Skip to content

Commit b2010a7

Browse files
committed
8287805: Shenandoah: consolidate evacuate-update-root closures
Reviewed-by: shade
1 parent ea8b75c commit b2010a7

File tree

4 files changed

+45
-98
lines changed

4 files changed

+45
-98
lines changed

src/hotspot/share/gc/shenandoah/shenandoahClosures.hpp

Lines changed: 9 additions & 28 deletions
Original file line numberDiff line numberDiff line change
@@ -89,42 +89,23 @@ class ShenandoahUpdateRefsClosure: public ShenandoahOopClosureBase {
8989
inline void do_oop_work(T* p);
9090
};
9191

92-
template <DecoratorSet MO = MO_UNORDERED>
93-
class ShenandoahEvacuateUpdateMetadataClosure: public ShenandoahOopClosureBase {
94-
private:
92+
template <bool concurrent, bool stable_thread>
93+
class ShenandoahEvacuateUpdateRootClosureBase : public ShenandoahOopClosureBase {
94+
protected:
9595
ShenandoahHeap* const _heap;
96-
Thread* const _thread;
96+
Thread* const _thread;
9797
public:
98-
inline ShenandoahEvacuateUpdateMetadataClosure();
98+
inline ShenandoahEvacuateUpdateRootClosureBase();
9999
inline void do_oop(oop* p);
100100
inline void do_oop(narrowOop* p);
101-
102-
private:
101+
protected:
103102
template <class T>
104103
inline void do_oop_work(T* p);
105104
};
106105

107-
// Context free version, cannot cache calling thread
108-
class ShenandoahEvacuateUpdateRootsClosure : public ShenandoahOopClosureBase {
109-
private:
110-
ShenandoahHeap* const _heap;
111-
public:
112-
inline ShenandoahEvacuateUpdateRootsClosure();
113-
inline void do_oop(oop* p);
114-
inline void do_oop(narrowOop* p);
115-
protected:
116-
template <typename T>
117-
inline void do_oop_work(T* p, Thread* thr);
118-
};
119-
120-
class ShenandoahContextEvacuateUpdateRootsClosure : public ShenandoahEvacuateUpdateRootsClosure {
121-
private:
122-
Thread* const _thread;
123-
public:
124-
inline ShenandoahContextEvacuateUpdateRootsClosure();
125-
inline void do_oop(oop* p);
126-
inline void do_oop(narrowOop* p);
127-
};
106+
using ShenandoahEvacuateUpdateMetadataClosure = ShenandoahEvacuateUpdateRootClosureBase<false, true>;
107+
using ShenandoahEvacuateUpdateRootsClosure = ShenandoahEvacuateUpdateRootClosureBase<true, false>;
108+
using ShenandoahContextEvacuateUpdateRootsClosure = ShenandoahEvacuateUpdateRootClosureBase<true, true>;
128109

129110
template <bool CONCURRENT, typename IsAlive, typename KeepAlive>
130111
class ShenandoahCleanUpdateWeakOopsClosure : public OopClosure {

src/hotspot/share/gc/shenandoah/shenandoahClosures.inline.hpp

Lines changed: 32 additions & 66 deletions
Original file line numberDiff line numberDiff line change
@@ -109,53 +109,37 @@ void ShenandoahUpdateRefsClosure::do_oop_work(T* p) {
109109
void ShenandoahUpdateRefsClosure::do_oop(oop* p) { do_oop_work(p); }
110110
void ShenandoahUpdateRefsClosure::do_oop(narrowOop* p) { do_oop_work(p); }
111111

112-
template <DecoratorSet MO>
113-
ShenandoahEvacuateUpdateMetadataClosure<MO>::ShenandoahEvacuateUpdateMetadataClosure() :
114-
_heap(ShenandoahHeap::heap()), _thread(Thread::current()) {
115-
}
116-
117-
template <DecoratorSet MO>
118-
template <class T>
119-
void ShenandoahEvacuateUpdateMetadataClosure<MO>::do_oop_work(T* p) {
120-
assert(_heap->is_concurrent_weak_root_in_progress() ||
121-
_heap->is_concurrent_strong_root_in_progress(),
122-
"Only do this in root processing phase");
123-
assert(_thread == Thread::current(), "Wrong thread");
124-
125-
T o = RawAccess<>::oop_load(p);
126-
if (! CompressedOops::is_null(o)) {
127-
oop obj = CompressedOops::decode_not_null(o);
128-
if (_heap->in_collection_set(obj)) {
129-
assert(_heap->is_evacuation_in_progress(), "Only do this when evacuation is in progress");
130-
shenandoah_assert_marked(p, obj);
131-
oop resolved = ShenandoahBarrierSet::resolve_forwarded_not_null(obj);
132-
if (resolved == obj) {
133-
resolved = _heap->evacuate_object(obj, _thread);
134-
}
135-
RawAccess<IS_NOT_NULL | MO>::oop_store(p, resolved);
136-
}
112+
template <bool concurrent, bool stable_thread>
113+
ShenandoahEvacuateUpdateRootClosureBase<concurrent, stable_thread>::ShenandoahEvacuateUpdateRootClosureBase() :
114+
_heap(ShenandoahHeap::heap()), _thread(stable_thread ? Thread::current() : NULL) {
115+
}
116+
117+
template <bool concurrent, bool stable_thread>
118+
void ShenandoahEvacuateUpdateRootClosureBase<concurrent, stable_thread>::do_oop(oop* p) {
119+
if (concurrent) {
120+
ShenandoahEvacOOMScope scope;
121+
do_oop_work(p);
122+
} else {
123+
do_oop_work(p);
137124
}
138125
}
139-
template <DecoratorSet MO>
140-
void ShenandoahEvacuateUpdateMetadataClosure<MO>::do_oop(oop* p) {
141-
do_oop_work(p);
142-
}
143-
144-
template <DecoratorSet MO>
145-
void ShenandoahEvacuateUpdateMetadataClosure<MO>::do_oop(narrowOop* p) {
146-
do_oop_work(p);
147-
}
148126

149-
ShenandoahEvacuateUpdateRootsClosure::ShenandoahEvacuateUpdateRootsClosure() :
150-
_heap(ShenandoahHeap::heap()) {
127+
template <bool concurrent, bool stable_thread>
128+
void ShenandoahEvacuateUpdateRootClosureBase<concurrent, stable_thread>::do_oop(narrowOop* p) {
129+
if (concurrent) {
130+
ShenandoahEvacOOMScope scope;
131+
do_oop_work(p);
132+
} else {
133+
do_oop_work(p);
134+
}
151135
}
152136

153-
template <typename T>
154-
void ShenandoahEvacuateUpdateRootsClosure::do_oop_work(T* p, Thread* t) {
137+
template <bool atomic, bool stable_thread>
138+
template <class T>
139+
void ShenandoahEvacuateUpdateRootClosureBase<atomic, stable_thread>::do_oop_work(T* p) {
155140
assert(_heap->is_concurrent_weak_root_in_progress() ||
156141
_heap->is_concurrent_strong_root_in_progress(),
157142
"Only do this in root processing phase");
158-
assert(t == Thread::current(), "Wrong thread");
159143

160144
T o = RawAccess<>::oop_load(p);
161145
if (!CompressedOops::is_null(o)) {
@@ -165,38 +149,20 @@ void ShenandoahEvacuateUpdateRootsClosure::do_oop_work(T* p, Thread* t) {
165149
shenandoah_assert_marked(p, obj);
166150
oop resolved = ShenandoahBarrierSet::resolve_forwarded_not_null(obj);
167151
if (resolved == obj) {
168-
resolved = _heap->evacuate_object(obj, t);
152+
Thread* thr = stable_thread ? _thread : Thread::current();
153+
assert(thr == Thread::current(), "Wrong thread");
154+
155+
resolved = _heap->evacuate_object(obj, thr);
156+
}
157+
if (atomic) {
158+
ShenandoahHeap::atomic_update_oop(resolved, p, o);
159+
} else {
160+
RawAccess<IS_NOT_NULL | MO_UNORDERED>::oop_store(p, resolved);
169161
}
170-
ShenandoahHeap::atomic_update_oop(resolved, p, o);
171162
}
172163
}
173164
}
174165

175-
void ShenandoahEvacuateUpdateRootsClosure::do_oop(oop* p) {
176-
ShenandoahEvacOOMScope scope;
177-
do_oop_work(p, Thread::current());
178-
}
179-
180-
void ShenandoahEvacuateUpdateRootsClosure::do_oop(narrowOop* p) {
181-
ShenandoahEvacOOMScope scope;
182-
do_oop_work(p, Thread::current());
183-
}
184-
185-
ShenandoahContextEvacuateUpdateRootsClosure::ShenandoahContextEvacuateUpdateRootsClosure() :
186-
ShenandoahEvacuateUpdateRootsClosure(),
187-
_thread(Thread::current()) {
188-
}
189-
190-
void ShenandoahContextEvacuateUpdateRootsClosure::do_oop(oop* p) {
191-
ShenandoahEvacOOMScope scope;
192-
do_oop_work(p, _thread);
193-
}
194-
195-
void ShenandoahContextEvacuateUpdateRootsClosure::do_oop(narrowOop* p) {
196-
ShenandoahEvacOOMScope scope;
197-
do_oop_work(p, _thread);
198-
}
199-
200166
template <bool CONCURRENT, typename IsAlive, typename KeepAlive>
201167
ShenandoahCleanUpdateWeakOopsClosure<CONCURRENT, IsAlive, KeepAlive>::ShenandoahCleanUpdateWeakOopsClosure(IsAlive* is_alive, KeepAlive* keep_alive) :
202168
_is_alive(is_alive), _keep_alive(keep_alive) {

src/hotspot/share/gc/shenandoah/shenandoahConcurrentGC.cpp

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -834,7 +834,7 @@ void ShenandoahConcurrentGC::op_class_unloading() {
834834
class ShenandoahEvacUpdateCodeCacheClosure : public NMethodClosure {
835835
private:
836836
BarrierSetNMethod* const _bs;
837-
ShenandoahEvacuateUpdateMetadataClosure<> _cl;
837+
ShenandoahEvacuateUpdateMetadataClosure _cl;
838838

839839
public:
840840
ShenandoahEvacUpdateCodeCacheClosure() :
@@ -893,7 +893,7 @@ class ShenandoahConcurrentRootsEvacUpdateTask : public WorkerTask {
893893
}
894894

895895
{
896-
ShenandoahEvacuateUpdateMetadataClosure<> cl;
896+
ShenandoahEvacuateUpdateMetadataClosure cl;
897897
CLDToOopClosure clds(&cl, ClassLoaderData::_claim_strong);
898898
_cld_roots.cld_do(&clds, worker_id);
899899
}

src/hotspot/share/gc/shenandoah/shenandoahNMethod.inline.hpp

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,5 @@
11
/*
2-
* Copyright (c) 2019, 2021, Red Hat, Inc. All rights reserved.
2+
* Copyright (c) 2019, 2022, Red Hat, Inc. All rights reserved.
33
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
44
*
55
* This code is free software; you can redistribute it and/or modify it
@@ -74,7 +74,7 @@ void ShenandoahNMethod::oops_do(OopClosure* oops, bool fix_relocations) {
7474
}
7575

7676
void ShenandoahNMethod::heal_nmethod_metadata(ShenandoahNMethod* nmethod_data) {
77-
ShenandoahEvacuateUpdateMetadataClosure<> cl;
77+
ShenandoahEvacuateUpdateMetadataClosure cl;
7878
nmethod_data->oops_do(&cl, true /*fix relocation*/);
7979
}
8080

0 commit comments

Comments
 (0)