about summary refs log tree commit diff
path: root/malloc/arena.c
diff options
context:
space:
mode:
authorSiddhesh Poyarekar <siddhesh@redhat.com>2012-09-25 14:10:29 +0530
committerSiddhesh Poyarekar <siddhesh@redhat.com>2012-09-25 14:30:52 +0530
commit9fab36eb583c0e585e83a01253299afed9ea9a11 (patch)
tree948ce03e0a724c8a3a7bca0fc1dbb7655f94e64e /malloc/arena.c
parent2b4f00d1a42b705521ca205ad8285dde82d84f2b (diff)
downloadglibc-9fab36eb583c0e585e83a01253299afed9ea9a11.tar.gz
glibc-9fab36eb583c0e585e83a01253299afed9ea9a11.tar.xz
glibc-9fab36eb583c0e585e83a01253299afed9ea9a11.zip
Shrink heap on linux when overcommit_memory == 2
Using madvise with MADV_DONTNEED to release memory back to the kernel
is not sufficient to change the commit charge accounted against the
process on Linux.  It is OK however, when overcommit is enabled or is
heuristic.  However, when overcommit is restricted to a percentage of
memory setting the contents of /proc/sys/vm/overcommit_memory as 2, it
makes a difference since memory requests will fail.  Hence, we do what
we do with secure exec binaries, which is to call mmap on the region
to be dropped with MAP_FIXED. This internally unmaps the pages in
question and reduces the amount of memory accounted against the
process.
Diffstat (limited to 'malloc/arena.c')
-rw-r--r--malloc/arena.c9
1 files changed, 6 insertions, 3 deletions
diff --git a/malloc/arena.c b/malloc/arena.c
index f24e76c4f6..b209e3b7cd 100644
--- a/malloc/arena.c
+++ b/malloc/arena.c
@@ -19,6 +19,9 @@
 
 #include <stdbool.h>
 
+/* Get the implementation for check_may_shrink_heap.  */
+#include <malloc-sysdep.h>
+
 /* Compile-time constants.  */
 
 #define HEAP_MIN_SIZE (32*1024)
@@ -621,9 +624,9 @@ shrink_heap(heap_info *h, long diff)
   new_size = (long)h->size - diff;
   if(new_size < (long)sizeof(*h))
     return -1;
-  /* Try to re-map the extra heap space freshly to save memory, and
-     make it inaccessible. */
-  if (__builtin_expect (__libc_enable_secure, 0))
+  /* Try to re-map the extra heap space freshly to save memory, and make it
+     inaccessible.  See malloc-sysdep.h to know when this is true.  */
+  if (__builtin_expect (check_may_shrink_heap (), 0))
     {
       if((char *)MMAP((char *)h + new_size, diff, PROT_NONE,
 		      MAP_FIXED) == (char *) MAP_FAILED)