author | tschatzl |
Wed, 08 Aug 2018 15:31:06 +0200 | |
changeset 51332 | c25572739e7c |
parent 50752 | 9d62da00bf15 |
child 51708 | 469ab7c92a32 |
permissions | -rw-r--r-- |
1374 | 1 |
/* |
49606
9ae8719efcae
8197850: Calculate liveness in regions during marking
tschatzl
parents:
49337
diff
changeset
|
2 |
* Copyright (c) 2001, 2018, Oracle and/or its affiliates. All rights reserved. |
1374 | 3 |
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
4 |
* |
|
5 |
* This code is free software; you can redistribute it and/or modify it |
|
6 |
* under the terms of the GNU General Public License version 2 only, as |
|
7 |
* published by the Free Software Foundation. |
|
8 |
* |
|
9 |
* This code is distributed in the hope that it will be useful, but WITHOUT |
|
10 |
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
|
11 |
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License |
|
12 |
* version 2 for more details (a copy is included in the LICENSE file that |
|
13 |
* accompanied this code). |
|
14 |
* |
|
15 |
* You should have received a copy of the GNU General Public License version |
|
16 |
* 2 along with this work; if not, write to the Free Software Foundation, |
|
17 |
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. |
|
18 |
* |
|
5547
f4b087cbb361
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
4902
diff
changeset
|
19 |
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
f4b087cbb361
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
4902
diff
changeset
|
20 |
* or visit www.oracle.com if you need additional information or have any |
f4b087cbb361
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
4902
diff
changeset
|
21 |
* questions. |
1374 | 22 |
* |
23 |
*/ |
|
24 |
||
30764 | 25 |
#ifndef SHARE_VM_GC_G1_G1OOPCLOSURES_HPP |
26 |
#define SHARE_VM_GC_G1_G1OOPCLOSURES_HPP |
|
7397 | 27 |
|
46572 | 28 |
#include "gc/g1/g1InCSetState.hpp" |
25492
d27050bdfb04
8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents:
25491
diff
changeset
|
29 |
#include "memory/iterator.hpp" |
28213
b0bf57cd1e9d
8060025: Object copy time regressions after JDK-8031323 and JDK-8057536
tschatzl
parents:
28207
diff
changeset
|
30 |
#include "oops/markOop.hpp" |
25492
d27050bdfb04
8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents:
25491
diff
changeset
|
31 |
|
1374 | 32 |
class HeapRegion; |
33 |
class G1CollectedHeap; |
|
34 |
class G1RemSet; |
|
35943
e726308008c0
8148973: Rename g1/concurrentMark.{hpp,cpp,inline.hpp} to g1/g1ConcurrentMark.{hpp,cpp,inline.hpp}
ehelin
parents:
35862
diff
changeset
|
35 |
class G1ConcurrentMark; |
1374 | 36 |
class DirtyCardToOopClosure; |
35943
e726308008c0
8148973: Rename g1/concurrentMark.{hpp,cpp,inline.hpp} to g1/g1ConcurrentMark.{hpp,cpp,inline.hpp}
ehelin
parents:
35862
diff
changeset
|
37 |
class G1CMBitMap; |
1374 | 38 |
class G1ParScanThreadState; |
35943
e726308008c0
8148973: Rename g1/concurrentMark.{hpp,cpp,inline.hpp} to g1/g1ConcurrentMark.{hpp,cpp,inline.hpp}
ehelin
parents:
35862
diff
changeset
|
39 |
class G1CMTask; |
10670
4ea0e7d2ffbc
6484982: G1: process references during evacuation pauses
johnc
parents:
10664
diff
changeset
|
40 |
class ReferenceProcessor; |
1374 | 41 |
|
50752 | 42 |
class G1ScanClosureBase : public BasicOopIterateClosure { |
1374 | 43 |
protected: |
49806 | 44 |
G1CollectedHeap* _g1h; |
1374 | 45 |
G1ParScanThreadState* _par_scan_state; |
46590 | 46 |
HeapRegion* _from; |
33224
bc5da96c1f0e
8139200: Eliminate G1ParClosureSuper::_worker_id
kbarrett
parents:
33213
diff
changeset
|
47 |
|
49806 | 48 |
G1ScanClosureBase(G1CollectedHeap* g1h, G1ParScanThreadState* par_scan_state); |
46572 | 49 |
~G1ScanClosureBase() { } |
33224
bc5da96c1f0e
8139200: Eliminate G1ParClosureSuper::_worker_id
kbarrett
parents:
33213
diff
changeset
|
50 |
|
46572 | 51 |
template <class T> |
52 |
inline void prefetch_and_push(T* p, oop const obj); |
|
53 |
||
54 |
template <class T> |
|
55 |
inline void handle_non_cset_obj_common(InCSetState const state, T* p, oop const obj); |
|
1374 | 56 |
public: |
46445
825b002e05ae
8138888: Remove ExtendedOopClosure::apply_to_weak_ref_discovered_field
sjohanss
parents:
46307
diff
changeset
|
57 |
// This closure needs special handling for InstanceRefKlass. |
825b002e05ae
8138888: Remove ExtendedOopClosure::apply_to_weak_ref_discovered_field
sjohanss
parents:
46307
diff
changeset
|
58 |
virtual ReferenceIterationMode reference_iteration_mode() { return DO_DISCOVERED_AND_DISCOVERY; } |
46590 | 59 |
void set_region(HeapRegion* from) { _from = from; } |
49911
358be4680d12
6672778: G1 should trim task queues more aggressively during evacuation pauses
tschatzl
parents:
49827
diff
changeset
|
60 |
|
358be4680d12
6672778: G1 should trim task queues more aggressively during evacuation pauses
tschatzl
parents:
49827
diff
changeset
|
61 |
inline void trim_queue_partially(); |
1374 | 62 |
}; |
63 |
||
46572 | 64 |
// Used during the Update RS phase to refine remaining cards in the DCQ during garbage collection. |
65 |
class G1ScanObjsDuringUpdateRSClosure: public G1ScanClosureBase { |
|
66 |
uint _worker_i; |
|
67 |
||
4902
991aaddb5165
6923991: G1: improve scalability of RSet scanning
iveresov
parents:
3262
diff
changeset
|
68 |
public: |
46572 | 69 |
G1ScanObjsDuringUpdateRSClosure(G1CollectedHeap* g1h, |
70 |
G1ParScanThreadState* pss, |
|
71 |
uint worker_i) : |
|
46670
55a3c36b64b2
8183539: Remove G1RemSet::_into_cset_dirty_card_queue_set
ehelin
parents:
46590
diff
changeset
|
72 |
G1ScanClosureBase(g1h, pss), _worker_i(worker_i) { } |
46572 | 73 |
|
50752 | 74 |
template <class T> void do_oop_work(T* p); |
75 |
virtual void do_oop(narrowOop* p) { do_oop_work(p); } |
|
76 |
virtual void do_oop(oop* p) { do_oop_work(p); } |
|
46572 | 77 |
}; |
78 |
||
79 |
// Used during the Scan RS phase to scan cards from the remembered set during garbage collection. |
|
80 |
class G1ScanObjsDuringScanRSClosure : public G1ScanClosureBase { |
|
81 |
public: |
|
49806 | 82 |
G1ScanObjsDuringScanRSClosure(G1CollectedHeap* g1h, |
46572 | 83 |
G1ParScanThreadState* par_scan_state): |
49806 | 84 |
G1ScanClosureBase(g1h, par_scan_state) { } |
10670
4ea0e7d2ffbc
6484982: G1: process references during evacuation pauses
johnc
parents:
10664
diff
changeset
|
85 |
|
50752 | 86 |
template <class T> void do_oop_work(T* p); |
87 |
virtual void do_oop(oop* p) { do_oop_work(p); } |
|
88 |
virtual void do_oop(narrowOop* p) { do_oop_work(p); } |
|
4902
991aaddb5165
6923991: G1: improve scalability of RSet scanning
iveresov
parents:
3262
diff
changeset
|
89 |
}; |
991aaddb5165
6923991: G1: improve scalability of RSet scanning
iveresov
parents:
3262
diff
changeset
|
90 |
|
46572 | 91 |
// This closure is applied to the fields of the objects that have just been copied during evacuation. |
92 |
class G1ScanEvacuatedObjClosure : public G1ScanClosureBase { |
|
1374 | 93 |
public: |
49806 | 94 |
G1ScanEvacuatedObjClosure(G1CollectedHeap* g1h, G1ParScanThreadState* par_scan_state) : |
95 |
G1ScanClosureBase(g1h, par_scan_state) { } |
|
10670
4ea0e7d2ffbc
6484982: G1: process references during evacuation pauses
johnc
parents:
10664
diff
changeset
|
96 |
|
50752 | 97 |
template <class T> void do_oop_work(T* p); |
98 |
virtual void do_oop(oop* p) { do_oop_work(p); } |
|
99 |
virtual void do_oop(narrowOop* p) { do_oop_work(p); } |
|
32381
b750fd963056
8040162: Avoid reallocating PLABs between GC phases in G1
tschatzl
parents:
31976
diff
changeset
|
100 |
|
49827 | 101 |
void set_ref_discoverer(ReferenceDiscoverer* rd) { |
102 |
set_ref_discoverer_internal(rd); |
|
33226
19cb9b844190
8139341: Hide ExtendedOopClosure::_ref_processor
kbarrett
parents:
33224
diff
changeset
|
103 |
} |
1374 | 104 |
}; |
105 |
||
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13336
diff
changeset
|
106 |
// Add back base class for metadata |
35067
0fa08ea22241
8144505: Change G1ParCopyHelper to inherit OopClosure
sjohanss
parents:
35062
diff
changeset
|
107 |
class G1ParCopyHelper : public OopClosure { |
22901
3b4e9802e94f
8027559: Decrease code size and templatizing in G1ParCopyClosure::do_oop_work
tschatzl
parents:
22761
diff
changeset
|
108 |
protected: |
49806 | 109 |
G1CollectedHeap* _g1h; |
35067
0fa08ea22241
8144505: Change G1ParCopyHelper to inherit OopClosure
sjohanss
parents:
35062
diff
changeset
|
110 |
G1ParScanThreadState* _par_scan_state; |
33224
bc5da96c1f0e
8139200: Eliminate G1ParClosureSuper::_worker_id
kbarrett
parents:
33213
diff
changeset
|
111 |
uint _worker_id; // Cache value from par_scan_state. |
47580 | 112 |
ClassLoaderData* _scanned_cld; |
35943
e726308008c0
8148973: Rename g1/concurrentMark.{hpp,cpp,inline.hpp} to g1/g1ConcurrentMark.{hpp,cpp,inline.hpp}
ehelin
parents:
35862
diff
changeset
|
113 |
G1ConcurrentMark* _cm; |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13336
diff
changeset
|
114 |
|
22901
3b4e9802e94f
8027559: Decrease code size and templatizing in G1ParCopyClosure::do_oop_work
tschatzl
parents:
22761
diff
changeset
|
115 |
// Mark the object if it's not already marked. This is used to mark |
3b4e9802e94f
8027559: Decrease code size and templatizing in G1ParCopyClosure::do_oop_work
tschatzl
parents:
22761
diff
changeset
|
116 |
// objects pointed to by roots that are guaranteed not to move |
3b4e9802e94f
8027559: Decrease code size and templatizing in G1ParCopyClosure::do_oop_work
tschatzl
parents:
22761
diff
changeset
|
117 |
// during the GC (i.e., non-CSet objects). It is MT-safe. |
33213
b937f634f56e
8138762: Refactor setup of evacuation closures in G1
mgerdin
parents:
32592
diff
changeset
|
118 |
inline void mark_object(oop obj); |
22901
3b4e9802e94f
8027559: Decrease code size and templatizing in G1ParCopyClosure::do_oop_work
tschatzl
parents:
22761
diff
changeset
|
119 |
|
3b4e9802e94f
8027559: Decrease code size and templatizing in G1ParCopyClosure::do_oop_work
tschatzl
parents:
22761
diff
changeset
|
120 |
// Mark the object if it's not already marked. This is used to mark |
3b4e9802e94f
8027559: Decrease code size and templatizing in G1ParCopyClosure::do_oop_work
tschatzl
parents:
22761
diff
changeset
|
121 |
// objects pointed to by roots that have been forwarded during a |
3b4e9802e94f
8027559: Decrease code size and templatizing in G1ParCopyClosure::do_oop_work
tschatzl
parents:
22761
diff
changeset
|
122 |
// GC. It is MT-safe. |
33213
b937f634f56e
8138762: Refactor setup of evacuation closures in G1
mgerdin
parents:
32592
diff
changeset
|
123 |
inline void mark_forwarded_object(oop from_obj, oop to_obj); |
33224
bc5da96c1f0e
8139200: Eliminate G1ParClosureSuper::_worker_id
kbarrett
parents:
33213
diff
changeset
|
124 |
|
49806 | 125 |
G1ParCopyHelper(G1CollectedHeap* g1h, G1ParScanThreadState* par_scan_state); |
33224
bc5da96c1f0e
8139200: Eliminate G1ParClosureSuper::_worker_id
kbarrett
parents:
33213
diff
changeset
|
126 |
~G1ParCopyHelper() { } |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13336
diff
changeset
|
127 |
|
33224
bc5da96c1f0e
8139200: Eliminate G1ParClosureSuper::_worker_id
kbarrett
parents:
33213
diff
changeset
|
128 |
public: |
47580 | 129 |
void set_scanned_cld(ClassLoaderData* cld) { _scanned_cld = cld; } |
130 |
inline void do_cld_barrier(oop new_obj); |
|
49911
358be4680d12
6672778: G1 should trim task queues more aggressively during evacuation pauses
tschatzl
parents:
49827
diff
changeset
|
131 |
|
358be4680d12
6672778: G1 should trim task queues more aggressively during evacuation pauses
tschatzl
parents:
49827
diff
changeset
|
132 |
inline void trim_queue_partially(); |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13336
diff
changeset
|
133 |
}; |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13336
diff
changeset
|
134 |
|
29688 | 135 |
enum G1Barrier { |
136 |
G1BarrierNone, |
|
47580 | 137 |
G1BarrierCLD |
29688 | 138 |
}; |
139 |
||
140 |
enum G1Mark { |
|
141 |
G1MarkNone, |
|
142 |
G1MarkFromRoot, |
|
143 |
G1MarkPromotedFromRoot |
|
144 |
}; |
|
145 |
||
49337
e4fdca451542
8197847: Remove unused file g1ParScanThreadState_ext.cpp
ehelin
parents:
47580
diff
changeset
|
146 |
template <G1Barrier barrier, G1Mark do_mark_object> |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13336
diff
changeset
|
147 |
class G1ParCopyClosure : public G1ParCopyHelper { |
1374 | 148 |
public: |
49806 | 149 |
G1ParCopyClosure(G1CollectedHeap* g1h, G1ParScanThreadState* par_scan_state) : |
150 |
G1ParCopyHelper(g1h, par_scan_state) { } |
|
10670
4ea0e7d2ffbc
6484982: G1: process references during evacuation pauses
johnc
parents:
10664
diff
changeset
|
151 |
|
35067
0fa08ea22241
8144505: Change G1ParCopyHelper to inherit OopClosure
sjohanss
parents:
35062
diff
changeset
|
152 |
template <class T> void do_oop_work(T* p); |
0fa08ea22241
8144505: Change G1ParCopyHelper to inherit OopClosure
sjohanss
parents:
35062
diff
changeset
|
153 |
virtual void do_oop(oop* p) { do_oop_work(p); } |
0fa08ea22241
8144505: Change G1ParCopyHelper to inherit OopClosure
sjohanss
parents:
35062
diff
changeset
|
154 |
virtual void do_oop(narrowOop* p) { do_oop_work(p); } |
1374 | 155 |
}; |
156 |
||
47580 | 157 |
class G1CLDScanClosure : public CLDClosure { |
49644
50a01910e00a
8151171: Bring g1ConcurrentMark files up to current coding conventions
tschatzl
parents:
49607
diff
changeset
|
158 |
G1ParCopyHelper* _closure; |
50a01910e00a
8151171: Bring g1ConcurrentMark files up to current coding conventions
tschatzl
parents:
49607
diff
changeset
|
159 |
bool _process_only_dirty; |
50a01910e00a
8151171: Bring g1ConcurrentMark files up to current coding conventions
tschatzl
parents:
49607
diff
changeset
|
160 |
bool _must_claim; |
50a01910e00a
8151171: Bring g1ConcurrentMark files up to current coding conventions
tschatzl
parents:
49607
diff
changeset
|
161 |
int _count; |
50a01910e00a
8151171: Bring g1ConcurrentMark files up to current coding conventions
tschatzl
parents:
49607
diff
changeset
|
162 |
public: |
47580 | 163 |
G1CLDScanClosure(G1ParCopyHelper* closure, |
164 |
bool process_only_dirty, bool must_claim) |
|
51332 | 165 |
: _closure(closure), _process_only_dirty(process_only_dirty), _must_claim(must_claim), _count(0) {} |
47580 | 166 |
void do_cld(ClassLoaderData* cld); |
33213
b937f634f56e
8138762: Refactor setup of evacuation closures in G1
mgerdin
parents:
32592
diff
changeset
|
167 |
}; |
10670
4ea0e7d2ffbc
6484982: G1: process references during evacuation pauses
johnc
parents:
10664
diff
changeset
|
168 |
|
9994 | 169 |
// Closure for iterating over object fields during concurrent marking |
50752 | 170 |
class G1CMOopClosure : public MetadataVisitingOopIterateClosure { |
9994 | 171 |
G1CollectedHeap* _g1h; |
35943
e726308008c0
8148973: Rename g1/concurrentMark.{hpp,cpp,inline.hpp} to g1/g1ConcurrentMark.{hpp,cpp,inline.hpp}
ehelin
parents:
35862
diff
changeset
|
172 |
G1CMTask* _task; |
9994 | 173 |
public: |
49644
50a01910e00a
8151171: Bring g1ConcurrentMark files up to current coding conventions
tschatzl
parents:
49607
diff
changeset
|
174 |
G1CMOopClosure(G1CollectedHeap* g1h,G1CMTask* task); |
50752 | 175 |
template <class T> void do_oop_work(T* p); |
176 |
virtual void do_oop( oop* p) { do_oop_work(p); } |
|
177 |
virtual void do_oop(narrowOop* p) { do_oop_work(p); } |
|
9994 | 178 |
}; |
179 |
||
11584
e1df4d08a1f4
7127706: G1: re-enable survivors during the initial-mark pause
tonyp
parents:
11583
diff
changeset
|
180 |
// Closure to scan the root regions during concurrent marking |
50752 | 181 |
class G1RootRegionScanClosure : public MetadataVisitingOopIterateClosure { |
11584
e1df4d08a1f4
7127706: G1: re-enable survivors during the initial-mark pause
tonyp
parents:
11583
diff
changeset
|
182 |
private: |
e1df4d08a1f4
7127706: G1: re-enable survivors during the initial-mark pause
tonyp
parents:
11583
diff
changeset
|
183 |
G1CollectedHeap* _g1h; |
35943
e726308008c0
8148973: Rename g1/concurrentMark.{hpp,cpp,inline.hpp} to g1/g1ConcurrentMark.{hpp,cpp,inline.hpp}
ehelin
parents:
35862
diff
changeset
|
184 |
G1ConcurrentMark* _cm; |
49606
9ae8719efcae
8197850: Calculate liveness in regions during marking
tschatzl
parents:
49337
diff
changeset
|
185 |
uint _worker_id; |
11584
e1df4d08a1f4
7127706: G1: re-enable survivors during the initial-mark pause
tonyp
parents:
11583
diff
changeset
|
186 |
public: |
49606
9ae8719efcae
8197850: Calculate liveness in regions during marking
tschatzl
parents:
49337
diff
changeset
|
187 |
G1RootRegionScanClosure(G1CollectedHeap* g1h, G1ConcurrentMark* cm, uint worker_id) : |
9ae8719efcae
8197850: Calculate liveness in regions during marking
tschatzl
parents:
49337
diff
changeset
|
188 |
_g1h(g1h), _cm(cm), _worker_id(worker_id) { } |
50752 | 189 |
template <class T> void do_oop_work(T* p); |
190 |
virtual void do_oop( oop* p) { do_oop_work(p); } |
|
191 |
virtual void do_oop(narrowOop* p) { do_oop_work(p); } |
|
11584
e1df4d08a1f4
7127706: G1: re-enable survivors during the initial-mark pause
tonyp
parents:
11583
diff
changeset
|
192 |
}; |
e1df4d08a1f4
7127706: G1: re-enable survivors during the initial-mark pause
tonyp
parents:
11583
diff
changeset
|
193 |
|
50752 | 194 |
class G1ConcurrentRefineOopClosure: public BasicOopIterateClosure { |
49806 | 195 |
G1CollectedHeap* _g1h; |
46519
40c9c132f961
8177707: Specialize G1RemSet::refine_card for concurrent/during safepoint refinement
tschatzl
parents:
46445
diff
changeset
|
196 |
uint _worker_i; |
40c9c132f961
8177707: Specialize G1RemSet::refine_card for concurrent/during safepoint refinement
tschatzl
parents:
46445
diff
changeset
|
197 |
|
40c9c132f961
8177707: Specialize G1RemSet::refine_card for concurrent/during safepoint refinement
tschatzl
parents:
46445
diff
changeset
|
198 |
public: |
40c9c132f961
8177707: Specialize G1RemSet::refine_card for concurrent/during safepoint refinement
tschatzl
parents:
46445
diff
changeset
|
199 |
G1ConcurrentRefineOopClosure(G1CollectedHeap* g1h, uint worker_i) : |
49806 | 200 |
_g1h(g1h), |
46519
40c9c132f961
8177707: Specialize G1RemSet::refine_card for concurrent/during safepoint refinement
tschatzl
parents:
46445
diff
changeset
|
201 |
_worker_i(worker_i) { |
40c9c132f961
8177707: Specialize G1RemSet::refine_card for concurrent/during safepoint refinement
tschatzl
parents:
46445
diff
changeset
|
202 |
} |
40c9c132f961
8177707: Specialize G1RemSet::refine_card for concurrent/during safepoint refinement
tschatzl
parents:
46445
diff
changeset
|
203 |
|
40c9c132f961
8177707: Specialize G1RemSet::refine_card for concurrent/during safepoint refinement
tschatzl
parents:
46445
diff
changeset
|
204 |
// This closure needs special handling for InstanceRefKlass. |
40c9c132f961
8177707: Specialize G1RemSet::refine_card for concurrent/during safepoint refinement
tschatzl
parents:
46445
diff
changeset
|
205 |
virtual ReferenceIterationMode reference_iteration_mode() { return DO_DISCOVERED_AND_DISCOVERY; } |
40c9c132f961
8177707: Specialize G1RemSet::refine_card for concurrent/during safepoint refinement
tschatzl
parents:
46445
diff
changeset
|
206 |
|
50752 | 207 |
template <class T> void do_oop_work(T* p); |
208 |
virtual void do_oop(narrowOop* p) { do_oop_work(p); } |
|
209 |
virtual void do_oop(oop* p) { do_oop_work(p); } |
|
11586
ccc217c177ee
7133038: G1: Some small profile based optimizations
johnc
parents:
11584
diff
changeset
|
210 |
}; |
ccc217c177ee
7133038: G1: Some small profile based optimizations
johnc
parents:
11584
diff
changeset
|
211 |
|
50752 | 212 |
class G1RebuildRemSetClosure : public BasicOopIterateClosure { |
49806 | 213 |
G1CollectedHeap* _g1h; |
49607
acffe6ff3ae7
8180415: Rebuild remembered sets during the concurrent cycle
tschatzl
parents:
49606
diff
changeset
|
214 |
uint _worker_id; |
acffe6ff3ae7
8180415: Rebuild remembered sets during the concurrent cycle
tschatzl
parents:
49606
diff
changeset
|
215 |
public: |
49806 | 216 |
G1RebuildRemSetClosure(G1CollectedHeap* g1h, uint worker_id) : _g1h(g1h), _worker_id(worker_id) { |
49607
acffe6ff3ae7
8180415: Rebuild remembered sets during the concurrent cycle
tschatzl
parents:
49606
diff
changeset
|
217 |
} |
acffe6ff3ae7
8180415: Rebuild remembered sets during the concurrent cycle
tschatzl
parents:
49606
diff
changeset
|
218 |
|
50752 | 219 |
template <class T> void do_oop_work(T* p); |
220 |
virtual void do_oop(oop* p) { do_oop_work(p); } |
|
221 |
virtual void do_oop(narrowOop* p) { do_oop_work(p); } |
|
49607
acffe6ff3ae7
8180415: Rebuild remembered sets during the concurrent cycle
tschatzl
parents:
49606
diff
changeset
|
222 |
// This closure needs special handling for InstanceRefKlass. |
acffe6ff3ae7
8180415: Rebuild remembered sets during the concurrent cycle
tschatzl
parents:
49606
diff
changeset
|
223 |
virtual ReferenceIterationMode reference_iteration_mode() { return DO_DISCOVERED_AND_DISCOVERY; } |
acffe6ff3ae7
8180415: Rebuild remembered sets during the concurrent cycle
tschatzl
parents:
49606
diff
changeset
|
224 |
}; |
acffe6ff3ae7
8180415: Rebuild remembered sets during the concurrent cycle
tschatzl
parents:
49606
diff
changeset
|
225 |
|
30764 | 226 |
#endif // SHARE_VM_GC_G1_G1OOPCLOSURES_HPP |