From e265b2a2918f39a1d9afdb6a473c2d8d657cbb8c Mon Sep 17 00:00:00 2001 From: Thomas Schatzl Date: Wed, 3 Aug 2022 14:26:06 +0000 Subject: [PATCH] 8290867: Race freeing remembered set segments Reviewed-by: kbarrett, sangheki --- src/hotspot/share/gc/g1/g1SegmentedArray.cpp | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/src/hotspot/share/gc/g1/g1SegmentedArray.cpp b/src/hotspot/share/gc/g1/g1SegmentedArray.cpp index 2abddc3d6d0..3dedd7ef339 100644 --- a/src/hotspot/share/gc/g1/g1SegmentedArray.cpp +++ b/src/hotspot/share/gc/g1/g1SegmentedArray.cpp @@ -27,6 +27,7 @@ #include "gc/g1/g1SegmentedArray.inline.hpp" #include "memory/allocation.hpp" #include "runtime/atomic.hpp" +#include "runtime/vmOperations.hpp" #include "utilities/globalCounter.inline.hpp" G1SegmentedArraySegment::G1SegmentedArraySegment(uint slot_size, uint num_slots, G1SegmentedArraySegment* next, MEMFLAGS flag) : @@ -48,6 +49,11 @@ G1SegmentedArraySegment* G1SegmentedArraySegment::create_segment(uint slot_size, } void G1SegmentedArraySegment::delete_segment(G1SegmentedArraySegment* segment) { + // Wait for concurrent readers of the segment to exit before freeing; but only if the VM + // isn't exiting. + if (!VM_Exit::vm_exited()) { + GlobalCounter::write_synchronize(); + } segment->~G1SegmentedArraySegment(); FREE_C_HEAP_ARRAY(_mem_flag, segment); }