diff options
author | Kostya Serebryany <kcc@google.com> | 2011-11-17 23:14:59 +0000 |
---|---|---|
committer | Kostya Serebryany <kcc@google.com> | 2011-11-17 23:14:59 +0000 |
commit | 7cf2a04361e8613264498e50babe52d65c070473 (patch) | |
tree | 9a70d15c2e0d7e4ca7401236bd72112b79ae6ec2 /lib/Transforms/Instrumentation | |
parent | f24944953986ad1e0a78279e6c3288e15a7e2619 (diff) | |
download | llvm-7cf2a04361e8613264498e50babe52d65c070473.tar.gz llvm-7cf2a04361e8613264498e50babe52d65c070473.tar.bz2 llvm-7cf2a04361e8613264498e50babe52d65c070473.tar.xz |
fall back to explicit list of allowed linkages when instrumenting globals in asan; add a test check that asan does not touch linkonce_odr
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@144933 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Transforms/Instrumentation')
-rw-r--r-- | lib/Transforms/Instrumentation/AddressSanitizer.cpp | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/lib/Transforms/Instrumentation/AddressSanitizer.cpp b/lib/Transforms/Instrumentation/AddressSanitizer.cpp index e858bccdfb..1f3672e25c 100644 --- a/lib/Transforms/Instrumentation/AddressSanitizer.cpp +++ b/lib/Transforms/Instrumentation/AddressSanitizer.cpp @@ -448,8 +448,11 @@ bool AddressSanitizer::insertGlobalRedzones(Module &M) { if (!Ty->isSized()) continue; if (!G->hasInitializer()) continue; - if (GlobalVariable::mayBeOverridden(G->getLinkage()) || - G->getLinkage() == GlobalVariable::AppendingLinkage) + // Touch only those globals that will not be defined in other modules. + // Don't handle ODR type linkages since other modules may be built w/o asan. + if (G->getLinkage() != GlobalVariable::GlobalVariable::ExternalLinkage && + G->getLinkage() != GlobalVariable::GlobalVariable::PrivateLinkage && + G->getLinkage() != GlobalVariable::GlobalVariable::InternalLinkage) continue; // For now, just ignore this Alloca if the alignment is large. if (G->getAlignment() > RedzoneSize) continue; |