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();
581 template <
typename ITy>
bool match(ITy *V)
const {
709 return C.isInfinity() && IsNegative ==
C.isNegative();
794 return !
C.isDenormal() &&
C.isNonZero();
811 template <
typename ITy>
bool match(ITy *V)
const {
828 template <
typename ITy>
bool match(ITy *V)
const {
830 if (CV &&
Match.match(V)) {
843template <
typename MatchTy>
845 const MatchTy &Match) {
850template <
typename MatchTy>
852 const MatchTy &Match) {
863template <
typename MatchTy>
868template <
typename MatchTy>
927 if (CV->getType()->isVectorTy()) {
928 if (
auto *
Splat = CV->getSplatValue(
true)) {
930 !
Splat->containsConstantExpression()) {
952 template <
typename ITy>
bool match(ITy *V)
const {
972 template <
typename ITy>
bool match(ITy *V)
const {
return V ==
Val; }
985 template <
typename ITy>
bool match(ITy *
const V)
const {
return V ==
Val; }
1006 template <
typename ITy>
bool match(ITy *V)
const {
1008 return CFP->isExactlyValue(
Val);
1009 if (V->getType()->isVectorTy())
1012 return CFP->isExactlyValue(
Val);
1029 template <
typename ITy>
bool match(ITy *V)
const {
1030 const APInt *ConstInt;
1033 std::optional<uint64_t> ZExtVal = ConstInt->
tryZExtValue();
1048 template <
typename ITy>
bool match(ITy *V)
const {
1050 if (!CI && V->getType()->isVectorTy())
1063 template <
typename ITy>
bool match(ITy *V)
const {
1065 if (!CI && V->getType()->isVectorTy())
1069 return CI && CI->getValue() ==
Val;
1101 template <
typename ITy>
bool match(ITy *V)
const {
1103 return BB && BB ==
Val;
1124template <
typename LHS_t,
typename RHS_t,
bool Commutable = false>
1133 template <
typename OpTy>
bool match(OpTy *V)
const {
1135 return (
L.match(
I->getOperand(0)) &&
R.match(
I->getOperand(1))) ||
1136 (Commutable &&
L.match(
I->getOperand(1)) &&
1137 R.match(
I->getOperand(0)));
1142template <
typename LHS,
typename RHS>
1156 template <
typename OpTy>
bool match(OpTy *V)
const {
1158 return X.match(
I->getOperand(0));
1171template <
typename LHS_t,
typename RHS_t,
unsigned Opcode,
1172 bool Commutable =
false>
1181 template <
typename OpTy>
inline bool match(
unsigned Opc, OpTy *V)
const {
1182 if (V->getValueID() == Value::InstructionVal +
Opc) {
1184 return (
L.match(
I->getOperand(0)) &&
R.match(
I->getOperand(1))) ||
1185 (Commutable &&
L.match(
I->getOperand(1)) &&
1186 R.match(
I->getOperand(0)));
1191 template <
typename OpTy>
bool match(OpTy *V)
const {
1192 return match(Opcode, V);
1196template <
typename LHS,
typename RHS>
1202template <
typename LHS,
typename RHS>
1208template <
typename LHS,
typename RHS>
1214template <
typename LHS,
typename RHS>
1224 template <
typename OpTy>
bool match(OpTy *V)
const {
1229 if (FPMO->getOpcode() == Instruction::FNeg)
1230 return X.match(FPMO->getOperand(0));
1232 if (FPMO->getOpcode() == Instruction::FSub) {
1233 if (FPMO->hasNoSignedZeros()) {
1243 return X.match(FPMO->getOperand(1));
1256template <
typename RHS>
1262template <
typename LHS,
typename RHS>
1268template <
typename LHS,
typename RHS>
1274template <
typename LHS,
typename RHS>
1280template <
typename LHS,
typename RHS>
1286template <
typename LHS,
typename RHS>
1292template <
typename LHS,
typename RHS>
1298template <
typename LHS,
typename RHS>
1304template <
typename LHS,
typename RHS>
1310template <
typename LHS,
typename RHS>
1316template <
typename LHS,
typename RHS>
1322template <
typename LHS,
typename RHS>
1328template <
typename LHS,
typename RHS>
1334template <
typename LHS,
typename RHS>
1340template <
typename LHS,
typename RHS>
1352 template <
typename OpTy>
bool match(OpTy *V)
const {
1354 if (
Op->getOpcode() == Opcode)
1356 L.match(
Op->getOperand(0));
1365template <
typename LHS>
1372template <
typename LHS>
1379template <
typename LHS>
1385template <
typename LHS_t,
typename RHS_t,
unsigned Opcode,
1386 unsigned WrapFlags = 0,
bool Commutable =
false>
1394 template <
typename OpTy>
bool match(OpTy *V)
const {
1396 if (
Op->getOpcode() != Opcode)
1399 !
Op->hasNoUnsignedWrap())
1402 !
Op->hasNoSignedWrap())
1404 return (
L.match(
Op->getOperand(0)) &&
R.match(
Op->getOperand(1))) ||
1405 (Commutable &&
L.match(
Op->getOperand(1)) &&
1406 R.match(
Op->getOperand(0)));
1412template <
typename LHS,
typename RHS>
1420template <
typename LHS,
typename RHS>
1428template <
typename LHS,
typename RHS>
1436template <
typename LHS,
typename RHS>
1444template <
typename LHS,
typename RHS>
1453template <
typename LHS,
typename RHS>
1462template <
typename LHS,
typename RHS>
1471template <
typename LHS,
typename RHS>
1479template <
typename LHS,
typename RHS>
1487template <
typename LHS,
typename RHS>
1496template <
typename LHS_t,
typename RHS_t,
bool Commutable = false>
1504 template <
typename OpTy>
bool match(OpTy *V)
const {
1510template <
typename LHS,
typename RHS>
1516template <
typename LHS,
typename RHS,
bool Commutable = false>
1523 template <
typename OpTy>
bool match(OpTy *V)
const {
1525 assert(PDI->getOpcode() == Instruction::Or &&
"Only or can be disjoint");
1526 if (!PDI->isDisjoint())
1528 return (
L.match(PDI->getOperand(0)) &&
R.match(PDI->getOperand(1))) ||
1529 (Commutable &&
L.match(PDI->getOperand(1)) &&
1530 R.match(PDI->getOperand(0)));
1536template <
typename LHS,
typename RHS>
1541template <
typename LHS,
typename RHS>
1548template <
typename LHS,
typename RHS>
1556template <
typename LHS,
typename RHS>
1566template <
typename LHS,
typename RHS>
1575template <
typename LHS,
typename RHS>
1582 template <
typename OpTy>
bool match(OpTy *V)
const {
1584 if (
Op->getOpcode() == Instruction::Sub &&
Op->hasNoUnsignedWrap() &&
1587 else if (
Op->getOpcode() != Instruction::Xor)
1589 return (
L.match(
Op->getOperand(0)) &&
R.match(
Op->getOperand(1))) ||
1590 (
L.match(
Op->getOperand(1)) &&
R.match(
Op->getOperand(0)));
1598template <
typename LHS,
typename RHS>
1606template <
typename LHS_t,
typename RHS_t,
typename Predicate,
1607 bool Commutable =
false>
1614 template <
typename OpTy>
bool match(OpTy *V)
const {
1616 return this->isOpType(
I->getOpcode()) &&
1617 ((
L.match(
I->getOperand(0)) &&
R.match(
I->getOperand(1))) ||
1618 (Commutable &&
L.match(
I->getOperand(1)) &&
1619 R.match(
I->getOperand(0))));
1630 return Opcode == Instruction::LShr || Opcode == Instruction::AShr;
1636 return Opcode == Instruction::LShr || Opcode == Instruction::Shl;
1648 return Opcode == Instruction::SDiv || Opcode == Instruction::UDiv;
1654 return Opcode == Instruction::SRem || Opcode == Instruction::URem;
1659template <
typename LHS,
typename RHS>
1666template <
typename LHS,
typename RHS>
1673template <
typename LHS,
typename RHS>
1680template <
typename LHS,
typename RHS>
1687template <
typename LHS,
typename RHS>
1694template <
typename LHS,
typename RHS>
1701template <
typename LHS,
typename RHS>
1715 template <
typename OpTy>
bool match(OpTy *V)
const {
1717 return PEO->isExact() &&
SubPattern.match(V);
1730template <
typename LHS_t,
typename RHS_t,
typename Class,
1731 bool Commutable =
false>
1744 template <
typename OpTy>
bool match(OpTy *V)
const {
1746 if (
L.match(
I->getOperand(0)) &&
R.match(
I->getOperand(1))) {
1751 if (Commutable &&
L.match(
I->getOperand(1)) &&
1752 R.match(
I->getOperand(0))) {
1762template <
typename LHS,
typename RHS>
1768template <
typename LHS,
typename RHS>
1770 const LHS &L,
const RHS &R) {
1774template <
typename LHS,
typename RHS>
1776 const LHS &L,
const RHS &R) {
1780template <
typename LHS,
typename RHS>
1785template <
typename LHS,
typename RHS>
1790template <
typename LHS,
typename RHS>
1797template <
typename LHS_t,
typename RHS_t,
typename Class,
1798 bool Commutable =
false>
1807 template <
typename OpTy>
bool match(OpTy *V)
const {
1810 L.match(
I->getOperand(0)) &&
R.match(
I->getOperand(1)))
1812 if constexpr (Commutable) {
1815 L.match(
I->getOperand(1)) &&
R.match(
I->getOperand(0)))
1824template <
typename LHS,
typename RHS>
1830template <
typename LHS,
typename RHS>
1836template <
typename LHS,
typename RHS>
1842template <
typename LHS,
typename RHS>
1858 template <
typename OpTy>
bool match(OpTy *V)
const {
1859 if (V->getValueID() == Value::InstructionVal + Opcode) {
1861 return Op1.match(
I->getOperand(0));
1874 template <
typename OpTy>
bool match(OpTy *V)
const {
1875 if (V->getValueID() == Value::InstructionVal + Opcode) {
1877 return Op1.match(
I->getOperand(0)) &&
Op2.match(
I->getOperand(1));
1884template <
typename T0,
typename T1,
typename T2,
unsigned Opcode,
1885 bool CommutableOp2Op3 =
false>
1894 template <
typename OpTy>
bool match(OpTy *V)
const {
1895 if (V->getValueID() == Value::InstructionVal + Opcode) {
1897 if (!
Op1.match(
I->getOperand(0)))
1899 if (
Op2.match(
I->getOperand(1)) &&
Op3.match(
I->getOperand(2)))
1901 return CommutableOp2Op3 &&
Op2.match(
I->getOperand(2)) &&
1902 Op3.match(
I->getOperand(1));
1918 template <
int Idx,
int Last>
1919 std::enable_if_t<Idx != Last, bool>
1924 template <
int Idx,
int Last>
1925 std::enable_if_t<Idx == Last, bool>
1927 return std::get<Idx>(
Operands).match(
I->getOperand(Idx));
1930 template <
typename OpTy>
bool match(OpTy *V)
const {
1931 if (V->getValueID() == Value::InstructionVal + Opcode) {
1933 return I->getNumOperands() ==
sizeof...(OperandTypes) &&
1941template <
typename Cond,
typename LHS,
typename RHS>
1949template <
int64_t L,
int64_t R,
typename Cond>
1951 Instruction::Select>
1957template <
typename LHS,
typename RHS>
1965template <
typename OpTy>
1971template <
typename Val_t,
typename Elt_t,
typename Idx_t>
1979template <
typename Val_t,
typename Idx_t>
1994 template <
typename OpTy>
bool match(OpTy *V)
const {
1996 return Op1.match(
I->getOperand(0)) &&
Op2.match(
I->getOperand(1)) &&
1997 Mask.match(
I->getShuffleMask());
2014 return all_of(Mask, [](
int Elem) {
return Elem == 0 || Elem == -1; });
2028 const auto *
First =
find_if(Mask, [](
int Elem) {
return Elem != -1; });
2029 if (
First == Mask.end())
2033 [
First](
int Elem) {
return Elem == *
First || Elem == -1; });
2044 template <
typename OpTy>
bool match(OpTy *V)
const {
2046 return GEP &&
GEP->getSourceElementType()->isIntegerTy(8) &&
2053template <
typename V1_t,
typename V2_t>
2059template <
typename V1_t,
typename V2_t,
typename Mask_t>
2066template <
typename OpTy>
2072template <
typename ValueOpTy,
typename Po
interOpTy>
2074m_Store(
const ValueOpTy &ValueOp,
const PointerOpTy &PointerOp) {
2080template <
typename... OperandTypes>
2082 return AnyOps_match<Instruction::GetElementPtr, OperandTypes...>(
Ops...);
2086template <
typename Po
interOpTy,
typename OffsetOpTy>
2101 template <
typename OpTy>
bool match(OpTy *V)
const {
2103 return O->getOpcode() == Opcode &&
Op.match(O->getOperand(0));
2113 template <
typename OpTy>
bool match(OpTy *V)
const {
2115 return Op.match(
I->getOperand(0));
2127 template <
typename OpTy>
bool match(OpTy *V)
const {
2129 return O->getOpcode() == Instruction::PtrToInt &&
2130 DL.getTypeSizeInBits(O->getType()) ==
2131 DL.getTypeSizeInBits(O->getOperand(0)->getType()) &&
2132 Op.match(O->getOperand(0));
2142 template <
typename OpTy>
bool match(OpTy *V)
const {
2144 return I->hasNonNeg() &&
Op.match(
I->getOperand(0));
2154 template <
typename OpTy>
bool match(OpTy *V)
const {
2156 return (
I->getNoWrapKind() & WrapFlags) == WrapFlags &&
2157 Op.match(
I->getOperand(0));
2163template <
typename OpTy>
2174 template <
typename OpTy>
bool match(OpTy *V)
const {
2178 Type *SrcType =
I->getSrcTy();
2179 Type *DstType =
I->getType();
2182 if (SrcType->isVectorTy() != DstType->isVectorTy())
2185 SrcVecTy && SrcVecTy->getElementCount() !=
2188 return Op.match(
I->getOperand(0));
2192template <
typename OpTy>
2198template <
typename OpTy>
2204template <
typename OpTy>
2211template <
typename OpTy>
2223template <
typename OpTy>
2230template <
typename OpTy>
2237template <
typename OpTy>
2243template <
typename OpTy>
2250template <
typename OpTy>
2256template <
typename OpTy>
2263template <
typename OpTy>
2269template <
typename OpTy>
2274template <
typename OpTy>
2279template <
typename OpTy>
2285template <
typename OpTy>
2292template <
typename OpTy>
2298template <
typename OpTy>
2305template <
typename OpTy>
2325 template <
typename OpTy>
bool match(OpTy *V)
const {
2330 Type *Ty = V->getType();
2331 Value *CondV =
nullptr;
2336 TrueC.match(ConstantInt::get(Ty, 1)) &&
2337 FalseC.match(ConstantInt::get(Ty, 0)))
2344 FalseC.match(ConstantInt::get(Ty, 0)))
2359template <
typename CondTy,
typename LTy,
typename RTy>
2365template <
typename OpTy>
2370template <
typename OpTy>
2375template <
typename OpTy>
2382template <
typename OpTy>
2387template <
typename OpTy>
2392template <
typename OpTy>
2399template <
typename OpTy>
2404template <
typename OpTy>
2418 template <
typename OpTy>
bool match(OpTy *V)
const {
2420 Succ = BI->getSuccessor();
2429template <
typename Cond_t,
typename TrueBlock_t,
typename FalseBlock_t>
2435 brc_match(
const Cond_t &
C,
const TrueBlock_t &t,
const FalseBlock_t &f)
2438 template <
typename OpTy>
bool match(OpTy *V)
const {
2440 if (
Cond.match(BI->getCondition()))
2441 return T.match(BI->getSuccessor(0)) &&
F.match(BI->getSuccessor(1));
2446template <
typename Cond_t>
2453template <
typename Cond_t,
typename TrueBlock_t,
typename FalseBlock_t>
2455m_Br(
const Cond_t &
C,
const TrueBlock_t &
T,
const FalseBlock_t &
F) {
2463template <
typename CmpInst_t,
typename LHS_t,
typename RHS_t,
typename Pred_t,
2464 bool Commutable =
false>
2474 template <
typename OpTy>
bool match(OpTy *V)
const {
2481 Value *LHS =
II->getOperand(0), *RHS =
II->getOperand(1);
2482 return (
L.match(LHS) &&
R.match(RHS)) ||
2483 (Commutable &&
L.match(RHS) &&
R.match(LHS));
2495 auto *TrueVal =
SI->getTrueValue();
2496 auto *FalseVal =
SI->getFalseValue();
2497 auto *LHS = Cmp->getOperand(0);
2498 auto *RHS = Cmp->getOperand(1);
2499 if ((TrueVal != LHS || FalseVal != RHS) &&
2500 (TrueVal != RHS || FalseVal != LHS))
2502 typename CmpInst_t::Predicate Pred =
2503 LHS == TrueVal ? Cmp->getPredicate() : Cmp->getInversePredicate();
2505 if (!Pred_t::match(Pred))
2508 return (
L.match(LHS) &&
R.match(RHS)) ||
2509 (Commutable &&
L.match(RHS) &&
R.match(LHS));
2569template <
typename LHS,
typename RHS>
2575template <
typename LHS,
typename RHS>
2581template <
typename LHS,
typename RHS>
2587template <
typename LHS,
typename RHS>
2593template <
typename LHS,
typename RHS>
2607template <
typename LHS,
typename RHS>
2622template <
typename LHS,
typename RHS>
2637template <
typename LHS,
typename RHS>
2652template <
typename LHS,
typename RHS>
2663template <
typename LHS,
typename RHS>
2676template <
typename LHS,
typename RHS>
2687template <
typename ValTy>
2693template <
typename ValTy>
2705template <
typename LHS_t,
typename RHS_t,
typename Sum_t>
2714 template <
typename OpTy>
bool match(OpTy *V)
const {
2715 Value *ICmpLHS, *ICmpRHS;
2720 Value *AddLHS, *AddRHS;
2725 if (AddExpr.match(ICmpLHS) && (ICmpRHS == AddLHS || ICmpRHS == AddRHS))
2726 return L.match(AddLHS) &&
R.match(AddRHS) &&
S.match(ICmpLHS);
2730 if (AddExpr.match(ICmpRHS) && (ICmpLHS == AddLHS || ICmpLHS == AddRHS))
2731 return L.match(AddLHS) &&
R.match(AddRHS) &&
S.match(ICmpRHS);
2737 if (XorExpr.match(ICmpLHS))
2738 return L.match(Op1) &&
R.match(ICmpRHS) &&
S.match(ICmpLHS);
2742 if (XorExpr.match(ICmpRHS))
2743 return L.match(Op1) &&
R.match(ICmpLHS) &&
S.match(ICmpRHS);
2752 return L.match(AddLHS) &&
R.match(AddRHS) &&
S.match(ICmpLHS);
2757 return L.match(AddLHS) &&
R.match(AddRHS) &&
S.match(ICmpRHS);
2768template <
typename LHS_t,
typename RHS_t,
typename Sum_t>
2780 template <
typename OpTy>
bool match(OpTy *V)
const {
2783 return Val.match(CI->getArgOperand(
OpI));
2789template <
unsigned OpI,
typename Opnd_t>
2800 template <
typename OpTy>
bool match(OpTy *V)
const {
2803 return F->getIntrinsicID() ==
ID;
2812template <
typename T0 = void,
typename T1 = void,
typename T2 = void,
2813 typename T3 = void,
typename T4 = void,
typename T5 = void,
2814 typename T6 = void,
typename T7 = void,
typename T8 = void,
2815 typename T9 = void,
typename T10 =
void>
2824template <
typename T0,
typename T1,
typename T2>
2829template <
typename T0,
typename T1,
typename T2,
typename T3>
2835template <
typename T0,
typename T1,
typename T2,
typename T3,
typename T4>
2841template <
typename T0,
typename T1,
typename T2,
typename T3,
typename T4,
2855template <
typename Opnd0,
typename Opnd1,
typename Opnd2>
2862template <
typename Opnd0,
typename Opnd1,
typename Opnd2>
2869template <
typename Opnd0,
typename Opnd1,
typename Opnd2>
2875template <Intrinsic::ID IntrID,
typename T0>
2880template <Intrinsic::ID IntrID,
typename T0,
typename T1>
2886template <Intrinsic::ID IntrID,
typename T0,
typename T1,
typename T2>
2892template <
Intrinsic::ID IntrID,
typename T0,
typename T1,
typename T2,
2895m_Intrinsic(
const T0 &Op0,
const T1 &Op1,
const T2 &Op2,
const T3 &Op3) {
2899template <
Intrinsic::ID IntrID,
typename T0,
typename T1,
typename T2,
2900 typename T3,
typename T4>
2902m_Intrinsic(
const T0 &Op0,
const T1 &Op1,
const T2 &Op2,
const T3 &Op3,
2908template <
Intrinsic::ID IntrID,
typename T0,
typename T1,
typename T2,
2909 typename T3,
typename T4,
typename T5>
2911m_Intrinsic(
const T0 &Op0,
const T1 &Op1,
const T2 &Op2,
const T3 &Op3,
2912 const T4 &Op4,
const T5 &Op5) {
2918template <
typename Opnd0>
2923template <
typename Opnd0>
2928template <
typename Opnd0>
2933template <
typename Opnd0>
2938template <
typename Opnd0,
typename Opnd1>
2944template <
typename Opnd0,
typename Opnd1>
2950template <
typename Opnd0,
typename Opnd1>
2956template <
typename Opnd0,
typename Opnd1>
2962template <
typename Opnd0,
typename Opnd1>
2968template <
typename Opnd0,
typename Opnd1>
2974template <
typename Opnd0,
typename Opnd1>
2981template <
typename Opnd0,
typename Opnd1>
2988template <
typename Opnd0,
typename Opnd1,
typename Opnd2>
2990m_FShl(
const Opnd0 &Op0,
const Opnd1 &Op1,
const Opnd2 &Op2) {
2994template <
typename Opnd0,
typename Opnd1,
typename Opnd2>
2996m_FShr(
const Opnd0 &Op0,
const Opnd1 &Op1,
const Opnd2 &Op2) {
3000template <
typename Opnd0>
3005template <
typename Opnd0,
typename Opnd1>
3011template <
typename Opnd0>
3016template <
typename Opnd0,
typename Opnd1,
typename Opnd2>
3027template <
typename LHS,
typename RHS>
3034template <
typename LHS,
typename RHS>
3040template <
typename LHS,
typename RHS>
3047template <
typename LHS,
typename RHS>
3054template <
typename LHS,
typename RHS>
3061template <
typename LHS,
typename RHS>
3068template <
typename LHS,
typename RHS>
3075template <
typename LHS,
typename RHS>
3082template <
typename LHS,
typename RHS>
3089template <
typename ValTy>
3096template <
typename ValTy>
3105template <
typename LHS,
typename RHS>
3111template <
typename LHS,
typename RHS>
3117template <
typename LHS,
typename RHS>
3123template <
typename LHS,
typename RHS>
3129template <
typename LHS,
typename RHS>
3135template <Intrinsic::ID IntrID,
typename LHS,
typename RHS>
3142 template <
typename OpTy>
bool match(OpTy *V)
const {
3144 if (!
II ||
II->getIntrinsicID() != IntrID)
3146 return (
L.match(
II->getArgOperand(0)) &&
R.match(
II->getArgOperand(1))) ||
3147 (
L.match(
II->getArgOperand(1)) &&
R.match(
II->getArgOperand(0)));
3151template <Intrinsic::ID IntrID,
typename T0,
typename T1>
3158template <
typename LHS,
typename RHS>
3165template <
typename LHS,
typename RHS>
3175 template <
typename OpTy>
bool match(OpTy *V)
const {
3176 unsigned TypeSize = V->getType()->getScalarSizeInBits();
3180 unsigned ShiftWidth =
TypeSize - 1;
3195 auto Signum =
m_c_Or(LHS, RHS);
3197 return Signum.match(V) &&
Val.match(
Op);
3215 template <
typename OpTy>
bool match(OpTy *V)
const {
3219 !(
I->getNumIndices() == 1 &&
I->getIndices()[0] == (
unsigned)Ind))
3221 return Val.match(
I->getAggregateOperand());
3229template <
int Ind,
typename Val_t>
3236template <
typename Val_t>
3248 template <
typename OpTy>
bool match(OpTy *V)
const {
3250 return Op0.match(
I->getOperand(0)) &&
Op1.match(
I->getOperand(1)) &&
3251 I->getNumIndices() == 1 && Ind ==
I->getIndices()[0];
3258template <
int Ind,
typename Val_t,
typename Elt_t>
3267template <
typename Opnd0,
typename Opnd1>
3273template <
typename Opnd>
3278template <
typename LHS,
typename RHS,
unsigned Opcode,
bool Commutable = false>
3285 template <
typename T>
bool match(
T *V)
const {
3287 if (!
I || !
I->getType()->isIntOrIntVectorTy(1))
3290 if (
I->getOpcode() == Opcode) {
3291 auto *Op0 =
I->getOperand(0);
3292 auto *Op1 =
I->getOperand(1);
3293 return (
L.match(Op0) &&
R.match(Op1)) ||
3294 (Commutable &&
L.match(Op1) &&
R.match(Op0));
3299 auto *TVal =
Select->getTrueValue();
3300 auto *FVal =
Select->getFalseValue();
3307 if (Opcode == Instruction::And) {
3309 if (
C &&
C->isNullValue())
3310 return (
L.match(
Cond) &&
R.match(TVal)) ||
3311 (Commutable &&
L.match(TVal) &&
R.match(
Cond));
3313 assert(Opcode == Instruction::Or);
3315 if (
C &&
C->isOneValue())
3316 return (
L.match(
Cond) &&
R.match(FVal)) ||
3317 (Commutable &&
L.match(FVal) &&
R.match(
Cond));
3327template <
typename LHS,
typename RHS>
3337template <
typename LHS,
typename RHS>
3345template <
typename LHS,
typename RHS>
3355template <
typename LHS,
typename RHS>
3364template <
typename LHS,
typename RHS,
bool Commutable = false>
3375template <
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)
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...
ArrayRef - 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)
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.
@ 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.
cst_pred_ty< is_shifted_mask > m_ShiftedMask()
bind_ty< Instruction > m_Instruction(Instruction *&I)
Match an instruction, capturing it if we 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)
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).
bind_ty< WithOverflowInst > m_WithOverflowInst(WithOverflowInst *&I)
Match a with overflow intrinsic, capturing it if we match.
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)
deferredval_ty< 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()...
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)
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)
brc_match< Cond_t, bind_ty< BasicBlock >, bind_ty< BasicBlock > > m_Br(const Cond_t &C, BasicBlock *&T, BasicBlock *&F)
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".
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.
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)
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)
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.
Matching and combinator leaf case.
Matching or combinator leaf case.
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
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
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)
Check whether the value has the given Class and matches the nested pattern.
bind_and_match_ty(Class *&V, const MatchTy &Match)
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
Stores a reference to the Value *, not the Value * itself, thus can be used in commutative matchers.
deferredval_ty(Class *const &V)
bool match(ITy *const V) const
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)
Match a 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)