From 91b53894437af38ba57af21961d15c04f2d0fa20 Mon Sep 17 00:00:00 2001 From: Erik Helin Date: Fri, 4 Dec 2015 15:47:13 +0100 Subject: [PATCH] 8144712: Remove g1RootClosures.inline.hpp Reviewed-by: stefank, mgerdin --- hotspot/src/share/vm/gc/g1/g1RootClosures.cpp | 33 ++++++++++++++++- ...osures.inline.hpp => g1SharedClosures.hpp} | 36 +++---------------- 2 files changed, 37 insertions(+), 32 deletions(-) rename hotspot/src/share/vm/gc/g1/{g1RootClosures.inline.hpp => g1SharedClosures.hpp} (61%) diff --git a/hotspot/src/share/vm/gc/g1/g1RootClosures.cpp b/hotspot/src/share/vm/gc/g1/g1RootClosures.cpp index 3d93bf9cec9..4e54a68c73a 100644 --- a/hotspot/src/share/vm/gc/g1/g1RootClosures.cpp +++ b/hotspot/src/share/vm/gc/g1/g1RootClosures.cpp @@ -23,7 +23,38 @@ */ #include "precompiled.hpp" -#include "gc/g1/g1RootClosures.inline.hpp" +#include "gc/g1/g1OopClosures.inline.hpp" +#include "gc/g1/g1RootClosures.hpp" +#include "gc/g1/g1SharedClosures.hpp" + +// Closures used for standard G1 evacuation. +class G1EvacuationClosures : public G1EvacuationRootClosures { + G1SharedClosures _closures; + +public: + G1EvacuationClosures(G1CollectedHeap* g1h, + G1ParScanThreadState* pss, + bool gcs_are_young) : + _closures(g1h, pss, gcs_are_young, /* must_claim_cld */ false) {} + + OopClosure* weak_oops() { return &_closures._buffered_oops; } + OopClosure* strong_oops() { return &_closures._buffered_oops; } + + CLDClosure* weak_clds() { return &_closures._clds; } + CLDClosure* strong_clds() { return &_closures._clds; } + CLDClosure* thread_root_clds() { return NULL; } + CLDClosure* second_pass_weak_clds() { return NULL; } + + CodeBlobClosure* strong_codeblobs() { return &_closures._codeblobs; } + CodeBlobClosure* weak_codeblobs() { return &_closures._codeblobs; } + + void flush() { _closures._buffered_oops.done(); } + double closure_app_seconds() { return _closures._buffered_oops.closure_app_seconds(); } + + OopClosure* raw_strong_oops() { return &_closures._oops; } + + bool trace_metadata() { return false; } +}; // Closures used during initial mark. // The treatment of "weak" roots is selectable through the template parameter, diff --git a/hotspot/src/share/vm/gc/g1/g1RootClosures.inline.hpp b/hotspot/src/share/vm/gc/g1/g1SharedClosures.hpp similarity index 61% rename from hotspot/src/share/vm/gc/g1/g1RootClosures.inline.hpp rename to hotspot/src/share/vm/gc/g1/g1SharedClosures.hpp index 57cf4c7c2a4..85ee225227c 100644 --- a/hotspot/src/share/vm/gc/g1/g1RootClosures.inline.hpp +++ b/hotspot/src/share/vm/gc/g1/g1SharedClosures.hpp @@ -24,9 +24,11 @@ #include "gc/g1/bufferingOopClosure.hpp" #include "gc/g1/g1CodeBlobClosure.hpp" -#include "gc/g1/g1CollectedHeap.hpp" -#include "gc/g1/g1OopClosures.inline.hpp" -#include "gc/g1/g1RootClosures.hpp" +#include "gc/g1/g1OopClosures.hpp" +#include "memory/iterator.hpp" + +class G1CollectedHeap; +class G1ParScanThreadState; // Simple holder object for a complete set of closures used by the G1 evacuation code. template @@ -47,31 +49,3 @@ public: _codeblobs(&_oops), _buffered_oops(&_oops) {} }; - -class G1EvacuationClosures : public G1EvacuationRootClosures { - G1SharedClosures _closures; - -public: - G1EvacuationClosures(G1CollectedHeap* g1h, - G1ParScanThreadState* pss, - bool gcs_are_young) : - _closures(g1h, pss, gcs_are_young, /* must_claim_cld */ false) {} - - OopClosure* weak_oops() { return &_closures._buffered_oops; } - OopClosure* strong_oops() { return &_closures._buffered_oops; } - - CLDClosure* weak_clds() { return &_closures._clds; } - CLDClosure* strong_clds() { return &_closures._clds; } - CLDClosure* thread_root_clds() { return NULL; } - CLDClosure* second_pass_weak_clds() { return NULL; } - - CodeBlobClosure* strong_codeblobs() { return &_closures._codeblobs; } - CodeBlobClosure* weak_codeblobs() { return &_closures._codeblobs; } - - void flush() { _closures._buffered_oops.done(); } - double closure_app_seconds() { return _closures._buffered_oops.closure_app_seconds(); } - - OopClosure* raw_strong_oops() { return &_closures._oops; } - - bool trace_metadata() { return false; } -};