mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-15 07:34:33 +00:00
Yet more ARM NEON assembly parsing for the lane index operand.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@142416 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
0487e459e0
commit
a7d2e759ee
@ -1976,8 +1976,8 @@ class N3VQSL<bits<2> op21_20, bits<4> op11_8,
|
||||
InstrItinClass itin, string OpcodeStr, string Dt,
|
||||
ValueType ResTy, ValueType OpTy, SDNode ShOp>
|
||||
: N3VLane32<1, 1, op21_20, op11_8, 1, 0,
|
||||
(outs QPR:$Vd), (ins QPR:$Vn, DPR_VFP2:$Vm, nohash_imm:$lane),
|
||||
NVMulSLFrm, itin, OpcodeStr, Dt, "$Vd, $Vn, $Vm[$lane]", "",
|
||||
(outs QPR:$Vd), (ins QPR:$Vn, DPR_VFP2:$Vm, VectorIndex32:$lane),
|
||||
NVMulSLFrm, itin, OpcodeStr, Dt, "$Vd, $Vn, $Vm$lane", "",
|
||||
[(set (ResTy QPR:$Vd),
|
||||
(ResTy (ShOp (ResTy QPR:$Vn),
|
||||
(ResTy (NEONvduplane (OpTy DPR_VFP2:$Vm),
|
||||
@ -1987,8 +1987,8 @@ class N3VQSL<bits<2> op21_20, bits<4> op11_8,
|
||||
class N3VQSL16<bits<2> op21_20, bits<4> op11_8, string OpcodeStr, string Dt,
|
||||
ValueType ResTy, ValueType OpTy, SDNode ShOp>
|
||||
: N3VLane16<1, 1, op21_20, op11_8, 1, 0,
|
||||
(outs QPR:$Vd), (ins QPR:$Vn, DPR_8:$Vm, nohash_imm:$lane),
|
||||
NVMulSLFrm, IIC_VMULi16Q, OpcodeStr, Dt,"$Vd, $Vn, $Vm[$lane]","",
|
||||
(outs QPR:$Vd), (ins QPR:$Vn, DPR_8:$Vm, VectorIndex16:$lane),
|
||||
NVMulSLFrm, IIC_VMULi16Q, OpcodeStr, Dt,"$Vd, $Vn, $Vm$lane", "",
|
||||
[(set (ResTy QPR:$Vd),
|
||||
(ResTy (ShOp (ResTy QPR:$Vn),
|
||||
(ResTy (NEONvduplane (OpTy DPR_8:$Vm),
|
||||
@ -2050,8 +2050,8 @@ class N3VQIntSL<bits<2> op21_20, bits<4> op11_8, InstrItinClass itin,
|
||||
string OpcodeStr, string Dt,
|
||||
ValueType ResTy, ValueType OpTy, Intrinsic IntOp>
|
||||
: N3VLane32<1, 1, op21_20, op11_8, 1, 0,
|
||||
(outs QPR:$Vd), (ins QPR:$Vn, DPR_VFP2:$Vm, nohash_imm:$lane),
|
||||
NVMulSLFrm, itin, OpcodeStr, Dt, "$Vd, $Vn, $Vm[$lane]", "",
|
||||
(outs QPR:$Vd), (ins QPR:$Vn, DPR_VFP2:$Vm, VectorIndex32:$lane),
|
||||
NVMulSLFrm, itin, OpcodeStr, Dt, "$Vd, $Vn, $Vm$lane", "",
|
||||
[(set (ResTy QPR:$Vd),
|
||||
(ResTy (IntOp (ResTy QPR:$Vn),
|
||||
(ResTy (NEONvduplane (OpTy DPR_VFP2:$Vm),
|
||||
@ -2062,8 +2062,8 @@ class N3VQIntSL16<bits<2> op21_20, bits<4> op11_8, InstrItinClass itin,
|
||||
string OpcodeStr, string Dt,
|
||||
ValueType ResTy, ValueType OpTy, Intrinsic IntOp>
|
||||
: N3VLane16<1, 1, op21_20, op11_8, 1, 0,
|
||||
(outs QPR:$Vd), (ins QPR:$Vn, DPR_8:$Vm, nohash_imm:$lane),
|
||||
NVMulSLFrm, itin, OpcodeStr, Dt, "$Vd, $Vn, $Vm[$lane]", "",
|
||||
(outs QPR:$Vd), (ins QPR:$Vn, DPR_8:$Vm, VectorIndex16:$lane),
|
||||
NVMulSLFrm, itin, OpcodeStr, Dt, "$Vd, $Vn, $Vm$lane", "",
|
||||
[(set (ResTy QPR:$Vd),
|
||||
(ResTy (IntOp (ResTy QPR:$Vn),
|
||||
(ResTy (NEONvduplane (OpTy DPR_8:$Vm),
|
||||
@ -2252,9 +2252,9 @@ class N3VLInt3SL<bit op24, bits<2> op21_20, bits<4> op11_8, InstrItinClass itin,
|
||||
ValueType ResTy, ValueType OpTy, Intrinsic IntOp>
|
||||
: N3VLane32<op24, 1, op21_20, op11_8, 1, 0,
|
||||
(outs QPR:$Vd),
|
||||
(ins QPR:$src1, DPR:$Vn, DPR_VFP2:$Vm, nohash_imm:$lane),
|
||||
(ins QPR:$src1, DPR:$Vn, DPR_VFP2:$Vm, VectorIndex32:$lane),
|
||||
NVMulSLFrm, itin,
|
||||
OpcodeStr, Dt, "$Vd, $Vn, $Vm[$lane]", "$src1 = $Vd",
|
||||
OpcodeStr, Dt, "$Vd, $Vn, $Vm$lane", "$src1 = $Vd",
|
||||
[(set (ResTy QPR:$Vd),
|
||||
(ResTy (IntOp (ResTy QPR:$src1),
|
||||
(OpTy DPR:$Vn),
|
||||
@ -2299,8 +2299,8 @@ class N3VLSL<bit op24, bits<2> op21_20, bits<4> op11_8,
|
||||
InstrItinClass itin, string OpcodeStr, string Dt,
|
||||
ValueType TyQ, ValueType TyD, SDNode OpNode>
|
||||
: N3VLane32<op24, 1, op21_20, op11_8, 1, 0,
|
||||
(outs QPR:$Vd), (ins DPR:$Vn, DPR_VFP2:$Vm, nohash_imm:$lane),
|
||||
NVMulSLFrm, itin, OpcodeStr, Dt, "$Vd, $Vn, $Vm[$lane]", "",
|
||||
(outs QPR:$Vd), (ins DPR:$Vn, DPR_VFP2:$Vm, VectorIndex32:$lane),
|
||||
NVMulSLFrm, itin, OpcodeStr, Dt, "$Vd, $Vn, $Vm$lane", "",
|
||||
[(set QPR:$Vd,
|
||||
(TyQ (OpNode (TyD DPR:$Vn),
|
||||
(TyD (NEONvduplane (TyD DPR_VFP2:$Vm),imm:$lane)))))]>;
|
||||
@ -2308,8 +2308,8 @@ class N3VLSL16<bit op24, bits<2> op21_20, bits<4> op11_8,
|
||||
InstrItinClass itin, string OpcodeStr, string Dt,
|
||||
ValueType TyQ, ValueType TyD, SDNode OpNode>
|
||||
: N3VLane16<op24, 1, op21_20, op11_8, 1, 0,
|
||||
(outs QPR:$Vd), (ins DPR:$Vn, DPR_8:$Vm, nohash_imm:$lane),
|
||||
NVMulSLFrm, itin, OpcodeStr, Dt, "$Vd, $Vn, $Vm[$lane]", "",
|
||||
(outs QPR:$Vd), (ins DPR:$Vn, DPR_8:$Vm, VectorIndex16:$lane),
|
||||
NVMulSLFrm, itin, OpcodeStr, Dt, "$Vd, $Vn, $Vm$lane", "",
|
||||
[(set QPR:$Vd,
|
||||
(TyQ (OpNode (TyD DPR:$Vn),
|
||||
(TyD (NEONvduplane (TyD DPR_8:$Vm), imm:$lane)))))]>;
|
||||
@ -2354,8 +2354,8 @@ class N3VLIntSL<bit op24, bits<2> op21_20, bits<4> op11_8, InstrItinClass itin,
|
||||
string OpcodeStr, string Dt,
|
||||
ValueType ResTy, ValueType OpTy, Intrinsic IntOp>
|
||||
: N3VLane32<op24, 1, op21_20, op11_8, 1, 0,
|
||||
(outs QPR:$Vd), (ins DPR:$Vn, DPR_VFP2:$Vm, nohash_imm:$lane),
|
||||
NVMulSLFrm, itin, OpcodeStr, Dt, "$Vd, $Vn, $Vm[$lane]", "",
|
||||
(outs QPR:$Vd), (ins DPR:$Vn, DPR_VFP2:$Vm, VectorIndex32:$lane),
|
||||
NVMulSLFrm, itin, OpcodeStr, Dt, "$Vd, $Vn, $Vm$lane", "",
|
||||
[(set (ResTy QPR:$Vd),
|
||||
(ResTy (IntOp (OpTy DPR:$Vn),
|
||||
(OpTy (NEONvduplane (OpTy DPR_VFP2:$Vm),
|
||||
@ -2364,8 +2364,8 @@ class N3VLIntSL16<bit op24, bits<2> op21_20, bits<4> op11_8,
|
||||
InstrItinClass itin, string OpcodeStr, string Dt,
|
||||
ValueType ResTy, ValueType OpTy, Intrinsic IntOp>
|
||||
: N3VLane16<op24, 1, op21_20, op11_8, 1, 0,
|
||||
(outs QPR:$Vd), (ins DPR:$Vn, DPR_8:$Vm, nohash_imm:$lane),
|
||||
NVMulSLFrm, itin, OpcodeStr, Dt, "$Vd, $Vn, $Vm[$lane]", "",
|
||||
(outs QPR:$Vd), (ins DPR:$Vn, DPR_8:$Vm, VectorIndex16:$lane),
|
||||
NVMulSLFrm, itin, OpcodeStr, Dt, "$Vd, $Vn, $Vm$lane", "",
|
||||
[(set (ResTy QPR:$Vd),
|
||||
(ResTy (IntOp (OpTy DPR:$Vn),
|
||||
(OpTy (NEONvduplane (OpTy DPR_8:$Vm),
|
||||
|
Loading…
x
Reference in New Issue
Block a user