8292656: G1: Remove G1HotCardCache::_use_cache

Reviewed-by: tschatzl, iwalulya
This commit is contained in:
Albert Mingkun Yang 2022-08-22 12:38:00 +00:00
parent a17fce7507
commit 476c484e37
7 changed files with 12 additions and 26 deletions

View File

@ -1048,7 +1048,7 @@ void G1CollectedHeap::prepare_heap_for_mutators() {
} }
void G1CollectedHeap::abort_refinement() { void G1CollectedHeap::abort_refinement() {
if (_hot_card_cache->use_cache()) { if (G1HotCardCache::use_cache()) {
_hot_card_cache->reset_hot_cache(); _hot_card_cache->reset_hot_cache();
} }
@ -3377,7 +3377,6 @@ void G1CollectedHeap::update_used_after_gc(bool evacuation_failed) {
void G1CollectedHeap::reset_hot_card_cache() { void G1CollectedHeap::reset_hot_card_cache() {
_hot_card_cache->reset_hot_cache(); _hot_card_cache->reset_hot_cache();
_hot_card_cache->set_use_cache(true);
} }
void G1CollectedHeap::purge_code_root_memory() { void G1CollectedHeap::purge_code_root_memory() {

View File

@ -121,7 +121,7 @@ void G1FullGCPrepareTask::G1ResetMetadataClosure::reset_region_metadata(HeapRegi
hr->clear_cardtable(); hr->clear_cardtable();
G1HotCardCache* hcc = _g1h->hot_card_cache(); G1HotCardCache* hcc = _g1h->hot_card_cache();
if (hcc->use_cache()) { if (G1HotCardCache::use_cache()) {
hcc->reset_card_counts(hr); hcc->reset_card_counts(hr);
} }
} }

View File

@ -83,7 +83,7 @@ G1GCPhaseTimes::G1GCPhaseTimes(STWGCTimer* gc_timer, uint max_gc_threads) :
} }
_gc_par_phases[MergeLB] = new WorkerDataArray<double>("MergeLB", "Log Buffers (ms):", max_gc_threads); _gc_par_phases[MergeLB] = new WorkerDataArray<double>("MergeLB", "Log Buffers (ms):", max_gc_threads);
if (G1HotCardCache::default_use_cache()) { if (G1HotCardCache::use_cache()) {
_gc_par_phases[MergeHCC] = new WorkerDataArray<double>("MergeHCC", "Hot Card Cache (ms):", max_gc_threads); _gc_par_phases[MergeHCC] = new WorkerDataArray<double>("MergeHCC", "Hot Card Cache (ms):", max_gc_threads);
_gc_par_phases[MergeHCC]->create_thread_work_items("Dirty Cards:", MergeHCCDirtyCards); _gc_par_phases[MergeHCC]->create_thread_work_items("Dirty Cards:", MergeHCCDirtyCards);
_gc_par_phases[MergeHCC]->create_thread_work_items("Skipped Cards:", MergeHCCSkippedCards); _gc_par_phases[MergeHCC]->create_thread_work_items("Skipped Cards:", MergeHCCSkippedCards);
@ -434,7 +434,7 @@ double G1GCPhaseTimes::print_evacuate_initial_collection_set() const {
debug_time("Prepare Merge Heap Roots", _cur_prepare_merge_heap_roots_time_ms); debug_time("Prepare Merge Heap Roots", _cur_prepare_merge_heap_roots_time_ms);
debug_phase(_gc_par_phases[MergeER]); debug_phase(_gc_par_phases[MergeER]);
debug_phase(_gc_par_phases[MergeRS]); debug_phase(_gc_par_phases[MergeRS]);
if (G1HotCardCache::default_use_cache()) { if (G1HotCardCache::use_cache()) {
debug_phase(_gc_par_phases[MergeHCC]); debug_phase(_gc_par_phases[MergeHCC]);
} }
debug_phase(_gc_par_phases[MergeLB]); debug_phase(_gc_par_phases[MergeLB]);

View File

@ -30,15 +30,13 @@
#include "runtime/atomic.hpp" #include "runtime/atomic.hpp"
G1HotCardCache::G1HotCardCache(G1CollectedHeap *g1h): G1HotCardCache::G1HotCardCache(G1CollectedHeap *g1h):
_g1h(g1h), _use_cache(false), _card_counts(g1h), _g1h(g1h), _card_counts(g1h),
_hot_cache(NULL), _hot_cache_size(0), _hot_cache_par_chunk_size(0), _hot_cache(NULL), _hot_cache_size(0), _hot_cache_par_chunk_size(0),
_hot_cache_idx(0), _hot_cache_par_claimed_idx(0), _cache_wrapped_around(false) _hot_cache_idx(0), _hot_cache_par_claimed_idx(0), _cache_wrapped_around(false)
{} {}
void G1HotCardCache::initialize(G1RegionToSpaceMapper* card_counts_storage) { void G1HotCardCache::initialize(G1RegionToSpaceMapper* card_counts_storage) {
if (default_use_cache()) { if (use_cache()) {
_use_cache = true;
_hot_cache_size = (size_t)1 << G1ConcRSLogCacheSize; _hot_cache_size = (size_t)1 << G1ConcRSLogCacheSize;
_hot_cache = ArrayAllocator<CardValue*>::allocate(_hot_cache_size, mtGC); _hot_cache = ArrayAllocator<CardValue*>::allocate(_hot_cache_size, mtGC);
@ -55,7 +53,7 @@ void G1HotCardCache::initialize(G1RegionToSpaceMapper* card_counts_storage) {
} }
G1HotCardCache::~G1HotCardCache() { G1HotCardCache::~G1HotCardCache() {
if (default_use_cache()) { if (use_cache()) {
assert(_hot_cache != NULL, "Logic"); assert(_hot_cache != NULL, "Logic");
ArrayAllocator<CardValue*>::free(_hot_cache, _hot_cache_size); ArrayAllocator<CardValue*>::free(_hot_cache, _hot_cache_size);
_hot_cache = NULL; _hot_cache = NULL;
@ -92,10 +90,9 @@ CardTable::CardValue* G1HotCardCache::insert(CardValue* card_ptr) {
} }
void G1HotCardCache::drain(G1CardTableEntryClosure* cl, uint worker_id) { void G1HotCardCache::drain(G1CardTableEntryClosure* cl, uint worker_id) {
assert(default_use_cache(), "Drain only necessary if we use the hot card cache."); assert(use_cache(), "Drain only necessary if we use the hot card cache.");
assert(_hot_cache != NULL, "Logic"); assert(_hot_cache != NULL, "Logic");
assert(!use_cache(), "cache should be disabled");
while (_hot_cache_par_claimed_idx < _hot_cache_size) { while (_hot_cache_par_claimed_idx < _hot_cache_size) {
size_t end_idx = Atomic::add(&_hot_cache_par_claimed_idx, size_t end_idx = Atomic::add(&_hot_cache_par_claimed_idx,

View File

@ -58,8 +58,6 @@ public:
private: private:
G1CollectedHeap* _g1h; G1CollectedHeap* _g1h;
bool _use_cache;
G1CardCounts _card_counts; G1CardCounts _card_counts;
@ -90,7 +88,7 @@ private:
static const int ClaimChunkSize = 32; static const int ClaimChunkSize = 32;
public: public:
static bool default_use_cache() { static bool use_cache() {
return (G1ConcRSLogCacheSize > 0); return (G1ConcRSLogCacheSize > 0);
} }
@ -99,12 +97,6 @@ private:
void initialize(G1RegionToSpaceMapper* card_counts_storage); void initialize(G1RegionToSpaceMapper* card_counts_storage);
bool use_cache() { return _use_cache; }
void set_use_cache(bool b) {
_use_cache = (b ? default_use_cache() : false);
}
// Returns the card to be refined or NULL. // Returns the card to be refined or NULL.
// //
// Increments the count for given the card. if the card is not 'hot', // Increments the count for given the card. if the card is not 'hot',
@ -128,7 +120,7 @@ private:
// Resets the hot card cache and discards the entries. // Resets the hot card cache and discards the entries.
void reset_hot_cache() { void reset_hot_cache() {
assert(SafepointSynchronize::is_at_safepoint(), "Should be at a safepoint"); assert(SafepointSynchronize::is_at_safepoint(), "Should be at a safepoint");
if (default_use_cache()) { if (use_cache()) {
reset_hot_cache_internal(); reset_hot_cache_internal();
} }
} }

View File

@ -1491,7 +1491,7 @@ public:
} }
// Apply closure to log entries in the HCC. // Apply closure to log entries in the HCC.
if (_initial_evacuation && G1HotCardCache::default_use_cache()) { if (_initial_evacuation && G1HotCardCache::use_cache()) {
assert(merge_remset_phase == G1GCPhaseTimes::MergeRS, "Wrong merge phase"); assert(merge_remset_phase == G1GCPhaseTimes::MergeRS, "Wrong merge phase");
G1GCParPhaseTimesTracker x(p, G1GCPhaseTimes::MergeHCC, worker_id); G1GCParPhaseTimesTracker x(p, G1GCPhaseTimes::MergeHCC, worker_id);
G1MergeLogBufferCardsClosure cl(g1h, _scan_state); G1MergeLogBufferCardsClosure cl(g1h, _scan_state);
@ -1657,7 +1657,7 @@ bool G1RemSet::clean_card_before_refine(CardValue** const card_ptr_addr) {
// * a pointer to a "hot" card that was evicted from the "hot" cache. // * a pointer to a "hot" card that was evicted from the "hot" cache.
// //
if (_hot_card_cache->use_cache()) { if (G1HotCardCache::use_cache()) {
assert(!SafepointSynchronize::is_at_safepoint(), "sanity"); assert(!SafepointSynchronize::is_at_safepoint(), "sanity");
const CardValue* orig_card_ptr = card_ptr; const CardValue* orig_card_ptr = card_ptr;

View File

@ -492,9 +492,7 @@ void G1YoungCollector::pre_evacuate_collection_set(G1EvacInfo* evacuation_info,
phase_times()->record_concatenate_dirty_card_logs_time_ms(dt.seconds() * MILLIUNITS); phase_times()->record_concatenate_dirty_card_logs_time_ms(dt.seconds() * MILLIUNITS);
} }
// Disable the hot card cache.
hot_card_cache()->reset_hot_cache_claimed_index(); hot_card_cache()->reset_hot_cache_claimed_index();
hot_card_cache()->set_use_cache(false);
// Initialize the GC alloc regions. // Initialize the GC alloc regions.
allocator()->init_gc_alloc_regions(evacuation_info); allocator()->init_gc_alloc_regions(evacuation_info);