From f449bf36ef5cb8e23fa2b5bc43f8d54d2b48fa4e Mon Sep 17 00:00:00 2001 From: Dan Gohman Date: Fri, 14 Nov 2008 00:06:09 +0000 Subject: Initial support for carrying MachineInstrs in SUnits. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@59278 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/CodeGen/SelectionDAG/SelectionDAGPrinter.cpp | 21 +++++++++++++++++---- 1 file changed, 17 insertions(+), 4 deletions(-) (limited to 'lib/CodeGen/SelectionDAG/SelectionDAGPrinter.cpp') diff --git a/lib/CodeGen/SelectionDAG/SelectionDAGPrinter.cpp b/lib/CodeGen/SelectionDAG/SelectionDAGPrinter.cpp index 27746333e4..8ff50c1a3a 100644 --- a/lib/CodeGen/SelectionDAG/SelectionDAGPrinter.cpp +++ b/lib/CodeGen/SelectionDAG/SelectionDAGPrinter.cpp @@ -420,11 +420,24 @@ namespace llvm { static void addCustomGraphFeatures(ScheduleDAG *G, GraphWriter &GW) { + // Draw a special "GraphRoot" node to indicate the root of the graph. GW.emitSimpleNode(0, "plaintext=circle", "GraphRoot"); - const SDNode *N = G->DAG->getRoot().getNode(); - if (N && N->getNodeId() != -1) - GW.emitEdge(0, -1, &G->SUnits[N->getNodeId()], -1, - "color=blue,style=dashed"); + if (G->DAG) { + // For an SDNode-based ScheduleDAG, point to the root of the ScheduleDAG. + const SDNode *N = G->DAG->getRoot().getNode(); + if (N && N->getNodeId() != -1) + GW.emitEdge(0, -1, &G->SUnits[N->getNodeId()], -1, + "color=blue,style=dashed"); + } else { + // For a MachineInstr-based ScheduleDAG, find a root to point to. + for (unsigned i = 0, e = G->SUnits.size(); i != e; ++i) { + if (G->SUnits[i].Succs.empty()) { + GW.emitEdge(0, -1, &G->SUnits[i], -1, + "color=blue,style=dashed"); + break; + } + } + } } }; } -- cgit v1.2.3-18-g5258