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 assert(!Subtarget->is64Bit() &&
"Unexpected opcode");
2082 (
Node->getOpcode() != RISCVISD::PPAIRE_DB || Subtarget->hasStdExtP()) &&
2083 "Unexpected opcode");
2090 Op0 =
CurDAG->getRegister(RISCV::X0_Pair, MVT::Untyped);
2099 if (Opcode == RISCVISD::WADDAU || Opcode == RISCVISD::WSUBAU) {
2102 unsigned Opc = Opcode == RISCVISD::WADDAU ? RISCV::WADDAU : RISCV::WSUBAU;
2103 New =
CurDAG->getMachineNode(
Opc,
DL, MVT::Untyped, Op0, Op1Lo, Op1Hi);
2111 case RISCVISD::ADDD:
2114 case RISCVISD::SUBD:
2117 case RISCVISD::PPAIRE_DB:
2118 Opc = RISCV::PPAIRE_DB;
2121 New =
CurDAG->getMachineNode(
Opc,
DL, MVT::Untyped, Op0, Op1);
2131 unsigned IntNo =
Node->getConstantOperandVal(0);
2136 case Intrinsic::riscv_vmsgeu:
2137 case Intrinsic::riscv_vmsge: {
2140 bool IsUnsigned = IntNo == Intrinsic::riscv_vmsgeu;
2141 bool IsCmpConstant =
false;
2142 bool IsCmpMinimum =
false;
2150 IsCmpConstant =
true;
2151 CVal =
C->getSExtValue();
2152 if (CVal >= -15 && CVal <= 16) {
2153 if (!IsUnsigned || CVal != 0)
2155 IsCmpMinimum =
true;
2159 IsCmpMinimum =
true;
2162 unsigned VMSLTOpcode, VMNANDOpcode, VMSetOpcode, VMSGTOpcode;
2166#define CASE_VMSLT_OPCODES(lmulenum, suffix) \
2167 case RISCVVType::lmulenum: \
2168 VMSLTOpcode = IsUnsigned ? RISCV::PseudoVMSLTU_VX_##suffix \
2169 : RISCV::PseudoVMSLT_VX_##suffix; \
2170 VMSGTOpcode = IsUnsigned ? RISCV::PseudoVMSGTU_VX_##suffix \
2171 : RISCV::PseudoVMSGT_VX_##suffix; \
2180#undef CASE_VMSLT_OPCODES
2186#define CASE_VMNAND_VMSET_OPCODES(lmulenum, suffix) \
2187 case RISCVVType::lmulenum: \
2188 VMNANDOpcode = RISCV::PseudoVMNAND_MM_##suffix; \
2189 VMSetOpcode = RISCV::PseudoVMSET_M_##suffix; \
2198#undef CASE_VMNAND_VMSET_OPCODES
2209 CurDAG->getMachineNode(VMSetOpcode,
DL, VT, VL, MaskSEW));
2213 if (IsCmpConstant) {
2218 {Src1, Imm, VL, SEW}));
2225 CurDAG->getMachineNode(VMSLTOpcode,
DL, VT, {Src1, Src2, VL, SEW}),
2228 {Cmp, Cmp, VL, MaskSEW}));
2231 case Intrinsic::riscv_vmsgeu_mask:
2232 case Intrinsic::riscv_vmsge_mask: {
2235 bool IsUnsigned = IntNo == Intrinsic::riscv_vmsgeu_mask;
2236 bool IsCmpConstant =
false;
2237 bool IsCmpMinimum =
false;
2245 IsCmpConstant =
true;
2246 CVal =
C->getSExtValue();
2247 if (CVal >= -15 && CVal <= 16) {
2248 if (!IsUnsigned || CVal != 0)
2250 IsCmpMinimum =
true;
2254 IsCmpMinimum =
true;
2257 unsigned VMSLTOpcode, VMSLTMaskOpcode, VMXOROpcode, VMANDNOpcode,
2258 VMOROpcode, VMSGTMaskOpcode;
2262#define CASE_VMSLT_OPCODES(lmulenum, suffix) \
2263 case RISCVVType::lmulenum: \
2264 VMSLTOpcode = IsUnsigned ? RISCV::PseudoVMSLTU_VX_##suffix \
2265 : RISCV::PseudoVMSLT_VX_##suffix; \
2266 VMSLTMaskOpcode = IsUnsigned ? RISCV::PseudoVMSLTU_VX_##suffix##_MASK \
2267 : RISCV::PseudoVMSLT_VX_##suffix##_MASK; \
2268 VMSGTMaskOpcode = IsUnsigned ? RISCV::PseudoVMSGTU_VX_##suffix##_MASK \
2269 : RISCV::PseudoVMSGT_VX_##suffix##_MASK; \
2278#undef CASE_VMSLT_OPCODES
2284#define CASE_VMXOR_VMANDN_VMOR_OPCODES(lmulenum, suffix) \
2285 case RISCVVType::lmulenum: \
2286 VMXOROpcode = RISCV::PseudoVMXOR_MM_##suffix; \
2287 VMANDNOpcode = RISCV::PseudoVMANDN_MM_##suffix; \
2288 VMOROpcode = RISCV::PseudoVMOR_MM_##suffix; \
2297#undef CASE_VMXOR_VMANDN_VMOR_OPCODES
2311 if (Mask == MaskedOff) {
2316 CurDAG->getMachineNode(VMOROpcode,
DL, VT,
2317 {Mask, MaskedOff, VL, MaskSEW}));
2324 if (Mask == MaskedOff) {
2326 CurDAG->getMachineNode(VMSLTOpcode,
DL, VT, {Src1, Src2, VL, SEW}),
2329 {Mask, Cmp, VL, MaskSEW}));
2336 if (IsCmpConstant) {
2341 VMSGTMaskOpcode,
DL, VT,
2342 {MaskedOff, Src1, Imm, Mask, VL, SEW, PolicyOp}));
2352 {MaskedOff, Src1, Src2, Mask,
2353 VL, SEW, PolicyOp}),
2357 {Cmp, Mask, VL, MaskSEW}));
2360 case Intrinsic::riscv_vsetvli:
2361 case Intrinsic::riscv_vsetvlimax:
2363 case Intrinsic::riscv_sf_vsettnt:
2364 case Intrinsic::riscv_sf_vsettm:
2365 case Intrinsic::riscv_sf_vsettk:
2371 unsigned IntNo =
Node->getConstantOperandVal(1);
2376 case Intrinsic::riscv_vlseg2:
2377 case Intrinsic::riscv_vlseg3:
2378 case Intrinsic::riscv_vlseg4:
2379 case Intrinsic::riscv_vlseg5:
2380 case Intrinsic::riscv_vlseg6:
2381 case Intrinsic::riscv_vlseg7:
2382 case Intrinsic::riscv_vlseg8: {
2387 case Intrinsic::riscv_vlseg2_mask:
2388 case Intrinsic::riscv_vlseg3_mask:
2389 case Intrinsic::riscv_vlseg4_mask:
2390 case Intrinsic::riscv_vlseg5_mask:
2391 case Intrinsic::riscv_vlseg6_mask:
2392 case Intrinsic::riscv_vlseg7_mask:
2393 case Intrinsic::riscv_vlseg8_mask: {
2398 case Intrinsic::riscv_vlsseg2:
2399 case Intrinsic::riscv_vlsseg3:
2400 case Intrinsic::riscv_vlsseg4:
2401 case Intrinsic::riscv_vlsseg5:
2402 case Intrinsic::riscv_vlsseg6:
2403 case Intrinsic::riscv_vlsseg7:
2404 case Intrinsic::riscv_vlsseg8: {
2409 case Intrinsic::riscv_vlsseg2_mask:
2410 case Intrinsic::riscv_vlsseg3_mask:
2411 case Intrinsic::riscv_vlsseg4_mask:
2412 case Intrinsic::riscv_vlsseg5_mask:
2413 case Intrinsic::riscv_vlsseg6_mask:
2414 case Intrinsic::riscv_vlsseg7_mask:
2415 case Intrinsic::riscv_vlsseg8_mask: {
2420 case Intrinsic::riscv_vloxseg2:
2421 case Intrinsic::riscv_vloxseg3:
2422 case Intrinsic::riscv_vloxseg4:
2423 case Intrinsic::riscv_vloxseg5:
2424 case Intrinsic::riscv_vloxseg6:
2425 case Intrinsic::riscv_vloxseg7:
2426 case Intrinsic::riscv_vloxseg8:
2430 case Intrinsic::riscv_vluxseg2:
2431 case Intrinsic::riscv_vluxseg3:
2432 case Intrinsic::riscv_vluxseg4:
2433 case Intrinsic::riscv_vluxseg5:
2434 case Intrinsic::riscv_vluxseg6:
2435 case Intrinsic::riscv_vluxseg7:
2436 case Intrinsic::riscv_vluxseg8:
2440 case Intrinsic::riscv_vloxseg2_mask:
2441 case Intrinsic::riscv_vloxseg3_mask:
2442 case Intrinsic::riscv_vloxseg4_mask:
2443 case Intrinsic::riscv_vloxseg5_mask:
2444 case Intrinsic::riscv_vloxseg6_mask:
2445 case Intrinsic::riscv_vloxseg7_mask:
2446 case Intrinsic::riscv_vloxseg8_mask:
2450 case Intrinsic::riscv_vluxseg2_mask:
2451 case Intrinsic::riscv_vluxseg3_mask:
2452 case Intrinsic::riscv_vluxseg4_mask:
2453 case Intrinsic::riscv_vluxseg5_mask:
2454 case Intrinsic::riscv_vluxseg6_mask:
2455 case Intrinsic::riscv_vluxseg7_mask:
2456 case Intrinsic::riscv_vluxseg8_mask:
2460 case Intrinsic::riscv_vlseg8ff:
2461 case Intrinsic::riscv_vlseg7ff:
2462 case Intrinsic::riscv_vlseg6ff:
2463 case Intrinsic::riscv_vlseg5ff:
2464 case Intrinsic::riscv_vlseg4ff:
2465 case Intrinsic::riscv_vlseg3ff:
2466 case Intrinsic::riscv_vlseg2ff: {
2470 case Intrinsic::riscv_vlseg8ff_mask:
2471 case Intrinsic::riscv_vlseg7ff_mask:
2472 case Intrinsic::riscv_vlseg6ff_mask:
2473 case Intrinsic::riscv_vlseg5ff_mask:
2474 case Intrinsic::riscv_vlseg4ff_mask:
2475 case Intrinsic::riscv_vlseg3ff_mask:
2476 case Intrinsic::riscv_vlseg2ff_mask: {
2480 case Intrinsic::riscv_vloxei:
2481 case Intrinsic::riscv_vloxei_mask:
2482 case Intrinsic::riscv_vluxei:
2483 case Intrinsic::riscv_vluxei_mask: {
2484 bool IsMasked = IntNo == Intrinsic::riscv_vloxei_mask ||
2485 IntNo == Intrinsic::riscv_vluxei_mask;
2486 bool IsOrdered = IntNo == Intrinsic::riscv_vloxei ||
2487 IntNo == Intrinsic::riscv_vloxei_mask;
2489 MVT VT =
Node->getSimpleValueType(0);
2502 "Element count mismatch");
2507 if (IndexLog2EEW == 6 && !Subtarget->is64Bit()) {
2509 "index values when XLEN=32");
2512 IsMasked, IsOrdered, IndexLog2EEW,
static_cast<unsigned>(LMUL),
2513 static_cast<unsigned>(IndexLMUL));
2515 CurDAG->getMachineNode(
P->Pseudo,
DL,
Node->getVTList(), Operands);
2522 case Intrinsic::riscv_vlm:
2523 case Intrinsic::riscv_vle:
2524 case Intrinsic::riscv_vle_mask:
2525 case Intrinsic::riscv_vlse:
2526 case Intrinsic::riscv_vlse_mask: {
2527 bool IsMasked = IntNo == Intrinsic::riscv_vle_mask ||
2528 IntNo == Intrinsic::riscv_vlse_mask;
2530 IntNo == Intrinsic::riscv_vlse || IntNo == Intrinsic::riscv_vlse_mask;
2532 MVT VT =
Node->getSimpleValueType(0);
2541 bool HasPassthruOperand = IntNo != Intrinsic::riscv_vlm;
2544 if (HasPassthruOperand)
2550 CurDAG->getMachineNode(TargetOpcode::IMPLICIT_DEF,
DL, VT);
2558 RISCV::getVLEPseudo(IsMasked, IsStrided,
false, Log2SEW,
2559 static_cast<unsigned>(LMUL));
2561 CurDAG->getMachineNode(
P->Pseudo,
DL,
Node->getVTList(), Operands);
2568 case Intrinsic::riscv_vleff:
2569 case Intrinsic::riscv_vleff_mask: {
2570 bool IsMasked = IntNo == Intrinsic::riscv_vleff_mask;
2572 MVT VT =
Node->getSimpleValueType(0);
2584 RISCV::getVLEPseudo(IsMasked,
false,
true,
2585 Log2SEW,
static_cast<unsigned>(LMUL));
2587 P->Pseudo,
DL,
Node->getVTList(), Operands);
2593 case Intrinsic::riscv_nds_vln:
2594 case Intrinsic::riscv_nds_vln_mask:
2595 case Intrinsic::riscv_nds_vlnu:
2596 case Intrinsic::riscv_nds_vlnu_mask: {
2597 bool IsMasked = IntNo == Intrinsic::riscv_nds_vln_mask ||
2598 IntNo == Intrinsic::riscv_nds_vlnu_mask;
2599 bool IsUnsigned = IntNo == Intrinsic::riscv_nds_vlnu ||
2600 IntNo == Intrinsic::riscv_nds_vlnu_mask;
2602 MVT VT =
Node->getSimpleValueType(0);
2614 IsMasked, IsUnsigned, Log2SEW,
static_cast<unsigned>(LMUL));
2616 CurDAG->getMachineNode(
P->Pseudo,
DL,
Node->getVTList(), Operands);
2619 CurDAG->setNodeMemRefs(Load, {
MemOp->getMemOperand()});
2628 unsigned IntNo =
Node->getConstantOperandVal(1);
2630 case Intrinsic::riscv_vsseg2:
2631 case Intrinsic::riscv_vsseg3:
2632 case Intrinsic::riscv_vsseg4:
2633 case Intrinsic::riscv_vsseg5:
2634 case Intrinsic::riscv_vsseg6:
2635 case Intrinsic::riscv_vsseg7:
2636 case Intrinsic::riscv_vsseg8: {
2641 case Intrinsic::riscv_vsseg2_mask:
2642 case Intrinsic::riscv_vsseg3_mask:
2643 case Intrinsic::riscv_vsseg4_mask:
2644 case Intrinsic::riscv_vsseg5_mask:
2645 case Intrinsic::riscv_vsseg6_mask:
2646 case Intrinsic::riscv_vsseg7_mask:
2647 case Intrinsic::riscv_vsseg8_mask: {
2652 case Intrinsic::riscv_vssseg2:
2653 case Intrinsic::riscv_vssseg3:
2654 case Intrinsic::riscv_vssseg4:
2655 case Intrinsic::riscv_vssseg5:
2656 case Intrinsic::riscv_vssseg6:
2657 case Intrinsic::riscv_vssseg7:
2658 case Intrinsic::riscv_vssseg8: {
2663 case Intrinsic::riscv_vssseg2_mask:
2664 case Intrinsic::riscv_vssseg3_mask:
2665 case Intrinsic::riscv_vssseg4_mask:
2666 case Intrinsic::riscv_vssseg5_mask:
2667 case Intrinsic::riscv_vssseg6_mask:
2668 case Intrinsic::riscv_vssseg7_mask:
2669 case Intrinsic::riscv_vssseg8_mask: {
2674 case Intrinsic::riscv_vsoxseg2:
2675 case Intrinsic::riscv_vsoxseg3:
2676 case Intrinsic::riscv_vsoxseg4:
2677 case Intrinsic::riscv_vsoxseg5:
2678 case Intrinsic::riscv_vsoxseg6:
2679 case Intrinsic::riscv_vsoxseg7:
2680 case Intrinsic::riscv_vsoxseg8:
2684 case Intrinsic::riscv_vsuxseg2:
2685 case Intrinsic::riscv_vsuxseg3:
2686 case Intrinsic::riscv_vsuxseg4:
2687 case Intrinsic::riscv_vsuxseg5:
2688 case Intrinsic::riscv_vsuxseg6:
2689 case Intrinsic::riscv_vsuxseg7:
2690 case Intrinsic::riscv_vsuxseg8:
2694 case Intrinsic::riscv_vsoxseg2_mask:
2695 case Intrinsic::riscv_vsoxseg3_mask:
2696 case Intrinsic::riscv_vsoxseg4_mask:
2697 case Intrinsic::riscv_vsoxseg5_mask:
2698 case Intrinsic::riscv_vsoxseg6_mask:
2699 case Intrinsic::riscv_vsoxseg7_mask:
2700 case Intrinsic::riscv_vsoxseg8_mask:
2704 case Intrinsic::riscv_vsuxseg2_mask:
2705 case Intrinsic::riscv_vsuxseg3_mask:
2706 case Intrinsic::riscv_vsuxseg4_mask:
2707 case Intrinsic::riscv_vsuxseg5_mask:
2708 case Intrinsic::riscv_vsuxseg6_mask:
2709 case Intrinsic::riscv_vsuxseg7_mask:
2710 case Intrinsic::riscv_vsuxseg8_mask:
2714 case Intrinsic::riscv_vsoxei:
2715 case Intrinsic::riscv_vsoxei_mask:
2716 case Intrinsic::riscv_vsuxei:
2717 case Intrinsic::riscv_vsuxei_mask: {
2718 bool IsMasked = IntNo == Intrinsic::riscv_vsoxei_mask ||
2719 IntNo == Intrinsic::riscv_vsuxei_mask;
2720 bool IsOrdered = IntNo == Intrinsic::riscv_vsoxei ||
2721 IntNo == Intrinsic::riscv_vsoxei_mask;
2723 MVT VT =
Node->getOperand(2)->getSimpleValueType(0);
2736 "Element count mismatch");
2741 if (IndexLog2EEW == 6 && !Subtarget->is64Bit()) {
2743 "index values when XLEN=32");
2746 IsMasked, IsOrdered, IndexLog2EEW,
2747 static_cast<unsigned>(LMUL),
static_cast<unsigned>(IndexLMUL));
2749 CurDAG->getMachineNode(
P->Pseudo,
DL,
Node->getVTList(), Operands);
2756 case Intrinsic::riscv_vsm:
2757 case Intrinsic::riscv_vse:
2758 case Intrinsic::riscv_vse_mask:
2759 case Intrinsic::riscv_vsse:
2760 case Intrinsic::riscv_vsse_mask: {
2761 bool IsMasked = IntNo == Intrinsic::riscv_vse_mask ||
2762 IntNo == Intrinsic::riscv_vsse_mask;
2764 IntNo == Intrinsic::riscv_vsse || IntNo == Intrinsic::riscv_vsse_mask;
2766 MVT VT =
Node->getOperand(2)->getSimpleValueType(0);
2778 IsMasked, IsStrided, Log2SEW,
static_cast<unsigned>(LMUL));
2780 CurDAG->getMachineNode(
P->Pseudo,
DL,
Node->getVTList(), Operands);
2786 case Intrinsic::riscv_sf_vc_x_se:
2787 case Intrinsic::riscv_sf_vc_i_se:
2790 case Intrinsic::riscv_sf_vlte8:
2791 case Intrinsic::riscv_sf_vlte16:
2792 case Intrinsic::riscv_sf_vlte32:
2793 case Intrinsic::riscv_sf_vlte64: {
2795 unsigned PseudoInst;
2797 case Intrinsic::riscv_sf_vlte8:
2798 PseudoInst = RISCV::PseudoSF_VLTE8;
2801 case Intrinsic::riscv_sf_vlte16:
2802 PseudoInst = RISCV::PseudoSF_VLTE16;
2805 case Intrinsic::riscv_sf_vlte32:
2806 PseudoInst = RISCV::PseudoSF_VLTE32;
2809 case Intrinsic::riscv_sf_vlte64:
2810 PseudoInst = RISCV::PseudoSF_VLTE64;
2818 Node->getOperand(3),
2819 Node->getOperand(4),
2822 Node->getOperand(0)};
2825 CurDAG->getMachineNode(PseudoInst,
DL,
Node->getVTList(), Operands);
2826 CurDAG->setNodeMemRefs(TileLoad,
2832 case Intrinsic::riscv_sf_mm_s_s:
2833 case Intrinsic::riscv_sf_mm_s_u:
2834 case Intrinsic::riscv_sf_mm_u_s:
2835 case Intrinsic::riscv_sf_mm_u_u:
2836 case Intrinsic::riscv_sf_mm_e5m2_e5m2:
2837 case Intrinsic::riscv_sf_mm_e5m2_e4m3:
2838 case Intrinsic::riscv_sf_mm_e4m3_e5m2:
2839 case Intrinsic::riscv_sf_mm_e4m3_e4m3:
2840 case Intrinsic::riscv_sf_mm_f_f: {
2841 bool HasFRM =
false;
2842 unsigned PseudoInst;
2844 case Intrinsic::riscv_sf_mm_s_s:
2845 PseudoInst = RISCV::PseudoSF_MM_S_S;
2847 case Intrinsic::riscv_sf_mm_s_u:
2848 PseudoInst = RISCV::PseudoSF_MM_S_U;
2850 case Intrinsic::riscv_sf_mm_u_s:
2851 PseudoInst = RISCV::PseudoSF_MM_U_S;
2853 case Intrinsic::riscv_sf_mm_u_u:
2854 PseudoInst = RISCV::PseudoSF_MM_U_U;
2856 case Intrinsic::riscv_sf_mm_e5m2_e5m2:
2857 PseudoInst = RISCV::PseudoSF_MM_E5M2_E5M2;
2860 case Intrinsic::riscv_sf_mm_e5m2_e4m3:
2861 PseudoInst = RISCV::PseudoSF_MM_E5M2_E4M3;
2864 case Intrinsic::riscv_sf_mm_e4m3_e5m2:
2865 PseudoInst = RISCV::PseudoSF_MM_E4M3_E5M2;
2868 case Intrinsic::riscv_sf_mm_e4m3_e4m3:
2869 PseudoInst = RISCV::PseudoSF_MM_E4M3_E4M3;
2872 case Intrinsic::riscv_sf_mm_f_f:
2873 if (
Node->getOperand(3).getValueType().getScalarType() == MVT::bf16)
2874 PseudoInst = RISCV::PseudoSF_MM_F_F_ALT;
2876 PseudoInst = RISCV::PseudoSF_MM_F_F;
2892 if (IntNo == Intrinsic::riscv_sf_mm_f_f && Log2SEW == 5 &&
2901 Operands.append({TmOp, TnOp, TkOp,
2902 CurDAG->getTargetConstant(Log2SEW,
DL, XLenVT), TWidenOp,
2906 CurDAG->getMachineNode(PseudoInst,
DL,
Node->getVTList(), Operands);
2911 case Intrinsic::riscv_sf_vtzero_t: {
2918 auto *NewNode =
CurDAG->getMachineNode(
2919 RISCV::PseudoSF_VTZERO_T,
DL,
Node->getVTList(),
2920 {CurDAG->getRegister(getTileReg(TileNum), XLenVT), Tm, Tn, Log2SEW,
2930 MVT SrcVT =
Node->getOperand(0).getSimpleValueType();
2939 if (Subtarget->hasStdExtP()) {
2941 (VT == MVT::i32 && (SrcVT == MVT::v4i8 || SrcVT == MVT::v2i16)) ||
2942 (SrcVT == MVT::i32 && (VT == MVT::v4i8 || VT == MVT::v2i16));
2944 (VT == MVT::i64 && (SrcVT == MVT::v8i8 || SrcVT == MVT::v4i16 ||
2945 SrcVT == MVT::v2i32)) ||
2946 (SrcVT == MVT::i64 &&
2947 (VT == MVT::v8i8 || VT == MVT::v4i16 || VT == MVT::v2i32));
2948 if (Is32BitCast || Is64BitCast) {
2957 if (!Subtarget->hasStdExtP())
2960 bool IsDoubleWide = Subtarget->isPExtPackedDoubleType(VT);
2962 if (ConstNode->isZero()) {
2963 MCPhysReg X0Reg = IsDoubleWide ? RISCV::X0_Pair : RISCV::X0;
2971 APInt Val = ConstNode->getAPIntValue().
trunc(EltSize);
2976 RISCV::ADDI,
DL, VT,
CurDAG->getRegister(RISCV::X0, VT),
2977 CurDAG->getAllOnesConstant(
DL, XLenVT,
true));
2984 Val = Val.
trunc(16);
2993 Opc = IsDoubleWide ? RISCV::PLI_DB : RISCV::PLI_B;
2994 }
else if (EltSize == 16 &&
isInt<10>(Imm)) {
2995 Opc = IsDoubleWide ? RISCV::PLI_DH : RISCV::PLI_H;
2996 }
else if (!IsDoubleWide && EltSize == 32 &&
isInt<10>(Imm)) {
2999 Opc = IsDoubleWide ? RISCV::PLUI_DH : RISCV::PLUI_H;
3002 Opc = RISCV::PLUI_W;
3008 Opc,
DL, VT,
CurDAG->getSignedTargetConstant(Imm,
DL, XLenVT));
3017 if (Subtarget->hasStdExtP()) {
3018 MVT SrcVT =
Node->getOperand(0).getSimpleValueType();
3019 if ((VT == MVT::v2i32 && SrcVT == MVT::i64) ||
3020 (VT == MVT::v4i8 && SrcVT == MVT::i32)) {
3028 case RISCVISD::TUPLE_INSERT: {
3032 auto Idx =
Node->getConstantOperandVal(2);
3036 MVT SubVecContainerVT = SubVecVT;
3039 SubVecContainerVT =
TLI.getContainerForFixedLengthVector(SubVecVT);
3041 [[maybe_unused]]
bool ExactlyVecRegSized =
3043 .isKnownMultipleOf(Subtarget->expandVScale(VecRegSize));
3045 .getKnownMinValue()));
3046 assert(Idx == 0 && (ExactlyVecRegSized || V.isUndef()));
3048 MVT ContainerVT = VT;
3050 ContainerVT =
TLI.getContainerForFixedLengthVector(VT);
3052 const auto *
TRI = Subtarget->getRegisterInfo();
3054 std::tie(SubRegIdx, Idx) =
3056 ContainerVT, SubVecContainerVT, Idx,
TRI);
3066 [[maybe_unused]]
bool IsSubVecPartReg =
3070 assert((V.getValueType().isRISCVVectorTuple() || !IsSubVecPartReg ||
3072 "Expecting lowering to have created legal INSERT_SUBVECTORs when "
3073 "the subvector is smaller than a full-sized register");
3077 if (SubRegIdx == RISCV::NoSubRegister) {
3078 unsigned InRegClassID =
3082 "Unexpected subvector extraction");
3084 SDNode *NewNode =
CurDAG->getMachineNode(TargetOpcode::COPY_TO_REGCLASS,
3090 SDValue Insert =
CurDAG->getTargetInsertSubreg(SubRegIdx,
DL, VT, V, SubV);
3095 case RISCVISD::TUPLE_EXTRACT: {
3097 auto Idx =
Node->getConstantOperandVal(1);
3098 MVT InVT = V.getSimpleValueType();
3102 if (Subtarget->hasStdExtP() && !Subtarget->is64Bit() &&
3103 ((InVT == MVT::v4i16 && VT == MVT::v2i16) ||
3104 (InVT == MVT::v8i8 && VT == MVT::v4i8))) {
3106 if (Idx != 0 && Idx != NumElts)
3109 unsigned SubRegIdx = Idx == 0 ? RISCV::sub_gpr_even : RISCV::sub_gpr_odd;
3110 SDValue Extract =
CurDAG->getTargetExtractSubreg(SubRegIdx,
DL, VT, V);
3118 MVT SubVecContainerVT = VT;
3122 SubVecContainerVT =
TLI.getContainerForFixedLengthVector(VT);
3125 InVT =
TLI.getContainerForFixedLengthVector(InVT);
3127 const auto *
TRI = Subtarget->getRegisterInfo();
3129 std::tie(SubRegIdx, Idx) =
3131 InVT, SubVecContainerVT, Idx,
TRI);
3141 if (SubRegIdx == RISCV::NoSubRegister) {
3145 "Unexpected subvector extraction");
3148 CurDAG->getMachineNode(TargetOpcode::COPY_TO_REGCLASS,
DL, VT, V, RC);
3153 SDValue Extract =
CurDAG->getTargetExtractSubreg(SubRegIdx,
DL, VT, V);
3157 case RISCVISD::VMV_S_X_VL:
3158 case RISCVISD::VFMV_S_F_VL:
3159 case RISCVISD::VMV_V_X_VL:
3160 case RISCVISD::VFMV_V_F_VL: {
3162 bool IsScalarMove =
Node->getOpcode() == RISCVISD::VMV_S_X_VL ||
3163 Node->getOpcode() == RISCVISD::VFMV_S_F_VL;
3164 if (!
Node->getOperand(0).isUndef())
3170 if (!Ld || Ld->isIndexed())
3172 EVT MemVT = Ld->getMemoryVT();
3198 if (IsStrided && !Subtarget->hasOptimizedZeroStrideLoad())
3202 SDValue(
CurDAG->getMachineNode(TargetOpcode::IMPLICIT_DEF,
DL, VT), 0),
3208 Operands.
append({VL, SEW, PolicyOp, Ld->getChain()});
3212 false, IsStrided,
false,
3213 Log2SEW,
static_cast<unsigned>(LMUL));
3215 CurDAG->getMachineNode(
P->Pseudo,
DL, {VT, MVT::Other}, Operands);
3219 CurDAG->setNodeMemRefs(Load, {Ld->getMemOperand()});
3224 case RISCVISD::LPAD_CALL:
3225 case RISCVISD::LPAD_CALL_INDIRECT: {
3226 bool IsIndirect = Opcode == RISCVISD::LPAD_CALL_INDIRECT;
3227 unsigned PseudoOpc = IsIndirect ? RISCV::PseudoCALLIndirectLpadAlign
3228 : RISCV::PseudoCALLLpadAlign;
3234 "in unsigned 20-bits");
3239 Ops.push_back(
Node->getOperand(1));
3240 Ops.push_back(
CurDAG->getTargetConstant(LpadLabel,
DL, XLenVT));
3241 Ops.push_back(
Node->getOperand(0));
3242 if (
Node->getGluedNode())
3243 Ops.push_back(
Node->getOperand(
Node->getNumOperands() - 1));
3252 if (Subtarget->hasVendorXMIPSCBOP())
3255 unsigned Locality =
Node->getConstantOperandVal(3);
3263 int NontemporalLevel = 0;
3266 NontemporalLevel = 3;
3269 NontemporalLevel = 1;
3272 NontemporalLevel = 0;
3278 if (NontemporalLevel & 0b1)
3280 if (NontemporalLevel & 0b10)