diff --git a/src/hotspot/share/gc/shenandoah/shenandoahHeap.cpp b/src/hotspot/share/gc/shenandoah/shenandoahHeap.cpp index cc99133a58b..2f118317dc1 100644 --- a/src/hotspot/share/gc/shenandoah/shenandoahHeap.cpp +++ b/src/hotspot/share/gc/shenandoah/shenandoahHeap.cpp @@ -2882,6 +2882,7 @@ void ShenandoahHeap::entry_weak_roots() { EventMark em("%s", msg); ShenandoahGCPhase phase(ShenandoahPhaseTimings::conc_weak_roots); + ShenandoahGCWorkerPhase worker_phase(ShenandoahPhaseTimings::conc_weak_roots); ShenandoahWorkerScope scope(workers(), ShenandoahWorkerPolicy::calc_workers_for_conc_root_processing(), @@ -2912,6 +2913,7 @@ void ShenandoahHeap::entry_strong_roots() { EventMark em("%s", msg); ShenandoahGCPhase phase(ShenandoahPhaseTimings::conc_strong_roots); + ShenandoahGCWorkerPhase worker_phase(ShenandoahPhaseTimings::conc_strong_roots); ShenandoahWorkerScope scope(workers(), ShenandoahWorkerPolicy::calc_workers_for_conc_root_processing(), diff --git a/src/hotspot/share/gc/shenandoah/shenandoahPhaseTimings.cpp b/src/hotspot/share/gc/shenandoah/shenandoahPhaseTimings.cpp index c8a1246fa02..cec096e160d 100644 --- a/src/hotspot/share/gc/shenandoah/shenandoahPhaseTimings.cpp +++ b/src/hotspot/share/gc/shenandoah/shenandoahPhaseTimings.cpp @@ -107,6 +107,8 @@ bool ShenandoahPhaseTimings::is_worker_phase(Phase phase) { case purge_class_unload: case purge_weak_par: case heap_iteration_roots: + case conc_weak_roots: + case conc_strong_roots: return true; default: return false; diff --git a/src/hotspot/share/gc/shenandoah/shenandoahPhaseTimings.hpp b/src/hotspot/share/gc/shenandoah/shenandoahPhaseTimings.hpp index cad296d1209..4381fca439d 100644 --- a/src/hotspot/share/gc/shenandoah/shenandoahPhaseTimings.hpp +++ b/src/hotspot/share/gc/shenandoah/shenandoahPhaseTimings.hpp @@ -91,9 +91,11 @@ class outputStream; SHENANDOAH_PAR_PHASE_DO(evac_, " E: ", f) \ \ f(conc_weak_roots, "Concurrent Weak Roots") \ + SHENANDOAH_PAR_PHASE_DO(conc_weak_roots_, " CWR: ", f) \ f(conc_cleanup_early, "Concurrent Cleanup") \ f(conc_class_unloading, "Concurrent Class Unloading") \ f(conc_strong_roots, "Concurrent Strong Roots") \ + SHENANDOAH_PAR_PHASE_DO(conc_strong_roots_, " CSR: ", f) \ f(conc_evac, "Concurrent Evacuation") \ \ f(init_update_refs_gross, "Pause Init Update Refs (G)") \ diff --git a/src/hotspot/share/gc/shenandoah/shenandoahRootProcessor.inline.hpp b/src/hotspot/share/gc/shenandoah/shenandoahRootProcessor.inline.hpp index e2d2281e791..2b9efc9a339 100644 --- a/src/hotspot/share/gc/shenandoah/shenandoahRootProcessor.inline.hpp +++ b/src/hotspot/share/gc/shenandoah/shenandoahRootProcessor.inline.hpp @@ -48,12 +48,8 @@ inline ShenandoahVMRoot::ShenandoahVMRoot(OopStorage* storage, template template inline void ShenandoahVMRoot::oops_do(Closure* cl, uint worker_id) { - if (CONCURRENT) { - _itr.oops_do(cl); - } else { - ShenandoahWorkerTimingsTracker timer(_phase, _par_phase, worker_id); - _itr.oops_do(cl); - } + ShenandoahWorkerTimingsTracker timer(_phase, _par_phase, worker_id); + _itr.oops_do(cl); } template @@ -149,11 +145,9 @@ void ShenandoahClassLoaderDataRoots::always_strong_ assert(SafepointSynchronize::is_at_safepoint(), "Must be at a safepoint"); assert(Thread::current()->is_VM_thread(), "Single threaded CLDG iteration can only be done by VM thread"); ClassLoaderDataGraph::always_strong_cld_do(clds); - } else if (CONCURRENT) { - ClassLoaderDataGraph::always_strong_cld_do(clds); } else { - ShenandoahWorkerTimingsTracker timer(_phase, ShenandoahPhaseTimings::CLDGRoots, worker_id); - ClassLoaderDataGraph::always_strong_cld_do(clds); + ShenandoahWorkerTimingsTracker timer(_phase, ShenandoahPhaseTimings::CLDGRoots, worker_id); + ClassLoaderDataGraph::always_strong_cld_do(clds); } } @@ -163,9 +157,7 @@ void ShenandoahClassLoaderDataRoots::cld_do(CLDClos assert(SafepointSynchronize::is_at_safepoint(), "Must be at a safepoint"); assert(Thread::current()->is_VM_thread(), "Single threaded CLDG iteration can only be done by VM thread"); ClassLoaderDataGraph::cld_do(clds); - } else if (CONCURRENT) { - ClassLoaderDataGraph::cld_do(clds); - } else { + } else { ShenandoahWorkerTimingsTracker timer(_phase, ShenandoahPhaseTimings::CLDGRoots, worker_id); ClassLoaderDataGraph::cld_do(clds); }