mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-14 00:14:19 +00:00
[asan] better debug diagnostics in asan compiler module
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@166102 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
02bf98ab38
commit
324d96b9e2
@ -534,7 +534,7 @@ void AddressSanitizer::createInitializerPoisonCalls(Module &M,
|
|||||||
|
|
||||||
bool AddressSanitizer::ShouldInstrumentGlobal(GlobalVariable *G) {
|
bool AddressSanitizer::ShouldInstrumentGlobal(GlobalVariable *G) {
|
||||||
Type *Ty = cast<PointerType>(G->getType())->getElementType();
|
Type *Ty = cast<PointerType>(G->getType())->getElementType();
|
||||||
DEBUG(dbgs() << "GLOBAL: " << *G);
|
DEBUG(dbgs() << "GLOBAL: " << *G << "\n");
|
||||||
|
|
||||||
if (BL->isIn(*G)) return false;
|
if (BL->isIn(*G)) return false;
|
||||||
if (!Ty->isSized()) return false;
|
if (!Ty->isSized()) return false;
|
||||||
@ -682,7 +682,7 @@ bool AddressSanitizer::insertGlobalRedzones(Module &M) {
|
|||||||
FirstDynamic = LastDynamic;
|
FirstDynamic = LastDynamic;
|
||||||
}
|
}
|
||||||
|
|
||||||
DEBUG(dbgs() << "NEW GLOBAL:\n" << *NewGlobal);
|
DEBUG(dbgs() << "NEW GLOBAL: " << *NewGlobal << "\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
ArrayType *ArrayOfGlobalStructTy = ArrayType::get(GlobalStructTy, n);
|
ArrayType *ArrayOfGlobalStructTy = ArrayType::get(GlobalStructTy, n);
|
||||||
@ -851,6 +851,7 @@ bool AddressSanitizer::maybeInsertAsanInitAtFunctionEntry(Function &F) {
|
|||||||
bool AddressSanitizer::runOnFunction(Function &F) {
|
bool AddressSanitizer::runOnFunction(Function &F) {
|
||||||
if (BL->isIn(F)) return false;
|
if (BL->isIn(F)) return false;
|
||||||
if (&F == AsanCtorFunction) return false;
|
if (&F == AsanCtorFunction) return false;
|
||||||
|
DEBUG(dbgs() << "ASAN instrumenting:\n" << F << "\n");
|
||||||
|
|
||||||
// If needed, insert __asan_init before checking for AddressSafety attr.
|
// If needed, insert __asan_init before checking for AddressSafety attr.
|
||||||
maybeInsertAsanInitAtFunctionEntry(F);
|
maybeInsertAsanInitAtFunctionEntry(F);
|
||||||
@ -914,8 +915,6 @@ bool AddressSanitizer::runOnFunction(Function &F) {
|
|||||||
NumInstrumented++;
|
NumInstrumented++;
|
||||||
}
|
}
|
||||||
|
|
||||||
DEBUG(dbgs() << F);
|
|
||||||
|
|
||||||
bool ChangedStack = poisonStackInFunction(F);
|
bool ChangedStack = poisonStackInFunction(F);
|
||||||
|
|
||||||
// We must unpoison the stack before every NoReturn call (throw, _exit, etc).
|
// We must unpoison the stack before every NoReturn call (throw, _exit, etc).
|
||||||
@ -925,6 +924,7 @@ bool AddressSanitizer::runOnFunction(Function &F) {
|
|||||||
IRBuilder<> IRB(CI);
|
IRBuilder<> IRB(CI);
|
||||||
IRB.CreateCall(AsanHandleNoReturnFunc);
|
IRB.CreateCall(AsanHandleNoReturnFunc);
|
||||||
}
|
}
|
||||||
|
DEBUG(dbgs() << "ASAN done instrumenting:\n" << F << "\n");
|
||||||
|
|
||||||
return NumInstrumented > 0 || ChangedStack || !NoReturnCalls.empty();
|
return NumInstrumented > 0 || ChangedStack || !NoReturnCalls.empty();
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user