LLVM
8.0.1
|
Classes | |
struct | AnyBinaryOp_match |
struct | apfloat_match |
struct | api_pred_ty |
This helper class is used to match scalar and vector constants that satisfy a specified predicate, and bind them to an APInt. More... | |
struct | apint_match |
struct | Argument_match |
struct | BinaryOp_match |
struct | bind_const_intval_ty |
struct | bind_ty |
struct | BinOpPred_match |
struct | br_match |
struct | brc_match |
struct | CastClass_match |
struct | class_match |
struct | CmpClass_match |
struct | constantint_match |
struct | cst_pred_ty |
This helper class is used to match scalar and vector integer constants that satisfy a specified predicate. More... | |
struct | cstfp_pred_ty |
This helper class is used to match scalar and vector floating-point constants that satisfy a specified predicate. More... | |
struct | deferredval_ty |
Stores a reference to the Value *, not the Value * itself, thus can be used in commutative matchers. More... | |
struct | Exact_match |
struct | FNeg_match |
struct | IntrinsicID_match |
Intrinsic matchers. More... | |
struct | is_all_ones |
struct | is_any_zero_fp |
struct | is_bitwiselogic_op |
struct | is_idiv_op |
struct | is_logical_shift_op |
struct | is_lowbit_mask |
struct | is_maxsignedvalue |
struct | is_nan |
struct | is_neg_zero_fp |
struct | is_negative |
struct | is_nonnegative |
struct | is_one |
struct | is_pos_zero_fp |
struct | is_power2 |
struct | is_power2_or_zero |
struct | is_right_shift_op |
struct | is_shift_op |
struct | is_sign_mask |
struct | is_zero |
struct | is_zero_int |
struct | m_Intrinsic_Ty |
Intrinsic matches are combinations of ID matchers, and argument matchers. More... | |
struct | m_Intrinsic_Ty< T0 > |
struct | m_Intrinsic_Ty< T0, T1 > |
struct | m_Intrinsic_Ty< T0, T1, T2 > |
struct | m_Intrinsic_Ty< T0, T1, T2, T3 > |
struct | match_combine_and |
struct | match_combine_or |
Matching combinators. More... | |
struct | MaxMin_match |
struct | ofmax_pred_ty |
Helper class for identifying ordered max predicates. More... | |
struct | ofmin_pred_ty |
Helper class for identifying ordered min predicates. More... | |
struct | OneOps_match |
Matches instructions with Opcode and three operands. More... | |
struct | OneUse_match |
struct | OverflowingBinaryOp_match |
struct | Signum_match |
struct | smax_pred_ty |
Helper class for identifying signed max predicates. More... | |
struct | smin_pred_ty |
Helper class for identifying signed min predicates. More... | |
struct | specific_fpval |
Match a specified floating point value or vector of all elements of that value. More... | |
struct | specific_intval |
Match a specified integer value or vector of all elements of that. More... | |
struct | specificval_ty |
Match a specified Value*. More... | |
struct | ThreeOps_match |
Matches instructions with Opcode and three operands. More... | |
struct | TwoOps_match |
Matches instructions with Opcode and three operands. More... | |
struct | UAddWithOverflow_match |
struct | ufmax_pred_ty |
Helper class for identifying unordered max predicates. More... | |
struct | ufmin_pred_ty |
Helper class for identifying unordered min predicates. More... | |
struct | umax_pred_ty |
Helper class for identifying unsigned max predicates. More... | |
struct | umin_pred_ty |
Helper class for identifying unsigned min predicates. More... | |
Functions | |
template<typename Val , typename Pattern > | |
bool | match (Val *V, const Pattern &P) |
template<typename T > | |
OneUse_match< T > | m_OneUse (const T &SubPattern) |
class_match< Value > | m_Value () |
Match an arbitrary value and ignore it. More... | |
class_match< BinaryOperator > | m_BinOp () |
Match an arbitrary binary operation and ignore it. More... | |
class_match< CmpInst > | m_Cmp () |
Matches any compare instruction and ignore it. More... | |
class_match< ConstantInt > | m_ConstantInt () |
Match an arbitrary ConstantInt and ignore it. More... | |
class_match< UndefValue > | m_Undef () |
Match an arbitrary undef constant. More... | |
class_match< Constant > | m_Constant () |
Match an arbitrary Constant and ignore it. More... | |
template<typename LTy , typename RTy > | |
match_combine_or< LTy, RTy > | m_CombineOr (const LTy &L, const RTy &R) |
Combine two pattern matchers matching L || R. More... | |
template<typename LTy , typename RTy > | |
match_combine_and< LTy, RTy > | m_CombineAnd (const LTy &L, const RTy &R) |
Combine two pattern matchers matching L && R. More... | |
apint_match | m_APInt (const APInt *&Res) |
Match a ConstantInt or splatted ConstantVector, binding the specified pointer to the contained APInt. More... | |
apfloat_match | m_APFloat (const APFloat *&Res) |
Match a ConstantFP or splatted ConstantVector, binding the specified pointer to the contained APFloat. More... | |
cst_pred_ty< is_all_ones > | m_AllOnes () |
Match an integer or vector with all bits set. More... | |
cst_pred_ty< is_maxsignedvalue > | m_MaxSignedValue () |
Match an integer or vector with values having all bits except for the high bit set (0x7f...). More... | |
api_pred_ty< is_maxsignedvalue > | m_MaxSignedValue (const APInt *&V) |
cst_pred_ty< is_negative > | m_Negative () |
Match an integer or vector of negative values. More... | |
api_pred_ty< is_negative > | m_Negative (const APInt *&V) |
cst_pred_ty< is_nonnegative > | m_NonNegative () |
Match an integer or vector of nonnegative values. More... | |
api_pred_ty< is_nonnegative > | m_NonNegative (const APInt *&V) |
cst_pred_ty< is_one > | m_One () |
Match an integer 1 or a vector with all elements equal to 1. More... | |
cst_pred_ty< is_zero_int > | m_ZeroInt () |
Match an integer 0 or a vector with all elements equal to 0. More... | |
is_zero | m_Zero () |
Match any null constant or a vector with all elements equal to 0. More... | |
cst_pred_ty< is_power2 > | m_Power2 () |
Match an integer or vector power-of-2. More... | |
api_pred_ty< is_power2 > | m_Power2 (const APInt *&V) |
cst_pred_ty< is_power2_or_zero > | m_Power2OrZero () |
Match an integer or vector of 0 or power-of-2 values. More... | |
api_pred_ty< is_power2_or_zero > | m_Power2OrZero (const APInt *&V) |
cst_pred_ty< is_sign_mask > | m_SignMask () |
Match an integer or vector with only the sign bit(s) set. More... | |
cst_pred_ty< is_lowbit_mask > | m_LowBitMask () |
Match an integer or vector with only the low bit(s) set. More... | |
cstfp_pred_ty< is_nan > | m_NaN () |
Match an arbitrary NaN constant. More... | |
cstfp_pred_ty< is_any_zero_fp > | m_AnyZeroFP () |
Match a floating-point negative zero or positive zero. More... | |
cstfp_pred_ty< is_pos_zero_fp > | m_PosZeroFP () |
Match a floating-point positive zero. More... | |
cstfp_pred_ty< is_neg_zero_fp > | m_NegZeroFP () |
Match a floating-point negative zero. More... | |
bind_ty< Value > | m_Value (Value *&V) |
Match a value, capturing it if we match. More... | |
bind_ty< const Value > | m_Value (const Value *&V) |
bind_ty< Instruction > | m_Instruction (Instruction *&I) |
Match an instruction, capturing it if we match. More... | |
bind_ty< BinaryOperator > | m_BinOp (BinaryOperator *&I) |
Match a binary operator, capturing it if we match. More... | |
bind_ty< ConstantInt > | m_ConstantInt (ConstantInt *&CI) |
Match a ConstantInt, capturing the value if we match. More... | |
bind_ty< Constant > | m_Constant (Constant *&C) |
Match a Constant, capturing the value if we match. More... | |
bind_ty< ConstantFP > | m_ConstantFP (ConstantFP *&C) |
Match a ConstantFP, capturing the value if we match. More... | |
specificval_ty | m_Specific (const Value *V) |
Match if we have a specific specified value. More... | |
deferredval_ty< Value > | m_Deferred (Value *const &V) |
A commutative-friendly version of m_Specific(). More... | |
deferredval_ty< const Value > | m_Deferred (const Value *const &V) |
specific_fpval | m_SpecificFP (double V) |
Match a specific floating point value or vector with all elements equal to the value. More... | |
specific_fpval | m_FPOne () |
Match a float 1.0 or vector with all elements equal to 1.0. More... | |
specific_intval | m_SpecificInt (uint64_t V) |
Match a specific integer value or vector with all elements equal to the value. More... | |
bind_const_intval_ty | m_ConstantInt (uint64_t &V) |
Match a ConstantInt and bind to its value. More... | |
template<typename LHS , typename RHS > | |
AnyBinaryOp_match< LHS, RHS > | m_BinOp (const LHS &L, const RHS &R) |
template<typename LHS , typename RHS > | |
BinaryOp_match< LHS, RHS, Instruction::Add > | m_Add (const LHS &L, const RHS &R) |
template<typename LHS , typename RHS > | |
BinaryOp_match< LHS, RHS, Instruction::FAdd > | m_FAdd (const LHS &L, const RHS &R) |
template<typename LHS , typename RHS > | |
BinaryOp_match< LHS, RHS, Instruction::Sub > | m_Sub (const LHS &L, const RHS &R) |
template<typename LHS , typename RHS > | |
BinaryOp_match< LHS, RHS, Instruction::FSub > | m_FSub (const LHS &L, const RHS &R) |
template<typename OpTy > | |
FNeg_match< OpTy > | m_FNeg (const OpTy &X) |
Match 'fneg X' as 'fsub -0.0, X'. More... | |
template<typename RHS > | |
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'. More... | |
template<typename LHS , typename RHS > | |
BinaryOp_match< LHS, RHS, Instruction::Mul > | m_Mul (const LHS &L, const RHS &R) |
template<typename LHS , typename RHS > | |
BinaryOp_match< LHS, RHS, Instruction::FMul > | m_FMul (const LHS &L, const RHS &R) |
template<typename LHS , typename RHS > | |
BinaryOp_match< LHS, RHS, Instruction::UDiv > | m_UDiv (const LHS &L, const RHS &R) |
template<typename LHS , typename RHS > | |
BinaryOp_match< LHS, RHS, Instruction::SDiv > | m_SDiv (const LHS &L, const RHS &R) |
template<typename LHS , typename RHS > | |
BinaryOp_match< LHS, RHS, Instruction::FDiv > | m_FDiv (const LHS &L, const RHS &R) |
template<typename LHS , typename RHS > | |
BinaryOp_match< LHS, RHS, Instruction::URem > | m_URem (const LHS &L, const RHS &R) |
template<typename LHS , typename RHS > | |
BinaryOp_match< LHS, RHS, Instruction::SRem > | m_SRem (const LHS &L, const RHS &R) |
template<typename LHS , typename RHS > | |
BinaryOp_match< LHS, RHS, Instruction::FRem > | m_FRem (const LHS &L, const RHS &R) |
template<typename LHS , typename RHS > | |
BinaryOp_match< LHS, RHS, Instruction::And > | m_And (const LHS &L, const RHS &R) |
template<typename LHS , typename RHS > | |
BinaryOp_match< LHS, RHS, Instruction::Or > | m_Or (const LHS &L, const RHS &R) |
template<typename LHS , typename RHS > | |
BinaryOp_match< LHS, RHS, Instruction::Xor > | m_Xor (const LHS &L, const RHS &R) |
template<typename LHS , typename RHS > | |
BinaryOp_match< LHS, RHS, Instruction::Shl > | m_Shl (const LHS &L, const RHS &R) |
template<typename LHS , typename RHS > | |
BinaryOp_match< LHS, RHS, Instruction::LShr > | m_LShr (const LHS &L, const RHS &R) |
template<typename LHS , typename RHS > | |
BinaryOp_match< LHS, RHS, Instruction::AShr > | m_AShr (const LHS &L, const RHS &R) |
template<typename LHS , typename RHS > | |
OverflowingBinaryOp_match< LHS, RHS, Instruction::Add, OverflowingBinaryOperator::NoSignedWrap > | m_NSWAdd (const LHS &L, const RHS &R) |
template<typename LHS , typename RHS > | |
OverflowingBinaryOp_match< LHS, RHS, Instruction::Sub, OverflowingBinaryOperator::NoSignedWrap > | m_NSWSub (const LHS &L, const RHS &R) |
template<typename LHS , typename RHS > | |
OverflowingBinaryOp_match< LHS, RHS, Instruction::Mul, OverflowingBinaryOperator::NoSignedWrap > | m_NSWMul (const LHS &L, const RHS &R) |
template<typename LHS , typename RHS > | |
OverflowingBinaryOp_match< LHS, RHS, Instruction::Shl, OverflowingBinaryOperator::NoSignedWrap > | m_NSWShl (const LHS &L, const RHS &R) |
template<typename LHS , typename RHS > | |
OverflowingBinaryOp_match< LHS, RHS, Instruction::Add, OverflowingBinaryOperator::NoUnsignedWrap > | m_NUWAdd (const LHS &L, const RHS &R) |
template<typename LHS , typename RHS > | |
OverflowingBinaryOp_match< LHS, RHS, Instruction::Sub, OverflowingBinaryOperator::NoUnsignedWrap > | m_NUWSub (const LHS &L, const RHS &R) |
template<typename LHS , typename RHS > | |
OverflowingBinaryOp_match< LHS, RHS, Instruction::Mul, OverflowingBinaryOperator::NoUnsignedWrap > | m_NUWMul (const LHS &L, const RHS &R) |
template<typename LHS , typename RHS > | |
OverflowingBinaryOp_match< LHS, RHS, Instruction::Shl, OverflowingBinaryOperator::NoUnsignedWrap > | m_NUWShl (const LHS &L, const RHS &R) |
template<typename LHS , typename RHS > | |
BinOpPred_match< LHS, RHS, is_shift_op > | m_Shift (const LHS &L, const RHS &R) |
Matches shift operations. More... | |
template<typename LHS , typename RHS > | |
BinOpPred_match< LHS, RHS, is_right_shift_op > | m_Shr (const LHS &L, const RHS &R) |
Matches logical shift operations. More... | |
template<typename LHS , typename RHS > | |
BinOpPred_match< LHS, RHS, is_logical_shift_op > | m_LogicalShift (const LHS &L, const RHS &R) |
Matches logical shift operations. More... | |
template<typename LHS , typename RHS > | |
BinOpPred_match< LHS, RHS, is_bitwiselogic_op > | m_BitwiseLogic (const LHS &L, const RHS &R) |
Matches bitwise logic operations. More... | |
template<typename LHS , typename RHS > | |
BinOpPred_match< LHS, RHS, is_idiv_op > | m_IDiv (const LHS &L, const RHS &R) |
Matches integer division operations. More... | |
template<typename T > | |
Exact_match< T > | m_Exact (const T &SubPattern) |
template<typename LHS , typename RHS > | |
CmpClass_match< LHS, RHS, CmpInst, CmpInst::Predicate > | m_Cmp (CmpInst::Predicate &Pred, const LHS &L, const RHS &R) |
template<typename LHS , typename RHS > | |
CmpClass_match< LHS, RHS, ICmpInst, ICmpInst::Predicate > | m_ICmp (ICmpInst::Predicate &Pred, const LHS &L, const RHS &R) |
template<typename LHS , typename RHS > | |
CmpClass_match< LHS, RHS, FCmpInst, FCmpInst::Predicate > | m_FCmp (FCmpInst::Predicate &Pred, const LHS &L, const RHS &R) |
template<typename Cond , typename LHS , typename RHS > | |
ThreeOps_match< Cond, LHS, RHS, Instruction::Select > | m_Select (const Cond &C, const LHS &L, const RHS &R) |
Matches SelectInst. More... | |
template<int64_t L, int64_t R, typename Cond > | |
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. More... | |
template<typename Val_t , typename Elt_t , typename Idx_t > | |
ThreeOps_match< Val_t, Elt_t, Idx_t, Instruction::InsertElement > | m_InsertElement (const Val_t &Val, const Elt_t &Elt, const Idx_t &Idx) |
Matches InsertElementInst. More... | |
template<typename Val_t , typename Idx_t > | |
TwoOps_match< Val_t, Idx_t, Instruction::ExtractElement > | m_ExtractElement (const Val_t &Val, const Idx_t &Idx) |
Matches ExtractElementInst. More... | |
template<typename V1_t , typename V2_t , typename Mask_t > | |
ThreeOps_match< V1_t, V2_t, Mask_t, Instruction::ShuffleVector > | m_ShuffleVector (const V1_t &v1, const V2_t &v2, const Mask_t &m) |
Matches ShuffleVectorInst. More... | |
template<typename OpTy > | |
OneOps_match< OpTy, Instruction::Load > | m_Load (const OpTy &Op) |
Matches LoadInst. More... | |
template<typename ValueOpTy , typename PointerOpTy > | |
TwoOps_match< ValueOpTy, PointerOpTy, Instruction::Store > | m_Store (const ValueOpTy &ValueOp, const PointerOpTy &PointerOp) |
Matches StoreInst. More... | |
template<typename OpTy > | |
CastClass_match< OpTy, Instruction::BitCast > | m_BitCast (const OpTy &Op) |
Matches BitCast. More... | |
template<typename OpTy > | |
CastClass_match< OpTy, Instruction::PtrToInt > | m_PtrToInt (const OpTy &Op) |
Matches PtrToInt. More... | |
template<typename OpTy > | |
CastClass_match< OpTy, Instruction::Trunc > | m_Trunc (const OpTy &Op) |
Matches Trunc. More... | |
template<typename OpTy > | |
CastClass_match< OpTy, Instruction::SExt > | m_SExt (const OpTy &Op) |
Matches SExt. More... | |
template<typename OpTy > | |
CastClass_match< OpTy, Instruction::ZExt > | m_ZExt (const OpTy &Op) |
Matches ZExt. More... | |
template<typename OpTy > | |
match_combine_or< CastClass_match< OpTy, Instruction::ZExt >, CastClass_match< OpTy, Instruction::SExt > > | m_ZExtOrSExt (const OpTy &Op) |
template<typename OpTy > | |
CastClass_match< OpTy, Instruction::UIToFP > | m_UIToFP (const OpTy &Op) |
Matches UIToFP. More... | |
template<typename OpTy > | |
CastClass_match< OpTy, Instruction::SIToFP > | m_SIToFP (const OpTy &Op) |
Matches SIToFP. More... | |
template<typename OpTy > | |
CastClass_match< OpTy, Instruction::FPTrunc > | m_FPTrunc (const OpTy &Op) |
Matches FPTrunc. More... | |
template<typename OpTy > | |
CastClass_match< OpTy, Instruction::FPExt > | m_FPExt (const OpTy &Op) |
Matches FPExt. More... | |
br_match | m_UnconditionalBr (BasicBlock *&Succ) |
template<typename Cond_t > | |
brc_match< Cond_t > | m_Br (const Cond_t &C, BasicBlock *&T, BasicBlock *&F) |
template<typename LHS , typename RHS > | |
MaxMin_match< ICmpInst, LHS, RHS, smax_pred_ty > | m_SMax (const LHS &L, const RHS &R) |
template<typename LHS , typename RHS > | |
MaxMin_match< ICmpInst, LHS, RHS, smin_pred_ty > | m_SMin (const LHS &L, const RHS &R) |
template<typename LHS , typename RHS > | |
MaxMin_match< ICmpInst, LHS, RHS, umax_pred_ty > | m_UMax (const LHS &L, const RHS &R) |
template<typename LHS , typename RHS > | |
MaxMin_match< ICmpInst, LHS, RHS, umin_pred_ty > | m_UMin (const LHS &L, const RHS &R) |
template<typename LHS , typename RHS > | |
MaxMin_match< FCmpInst, LHS, RHS, ofmax_pred_ty > | m_OrdFMax (const LHS &L, const RHS &R) |
Match an 'ordered' floating point maximum function. More... | |
template<typename LHS , typename RHS > | |
MaxMin_match< FCmpInst, LHS, RHS, ofmin_pred_ty > | m_OrdFMin (const LHS &L, const RHS &R) |
Match an 'ordered' floating point minimum function. More... | |
template<typename LHS , typename RHS > | |
MaxMin_match< FCmpInst, LHS, RHS, ufmax_pred_ty > | m_UnordFMax (const LHS &L, const RHS &R) |
Match an 'unordered' floating point maximum function. More... | |
template<typename LHS , typename RHS > | |
MaxMin_match< FCmpInst, LHS, RHS, ufmin_pred_ty > | m_UnordFMin (const LHS &L, const RHS &R) |
Match an 'unordered' floating point minimum function. More... | |
template<typename LHS_t , typename RHS_t , typename Sum_t > | |
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. More... | |
template<unsigned OpI, typename Opnd_t > | |
Argument_match< Opnd_t > | m_Argument (const Opnd_t &Op) |
Match an argument. More... | |
template<Intrinsic::ID IntrID> | |
IntrinsicID_match | m_Intrinsic () |
Match intrinsic calls like this: m_Intrinsic<Intrinsic::fabs>(m_Value(X)) More... | |
template<Intrinsic::ID IntrID, typename T0 > | |
m_Intrinsic_Ty< T0 >::Ty | m_Intrinsic (const T0 &Op0) |
template<Intrinsic::ID IntrID, typename T0 , typename T1 > | |
m_Intrinsic_Ty< T0, T1 >::Ty | m_Intrinsic (const T0 &Op0, const T1 &Op1) |
template<Intrinsic::ID IntrID, typename T0 , typename T1 , typename T2 > | |
m_Intrinsic_Ty< T0, T1, T2 >::Ty | m_Intrinsic (const T0 &Op0, const T1 &Op1, const T2 &Op2) |
template<Intrinsic::ID IntrID, typename T0 , typename T1 , typename T2 , typename T3 > | |
m_Intrinsic_Ty< T0, T1, T2, T3 >::Ty | m_Intrinsic (const T0 &Op0, const T1 &Op1, const T2 &Op2, const T3 &Op3) |
template<typename Opnd0 > | |
m_Intrinsic_Ty< Opnd0 >::Ty | m_BitReverse (const Opnd0 &Op0) |
template<typename Opnd0 > | |
m_Intrinsic_Ty< Opnd0 >::Ty | m_BSwap (const Opnd0 &Op0) |
template<typename Opnd0 > | |
m_Intrinsic_Ty< Opnd0 >::Ty | m_FAbs (const Opnd0 &Op0) |
template<typename Opnd0 > | |
m_Intrinsic_Ty< Opnd0 >::Ty | m_FCanonicalize (const Opnd0 &Op0) |
template<typename Opnd0 , typename Opnd1 > | |
m_Intrinsic_Ty< Opnd0, Opnd1 >::Ty | m_FMin (const Opnd0 &Op0, const Opnd1 &Op1) |
template<typename Opnd0 , typename Opnd1 > | |
m_Intrinsic_Ty< Opnd0, Opnd1 >::Ty | m_FMax (const Opnd0 &Op0, const Opnd1 &Op1) |
template<typename LHS , typename RHS > | |
AnyBinaryOp_match< LHS, RHS, true > | m_c_BinOp (const LHS &L, const RHS &R) |
Matches a BinaryOperator with LHS and RHS in either order. More... | |
template<typename LHS , typename RHS > | |
CmpClass_match< LHS, RHS, ICmpInst, ICmpInst::Predicate, true > | m_c_ICmp (ICmpInst::Predicate &Pred, const LHS &L, const RHS &R) |
Matches an ICmp with a predicate over LHS and RHS in either order. More... | |
template<typename LHS , typename RHS > | |
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. More... | |
template<typename LHS , typename RHS > | |
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. More... | |
template<typename LHS , typename RHS > | |
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. More... | |
template<typename LHS , typename RHS > | |
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. More... | |
template<typename LHS , typename RHS > | |
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. More... | |
template<typename ValTy > | |
BinaryOp_match< cst_pred_ty< is_zero_int >, ValTy, Instruction::Sub > | m_Neg (const ValTy &V) |
Matches a 'Neg' as 'sub 0, V'. More... | |
template<typename ValTy > | |
BinaryOp_match< ValTy, cst_pred_ty< is_all_ones >, Instruction::Xor, true > | m_Not (const ValTy &V) |
Matches a 'Not' as 'xor V, -1' or 'xor -1, V'. More... | |
template<typename LHS , typename RHS > | |
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. More... | |
template<typename LHS , typename RHS > | |
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. More... | |
template<typename LHS , typename RHS > | |
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. More... | |
template<typename LHS , typename RHS > | |
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. More... | |
template<typename LHS , typename RHS > | |
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. More... | |
template<typename LHS , typename RHS > | |
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. More... | |
template<typename Val_t > | |
Signum_match< Val_t > | m_Signum (const Val_t &V) |
Matches a signum pattern. More... | |
|
inline |
Definition at line 642 of file PatternMatch.h.
Referenced by areInverseVectorBitmasks(), canNarrowShiftAmt(), canonicalizeLowbitMask(), checkForNegativeOperand(), llvm::InstCombiner::commonShiftTransforms(), computeKnownBitsFromOperator(), llvm::JumpThreadingPass::ComputeValueKnownInPredecessorsImpl(), llvm::createSeparateConstOffsetFromGEPPass(), llvm::findScalarElement(), foldICmpWithHighBitMask(), foldICmpWithLowBitMaskedVal(), foldICmpWithTruncSignExtendedVal(), foldSignedTruncationCheck(), GetConstantInt(), getValueFromICmpCondition(), isGEPFoldable(), isKnownNonZero(), isKnownToBeAPowerOfTwo(), IsNarrowSequence(), isObjectDereferencedInBlock(), llvm::PatternMatch::UAddWithOverflow_match< LHS_t, RHS_t, Sum_t >::match(), matchesAdd(), processUGT_ADDCST_ADD(), simplifyAndOfICmpsWithAdd(), simplifyOrOfICmpsWithAdd(), SimplifySubInst(), llvm::InstCombiner::visitAdd(), llvm::InstCombiner::visitICmpInst(), llvm::InstCombiner::visitMul(), llvm::InstCombiner::visitSub(), llvm::InstCombiner::visitSwitchInst(), and llvm::InstCombiner::visitXor().
|
inline |
Match an integer or vector with all bits set.
For vectors, this includes constants with undefined elements.
Definition at line 309 of file PatternMatch.h.
Referenced by areInverseVectorBitmasks(), canonicalizeLowbitMask(), canonicalizeSaturatedSubtract(), checkForNegativeOperand(), foldICmpWithHighBitMask(), foldICmpWithLowBitMaskedVal(), foldICmpWithTruncSignExtendedVal(), foldSelectICmpAndOr(), foldXorToXor(), m_Not(), matchSelectPattern(), SimplifyAddInst(), SimplifyAndInst(), SimplifyAShrInst(), simplifyBinaryIntrinsic(), SimplifyGEPInst(), simplifyICmpWithConstant(), SimplifyOrInst(), llvm::InstCombiner::visitCallInst(), llvm::InstCombiner::visitICmpInst(), llvm::InstCombiner::visitMul(), llvm::InstCombiner::visitSDiv(), llvm::InstCombiner::visitSub(), llvm::InstCombiner::visitXor(), and llvm::InstCombiner::visitZExt().
|
inline |
Definition at line 749 of file PatternMatch.h.
Referenced by canonicalizeSaturatedSubtract(), checkForNegativeOperand(), llvm::collectCmpOps(), foldAndOrOfEqualityCmpsWithConstants(), foldAnyOrAllBitsSet(), foldICmpWithMinMax(), foldOrToXor(), foldSelectICmpAnd(), foldSelectICmpAndAnd(), foldSelectICmpAndOr(), llvm::InstCombiner::FoldShiftByConstant(), foldSignedTruncationCheck(), foldVecTruncToExtElt(), foldXorToXor(), GetConstantInt(), getMaskedTypeForICmpPair(), isImpliedCondAndOr(), isKnownToBeAPowerOfTwo(), isOnlyReachableViaThisEdge(), matchAndOrChain(), MatchRem(), matchRotate(), processUMulZExtIdiom(), replaceAllUsesOfWithIn(), llvm::InstCombiner::replacedSelectWithOperand(), llvm::LoopPredicationPass::run(), scaleWeights(), SimplifyOrInst(), simplifySelectBitTest(), simplifySelectWithICmpCond(), llvm::InstCombiner::visitAdd(), llvm::InstCombiner::visitAnd(), llvm::InstCombiner::visitCallInst(), llvm::InstCombiner::visitICmpInst(), llvm::InstCombiner::visitOr(), llvm::InstCombiner::visitXor(), and llvm::InstCombiner::visitZExt().
|
inline |
Match a floating-point negative zero or positive zero.
For vectors, this includes constants with undefined elements.
Definition at line 436 of file PatternMatch.h.
Referenced by canonicalizeSaturatedSubtract(), foldFCmpReciprocalAndZero(), foldSelectBinOpIdentity(), m_FNegNSZ(), matchSelectPattern(), SimplifyFAddInst(), SimplifyFDivInst(), SimplifyFMulInst(), SimplifyFSubInst(), and llvm::InstCombiner::visitFCmpInst().
|
inline |
Match a ConstantFP or splatted ConstantVector, binding the specified pointer to the contained APFloat.
Definition at line 180 of file PatternMatch.h.
Referenced by factorizeFAddFSub(), foldFCmpReciprocalAndZero(), getPow(), getSqrtCall(), matchFastFloatClamp(), simplifyBinaryIntrinsic(), SimplifyFCmpInst(), simplifySelectWithFCmp(), llvm::InstCombiner::visitCallInst(), and llvm::InstCombiner::visitFCmpInst().
|
inline |
Match a ConstantInt or splatted ConstantVector, binding the specified pointer to the contained APInt.
Definition at line 176 of file PatternMatch.h.
Referenced by canEvaluateShiftedShift(), canEvaluateTruncated(), canEvaluateZExtd(), canonicalizeSaturatedSubtract(), checkForNegativeOperand(), llvm::InstCombiner::commonIDivTransforms(), llvm::InstCombiner::commonIRemTransforms(), computeKnownBits(), computeKnownBitsFromOperator(), ComputeNumSignBitsImpl(), llvm::ConstantFoldBinaryInstruction(), createAndInstr(), CreateLoadIns(), llvm::decomposeBitTestICmp(), foldAndOrOfEqualityCmpsWithConstants(), foldICmpShlOne(), foldICmpWithTruncSignExtendedVal(), foldSelectICmpAnd(), llvm::InstCombiner::FoldShiftByConstant(), foldShiftedShift(), foldSignedTruncationCheck(), getAlternateBinop(), getBinOpsForFactorization(), GetConstantInt(), getDemandedBitsLHSMask(), getLogBase2(), GetLoopInvariantInsertPosition(), getRangeForAffineARHelper(), isAlwaysLive(), isDivZero(), llvm::isSafeToSpeculativelyExecute(), isSelect01(), isSignedMinMaxClamp(), isTruePredicate(), lookThroughAnd(), MaintainNoSignedWrap(), matchClamp(), MatchDiv(), matchMinMax(), MatchMul(), MatchRem(), processUGT_ADDCST_ADD(), llvm::InstCombiner::replacedSelectWithOperand(), setLimitsForBinOp(), setLimitsForIntrinsic(), ShrinkDemandedConstant(), SimplifyAndInst(), simplifyAndOfICmpsWithAdd(), simplifyAndOrOfICmpsWithConstants(), SimplifyBSwap(), simplifyICmpWithAbsNabs(), simplifyICmpWithBinOp(), simplifyICmpWithConstant(), simplifyIntrinsic(), SimplifyLShrInst(), SimplifyOrInst(), simplifyOrOfICmpsWithAdd(), simplifySelectBitTest(), simplifySelectWithICmpCond(), truncateIVUse(), llvm::InstCombiner::visitAnd(), llvm::InstCombiner::visitAShr(), llvm::InstCombiner::visitCallInst(), llvm::InstCombiner::visitICmpInst(), llvm::InstCombiner::visitLShr(), llvm::InstCombiner::visitMul(), llvm::InstCombiner::visitOr(), llvm::InstCombiner::visitSDiv(), llvm::InstCombiner::visitShl(), llvm::InstCombiner::visitSub(), llvm::InstCombiner::visitTrunc(), llvm::InstCombiner::visitUDiv(), llvm::InstCombiner::visitXor(), and llvm::reassociate::XorOpnd::XorOpnd().
|
inline |
Match an argument.
Definition at line 1497 of file PatternMatch.h.
|
inline |
Definition at line 779 of file PatternMatch.h.
Referenced by checkForNegativeOperand(), EvaluateConstantChrecAtConstant(), foldICmpWithMinMax(), foldICmpWithTruncSignExtendedVal(), GetLoopInvariantInsertPosition(), llvm::PatternMatch::Signum_match< Opnd_t >::match(), SimplifyGEPInst(), llvm::InstCombiner::visitAShr(), llvm::InstCombiner::visitGetElementPtrInst(), llvm::InstCombiner::visitSExt(), llvm::InstCombiner::visitSub(), and llvm::InstCombiner::visitXor().
|
inline |
Match an arbitrary binary operation and ignore it.
Definition at line 74 of file PatternMatch.h.
Referenced by canonicalizeSaturatedSubtract(), cheapToScalarize(), createRdxShuffleMask(), foldAndToXor(), foldBitCastBitwiseLogic(), foldSelectBinOpIdentity(), foldSelectShuffle(), foldSelectShuffleWith1Binop(), llvm::InstCombiner::FoldShiftByConstant(), foldVecTruncToExtElt(), getReductionData(), scaleWeights(), ShrinkDemandedConstant(), simplifyAssocCastAssoc(), llvm::InstCombiner::visitExtractElementInst(), and llvm::InstCombiner::visitXor().
|
inline |
Match a binary operator, capturing it if we match.
Definition at line 481 of file PatternMatch.h.
References I.
|
inline |
Definition at line 607 of file PatternMatch.h.
References llvm::MCID::Commutable.
|
inline |
Matches BitCast.
Definition at line 1150 of file PatternMatch.h.
Referenced by canonicalizeSaturatedSubtract(), combineLoadToNewType(), computeKnownBitsFromAssume(), foldBitCastBitwiseLogic(), foldBitcastExtElt(), foldBitCastSelect(), foldVecTruncToExtElt(), removeBitcastsFromLoadStoreOnMinMax(), simplifyICmpWithConstant(), llvm::AssumptionCache::updateAffectedValues(), and llvm::InstCombiner::visitICmpInst().
|
inline |
Definition at line 1576 of file PatternMatch.h.
Referenced by foldICmpWithMinMax(), and simplifyUnaryIntrinsic().
|
inline |
Matches bitwise logic operations.
Definition at line 948 of file PatternMatch.h.
Referenced by llvm::AssumptionCache::updateAffectedValues().
|
inline |
Definition at line 1249 of file PatternMatch.h.
Referenced by foldGuardedRotateToFunnelShift(), llvm::SCEVExpander::getRelatedExistingExpansion(), llvm::isImpliedByDomCondition(), isLoopNeverExecuted(), processUGT_ADDCST_ADD(), llvm::LoopPredicationPass::run(), scaleWeights(), tryToMoveFreeBeforeNullTest(), and llvm::InstCombiner::visitBranchInst().
|
inline |
Definition at line 1581 of file PatternMatch.h.
Referenced by foldICmpWithMinMax(), SimplifyBSwap(), simplifyUnaryIntrinsic(), and llvm::InstCombiner::visitCallInst().
|
inline |
Matches a Add with LHS and RHS in either order.
Definition at line 1628 of file PatternMatch.h.
Referenced by foldICmpWithTruncSignExtendedVal(), SimplifyOrInst(), llvm::InstCombiner::visitSub(), and llvm::InstCombiner::visitXor().
|
inline |
Matches an And with LHS and RHS in either order.
Definition at line 1642 of file PatternMatch.h.
Referenced by llvm::collectCmpOps(), computeKnownBitsFromAssume(), foldAndToXor(), foldAnyOrAllBitsSet(), foldICmpWithLowBitMaskedVal(), foldICmpWithTruncSignExtendedVal(), foldOrToXor(), foldSelectICmpAndAnd(), foldXorToXor(), llvm::haveNoCommonBitsSet(), lookThroughAnd(), simplifyAndOrOfICmpsWithZero(), simplifyICmpWithBinOp(), SimplifyOrInst(), llvm::InstCombiner::visitAdd(), visitMaskedMerge(), llvm::InstCombiner::visitSub(), and llvm::InstCombiner::visitXor().
|
inline |
Matches a BinaryOperator with LHS and RHS in either order.
Definition at line 1613 of file PatternMatch.h.
Referenced by computeKnownBitsFromOperator(), foldSelectBinOpIdentity(), foldSelectWithBinaryOp(), shouldMergeGEPs(), llvm::InstCombiner::visitAdd(), and llvm::InstCombiner::visitAnd().
|
inline |
Matches FAdd with LHS and RHS in either order.
Definition at line 1703 of file PatternMatch.h.
Referenced by SimplifyFSubInst(), and llvm::InstCombiner::visitFSub().
|
inline |
Matches FMul with LHS and RHS in either order.
Definition at line 1710 of file PatternMatch.h.
Referenced by factorizeFAddFSub(), SimplifyFDivInst(), llvm::InstCombiner::visitFDiv(), and llvm::InstCombiner::visitFMul().
|
inline |
Matches an ICmp with a predicate over LHS and RHS in either order.
Does not swap the predicate.
Definition at line 1621 of file PatternMatch.h.
Referenced by computeKnownBitsFromAssume(), foldICmpWithHighBitMask(), foldICmpWithLowBitMaskedVal(), foldICmpWithTruncSignExtendedVal(), foldSelectWithBinaryOp(), and isKnownNonNullFromDominatingCondition().
|
inline |
Matches a Mul with LHS and RHS in either order.
Definition at line 1635 of file PatternMatch.h.
Referenced by llvm::InstCombiner::commonIDivTransforms(), simplifyDiv(), llvm::InstCombiner::visitMul(), and llvm::InstCombiner::visitSub().
|
inline |
Matches an Or with LHS and RHS in either order.
Definition at line 1649 of file PatternMatch.h.
Referenced by computeKnownBitsFromAssume(), foldAndToXor(), foldGuardedRotateToFunnelShift(), foldOrToXor(), foldXorToXor(), SimplifyAndInst(), simplifyICmpWithBinOp(), SimplifyLShrInst(), splitMergedValStore(), llvm::InstCombiner::visitAnd(), llvm::InstCombiner::visitOr(), llvm::InstCombiner::visitSub(), llvm::InstCombiner::visitTrunc(), and llvm::InstCombiner::visitXor().
|
inline |
Matches an SMax with LHS and RHS in either order.
Definition at line 1684 of file PatternMatch.h.
Referenced by foldICmpWithMinMax().
|
inline |
Matches an SMin with LHS and RHS in either order.
Definition at line 1678 of file PatternMatch.h.
Referenced by foldICmpWithMinMax().
|
inline |
Matches a UMax with LHS and RHS in either order.
Definition at line 1696 of file PatternMatch.h.
Referenced by foldICmpWithMinMax().
|
inline |
Matches a UMin with LHS and RHS in either order.
Definition at line 1690 of file PatternMatch.h.
Referenced by foldICmpWithMinMax().
|
inline |
Matches an Xor with LHS and RHS in either order.
Definition at line 1656 of file PatternMatch.h.
Referenced by computeKnownBitsFromAssume(), foldXorToXor(), m_Not(), SimplifyOrInst(), llvm::InstCombiner::visitAnd(), visitMaskedMerge(), llvm::InstCombiner::visitOr(), llvm::InstCombiner::visitSub(), and llvm::InstCombiner::visitXor().
|
inline |
Matches any compare instruction and ignore it.
Definition at line 79 of file PatternMatch.h.
Referenced by canonicalizeSaturatedSubtract(), cheapToScalarize(), llvm::collectCmpOps(), createRdxShuffleMask(), foldSelectBinOpIdentity(), isMinMaxWithLoads(), scaleWeights(), llvm::InstCombiner::visitBranchInst(), llvm::InstCombiner::visitCallInst(), llvm::InstCombiner::visitExtractElementInst(), and llvm::InstCombiner::visitXor().
|
inline |
Definition at line 1008 of file PatternMatch.h.
|
inline |
Combine two pattern matchers matching L && R.
Definition at line 130 of file PatternMatch.h.
Referenced by foldICmpWithLowBitMaskedVal(), m_Intrinsic(), SimplifyAndInst(), and visitMaskedMerge().
|
inline |
Combine two pattern matchers matching L || R.
Definition at line 124 of file PatternMatch.h.
Referenced by computeKnownBitsFromAssume(), foldICmpWithHighBitMask(), foldICmpWithLowBitMaskedVal(), foldVecTruncToExtElt(), m_ZExtOrSExt(), markAliveBlocks(), matchFastFloatClamp(), matchSelectPattern(), scaleWeights(), SimplifyMulInst(), simplifySelectWithICmpCond(), and tryToMoveFreeBeforeNullTest().
|
inline |
Match an arbitrary Constant and ignore it.
Definition at line 90 of file PatternMatch.h.
Referenced by areInverseVectorBitmasks(), canNarrowShiftAmt(), canonicalizeSaturatedSubtract(), checkForNegativeOperand(), llvm::InstCombiner::commonShiftTransforms(), llvm::findScalarElement(), foldBitCastBitwiseLogic(), foldConstantInsEltIntoShuffle(), foldFDivConstantDividend(), foldFDivConstantDivisor(), foldICmpShlOne(), foldICmpWithLowBitMaskedVal(), foldIdentityExtractShuffle(), foldSelectBinOpIdentity(), foldSelectShuffle(), foldSelectShuffleWith1Binop(), foldUDivShl(), foldVectorCmp(), foldVecTruncToExtElt(), getAlternateBinop(), getBinOpsForFactorization(), hoistInsEltConst(), lookThroughCast(), narrowUDivURem(), narrowVectorSelect(), recordCondition(), shouldMergeGEPs(), simplifyAssocCastAssoc(), llvm::InstCombiner::visitCallInst(), llvm::InstCombiner::visitFCmpInst(), llvm::InstCombiner::visitFMul(), llvm::InstCombiner::visitFSub(), visitMaskedMerge(), llvm::InstCombiner::visitMul(), llvm::InstCombiner::visitShl(), llvm::InstCombiner::visitSub(), llvm::InstCombiner::visitTrunc(), llvm::InstCombiner::visitXor(), and llvm::InstCombiner::visitZExt().
Match a Constant, capturing the value if we match.
Definition at line 487 of file PatternMatch.h.
References C.
|
inline |
Match a ConstantFP, capturing the value if we match.
Definition at line 490 of file PatternMatch.h.
References C.
|
inline |
Match an arbitrary ConstantInt and ignore it.
Match a ConstantInt with a specific value.
Definition at line 82 of file PatternMatch.h.
Referenced by areInverseVectorBitmasks(), canEvaluateShifted(), cheapToScalarize(), computeKnownBitsFromAssume(), llvm::JumpThreadingPass::ComputeValueKnownInPredecessorsImpl(), EvaluateConstantChrecAtConstant(), foldBitcastExtElt(), foldConstantInsEltIntoShuffle(), foldICmpShlOne(), foldICmpWithMinMax(), llvm::InstCombiner::FoldShiftByConstant(), foldShuffleWithInsert(), foldSignedTruncationCheck(), foldVecTruncToExtElt(), getValueFromICmpCondition(), hasOnlyOneNonZeroIndex(), hoistInsEltConst(), isLoopNeverExecuted(), IsNarrowSequence(), isObjectDereferencedInBlock(), llvm::PatternMatch::constantint_match< Val >::match(), matchAndOrChain(), matchesAdd(), matchesOr(), processUGT_ADDCST_ADD(), processUMulZExtIdiom(), simplifyDiv(), SimplifyGEPInst(), llvm::AssumptionCache::updateAffectedValues(), llvm::InstCombiner::visitAdd(), llvm::InstCombiner::visitAnd(), llvm::InstCombiner::visitGetElementPtrInst(), llvm::InstCombiner::visitInsertElementInst(), llvm::InstCombiner::visitMul(), llvm::InstCombiner::visitOr(), llvm::InstCombiner::visitSExt(), llvm::InstCombiner::visitSwitchInst(), and llvm::InstCombiner::visitTrunc().
|
inline |
Match a ConstantInt, capturing the value if we match.
Definition at line 484 of file PatternMatch.h.
|
inline |
Match a ConstantInt and bind to its value.
This does not match ConstantInts wider than 64-bits.
Definition at line 583 of file PatternMatch.h.
|
inline |
A commutative-friendly version of m_Specific().
Definition at line 515 of file PatternMatch.h.
Referenced by computeKnownBitsFromOperator(), foldAndToXor(), foldICmpWithLowBitMaskedVal(), foldICmpWithTruncSignExtendedVal(), foldXorToXor(), llvm::InstCombiner::visitAdd(), visitMaskedMerge(), llvm::InstCombiner::visitTrunc(), and llvm::InstCombiner::visitXor().
Definition at line 516 of file PatternMatch.h.
|
inline |
Definition at line 974 of file PatternMatch.h.
References llvm::PatternMatch::OneUse_match< SubPattern_t >::SubPattern.
Referenced by isKnownNonZero(), isKnownToBeAPowerOfTwo(), SimplifyMulInst(), SimplifyShlInst(), llvm::InstCombiner::visitShl(), and llvm::InstCombiner::visitUDiv().
|
inline |
Matches ExtractElementInst.
Definition at line 1106 of file PatternMatch.h.
Referenced by llvm::InstCombiner::visitInsertElementInst().
|
inline |
Definition at line 1586 of file PatternMatch.h.
Referenced by llvm::InstCombiner::visitCallInst().
|
inline |
Definition at line 648 of file PatternMatch.h.
Referenced by llvm::CannotBeNegativeZero(), llvm::RecurrenceDescriptor::isConditionalRdxPattern(), and llvm::InstCombiner::visitFMul().
|
inline |
Definition at line 1591 of file PatternMatch.h.
|
inline |
Definition at line 1020 of file PatternMatch.h.
Referenced by simplifySelectWithFCmp().
|
inline |
Definition at line 725 of file PatternMatch.h.
Referenced by factorizeFAddFSub(), foldFDivConstantDividend(), llvm::InstCombiner::visitFDiv(), llvm::InstCombiner::visitFMul(), and llvm::InstCombiner::visitFSub().
|
inline |
Definition at line 1602 of file PatternMatch.h.
|
inline |
Definition at line 1596 of file PatternMatch.h.
|
inline |
Definition at line 707 of file PatternMatch.h.
Referenced by factorizeFAddFSub(), foldFDivConstantDividend(), getSqrtCall(), llvm::RecurrenceDescriptor::isConditionalRdxPattern(), llvm::InstCombiner::visitFMul(), and llvm::InstCombiner::visitFSub().
|
inline |
Match 'fneg X' as 'fsub -0.0, X'.
Definition at line 689 of file PatternMatch.h.
References X.
Referenced by buildMultiplyTree(), canonicalizeSaturatedSubtract(), createAndInstr(), foldFDivConstantDividend(), foldFDivConstantDivisor(), llvm::getComplexity(), isReassociableOp(), LinearizeExprTree(), NegateValue(), optimizeTrigReflections(), llvm::FastISel::selectFNeg(), ShouldBreakUpSubtract(), llvm::InstCombiner::visitCallInst(), llvm::InstCombiner::visitFAdd(), llvm::InstCombiner::visitFCmpInst(), llvm::InstCombiner::visitFDiv(), llvm::InstCombiner::visitFMul(), llvm::InstCombiner::visitFPTrunc(), and llvm::InstCombiner::visitFSub().
|
inline |
Match 'fneg X' as 'fsub +-0.0, X'.
Definition at line 696 of file PatternMatch.h.
References m_AnyZeroFP(), and m_FSub().
Referenced by SimplifyFDivInst().
|
inline |
Matches FPExt.
Definition at line 1205 of file PatternMatch.h.
Referenced by llvm::InstCombiner::visitCallInst(), llvm::InstCombiner::visitFCmpInst(), and llvm::InstCombiner::visitFSub().
|
inline |
Match a float 1.0 or vector with all elements equal to 1.0.
Definition at line 543 of file PatternMatch.h.
References m_SpecificFP().
Referenced by llvm::GCNTTIImpl::getArithmeticInstrCost(), getSqrtCall(), SimplifyFDivInst(), SimplifyFMulInst(), and llvm::InstCombiner::visitCallInst().
|
inline |
Matches FPTrunc.
Definition at line 1199 of file PatternMatch.h.
Referenced by llvm::InstCombiner::visitFSub().
|
inline |
Definition at line 743 of file PatternMatch.h.
|
inline |
Definition at line 660 of file PatternMatch.h.
Referenced by canonicalizeSaturatedSubtract(), llvm::RecurrenceDescriptor::isConditionalRdxPattern(), m_FNegNSZ(), SimplifyFAddInst(), SimplifyFSubInst(), llvm::InstCombiner::visitCallInst(), llvm::InstCombiner::visitFMul(), and llvm::InstCombiner::visitFSub().
|
inline |
Definition at line 1014 of file PatternMatch.h.
Referenced by canonicalizeSaturatedSubtract(), computeKnownBitsFromAssume(), countToEliminateCompares(), foldGuardedRotateToFunnelShift(), foldICmpShlOne(), foldSelectWithBinaryOp(), foldSignedTruncationCheck(), llvm::SCEVExpander::getRelatedExistingExpansion(), llvm::PatternMatch::UAddWithOverflow_match< LHS_t, RHS_t, Sum_t >::match(), processUGT_ADDCST_ADD(), recordCondition(), replaceAllUsesOfWithIn(), llvm::LoopPredicationPass::run(), simplifyAndOfICmpsWithAdd(), simplifyAndOfICmpsWithSameOperands(), simplifyOrOfICmpsWithAdd(), simplifyOrOfICmpsWithSameOperands(), simplifySelectWithICmpCond(), simplifyUnsignedRangeCheck(), truncateIVUse(), tryToMoveFreeBeforeNullTest(), llvm::AssumptionCache::updateAffectedValues(), and llvm::InstCombiner::visitCallInst().
|
inline |
Matches integer division operations.
Definition at line 954 of file PatternMatch.h.
Referenced by isKnownNonZero(), and SimplifyMulInst().
|
inline |
Matches InsertElementInst.
Definition at line 1098 of file PatternMatch.h.
Referenced by cheapToScalarize(), foldBitcastExtElt(), and foldShuffleWithInsert().
|
inline |
Match an instruction, capturing it if we match.
Definition at line 479 of file PatternMatch.h.
References I.
Referenced by canonicalizeSaturatedSubtract(), CombineUAddWithOverflow(), createRdxShuffleMask(), llvm::SCEVExpander::getRelatedExistingExpansion(), isMinMaxWithLoads(), lookThroughAnd(), llvm::InstCombiner::visitCallInst(), llvm::InstCombiner::visitFCmpInst(), and llvm::InstCombiner::visitICmpInst().
|
inline |
Match intrinsic calls like this: m_Intrinsic<Intrinsic::fabs>(m_Value(X))
Definition at line 1546 of file PatternMatch.h.
|
inline |
Definition at line 1551 of file PatternMatch.h.
References m_CombineAnd().
|
inline |
Definition at line 1556 of file PatternMatch.h.
References m_CombineAnd().
|
inline |
Definition at line 1563 of file PatternMatch.h.
References m_CombineAnd(), and T1.
|
inline |
Definition at line 1570 of file PatternMatch.h.
References m_CombineAnd().
|
inline |
Matches LoadInst.
Definition at line 1120 of file PatternMatch.h.
Referenced by cheapToScalarize(), isMinMaxWithLoads(), IsNarrowSequence(), and removeBitcastsFromLoadStoreOnMinMax().
|
inline |
Matches logical shift operations.
Definition at line 941 of file PatternMatch.h.
Referenced by canonicalizeSaturatedSubtract(), foldVecTruncToExtElt(), matchRotate(), and llvm::InstCombiner::visitAnd().
|
inline |
Match an integer or vector with only the low bit(s) set.
For vectors, this includes constants with undefined elements.
Definition at line 418 of file PatternMatch.h.
Referenced by foldICmpWithLowBitMaskedVal().
|
inline |
Definition at line 773 of file PatternMatch.h.
Referenced by canEvaluateShifted(), canNarrowShiftAmt(), EvaluateConstantChrecAtConstant(), foldGuardedRotateToFunnelShift(), foldICmpWithLowBitMaskedVal(), foldICmpWithMinMax(), foldSelectICmpAndAnd(), foldVecTruncToExtElt(), GetLoopInvariantInsertPosition(), isKnownToBeAPowerOfTwo(), llvm::PatternMatch::Signum_match< Opnd_t >::match(), matchAndOrChain(), MatchDiv(), processUGT_ADDCST_ADD(), replaceAllUsesOfWithIn(), llvm::InstCombiner::replacedSelectWithOperand(), SimplifyAndInst(), simplifyICmpWithBinOp(), simplifyValueKnownNonZero(), llvm::InstCombiner::visitLShr(), llvm::InstCombiner::visitMul(), llvm::InstCombiner::visitSub(), llvm::InstCombiner::visitTrunc(), llvm::InstCombiner::visitUDiv(), and llvm::InstCombiner::visitXor().
|
inline |
Match an integer or vector with values having all bits except for the high bit set (0x7f...).
For vectors, this includes constants with undefined elements.
Definition at line 319 of file PatternMatch.h.
|
inline |
Definition at line 322 of file PatternMatch.h.
|
inline |
Definition at line 701 of file PatternMatch.h.
Referenced by canNarrowShiftAmt(), hasOnlyOneNonZeroIndex(), isGEPFoldable(), isKnownNonZero(), MatchMul(), llvm::InstCombiner::visitICmpInst(), llvm::InstCombiner::visitMul(), llvm::InstCombiner::visitShl(), and llvm::InstCombiner::visitSub().
|
inline |
Match an arbitrary NaN constant.
This includes quiet and signalling nans. For vectors, this includes constants with undefined elements.
Definition at line 427 of file PatternMatch.h.
Referenced by simplifyBinaryIntrinsic(), SimplifyFCmpInst(), simplifyFPBinop(), and llvm::InstCombiner::visitCallInst().
|
inline |
Matches a 'Neg' as 'sub 0, V'.
Definition at line 1664 of file PatternMatch.h.
References m_Sub(), and m_ZeroInt().
Referenced by buildMultiplyTree(), canonicalizeSaturatedSubtract(), createAndInstr(), foldICmpWithTruncSignExtendedVal(), foldVecTruncToExtElt(), getBinOpsForFactorization(), llvm::getComplexity(), isKnownToBeAPowerOfTwo(), isReassociableOp(), LinearizeExprTree(), llvm::PatternMatch::Signum_match< Opnd_t >::match(), matchRotate(), matchSelectPattern(), NegateValue(), ShouldBreakUpSubtract(), SimplifyAndInst(), simplifyICmpWithBinOp(), unifyBitWidth(), llvm::InstCombiner::visitAdd(), llvm::InstCombiner::visitGetElementPtrInst(), llvm::InstCombiner::visitMul(), and llvm::InstCombiner::visitSub().
|
inline |
Match an integer or vector of negative values.
For vectors, this includes constants with undefined elements.
Definition at line 331 of file PatternMatch.h.
Referenced by SimplifyShlInst(), llvm::InstCombiner::visitSRem(), llvm::InstCombiner::visitUDiv(), llvm::InstCombiner::visitURem(), and llvm::InstCombiner::visitXor().
|
inline |
Definition at line 334 of file PatternMatch.h.
|
inline |
Match a floating-point negative zero.
For vectors, this includes constants with undefined elements.
Definition at line 454 of file PatternMatch.h.
Referenced by SimplifyFAddInst(), SimplifyFRemInst(), and SimplifyFSubInst().
|
inline |
Match an integer or vector of nonnegative values.
For vectors, this includes constants with undefined elements.
Definition at line 343 of file PatternMatch.h.
Referenced by foldICmpWithLowBitMaskedVal(), and llvm::InstCombiner::visitXor().
|
inline |
Definition at line 346 of file PatternMatch.h.
|
inline |
Matches a 'Not' as 'xor V, -1' or 'xor -1, V'.
Definition at line 1671 of file PatternMatch.h.
References m_AllOnes(), and m_c_Xor().
Referenced by areInverseVectorBitmasks(), canonicalizeSaturatedSubtract(), checkForNegativeOperand(), computeKnownBitsFromAssume(), createAndInstr(), llvm::SelectionDAGBuilder::FindMergedConditions(), foldAndToXor(), foldICmpWithHighBitMask(), foldICmpWithLowBitMaskedVal(), foldOrToXor(), foldXorToXor(), llvm::getComplexity(), llvm::haveNoCommonBitsSet(), llvm::IsFreeToInvert(), isReassociableOp(), matchDeMorgansLaws(), matchMinMax(), matchMinMaxOfMinMax(), OptimizeAndOrXor(), SimplifyAddInst(), SimplifyAndInst(), SimplifyOrInst(), SimplifyXorInst(), sinkNotIntoXor(), llvm::AssumptionCache::updateAffectedValues(), llvm::InstCombiner::visitAdd(), llvm::InstCombiner::visitAnd(), llvm::InstCombiner::visitBranchInst(), llvm::InstCombiner::visitCallInst(), llvm::InstCombiner::visitICmpInst(), visitMaskedMerge(), llvm::InstCombiner::visitOr(), llvm::InstCombiner::visitSub(), and llvm::InstCombiner::visitXor().
|
inline |
Definition at line 812 of file PatternMatch.h.
References llvm::MCID::Add, and llvm::OverflowingBinaryOperator::NoSignedWrap.
Referenced by llvm::createSeparateConstOffsetFromGEPPass(), isTruePredicate(), and truncateIVUse().
|
inline |
Definition at line 828 of file PatternMatch.h.
References llvm::OverflowingBinaryOperator::NoSignedWrap.
Referenced by llvm::InstCombiner::commonIDivTransforms(), and matchesOr().
|
inline |
Definition at line 836 of file PatternMatch.h.
References llvm::MCID::Add, llvm::OverflowingBinaryOperator::NoSignedWrap, and llvm::OverflowingBinaryOperator::NoUnsignedWrap.
Referenced by llvm::InstCombiner::commonIDivTransforms(), matchesOr(), SimplifyAShrInst(), simplifyRem(), and llvm::InstCombiner::visitAShr().
|
inline |
Definition at line 820 of file PatternMatch.h.
References llvm::OverflowingBinaryOperator::NoSignedWrap.
Referenced by llvm::createSeparateConstOffsetFromGEPPass(), llvm::isKnownNegation(), matchMinMax(), and llvm::InstCombiner::visitSDiv().
|
inline |
Definition at line 845 of file PatternMatch.h.
References llvm::MCID::Add, and llvm::OverflowingBinaryOperator::NoUnsignedWrap.
Referenced by checkForNegativeOperand(), and isTruePredicate().
|
inline |
Definition at line 861 of file PatternMatch.h.
References llvm::OverflowingBinaryOperator::NoUnsignedWrap.
Referenced by llvm::InstCombiner::commonIDivTransforms(), and llvm::InstCombiner::visitUDiv().
|
inline |
Definition at line 869 of file PatternMatch.h.
References llvm::OverflowingBinaryOperator::NoUnsignedWrap.
Referenced by llvm::InstCombiner::commonIDivTransforms(), SimplifyAndInst(), SimplifyLShrInst(), and simplifyRem().
|
inline |
Definition at line 853 of file PatternMatch.h.
References llvm::OverflowingBinaryOperator::NoUnsignedWrap.
|
inline |
Match an integer 1 or a vector with all elements equal to 1.
For vectors, this includes constants with undefined elements.
Definition at line 355 of file PatternMatch.h.
Referenced by canonicalizeICmpBool(), canonicalizeLowbitMask(), canonicalizeSaturatedSubtract(), checkForNegativeOperand(), llvm::InstCombiner::commonIDivTransforms(), llvm::ConstantFoldBinaryInstruction(), despeculateCountZeros(), foldAnyOrAllBitsSet(), foldCttzCtlz(), foldICmpShlOne(), foldICmpWithHighBitMask(), foldICmpWithLowBitMaskedVal(), foldICmpWithMinMax(), foldICmpWithTruncSignExtendedVal(), foldSelectICmpAndAnd(), isKnownToBeAPowerOfTwo(), matchAndOrChain(), matchSelectPattern(), processUGT_ADDCST_ADD(), replaceAllUsesOfWithIn(), llvm::InstCombiner::replacedSelectWithOperand(), simplifyDivRem(), simplifyICmpOfBools(), SimplifyMulInst(), simplifyValueKnownNonZero(), ThreadCmpOverSelect(), llvm::InstCombiner::visitAdd(), llvm::InstCombiner::visitAnd(), llvm::InstCombiner::visitCallInst(), llvm::InstCombiner::visitICmpInst(), llvm::InstCombiner::visitMul(), llvm::InstCombiner::visitSub(), and llvm::InstCombiner::visitURem().
|
inline |
Definition at line 62 of file PatternMatch.h.
References llvm::PatternMatch::OneUse_match< SubPattern_t >::SubPattern.
Referenced by areInverseVectorBitmasks(), canNarrowShiftAmt(), canonicalizeLowbitMask(), canonicalizeSaturatedSubtract(), cheapToScalarize(), checkForNegativeOperand(), factorizeFAddFSub(), foldAnyOrAllBitsSet(), foldBitCastBitwiseLogic(), foldBitCastSelect(), foldGuardedRotateToFunnelShift(), foldICmpWithHighBitMask(), foldICmpWithMinMax(), foldICmpWithTruncSignExtendedVal(), foldLogicCastConstant(), foldSelectICmpAndAnd(), foldSelectICmpAndOr(), llvm::InstCombiner::FoldShiftByConstant(), foldVecTruncToExtElt(), matchDeMorgansLaws(), matchRotate(), narrowUDivURem(), narrowVectorSelect(), optimizeTrigReflections(), processUGT_ADDCST_ADD(), scaleWeights(), shouldMergeGEPs(), simplifyAssocCastAssoc(), simplifyValueKnownNonZero(), sinkNotIntoXor(), splitMergedValStore(), llvm::InstCombiner::visitAnd(), llvm::InstCombiner::visitAShr(), llvm::InstCombiner::visitBranchInst(), llvm::InstCombiner::visitCallInst(), llvm::InstCombiner::visitFDiv(), llvm::InstCombiner::visitFMul(), llvm::InstCombiner::visitFSub(), llvm::InstCombiner::visitLShr(), visitMaskedMerge(), llvm::InstCombiner::visitMul(), llvm::InstCombiner::visitOr(), llvm::InstCombiner::visitSDiv(), llvm::InstCombiner::visitSExt(), llvm::InstCombiner::visitShl(), llvm::InstCombiner::visitSub(), llvm::InstCombiner::visitTrunc(), llvm::InstCombiner::visitXor(), and llvm::InstCombiner::visitZExt().
|
inline |
Definition at line 755 of file PatternMatch.h.
Referenced by canonicalizeSaturatedSubtract(), checkForNegativeOperand(), llvm::collectCmpOps(), foldAndToXor(), foldAnyOrAllBitsSet(), foldSelectICmpAndOr(), foldVecTruncToExtElt(), foldXorToXor(), GetConstantInt(), isImpliedCondAndOr(), isKnownNonZero(), isOnlyReachableViaThisEdge(), isTruePredicate(), llvm::PatternMatch::Signum_match< Opnd_t >::match(), matchAndOrChain(), matchesOr(), processUGT_ADDCST_ADD(), scaleWeights(), simplifySelectBitTest(), llvm::InstCombiner::visitAdd(), llvm::InstCombiner::visitAnd(), llvm::InstCombiner::visitCallInst(), llvm::InstCombiner::visitOr(), and llvm::InstCombiner::visitXor().
|
inline |
Match an 'ordered' floating point maximum function.
Floating point has one special value 'NaN'. Therefore, there is no total order. However, if we can ignore the 'NaN' value (for example, because of a 'no-nans-float-math' flag) a combination of a fcmp and select has 'maximum' semantics. In the presence of 'NaN' we have to preserve the original select(fcmp(ogt/ge, L, R), L, R) semantics matched by this predicate.
max(L, R) iff L and R are not NaN
m_OrdFMax(L, R) = R iff L or R are NaN
Definition at line 1385 of file PatternMatch.h.
Referenced by createRdxShuffleMask(), getReductionData(), llvm::RecurrenceDescriptor::isMinMaxSelectCmpPattern(), and matchFastFloatClamp().
|
inline |
Match an 'ordered' floating point minimum function.
Floating point has one special value 'NaN'. Therefore, there is no total order. However, if we can ignore the 'NaN' value (for example, because of a 'no-nans-float-math' flag) a combination of a fcmp and select has 'minimum' semantics. In the presence of 'NaN' we have to preserve the original select(fcmp(olt/le, L, R), L, R) semantics matched by this predicate.
min(L, R) iff L and R are not NaN
m_OrdFMin(L, R) = R iff L or R are NaN
Definition at line 1400 of file PatternMatch.h.
Referenced by createRdxShuffleMask(), getReductionData(), llvm::RecurrenceDescriptor::isMinMaxSelectCmpPattern(), and matchFastFloatClamp().
|
inline |
Match a floating-point positive zero.
For vectors, this includes constants with undefined elements.
Definition at line 445 of file PatternMatch.h.
Referenced by llvm::CannotBeNegativeZero(), canonicalizeSaturatedSubtract(), foldFabsWithFcmpZero(), foldSignedTruncationCheck(), SimplifyFAddInst(), SimplifyFRemInst(), SimplifyFSubInst(), llvm::InstCombiner::visitCallInst(), llvm::InstCombiner::visitFCmpInst(), and llvm::InstCombiner::visitFSub().
|
inline |
Match an integer or vector power-of-2.
For vectors, this includes constants with undefined elements.
Definition at line 385 of file PatternMatch.h.
Referenced by canonicalizeSaturatedSubtract(), llvm::InstCombiner::commonShiftTransforms(), foldSelectICmpAnd(), foldSelectICmpAndOr(), foldSignedTruncationCheck(), isKnownToBeAPowerOfTwo(), PickMostRelevantLoop(), llvm::InstCombiner::replacedSelectWithOperand(), and visitUDivOperand().
|
inline |
Definition at line 388 of file PatternMatch.h.
|
inline |
Match an integer or vector of 0 or power-of-2 values.
For vectors, this includes constants with undefined elements.
Definition at line 397 of file PatternMatch.h.
Referenced by isKnownToBeAPowerOfTwo().
|
inline |
Definition at line 400 of file PatternMatch.h.
|
inline |
Matches PtrToInt.
Definition at line 1156 of file PatternMatch.h.
Referenced by computeKnownBitsFromAssume(), processUGT_ADDCST_ADD(), simplifyAndOrOfICmpsWithZero(), SimplifyGEPInst(), SimplifySubInst(), llvm::AssumptionCache::updateAffectedValues(), llvm::InstCombiner::visitGetElementPtrInst(), and llvm::InstCombiner::visitSub().
|
inline |
Definition at line 719 of file PatternMatch.h.
Referenced by llvm::InstCombiner::commonIDivTransforms(), IsKnownPredicateViaMinOrMax(), MatchDiv(), simplifyDiv(), SimplifyGEPInst(), llvm::InstCombiner::visitGetElementPtrInst(), and llvm::InstCombiner::visitSub().
|
inline |
Matches SelectInst.
Definition at line 1082 of file PatternMatch.h.
References C, and llvm::MCID::Select.
Referenced by foldBitCastSelect(), foldICmpShlOne(), llvm::InstCombiner::FoldShiftByConstant(), getBinOpsForFactorization(), getRangeForAffineARHelper(), llvm::IsFreeToInvert(), isMinMaxWithLoads(), m_SelectCst(), narrowVectorSelect(), llvm::InstCombiner::visitCallInst(), llvm::InstCombiner::visitICmpInst(), and llvm::InstCombiner::visitOr().
|
inline |
This matches a select of two constants, e.g.
: m_SelectCst<-1, 0>(m_Value(V))
Definition at line 1091 of file PatternMatch.h.
References m_Select().
|
inline |
Matches SExt.
Definition at line 1168 of file PatternMatch.h.
Referenced by areInverseVectorBitmasks(), canonicalizeSaturatedSubtract(), checkForNegativeOperand(), llvm::createSeparateConstOffsetFromGEPPass(), foldLogicCastConstant(), m_ZExtOrSExt(), matchesOr(), matchSelectPattern(), shouldMergeGEPs(), SimplifyShift(), SimplifySRemInst(), simplifyX86movmsk(), llvm::InstCombiner::visitAnd(), llvm::InstCombiner::visitAShr(), llvm::InstCombiner::visitCallInst(), llvm::InstCombiner::visitLShr(), llvm::InstCombiner::visitOr(), llvm::InstCombiner::visitSDiv(), llvm::InstCombiner::visitSub(), llvm::InstCombiner::visitTrunc(), llvm::InstCombiner::visitUDiv(), and llvm::InstCombiner::visitURem().
|
inline |
Matches shift operations.
Definition at line 926 of file PatternMatch.h.
Referenced by llvm::AssumptionCache::updateAffectedValues().
|
inline |
Definition at line 767 of file PatternMatch.h.
Referenced by canEvaluateShifted(), canNarrowShiftAmt(), canonicalizeLowbitMask(), checkForNegativeOperand(), computeKnownBitsFromAssume(), EvaluateConstantChrecAtConstant(), foldGuardedRotateToFunnelShift(), foldICmpShlOne(), foldICmpWithHighBitMask(), foldICmpWithLowBitMaskedVal(), foldICmpWithMinMax(), foldICmpWithTruncSignExtendedVal(), foldUDivShl(), getBinOpsForFactorization(), GetLoopInvariantInsertPosition(), hasOnlyOneNonZeroIndex(), isKnownNonZero(), isKnownToBeAPowerOfTwo(), MatchMul(), replaceAllUsesOfWithIn(), llvm::InstCombiner::replacedSelectWithOperand(), SimplifyAndInst(), simplifyICmpWithBinOp(), simplifyValueKnownNonZero(), splitMergedValStore(), llvm::InstCombiner::visitAShr(), llvm::InstCombiner::visitLShr(), llvm::InstCombiner::visitMul(), llvm::InstCombiner::visitSExt(), llvm::InstCombiner::visitShl(), llvm::InstCombiner::visitSub(), llvm::InstCombiner::visitTrunc(), and visitUDivOperand().
|
inline |
Matches logical shift operations.
Definition at line 933 of file PatternMatch.h.
Referenced by computeKnownBitsFromAssume(), llvm::InstCombiner::FoldShiftByConstant(), isKnownNonZero(), ShrinkDemandedConstant(), SimplifyShlInst(), llvm::InstCombiner::visitShl(), and llvm::InstCombiner::visitTrunc().
|
inline |
Matches ShuffleVectorInst.
Definition at line 1113 of file PatternMatch.h.
Referenced by foldICmpShlOne(), foldIdentityExtractShuffle(), foldVectorCmp(), narrowVectorSelect(), and shouldMergeGEPs().
|
inline |
Match an integer or vector with only the sign bit(s) set.
For vectors, this includes constants with undefined elements.
Definition at line 409 of file PatternMatch.h.
Referenced by isKnownToBeAPowerOfTwo(), and SimplifyAddInst().
|
inline |
Matches a signum pattern.
signum(x) = x > 0 -> 1 x == 0 -> 0 x < 0 -> -1
Definition at line 1750 of file PatternMatch.h.
Referenced by processUGT_ADDCST_ADD().
|
inline |
Matches SIToFP.
Definition at line 1193 of file PatternMatch.h.
Referenced by llvm::InstCombiner::visitICmpInst().
|
inline |
Definition at line 1352 of file PatternMatch.h.
Referenced by createRdxShuffleMask(), getReductionData(), getSelectFoldableConstant(), llvm::RecurrenceDescriptor::isMinMaxSelectCmpPattern(), matchClamp(), and simplifyICmpWithMinMax().
|
inline |
Definition at line 1358 of file PatternMatch.h.
Referenced by createRdxShuffleMask(), getReductionData(), getSelectFoldableConstant(), llvm::RecurrenceDescriptor::isMinMaxSelectCmpPattern(), matchClamp(), and simplifyICmpWithMinMax().
|
inline |
Match if we have a specific specified value.
Definition at line 502 of file PatternMatch.h.
Referenced by areInverseVectorBitmasks(), canNarrowShiftAmt(), canonicalizeSaturatedSubtract(), llvm::InstCombiner::commonIDivTransforms(), computeKnownBitsFromAssume(), createRdxShuffleMask(), factorizeFAddFSub(), foldGuardedRotateToFunnelShift(), foldICmpShlOne(), foldICmpWithMinMax(), foldICmpWithTruncSignExtendedVal(), foldOrToXor(), foldSelectBinOpIdentity(), foldSelectICmpAndAnd(), foldSelectICmpAndOr(), foldSelectShuffleWith1Binop(), foldSelectWithBinaryOp(), llvm::InstCombiner::FoldShiftByConstant(), foldSignedTruncationCheck(), foldVectorCmp(), foldVecTruncToExtElt(), foldXorToXor(), getBinOpsForFactorization(), GetLoopInvariantInsertPosition(), getValueFromICmpCondition(), llvm::haveNoCommonBitsSet(), llvm::isKnownNegation(), isKnownNonNullFromDominatingCondition(), isKnownToBeAPowerOfTwo(), isMinMaxWithLoads(), isObjectDereferencedInBlock(), isTruePredicate(), matchClamp(), matchFastFloatClamp(), matchMinMax(), matchMinMaxOfMinMax(), matchRotate(), matchSelectPattern(), processUGT_ADDCST_ADD(), replaceAllUsesOfWithIn(), shouldMergeGEPs(), SimplifyAddInst(), SimplifyAndInst(), simplifyAndOfICmpsWithAdd(), simplifyAndOfICmpsWithSameOperands(), simplifyAndOrOfICmpsWithZero(), SimplifyAShrInst(), simplifyDiv(), SimplifyFAddInst(), SimplifyFDivInst(), SimplifyFSubInst(), SimplifyGEPInst(), simplifyICmpWithBinOp(), SimplifyLShrInst(), SimplifyMulInst(), SimplifyOrInst(), simplifyOrOfICmpsWithAdd(), simplifyOrOfICmpsWithSameOperands(), simplifyRem(), simplifySelectBitTest(), simplifySelectWithFCmp(), SimplifyShlInst(), simplifyUnsignedRangeCheck(), SimplifyXorInst(), swapMayExposeCSEOpportunities(), truncateIVUse(), tryToMoveFreeBeforeNullTest(), llvm::InstCombiner::visitAdd(), llvm::InstCombiner::visitAnd(), llvm::InstCombiner::visitAShr(), llvm::InstCombiner::visitCallInst(), llvm::InstCombiner::visitFDiv(), llvm::InstCombiner::visitFMul(), llvm::InstCombiner::visitFSub(), llvm::InstCombiner::visitGetElementPtrInst(), llvm::InstCombiner::visitLShr(), llvm::InstCombiner::visitOr(), llvm::InstCombiner::visitShl(), llvm::InstCombiner::visitSub(), llvm::InstCombiner::visitUDiv(), llvm::InstCombiner::visitXor(), and llvm::InstCombiner::visitZExt().
|
inline |
Match a specific floating point value or vector with all elements equal to the value.
Definition at line 540 of file PatternMatch.h.
Referenced by getPow(), getSqrtCall(), m_FPOne(), and llvm::InstCombiner::visitFMul().
|
inline |
Match a specific integer value or vector with all elements equal to the value.
Definition at line 579 of file PatternMatch.h.
Referenced by canonicalizeSaturatedSubtract(), foldGuardedRotateToFunnelShift(), foldVecTruncToExtElt(), llvm::PatternMatch::Signum_match< Opnd_t >::match(), matchRotate(), SimplifyGEPInst(), and splitMergedValStore().
|
inline |
Definition at line 737 of file PatternMatch.h.
Referenced by llvm::InstCombiner::commonIDivTransforms(), llvm::InstCombiner::commonShiftTransforms(), MatchRem(), simplifyDiv(), and simplifyRem().
|
inline |
Matches StoreInst.
Definition at line 1127 of file PatternMatch.h.
|
inline |
Definition at line 654 of file PatternMatch.h.
Referenced by canNarrowShiftAmt(), canonicalizeSaturatedSubtract(), checkForNegativeOperand(), llvm::InstCombiner::commonIDivTransforms(), llvm::createSeparateConstOffsetFromGEPPass(), foldGuardedRotateToFunnelShift(), foldVecTruncToExtElt(), llvm::isKnownNegation(), m_Neg(), SimplifyAddInst(), SimplifyGEPInst(), SimplifySubInst(), swapMayExposeCSEOpportunities(), llvm::InstCombiner::visitAdd(), llvm::InstCombiner::visitGetElementPtrInst(), llvm::InstCombiner::visitMul(), llvm::InstCombiner::visitSub(), and llvm::InstCombiner::visitXor().
|
inline |
Matches Trunc.
Definition at line 1162 of file PatternMatch.h.
Referenced by canAlwaysEvaluateInType(), canonicalizeSaturatedSubtract(), llvm::decomposeBitTestICmp(), foldICmpWithMinMax(), foldSelectICmpAndOr(), foldSignedTruncationCheck(), IsNarrowSequence(), processUGT_ADDCST_ADD(), SimplifySubInst(), llvm::InstCombiner::visitAnd(), llvm::InstCombiner::visitCallInst(), llvm::InstCombiner::visitSExt(), llvm::InstCombiner::visitSub(), and llvm::InstCombiner::visitZExt().
UAddWithOverflow_match<LHS_t, RHS_t, Sum_t> llvm::PatternMatch::m_UAddWithOverflow | ( | const LHS_t & | L, |
const RHS_t & | R, | ||
const Sum_t & | S | ||
) |
Match an icmp instruction checking for unsigned overflow on addition.
S is matched to the addition whose result is being checked for overflow, and L and R are matched to the LHS and RHS of S.
Definition at line 1477 of file PatternMatch.h.
Referenced by CombineUAddWithOverflow(), and llvm::InstCombiner::visitICmpInst().
|
inline |
Definition at line 713 of file PatternMatch.h.
Referenced by llvm::InstCombiner::commonIDivTransforms(), isKnownToBeAPowerOfTwo(), MatchDiv(), simplifyDiv(), and simplifyICmpWithBinOp().
|
inline |
Matches UIToFP.
Definition at line 1187 of file PatternMatch.h.
Referenced by simplifyICmpWithConstant(), and llvm::InstCombiner::visitICmpInst().
|
inline |
Definition at line 1364 of file PatternMatch.h.
Referenced by createRdxShuffleMask(), getReductionData(), getSelectFoldableConstant(), llvm::RecurrenceDescriptor::isMinMaxSelectCmpPattern(), matchClamp(), and simplifyICmpWithMinMax().
|
inline |
Definition at line 1370 of file PatternMatch.h.
Referenced by createRdxShuffleMask(), getReductionData(), getSelectFoldableConstant(), llvm::RecurrenceDescriptor::isMinMaxSelectCmpPattern(), matchClamp(), and simplifyICmpWithMinMax().
|
inline |
Definition at line 1228 of file PatternMatch.h.
Referenced by tryToMoveFreeBeforeNullTest().
|
inline |
Match an arbitrary undef constant.
Definition at line 87 of file PatternMatch.h.
Referenced by llvm::ConstantFoldBinaryInstruction(), foldICmpShlOne(), foldVectorCmp(), markAliveBlocks(), narrowVectorSelect(), shouldMergeGEPs(), SimplifyAddInst(), SimplifyAndInst(), simplifyBinaryIntrinsic(), simplifyDivRem(), SimplifyInsertValueInst(), simplifyIntrinsic(), SimplifyMulInst(), SimplifyOrInst(), SimplifyRightShift(), SimplifyShlInst(), SimplifySubInst(), SimplifyXorInst(), and llvm::InstCombiner::visitCallInst().
|
inline |
Match an 'unordered' floating point maximum function.
Floating point has one special value 'NaN'. Therefore, there is no total order. However, if we can ignore the 'NaN' value (for example, because of a 'no-nans-float-math' flag) a combination of a fcmp and select has 'maximum' semantics. In the presence of 'NaN' we have to preserve the original select(fcmp(ugt/ge, L, R), L, R) semantics matched by this predicate.
max(L, R) iff L and R are not NaN
m_UnordFMax(L, R) = L iff L or R are NaN
Definition at line 1416 of file PatternMatch.h.
Referenced by createRdxShuffleMask(), getReductionData(), llvm::RecurrenceDescriptor::isMinMaxSelectCmpPattern(), and matchFastFloatClamp().
|
inline |
Match an 'unordered' floating point minimum function.
Floating point has one special value 'NaN'. Therefore, there is no total order. However, if we can ignore the 'NaN' value (for example, because of a 'no-nans-float-math' flag) a combination of a fcmp and select has 'minimum' semantics. In the presence of 'NaN' we have to preserve the original select(fcmp(ult/le, L, R), L, R) semantics matched by this predicate.
min(L, R) iff L and R are not NaN
m_UnordFMin(L, R) = L iff L or R are NaN
Definition at line 1431 of file PatternMatch.h.
Referenced by createRdxShuffleMask(), getReductionData(), llvm::RecurrenceDescriptor::isMinMaxSelectCmpPattern(), and matchFastFloatClamp().
|
inline |
Definition at line 731 of file PatternMatch.h.
Referenced by llvm::InstCombiner::commonIDivTransforms(), MatchRem(), simplifyDiv(), simplifyICmpWithBinOp(), and simplifyRem().
|
inline |
Match an arbitrary value and ignore it.
Definition at line 71 of file PatternMatch.h.
Referenced by areInverseVectorBitmasks(), buildMultiplyTree(), canAlwaysEvaluateInType(), canEvaluateShifted(), canNarrowShiftAmt(), llvm::CannotBeNegativeZero(), canonicalizeLowbitMask(), canonicalizeSaturatedSubtract(), cheapToScalarize(), checkForNegativeOperand(), llvm::collectCmpOps(), combineLoadToNewType(), CombineUAddWithOverflow(), llvm::InstCombiner::commonIDivTransforms(), llvm::InstCombiner::commonShiftTransforms(), computeKnownBitsFromAssume(), computeKnownBitsFromOperator(), llvm::JumpThreadingPass::ComputeValueKnownInPredecessorsImpl(), countToEliminateCompares(), createAndInstr(), createRdxShuffleMask(), llvm::createSeparateConstOffsetFromGEPPass(), llvm::decomposeBitTestICmp(), EvaluateConstantChrecAtConstant(), factorizeFAddFSub(), llvm::SelectionDAGBuilder::FindMergedConditions(), llvm::findScalarElement(), foldAndOrOfEqualityCmpsWithConstants(), foldAndToXor(), foldAnyOrAllBitsSet(), foldBitCastBitwiseLogic(), foldBitcastExtElt(), foldBitCastSelect(), foldFabsWithFcmpZero(), foldFDivConstantDividend(), foldFDivConstantDivisor(), foldGuardedRotateToFunnelShift(), foldICmpShlOne(), foldICmpWithHighBitMask(), foldICmpWithLowBitMaskedVal(), foldICmpWithMinMax(), foldICmpWithTruncSignExtendedVal(), foldIdentityExtractShuffle(), foldLogicCastConstant(), foldOrToXor(), foldSelectBinOpIdentity(), foldSelectICmpAnd(), foldSelectICmpAndAnd(), foldSelectICmpAndOr(), foldSelectShuffle(), foldSelectWithBinaryOp(), llvm::InstCombiner::FoldShiftByConstant(), foldShuffleWithInsert(), foldSignedTruncationCheck(), foldUDivShl(), foldVectorCmp(), foldVecTruncToExtElt(), foldXorToXor(), getBinOpsForFactorization(), llvm::getComplexity(), GetConstantInt(), GetLoopInvariantInsertPosition(), getMaskedTypeForICmpPair(), getRangeForAffineARHelper(), getReductionData(), getSelectFoldableConstant(), getSqrtCall(), hasOnlyOneNonZeroIndex(), llvm::haveNoCommonBitsSet(), hoistInsEltConst(), llvm::RecurrenceDescriptor::isConditionalRdxPattern(), llvm::IsFreeToInvert(), isGEPFoldable(), llvm::isImpliedByDomCondition(), isImpliedCondAndOr(), llvm::isKnownNegation(), isKnownNonZero(), IsKnownPredicateViaMinOrMax(), isKnownToBeAPowerOfTwo(), llvm::ScalarEvolution::isLoopInvariantPredicate(), llvm::RecurrenceDescriptor::isMinMaxSelectCmpPattern(), isMinMaxWithLoads(), IsNarrowSequence(), isObjectDereferencedInBlock(), isOnlyReachableViaThisEdge(), isReassociableOp(), isTruePredicate(), LinearizeExprTree(), llvm::PatternMatch::UAddWithOverflow_match< LHS_t, RHS_t, Sum_t >::match(), llvm::PatternMatch::Signum_match< Opnd_t >::match(), matchAndOrChain(), matchDeMorgansLaws(), MatchDiv(), matchesAdd(), matchesOr(), MatchMul(), MatchRem(), matchRotate(), narrowUDivURem(), narrowVectorSelect(), NegateValue(), OptimizeAndOrXor(), optimizeTrigReflections(), processUGT_ADDCST_ADD(), processUMulZExtIdiom(), recordCondition(), removeBitcastsFromLoadStoreOnMinMax(), replaceAllUsesOfWithIn(), llvm::InstCombiner::replacedSelectWithOperand(), llvm::LoopPredicationPass::run(), scaleWeights(), llvm::FastISel::selectFNeg(), ShouldBreakUpSubtract(), shouldMergeGEPs(), ShrinkDemandedConstant(), SimplifyAddInst(), SimplifyAndInst(), simplifyAndOfICmpsWithAdd(), simplifyAndOfICmpsWithSameOperands(), simplifyAndOrOfICmpsWithZero(), SimplifyAShrInst(), simplifyAssocCastAssoc(), SimplifyBSwap(), simplifyDiv(), simplifyDivRem(), SimplifyFAddInst(), SimplifyFDivInst(), SimplifyFMulInst(), SimplifyFSubInst(), SimplifyGEPInst(), simplifyICmpWithBinOp(), simplifyICmpWithConstant(), simplifyICmpWithMinMax(), SimplifyLShrInst(), SimplifyMulInst(), SimplifyOrInst(), simplifyOrOfICmpsWithAdd(), simplifyOrOfICmpsWithSameOperands(), simplifyRem(), simplifySelectWithICmpCond(), SimplifyShift(), SimplifyShlInst(), SimplifySRemInst(), SimplifySubInst(), simplifyUnaryIntrinsic(), simplifyUnsignedRangeCheck(), simplifyValueKnownNonZero(), simplifyX86movmsk(), sinkNotIntoXor(), splitMergedValStore(), truncateIVUse(), unifyBitWidth(), llvm::AssumptionCache::updateAffectedValues(), llvm::InstCombiner::visitAdd(), llvm::InstCombiner::visitAnd(), llvm::InstCombiner::visitAShr(), llvm::InstCombiner::visitBranchInst(), llvm::InstCombiner::visitCallInst(), llvm::InstCombiner::visitExtractElementInst(), llvm::InstCombiner::visitFAdd(), llvm::InstCombiner::visitFCmpInst(), llvm::InstCombiner::visitFDiv(), llvm::InstCombiner::visitFMul(), llvm::InstCombiner::visitFPTrunc(), llvm::InstCombiner::visitFSub(), llvm::InstCombiner::visitGetElementPtrInst(), llvm::InstCombiner::visitICmpInst(), llvm::InstCombiner::visitInsertElementInst(), llvm::InstCombiner::visitLShr(), visitMaskedMerge(), llvm::InstCombiner::visitMul(), llvm::InstCombiner::visitOr(), llvm::InstCombiner::visitSDiv(), llvm::InstCombiner::visitSExt(), llvm::InstCombiner::visitShl(), llvm::InstCombiner::visitSub(), llvm::InstCombiner::visitSwitchInst(), llvm::InstCombiner::visitTrunc(), llvm::InstCombiner::visitUDiv(), visitUDivOperand(), llvm::InstCombiner::visitURem(), llvm::InstCombiner::visitXor(), and llvm::InstCombiner::visitZExt().
Match a value, capturing it if we match.
Definition at line 475 of file PatternMatch.h.
Definition at line 476 of file PatternMatch.h.
|
inline |
Definition at line 761 of file PatternMatch.h.
Referenced by areInverseVectorBitmasks(), canonicalizeSaturatedSubtract(), checkForNegativeOperand(), foldICmpWithMinMax(), foldXorToXor(), processUGT_ADDCST_ADD(), replaceAllUsesOfWithIn(), SimplifyAddInst(), SimplifyGEPInst(), SimplifyOrInst(), sinkNotIntoXor(), llvm::InstCombiner::visitAdd(), llvm::InstCombiner::visitAnd(), llvm::InstCombiner::visitCallInst(), llvm::InstCombiner::visitOr(), llvm::InstCombiner::visitSub(), llvm::InstCombiner::visitXor(), and llvm::InstCombiner::visitZExt().
|
inline |
Match any null constant or a vector with all elements equal to 0.
For vectors, this includes constants with undefined elements.
Definition at line 376 of file PatternMatch.h.
Referenced by areInverseVectorBitmasks(), canonicalizeICmpBool(), canonicalizeSaturatedSubtract(), llvm::ConstantFoldBinaryInstruction(), foldICmpWithMinMax(), foldSelectICmpAnd(), foldSelectICmpAndAnd(), foldSelectICmpAndOr(), foldSignedTruncationCheck(), foldXorToXor(), llvm::getGEPInductionOperand(), isKnownNonNullFromDominatingCondition(), markAliveBlocks(), matchMinMax(), processUGT_ADDCST_ADD(), replaceAllUsesOfWithIn(), shouldMergeGEPs(), SimplifyAddInst(), SimplifyAndInst(), simplifyAndOrOfICmpsWithZero(), simplifyBinaryIntrinsic(), simplifyDivRem(), llvm::InstCombiner::simplifyDivRemOfSelectWithZeroOp(), SimplifyGEPInst(), simplifyICmpOfBools(), simplifyICmpWithConstant(), simplifyICmpWithZero(), SimplifyMulInst(), SimplifyOrInst(), simplifySelectWithICmpCond(), SimplifyShift(), SimplifySubInst(), simplifyUnsignedRangeCheck(), SimplifyXorInst(), ThreadCmpOverSelect(), tryToMoveFreeBeforeNullTest(), llvm::InstCombiner::visitAdd(), llvm::InstCombiner::visitCallInst(), llvm::InstCombiner::visitICmpInst(), llvm::InstCombiner::visitPHINode(), llvm::InstCombiner::visitSDiv(), and llvm::InstCombiner::visitSub().
|
inline |
Match an integer 0 or a vector with all elements equal to 0.
For vectors, this includes constants with undefined elements.
Definition at line 364 of file PatternMatch.h.
Referenced by canonicalizeSaturatedSubtract(), foldGuardedRotateToFunnelShift(), llvm::isKnownNegation(), m_Neg(), matchSelectPattern(), llvm::InstCombiner::visitCallInst(), llvm::InstCombiner::visitSub(), and llvm::InstCombiner::visitZExt().
|
inline |
Matches ZExt.
Definition at line 1174 of file PatternMatch.h.
Referenced by canNarrowShiftAmt(), canonicalizeSaturatedSubtract(), checkForNegativeOperand(), foldICmpWithMinMax(), foldLogicCastConstant(), foldUDivShl(), foldVecTruncToExtElt(), m_ZExtOrSExt(), narrowUDivURem(), replaceAllUsesOfWithIn(), shouldMergeGEPs(), simplifyDivRem(), simplifyICmpWithBinOp(), splitMergedValStore(), llvm::InstCombiner::visitAnd(), llvm::InstCombiner::visitAShr(), llvm::InstCombiner::visitCallInst(), llvm::InstCombiner::visitICmpInst(), llvm::InstCombiner::visitLShr(), llvm::InstCombiner::visitMul(), llvm::InstCombiner::visitShl(), llvm::InstCombiner::visitSub(), llvm::InstCombiner::visitTrunc(), and visitUDivOperand().
|
inline |
Definition at line 1181 of file PatternMatch.h.
References m_CombineOr(), m_SExt(), and m_ZExt().
Referenced by canAlwaysEvaluateInType(), foldVecTruncToExtElt(), IsNarrowSequence(), shouldMergeGEPs(), and llvm::InstCombiner::visitCallInst().
bool llvm::PatternMatch::match | ( | Val * | V, |
const Pattern & | P | ||
) |
Definition at line 48 of file PatternMatch.h.
References P.
Referenced by llvm::AliasSetTracker::add(), areInverseVectorBitmasks(), buildMultiplyTree(), canAlwaysEvaluateInType(), canEvaluateShifted(), canEvaluateShiftedShift(), canEvaluateTruncated(), canEvaluateZExtd(), canNarrowShiftAmt(), llvm::CannotBeNegativeZero(), canonicalizeICmpBool(), canonicalizeLowbitMask(), canonicalizeSaturatedSubtract(), llvm::canSinkOrHoistInst(), cheapToScalarize(), checkForNegativeOperand(), llvm::collectCmpOps(), combineInstructionsOverFunction(), combineLoadToNewType(), CombineUAddWithOverflow(), llvm::InstCombiner::commonIDivTransforms(), llvm::InstCombiner::commonIRemTransforms(), llvm::InstCombiner::commonShiftTransforms(), computeKnownBits(), computeKnownBitsFromAssume(), computeKnownBitsFromOperator(), ComputeNumSignBitsImpl(), llvm::JumpThreadingPass::ComputeValueKnownInPredecessorsImpl(), llvm::ConstantFoldBinaryInstruction(), countToEliminateCompares(), createAndInstr(), CreateLoadIns(), createRdxShuffleMask(), llvm::createSeparateConstOffsetFromGEPPass(), llvm::decomposeBitTestICmp(), despeculateCountZeros(), EvaluateConstantChrecAtConstant(), factorizeFAddFSub(), llvm::SelectionDAGBuilder::FindMergedConditions(), llvm::findScalarElement(), foldAndOrOfEqualityCmpsWithConstants(), foldAndToXor(), foldAnyOrAllBitsSet(), foldBitCastBitwiseLogic(), foldBitcastExtElt(), foldBitCastSelect(), foldConstantInsEltIntoShuffle(), foldCttzCtlz(), foldFabsWithFcmpZero(), foldFCmpReciprocalAndZero(), foldFDivConstantDividend(), foldFDivConstantDivisor(), foldGuardedRotateToFunnelShift(), foldICmpShlOne(), foldICmpWithHighBitMask(), foldICmpWithLowBitMaskedVal(), foldICmpWithMinMax(), foldICmpWithTruncSignExtendedVal(), foldIdentityExtractShuffle(), foldLogicCastConstant(), foldOrToXor(), foldSelectBinOpIdentity(), foldSelectICmpAnd(), foldSelectICmpAndAnd(), foldSelectICmpAndOr(), foldSelectShuffle(), foldSelectShuffleWith1Binop(), foldSelectWithBinaryOp(), llvm::InstCombiner::FoldShiftByConstant(), foldShiftedShift(), foldShuffleWithInsert(), foldSignedTruncationCheck(), foldUDivShl(), foldVectorCmp(), foldVecTruncToExtElt(), foldXorToXor(), llvm::itanium_demangle::ForwardTemplateReference::ForwardTemplateReference(), getAlternateBinop(), llvm::GCNTTIImpl::getArithmeticInstrCost(), getBinOpsForFactorization(), llvm::getComplexity(), GetConstantInt(), getDemandedBitsLHSMask(), llvm::getGEPInductionOperand(), getLogBase2(), GetLoopInvariantInsertPosition(), getMaskedTypeForICmpPair(), getPow(), getRangeForAffineARHelper(), getReductionData(), llvm::SCEVExpander::getRelatedExistingExpansion(), getSelectFoldableConstant(), getSqrtCall(), getValueFromICmpCondition(), hasOnlyOneNonZeroIndex(), llvm::haveNoCommonBitsSet(), hoistInsEltConst(), llvm::hoistRegion(), isAlwaysLive(), llvm::RecurrenceDescriptor::isConditionalRdxPattern(), isDivZero(), llvm::IsFreeToInvert(), isGEPFoldable(), llvm::isGuaranteedToTransferExecutionToSuccessor(), llvm::isGuard(), llvm::isImpliedByDomCondition(), isImpliedCondAndOr(), llvm::isKnownNegation(), isKnownNonNullFromDominatingCondition(), isKnownNonZero(), IsKnownPredicateViaMinOrMax(), isKnownToBeAPowerOfTwo(), llvm::ScalarEvolution::isLoopInvariantPredicate(), isLoopNeverExecuted(), isMinMaxWithLoads(), IsNarrowSequence(), isObjectDereferencedInBlock(), isOnlyReachableViaThisEdge(), isReassociableOp(), llvm::isSafeToSpeculativelyExecute(), isSelect01(), isSignedMinMaxClamp(), isTruePredicate(), LinearizeExprTree(), lookThroughAnd(), lookThroughCast(), MaintainNoSignedWrap(), markAliveBlocks(), llvm::FileCheckPattern::Match(), llvm::PatternMatch::MaxMin_match< CmpInst_t, LHS_t, RHS_t, Pred_t, Commutable >::match(), matchAndOrChain(), matchClamp(), matchDeMorgansLaws(), MatchDiv(), matchesAdd(), matchesOr(), matchFastFloatClamp(), matchMinMax(), matchMinMaxOfMinMax(), MatchMul(), MatchRem(), matchRotate(), matchSelectPattern(), llvm::AliasSet::mergeSetIn(), narrowUDivURem(), narrowVectorSelect(), NegateValue(), OptimizeAndOrXor(), optimizeTrigReflections(), PickMostRelevantLoop(), processUGT_ADDCST_ADD(), processUMulZExtIdiom(), recordCondition(), llvm::AssumptionCache::registerAssumption(), removeBitcastsFromLoadStoreOnMinMax(), replaceAllUsesOfWithIn(), llvm::InstCombiner::replacedSelectWithOperand(), llvm::LoopPredicationPass::run(), scaleWeights(), llvm::FastISel::selectFNeg(), setLimitsForBinOp(), setLimitsForIntrinsic(), ShouldBreakUpSubtract(), shouldMergeGEPs(), ShrinkDemandedConstant(), SimplifyAddInst(), SimplifyAndInst(), simplifyAndOfICmpsWithAdd(), simplifyAndOfICmpsWithSameOperands(), simplifyAndOrOfICmpsWithConstants(), simplifyAndOrOfICmpsWithZero(), SimplifyAShrInst(), simplifyAssocCastAssoc(), simplifyBinaryIntrinsic(), SimplifyBSwap(), simplifyDiv(), simplifyDivRem(), llvm::InstCombiner::simplifyDivRemOfSelectWithZeroOp(), SimplifyFAddInst(), SimplifyFCmpInst(), SimplifyFDivInst(), SimplifyFMulInst(), simplifyFPBinop(), SimplifyFRemInst(), SimplifyFSubInst(), SimplifyGEPInst(), simplifyICmpOfBools(), simplifyICmpWithAbsNabs(), simplifyICmpWithBinOp(), simplifyICmpWithConstant(), simplifyICmpWithMinMax(), simplifyICmpWithZero(), SimplifyInsertValueInst(), simplifyIntrinsic(), SimplifyLShrInst(), SimplifyMulInst(), SimplifyOrInst(), simplifyOrOfICmpsWithAdd(), simplifyOrOfICmpsWithSameOperands(), simplifyRem(), SimplifyRightShift(), simplifySelectBitTest(), simplifySelectWithFCmp(), simplifySelectWithICmpCond(), SimplifyShift(), SimplifyShlInst(), SimplifySRemInst(), SimplifySubInst(), simplifyUnaryIntrinsic(), simplifyUnsignedRangeCheck(), simplifyValueKnownNonZero(), simplifyX86movmsk(), SimplifyXorInst(), sinkNotIntoXor(), splitMergedValStore(), swapMayExposeCSEOpportunities(), ThreadCmpOverSelect(), truncateIVUse(), tryToMoveFreeBeforeNullTest(), unifyBitWidth(), llvm::AssumptionCache::updateAffectedValues(), llvm::AssumptionCacheTracker::verifyAnalysis(), llvm::InstCombiner::visitAdd(), llvm::InstCombiner::visitAnd(), llvm::InstCombiner::visitAShr(), llvm::InstCombiner::visitBranchInst(), llvm::InstCombiner::visitCallInst(), llvm::InstCombiner::visitExtractElementInst(), llvm::InstCombiner::visitFAdd(), llvm::InstCombiner::visitFCmpInst(), llvm::InstCombiner::visitFDiv(), llvm::InstCombiner::visitFMul(), llvm::InstCombiner::visitFPTrunc(), llvm::InstCombiner::visitFSub(), llvm::InstCombiner::visitGetElementPtrInst(), llvm::InstCombiner::visitICmpInst(), llvm::InstCombiner::visitInsertElementInst(), llvm::InstCombiner::visitLShr(), visitMaskedMerge(), llvm::InstCombiner::visitMul(), llvm::InstCombiner::visitOr(), llvm::InstCombiner::visitPHINode(), llvm::InstCombiner::visitSDiv(), llvm::InstCombiner::visitSExt(), llvm::InstCombiner::visitShl(), llvm::InstCombiner::visitSRem(), llvm::InstCombiner::visitSub(), llvm::InstCombiner::visitSwitchInst(), llvm::InstCombiner::visitTrunc(), llvm::InstCombiner::visitUDiv(), visitUDivOperand(), llvm::InstCombiner::visitURem(), llvm::InstCombiner::visitXor(), llvm::InstCombiner::visitZExt(), and llvm::reassociate::XorOpnd::XorOpnd().