28#ifndef LLVM_IR_PATTERNMATCH_H
29#define LLVM_IR_PATTERNMATCH_H
47namespace PatternMatch {
49template <
typename Val,
typename Pattern>
bool match(Val *V,
const Pattern &
P) {
62 template <
typename OpTy>
bool match(OpTy *V)
const {
76 template <
typename OpTy>
bool match(OpTy *V)
const {
77 auto *
I = dyn_cast<FPMathOperator>(V);
88 template <
typename ITy>
bool match(ITy *V)
const {
return isa<Class>(V); }
109 if (isa<UndefValue>(V))
112 const auto *CA = dyn_cast<ConstantAggregate>(V);
123 for (
const Value *
Op : CA->operand_values()) {
124 if (isa<UndefValue>(
Op))
127 const auto *CA = dyn_cast<ConstantAggregate>(
Op);
130 if (Seen.
insert(CA).second)
140 while (!Worklist.
empty()) {
146 template <
typename ITy>
bool match(ITy *V)
const {
return check(V); }
178 template <
typename ITy>
bool match(ITy *V)
const {
179 auto *
C = dyn_cast<Constant>(V);
180 return C && (isa<ConstantExpr>(
C) ||
C->containsConstantExpression());
199 template <
typename ITy>
bool match(ITy *V)
const {
return !
M.match(V); }
214 template <
typename ITy>
bool match(ITy *V)
const {
229 template <
typename ITy>
bool match(ITy *V)
const {
238template <
typename LTy,
typename RTy>
244template <
typename LTy,
typename RTy>
256 template <
typename ITy>
bool match(ITy *V)
const {
257 if (
auto *CI = dyn_cast<ConstantInt>(V)) {
258 Res = &CI->getValue();
261 if (V->getType()->isVectorTy())
262 if (
const auto *
C = dyn_cast<Constant>(V))
264 dyn_cast_or_null<ConstantInt>(
C->getSplatValue(
AllowPoison))) {
265 Res = &CI->getValue();
281 template <
typename ITy>
bool match(ITy *V)
const {
282 if (
auto *CI = dyn_cast<ConstantFP>(V)) {
283 Res = &CI->getValueAPF();
286 if (V->getType()->isVectorTy())
287 if (
const auto *
C = dyn_cast<Constant>(V))
289 dyn_cast_or_null<ConstantFP>(
C->getSplatValue(
AllowPoison))) {
290 Res = &CI->getValueAPF();
332 template <
typename ITy>
bool match(ITy *V)
const {
333 if (
const auto *CI = dyn_cast<ConstantInt>(V)) {
334 const APInt &CIV = CI->getValue();
336 return CIV ==
static_cast<uint64_t>(Val);
355template <
typename Predicate,
typename ConstantVal,
bool AllowPoison>
359 if (
const auto *CV = dyn_cast<ConstantVal>(V))
360 return this->isValue(CV->getValue());
361 if (
const auto *VTy = dyn_cast<VectorType>(V->getType())) {
362 if (
const auto *
C = dyn_cast<Constant>(V)) {
363 if (
const auto *CV = dyn_cast_or_null<ConstantVal>(
C->getSplatValue()))
364 return this->isValue(CV->getValue());
367 auto *FVTy = dyn_cast<FixedVectorType>(VTy);
372 unsigned NumElts = FVTy->getNumElements();
373 assert(NumElts != 0 &&
"Constant vector with no elements?");
374 bool HasNonPoisonElements =
false;
375 for (
unsigned i = 0; i != NumElts; ++i) {
376 Constant *Elt =
C->getAggregateElement(i);
379 if (AllowPoison && isa<PoisonValue>(Elt))
381 auto *CV = dyn_cast<ConstantVal>(Elt);
382 if (!CV || !this->isValue(CV->getValue()))
384 HasNonPoisonElements =
true;
386 return HasNonPoisonElements;
392 template <
typename ITy>
bool match(ITy *V)
const {
395 *
Res = cast<Constant>(V);
403template <
typename Predicate,
bool AllowPoison = true>
407template <
typename Predicate>
418 template <
typename ITy>
bool match(ITy *V)
const {
419 if (
const auto *CI = dyn_cast<ConstantInt>(V))
420 if (this->isValue(CI->getValue())) {
421 Res = &CI->getValue();
424 if (V->getType()->isVectorTy())
425 if (
const auto *
C = dyn_cast<Constant>(V))
426 if (
auto *CI = dyn_cast_or_null<ConstantInt>(
427 C->getSplatValue(
true)))
428 if (this->isValue(CI->getValue())) {
429 Res = &CI->getValue();
445 template <
typename ITy>
bool match(ITy *V)
const {
446 if (
const auto *CI = dyn_cast<ConstantFP>(V))
447 if (this->isValue(CI->getValue())) {
448 Res = &CI->getValue();
451 if (V->getType()->isVectorTy())
452 if (
const auto *
C = dyn_cast<Constant>(V))
453 if (
auto *CI = dyn_cast_or_null<ConstantFP>(
454 C->getSplatValue(
true)))
455 if (this->isValue(CI->getValue())) {
456 Res = &CI->getValue();
604 template <
typename ITy>
bool match(ITy *V)
const {
605 auto *
C = dyn_cast<Constant>(V);
799 return !
C.isDenormal() &&
C.isNonZero();
816 template <
typename ITy>
bool match(ITy *V)
const {
817 if (
auto *CV = dyn_cast<Class>(V)) {
833 template <
typename ITy>
bool match(ITy *V)
const {
834 auto *CV = dyn_cast<Class>(V);
835 if (CV &&
Match.match(V)) {
848template <
typename MatchTy>
850 const MatchTy &Match) {
855template <
typename MatchTy>
857 const MatchTy &Match) {
865template <
typename MatchTy>
909 if (
auto *CV = dyn_cast<Constant>(V)) {
910 if (!isa<ConstantExpr>(CV) && !CV->containsConstantExpression())
913 if (CV->getType()->isVectorTy()) {
914 if (
auto *
Splat = CV->getSplatValue(
true)) {
915 if (!isa<ConstantExpr>(
Splat) &&
916 !
Splat->containsConstantExpression()) {
938 template <
typename ITy>
bool match(ITy *V)
const {
940 VR = cast<Constant>(V);
958 template <
typename ITy>
bool match(ITy *V)
const {
return V ==
Val; }
971 template <
typename ITy>
bool match(ITy *
const V)
const {
return V ==
Val; }
992 template <
typename ITy>
bool match(ITy *V)
const {
993 if (
const auto *CFP = dyn_cast<ConstantFP>(V))
994 return CFP->isExactlyValue(
Val);
995 if (V->getType()->isVectorTy())
996 if (
const auto *
C = dyn_cast<Constant>(V))
997 if (
auto *CFP = dyn_cast_or_null<ConstantFP>(
C->getSplatValue()))
998 return CFP->isExactlyValue(
Val);
1015 template <
typename ITy>
bool match(ITy *V)
const {
1016 const APInt *ConstInt;
1033 template <
typename ITy>
bool match(ITy *V)
const {
1034 const auto *CI = dyn_cast<ConstantInt>(V);
1035 if (!CI && V->getType()->isVectorTy())
1036 if (
const auto *
C = dyn_cast<Constant>(V))
1037 CI = dyn_cast_or_null<ConstantInt>(
C->getSplatValue(AllowPoison));
1048 template <
typename ITy>
bool match(ITy *V)
const {
1049 const auto *CI = dyn_cast<ConstantInt>(V);
1050 if (!CI && V->getType()->isVectorTy())
1051 if (
const auto *
C = dyn_cast<Constant>(V))
1052 CI = dyn_cast_or_null<ConstantInt>(
C->getSplatValue(AllowPoison));
1054 return CI && CI->getValue() ==
Val;
1086 template <
typename ITy>
bool match(ITy *V)
const {
1087 const auto *BB = dyn_cast<BasicBlock>(V);
1088 return BB && BB ==
Val;
1109template <
typename LHS_t,
typename RHS_t,
bool Commutable = false>
1118 template <
typename OpTy>
bool match(OpTy *V)
const {
1119 if (
auto *
I = dyn_cast<BinaryOperator>(V))
1120 return (
L.match(
I->getOperand(0)) &&
R.match(
I->getOperand(1))) ||
1121 (Commutable &&
L.match(
I->getOperand(1)) &&
1122 R.match(
I->getOperand(0)));
1127template <
typename LHS,
typename RHS>
1141 template <
typename OpTy>
bool match(OpTy *V)
const {
1142 if (
auto *
I = dyn_cast<UnaryOperator>(V))
1143 return X.match(
I->getOperand(0));
1156template <
typename LHS_t,
typename RHS_t,
unsigned Opcode,
1157 bool Commutable =
false>
1166 template <
typename OpTy>
inline bool match(
unsigned Opc, OpTy *V)
const {
1167 if (V->getValueID() == Value::InstructionVal +
Opc) {
1168 auto *
I = cast<BinaryOperator>(V);
1169 return (
L.match(
I->getOperand(0)) &&
R.match(
I->getOperand(1))) ||
1170 (Commutable &&
L.match(
I->getOperand(1)) &&
1171 R.match(
I->getOperand(0)));
1176 template <
typename OpTy>
bool match(OpTy *V)
const {
1177 return match(Opcode, V);
1181template <
typename LHS,
typename RHS>
1187template <
typename LHS,
typename RHS>
1193template <
typename LHS,
typename RHS>
1199template <
typename LHS,
typename RHS>
1209 template <
typename OpTy>
bool match(OpTy *V)
const {
1210 auto *FPMO = dyn_cast<FPMathOperator>(V);
1214 if (FPMO->getOpcode() == Instruction::FNeg)
1215 return X.match(FPMO->getOperand(0));
1217 if (FPMO->getOpcode() == Instruction::FSub) {
1218 if (FPMO->hasNoSignedZeros()) {
1228 return X.match(FPMO->getOperand(1));
1241template <
typename RHS>
1247template <
typename LHS,
typename RHS>
1253template <
typename LHS,
typename RHS>
1259template <
typename LHS,
typename RHS>
1265template <
typename LHS,
typename RHS>
1271template <
typename LHS,
typename RHS>
1277template <
typename LHS,
typename RHS>
1283template <
typename LHS,
typename RHS>
1289template <
typename LHS,
typename RHS>
1295template <
typename LHS,
typename RHS>
1301template <
typename LHS,
typename RHS>
1307template <
typename LHS,
typename RHS>
1313template <
typename LHS,
typename RHS>
1319template <
typename LHS,
typename RHS>
1325template <
typename LHS,
typename RHS>
1337 template <
typename OpTy>
bool match(OpTy *V)
const {
1338 if (
auto *
Op = dyn_cast<BinaryOperator>(V)) {
1339 if (
Op->getOpcode() == Opcode)
1341 L.match(
Op->getOperand(0));
1350template <
typename LHS>
1357template <
typename LHS>
1364template <
typename LHS>
1370template <
typename LHS_t,
typename RHS_t,
unsigned Opcode,
1371 unsigned WrapFlags = 0,
bool Commutable =
false>
1379 template <
typename OpTy>
bool match(OpTy *V)
const {
1380 if (
auto *
Op = dyn_cast<OverflowingBinaryOperator>(V)) {
1381 if (
Op->getOpcode() != Opcode)
1384 !
Op->hasNoUnsignedWrap())
1387 !
Op->hasNoSignedWrap())
1389 return (
L.match(
Op->getOperand(0)) &&
R.match(
Op->getOperand(1))) ||
1390 (Commutable &&
L.match(
Op->getOperand(1)) &&
1391 R.match(
Op->getOperand(0)));
1397template <
typename LHS,
typename RHS>
1405template <
typename LHS,
typename RHS>
1413template <
typename LHS,
typename RHS>
1421template <
typename LHS,
typename RHS>
1429template <
typename LHS,
typename RHS>
1438template <
typename LHS,
typename RHS>
1447template <
typename LHS,
typename RHS>
1456template <
typename LHS,
typename RHS>
1464template <
typename LHS,
typename RHS>
1472template <
typename LHS,
typename RHS>
1481template <
typename LHS_t,
typename RHS_t,
bool Commutable = false>
1489 template <
typename OpTy>
bool match(OpTy *V)
const {
1495template <
typename LHS,
typename RHS>
1501template <
typename LHS,
typename RHS,
bool Commutable = false>
1508 template <
typename OpTy>
bool match(OpTy *V)
const {
1509 if (
auto *PDI = dyn_cast<PossiblyDisjointInst>(V)) {
1510 assert(PDI->getOpcode() == Instruction::Or &&
"Only or can be disjoint");
1511 if (!PDI->isDisjoint())
1513 return (
L.match(PDI->getOperand(0)) &&
R.match(PDI->getOperand(1))) ||
1514 (Commutable &&
L.match(PDI->getOperand(1)) &&
1515 R.match(PDI->getOperand(0)));
1521template <
typename LHS,
typename RHS>
1526template <
typename LHS,
typename RHS>
1533template <
typename LHS,
typename RHS>
1541template <
typename LHS,
typename RHS>
1551template <
typename LHS,
typename RHS>
1560template <
typename LHS,
typename RHS>
1567 template <
typename OpTy>
bool match(OpTy *V)
const {
1568 if (
auto *
Op = dyn_cast<BinaryOperator>(V)) {
1569 if (
Op->getOpcode() == Instruction::Sub &&
Op->hasNoUnsignedWrap() &&
1572 else if (
Op->getOpcode() != Instruction::Xor)
1574 return (
L.match(
Op->getOperand(0)) &&
R.match(
Op->getOperand(1))) ||
1575 (
L.match(
Op->getOperand(1)) &&
R.match(
Op->getOperand(0)));
1583template <
typename LHS,
typename RHS>
1592 bool Commutable =
false>
1599 template <
typename OpTy>
bool match(OpTy *V)
const {
1600 if (
auto *
I = dyn_cast<Instruction>(V))
1601 return this->isOpType(
I->getOpcode()) &&
1602 ((
L.match(
I->getOperand(0)) &&
R.match(
I->getOperand(1))) ||
1603 (Commutable &&
L.match(
I->getOperand(1)) &&
1604 R.match(
I->getOperand(0))));
1615 return Opcode == Instruction::LShr || Opcode == Instruction::AShr;
1621 return Opcode == Instruction::LShr || Opcode == Instruction::Shl;
1633 return Opcode == Instruction::SDiv || Opcode == Instruction::UDiv;
1639 return Opcode == Instruction::SRem || Opcode == Instruction::URem;
1644template <
typename LHS,
typename RHS>
1651template <
typename LHS,
typename RHS>
1658template <
typename LHS,
typename RHS>
1665template <
typename LHS,
typename RHS>
1672template <
typename LHS,
typename RHS>
1679template <
typename LHS,
typename RHS>
1686template <
typename LHS,
typename RHS>
1700 template <
typename OpTy>
bool match(OpTy *V)
const {
1701 if (
auto *PEO = dyn_cast<PossiblyExactOperator>(V))
1702 return PEO->isExact() &&
SubPattern.match(V);
1715template <
typename LHS_t,
typename RHS_t,
typename Class,
1716 bool Commutable =
false>
1729 template <
typename OpTy>
bool match(OpTy *V)
const {
1730 if (
auto *
I = dyn_cast<Class>(V)) {
1731 if (
L.match(
I->getOperand(0)) &&
R.match(
I->getOperand(1))) {
1736 if (Commutable &&
L.match(
I->getOperand(1)) &&
1737 R.match(
I->getOperand(0))) {
1747template <
typename LHS,
typename RHS>
1753template <
typename LHS,
typename RHS>
1755 const LHS &L,
const RHS &R) {
1759template <
typename LHS,
typename RHS>
1761 const LHS &L,
const RHS &R) {
1765template <
typename LHS,
typename RHS>
1770template <
typename LHS,
typename RHS>
1775template <
typename LHS,
typename RHS>
1782template <
typename LHS_t,
typename RHS_t,
typename Class,
1783 bool Commutable =
false>
1792 template <
typename OpTy>
bool match(OpTy *V)
const {
1793 if (
auto *
I = dyn_cast<Class>(V)) {
1795 L.match(
I->getOperand(0)) &&
R.match(
I->getOperand(1)))
1797 if constexpr (Commutable) {
1800 L.match(
I->getOperand(1)) &&
R.match(
I->getOperand(0)))
1809template <
typename LHS,
typename RHS>
1815template <
typename LHS,
typename RHS>
1821template <
typename LHS,
typename RHS>
1827template <
typename LHS,
typename RHS>
1843 template <
typename OpTy>
bool match(OpTy *V)
const {
1844 if (V->getValueID() == Value::InstructionVal + Opcode) {
1845 auto *
I = cast<Instruction>(V);
1846 return Op1.match(
I->getOperand(0));
1859 template <
typename OpTy>
bool match(OpTy *V)
const {
1860 if (V->getValueID() == Value::InstructionVal + Opcode) {
1861 auto *
I = cast<Instruction>(V);
1862 return Op1.match(
I->getOperand(0)) &&
Op2.match(
I->getOperand(1));
1869template <
typename T0,
typename T1,
typename T2,
unsigned Opcode,
1870 bool CommutableOp2Op3 =
false>
1879 template <
typename OpTy>
bool match(OpTy *V)
const {
1880 if (V->getValueID() == Value::InstructionVal + Opcode) {
1881 auto *
I = cast<Instruction>(V);
1882 if (!
Op1.match(
I->getOperand(0)))
1884 if (
Op2.match(
I->getOperand(1)) &&
Op3.match(
I->getOperand(2)))
1886 return CommutableOp2Op3 &&
Op2.match(
I->getOperand(2)) &&
1887 Op3.match(
I->getOperand(1));
1903 template <
int Idx,
int Last>
1904 std::enable_if_t<Idx != Last, bool>
1906 return match_operands<Idx, Idx>(
I) && match_operands<Idx + 1, Last>(
I);
1909 template <
int Idx,
int Last>
1910 std::enable_if_t<Idx == Last, bool>
1912 return std::get<Idx>(
Operands).match(
I->getOperand(
Idx));
1915 template <
typename OpTy>
bool match(OpTy *V)
const {
1916 if (V->getValueID() == Value::InstructionVal + Opcode) {
1917 auto *
I = cast<Instruction>(V);
1918 return I->getNumOperands() ==
sizeof...(OperandTypes) &&
1926template <
typename Cond,
typename LHS,
typename RHS>
1934template <
int64_t L,
int64_t R,
typename Cond>
1936 Instruction::Select>
1938 return m_Select(
C, m_ConstantInt<L>(), m_ConstantInt<R>());
1942template <
typename LHS,
typename RHS>
1950template <
typename OpTy>
1956template <
typename Val_t,
typename Elt_t,
typename Idx_t>
1964template <
typename Val_t,
typename Idx_t>
1979 template <
typename OpTy>
bool match(OpTy *V)
const {
1980 if (
auto *
I = dyn_cast<ShuffleVectorInst>(V)) {
1981 return Op1.match(
I->getOperand(0)) &&
Op2.match(
I->getOperand(1)) &&
1982 Mask.match(
I->getShuffleMask());
1999 return all_of(Mask, [](
int Elem) {
return Elem == 0 || Elem == -1; });
2013 const auto *
First =
find_if(Mask, [](
int Elem) {
return Elem != -1; });
2014 if (
First == Mask.end())
2018 [
First](
int Elem) {
return Elem == *
First || Elem == -1; });
2029 template <
typename OpTy>
bool match(OpTy *V)
const {
2030 auto *
GEP = dyn_cast<GEPOperator>(V);
2031 return GEP &&
GEP->getSourceElementType()->isIntegerTy(8) &&
2038template <
typename V1_t,
typename V2_t>
2044template <
typename V1_t,
typename V2_t,
typename Mask_t>
2046m_Shuffle(
const V1_t &v1,
const V2_t &v2,
const Mask_t &mask) {
2051template <
typename OpTy>
2057template <
typename ValueOpTy,
typename Po
interOpTy>
2059m_Store(
const ValueOpTy &ValueOp,
const PointerOpTy &PointerOp) {
2065template <
typename... OperandTypes>
2066inline auto m_GEP(
const OperandTypes &...Ops) {
2067 return AnyOps_match<Instruction::GetElementPtr, OperandTypes...>(Ops...);
2071template <
typename Po
interOpTy,
typename OffsetOpTy>
2086 template <
typename OpTy>
bool match(OpTy *V)
const {
2087 if (
auto *O = dyn_cast<Operator>(V))
2088 return O->getOpcode() == Opcode &&
Op.match(O->getOperand(0));
2098 template <
typename OpTy>
bool match(OpTy *V)
const {
2099 if (
auto *
I = dyn_cast<Class>(V))
2100 return Op.match(
I->getOperand(0));
2112 template <
typename OpTy>
bool match(OpTy *V)
const {
2113 if (
auto *O = dyn_cast<Operator>(V))
2114 return O->getOpcode() == Instruction::PtrToInt &&
2117 Op.match(O->getOperand(0));
2127 template <
typename OpTy>
bool match(OpTy *V)
const {
2128 if (
auto *
I = dyn_cast<ZExtInst>(V))
2129 return I->hasNonNeg() &&
Op.match(
I->getOperand(0));
2139 template <
typename OpTy>
bool match(OpTy *V)
const {
2140 if (
auto *
I = dyn_cast<TruncInst>(V))
2141 return (
I->getNoWrapKind() & WrapFlags) == WrapFlags &&
2142 Op.match(
I->getOperand(0));
2148template <
typename OpTy>
2159 template <
typename OpTy>
bool match(OpTy *V)
const {
2160 auto *
I = dyn_cast<BitCastInst>(V);
2163 Type *SrcType =
I->getSrcTy();
2164 Type *DstType =
I->getType();
2169 if (
VectorType *SrcVecTy = dyn_cast<VectorType>(SrcType);
2171 cast<VectorType>(DstType)->getElementCount())
2173 return Op.match(
I->getOperand(0));
2177template <
typename OpTy>
2183template <
typename OpTy>
2189template <
typename OpTy>
2196template <
typename OpTy>
2203template <
typename OpTy>
2210template <
typename OpTy>
2216template <
typename OpTy>
2223template <
typename OpTy>
2229template <
typename OpTy>
2236template <
typename OpTy>
2242template <
typename OpTy>
2247template <
typename OpTy>
2252template <
typename OpTy>
2258template <
typename OpTy>
2265template <
typename OpTy>
2271template <
typename OpTy>
2278template <
typename OpTy>
2286template <
typename OpTy>
2291template <
typename OpTy>
2296template <
typename OpTy>
2301template <
typename OpTy>
2306template <
typename OpTy>
2311template <
typename OpTy>
2325 template <
typename OpTy>
bool match(OpTy *V)
const {
2326 if (
auto *BI = dyn_cast<BranchInst>(V))
2327 if (BI->isUnconditional()) {
2328 Succ = BI->getSuccessor(0);
2337template <
typename Cond_t,
typename TrueBlock_t,
typename FalseBlock_t>
2343 brc_match(
const Cond_t &
C,
const TrueBlock_t &t,
const FalseBlock_t &f)
2346 template <
typename OpTy>
bool match(OpTy *V)
const {
2347 if (
auto *BI = dyn_cast<BranchInst>(V))
2348 if (BI->isConditional() &&
Cond.match(BI->getCondition()))
2349 return T.match(BI->getSuccessor(0)) &&
F.match(BI->getSuccessor(1));
2354template <
typename Cond_t>
2361template <
typename Cond_t,
typename TrueBlock_t,
typename FalseBlock_t>
2363m_Br(
const Cond_t &
C,
const TrueBlock_t &
T,
const FalseBlock_t &
F) {
2371template <
typename CmpInst_t,
typename LHS_t,
typename RHS_t,
typename Pred_t,
2372 bool Commutable =
false>
2382 template <
typename OpTy>
bool match(OpTy *V)
const {
2383 if (
auto *
II = dyn_cast<IntrinsicInst>(V)) {
2390 return (
L.match(
LHS) &&
R.match(
RHS)) ||
2391 (Commutable &&
L.match(
RHS) &&
R.match(
LHS));
2395 auto *SI = dyn_cast<SelectInst>(V);
2398 auto *Cmp = dyn_cast<CmpInst_t>(SI->getCondition());
2403 auto *TrueVal = SI->getTrueValue();
2404 auto *FalseVal = SI->getFalseValue();
2405 auto *
LHS = Cmp->getOperand(0);
2406 auto *
RHS = Cmp->getOperand(1);
2407 if ((TrueVal !=
LHS || FalseVal !=
RHS) &&
2408 (TrueVal !=
RHS || FalseVal !=
LHS))
2410 typename CmpInst_t::Predicate Pred =
2411 LHS == TrueVal ? Cmp->getPredicate() : Cmp->getInversePredicate();
2413 if (!Pred_t::match(Pred))
2416 return (
L.match(
LHS) &&
R.match(
RHS)) ||
2417 (Commutable &&
L.match(
RHS) &&
R.match(
LHS));
2477template <
typename LHS,
typename RHS>
2483template <
typename LHS,
typename RHS>
2489template <
typename LHS,
typename RHS>
2495template <
typename LHS,
typename RHS>
2501template <
typename LHS,
typename RHS>
2521template <
typename LHS,
typename RHS>
2536template <
typename LHS,
typename RHS>
2551template <
typename LHS,
typename RHS>
2566template <
typename LHS,
typename RHS>
2577template <
typename LHS,
typename RHS>
2590template <
typename LHS,
typename RHS>
2601template <
typename ValTy>
2607template <
typename ValTy>
2619template <
typename LHS_t,
typename RHS_t,
typename Sum_t>
2628 template <
typename OpTy>
bool match(OpTy *V)
const {
2629 Value *ICmpLHS, *ICmpRHS;
2634 Value *AddLHS, *AddRHS;
2639 if (AddExpr.match(ICmpLHS) && (ICmpRHS == AddLHS || ICmpRHS == AddRHS))
2640 return L.match(AddLHS) &&
R.match(AddRHS) &&
S.match(ICmpLHS);
2644 if (AddExpr.match(ICmpRHS) && (ICmpLHS == AddLHS || ICmpLHS == AddRHS))
2645 return L.match(AddLHS) &&
R.match(AddRHS) &&
S.match(ICmpRHS);
2651 if (XorExpr.match(ICmpLHS))
2652 return L.match(Op1) &&
R.match(ICmpRHS) &&
S.match(ICmpLHS);
2656 if (XorExpr.match(ICmpRHS))
2657 return L.match(Op1) &&
R.match(ICmpLHS) &&
S.match(ICmpRHS);
2666 return L.match(AddLHS) &&
R.match(AddRHS) &&
S.match(ICmpLHS);
2671 return L.match(AddLHS) &&
R.match(AddRHS) &&
S.match(ICmpRHS);
2682template <
typename LHS_t,
typename RHS_t,
typename Sum_t>
2694 template <
typename OpTy>
bool match(OpTy *V)
const {
2696 if (
const auto *CI = dyn_cast<CallInst>(V))
2697 return Val.match(CI->getArgOperand(
OpI));
2703template <
unsigned OpI,
typename Opnd_t>
2714 template <
typename OpTy>
bool match(OpTy *V)
const {
2715 if (
const auto *CI = dyn_cast<CallInst>(V))
2716 if (
const auto *
F = dyn_cast_or_null<Function>(CI->getCalledOperand()))
2717 return F->getIntrinsicID() ==
ID;
2726template <
typename T0 = void,
typename T1 = void,
typename T2 = void,
2727 typename T3 = void,
typename T4 = void,
typename T5 = void,
2728 typename T6 = void,
typename T7 = void,
typename T8 = void,
2729 typename T9 = void,
typename T10 =
void>
2738template <
typename T0,
typename T1,
typename T2>
2743template <
typename T0,
typename T1,
typename T2,
typename T3>
2749template <
typename T0,
typename T1,
typename T2,
typename T3,
typename T4>
2755template <
typename T0,
typename T1,
typename T2,
typename T3,
typename T4,
2769template <
typename Opnd0,
typename Opnd1,
typename Opnd2,
typename Opnd3>
2773 return m_Intrinsic<Intrinsic::masked_load>(Op0, Op1, Op2, Op3);
2777template <
typename Opnd0,
typename Opnd1,
typename Opnd2,
typename Opnd3>
2781 return m_Intrinsic<Intrinsic::masked_gather>(Op0, Op1, Op2, Op3);
2784template <Intrinsic::ID IntrID,
typename T0>
2786 return m_CombineAnd(m_Intrinsic<IntrID>(), m_Argument<0>(Op0));
2789template <Intrinsic::ID IntrID,
typename T0,
typename T1>
2792 return m_CombineAnd(m_Intrinsic<IntrID>(Op0), m_Argument<1>(Op1));
2795template <Intrinsic::ID IntrID,
typename T0,
typename T1,
typename T2>
2798 return m_CombineAnd(m_Intrinsic<IntrID>(Op0, Op1), m_Argument<2>(Op2));
2805 return m_CombineAnd(m_Intrinsic<IntrID>(Op0, Op1, Op2), m_Argument<3>(Op3));
2809 typename T3,
typename T4>
2813 return m_CombineAnd(m_Intrinsic<IntrID>(Op0, Op1, Op2, Op3),
2814 m_Argument<4>(Op4));
2818 typename T3,
typename T4,
typename T5>
2821 const T4 &Op4,
const T5 &Op5) {
2822 return m_CombineAnd(m_Intrinsic<IntrID>(Op0, Op1, Op2, Op3, Op4),
2823 m_Argument<5>(Op5));
2827template <
typename Opnd0>
2829 return m_Intrinsic<Intrinsic::bitreverse>(Op0);
2832template <
typename Opnd0>
2834 return m_Intrinsic<Intrinsic::bswap>(Op0);
2837template <
typename Opnd0>
2839 return m_Intrinsic<Intrinsic::fabs>(Op0);
2842template <
typename Opnd0>
2844 return m_Intrinsic<Intrinsic::canonicalize>(Op0);
2847template <
typename Opnd0,
typename Opnd1>
2850 return m_Intrinsic<Intrinsic::minnum>(Op0, Op1);
2853template <
typename Opnd0,
typename Opnd1>
2856 return m_Intrinsic<Intrinsic::minimum>(Op0, Op1);
2859template <
typename Opnd0,
typename Opnd1>
2862 return m_Intrinsic<Intrinsic::minimumnum>(Op0, Op1);
2865template <
typename Opnd0,
typename Opnd1>
2868 return m_Intrinsic<Intrinsic::maxnum>(Op0, Op1);
2871template <
typename Opnd0,
typename Opnd1>
2874 return m_Intrinsic<Intrinsic::maximum>(Op0, Op1);
2877template <
typename Opnd0,
typename Opnd1>
2880 return m_Intrinsic<Intrinsic::maximumnum>(Op0, Op1);
2883template <
typename Opnd0,
typename Opnd1,
typename Opnd2>
2885m_FShl(
const Opnd0 &Op0,
const Opnd1 &Op1,
const Opnd2 &Op2) {
2886 return m_Intrinsic<Intrinsic::fshl>(Op0, Op1, Op2);
2889template <
typename Opnd0,
typename Opnd1,
typename Opnd2>
2891m_FShr(
const Opnd0 &Op0,
const Opnd1 &Op1,
const Opnd2 &Op2) {
2892 return m_Intrinsic<Intrinsic::fshr>(Op0, Op1, Op2);
2895template <
typename Opnd0>
2897 return m_Intrinsic<Intrinsic::sqrt>(Op0);
2900template <
typename Opnd0,
typename Opnd1>
2903 return m_Intrinsic<Intrinsic::copysign>(Op0, Op1);
2906template <
typename Opnd0>
2908 return m_Intrinsic<Intrinsic::vector_reverse>(Op0);
2916template <
typename LHS,
typename RHS>
2923template <
typename LHS,
typename RHS>
2929template <
typename LHS,
typename RHS>
2936template <
typename LHS,
typename RHS>
2943template <
typename LHS,
typename RHS>
2950template <
typename LHS,
typename RHS>
2957template <
typename LHS,
typename RHS>
2964template <
typename LHS,
typename RHS>
2971template <
typename LHS,
typename RHS>
2978template <
typename ValTy>
2985template <
typename ValTy>
2994template <
typename LHS,
typename RHS>
3000template <
typename LHS,
typename RHS>
3006template <
typename LHS,
typename RHS>
3012template <
typename LHS,
typename RHS>
3018template <
typename LHS,
typename RHS>
3029template <Intrinsic::ID IntrID,
typename T0,
typename T1>
3034 m_Intrinsic<IntrID>(Op1, Op0));
3038template <
typename LHS,
typename RHS>
3045template <
typename LHS,
typename RHS>
3055 template <
typename OpTy>
bool match(OpTy *V)
const {
3056 unsigned TypeSize = V->getType()->getScalarSizeInBits();
3060 unsigned ShiftWidth =
TypeSize - 1;
3077 return Signum.match(V) &&
Val.match(
Op);
3095 template <
typename OpTy>
bool match(OpTy *V)
const {
3096 if (
auto *
I = dyn_cast<ExtractValueInst>(V)) {
3099 !(
I->getNumIndices() == 1 &&
I->getIndices()[0] == (
unsigned)Ind))
3101 return Val.match(
I->getAggregateOperand());
3109template <
int Ind,
typename Val_t>
3116template <
typename Val_t>
3128 template <
typename OpTy>
bool match(OpTy *V)
const {
3129 if (
auto *
I = dyn_cast<InsertValueInst>(V)) {
3130 return Op0.match(
I->getOperand(0)) &&
Op1.match(
I->getOperand(1)) &&
3131 I->getNumIndices() == 1 && Ind ==
I->getIndices()[0];
3138template <
int Ind,
typename Val_t,
typename Elt_t>
3147template <
typename Opnd0,
typename Opnd1>
3150 return m_Intrinsic<Intrinsic::vector_interleave2>(Op0, Op1);
3153template <
typename Opnd>
3155 return m_Intrinsic<Intrinsic::vector_deinterleave2>(
Op);
3158template <
typename LHS,
typename RHS,
unsigned Opcode,
bool Commutable = false>
3165 template <
typename T>
bool match(
T *V)
const {
3166 auto *
I = dyn_cast<Instruction>(V);
3167 if (!
I || !
I->getType()->isIntOrIntVectorTy(1))
3170 if (
I->getOpcode() == Opcode) {
3171 auto *Op0 =
I->getOperand(0);
3172 auto *Op1 =
I->getOperand(1);
3173 return (
L.match(Op0) &&
R.match(Op1)) ||
3174 (Commutable &&
L.match(Op1) &&
R.match(Op0));
3177 if (
auto *
Select = dyn_cast<SelectInst>(
I)) {
3179 auto *TVal =
Select->getTrueValue();
3180 auto *FVal =
Select->getFalseValue();
3187 if (Opcode == Instruction::And) {
3188 auto *
C = dyn_cast<Constant>(FVal);
3189 if (
C &&
C->isNullValue())
3190 return (
L.match(
Cond) &&
R.match(TVal)) ||
3191 (Commutable &&
L.match(TVal) &&
R.match(
Cond));
3193 assert(Opcode == Instruction::Or);
3194 auto *
C = dyn_cast<Constant>(TVal);
3195 if (
C &&
C->isOneValue())
3196 return (
L.match(
Cond) &&
R.match(FVal)) ||
3197 (Commutable &&
L.match(FVal) &&
R.match(
Cond));
3207template <
typename LHS,
typename RHS>
3217template <
typename LHS,
typename RHS>
3225template <
typename LHS,
typename RHS>
3235template <
typename LHS,
typename RHS>
3244template <
typename LHS,
typename RHS,
bool Commutable = false>
3255template <
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
This file contains the declarations for the subclasses of Constant, which represent the different fla...
Returns the sub type a function will return at a given Idx Should correspond to the result type of an ExtractValue instruction executed with just that one unsigned Idx
static GCMetadataPrinterRegistry::Add< ErlangGCPrinter > X("erlang", "erlang-compatible garbage collector")
std::pair< Instruction::BinaryOps, Value * > OffsetOp
Find all possible pairs (BinOp, RHS) that BinOp V, RHS can be simplified.
MachineInstr unsigned OpIdx
uint64_t IntrinsicInst * II
const SmallVectorImpl< MachineOperand > & Cond
Class for arbitrary precision integers.
uint64_t getZExtValue() const
Get zero extended value.
unsigned getActiveBits() const
Compute the number of active bits in the value.
static bool isSameValue(const APInt &I1, const APInt &I2)
Determine if two APInts have the same value, after zero-extending one of them (if needed!...
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.
This class represents an Operation in the Expression.
A parsed version of the target data layout string in and methods for querying it.
TypeSize getTypeSizeInBits(Type *Ty) const
Size examples:
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.
std::pair< iterator, bool > insert(PtrType Ptr)
Inserts Ptr if and only if there is no element in the container equal to Ptr.
SmallPtrSet - This class implements a set which is optimized for holding SmallSize or less elements.
reference emplace_back(ArgTypes &&... Args)
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
The instances of the Type class are immutable: once they are created, they are never changed.
bool isVectorTy() const
True if this is an instance of VectorType.
'undef' values are things that do not have specified contents.
LLVM Value Representation.
Base class of all SIMD vector types.
ElementCount getElementCount() const
Return an ElementCount instance to represent the (possibly scalable) number of elements in the vector...
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.
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.
class_match< PoisonValue > m_Poison()
Match an arbitrary poison constant.
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.
apfloat_match m_APFloatForbidPoison(const APFloat *&Res)
Match APFloat while forbidding poison in splat vector constants.
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).
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)
class_match< BinaryOperator > m_BinOp()
Match an arbitrary binary operation and ignore it.
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)
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)
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.
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.
class_match< Constant > m_Constant()
Match an arbitrary Constant and ignore it.
AllowReassoc_match< T > m_AllowReassoc(const T &SubPattern)
OneOps_match< OpTy, Instruction::Freeze > m_Freeze(const OpTy &Op)
Matches FreezeInst.
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.
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)
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.
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.
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)
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.
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'.
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.
class_match< ConstantInt > m_ConstantInt()
Match an arbitrary ConstantInt and ignore it.
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.
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.
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.
match_combine_and< LTy, RTy > m_CombineAnd(const LTy &L, const RTy &R)
Combine two pattern matchers matching L && R.
MaxMin_match< ICmpInst, LHS, RHS, smin_pred_ty > m_SMin(const LHS &L, const RHS &R)
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)
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)
match_combine_or< typename m_Intrinsic_Ty< T0, T1 >::Ty, typename m_Intrinsic_Ty< T1, T0 >::Ty > m_c_Intrinsic(const T0 &Op0, const T1 &Op1)
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()...
cst_pred_ty< is_zero_int > m_ZeroInt()
Match an integer 0 or a vector with all elements equal to 0.
apint_match m_APIntAllowPoison(const APInt *&Res)
Match APInt while allowing poison in splat vector constants.
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'.
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.
cst_pred_ty< is_strictlypositive > m_StrictlyPositive()
Match an integer or vector of strictly positive values.
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)
class_match< ConstantFP > m_ConstantFP()
Match an arbitrary ConstantFP and ignore it.
cstfp_pred_ty< is_nonnan > m_NonNaN()
Match a non-NaN FP constant.
m_Intrinsic_Ty< Opnd0, Opnd1, Opnd2, Opnd3 >::Ty m_MaskedLoad(const Opnd0 &Op0, const Opnd1 &Op1, const Opnd2 &Op2, const Opnd3 &Op3)
Matches MaskedLoad Intrinsic.
SpecificCmpClass_match< LHS, RHS, ICmpInst > m_SpecificICmp(CmpPredicate MatchPred, const LHS &L, const RHS &R)
OneOps_match< OpTy, Instruction::Load > m_Load(const OpTy &Op)
Matches LoadInst.
apint_match m_APIntForbidPoison(const APInt *&Res)
Match APInt while forbidding poison in splat vector constants.
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)
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.
class_match< UndefValue > m_UndefValue()
Match an arbitrary UndefValue constant.
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)
class_match< CmpInst > m_Cmp()
Matches any compare instruction and ignore it.
brc_match< Cond_t, bind_ty< BasicBlock >, bind_ty< BasicBlock > > m_Br(const Cond_t &C, BasicBlock *&T, BasicBlock *&F)
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_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.
cst_pred_ty< is_lowbit_mask_or_zero > m_LowBitMaskOrZero()
Match an integer or vector with only the low bit(s) set.
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)
apfloat_match m_APFloatAllowPoison(const APFloat *&Res)
Match APFloat while allowing poison in splat vector constants.
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".
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)
match_combine_or< match_combine_or< MaxMin_match< ICmpInst, LHS, RHS, smax_pred_ty, true >, MaxMin_match< ICmpInst, LHS, RHS, smin_pred_ty, true > >, match_combine_or< MaxMin_match< ICmpInst, LHS, RHS, umax_pred_ty, true >, MaxMin_match< ICmpInst, LHS, RHS, umin_pred_ty, true > > > m_c_MaxOrMin(const LHS &L, const RHS &R)
MaxMin_match< FCmpInst, LHS, RHS, ufmax_pred_ty > m_UnordFMax(const LHS &L, const RHS &R)
Match an 'unordered' floating point maximum function.
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.
class_match< UnaryOperator > m_UnOp()
Match an arbitrary unary operation and ignore it.
CastInst_match< OpTy, FPToSIInst > m_FPToSI(const OpTy &Op)
BinaryOp_match< LHS, RHS, Instruction::SDiv > m_SDiv(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)
apint_match m_APInt(const APInt *&Res)
Match a ConstantInt or splatted ConstantVector, binding the specified pointer to the contained APInt.
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".
class_match< Value > m_Value()
Match an arbitrary value and ignore it.
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.
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.
apfloat_match m_APFloat(const APFloat *&Res)
Match a ConstantFP or splatted ConstantVector, binding the specified pointer to the contained APFloat...
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.
match_combine_or< match_combine_or< MaxMin_match< ICmpInst, LHS, RHS, smax_pred_ty >, MaxMin_match< ICmpInst, LHS, RHS, smin_pred_ty > >, match_combine_or< MaxMin_match< ICmpInst, LHS, RHS, umax_pred_ty >, MaxMin_match< ICmpInst, LHS, RHS, umin_pred_ty > > > m_MaxOrMin(const LHS &L, const RHS &R)
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)
CastInst_match< OpTy, FPTruncInst > m_FPTrunc(const OpTy &Op)
class_match< BasicBlock > m_BasicBlock()
Match an arbitrary basic block value and ignore it.
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.
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'.
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.
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)
m_Intrinsic_Ty< Opnd0, Opnd1, Opnd2, Opnd3 >::Ty m_MaskedGather(const Opnd0 &Op0, const Opnd1 &Op1, const Opnd2 &Op2, const Opnd3 &Op3)
Matches MaskedGather Intrinsic.
match_unless< Ty > m_Unless(const Ty &M)
Match if the inner matcher does NOT match.
match_combine_or< LTy, RTy > m_CombineOr(const LTy &L, const RTy &R)
Combine two pattern matchers matching L || R.
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.
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.
@ First
Helpers to iterate all locations in the MemoryEffectsBase class.
DWARFExpression::Operation Op
auto find_if(R &&Range, UnaryPredicate P)
Provide wrappers to std::find_if which take ranges instead of having to pass begin/end explicitly.
AllowReassoc_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)
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
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
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
This helper class is used to match scalar and vector constants that satisfy a specified predicate,...
apf_pred_ty(const APFloat *&R)
apfloat_match(const APFloat *&Res, bool AllowPoison)
This helper class is used to match scalar and vector constants that satisfy a specified predicate,...
api_pred_ty(const APInt *&R)
apint_match(const APInt *&Res, bool AllowPoison)
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 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 APInt &C) const
bool isValue(const APInt &C) const
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_combine_and(const LTy &Left, const RTy &Right)
match_combine_or(const LTy &Left, const RTy &Right)
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)