8292656: G1: Remove G1HotCardCache::_use_cache
Reviewed-by: tschatzl, iwalulya
This commit is contained in:
parent
a17fce7507
commit
476c484e37
@ -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() {
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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]);
|
||||||
|
@ -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,
|
||||||
|
@ -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();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
|
@ -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);
|
||||||
|
Loading…
Reference in New Issue
Block a user