[llvm] r264003 - [sancov] do not instrument nodes that are full pre-dominators
Mike Aizatsky via llvm-commits
llvm-commits at lists.llvm.org
Mon Mar 21 16:08:17 PDT 2016
Author: aizatsky
Date: Mon Mar 21 18:08:16 2016
New Revision: 264003
URL: http://llvm.org/viewvc/llvm-project?rev=264003&view=rev
Log:
[sancov] do not instrument nodes that are full pre-dominators
Summary:
Without tree pruning clang has 2,667,552 points.
Wiht only dominators pruning: 1,515,586.
With both dominators & predominators pruning: 1,340,534.
Resubmit of r262103.
Differential Revision: http://reviews.llvm.org/D18341
Modified:
llvm/trunk/lib/Transforms/Instrumentation/SanitizerCoverage.cpp
Modified: llvm/trunk/lib/Transforms/Instrumentation/SanitizerCoverage.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Transforms/Instrumentation/SanitizerCoverage.cpp?rev=264003&r1=264002&r2=264003&view=diff
==============================================================================
--- llvm/trunk/lib/Transforms/Instrumentation/SanitizerCoverage.cpp (original)
+++ llvm/trunk/lib/Transforms/Instrumentation/SanitizerCoverage.cpp Mon Mar 21 18:08:16 2016
@@ -315,20 +315,24 @@ bool SanitizerCoverageModule::runOnModul
return true;
}
-static bool shouldInstrumentBlock(const BasicBlock *BB,
- const DominatorTree *DT) {
+static bool shouldInstrumentBlock(const BasicBlock *BB, const DominatorTree *DT,
+ const PostDominatorTree *PDT) {
if (!ClPruneBlocks)
return true;
- if (succ_begin(BB) == succ_end(BB))
- return true;
// Check if BB dominates all its successors.
+ bool DominatesAll = succ_begin(BB) != succ_end(BB);
for (const BasicBlock *SUCC : make_range(succ_begin(BB), succ_end(BB))) {
- if (!DT->dominates(BB, SUCC))
- return true;
+ DominatesAll &= DT->dominates(BB, SUCC);
+ }
+
+ // Check if BB pre-dominates all predecessors.
+ bool PreDominatesAll = pred_begin(BB) != pred_end(BB);
+ for (const BasicBlock *PRED : make_range(pred_begin(BB), pred_end(BB))) {
+ PreDominatesAll &= PDT->dominates(BB, PRED);
}
- return false;
+ return !(DominatesAll || PreDominatesAll);
}
bool SanitizerCoverageModule::runOnFunction(Function &F) {
@@ -349,10 +353,13 @@ bool SanitizerCoverageModule::runOnFunct
SmallVector<Instruction *, 8> CmpTraceTargets;
SmallVector<Instruction *, 8> SwitchTraceTargets;
- DominatorTree DT;
- DT.recalculate(F);
+ const DominatorTree *DT =
+ &getAnalysis<DominatorTreeWrapperPass>(F).getDomTree();
+ const PostDominatorTree *PDT =
+ &getAnalysis<PostDominatorTreeWrapperPass>(F).getPostDomTree();
+
for (auto &BB : F) {
- if (shouldInstrumentBlock(&BB, &DT))
+ if (shouldInstrumentBlock(&BB, DT, PDT))
BlocksToInstrument.push_back(&BB);
for (auto &Inst : BB) {
if (Options.IndirectCalls) {
More information about the llvm-commits
mailing list