mirror of
https://github.com/RPCS3/llvm.git
synced 2024-11-27 21:50:29 +00:00
by ignoring globals from __TEXT,__cstring,cstring_literals during instrumenation. Add a regression test. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@203916 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
89ca7b3e36
commit
670ef0236b
@ -895,7 +895,7 @@ bool AddressSanitizerModule::ShouldInstrumentGlobal(GlobalVariable *G) {
|
||||
// our redzones get broken.
|
||||
if ((G->getName().find("\01L_OBJC_") == 0) ||
|
||||
(G->getName().find("\01l_OBJC_") == 0)) {
|
||||
DEBUG(dbgs() << "Ignoring \\01L_OBJC_* global: " << *G);
|
||||
DEBUG(dbgs() << "Ignoring \\01L_OBJC_* global: " << *G << "\n");
|
||||
return false;
|
||||
}
|
||||
|
||||
@ -906,7 +906,7 @@ bool AddressSanitizerModule::ShouldInstrumentGlobal(GlobalVariable *G) {
|
||||
// them.
|
||||
if ((Section.find("__OBJC,") == 0) ||
|
||||
(Section.find("__DATA, __objc_") == 0)) {
|
||||
DEBUG(dbgs() << "Ignoring ObjC runtime global: " << *G);
|
||||
DEBUG(dbgs() << "Ignoring ObjC runtime global: " << *G << "\n");
|
||||
return false;
|
||||
}
|
||||
// See http://code.google.com/p/address-sanitizer/issues/detail?id=32
|
||||
@ -918,7 +918,13 @@ bool AddressSanitizerModule::ShouldInstrumentGlobal(GlobalVariable *G) {
|
||||
// Therefore there's no point in placing redzones into __DATA,__cfstring.
|
||||
// Moreover, it causes the linker to crash on OS X 10.7
|
||||
if (Section.find("__DATA,__cfstring") == 0) {
|
||||
DEBUG(dbgs() << "Ignoring CFString: " << *G);
|
||||
DEBUG(dbgs() << "Ignoring CFString: " << *G << "\n");
|
||||
return false;
|
||||
}
|
||||
// The linker merges the contents of cstring_literals and removes the
|
||||
// trailing zeroes.
|
||||
if (Section.find("__TEXT,__cstring,cstring_literals") == 0) {
|
||||
DEBUG(dbgs() << "Ignoring a cstring literal: " << *G << "\n");
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user