2009-06-19 02:51:09 +02:00
|
|
|
2009-06-15 Petr Baudis <pasky@suse.cz>
|
|
|
|
|
|
|
|
* malloc/hooks.c (free_check): Do not invoke mem2chunk_check()
|
|
|
|
without main_arena mutex held.
|
|
|
|
|
|
|
|
diff --git a/malloc/hooks.c b/malloc/hooks.c
|
|
|
|
index 622a815..47d3c85 100644
|
|
|
|
--- malloc/hooks.c
|
|
|
|
+++ malloc/hooks.c
|
|
|
|
@@ -276,25 +276,33 @@ free_check(mem, caller) Void_t* mem; const Void_t *caller;
|
2009-06-12 16:37:00 +02:00
|
|
|
mchunkptr p;
|
|
|
|
|
|
|
|
if(!mem) return;
|
|
|
|
+#ifndef ATOMIC_FASTBINS
|
|
|
|
+ (void)mutex_lock(&main_arena.mutex);
|
|
|
|
+#endif
|
|
|
|
p = mem2chunk_check(mem, NULL);
|
|
|
|
if(!p) {
|
2009-06-19 02:51:09 +02:00
|
|
|
+#ifndef ATOMIC_FASTBINS
|
|
|
|
+ (void)mutex_unlock(&main_arena.mutex);
|
|
|
|
+#endif
|
2009-06-12 16:37:00 +02:00
|
|
|
malloc_printerr(check_action, "free(): invalid pointer", mem);
|
2009-06-19 02:51:09 +02:00
|
|
|
return;
|
2009-06-12 16:37:00 +02:00
|
|
|
}
|
|
|
|
#if HAVE_MMAP
|
|
|
|
if (chunk_is_mmapped(p)) {
|
|
|
|
munmap_chunk(p);
|
|
|
|
- return;
|
2009-06-19 02:51:09 +02:00
|
|
|
- }
|
|
|
|
+ } else
|
2009-06-12 16:37:00 +02:00
|
|
|
#endif
|
2009-06-19 02:51:09 +02:00
|
|
|
+ {
|
2009-06-12 16:37:00 +02:00
|
|
|
#if 0 /* Erase freed memory. */
|
2009-06-19 02:51:09 +02:00
|
|
|
- memset(mem, 0, chunksize(p) - (SIZE_SZ+1));
|
|
|
|
+ memset(mem, 0, chunksize(p) - (SIZE_SZ+1));
|
|
|
|
#endif
|
2009-06-12 16:37:00 +02:00
|
|
|
#ifdef ATOMIC_FASTBINS
|
2009-06-19 02:51:09 +02:00
|
|
|
- _int_free(&main_arena, p, 0);
|
|
|
|
+ _int_free(&main_arena, p, 0);
|
2009-06-12 16:37:00 +02:00
|
|
|
#else
|
|
|
|
- (void)mutex_lock(&main_arena.mutex);
|
2009-06-19 02:51:09 +02:00
|
|
|
- _int_free(&main_arena, p);
|
|
|
|
+ _int_free(&main_arena, p);
|
2009-06-12 16:37:00 +02:00
|
|
|
+#endif
|
2009-06-19 02:51:09 +02:00
|
|
|
+ }
|
|
|
|
+#ifndef ATOMIC_FASTBINS
|
2009-06-12 16:37:00 +02:00
|
|
|
(void)mutex_unlock(&main_arena.mutex);
|
|
|
|
#endif
|
|
|
|
}
|