2017-03-17 Chris Evans <scarybeasts@gmail.com>
* malloc/malloc.c (unlink): Add consistency check between size and
next->prev->size, to further harden against 1-byte overflows.
2016-10-27 Florian Weimer <fweimer@redhat.com>
* malloc/malloc.c (sysmalloc): Initialize previous size field of
mmaped chunks.
Gbp-Pq: Topic any
Gbp-Pq: Name cvs-malloc-hardening.diff
/* Take a chunk off a bin list */
#define unlink(AV, P, BK, FD) { \
+ if (__builtin_expect (chunksize(P) != next_chunk(P)->prev_size, 0)) \
+ malloc_printerr (check_action, "corrupted size vs. prev_size", P, AV); \
FD = P->fd; \
BK = P->bk; \
if (__builtin_expect (FD->bk != P || BK->fd != P, 0)) \
else
{
p = (mchunkptr) mm;
+ p->prev_size = 0;
set_head (p, size | IS_MMAPPED);
}