CalcSpillWeights: allow overidding the spill weight normalizing function

This will enable the PBQP register allocator to provide its own normalizing function.

No functionnal change.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@194417 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Arnaud A. de Grandmaison 2013-11-11 19:56:14 +00:00
parent ef572e31e2
commit d736763847
2 changed files with 16 additions and 6 deletions

View File

@ -43,16 +43,23 @@ namespace llvm {
/// \brief Calculate auxiliary information for a virtual register such as its /// \brief Calculate auxiliary information for a virtual register such as its
/// spill weight and allocation hint. /// spill weight and allocation hint.
class VirtRegAuxInfo { class VirtRegAuxInfo {
public:
typedef float (*NormalizingFn)(float, unsigned);
private:
MachineFunction &MF; MachineFunction &MF;
LiveIntervals &LIS; LiveIntervals &LIS;
const MachineLoopInfo &Loops; const MachineLoopInfo &Loops;
const MachineBlockFrequencyInfo &MBFI; const MachineBlockFrequencyInfo &MBFI;
DenseMap<unsigned, float> Hint; DenseMap<unsigned, float> Hint;
NormalizingFn normalize;
public: public:
VirtRegAuxInfo(MachineFunction &mf, LiveIntervals &lis, VirtRegAuxInfo(MachineFunction &mf, LiveIntervals &lis,
const MachineLoopInfo &loops, const MachineLoopInfo &loops,
const MachineBlockFrequencyInfo &mbfi) const MachineBlockFrequencyInfo &mbfi,
: MF(mf), LIS(lis), Loops(loops), MBFI(mbfi) {} NormalizingFn norm = normalizeSpillWeight)
: MF(mf), LIS(lis), Loops(loops), MBFI(mbfi), normalize(norm) {}
/// \brief (re)compute li's spill weight and allocation hint. /// \brief (re)compute li's spill weight and allocation hint.
void calculateSpillWeightAndHint(LiveInterval &li); void calculateSpillWeightAndHint(LiveInterval &li);
@ -62,7 +69,9 @@ namespace llvm {
/// live intervals. /// live intervals.
void calculateSpillWeightsAndHints(LiveIntervals &LIS, MachineFunction &MF, void calculateSpillWeightsAndHints(LiveIntervals &LIS, MachineFunction &MF,
const MachineLoopInfo &MLI, const MachineLoopInfo &MLI,
const MachineBlockFrequencyInfo &MBFI); const MachineBlockFrequencyInfo &MBFI,
VirtRegAuxInfo::NormalizingFn norm =
normalizeSpillWeight);
} }
#endif // LLVM_CODEGEN_CALCSPILLWEIGHTS_H #endif // LLVM_CODEGEN_CALCSPILLWEIGHTS_H

View File

@ -25,12 +25,13 @@ using namespace llvm;
void llvm::calculateSpillWeightsAndHints(LiveIntervals &LIS, void llvm::calculateSpillWeightsAndHints(LiveIntervals &LIS,
MachineFunction &MF, MachineFunction &MF,
const MachineLoopInfo &MLI, const MachineLoopInfo &MLI,
const MachineBlockFrequencyInfo &MBFI) { const MachineBlockFrequencyInfo &MBFI,
VirtRegAuxInfo::NormalizingFn norm) {
DEBUG(dbgs() << "********** Compute Spill Weights **********\n" DEBUG(dbgs() << "********** Compute Spill Weights **********\n"
<< "********** Function: " << MF.getName() << '\n'); << "********** Function: " << MF.getName() << '\n');
MachineRegisterInfo &MRI = MF.getRegInfo(); MachineRegisterInfo &MRI = MF.getRegInfo();
VirtRegAuxInfo VRAI(MF, LIS, MLI, MBFI); VirtRegAuxInfo VRAI(MF, LIS, MLI, MBFI, norm);
for (unsigned i = 0, e = MRI.getNumVirtRegs(); i != e; ++i) { for (unsigned i = 0, e = MRI.getNumVirtRegs(); i != e; ++i) {
unsigned Reg = TargetRegisterInfo::index2VirtReg(i); unsigned Reg = TargetRegisterInfo::index2VirtReg(i);
if (MRI.reg_nodbg_empty(Reg)) if (MRI.reg_nodbg_empty(Reg))
@ -182,5 +183,5 @@ VirtRegAuxInfo::calculateSpillWeightAndHint(LiveInterval &li) {
if (isRematerializable(li, LIS, *MF.getTarget().getInstrInfo())) if (isRematerializable(li, LIS, *MF.getTarget().getInstrInfo()))
totalWeight *= 0.5F; totalWeight *= 0.5F;
li.weight = normalizeSpillWeight(totalWeight, li.getSize()); li.weight = normalize(totalWeight, li.getSize());
} }