LLVM API Documentation
#include "llvm/Analysis/InstructionSimplify.h"
#include "llvm/ADT/SetVector.h"
#include "llvm/ADT/Statistic.h"
#include "llvm/Analysis/ConstantFolding.h"
#include "llvm/Analysis/MemoryBuiltins.h"
#include "llvm/Analysis/ValueTracking.h"
#include "llvm/IR/ConstantRange.h"
#include "llvm/IR/DataLayout.h"
#include "llvm/IR/Dominators.h"
#include "llvm/IR/GetElementPtrTypeIterator.h"
#include "llvm/IR/GlobalAlias.h"
#include "llvm/IR/Operator.h"
#include "llvm/IR/PatternMatch.h"
#include "llvm/IR/ValueHandle.h"
Go to the source code of this file.
Defines | |
#define | DEBUG_TYPE "instsimplify" |
Enumerations | |
enum | { RecursionLimit = 3 } |
Functions | |
STATISTIC (NumExpand,"Number of expansions") | |
STATISTIC (NumReassoc,"Number of reassociations") | |
static Value * | SimplifyAndInst (Value *, Value *, const Query &, unsigned) |
static Value * | SimplifyBinOp (unsigned, Value *, Value *, const Query &, unsigned) |
static Value * | SimplifyCmpInst (unsigned, Value *, Value *, const Query &, unsigned) |
static Value * | SimplifyOrInst (Value *, Value *, const Query &, unsigned) |
static Value * | SimplifyXorInst (Value *, Value *, const Query &, unsigned) |
static Value * | SimplifyTruncInst (Value *, Type *, const Query &, unsigned) |
static Constant * | getFalse (Type *Ty) |
static Constant * | getTrue (Type *Ty) |
static bool | isSameCompare (Value *V, CmpInst::Predicate Pred, Value *LHS, Value *RHS) |
isSameCompare - Is V equivalent to the comparison "LHS Pred RHS"? | |
static bool | ValueDominatesPHI (Value *V, PHINode *P, const DominatorTree *DT) |
ValueDominatesPHI - Does the given value dominate the specified phi node? | |
static Value * | ExpandBinOp (unsigned Opcode, Value *LHS, Value *RHS, unsigned OpcToExpand, const Query &Q, unsigned MaxRecurse) |
static Value * | SimplifyAssociativeBinOp (unsigned Opc, Value *LHS, Value *RHS, const Query &Q, unsigned MaxRecurse) |
static Value * | ThreadBinOpOverSelect (unsigned Opcode, Value *LHS, Value *RHS, const Query &Q, unsigned MaxRecurse) |
static Value * | ThreadCmpOverSelect (CmpInst::Predicate Pred, Value *LHS, Value *RHS, const Query &Q, unsigned MaxRecurse) |
static Value * | ThreadBinOpOverPHI (unsigned Opcode, Value *LHS, Value *RHS, const Query &Q, unsigned MaxRecurse) |
static Value * | ThreadCmpOverPHI (CmpInst::Predicate Pred, Value *LHS, Value *RHS, const Query &Q, unsigned MaxRecurse) |
static Value * | SimplifyAddInst (Value *Op0, Value *Op1, bool isNSW, bool isNUW, const Query &Q, unsigned MaxRecurse) |
static Constant * | stripAndComputeConstantOffsets (const DataLayout *DL, Value *&V, bool AllowNonInbounds=false) |
Compute the base pointer and cumulative constant offsets for V. | |
static Constant * | computePointerDifference (const DataLayout *DL, Value *LHS, Value *RHS) |
Compute the constant difference between two pointer values. If the difference is not a constant, returns zero. | |
static Value * | SimplifySubInst (Value *Op0, Value *Op1, bool isNSW, bool isNUW, const Query &Q, unsigned MaxRecurse) |
static Value * | SimplifyFAddInst (Value *Op0, Value *Op1, FastMathFlags FMF, const Query &Q, unsigned MaxRecurse) |
static Value * | SimplifyFSubInst (Value *Op0, Value *Op1, FastMathFlags FMF, const Query &Q, unsigned MaxRecurse) |
static Value * | SimplifyFMulInst (Value *Op0, Value *Op1, FastMathFlags FMF, const Query &Q, unsigned MaxRecurse) |
Given the operands for an FMul, see if we can fold the result. | |
static Value * | SimplifyMulInst (Value *Op0, Value *Op1, const Query &Q, unsigned MaxRecurse) |
static Value * | SimplifyDiv (Instruction::BinaryOps Opcode, Value *Op0, Value *Op1, const Query &Q, unsigned MaxRecurse) |
static Value * | SimplifySDivInst (Value *Op0, Value *Op1, const Query &Q, unsigned MaxRecurse) |
static Value * | SimplifyUDivInst (Value *Op0, Value *Op1, const Query &Q, unsigned MaxRecurse) |
static Value * | SimplifyFDivInst (Value *Op0, Value *Op1, const Query &Q, unsigned) |
static Value * | SimplifyRem (Instruction::BinaryOps Opcode, Value *Op0, Value *Op1, const Query &Q, unsigned MaxRecurse) |
static Value * | SimplifySRemInst (Value *Op0, Value *Op1, const Query &Q, unsigned MaxRecurse) |
static Value * | SimplifyURemInst (Value *Op0, Value *Op1, const Query &Q, unsigned MaxRecurse) |
static Value * | SimplifyFRemInst (Value *Op0, Value *Op1, const Query &, unsigned) |
static bool | isUndefShift (Value *Amount) |
isUndefShift - Returns true if a shift by Amount always yields undef. | |
static Value * | SimplifyShift (unsigned Opcode, Value *Op0, Value *Op1, const Query &Q, unsigned MaxRecurse) |
static Value * | SimplifyShlInst (Value *Op0, Value *Op1, bool isNSW, bool isNUW, const Query &Q, unsigned MaxRecurse) |
static Value * | SimplifyLShrInst (Value *Op0, Value *Op1, bool isExact, const Query &Q, unsigned MaxRecurse) |
static Value * | SimplifyAShrInst (Value *Op0, Value *Op1, bool isExact, const Query &Q, unsigned MaxRecurse) |
static Value * | SimplifyAndOfICmps (ICmpInst *Op0, ICmpInst *Op1) |
static Value * | SimplifyOrOfICmps (ICmpInst *Op0, ICmpInst *Op1) |
static Type * | GetCompareTy (Value *Op) |
static Value * | ExtractEquivalentCondition (Value *V, CmpInst::Predicate Pred, Value *LHS, Value *RHS) |
static Constant * | computePointerICmp (const DataLayout *DL, const TargetLibraryInfo *TLI, CmpInst::Predicate Pred, Value *LHS, Value *RHS) |
static Value * | SimplifyICmpInst (unsigned Predicate, Value *LHS, Value *RHS, const Query &Q, unsigned MaxRecurse) |
static Value * | SimplifyFCmpInst (unsigned Predicate, Value *LHS, Value *RHS, const Query &Q, unsigned MaxRecurse) |
static Value * | SimplifySelectInst (Value *CondVal, Value *TrueVal, Value *FalseVal, const Query &Q, unsigned MaxRecurse) |
static Value * | SimplifyGEPInst (ArrayRef< Value * > Ops, const Query &Q, unsigned) |
static Value * | SimplifyInsertValueInst (Value *Agg, Value *Val, ArrayRef< unsigned > Idxs, const Query &Q, unsigned) |
static Value * | SimplifyPHINode (PHINode *PN, const Query &Q) |
SimplifyPHINode - See if we can fold the given phi. If not, returns null. | |
static bool | IsIdempotent (Intrinsic::ID ID) |
template<typename IterTy > | |
static Value * | SimplifyIntrinsic (Intrinsic::ID IID, IterTy ArgBegin, IterTy ArgEnd, const Query &Q, unsigned MaxRecurse) |
template<typename IterTy > | |
static Value * | SimplifyCall (Value *V, IterTy ArgBegin, IterTy ArgEnd, const Query &Q, unsigned MaxRecurse) |
static bool | replaceAndRecursivelySimplifyImpl (Instruction *I, Value *SimpleV, const DataLayout *DL, const TargetLibraryInfo *TLI, const DominatorTree *DT, AssumptionTracker *AT) |
Implementation of recursive simplification through an instructions uses. |
#define DEBUG_TYPE "instsimplify" |
Definition at line 37 of file InstructionSimplify.cpp.
anonymous enum |
Definition at line 39 of file InstructionSimplify.cpp.
static Constant* computePointerDifference | ( | const DataLayout * | DL, |
Value * | LHS, | ||
Value * | RHS | ||
) | [static] |
Compute the constant difference between two pointer values. If the difference is not a constant, returns zero.
Definition at line 645 of file InstructionSimplify.cpp.
References llvm::ConstantExpr::getSub(), and stripAndComputeConstantOffsets().
Referenced by SimplifySubInst().
static Constant* computePointerICmp | ( | const DataLayout * | DL, |
const TargetLibraryInfo * | TLI, | ||
CmpInst::Predicate | Pred, | ||
Value * | LHS, | ||
Value * | RHS | ||
) | [static] |
Definition at line 1870 of file InstructionSimplify.cpp.
References llvm::dyn_cast(), llvm::ConstantInt::get(), llvm::ConstantExpr::getAdd(), GetCompareTy(), llvm::ConstantExpr::getICmp(), llvm::getObjectSize(), llvm::ICmpInst::getSignedPredicate(), llvm::Value::getType(), llvm::ConstantInt::getValue(), llvm::CmpInst::ICMP_EQ, llvm::CmpInst::ICMP_NE, llvm::CmpInst::ICMP_UGE, llvm::CmpInst::ICMP_UGT, llvm::CmpInst::ICMP_ULE, llvm::CmpInst::ICMP_ULT, llvm::isKnownNonNull(), llvm::APInt::isNegative(), llvm::Constant::isNullValue(), llvm::ISD::isTrueWhenEqual(), llvm::CmpInst::isTrueWhenEqual(), stripAndComputeConstantOffsets(), llvm::Value::stripPointerCasts(), and llvm::APInt::ult().
Referenced by SimplifyICmpInst().
static Value* ExpandBinOp | ( | unsigned | Opcode, |
Value * | LHS, | ||
Value * | RHS, | ||
unsigned | OpcToExpand, | ||
const Query & | Q, | ||
unsigned | MaxRecurse | ||
) | [static] |
ExpandBinOp - Simplify "A op (B op' C)" by distributing op over op', turning it into "(A op B) op' (A op C)". Here "op" is given by Opcode and "op'" is given by OpcodeToExpand, while "A" corresponds to LHS and "B op' C" to RHS. Also performs the transform "(A op' B) op C" -> "(A op C) op' (B op C)". Returns the simplified value, or null if no simplification was performed.
Definition at line 134 of file InstructionSimplify.cpp.
References llvm::ARM_PROC::A, llvm::CallingConv::C, llvm::Instruction::isCommutative(), and llvm::SimplifyBinOp().
Referenced by SimplifyAndInst(), SimplifyMulInst(), and SimplifyOrInst().
static Value* ExtractEquivalentCondition | ( | Value * | V, |
CmpInst::Predicate | Pred, | ||
Value * | LHS, | ||
Value * | RHS | ||
) | [static] |
ExtractEquivalentCondition - Rummage around inside V looking for something equivalent to the comparison "LHS Pred RHS". Return such a value if found, otherwise return null. Helper function for analyzing max/min idioms.
Definition at line 1825 of file InstructionSimplify.cpp.
References llvm::dyn_cast(), llvm::SelectInst::getCondition(), llvm::User::getOperand(), llvm::CmpInst::getPredicate(), and llvm::CmpInst::getSwappedPredicate().
Referenced by SimplifyICmpInst().
static Type* GetCompareTy | ( | Value * | Op | ) | [static] |
Definition at line 1818 of file InstructionSimplify.cpp.
References llvm::Value::getType(), and llvm::CmpInst::makeCmpResultType().
Referenced by computePointerICmp(), SimplifyFCmpInst(), and SimplifyICmpInst().
getFalse - For a boolean type, or a vector of boolean type, return false, or a vector with every element false, as appropriate for the type.
Definition at line 70 of file InstructionSimplify.cpp.
References llvm::Constant::getNullValue(), llvm::Type::getScalarType(), and llvm::Type::isIntegerTy().
Referenced by SimplifyAndOfICmps(), SimplifyFCmpInst(), SimplifyICmpInst(), ThreadCmpOverSelect(), and TryToSimplifyUncondBranchWithICmpInIt().
getTrue - For a boolean type, or a vector of boolean type, return true, or a vector with every element true, as appropriate for the type.
Definition at line 78 of file InstructionSimplify.cpp.
References llvm::Constant::getAllOnesValue(), llvm::Type::getScalarType(), and llvm::Type::isIntegerTy().
Referenced by computeKnownBits(), getFCmpValue(), SimplifyFCmpInst(), SimplifyICmpInst(), SimplifyOrOfICmps(), ThreadCmpOverSelect(), and TryToSimplifyUncondBranchWithICmpInIt().
static bool IsIdempotent | ( | Intrinsic::ID | ID | ) | [static] |
Definition at line 3293 of file InstructionSimplify.cpp.
References llvm::LibFunc::ceil, llvm::LibFunc::fabs, llvm::LibFunc::floor, llvm::LibFunc::nearbyint, llvm::LibFunc::rint, llvm::LibFunc::round, and llvm::LibFunc::trunc.
Referenced by SimplifyIntrinsic().
static bool isSameCompare | ( | Value * | V, |
CmpInst::Predicate | Pred, | ||
Value * | LHS, | ||
Value * | RHS | ||
) | [static] |
isSameCompare - Is V equivalent to the comparison "LHS Pred RHS"?
Definition at line 85 of file InstructionSimplify.cpp.
References llvm::dyn_cast(), llvm::User::getOperand(), llvm::CmpInst::getPredicate(), and llvm::PPC::getSwappedPredicate().
Referenced by ThreadCmpOverSelect().
static bool isUndefShift | ( | Value * | Amount | ) | [static] |
isUndefShift - Returns true if a shift by Amount
always yields undef.
Definition at line 1257 of file InstructionSimplify.cpp.
References llvm::CallingConv::C, llvm::dyn_cast(), llvm::Constant::getAggregateElement(), llvm::Value::getType(), llvm::Type::getVectorNumElements(), and I.
Referenced by SimplifyShift().
static bool replaceAndRecursivelySimplifyImpl | ( | Instruction * | I, |
Value * | SimpleV, | ||
const DataLayout * | DL, | ||
const TargetLibraryInfo * | TLI, | ||
const DominatorTree * | DT, | ||
AssumptionTracker * | AT | ||
) | [static] |
Implementation of recursive simplification through an instructions uses.
This is the common implementation of the recursive simplification routines. If we have a pre-simplified value in 'SimpleV', that is forcibly used to replace the instruction 'I'. Otherwise, we simply add 'I' to the list of instructions to process and attempt to simplify it using InstructionSimplify.
This routine returns 'true' only when *it* simplifies something. The passed in simplified value does not count toward this.
Definition at line 3528 of file InstructionSimplify.cpp.
References llvm::Instruction::eraseFromParent(), llvm::Instruction::getParent(), llvm::SetVector< T, SmallVector< T, N >, SmallSet< T, N > >::insert(), llvm::Value::replaceAllUsesWith(), llvm::JumpTable::Simplified, llvm::SimplifyInstruction(), llvm::SetVector< T, SmallVector< T, N >, SmallSet< T, N > >::size(), and llvm::Value::users().
Referenced by llvm::recursivelySimplifyInstruction(), and llvm::replaceAndRecursivelySimplify().
static Value* SimplifyAddInst | ( | Value * | Op0, |
Value * | Op1, | ||
bool | isNSW, | ||
bool | isNUW, | ||
const Query & | Q, | ||
unsigned | MaxRecurse | ||
) | [static] |
SimplifyAddInst - Given operands for an Add, see if we can fold the result. If not, this returns null.
i1 add -> xor.
Definition at line 526 of file InstructionSimplify.cpp.
References llvm::ConstantFoldInstOperands(), llvm::Constant::getAllOnesValue(), llvm::Value::getType(), llvm::Type::isIntegerTy(), llvm::PatternMatch::m_Not(), llvm::PatternMatch::m_Specific(), llvm::PatternMatch::m_Sub(), llvm::PatternMatch::m_Undef(), llvm::PatternMatch::m_Value(), llvm::PatternMatch::m_Zero(), llvm::PatternMatch::match(), SimplifyAssociativeBinOp(), llvm::SimplifyXorInst(), std::swap(), and Y.
static Value * SimplifyAndInst | ( | Value * | Op0, |
Value * | Op1, | ||
const Query & | Q, | ||
unsigned | MaxRecurse | ||
) | [static] |
SimplifyAndInst - Given operands for an And, see if we can fold the result. If not, this returns null.
Definition at line 1474 of file InstructionSimplify.cpp.
References llvm::ARM_PROC::A, llvm::APIntOps::And(), llvm::ConstantFoldInstOperands(), ExpandBinOp(), llvm::Constant::getNullValue(), llvm::Value::getType(), llvm::isKnownToBeAPowerOfTwo(), llvm::PatternMatch::m_AllOnes(), llvm::PatternMatch::m_Neg(), llvm::PatternMatch::m_Not(), llvm::PatternMatch::m_Or(), llvm::PatternMatch::m_Specific(), llvm::PatternMatch::m_Undef(), llvm::PatternMatch::m_Value(), llvm::PatternMatch::m_Zero(), llvm::PatternMatch::match(), llvm::APIntOps::Or(), SimplifyAndOfICmps(), SimplifyAssociativeBinOp(), std::swap(), ThreadBinOpOverPHI(), ThreadBinOpOverSelect(), and llvm::APIntOps::Xor().
static Value* SimplifyAndOfICmps | ( | ICmpInst * | Op0, |
ICmpInst * | Op1 | ||
) | [static] |
Definition at line 1426 of file InstructionSimplify.cpp.
References getFalse(), llvm::User::getOperand(), llvm::Value::getType(), llvm::ConstantInt::getValue(), llvm::CmpInst::ICMP_SGT, llvm::CmpInst::ICMP_SLE, llvm::CmpInst::ICMP_SLT, llvm::CmpInst::ICMP_UGT, llvm::CmpInst::ICMP_ULE, llvm::CmpInst::ICMP_ULT, llvm::PatternMatch::m_Add(), llvm::PatternMatch::m_ConstantInt(), llvm::PatternMatch::m_ICmp(), llvm::PatternMatch::m_Specific(), llvm::PatternMatch::m_Value(), and llvm::PatternMatch::match().
Referenced by SimplifyAndInst().
static Value* SimplifyAShrInst | ( | Value * | Op0, |
Value * | Op1, | ||
bool | isExact, | ||
const Query & | Q, | ||
unsigned | MaxRecurse | ||
) | [static] |
SimplifyAShrInst - Given operands for an AShr, see if we can fold the result. If not, this returns null.
Definition at line 1383 of file InstructionSimplify.cpp.
References llvm::ComputeNumSignBits(), llvm::Constant::getAllOnesValue(), llvm::Constant::getNullValue(), llvm::Type::getScalarSizeInBits(), llvm::Value::getType(), llvm::PatternMatch::m_AllOnes(), llvm::PatternMatch::m_Shl(), llvm::PatternMatch::m_Specific(), llvm::PatternMatch::m_Undef(), llvm::PatternMatch::m_Value(), llvm::PatternMatch::match(), SimplifyShift(), and llvm::X.
static Value* SimplifyAssociativeBinOp | ( | unsigned | Opc, |
Value * | LHS, | ||
Value * | RHS, | ||
const Query & | Q, | ||
unsigned | MaxRecurse | ||
) | [static] |
SimplifyAssociativeBinOp - Generic simplifications for associative binary operations. Returns the simpler value, or null if none was found.
Definition at line 193 of file InstructionSimplify.cpp.
References llvm::ARM_PROC::A, llvm::CallingConv::C, llvm::dyn_cast(), llvm::BinaryOperator::getOpcode(), llvm::User::getOperand(), llvm::Instruction::isAssociative(), llvm::Instruction::isCommutative(), and llvm::SimplifyBinOp().
Referenced by SimplifyAddInst(), SimplifyAndInst(), SimplifyBinOp(), SimplifyMulInst(), SimplifyOrInst(), and SimplifyXorInst().
static Value * SimplifyBinOp | ( | unsigned | Opcode, |
Value * | LHS, | ||
Value * | RHS, | ||
const Query & | Q, | ||
unsigned | MaxRecurse | ||
) | [static] |
SimplifyBinOp - Given operands for a BinaryOperator, see if we can fold the result. If not, this returns null.
Definition at line 3205 of file InstructionSimplify.cpp.
References llvm::APIntOps::And(), llvm::ConstantFoldInstOperands(), llvm::Value::getType(), llvm::Instruction::isAssociative(), llvm::LShr, llvm::APIntOps::Or(), llvm::SimplifyAddInst(), llvm::SimplifyAndInst(), llvm::SimplifyAShrInst(), SimplifyAssociativeBinOp(), llvm::SimplifyFAddInst(), llvm::SimplifyFDivInst(), llvm::SimplifyFMulInst(), llvm::SimplifyFRemInst(), llvm::SimplifyFSubInst(), llvm::SimplifyLShrInst(), llvm::SimplifyMulInst(), llvm::SimplifyOrInst(), llvm::SimplifySDivInst(), llvm::SimplifyShlInst(), llvm::SimplifySRemInst(), llvm::SimplifySubInst(), llvm::SimplifyUDivInst(), llvm::SimplifyURemInst(), llvm::SimplifyXorInst(), ThreadBinOpOverPHI(), ThreadBinOpOverSelect(), and llvm::APIntOps::Xor().
static Value* SimplifyCall | ( | Value * | V, |
IterTy | ArgBegin, | ||
IterTy | ArgEnd, | ||
const Query & | Q, | ||
unsigned | MaxRecurse | ||
) | [static] |
Definition at line 3326 of file InstructionSimplify.cpp.
References llvm::CallingConv::C, llvm::canConstantFoldCallTo(), llvm::ConstantFoldCall(), llvm::dyn_cast(), F(), llvm::UndefValue::get(), llvm::Function::getIntrinsicID(), llvm::FunctionType::getReturnType(), llvm::Value::getType(), I, llvm::SmallVectorTemplateBase< T, isPodLike< T >::value >::push_back(), llvm::SmallVectorImpl< T >::reserve(), llvm::MipsISD::Ret, and SimplifyIntrinsic().
static Value * SimplifyCmpInst | ( | unsigned | Predicate, |
Value * | LHS, | ||
Value * | RHS, | ||
const Query & | Q, | ||
unsigned | MaxRecurse | ||
) | [static] |
SimplifyCmpInst - Given operands for a CmpInst, see if we can fold the result.
Definition at line 3278 of file InstructionSimplify.cpp.
References llvm::CmpInst::isIntPredicate(), llvm::SimplifyFCmpInst(), and llvm::SimplifyICmpInst().
static Value* SimplifyDiv | ( | Instruction::BinaryOps | Opcode, |
Value * | Op0, | ||
Value * | Op1, | ||
const Query & | Q, | ||
unsigned | MaxRecurse | ||
) | [static] |
SimplifyDiv - Given operands for an SDiv or UDiv, see if we can fold the result. If not, this returns null.
Definition at line 1005 of file InstructionSimplify.cpp.
References llvm::ConstantFoldInstOperands(), llvm::ConstantInt::get(), llvm::Constant::getNullValue(), llvm::Value::getType(), llvm::OverflowingBinaryOperator::hasNoSignedWrap(), llvm::OverflowingBinaryOperator::hasNoUnsignedWrap(), llvm::Type::isIntegerTy(), llvm::PatternMatch::m_Mul(), llvm::PatternMatch::m_One(), llvm::PatternMatch::m_Specific(), llvm::PatternMatch::m_SRem(), llvm::PatternMatch::m_Undef(), llvm::PatternMatch::m_URem(), llvm::PatternMatch::m_Value(), llvm::PatternMatch::m_Zero(), llvm::PatternMatch::match(), std::swap(), ThreadBinOpOverPHI(), ThreadBinOpOverSelect(), llvm::X, and Y.
Referenced by SimplifySDivInst(), and SimplifyUDivInst().
static Value* SimplifyFAddInst | ( | Value * | Op0, |
Value * | Op1, | ||
FastMathFlags | FMF, | ||
const Query & | Q, | ||
unsigned | MaxRecurse | ||
) | [static] |
Given operands for an FAdd, see if we can fold the result. If not, this returns null.
Definition at line 799 of file InstructionSimplify.cpp.
References llvm::CannotBeNegativeZero(), llvm::ConstantFoldInstOperands(), llvm::Constant::getNullValue(), llvm::Value::getType(), llvm::Instruction::hasNoInfs(), llvm::Instruction::hasNoNaNs(), llvm::PatternMatch::m_AnyZero(), llvm::PatternMatch::m_FSub(), llvm::PatternMatch::m_NegZero(), llvm::PatternMatch::m_Specific(), llvm::PatternMatch::m_Zero(), llvm::PatternMatch::match(), llvm::FastMathFlags::noInfs(), llvm::FastMathFlags::noNaNs(), llvm::FastMathFlags::noSignedZeros(), and std::swap().
static Value* SimplifyFCmpInst | ( | unsigned | Predicate, |
Value * | LHS, | ||
Value * | RHS, | ||
const Query & | Q, | ||
unsigned | MaxRecurse | ||
) | [static] |
SimplifyFCmpInst - Given operands for an FCmpInst, see if we can fold the result. If not, this returns null.
Definition at line 2883 of file InstructionSimplify.cpp.
References llvm::ConstantFoldCompareInstOperands(), llvm::CmpInst::FCMP_FALSE, llvm::CmpInst::FCMP_OGT, llvm::CmpInst::FCMP_OLT, llvm::CmpInst::FCMP_TRUE, llvm::CmpInst::FCMP_UGE, llvm::CmpInst::FCMP_ULE, llvm::ConstantInt::get(), llvm::UndefValue::get(), GetCompareTy(), llvm::ConstantInt::getFalse(), getFalse(), llvm::PPC::getSwappedPredicate(), getTrue(), llvm::CmpInst::isFalseWhenEqual(), llvm::CmpInst::isFPPredicate(), llvm::CmpInst::isOrdered(), llvm::CmpInst::isTrueWhenEqual(), llvm::CmpInst::isUnordered(), std::swap(), ThreadCmpOverPHI(), and ThreadCmpOverSelect().
Definition at line 1113 of file InstructionSimplify.cpp.
References llvm::PatternMatch::m_Undef(), and llvm::PatternMatch::match().
static Value* SimplifyFMulInst | ( | Value * | Op0, |
Value * | Op1, | ||
FastMathFlags | FMF, | ||
const Query & | Q, | ||
unsigned | MaxRecurse | ||
) | [static] |
Given the operands for an FMul, see if we can fold the result.
Definition at line 877 of file InstructionSimplify.cpp.
References llvm::ConstantFoldInstOperands(), llvm::PatternMatch::m_AnyZero(), llvm::PatternMatch::m_FPOne(), llvm::PatternMatch::match(), llvm::FastMathFlags::noNaNs(), llvm::FastMathFlags::noSignedZeros(), and std::swap().
Definition at line 1234 of file InstructionSimplify.cpp.
References llvm::PatternMatch::m_Undef(), and llvm::PatternMatch::match().
static Value* SimplifyFSubInst | ( | Value * | Op0, |
Value * | Op1, | ||
FastMathFlags | FMF, | ||
const Query & | Q, | ||
unsigned | MaxRecurse | ||
) | [static] |
Given operands for an FSub, see if we can fold the result. If not, this returns null.
Definition at line 841 of file InstructionSimplify.cpp.
References llvm::CannotBeNegativeZero(), llvm::ConstantFoldInstOperands(), llvm::Constant::getNullValue(), llvm::Value::getType(), llvm::PatternMatch::m_AnyZero(), llvm::PatternMatch::m_FSub(), llvm::PatternMatch::m_NegZero(), llvm::PatternMatch::m_Value(), llvm::PatternMatch::m_Zero(), llvm::PatternMatch::match(), llvm::FastMathFlags::noInfs(), llvm::FastMathFlags::noNaNs(), llvm::FastMathFlags::noSignedZeros(), and llvm::X.
SimplifyGEPInst - Given operands for an GetElementPtrInst, see if we can fold the result. If not, this returns null.
Definition at line 3023 of file InstructionSimplify.cpp.
References llvm::CallingConv::C, llvm::VectorType::get(), llvm::PointerType::get(), llvm::UndefValue::get(), llvm::PointerType::getAddressSpace(), llvm::SequentialType::getElementType(), llvm::ConstantExpr::getGetElementPtr(), llvm::GetElementPtrInst::getIndexedType(), llvm::Constant::getNullValue(), llvm::Intrinsic::getType(), llvm::Value::getType(), llvm::Type::isSized(), llvm::PatternMatch::m_AShr(), llvm::PatternMatch::m_ConstantInt(), llvm::PatternMatch::m_PtrToInt(), llvm::PatternMatch::m_SDiv(), llvm::PatternMatch::m_Specific(), llvm::PatternMatch::m_SpecificInt(), llvm::PatternMatch::m_Sub(), llvm::PatternMatch::m_Value(), llvm::PatternMatch::m_Zero(), llvm::PatternMatch::match(), P, llvm::ArrayRef< T >::size(), and llvm::ArrayRef< T >::slice().
static Value* SimplifyICmpInst | ( | unsigned | Predicate, |
Value * | LHS, | ||
Value * | RHS, | ||
const Query & | Q, | ||
unsigned | MaxRecurse | ||
) | [static] |
SimplifyICmpInst - Given operands for an ICmpInst, see if we can fold the result. If not, this returns null.
Definition at line 1998 of file InstructionSimplify.cpp.
References llvm::ARM_PROC::A, llvm::APInt::abs(), llvm::APInt::ashr(), llvm::CmpInst::BAD_ICMP_PREDICATE, llvm::CallingConv::C, llvm::computeKnownBits(), computePointerICmp(), llvm::ComputeSignBit(), llvm::ConstantFoldCompareInstOperands(), llvm::ConstantRange::contains(), llvm::APInt::countLeadingOnes(), llvm::APInt::countLeadingZeros(), llvm::APInt::countTrailingZeros(), llvm::dyn_cast(), ExtractEquivalentCondition(), llvm::ConstantInt::get(), llvm::APInt::getAllOnesValue(), llvm::ConstantInt::getBitWidth(), llvm::ConstantExpr::getCast(), GetCompareTy(), llvm::Value::getContext(), llvm::ConstantInt::getFalse(), getFalse(), llvm::ConstantExpr::getGetElementPtr(), llvm::ConstantExpr::getICmp(), llvm::ConstantExpr::getIntToPtr(), llvm::CmpInst::getInversePredicate(), llvm::Constant::getNullValue(), llvm::BinaryOperator::getOpcode(), llvm::User::getOperand(), llvm::Type::getPrimitiveSizeInBits(), llvm::Type::getScalarType(), llvm::APInt::getSignedMaxValue(), llvm::APInt::getSignedMinValue(), llvm::ICmpInst::getSignedPredicate(), llvm::PPC::getSwappedPredicate(), llvm::ConstantInt::getTrue(), getTrue(), llvm::ConstantExpr::getTrunc(), llvm::Value::getType(), llvm::ICmpInst::getUnsignedPredicate(), llvm::ConstantInt::getValue(), llvm::BinaryOperator::hasNoSignedWrap(), llvm::BinaryOperator::hasNoUnsignedWrap(), llvm::CmpInst::ICMP_EQ, llvm::CmpInst::ICMP_NE, llvm::CmpInst::ICMP_SGE, llvm::CmpInst::ICMP_SGT, llvm::CmpInst::ICMP_SLE, llvm::CmpInst::ICMP_SLT, llvm::CmpInst::ICMP_UGE, llvm::CmpInst::ICMP_UGT, llvm::CmpInst::ICMP_ULE, llvm::CmpInst::ICMP_ULT, llvm::ConstantRange::inverse(), llvm::APInt::isAllOnesValue(), llvm::ConstantRange::isEmptySet(), llvm::ICmpInst::isEquality(), llvm::BinaryOperator::isExact(), llvm::ConstantRange::isFullSet(), llvm::Type::isIntegerTy(), llvm::CmpInst::isIntPredicate(), llvm::isKnownNonZero(), llvm::Constant::isMinSignedValue(), llvm::ConstantInt::isNegative(), llvm::Type::isPointerTy(), llvm::APInt::isPowerOf2(), llvm::APInt::isSignBit(), llvm::CmpInst::isSigned(), llvm::CmpInst::isTrueWhenEqual(), llvm::CmpInst::isUnsigned(), llvm::ConstantInt::isZero(), LI, llvm_unreachable, llvm::LShr, llvm::APInt::lshr(), llvm::PatternMatch::m_And(), llvm::PatternMatch::m_APInt(), llvm::PatternMatch::m_AShr(), llvm::PatternMatch::m_ConstantInt(), llvm::PatternMatch::m_LShr(), llvm::PatternMatch::m_Neg(), llvm::PatternMatch::m_NSWShl(), llvm::PatternMatch::m_NUWShl(), llvm::PatternMatch::m_One(), llvm::PatternMatch::m_Or(), llvm::PatternMatch::m_SDiv(), llvm::PatternMatch::m_Shl(), llvm::PatternMatch::m_SMax(), llvm::PatternMatch::m_SMin(), llvm::PatternMatch::m_Specific(), llvm::PatternMatch::m_SRem(), llvm::PatternMatch::m_UDiv(), llvm::PatternMatch::m_UMax(), llvm::PatternMatch::m_UMin(), llvm::PatternMatch::m_URem(), llvm::PatternMatch::m_Value(), llvm::PatternMatch::m_Zero(), llvm::PatternMatch::m_ZExt(), llvm::ICmpInst::makeConstantRange(), llvm::PatternMatch::match(), P, llvm::APInt::sdiv(), llvm::SExt, llvm::APInt::sgt(), llvm::APInt::shl(), llvm::SimplifyICmpInst(), std::swap(), ThreadCmpOverPHI(), ThreadCmpOverSelect(), llvm::Trunc, llvm::APInt::udiv(), llvm::APInt::ult(), and Y.
static Value* SimplifyInsertValueInst | ( | Value * | Agg, |
Value * | Val, | ||
ArrayRef< unsigned > | Idxs, | ||
const Query & | Q, | ||
unsigned | |||
) | [static] |
SimplifyInsertValueInst - Given operands for an InsertValueInst, see if we can fold the result. If not, this returns null.
Definition at line 3112 of file InstructionSimplify.cpp.
References llvm::ConstantFoldInsertValueInstruction(), llvm::Value::getType(), llvm::PatternMatch::m_Undef(), and llvm::PatternMatch::match().
static Value* SimplifyIntrinsic | ( | Intrinsic::ID | IID, |
IterTy | ArgBegin, | ||
IterTy | ArgEnd, | ||
const Query & | Q, | ||
unsigned | MaxRecurse | ||
) | [static] |
Definition at line 3310 of file InstructionSimplify.cpp.
References IsIdempotent().
Referenced by SimplifyCall().
static Value* SimplifyLShrInst | ( | Value * | Op0, |
Value * | Op1, | ||
bool | isExact, | ||
const Query & | Q, | ||
unsigned | MaxRecurse | ||
) | [static] |
SimplifyLShrInst - Given operands for an LShr, see if we can fold the result. If not, this returns null.
Definition at line 1349 of file InstructionSimplify.cpp.
References llvm::Constant::getNullValue(), llvm::Value::getType(), llvm::LShr, llvm::PatternMatch::m_Shl(), llvm::PatternMatch::m_Specific(), llvm::PatternMatch::m_Undef(), llvm::PatternMatch::m_Value(), llvm::PatternMatch::match(), SimplifyShift(), and llvm::X.
static Value* SimplifyMulInst | ( | Value * | Op0, |
Value * | Op1, | ||
const Query & | Q, | ||
unsigned | MaxRecurse | ||
) | [static] |
SimplifyMulInst - Given operands for a Mul, see if we can fold the result. If not, this returns null.
Definition at line 905 of file InstructionSimplify.cpp.
References llvm::ConstantFoldInstOperands(), ExpandBinOp(), llvm::Constant::getNullValue(), llvm::Value::getType(), llvm::Type::isIntegerTy(), llvm::PatternMatch::m_Exact(), llvm::PatternMatch::m_IDiv(), llvm::PatternMatch::m_One(), llvm::PatternMatch::m_Specific(), llvm::PatternMatch::m_Undef(), llvm::PatternMatch::m_Value(), llvm::PatternMatch::m_Zero(), llvm::PatternMatch::match(), llvm::SimplifyAndInst(), SimplifyAssociativeBinOp(), std::swap(), ThreadBinOpOverPHI(), ThreadBinOpOverSelect(), and llvm::X.
static Value * SimplifyOrInst | ( | Value * | Op0, |
Value * | Op1, | ||
const Query & | Q, | ||
unsigned | MaxRecurse | ||
) | [static] |
SimplifyOrInst - Given operands for an Or, see if we can fold the result. If not, this returns null.
Definition at line 1627 of file InstructionSimplify.cpp.
References llvm::ARM_PROC::A, llvm::APIntOps::And(), llvm::CallingConv::C, llvm::ConstantFoldInstOperands(), llvm::dyn_cast(), ExpandBinOp(), llvm::Constant::getAllOnesValue(), llvm::Value::getType(), llvm::ConstantInt::getValue(), llvm::PatternMatch::m_Add(), llvm::PatternMatch::m_AllOnes(), llvm::PatternMatch::m_And(), llvm::PatternMatch::m_Not(), llvm::PatternMatch::m_Specific(), llvm::PatternMatch::m_Undef(), llvm::PatternMatch::m_Value(), llvm::PatternMatch::m_Zero(), llvm::MaskedValueIsZero(), llvm::PatternMatch::match(), llvm::APIntOps::Or(), SimplifyAssociativeBinOp(), SimplifyOrOfICmps(), std::swap(), ThreadBinOpOverPHI(), ThreadBinOpOverSelect(), and llvm::NVPTX::PTXLdStInstCode::V2.
static Value* SimplifyOrOfICmps | ( | ICmpInst * | Op0, |
ICmpInst * | Op1 | ||
) | [static] |
Definition at line 1579 of file InstructionSimplify.cpp.
References llvm::User::getOperand(), getTrue(), llvm::Value::getType(), llvm::ConstantInt::getValue(), llvm::CmpInst::ICMP_SGE, llvm::CmpInst::ICMP_SGT, llvm::CmpInst::ICMP_SLE, llvm::CmpInst::ICMP_UGE, llvm::CmpInst::ICMP_UGT, llvm::CmpInst::ICMP_ULE, llvm::PatternMatch::m_Add(), llvm::PatternMatch::m_ConstantInt(), llvm::PatternMatch::m_ICmp(), llvm::PatternMatch::m_Specific(), llvm::PatternMatch::m_Value(), and llvm::PatternMatch::match().
Referenced by SimplifyOrInst().
static Value* SimplifyPHINode | ( | PHINode * | PN, |
const Query & | Q | ||
) | [static] |
SimplifyPHINode - See if we can fold the given phi. If not, returns null.
Definition at line 3152 of file InstructionSimplify.cpp.
References llvm::UndefValue::get(), llvm::PHINode::getIncomingValue(), llvm::PHINode::getNumIncomingValues(), llvm::Value::getType(), and ValueDominatesPHI().
Referenced by llvm::SimplifyInstruction().
static Value* SimplifyRem | ( | Instruction::BinaryOps | Opcode, |
Value * | Op0, | ||
Value * | Op1, | ||
const Query & | Q, | ||
unsigned | MaxRecurse | ||
) | [static] |
SimplifyRem - Given operands for an SRem or URem, see if we can fold the result. If not, this returns null.
Definition at line 1137 of file InstructionSimplify.cpp.
References llvm::ConstantFoldInstOperands(), llvm::UndefValue::get(), llvm::Constant::getNullValue(), llvm::Value::getType(), llvm::Type::isIntegerTy(), llvm::PatternMatch::m_One(), llvm::PatternMatch::m_Specific(), llvm::PatternMatch::m_SRem(), llvm::PatternMatch::m_Undef(), llvm::PatternMatch::m_URem(), llvm::PatternMatch::m_Value(), llvm::PatternMatch::m_Zero(), llvm::PatternMatch::match(), ThreadBinOpOverPHI(), and ThreadBinOpOverSelect().
Referenced by SimplifySRemInst(), and SimplifyURemInst().
static Value* SimplifySDivInst | ( | Value * | Op0, |
Value * | Op1, | ||
const Query & | Q, | ||
unsigned | MaxRecurse | ||
) | [static] |
SimplifySDivInst - Given operands for an SDiv, see if we can fold the result. If not, this returns null.
Definition at line 1077 of file InstructionSimplify.cpp.
References SimplifyDiv().
static Value* SimplifySelectInst | ( | Value * | CondVal, |
Value * | TrueVal, | ||
Value * | FalseVal, | ||
const Query & | Q, | ||
unsigned | MaxRecurse | ||
) | [static] |
SimplifySelectInst - Given operands for a SelectInst, see if we can fold the result. If not, this returns null.
Definition at line 2982 of file InstructionSimplify.cpp.
static Value* SimplifyShift | ( | unsigned | Opcode, |
Value * | Op0, | ||
Value * | Op1, | ||
const Query & | Q, | ||
unsigned | MaxRecurse | ||
) | [static] |
SimplifyShift - Given operands for an Shl, LShr or AShr, see if we can fold the result. If not, this returns null.
Definition at line 1285 of file InstructionSimplify.cpp.
References llvm::ConstantFoldInstOperands(), llvm::UndefValue::get(), llvm::Value::getType(), isUndefShift(), llvm::PatternMatch::m_Zero(), llvm::PatternMatch::match(), ThreadBinOpOverPHI(), and ThreadBinOpOverSelect().
Referenced by SimplifyAShrInst(), SimplifyLShrInst(), and SimplifyShlInst().
static Value* SimplifyShlInst | ( | Value * | Op0, |
Value * | Op1, | ||
bool | isNSW, | ||
bool | isNUW, | ||
const Query & | Q, | ||
unsigned | MaxRecurse | ||
) | [static] |
SimplifyShlInst - Given operands for an Shl, see if we can fold the result. If not, this returns null.
Definition at line 1323 of file InstructionSimplify.cpp.
References llvm::Constant::getNullValue(), llvm::Value::getType(), llvm::PatternMatch::m_Exact(), llvm::PatternMatch::m_Shr(), llvm::PatternMatch::m_Specific(), llvm::PatternMatch::m_Undef(), llvm::PatternMatch::m_Value(), llvm::PatternMatch::match(), SimplifyShift(), and llvm::X.
static Value* SimplifySRemInst | ( | Value * | Op0, |
Value * | Op1, | ||
const Query & | Q, | ||
unsigned | MaxRecurse | ||
) | [static] |
SimplifySRemInst - Given operands for an SRem, see if we can fold the result. If not, this returns null.
Definition at line 1198 of file InstructionSimplify.cpp.
References SimplifyRem().
static Value* SimplifySubInst | ( | Value * | Op0, |
Value * | Op1, | ||
bool | isNSW, | ||
bool | isNUW, | ||
const Query & | Q, | ||
unsigned | MaxRecurse | ||
) | [static] |
SimplifySubInst - Given operands for a Sub, see if we can fold the result. If not, this returns null.
Definition at line 664 of file InstructionSimplify.cpp.
References computePointerDifference(), llvm::ConstantFoldInstOperands(), llvm::UndefValue::get(), llvm::ConstantExpr::getIntegerCast(), llvm::Constant::getNullValue(), llvm::Value::getType(), llvm::Type::isIntegerTy(), llvm::BinaryOperator::isNeg(), llvm::PatternMatch::m_Add(), llvm::PatternMatch::m_PtrToInt(), llvm::PatternMatch::m_Sub(), llvm::PatternMatch::m_Trunc(), llvm::PatternMatch::m_Undef(), llvm::PatternMatch::m_Value(), llvm::PatternMatch::m_Zero(), llvm::PatternMatch::match(), llvm::SimplifyBinOp(), llvm::SimplifyTruncInst(), llvm::SimplifyXorInst(), llvm::X, and Y.
Definition at line 3185 of file InstructionSimplify.cpp.
References llvm::CallingConv::C, llvm::ConstantFoldInstOperands(), and llvm::Trunc.
static Value* SimplifyUDivInst | ( | Value * | Op0, |
Value * | Op1, | ||
const Query & | Q, | ||
unsigned | MaxRecurse | ||
) | [static] |
SimplifyUDivInst - Given operands for a UDiv, see if we can fold the result. If not, this returns null.
Definition at line 1096 of file InstructionSimplify.cpp.
References SimplifyDiv().
static Value* SimplifyURemInst | ( | Value * | Op0, |
Value * | Op1, | ||
const Query & | Q, | ||
unsigned | MaxRecurse | ||
) | [static] |
SimplifyURemInst - Given operands for a URem, see if we can fold the result. If not, this returns null.
Definition at line 1217 of file InstructionSimplify.cpp.
References SimplifyRem().
static Value * SimplifyXorInst | ( | Value * | Op0, |
Value * | Op1, | ||
const Query & | Q, | ||
unsigned | MaxRecurse | ||
) | [static] |
SimplifyXorInst - Given operands for a Xor, see if we can fold the result. If not, this returns null.
Definition at line 1763 of file InstructionSimplify.cpp.
References llvm::ConstantFoldInstOperands(), llvm::Constant::getAllOnesValue(), llvm::Constant::getNullValue(), llvm::Value::getType(), llvm::PatternMatch::m_Not(), llvm::PatternMatch::m_Specific(), llvm::PatternMatch::m_Undef(), llvm::PatternMatch::m_Zero(), llvm::PatternMatch::match(), SimplifyAssociativeBinOp(), std::swap(), and llvm::APIntOps::Xor().
STATISTIC | ( | NumExpand | , |
"Number of expansions" | |||
) |
STATISTIC | ( | NumReassoc | , |
"Number of reassociations" | |||
) |
static Constant* stripAndComputeConstantOffsets | ( | const DataLayout * | DL, |
Value *& | V, | ||
bool | AllowNonInbounds = false |
||
) | [static] |
Compute the base pointer and cumulative constant offsets for V.
This strips all constant offsets off of V, leaving it the base pointer, and accumulates the total constant offset applied in the returned constant. It returns 0 if V is not a pointer, and returns the constant '0' if there are no constant offsets applied.
This is very similar to GetPointerBaseWithConstantOffset except it doesn't follow non-inbounds geps. This allows it to remain usable for icmp ult/etc. folding.
Definition at line 600 of file InstructionSimplify.cpp.
References llvm::IntegerType::get(), llvm::ConstantInt::get(), llvm::Value::getContext(), llvm::Type::getIntegerBitWidth(), llvm::DataLayout::getIntPtrType(), llvm::APInt::getNullValue(), llvm::Operator::getOpcode(), llvm::Type::getScalarType(), llvm::ConstantVector::getSplat(), llvm::Value::getType(), llvm::Type::getVectorNumElements(), llvm::SmallPtrSetImpl< PtrType >::insert(), llvm::Type::isPointerTy(), and llvm::Type::isVectorTy().
Referenced by computePointerDifference(), and computePointerICmp().
static Value* ThreadBinOpOverPHI | ( | unsigned | Opcode, |
Value * | LHS, | ||
Value * | RHS, | ||
const Query & | Q, | ||
unsigned | MaxRecurse | ||
) | [static] |
ThreadBinOpOverPHI - In the case of a binary operation with an operand that is a PHI instruction, try to simplify the binop by seeing whether evaluating it on the incoming phi values yields the same result for every value. If so returns the common value, otherwise returns null.
Definition at line 446 of file InstructionSimplify.cpp.
References llvm::PHINode::getIncomingValue(), llvm::PHINode::getNumIncomingValues(), llvm::SimplifyBinOp(), and ValueDominatesPHI().
Referenced by SimplifyAndInst(), SimplifyBinOp(), SimplifyDiv(), SimplifyMulInst(), SimplifyOrInst(), SimplifyRem(), and SimplifyShift().
static Value* ThreadBinOpOverSelect | ( | unsigned | Opcode, |
Value * | LHS, | ||
Value * | RHS, | ||
const Query & | Q, | ||
unsigned | MaxRecurse | ||
) | [static] |
ThreadBinOpOverSelect - In the case of a binary operation with a select instruction as an operand, try to simplify the binop by seeing whether evaluating it on both branches of the select results in the same value. Returns the common value if so, otherwise returns null.
Definition at line 292 of file InstructionSimplify.cpp.
References llvm::dyn_cast(), llvm::SelectInst::getFalseValue(), llvm::Instruction::getOpcode(), llvm::User::getOperand(), llvm::SelectInst::getTrueValue(), llvm::Instruction::isCommutative(), llvm::JumpTable::Simplified, and llvm::SimplifyBinOp().
Referenced by SimplifyAndInst(), SimplifyBinOp(), SimplifyDiv(), SimplifyMulInst(), SimplifyOrInst(), SimplifyRem(), and SimplifyShift().
static Value* ThreadCmpOverPHI | ( | CmpInst::Predicate | Pred, |
Value * | LHS, | ||
Value * | RHS, | ||
const Query & | Q, | ||
unsigned | MaxRecurse | ||
) | [static] |
ThreadCmpOverPHI - In the case of a comparison with a PHI instruction, try try to simplify the comparison by seeing whether comparing with all of the incoming phi values yields the same result every time. If so returns the common result, otherwise returns null.
Definition at line 489 of file InstructionSimplify.cpp.
References llvm::PHINode::getIncomingValue(), llvm::PHINode::getNumIncomingValues(), llvm::PPC::getSwappedPredicate(), llvm::SimplifyCmpInst(), std::swap(), and ValueDominatesPHI().
Referenced by SimplifyFCmpInst(), and SimplifyICmpInst().
static Value* ThreadCmpOverSelect | ( | CmpInst::Predicate | Pred, |
Value * | LHS, | ||
Value * | RHS, | ||
const Query & | Q, | ||
unsigned | MaxRecurse | ||
) | [static] |
ThreadCmpOverSelect - In the case of a comparison with a select instruction, try to simplify the comparison by seeing whether both branches of the select result in the same value. Returns the common value if so, otherwise returns null.
Definition at line 364 of file InstructionSimplify.cpp.
References llvm::FCmp, llvm::Constant::getAllOnesValue(), llvm::SelectInst::getCondition(), getFalse(), llvm::SelectInst::getFalseValue(), llvm::PPC::getSwappedPredicate(), getTrue(), llvm::SelectInst::getTrueValue(), llvm::Value::getType(), isSameCompare(), llvm::Type::isVectorTy(), llvm::PatternMatch::m_One(), llvm::PatternMatch::m_Zero(), llvm::PatternMatch::match(), llvm::SimplifyAndInst(), llvm::SimplifyCmpInst(), llvm::SimplifyOrInst(), llvm::SimplifyXorInst(), and std::swap().
Referenced by SimplifyFCmpInst(), and SimplifyICmpInst().
static bool ValueDominatesPHI | ( | Value * | V, |
PHINode * | P, | ||
const DominatorTree * | DT | ||
) | [static] |
ValueDominatesPHI - Does the given value dominate the specified phi node?
Definition at line 99 of file InstructionSimplify.cpp.
References llvm::DominatorTree::dominates(), llvm::dyn_cast(), llvm::Function::getEntryBlock(), llvm::Instruction::getParent(), llvm::BasicBlock::getParent(), I, and llvm::DominatorTree::isReachableFromEntry().
Referenced by SimplifyPHINode(), ThreadBinOpOverPHI(), and ThreadCmpOverPHI().