1100 if (
Node->isMachineOpcode()) {
1102 Node->setNodeId(-1);
1108 unsigned Opcode =
Node->getOpcode();
1109 MVT XLenVT = Subtarget->getXLenVT();
1111 MVT VT =
Node->getSimpleValueType(0);
1113 bool HasBitTest = Subtarget->hasBEXTILike();
1117 assert(VT == Subtarget->getXLenVT() &&
"Unexpected VT");
1119 if (ConstNode->isZero()) {
1121 CurDAG->getCopyFromReg(
CurDAG->getEntryNode(),
DL, RISCV::X0, VT);
1125 int64_t Imm = ConstNode->getSExtValue();
1140 if (Subtarget->hasStdExtP() && !
isInt<12>(Imm) &&
1161 Imm = ((
uint64_t)Imm << 32) | (Imm & 0xFFFFFFFF);
1171 bool Is64Bit = Subtarget->is64Bit();
1172 bool HasZdinx = Subtarget->hasStdExtZdinx();
1174 bool NegZeroF64 = APF.
isNegZero() && VT == MVT::f64;
1179 if (VT == MVT::f64 && HasZdinx && !Is64Bit)
1180 Imm =
CurDAG->getRegister(RISCV::X0_Pair, MVT::f64);
1182 Imm =
CurDAG->getRegister(RISCV::X0, XLenVT);
1193 assert(Subtarget->hasStdExtZfbfmin());
1194 Opc = RISCV::FMV_H_X;
1197 Opc = Subtarget->hasStdExtZhinxmin() ? RISCV::COPY : RISCV::FMV_H_X;
1200 Opc = Subtarget->hasStdExtZfinx() ? RISCV::COPY : RISCV::FMV_W_X;
1205 assert((Subtarget->is64Bit() || APF.
isZero()) &&
"Unexpected constant");
1209 Opc = Is64Bit ? RISCV::FMV_D_X : RISCV::FCVT_D_W;
1214 if (VT.
SimpleTy == MVT::f16 &&
Opc == RISCV::COPY) {
1216 CurDAG->getTargetExtractSubreg(RISCV::sub_16,
DL, VT, Imm).getNode();
1217 }
else if (VT.
SimpleTy == MVT::f32 &&
Opc == RISCV::COPY) {
1219 CurDAG->getTargetExtractSubreg(RISCV::sub_32,
DL, VT, Imm).getNode();
1220 }
else if (
Opc == RISCV::FCVT_D_W_IN32X ||
Opc == RISCV::FCVT_D_W)
1221 Res =
CurDAG->getMachineNode(
1229 Opc = RISCV::FSGNJN_D;
1231 Opc = Is64Bit ? RISCV::FSGNJN_D_INX : RISCV::FSGNJN_D_IN32X;
1239 case RISCVISD::BuildGPRPair:
1240 case RISCVISD::BuildPairF64: {
1241 if (Opcode == RISCVISD::BuildPairF64 && !Subtarget->hasStdExtZdinx())
1244 assert((!Subtarget->is64Bit() || Opcode == RISCVISD::BuildGPRPair) &&
1245 "BuildPairF64 only handled here on rv32i_zdinx");
1252 case RISCVISD::SplitGPRPair:
1253 case RISCVISD::SplitF64: {
1254 if (Subtarget->hasStdExtZdinx() || Opcode != RISCVISD::SplitF64) {
1255 assert((!Subtarget->is64Bit() || Opcode == RISCVISD::SplitGPRPair) &&
1256 "SplitF64 only handled here on rv32i_zdinx");
1260 Node->getValueType(0),
1261 Node->getOperand(0));
1267 RISCV::sub_gpr_odd,
DL,
Node->getValueType(1),
Node->getOperand(0));
1275 assert(Opcode != RISCVISD::SplitGPRPair &&
1276 "SplitGPRPair should already be handled");
1278 if (!Subtarget->hasStdExtZfa())
1280 assert(Subtarget->hasStdExtD() && !Subtarget->is64Bit() &&
1281 "Unexpected subtarget");
1286 Node->getOperand(0));
1291 Node->getOperand(0));
1306 unsigned ShAmt = N1C->getZExtValue();
1310 unsigned XLen = Subtarget->getXLen();
1313 if (ShAmt <= 32 && TrailingZeros > 0 && LeadingZeros == 32) {
1318 CurDAG->getTargetConstant(TrailingZeros,
DL, VT));
1321 CurDAG->getTargetConstant(TrailingZeros + ShAmt,
DL, VT));
1325 if (TrailingZeros == 0 && LeadingZeros > ShAmt &&
1326 XLen - LeadingZeros > 11 && LeadingZeros != 32) {
1337 CurDAG->getTargetConstant(LeadingZeros,
DL, VT));
1340 CurDAG->getTargetConstant(LeadingZeros - ShAmt,
DL, VT));
1354 unsigned ShAmt = N1C->getZExtValue();
1360 unsigned XLen = Subtarget->getXLen();
1363 if (LeadingZeros == 32 && TrailingZeros > ShAmt) {
1366 CurDAG->getTargetConstant(TrailingZeros,
DL, VT));
1369 CurDAG->getTargetConstant(TrailingZeros - ShAmt,
DL, VT));
1386 if (ShAmt >= TrailingOnes)
1389 if (TrailingOnes == 32) {
1391 Subtarget->is64Bit() ? RISCV::SRLIW : RISCV::SRLI,
DL, VT,
1402 if (HasBitTest && ShAmt + 1 == TrailingOnes) {
1404 Subtarget->hasStdExtZbs() ? RISCV::BEXTI : RISCV::TH_TST,
DL, VT,
1410 const unsigned Msb = TrailingOnes - 1;
1411 const unsigned Lsb = ShAmt;
1415 unsigned LShAmt = Subtarget->getXLen() - TrailingOnes;
1418 CurDAG->getTargetConstant(LShAmt,
DL, VT));
1421 CurDAG->getTargetConstant(LShAmt + ShAmt,
DL, VT));
1446 unsigned ShAmt = N1C->getZExtValue();
1450 if (ExtSize >= 32 || ShAmt >= ExtSize)
1452 unsigned LShAmt = Subtarget->getXLen() - ExtSize;
1455 CurDAG->getTargetConstant(LShAmt,
DL, VT));
1458 CurDAG->getTargetConstant(LShAmt + ShAmt,
DL, VT));
1477 unsigned ShAmt = ShAmtC->getZExtValue();
1478 unsigned XLen = Subtarget->getXLen();
1481 if (ExtSize >= 32 || ShAmt >= XLen - ExtSize)
1484 unsigned LShAmt = XLen - ExtSize - ShAmt;
1487 CurDAG->getTargetConstant(LShAmt,
DL, VT));
1490 CurDAG->getTargetConstant(XLen - ExtSize,
DL, VT));
1517 unsigned C2 =
C->getZExtValue();
1518 unsigned XLen = Subtarget->getXLen();
1519 assert((C2 > 0 && C2 < XLen) &&
"Unexpected shift amount!");
1527 bool IsCANDI =
isInt<6>(N1C->getSExtValue());
1539 bool OneUseOrZExtW = N0.
hasOneUse() || C1 == UINT64_C(0xFFFFFFFF);
1549 if (C2 + 32 == Leading) {
1551 RISCV::SRLIW,
DL, VT,
X,
CurDAG->getTargetConstant(C2,
DL, VT));
1561 if (C2 >= 32 && (Leading - C2) == 1 && N0.
hasOneUse() &&
1565 CurDAG->getMachineNode(RISCV::SRAIW,
DL, VT,
X.getOperand(0),
1566 CurDAG->getTargetConstant(31,
DL, VT));
1568 RISCV::SRLIW,
DL, VT,
SDValue(SRAIW, 0),
1569 CurDAG->getTargetConstant(Leading - 32,
DL, VT));
1582 const unsigned Lsb = C2;
1588 bool Skip = Subtarget->hasStdExtZba() && Leading == 32 &&
1592 Skip |= HasBitTest && Leading == XLen - 1;
1593 if (OneUseOrZExtW && !Skip) {
1595 RISCV::SLLI,
DL, VT,
X,
1596 CurDAG->getTargetConstant(Leading - C2,
DL, VT));
1599 CurDAG->getTargetConstant(Leading,
DL, VT));
1611 if (C2 + Leading < XLen &&
1614 if ((XLen - (C2 + Leading)) == 32 && Subtarget->hasStdExtZba()) {
1616 CurDAG->getMachineNode(RISCV::SLLI_UW,
DL, VT,
X,
1617 CurDAG->getTargetConstant(C2,
DL, VT));
1630 const unsigned Msb = XLen - Leading - 1;
1631 const unsigned Lsb = C2;
1635 if (OneUseOrZExtW && !IsCANDI) {
1637 if (Subtarget->hasStdExtZbkb() && C1 == 0xff00 && C2 == 8) {
1639 RISCV::PACKH,
DL, VT,
1640 CurDAG->getRegister(RISCV::X0, Subtarget->getXLenVT()),
X);
1646 RISCV::SLLI,
DL, VT,
X,
1647 CurDAG->getTargetConstant(C2 + Leading,
DL, VT));
1650 CurDAG->getTargetConstant(Leading,
DL, VT));
1662 if (Leading == C2 && C2 + Trailing < XLen && OneUseOrZExtW &&
1664 unsigned SrliOpc = RISCV::SRLI;
1668 X.getConstantOperandVal(1) == UINT64_C(0xFFFFFFFF)) {
1669 SrliOpc = RISCV::SRLIW;
1670 X =
X.getOperand(0);
1674 CurDAG->getTargetConstant(C2 + Trailing,
DL, VT));
1677 CurDAG->getTargetConstant(Trailing,
DL, VT));
1682 if (Leading > 32 && (Leading - 32) == C2 && C2 + Trailing < 32 &&
1683 OneUseOrZExtW && !IsCANDI) {
1685 RISCV::SRLIW,
DL, VT,
X,
1686 CurDAG->getTargetConstant(C2 + Trailing,
DL, VT));
1689 CurDAG->getTargetConstant(Trailing,
DL, VT));
1694 if (Trailing > 0 && Leading + Trailing == 32 && C2 + Trailing < XLen &&
1695 OneUseOrZExtW && Subtarget->hasStdExtZba()) {
1697 RISCV::SRLI,
DL, VT,
X,
1698 CurDAG->getTargetConstant(C2 + Trailing,
DL, VT));
1700 RISCV::SLLI_UW,
DL, VT,
SDValue(SRLI, 0),
1701 CurDAG->getTargetConstant(Trailing,
DL, VT));
1712 if (Leading == 0 && C2 < Trailing && OneUseOrZExtW && !IsCANDI) {
1714 RISCV::SRLI,
DL, VT,
X,
1715 CurDAG->getTargetConstant(Trailing - C2,
DL, VT));
1718 CurDAG->getTargetConstant(Trailing,
DL, VT));
1723 if (C2 < Trailing && Leading + C2 == 32 && OneUseOrZExtW && !IsCANDI) {
1725 RISCV::SRLIW,
DL, VT,
X,
1726 CurDAG->getTargetConstant(Trailing - C2,
DL, VT));
1729 CurDAG->getTargetConstant(Trailing,
DL, VT));
1735 if (C2 < Trailing && Leading + Trailing == 32 && OneUseOrZExtW &&
1736 Subtarget->hasStdExtZba()) {
1738 RISCV::SRLI,
DL, VT,
X,
1739 CurDAG->getTargetConstant(Trailing - C2,
DL, VT));
1741 RISCV::SLLI_UW,
DL, VT,
SDValue(SRLI, 0),
1742 CurDAG->getTargetConstant(Trailing,
DL, VT));
1749 const uint64_t C1 = N1C->getZExtValue();
1754 unsigned XLen = Subtarget->getXLen();
1755 assert((C2 > 0 && C2 < XLen) &&
"Unexpected shift amount!");
1760 bool Skip = C2 > 32 &&
isInt<12>(N1C->getSExtValue()) &&
1763 X.getConstantOperandVal(1) == 32;
1770 RISCV::SRAI,
DL, VT,
X,
1771 CurDAG->getTargetConstant(C2 - Leading,
DL, VT));
1774 CurDAG->getTargetConstant(Leading,
DL, VT));
1786 if (C2 > Leading && Leading > 0 && Trailing > 0) {
1789 CurDAG->getTargetConstant(C2 - Leading,
DL, VT));
1792 CurDAG->getTargetConstant(Leading + Trailing,
DL, VT));
1795 CurDAG->getTargetConstant(Trailing,
DL, VT));
1808 !(C1 == 0xffff && Subtarget->hasStdExtZbb()) &&
1809 !(C1 == 0xffffffff && Subtarget->hasStdExtZba())) {
1829 if (!N1C || !N1C->hasOneUse())
1850 (C2 == UINT64_C(0xFFFF) && Subtarget->hasStdExtZbb());
1852 IsANDIOrZExt |= C2 == UINT64_C(0xFFFF) && Subtarget->hasVendorXTHeadBb();
1857 bool IsZExtW = C2 == UINT64_C(0xFFFFFFFF) && Subtarget->hasStdExtZba();
1859 IsZExtW |= C2 == UINT64_C(0xFFFFFFFF) && Subtarget->hasVendorXTHeadBb();
1866 unsigned XLen = Subtarget->getXLen();
1872 unsigned ConstantShift = XLen - LeadingZeros;
1876 uint64_t ShiftedC1 = C1 << ConstantShift;
1885 CurDAG->getTargetConstant(LeadingZeros,
DL, VT));
1893 case RISCVISD::WMULSU:
1894 case RISCVISD::WADDU:
1895 case RISCVISD::WSUBU: {
1896 assert(Subtarget->hasStdExtP() && !Subtarget->is64Bit() && VT == MVT::i32 &&
1897 "Unexpected opcode");
1900 switch (
Node->getOpcode()) {
1909 case RISCVISD::WMULSU:
1910 Opc = RISCV::WMULSU;
1912 case RISCVISD::WADDU:
1915 case RISCVISD::WSUBU:
1921 Opc,
DL, MVT::Untyped,
Node->getOperand(0),
Node->getOperand(1));
1929 case RISCVISD::WSLL:
1930 case RISCVISD::WSLA: {
1932 assert(Subtarget->hasStdExtP() && !Subtarget->is64Bit() && VT == MVT::i32 &&
1933 "Unexpected opcode");
1935 bool IsSigned =
Node->getOpcode() == RISCVISD::WSLA;
1942 if (ShAmtC && ShAmtC->getZExtValue() < 64) {
1943 Opc = IsSigned ? RISCV::WSLAI : RISCV::WSLLI;
1944 ShAmt =
CurDAG->getTargetConstant(ShAmtC->getZExtValue(),
DL, XLenVT);
1946 Opc = IsSigned ? RISCV::WSLA : RISCV::WSLL;
1950 Node->getOperand(0), ShAmt);
1962 if (Subtarget->hasVendorXCVmem() && !Subtarget->is64Bit()) {
1972 bool Simm12 =
false;
1973 bool SignExtend = Load->getExtensionType() ==
ISD::SEXTLOAD;
1976 int ConstantVal = ConstantOffset->getSExtValue();
1983 unsigned Opcode = 0;
1984 switch (Load->getMemoryVT().getSimpleVT().SimpleTy) {
1986 if (Simm12 && SignExtend)
1987 Opcode = RISCV::CV_LB_ri_inc;
1988 else if (Simm12 && !SignExtend)
1989 Opcode = RISCV::CV_LBU_ri_inc;
1990 else if (!Simm12 && SignExtend)
1991 Opcode = RISCV::CV_LB_rr_inc;
1993 Opcode = RISCV::CV_LBU_rr_inc;
1996 if (Simm12 && SignExtend)
1997 Opcode = RISCV::CV_LH_ri_inc;
1998 else if (Simm12 && !SignExtend)
1999 Opcode = RISCV::CV_LHU_ri_inc;
2000 else if (!Simm12 && SignExtend)
2001 Opcode = RISCV::CV_LH_rr_inc;
2003 Opcode = RISCV::CV_LHU_rr_inc;
2007 Opcode = RISCV::CV_LW_ri_inc;
2009 Opcode = RISCV::CV_LW_rr_inc;
2024 case RISCVISD::LD_RV32: {
2025 assert(Subtarget->hasStdExtZilsd() &&
"LD_RV32 is only used with Zilsd");
2034 RISCV::LD_RV32,
DL, {MVT::Untyped, MVT::Other},
Ops);
2043 case RISCVISD::SD_RV32: {
2055 RegPair =
CurDAG->getRegister(RISCV::X0_Pair, MVT::Untyped);
2067 case RISCVISD::ADDD:
2075 case RISCVISD::SUBD:
2076 case RISCVISD::PPAIRE_DB:
2077 case RISCVISD::WADDAU:
2078 case RISCVISD::WSUBAU: {
2079 assert(!Subtarget->is64Bit() &&
"Unexpected opcode");
2081 (
Node->getOpcode() != RISCVISD::PPAIRE_DB || Subtarget->hasStdExtP()) &&
2082 "Unexpected opcode");
2089 Op0 =
CurDAG->getRegister(RISCV::X0_Pair, MVT::Untyped);
2098 if (Opcode == RISCVISD::WADDAU || Opcode == RISCVISD::WSUBAU) {
2101 unsigned Opc = Opcode == RISCVISD::WADDAU ? RISCV::WADDAU : RISCV::WSUBAU;
2102 New =
CurDAG->getMachineNode(
Opc,
DL, MVT::Untyped, Op0, Op1Lo, Op1Hi);
2110 case RISCVISD::ADDD:
2113 case RISCVISD::SUBD:
2116 case RISCVISD::PPAIRE_DB:
2117 Opc = RISCV::PPAIRE_DB;
2120 New =
CurDAG->getMachineNode(
Opc,
DL, MVT::Untyped, Op0, Op1);
2130 unsigned IntNo =
Node->getConstantOperandVal(0);
2135 case Intrinsic::riscv_vmsgeu:
2136 case Intrinsic::riscv_vmsge: {
2139 bool IsUnsigned = IntNo == Intrinsic::riscv_vmsgeu;
2140 bool IsCmpConstant =
false;
2141 bool IsCmpMinimum =
false;
2149 IsCmpConstant =
true;
2150 CVal =
C->getSExtValue();
2151 if (CVal >= -15 && CVal <= 16) {
2152 if (!IsUnsigned || CVal != 0)
2154 IsCmpMinimum =
true;
2158 IsCmpMinimum =
true;
2161 unsigned VMSLTOpcode, VMNANDOpcode, VMSetOpcode, VMSGTOpcode;
2165#define CASE_VMSLT_OPCODES(lmulenum, suffix) \
2166 case RISCVVType::lmulenum: \
2167 VMSLTOpcode = IsUnsigned ? RISCV::PseudoVMSLTU_VX_##suffix \
2168 : RISCV::PseudoVMSLT_VX_##suffix; \
2169 VMSGTOpcode = IsUnsigned ? RISCV::PseudoVMSGTU_VX_##suffix \
2170 : RISCV::PseudoVMSGT_VX_##suffix; \
2179#undef CASE_VMSLT_OPCODES
2185#define CASE_VMNAND_VMSET_OPCODES(lmulenum, suffix) \
2186 case RISCVVType::lmulenum: \
2187 VMNANDOpcode = RISCV::PseudoVMNAND_MM_##suffix; \
2188 VMSetOpcode = RISCV::PseudoVMSET_M_##suffix; \
2197#undef CASE_VMNAND_VMSET_OPCODES
2208 CurDAG->getMachineNode(VMSetOpcode,
DL, VT, VL, MaskSEW));
2212 if (IsCmpConstant) {
2217 {Src1, Imm, VL, SEW}));
2224 CurDAG->getMachineNode(VMSLTOpcode,
DL, VT, {Src1, Src2, VL, SEW}),
2227 {Cmp, Cmp, VL, MaskSEW}));
2230 case Intrinsic::riscv_vmsgeu_mask:
2231 case Intrinsic::riscv_vmsge_mask: {
2234 bool IsUnsigned = IntNo == Intrinsic::riscv_vmsgeu_mask;
2235 bool IsCmpConstant =
false;
2236 bool IsCmpMinimum =
false;
2244 IsCmpConstant =
true;
2245 CVal =
C->getSExtValue();
2246 if (CVal >= -15 && CVal <= 16) {
2247 if (!IsUnsigned || CVal != 0)
2249 IsCmpMinimum =
true;
2253 IsCmpMinimum =
true;
2256 unsigned VMSLTOpcode, VMSLTMaskOpcode, VMXOROpcode, VMANDNOpcode,
2257 VMOROpcode, VMSGTMaskOpcode;
2261#define CASE_VMSLT_OPCODES(lmulenum, suffix) \
2262 case RISCVVType::lmulenum: \
2263 VMSLTOpcode = IsUnsigned ? RISCV::PseudoVMSLTU_VX_##suffix \
2264 : RISCV::PseudoVMSLT_VX_##suffix; \
2265 VMSLTMaskOpcode = IsUnsigned ? RISCV::PseudoVMSLTU_VX_##suffix##_MASK \
2266 : RISCV::PseudoVMSLT_VX_##suffix##_MASK; \
2267 VMSGTMaskOpcode = IsUnsigned ? RISCV::PseudoVMSGTU_VX_##suffix##_MASK \
2268 : RISCV::PseudoVMSGT_VX_##suffix##_MASK; \
2277#undef CASE_VMSLT_OPCODES
2283#define CASE_VMXOR_VMANDN_VMOR_OPCODES(lmulenum, suffix) \
2284 case RISCVVType::lmulenum: \
2285 VMXOROpcode = RISCV::PseudoVMXOR_MM_##suffix; \
2286 VMANDNOpcode = RISCV::PseudoVMANDN_MM_##suffix; \
2287 VMOROpcode = RISCV::PseudoVMOR_MM_##suffix; \
2296#undef CASE_VMXOR_VMANDN_VMOR_OPCODES
2310 if (Mask == MaskedOff) {
2315 CurDAG->getMachineNode(VMOROpcode,
DL, VT,
2316 {Mask, MaskedOff, VL, MaskSEW}));
2323 if (Mask == MaskedOff) {
2325 CurDAG->getMachineNode(VMSLTOpcode,
DL, VT, {Src1, Src2, VL, SEW}),
2328 {Mask, Cmp, VL, MaskSEW}));
2335 if (IsCmpConstant) {
2340 VMSGTMaskOpcode,
DL, VT,
2341 {MaskedOff, Src1, Imm, Mask, VL, SEW, PolicyOp}));
2351 {MaskedOff, Src1, Src2, Mask,
2352 VL, SEW, PolicyOp}),
2356 {Cmp, Mask, VL, MaskSEW}));
2359 case Intrinsic::riscv_vsetvli:
2360 case Intrinsic::riscv_vsetvlimax:
2362 case Intrinsic::riscv_sf_vsettnt:
2363 case Intrinsic::riscv_sf_vsettm:
2364 case Intrinsic::riscv_sf_vsettk:
2370 unsigned IntNo =
Node->getConstantOperandVal(1);
2375 case Intrinsic::riscv_vlseg2:
2376 case Intrinsic::riscv_vlseg3:
2377 case Intrinsic::riscv_vlseg4:
2378 case Intrinsic::riscv_vlseg5:
2379 case Intrinsic::riscv_vlseg6:
2380 case Intrinsic::riscv_vlseg7:
2381 case Intrinsic::riscv_vlseg8: {
2386 case Intrinsic::riscv_vlseg2_mask:
2387 case Intrinsic::riscv_vlseg3_mask:
2388 case Intrinsic::riscv_vlseg4_mask:
2389 case Intrinsic::riscv_vlseg5_mask:
2390 case Intrinsic::riscv_vlseg6_mask:
2391 case Intrinsic::riscv_vlseg7_mask:
2392 case Intrinsic::riscv_vlseg8_mask: {
2397 case Intrinsic::riscv_vlsseg2:
2398 case Intrinsic::riscv_vlsseg3:
2399 case Intrinsic::riscv_vlsseg4:
2400 case Intrinsic::riscv_vlsseg5:
2401 case Intrinsic::riscv_vlsseg6:
2402 case Intrinsic::riscv_vlsseg7:
2403 case Intrinsic::riscv_vlsseg8: {
2408 case Intrinsic::riscv_vlsseg2_mask:
2409 case Intrinsic::riscv_vlsseg3_mask:
2410 case Intrinsic::riscv_vlsseg4_mask:
2411 case Intrinsic::riscv_vlsseg5_mask:
2412 case Intrinsic::riscv_vlsseg6_mask:
2413 case Intrinsic::riscv_vlsseg7_mask:
2414 case Intrinsic::riscv_vlsseg8_mask: {
2419 case Intrinsic::riscv_vloxseg2:
2420 case Intrinsic::riscv_vloxseg3:
2421 case Intrinsic::riscv_vloxseg4:
2422 case Intrinsic::riscv_vloxseg5:
2423 case Intrinsic::riscv_vloxseg6:
2424 case Intrinsic::riscv_vloxseg7:
2425 case Intrinsic::riscv_vloxseg8:
2429 case Intrinsic::riscv_vluxseg2:
2430 case Intrinsic::riscv_vluxseg3:
2431 case Intrinsic::riscv_vluxseg4:
2432 case Intrinsic::riscv_vluxseg5:
2433 case Intrinsic::riscv_vluxseg6:
2434 case Intrinsic::riscv_vluxseg7:
2435 case Intrinsic::riscv_vluxseg8:
2439 case Intrinsic::riscv_vloxseg2_mask:
2440 case Intrinsic::riscv_vloxseg3_mask:
2441 case Intrinsic::riscv_vloxseg4_mask:
2442 case Intrinsic::riscv_vloxseg5_mask:
2443 case Intrinsic::riscv_vloxseg6_mask:
2444 case Intrinsic::riscv_vloxseg7_mask:
2445 case Intrinsic::riscv_vloxseg8_mask:
2449 case Intrinsic::riscv_vluxseg2_mask:
2450 case Intrinsic::riscv_vluxseg3_mask:
2451 case Intrinsic::riscv_vluxseg4_mask:
2452 case Intrinsic::riscv_vluxseg5_mask:
2453 case Intrinsic::riscv_vluxseg6_mask:
2454 case Intrinsic::riscv_vluxseg7_mask:
2455 case Intrinsic::riscv_vluxseg8_mask:
2459 case Intrinsic::riscv_vlseg8ff:
2460 case Intrinsic::riscv_vlseg7ff:
2461 case Intrinsic::riscv_vlseg6ff:
2462 case Intrinsic::riscv_vlseg5ff:
2463 case Intrinsic::riscv_vlseg4ff:
2464 case Intrinsic::riscv_vlseg3ff:
2465 case Intrinsic::riscv_vlseg2ff: {
2469 case Intrinsic::riscv_vlseg8ff_mask:
2470 case Intrinsic::riscv_vlseg7ff_mask:
2471 case Intrinsic::riscv_vlseg6ff_mask:
2472 case Intrinsic::riscv_vlseg5ff_mask:
2473 case Intrinsic::riscv_vlseg4ff_mask:
2474 case Intrinsic::riscv_vlseg3ff_mask:
2475 case Intrinsic::riscv_vlseg2ff_mask: {
2479 case Intrinsic::riscv_vloxei:
2480 case Intrinsic::riscv_vloxei_mask:
2481 case Intrinsic::riscv_vluxei:
2482 case Intrinsic::riscv_vluxei_mask: {
2483 bool IsMasked = IntNo == Intrinsic::riscv_vloxei_mask ||
2484 IntNo == Intrinsic::riscv_vluxei_mask;
2485 bool IsOrdered = IntNo == Intrinsic::riscv_vloxei ||
2486 IntNo == Intrinsic::riscv_vloxei_mask;
2488 MVT VT =
Node->getSimpleValueType(0);
2501 "Element count mismatch");
2506 if (IndexLog2EEW == 6 && !Subtarget->is64Bit()) {
2508 "index values when XLEN=32");
2511 IsMasked, IsOrdered, IndexLog2EEW,
static_cast<unsigned>(LMUL),
2512 static_cast<unsigned>(IndexLMUL));
2514 CurDAG->getMachineNode(
P->Pseudo,
DL,
Node->getVTList(), Operands);
2521 case Intrinsic::riscv_vlm:
2522 case Intrinsic::riscv_vle:
2523 case Intrinsic::riscv_vle_mask:
2524 case Intrinsic::riscv_vlse:
2525 case Intrinsic::riscv_vlse_mask: {
2526 bool IsMasked = IntNo == Intrinsic::riscv_vle_mask ||
2527 IntNo == Intrinsic::riscv_vlse_mask;
2529 IntNo == Intrinsic::riscv_vlse || IntNo == Intrinsic::riscv_vlse_mask;
2531 MVT VT =
Node->getSimpleValueType(0);
2540 bool HasPassthruOperand = IntNo != Intrinsic::riscv_vlm;
2543 if (HasPassthruOperand)
2549 CurDAG->getMachineNode(TargetOpcode::IMPLICIT_DEF,
DL, VT);
2557 RISCV::getVLEPseudo(IsMasked, IsStrided,
false, Log2SEW,
2558 static_cast<unsigned>(LMUL));
2560 CurDAG->getMachineNode(
P->Pseudo,
DL,
Node->getVTList(), Operands);
2567 case Intrinsic::riscv_vleff:
2568 case Intrinsic::riscv_vleff_mask: {
2569 bool IsMasked = IntNo == Intrinsic::riscv_vleff_mask;
2571 MVT VT =
Node->getSimpleValueType(0);
2583 RISCV::getVLEPseudo(IsMasked,
false,
true,
2584 Log2SEW,
static_cast<unsigned>(LMUL));
2586 P->Pseudo,
DL,
Node->getVTList(), Operands);
2592 case Intrinsic::riscv_nds_vln:
2593 case Intrinsic::riscv_nds_vln_mask:
2594 case Intrinsic::riscv_nds_vlnu:
2595 case Intrinsic::riscv_nds_vlnu_mask: {
2596 bool IsMasked = IntNo == Intrinsic::riscv_nds_vln_mask ||
2597 IntNo == Intrinsic::riscv_nds_vlnu_mask;
2598 bool IsUnsigned = IntNo == Intrinsic::riscv_nds_vlnu ||
2599 IntNo == Intrinsic::riscv_nds_vlnu_mask;
2601 MVT VT =
Node->getSimpleValueType(0);
2613 IsMasked, IsUnsigned, Log2SEW,
static_cast<unsigned>(LMUL));
2615 CurDAG->getMachineNode(
P->Pseudo,
DL,
Node->getVTList(), Operands);
2618 CurDAG->setNodeMemRefs(Load, {
MemOp->getMemOperand()});
2627 unsigned IntNo =
Node->getConstantOperandVal(1);
2629 case Intrinsic::riscv_vsseg2:
2630 case Intrinsic::riscv_vsseg3:
2631 case Intrinsic::riscv_vsseg4:
2632 case Intrinsic::riscv_vsseg5:
2633 case Intrinsic::riscv_vsseg6:
2634 case Intrinsic::riscv_vsseg7:
2635 case Intrinsic::riscv_vsseg8: {
2640 case Intrinsic::riscv_vsseg2_mask:
2641 case Intrinsic::riscv_vsseg3_mask:
2642 case Intrinsic::riscv_vsseg4_mask:
2643 case Intrinsic::riscv_vsseg5_mask:
2644 case Intrinsic::riscv_vsseg6_mask:
2645 case Intrinsic::riscv_vsseg7_mask:
2646 case Intrinsic::riscv_vsseg8_mask: {
2651 case Intrinsic::riscv_vssseg2:
2652 case Intrinsic::riscv_vssseg3:
2653 case Intrinsic::riscv_vssseg4:
2654 case Intrinsic::riscv_vssseg5:
2655 case Intrinsic::riscv_vssseg6:
2656 case Intrinsic::riscv_vssseg7:
2657 case Intrinsic::riscv_vssseg8: {
2662 case Intrinsic::riscv_vssseg2_mask:
2663 case Intrinsic::riscv_vssseg3_mask:
2664 case Intrinsic::riscv_vssseg4_mask:
2665 case Intrinsic::riscv_vssseg5_mask:
2666 case Intrinsic::riscv_vssseg6_mask:
2667 case Intrinsic::riscv_vssseg7_mask:
2668 case Intrinsic::riscv_vssseg8_mask: {
2673 case Intrinsic::riscv_vsoxseg2:
2674 case Intrinsic::riscv_vsoxseg3:
2675 case Intrinsic::riscv_vsoxseg4:
2676 case Intrinsic::riscv_vsoxseg5:
2677 case Intrinsic::riscv_vsoxseg6:
2678 case Intrinsic::riscv_vsoxseg7:
2679 case Intrinsic::riscv_vsoxseg8:
2683 case Intrinsic::riscv_vsuxseg2:
2684 case Intrinsic::riscv_vsuxseg3:
2685 case Intrinsic::riscv_vsuxseg4:
2686 case Intrinsic::riscv_vsuxseg5:
2687 case Intrinsic::riscv_vsuxseg6:
2688 case Intrinsic::riscv_vsuxseg7:
2689 case Intrinsic::riscv_vsuxseg8:
2693 case Intrinsic::riscv_vsoxseg2_mask:
2694 case Intrinsic::riscv_vsoxseg3_mask:
2695 case Intrinsic::riscv_vsoxseg4_mask:
2696 case Intrinsic::riscv_vsoxseg5_mask:
2697 case Intrinsic::riscv_vsoxseg6_mask:
2698 case Intrinsic::riscv_vsoxseg7_mask:
2699 case Intrinsic::riscv_vsoxseg8_mask:
2703 case Intrinsic::riscv_vsuxseg2_mask:
2704 case Intrinsic::riscv_vsuxseg3_mask:
2705 case Intrinsic::riscv_vsuxseg4_mask:
2706 case Intrinsic::riscv_vsuxseg5_mask:
2707 case Intrinsic::riscv_vsuxseg6_mask:
2708 case Intrinsic::riscv_vsuxseg7_mask:
2709 case Intrinsic::riscv_vsuxseg8_mask:
2713 case Intrinsic::riscv_vsoxei:
2714 case Intrinsic::riscv_vsoxei_mask:
2715 case Intrinsic::riscv_vsuxei:
2716 case Intrinsic::riscv_vsuxei_mask: {
2717 bool IsMasked = IntNo == Intrinsic::riscv_vsoxei_mask ||
2718 IntNo == Intrinsic::riscv_vsuxei_mask;
2719 bool IsOrdered = IntNo == Intrinsic::riscv_vsoxei ||
2720 IntNo == Intrinsic::riscv_vsoxei_mask;
2722 MVT VT =
Node->getOperand(2)->getSimpleValueType(0);
2735 "Element count mismatch");
2740 if (IndexLog2EEW == 6 && !Subtarget->is64Bit()) {
2742 "index values when XLEN=32");
2745 IsMasked, IsOrdered, IndexLog2EEW,
2746 static_cast<unsigned>(LMUL),
static_cast<unsigned>(IndexLMUL));
2748 CurDAG->getMachineNode(
P->Pseudo,
DL,
Node->getVTList(), Operands);
2755 case Intrinsic::riscv_vsm:
2756 case Intrinsic::riscv_vse:
2757 case Intrinsic::riscv_vse_mask:
2758 case Intrinsic::riscv_vsse:
2759 case Intrinsic::riscv_vsse_mask: {
2760 bool IsMasked = IntNo == Intrinsic::riscv_vse_mask ||
2761 IntNo == Intrinsic::riscv_vsse_mask;
2763 IntNo == Intrinsic::riscv_vsse || IntNo == Intrinsic::riscv_vsse_mask;
2765 MVT VT =
Node->getOperand(2)->getSimpleValueType(0);
2777 IsMasked, IsStrided, Log2SEW,
static_cast<unsigned>(LMUL));
2779 CurDAG->getMachineNode(
P->Pseudo,
DL,
Node->getVTList(), Operands);
2785 case Intrinsic::riscv_sf_vc_x_se:
2786 case Intrinsic::riscv_sf_vc_i_se:
2789 case Intrinsic::riscv_sf_vlte8:
2790 case Intrinsic::riscv_sf_vlte16:
2791 case Intrinsic::riscv_sf_vlte32:
2792 case Intrinsic::riscv_sf_vlte64: {
2794 unsigned PseudoInst;
2796 case Intrinsic::riscv_sf_vlte8:
2797 PseudoInst = RISCV::PseudoSF_VLTE8;
2800 case Intrinsic::riscv_sf_vlte16:
2801 PseudoInst = RISCV::PseudoSF_VLTE16;
2804 case Intrinsic::riscv_sf_vlte32:
2805 PseudoInst = RISCV::PseudoSF_VLTE32;
2808 case Intrinsic::riscv_sf_vlte64:
2809 PseudoInst = RISCV::PseudoSF_VLTE64;
2817 Node->getOperand(3),
2818 Node->getOperand(4),
2821 Node->getOperand(0)};
2824 CurDAG->getMachineNode(PseudoInst,
DL,
Node->getVTList(), Operands);
2825 CurDAG->setNodeMemRefs(TileLoad,
2831 case Intrinsic::riscv_sf_mm_s_s:
2832 case Intrinsic::riscv_sf_mm_s_u:
2833 case Intrinsic::riscv_sf_mm_u_s:
2834 case Intrinsic::riscv_sf_mm_u_u:
2835 case Intrinsic::riscv_sf_mm_e5m2_e5m2:
2836 case Intrinsic::riscv_sf_mm_e5m2_e4m3:
2837 case Intrinsic::riscv_sf_mm_e4m3_e5m2:
2838 case Intrinsic::riscv_sf_mm_e4m3_e4m3:
2839 case Intrinsic::riscv_sf_mm_f_f: {
2840 bool HasFRM =
false;
2841 unsigned PseudoInst;
2843 case Intrinsic::riscv_sf_mm_s_s:
2844 PseudoInst = RISCV::PseudoSF_MM_S_S;
2846 case Intrinsic::riscv_sf_mm_s_u:
2847 PseudoInst = RISCV::PseudoSF_MM_S_U;
2849 case Intrinsic::riscv_sf_mm_u_s:
2850 PseudoInst = RISCV::PseudoSF_MM_U_S;
2852 case Intrinsic::riscv_sf_mm_u_u:
2853 PseudoInst = RISCV::PseudoSF_MM_U_U;
2855 case Intrinsic::riscv_sf_mm_e5m2_e5m2:
2856 PseudoInst = RISCV::PseudoSF_MM_E5M2_E5M2;
2859 case Intrinsic::riscv_sf_mm_e5m2_e4m3:
2860 PseudoInst = RISCV::PseudoSF_MM_E5M2_E4M3;
2863 case Intrinsic::riscv_sf_mm_e4m3_e5m2:
2864 PseudoInst = RISCV::PseudoSF_MM_E4M3_E5M2;
2867 case Intrinsic::riscv_sf_mm_e4m3_e4m3:
2868 PseudoInst = RISCV::PseudoSF_MM_E4M3_E4M3;
2871 case Intrinsic::riscv_sf_mm_f_f:
2872 if (
Node->getOperand(3).getValueType().getScalarType() == MVT::bf16)
2873 PseudoInst = RISCV::PseudoSF_MM_F_F_ALT;
2875 PseudoInst = RISCV::PseudoSF_MM_F_F;
2891 if (IntNo == Intrinsic::riscv_sf_mm_f_f && Log2SEW == 5 &&
2900 Operands.append({TmOp, TnOp, TkOp,
2901 CurDAG->getTargetConstant(Log2SEW,
DL, XLenVT), TWidenOp,
2905 CurDAG->getMachineNode(PseudoInst,
DL,
Node->getVTList(), Operands);
2910 case Intrinsic::riscv_sf_vtzero_t: {
2917 auto *NewNode =
CurDAG->getMachineNode(
2918 RISCV::PseudoSF_VTZERO_T,
DL,
Node->getVTList(),
2919 {CurDAG->getRegister(getTileReg(TileNum), XLenVT), Tm, Tn, Log2SEW,
2929 MVT SrcVT =
Node->getOperand(0).getSimpleValueType();
2938 if (Subtarget->hasStdExtP()) {
2940 (VT == MVT::i32 && (SrcVT == MVT::v4i8 || SrcVT == MVT::v2i16)) ||
2941 (SrcVT == MVT::i32 && (VT == MVT::v4i8 || VT == MVT::v2i16));
2943 (VT == MVT::i64 && (SrcVT == MVT::v8i8 || SrcVT == MVT::v4i16 ||
2944 SrcVT == MVT::v2i32)) ||
2945 (SrcVT == MVT::i64 &&
2946 (VT == MVT::v8i8 || VT == MVT::v4i16 || VT == MVT::v2i32));
2947 if (Is32BitCast || Is64BitCast) {
2956 if (!Subtarget->hasStdExtP())
2962 if (ConstNode->isZero()) {
2964 CurDAG->getCopyFromReg(
CurDAG->getEntryNode(),
DL, RISCV::X0, VT);
2970 APInt Val = ConstNode->getAPIntValue().
trunc(EltSize);
2975 RISCV::ADDI,
DL, VT,
CurDAG->getRegister(RISCV::X0, VT),
2976 CurDAG->getAllOnesConstant(
DL, XLenVT,
true));
2983 Val = Val.
trunc(16);
2994 Opc = EltSize == 32 ? RISCV::PLI_W : RISCV::PLI_H;
2996 Opc = RISCV::PLUI_H;
2999 Opc = RISCV::PLUI_W;
3005 Opc,
DL, VT,
CurDAG->getSignedTargetConstant(Imm,
DL, XLenVT));
3013 if (Subtarget->hasStdExtP()) {
3014 MVT SrcVT =
Node->getOperand(0).getSimpleValueType();
3015 if ((VT == MVT::v2i32 && SrcVT == MVT::i64) ||
3016 (VT == MVT::v4i8 && SrcVT == MVT::i32)) {
3024 case RISCVISD::TUPLE_INSERT: {
3028 auto Idx =
Node->getConstantOperandVal(2);
3032 MVT SubVecContainerVT = SubVecVT;
3035 SubVecContainerVT =
TLI.getContainerForFixedLengthVector(SubVecVT);
3037 [[maybe_unused]]
bool ExactlyVecRegSized =
3039 .isKnownMultipleOf(Subtarget->expandVScale(VecRegSize));
3041 .getKnownMinValue()));
3042 assert(Idx == 0 && (ExactlyVecRegSized || V.isUndef()));
3044 MVT ContainerVT = VT;
3046 ContainerVT =
TLI.getContainerForFixedLengthVector(VT);
3048 const auto *
TRI = Subtarget->getRegisterInfo();
3050 std::tie(SubRegIdx, Idx) =
3052 ContainerVT, SubVecContainerVT, Idx,
TRI);
3062 [[maybe_unused]]
bool IsSubVecPartReg =
3066 assert((V.getValueType().isRISCVVectorTuple() || !IsSubVecPartReg ||
3068 "Expecting lowering to have created legal INSERT_SUBVECTORs when "
3069 "the subvector is smaller than a full-sized register");
3073 if (SubRegIdx == RISCV::NoSubRegister) {
3074 unsigned InRegClassID =
3078 "Unexpected subvector extraction");
3080 SDNode *NewNode =
CurDAG->getMachineNode(TargetOpcode::COPY_TO_REGCLASS,
3086 SDValue Insert =
CurDAG->getTargetInsertSubreg(SubRegIdx,
DL, VT, V, SubV);
3091 case RISCVISD::TUPLE_EXTRACT: {
3093 auto Idx =
Node->getConstantOperandVal(1);
3094 MVT InVT = V.getSimpleValueType();
3098 MVT SubVecContainerVT = VT;
3102 SubVecContainerVT =
TLI.getContainerForFixedLengthVector(VT);
3105 InVT =
TLI.getContainerForFixedLengthVector(InVT);
3107 const auto *
TRI = Subtarget->getRegisterInfo();
3109 std::tie(SubRegIdx, Idx) =
3111 InVT, SubVecContainerVT, Idx,
TRI);
3121 if (SubRegIdx == RISCV::NoSubRegister) {
3125 "Unexpected subvector extraction");
3128 CurDAG->getMachineNode(TargetOpcode::COPY_TO_REGCLASS,
DL, VT, V, RC);
3133 SDValue Extract =
CurDAG->getTargetExtractSubreg(SubRegIdx,
DL, VT, V);
3137 case RISCVISD::VMV_S_X_VL:
3138 case RISCVISD::VFMV_S_F_VL:
3139 case RISCVISD::VMV_V_X_VL:
3140 case RISCVISD::VFMV_V_F_VL: {
3142 bool IsScalarMove =
Node->getOpcode() == RISCVISD::VMV_S_X_VL ||
3143 Node->getOpcode() == RISCVISD::VFMV_S_F_VL;
3144 if (!
Node->getOperand(0).isUndef())
3150 if (!Ld || Ld->isIndexed())
3152 EVT MemVT = Ld->getMemoryVT();
3178 if (IsStrided && !Subtarget->hasOptimizedZeroStrideLoad())
3182 SDValue(
CurDAG->getMachineNode(TargetOpcode::IMPLICIT_DEF,
DL, VT), 0),
3188 Operands.
append({VL, SEW, PolicyOp, Ld->getChain()});
3192 false, IsStrided,
false,
3193 Log2SEW,
static_cast<unsigned>(LMUL));
3195 CurDAG->getMachineNode(
P->Pseudo,
DL, {VT, MVT::Other}, Operands);
3199 CurDAG->setNodeMemRefs(Load, {Ld->getMemOperand()});
3207 if (Subtarget->hasVendorXMIPSCBOP())
3210 unsigned Locality =
Node->getConstantOperandVal(3);
3218 int NontemporalLevel = 0;
3221 NontemporalLevel = 3;
3224 NontemporalLevel = 1;
3227 NontemporalLevel = 0;
3233 if (NontemporalLevel & 0b1)
3235 if (NontemporalLevel & 0b10)