diff options
author | Bob Wilson <bob.wilson@apple.com> | 2009-05-19 18:33:02 +0000 |
---|---|---|
committer | Bob Wilson <bob.wilson@apple.com> | 2009-05-19 18:33:02 +0000 |
commit | 86c212e8945410c34455619a58b15a9e02ec8e0d (patch) | |
tree | f5960226823bc5cae818a0e9d047e449f69973fa /lib/Target/ARM/ARMRegisterInfo.cpp | |
parent | cd35ed5153963c92333aa8d82692f1344d3ec911 (diff) | |
download | llvm-86c212e8945410c34455619a58b15a9e02ec8e0d.tar.gz llvm-86c212e8945410c34455619a58b15a9e02ec8e0d.tar.bz2 llvm-86c212e8945410c34455619a58b15a9e02ec8e0d.tar.xz |
Follow up on new support for memory operands in ARM inline assembly.
This fixes pr4233.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@72115 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/ARM/ARMRegisterInfo.cpp')
-rw-r--r-- | lib/Target/ARM/ARMRegisterInfo.cpp | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/lib/Target/ARM/ARMRegisterInfo.cpp b/lib/Target/ARM/ARMRegisterInfo.cpp index 693d12ee1f..964f50a270 100644 --- a/lib/Target/ARM/ARMRegisterInfo.cpp +++ b/lib/Target/ARM/ARMRegisterInfo.cpp @@ -688,6 +688,10 @@ void ARMRegisterInfo::eliminateFrameIndex(MachineBasicBlock::iterator II, unsigned AddrMode = (Desc.TSFlags & ARMII::AddrModeMask); bool isSub = false; + // Memory operands in inline assembly always use AddrMode2. + if (Opcode == ARM::INLINEASM) + AddrMode = ARMII::AddrMode2; + if (Opcode == ARM::ADDri) { Offset += MI.getOperand(i+1).getImm(); if (Offset == 0) { |