STRD and LDRD require ARMv5TE, not just ARMv5T.
authorMisha Brukman <brukman+llvm@gmail.com>
Thu, 27 Aug 2009 14:14:21 +0000 (14:14 +0000)
committerMisha Brukman <brukman+llvm@gmail.com>
Thu, 27 Aug 2009 14:14:21 +0000 (14:14 +0000)
See http://llvm.org/PR4687 for more info and links.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@80244 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Target/ARM/ARMInstrInfo.td

index 21b42885d29c8f33c37daaafa681796faa0857d8..2acee58ac41ce5b903fcefc61190176a69fb7980 100644 (file)
@@ -767,7 +767,7 @@ let mayLoad = 1 in {
 // Load doubleword
 def LDRD : AI3ldd<(outs GPR:$dst1, GPR:$dst2), (ins addrmode3:$addr), LdMiscFrm,
                  IIC_iLoadr, "ldr", "d $dst1, $addr",
-                 []>, Requires<[IsARM, HasV5T]>;
+                 []>, Requires<[IsARM, HasV5TE]>;
 
 // Indexed loads
 def LDR_PRE  : AI2ldwpr<(outs GPR:$dst, GPR:$base_wb),
@@ -829,7 +829,7 @@ def STRB : AI2stb<(outs), (ins GPR:$src, addrmode2:$addr), StFrm, IIC_iStorer,
 let mayStore = 1 in
 def STRD : AI3std<(outs), (ins GPR:$src1, GPR:$src2, addrmode3:$addr),
                StMiscFrm, IIC_iStorer,
-               "str", "d $src1, $addr", []>, Requires<[IsARM, HasV5T]>;
+               "str", "d $src1, $addr", []>, Requires<[IsARM, HasV5TE]>;
 
 // Indexed stores
 def STR_PRE  : AI2stwpr<(outs GPR:$base_wb),