diff options
author | Evan Cheng <evan.cheng@apple.com> | 2007-11-06 08:44:59 +0000 |
---|---|---|
committer | Evan Cheng <evan.cheng@apple.com> | 2007-11-06 08:44:59 +0000 |
commit | 1fd15ba9614e81a3b9cc5cd9631ca76c845159b2 (patch) | |
tree | 7602135e9c02e304229095f04511fe5aa84705eb /lib/CodeGen/SelectionDAG/ScheduleDAGRRList.cpp | |
parent | 7badb2d810643a685bf718ca8c9639075e708638 (diff) |
Add pseudo dependency to force two-address instruction to be scheduled after
other uses. There was a overly restricted check that prevented some obvious
cases.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@43762 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/SelectionDAG/ScheduleDAGRRList.cpp')
-rw-r--r-- | lib/CodeGen/SelectionDAG/ScheduleDAGRRList.cpp | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/lib/CodeGen/SelectionDAG/ScheduleDAGRRList.cpp b/lib/CodeGen/SelectionDAG/ScheduleDAGRRList.cpp index 5a2f200303..9c03b4e5b0 100644 --- a/lib/CodeGen/SelectionDAG/ScheduleDAGRRList.cpp +++ b/lib/CodeGen/SelectionDAG/ScheduleDAGRRList.cpp @@ -1308,8 +1308,11 @@ void BURegReductionPriorityQueue<SF>::AddPseudoTwoAddrDeps() { // plus it may increase register pressures. if (SuccSU == SU || SuccSU->hasPhysRegDefs) continue; - // Be conservative. Ignore if nodes aren't at the same depth. - if (SuccSU->Depth != SU->Depth) + // Be conservative. Ignore if nodes aren't at roughly the same + // depth and height. + if (SuccSU->Height < SU->Height && (SU->Height - SuccSU->Height) > 1) + continue; + if (SuccSU->Depth > SU->Depth && (SuccSU->Depth - SU->Depth) > 1) continue; if (!SuccSU->Node || !SuccSU->Node->isTargetOpcode()) continue; |