forked from OSchip/llvm-project
parent
e492cb41b7
commit
2713117135
|
@ -18,8 +18,10 @@
|
|||
#include "llvm/ADT/DenseMap.h"
|
||||
#include "llvm/ADT/PostOrderIterator.h"
|
||||
#include "llvm/CodeGen/MachineBasicBlock.h"
|
||||
#include "llvm/CodeGen/MachineFunction.h"
|
||||
#include "llvm/Support/BranchProbability.h"
|
||||
#include "llvm/Support/Debug.h"
|
||||
#include "llvm/Support/raw_ostream.h"
|
||||
#include <vector>
|
||||
#include <sstream>
|
||||
#include <string>
|
||||
|
@ -28,6 +30,8 @@ namespace llvm {
|
|||
|
||||
|
||||
class BlockFrequency;
|
||||
class MachineBlockFrequency;
|
||||
|
||||
/// BlockFrequencyImpl implements block frequency algorithm for IR and
|
||||
/// Machine Instructions. Algorithm starts with value 1024 (START_FREQ)
|
||||
/// for the entry block and then propagates frequencies using branch weights
|
||||
|
@ -53,9 +57,8 @@ class BlockFrequencyImpl {
|
|||
std::string getBlockName(MachineBasicBlock *MBB) const {
|
||||
std::stringstream ss;
|
||||
ss << "BB#" << MBB->getNumber();
|
||||
const BasicBlock *BB = MBB->getBasicBlock();
|
||||
|
||||
if (BB)
|
||||
if (const BasicBlock *BB = MBB->getBasicBlock())
|
||||
ss << " derived from LLVM BB " << BB->getNameStr();
|
||||
|
||||
return ss.str();
|
||||
|
@ -261,6 +264,7 @@ class BlockFrequencyImpl {
|
|||
}
|
||||
|
||||
friend class BlockFrequency;
|
||||
friend class MachineBlockFrequency;
|
||||
|
||||
void doFunction(FunctionT *fn, BlockProbInfoT *bpi) {
|
||||
Fn = fn;
|
||||
|
|
|
@ -0,0 +1,53 @@
|
|||
//====----- MachineBlockFrequency.h - MachineBlock Frequency Analysis ----====//
|
||||
//
|
||||
// The LLVM Compiler Infrastructure
|
||||
//
|
||||
// This file is distributed under the University of Illinois Open Source
|
||||
// License. See LICENSE.TXT for details.
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
//
|
||||
// Loops should be simplified before this analysis.
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
#ifndef LLVM_CODEGEN_MACHINEBLOCKFREQUENCY_H
|
||||
#define LLVM_CODEGEN_MACHINEBLOCKFREQUENCY_H
|
||||
|
||||
#include "llvm/CodeGen/MachineFunctionPass.h"
|
||||
#include <climits>
|
||||
|
||||
namespace llvm {
|
||||
|
||||
class MachineBranchProbabilityInfo;
|
||||
template<class BlockT, class FunctionT, class BranchProbInfoT>
|
||||
class BlockFrequencyImpl;
|
||||
|
||||
/// MachineBlockFrequency pass uses BlockFrequencyImpl implementation to estimate
|
||||
/// machine basic block frequencies.
|
||||
class MachineBlockFrequency : public MachineFunctionPass {
|
||||
|
||||
BlockFrequencyImpl<MachineBasicBlock, MachineFunction, MachineBranchProbabilityInfo> *MBFI;
|
||||
|
||||
public:
|
||||
static char ID;
|
||||
|
||||
MachineBlockFrequency();
|
||||
|
||||
~MachineBlockFrequency();
|
||||
|
||||
void getAnalysisUsage(AnalysisUsage &AU) const;
|
||||
|
||||
bool runOnMachineFunction(MachineFunction &F);
|
||||
|
||||
/// getblockFreq - Return block frequency. Never return 0, value must be
|
||||
/// positive. Please note that initial frequency is equal to 1024. It means
|
||||
/// that we should not rely on the value itself, but only on the comparison to
|
||||
/// the other block frequencies. We do this to avoid using of the floating
|
||||
/// points.
|
||||
uint32_t getBlockFreq(MachineBasicBlock *MBB);
|
||||
};
|
||||
|
||||
}
|
||||
|
||||
#endif
|
|
@ -145,6 +145,7 @@ void initializeLowerIntrinsicsPass(PassRegistry&);
|
|||
void initializeLowerInvokePass(PassRegistry&);
|
||||
void initializeLowerSetJmpPass(PassRegistry&);
|
||||
void initializeLowerSwitchPass(PassRegistry&);
|
||||
void initializeMachineBlockFrequencyPass(PassRegistry&);
|
||||
void initializeMachineBranchProbabilityInfoPass(PassRegistry&);
|
||||
void initializeMachineCSEPass(PassRegistry&);
|
||||
void initializeMachineDominatorTreePass(PassRegistry&);
|
||||
|
|
|
@ -33,6 +33,7 @@ add_llvm_library(LLVMCodeGen
|
|||
LocalStackSlotAllocation.cpp
|
||||
LowerSubregs.cpp
|
||||
MachineBasicBlock.cpp
|
||||
MachineBlockFrequency.cpp
|
||||
MachineBranchProbabilityInfo.cpp
|
||||
MachineCSE.cpp
|
||||
MachineDominators.cpp
|
||||
|
|
|
@ -0,0 +1,59 @@
|
|||
//====----- MachineBlockFrequency.cpp - Machine Block Frequency Analysis ----====//
|
||||
//
|
||||
// The LLVM Compiler Infrastructure
|
||||
//
|
||||
// This file is distributed under the University of Illinois Open Source
|
||||
// License. See LICENSE.TXT for details.
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
//
|
||||
// Loops should be simplified before this analysis.
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
#include "llvm/InitializePasses.h"
|
||||
#include "llvm/Analysis/BlockFrequencyImpl.h"
|
||||
#include "llvm/CodeGen/MachineBlockFrequency.h"
|
||||
#include "llvm/CodeGen/Passes.h"
|
||||
#include "llvm/CodeGen/MachineBranchProbabilityInfo.h"
|
||||
|
||||
using namespace llvm;
|
||||
|
||||
INITIALIZE_PASS_BEGIN(MachineBlockFrequency, "machine-block-freq",
|
||||
"Machine Block Frequency Analysis", true, true)
|
||||
INITIALIZE_PASS_DEPENDENCY(MachineBranchProbabilityInfo)
|
||||
INITIALIZE_PASS_END(MachineBlockFrequency, "machine-block-freq",
|
||||
"Machine Block Frequency Analysis", true, true)
|
||||
|
||||
char MachineBlockFrequency::ID = 0;
|
||||
|
||||
|
||||
MachineBlockFrequency::MachineBlockFrequency() : MachineFunctionPass(ID) {
|
||||
initializeMachineBlockFrequencyPass(*PassRegistry::getPassRegistry());
|
||||
MBFI = new BlockFrequencyImpl<MachineBasicBlock, MachineFunction,
|
||||
MachineBranchProbabilityInfo>();
|
||||
}
|
||||
|
||||
MachineBlockFrequency::~MachineBlockFrequency() {
|
||||
delete MBFI;
|
||||
}
|
||||
|
||||
void MachineBlockFrequency::getAnalysisUsage(AnalysisUsage &AU) const {
|
||||
AU.addRequired<MachineBranchProbabilityInfo>();
|
||||
AU.setPreservesAll();
|
||||
}
|
||||
|
||||
bool MachineBlockFrequency::runOnMachineFunction(MachineFunction &F) {
|
||||
MachineBranchProbabilityInfo &MBPI = getAnalysis<MachineBranchProbabilityInfo>();
|
||||
MBFI->doFunction(&F, &MBPI);
|
||||
return false;
|
||||
}
|
||||
|
||||
/// getblockFreq - Return block frequency. Never return 0, value must be
|
||||
/// positive. Please note that initial frequency is equal to 1024. It means that
|
||||
/// we should not rely on the value itself, but only on the comparison to the
|
||||
/// other block frequencies. We do this to avoid using of floating points.
|
||||
///
|
||||
uint32_t MachineBlockFrequency::getBlockFreq(MachineBasicBlock *MBB) {
|
||||
return MBFI->getBlockFreq(MBB);
|
||||
}
|
Loading…
Reference in New Issue