Previous: Tunable names, Up: Tunables [Contents][Index]
Memory allocation behavior can be modified by setting any of the
following tunables in the malloc
namespace:
This tunable supersedes the MALLOC_CHECK_
environment variable and is
identical in features.
Setting this tunable enables a special (less efficient) memory allocator for the malloc family of functions that is designed to be tolerant against simple errors such as double calls of free with the same argument, or overruns of a single byte (off-by-one bugs). Not all such errors can be protected against, however, and memory leaks can result. The following list describes the values that this tunable can take and the effect they have on malloc functionality:
0
Ignore all errors. The default allocator continues to be in
use, but all errors are silently ignored.
1
Report errors. The alternate allocator is selected and heap
corruption, if detected, is reported as diagnostic messages to stderr
and the program continues execution.
2
Abort on errors. The alternate allocator is selected and if
heap corruption is detected, the program is ended immediately by calling
abort
.
3
Fully enabled. The alternate allocator is selected and is fully
functional. That is, if heap corruption is detected, a verbose diagnostic
message is printed to stderr
and the program is ended by calling
abort
.
Like MALLOC_CHECK_
, glibc.malloc.check
has a problem in that it
diverges from normal program behavior by writing to stderr
, which could
by exploited in SUID and SGID binaries. Therefore, glibc.malloc.check
is disabled by default for SUID and SGID binaries. This can be enabled again
by the system administrator by adding a file /etc/suid-debug; the
content of the file could be anything or even empty.
This tunable supersedes the MALLOC_TOP_PAD_
environment variable and is
identical in features.
This tunable determines the amount of extra memory in bytes to obtain from the system when any of the arenas need to be extended. It also specifies the number of bytes to retain when shrinking any of the arenas. This provides the necessary hysteresis in heap size such that excessive amounts of system calls can be avoided.
The default value of this tunable is ‘0’.
This tunable supersedes the MALLOC_PERTURB_
environment variable and is
identical in features.
If set to a non-zero value, memory blocks are initialized with values depending on some low order bits of this tunable when they are allocated (except when allocated by calloc) and freed. This can be used to debug the use of uninitialized or freed heap memory. Note that this option does not guarantee that the freed block will have any specific values. It only guarantees that the content the block had before it was freed will be overwritten.
The default value of this tunable is ‘0’.
This tunable supersedes the MALLOC_MMAP_THRESHOLD_
environment variable
and is identical in features.
When this tunable is set, all chunks larger than this value in bytes are
allocated outside the normal heap, using the mmap
system call. This way
it is guaranteed that the memory for these chunks can be returned to the system
on free
. Note that requests smaller than this threshold might still be
allocated via mmap
.
If this tunable is not set, the default value is set to ‘131072’ bytes and the threshold is adjusted dynamically to suit the allocation patterns of the program. If the tunable is set, the dynamic adjustment is disabled and the value is set as static.
This tunable supersedes the MALLOC_TRIM_THRESHOLD_
environment variable
and is identical in features.
The value of this tunable is the minimum size (in bytes) of the top-most, releasable chunk in an arena that will trigger a system call in order to return memory to the system from that arena.
If this tunable is not set, the default value is set as 128 KB and the threshold is adjusted dynamically to suit the allocation patterns of the program. If the tunable is set, the dynamic adjustment is disabled and the value is set as static.
This tunable supersedes the MALLOC_MMAP_MAX_
environment variable and is
identical in features.
The value of this tunable is maximum number of chunks to allocate with
mmap
. Setting this to zero disables all use of mmap
.
The default value of this tunable is ‘65536’.
This tunable supersedes the MALLOC_ARENA_TEST
environment variable and is
identical in features.
The glibc.malloc.arena_test
tunable specifies the number of arenas that
can be created before the test on the limit to the number of arenas is
conducted. The value is ignored if glibc.malloc.arena_max
is set.
The default value of this tunable is 2 for 32-bit systems and 8 for 64-bit systems.
This tunable supersedes the MALLOC_ARENA_MAX
environment variable and is
identical in features.
This tunable sets the number of arenas to use in a process regardless of the number of cores in the system.
The default value of this tunable is 0
, meaning that the limit on the
number of arenas is determined by the number of CPU cores online. For 32-bit
systems the limit is twice the number of cores online and on 64-bit systems, it
is 8 times the number of cores online.
Previous: Tunable names, Up: Tunables [Contents][Index]