diff --git a/lib/Target/X86/X86PeepholeOpt.cpp b/lib/Target/X86/X86PeepholeOpt.cpp index 9d02cbd69a9..8baf5d214c4 100644 --- a/lib/Target/X86/X86PeepholeOpt.cpp +++ b/lib/Target/X86/X86PeepholeOpt.cpp @@ -198,9 +198,11 @@ bool PH::PeepholeOptimize(MachineBasicBlock &MBB, addReg(R1).addSImm(Offset).addZImm((char)Val)); } else if (MI->getOperand(3).isGlobalAddress()) { GlobalValue *GA = MI->getOperand(3).getGlobal(); + int Offset = MI->getOperand(3).getOffset(); I = MBB.insert(MBB.erase(I), BuildMI(Opcode, 5).addReg(R0).addZImm(Scale). - addReg(R1).addGlobalAddress(GA).addZImm((char)Val)); + addReg(R1).addGlobalAddress(GA, false, Offset). + addZImm((char)Val)); } return true; }