/external/swiftshader/third_party/llvm-10.0/llvm/lib/Transforms/Vectorize/ |
D | LoopVectorizationPlanner.h | 37 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 …]
|
D | VPlanHCFGBuilder.cpp | 55 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 …]
|
D | VPlanPredicator.cpp | 37 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()
|
D | VPlan.cpp | 60 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 …]
|
D | VPRecipeBuilder.h | 119 bool tryToWiden(Instruction *I, VPBasicBlock *VPBB, VFRange &Range); 135 VPBasicBlock *VPBB); 143 VPBasicBlock *handleReplication( 144 Instruction *I, VFRange &Range, VPBasicBlock *VPBB,
|
D | VPlan.h | 60 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 …]
|
D | VPlanPredicator.h | 50 VPValue *getOrCreateNotPredicate(VPBasicBlock *PredBB, VPBasicBlock *CurrBB);
|
D | VPlanTransforms.cpp | 31 VPBasicBlock *VPBB = Base->getEntryBasicBlock(); in VPInstructionsToVPRecipes() 43 VPBasicBlock *VPBB = Base->getEntryBasicBlock(); in VPInstructionsToVPRecipes()
|
D | VPlanValue.h | 41 friend class VPBasicBlock; variable
|
D | LoopVectorize.cpp | 6864 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 …]
|
D | VPlanSLP.cpp | 123 VPBasicBlock *Parent = cast<VPInstruction>(Operands[0])->getParent(); in areVectorizable()
|
/external/llvm-project/llvm/lib/Transforms/Vectorize/ |
D | LoopVectorizationPlanner.h | 41 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 …]
|
D | VPlanHCFGBuilder.cpp | 55 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 …]
|
D | VPlanPredicator.cpp | 37 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()
|
D | VPlan.cpp | 188 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 …]
|
D | VPlanPredicator.h | 50 VPValue *getOrCreateNotPredicate(VPBasicBlock *PredBB, VPBasicBlock *CurrBB);
|
D | VPlan.h | 58 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 …]
|
D | VPlanTransforms.cpp | 31 VPBasicBlock *VPBB = Base->getEntryBasicBlock(); in VPInstructionsToVPRecipes() 44 VPBasicBlock *VPBB = Base->getEntryBasicBlock(); in VPInstructionsToVPRecipes()
|
D | VPRecipeBuilder.h | 152 VPBasicBlock *handleReplication( 153 Instruction *I, VFRange &Range, VPBasicBlock *VPBB,
|
D | VPlanValue.h | 48 friend class VPBasicBlock; variable 299 class VPBasicBlock; variable 311 void assignSlots(const VPBasicBlock *VPBB);
|
D | VPlanSLP.cpp | 123 VPBasicBlock *Parent = cast<VPInstruction>(Operands[0])->getParent(); in areVectorizable()
|
/external/llvm-project/llvm/unittests/Transforms/Vectorize/ |
D | VPlanTest.cpp | 33 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 …]
|
D | VPlanSlpTest.cpp | 102 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 …]
|
D | VPlanHCFGTest.cpp | 44 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/ |
D | VectorizationPlan.rst | 117 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
|