Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
various cosmetics and comments improvements
[simgrid.git] / src / xbt / mmalloc / mmemalign.c
index 690496a..cf0cef7 100644 (file)
@@ -9,42 +9,48 @@
 
 #include "mmprivate.h"
 
-void *
-mmemalign (void *md, size_t alignment, size_t size)
+void *mmemalign(xbt_mheap_t mdp, size_t alignment, size_t size)
 {
-  voidresult;
+  void *result;
   unsigned long int adj;
   struct alignlist *l;
-  struct mdesc *mdp;
-
-  if ((result = mmalloc (md, size + alignment - 1)) != NULL)
-  {
-    adj = RESIDUAL (result, alignment);
-    if (adj != 0)
-    {
-      mdp = MD_TO_MDP (md);
-      for (l = mdp -> aligned_blocks; l != NULL; l = l -> next)
-      {
-        if (l -> aligned == NULL)
-        {
+
+  if ((result = mmalloc(mdp, size + alignment - 1)) != NULL) {
+    adj = RESIDUAL(result, alignment);
+    if (adj != 0) {
+      for (l = mdp->aligned_blocks; l != NULL; l = l->next) {
+        if (l->aligned == NULL) {
           /* This slot is free.  Use it.  */
           break;
         }
       }
-      if (l == NULL)
-      {
-        l = (struct alignlist *) mmalloc (md, sizeof (struct alignlist));
-        if (l == NULL)
-        {
-          mfree (md, result);
+      if (l == NULL) {
+        l = (struct alignlist *) mmalloc(mdp, sizeof(struct alignlist));
+        if (l == NULL) {
+          mfree(mdp, result);
           return (NULL);
         }
-        l -> next = mdp -> aligned_blocks;
-        mdp -> aligned_blocks = l;
+        l->next = mdp->aligned_blocks;
+        mdp->aligned_blocks = l;
       }
-      l -> exact = result;
-      result = l -> aligned = (char*) result + alignment - adj;
+      l->exact = result;
+      result = l->aligned = (char *) result + alignment - adj;
     }
   }
   return (result);
 }
+
+/* Cache the pagesize for the current host machine.  Note that if the host
+   does not readily provide a getpagesize() function, we need to emulate it
+   elsewhere, not clutter up this file with lots of kluges to try to figure
+   it out. */
+static size_t cache_pagesize;
+
+void *mvalloc(xbt_mheap_t mdp, size_t size)
+{
+  if (cache_pagesize == 0)
+    cache_pagesize = getpagesize();
+
+  return mmemalign(mdp, cache_pagesize, size);
+}
+