(_int_malloc): Limit number of unsorted blocks to sort in each call.
authordrepper <drepper>
Sat, 19 Aug 2006 22:33:32 +0000 (22:33 +0000)
committerdrepper <drepper>
Sat, 19 Aug 2006 22:33:32 +0000 (22:33 +0000)
malloc/malloc.c

index 890d366..3f4ddcd 100644 (file)
@@ -4055,6 +4055,8 @@ _int_malloc(mstate av, size_t bytes)
 
   for(;;) {
 
+    int iters = 0;
+    bool any_larger = false;
     while ( (victim = unsorted_chunks(av)->bk) != unsorted_chunks(av)) {
       bck = victim->bk;
       if (__builtin_expect (victim->size <= 2 * SIZE_SZ, 0)
@@ -4145,6 +4147,12 @@ _int_malloc(mstate av, size_t bytes)
         }
       }
 
+      if (size >= nb)
+       any_larger = true;
+#define MAX_ITERS      10000
+      if (++iters == MAX_ITERS)
+       break;
+
       mark_bin(av, victim_index);
       victim->bk = bck;
       victim->fd = fwd;