mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-22 10:33:23 +00:00
Post-RA scheduler compile time fix. Quadratic computation of DAG node depth.
The post-ra scheduler was explicitly updating the depth of a node's successors after scheduling it, regardless of whether the successor was ready. This is quadratic for DAGs with transitively redundant edges. I simply removed the useless update of depth, which is lazilly computed later. Fixes <rdar://problem/9044332> compiler takes way too long to build TextInput. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@130992 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
31c5d05a26
commit
15ab3594eb
@ -540,10 +540,16 @@ void SchedulePostRATDList::ReleaseSucc(SUnit *SU, SDep *SuccEdge) {
|
|||||||
#endif
|
#endif
|
||||||
--SuccSU->NumPredsLeft;
|
--SuccSU->NumPredsLeft;
|
||||||
|
|
||||||
// Compute how many cycles it will be before this actually becomes
|
// Standard scheduler algorithms will recomute the depth of the successor
|
||||||
// available. This is the max of the start time of all predecessors plus
|
// here as such:
|
||||||
// their latencies.
|
// SuccSU->setDepthToAtLeast(SU->getDepth() + SuccEdge->getLatency());
|
||||||
SuccSU->setDepthToAtLeast(SU->getDepth() + SuccEdge->getLatency());
|
//
|
||||||
|
// However, we lazily compute node depth instead. Note that
|
||||||
|
// ScheduleNodeTopDown has already updated the depth of this node which causes
|
||||||
|
// all descendents to be marked dirty. Setting the successor depth explicitly
|
||||||
|
// here would cause depth to be recomputed for all its ancestors. If the
|
||||||
|
// successor is not yet ready (because of a transitively redundant edge) then
|
||||||
|
// this causes depth computation to be quadratic in the size of the DAG.
|
||||||
|
|
||||||
// If all the node's predecessors are scheduled, this node is ready
|
// If all the node's predecessors are scheduled, this node is ready
|
||||||
// to be scheduled. Ignore the special ExitSU node.
|
// to be scheduled. Ignore the special ExitSU node.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user