aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2005-01-11 22:58:43 +0000
committerChris Lattner <sabre@nondot.org>2005-01-11 22:58:43 +0000
commit5f75d9a88c32f4aa47cc8a91dd6e59fdce711cc3 (patch)
tree14ec6ca977c59100595759dc9351066c0ae19296
parentc4b6a789809696c2835999d39293466c99f22c1a (diff)
Handle the global address case here, not just the offset case.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@19487 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--lib/Target/X86/X86PeepholeOpt.cpp15
1 files changed, 11 insertions, 4 deletions
diff --git a/lib/Target/X86/X86PeepholeOpt.cpp b/lib/Target/X86/X86PeepholeOpt.cpp
index d0414809f5..9d02cbd69a 100644
--- a/lib/Target/X86/X86PeepholeOpt.cpp
+++ b/lib/Target/X86/X86PeepholeOpt.cpp
@@ -191,10 +191,17 @@ bool PH::PeepholeOptimize(MachineBasicBlock &MBB,
unsigned R0 = MI->getOperand(0).getReg();
unsigned Scale = MI->getOperand(1).getImmedValue();
unsigned R1 = MI->getOperand(2).getReg();
- unsigned Offset = MI->getOperand(3).getImmedValue();
- I = MBB.insert(MBB.erase(I),
- BuildMI(Opcode, 5).addReg(R0).addZImm(Scale).
- addReg(R1).addSImm(Offset).addZImm((char)Val));
+ if (MI->getOperand(3).isImmediate()) {
+ unsigned Offset = MI->getOperand(3).getImmedValue();
+ I = MBB.insert(MBB.erase(I),
+ BuildMI(Opcode, 5).addReg(R0).addZImm(Scale).
+ addReg(R1).addSImm(Offset).addZImm((char)Val));
+ } else if (MI->getOperand(3).isGlobalAddress()) {
+ GlobalValue *GA = MI->getOperand(3).getGlobal();
+ I = MBB.insert(MBB.erase(I),
+ BuildMI(Opcode, 5).addReg(R0).addZImm(Scale).
+ addReg(R1).addGlobalAddress(GA).addZImm((char)Val));
+ }
return true;
}
}