From aceb22c1f59231909777f7d0a6b955adbf7096a2 Mon Sep 17 00:00:00 2001 From: Siddhesh Poyarekar Date: Wed, 26 Oct 2016 15:07:07 +0530 Subject: Remove references to sbrk to grow/shrink arenas The manual incorrectly references sbrk as the method used to grow and shrink heaps and the fact that M_TRIM_THRESHOLD and M_TOP_PAD control that behavior. In reality, a heap may be grown or shrunk through multiple methods depending on whether it is the main arena (in which case sbrk is correct) or not (in which case, there are a number of strategies including allocating an additional heap to grow an arena and/or 'mprotect' a region to make it available for allocation). Remove references to sbrk so that it covers the behavior more accurately. * manual/memory.texi (M_TOP_PAD): Remove reference to sbrk. (M_TRIM_THRESHOLD): Likewise. --- manual/memory.texi | 12 +++++------- 1 file changed, 5 insertions(+), 7 deletions(-) (limited to 'manual') diff --git a/manual/memory.texi b/manual/memory.texi index 4ad2c96..b66de60 100644 --- a/manual/memory.texi +++ b/manual/memory.texi @@ -1132,11 +1132,10 @@ This parameter can also be set for the process at startup by setting the environment variable @env{MALLOC_MMAP_PERTURB_} to the desired value. @item M_TOP_PAD -This parameter determines the amount of extra memory to obtain from the -system when a call to @code{sbrk} is required. It also specifies the -number of bytes to retain when shrinking the heap by calling @code{sbrk} -with a negative argument. This provides the necessary hysteresis in -heap size such that excessive amounts of system calls can be avoided. +This parameter determines the amount of extra memory to obtain from the system +when an arena needs to be extended. It also specifies the number of bytes to +retain when shrinking an arena. This provides the necessary hysteresis in heap +size such that excessive amounts of system calls can be avoided. The default value of this parameter is @code{0}. @@ -1145,8 +1144,7 @@ environment variable @env{MALLOC_TOP_PAD_} to the desired value. @item M_TRIM_THRESHOLD This is the minimum size (in bytes) of the top-most, releasable chunk -that will cause @code{sbrk} to be called with a negative argument in -order to return memory to the system. +that will trigger a system call in order to return memory to the system. If this parameter is not set, the default value is set as 128 KiB and the threshold is adjusted dynamically to suit the allocation patterns of the -- cgit v1.1