From 609d11387457cd09f8369c60e453e5c466e444d7 Mon Sep 17 00:00:00 2001 From: Jim Grosbach Date: Fri, 11 Nov 2011 23:34:43 +0000 Subject: [PATCH] ARM optional size suffix for VLDR/VSTR syntax. llvm-svn: 144427 --- llvm/lib/Target/ARM/ARMInstrVFP.td | 9 +++++++++ llvm/test/MC/ARM/simple-fp-encoding.s | 10 ++++++++++ 2 files changed, 19 insertions(+) diff --git a/llvm/lib/Target/ARM/ARMInstrVFP.td b/llvm/lib/Target/ARM/ARMInstrVFP.td index e746cf20d032..22a464e50cde 100644 --- a/llvm/lib/Target/ARM/ARMInstrVFP.td +++ b/llvm/lib/Target/ARM/ARMInstrVFP.td @@ -1163,3 +1163,12 @@ def FCONSTS : VFPAI<(outs SPR:$Sd), (ins vfp_f32imm:$imm), def : VFP2InstAlias<"fmstat${p}", (FMSTAT pred:$p)>; +// The size suffix is optional for VLDR/VSTR +def : VFP2InstAlias<"vldr$p $Dd, $addr", + (VLDRD DPR:$Dd, addrmode5:$addr, pred:$p)>; +def : VFP2InstAlias<"vldr$p $Sd, $addr", + (VLDRS SPR:$Sd, addrmode5:$addr, pred:$p)>; +def : VFP2InstAlias<"vstr$p $Dd, $addr", + (VSTRD DPR:$Dd, addrmode5:$addr, pred:$p)>; +def : VFP2InstAlias<"vstr$p $Sd, $addr", + (VSTRS SPR:$Sd, addrmode5:$addr, pred:$p)>; diff --git a/llvm/test/MC/ARM/simple-fp-encoding.s b/llvm/test/MC/ARM/simple-fp-encoding.s index 8cc32bc3fce5..cb76215f7fd0 100644 --- a/llvm/test/MC/ARM/simple-fp-encoding.s +++ b/llvm/test/MC/ARM/simple-fp-encoding.s @@ -173,7 +173,12 @@ vmov r0, r1, d16 @ CHECK: vldr.64 d17, [r0] @ encoding: [0x00,0x1b,0xd0,0xed] +@ CHECK: vldr.32 s0, [lr] @ encoding: [0x00,0x0a,0x9e,0xed] +@ CHECK: vldr.64 d0, [lr] @ encoding: [0x00,0x0b,0x9e,0xed] + vldr.64 d17, [r0] + vldr s0, [lr] + vldr d0, [lr] @ CHECK: vldr.64 d1, [r2, #32] @ encoding: [0x08,0x1b,0x92,0xed] @ CHECK: vldr.64 d1, [r2, #-32] @ encoding: [0x08,0x1b,0x12,0xed] @@ -211,9 +216,14 @@ @ CHECK: vstr.64 d4, [r1] @ encoding: [0x00,0x4b,0x81,0xed] @ CHECK: vstr.64 d4, [r1, #24] @ encoding: [0x06,0x4b,0x81,0xed] @ CHECK: vstr.64 d4, [r1, #-24] @ encoding: [0x06,0x4b,0x01,0xed] +@ CHECK: vstr.32 s0, [lr] @ encoding: [0x00,0x0a,0x8e,0xed] +@ CHECK: vstr.64 d0, [lr] @ encoding: [0x00,0x0b,0x8e,0xed] + vstr.64 d4, [r1] vstr.64 d4, [r1, #24] vstr.64 d4, [r1, #-24] + vstr s0, [lr] + vstr d0, [lr] @ CHECK: vstr.32 s4, [r1] @ encoding: [0x00,0x2a,0x81,0xed] @ CHECK: vstr.32 s4, [r1, #24] @ encoding: [0x06,0x2a,0x81,0xed]