Skip to content

Commit

Permalink
Introduce BlockFrequency analysis for BasicBlocks.
Browse files Browse the repository at this point in the history
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@133766 91177308-0d34-0410-b5e6-96231b3b80d8
  • Loading branch information
Jakub Staszak committed Jun 23, 2011
1 parent a390a1a commit 44eb49c
Show file tree
Hide file tree
Showing 6 changed files with 46 additions and 1 deletion.
10 changes: 10 additions & 0 deletions include/llvm/Analysis/BranchProbabilityInfo.h
Expand Up @@ -39,6 +39,9 @@ class BranchProbabilityInfo : public FunctionPass {
// Get sum of the block successors' weights.
uint32_t getSumForBlock(BasicBlock *BB) const;

// Get sum of the edge weights going to the BB block.
uint32_t getBackSumForBlock(BasicBlock *BB) const;

public:
static char ID;

Expand Down Expand Up @@ -71,6 +74,13 @@ class BranchProbabilityInfo : public FunctionPass {
// only iff SRC block has only one successor.
BranchProbability getEdgeProbability(BasicBlock *Src, BasicBlock *Dst) const;

// Return a probability of getting to the DST block through SRC->DST edge.
// Returned value is a fraction between 0 (0% probability) and
// 1 (100% probability), however the value is never equal to 0, and can be 1
// only iff DST block has only one predecesor.
BranchProbability getBackEdgeProbability(BasicBlock *Src,
BasicBlock *Dst) const;

// Print value between 0 (0% probability) and 1 (100% probability),
// however the value is never equal to 0, and can be 1 only iff SRC block
// has only one successor.
Expand Down
1 change: 1 addition & 0 deletions include/llvm/InitializePasses.h
Expand Up @@ -65,6 +65,7 @@ void initializeArgPromotionPass(PassRegistry&);
void initializeBasicAliasAnalysisPass(PassRegistry&);
void initializeBasicCallGraphPass(PassRegistry&);
void initializeBlockExtractorPassPass(PassRegistry&);
void initializeBlockFrequencyPass(PassRegistry&);
void initializeBlockPlacementPass(PassRegistry&);
void initializeBranchProbabilityInfoPass(PassRegistry&);
void initializeBreakCriticalEdgesPass(PassRegistry&);
Expand Down
10 changes: 9 additions & 1 deletion include/llvm/Support/BranchProbability.h
Expand Up @@ -18,13 +18,17 @@

namespace llvm {

class raw_ostream;
template<class BlockT, class FunctionT, class BranchProbInfoT>
class BlockFrequencyImpl;
class BranchProbabilityInfo;
class MachineBranchProbabilityInfo;
class MachineBasicBlock;
class raw_ostream;

// This class represents Branch Probability as a non-negative fraction.
class BranchProbability {
template<class BlockT, class FunctionT, class BranchProbInfoT>
friend class BlockFrequencyImpl;
friend class BranchProbabilityInfo;
friend class MachineBranchProbabilityInfo;
friend class MachineBasicBlock;
Expand All @@ -38,6 +42,10 @@ class BranchProbability {
BranchProbability(uint32_t n, uint32_t d);

public:

uint32_t getNumerator() const { return N; }
uint32_t getDenominator() const { return D; }

raw_ostream &print(raw_ostream &OS) const;

void dump() const;
Expand Down
1 change: 1 addition & 0 deletions lib/Analysis/Analysis.cpp
Expand Up @@ -23,6 +23,7 @@ void llvm::initializeAnalysis(PassRegistry &Registry) {
initializeAliasSetPrinterPass(Registry);
initializeNoAAPass(Registry);
initializeBasicAliasAnalysisPass(Registry);
initializeBlockFrequencyPass(Registry);
initializeBranchProbabilityInfoPass(Registry);
initializeCFGViewerPass(Registry);
initializeCFGPrinterPass(Registry);
Expand Down
24 changes: 24 additions & 0 deletions lib/Analysis/BranchProbabilityInfo.cpp
Expand Up @@ -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);
Expand Down Expand Up @@ -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 {
Expand Down
1 change: 1 addition & 0 deletions lib/Analysis/CMakeLists.txt
Expand Up @@ -6,6 +6,7 @@ add_llvm_library(LLVMAnalysis
AliasSetTracker.cpp
Analysis.cpp
BasicAliasAnalysis.cpp
BlockFrequency.cpp
BranchProbabilityInfo.cpp
CFGPrinter.cpp
CaptureTracking.cpp
Expand Down

0 comments on commit 44eb49c

Please sign in to comment.