aboutsummaryrefslogtreecommitdiffstats
path: root/lib/CodeGen/SelectionDAG/SelectionDAGPrinter.cpp
diff options
context:
space:
mode:
authorDan Gohman <gohman@apple.com>2008-11-14 00:28:56 +0000
committerDan Gohman <gohman@apple.com>2008-11-14 00:28:56 +0000
commit505a551dab05029d2c7b5dc65a879d35e03e17c1 (patch)
tree705fdbd925640c2c44ef3fefd2b8a4dcccfb4e13 /lib/CodeGen/SelectionDAG/SelectionDAGPrinter.cpp
parentf449bf36ef5cb8e23fa2b5bc43f8d54d2b48fa4e (diff)
downloadexternal_llvm-505a551dab05029d2c7b5dc65a879d35e03e17c1.zip
external_llvm-505a551dab05029d2c7b5dc65a879d35e03e17c1.tar.gz
external_llvm-505a551dab05029d2c7b5dc65a879d35e03e17c1.tar.bz2
Debug printing for SUnits that carry MachineInstrs.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@59279 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/SelectionDAG/SelectionDAGPrinter.cpp')
-rw-r--r--lib/CodeGen/SelectionDAG/SelectionDAGPrinter.cpp27
1 files changed, 17 insertions, 10 deletions
diff --git a/lib/CodeGen/SelectionDAG/SelectionDAGPrinter.cpp b/lib/CodeGen/SelectionDAG/SelectionDAGPrinter.cpp
index 8ff50c1..66ada59 100644
--- a/lib/CodeGen/SelectionDAG/SelectionDAGPrinter.cpp
+++ b/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;