diff options
author | Wilco Dijkstra <wdijkstr@arm.com> | 2019-05-10 16:38:21 +0100 |
---|---|---|
committer | Wilco Dijkstra <wdijkstr@arm.com> | 2019-05-22 14:37:54 +0100 |
commit | 58d2672f64176fcb323859d3bd5240fb1cf8f25c (patch) | |
tree | 7aa2258568d71b0cb31620b3594eccc3fd3bf522 | |
parent | 059d6750f923b2c3aa06c82befa430142ef10389 (diff) | |
download | glibc-58d2672f64176fcb323859d3bd5240fb1cf8f25c.tar glibc-58d2672f64176fcb323859d3bd5240fb1cf8f25c.tar.gz glibc-58d2672f64176fcb323859d3bd5240fb1cf8f25c.tar.bz2 glibc-58d2672f64176fcb323859d3bd5240fb1cf8f25c.zip |
Fix tcache count maximum (BZ #24531)
The tcache counts[] array is a char, which has a very small range and thus
may overflow. When setting tcache_count tunable, there is no overflow check.
However the tunable must not be larger than the maximum value of the tcache
counts[] array, otherwise it can overflow when filling the tcache.
[BZ #24531]
* malloc/malloc.c (MAX_TCACHE_COUNT): New define.
(do_set_tcache_count): Only update if count is small enough.
* manual/tunables.texi (glibc.malloc.tcache_count): Document max value.
(cherry picked from commit 5ad533e8e65092be962e414e0417112c65d154fb)
-rw-r--r-- | ChangeLog | 7 | ||||
-rw-r--r-- | malloc/malloc.c | 9 | ||||
-rw-r--r-- | manual/tunables.texi | 4 |
3 files changed, 16 insertions, 4 deletions
@@ -1,3 +1,10 @@ +2019-05-22 Wilco Dijkstra <wdijkstr@arm.com> + + [BZ #24531] + * malloc/malloc.c (MAX_TCACHE_COUNT): New define. + (do_set_tcache_count): Only update if count is small enough. + * manual/tunables.texi (glibc.malloc.tcache_count): Document max value. + 2019-05-15 Mark Wielaard <mark@klomp.org> [BZ#24476] diff --git a/malloc/malloc.c b/malloc/malloc.c index 0e9a2e23ec..0e7970001a 100644 --- a/malloc/malloc.c +++ b/malloc/malloc.c @@ -2912,6 +2912,8 @@ typedef struct tcache_perthread_struct tcache_entry *entries[TCACHE_MAX_BINS]; } tcache_perthread_struct; +#define MAX_TCACHE_COUNT 127 /* Maximum value of counts[] entries. */ + static __thread bool tcache_shutting_down = false; static __thread tcache_perthread_struct *tcache = NULL; @@ -5122,8 +5124,11 @@ static inline int __always_inline do_set_tcache_count (size_t value) { - LIBC_PROBE (memory_tunable_tcache_count, 2, value, mp_.tcache_count); - mp_.tcache_count = value; + if (value <= MAX_TCACHE_COUNT) + { + LIBC_PROBE (memory_tunable_tcache_count, 2, value, mp_.tcache_count); + mp_.tcache_count = value; + } return 1; } diff --git a/manual/tunables.texi b/manual/tunables.texi index bb4819bdf1..9dccf2ee7f 100644 --- a/manual/tunables.texi +++ b/manual/tunables.texi @@ -188,8 +188,8 @@ per-thread cache. The default (and maximum) value is 1032 bytes on @deftp Tunable glibc.malloc.tcache_count The maximum number of chunks of each size to cache. The default is 7. -There is no upper limit, other than available system memory. If set -to zero, the per-thread cache is effectively disabled. +The upper limit is 127. If set to zero, the per-thread cache is effectively +disabled. The approximate maximum overhead of the per-thread cache is thus equal to the number of bins times the chunk count in each bin times the size |