mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-04-03 16:21:41 +00:00
Revert "LivePhysRegs: Skip reserved regs in computeLiveIns; NFCI"
Tentatively revert, suspecting that it caused breakage in stage2 buildbots. This reverts commit r303949. This reverts commit r303937. llvm-svn: 303955
This commit is contained in:
parent
d1780d1f25
commit
34bf22f6ad
include/llvm/CodeGen
lib/CodeGen
@ -163,7 +163,7 @@ inline raw_ostream &operator<<(raw_ostream &OS, const LivePhysRegs& LR) {
|
||||
/// lists are up-to-date. Uses the given LivePhysReg instance \p LiveRegs; This
|
||||
/// is just here to avoid repeated heap allocations when calling this multiple
|
||||
/// times in a pass.
|
||||
void computeLiveIns(LivePhysRegs &LiveRegs, const MachineRegisterInfo &MRI,
|
||||
void computeLiveIns(LivePhysRegs &LiveRegs, const TargetRegisterInfo &TRI,
|
||||
MachineBasicBlock &MBB);
|
||||
|
||||
} // end namespace llvm
|
||||
|
@ -153,14 +153,13 @@ bool BranchFolder::OptimizeFunction(MachineFunction &MF,
|
||||
|
||||
TriedMerging.clear();
|
||||
|
||||
MachineRegisterInfo &MRI = MF.getRegInfo();
|
||||
AfterBlockPlacement = AfterPlacement;
|
||||
TII = tii;
|
||||
TRI = tri;
|
||||
MMI = mmi;
|
||||
MLI = mli;
|
||||
this->MRI = &MRI;
|
||||
|
||||
MachineRegisterInfo &MRI = MF.getRegInfo();
|
||||
UpdateLiveIns = MRI.tracksLiveness() && TRI->trackLivenessAfterRegAlloc(MF);
|
||||
if (!UpdateLiveIns)
|
||||
MRI.invalidateLiveness();
|
||||
@ -352,7 +351,7 @@ void BranchFolder::ReplaceTailWithBranchTo(MachineBasicBlock::iterator OldInst,
|
||||
|
||||
if (UpdateLiveIns) {
|
||||
NewDest->clearLiveIns();
|
||||
computeLiveIns(LiveRegs, *MRI, *NewDest);
|
||||
computeLiveIns(LiveRegs, *TRI, *NewDest);
|
||||
}
|
||||
|
||||
++NumTailMerge;
|
||||
@ -389,7 +388,7 @@ MachineBasicBlock *BranchFolder::SplitMBBAt(MachineBasicBlock &CurMBB,
|
||||
MBBFreqInfo.setBlockFreq(NewMBB, MBBFreqInfo.getBlockFreq(&CurMBB));
|
||||
|
||||
if (UpdateLiveIns)
|
||||
computeLiveIns(LiveRegs, *MRI, *NewMBB);
|
||||
computeLiveIns(LiveRegs, *TRI, *NewMBB);
|
||||
|
||||
// Add the new block to the funclet.
|
||||
const auto &FuncletI = FuncletMembership.find(&CurMBB);
|
||||
|
@ -108,7 +108,6 @@ namespace llvm {
|
||||
bool UpdateLiveIns;
|
||||
unsigned MinCommonTailLength;
|
||||
const TargetInstrInfo *TII;
|
||||
const MachineRegisterInfo *MRI;
|
||||
const TargetRegisterInfo *TRI;
|
||||
MachineModuleInfo *MMI;
|
||||
MachineLoopInfo *MLI;
|
||||
|
@ -259,7 +259,7 @@ MachineBasicBlock *BranchRelaxation::splitBlockBeforeInstr(MachineInstr &MI,
|
||||
|
||||
// Need to fix live-in lists if we track liveness.
|
||||
if (TRI->trackLivenessAfterRegAlloc(*MF))
|
||||
computeLiveIns(LiveRegs, MF->getRegInfo(), *NewBB);
|
||||
computeLiveIns(LiveRegs, *TRI, *NewBB);
|
||||
|
||||
++NumSplit;
|
||||
|
||||
|
@ -214,10 +214,8 @@ void LivePhysRegs::addLiveIns(const MachineBasicBlock &MBB) {
|
||||
addBlockLiveIns(MBB);
|
||||
}
|
||||
|
||||
void llvm::computeLiveIns(LivePhysRegs &LiveRegs,
|
||||
const MachineRegisterInfo &MRI,
|
||||
void llvm::computeLiveIns(LivePhysRegs &LiveRegs, const TargetRegisterInfo &TRI,
|
||||
MachineBasicBlock &MBB) {
|
||||
const TargetRegisterInfo &TRI = *MRI.getTargetRegisterInfo();
|
||||
assert(MBB.livein_empty());
|
||||
LiveRegs.init(TRI);
|
||||
LiveRegs.addLiveOutsNoPristines(MBB);
|
||||
@ -225,12 +223,10 @@ void llvm::computeLiveIns(LivePhysRegs &LiveRegs,
|
||||
LiveRegs.stepBackward(MI);
|
||||
|
||||
for (unsigned Reg : LiveRegs) {
|
||||
if (MRI.isReserved(Reg))
|
||||
continue;
|
||||
// Skip the register if we are about to add one of its super registers.
|
||||
bool ContainsSuperReg = false;
|
||||
for (MCSuperRegIterator SReg(Reg, &TRI); SReg.isValid(); ++SReg) {
|
||||
if (LiveRegs.contains(*SReg) && !MRI.isReserved(*SReg)) {
|
||||
if (LiveRegs.contains(*SReg)) {
|
||||
ContainsSuperReg = true;
|
||||
break;
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user