diff --git a/src/hotspot/share/gc/shared/genCollectedHeap.cpp b/src/hotspot/share/gc/shared/genCollectedHeap.cpp index e32356a9d5d..2324fdfd2e7 100644 --- a/src/hotspot/share/gc/shared/genCollectedHeap.cpp +++ b/src/hotspot/share/gc/shared/genCollectedHeap.cpp @@ -49,7 +49,7 @@ #include "gc/shared/gcInitLogger.hpp" #include "gc/shared/locationPrinter.inline.hpp" #include "gc/shared/oopStorage.inline.hpp" -#include "gc/shared/oopStorageSet.hpp" +#include "gc/shared/oopStorageSet.inline.hpp" #include "gc/shared/oopStorageParState.inline.hpp" #include "gc/shared/scavengableNMethods.hpp" #include "gc/shared/space.hpp" @@ -825,10 +825,6 @@ void GenCollectedHeap::process_roots(StrongRootsScope* scope, if (_process_strong_tasks->try_claim_task(GCH_PS_Universe_oops_do)) { Universe::oops_do(strong_roots); } - // Global (strong) JNI handles - if (_process_strong_tasks->try_claim_task(GCH_PS_JNIHandles_oops_do)) { - JNIHandles::oops_do(strong_roots); - } if (_process_strong_tasks->try_claim_task(GCH_PS_ObjectSynchronizer_oops_do)) { ObjectSynchronizer::oops_do(strong_roots); @@ -844,8 +840,8 @@ void GenCollectedHeap::process_roots(StrongRootsScope* scope, AOTLoader::oops_do(strong_roots); } #endif - if (_process_strong_tasks->try_claim_task(GCH_PS_VMGlobal_oops_do)) { - OopStorageSet::vm_global()->oops_do(strong_roots); + if (_process_strong_tasks->try_claim_task(GCH_PS_OopStorageSet_oops_do)) { + OopStorageSet::strong_oops_do(strong_roots); } if (_process_strong_tasks->try_claim_task(GCH_PS_CodeCache_oops_do)) { diff --git a/src/hotspot/share/gc/shared/genCollectedHeap.hpp b/src/hotspot/share/gc/shared/genCollectedHeap.hpp index 4bd5e32fc53..75716573103 100644 --- a/src/hotspot/share/gc/shared/genCollectedHeap.hpp +++ b/src/hotspot/share/gc/shared/genCollectedHeap.hpp @@ -106,11 +106,10 @@ protected: // The set of potentially parallel tasks in root scanning. enum GCH_strong_roots_tasks { GCH_PS_Universe_oops_do, - GCH_PS_JNIHandles_oops_do, GCH_PS_ObjectSynchronizer_oops_do, GCH_PS_FlatProfiler_oops_do, GCH_PS_Management_oops_do, - GCH_PS_VMGlobal_oops_do, + GCH_PS_OopStorageSet_oops_do, GCH_PS_ClassLoaderDataGraph_oops_do, GCH_PS_jvmti_oops_do, GCH_PS_CodeCache_oops_do, diff --git a/src/hotspot/share/gc/shared/oopStorageSet.hpp b/src/hotspot/share/gc/shared/oopStorageSet.hpp index 120f1c4f8d1..1e2b9691140 100644 --- a/src/hotspot/share/gc/shared/oopStorageSet.hpp +++ b/src/hotspot/share/gc/shared/oopStorageSet.hpp @@ -95,6 +95,9 @@ public: static OopStorage* resolved_method_table_weak() { return storage(resolved_method_table_weak_index); } + + template + static void strong_oops_do(Closure* cl); }; class OopStorageSet::Iterator { diff --git a/src/hotspot/share/gc/shared/oopStorageSet.inline.hpp b/src/hotspot/share/gc/shared/oopStorageSet.inline.hpp new file mode 100644 index 00000000000..65f6ed01915 --- /dev/null +++ b/src/hotspot/share/gc/shared/oopStorageSet.inline.hpp @@ -0,0 +1,38 @@ +/* + * Copyright (c) 2020, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + * + */ + +#ifndef SHARE_GC_SHARED_OOPSTORAGESET_INLINE_HPP +#define SHARE_GC_SHARED_OOPSTORAGESET_INLINE_HPP + +#include "gc/shared/oopStorage.inline.hpp" +#include "gc/shared/oopStorageSet.hpp" + +template +void OopStorageSet::strong_oops_do(Closure* cl) { + for (OopStorageSet::Iterator it = OopStorageSet::strong_iterator(); !it.is_end(); ++it) { + (*it)->oops_do(cl); + } +} + +#endif // SHARE_GC_SHARED_OOPSTORAGESET_INLINE_HPP