Update.
authorUlrich Drepper <drepper@redhat.com>
Thu, 9 Sep 2004 01:58:35 +0000 (01:58 +0000)
committerUlrich Drepper <drepper@redhat.com>
Thu, 9 Sep 2004 01:58:35 +0000 (01:58 +0000)
2004-09-08  Ulrich Drepper  <drepper@redhat.com>

* malloc/malloc.c (_int_free): Add inexpensive double free test.

ChangeLog
malloc/malloc.c

index a906d61..c062399 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,7 @@
+2004-09-08  Ulrich Drepper  <drepper@redhat.com>
+
+       * malloc/malloc.c (_int_free): Add inexpensive double free test.
+
 2004-09-08  Roland McGrath  <roland@redhat.com>
 
        * malloc/mcheck.c: Don't use __P.
index 5636d5c..4db4051 100644 (file)
@@ -4201,6 +4201,13 @@ _int_free(mstate av, Void_t* mem)
 
       set_fastchunks(av);
       fb = &(av->fastbins[fastbin_index(size)]);
+      /* Another simple check: make sure the top of the bin is not the
+        record we are going to add (i.e., double free).  */
+      if (__builtin_expect (*fb == p, 0))
+       {
+         malloc_printf_nc (check_action, "double free(%p)!\n", mem);
+         return;
+       }
       p->fd = *fb;
       *fb = p;
     }