mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-11-01 00:17:01 +00:00
Iteration is required for some cases, even if they don't occur in crafty.
Restore it, which re-fixes X86/2006-08-21-ExtraMovInst.ll git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@30050 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -53,6 +53,17 @@ namespace llvm {
|
|||||||
std::vector<bool> allocatableRegs_;
|
std::vector<bool> allocatableRegs_;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
struct CopyRec {
|
||||||
|
MachineInstr *MI;
|
||||||
|
unsigned SrcReg, DstReg;
|
||||||
|
};
|
||||||
|
CopyRec getCopyRec(MachineInstr *MI, unsigned SrcReg, unsigned DstReg) {
|
||||||
|
CopyRec R;
|
||||||
|
R.MI = MI;
|
||||||
|
R.SrcReg = SrcReg;
|
||||||
|
R.DstReg = DstReg;
|
||||||
|
return R;
|
||||||
|
}
|
||||||
struct InstrSlots {
|
struct InstrSlots {
|
||||||
enum {
|
enum {
|
||||||
LOAD = 0,
|
LOAD = 0,
|
||||||
@@ -150,9 +161,10 @@ namespace llvm {
|
|||||||
/// joinIntervals - join compatible live intervals
|
/// joinIntervals - join compatible live intervals
|
||||||
void joinIntervals();
|
void joinIntervals();
|
||||||
|
|
||||||
/// CopyCoallesceInMBB - Coallsece copies in the specified MBB.
|
/// CopyCoallesceInMBB - Coallsece copies in the specified MBB, putting
|
||||||
void CopyCoallesceInMBB(MachineBasicBlock *MBB);
|
/// copies that cannot yet be coallesced into the "TryAgain" list.
|
||||||
|
void CopyCoallesceInMBB(MachineBasicBlock *MBB,
|
||||||
|
std::vector<CopyRec> &TryAgain);
|
||||||
/// JoinCopy - Attempt to join intervals corresponding to SrcReg/DstReg,
|
/// JoinCopy - Attempt to join intervals corresponding to SrcReg/DstReg,
|
||||||
/// which are the src/dst of the copy instruction CopyMI. This returns true
|
/// which are the src/dst of the copy instruction CopyMI. This returns true
|
||||||
/// if the copy was successfully coallesced away, or if it is never possible
|
/// if the copy was successfully coallesced away, or if it is never possible
|
||||||
|
|||||||
@@ -883,12 +883,6 @@ static unsigned ComputeUltimateVN(unsigned VN,
|
|||||||
return ThisValNoAssignments[VN] = UltimateVN;
|
return ThisValNoAssignments[VN] = UltimateVN;
|
||||||
}
|
}
|
||||||
|
|
||||||
Statistic<> A("x", "a");
|
|
||||||
Statistic<> B("x", "b");
|
|
||||||
Statistic<> C("x", "c");
|
|
||||||
Statistic<> D("x", "d");
|
|
||||||
|
|
||||||
|
|
||||||
static bool InVector(unsigned Val, const SmallVector<unsigned, 8> &V) {
|
static bool InVector(unsigned Val, const SmallVector<unsigned, 8> &V) {
|
||||||
return std::find(V.begin(), V.end(), Val) != V.end();
|
return std::find(V.begin(), V.end(), Val) != V.end();
|
||||||
}
|
}
|
||||||
@@ -1048,13 +1042,11 @@ bool LiveIntervals::JoinIntervals(LiveInterval &LHS, LiveInterval &RHS) {
|
|||||||
} else {
|
} else {
|
||||||
RHSValNoInfo = RHS.getValNumInfo(0);
|
RHSValNoInfo = RHS.getValNumInfo(0);
|
||||||
}
|
}
|
||||||
++A;
|
|
||||||
} else {
|
} else {
|
||||||
// It was defined as a copy from the LHS, find out what value # it is.
|
// It was defined as a copy from the LHS, find out what value # it is.
|
||||||
unsigned ValInst = RHS.getInstForValNum(0);
|
unsigned ValInst = RHS.getInstForValNum(0);
|
||||||
RHSValID = LHS.getLiveRangeContaining(ValInst-1)->ValId;
|
RHSValID = LHS.getLiveRangeContaining(ValInst-1)->ValId;
|
||||||
RHSValNoInfo = LHS.getValNumInfo(RHSValID);
|
RHSValNoInfo = LHS.getValNumInfo(RHSValID);
|
||||||
++B;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
LHSValNoAssignments.resize(LHS.getNumValNums(), -1);
|
LHSValNoAssignments.resize(LHS.getNumValNums(), -1);
|
||||||
@@ -1093,7 +1085,6 @@ bool LiveIntervals::JoinIntervals(LiveInterval &LHS, LiveInterval &RHS) {
|
|||||||
RHSValNoAssignments[0] = RHSValID;
|
RHSValNoAssignments[0] = RHSValID;
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
++D;
|
|
||||||
// Loop over the value numbers of the LHS, seeing if any are defined from
|
// Loop over the value numbers of the LHS, seeing if any are defined from
|
||||||
// the RHS.
|
// the RHS.
|
||||||
SmallVector<int, 16> LHSValsDefinedFromRHS;
|
SmallVector<int, 16> LHSValsDefinedFromRHS;
|
||||||
@@ -1223,7 +1214,8 @@ namespace {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void LiveIntervals::CopyCoallesceInMBB(MachineBasicBlock *MBB) {
|
void LiveIntervals::CopyCoallesceInMBB(MachineBasicBlock *MBB,
|
||||||
|
std::vector<CopyRec> &TryAgain) {
|
||||||
DEBUG(std::cerr << ((Value*)MBB->getBasicBlock())->getName() << ":\n");
|
DEBUG(std::cerr << ((Value*)MBB->getBasicBlock())->getName() << ":\n");
|
||||||
|
|
||||||
for (MachineBasicBlock::iterator MII = MBB->begin(), E = MBB->end();
|
for (MachineBasicBlock::iterator MII = MBB->begin(), E = MBB->end();
|
||||||
@@ -1234,7 +1226,8 @@ void LiveIntervals::CopyCoallesceInMBB(MachineBasicBlock *MBB) {
|
|||||||
unsigned SrcReg, DstReg;
|
unsigned SrcReg, DstReg;
|
||||||
if (!tii_->isMoveInstr(*Inst, SrcReg, DstReg)) continue;
|
if (!tii_->isMoveInstr(*Inst, SrcReg, DstReg)) continue;
|
||||||
|
|
||||||
JoinCopy(Inst, SrcReg, DstReg);
|
if (!JoinCopy(Inst, SrcReg, DstReg))
|
||||||
|
TryAgain.push_back(getCopyRec(Inst, SrcReg, DstReg));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1242,12 +1235,14 @@ void LiveIntervals::CopyCoallesceInMBB(MachineBasicBlock *MBB) {
|
|||||||
void LiveIntervals::joinIntervals() {
|
void LiveIntervals::joinIntervals() {
|
||||||
DEBUG(std::cerr << "********** JOINING INTERVALS ***********\n");
|
DEBUG(std::cerr << "********** JOINING INTERVALS ***********\n");
|
||||||
|
|
||||||
|
std::vector<CopyRec> TryAgainList;
|
||||||
|
|
||||||
const LoopInfo &LI = getAnalysis<LoopInfo>();
|
const LoopInfo &LI = getAnalysis<LoopInfo>();
|
||||||
if (LI.begin() == LI.end()) {
|
if (LI.begin() == LI.end()) {
|
||||||
// If there are no loops in the function, join intervals in function order.
|
// If there are no loops in the function, join intervals in function order.
|
||||||
for (MachineFunction::iterator I = mf_->begin(), E = mf_->end();
|
for (MachineFunction::iterator I = mf_->begin(), E = mf_->end();
|
||||||
I != E; ++I)
|
I != E; ++I)
|
||||||
CopyCoallesceInMBB(I);
|
CopyCoallesceInMBB(I, TryAgainList);
|
||||||
} else {
|
} else {
|
||||||
// Otherwise, join intervals in inner loops before other intervals.
|
// Otherwise, join intervals in inner loops before other intervals.
|
||||||
// Unfortunately we can't just iterate over loop hierarchy here because
|
// Unfortunately we can't just iterate over loop hierarchy here because
|
||||||
@@ -1262,7 +1257,23 @@ void LiveIntervals::joinIntervals() {
|
|||||||
|
|
||||||
// Finally, join intervals in loop nest order.
|
// Finally, join intervals in loop nest order.
|
||||||
for (unsigned i = 0, e = MBBs.size(); i != e; ++i)
|
for (unsigned i = 0, e = MBBs.size(); i != e; ++i)
|
||||||
CopyCoallesceInMBB(MBBs[i].second);
|
CopyCoallesceInMBB(MBBs[i].second, TryAgainList);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Joining intervals can allow other intervals to be joined. Iteratively join
|
||||||
|
// until we make no progress.
|
||||||
|
bool ProgressMade = true;
|
||||||
|
while (ProgressMade) {
|
||||||
|
ProgressMade = false;
|
||||||
|
|
||||||
|
for (unsigned i = 0, e = TryAgainList.size(); i != e; ++i) {
|
||||||
|
CopyRec &TheCopy = TryAgainList[i];
|
||||||
|
if (TheCopy.MI &&
|
||||||
|
JoinCopy(TheCopy.MI, TheCopy.SrcReg, TheCopy.DstReg)) {
|
||||||
|
TheCopy.MI = 0; // Mark this one as done.
|
||||||
|
ProgressMade = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
DEBUG(std::cerr << "*** Register mapping ***\n");
|
DEBUG(std::cerr << "*** Register mapping ***\n");
|
||||||
|
|||||||
Reference in New Issue
Block a user