summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Analysis/BranchProbabilityInfo.cpp
diff options
context:
space:
mode:
authorJakub Staszak <jstaszak@apple.com>2011-06-23 21:45:20 +0000
committerJakub Staszak <jstaszak@apple.com>2011-06-23 21:45:20 +0000
commitbe52acc98ac21bb5fa6b5c5b0fbdc6e790c58559 (patch)
treee1e4cbd2a6cef89542889b4465ff6642339a2dfd /llvm/lib/Analysis/BranchProbabilityInfo.cpp
parentbb7f31fa2976875a8460c2f5d214c702ea982146 (diff)
downloadbcm5719-llvm-be52acc98ac21bb5fa6b5c5b0fbdc6e790c58559.tar.gz
bcm5719-llvm-be52acc98ac21bb5fa6b5c5b0fbdc6e790c58559.zip
Introduce BlockFrequency analysis for BasicBlocks.
llvm-svn: 133766
Diffstat (limited to 'llvm/lib/Analysis/BranchProbabilityInfo.cpp')
-rw-r--r--llvm/lib/Analysis/BranchProbabilityInfo.cpp24
1 files changed, 24 insertions, 0 deletions
diff --git a/llvm/lib/Analysis/BranchProbabilityInfo.cpp b/llvm/lib/Analysis/BranchProbabilityInfo.cpp
index 15059c733ab..263ea2c26b0 100644
--- a/llvm/lib/Analysis/BranchProbabilityInfo.cpp
+++ b/llvm/lib/Analysis/BranchProbabilityInfo.cpp
@@ -279,6 +279,21 @@ uint32_t BranchProbabilityInfo::getSumForBlock(BasicBlock *BB) const {
return Sum;
}
+uint32_t BranchProbabilityInfo::getBackSumForBlock(BasicBlock *BB) const {
+ uint32_t Sum = 0;
+
+ for (pred_iterator I = pred_begin(BB), E = pred_end(BB); I != E; ++I) {
+ BasicBlock *Pred = *I;
+ uint32_t Weight = getEdgeWeight(Pred, BB);
+ uint32_t PrevSum = Sum;
+
+ Sum += Weight;
+ assert(Sum > PrevSum); (void) PrevSum;
+ }
+
+ return Sum;
+}
+
bool BranchProbabilityInfo::isEdgeHot(BasicBlock *Src, BasicBlock *Dst) const {
// Hot probability is at least 4/5 = 80%
uint32_t Weight = getEdgeWeight(Src, Dst);
@@ -345,6 +360,15 @@ getEdgeProbability(BasicBlock *Src, BasicBlock *Dst) const {
return BranchProbability(N, D);
}
+BranchProbability BranchProbabilityInfo::
+getBackEdgeProbability(BasicBlock *Src, BasicBlock *Dst) const {
+
+ uint32_t N = getEdgeWeight(Src, Dst);
+ uint32_t D = getBackSumForBlock(Dst);
+
+ return BranchProbability(N, D);
+}
+
raw_ostream &
BranchProbabilityInfo::printEdgeProbability(raw_ostream &OS, BasicBlock *Src,
BasicBlock *Dst) const {
OpenPOWER on IntegriCloud