Home
last modified time | relevance | path

Searched refs:VPBasicBlock (Results 1 – 25 of 26) sorted by relevance

12

/external/swiftshader/third_party/llvm-10.0/llvm/lib/Transforms/Vectorize/
DLoopVectorizationPlanner.h37 VPBasicBlock *BB = nullptr;
38 VPBasicBlock::iterator InsertPt = VPBasicBlock::iterator();
60 InsertPt = VPBasicBlock::iterator(); in clearInsertionPoint()
63 VPBasicBlock *getInsertBlock() const { return BB; } in getInsertBlock()
64 VPBasicBlock::iterator getInsertPoint() const { return InsertPt; } in getInsertPoint()
68 VPBasicBlock *Block = nullptr;
69 VPBasicBlock::iterator Point;
76 VPInsertPoint(VPBasicBlock *InsertBlock, VPBasicBlock::iterator InsertPoint) in VPInsertPoint()
82 VPBasicBlock *getBlock() const { return Block; } in getBlock()
83 VPBasicBlock::iterator getPoint() const { return Point; } in getPoint()
[all …]
DVPlanHCFGBuilder.cpp55 DenseMap<BasicBlock *, VPBasicBlock *> BB2VPBB;
63 void setVPBBPredsFromBB(VPBasicBlock *VPBB, BasicBlock *BB);
65 VPBasicBlock *getOrCreateVPBB(BasicBlock *BB);
70 void createVPInstructionsForVPBB(VPBasicBlock *VPBB, BasicBlock *BB);
83 void PlainCFGBuilder::setVPBBPredsFromBB(VPBasicBlock *VPBB, BasicBlock *BB) { in setVPBBPredsFromBB()
109 VPBasicBlock *PlainCFGBuilder::getOrCreateVPBB(BasicBlock *BB) { in getOrCreateVPBB()
117 VPBasicBlock *VPBB = new VPBasicBlock(BB->getName()); in getOrCreateVPBB()
192 void PlainCFGBuilder::createVPInstructionsForVPBB(VPBasicBlock *VPBB, in createVPInstructionsForVPBB()
255 VPBasicBlock *PreheaderVPBB = getOrCreateVPBB(PreheaderBB); in buildPlainCFG()
268 VPBasicBlock *VPBB = getOrCreateVPBB(BB); in buildPlainCFG()
[all …]
DVPlanPredicator.cpp37 VPValue *VPlanPredicator::getOrCreateNotPredicate(VPBasicBlock *PredBB, in getOrCreateNotPredicate()
38 VPBasicBlock *CurrBB) { in getOrCreateNotPredicate()
147 VPBasicBlock *CurrBB = cast<VPBasicBlock>(CurrBlock->getEntryBasicBlock()); in createOrPropagatePredicates()
169 assert(isa<VPBasicBlock>(PredBlock) && "Only BBs have multiple exits"); in createOrPropagatePredicates()
171 getOrCreateNotPredicate(cast<VPBasicBlock>(PredBlock), CurrBB); in createOrPropagatePredicates()
188 VPBasicBlock *EntryBlock = cast<VPBasicBlock>(Region->getEntry()); in predicateRegionRec()
DVPlan.cpp60 const VPBasicBlock *VPBlockBase::getEntryBasicBlock() const { in getEntryBasicBlock()
64 return cast<VPBasicBlock>(Block); in getEntryBasicBlock()
67 VPBasicBlock *VPBlockBase::getEntryBasicBlock() { in getEntryBasicBlock()
71 return cast<VPBasicBlock>(Block); in getEntryBasicBlock()
75 const VPBasicBlock *VPBlockBase::getExitBasicBlock() const { in getExitBasicBlock()
79 return cast<VPBasicBlock>(Block); in getExitBasicBlock()
82 VPBasicBlock *VPBlockBase::getExitBasicBlock() { in getExitBasicBlock()
86 return cast<VPBasicBlock>(Block); in getExitBasicBlock()
115 VPBasicBlock::createEmptyBasicBlock(VPTransformState::CFGState &CFG) { in createEmptyBasicBlock()
125 VPBasicBlock *PredVPBB = PredVPBlock->getExitBasicBlock(); in createEmptyBasicBlock()
[all …]
DVPRecipeBuilder.h119 bool tryToWiden(Instruction *I, VPBasicBlock *VPBB, VFRange &Range);
135 VPBasicBlock *VPBB);
143 VPBasicBlock *handleReplication(
144 Instruction *I, VFRange &Range, VPBasicBlock *VPBB,
DVPlan.h60 class VPBasicBlock; variable
294 VPBasicBlock *PrevVPBB = nullptr;
306 SmallDenseMap<VPBasicBlock *, BasicBlock *> VPBB2IRBB;
310 SmallVector<VPBasicBlock *, 8> VPBBsToFix;
426 const VPBasicBlock *getEntryBasicBlock() const;
427 VPBasicBlock *getEntryBasicBlock();
432 const VPBasicBlock *getExitBasicBlock() const;
433 VPBasicBlock *getExitBasicBlock();
578 class VPRecipeBase : public ilist_node_with_parent<VPRecipeBase, VPBasicBlock> {
579 friend VPBasicBlock; variable
[all …]
DVPlanPredicator.h50 VPValue *getOrCreateNotPredicate(VPBasicBlock *PredBB, VPBasicBlock *CurrBB);
DVPlanTransforms.cpp31 VPBasicBlock *VPBB = Base->getEntryBasicBlock(); in VPInstructionsToVPRecipes()
43 VPBasicBlock *VPBB = Base->getEntryBasicBlock(); in VPInstructionsToVPRecipes()
DVPlanValue.h41 friend class VPBasicBlock; variable
DLoopVectorize.cpp6864 bool VPRecipeBuilder::tryToWiden(Instruction *I, VPBasicBlock *VPBB, in tryToWiden()
6976 VPBasicBlock *VPRecipeBuilder::handleReplication( in handleReplication()
6977 Instruction *I, VFRange &Range, VPBasicBlock *VPBB, in handleReplication()
7011 auto *RegSucc = new VPBasicBlock(); in handleReplication()
7029 auto *Entry = new VPBasicBlock(Twine(RegionName) + ".entry", BOMRecipe); in createReplicateRegion()
7032 auto *Exit = new VPBasicBlock(Twine(RegionName) + ".continue", PHIRecipe); in createReplicateRegion()
7033 auto *Pred = new VPBasicBlock(Twine(RegionName) + ".if", PredRecipe); in createReplicateRegion()
7045 VPlanPtr &Plan, VPBasicBlock *VPBB) { in tryToCreateRecipe()
7184 VPBasicBlock *VPBB = new VPBasicBlock("Pre-Entry"); in buildVPlanWithVPRecipes()
7200 auto *FirstVPBBForBB = new VPBasicBlock(BB->getName()); in buildVPlanWithVPRecipes()
[all …]
DVPlanSLP.cpp123 VPBasicBlock *Parent = cast<VPInstruction>(Operands[0])->getParent(); in areVectorizable()
/external/llvm-project/llvm/lib/Transforms/Vectorize/
DLoopVectorizationPlanner.h41 VPBasicBlock *BB = nullptr;
42 VPBasicBlock::iterator InsertPt = VPBasicBlock::iterator();
64 InsertPt = VPBasicBlock::iterator(); in clearInsertionPoint()
67 VPBasicBlock *getInsertBlock() const { return BB; } in getInsertBlock()
68 VPBasicBlock::iterator getInsertPoint() const { return InsertPt; } in getInsertPoint()
72 VPBasicBlock *Block = nullptr;
73 VPBasicBlock::iterator Point;
80 VPInsertPoint(VPBasicBlock *InsertBlock, VPBasicBlock::iterator InsertPoint) in VPInsertPoint()
86 VPBasicBlock *getBlock() const { return Block; } in getBlock()
87 VPBasicBlock::iterator getPoint() const { return Point; } in getPoint()
[all …]
DVPlanHCFGBuilder.cpp55 DenseMap<BasicBlock *, VPBasicBlock *> BB2VPBB;
63 void setVPBBPredsFromBB(VPBasicBlock *VPBB, BasicBlock *BB);
65 VPBasicBlock *getOrCreateVPBB(BasicBlock *BB);
70 void createVPInstructionsForVPBB(VPBasicBlock *VPBB, BasicBlock *BB);
83 void PlainCFGBuilder::setVPBBPredsFromBB(VPBasicBlock *VPBB, BasicBlock *BB) { in setVPBBPredsFromBB()
109 VPBasicBlock *PlainCFGBuilder::getOrCreateVPBB(BasicBlock *BB) { in getOrCreateVPBB()
117 VPBasicBlock *VPBB = new VPBasicBlock(BB->getName()); in getOrCreateVPBB()
192 void PlainCFGBuilder::createVPInstructionsForVPBB(VPBasicBlock *VPBB, in createVPInstructionsForVPBB()
255 VPBasicBlock *PreheaderVPBB = getOrCreateVPBB(PreheaderBB); in buildPlainCFG()
268 VPBasicBlock *VPBB = getOrCreateVPBB(BB); in buildPlainCFG()
[all …]
DVPlanPredicator.cpp37 VPValue *VPlanPredicator::getOrCreateNotPredicate(VPBasicBlock *PredBB, in getOrCreateNotPredicate()
38 VPBasicBlock *CurrBB) { in getOrCreateNotPredicate()
147 VPBasicBlock *CurrBB = cast<VPBasicBlock>(CurrBlock->getEntryBasicBlock()); in createOrPropagatePredicates()
169 assert(isa<VPBasicBlock>(PredBlock) && "Only BBs have multiple exits"); in createOrPropagatePredicates()
171 getOrCreateNotPredicate(cast<VPBasicBlock>(PredBlock), CurrBB); in createOrPropagatePredicates()
188 VPBasicBlock *EntryBlock = cast<VPBasicBlock>(Region->getEntry()); in predicateRegionRec()
DVPlan.cpp188 const VPBasicBlock *VPBlockBase::getEntryBasicBlock() const { in getEntryBasicBlock()
192 return cast<VPBasicBlock>(Block); in getEntryBasicBlock()
195 VPBasicBlock *VPBlockBase::getEntryBasicBlock() { in getEntryBasicBlock()
199 return cast<VPBasicBlock>(Block); in getEntryBasicBlock()
209 const VPBasicBlock *VPBlockBase::getExitBasicBlock() const { in getExitBasicBlock()
213 return cast<VPBasicBlock>(Block); in getExitBasicBlock()
216 VPBasicBlock *VPBlockBase::getExitBasicBlock() { in getExitBasicBlock()
220 return cast<VPBasicBlock>(Block); in getExitBasicBlock()
249 VPBasicBlock::iterator VPBasicBlock::getFirstNonPhi() { in getFirstNonPhi()
260 VPBasicBlock::createEmptyBasicBlock(VPTransformState::CFGState &CFG) { in createEmptyBasicBlock()
[all …]
DVPlanPredicator.h50 VPValue *getOrCreateNotPredicate(VPBasicBlock *PredBB, VPBasicBlock *CurrBB);
DVPlan.h58 class VPBasicBlock; variable
322 VPBasicBlock *PrevVPBB = nullptr;
334 SmallDenseMap<VPBasicBlock *, BasicBlock *> VPBB2IRBB;
338 SmallVector<VPBasicBlock *, 8> VPBBsToFix;
468 const VPBasicBlock *getEntryBasicBlock() const;
469 VPBasicBlock *getEntryBasicBlock();
474 const VPBasicBlock *getExitBasicBlock() const;
475 VPBasicBlock *getExitBasicBlock();
624 class VPRecipeBase : public ilist_node_with_parent<VPRecipeBase, VPBasicBlock> {
625 friend VPBasicBlock; variable
[all …]
DVPlanTransforms.cpp31 VPBasicBlock *VPBB = Base->getEntryBasicBlock(); in VPInstructionsToVPRecipes()
44 VPBasicBlock *VPBB = Base->getEntryBasicBlock(); in VPInstructionsToVPRecipes()
DVPRecipeBuilder.h152 VPBasicBlock *handleReplication(
153 Instruction *I, VFRange &Range, VPBasicBlock *VPBB,
DVPlanValue.h48 friend class VPBasicBlock; variable
299 class VPBasicBlock; variable
311 void assignSlots(const VPBasicBlock *VPBB);
DVPlanSLP.cpp123 VPBasicBlock *Parent = cast<VPInstruction>(Operands[0])->getParent(); in areVectorizable()
/external/llvm-project/llvm/unittests/Transforms/Vectorize/
DVPlanTest.cpp33 VPBasicBlock VPBB1; in TEST()
48 VPBasicBlock VPBB1; in TEST()
68 VPBasicBlock VPBB1; in TEST()
79 VPBasicBlock VPBB2; in TEST()
202 VPBasicBlock *VPBB1 = new VPBasicBlock(); in TEST()
203 VPBasicBlock *VPBB2 = new VPBasicBlock(); in TEST()
204 VPBasicBlock *VPBB3 = new VPBasicBlock(); in TEST()
205 VPBasicBlock *VPBB4 = new VPBasicBlock(); in TEST()
228 VPBasicBlock *R1BB1 = new VPBasicBlock(); in TEST()
229 VPBasicBlock *R1BB2 = new VPBasicBlock(); in TEST()
[all …]
DVPlanSlpTest.cpp102 VPBasicBlock *Body = Entry->getSingleSuccessor()->getEntryBasicBlock(); in TEST_F()
174 VPBasicBlock *Body = Entry->getSingleSuccessor()->getEntryBasicBlock(); in TEST_F()
246 VPBasicBlock *Body = Entry->getSingleSuccessor()->getEntryBasicBlock(); in TEST_F()
309 VPBasicBlock *Body = Entry->getSingleSuccessor()->getEntryBasicBlock(); in TEST_F()
321 VPBasicBlock *Body, in checkReorderExample()
446 VPBasicBlock *Body = Entry->getSingleSuccessor()->getEntryBasicBlock(); in TEST_F()
518 VPBasicBlock *Body = Entry->getSingleSuccessor()->getEntryBasicBlock(); in TEST_F()
590 VPBasicBlock *Body = Entry->getSingleSuccessor()->getEntryBasicBlock(); in TEST_F()
666 VPBasicBlock *Body = Entry->getSingleSuccessor()->getEntryBasicBlock(); in TEST_F()
727 VPBasicBlock *Body = Entry->getSingleSuccessor()->getEntryBasicBlock(); in TEST_F()
[all …]
DVPlanHCFGTest.cpp44 VPBasicBlock *Entry = Plan->getEntry()->getEntryBasicBlock(); in TEST_F()
50 VPBasicBlock *VecBB = Entry->getSingleSuccessor()->getEntryBasicBlock(); in TEST_F()
171 VPBasicBlock *VecBB = Entry->getSingleSuccessor()->getEntryBasicBlock(); in TEST_F()
/external/llvm-project/llvm/docs/Proposals/
DVectorizationPlan.rst117 VPBasicBlock and VPRegionBlock, see below. VPBlockBase models the hierarchical
123 :VPBasicBlock:
124 VPBasicBlock is a subclass of VPBlockBase, and serves as the leaves of the
127 basic-block originate from one or more VPBasicBlocks. VPBasicBlock holds a

12