From 0148adf20e6f0084a906ba6aa8aff123e905adfd Mon Sep 17 00:00:00 2001 From: Vladimir Ivanov Date: Thu, 14 Jan 2021 17:18:44 +0000 Subject: [PATCH] 8255120: C2: assert(outer->outcnt() >= phis + 2 && outer->outcnt() <= phis + 2 + stores + 1) failed: only phis Reviewed-by: thartmann --- .../gc/shenandoah/c2/shenandoahSupport.cpp | 5 +++ src/hotspot/share/opto/compile.cpp | 38 ++++++++----------- src/hotspot/share/opto/compile.hpp | 5 ++- src/hotspot/share/opto/loopnode.hpp | 1 + test/hotspot/jtreg/ProblemList.txt | 2 - 5 files changed, 25 insertions(+), 26 deletions(-) diff --git a/src/hotspot/share/gc/shenandoah/c2/shenandoahSupport.cpp b/src/hotspot/share/gc/shenandoah/c2/shenandoahSupport.cpp index e5c426d2f3d..81ae22fef88 100644 --- a/src/hotspot/share/gc/shenandoah/c2/shenandoahSupport.cpp +++ b/src/hotspot/share/gc/shenandoah/c2/shenandoahSupport.cpp @@ -47,6 +47,8 @@ bool ShenandoahBarrierC2Support::expand(Compile* C, PhaseIterGVN& igvn) { ShenandoahBarrierSetC2State* state = ShenandoahBarrierSetC2::bsc2()->state(); if ((state->enqueue_barriers_count() + state->load_reference_barriers_count()) > 0) { + assert(C->post_loop_opts_phase(), "no loop opts allowed"); + C->reset_post_loop_opts_phase(); // ... but we know what we are doing bool attempt_more_loopopts = ShenandoahLoopOptsAfterExpansion; C->clear_major_progress(); PhaseIdealLoop::optimize(igvn, LoopOptsShenandoahExpand); @@ -59,7 +61,10 @@ bool ShenandoahBarrierC2Support::expand(Compile* C, PhaseIterGVN& igvn) { return false; } C->clear_major_progress(); + + C->process_for_post_loop_opts_igvn(igvn); } + C->set_post_loop_opts_phase(); // now for real! } return true; } diff --git a/src/hotspot/share/opto/compile.cpp b/src/hotspot/share/opto/compile.cpp index 1d997b1e206..d5f9311432e 100644 --- a/src/hotspot/share/opto/compile.cpp +++ b/src/hotspot/share/opto/compile.cpp @@ -1834,16 +1834,21 @@ void Compile::remove_from_post_loop_opts_igvn(Node* n) { } void Compile::process_for_post_loop_opts_igvn(PhaseIterGVN& igvn) { - if (_for_post_loop_igvn.length() == 0) { - return; // no work to do + // Verify that all previous optimizations produced a valid graph + // at least to this point, even if no loop optimizations were done. + PhaseIdealLoop::verify(igvn); + + C->set_post_loop_opts_phase(); // no more loop opts allowed + + if (_for_post_loop_igvn.length() > 0) { + while (_for_post_loop_igvn.length() > 0) { + Node* n = _for_post_loop_igvn.pop(); + n->remove_flag(Node::NodeFlags::Flag_for_post_loop_opts_igvn); + igvn._worklist.push(n); + } + igvn.optimize(); + assert(_for_post_loop_igvn.length() == 0, "no more delayed nodes allowed"); } - while (_for_post_loop_igvn.length() > 0) { - Node* n = _for_post_loop_igvn.pop(); - n->remove_flag(Node::NodeFlags::Flag_for_post_loop_opts_igvn); - igvn._worklist.push(n); - } - igvn.optimize(); - assert(_for_post_loop_igvn.length() == 0, "no more delayed nodes allowed"); } // StringOpts and late inlining of string methods @@ -2252,7 +2257,6 @@ void Compile::Optimize() { } if (!failing()) { // Verify that last round of loop opts produced a valid graph - TracePhase tp("idealLoopVerify", &timers[_t_idealLoopVerify]); PhaseIdealLoop::verify(igvn); } } @@ -2287,15 +2291,9 @@ void Compile::Optimize() { if (failing()) return; - // Ensure that major progress is now clear - C->clear_major_progress(); + C->clear_major_progress(); // ensure that major progress is now clear - { - // Verify that all previous optimizations produced a valid graph - // at least to this point, even if no loop optimizations were done. - TracePhase tp("idealLoopVerify", &timers[_t_idealLoopVerify]); - PhaseIdealLoop::verify(igvn); - } + process_for_post_loop_opts_igvn(igvn); #ifdef ASSERT bs->verify_gc_barriers(this, BarrierSetC2::BeforeMacroExpand); @@ -2320,10 +2318,6 @@ void Compile::Optimize() { print_method(PHASE_BARRIER_EXPANSION, 2); } - C->set_post_loop_opts_phase(); // no more loop opts allowed - - process_for_post_loop_opts_igvn(igvn); - if (C->max_vector_size() > 0) { C->optimize_logic_cones(igvn); igvn.optimize(); diff --git a/src/hotspot/share/opto/compile.hpp b/src/hotspot/share/opto/compile.hpp index a2e20a431da..cfd8c4f8970 100644 --- a/src/hotspot/share/opto/compile.hpp +++ b/src/hotspot/share/opto/compile.hpp @@ -689,8 +689,9 @@ class Compile : public Phase { _predicate_opaqs.append(n); } - bool post_loop_opts_phase() { return _post_loop_opts_phase; } - void set_post_loop_opts_phase() { _post_loop_opts_phase = true; } + bool post_loop_opts_phase() { return _post_loop_opts_phase; } + void set_post_loop_opts_phase() { _post_loop_opts_phase = true; } + void reset_post_loop_opts_phase() { _post_loop_opts_phase = false; } void record_for_post_loop_opts_igvn(Node* n); void remove_from_post_loop_opts_igvn(Node* n); diff --git a/src/hotspot/share/opto/loopnode.hpp b/src/hotspot/share/opto/loopnode.hpp index aa89d475ef8..68903e4b97d 100644 --- a/src/hotspot/share/opto/loopnode.hpp +++ b/src/hotspot/share/opto/loopnode.hpp @@ -1132,6 +1132,7 @@ public: static void verify(PhaseIterGVN& igvn) { #ifdef ASSERT ResourceMark rm; + Compile::TracePhase tp("idealLoopVerify", &timers[_t_idealLoopVerify]); PhaseIdealLoop v(igvn); #endif } diff --git a/test/hotspot/jtreg/ProblemList.txt b/test/hotspot/jtreg/ProblemList.txt index 45fbf33335e..d17a2c4c6ac 100644 --- a/test/hotspot/jtreg/ProblemList.txt +++ b/test/hotspot/jtreg/ProblemList.txt @@ -64,8 +64,6 @@ compiler/rtm/print/TestPrintPreciseRTMLockingStatistics.java 8183263 generic-x64 compiler/c2/Test8004741.java 8235801 generic-all -compiler/loopstripmining/BackedgeNodeWithOutOfLoopControl.java 8255120 generic-all - ############################################################################# # :hotspot_gc