37#include "llvm/IR/IntrinsicsMips.h"
53#define DEBUG_TYPE "mips-isel"
56 cl::desc(
"Expand double precision loads and "
57 "stores to their single precision "
123 for (
const auto &VecTy : VecTys) {
161 for (
MVT VT : {MVT::f32, MVT::f64}) {
375 if (VT == MVT::Untyped)
376 return Subtarget.hasDSP() ? &Mips::ACC64DSPRegClass : &Mips::ACC64RegClass;
420 if (Ty == MVT::v4i32 || Ty == MVT::v2i64) {
451 if (Ty != MVT::v8f16) {
478 EVT ResTy =
Op->getValueType(0);
485 return DAG.
getNode(MipsISD::FSELECT,
DL, ResTy, Tmp,
Op->getOperand(1),
494 EVT ResTy =
Op.getValueType();
495 assert((ResTy == MVT::f32 || ResTy == MVT::f64) &&
"Unexpected FP16_TO_FP");
499 assert(In.getValueType() == MVT::i32 &&
"Unexpected FP16_TO_FP operand type");
510 DAG.
getConstant(Intrinsic::mips_fexupr_w,
DL, MVT::i32), HVec);
512 if (ResTy == MVT::f32) {
520 DAG.
getConstant(Intrinsic::mips_fexupr_d,
DL, MVT::i32), F32Vec);
534 EVT ResTy =
Op.getValueType();
536 assert((
In.getValueType() == MVT::f32 ||
In.getValueType() == MVT::f64) &&
537 "Unexpected FP_TO_FP16");
540 if (
In.getValueType() == MVT::f64) {
554 DAG.
getConstant(Intrinsic::mips_fexdo_h,
DL, MVT::i32), F32Vec, F32Vec);
568 if (
Subtarget.systemSupportsUnalignedAccess()) {
593 switch(
Op.getOpcode()) {
596 case ISD::SMUL_LOHI:
return lowerMulDiv(
Op, MipsISD::Mult,
true,
true, DAG);
597 case ISD::UMUL_LOHI:
return lowerMulDiv(
Op, MipsISD::Multu,
true,
true, DAG);
598 case ISD::MULHS:
return lowerMulDiv(
Op, MipsISD::Mult,
false,
true, DAG);
599 case ISD::MULHU:
return lowerMulDiv(
Op, MipsISD::Multu,
false,
true, DAG);
600 case ISD::MUL:
return lowerMulDiv(
Op, MipsISD::Mult,
true,
false, DAG);
601 case ISD::SDIVREM:
return lowerMulDiv(
Op, MipsISD::DivRem,
true,
true, DAG);
602 case ISD::UDIVREM:
return lowerMulDiv(
Op, MipsISD::DivRemU,
true,
true,
611 return lowerSELECT(
Op, DAG);
614 return lowerFP16_TO_FP(
Op, DAG);
617 return lowerFP_TO_FP16(
Op, DAG);
620 return lowerR5900FPOp(
Op, DAG, RTLIB::ADD_F32);
622 return lowerR5900FPOp(
Op, DAG, RTLIB::SUB_F32);
624 return lowerR5900FPOp(
Op, DAG, RTLIB::MUL_F32);
626 return lowerR5900FPOp(
Op, DAG, RTLIB::DIV_F32);
628 return lowerR5900FPOp(
Op, DAG, RTLIB::SQRT_F32);
635 RTLIB::Libcall LC)
const {
639 if (Flags.hasNoNaNs() && Flags.hasNoInfs()) {
647 MVT VT =
Op.getSimpleValueType();
675 if (Op0Opcode == MipsISD::VEXTRACT_SEXT_ELT ||
676 Op0Opcode == MipsISD::VEXTRACT_ZEXT_ELT) {
682 int32_t Log2IfPositive = (Mask->getAPIntValue() + 1).exactLogBase2();
684 if (Log2IfPositive <= 0)
690 unsigned Log2 = Log2IfPositive;
692 if ((Op0Opcode == MipsISD::VEXTRACT_ZEXT_ELT &&
Log2 >= ExtendTySize) ||
693 Log2 == ExtendTySize) {
695 return DAG.
getNode(MipsISD::VEXTRACT_ZEXT_ELT,
SDLoc(Op0),
719 APInt SplatValue, SplatUndef;
720 unsigned SplatBitSize;
723 if (!
Node->isConstantSplat(SplatValue, SplatUndef, SplatBitSize, HasAnyUndefs,
737 N =
N->getOperand(0);
744 APInt SplatValue, SplatUndef;
745 unsigned SplatBitSize;
750 if (BVN->
isConstantSplat(SplatValue, SplatUndef, SplatBitSize, HasAnyUndefs))
762 return N->getOperand(1) == OfNode;
765 return N->getOperand(0) == OfNode;
782 EVT Ty =
N->getValueType(0);
784 if (!Ty.is128BitVector())
795 bool IsLittleEndian = !Subtarget.
isLittle();
798 bool IsConstantMask =
false;
805 if (
isVSplat(Op0Op0, Mask, IsLittleEndian)) {
809 if (
isVSplat(Op1Op0, InvMask, IsLittleEndian) &&
810 Mask.getBitWidth() == InvMask.
getBitWidth() && Mask == ~InvMask)
812 else if (
isVSplat(Op1Op1, InvMask, IsLittleEndian) &&
813 Mask.getBitWidth() == InvMask.
getBitWidth() && Mask == ~InvMask)
816 IsConstantMask =
true;
826 if (
isVSplat(Op1Op0, InvMask, IsLittleEndian) &&
827 Mask.getBitWidth() == InvMask.
getBitWidth() && Mask == ~InvMask)
829 else if (
isVSplat(Op1Op1, InvMask, IsLittleEndian) &&
830 Mask.getBitWidth() == InvMask.
getBitWidth() && Mask == ~InvMask)
833 IsConstantMask =
true;
882 if (IsConstantMask) {
883 if (Mask.isAllOnes())
930 while (!WorkStack.
empty()) {
933 if (Val == 0 || Val == 1)
947 if ((Val - Floor).ule(Ceil - Val)) {
995 if ((
C - Floor).ule(Ceil -
C)) {
1012 EVT VT =
N->getValueType(0);
1016 C->getAPIntValue(), VT, DAG, Subtarget))
1028 APInt SplatValue, SplatUndef;
1029 unsigned SplatBitSize;
1031 unsigned EltSize = Ty.getScalarSizeInBits();
1038 !BV->
isConstantSplat(SplatValue, SplatUndef, SplatBitSize, HasAnyUndefs,
1040 (SplatBitSize != EltSize) ||
1052 EVT Ty =
N->getValueType(0);
1054 if ((Ty != MVT::v2i16) && (Ty != MVT::v4i8))
1075 EVT Ty =
N->getValueType(0);
1077 if (Subtarget.
hasMSA()) {
1092 if (Op0Op0->
getOpcode() != MipsISD::VEXTRACT_SEXT_ELT &&
1093 Op0Op0->
getOpcode() != MipsISD::VEXTRACT_ZEXT_ELT)
1099 if (TotalBits == 32 ||
1100 (Op0Op0->
getOpcode() == MipsISD::VEXTRACT_SEXT_ELT &&
1104 return DAG.
getNode(MipsISD::VEXTRACT_SEXT_ELT,
SDLoc(Op0Op0),
1111 if ((Ty != MVT::v2i16) && ((Ty != MVT::v4i8) || !Subtarget.
hasDSPR2()))
1121 EVT Ty =
N->getValueType(0);
1123 if (((Ty != MVT::v2i16) || !Subtarget.
hasDSPR2()) && (Ty != MVT::v4i8))
1130 bool IsV216 = (Ty == MVT::v2i16);
1143 default:
return false;
1148 EVT Ty =
N->getValueType(0);
1150 if ((Ty != MVT::v2i16) && (Ty != MVT::v4i8))
1156 return DAG.
getNode(MipsISD::SETCC_DSP,
SDLoc(
N), Ty,
N->getOperand(0),
1157 N->getOperand(1),
N->getOperand(2));
1161 EVT Ty =
N->getValueType(0);
1163 if (Ty == MVT::v2i16 || Ty == MVT::v4i8) {
1166 if (SetCC.
getOpcode() != MipsISD::SETCC_DSP)
1171 N->getOperand(1),
N->getOperand(2), SetCC.
getOperand(2));
1179 EVT Ty =
N->getValueType(0);
1181 if (Subtarget.
hasMSA() && Ty.is128BitVector() && Ty.isInteger()) {
1207 EVT VT =
N->getValueType(0);
1226 switch (
N->getOpcode()) {
1257 N->printrWithDepth(
dbgs(), &DAG);
dbgs() <<
"\n=> \n";
1268 switch (
MI.getOpcode()) {
1271 case Mips::BPOSGE32_PSEUDO:
1272 return emitBPOSGE32(
MI, BB);
1273 case Mips::SNZ_B_PSEUDO:
1274 return emitMSACBranchPseudo(
MI, BB, Mips::BNZ_B);
1275 case Mips::SNZ_H_PSEUDO:
1276 return emitMSACBranchPseudo(
MI, BB, Mips::BNZ_H);
1277 case Mips::SNZ_W_PSEUDO:
1278 return emitMSACBranchPseudo(
MI, BB, Mips::BNZ_W);
1279 case Mips::SNZ_D_PSEUDO:
1280 return emitMSACBranchPseudo(
MI, BB, Mips::BNZ_D);
1281 case Mips::SNZ_V_PSEUDO:
1282 return emitMSACBranchPseudo(
MI, BB, Mips::BNZ_V);
1283 case Mips::SZ_B_PSEUDO:
1284 return emitMSACBranchPseudo(
MI, BB, Mips::BZ_B);
1285 case Mips::SZ_H_PSEUDO:
1286 return emitMSACBranchPseudo(
MI, BB, Mips::BZ_H);
1287 case Mips::SZ_W_PSEUDO:
1288 return emitMSACBranchPseudo(
MI, BB, Mips::BZ_W);
1289 case Mips::SZ_D_PSEUDO:
1290 return emitMSACBranchPseudo(
MI, BB, Mips::BZ_D);
1291 case Mips::SZ_V_PSEUDO:
1292 return emitMSACBranchPseudo(
MI, BB, Mips::BZ_V);
1293 case Mips::COPY_FW_PSEUDO:
1294 return emitCOPY_FW(
MI, BB);
1295 case Mips::COPY_FD_PSEUDO:
1296 return emitCOPY_FD(
MI, BB);
1297 case Mips::INSERT_FW_PSEUDO:
1298 return emitINSERT_FW(
MI, BB);
1299 case Mips::INSERT_FD_PSEUDO:
1300 return emitINSERT_FD(
MI, BB);
1301 case Mips::INSERT_B_VIDX_PSEUDO:
1302 case Mips::INSERT_B_VIDX64_PSEUDO:
1303 return emitINSERT_DF_VIDX(
MI, BB, 1,
false);
1304 case Mips::INSERT_H_VIDX_PSEUDO:
1305 case Mips::INSERT_H_VIDX64_PSEUDO:
1306 return emitINSERT_DF_VIDX(
MI, BB, 2,
false);
1307 case Mips::INSERT_W_VIDX_PSEUDO:
1308 case Mips::INSERT_W_VIDX64_PSEUDO:
1309 return emitINSERT_DF_VIDX(
MI, BB, 4,
false);
1310 case Mips::INSERT_D_VIDX_PSEUDO:
1311 case Mips::INSERT_D_VIDX64_PSEUDO:
1312 return emitINSERT_DF_VIDX(
MI, BB, 8,
false);
1313 case Mips::INSERT_FW_VIDX_PSEUDO:
1314 case Mips::INSERT_FW_VIDX64_PSEUDO:
1315 return emitINSERT_DF_VIDX(
MI, BB, 4,
true);
1316 case Mips::INSERT_FD_VIDX_PSEUDO:
1317 case Mips::INSERT_FD_VIDX64_PSEUDO:
1318 return emitINSERT_DF_VIDX(
MI, BB, 8,
true);
1319 case Mips::FILL_FW_PSEUDO:
1320 return emitFILL_FW(
MI, BB);
1321 case Mips::FILL_FD_PSEUDO:
1322 return emitFILL_FD(
MI, BB);
1323 case Mips::FEXP2_W_1_PSEUDO:
1324 return emitFEXP2_W_1(
MI, BB);
1325 case Mips::FEXP2_D_1_PSEUDO:
1326 return emitFEXP2_D_1(
MI, BB);
1330bool MipsSETargetLowering::isEligibleForTailCallOptimization(
1331 const CCState &CCInfo,
unsigned NextStackOffset,
1345void MipsSETargetLowering::
1347 std::deque<std::pair<unsigned, SDValue>> &RegsToPass,
1348 bool IsPICCall,
bool GlobalOrExternal,
bool InternalLinkage,
1349 bool IsCallReloc, CallLoweringInfo &CLI,
SDValue Callee,
1351 Ops.push_back(Callee);
1353 InternalLinkage, IsCallReloc, CLI, Callee,
1375 MVT::i32,
DL,
Lo.getValue(1), Ptr, MachinePointerInfo(),
1410 return DAG.
getStore(Chain,
DL,
Hi, Ptr, MachinePointerInfo(),
1418 MVT Src =
Op.getOperand(0).getValueType().getSimpleVT();
1419 MVT Dest =
Op.getValueType().getSimpleVT();
1422 if (Src == MVT::i64 && Dest == MVT::f64) {
1426 return DAG.
getNode(MipsISD::BuildPairF64,
DL, MVT::f64,
Lo,
Hi);
1430 if (Src == MVT::f64 && Dest == MVT::i64) {
1437 DAG.
getNode(MipsISD::ExtractElementF64,
DL, MVT::i32,
Op.getOperand(0),
1440 DAG.
getNode(MipsISD::ExtractElementF64,
DL, MVT::i32,
Op.getOperand(0),
1450 bool HasLo,
bool HasHi,
1455 EVT Ty =
Op.getOperand(0).getValueType();
1458 Op.getOperand(0),
Op.getOperand(1));
1466 if (!HasLo || !HasHi)
1467 return HasLo ?
Lo :
Hi;
1475 std::tie(InLo, InHi) = DAG.
SplitScalar(In,
DL, MVT::i32, MVT::i32);
1476 return DAG.
getNode(MipsISD::MTLOHI,
DL, MVT::Untyped, InLo, InHi);
1499 bool HasChainIn =
Op->getOperand(0).getValueType() == MVT::Other;
1505 Ops.push_back(
Op->getOperand(OpNo++));
1511 SDValue Opnd =
Op->getOperand(++OpNo), In64;
1516 Ops.push_back(Opnd);
1519 for (++OpNo ; OpNo <
Op->getNumOperands(); ++OpNo)
1520 Ops.push_back(
Op->getOperand(OpNo));
1524 Ops.push_back(In64);
1529 for (
EVT Ty :
Op->values())
1530 ResTys.
push_back((Ty == MVT::i64) ? MVT::Untyped : Ty);
1549 EVT ResTy =
Op->getValueType(0);
1559 EVT ResVecTy =
Op->getValueType(0);
1560 EVT ViaVecTy = ResVecTy;
1570 if (ResVecTy == MVT::v2i64) {
1581 ViaVecTy = MVT::v4i32;
1587 SDValue Ops[16] = { LaneA, LaneB, LaneA, LaneB, LaneA, LaneB, LaneA, LaneB,
1588 LaneA, LaneB, LaneA, LaneB, LaneA, LaneB, LaneA, LaneB };
1593 if (ViaVecTy != ResVecTy) {
1603 bool IsSigned =
false) {
1606 APInt(
Op->getValueType(0).getScalarType().getSizeInBits(),
1607 IsSigned ? CImm->getSExtValue() : CImm->getZExtValue(), IsSigned),
1613 EVT ViaVecTy = VecTy;
1614 SDValue SplatValueA = SplatValue;
1615 SDValue SplatValueB = SplatValue;
1618 if (VecTy == MVT::v2i64) {
1620 ViaVecTy = MVT::v4i32;
1633 SDValue Ops[16] = { SplatValueA, SplatValueB, SplatValueA, SplatValueB,
1634 SplatValueA, SplatValueB, SplatValueA, SplatValueB,
1635 SplatValueA, SplatValueB, SplatValueA, SplatValueB,
1636 SplatValueA, SplatValueB, SplatValueA, SplatValueB };
1641 if (VecTy != ViaVecTy)
1650 EVT VecTy =
Op->getValueType(0);
1656 if (VecTy == MVT::v2i64) {
1658 APInt BitImm =
APInt(64, 1) << CImm->getAPIntValue();
1670 {BitImmLoOp, BitImmHiOp, BitImmLoOp, BitImmHiOp}));
1679 if (VecTy == MVT::v2i64)
1693 EVT ResTy =
Op->getValueType(0);
1696 MVT ResEltTy = ResTy == MVT::v2i64 ? MVT::i64 : MVT::i32;
1705 EVT ResTy =
Op->getValueType(0);
1716 EVT ResTy =
Op->getValueType(0);
1718 <<
Op->getConstantOperandAPInt(2);
1727 unsigned Intrinsic =
Op->getConstantOperandVal(0);
1728 switch (Intrinsic) {
1731 case Intrinsic::mips_shilo:
1733 case Intrinsic::mips_dpau_h_qbl:
1735 case Intrinsic::mips_dpau_h_qbr:
1737 case Intrinsic::mips_dpsu_h_qbl:
1739 case Intrinsic::mips_dpsu_h_qbr:
1741 case Intrinsic::mips_dpa_w_ph:
1743 case Intrinsic::mips_dps_w_ph:
1745 case Intrinsic::mips_dpax_w_ph:
1747 case Intrinsic::mips_dpsx_w_ph:
1749 case Intrinsic::mips_mulsa_w_ph:
1751 case Intrinsic::mips_mult:
1753 case Intrinsic::mips_multu:
1755 case Intrinsic::mips_madd:
1757 case Intrinsic::mips_maddu:
1759 case Intrinsic::mips_msub:
1761 case Intrinsic::mips_msubu:
1763 case Intrinsic::mips_addv_b:
1764 case Intrinsic::mips_addv_h:
1765 case Intrinsic::mips_addv_w:
1766 case Intrinsic::mips_addv_d:
1769 case Intrinsic::mips_addvi_b:
1770 case Intrinsic::mips_addvi_h:
1771 case Intrinsic::mips_addvi_w:
1772 case Intrinsic::mips_addvi_d:
1775 case Intrinsic::mips_and_v:
1778 case Intrinsic::mips_andi_b:
1781 case Intrinsic::mips_bclr_b:
1782 case Intrinsic::mips_bclr_h:
1783 case Intrinsic::mips_bclr_w:
1784 case Intrinsic::mips_bclr_d:
1786 case Intrinsic::mips_bclri_b:
1787 case Intrinsic::mips_bclri_h:
1788 case Intrinsic::mips_bclri_w:
1789 case Intrinsic::mips_bclri_d:
1791 case Intrinsic::mips_binsli_b:
1792 case Intrinsic::mips_binsli_h:
1793 case Intrinsic::mips_binsli_w:
1794 case Intrinsic::mips_binsli_d: {
1796 EVT VecTy =
Op->getValueType(0);
1801 Op->getConstantOperandVal(3) + 1);
1804 Op->getOperand(2),
Op->getOperand(1));
1806 case Intrinsic::mips_binsri_b:
1807 case Intrinsic::mips_binsri_h:
1808 case Intrinsic::mips_binsri_w:
1809 case Intrinsic::mips_binsri_d: {
1811 EVT VecTy =
Op->getValueType(0);
1816 Op->getConstantOperandVal(3) + 1);
1819 Op->getOperand(2),
Op->getOperand(1));
1821 case Intrinsic::mips_bmnz_v:
1823 Op->getOperand(2),
Op->getOperand(1));
1824 case Intrinsic::mips_bmnzi_b:
1828 case Intrinsic::mips_bmz_v:
1830 Op->getOperand(1),
Op->getOperand(2));
1831 case Intrinsic::mips_bmzi_b:
1835 case Intrinsic::mips_bneg_b:
1836 case Intrinsic::mips_bneg_h:
1837 case Intrinsic::mips_bneg_w:
1838 case Intrinsic::mips_bneg_d: {
1839 EVT VecTy =
Op->getValueType(0);
1846 case Intrinsic::mips_bnegi_b:
1847 case Intrinsic::mips_bnegi_h:
1848 case Intrinsic::mips_bnegi_w:
1849 case Intrinsic::mips_bnegi_d:
1852 case Intrinsic::mips_bnz_b:
1853 case Intrinsic::mips_bnz_h:
1854 case Intrinsic::mips_bnz_w:
1855 case Intrinsic::mips_bnz_d:
1856 return DAG.
getNode(MipsISD::VALL_NONZERO,
DL,
Op->getValueType(0),
1858 case Intrinsic::mips_bnz_v:
1859 return DAG.
getNode(MipsISD::VANY_NONZERO,
DL,
Op->getValueType(0),
1861 case Intrinsic::mips_bsel_v:
1864 Op->getOperand(1),
Op->getOperand(3),
1866 case Intrinsic::mips_bseli_b:
1871 case Intrinsic::mips_bset_b:
1872 case Intrinsic::mips_bset_h:
1873 case Intrinsic::mips_bset_w:
1874 case Intrinsic::mips_bset_d: {
1875 EVT VecTy =
Op->getValueType(0);
1882 case Intrinsic::mips_bseti_b:
1883 case Intrinsic::mips_bseti_h:
1884 case Intrinsic::mips_bseti_w:
1885 case Intrinsic::mips_bseti_d:
1888 case Intrinsic::mips_bz_b:
1889 case Intrinsic::mips_bz_h:
1890 case Intrinsic::mips_bz_w:
1891 case Intrinsic::mips_bz_d:
1892 return DAG.
getNode(MipsISD::VALL_ZERO,
DL,
Op->getValueType(0),
1894 case Intrinsic::mips_bz_v:
1895 return DAG.
getNode(MipsISD::VANY_ZERO,
DL,
Op->getValueType(0),
1897 case Intrinsic::mips_ceq_b:
1898 case Intrinsic::mips_ceq_h:
1899 case Intrinsic::mips_ceq_w:
1900 case Intrinsic::mips_ceq_d:
1903 case Intrinsic::mips_ceqi_b:
1904 case Intrinsic::mips_ceqi_h:
1905 case Intrinsic::mips_ceqi_w:
1906 case Intrinsic::mips_ceqi_d:
1909 case Intrinsic::mips_cle_s_b:
1910 case Intrinsic::mips_cle_s_h:
1911 case Intrinsic::mips_cle_s_w:
1912 case Intrinsic::mips_cle_s_d:
1915 case Intrinsic::mips_clei_s_b:
1916 case Intrinsic::mips_clei_s_h:
1917 case Intrinsic::mips_clei_s_w:
1918 case Intrinsic::mips_clei_s_d:
1921 case Intrinsic::mips_cle_u_b:
1922 case Intrinsic::mips_cle_u_h:
1923 case Intrinsic::mips_cle_u_w:
1924 case Intrinsic::mips_cle_u_d:
1927 case Intrinsic::mips_clei_u_b:
1928 case Intrinsic::mips_clei_u_h:
1929 case Intrinsic::mips_clei_u_w:
1930 case Intrinsic::mips_clei_u_d:
1933 case Intrinsic::mips_clt_s_b:
1934 case Intrinsic::mips_clt_s_h:
1935 case Intrinsic::mips_clt_s_w:
1936 case Intrinsic::mips_clt_s_d:
1939 case Intrinsic::mips_clti_s_b:
1940 case Intrinsic::mips_clti_s_h:
1941 case Intrinsic::mips_clti_s_w:
1942 case Intrinsic::mips_clti_s_d:
1945 case Intrinsic::mips_clt_u_b:
1946 case Intrinsic::mips_clt_u_h:
1947 case Intrinsic::mips_clt_u_w:
1948 case Intrinsic::mips_clt_u_d:
1951 case Intrinsic::mips_clti_u_b:
1952 case Intrinsic::mips_clti_u_h:
1953 case Intrinsic::mips_clti_u_w:
1954 case Intrinsic::mips_clti_u_d:
1957 case Intrinsic::mips_copy_s_b:
1958 case Intrinsic::mips_copy_s_h:
1959 case Intrinsic::mips_copy_s_w:
1961 case Intrinsic::mips_copy_s_d:
1969 Op->getValueType(0),
Op->getOperand(1),
1972 case Intrinsic::mips_copy_u_b:
1973 case Intrinsic::mips_copy_u_h:
1974 case Intrinsic::mips_copy_u_w:
1976 case Intrinsic::mips_copy_u_d:
1987 Op->getValueType(0),
Op->getOperand(1),
1990 case Intrinsic::mips_div_s_b:
1991 case Intrinsic::mips_div_s_h:
1992 case Intrinsic::mips_div_s_w:
1993 case Intrinsic::mips_div_s_d:
1996 case Intrinsic::mips_div_u_b:
1997 case Intrinsic::mips_div_u_h:
1998 case Intrinsic::mips_div_u_w:
1999 case Intrinsic::mips_div_u_d:
2002 case Intrinsic::mips_fadd_w:
2003 case Intrinsic::mips_fadd_d:
2008 case Intrinsic::mips_fceq_w:
2009 case Intrinsic::mips_fceq_d:
2012 case Intrinsic::mips_fcle_w:
2013 case Intrinsic::mips_fcle_d:
2016 case Intrinsic::mips_fclt_w:
2017 case Intrinsic::mips_fclt_d:
2020 case Intrinsic::mips_fcne_w:
2021 case Intrinsic::mips_fcne_d:
2024 case Intrinsic::mips_fcor_w:
2025 case Intrinsic::mips_fcor_d:
2028 case Intrinsic::mips_fcueq_w:
2029 case Intrinsic::mips_fcueq_d:
2032 case Intrinsic::mips_fcule_w:
2033 case Intrinsic::mips_fcule_d:
2036 case Intrinsic::mips_fcult_w:
2037 case Intrinsic::mips_fcult_d:
2040 case Intrinsic::mips_fcun_w:
2041 case Intrinsic::mips_fcun_d:
2044 case Intrinsic::mips_fcune_w:
2045 case Intrinsic::mips_fcune_d:
2048 case Intrinsic::mips_fdiv_w:
2049 case Intrinsic::mips_fdiv_d:
2053 case Intrinsic::mips_ffint_u_w:
2054 case Intrinsic::mips_ffint_u_d:
2057 case Intrinsic::mips_ffint_s_w:
2058 case Intrinsic::mips_ffint_s_d:
2061 case Intrinsic::mips_fill_b:
2062 case Intrinsic::mips_fill_h:
2063 case Intrinsic::mips_fill_w:
2064 case Intrinsic::mips_fill_d: {
2065 EVT ResTy =
Op->getValueType(0);
2073 case Intrinsic::mips_fexp2_w:
2074 case Intrinsic::mips_fexp2_d: {
2076 EVT ResTy =
Op->getValueType(0);
2081 case Intrinsic::mips_flog2_w:
2082 case Intrinsic::mips_flog2_d:
2084 case Intrinsic::mips_fmadd_w:
2085 case Intrinsic::mips_fmadd_d:
2087 Op->getOperand(1),
Op->getOperand(2),
Op->getOperand(3));
2088 case Intrinsic::mips_fmul_w:
2089 case Intrinsic::mips_fmul_d:
2093 case Intrinsic::mips_fmsub_w:
2094 case Intrinsic::mips_fmsub_d: {
2096 return DAG.
getNode(MipsISD::FMS, SDLoc(
Op),
Op->getValueType(0),
2097 Op->getOperand(1),
Op->getOperand(2),
Op->getOperand(3));
2099 case Intrinsic::mips_frint_w:
2100 case Intrinsic::mips_frint_d:
2102 case Intrinsic::mips_fsqrt_w:
2103 case Intrinsic::mips_fsqrt_d:
2105 case Intrinsic::mips_fsub_w:
2106 case Intrinsic::mips_fsub_d:
2110 case Intrinsic::mips_ftrunc_u_w:
2111 case Intrinsic::mips_ftrunc_u_d:
2114 case Intrinsic::mips_ftrunc_s_w:
2115 case Intrinsic::mips_ftrunc_s_d:
2118 case Intrinsic::mips_ilvev_b:
2119 case Intrinsic::mips_ilvev_h:
2120 case Intrinsic::mips_ilvev_w:
2121 case Intrinsic::mips_ilvev_d:
2122 return DAG.
getNode(MipsISD::ILVEV,
DL,
Op->getValueType(0),
2123 Op->getOperand(1),
Op->getOperand(2));
2124 case Intrinsic::mips_ilvl_b:
2125 case Intrinsic::mips_ilvl_h:
2126 case Intrinsic::mips_ilvl_w:
2127 case Intrinsic::mips_ilvl_d:
2128 return DAG.
getNode(MipsISD::ILVL,
DL,
Op->getValueType(0),
2129 Op->getOperand(1),
Op->getOperand(2));
2130 case Intrinsic::mips_ilvod_b:
2131 case Intrinsic::mips_ilvod_h:
2132 case Intrinsic::mips_ilvod_w:
2133 case Intrinsic::mips_ilvod_d:
2134 return DAG.
getNode(MipsISD::ILVOD,
DL,
Op->getValueType(0),
2135 Op->getOperand(1),
Op->getOperand(2));
2136 case Intrinsic::mips_ilvr_b:
2137 case Intrinsic::mips_ilvr_h:
2138 case Intrinsic::mips_ilvr_w:
2139 case Intrinsic::mips_ilvr_d:
2140 return DAG.
getNode(MipsISD::ILVR,
DL,
Op->getValueType(0),
2141 Op->getOperand(1),
Op->getOperand(2));
2142 case Intrinsic::mips_insert_b:
2143 case Intrinsic::mips_insert_h:
2144 case Intrinsic::mips_insert_w:
2145 case Intrinsic::mips_insert_d:
2147 Op->getOperand(1),
Op->getOperand(3),
Op->getOperand(2));
2148 case Intrinsic::mips_insve_b:
2149 case Intrinsic::mips_insve_h:
2150 case Intrinsic::mips_insve_w:
2151 case Intrinsic::mips_insve_d: {
2154 switch (Intrinsic) {
2155 case Intrinsic::mips_insve_b:
Max = 15;
break;
2156 case Intrinsic::mips_insve_h:
Max = 7;
break;
2157 case Intrinsic::mips_insve_w:
Max = 3;
break;
2158 case Intrinsic::mips_insve_d:
Max = 1;
break;
2164 return DAG.
getNode(MipsISD::INSVE,
DL,
Op->getValueType(0),
2165 Op->getOperand(1),
Op->getOperand(2),
Op->getOperand(3),
2168 case Intrinsic::mips_ldi_b:
2169 case Intrinsic::mips_ldi_h:
2170 case Intrinsic::mips_ldi_w:
2171 case Intrinsic::mips_ldi_d:
2173 case Intrinsic::mips_lsa:
2174 case Intrinsic::mips_dlsa: {
2175 EVT ResTy =
Op->getValueType(0);
2178 Op->getOperand(2),
Op->getOperand(3)));
2180 case Intrinsic::mips_maddv_b:
2181 case Intrinsic::mips_maddv_h:
2182 case Intrinsic::mips_maddv_w:
2183 case Intrinsic::mips_maddv_d: {
2184 EVT ResTy =
Op->getValueType(0);
2187 Op->getOperand(2),
Op->getOperand(3)));
2189 case Intrinsic::mips_max_s_b:
2190 case Intrinsic::mips_max_s_h:
2191 case Intrinsic::mips_max_s_w:
2192 case Intrinsic::mips_max_s_d:
2194 Op->getOperand(1),
Op->getOperand(2));
2195 case Intrinsic::mips_max_u_b:
2196 case Intrinsic::mips_max_u_h:
2197 case Intrinsic::mips_max_u_w:
2198 case Intrinsic::mips_max_u_d:
2200 Op->getOperand(1),
Op->getOperand(2));
2201 case Intrinsic::mips_maxi_s_b:
2202 case Intrinsic::mips_maxi_s_h:
2203 case Intrinsic::mips_maxi_s_w:
2204 case Intrinsic::mips_maxi_s_d:
2207 case Intrinsic::mips_maxi_u_b:
2208 case Intrinsic::mips_maxi_u_h:
2209 case Intrinsic::mips_maxi_u_w:
2210 case Intrinsic::mips_maxi_u_d:
2213 case Intrinsic::mips_min_s_b:
2214 case Intrinsic::mips_min_s_h:
2215 case Intrinsic::mips_min_s_w:
2216 case Intrinsic::mips_min_s_d:
2218 Op->getOperand(1),
Op->getOperand(2));
2219 case Intrinsic::mips_min_u_b:
2220 case Intrinsic::mips_min_u_h:
2221 case Intrinsic::mips_min_u_w:
2222 case Intrinsic::mips_min_u_d:
2224 Op->getOperand(1),
Op->getOperand(2));
2225 case Intrinsic::mips_mini_s_b:
2226 case Intrinsic::mips_mini_s_h:
2227 case Intrinsic::mips_mini_s_w:
2228 case Intrinsic::mips_mini_s_d:
2231 case Intrinsic::mips_mini_u_b:
2232 case Intrinsic::mips_mini_u_h:
2233 case Intrinsic::mips_mini_u_w:
2234 case Intrinsic::mips_mini_u_d:
2237 case Intrinsic::mips_mod_s_b:
2238 case Intrinsic::mips_mod_s_h:
2239 case Intrinsic::mips_mod_s_w:
2240 case Intrinsic::mips_mod_s_d:
2243 case Intrinsic::mips_mod_u_b:
2244 case Intrinsic::mips_mod_u_h:
2245 case Intrinsic::mips_mod_u_w:
2246 case Intrinsic::mips_mod_u_d:
2249 case Intrinsic::mips_mulv_b:
2250 case Intrinsic::mips_mulv_h:
2251 case Intrinsic::mips_mulv_w:
2252 case Intrinsic::mips_mulv_d:
2255 case Intrinsic::mips_msubv_b:
2256 case Intrinsic::mips_msubv_h:
2257 case Intrinsic::mips_msubv_w:
2258 case Intrinsic::mips_msubv_d: {
2259 EVT ResTy =
Op->getValueType(0);
2262 Op->getOperand(2),
Op->getOperand(3)));
2264 case Intrinsic::mips_nlzc_b:
2265 case Intrinsic::mips_nlzc_h:
2266 case Intrinsic::mips_nlzc_w:
2267 case Intrinsic::mips_nlzc_d:
2269 case Intrinsic::mips_nor_v: {
2271 Op->getOperand(1),
Op->getOperand(2));
2274 case Intrinsic::mips_nori_b: {
2280 case Intrinsic::mips_or_v:
2283 case Intrinsic::mips_ori_b:
2286 case Intrinsic::mips_pckev_b:
2287 case Intrinsic::mips_pckev_h:
2288 case Intrinsic::mips_pckev_w:
2289 case Intrinsic::mips_pckev_d:
2290 return DAG.
getNode(MipsISD::PCKEV,
DL,
Op->getValueType(0),
2291 Op->getOperand(1),
Op->getOperand(2));
2292 case Intrinsic::mips_pckod_b:
2293 case Intrinsic::mips_pckod_h:
2294 case Intrinsic::mips_pckod_w:
2295 case Intrinsic::mips_pckod_d:
2296 return DAG.
getNode(MipsISD::PCKOD,
DL,
Op->getValueType(0),
2297 Op->getOperand(1),
Op->getOperand(2));
2298 case Intrinsic::mips_pcnt_b:
2299 case Intrinsic::mips_pcnt_h:
2300 case Intrinsic::mips_pcnt_w:
2301 case Intrinsic::mips_pcnt_d:
2303 case Intrinsic::mips_sat_s_b:
2304 case Intrinsic::mips_sat_s_h:
2305 case Intrinsic::mips_sat_s_w:
2306 case Intrinsic::mips_sat_s_d:
2307 case Intrinsic::mips_sat_u_b:
2308 case Intrinsic::mips_sat_u_h:
2309 case Intrinsic::mips_sat_u_w:
2310 case Intrinsic::mips_sat_u_d: {
2313 switch (Intrinsic) {
2314 case Intrinsic::mips_sat_s_b:
2315 case Intrinsic::mips_sat_u_b:
Max = 7;
break;
2316 case Intrinsic::mips_sat_s_h:
2317 case Intrinsic::mips_sat_u_h:
Max = 15;
break;
2318 case Intrinsic::mips_sat_s_w:
2319 case Intrinsic::mips_sat_u_w:
Max = 31;
break;
2320 case Intrinsic::mips_sat_s_d:
2321 case Intrinsic::mips_sat_u_d:
Max = 63;
break;
2329 case Intrinsic::mips_shf_b:
2330 case Intrinsic::mips_shf_h:
2331 case Intrinsic::mips_shf_w: {
2335 return DAG.
getNode(MipsISD::SHF,
DL,
Op->getValueType(0),
2336 Op->getOperand(2),
Op->getOperand(1));
2338 case Intrinsic::mips_sldi_b:
2339 case Intrinsic::mips_sldi_h:
2340 case Intrinsic::mips_sldi_w:
2341 case Intrinsic::mips_sldi_d: {
2344 switch (Intrinsic) {
2345 case Intrinsic::mips_sldi_b:
Max = 15;
break;
2346 case Intrinsic::mips_sldi_h:
Max = 7;
break;
2347 case Intrinsic::mips_sldi_w:
Max = 3;
break;
2348 case Intrinsic::mips_sldi_d:
Max = 1;
break;
2356 case Intrinsic::mips_sll_b:
2357 case Intrinsic::mips_sll_h:
2358 case Intrinsic::mips_sll_w:
2359 case Intrinsic::mips_sll_d:
2362 case Intrinsic::mips_slli_b:
2363 case Intrinsic::mips_slli_h:
2364 case Intrinsic::mips_slli_w:
2365 case Intrinsic::mips_slli_d:
2368 case Intrinsic::mips_splat_b:
2369 case Intrinsic::mips_splat_h:
2370 case Intrinsic::mips_splat_w:
2371 case Intrinsic::mips_splat_d:
2376 return DAG.
getNode(MipsISD::VSHF,
DL,
Op->getValueType(0),
2379 case Intrinsic::mips_splati_b:
2380 case Intrinsic::mips_splati_h:
2381 case Intrinsic::mips_splati_w:
2382 case Intrinsic::mips_splati_d:
2383 return DAG.
getNode(MipsISD::VSHF,
DL,
Op->getValueType(0),
2386 case Intrinsic::mips_sra_b:
2387 case Intrinsic::mips_sra_h:
2388 case Intrinsic::mips_sra_w:
2389 case Intrinsic::mips_sra_d:
2392 case Intrinsic::mips_srai_b:
2393 case Intrinsic::mips_srai_h:
2394 case Intrinsic::mips_srai_w:
2395 case Intrinsic::mips_srai_d:
2398 case Intrinsic::mips_srari_b:
2399 case Intrinsic::mips_srari_h:
2400 case Intrinsic::mips_srari_w:
2401 case Intrinsic::mips_srari_d: {
2404 switch (Intrinsic) {
2405 case Intrinsic::mips_srari_b:
Max = 7;
break;
2406 case Intrinsic::mips_srari_h:
Max = 15;
break;
2407 case Intrinsic::mips_srari_w:
Max = 31;
break;
2408 case Intrinsic::mips_srari_d:
Max = 63;
break;
2416 case Intrinsic::mips_srl_b:
2417 case Intrinsic::mips_srl_h:
2418 case Intrinsic::mips_srl_w:
2419 case Intrinsic::mips_srl_d:
2422 case Intrinsic::mips_srli_b:
2423 case Intrinsic::mips_srli_h:
2424 case Intrinsic::mips_srli_w:
2425 case Intrinsic::mips_srli_d:
2428 case Intrinsic::mips_srlri_b:
2429 case Intrinsic::mips_srlri_h:
2430 case Intrinsic::mips_srlri_w:
2431 case Intrinsic::mips_srlri_d: {
2434 switch (Intrinsic) {
2435 case Intrinsic::mips_srlri_b:
Max = 7;
break;
2436 case Intrinsic::mips_srlri_h:
Max = 15;
break;
2437 case Intrinsic::mips_srlri_w:
Max = 31;
break;
2438 case Intrinsic::mips_srlri_d:
Max = 63;
break;
2446 case Intrinsic::mips_subv_b:
2447 case Intrinsic::mips_subv_h:
2448 case Intrinsic::mips_subv_w:
2449 case Intrinsic::mips_subv_d:
2452 case Intrinsic::mips_subvi_b:
2453 case Intrinsic::mips_subvi_h:
2454 case Intrinsic::mips_subvi_w:
2455 case Intrinsic::mips_subvi_d:
2458 case Intrinsic::mips_vshf_b:
2459 case Intrinsic::mips_vshf_h:
2460 case Intrinsic::mips_vshf_w:
2461 case Intrinsic::mips_vshf_d:
2462 return DAG.
getNode(MipsISD::VSHF,
DL,
Op->getValueType(0),
2463 Op->getOperand(1),
Op->getOperand(2),
Op->getOperand(3));
2464 case Intrinsic::mips_xor_v:
2467 case Intrinsic::mips_xori_b:
2470 case Intrinsic::thread_pointer: {
2472 return DAG.
getNode(MipsISD::ThreadPointer,
DL, PtrVT);
2483 EVT ResTy =
Op->getValueType(0);
2484 EVT PtrTy = Address->getValueType(0);
2499 unsigned Intr =
Op->getConstantOperandVal(1);
2503 case Intrinsic::mips_extp:
2505 case Intrinsic::mips_extpdp:
2507 case Intrinsic::mips_extr_w:
2509 case Intrinsic::mips_extr_r_w:
2511 case Intrinsic::mips_extr_rs_w:
2513 case Intrinsic::mips_extr_s_h:
2515 case Intrinsic::mips_mthlip:
2517 case Intrinsic::mips_mulsaq_s_w_ph:
2519 case Intrinsic::mips_maq_s_w_phl:
2521 case Intrinsic::mips_maq_s_w_phr:
2523 case Intrinsic::mips_maq_sa_w_phl:
2525 case Intrinsic::mips_maq_sa_w_phr:
2527 case Intrinsic::mips_dpaq_s_w_ph:
2529 case Intrinsic::mips_dpsq_s_w_ph:
2531 case Intrinsic::mips_dpaq_sa_l_w:
2533 case Intrinsic::mips_dpsq_sa_l_w:
2535 case Intrinsic::mips_dpaqx_s_w_ph:
2537 case Intrinsic::mips_dpaqx_sa_w_ph:
2539 case Intrinsic::mips_dpsqx_s_w_ph:
2541 case Intrinsic::mips_dpsqx_sa_w_ph:
2543 case Intrinsic::mips_ld_b:
2544 case Intrinsic::mips_ld_h:
2545 case Intrinsic::mips_ld_w:
2546 case Intrinsic::mips_ld_d:
2558 EVT PtrTy = Address->getValueType(0);
2574 unsigned Intr =
Op->getConstantOperandVal(1);
2578 case Intrinsic::mips_st_b:
2579 case Intrinsic::mips_st_h:
2580 case Intrinsic::mips_st_w:
2581 case Intrinsic::mips_st_d:
2596 EVT ResTy =
Op->getValueType(0);
2606 return DAG.
getNode(MipsISD::VEXTRACT_SEXT_ELT,
DL, ResTy, Op0, Op1,
2624 for (
unsigned i = 0; i <
Op->getNumOperands(); ++i)
2646 EVT ResTy =
Op->getValueType(0);
2648 APInt SplatValue, SplatUndef;
2649 unsigned SplatBitSize;
2655 if (
Node->isConstantSplat(SplatValue, SplatUndef, SplatBitSize,
2657 !
Subtarget.isLittle()) && SplatBitSize <= 64) {
2659 if (SplatBitSize != 8 && SplatBitSize != 16 && SplatBitSize != 32 &&
2671 switch (SplatBitSize) {
2675 ViaVecTy = MVT::v16i8;
2678 ViaVecTy = MVT::v8i16;
2681 ViaVecTy = MVT::v4i32;
2692 if (ViaVecTy != ResTy)
2702 EVT ResTy =
Node->getValueType(0);
2708 for (
unsigned i = 0; i < NumElts; ++i) {
2710 Node->getOperand(i),
2740 int SHFIndices[4] = { -1, -1, -1, -1 };
2742 if (Indices.
size() < 4)
2745 for (
unsigned i = 0; i < 4; ++i) {
2746 for (
unsigned j = i; j < Indices.
size(); j += 4) {
2747 int Idx = Indices[j];
2753 if (Idx < 0 || Idx >= 4)
2759 if (SHFIndices[i] == -1)
2760 SHFIndices[i] = Idx;
2764 if (!(Idx == -1 || Idx == SHFIndices[i]))
2771 for (
int i = 3; i >= 0; --i) {
2772 int Idx = SHFIndices[i];
2782 return DAG.
getNode(MipsISD::SHF,
DL, ResTy,
2789template <
typename ValType>
2792 unsigned CheckStride,
2794 ValType ExpectedIndex,
unsigned ExpectedIndexStride) {
2798 if (*
I != -1 && *
I != ExpectedIndex)
2800 ExpectedIndex += ExpectedIndexStride;
2804 for (
unsigned n = 0; n < CheckStride &&
I != End; ++n, ++
I)
2823 int SplatIndex = -1;
2824 for (
const auto &V : Indices) {
2857 const auto &Begin = Indices.
begin();
2858 const auto &End = Indices.
end();
2863 Wt =
Op->getOperand(0);
2865 Wt =
Op->getOperand(1);
2872 Ws =
Op->getOperand(0);
2874 Ws =
Op->getOperand(1);
2903 const auto &Begin = Indices.
begin();
2904 const auto &End = Indices.
end();
2909 Wt =
Op->getOperand(0);
2911 Wt =
Op->getOperand(1);
2918 Ws =
Op->getOperand(0);
2920 Ws =
Op->getOperand(1);
2950 const auto &Begin = Indices.
begin();
2951 const auto &End = Indices.
end();
2956 Wt =
Op->getOperand(0);
2958 Wt =
Op->getOperand(1);
2965 Ws =
Op->getOperand(0);
2967 Ws =
Op->getOperand(1);
2995 unsigned HalfSize = Indices.
size() / 2;
2998 const auto &Begin = Indices.
begin();
2999 const auto &End = Indices.
end();
3004 Wt =
Op->getOperand(0);
3006 Wt =
Op->getOperand(1);
3013 Ws =
Op->getOperand(0);
3016 Ws =
Op->getOperand(1);
3045 const auto &Begin = Indices.
begin();
3046 const auto &Mid = Indices.
begin() + Indices.
size() / 2;
3047 const auto &End = Indices.
end();
3050 Wt =
Op->getOperand(0);
3052 Wt =
Op->getOperand(1);
3057 Ws =
Op->getOperand(0);
3059 Ws =
Op->getOperand(1);
3088 const auto &Begin = Indices.
begin();
3089 const auto &Mid = Indices.
begin() + Indices.
size() / 2;
3090 const auto &End = Indices.
end();
3093 Wt =
Op->getOperand(0);
3095 Wt =
Op->getOperand(1);
3100 Ws =
Op->getOperand(0);
3102 Ws =
Op->getOperand(1);
3124 const bool isSPLATI,
3131 bool Using1stVec =
false;
3132 bool Using2ndVec =
false;
3136 assert(Indices[0] >= 0 &&
3137 "shuffle mask starts with an UNDEF, which is not expected");
3139 for (
int i = 0; i < ResTyNumElts; ++i) {
3141 int Idx = Indices[i];
3143 if (0 <= Idx && Idx < ResTyNumElts)
3145 if (ResTyNumElts <= Idx && Idx < ResTyNumElts * 2)
3148 int LastValidIndex = 0;
3149 for (
size_t i = 0; i < Indices.
size(); i++) {
3150 int Idx = Indices[i];
3153 Idx = isSPLATI ? Indices[0] : LastValidIndex;
3155 LastValidIndex = Idx;
3162 if (Using1stVec && Using2ndVec) {
3163 Op0 =
Op->getOperand(0);
3164 Op1 =
Op->getOperand(1);
3165 }
else if (Using1stVec)
3166 Op0 = Op1 =
Op->getOperand(0);
3167 else if (Using2ndVec)
3168 Op0 = Op1 =
Op->getOperand(1);
3170 llvm_unreachable(
"shuffle vector mask references neither vector operand?");
3179 return DAG.
getNode(MipsISD::VSHF,
DL, ResTy, MaskVec, Op1, Op0);
3187 EVT ResTy =
Op->getValueType(0);
3193 SmallVector<int, 16> Indices;
3195 for (
int i = 0; i < ResTyNumElts; ++i)
3238 const TargetRegisterClass *RC = &Mips::GPR32RegClass;
3244 MachineBasicBlock *
TBB =
F->CreateMachineBasicBlock(LLVM_BB);
3245 MachineBasicBlock *
Sink =
F->CreateMachineBasicBlock(LLVM_BB);
3248 F->insert(It, Sink);
3253 Sink->transferSuccessorsAndUpdatePHIs(BB);
3279 MI.getOperand(0).getReg())
3285 MI.eraseFromParent();
3307 const TargetRegisterClass *RC = &Mips::GPR32RegClass;
3312 MachineBasicBlock *FBB =
F->CreateMachineBasicBlock(LLVM_BB);
3313 MachineBasicBlock *
TBB =
F->CreateMachineBasicBlock(LLVM_BB);
3314 MachineBasicBlock *
Sink =
F->CreateMachineBasicBlock(LLVM_BB);
3317 F->insert(It, Sink);
3322 Sink->transferSuccessorsAndUpdatePHIs(BB);
3348 MI.getOperand(0).getReg())
3354 MI.eraseFromParent();
3376 unsigned Lane =
MI.getOperand(2).getImm();
3391 Subtarget.useOddSPReg() ? &Mips::MSA128WRegClass
3392 : &Mips::MSA128WEvensRegClass);
3398 MI.eraseFromParent();
3421 unsigned Lane =
MI.getOperand(2).getImm() * 2;
3433 MI.eraseFromParent();
3451 unsigned Lane =
MI.getOperand(2).getImm();
3454 Subtarget.useOddSPReg() ? &Mips::MSA128WRegClass
3455 : &Mips::MSA128WEvensRegClass);
3466 MI.eraseFromParent();
3486 unsigned Lane =
MI.getOperand(2).getImm();
3499 MI.eraseFromParent();
3530 Register SrcVecReg =
MI.getOperand(1).getReg();
3531 Register LaneReg =
MI.getOperand(2).getReg();
3532 Register SrcValReg =
MI.getOperand(3).getReg();
3534 const TargetRegisterClass *VecRC =
nullptr;
3536 const TargetRegisterClass *GPRRC =
3537 Subtarget.isABI_N64() ? &Mips::GPR64RegClass : &Mips::GPR32RegClass;
3538 unsigned SubRegIdx =
Subtarget.isABI_N64() ? Mips::sub_32 : 0;
3539 unsigned ShiftOp =
Subtarget.isABI_N64() ? Mips::DSLL : Mips::SLL;
3540 unsigned EltLog2Size;
3541 unsigned InsertOp = 0;
3542 unsigned InsveOp = 0;
3543 switch (EltSizeInBytes) {
3548 InsertOp = Mips::INSERT_B;
3549 InsveOp = Mips::INSVE_B;
3550 VecRC = &Mips::MSA128BRegClass;
3554 InsertOp = Mips::INSERT_H;
3555 InsveOp = Mips::INSVE_H;
3556 VecRC = &Mips::MSA128HRegClass;
3560 InsertOp = Mips::INSERT_W;
3561 InsveOp = Mips::INSVE_W;
3562 VecRC = &Mips::MSA128WRegClass;
3566 InsertOp = Mips::INSERT_D;
3567 InsveOp = Mips::INSVE_D;
3568 VecRC = &Mips::MSA128DRegClass;
3576 .
addImm(EltSizeInBytes == 8 ? Mips::sub_64 : Mips::sub_lo);
3581 if (EltSizeInBytes != 1) {
3594 .
addReg(LaneReg, {}, SubRegIdx);
3623 .
addReg(LaneTmp2, {}, SubRegIdx);
3625 MI.eraseFromParent();
3645 Subtarget.useOddSPReg() ? &Mips::MSA128WRegClass
3646 : &Mips::MSA128WEvensRegClass);
3648 Subtarget.useOddSPReg() ? &Mips::MSA128WRegClass
3649 : &Mips::MSA128WEvensRegClass);
3658 MI.eraseFromParent();
3689 MI.eraseFromParent();
3704 const TargetRegisterClass *RC = &Mips::MSA128WRegClass;
3716 .
addReg(
MI.getOperand(1).getReg());
3718 MI.eraseFromParent();
3733 const TargetRegisterClass *RC = &Mips::MSA128DRegClass;
3745 .
addReg(
MI.getOperand(1).getReg());
3747 MI.eraseFromParent();
static SDValue performSHLCombine(SDNode *N, TargetLowering::DAGCombinerInfo &DCI, SelectionDAG &DAG)
If the operand is a bitwise AND with a constant RHS, and the shift has a constant RHS and is the only...
static SDValue performORCombine(SDNode *N, TargetLowering::DAGCombinerInfo &DCI)
static SDValue performANDCombine(SDNode *N, TargetLowering::DAGCombinerInfo &DCI)
static SDValue performSETCCCombine(SDNode *N, TargetLowering::DAGCombinerInfo &DCI, SelectionDAG &DAG)
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
This file implements a class to represent arbitrary precision integral constant values and operations...
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
const HexagonInstrInfo * TII
const AbstractManglingParser< Derived, Alloc >::OperatorInfo AbstractManglingParser< Derived, Alloc >::Ops[]
static bool fitsRegularPattern(typename SmallVectorImpl< ValType >::const_iterator Begin, unsigned CheckStride, typename SmallVectorImpl< ValType >::const_iterator End, ValType ExpectedIndex, unsigned ExpectedIndexStride)
Determine whether a range fits a regular pattern of values.
static SDValue performVSELECTCombine(SDNode *N, SelectionDAG &DAG, TargetLowering::DAGCombinerInfo &DCI, const LoongArchSubtarget &Subtarget)
static SDValue performSRLCombine(SDNode *N, SelectionDAG &DAG, TargetLowering::DAGCombinerInfo &DCI, const LoongArchSubtarget &Subtarget)
static SDValue truncateVecElts(SDNode *Node, SelectionDAG &DAG)
Promote Memory to Register
static SDValue lowerMSABinaryBitImmIntr(SDValue Op, SelectionDAG &DAG, unsigned Opc, SDValue Imm, bool BigEndian)
static SDValue lowerMSABitClearImm(SDValue Op, SelectionDAG &DAG)
static SDValue performMULCombine(SDNode *N, SelectionDAG &DAG, const TargetLowering::DAGCombinerInfo &DCI, const MipsSETargetLowering *TL, const MipsSubtarget &Subtarget)
static SDValue performXORCombine(SDNode *N, SelectionDAG &DAG, const MipsSubtarget &Subtarget)
static SDValue lowerDSPIntr(SDValue Op, SelectionDAG &DAG, unsigned Opc)
static SDValue performDSPShiftCombine(unsigned Opc, SDNode *N, EVT Ty, SelectionDAG &DAG, const MipsSubtarget &Subtarget)
static SDValue lowerMSACopyIntr(SDValue Op, SelectionDAG &DAG, unsigned Opc)
static cl::opt< bool > NoDPLoadStore("mno-ldc1-sdc1", cl::init(false), cl::desc("Expand double precision loads and " "stores to their single precision " "counterparts"))
static SDValue lowerVECTOR_SHUFFLE_ILVR(SDValue Op, EVT ResTy, SmallVector< int, 16 > Indices, SelectionDAG &DAG)
static SDValue getBuildVectorSplat(EVT VecTy, SDValue SplatValue, bool BigEndian, SelectionDAG &DAG)
static bool isVSplat(SDValue N, APInt &Imm, bool IsLittleEndian)
static SDValue initAccumulator(SDValue In, const SDLoc &DL, SelectionDAG &DAG)
static bool isBitwiseInverse(SDValue N, SDValue OfNode)
static SDValue lowerMSAStoreIntr(SDValue Op, SelectionDAG &DAG, unsigned Intr, const MipsSubtarget &Subtarget)
static SDValue performSRACombine(SDNode *N, SelectionDAG &DAG, TargetLowering::DAGCombinerInfo &DCI, const MipsSubtarget &Subtarget)
static bool isVectorAllOnes(SDValue N)
static SDValue lowerVECTOR_SHUFFLE_PCKOD(SDValue Op, EVT ResTy, SmallVector< int, 16 > Indices, SelectionDAG &DAG)
static SDValue performFP_TO_UINTCombine(SDNode *N, SelectionDAG &DAG)
static bool isLegalDSPCondCode(EVT Ty, ISD::CondCode CC)
static SDValue lowerMSASplatZExt(SDValue Op, unsigned OpNr, SelectionDAG &DAG)
static SDValue lowerMSABitClear(SDValue Op, SelectionDAG &DAG)
static SDValue lowerVECTOR_SHUFFLE_PCKEV(SDValue Op, EVT ResTy, SmallVector< int, 16 > Indices, SelectionDAG &DAG)
static SDValue genConstMult(SDValue X, APInt C, const SDLoc &DL, EVT VT, EVT ShiftTy, SelectionDAG &DAG)
static SDValue lowerMSASplatImm(SDValue Op, unsigned ImmOp, SelectionDAG &DAG, bool IsSigned=false)
static SDValue lowerVECTOR_SHUFFLE_ILVOD(SDValue Op, EVT ResTy, SmallVector< int, 16 > Indices, SelectionDAG &DAG)
static bool isConstantOrUndef(const SDValue Op)
static SDValue lowerVECTOR_SHUFFLE_VSHF(SDValue Op, EVT ResTy, const SmallVector< int, 16 > &Indices, const bool isSPLATI, SelectionDAG &DAG)
static SDValue lowerVECTOR_SHUFFLE_SHF(SDValue Op, EVT ResTy, SmallVector< int, 16 > Indices, SelectionDAG &DAG)
static SDValue extractLOHI(SDValue Op, const SDLoc &DL, SelectionDAG &DAG)
static bool shouldTransformMulToShiftsAddsSubs(APInt C, EVT VT, SelectionDAG &DAG, const MipsSubtarget &Subtarget)
static SDValue lowerVECTOR_SHUFFLE_ILVEV(SDValue Op, EVT ResTy, SmallVector< int, 16 > Indices, SelectionDAG &DAG)
static bool isVECTOR_SHUFFLE_SPLATI(SDValue Op, EVT ResTy, SmallVector< int, 16 > Indices, SelectionDAG &DAG)
static bool isConstantOrUndefBUILD_VECTOR(const BuildVectorSDNode *Op)
static SDValue lowerMSALoadIntr(SDValue Op, SelectionDAG &DAG, unsigned Intr, const MipsSubtarget &Subtarget)
static SDValue lowerVECTOR_SHUFFLE_ILVL(SDValue Op, EVT ResTy, SmallVector< int, 16 > Indices, SelectionDAG &DAG)
const SmallVectorImpl< MachineOperand > MachineBasicBlock * TBB
const SmallVectorImpl< MachineOperand > & Cond
static cl::opt< unsigned > MaxSteps("has-predecessor-max-steps", cl::Hidden, cl::init(8192), cl::desc("DAG combiner limit number of steps when searching DAG " "for predecessor nodes"))
This file defines the SmallVector class.
This file describes how to lower LLVM code to machine code.
Class for arbitrary precision integers.
uint64_t getZExtValue() const
Get zero extended value.
LLVM_ABI APInt trunc(unsigned width) const
Truncate to new width.
bool isAllOnes() const
Determine if all bits are set. This is true for zero-width values.
unsigned getBitWidth() const
Return the number of bits in the APInt.
bool isNegative() const
Determine sign of this APInt.
unsigned logBase2() const
bool isPowerOf2() const
Check if this APInt's value is a power of two greater than zero.
static APInt getLowBitsSet(unsigned numBits, unsigned loBitsSet)
Constructs an APInt value that has the bottom loBitsSet bits set.
static APInt getHighBitsSet(unsigned numBits, unsigned hiBitsSet)
Constructs an APInt value that has the top hiBitsSet bits set.
APInt lshr(unsigned shiftAmt) const
Logical right-shift function.
Represent a constant reference to an array (0 or more elements consecutively in memory),...
A "pseudo-class" with methods for operating on BUILD_VECTORs.
LLVM_ABI bool isConstantSplat(APInt &SplatValue, APInt &SplatUndef, unsigned &SplatBitSize, bool &HasAnyUndefs, unsigned MinSplatBits=0, bool isBigEndian=false) const
Check if this is a constant splat, and if so, find the smallest element size that splats the vector.
CCState - This class holds information needed while lowering arguments and return values.
unsigned getInRegsParamsCount() const
uint64_t getZExtValue() const
const SDValue & getBasePtr() const
const Triple & getTargetTriple() const
TypeSize getSizeInBits() const
Returns the size of the specified MVT in bits.
static auto fixedlen_vector_valuetypes()
const BasicBlock * getBasicBlock() const
Return the LLVM basic block that this instance corresponded to originally.
LLVM_ABI void addSuccessor(MachineBasicBlock *Succ, BranchProbability Prob=BranchProbability::getUnknown())
Add Succ as a successor of this MachineBasicBlock.
const MachineFunction * getParent() const
Return the MachineFunction containing this basic block.
MachineInstrBundleIterator< MachineInstr > iterator
MachineRegisterInfo & getRegInfo()
getRegInfo - Return information about the registers currently in use.
BasicBlockListType::iterator iterator
MachineBasicBlock * CreateMachineBasicBlock(const BasicBlock *BB=nullptr, std::optional< UniqueBBID > BBID=std::nullopt)
CreateMachineInstr - Allocate a new MachineInstr.
const MachineInstrBuilder & addReg(Register RegNo, RegState Flags={}, unsigned SubReg=0) const
Add a new virtual register operand.
const MachineInstrBuilder & addImm(int64_t Val) const
Add a new immediate operand.
const MachineInstrBuilder & addMBB(MachineBasicBlock *MBB, unsigned TargetFlags=0) const
Representation of each machine instruction.
Flags
Flags values. These may be or'd together.
Flags getFlags() const
Return the raw flags of the source value,.
LLVM_ABI Register createVirtualRegister(const TargetRegisterClass *RegClass, StringRef Name="")
createVirtualRegister - Create and return a new virtual register in the function with the specified r...
AAMDNodes getAAInfo() const
Returns the AA info that describes the dereference.
MachineMemOperand * getMemOperand() const
Return the unique MachineMemOperand object describing the memory reference performed by operation.
const SDValue & getChain() const
EVT getMemoryVT() const
Return the type of the in-memory value.
MipsFunctionInfo - This class is derived from MachineFunction private Mips target-specific informatio...
unsigned getIncomingArgSize() const
SDValue PerformDAGCombine(SDNode *N, DAGCombinerInfo &DCI) const override
This method will be invoked for all target nodes and for any target-independent nodes that the target...
TargetLoweringBase::LegalizeTypeAction getPreferredVectorAction(MVT VT) const override
Return the preferred vector type legalization action.
void addMSAFloatType(MVT::SimpleValueType Ty, const TargetRegisterClass *RC)
Enable MSA support for the given floating-point type and Register class.
void addMSAIntType(MVT::SimpleValueType Ty, const TargetRegisterClass *RC)
Enable MSA support for the given integer type and Register class.
MachineBasicBlock * EmitInstrWithCustomInserter(MachineInstr &MI, MachineBasicBlock *MBB) const override
This method should be implemented by targets that mark instructions with the 'usesCustomInserter' fla...
const TargetRegisterClass * getRepRegClassFor(MVT VT) const override
Return the 'representative' register class for the specified value type.
bool allowsMisalignedMemoryAccesses(EVT VT, unsigned AS=0, Align Alignment=Align(1), MachineMemOperand::Flags Flags=MachineMemOperand::MONone, unsigned *Fast=nullptr) const override
Determine if the target supports unaligned memory accesses.
SDValue LowerOperation(SDValue Op, SelectionDAG &DAG) const override
This callback is invoked for operations that are unsupported by the target, which are registered to u...
MipsSETargetLowering(const MipsTargetMachine &TM, const MipsSubtarget &STI)
MVT getScalarShiftAmountTy(const DataLayout &, EVT) const override
Return the type to use for a scalar shift opcode, given the shifted amount type.
MipsTargetLowering(const MipsTargetMachine &TM, const MipsSubtarget &STI)
SDValue PerformDAGCombine(SDNode *N, DAGCombinerInfo &DCI) const override
This method will be invoked for all target nodes and for any target-independent nodes that the target...
MachineBasicBlock * EmitInstrWithCustomInserter(MachineInstr &MI, MachineBasicBlock *MBB) const override
This method should be implemented by targets that mark instructions with the 'usesCustomInserter' fla...
SDValue lowerSTORE(SDValue Op, SelectionDAG &DAG) const
virtual void getOpndList(SmallVectorImpl< SDValue > &Ops, std::deque< std::pair< unsigned, SDValue > > &RegsToPass, bool IsPICCall, bool GlobalOrExternal, bool InternalLinkage, bool IsCallReloc, CallLoweringInfo &CLI, SDValue Callee, SDValue Chain) const
This function fills Ops, which is the list of operands that will later be used when a function call n...
SDValue LowerOperation(SDValue Op, SelectionDAG &DAG) const override
LowerOperation - Provide custom lowering hooks for some operations.
const MipsSubtarget & Subtarget
SDValue lowerLOAD(SDValue Op, SelectionDAG &DAG) const
Wrapper class for IR location info (IR ordering and DebugLoc) to be passed into SDNode creation funct...
Represents one node in the SelectionDAG.
unsigned getOpcode() const
Return the SelectionDAG opcode value for this node.
unsigned getNumOperands() const
Return the number of values used by this operation.
SDVTList getVTList() const
const SDValue & getOperand(unsigned Num) const
LLVM_ABI void printrWithDepth(raw_ostream &O, const SelectionDAG *G=nullptr, unsigned depth=100) const
Print a SelectionDAG node and children up to depth "depth." The given SelectionDAG allows target-spec...
EVT getValueType(unsigned ResNo) const
Return the type of a specified result.
Unlike LLVM values, Selection DAG nodes may return multiple values as the result of a computation.
SDNode * getNode() const
get the SDNode which holds the desired result
SDValue getValue(unsigned R) const
EVT getValueType() const
Return the ValueType of the referenced return value.
const SDValue & getOperand(unsigned i) const
uint64_t getScalarValueSizeInBits() const
unsigned getOpcode() const
This is used to represent a portion of an LLVM function in a low-level Data Dependence DAG representa...
const TargetSubtargetInfo & getSubtarget() const
LLVM_ABI SDValue getMergeValues(ArrayRef< SDValue > Ops, const SDLoc &dl)
Create a MERGE_VALUES node from the given operands.
LLVM_ABI SDValue getLoad(EVT VT, const SDLoc &dl, SDValue Chain, SDValue Ptr, MachinePointerInfo PtrInfo, MaybeAlign Alignment=MaybeAlign(), MachineMemOperand::Flags MMOFlags=MachineMemOperand::MONone, const AAMDNodes &AAInfo=AAMDNodes(), const MDNode *Ranges=nullptr)
Loads are not normal binary operators: their result type is not determined by their operands,...
SDValue getSetCC(const SDLoc &DL, EVT VT, SDValue LHS, SDValue RHS, ISD::CondCode Cond, SDValue Chain=SDValue(), bool IsSignaling=false, SDNodeFlags Flags={})
Helper function to make it easier to build SetCC's if you just have an ISD::CondCode instead of an SD...
LLVM_ABI SDValue getNOT(const SDLoc &DL, SDValue Val, EVT VT)
Create a bitwise NOT operation as (XOR Val, -1).
const TargetLowering & getTargetLoweringInfo() const
SDValue getUNDEF(EVT VT)
Return an UNDEF node. UNDEF does not have a useful SDLoc.
SDValue getBuildVector(EVT VT, const SDLoc &DL, ArrayRef< SDValue > Ops)
Return an ISD::BUILD_VECTOR node.
LLVM_ABI bool isSplatValue(SDValue V, const APInt &DemandedElts, APInt &UndefElts, unsigned Depth=0) const
Test whether V has a splatted value for all the demanded elements.
const DataLayout & getDataLayout() const
LLVM_ABI SDValue getConstant(uint64_t Val, const SDLoc &DL, EVT VT, bool isTarget=false, bool isOpaque=false)
Create a ConstantSDNode wrapping a constant value.
LLVM_ABI SDValue getStore(SDValue Chain, const SDLoc &dl, SDValue Val, SDValue Ptr, MachinePointerInfo PtrInfo, Align Alignment, MachineMemOperand::Flags MMOFlags=MachineMemOperand::MONone, const AAMDNodes &AAInfo=AAMDNodes())
Helper function to build ISD::STORE nodes.
LLVM_ABI SDValue getValueType(EVT)
LLVM_ABI SDValue getNode(unsigned Opcode, const SDLoc &DL, EVT VT, ArrayRef< SDUse > Ops)
Gets or creates the specified node.
SDValue getTargetConstant(uint64_t Val, const SDLoc &DL, EVT VT, bool isOpaque=false)
LLVM_ABI SDValue getVectorIdxConstant(uint64_t Val, const SDLoc &DL, bool isTarget=false)
SDValue getSplatBuildVector(EVT VT, const SDLoc &DL, SDValue Op)
Return a splat ISD::BUILD_VECTOR node, consisting of Op splatted to all elements.
LLVMContext * getContext() const
LLVM_ABI std::pair< SDValue, SDValue > SplitScalar(const SDValue &N, const SDLoc &DL, const EVT &LoVT, const EVT &HiVT)
Split the scalar node with EXTRACT_ELEMENT using the provided VTs and return the low/high part.
This class consists of common code factored out of the SmallVector class to reduce code duplication b...
typename SuperClass::const_iterator const_iterator
void push_back(const T &Elt)
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
const SDValue & getBasePtr() const
const SDValue & getValue() const
void setOperationAction(unsigned Op, MVT VT, LegalizeAction Action)
Indicate that the specified operation does not work with the specified type and indicate what to do a...
LegalizeTypeAction
This enum indicates whether a types are legal for a target, and if not, what action should be used to...
virtual TargetLoweringBase::LegalizeTypeAction getPreferredVectorAction(MVT VT) const
Return the preferred vector type legalization action.
void computeRegisterProperties(const TargetRegisterInfo *TRI)
Once all of the register classes are added, this allows us to compute derived properties we expose.
void addRegisterClass(MVT VT, const TargetRegisterClass *RC)
Add the specified register class as an available regclass for the specified value type.
virtual MVT getPointerTy(const DataLayout &DL, uint32_t AS=0) const
Return the pointer type for the given address space, defaults to the pointer type from the data layou...
void setTruncStoreAction(MVT ValVT, MVT MemVT, LegalizeAction Action)
Indicate that the specified truncating store does not work with the specified type and indicate what ...
virtual const TargetRegisterClass * getRepRegClassFor(MVT VT) const
Return the 'representative' register class for the specified value type.
void setCondCodeAction(ArrayRef< ISD::CondCode > CCs, MVT VT, LegalizeAction Action)
Indicate that the specified condition code is or isn't supported on the target and indicate what to d...
void setTargetDAGCombine(ArrayRef< ISD::NodeType > NTs)
Targets should invoke this method for each target independent node that they want to provide a custom...
void setLoadExtAction(unsigned ExtType, MVT ValVT, MVT MemVT, LegalizeAction Action)
Indicate that the specified load with extension does not work with the specified type and indicate wh...
LegalizeTypeAction getTypeAction(LLVMContext &Context, EVT VT) const
Return how we should legalize values of this type, either it is already legal (return 'Legal') or we ...
MVT getRegisterType(MVT VT) const
Return the type of registers that this ValueType will eventually require.
std::pair< SDValue, SDValue > makeLibCall(SelectionDAG &DAG, RTLIB::LibcallImpl LibcallImpl, EVT RetVT, ArrayRef< SDValue > Ops, MakeLibCallOptions CallOptions, const SDLoc &dl, SDValue Chain=SDValue()) const
Returns a pair of (return value, chain).
LLVM_ABI bool isLittleEndian() const
Tests whether the target triple is little endian.
LLVM Value Representation.
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
constexpr std::underlying_type_t< E > Mask()
Get a bitmask with 1s in all places up to the high-order bit of E's largest value.
@ Fast
Attempts to make calls as fast as possible (e.g.
@ C
The default llvm calling convention, compatible with C.
@ SETCC
SetCC operator - This evaluates to a true value iff the condition is true.
@ SMUL_LOHI
SMUL_LOHI/UMUL_LOHI - Multiply two integers of type iN, producing a signed/unsigned value of type i[2...
@ ADDC
Carry-setting nodes for multiple precision addition and subtraction.
@ ADD
Simple integer binary arithmetic operators.
@ LOAD
LOAD and STORE have token chains as their first operand, then the same operands as an LLVM load/store...
@ FMA
FMA - Perform a * b + c with no intermediate rounding step.
@ INTRINSIC_VOID
OUTCHAIN = INTRINSIC_VOID(INCHAIN, INTRINSICID, arg1, arg2, ...) This node represents a target intrin...
@ SINT_TO_FP
[SU]INT_TO_FP - These operators convert integers (whose interpreted sign depends on the first letter)...
@ FADD
Simple binary floating point operators.
@ ATOMIC_FENCE
OUTCHAIN = ATOMIC_FENCE(INCHAIN, ordering, scope) This corresponds to the fence instruction.
@ SDIVREM
SDIVREM/UDIVREM - Divide two integers and produce both a quotient and remainder result.
@ FP16_TO_FP
FP16_TO_FP, FP_TO_FP16 - These operators are used to perform promotions and truncation for half-preci...
@ BITCAST
BITCAST - This operator converts between integer, vector and FP values, as if the value was stored to...
@ BUILD_PAIR
BUILD_PAIR - This is the opposite of EXTRACT_ELEMENT in some ways.
@ STRICT_FSQRT
Constrained versions of libm-equivalent floating point intrinsics.
@ BUILTIN_OP_END
BUILTIN_OP_END - This must be the last enum value in this list.
@ SIGN_EXTEND
Conversion operators.
@ SELECT
Select(COND, TRUEVAL, FALSEVAL).
@ UNDEF
UNDEF - An undefined node.
@ BasicBlock
Various leaf nodes.
@ MULHU
MULHU/MULHS - Multiply high - Multiply two integers of type iN, producing an unsigned/signed value of...
@ SHL
Shift and rotation operations.
@ VECTOR_SHUFFLE
VECTOR_SHUFFLE(VEC1, VEC2) - Returns a vector, of the same type as VEC1/VEC2.
@ EXTRACT_VECTOR_ELT
EXTRACT_VECTOR_ELT(VECTOR, IDX) - Returns a single element from VECTOR identified by the (potentially...
@ ZERO_EXTEND
ZERO_EXTEND - Used for integer types, zeroing the new bits.
@ SELECT_CC
Select with condition operator - This selects between a true value and a false value (ops #2 and #3) ...
@ SMIN
[US]{MIN/MAX} - Binary minimum or maximum of signed or unsigned integers.
@ VSELECT
Select with a vector condition (op #0) and two vector operands (ops #1 and #2), returning a vector re...
@ FP_TO_SINT
FP_TO_[US]INT - Convert a floating point value to a signed or unsigned integer.
@ TargetConstant
TargetConstant* - Like Constant*, but the DAG does not do any folding, simplification,...
@ AND
Bitwise operators - logical and, logical or, logical xor.
@ INTRINSIC_WO_CHAIN
RESULT = INTRINSIC_WO_CHAIN(INTRINSICID, arg1, arg2, ...) This node represents a target intrinsic fun...
@ ADDE
Carry-using nodes for multiple precision addition and subtraction.
@ STRICT_FADD
Constrained versions of the binary floating point operators.
@ INSERT_VECTOR_ELT
INSERT_VECTOR_ELT(VECTOR, VAL, IDX) - Returns VECTOR with the element at IDX replaced with VAL.
@ TRUNCATE
TRUNCATE - Completely drop the high bits.
@ BRCOND
BRCOND - Conditional branch.
@ INTRINSIC_W_CHAIN
RESULT,OUTCHAIN = INTRINSIC_W_CHAIN(INCHAIN, INTRINSICID, arg1, ...) This node represents a target in...
@ BUILD_VECTOR
BUILD_VECTOR(ELT0, ELT1, ELT2, ELT3,...) - Return a fixed-width vector with the specified,...
CondCode
ISD::CondCode enum - These are ordered carefully to make the bitfields below work out,...
LLVM_ABI bool isBuildVectorAllOnes(const SDNode *N)
Return true if the specified node is a BUILD_VECTOR where all of the elements are ~0 or undef.
initializer< Ty > init(const Ty &Val)
NodeAddr< NodeBase * > Node
This is an optimization pass for GlobalISel generic memory operations.
FunctionAddr VTableAddr Value
MachineInstrBuilder BuildMI(MachineFunction &MF, const MIMetadata &MIMD, const MCInstrDesc &MCID)
Builder interface. Specify how to create the initial instruction itself.
decltype(auto) dyn_cast(const From &Val)
dyn_cast<X> - Return the argument parameter cast to the specified type.
LLVM_ABI raw_ostream & dbgs()
dbgs() - This returns a reference to a raw_ostream for debugging messages.
LLVM_ABI void report_fatal_error(Error Err, bool gen_crash_diag=true)
class LLVM_GSL_OWNER SmallVector
Forward declaration of SmallVector so that calculateSmallVectorDefaultInlinedElements can reference s...
bool isa(const From &Val)
isa<X> - Return true if the parameter to the template is an instance of one of the template type argu...
DWARFExpression::Operation Op
ArrayRef(const T &OneElt) -> ArrayRef< T >
constexpr unsigned BitWidth
decltype(auto) cast(const From &Val)
cast<X> - Return the argument parameter cast to the specified type.
const MipsTargetLowering * createMipsSETargetLowering(const MipsTargetMachine &TM, const MipsSubtarget &STI)
Align commonAlignment(Align A, uint64_t Offset)
Returns the alignment that satisfies both alignments.
unsigned Log2(Align A)
Returns the log2 of the alignment.
@ Custom
The result value requires a custom uniformity check.
void swap(llvm::BitVector &LHS, llvm::BitVector &RHS)
Implement std::swap in terms of BitVector swap.
This struct is a compact representation of a valid (non-zero power of two) alignment.
EVT changeVectorElementTypeToInteger() const
Return a vector with the same number of elements as this vector, but with the element type converted ...
TypeSize getSizeInBits() const
Return the size of the specified value type in bits.
uint64_t getScalarSizeInBits() const
MVT getSimpleVT() const
Return the SimpleValueType held in the specified simple EVT.
bool is128BitVector() const
Return true if this is a 128-bit vector type.
bool isVector() const
Return true if this is a vector value type.
EVT getVectorElementType() const
Given a vector type, return the type of each element.
unsigned getVectorNumElements() const
Given a vector type, return the number of elements it contains.
bool isInteger() const
Return true if this is an integer or a vector integer type.
This class contains a discriminated union of information about pointers in memory operands,...
These are IR-level optimization flags that may be propagated to SDNodes.
This structure is used to pass arguments to makeLibCall function.