forked from OSchip/llvm-project
[scudo] Fix EXPECT_DEATH tests
Put allocate/deallocate next to memory access inside EXPECT_DEATH block. This way we reduce probability that memory is not mapped by unrelated code. It's still not absolutely guaranty that mmap does not happen so we repeat it few times to be sure. Reviewed By: cryptoad Differential Revision: https://reviews.llvm.org/D102886
This commit is contained in:
parent
6c05f2dab3
commit
96b760607f
|
@ -31,11 +31,19 @@ TEST(ScudoMapTest, MapNoAccessUnmap) {
|
||||||
|
|
||||||
TEST(ScudoMapTest, MapUnmap) {
|
TEST(ScudoMapTest, MapUnmap) {
|
||||||
const scudo::uptr Size = 4 * scudo::getPageSizeCached();
|
const scudo::uptr Size = 4 * scudo::getPageSizeCached();
|
||||||
|
EXPECT_DEATH(
|
||||||
|
{
|
||||||
|
// Repeat few time to avoid missing crash if it's mmaped by unrelated
|
||||||
|
// code.
|
||||||
|
for (int i = 0; i < 10; ++i) {
|
||||||
void *P = scudo::map(nullptr, Size, MappingName, 0, nullptr);
|
void *P = scudo::map(nullptr, Size, MappingName, 0, nullptr);
|
||||||
EXPECT_NE(P, nullptr);
|
if (!P)
|
||||||
memset(P, 0xaa, Size);
|
continue;
|
||||||
scudo::unmap(P, Size, 0, nullptr);
|
scudo::unmap(P, Size, 0, nullptr);
|
||||||
EXPECT_DEATH(memset(P, 0xbb, Size), "");
|
memset(P, 0xbb, Size);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"");
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(ScudoMapTest, MapWithGuardUnmap) {
|
TEST(ScudoMapTest, MapWithGuardUnmap) {
|
||||||
|
|
|
@ -39,9 +39,20 @@ template <typename Config> static void testSecondaryBasic(void) {
|
||||||
// the test on arm32 until we can debug it further.
|
// the test on arm32 until we can debug it further.
|
||||||
#ifndef __arm__
|
#ifndef __arm__
|
||||||
// If the Secondary can't cache that pointer, it will be unmapped.
|
// If the Secondary can't cache that pointer, it will be unmapped.
|
||||||
if (!L->canCache(Size))
|
if (!L->canCache(Size)) {
|
||||||
EXPECT_DEATH(memset(P, 'A', Size), "");
|
EXPECT_DEATH(
|
||||||
|
{
|
||||||
|
// Repeat few time to avoid missing crash if it's mmaped by unrelated
|
||||||
|
// code.
|
||||||
|
for (int i = 0; i < 10; ++i) {
|
||||||
|
P = L->allocate(scudo::Options{}, Size);
|
||||||
|
L->deallocate(scudo::Options{}, P);
|
||||||
|
memset(P, 'A', Size);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"");
|
||||||
#endif // __arm__
|
#endif // __arm__
|
||||||
|
}
|
||||||
|
|
||||||
const scudo::uptr Align = 1U << 16;
|
const scudo::uptr Align = 1U << 16;
|
||||||
P = L->allocate(scudo::Options{}, Size + Align, Align);
|
P = L->allocate(scudo::Options{}, Size + Align, Align);
|
||||||
|
|
Loading…
Reference in New Issue