1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-11-25 04:02:41 +01:00

Revert "[NFC][ScheduleDAG] Remove unused EntrySU SUnit"

This reverts commit 0345d88de654259ae90494bf9b015416e2cccacb.

Google internal backend uses EntrySU, we are looking into removing
dependency on it.

Differential Revision: https://reviews.llvm.org/D88018
This commit is contained in:
Alexander Belyaev 2020-09-21 13:18:39 +02:00
parent 77b449d743
commit da4afc0c02
13 changed files with 48 additions and 25 deletions

View File

@ -234,7 +234,7 @@ public:
virtual void leaveMBB() {}; virtual void leaveMBB() {};
/// Notify this strategy that all roots have been released (including those /// Notify this strategy that all roots have been released (including those
/// that depend on ExitSU). /// that depend on EntrySU or ExitSU).
virtual void registerRoots() {} virtual void registerRoots() {}
/// Pick the next node to schedule, or return NULL. Set IsTopNode to true to /// Pick the next node to schedule, or return NULL. Set IsTopNode to true to

View File

@ -560,6 +560,7 @@ class TargetRegisterInfo;
MachineFunction &MF; ///< Machine function MachineFunction &MF; ///< Machine function
MachineRegisterInfo &MRI; ///< Virtual/real register map MachineRegisterInfo &MRI; ///< Virtual/real register map
std::vector<SUnit> SUnits; ///< The scheduling units. std::vector<SUnit> SUnits; ///< The scheduling units.
SUnit EntrySU; ///< Special node for the region entry.
SUnit ExitSU; ///< Special node for the region exit. SUnit ExitSU; ///< Special node for the region exit.
#ifdef NDEBUG #ifdef NDEBUG

View File

