From 1dc8fa9902cf2cfa3556ccffb15244115f594966 Mon Sep 17 00:00:00 2001 From: Thomas Schatzl Date: Wed, 29 Sep 2021 13:59:58 +0000 Subject: [PATCH] 8274340: [BACKOUT] JDK-8271880: Tighten condition for excluding regions from collecting cards with cross-references Reviewed-by: kbarrett, ayang --- src/hotspot/share/gc/g1/g1CollectedHeap.cpp | 1 - src/hotspot/share/gc/g1/g1CollectedHeap.hpp | 1 - .../share/gc/g1/g1CollectedHeap.inline.hpp | 4 - src/hotspot/share/gc/g1/g1EvacFailure.cpp | 76 ++++++++++++++++++- src/hotspot/share/gc/g1/g1EvacFailure.hpp | 4 +- src/hotspot/share/gc/g1/g1HeapRegionAttr.hpp | 14 +--- src/hotspot/share/gc/g1/g1OopClosures.hpp | 4 +- .../share/gc/g1/g1ParScanThreadState.cpp | 23 +----- .../share/gc/g1/g1ParScanThreadState.hpp | 2 +- .../gc/g1/g1ParScanThreadState.inline.hpp | 25 ++---- src/hotspot/share/gc/g1/g1YoungCollector.cpp | 30 +------- src/hotspot/share/gc/g1/g1YoungCollector.hpp | 1 + .../gc/g1/g1YoungGCPostEvacuateTasks.cpp | 6 +- .../gc/g1/g1YoungGCPostEvacuateTasks.hpp | 1 + 14 files changed, 95 insertions(+), 97 deletions(-) diff --git a/src/hotspot/share/gc/g1/g1CollectedHeap.cpp b/src/hotspot/share/gc/g1/g1CollectedHeap.cpp index 78f93cf1dcd42..1e8e36d8aa349 100644 --- a/src/hotspot/share/gc/g1/g1CollectedHeap.cpp +++ b/src/hotspot/share/gc/g1/g1CollectedHeap.cpp @@ -3277,7 +3277,6 @@ HeapRegion* G1CollectedHeap::new_gc_alloc_region(size_t word_size, G1HeapRegionA new_alloc_region->set_survivor(); _survivor.add(new_alloc_region); _verifier->check_bitmaps("Survivor Region Allocation", new_alloc_region); - register_new_survivor_region_with_region_attr(new_alloc_region); } else { new_alloc_region->set_old(); _verifier->check_bitmaps("Old Region Allocation", new_alloc_region); diff --git a/src/hotspot/share/gc/g1/g1CollectedHeap.hpp b/src/hotspot/share/gc/g1/g1CollectedHeap.hpp index 55c271f10c6c7..a89faf4c1fcb4 100644 --- a/src/hotspot/share/gc/g1/g1CollectedHeap.hpp +++ b/src/hotspot/share/gc/g1/g1CollectedHeap.hpp @@ -605,7 +605,6 @@ class G1CollectedHeap : public CollectedHeap { void register_young_region_with_region_attr(HeapRegion* r) { _region_attr.set_in_young(r->hrm_index()); } - inline void register_new_survivor_region_with_region_attr(HeapRegion* r); inline void register_region_with_region_attr(HeapRegion* r); inline void register_old_region_with_region_attr(HeapRegion* r); inline void register_optional_region_with_region_attr(HeapRegion* r); diff --git a/src/hotspot/share/gc/g1/g1CollectedHeap.inline.hpp b/src/hotspot/share/gc/g1/g1CollectedHeap.inline.hpp index 0fef0a944492f..4de285b980fba 100644 --- a/src/hotspot/share/gc/g1/g1CollectedHeap.inline.hpp +++ b/src/hotspot/share/gc/g1/g1CollectedHeap.inline.hpp @@ -184,10 +184,6 @@ void G1CollectedHeap::register_humongous_region_with_region_attr(uint index) { _region_attr.set_humongous(index, region_at(index)->rem_set()->is_tracked()); } -void G1CollectedHeap::register_new_survivor_region_with_region_attr(HeapRegion* r) { - _region_attr.set_new_survivor_region(r->hrm_index()); -} - void G1CollectedHeap::register_region_with_region_attr(HeapRegion* r) { _region_attr.set_has_remset(r->hrm_index(), r->rem_set()->is_tracked()); } diff --git a/src/hotspot/share/gc/g1/g1EvacFailure.cpp b/src/hotspot/share/gc/g1/g1EvacFailure.cpp index d3b9b24bdd8bd..b7b564abe494b 100644 --- a/src/hotspot/share/gc/g1/g1EvacFailure.cpp +++ b/src/hotspot/share/gc/g1/g1EvacFailure.cpp @@ -30,6 +30,7 @@ #include "gc/g1/g1EvacFailureRegions.hpp" #include "gc/g1/g1HeapVerifier.hpp" #include "gc/g1/g1OopClosures.inline.hpp" +#include "gc/g1/g1RedirtyCardsQueue.hpp" #include "gc/g1/heapRegion.hpp" #include "gc/g1/heapRegionRemSet.inline.hpp" #include "gc/shared/preservedMarks.inline.hpp" @@ -37,23 +38,65 @@ #include "oops/compressedOops.inline.hpp" #include "oops/oop.inline.hpp" +class UpdateLogBuffersDeferred : public BasicOopIterateClosure { +private: + G1CollectedHeap* _g1h; + G1RedirtyCardsLocalQueueSet* _rdc_local_qset; + G1CardTable* _ct; + + // Remember the last enqueued card to avoid enqueuing the same card over and over; + // since we only ever handle a card once, this is sufficient. + size_t _last_enqueued_card; + +public: + UpdateLogBuffersDeferred(G1RedirtyCardsLocalQueueSet* rdc_local_qset) : + _g1h(G1CollectedHeap::heap()), + _rdc_local_qset(rdc_local_qset), + _ct(_g1h->card_table()), + _last_enqueued_card(SIZE_MAX) {} + + virtual void do_oop(narrowOop* p) { do_oop_work(p); } + virtual void do_oop( oop* p) { do_oop_work(p); } + template void do_oop_work(T* p) { + assert(_g1h->heap_region_containing(p)->is_in_reserved(p), "paranoia"); + assert(!_g1h->heap_region_containing(p)->is_survivor(), "Unexpected evac failure in survivor region"); + + T const o = RawAccess<>::oop_load(p); + if (CompressedOops::is_null(o)) { + return; + } + + if (HeapRegion::is_in_same_region(p, CompressedOops::decode(o))) { + return; + } + size_t card_index = _ct->index_for(p); + if (card_index != _last_enqueued_card) { + _rdc_local_qset->enqueue(_ct->byte_for_index(card_index)); + _last_enqueued_card = card_index; + } + } +}; + class RemoveSelfForwardPtrObjClosure: public ObjectClosure { G1CollectedHeap* _g1h; G1ConcurrentMark* _cm; HeapRegion* _hr; size_t _marked_bytes; + UpdateLogBuffersDeferred* _log_buffer_cl; bool _during_concurrent_start; uint _worker_id; HeapWord* _last_forwarded_object_end; public: RemoveSelfForwardPtrObjClosure(HeapRegion* hr, + UpdateLogBuffersDeferred* log_buffer_cl, bool during_concurrent_start, uint worker_id) : _g1h(G1CollectedHeap::heap()), _cm(_g1h->concurrent_mark()), _hr(hr), _marked_bytes(0), + _log_buffer_cl(log_buffer_cl), _during_concurrent_start(during_concurrent_start), _worker_id(worker_id), _last_forwarded_object_end(hr->bottom()) { } @@ -98,6 +141,20 @@ class RemoveSelfForwardPtrObjClosure: public ObjectClosure { _marked_bytes += (obj_size * HeapWordSize); PreservedMarks::init_forwarded_mark(obj); + // While we were processing RSet buffers during the collection, + // we actually didn't scan any cards on the collection set, + // since we didn't want to update remembered sets with entries + // that point into the collection set, given that live objects + // from the collection set are about to move and such entries + // will be stale very soon. + // This change also dealt with a reliability issue which + // involved scanning a card in the collection set and coming + // across an array that was being chunked and looking malformed. + // The problem is that, if evacuation fails, we might have + // remembered set entries missing given that we skipped cards on + // the collection set. So, we'll recreate such entries now. + obj->oop_iterate(_log_buffer_cl); + HeapWord* obj_end = obj_addr + obj_size; _last_forwarded_object_end = obj_end; _hr->alloc_block_in_bot(obj_addr, obj_end); @@ -146,22 +203,33 @@ class RemoveSelfForwardPtrHRClosure: public HeapRegionClosure { G1CollectedHeap* _g1h; uint _worker_id; + G1RedirtyCardsLocalQueueSet _rdc_local_qset; + UpdateLogBuffersDeferred _log_buffer_cl; + uint volatile* _num_failed_regions; G1EvacFailureRegions* _evac_failure_regions; public: - RemoveSelfForwardPtrHRClosure(uint worker_id, + RemoveSelfForwardPtrHRClosure(G1RedirtyCardsQueueSet* rdcqs, + uint worker_id, uint volatile* num_failed_regions, G1EvacFailureRegions* evac_failure_regions) : _g1h(G1CollectedHeap::heap()), _worker_id(worker_id), + _rdc_local_qset(rdcqs), + _log_buffer_cl(&_rdc_local_qset), _num_failed_regions(num_failed_regions), _evac_failure_regions(evac_failure_regions) { } + ~RemoveSelfForwardPtrHRClosure() { + _rdc_local_qset.flush(); + } + size_t remove_self_forward_ptr_by_walking_hr(HeapRegion* hr, bool during_concurrent_start) { RemoveSelfForwardPtrObjClosure rspc(hr, + &_log_buffer_cl, during_concurrent_start, _worker_id); hr->object_iterate(&rspc); @@ -200,15 +268,17 @@ class RemoveSelfForwardPtrHRClosure: public HeapRegionClosure { } }; -G1ParRemoveSelfForwardPtrsTask::G1ParRemoveSelfForwardPtrsTask(G1EvacFailureRegions* evac_failure_regions) : +G1ParRemoveSelfForwardPtrsTask::G1ParRemoveSelfForwardPtrsTask(G1RedirtyCardsQueueSet* rdcqs, + G1EvacFailureRegions* evac_failure_regions) : AbstractGangTask("G1 Remove Self-forwarding Pointers"), _g1h(G1CollectedHeap::heap()), + _rdcqs(rdcqs), _hrclaimer(_g1h->workers()->active_workers()), _evac_failure_regions(evac_failure_regions), _num_failed_regions(0) { } void G1ParRemoveSelfForwardPtrsTask::work(uint worker_id) { - RemoveSelfForwardPtrHRClosure rsfp_cl(worker_id, &_num_failed_regions, _evac_failure_regions); + RemoveSelfForwardPtrHRClosure rsfp_cl(_rdcqs, worker_id, &_num_failed_regions, _evac_failure_regions); // Iterate through all regions that failed evacuation during the entire collection. _evac_failure_regions->par_iterate(&rsfp_cl, &_hrclaimer, worker_id); diff --git a/src/hotspot/share/gc/g1/g1EvacFailure.hpp b/src/hotspot/share/gc/g1/g1EvacFailure.hpp index b0387a3a24f8b..cd587ac839d60 100644 --- a/src/hotspot/share/gc/g1/g1EvacFailure.hpp +++ b/src/hotspot/share/gc/g1/g1EvacFailure.hpp @@ -32,19 +32,21 @@ class G1CollectedHeap; class G1EvacFailureRegions; +class G1RedirtyCardsQueueSet; // Task to fixup self-forwarding pointers // installed as a result of an evacuation failure. class G1ParRemoveSelfForwardPtrsTask: public AbstractGangTask { protected: G1CollectedHeap* _g1h; + G1RedirtyCardsQueueSet* _rdcqs; HeapRegionClaimer _hrclaimer; G1EvacFailureRegions* _evac_failure_regions; uint volatile _num_failed_regions; public: - G1ParRemoveSelfForwardPtrsTask(G1EvacFailureRegions* evac_failure_regions); + G1ParRemoveSelfForwardPtrsTask(G1RedirtyCardsQueueSet* rdcqs, G1EvacFailureRegions* evac_failure_regions); void work(uint worker_id); diff --git a/src/hotspot/share/gc/g1/g1HeapRegionAttr.hpp b/src/hotspot/share/gc/g1/g1HeapRegionAttr.hpp index 3bb7c02b88de5..2d8ae1fae4079 100644 --- a/src/hotspot/share/gc/g1/g1HeapRegionAttr.hpp +++ b/src/hotspot/share/gc/g1/g1HeapRegionAttr.hpp @@ -57,9 +57,8 @@ struct G1HeapRegionAttr { // // The other values are used for objects in regions requiring various special handling, // eager reclamation of humongous objects or optional regions. - static const region_type_t Optional = -4; // The region is optional not in the current collection set. - static const region_type_t Humongous = -3; // The region is a humongous candidate not in the current collection set. - static const region_type_t NewSurvivor = -2; // The region is a new (ly allocated) survivor region. + static const region_type_t Optional = -3; // The region is optional not in the current collection set. + static const region_type_t Humongous = -2; // The region is a humongous candidate not in the current collection set. static const region_type_t NotInCSet = -1; // The region is not in the collection set. static const region_type_t Young = 0; // The region is in the collection set and a young region. static const region_type_t Old = 1; // The region is in the collection set and an old region. @@ -77,7 +76,6 @@ struct G1HeapRegionAttr { switch (type()) { case Optional: return "Optional"; case Humongous: return "Humongous"; - case NewSurvivor: return "NewSurvivor"; case NotInCSet: return "NotInCSet"; case Young: return "Young"; case Old: return "Old"; @@ -87,7 +85,6 @@ struct G1HeapRegionAttr { bool needs_remset_update() const { return _needs_remset_update != 0; } - void set_new_survivor() { _type = NewSurvivor; } void set_old() { _type = Old; } void clear_humongous() { assert(is_humongous() || !is_in_cset(), "must be"); @@ -99,7 +96,6 @@ struct G1HeapRegionAttr { bool is_in_cset() const { return type() >= Young; } bool is_humongous() const { return type() == Humongous; } - bool is_new_survivor() const { return type() == NewSurvivor; } bool is_young() const { return type() == Young; } bool is_old() const { return type() == Old; } bool is_optional() const { return type() == Optional; } @@ -132,12 +128,6 @@ class G1HeapRegionAttrBiasedMappedArray : public G1BiasedMappedArrayset_new_survivor(); - } - void set_humongous(uintptr_t index, bool needs_remset_update) { assert(get_by_index(index).is_default(), "Region attributes at index " INTPTR_FORMAT " should be default but is %s", index, get_by_index(index).get_type_str()); diff --git a/src/hotspot/share/gc/g1/g1OopClosures.hpp b/src/hotspot/share/gc/g1/g1OopClosures.hpp index 9f0c4a23a55d4..d8fff5721da60 100644 --- a/src/hotspot/share/gc/g1/g1OopClosures.hpp +++ b/src/hotspot/share/gc/g1/g1OopClosures.hpp @@ -116,9 +116,9 @@ class G1SkipCardEnqueueSetter : public StackObj { G1ScanEvacuatedObjClosure* _closure; public: - G1SkipCardEnqueueSetter(G1ScanEvacuatedObjClosure* closure, bool skip_card_enqueue) : _closure(closure) { + G1SkipCardEnqueueSetter(G1ScanEvacuatedObjClosure* closure, bool new_value) : _closure(closure) { assert(_closure->_skip_card_enqueue == G1ScanEvacuatedObjClosure::Uninitialized, "Must not be set"); - _closure->_skip_card_enqueue = skip_card_enqueue ? G1ScanEvacuatedObjClosure::True : G1ScanEvacuatedObjClosure::False; + _closure->_skip_card_enqueue = new_value ? G1ScanEvacuatedObjClosure::True : G1ScanEvacuatedObjClosure::False; } ~G1SkipCardEnqueueSetter() { diff --git a/src/hotspot/share/gc/g1/g1ParScanThreadState.cpp b/src/hotspot/share/gc/g1/g1ParScanThreadState.cpp index 92772cc2db7f6..03540a9567182 100644 --- a/src/hotspot/share/gc/g1/g1ParScanThreadState.cpp +++ b/src/hotspot/share/gc/g1/g1ParScanThreadState.cpp @@ -235,8 +235,8 @@ void G1ParScanThreadState::do_partial_array(PartialArrayScanTask task) { push_on_queue(ScannerTask(PartialArrayScanTask(from_obj))); } - G1HeapRegionAttr dest_attr = _g1h->region_attr(to_array); - G1SkipCardEnqueueSetter x(&_scanner, dest_attr.is_new_survivor()); + HeapRegion* hr = _g1h->heap_region_containing(to_array); + G1SkipCardEnqueueSetter x(&_scanner, hr->is_young()); // Process claimed task. The length of to_array is not correct, but // fortunately the iteration ignores the length field and just relies // on start/end. @@ -268,11 +268,6 @@ void G1ParScanThreadState::start_partial_objarray(G1HeapRegionAttr dest_attr, push_on_queue(ScannerTask(PartialArrayScanTask(from_obj))); } - // Skip the card enqueue iff the object (to_array) is in survivor region. - // However, HeapRegion::is_survivor() is too expensive here. - // Instead, we use dest_attr.is_young() because the two values are always - // equal: successfully allocated young regions must be survivor regions. - assert(dest_attr.is_young() == _g1h->heap_region_containing(to_array)->is_survivor(), "must be"); G1SkipCardEnqueueSetter x(&_scanner, dest_attr.is_young()); // Process the initial chunk. No need to process the type in the // klass, as it will already be handled by processing the built-in @@ -524,11 +519,6 @@ oop G1ParScanThreadState::do_copy_to_survivor_space(G1HeapRegionAttr const regio _string_dedup_requests.add(old); } - // Skip the card enqueue iff the object (obj) is in survivor region. - // However, HeapRegion::is_survivor() is too expensive here. - // Instead, we use dest_attr.is_young() because the two values are always - // equal: successfully allocated young regions must be survivor regions. - assert(dest_attr.is_young() == _g1h->heap_region_containing(obj)->is_survivor(), "must be"); G1SkipCardEnqueueSetter x(&_scanner, dest_attr.is_young()); obj->oop_iterate_backwards(&_scanner, klass); return obj; @@ -615,14 +605,7 @@ oop G1ParScanThreadState::handle_evacuation_failure_par(oop old, markWord m, siz _preserved_marks->push_if_necessary(old, m); _evacuation_failed_info.register_copy_failure(word_sz); - // For iterating objects that failed evacuation currently we can reuse the - // existing closure to scan evacuated objects because: - // - for objects referring into the collection set we do not need to gather - // cards at this time. The regions they are in will be unconditionally turned - // to old regions without remembered sets. - // - since we are iterating from a collection set region (i.e. never a Survivor - // region), we always need to gather cards for this case. - G1SkipCardEnqueueSetter x(&_scanner, false /* skip_card_enqueue */); + G1SkipCardEnqueueSetter x(&_scanner, r->is_young()); old->oop_iterate_backwards(&_scanner); return old; diff --git a/src/hotspot/share/gc/g1/g1ParScanThreadState.hpp b/src/hotspot/share/gc/g1/g1ParScanThreadState.hpp index 0ecc11f50a516..ea4fb10f5bd32 100644 --- a/src/hotspot/share/gc/g1/g1ParScanThreadState.hpp +++ b/src/hotspot/share/gc/g1/g1ParScanThreadState.hpp @@ -134,7 +134,7 @@ class G1ParScanThreadState : public CHeapObj { // Apply the post barrier to the given reference field. Enqueues the card of p // if the barrier does not filter out the reference for some reason (e.g. - // p and q are in the same region, p is in survivor, p is in collection set) + // p and q are in the same region, p is in survivor) // To be called during GC if nothing particular about p and obj are known. template void write_ref_field_post(T* p, oop obj); diff --git a/src/hotspot/share/gc/g1/g1ParScanThreadState.inline.hpp b/src/hotspot/share/gc/g1/g1ParScanThreadState.inline.hpp index a363473710376..1184919dbf28d 100644 --- a/src/hotspot/share/gc/g1/g1ParScanThreadState.inline.hpp +++ b/src/hotspot/share/gc/g1/g1ParScanThreadState.inline.hpp @@ -97,34 +97,19 @@ G1OopStarChunkedList* G1ParScanThreadState::oops_into_optional_region(const Heap } template void G1ParScanThreadState::write_ref_field_post(T* p, oop obj) { - assert(obj != nullptr, "Must be"); + assert(obj != NULL, "Must be"); if (HeapRegion::is_in_same_region(p, obj)) { return; } - G1HeapRegionAttr from_attr = _g1h->region_attr(p); - // If this is a reference from (current) survivor regions, we do not need - // to track references from it. - if (from_attr.is_new_survivor()) { - return; - } - G1HeapRegionAttr dest_attr = _g1h->region_attr(obj); - // References to the current collection set are references to objects that failed - // evacuation. Currently these regions are always relabelled as old without - // remembered sets, so skip them. - assert(dest_attr.is_in_cset() == (obj->forwardee() == obj), - "Only evac-failed objects must be in the collection set here but " PTR_FORMAT " is not", p2i(obj)); - if (dest_attr.is_in_cset()) { - return; + HeapRegion* from = _g1h->heap_region_containing(p); + if (!from->is_young()) { + enqueue_card_if_tracked(_g1h->region_attr(obj), p, obj); } - enqueue_card_if_tracked(dest_attr, p, obj); } template void G1ParScanThreadState::enqueue_card_if_tracked(G1HeapRegionAttr region_attr, T* p, oop o) { assert(!HeapRegion::is_in_same_region(p, o), "Should have filtered out cross-region references already."); - assert(!_g1h->heap_region_containing(p)->is_survivor(), "Should have filtered out from-newly allocated survivor references already."); - // We relabel all regions that failed evacuation as old gen without remembered, - // and so pre-filter them out in the caller. - assert(!_g1h->heap_region_containing(o)->in_collection_set(), "Should not try to enqueue reference into collection set region"); + assert(!_g1h->heap_region_containing(p)->is_young(), "Should have filtered out from-young references already."); #ifdef ASSERT HeapRegion* const hr_obj = _g1h->heap_region_containing(o); diff --git a/src/hotspot/share/gc/g1/g1YoungCollector.cpp b/src/hotspot/share/gc/g1/g1YoungCollector.cpp index e1c0fcd16dff0..13296026a3462 100644 --- a/src/hotspot/share/gc/g1/g1YoungCollector.cpp +++ b/src/hotspot/share/gc/g1/g1YoungCollector.cpp @@ -25,7 +25,6 @@ #include "precompiled.hpp" #include "classfile/classLoaderDataGraph.inline.hpp" -#include "classfile/javaClasses.inline.hpp" #include "compiler/oopMap.hpp" #include "gc/g1/g1Allocator.hpp" #include "gc/g1/g1CardSetMemory.hpp" @@ -912,33 +911,6 @@ class G1STWRefProcProxyTask : public RefProcProxyTask { TaskTerminator _terminator; G1ScannerTasksQueueSet& _task_queues; - // Special closure for enqueuing discovered fields: during enqueue the card table - // may not be in shape to properly handle normal barrier calls (e.g. card marks - // in regions that failed evacuation, scribbling of various values by card table - // scan code). Additionally the regular barrier enqueues into the "global" - // DCQS, but during GC we need these to-be-refined entries in the GC local queue - // so that after clearing the card table, the redirty cards phase will properly - // mark all dirty cards to be picked up by refinement. - class G1EnqueueDiscoveredFieldClosure : public EnqueueDiscoveredFieldClosure { - G1CollectedHeap* _g1h; - G1ParScanThreadState* _pss; - - public: - G1EnqueueDiscoveredFieldClosure(G1CollectedHeap* g1h, G1ParScanThreadState* pss) : _g1h(g1h), _pss(pss) { } - - void enqueue(oop reference, oop value) override { - HeapWord* discovered_addr = java_lang_ref_Reference::discovered_addr_raw(reference); - - // Store the value first, whatever it is. - RawAccess<>::oop_store(discovered_addr, value); - - if (value == nullptr) { - return; - } - _pss->write_ref_field_post(discovered_addr, value); - } - }; - public: G1STWRefProcProxyTask(uint max_workers, G1CollectedHeap& g1h, G1ParScanThreadStateSet& pss, G1ScannerTasksQueueSet& task_queues) : RefProcProxyTask("G1STWRefProcProxyTask", max_workers), @@ -956,7 +928,7 @@ class G1STWRefProcProxyTask : public RefProcProxyTask { G1STWIsAliveClosure is_alive(&_g1h); G1CopyingKeepAliveClosure keep_alive(&_g1h, pss); - G1EnqueueDiscoveredFieldClosure enqueue(&_g1h, pss); + BarrierEnqueueDiscoveredFieldClosure enqueue; G1ParEvacuateFollowersClosure complete_gc(&_g1h, pss, &_task_queues, _tm == RefProcThreadModel::Single ? nullptr : &_terminator, G1GCPhaseTimes::ObjCopy); _rp_task->rp_work(worker_id, &is_alive, &keep_alive, &enqueue, &complete_gc); diff --git a/src/hotspot/share/gc/g1/g1YoungCollector.hpp b/src/hotspot/share/gc/g1/g1YoungCollector.hpp index cc6370f1957f9..94a5e1c091e8c 100644 --- a/src/hotspot/share/gc/g1/g1YoungCollector.hpp +++ b/src/hotspot/share/gc/g1/g1YoungCollector.hpp @@ -142,6 +142,7 @@ class G1YoungCollector { #endif // TASKQUEUE_STATS public: + G1YoungCollector(GCCause::Cause gc_cause, double target_pause_time_ms); void collect(); diff --git a/src/hotspot/share/gc/g1/g1YoungGCPostEvacuateTasks.cpp b/src/hotspot/share/gc/g1/g1YoungGCPostEvacuateTasks.cpp index 88c9cba3c606b..727c4538610b2 100644 --- a/src/hotspot/share/gc/g1/g1YoungGCPostEvacuateTasks.cpp +++ b/src/hotspot/share/gc/g1/g1YoungGCPostEvacuateTasks.cpp @@ -102,9 +102,9 @@ class G1PostEvacuateCollectionSetCleanupTask1::RemoveSelfForwardPtrsTask : publi G1EvacFailureRegions* _evac_failure_regions; public: - RemoveSelfForwardPtrsTask(G1EvacFailureRegions* evac_failure_regions) : + RemoveSelfForwardPtrsTask(G1RedirtyCardsQueueSet* rdcqs, G1EvacFailureRegions* evac_failure_regions) : G1AbstractSubTask(G1GCPhaseTimes::RemoveSelfForwardingPtr), - _task(evac_failure_regions), + _task(rdcqs, evac_failure_regions), _evac_failure_regions(evac_failure_regions) { } ~RemoveSelfForwardPtrsTask() { @@ -135,7 +135,7 @@ G1PostEvacuateCollectionSetCleanupTask1::G1PostEvacuateCollectionSetCleanupTask1 add_serial_task(new SampleCollectionSetCandidatesTask()); } if (evacuation_failed) { - add_parallel_task(new RemoveSelfForwardPtrsTask(evac_failure_regions)); + add_parallel_task(new RemoveSelfForwardPtrsTask(per_thread_states->rdcqs(), evac_failure_regions)); } add_parallel_task(G1CollectedHeap::heap()->rem_set()->create_cleanup_after_scan_heap_roots_task()); } diff --git a/src/hotspot/share/gc/g1/g1YoungGCPostEvacuateTasks.hpp b/src/hotspot/share/gc/g1/g1YoungGCPostEvacuateTasks.hpp index 6613438e19b3f..0201dc3a738d5 100644 --- a/src/hotspot/share/gc/g1/g1YoungGCPostEvacuateTasks.hpp +++ b/src/hotspot/share/gc/g1/g1YoungGCPostEvacuateTasks.hpp @@ -34,6 +34,7 @@ class G1CollectedHeap; class G1EvacFailureRegions; class G1EvacInfo; class G1ParScanThreadStateSet; +class G1RedirtyCardsQueueSet; // First set of post evacuate collection set tasks containing ("s" means serial): // - Merge PSS (s)