]> CyberLeo.Net >> Repos - FreeBSD/stable/9.git/commit
MFC r262277:
authordavidxu <davidxu@ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f>
Thu, 27 Feb 2014 02:41:41 +0000 (02:41 +0000)
committerdavidxu <davidxu@ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f>
Thu, 27 Feb 2014 02:41:41 +0000 (02:41 +0000)
commit7d036a5bdb8d3f6f974b6a055fda558442d20538
tree66966e0549ec4609c09b828361c5698e472d135d
parenta7c1b8dc5a7e916c673676f034687b2993a840e5
MFC r262277:

malloc_aligned() may not leave enough space for pointer to allocated memory,
saving the pointer will overwrite bytes belongs to another memory block
unexpectly, to fix the problem, use (allocated address + sizeof(void *)) as
initial value, and slip to next aligned address, so maximum extra bytes is
sizeof(void *) + align - 1.

Tested by: Andre Albsmeier < mail at ma17 dot ata dot myota dot orgndre >

MFC r262334:

Increase alignment to size of pointer if the alignment is too small.
Some modules do not align data at least to size of pointer, they uses a
smaller alignment, but our pointer should be aligned to its native
boundary, otherwise on some platforms, hardware alignment checking
will cause bus error.

git-svn-id: svn://svn.freebsd.org/base/stable/9@262545 ccf9f872-aa2e-dd11-9fc8-001c23d0bc1f
libexec/rtld-elf/xmalloc.c