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