28#ifndef LLVM_IR_PATTERNMATCH_H
29#define LLVM_IR_PATTERNMATCH_H
53template <
typename Val,
typename Pattern>
bool match(Val *V,
const Pattern &
P) {
59template <
typename Val = const Value,
typename Pattern>
73 template <
typename OpTy>
bool match(OpTy *V)
const {
88 template <
typename OpTy>
bool match(OpTy *V)
const {
158 return checkAggregate(CA);
161 template <
typename ITy>
bool match(ITy *V)
const {
return check(V); }
185 template <
typename ITy>
bool match(ITy *V)
const {
199 template <
typename OpTy>
bool match(OpTy *V)
const {
201 auto *
Splat =
C->getSplatValue();
224 template <
typename ITy>
bool match(ITy *V)
const {
return !
M.match(V); }
233 static_assert(std::is_same_v<APTy, APInt> || std::is_same_v<APTy, APFloat>);
243 template <
typename ITy>
bool match(ITy *V)
const {
245 Res = &CI->getValue();
248 if (V->getType()->isVectorTy())
252 Res = &CI->getValue();
294 template <
typename ITy>
bool match(ITy *V)
const {
296 const APInt &CIV = CI->getValue();
298 return CIV ==
static_cast<uint64_t>(Val);
317template <
typename Predicate,
typename ConstantVal,
bool AllowPoison>
320 bool matchVector(
const Value *V)
const {
323 return this->isValue(CV->getValue());
331 unsigned NumElts = FVTy->getNumElements();
332 assert(NumElts != 0 &&
"Constant vector with no elements?");
333 bool HasNonPoisonElements =
false;
334 for (
unsigned i = 0; i != NumElts; ++i) {
335 Constant *Elt =
C->getAggregateElement(i);
341 if (!CV || !this->isValue(CV->getValue()))
343 HasNonPoisonElements =
true;
345 return HasNonPoisonElements;
354 return this->isValue(CV->getValue());
356 return matchVector(V);
360 template <
typename ITy>
bool match(ITy *V)
const {
371template <
typename Predicate,
bool AllowPoison = true>
375template <
typename Predicate>
381template <
typename Predicate>
struct api_pred_ty :
public Predicate {
386 template <
typename ITy>
bool match(ITy *V)
const {
388 if (this->isValue(CI->getValue())) {
389 Res = &CI->getValue();
392 if (V->getType()->isVectorTy())
395 C->getSplatValue(
true)))
396 if (this->isValue(CI->getValue())) {
397 Res = &CI->getValue();
408template <
typename Predicate>
struct apf_pred_ty :
public Predicate {
413 template <
typename ITy>
bool match(ITy *V)
const {
415 if (this->isValue(CI->getValue())) {
416 Res = &CI->getValue();
419 if (V->getType()->isVectorTy())
422 C->getSplatValue(
true)))
423 if (this->isValue(CI->getValue())) {
424 Res = &CI->getValue();
583 template <
typename ITy>
bool match(ITy *V)
const {
713 return C.isInfinity() && IsNegative ==
C.isNegative();
798 return !
C.isDenormal() &&
C.isNonZero();
820template <
typename Pattern>
832template <
typename Pattern>
836template <
typename Pattern>
894 if (CV->getType()->isVectorTy()) {
895 if (
auto *
Splat = CV->getSplatValue(
true)) {
897 !
Splat->containsConstantExpression()) {
919 template <
typename ITy>
bool match(ITy *V)
const {
939 template <
typename ITy>
bool match(ITy *V)
const {
return V ==
Val; }
963 template <
typename ITy>
bool match(ITy *V)
const {
965 return CFP->isExactlyValue(
Val);
966 if (V->getType()->isVectorTy())
969 return CFP->isExactlyValue(
Val);
986 template <
typename ITy>
bool match(ITy *V)
const {
987 const APInt *ConstInt;
990 std::optional<uint64_t> ZExtVal = ConstInt->
tryZExtValue();
1005 template <
typename ITy>
bool match(ITy *V)
const {
1007 if (!CI && V->getType()->isVectorTy())
1020 template <
typename ITy>
bool match(ITy *V)
const {
1022 if (!CI && V->getType()->isVectorTy())
1026 return CI && CI->getValue() ==
Val;
1058 template <
typename ITy>
bool match(ITy *V)
const {
1060 return BB && BB ==
Val;
1081template <
typename LHS_t,
typename RHS_t,
bool Commutable = false>
1090 template <
typename OpTy>
bool match(OpTy *V)
const {
1092 return (
L.match(
I->getOperand(0)) &&
R.match(
I->getOperand(1))) ||
1093 (Commutable &&
L.match(
I->getOperand(1)) &&
1094 R.match(
I->getOperand(0)));
1099template <
typename LHS,
typename RHS>
1113 template <
typename OpTy>
bool match(OpTy *V)
const {
1115 return X.match(
I->getOperand(0));
1128template <
typename LHS_t,
typename RHS_t,
unsigned Opcode,
1129 bool Commutable =
false>
1138 template <
typename OpTy>
inline bool match(
unsigned Opc, OpTy *V)
const {
1139 if (V->getValueID() == Value::InstructionVal +
Opc) {
1141 return (
L.match(
I->getOperand(0)) &&
R.match(
I->getOperand(1))) ||
1142 (Commutable &&
L.match(
I->getOperand(1)) &&
1143 R.match(
I->getOperand(0)));
1148 template <
typename OpTy>
bool match(OpTy *V)
const {
1149 return match(Opcode, V);
1153template <
typename LHS,
typename RHS>
1159template <
typename LHS,
typename RHS>
1165template <
typename LHS,
typename RHS>
1171template <
typename LHS,
typename RHS>
1181 template <
typename OpTy>
bool match(OpTy *V)
const {
1186 if (FPMO->getOpcode() == Instruction::FNeg)
1187 return X.match(FPMO->getOperand(0));
1189 if (FPMO->getOpcode() == Instruction::FSub) {
1190 if (FPMO->hasNoSignedZeros()) {
1200 return X.match(FPMO->getOperand(1));
1213template <
typename RHS>
1219template <
typename LHS,
typename RHS>
1225template <
typename LHS,
typename RHS>
1231template <
typename LHS,
typename RHS>
1237template <
typename LHS,
typename RHS>
1243template <
typename LHS,
typename RHS>
1249template <
typename LHS,
typename RHS>
1255template <
typename LHS,
typename RHS>
1261template <
typename LHS,
typename RHS>
1267template <
typename LHS,
typename RHS>
1273template <
typename LHS,
typename RHS>
1279template <
typename LHS,
typename RHS>
1285template <
typename LHS,
typename RHS>
1291template <
typename LHS,
typename RHS>
1297template <
typename LHS,
typename RHS>
1309 template <
typename OpTy>
bool match(OpTy *V)
const {
1311 if (
Op->getOpcode() == Opcode)
1313 L.match(
Op->getOperand(0));
1322template <
typename LHS>
1329template <
typename LHS>
1336template <
typename LHS>
1342template <
typename LHS_t,
typename RHS_t,
unsigned Opcode,
1343 unsigned WrapFlags = 0,
bool Commutable =
false>
1351 template <
typename OpTy>
bool match(OpTy *V)
const {
1353 if (
Op->getOpcode() != Opcode)
1356 !
Op->hasNoUnsignedWrap())
1359 !
Op->hasNoSignedWrap())
1361 return (
L.match(
Op->getOperand(0)) &&
R.match(
Op->getOperand(1))) ||
1362 (Commutable &&
L.match(
Op->getOperand(1)) &&
1363 R.match(
Op->getOperand(0)));
1369template <
typename LHS,
typename RHS>
1377template <
typename LHS,
typename RHS>
1385template <
typename LHS,
typename RHS>
1393template <
typename LHS,
typename RHS>
1401template <
typename LHS,
typename RHS>
1410template <
typename LHS,
typename RHS>
1419template <
typename LHS,
typename RHS>
1428template <
typename LHS,
typename RHS>
1436template <
typename LHS,
typename RHS>
1444template <
typename LHS,
typename RHS>
1453template <
typename LHS_t,
typename RHS_t,
bool Commutable = false>
1461 template <
typename OpTy>
bool match(OpTy *V)
const {
1467template <
typename LHS,
typename RHS>
1473template <
typename LHS,
typename RHS,
bool Commutable = false>
1480 template <
typename OpTy>
bool match(OpTy *V)
const {
1482 assert(PDI->getOpcode() == Instruction::Or &&
"Only or can be disjoint");
1483 if (!PDI->isDisjoint())
1485 return (
L.match(PDI->getOperand(0)) &&
R.match(PDI->getOperand(1))) ||
1486 (Commutable &&
L.match(PDI->getOperand(1)) &&
1487 R.match(PDI->getOperand(0)));
1493template <
typename LHS,
typename RHS>
1498template <
typename LHS,
typename RHS>
1505template <
typename LHS,
typename RHS>
1513template <
typename LHS,
typename RHS>
1523template <
typename LHS,
typename RHS>
1532template <
typename LHS,
typename RHS>
1539 template <
typename OpTy>
bool match(OpTy *V)
const {
1541 if (
Op->getOpcode() == Instruction::Sub &&
Op->hasNoUnsignedWrap() &&
1544 else if (
Op->getOpcode() != Instruction::Xor)
1546 return (
L.match(
Op->getOperand(0)) &&
R.match(
Op->getOperand(1))) ||
1547 (
L.match(
Op->getOperand(1)) &&
R.match(
Op->getOperand(0)));
1555template <
typename LHS,
typename RHS>
1563template <
typename LHS_t,
typename RHS_t,
typename Predicate,
1564 bool Commutable =
false>
1571 template <
typename OpTy>
bool match(OpTy *V)
const {
1573 return this->isOpType(
I->getOpcode()) &&
1574 ((
L.match(
I->getOperand(0)) &&
R.match(
I->getOperand(1))) ||
1575 (Commutable &&
L.match(
I->getOperand(1)) &&
1576 R.match(
I->getOperand(0))));
1587 return Opcode == Instruction::LShr || Opcode == Instruction::AShr;
1593 return Opcode == Instruction::LShr || Opcode == Instruction::Shl;
1605 return Opcode == Instruction::SDiv || Opcode == Instruction::UDiv;
1611 return Opcode == Instruction::SRem || Opcode == Instruction::URem;
1616template <
typename LHS,
typename RHS>
1623template <
typename LHS,
typename RHS>
1630template <
typename LHS,
typename RHS>
1637template <
typename LHS,
typename RHS>
1644template <
typename LHS,
typename RHS>
1651template <
typename LHS,
typename RHS>
1658template <
typename LHS,
typename RHS>
1672 template <
typename OpTy>
bool match(OpTy *V)
const {
1674 return PEO->isExact() &&
SubPattern.match(V);
1687template <
typename LHS_t,
typename RHS_t,
typename Class,
1688 bool Commutable =
false>
1701 template <
typename OpTy>
bool match(OpTy *V)
const {
1703 if (
L.match(
I->getOperand(0)) &&
R.match(
I->getOperand(1))) {
1708 if (Commutable &&
L.match(
I->getOperand(1)) &&
1709 R.match(
I->getOperand(0))) {
1719template <
typename LHS,
typename RHS>
1725template <
typename LHS,
typename RHS>
1727 const LHS &L,
const RHS &R) {
1731template <
typename LHS,
typename RHS>
1733 const LHS &L,
const RHS &R) {
1737template <
typename LHS,
typename RHS>
1742template <
typename LHS,
typename RHS>
1747template <
typename LHS,
typename RHS>
1754template <
typename LHS_t,
typename RHS_t,
typename Class,
1755 bool Commutable =
false>
1764 template <
typename OpTy>
bool match(OpTy *V)
const {
1767 L.match(
I->getOperand(0)) &&
R.match(
I->getOperand(1)))
1769 if constexpr (Commutable) {
1772 L.match(
I->getOperand(1)) &&
R.match(
I->getOperand(0)))
1781template <
typename LHS,
typename RHS>
1787template <
typename LHS,
typename RHS>
1793template <
typename LHS,
typename RHS>
1799template <
typename LHS,
typename RHS>
1815 template <
typename OpTy>
bool match(OpTy *V)
const {
1816 if (V->getValueID() == Value::InstructionVal + Opcode) {
1818 return Op1.match(
I->getOperand(0));
1831 template <
typename OpTy>
bool match(OpTy *V)
const {
1832 if (V->getValueID() == Value::InstructionVal + Opcode) {
1834 return Op1.match(
I->getOperand(0)) &&
Op2.match(
I->getOperand(1));
1841template <
typename T0,
typename T1,
typename T2,
unsigned Opcode,
1842 bool CommutableOp2Op3 =
false>
1851 template <
typename OpTy>
bool match(OpTy *V)
const {
1852 if (V->getValueID() == Value::InstructionVal + Opcode) {
1854 if (!
Op1.match(
I->getOperand(0)))
1856 if (
Op2.match(
I->getOperand(1)) &&
Op3.match(
I->getOperand(2)))
1858 return CommutableOp2Op3 &&
Op2.match(
I->getOperand(2)) &&
1859 Op3.match(
I->getOperand(1));
1875 template <
int Idx,
int Last>
1876 std::enable_if_t<Idx != Last, bool>
1881 template <
int Idx,
int Last>
1882 std::enable_if_t<Idx == Last, bool>
1884 return std::get<Idx>(
Operands).match(
I->getOperand(Idx));
1887 template <
typename OpTy>
bool match(OpTy *V)
const {
1888 if (V->getValueID() == Value::InstructionVal + Opcode) {
1890 return I->getNumOperands() ==
sizeof...(OperandTypes) &&
1898template <
typename Cond,
typename LHS,
typename RHS>
1906template <
int64_t L,
int64_t R,
typename Cond>
1908 Instruction::Select>
1914template <
typename LHS,
typename RHS>
1922template <
typename OpTy>
1928template <
typename Val_t,
typename Elt_t,
typename Idx_t>
1936template <
typename Val_t,
typename Idx_t>
1951 template <
typename OpTy>
bool match(OpTy *V)
const {
1953 return Op1.match(
I->getOperand(0)) &&
Op2.match(
I->getOperand(1)) &&
1954 Mask.match(
I->getShuffleMask());
1971 return all_of(Mask, [](
int Elem) {
return Elem == 0 || Elem == -1; });
1985 const auto *
First =
find_if(Mask, [](
int Elem) {
return Elem != -1; });
1986 if (
First == Mask.end())
1990 [
First](
int Elem) {
return Elem == *
First || Elem == -1; });
2001 template <
typename OpTy>
bool match(OpTy *V)
const {
2003 return GEP &&
GEP->getSourceElementType()->isIntegerTy(8) &&
2010template <
typename V1_t,
typename V2_t>
2016template <
typename V1_t,
typename V2_t,
typename Mask_t>
2023template <
typename OpTy>
2029template <
typename ValueOpTy,
typename Po
interOpTy>
2031m_Store(
const ValueOpTy &ValueOp,
const PointerOpTy &PointerOp) {
2037template <
typename... OperandTypes>
2039 return AnyOps_match<Instruction::GetElementPtr, OperandTypes...>(
Ops...);
2043template <
typename Po
interOpTy,
typename OffsetOpTy>
2058 template <
typename OpTy>
bool match(OpTy *V)
const {
2060 return O->getOpcode() == Opcode &&
Op.match(O->getOperand(0));
2070 template <
typename OpTy>
bool match(OpTy *V)
const {
2072 return Op.match(
I->getOperand(0));
2084 template <
typename OpTy>
bool match(OpTy *V)
const {
2086 return O->getOpcode() == Instruction::PtrToInt &&
2087 DL.getTypeSizeInBits(O->getType()) ==
2088 DL.getTypeSizeInBits(O->getOperand(0)->getType()) &&
2089 Op.match(O->getOperand(0));
2099 template <
typename OpTy>
bool match(OpTy *V)
const {
2101 return I->hasNonNeg() &&
Op.match(
I->getOperand(0));
2111 template <
typename OpTy>
bool match(OpTy *V)
const {
2113 return (
I->getNoWrapKind() & WrapFlags) == WrapFlags &&
2114 Op.match(
I->getOperand(0));
2120template <
typename OpTy>
2131 template <
typename OpTy>
bool match(OpTy *V)
const {
2135 Type *SrcType =
I->getSrcTy();
2136 Type *DstType =
I->getType();
2139 if (SrcType->isVectorTy() != DstType->isVectorTy())
2142 SrcVecTy && SrcVecTy->getElementCount() !=
2145 return Op.match(
I->getOperand(0));
2149template <
typename OpTy>
2155template <
typename OpTy>
2161template <
typename OpTy>
2168template <
typename OpTy>
2180template <
typename OpTy>
2187template <
typename OpTy>
2194template <
typename OpTy>
2200template <
typename OpTy>
2207template <
typename OpTy>
2213template <
typename OpTy>
2220template <
typename OpTy>
2226template <
typename OpTy>
2231template <
typename OpTy>
2236template <
typename OpTy>
2242template <
typename OpTy>
2249template <
typename OpTy>
2255template <
typename OpTy>
2262template <
typename OpTy>
2282 template <
typename OpTy>
bool match(OpTy *V)
const {
2287 if (V->getType()->isIntOrIntVectorTy(1) &&
2297template <
typename LHS,
typename RHS>
2311 template <
typename OpTy>
bool match(OpTy *V)
const {
2316 Type *Ty = V->getType();
2317 Value *CondV =
nullptr;
2322 TrueC.match(ConstantInt::get(Ty, 1)) &&
2323 FalseC.match(ConstantInt::get(Ty, 0)))
2330 FalseC.match(ConstantInt::get(Ty, 0)))
2345template <
typename CondTy,
typename LTy,
typename RTy>
2351template <
typename OpTy>
2356template <
typename OpTy>
2361template <
typename OpTy>
2368template <
typename OpTy>
2373template <
typename OpTy>
2378template <
typename OpTy>
2385template <
typename OpTy>
2390template <
typename OpTy>
2404 template <
typename OpTy>
bool match(OpTy *V)
const {
2406 Succ = BI->getSuccessor();
2415template <
typename Cond_t,
typename TrueBlock_t,
typename FalseBlock_t>
2421 brc_match(
const Cond_t &
C,
const TrueBlock_t &t,
const FalseBlock_t &f)
2424 template <
typename OpTy>
bool match(OpTy *V)
const {
2426 if (
Cond.match(BI->getCondition()))
2427 return T.match(BI->getSuccessor(0)) &&
F.match(BI->getSuccessor(1));
2432template <
typename Cond_t>
2439template <
typename Cond_t,
typename TrueBlock_t,
typename FalseBlock_t>
2441m_Br(
const Cond_t &
C,
const TrueBlock_t &
T,
const FalseBlock_t &
F) {
2449template <
typename CmpInst_t,
typename LHS_t,
typename RHS_t,
typename Pred_t,
2450 bool Commutable =
false>
2460 template <
typename OpTy>
bool match(OpTy *V)
const {
2467 Value *LHS =
II->getOperand(0), *RHS =
II->getOperand(1);
2468 return (
L.match(LHS) &&
R.match(RHS)) ||
2469 (Commutable &&
L.match(RHS) &&
R.match(LHS));
2481 auto *TrueVal =
SI->getTrueValue();
2482 auto *FalseVal =
SI->getFalseValue();
2483 auto *LHS = Cmp->getOperand(0);
2484 auto *RHS = Cmp->getOperand(1);
2485 if ((TrueVal != LHS || FalseVal != RHS) &&
2486 (TrueVal != RHS || FalseVal != LHS))
2488 typename CmpInst_t::Predicate Pred =
2489 LHS == TrueVal ? Cmp->getPredicate() : Cmp->getInversePredicate();
2491 if (!Pred_t::match(Pred))
2494 return (
L.match(LHS) &&
R.match(RHS)) ||
2495 (Commutable &&
L.match(RHS) &&
R.match(LHS));
2555template <
typename LHS,
typename RHS>
2561template <
typename LHS,
typename RHS>
2567template <
typename LHS,
typename RHS>
2573template <
typename LHS,
typename RHS>
2579template <
typename LHS,
typename RHS>
2593template <
typename LHS,
typename RHS>
2608template <
typename LHS,
typename RHS>
2623template <
typename LHS,
typename RHS>
2638template <
typename LHS,
typename RHS>
2649template <
typename LHS,
typename RHS>
2662template <
typename LHS,
typename RHS>
2673template <
typename ValTy>
2679template <
typename ValTy>
2691template <
typename LHS_t,
typename RHS_t,
typename Sum_t>
2700 template <
typename OpTy>
bool match(OpTy *V)
const {
2701 Value *ICmpLHS, *ICmpRHS;
2706 Value *AddLHS, *AddRHS;
2711 if (AddExpr.match(ICmpLHS) && (ICmpRHS == AddLHS || ICmpRHS == AddRHS))
2712 return L.match(AddLHS) &&
R.match(AddRHS) &&
S.match(ICmpLHS);
2716 if (AddExpr.match(ICmpRHS) && (ICmpLHS == AddLHS || ICmpLHS == AddRHS))
2717 return L.match(AddLHS) &&
R.match(AddRHS) &&
S.match(ICmpRHS);
2723 if (XorExpr.match(ICmpLHS))
2724 return L.match(Op1) &&
R.match(ICmpRHS) &&
S.match(ICmpLHS);
2728 if (XorExpr.match(ICmpRHS))
2729 return L.match(Op1) &&
R.match(ICmpLHS) &&
S.match(ICmpRHS);
2738 return L.match(AddLHS) &&
R.match(AddRHS) &&
S.match(ICmpLHS);
2743 return L.match(AddLHS) &&
R.match(AddRHS) &&
S.match(ICmpRHS);
2754template <
typename LHS_t,
typename RHS_t,
typename Sum_t>
2766 template <
typename OpTy>
bool match(OpTy *V)
const {
2769 return Val.match(CI->getArgOperand(
OpI));
2775template <
unsigned OpI,
typename Opnd_t>
2786 template <
typename OpTy>
bool match(OpTy *V)
const {
2789 return F->getIntrinsicID() ==
ID;
2796 template <
typename OpTy>
bool match(OpTy *V)
const {
2800 return ((
ID == IntrIDs) || ...);
2810template <
typename T0 = void,
typename T1 = void,
typename T2 = void,
2811 typename T3 = void,
typename T4 = void,
typename T5 = void,
2812 typename T6 = void,
typename T7 = void,
typename T8 = void,
2813 typename T9 = void,
typename T10 =
void>
2822template <
typename T0,
typename T1,
typename T2>
2827template <
typename T0,
typename T1,
typename T2,
typename T3>
2833template <
typename T0,
typename T1,
typename T2,
typename T3,
typename T4>
2839template <
typename T0,
typename T1,
typename T2,
typename T3,
typename T4,
2862template <
typename Opnd0,
typename Opnd1,
typename Opnd2>
2869template <
typename Opnd0,
typename Opnd1,
typename Opnd2>
2876template <
typename Opnd0,
typename Opnd1,
typename Opnd2>
2882template <Intrinsic::ID IntrID,
typename T0>
2887template <Intrinsic::ID IntrID,
typename T0,
typename T1>
2893template <Intrinsic::ID IntrID,
typename T0,
typename T1,
typename T2>
2899template <
Intrinsic::ID IntrID,
typename T0,
typename T1,
typename T2,
2902m_Intrinsic(
const T0 &Op0,
const T1 &Op1,
const T2 &Op2,
const T3 &Op3) {
2906template <
Intrinsic::ID IntrID,
typename T0,
typename T1,
typename T2,
2907 typename T3,
typename T4>
2909m_Intrinsic(
const T0 &Op0,
const T1 &Op1,
const T2 &Op2,
const T3 &Op3,
2915template <
Intrinsic::ID IntrID,
typename T0,
typename T1,
typename T2,
2916 typename T3,
typename T4,
typename T5>
2918m_Intrinsic(
const T0 &Op0,
const T1 &Op1,
const T2 &Op2,
const T3 &Op3,
2919 const T4 &Op4,
const T5 &Op5) {
2925template <
typename Opnd0>
2930template <
typename Opnd0>
2934template <
typename Opnd0>
2939template <
typename Opnd0>
2944template <
typename Opnd0>
2949template <
typename Opnd0,
typename Opnd1>
2955template <
typename Opnd0,
typename Opnd1>
2961template <
typename Opnd0,
typename Opnd1>
2967template <
typename Opnd0,
typename Opnd1>
2973template <
typename Opnd0,
typename Opnd1>
2979template <
typename Opnd0,
typename Opnd1>
2985template <
typename Opnd0,
typename Opnd1>
2991template <
typename Opnd0,
typename Opnd1>
2997template <
typename Opnd0,
typename Opnd1>
3004template <
typename Opnd0,
typename Opnd1>
3011template <
typename Opnd0,
typename Opnd1,
typename Opnd2>
3013m_FShl(
const Opnd0 &Op0,
const Opnd1 &Op1,
const Opnd2 &Op2) {
3017template <
typename Opnd0,
typename Opnd1,
typename Opnd2>
3019m_FShr(
const Opnd0 &Op0,
const Opnd1 &Op1,
const Opnd2 &Op2) {
3023template <
typename Opnd0>
3028template <
typename Opnd0,
typename Opnd1>
3034template <
typename Opnd0>
3039template <
typename Opnd0,
typename Opnd1,
typename Opnd2>
3050template <
typename LHS,
typename RHS>
3057template <
typename LHS,
typename RHS>
3063template <
typename LHS,
typename RHS>
3070template <
typename LHS,
typename RHS>
3077template <
typename LHS,
typename RHS>
3084template <
typename LHS,
typename RHS>
3091template <
typename LHS,
typename RHS>
3098template <
typename LHS,
typename RHS>
3105template <
typename LHS,
typename RHS>
3112template <
typename ValTy>
3119template <
typename ValTy>
3128template <
typename LHS,
typename RHS>
3134template <
typename LHS,
typename RHS>
3140template <
typename LHS,
typename RHS>
3146template <
typename LHS,
typename RHS>
3152template <
typename LHS,
typename RHS>
3158template <Intrinsic::ID IntrID,
typename LHS,
typename RHS>
3165 template <
typename OpTy>
bool match(OpTy *V)
const {
3167 if (!
II ||
II->getIntrinsicID() != IntrID)
3169 return (
L.match(
II->getArgOperand(0)) &&
R.match(
II->getArgOperand(1))) ||
3170 (
L.match(
II->getArgOperand(1)) &&
R.match(
II->getArgOperand(0)));
3174template <Intrinsic::ID IntrID,
typename T0,
typename T1>
3181template <
typename LHS,
typename RHS>
3188template <
typename LHS,
typename RHS>
3198 template <
typename OpTy>
bool match(OpTy *V)
const {
3199 unsigned TypeSize = V->getType()->getScalarSizeInBits();
3203 unsigned ShiftWidth =
TypeSize - 1;
3218 auto Signum =
m_c_Or(LHS, RHS);
3220 return Signum.match(V) &&
Val.match(
Op);
3238 template <
typename OpTy>
bool match(OpTy *V)
const {
3242 !(
I->getNumIndices() == 1 &&
I->getIndices()[0] == (
unsigned)Ind))
3244 return Val.match(
I->getAggregateOperand());
3252template <
int Ind,
typename Val_t>
3259template <
typename Val_t>
3271 template <
typename OpTy>
bool match(OpTy *V)
const {
3273 return Op0.match(
I->getOperand(0)) &&
Op1.match(
I->getOperand(1)) &&
3274 I->getNumIndices() == 1 && Ind ==
I->getIndices()[0];
3281template <
int Ind,
typename Val_t,
typename Elt_t>
3290template <
typename Opnd0,
typename Opnd1>
3296template <
typename Opnd>
3301template <
typename LHS,
typename RHS,
unsigned Opcode,
bool Commutable = false>
3308 template <
typename T>
bool match(
T *V)
const {
3310 if (!
I || !
I->getType()->isIntOrIntVectorTy(1))
3313 if (
I->getOpcode() == Opcode) {
3314 auto *Op0 =
I->getOperand(0);
3315 auto *Op1 =
I->getOperand(1);
3316 return (
L.match(Op0) &&
R.match(Op1)) ||
3317 (Commutable &&
L.match(Op1) &&
R.match(Op0));
3322 auto *TVal =
Select->getTrueValue();
3323 auto *FVal =
Select->getFalseValue();
3330 if (Opcode == Instruction::And) {
3332 if (
C &&
C->isNullValue())
3333 return (
L.match(
Cond) &&
R.match(TVal)) ||
3334 (Commutable &&
L.match(TVal) &&
R.match(
Cond));
3336 assert(Opcode == Instruction::Or);
3338 if (
C &&
C->isOneValue())
3339 return (
L.match(
Cond) &&
R.match(FVal)) ||
3340 (Commutable &&
L.match(FVal) &&
R.match(
Cond));
3350template <
typename LHS,
typename RHS>
3360template <
typename LHS,
typename RHS>
3368template <
typename LHS,
typename RHS>
3378template <
typename LHS,
typename RHS>
3387template <
typename LHS,
typename RHS,
bool Commutable = false>
3398template <
typename LHS,
typename RHS>
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
AMDGPU Register Bank Select
This file declares a class to represent arbitrary precision floating point values and provide a varie...
This file implements a class to represent arbitrary precision integral constant values and operations...
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
static constexpr unsigned long long mask(BlockVerifier::State S)
static GCRegistry::Add< ErlangGC > A("erlang", "erlang-compatible garbage collector")
This file contains the declarations for the subclasses of Constant, which represent the different fla...
std::pair< Instruction::BinaryOps, Value * > OffsetOp
Find all possible pairs (BinOp, RHS) that BinOp V, RHS can be simplified.
const AbstractManglingParser< Derived, Alloc >::OperatorInfo AbstractManglingParser< Derived, Alloc >::Ops[]
MachineInstr unsigned OpIdx
uint64_t IntrinsicInst * II
const SmallVectorImpl< MachineOperand > & Cond
Class for arbitrary precision integers.
std::optional< uint64_t > tryZExtValue() const
Get zero extended value if possible.
static bool isSameValue(const APInt &I1, const APInt &I2, bool SignedCompare=false)
Determine if two APInts have the same value, after zero-extending or sign-extending (if SignedCompare...
Represent a constant reference to an array (0 or more elements consecutively in memory),...
LLVM Basic Block Representation.
Predicate
This enumeration lists the possible predicates for CmpInst subclasses.
@ ICMP_SLT
signed less than
@ ICMP_SLE
signed less or equal
@ FCMP_OLT
0 1 0 0 True if ordered and less than
@ FCMP_ULE
1 1 0 1 True if unordered, less than, or equal
@ FCMP_OGT
0 0 1 0 True if ordered and greater than
@ FCMP_OGE
0 0 1 1 True if ordered and greater than or equal
@ ICMP_UGE
unsigned greater or equal
@ ICMP_UGT
unsigned greater than
@ ICMP_SGT
signed greater than
@ FCMP_ULT
1 1 0 0 True if unordered or less than
@ ICMP_ULT
unsigned less than
@ FCMP_UGT
1 0 1 0 True if unordered or greater than
@ FCMP_OLE
0 1 0 1 True if ordered and less than or equal
@ ICMP_SGE
signed greater or equal
@ ICMP_ULE
unsigned less or equal
@ FCMP_UGE
1 0 1 1 True if unordered, greater than, or equal
An abstraction over a floating-point predicate, and a pack of an integer predicate with samesign info...
static LLVM_ABI std::optional< CmpPredicate > getMatching(CmpPredicate A, CmpPredicate B)
Compares two CmpPredicates taking samesign into account and returns the canonicalized CmpPredicate if...
static LLVM_ABI CmpPredicate get(const CmpInst *Cmp)
Do a ICmpInst::getCmpPredicate() or CmpInst::getPredicate(), as appropriate.
static LLVM_ABI CmpPredicate getSwapped(CmpPredicate P)
Get the swapped predicate of a CmpPredicate.
Base class for aggregate constants (with operands).
A constant value that is initialized with an expression using other constant values.
ConstantFP - Floating Point Values [float, double].
This is the shared class of boolean and integer constants.
This is an important base class in LLVM.
static LLVM_ABI Constant * getAllOnesValue(Type *Ty)
static LLVM_ABI Constant * getNullValue(Type *Ty)
Constructor to create a '0' constant of arbitrary type.
A parsed version of the target data layout string in and methods for querying it.
Convenience struct for specifying and reasoning about fast-math flags.
static LLVM_ABI bool compare(const APInt &LHS, const APInt &RHS, ICmpInst::Predicate Pred)
Return result of LHS Pred RHS comparison.
bool isBitwiseLogicOp() const
Return true if this is and/or/xor.
A wrapper class for inspecting calls to intrinsic functions.
The instances of the Type class are immutable: once they are created, they are never changed.
bool isIntOrIntVectorTy() const
Return true if this is an integer type or a vector of integer types.
'undef' values are things that do not have specified contents.
LLVM Value Representation.
Type * getType() const
All values are typed, get the type of this value.
Base class of all SIMD vector types.
Represents an op.with.overflow intrinsic.
An efficient, type-erasing, non-owning reference to a callable.
unsigned ID
LLVM IR allows to use arbitrary numbers as calling convention identifiers.
@ C
The default llvm calling convention, compatible with C.
match_isa< To... > m_Isa()
match_combine_or< Ty... > m_CombineOr(const Ty &...Ps)
Combine pattern matchers matching any of Ps patterns.
match_combine_and< Ty... > m_CombineAnd(const Ty &...Ps)
Combine pattern matchers matching all of Ps patterns.
TwoOps_match< ValueOpTy, PointerOpTy, Instruction::Store > m_Store(const ValueOpTy &ValueOp, const PointerOpTy &PointerOp)
Matches StoreInst.
cst_pred_ty< is_all_ones > m_AllOnes()
Match an integer or vector with all bits set.
cst_pred_ty< is_lowbit_mask > m_LowBitMask()
Match an integer or vector with only the low bit(s) set.
BinaryOp_match< LHS, RHS, Instruction::And > m_And(const LHS &L, const RHS &R)
PtrAdd_match< PointerOpTy, OffsetOpTy > m_PtrAdd(const PointerOpTy &PointerOp, const OffsetOpTy &OffsetOp)
Matches GEP with i8 source element type.
cst_pred_ty< is_negative > m_Negative()
Match an integer or vector of negative values.
ShiftLike_match< LHS, Instruction::LShr > m_LShrOrSelf(const LHS &L, uint64_t &R)
Matches lshr L, ConstShAmt or L itself (R will be set to zero in this case).
AllowFmf_match< T, FastMathFlags::NoSignedZeros > m_NoSignedZeros(const T &SubPattern)
auto m_Cmp()
Matches any compare instruction and ignore it.
BinaryOp_match< cst_pred_ty< is_all_ones, false >, ValTy, Instruction::Xor, true > m_NotForbidPoison(const ValTy &V)
MaxMin_match< FCmpInst, LHS, RHS, ufmin_pred_ty > m_UnordFMin(const LHS &L, const RHS &R)
Match an 'unordered' floating point minimum function.
PtrToIntSameSize_match< OpTy > m_PtrToIntSameSize(const DataLayout &DL, const OpTy &Op)
BinaryOp_match< LHS, RHS, Instruction::Add > m_Add(const LHS &L, const RHS &R)
m_Intrinsic_Ty< Opnd0 >::Ty m_FCanonicalize(const Opnd0 &Op0)
CmpClass_match< LHS, RHS, FCmpInst > m_FCmp(CmpPredicate &Pred, const LHS &L, const RHS &R)
AllowFmf_match< T, FastMathFlags::NoInfs > m_NoInfs(const T &SubPattern)
BinaryOp_match< LHS, RHS, Instruction::FMul, true > m_c_FMul(const LHS &L, const RHS &R)
Matches FMul with LHS and RHS in either order.
cst_pred_ty< is_sign_mask > m_SignMask()
Match an integer or vector with only the sign bit(s) set.
OverflowingBinaryOp_match< LHS, RHS, Instruction::Add, OverflowingBinaryOperator::NoUnsignedWrap > m_NUWAdd(const LHS &L, const RHS &R)
BinaryOp_match< LHS, RHS, Instruction::AShr > m_AShr(const LHS &L, const RHS &R)
auto m_PtrToIntOrAddr(const OpTy &Op)
Matches PtrToInt or PtrToAddr.
match_combine_or< typename m_Intrinsic_Ty< Opnd0, Opnd1 >::Ty, typename m_Intrinsic_Ty< Opnd0, Opnd1 >::Ty > m_FMinNum_or_FMinimumNum(const Opnd0 &Op0, const Opnd1 &Op1)
cstfp_pred_ty< is_inf > m_Inf()
Match a positive or negative infinity FP constant.
m_Intrinsic_Ty< Opnd0 >::Ty m_BitReverse(const Opnd0 &Op0)
BinaryOp_match< LHS, RHS, Instruction::FSub > m_FSub(const LHS &L, const RHS &R)
cst_pred_ty< is_power2 > m_Power2()
Match an integer or vector power-of-2.
m_Intrinsic_Ty< Opnd0, Opnd1, Opnd2 >::Ty m_MaskedStore(const Opnd0 &Op0, const Opnd1 &Op1, const Opnd2 &Op2)
Matches MaskedStore Intrinsic.
OverflowingBinaryOp_match< LHS, RHS, Instruction::Add, OverflowingBinaryOperator::NoSignedWrap, true > m_c_NSWAdd(const LHS &L, const RHS &R)
BinaryOp_match< cstfp_pred_ty< is_any_zero_fp >, RHS, Instruction::FSub > m_FNegNSZ(const RHS &X)
Match 'fneg X' as 'fsub +-0.0, X'.
BinaryOp_match< LHS, RHS, Instruction::URem > m_URem(const LHS &L, const RHS &R)
match_combine_or< CastInst_match< OpTy, CastInst >, OpTy > m_CastOrSelf(const OpTy &Op)
Matches any cast or self. Used to ignore casts.
match_combine_or< CastInst_match< OpTy, TruncInst >, OpTy > m_TruncOrSelf(const OpTy &Op)
auto m_LogicalOp()
Matches either L && R or L || R where L and R are arbitrary values.
CommutativeBinaryIntrinsic_match< IntrID, T0, T1 > m_c_Intrinsic(const T0 &Op0, const T1 &Op1)
OneOps_match< OpTy, Instruction::Freeze > m_Freeze(const OpTy &Op)
Matches FreezeInst.
auto m_Poison()
Match an arbitrary poison constant.
ap_match< APInt > m_APInt(const APInt *&Res)
Match a ConstantInt or splatted ConstantVector, binding the specified pointer to the contained APInt.
BinaryOp_match< LHS, RHS, Instruction::And, true > m_c_And(const LHS &L, const RHS &R)
Matches an And with LHS and RHS in either order.
ap_match< APFloat > m_APFloatForbidPoison(const APFloat *&Res)
Match APFloat while forbidding poison in splat vector constants.
cst_pred_ty< is_power2_or_zero > m_Power2OrZero()
Match an integer or vector of 0 or power-of-2 values.
CastInst_match< OpTy, TruncInst > m_Trunc(const OpTy &Op)
Matches Trunc.
BinaryOp_match< LHS, RHS, Instruction::Xor > m_Xor(const LHS &L, const RHS &R)
br_match m_UnconditionalBr(BasicBlock *&Succ)
CastOperator_match< OpTy, Instruction::PtrToAddr > m_PtrToAddr(const OpTy &Op)
Matches PtrToAddr.
ap_match< APInt > m_APIntAllowPoison(const APInt *&Res)
Match APInt while allowing poison in splat vector constants.
OverflowingBinaryOp_match< LHS, RHS, Instruction::Sub, OverflowingBinaryOperator::NoSignedWrap > m_NSWSub(const LHS &L, const RHS &R)
specific_intval< false > m_SpecificInt(const APInt &V)
Match a specific integer value or vector with all elements equal to the value.
BinaryOp_match< LHS, RHS, Instruction::FMul > m_FMul(const LHS &L, const RHS &R)
match_combine_or< CastInst_match< OpTy, ZExtInst >, OpTy > m_ZExtOrSelf(const OpTy &Op)
bool match(Val *V, const Pattern &P)
BinOpPred_match< LHS, RHS, is_idiv_op > m_IDiv(const LHS &L, const RHS &R)
Matches integer division operations.
match_bind< Instruction > m_Instruction(Instruction *&I)
Match an instruction, capturing it if we match.
cst_pred_ty< is_shifted_mask > m_ShiftedMask()
match_deferred< Value > m_Deferred(Value *const &V)
Like m_Specific(), but works if the specific value to match is determined as part of the same match()...
cstval_pred_ty< Predicate, ConstantInt, AllowPoison > cst_pred_ty
specialization of cstval_pred_ty for ConstantInt
m_Intrinsic_Ty< Opnd0, Opnd1 >::Ty m_FMaxNum(const Opnd0 &Op0, const Opnd1 &Op1)
cstfp_pred_ty< is_any_zero_fp > m_AnyZeroFP()
Match a floating-point negative zero or positive zero.
specificval_ty m_Specific(const Value *V)
Match if we have a specific specified value.
DisjointOr_match< LHS, RHS > m_DisjointOr(const LHS &L, const RHS &R)
constantexpr_match m_ConstantExpr()
Match a constant expression or a constant that contains a constant expression.
cstfp_pred_ty< is_signed_inf< true > > m_NegInf()
Match a negative infinity FP constant.
BinOpPred_match< LHS, RHS, is_right_shift_op > m_Shr(const LHS &L, const RHS &R)
Matches logical shift operations.
auto m_c_XorLike(const LHS &L, const RHS &R)
Match either (xor L, R), (xor R, L) or (sub nuw R, L) iff R.isMask() Only commutative matcher as the ...
specific_intval< true > m_SpecificIntAllowPoison(const APInt &V)
ap_match< APFloat > m_APFloat(const APFloat *&Res)
Match a ConstantFP or splatted ConstantVector, binding the specified pointer to the contained APFloat...
ap_match< APFloat > m_APFloatAllowPoison(const APFloat *&Res)
Match APFloat while allowing poison in splat vector constants.
CmpClass_match< LHS, RHS, ICmpInst, true > m_c_ICmp(CmpPredicate &Pred, const LHS &L, const RHS &R)
Matches an ICmp with a predicate over LHS and RHS in either order.
auto match_fn(const Pattern &P)
A match functor that can be used as a UnaryPredicate in functional algorithms like all_of.
OverflowingBinaryOp_match< LHS, RHS, Instruction::Add, OverflowingBinaryOperator::NoUnsignedWrap, true > m_c_NUWAdd(const LHS &L, const RHS &R)
OverflowingBinaryOp_match< cst_pred_ty< is_zero_int >, ValTy, Instruction::Sub, OverflowingBinaryOperator::NoSignedWrap > m_NSWNeg(const ValTy &V)
Matches a 'Neg' as 'sub nsw 0, V'.
m_Intrinsic_Ty< Opnd0, Opnd1, Opnd2 >::Ty m_MaskedLoad(const Opnd0 &Op0, const Opnd1 &Op1, const Opnd2 &Op2)
Matches MaskedLoad Intrinsic.
TwoOps_match< Val_t, Idx_t, Instruction::ExtractElement > m_ExtractElt(const Val_t &Val, const Idx_t &Idx)
Matches ExtractElementInst.
cstfp_pred_ty< is_finite > m_Finite()
Match a finite FP constant, i.e.
cst_pred_ty< is_nonnegative > m_NonNegative()
Match an integer or vector of non-negative values.
auto m_LogicalOp(const LHS &L, const RHS &R)
Matches either L && R or L || R, either one being in the either binary or logical form.
cst_pred_ty< is_one > m_One()
Match an integer 1 or a vector with all elements equal to 1.
IntrinsicID_match m_Intrinsic()
Match intrinsic calls like this: m_Intrinsic<Intrinsic::fabs>(m_Value(X))
ThreeOps_match< Cond, LHS, RHS, Instruction::Select > m_Select(const Cond &C, const LHS &L, const RHS &R)
Matches SelectInst.
IntrinsicID_match m_VScale()
Matches a call to llvm.vscale().
cstfp_pred_ty< is_neg_zero_fp > m_NegZeroFP()
Match a floating-point negative zero.
auto m_BinOp()
Match an arbitrary binary operation and ignore it.
m_Intrinsic_Ty< Opnd0, Opnd1 >::Ty m_FMinimum(const Opnd0 &Op0, const Opnd1 &Op1)
match_combine_or< CastInst_match< OpTy, SExtInst >, OpTy > m_SExtOrSelf(const OpTy &Op)
InsertValue_match< Ind, Val_t, Elt_t > m_InsertValue(const Val_t &Val, const Elt_t &Elt)
Matches a single index InsertValue instruction.
match_combine_or< MaxMin_match< FCmpInst, LHS, RHS, ofmin_pred_ty >, MaxMin_match< FCmpInst, LHS, RHS, ufmin_pred_ty > > m_OrdOrUnordFMin(const LHS &L, const RHS &R)
Match an 'ordered' or 'unordered' floating point minimum function.
auto m_BasicBlock()
Match an arbitrary basic block value and ignore it.
specific_fpval m_SpecificFP(double V)
Match a specific floating point value or vector with all elements equal to the value.
m_Intrinsic_Ty< Opnd0, Opnd1 >::Ty m_Interleave2(const Opnd0 &Op0, const Opnd1 &Op1)
ExtractValue_match< Ind, Val_t > m_ExtractValue(const Val_t &V)
Match a single index ExtractValue instruction.
BinOpPred_match< LHS, RHS, is_logical_shift_op > m_LogicalShift(const LHS &L, const RHS &R)
Matches logical shift operations.
MaxMin_match< ICmpInst, LHS, RHS, smin_pred_ty > m_SMin(const LHS &L, const RHS &R)
match_combine_or< CastInst_match< OpTy, UIToFPInst >, CastInst_match< OpTy, SIToFPInst > > m_IToFP(const OpTy &Op)
cst_pred_ty< is_any_apint > m_AnyIntegralConstant()
Match an integer or vector with any integral constant.
m_Intrinsic_Ty< Opnd0, Opnd1 >::Ty m_FMaximum(const Opnd0 &Op0, const Opnd1 &Op1)
ICmpLike_match< LHS, RHS > m_ICmpLike(CmpPredicate &Pred, const LHS &L, const RHS &R)
CastInst_match< OpTy, FPToUIInst > m_FPToUI(const OpTy &Op)
auto m_Value()
Match an arbitrary value and ignore it.
m_Intrinsic_Ty< Opnd0 >::Ty m_Sqrt(const Opnd0 &Op0)
ShiftLike_match< LHS, Instruction::Shl > m_ShlOrSelf(const LHS &L, uint64_t &R)
Matches shl L, ConstShAmt or L itself (R will be set to zero in this case).
BinaryOp_match< LHS, RHS, Instruction::Xor, true > m_c_Xor(const LHS &L, const RHS &R)
Matches an Xor with LHS and RHS in either order.
BinaryOp_match< LHS, RHS, Instruction::FAdd > m_FAdd(const LHS &L, const RHS &R)
SpecificCmpClass_match< LHS, RHS, CmpInst > m_SpecificCmp(CmpPredicate MatchPred, const LHS &L, const RHS &R)
BinaryOp_match< LHS, RHS, Instruction::Mul > m_Mul(const LHS &L, const RHS &R)
auto m_UndefValue()
Match an arbitrary UndefValue constant.
cst_pred_ty< is_zero_int > m_ZeroInt()
Match an integer 0 or a vector with all elements equal to 0.
auto m_Constant()
Match an arbitrary Constant and ignore it.
NoWrapTrunc_match< OpTy, TruncInst::NoSignedWrap > m_NSWTrunc(const OpTy &Op)
Matches trunc nsw.
match_combine_or< match_combine_or< CastInst_match< OpTy, ZExtInst >, CastInst_match< OpTy, SExtInst > >, OpTy > m_ZExtOrSExtOrSelf(const OpTy &Op)
OneUse_match< T > m_OneUse(const T &SubPattern)
NNegZExt_match< OpTy > m_NNegZExt(const OpTy &Op)
MaxMin_match< ICmpInst, LHS, RHS, smin_pred_ty, true > m_c_SMin(const LHS &L, const RHS &R)
Matches an SMin with LHS and RHS in either order.
auto m_LogicalOr()
Matches L || R where L and R are arbitrary values.
BinaryOp_match< cst_pred_ty< is_zero_int >, ValTy, Instruction::Sub > m_Neg(const ValTy &V)
Matches a 'Neg' as 'sub 0, V'.
Splat_match< T > m_ConstantSplat(const T &SubPattern)
Match a constant splat. TODO: Extend this to non-constant splats.
TwoOps_match< V1_t, V2_t, Instruction::ShuffleVector > m_Shuffle(const V1_t &v1, const V2_t &v2)
Matches ShuffleVectorInst independently of mask value.
specific_bbval m_SpecificBB(BasicBlock *BB)
Match a specific basic block value.
MaxMin_match< ICmpInst, LHS, RHS, umax_pred_ty, true > m_c_UMax(const LHS &L, const RHS &R)
Matches a UMax with LHS and RHS in either order.
auto m_GEP(const OperandTypes &...Ops)
Matches GetElementPtrInst.
ap_match< APInt > m_APIntForbidPoison(const APInt *&Res)
Match APInt while forbidding poison in splat vector constants.
AllowFmf_match< T, FastMathFlags::NoNaNs > m_NoNaNs(const T &SubPattern)
cst_pred_ty< is_strictlypositive > m_StrictlyPositive()
Match an integer or vector of strictly positive values.
match_combine_or< CastInst_match< OpTy, FPToUIInst >, CastInst_match< OpTy, FPToSIInst > > m_FPToI(const OpTy &Op)
cst_pred_ty< is_non_zero_int > m_NonZeroInt()
Match a non-zero integer or a vector with all non-zero elements.
ThreeOps_match< decltype(m_Value()), LHS, RHS, Instruction::Select, true > m_c_Select(const LHS &L, const RHS &R)
Match Select(C, LHS, RHS) or Select(C, RHS, LHS)
CastInst_match< OpTy, FPExtInst > m_FPExt(const OpTy &Op)
OverflowingBinaryOp_match< LHS, RHS, Instruction::Shl, OverflowingBinaryOperator::NoSignedWrap > m_NSWShl(const LHS &L, const RHS &R)
match_bind< WithOverflowInst > m_WithOverflowInst(WithOverflowInst *&I)
Match a with overflow intrinsic, capturing it if we match.
cstfp_pred_ty< is_nonnan > m_NonNaN()
Match a non-NaN FP constant.
SpecificCmpClass_match< LHS, RHS, ICmpInst > m_SpecificICmp(CmpPredicate MatchPred, const LHS &L, const RHS &R)
AllowFmf_match< T, FastMathFlags::AllowReassoc > m_AllowReassoc(const T &SubPattern)
OneOps_match< OpTy, Instruction::Load > m_Load(const OpTy &Op)
Matches LoadInst.
CastInst_match< OpTy, ZExtInst > m_ZExt(const OpTy &Op)
Matches ZExt.
OverflowingBinaryOp_match< LHS, RHS, Instruction::Shl, OverflowingBinaryOperator::NoUnsignedWrap > m_NUWShl(const LHS &L, const RHS &R)
auto m_AnyIntrinsic()
Matches any intrinsic call and ignore it.
cstfp_pred_ty< is_non_zero_not_denormal_fp > m_NonZeroNotDenormalFP()
Match a floating-point non-zero that is not a denormal.
cst_pred_ty< is_all_ones, false > m_AllOnesForbidPoison()
OverflowingBinaryOp_match< LHS, RHS, Instruction::Mul, OverflowingBinaryOperator::NoUnsignedWrap > m_NUWMul(const LHS &L, const RHS &R)
BinaryOp_match< LHS, RHS, Instruction::UDiv > m_UDiv(const LHS &L, const RHS &R)
BinOpPred_match< LHS, RHS, is_bitwiselogic_op, true > m_c_BitwiseLogic(const LHS &L, const RHS &R)
Matches bitwise logic operations in either order.
m_Intrinsic_Ty< Opnd0, Opnd1 >::Ty m_FMaximumNum(const Opnd0 &Op0, const Opnd1 &Op1)
MaxMin_match< ICmpInst, LHS, RHS, umax_pred_ty > m_UMax(const LHS &L, const RHS &R)
AllowFmf_match< T, FastMathFlags::ApproxFunc > m_ApproxFunc(const T &SubPattern)
cstfp_pred_ty< is_signed_inf< false > > m_PosInf()
Match a positive infinity FP constant.
cst_pred_ty< is_negated_power2 > m_NegatedPower2()
Match a integer or vector negated power-of-2.
match_immconstant_ty m_ImmConstant()
Match an arbitrary immediate Constant and ignore it.
cst_pred_ty< is_negated_power2_or_zero > m_NegatedPower2OrZero()
Match a integer or vector negated power-of-2.
auto m_ZExtOrTruncOrSelf(const OpTy &Op)
auto m_c_LogicalOp(const LHS &L, const RHS &R)
Matches either L && R or L || R with LHS and RHS in either order.
NoWrapTrunc_match< OpTy, TruncInst::NoUnsignedWrap > m_NUWTrunc(const OpTy &Op)
Matches trunc nuw.
ShiftLike_match< LHS, Instruction::AShr > m_AShrOrSelf(const LHS &L, uint64_t &R)
Matches ashr L, ConstShAmt or L itself (R will be set to zero in this case).
cst_pred_ty< custom_checkfn< APInt > > m_CheckedInt(function_ref< bool(const APInt &)> CheckFn)
Match an integer or vector where CheckFn(ele) for each element is true.
SelectLike_match< CondTy, LTy, RTy > m_SelectLike(const CondTy &C, const LTy &TrueC, const RTy &FalseC)
Matches a value that behaves like a boolean-controlled select, i.e.
cst_pred_ty< is_lowbit_mask_or_zero > m_LowBitMaskOrZero()
Match an integer or vector with only the low bit(s) set.
auto m_MaxOrMin(const LHS &L, const RHS &R)
m_Intrinsic_Ty< Opnd0, Opnd1 >::Ty m_FMinimumNum(const Opnd0 &Op0, const Opnd1 &Op1)
specific_fpval m_FPOne()
Match a float 1.0 or vector with all elements equal to 1.0.
DisjointOr_match< LHS, RHS, true > m_c_DisjointOr(const LHS &L, const RHS &R)
MaxMin_match< ICmpInst, LHS, RHS, umin_pred_ty, true > m_c_UMin(const LHS &L, const RHS &R)
Matches a UMin with LHS and RHS in either order.
BinaryOp_match< LHS, RHS, Instruction::Add, true > m_c_Add(const LHS &L, const RHS &R)
Matches a Add with LHS and RHS in either order.
SpecificCmpClass_match< LHS, RHS, FCmpInst > m_SpecificFCmp(CmpPredicate MatchPred, const LHS &L, const RHS &R)
match_combine_or< BinaryOp_match< LHS, RHS, Instruction::Add >, DisjointOr_match< LHS, RHS > > m_AddLike(const LHS &L, const RHS &R)
Match either "add" or "or disjoint".
m_Intrinsic_Ty< Opnd0, Opnd1, Opnd2 >::Ty m_MaskedGather(const Opnd0 &Op0, const Opnd1 &Op1, const Opnd2 &Op2)
Matches MaskedGather Intrinsic.
CastInst_match< OpTy, UIToFPInst > m_UIToFP(const OpTy &Op)
match_combine_or< MaxMin_match< FCmpInst, LHS, RHS, ofmax_pred_ty >, MaxMin_match< FCmpInst, LHS, RHS, ufmax_pred_ty > > m_OrdOrUnordFMax(const LHS &L, const RHS &R)
Match an 'ordered' or 'unordered' floating point maximum function.
MaxMin_match< ICmpInst, LHS, RHS, smax_pred_ty, true > m_c_SMax(const LHS &L, const RHS &R)
Matches an SMax with LHS and RHS in either order.
CastOperator_match< OpTy, Instruction::BitCast > m_BitCast(const OpTy &Op)
Matches BitCast.
m_Intrinsic_Ty< Opnd0, Opnd1, Opnd2 >::Ty m_FShl(const Opnd0 &Op0, const Opnd1 &Op1, const Opnd2 &Op2)
MaxMin_match< FCmpInst, LHS, RHS, ufmax_pred_ty > m_UnordFMax(const LHS &L, const RHS &R)
Match an 'unordered' floating point maximum function.
cstval_pred_ty< Predicate, ConstantFP, true > cstfp_pred_ty
specialization of cstval_pred_ty for ConstantFP
match_combine_or< CastInst_match< OpTy, SExtInst >, NNegZExt_match< OpTy > > m_SExtLike(const OpTy &Op)
Match either "sext" or "zext nneg".
cstfp_pred_ty< is_finitenonzero > m_FiniteNonZero()
Match a finite non-zero FP constant.
CastInst_match< OpTy, FPToSIInst > m_FPToSI(const OpTy &Op)
BinaryOp_match< LHS, RHS, Instruction::SDiv > m_SDiv(const LHS &L, const RHS &R)
auto m_c_MaxOrMin(const LHS &L, const RHS &R)
cstfp_pred_ty< custom_checkfn< APFloat > > m_CheckedFp(function_ref< bool(const APFloat &)> CheckFn)
Match a float or vector where CheckFn(ele) for each element is true.
OverflowingBinaryOp_match< LHS, RHS, Instruction::Sub, OverflowingBinaryOperator::NoUnsignedWrap > m_NUWSub(const LHS &L, const RHS &R)
MaxMin_match< ICmpInst, LHS, RHS, smax_pred_ty > m_SMax(const LHS &L, const RHS &R)
cst_pred_ty< is_maxsignedvalue > m_MaxSignedValue()
Match an integer or vector with values having all bits except for the high bit set (0x7f....
MaxMin_match< FCmpInst, LHS, RHS, ofmax_pred_ty > m_OrdFMax(const LHS &L, const RHS &R)
Match an 'ordered' floating point maximum function.
match_combine_or< OverflowingBinaryOp_match< LHS, RHS, Instruction::Add, OverflowingBinaryOperator::NoSignedWrap >, DisjointOr_match< LHS, RHS > > m_NSWAddLike(const LHS &L, const RHS &R)
Match either "add nsw" or "or disjoint".
m_Intrinsic_Ty< Opnd0 >::Ty m_Ctpop(const Opnd0 &Op0)
AnyBinaryOp_match< LHS, RHS, true > m_c_BinOp(const LHS &L, const RHS &R)
Matches a BinaryOperator with LHS and RHS in either order.
Signum_match< Val_t > m_Signum(const Val_t &V)
Matches a signum pattern.
OverflowingBinaryOp_match< LHS, RHS, Instruction::Add, OverflowingBinaryOperator::NoSignedWrap > m_NSWAdd(const LHS &L, const RHS &R)
CastInst_match< OpTy, SIToFPInst > m_SIToFP(const OpTy &Op)
BinaryOp_match< LHS, RHS, Instruction::LShr > m_LShr(const LHS &L, const RHS &R)
CmpClass_match< LHS, RHS, ICmpInst > m_ICmp(CmpPredicate &Pred, const LHS &L, const RHS &R)
Argument_match< Opnd_t > m_Argument(const Opnd_t &Op)
Match an argument.
match_combine_or< CastInst_match< OpTy, ZExtInst >, CastInst_match< OpTy, SExtInst > > m_ZExtOrSExt(const OpTy &Op)
Exact_match< T > m_Exact(const T &SubPattern)
FNeg_match< OpTy > m_FNeg(const OpTy &X)
Match 'fneg X' as 'fsub -0.0, X'.
BinOpPred_match< LHS, RHS, is_shift_op > m_Shift(const LHS &L, const RHS &R)
Matches shift operations.
cstfp_pred_ty< is_pos_zero_fp > m_PosZeroFP()
Match a floating-point positive zero.
BinaryOp_match< LHS, RHS, Instruction::FAdd, true > m_c_FAdd(const LHS &L, const RHS &R)
Matches FAdd with LHS and RHS in either order.
auto m_UnOp()
Match an arbitrary unary operation and ignore it.
LogicalOp_match< LHS, RHS, Instruction::And, true > m_c_LogicalAnd(const LHS &L, const RHS &R)
Matches L && R with LHS and RHS in either order.
BinaryOp_match< LHS, RHS, Instruction::Shl > m_Shl(const LHS &L, const RHS &R)
cstfp_pred_ty< is_non_zero_fp > m_NonZeroFP()
Match a floating-point non-zero.
UAddWithOverflow_match< LHS_t, RHS_t, Sum_t > m_UAddWithOverflow(const LHS_t &L, const RHS_t &R, const Sum_t &S)
Match an icmp instruction checking for unsigned overflow on addition.
BinaryOp_match< LHS, RHS, Instruction::FDiv > m_FDiv(const LHS &L, const RHS &R)
m_Intrinsic_Ty< Opnd0 >::Ty m_VecReverse(const Opnd0 &Op0)
BinOpPred_match< LHS, RHS, is_irem_op > m_IRem(const LHS &L, const RHS &R)
Matches integer remainder operations.
m_Intrinsic_Ty< Opnd0, Opnd1 >::Ty m_Cttz(const Opnd0 &Op0, const Opnd1 &Op1)
auto m_LogicalAnd()
Matches L && R where L and R are arbitrary values.
MaxMin_match< FCmpInst, LHS, RHS, ofmin_pred_ty > m_OrdFMin(const LHS &L, const RHS &R)
Match an 'ordered' floating point minimum function.
m_Intrinsic_Ty< Opnd0, Opnd1, Opnd2 >::Ty m_FShr(const Opnd0 &Op0, const Opnd1 &Op1, const Opnd2 &Op2)
brc_match< Cond_t, match_bind< BasicBlock >, match_bind< BasicBlock > > m_Br(const Cond_t &C, BasicBlock *&T, BasicBlock *&F)
ThreeOps_match< Cond, constantint_match< L >, constantint_match< R >, Instruction::Select > m_SelectCst(const Cond &C)
This matches a select of two constants, e.g.: m_SelectCst<-1, 0>(m_Value(V))
BinaryOp_match< LHS, RHS, Instruction::FRem > m_FRem(const LHS &L, const RHS &R)
AllowFmf_match< T, FastMathFlags::AllowContract > m_AllowContract(const T &SubPattern)
CastInst_match< OpTy, FPTruncInst > m_FPTrunc(const OpTy &Op)
m_Intrinsic_Ty< Opnd0, Opnd1 >::Ty m_Ctlz(const Opnd0 &Op0, const Opnd1 &Op1)
BinaryOp_match< LHS, RHS, Instruction::SRem > m_SRem(const LHS &L, const RHS &R)
auto m_Undef()
Match an arbitrary undef constant.
m_Intrinsic_Ty< Opnd0, Opnd1 >::Ty m_FMinNum(const Opnd0 &Op0, const Opnd1 &Op1)
cst_pred_ty< is_nonpositive > m_NonPositive()
Match an integer or vector of non-positive values.
cstfp_pred_ty< is_nan > m_NaN()
Match an arbitrary NaN constant.
auto m_ConstantFP()
Match an arbitrary ConstantFP and ignore it.
BinaryOp_match< cst_pred_ty< is_all_ones >, ValTy, Instruction::Xor, true > m_Not(const ValTy &V)
Matches a 'Not' as 'xor V, -1' or 'xor -1, V'.
match_combine_or< typename m_Intrinsic_Ty< Opnd0, Opnd1 >::Ty, typename m_Intrinsic_Ty< Opnd0, Opnd1 >::Ty > m_FMaxNum_or_FMaximumNum(const Opnd0 &Op0, const Opnd1 &Op1)
BinaryOp_match< LHS, RHS, Instruction::Or > m_Or(const LHS &L, const RHS &R)
m_Intrinsic_Ty< Opnd0 >::Ty m_BSwap(const Opnd0 &Op0)
CastInst_match< OpTy, SExtInst > m_SExt(const OpTy &Op)
Matches SExt.
is_zero m_Zero()
Match any null constant or a vector with all elements equal to 0.
BinaryOp_match< LHS, RHS, Instruction::Or, true > m_c_Or(const LHS &L, const RHS &R)
Matches an Or with LHS and RHS in either order.
match_combine_or< OverflowingBinaryOp_match< LHS, RHS, Instruction::Add, OverflowingBinaryOperator::NoUnsignedWrap >, DisjointOr_match< LHS, RHS > > m_NUWAddLike(const LHS &L, const RHS &R)
Match either "add nuw" or "or disjoint".
CastOperator_match< OpTy, Instruction::IntToPtr > m_IntToPtr(const OpTy &Op)
Matches IntToPtr.
BinOpPred_match< LHS, RHS, is_bitwiselogic_op > m_BitwiseLogic(const LHS &L, const RHS &R)
Matches bitwise logic operations.
LogicalOp_match< LHS, RHS, Instruction::Or, true > m_c_LogicalOr(const LHS &L, const RHS &R)
Matches L || R with LHS and RHS in either order.
ThreeOps_match< Val_t, Elt_t, Idx_t, Instruction::InsertElement > m_InsertElt(const Val_t &Val, const Elt_t &Elt, const Idx_t &Idx)
Matches InsertElementInst.
SpecificCmpClass_match< LHS, RHS, ICmpInst, true > m_c_SpecificICmp(CmpPredicate MatchPred, const LHS &L, const RHS &R)
ElementWiseBitCast_match< OpTy > m_ElementWiseBitCast(const OpTy &Op)
m_Intrinsic_Ty< Opnd0 >::Ty m_FAbs(const Opnd0 &Op0)
BinaryOp_match< LHS, RHS, Instruction::Mul, true > m_c_Mul(const LHS &L, const RHS &R)
Matches a Mul with LHS and RHS in either order.
m_Intrinsic_Ty< Opnd0, Opnd1 >::Ty m_CopySign(const Opnd0 &Op0, const Opnd1 &Op1)
CastOperator_match< OpTy, Instruction::PtrToInt > m_PtrToInt(const OpTy &Op)
Matches PtrToInt.
m_Intrinsic_Ty< Opnd0, Opnd1, Opnd2 >::Ty m_VectorInsert(const Opnd0 &Op0, const Opnd1 &Op1, const Opnd2 &Op2)
AllowFmf_match< T, FastMathFlags::AllowReciprocal > m_AllowReciprocal(const T &SubPattern)
OverflowingBinaryOp_match< LHS, RHS, Instruction::Mul, OverflowingBinaryOperator::NoSignedWrap > m_NSWMul(const LHS &L, const RHS &R)
BinaryOp_match< LHS, RHS, Instruction::Sub > m_Sub(const LHS &L, const RHS &R)
MaxMin_match< ICmpInst, LHS, RHS, umin_pred_ty > m_UMin(const LHS &L, const RHS &R)
cstfp_pred_ty< is_noninf > m_NonInf()
Match a non-infinity FP constant, i.e.
m_Intrinsic_Ty< Opnd >::Ty m_Deinterleave2(const Opnd &Op)
match_unless< Ty > m_Unless(const Ty &M)
Match if the inner matcher does NOT match.
cst_pred_ty< icmp_pred_with_threshold > m_SpecificInt_ICMP(ICmpInst::Predicate Predicate, const APInt &Threshold)
Match an integer or vector with every element comparing 'pred' (eg/ne/...) to Threshold.
auto m_ConstantInt()
Match an arbitrary ConstantInt and ignore it.
This is an optimization pass for GlobalISel generic memory operations.
bool all_of(R &&range, UnaryPredicate P)
Provide wrappers to std::all_of which take ranges instead of having to pass begin/end explicitly.
decltype(auto) dyn_cast(const From &Val)
dyn_cast<X> - Return the argument parameter cast to the specified type.
constexpr auto bind_back(FnT &&Fn, BindArgsT &&...BindArgs)
C++23 bind_back.
auto dyn_cast_or_null(const Y &Val)
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...
@ First
Helpers to iterate all locations in the MemoryEffectsBase class.
DWARFExpression::Operation Op
decltype(auto) cast(const From &Val)
cast<X> - Return the argument parameter cast to the specified type.
auto find_if(R &&Range, UnaryPredicate P)
Provide wrappers to std::find_if which take ranges instead of having to pass begin/end explicitly.
Matcher to bind the captured value.
Matching and combinator leaf case.
Matching or combinator leaf case.
Matcher for a specific value, but stores a reference to the value, not the value itself.
AllowFmf_match(const SubPattern_t &SP)
bool match(OpTy *V) const
AnyBinaryOp_match(const LHS_t &LHS, const RHS_t &RHS)
bool match(OpTy *V) const
Matches instructions with Opcode and any number of operands.
bool match(OpTy *V) const
std::enable_if_t< Idx==Last, bool > match_operands(const Instruction *I) const
std::enable_if_t< Idx !=Last, bool > match_operands(const Instruction *I) const
std::tuple< OperandTypes... > Operands
AnyOps_match(const OperandTypes &...Ops)
AnyUnaryOp_match(const OP_t &X)
bool match(OpTy *V) const
Argument_match(unsigned OpIdx, const Opnd_t &V)
bool match(OpTy *V) const
BinOpPred_match(const LHS_t &LHS, const RHS_t &RHS)
bool match(OpTy *V) const
BinaryOp_match(const LHS_t &LHS, const RHS_t &RHS)
bool match(OpTy *V) const
bool match(unsigned Opc, OpTy *V) const
CastInst_match(const Op_t &OpMatch)
bool match(OpTy *V) const
CastOperator_match(const Op_t &OpMatch)
bool match(OpTy *V) const
bool match(OpTy *V) const
CmpClass_match(CmpPredicate &Pred, const LHS_t &LHS, const RHS_t &RHS)
CmpClass_match(const LHS_t &LHS, const RHS_t &RHS)
bool match(OpTy *V) const
CommutativeBinaryIntrinsic_match(const LHS &L, const RHS &R)
DisjointOr_match(const LHS &L, const RHS &R)
bool match(OpTy *V) const
bool match(OpTy *V) const
ElementWiseBitCast_match(const Op_t &OpMatch)
Exact_match(const SubPattern_t &SP)
bool match(OpTy *V) const
FNeg_match(const Op_t &Op)
bool match(OpTy *V) const
ICmpLike_match(CmpPredicate &P, const LHS_t &Left, const RHS_t &Right)
bool match(OpTy *V) const
Matcher for a single index InsertValue instruction.
InsertValue_match(const T0 &Op0, const T1 &Op1)
bool match(OpTy *V) const
IntrinsicID_match(Intrinsic::ID IntrID)
bool match(OpTy *V) const
Match intrinsic calls with any of the given IDs.
bool match(OpTy *V) const
LogicalOp_match(const LHS &L, const RHS &R)
MaxMin_match(const LHS_t &LHS, const RHS_t &RHS)
bool match(OpTy *V) const
NNegZExt_match(const Op_t &OpMatch)
bool match(OpTy *V) const
NoWrapTrunc_match(const Op_t &OpMatch)
bool match(OpTy *V) const
Matches instructions with Opcode and three operands.
bool match(OpTy *V) const
OneOps_match(const T0 &Op1)
bool match(OpTy *V) const
OneUse_match(const SubPattern_t &SP)
bool match(OpTy *V) const
OverflowingBinaryOp_match(const LHS_t &LHS, const RHS_t &RHS)
bool match(OpTy *V) const
PtrAdd_match(const PointerOpTy &PointerOp, const OffsetOpTy &OffsetOp)
PtrToIntSameSize_match(const DataLayout &DL, const Op_t &OpMatch)
bool match(OpTy *V) const
SelectLike_match(const CondTy &C, const LTy &TC, const RTy &FC)
bool match(OpTy *V) const
ShiftLike_match(const LHS_t &LHS, uint64_t &RHS)
bool match(OpTy *V) const
Shuffle_match(const T0 &Op1, const T1 &Op2, const T2 &Mask)
bool match(OpTy *V) const
bool match(OpTy *V) const
Signum_match(const Opnd_t &V)
bool match(OpTy *V) const
SpecificBinaryOp_match(unsigned Opcode, const LHS_t &LHS, const RHS_t &RHS)
bool match(OpTy *V) const
SpecificCmpClass_match(CmpPredicate Pred, const LHS_t &LHS, const RHS_t &RHS)
const CmpPredicate Predicate
bool match(OpTy *V) const
Splat_match(const SubPattern_t &SP)
Matches instructions with Opcode and three operands.
ThreeOps_match(const T0 &Op1, const T1 &Op2, const T2 &Op3)
bool match(OpTy *V) const
Matches instructions with Opcode and three operands.
TwoOps_match(const T0 &Op1, const T1 &Op2)
bool match(OpTy *V) const
bool match(OpTy *V) const
UAddWithOverflow_match(const LHS_t &L, const RHS_t &R, const Sum_t &S)
XorLike_match(const LHS &L, const RHS &R)
bool match(OpTy *V) const
ap_match(const APTy *&Res, bool AllowPoison)
std::conditional_t< std::is_same_v< APTy, APInt >, ConstantInt, ConstantFP > ConstantTy
This helper class is used to match scalar and vector constants that satisfy a specified predicate,...
apf_pred_ty(const APFloat *&R)
This helper class is used to match scalar and vector constants that satisfy a specified predicate,...
api_pred_ty(const APInt *&R)
bind_const_intval_ty(uint64_t &V)
bind_immconstant_ty(Constant *&V)
bool match(OpTy *V) const
br_match(BasicBlock *&Succ)
brc_match(const Cond_t &C, const TrueBlock_t &t, const FalseBlock_t &f)
bool match(OpTy *V) const
This helper class is used to match constant scalars, vector splats, and fixed width vectors that sati...
bool match_impl(ITy *V) const
bool isValue(const APTy &C) const
function_ref< bool(const APTy &)> CheckFn
bool isValue(const APInt &C) const
static bool isImmConstant(ITy *V)
bool isValue(const APInt &C) const
bool isValue(const APInt &C) const
bool isValue(const APFloat &C) const
bool isOpType(unsigned Opcode) const
bool isValue(const APFloat &C) const
bool isValue(const APFloat &C) const
bool isOpType(unsigned Opcode) const
bool isValue(const APFloat &C) const
bool isOpType(unsigned Opcode) const
bool isOpType(unsigned Opcode) const
bool isValue(const APInt &C) const
bool isValue(const APInt &C) const
bool isValue(const APInt &C) const
bool isValue(const APFloat &C) const
bool isValue(const APFloat &C) const
bool isValue(const APInt &C) const
bool isValue(const APInt &C) const
bool isValue(const APInt &C) const
bool isValue(const APFloat &C) const
bool isValue(const APInt &C) const
bool isValue(const APFloat &C) const
bool isValue(const APFloat &C) const
bool isValue(const APFloat &C) const
bool isValue(const APInt &C) const
bool isValue(const APInt &C) const
bool isValue(const APInt &C) const
bool isValue(const APFloat &C) const
bool isValue(const APInt &C) const
bool isValue(const APInt &C) const
bool isOpType(unsigned Opcode) const
bool isOpType(unsigned Opcode) const
bool isValue(const APInt &C) const
bool isValue(const APInt &C) const
bool isValue(const APFloat &C) const
bool isValue(const APInt &C) const
bool isValue(const APInt &C) const
match_combine_and< typename m_Intrinsic_Ty< T0, T1, T2, T3, T4 >::Ty, Argument_match< T5 > > Ty
match_combine_and< typename m_Intrinsic_Ty< T0, T1, T2, T3 >::Ty, Argument_match< T4 > > Ty
match_combine_and< typename m_Intrinsic_Ty< T0, T1, T2 >::Ty, Argument_match< T3 > > Ty
match_combine_and< typename m_Intrinsic_Ty< T0, T1 >::Ty, Argument_match< T2 > > Ty
match_combine_and< typename m_Intrinsic_Ty< T0 >::Ty, Argument_match< T1 > > Ty
match_combine_and< IntrinsicID_match, Argument_match< T0 > > Ty
Intrinsic matches are combinations of ID matchers, and argument matchers.
ArrayRef< int > & MaskRef
m_Mask(ArrayRef< int > &MaskRef)
bool match(ArrayRef< int > Mask) const
bool match(ArrayRef< int > Mask) const
m_SpecificMask(ArrayRef< int > Val)
bool match(ArrayRef< int > Mask) const
m_SplatOrPoisonMask(int &SplatIndex)
bool match(ArrayRef< int > Mask) const
match_unless(const Ty &Matcher)
Helper class for identifying ordered max predicates.
static bool match(FCmpInst::Predicate Pred)
Helper class for identifying ordered min predicates.
static bool match(FCmpInst::Predicate Pred)
Helper class for identifying signed max predicates.
static bool match(ICmpInst::Predicate Pred)
Helper class for identifying signed min predicates.
static bool match(ICmpInst::Predicate Pred)
Match a specified basic block value.
specific_bbval(BasicBlock *Val)
Match a specified floating point value or vector of all elements of that value.
specific_intval64(uint64_t V)
Match a specified integer value or vector of all elements of that value.
specific_intval(const APInt &V)
Matcher for specified Value*.
specificval_ty(const Value *V)
Helper class for identifying unordered max predicates.
static bool match(FCmpInst::Predicate Pred)
Helper class for identifying unordered min predicates.
static bool match(FCmpInst::Predicate Pred)
Helper class for identifying unsigned max predicates.
static bool match(ICmpInst::Predicate Pred)
Helper class for identifying unsigned min predicates.
static bool match(ICmpInst::Predicate Pred)
static bool check(const Value *V)