diff options
author | Evan Cheng <evan.cheng@apple.com> | 2008-04-16 23:44:44 +0000 |
---|---|---|
committer | Evan Cheng <evan.cheng@apple.com> | 2008-04-16 23:44:44 +0000 |
commit | 03eb38848c9f880f8d97508b6a008f81cc4bdcb9 (patch) | |
tree | 07ac0a7f28a33d99f49d9a05f5d80808e321d6c9 /lib/Target/X86/X86InstrInfo.cpp | |
parent | 5e8fb81353c0a07a09cedd7b37aadd7c3cbcd5ae (diff) | |
download | external_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.cpp | 13 |
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 |