1102 if (
Node->isMachineOpcode()) {
1104 Node->setNodeId(-1);
1110 unsigned Opcode =
Node->getOpcode();
1111 MVT XLenVT = Subtarget->getXLenVT();
1113 MVT VT =
Node->getSimpleValueType(0);
1115 bool HasBitTest = Subtarget->hasBEXTILike();
1119 assert(VT == Subtarget->getXLenVT() &&
"Unexpected VT");
1121 if (ConstNode->isZero()) {
1123 CurDAG->getCopyFromReg(
CurDAG->getEntryNode(),
DL, RISCV::X0, VT);
1127 int64_t Imm = ConstNode->getSExtValue();
1142 if (Subtarget->hasStdExtP() && !
isInt<12>(Imm) &&
1163 Imm = ((
uint64_t)Imm << 32) | (Imm & 0xFFFFFFFF);
1173 bool Is64Bit = Subtarget->is64Bit();
1174 bool HasZdinx = Subtarget->hasStdExtZdinx();
1176 bool NegZeroF64 = APF.
isNegZero() && VT == MVT::f64;
1181 if (VT == MVT::f64 && HasZdinx && !Is64Bit)
1182 Imm =
CurDAG->getRegister(RISCV::X0_Pair, MVT::f64);
1184 Imm =
CurDAG->getRegister(RISCV::X0, XLenVT);
1195 assert(Subtarget->hasStdExtZfbfmin());
1196 Opc = RISCV::FMV_H_X;
1199 Opc = Subtarget->hasStdExtZhinxmin() ? RISCV::COPY : RISCV::FMV_H_X;
1202 Opc = Subtarget->hasStdExtZfinx() ? RISCV::COPY : RISCV::FMV_W_X;
1207 assert((Subtarget->is64Bit() || APF.
isZero()) &&
"Unexpected constant");
1211 Opc = Is64Bit ? RISCV::FMV_D_X : RISCV::FCVT_D_W;
1216 if (VT.
SimpleTy == MVT::f16 &&
Opc == RISCV::COPY) {
1218 CurDAG->getTargetExtractSubreg(RISCV::sub_16,
DL, VT, Imm).getNode();
1219 }
else if (VT.
SimpleTy == MVT::f32 &&
Opc == RISCV::COPY) {
1221 CurDAG->getTargetExtractSubreg(RISCV::sub_32,
DL, VT, Imm).getNode();
1222 }
else if (
Opc == RISCV::FCVT_D_W_IN32X ||
Opc == RISCV::FCVT_D_W)
1223 Res =
CurDAG->getMachineNode(
1231 Opc = RISCV::FSGNJN_D;
1233 Opc = Is64Bit ? RISCV::FSGNJN_D_INX : RISCV::FSGNJN_D_IN32X;
1241 case RISCVISD::BuildGPRPair:
1242 case RISCVISD::BuildPairF64:
1243 case RISCVISD::BuildPairGPRVec: {
1244 if (Opcode == RISCVISD::BuildPairF64 && !Subtarget->hasStdExtZdinx())
1247 assert((!Subtarget->is64Bit() || Opcode != RISCVISD::BuildPairF64) &&
1248 "BuildPairF64 only handled here on rv32i_zdinx");
1255 case RISCVISD::SplitGPRPair:
1256 case RISCVISD::SplitF64:
1257 case RISCVISD::SplitGPRVec: {
1258 if (Subtarget->hasStdExtZdinx() || Opcode != RISCVISD::SplitF64) {
1259 assert((!Subtarget->is64Bit() || Opcode != RISCVISD::SplitF64) &&
1260 "SplitF64 only handled here on rv32i_zdinx");
1264 Node->getValueType(0),
1265 Node->getOperand(0));
1271 RISCV::sub_gpr_odd,
DL,
Node->getValueType(1),
Node->getOperand(0));
1279 if (!Subtarget->hasStdExtZfa())
1281 assert(Subtarget->hasStdExtD() && !Subtarget->is64Bit() &&
1282 "Unexpected subtarget");
1287 Node->getOperand(0));
1292 Node->getOperand(0));
1307 unsigned ShAmt = N1C->getZExtValue();
1311 unsigned XLen = Subtarget->getXLen();
1314 if (ShAmt <= 32 && TrailingZeros > 0 && LeadingZeros == 32) {
1319 CurDAG->getTargetConstant(TrailingZeros,
DL, VT));
1322 CurDAG->getTargetConstant(TrailingZeros + ShAmt,
DL, VT));
1326 if (TrailingZeros == 0 && LeadingZeros > ShAmt &&
1327 XLen - LeadingZeros > 11 && LeadingZeros != 32) {
1338 CurDAG->getTargetConstant(LeadingZeros,
DL, VT));
1341 CurDAG->getTargetConstant(LeadingZeros - ShAmt,
DL, VT));
1355 unsigned ShAmt = N1C->getZExtValue();
1361 unsigned XLen = Subtarget->getXLen();
1364 if (LeadingZeros == 32 && TrailingZeros > ShAmt) {
1367 CurDAG->getTargetConstant(TrailingZeros,
DL, VT));
1370 CurDAG->getTargetConstant(TrailingZeros - ShAmt,
DL, VT));
1387 if (ShAmt >= TrailingOnes)
1390 if (TrailingOnes == 32) {
1392 Subtarget->is64Bit() ? RISCV::SRLIW : RISCV::SRLI,
DL, VT,
1403 if (HasBitTest && ShAmt + 1 == TrailingOnes) {
1405 Subtarget->hasStdExtZbs() ? RISCV::BEXTI : RISCV::TH_TST,
DL, VT,
1411 const unsigned Msb = TrailingOnes - 1;
1412 const unsigned Lsb = ShAmt;
1416 unsigned LShAmt = Subtarget->getXLen() - TrailingOnes;
1419 CurDAG->getTargetConstant(LShAmt,
DL, VT));
1422 CurDAG->getTargetConstant(LShAmt + ShAmt,
DL, VT));
1447 unsigned ShAmt = N1C->getZExtValue();
1451 if (ExtSize >= 32 || ShAmt >= ExtSize)
1453 unsigned LShAmt = Subtarget->getXLen() - ExtSize;
1456 CurDAG->getTargetConstant(LShAmt,
DL, VT));
1459 CurDAG->getTargetConstant(LShAmt + ShAmt,
DL, VT));
1478 unsigned ShAmt = ShAmtC->getZExtValue();
1479 unsigned XLen = Subtarget->getXLen();
1482 if (ExtSize >= 32 || ShAmt >= XLen - ExtSize)
1485 unsigned LShAmt = XLen - ExtSize - ShAmt;
1488 CurDAG->getTargetConstant(LShAmt,
DL, VT));
1491 CurDAG->getTargetConstant(XLen - ExtSize,
DL, VT));
1518 unsigned C2 =
C->getZExtValue();
1519 unsigned XLen = Subtarget->getXLen();
1520 assert((C2 > 0 && C2 < XLen) &&
"Unexpected shift amount!");
1528 bool IsCANDI =
isInt<6>(N1C->getSExtValue());
1540 bool OneUseOrZExtW = N0.
hasOneUse() || C1 == UINT64_C(0xFFFFFFFF);
1550 if (C2 + 32 == Leading) {
1552 RISCV::SRLIW,
DL, VT,
X,
CurDAG->getTargetConstant(C2,
DL, VT));
1562 if (C2 >= 32 && (Leading - C2) == 1 && N0.
hasOneUse() &&
1566 CurDAG->getMachineNode(RISCV::SRAIW,
DL, VT,
X.getOperand(0),
1567 CurDAG->getTargetConstant(31,
DL, VT));
1569 RISCV::SRLIW,
DL, VT,
SDValue(SRAIW, 0),
1570 CurDAG->getTargetConstant(Leading - 32,
DL, VT));
1583 const unsigned Lsb = C2;
1589 bool Skip = Subtarget->hasStdExtZba() && Leading == 32 &&
1593 Skip |= HasBitTest && Leading == XLen - 1;
1594 if (OneUseOrZExtW && !Skip) {
1596 RISCV::SLLI,
DL, VT,
X,
1597 CurDAG->getTargetConstant(Leading - C2,
DL, VT));
1600 CurDAG->getTargetConstant(Leading,
DL, VT));
1612 if (C2 + Leading < XLen &&
1615 if ((XLen - (C2 + Leading)) == 32 && Subtarget->hasStdExtZba()) {
1617 CurDAG->getMachineNode(RISCV::SLLI_UW,
DL, VT,
X,
1618 CurDAG->getTargetConstant(C2,
DL, VT));
1631 const unsigned Msb = XLen - Leading - 1;
1632 const unsigned Lsb = C2;
1636 if (OneUseOrZExtW && !IsCANDI) {
1638 if (Subtarget->hasStdExtZbkb() && C1 == 0xff00 && C2 == 8) {
1640 RISCV::PACKH,
DL, VT,
1641 CurDAG->getRegister(RISCV::X0, Subtarget->getXLenVT()),
X);
1647 RISCV::SLLI,
DL, VT,
X,
1648 CurDAG->getTargetConstant(C2 + Leading,
DL, VT));
1651 CurDAG->getTargetConstant(Leading,
DL, VT));
1663 if (Leading == C2 && C2 + Trailing < XLen && OneUseOrZExtW &&
1665 unsigned SrliOpc = RISCV::SRLI;
1669 X.getConstantOperandVal(1) == UINT64_C(0xFFFFFFFF)) {
1670 SrliOpc = RISCV::SRLIW;
1671 X =
X.getOperand(0);
1675 CurDAG->getTargetConstant(C2 + Trailing,
DL, VT));
1678 CurDAG->getTargetConstant(Trailing,
DL, VT));
1683 if (Leading > 32 && (Leading - 32) == C2 && C2 + Trailing < 32 &&
1684 OneUseOrZExtW && !IsCANDI) {
1686 RISCV::SRLIW,
DL, VT,
X,
1687 CurDAG->getTargetConstant(C2 + Trailing,
DL, VT));
1690 CurDAG->getTargetConstant(Trailing,
DL, VT));
1695 if (Trailing > 0 && Leading + Trailing == 32 && C2 + Trailing < XLen &&
1696 OneUseOrZExtW && Subtarget->hasStdExtZba()) {
1698 RISCV::SRLI,
DL, VT,
X,
1699 CurDAG->getTargetConstant(C2 + Trailing,
DL, VT));
1701 RISCV::SLLI_UW,
DL, VT,
SDValue(SRLI, 0),
1702 CurDAG->getTargetConstant(Trailing,
DL, VT));
1713 if (Leading == 0 && C2 < Trailing && OneUseOrZExtW && !IsCANDI) {
1715 RISCV::SRLI,
DL, VT,
X,
1716 CurDAG->getTargetConstant(Trailing - C2,
DL, VT));
1719 CurDAG->getTargetConstant(Trailing,
DL, VT));
1724 if (C2 < Trailing && Leading + C2 == 32 && OneUseOrZExtW && !IsCANDI) {
1726 RISCV::SRLIW,
DL, VT,
X,
1727 CurDAG->getTargetConstant(Trailing - C2,
DL, VT));
1730 CurDAG->getTargetConstant(Trailing,
DL, VT));
1736 if (C2 < Trailing && Leading + Trailing == 32 && OneUseOrZExtW &&
1737 Subtarget->hasStdExtZba()) {
1739 RISCV::SRLI,
DL, VT,
X,
1740 CurDAG->getTargetConstant(Trailing - C2,
DL, VT));
1742 RISCV::SLLI_UW,
DL, VT,
SDValue(SRLI, 0),
1743 CurDAG->getTargetConstant(Trailing,
DL, VT));
1750 const uint64_t C1 = N1C->getZExtValue();
1755 unsigned XLen = Subtarget->getXLen();
1756 assert((C2 > 0 && C2 < XLen) &&
"Unexpected shift amount!");
1761 bool Skip = C2 > 32 &&
isInt<12>(N1C->getSExtValue()) &&
1764 X.getConstantOperandVal(1) == 32;
1771 RISCV::SRAI,
DL, VT,
X,
1772 CurDAG->getTargetConstant(C2 - Leading,
DL, VT));
1775 CurDAG->getTargetConstant(Leading,
DL, VT));
1787 if (C2 > Leading && Leading > 0 && Trailing > 0) {
1790 CurDAG->getTargetConstant(C2 - Leading,
DL, VT));
1793 CurDAG->getTargetConstant(Leading + Trailing,
DL, VT));
1796 CurDAG->getTargetConstant(Trailing,
DL, VT));
1809 !(C1 == 0xffff && Subtarget->hasStdExtZbb()) &&
1810 !(C1 == 0xffffffff && Subtarget->hasStdExtZba())) {
1830 if (!N1C || !N1C->hasOneUse())
1851 (C2 == UINT64_C(0xFFFF) && Subtarget->hasStdExtZbb());
1853 IsANDIOrZExt |= C2 == UINT64_C(0xFFFF) && Subtarget->hasVendorXTHeadBb();
1858 bool IsZExtW = C2 == UINT64_C(0xFFFFFFFF) && Subtarget->hasStdExtZba();
1860 IsZExtW |= C2 == UINT64_C(0xFFFFFFFF) && Subtarget->hasVendorXTHeadBb();
1867 unsigned XLen = Subtarget->getXLen();
1873 unsigned ConstantShift = XLen - LeadingZeros;
1877 uint64_t ShiftedC1 = C1 << ConstantShift;
1886 CurDAG->getTargetConstant(LeadingZeros,
DL, VT));
1894 case RISCVISD::WMULSU:
1895 case RISCVISD::WADDU:
1896 case RISCVISD::WSUBU: {
1897 assert(Subtarget->hasStdExtP() && !Subtarget->is64Bit() && VT == MVT::i32 &&
1898 "Unexpected opcode");
1901 switch (
Node->getOpcode()) {
1910 case RISCVISD::WMULSU:
1911 Opc = RISCV::WMULSU;
1913 case RISCVISD::WADDU:
1916 case RISCVISD::WSUBU:
1922 Opc,
DL, MVT::Untyped,
Node->getOperand(0),
Node->getOperand(1));
1930 case RISCVISD::WSLL:
1931 case RISCVISD::WSLA: {
1933 assert(Subtarget->hasStdExtP() && !Subtarget->is64Bit() && VT == MVT::i32 &&
1934 "Unexpected opcode");
1936 bool IsSigned =
Node->getOpcode() == RISCVISD::WSLA;
1943 if (ShAmtC && ShAmtC->getZExtValue() < 64) {
1944 Opc = IsSigned ? RISCV::WSLAI : RISCV::WSLLI;
1945 ShAmt =
CurDAG->getTargetConstant(ShAmtC->getZExtValue(),
DL, XLenVT);
1947 Opc = IsSigned ? RISCV::WSLA : RISCV::WSLL;
1951 Node->getOperand(0), ShAmt);
1963 if (Subtarget->hasVendorXCVmem() && !Subtarget->is64Bit()) {
1973 bool Simm12 =
false;
1974 bool SignExtend = Load->getExtensionType() ==
ISD::SEXTLOAD;
1977 int ConstantVal = ConstantOffset->getSExtValue();
1984 unsigned Opcode = 0;
1985 switch (Load->getMemoryVT().getSimpleVT().SimpleTy) {
1987 if (Simm12 && SignExtend)
1988 Opcode = RISCV::CV_LB_ri_inc;
1989 else if (Simm12 && !SignExtend)
1990 Opcode = RISCV::CV_LBU_ri_inc;
1991 else if (!Simm12 && SignExtend)
1992 Opcode = RISCV::CV_LB_rr_inc;
1994 Opcode = RISCV::CV_LBU_rr_inc;
1997 if (Simm12 && SignExtend)
1998 Opcode = RISCV::CV_LH_ri_inc;
1999 else if (Simm12 && !SignExtend)
2000 Opcode = RISCV::CV_LHU_ri_inc;
2001 else if (!Simm12 && SignExtend)
2002 Opcode = RISCV::CV_LH_rr_inc;
2004 Opcode = RISCV::CV_LHU_rr_inc;
2008 Opcode = RISCV::CV_LW_ri_inc;
2010 Opcode = RISCV::CV_LW_rr_inc;
2025 case RISCVISD::LD_RV32: {
2026 assert(Subtarget->hasStdExtZilsd() &&
"LD_RV32 is only used with Zilsd");
2035 RISCV::LD_RV32,
DL, {MVT::Untyped, MVT::Other},
Ops);
2044 case RISCVISD::SD_RV32: {
2056 RegPair =
CurDAG->getRegister(RISCV::X0_Pair, MVT::Untyped);
2068 case RISCVISD::ADDD:
2076 case RISCVISD::SUBD:
2077 case RISCVISD::PPAIRE_DB:
2078 case RISCVISD::WADDAU:
2079 case RISCVISD::WSUBAU:
2080 case RISCVISD::WADDA:
2081 case RISCVISD::WSUBA: {
2082 assert(!Subtarget->is64Bit() &&
"Unexpected opcode");
2084 (
Node->getOpcode() != RISCVISD::PPAIRE_DB || Subtarget->hasStdExtP()) &&
2085 "Unexpected opcode");
2092 Op0 =
CurDAG->getRegister(RISCV::X0_Pair, MVT::Untyped);
2101 if (Opcode == RISCVISD::WADDAU || Opcode == RISCVISD::WSUBAU ||
2102 Opcode == RISCVISD::WADDA || Opcode == RISCVISD::WSUBA) {
2109 case RISCVISD::WADDAU:
2110 Opc = RISCV::WADDAU;
2112 case RISCVISD::WSUBAU:
2113 Opc = RISCV::WSUBAU;
2115 case RISCVISD::WADDA:
2118 case RISCVISD::WSUBA:
2122 New =
CurDAG->getMachineNode(
Opc,
DL, MVT::Untyped, Op0, Op1Lo, Op1Hi);
2130 case RISCVISD::ADDD:
2133 case RISCVISD::SUBD:
2136 case RISCVISD::PPAIRE_DB:
2137 Opc = RISCV::PPAIRE_DB;
2140 New =
CurDAG->getMachineNode(
Opc,
DL, MVT::Untyped, Op0, Op1);
2150 unsigned IntNo =
Node->getConstantOperandVal(0);
2155 case Intrinsic::riscv_vmsgeu:
2156 case Intrinsic::riscv_vmsge: {
2159 bool IsUnsigned = IntNo == Intrinsic::riscv_vmsgeu;
2160 bool IsCmpConstant =
false;
2161 bool IsCmpMinimum =
false;
2169 IsCmpConstant =
true;
2170 CVal =
C->getSExtValue();
2171 if (CVal >= -15 && CVal <= 16) {
2172 if (!IsUnsigned || CVal != 0)
2174 IsCmpMinimum =
true;
2178 IsCmpMinimum =
true;
2181 unsigned VMSLTOpcode, VMNANDOpcode, VMSetOpcode, VMSGTOpcode;
2185#define CASE_VMSLT_OPCODES(lmulenum, suffix) \
2186 case RISCVVType::lmulenum: \
2187 VMSLTOpcode = IsUnsigned ? RISCV::PseudoVMSLTU_VX_##suffix \
2188 : RISCV::PseudoVMSLT_VX_##suffix; \
2189 VMSGTOpcode = IsUnsigned ? RISCV::PseudoVMSGTU_VX_##suffix \
2190 : RISCV::PseudoVMSGT_VX_##suffix; \
2199#undef CASE_VMSLT_OPCODES
2205#define CASE_VMNAND_VMSET_OPCODES(lmulenum, suffix) \
2206 case RISCVVType::lmulenum: \
2207 VMNANDOpcode = RISCV::PseudoVMNAND_MM_##suffix; \
2208 VMSetOpcode = RISCV::PseudoVMSET_M_##suffix; \
2217#undef CASE_VMNAND_VMSET_OPCODES
2228 CurDAG->getMachineNode(VMSetOpcode,
DL, VT, VL, MaskSEW));
2232 if (IsCmpConstant) {
2237 {Src1, Imm, VL, SEW}));
2244 CurDAG->getMachineNode(VMSLTOpcode,
DL, VT, {Src1, Src2, VL, SEW}),
2247 {Cmp, Cmp, VL, MaskSEW}));
2250 case Intrinsic::riscv_vmsgeu_mask:
2251 case Intrinsic::riscv_vmsge_mask: {
2254 bool IsUnsigned = IntNo == Intrinsic::riscv_vmsgeu_mask;
2255 bool IsCmpConstant =
false;
2256 bool IsCmpMinimum =
false;
2264 IsCmpConstant =
true;
2265 CVal =
C->getSExtValue();
2266 if (CVal >= -15 && CVal <= 16) {
2267 if (!IsUnsigned || CVal != 0)
2269 IsCmpMinimum =
true;
2273 IsCmpMinimum =
true;
2276 unsigned VMSLTOpcode, VMSLTMaskOpcode, VMXOROpcode, VMANDNOpcode,
2277 VMOROpcode, VMSGTMaskOpcode;
2281#define CASE_VMSLT_OPCODES(lmulenum, suffix) \
2282 case RISCVVType::lmulenum: \
2283 VMSLTOpcode = IsUnsigned ? RISCV::PseudoVMSLTU_VX_##suffix \
2284 : RISCV::PseudoVMSLT_VX_##suffix; \
2285 VMSLTMaskOpcode = IsUnsigned ? RISCV::PseudoVMSLTU_VX_##suffix##_MASK \
2286 : RISCV::PseudoVMSLT_VX_##suffix##_MASK; \
2287 VMSGTMaskOpcode = IsUnsigned ? RISCV::PseudoVMSGTU_VX_##suffix##_MASK \
2288 : RISCV::PseudoVMSGT_VX_##suffix##_MASK; \
2297#undef CASE_VMSLT_OPCODES
2303#define CASE_VMXOR_VMANDN_VMOR_OPCODES(lmulenum, suffix) \
2304 case RISCVVType::lmulenum: \
2305 VMXOROpcode = RISCV::PseudoVMXOR_MM_##suffix; \
2306 VMANDNOpcode = RISCV::PseudoVMANDN_MM_##suffix; \
2307 VMOROpcode = RISCV::PseudoVMOR_MM_##suffix; \
2316#undef CASE_VMXOR_VMANDN_VMOR_OPCODES
2330 if (Mask == MaskedOff) {
2335 CurDAG->getMachineNode(VMOROpcode,
DL, VT,
2336 {Mask, MaskedOff, VL, MaskSEW}));
2343 if (Mask == MaskedOff) {
2345 CurDAG->getMachineNode(VMSLTOpcode,
DL, VT, {Src1, Src2, VL, SEW}),
2348 {Mask, Cmp, VL, MaskSEW}));
2355 if (IsCmpConstant) {
2360 VMSGTMaskOpcode,
DL, VT,
2361 {MaskedOff, Src1, Imm, Mask, VL, SEW, PolicyOp}));
2371 {MaskedOff, Src1, Src2, Mask,
2372 VL, SEW, PolicyOp}),
2376 {Cmp, Mask, VL, MaskSEW}));
2379 case Intrinsic::riscv_vsetvli:
2380 case Intrinsic::riscv_vsetvlimax:
2382 case Intrinsic::riscv_sf_vsettnt:
2383 case Intrinsic::riscv_sf_vsettm:
2384 case Intrinsic::riscv_sf_vsettk:
2390 unsigned IntNo =
Node->getConstantOperandVal(1);
2395 case Intrinsic::riscv_vlseg2:
2396 case Intrinsic::riscv_vlseg3:
2397 case Intrinsic::riscv_vlseg4:
2398 case Intrinsic::riscv_vlseg5:
2399 case Intrinsic::riscv_vlseg6:
2400 case Intrinsic::riscv_vlseg7:
2401 case Intrinsic::riscv_vlseg8: {
2406 case Intrinsic::riscv_vlseg2_mask:
2407 case Intrinsic::riscv_vlseg3_mask:
2408 case Intrinsic::riscv_vlseg4_mask:
2409 case Intrinsic::riscv_vlseg5_mask:
2410 case Intrinsic::riscv_vlseg6_mask:
2411 case Intrinsic::riscv_vlseg7_mask:
2412 case Intrinsic::riscv_vlseg8_mask: {
2417 case Intrinsic::riscv_vlsseg2:
2418 case Intrinsic::riscv_vlsseg3:
2419 case Intrinsic::riscv_vlsseg4:
2420 case Intrinsic::riscv_vlsseg5:
2421 case Intrinsic::riscv_vlsseg6:
2422 case Intrinsic::riscv_vlsseg7:
2423 case Intrinsic::riscv_vlsseg8: {
2428 case Intrinsic::riscv_vlsseg2_mask:
2429 case Intrinsic::riscv_vlsseg3_mask:
2430 case Intrinsic::riscv_vlsseg4_mask:
2431 case Intrinsic::riscv_vlsseg5_mask:
2432 case Intrinsic::riscv_vlsseg6_mask:
2433 case Intrinsic::riscv_vlsseg7_mask:
2434 case Intrinsic::riscv_vlsseg8_mask: {
2439 case Intrinsic::riscv_vloxseg2:
2440 case Intrinsic::riscv_vloxseg3:
2441 case Intrinsic::riscv_vloxseg4:
2442 case Intrinsic::riscv_vloxseg5:
2443 case Intrinsic::riscv_vloxseg6:
2444 case Intrinsic::riscv_vloxseg7:
2445 case Intrinsic::riscv_vloxseg8:
2449 case Intrinsic::riscv_vluxseg2:
2450 case Intrinsic::riscv_vluxseg3:
2451 case Intrinsic::riscv_vluxseg4:
2452 case Intrinsic::riscv_vluxseg5:
2453 case Intrinsic::riscv_vluxseg6:
2454 case Intrinsic::riscv_vluxseg7:
2455 case Intrinsic::riscv_vluxseg8:
2459 case Intrinsic::riscv_vloxseg2_mask:
2460 case Intrinsic::riscv_vloxseg3_mask:
2461 case Intrinsic::riscv_vloxseg4_mask:
2462 case Intrinsic::riscv_vloxseg5_mask:
2463 case Intrinsic::riscv_vloxseg6_mask:
2464 case Intrinsic::riscv_vloxseg7_mask:
2465 case Intrinsic::riscv_vloxseg8_mask:
2469 case Intrinsic::riscv_vluxseg2_mask:
2470 case Intrinsic::riscv_vluxseg3_mask:
2471 case Intrinsic::riscv_vluxseg4_mask:
2472 case Intrinsic::riscv_vluxseg5_mask:
2473 case Intrinsic::riscv_vluxseg6_mask:
2474 case Intrinsic::riscv_vluxseg7_mask:
2475 case Intrinsic::riscv_vluxseg8_mask:
2479 case Intrinsic::riscv_vlseg8ff:
2480 case Intrinsic::riscv_vlseg7ff:
2481 case Intrinsic::riscv_vlseg6ff:
2482 case Intrinsic::riscv_vlseg5ff:
2483 case Intrinsic::riscv_vlseg4ff:
2484 case Intrinsic::riscv_vlseg3ff:
2485 case Intrinsic::riscv_vlseg2ff: {
2489 case Intrinsic::riscv_vlseg8ff_mask:
2490 case Intrinsic::riscv_vlseg7ff_mask:
2491 case Intrinsic::riscv_vlseg6ff_mask:
2492 case Intrinsic::riscv_vlseg5ff_mask:
2493 case Intrinsic::riscv_vlseg4ff_mask:
2494 case Intrinsic::riscv_vlseg3ff_mask:
2495 case Intrinsic::riscv_vlseg2ff_mask: {
2499 case Intrinsic::riscv_vloxei:
2500 case Intrinsic::riscv_vloxei_mask:
2501 case Intrinsic::riscv_vluxei:
2502 case Intrinsic::riscv_vluxei_mask: {
2503 bool IsMasked = IntNo == Intrinsic::riscv_vloxei_mask ||
2504 IntNo == Intrinsic::riscv_vluxei_mask;
2505 bool IsOrdered = IntNo == Intrinsic::riscv_vloxei ||
2506 IntNo == Intrinsic::riscv_vloxei_mask;
2508 MVT VT =
Node->getSimpleValueType(0);
2521 "Element count mismatch");
2526 if (IndexLog2EEW == 6 && !Subtarget->is64Bit()) {
2528 "index values when XLEN=32");
2531 IsMasked, IsOrdered, IndexLog2EEW,
static_cast<unsigned>(LMUL),
2532 static_cast<unsigned>(IndexLMUL));
2534 CurDAG->getMachineNode(
P->Pseudo,
DL,
Node->getVTList(), Operands);
2541 case Intrinsic::riscv_vlm:
2542 case Intrinsic::riscv_vle:
2543 case Intrinsic::riscv_vle_mask:
2544 case Intrinsic::riscv_vlse:
2545 case Intrinsic::riscv_vlse_mask: {
2546 bool IsMasked = IntNo == Intrinsic::riscv_vle_mask ||
2547 IntNo == Intrinsic::riscv_vlse_mask;
2549 IntNo == Intrinsic::riscv_vlse || IntNo == Intrinsic::riscv_vlse_mask;
2551 MVT VT =
Node->getSimpleValueType(0);
2560 bool HasPassthruOperand = IntNo != Intrinsic::riscv_vlm;
2563 if (HasPassthruOperand)
2569 CurDAG->getMachineNode(TargetOpcode::IMPLICIT_DEF,
DL, VT);
2577 RISCV::getVLEPseudo(IsMasked, IsStrided,
false, Log2SEW,
2578 static_cast<unsigned>(LMUL));
2580 CurDAG->getMachineNode(
P->Pseudo,
DL,
Node->getVTList(), Operands);
2587 case Intrinsic::riscv_vleff:
2588 case Intrinsic::riscv_vleff_mask: {
2589 bool IsMasked = IntNo == Intrinsic::riscv_vleff_mask;
2591 MVT VT =
Node->getSimpleValueType(0);
2603 RISCV::getVLEPseudo(IsMasked,
false,
true,
2604 Log2SEW,
static_cast<unsigned>(LMUL));
2606 P->Pseudo,
DL,
Node->getVTList(), Operands);
2612 case Intrinsic::riscv_nds_vln:
2613 case Intrinsic::riscv_nds_vln_mask:
2614 case Intrinsic::riscv_nds_vlnu:
2615 case Intrinsic::riscv_nds_vlnu_mask: {
2616 bool IsMasked = IntNo == Intrinsic::riscv_nds_vln_mask ||
2617 IntNo == Intrinsic::riscv_nds_vlnu_mask;
2618 bool IsUnsigned = IntNo == Intrinsic::riscv_nds_vlnu ||
2619 IntNo == Intrinsic::riscv_nds_vlnu_mask;
2621 MVT VT =
Node->getSimpleValueType(0);
2633 IsMasked, IsUnsigned, Log2SEW,
static_cast<unsigned>(LMUL));
2635 CurDAG->getMachineNode(
P->Pseudo,
DL,
Node->getVTList(), Operands);
2638 CurDAG->setNodeMemRefs(Load, {
MemOp->getMemOperand()});
2647 unsigned IntNo =
Node->getConstantOperandVal(1);
2649 case Intrinsic::riscv_vsseg2:
2650 case Intrinsic::riscv_vsseg3:
2651 case Intrinsic::riscv_vsseg4:
2652 case Intrinsic::riscv_vsseg5:
2653 case Intrinsic::riscv_vsseg6:
2654 case Intrinsic::riscv_vsseg7:
2655 case Intrinsic::riscv_vsseg8: {
2660 case Intrinsic::riscv_vsseg2_mask:
2661 case Intrinsic::riscv_vsseg3_mask:
2662 case Intrinsic::riscv_vsseg4_mask:
2663 case Intrinsic::riscv_vsseg5_mask:
2664 case Intrinsic::riscv_vsseg6_mask:
2665 case Intrinsic::riscv_vsseg7_mask:
2666 case Intrinsic::riscv_vsseg8_mask: {
2671 case Intrinsic::riscv_vssseg2:
2672 case Intrinsic::riscv_vssseg3:
2673 case Intrinsic::riscv_vssseg4:
2674 case Intrinsic::riscv_vssseg5:
2675 case Intrinsic::riscv_vssseg6:
2676 case Intrinsic::riscv_vssseg7:
2677 case Intrinsic::riscv_vssseg8: {
2682 case Intrinsic::riscv_vssseg2_mask:
2683 case Intrinsic::riscv_vssseg3_mask:
2684 case Intrinsic::riscv_vssseg4_mask:
2685 case Intrinsic::riscv_vssseg5_mask:
2686 case Intrinsic::riscv_vssseg6_mask:
2687 case Intrinsic::riscv_vssseg7_mask:
2688 case Intrinsic::riscv_vssseg8_mask: {
2693 case Intrinsic::riscv_vsoxseg2:
2694 case Intrinsic::riscv_vsoxseg3:
2695 case Intrinsic::riscv_vsoxseg4:
2696 case Intrinsic::riscv_vsoxseg5:
2697 case Intrinsic::riscv_vsoxseg6:
2698 case Intrinsic::riscv_vsoxseg7:
2699 case Intrinsic::riscv_vsoxseg8:
2703 case Intrinsic::riscv_vsuxseg2:
2704 case Intrinsic::riscv_vsuxseg3:
2705 case Intrinsic::riscv_vsuxseg4:
2706 case Intrinsic::riscv_vsuxseg5:
2707 case Intrinsic::riscv_vsuxseg6:
2708 case Intrinsic::riscv_vsuxseg7:
2709 case Intrinsic::riscv_vsuxseg8:
2713 case Intrinsic::riscv_vsoxseg2_mask:
2714 case Intrinsic::riscv_vsoxseg3_mask:
2715 case Intrinsic::riscv_vsoxseg4_mask:
2716 case Intrinsic::riscv_vsoxseg5_mask:
2717 case Intrinsic::riscv_vsoxseg6_mask:
2718 case Intrinsic::riscv_vsoxseg7_mask:
2719 case Intrinsic::riscv_vsoxseg8_mask:
2723 case Intrinsic::riscv_vsuxseg2_mask:
2724 case Intrinsic::riscv_vsuxseg3_mask:
2725 case Intrinsic::riscv_vsuxseg4_mask:
2726 case Intrinsic::riscv_vsuxseg5_mask:
2727 case Intrinsic::riscv_vsuxseg6_mask:
2728 case Intrinsic::riscv_vsuxseg7_mask:
2729 case Intrinsic::riscv_vsuxseg8_mask:
2733 case Intrinsic::riscv_vsoxei:
2734 case Intrinsic::riscv_vsoxei_mask:
2735 case Intrinsic::riscv_vsuxei:
2736 case Intrinsic::riscv_vsuxei_mask: {
2737 bool IsMasked = IntNo == Intrinsic::riscv_vsoxei_mask ||
2738 IntNo == Intrinsic::riscv_vsuxei_mask;
2739 bool IsOrdered = IntNo == Intrinsic::riscv_vsoxei ||
2740 IntNo == Intrinsic::riscv_vsoxei_mask;
2742 MVT VT =
Node->getOperand(2)->getSimpleValueType(0);
2755 "Element count mismatch");
2760 if (IndexLog2EEW == 6 && !Subtarget->is64Bit()) {
2762 "index values when XLEN=32");
2765 IsMasked, IsOrdered, IndexLog2EEW,
2766 static_cast<unsigned>(LMUL),
static_cast<unsigned>(IndexLMUL));
2768 CurDAG->getMachineNode(
P->Pseudo,
DL,
Node->getVTList(), Operands);
2775 case Intrinsic::riscv_vsm:
2776 case Intrinsic::riscv_vse:
2777 case Intrinsic::riscv_vse_mask:
2778 case Intrinsic::riscv_vsse:
2779 case Intrinsic::riscv_vsse_mask: {
2780 bool IsMasked = IntNo == Intrinsic::riscv_vse_mask ||
2781 IntNo == Intrinsic::riscv_vsse_mask;
2783 IntNo == Intrinsic::riscv_vsse || IntNo == Intrinsic::riscv_vsse_mask;
2785 MVT VT =
Node->getOperand(2)->getSimpleValueType(0);
2797 IsMasked, IsStrided, Log2SEW,
static_cast<unsigned>(LMUL));
2799 CurDAG->getMachineNode(
P->Pseudo,
DL,
Node->getVTList(), Operands);
2805 case Intrinsic::riscv_sf_vc_x_se:
2806 case Intrinsic::riscv_sf_vc_i_se:
2809 case Intrinsic::riscv_sf_vlte8:
2810 case Intrinsic::riscv_sf_vlte16:
2811 case Intrinsic::riscv_sf_vlte32:
2812 case Intrinsic::riscv_sf_vlte64: {
2814 unsigned PseudoInst;
2816 case Intrinsic::riscv_sf_vlte8:
2817 PseudoInst = RISCV::PseudoSF_VLTE8;
2820 case Intrinsic::riscv_sf_vlte16:
2821 PseudoInst = RISCV::PseudoSF_VLTE16;
2824 case Intrinsic::riscv_sf_vlte32:
2825 PseudoInst = RISCV::PseudoSF_VLTE32;
2828 case Intrinsic::riscv_sf_vlte64:
2829 PseudoInst = RISCV::PseudoSF_VLTE64;
2837 Node->getOperand(3),
2838 Node->getOperand(4),
2841 Node->getOperand(0)};
2844 CurDAG->getMachineNode(PseudoInst,
DL,
Node->getVTList(), Operands);
2845 CurDAG->setNodeMemRefs(TileLoad,
2851 case Intrinsic::riscv_sf_mm_s_s:
2852 case Intrinsic::riscv_sf_mm_s_u:
2853 case Intrinsic::riscv_sf_mm_u_s:
2854 case Intrinsic::riscv_sf_mm_u_u:
2855 case Intrinsic::riscv_sf_mm_e5m2_e5m2:
2856 case Intrinsic::riscv_sf_mm_e5m2_e4m3:
2857 case Intrinsic::riscv_sf_mm_e4m3_e5m2:
2858 case Intrinsic::riscv_sf_mm_e4m3_e4m3:
2859 case Intrinsic::riscv_sf_mm_f_f: {
2860 bool HasFRM =
false;
2861 unsigned PseudoInst;
2863 case Intrinsic::riscv_sf_mm_s_s:
2864 PseudoInst = RISCV::PseudoSF_MM_S_S;
2866 case Intrinsic::riscv_sf_mm_s_u:
2867 PseudoInst = RISCV::PseudoSF_MM_S_U;
2869 case Intrinsic::riscv_sf_mm_u_s:
2870 PseudoInst = RISCV::PseudoSF_MM_U_S;
2872 case Intrinsic::riscv_sf_mm_u_u:
2873 PseudoInst = RISCV::PseudoSF_MM_U_U;
2875 case Intrinsic::riscv_sf_mm_e5m2_e5m2:
2876 PseudoInst = RISCV::PseudoSF_MM_E5M2_E5M2;
2879 case Intrinsic::riscv_sf_mm_e5m2_e4m3:
2880 PseudoInst = RISCV::PseudoSF_MM_E5M2_E4M3;
2883 case Intrinsic::riscv_sf_mm_e4m3_e5m2:
2884 PseudoInst = RISCV::PseudoSF_MM_E4M3_E5M2;
2887 case Intrinsic::riscv_sf_mm_e4m3_e4m3:
2888 PseudoInst = RISCV::PseudoSF_MM_E4M3_E4M3;
2891 case Intrinsic::riscv_sf_mm_f_f:
2892 if (
Node->getOperand(3).getValueType().getScalarType() == MVT::bf16)
2893 PseudoInst = RISCV::PseudoSF_MM_F_F_ALT;
2895 PseudoInst = RISCV::PseudoSF_MM_F_F;
2911 if (IntNo == Intrinsic::riscv_sf_mm_f_f && Log2SEW == 5 &&
2920 Operands.append({TmOp, TnOp, TkOp,
2921 CurDAG->getTargetConstant(Log2SEW,
DL, XLenVT), TWidenOp,
2925 CurDAG->getMachineNode(PseudoInst,
DL,
Node->getVTList(), Operands);
2930 case Intrinsic::riscv_sf_vtzero_t: {
2937 auto *NewNode =
CurDAG->getMachineNode(
2938 RISCV::PseudoSF_VTZERO_T,
DL,
Node->getVTList(),
2939 {CurDAG->getRegister(getTileReg(TileNum), XLenVT), Tm, Tn, Log2SEW,
2949 MVT SrcVT =
Node->getOperand(0).getSimpleValueType();
2958 if (Subtarget->hasStdExtP()) {
2960 (VT == MVT::i32 && (SrcVT == MVT::v4i8 || SrcVT == MVT::v2i16)) ||
2961 (SrcVT == MVT::i32 && (VT == MVT::v4i8 || VT == MVT::v2i16));
2963 (VT == MVT::i64 && (SrcVT == MVT::v8i8 || SrcVT == MVT::v4i16 ||
2964 SrcVT == MVT::v2i32)) ||
2965 (SrcVT == MVT::i64 &&
2966 (VT == MVT::v8i8 || VT == MVT::v4i16 || VT == MVT::v2i32));
2967 if (Is32BitCast || Is64BitCast) {
2976 if (!Subtarget->hasStdExtP())
2979 bool IsDoubleWide = Subtarget->isPExtPackedDoubleType(VT);
2981 if (ConstNode->isZero()) {
2982 MCPhysReg X0Reg = IsDoubleWide ? RISCV::X0_Pair : RISCV::X0;
2990 APInt Val = ConstNode->getAPIntValue().
trunc(EltSize);
2995 RISCV::ADDI,
DL, VT,
CurDAG->getRegister(RISCV::X0, VT),
2996 CurDAG->getAllOnesConstant(
DL, XLenVT,
true));
3003 Val = Val.
trunc(16);
3012 Opc = IsDoubleWide ? RISCV::PLI_DB : RISCV::PLI_B;
3013 }
else if (EltSize == 16 &&
isInt<10>(Imm)) {
3014 Opc = IsDoubleWide ? RISCV::PLI_DH : RISCV::PLI_H;
3015 }
else if (!IsDoubleWide && EltSize == 32 &&
isInt<10>(Imm)) {
3018 Opc = IsDoubleWide ? RISCV::PLUI_DH : RISCV::PLUI_H;
3021 Opc = RISCV::PLUI_W;
3027 Opc,
DL, VT,
CurDAG->getSignedTargetConstant(Imm,
DL, XLenVT));
3036 if (Subtarget->hasStdExtP()) {
3037 MVT SrcVT =
Node->getOperand(0).getSimpleValueType();
3038 if ((VT == MVT::v2i32 && SrcVT == MVT::i64) ||
3039 (VT == MVT::v4i8 && SrcVT == MVT::i32)) {
3047 case RISCVISD::TUPLE_INSERT: {
3051 auto Idx =
Node->getConstantOperandVal(2);
3055 MVT SubVecContainerVT = SubVecVT;
3058 SubVecContainerVT =
TLI.getContainerForFixedLengthVector(SubVecVT);
3060 [[maybe_unused]]
bool ExactlyVecRegSized =
3062 .isKnownMultipleOf(Subtarget->expandVScale(VecRegSize));
3064 .getKnownMinValue()));
3065 assert(Idx == 0 && (ExactlyVecRegSized || V.isUndef()));
3067 MVT ContainerVT = VT;
3069 ContainerVT =
TLI.getContainerForFixedLengthVector(VT);
3071 const auto *
TRI = Subtarget->getRegisterInfo();
3073 std::tie(SubRegIdx, Idx) =
3075 ContainerVT, SubVecContainerVT, Idx,
TRI);
3085 [[maybe_unused]]
bool IsSubVecPartReg =
3089 assert((V.getValueType().isRISCVVectorTuple() || !IsSubVecPartReg ||
3091 "Expecting lowering to have created legal INSERT_SUBVECTORs when "
3092 "the subvector is smaller than a full-sized register");
3096 if (SubRegIdx == RISCV::NoSubRegister) {
3097 unsigned InRegClassID =
3101 "Unexpected subvector extraction");
3103 SDNode *NewNode =
CurDAG->getMachineNode(TargetOpcode::COPY_TO_REGCLASS,
3109 SDValue Insert =
CurDAG->getTargetInsertSubreg(SubRegIdx,
DL, VT, V, SubV);
3114 case RISCVISD::TUPLE_EXTRACT: {
3116 auto Idx =
Node->getConstantOperandVal(1);
3117 MVT InVT = V.getSimpleValueType();
3121 if (Subtarget->hasStdExtP() && !Subtarget->is64Bit() &&
3122 ((InVT == MVT::v4i16 && VT == MVT::v2i16) ||
3123 (InVT == MVT::v8i8 && VT == MVT::v4i8))) {
3125 if (Idx != 0 && Idx != NumElts)
3128 unsigned SubRegIdx = Idx == 0 ? RISCV::sub_gpr_even : RISCV::sub_gpr_odd;
3129 SDValue Extract =
CurDAG->getTargetExtractSubreg(SubRegIdx,
DL, VT, V);
3137 MVT SubVecContainerVT = VT;
3141 SubVecContainerVT =
TLI.getContainerForFixedLengthVector(VT);
3144 InVT =
TLI.getContainerForFixedLengthVector(InVT);
3146 const auto *
TRI = Subtarget->getRegisterInfo();
3148 std::tie(SubRegIdx, Idx) =
3150 InVT, SubVecContainerVT, Idx,
TRI);
3160 if (SubRegIdx == RISCV::NoSubRegister) {
3164 "Unexpected subvector extraction");
3167 CurDAG->getMachineNode(TargetOpcode::COPY_TO_REGCLASS,
DL, VT, V, RC);
3172 SDValue Extract =
CurDAG->getTargetExtractSubreg(SubRegIdx,
DL, VT, V);
3176 case RISCVISD::VMV_S_X_VL:
3177 case RISCVISD::VFMV_S_F_VL:
3178 case RISCVISD::VMV_V_X_VL:
3179 case RISCVISD::VFMV_V_F_VL: {
3181 bool IsScalarMove =
Node->getOpcode() == RISCVISD::VMV_S_X_VL ||
3182 Node->getOpcode() == RISCVISD::VFMV_S_F_VL;
3183 if (!
Node->getOperand(0).isUndef())
3189 if (!Ld || Ld->isIndexed())
3191 EVT MemVT = Ld->getMemoryVT();
3217 if (IsStrided && !Subtarget->hasOptimizedZeroStrideLoad())
3221 SDValue(
CurDAG->getMachineNode(TargetOpcode::IMPLICIT_DEF,
DL, VT), 0),
3227 Operands.
append({VL, SEW, PolicyOp, Ld->getChain()});
3231 false, IsStrided,
false,
3232 Log2SEW,
static_cast<unsigned>(LMUL));
3234 CurDAG->getMachineNode(
P->Pseudo,
DL, {VT, MVT::Other}, Operands);
3238 CurDAG->setNodeMemRefs(Load, {Ld->getMemOperand()});
3243 case RISCVISD::LPAD_CALL:
3244 case RISCVISD::LPAD_CALL_INDIRECT: {
3245 bool IsIndirect = Opcode == RISCVISD::LPAD_CALL_INDIRECT;
3246 unsigned PseudoOpc = IsIndirect ? RISCV::PseudoCALLIndirectLpadAlign
3247 : RISCV::PseudoCALLLpadAlign;
3253 "in unsigned 20-bits");
3258 Ops.push_back(
Node->getOperand(1));
3259 Ops.push_back(
CurDAG->getTargetConstant(LpadLabel,
DL, XLenVT));
3260 Ops.push_back(
Node->getOperand(0));
3261 if (
Node->getGluedNode())
3262 Ops.push_back(
Node->getOperand(
Node->getNumOperands() - 1));
3271 if (Subtarget->hasVendorXMIPSCBOP())
3274 unsigned Locality =
Node->getConstantOperandVal(3);
3282 int NontemporalLevel = 0;
3285 NontemporalLevel = 3;
3288 NontemporalLevel = 1;
3291 NontemporalLevel = 0;
3297 if (NontemporalLevel & 0b1)
3299 if (NontemporalLevel & 0b10)