bug-gnulib
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

vma-iter: provide failure indication


From: Bruno Haible
Subject: vma-iter: provide failure indication
Date: Fri, 10 Mar 2017 18:50:42 +0100
User-agent: KMail/5.1.3 (Linux/4.4.0-66-generic; KDE/5.18.0; x86_64; ; )

Callers of vma_iterate() have no way of knowing about failure.
This fixes it.


2017-03-10  Bruno Haible  <address@hidden>

        vma-iter: Let callers know about error.
        * lib/vma-iter.h (vma_iterate): Return 'int', not 'void'.
        * lib/vma-iter.c (vma_iterate): Return -1 in case of error.

diff --git a/lib/vma-iter.h b/lib/vma-iter.h
index 0c00159..36c8d66 100644
--- a/lib/vma-iter.h
+++ b/lib/vma-iter.h
@@ -44,8 +44,9 @@ typedef int (*vma_iterate_callback_fn) (void *data,
      - FLAGS is a combination of the VMA_* bits.
    If the callback returns 0, the iteration continues.  If it returns 1,
    the iteration terminates prematurely.
-   This function may open file descriptors, but does not call malloc().  */
-extern void vma_iterate (vma_iterate_callback_fn callback, void *data);
+   This function may open file descriptors, but does not call malloc().
+   Return 0 if all went well, or -1 in case of error.  */
+extern int vma_iterate (vma_iterate_callback_fn callback, void *data);
 
 /* The macro VMA_ITERATE_SUPPORTED indicates that vma_iterate is supported on
    this platform.
diff --git a/lib/vma-iter.c b/lib/vma-iter.c
index f2c5282..d5ff6ff 100644
--- a/lib/vma-iter.c
+++ b/lib/vma-iter.c
@@ -157,7 +157,7 @@ rof_close (struct rofile *rof)
 #endif
 
 
-void
+int
 vma_iterate (vma_iterate_callback_fn callback, void *data)
 {
 #if defined __linux__ /* || defined __CYGWIN__ */
@@ -167,7 +167,7 @@ vma_iterate (vma_iterate_callback_fn callback, void *data)
 
   /* Open the current process' maps file.  It describes one VMA per line.  */
   if (rof_open (&rof, "/proc/self/maps") < 0)
-    return;
+    return -1;
 
   for (;;)
     {
@@ -199,6 +199,7 @@ vma_iterate (vma_iterate_callback_fn callback, void *data)
         break;
     }
   rof_close (&rof);
+  return 0;
 
 #elif defined __FreeBSD__ || defined __NetBSD__
 
@@ -207,7 +208,7 @@ vma_iterate (vma_iterate_callback_fn callback, void *data)
 
   /* Open the current process' maps file.  It describes one VMA per line.  */
   if (rof_open (&rof, "/proc/curproc/map") < 0)
-    return;
+    return -1;
 
   for (;;)
     {
@@ -246,6 +247,7 @@ vma_iterate (vma_iterate_callback_fn callback, void *data)
         break;
     }
   rof_close (&rof);
+  return 0;
 
 #elif defined __sgi || defined __osf__ /* IRIX, OSF/1 */
 
@@ -284,7 +286,7 @@ vma_iterate (vma_iterate_callback_fn callback, void *data)
 
   fd = open (fname, O_RDONLY);
   if (fd < 0)
-    return;
+    return -1;
 
   if (ioctl (fd, PIOCNMAP, &nmaps) < 0)
     goto fail2;
@@ -351,13 +353,13 @@ vma_iterate (vma_iterate_callback_fn callback, void *data)
     }
   munmap (auxmap, memneed);
   close (fd);
-  return;
+  return 0;
 
  fail1:
   munmap (auxmap, memneed);
  fail2:
   close (fd);
-  return;
+  return -1;
 
 #elif defined __APPLE__ && defined __MACH__ /* Mac OS X */
 
@@ -419,6 +421,7 @@ vma_iterate (vma_iterate_callback_fn callback, void *data)
       if (callback (data, address, address + size, flags))
         break;
     }
+  return 0;
 
 #elif (defined _WIN32 || defined __WIN32__) || defined __CYGWIN__
   /* Windows platform.  Use the native Windows API.  */
@@ -470,6 +473,7 @@ vma_iterate (vma_iterate_callback_fn callback, void *data)
           }
       address = (uintptr_t)info.BaseAddress + info.RegionSize;
     }
+  return 0;
 
 #elif defined __BEOS__ || defined __HAIKU__
   /* Use the BeOS specific API.  */
@@ -494,6 +498,7 @@ vma_iterate (vma_iterate_callback_fn callback, void *data)
       if (callback (data, start, end, flags))
         break;
     }
+  return 0;
 
 #elif HAVE_MQUERY /* OpenBSD */
 
@@ -587,6 +592,12 @@ vma_iterate (vma_iterate_callback_fn callback, void *data)
       if (address + pagesize - 1 < pagesize) /* wrap around? */
         break;
     }
+  return 0;
+
+#else
+
+  /* Not implemented.  */
+  return -1;
 
 #endif
 }




reply via email to

[Prev in Thread] Current Thread [Next in Thread]