aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorEvan Cheng <evan.cheng@apple.com>2008-09-26 16:58:16 +0000
committerEvan Cheng <evan.cheng@apple.com>2008-09-26 16:58:16 +0000
commit001ffdd36b04fe8617788826156b3b5a0434479b (patch)
treedfcf74243c26f8c18a1c878d7a0a1ed245d78d9d
parent61a625ff702c7d174b302b0db032dc5568ebc054 (diff)
downloadllvm-001ffdd36b04fe8617788826156b3b5a0434479b.zip
llvm-001ffdd36b04fe8617788826156b3b5a0434479b.tar.gz
llvm-001ffdd36b04fe8617788826156b3b5a0434479b.tar.bz2
X86 address displacement field must be interpreted as a 32-bit value.
llvm-svn: 56665
-rw-r--r--llvm/lib/Target/X86/X86RegisterInfo.cpp7
1 files changed, 4 insertions, 3 deletions
diff --git a/llvm/lib/Target/X86/X86RegisterInfo.cpp b/llvm/lib/Target/X86/X86RegisterInfo.cpp
index e86c6be..49766a8 100644
--- a/llvm/lib/Target/X86/X86RegisterInfo.cpp
+++ b/llvm/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);
}