From 4367ff7aff54cac3e84d79d1b038f50390d66103 Mon Sep 17 00:00:00 2001 From: Evan Cheng Date: Fri, 26 Sep 2008 16:58:16 +0000 Subject: [PATCH] X86 address displacement field must be interpreted as a 32-bit value. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@56665 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Target/X86/X86RegisterInfo.cpp | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/lib/Target/X86/X86RegisterInfo.cpp b/lib/Target/X86/X86RegisterInfo.cpp index e86c6be0dd3..49766a8fc74 100644 --- a/lib/Target/X86/X86RegisterInfo.cpp +++ b/lib/Target/X86/X86RegisterInfo.cpp @@ -427,9 +427,10 @@ void X86RegisterInfo::eliminateFrameIndex(MachineBasicBlock::iterator II, // FrameIndex with base register with EBP. Add an offset to the offset. MI.getOperand(i).ChangeToRegister(BasePtr, false); - // Now add the frame object offset to the offset from EBP. - int64_t Offset = getFrameIndexOffset(MF, FrameIndex) + - MI.getOperand(i+3).getImm(); + // Now add the frame object offset to the offset from EBP. Offset is a + // 32-bit integer. + int Offset = getFrameIndexOffset(MF, FrameIndex) + + (int)(MI.getOperand(i+3).getImm()); MI.getOperand(i+3).ChangeToImmediate(Offset); } -- 2.34.1