aboutsummaryrefslogtreecommitdiff
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.zip
glibc-9fab36eb583c0e585e83a01253299afed9ea9a11.tar.gz
glibc-9fab36eb583c0e585e83a01253299afed9ea9a11.tar.bz2
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 f24e76c..b209e3b 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)