summaryrefslogtreecommitdiff
path: root/include/llvm/Analysis/BlockFrequencyImpl.h
diff options
context:
space:
mode:
authorJakub Staszak <jstaszak@apple.com>2011-06-23 23:52:11 +0000
committerJakub Staszak <jstaszak@apple.com>2011-06-23 23:52:11 +0000
commit66dddd1da3e036d05f94df82221a97b7d26e3498 (patch)
treedab8e540bcd86316d6e64b1fa8e04d2bcd15fc86 /include/llvm/Analysis/BlockFrequencyImpl.h
parent0edb05b9e4a63d469a6cc9e15fa0dc8de7ee1cdf (diff)
downloadllvm-66dddd1da3e036d05f94df82221a97b7d26e3498.tar.gz
llvm-66dddd1da3e036d05f94df82221a97b7d26e3498.tar.bz2
llvm-66dddd1da3e036d05f94df82221a97b7d26e3498.tar.xz
Calculate backedge probability correctly.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@133776 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'include/llvm/Analysis/BlockFrequencyImpl.h')
-rw-r--r--include/llvm/Analysis/BlockFrequencyImpl.h17
1 files changed, 13 insertions, 4 deletions
diff --git a/include/llvm/Analysis/BlockFrequencyImpl.h b/include/llvm/Analysis/BlockFrequencyImpl.h
index 7447e80a31..cef375f10e 100644
--- a/include/llvm/Analysis/BlockFrequencyImpl.h
+++ b/include/llvm/Analysis/BlockFrequencyImpl.h
@@ -133,6 +133,15 @@ class BlockFrequencyImpl {
}
+ /// Return a probability of getting to the DST block through SRC->DST edge.
+ ///
+ BranchProbability getBackEdgeProbability(BlockT *Src, BlockT *Dst) const {
+ uint32_t N = getEdgeFreq(Src, Dst);
+ uint32_t D = getBlockFreq(Dst);
+
+ return BranchProbability(N, D);
+ }
+
/// isReachable - Returns if BB block is reachable from the entry.
///
bool isReachable(BlockT *BB) {
@@ -213,7 +222,9 @@ class BlockFrequencyImpl {
return;
assert(START_FREQ >= CycleProb[BB]);
- divBlockFreq(BB, BranchProbability(START_FREQ - CycleProb[BB], START_FREQ));
+ uint32_t CProb = CycleProb[BB];
+ uint32_t Numerator = START_FREQ - CProb ? START_FREQ - CProb : 1;
+ divBlockFreq(BB, BranchProbability(Numerator, START_FREQ));
}
/// doLoop - Propagate block frequency down throught the loop.
@@ -238,19 +249,17 @@ class BlockFrequencyImpl {
BlockT *Pred = *PI;
assert(Pred);
if (isReachable(Pred) && isBackedge(Pred, Head)) {
- BranchProbability Prob = BPI->getBackEdgeProbability(Pred, Head);
+ BranchProbability Prob = getBackEdgeProbability(Pred, Head);
uint64_t N = Prob.getNumerator();
uint64_t D = Prob.getDenominator();
uint64_t Res = (N * START_FREQ) / D;
- // CycleProb[Head] += getEdgeFreq(Pred, Head);
assert(Res <= UINT32_MAX);
CycleProb[Head] += (uint32_t) Res;
}
}
}
-
friend class BlockFrequency;
void doFunction(FunctionT *fn, BlockProbInfoT *bpi) {