forked from OSchip/llvm-project
[tsan] Respect no_huge_pages_for_shadow.
Disable huge pages in the TSan shadow regions when no_huge_pages_for_shadow == true (default). Reviewed By: eugenis Differential Revision: https://reviews.llvm.org/D85841
This commit is contained in:
parent
bc45bab7eb
commit
96855125e7
|
@ -46,7 +46,8 @@ static void DontDumpShadow(uptr addr, uptr size) {
|
|||
#if !SANITIZER_GO
|
||||
void InitializeShadowMemory() {
|
||||
// Map memory shadow.
|
||||
if (!MmapFixedNoReserve(ShadowBeg(), ShadowEnd() - ShadowBeg(), "shadow")) {
|
||||
if (!MmapFixedSuperNoReserve(ShadowBeg(), ShadowEnd() - ShadowBeg(),
|
||||
"shadow")) {
|
||||
Printf("FATAL: ThreadSanitizer can not mmap the shadow memory\n");
|
||||
Printf("FATAL: Make sure to compile with -fPIE and to link with -pie.\n");
|
||||
Die();
|
||||
|
@ -90,8 +91,6 @@ void InitializeShadowMemory() {
|
|||
DCHECK(0);
|
||||
}
|
||||
#endif
|
||||
NoHugePagesInShadow(MemToShadow(kMadviseRangeBeg),
|
||||
kMadviseRangeSize * kShadowMultiplier);
|
||||
DontDumpShadow(ShadowBeg(), ShadowEnd() - ShadowBeg());
|
||||
DPrintf("memory shadow: %zx-%zx (%zuGB)\n",
|
||||
ShadowBeg(), ShadowEnd(),
|
||||
|
@ -100,12 +99,11 @@ void InitializeShadowMemory() {
|
|||
// Map meta shadow.
|
||||
const uptr meta = MetaShadowBeg();
|
||||
const uptr meta_size = MetaShadowEnd() - meta;
|
||||
if (!MmapFixedNoReserve(meta, meta_size, "meta shadow")) {
|
||||
if (!MmapFixedSuperNoReserve(meta, meta_size, "meta shadow")) {
|
||||
Printf("FATAL: ThreadSanitizer can not mmap the shadow memory\n");
|
||||
Printf("FATAL: Make sure to compile with -fPIE and to link with -pie.\n");
|
||||
Die();
|
||||
}
|
||||
NoHugePagesInShadow(meta, meta_size);
|
||||
DontDumpShadow(meta, meta_size);
|
||||
DPrintf("meta shadow: %zx-%zx (%zuGB)\n",
|
||||
meta, meta + meta_size, meta_size >> 30);
|
||||
|
|
|
@ -256,7 +256,8 @@ void MapShadow(uptr addr, uptr size) {
|
|||
const uptr kPageSize = GetPageSizeCached();
|
||||
uptr shadow_begin = RoundDownTo((uptr)MemToShadow(addr), kPageSize);
|
||||
uptr shadow_end = RoundUpTo((uptr)MemToShadow(addr + size), kPageSize);
|
||||
if (!MmapFixedNoReserve(shadow_begin, shadow_end - shadow_begin, "shadow"))
|
||||
if (!MmapFixedSuperNoReserve(shadow_begin, shadow_end - shadow_begin,
|
||||
"shadow"))
|
||||
Die();
|
||||
|
||||
// Meta shadow is 2:1, so tread carefully.
|
||||
|
@ -269,7 +270,8 @@ void MapShadow(uptr addr, uptr size) {
|
|||
if (!data_mapped) {
|
||||
// First call maps data+bss.
|
||||
data_mapped = true;
|
||||
if (!MmapFixedNoReserve(meta_begin, meta_end - meta_begin, "meta shadow"))
|
||||
if (!MmapFixedSuperNoReserve(meta_begin, meta_end - meta_begin,
|
||||
"meta shadow"))
|
||||
Die();
|
||||
} else {
|
||||
// Mapping continous heap.
|
||||
|
@ -280,7 +282,8 @@ void MapShadow(uptr addr, uptr size) {
|
|||
return;
|
||||
if (meta_begin < mapped_meta_end)
|
||||
meta_begin = mapped_meta_end;
|
||||
if (!MmapFixedNoReserve(meta_begin, meta_end - meta_begin, "meta shadow"))
|
||||
if (!MmapFixedSuperNoReserve(meta_begin, meta_end - meta_begin,
|
||||
"meta shadow"))
|
||||
Die();
|
||||
mapped_meta_end = meta_end;
|
||||
}
|
||||
|
@ -293,7 +296,7 @@ void MapThreadTrace(uptr addr, uptr size, const char *name) {
|
|||
CHECK_GE(addr, TraceMemBeg());
|
||||
CHECK_LE(addr + size, TraceMemEnd());
|
||||
CHECK_EQ(addr, addr & ~((64 << 10) - 1)); // windows wants 64K alignment
|
||||
if (!MmapFixedNoReserve(addr, size, name)) {
|
||||
if (!MmapFixedSuperNoReserve(addr, size, name)) {
|
||||
Printf("FATAL: ThreadSanitizer can not mmap thread trace (%p/%p)\n",
|
||||
addr, size);
|
||||
Die();
|
||||
|
@ -957,7 +960,7 @@ static void MemoryRangeSet(ThreadState *thr, uptr pc, uptr addr, uptr size,
|
|||
u64 *p1 = p;
|
||||
p = RoundDown(end, kPageSize);
|
||||
UnmapOrDie((void*)p1, (uptr)p - (uptr)p1);
|
||||
if (!MmapFixedNoReserve((uptr)p1, (uptr)p - (uptr)p1))
|
||||
if (!MmapFixedSuperNoReserve((uptr)p1, (uptr)p - (uptr)p1))
|
||||
Die();
|
||||
// Set the ending.
|
||||
while (p < end) {
|
||||
|
|
|
@ -175,7 +175,7 @@ void MetaMap::ResetRange(Processor *proc, uptr p, uptr sz) {
|
|||
uptr metap = (uptr)MemToMeta(p0);
|
||||
uptr metasz = sz0 / kMetaRatio;
|
||||
UnmapOrDie((void*)metap, metasz);
|
||||
if (!MmapFixedNoReserve(metap, metasz))
|
||||
if (!MmapFixedSuperNoReserve(metap, metasz))
|
||||
Die();
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue