From a99eca12cc0410955a0c427ca34baf8991d7dd5a Mon Sep 17 00:00:00 2001 From: Kim Barrett Date: Mon, 23 Apr 2018 16:00:56 -0400 Subject: [PATCH] 8201826: G1: Don't invoke WeakProcessor if mark stack has overflowed Move WeakProcessor invocation after overflow check Reviewed-by: stefank, tschatzl --- src/hotspot/share/gc/g1/g1ConcurrentMark.cpp | 13 +++++-------- 1 file changed, 5 insertions(+), 8 deletions(-) diff --git a/src/hotspot/share/gc/g1/g1ConcurrentMark.cpp b/src/hotspot/share/gc/g1/g1ConcurrentMark.cpp index d1703a0caf4..b047e00add4 100644 --- a/src/hotspot/share/gc/g1/g1ConcurrentMark.cpp +++ b/src/hotspot/share/gc/g1/g1ConcurrentMark.cpp @@ -1695,14 +1695,6 @@ void G1ConcurrentMark::weak_refs_work(bool clear_all_soft_refs) { assert(!rp->discovery_enabled(), "Post condition"); } - assert(has_overflown() || _global_mark_stack.is_empty(), - "Mark stack should be empty (unless it has overflown)"); - - { - GCTraceTime(Debug, gc, phases) debug("Weak Processing", _gc_timer_cm); - WeakProcessor::weak_oops_do(&g1_is_alive, &do_nothing_cl); - } - if (has_overflown()) { // We can not trust g1_is_alive if the marking stack overflowed return; @@ -1710,6 +1702,11 @@ void G1ConcurrentMark::weak_refs_work(bool clear_all_soft_refs) { assert(_global_mark_stack.is_empty(), "Marking should have completed"); + { + GCTraceTime(Debug, gc, phases) debug("Weak Processing", _gc_timer_cm); + WeakProcessor::weak_oops_do(&g1_is_alive, &do_nothing_cl); + } + // Unload Klasses, String, Symbols, Code Cache, etc. if (ClassUnloadingWithConcurrentMark) { GCTraceTime(Debug, gc, phases) debug("Class Unloading", _gc_timer_cm);