mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-14 16:33:28 +00:00
Remove the CycleBound computation code from the ScheduleDAGRRList
schedulers. This doesn't have much immediate impact because targets that use these schedulers by default don't yet provide pipeline information. This code also didn't have the benefit of register pressure information. Also, removing it will avoid problems with list-burr suddenly starting to do latency-oriented scheduling on x86 when we start providing pipeline data, which would increase spilling. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@59775 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
08c85d1209
commit
f209c2cc30
@ -270,19 +270,6 @@ void ScheduleDAGRRList::ReleasePred(SUnit *SU, SUnit *PredSU, bool isChain) {
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Compute how many cycles it will be before this actually becomes
|
|
||||||
// available. This is the max of the start time of all predecessors plus
|
|
||||||
// their latencies.
|
|
||||||
// If this is a token edge, we don't need to wait for the latency of the
|
|
||||||
// preceeding instruction (e.g. a long-latency load) unless there is also
|
|
||||||
// some other data dependence.
|
|
||||||
unsigned PredDoneCycle = SU->Cycle;
|
|
||||||
if (!isChain)
|
|
||||||
PredDoneCycle += PredSU->Latency;
|
|
||||||
else if (SU->Latency)
|
|
||||||
PredDoneCycle += 1;
|
|
||||||
PredSU->CycleBound = std::max(PredSU->CycleBound, PredDoneCycle);
|
|
||||||
|
|
||||||
if (PredSU->NumSuccsLeft == 0) {
|
if (PredSU->NumSuccsLeft == 0) {
|
||||||
PredSU->isAvailable = true;
|
PredSU->isAvailable = true;
|
||||||
AvailableQueue->push(PredSU);
|
AvailableQueue->push(PredSU);
|
||||||
@ -339,22 +326,12 @@ void ScheduleDAGRRList::ScheduleNodeBottomUp(SUnit *SU, unsigned CurCycle) {
|
|||||||
/// unscheduled, incrcease the succ left count of its predecessors. Remove
|
/// unscheduled, incrcease the succ left count of its predecessors. Remove
|
||||||
/// them from AvailableQueue if necessary.
|
/// them from AvailableQueue if necessary.
|
||||||
void ScheduleDAGRRList::CapturePred(SUnit *PredSU, SUnit *SU, bool isChain) {
|
void ScheduleDAGRRList::CapturePred(SUnit *PredSU, SUnit *SU, bool isChain) {
|
||||||
unsigned CycleBound = 0;
|
|
||||||
for (SUnit::succ_iterator I = PredSU->Succs.begin(), E = PredSU->Succs.end();
|
|
||||||
I != E; ++I) {
|
|
||||||
if (I->Dep == SU)
|
|
||||||
continue;
|
|
||||||
CycleBound = std::max(CycleBound,
|
|
||||||
I->Dep->Cycle + PredSU->Latency);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (PredSU->isAvailable) {
|
if (PredSU->isAvailable) {
|
||||||
PredSU->isAvailable = false;
|
PredSU->isAvailable = false;
|
||||||
if (!PredSU->isPending)
|
if (!PredSU->isPending)
|
||||||
AvailableQueue->remove(PredSU);
|
AvailableQueue->remove(PredSU);
|
||||||
}
|
}
|
||||||
|
|
||||||
PredSU->CycleBound = CycleBound;
|
|
||||||
++PredSU->NumSuccsLeft;
|
++PredSU->NumSuccsLeft;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -948,13 +925,11 @@ void ScheduleDAGRRList::ListScheduleBottomUp() {
|
|||||||
LRegsMap.clear();
|
LRegsMap.clear();
|
||||||
SUnit *CurSU = AvailableQueue->pop();
|
SUnit *CurSU = AvailableQueue->pop();
|
||||||
while (CurSU) {
|
while (CurSU) {
|
||||||
if (CurSU->CycleBound <= CurCycle) {
|
|
||||||
SmallVector<unsigned, 4> LRegs;
|
SmallVector<unsigned, 4> LRegs;
|
||||||
if (!DelayForLiveRegsBottomUp(CurSU, LRegs))
|
if (!DelayForLiveRegsBottomUp(CurSU, LRegs))
|
||||||
break;
|
break;
|
||||||
Delayed = true;
|
Delayed = true;
|
||||||
LRegsMap.insert(std::make_pair(CurSU, LRegs));
|
LRegsMap.insert(std::make_pair(CurSU, LRegs));
|
||||||
}
|
|
||||||
|
|
||||||
CurSU->isPending = true; // This SU is not in AvailableQueue right now.
|
CurSU->isPending = true; // This SU is not in AvailableQueue right now.
|
||||||
NotReady.push_back(CurSU);
|
NotReady.push_back(CurSU);
|
||||||
@ -1083,19 +1058,6 @@ void ScheduleDAGRRList::ReleaseSucc(SUnit *SU, SUnit *SuccSU, bool isChain) {
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Compute how many cycles it will be before this actually becomes
|
|
||||||
// available. This is the max of the start time of all predecessors plus
|
|
||||||
// their latencies.
|
|
||||||
// If this is a token edge, we don't need to wait for the latency of the
|
|
||||||
// preceeding instruction (e.g. a long-latency load) unless there is also
|
|
||||||
// some other data dependence.
|
|
||||||
unsigned PredDoneCycle = SU->Cycle;
|
|
||||||
if (!isChain)
|
|
||||||
PredDoneCycle += SU->Latency;
|
|
||||||
else if (SU->Latency)
|
|
||||||
PredDoneCycle += 1;
|
|
||||||
SuccSU->CycleBound = std::max(SuccSU->CycleBound, PredDoneCycle);
|
|
||||||
|
|
||||||
if (SuccSU->NumPredsLeft == 0) {
|
if (SuccSU->NumPredsLeft == 0) {
|
||||||
SuccSU->isAvailable = true;
|
SuccSU->isAvailable = true;
|
||||||
AvailableQueue->push(SuccSU);
|
AvailableQueue->push(SuccSU);
|
||||||
@ -1137,18 +1099,9 @@ void ScheduleDAGRRList::ListScheduleTopDown() {
|
|||||||
|
|
||||||
// While Available queue is not empty, grab the node with the highest
|
// While Available queue is not empty, grab the node with the highest
|
||||||
// priority. If it is not ready put it back. Schedule the node.
|
// priority. If it is not ready put it back. Schedule the node.
|
||||||
std::vector<SUnit*> NotReady;
|
|
||||||
Sequence.reserve(SUnits.size());
|
Sequence.reserve(SUnits.size());
|
||||||
while (!AvailableQueue->empty()) {
|
while (!AvailableQueue->empty()) {
|
||||||
SUnit *CurSU = AvailableQueue->pop();
|
SUnit *CurSU = AvailableQueue->pop();
|
||||||
while (CurSU && CurSU->CycleBound > CurCycle) {
|
|
||||||
NotReady.push_back(CurSU);
|
|
||||||
CurSU = AvailableQueue->pop();
|
|
||||||
}
|
|
||||||
|
|
||||||
// Add the nodes that aren't ready back onto the available list.
|
|
||||||
AvailableQueue->push_all(NotReady);
|
|
||||||
NotReady.clear();
|
|
||||||
|
|
||||||
if (CurSU)
|
if (CurSU)
|
||||||
ScheduleNodeTopDown(CurSU, CurCycle);
|
ScheduleNodeTopDown(CurSU, CurCycle);
|
||||||
@ -1433,9 +1386,6 @@ bool bu_ls_rr_sort::operator()(const SUnit *left, const SUnit *right) const {
|
|||||||
if (left->Depth != right->Depth)
|
if (left->Depth != right->Depth)
|
||||||
return left->Depth < right->Depth;
|
return left->Depth < right->Depth;
|
||||||
|
|
||||||
if (left->CycleBound != right->CycleBound)
|
|
||||||
return left->CycleBound > right->CycleBound;
|
|
||||||
|
|
||||||
assert(left->NodeQueueId && right->NodeQueueId &&
|
assert(left->NodeQueueId && right->NodeQueueId &&
|
||||||
"NodeQueueId cannot be zero");
|
"NodeQueueId cannot be zero");
|
||||||
return (left->NodeQueueId > right->NodeQueueId);
|
return (left->NodeQueueId > right->NodeQueueId);
|
||||||
@ -1636,9 +1586,6 @@ bool td_ls_rr_sort::operator()(const SUnit *left, const SUnit *right) const {
|
|||||||
if (left->NumSuccsLeft != right->NumSuccsLeft)
|
if (left->NumSuccsLeft != right->NumSuccsLeft)
|
||||||
return left->NumSuccsLeft > right->NumSuccsLeft;
|
return left->NumSuccsLeft > right->NumSuccsLeft;
|
||||||
|
|
||||||
if (left->CycleBound != right->CycleBound)
|
|
||||||
return left->CycleBound > right->CycleBound;
|
|
||||||
|
|
||||||
assert(left->NodeQueueId && right->NodeQueueId &&
|
assert(left->NodeQueueId && right->NodeQueueId &&
|
||||||
"NodeQueueId cannot be zero");
|
"NodeQueueId cannot be zero");
|
||||||
return (left->NodeQueueId > right->NodeQueueId);
|
return (left->NodeQueueId > right->NodeQueueId);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user