aboutsummaryrefslogtreecommitdiff
path: root/malloc
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>2006-10-13 20:53:14 +0000
committerUlrich Drepper <drepper@redhat.com>2006-10-13 20:53:14 +0000
commitcc7eecbfc09fb9f1c9e1aa33e8490f1ade0530b3 (patch)
tree2687e5c28506d4da77485f8a8ea9c24c1ceb19c1 /malloc
parentdbc3d56b704c7858de411b59688efe7860dfe580 (diff)
downloadglibc-cc7eecbfc09fb9f1c9e1aa33e8490f1ade0530b3.zip
glibc-cc7eecbfc09fb9f1c9e1aa33e8490f1ade0530b3.tar.gz
glibc-cc7eecbfc09fb9f1c9e1aa33e8490f1ade0530b3.tar.bz2
[BZ #3313]
* malloc/malloc.c (malloc_consolidate): Don't use get_fast_max to determine highest fast bin to consolidate, always look into all of them. (do_check_malloc_state): Only require for empty bins for large sizes in main arena.
Diffstat (limited to 'malloc')
-rw-r--r--malloc/malloc.c8
1 files changed, 8 insertions, 0 deletions
diff --git a/malloc/malloc.c b/malloc/malloc.c
index e4b693c..38ceb1e 100644
--- a/malloc/malloc.c
+++ b/malloc/malloc.c
@@ -4692,7 +4692,15 @@ static void malloc_consolidate(av) mstate av;
reused anyway.
*/
+#if 0
+ /* It is wrong to limit the fast bins to search using get_max_fast
+ because, except for the main arena, all the others might have
+ blocks in the high fast bins. It's not worth it anyway, just
+ search all bins all the time. */
maxfb = &(av->fastbins[fastbin_index(get_max_fast ())]);
+#else
+ maxfb = &(av->fastbins[NFASTBINS]);
+#endif
fb = &(av->fastbins[0]);
do {
if ( (p = *fb) != 0) {