diff options
| author | Evan Cheng <evan.cheng@apple.com> | 2008-09-26 16:58:16 +0000 |
|---|---|---|
| committer | Evan Cheng <evan.cheng@apple.com> | 2008-09-26 16:58:16 +0000 |
| commit | 001ffdd36b04fe8617788826156b3b5a0434479b (patch) | |
| tree | dfcf74243c26f8c18a1c878d7a0a1ed245d78d9d | |
| parent | 61a625ff702c7d174b302b0db032dc5568ebc054 (diff) | |
| download | llvm-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.cpp | 7 |
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); } |
