ARM isLegalAddressImmediate should check if type is a simple type now that optimizer...
authorEvan Cheng <evan.cheng@apple.com>
Mon, 9 Mar 2009 19:15:00 +0000 (19:15 +0000)
committerEvan Cheng <evan.cheng@apple.com>
Mon, 9 Mar 2009 19:15:00 +0000 (19:15 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@66429 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Target/ARM/ARMISelLowering.cpp
test/CodeGen/ARM/2009-03-09-AddrModeBug.ll [new file with mode: 0644]

index cc38efb9ccc8c8817d5b5e8c6af665f46cc94704..a6674b2916e2aa1d8e26a425e63c3f51e7f9becb 100644 (file)
@@ -1591,6 +1591,9 @@ static bool isLegalAddressImmediate(int64_t V, MVT VT,
   if (V == 0)
     return true;
 
+  if (!VT.isSimple())
+    return false;
+
   if (Subtarget->isThumb()) {
     if (V < 0)
       return false;
diff --git a/test/CodeGen/ARM/2009-03-09-AddrModeBug.ll b/test/CodeGen/ARM/2009-03-09-AddrModeBug.ll
new file mode 100644 (file)
index 0000000..0ec6d7d
--- /dev/null
@@ -0,0 +1,13 @@
+; RUN: llvm-as < %s | llc -march=arm
+
+       %struct.hit_t = type { %struct.v_t, double }
+       %struct.node_t = type { %struct.hit_t, %struct.hit_t, i32 }
+       %struct.v_t = type { double, double, double }
+
+define fastcc %struct.node_t* @_ZL6createP6node_tii3v_tS1_d(%struct.node_t* %n, i32 %lvl, i32 %dist, i64 %c.0.0, i64 %c.0.1, i64 %c.0.2, i64 %d.0.0, i64 %d.0.1, i64 %d.0.2, double %r) nounwind {
+entry:
+       %0 = getelementptr %struct.node_t* %n, i32 0, i32 1             ; <%struct.hit_t*> [#uses=1]
+       %1 = bitcast %struct.hit_t* %0 to i256*         ; <i256*> [#uses=1]
+       store i256 0, i256* %1, align 4
+       unreachable
+}