LLVM: lib/CodeGen/ScheduleDAGPrinter.cpp Source File (original) (raw)

1

2

3

4

5

6

7

8

9

10

11

12

17using namespace llvm;

18

19template <>

21

23

25 return std::string(G->MF.getName());

26 }

27

29

31 return (Node->NumPreds > 10 || Node->NumSuccs > 10);

32 }

33

36 std::string R;

38 OS << static_cast<const void *>(Node);

39 return R;

40 }

41

42

43

47 return "color=cyan,style=dashed";

49 return "color=blue,style=dashed";

50 return "";

51 }

52

56 return "shape=Mrecord";

57 }

58

61 return G->addCustomGraphFeatures(GW);

62 }

63};

64

67 return G->getGraphNodeLabel(SU);

68}

69

70

71

72

74

75#ifndef NDEBUG

76 ViewGraph(this, Name, false, Title);

77#else

78 errs() << "ScheduleDAG::viewGraph is only available in debug builds on "

79 << "systems with Graphviz or gv!\n";

80#endif

81}

82

83

bool isArtificialDep() const

bool isCtrlDep() const

Tests if this is not an SDep::Data dependence.

Scheduling unit. This is a node in the scheduling DAG.

virtual std::string getDAGName() const =0

Returns a label for the region of code covered by the DAG.

virtual void viewGraph()

Out-of-line implementation with no arguments is handy for gdb.

Definition ScheduleDAGPrinter.cpp:84

Twine - A lightweight data structure for efficiently representing the concatenation of temporary valu...

A raw_ostream that writes to an std::string.

This is an optimization pass for GlobalISel generic memory operations.

LLVM_ABI raw_fd_ostream & errs()

This returns a reference to a raw_ostream for standard error.

void ViewGraph(const GraphType &G, const Twine &Name, bool ShortNames=false, const Twine &Title="", GraphProgram::Name Program=GraphProgram::DOT)

ViewGraph - Emit a dot graph, run 'dot', run gv on the postscript file, then cleanup.

static std::string getNodeAttributes(const SUnit *N, const ScheduleDAG *Graph)

Definition ScheduleDAGPrinter.cpp:54

static std::string getEdgeAttributes(const SUnit *Node, SUnitIterator EI, const ScheduleDAG *Graph)

If you want to override the dot attributes printed for a particular edge, override this method.

Definition ScheduleDAGPrinter.cpp:44

static bool isNodeHidden(const SUnit *Node, const ScheduleDAG *G)

Definition ScheduleDAGPrinter.cpp:30

DOTGraphTraits(bool isSimple=false)

Definition ScheduleDAGPrinter.cpp:22

static void addCustomGraphFeatures(ScheduleDAG *G, GraphWriter< ScheduleDAG * > &GW)

Definition ScheduleDAGPrinter.cpp:59

static bool renderGraphFromBottomUp()

Definition ScheduleDAGPrinter.cpp:28

static std::string getGraphName(const ScheduleDAG *G)

Definition ScheduleDAGPrinter.cpp:24

static std::string getNodeIdentifierLabel(const SUnit *Node, const ScheduleDAG *Graph)

Definition ScheduleDAGPrinter.cpp:34

std::string getNodeLabel(const SUnit *SU, const ScheduleDAG *Graph)

DOTGraphTraits - Template class that can be specialized to customize how graphs are converted to 'dot...

DefaultDOTGraphTraits(bool simple=false)

std::string getNodeLabel(const void *, const GraphType &)

getNodeLabel - Given a node and a pointer to the top level graph, return the label to print in the no...