diff options
| author | Dan Gohman <gohman@apple.com> | 2009-03-23 16:10:52 +0000 |
|---|---|---|
| committer | Dan Gohman <gohman@apple.com> | 2009-03-23 16:10:52 +0000 |
| commit | 52c278e54d45646a2224a7c45a6f2f9b8275cc9c (patch) | |
| tree | 1de4e2d0245c6a9264abc0b377a859797043c99b /llvm/lib/CodeGen | |
| parent | c53305fd421b7c752f2f6971ee3ffd7271c815a8 (diff) | |
| download | bcm5719-llvm-52c278e54d45646a2224a7c45a6f2f9b8275cc9c.tar.gz bcm5719-llvm-52c278e54d45646a2224a7c45a6f2f9b8275cc9c.zip | |
Add a new bit to SUnit to record whether a node has implicit physreg
defs, regardless of whether they are actually used.
llvm-svn: 67528
Diffstat (limited to 'llvm/lib/CodeGen')
| -rw-r--r-- | llvm/lib/CodeGen/SelectionDAG/ScheduleDAGSDNodes.cpp | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/llvm/lib/CodeGen/SelectionDAG/ScheduleDAGSDNodes.cpp b/llvm/lib/CodeGen/SelectionDAG/ScheduleDAGSDNodes.cpp index 967a8cef8e1..303f8cc6a61 100644 --- a/llvm/lib/CodeGen/SelectionDAG/ScheduleDAGSDNodes.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/ScheduleDAGSDNodes.cpp @@ -41,6 +41,7 @@ SUnit *ScheduleDAGSDNodes::Clone(SUnit *Old) { SU->isTwoAddress = Old->isTwoAddress; SU->isCommutable = Old->isCommutable; SU->hasPhysRegDefs = Old->hasPhysRegDefs; + SU->hasPhysRegClobbers = Old->hasPhysRegClobbers; Old->isCloned = true; return SU; } @@ -172,9 +173,11 @@ void ScheduleDAGSDNodes::AddSchedEdges() { // Find all predecessors and successors of the group. for (SDNode *N = SU->getNode(); N; N = N->getFlaggedNode()) { if (N->isMachineOpcode() && - TII->get(N->getMachineOpcode()).getImplicitDefs() && - CountResults(N) > TII->get(N->getMachineOpcode()).getNumDefs()) - SU->hasPhysRegDefs = true; + TII->get(N->getMachineOpcode()).getImplicitDefs()) { + SU->hasPhysRegClobbers = true; + if (CountResults(N) > TII->get(N->getMachineOpcode()).getNumDefs()) + SU->hasPhysRegDefs = true; + } for (unsigned i = 0, e = N->getNumOperands(); i != e; ++i) { SDNode *OpN = N->getOperand(i).getNode(); |

