diff options
author | Dan Gohman <gohman@apple.com> | 2008-11-14 00:28:56 +0000 |
---|---|---|
committer | Dan Gohman <gohman@apple.com> | 2008-11-14 00:28:56 +0000 |
commit | 8f973f157dc313f3bd732f109c10e6a8768181b1 (patch) | |
tree | f05823d1faf0c66607c1148def8bdaccb81b5f12 /llvm/lib/CodeGen/SelectionDAG/SelectionDAGPrinter.cpp | |
parent | ee8273e52f292bdf098a77819b82bb552b16faed (diff) | |
download | bcm5719-llvm-8f973f157dc313f3bd732f109c10e6a8768181b1.tar.gz bcm5719-llvm-8f973f157dc313f3bd732f109c10e6a8768181b1.zip |
Debug printing for SUnits that carry MachineInstrs.
llvm-svn: 59279
Diffstat (limited to 'llvm/lib/CodeGen/SelectionDAG/SelectionDAGPrinter.cpp')
-rw-r--r-- | llvm/lib/CodeGen/SelectionDAG/SelectionDAGPrinter.cpp | 27 |
1 files changed, 17 insertions, 10 deletions
diff --git a/llvm/lib/CodeGen/SelectionDAG/SelectionDAGPrinter.cpp b/llvm/lib/CodeGen/SelectionDAG/SelectionDAGPrinter.cpp index 8ff50c1a3ad..66ada59acdb 100644 --- a/llvm/lib/CodeGen/SelectionDAG/SelectionDAGPrinter.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/SelectionDAGPrinter.cpp @@ -446,17 +446,24 @@ std::string DOTGraphTraits<ScheduleDAG*>::getNodeLabel(const SUnit *SU, const ScheduleDAG *G) { std::string Op; - if (!SU->getNode()) - Op = "<CROSS RC COPY>"; - else { - SmallVector<SDNode *, 4> FlaggedNodes; - for (SDNode *N = SU->getNode(); N; N = N->getFlaggedNode()) - FlaggedNodes.push_back(N); - while (!FlaggedNodes.empty()) { - Op += DOTGraphTraits<SelectionDAG*>::getNodeLabel(FlaggedNodes.back(), - G->DAG) + "\n"; - FlaggedNodes.pop_back(); + if (G->DAG) { + if (!SU->getNode()) + Op = "<CROSS RC COPY>"; + else { + SmallVector<SDNode *, 4> FlaggedNodes; + for (SDNode *N = SU->getNode(); N; N = N->getFlaggedNode()) + FlaggedNodes.push_back(N); + while (!FlaggedNodes.empty()) { + Op += DOTGraphTraits<SelectionDAG*>::getNodeLabel(FlaggedNodes.back(), + G->DAG) + "\n"; + FlaggedNodes.pop_back(); + } } + } else { + std::string s; + raw_string_ostream oss(s); + SU->MI->print(oss); + Op += oss.str(); } return Op; |