From 47d4438e75eca6f6f2aef9c0f88cab78996f7f80 Mon Sep 17 00:00:00 2001 From: Albert Mingkun Yang Date: Thu, 6 May 2021 12:52:34 +0000 Subject: [PATCH] 8266426: ZHeapIteratorOopClosure does not handle native access properly MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: Per Liden Co-authored-by: Erik Ă–sterlund Co-authored-by: Stefan Karlsson Reviewed-by: stefank, pliden --- src/hotspot/share/gc/z/zHeapIterator.cpp | 40 ++++++++++++++++++++++-- 1 file changed, 38 insertions(+), 2 deletions(-) diff --git a/src/hotspot/share/gc/z/zHeapIterator.cpp b/src/hotspot/share/gc/z/zHeapIterator.cpp index c95963e2c66..a777caedb61 100644 --- a/src/hotspot/share/gc/z/zHeapIterator.cpp +++ b/src/hotspot/share/gc/z/zHeapIterator.cpp @@ -27,6 +27,7 @@ #include "gc/shared/gc_globals.hpp" #include "gc/shared/taskqueue.inline.hpp" #include "gc/z/zAddress.inline.hpp" +#include "gc/z/zCollectedHeap.hpp" #include "gc/z/zGlobals.hpp" #include "gc/z/zGranuleMap.inline.hpp" #include "gc/z/zHeapIterator.hpp" @@ -123,12 +124,14 @@ public: }; template -class ZHeapIteratorOopClosure : public ClaimMetadataVisitingOopIterateClosure { +class ZHeapIteratorOopClosure : public OopIterateClosure { private: const ZHeapIteratorContext& _context; const oop _base; oop load_oop(oop* p) { + assert(ZCollectedHeap::heap()->is_in(p), "Should be in heap"); + if (VisitReferents) { return HeapAccess::oop_load_at(_base, _base->field_offset(p)); } @@ -138,7 +141,7 @@ private: public: ZHeapIteratorOopClosure(const ZHeapIteratorContext& context, oop base) : - ClaimMetadataVisitingOopIterateClosure(ClassLoaderData::_claim_other), + OopIterateClosure(), _context(context), _base(base) {} @@ -154,6 +157,39 @@ public: virtual void do_oop(narrowOop* p) { ShouldNotReachHere(); } + + virtual bool do_metadata() { + return true; + } + + virtual void do_klass(Klass* k) { + ClassLoaderData* const cld = k->class_loader_data(); + ZHeapIteratorOopClosure::do_cld(cld); + } + + virtual void do_cld(ClassLoaderData* cld) { + class NativeAccessClosure : public OopClosure { + private: + const ZHeapIteratorContext& _context; + + public: + explicit NativeAccessClosure(const ZHeapIteratorContext& context) : + _context(context) {} + + virtual void do_oop(oop* p) { + assert(!ZCollectedHeap::heap()->is_in(p), "Should not be in heap"); + const oop obj = NativeAccess::oop_load(p); + _context.mark_and_push(obj); + } + + virtual void do_oop(narrowOop* p) { + ShouldNotReachHere(); + } + }; + + NativeAccessClosure cl(_context); + cld->oops_do(&cl, ClassLoaderData::_claim_other); + } }; ZHeapIterator::ZHeapIterator(uint nworkers, bool visit_weaks) :