15#ifndef LLVM_TRANSFORM_VECTORIZE_VPLANPATTERNMATCH_H 
   16#define LLVM_TRANSFORM_VECTORIZE_VPLANPATTERNMATCH_H 
   23template <
typename Val, 
typename Pattern> 
bool match(Val *V, 
const Pattern &
P) {
 
 
   40template <
typename Val = VPUser, 
typename Pattern>
 
   57  template <
typename ITy> 
bool match(ITy *V)
 const {
 
 
 
   99template <
typename Pred, 
unsigned BitW
idth = 0> 
struct int_pred_ty {
 
  111    assert(!V->getType()->isVectorTy() && 
"Unexpected vector live-in");
 
  118    return P.isValue(CI->getValue());
 
 
 
  133template <
unsigned Bitw
idth = 0>
 
  187    assert(!V->getType()->isVectorTy() && 
"Unexpected vector live-in");
 
  191    Res = &CI->getValue();
 
 
 
  204    const APInt *APConst;
 
 
 
  226  template <
typename ITy> 
bool match(ITy *V)
 const {
 
  227    return L.match(V) || 
R.match(V);
 
 
 
  237  template <
typename ITy> 
bool match(ITy *V)
 const {
 
  238    return L.match(V) && 
R.match(V);
 
 
 
  243template <
typename LTy, 
typename RTy>
 
  249template <
typename LTy, 
typename RTy>
 
  260template <
typename Ops_t, 
unsigned Opcode, 
bool Commutative,
 
  261          typename... RecipeTys>
 
  266    static_assert(std::tuple_size<Ops_t>::value == 
sizeof...(Ops) &&
 
  267                  "number of operands in constructor doesn't match Ops_t");
 
  268    static_assert((!Commutative || std::tuple_size<Ops_t>::value == 2) &&
 
  269                  "only binary ops can be commutative");
 
 
  273    auto *DefR = V->getDefiningRecipe();
 
  274    return DefR && 
match(DefR);
 
 
  282    if (std::tuple_size_v<Ops_t> == 0) {
 
  284      return VPI && VPI->getOpcode() == Opcode;
 
  287    if ((!matchRecipeAndOpcode<RecipeTys>(R) && ...))
 
  290    if (R->getNumOperands() != std::tuple_size<Ops_t>::value) {
 
  291      assert(Opcode == Instruction::PHI &&
 
  292             "non-variadic recipe with matched opcode does not have the " 
  293             "expected number of operands");
 
  297    auto IdxSeq = std::make_index_sequence<std::tuple_size<Ops_t>::value>();
 
  298    if (all_of_tuple_elements(IdxSeq, [R](
auto Op, 
unsigned Idx) {
 
  299          return Op.match(R->getOperand(Idx));
 
  303    return Commutative &&
 
  304           all_of_tuple_elements(IdxSeq, [R](
auto Op, 
unsigned Idx) {
 
  305             return Op.match(R->getOperand(R->getNumOperands() - Idx - 1));
 
 
  310  template <
typename RecipeTy>
 
  311  static bool matchRecipeAndOpcode(
const VPRecipeBase *R) {
 
  314    if constexpr (std::is_same_v<RecipeTy, VPScalarIVStepsRecipe> ||
 
  315                  std::is_same_v<RecipeTy, VPCanonicalIVPHIRecipe> ||
 
  316                  std::is_same_v<RecipeTy, VPDerivedIVRecipe> ||
 
  317                  std::is_same_v<RecipeTy, VPVectorEndPointerRecipe>)
 
  320      return DefR && DefR->getOpcode() == Opcode;
 
  325  template <
typename Fn, std::size_t... Is>
 
  326  bool all_of_tuple_elements(std::index_sequence<Is...>, Fn 
P)
 const {
 
  327    return (
P(std::get<Is>(
Ops), Is) && ...);
 
 
  331template <
unsigned Opcode, 
typename... OpTys>
 
  337template <
unsigned Opcode, 
typename... OpTys>
 
  342template <
unsigned Opcode, 
typename... OpTys>
 
  346template <
unsigned Opcode, 
typename... OpTys>
 
  358template <
typename Op0_t>
 
  368template <
typename Op0_t>
 
  374template <
typename Op0_t>
 
  380template <
typename Op0_t>
 
  386template <
typename Op0_t>
 
  392template <
typename Op0_t, 
typename Op1_t>
 
  398template <
typename Op0_t>
 
  404template <
typename Op0_t, 
typename Op1_t, 
typename Op2_t>
 
  414template <
typename Op0_t, 
typename Op1_t>
 
  420template <
typename Op0_t>
 
  426template <
typename Op0_t>
 
  432template <
unsigned Opcode, 
typename Op0_t>
 
  437template <
typename Op0_t>
 
  442template <
typename Op0_t>
 
  447template <
typename Op0_t>
 
  452template <
typename Op0_t>
 
  459template <
typename Op0_t>
 
  465template <
unsigned Opcode, 
typename Op0_t, 
typename Op1_t>
 
  471template <
unsigned Opcode, 
typename Op0_t, 
typename Op1_t>
 
  477template <
typename Op0_t, 
typename Op1_t>
 
  483template <
typename Op0_t, 
typename Op1_t>
 
  489template <
typename Op0_t, 
typename Op1_t>
 
  495template <
typename Op0_t, 
typename Op1_t>
 
  502template <
typename Op0_t, 
typename Op1_t>
 
  512template <
typename Op0_t, 
typename Op1_t>
 
  518template <
typename Op0_t, 
typename Op1_t>
 
  527template <
typename Op0_t, 
typename Op1_t, 
unsigned... Opcodes>
 
  529  static_assert((
sizeof...(Opcodes) == 1 || 
sizeof...(Opcodes) == 2) &&
 
  530                "Expected one or two opcodes");
 
  532      ((Opcodes == Instruction::ICmp || Opcodes == Instruction::FCmp) && ...) &&
 
  533      "Expected a compare instruction opcode");
 
  544    auto *DefR = V->getDefiningRecipe();
 
  545    return DefR && 
match(DefR);
 
 
 
  560template <
typename Op0_t, 
typename Op1_t, 
unsigned... Opcodes>
 
  577template <
typename Op0_t, 
typename Op1_t>
 
  583template <
typename Op0_t, 
typename Op1_t>
 
  584inline Cmp_match<Op0_t, Op1_t, Instruction::ICmp>
 
  589template <
typename Op0_t, 
typename Op1_t>
 
  590inline SpecificCmp_match<Op0_t, Op1_t, Instruction::ICmp>
 
  596template <
typename Op0_t, 
typename Op1_t>
 
  597inline Cmp_match<Op0_t, Op1_t, Instruction::ICmp, Instruction::FCmp>
 
  603template <
typename Op0_t, 
typename Op1_t>
 
  604inline Cmp_match<Op0_t, Op1_t, Instruction::ICmp, Instruction::FCmp>
 
  610template <
typename Op0_t, 
typename Op1_t>
 
  611inline SpecificCmp_match<Op0_t, Op1_t, Instruction::ICmp, Instruction::FCmp>
 
  614      MatchPred, Op0, Op1);
 
 
  617template <
typename Op0_t, 
typename Op1_t>
 
  625template <
typename Op0_t, 
typename Op1_t>
 
  629      Recipe_match<std::tuple<Op0_t, Op1_t>, Instruction::GetElementPtr,
 
 
  638template <
typename Op0_t, 
typename Op1_t, 
typename Op2_t>
 
  645template <
typename Op0_t>
 
  648                            Instruction::Xor, int_pred_ty<is_all_ones>, Op0_t>>
 
  654template <
typename Op0_t, 
typename Op1_t>
 
  664template <
typename Op0_t, 
typename Op1_t>
 
  670template <
typename Op0_t, 
typename Op1_t, 
typename Op2_t>
 
  674template <
typename Op0_t, 
typename Op1_t, 
typename Op2_t>
 
  680template <
typename Op0_t, 
typename Op1_t, 
typename Op2_t>
 
  684template <
typename Op0_t, 
typename Op1_t, 
typename Op2_t>
 
  690template <
typename Addr_t, 
typename Mask_t> 
struct Load_match {
 
  696  template <
typename OpTy> 
bool match(
const OpTy *V)
 const {
 
  698    if (!Load || !
Addr.match(Load->getAddr()) || !Load->isMasked() ||
 
  699        !
Mask.match(Load->getMask()))
 
 
 
  706template <
typename Addr_t, 
typename Mask_t>
 
  708                                               const Mask_t &Mask) {
 
 
  712template <
typename Addr_t, 
typename Val_t, 
typename Mask_t> 
struct Store_match {
 
  720  template <
typename OpTy> 
bool match(
const OpTy *V)
 const {
 
  722    if (!Store || !
Addr.match(Store->getAddr()) ||
 
  723        !
Val.match(Store->getStoredValue()) || !Store->isMasked() ||
 
  724        !
Mask.match(Store->getMask()))
 
 
 
  731template <
typename Addr_t, 
typename Val_t, 
typename Mask_t>
 
  732inline Store_match<Addr_t, Val_t, Mask_t>
 
  737template <
typename Op0_t, 
typename Op1_t>
 
  742template <
typename Op0_t, 
typename Op1_t>
 
  756  template <
typename OpTy> 
bool match(OpTy *V)
 const {
 
  758      return Val.match(R->getOperand(
OpI));
 
  760      return Val.match(R->getOperand(
OpI));
 
  763        return Val.match(R->getOperand(
OpI + 1));
 
 
 
  769template <
unsigned OpI, 
typename Opnd_t>
 
  780  template <
typename OpTy> 
bool match(OpTy *V)
 const {
 
  782      return R->getVectorIntrinsicID() == 
ID;
 
  784      return R->getCalledScalarFunction()->getIntrinsicID() == 
ID;
 
  787        if (
const auto *
F = CI->getCalledFunction())
 
  788          return F->getIntrinsicID() == 
ID;
 
 
 
  797template <
typename T0 = void, 
typename T1 = void, 
typename T2 = void,
 
  807template <
typename T0, 
typename T1, 
typename T2>
 
  812template <
typename T0, 
typename T1, 
typename T2, 
typename T3>
 
  824template <Intrinsic::ID IntrID, 
typename T0>
 
  829template <Intrinsic::ID IntrID, 
typename T0, 
typename T1>
 
  835template <Intrinsic::ID IntrID, 
typename T0, 
typename T1, 
typename T2>
 
  849  template <
typename ITy> 
bool match(ITy *V)
 const {
 
 
 
  862  template <
typename OpTy> 
bool match(OpTy *V) {
 
 
 
 
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
 
const AbstractManglingParser< Derived, Alloc >::OperatorInfo AbstractManglingParser< Derived, Alloc >::Ops[]
 
MachineInstr unsigned OpIdx
 
This file contains the declarations of the Vectorization Plan base classes:
 
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)
Determine if two APInts have the same value, after zero-extending one of them (if needed!...
 
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...
 
A recipe for converting the input value IV value to the corresponding value of an IV with different s...
 
This is a concrete Recipe that models a single VPlan-level instruction.
 
VPRecipeBase is a base class modeling a sequence of one or more output IR instructions.
 
VPReplicateRecipe replicates a given instruction producing multiple scalar copies of the original sca...
 
A recipe for handling phi nodes of integer and floating-point inductions, producing their scalar valu...
 
VPSingleDef is a base class for recipes for modeling a sequence of one or more output IR that define ...
 
This class augments VPValue with operands which provide the inverse def-use edges from VPValue's user...
 
This is the base class of the VPlan Def/Use graph, used for modeling the data flow into,...
 
Value * getLiveInIRValue() const
Returns the underlying IR value, if this VPValue is defined outside the scope of VPlan.
 
bool isLiveIn() const
Returns true if this VPValue is a live-in, i.e. defined outside the VPlan.
 
A recipe to compute a pointer to the last element of each part of a widened memory access for widened...
 
VPWidenCastRecipe is a recipe to create vector cast instructions.
 
A recipe for handling GEP instructions.
 
VPWidenRecipe is a recipe for producing a widened instruction using the opcode and operands of the re...
 
LLVM Value Representation.
 
@ C
The default llvm calling convention, compatible with C.
 
class_match< ConstantInt > m_ConstantInt()
Match an arbitrary ConstantInt and ignore it.
 
auto m_LogicalOr()
Matches L || R where L and R are arbitrary values.
 
class_match< CmpInst > m_Cmp()
Matches any compare instruction and ignore it.
 
auto m_LogicalAnd()
Matches L && R where L and R are arbitrary values.
 
AllRecipe_match< Instruction::Select, Op0_t, Op1_t, Op2_t > m_Select(const Op0_t &Op0, const Op1_t &Op1, const Op2_t &Op2)
 
VPInstruction_match< Instruction::Freeze, Op0_t > m_Freeze(const Op0_t &Op0)
 
AllRecipe_commutative_match< Instruction::And, Op0_t, Op1_t > m_c_BinaryAnd(const Op0_t &Op0, const Op1_t &Op1)
Match a binary AND operation.
 
AllRecipe_match< Instruction::ZExt, Op0_t > m_ZExt(const Op0_t &Op0)
 
AllRecipe_match< Instruction::Or, Op0_t, Op1_t > m_BinaryOr(const Op0_t &Op0, const Op1_t &Op1)
Match a binary OR operation.
 
int_pred_ty< is_specific_int, Bitwidth > specific_intval
 
Store_match< Addr_t, Val_t, Mask_t > m_MaskedStore(const Addr_t &Addr, const Val_t &Val, const Mask_t &Mask)
Match a (possibly reversed) masked store.
 
int_pred_ty< is_zero_int > m_ZeroInt()
Match an integer 0 or a vector with all elements equal to 0.
 
SpecificCmp_match< Op0_t, Op1_t, Instruction::ICmp, Instruction::FCmp > m_SpecificCmp(CmpPredicate MatchPred, const Op0_t &Op0, const Op1_t &Op1)
 
match_combine_or< VPInstruction_match< VPInstruction::Not, Op0_t >, AllRecipe_commutative_match< Instruction::Xor, int_pred_ty< is_all_ones >, Op0_t > > m_Not(const Op0_t &Op0)
 
int_pred_ty< is_all_ones > m_AllOnes()
Match an integer or vector with all bits set.
 
AllRecipe_commutative_match< Opcode, Op0_t, Op1_t > m_c_Binary(const Op0_t &Op0, const Op1_t &Op1)
 
AllRecipe_commutative_match< Instruction::Add, Op0_t, Op1_t > m_c_Add(const Op0_t &Op0, const Op1_t &Op1)
 
AllRecipe_commutative_match< Instruction::Or, Op0_t, Op1_t > m_c_BinaryOr(const Op0_t &Op0, const Op1_t &Op1)
 
match_combine_or< AllRecipe_match< Instruction::ZExt, Op0_t >, AllRecipe_match< Instruction::SExt, Op0_t > > m_ZExtOrSExt(const Op0_t &Op0)
 
match_combine_and< LTy, RTy > m_CombineAnd(const LTy &L, const RTy &R)
Combine two pattern matchers matching L && R.
 
SpecificCmp_match< Op0_t, Op1_t, Instruction::ICmp > m_SpecificICmp(CmpPredicate MatchPred, const Op0_t &Op0, const Op1_t &Op1)
 
VPInstruction_match< VPInstruction::AnyOf, Op0_t > m_AnyOf(const Op0_t &Op0)
 
VPScalarIVSteps_match< Op0_t, Op1_t, Op2_t > m_ScalarIVSteps(const Op0_t &Op0, const Op1_t &Op1, const Op2_t &Op2)
 
match_combine_or< LTy, RTy > m_CombineOr(const LTy &L, const RTy &R)
Combine two pattern matchers matching L || R.
 
GEPLikeRecipe_match< Op0_t, Op1_t > m_GetElementPtr(const Op0_t &Op0, const Op1_t &Op1)
 
Recipe_match< std::tuple< OpTys... >, Opcode, false, VPInstruction > VPInstruction_match
 
VPInstruction_match< VPInstruction::ExtractLastLanePerPart, Op0_t > m_ExtractLastLanePerPart(const Op0_t &Op0)
 
VPInstruction_match< VPInstruction::ExtractLastElement, Op0_t > m_ExtractLastElement(const Op0_t &Op0)
 
AllRecipe_match< Opcode, Op0_t, Op1_t > m_Binary(const Op0_t &Op0, const Op1_t &Op1)
 
AllRecipe_match< Opcode, Op0_t > m_Unary(const Op0_t &Op0)
 
Load_match< Addr_t, Mask_t > m_MaskedLoad(const Addr_t &Addr, const Mask_t &Mask)
Match a (possibly reversed) masked load.
 
AllRecipe_commutative_match< Instruction::Mul, Op0_t, Op1_t > m_c_Mul(const Op0_t &Op0, const Op1_t &Op1)
 
Cmp_match< Op0_t, Op1_t, Instruction::ICmp > m_ICmp(const Op0_t &Op0, const Op1_t &Op1)
 
AllRecipe_match< Instruction::Mul, Op0_t, Op1_t > m_Mul(const Op0_t &Op0, const Op1_t &Op1)
 
specificval_ty m_Specific(const VPValue *VPV)
 
match_combine_or< Recipe_match< std::tuple< Op0_t, Op1_t >, Instruction::GetElementPtr, false, VPReplicateRecipe, VPWidenGEPRecipe >, match_combine_or< VPInstruction_match< VPInstruction::PtrAdd, Op0_t, Op1_t >, VPInstruction_match< VPInstruction::WidePtrAdd, Op0_t, Op1_t > > > GEPLikeRecipe_match
 
VPInstruction_match< Instruction::ExtractElement, Op0_t, Op1_t > m_ExtractElement(const Op0_t &Op0, const Op1_t &Op1)
 
specific_intval< 1 > m_False()
 
VPDerivedIV_match< Op0_t, Op1_t, Op2_t > m_DerivedIV(const Op0_t &Op0, const Op1_t &Op1, const Op2_t &Op2)
 
VPMatchFunctor< Val, Pattern > match_fn(const Pattern &P)
A match functor that can be used as a UnaryPredicate in functional algorithms like all_of.
 
specific_intval< 0 > m_SpecificInt(uint64_t V)
 
VPInstruction_match< VPInstruction::ActiveLaneMask, Op0_t, Op1_t, Op2_t > m_ActiveLaneMask(const Op0_t &Op0, const Op1_t &Op1, const Op2_t &Op2)
 
live_in_vpvalue m_LiveIn()
 
VPInstruction_match< VPInstruction::BranchOnCount > m_BranchOnCount()
 
Recipe_match< std::tuple< Op0_t, Op1_t, Op2_t >, 0, false, VPDerivedIVRecipe > VPDerivedIV_match
 
AllRecipe_match< Instruction::Sub, Op0_t, Op1_t > m_Sub(const Op0_t &Op0, const Op1_t &Op1)
 
AllRecipe_match< Instruction::SExt, Op0_t > m_SExt(const Op0_t &Op0)
 
specific_intval< 1 > m_True()
 
Recipe_match< std::tuple< OpTys... >, Opcode, false, VPWidenRecipe, VPReplicateRecipe, VPWidenCastRecipe, VPInstruction, VPWidenSelectRecipe > AllRecipe_match
 
IntrinsicID_match m_Intrinsic()
Match intrinsic calls like this: m_Intrinsic<Intrinsic::fabs>(m_VPValue(X), ...)
 
Recipe_match< std::tuple< OpTys... >, Opcode, true, VPWidenRecipe, VPReplicateRecipe, VPInstruction > AllRecipe_commutative_match
 
deferredval_ty m_Deferred(VPValue *const &V)
Like m_Specific(), but works if the specific value to match is determined as part of the same match()...
 
VectorEndPointerRecipe_match< Op0_t, Op1_t > m_VecEndPtr(const Op0_t &Op0, const Op1_t &Op1)
 
VPInstruction_match< VPInstruction::Broadcast, Op0_t > m_Broadcast(const Op0_t &Op0)
 
bool match(Val *V, const Pattern &P)
 
class_match< VPValue > m_VPValue()
Match an arbitrary VPValue and ignore it.
 
OneUse_match< T > m_OneUse(const T &SubPattern)
 
VPInstruction_match< VPInstruction::ExplicitVectorLength, Op0_t > m_EVL(const Op0_t &Op0)
 
VPInstruction_match< VPInstruction::BuildVector > m_BuildVector()
BuildVector is matches only its opcode, w/o matching its operands as the number of operands is not fi...
 
AllRecipe_match< Instruction::Trunc, Op0_t > m_Trunc(const Op0_t &Op0)
 
Recipe_match< std::tuple< Op0_t, Op1_t >, 0, false, VPVectorEndPointerRecipe > VectorEndPointerRecipe_match
 
match_combine_or< AllRecipe_match< Instruction::ZExt, Op0_t >, Op0_t > m_ZExtOrSelf(const Op0_t &Op0)
 
VPInstruction_match< VPInstruction::FirstActiveLane, Op0_t > m_FirstActiveLane(const Op0_t &Op0)
 
Argument_match< Opnd_t > m_Argument(const Opnd_t &Op)
Match a call argument.
 
bind_ty< VPInstruction > m_VPInstruction(VPInstruction *&V)
Match a VPInstruction, capturing if we match.
 
Recipe_match< std::tuple< Op0_t, Op1_t, Op2_t >, 0, false, VPScalarIVStepsRecipe > VPScalarIVSteps_match
 
int_pred_ty< is_one > m_One()
Match an integer 1 or a vector with all elements equal to 1.
 
VPInstruction_match< VPInstruction::BranchOnCond > m_BranchOnCond()
 
bind_apint m_APInt(const APInt *&C)
 
This is an optimization pass for GlobalISel generic memory operations.
 
decltype(auto) dyn_cast(const From &Val)
dyn_cast<X> - Return the argument parameter cast to the specified type.
 
bool isa(const From &Val)
isa<X> - Return true if the parameter to the template is an instance of one of the template type argu...
 
DWARFExpression::Operation Op
 
constexpr unsigned BitWidth
 
OutputIt move(R &&Range, OutputIt Out)
Provide wrappers to std::move which take ranges instead of having to pass begin/end explicitly.
 
decltype(auto) cast(const From &Val)
cast<X> - Return the argument parameter cast to the specified type.
 
Implement std::hash so that hash_code can be used in STL containers.
 
Intrinsic matches are combinations of ID matchers, and argument matchers.
 
A recipe for widening select instructions.
 
Match a call argument at a given argument index.
 
unsigned OpI
Call argument index to match.
 
Argument_match(unsigned OpIdx, const Opnd_t &V)
 
bool match(OpTy *V) const
 
Cmp_match is a variant of BinaryRecipe_match that also binds the comparison predicate.
 
Cmp_match(CmpPredicate &Pred, const Op0_t &Op0, const Op1_t &Op1)
 
Cmp_match(const Op0_t &Op0, const Op1_t &Op1)
 
bool match(const VPValue *V) const
 
bool match(const VPRecipeBase *V) const
 
IntrinsicID_match(Intrinsic::ID IntrID)
 
bool match(OpTy *V) const
 
Load_match(Addr_t Addr, Mask_t Mask)
 
bool match(const OpTy *V) const
 
OneUse_match(const SubPattern_t &SP)
 
bool match(const VPSingleDefRecipe *R) const
 
Recipe_match(OpTy... Ops)
 
std::tuple< OpTys... > Ops
 
bool match(const VPValue *V) const
 
bool match(const VPRecipeBase *R) const
 
SpecificCmp_match is a variant of Cmp_match that matches the comparison predicate,...
 
SpecificCmp_match(CmpPredicate Pred, const Op0_t &LHS, const Op1_t &RHS)
 
const CmpPredicate Predicate
 
bool match(const VPValue *V) const
 
Store_match(Addr_t Addr, Val_t Val, Mask_t Mask)
 
bool match(const OpTy *V) const
 
VPMatchFunctor(const Pattern &P)
 
bool operator()(Val *V) const
 
bool match(VPValue *VPV) const
 
bind_apint(const APInt *&Res)
 
bool match(VPValue *VPV) const
 
bind_const_int(uint64_t &Res)
 
Stores a reference to the VPValue *, not the VPValue * itself, thus can be used in commutative matche...
 
deferredval_ty(VPValue *const &V)
 
bool match(VPValue *const V) const
 
Match an integer constant or vector of constants if Pred::isValue returns true for the APInt.
 
bool match(VPValue *VPV) const
 
bool isValue(const APInt &C) const
 
bool isValue(const APInt &C) const
 
Match a specified integer value or vector of all elements of that value.
 
bool isValue(const APInt &C) const
 
is_specific_int(APInt Val)
 
bool isValue(const APInt &C) const
 
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.
 
match_combine_and< typename m_Intrinsic_Ty< T0, T1, T2 >::Ty, Argument_match< T3 > > Ty
 
match_combine_and(const LTy &Left, const RTy &Right)
 
llvm::VPlanPatternMatch::match_combine_or< Recipe_match< std::tuple< Op0_t, Op1_t >, Instruction::GetElementPtr, false, VPReplicateRecipe, VPWidenGEPRecipe >, match_combine_or< VPInstruction_match< VPInstruction::PtrAdd, Op0_t, Op1_t >, VPInstruction_match< VPInstruction::WidePtrAdd, Op0_t, Op1_t > > >::L Recipe_match< std::tuple< Op0_t, Op1_t >, Instruction::GetElementPtr, false, VPReplicateRecipe, VPWidenGEPRecipe > L
 
llvm::VPlanPatternMatch::match_combine_or< Recipe_match< std::tuple< Op0_t, Op1_t >, Instruction::GetElementPtr, false, VPReplicateRecipe, VPWidenGEPRecipe >, match_combine_or< VPInstruction_match< VPInstruction::PtrAdd, Op0_t, Op1_t >, VPInstruction_match< VPInstruction::WidePtrAdd, Op0_t, Op1_t > > >::R match_combine_or< VPInstruction_match< VPInstruction::PtrAdd, Op0_t, Op1_t >, VPInstruction_match< VPInstruction::WidePtrAdd, Op0_t, Op1_t > > R
 
match_combine_or(const LTy &Left, const RTy &Right)
 
Match a specified VPValue.
 
specificval_ty(const VPValue *V)
 
bool match(VPValue *VPV) const