summaryrefslogtreecommitdiff
path: root/lib/Target
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2007-04-13 06:50:55 +0000
committerChris Lattner <sabre@nondot.org>2007-04-13 06:50:55 +0000
commit5a3d40d88fbfe79ad7ed5802ff4fd1498c4c820b (patch)
tree95425bf37536e8c5874ae1e64af25bf2c14c96ab /lib/Target
parentdaacf22537e0d140c379a39a11a83d3321395d4d (diff)
downloadllvm-5a3d40d88fbfe79ad7ed5802ff4fd1498c4c820b.tar.gz
llvm-5a3d40d88fbfe79ad7ed5802ff4fd1498c4c820b.tar.bz2
llvm-5a3d40d88fbfe79ad7ed5802ff4fd1498c4c820b.tar.xz
arm has r+r*s and r+i addr modes, but no r+i+r*s addr modes.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@35962 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target')
-rw-r--r--lib/Target/ARM/ARMISelLowering.cpp6
1 files changed, 5 insertions, 1 deletions
diff --git a/lib/Target/ARM/ARMISelLowering.cpp b/lib/Target/ARM/ARMISelLowering.cpp
index 219e4e1437..0cef4cce68 100644
--- a/lib/Target/ARM/ARMISelLowering.cpp
+++ b/lib/Target/ARM/ARMISelLowering.cpp
@@ -1370,8 +1370,12 @@ bool ARMTargetLowering::isLegalAddressingMode(const AddrMode &AM,
case 1:
if (Subtarget->isThumb())
return false;
-
+ // FALL THROUGH.
default:
+ // ARM doesn't support any R+R*scale+imm addr modes.
+ if (AM.BaseOffs)
+ return false;
+
int Scale = AM.Scale;
switch (getValueType(Ty)) {
default: return false;