aboutsummaryrefslogtreecommitdiffstats
path: root/lib/Target/X86/X86InstrInfo.cpp
diff options
context:
space:
mode:
authorEvan Cheng <evan.cheng@apple.com>2008-04-16 23:44:44 +0000
committerEvan Cheng <evan.cheng@apple.com>2008-04-16 23:44:44 +0000
commit03eb38848c9f880f8d97508b6a008f81cc4bdcb9 (patch)
tree07ac0a7f28a33d99f49d9a05f5d80808e321d6c9 /lib/Target/X86/X86InstrInfo.cpp
parent5e8fb81353c0a07a09cedd7b37aadd7c3cbcd5ae (diff)
downloadexternal_llvm-03eb38848c9f880f8d97508b6a008f81cc4bdcb9.zip
external_llvm-03eb38848c9f880f8d97508b6a008f81cc4bdcb9.tar.gz
external_llvm-03eb38848c9f880f8d97508b6a008f81cc4bdcb9.tar.bz2
Don't forget about sub-register indices when rematting instructions.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@49830 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/X86/X86InstrInfo.cpp')
-rw-r--r--lib/Target/X86/X86InstrInfo.cpp13
1 files changed, 13 insertions, 0 deletions
diff --git a/lib/Target/X86/X86InstrInfo.cpp b/lib/Target/X86/X86InstrInfo.cpp
index dcba66f..280809d 100644
--- a/lib/Target/X86/X86InstrInfo.cpp
+++ b/lib/Target/X86/X86InstrInfo.cpp
@@ -831,6 +831,14 @@ void X86InstrInfo::reMaterialize(MachineBasicBlock &MBB,
MachineBasicBlock::iterator I,
unsigned DestReg,
const MachineInstr *Orig) const {
+ unsigned SubIdx = Orig->getOperand(0).isReg()
+ ? Orig->getOperand(0).getSubReg() : 0;
+ bool ChangeSubIdx = SubIdx != 0;
+ if (SubIdx && TargetRegisterInfo::isPhysicalRegister(DestReg)) {
+ DestReg = RI.getSubReg(DestReg, SubIdx);
+ SubIdx = 0;
+ }
+
// MOV32r0 etc. are implemented with xor which clobbers condition code.
// Re-materialize them as movri instructions to avoid side effects.
switch (Orig->getOpcode()) {
@@ -853,6 +861,11 @@ void X86InstrInfo::reMaterialize(MachineBasicBlock &MBB,
break;
}
}
+
+ if (ChangeSubIdx) {
+ MachineInstr *NewMI = prior(I);
+ NewMI->getOperand(0).setSubReg(SubIdx);
+ }
}
/// isInvariantLoad - Return true if the specified instruction (which is marked