mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-15 07:34:33 +00:00
- Update the virtual reg to machine instruction map when hoisting.
- Fix subtle bug when creating initially creating this map. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@44873 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
650b0527a4
commit
28bd5f0e47
@ -215,7 +215,7 @@ void MachineLICM::MapVirtualRegisterDefs(const MachineFunction &MF) {
|
|||||||
const MachineInstr &MI = *II;
|
const MachineInstr &MI = *II;
|
||||||
|
|
||||||
for (unsigned i = 0, e = MI.getNumOperands(); i != e; ++i) {
|
for (unsigned i = 0, e = MI.getNumOperands(); i != e; ++i) {
|
||||||
const MachineOperand &MO = MI.getOperand(0);
|
const MachineOperand &MO = MI.getOperand(i);
|
||||||
|
|
||||||
if (MO.isRegister() && MO.isDef() &&
|
if (MO.isRegister() && MO.isDef() &&
|
||||||
MRegisterInfo::isVirtualRegister(MO.getReg()))
|
MRegisterInfo::isVirtualRegister(MO.getReg()))
|
||||||
@ -317,7 +317,17 @@ void MachineLICM::Hoist(MachineInstr &MI) {
|
|||||||
"The predecessor doesn't feed directly into the loop header!");
|
"The predecessor doesn't feed directly into the loop header!");
|
||||||
|
|
||||||
// Now move the instructions to the predecessor.
|
// Now move the instructions to the predecessor.
|
||||||
MoveInstToEndOfBlock(MBB, MI.clone());
|
MachineInstr *NewMI = MI.clone();
|
||||||
|
MoveInstToEndOfBlock(MBB, NewMI);
|
||||||
|
|
||||||
|
// Update VRegDefs.
|
||||||
|
for (unsigned i = 0, e = NewMI->getNumOperands(); i != e; ++i) {
|
||||||
|
const MachineOperand &MO = NewMI->getOperand(i);
|
||||||
|
|
||||||
|
if (MO.isRegister() && MO.isDef() &&
|
||||||
|
MRegisterInfo::isVirtualRegister(MO.getReg()))
|
||||||
|
VRegDefs[MO.getReg()] = NewMI;
|
||||||
|
}
|
||||||
|
|
||||||
// Hoisting was successful! Remove bothersome instruction now.
|
// Hoisting was successful! Remove bothersome instruction now.
|
||||||
MI.getParent()->remove(&MI);
|
MI.getParent()->remove(&MI);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user