From 12f6ba0deb31a29353b35ecea5bb8cb5f71011e6 Mon Sep 17 00:00:00 2001 From: Albert Mingkun Yang Date: Tue, 23 Feb 2021 09:27:57 +0000 Subject: [PATCH] 8262087: Use atomic boolean type in G1FullGCAdjustTask Reviewed-by: kbarrett, tschatzl --- src/hotspot/share/gc/g1/g1FullGCAdjustTask.cpp | 5 ++--- src/hotspot/share/gc/g1/g1FullGCAdjustTask.hpp | 2 +- 2 files changed, 3 insertions(+), 4 deletions(-) diff --git a/src/hotspot/share/gc/g1/g1FullGCAdjustTask.cpp b/src/hotspot/share/gc/g1/g1FullGCAdjustTask.cpp index ac5ba8834fb..80dd4288b20 100644 --- a/src/hotspot/share/gc/g1/g1FullGCAdjustTask.cpp +++ b/src/hotspot/share/gc/g1/g1FullGCAdjustTask.cpp @@ -81,7 +81,7 @@ class G1AdjustRegionClosure : public HeapRegionClosure { G1FullGCAdjustTask::G1FullGCAdjustTask(G1FullCollector* collector) : G1FullGCTask("G1 Adjust", collector), _root_processor(G1CollectedHeap::heap(), collector->workers()), - _references_done(0), + _references_done(false), _weak_proc_task(collector->workers()), _hrclaimer(collector->workers()), _adjust(collector), @@ -99,8 +99,7 @@ void G1FullGCAdjustTask::work(uint worker_id) { marker->preserved_stack()->adjust_during_full_gc(); // Adjust the weak roots. - - if (Atomic::add(&_references_done, 1u) == 1u) { // First incr claims task. + if (!Atomic::cmpxchg(&_references_done, false, true)) { G1CollectedHeap::heap()->ref_processor_stw()->weak_oops_do(&_adjust); } diff --git a/src/hotspot/share/gc/g1/g1FullGCAdjustTask.hpp b/src/hotspot/share/gc/g1/g1FullGCAdjustTask.hpp index 2ddcc9853fe..0b33b485452 100644 --- a/src/hotspot/share/gc/g1/g1FullGCAdjustTask.hpp +++ b/src/hotspot/share/gc/g1/g1FullGCAdjustTask.hpp @@ -38,7 +38,7 @@ class G1CollectedHeap; class G1FullGCAdjustTask : public G1FullGCTask { G1RootProcessor _root_processor; - volatile uint _references_done; // Atomic counter / bool + volatile bool _references_done; WeakProcessor::Task _weak_proc_task; HeapRegionClaimer _hrclaimer; G1AdjustClosure _adjust;