mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-14 11:32:34 +00:00
ProfileInfo interface tweaks.
- Add getExecutionCount(const Function). - Add helper Edge type. - constify. - No functionality change. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@75623 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
e11c4db848
commit
858cb8a5e0
@ -26,17 +26,22 @@
|
||||
|
||||
namespace llvm {
|
||||
class BasicBlock;
|
||||
class Function;
|
||||
class Pass;
|
||||
|
||||
/// ProfileInfo Class - This class holds and maintains edge profiling
|
||||
/// information for some unit of code.
|
||||
class ProfileInfo {
|
||||
public:
|
||||
// Types for handling profiling information.
|
||||
typedef std::pair<const BasicBlock*, const BasicBlock*> Edge;
|
||||
|
||||
protected:
|
||||
// EdgeCounts - Count the number of times a transition between two blocks is
|
||||
// executed. As a special case, we also hold an edge from the null
|
||||
// BasicBlock to the entry block to indicate how many times the function was
|
||||
// entered.
|
||||
std::map<std::pair<BasicBlock*, BasicBlock*>, unsigned> EdgeCounts;
|
||||
std::map<Edge, unsigned> EdgeCounts;
|
||||
public:
|
||||
static char ID; // Class identification, replacement for typeinfo
|
||||
virtual ~ProfileInfo(); // We want to be subclassed
|
||||
@ -44,10 +49,13 @@ namespace llvm {
|
||||
//===------------------------------------------------------------------===//
|
||||
/// Profile Information Queries
|
||||
///
|
||||
unsigned getExecutionCount(BasicBlock *BB) const;
|
||||
unsigned getExecutionCount(const Function *F) const;
|
||||
|
||||
unsigned getEdgeWeight(BasicBlock *Src, BasicBlock *Dest) const {
|
||||
std::map<std::pair<BasicBlock*, BasicBlock*>, unsigned>::const_iterator I=
|
||||
unsigned getExecutionCount(const BasicBlock *BB) const;
|
||||
|
||||
unsigned getEdgeWeight(const BasicBlock *Src,
|
||||
const BasicBlock *Dest) const {
|
||||
std::map<Edge, unsigned>::const_iterator I =
|
||||
EdgeCounts.find(std::make_pair(Src, Dest));
|
||||
return I != EdgeCounts.end() ? I->second : 0;
|
||||
}
|
||||
|
@ -26,8 +26,8 @@ char ProfileInfo::ID = 0;
|
||||
|
||||
ProfileInfo::~ProfileInfo() {}
|
||||
|
||||
unsigned ProfileInfo::getExecutionCount(BasicBlock *BB) const {
|
||||
pred_iterator PI = pred_begin(BB), PE = pred_end(BB);
|
||||
unsigned ProfileInfo::getExecutionCount(const BasicBlock *BB) const {
|
||||
pred_const_iterator PI = pred_begin(BB), PE = pred_end(BB);
|
||||
|
||||
// Are there zero predecessors of this block?
|
||||
if (PI == PE) {
|
||||
@ -49,23 +49,23 @@ unsigned ProfileInfo::getExecutionCount(BasicBlock *BB) const {
|
||||
// has a LARGE number of in-edges. Handle the common case of having only a
|
||||
// few in-edges with special code.
|
||||
//
|
||||
BasicBlock *FirstPred = *PI;
|
||||
const BasicBlock *FirstPred = *PI;
|
||||
unsigned Count = getEdgeWeight(FirstPred, BB);
|
||||
++PI;
|
||||
if (PI == PE) return Count; // Quick exit for single predecessor blocks
|
||||
|
||||
BasicBlock *SecondPred = *PI;
|
||||
const BasicBlock *SecondPred = *PI;
|
||||
if (SecondPred != FirstPred) Count += getEdgeWeight(SecondPred, BB);
|
||||
++PI;
|
||||
if (PI == PE) return Count; // Quick exit for two predecessor blocks
|
||||
|
||||
BasicBlock *ThirdPred = *PI;
|
||||
const BasicBlock *ThirdPred = *PI;
|
||||
if (ThirdPred != FirstPred && ThirdPred != SecondPred)
|
||||
Count += getEdgeWeight(ThirdPred, BB);
|
||||
++PI;
|
||||
if (PI == PE) return Count; // Quick exit for three predecessor blocks
|
||||
|
||||
std::set<BasicBlock*> ProcessedPreds;
|
||||
std::set<const BasicBlock*> ProcessedPreds;
|
||||
ProcessedPreds.insert(FirstPred);
|
||||
ProcessedPreds.insert(SecondPred);
|
||||
ProcessedPreds.insert(ThirdPred);
|
||||
@ -75,6 +75,10 @@ unsigned ProfileInfo::getExecutionCount(BasicBlock *BB) const {
|
||||
return Count;
|
||||
}
|
||||
|
||||
unsigned ProfileInfo::getExecutionCount(const Function *F) const {
|
||||
if (F->isDeclaration()) return -1;
|
||||
return getExecutionCount(&F->getEntryBlock());
|
||||
}
|
||||
|
||||
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
Loading…
Reference in New Issue
Block a user