author | ehelin |
Mon, 05 Mar 2018 11:32:17 +0100 | |
changeset 49337 | e4fdca451542 |
parent 47580 | 96392e113a0a |
child 49606 | 9ae8719efcae |
permissions | -rw-r--r-- |
1374 | 1 |
/* |
46307
686d50172bfd
8071278: Fix the closure mess in G1RemSet::refine_card()
tschatzl
parents:
41176
diff
changeset
|
2 |
* Copyright (c) 2001, 2017, 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 |
|
46590 | 42 |
class G1ScanClosureBase : public ExtendedOopClosure { |
1374 | 43 |
protected: |
44 |
G1CollectedHeap* _g1; |
|
45 |
G1ParScanThreadState* _par_scan_state; |
|
46590 | 46 |
HeapRegion* _from; |
33224
bc5da96c1f0e
8139200: Eliminate G1ParClosureSuper::_worker_id
kbarrett
parents:
33213
diff
changeset
|
47 |
|
46572 | 48 |
G1ScanClosureBase(G1CollectedHeap* g1, G1ParScanThreadState* par_scan_state); |
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; } |
1374 | 60 |
}; |
61 |
||
46572 | 62 |
// Used during the Update RS phase to refine remaining cards in the DCQ during garbage collection. |
63 |
class G1ScanObjsDuringUpdateRSClosure: public G1ScanClosureBase { |
|
64 |
uint _worker_i; |
|
65 |
||
4902
991aaddb5165
6923991: G1: improve scalability of RSet scanning
iveresov
parents:
3262
diff
changeset
|
66 |
public: |
46572 | 67 |
G1ScanObjsDuringUpdateRSClosure(G1CollectedHeap* g1h, |
68 |
G1ParScanThreadState* pss, |
|
69 |
uint worker_i) : |
|
46670
55a3c36b64b2
8183539: Remove G1RemSet::_into_cset_dirty_card_queue_set
ehelin
parents:
46590
diff
changeset
|
70 |
G1ScanClosureBase(g1h, pss), _worker_i(worker_i) { } |
46572 | 71 |
|
72 |
template <class T> void do_oop_nv(T* p); |
|
73 |
virtual void do_oop(narrowOop* p) { do_oop_nv(p); } |
|
74 |
virtual void do_oop(oop* p) { do_oop_nv(p); } |
|
75 |
}; |
|
76 |
||
77 |
// Used during the Scan RS phase to scan cards from the remembered set during garbage collection. |
|
78 |
class G1ScanObjsDuringScanRSClosure : public G1ScanClosureBase { |
|
79 |
public: |
|
80 |
G1ScanObjsDuringScanRSClosure(G1CollectedHeap* g1, |
|
81 |
G1ParScanThreadState* par_scan_state): |
|
82 |
G1ScanClosureBase(g1, par_scan_state) { } |
|
10670
4ea0e7d2ffbc
6484982: G1: process references during evacuation pauses
johnc
parents:
10664
diff
changeset
|
83 |
|
4902
991aaddb5165
6923991: G1: improve scalability of RSet scanning
iveresov
parents:
3262
diff
changeset
|
84 |
template <class T> void do_oop_nv(T* p); |
991aaddb5165
6923991: G1: improve scalability of RSet scanning
iveresov
parents:
3262
diff
changeset
|
85 |
virtual void do_oop(oop* p) { do_oop_nv(p); } |
991aaddb5165
6923991: G1: improve scalability of RSet scanning
iveresov
parents:
3262
diff
changeset
|
86 |
virtual void do_oop(narrowOop* p) { do_oop_nv(p); } |
991aaddb5165
6923991: G1: improve scalability of RSet scanning
iveresov
parents:
3262
diff
changeset
|
87 |
}; |
991aaddb5165
6923991: G1: improve scalability of RSet scanning
iveresov
parents:
3262
diff
changeset
|
88 |
|
46572 | 89 |
// This closure is applied to the fields of the objects that have just been copied during evacuation. |
90 |
class G1ScanEvacuatedObjClosure : public G1ScanClosureBase { |
|
1374 | 91 |
public: |
46572 | 92 |
G1ScanEvacuatedObjClosure(G1CollectedHeap* g1, G1ParScanThreadState* par_scan_state) : |
93 |
G1ScanClosureBase(g1, par_scan_state) { } |
|
10670
4ea0e7d2ffbc
6484982: G1: process references during evacuation pauses
johnc
parents:
10664
diff
changeset
|
94 |
|
3262
30d1c247fc25
6700789: G1: Enable use of compressed oops with G1 heaps
ysr
parents:
2105
diff
changeset
|
95 |
template <class T> void do_oop_nv(T* p); |
1374 | 96 |
virtual void do_oop(oop* p) { do_oop_nv(p); } |
97 |
virtual void do_oop(narrowOop* p) { do_oop_nv(p); } |
|
32381
b750fd963056
8040162: Avoid reallocating PLABs between GC phases in G1
tschatzl
parents:
31976
diff
changeset
|
98 |
|
33226
19cb9b844190
8139341: Hide ExtendedOopClosure::_ref_processor
kbarrett
parents:
33224
diff
changeset
|
99 |
void set_ref_processor(ReferenceProcessor* rp) { |
19cb9b844190
8139341: Hide ExtendedOopClosure::_ref_processor
kbarrett
parents:
33224
diff
changeset
|
100 |
set_ref_processor_internal(rp); |
19cb9b844190
8139341: Hide ExtendedOopClosure::_ref_processor
kbarrett
parents:
33224
diff
changeset
|
101 |
} |
1374 | 102 |
}; |
103 |
||
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13336
diff
changeset
|
104 |
// Add back base class for metadata |
35067
0fa08ea22241
8144505: Change G1ParCopyHelper to inherit OopClosure
sjohanss
parents:
35062
diff
changeset
|
105 |
class G1ParCopyHelper : public OopClosure { |
22901
3b4e9802e94f
8027559: Decrease code size and templatizing in G1ParCopyClosure::do_oop_work
tschatzl
parents:
22761
diff
changeset
|
106 |
protected: |
35067
0fa08ea22241
8144505: Change G1ParCopyHelper to inherit OopClosure
sjohanss
parents:
35062
diff
changeset
|
107 |
G1CollectedHeap* _g1; |
0fa08ea22241
8144505: Change G1ParCopyHelper to inherit OopClosure
sjohanss
parents:
35062
diff
changeset
|
108 |
G1ParScanThreadState* _par_scan_state; |
33224
bc5da96c1f0e
8139200: Eliminate G1ParClosureSuper::_worker_id
kbarrett
parents:
33213
diff
changeset
|
109 |
uint _worker_id; // Cache value from par_scan_state. |
47580 | 110 |
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
|
111 |
G1ConcurrentMark* _cm; |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13336
diff
changeset
|
112 |
|
22901
3b4e9802e94f
8027559: Decrease code size and templatizing in G1ParCopyClosure::do_oop_work
tschatzl
parents:
22761
diff
changeset
|
113 |
// 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
|
114 |
// 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
|
115 |
// 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
|
116 |
inline void mark_object(oop obj); |
22901
3b4e9802e94f
8027559: Decrease code size and templatizing in G1ParCopyClosure::do_oop_work
tschatzl
parents:
22761
diff
changeset
|
117 |
|
3b4e9802e94f
8027559: Decrease code size and templatizing in G1ParCopyClosure::do_oop_work
tschatzl
parents:
22761
diff
changeset
|
118 |
// 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
|
119 |
// 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
|
120 |
// GC. It is MT-safe. |
33213
b937f634f56e
8138762: Refactor setup of evacuation closures in G1
mgerdin
parents:
32592
diff
changeset
|
121 |
inline void mark_forwarded_object(oop from_obj, oop to_obj); |
33224
bc5da96c1f0e
8139200: Eliminate G1ParClosureSuper::_worker_id
kbarrett
parents:
33213
diff
changeset
|
122 |
|
22901
3b4e9802e94f
8027559: Decrease code size and templatizing in G1ParCopyClosure::do_oop_work
tschatzl
parents:
22761
diff
changeset
|
123 |
G1ParCopyHelper(G1CollectedHeap* g1, G1ParScanThreadState* par_scan_state); |
33224
bc5da96c1f0e
8139200: Eliminate G1ParClosureSuper::_worker_id
kbarrett
parents:
33213
diff
changeset
|
124 |
~G1ParCopyHelper() { } |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13336
diff
changeset
|
125 |
|
33224
bc5da96c1f0e
8139200: Eliminate G1ParClosureSuper::_worker_id
kbarrett
parents:
33213
diff
changeset
|
126 |
public: |
47580 | 127 |
void set_scanned_cld(ClassLoaderData* cld) { _scanned_cld = cld; } |
128 |
inline void do_cld_barrier(oop new_obj); |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13336
diff
changeset
|
129 |
}; |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13336
diff
changeset
|
130 |
|
29688 | 131 |
enum G1Barrier { |
132 |
G1BarrierNone, |
|
47580 | 133 |
G1BarrierCLD |
29688 | 134 |
}; |
135 |
||
136 |
enum G1Mark { |
|
137 |
G1MarkNone, |
|
138 |
G1MarkFromRoot, |
|
139 |
G1MarkPromotedFromRoot |
|
140 |
}; |
|
141 |
||
49337
e4fdca451542
8197847: Remove unused file g1ParScanThreadState_ext.cpp
ehelin
parents:
47580
diff
changeset
|
142 |
template <G1Barrier barrier, G1Mark do_mark_object> |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13336
diff
changeset
|
143 |
class G1ParCopyClosure : public G1ParCopyHelper { |
1374 | 144 |
public: |
32592
d066afd32088
8134509: G1ParCopyClosure does not need a ReferenceProcessor
ehelin
parents:
32381
diff
changeset
|
145 |
G1ParCopyClosure(G1CollectedHeap* g1, G1ParScanThreadState* par_scan_state) : |
35067
0fa08ea22241
8144505: Change G1ParCopyHelper to inherit OopClosure
sjohanss
parents:
35062
diff
changeset
|
146 |
G1ParCopyHelper(g1, par_scan_state) { } |
10670
4ea0e7d2ffbc
6484982: G1: process references during evacuation pauses
johnc
parents:
10664
diff
changeset
|
147 |
|
35067
0fa08ea22241
8144505: Change G1ParCopyHelper to inherit OopClosure
sjohanss
parents:
35062
diff
changeset
|
148 |
template <class T> void do_oop_work(T* p); |
0fa08ea22241
8144505: Change G1ParCopyHelper to inherit OopClosure
sjohanss
parents:
35062
diff
changeset
|
149 |
virtual void do_oop(oop* p) { do_oop_work(p); } |
0fa08ea22241
8144505: Change G1ParCopyHelper to inherit OopClosure
sjohanss
parents:
35062
diff
changeset
|
150 |
virtual void do_oop(narrowOop* p) { do_oop_work(p); } |
1374 | 151 |
}; |
152 |
||
47580 | 153 |
class G1CLDScanClosure : public CLDClosure { |
33213
b937f634f56e
8138762: Refactor setup of evacuation closures in G1
mgerdin
parents:
32592
diff
changeset
|
154 |
G1ParCopyHelper* _closure; |
b937f634f56e
8138762: Refactor setup of evacuation closures in G1
mgerdin
parents:
32592
diff
changeset
|
155 |
bool _process_only_dirty; |
47580 | 156 |
bool _must_claim; |
33213
b937f634f56e
8138762: Refactor setup of evacuation closures in G1
mgerdin
parents:
32592
diff
changeset
|
157 |
int _count; |
b937f634f56e
8138762: Refactor setup of evacuation closures in G1
mgerdin
parents:
32592
diff
changeset
|
158 |
public: |
47580 | 159 |
G1CLDScanClosure(G1ParCopyHelper* closure, |
160 |
bool process_only_dirty, bool must_claim) |
|
161 |
: _process_only_dirty(process_only_dirty), _must_claim(must_claim), _closure(closure), _count(0) {} |
|
162 |
void do_cld(ClassLoaderData* cld); |
|
33213
b937f634f56e
8138762: Refactor setup of evacuation closures in G1
mgerdin
parents:
32592
diff
changeset
|
163 |
}; |
10670
4ea0e7d2ffbc
6484982: G1: process references during evacuation pauses
johnc
parents:
10664
diff
changeset
|
164 |
|
9994 | 165 |
// Closure for iterating over object fields during concurrent marking |
25492
d27050bdfb04
8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents:
25491
diff
changeset
|
166 |
class G1CMOopClosure : public MetadataAwareOopClosure { |
d27050bdfb04
8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents:
25491
diff
changeset
|
167 |
protected: |
35943
e726308008c0
8148973: Rename g1/concurrentMark.{hpp,cpp,inline.hpp} to g1/g1ConcurrentMark.{hpp,cpp,inline.hpp}
ehelin
parents:
35862
diff
changeset
|
168 |
G1ConcurrentMark* _cm; |
11584
e1df4d08a1f4
7127706: G1: re-enable survivors during the initial-mark pause
tonyp
parents:
11583
diff
changeset
|
169 |
private: |
9994 | 170 |
G1CollectedHeap* _g1h; |
35943
e726308008c0
8148973: Rename g1/concurrentMark.{hpp,cpp,inline.hpp} to g1/g1ConcurrentMark.{hpp,cpp,inline.hpp}
ehelin
parents:
35862
diff
changeset
|
171 |
G1CMTask* _task; |
9994 | 172 |
public: |
35943
e726308008c0
8148973: Rename g1/concurrentMark.{hpp,cpp,inline.hpp} to g1/g1ConcurrentMark.{hpp,cpp,inline.hpp}
ehelin
parents:
35862
diff
changeset
|
173 |
G1CMOopClosure(G1CollectedHeap* g1h, G1ConcurrentMark* cm, G1CMTask* task); |
9994 | 174 |
template <class T> void do_oop_nv(T* p); |
175 |
virtual void do_oop( oop* p) { do_oop_nv(p); } |
|
176 |
virtual void do_oop(narrowOop* p) { do_oop_nv(p); } |
|
177 |
}; |
|
178 |
||
11584
e1df4d08a1f4
7127706: G1: re-enable survivors during the initial-mark pause
tonyp
parents:
11583
diff
changeset
|
179 |
// Closure to scan the root regions during concurrent marking |
25492
d27050bdfb04
8049421: G1 Class Unloading after completing a concurrent mark cycle
stefank
parents:
25491
diff
changeset
|
180 |
class G1RootRegionScanClosure : public MetadataAwareOopClosure { |
11584
e1df4d08a1f4
7127706: G1: re-enable survivors during the initial-mark pause
tonyp
parents:
11583
diff
changeset
|
181 |
private: |
e1df4d08a1f4
7127706: G1: re-enable survivors during the initial-mark pause
tonyp
parents:
11583
diff
changeset
|
182 |
G1CollectedHeap* _g1h; |
35943
e726308008c0
8148973: Rename g1/concurrentMark.{hpp,cpp,inline.hpp} to g1/g1ConcurrentMark.{hpp,cpp,inline.hpp}
ehelin
parents:
35862
diff
changeset
|
183 |
G1ConcurrentMark* _cm; |
11584
e1df4d08a1f4
7127706: G1: re-enable survivors during the initial-mark pause
tonyp
parents:
11583
diff
changeset
|
184 |
public: |
37414
2672ba9af0dc
8151386: Extract card live data out of G1ConcurrentMark
tschatzl
parents:
35943
diff
changeset
|
185 |
G1RootRegionScanClosure(G1CollectedHeap* g1h, G1ConcurrentMark* cm) : |
2672ba9af0dc
8151386: Extract card live data out of G1ConcurrentMark
tschatzl
parents:
35943
diff
changeset
|
186 |
_g1h(g1h), _cm(cm) { } |
11584
e1df4d08a1f4
7127706: G1: re-enable survivors during the initial-mark pause
tonyp
parents:
11583
diff
changeset
|
187 |
template <class T> void do_oop_nv(T* p); |
e1df4d08a1f4
7127706: G1: re-enable survivors during the initial-mark pause
tonyp
parents:
11583
diff
changeset
|
188 |
virtual void do_oop( oop* p) { do_oop_nv(p); } |
e1df4d08a1f4
7127706: G1: re-enable survivors during the initial-mark pause
tonyp
parents:
11583
diff
changeset
|
189 |
virtual void do_oop(narrowOop* p) { do_oop_nv(p); } |
e1df4d08a1f4
7127706: G1: re-enable survivors during the initial-mark pause
tonyp
parents:
11583
diff
changeset
|
190 |
}; |
e1df4d08a1f4
7127706: G1: re-enable survivors during the initial-mark pause
tonyp
parents:
11583
diff
changeset
|
191 |
|
46519
40c9c132f961
8177707: Specialize G1RemSet::refine_card for concurrent/during safepoint refinement
tschatzl
parents:
46445
diff
changeset
|
192 |
class G1ConcurrentRefineOopClosure: public ExtendedOopClosure { |
40c9c132f961
8177707: Specialize G1RemSet::refine_card for concurrent/during safepoint refinement
tschatzl
parents:
46445
diff
changeset
|
193 |
G1CollectedHeap* _g1; |
40c9c132f961
8177707: Specialize G1RemSet::refine_card for concurrent/during safepoint refinement
tschatzl
parents:
46445
diff
changeset
|
194 |
uint _worker_i; |
40c9c132f961
8177707: Specialize G1RemSet::refine_card for concurrent/during safepoint refinement
tschatzl
parents:
46445
diff
changeset
|
195 |
|
40c9c132f961
8177707: Specialize G1RemSet::refine_card for concurrent/during safepoint refinement
tschatzl
parents:
46445
diff
changeset
|
196 |
public: |
40c9c132f961
8177707: Specialize G1RemSet::refine_card for concurrent/during safepoint refinement
tschatzl
parents:
46445
diff
changeset
|
197 |
G1ConcurrentRefineOopClosure(G1CollectedHeap* g1h, uint worker_i) : |
40c9c132f961
8177707: Specialize G1RemSet::refine_card for concurrent/during safepoint refinement
tschatzl
parents:
46445
diff
changeset
|
198 |
_g1(g1h), |
40c9c132f961
8177707: Specialize G1RemSet::refine_card for concurrent/during safepoint refinement
tschatzl
parents:
46445
diff
changeset
|
199 |
_worker_i(worker_i) { |
40c9c132f961
8177707: Specialize G1RemSet::refine_card for concurrent/during safepoint refinement
tschatzl
parents:
46445
diff
changeset
|
200 |
} |
40c9c132f961
8177707: Specialize G1RemSet::refine_card for concurrent/during safepoint refinement
tschatzl
parents:
46445
diff
changeset
|
201 |
|
40c9c132f961
8177707: Specialize G1RemSet::refine_card for concurrent/during safepoint refinement
tschatzl
parents:
46445
diff
changeset
|
202 |
// This closure needs special handling for InstanceRefKlass. |
40c9c132f961
8177707: Specialize G1RemSet::refine_card for concurrent/during safepoint refinement
tschatzl
parents:
46445
diff
changeset
|
203 |
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
|
204 |
|
40c9c132f961
8177707: Specialize G1RemSet::refine_card for concurrent/during safepoint refinement
tschatzl
parents:
46445
diff
changeset
|
205 |
template <class T> void do_oop_nv(T* p); |
40c9c132f961
8177707: Specialize G1RemSet::refine_card for concurrent/during safepoint refinement
tschatzl
parents:
46445
diff
changeset
|
206 |
virtual void do_oop(narrowOop* p) { do_oop_nv(p); } |
46572 | 207 |
virtual void do_oop(oop* p) { do_oop_nv(p); } |
11586
ccc217c177ee
7133038: G1: Some small profile based optimizations
johnc
parents:
11584
diff
changeset
|
208 |
}; |
ccc217c177ee
7133038: G1: Some small profile based optimizations
johnc
parents:
11584
diff
changeset
|
209 |
|
30764 | 210 |
#endif // SHARE_VM_GC_G1_G1OOPCLOSURES_HPP |