xref: /freebsd/contrib/llvm-project/llvm/lib/Target/LoongArch/LoongArchLSXInstrInfo.td (revision 357378bbdedf24ce2b90e9bd831af4a9db3ec70a)
1//===- LoongArchLSXInstrInfo.td - LoongArch LSX instructions -*- tablegen -*-=//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8//
9// This file describes the SIMD extension instructions.
10//
11//===----------------------------------------------------------------------===//
12
13def SDT_LoongArchVreplve : SDTypeProfile<1, 2, [SDTCisInt<0>, SDTCisVec<0>,
14                                         SDTCisInt<1>, SDTCisVec<1>,
15                                         SDTCisSameAs<0, 1>, SDTCisInt<2>]>;
16def SDT_LoongArchVecCond : SDTypeProfile<1, 1, [SDTCisInt<0>, SDTCisVec<1>]>;
17
18// Target nodes.
19def loongarch_vreplve : SDNode<"LoongArchISD::VREPLVE", SDT_LoongArchVreplve>;
20def loongarch_vall_nonzero : SDNode<"LoongArchISD::VALL_NONZERO",
21                                    SDT_LoongArchVecCond>;
22def loongarch_vany_nonzero : SDNode<"LoongArchISD::VANY_NONZERO",
23                                    SDT_LoongArchVecCond>;
24def loongarch_vall_zero : SDNode<"LoongArchISD::VALL_ZERO",
25                                SDT_LoongArchVecCond>;
26def loongarch_vany_zero : SDNode<"LoongArchISD::VANY_ZERO",
27                                SDT_LoongArchVecCond>;
28
29def loongarch_vpick_sext_elt : SDNode<"LoongArchISD::VPICK_SEXT_ELT",
30                                      SDTypeProfile<1, 3, [SDTCisPtrTy<2>]>>;
31def loongarch_vpick_zext_elt : SDNode<"LoongArchISD::VPICK_ZEXT_ELT",
32                                      SDTypeProfile<1, 3, [SDTCisPtrTy<2>]>>;
33
34class VecCond<SDPatternOperator OpNode, ValueType TyNode,
35              RegisterClass RC = LSX128>
36    : Pseudo<(outs GPR:$rd), (ins RC:$vj),
37             [(set GPR:$rd, (OpNode (TyNode RC:$vj)))]> {
38  let hasSideEffects = 0;
39  let mayLoad = 0;
40  let mayStore = 0;
41  let usesCustomInserter = 1;
42}
43
44def vsplat_imm_eq_1 : PatFrags<(ops), [(build_vector),
45                                       (bitconvert (v4i32 (build_vector)))], [{
46  APInt Imm;
47  EVT EltTy = N->getValueType(0).getVectorElementType();
48
49  if (N->getOpcode() == ISD::BITCAST)
50    N = N->getOperand(0).getNode();
51
52  return selectVSplat(N, Imm, EltTy.getSizeInBits()) &&
53         Imm.getBitWidth() == EltTy.getSizeInBits() && Imm == 1;
54}]>;
55
56def vsplati8_imm_eq_7 : PatFrags<(ops), [(build_vector)], [{
57  APInt Imm;
58  EVT EltTy = N->getValueType(0).getVectorElementType();
59
60  if (N->getOpcode() == ISD::BITCAST)
61    N = N->getOperand(0).getNode();
62
63  return selectVSplat(N, Imm, EltTy.getSizeInBits()) &&
64         Imm.getBitWidth() == EltTy.getSizeInBits() && Imm == 7;
65}]>;
66def vsplati16_imm_eq_15 : PatFrags<(ops), [(build_vector)], [{
67  APInt Imm;
68  EVT EltTy = N->getValueType(0).getVectorElementType();
69
70  if (N->getOpcode() == ISD::BITCAST)
71    N = N->getOperand(0).getNode();
72
73  return selectVSplat(N, Imm, EltTy.getSizeInBits()) &&
74         Imm.getBitWidth() == EltTy.getSizeInBits() && Imm == 15;
75}]>;
76def vsplati32_imm_eq_31 : PatFrags<(ops), [(build_vector)], [{
77  APInt Imm;
78  EVT EltTy = N->getValueType(0).getVectorElementType();
79
80  if (N->getOpcode() == ISD::BITCAST)
81    N = N->getOperand(0).getNode();
82
83  return selectVSplat(N, Imm, EltTy.getSizeInBits()) &&
84         Imm.getBitWidth() == EltTy.getSizeInBits() && Imm == 31;
85}]>;
86def vsplati64_imm_eq_63 : PatFrags<(ops), [(build_vector),
87                                           (bitconvert (v4i32 (build_vector)))], [{
88  APInt Imm;
89  EVT EltTy = N->getValueType(0).getVectorElementType();
90
91  if (N->getOpcode() == ISD::BITCAST)
92    N = N->getOperand(0).getNode();
93
94  return selectVSplat(N, Imm, EltTy.getSizeInBits()) &&
95         Imm.getBitWidth() == EltTy.getSizeInBits() && Imm == 63;
96}]>;
97
98def vsplatf32_fpimm_eq_1
99  : PatFrags<(ops), [(bitconvert (v4i32 (build_vector))),
100                     (bitconvert (v8i32 (build_vector)))], [{
101  APInt Imm;
102  EVT EltTy = N->getValueType(0).getVectorElementType();
103  N = N->getOperand(0).getNode();
104
105  return selectVSplat(N, Imm, EltTy.getSizeInBits()) &&
106         Imm.getBitWidth() == EltTy.getSizeInBits() &&
107         Imm == APFloat(+1.0f).bitcastToAPInt();
108}]>;
109def vsplatf64_fpimm_eq_1
110  : PatFrags<(ops), [(bitconvert (v2i64 (build_vector))),
111                     (bitconvert (v4i64 (build_vector)))], [{
112  APInt Imm;
113  EVT EltTy = N->getValueType(0).getVectorElementType();
114  N = N->getOperand(0).getNode();
115
116  return selectVSplat(N, Imm, EltTy.getSizeInBits()) &&
117         Imm.getBitWidth() == EltTy.getSizeInBits() &&
118         Imm == APFloat(+1.0).bitcastToAPInt();
119}]>;
120
121def vsplati8imm7   : PatFrag<(ops node:$reg),
122                             (and node:$reg, vsplati8_imm_eq_7)>;
123def vsplati16imm15 : PatFrag<(ops node:$reg),
124                             (and node:$reg, vsplati16_imm_eq_15)>;
125def vsplati32imm31 : PatFrag<(ops node:$reg),
126                             (and node:$reg, vsplati32_imm_eq_31)>;
127def vsplati64imm63 : PatFrag<(ops node:$reg),
128                             (and node:$reg, vsplati64_imm_eq_63)>;
129
130foreach N = [3, 4, 5, 6, 8] in
131  def SplatPat_uimm#N : ComplexPattern<vAny, 1, "selectVSplatImm<"#N#">",
132                                       [build_vector, bitconvert], [], 2>;
133
134foreach N = [5] in
135  def SplatPat_simm#N : ComplexPattern<vAny, 1, "selectVSplatImm<"#N#", true>",
136                                       [build_vector, bitconvert]>;
137
138def vsplat_uimm_inv_pow2 : ComplexPattern<vAny, 1, "selectVSplatUimmInvPow2",
139                                          [build_vector, bitconvert]>;
140
141def vsplat_uimm_pow2 : ComplexPattern<vAny, 1, "selectVSplatUimmPow2",
142                                      [build_vector, bitconvert]>;
143
144def muladd : PatFrag<(ops node:$vd, node:$vj, node:$vk),
145                     (add node:$vd, (mul node:$vj, node:$vk))>;
146
147def mulsub : PatFrag<(ops node:$vd, node:$vj, node:$vk),
148                     (sub node:$vd, (mul node:$vj, node:$vk))>;
149
150def lsxsplati8  : PatFrag<(ops node:$e0),
151                          (v16i8 (build_vector node:$e0, node:$e0,
152                                               node:$e0, node:$e0,
153                                               node:$e0, node:$e0,
154                                               node:$e0, node:$e0,
155                                               node:$e0, node:$e0,
156                                               node:$e0, node:$e0,
157                                               node:$e0, node:$e0,
158                                               node:$e0, node:$e0))>;
159def lsxsplati16 : PatFrag<(ops node:$e0),
160                          (v8i16 (build_vector node:$e0, node:$e0,
161                                               node:$e0, node:$e0,
162                                               node:$e0, node:$e0,
163                                               node:$e0, node:$e0))>;
164def lsxsplati32 : PatFrag<(ops node:$e0),
165                          (v4i32 (build_vector node:$e0, node:$e0,
166                                               node:$e0, node:$e0))>;
167def lsxsplati64 : PatFrag<(ops node:$e0),
168                          (v2i64 (build_vector node:$e0, node:$e0))>;
169def lsxsplatf32 : PatFrag<(ops node:$e0),
170                          (v4f32 (build_vector node:$e0, node:$e0,
171                                               node:$e0, node:$e0))>;
172def lsxsplatf64 : PatFrag<(ops node:$e0),
173                          (v2f64 (build_vector node:$e0, node:$e0))>;
174
175def to_valid_timm : SDNodeXForm<timm, [{
176  auto CN = cast<ConstantSDNode>(N);
177  return CurDAG->getTargetConstant(CN->getSExtValue(), SDLoc(N), Subtarget->getGRLenVT());
178}]>;
179
180//===----------------------------------------------------------------------===//
181// Instruction class templates
182//===----------------------------------------------------------------------===//
183
184class LSX1RI13_VI<bits<32> op, Operand ImmOpnd = simm13>
185    : Fmt1RI13_VI<op, (outs LSX128:$vd), (ins ImmOpnd:$imm13), "$vd, $imm13">;
186
187class LSX2R_VV<bits<32> op>
188    : Fmt2R_VV<op, (outs LSX128:$vd), (ins LSX128:$vj), "$vd, $vj">;
189
190class LSX2R_VR<bits<32> op>
191    : Fmt2R_VR<op, (outs LSX128:$vd), (ins GPR:$rj), "$vd, $rj">;
192
193class LSX2R_CV<bits<32> op>
194    : Fmt2R_CV<op, (outs CFR:$cd), (ins LSX128:$vj), "$cd, $vj">;
195
196class LSX2RI1_VVI<bits<32> op, Operand ImmOpnd = uimm1>
197    : Fmt2RI1_VVI<op, (outs LSX128:$vd), (ins LSX128:$vj, ImmOpnd:$imm1),
198                  "$vd, $vj, $imm1">;
199
200class LSX2RI1_RVI<bits<32> op, Operand ImmOpnd = uimm1>
201    : Fmt2RI1_RVI<op, (outs GPR:$rd), (ins LSX128:$vj, ImmOpnd:$imm1),
202                  "$rd, $vj, $imm1">;
203
204class LSX2RI2_VVI<bits<32> op, Operand ImmOpnd = uimm2>
205    : Fmt2RI2_VVI<op, (outs LSX128:$vd), (ins LSX128:$vj, ImmOpnd:$imm2),
206                  "$vd, $vj, $imm2">;
207
208class LSX2RI2_RVI<bits<32> op, Operand ImmOpnd = uimm2>
209    : Fmt2RI2_RVI<op, (outs GPR:$rd), (ins LSX128:$vj, ImmOpnd:$imm2),
210                  "$rd, $vj, $imm2">;
211
212class LSX2RI3_VVI<bits<32> op, Operand ImmOpnd = uimm3>
213    : Fmt2RI3_VVI<op, (outs LSX128:$vd), (ins LSX128:$vj, ImmOpnd:$imm3),
214                  "$vd, $vj, $imm3">;
215
216class LSX2RI3_RVI<bits<32> op, Operand ImmOpnd = uimm3>
217    : Fmt2RI3_RVI<op, (outs GPR:$rd), (ins LSX128:$vj, ImmOpnd:$imm3),
218                  "$rd, $vj, $imm3">;
219
220class LSX2RI4_VVI<bits<32> op, Operand ImmOpnd = uimm4>
221    : Fmt2RI4_VVI<op, (outs LSX128:$vd), (ins LSX128:$vj, ImmOpnd:$imm4),
222                  "$vd, $vj, $imm4">;
223
224class LSX2RI4_RVI<bits<32> op, Operand ImmOpnd = uimm4>
225    : Fmt2RI4_RVI<op, (outs GPR:$rd), (ins LSX128:$vj, ImmOpnd:$imm4),
226                  "$rd, $vj, $imm4">;
227
228class LSX2RI5_VVI<bits<32> op, Operand ImmOpnd = uimm5>
229    : Fmt2RI5_VVI<op, (outs LSX128:$vd), (ins LSX128:$vj, ImmOpnd:$imm5),
230                  "$vd, $vj, $imm5">;
231
232class LSX2RI6_VVI<bits<32> op, Operand ImmOpnd = uimm6>
233    : Fmt2RI6_VVI<op, (outs LSX128:$vd), (ins LSX128:$vj, ImmOpnd:$imm6),
234                  "$vd, $vj, $imm6">;
235
236class LSX2RI8_VVI<bits<32> op, Operand ImmOpnd = uimm8>
237    : Fmt2RI8_VVI<op, (outs LSX128:$vd), (ins LSX128:$vj, ImmOpnd:$imm8),
238                  "$vd, $vj, $imm8">;
239
240class LSX2RI8I1_VRII<bits<32> op, Operand ImmOpnd = simm8,
241                     Operand IdxOpnd = uimm1>
242    : Fmt2RI8I1_VRII<op, (outs),
243                     (ins LSX128:$vd, GPR:$rj, ImmOpnd:$imm8, IdxOpnd:$imm1),
244                     "$vd, $rj, $imm8, $imm1">;
245class LSX2RI8I2_VRII<bits<32> op, Operand ImmOpnd = simm8,
246                     Operand IdxOpnd = uimm2>
247    : Fmt2RI8I2_VRII<op, (outs),
248                     (ins LSX128:$vd, GPR:$rj, ImmOpnd:$imm8, IdxOpnd:$imm2),
249                     "$vd, $rj, $imm8, $imm2">;
250class LSX2RI8I3_VRII<bits<32> op, Operand ImmOpnd = simm8,
251                     Operand IdxOpnd = uimm3>
252    : Fmt2RI8I3_VRII<op, (outs),
253                     (ins LSX128:$vd, GPR:$rj, ImmOpnd:$imm8, IdxOpnd:$imm3),
254                     "$vd, $rj, $imm8, $imm3">;
255class LSX2RI8I4_VRII<bits<32> op, Operand ImmOpnd = simm8,
256                     Operand IdxOpnd = uimm4>
257    : Fmt2RI8I4_VRII<op, (outs),
258                     (ins LSX128:$vd, GPR:$rj, ImmOpnd:$imm8, IdxOpnd:$imm4),
259                     "$vd, $rj, $imm8, $imm4">;
260
261class LSX3R_VVV<bits<32> op>
262    : Fmt3R_VVV<op, (outs LSX128:$vd), (ins LSX128:$vj, LSX128:$vk),
263                "$vd, $vj, $vk">;
264
265class LSX3R_VVR<bits<32> op>
266    : Fmt3R_VVR<op, (outs LSX128:$vd), (ins LSX128:$vj, GPR:$rk),
267                "$vd, $vj, $rk">;
268
269class LSX4R_VVVV<bits<32> op>
270    : Fmt4R_VVVV<op, (outs LSX128:$vd),
271                 (ins LSX128:$vj, LSX128:$vk, LSX128:$va),
272                 "$vd, $vj, $vk, $va">;
273
274let Constraints = "$vd = $dst" in {
275
276class LSX2RI1_VVRI<bits<32> op, Operand ImmOpnd = uimm1>
277    : Fmt2RI1_VRI<op, (outs LSX128:$dst), (ins LSX128:$vd, GPR:$rj, ImmOpnd:$imm1),
278                  "$vd, $rj, $imm1">;
279class LSX2RI2_VVRI<bits<32> op, Operand ImmOpnd = uimm2>
280    : Fmt2RI2_VRI<op, (outs LSX128:$dst), (ins LSX128:$vd, GPR:$rj, ImmOpnd:$imm2),
281                  "$vd, $rj, $imm2">;
282class LSX2RI3_VVRI<bits<32> op, Operand ImmOpnd = uimm3>
283    : Fmt2RI3_VRI<op, (outs LSX128:$dst), (ins LSX128:$vd, GPR:$rj, ImmOpnd:$imm3),
284                  "$vd, $rj, $imm3">;
285class LSX2RI4_VVRI<bits<32> op, Operand ImmOpnd = uimm4>
286    : Fmt2RI4_VRI<op, (outs LSX128:$dst), (ins LSX128:$vd, GPR:$rj, ImmOpnd:$imm4),
287                  "$vd, $rj, $imm4">;
288
289class LSX2RI4_VVVI<bits<32> op, Operand ImmOpnd = uimm4>
290    : Fmt2RI4_VVI<op, (outs LSX128:$dst), (ins LSX128:$vd, LSX128:$vj, ImmOpnd:$imm4),
291                  "$vd, $vj, $imm4">;
292class LSX2RI5_VVVI<bits<32> op, Operand ImmOpnd = uimm5>
293    : Fmt2RI5_VVI<op, (outs LSX128:$dst), (ins LSX128:$vd, LSX128:$vj, ImmOpnd:$imm5),
294                  "$vd, $vj, $imm5">;
295class LSX2RI6_VVVI<bits<32> op, Operand ImmOpnd = uimm6>
296    : Fmt2RI6_VVI<op, (outs LSX128:$dst), (ins LSX128:$vd, LSX128:$vj, ImmOpnd:$imm6),
297                  "$vd, $vj, $imm6">;
298class LSX2RI7_VVVI<bits<32> op, Operand ImmOpnd = uimm7>
299    : Fmt2RI7_VVI<op, (outs LSX128:$dst), (ins LSX128:$vd, LSX128:$vj, ImmOpnd:$imm7),
300                  "$vd, $vj, $imm7">;
301
302class LSX2RI8_VVVI<bits<32> op, Operand ImmOpnd = uimm8>
303    : Fmt2RI8_VVI<op, (outs LSX128:$dst), (ins LSX128:$vd, LSX128:$vj, ImmOpnd:$imm8),
304                  "$vd, $vj, $imm8">;
305
306class LSX3R_VVVV<bits<32> op>
307    : Fmt3R_VVV<op, (outs LSX128:$dst), (ins LSX128:$vd, LSX128:$vj, LSX128:$vk),
308                "$vd, $vj, $vk">;
309
310} // Constraints = "$vd = $dst"
311
312class LSX2RI9_Load<bits<32> op, Operand ImmOpnd = simm9_lsl3>
313    : Fmt2RI9_VRI<op, (outs LSX128:$vd), (ins GPR:$rj, ImmOpnd:$imm9),
314                  "$vd, $rj, $imm9">;
315class LSX2RI10_Load<bits<32> op, Operand ImmOpnd = simm10_lsl2>
316    : Fmt2RI10_VRI<op, (outs LSX128:$vd), (ins GPR:$rj, ImmOpnd:$imm10),
317                  "$vd, $rj, $imm10">;
318class LSX2RI11_Load<bits<32> op, Operand ImmOpnd = simm11_lsl1>
319    : Fmt2RI11_VRI<op, (outs LSX128:$vd), (ins GPR:$rj, ImmOpnd:$imm11),
320                  "$vd, $rj, $imm11">;
321class LSX2RI12_Load<bits<32> op, Operand ImmOpnd = simm12>
322    : Fmt2RI12_VRI<op, (outs LSX128:$vd), (ins GPR:$rj, ImmOpnd:$imm12),
323                  "$vd, $rj, $imm12">;
324class LSX2RI12_Store<bits<32> op, Operand ImmOpnd = simm12>
325    : Fmt2RI12_VRI<op, (outs), (ins LSX128:$vd, GPR:$rj, ImmOpnd:$imm12),
326                  "$vd, $rj, $imm12">;
327
328class LSX3R_Load<bits<32> op>
329    : Fmt3R_VRR<op, (outs LSX128:$vd), (ins GPR:$rj, GPR:$rk),
330                "$vd, $rj, $rk">;
331class LSX3R_Store<bits<32> op>
332    : Fmt3R_VRR<op, (outs), (ins LSX128:$vd, GPR:$rj, GPR:$rk),
333                "$vd, $rj, $rk">;
334
335//===----------------------------------------------------------------------===//
336// Instructions
337//===----------------------------------------------------------------------===//
338
339let hasSideEffects = 0, Predicates = [HasExtLSX] in {
340
341let mayLoad = 0, mayStore = 0 in {
342
343def VADD_B : LSX3R_VVV<0x700a0000>;
344def VADD_H : LSX3R_VVV<0x700a8000>;
345def VADD_W : LSX3R_VVV<0x700b0000>;
346def VADD_D : LSX3R_VVV<0x700b8000>;
347def VADD_Q : LSX3R_VVV<0x712d0000>;
348
349def VSUB_B : LSX3R_VVV<0x700c0000>;
350def VSUB_H : LSX3R_VVV<0x700c8000>;
351def VSUB_W : LSX3R_VVV<0x700d0000>;
352def VSUB_D : LSX3R_VVV<0x700d8000>;
353def VSUB_Q : LSX3R_VVV<0x712d8000>;
354
355def VADDI_BU : LSX2RI5_VVI<0x728a0000>;
356def VADDI_HU : LSX2RI5_VVI<0x728a8000>;
357def VADDI_WU : LSX2RI5_VVI<0x728b0000>;
358def VADDI_DU : LSX2RI5_VVI<0x728b8000>;
359
360def VSUBI_BU : LSX2RI5_VVI<0x728c0000>;
361def VSUBI_HU : LSX2RI5_VVI<0x728c8000>;
362def VSUBI_WU : LSX2RI5_VVI<0x728d0000>;
363def VSUBI_DU : LSX2RI5_VVI<0x728d8000>;
364
365def VNEG_B : LSX2R_VV<0x729c3000>;
366def VNEG_H : LSX2R_VV<0x729c3400>;
367def VNEG_W : LSX2R_VV<0x729c3800>;
368def VNEG_D : LSX2R_VV<0x729c3c00>;
369
370def VSADD_B : LSX3R_VVV<0x70460000>;
371def VSADD_H : LSX3R_VVV<0x70468000>;
372def VSADD_W : LSX3R_VVV<0x70470000>;
373def VSADD_D : LSX3R_VVV<0x70478000>;
374def VSADD_BU : LSX3R_VVV<0x704a0000>;
375def VSADD_HU : LSX3R_VVV<0x704a8000>;
376def VSADD_WU : LSX3R_VVV<0x704b0000>;
377def VSADD_DU : LSX3R_VVV<0x704b8000>;
378
379def VSSUB_B : LSX3R_VVV<0x70480000>;
380def VSSUB_H : LSX3R_VVV<0x70488000>;
381def VSSUB_W : LSX3R_VVV<0x70490000>;
382def VSSUB_D : LSX3R_VVV<0x70498000>;
383def VSSUB_BU : LSX3R_VVV<0x704c0000>;
384def VSSUB_HU : LSX3R_VVV<0x704c8000>;
385def VSSUB_WU : LSX3R_VVV<0x704d0000>;
386def VSSUB_DU : LSX3R_VVV<0x704d8000>;
387
388def VHADDW_H_B : LSX3R_VVV<0x70540000>;
389def VHADDW_W_H : LSX3R_VVV<0x70548000>;
390def VHADDW_D_W : LSX3R_VVV<0x70550000>;
391def VHADDW_Q_D : LSX3R_VVV<0x70558000>;
392def VHADDW_HU_BU : LSX3R_VVV<0x70580000>;
393def VHADDW_WU_HU : LSX3R_VVV<0x70588000>;
394def VHADDW_DU_WU : LSX3R_VVV<0x70590000>;
395def VHADDW_QU_DU : LSX3R_VVV<0x70598000>;
396
397def VHSUBW_H_B : LSX3R_VVV<0x70560000>;
398def VHSUBW_W_H : LSX3R_VVV<0x70568000>;
399def VHSUBW_D_W : LSX3R_VVV<0x70570000>;
400def VHSUBW_Q_D : LSX3R_VVV<0x70578000>;
401def VHSUBW_HU_BU : LSX3R_VVV<0x705a0000>;
402def VHSUBW_WU_HU : LSX3R_VVV<0x705a8000>;
403def VHSUBW_DU_WU : LSX3R_VVV<0x705b0000>;
404def VHSUBW_QU_DU : LSX3R_VVV<0x705b8000>;
405
406def VADDWEV_H_B : LSX3R_VVV<0x701e0000>;
407def VADDWEV_W_H : LSX3R_VVV<0x701e8000>;
408def VADDWEV_D_W : LSX3R_VVV<0x701f0000>;
409def VADDWEV_Q_D : LSX3R_VVV<0x701f8000>;
410def VADDWOD_H_B : LSX3R_VVV<0x70220000>;
411def VADDWOD_W_H : LSX3R_VVV<0x70228000>;
412def VADDWOD_D_W : LSX3R_VVV<0x70230000>;
413def VADDWOD_Q_D : LSX3R_VVV<0x70238000>;
414
415def VSUBWEV_H_B : LSX3R_VVV<0x70200000>;
416def VSUBWEV_W_H : LSX3R_VVV<0x70208000>;
417def VSUBWEV_D_W : LSX3R_VVV<0x70210000>;
418def VSUBWEV_Q_D : LSX3R_VVV<0x70218000>;
419def VSUBWOD_H_B : LSX3R_VVV<0x70240000>;
420def VSUBWOD_W_H : LSX3R_VVV<0x70248000>;
421def VSUBWOD_D_W : LSX3R_VVV<0x70250000>;
422def VSUBWOD_Q_D : LSX3R_VVV<0x70258000>;
423
424def VADDWEV_H_BU : LSX3R_VVV<0x702e0000>;
425def VADDWEV_W_HU : LSX3R_VVV<0x702e8000>;
426def VADDWEV_D_WU : LSX3R_VVV<0x702f0000>;
427def VADDWEV_Q_DU : LSX3R_VVV<0x702f8000>;
428def VADDWOD_H_BU : LSX3R_VVV<0x70320000>;
429def VADDWOD_W_HU : LSX3R_VVV<0x70328000>;
430def VADDWOD_D_WU : LSX3R_VVV<0x70330000>;
431def VADDWOD_Q_DU : LSX3R_VVV<0x70338000>;
432
433def VSUBWEV_H_BU : LSX3R_VVV<0x70300000>;
434def VSUBWEV_W_HU : LSX3R_VVV<0x70308000>;
435def VSUBWEV_D_WU : LSX3R_VVV<0x70310000>;
436def VSUBWEV_Q_DU : LSX3R_VVV<0x70318000>;
437def VSUBWOD_H_BU : LSX3R_VVV<0x70340000>;
438def VSUBWOD_W_HU : LSX3R_VVV<0x70348000>;
439def VSUBWOD_D_WU : LSX3R_VVV<0x70350000>;
440def VSUBWOD_Q_DU : LSX3R_VVV<0x70358000>;
441
442def VADDWEV_H_BU_B : LSX3R_VVV<0x703e0000>;
443def VADDWEV_W_HU_H : LSX3R_VVV<0x703e8000>;
444def VADDWEV_D_WU_W : LSX3R_VVV<0x703f0000>;
445def VADDWEV_Q_DU_D : LSX3R_VVV<0x703f8000>;
446def VADDWOD_H_BU_B : LSX3R_VVV<0x70400000>;
447def VADDWOD_W_HU_H : LSX3R_VVV<0x70408000>;
448def VADDWOD_D_WU_W : LSX3R_VVV<0x70410000>;
449def VADDWOD_Q_DU_D : LSX3R_VVV<0x70418000>;
450
451def VAVG_B : LSX3R_VVV<0x70640000>;
452def VAVG_H : LSX3R_VVV<0x70648000>;
453def VAVG_W : LSX3R_VVV<0x70650000>;
454def VAVG_D : LSX3R_VVV<0x70658000>;
455def VAVG_BU : LSX3R_VVV<0x70660000>;
456def VAVG_HU : LSX3R_VVV<0x70668000>;
457def VAVG_WU : LSX3R_VVV<0x70670000>;
458def VAVG_DU : LSX3R_VVV<0x70678000>;
459def VAVGR_B : LSX3R_VVV<0x70680000>;
460def VAVGR_H : LSX3R_VVV<0x70688000>;
461def VAVGR_W : LSX3R_VVV<0x70690000>;
462def VAVGR_D : LSX3R_VVV<0x70698000>;
463def VAVGR_BU : LSX3R_VVV<0x706a0000>;
464def VAVGR_HU : LSX3R_VVV<0x706a8000>;
465def VAVGR_WU : LSX3R_VVV<0x706b0000>;
466def VAVGR_DU : LSX3R_VVV<0x706b8000>;
467
468def VABSD_B : LSX3R_VVV<0x70600000>;
469def VABSD_H : LSX3R_VVV<0x70608000>;
470def VABSD_W : LSX3R_VVV<0x70610000>;
471def VABSD_D : LSX3R_VVV<0x70618000>;
472def VABSD_BU : LSX3R_VVV<0x70620000>;
473def VABSD_HU : LSX3R_VVV<0x70628000>;
474def VABSD_WU : LSX3R_VVV<0x70630000>;
475def VABSD_DU : LSX3R_VVV<0x70638000>;
476
477def VADDA_B : LSX3R_VVV<0x705c0000>;
478def VADDA_H : LSX3R_VVV<0x705c8000>;
479def VADDA_W : LSX3R_VVV<0x705d0000>;
480def VADDA_D : LSX3R_VVV<0x705d8000>;
481
482def VMAX_B : LSX3R_VVV<0x70700000>;
483def VMAX_H : LSX3R_VVV<0x70708000>;
484def VMAX_W : LSX3R_VVV<0x70710000>;
485def VMAX_D : LSX3R_VVV<0x70718000>;
486def VMAXI_B : LSX2RI5_VVI<0x72900000, simm5>;
487def VMAXI_H : LSX2RI5_VVI<0x72908000, simm5>;
488def VMAXI_W : LSX2RI5_VVI<0x72910000, simm5>;
489def VMAXI_D : LSX2RI5_VVI<0x72918000, simm5>;
490def VMAX_BU : LSX3R_VVV<0x70740000>;
491def VMAX_HU : LSX3R_VVV<0x70748000>;
492def VMAX_WU : LSX3R_VVV<0x70750000>;
493def VMAX_DU : LSX3R_VVV<0x70758000>;
494def VMAXI_BU : LSX2RI5_VVI<0x72940000>;
495def VMAXI_HU : LSX2RI5_VVI<0x72948000>;
496def VMAXI_WU : LSX2RI5_VVI<0x72950000>;
497def VMAXI_DU : LSX2RI5_VVI<0x72958000>;
498
499def VMIN_B : LSX3R_VVV<0x70720000>;
500def VMIN_H : LSX3R_VVV<0x70728000>;
501def VMIN_W : LSX3R_VVV<0x70730000>;
502def VMIN_D : LSX3R_VVV<0x70738000>;
503def VMINI_B : LSX2RI5_VVI<0x72920000, simm5>;
504def VMINI_H : LSX2RI5_VVI<0x72928000, simm5>;
505def VMINI_W : LSX2RI5_VVI<0x72930000, simm5>;
506def VMINI_D : LSX2RI5_VVI<0x72938000, simm5>;
507def VMIN_BU : LSX3R_VVV<0x70760000>;
508def VMIN_HU : LSX3R_VVV<0x70768000>;
509def VMIN_WU : LSX3R_VVV<0x70770000>;
510def VMIN_DU : LSX3R_VVV<0x70778000>;
511def VMINI_BU : LSX2RI5_VVI<0x72960000>;
512def VMINI_HU : LSX2RI5_VVI<0x72968000>;
513def VMINI_WU : LSX2RI5_VVI<0x72970000>;
514def VMINI_DU : LSX2RI5_VVI<0x72978000>;
515
516def VMUL_B : LSX3R_VVV<0x70840000>;
517def VMUL_H : LSX3R_VVV<0x70848000>;
518def VMUL_W : LSX3R_VVV<0x70850000>;
519def VMUL_D : LSX3R_VVV<0x70858000>;
520
521def VMUH_B : LSX3R_VVV<0x70860000>;
522def VMUH_H : LSX3R_VVV<0x70868000>;
523def VMUH_W : LSX3R_VVV<0x70870000>;
524def VMUH_D : LSX3R_VVV<0x70878000>;
525def VMUH_BU : LSX3R_VVV<0x70880000>;
526def VMUH_HU : LSX3R_VVV<0x70888000>;
527def VMUH_WU : LSX3R_VVV<0x70890000>;
528def VMUH_DU : LSX3R_VVV<0x70898000>;
529
530def VMULWEV_H_B : LSX3R_VVV<0x70900000>;
531def VMULWEV_W_H : LSX3R_VVV<0x70908000>;
532def VMULWEV_D_W : LSX3R_VVV<0x70910000>;
533def VMULWEV_Q_D : LSX3R_VVV<0x70918000>;
534def VMULWOD_H_B : LSX3R_VVV<0x70920000>;
535def VMULWOD_W_H : LSX3R_VVV<0x70928000>;
536def VMULWOD_D_W : LSX3R_VVV<0x70930000>;
537def VMULWOD_Q_D : LSX3R_VVV<0x70938000>;
538def VMULWEV_H_BU : LSX3R_VVV<0x70980000>;
539def VMULWEV_W_HU : LSX3R_VVV<0x70988000>;
540def VMULWEV_D_WU : LSX3R_VVV<0x70990000>;
541def VMULWEV_Q_DU : LSX3R_VVV<0x70998000>;
542def VMULWOD_H_BU : LSX3R_VVV<0x709a0000>;
543def VMULWOD_W_HU : LSX3R_VVV<0x709a8000>;
544def VMULWOD_D_WU : LSX3R_VVV<0x709b0000>;
545def VMULWOD_Q_DU : LSX3R_VVV<0x709b8000>;
546def VMULWEV_H_BU_B : LSX3R_VVV<0x70a00000>;
547def VMULWEV_W_HU_H : LSX3R_VVV<0x70a08000>;
548def VMULWEV_D_WU_W : LSX3R_VVV<0x70a10000>;
549def VMULWEV_Q_DU_D : LSX3R_VVV<0x70a18000>;
550def VMULWOD_H_BU_B : LSX3R_VVV<0x70a20000>;
551def VMULWOD_W_HU_H : LSX3R_VVV<0x70a28000>;
552def VMULWOD_D_WU_W : LSX3R_VVV<0x70a30000>;
553def VMULWOD_Q_DU_D : LSX3R_VVV<0x70a38000>;
554
555def VMADD_B : LSX3R_VVVV<0x70a80000>;
556def VMADD_H : LSX3R_VVVV<0x70a88000>;
557def VMADD_W : LSX3R_VVVV<0x70a90000>;
558def VMADD_D : LSX3R_VVVV<0x70a98000>;
559
560def VMSUB_B : LSX3R_VVVV<0x70aa0000>;
561def VMSUB_H : LSX3R_VVVV<0x70aa8000>;
562def VMSUB_W : LSX3R_VVVV<0x70ab0000>;
563def VMSUB_D : LSX3R_VVVV<0x70ab8000>;
564
565def VMADDWEV_H_B : LSX3R_VVVV<0x70ac0000>;
566def VMADDWEV_W_H : LSX3R_VVVV<0x70ac8000>;
567def VMADDWEV_D_W : LSX3R_VVVV<0x70ad0000>;
568def VMADDWEV_Q_D : LSX3R_VVVV<0x70ad8000>;
569def VMADDWOD_H_B : LSX3R_VVVV<0x70ae0000>;
570def VMADDWOD_W_H : LSX3R_VVVV<0x70ae8000>;
571def VMADDWOD_D_W : LSX3R_VVVV<0x70af0000>;
572def VMADDWOD_Q_D : LSX3R_VVVV<0x70af8000>;
573def VMADDWEV_H_BU : LSX3R_VVVV<0x70b40000>;
574def VMADDWEV_W_HU : LSX3R_VVVV<0x70b48000>;
575def VMADDWEV_D_WU : LSX3R_VVVV<0x70b50000>;
576def VMADDWEV_Q_DU : LSX3R_VVVV<0x70b58000>;
577def VMADDWOD_H_BU : LSX3R_VVVV<0x70b60000>;
578def VMADDWOD_W_HU : LSX3R_VVVV<0x70b68000>;
579def VMADDWOD_D_WU : LSX3R_VVVV<0x70b70000>;
580def VMADDWOD_Q_DU : LSX3R_VVVV<0x70b78000>;
581def VMADDWEV_H_BU_B : LSX3R_VVVV<0x70bc0000>;
582def VMADDWEV_W_HU_H : LSX3R_VVVV<0x70bc8000>;
583def VMADDWEV_D_WU_W : LSX3R_VVVV<0x70bd0000>;
584def VMADDWEV_Q_DU_D : LSX3R_VVVV<0x70bd8000>;
585def VMADDWOD_H_BU_B : LSX3R_VVVV<0x70be0000>;
586def VMADDWOD_W_HU_H : LSX3R_VVVV<0x70be8000>;
587def VMADDWOD_D_WU_W : LSX3R_VVVV<0x70bf0000>;
588def VMADDWOD_Q_DU_D : LSX3R_VVVV<0x70bf8000>;
589
590def VDIV_B : LSX3R_VVV<0x70e00000>;
591def VDIV_H : LSX3R_VVV<0x70e08000>;
592def VDIV_W : LSX3R_VVV<0x70e10000>;
593def VDIV_D : LSX3R_VVV<0x70e18000>;
594def VDIV_BU : LSX3R_VVV<0x70e40000>;
595def VDIV_HU : LSX3R_VVV<0x70e48000>;
596def VDIV_WU : LSX3R_VVV<0x70e50000>;
597def VDIV_DU : LSX3R_VVV<0x70e58000>;
598
599def VMOD_B : LSX3R_VVV<0x70e20000>;
600def VMOD_H : LSX3R_VVV<0x70e28000>;
601def VMOD_W : LSX3R_VVV<0x70e30000>;
602def VMOD_D : LSX3R_VVV<0x70e38000>;
603def VMOD_BU : LSX3R_VVV<0x70e60000>;
604def VMOD_HU : LSX3R_VVV<0x70e68000>;
605def VMOD_WU : LSX3R_VVV<0x70e70000>;
606def VMOD_DU : LSX3R_VVV<0x70e78000>;
607
608def VSAT_B : LSX2RI3_VVI<0x73242000>;
609def VSAT_H : LSX2RI4_VVI<0x73244000>;
610def VSAT_W : LSX2RI5_VVI<0x73248000>;
611def VSAT_D : LSX2RI6_VVI<0x73250000>;
612def VSAT_BU : LSX2RI3_VVI<0x73282000>;
613def VSAT_HU : LSX2RI4_VVI<0x73284000>;
614def VSAT_WU : LSX2RI5_VVI<0x73288000>;
615def VSAT_DU : LSX2RI6_VVI<0x73290000>;
616
617def VEXTH_H_B : LSX2R_VV<0x729ee000>;
618def VEXTH_W_H : LSX2R_VV<0x729ee400>;
619def VEXTH_D_W : LSX2R_VV<0x729ee800>;
620def VEXTH_Q_D : LSX2R_VV<0x729eec00>;
621def VEXTH_HU_BU : LSX2R_VV<0x729ef000>;
622def VEXTH_WU_HU : LSX2R_VV<0x729ef400>;
623def VEXTH_DU_WU : LSX2R_VV<0x729ef800>;
624def VEXTH_QU_DU : LSX2R_VV<0x729efc00>;
625
626def VSIGNCOV_B : LSX3R_VVV<0x712e0000>;
627def VSIGNCOV_H : LSX3R_VVV<0x712e8000>;
628def VSIGNCOV_W : LSX3R_VVV<0x712f0000>;
629def VSIGNCOV_D : LSX3R_VVV<0x712f8000>;
630
631def VMSKLTZ_B : LSX2R_VV<0x729c4000>;
632def VMSKLTZ_H : LSX2R_VV<0x729c4400>;
633def VMSKLTZ_W : LSX2R_VV<0x729c4800>;
634def VMSKLTZ_D : LSX2R_VV<0x729c4c00>;
635
636def VMSKGEZ_B : LSX2R_VV<0x729c5000>;
637
638def VMSKNZ_B : LSX2R_VV<0x729c6000>;
639
640def VLDI : LSX1RI13_VI<0x73e00000>;
641
642def VAND_V : LSX3R_VVV<0x71260000>;
643def VOR_V : LSX3R_VVV<0x71268000>;
644def VXOR_V : LSX3R_VVV<0x71270000>;
645def VNOR_V : LSX3R_VVV<0x71278000>;
646def VANDN_V : LSX3R_VVV<0x71280000>;
647def VORN_V : LSX3R_VVV<0x71288000>;
648
649def VANDI_B : LSX2RI8_VVI<0x73d00000>;
650def VORI_B : LSX2RI8_VVI<0x73d40000>;
651def VXORI_B : LSX2RI8_VVI<0x73d80000>;
652def VNORI_B : LSX2RI8_VVI<0x73dc0000>;
653
654def VSLL_B : LSX3R_VVV<0x70e80000>;
655def VSLL_H : LSX3R_VVV<0x70e88000>;
656def VSLL_W : LSX3R_VVV<0x70e90000>;
657def VSLL_D : LSX3R_VVV<0x70e98000>;
658def VSLLI_B : LSX2RI3_VVI<0x732c2000>;
659def VSLLI_H : LSX2RI4_VVI<0x732c4000>;
660def VSLLI_W : LSX2RI5_VVI<0x732c8000>;
661def VSLLI_D : LSX2RI6_VVI<0x732d0000>;
662
663def VSRL_B : LSX3R_VVV<0x70ea0000>;
664def VSRL_H : LSX3R_VVV<0x70ea8000>;
665def VSRL_W : LSX3R_VVV<0x70eb0000>;
666def VSRL_D : LSX3R_VVV<0x70eb8000>;
667def VSRLI_B : LSX2RI3_VVI<0x73302000>;
668def VSRLI_H : LSX2RI4_VVI<0x73304000>;
669def VSRLI_W : LSX2RI5_VVI<0x73308000>;
670def VSRLI_D : LSX2RI6_VVI<0x73310000>;
671
672def VSRA_B : LSX3R_VVV<0x70ec0000>;
673def VSRA_H : LSX3R_VVV<0x70ec8000>;
674def VSRA_W : LSX3R_VVV<0x70ed0000>;
675def VSRA_D : LSX3R_VVV<0x70ed8000>;
676def VSRAI_B : LSX2RI3_VVI<0x73342000>;
677def VSRAI_H : LSX2RI4_VVI<0x73344000>;
678def VSRAI_W : LSX2RI5_VVI<0x73348000>;
679def VSRAI_D : LSX2RI6_VVI<0x73350000>;
680
681def VROTR_B : LSX3R_VVV<0x70ee0000>;
682def VROTR_H : LSX3R_VVV<0x70ee8000>;
683def VROTR_W : LSX3R_VVV<0x70ef0000>;
684def VROTR_D : LSX3R_VVV<0x70ef8000>;
685def VROTRI_B : LSX2RI3_VVI<0x72a02000>;
686def VROTRI_H : LSX2RI4_VVI<0x72a04000>;
687def VROTRI_W : LSX2RI5_VVI<0x72a08000>;
688def VROTRI_D : LSX2RI6_VVI<0x72a10000>;
689
690def VSLLWIL_H_B : LSX2RI3_VVI<0x73082000>;
691def VSLLWIL_W_H : LSX2RI4_VVI<0x73084000>;
692def VSLLWIL_D_W : LSX2RI5_VVI<0x73088000>;
693def VEXTL_Q_D : LSX2R_VV<0x73090000>;
694def VSLLWIL_HU_BU : LSX2RI3_VVI<0x730c2000>;
695def VSLLWIL_WU_HU : LSX2RI4_VVI<0x730c4000>;
696def VSLLWIL_DU_WU : LSX2RI5_VVI<0x730c8000>;
697def VEXTL_QU_DU : LSX2R_VV<0x730d0000>;
698
699def VSRLR_B : LSX3R_VVV<0x70f00000>;
700def VSRLR_H : LSX3R_VVV<0x70f08000>;
701def VSRLR_W : LSX3R_VVV<0x70f10000>;
702def VSRLR_D : LSX3R_VVV<0x70f18000>;
703def VSRLRI_B : LSX2RI3_VVI<0x72a42000>;
704def VSRLRI_H : LSX2RI4_VVI<0x72a44000>;
705def VSRLRI_W : LSX2RI5_VVI<0x72a48000>;
706def VSRLRI_D : LSX2RI6_VVI<0x72a50000>;
707
708def VSRAR_B : LSX3R_VVV<0x70f20000>;
709def VSRAR_H : LSX3R_VVV<0x70f28000>;
710def VSRAR_W : LSX3R_VVV<0x70f30000>;
711def VSRAR_D : LSX3R_VVV<0x70f38000>;
712def VSRARI_B : LSX2RI3_VVI<0x72a82000>;
713def VSRARI_H : LSX2RI4_VVI<0x72a84000>;
714def VSRARI_W : LSX2RI5_VVI<0x72a88000>;
715def VSRARI_D : LSX2RI6_VVI<0x72a90000>;
716
717def VSRLN_B_H : LSX3R_VVV<0x70f48000>;
718def VSRLN_H_W : LSX3R_VVV<0x70f50000>;
719def VSRLN_W_D : LSX3R_VVV<0x70f58000>;
720def VSRAN_B_H : LSX3R_VVV<0x70f68000>;
721def VSRAN_H_W : LSX3R_VVV<0x70f70000>;
722def VSRAN_W_D : LSX3R_VVV<0x70f78000>;
723
724def VSRLNI_B_H : LSX2RI4_VVVI<0x73404000>;
725def VSRLNI_H_W : LSX2RI5_VVVI<0x73408000>;
726def VSRLNI_W_D : LSX2RI6_VVVI<0x73410000>;
727def VSRLNI_D_Q : LSX2RI7_VVVI<0x73420000>;
728def VSRANI_B_H : LSX2RI4_VVVI<0x73584000>;
729def VSRANI_H_W : LSX2RI5_VVVI<0x73588000>;
730def VSRANI_W_D : LSX2RI6_VVVI<0x73590000>;
731def VSRANI_D_Q : LSX2RI7_VVVI<0x735a0000>;
732
733def VSRLRN_B_H : LSX3R_VVV<0x70f88000>;
734def VSRLRN_H_W : LSX3R_VVV<0x70f90000>;
735def VSRLRN_W_D : LSX3R_VVV<0x70f98000>;
736def VSRARN_B_H : LSX3R_VVV<0x70fa8000>;
737def VSRARN_H_W : LSX3R_VVV<0x70fb0000>;
738def VSRARN_W_D : LSX3R_VVV<0x70fb8000>;
739
740def VSRLRNI_B_H : LSX2RI4_VVVI<0x73444000>;
741def VSRLRNI_H_W : LSX2RI5_VVVI<0x73448000>;
742def VSRLRNI_W_D : LSX2RI6_VVVI<0x73450000>;
743def VSRLRNI_D_Q : LSX2RI7_VVVI<0x73460000>;
744def VSRARNI_B_H : LSX2RI4_VVVI<0x735c4000>;
745def VSRARNI_H_W : LSX2RI5_VVVI<0x735c8000>;
746def VSRARNI_W_D : LSX2RI6_VVVI<0x735d0000>;
747def VSRARNI_D_Q : LSX2RI7_VVVI<0x735e0000>;
748
749def VSSRLN_B_H : LSX3R_VVV<0x70fc8000>;
750def VSSRLN_H_W : LSX3R_VVV<0x70fd0000>;
751def VSSRLN_W_D : LSX3R_VVV<0x70fd8000>;
752def VSSRAN_B_H : LSX3R_VVV<0x70fe8000>;
753def VSSRAN_H_W : LSX3R_VVV<0x70ff0000>;
754def VSSRAN_W_D : LSX3R_VVV<0x70ff8000>;
755def VSSRLN_BU_H : LSX3R_VVV<0x71048000>;
756def VSSRLN_HU_W : LSX3R_VVV<0x71050000>;
757def VSSRLN_WU_D : LSX3R_VVV<0x71058000>;
758def VSSRAN_BU_H : LSX3R_VVV<0x71068000>;
759def VSSRAN_HU_W : LSX3R_VVV<0x71070000>;
760def VSSRAN_WU_D : LSX3R_VVV<0x71078000>;
761
762def VSSRLNI_B_H : LSX2RI4_VVVI<0x73484000>;
763def VSSRLNI_H_W : LSX2RI5_VVVI<0x73488000>;
764def VSSRLNI_W_D : LSX2RI6_VVVI<0x73490000>;
765def VSSRLNI_D_Q : LSX2RI7_VVVI<0x734a0000>;
766def VSSRANI_B_H : LSX2RI4_VVVI<0x73604000>;
767def VSSRANI_H_W : LSX2RI5_VVVI<0x73608000>;
768def VSSRANI_W_D : LSX2RI6_VVVI<0x73610000>;
769def VSSRANI_D_Q : LSX2RI7_VVVI<0x73620000>;
770def VSSRLNI_BU_H : LSX2RI4_VVVI<0x734c4000>;
771def VSSRLNI_HU_W : LSX2RI5_VVVI<0x734c8000>;
772def VSSRLNI_WU_D : LSX2RI6_VVVI<0x734d0000>;
773def VSSRLNI_DU_Q : LSX2RI7_VVVI<0x734e0000>;
774def VSSRANI_BU_H : LSX2RI4_VVVI<0x73644000>;
775def VSSRANI_HU_W : LSX2RI5_VVVI<0x73648000>;
776def VSSRANI_WU_D : LSX2RI6_VVVI<0x73650000>;
777def VSSRANI_DU_Q : LSX2RI7_VVVI<0x73660000>;
778
779def VSSRLRN_B_H : LSX3R_VVV<0x71008000>;
780def VSSRLRN_H_W : LSX3R_VVV<0x71010000>;
781def VSSRLRN_W_D : LSX3R_VVV<0x71018000>;
782def VSSRARN_B_H : LSX3R_VVV<0x71028000>;
783def VSSRARN_H_W : LSX3R_VVV<0x71030000>;
784def VSSRARN_W_D : LSX3R_VVV<0x71038000>;
785def VSSRLRN_BU_H : LSX3R_VVV<0x71088000>;
786def VSSRLRN_HU_W : LSX3R_VVV<0x71090000>;
787def VSSRLRN_WU_D : LSX3R_VVV<0x71098000>;
788def VSSRARN_BU_H : LSX3R_VVV<0x710a8000>;
789def VSSRARN_HU_W : LSX3R_VVV<0x710b0000>;
790def VSSRARN_WU_D : LSX3R_VVV<0x710b8000>;
791
792def VSSRLRNI_B_H : LSX2RI4_VVVI<0x73504000>;
793def VSSRLRNI_H_W : LSX2RI5_VVVI<0x73508000>;
794def VSSRLRNI_W_D : LSX2RI6_VVVI<0x73510000>;
795def VSSRLRNI_D_Q : LSX2RI7_VVVI<0x73520000>;
796def VSSRARNI_B_H : LSX2RI4_VVVI<0x73684000>;
797def VSSRARNI_H_W : LSX2RI5_VVVI<0x73688000>;
798def VSSRARNI_W_D : LSX2RI6_VVVI<0x73690000>;
799def VSSRARNI_D_Q : LSX2RI7_VVVI<0x736a0000>;
800def VSSRLRNI_BU_H : LSX2RI4_VVVI<0x73544000>;
801def VSSRLRNI_HU_W : LSX2RI5_VVVI<0x73548000>;
802def VSSRLRNI_WU_D : LSX2RI6_VVVI<0x73550000>;
803def VSSRLRNI_DU_Q : LSX2RI7_VVVI<0x73560000>;
804def VSSRARNI_BU_H : LSX2RI4_VVVI<0x736c4000>;
805def VSSRARNI_HU_W : LSX2RI5_VVVI<0x736c8000>;
806def VSSRARNI_WU_D : LSX2RI6_VVVI<0x736d0000>;
807def VSSRARNI_DU_Q : LSX2RI7_VVVI<0x736e0000>;
808
809def VCLO_B : LSX2R_VV<0x729c0000>;
810def VCLO_H : LSX2R_VV<0x729c0400>;
811def VCLO_W : LSX2R_VV<0x729c0800>;
812def VCLO_D : LSX2R_VV<0x729c0c00>;
813def VCLZ_B : LSX2R_VV<0x729c1000>;
814def VCLZ_H : LSX2R_VV<0x729c1400>;
815def VCLZ_W : LSX2R_VV<0x729c1800>;
816def VCLZ_D : LSX2R_VV<0x729c1c00>;
817
818def VPCNT_B : LSX2R_VV<0x729c2000>;
819def VPCNT_H : LSX2R_VV<0x729c2400>;
820def VPCNT_W : LSX2R_VV<0x729c2800>;
821def VPCNT_D : LSX2R_VV<0x729c2c00>;
822
823def VBITCLR_B : LSX3R_VVV<0x710c0000>;
824def VBITCLR_H : LSX3R_VVV<0x710c8000>;
825def VBITCLR_W : LSX3R_VVV<0x710d0000>;
826def VBITCLR_D : LSX3R_VVV<0x710d8000>;
827def VBITCLRI_B : LSX2RI3_VVI<0x73102000>;
828def VBITCLRI_H : LSX2RI4_VVI<0x73104000>;
829def VBITCLRI_W : LSX2RI5_VVI<0x73108000>;
830def VBITCLRI_D : LSX2RI6_VVI<0x73110000>;
831
832def VBITSET_B : LSX3R_VVV<0x710e0000>;
833def VBITSET_H : LSX3R_VVV<0x710e8000>;
834def VBITSET_W : LSX3R_VVV<0x710f0000>;
835def VBITSET_D : LSX3R_VVV<0x710f8000>;
836def VBITSETI_B : LSX2RI3_VVI<0x73142000>;
837def VBITSETI_H : LSX2RI4_VVI<0x73144000>;
838def VBITSETI_W : LSX2RI5_VVI<0x73148000>;
839def VBITSETI_D : LSX2RI6_VVI<0x73150000>;
840
841def VBITREV_B : LSX3R_VVV<0x71100000>;
842def VBITREV_H : LSX3R_VVV<0x71108000>;
843def VBITREV_W : LSX3R_VVV<0x71110000>;
844def VBITREV_D : LSX3R_VVV<0x71118000>;
845def VBITREVI_B : LSX2RI3_VVI<0x73182000>;
846def VBITREVI_H : LSX2RI4_VVI<0x73184000>;
847def VBITREVI_W : LSX2RI5_VVI<0x73188000>;
848def VBITREVI_D : LSX2RI6_VVI<0x73190000>;
849
850def VFRSTP_B : LSX3R_VVVV<0x712b0000>;
851def VFRSTP_H : LSX3R_VVVV<0x712b8000>;
852def VFRSTPI_B : LSX2RI5_VVVI<0x729a0000>;
853def VFRSTPI_H : LSX2RI5_VVVI<0x729a8000>;
854
855def VFADD_S : LSX3R_VVV<0x71308000>;
856def VFADD_D : LSX3R_VVV<0x71310000>;
857def VFSUB_S : LSX3R_VVV<0x71328000>;
858def VFSUB_D : LSX3R_VVV<0x71330000>;
859def VFMUL_S : LSX3R_VVV<0x71388000>;
860def VFMUL_D : LSX3R_VVV<0x71390000>;
861def VFDIV_S : LSX3R_VVV<0x713a8000>;
862def VFDIV_D : LSX3R_VVV<0x713b0000>;
863
864def VFMADD_S : LSX4R_VVVV<0x09100000>;
865def VFMADD_D : LSX4R_VVVV<0x09200000>;
866def VFMSUB_S : LSX4R_VVVV<0x09500000>;
867def VFMSUB_D : LSX4R_VVVV<0x09600000>;
868def VFNMADD_S : LSX4R_VVVV<0x09900000>;
869def VFNMADD_D : LSX4R_VVVV<0x09a00000>;
870def VFNMSUB_S : LSX4R_VVVV<0x09d00000>;
871def VFNMSUB_D : LSX4R_VVVV<0x09e00000>;
872
873def VFMAX_S : LSX3R_VVV<0x713c8000>;
874def VFMAX_D : LSX3R_VVV<0x713d0000>;
875def VFMIN_S : LSX3R_VVV<0x713e8000>;
876def VFMIN_D : LSX3R_VVV<0x713f0000>;
877
878def VFMAXA_S : LSX3R_VVV<0x71408000>;
879def VFMAXA_D : LSX3R_VVV<0x71410000>;
880def VFMINA_S : LSX3R_VVV<0x71428000>;
881def VFMINA_D : LSX3R_VVV<0x71430000>;
882
883def VFLOGB_S : LSX2R_VV<0x729cc400>;
884def VFLOGB_D : LSX2R_VV<0x729cc800>;
885
886def VFCLASS_S : LSX2R_VV<0x729cd400>;
887def VFCLASS_D : LSX2R_VV<0x729cd800>;
888
889def VFSQRT_S : LSX2R_VV<0x729ce400>;
890def VFSQRT_D : LSX2R_VV<0x729ce800>;
891def VFRECIP_S : LSX2R_VV<0x729cf400>;
892def VFRECIP_D : LSX2R_VV<0x729cf800>;
893def VFRSQRT_S : LSX2R_VV<0x729d0400>;
894def VFRSQRT_D : LSX2R_VV<0x729d0800>;
895def VFRECIPE_S : LSX2R_VV<0x729d1400>;
896def VFRECIPE_D : LSX2R_VV<0x729d1800>;
897def VFRSQRTE_S : LSX2R_VV<0x729d2400>;
898def VFRSQRTE_D : LSX2R_VV<0x729d2800>;
899
900def VFCVTL_S_H : LSX2R_VV<0x729de800>;
901def VFCVTH_S_H : LSX2R_VV<0x729dec00>;
902def VFCVTL_D_S : LSX2R_VV<0x729df000>;
903def VFCVTH_D_S : LSX2R_VV<0x729df400>;
904def VFCVT_H_S : LSX3R_VVV<0x71460000>;
905def VFCVT_S_D : LSX3R_VVV<0x71468000>;
906
907def VFRINTRNE_S : LSX2R_VV<0x729d7400>;
908def VFRINTRNE_D : LSX2R_VV<0x729d7800>;
909def VFRINTRZ_S : LSX2R_VV<0x729d6400>;
910def VFRINTRZ_D : LSX2R_VV<0x729d6800>;
911def VFRINTRP_S : LSX2R_VV<0x729d5400>;
912def VFRINTRP_D : LSX2R_VV<0x729d5800>;
913def VFRINTRM_S : LSX2R_VV<0x729d4400>;
914def VFRINTRM_D : LSX2R_VV<0x729d4800>;
915def VFRINT_S : LSX2R_VV<0x729d3400>;
916def VFRINT_D : LSX2R_VV<0x729d3800>;
917
918def VFTINTRNE_W_S : LSX2R_VV<0x729e5000>;
919def VFTINTRNE_L_D : LSX2R_VV<0x729e5400>;
920def VFTINTRZ_W_S : LSX2R_VV<0x729e4800>;
921def VFTINTRZ_L_D : LSX2R_VV<0x729e4c00>;
922def VFTINTRP_W_S : LSX2R_VV<0x729e4000>;
923def VFTINTRP_L_D : LSX2R_VV<0x729e4400>;
924def VFTINTRM_W_S : LSX2R_VV<0x729e3800>;
925def VFTINTRM_L_D : LSX2R_VV<0x729e3c00>;
926def VFTINT_W_S : LSX2R_VV<0x729e3000>;
927def VFTINT_L_D : LSX2R_VV<0x729e3400>;
928def VFTINTRZ_WU_S : LSX2R_VV<0x729e7000>;
929def VFTINTRZ_LU_D : LSX2R_VV<0x729e7400>;
930def VFTINT_WU_S : LSX2R_VV<0x729e5800>;
931def VFTINT_LU_D : LSX2R_VV<0x729e5c00>;
932
933def VFTINTRNE_W_D : LSX3R_VVV<0x714b8000>;
934def VFTINTRZ_W_D : LSX3R_VVV<0x714b0000>;
935def VFTINTRP_W_D : LSX3R_VVV<0x714a8000>;
936def VFTINTRM_W_D : LSX3R_VVV<0x714a0000>;
937def VFTINT_W_D : LSX3R_VVV<0x71498000>;
938
939def VFTINTRNEL_L_S : LSX2R_VV<0x729ea000>;
940def VFTINTRNEH_L_S : LSX2R_VV<0x729ea400>;
941def VFTINTRZL_L_S : LSX2R_VV<0x729e9800>;
942def VFTINTRZH_L_S : LSX2R_VV<0x729e9c00>;
943def VFTINTRPL_L_S : LSX2R_VV<0x729e9000>;
944def VFTINTRPH_L_S : LSX2R_VV<0x729e9400>;
945def VFTINTRML_L_S : LSX2R_VV<0x729e8800>;
946def VFTINTRMH_L_S : LSX2R_VV<0x729e8c00>;
947def VFTINTL_L_S : LSX2R_VV<0x729e8000>;
948def VFTINTH_L_S : LSX2R_VV<0x729e8400>;
949
950def VFFINT_S_W : LSX2R_VV<0x729e0000>;
951def VFFINT_D_L : LSX2R_VV<0x729e0800>;
952def VFFINT_S_WU : LSX2R_VV<0x729e0400>;
953def VFFINT_D_LU : LSX2R_VV<0x729e0c00>;
954def VFFINTL_D_W : LSX2R_VV<0x729e1000>;
955def VFFINTH_D_W : LSX2R_VV<0x729e1400>;
956def VFFINT_S_L : LSX3R_VVV<0x71480000>;
957
958def VSEQ_B : LSX3R_VVV<0x70000000>;
959def VSEQ_H : LSX3R_VVV<0x70008000>;
960def VSEQ_W : LSX3R_VVV<0x70010000>;
961def VSEQ_D : LSX3R_VVV<0x70018000>;
962def VSEQI_B : LSX2RI5_VVI<0x72800000, simm5>;
963def VSEQI_H : LSX2RI5_VVI<0x72808000, simm5>;
964def VSEQI_W : LSX2RI5_VVI<0x72810000, simm5>;
965def VSEQI_D : LSX2RI5_VVI<0x72818000, simm5>;
966
967def VSLE_B : LSX3R_VVV<0x70020000>;
968def VSLE_H : LSX3R_VVV<0x70028000>;
969def VSLE_W : LSX3R_VVV<0x70030000>;
970def VSLE_D : LSX3R_VVV<0x70038000>;
971def VSLEI_B : LSX2RI5_VVI<0x72820000, simm5>;
972def VSLEI_H : LSX2RI5_VVI<0x72828000, simm5>;
973def VSLEI_W : LSX2RI5_VVI<0x72830000, simm5>;
974def VSLEI_D : LSX2RI5_VVI<0x72838000, simm5>;
975
976def VSLE_BU : LSX3R_VVV<0x70040000>;
977def VSLE_HU : LSX3R_VVV<0x70048000>;
978def VSLE_WU : LSX3R_VVV<0x70050000>;
979def VSLE_DU : LSX3R_VVV<0x70058000>;
980def VSLEI_BU : LSX2RI5_VVI<0x72840000>;
981def VSLEI_HU : LSX2RI5_VVI<0x72848000>;
982def VSLEI_WU : LSX2RI5_VVI<0x72850000>;
983def VSLEI_DU : LSX2RI5_VVI<0x72858000>;
984
985def VSLT_B : LSX3R_VVV<0x70060000>;
986def VSLT_H : LSX3R_VVV<0x70068000>;
987def VSLT_W : LSX3R_VVV<0x70070000>;
988def VSLT_D : LSX3R_VVV<0x70078000>;
989def VSLTI_B : LSX2RI5_VVI<0x72860000, simm5>;
990def VSLTI_H : LSX2RI5_VVI<0x72868000, simm5>;
991def VSLTI_W : LSX2RI5_VVI<0x72870000, simm5>;
992def VSLTI_D : LSX2RI5_VVI<0x72878000, simm5>;
993
994def VSLT_BU : LSX3R_VVV<0x70080000>;
995def VSLT_HU : LSX3R_VVV<0x70088000>;
996def VSLT_WU : LSX3R_VVV<0x70090000>;
997def VSLT_DU : LSX3R_VVV<0x70098000>;
998def VSLTI_BU : LSX2RI5_VVI<0x72880000>;
999def VSLTI_HU : LSX2RI5_VVI<0x72888000>;
1000def VSLTI_WU : LSX2RI5_VVI<0x72890000>;
1001def VSLTI_DU : LSX2RI5_VVI<0x72898000>;
1002
1003def VFCMP_CAF_S : LSX3R_VVV<0x0c500000>;
1004def VFCMP_SAF_S : LSX3R_VVV<0x0c508000>;
1005def VFCMP_CLT_S : LSX3R_VVV<0x0c510000>;
1006def VFCMP_SLT_S : LSX3R_VVV<0x0c518000>;
1007def VFCMP_CEQ_S : LSX3R_VVV<0x0c520000>;
1008def VFCMP_SEQ_S : LSX3R_VVV<0x0c528000>;
1009def VFCMP_CLE_S : LSX3R_VVV<0x0c530000>;
1010def VFCMP_SLE_S : LSX3R_VVV<0x0c538000>;
1011def VFCMP_CUN_S : LSX3R_VVV<0x0c540000>;
1012def VFCMP_SUN_S : LSX3R_VVV<0x0c548000>;
1013def VFCMP_CULT_S : LSX3R_VVV<0x0c550000>;
1014def VFCMP_SULT_S : LSX3R_VVV<0x0c558000>;
1015def VFCMP_CUEQ_S : LSX3R_VVV<0x0c560000>;
1016def VFCMP_SUEQ_S : LSX3R_VVV<0x0c568000>;
1017def VFCMP_CULE_S : LSX3R_VVV<0x0c570000>;
1018def VFCMP_SULE_S : LSX3R_VVV<0x0c578000>;
1019def VFCMP_CNE_S : LSX3R_VVV<0x0c580000>;
1020def VFCMP_SNE_S : LSX3R_VVV<0x0c588000>;
1021def VFCMP_COR_S : LSX3R_VVV<0x0c5a0000>;
1022def VFCMP_SOR_S : LSX3R_VVV<0x0c5a8000>;
1023def VFCMP_CUNE_S : LSX3R_VVV<0x0c5c0000>;
1024def VFCMP_SUNE_S : LSX3R_VVV<0x0c5c8000>;
1025
1026def VFCMP_CAF_D : LSX3R_VVV<0x0c600000>;
1027def VFCMP_SAF_D : LSX3R_VVV<0x0c608000>;
1028def VFCMP_CLT_D : LSX3R_VVV<0x0c610000>;
1029def VFCMP_SLT_D : LSX3R_VVV<0x0c618000>;
1030def VFCMP_CEQ_D : LSX3R_VVV<0x0c620000>;
1031def VFCMP_SEQ_D : LSX3R_VVV<0x0c628000>;
1032def VFCMP_CLE_D : LSX3R_VVV<0x0c630000>;
1033def VFCMP_SLE_D : LSX3R_VVV<0x0c638000>;
1034def VFCMP_CUN_D : LSX3R_VVV<0x0c640000>;
1035def VFCMP_SUN_D : LSX3R_VVV<0x0c648000>;
1036def VFCMP_CULT_D : LSX3R_VVV<0x0c650000>;
1037def VFCMP_SULT_D : LSX3R_VVV<0x0c658000>;
1038def VFCMP_CUEQ_D : LSX3R_VVV<0x0c660000>;
1039def VFCMP_SUEQ_D : LSX3R_VVV<0x0c668000>;
1040def VFCMP_CULE_D : LSX3R_VVV<0x0c670000>;
1041def VFCMP_SULE_D : LSX3R_VVV<0x0c678000>;
1042def VFCMP_CNE_D : LSX3R_VVV<0x0c680000>;
1043def VFCMP_SNE_D : LSX3R_VVV<0x0c688000>;
1044def VFCMP_COR_D : LSX3R_VVV<0x0c6a0000>;
1045def VFCMP_SOR_D : LSX3R_VVV<0x0c6a8000>;
1046def VFCMP_CUNE_D : LSX3R_VVV<0x0c6c0000>;
1047def VFCMP_SUNE_D : LSX3R_VVV<0x0c6c8000>;
1048
1049def VBITSEL_V : LSX4R_VVVV<0x0d100000>;
1050
1051def VBITSELI_B : LSX2RI8_VVVI<0x73c40000>;
1052
1053def VSETEQZ_V : LSX2R_CV<0x729c9800>;
1054def VSETNEZ_V : LSX2R_CV<0x729c9c00>;
1055def VSETANYEQZ_B : LSX2R_CV<0x729ca000>;
1056def VSETANYEQZ_H : LSX2R_CV<0x729ca400>;
1057def VSETANYEQZ_W : LSX2R_CV<0x729ca800>;
1058def VSETANYEQZ_D : LSX2R_CV<0x729cac00>;
1059def VSETALLNEZ_B : LSX2R_CV<0x729cb000>;
1060def VSETALLNEZ_H : LSX2R_CV<0x729cb400>;
1061def VSETALLNEZ_W : LSX2R_CV<0x729cb800>;
1062def VSETALLNEZ_D : LSX2R_CV<0x729cbc00>;
1063
1064def VINSGR2VR_B : LSX2RI4_VVRI<0x72eb8000>;
1065def VINSGR2VR_H : LSX2RI3_VVRI<0x72ebc000>;
1066def VINSGR2VR_W : LSX2RI2_VVRI<0x72ebe000>;
1067def VINSGR2VR_D : LSX2RI1_VVRI<0x72ebf000>;
1068def VPICKVE2GR_B : LSX2RI4_RVI<0x72ef8000>;
1069def VPICKVE2GR_H : LSX2RI3_RVI<0x72efc000>;
1070def VPICKVE2GR_W : LSX2RI2_RVI<0x72efe000>;
1071def VPICKVE2GR_D : LSX2RI1_RVI<0x72eff000>;
1072def VPICKVE2GR_BU : LSX2RI4_RVI<0x72f38000>;
1073def VPICKVE2GR_HU : LSX2RI3_RVI<0x72f3c000>;
1074def VPICKVE2GR_WU : LSX2RI2_RVI<0x72f3e000>;
1075def VPICKVE2GR_DU : LSX2RI1_RVI<0x72f3f000>;
1076
1077def VREPLGR2VR_B : LSX2R_VR<0x729f0000>;
1078def VREPLGR2VR_H : LSX2R_VR<0x729f0400>;
1079def VREPLGR2VR_W : LSX2R_VR<0x729f0800>;
1080def VREPLGR2VR_D : LSX2R_VR<0x729f0c00>;
1081
1082def VREPLVE_B : LSX3R_VVR<0x71220000>;
1083def VREPLVE_H : LSX3R_VVR<0x71228000>;
1084def VREPLVE_W : LSX3R_VVR<0x71230000>;
1085def VREPLVE_D : LSX3R_VVR<0x71238000>;
1086def VREPLVEI_B : LSX2RI4_VVI<0x72f78000>;
1087def VREPLVEI_H : LSX2RI3_VVI<0x72f7c000>;
1088def VREPLVEI_W : LSX2RI2_VVI<0x72f7e000>;
1089def VREPLVEI_D : LSX2RI1_VVI<0x72f7f000>;
1090
1091def VBSLL_V : LSX2RI5_VVI<0x728e0000>;
1092def VBSRL_V : LSX2RI5_VVI<0x728e8000>;
1093
1094def VPACKEV_B : LSX3R_VVV<0x71160000>;
1095def VPACKEV_H : LSX3R_VVV<0x71168000>;
1096def VPACKEV_W : LSX3R_VVV<0x71170000>;
1097def VPACKEV_D : LSX3R_VVV<0x71178000>;
1098def VPACKOD_B : LSX3R_VVV<0x71180000>;
1099def VPACKOD_H : LSX3R_VVV<0x71188000>;
1100def VPACKOD_W : LSX3R_VVV<0x71190000>;
1101def VPACKOD_D : LSX3R_VVV<0x71198000>;
1102
1103def VPICKEV_B : LSX3R_VVV<0x711e0000>;
1104def VPICKEV_H : LSX3R_VVV<0x711e8000>;
1105def VPICKEV_W : LSX3R_VVV<0x711f0000>;
1106def VPICKEV_D : LSX3R_VVV<0x711f8000>;
1107def VPICKOD_B : LSX3R_VVV<0x71200000>;
1108def VPICKOD_H : LSX3R_VVV<0x71208000>;
1109def VPICKOD_W : LSX3R_VVV<0x71210000>;
1110def VPICKOD_D : LSX3R_VVV<0x71218000>;
1111
1112def VILVL_B : LSX3R_VVV<0x711a0000>;
1113def VILVL_H : LSX3R_VVV<0x711a8000>;
1114def VILVL_W : LSX3R_VVV<0x711b0000>;
1115def VILVL_D : LSX3R_VVV<0x711b8000>;
1116def VILVH_B : LSX3R_VVV<0x711c0000>;
1117def VILVH_H : LSX3R_VVV<0x711c8000>;
1118def VILVH_W : LSX3R_VVV<0x711d0000>;
1119def VILVH_D : LSX3R_VVV<0x711d8000>;
1120
1121def VSHUF_B : LSX4R_VVVV<0x0d500000>;
1122
1123def VSHUF_H : LSX3R_VVVV<0x717a8000>;
1124def VSHUF_W : LSX3R_VVVV<0x717b0000>;
1125def VSHUF_D : LSX3R_VVVV<0x717b8000>;
1126
1127def VSHUF4I_B : LSX2RI8_VVI<0x73900000>;
1128def VSHUF4I_H : LSX2RI8_VVI<0x73940000>;
1129def VSHUF4I_W : LSX2RI8_VVI<0x73980000>;
1130def VSHUF4I_D : LSX2RI8_VVVI<0x739c0000>;
1131
1132def VPERMI_W : LSX2RI8_VVVI<0x73e40000>;
1133
1134def VEXTRINS_D : LSX2RI8_VVVI<0x73800000>;
1135def VEXTRINS_W : LSX2RI8_VVVI<0x73840000>;
1136def VEXTRINS_H : LSX2RI8_VVVI<0x73880000>;
1137def VEXTRINS_B : LSX2RI8_VVVI<0x738c0000>;
1138} // mayLoad = 0, mayStore = 0
1139
1140let mayLoad = 1, mayStore = 0 in {
1141def VLD : LSX2RI12_Load<0x2c000000>;
1142def VLDX : LSX3R_Load<0x38400000>;
1143
1144def VLDREPL_B : LSX2RI12_Load<0x30800000>;
1145def VLDREPL_H : LSX2RI11_Load<0x30400000>;
1146def VLDREPL_W : LSX2RI10_Load<0x30200000>;
1147def VLDREPL_D : LSX2RI9_Load<0x30100000>;
1148} // mayLoad = 1, mayStore = 0
1149
1150let mayLoad = 0, mayStore = 1 in {
1151def VST : LSX2RI12_Store<0x2c400000>;
1152def VSTX : LSX3R_Store<0x38440000>;
1153
1154def VSTELM_B : LSX2RI8I4_VRII<0x31800000>;
1155def VSTELM_H : LSX2RI8I3_VRII<0x31400000, simm8_lsl1>;
1156def VSTELM_W : LSX2RI8I2_VRII<0x31200000, simm8_lsl2>;
1157def VSTELM_D : LSX2RI8I1_VRII<0x31100000, simm8_lsl3>;
1158} // mayLoad = 0, mayStore = 1
1159
1160} // hasSideEffects = 0, Predicates = [HasExtLSX]
1161
1162/// Pseudo-instructions
1163
1164let Predicates = [HasExtLSX] in {
1165
1166let hasSideEffects = 0, mayLoad = 0, mayStore = 0, isCodeGenOnly = 0,
1167    isAsmParserOnly = 1 in {
1168def PseudoVREPLI_B : Pseudo<(outs LSX128:$vd), (ins simm10:$imm), [],
1169                            "vrepli.b", "$vd, $imm">;
1170def PseudoVREPLI_H : Pseudo<(outs LSX128:$vd), (ins simm10:$imm), [],
1171                            "vrepli.h", "$vd, $imm">;
1172def PseudoVREPLI_W : Pseudo<(outs LSX128:$vd), (ins simm10:$imm), [],
1173                            "vrepli.w", "$vd, $imm">;
1174def PseudoVREPLI_D : Pseudo<(outs LSX128:$vd), (ins simm10:$imm), [],
1175                            "vrepli.d", "$vd, $imm">;
1176}
1177
1178def PseudoVBNZ_B : VecCond<loongarch_vall_nonzero, v16i8>;
1179def PseudoVBNZ_H : VecCond<loongarch_vall_nonzero, v8i16>;
1180def PseudoVBNZ_W : VecCond<loongarch_vall_nonzero, v4i32>;
1181def PseudoVBNZ_D : VecCond<loongarch_vall_nonzero, v2i64>;
1182def PseudoVBNZ : VecCond<loongarch_vany_nonzero, v16i8>;
1183
1184def PseudoVBZ_B : VecCond<loongarch_vall_zero, v16i8>;
1185def PseudoVBZ_H : VecCond<loongarch_vall_zero, v8i16>;
1186def PseudoVBZ_W : VecCond<loongarch_vall_zero, v4i32>;
1187def PseudoVBZ_D : VecCond<loongarch_vall_zero, v2i64>;
1188def PseudoVBZ : VecCond<loongarch_vany_zero, v16i8>;
1189
1190} // Predicates = [HasExtLSX]
1191
1192multiclass PatVr<SDPatternOperator OpNode, string Inst> {
1193  def : Pat<(v16i8 (OpNode (v16i8 LSX128:$vj))),
1194            (!cast<LAInst>(Inst#"_B") LSX128:$vj)>;
1195  def : Pat<(v8i16 (OpNode (v8i16 LSX128:$vj))),
1196            (!cast<LAInst>(Inst#"_H") LSX128:$vj)>;
1197  def : Pat<(v4i32 (OpNode (v4i32 LSX128:$vj))),
1198            (!cast<LAInst>(Inst#"_W") LSX128:$vj)>;
1199  def : Pat<(v2i64 (OpNode (v2i64 LSX128:$vj))),
1200            (!cast<LAInst>(Inst#"_D") LSX128:$vj)>;
1201}
1202
1203multiclass PatVrF<SDPatternOperator OpNode, string Inst> {
1204  def : Pat<(v4f32 (OpNode (v4f32 LSX128:$vj))),
1205            (!cast<LAInst>(Inst#"_S") LSX128:$vj)>;
1206  def : Pat<(v2f64 (OpNode (v2f64 LSX128:$vj))),
1207            (!cast<LAInst>(Inst#"_D") LSX128:$vj)>;
1208}
1209
1210multiclass PatVrVr<SDPatternOperator OpNode, string Inst> {
1211  def : Pat<(OpNode (v16i8 LSX128:$vj), (v16i8 LSX128:$vk)),
1212            (!cast<LAInst>(Inst#"_B") LSX128:$vj, LSX128:$vk)>;
1213  def : Pat<(OpNode (v8i16 LSX128:$vj), (v8i16 LSX128:$vk)),
1214            (!cast<LAInst>(Inst#"_H") LSX128:$vj, LSX128:$vk)>;
1215  def : Pat<(OpNode (v4i32 LSX128:$vj), (v4i32 LSX128:$vk)),
1216            (!cast<LAInst>(Inst#"_W") LSX128:$vj, LSX128:$vk)>;
1217  def : Pat<(OpNode (v2i64 LSX128:$vj), (v2i64 LSX128:$vk)),
1218            (!cast<LAInst>(Inst#"_D") LSX128:$vj, LSX128:$vk)>;
1219}
1220
1221multiclass PatVrVrF<SDPatternOperator OpNode, string Inst> {
1222  def : Pat<(OpNode (v4f32 LSX128:$vj), (v4f32 LSX128:$vk)),
1223            (!cast<LAInst>(Inst#"_S") LSX128:$vj, LSX128:$vk)>;
1224  def : Pat<(OpNode (v2f64 LSX128:$vj), (v2f64 LSX128:$vk)),
1225            (!cast<LAInst>(Inst#"_D") LSX128:$vj, LSX128:$vk)>;
1226}
1227
1228multiclass PatVrVrU<SDPatternOperator OpNode, string Inst> {
1229  def : Pat<(OpNode (v16i8 LSX128:$vj), (v16i8 LSX128:$vk)),
1230            (!cast<LAInst>(Inst#"_BU") LSX128:$vj, LSX128:$vk)>;
1231  def : Pat<(OpNode (v8i16 LSX128:$vj), (v8i16 LSX128:$vk)),
1232            (!cast<LAInst>(Inst#"_HU") LSX128:$vj, LSX128:$vk)>;
1233  def : Pat<(OpNode (v4i32 LSX128:$vj), (v4i32 LSX128:$vk)),
1234            (!cast<LAInst>(Inst#"_WU") LSX128:$vj, LSX128:$vk)>;
1235  def : Pat<(OpNode (v2i64 LSX128:$vj), (v2i64 LSX128:$vk)),
1236            (!cast<LAInst>(Inst#"_DU") LSX128:$vj, LSX128:$vk)>;
1237}
1238
1239multiclass PatVrSimm5<SDPatternOperator OpNode, string Inst> {
1240  def : Pat<(OpNode (v16i8 LSX128:$vj), (v16i8 (SplatPat_simm5 simm5:$imm))),
1241            (!cast<LAInst>(Inst#"_B") LSX128:$vj, simm5:$imm)>;
1242  def : Pat<(OpNode (v8i16 LSX128:$vj), (v8i16 (SplatPat_simm5 simm5:$imm))),
1243            (!cast<LAInst>(Inst#"_H") LSX128:$vj, simm5:$imm)>;
1244  def : Pat<(OpNode (v4i32 LSX128:$vj), (v4i32 (SplatPat_simm5 simm5:$imm))),
1245            (!cast<LAInst>(Inst#"_W") LSX128:$vj, simm5:$imm)>;
1246  def : Pat<(OpNode (v2i64 LSX128:$vj), (v2i64 (SplatPat_simm5 simm5:$imm))),
1247            (!cast<LAInst>(Inst#"_D") LSX128:$vj, simm5:$imm)>;
1248}
1249
1250multiclass PatVrUimm5<SDPatternOperator OpNode, string Inst> {
1251  def : Pat<(OpNode (v16i8 LSX128:$vj), (v16i8 (SplatPat_uimm5 uimm5:$imm))),
1252            (!cast<LAInst>(Inst#"_BU") LSX128:$vj, uimm5:$imm)>;
1253  def : Pat<(OpNode (v8i16 LSX128:$vj), (v8i16 (SplatPat_uimm5 uimm5:$imm))),
1254            (!cast<LAInst>(Inst#"_HU") LSX128:$vj, uimm5:$imm)>;
1255  def : Pat<(OpNode (v4i32 LSX128:$vj), (v4i32 (SplatPat_uimm5 uimm5:$imm))),
1256            (!cast<LAInst>(Inst#"_WU") LSX128:$vj, uimm5:$imm)>;
1257  def : Pat<(OpNode (v2i64 LSX128:$vj), (v2i64 (SplatPat_uimm5 uimm5:$imm))),
1258            (!cast<LAInst>(Inst#"_DU") LSX128:$vj, uimm5:$imm)>;
1259}
1260
1261multiclass PatVrVrVr<SDPatternOperator OpNode, string Inst> {
1262  def : Pat<(OpNode (v16i8 LSX128:$vd), (v16i8 LSX128:$vj), (v16i8 LSX128:$vk)),
1263            (!cast<LAInst>(Inst#"_B") LSX128:$vd, LSX128:$vj, LSX128:$vk)>;
1264  def : Pat<(OpNode (v8i16 LSX128:$vd), (v8i16 LSX128:$vj), (v8i16 LSX128:$vk)),
1265            (!cast<LAInst>(Inst#"_H") LSX128:$vd, LSX128:$vj, LSX128:$vk)>;
1266  def : Pat<(OpNode (v4i32 LSX128:$vd), (v4i32 LSX128:$vj), (v4i32 LSX128:$vk)),
1267            (!cast<LAInst>(Inst#"_W") LSX128:$vd, LSX128:$vj, LSX128:$vk)>;
1268  def : Pat<(OpNode (v2i64 LSX128:$vd), (v2i64 LSX128:$vj), (v2i64 LSX128:$vk)),
1269            (!cast<LAInst>(Inst#"_D") LSX128:$vd, LSX128:$vj, LSX128:$vk)>;
1270}
1271
1272multiclass PatShiftVrVr<SDPatternOperator OpNode, string Inst> {
1273  def : Pat<(OpNode (v16i8 LSX128:$vj), (and vsplati8_imm_eq_7,
1274                                             (v16i8 LSX128:$vk))),
1275            (!cast<LAInst>(Inst#"_B") LSX128:$vj, LSX128:$vk)>;
1276  def : Pat<(OpNode (v8i16 LSX128:$vj), (and vsplati16_imm_eq_15,
1277                                             (v8i16 LSX128:$vk))),
1278            (!cast<LAInst>(Inst#"_H") LSX128:$vj, LSX128:$vk)>;
1279  def : Pat<(OpNode (v4i32 LSX128:$vj), (and vsplati32_imm_eq_31,
1280                                             (v4i32 LSX128:$vk))),
1281            (!cast<LAInst>(Inst#"_W") LSX128:$vj, LSX128:$vk)>;
1282  def : Pat<(OpNode (v2i64 LSX128:$vj), (and vsplati64_imm_eq_63,
1283                                             (v2i64 LSX128:$vk))),
1284            (!cast<LAInst>(Inst#"_D") LSX128:$vj, LSX128:$vk)>;
1285}
1286
1287multiclass PatShiftVrUimm<SDPatternOperator OpNode, string Inst> {
1288  def : Pat<(OpNode (v16i8 LSX128:$vj), (v16i8 (SplatPat_uimm3 uimm3:$imm))),
1289            (!cast<LAInst>(Inst#"_B") LSX128:$vj, uimm3:$imm)>;
1290  def : Pat<(OpNode (v8i16 LSX128:$vj), (v8i16 (SplatPat_uimm4 uimm4:$imm))),
1291            (!cast<LAInst>(Inst#"_H") LSX128:$vj, uimm4:$imm)>;
1292  def : Pat<(OpNode (v4i32 LSX128:$vj), (v4i32 (SplatPat_uimm5 uimm5:$imm))),
1293            (!cast<LAInst>(Inst#"_W") LSX128:$vj, uimm5:$imm)>;
1294  def : Pat<(OpNode (v2i64 LSX128:$vj), (v2i64 (SplatPat_uimm6 uimm6:$imm))),
1295            (!cast<LAInst>(Inst#"_D") LSX128:$vj, uimm6:$imm)>;
1296}
1297
1298multiclass PatCCVrSimm5<CondCode CC, string Inst> {
1299  def : Pat<(v16i8 (setcc (v16i8 LSX128:$vj),
1300                          (v16i8 (SplatPat_simm5 simm5:$imm)), CC)),
1301            (!cast<LAInst>(Inst#"_B") LSX128:$vj, simm5:$imm)>;
1302  def : Pat<(v8i16 (setcc (v8i16 LSX128:$vj),
1303                          (v8i16 (SplatPat_simm5 simm5:$imm)), CC)),
1304            (!cast<LAInst>(Inst#"_H") LSX128:$vj, simm5:$imm)>;
1305  def : Pat<(v4i32 (setcc (v4i32 LSX128:$vj),
1306                          (v4i32 (SplatPat_simm5 simm5:$imm)), CC)),
1307            (!cast<LAInst>(Inst#"_W") LSX128:$vj, simm5:$imm)>;
1308  def : Pat<(v2i64 (setcc (v2i64 LSX128:$vj),
1309                          (v2i64 (SplatPat_simm5 simm5:$imm)), CC)),
1310            (!cast<LAInst>(Inst#"_D") LSX128:$vj, simm5:$imm)>;
1311}
1312
1313multiclass PatCCVrUimm5<CondCode CC, string Inst> {
1314  def : Pat<(v16i8 (setcc (v16i8 LSX128:$vj),
1315                          (v16i8 (SplatPat_uimm5 uimm5:$imm)), CC)),
1316            (!cast<LAInst>(Inst#"_BU") LSX128:$vj, uimm5:$imm)>;
1317  def : Pat<(v8i16 (setcc (v8i16 LSX128:$vj),
1318                          (v8i16 (SplatPat_uimm5 uimm5:$imm)), CC)),
1319            (!cast<LAInst>(Inst#"_HU") LSX128:$vj, uimm5:$imm)>;
1320  def : Pat<(v4i32 (setcc (v4i32 LSX128:$vj),
1321                          (v4i32 (SplatPat_uimm5 uimm5:$imm)), CC)),
1322            (!cast<LAInst>(Inst#"_WU") LSX128:$vj, uimm5:$imm)>;
1323  def : Pat<(v2i64 (setcc (v2i64 LSX128:$vj),
1324                          (v2i64 (SplatPat_uimm5 uimm5:$imm)), CC)),
1325            (!cast<LAInst>(Inst#"_DU") LSX128:$vj, uimm5:$imm)>;
1326}
1327
1328multiclass PatCCVrVr<CondCode CC, string Inst> {
1329  def : Pat<(v16i8 (setcc (v16i8 LSX128:$vj), (v16i8 LSX128:$vk), CC)),
1330            (!cast<LAInst>(Inst#"_B") LSX128:$vj, LSX128:$vk)>;
1331  def : Pat<(v8i16 (setcc (v8i16 LSX128:$vj), (v8i16 LSX128:$vk), CC)),
1332            (!cast<LAInst>(Inst#"_H") LSX128:$vj, LSX128:$vk)>;
1333  def : Pat<(v4i32 (setcc (v4i32 LSX128:$vj), (v4i32 LSX128:$vk), CC)),
1334            (!cast<LAInst>(Inst#"_W") LSX128:$vj, LSX128:$vk)>;
1335  def : Pat<(v2i64 (setcc (v2i64 LSX128:$vj), (v2i64 LSX128:$vk), CC)),
1336            (!cast<LAInst>(Inst#"_D") LSX128:$vj, LSX128:$vk)>;
1337}
1338
1339multiclass PatCCVrVrU<CondCode CC, string Inst> {
1340  def : Pat<(v16i8 (setcc (v16i8 LSX128:$vj), (v16i8 LSX128:$vk), CC)),
1341            (!cast<LAInst>(Inst#"_BU") LSX128:$vj, LSX128:$vk)>;
1342  def : Pat<(v8i16 (setcc (v8i16 LSX128:$vj), (v8i16 LSX128:$vk), CC)),
1343            (!cast<LAInst>(Inst#"_HU") LSX128:$vj, LSX128:$vk)>;
1344  def : Pat<(v4i32 (setcc (v4i32 LSX128:$vj), (v4i32 LSX128:$vk), CC)),
1345            (!cast<LAInst>(Inst#"_WU") LSX128:$vj, LSX128:$vk)>;
1346  def : Pat<(v2i64 (setcc (v2i64 LSX128:$vj), (v2i64 LSX128:$vk), CC)),
1347            (!cast<LAInst>(Inst#"_DU") LSX128:$vj, LSX128:$vk)>;
1348}
1349
1350multiclass PatCCVrVrF<CondCode CC, string Inst> {
1351  def : Pat<(v4i32 (setcc (v4f32 LSX128:$vj), (v4f32 LSX128:$vk), CC)),
1352            (!cast<LAInst>(Inst#"_S") LSX128:$vj, LSX128:$vk)>;
1353  def : Pat<(v2i64 (setcc (v2f64 LSX128:$vj), (v2f64 LSX128:$vk), CC)),
1354            (!cast<LAInst>(Inst#"_D") LSX128:$vj, LSX128:$vk)>;
1355}
1356
1357let Predicates = [HasExtLSX] in {
1358
1359// VADD_{B/H/W/D}
1360defm : PatVrVr<add, "VADD">;
1361// VSUB_{B/H/W/D}
1362defm : PatVrVr<sub, "VSUB">;
1363
1364// VADDI_{B/H/W/D}U
1365defm : PatVrUimm5<add, "VADDI">;
1366// VSUBI_{B/H/W/D}U
1367defm : PatVrUimm5<sub, "VSUBI">;
1368
1369// VNEG_{B/H/W/D}
1370def : Pat<(sub immAllZerosV, (v16i8 LSX128:$vj)), (VNEG_B LSX128:$vj)>;
1371def : Pat<(sub immAllZerosV, (v8i16 LSX128:$vj)), (VNEG_H LSX128:$vj)>;
1372def : Pat<(sub immAllZerosV, (v4i32 LSX128:$vj)), (VNEG_W LSX128:$vj)>;
1373def : Pat<(sub immAllZerosV, (v2i64 LSX128:$vj)), (VNEG_D LSX128:$vj)>;
1374
1375// VMAX[I]_{B/H/W/D}[U]
1376defm : PatVrVr<smax, "VMAX">;
1377defm : PatVrVrU<umax, "VMAX">;
1378defm : PatVrSimm5<smax, "VMAXI">;
1379defm : PatVrUimm5<umax, "VMAXI">;
1380
1381// VMIN[I]_{B/H/W/D}[U]
1382defm : PatVrVr<smin, "VMIN">;
1383defm : PatVrVrU<umin, "VMIN">;
1384defm : PatVrSimm5<smin, "VMINI">;
1385defm : PatVrUimm5<umin, "VMINI">;
1386
1387// VMUL_{B/H/W/D}
1388defm : PatVrVr<mul, "VMUL">;
1389
1390// VMUH_{B/H/W/D}[U]
1391defm : PatVrVr<mulhs, "VMUH">;
1392defm : PatVrVrU<mulhu, "VMUH">;
1393
1394// VMADD_{B/H/W/D}
1395defm : PatVrVrVr<muladd, "VMADD">;
1396// VMSUB_{B/H/W/D}
1397defm : PatVrVrVr<mulsub, "VMSUB">;
1398
1399// VDIV_{B/H/W/D}[U]
1400defm : PatVrVr<sdiv, "VDIV">;
1401defm : PatVrVrU<udiv, "VDIV">;
1402
1403// VMOD_{B/H/W/D}[U]
1404defm : PatVrVr<srem, "VMOD">;
1405defm : PatVrVrU<urem, "VMOD">;
1406
1407// VAND_V
1408foreach vt = [v16i8, v8i16, v4i32, v2i64] in
1409def : Pat<(and (vt LSX128:$vj), (vt LSX128:$vk)),
1410          (VAND_V LSX128:$vj, LSX128:$vk)>;
1411// VOR_V
1412foreach vt = [v16i8, v8i16, v4i32, v2i64] in
1413def : Pat<(or (vt LSX128:$vj), (vt LSX128:$vk)),
1414          (VOR_V LSX128:$vj, LSX128:$vk)>;
1415// VXOR_V
1416foreach vt = [v16i8, v8i16, v4i32, v2i64] in
1417def : Pat<(xor (vt LSX128:$vj), (vt LSX128:$vk)),
1418          (VXOR_V LSX128:$vj, LSX128:$vk)>;
1419// VNOR_V
1420foreach vt = [v16i8, v8i16, v4i32, v2i64] in
1421def : Pat<(vnot (or (vt LSX128:$vj), (vt LSX128:$vk))),
1422          (VNOR_V LSX128:$vj, LSX128:$vk)>;
1423
1424// VANDI_B
1425def : Pat<(and (v16i8 LSX128:$vj), (v16i8 (SplatPat_uimm8 uimm8:$imm))),
1426          (VANDI_B LSX128:$vj, uimm8:$imm)>;
1427// VORI_B
1428def : Pat<(or (v16i8 LSX128:$vj), (v16i8 (SplatPat_uimm8 uimm8:$imm))),
1429          (VORI_B LSX128:$vj, uimm8:$imm)>;
1430
1431// VXORI_B
1432def : Pat<(xor (v16i8 LSX128:$vj), (v16i8 (SplatPat_uimm8 uimm8:$imm))),
1433          (VXORI_B LSX128:$vj, uimm8:$imm)>;
1434
1435// VSLL[I]_{B/H/W/D}
1436defm : PatVrVr<shl, "VSLL">;
1437defm : PatShiftVrVr<shl, "VSLL">;
1438defm : PatShiftVrUimm<shl, "VSLLI">;
1439
1440// VSRL[I]_{B/H/W/D}
1441defm : PatVrVr<srl, "VSRL">;
1442defm : PatShiftVrVr<srl, "VSRL">;
1443defm : PatShiftVrUimm<srl, "VSRLI">;
1444
1445// VSRA[I]_{B/H/W/D}
1446defm : PatVrVr<sra, "VSRA">;
1447defm : PatShiftVrVr<sra, "VSRA">;
1448defm : PatShiftVrUimm<sra, "VSRAI">;
1449
1450// VCLZ_{B/H/W/D}
1451defm : PatVr<ctlz, "VCLZ">;
1452
1453// VPCNT_{B/H/W/D}
1454defm : PatVr<ctpop, "VPCNT">;
1455
1456// VBITCLR_{B/H/W/D}
1457def : Pat<(and v16i8:$vj, (vnot (shl vsplat_imm_eq_1, v16i8:$vk))),
1458          (v16i8 (VBITCLR_B v16i8:$vj, v16i8:$vk))>;
1459def : Pat<(and v8i16:$vj, (vnot (shl vsplat_imm_eq_1, v8i16:$vk))),
1460          (v8i16 (VBITCLR_H v8i16:$vj, v8i16:$vk))>;
1461def : Pat<(and v4i32:$vj, (vnot (shl vsplat_imm_eq_1, v4i32:$vk))),
1462          (v4i32 (VBITCLR_W v4i32:$vj, v4i32:$vk))>;
1463def : Pat<(and v2i64:$vj, (vnot (shl vsplat_imm_eq_1, v2i64:$vk))),
1464          (v2i64 (VBITCLR_D v2i64:$vj, v2i64:$vk))>;
1465def : Pat<(and v16i8:$vj, (vnot (shl vsplat_imm_eq_1,
1466                                     (vsplati8imm7 v16i8:$vk)))),
1467          (v16i8 (VBITCLR_B v16i8:$vj, v16i8:$vk))>;
1468def : Pat<(and v8i16:$vj, (vnot (shl vsplat_imm_eq_1,
1469                                     (vsplati16imm15 v8i16:$vk)))),
1470          (v8i16 (VBITCLR_H v8i16:$vj, v8i16:$vk))>;
1471def : Pat<(and v4i32:$vj, (vnot (shl vsplat_imm_eq_1,
1472                                     (vsplati32imm31 v4i32:$vk)))),
1473          (v4i32 (VBITCLR_W v4i32:$vj, v4i32:$vk))>;
1474def : Pat<(and v2i64:$vj, (vnot (shl vsplat_imm_eq_1,
1475                                     (vsplati64imm63 v2i64:$vk)))),
1476          (v2i64 (VBITCLR_D v2i64:$vj, v2i64:$vk))>;
1477
1478// VBITCLRI_{B/H/W/D}
1479def : Pat<(and (v16i8 LSX128:$vj), (v16i8 (vsplat_uimm_inv_pow2 uimm3:$imm))),
1480          (VBITCLRI_B LSX128:$vj, uimm3:$imm)>;
1481def : Pat<(and (v8i16 LSX128:$vj), (v8i16 (vsplat_uimm_inv_pow2 uimm4:$imm))),
1482          (VBITCLRI_H LSX128:$vj, uimm4:$imm)>;
1483def : Pat<(and (v4i32 LSX128:$vj), (v4i32 (vsplat_uimm_inv_pow2 uimm5:$imm))),
1484          (VBITCLRI_W LSX128:$vj, uimm5:$imm)>;
1485def : Pat<(and (v2i64 LSX128:$vj), (v2i64 (vsplat_uimm_inv_pow2 uimm6:$imm))),
1486          (VBITCLRI_D LSX128:$vj, uimm6:$imm)>;
1487
1488// VBITSET_{B/H/W/D}
1489def : Pat<(or v16i8:$vj, (shl vsplat_imm_eq_1, v16i8:$vk)),
1490          (v16i8 (VBITSET_B v16i8:$vj, v16i8:$vk))>;
1491def : Pat<(or v8i16:$vj, (shl vsplat_imm_eq_1, v8i16:$vk)),
1492          (v8i16 (VBITSET_H v8i16:$vj, v8i16:$vk))>;
1493def : Pat<(or v4i32:$vj, (shl vsplat_imm_eq_1, v4i32:$vk)),
1494          (v4i32 (VBITSET_W v4i32:$vj, v4i32:$vk))>;
1495def : Pat<(or v2i64:$vj, (shl vsplat_imm_eq_1, v2i64:$vk)),
1496          (v2i64 (VBITSET_D v2i64:$vj, v2i64:$vk))>;
1497def : Pat<(or v16i8:$vj, (shl vsplat_imm_eq_1, (vsplati8imm7 v16i8:$vk))),
1498          (v16i8 (VBITSET_B v16i8:$vj, v16i8:$vk))>;
1499def : Pat<(or v8i16:$vj, (shl vsplat_imm_eq_1, (vsplati16imm15 v8i16:$vk))),
1500          (v8i16 (VBITSET_H v8i16:$vj, v8i16:$vk))>;
1501def : Pat<(or v4i32:$vj, (shl vsplat_imm_eq_1, (vsplati32imm31 v4i32:$vk))),
1502          (v4i32 (VBITSET_W v4i32:$vj, v4i32:$vk))>;
1503def : Pat<(or v2i64:$vj, (shl vsplat_imm_eq_1, (vsplati64imm63 v2i64:$vk))),
1504          (v2i64 (VBITSET_D v2i64:$vj, v2i64:$vk))>;
1505
1506// VBITSETI_{B/H/W/D}
1507def : Pat<(or (v16i8 LSX128:$vj), (v16i8 (vsplat_uimm_pow2 uimm3:$imm))),
1508          (VBITSETI_B LSX128:$vj, uimm3:$imm)>;
1509def : Pat<(or (v8i16 LSX128:$vj), (v8i16 (vsplat_uimm_pow2 uimm4:$imm))),
1510          (VBITSETI_H LSX128:$vj, uimm4:$imm)>;
1511def : Pat<(or (v4i32 LSX128:$vj), (v4i32 (vsplat_uimm_pow2 uimm5:$imm))),
1512          (VBITSETI_W LSX128:$vj, uimm5:$imm)>;
1513def : Pat<(or (v2i64 LSX128:$vj), (v2i64 (vsplat_uimm_pow2 uimm6:$imm))),
1514          (VBITSETI_D LSX128:$vj, uimm6:$imm)>;
1515
1516// VBITREV_{B/H/W/D}
1517def : Pat<(xor v16i8:$vj, (shl vsplat_imm_eq_1, v16i8:$vk)),
1518          (v16i8 (VBITREV_B v16i8:$vj, v16i8:$vk))>;
1519def : Pat<(xor v8i16:$vj, (shl vsplat_imm_eq_1, v8i16:$vk)),
1520          (v8i16 (VBITREV_H v8i16:$vj, v8i16:$vk))>;
1521def : Pat<(xor v4i32:$vj, (shl vsplat_imm_eq_1, v4i32:$vk)),
1522          (v4i32 (VBITREV_W v4i32:$vj, v4i32:$vk))>;
1523def : Pat<(xor v2i64:$vj, (shl vsplat_imm_eq_1, v2i64:$vk)),
1524          (v2i64 (VBITREV_D v2i64:$vj, v2i64:$vk))>;
1525def : Pat<(xor v16i8:$vj, (shl vsplat_imm_eq_1, (vsplati8imm7 v16i8:$vk))),
1526          (v16i8 (VBITREV_B v16i8:$vj, v16i8:$vk))>;
1527def : Pat<(xor v8i16:$vj, (shl vsplat_imm_eq_1, (vsplati16imm15 v8i16:$vk))),
1528          (v8i16 (VBITREV_H v8i16:$vj, v8i16:$vk))>;
1529def : Pat<(xor v4i32:$vj, (shl vsplat_imm_eq_1, (vsplati32imm31 v4i32:$vk))),
1530          (v4i32 (VBITREV_W v4i32:$vj, v4i32:$vk))>;
1531def : Pat<(xor v2i64:$vj, (shl vsplat_imm_eq_1, (vsplati64imm63 v2i64:$vk))),
1532          (v2i64 (VBITREV_D v2i64:$vj, v2i64:$vk))>;
1533
1534// VBITREVI_{B/H/W/D}
1535def : Pat<(xor (v16i8 LSX128:$vj), (v16i8 (vsplat_uimm_pow2 uimm3:$imm))),
1536          (VBITREVI_B LSX128:$vj, uimm3:$imm)>;
1537def : Pat<(xor (v8i16 LSX128:$vj), (v8i16 (vsplat_uimm_pow2 uimm4:$imm))),
1538          (VBITREVI_H LSX128:$vj, uimm4:$imm)>;
1539def : Pat<(xor (v4i32 LSX128:$vj), (v4i32 (vsplat_uimm_pow2 uimm5:$imm))),
1540          (VBITREVI_W LSX128:$vj, uimm5:$imm)>;
1541def : Pat<(xor (v2i64 LSX128:$vj), (v2i64 (vsplat_uimm_pow2 uimm6:$imm))),
1542          (VBITREVI_D LSX128:$vj, uimm6:$imm)>;
1543
1544// VFADD_{S/D}
1545defm : PatVrVrF<fadd, "VFADD">;
1546
1547// VFSUB_{S/D}
1548defm : PatVrVrF<fsub, "VFSUB">;
1549
1550// VFMUL_{S/D}
1551defm : PatVrVrF<fmul, "VFMUL">;
1552
1553// VFDIV_{S/D}
1554defm : PatVrVrF<fdiv, "VFDIV">;
1555
1556// VFMADD_{S/D}
1557def : Pat<(fma v4f32:$vj, v4f32:$vk, v4f32:$va),
1558          (VFMADD_S v4f32:$vj, v4f32:$vk, v4f32:$va)>;
1559def : Pat<(fma v2f64:$vj, v2f64:$vk, v2f64:$va),
1560          (VFMADD_D v2f64:$vj, v2f64:$vk, v2f64:$va)>;
1561
1562// VFMSUB_{S/D}
1563def : Pat<(fma v4f32:$vj, v4f32:$vk, (fneg v4f32:$va)),
1564          (VFMSUB_S v4f32:$vj, v4f32:$vk, v4f32:$va)>;
1565def : Pat<(fma v2f64:$vj, v2f64:$vk, (fneg v2f64:$va)),
1566          (VFMSUB_D v2f64:$vj, v2f64:$vk, v2f64:$va)>;
1567
1568// VFNMADD_{S/D}
1569def : Pat<(fneg (fma v4f32:$vj, v4f32:$vk, v4f32:$va)),
1570          (VFNMADD_S v4f32:$vj, v4f32:$vk, v4f32:$va)>;
1571def : Pat<(fneg (fma v2f64:$vj, v2f64:$vk, v2f64:$va)),
1572          (VFNMADD_D v2f64:$vj, v2f64:$vk, v2f64:$va)>;
1573def : Pat<(fma_nsz (fneg v4f32:$vj), v4f32:$vk, (fneg v4f32:$va)),
1574          (VFNMADD_S v4f32:$vj, v4f32:$vk, v4f32:$va)>;
1575def : Pat<(fma_nsz (fneg v2f64:$vj), v2f64:$vk, (fneg v2f64:$va)),
1576          (VFNMADD_D v2f64:$vj, v2f64:$vk, v2f64:$va)>;
1577
1578// VFNMSUB_{S/D}
1579def : Pat<(fneg (fma v4f32:$vj, v4f32:$vk, (fneg v4f32:$va))),
1580          (VFNMSUB_S v4f32:$vj, v4f32:$vk, v4f32:$va)>;
1581def : Pat<(fneg (fma v2f64:$vj, v2f64:$vk, (fneg v2f64:$va))),
1582          (VFNMSUB_D v2f64:$vj, v2f64:$vk, v2f64:$va)>;
1583def : Pat<(fma_nsz (fneg v4f32:$vj), v4f32:$vk, v4f32:$va),
1584          (VFNMSUB_S v4f32:$vj, v4f32:$vk, v4f32:$va)>;
1585def : Pat<(fma_nsz (fneg v2f64:$vj), v2f64:$vk, v2f64:$va),
1586          (VFNMSUB_D v2f64:$vj, v2f64:$vk, v2f64:$va)>;
1587
1588// VFSQRT_{S/D}
1589defm : PatVrF<fsqrt, "VFSQRT">;
1590
1591// VFRECIP_{S/D}
1592def : Pat<(fdiv vsplatf32_fpimm_eq_1, v4f32:$vj),
1593          (VFRECIP_S v4f32:$vj)>;
1594def : Pat<(fdiv vsplatf64_fpimm_eq_1, v2f64:$vj),
1595          (VFRECIP_D v2f64:$vj)>;
1596
1597// VFRSQRT_{S/D}
1598def : Pat<(fdiv vsplatf32_fpimm_eq_1, (fsqrt v4f32:$vj)),
1599          (VFRSQRT_S v4f32:$vj)>;
1600def : Pat<(fdiv vsplatf64_fpimm_eq_1, (fsqrt v2f64:$vj)),
1601          (VFRSQRT_D v2f64:$vj)>;
1602
1603// VSEQ[I]_{B/H/W/D}
1604defm : PatCCVrSimm5<SETEQ, "VSEQI">;
1605defm : PatCCVrVr<SETEQ, "VSEQ">;
1606
1607// VSLE[I]_{B/H/W/D}[U]
1608defm : PatCCVrSimm5<SETLE, "VSLEI">;
1609defm : PatCCVrUimm5<SETULE, "VSLEI">;
1610defm : PatCCVrVr<SETLE, "VSLE">;
1611defm : PatCCVrVrU<SETULE, "VSLE">;
1612
1613// VSLT[I]_{B/H/W/D}[U]
1614defm : PatCCVrSimm5<SETLT, "VSLTI">;
1615defm : PatCCVrUimm5<SETULT, "VSLTI">;
1616defm : PatCCVrVr<SETLT, "VSLT">;
1617defm : PatCCVrVrU<SETULT, "VSLT">;
1618
1619// VFCMP.cond.{S/D}
1620defm : PatCCVrVrF<SETEQ, "VFCMP_CEQ">;
1621defm : PatCCVrVrF<SETOEQ, "VFCMP_CEQ">;
1622defm : PatCCVrVrF<SETUEQ, "VFCMP_CUEQ">;
1623
1624defm : PatCCVrVrF<SETLE, "VFCMP_CLE">;
1625defm : PatCCVrVrF<SETOLE, "VFCMP_CLE">;
1626defm : PatCCVrVrF<SETULE, "VFCMP_CULE">;
1627
1628defm : PatCCVrVrF<SETLT, "VFCMP_CLT">;
1629defm : PatCCVrVrF<SETOLT, "VFCMP_CLT">;
1630defm : PatCCVrVrF<SETULT, "VFCMP_CULT">;
1631
1632defm : PatCCVrVrF<SETNE, "VFCMP_CNE">;
1633defm : PatCCVrVrF<SETONE, "VFCMP_CNE">;
1634defm : PatCCVrVrF<SETUNE, "VFCMP_CUNE">;
1635
1636defm : PatCCVrVrF<SETO, "VFCMP_COR">;
1637defm : PatCCVrVrF<SETUO, "VFCMP_CUN">;
1638
1639// VINSGR2VR_{B/H/W/D}
1640def : Pat<(vector_insert v16i8:$vd, GRLenVT:$rj, uimm4:$imm),
1641          (VINSGR2VR_B v16i8:$vd, GRLenVT:$rj, uimm4:$imm)>;
1642def : Pat<(vector_insert v8i16:$vd, GRLenVT:$rj, uimm3:$imm),
1643          (VINSGR2VR_H v8i16:$vd, GRLenVT:$rj, uimm3:$imm)>;
1644def : Pat<(vector_insert v4i32:$vd, GRLenVT:$rj, uimm2:$imm),
1645          (VINSGR2VR_W v4i32:$vd, GRLenVT:$rj, uimm2:$imm)>;
1646def : Pat<(vector_insert v2i64:$vd, GRLenVT:$rj, uimm1:$imm),
1647          (VINSGR2VR_D v2i64:$vd, GRLenVT:$rj, uimm1:$imm)>;
1648
1649def : Pat<(vector_insert v4f32:$vd, FPR32:$fj, uimm2:$imm),
1650          (VINSGR2VR_W $vd, (COPY_TO_REGCLASS FPR32:$fj, GPR), uimm2:$imm)>;
1651def : Pat<(vector_insert v2f64:$vd, FPR64:$fj, uimm1:$imm),
1652          (VINSGR2VR_D $vd, (COPY_TO_REGCLASS FPR64:$fj, GPR), uimm1:$imm)>;
1653
1654// VPICKVE2GR_{B/H/W}[U]
1655def : Pat<(loongarch_vpick_sext_elt v16i8:$vd, uimm4:$imm, i8),
1656          (VPICKVE2GR_B v16i8:$vd, uimm4:$imm)>;
1657def : Pat<(loongarch_vpick_sext_elt v8i16:$vd, uimm3:$imm, i16),
1658          (VPICKVE2GR_H v8i16:$vd, uimm3:$imm)>;
1659def : Pat<(loongarch_vpick_sext_elt v4i32:$vd, uimm2:$imm, i32),
1660          (VPICKVE2GR_W v4i32:$vd, uimm2:$imm)>;
1661
1662def : Pat<(loongarch_vpick_zext_elt v16i8:$vd, uimm4:$imm, i8),
1663          (VPICKVE2GR_BU v16i8:$vd, uimm4:$imm)>;
1664def : Pat<(loongarch_vpick_zext_elt v8i16:$vd, uimm3:$imm, i16),
1665          (VPICKVE2GR_HU v8i16:$vd, uimm3:$imm)>;
1666def : Pat<(loongarch_vpick_zext_elt v4i32:$vd, uimm2:$imm, i32),
1667          (VPICKVE2GR_WU v4i32:$vd, uimm2:$imm)>;
1668
1669// VREPLGR2VR_{B/H/W/D}
1670def : Pat<(lsxsplati8 GPR:$rj), (VREPLGR2VR_B GPR:$rj)>;
1671def : Pat<(lsxsplati16 GPR:$rj), (VREPLGR2VR_H GPR:$rj)>;
1672def : Pat<(lsxsplati32 GPR:$rj), (VREPLGR2VR_W GPR:$rj)>;
1673def : Pat<(lsxsplati64 GPR:$rj), (VREPLGR2VR_D GPR:$rj)>;
1674
1675// VREPLVE_{B/H/W/D}
1676def : Pat<(loongarch_vreplve v16i8:$vj, GRLenVT:$rk),
1677          (VREPLVE_B v16i8:$vj, GRLenVT:$rk)>;
1678def : Pat<(loongarch_vreplve v8i16:$vj, GRLenVT:$rk),
1679          (VREPLVE_H v8i16:$vj, GRLenVT:$rk)>;
1680def : Pat<(loongarch_vreplve v4i32:$vj, GRLenVT:$rk),
1681          (VREPLVE_W v4i32:$vj, GRLenVT:$rk)>;
1682def : Pat<(loongarch_vreplve v2i64:$vj, GRLenVT:$rk),
1683          (VREPLVE_D v2i64:$vj, GRLenVT:$rk)>;
1684
1685// VREPLVEI_{W/D}
1686def : Pat<(lsxsplatf32 FPR32:$fj),
1687          (VREPLVEI_W (SUBREG_TO_REG (i64 0), FPR32:$fj, sub_32), 0)>;
1688def : Pat<(lsxsplatf64 FPR64:$fj),
1689          (VREPLVEI_D (SUBREG_TO_REG (i64 0), FPR64:$fj, sub_64), 0)>;
1690
1691// Loads/Stores
1692foreach vt = [v16i8, v8i16, v4i32, v2i64, v4f32, v2f64] in {
1693  defm : LdPat<load, VLD, vt>;
1694  def  : RegRegLdPat<load, VLDX, vt>;
1695  defm : StPat<store, VST, LSX128, vt>;
1696  def  : RegRegStPat<store, VSTX, LSX128, vt>;
1697}
1698
1699// Vector extraction with constant index.
1700def : Pat<(i64 (vector_extract v16i8:$vj, uimm4:$imm)),
1701          (VPICKVE2GR_B v16i8:$vj, uimm4:$imm)>;
1702def : Pat<(i64 (vector_extract v8i16:$vj, uimm3:$imm)),
1703          (VPICKVE2GR_H v8i16:$vj, uimm3:$imm)>;
1704def : Pat<(i64 (vector_extract v4i32:$vj, uimm2:$imm)),
1705          (VPICKVE2GR_W v4i32:$vj, uimm2:$imm)>;
1706def : Pat<(i64 (vector_extract v2i64:$vj, uimm1:$imm)),
1707          (VPICKVE2GR_D v2i64:$vj, uimm1:$imm)>;
1708def : Pat<(f32 (vector_extract v4f32:$vj, uimm2:$imm)),
1709          (f32 (EXTRACT_SUBREG (VREPLVEI_W v4f32:$vj, uimm2:$imm), sub_32))>;
1710def : Pat<(f64 (vector_extract v2f64:$vj, uimm1:$imm)),
1711          (f64 (EXTRACT_SUBREG (VREPLVEI_D v2f64:$vj, uimm1:$imm), sub_64))>;
1712
1713// Vector extraction with variable index.
1714def : Pat<(i64 (vector_extract v16i8:$vj, i64:$rk)),
1715          (SRAI_W (COPY_TO_REGCLASS (f32 (EXTRACT_SUBREG (VREPLVE_B v16i8:$vj,
1716                                                                    i64:$rk),
1717                                                         sub_32)),
1718                                    GPR), (i64 24))>;
1719def : Pat<(i64 (vector_extract v8i16:$vj, i64:$rk)),
1720          (SRAI_W (COPY_TO_REGCLASS (f32 (EXTRACT_SUBREG (VREPLVE_H v8i16:$vj,
1721                                                                    i64:$rk),
1722                                                         sub_32)),
1723                                    GPR), (i64 16))>;
1724def : Pat<(i64 (vector_extract v4i32:$vj, i64:$rk)),
1725          (COPY_TO_REGCLASS (f32 (EXTRACT_SUBREG (VREPLVE_W v4i32:$vj, i64:$rk),
1726                                                 sub_32)),
1727                            GPR)>;
1728def : Pat<(i64 (vector_extract v2i64:$vj, i64:$rk)),
1729          (COPY_TO_REGCLASS (f64 (EXTRACT_SUBREG (VREPLVE_D v2i64:$vj, i64:$rk),
1730                                                 sub_64)),
1731                            GPR)>;
1732def : Pat<(f32 (vector_extract v4f32:$vj, i64:$rk)),
1733          (f32 (EXTRACT_SUBREG (VREPLVE_W v4f32:$vj, i64:$rk), sub_32))>;
1734def : Pat<(f64 (vector_extract v2f64:$vj, i64:$rk)),
1735          (f64 (EXTRACT_SUBREG (VREPLVE_D v2f64:$vj, i64:$rk), sub_64))>;
1736
1737// vselect
1738def : Pat<(v16i8 (vselect LSX128:$vd, (v16i8 (SplatPat_uimm8 uimm8:$imm)),
1739                          LSX128:$vj)),
1740          (VBITSELI_B LSX128:$vd, LSX128:$vj, uimm8:$imm)>;
1741foreach vt = [v16i8, v8i16, v4i32, v2i64, v4f32, v2f64] in
1742  def  : Pat<(vt (vselect LSX128:$va, LSX128:$vk, LSX128:$vj)),
1743             (VBITSEL_V LSX128:$vj, LSX128:$vk, LSX128:$va)>;
1744
1745// fneg
1746def : Pat<(fneg (v4f32 LSX128:$vj)), (VBITREVI_W LSX128:$vj, 31)>;
1747def : Pat<(fneg (v2f64 LSX128:$vj)), (VBITREVI_D LSX128:$vj, 63)>;
1748
1749// VFFINT_{S_W/D_L}
1750def : Pat<(v4f32 (sint_to_fp v4i32:$vj)), (VFFINT_S_W v4i32:$vj)>;
1751def : Pat<(v2f64 (sint_to_fp v2i64:$vj)), (VFFINT_D_L v2i64:$vj)>;
1752
1753// VFFINT_{S_WU/D_LU}
1754def : Pat<(v4f32 (uint_to_fp v4i32:$vj)), (VFFINT_S_WU v4i32:$vj)>;
1755def : Pat<(v2f64 (uint_to_fp v2i64:$vj)), (VFFINT_D_LU v2i64:$vj)>;
1756
1757// VFTINTRZ_{W_S/L_D}
1758def : Pat<(v4i32 (fp_to_sint v4f32:$vj)), (VFTINTRZ_W_S v4f32:$vj)>;
1759def : Pat<(v2i64 (fp_to_sint v2f64:$vj)), (VFTINTRZ_L_D v2f64:$vj)>;
1760
1761// VFTINTRZ_{W_SU/L_DU}
1762def : Pat<(v4i32 (fp_to_uint v4f32:$vj)), (VFTINTRZ_WU_S v4f32:$vj)>;
1763def : Pat<(v2i64 (fp_to_uint v2f64:$vj)), (VFTINTRZ_LU_D v2f64:$vj)>;
1764
1765} // Predicates = [HasExtLSX]
1766
1767/// Intrinsic pattern
1768
1769class deriveLSXIntrinsic<string Inst> {
1770  Intrinsic ret = !cast<Intrinsic>(!tolower("int_loongarch_lsx_"#Inst));
1771}
1772
1773let Predicates = [HasExtLSX] in {
1774
1775// vty: v16i8/v8i16/v4i32/v2i64
1776// Pat<(Intrinsic vty:$vj, vty:$vk),
1777//     (LAInst vty:$vj, vty:$vk)>;
1778foreach Inst = ["VSADD_B", "VSADD_BU", "VSSUB_B", "VSSUB_BU",
1779                "VHADDW_H_B", "VHADDW_HU_BU", "VHSUBW_H_B", "VHSUBW_HU_BU",
1780                "VADDWEV_H_B", "VADDWOD_H_B", "VSUBWEV_H_B", "VSUBWOD_H_B",
1781                "VADDWEV_H_BU", "VADDWOD_H_BU", "VSUBWEV_H_BU", "VSUBWOD_H_BU",
1782                "VADDWEV_H_BU_B", "VADDWOD_H_BU_B",
1783                "VAVG_B", "VAVG_BU", "VAVGR_B", "VAVGR_BU",
1784                "VABSD_B", "VABSD_BU", "VADDA_B", "VMUH_B", "VMUH_BU",
1785                "VMULWEV_H_B", "VMULWOD_H_B", "VMULWEV_H_BU", "VMULWOD_H_BU",
1786                "VMULWEV_H_BU_B", "VMULWOD_H_BU_B", "VSIGNCOV_B",
1787                "VANDN_V", "VORN_V", "VROTR_B", "VSRLR_B", "VSRAR_B",
1788                "VSEQ_B", "VSLE_B", "VSLE_BU", "VSLT_B", "VSLT_BU",
1789                "VPACKEV_B", "VPACKOD_B", "VPICKEV_B", "VPICKOD_B",
1790                "VILVL_B", "VILVH_B"] in
1791  def : Pat<(deriveLSXIntrinsic<Inst>.ret
1792               (v16i8 LSX128:$vj), (v16i8 LSX128:$vk)),
1793            (!cast<LAInst>(Inst) LSX128:$vj, LSX128:$vk)>;
1794foreach Inst = ["VSADD_H", "VSADD_HU", "VSSUB_H", "VSSUB_HU",
1795                "VHADDW_W_H", "VHADDW_WU_HU", "VHSUBW_W_H", "VHSUBW_WU_HU",
1796                "VADDWEV_W_H", "VADDWOD_W_H", "VSUBWEV_W_H", "VSUBWOD_W_H",
1797                "VADDWEV_W_HU", "VADDWOD_W_HU", "VSUBWEV_W_HU", "VSUBWOD_W_HU",
1798                "VADDWEV_W_HU_H", "VADDWOD_W_HU_H",
1799                "VAVG_H", "VAVG_HU", "VAVGR_H", "VAVGR_HU",
1800                "VABSD_H", "VABSD_HU", "VADDA_H", "VMUH_H", "VMUH_HU",
1801                "VMULWEV_W_H", "VMULWOD_W_H", "VMULWEV_W_HU", "VMULWOD_W_HU",
1802                "VMULWEV_W_HU_H", "VMULWOD_W_HU_H", "VSIGNCOV_H", "VROTR_H",
1803                "VSRLR_H", "VSRAR_H", "VSRLN_B_H", "VSRAN_B_H", "VSRLRN_B_H",
1804                "VSRARN_B_H", "VSSRLN_B_H", "VSSRAN_B_H", "VSSRLN_BU_H",
1805                "VSSRAN_BU_H", "VSSRLRN_B_H", "VSSRARN_B_H", "VSSRLRN_BU_H",
1806                "VSSRARN_BU_H",
1807                "VSEQ_H", "VSLE_H", "VSLE_HU", "VSLT_H", "VSLT_HU",
1808                "VPACKEV_H", "VPACKOD_H", "VPICKEV_H", "VPICKOD_H",
1809                "VILVL_H", "VILVH_H"] in
1810  def : Pat<(deriveLSXIntrinsic<Inst>.ret
1811               (v8i16 LSX128:$vj), (v8i16 LSX128:$vk)),
1812            (!cast<LAInst>(Inst) LSX128:$vj, LSX128:$vk)>;
1813foreach Inst = ["VSADD_W", "VSADD_WU", "VSSUB_W", "VSSUB_WU",
1814                "VHADDW_D_W", "VHADDW_DU_WU", "VHSUBW_D_W", "VHSUBW_DU_WU",
1815                "VADDWEV_D_W", "VADDWOD_D_W", "VSUBWEV_D_W", "VSUBWOD_D_W",
1816                "VADDWEV_D_WU", "VADDWOD_D_WU", "VSUBWEV_D_WU", "VSUBWOD_D_WU",
1817                "VADDWEV_D_WU_W", "VADDWOD_D_WU_W",
1818                "VAVG_W", "VAVG_WU", "VAVGR_W", "VAVGR_WU",
1819                "VABSD_W", "VABSD_WU", "VADDA_W", "VMUH_W", "VMUH_WU",
1820                "VMULWEV_D_W", "VMULWOD_D_W", "VMULWEV_D_WU", "VMULWOD_D_WU",
1821                "VMULWEV_D_WU_W", "VMULWOD_D_WU_W", "VSIGNCOV_W", "VROTR_W",
1822                "VSRLR_W", "VSRAR_W", "VSRLN_H_W", "VSRAN_H_W", "VSRLRN_H_W",
1823                "VSRARN_H_W", "VSSRLN_H_W", "VSSRAN_H_W", "VSSRLN_HU_W",
1824                "VSSRAN_HU_W", "VSSRLRN_H_W", "VSSRARN_H_W", "VSSRLRN_HU_W",
1825                "VSSRARN_HU_W",
1826                "VSEQ_W", "VSLE_W", "VSLE_WU", "VSLT_W", "VSLT_WU",
1827                "VPACKEV_W", "VPACKOD_W", "VPICKEV_W", "VPICKOD_W",
1828                "VILVL_W", "VILVH_W"] in
1829  def : Pat<(deriveLSXIntrinsic<Inst>.ret
1830               (v4i32 LSX128:$vj), (v4i32 LSX128:$vk)),
1831            (!cast<LAInst>(Inst) LSX128:$vj, LSX128:$vk)>;
1832foreach Inst = ["VADD_Q", "VSUB_Q",
1833                "VSADD_D", "VSADD_DU", "VSSUB_D", "VSSUB_DU",
1834                "VHADDW_Q_D", "VHADDW_QU_DU", "VHSUBW_Q_D", "VHSUBW_QU_DU",
1835                "VADDWEV_Q_D", "VADDWOD_Q_D", "VSUBWEV_Q_D", "VSUBWOD_Q_D",
1836                "VADDWEV_Q_DU", "VADDWOD_Q_DU", "VSUBWEV_Q_DU", "VSUBWOD_Q_DU",
1837                "VADDWEV_Q_DU_D", "VADDWOD_Q_DU_D",
1838                "VAVG_D", "VAVG_DU", "VAVGR_D", "VAVGR_DU",
1839                "VABSD_D", "VABSD_DU", "VADDA_D", "VMUH_D", "VMUH_DU",
1840                "VMULWEV_Q_D", "VMULWOD_Q_D", "VMULWEV_Q_DU", "VMULWOD_Q_DU",
1841                "VMULWEV_Q_DU_D", "VMULWOD_Q_DU_D", "VSIGNCOV_D", "VROTR_D",
1842                "VSRLR_D", "VSRAR_D", "VSRLN_W_D", "VSRAN_W_D", "VSRLRN_W_D",
1843                "VSRARN_W_D", "VSSRLN_W_D", "VSSRAN_W_D", "VSSRLN_WU_D",
1844                "VSSRAN_WU_D", "VSSRLRN_W_D", "VSSRARN_W_D", "VSSRLRN_WU_D",
1845                "VSSRARN_WU_D", "VFFINT_S_L",
1846                "VSEQ_D", "VSLE_D", "VSLE_DU", "VSLT_D", "VSLT_DU",
1847                "VPACKEV_D", "VPACKOD_D", "VPICKEV_D", "VPICKOD_D",
1848                "VILVL_D", "VILVH_D"] in
1849  def : Pat<(deriveLSXIntrinsic<Inst>.ret
1850               (v2i64 LSX128:$vj), (v2i64 LSX128:$vk)),
1851            (!cast<LAInst>(Inst) LSX128:$vj, LSX128:$vk)>;
1852
1853// vty: v16i8/v8i16/v4i32/v2i64
1854// Pat<(Intrinsic vty:$vd, vty:$vj, vty:$vk),
1855//     (LAInst vty:$vd, vty:$vj, vty:$vk)>;
1856foreach Inst = ["VMADDWEV_H_B", "VMADDWOD_H_B", "VMADDWEV_H_BU",
1857                "VMADDWOD_H_BU", "VMADDWEV_H_BU_B", "VMADDWOD_H_BU_B"] in
1858  def : Pat<(deriveLSXIntrinsic<Inst>.ret
1859               (v8i16 LSX128:$vd), (v16i8 LSX128:$vj), (v16i8 LSX128:$vk)),
1860            (!cast<LAInst>(Inst) LSX128:$vd, LSX128:$vj, LSX128:$vk)>;
1861foreach Inst = ["VMADDWEV_W_H", "VMADDWOD_W_H", "VMADDWEV_W_HU",
1862                "VMADDWOD_W_HU", "VMADDWEV_W_HU_H", "VMADDWOD_W_HU_H"] in
1863  def : Pat<(deriveLSXIntrinsic<Inst>.ret
1864               (v4i32 LSX128:$vd), (v8i16 LSX128:$vj), (v8i16 LSX128:$vk)),
1865            (!cast<LAInst>(Inst) LSX128:$vd, LSX128:$vj, LSX128:$vk)>;
1866foreach Inst = ["VMADDWEV_D_W", "VMADDWOD_D_W", "VMADDWEV_D_WU",
1867                "VMADDWOD_D_WU", "VMADDWEV_D_WU_W", "VMADDWOD_D_WU_W"] in
1868  def : Pat<(deriveLSXIntrinsic<Inst>.ret
1869               (v2i64 LSX128:$vd), (v4i32 LSX128:$vj), (v4i32 LSX128:$vk)),
1870            (!cast<LAInst>(Inst) LSX128:$vd, LSX128:$vj, LSX128:$vk)>;
1871foreach Inst = ["VMADDWEV_Q_D", "VMADDWOD_Q_D", "VMADDWEV_Q_DU",
1872                "VMADDWOD_Q_DU", "VMADDWEV_Q_DU_D", "VMADDWOD_Q_DU_D"] in
1873  def : Pat<(deriveLSXIntrinsic<Inst>.ret
1874               (v2i64 LSX128:$vd), (v2i64 LSX128:$vj), (v2i64 LSX128:$vk)),
1875            (!cast<LAInst>(Inst) LSX128:$vd, LSX128:$vj, LSX128:$vk)>;
1876
1877// vty: v16i8/v8i16/v4i32/v2i64
1878// Pat<(Intrinsic vty:$vj),
1879//     (LAInst vty:$vj)>;
1880foreach Inst = ["VEXTH_H_B", "VEXTH_HU_BU",
1881                "VMSKLTZ_B", "VMSKGEZ_B", "VMSKNZ_B",
1882                "VCLO_B"] in
1883  def : Pat<(deriveLSXIntrinsic<Inst>.ret (v16i8 LSX128:$vj)),
1884            (!cast<LAInst>(Inst) LSX128:$vj)>;
1885foreach Inst = ["VEXTH_W_H", "VEXTH_WU_HU", "VMSKLTZ_H",
1886                "VCLO_H", "VFCVTL_S_H", "VFCVTH_S_H"] in
1887  def : Pat<(deriveLSXIntrinsic<Inst>.ret (v8i16 LSX128:$vj)),
1888            (!cast<LAInst>(Inst) LSX128:$vj)>;
1889foreach Inst = ["VEXTH_D_W", "VEXTH_DU_WU", "VMSKLTZ_W",
1890                "VCLO_W", "VFFINT_S_W", "VFFINT_S_WU",
1891                "VFFINTL_D_W", "VFFINTH_D_W"] in
1892  def : Pat<(deriveLSXIntrinsic<Inst>.ret (v4i32 LSX128:$vj)),
1893            (!cast<LAInst>(Inst) LSX128:$vj)>;
1894foreach Inst = ["VEXTH_Q_D", "VEXTH_QU_DU", "VMSKLTZ_D",
1895                "VEXTL_Q_D", "VEXTL_QU_DU",
1896                "VCLO_D", "VFFINT_D_L", "VFFINT_D_LU"] in
1897  def : Pat<(deriveLSXIntrinsic<Inst>.ret (v2i64 LSX128:$vj)),
1898            (!cast<LAInst>(Inst) LSX128:$vj)>;
1899
1900// Pat<(Intrinsic timm:$imm)
1901//     (LAInst timm:$imm)>;
1902def : Pat<(int_loongarch_lsx_vldi timm:$imm),
1903          (VLDI (to_valid_timm timm:$imm))>;
1904foreach Inst = ["VREPLI_B", "VREPLI_H", "VREPLI_W", "VREPLI_D"] in
1905  def : Pat<(deriveLSXIntrinsic<Inst>.ret timm:$imm),
1906            (!cast<LAInst>("Pseudo"#Inst) (to_valid_timm timm:$imm))>;
1907
1908// vty: v16i8/v8i16/v4i32/v2i64
1909// Pat<(Intrinsic vty:$vj, timm:$imm)
1910//     (LAInst vty:$vj, timm:$imm)>;
1911foreach Inst = ["VSAT_B", "VSAT_BU", "VNORI_B", "VROTRI_B", "VSLLWIL_H_B",
1912                "VSLLWIL_HU_BU", "VSRLRI_B", "VSRARI_B",
1913                "VSEQI_B", "VSLEI_B", "VSLEI_BU", "VSLTI_B", "VSLTI_BU",
1914                "VREPLVEI_B", "VBSLL_V", "VBSRL_V", "VSHUF4I_B"] in
1915  def : Pat<(deriveLSXIntrinsic<Inst>.ret (v16i8 LSX128:$vj), timm:$imm),
1916            (!cast<LAInst>(Inst) LSX128:$vj, (to_valid_timm timm:$imm))>;
1917foreach Inst = ["VSAT_H", "VSAT_HU", "VROTRI_H", "VSLLWIL_W_H",
1918                "VSLLWIL_WU_HU", "VSRLRI_H", "VSRARI_H",
1919                "VSEQI_H", "VSLEI_H", "VSLEI_HU", "VSLTI_H", "VSLTI_HU",
1920                "VREPLVEI_H", "VSHUF4I_H"] in
1921  def : Pat<(deriveLSXIntrinsic<Inst>.ret (v8i16 LSX128:$vj), timm:$imm),
1922            (!cast<LAInst>(Inst) LSX128:$vj, (to_valid_timm timm:$imm))>;
1923foreach Inst = ["VSAT_W", "VSAT_WU", "VROTRI_W", "VSLLWIL_D_W",
1924                "VSLLWIL_DU_WU", "VSRLRI_W", "VSRARI_W",
1925                "VSEQI_W", "VSLEI_W", "VSLEI_WU", "VSLTI_W", "VSLTI_WU",
1926                "VREPLVEI_W", "VSHUF4I_W"] in
1927  def : Pat<(deriveLSXIntrinsic<Inst>.ret (v4i32 LSX128:$vj), timm:$imm),
1928            (!cast<LAInst>(Inst) LSX128:$vj, (to_valid_timm timm:$imm))>;
1929foreach Inst = ["VSAT_D", "VSAT_DU", "VROTRI_D", "VSRLRI_D", "VSRARI_D",
1930                "VSEQI_D", "VSLEI_D", "VSLEI_DU", "VSLTI_D", "VSLTI_DU",
1931                "VPICKVE2GR_D", "VPICKVE2GR_DU",
1932                "VREPLVEI_D"] in
1933  def : Pat<(deriveLSXIntrinsic<Inst>.ret (v2i64 LSX128:$vj), timm:$imm),
1934            (!cast<LAInst>(Inst) LSX128:$vj, (to_valid_timm timm:$imm))>;
1935
1936// vty: v16i8/v8i16/v4i32/v2i64
1937// Pat<(Intrinsic vty:$vd, vty:$vj, timm:$imm)
1938//     (LAInst vty:$vd, vty:$vj, timm:$imm)>;
1939foreach Inst = ["VSRLNI_B_H", "VSRANI_B_H", "VSRLRNI_B_H", "VSRARNI_B_H",
1940                "VSSRLNI_B_H", "VSSRANI_B_H", "VSSRLNI_BU_H", "VSSRANI_BU_H",
1941                "VSSRLRNI_B_H", "VSSRARNI_B_H", "VSSRLRNI_BU_H", "VSSRARNI_BU_H",
1942                "VFRSTPI_B", "VBITSELI_B", "VEXTRINS_B"] in
1943  def : Pat<(deriveLSXIntrinsic<Inst>.ret
1944               (v16i8 LSX128:$vd), (v16i8 LSX128:$vj), timm:$imm),
1945            (!cast<LAInst>(Inst) LSX128:$vd, LSX128:$vj,
1946               (to_valid_timm timm:$imm))>;
1947foreach Inst = ["VSRLNI_H_W", "VSRANI_H_W", "VSRLRNI_H_W", "VSRARNI_H_W",
1948                "VSSRLNI_H_W", "VSSRANI_H_W", "VSSRLNI_HU_W", "VSSRANI_HU_W",
1949                "VSSRLRNI_H_W", "VSSRARNI_H_W", "VSSRLRNI_HU_W", "VSSRARNI_HU_W",
1950                "VFRSTPI_H", "VEXTRINS_H"] in
1951  def : Pat<(deriveLSXIntrinsic<Inst>.ret
1952               (v8i16 LSX128:$vd), (v8i16 LSX128:$vj), timm:$imm),
1953            (!cast<LAInst>(Inst) LSX128:$vd, LSX128:$vj,
1954               (to_valid_timm timm:$imm))>;
1955foreach Inst = ["VSRLNI_W_D", "VSRANI_W_D", "VSRLRNI_W_D", "VSRARNI_W_D",
1956                "VSSRLNI_W_D", "VSSRANI_W_D", "VSSRLNI_WU_D", "VSSRANI_WU_D",
1957                "VSSRLRNI_W_D", "VSSRARNI_W_D", "VSSRLRNI_WU_D", "VSSRARNI_WU_D",
1958                "VPERMI_W", "VEXTRINS_W"] in
1959  def : Pat<(deriveLSXIntrinsic<Inst>.ret
1960               (v4i32 LSX128:$vd), (v4i32 LSX128:$vj), timm:$imm),
1961            (!cast<LAInst>(Inst) LSX128:$vd, LSX128:$vj,
1962               (to_valid_timm timm:$imm))>;
1963foreach Inst = ["VSRLNI_D_Q", "VSRANI_D_Q", "VSRLRNI_D_Q", "VSRARNI_D_Q",
1964                "VSSRLNI_D_Q", "VSSRANI_D_Q", "VSSRLNI_DU_Q", "VSSRANI_DU_Q",
1965                "VSSRLRNI_D_Q", "VSSRARNI_D_Q", "VSSRLRNI_DU_Q", "VSSRARNI_DU_Q",
1966                "VSHUF4I_D", "VEXTRINS_D"] in
1967  def : Pat<(deriveLSXIntrinsic<Inst>.ret
1968               (v2i64 LSX128:$vd), (v2i64 LSX128:$vj), timm:$imm),
1969            (!cast<LAInst>(Inst) LSX128:$vd, LSX128:$vj,
1970               (to_valid_timm timm:$imm))>;
1971
1972// vty: v16i8/v8i16/v4i32/v2i64
1973// Pat<(Intrinsic vty:$vd, vty:$vj, vty:$vk),
1974//     (LAInst vty:$vd, vty:$vj, vty:$vk)>;
1975foreach Inst = ["VFRSTP_B", "VBITSEL_V", "VSHUF_B"] in
1976  def : Pat<(deriveLSXIntrinsic<Inst>.ret
1977               (v16i8 LSX128:$vd), (v16i8 LSX128:$vj), (v16i8 LSX128:$vk)),
1978            (!cast<LAInst>(Inst) LSX128:$vd, LSX128:$vj, LSX128:$vk)>;
1979foreach Inst = ["VFRSTP_H", "VSHUF_H"] in
1980  def : Pat<(deriveLSXIntrinsic<Inst>.ret
1981               (v8i16 LSX128:$vd), (v8i16 LSX128:$vj), (v8i16 LSX128:$vk)),
1982            (!cast<LAInst>(Inst) LSX128:$vd, LSX128:$vj, LSX128:$vk)>;
1983def : Pat<(int_loongarch_lsx_vshuf_w (v4i32 LSX128:$vd), (v4i32 LSX128:$vj),
1984                                     (v4i32 LSX128:$vk)),
1985          (VSHUF_W LSX128:$vd, LSX128:$vj, LSX128:$vk)>;
1986def : Pat<(int_loongarch_lsx_vshuf_d (v2i64 LSX128:$vd), (v2i64 LSX128:$vj),
1987                                     (v2i64 LSX128:$vk)),
1988          (VSHUF_D LSX128:$vd, LSX128:$vj, LSX128:$vk)>;
1989
1990// vty: v4f32/v2f64
1991// Pat<(Intrinsic vty:$vj, vty:$vk, vty:$va),
1992//     (LAInst vty:$vj, vty:$vk, vty:$va)>;
1993foreach Inst = ["VFMSUB_S", "VFNMADD_S", "VFNMSUB_S"] in
1994  def : Pat<(deriveLSXIntrinsic<Inst>.ret
1995               (v4f32 LSX128:$vj), (v4f32 LSX128:$vk), (v4f32 LSX128:$va)),
1996            (!cast<LAInst>(Inst) LSX128:$vj, LSX128:$vk, LSX128:$va)>;
1997foreach Inst = ["VFMSUB_D", "VFNMADD_D", "VFNMSUB_D"] in
1998  def : Pat<(deriveLSXIntrinsic<Inst>.ret
1999               (v2f64 LSX128:$vj), (v2f64 LSX128:$vk), (v2f64 LSX128:$va)),
2000            (!cast<LAInst>(Inst) LSX128:$vj, LSX128:$vk, LSX128:$va)>;
2001
2002// vty: v4f32/v2f64
2003// Pat<(Intrinsic vty:$vj, vty:$vk),
2004//     (LAInst vty:$vj, vty:$vk)>;
2005foreach Inst = ["VFMAX_S", "VFMIN_S", "VFMAXA_S", "VFMINA_S", "VFCVT_H_S",
2006                "VFCMP_CAF_S", "VFCMP_CUN_S", "VFCMP_CEQ_S", "VFCMP_CUEQ_S",
2007                "VFCMP_CLT_S", "VFCMP_CULT_S", "VFCMP_CLE_S", "VFCMP_CULE_S",
2008                "VFCMP_CNE_S", "VFCMP_COR_S", "VFCMP_CUNE_S",
2009                "VFCMP_SAF_S", "VFCMP_SUN_S", "VFCMP_SEQ_S", "VFCMP_SUEQ_S",
2010                "VFCMP_SLT_S", "VFCMP_SULT_S", "VFCMP_SLE_S", "VFCMP_SULE_S",
2011                "VFCMP_SNE_S", "VFCMP_SOR_S", "VFCMP_SUNE_S"] in
2012  def : Pat<(deriveLSXIntrinsic<Inst>.ret
2013               (v4f32 LSX128:$vj), (v4f32 LSX128:$vk)),
2014            (!cast<LAInst>(Inst) LSX128:$vj, LSX128:$vk)>;
2015foreach Inst = ["VFMAX_D", "VFMIN_D", "VFMAXA_D", "VFMINA_D", "VFCVT_S_D",
2016                "VFTINTRNE_W_D", "VFTINTRZ_W_D", "VFTINTRP_W_D", "VFTINTRM_W_D",
2017                "VFTINT_W_D",
2018                "VFCMP_CAF_D", "VFCMP_CUN_D", "VFCMP_CEQ_D", "VFCMP_CUEQ_D",
2019                "VFCMP_CLT_D", "VFCMP_CULT_D", "VFCMP_CLE_D", "VFCMP_CULE_D",
2020                "VFCMP_CNE_D", "VFCMP_COR_D", "VFCMP_CUNE_D",
2021                "VFCMP_SAF_D", "VFCMP_SUN_D", "VFCMP_SEQ_D", "VFCMP_SUEQ_D",
2022                "VFCMP_SLT_D", "VFCMP_SULT_D", "VFCMP_SLE_D", "VFCMP_SULE_D",
2023                "VFCMP_SNE_D", "VFCMP_SOR_D", "VFCMP_SUNE_D"] in
2024  def : Pat<(deriveLSXIntrinsic<Inst>.ret
2025               (v2f64 LSX128:$vj), (v2f64 LSX128:$vk)),
2026            (!cast<LAInst>(Inst) LSX128:$vj, LSX128:$vk)>;
2027
2028// vty: v4f32/v2f64
2029// Pat<(Intrinsic vty:$vj),
2030//     (LAInst vty:$vj)>;
2031foreach Inst = ["VFLOGB_S", "VFCLASS_S", "VFSQRT_S", "VFRECIP_S", "VFRSQRT_S",
2032                "VFRINT_S", "VFCVTL_D_S", "VFCVTH_D_S",
2033                "VFRINTRNE_S", "VFRINTRZ_S", "VFRINTRP_S", "VFRINTRM_S",
2034                "VFTINTRNE_W_S", "VFTINTRZ_W_S", "VFTINTRP_W_S", "VFTINTRM_W_S",
2035                "VFTINT_W_S", "VFTINTRZ_WU_S", "VFTINT_WU_S",
2036                "VFTINTRNEL_L_S", "VFTINTRNEH_L_S", "VFTINTRZL_L_S",
2037                "VFTINTRZH_L_S", "VFTINTRPL_L_S", "VFTINTRPH_L_S",
2038                "VFTINTRML_L_S", "VFTINTRMH_L_S", "VFTINTL_L_S",
2039                "VFTINTH_L_S"] in
2040  def : Pat<(deriveLSXIntrinsic<Inst>.ret (v4f32 LSX128:$vj)),
2041            (!cast<LAInst>(Inst) LSX128:$vj)>;
2042foreach Inst = ["VFLOGB_D", "VFCLASS_D", "VFSQRT_D", "VFRECIP_D", "VFRSQRT_D",
2043                "VFRINT_D",
2044                "VFRINTRNE_D", "VFRINTRZ_D", "VFRINTRP_D", "VFRINTRM_D",
2045                "VFTINTRNE_L_D", "VFTINTRZ_L_D", "VFTINTRP_L_D", "VFTINTRM_L_D",
2046                "VFTINT_L_D", "VFTINTRZ_LU_D", "VFTINT_LU_D"] in
2047  def : Pat<(deriveLSXIntrinsic<Inst>.ret (v2f64 LSX128:$vj)),
2048            (!cast<LAInst>(Inst) LSX128:$vj)>;
2049
2050// 128-Bit vector FP approximate reciprocal operation
2051let Predicates = [HasFrecipe] in {
2052foreach Inst = ["VFRECIPE_S", "VFRSQRTE_S"] in
2053  def : Pat<(deriveLSXIntrinsic<Inst>.ret (v4f32 LSX128:$vj)),
2054            (!cast<LAInst>(Inst) LSX128:$vj)>;
2055foreach Inst = ["VFRECIPE_D", "VFRSQRTE_D"] in
2056  def : Pat<(deriveLSXIntrinsic<Inst>.ret (v2f64 LSX128:$vj)),
2057            (!cast<LAInst>(Inst) LSX128:$vj)>;
2058}
2059
2060// load
2061def : Pat<(int_loongarch_lsx_vld GPR:$rj, timm:$imm),
2062          (VLD GPR:$rj, (to_valid_timm timm:$imm))>;
2063def : Pat<(int_loongarch_lsx_vldx GPR:$rj, GPR:$rk),
2064          (VLDX GPR:$rj, GPR:$rk)>;
2065
2066def : Pat<(int_loongarch_lsx_vldrepl_b GPR:$rj, timm:$imm),
2067          (VLDREPL_B GPR:$rj, (to_valid_timm timm:$imm))>;
2068def : Pat<(int_loongarch_lsx_vldrepl_h GPR:$rj, timm:$imm),
2069          (VLDREPL_H GPR:$rj, (to_valid_timm timm:$imm))>;
2070def : Pat<(int_loongarch_lsx_vldrepl_w GPR:$rj, timm:$imm),
2071          (VLDREPL_W GPR:$rj, (to_valid_timm timm:$imm))>;
2072def : Pat<(int_loongarch_lsx_vldrepl_d GPR:$rj, timm:$imm),
2073          (VLDREPL_D GPR:$rj, (to_valid_timm timm:$imm))>;
2074
2075// store
2076def : Pat<(int_loongarch_lsx_vst LSX128:$vd, GPR:$rj, timm:$imm),
2077          (VST LSX128:$vd, GPR:$rj, (to_valid_timm timm:$imm))>;
2078def : Pat<(int_loongarch_lsx_vstx LSX128:$vd, GPR:$rj, GPR:$rk),
2079          (VSTX LSX128:$vd, GPR:$rj, GPR:$rk)>;
2080
2081def : Pat<(int_loongarch_lsx_vstelm_b v16i8:$vd, GPR:$rj, timm:$imm, timm:$idx),
2082          (VSTELM_B v16i8:$vd, GPR:$rj, (to_valid_timm timm:$imm),
2083                    (to_valid_timm timm:$idx))>;
2084def : Pat<(int_loongarch_lsx_vstelm_h v8i16:$vd, GPR:$rj, timm:$imm, timm:$idx),
2085          (VSTELM_H v8i16:$vd, GPR:$rj, (to_valid_timm timm:$imm),
2086                    (to_valid_timm timm:$idx))>;
2087def : Pat<(int_loongarch_lsx_vstelm_w v4i32:$vd, GPR:$rj, timm:$imm, timm:$idx),
2088          (VSTELM_W v4i32:$vd, GPR:$rj, (to_valid_timm timm:$imm),
2089                    (to_valid_timm timm:$idx))>;
2090def : Pat<(int_loongarch_lsx_vstelm_d v2i64:$vd, GPR:$rj, timm:$imm, timm:$idx),
2091          (VSTELM_D v2i64:$vd, GPR:$rj, (to_valid_timm timm:$imm),
2092                    (to_valid_timm timm:$idx))>;
2093
2094} // Predicates = [HasExtLSX]
2095