From 1f00c3b9ba75fe3aff9844874b2d7190e53d1b22 Mon Sep 17 00:00:00 2001 From: Roman Kennke Date: Wed, 28 Oct 2020 12:14:44 +0000 Subject: [PATCH] 8255527: Shenandoah: Let ShenadoahGCStateResetter disable barriers Reviewed-by: shade, zgu --- .../share/gc/shenandoah/shenandoahRootVerifier.cpp | 12 +++++++----- .../share/gc/shenandoah/shenandoahRootVerifier.hpp | 1 + 2 files changed, 8 insertions(+), 5 deletions(-) diff --git a/src/hotspot/share/gc/shenandoah/shenandoahRootVerifier.cpp b/src/hotspot/share/gc/shenandoah/shenandoahRootVerifier.cpp index 84fde873dda..6e3c826a80e 100644 --- a/src/hotspot/share/gc/shenandoah/shenandoahRootVerifier.cpp +++ b/src/hotspot/share/gc/shenandoah/shenandoahRootVerifier.cpp @@ -41,15 +41,17 @@ #include "utilities/debug.hpp" ShenandoahGCStateResetter::ShenandoahGCStateResetter() : - _gc_state(ShenandoahHeap::heap()->gc_state()), + _heap(ShenandoahHeap::heap()), + _gc_state(_heap->gc_state()), _concurrent_weak_root_in_progress(ShenandoahHeap::heap()->is_concurrent_weak_root_in_progress()) { + _heap->_gc_state.clear(); + _heap->set_concurrent_weak_root_in_progress(false); } ShenandoahGCStateResetter::~ShenandoahGCStateResetter() { - ShenandoahHeap* const heap = ShenandoahHeap::heap(); - heap->_gc_state.set(_gc_state); - assert(heap->gc_state() == _gc_state, "Should be restored"); - heap->set_concurrent_weak_root_in_progress(_concurrent_weak_root_in_progress); + _heap->_gc_state.set(_gc_state); + assert(_heap->gc_state() == _gc_state, "Should be restored"); + _heap->set_concurrent_weak_root_in_progress(_concurrent_weak_root_in_progress); } // Check for overflow of number of root types. diff --git a/src/hotspot/share/gc/shenandoah/shenandoahRootVerifier.hpp b/src/hotspot/share/gc/shenandoah/shenandoahRootVerifier.hpp index a0171a684cf..3668c240190 100644 --- a/src/hotspot/share/gc/shenandoah/shenandoahRootVerifier.hpp +++ b/src/hotspot/share/gc/shenandoah/shenandoahRootVerifier.hpp @@ -30,6 +30,7 @@ class ShenandoahGCStateResetter : public StackObj { private: + ShenandoahHeap* const _heap; const char _gc_state; const bool _concurrent_weak_root_in_progress;