Mercurial > hg > truffle
annotate src/share/vm/memory/cardTableRS.hpp @ 15177:66e3af78ea96
HSAIL: added safepoint support
Contributed-by: Eric Caspole <eric.caspole@amd.com>
author | Doug Simon <doug.simon@oracle.com> |
---|---|
date | Thu, 17 Apr 2014 00:44:32 +0200 |
parents | 4ca6dc0799b6 |
children |
rev | line source |
---|---|
0 | 1 /* |
10271
f9be75d21404
8012902: remove use of global operator new - take 2
minqi
parents:
10135
diff
changeset
|
2 * Copyright (c) 2001, 2013, Oracle and/or its affiliates. All rights reserved. |
0 | 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 * | |
1552
c18cbe5936b8
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
356
diff
changeset
|
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
c18cbe5936b8
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
356
diff
changeset
|
20 * or visit www.oracle.com if you need additional information or have any |
c18cbe5936b8
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
356
diff
changeset
|
21 * questions. |
0 | 22 * |
23 */ | |
24 | |
1972 | 25 #ifndef SHARE_VM_MEMORY_CARDTABLERS_HPP |
26 #define SHARE_VM_MEMORY_CARDTABLERS_HPP | |
27 | |
28 #include "memory/cardTableModRefBS.hpp" | |
29 #include "memory/genRemSet.hpp" | |
30 #include "memory/memRegion.hpp" | |
31 | |
0 | 32 class Space; |
33 class OopsInGenClosure; | |
34 | |
35 // This kind of "GenRemSet" uses a card table both as shared data structure | |
36 // for a mod ref barrier set and for the rem set information. | |
37 | |
38 class CardTableRS: public GenRemSet { | |
39 friend class VMStructs; | |
40 // Below are private classes used in impl. | |
41 friend class VerifyCTSpaceClosure; | |
42 friend class ClearNoncleanCardWrapper; | |
43 | |
44 static jbyte clean_card_val() { | |
45 return CardTableModRefBS::clean_card; | |
46 } | |
47 | |
5939
c7a555a9449a
7068625: Testing 8 bytes of card table entries at a time speeds up card-scanning
brutisso
parents:
3357
diff
changeset
|
48 static intptr_t clean_card_row() { |
c7a555a9449a
7068625: Testing 8 bytes of card table entries at a time speeds up card-scanning
brutisso
parents:
3357
diff
changeset
|
49 return CardTableModRefBS::clean_card_row; |
c7a555a9449a
7068625: Testing 8 bytes of card table entries at a time speeds up card-scanning
brutisso
parents:
3357
diff
changeset
|
50 } |
c7a555a9449a
7068625: Testing 8 bytes of card table entries at a time speeds up card-scanning
brutisso
parents:
3357
diff
changeset
|
51 |
0 | 52 static bool |
53 card_is_dirty_wrt_gen_iter(jbyte cv) { | |
54 return CardTableModRefBS::card_is_dirty_wrt_gen_iter(cv); | |
55 } | |
56 | |
342
37f87013dfd8
6711316: Open source the Garbage-First garbage collector
ysr
parents:
113
diff
changeset
|
57 CardTableModRefBSForCTRS* _ct_bs; |
0 | 58 |
59 virtual void younger_refs_in_space_iterate(Space* sp, OopsInGenClosure* cl); | |
60 | |
61 void verify_space(Space* s, HeapWord* gen_start); | |
62 | |
63 enum ExtendedCardValue { | |
64 youngergen_card = CardTableModRefBS::CT_MR_BS_last_reserved + 1, | |
65 // These are for parallel collection. | |
66 // There are three P (parallel) youngergen card values. In general, this | |
67 // needs to be more than the number of generations (including the perm | |
68 // gen) that might have younger_refs_do invoked on them separately. So | |
69 // if we add more gens, we have to add more values. | |
70 youngergenP1_card = CardTableModRefBS::CT_MR_BS_last_reserved + 2, | |
71 youngergenP2_card = CardTableModRefBS::CT_MR_BS_last_reserved + 3, | |
72 youngergenP3_card = CardTableModRefBS::CT_MR_BS_last_reserved + 4, | |
73 cur_youngergen_and_prev_nonclean_card = | |
74 CardTableModRefBS::CT_MR_BS_last_reserved + 5 | |
75 }; | |
76 | |
77 // An array that contains, for each generation, the card table value last | |
78 // used as the current value for a younger_refs_do iteration of that | |
79 // portion of the table. (The perm gen is index 0; other gens are at | |
80 // their level plus 1. They youngest gen is in the table, but will | |
81 // always have the value "clean_card".) | |
82 jbyte* _last_cur_val_in_gen; | |
83 | |
84 jbyte _cur_youngergen_card_val; | |
85 | |
342
37f87013dfd8
6711316: Open source the Garbage-First garbage collector
ysr
parents:
113
diff
changeset
|
86 int _regions_to_iterate; |
37f87013dfd8
6711316: Open source the Garbage-First garbage collector
ysr
parents:
113
diff
changeset
|
87 |
0 | 88 jbyte cur_youngergen_card_val() { |
89 return _cur_youngergen_card_val; | |
90 } | |
91 void set_cur_youngergen_card_val(jbyte v) { | |
92 _cur_youngergen_card_val = v; | |
93 } | |
94 bool is_prev_youngergen_card_val(jbyte v) { | |
95 return | |
96 youngergen_card <= v && | |
97 v < cur_youngergen_and_prev_nonclean_card && | |
98 v != _cur_youngergen_card_val; | |
99 } | |
100 // Return a youngergen_card_value that is not currently in use. | |
101 jbyte find_unused_youngergenP_card_value(); | |
102 | |
103 public: | |
104 CardTableRS(MemRegion whole_heap, int max_covered_regions); | |
10271
f9be75d21404
8012902: remove use of global operator new - take 2
minqi
parents:
10135
diff
changeset
|
105 ~CardTableRS(); |
0 | 106 |
107 // *** GenRemSet functions. | |
14909 | 108 GenRemSet::Name rs_kind() { return GenRemSet::CardTable; } |
109 | |
0 | 110 CardTableRS* as_CardTableRS() { return this; } |
111 | |
342
37f87013dfd8
6711316: Open source the Garbage-First garbage collector
ysr
parents:
113
diff
changeset
|
112 CardTableModRefBS* ct_bs() { return _ct_bs; } |
0 | 113 |
114 // Override. | |
115 void prepare_for_younger_refs_iterate(bool parallel); | |
116 | |
117 // Card table entries are cleared before application; "blk" is | |
118 // responsible for dirtying if the oop is still older-to-younger after | |
119 // closure application. | |
120 void younger_refs_iterate(Generation* g, OopsInGenClosure* blk); | |
121 | |
113
ba764ed4b6f2
6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents:
6
diff
changeset
|
122 void inline_write_ref_field_gc(void* field, oop new_val) { |
342
37f87013dfd8
6711316: Open source the Garbage-First garbage collector
ysr
parents:
113
diff
changeset
|
123 jbyte* byte = _ct_bs->byte_for(field); |
0 | 124 *byte = youngergen_card; |
125 } | |
113
ba764ed4b6f2
6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents:
6
diff
changeset
|
126 void write_ref_field_gc_work(void* field, oop new_val) { |
0 | 127 inline_write_ref_field_gc(field, new_val); |
128 } | |
129 | |
130 // Override. Might want to devirtualize this in the same fashion as | |
131 // above. Ensures that the value of the card for field says that it's | |
132 // a younger card in the current collection. | |
113
ba764ed4b6f2
6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents:
6
diff
changeset
|
133 virtual void write_ref_field_gc_par(void* field, oop new_val); |
0 | 134 |
135 void resize_covered_region(MemRegion new_region); | |
136 | |
137 bool is_aligned(HeapWord* addr) { | |
342
37f87013dfd8
6711316: Open source the Garbage-First garbage collector
ysr
parents:
113
diff
changeset
|
138 return _ct_bs->is_card_aligned(addr); |
0 | 139 } |
140 | |
141 void verify(); | |
6
73e96e5c30df
6624765: Guarantee failure "Unexpected dirty card found"
jmasa
parents:
0
diff
changeset
|
142 void verify_aligned_region_empty(MemRegion mr); |
0 | 143 |
342
37f87013dfd8
6711316: Open source the Garbage-First garbage collector
ysr
parents:
113
diff
changeset
|
144 void clear(MemRegion mr) { _ct_bs->clear(mr); } |
12033
bd902affe102
8023021: Unnecessary clearing of the card table introduced by the fix for JDK-8023013
brutisso
parents:
12030
diff
changeset
|
145 void clear_into_younger(Generation* old_gen); |
0 | 146 |
342
37f87013dfd8
6711316: Open source the Garbage-First garbage collector
ysr
parents:
113
diff
changeset
|
147 void invalidate(MemRegion mr, bool whole_heap = false) { |
37f87013dfd8
6711316: Open source the Garbage-First garbage collector
ysr
parents:
113
diff
changeset
|
148 _ct_bs->invalidate(mr, whole_heap); |
37f87013dfd8
6711316: Open source the Garbage-First garbage collector
ysr
parents:
113
diff
changeset
|
149 } |
12033
bd902affe102
8023021: Unnecessary clearing of the card table introduced by the fix for JDK-8023013
brutisso
parents:
12030
diff
changeset
|
150 void invalidate_or_clear(Generation* old_gen); |
0 | 151 |
152 static uintx ct_max_alignment_constraint() { | |
153 return CardTableModRefBS::ct_max_alignment_constraint(); | |
154 } | |
155 | |
342
37f87013dfd8
6711316: Open source the Garbage-First garbage collector
ysr
parents:
113
diff
changeset
|
156 jbyte* byte_for(void* p) { return _ct_bs->byte_for(p); } |
37f87013dfd8
6711316: Open source the Garbage-First garbage collector
ysr
parents:
113
diff
changeset
|
157 jbyte* byte_after(void* p) { return _ct_bs->byte_after(p); } |
37f87013dfd8
6711316: Open source the Garbage-First garbage collector
ysr
parents:
113
diff
changeset
|
158 HeapWord* addr_for(jbyte* p) { return _ct_bs->addr_for(p); } |
0 | 159 |
160 bool is_prev_nonclean_card_val(jbyte v) { | |
161 return | |
162 youngergen_card <= v && | |
163 v <= cur_youngergen_and_prev_nonclean_card && | |
164 v != _cur_youngergen_card_val; | |
165 } | |
166 | |
167 static bool youngergen_may_have_been_dirty(jbyte cv) { | |
168 return cv == CardTableRS::cur_youngergen_and_prev_nonclean_card; | |
169 } | |
170 | |
171 }; | |
1972 | 172 |
3287
c48ad6ab8bdf
7037276: Unnecessary double traversal of dirty card windows
ysr
parents:
1972
diff
changeset
|
173 class ClearNoncleanCardWrapper: public MemRegionClosure { |
3357
fc2b798ab316
6883834: ParNew: assert(!_g->to()->is_in_reserved(obj),"Scanning field twice?") with LargeObjects tests
ysr
parents:
3287
diff
changeset
|
174 DirtyCardToOopClosure* _dirty_card_closure; |
3287
c48ad6ab8bdf
7037276: Unnecessary double traversal of dirty card windows
ysr
parents:
1972
diff
changeset
|
175 CardTableRS* _ct; |
c48ad6ab8bdf
7037276: Unnecessary double traversal of dirty card windows
ysr
parents:
1972
diff
changeset
|
176 bool _is_par; |
c48ad6ab8bdf
7037276: Unnecessary double traversal of dirty card windows
ysr
parents:
1972
diff
changeset
|
177 private: |
c48ad6ab8bdf
7037276: Unnecessary double traversal of dirty card windows
ysr
parents:
1972
diff
changeset
|
178 // Clears the given card, return true if the corresponding card should be |
c48ad6ab8bdf
7037276: Unnecessary double traversal of dirty card windows
ysr
parents:
1972
diff
changeset
|
179 // processed. |
c48ad6ab8bdf
7037276: Unnecessary double traversal of dirty card windows
ysr
parents:
1972
diff
changeset
|
180 inline bool clear_card(jbyte* entry); |
c48ad6ab8bdf
7037276: Unnecessary double traversal of dirty card windows
ysr
parents:
1972
diff
changeset
|
181 // Work methods called by the clear_card() |
c48ad6ab8bdf
7037276: Unnecessary double traversal of dirty card windows
ysr
parents:
1972
diff
changeset
|
182 inline bool clear_card_serial(jbyte* entry); |
c48ad6ab8bdf
7037276: Unnecessary double traversal of dirty card windows
ysr
parents:
1972
diff
changeset
|
183 inline bool clear_card_parallel(jbyte* entry); |
5939
c7a555a9449a
7068625: Testing 8 bytes of card table entries at a time speeds up card-scanning
brutisso
parents:
3357
diff
changeset
|
184 // check alignment of pointer |
c7a555a9449a
7068625: Testing 8 bytes of card table entries at a time speeds up card-scanning
brutisso
parents:
3357
diff
changeset
|
185 bool is_word_aligned(jbyte* entry); |
3287
c48ad6ab8bdf
7037276: Unnecessary double traversal of dirty card windows
ysr
parents:
1972
diff
changeset
|
186 |
c48ad6ab8bdf
7037276: Unnecessary double traversal of dirty card windows
ysr
parents:
1972
diff
changeset
|
187 public: |
3357
fc2b798ab316
6883834: ParNew: assert(!_g->to()->is_in_reserved(obj),"Scanning field twice?") with LargeObjects tests
ysr
parents:
3287
diff
changeset
|
188 ClearNoncleanCardWrapper(DirtyCardToOopClosure* dirty_card_closure, CardTableRS* ct); |
3287
c48ad6ab8bdf
7037276: Unnecessary double traversal of dirty card windows
ysr
parents:
1972
diff
changeset
|
189 void do_MemRegion(MemRegion mr); |
c48ad6ab8bdf
7037276: Unnecessary double traversal of dirty card windows
ysr
parents:
1972
diff
changeset
|
190 }; |
c48ad6ab8bdf
7037276: Unnecessary double traversal of dirty card windows
ysr
parents:
1972
diff
changeset
|
191 |
1972 | 192 #endif // SHARE_VM_MEMORY_CARDTABLERS_HPP |