8310220: IGV: dump graph after each IGVN step at level 4
Reviewed-by: chagedorn, tholenstein
This commit is contained in:
parent
adfc1d6cd2
commit
0d52c82ed1
@ -365,10 +365,10 @@
|
|||||||
"Level of detail of the ideal graph printout. " \
|
"Level of detail of the ideal graph printout. " \
|
||||||
"System-wide value, -1=printing is disabled, " \
|
"System-wide value, -1=printing is disabled, " \
|
||||||
"0=print nothing except IGVPrintLevel directives, " \
|
"0=print nothing except IGVPrintLevel directives, " \
|
||||||
"4=all details printed. " \
|
"5=all details printed. " \
|
||||||
"Level of detail of printouts can be set on a per-method level " \
|
"Level of detail of printouts can be set on a per-method level " \
|
||||||
"as well by using CompileCommand=option.") \
|
"as well by using CompileCommand=option.") \
|
||||||
range(-1, 4) \
|
range(-1, 5) \
|
||||||
\
|
\
|
||||||
notproduct(intx, PrintIdealGraphPort, 4444, \
|
notproduct(intx, PrintIdealGraphPort, 4444, \
|
||||||
"Ideal graph printer to network port") \
|
"Ideal graph printer to network port") \
|
||||||
|
@ -260,7 +260,7 @@ void PhaseOutput::perform_mach_node_analysis() {
|
|||||||
|
|
||||||
pd_perform_mach_node_analysis();
|
pd_perform_mach_node_analysis();
|
||||||
|
|
||||||
C->print_method(CompilerPhaseType::PHASE_MACH_ANALYSIS, 4);
|
C->print_method(CompilerPhaseType::PHASE_MACH_ANALYSIS, 3);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Convert Nodes to instruction bits and pass off to the VM
|
// Convert Nodes to instruction bits and pass off to the VM
|
||||||
|
@ -2785,7 +2785,7 @@ void Parse::do_one_bytecode() {
|
|||||||
jio_snprintf(buffer, sizeof(buffer), "Bytecode %d: %s", bci(), Bytecodes::name(bc()));
|
jio_snprintf(buffer, sizeof(buffer), "Bytecode %d: %s", bci(), Bytecodes::name(bc()));
|
||||||
bool old = printer->traverse_outs();
|
bool old = printer->traverse_outs();
|
||||||
printer->set_traverse_outs(true);
|
printer->set_traverse_outs(true);
|
||||||
printer->print_method(buffer, 4);
|
printer->print_method(buffer, 5);
|
||||||
printer->set_traverse_outs(old);
|
printer->set_traverse_outs(old);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -891,9 +891,12 @@ void PhaseIterGVN::verify_step(Node* n) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void PhaseIterGVN::trace_PhaseIterGVN(Node* n, Node* nn, const Type* oldtype) {
|
void PhaseIterGVN::trace_PhaseIterGVN(Node* n, Node* nn, const Type* oldtype) {
|
||||||
|
const Type* newtype = type_or_null(n);
|
||||||
|
if (nn != n || oldtype != newtype) {
|
||||||
|
C->print_method(PHASE_AFTER_ITER_GVN_STEP, 4, n);
|
||||||
|
}
|
||||||
if (TraceIterativeGVN) {
|
if (TraceIterativeGVN) {
|
||||||
uint wlsize = _worklist.size();
|
uint wlsize = _worklist.size();
|
||||||
const Type* newtype = type_or_null(n);
|
|
||||||
if (nn != n) {
|
if (nn != n) {
|
||||||
// print old node
|
// print old node
|
||||||
tty->print("< ");
|
tty->print("< ");
|
||||||
@ -1021,6 +1024,7 @@ void PhaseIterGVN::trace_PhaseIterGVN_verbose(Node* n, int num_processed) {
|
|||||||
void PhaseIterGVN::optimize() {
|
void PhaseIterGVN::optimize() {
|
||||||
DEBUG_ONLY(uint num_processed = 0;)
|
DEBUG_ONLY(uint num_processed = 0;)
|
||||||
NOT_PRODUCT(init_verifyPhaseIterGVN();)
|
NOT_PRODUCT(init_verifyPhaseIterGVN();)
|
||||||
|
C->print_method(PHASE_BEFORE_ITER_GVN, 3);
|
||||||
if (StressIGVN) {
|
if (StressIGVN) {
|
||||||
shuffle_worklist();
|
shuffle_worklist();
|
||||||
}
|
}
|
||||||
@ -1030,12 +1034,14 @@ void PhaseIterGVN::optimize() {
|
|||||||
// update edge info and put uses on worklist.
|
// update edge info and put uses on worklist.
|
||||||
while(_worklist.size()) {
|
while(_worklist.size()) {
|
||||||
if (C->check_node_count(NodeLimitFudgeFactor * 2, "Out of nodes")) {
|
if (C->check_node_count(NodeLimitFudgeFactor * 2, "Out of nodes")) {
|
||||||
|
C->print_method(PHASE_AFTER_ITER_GVN, 3);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
Node* n = _worklist.pop();
|
Node* n = _worklist.pop();
|
||||||
if (loop_count >= K * C->live_nodes()) {
|
if (loop_count >= K * C->live_nodes()) {
|
||||||
DEBUG_ONLY(dump_infinite_loop_info(n, "PhaseIterGVN::optimize");)
|
DEBUG_ONLY(dump_infinite_loop_info(n, "PhaseIterGVN::optimize");)
|
||||||
C->record_method_not_compilable("infinite loop in PhaseIterGVN::optimize");
|
C->record_method_not_compilable("infinite loop in PhaseIterGVN::optimize");
|
||||||
|
C->print_method(PHASE_AFTER_ITER_GVN, 3);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
DEBUG_ONLY(trace_PhaseIterGVN_verbose(n, num_processed++);)
|
DEBUG_ONLY(trace_PhaseIterGVN_verbose(n, num_processed++);)
|
||||||
@ -1050,6 +1056,7 @@ void PhaseIterGVN::optimize() {
|
|||||||
loop_count++;
|
loop_count++;
|
||||||
}
|
}
|
||||||
NOT_PRODUCT(verify_PhaseIterGVN();)
|
NOT_PRODUCT(verify_PhaseIterGVN();)
|
||||||
|
C->print_method(PHASE_AFTER_ITER_GVN, 3);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef ASSERT
|
#ifdef ASSERT
|
||||||
|
@ -30,7 +30,10 @@
|
|||||||
flags(AFTER_STRINGOPTS, "After StringOpts") \
|
flags(AFTER_STRINGOPTS, "After StringOpts") \
|
||||||
flags(BEFORE_REMOVEUSELESS, "Before RemoveUseless") \
|
flags(BEFORE_REMOVEUSELESS, "Before RemoveUseless") \
|
||||||
flags(AFTER_PARSING, "After Parsing") \
|
flags(AFTER_PARSING, "After Parsing") \
|
||||||
|
flags(BEFORE_ITER_GVN, "Before Iter GVN") \
|
||||||
flags(ITER_GVN1, "Iter GVN 1") \
|
flags(ITER_GVN1, "Iter GVN 1") \
|
||||||
|
flags(AFTER_ITER_GVN_STEP, "After Iter GVN Step") \
|
||||||
|
flags(AFTER_ITER_GVN, "After Iter GVN") \
|
||||||
flags(INCREMENTAL_INLINE_STEP, "Incremental Inline Step") \
|
flags(INCREMENTAL_INLINE_STEP, "Incremental Inline Step") \
|
||||||
flags(INCREMENTAL_INLINE_CLEANUP, "Incremental Inline Cleanup") \
|
flags(INCREMENTAL_INLINE_CLEANUP, "Incremental Inline Cleanup") \
|
||||||
flags(INCREMENTAL_INLINE, "Incremental Inline") \
|
flags(INCREMENTAL_INLINE, "Incremental Inline") \
|
||||||
|
@ -22,15 +22,16 @@ for building and running IGV.
|
|||||||
|
|
||||||
# Usage
|
# Usage
|
||||||
|
|
||||||
The JVM support is controlled by the flag `-XX:PrintIdealGraphLevel=#` where `#`
|
The JVM support is controlled by the flag `-XX:PrintIdealGraphLevel=N`, where
|
||||||
is:
|
Ideal graphs are dumped at the following points:
|
||||||
|
|
||||||
* 0: no output, the default
|
* `N=0`: no output (default)
|
||||||
* 1: dumps graph after parsing, before matching, and final code (also dumps
|
* `N=1`: after parsing, before matching, and final code (also for failed
|
||||||
graphs for failed compilations, if available)
|
compilations, if available)
|
||||||
* 2: more detail, including after loop opts
|
* `N=2`: additionally, after every major phase (including loop opts)
|
||||||
* 3: even more detail
|
* `N=3`: additionally, after every minor phase
|
||||||
* 4: prints graph after parsing every bytecode (very slow)
|
* `N=4`: additionally, after every effective IGVN step (slow)
|
||||||
|
* `N=5`: additionally, after parsing every bytecode (very slow)
|
||||||
|
|
||||||
By default the JVM expects that it will connect to a visualizer on the local
|
By default the JVM expects that it will connect to a visualizer on the local
|
||||||
host on port 4444. This can be configured using the options
|
host on port 4444. This can be configured using the options
|
||||||
|
@ -29,7 +29,7 @@ import java.util.Map;
|
|||||||
/**
|
/**
|
||||||
* This enum represents all available compile phases on which an IR matching can be done. There is a 1:1 mapping
|
* This enum represents all available compile phases on which an IR matching can be done. There is a 1:1 mapping
|
||||||
* between IGV phases as specified in phasetype.hpp. Compile phases which are normally not emitted by C2 like FAILURE
|
* between IGV phases as specified in phasetype.hpp. Compile phases which are normally not emitted by C2 like FAILURE
|
||||||
* or DEBUG are not listed. This enum should be kept in sync with phasetye.hpp.
|
* or DEBUG are not listed. This enum should be kept in sync with phasetype.hpp.
|
||||||
*
|
*
|
||||||
* <p>
|
* <p>
|
||||||
* There are two additional compile phases PRINT_IDEAL and PRINT_OPTO_ASSEMBLY. PRINT_IDEAL is the output that is printed
|
* There are two additional compile phases PRINT_IDEAL and PRINT_OPTO_ASSEMBLY. PRINT_IDEAL is the output that is printed
|
||||||
@ -43,7 +43,10 @@ public enum CompilePhase {
|
|||||||
AFTER_STRINGOPTS("After StringOpts"),
|
AFTER_STRINGOPTS("After StringOpts"),
|
||||||
BEFORE_REMOVEUSELESS("Before RemoveUseless"),
|
BEFORE_REMOVEUSELESS("Before RemoveUseless"),
|
||||||
AFTER_PARSING("After Parsing"),
|
AFTER_PARSING("After Parsing"),
|
||||||
|
BEFORE_ITER_GVN("Before Iter GVN"),
|
||||||
ITER_GVN1("Iter GVN 1"),
|
ITER_GVN1("Iter GVN 1"),
|
||||||
|
AFTER_ITER_GVN_STEP("After Iter GVN Step"),
|
||||||
|
AFTER_ITER_GVN("After Iter GVN"),
|
||||||
INCREMENTAL_INLINE_STEP("Incremental Inline Step"),
|
INCREMENTAL_INLINE_STEP("Incremental Inline Step"),
|
||||||
INCREMENTAL_INLINE_CLEANUP("Incremental Inline Cleanup"),
|
INCREMENTAL_INLINE_CLEANUP("Incremental Inline Cleanup"),
|
||||||
INCREMENTAL_INLINE("Incremental Inline"),
|
INCREMENTAL_INLINE("Incremental Inline"),
|
||||||
|
Loading…
x
Reference in New Issue
Block a user