diff options
author | Alexey Samsonov <vonosmas@gmail.com> | 2014-05-31 00:11:37 +0000 |
---|---|---|
committer | Alexey Samsonov <vonosmas@gmail.com> | 2014-05-31 00:11:37 +0000 |
commit | d3828b8240a12764fc7b42a5161ec909e60845fb (patch) | |
tree | 0ff57010089f719618a8f46aaee9ca2a4dd49ec0 /llvm/lib/Transforms/Instrumentation/ThreadSanitizer.cpp | |
parent | 98b5f08fd9aef296c540a0da2dd643303286d16f (diff) | |
download | llvm-d3828b8240a12764fc7b42a5161ec909e60845fb.zip llvm-d3828b8240a12764fc7b42a5161ec909e60845fb.tar.gz llvm-d3828b8240a12764fc7b42a5161ec909e60845fb.tar.bz2 |
[TSan] Behave the same for functions w/o sanitize_thread attribute and blacklisted functions
llvm-svn: 209939
Diffstat (limited to 'llvm/lib/Transforms/Instrumentation/ThreadSanitizer.cpp')
-rw-r--r-- | llvm/lib/Transforms/Instrumentation/ThreadSanitizer.cpp | 12 |
1 files changed, 7 insertions, 5 deletions
diff --git a/llvm/lib/Transforms/Instrumentation/ThreadSanitizer.cpp b/llvm/lib/Transforms/Instrumentation/ThreadSanitizer.cpp index 345b212..233f7f6 100644 --- a/llvm/lib/Transforms/Instrumentation/ThreadSanitizer.cpp +++ b/llvm/lib/Transforms/Instrumentation/ThreadSanitizer.cpp @@ -322,7 +322,6 @@ static bool isAtomic(Instruction *I) { bool ThreadSanitizer::runOnFunction(Function &F) { if (!DL) return false; - if (BL->isIn(F)) return false; initializeCallbacks(*F.getParent()); SmallVector<Instruction*, 8> RetVec; SmallVector<Instruction*, 8> AllLoadsAndStores; @@ -331,6 +330,8 @@ bool ThreadSanitizer::runOnFunction(Function &F) { SmallVector<Instruction*, 8> MemIntrinCalls; bool Res = false; bool HasCalls = false; + bool SanitizeFunction = + F.hasFnAttribute(Attribute::SanitizeThread) && !BL->isIn(F); // Traverse all instructions, collect loads/stores/returns, check for calls. for (auto &BB : F) { @@ -355,19 +356,20 @@ bool ThreadSanitizer::runOnFunction(Function &F) { // FIXME: many of these accesses do not need to be checked for races // (e.g. variables that do not escape, etc). - // Instrument memory accesses. - if (ClInstrumentMemoryAccesses && F.hasFnAttribute(Attribute::SanitizeThread)) + // Instrument memory accesses only if we want to report bugs in the function. + if (ClInstrumentMemoryAccesses && SanitizeFunction) for (auto Inst : AllLoadsAndStores) { Res |= instrumentLoadOrStore(Inst); } - // Instrument atomic memory accesses. + // Instrument atomic memory accesses in any case (they can be used to + // implement synchronization). if (ClInstrumentAtomics) for (auto Inst : AtomicAccesses) { Res |= instrumentAtomic(Inst); } - if (ClInstrumentMemIntrinsics) + if (ClInstrumentMemIntrinsics && SanitizeFunction) for (auto Inst : MemIntrinCalls) { Res |= instrumentMemIntrinsic(Inst); } |