Home
last modified time | relevance | path

Searched refs:SelectInst (Results 1 – 25 of 116) sorted by relevance

12345

/freebsd/contrib/llvm-project/llvm/lib/Transforms/ObjCARC/
H A DProvenanceAnalysis.cpp41 bool ProvenanceAnalysis::relatedSelect(const SelectInst *A, in relatedSelect()
45 if (const SelectInst *SB = dyn_cast<SelectInst>(B)) in relatedSelect()
150 if (const SelectInst *S = dyn_cast<SelectInst>(A)) in relatedCheck()
152 if (const SelectInst *S = dyn_cast<SelectInst>(B)) in relatedCheck()
H A DProvenanceAnalysis.h37 class SelectInst; variable
63 bool relatedSelect(const SelectInst *A, const Value *B);
/freebsd/contrib/llvm-project/llvm/lib/Transforms/Instrumentation/
H A DControlHeightReduction.cpp138 SmallVector<SelectInst *, 8> Selects;
275 DenseSet<SelectInst *> TrueBiasedSelects;
276 DenseSet<SelectInst *> FalseBiasedSelects;
355 void fixupSelect(SelectInst *SI, CHRScope *Scope, IRBuilder<> &IRB,
386 DenseSet<SelectInst *> TrueBiasedSelectsGlobal;
388 DenseSet<SelectInst *> FalseBiasedSelectsGlobal;
392 DenseMap<SelectInst *, BranchProbability> SelectBiasMap;
471 return isa<BinaryOperator>(I) || isa<CastInst>(I) || isa<SelectInst>(I) || in isHoistableInstructionType()
661 SelectInst *SI, Region *R, in checkBiasedSelect()
662 DenseSet<SelectInst *> &TrueBiasedSelectsGlobal, in checkBiasedSelect()
[all …]
/freebsd/contrib/llvm-project/llvm/lib/Transforms/InstCombine/
H A DInstCombineSelect.cpp55 static Instruction *foldSelectBinOpIdentity(SelectInst &Sel, in foldSelectBinOpIdentity()
122 static Value *foldSelectICmpAnd(SelectInst &Sel, ICmpInst *Cmp, in foldSelectICmpAnd()
271 Instruction *InstCombinerImpl::foldSelectOpOp(SelectInst &SI, Instruction *TI, in foldSelectOpOp()
510 Instruction *InstCombinerImpl::foldSelectIntoOp(SelectInst &SI, Value *TrueVal, in foldSelectIntoOp()
514 auto TryFoldSelectIntoOp = [&](SelectInst &SI, Value *TrueVal, in foldSelectIntoOp()
818 static Instruction *foldSetClearBits(SelectInst &Sel, in foldSetClearBits()
858 static Instruction *foldSelectZeroOrMul(SelectInst &SI, InstCombinerImpl &IC) { in foldSelectZeroOrMul()
1286 Instruction *InstCombinerImpl::foldSelectValueEquivalence(SelectInst &Sel, in foldSelectValueEquivalence()
1393 static Value *canonicalizeClampLike(SelectInst &Sel0, ICmpInst &Cmp0, in canonicalizeClampLike()
1410 if (!isa<SelectInst>(Sel1)) { in canonicalizeClampLike()
[all …]
H A DInstCombineInternal.h150 Instruction *visitSelectInst(SelectInst &SI);
196 bool replacedSelectWithOperand(SelectInst *SI, const ICmpInst *Icmp,
452 Instruction *foldAndOrOfSelectUsingImpliedCond(Value *Op, SelectInst &SI,
544 bool matchThreeWayIntCompare(SelectInst *SI, Value *&LHS, Value *&RHS,
592 Instruction *foldVectorSelect(SelectInst &Sel);
614 Instruction *FoldOpIntoSelect(Instruction &Op, SelectInst *SI,
647 Instruction *foldSelectICmp(ICmpInst::Predicate Pred, SelectInst *SI,
681 Instruction *foldICmpSelectConstant(ICmpInst &Cmp, SelectInst *Select,
733 Instruction *foldSelectOfBools(SelectInst &SI);
734 Instruction *foldSelectExtConst(SelectInst &Sel);
[all …]
H A DInstCombineMulDivRem.cpp470 return SelectInst::Create(X, Op1, ConstantInt::getNullValue(Ty)); in visitMul()
472 return SelectInst::Create(X, Op0, ConstantInt::getNullValue(Ty)); in visitMul()
478 return SelectInst::Create(X, Builder.CreateNeg(Y, "", I.hasNoSignedWrap()), in visitMul()
486 return SelectInst::Create(X, NegC, ConstantInt::getNullValue(Ty)); in visitMul()
495 return SelectInst::Create(IsNeg, NegC, ConstantInt::getNullValue(Ty)); in visitMul()
506 return SelectInst::Create(IsNeg, Y, ConstantInt::getNullValue(Ty)); in visitMul()
512 return SelectInst::Create(Tr, Y, ConstantInt::getNullValue(Ty)); in visitMul()
916 auto *SI = SelectInst::Create(X, Op1, ConstantFP::get(I.getType(), 0.0)); in visitFMul()
922 auto *SI = SelectInst::Create(X, Op0, ConstantFP::get(I.getType(), 0.0)); in visitFMul()
986 SelectInst *SI = dyn_cast<SelectInst>(I.getOperand(1)); in simplifyDivRemOfSelectWithZeroOp()
[all …]
H A DInstCombineLoadStoreAlloca.cpp82 if (isa<PHINode, SelectInst>(I)) { in isOnlyCopiedFromConstantMemory()
322 } else if (auto *SI = dyn_cast<SelectInst>(Inst)) { in collectUsersRecursive()
396 } else if (auto *SI = dyn_cast<SelectInst>(I)) { in replace()
403 auto *NewSI = SelectInst::Create(SI->getCondition(), TrueValue, FalseValue, in replace()
820 if (SelectInst *SI = dyn_cast<SelectInst>(P)) { in isObjectSizeLessThanOrEq()
1067 if (SelectInst *SI = dyn_cast<SelectInst>(Op)) { in visitLoadInst()
1085 return SelectInst::Create(SI->getCondition(), V1, V2); in visitLoadInst()
H A DInstCombineAddSub.cpp883 return SelectInst::Create(X, InstCombiner::AddOne(Op1C), Op1); in foldAddWithConstant()
887 return SelectInst::Create(X, InstCombiner::SubOne(Op1C), Op1); in foldAddWithConstant()
2299 return SelectInst::Create(X, InstCombiner::SubOne(C), C); in visitSub()
2302 return SelectInst::Create(X, InstCombiner::AddOne(C), C); in visitSub()
2309 if (SelectInst *SI = dyn_cast<SelectInst>(Op1)) in visitSub()
2456 return SelectInst::Create(C, Builder.CreateNeg(X), X); in visitSub()
2458 return SelectInst::Create(C, X, Builder.CreateNeg(X)); in visitSub()
2493 SelectInst *NewSel = in visitSub()
2494 SelectInst::Create(Cond, OtherHandOfSubIsTrueVal ? Zero : NewSub, in visitSub()
2578 return SelectInst::Create(IsNeg, NegA, A); in visitSub()
[all …]
H A DInstCombineAndOrXor.cpp1602 return SelectInst::Create(Cond, Builder.CreateNeg(X, X->getName() + ".neg"), in canonicalizeConditionalNegationViaMathToSelect()
2364 return SelectInst::Create(Cmp, ConstantInt::getNullValue(Ty), Y); in visitAnd()
2524 return SelectInst::Create(Cmp, ConstantInt::get(Ty, *C), in visitAnd()
2544 return SelectInst::Create(Cmp, ConstantInt::get(Ty, *C3), in visitAnd()
2561 return SelectInst::Create(Cmp, ConstantInt::get(Ty, *C3), in visitAnd()
2605 if (auto *SI0 = dyn_cast<SelectInst>(Op0)) { in visitAnd()
2610 if (auto *SI1 = dyn_cast<SelectInst>(Op1)) { in visitAnd()
2695 bool IsLogical = isa<SelectInst>(Op1); in visitAnd()
2712 bool IsLogical = isa<SelectInst>(Op0); in visitAnd()
2752 return SelectInst::Create(A, B, Constant::getNullValue(Ty)); in visitAnd()
[all …]
/freebsd/contrib/llvm-project/llvm/lib/Transforms/Scalar/
H A DDFAJumpThreading.cpp122 SelectInst *SI;
126 SelectInstToUnfold(SelectInst *SI, PHINode *SIUse) : SI(SI), SIUse(SIUse) {} in SelectInstToUnfold()
128 SelectInst *getInst() { return SI; } in getInst()
182 DomTreeUpdater *DTU, SelectInst *SI, PHINode *SIUse, SelectInst *SIToSink, in createBasicBlockAndSinkSelectInst()
208 SelectInst *SI = SIToUnfold.getInst(); in unfold()
226 if (SelectInst *SIOp = dyn_cast<SelectInst>(SI->getTrueValue())) { in unfold()
231 if (SelectInst *SIOp = dyn_cast<SelectInst>(SI->getFalseValue())) { in unfold()
447 } else if (SelectInst *SelI = dyn_cast<SelectInst>(Current)) { in isCandidate()
492 bool isValidSelectInst(SelectInst *SI) { in isValidSelectInst()
498 if (!SIUse && !(isa<PHINode>(SIUse) || isa<SelectInst>(SIUse))) in isValidSelectInst()
[all …]
H A DTailRecursionElimination.cpp421 SmallVector<SelectInst *, 8> RetSelects;
719 SelectInst *SI = in eliminateCall()
720 SelectInst::Create(RetKnownPN, RetPN, Ret->getReturnValue(), in eliminateCall()
794 SelectInst *SI = in cleanupAndFinalize()
795 SelectInst::Create(RetKnownPN, RetPN, RI->getOperand(0), in cleanupAndFinalize()
805 for (SelectInst *SI : RetSelects) { in cleanupAndFinalize()
H A DSROA.cpp212 SmallMapVector<SelectInst *, RewriteableMemOps, 8> SelectsToRewrite;
231 isSafeSelectToSpeculate(SelectInst &SI, bool PreserveCFG);
988 static Value *foldSelectInst(SelectInst &SI) { in foldSelectInst()
1006 return foldSelectInst(cast<SelectInst>(I)); in foldPHINodeOrSelectInst()
1317 !isa<SelectInst>(I) && !isa<AddrSpaceCastInst>(I)) { in hasUnsafePHIOrSelectUse()
1330 assert(isa<PHINode>(I) || isa<SelectInst>(I)); in visitPHINodeOrSelectInst()
1389 void visitSelectInst(SelectInst &SI) { visitPHINodeOrSelectInst(SI); } in visitSelectInst()
1684 isSafeLoadOfSelectToSpeculate(LoadInst &LI, SelectInst &SI, bool PreserveCFG) { in isSafeLoadOfSelectToSpeculate()
1700 SROA::isSafeSelectToSpeculate(SelectInst &SI, bool PreserveCFG) { in isSafeSelectToSpeculate()
1746 static void speculateSelectInstLoads(SelectInst &SI, LoadInst &LI, in speculateSelectInstLoads()
[all …]
H A DJumpThreading.cpp869 if (SelectInst *SI = dyn_cast<SelectInst>(I)) { in computeValueKnownInPredecessorsImpl()
2754 SelectInst *SI, PHINode *SIUse, in unfoldSelectInstr()
2824 SelectInst *PredSI = dyn_cast<SelectInst>(CondPHI->getIncomingValue(I)); in tryToUnfoldSelect()
2865 SelectInst *SI = dyn_cast<SelectInst>(CondLHS->getIncomingValue(I)); in tryToUnfoldSelect()
2931 auto isUnfoldCandidate = [BB](SelectInst *SI, Value *V) { in tryToUnfoldSelectInCurrBB()
2942 SelectInst *SI = nullptr; in tryToUnfoldSelectInCurrBB()
2949 if (SelectInst *SelectI = dyn_cast<SelectInst>(Cmp->user_back())) in tryToUnfoldSelectInCurrBB()
2954 } else if (SelectInst *SelectI = dyn_cast<SelectInst>(U.getUser())) { in tryToUnfoldSelectInCurrBB()
/freebsd/contrib/llvm-project/llvm/lib/SandboxIR/
H A DSandboxIR.cpp458 Value *SelectInst::createCommon(Value *Cond, Value *True, Value *False, in createCommon()
463 if (auto *NewSI = dyn_cast<llvm::SelectInst>(NewV)) in createCommon()
469 Value *SelectInst::create(Value *Cond, Value *True, Value *False, in create()
478 Value *SelectInst::create(Value *Cond, Value *True, Value *False, in create()
487 bool SelectInst::classof(const Value *From) { in classof()
492 void SelectInst::dump(raw_ostream &OS) const { in dump()
497 void SelectInst::dump() const { in dump()
757 auto *LLVMSel = cast<llvm::SelectInst>(LLVMV); in getOrCreateValueInternal()
758 It->second = std::unique_ptr<SelectInst>(new SelectInst(LLVMSel, *this)); in getOrCreateValueInternal()
794 SelectInst *Context::createSelectInst(llvm::SelectInst *SI) { in createSelectInst()
[all …]
/freebsd/contrib/llvm-project/llvm/include/llvm/Transforms/Scalar/
H A DSROA.h38 class SelectInst; global() variable
H A DJumpThreading.h43 class SelectInst; variable
158 void unfoldSelectInstr(BasicBlock *Pred, BasicBlock *BB, SelectInst *SI,
/freebsd/contrib/llvm-project/llvm/lib/CodeGen/
H A DSelectOptimize.cpp143 if (isa<SelectInst>(I)) in match()
176 if (auto *Sel = dyn_cast<SelectInst>(I)) in getNonInvertedCondition()
210 if (auto *Sel = dyn_cast<SelectInst>(I)) in getTrueValue()
226 if (auto *Sel = dyn_cast<SelectInst>(I)) in getFalseValue()
246 if (isa<SelectInst>(I)) in getTrueOpCost()
272 if (isa<SelectInst>(I)) in getFalseOpCost()
537 for (SelectInst *DefSI = dyn_cast<SelectInst>(SI.getI()); in getTrueOrFalseValue()
539 DefSI = dyn_cast<SelectInst>(V)) { in getTrueOrFalseValue()
611 if (isa<SelectInst>(SI.getI()) || !FI->hasOneUse()) { in convertProfitableSIGroups()
806 if (!isa<SelectInst>(NI)) in collectSelectGroups()
[all …]
/freebsd/contrib/llvm-project/llvm/lib/Target/Hexagon/
H A DHexagonLoopIdiomRecognition.cpp622 bool matchLeftShift(SelectInst *SelI, Value *CIV, ParsedValues &PV);
623 bool matchRightShift(SelectInst *SelI, ParsedValues &PV);
624 bool scanSelect(SelectInst *SI, BasicBlock *LoopB, BasicBlock *PrehB,
683 bool PolynomialMultiplyRecognize::matchLeftShift(SelectInst *SelI, in matchLeftShift()
797 bool PolynomialMultiplyRecognize::matchRightShift(SelectInst *SelI, in matchRightShift()
867 bool PolynomialMultiplyRecognize::scanSelect(SelectInst *SelI, in scanSelect()
1642 if (SelectInst *Sel = dyn_cast<SelectInst>(BO->getOperand(0))) { in setupPreSimplifier()
1650 if (SelectInst *Sel = dyn_cast<SelectInst>(BO->getOperand(1))) { in setupPreSimplifier()
1664 SelectInst *Sel = dyn_cast<SelectInst>(I); in setupPreSimplifier()
1669 if (SelectInst *Sel0 = dyn_cast<SelectInst>(Sel->getTrueValue())) { in setupPreSimplifier()
[all …]
/freebsd/contrib/llvm-project/llvm/lib/Analysis/
H A DIVDescriptors.cpp366 if (!Cur->isCommutative() && !IsAPhi && !isa<SelectInst>(Cur) && in AddReductionVar()
385 if (auto *Sel = dyn_cast<SelectInst>(ReduxDesc.getPatternInst())) { in AddReductionVar()
402 bool IsASelect = isa<SelectInst>(Cur); in AddReductionVar()
420 (isa<ICmpInst>(Cur) || isa<SelectInst>(Cur))) in AddReductionVar()
423 (isa<FCmpInst>(Cur) || isa<SelectInst>(Cur))) in AddReductionVar()
486 !isa<SelectInst>(UI)) || in AddReductionVar()
634 if (auto *Select = dyn_cast<SelectInst>(*I->user_begin())) in isAnyOfPattern()
642 SelectInst *SI = cast<SelectInst>(I); in isAnyOfPattern()
665 assert((isa<CmpInst>(I) || isa<SelectInst>(I) || isa<CallInst>(I)) && in isMinMaxPattern()
674 if (auto *Select = dyn_cast<SelectInst>(*I->user_begin())) in isMinMaxPattern()
[all …]
H A DBasicAliasAnalysis.cpp792 if (const SelectInst *SI = dyn_cast<SelectInst>(V)) { in getModRefInfoMask()
1383 BasicAAResult::aliasSelect(const SelectInst *SI, LocationSize SISize, in aliasSelect()
1388 if (const SelectInst *SI2 = dyn_cast<SelectInst>(V2)) in aliasSelect()
1788 if (const SelectInst *S1 = dyn_cast<SelectInst>(V1)) { in aliasCheckRecursive()
1792 } else if (const SelectInst *S2 = dyn_cast<SelectInst>(V2)) { in aliasCheckRecursive()
/freebsd/contrib/llvm-project/llvm/include/llvm/SandboxIR/
H A DSandboxIR.h78 class SelectInst; variable
181 friend class SelectInst; // For getting `Val`. variable
506 friend class SelectInst; // For getTopmostLLVMInstruction(). variable
574 class SelectInst : public Instruction {
577 SelectInst(llvm::SelectInst *CI, Context &Ctx) in SelectInst() function
608 void swapValues() { cast<llvm::SelectInst>(Val)->swapValues(); } in swapValues()
613 assert(isa<llvm::SelectInst>(Val) && "Expected SelectInst!"); in verify()
871 SelectInst *createSelectInst(llvm::SelectInst *SI);
872 friend SelectInst; // For createSelectInst() variable
H A DSandboxIRValues.def28 DEF_INSTR(Select, OP(Select), SelectInst)
/freebsd/contrib/llvm-project/llvm/include/llvm/Analysis/
H A DMemoryBuiltins.h48 class SelectInst; variable
260 SizeOffsetAPInt visitSelectInst(SelectInst &I);
338 SizeOffsetValue visitSelectInst(SelectInst &I);
H A DBasicAliasAnalysis.h31 class SelectInst;
137 AliasResult aliasSelect(const SelectInst *SI, LocationSize SISize,
32 class SelectInst; global() variable
/freebsd/contrib/llvm-project/llvm/lib/Target/AMDGPU/
H A DAMDGPUCodeGenPrepare.cpp157 bool isSigned(const SelectInst &I) const;
209 bool promoteUniformOpToI32(SelectInst &I) const;
312 bool visitSelectInst(SelectInst &I);
398 bool AMDGPUCodeGenPrepareImpl::isSigned(const SelectInst &I) const { in isSigned()
539 bool AMDGPUCodeGenPrepareImpl::promoteUniformOpToI32(SelectInst &I) const { in promoteUniformOpToI32()
694 static SelectInst *findSelectThroughCast(Value *V, CastInst *&Cast) { in findSelectThroughCast()
696 if (SelectInst *Sel = dyn_cast<SelectInst>(V)) in findSelectThroughCast()
700 if (SelectInst *Sel = dyn_cast<SelectInst>(Cast->getOperand(0))) in findSelectThroughCast()
716 SelectInst *Sel = findSelectThroughCast(BO.getOperand(0), CastOp); in foldBinOpIntoSelect()
1687 bool AMDGPUCodeGenPrepareImpl::visitSelectInst(SelectInst &I) { in visitSelectInst()

12345