mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-15 23:31:37 +00:00
ARM NEON two-operand aliases for VQDMULH.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@146514 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
e91e7bcadc
commit
0f293de207
@ -5708,6 +5708,17 @@ def : NEONInstAlias<"vext${p}.32 $Vdn, $Vm, $imm",
|
|||||||
def : NEONInstAlias<"vext${p}.64 $Vdn, $Vm, $imm",
|
def : NEONInstAlias<"vext${p}.64 $Vdn, $Vm, $imm",
|
||||||
(VEXTq64 QPR:$Vdn, QPR:$Vdn, QPR:$Vm, imm0_1:$imm, pred:$p)>;
|
(VEXTq64 QPR:$Vdn, QPR:$Vdn, QPR:$Vm, imm0_1:$imm, pred:$p)>;
|
||||||
|
|
||||||
|
// Two-operand variants for VQDMULH
|
||||||
|
def : NEONInstAlias<"vqdmulh${p}.s16 $Vdn, $Vm",
|
||||||
|
(VQDMULHv4i16 DPR:$Vdn, DPR:$Vdn, DPR:$Vm, pred:$p)>;
|
||||||
|
def : NEONInstAlias<"vqdmulh${p}.s32 $Vdn, $Vm",
|
||||||
|
(VQDMULHv2i32 DPR:$Vdn, DPR:$Vdn, DPR:$Vm, pred:$p)>;
|
||||||
|
|
||||||
|
def : NEONInstAlias<"vqdmulh${p}.s16 $Vdn, $Vm",
|
||||||
|
(VQDMULHv8i16 QPR:$Vdn, QPR:$Vdn, QPR:$Vm, pred:$p)>;
|
||||||
|
def : NEONInstAlias<"vqdmulh${p}.s32 $Vdn, $Vm",
|
||||||
|
(VQDMULHv4i32 QPR:$Vdn, QPR:$Vdn, QPR:$Vm, pred:$p)>;
|
||||||
|
|
||||||
// 'gas' compatibility aliases for quad-word instructions. Strictly speaking,
|
// 'gas' compatibility aliases for quad-word instructions. Strictly speaking,
|
||||||
// these should restrict to just the Q register variants, but the register
|
// these should restrict to just the Q register variants, but the register
|
||||||
// classes are enough to match correctly regardless, so we keep it simple
|
// classes are enough to match correctly regardless, so we keep it simple
|
||||||
|
@ -1192,6 +1192,8 @@ def : VFP2MnemonicAlias<"fuitod", "vcvt.f64.u32">;
|
|||||||
def : VFP2MnemonicAlias<"fuitos", "vcvt.f32.u32">;
|
def : VFP2MnemonicAlias<"fuitos", "vcvt.f32.u32">;
|
||||||
def : VFP2MnemonicAlias<"fsts", "vstr">;
|
def : VFP2MnemonicAlias<"fsts", "vstr">;
|
||||||
def : VFP2MnemonicAlias<"fstd", "vstr">;
|
def : VFP2MnemonicAlias<"fstd", "vstr">;
|
||||||
|
def : VFP2MnemonicAlias<"fmacd", "vmla.f64">;
|
||||||
|
def : VFP2MnemonicAlias<"fmacs", "vmla.f32">;
|
||||||
|
|
||||||
def : VFP2InstAlias<"fmstat${p}", (FMSTAT pred:$p)>;
|
def : VFP2InstAlias<"fmstat${p}", (FMSTAT pred:$p)>;
|
||||||
def : VFP2InstAlias<"fadds${p} $Sd, $Sn, $Sm",
|
def : VFP2InstAlias<"fadds${p} $Sd, $Sn, $Sm",
|
||||||
|
@ -51,8 +51,16 @@
|
|||||||
vqdmulh.s32 d16, d16, d17
|
vqdmulh.s32 d16, d16, d17
|
||||||
vqdmulh.s16 q8, q8, q9
|
vqdmulh.s16 q8, q8, q9
|
||||||
vqdmulh.s32 q8, q8, q9
|
vqdmulh.s32 q8, q8, q9
|
||||||
|
vqdmulh.s16 d16, d17
|
||||||
|
vqdmulh.s32 d16, d17
|
||||||
|
vqdmulh.s16 q8, q9
|
||||||
|
vqdmulh.s32 q8, q9
|
||||||
vqdmulh.s16 d11, d2, d3[0]
|
vqdmulh.s16 d11, d2, d3[0]
|
||||||
|
|
||||||
|
@ CHECK: vqdmulh.s16 d16, d16, d17 @ encoding: [0xa1,0x0b,0x50,0xf2]
|
||||||
|
@ CHECK: vqdmulh.s32 d16, d16, d17 @ encoding: [0xa1,0x0b,0x60,0xf2]
|
||||||
|
@ CHECK: vqdmulh.s16 q8, q8, q9 @ encoding: [0xe2,0x0b,0x50,0xf2]
|
||||||
|
@ CHECK: vqdmulh.s32 q8, q8, q9 @ encoding: [0xe2,0x0b,0x60,0xf2]
|
||||||
@ CHECK: vqdmulh.s16 d16, d16, d17 @ encoding: [0xa1,0x0b,0x50,0xf2]
|
@ CHECK: vqdmulh.s16 d16, d16, d17 @ encoding: [0xa1,0x0b,0x50,0xf2]
|
||||||
@ CHECK: vqdmulh.s32 d16, d16, d17 @ encoding: [0xa1,0x0b,0x60,0xf2]
|
@ CHECK: vqdmulh.s32 d16, d16, d17 @ encoding: [0xa1,0x0b,0x60,0xf2]
|
||||||
@ CHECK: vqdmulh.s16 q8, q8, q9 @ encoding: [0xe2,0x0b,0x50,0xf2]
|
@ CHECK: vqdmulh.s16 q8, q8, q9 @ encoding: [0xe2,0x0b,0x50,0xf2]
|
||||||
|
Loading…
x
Reference in New Issue
Block a user