Lines Matching refs:Block
1223 for (SIScheduleBlock *Block : CurrentBlocks) in createBlocksForVariant()
1224 Block->finalizeUnits(); in createBlocksForVariant()
1227 for (SIScheduleBlock *Block : CurrentBlocks) in createBlocksForVariant()
1228 Block->printDebug(true); in createBlocksForVariant()
1257 SIScheduleBlock *Block = CurrentBlocks[i]; in topologicalSort() local
1258 unsigned Degree = Block->getSuccs().size(); in topologicalSort()
1268 SIScheduleBlock *Block = CurrentBlocks[i]; in topologicalSort() local
1272 for (SIScheduleBlock* Pred : Block->getPreds()) { in topologicalSort()
1281 SIScheduleBlock *Block = CurrentBlocks[i]; in topologicalSort() local
1282 for (SIScheduleBlock* Pred : Block->getPreds()) { in topologicalSort()
1302 SIScheduleBlock *Block = CurrentBlocks[i]; in scheduleInsideBlocks() local
1303 Block->fastSchedule(); in scheduleInsideBlocks()
1318 SIScheduleBlock *Block = CurrentBlocks[BlockIndice]; in scheduleInsideBlocks() local
1319 std::vector<SUnit*> SUs = Block->getScheduledUnits(); in scheduleInsideBlocks()
1349 SIScheduleBlock *Block = CurrentBlocks[i]; in scheduleInsideBlocks() local
1350 std::vector<SUnit*> SUs = Block->getScheduledUnits(); in scheduleInsideBlocks()
1351 Block->schedule((*SUs.begin())->getInstr(), (*SUs.rbegin())->getInstr()); in scheduleInsideBlocks()
1369 for (SIScheduleBlock *Block : CurrentBlocks) in scheduleInsideBlocks()
1370 Block->printDebug(true); in scheduleInsideBlocks()
1379 SIScheduleBlock *Block = CurrentBlocks[BlockIndice]; in fillStats() local
1380 if (Block->getPreds().empty()) in fillStats()
1381 Block->Depth = 0; in fillStats()
1384 for (SIScheduleBlock *Pred : Block->getPreds()) { in fillStats()
1388 Block->Depth = Depth; in fillStats()
1394 SIScheduleBlock *Block = CurrentBlocks[BlockIndice]; in fillStats() local
1395 if (Block->getSuccs().empty()) in fillStats()
1396 Block->Height = 0; in fillStats()
1399 for (const auto &Succ : Block->getSuccs()) in fillStats()
1401 Block->Height = Height; in fillStats()
1426 for (SIScheduleBlock *Block : Blocks) { in SIScheduleBlockScheduler()
1427 for (unsigned Reg : Block->getInRegs()) { in SIScheduleBlockScheduler()
1430 for (SIScheduleBlock* Pred: Block->getPreds()) { in SIScheduleBlockScheduler()
1455 SIScheduleBlock *Block = Blocks[i]; in SIScheduleBlockScheduler() local
1456 BlockNumPredsLeft[i] = Block->getPreds().size(); in SIScheduleBlockScheduler()
1457 BlockNumSuccsLeft[i] = Block->getSuccs().size(); in SIScheduleBlockScheduler()
1462 SIScheduleBlock *Block = Blocks[i]; in SIScheduleBlockScheduler() local
1463 assert(Block->getID() == i); in SIScheduleBlockScheduler()
1477 SIScheduleBlock *Block = Blocks[ID]; in SIScheduleBlockScheduler() local
1478 const std::set<unsigned> &OutRegs = Block->getOutRegs(); in SIScheduleBlockScheduler()
1490 for (SIScheduleBlock *Block : Blocks) { in SIScheduleBlockScheduler()
1491 for (unsigned Reg : Block->getInRegs()) { in SIScheduleBlockScheduler()
1493 for (SIScheduleBlock* Pred: Block->getPreds()) { in SIScheduleBlockScheduler()
1509 SIScheduleBlock *Block = Blocks[i]; in SIScheduleBlockScheduler() local
1511 ReadyBlocks.push_back(Block); in SIScheduleBlockScheduler()
1515 while (SIScheduleBlock *Block = pickBlock()) { in SIScheduleBlockScheduler() local
1516 BlocksScheduled.push_back(Block); in SIScheduleBlockScheduler()
1517 blockScheduled(Block); in SIScheduleBlockScheduler()
1520 LLVM_DEBUG(dbgs() << "Block Order:"; for (SIScheduleBlock *Block in SIScheduleBlockScheduler()
1522 dbgs() << ' ' << Block->getID(); in SIScheduleBlockScheduler()
1576 SIScheduleBlock *Block; in pickBlock() local
1587 for (SIScheduleBlock *Block in pickBlock()
1589 << Block->getID() << ' '; in pickBlock()
1598 Cand.Block = nullptr; in pickBlock()
1602 TryCand.Block = *I; in pickBlock()
1603 TryCand.IsHighLatency = TryCand.Block->isHighLatencyBlock(); in pickBlock()
1605 checkRegUsageImpact(TryCand.Block->getInRegs(), in pickBlock()
1606 TryCand.Block->getOutRegs())[AMDGPU::RegisterPressureSets::VGPR_32]; in pickBlock()
1607 TryCand.NumSuccessors = TryCand.Block->getSuccs().size(); in pickBlock()
1609 TryCand.Block->getNumHighLatencySuccessors(); in pickBlock()
1612 LastPosHighLatencyParentScheduled[TryCand.Block->getID()] - in pickBlock()
1614 TryCand.Height = TryCand.Block->Height; in pickBlock()
1628 LLVM_DEBUG(dbgs() << "Best Current Choice: " << Cand.Block->getID() << ' ' in pickBlock()
1633 LLVM_DEBUG(dbgs() << "Picking: " << Cand.Block->getID() << '\n'; in pickBlock()
1641 Block = Cand.Block; in pickBlock()
1643 return Block; in pickBlock()
1658 void SIScheduleBlockScheduler::decreaseLiveRegs(SIScheduleBlock *Block, in decreaseLiveRegs() argument
1673 for (const auto &Block : Parent->getSuccs()) { in releaseBlockSuccs() local
1674 if (--BlockNumPredsLeft[Block.first->getID()] == 0) in releaseBlockSuccs()
1675 ReadyBlocks.push_back(Block.first); in releaseBlockSuccs()
1678 Block.second == SIScheduleBlockLinkKind::Data) in releaseBlockSuccs()
1679 LastPosHighLatencyParentScheduled[Block.first->getID()] = NumBlockScheduled; in releaseBlockSuccs()
1683 void SIScheduleBlockScheduler::blockScheduled(SIScheduleBlock *Block) { in blockScheduled() argument
1684 decreaseLiveRegs(Block, Block->getInRegs()); in blockScheduled()
1685 addLiveRegs(Block->getOutRegs()); in blockScheduled()
1686 releaseBlockSuccs(Block); in blockScheduled()
1687 for (const auto &RegP : LiveOutRegsNumUsages[Block->getID()]) { in blockScheduled()
1693 if (LastPosHighLatencyParentScheduled[Block->getID()] > in blockScheduled()
1696 LastPosHighLatencyParentScheduled[Block->getID()]; in blockScheduled()
1743 for (SIScheduleBlock *Block : ScheduledBlocks) { in scheduleVariant()
1744 std::vector<SUnit*> SUs = Block->getScheduledUnits(); in scheduleVariant()