1//===- MipsMSAInstrInfo.td - MSA ASE instructions -*- tablegen ------------*-=// 2// 3// The LLVM Compiler Infrastructure 4// 5// This file is distributed under the University of Illinois Open Source 6// License. See LICENSE.TXT for details. 7// 8//===----------------------------------------------------------------------===// 9// 10// This file describes Mips MSA ASE instructions. 11// 12//===----------------------------------------------------------------------===// 13 14def SDT_MipsVecCond : SDTypeProfile<1, 1, [SDTCisInt<0>, SDTCisVec<1>]>; 15def SDT_VSetCC : SDTypeProfile<1, 3, [SDTCisInt<0>, 16 SDTCisInt<1>, 17 SDTCisSameAs<1, 2>, 18 SDTCisVT<3, OtherVT>]>; 19def SDT_VFSetCC : SDTypeProfile<1, 3, [SDTCisInt<0>, 20 SDTCisFP<1>, 21 SDTCisSameAs<1, 2>, 22 SDTCisVT<3, OtherVT>]>; 23def SDT_VSHF : SDTypeProfile<1, 3, [SDTCisInt<0>, SDTCisVec<0>, 24 SDTCisInt<1>, SDTCisVec<1>, 25 SDTCisSameAs<0, 2>, SDTCisSameAs<2, 3>]>; 26def SDT_SHF : SDTypeProfile<1, 2, [SDTCisInt<0>, SDTCisVec<0>, 27 SDTCisVT<1, i32>, SDTCisSameAs<0, 2>]>; 28def SDT_ILV : SDTypeProfile<1, 2, [SDTCisInt<0>, SDTCisVec<0>, 29 SDTCisSameAs<0, 1>, SDTCisSameAs<1, 2>]>; 30def SDT_INSVE : SDTypeProfile<1, 4, [SDTCisVec<0>, SDTCisSameAs<0, 1>, 31 SDTCisVT<2, i32>, SDTCisSameAs<0, 3>, 32 SDTCisVT<4, i32>]>; 33 34def MipsVAllNonZero : SDNode<"MipsISD::VALL_NONZERO", SDT_MipsVecCond>; 35def MipsVAnyNonZero : SDNode<"MipsISD::VANY_NONZERO", SDT_MipsVecCond>; 36def MipsVAllZero : SDNode<"MipsISD::VALL_ZERO", SDT_MipsVecCond>; 37def MipsVAnyZero : SDNode<"MipsISD::VANY_ZERO", SDT_MipsVecCond>; 38def MipsVSMax : SDNode<"MipsISD::VSMAX", SDTIntBinOp, 39 [SDNPCommutative, SDNPAssociative]>; 40def MipsVSMin : SDNode<"MipsISD::VSMIN", SDTIntBinOp, 41 [SDNPCommutative, SDNPAssociative]>; 42def MipsVUMax : SDNode<"MipsISD::VUMAX", SDTIntBinOp, 43 [SDNPCommutative, SDNPAssociative]>; 44def MipsVUMin : SDNode<"MipsISD::VUMIN", SDTIntBinOp, 45 [SDNPCommutative, SDNPAssociative]>; 46def MipsVNOR : SDNode<"MipsISD::VNOR", SDTIntBinOp, 47 [SDNPCommutative, SDNPAssociative]>; 48def MipsVSHF : SDNode<"MipsISD::VSHF", SDT_VSHF>; 49def MipsSHF : SDNode<"MipsISD::SHF", SDT_SHF>; 50def MipsILVEV : SDNode<"MipsISD::ILVEV", SDT_ILV>; 51def MipsILVOD : SDNode<"MipsISD::ILVOD", SDT_ILV>; 52def MipsILVL : SDNode<"MipsISD::ILVL", SDT_ILV>; 53def MipsILVR : SDNode<"MipsISD::ILVR", SDT_ILV>; 54def MipsPCKEV : SDNode<"MipsISD::PCKEV", SDT_ILV>; 55def MipsPCKOD : SDNode<"MipsISD::PCKOD", SDT_ILV>; 56def MipsINSVE : SDNode<"MipsISD::INSVE", SDT_INSVE>; 57 58def vsetcc : SDNode<"ISD::SETCC", SDT_VSetCC>; 59def vfsetcc : SDNode<"ISD::SETCC", SDT_VFSetCC>; 60 61def MipsVExtractSExt : SDNode<"MipsISD::VEXTRACT_SEXT_ELT", 62 SDTypeProfile<1, 3, [SDTCisPtrTy<2>]>, []>; 63def MipsVExtractZExt : SDNode<"MipsISD::VEXTRACT_ZEXT_ELT", 64 SDTypeProfile<1, 3, [SDTCisPtrTy<2>]>, []>; 65 66def immZExt1Ptr : ImmLeaf<iPTR, [{return isUInt<1>(Imm);}]>; 67def immZExt2Ptr : ImmLeaf<iPTR, [{return isUInt<2>(Imm);}]>; 68def immZExt3Ptr : ImmLeaf<iPTR, [{return isUInt<3>(Imm);}]>; 69def immZExt4Ptr : ImmLeaf<iPTR, [{return isUInt<4>(Imm);}]>; 70 71// Operands 72 73def immZExt2Lsa : ImmLeaf<i32, [{return isUInt<2>(Imm - 1);}]>; 74 75// Pattern fragments 76def vextract_sext_i8 : PatFrag<(ops node:$vec, node:$idx), 77 (MipsVExtractSExt node:$vec, node:$idx, i8)>; 78def vextract_sext_i16 : PatFrag<(ops node:$vec, node:$idx), 79 (MipsVExtractSExt node:$vec, node:$idx, i16)>; 80def vextract_sext_i32 : PatFrag<(ops node:$vec, node:$idx), 81 (MipsVExtractSExt node:$vec, node:$idx, i32)>; 82def vextract_sext_i64 : PatFrag<(ops node:$vec, node:$idx), 83 (MipsVExtractSExt node:$vec, node:$idx, i64)>; 84 85def vextract_zext_i8 : PatFrag<(ops node:$vec, node:$idx), 86 (MipsVExtractZExt node:$vec, node:$idx, i8)>; 87def vextract_zext_i16 : PatFrag<(ops node:$vec, node:$idx), 88 (MipsVExtractZExt node:$vec, node:$idx, i16)>; 89def vextract_zext_i32 : PatFrag<(ops node:$vec, node:$idx), 90 (MipsVExtractZExt node:$vec, node:$idx, i32)>; 91def vextract_zext_i64 : PatFrag<(ops node:$vec, node:$idx), 92 (MipsVExtractZExt node:$vec, node:$idx, i64)>; 93 94def vinsert_v16i8 : PatFrag<(ops node:$vec, node:$val, node:$idx), 95 (v16i8 (vector_insert node:$vec, node:$val, node:$idx))>; 96def vinsert_v8i16 : PatFrag<(ops node:$vec, node:$val, node:$idx), 97 (v8i16 (vector_insert node:$vec, node:$val, node:$idx))>; 98def vinsert_v4i32 : PatFrag<(ops node:$vec, node:$val, node:$idx), 99 (v4i32 (vector_insert node:$vec, node:$val, node:$idx))>; 100def vinsert_v2i64 : PatFrag<(ops node:$vec, node:$val, node:$idx), 101 (v2i64 (vector_insert node:$vec, node:$val, node:$idx))>; 102 103def insve_v16i8 : PatFrag<(ops node:$v1, node:$i1, node:$v2, node:$i2), 104 (v16i8 (MipsINSVE node:$v1, node:$i1, node:$v2, node:$i2))>; 105def insve_v8i16 : PatFrag<(ops node:$v1, node:$i1, node:$v2, node:$i2), 106 (v8i16 (MipsINSVE node:$v1, node:$i1, node:$v2, node:$i2))>; 107def insve_v4i32 : PatFrag<(ops node:$v1, node:$i1, node:$v2, node:$i2), 108 (v4i32 (MipsINSVE node:$v1, node:$i1, node:$v2, node:$i2))>; 109def insve_v2i64 : PatFrag<(ops node:$v1, node:$i1, node:$v2, node:$i2), 110 (v2i64 (MipsINSVE node:$v1, node:$i1, node:$v2, node:$i2))>; 111 112class vfsetcc_type<ValueType ResTy, ValueType OpTy, CondCode CC> : 113 PatFrag<(ops node:$lhs, node:$rhs), 114 (ResTy (vfsetcc (OpTy node:$lhs), (OpTy node:$rhs), CC))>; 115 116// ISD::SETFALSE cannot occur 117def vfsetoeq_v4f32 : vfsetcc_type<v4i32, v4f32, SETOEQ>; 118def vfsetoeq_v2f64 : vfsetcc_type<v2i64, v2f64, SETOEQ>; 119def vfsetoge_v4f32 : vfsetcc_type<v4i32, v4f32, SETOGE>; 120def vfsetoge_v2f64 : vfsetcc_type<v2i64, v2f64, SETOGE>; 121def vfsetogt_v4f32 : vfsetcc_type<v4i32, v4f32, SETOGT>; 122def vfsetogt_v2f64 : vfsetcc_type<v2i64, v2f64, SETOGT>; 123def vfsetole_v4f32 : vfsetcc_type<v4i32, v4f32, SETOLE>; 124def vfsetole_v2f64 : vfsetcc_type<v2i64, v2f64, SETOLE>; 125def vfsetolt_v4f32 : vfsetcc_type<v4i32, v4f32, SETOLT>; 126def vfsetolt_v2f64 : vfsetcc_type<v2i64, v2f64, SETOLT>; 127def vfsetone_v4f32 : vfsetcc_type<v4i32, v4f32, SETONE>; 128def vfsetone_v2f64 : vfsetcc_type<v2i64, v2f64, SETONE>; 129def vfsetord_v4f32 : vfsetcc_type<v4i32, v4f32, SETO>; 130def vfsetord_v2f64 : vfsetcc_type<v2i64, v2f64, SETO>; 131def vfsetun_v4f32 : vfsetcc_type<v4i32, v4f32, SETUO>; 132def vfsetun_v2f64 : vfsetcc_type<v2i64, v2f64, SETUO>; 133def vfsetueq_v4f32 : vfsetcc_type<v4i32, v4f32, SETUEQ>; 134def vfsetueq_v2f64 : vfsetcc_type<v2i64, v2f64, SETUEQ>; 135def vfsetuge_v4f32 : vfsetcc_type<v4i32, v4f32, SETUGE>; 136def vfsetuge_v2f64 : vfsetcc_type<v2i64, v2f64, SETUGE>; 137def vfsetugt_v4f32 : vfsetcc_type<v4i32, v4f32, SETUGT>; 138def vfsetugt_v2f64 : vfsetcc_type<v2i64, v2f64, SETUGT>; 139def vfsetule_v4f32 : vfsetcc_type<v4i32, v4f32, SETULE>; 140def vfsetule_v2f64 : vfsetcc_type<v2i64, v2f64, SETULE>; 141def vfsetult_v4f32 : vfsetcc_type<v4i32, v4f32, SETULT>; 142def vfsetult_v2f64 : vfsetcc_type<v2i64, v2f64, SETULT>; 143def vfsetune_v4f32 : vfsetcc_type<v4i32, v4f32, SETUNE>; 144def vfsetune_v2f64 : vfsetcc_type<v2i64, v2f64, SETUNE>; 145// ISD::SETTRUE cannot occur 146// ISD::SETFALSE2 cannot occur 147// ISD::SETTRUE2 cannot occur 148 149class vsetcc_type<ValueType ResTy, CondCode CC> : 150 PatFrag<(ops node:$lhs, node:$rhs), 151 (ResTy (vsetcc node:$lhs, node:$rhs, CC))>; 152 153def vseteq_v16i8 : vsetcc_type<v16i8, SETEQ>; 154def vseteq_v8i16 : vsetcc_type<v8i16, SETEQ>; 155def vseteq_v4i32 : vsetcc_type<v4i32, SETEQ>; 156def vseteq_v2i64 : vsetcc_type<v2i64, SETEQ>; 157def vsetle_v16i8 : vsetcc_type<v16i8, SETLE>; 158def vsetle_v8i16 : vsetcc_type<v8i16, SETLE>; 159def vsetle_v4i32 : vsetcc_type<v4i32, SETLE>; 160def vsetle_v2i64 : vsetcc_type<v2i64, SETLE>; 161def vsetlt_v16i8 : vsetcc_type<v16i8, SETLT>; 162def vsetlt_v8i16 : vsetcc_type<v8i16, SETLT>; 163def vsetlt_v4i32 : vsetcc_type<v4i32, SETLT>; 164def vsetlt_v2i64 : vsetcc_type<v2i64, SETLT>; 165def vsetule_v16i8 : vsetcc_type<v16i8, SETULE>; 166def vsetule_v8i16 : vsetcc_type<v8i16, SETULE>; 167def vsetule_v4i32 : vsetcc_type<v4i32, SETULE>; 168def vsetule_v2i64 : vsetcc_type<v2i64, SETULE>; 169def vsetult_v16i8 : vsetcc_type<v16i8, SETULT>; 170def vsetult_v8i16 : vsetcc_type<v8i16, SETULT>; 171def vsetult_v4i32 : vsetcc_type<v4i32, SETULT>; 172def vsetult_v2i64 : vsetcc_type<v2i64, SETULT>; 173 174def vsplati8 : PatFrag<(ops node:$e0), 175 (v16i8 (build_vector node:$e0, node:$e0, 176 node:$e0, node:$e0, 177 node:$e0, node:$e0, 178 node:$e0, node:$e0, 179 node:$e0, node:$e0, 180 node:$e0, node:$e0, 181 node:$e0, node:$e0, 182 node:$e0, node:$e0))>; 183def vsplati16 : PatFrag<(ops node:$e0), 184 (v8i16 (build_vector node:$e0, node:$e0, 185 node:$e0, node:$e0, 186 node:$e0, node:$e0, 187 node:$e0, node:$e0))>; 188def vsplati32 : PatFrag<(ops node:$e0), 189 (v4i32 (build_vector node:$e0, node:$e0, 190 node:$e0, node:$e0))>; 191def vsplati64 : PatFrag<(ops node:$e0), 192 (v2i64 (build_vector node:$e0, node:$e0))>; 193def vsplatf32 : PatFrag<(ops node:$e0), 194 (v4f32 (build_vector node:$e0, node:$e0, 195 node:$e0, node:$e0))>; 196def vsplatf64 : PatFrag<(ops node:$e0), 197 (v2f64 (build_vector node:$e0, node:$e0))>; 198 199def vsplati8_elt : PatFrag<(ops node:$v, node:$i), 200 (MipsVSHF (vsplati8 node:$i), node:$v, node:$v)>; 201def vsplati16_elt : PatFrag<(ops node:$v, node:$i), 202 (MipsVSHF (vsplati16 node:$i), node:$v, node:$v)>; 203def vsplati32_elt : PatFrag<(ops node:$v, node:$i), 204 (MipsVSHF (vsplati32 node:$i), node:$v, node:$v)>; 205def vsplati64_elt : PatFrag<(ops node:$v, node:$i), 206 (MipsVSHF (vsplati64 node:$i), node:$v, node:$v)>; 207 208class SplatPatLeaf<Operand opclass, dag frag, code pred = [{}], 209 SDNodeXForm xform = NOOP_SDNodeXForm> 210 : PatLeaf<frag, pred, xform> { 211 Operand OpClass = opclass; 212} 213 214class SplatComplexPattern<Operand opclass, ValueType ty, int numops, string fn, 215 list<SDNode> roots = [], 216 list<SDNodeProperty> props = []> : 217 ComplexPattern<ty, numops, fn, roots, props> { 218 Operand OpClass = opclass; 219} 220 221def vsplati8_uimm3 : SplatComplexPattern<vsplat_uimm3, v16i8, 1, 222 "selectVSplatUimm3", 223 [build_vector, bitconvert]>; 224 225def vsplati8_uimm4 : SplatComplexPattern<vsplat_uimm4, v16i8, 1, 226 "selectVSplatUimm4", 227 [build_vector, bitconvert]>; 228 229def vsplati8_uimm5 : SplatComplexPattern<vsplat_uimm5, v16i8, 1, 230 "selectVSplatUimm5", 231 [build_vector, bitconvert]>; 232 233def vsplati8_uimm8 : SplatComplexPattern<vsplat_uimm8, v16i8, 1, 234 "selectVSplatUimm8", 235 [build_vector, bitconvert]>; 236 237def vsplati8_simm5 : SplatComplexPattern<vsplat_simm5, v16i8, 1, 238 "selectVSplatSimm5", 239 [build_vector, bitconvert]>; 240 241def vsplati16_uimm3 : SplatComplexPattern<vsplat_uimm3, v8i16, 1, 242 "selectVSplatUimm3", 243 [build_vector, bitconvert]>; 244 245def vsplati16_uimm4 : SplatComplexPattern<vsplat_uimm4, v8i16, 1, 246 "selectVSplatUimm4", 247 [build_vector, bitconvert]>; 248 249def vsplati16_uimm5 : SplatComplexPattern<vsplat_uimm5, v8i16, 1, 250 "selectVSplatUimm5", 251 [build_vector, bitconvert]>; 252 253def vsplati16_simm5 : SplatComplexPattern<vsplat_simm5, v8i16, 1, 254 "selectVSplatSimm5", 255 [build_vector, bitconvert]>; 256 257def vsplati32_uimm2 : SplatComplexPattern<vsplat_uimm2, v4i32, 1, 258 "selectVSplatUimm2", 259 [build_vector, bitconvert]>; 260 261def vsplati32_uimm5 : SplatComplexPattern<vsplat_uimm5, v4i32, 1, 262 "selectVSplatUimm5", 263 [build_vector, bitconvert]>; 264 265def vsplati32_simm5 : SplatComplexPattern<vsplat_simm5, v4i32, 1, 266 "selectVSplatSimm5", 267 [build_vector, bitconvert]>; 268 269def vsplati64_uimm1 : SplatComplexPattern<vsplat_uimm1, v2i64, 1, 270 "selectVSplatUimm1", 271 [build_vector, bitconvert]>; 272 273def vsplati64_uimm5 : SplatComplexPattern<vsplat_uimm5, v2i64, 1, 274 "selectVSplatUimm5", 275 [build_vector, bitconvert]>; 276 277def vsplati64_uimm6 : SplatComplexPattern<vsplat_uimm6, v2i64, 1, 278 "selectVSplatUimm6", 279 [build_vector, bitconvert]>; 280 281def vsplati64_simm5 : SplatComplexPattern<vsplat_simm5, v2i64, 1, 282 "selectVSplatSimm5", 283 [build_vector, bitconvert]>; 284 285// Any build_vector that is a constant splat with a value that is an exact 286// power of 2 287def vsplat_uimm_pow2 : ComplexPattern<vAny, 1, "selectVSplatUimmPow2", 288 [build_vector, bitconvert]>; 289 290// Any build_vector that is a constant splat with a value that is the bitwise 291// inverse of an exact power of 2 292def vsplat_uimm_inv_pow2 : ComplexPattern<vAny, 1, "selectVSplatUimmInvPow2", 293 [build_vector, bitconvert]>; 294 295// Any build_vector that is a constant splat with only a consecutive sequence 296// of left-most bits set. 297def vsplat_maskl_bits_uimm3 298 : SplatComplexPattern<vsplat_uimm3, vAny, 1, "selectVSplatMaskL", 299 [build_vector, bitconvert]>; 300def vsplat_maskl_bits_uimm4 301 : SplatComplexPattern<vsplat_uimm4, vAny, 1, "selectVSplatMaskL", 302 [build_vector, bitconvert]>; 303def vsplat_maskl_bits_uimm5 304 : SplatComplexPattern<vsplat_uimm5, vAny, 1, "selectVSplatMaskL", 305 [build_vector, bitconvert]>; 306def vsplat_maskl_bits_uimm6 307 : SplatComplexPattern<vsplat_uimm6, vAny, 1, "selectVSplatMaskL", 308 [build_vector, bitconvert]>; 309 310// Any build_vector that is a constant splat with only a consecutive sequence 311// of right-most bits set. 312def vsplat_maskr_bits_uimm3 313 : SplatComplexPattern<vsplat_uimm3, vAny, 1, "selectVSplatMaskR", 314 [build_vector, bitconvert]>; 315def vsplat_maskr_bits_uimm4 316 : SplatComplexPattern<vsplat_uimm4, vAny, 1, "selectVSplatMaskR", 317 [build_vector, bitconvert]>; 318def vsplat_maskr_bits_uimm5 319 : SplatComplexPattern<vsplat_uimm5, vAny, 1, "selectVSplatMaskR", 320 [build_vector, bitconvert]>; 321def vsplat_maskr_bits_uimm6 322 : SplatComplexPattern<vsplat_uimm6, vAny, 1, "selectVSplatMaskR", 323 [build_vector, bitconvert]>; 324 325// Any build_vector that is a constant splat with a value that equals 1 326// FIXME: These should be a ComplexPattern but we can't use them because the 327// ISel generator requires the uses to have a name, but providing a name 328// causes other errors ("used in pattern but not operand list") 329def vsplat_imm_eq_1 : PatLeaf<(build_vector), [{ 330 APInt Imm; 331 EVT EltTy = N->getValueType(0).getVectorElementType(); 332 333 return selectVSplat(N, Imm, EltTy.getSizeInBits()) && 334 Imm.getBitWidth() == EltTy.getSizeInBits() && Imm == 1; 335}]>; 336 337def vsplati64_imm_eq_1 : PatLeaf<(bitconvert (v4i32 (build_vector))), [{ 338 APInt Imm; 339 SDNode *BV = N->getOperand(0).getNode(); 340 EVT EltTy = N->getValueType(0).getVectorElementType(); 341 342 return selectVSplat(BV, Imm, EltTy.getSizeInBits()) && 343 Imm.getBitWidth() == EltTy.getSizeInBits() && Imm == 1; 344}]>; 345 346def vbclr_b : PatFrag<(ops node:$ws, node:$wt), 347 (and node:$ws, (xor (shl vsplat_imm_eq_1, node:$wt), 348 immAllOnesV))>; 349def vbclr_h : PatFrag<(ops node:$ws, node:$wt), 350 (and node:$ws, (xor (shl vsplat_imm_eq_1, node:$wt), 351 immAllOnesV))>; 352def vbclr_w : PatFrag<(ops node:$ws, node:$wt), 353 (and node:$ws, (xor (shl vsplat_imm_eq_1, node:$wt), 354 immAllOnesV))>; 355def vbclr_d : PatFrag<(ops node:$ws, node:$wt), 356 (and node:$ws, (xor (shl (v2i64 vsplati64_imm_eq_1), 357 node:$wt), 358 (bitconvert (v4i32 immAllOnesV))))>; 359 360def vbneg_b : PatFrag<(ops node:$ws, node:$wt), 361 (xor node:$ws, (shl vsplat_imm_eq_1, node:$wt))>; 362def vbneg_h : PatFrag<(ops node:$ws, node:$wt), 363 (xor node:$ws, (shl vsplat_imm_eq_1, node:$wt))>; 364def vbneg_w : PatFrag<(ops node:$ws, node:$wt), 365 (xor node:$ws, (shl vsplat_imm_eq_1, node:$wt))>; 366def vbneg_d : PatFrag<(ops node:$ws, node:$wt), 367 (xor node:$ws, (shl (v2i64 vsplati64_imm_eq_1), 368 node:$wt))>; 369 370def vbset_b : PatFrag<(ops node:$ws, node:$wt), 371 (or node:$ws, (shl vsplat_imm_eq_1, node:$wt))>; 372def vbset_h : PatFrag<(ops node:$ws, node:$wt), 373 (or node:$ws, (shl vsplat_imm_eq_1, node:$wt))>; 374def vbset_w : PatFrag<(ops node:$ws, node:$wt), 375 (or node:$ws, (shl vsplat_imm_eq_1, node:$wt))>; 376def vbset_d : PatFrag<(ops node:$ws, node:$wt), 377 (or node:$ws, (shl (v2i64 vsplati64_imm_eq_1), 378 node:$wt))>; 379 380def fms : PatFrag<(ops node:$wd, node:$ws, node:$wt), 381 (fsub node:$wd, (fmul node:$ws, node:$wt))>; 382 383def muladd : PatFrag<(ops node:$wd, node:$ws, node:$wt), 384 (add node:$wd, (mul node:$ws, node:$wt))>; 385 386def mulsub : PatFrag<(ops node:$wd, node:$ws, node:$wt), 387 (sub node:$wd, (mul node:$ws, node:$wt))>; 388 389def mul_fexp2 : PatFrag<(ops node:$ws, node:$wt), 390 (fmul node:$ws, (fexp2 node:$wt))>; 391 392// Immediates 393def immSExt5 : ImmLeaf<i32, [{return isInt<5>(Imm);}]>; 394def immSExt10: ImmLeaf<i32, [{return isInt<10>(Imm);}]>; 395 396// Instruction encoding. 397class ADD_A_B_ENC : MSA_3R_FMT<0b000, 0b00, 0b010000>; 398class ADD_A_H_ENC : MSA_3R_FMT<0b000, 0b01, 0b010000>; 399class ADD_A_W_ENC : MSA_3R_FMT<0b000, 0b10, 0b010000>; 400class ADD_A_D_ENC : MSA_3R_FMT<0b000, 0b11, 0b010000>; 401 402class ADDS_A_B_ENC : MSA_3R_FMT<0b001, 0b00, 0b010000>; 403class ADDS_A_H_ENC : MSA_3R_FMT<0b001, 0b01, 0b010000>; 404class ADDS_A_W_ENC : MSA_3R_FMT<0b001, 0b10, 0b010000>; 405class ADDS_A_D_ENC : MSA_3R_FMT<0b001, 0b11, 0b010000>; 406 407class ADDS_S_B_ENC : MSA_3R_FMT<0b010, 0b00, 0b010000>; 408class ADDS_S_H_ENC : MSA_3R_FMT<0b010, 0b01, 0b010000>; 409class ADDS_S_W_ENC : MSA_3R_FMT<0b010, 0b10, 0b010000>; 410class ADDS_S_D_ENC : MSA_3R_FMT<0b010, 0b11, 0b010000>; 411 412class ADDS_U_B_ENC : MSA_3R_FMT<0b011, 0b00, 0b010000>; 413class ADDS_U_H_ENC : MSA_3R_FMT<0b011, 0b01, 0b010000>; 414class ADDS_U_W_ENC : MSA_3R_FMT<0b011, 0b10, 0b010000>; 415class ADDS_U_D_ENC : MSA_3R_FMT<0b011, 0b11, 0b010000>; 416 417class ADDV_B_ENC : MSA_3R_FMT<0b000, 0b00, 0b001110>; 418class ADDV_H_ENC : MSA_3R_FMT<0b000, 0b01, 0b001110>; 419class ADDV_W_ENC : MSA_3R_FMT<0b000, 0b10, 0b001110>; 420class ADDV_D_ENC : MSA_3R_FMT<0b000, 0b11, 0b001110>; 421 422class ADDVI_B_ENC : MSA_I5_FMT<0b000, 0b00, 0b000110>; 423class ADDVI_H_ENC : MSA_I5_FMT<0b000, 0b01, 0b000110>; 424class ADDVI_W_ENC : MSA_I5_FMT<0b000, 0b10, 0b000110>; 425class ADDVI_D_ENC : MSA_I5_FMT<0b000, 0b11, 0b000110>; 426 427class AND_V_ENC : MSA_VEC_FMT<0b00000, 0b011110>; 428 429class ANDI_B_ENC : MSA_I8_FMT<0b00, 0b000000>; 430 431class ASUB_S_B_ENC : MSA_3R_FMT<0b100, 0b00, 0b010001>; 432class ASUB_S_H_ENC : MSA_3R_FMT<0b100, 0b01, 0b010001>; 433class ASUB_S_W_ENC : MSA_3R_FMT<0b100, 0b10, 0b010001>; 434class ASUB_S_D_ENC : MSA_3R_FMT<0b100, 0b11, 0b010001>; 435 436class ASUB_U_B_ENC : MSA_3R_FMT<0b101, 0b00, 0b010001>; 437class ASUB_U_H_ENC : MSA_3R_FMT<0b101, 0b01, 0b010001>; 438class ASUB_U_W_ENC : MSA_3R_FMT<0b101, 0b10, 0b010001>; 439class ASUB_U_D_ENC : MSA_3R_FMT<0b101, 0b11, 0b010001>; 440 441class AVE_S_B_ENC : MSA_3R_FMT<0b100, 0b00, 0b010000>; 442class AVE_S_H_ENC : MSA_3R_FMT<0b100, 0b01, 0b010000>; 443class AVE_S_W_ENC : MSA_3R_FMT<0b100, 0b10, 0b010000>; 444class AVE_S_D_ENC : MSA_3R_FMT<0b100, 0b11, 0b010000>; 445 446class AVE_U_B_ENC : MSA_3R_FMT<0b101, 0b00, 0b010000>; 447class AVE_U_H_ENC : MSA_3R_FMT<0b101, 0b01, 0b010000>; 448class AVE_U_W_ENC : MSA_3R_FMT<0b101, 0b10, 0b010000>; 449class AVE_U_D_ENC : MSA_3R_FMT<0b101, 0b11, 0b010000>; 450 451class AVER_S_B_ENC : MSA_3R_FMT<0b110, 0b00, 0b010000>; 452class AVER_S_H_ENC : MSA_3R_FMT<0b110, 0b01, 0b010000>; 453class AVER_S_W_ENC : MSA_3R_FMT<0b110, 0b10, 0b010000>; 454class AVER_S_D_ENC : MSA_3R_FMT<0b110, 0b11, 0b010000>; 455 456class AVER_U_B_ENC : MSA_3R_FMT<0b111, 0b00, 0b010000>; 457class AVER_U_H_ENC : MSA_3R_FMT<0b111, 0b01, 0b010000>; 458class AVER_U_W_ENC : MSA_3R_FMT<0b111, 0b10, 0b010000>; 459class AVER_U_D_ENC : MSA_3R_FMT<0b111, 0b11, 0b010000>; 460 461class BCLR_B_ENC : MSA_3R_FMT<0b011, 0b00, 0b001101>; 462class BCLR_H_ENC : MSA_3R_FMT<0b011, 0b01, 0b001101>; 463class BCLR_W_ENC : MSA_3R_FMT<0b011, 0b10, 0b001101>; 464class BCLR_D_ENC : MSA_3R_FMT<0b011, 0b11, 0b001101>; 465 466class BCLRI_B_ENC : MSA_BIT_B_FMT<0b011, 0b001001>; 467class BCLRI_H_ENC : MSA_BIT_H_FMT<0b011, 0b001001>; 468class BCLRI_W_ENC : MSA_BIT_W_FMT<0b011, 0b001001>; 469class BCLRI_D_ENC : MSA_BIT_D_FMT<0b011, 0b001001>; 470 471class BINSL_B_ENC : MSA_3R_FMT<0b110, 0b00, 0b001101>; 472class BINSL_H_ENC : MSA_3R_FMT<0b110, 0b01, 0b001101>; 473class BINSL_W_ENC : MSA_3R_FMT<0b110, 0b10, 0b001101>; 474class BINSL_D_ENC : MSA_3R_FMT<0b110, 0b11, 0b001101>; 475 476class BINSLI_B_ENC : MSA_BIT_B_FMT<0b110, 0b001001>; 477class BINSLI_H_ENC : MSA_BIT_H_FMT<0b110, 0b001001>; 478class BINSLI_W_ENC : MSA_BIT_W_FMT<0b110, 0b001001>; 479class BINSLI_D_ENC : MSA_BIT_D_FMT<0b110, 0b001001>; 480 481class BINSR_B_ENC : MSA_3R_FMT<0b111, 0b00, 0b001101>; 482class BINSR_H_ENC : MSA_3R_FMT<0b111, 0b01, 0b001101>; 483class BINSR_W_ENC : MSA_3R_FMT<0b111, 0b10, 0b001101>; 484class BINSR_D_ENC : MSA_3R_FMT<0b111, 0b11, 0b001101>; 485 486class BINSRI_B_ENC : MSA_BIT_B_FMT<0b111, 0b001001>; 487class BINSRI_H_ENC : MSA_BIT_H_FMT<0b111, 0b001001>; 488class BINSRI_W_ENC : MSA_BIT_W_FMT<0b111, 0b001001>; 489class BINSRI_D_ENC : MSA_BIT_D_FMT<0b111, 0b001001>; 490 491class BMNZ_V_ENC : MSA_VEC_FMT<0b00100, 0b011110>; 492 493class BMNZI_B_ENC : MSA_I8_FMT<0b00, 0b000001>; 494 495class BMZ_V_ENC : MSA_VEC_FMT<0b00101, 0b011110>; 496 497class BMZI_B_ENC : MSA_I8_FMT<0b01, 0b000001>; 498 499class BNEG_B_ENC : MSA_3R_FMT<0b101, 0b00, 0b001101>; 500class BNEG_H_ENC : MSA_3R_FMT<0b101, 0b01, 0b001101>; 501class BNEG_W_ENC : MSA_3R_FMT<0b101, 0b10, 0b001101>; 502class BNEG_D_ENC : MSA_3R_FMT<0b101, 0b11, 0b001101>; 503 504class BNEGI_B_ENC : MSA_BIT_B_FMT<0b101, 0b001001>; 505class BNEGI_H_ENC : MSA_BIT_H_FMT<0b101, 0b001001>; 506class BNEGI_W_ENC : MSA_BIT_W_FMT<0b101, 0b001001>; 507class BNEGI_D_ENC : MSA_BIT_D_FMT<0b101, 0b001001>; 508 509class BNZ_B_ENC : MSA_CBRANCH_FMT<0b111, 0b00>; 510class BNZ_H_ENC : MSA_CBRANCH_FMT<0b111, 0b01>; 511class BNZ_W_ENC : MSA_CBRANCH_FMT<0b111, 0b10>; 512class BNZ_D_ENC : MSA_CBRANCH_FMT<0b111, 0b11>; 513 514class BNZ_V_ENC : MSA_CBRANCH_V_FMT<0b01111>; 515 516class BSEL_V_ENC : MSA_VEC_FMT<0b00110, 0b011110>; 517 518class BSELI_B_ENC : MSA_I8_FMT<0b10, 0b000001>; 519 520class BSET_B_ENC : MSA_3R_FMT<0b100, 0b00, 0b001101>; 521class BSET_H_ENC : MSA_3R_FMT<0b100, 0b01, 0b001101>; 522class BSET_W_ENC : MSA_3R_FMT<0b100, 0b10, 0b001101>; 523class BSET_D_ENC : MSA_3R_FMT<0b100, 0b11, 0b001101>; 524 525class BSETI_B_ENC : MSA_BIT_B_FMT<0b100, 0b001001>; 526class BSETI_H_ENC : MSA_BIT_H_FMT<0b100, 0b001001>; 527class BSETI_W_ENC : MSA_BIT_W_FMT<0b100, 0b001001>; 528class BSETI_D_ENC : MSA_BIT_D_FMT<0b100, 0b001001>; 529 530class BZ_B_ENC : MSA_CBRANCH_FMT<0b110, 0b00>; 531class BZ_H_ENC : MSA_CBRANCH_FMT<0b110, 0b01>; 532class BZ_W_ENC : MSA_CBRANCH_FMT<0b110, 0b10>; 533class BZ_D_ENC : MSA_CBRANCH_FMT<0b110, 0b11>; 534 535class BZ_V_ENC : MSA_CBRANCH_V_FMT<0b01011>; 536 537class CEQ_B_ENC : MSA_3R_FMT<0b000, 0b00, 0b001111>; 538class CEQ_H_ENC : MSA_3R_FMT<0b000, 0b01, 0b001111>; 539class CEQ_W_ENC : MSA_3R_FMT<0b000, 0b10, 0b001111>; 540class CEQ_D_ENC : MSA_3R_FMT<0b000, 0b11, 0b001111>; 541 542class CEQI_B_ENC : MSA_I5_FMT<0b000, 0b00, 0b000111>; 543class CEQI_H_ENC : MSA_I5_FMT<0b000, 0b01, 0b000111>; 544class CEQI_W_ENC : MSA_I5_FMT<0b000, 0b10, 0b000111>; 545class CEQI_D_ENC : MSA_I5_FMT<0b000, 0b11, 0b000111>; 546 547class CFCMSA_ENC : MSA_ELM_CFCMSA_FMT<0b0001111110, 0b011001>; 548 549class CLE_S_B_ENC : MSA_3R_FMT<0b100, 0b00, 0b001111>; 550class CLE_S_H_ENC : MSA_3R_FMT<0b100, 0b01, 0b001111>; 551class CLE_S_W_ENC : MSA_3R_FMT<0b100, 0b10, 0b001111>; 552class CLE_S_D_ENC : MSA_3R_FMT<0b100, 0b11, 0b001111>; 553 554class CLE_U_B_ENC : MSA_3R_FMT<0b101, 0b00, 0b001111>; 555class CLE_U_H_ENC : MSA_3R_FMT<0b101, 0b01, 0b001111>; 556class CLE_U_W_ENC : MSA_3R_FMT<0b101, 0b10, 0b001111>; 557class CLE_U_D_ENC : MSA_3R_FMT<0b101, 0b11, 0b001111>; 558 559class CLEI_S_B_ENC : MSA_I5_FMT<0b100, 0b00, 0b000111>; 560class CLEI_S_H_ENC : MSA_I5_FMT<0b100, 0b01, 0b000111>; 561class CLEI_S_W_ENC : MSA_I5_FMT<0b100, 0b10, 0b000111>; 562class CLEI_S_D_ENC : MSA_I5_FMT<0b100, 0b11, 0b000111>; 563 564class CLEI_U_B_ENC : MSA_I5_FMT<0b101, 0b00, 0b000111>; 565class CLEI_U_H_ENC : MSA_I5_FMT<0b101, 0b01, 0b000111>; 566class CLEI_U_W_ENC : MSA_I5_FMT<0b101, 0b10, 0b000111>; 567class CLEI_U_D_ENC : MSA_I5_FMT<0b101, 0b11, 0b000111>; 568 569class CLT_S_B_ENC : MSA_3R_FMT<0b010, 0b00, 0b001111>; 570class CLT_S_H_ENC : MSA_3R_FMT<0b010, 0b01, 0b001111>; 571class CLT_S_W_ENC : MSA_3R_FMT<0b010, 0b10, 0b001111>; 572class CLT_S_D_ENC : MSA_3R_FMT<0b010, 0b11, 0b001111>; 573 574class CLT_U_B_ENC : MSA_3R_FMT<0b011, 0b00, 0b001111>; 575class CLT_U_H_ENC : MSA_3R_FMT<0b011, 0b01, 0b001111>; 576class CLT_U_W_ENC : MSA_3R_FMT<0b011, 0b10, 0b001111>; 577class CLT_U_D_ENC : MSA_3R_FMT<0b011, 0b11, 0b001111>; 578 579class CLTI_S_B_ENC : MSA_I5_FMT<0b010, 0b00, 0b000111>; 580class CLTI_S_H_ENC : MSA_I5_FMT<0b010, 0b01, 0b000111>; 581class CLTI_S_W_ENC : MSA_I5_FMT<0b010, 0b10, 0b000111>; 582class CLTI_S_D_ENC : MSA_I5_FMT<0b010, 0b11, 0b000111>; 583 584class CLTI_U_B_ENC : MSA_I5_FMT<0b011, 0b00, 0b000111>; 585class CLTI_U_H_ENC : MSA_I5_FMT<0b011, 0b01, 0b000111>; 586class CLTI_U_W_ENC : MSA_I5_FMT<0b011, 0b10, 0b000111>; 587class CLTI_U_D_ENC : MSA_I5_FMT<0b011, 0b11, 0b000111>; 588 589class COPY_S_B_ENC : MSA_ELM_COPY_B_FMT<0b0010, 0b011001>; 590class COPY_S_H_ENC : MSA_ELM_COPY_H_FMT<0b0010, 0b011001>; 591class COPY_S_W_ENC : MSA_ELM_COPY_W_FMT<0b0010, 0b011001>; 592class COPY_S_D_ENC : MSA_ELM_COPY_D_FMT<0b0010, 0b011001>; 593 594class COPY_U_B_ENC : MSA_ELM_COPY_B_FMT<0b0011, 0b011001>; 595class COPY_U_H_ENC : MSA_ELM_COPY_H_FMT<0b0011, 0b011001>; 596class COPY_U_W_ENC : MSA_ELM_COPY_W_FMT<0b0011, 0b011001>; 597 598class CTCMSA_ENC : MSA_ELM_CTCMSA_FMT<0b0000111110, 0b011001>; 599 600class DIV_S_B_ENC : MSA_3R_FMT<0b100, 0b00, 0b010010>; 601class DIV_S_H_ENC : MSA_3R_FMT<0b100, 0b01, 0b010010>; 602class DIV_S_W_ENC : MSA_3R_FMT<0b100, 0b10, 0b010010>; 603class DIV_S_D_ENC : MSA_3R_FMT<0b100, 0b11, 0b010010>; 604 605class DIV_U_B_ENC : MSA_3R_FMT<0b101, 0b00, 0b010010>; 606class DIV_U_H_ENC : MSA_3R_FMT<0b101, 0b01, 0b010010>; 607class DIV_U_W_ENC : MSA_3R_FMT<0b101, 0b10, 0b010010>; 608class DIV_U_D_ENC : MSA_3R_FMT<0b101, 0b11, 0b010010>; 609 610class DOTP_S_H_ENC : MSA_3R_FMT<0b000, 0b01, 0b010011>; 611class DOTP_S_W_ENC : MSA_3R_FMT<0b000, 0b10, 0b010011>; 612class DOTP_S_D_ENC : MSA_3R_FMT<0b000, 0b11, 0b010011>; 613 614class DOTP_U_H_ENC : MSA_3R_FMT<0b001, 0b01, 0b010011>; 615class DOTP_U_W_ENC : MSA_3R_FMT<0b001, 0b10, 0b010011>; 616class DOTP_U_D_ENC : MSA_3R_FMT<0b001, 0b11, 0b010011>; 617 618class DPADD_S_H_ENC : MSA_3R_FMT<0b010, 0b01, 0b010011>; 619class DPADD_S_W_ENC : MSA_3R_FMT<0b010, 0b10, 0b010011>; 620class DPADD_S_D_ENC : MSA_3R_FMT<0b010, 0b11, 0b010011>; 621 622class DPADD_U_H_ENC : MSA_3R_FMT<0b011, 0b01, 0b010011>; 623class DPADD_U_W_ENC : MSA_3R_FMT<0b011, 0b10, 0b010011>; 624class DPADD_U_D_ENC : MSA_3R_FMT<0b011, 0b11, 0b010011>; 625 626class DPSUB_S_H_ENC : MSA_3R_FMT<0b100, 0b01, 0b010011>; 627class DPSUB_S_W_ENC : MSA_3R_FMT<0b100, 0b10, 0b010011>; 628class DPSUB_S_D_ENC : MSA_3R_FMT<0b100, 0b11, 0b010011>; 629 630class DPSUB_U_H_ENC : MSA_3R_FMT<0b101, 0b01, 0b010011>; 631class DPSUB_U_W_ENC : MSA_3R_FMT<0b101, 0b10, 0b010011>; 632class DPSUB_U_D_ENC : MSA_3R_FMT<0b101, 0b11, 0b010011>; 633 634class FADD_W_ENC : MSA_3RF_FMT<0b0000, 0b0, 0b011011>; 635class FADD_D_ENC : MSA_3RF_FMT<0b0000, 0b1, 0b011011>; 636 637class FCAF_W_ENC : MSA_3RF_FMT<0b0000, 0b0, 0b011010>; 638class FCAF_D_ENC : MSA_3RF_FMT<0b0000, 0b1, 0b011010>; 639 640class FCEQ_W_ENC : MSA_3RF_FMT<0b0010, 0b0, 0b011010>; 641class FCEQ_D_ENC : MSA_3RF_FMT<0b0010, 0b1, 0b011010>; 642 643class FCLASS_W_ENC : MSA_2RF_FMT<0b110010000, 0b0, 0b011110>; 644class FCLASS_D_ENC : MSA_2RF_FMT<0b110010000, 0b1, 0b011110>; 645 646class FCLE_W_ENC : MSA_3RF_FMT<0b0110, 0b0, 0b011010>; 647class FCLE_D_ENC : MSA_3RF_FMT<0b0110, 0b1, 0b011010>; 648 649class FCLT_W_ENC : MSA_3RF_FMT<0b0100, 0b0, 0b011010>; 650class FCLT_D_ENC : MSA_3RF_FMT<0b0100, 0b1, 0b011010>; 651 652class FCNE_W_ENC : MSA_3RF_FMT<0b0011, 0b0, 0b011100>; 653class FCNE_D_ENC : MSA_3RF_FMT<0b0011, 0b1, 0b011100>; 654 655class FCOR_W_ENC : MSA_3RF_FMT<0b0001, 0b0, 0b011100>; 656class FCOR_D_ENC : MSA_3RF_FMT<0b0001, 0b1, 0b011100>; 657 658class FCUEQ_W_ENC : MSA_3RF_FMT<0b0011, 0b0, 0b011010>; 659class FCUEQ_D_ENC : MSA_3RF_FMT<0b0011, 0b1, 0b011010>; 660 661class FCULE_W_ENC : MSA_3RF_FMT<0b0111, 0b0, 0b011010>; 662class FCULE_D_ENC : MSA_3RF_FMT<0b0111, 0b1, 0b011010>; 663 664class FCULT_W_ENC : MSA_3RF_FMT<0b0101, 0b0, 0b011010>; 665class FCULT_D_ENC : MSA_3RF_FMT<0b0101, 0b1, 0b011010>; 666 667class FCUN_W_ENC : MSA_3RF_FMT<0b0001, 0b0, 0b011010>; 668class FCUN_D_ENC : MSA_3RF_FMT<0b0001, 0b1, 0b011010>; 669 670class FCUNE_W_ENC : MSA_3RF_FMT<0b0010, 0b0, 0b011100>; 671class FCUNE_D_ENC : MSA_3RF_FMT<0b0010, 0b1, 0b011100>; 672 673class FDIV_W_ENC : MSA_3RF_FMT<0b0011, 0b0, 0b011011>; 674class FDIV_D_ENC : MSA_3RF_FMT<0b0011, 0b1, 0b011011>; 675 676class FEXDO_H_ENC : MSA_3RF_FMT<0b1000, 0b0, 0b011011>; 677class FEXDO_W_ENC : MSA_3RF_FMT<0b1000, 0b1, 0b011011>; 678 679class FEXP2_W_ENC : MSA_3RF_FMT<0b0111, 0b0, 0b011011>; 680class FEXP2_D_ENC : MSA_3RF_FMT<0b0111, 0b1, 0b011011>; 681 682class FEXUPL_W_ENC : MSA_2RF_FMT<0b110011000, 0b0, 0b011110>; 683class FEXUPL_D_ENC : MSA_2RF_FMT<0b110011000, 0b1, 0b011110>; 684 685class FEXUPR_W_ENC : MSA_2RF_FMT<0b110011001, 0b0, 0b011110>; 686class FEXUPR_D_ENC : MSA_2RF_FMT<0b110011001, 0b1, 0b011110>; 687 688class FFINT_S_W_ENC : MSA_2RF_FMT<0b110011110, 0b0, 0b011110>; 689class FFINT_S_D_ENC : MSA_2RF_FMT<0b110011110, 0b1, 0b011110>; 690 691class FFINT_U_W_ENC : MSA_2RF_FMT<0b110011111, 0b0, 0b011110>; 692class FFINT_U_D_ENC : MSA_2RF_FMT<0b110011111, 0b1, 0b011110>; 693 694class FFQL_W_ENC : MSA_2RF_FMT<0b110011010, 0b0, 0b011110>; 695class FFQL_D_ENC : MSA_2RF_FMT<0b110011010, 0b1, 0b011110>; 696 697class FFQR_W_ENC : MSA_2RF_FMT<0b110011011, 0b0, 0b011110>; 698class FFQR_D_ENC : MSA_2RF_FMT<0b110011011, 0b1, 0b011110>; 699 700class FILL_B_ENC : MSA_2R_FILL_FMT<0b11000000, 0b00, 0b011110>; 701class FILL_H_ENC : MSA_2R_FILL_FMT<0b11000000, 0b01, 0b011110>; 702class FILL_W_ENC : MSA_2R_FILL_FMT<0b11000000, 0b10, 0b011110>; 703class FILL_D_ENC : MSA_2R_FILL_D_FMT<0b11000000, 0b11, 0b011110>; 704 705class FLOG2_W_ENC : MSA_2RF_FMT<0b110010111, 0b0, 0b011110>; 706class FLOG2_D_ENC : MSA_2RF_FMT<0b110010111, 0b1, 0b011110>; 707 708class FMADD_W_ENC : MSA_3RF_FMT<0b0100, 0b0, 0b011011>; 709class FMADD_D_ENC : MSA_3RF_FMT<0b0100, 0b1, 0b011011>; 710 711class FMAX_W_ENC : MSA_3RF_FMT<0b1110, 0b0, 0b011011>; 712class FMAX_D_ENC : MSA_3RF_FMT<0b1110, 0b1, 0b011011>; 713 714class FMAX_A_W_ENC : MSA_3RF_FMT<0b1111, 0b0, 0b011011>; 715class FMAX_A_D_ENC : MSA_3RF_FMT<0b1111, 0b1, 0b011011>; 716 717class FMIN_W_ENC : MSA_3RF_FMT<0b1100, 0b0, 0b011011>; 718class FMIN_D_ENC : MSA_3RF_FMT<0b1100, 0b1, 0b011011>; 719 720class FMIN_A_W_ENC : MSA_3RF_FMT<0b1101, 0b0, 0b011011>; 721class FMIN_A_D_ENC : MSA_3RF_FMT<0b1101, 0b1, 0b011011>; 722 723class FMSUB_W_ENC : MSA_3RF_FMT<0b0101, 0b0, 0b011011>; 724class FMSUB_D_ENC : MSA_3RF_FMT<0b0101, 0b1, 0b011011>; 725 726class FMUL_W_ENC : MSA_3RF_FMT<0b0010, 0b0, 0b011011>; 727class FMUL_D_ENC : MSA_3RF_FMT<0b0010, 0b1, 0b011011>; 728 729class FRINT_W_ENC : MSA_2RF_FMT<0b110010110, 0b0, 0b011110>; 730class FRINT_D_ENC : MSA_2RF_FMT<0b110010110, 0b1, 0b011110>; 731 732class FRCP_W_ENC : MSA_2RF_FMT<0b110010101, 0b0, 0b011110>; 733class FRCP_D_ENC : MSA_2RF_FMT<0b110010101, 0b1, 0b011110>; 734 735class FRSQRT_W_ENC : MSA_2RF_FMT<0b110010100, 0b0, 0b011110>; 736class FRSQRT_D_ENC : MSA_2RF_FMT<0b110010100, 0b1, 0b011110>; 737 738class FSAF_W_ENC : MSA_3RF_FMT<0b1000, 0b0, 0b011010>; 739class FSAF_D_ENC : MSA_3RF_FMT<0b1000, 0b1, 0b011010>; 740 741class FSEQ_W_ENC : MSA_3RF_FMT<0b1010, 0b0, 0b011010>; 742class FSEQ_D_ENC : MSA_3RF_FMT<0b1010, 0b1, 0b011010>; 743 744class FSLE_W_ENC : MSA_3RF_FMT<0b1110, 0b0, 0b011010>; 745class FSLE_D_ENC : MSA_3RF_FMT<0b1110, 0b1, 0b011010>; 746 747class FSLT_W_ENC : MSA_3RF_FMT<0b1100, 0b0, 0b011010>; 748class FSLT_D_ENC : MSA_3RF_FMT<0b1100, 0b1, 0b011010>; 749 750class FSNE_W_ENC : MSA_3RF_FMT<0b1011, 0b0, 0b011100>; 751class FSNE_D_ENC : MSA_3RF_FMT<0b1011, 0b1, 0b011100>; 752 753class FSOR_W_ENC : MSA_3RF_FMT<0b1001, 0b0, 0b011100>; 754class FSOR_D_ENC : MSA_3RF_FMT<0b1001, 0b1, 0b011100>; 755 756class FSQRT_W_ENC : MSA_2RF_FMT<0b110010011, 0b0, 0b011110>; 757class FSQRT_D_ENC : MSA_2RF_FMT<0b110010011, 0b1, 0b011110>; 758 759class FSUB_W_ENC : MSA_3RF_FMT<0b0001, 0b0, 0b011011>; 760class FSUB_D_ENC : MSA_3RF_FMT<0b0001, 0b1, 0b011011>; 761 762class FSUEQ_W_ENC : MSA_3RF_FMT<0b1011, 0b0, 0b011010>; 763class FSUEQ_D_ENC : MSA_3RF_FMT<0b1011, 0b1, 0b011010>; 764 765class FSULE_W_ENC : MSA_3RF_FMT<0b1111, 0b0, 0b011010>; 766class FSULE_D_ENC : MSA_3RF_FMT<0b1111, 0b1, 0b011010>; 767 768class FSULT_W_ENC : MSA_3RF_FMT<0b1101, 0b0, 0b011010>; 769class FSULT_D_ENC : MSA_3RF_FMT<0b1101, 0b1, 0b011010>; 770 771class FSUN_W_ENC : MSA_3RF_FMT<0b1001, 0b0, 0b011010>; 772class FSUN_D_ENC : MSA_3RF_FMT<0b1001, 0b1, 0b011010>; 773 774class FSUNE_W_ENC : MSA_3RF_FMT<0b1010, 0b0, 0b011100>; 775class FSUNE_D_ENC : MSA_3RF_FMT<0b1010, 0b1, 0b011100>; 776 777class FTINT_S_W_ENC : MSA_2RF_FMT<0b110011100, 0b0, 0b011110>; 778class FTINT_S_D_ENC : MSA_2RF_FMT<0b110011100, 0b1, 0b011110>; 779 780class FTINT_U_W_ENC : MSA_2RF_FMT<0b110011101, 0b0, 0b011110>; 781class FTINT_U_D_ENC : MSA_2RF_FMT<0b110011101, 0b1, 0b011110>; 782 783class FTQ_H_ENC : MSA_3RF_FMT<0b1010, 0b0, 0b011011>; 784class FTQ_W_ENC : MSA_3RF_FMT<0b1010, 0b1, 0b011011>; 785 786class FTRUNC_S_W_ENC : MSA_2RF_FMT<0b110010001, 0b0, 0b011110>; 787class FTRUNC_S_D_ENC : MSA_2RF_FMT<0b110010001, 0b1, 0b011110>; 788 789class FTRUNC_U_W_ENC : MSA_2RF_FMT<0b110010010, 0b0, 0b011110>; 790class FTRUNC_U_D_ENC : MSA_2RF_FMT<0b110010010, 0b1, 0b011110>; 791 792class HADD_S_H_ENC : MSA_3R_FMT<0b100, 0b01, 0b010101>; 793class HADD_S_W_ENC : MSA_3R_FMT<0b100, 0b10, 0b010101>; 794class HADD_S_D_ENC : MSA_3R_FMT<0b100, 0b11, 0b010101>; 795 796class HADD_U_H_ENC : MSA_3R_FMT<0b101, 0b01, 0b010101>; 797class HADD_U_W_ENC : MSA_3R_FMT<0b101, 0b10, 0b010101>; 798class HADD_U_D_ENC : MSA_3R_FMT<0b101, 0b11, 0b010101>; 799 800class HSUB_S_H_ENC : MSA_3R_FMT<0b110, 0b01, 0b010101>; 801class HSUB_S_W_ENC : MSA_3R_FMT<0b110, 0b10, 0b010101>; 802class HSUB_S_D_ENC : MSA_3R_FMT<0b110, 0b11, 0b010101>; 803 804class HSUB_U_H_ENC : MSA_3R_FMT<0b111, 0b01, 0b010101>; 805class HSUB_U_W_ENC : MSA_3R_FMT<0b111, 0b10, 0b010101>; 806class HSUB_U_D_ENC : MSA_3R_FMT<0b111, 0b11, 0b010101>; 807 808class ILVEV_B_ENC : MSA_3R_FMT<0b110, 0b00, 0b010100>; 809class ILVEV_H_ENC : MSA_3R_FMT<0b110, 0b01, 0b010100>; 810class ILVEV_W_ENC : MSA_3R_FMT<0b110, 0b10, 0b010100>; 811class ILVEV_D_ENC : MSA_3R_FMT<0b110, 0b11, 0b010100>; 812 813class ILVL_B_ENC : MSA_3R_FMT<0b100, 0b00, 0b010100>; 814class ILVL_H_ENC : MSA_3R_FMT<0b100, 0b01, 0b010100>; 815class ILVL_W_ENC : MSA_3R_FMT<0b100, 0b10, 0b010100>; 816class ILVL_D_ENC : MSA_3R_FMT<0b100, 0b11, 0b010100>; 817 818class ILVOD_B_ENC : MSA_3R_FMT<0b111, 0b00, 0b010100>; 819class ILVOD_H_ENC : MSA_3R_FMT<0b111, 0b01, 0b010100>; 820class ILVOD_W_ENC : MSA_3R_FMT<0b111, 0b10, 0b010100>; 821class ILVOD_D_ENC : MSA_3R_FMT<0b111, 0b11, 0b010100>; 822 823class ILVR_B_ENC : MSA_3R_FMT<0b101, 0b00, 0b010100>; 824class ILVR_H_ENC : MSA_3R_FMT<0b101, 0b01, 0b010100>; 825class ILVR_W_ENC : MSA_3R_FMT<0b101, 0b10, 0b010100>; 826class ILVR_D_ENC : MSA_3R_FMT<0b101, 0b11, 0b010100>; 827 828class INSERT_B_ENC : MSA_ELM_INSERT_B_FMT<0b0100, 0b011001>; 829class INSERT_H_ENC : MSA_ELM_INSERT_H_FMT<0b0100, 0b011001>; 830class INSERT_W_ENC : MSA_ELM_INSERT_W_FMT<0b0100, 0b011001>; 831class INSERT_D_ENC : MSA_ELM_INSERT_D_FMT<0b0100, 0b011001>; 832 833class INSVE_B_ENC : MSA_ELM_B_FMT<0b0101, 0b011001>; 834class INSVE_H_ENC : MSA_ELM_H_FMT<0b0101, 0b011001>; 835class INSVE_W_ENC : MSA_ELM_W_FMT<0b0101, 0b011001>; 836class INSVE_D_ENC : MSA_ELM_D_FMT<0b0101, 0b011001>; 837 838class LD_B_ENC : MSA_MI10_FMT<0b00, 0b1000>; 839class LD_H_ENC : MSA_MI10_FMT<0b01, 0b1000>; 840class LD_W_ENC : MSA_MI10_FMT<0b10, 0b1000>; 841class LD_D_ENC : MSA_MI10_FMT<0b11, 0b1000>; 842 843class LDI_B_ENC : MSA_I10_FMT<0b110, 0b00, 0b000111>; 844class LDI_H_ENC : MSA_I10_FMT<0b110, 0b01, 0b000111>; 845class LDI_W_ENC : MSA_I10_FMT<0b110, 0b10, 0b000111>; 846class LDI_D_ENC : MSA_I10_FMT<0b110, 0b11, 0b000111>; 847 848class LSA_ENC : SPECIAL_LSA_FMT<0b000101>; 849class DLSA_ENC : SPECIAL_DLSA_FMT<0b010101>; 850 851class MADD_Q_H_ENC : MSA_3RF_FMT<0b0101, 0b0, 0b011100>; 852class MADD_Q_W_ENC : MSA_3RF_FMT<0b0101, 0b1, 0b011100>; 853 854class MADDR_Q_H_ENC : MSA_3RF_FMT<0b1101, 0b0, 0b011100>; 855class MADDR_Q_W_ENC : MSA_3RF_FMT<0b1101, 0b1, 0b011100>; 856 857class MADDV_B_ENC : MSA_3R_FMT<0b001, 0b00, 0b010010>; 858class MADDV_H_ENC : MSA_3R_FMT<0b001, 0b01, 0b010010>; 859class MADDV_W_ENC : MSA_3R_FMT<0b001, 0b10, 0b010010>; 860class MADDV_D_ENC : MSA_3R_FMT<0b001, 0b11, 0b010010>; 861 862class MAX_A_B_ENC : MSA_3R_FMT<0b110, 0b00, 0b001110>; 863class MAX_A_H_ENC : MSA_3R_FMT<0b110, 0b01, 0b001110>; 864class MAX_A_W_ENC : MSA_3R_FMT<0b110, 0b10, 0b001110>; 865class MAX_A_D_ENC : MSA_3R_FMT<0b110, 0b11, 0b001110>; 866 867class MAX_S_B_ENC : MSA_3R_FMT<0b010, 0b00, 0b001110>; 868class MAX_S_H_ENC : MSA_3R_FMT<0b010, 0b01, 0b001110>; 869class MAX_S_W_ENC : MSA_3R_FMT<0b010, 0b10, 0b001110>; 870class MAX_S_D_ENC : MSA_3R_FMT<0b010, 0b11, 0b001110>; 871 872class MAX_U_B_ENC : MSA_3R_FMT<0b011, 0b00, 0b001110>; 873class MAX_U_H_ENC : MSA_3R_FMT<0b011, 0b01, 0b001110>; 874class MAX_U_W_ENC : MSA_3R_FMT<0b011, 0b10, 0b001110>; 875class MAX_U_D_ENC : MSA_3R_FMT<0b011, 0b11, 0b001110>; 876 877class MAXI_S_B_ENC : MSA_I5_FMT<0b010, 0b00, 0b000110>; 878class MAXI_S_H_ENC : MSA_I5_FMT<0b010, 0b01, 0b000110>; 879class MAXI_S_W_ENC : MSA_I5_FMT<0b010, 0b10, 0b000110>; 880class MAXI_S_D_ENC : MSA_I5_FMT<0b010, 0b11, 0b000110>; 881 882class MAXI_U_B_ENC : MSA_I5_FMT<0b011, 0b00, 0b000110>; 883class MAXI_U_H_ENC : MSA_I5_FMT<0b011, 0b01, 0b000110>; 884class MAXI_U_W_ENC : MSA_I5_FMT<0b011, 0b10, 0b000110>; 885class MAXI_U_D_ENC : MSA_I5_FMT<0b011, 0b11, 0b000110>; 886 887class MIN_A_B_ENC : MSA_3R_FMT<0b111, 0b00, 0b001110>; 888class MIN_A_H_ENC : MSA_3R_FMT<0b111, 0b01, 0b001110>; 889class MIN_A_W_ENC : MSA_3R_FMT<0b111, 0b10, 0b001110>; 890class MIN_A_D_ENC : MSA_3R_FMT<0b111, 0b11, 0b001110>; 891 892class MIN_S_B_ENC : MSA_3R_FMT<0b100, 0b00, 0b001110>; 893class MIN_S_H_ENC : MSA_3R_FMT<0b100, 0b01, 0b001110>; 894class MIN_S_W_ENC : MSA_3R_FMT<0b100, 0b10, 0b001110>; 895class MIN_S_D_ENC : MSA_3R_FMT<0b100, 0b11, 0b001110>; 896 897class MIN_U_B_ENC : MSA_3R_FMT<0b101, 0b00, 0b001110>; 898class MIN_U_H_ENC : MSA_3R_FMT<0b101, 0b01, 0b001110>; 899class MIN_U_W_ENC : MSA_3R_FMT<0b101, 0b10, 0b001110>; 900class MIN_U_D_ENC : MSA_3R_FMT<0b101, 0b11, 0b001110>; 901 902class MINI_S_B_ENC : MSA_I5_FMT<0b100, 0b00, 0b000110>; 903class MINI_S_H_ENC : MSA_I5_FMT<0b100, 0b01, 0b000110>; 904class MINI_S_W_ENC : MSA_I5_FMT<0b100, 0b10, 0b000110>; 905class MINI_S_D_ENC : MSA_I5_FMT<0b100, 0b11, 0b000110>; 906 907class MINI_U_B_ENC : MSA_I5_FMT<0b101, 0b00, 0b000110>; 908class MINI_U_H_ENC : MSA_I5_FMT<0b101, 0b01, 0b000110>; 909class MINI_U_W_ENC : MSA_I5_FMT<0b101, 0b10, 0b000110>; 910class MINI_U_D_ENC : MSA_I5_FMT<0b101, 0b11, 0b000110>; 911 912class MOD_S_B_ENC : MSA_3R_FMT<0b110, 0b00, 0b010010>; 913class MOD_S_H_ENC : MSA_3R_FMT<0b110, 0b01, 0b010010>; 914class MOD_S_W_ENC : MSA_3R_FMT<0b110, 0b10, 0b010010>; 915class MOD_S_D_ENC : MSA_3R_FMT<0b110, 0b11, 0b010010>; 916 917class MOD_U_B_ENC : MSA_3R_FMT<0b111, 0b00, 0b010010>; 918class MOD_U_H_ENC : MSA_3R_FMT<0b111, 0b01, 0b010010>; 919class MOD_U_W_ENC : MSA_3R_FMT<0b111, 0b10, 0b010010>; 920class MOD_U_D_ENC : MSA_3R_FMT<0b111, 0b11, 0b010010>; 921 922class MOVE_V_ENC : MSA_ELM_FMT<0b0010111110, 0b011001>; 923 924class MSUB_Q_H_ENC : MSA_3RF_FMT<0b0110, 0b0, 0b011100>; 925class MSUB_Q_W_ENC : MSA_3RF_FMT<0b0110, 0b1, 0b011100>; 926 927class MSUBR_Q_H_ENC : MSA_3RF_FMT<0b1110, 0b0, 0b011100>; 928class MSUBR_Q_W_ENC : MSA_3RF_FMT<0b1110, 0b1, 0b011100>; 929 930class MSUBV_B_ENC : MSA_3R_FMT<0b010, 0b00, 0b010010>; 931class MSUBV_H_ENC : MSA_3R_FMT<0b010, 0b01, 0b010010>; 932class MSUBV_W_ENC : MSA_3R_FMT<0b010, 0b10, 0b010010>; 933class MSUBV_D_ENC : MSA_3R_FMT<0b010, 0b11, 0b010010>; 934 935class MUL_Q_H_ENC : MSA_3RF_FMT<0b0100, 0b0, 0b011100>; 936class MUL_Q_W_ENC : MSA_3RF_FMT<0b0100, 0b1, 0b011100>; 937 938class MULR_Q_H_ENC : MSA_3RF_FMT<0b1100, 0b0, 0b011100>; 939class MULR_Q_W_ENC : MSA_3RF_FMT<0b1100, 0b1, 0b011100>; 940 941class MULV_B_ENC : MSA_3R_FMT<0b000, 0b00, 0b010010>; 942class MULV_H_ENC : MSA_3R_FMT<0b000, 0b01, 0b010010>; 943class MULV_W_ENC : MSA_3R_FMT<0b000, 0b10, 0b010010>; 944class MULV_D_ENC : MSA_3R_FMT<0b000, 0b11, 0b010010>; 945 946class NLOC_B_ENC : MSA_2R_FMT<0b11000010, 0b00, 0b011110>; 947class NLOC_H_ENC : MSA_2R_FMT<0b11000010, 0b01, 0b011110>; 948class NLOC_W_ENC : MSA_2R_FMT<0b11000010, 0b10, 0b011110>; 949class NLOC_D_ENC : MSA_2R_FMT<0b11000010, 0b11, 0b011110>; 950 951class NLZC_B_ENC : MSA_2R_FMT<0b11000011, 0b00, 0b011110>; 952class NLZC_H_ENC : MSA_2R_FMT<0b11000011, 0b01, 0b011110>; 953class NLZC_W_ENC : MSA_2R_FMT<0b11000011, 0b10, 0b011110>; 954class NLZC_D_ENC : MSA_2R_FMT<0b11000011, 0b11, 0b011110>; 955 956class NOR_V_ENC : MSA_VEC_FMT<0b00010, 0b011110>; 957 958class NORI_B_ENC : MSA_I8_FMT<0b10, 0b000000>; 959 960class OR_V_ENC : MSA_VEC_FMT<0b00001, 0b011110>; 961 962class ORI_B_ENC : MSA_I8_FMT<0b01, 0b000000>; 963 964class PCKEV_B_ENC : MSA_3R_FMT<0b010, 0b00, 0b010100>; 965class PCKEV_H_ENC : MSA_3R_FMT<0b010, 0b01, 0b010100>; 966class PCKEV_W_ENC : MSA_3R_FMT<0b010, 0b10, 0b010100>; 967class PCKEV_D_ENC : MSA_3R_FMT<0b010, 0b11, 0b010100>; 968 969class PCKOD_B_ENC : MSA_3R_FMT<0b011, 0b00, 0b010100>; 970class PCKOD_H_ENC : MSA_3R_FMT<0b011, 0b01, 0b010100>; 971class PCKOD_W_ENC : MSA_3R_FMT<0b011, 0b10, 0b010100>; 972class PCKOD_D_ENC : MSA_3R_FMT<0b011, 0b11, 0b010100>; 973 974class PCNT_B_ENC : MSA_2R_FMT<0b11000001, 0b00, 0b011110>; 975class PCNT_H_ENC : MSA_2R_FMT<0b11000001, 0b01, 0b011110>; 976class PCNT_W_ENC : MSA_2R_FMT<0b11000001, 0b10, 0b011110>; 977class PCNT_D_ENC : MSA_2R_FMT<0b11000001, 0b11, 0b011110>; 978 979class SAT_S_B_ENC : MSA_BIT_B_FMT<0b000, 0b001010>; 980class SAT_S_H_ENC : MSA_BIT_H_FMT<0b000, 0b001010>; 981class SAT_S_W_ENC : MSA_BIT_W_FMT<0b000, 0b001010>; 982class SAT_S_D_ENC : MSA_BIT_D_FMT<0b000, 0b001010>; 983 984class SAT_U_B_ENC : MSA_BIT_B_FMT<0b001, 0b001010>; 985class SAT_U_H_ENC : MSA_BIT_H_FMT<0b001, 0b001010>; 986class SAT_U_W_ENC : MSA_BIT_W_FMT<0b001, 0b001010>; 987class SAT_U_D_ENC : MSA_BIT_D_FMT<0b001, 0b001010>; 988 989class SHF_B_ENC : MSA_I8_FMT<0b00, 0b000010>; 990class SHF_H_ENC : MSA_I8_FMT<0b01, 0b000010>; 991class SHF_W_ENC : MSA_I8_FMT<0b10, 0b000010>; 992 993class SLD_B_ENC : MSA_3R_INDEX_FMT<0b000, 0b00, 0b010100>; 994class SLD_H_ENC : MSA_3R_INDEX_FMT<0b000, 0b01, 0b010100>; 995class SLD_W_ENC : MSA_3R_INDEX_FMT<0b000, 0b10, 0b010100>; 996class SLD_D_ENC : MSA_3R_INDEX_FMT<0b000, 0b11, 0b010100>; 997 998class SLDI_B_ENC : MSA_ELM_B_FMT<0b0000, 0b011001>; 999class SLDI_H_ENC : MSA_ELM_H_FMT<0b0000, 0b011001>; 1000class SLDI_W_ENC : MSA_ELM_W_FMT<0b0000, 0b011001>; 1001class SLDI_D_ENC : MSA_ELM_D_FMT<0b0000, 0b011001>; 1002 1003class SLL_B_ENC : MSA_3R_FMT<0b000, 0b00, 0b001101>; 1004class SLL_H_ENC : MSA_3R_FMT<0b000, 0b01, 0b001101>; 1005class SLL_W_ENC : MSA_3R_FMT<0b000, 0b10, 0b001101>; 1006class SLL_D_ENC : MSA_3R_FMT<0b000, 0b11, 0b001101>; 1007 1008class SLLI_B_ENC : MSA_BIT_B_FMT<0b000, 0b001001>; 1009class SLLI_H_ENC : MSA_BIT_H_FMT<0b000, 0b001001>; 1010class SLLI_W_ENC : MSA_BIT_W_FMT<0b000, 0b001001>; 1011class SLLI_D_ENC : MSA_BIT_D_FMT<0b000, 0b001001>; 1012 1013class SPLAT_B_ENC : MSA_3R_INDEX_FMT<0b001, 0b00, 0b010100>; 1014class SPLAT_H_ENC : MSA_3R_INDEX_FMT<0b001, 0b01, 0b010100>; 1015class SPLAT_W_ENC : MSA_3R_INDEX_FMT<0b001, 0b10, 0b010100>; 1016class SPLAT_D_ENC : MSA_3R_INDEX_FMT<0b001, 0b11, 0b010100>; 1017 1018class SPLATI_B_ENC : MSA_ELM_B_FMT<0b0001, 0b011001>; 1019class SPLATI_H_ENC : MSA_ELM_H_FMT<0b0001, 0b011001>; 1020class SPLATI_W_ENC : MSA_ELM_W_FMT<0b0001, 0b011001>; 1021class SPLATI_D_ENC : MSA_ELM_D_FMT<0b0001, 0b011001>; 1022 1023class SRA_B_ENC : MSA_3R_FMT<0b001, 0b00, 0b001101>; 1024class SRA_H_ENC : MSA_3R_FMT<0b001, 0b01, 0b001101>; 1025class SRA_W_ENC : MSA_3R_FMT<0b001, 0b10, 0b001101>; 1026class SRA_D_ENC : MSA_3R_FMT<0b001, 0b11, 0b001101>; 1027 1028class SRAI_B_ENC : MSA_BIT_B_FMT<0b001, 0b001001>; 1029class SRAI_H_ENC : MSA_BIT_H_FMT<0b001, 0b001001>; 1030class SRAI_W_ENC : MSA_BIT_W_FMT<0b001, 0b001001>; 1031class SRAI_D_ENC : MSA_BIT_D_FMT<0b001, 0b001001>; 1032 1033class SRAR_B_ENC : MSA_3R_FMT<0b001, 0b00, 0b010101>; 1034class SRAR_H_ENC : MSA_3R_FMT<0b001, 0b01, 0b010101>; 1035class SRAR_W_ENC : MSA_3R_FMT<0b001, 0b10, 0b010101>; 1036class SRAR_D_ENC : MSA_3R_FMT<0b001, 0b11, 0b010101>; 1037 1038class SRARI_B_ENC : MSA_BIT_B_FMT<0b010, 0b001010>; 1039class SRARI_H_ENC : MSA_BIT_H_FMT<0b010, 0b001010>; 1040class SRARI_W_ENC : MSA_BIT_W_FMT<0b010, 0b001010>; 1041class SRARI_D_ENC : MSA_BIT_D_FMT<0b010, 0b001010>; 1042 1043class SRL_B_ENC : MSA_3R_FMT<0b010, 0b00, 0b001101>; 1044class SRL_H_ENC : MSA_3R_FMT<0b010, 0b01, 0b001101>; 1045class SRL_W_ENC : MSA_3R_FMT<0b010, 0b10, 0b001101>; 1046class SRL_D_ENC : MSA_3R_FMT<0b010, 0b11, 0b001101>; 1047 1048class SRLI_B_ENC : MSA_BIT_B_FMT<0b010, 0b001001>; 1049class SRLI_H_ENC : MSA_BIT_H_FMT<0b010, 0b001001>; 1050class SRLI_W_ENC : MSA_BIT_W_FMT<0b010, 0b001001>; 1051class SRLI_D_ENC : MSA_BIT_D_FMT<0b010, 0b001001>; 1052 1053class SRLR_B_ENC : MSA_3R_FMT<0b010, 0b00, 0b010101>; 1054class SRLR_H_ENC : MSA_3R_FMT<0b010, 0b01, 0b010101>; 1055class SRLR_W_ENC : MSA_3R_FMT<0b010, 0b10, 0b010101>; 1056class SRLR_D_ENC : MSA_3R_FMT<0b010, 0b11, 0b010101>; 1057 1058class SRLRI_B_ENC : MSA_BIT_B_FMT<0b011, 0b001010>; 1059class SRLRI_H_ENC : MSA_BIT_H_FMT<0b011, 0b001010>; 1060class SRLRI_W_ENC : MSA_BIT_W_FMT<0b011, 0b001010>; 1061class SRLRI_D_ENC : MSA_BIT_D_FMT<0b011, 0b001010>; 1062 1063class ST_B_ENC : MSA_MI10_FMT<0b00, 0b1001>; 1064class ST_H_ENC : MSA_MI10_FMT<0b01, 0b1001>; 1065class ST_W_ENC : MSA_MI10_FMT<0b10, 0b1001>; 1066class ST_D_ENC : MSA_MI10_FMT<0b11, 0b1001>; 1067 1068class SUBS_S_B_ENC : MSA_3R_FMT<0b000, 0b00, 0b010001>; 1069class SUBS_S_H_ENC : MSA_3R_FMT<0b000, 0b01, 0b010001>; 1070class SUBS_S_W_ENC : MSA_3R_FMT<0b000, 0b10, 0b010001>; 1071class SUBS_S_D_ENC : MSA_3R_FMT<0b000, 0b11, 0b010001>; 1072 1073class SUBS_U_B_ENC : MSA_3R_FMT<0b001, 0b00, 0b010001>; 1074class SUBS_U_H_ENC : MSA_3R_FMT<0b001, 0b01, 0b010001>; 1075class SUBS_U_W_ENC : MSA_3R_FMT<0b001, 0b10, 0b010001>; 1076class SUBS_U_D_ENC : MSA_3R_FMT<0b001, 0b11, 0b010001>; 1077 1078class SUBSUS_U_B_ENC : MSA_3R_FMT<0b010, 0b00, 0b010001>; 1079class SUBSUS_U_H_ENC : MSA_3R_FMT<0b010, 0b01, 0b010001>; 1080class SUBSUS_U_W_ENC : MSA_3R_FMT<0b010, 0b10, 0b010001>; 1081class SUBSUS_U_D_ENC : MSA_3R_FMT<0b010, 0b11, 0b010001>; 1082 1083class SUBSUU_S_B_ENC : MSA_3R_FMT<0b011, 0b00, 0b010001>; 1084class SUBSUU_S_H_ENC : MSA_3R_FMT<0b011, 0b01, 0b010001>; 1085class SUBSUU_S_W_ENC : MSA_3R_FMT<0b011, 0b10, 0b010001>; 1086class SUBSUU_S_D_ENC : MSA_3R_FMT<0b011, 0b11, 0b010001>; 1087 1088class SUBV_B_ENC : MSA_3R_FMT<0b001, 0b00, 0b001110>; 1089class SUBV_H_ENC : MSA_3R_FMT<0b001, 0b01, 0b001110>; 1090class SUBV_W_ENC : MSA_3R_FMT<0b001, 0b10, 0b001110>; 1091class SUBV_D_ENC : MSA_3R_FMT<0b001, 0b11, 0b001110>; 1092 1093class SUBVI_B_ENC : MSA_I5_FMT<0b001, 0b00, 0b000110>; 1094class SUBVI_H_ENC : MSA_I5_FMT<0b001, 0b01, 0b000110>; 1095class SUBVI_W_ENC : MSA_I5_FMT<0b001, 0b10, 0b000110>; 1096class SUBVI_D_ENC : MSA_I5_FMT<0b001, 0b11, 0b000110>; 1097 1098class VSHF_B_ENC : MSA_3R_FMT<0b000, 0b00, 0b010101>; 1099class VSHF_H_ENC : MSA_3R_FMT<0b000, 0b01, 0b010101>; 1100class VSHF_W_ENC : MSA_3R_FMT<0b000, 0b10, 0b010101>; 1101class VSHF_D_ENC : MSA_3R_FMT<0b000, 0b11, 0b010101>; 1102 1103class XOR_V_ENC : MSA_VEC_FMT<0b00011, 0b011110>; 1104 1105class XORI_B_ENC : MSA_I8_FMT<0b11, 0b000000>; 1106 1107// Instruction desc. 1108class MSA_BIT_B_DESC_BASE<string instr_asm, SDPatternOperator OpNode, 1109 ComplexPattern Imm, RegisterOperand ROWD, 1110 RegisterOperand ROWS = ROWD, 1111 InstrItinClass itin = NoItinerary> { 1112 dag OutOperandList = (outs ROWD:$wd); 1113 dag InOperandList = (ins ROWS:$ws, vsplat_uimm3:$m); 1114 string AsmString = !strconcat(instr_asm, "\t$wd, $ws, $m"); 1115 list<dag> Pattern = [(set ROWD:$wd, (OpNode ROWS:$ws, Imm:$m))]; 1116 InstrItinClass Itinerary = itin; 1117} 1118 1119class MSA_BIT_H_DESC_BASE<string instr_asm, SDPatternOperator OpNode, 1120 ComplexPattern Imm, RegisterOperand ROWD, 1121 RegisterOperand ROWS = ROWD, 1122 InstrItinClass itin = NoItinerary> { 1123 dag OutOperandList = (outs ROWD:$wd); 1124 dag InOperandList = (ins ROWS:$ws, vsplat_uimm4:$m); 1125 string AsmString = !strconcat(instr_asm, "\t$wd, $ws, $m"); 1126 list<dag> Pattern = [(set ROWD:$wd, (OpNode ROWS:$ws, Imm:$m))]; 1127 InstrItinClass Itinerary = itin; 1128} 1129 1130class MSA_BIT_W_DESC_BASE<string instr_asm, SDPatternOperator OpNode, 1131 ComplexPattern Imm, RegisterOperand ROWD, 1132 RegisterOperand ROWS = ROWD, 1133 InstrItinClass itin = NoItinerary> { 1134 dag OutOperandList = (outs ROWD:$wd); 1135 dag InOperandList = (ins ROWS:$ws, vsplat_uimm5:$m); 1136 string AsmString = !strconcat(instr_asm, "\t$wd, $ws, $m"); 1137 list<dag> Pattern = [(set ROWD:$wd, (OpNode ROWS:$ws, Imm:$m))]; 1138 InstrItinClass Itinerary = itin; 1139} 1140 1141class MSA_BIT_D_DESC_BASE<string instr_asm, SDPatternOperator OpNode, 1142 ComplexPattern Imm, RegisterOperand ROWD, 1143 RegisterOperand ROWS = ROWD, 1144 InstrItinClass itin = NoItinerary> { 1145 dag OutOperandList = (outs ROWD:$wd); 1146 dag InOperandList = (ins ROWS:$ws, vsplat_uimm6:$m); 1147 string AsmString = !strconcat(instr_asm, "\t$wd, $ws, $m"); 1148 list<dag> Pattern = [(set ROWD:$wd, (OpNode ROWS:$ws, Imm:$m))]; 1149 InstrItinClass Itinerary = itin; 1150} 1151 1152class MSA_BIT_X_DESC_BASE<string instr_asm, SDPatternOperator OpNode, 1153 Operand ImmOp, ImmLeaf Imm, RegisterOperand ROWD, 1154 RegisterOperand ROWS = ROWD, 1155 InstrItinClass itin = NoItinerary> { 1156 dag OutOperandList = (outs ROWD:$wd); 1157 dag InOperandList = (ins ROWS:$ws, ImmOp:$m); 1158 string AsmString = !strconcat(instr_asm, "\t$wd, $ws, $m"); 1159 list<dag> Pattern = [(set ROWD:$wd, (OpNode ROWS:$ws, Imm:$m))]; 1160 InstrItinClass Itinerary = itin; 1161} 1162 1163class MSA_BIT_BINSXI_DESC_BASE<string instr_asm, ValueType Ty, 1164 SplatComplexPattern Mask, RegisterOperand ROWD, 1165 RegisterOperand ROWS = ROWD, 1166 InstrItinClass itin = NoItinerary> { 1167 dag OutOperandList = (outs ROWD:$wd); 1168 dag InOperandList = (ins ROWD:$wd_in, ROWS:$ws, Mask.OpClass:$m); 1169 string AsmString = !strconcat(instr_asm, "\t$wd, $ws, $m"); 1170 // Note that binsxi and vselect treat the condition operand the opposite 1171 // way to each other. 1172 // (vselect cond, if_set, if_clear) 1173 // (BSEL_V cond, if_clear, if_set) 1174 list<dag> Pattern = [(set ROWD:$wd, (vselect (Ty Mask:$m), (Ty ROWD:$ws), 1175 ROWS:$wd_in))]; 1176 InstrItinClass Itinerary = itin; 1177 string Constraints = "$wd = $wd_in"; 1178} 1179 1180class MSA_BIT_BINSLI_DESC_BASE<string instr_asm, ValueType Ty, 1181 SplatComplexPattern ImmOp, RegisterOperand ROWD, 1182 RegisterOperand ROWS = ROWD, 1183 InstrItinClass itin = NoItinerary> : 1184 MSA_BIT_BINSXI_DESC_BASE<instr_asm, Ty, ImmOp, ROWD, ROWS, itin>; 1185 1186class MSA_BIT_BINSRI_DESC_BASE<string instr_asm, ValueType Ty, 1187 SplatComplexPattern ImmOp, RegisterOperand ROWD, 1188 RegisterOperand ROWS = ROWD, 1189 InstrItinClass itin = NoItinerary> : 1190 MSA_BIT_BINSXI_DESC_BASE<instr_asm, Ty, ImmOp, ROWD, ROWS, itin>; 1191 1192class MSA_BIT_SPLAT_DESC_BASE<string instr_asm, SDPatternOperator OpNode, 1193 SplatComplexPattern SplatImm, 1194 RegisterOperand ROWD, RegisterOperand ROWS = ROWD, 1195 InstrItinClass itin = NoItinerary> { 1196 dag OutOperandList = (outs ROWD:$wd); 1197 dag InOperandList = (ins ROWS:$ws, SplatImm.OpClass:$m); 1198 string AsmString = !strconcat(instr_asm, "\t$wd, $ws, $m"); 1199 list<dag> Pattern = [(set ROWD:$wd, (OpNode ROWS:$ws, SplatImm:$m))]; 1200 InstrItinClass Itinerary = itin; 1201} 1202 1203class MSA_COPY_DESC_BASE<string instr_asm, SDPatternOperator OpNode, 1204 ValueType VecTy, Operand ImmOp, ImmLeaf Imm, 1205 RegisterOperand ROD, RegisterOperand ROWS, 1206 InstrItinClass itin = NoItinerary> { 1207 dag OutOperandList = (outs ROD:$rd); 1208 dag InOperandList = (ins ROWS:$ws, ImmOp:$n); 1209 string AsmString = !strconcat(instr_asm, "\t$rd, $ws[$n]"); 1210 list<dag> Pattern = [(set ROD:$rd, (OpNode (VecTy ROWS:$ws), Imm:$n))]; 1211 InstrItinClass Itinerary = itin; 1212} 1213 1214class MSA_ELM_SLD_DESC_BASE<string instr_asm, SDPatternOperator OpNode, 1215 RegisterOperand ROWD, RegisterOperand ROWS, 1216 Operand ImmOp, ImmLeaf Imm, 1217 InstrItinClass itin = NoItinerary> { 1218 dag OutOperandList = (outs ROWD:$wd); 1219 dag InOperandList = (ins ROWD:$wd_in, ROWS:$ws, ImmOp:$n); 1220 string AsmString = !strconcat(instr_asm, "\t$wd, $ws[$n]"); 1221 list<dag> Pattern = [(set ROWD:$wd, (OpNode ROWD:$wd_in, ROWS:$ws, 1222 Imm:$n))]; 1223 string Constraints = "$wd = $wd_in"; 1224 InstrItinClass Itinerary = itin; 1225} 1226 1227class MSA_COPY_PSEUDO_BASE<SDPatternOperator OpNode, ValueType VecTy, 1228 Operand ImmOp, ImmLeaf Imm, RegisterClass RCD, 1229 RegisterClass RCWS> : 1230 MSAPseudo<(outs RCD:$wd), (ins RCWS:$ws, ImmOp:$n), 1231 [(set RCD:$wd, (OpNode (VecTy RCWS:$ws), Imm:$n))]> { 1232 bit usesCustomInserter = 1; 1233} 1234 1235class MSA_I5_DESC_BASE<string instr_asm, SDPatternOperator OpNode, 1236 SplatComplexPattern SplatImm, RegisterOperand ROWD, 1237 RegisterOperand ROWS = ROWD, 1238 InstrItinClass itin = NoItinerary> { 1239 dag OutOperandList = (outs ROWD:$wd); 1240 dag InOperandList = (ins ROWS:$ws, SplatImm.OpClass:$imm); 1241 string AsmString = !strconcat(instr_asm, "\t$wd, $ws, $imm"); 1242 list<dag> Pattern = [(set ROWD:$wd, (OpNode ROWS:$ws, SplatImm:$imm))]; 1243 InstrItinClass Itinerary = itin; 1244} 1245 1246class MSA_I8_DESC_BASE<string instr_asm, SDPatternOperator OpNode, 1247 SplatComplexPattern SplatImm, RegisterOperand ROWD, 1248 RegisterOperand ROWS = ROWD, 1249 InstrItinClass itin = NoItinerary> { 1250 dag OutOperandList = (outs ROWD:$wd); 1251 dag InOperandList = (ins ROWS:$ws, SplatImm.OpClass:$u8); 1252 string AsmString = !strconcat(instr_asm, "\t$wd, $ws, $u8"); 1253 list<dag> Pattern = [(set ROWD:$wd, (OpNode ROWS:$ws, SplatImm:$u8))]; 1254 InstrItinClass Itinerary = itin; 1255} 1256 1257class MSA_I8_SHF_DESC_BASE<string instr_asm, RegisterOperand ROWD, 1258 RegisterOperand ROWS = ROWD, 1259 InstrItinClass itin = NoItinerary> { 1260 dag OutOperandList = (outs ROWD:$wd); 1261 dag InOperandList = (ins ROWS:$ws, uimm8:$u8); 1262 string AsmString = !strconcat(instr_asm, "\t$wd, $ws, $u8"); 1263 list<dag> Pattern = [(set ROWD:$wd, (MipsSHF immZExt8:$u8, ROWS:$ws))]; 1264 InstrItinClass Itinerary = itin; 1265} 1266 1267class MSA_I10_LDI_DESC_BASE<string instr_asm, RegisterOperand ROWD, 1268 InstrItinClass itin = NoItinerary> { 1269 dag OutOperandList = (outs ROWD:$wd); 1270 dag InOperandList = (ins vsplat_simm10:$s10); 1271 string AsmString = !strconcat(instr_asm, "\t$wd, $s10"); 1272 // LDI is matched using custom matching code in MipsSEISelDAGToDAG.cpp 1273 list<dag> Pattern = []; 1274 bit hasSideEffects = 0; 1275 InstrItinClass Itinerary = itin; 1276} 1277 1278class MSA_2R_DESC_BASE<string instr_asm, SDPatternOperator OpNode, 1279 RegisterOperand ROWD, RegisterOperand ROWS = ROWD, 1280 InstrItinClass itin = NoItinerary> { 1281 dag OutOperandList = (outs ROWD:$wd); 1282 dag InOperandList = (ins ROWS:$ws); 1283 string AsmString = !strconcat(instr_asm, "\t$wd, $ws"); 1284 list<dag> Pattern = [(set ROWD:$wd, (OpNode ROWS:$ws))]; 1285 InstrItinClass Itinerary = itin; 1286} 1287 1288class MSA_2R_FILL_DESC_BASE<string instr_asm, ValueType VT, 1289 SDPatternOperator OpNode, RegisterOperand ROWD, 1290 RegisterOperand ROS = ROWD, 1291 InstrItinClass itin = NoItinerary> { 1292 dag OutOperandList = (outs ROWD:$wd); 1293 dag InOperandList = (ins ROS:$rs); 1294 string AsmString = !strconcat(instr_asm, "\t$wd, $rs"); 1295 list<dag> Pattern = [(set ROWD:$wd, (VT (OpNode ROS:$rs)))]; 1296 InstrItinClass Itinerary = itin; 1297} 1298 1299class MSA_2R_FILL_PSEUDO_BASE<ValueType VT, SDPatternOperator OpNode, 1300 RegisterClass RCWD, RegisterClass RCWS = RCWD> : 1301 MSAPseudo<(outs RCWD:$wd), (ins RCWS:$fs), 1302 [(set RCWD:$wd, (OpNode RCWS:$fs))]> { 1303 let usesCustomInserter = 1; 1304} 1305 1306class MSA_2RF_DESC_BASE<string instr_asm, SDPatternOperator OpNode, 1307 RegisterOperand ROWD, RegisterOperand ROWS = ROWD, 1308 InstrItinClass itin = NoItinerary> { 1309 dag OutOperandList = (outs ROWD:$wd); 1310 dag InOperandList = (ins ROWS:$ws); 1311 string AsmString = !strconcat(instr_asm, "\t$wd, $ws"); 1312 list<dag> Pattern = [(set ROWD:$wd, (OpNode ROWS:$ws))]; 1313 InstrItinClass Itinerary = itin; 1314} 1315 1316class MSA_3R_DESC_BASE<string instr_asm, SDPatternOperator OpNode, 1317 RegisterOperand ROWD, RegisterOperand ROWS = ROWD, 1318 RegisterOperand ROWT = ROWD, 1319 InstrItinClass itin = NoItinerary> { 1320 dag OutOperandList = (outs ROWD:$wd); 1321 dag InOperandList = (ins ROWS:$ws, ROWT:$wt); 1322 string AsmString = !strconcat(instr_asm, "\t$wd, $ws, $wt"); 1323 list<dag> Pattern = [(set ROWD:$wd, (OpNode ROWS:$ws, ROWT:$wt))]; 1324 InstrItinClass Itinerary = itin; 1325} 1326 1327class MSA_3R_BINSX_DESC_BASE<string instr_asm, SDPatternOperator OpNode, 1328 RegisterOperand ROWD, RegisterOperand ROWS = ROWD, 1329 RegisterOperand ROWT = ROWD, 1330 InstrItinClass itin = NoItinerary> { 1331 dag OutOperandList = (outs ROWD:$wd); 1332 dag InOperandList = (ins ROWD:$wd_in, ROWS:$ws, ROWT:$wt); 1333 string AsmString = !strconcat(instr_asm, "\t$wd, $ws, $wt"); 1334 list<dag> Pattern = [(set ROWD:$wd, (OpNode ROWD:$wd_in, ROWS:$ws, 1335 ROWT:$wt))]; 1336 string Constraints = "$wd = $wd_in"; 1337 InstrItinClass Itinerary = itin; 1338} 1339 1340class MSA_3R_SPLAT_DESC_BASE<string instr_asm, SDPatternOperator OpNode, 1341 RegisterOperand ROWD, RegisterOperand ROWS = ROWD, 1342 InstrItinClass itin = NoItinerary> { 1343 dag OutOperandList = (outs ROWD:$wd); 1344 dag InOperandList = (ins ROWS:$ws, GPR32Opnd:$rt); 1345 string AsmString = !strconcat(instr_asm, "\t$wd, $ws[$rt]"); 1346 list<dag> Pattern = [(set ROWD:$wd, (OpNode ROWS:$ws, GPR32Opnd:$rt))]; 1347 InstrItinClass Itinerary = itin; 1348} 1349 1350class MSA_3R_VSHF_DESC_BASE<string instr_asm, RegisterOperand ROWD, 1351 RegisterOperand ROWS = ROWD, 1352 RegisterOperand ROWT = ROWD, 1353 InstrItinClass itin = NoItinerary> { 1354 dag OutOperandList = (outs ROWD:$wd); 1355 dag InOperandList = (ins ROWD:$wd_in, ROWS:$ws, ROWT:$wt); 1356 string AsmString = !strconcat(instr_asm, "\t$wd, $ws, $wt"); 1357 list<dag> Pattern = [(set ROWD:$wd, (MipsVSHF ROWD:$wd_in, ROWS:$ws, 1358 ROWT:$wt))]; 1359 string Constraints = "$wd = $wd_in"; 1360 InstrItinClass Itinerary = itin; 1361} 1362 1363class MSA_3R_SLD_DESC_BASE<string instr_asm, SDPatternOperator OpNode, 1364 RegisterOperand ROWD, RegisterOperand ROWS = ROWD, 1365 InstrItinClass itin = NoItinerary> { 1366 dag OutOperandList = (outs ROWD:$wd); 1367 dag InOperandList = (ins ROWD:$wd_in, ROWS:$ws, GPR32Opnd:$rt); 1368 string AsmString = !strconcat(instr_asm, "\t$wd, $ws[$rt]"); 1369 list<dag> Pattern = [(set ROWD:$wd, (OpNode ROWD:$wd_in, ROWS:$ws, 1370 GPR32Opnd:$rt))]; 1371 InstrItinClass Itinerary = itin; 1372 string Constraints = "$wd = $wd_in"; 1373} 1374 1375class MSA_3R_4R_DESC_BASE<string instr_asm, SDPatternOperator OpNode, 1376 RegisterOperand ROWD, RegisterOperand ROWS = ROWD, 1377 RegisterOperand ROWT = ROWD, 1378 InstrItinClass itin = NoItinerary> { 1379 dag OutOperandList = (outs ROWD:$wd); 1380 dag InOperandList = (ins ROWD:$wd_in, ROWS:$ws, ROWT:$wt); 1381 string AsmString = !strconcat(instr_asm, "\t$wd, $ws, $wt"); 1382 list<dag> Pattern = [(set ROWD:$wd, (OpNode ROWD:$wd_in, ROWS:$ws, 1383 ROWT:$wt))]; 1384 InstrItinClass Itinerary = itin; 1385 string Constraints = "$wd = $wd_in"; 1386} 1387 1388class MSA_3RF_DESC_BASE<string instr_asm, SDPatternOperator OpNode, 1389 RegisterOperand ROWD, RegisterOperand ROWS = ROWD, 1390 RegisterOperand ROWT = ROWD, 1391 InstrItinClass itin = NoItinerary> : 1392 MSA_3R_DESC_BASE<instr_asm, OpNode, ROWD, ROWS, ROWT, itin>; 1393 1394class MSA_3RF_4RF_DESC_BASE<string instr_asm, SDPatternOperator OpNode, 1395 RegisterOperand ROWD, RegisterOperand ROWS = ROWD, 1396 RegisterOperand ROWT = ROWD, 1397 InstrItinClass itin = NoItinerary> : 1398 MSA_3R_4R_DESC_BASE<instr_asm, OpNode, ROWD, ROWS, ROWT, itin>; 1399 1400class MSA_CBRANCH_DESC_BASE<string instr_asm, RegisterOperand ROWD> { 1401 dag OutOperandList = (outs); 1402 dag InOperandList = (ins ROWD:$wt, brtarget:$offset); 1403 string AsmString = !strconcat(instr_asm, "\t$wt, $offset"); 1404 list<dag> Pattern = []; 1405 InstrItinClass Itinerary = NoItinerary; 1406 bit isBranch = 1; 1407 bit isTerminator = 1; 1408 bit hasDelaySlot = 1; 1409 list<Register> Defs = [AT]; 1410} 1411 1412class MSA_INSERT_DESC_BASE<string instr_asm, SDPatternOperator OpNode, 1413 Operand ImmOp, ImmLeaf Imm, RegisterOperand ROWD, 1414 RegisterOperand ROS, 1415 InstrItinClass itin = NoItinerary> { 1416 dag OutOperandList = (outs ROWD:$wd); 1417 dag InOperandList = (ins ROWD:$wd_in, ROS:$rs, ImmOp:$n); 1418 string AsmString = !strconcat(instr_asm, "\t$wd[$n], $rs"); 1419 list<dag> Pattern = [(set ROWD:$wd, (OpNode ROWD:$wd_in, ROS:$rs, Imm:$n))]; 1420 InstrItinClass Itinerary = itin; 1421 string Constraints = "$wd = $wd_in"; 1422} 1423 1424class MSA_INSERT_PSEUDO_BASE<SDPatternOperator OpNode, ValueType Ty, 1425 Operand ImmOp, ImmLeaf Imm, RegisterOperand ROWD, 1426 RegisterOperand ROFS> : 1427 MSAPseudo<(outs ROWD:$wd), (ins ROWD:$wd_in, ImmOp:$n, ROFS:$fs), 1428 [(set ROWD:$wd, (OpNode (Ty ROWD:$wd_in), ROFS:$fs, Imm:$n))]> { 1429 bit usesCustomInserter = 1; 1430 string Constraints = "$wd = $wd_in"; 1431} 1432 1433class MSA_INSERT_VIDX_PSEUDO_BASE<SDPatternOperator OpNode, ValueType Ty, 1434 RegisterOperand ROWD, RegisterOperand ROFS, 1435 RegisterOperand ROIdx> : 1436 MSAPseudo<(outs ROWD:$wd), (ins ROWD:$wd_in, ROIdx:$n, ROFS:$fs), 1437 [(set ROWD:$wd, (OpNode (Ty ROWD:$wd_in), ROFS:$fs, 1438 ROIdx:$n))]> { 1439 bit usesCustomInserter = 1; 1440 string Constraints = "$wd = $wd_in"; 1441} 1442 1443class MSA_INSVE_DESC_BASE<string instr_asm, SDPatternOperator OpNode, 1444 Operand ImmOp, ImmLeaf Imm, RegisterOperand ROWD, 1445 RegisterOperand ROWS = ROWD, 1446 InstrItinClass itin = NoItinerary> { 1447 dag OutOperandList = (outs ROWD:$wd); 1448 dag InOperandList = (ins ROWD:$wd_in, ImmOp:$n, ROWS:$ws, uimmz:$n2); 1449 string AsmString = !strconcat(instr_asm, "\t$wd[$n], $ws[$n2]"); 1450 list<dag> Pattern = [(set ROWD:$wd, (OpNode ROWD:$wd_in, 1451 Imm:$n, 1452 ROWS:$ws, 1453 immz:$n2))]; 1454 InstrItinClass Itinerary = itin; 1455 string Constraints = "$wd = $wd_in"; 1456} 1457 1458class MSA_VEC_DESC_BASE<string instr_asm, SDPatternOperator OpNode, 1459 RegisterOperand ROWD, RegisterOperand ROWS = ROWD, 1460 RegisterOperand ROWT = ROWD, 1461 InstrItinClass itin = NoItinerary> { 1462 dag OutOperandList = (outs ROWD:$wd); 1463 dag InOperandList = (ins ROWS:$ws, ROWT:$wt); 1464 string AsmString = !strconcat(instr_asm, "\t$wd, $ws, $wt"); 1465 list<dag> Pattern = [(set ROWD:$wd, (OpNode ROWS:$ws, ROWT:$wt))]; 1466 InstrItinClass Itinerary = itin; 1467} 1468 1469class MSA_ELM_SPLAT_DESC_BASE<string instr_asm, SplatComplexPattern SplatImm, 1470 RegisterOperand ROWD, 1471 RegisterOperand ROWS = ROWD, 1472 InstrItinClass itin = NoItinerary> { 1473 dag OutOperandList = (outs ROWD:$wd); 1474 dag InOperandList = (ins ROWS:$ws, SplatImm.OpClass:$n); 1475 string AsmString = !strconcat(instr_asm, "\t$wd, $ws[$n]"); 1476 list<dag> Pattern = [(set ROWD:$wd, (MipsVSHF SplatImm:$n, ROWS:$ws, 1477 ROWS:$ws))]; 1478 InstrItinClass Itinerary = itin; 1479} 1480 1481class MSA_VEC_PSEUDO_BASE<SDPatternOperator OpNode, RegisterOperand ROWD, 1482 RegisterOperand ROWS = ROWD, 1483 RegisterOperand ROWT = ROWD> : 1484 MSAPseudo<(outs ROWD:$wd), (ins ROWS:$ws, ROWT:$wt), 1485 [(set ROWD:$wd, (OpNode ROWS:$ws, ROWT:$wt))]>; 1486 1487class ADD_A_B_DESC : MSA_3R_DESC_BASE<"add_a.b", int_mips_add_a_b, MSA128BOpnd>, 1488 IsCommutable; 1489class ADD_A_H_DESC : MSA_3R_DESC_BASE<"add_a.h", int_mips_add_a_h, MSA128HOpnd>, 1490 IsCommutable; 1491class ADD_A_W_DESC : MSA_3R_DESC_BASE<"add_a.w", int_mips_add_a_w, MSA128WOpnd>, 1492 IsCommutable; 1493class ADD_A_D_DESC : MSA_3R_DESC_BASE<"add_a.d", int_mips_add_a_d, MSA128DOpnd>, 1494 IsCommutable; 1495 1496class ADDS_A_B_DESC : MSA_3R_DESC_BASE<"adds_a.b", int_mips_adds_a_b, 1497 MSA128BOpnd>, IsCommutable; 1498class ADDS_A_H_DESC : MSA_3R_DESC_BASE<"adds_a.h", int_mips_adds_a_h, 1499 MSA128HOpnd>, IsCommutable; 1500class ADDS_A_W_DESC : MSA_3R_DESC_BASE<"adds_a.w", int_mips_adds_a_w, 1501 MSA128WOpnd>, IsCommutable; 1502class ADDS_A_D_DESC : MSA_3R_DESC_BASE<"adds_a.d", int_mips_adds_a_d, 1503 MSA128DOpnd>, IsCommutable; 1504 1505class ADDS_S_B_DESC : MSA_3R_DESC_BASE<"adds_s.b", int_mips_adds_s_b, 1506 MSA128BOpnd>, IsCommutable; 1507class ADDS_S_H_DESC : MSA_3R_DESC_BASE<"adds_s.h", int_mips_adds_s_h, 1508 MSA128HOpnd>, IsCommutable; 1509class ADDS_S_W_DESC : MSA_3R_DESC_BASE<"adds_s.w", int_mips_adds_s_w, 1510 MSA128WOpnd>, IsCommutable; 1511class ADDS_S_D_DESC : MSA_3R_DESC_BASE<"adds_s.d", int_mips_adds_s_d, 1512 MSA128DOpnd>, IsCommutable; 1513 1514class ADDS_U_B_DESC : MSA_3R_DESC_BASE<"adds_u.b", int_mips_adds_u_b, 1515 MSA128BOpnd>, IsCommutable; 1516class ADDS_U_H_DESC : MSA_3R_DESC_BASE<"adds_u.h", int_mips_adds_u_h, 1517 MSA128HOpnd>, IsCommutable; 1518class ADDS_U_W_DESC : MSA_3R_DESC_BASE<"adds_u.w", int_mips_adds_u_w, 1519 MSA128WOpnd>, IsCommutable; 1520class ADDS_U_D_DESC : MSA_3R_DESC_BASE<"adds_u.d", int_mips_adds_u_d, 1521 MSA128DOpnd>, IsCommutable; 1522 1523class ADDV_B_DESC : MSA_3R_DESC_BASE<"addv.b", add, MSA128BOpnd>, IsCommutable; 1524class ADDV_H_DESC : MSA_3R_DESC_BASE<"addv.h", add, MSA128HOpnd>, IsCommutable; 1525class ADDV_W_DESC : MSA_3R_DESC_BASE<"addv.w", add, MSA128WOpnd>, IsCommutable; 1526class ADDV_D_DESC : MSA_3R_DESC_BASE<"addv.d", add, MSA128DOpnd>, IsCommutable; 1527 1528class ADDVI_B_DESC : MSA_I5_DESC_BASE<"addvi.b", add, vsplati8_uimm5, 1529 MSA128BOpnd>; 1530class ADDVI_H_DESC : MSA_I5_DESC_BASE<"addvi.h", add, vsplati16_uimm5, 1531 MSA128HOpnd>; 1532class ADDVI_W_DESC : MSA_I5_DESC_BASE<"addvi.w", add, vsplati32_uimm5, 1533 MSA128WOpnd>; 1534class ADDVI_D_DESC : MSA_I5_DESC_BASE<"addvi.d", add, vsplati64_uimm5, 1535 MSA128DOpnd>; 1536 1537class AND_V_DESC : MSA_VEC_DESC_BASE<"and.v", and, MSA128BOpnd>; 1538class AND_V_H_PSEUDO_DESC : MSA_VEC_PSEUDO_BASE<and, MSA128HOpnd>; 1539class AND_V_W_PSEUDO_DESC : MSA_VEC_PSEUDO_BASE<and, MSA128WOpnd>; 1540class AND_V_D_PSEUDO_DESC : MSA_VEC_PSEUDO_BASE<and, MSA128DOpnd>; 1541 1542class ANDI_B_DESC : MSA_I8_DESC_BASE<"andi.b", and, vsplati8_uimm8, 1543 MSA128BOpnd>; 1544 1545class ASUB_S_B_DESC : MSA_3R_DESC_BASE<"asub_s.b", int_mips_asub_s_b, 1546 MSA128BOpnd>; 1547class ASUB_S_H_DESC : MSA_3R_DESC_BASE<"asub_s.h", int_mips_asub_s_h, 1548 MSA128HOpnd>; 1549class ASUB_S_W_DESC : MSA_3R_DESC_BASE<"asub_s.w", int_mips_asub_s_w, 1550 MSA128WOpnd>; 1551class ASUB_S_D_DESC : MSA_3R_DESC_BASE<"asub_s.d", int_mips_asub_s_d, 1552 MSA128DOpnd>; 1553 1554class ASUB_U_B_DESC : MSA_3R_DESC_BASE<"asub_u.b", int_mips_asub_u_b, 1555 MSA128BOpnd>; 1556class ASUB_U_H_DESC : MSA_3R_DESC_BASE<"asub_u.h", int_mips_asub_u_h, 1557 MSA128HOpnd>; 1558class ASUB_U_W_DESC : MSA_3R_DESC_BASE<"asub_u.w", int_mips_asub_u_w, 1559 MSA128WOpnd>; 1560class ASUB_U_D_DESC : MSA_3R_DESC_BASE<"asub_u.d", int_mips_asub_u_d, 1561 MSA128DOpnd>; 1562 1563class AVE_S_B_DESC : MSA_3R_DESC_BASE<"ave_s.b", int_mips_ave_s_b, MSA128BOpnd>, 1564 IsCommutable; 1565class AVE_S_H_DESC : MSA_3R_DESC_BASE<"ave_s.h", int_mips_ave_s_h, MSA128HOpnd>, 1566 IsCommutable; 1567class AVE_S_W_DESC : MSA_3R_DESC_BASE<"ave_s.w", int_mips_ave_s_w, MSA128WOpnd>, 1568 IsCommutable; 1569class AVE_S_D_DESC : MSA_3R_DESC_BASE<"ave_s.d", int_mips_ave_s_d, MSA128DOpnd>, 1570 IsCommutable; 1571 1572class AVE_U_B_DESC : MSA_3R_DESC_BASE<"ave_u.b", int_mips_ave_u_b, MSA128BOpnd>, 1573 IsCommutable; 1574class AVE_U_H_DESC : MSA_3R_DESC_BASE<"ave_u.h", int_mips_ave_u_h, MSA128HOpnd>, 1575 IsCommutable; 1576class AVE_U_W_DESC : MSA_3R_DESC_BASE<"ave_u.w", int_mips_ave_u_w, MSA128WOpnd>, 1577 IsCommutable; 1578class AVE_U_D_DESC : MSA_3R_DESC_BASE<"ave_u.d", int_mips_ave_u_d, MSA128DOpnd>, 1579 IsCommutable; 1580 1581class AVER_S_B_DESC : MSA_3R_DESC_BASE<"aver_s.b", int_mips_aver_s_b, 1582 MSA128BOpnd>, IsCommutable; 1583class AVER_S_H_DESC : MSA_3R_DESC_BASE<"aver_s.h", int_mips_aver_s_h, 1584 MSA128HOpnd>, IsCommutable; 1585class AVER_S_W_DESC : MSA_3R_DESC_BASE<"aver_s.w", int_mips_aver_s_w, 1586 MSA128WOpnd>, IsCommutable; 1587class AVER_S_D_DESC : MSA_3R_DESC_BASE<"aver_s.d", int_mips_aver_s_d, 1588 MSA128DOpnd>, IsCommutable; 1589 1590class AVER_U_B_DESC : MSA_3R_DESC_BASE<"aver_u.b", int_mips_aver_u_b, 1591 MSA128BOpnd>, IsCommutable; 1592class AVER_U_H_DESC : MSA_3R_DESC_BASE<"aver_u.h", int_mips_aver_u_h, 1593 MSA128HOpnd>, IsCommutable; 1594class AVER_U_W_DESC : MSA_3R_DESC_BASE<"aver_u.w", int_mips_aver_u_w, 1595 MSA128WOpnd>, IsCommutable; 1596class AVER_U_D_DESC : MSA_3R_DESC_BASE<"aver_u.d", int_mips_aver_u_d, 1597 MSA128DOpnd>, IsCommutable; 1598 1599class BCLR_B_DESC : MSA_3R_DESC_BASE<"bclr.b", vbclr_b, MSA128BOpnd>; 1600class BCLR_H_DESC : MSA_3R_DESC_BASE<"bclr.h", vbclr_h, MSA128HOpnd>; 1601class BCLR_W_DESC : MSA_3R_DESC_BASE<"bclr.w", vbclr_w, MSA128WOpnd>; 1602class BCLR_D_DESC : MSA_3R_DESC_BASE<"bclr.d", vbclr_d, MSA128DOpnd>; 1603 1604class BCLRI_B_DESC : MSA_BIT_B_DESC_BASE<"bclri.b", and, vsplat_uimm_inv_pow2, 1605 MSA128BOpnd>; 1606class BCLRI_H_DESC : MSA_BIT_H_DESC_BASE<"bclri.h", and, vsplat_uimm_inv_pow2, 1607 MSA128HOpnd>; 1608class BCLRI_W_DESC : MSA_BIT_W_DESC_BASE<"bclri.w", and, vsplat_uimm_inv_pow2, 1609 MSA128WOpnd>; 1610class BCLRI_D_DESC : MSA_BIT_D_DESC_BASE<"bclri.d", and, vsplat_uimm_inv_pow2, 1611 MSA128DOpnd>; 1612 1613class BINSL_B_DESC : MSA_3R_BINSX_DESC_BASE<"binsl.b", int_mips_binsl_b, 1614 MSA128BOpnd>; 1615class BINSL_H_DESC : MSA_3R_BINSX_DESC_BASE<"binsl.h", int_mips_binsl_h, 1616 MSA128HOpnd>; 1617class BINSL_W_DESC : MSA_3R_BINSX_DESC_BASE<"binsl.w", int_mips_binsl_w, 1618 MSA128WOpnd>; 1619class BINSL_D_DESC : MSA_3R_BINSX_DESC_BASE<"binsl.d", int_mips_binsl_d, 1620 MSA128DOpnd>; 1621 1622class BINSLI_B_DESC : MSA_BIT_BINSLI_DESC_BASE<"binsli.b", v16i8, vsplat_maskl_bits_uimm3, MSA128BOpnd>; 1623class BINSLI_H_DESC : MSA_BIT_BINSLI_DESC_BASE<"binsli.h", v8i16, vsplat_maskl_bits_uimm4, MSA128HOpnd>; 1624class BINSLI_W_DESC : MSA_BIT_BINSLI_DESC_BASE<"binsli.w", v4i32, vsplat_maskl_bits_uimm5, MSA128WOpnd>; 1625class BINSLI_D_DESC : MSA_BIT_BINSLI_DESC_BASE<"binsli.d", v2i64, vsplat_maskl_bits_uimm6, MSA128DOpnd>; 1626 1627class BINSR_B_DESC : MSA_3R_BINSX_DESC_BASE<"binsr.b", int_mips_binsr_b, 1628 MSA128BOpnd>; 1629class BINSR_H_DESC : MSA_3R_BINSX_DESC_BASE<"binsr.h", int_mips_binsr_h, 1630 MSA128HOpnd>; 1631class BINSR_W_DESC : MSA_3R_BINSX_DESC_BASE<"binsr.w", int_mips_binsr_w, 1632 MSA128WOpnd>; 1633class BINSR_D_DESC : MSA_3R_BINSX_DESC_BASE<"binsr.d", int_mips_binsr_d, 1634 MSA128DOpnd>; 1635 1636class BINSRI_B_DESC 1637 : MSA_BIT_BINSRI_DESC_BASE<"binsri.b", v16i8, vsplat_maskr_bits_uimm3, 1638 MSA128BOpnd>; 1639class BINSRI_H_DESC 1640 : MSA_BIT_BINSRI_DESC_BASE<"binsri.h", v8i16, vsplat_maskr_bits_uimm4, 1641 MSA128HOpnd>; 1642class BINSRI_W_DESC 1643 : MSA_BIT_BINSRI_DESC_BASE<"binsri.w", v4i32, vsplat_maskr_bits_uimm5, 1644 MSA128WOpnd>; 1645class BINSRI_D_DESC 1646 : MSA_BIT_BINSRI_DESC_BASE<"binsri.d", v2i64, vsplat_maskr_bits_uimm6, 1647 MSA128DOpnd>; 1648 1649class BMNZ_V_DESC { 1650 dag OutOperandList = (outs MSA128BOpnd:$wd); 1651 dag InOperandList = (ins MSA128BOpnd:$wd_in, MSA128BOpnd:$ws, 1652 MSA128BOpnd:$wt); 1653 string AsmString = "bmnz.v\t$wd, $ws, $wt"; 1654 list<dag> Pattern = [(set MSA128BOpnd:$wd, (vselect MSA128BOpnd:$wt, 1655 MSA128BOpnd:$ws, 1656 MSA128BOpnd:$wd_in))]; 1657 InstrItinClass Itinerary = NoItinerary; 1658 string Constraints = "$wd = $wd_in"; 1659} 1660 1661class BMNZI_B_DESC { 1662 dag OutOperandList = (outs MSA128BOpnd:$wd); 1663 dag InOperandList = (ins MSA128BOpnd:$wd_in, MSA128BOpnd:$ws, 1664 vsplat_uimm8:$u8); 1665 string AsmString = "bmnzi.b\t$wd, $ws, $u8"; 1666 list<dag> Pattern = [(set MSA128BOpnd:$wd, (vselect vsplati8_uimm8:$u8, 1667 MSA128BOpnd:$ws, 1668 MSA128BOpnd:$wd_in))]; 1669 InstrItinClass Itinerary = NoItinerary; 1670 string Constraints = "$wd = $wd_in"; 1671} 1672 1673class BMZ_V_DESC { 1674 dag OutOperandList = (outs MSA128BOpnd:$wd); 1675 dag InOperandList = (ins MSA128BOpnd:$wd_in, MSA128BOpnd:$ws, 1676 MSA128BOpnd:$wt); 1677 string AsmString = "bmz.v\t$wd, $ws, $wt"; 1678 list<dag> Pattern = [(set MSA128BOpnd:$wd, (vselect MSA128BOpnd:$wt, 1679 MSA128BOpnd:$wd_in, 1680 MSA128BOpnd:$ws))]; 1681 InstrItinClass Itinerary = NoItinerary; 1682 string Constraints = "$wd = $wd_in"; 1683} 1684 1685class BMZI_B_DESC { 1686 dag OutOperandList = (outs MSA128BOpnd:$wd); 1687 dag InOperandList = (ins MSA128BOpnd:$wd_in, MSA128BOpnd:$ws, 1688 vsplat_uimm8:$u8); 1689 string AsmString = "bmzi.b\t$wd, $ws, $u8"; 1690 list<dag> Pattern = [(set MSA128BOpnd:$wd, (vselect vsplati8_uimm8:$u8, 1691 MSA128BOpnd:$wd_in, 1692 MSA128BOpnd:$ws))]; 1693 InstrItinClass Itinerary = NoItinerary; 1694 string Constraints = "$wd = $wd_in"; 1695} 1696 1697class BNEG_B_DESC : MSA_3R_DESC_BASE<"bneg.b", vbneg_b, MSA128BOpnd>; 1698class BNEG_H_DESC : MSA_3R_DESC_BASE<"bneg.h", vbneg_h, MSA128HOpnd>; 1699class BNEG_W_DESC : MSA_3R_DESC_BASE<"bneg.w", vbneg_w, MSA128WOpnd>; 1700class BNEG_D_DESC : MSA_3R_DESC_BASE<"bneg.d", vbneg_d, MSA128DOpnd>; 1701 1702class BNEGI_B_DESC : MSA_BIT_B_DESC_BASE<"bnegi.b", xor, vsplat_uimm_pow2, 1703 MSA128BOpnd>; 1704class BNEGI_H_DESC : MSA_BIT_H_DESC_BASE<"bnegi.h", xor, vsplat_uimm_pow2, 1705 MSA128HOpnd>; 1706class BNEGI_W_DESC : MSA_BIT_W_DESC_BASE<"bnegi.w", xor, vsplat_uimm_pow2, 1707 MSA128WOpnd>; 1708class BNEGI_D_DESC : MSA_BIT_D_DESC_BASE<"bnegi.d", xor, vsplat_uimm_pow2, 1709 MSA128DOpnd>; 1710 1711class BNZ_B_DESC : MSA_CBRANCH_DESC_BASE<"bnz.b", MSA128BOpnd>; 1712class BNZ_H_DESC : MSA_CBRANCH_DESC_BASE<"bnz.h", MSA128HOpnd>; 1713class BNZ_W_DESC : MSA_CBRANCH_DESC_BASE<"bnz.w", MSA128WOpnd>; 1714class BNZ_D_DESC : MSA_CBRANCH_DESC_BASE<"bnz.d", MSA128DOpnd>; 1715 1716class BNZ_V_DESC : MSA_CBRANCH_DESC_BASE<"bnz.v", MSA128BOpnd>; 1717 1718class BSEL_V_DESC { 1719 dag OutOperandList = (outs MSA128BOpnd:$wd); 1720 dag InOperandList = (ins MSA128BOpnd:$wd_in, MSA128BOpnd:$ws, 1721 MSA128BOpnd:$wt); 1722 string AsmString = "bsel.v\t$wd, $ws, $wt"; 1723 // Note that vselect and BSEL_V treat the condition operand the opposite way 1724 // from each other. 1725 // (vselect cond, if_set, if_clear) 1726 // (BSEL_V cond, if_clear, if_set) 1727 list<dag> Pattern = [(set MSA128BOpnd:$wd, 1728 (vselect MSA128BOpnd:$wd_in, MSA128BOpnd:$wt, 1729 MSA128BOpnd:$ws))]; 1730 InstrItinClass Itinerary = NoItinerary; 1731 string Constraints = "$wd = $wd_in"; 1732} 1733 1734class BSELI_B_DESC { 1735 dag OutOperandList = (outs MSA128BOpnd:$wd); 1736 dag InOperandList = (ins MSA128BOpnd:$wd_in, MSA128BOpnd:$ws, 1737 vsplat_uimm8:$u8); 1738 string AsmString = "bseli.b\t$wd, $ws, $u8"; 1739 // Note that vselect and BSEL_V treat the condition operand the opposite way 1740 // from each other. 1741 // (vselect cond, if_set, if_clear) 1742 // (BSEL_V cond, if_clear, if_set) 1743 list<dag> Pattern = [(set MSA128BOpnd:$wd, (vselect MSA128BOpnd:$wd_in, 1744 vsplati8_uimm8:$u8, 1745 MSA128BOpnd:$ws))]; 1746 InstrItinClass Itinerary = NoItinerary; 1747 string Constraints = "$wd = $wd_in"; 1748} 1749 1750class BSET_B_DESC : MSA_3R_DESC_BASE<"bset.b", vbset_b, MSA128BOpnd>; 1751class BSET_H_DESC : MSA_3R_DESC_BASE<"bset.h", vbset_h, MSA128HOpnd>; 1752class BSET_W_DESC : MSA_3R_DESC_BASE<"bset.w", vbset_w, MSA128WOpnd>; 1753class BSET_D_DESC : MSA_3R_DESC_BASE<"bset.d", vbset_d, MSA128DOpnd>; 1754 1755class BSETI_B_DESC : MSA_BIT_B_DESC_BASE<"bseti.b", or, vsplat_uimm_pow2, 1756 MSA128BOpnd>; 1757class BSETI_H_DESC : MSA_BIT_H_DESC_BASE<"bseti.h", or, vsplat_uimm_pow2, 1758 MSA128HOpnd>; 1759class BSETI_W_DESC : MSA_BIT_W_DESC_BASE<"bseti.w", or, vsplat_uimm_pow2, 1760 MSA128WOpnd>; 1761class BSETI_D_DESC : MSA_BIT_D_DESC_BASE<"bseti.d", or, vsplat_uimm_pow2, 1762 MSA128DOpnd>; 1763 1764class BZ_B_DESC : MSA_CBRANCH_DESC_BASE<"bz.b", MSA128BOpnd>; 1765class BZ_H_DESC : MSA_CBRANCH_DESC_BASE<"bz.h", MSA128HOpnd>; 1766class BZ_W_DESC : MSA_CBRANCH_DESC_BASE<"bz.w", MSA128WOpnd>; 1767class BZ_D_DESC : MSA_CBRANCH_DESC_BASE<"bz.d", MSA128DOpnd>; 1768 1769class BZ_V_DESC : MSA_CBRANCH_DESC_BASE<"bz.v", MSA128BOpnd>; 1770 1771class CEQ_B_DESC : MSA_3R_DESC_BASE<"ceq.b", vseteq_v16i8, MSA128BOpnd>, 1772 IsCommutable; 1773class CEQ_H_DESC : MSA_3R_DESC_BASE<"ceq.h", vseteq_v8i16, MSA128HOpnd>, 1774 IsCommutable; 1775class CEQ_W_DESC : MSA_3R_DESC_BASE<"ceq.w", vseteq_v4i32, MSA128WOpnd>, 1776 IsCommutable; 1777class CEQ_D_DESC : MSA_3R_DESC_BASE<"ceq.d", vseteq_v2i64, MSA128DOpnd>, 1778 IsCommutable; 1779 1780class CEQI_B_DESC : MSA_I5_DESC_BASE<"ceqi.b", vseteq_v16i8, vsplati8_simm5, 1781 MSA128BOpnd>; 1782class CEQI_H_DESC : MSA_I5_DESC_BASE<"ceqi.h", vseteq_v8i16, vsplati16_simm5, 1783 MSA128HOpnd>; 1784class CEQI_W_DESC : MSA_I5_DESC_BASE<"ceqi.w", vseteq_v4i32, vsplati32_simm5, 1785 MSA128WOpnd>; 1786class CEQI_D_DESC : MSA_I5_DESC_BASE<"ceqi.d", vseteq_v2i64, vsplati64_simm5, 1787 MSA128DOpnd>; 1788 1789class CFCMSA_DESC { 1790 dag OutOperandList = (outs GPR32Opnd:$rd); 1791 dag InOperandList = (ins MSA128CROpnd:$cs); 1792 string AsmString = "cfcmsa\t$rd, $cs"; 1793 InstrItinClass Itinerary = NoItinerary; 1794 bit hasSideEffects = 1; 1795} 1796 1797class CLE_S_B_DESC : MSA_3R_DESC_BASE<"cle_s.b", vsetle_v16i8, MSA128BOpnd>; 1798class CLE_S_H_DESC : MSA_3R_DESC_BASE<"cle_s.h", vsetle_v8i16, MSA128HOpnd>; 1799class CLE_S_W_DESC : MSA_3R_DESC_BASE<"cle_s.w", vsetle_v4i32, MSA128WOpnd>; 1800class CLE_S_D_DESC : MSA_3R_DESC_BASE<"cle_s.d", vsetle_v2i64, MSA128DOpnd>; 1801 1802class CLE_U_B_DESC : MSA_3R_DESC_BASE<"cle_u.b", vsetule_v16i8, MSA128BOpnd>; 1803class CLE_U_H_DESC : MSA_3R_DESC_BASE<"cle_u.h", vsetule_v8i16, MSA128HOpnd>; 1804class CLE_U_W_DESC : MSA_3R_DESC_BASE<"cle_u.w", vsetule_v4i32, MSA128WOpnd>; 1805class CLE_U_D_DESC : MSA_3R_DESC_BASE<"cle_u.d", vsetule_v2i64, MSA128DOpnd>; 1806 1807class CLEI_S_B_DESC : MSA_I5_DESC_BASE<"clei_s.b", vsetle_v16i8, 1808 vsplati8_simm5, MSA128BOpnd>; 1809class CLEI_S_H_DESC : MSA_I5_DESC_BASE<"clei_s.h", vsetle_v8i16, 1810 vsplati16_simm5, MSA128HOpnd>; 1811class CLEI_S_W_DESC : MSA_I5_DESC_BASE<"clei_s.w", vsetle_v4i32, 1812 vsplati32_simm5, MSA128WOpnd>; 1813class CLEI_S_D_DESC : MSA_I5_DESC_BASE<"clei_s.d", vsetle_v2i64, 1814 vsplati64_simm5, MSA128DOpnd>; 1815 1816class CLEI_U_B_DESC : MSA_I5_DESC_BASE<"clei_u.b", vsetule_v16i8, 1817 vsplati8_uimm5, MSA128BOpnd>; 1818class CLEI_U_H_DESC : MSA_I5_DESC_BASE<"clei_u.h", vsetule_v8i16, 1819 vsplati16_uimm5, MSA128HOpnd>; 1820class CLEI_U_W_DESC : MSA_I5_DESC_BASE<"clei_u.w", vsetule_v4i32, 1821 vsplati32_uimm5, MSA128WOpnd>; 1822class CLEI_U_D_DESC : MSA_I5_DESC_BASE<"clei_u.d", vsetule_v2i64, 1823 vsplati64_uimm5, MSA128DOpnd>; 1824 1825class CLT_S_B_DESC : MSA_3R_DESC_BASE<"clt_s.b", vsetlt_v16i8, MSA128BOpnd>; 1826class CLT_S_H_DESC : MSA_3R_DESC_BASE<"clt_s.h", vsetlt_v8i16, MSA128HOpnd>; 1827class CLT_S_W_DESC : MSA_3R_DESC_BASE<"clt_s.w", vsetlt_v4i32, MSA128WOpnd>; 1828class CLT_S_D_DESC : MSA_3R_DESC_BASE<"clt_s.d", vsetlt_v2i64, MSA128DOpnd>; 1829 1830class CLT_U_B_DESC : MSA_3R_DESC_BASE<"clt_u.b", vsetult_v16i8, MSA128BOpnd>; 1831class CLT_U_H_DESC : MSA_3R_DESC_BASE<"clt_u.h", vsetult_v8i16, MSA128HOpnd>; 1832class CLT_U_W_DESC : MSA_3R_DESC_BASE<"clt_u.w", vsetult_v4i32, MSA128WOpnd>; 1833class CLT_U_D_DESC : MSA_3R_DESC_BASE<"clt_u.d", vsetult_v2i64, MSA128DOpnd>; 1834 1835class CLTI_S_B_DESC : MSA_I5_DESC_BASE<"clti_s.b", vsetlt_v16i8, 1836 vsplati8_simm5, MSA128BOpnd>; 1837class CLTI_S_H_DESC : MSA_I5_DESC_BASE<"clti_s.h", vsetlt_v8i16, 1838 vsplati16_simm5, MSA128HOpnd>; 1839class CLTI_S_W_DESC : MSA_I5_DESC_BASE<"clti_s.w", vsetlt_v4i32, 1840 vsplati32_simm5, MSA128WOpnd>; 1841class CLTI_S_D_DESC : MSA_I5_DESC_BASE<"clti_s.d", vsetlt_v2i64, 1842 vsplati64_simm5, MSA128DOpnd>; 1843 1844class CLTI_U_B_DESC : MSA_I5_DESC_BASE<"clti_u.b", vsetult_v16i8, 1845 vsplati8_uimm5, MSA128BOpnd>; 1846class CLTI_U_H_DESC : MSA_I5_DESC_BASE<"clti_u.h", vsetult_v8i16, 1847 vsplati16_uimm5, MSA128HOpnd>; 1848class CLTI_U_W_DESC : MSA_I5_DESC_BASE<"clti_u.w", vsetult_v4i32, 1849 vsplati32_uimm5, MSA128WOpnd>; 1850class CLTI_U_D_DESC : MSA_I5_DESC_BASE<"clti_u.d", vsetult_v2i64, 1851 vsplati64_uimm5, MSA128DOpnd>; 1852 1853class COPY_S_B_DESC : MSA_COPY_DESC_BASE<"copy_s.b", vextract_sext_i8, v16i8, 1854 uimm4_ptr, immZExt4Ptr, GPR32Opnd, 1855 MSA128BOpnd>; 1856class COPY_S_H_DESC : MSA_COPY_DESC_BASE<"copy_s.h", vextract_sext_i16, v8i16, 1857 uimm3_ptr, immZExt3Ptr, GPR32Opnd, 1858 MSA128HOpnd>; 1859class COPY_S_W_DESC : MSA_COPY_DESC_BASE<"copy_s.w", vextract_sext_i32, v4i32, 1860 uimm2_ptr, immZExt2Ptr, GPR32Opnd, 1861 MSA128WOpnd>; 1862class COPY_S_D_DESC : MSA_COPY_DESC_BASE<"copy_s.d", vextract_sext_i64, v2i64, 1863 uimm1_ptr, immZExt1Ptr, GPR64Opnd, 1864 MSA128DOpnd>; 1865 1866class COPY_U_B_DESC : MSA_COPY_DESC_BASE<"copy_u.b", vextract_zext_i8, v16i8, 1867 uimm4_ptr, immZExt4Ptr, GPR32Opnd, 1868 MSA128BOpnd>; 1869class COPY_U_H_DESC : MSA_COPY_DESC_BASE<"copy_u.h", vextract_zext_i16, v8i16, 1870 uimm3_ptr, immZExt3Ptr, GPR32Opnd, 1871 MSA128HOpnd>; 1872class COPY_U_W_DESC : MSA_COPY_DESC_BASE<"copy_u.w", vextract_zext_i32, v4i32, 1873 uimm2_ptr, immZExt2Ptr, GPR32Opnd, 1874 MSA128WOpnd>; 1875 1876class COPY_FW_PSEUDO_DESC : MSA_COPY_PSEUDO_BASE<vector_extract, v4f32, 1877 uimm2_ptr, immZExt2Ptr, FGR32, 1878 MSA128W>; 1879class COPY_FD_PSEUDO_DESC : MSA_COPY_PSEUDO_BASE<vector_extract, v2f64, 1880 uimm1_ptr, immZExt1Ptr, FGR64, 1881 MSA128D>; 1882 1883class CTCMSA_DESC { 1884 dag OutOperandList = (outs); 1885 dag InOperandList = (ins MSA128CROpnd:$cd, GPR32Opnd:$rs); 1886 string AsmString = "ctcmsa\t$cd, $rs"; 1887 InstrItinClass Itinerary = NoItinerary; 1888 bit hasSideEffects = 1; 1889} 1890 1891class DIV_S_B_DESC : MSA_3R_DESC_BASE<"div_s.b", sdiv, MSA128BOpnd>; 1892class DIV_S_H_DESC : MSA_3R_DESC_BASE<"div_s.h", sdiv, MSA128HOpnd>; 1893class DIV_S_W_DESC : MSA_3R_DESC_BASE<"div_s.w", sdiv, MSA128WOpnd>; 1894class DIV_S_D_DESC : MSA_3R_DESC_BASE<"div_s.d", sdiv, MSA128DOpnd>; 1895 1896class DIV_U_B_DESC : MSA_3R_DESC_BASE<"div_u.b", udiv, MSA128BOpnd>; 1897class DIV_U_H_DESC : MSA_3R_DESC_BASE<"div_u.h", udiv, MSA128HOpnd>; 1898class DIV_U_W_DESC : MSA_3R_DESC_BASE<"div_u.w", udiv, MSA128WOpnd>; 1899class DIV_U_D_DESC : MSA_3R_DESC_BASE<"div_u.d", udiv, MSA128DOpnd>; 1900 1901class DOTP_S_H_DESC : MSA_3R_DESC_BASE<"dotp_s.h", int_mips_dotp_s_h, 1902 MSA128HOpnd, MSA128BOpnd, MSA128BOpnd>, 1903 IsCommutable; 1904class DOTP_S_W_DESC : MSA_3R_DESC_BASE<"dotp_s.w", int_mips_dotp_s_w, 1905 MSA128WOpnd, MSA128HOpnd, MSA128HOpnd>, 1906 IsCommutable; 1907class DOTP_S_D_DESC : MSA_3R_DESC_BASE<"dotp_s.d", int_mips_dotp_s_d, 1908 MSA128DOpnd, MSA128WOpnd, MSA128WOpnd>, 1909 IsCommutable; 1910 1911class DOTP_U_H_DESC : MSA_3R_DESC_BASE<"dotp_u.h", int_mips_dotp_u_h, 1912 MSA128HOpnd, MSA128BOpnd, MSA128BOpnd>, 1913 IsCommutable; 1914class DOTP_U_W_DESC : MSA_3R_DESC_BASE<"dotp_u.w", int_mips_dotp_u_w, 1915 MSA128WOpnd, MSA128HOpnd, MSA128HOpnd>, 1916 IsCommutable; 1917class DOTP_U_D_DESC : MSA_3R_DESC_BASE<"dotp_u.d", int_mips_dotp_u_d, 1918 MSA128DOpnd, MSA128WOpnd, MSA128WOpnd>, 1919 IsCommutable; 1920 1921class DPADD_S_H_DESC : MSA_3R_4R_DESC_BASE<"dpadd_s.h", int_mips_dpadd_s_h, 1922 MSA128HOpnd, MSA128BOpnd, 1923 MSA128BOpnd>, IsCommutable; 1924class DPADD_S_W_DESC : MSA_3R_4R_DESC_BASE<"dpadd_s.w", int_mips_dpadd_s_w, 1925 MSA128WOpnd, MSA128HOpnd, 1926 MSA128HOpnd>, IsCommutable; 1927class DPADD_S_D_DESC : MSA_3R_4R_DESC_BASE<"dpadd_s.d", int_mips_dpadd_s_d, 1928 MSA128DOpnd, MSA128WOpnd, 1929 MSA128WOpnd>, IsCommutable; 1930 1931class DPADD_U_H_DESC : MSA_3R_4R_DESC_BASE<"dpadd_u.h", int_mips_dpadd_u_h, 1932 MSA128HOpnd, MSA128BOpnd, 1933 MSA128BOpnd>, IsCommutable; 1934class DPADD_U_W_DESC : MSA_3R_4R_DESC_BASE<"dpadd_u.w", int_mips_dpadd_u_w, 1935 MSA128WOpnd, MSA128HOpnd, 1936 MSA128HOpnd>, IsCommutable; 1937class DPADD_U_D_DESC : MSA_3R_4R_DESC_BASE<"dpadd_u.d", int_mips_dpadd_u_d, 1938 MSA128DOpnd, MSA128WOpnd, 1939 MSA128WOpnd>, IsCommutable; 1940 1941class DPSUB_S_H_DESC : MSA_3R_4R_DESC_BASE<"dpsub_s.h", int_mips_dpsub_s_h, 1942 MSA128HOpnd, MSA128BOpnd, 1943 MSA128BOpnd>; 1944class DPSUB_S_W_DESC : MSA_3R_4R_DESC_BASE<"dpsub_s.w", int_mips_dpsub_s_w, 1945 MSA128WOpnd, MSA128HOpnd, 1946 MSA128HOpnd>; 1947class DPSUB_S_D_DESC : MSA_3R_4R_DESC_BASE<"dpsub_s.d", int_mips_dpsub_s_d, 1948 MSA128DOpnd, MSA128WOpnd, 1949 MSA128WOpnd>; 1950 1951class DPSUB_U_H_DESC : MSA_3R_4R_DESC_BASE<"dpsub_u.h", int_mips_dpsub_u_h, 1952 MSA128HOpnd, MSA128BOpnd, 1953 MSA128BOpnd>; 1954class DPSUB_U_W_DESC : MSA_3R_4R_DESC_BASE<"dpsub_u.w", int_mips_dpsub_u_w, 1955 MSA128WOpnd, MSA128HOpnd, 1956 MSA128HOpnd>; 1957class DPSUB_U_D_DESC : MSA_3R_4R_DESC_BASE<"dpsub_u.d", int_mips_dpsub_u_d, 1958 MSA128DOpnd, MSA128WOpnd, 1959 MSA128WOpnd>; 1960 1961class FADD_W_DESC : MSA_3RF_DESC_BASE<"fadd.w", fadd, MSA128WOpnd>, 1962 IsCommutable; 1963class FADD_D_DESC : MSA_3RF_DESC_BASE<"fadd.d", fadd, MSA128DOpnd>, 1964 IsCommutable; 1965 1966class FCAF_W_DESC : MSA_3RF_DESC_BASE<"fcaf.w", int_mips_fcaf_w, MSA128WOpnd>, 1967 IsCommutable; 1968class FCAF_D_DESC : MSA_3RF_DESC_BASE<"fcaf.d", int_mips_fcaf_d, MSA128DOpnd>, 1969 IsCommutable; 1970 1971class FCEQ_W_DESC : MSA_3RF_DESC_BASE<"fceq.w", vfsetoeq_v4f32, MSA128WOpnd>, 1972 IsCommutable; 1973class FCEQ_D_DESC : MSA_3RF_DESC_BASE<"fceq.d", vfsetoeq_v2f64, MSA128DOpnd>, 1974 IsCommutable; 1975 1976class FCLASS_W_DESC : MSA_2RF_DESC_BASE<"fclass.w", int_mips_fclass_w, 1977 MSA128WOpnd>; 1978class FCLASS_D_DESC : MSA_2RF_DESC_BASE<"fclass.d", int_mips_fclass_d, 1979 MSA128DOpnd>; 1980 1981class FCLE_W_DESC : MSA_3RF_DESC_BASE<"fcle.w", vfsetole_v4f32, MSA128WOpnd>; 1982class FCLE_D_DESC : MSA_3RF_DESC_BASE<"fcle.d", vfsetole_v2f64, MSA128DOpnd>; 1983 1984class FCLT_W_DESC : MSA_3RF_DESC_BASE<"fclt.w", vfsetolt_v4f32, MSA128WOpnd>; 1985class FCLT_D_DESC : MSA_3RF_DESC_BASE<"fclt.d", vfsetolt_v2f64, MSA128DOpnd>; 1986 1987class FCNE_W_DESC : MSA_3RF_DESC_BASE<"fcne.w", vfsetone_v4f32, MSA128WOpnd>, 1988 IsCommutable; 1989class FCNE_D_DESC : MSA_3RF_DESC_BASE<"fcne.d", vfsetone_v2f64, MSA128DOpnd>, 1990 IsCommutable; 1991 1992class FCOR_W_DESC : MSA_3RF_DESC_BASE<"fcor.w", vfsetord_v4f32, MSA128WOpnd>, 1993 IsCommutable; 1994class FCOR_D_DESC : MSA_3RF_DESC_BASE<"fcor.d", vfsetord_v2f64, MSA128DOpnd>, 1995 IsCommutable; 1996 1997class FCUEQ_W_DESC : MSA_3RF_DESC_BASE<"fcueq.w", vfsetueq_v4f32, MSA128WOpnd>, 1998 IsCommutable; 1999class FCUEQ_D_DESC : MSA_3RF_DESC_BASE<"fcueq.d", vfsetueq_v2f64, MSA128DOpnd>, 2000 IsCommutable; 2001 2002class FCULE_W_DESC : MSA_3RF_DESC_BASE<"fcule.w", vfsetule_v4f32, MSA128WOpnd>, 2003 IsCommutable; 2004class FCULE_D_DESC : MSA_3RF_DESC_BASE<"fcule.d", vfsetule_v2f64, MSA128DOpnd>, 2005 IsCommutable; 2006 2007class FCULT_W_DESC : MSA_3RF_DESC_BASE<"fcult.w", vfsetult_v4f32, MSA128WOpnd>, 2008 IsCommutable; 2009class FCULT_D_DESC : MSA_3RF_DESC_BASE<"fcult.d", vfsetult_v2f64, MSA128DOpnd>, 2010 IsCommutable; 2011 2012class FCUN_W_DESC : MSA_3RF_DESC_BASE<"fcun.w", vfsetun_v4f32, MSA128WOpnd>, 2013 IsCommutable; 2014class FCUN_D_DESC : MSA_3RF_DESC_BASE<"fcun.d", vfsetun_v2f64, MSA128DOpnd>, 2015 IsCommutable; 2016 2017class FCUNE_W_DESC : MSA_3RF_DESC_BASE<"fcune.w", vfsetune_v4f32, MSA128WOpnd>, 2018 IsCommutable; 2019class FCUNE_D_DESC : MSA_3RF_DESC_BASE<"fcune.d", vfsetune_v2f64, MSA128DOpnd>, 2020 IsCommutable; 2021 2022class FDIV_W_DESC : MSA_3RF_DESC_BASE<"fdiv.w", fdiv, MSA128WOpnd>; 2023class FDIV_D_DESC : MSA_3RF_DESC_BASE<"fdiv.d", fdiv, MSA128DOpnd>; 2024 2025class FEXDO_H_DESC : MSA_3RF_DESC_BASE<"fexdo.h", int_mips_fexdo_h, 2026 MSA128HOpnd, MSA128WOpnd, MSA128WOpnd>; 2027class FEXDO_W_DESC : MSA_3RF_DESC_BASE<"fexdo.w", int_mips_fexdo_w, 2028 MSA128WOpnd, MSA128DOpnd, MSA128DOpnd>; 2029 2030// The fexp2.df instruction multiplies the first operand by 2 to the power of 2031// the second operand. We therefore need a pseudo-insn in order to invent the 2032// 1.0 when we only need to match ISD::FEXP2. 2033class FEXP2_W_DESC : MSA_3RF_DESC_BASE<"fexp2.w", mul_fexp2, MSA128WOpnd>; 2034class FEXP2_D_DESC : MSA_3RF_DESC_BASE<"fexp2.d", mul_fexp2, MSA128DOpnd>; 2035let usesCustomInserter = 1 in { 2036 class FEXP2_W_1_PSEUDO_DESC : 2037 MSAPseudo<(outs MSA128W:$wd), (ins MSA128W:$ws), 2038 [(set MSA128W:$wd, (fexp2 MSA128W:$ws))]>; 2039 class FEXP2_D_1_PSEUDO_DESC : 2040 MSAPseudo<(outs MSA128D:$wd), (ins MSA128D:$ws), 2041 [(set MSA128D:$wd, (fexp2 MSA128D:$ws))]>; 2042} 2043 2044class FEXUPL_W_DESC : MSA_2RF_DESC_BASE<"fexupl.w", int_mips_fexupl_w, 2045 MSA128WOpnd, MSA128HOpnd>; 2046class FEXUPL_D_DESC : MSA_2RF_DESC_BASE<"fexupl.d", int_mips_fexupl_d, 2047 MSA128DOpnd, MSA128WOpnd>; 2048 2049class FEXUPR_W_DESC : MSA_2RF_DESC_BASE<"fexupr.w", int_mips_fexupr_w, 2050 MSA128WOpnd, MSA128HOpnd>; 2051class FEXUPR_D_DESC : MSA_2RF_DESC_BASE<"fexupr.d", int_mips_fexupr_d, 2052 MSA128DOpnd, MSA128WOpnd>; 2053 2054class FFINT_S_W_DESC : MSA_2RF_DESC_BASE<"ffint_s.w", sint_to_fp, MSA128WOpnd>; 2055class FFINT_S_D_DESC : MSA_2RF_DESC_BASE<"ffint_s.d", sint_to_fp, MSA128DOpnd>; 2056 2057class FFINT_U_W_DESC : MSA_2RF_DESC_BASE<"ffint_u.w", uint_to_fp, MSA128WOpnd>; 2058class FFINT_U_D_DESC : MSA_2RF_DESC_BASE<"ffint_u.d", uint_to_fp, MSA128DOpnd>; 2059 2060class FFQL_W_DESC : MSA_2RF_DESC_BASE<"ffql.w", int_mips_ffql_w, 2061 MSA128WOpnd, MSA128HOpnd>; 2062class FFQL_D_DESC : MSA_2RF_DESC_BASE<"ffql.d", int_mips_ffql_d, 2063 MSA128DOpnd, MSA128WOpnd>; 2064 2065class FFQR_W_DESC : MSA_2RF_DESC_BASE<"ffqr.w", int_mips_ffqr_w, 2066 MSA128WOpnd, MSA128HOpnd>; 2067class FFQR_D_DESC : MSA_2RF_DESC_BASE<"ffqr.d", int_mips_ffqr_d, 2068 MSA128DOpnd, MSA128WOpnd>; 2069 2070class FILL_B_DESC : MSA_2R_FILL_DESC_BASE<"fill.b", v16i8, vsplati8, 2071 MSA128BOpnd, GPR32Opnd>; 2072class FILL_H_DESC : MSA_2R_FILL_DESC_BASE<"fill.h", v8i16, vsplati16, 2073 MSA128HOpnd, GPR32Opnd>; 2074class FILL_W_DESC : MSA_2R_FILL_DESC_BASE<"fill.w", v4i32, vsplati32, 2075 MSA128WOpnd, GPR32Opnd>; 2076class FILL_D_DESC : MSA_2R_FILL_DESC_BASE<"fill.d", v2i64, vsplati64, 2077 MSA128DOpnd, GPR64Opnd>; 2078 2079class FILL_FW_PSEUDO_DESC : MSA_2R_FILL_PSEUDO_BASE<v4f32, vsplatf32, MSA128W, 2080 FGR32>; 2081class FILL_FD_PSEUDO_DESC : MSA_2R_FILL_PSEUDO_BASE<v2f64, vsplatf64, MSA128D, 2082 FGR64>; 2083 2084class FLOG2_W_DESC : MSA_2RF_DESC_BASE<"flog2.w", flog2, MSA128WOpnd>; 2085class FLOG2_D_DESC : MSA_2RF_DESC_BASE<"flog2.d", flog2, MSA128DOpnd>; 2086 2087class FMADD_W_DESC : MSA_3RF_4RF_DESC_BASE<"fmadd.w", fma, MSA128WOpnd>; 2088class FMADD_D_DESC : MSA_3RF_4RF_DESC_BASE<"fmadd.d", fma, MSA128DOpnd>; 2089 2090class FMAX_W_DESC : MSA_3RF_DESC_BASE<"fmax.w", int_mips_fmax_w, MSA128WOpnd>; 2091class FMAX_D_DESC : MSA_3RF_DESC_BASE<"fmax.d", int_mips_fmax_d, MSA128DOpnd>; 2092 2093class FMAX_A_W_DESC : MSA_3RF_DESC_BASE<"fmax_a.w", int_mips_fmax_a_w, 2094 MSA128WOpnd>; 2095class FMAX_A_D_DESC : MSA_3RF_DESC_BASE<"fmax_a.d", int_mips_fmax_a_d, 2096 MSA128DOpnd>; 2097 2098class FMIN_W_DESC : MSA_3RF_DESC_BASE<"fmin.w", int_mips_fmin_w, MSA128WOpnd>; 2099class FMIN_D_DESC : MSA_3RF_DESC_BASE<"fmin.d", int_mips_fmin_d, MSA128DOpnd>; 2100 2101class FMIN_A_W_DESC : MSA_3RF_DESC_BASE<"fmin_a.w", int_mips_fmin_a_w, 2102 MSA128WOpnd>; 2103class FMIN_A_D_DESC : MSA_3RF_DESC_BASE<"fmin_a.d", int_mips_fmin_a_d, 2104 MSA128DOpnd>; 2105 2106class FMSUB_W_DESC : MSA_3RF_4RF_DESC_BASE<"fmsub.w", fms, MSA128WOpnd>; 2107class FMSUB_D_DESC : MSA_3RF_4RF_DESC_BASE<"fmsub.d", fms, MSA128DOpnd>; 2108 2109class FMUL_W_DESC : MSA_3RF_DESC_BASE<"fmul.w", fmul, MSA128WOpnd>; 2110class FMUL_D_DESC : MSA_3RF_DESC_BASE<"fmul.d", fmul, MSA128DOpnd>; 2111 2112class FRINT_W_DESC : MSA_2RF_DESC_BASE<"frint.w", frint, MSA128WOpnd>; 2113class FRINT_D_DESC : MSA_2RF_DESC_BASE<"frint.d", frint, MSA128DOpnd>; 2114 2115class FRCP_W_DESC : MSA_2RF_DESC_BASE<"frcp.w", int_mips_frcp_w, MSA128WOpnd>; 2116class FRCP_D_DESC : MSA_2RF_DESC_BASE<"frcp.d", int_mips_frcp_d, MSA128DOpnd>; 2117 2118class FRSQRT_W_DESC : MSA_2RF_DESC_BASE<"frsqrt.w", int_mips_frsqrt_w, 2119 MSA128WOpnd>; 2120class FRSQRT_D_DESC : MSA_2RF_DESC_BASE<"frsqrt.d", int_mips_frsqrt_d, 2121 MSA128DOpnd>; 2122 2123class FSAF_W_DESC : MSA_3RF_DESC_BASE<"fsaf.w", int_mips_fsaf_w, MSA128WOpnd>; 2124class FSAF_D_DESC : MSA_3RF_DESC_BASE<"fsaf.d", int_mips_fsaf_d, MSA128DOpnd>; 2125 2126class FSEQ_W_DESC : MSA_3RF_DESC_BASE<"fseq.w", int_mips_fseq_w, MSA128WOpnd>; 2127class FSEQ_D_DESC : MSA_3RF_DESC_BASE<"fseq.d", int_mips_fseq_d, MSA128DOpnd>; 2128 2129class FSLE_W_DESC : MSA_3RF_DESC_BASE<"fsle.w", int_mips_fsle_w, MSA128WOpnd>; 2130class FSLE_D_DESC : MSA_3RF_DESC_BASE<"fsle.d", int_mips_fsle_d, MSA128DOpnd>; 2131 2132class FSLT_W_DESC : MSA_3RF_DESC_BASE<"fslt.w", int_mips_fslt_w, MSA128WOpnd>; 2133class FSLT_D_DESC : MSA_3RF_DESC_BASE<"fslt.d", int_mips_fslt_d, MSA128DOpnd>; 2134 2135class FSNE_W_DESC : MSA_3RF_DESC_BASE<"fsne.w", int_mips_fsne_w, MSA128WOpnd>; 2136class FSNE_D_DESC : MSA_3RF_DESC_BASE<"fsne.d", int_mips_fsne_d, MSA128DOpnd>; 2137 2138class FSOR_W_DESC : MSA_3RF_DESC_BASE<"fsor.w", int_mips_fsor_w, MSA128WOpnd>; 2139class FSOR_D_DESC : MSA_3RF_DESC_BASE<"fsor.d", int_mips_fsor_d, MSA128DOpnd>; 2140 2141class FSQRT_W_DESC : MSA_2RF_DESC_BASE<"fsqrt.w", fsqrt, MSA128WOpnd>; 2142class FSQRT_D_DESC : MSA_2RF_DESC_BASE<"fsqrt.d", fsqrt, MSA128DOpnd>; 2143 2144class FSUB_W_DESC : MSA_3RF_DESC_BASE<"fsub.w", fsub, MSA128WOpnd>; 2145class FSUB_D_DESC : MSA_3RF_DESC_BASE<"fsub.d", fsub, MSA128DOpnd>; 2146 2147class FSUEQ_W_DESC : MSA_3RF_DESC_BASE<"fsueq.w", int_mips_fsueq_w, 2148 MSA128WOpnd>; 2149class FSUEQ_D_DESC : MSA_3RF_DESC_BASE<"fsueq.d", int_mips_fsueq_d, 2150 MSA128DOpnd>; 2151 2152class FSULE_W_DESC : MSA_3RF_DESC_BASE<"fsule.w", int_mips_fsule_w, 2153 MSA128WOpnd>; 2154class FSULE_D_DESC : MSA_3RF_DESC_BASE<"fsule.d", int_mips_fsule_d, 2155 MSA128DOpnd>; 2156 2157class FSULT_W_DESC : MSA_3RF_DESC_BASE<"fsult.w", int_mips_fsult_w, 2158 MSA128WOpnd>; 2159class FSULT_D_DESC : MSA_3RF_DESC_BASE<"fsult.d", int_mips_fsult_d, 2160 MSA128DOpnd>; 2161 2162class FSUN_W_DESC : MSA_3RF_DESC_BASE<"fsun.w", int_mips_fsun_w, 2163 MSA128WOpnd>; 2164class FSUN_D_DESC : MSA_3RF_DESC_BASE<"fsun.d", int_mips_fsun_d, 2165 MSA128DOpnd>; 2166 2167class FSUNE_W_DESC : MSA_3RF_DESC_BASE<"fsune.w", int_mips_fsune_w, 2168 MSA128WOpnd>; 2169class FSUNE_D_DESC : MSA_3RF_DESC_BASE<"fsune.d", int_mips_fsune_d, 2170 MSA128DOpnd>; 2171 2172class FTINT_S_W_DESC : MSA_2RF_DESC_BASE<"ftint_s.w", int_mips_ftint_s_w, 2173 MSA128WOpnd>; 2174class FTINT_S_D_DESC : MSA_2RF_DESC_BASE<"ftint_s.d", int_mips_ftint_s_d, 2175 MSA128DOpnd>; 2176 2177class FTINT_U_W_DESC : MSA_2RF_DESC_BASE<"ftint_u.w", int_mips_ftint_u_w, 2178 MSA128WOpnd>; 2179class FTINT_U_D_DESC : MSA_2RF_DESC_BASE<"ftint_u.d", int_mips_ftint_u_d, 2180 MSA128DOpnd>; 2181 2182class FTQ_H_DESC : MSA_3RF_DESC_BASE<"ftq.h", int_mips_ftq_h, 2183 MSA128HOpnd, MSA128WOpnd, MSA128WOpnd>; 2184class FTQ_W_DESC : MSA_3RF_DESC_BASE<"ftq.w", int_mips_ftq_w, 2185 MSA128WOpnd, MSA128DOpnd, MSA128DOpnd>; 2186 2187class FTRUNC_S_W_DESC : MSA_2RF_DESC_BASE<"ftrunc_s.w", fp_to_sint, 2188 MSA128WOpnd>; 2189class FTRUNC_S_D_DESC : MSA_2RF_DESC_BASE<"ftrunc_s.d", fp_to_sint, 2190 MSA128DOpnd>; 2191 2192class FTRUNC_U_W_DESC : MSA_2RF_DESC_BASE<"ftrunc_u.w", fp_to_uint, 2193 MSA128WOpnd>; 2194class FTRUNC_U_D_DESC : MSA_2RF_DESC_BASE<"ftrunc_u.d", fp_to_uint, 2195 MSA128DOpnd>; 2196 2197class HADD_S_H_DESC : MSA_3R_DESC_BASE<"hadd_s.h", int_mips_hadd_s_h, 2198 MSA128HOpnd, MSA128BOpnd, MSA128BOpnd>; 2199class HADD_S_W_DESC : MSA_3R_DESC_BASE<"hadd_s.w", int_mips_hadd_s_w, 2200 MSA128WOpnd, MSA128HOpnd, MSA128HOpnd>; 2201class HADD_S_D_DESC : MSA_3R_DESC_BASE<"hadd_s.d", int_mips_hadd_s_d, 2202 MSA128DOpnd, MSA128WOpnd, MSA128WOpnd>; 2203 2204class HADD_U_H_DESC : MSA_3R_DESC_BASE<"hadd_u.h", int_mips_hadd_u_h, 2205 MSA128HOpnd, MSA128BOpnd, MSA128BOpnd>; 2206class HADD_U_W_DESC : MSA_3R_DESC_BASE<"hadd_u.w", int_mips_hadd_u_w, 2207 MSA128WOpnd, MSA128HOpnd, MSA128HOpnd>; 2208class HADD_U_D_DESC : MSA_3R_DESC_BASE<"hadd_u.d", int_mips_hadd_u_d, 2209 MSA128DOpnd, MSA128WOpnd, MSA128WOpnd>; 2210 2211class HSUB_S_H_DESC : MSA_3R_DESC_BASE<"hsub_s.h", int_mips_hsub_s_h, 2212 MSA128HOpnd, MSA128BOpnd, MSA128BOpnd>; 2213class HSUB_S_W_DESC : MSA_3R_DESC_BASE<"hsub_s.w", int_mips_hsub_s_w, 2214 MSA128WOpnd, MSA128HOpnd, MSA128HOpnd>; 2215class HSUB_S_D_DESC : MSA_3R_DESC_BASE<"hsub_s.d", int_mips_hsub_s_d, 2216 MSA128DOpnd, MSA128WOpnd, MSA128WOpnd>; 2217 2218class HSUB_U_H_DESC : MSA_3R_DESC_BASE<"hsub_u.h", int_mips_hsub_u_h, 2219 MSA128HOpnd, MSA128BOpnd, MSA128BOpnd>; 2220class HSUB_U_W_DESC : MSA_3R_DESC_BASE<"hsub_u.w", int_mips_hsub_u_w, 2221 MSA128WOpnd, MSA128HOpnd, MSA128HOpnd>; 2222class HSUB_U_D_DESC : MSA_3R_DESC_BASE<"hsub_u.d", int_mips_hsub_u_d, 2223 MSA128DOpnd, MSA128WOpnd, MSA128WOpnd>; 2224 2225class ILVEV_B_DESC : MSA_3R_DESC_BASE<"ilvev.b", MipsILVEV, MSA128BOpnd>; 2226class ILVEV_H_DESC : MSA_3R_DESC_BASE<"ilvev.h", MipsILVEV, MSA128HOpnd>; 2227class ILVEV_W_DESC : MSA_3R_DESC_BASE<"ilvev.w", MipsILVEV, MSA128WOpnd>; 2228class ILVEV_D_DESC : MSA_3R_DESC_BASE<"ilvev.d", MipsILVEV, MSA128DOpnd>; 2229 2230class ILVL_B_DESC : MSA_3R_DESC_BASE<"ilvl.b", MipsILVL, MSA128BOpnd>; 2231class ILVL_H_DESC : MSA_3R_DESC_BASE<"ilvl.h", MipsILVL, MSA128HOpnd>; 2232class ILVL_W_DESC : MSA_3R_DESC_BASE<"ilvl.w", MipsILVL, MSA128WOpnd>; 2233class ILVL_D_DESC : MSA_3R_DESC_BASE<"ilvl.d", MipsILVL, MSA128DOpnd>; 2234 2235class ILVOD_B_DESC : MSA_3R_DESC_BASE<"ilvod.b", MipsILVOD, MSA128BOpnd>; 2236class ILVOD_H_DESC : MSA_3R_DESC_BASE<"ilvod.h", MipsILVOD, MSA128HOpnd>; 2237class ILVOD_W_DESC : MSA_3R_DESC_BASE<"ilvod.w", MipsILVOD, MSA128WOpnd>; 2238class ILVOD_D_DESC : MSA_3R_DESC_BASE<"ilvod.d", MipsILVOD, MSA128DOpnd>; 2239 2240class ILVR_B_DESC : MSA_3R_DESC_BASE<"ilvr.b", MipsILVR, MSA128BOpnd>; 2241class ILVR_H_DESC : MSA_3R_DESC_BASE<"ilvr.h", MipsILVR, MSA128HOpnd>; 2242class ILVR_W_DESC : MSA_3R_DESC_BASE<"ilvr.w", MipsILVR, MSA128WOpnd>; 2243class ILVR_D_DESC : MSA_3R_DESC_BASE<"ilvr.d", MipsILVR, MSA128DOpnd>; 2244 2245class INSERT_B_DESC : MSA_INSERT_DESC_BASE<"insert.b", vinsert_v16i8, uimm4, 2246 immZExt4Ptr, MSA128BOpnd, GPR32Opnd>; 2247class INSERT_H_DESC : MSA_INSERT_DESC_BASE<"insert.h", vinsert_v8i16, uimm3, 2248 immZExt3Ptr, MSA128HOpnd, GPR32Opnd>; 2249class INSERT_W_DESC : MSA_INSERT_DESC_BASE<"insert.w", vinsert_v4i32, uimm2, 2250 immZExt2Ptr, MSA128WOpnd, GPR32Opnd>; 2251class INSERT_D_DESC : MSA_INSERT_DESC_BASE<"insert.d", vinsert_v2i64, uimm1, 2252 immZExt1Ptr, MSA128DOpnd, GPR64Opnd>; 2253 2254class INSERT_B_VIDX_PSEUDO_DESC : 2255 MSA_INSERT_VIDX_PSEUDO_BASE<vector_insert, v16i8, MSA128BOpnd, GPR32Opnd, GPR32Opnd>; 2256class INSERT_H_VIDX_PSEUDO_DESC : 2257 MSA_INSERT_VIDX_PSEUDO_BASE<vector_insert, v8i16, MSA128HOpnd, GPR32Opnd, GPR32Opnd>; 2258class INSERT_W_VIDX_PSEUDO_DESC : 2259 MSA_INSERT_VIDX_PSEUDO_BASE<vector_insert, v4i32, MSA128WOpnd, GPR32Opnd, GPR32Opnd>; 2260class INSERT_D_VIDX_PSEUDO_DESC : 2261 MSA_INSERT_VIDX_PSEUDO_BASE<vector_insert, v2i64, MSA128DOpnd, GPR64Opnd, GPR32Opnd>; 2262 2263class INSERT_FW_PSEUDO_DESC : MSA_INSERT_PSEUDO_BASE<vector_insert, v4f32, 2264 uimm2, immZExt2Ptr, 2265 MSA128WOpnd, FGR32Opnd>; 2266class INSERT_FD_PSEUDO_DESC : MSA_INSERT_PSEUDO_BASE<vector_insert, v2f64, 2267 uimm1, immZExt1Ptr, 2268 MSA128DOpnd, FGR64Opnd>; 2269 2270class INSERT_FW_VIDX_PSEUDO_DESC : 2271 MSA_INSERT_VIDX_PSEUDO_BASE<vector_insert, v4f32, MSA128WOpnd, FGR32Opnd, GPR32Opnd>; 2272class INSERT_FD_VIDX_PSEUDO_DESC : 2273 MSA_INSERT_VIDX_PSEUDO_BASE<vector_insert, v2f64, MSA128DOpnd, FGR64Opnd, GPR32Opnd>; 2274 2275class INSERT_B_VIDX64_PSEUDO_DESC : 2276 MSA_INSERT_VIDX_PSEUDO_BASE<vector_insert, v16i8, MSA128BOpnd, GPR32Opnd, GPR64Opnd>; 2277class INSERT_H_VIDX64_PSEUDO_DESC : 2278 MSA_INSERT_VIDX_PSEUDO_BASE<vector_insert, v8i16, MSA128HOpnd, GPR32Opnd, GPR64Opnd>; 2279class INSERT_W_VIDX64_PSEUDO_DESC : 2280 MSA_INSERT_VIDX_PSEUDO_BASE<vector_insert, v4i32, MSA128WOpnd, GPR32Opnd, GPR64Opnd>; 2281class INSERT_D_VIDX64_PSEUDO_DESC : 2282 MSA_INSERT_VIDX_PSEUDO_BASE<vector_insert, v2i64, MSA128DOpnd, GPR64Opnd, GPR64Opnd>; 2283 2284class INSERT_FW_VIDX64_PSEUDO_DESC : 2285 MSA_INSERT_VIDX_PSEUDO_BASE<vector_insert, v4f32, MSA128WOpnd, FGR32Opnd, GPR64Opnd>; 2286class INSERT_FD_VIDX64_PSEUDO_DESC : 2287 MSA_INSERT_VIDX_PSEUDO_BASE<vector_insert, v2f64, MSA128DOpnd, FGR64Opnd, GPR64Opnd>; 2288 2289class INSVE_B_DESC : MSA_INSVE_DESC_BASE<"insve.b", insve_v16i8, uimm4, immZExt4, 2290 MSA128BOpnd>; 2291class INSVE_H_DESC : MSA_INSVE_DESC_BASE<"insve.h", insve_v8i16, uimm3, immZExt3, 2292 MSA128HOpnd>; 2293class INSVE_W_DESC : MSA_INSVE_DESC_BASE<"insve.w", insve_v4i32, uimm2, immZExt2, 2294 MSA128WOpnd>; 2295class INSVE_D_DESC : MSA_INSVE_DESC_BASE<"insve.d", insve_v2i64, uimm1, immZExt1, 2296 MSA128DOpnd>; 2297 2298class LD_DESC_BASE<string instr_asm, SDPatternOperator OpNode, 2299 ValueType TyNode, RegisterOperand ROWD, 2300 Operand MemOpnd, ComplexPattern Addr = addrimm10, 2301 InstrItinClass itin = NoItinerary> { 2302 dag OutOperandList = (outs ROWD:$wd); 2303 dag InOperandList = (ins MemOpnd:$addr); 2304 string AsmString = !strconcat(instr_asm, "\t$wd, $addr"); 2305 list<dag> Pattern = [(set ROWD:$wd, (TyNode (OpNode Addr:$addr)))]; 2306 InstrItinClass Itinerary = itin; 2307 string DecoderMethod = "DecodeMSA128Mem"; 2308} 2309 2310class LD_B_DESC : LD_DESC_BASE<"ld.b", load, v16i8, MSA128BOpnd, mem_simm10>; 2311class LD_H_DESC : LD_DESC_BASE<"ld.h", load, v8i16, MSA128HOpnd, mem_simm10_lsl1>; 2312class LD_W_DESC : LD_DESC_BASE<"ld.w", load, v4i32, MSA128WOpnd, mem_simm10_lsl2>; 2313class LD_D_DESC : LD_DESC_BASE<"ld.d", load, v2i64, MSA128DOpnd, mem_simm10_lsl3>; 2314 2315class LDI_B_DESC : MSA_I10_LDI_DESC_BASE<"ldi.b", MSA128BOpnd>; 2316class LDI_H_DESC : MSA_I10_LDI_DESC_BASE<"ldi.h", MSA128HOpnd>; 2317class LDI_W_DESC : MSA_I10_LDI_DESC_BASE<"ldi.w", MSA128WOpnd>; 2318class LDI_D_DESC : MSA_I10_LDI_DESC_BASE<"ldi.d", MSA128DOpnd>; 2319 2320class LSA_DESC_BASE<string instr_asm, RegisterOperand RORD, 2321 InstrItinClass itin = NoItinerary> { 2322 dag OutOperandList = (outs RORD:$rd); 2323 dag InOperandList = (ins RORD:$rs, RORD:$rt, uimm2_plus1:$sa); 2324 string AsmString = !strconcat(instr_asm, "\t$rd, $rs, $rt, $sa"); 2325 list<dag> Pattern = [(set RORD:$rd, (add RORD:$rt, 2326 (shl RORD:$rs, 2327 immZExt2Lsa:$sa)))]; 2328 InstrItinClass Itinerary = itin; 2329} 2330 2331class LSA_DESC : LSA_DESC_BASE<"lsa", GPR32Opnd, II_LSA>; 2332class DLSA_DESC : LSA_DESC_BASE<"dlsa", GPR64Opnd, II_DLSA>; 2333 2334class MADD_Q_H_DESC : MSA_3RF_4RF_DESC_BASE<"madd_q.h", int_mips_madd_q_h, 2335 MSA128HOpnd>; 2336class MADD_Q_W_DESC : MSA_3RF_4RF_DESC_BASE<"madd_q.w", int_mips_madd_q_w, 2337 MSA128WOpnd>; 2338 2339class MADDR_Q_H_DESC : MSA_3RF_4RF_DESC_BASE<"maddr_q.h", int_mips_maddr_q_h, 2340 MSA128HOpnd>; 2341class MADDR_Q_W_DESC : MSA_3RF_4RF_DESC_BASE<"maddr_q.w", int_mips_maddr_q_w, 2342 MSA128WOpnd>; 2343 2344class MADDV_B_DESC : MSA_3R_4R_DESC_BASE<"maddv.b", muladd, MSA128BOpnd>; 2345class MADDV_H_DESC : MSA_3R_4R_DESC_BASE<"maddv.h", muladd, MSA128HOpnd>; 2346class MADDV_W_DESC : MSA_3R_4R_DESC_BASE<"maddv.w", muladd, MSA128WOpnd>; 2347class MADDV_D_DESC : MSA_3R_4R_DESC_BASE<"maddv.d", muladd, MSA128DOpnd>; 2348 2349class MAX_A_B_DESC : MSA_3R_DESC_BASE<"max_a.b", int_mips_max_a_b, MSA128BOpnd>; 2350class MAX_A_H_DESC : MSA_3R_DESC_BASE<"max_a.h", int_mips_max_a_h, MSA128HOpnd>; 2351class MAX_A_W_DESC : MSA_3R_DESC_BASE<"max_a.w", int_mips_max_a_w, MSA128WOpnd>; 2352class MAX_A_D_DESC : MSA_3R_DESC_BASE<"max_a.d", int_mips_max_a_d, MSA128DOpnd>; 2353 2354class MAX_S_B_DESC : MSA_3R_DESC_BASE<"max_s.b", MipsVSMax, MSA128BOpnd>; 2355class MAX_S_H_DESC : MSA_3R_DESC_BASE<"max_s.h", MipsVSMax, MSA128HOpnd>; 2356class MAX_S_W_DESC : MSA_3R_DESC_BASE<"max_s.w", MipsVSMax, MSA128WOpnd>; 2357class MAX_S_D_DESC : MSA_3R_DESC_BASE<"max_s.d", MipsVSMax, MSA128DOpnd>; 2358 2359class MAX_U_B_DESC : MSA_3R_DESC_BASE<"max_u.b", MipsVUMax, MSA128BOpnd>; 2360class MAX_U_H_DESC : MSA_3R_DESC_BASE<"max_u.h", MipsVUMax, MSA128HOpnd>; 2361class MAX_U_W_DESC : MSA_3R_DESC_BASE<"max_u.w", MipsVUMax, MSA128WOpnd>; 2362class MAX_U_D_DESC : MSA_3R_DESC_BASE<"max_u.d", MipsVUMax, MSA128DOpnd>; 2363 2364class MAXI_S_B_DESC : MSA_I5_DESC_BASE<"maxi_s.b", MipsVSMax, vsplati8_simm5, 2365 MSA128BOpnd>; 2366class MAXI_S_H_DESC : MSA_I5_DESC_BASE<"maxi_s.h", MipsVSMax, vsplati16_simm5, 2367 MSA128HOpnd>; 2368class MAXI_S_W_DESC : MSA_I5_DESC_BASE<"maxi_s.w", MipsVSMax, vsplati32_simm5, 2369 MSA128WOpnd>; 2370class MAXI_S_D_DESC : MSA_I5_DESC_BASE<"maxi_s.d", MipsVSMax, vsplati64_simm5, 2371 MSA128DOpnd>; 2372 2373class MAXI_U_B_DESC : MSA_I5_DESC_BASE<"maxi_u.b", MipsVUMax, vsplati8_uimm5, 2374 MSA128BOpnd>; 2375class MAXI_U_H_DESC : MSA_I5_DESC_BASE<"maxi_u.h", MipsVUMax, vsplati16_uimm5, 2376 MSA128HOpnd>; 2377class MAXI_U_W_DESC : MSA_I5_DESC_BASE<"maxi_u.w", MipsVUMax, vsplati32_uimm5, 2378 MSA128WOpnd>; 2379class MAXI_U_D_DESC : MSA_I5_DESC_BASE<"maxi_u.d", MipsVUMax, vsplati64_uimm5, 2380 MSA128DOpnd>; 2381 2382class MIN_A_B_DESC : MSA_3R_DESC_BASE<"min_a.b", int_mips_min_a_b, MSA128BOpnd>; 2383class MIN_A_H_DESC : MSA_3R_DESC_BASE<"min_a.h", int_mips_min_a_h, MSA128HOpnd>; 2384class MIN_A_W_DESC : MSA_3R_DESC_BASE<"min_a.w", int_mips_min_a_w, MSA128WOpnd>; 2385class MIN_A_D_DESC : MSA_3R_DESC_BASE<"min_a.d", int_mips_min_a_d, MSA128DOpnd>; 2386 2387class MIN_S_B_DESC : MSA_3R_DESC_BASE<"min_s.b", MipsVSMin, MSA128BOpnd>; 2388class MIN_S_H_DESC : MSA_3R_DESC_BASE<"min_s.h", MipsVSMin, MSA128HOpnd>; 2389class MIN_S_W_DESC : MSA_3R_DESC_BASE<"min_s.w", MipsVSMin, MSA128WOpnd>; 2390class MIN_S_D_DESC : MSA_3R_DESC_BASE<"min_s.d", MipsVSMin, MSA128DOpnd>; 2391 2392class MIN_U_B_DESC : MSA_3R_DESC_BASE<"min_u.b", MipsVUMin, MSA128BOpnd>; 2393class MIN_U_H_DESC : MSA_3R_DESC_BASE<"min_u.h", MipsVUMin, MSA128HOpnd>; 2394class MIN_U_W_DESC : MSA_3R_DESC_BASE<"min_u.w", MipsVUMin, MSA128WOpnd>; 2395class MIN_U_D_DESC : MSA_3R_DESC_BASE<"min_u.d", MipsVUMin, MSA128DOpnd>; 2396 2397class MINI_S_B_DESC : MSA_I5_DESC_BASE<"mini_s.b", MipsVSMin, vsplati8_simm5, 2398 MSA128BOpnd>; 2399class MINI_S_H_DESC : MSA_I5_DESC_BASE<"mini_s.h", MipsVSMin, vsplati16_simm5, 2400 MSA128HOpnd>; 2401class MINI_S_W_DESC : MSA_I5_DESC_BASE<"mini_s.w", MipsVSMin, vsplati32_simm5, 2402 MSA128WOpnd>; 2403class MINI_S_D_DESC : MSA_I5_DESC_BASE<"mini_s.d", MipsVSMin, vsplati64_simm5, 2404 MSA128DOpnd>; 2405 2406class MINI_U_B_DESC : MSA_I5_DESC_BASE<"mini_u.b", MipsVUMin, vsplati8_uimm5, 2407 MSA128BOpnd>; 2408class MINI_U_H_DESC : MSA_I5_DESC_BASE<"mini_u.h", MipsVUMin, vsplati16_uimm5, 2409 MSA128HOpnd>; 2410class MINI_U_W_DESC : MSA_I5_DESC_BASE<"mini_u.w", MipsVUMin, vsplati32_uimm5, 2411 MSA128WOpnd>; 2412class MINI_U_D_DESC : MSA_I5_DESC_BASE<"mini_u.d", MipsVUMin, vsplati64_uimm5, 2413 MSA128DOpnd>; 2414 2415class MOD_S_B_DESC : MSA_3R_DESC_BASE<"mod_s.b", srem, MSA128BOpnd>; 2416class MOD_S_H_DESC : MSA_3R_DESC_BASE<"mod_s.h", srem, MSA128HOpnd>; 2417class MOD_S_W_DESC : MSA_3R_DESC_BASE<"mod_s.w", srem, MSA128WOpnd>; 2418class MOD_S_D_DESC : MSA_3R_DESC_BASE<"mod_s.d", srem, MSA128DOpnd>; 2419 2420class MOD_U_B_DESC : MSA_3R_DESC_BASE<"mod_u.b", urem, MSA128BOpnd>; 2421class MOD_U_H_DESC : MSA_3R_DESC_BASE<"mod_u.h", urem, MSA128HOpnd>; 2422class MOD_U_W_DESC : MSA_3R_DESC_BASE<"mod_u.w", urem, MSA128WOpnd>; 2423class MOD_U_D_DESC : MSA_3R_DESC_BASE<"mod_u.d", urem, MSA128DOpnd>; 2424 2425class MOVE_V_DESC { 2426 dag OutOperandList = (outs MSA128BOpnd:$wd); 2427 dag InOperandList = (ins MSA128BOpnd:$ws); 2428 string AsmString = "move.v\t$wd, $ws"; 2429 list<dag> Pattern = []; 2430 InstrItinClass Itinerary = NoItinerary; 2431} 2432 2433class MSUB_Q_H_DESC : MSA_3RF_4RF_DESC_BASE<"msub_q.h", int_mips_msub_q_h, 2434 MSA128HOpnd>; 2435class MSUB_Q_W_DESC : MSA_3RF_4RF_DESC_BASE<"msub_q.w", int_mips_msub_q_w, 2436 MSA128WOpnd>; 2437 2438class MSUBR_Q_H_DESC : MSA_3RF_4RF_DESC_BASE<"msubr_q.h", int_mips_msubr_q_h, 2439 MSA128HOpnd>; 2440class MSUBR_Q_W_DESC : MSA_3RF_4RF_DESC_BASE<"msubr_q.w", int_mips_msubr_q_w, 2441 MSA128WOpnd>; 2442 2443class MSUBV_B_DESC : MSA_3R_4R_DESC_BASE<"msubv.b", mulsub, MSA128BOpnd>; 2444class MSUBV_H_DESC : MSA_3R_4R_DESC_BASE<"msubv.h", mulsub, MSA128HOpnd>; 2445class MSUBV_W_DESC : MSA_3R_4R_DESC_BASE<"msubv.w", mulsub, MSA128WOpnd>; 2446class MSUBV_D_DESC : MSA_3R_4R_DESC_BASE<"msubv.d", mulsub, MSA128DOpnd>; 2447 2448class MUL_Q_H_DESC : MSA_3RF_DESC_BASE<"mul_q.h", int_mips_mul_q_h, 2449 MSA128HOpnd>; 2450class MUL_Q_W_DESC : MSA_3RF_DESC_BASE<"mul_q.w", int_mips_mul_q_w, 2451 MSA128WOpnd>; 2452 2453class MULR_Q_H_DESC : MSA_3RF_DESC_BASE<"mulr_q.h", int_mips_mulr_q_h, 2454 MSA128HOpnd>; 2455class MULR_Q_W_DESC : MSA_3RF_DESC_BASE<"mulr_q.w", int_mips_mulr_q_w, 2456 MSA128WOpnd>; 2457 2458class MULV_B_DESC : MSA_3R_DESC_BASE<"mulv.b", mul, MSA128BOpnd>; 2459class MULV_H_DESC : MSA_3R_DESC_BASE<"mulv.h", mul, MSA128HOpnd>; 2460class MULV_W_DESC : MSA_3R_DESC_BASE<"mulv.w", mul, MSA128WOpnd>; 2461class MULV_D_DESC : MSA_3R_DESC_BASE<"mulv.d", mul, MSA128DOpnd>; 2462 2463class NLOC_B_DESC : MSA_2R_DESC_BASE<"nloc.b", int_mips_nloc_b, MSA128BOpnd>; 2464class NLOC_H_DESC : MSA_2R_DESC_BASE<"nloc.h", int_mips_nloc_h, MSA128HOpnd>; 2465class NLOC_W_DESC : MSA_2R_DESC_BASE<"nloc.w", int_mips_nloc_w, MSA128WOpnd>; 2466class NLOC_D_DESC : MSA_2R_DESC_BASE<"nloc.d", int_mips_nloc_d, MSA128DOpnd>; 2467 2468class NLZC_B_DESC : MSA_2R_DESC_BASE<"nlzc.b", ctlz, MSA128BOpnd>; 2469class NLZC_H_DESC : MSA_2R_DESC_BASE<"nlzc.h", ctlz, MSA128HOpnd>; 2470class NLZC_W_DESC : MSA_2R_DESC_BASE<"nlzc.w", ctlz, MSA128WOpnd>; 2471class NLZC_D_DESC : MSA_2R_DESC_BASE<"nlzc.d", ctlz, MSA128DOpnd>; 2472 2473class NOR_V_DESC : MSA_VEC_DESC_BASE<"nor.v", MipsVNOR, MSA128BOpnd>; 2474class NOR_V_H_PSEUDO_DESC : MSA_VEC_PSEUDO_BASE<MipsVNOR, MSA128HOpnd>; 2475class NOR_V_W_PSEUDO_DESC : MSA_VEC_PSEUDO_BASE<MipsVNOR, MSA128WOpnd>; 2476class NOR_V_D_PSEUDO_DESC : MSA_VEC_PSEUDO_BASE<MipsVNOR, MSA128DOpnd>; 2477 2478class NORI_B_DESC : MSA_I8_DESC_BASE<"nori.b", MipsVNOR, vsplati8_uimm8, 2479 MSA128BOpnd>; 2480 2481class OR_V_DESC : MSA_VEC_DESC_BASE<"or.v", or, MSA128BOpnd>; 2482class OR_V_H_PSEUDO_DESC : MSA_VEC_PSEUDO_BASE<or, MSA128HOpnd>; 2483class OR_V_W_PSEUDO_DESC : MSA_VEC_PSEUDO_BASE<or, MSA128WOpnd>; 2484class OR_V_D_PSEUDO_DESC : MSA_VEC_PSEUDO_BASE<or, MSA128DOpnd>; 2485 2486class ORI_B_DESC : MSA_I8_DESC_BASE<"ori.b", or, vsplati8_uimm8, MSA128BOpnd>; 2487 2488class PCKEV_B_DESC : MSA_3R_DESC_BASE<"pckev.b", MipsPCKEV, MSA128BOpnd>; 2489class PCKEV_H_DESC : MSA_3R_DESC_BASE<"pckev.h", MipsPCKEV, MSA128HOpnd>; 2490class PCKEV_W_DESC : MSA_3R_DESC_BASE<"pckev.w", MipsPCKEV, MSA128WOpnd>; 2491class PCKEV_D_DESC : MSA_3R_DESC_BASE<"pckev.d", MipsPCKEV, MSA128DOpnd>; 2492 2493class PCKOD_B_DESC : MSA_3R_DESC_BASE<"pckod.b", MipsPCKOD, MSA128BOpnd>; 2494class PCKOD_H_DESC : MSA_3R_DESC_BASE<"pckod.h", MipsPCKOD, MSA128HOpnd>; 2495class PCKOD_W_DESC : MSA_3R_DESC_BASE<"pckod.w", MipsPCKOD, MSA128WOpnd>; 2496class PCKOD_D_DESC : MSA_3R_DESC_BASE<"pckod.d", MipsPCKOD, MSA128DOpnd>; 2497 2498class PCNT_B_DESC : MSA_2R_DESC_BASE<"pcnt.b", ctpop, MSA128BOpnd>; 2499class PCNT_H_DESC : MSA_2R_DESC_BASE<"pcnt.h", ctpop, MSA128HOpnd>; 2500class PCNT_W_DESC : MSA_2R_DESC_BASE<"pcnt.w", ctpop, MSA128WOpnd>; 2501class PCNT_D_DESC : MSA_2R_DESC_BASE<"pcnt.d", ctpop, MSA128DOpnd>; 2502 2503class SAT_S_B_DESC : MSA_BIT_X_DESC_BASE<"sat_s.b", int_mips_sat_s_b, uimm3, 2504 immZExt3, MSA128BOpnd>; 2505class SAT_S_H_DESC : MSA_BIT_X_DESC_BASE<"sat_s.h", int_mips_sat_s_h, uimm4, 2506 immZExt4, MSA128HOpnd>; 2507class SAT_S_W_DESC : MSA_BIT_X_DESC_BASE<"sat_s.w", int_mips_sat_s_w, uimm5, 2508 immZExt5, MSA128WOpnd>; 2509class SAT_S_D_DESC : MSA_BIT_X_DESC_BASE<"sat_s.d", int_mips_sat_s_d, uimm6, 2510 immZExt6, MSA128DOpnd>; 2511 2512class SAT_U_B_DESC : MSA_BIT_X_DESC_BASE<"sat_u.b", int_mips_sat_u_b, uimm3, 2513 immZExt3, MSA128BOpnd>; 2514class SAT_U_H_DESC : MSA_BIT_X_DESC_BASE<"sat_u.h", int_mips_sat_u_h, uimm4, 2515 immZExt4, MSA128HOpnd>; 2516class SAT_U_W_DESC : MSA_BIT_X_DESC_BASE<"sat_u.w", int_mips_sat_u_w, uimm5, 2517 immZExt5, MSA128WOpnd>; 2518class SAT_U_D_DESC : MSA_BIT_X_DESC_BASE<"sat_u.d", int_mips_sat_u_d, uimm6, 2519 immZExt6, MSA128DOpnd>; 2520 2521class SHF_B_DESC : MSA_I8_SHF_DESC_BASE<"shf.b", MSA128BOpnd>; 2522class SHF_H_DESC : MSA_I8_SHF_DESC_BASE<"shf.h", MSA128HOpnd>; 2523class SHF_W_DESC : MSA_I8_SHF_DESC_BASE<"shf.w", MSA128WOpnd>; 2524 2525class SLD_B_DESC : MSA_3R_SLD_DESC_BASE<"sld.b", int_mips_sld_b, MSA128BOpnd>; 2526class SLD_H_DESC : MSA_3R_SLD_DESC_BASE<"sld.h", int_mips_sld_h, MSA128HOpnd>; 2527class SLD_W_DESC : MSA_3R_SLD_DESC_BASE<"sld.w", int_mips_sld_w, MSA128WOpnd>; 2528class SLD_D_DESC : MSA_3R_SLD_DESC_BASE<"sld.d", int_mips_sld_d, MSA128DOpnd>; 2529 2530class SLDI_B_DESC : MSA_ELM_SLD_DESC_BASE<"sldi.b", int_mips_sldi_b, 2531 MSA128BOpnd, MSA128BOpnd, uimm4, 2532 immZExt4>; 2533class SLDI_H_DESC : MSA_ELM_SLD_DESC_BASE<"sldi.h", int_mips_sldi_h, 2534 MSA128HOpnd, MSA128HOpnd, uimm3, 2535 immZExt3>; 2536class SLDI_W_DESC : MSA_ELM_SLD_DESC_BASE<"sldi.w", int_mips_sldi_w, 2537 MSA128WOpnd, MSA128WOpnd, uimm2, 2538 immZExt2>; 2539class SLDI_D_DESC : MSA_ELM_SLD_DESC_BASE<"sldi.d", int_mips_sldi_d, 2540 MSA128DOpnd, MSA128DOpnd, uimm1, 2541 immZExt1>; 2542 2543class SLL_B_DESC : MSA_3R_DESC_BASE<"sll.b", shl, MSA128BOpnd>; 2544class SLL_H_DESC : MSA_3R_DESC_BASE<"sll.h", shl, MSA128HOpnd>; 2545class SLL_W_DESC : MSA_3R_DESC_BASE<"sll.w", shl, MSA128WOpnd>; 2546class SLL_D_DESC : MSA_3R_DESC_BASE<"sll.d", shl, MSA128DOpnd>; 2547 2548class SLLI_B_DESC : MSA_BIT_SPLAT_DESC_BASE<"slli.b", shl, vsplati8_uimm3, 2549 MSA128BOpnd>; 2550class SLLI_H_DESC : MSA_BIT_SPLAT_DESC_BASE<"slli.h", shl, vsplati16_uimm4, 2551 MSA128HOpnd>; 2552class SLLI_W_DESC : MSA_BIT_SPLAT_DESC_BASE<"slli.w", shl, vsplati32_uimm5, 2553 MSA128WOpnd>; 2554class SLLI_D_DESC : MSA_BIT_SPLAT_DESC_BASE<"slli.d", shl, vsplati64_uimm6, 2555 MSA128DOpnd>; 2556 2557class SPLAT_B_DESC : MSA_3R_SPLAT_DESC_BASE<"splat.b", vsplati8_elt, 2558 MSA128BOpnd>; 2559class SPLAT_H_DESC : MSA_3R_SPLAT_DESC_BASE<"splat.h", vsplati16_elt, 2560 MSA128HOpnd>; 2561class SPLAT_W_DESC : MSA_3R_SPLAT_DESC_BASE<"splat.w", vsplati32_elt, 2562 MSA128WOpnd>; 2563class SPLAT_D_DESC : MSA_3R_SPLAT_DESC_BASE<"splat.d", vsplati64_elt, 2564 MSA128DOpnd>; 2565 2566class SPLATI_B_DESC : MSA_ELM_SPLAT_DESC_BASE<"splati.b", vsplati8_uimm4, 2567 MSA128BOpnd>; 2568class SPLATI_H_DESC : MSA_ELM_SPLAT_DESC_BASE<"splati.h", vsplati16_uimm3, 2569 MSA128HOpnd>; 2570class SPLATI_W_DESC : MSA_ELM_SPLAT_DESC_BASE<"splati.w", vsplati32_uimm2, 2571 MSA128WOpnd>; 2572class SPLATI_D_DESC : MSA_ELM_SPLAT_DESC_BASE<"splati.d", vsplati64_uimm1, 2573 MSA128DOpnd>; 2574 2575class SRA_B_DESC : MSA_3R_DESC_BASE<"sra.b", sra, MSA128BOpnd>; 2576class SRA_H_DESC : MSA_3R_DESC_BASE<"sra.h", sra, MSA128HOpnd>; 2577class SRA_W_DESC : MSA_3R_DESC_BASE<"sra.w", sra, MSA128WOpnd>; 2578class SRA_D_DESC : MSA_3R_DESC_BASE<"sra.d", sra, MSA128DOpnd>; 2579 2580class SRAI_B_DESC : MSA_BIT_SPLAT_DESC_BASE<"srai.b", sra, vsplati8_uimm3, 2581 MSA128BOpnd>; 2582class SRAI_H_DESC : MSA_BIT_SPLAT_DESC_BASE<"srai.h", sra, vsplati16_uimm4, 2583 MSA128HOpnd>; 2584class SRAI_W_DESC : MSA_BIT_SPLAT_DESC_BASE<"srai.w", sra, vsplati32_uimm5, 2585 MSA128WOpnd>; 2586class SRAI_D_DESC : MSA_BIT_SPLAT_DESC_BASE<"srai.d", sra, vsplati64_uimm6, 2587 MSA128DOpnd>; 2588 2589class SRAR_B_DESC : MSA_3R_DESC_BASE<"srar.b", int_mips_srar_b, MSA128BOpnd>; 2590class SRAR_H_DESC : MSA_3R_DESC_BASE<"srar.h", int_mips_srar_h, MSA128HOpnd>; 2591class SRAR_W_DESC : MSA_3R_DESC_BASE<"srar.w", int_mips_srar_w, MSA128WOpnd>; 2592class SRAR_D_DESC : MSA_3R_DESC_BASE<"srar.d", int_mips_srar_d, MSA128DOpnd>; 2593 2594class SRARI_B_DESC : MSA_BIT_X_DESC_BASE<"srari.b", int_mips_srari_b, uimm3, 2595 immZExt3, MSA128BOpnd>; 2596class SRARI_H_DESC : MSA_BIT_X_DESC_BASE<"srari.h", int_mips_srari_h, uimm4, 2597 immZExt4, MSA128HOpnd>; 2598class SRARI_W_DESC : MSA_BIT_X_DESC_BASE<"srari.w", int_mips_srari_w, uimm5, 2599 immZExt5, MSA128WOpnd>; 2600class SRARI_D_DESC : MSA_BIT_X_DESC_BASE<"srari.d", int_mips_srari_d, uimm6, 2601 immZExt6, MSA128DOpnd>; 2602 2603class SRL_B_DESC : MSA_3R_DESC_BASE<"srl.b", srl, MSA128BOpnd>; 2604class SRL_H_DESC : MSA_3R_DESC_BASE<"srl.h", srl, MSA128HOpnd>; 2605class SRL_W_DESC : MSA_3R_DESC_BASE<"srl.w", srl, MSA128WOpnd>; 2606class SRL_D_DESC : MSA_3R_DESC_BASE<"srl.d", srl, MSA128DOpnd>; 2607 2608class SRLI_B_DESC : MSA_BIT_SPLAT_DESC_BASE<"srli.b", srl, vsplati8_uimm3, 2609 MSA128BOpnd>; 2610class SRLI_H_DESC : MSA_BIT_SPLAT_DESC_BASE<"srli.h", srl, vsplati16_uimm4, 2611 MSA128HOpnd>; 2612class SRLI_W_DESC : MSA_BIT_SPLAT_DESC_BASE<"srli.w", srl, vsplati32_uimm5, 2613 MSA128WOpnd>; 2614class SRLI_D_DESC : MSA_BIT_SPLAT_DESC_BASE<"srli.d", srl, vsplati64_uimm6, 2615 MSA128DOpnd>; 2616 2617class SRLR_B_DESC : MSA_3R_DESC_BASE<"srlr.b", int_mips_srlr_b, MSA128BOpnd>; 2618class SRLR_H_DESC : MSA_3R_DESC_BASE<"srlr.h", int_mips_srlr_h, MSA128HOpnd>; 2619class SRLR_W_DESC : MSA_3R_DESC_BASE<"srlr.w", int_mips_srlr_w, MSA128WOpnd>; 2620class SRLR_D_DESC : MSA_3R_DESC_BASE<"srlr.d", int_mips_srlr_d, MSA128DOpnd>; 2621 2622class SRLRI_B_DESC : MSA_BIT_X_DESC_BASE<"srlri.b", int_mips_srlri_b, uimm3, 2623 immZExt3, MSA128BOpnd>; 2624class SRLRI_H_DESC : MSA_BIT_X_DESC_BASE<"srlri.h", int_mips_srlri_h, uimm4, 2625 immZExt4, MSA128HOpnd>; 2626class SRLRI_W_DESC : MSA_BIT_X_DESC_BASE<"srlri.w", int_mips_srlri_w, uimm5, 2627 immZExt5, MSA128WOpnd>; 2628class SRLRI_D_DESC : MSA_BIT_X_DESC_BASE<"srlri.d", int_mips_srlri_d, uimm6, 2629 immZExt6, MSA128DOpnd>; 2630 2631class ST_DESC_BASE<string instr_asm, SDPatternOperator OpNode, 2632 ValueType TyNode, RegisterOperand ROWD, 2633 Operand MemOpnd, ComplexPattern Addr = addrimm10, 2634 InstrItinClass itin = NoItinerary> { 2635 dag OutOperandList = (outs); 2636 dag InOperandList = (ins ROWD:$wd, MemOpnd:$addr); 2637 string AsmString = !strconcat(instr_asm, "\t$wd, $addr"); 2638 list<dag> Pattern = [(OpNode (TyNode ROWD:$wd), Addr:$addr)]; 2639 InstrItinClass Itinerary = itin; 2640 string DecoderMethod = "DecodeMSA128Mem"; 2641} 2642 2643class ST_B_DESC : ST_DESC_BASE<"st.b", store, v16i8, MSA128BOpnd, mem_simm10>; 2644class ST_H_DESC : ST_DESC_BASE<"st.h", store, v8i16, MSA128HOpnd, mem_simm10_lsl1>; 2645class ST_W_DESC : ST_DESC_BASE<"st.w", store, v4i32, MSA128WOpnd, mem_simm10_lsl2>; 2646class ST_D_DESC : ST_DESC_BASE<"st.d", store, v2i64, MSA128DOpnd, mem_simm10_lsl3>; 2647 2648class SUBS_S_B_DESC : MSA_3R_DESC_BASE<"subs_s.b", int_mips_subs_s_b, 2649 MSA128BOpnd>; 2650class SUBS_S_H_DESC : MSA_3R_DESC_BASE<"subs_s.h", int_mips_subs_s_h, 2651 MSA128HOpnd>; 2652class SUBS_S_W_DESC : MSA_3R_DESC_BASE<"subs_s.w", int_mips_subs_s_w, 2653 MSA128WOpnd>; 2654class SUBS_S_D_DESC : MSA_3R_DESC_BASE<"subs_s.d", int_mips_subs_s_d, 2655 MSA128DOpnd>; 2656 2657class SUBS_U_B_DESC : MSA_3R_DESC_BASE<"subs_u.b", int_mips_subs_u_b, 2658 MSA128BOpnd>; 2659class SUBS_U_H_DESC : MSA_3R_DESC_BASE<"subs_u.h", int_mips_subs_u_h, 2660 MSA128HOpnd>; 2661class SUBS_U_W_DESC : MSA_3R_DESC_BASE<"subs_u.w", int_mips_subs_u_w, 2662 MSA128WOpnd>; 2663class SUBS_U_D_DESC : MSA_3R_DESC_BASE<"subs_u.d", int_mips_subs_u_d, 2664 MSA128DOpnd>; 2665 2666class SUBSUS_U_B_DESC : MSA_3R_DESC_BASE<"subsus_u.b", int_mips_subsus_u_b, 2667 MSA128BOpnd>; 2668class SUBSUS_U_H_DESC : MSA_3R_DESC_BASE<"subsus_u.h", int_mips_subsus_u_h, 2669 MSA128HOpnd>; 2670class SUBSUS_U_W_DESC : MSA_3R_DESC_BASE<"subsus_u.w", int_mips_subsus_u_w, 2671 MSA128WOpnd>; 2672class SUBSUS_U_D_DESC : MSA_3R_DESC_BASE<"subsus_u.d", int_mips_subsus_u_d, 2673 MSA128DOpnd>; 2674 2675class SUBSUU_S_B_DESC : MSA_3R_DESC_BASE<"subsuu_s.b", int_mips_subsuu_s_b, 2676 MSA128BOpnd>; 2677class SUBSUU_S_H_DESC : MSA_3R_DESC_BASE<"subsuu_s.h", int_mips_subsuu_s_h, 2678 MSA128HOpnd>; 2679class SUBSUU_S_W_DESC : MSA_3R_DESC_BASE<"subsuu_s.w", int_mips_subsuu_s_w, 2680 MSA128WOpnd>; 2681class SUBSUU_S_D_DESC : MSA_3R_DESC_BASE<"subsuu_s.d", int_mips_subsuu_s_d, 2682 MSA128DOpnd>; 2683 2684class SUBV_B_DESC : MSA_3R_DESC_BASE<"subv.b", sub, MSA128BOpnd>; 2685class SUBV_H_DESC : MSA_3R_DESC_BASE<"subv.h", sub, MSA128HOpnd>; 2686class SUBV_W_DESC : MSA_3R_DESC_BASE<"subv.w", sub, MSA128WOpnd>; 2687class SUBV_D_DESC : MSA_3R_DESC_BASE<"subv.d", sub, MSA128DOpnd>; 2688 2689class SUBVI_B_DESC : MSA_I5_DESC_BASE<"subvi.b", sub, vsplati8_uimm5, 2690 MSA128BOpnd>; 2691class SUBVI_H_DESC : MSA_I5_DESC_BASE<"subvi.h", sub, vsplati16_uimm5, 2692 MSA128HOpnd>; 2693class SUBVI_W_DESC : MSA_I5_DESC_BASE<"subvi.w", sub, vsplati32_uimm5, 2694 MSA128WOpnd>; 2695class SUBVI_D_DESC : MSA_I5_DESC_BASE<"subvi.d", sub, vsplati64_uimm5, 2696 MSA128DOpnd>; 2697 2698class VSHF_B_DESC : MSA_3R_VSHF_DESC_BASE<"vshf.b", MSA128BOpnd>; 2699class VSHF_H_DESC : MSA_3R_VSHF_DESC_BASE<"vshf.h", MSA128HOpnd>; 2700class VSHF_W_DESC : MSA_3R_VSHF_DESC_BASE<"vshf.w", MSA128WOpnd>; 2701class VSHF_D_DESC : MSA_3R_VSHF_DESC_BASE<"vshf.d", MSA128DOpnd>; 2702 2703class XOR_V_DESC : MSA_VEC_DESC_BASE<"xor.v", xor, MSA128BOpnd>; 2704class XOR_V_H_PSEUDO_DESC : MSA_VEC_PSEUDO_BASE<xor, MSA128HOpnd>; 2705class XOR_V_W_PSEUDO_DESC : MSA_VEC_PSEUDO_BASE<xor, MSA128WOpnd>; 2706class XOR_V_D_PSEUDO_DESC : MSA_VEC_PSEUDO_BASE<xor, MSA128DOpnd>; 2707 2708class XORI_B_DESC : MSA_I8_DESC_BASE<"xori.b", xor, vsplati8_uimm8, 2709 MSA128BOpnd>; 2710 2711// Instruction defs. 2712def ADD_A_B : ADD_A_B_ENC, ADD_A_B_DESC; 2713def ADD_A_H : ADD_A_H_ENC, ADD_A_H_DESC; 2714def ADD_A_W : ADD_A_W_ENC, ADD_A_W_DESC; 2715def ADD_A_D : ADD_A_D_ENC, ADD_A_D_DESC; 2716 2717def ADDS_A_B : ADDS_A_B_ENC, ADDS_A_B_DESC; 2718def ADDS_A_H : ADDS_A_H_ENC, ADDS_A_H_DESC; 2719def ADDS_A_W : ADDS_A_W_ENC, ADDS_A_W_DESC; 2720def ADDS_A_D : ADDS_A_D_ENC, ADDS_A_D_DESC; 2721 2722def ADDS_S_B : ADDS_S_B_ENC, ADDS_S_B_DESC; 2723def ADDS_S_H : ADDS_S_H_ENC, ADDS_S_H_DESC; 2724def ADDS_S_W : ADDS_S_W_ENC, ADDS_S_W_DESC; 2725def ADDS_S_D : ADDS_S_D_ENC, ADDS_S_D_DESC; 2726 2727def ADDS_U_B : ADDS_U_B_ENC, ADDS_U_B_DESC; 2728def ADDS_U_H : ADDS_U_H_ENC, ADDS_U_H_DESC; 2729def ADDS_U_W : ADDS_U_W_ENC, ADDS_U_W_DESC; 2730def ADDS_U_D : ADDS_U_D_ENC, ADDS_U_D_DESC; 2731 2732def ADDV_B : ADDV_B_ENC, ADDV_B_DESC; 2733def ADDV_H : ADDV_H_ENC, ADDV_H_DESC; 2734def ADDV_W : ADDV_W_ENC, ADDV_W_DESC; 2735def ADDV_D : ADDV_D_ENC, ADDV_D_DESC; 2736 2737def ADDVI_B : ADDVI_B_ENC, ADDVI_B_DESC; 2738def ADDVI_H : ADDVI_H_ENC, ADDVI_H_DESC; 2739def ADDVI_W : ADDVI_W_ENC, ADDVI_W_DESC; 2740def ADDVI_D : ADDVI_D_ENC, ADDVI_D_DESC; 2741 2742def AND_V : AND_V_ENC, AND_V_DESC; 2743def AND_V_H_PSEUDO : AND_V_H_PSEUDO_DESC, 2744 PseudoInstExpansion<(AND_V MSA128BOpnd:$wd, 2745 MSA128BOpnd:$ws, 2746 MSA128BOpnd:$wt)>; 2747def AND_V_W_PSEUDO : AND_V_W_PSEUDO_DESC, 2748 PseudoInstExpansion<(AND_V MSA128BOpnd:$wd, 2749 MSA128BOpnd:$ws, 2750 MSA128BOpnd:$wt)>; 2751def AND_V_D_PSEUDO : AND_V_D_PSEUDO_DESC, 2752 PseudoInstExpansion<(AND_V MSA128BOpnd:$wd, 2753 MSA128BOpnd:$ws, 2754 MSA128BOpnd:$wt)>; 2755 2756def ANDI_B : ANDI_B_ENC, ANDI_B_DESC; 2757 2758def ASUB_S_B : ASUB_S_B_ENC, ASUB_S_B_DESC; 2759def ASUB_S_H : ASUB_S_H_ENC, ASUB_S_H_DESC; 2760def ASUB_S_W : ASUB_S_W_ENC, ASUB_S_W_DESC; 2761def ASUB_S_D : ASUB_S_D_ENC, ASUB_S_D_DESC; 2762 2763def ASUB_U_B : ASUB_U_B_ENC, ASUB_U_B_DESC; 2764def ASUB_U_H : ASUB_U_H_ENC, ASUB_U_H_DESC; 2765def ASUB_U_W : ASUB_U_W_ENC, ASUB_U_W_DESC; 2766def ASUB_U_D : ASUB_U_D_ENC, ASUB_U_D_DESC; 2767 2768def AVE_S_B : AVE_S_B_ENC, AVE_S_B_DESC; 2769def AVE_S_H : AVE_S_H_ENC, AVE_S_H_DESC; 2770def AVE_S_W : AVE_S_W_ENC, AVE_S_W_DESC; 2771def AVE_S_D : AVE_S_D_ENC, AVE_S_D_DESC; 2772 2773def AVE_U_B : AVE_U_B_ENC, AVE_U_B_DESC; 2774def AVE_U_H : AVE_U_H_ENC, AVE_U_H_DESC; 2775def AVE_U_W : AVE_U_W_ENC, AVE_U_W_DESC; 2776def AVE_U_D : AVE_U_D_ENC, AVE_U_D_DESC; 2777 2778def AVER_S_B : AVER_S_B_ENC, AVER_S_B_DESC; 2779def AVER_S_H : AVER_S_H_ENC, AVER_S_H_DESC; 2780def AVER_S_W : AVER_S_W_ENC, AVER_S_W_DESC; 2781def AVER_S_D : AVER_S_D_ENC, AVER_S_D_DESC; 2782 2783def AVER_U_B : AVER_U_B_ENC, AVER_U_B_DESC; 2784def AVER_U_H : AVER_U_H_ENC, AVER_U_H_DESC; 2785def AVER_U_W : AVER_U_W_ENC, AVER_U_W_DESC; 2786def AVER_U_D : AVER_U_D_ENC, AVER_U_D_DESC; 2787 2788def BCLR_B : BCLR_B_ENC, BCLR_B_DESC; 2789def BCLR_H : BCLR_H_ENC, BCLR_H_DESC; 2790def BCLR_W : BCLR_W_ENC, BCLR_W_DESC; 2791def BCLR_D : BCLR_D_ENC, BCLR_D_DESC; 2792 2793def BCLRI_B : BCLRI_B_ENC, BCLRI_B_DESC; 2794def BCLRI_H : BCLRI_H_ENC, BCLRI_H_DESC; 2795def BCLRI_W : BCLRI_W_ENC, BCLRI_W_DESC; 2796def BCLRI_D : BCLRI_D_ENC, BCLRI_D_DESC; 2797 2798def BINSL_B : BINSL_B_ENC, BINSL_B_DESC; 2799def BINSL_H : BINSL_H_ENC, BINSL_H_DESC; 2800def BINSL_W : BINSL_W_ENC, BINSL_W_DESC; 2801def BINSL_D : BINSL_D_ENC, BINSL_D_DESC; 2802 2803def BINSLI_B : BINSLI_B_ENC, BINSLI_B_DESC; 2804def BINSLI_H : BINSLI_H_ENC, BINSLI_H_DESC; 2805def BINSLI_W : BINSLI_W_ENC, BINSLI_W_DESC; 2806def BINSLI_D : BINSLI_D_ENC, BINSLI_D_DESC; 2807 2808def BINSR_B : BINSR_B_ENC, BINSR_B_DESC; 2809def BINSR_H : BINSR_H_ENC, BINSR_H_DESC; 2810def BINSR_W : BINSR_W_ENC, BINSR_W_DESC; 2811def BINSR_D : BINSR_D_ENC, BINSR_D_DESC; 2812 2813def BINSRI_B : BINSRI_B_ENC, BINSRI_B_DESC; 2814def BINSRI_H : BINSRI_H_ENC, BINSRI_H_DESC; 2815def BINSRI_W : BINSRI_W_ENC, BINSRI_W_DESC; 2816def BINSRI_D : BINSRI_D_ENC, BINSRI_D_DESC; 2817 2818def BMNZ_V : BMNZ_V_ENC, BMNZ_V_DESC; 2819 2820def BMNZI_B : BMNZI_B_ENC, BMNZI_B_DESC; 2821 2822def BMZ_V : BMZ_V_ENC, BMZ_V_DESC; 2823 2824def BMZI_B : BMZI_B_ENC, BMZI_B_DESC; 2825 2826def BNEG_B : BNEG_B_ENC, BNEG_B_DESC; 2827def BNEG_H : BNEG_H_ENC, BNEG_H_DESC; 2828def BNEG_W : BNEG_W_ENC, BNEG_W_DESC; 2829def BNEG_D : BNEG_D_ENC, BNEG_D_DESC; 2830 2831def BNEGI_B : BNEGI_B_ENC, BNEGI_B_DESC; 2832def BNEGI_H : BNEGI_H_ENC, BNEGI_H_DESC; 2833def BNEGI_W : BNEGI_W_ENC, BNEGI_W_DESC; 2834def BNEGI_D : BNEGI_D_ENC, BNEGI_D_DESC; 2835 2836def BNZ_B : BNZ_B_ENC, BNZ_B_DESC; 2837def BNZ_H : BNZ_H_ENC, BNZ_H_DESC; 2838def BNZ_W : BNZ_W_ENC, BNZ_W_DESC; 2839def BNZ_D : BNZ_D_ENC, BNZ_D_DESC; 2840 2841def BNZ_V : BNZ_V_ENC, BNZ_V_DESC; 2842 2843def BSEL_V : BSEL_V_ENC, BSEL_V_DESC; 2844 2845class MSA_BSEL_PSEUDO_BASE<RegisterOperand RO, ValueType Ty> : 2846 MSAPseudo<(outs RO:$wd), (ins RO:$wd_in, RO:$ws, RO:$wt), 2847 [(set RO:$wd, (Ty (vselect RO:$wd_in, RO:$wt, RO:$ws)))]>, 2848 // Note that vselect and BSEL_V treat the condition operand the opposite way 2849 // from each other. 2850 // (vselect cond, if_set, if_clear) 2851 // (BSEL_V cond, if_clear, if_set) 2852 PseudoInstExpansion<(BSEL_V MSA128BOpnd:$wd, MSA128BOpnd:$wd_in, 2853 MSA128BOpnd:$ws, MSA128BOpnd:$wt)> { 2854 let Constraints = "$wd_in = $wd"; 2855} 2856 2857def BSEL_H_PSEUDO : MSA_BSEL_PSEUDO_BASE<MSA128HOpnd, v8i16>; 2858def BSEL_W_PSEUDO : MSA_BSEL_PSEUDO_BASE<MSA128WOpnd, v4i32>; 2859def BSEL_D_PSEUDO : MSA_BSEL_PSEUDO_BASE<MSA128DOpnd, v2i64>; 2860def BSEL_FW_PSEUDO : MSA_BSEL_PSEUDO_BASE<MSA128WOpnd, v4f32>; 2861def BSEL_FD_PSEUDO : MSA_BSEL_PSEUDO_BASE<MSA128DOpnd, v2f64>; 2862 2863def BSELI_B : BSELI_B_ENC, BSELI_B_DESC; 2864 2865def BSET_B : BSET_B_ENC, BSET_B_DESC; 2866def BSET_H : BSET_H_ENC, BSET_H_DESC; 2867def BSET_W : BSET_W_ENC, BSET_W_DESC; 2868def BSET_D : BSET_D_ENC, BSET_D_DESC; 2869 2870def BSETI_B : BSETI_B_ENC, BSETI_B_DESC; 2871def BSETI_H : BSETI_H_ENC, BSETI_H_DESC; 2872def BSETI_W : BSETI_W_ENC, BSETI_W_DESC; 2873def BSETI_D : BSETI_D_ENC, BSETI_D_DESC; 2874 2875def BZ_B : BZ_B_ENC, BZ_B_DESC; 2876def BZ_H : BZ_H_ENC, BZ_H_DESC; 2877def BZ_W : BZ_W_ENC, BZ_W_DESC; 2878def BZ_D : BZ_D_ENC, BZ_D_DESC; 2879 2880def BZ_V : BZ_V_ENC, BZ_V_DESC; 2881 2882def CEQ_B : CEQ_B_ENC, CEQ_B_DESC; 2883def CEQ_H : CEQ_H_ENC, CEQ_H_DESC; 2884def CEQ_W : CEQ_W_ENC, CEQ_W_DESC; 2885def CEQ_D : CEQ_D_ENC, CEQ_D_DESC; 2886 2887def CEQI_B : CEQI_B_ENC, CEQI_B_DESC; 2888def CEQI_H : CEQI_H_ENC, CEQI_H_DESC; 2889def CEQI_W : CEQI_W_ENC, CEQI_W_DESC; 2890def CEQI_D : CEQI_D_ENC, CEQI_D_DESC; 2891 2892def CFCMSA : CFCMSA_ENC, CFCMSA_DESC; 2893 2894def CLE_S_B : CLE_S_B_ENC, CLE_S_B_DESC; 2895def CLE_S_H : CLE_S_H_ENC, CLE_S_H_DESC; 2896def CLE_S_W : CLE_S_W_ENC, CLE_S_W_DESC; 2897def CLE_S_D : CLE_S_D_ENC, CLE_S_D_DESC; 2898 2899def CLE_U_B : CLE_U_B_ENC, CLE_U_B_DESC; 2900def CLE_U_H : CLE_U_H_ENC, CLE_U_H_DESC; 2901def CLE_U_W : CLE_U_W_ENC, CLE_U_W_DESC; 2902def CLE_U_D : CLE_U_D_ENC, CLE_U_D_DESC; 2903 2904def CLEI_S_B : CLEI_S_B_ENC, CLEI_S_B_DESC; 2905def CLEI_S_H : CLEI_S_H_ENC, CLEI_S_H_DESC; 2906def CLEI_S_W : CLEI_S_W_ENC, CLEI_S_W_DESC; 2907def CLEI_S_D : CLEI_S_D_ENC, CLEI_S_D_DESC; 2908 2909def CLEI_U_B : CLEI_U_B_ENC, CLEI_U_B_DESC; 2910def CLEI_U_H : CLEI_U_H_ENC, CLEI_U_H_DESC; 2911def CLEI_U_W : CLEI_U_W_ENC, CLEI_U_W_DESC; 2912def CLEI_U_D : CLEI_U_D_ENC, CLEI_U_D_DESC; 2913 2914def CLT_S_B : CLT_S_B_ENC, CLT_S_B_DESC; 2915def CLT_S_H : CLT_S_H_ENC, CLT_S_H_DESC; 2916def CLT_S_W : CLT_S_W_ENC, CLT_S_W_DESC; 2917def CLT_S_D : CLT_S_D_ENC, CLT_S_D_DESC; 2918 2919def CLT_U_B : CLT_U_B_ENC, CLT_U_B_DESC; 2920def CLT_U_H : CLT_U_H_ENC, CLT_U_H_DESC; 2921def CLT_U_W : CLT_U_W_ENC, CLT_U_W_DESC; 2922def CLT_U_D : CLT_U_D_ENC, CLT_U_D_DESC; 2923 2924def CLTI_S_B : CLTI_S_B_ENC, CLTI_S_B_DESC; 2925def CLTI_S_H : CLTI_S_H_ENC, CLTI_S_H_DESC; 2926def CLTI_S_W : CLTI_S_W_ENC, CLTI_S_W_DESC; 2927def CLTI_S_D : CLTI_S_D_ENC, CLTI_S_D_DESC; 2928 2929def CLTI_U_B : CLTI_U_B_ENC, CLTI_U_B_DESC; 2930def CLTI_U_H : CLTI_U_H_ENC, CLTI_U_H_DESC; 2931def CLTI_U_W : CLTI_U_W_ENC, CLTI_U_W_DESC; 2932def CLTI_U_D : CLTI_U_D_ENC, CLTI_U_D_DESC; 2933 2934def COPY_S_B : COPY_S_B_ENC, COPY_S_B_DESC; 2935def COPY_S_H : COPY_S_H_ENC, COPY_S_H_DESC; 2936def COPY_S_W : COPY_S_W_ENC, COPY_S_W_DESC; 2937def COPY_S_D : COPY_S_D_ENC, COPY_S_D_DESC, ASE_MSA64; 2938 2939def COPY_U_B : COPY_U_B_ENC, COPY_U_B_DESC; 2940def COPY_U_H : COPY_U_H_ENC, COPY_U_H_DESC; 2941def COPY_U_W : COPY_U_W_ENC, COPY_U_W_DESC, ASE_MSA64; 2942 2943def COPY_FW_PSEUDO : COPY_FW_PSEUDO_DESC; 2944def COPY_FD_PSEUDO : COPY_FD_PSEUDO_DESC; 2945 2946def CTCMSA : CTCMSA_ENC, CTCMSA_DESC; 2947 2948def DIV_S_B : DIV_S_B_ENC, DIV_S_B_DESC; 2949def DIV_S_H : DIV_S_H_ENC, DIV_S_H_DESC; 2950def DIV_S_W : DIV_S_W_ENC, DIV_S_W_DESC; 2951def DIV_S_D : DIV_S_D_ENC, DIV_S_D_DESC; 2952 2953def DIV_U_B : DIV_U_B_ENC, DIV_U_B_DESC; 2954def DIV_U_H : DIV_U_H_ENC, DIV_U_H_DESC; 2955def DIV_U_W : DIV_U_W_ENC, DIV_U_W_DESC; 2956def DIV_U_D : DIV_U_D_ENC, DIV_U_D_DESC; 2957 2958def DOTP_S_H : DOTP_S_H_ENC, DOTP_S_H_DESC; 2959def DOTP_S_W : DOTP_S_W_ENC, DOTP_S_W_DESC; 2960def DOTP_S_D : DOTP_S_D_ENC, DOTP_S_D_DESC; 2961 2962def DOTP_U_H : DOTP_U_H_ENC, DOTP_U_H_DESC; 2963def DOTP_U_W : DOTP_U_W_ENC, DOTP_U_W_DESC; 2964def DOTP_U_D : DOTP_U_D_ENC, DOTP_U_D_DESC; 2965 2966def DPADD_S_H : DPADD_S_H_ENC, DPADD_S_H_DESC; 2967def DPADD_S_W : DPADD_S_W_ENC, DPADD_S_W_DESC; 2968def DPADD_S_D : DPADD_S_D_ENC, DPADD_S_D_DESC; 2969 2970def DPADD_U_H : DPADD_U_H_ENC, DPADD_U_H_DESC; 2971def DPADD_U_W : DPADD_U_W_ENC, DPADD_U_W_DESC; 2972def DPADD_U_D : DPADD_U_D_ENC, DPADD_U_D_DESC; 2973 2974def DPSUB_S_H : DPSUB_S_H_ENC, DPSUB_S_H_DESC; 2975def DPSUB_S_W : DPSUB_S_W_ENC, DPSUB_S_W_DESC; 2976def DPSUB_S_D : DPSUB_S_D_ENC, DPSUB_S_D_DESC; 2977 2978def DPSUB_U_H : DPSUB_U_H_ENC, DPSUB_U_H_DESC; 2979def DPSUB_U_W : DPSUB_U_W_ENC, DPSUB_U_W_DESC; 2980def DPSUB_U_D : DPSUB_U_D_ENC, DPSUB_U_D_DESC; 2981 2982def FADD_W : FADD_W_ENC, FADD_W_DESC; 2983def FADD_D : FADD_D_ENC, FADD_D_DESC; 2984 2985def FCAF_W : FCAF_W_ENC, FCAF_W_DESC; 2986def FCAF_D : FCAF_D_ENC, FCAF_D_DESC; 2987 2988def FCEQ_W : FCEQ_W_ENC, FCEQ_W_DESC; 2989def FCEQ_D : FCEQ_D_ENC, FCEQ_D_DESC; 2990 2991def FCLE_W : FCLE_W_ENC, FCLE_W_DESC; 2992def FCLE_D : FCLE_D_ENC, FCLE_D_DESC; 2993 2994def FCLT_W : FCLT_W_ENC, FCLT_W_DESC; 2995def FCLT_D : FCLT_D_ENC, FCLT_D_DESC; 2996 2997def FCLASS_W : FCLASS_W_ENC, FCLASS_W_DESC; 2998def FCLASS_D : FCLASS_D_ENC, FCLASS_D_DESC; 2999 3000def FCNE_W : FCNE_W_ENC, FCNE_W_DESC; 3001def FCNE_D : FCNE_D_ENC, FCNE_D_DESC; 3002 3003def FCOR_W : FCOR_W_ENC, FCOR_W_DESC; 3004def FCOR_D : FCOR_D_ENC, FCOR_D_DESC; 3005 3006def FCUEQ_W : FCUEQ_W_ENC, FCUEQ_W_DESC; 3007def FCUEQ_D : FCUEQ_D_ENC, FCUEQ_D_DESC; 3008 3009def FCULE_W : FCULE_W_ENC, FCULE_W_DESC; 3010def FCULE_D : FCULE_D_ENC, FCULE_D_DESC; 3011 3012def FCULT_W : FCULT_W_ENC, FCULT_W_DESC; 3013def FCULT_D : FCULT_D_ENC, FCULT_D_DESC; 3014 3015def FCUN_W : FCUN_W_ENC, FCUN_W_DESC; 3016def FCUN_D : FCUN_D_ENC, FCUN_D_DESC; 3017 3018def FCUNE_W : FCUNE_W_ENC, FCUNE_W_DESC; 3019def FCUNE_D : FCUNE_D_ENC, FCUNE_D_DESC; 3020 3021def FDIV_W : FDIV_W_ENC, FDIV_W_DESC; 3022def FDIV_D : FDIV_D_ENC, FDIV_D_DESC; 3023 3024def FEXDO_H : FEXDO_H_ENC, FEXDO_H_DESC; 3025def FEXDO_W : FEXDO_W_ENC, FEXDO_W_DESC; 3026 3027def FEXP2_W : FEXP2_W_ENC, FEXP2_W_DESC; 3028def FEXP2_D : FEXP2_D_ENC, FEXP2_D_DESC; 3029def FEXP2_W_1_PSEUDO : FEXP2_W_1_PSEUDO_DESC; 3030def FEXP2_D_1_PSEUDO : FEXP2_D_1_PSEUDO_DESC; 3031 3032def FEXUPL_W : FEXUPL_W_ENC, FEXUPL_W_DESC; 3033def FEXUPL_D : FEXUPL_D_ENC, FEXUPL_D_DESC; 3034 3035def FEXUPR_W : FEXUPR_W_ENC, FEXUPR_W_DESC; 3036def FEXUPR_D : FEXUPR_D_ENC, FEXUPR_D_DESC; 3037 3038def FFINT_S_W : FFINT_S_W_ENC, FFINT_S_W_DESC; 3039def FFINT_S_D : FFINT_S_D_ENC, FFINT_S_D_DESC; 3040 3041def FFINT_U_W : FFINT_U_W_ENC, FFINT_U_W_DESC; 3042def FFINT_U_D : FFINT_U_D_ENC, FFINT_U_D_DESC; 3043 3044def FFQL_W : FFQL_W_ENC, FFQL_W_DESC; 3045def FFQL_D : FFQL_D_ENC, FFQL_D_DESC; 3046 3047def FFQR_W : FFQR_W_ENC, FFQR_W_DESC; 3048def FFQR_D : FFQR_D_ENC, FFQR_D_DESC; 3049 3050def FILL_B : FILL_B_ENC, FILL_B_DESC; 3051def FILL_H : FILL_H_ENC, FILL_H_DESC; 3052def FILL_W : FILL_W_ENC, FILL_W_DESC; 3053def FILL_D : FILL_D_ENC, FILL_D_DESC, ASE_MSA64; 3054def FILL_FW_PSEUDO : FILL_FW_PSEUDO_DESC; 3055def FILL_FD_PSEUDO : FILL_FD_PSEUDO_DESC; 3056 3057def FLOG2_W : FLOG2_W_ENC, FLOG2_W_DESC; 3058def FLOG2_D : FLOG2_D_ENC, FLOG2_D_DESC; 3059 3060def FMADD_W : FMADD_W_ENC, FMADD_W_DESC; 3061def FMADD_D : FMADD_D_ENC, FMADD_D_DESC; 3062 3063def FMAX_W : FMAX_W_ENC, FMAX_W_DESC; 3064def FMAX_D : FMAX_D_ENC, FMAX_D_DESC; 3065 3066def FMAX_A_W : FMAX_A_W_ENC, FMAX_A_W_DESC; 3067def FMAX_A_D : FMAX_A_D_ENC, FMAX_A_D_DESC; 3068 3069def FMIN_W : FMIN_W_ENC, FMIN_W_DESC; 3070def FMIN_D : FMIN_D_ENC, FMIN_D_DESC; 3071 3072def FMIN_A_W : FMIN_A_W_ENC, FMIN_A_W_DESC; 3073def FMIN_A_D : FMIN_A_D_ENC, FMIN_A_D_DESC; 3074 3075def FMSUB_W : FMSUB_W_ENC, FMSUB_W_DESC; 3076def FMSUB_D : FMSUB_D_ENC, FMSUB_D_DESC; 3077 3078def FMUL_W : FMUL_W_ENC, FMUL_W_DESC; 3079def FMUL_D : FMUL_D_ENC, FMUL_D_DESC; 3080 3081def FRINT_W : FRINT_W_ENC, FRINT_W_DESC; 3082def FRINT_D : FRINT_D_ENC, FRINT_D_DESC; 3083 3084def FRCP_W : FRCP_W_ENC, FRCP_W_DESC; 3085def FRCP_D : FRCP_D_ENC, FRCP_D_DESC; 3086 3087def FRSQRT_W : FRSQRT_W_ENC, FRSQRT_W_DESC; 3088def FRSQRT_D : FRSQRT_D_ENC, FRSQRT_D_DESC; 3089 3090def FSAF_W : FSAF_W_ENC, FSAF_W_DESC; 3091def FSAF_D : FSAF_D_ENC, FSAF_D_DESC; 3092 3093def FSEQ_W : FSEQ_W_ENC, FSEQ_W_DESC; 3094def FSEQ_D : FSEQ_D_ENC, FSEQ_D_DESC; 3095 3096def FSLE_W : FSLE_W_ENC, FSLE_W_DESC; 3097def FSLE_D : FSLE_D_ENC, FSLE_D_DESC; 3098 3099def FSLT_W : FSLT_W_ENC, FSLT_W_DESC; 3100def FSLT_D : FSLT_D_ENC, FSLT_D_DESC; 3101 3102def FSNE_W : FSNE_W_ENC, FSNE_W_DESC; 3103def FSNE_D : FSNE_D_ENC, FSNE_D_DESC; 3104 3105def FSOR_W : FSOR_W_ENC, FSOR_W_DESC; 3106def FSOR_D : FSOR_D_ENC, FSOR_D_DESC; 3107 3108def FSQRT_W : FSQRT_W_ENC, FSQRT_W_DESC; 3109def FSQRT_D : FSQRT_D_ENC, FSQRT_D_DESC; 3110 3111def FSUB_W : FSUB_W_ENC, FSUB_W_DESC; 3112def FSUB_D : FSUB_D_ENC, FSUB_D_DESC; 3113 3114def FSUEQ_W : FSUEQ_W_ENC, FSUEQ_W_DESC; 3115def FSUEQ_D : FSUEQ_D_ENC, FSUEQ_D_DESC; 3116 3117def FSULE_W : FSULE_W_ENC, FSULE_W_DESC; 3118def FSULE_D : FSULE_D_ENC, FSULE_D_DESC; 3119 3120def FSULT_W : FSULT_W_ENC, FSULT_W_DESC; 3121def FSULT_D : FSULT_D_ENC, FSULT_D_DESC; 3122 3123def FSUN_W : FSUN_W_ENC, FSUN_W_DESC; 3124def FSUN_D : FSUN_D_ENC, FSUN_D_DESC; 3125 3126def FSUNE_W : FSUNE_W_ENC, FSUNE_W_DESC; 3127def FSUNE_D : FSUNE_D_ENC, FSUNE_D_DESC; 3128 3129def FTINT_S_W : FTINT_S_W_ENC, FTINT_S_W_DESC; 3130def FTINT_S_D : FTINT_S_D_ENC, FTINT_S_D_DESC; 3131 3132def FTINT_U_W : FTINT_U_W_ENC, FTINT_U_W_DESC; 3133def FTINT_U_D : FTINT_U_D_ENC, FTINT_U_D_DESC; 3134 3135def FTQ_H : FTQ_H_ENC, FTQ_H_DESC; 3136def FTQ_W : FTQ_W_ENC, FTQ_W_DESC; 3137 3138def FTRUNC_S_W : FTRUNC_S_W_ENC, FTRUNC_S_W_DESC; 3139def FTRUNC_S_D : FTRUNC_S_D_ENC, FTRUNC_S_D_DESC; 3140 3141def FTRUNC_U_W : FTRUNC_U_W_ENC, FTRUNC_U_W_DESC; 3142def FTRUNC_U_D : FTRUNC_U_D_ENC, FTRUNC_U_D_DESC; 3143 3144def HADD_S_H : HADD_S_H_ENC, HADD_S_H_DESC; 3145def HADD_S_W : HADD_S_W_ENC, HADD_S_W_DESC; 3146def HADD_S_D : HADD_S_D_ENC, HADD_S_D_DESC; 3147 3148def HADD_U_H : HADD_U_H_ENC, HADD_U_H_DESC; 3149def HADD_U_W : HADD_U_W_ENC, HADD_U_W_DESC; 3150def HADD_U_D : HADD_U_D_ENC, HADD_U_D_DESC; 3151 3152def HSUB_S_H : HSUB_S_H_ENC, HSUB_S_H_DESC; 3153def HSUB_S_W : HSUB_S_W_ENC, HSUB_S_W_DESC; 3154def HSUB_S_D : HSUB_S_D_ENC, HSUB_S_D_DESC; 3155 3156def HSUB_U_H : HSUB_U_H_ENC, HSUB_U_H_DESC; 3157def HSUB_U_W : HSUB_U_W_ENC, HSUB_U_W_DESC; 3158def HSUB_U_D : HSUB_U_D_ENC, HSUB_U_D_DESC; 3159 3160def ILVEV_B : ILVEV_B_ENC, ILVEV_B_DESC; 3161def ILVEV_H : ILVEV_H_ENC, ILVEV_H_DESC; 3162def ILVEV_W : ILVEV_W_ENC, ILVEV_W_DESC; 3163def ILVEV_D : ILVEV_D_ENC, ILVEV_D_DESC; 3164 3165def ILVL_B : ILVL_B_ENC, ILVL_B_DESC; 3166def ILVL_H : ILVL_H_ENC, ILVL_H_DESC; 3167def ILVL_W : ILVL_W_ENC, ILVL_W_DESC; 3168def ILVL_D : ILVL_D_ENC, ILVL_D_DESC; 3169 3170def ILVOD_B : ILVOD_B_ENC, ILVOD_B_DESC; 3171def ILVOD_H : ILVOD_H_ENC, ILVOD_H_DESC; 3172def ILVOD_W : ILVOD_W_ENC, ILVOD_W_DESC; 3173def ILVOD_D : ILVOD_D_ENC, ILVOD_D_DESC; 3174 3175def ILVR_B : ILVR_B_ENC, ILVR_B_DESC; 3176def ILVR_H : ILVR_H_ENC, ILVR_H_DESC; 3177def ILVR_W : ILVR_W_ENC, ILVR_W_DESC; 3178def ILVR_D : ILVR_D_ENC, ILVR_D_DESC; 3179 3180def INSERT_B : INSERT_B_ENC, INSERT_B_DESC; 3181def INSERT_H : INSERT_H_ENC, INSERT_H_DESC; 3182def INSERT_W : INSERT_W_ENC, INSERT_W_DESC; 3183def INSERT_D : INSERT_D_ENC, INSERT_D_DESC, ASE_MSA64; 3184 3185// INSERT_FW_PSEUDO defined after INSVE_W 3186// INSERT_FD_PSEUDO defined after INSVE_D 3187 3188// There is a fourth operand that is not present in the encoding. Use a 3189// custom decoder to get a chance to add it. 3190let DecoderMethod = "DecodeINSVE_DF" in { 3191 def INSVE_B : INSVE_B_ENC, INSVE_B_DESC; 3192 def INSVE_H : INSVE_H_ENC, INSVE_H_DESC; 3193 def INSVE_W : INSVE_W_ENC, INSVE_W_DESC; 3194 def INSVE_D : INSVE_D_ENC, INSVE_D_DESC; 3195} 3196 3197def INSERT_FW_PSEUDO : INSERT_FW_PSEUDO_DESC; 3198def INSERT_FD_PSEUDO : INSERT_FD_PSEUDO_DESC; 3199 3200def INSERT_B_VIDX_PSEUDO : INSERT_B_VIDX_PSEUDO_DESC; 3201def INSERT_H_VIDX_PSEUDO : INSERT_H_VIDX_PSEUDO_DESC; 3202def INSERT_W_VIDX_PSEUDO : INSERT_W_VIDX_PSEUDO_DESC; 3203def INSERT_D_VIDX_PSEUDO : INSERT_D_VIDX_PSEUDO_DESC; 3204def INSERT_FW_VIDX_PSEUDO : INSERT_FW_VIDX_PSEUDO_DESC; 3205def INSERT_FD_VIDX_PSEUDO : INSERT_FD_VIDX_PSEUDO_DESC; 3206 3207def INSERT_B_VIDX64_PSEUDO : INSERT_B_VIDX64_PSEUDO_DESC; 3208def INSERT_H_VIDX64_PSEUDO : INSERT_H_VIDX64_PSEUDO_DESC; 3209def INSERT_W_VIDX64_PSEUDO : INSERT_W_VIDX64_PSEUDO_DESC; 3210def INSERT_D_VIDX64_PSEUDO : INSERT_D_VIDX64_PSEUDO_DESC; 3211def INSERT_FW_VIDX64_PSEUDO : INSERT_FW_VIDX64_PSEUDO_DESC; 3212def INSERT_FD_VIDX64_PSEUDO : INSERT_FD_VIDX64_PSEUDO_DESC; 3213 3214def LD_B: LD_B_ENC, LD_B_DESC; 3215def LD_H: LD_H_ENC, LD_H_DESC; 3216def LD_W: LD_W_ENC, LD_W_DESC; 3217def LD_D: LD_D_ENC, LD_D_DESC; 3218 3219def LDI_B : LDI_B_ENC, LDI_B_DESC; 3220def LDI_H : LDI_H_ENC, LDI_H_DESC; 3221def LDI_W : LDI_W_ENC, LDI_W_DESC; 3222def LDI_D : LDI_D_ENC, LDI_D_DESC; 3223 3224def LSA : LSA_ENC, LSA_DESC; 3225def DLSA : DLSA_ENC, DLSA_DESC, ASE_MSA64; 3226 3227def MADD_Q_H : MADD_Q_H_ENC, MADD_Q_H_DESC; 3228def MADD_Q_W : MADD_Q_W_ENC, MADD_Q_W_DESC; 3229 3230def MADDR_Q_H : MADDR_Q_H_ENC, MADDR_Q_H_DESC; 3231def MADDR_Q_W : MADDR_Q_W_ENC, MADDR_Q_W_DESC; 3232 3233def MADDV_B : MADDV_B_ENC, MADDV_B_DESC; 3234def MADDV_H : MADDV_H_ENC, MADDV_H_DESC; 3235def MADDV_W : MADDV_W_ENC, MADDV_W_DESC; 3236def MADDV_D : MADDV_D_ENC, MADDV_D_DESC; 3237 3238def MAX_A_B : MAX_A_B_ENC, MAX_A_B_DESC; 3239def MAX_A_H : MAX_A_H_ENC, MAX_A_H_DESC; 3240def MAX_A_W : MAX_A_W_ENC, MAX_A_W_DESC; 3241def MAX_A_D : MAX_A_D_ENC, MAX_A_D_DESC; 3242 3243def MAX_S_B : MAX_S_B_ENC, MAX_S_B_DESC; 3244def MAX_S_H : MAX_S_H_ENC, MAX_S_H_DESC; 3245def MAX_S_W : MAX_S_W_ENC, MAX_S_W_DESC; 3246def MAX_S_D : MAX_S_D_ENC, MAX_S_D_DESC; 3247 3248def MAX_U_B : MAX_U_B_ENC, MAX_U_B_DESC; 3249def MAX_U_H : MAX_U_H_ENC, MAX_U_H_DESC; 3250def MAX_U_W : MAX_U_W_ENC, MAX_U_W_DESC; 3251def MAX_U_D : MAX_U_D_ENC, MAX_U_D_DESC; 3252 3253def MAXI_S_B : MAXI_S_B_ENC, MAXI_S_B_DESC; 3254def MAXI_S_H : MAXI_S_H_ENC, MAXI_S_H_DESC; 3255def MAXI_S_W : MAXI_S_W_ENC, MAXI_S_W_DESC; 3256def MAXI_S_D : MAXI_S_D_ENC, MAXI_S_D_DESC; 3257 3258def MAXI_U_B : MAXI_U_B_ENC, MAXI_U_B_DESC; 3259def MAXI_U_H : MAXI_U_H_ENC, MAXI_U_H_DESC; 3260def MAXI_U_W : MAXI_U_W_ENC, MAXI_U_W_DESC; 3261def MAXI_U_D : MAXI_U_D_ENC, MAXI_U_D_DESC; 3262 3263def MIN_A_B : MIN_A_B_ENC, MIN_A_B_DESC; 3264def MIN_A_H : MIN_A_H_ENC, MIN_A_H_DESC; 3265def MIN_A_W : MIN_A_W_ENC, MIN_A_W_DESC; 3266def MIN_A_D : MIN_A_D_ENC, MIN_A_D_DESC; 3267 3268def MIN_S_B : MIN_S_B_ENC, MIN_S_B_DESC; 3269def MIN_S_H : MIN_S_H_ENC, MIN_S_H_DESC; 3270def MIN_S_W : MIN_S_W_ENC, MIN_S_W_DESC; 3271def MIN_S_D : MIN_S_D_ENC, MIN_S_D_DESC; 3272 3273def MIN_U_B : MIN_U_B_ENC, MIN_U_B_DESC; 3274def MIN_U_H : MIN_U_H_ENC, MIN_U_H_DESC; 3275def MIN_U_W : MIN_U_W_ENC, MIN_U_W_DESC; 3276def MIN_U_D : MIN_U_D_ENC, MIN_U_D_DESC; 3277 3278def MINI_S_B : MINI_S_B_ENC, MINI_S_B_DESC; 3279def MINI_S_H : MINI_S_H_ENC, MINI_S_H_DESC; 3280def MINI_S_W : MINI_S_W_ENC, MINI_S_W_DESC; 3281def MINI_S_D : MINI_S_D_ENC, MINI_S_D_DESC; 3282 3283def MINI_U_B : MINI_U_B_ENC, MINI_U_B_DESC; 3284def MINI_U_H : MINI_U_H_ENC, MINI_U_H_DESC; 3285def MINI_U_W : MINI_U_W_ENC, MINI_U_W_DESC; 3286def MINI_U_D : MINI_U_D_ENC, MINI_U_D_DESC; 3287 3288def MOD_S_B : MOD_S_B_ENC, MOD_S_B_DESC; 3289def MOD_S_H : MOD_S_H_ENC, MOD_S_H_DESC; 3290def MOD_S_W : MOD_S_W_ENC, MOD_S_W_DESC; 3291def MOD_S_D : MOD_S_D_ENC, MOD_S_D_DESC; 3292 3293def MOD_U_B : MOD_U_B_ENC, MOD_U_B_DESC; 3294def MOD_U_H : MOD_U_H_ENC, MOD_U_H_DESC; 3295def MOD_U_W : MOD_U_W_ENC, MOD_U_W_DESC; 3296def MOD_U_D : MOD_U_D_ENC, MOD_U_D_DESC; 3297 3298def MOVE_V : MOVE_V_ENC, MOVE_V_DESC; 3299 3300def MSUB_Q_H : MSUB_Q_H_ENC, MSUB_Q_H_DESC; 3301def MSUB_Q_W : MSUB_Q_W_ENC, MSUB_Q_W_DESC; 3302 3303def MSUBR_Q_H : MSUBR_Q_H_ENC, MSUBR_Q_H_DESC; 3304def MSUBR_Q_W : MSUBR_Q_W_ENC, MSUBR_Q_W_DESC; 3305 3306def MSUBV_B : MSUBV_B_ENC, MSUBV_B_DESC; 3307def MSUBV_H : MSUBV_H_ENC, MSUBV_H_DESC; 3308def MSUBV_W : MSUBV_W_ENC, MSUBV_W_DESC; 3309def MSUBV_D : MSUBV_D_ENC, MSUBV_D_DESC; 3310 3311def MUL_Q_H : MUL_Q_H_ENC, MUL_Q_H_DESC; 3312def MUL_Q_W : MUL_Q_W_ENC, MUL_Q_W_DESC; 3313 3314def MULR_Q_H : MULR_Q_H_ENC, MULR_Q_H_DESC; 3315def MULR_Q_W : MULR_Q_W_ENC, MULR_Q_W_DESC; 3316 3317def MULV_B : MULV_B_ENC, MULV_B_DESC; 3318def MULV_H : MULV_H_ENC, MULV_H_DESC; 3319def MULV_W : MULV_W_ENC, MULV_W_DESC; 3320def MULV_D : MULV_D_ENC, MULV_D_DESC; 3321 3322def NLOC_B : NLOC_B_ENC, NLOC_B_DESC; 3323def NLOC_H : NLOC_H_ENC, NLOC_H_DESC; 3324def NLOC_W : NLOC_W_ENC, NLOC_W_DESC; 3325def NLOC_D : NLOC_D_ENC, NLOC_D_DESC; 3326 3327def NLZC_B : NLZC_B_ENC, NLZC_B_DESC; 3328def NLZC_H : NLZC_H_ENC, NLZC_H_DESC; 3329def NLZC_W : NLZC_W_ENC, NLZC_W_DESC; 3330def NLZC_D : NLZC_D_ENC, NLZC_D_DESC; 3331 3332def NOR_V : NOR_V_ENC, NOR_V_DESC; 3333def NOR_V_H_PSEUDO : NOR_V_H_PSEUDO_DESC, 3334 PseudoInstExpansion<(NOR_V MSA128BOpnd:$wd, 3335 MSA128BOpnd:$ws, 3336 MSA128BOpnd:$wt)>; 3337def NOR_V_W_PSEUDO : NOR_V_W_PSEUDO_DESC, 3338 PseudoInstExpansion<(NOR_V MSA128BOpnd:$wd, 3339 MSA128BOpnd:$ws, 3340 MSA128BOpnd:$wt)>; 3341def NOR_V_D_PSEUDO : NOR_V_D_PSEUDO_DESC, 3342 PseudoInstExpansion<(NOR_V MSA128BOpnd:$wd, 3343 MSA128BOpnd:$ws, 3344 MSA128BOpnd:$wt)>; 3345 3346def NORI_B : NORI_B_ENC, NORI_B_DESC; 3347 3348def OR_V : OR_V_ENC, OR_V_DESC; 3349def OR_V_H_PSEUDO : OR_V_H_PSEUDO_DESC, 3350 PseudoInstExpansion<(OR_V MSA128BOpnd:$wd, 3351 MSA128BOpnd:$ws, 3352 MSA128BOpnd:$wt)>; 3353def OR_V_W_PSEUDO : OR_V_W_PSEUDO_DESC, 3354 PseudoInstExpansion<(OR_V MSA128BOpnd:$wd, 3355 MSA128BOpnd:$ws, 3356 MSA128BOpnd:$wt)>; 3357def OR_V_D_PSEUDO : OR_V_D_PSEUDO_DESC, 3358 PseudoInstExpansion<(OR_V MSA128BOpnd:$wd, 3359 MSA128BOpnd:$ws, 3360 MSA128BOpnd:$wt)>; 3361 3362def ORI_B : ORI_B_ENC, ORI_B_DESC; 3363 3364def PCKEV_B : PCKEV_B_ENC, PCKEV_B_DESC; 3365def PCKEV_H : PCKEV_H_ENC, PCKEV_H_DESC; 3366def PCKEV_W : PCKEV_W_ENC, PCKEV_W_DESC; 3367def PCKEV_D : PCKEV_D_ENC, PCKEV_D_DESC; 3368 3369def PCKOD_B : PCKOD_B_ENC, PCKOD_B_DESC; 3370def PCKOD_H : PCKOD_H_ENC, PCKOD_H_DESC; 3371def PCKOD_W : PCKOD_W_ENC, PCKOD_W_DESC; 3372def PCKOD_D : PCKOD_D_ENC, PCKOD_D_DESC; 3373 3374def PCNT_B : PCNT_B_ENC, PCNT_B_DESC; 3375def PCNT_H : PCNT_H_ENC, PCNT_H_DESC; 3376def PCNT_W : PCNT_W_ENC, PCNT_W_DESC; 3377def PCNT_D : PCNT_D_ENC, PCNT_D_DESC; 3378 3379def SAT_S_B : SAT_S_B_ENC, SAT_S_B_DESC; 3380def SAT_S_H : SAT_S_H_ENC, SAT_S_H_DESC; 3381def SAT_S_W : SAT_S_W_ENC, SAT_S_W_DESC; 3382def SAT_S_D : SAT_S_D_ENC, SAT_S_D_DESC; 3383 3384def SAT_U_B : SAT_U_B_ENC, SAT_U_B_DESC; 3385def SAT_U_H : SAT_U_H_ENC, SAT_U_H_DESC; 3386def SAT_U_W : SAT_U_W_ENC, SAT_U_W_DESC; 3387def SAT_U_D : SAT_U_D_ENC, SAT_U_D_DESC; 3388 3389def SHF_B : SHF_B_ENC, SHF_B_DESC; 3390def SHF_H : SHF_H_ENC, SHF_H_DESC; 3391def SHF_W : SHF_W_ENC, SHF_W_DESC; 3392 3393def SLD_B : SLD_B_ENC, SLD_B_DESC; 3394def SLD_H : SLD_H_ENC, SLD_H_DESC; 3395def SLD_W : SLD_W_ENC, SLD_W_DESC; 3396def SLD_D : SLD_D_ENC, SLD_D_DESC; 3397 3398def SLDI_B : SLDI_B_ENC, SLDI_B_DESC; 3399def SLDI_H : SLDI_H_ENC, SLDI_H_DESC; 3400def SLDI_W : SLDI_W_ENC, SLDI_W_DESC; 3401def SLDI_D : SLDI_D_ENC, SLDI_D_DESC; 3402 3403def SLL_B : SLL_B_ENC, SLL_B_DESC; 3404def SLL_H : SLL_H_ENC, SLL_H_DESC; 3405def SLL_W : SLL_W_ENC, SLL_W_DESC; 3406def SLL_D : SLL_D_ENC, SLL_D_DESC; 3407 3408def SLLI_B : SLLI_B_ENC, SLLI_B_DESC; 3409def SLLI_H : SLLI_H_ENC, SLLI_H_DESC; 3410def SLLI_W : SLLI_W_ENC, SLLI_W_DESC; 3411def SLLI_D : SLLI_D_ENC, SLLI_D_DESC; 3412 3413def SPLAT_B : SPLAT_B_ENC, SPLAT_B_DESC; 3414def SPLAT_H : SPLAT_H_ENC, SPLAT_H_DESC; 3415def SPLAT_W : SPLAT_W_ENC, SPLAT_W_DESC; 3416def SPLAT_D : SPLAT_D_ENC, SPLAT_D_DESC; 3417 3418def SPLATI_B : SPLATI_B_ENC, SPLATI_B_DESC; 3419def SPLATI_H : SPLATI_H_ENC, SPLATI_H_DESC; 3420def SPLATI_W : SPLATI_W_ENC, SPLATI_W_DESC; 3421def SPLATI_D : SPLATI_D_ENC, SPLATI_D_DESC; 3422 3423def SRA_B : SRA_B_ENC, SRA_B_DESC; 3424def SRA_H : SRA_H_ENC, SRA_H_DESC; 3425def SRA_W : SRA_W_ENC, SRA_W_DESC; 3426def SRA_D : SRA_D_ENC, SRA_D_DESC; 3427 3428def SRAI_B : SRAI_B_ENC, SRAI_B_DESC; 3429def SRAI_H : SRAI_H_ENC, SRAI_H_DESC; 3430def SRAI_W : SRAI_W_ENC, SRAI_W_DESC; 3431def SRAI_D : SRAI_D_ENC, SRAI_D_DESC; 3432 3433def SRAR_B : SRAR_B_ENC, SRAR_B_DESC; 3434def SRAR_H : SRAR_H_ENC, SRAR_H_DESC; 3435def SRAR_W : SRAR_W_ENC, SRAR_W_DESC; 3436def SRAR_D : SRAR_D_ENC, SRAR_D_DESC; 3437 3438def SRARI_B : SRARI_B_ENC, SRARI_B_DESC; 3439def SRARI_H : SRARI_H_ENC, SRARI_H_DESC; 3440def SRARI_W : SRARI_W_ENC, SRARI_W_DESC; 3441def SRARI_D : SRARI_D_ENC, SRARI_D_DESC; 3442 3443def SRL_B : SRL_B_ENC, SRL_B_DESC; 3444def SRL_H : SRL_H_ENC, SRL_H_DESC; 3445def SRL_W : SRL_W_ENC, SRL_W_DESC; 3446def SRL_D : SRL_D_ENC, SRL_D_DESC; 3447 3448def SRLI_B : SRLI_B_ENC, SRLI_B_DESC; 3449def SRLI_H : SRLI_H_ENC, SRLI_H_DESC; 3450def SRLI_W : SRLI_W_ENC, SRLI_W_DESC; 3451def SRLI_D : SRLI_D_ENC, SRLI_D_DESC; 3452 3453def SRLR_B : SRLR_B_ENC, SRLR_B_DESC; 3454def SRLR_H : SRLR_H_ENC, SRLR_H_DESC; 3455def SRLR_W : SRLR_W_ENC, SRLR_W_DESC; 3456def SRLR_D : SRLR_D_ENC, SRLR_D_DESC; 3457 3458def SRLRI_B : SRLRI_B_ENC, SRLRI_B_DESC; 3459def SRLRI_H : SRLRI_H_ENC, SRLRI_H_DESC; 3460def SRLRI_W : SRLRI_W_ENC, SRLRI_W_DESC; 3461def SRLRI_D : SRLRI_D_ENC, SRLRI_D_DESC; 3462 3463def ST_B: ST_B_ENC, ST_B_DESC; 3464def ST_H: ST_H_ENC, ST_H_DESC; 3465def ST_W: ST_W_ENC, ST_W_DESC; 3466def ST_D: ST_D_ENC, ST_D_DESC; 3467 3468def SUBS_S_B : SUBS_S_B_ENC, SUBS_S_B_DESC; 3469def SUBS_S_H : SUBS_S_H_ENC, SUBS_S_H_DESC; 3470def SUBS_S_W : SUBS_S_W_ENC, SUBS_S_W_DESC; 3471def SUBS_S_D : SUBS_S_D_ENC, SUBS_S_D_DESC; 3472 3473def SUBS_U_B : SUBS_U_B_ENC, SUBS_U_B_DESC; 3474def SUBS_U_H : SUBS_U_H_ENC, SUBS_U_H_DESC; 3475def SUBS_U_W : SUBS_U_W_ENC, SUBS_U_W_DESC; 3476def SUBS_U_D : SUBS_U_D_ENC, SUBS_U_D_DESC; 3477 3478def SUBSUS_U_B : SUBSUS_U_B_ENC, SUBSUS_U_B_DESC; 3479def SUBSUS_U_H : SUBSUS_U_H_ENC, SUBSUS_U_H_DESC; 3480def SUBSUS_U_W : SUBSUS_U_W_ENC, SUBSUS_U_W_DESC; 3481def SUBSUS_U_D : SUBSUS_U_D_ENC, SUBSUS_U_D_DESC; 3482 3483def SUBSUU_S_B : SUBSUU_S_B_ENC, SUBSUU_S_B_DESC; 3484def SUBSUU_S_H : SUBSUU_S_H_ENC, SUBSUU_S_H_DESC; 3485def SUBSUU_S_W : SUBSUU_S_W_ENC, SUBSUU_S_W_DESC; 3486def SUBSUU_S_D : SUBSUU_S_D_ENC, SUBSUU_S_D_DESC; 3487 3488def SUBV_B : SUBV_B_ENC, SUBV_B_DESC; 3489def SUBV_H : SUBV_H_ENC, SUBV_H_DESC; 3490def SUBV_W : SUBV_W_ENC, SUBV_W_DESC; 3491def SUBV_D : SUBV_D_ENC, SUBV_D_DESC; 3492 3493def SUBVI_B : SUBVI_B_ENC, SUBVI_B_DESC; 3494def SUBVI_H : SUBVI_H_ENC, SUBVI_H_DESC; 3495def SUBVI_W : SUBVI_W_ENC, SUBVI_W_DESC; 3496def SUBVI_D : SUBVI_D_ENC, SUBVI_D_DESC; 3497 3498def VSHF_B : VSHF_B_ENC, VSHF_B_DESC; 3499def VSHF_H : VSHF_H_ENC, VSHF_H_DESC; 3500def VSHF_W : VSHF_W_ENC, VSHF_W_DESC; 3501def VSHF_D : VSHF_D_ENC, VSHF_D_DESC; 3502 3503def XOR_V : XOR_V_ENC, XOR_V_DESC; 3504def XOR_V_H_PSEUDO : XOR_V_H_PSEUDO_DESC, 3505 PseudoInstExpansion<(XOR_V MSA128BOpnd:$wd, 3506 MSA128BOpnd:$ws, 3507 MSA128BOpnd:$wt)>; 3508def XOR_V_W_PSEUDO : XOR_V_W_PSEUDO_DESC, 3509 PseudoInstExpansion<(XOR_V MSA128BOpnd:$wd, 3510 MSA128BOpnd:$ws, 3511 MSA128BOpnd:$wt)>; 3512def XOR_V_D_PSEUDO : XOR_V_D_PSEUDO_DESC, 3513 PseudoInstExpansion<(XOR_V MSA128BOpnd:$wd, 3514 MSA128BOpnd:$ws, 3515 MSA128BOpnd:$wt)>; 3516 3517def XORI_B : XORI_B_ENC, XORI_B_DESC; 3518 3519// Patterns. 3520class MSAPat<dag pattern, dag result, list<Predicate> pred = [HasMSA]> : 3521 Pat<pattern, result>, Requires<pred>; 3522 3523def : MSAPat<(extractelt (v4i32 MSA128W:$ws), immZExt4:$idx), 3524 (COPY_S_W MSA128W:$ws, immZExt4:$idx)>; 3525 3526def : MSAPat<(v8f16 (load addrimm10:$addr)), (LD_H addrimm10:$addr)>; 3527def : MSAPat<(v4f32 (load addrimm10:$addr)), (LD_W addrimm10:$addr)>; 3528def : MSAPat<(v2f64 (load addrimm10:$addr)), (LD_D addrimm10:$addr)>; 3529 3530def ST_FH : MSAPat<(store (v8f16 MSA128H:$ws), addrimm10:$addr), 3531 (ST_H MSA128H:$ws, addrimm10:$addr)>; 3532def ST_FW : MSAPat<(store (v4f32 MSA128W:$ws), addrimm10:$addr), 3533 (ST_W MSA128W:$ws, addrimm10:$addr)>; 3534def ST_FD : MSAPat<(store (v2f64 MSA128D:$ws), addrimm10:$addr), 3535 (ST_D MSA128D:$ws, addrimm10:$addr)>; 3536 3537class MSA_FABS_PSEUDO_DESC_BASE<RegisterOperand ROWD, 3538 RegisterOperand ROWS = ROWD, 3539 InstrItinClass itin = NoItinerary> : 3540 MSAPseudo<(outs ROWD:$wd), 3541 (ins ROWS:$ws), 3542 [(set ROWD:$wd, (fabs ROWS:$ws))]> { 3543 InstrItinClass Itinerary = itin; 3544} 3545def FABS_W : MSA_FABS_PSEUDO_DESC_BASE<MSA128WOpnd>, 3546 PseudoInstExpansion<(FMAX_A_W MSA128WOpnd:$wd, MSA128WOpnd:$ws, 3547 MSA128WOpnd:$ws)>; 3548def FABS_D : MSA_FABS_PSEUDO_DESC_BASE<MSA128DOpnd>, 3549 PseudoInstExpansion<(FMAX_A_D MSA128DOpnd:$wd, MSA128DOpnd:$ws, 3550 MSA128DOpnd:$ws)>; 3551 3552class MSABitconvertPat<ValueType DstVT, ValueType SrcVT, 3553 RegisterClass DstRC, list<Predicate> preds = [HasMSA]> : 3554 MSAPat<(DstVT (bitconvert SrcVT:$src)), 3555 (COPY_TO_REGCLASS SrcVT:$src, DstRC), preds>; 3556 3557// These are endian-independent because the element size doesnt change 3558def : MSABitconvertPat<v8i16, v8f16, MSA128H>; 3559def : MSABitconvertPat<v4i32, v4f32, MSA128W>; 3560def : MSABitconvertPat<v2i64, v2f64, MSA128D>; 3561def : MSABitconvertPat<v8f16, v8i16, MSA128H>; 3562def : MSABitconvertPat<v4f32, v4i32, MSA128W>; 3563def : MSABitconvertPat<v2f64, v2i64, MSA128D>; 3564 3565// Little endian bitcasts are always no-ops 3566def : MSABitconvertPat<v16i8, v8i16, MSA128B, [HasMSA, IsLE]>; 3567def : MSABitconvertPat<v16i8, v4i32, MSA128B, [HasMSA, IsLE]>; 3568def : MSABitconvertPat<v16i8, v2i64, MSA128B, [HasMSA, IsLE]>; 3569def : MSABitconvertPat<v16i8, v8f16, MSA128B, [HasMSA, IsLE]>; 3570def : MSABitconvertPat<v16i8, v4f32, MSA128B, [HasMSA, IsLE]>; 3571def : MSABitconvertPat<v16i8, v2f64, MSA128B, [HasMSA, IsLE]>; 3572 3573def : MSABitconvertPat<v8i16, v16i8, MSA128H, [HasMSA, IsLE]>; 3574def : MSABitconvertPat<v8i16, v4i32, MSA128H, [HasMSA, IsLE]>; 3575def : MSABitconvertPat<v8i16, v2i64, MSA128H, [HasMSA, IsLE]>; 3576def : MSABitconvertPat<v8i16, v4f32, MSA128H, [HasMSA, IsLE]>; 3577def : MSABitconvertPat<v8i16, v2f64, MSA128H, [HasMSA, IsLE]>; 3578 3579def : MSABitconvertPat<v4i32, v16i8, MSA128W, [HasMSA, IsLE]>; 3580def : MSABitconvertPat<v4i32, v8i16, MSA128W, [HasMSA, IsLE]>; 3581def : MSABitconvertPat<v4i32, v2i64, MSA128W, [HasMSA, IsLE]>; 3582def : MSABitconvertPat<v4i32, v8f16, MSA128W, [HasMSA, IsLE]>; 3583def : MSABitconvertPat<v4i32, v2f64, MSA128W, [HasMSA, IsLE]>; 3584 3585def : MSABitconvertPat<v2i64, v16i8, MSA128D, [HasMSA, IsLE]>; 3586def : MSABitconvertPat<v2i64, v8i16, MSA128D, [HasMSA, IsLE]>; 3587def : MSABitconvertPat<v2i64, v4i32, MSA128D, [HasMSA, IsLE]>; 3588def : MSABitconvertPat<v2i64, v8f16, MSA128D, [HasMSA, IsLE]>; 3589def : MSABitconvertPat<v2i64, v4f32, MSA128D, [HasMSA, IsLE]>; 3590 3591def : MSABitconvertPat<v4f32, v16i8, MSA128W, [HasMSA, IsLE]>; 3592def : MSABitconvertPat<v4f32, v8i16, MSA128W, [HasMSA, IsLE]>; 3593def : MSABitconvertPat<v4f32, v2i64, MSA128W, [HasMSA, IsLE]>; 3594def : MSABitconvertPat<v4f32, v8f16, MSA128W, [HasMSA, IsLE]>; 3595def : MSABitconvertPat<v4f32, v2f64, MSA128W, [HasMSA, IsLE]>; 3596 3597def : MSABitconvertPat<v2f64, v16i8, MSA128D, [HasMSA, IsLE]>; 3598def : MSABitconvertPat<v2f64, v8i16, MSA128D, [HasMSA, IsLE]>; 3599def : MSABitconvertPat<v2f64, v4i32, MSA128D, [HasMSA, IsLE]>; 3600def : MSABitconvertPat<v2f64, v8f16, MSA128D, [HasMSA, IsLE]>; 3601def : MSABitconvertPat<v2f64, v4f32, MSA128D, [HasMSA, IsLE]>; 3602 3603// Big endian bitcasts expand to shuffle instructions. 3604// This is because bitcast is defined to be a store/load sequence and the 3605// vector store/load instructions are mixed-endian with respect to the vector 3606// as a whole (little endian with respect to element order, but big endian 3607// elements). 3608 3609class MSABitconvertReverseQuartersPat<ValueType DstVT, ValueType SrcVT, 3610 RegisterClass DstRC, MSAInst Insn, 3611 RegisterClass ViaRC> : 3612 MSAPat<(DstVT (bitconvert SrcVT:$src)), 3613 (COPY_TO_REGCLASS (Insn (COPY_TO_REGCLASS SrcVT:$src, ViaRC), 27), 3614 DstRC), 3615 [HasMSA, IsBE]>; 3616 3617class MSABitconvertReverseHalvesPat<ValueType DstVT, ValueType SrcVT, 3618 RegisterClass DstRC, MSAInst Insn, 3619 RegisterClass ViaRC> : 3620 MSAPat<(DstVT (bitconvert SrcVT:$src)), 3621 (COPY_TO_REGCLASS (Insn (COPY_TO_REGCLASS SrcVT:$src, ViaRC), 177), 3622 DstRC), 3623 [HasMSA, IsBE]>; 3624 3625class MSABitconvertReverseBInHPat<ValueType DstVT, ValueType SrcVT, 3626 RegisterClass DstRC> : 3627 MSABitconvertReverseHalvesPat<DstVT, SrcVT, DstRC, SHF_B, MSA128B>; 3628 3629class MSABitconvertReverseBInWPat<ValueType DstVT, ValueType SrcVT, 3630 RegisterClass DstRC> : 3631 MSABitconvertReverseQuartersPat<DstVT, SrcVT, DstRC, SHF_B, MSA128B>; 3632 3633class MSABitconvertReverseBInDPat<ValueType DstVT, ValueType SrcVT, 3634 RegisterClass DstRC> : 3635 MSAPat<(DstVT (bitconvert SrcVT:$src)), 3636 (COPY_TO_REGCLASS 3637 (SHF_W 3638 (COPY_TO_REGCLASS 3639 (SHF_B (COPY_TO_REGCLASS SrcVT:$src, MSA128B), 27), 3640 MSA128W), 177), 3641 DstRC), 3642 [HasMSA, IsBE]>; 3643 3644class MSABitconvertReverseHInWPat<ValueType DstVT, ValueType SrcVT, 3645 RegisterClass DstRC> : 3646 MSABitconvertReverseHalvesPat<DstVT, SrcVT, DstRC, SHF_H, MSA128H>; 3647 3648class MSABitconvertReverseHInDPat<ValueType DstVT, ValueType SrcVT, 3649 RegisterClass DstRC> : 3650 MSABitconvertReverseQuartersPat<DstVT, SrcVT, DstRC, SHF_H, MSA128H>; 3651 3652class MSABitconvertReverseWInDPat<ValueType DstVT, ValueType SrcVT, 3653 RegisterClass DstRC> : 3654 MSABitconvertReverseHalvesPat<DstVT, SrcVT, DstRC, SHF_W, MSA128W>; 3655 3656def : MSABitconvertReverseBInHPat<v8i16, v16i8, MSA128H>; 3657def : MSABitconvertReverseBInHPat<v8f16, v16i8, MSA128H>; 3658def : MSABitconvertReverseBInWPat<v4i32, v16i8, MSA128W>; 3659def : MSABitconvertReverseBInWPat<v4f32, v16i8, MSA128W>; 3660def : MSABitconvertReverseBInDPat<v2i64, v16i8, MSA128D>; 3661def : MSABitconvertReverseBInDPat<v2f64, v16i8, MSA128D>; 3662 3663def : MSABitconvertReverseBInHPat<v16i8, v8i16, MSA128B>; 3664def : MSABitconvertReverseHInWPat<v4i32, v8i16, MSA128W>; 3665def : MSABitconvertReverseHInWPat<v4f32, v8i16, MSA128W>; 3666def : MSABitconvertReverseHInDPat<v2i64, v8i16, MSA128D>; 3667def : MSABitconvertReverseHInDPat<v2f64, v8i16, MSA128D>; 3668 3669def : MSABitconvertReverseBInHPat<v16i8, v8f16, MSA128B>; 3670def : MSABitconvertReverseHInWPat<v4i32, v8f16, MSA128W>; 3671def : MSABitconvertReverseHInWPat<v4f32, v8f16, MSA128W>; 3672def : MSABitconvertReverseHInDPat<v2i64, v8f16, MSA128D>; 3673def : MSABitconvertReverseHInDPat<v2f64, v8f16, MSA128D>; 3674 3675def : MSABitconvertReverseBInWPat<v16i8, v4i32, MSA128B>; 3676def : MSABitconvertReverseHInWPat<v8i16, v4i32, MSA128H>; 3677def : MSABitconvertReverseHInWPat<v8f16, v4i32, MSA128H>; 3678def : MSABitconvertReverseWInDPat<v2i64, v4i32, MSA128D>; 3679def : MSABitconvertReverseWInDPat<v2f64, v4i32, MSA128D>; 3680 3681def : MSABitconvertReverseBInWPat<v16i8, v4f32, MSA128B>; 3682def : MSABitconvertReverseHInWPat<v8i16, v4f32, MSA128H>; 3683def : MSABitconvertReverseHInWPat<v8f16, v4f32, MSA128H>; 3684def : MSABitconvertReverseWInDPat<v2i64, v4f32, MSA128D>; 3685def : MSABitconvertReverseWInDPat<v2f64, v4f32, MSA128D>; 3686 3687def : MSABitconvertReverseBInDPat<v16i8, v2i64, MSA128B>; 3688def : MSABitconvertReverseHInDPat<v8i16, v2i64, MSA128H>; 3689def : MSABitconvertReverseHInDPat<v8f16, v2i64, MSA128H>; 3690def : MSABitconvertReverseWInDPat<v4i32, v2i64, MSA128W>; 3691def : MSABitconvertReverseWInDPat<v4f32, v2i64, MSA128W>; 3692 3693def : MSABitconvertReverseBInDPat<v16i8, v2f64, MSA128B>; 3694def : MSABitconvertReverseHInDPat<v8i16, v2f64, MSA128H>; 3695def : MSABitconvertReverseHInDPat<v8f16, v2f64, MSA128H>; 3696def : MSABitconvertReverseWInDPat<v4i32, v2f64, MSA128W>; 3697def : MSABitconvertReverseWInDPat<v4f32, v2f64, MSA128W>; 3698 3699// Pseudos used to implement BNZ.df, and BZ.df 3700 3701class MSA_CBRANCH_PSEUDO_DESC_BASE<SDPatternOperator OpNode, ValueType TyNode, 3702 RegisterClass RCWS, 3703 InstrItinClass itin = NoItinerary> : 3704 MipsPseudo<(outs GPR32:$dst), 3705 (ins RCWS:$ws), 3706 [(set GPR32:$dst, (OpNode (TyNode RCWS:$ws)))]> { 3707 bit usesCustomInserter = 1; 3708} 3709 3710def SNZ_B_PSEUDO : MSA_CBRANCH_PSEUDO_DESC_BASE<MipsVAllNonZero, v16i8, 3711 MSA128B, NoItinerary>; 3712def SNZ_H_PSEUDO : MSA_CBRANCH_PSEUDO_DESC_BASE<MipsVAllNonZero, v8i16, 3713 MSA128H, NoItinerary>; 3714def SNZ_W_PSEUDO : MSA_CBRANCH_PSEUDO_DESC_BASE<MipsVAllNonZero, v4i32, 3715 MSA128W, NoItinerary>; 3716def SNZ_D_PSEUDO : MSA_CBRANCH_PSEUDO_DESC_BASE<MipsVAllNonZero, v2i64, 3717 MSA128D, NoItinerary>; 3718def SNZ_V_PSEUDO : MSA_CBRANCH_PSEUDO_DESC_BASE<MipsVAnyNonZero, v16i8, 3719 MSA128B, NoItinerary>; 3720 3721def SZ_B_PSEUDO : MSA_CBRANCH_PSEUDO_DESC_BASE<MipsVAllZero, v16i8, 3722 MSA128B, NoItinerary>; 3723def SZ_H_PSEUDO : MSA_CBRANCH_PSEUDO_DESC_BASE<MipsVAllZero, v8i16, 3724 MSA128H, NoItinerary>; 3725def SZ_W_PSEUDO : MSA_CBRANCH_PSEUDO_DESC_BASE<MipsVAllZero, v4i32, 3726 MSA128W, NoItinerary>; 3727def SZ_D_PSEUDO : MSA_CBRANCH_PSEUDO_DESC_BASE<MipsVAllZero, v2i64, 3728 MSA128D, NoItinerary>; 3729def SZ_V_PSEUDO : MSA_CBRANCH_PSEUDO_DESC_BASE<MipsVAnyZero, v16i8, 3730 MSA128B, NoItinerary>; 3731 3732// Vector extraction with fixed index. 3733// 3734// Extracting 32-bit values on MSA32 should always use COPY_S_W rather than 3735// COPY_U_W, even for the zero-extended case. This is because our forward 3736// compatibility strategy is to consider registers to be infinitely 3737// sign-extended so that a MIPS64 can execute MIPS32 code without getting 3738// different register values. 3739def : MSAPat<(vextract_zext_i32 (v4i32 MSA128W:$ws), immZExt2Ptr:$idx), 3740 (COPY_S_W MSA128W:$ws, immZExt2:$idx)>, ASE_MSA_NOT_MSA64; 3741def : MSAPat<(vextract_zext_i32 (v4f32 MSA128W:$ws), immZExt2Ptr:$idx), 3742 (COPY_S_W MSA128W:$ws, immZExt2:$idx)>, ASE_MSA_NOT_MSA64; 3743 3744// Extracting 64-bit values on MSA64 should always use COPY_S_D rather than 3745// COPY_U_D, even for the zero-extended case. This is because our forward 3746// compatibility strategy is to consider registers to be infinitely 3747// sign-extended so that a hypothetical MIPS128 would be able to execute MIPS64 3748// code without getting different register values. 3749def : MSAPat<(vextract_zext_i64 (v2i64 MSA128D:$ws), immZExt1Ptr:$idx), 3750 (COPY_S_D MSA128D:$ws, immZExt1:$idx)>, ASE_MSA64; 3751def : MSAPat<(vextract_zext_i64 (v2f64 MSA128D:$ws), immZExt1Ptr:$idx), 3752 (COPY_S_D MSA128D:$ws, immZExt1:$idx)>, ASE_MSA64; 3753 3754// Vector extraction with variable index 3755def : MSAPat<(i32 (vextract_sext_i8 v16i8:$ws, i32:$idx)), 3756 (SRA (COPY_TO_REGCLASS (i32 (EXTRACT_SUBREG (SPLAT_B v16i8:$ws, 3757 i32:$idx), 3758 sub_lo)), 3759 GPR32), (i32 24))>; 3760def : MSAPat<(i32 (vextract_sext_i16 v8i16:$ws, i32:$idx)), 3761 (SRA (COPY_TO_REGCLASS (i32 (EXTRACT_SUBREG (SPLAT_H v8i16:$ws, 3762 i32:$idx), 3763 sub_lo)), 3764 GPR32), (i32 16))>; 3765def : MSAPat<(i32 (vextract_sext_i32 v4i32:$ws, i32:$idx)), 3766 (COPY_TO_REGCLASS (i32 (EXTRACT_SUBREG (SPLAT_W v4i32:$ws, 3767 i32:$idx), 3768 sub_lo)), 3769 GPR32)>; 3770def : MSAPat<(i64 (vextract_sext_i64 v2i64:$ws, i32:$idx)), 3771 (COPY_TO_REGCLASS (i64 (EXTRACT_SUBREG (SPLAT_D v2i64:$ws, 3772 i32:$idx), 3773 sub_64)), 3774 GPR64), [HasMSA, IsGP64bit]>; 3775 3776def : MSAPat<(i32 (vextract_zext_i8 v16i8:$ws, i32:$idx)), 3777 (SRL (COPY_TO_REGCLASS (i32 (EXTRACT_SUBREG (SPLAT_B v16i8:$ws, 3778 i32:$idx), 3779 sub_lo)), 3780 GPR32), (i32 24))>; 3781def : MSAPat<(i32 (vextract_zext_i16 v8i16:$ws, i32:$idx)), 3782 (SRL (COPY_TO_REGCLASS (i32 (EXTRACT_SUBREG (SPLAT_H v8i16:$ws, 3783 i32:$idx), 3784 sub_lo)), 3785 GPR32), (i32 16))>; 3786def : MSAPat<(i32 (vextract_zext_i32 v4i32:$ws, i32:$idx)), 3787 (COPY_TO_REGCLASS (i32 (EXTRACT_SUBREG (SPLAT_W v4i32:$ws, 3788 i32:$idx), 3789 sub_lo)), 3790 GPR32)>; 3791def : MSAPat<(i64 (vextract_zext_i64 v2i64:$ws, i32:$idx)), 3792 (COPY_TO_REGCLASS (i64 (EXTRACT_SUBREG (SPLAT_D v2i64:$ws, 3793 i32:$idx), 3794 sub_64)), 3795 GPR64), [HasMSA, IsGP64bit]>; 3796 3797def : MSAPat<(f32 (vector_extract v4f32:$ws, i32:$idx)), 3798 (f32 (EXTRACT_SUBREG (SPLAT_W v4f32:$ws, 3799 i32:$idx), 3800 sub_lo))>; 3801def : MSAPat<(f64 (vector_extract v2f64:$ws, i32:$idx)), 3802 (f64 (EXTRACT_SUBREG (SPLAT_D v2f64:$ws, 3803 i32:$idx), 3804 sub_64))>; 3805 3806// Vector extraction with variable index (N64 ABI) 3807def : MSAPat< 3808 (i32 (vextract_sext_i8 v16i8:$ws, i64:$idx)), 3809 (SRA (COPY_TO_REGCLASS 3810 (i32 (EXTRACT_SUBREG 3811 (SPLAT_B v16i8:$ws, 3812 (COPY_TO_REGCLASS 3813 (i32 (EXTRACT_SUBREG i64:$idx, sub_32)), GPR32)), 3814 sub_lo)), 3815 GPR32), 3816 (i32 24))>; 3817def : MSAPat< 3818 (i32 (vextract_sext_i16 v8i16:$ws, i64:$idx)), 3819 (SRA (COPY_TO_REGCLASS 3820 (i32 (EXTRACT_SUBREG 3821 (SPLAT_H v8i16:$ws, 3822 (COPY_TO_REGCLASS 3823 (i32 (EXTRACT_SUBREG i64:$idx, sub_32)), GPR32)), 3824 sub_lo)), 3825 GPR32), 3826 (i32 16))>; 3827def : MSAPat< 3828 (i32 (vextract_sext_i32 v4i32:$ws, i64:$idx)), 3829 (COPY_TO_REGCLASS 3830 (i32 (EXTRACT_SUBREG 3831 (SPLAT_W v4i32:$ws, 3832 (COPY_TO_REGCLASS 3833 (i32 (EXTRACT_SUBREG i64:$idx, sub_32)), GPR32)), 3834 sub_lo)), 3835 GPR32)>; 3836def : MSAPat< 3837 (i64 (vextract_sext_i64 v2i64:$ws, i64:$idx)), 3838 (COPY_TO_REGCLASS 3839 (i64 (EXTRACT_SUBREG 3840 (SPLAT_D v2i64:$ws, 3841 (COPY_TO_REGCLASS (i32 (EXTRACT_SUBREG i64:$idx, sub_32)), GPR32)), 3842 sub_64)), 3843 GPR64), [HasMSA, IsGP64bit]>; 3844 3845def : MSAPat< 3846 (i32 (vextract_zext_i8 v16i8:$ws, i64:$idx)), 3847 (SRL (COPY_TO_REGCLASS 3848 (i32 (EXTRACT_SUBREG 3849 (SPLAT_B v16i8:$ws, 3850 (COPY_TO_REGCLASS 3851 (i32 (EXTRACT_SUBREG i64:$idx, sub_32)), GPR32)), 3852 sub_lo)), 3853 GPR32), 3854 (i32 24))>; 3855def : MSAPat< 3856 (i32 (vextract_zext_i16 v8i16:$ws, i64:$idx)), 3857 (SRL (COPY_TO_REGCLASS 3858 (i32 (EXTRACT_SUBREG 3859 (SPLAT_H v8i16:$ws, 3860 (COPY_TO_REGCLASS 3861 (i32 (EXTRACT_SUBREG i64:$idx, sub_32)), GPR32)), 3862 sub_lo)), 3863 GPR32), 3864 (i32 16))>; 3865def : MSAPat< 3866 (i32 (vextract_zext_i32 v4i32:$ws, i64:$idx)), 3867 (COPY_TO_REGCLASS 3868 (i32 (EXTRACT_SUBREG 3869 (SPLAT_W v4i32:$ws, 3870 (COPY_TO_REGCLASS (i32 (EXTRACT_SUBREG i64:$idx, sub_32)), GPR32)), 3871 sub_lo)), 3872 GPR32)>; 3873def : MSAPat< 3874 (i64 (vextract_zext_i64 v2i64:$ws, i64:$idx)), 3875 (COPY_TO_REGCLASS 3876 (i64 (EXTRACT_SUBREG 3877 (SPLAT_D v2i64:$ws, 3878 (COPY_TO_REGCLASS (i32 (EXTRACT_SUBREG i64:$idx, sub_32)), GPR32)), 3879 sub_64)), 3880 GPR64), 3881 [HasMSA, IsGP64bit]>; 3882 3883def : MSAPat< 3884 (f32 (vector_extract v4f32:$ws, i64:$idx)), 3885 (f32 (EXTRACT_SUBREG 3886 (SPLAT_W v4f32:$ws, 3887 (COPY_TO_REGCLASS (i32 (EXTRACT_SUBREG i64:$idx, sub_32)), GPR32)), 3888 sub_lo))>; 3889def : MSAPat< 3890 (f64 (vector_extract v2f64:$ws, i64:$idx)), 3891 (f64 (EXTRACT_SUBREG 3892 (SPLAT_D v2f64:$ws, 3893 (COPY_TO_REGCLASS (i32 (EXTRACT_SUBREG i64:$idx, sub_32)), GPR32)), 3894 sub_64))>; 3895