forked from OSchip/llvm-project
parent
e492cb41b7
commit
2713117135
|
@ -18,8 +18,10 @@
|
||||||
#include "llvm/ADT/DenseMap.h"
|
#include "llvm/ADT/DenseMap.h"
|
||||||
#include "llvm/ADT/PostOrderIterator.h"
|
#include "llvm/ADT/PostOrderIterator.h"
|
||||||
#include "llvm/CodeGen/MachineBasicBlock.h"
|
#include "llvm/CodeGen/MachineBasicBlock.h"
|
||||||
|
#include "llvm/CodeGen/MachineFunction.h"
|
||||||
#include "llvm/Support/BranchProbability.h"
|
#include "llvm/Support/BranchProbability.h"
|
||||||
#include "llvm/Support/Debug.h"
|
#include "llvm/Support/Debug.h"
|
||||||
|
#include "llvm/Support/raw_ostream.h"
|
||||||
#include <vector>
|
#include <vector>
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
#include <string>
|
#include <string>
|
||||||
|
@ -28,6 +30,8 @@ namespace llvm {
|
||||||
|
|
||||||
|
|
||||||
class BlockFrequency;
|
class BlockFrequency;
|
||||||
|
class MachineBlockFrequency;
|
||||||
|
|
||||||
/// BlockFrequencyImpl implements block frequency algorithm for IR and
|
/// BlockFrequencyImpl implements block frequency algorithm for IR and
|
||||||
/// Machine Instructions. Algorithm starts with value 1024 (START_FREQ)
|
/// Machine Instructions. Algorithm starts with value 1024 (START_FREQ)
|
||||||
/// for the entry block and then propagates frequencies using branch weights
|
/// for the entry block and then propagates frequencies using branch weights
|
||||||
|
@ -53,9 +57,8 @@ class BlockFrequencyImpl {
|
||||||
std::string getBlockName(MachineBasicBlock *MBB) const {
|
std::string getBlockName(MachineBasicBlock *MBB) const {
|
||||||
std::stringstream ss;
|
std::stringstream ss;
|
||||||
ss << "BB#" << MBB->getNumber();
|
ss << "BB#" << MBB->getNumber();
|
||||||
const BasicBlock *BB = MBB->getBasicBlock();
|
|
||||||
|
|
||||||
if (BB)
|
if (const BasicBlock *BB = MBB->getBasicBlock())
|
||||||
ss << " derived from LLVM BB " << BB->getNameStr();
|
ss << " derived from LLVM BB " << BB->getNameStr();
|
||||||
|
|
||||||
return ss.str();
|
return ss.str();
|
||||||
|
@ -261,6 +264,7 @@ class BlockFrequencyImpl {
|
||||||
}
|
}
|
||||||
|
|
||||||
friend class BlockFrequency;
|
friend class BlockFrequency;
|
||||||
|
friend class MachineBlockFrequency;
|
||||||
|
|
||||||
void doFunction(FunctionT *fn, BlockProbInfoT *bpi) {
|
void doFunction(FunctionT *fn, BlockProbInfoT *bpi) {
|
||||||
Fn = fn;
|
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 initializeLowerInvokePass(PassRegistry&);
|
||||||
void initializeLowerSetJmpPass(PassRegistry&);
|
void initializeLowerSetJmpPass(PassRegistry&);
|
||||||
void initializeLowerSwitchPass(PassRegistry&);
|
void initializeLowerSwitchPass(PassRegistry&);
|
||||||
|
void initializeMachineBlockFrequencyPass(PassRegistry&);
|
||||||
void initializeMachineBranchProbabilityInfoPass(PassRegistry&);
|
void initializeMachineBranchProbabilityInfoPass(PassRegistry&);
|
||||||
void initializeMachineCSEPass(PassRegistry&);
|
void initializeMachineCSEPass(PassRegistry&);
|
||||||
void initializeMachineDominatorTreePass(PassRegistry&);
|
void initializeMachineDominatorTreePass(PassRegistry&);
|
||||||
|
|
|
@ -33,6 +33,7 @@ add_llvm_library(LLVMCodeGen
|
||||||
LocalStackSlotAllocation.cpp
|
LocalStackSlotAllocation.cpp
|
||||||
LowerSubregs.cpp
|
LowerSubregs.cpp
|
||||||
MachineBasicBlock.cpp
|
MachineBasicBlock.cpp
|
||||||
|
MachineBlockFrequency.cpp
|
||||||
MachineBranchProbabilityInfo.cpp
|
MachineBranchProbabilityInfo.cpp
|
||||||
MachineCSE.cpp
|
MachineCSE.cpp
|
||||||
MachineDominators.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