8329528: G1 does not update TAMS correctly when dropping retained regions during Concurrent Start pause

Reviewed-by: ayang, iwalulya
This commit is contained in:
Thomas Schatzl 2024-04-11 11:35:07 +00:00
parent 9acce7a6f3
commit ff5c9a4dde
4 changed files with 80 additions and 8 deletions

View File

@ -869,7 +869,7 @@ public:
NoteStartOfMarkHRClosure() : HeapRegionClosure(), _cm(G1CollectedHeap::heap()->concurrent_mark()) { }
bool do_heap_region(HeapRegion* r) override {
if (r->is_old_or_humongous() && !r->is_collection_set_candidate()) {
if (r->is_old_or_humongous() && !r->is_collection_set_candidate() && !r->in_collection_set()) {
_cm->update_top_at_mark_start(r);
}
return false;

View File

@ -484,13 +484,8 @@ void G1YoungCollector::set_young_collection_default_active_worker_threads(){
}
void G1YoungCollector::pre_evacuate_collection_set(G1EvacInfo* evacuation_info) {
// Must be before collection set calculation, requires collection set to not
// be calculated yet.
if (collector_state()->in_concurrent_start_gc()) {
concurrent_mark()->pre_concurrent_start(_gc_cause);
}
// Flush various data in thread-local buffers to be able to determine the collection
// set
{
Ticks start = Ticks::now();
G1PreEvacuateCollectionSetBatchTask cl;
@ -501,6 +496,10 @@ void G1YoungCollector::pre_evacuate_collection_set(G1EvacInfo* evacuation_info)
// Needs log buffers flushed.
calculate_collection_set(evacuation_info, policy()->max_pause_time_ms());
if (collector_state()->in_concurrent_start_gc()) {
concurrent_mark()->pre_concurrent_start(_gc_cause);
}
// Please see comment in g1CollectedHeap.hpp and
// G1CollectedHeap::ref_processing_init() to see how
// reference processing currently works in G1.

View File

@ -29,6 +29,7 @@
// Set of pre evacuate collection set tasks containing ("s" means serial):
// - Retire TLAB and Flush Logs (Java threads)
// - Flush pin count cache (Java threads)
// - Flush Logs (s) (Non-Java threads)
class G1PreEvacuateCollectionSetBatchTask : public G1BatchedTask {
class JavaThreadRetireTLABAndFlushLogs;

View File

@ -0,0 +1,72 @@
/*
* Copyright (c) 2024, 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.
*/
/* @test
* @summary Check that TAMSes are correctly updated for regions dropped from
* the retained collection set candidates during a Concurrent Start pause.
* @requires vm.gc.G1
* @requires vm.flagless
* @library /test/lib
* @build jdk.test.whitebox.WhiteBox
* @run driver jdk.test.lib.helpers.ClassFileInstaller jdk.test.whitebox.WhiteBox
* @run main/othervm -XX:+UseG1GC -XX:+UnlockDiagnosticVMOptions -XX:+UnlockExperimentalVMOptions
-XX:+WhiteBoxAPI -Xbootclasspath/a:. -Xmx32m -XX:G1NumCollectionsKeepPinned=1
-XX:+VerifyBeforeGC -XX:+VerifyAfterGC -XX:G1MixedGCLiveThresholdPercent=100
-XX:G1HeapWastePercent=0 -Xlog:gc,gc+ergo+cset=trace gc.g1.pinnedobjs.TestDroppedRetainedTAMS
*/
package gc.g1.pinnedobjs;
import jdk.test.whitebox.WhiteBox;
public class TestDroppedRetainedTAMS {
private static final WhiteBox wb = WhiteBox.getWhiteBox();
private static final char[] dummy = new char[100];
public static void main(String[] args) {
wb.fullGC(); // Move the target dummy object to old gen.
wb.pinObject(dummy);
// After this concurrent cycle the pinned region will be in the the (marking)
// collection set candidates.
wb.g1RunConcurrentGC();
// Pass the Prepare mixed gc which will not do anything about the marking
// candidates.
wb.youngGC();
// Mixed GC. Will complete. That pinned region is now retained. The mixed gcs
// will end here.
wb.youngGC();
// The pinned region will be dropped from the retained candidates during the
// Concurrent Start GC, leaving that region's TAMS broken.
wb.g1RunConcurrentGC();
// Verification will find a lot of broken objects.
wb.youngGC();
System.out.println(dummy);
}
}