mirror of
https://github.com/RPCSX/llvm.git
synced 2025-04-03 08:41:44 +00:00
Recalculate the spill weight and allocation hint for virtual registers created
during live range splitting. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@110686 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
dc0830947a
commit
08e93b14c3
@ -25,11 +25,11 @@ namespace llvm {
|
|||||||
class VirtRegAuxInfo {
|
class VirtRegAuxInfo {
|
||||||
MachineFunction &mf_;
|
MachineFunction &mf_;
|
||||||
LiveIntervals &lis_;
|
LiveIntervals &lis_;
|
||||||
MachineLoopInfo &loops_;
|
const MachineLoopInfo &loops_;
|
||||||
DenseMap<unsigned, float> hint_;
|
DenseMap<unsigned, float> hint_;
|
||||||
public:
|
public:
|
||||||
VirtRegAuxInfo(MachineFunction &mf, LiveIntervals &lis,
|
VirtRegAuxInfo(MachineFunction &mf, LiveIntervals &lis,
|
||||||
MachineLoopInfo &loops) :
|
const MachineLoopInfo &loops) :
|
||||||
mf_(mf), lis_(lis), loops_(loops) {}
|
mf_(mf), lis_(lis), loops_(loops) {}
|
||||||
|
|
||||||
/// CalculateRegClass - recompute the register class for li from its uses.
|
/// CalculateRegClass - recompute the register class for li from its uses.
|
||||||
|
@ -15,6 +15,7 @@
|
|||||||
#define DEBUG_TYPE "splitter"
|
#define DEBUG_TYPE "splitter"
|
||||||
#include "SplitKit.h"
|
#include "SplitKit.h"
|
||||||
#include "VirtRegMap.h"
|
#include "VirtRegMap.h"
|
||||||
|
#include "llvm/CodeGen/CalcSpillWeights.h"
|
||||||
#include "llvm/CodeGen/LiveIntervalAnalysis.h"
|
#include "llvm/CodeGen/LiveIntervalAnalysis.h"
|
||||||
#include "llvm/CodeGen/MachineFunctionPass.h"
|
#include "llvm/CodeGen/MachineFunctionPass.h"
|
||||||
#include "llvm/CodeGen/MachineInstrBuilder.h"
|
#include "llvm/CodeGen/MachineInstrBuilder.h"
|
||||||
@ -566,8 +567,12 @@ void SplitEditor::rewrite() {
|
|||||||
intervals_.push_back(dupli_);
|
intervals_.push_back(dupli_);
|
||||||
}
|
}
|
||||||
|
|
||||||
// FIXME: *Calculate spill weights, allocation hints, and register classes for
|
// Calculate spill weight and allocation hints for new intervals.
|
||||||
// firstInterval..
|
VirtRegAuxInfo vrai(vrm_.getMachineFunction(), lis_, sa_.loops_);
|
||||||
|
for (unsigned i = firstInterval, e = intervals_.size(); i != e; ++i) {
|
||||||
|
LiveInterval &li = *intervals_[i];
|
||||||
|
vrai.CalculateWeightAndHint(li);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -31,11 +31,13 @@ class VNInfo;
|
|||||||
/// SplitAnalysis - Analyze a LiveInterval, looking for live range splitting
|
/// SplitAnalysis - Analyze a LiveInterval, looking for live range splitting
|
||||||
/// opportunities.
|
/// opportunities.
|
||||||
class SplitAnalysis {
|
class SplitAnalysis {
|
||||||
|
public:
|
||||||
const MachineFunction &mf_;
|
const MachineFunction &mf_;
|
||||||
const LiveIntervals &lis_;
|
const LiveIntervals &lis_;
|
||||||
const MachineLoopInfo &loops_;
|
const MachineLoopInfo &loops_;
|
||||||
const TargetInstrInfo &tii_;
|
const TargetInstrInfo &tii_;
|
||||||
|
|
||||||
|
private:
|
||||||
// Current live interval.
|
// Current live interval.
|
||||||
const LiveInterval *curli_;
|
const LiveInterval *curli_;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user