From 3e00177e5a53c83916f8e0edc6d77d8c2a7fdbfb Mon Sep 17 00:00:00 2001 From: Ulrich Drepper Date: Fri, 10 Sep 2004 19:56:41 +0000 Subject: nt_free): Only do arena boundary check for contiguous arenas. --- malloc/malloc.c | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) (limited to 'malloc') diff --git a/malloc/malloc.c b/malloc/malloc.c index 0d0990cc35..665d7a4b3e 100644 --- a/malloc/malloc.c +++ b/malloc/malloc.c @@ -4229,8 +4229,9 @@ _int_free(mstate av, Void_t* mem) if (__builtin_expect (p == av->top, 0)) goto double_free; /* Or whether the next chunk is beyond the boundaries of the arena. */ - if (__builtin_expect ((char *) nextchunk >= ((char *) av->top - + chunksize(av->top)), 0)) + if (__builtin_expect (contiguous (av) + && (char *) nextchunk + >= ((char *) av->top + chunksize(av->top)), 0)) goto double_free; /* Or whether the block is actually not marked used. */ if (__builtin_expect (!prev_inuse(nextchunk), 0)) -- cgit v1.2.3