8251464: make Node::dump(int depth) support indent

Reviewed-by: thartmann
This commit is contained in:
Xin Liu 2020-10-02 13:45:29 +00:00 committed by Paul Hohensee
parent fff8c8deaa
commit ea5a2b15a0
5 changed files with 49 additions and 23 deletions

View File

@ -105,6 +105,10 @@
notproduct(bool, PrintIdeal, false, \ notproduct(bool, PrintIdeal, false, \
"Print ideal graph before code generation") \ "Print ideal graph before code generation") \
\ \
notproduct(uintx, PrintIdealIndentThreshold, 0, \
"A depth threshold of ideal graph. Indentation is disabled " \
"when users attempt to dump an ideal graph deeper than it.") \
\
notproduct(bool, PrintOpto, false, \ notproduct(bool, PrintOpto, false, \
"Print compiler2 attempts") \ "Print compiler2 attempts") \
\ \

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 1997, 2016, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 1997, 2020, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -329,6 +329,7 @@ Node::Node(uint req)
: _idx(Init(req)) : _idx(Init(req))
#ifdef ASSERT #ifdef ASSERT
, _parse_idx(_idx) , _parse_idx(_idx)
, _indent(0)
#endif #endif
{ {
assert( req < Compile::current()->max_node_limit() - NodeLimitFudgeFactor, "Input limit exceeded" ); assert( req < Compile::current()->max_node_limit() - NodeLimitFudgeFactor, "Input limit exceeded" );
@ -349,6 +350,7 @@ Node::Node(Node *n0)
: _idx(Init(1)) : _idx(Init(1))
#ifdef ASSERT #ifdef ASSERT
, _parse_idx(_idx) , _parse_idx(_idx)
, _indent(0)
#endif #endif
{ {
debug_only( verify_construction() ); debug_only( verify_construction() );
@ -362,6 +364,7 @@ Node::Node(Node *n0, Node *n1)
: _idx(Init(2)) : _idx(Init(2))
#ifdef ASSERT #ifdef ASSERT
, _parse_idx(_idx) , _parse_idx(_idx)
, _indent(0)
#endif #endif
{ {
debug_only( verify_construction() ); debug_only( verify_construction() );
@ -377,6 +380,7 @@ Node::Node(Node *n0, Node *n1, Node *n2)
: _idx(Init(3)) : _idx(Init(3))
#ifdef ASSERT #ifdef ASSERT
, _parse_idx(_idx) , _parse_idx(_idx)
, _indent(0)
#endif #endif
{ {
debug_only( verify_construction() ); debug_only( verify_construction() );
@ -394,6 +398,7 @@ Node::Node(Node *n0, Node *n1, Node *n2, Node *n3)
: _idx(Init(4)) : _idx(Init(4))
#ifdef ASSERT #ifdef ASSERT
, _parse_idx(_idx) , _parse_idx(_idx)
, _indent(0)
#endif #endif
{ {
debug_only( verify_construction() ); debug_only( verify_construction() );
@ -413,6 +418,7 @@ Node::Node(Node *n0, Node *n1, Node *n2, Node *n3, Node *n4)
: _idx(Init(5)) : _idx(Init(5))
#ifdef ASSERT #ifdef ASSERT
, _parse_idx(_idx) , _parse_idx(_idx)
, _indent(0)
#endif #endif
{ {
debug_only( verify_construction() ); debug_only( verify_construction() );
@ -435,6 +441,7 @@ Node::Node(Node *n0, Node *n1, Node *n2, Node *n3,
: _idx(Init(6)) : _idx(Init(6))
#ifdef ASSERT #ifdef ASSERT
, _parse_idx(_idx) , _parse_idx(_idx)
, _indent(0)
#endif #endif
{ {
debug_only( verify_construction() ); debug_only( verify_construction() );
@ -459,6 +466,7 @@ Node::Node(Node *n0, Node *n1, Node *n2, Node *n3,
: _idx(Init(7)) : _idx(Init(7))
#ifdef ASSERT #ifdef ASSERT
, _parse_idx(_idx) , _parse_idx(_idx)
, _indent(0)
#endif #endif
{ {
debug_only( verify_construction() ); debug_only( verify_construction() );
@ -1718,7 +1726,12 @@ void Node::dump(const char* suffix, bool mark, outputStream *st) const {
Compile* C = Compile::current(); Compile* C = Compile::current();
bool is_new = C->node_arena()->contains(this); bool is_new = C->node_arena()->contains(this);
C->_in_dump_cnt++; C->_in_dump_cnt++;
st->print("%c%d%s\t%s\t=== ", is_new ? ' ' : 'o', _idx, mark ? " >" : "", Name());
if (_indent > 0) {
st->print("%*s", (_indent << 1), " ");
}
st->print("%c%d%s%s === ", is_new ? ' ' : 'o', _idx, mark ? " >" : " ", Name());
// Dump the required and precedence inputs // Dump the required and precedence inputs
dump_req(st); dump_req(st);
@ -1843,7 +1856,7 @@ void Node::dump_out(outputStream *st) const {
// moving in a given direction until a certain depth (distance from the start // moving in a given direction until a certain depth (distance from the start
// node) is reached. Duplicates are ignored. // node) is reached. Duplicates are ignored.
// Arguments: // Arguments:
// nstack: the nodes are collected into this array. // queue: the nodes are collected into this array.
// start: the node at which to start collecting. // start: the node at which to start collecting.
// direction: if this is a positive number, collect input nodes; if it is // direction: if this is a positive number, collect input nodes; if it is
// a negative number, collect output nodes. // a negative number, collect output nodes.
@ -1851,15 +1864,18 @@ void Node::dump_out(outputStream *st) const {
// include_start: whether to include the start node in the result collection. // include_start: whether to include the start node in the result collection.
// only_ctrl: whether to regard control edges only during traversal. // only_ctrl: whether to regard control edges only during traversal.
// only_data: whether to regard data edges only during traversal. // only_data: whether to regard data edges only during traversal.
static void collect_nodes_i(GrowableArray<Node*> *nstack, const Node* start, int direction, uint depth, bool include_start, bool only_ctrl, bool only_data) { static void collect_nodes_i(GrowableArray<Node*>* queue, const Node* start, int direction, uint depth, bool include_start, bool only_ctrl, bool only_data) {
bool indent = depth <= PrintIdealIndentThreshold;
Node* s = (Node*) start; // remove const Node* s = (Node*) start; // remove const
nstack->append(s); queue->append(s);
int begin = 0; int begin = 0;
int end = 0; int end = 0;
s->set_indent(0);
for(uint i = 0; i < depth; i++) { for(uint i = 0; i < depth; i++) {
end = nstack->length(); end = queue->length();
for(int j = begin; j < end; j++) { for(int j = begin; j < end; j++) {
Node* tp = nstack->at(j); Node* tp = queue->at(j);
uint limit = direction > 0 ? tp->len() : tp->outcnt(); uint limit = direction > 0 ? tp->len() : tp->outcnt();
for(uint k = 0; k < limit; k++) { for(uint k = 0; k < limit; k++) {
Node* n = direction > 0 ? tp->in(k) : tp->raw_out(k); Node* n = direction > 0 ? tp->in(k) : tp->raw_out(k);
@ -1869,17 +1885,17 @@ static void collect_nodes_i(GrowableArray<Node*> *nstack, const Node* start, int
if (n->is_Root() || n->is_top()) continue; if (n->is_Root() || n->is_top()) continue;
if (only_ctrl && !n->is_CFG()) continue; if (only_ctrl && !n->is_CFG()) continue;
if (only_data && n->is_CFG()) continue; if (only_data && n->is_CFG()) continue;
bool in_queue = queue->contains(n);
bool on_stack = nstack->contains(n); if (!in_queue) {
if (!on_stack) { queue->append(n);
nstack->append(n); n->set_indent(indent ? (i + 1) : 0);
} }
} }
} }
begin = end; begin = end;
} }
if (!include_start) { if (!include_start) {
nstack->remove(s); queue->remove(s);
} }
} }
@ -1887,17 +1903,17 @@ static void collect_nodes_i(GrowableArray<Node*> *nstack, const Node* start, int
static void dump_nodes(const Node* start, int d, bool only_ctrl) { static void dump_nodes(const Node* start, int d, bool only_ctrl) {
if (NotANode(start)) return; if (NotANode(start)) return;
GrowableArray <Node *> nstack(Compile::current()->live_nodes()); GrowableArray <Node *> queue(Compile::current()->live_nodes());
collect_nodes_i(&nstack, start, d, (uint) ABS(d), true, only_ctrl, false); collect_nodes_i(&queue, start, d, (uint) ABS(d), true, only_ctrl, false);
int end = nstack.length(); int end = queue.length();
if (d > 0) { if (d > 0) {
for(int j = end-1; j >= 0; j--) { for(int j = end-1; j >= 0; j--) {
nstack.at(j)->dump(); queue.at(j)->dump();
} }
} else { } else {
for(int j = 0; j < end; j++) { for(int j = 0; j < end; j++) {
nstack.at(j)->dump(); queue.at(j)->dump();
} }
} }
} }

View File

@ -1119,6 +1119,12 @@ private:
//----------------- Printing, etc //----------------- Printing, etc
#ifndef PRODUCT #ifndef PRODUCT
int _indent;
public:
void set_indent(int indent) { _indent = indent; }
private:
static bool add_to_worklist(Node* n, Node_List* worklist, Arena* old_arena, VectorSet* old_space, VectorSet* new_space); static bool add_to_worklist(Node* n, Node_List* worklist, Arena* old_arena, VectorSet* old_space, VectorSet* new_space);
public: public:
Node* find(int idx, bool only_ctrl = false); // Search the graph for the given idx. Node* find(int idx, bool only_ctrl = false); // Search the graph for the given idx.

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2016, 2017, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2016, 2020, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -56,7 +56,7 @@ public class TestDriver {
private void verifyVectorizationNumber(List<String> vectorizationLog) { private void verifyVectorizationNumber(List<String> vectorizationLog) {
for (Map.Entry<String, Long> entry : expectedVectorizationNumbers.entrySet()) { for (Map.Entry<String, Long> entry : expectedVectorizationNumbers.entrySet()) {
String v = "\t" + entry.getKey(); String v = entry.getKey();
long actualNum = vectorizationLog.stream() long actualNum = vectorizationLog.stream()
.filter(s -> s.contains(v)).count(); .filter(s -> s.contains(v)).count();
long expectedNum = entry.getValue(); long expectedNum = entry.getValue();

View File

@ -73,12 +73,12 @@ public class UseCountedLoopSafepointsTest {
List<Node> safePoints = new ArrayList<>(); List<Node> safePoints = new ArrayList<>();
List<Node> loopEnds = new ArrayList<>(); List<Node> loopEnds = new ArrayList<>();
for (String line : oa.getOutput().split("\\n")) { for (String line : oa.getOutput().split("\\n")) {
int separatorIndex = line.indexOf("\t==="); int separatorIndex = line.indexOf(" ===");
if (separatorIndex > -1) { if (separatorIndex > -1) {
String header = line.substring(0, separatorIndex); String header = line.substring(0, separatorIndex);
if (header.endsWith("\tSafePoint")) { if (header.endsWith("SafePoint")) {
safePoints.add(new Node("SafePoint", line)); safePoints.add(new Node("SafePoint", line));
} else if (header.endsWith("\tCountedLoopEnd")) { } else if (header.endsWith("CountedLoopEnd")) {
loopEnds.add(new Node("CountedLoopEnd", line)); loopEnds.add(new Node("CountedLoopEnd", line));
} }
} }