@ -680,7 +680,7 @@ void ScheduleDAGMI::releasePred(SUnit *SU, SDep *PredEdge) {
PredSU->BotReadyCycle = SU->BotReadyCycle + PredEdge->getLatency(); PredSU->BotReadyCycle = SU->BotReadyCycle + PredEdge->getLatency();
--PredSU->NumSuccsLeft; --PredSU->NumSuccsLeft;
if (PredSU->NumSuccsLeft == 0) if (PredSU->NumSuccsLeft == 0 && PredSU != &EntrySU)
SchedImpl->releaseBottomNode(PredSU); SchedImpl->releaseBottomNode(PredSU);
} }
@ -853,7 +853,7 @@ void ScheduleDAGMI::initQueues(ArrayRef<SUnit*> TopRoots,
NextClusterSucc = nullptr; NextClusterSucc = nullptr;
NextClusterPred = nullptr; NextClusterPred = nullptr;
// Release all DAG roots for scheduling, not including ExitSU. // Release all DAG roots for scheduling, not including EntrySU/ExitSU.
// //
// Nodes with unreleased weak edges can still be roots. // Nodes with unreleased weak edges can still be roots.
// Release top roots in forward order. // Release top roots in forward order.
@ -867,6 +867,7 @@ void ScheduleDAGMI::initQueues(ArrayRef<SUnit*> TopRoots,
SchedImpl->releaseBottomNode(*I); SchedImpl->releaseBottomNode(*I);
} }
releaseSuccessors(&EntrySU);
releasePredecessors(&ExitSU); releasePredecessors(&ExitSU);
SchedImpl->registerRoots(); SchedImpl->registerRoots();
@ -1167,6 +1168,8 @@ void ScheduleDAGMILive::updatePressureDiffs(
void ScheduleDAGMILive::dump() const { void ScheduleDAGMILive::dump() const {
#if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP) #if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP)
if (EntrySU.getInstr() != nullptr)
dumpNodeAll(EntrySU);
for (const SUnit &SU : SUnits) { for (const SUnit &SU : SUnits) {
dumpNodeAll(SU); dumpNodeAll(SU);
if (ShouldTrackPressure) { if (ShouldTrackPressure) {

View File

@ -109,21 +109,23 @@ static bool fuseInstructionPair(ScheduleDAGInstrs &DAG, SUnit &FirstSU,
// Make the FirstSU also dependent on the dependencies of the SecondSU to // Make the FirstSU also dependent on the dependencies of the SecondSU to
// prevent them from being scheduled between the FirstSU and the SecondSU. // prevent them from being scheduled between the FirstSU and the SecondSU.
for (const SDep &SI : SecondSU.Preds) { if (&FirstSU != &DAG.EntrySU) {
SUnit *SU = SI.getSUnit(); for (const SDep &SI : SecondSU.Preds) {
if (SI.isWeak() || isHazard(SI) || &FirstSU == SU || FirstSU.isSucc(SU)) SUnit *SU = SI.getSUnit();
continue; if (SI.isWeak() || isHazard(SI) || &FirstSU == SU || FirstSU.isSucc(SU))
LLVM_DEBUG(dbgs() << " Bind "; DAG.dumpNodeName(*SU); dbgs() << " - "; continue;
DAG.dumpNodeName(FirstSU); dbgs() << '\n';); LLVM_DEBUG(dbgs() << " Bind "; DAG.dumpNodeName(*SU); dbgs() << " - ";
DAG.addEdge(&FirstSU, SDep(SU, SDep::Artificial)); DAG.dumpNodeName(FirstSU); dbgs() << '\n';);
} DAG.addEdge(&FirstSU, SDep(SU, SDep::Artificial));
// ExitSU comes last by design, which acts like an implicit dependency }
// between ExitSU and any bottom root in the graph. We should transfer // ExitSU comes last by design, which acts like an implicit dependency
// this to FirstSU as well. // between ExitSU and any bottom root in the graph. We should transfer
if (&SecondSU == &DAG.ExitSU) { // this to FirstSU as well.
for (SUnit &SU : DAG.SUnits) { if (&SecondSU == &DAG.ExitSU) {
if (SU.Succs.empty()) for (SUnit &SU : DAG.SUnits) {
DAG.addEdge(&FirstSU, SDep(&SU, SDep::Artificial)); if (SU.Succs.empty())
DAG.addEdge(&FirstSU, SDep(&SU, SDep::Artificial));
}
} }
} }

View File

@ -527,6 +527,9 @@ void SchedulePostRATDList::ListScheduleTopDown() {
// blocks are a single region). // blocks are a single region).
HazardRec->Reset(); HazardRec->Reset();
// Release any successors of the special Entry node.
ReleaseSuccessors(&EntrySU);
// Add all leaves to Available queue. // Add all leaves to Available queue.
for (unsigned i = 0, e = SUnits.size(); i != e; ++i) { for (unsigned i = 0, e = SUnits.size(); i != e; ++i) {
// It is available if it has no predecessors. // It is available if it has no predecessors.

View File

@ -63,6 +63,7 @@ ScheduleDAG::~ScheduleDAG() = default;
void ScheduleDAG::clearDAG() { void ScheduleDAG::clearDAG() {
SUnits.clear(); SUnits.clear();
EntrySU = SUnit();
ExitSU = SUnit(); ExitSU = SUnit();
} }
@ -351,7 +352,9 @@ LLVM_DUMP_METHOD void SUnit::dumpAttributes() const {
} }
LLVM_DUMP_METHOD void ScheduleDAG::dumpNodeName(const SUnit &SU) const { LLVM_DUMP_METHOD void ScheduleDAG::dumpNodeName(const SUnit &SU) const {
if (&SU == &ExitSU) if (&SU == &EntrySU)
dbgs() << "EntrySU";
else if (&SU == &ExitSU)
dbgs() << "ExitSU"; dbgs() << "ExitSU";
else else
dbgs() << "SU(" << SU.NodeNum << ")"; dbgs() << "SU(" << SU.NodeNum << ")";
@ -653,7 +656,7 @@ std::vector<int> ScheduleDAGTopologicalSort::GetSubGraph(const SUnit &StartSU,
for (int I = SU->Preds.size()-1; I >= 0; --I) { for (int I = SU->Preds.size()-1; I >= 0; --I) {
const SUnit *Pred = SU->Preds[I].getSUnit(); const SUnit *Pred = SU->Preds[I].getSUnit();
unsigned s = Pred->NodeNum; unsigned s = Pred->NodeNum;
// Edges to non-SUnits are allowed but ignored (e.g. ExitSU). // Edges to non-SUnits are allowed but ignored (e.g. EntrySU).
if (Pred->isBoundaryNode()) if (Pred->isBoundaryNode())
continue; continue;
if (Node2Index[s] == LowerBound) { if (Node2Index[s] == LowerBound) {

View File

@ -1167,6 +1167,8 @@ void ScheduleDAGInstrs::dumpNode(const SUnit &SU) const {
void ScheduleDAGInstrs::dump() const { void ScheduleDAGInstrs::dump() const {
#if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP) #if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP)
if (EntrySU.getInstr() != nullptr)
dumpNodeAll(EntrySU);
for (const SUnit &SU : SUnits) for (const SUnit &SU : SUnits)
dumpNodeAll(SU); dumpNodeAll(SU);
if (ExitSU.getInstr() != nullptr) if (ExitSU.getInstr() != nullptr)
@ -1177,7 +1179,9 @@ void ScheduleDAGInstrs::dump() const {
std::string ScheduleDAGInstrs::getGraphNodeLabel(const SUnit *SU) const { std::string ScheduleDAGInstrs::getGraphNodeLabel(const SUnit *SU) const {
std::string s; std::string s;
raw_string_ostream oss(s); raw_string_ostream oss(s);
if (SU == &ExitSU) if (SU == &EntrySU)
oss << "<entry>";
else if (SU == &ExitSU)
oss << "<exit>"; oss << "<exit>";
else else
SU->getInstr()->print(oss, /*IsStandalone=*/true); SU->getInstr()->print(oss, /*IsStandalone=*/true);

View File

@ -150,8 +150,8 @@ void ScheduleDAGFast::ReleasePred(SUnit *SU, SDep *PredEdge) {
--PredSU->NumSuccsLeft; --PredSU->NumSuccsLeft;
// If all the node's successors are scheduled, this node is ready // If all the node's successors are scheduled, this node is ready
// to be scheduled. // to be scheduled. Ignore the special EntrySU node.
if (PredSU->NumSuccsLeft == 0) { if (PredSU->NumSuccsLeft == 0 && PredSU != &EntrySU) {
PredSU->isAvailable = true; PredSU->isAvailable = true;
AvailableQueue.push(PredSU); AvailableQueue.push(PredSU);
} }

View File

@ -415,8 +415,8 @@ void ScheduleDAGRRList::ReleasePred(SUnit *SU, const SDep *PredEdge) {
} }
// If all the node's successors are scheduled, this node is ready // If all the node's successors are scheduled, this node is ready
// to be scheduled. // to be scheduled. Ignore the special EntrySU node.
if (PredSU->NumSuccsLeft == 0) { if (PredSU->NumSuccsLeft == 0 && PredSU != &EntrySU) {
PredSU->isAvailable = true; PredSU->isAvailable = true;
unsigned Height = PredSU->getHeight(); unsigned Height = PredSU->getHeight();

View File

@ -696,6 +696,8 @@ void ScheduleDAGSDNodes::dumpNode(const SUnit &SU) const {
void ScheduleDAGSDNodes::dump() const { void ScheduleDAGSDNodes::dump() const {
#if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP) #if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP)
if (EntrySU.getNode() != nullptr)
dumpNodeAll(EntrySU);
for (const SUnit &SU : SUnits) for (const SUnit &SU : SUnits)
dumpNodeAll(SU); dumpNodeAll(SU);
if (ExitSU.getNode() != nullptr) if (ExitSU.getNode() != nullptr)

View File

@ -166,6 +166,9 @@ void ScheduleDAGVLIW::scheduleNodeTopDown(SUnit *SU, unsigned CurCycle) {
void ScheduleDAGVLIW::listScheduleTopDown() { void ScheduleDAGVLIW::listScheduleTopDown() {
unsigned CurCycle = 0; unsigned CurCycle = 0;
// Release any successors of the special Entry node.
releaseSuccessors(&EntrySU);
// All leaves to AvailableQueue. // All leaves to AvailableQueue.
for (unsigned i = 0, e = SUnits.size(); i != e; ++i) { for (unsigned i = 0, e = SUnits.size(); i != e; ++i) {
// It is available if it has no predecessors. // It is available if it has no predecessors.

View File

@ -248,6 +248,7 @@ GCNMinRegScheduler::schedule(ArrayRef<const SUnit*> TopRoots,
for (auto SU : TopRoots) { for (auto SU : TopRoots) {
RQ.push_back(*new (Alloc.Allocate()) Candidate(SU, StepNo)); RQ.push_back(*new (Alloc.Allocate()) Candidate(SU, StepNo));
} }
releaseSuccessors(&DAG.EntrySU, StepNo);
while (!RQ.empty()) { while (!RQ.empty()) {
LLVM_DEBUG(dbgs() << "\n=== Picking candidate, Step = " << StepNo LLVM_DEBUG(dbgs() << "\n=== Picking candidate, Step = " << StepNo

View File

@ -455,6 +455,7 @@ public:
MachineRegisterInfo *getMRI() { return &MRI; } MachineRegisterInfo *getMRI() { return &MRI; }
const TargetRegisterInfo *getTRI() { return TRI; } const TargetRegisterInfo *getTRI() { return TRI; }
ScheduleDAGTopologicalSort *GetTopo() { return &Topo; } ScheduleDAGTopologicalSort *GetTopo() { return &Topo; }
SUnit &getEntrySU() { return EntrySU; }
SUnit& getExitSU() { return ExitSU; } SUnit& getExitSU() { return ExitSU; }
void restoreSULinksLeft(); void restoreSULinksLeft();