From e36fa7783ff556af02cade68b082fa25f4115976 Mon Sep 17 00:00:00 2001 From: Stefan Karlsson Date: Mon, 25 Nov 2019 14:57:03 +0100 Subject: [PATCH] 8234009: ZGC: Move resurrection unblock to before the _unload.purge() call Reviewed-by: pliden, eosterlund --- src/hotspot/share/gc/z/zHeap.cpp | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/hotspot/share/gc/z/zHeap.cpp b/src/hotspot/share/gc/z/zHeap.cpp index 9d50b863924..c6c3c0ca6c0 100644 --- a/src/hotspot/share/gc/z/zHeap.cpp +++ b/src/hotspot/share/gc/z/zHeap.cpp @@ -352,12 +352,12 @@ void ZHeap::process_non_strong_references() { ZRendezvousClosure cl; Handshake::execute(&cl); - // Purge stale metadata and nmethods that were unlinked - _unload.purge(); - // Unblock resurrection of weak/phantom references ZResurrection::unblock(); + // Purge stale metadata and nmethods that were unlinked + _unload.purge(); + // Enqueue Soft/Weak/Final/PhantomReferences. Note that this // must be done after unblocking resurrection. Otherwise the // Finalizer thread could call Reference.get() on the Finalizers