ARM NEON two-operand aliases for VPADD.
authorJim Grosbach <grosbach@apple.com>
Mon, 19 Dec 2011 19:51:03 +0000 (19:51 +0000)
committerJim Grosbach <grosbach@apple.com>
Mon, 19 Dec 2011 19:51:03 +0000 (19:51 +0000)
rdar://10602276

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

lib/Target/ARM/ARMInstrNEON.td
test/MC/ARM/neon-pairwise-encoding.s

index cac8f45468926c078671554a0115c374d0a003d6..ef987d210527efc53fb5beeeab7728e7968801e9 100644 (file)
@@ -5939,6 +5939,16 @@ def : NEONInstAlias<"vmin${p}.u32 $Vdn, $Vm",
 def : NEONInstAlias<"vmin${p}.f32 $Vdn, $Vm",
                     (VMINfq QPR:$Vdn, QPR:$Vdn, QPR:$Vm, pred:$p)>;
 
+// Two-operand variants for VPADD.
+def : NEONInstAlias<"vpadd${p}.i8 $Vdn, $Vm",
+                    (VPADDi8 DPR:$Vdn, DPR:$Vdn, DPR:$Vm, pred:$p)>;
+def : NEONInstAlias<"vpadd${p}.i16 $Vdn, $Vm",
+                    (VPADDi16 DPR:$Vdn, DPR:$Vdn, DPR:$Vm, pred:$p)>;
+def : NEONInstAlias<"vpadd${p}.i32 $Vdn, $Vm",
+                    (VPADDi32 DPR:$Vdn, DPR:$Vdn, DPR:$Vm, pred:$p)>;
+def : NEONInstAlias<"vpadd${p}.f32 $Vdn, $Vm",
+                    (VPADDf DPR:$Vdn, DPR:$Vdn, DPR:$Vm, pred:$p)>;
+
 // 'gas' compatibility aliases for quad-word instructions. Strictly speaking,
 // these should restrict to just the Q register variants, but the register
 // classes are enough to match correctly regardless, so we keep it simple
index 65c47bd64aeb737d3e6b1966d764d7b0e5ffec68..b1e86aa58edb831948b9b2c5aa96d1dcebb9a61f 100644 (file)
@@ -8,6 +8,16 @@
        vpadd.i32       d16, d17, d16
 @ CHECK: vpadd.f32     d16, d16, d17   @ encoding: [0xa1,0x0d,0x40,0xf3]
        vpadd.f32       d16, d16, d17
+
+@ CHECK: vpadd.i8      d17, d17, d16   @ encoding: [0xb0,0x1b,0x41,0xf2]
+       vpadd.i8        d17, d16
+@ CHECK: vpadd.i16     d17, d17, d16   @ encoding: [0xb0,0x1b,0x51,0xf2]
+       vpadd.i16       d17, d16
+@ CHECK: vpadd.i32     d17, d17, d16   @ encoding: [0xb0,0x1b,0x61,0xf2]
+       vpadd.i32       d17, d16
+@ CHECK: vpadd.f32     d16, d16, d17   @ encoding: [0xa1,0x0d,0x40,0xf3]
+       vpadd.f32       d16, d17
+
 @ CHECK: vpaddl.s8     d16, d16        @ encoding: [0x20,0x02,0xf0,0xf3]
        vpaddl.s8       d16, d16
 @ CHECK: vpaddl.s16    d16, d16        @ encoding: [0x20,0x02,0xf4,0xf3]