Lines Matching refs:Block

1215   for (SIScheduleBlock *Block : CurrentBlocks)  in createBlocksForVariant()
1216 Block->finalizeUnits(); in createBlocksForVariant()
1219 for (SIScheduleBlock *Block : CurrentBlocks) in createBlocksForVariant()
1220 Block->printDebug(true); in createBlocksForVariant()
1249 SIScheduleBlock *Block = CurrentBlocks[i]; in topologicalSort() local
1250 unsigned Degree = Block->getSuccs().size(); in topologicalSort()
1260 SIScheduleBlock *Block = CurrentBlocks[i]; in topologicalSort() local
1264 for (SIScheduleBlock* Pred : Block->getPreds()) { in topologicalSort()
1273 SIScheduleBlock *Block = CurrentBlocks[i]; in topologicalSort() local
1274 for (SIScheduleBlock* Pred : Block->getPreds()) { in topologicalSort()
1294 SIScheduleBlock *Block = CurrentBlocks[i]; in scheduleInsideBlocks() local
1295 Block->fastSchedule(); in scheduleInsideBlocks()
1310 SIScheduleBlock *Block = CurrentBlocks[BlockIndice]; in scheduleInsideBlocks() local
1311 std::vector<SUnit*> SUs = Block->getScheduledUnits(); in scheduleInsideBlocks()
1341 SIScheduleBlock *Block = CurrentBlocks[i]; in scheduleInsideBlocks() local
1342 std::vector<SUnit*> SUs = Block->getScheduledUnits(); in scheduleInsideBlocks()
1343 Block->schedule((*SUs.begin())->getInstr(), (*SUs.rbegin())->getInstr()); in scheduleInsideBlocks()
1361 for (SIScheduleBlock *Block : CurrentBlocks) in scheduleInsideBlocks()
1362 Block->printDebug(true); in scheduleInsideBlocks()
1371 SIScheduleBlock *Block = CurrentBlocks[BlockIndice]; in fillStats() local
1372 if (Block->getPreds().empty()) in fillStats()
1373 Block->Depth = 0; in fillStats()
1376 for (SIScheduleBlock *Pred : Block->getPreds()) { in fillStats()
1380 Block->Depth = Depth; in fillStats()
1386 SIScheduleBlock *Block = CurrentBlocks[BlockIndice]; in fillStats() local
1387 if (Block->getSuccs().empty()) in fillStats()
1388 Block->Height = 0; in fillStats()
1391 for (const auto &Succ : Block->getSuccs()) in fillStats()
1393 Block->Height = Height; in fillStats()
1418 for (SIScheduleBlock *Block : Blocks) { in SIScheduleBlockScheduler()
1419 for (unsigned Reg : Block->getInRegs()) { in SIScheduleBlockScheduler()
1422 for (SIScheduleBlock* Pred: Block->getPreds()) { in SIScheduleBlockScheduler()
1447 SIScheduleBlock *Block = Blocks[i]; in SIScheduleBlockScheduler() local
1448 BlockNumPredsLeft[i] = Block->getPreds().size(); in SIScheduleBlockScheduler()
1449 BlockNumSuccsLeft[i] = Block->getSuccs().size(); in SIScheduleBlockScheduler()
1454 SIScheduleBlock *Block = Blocks[i]; in SIScheduleBlockScheduler() local
1455 assert(Block->getID() == i); in SIScheduleBlockScheduler()
1469 SIScheduleBlock *Block = Blocks[ID]; in SIScheduleBlockScheduler() local
1470 const std::set<unsigned> &OutRegs = Block->getOutRegs(); in SIScheduleBlockScheduler()
1482 for (SIScheduleBlock *Block : Blocks) { in SIScheduleBlockScheduler()
1483 for (unsigned Reg : Block->getInRegs()) { in SIScheduleBlockScheduler()
1485 for (SIScheduleBlock* Pred: Block->getPreds()) { in SIScheduleBlockScheduler()
1501 SIScheduleBlock *Block = Blocks[i]; in SIScheduleBlockScheduler() local
1503 ReadyBlocks.push_back(Block); in SIScheduleBlockScheduler()
1507 while (SIScheduleBlock *Block = pickBlock()) { in SIScheduleBlockScheduler() local
1508 BlocksScheduled.push_back(Block); in SIScheduleBlockScheduler()
1509 blockScheduled(Block); in SIScheduleBlockScheduler()
1512 LLVM_DEBUG(dbgs() << "Block Order:"; for (SIScheduleBlock *Block in SIScheduleBlockScheduler()
1514 dbgs() << ' ' << Block->getID(); in SIScheduleBlockScheduler()
1568 SIScheduleBlock *Block; in pickBlock() local
1579 for (SIScheduleBlock *Block in pickBlock()
1581 << Block->getID() << ' '; in pickBlock()
1590 Cand.Block = nullptr; in pickBlock()
1594 TryCand.Block = *I; in pickBlock()
1595 TryCand.IsHighLatency = TryCand.Block->isHighLatencyBlock(); in pickBlock()
1597 checkRegUsageImpact(TryCand.Block->getInRegs(), in pickBlock()
1598 TryCand.Block->getOutRegs())[AMDGPU::RegisterPressureSets::VGPR_32]; in pickBlock()
1599 TryCand.NumSuccessors = TryCand.Block->getSuccs().size(); in pickBlock()
1601 TryCand.Block->getNumHighLatencySuccessors(); in pickBlock()
1604 LastPosHighLatencyParentScheduled[TryCand.Block->getID()] - in pickBlock()
1606 TryCand.Height = TryCand.Block->Height; in pickBlock()
1620 LLVM_DEBUG(dbgs() << "Best Current Choice: " << Cand.Block->getID() << ' ' in pickBlock()
1625 LLVM_DEBUG(dbgs() << "Picking: " << Cand.Block->getID() << '\n'; in pickBlock()
1633 Block = Cand.Block; in pickBlock()
1635 return Block; in pickBlock()
1650 void SIScheduleBlockScheduler::decreaseLiveRegs(SIScheduleBlock *Block, in decreaseLiveRegs() argument
1665 for (const auto &Block : Parent->getSuccs()) { in releaseBlockSuccs() local
1666 if (--BlockNumPredsLeft[Block.first->getID()] == 0) in releaseBlockSuccs()
1667 ReadyBlocks.push_back(Block.first); in releaseBlockSuccs()
1670 Block.second == SIScheduleBlockLinkKind::Data) in releaseBlockSuccs()
1671 LastPosHighLatencyParentScheduled[Block.first->getID()] = NumBlockScheduled; in releaseBlockSuccs()
1675 void SIScheduleBlockScheduler::blockScheduled(SIScheduleBlock *Block) { in blockScheduled() argument
1676 decreaseLiveRegs(Block, Block->getInRegs()); in blockScheduled()
1677 addLiveRegs(Block->getOutRegs()); in blockScheduled()
1678 releaseBlockSuccs(Block); in blockScheduled()
1679 for (const auto &RegP : LiveOutRegsNumUsages[Block->getID()]) { in blockScheduled()
1685 if (LastPosHighLatencyParentScheduled[Block->getID()] > in blockScheduled()
1688 LastPosHighLatencyParentScheduled[Block->getID()]; in blockScheduled()
1735 for (SIScheduleBlock *Block : ScheduledBlocks) { in scheduleVariant()
1736 std::vector<SUnit*> SUs = Block->getScheduledUnits(); in scheduleVariant()