annotate src/share/vm/oops/methodDataKlass.cpp @ 3917:eca1193ca245

4965777: GC changes to support use of discovered field for pending references Summary: If and when the reference handler thread is able to use the discovered field to link reference objects in its pending list, so will GC. In that case, GC will scan through this field once a reference object has been placed on the pending list, but not scan that field before that stage, as the field is used by the concurrent GC thread to link discovered objects. When ReferenceHandleR thread does not use the discovered field for the purpose of linking the elements in the pending list, as would be the case in older JDKs, the JVM will fall back to the old behaviour of using the next field for that purpose. Reviewed-by: jcoomes, mchung, stefank
author ysr
date Wed, 07 Sep 2011 13:55:42 -0700
parents e5383553fd4e
children f7251c729b31
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1 /*
2227
e5383553fd4e 7014851: Remove unused parallel compaction code
stefank
parents: 1972
diff changeset
2 * Copyright (c) 2000, 2011, Oracle and/or its affiliates. All rights reserved.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
a61af66fc99e Initial load
duke
parents:
diff changeset
4 *
a61af66fc99e Initial load
duke
parents:
diff changeset
5 * This code is free software; you can redistribute it and/or modify it
a61af66fc99e Initial load
duke
parents:
diff changeset
6 * under the terms of the GNU General Public License version 2 only, as
a61af66fc99e Initial load
duke
parents:
diff changeset
7 * published by the Free Software Foundation.
a61af66fc99e Initial load
duke
parents:
diff changeset
8 *
a61af66fc99e Initial load
duke
parents:
diff changeset
9 * This code is distributed in the hope that it will be useful, but WITHOUT
a61af66fc99e Initial load
duke
parents:
diff changeset
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
a61af66fc99e Initial load
duke
parents:
diff changeset
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
a61af66fc99e Initial load
duke
parents:
diff changeset
12 * version 2 for more details (a copy is included in the LICENSE file that
a61af66fc99e Initial load
duke
parents:
diff changeset
13 * accompanied this code).
a61af66fc99e Initial load
duke
parents:
diff changeset
14 *
a61af66fc99e Initial load
duke
parents:
diff changeset
15 * You should have received a copy of the GNU General Public License version
a61af66fc99e Initial load
duke
parents:
diff changeset
16 * 2 along with this work; if not, write to the Free Software Foundation,
a61af66fc99e Initial load
duke
parents:
diff changeset
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
a61af66fc99e Initial load
duke
parents:
diff changeset
18 *
1552
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1155
diff changeset
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1155
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: 1155
diff changeset
21 * questions.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
22 *
a61af66fc99e Initial load
duke
parents:
diff changeset
23 */
a61af66fc99e Initial load
duke
parents:
diff changeset
24
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1706
diff changeset
25 #include "precompiled.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1706
diff changeset
26 #include "gc_implementation/shared/markSweep.inline.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1706
diff changeset
27 #include "gc_interface/collectedHeap.inline.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1706
diff changeset
28 #include "memory/gcLocker.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1706
diff changeset
29 #include "memory/resourceArea.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1706
diff changeset
30 #include "memory/universe.inline.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1706
diff changeset
31 #include "oops/klassOop.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1706
diff changeset
32 #include "oops/methodDataKlass.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1706
diff changeset
33 #include "oops/methodDataOop.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1706
diff changeset
34 #include "oops/oop.inline.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1706
diff changeset
35 #include "oops/oop.inline2.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1706
diff changeset
36 #include "runtime/handles.inline.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1706
diff changeset
37 #ifndef SERIALGC
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1706
diff changeset
38 #include "gc_implementation/parallelScavenge/psScavenge.inline.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1706
diff changeset
39 #include "oops/oop.pcgc.inline.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1706
diff changeset
40 #endif
0
a61af66fc99e Initial load
duke
parents:
diff changeset
41
a61af66fc99e Initial load
duke
parents:
diff changeset
42 klassOop methodDataKlass::create_klass(TRAPS) {
a61af66fc99e Initial load
duke
parents:
diff changeset
43 methodDataKlass o;
a61af66fc99e Initial load
duke
parents:
diff changeset
44 KlassHandle h_this_klass(THREAD, Universe::klassKlassObj());
a61af66fc99e Initial load
duke
parents:
diff changeset
45 KlassHandle k = base_create_klass(h_this_klass, header_size(),
a61af66fc99e Initial load
duke
parents:
diff changeset
46 o.vtbl_value(), CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
47 // Make sure size calculation is right
a61af66fc99e Initial load
duke
parents:
diff changeset
48 assert(k()->size() == align_object_size(header_size()),
a61af66fc99e Initial load
duke
parents:
diff changeset
49 "wrong size for object");
a61af66fc99e Initial load
duke
parents:
diff changeset
50 return k();
a61af66fc99e Initial load
duke
parents:
diff changeset
51 }
a61af66fc99e Initial load
duke
parents:
diff changeset
52
a61af66fc99e Initial load
duke
parents:
diff changeset
53
a61af66fc99e Initial load
duke
parents:
diff changeset
54 int methodDataKlass::oop_size(oop obj) const {
a61af66fc99e Initial load
duke
parents:
diff changeset
55 assert(obj->is_methodData(), "must be method data oop");
a61af66fc99e Initial load
duke
parents:
diff changeset
56 return methodDataOop(obj)->object_size();
a61af66fc99e Initial load
duke
parents:
diff changeset
57 }
a61af66fc99e Initial load
duke
parents:
diff changeset
58
a61af66fc99e Initial load
duke
parents:
diff changeset
59
a61af66fc99e Initial load
duke
parents:
diff changeset
60 bool methodDataKlass::oop_is_parsable(oop obj) const {
a61af66fc99e Initial load
duke
parents:
diff changeset
61 assert(obj->is_methodData(), "must be method data oop");
a61af66fc99e Initial load
duke
parents:
diff changeset
62 return methodDataOop(obj)->object_is_parsable();
a61af66fc99e Initial load
duke
parents:
diff changeset
63 }
a61af66fc99e Initial load
duke
parents:
diff changeset
64
a61af66fc99e Initial load
duke
parents:
diff changeset
65
a61af66fc99e Initial load
duke
parents:
diff changeset
66 methodDataOop methodDataKlass::allocate(methodHandle method, TRAPS) {
a61af66fc99e Initial load
duke
parents:
diff changeset
67 int size = methodDataOopDesc::compute_allocation_size_in_words(method);
a61af66fc99e Initial load
duke
parents:
diff changeset
68 KlassHandle h_k(THREAD, as_klassOop());
a61af66fc99e Initial load
duke
parents:
diff changeset
69 methodDataOop mdo =
a61af66fc99e Initial load
duke
parents:
diff changeset
70 (methodDataOop)CollectedHeap::permanent_obj_allocate(h_k, size, CHECK_NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
71 assert(!mdo->is_parsable(), "not expecting parsability yet.");
a61af66fc99e Initial load
duke
parents:
diff changeset
72 No_Safepoint_Verifier no_safepoint; // init function atomic wrt GC
a61af66fc99e Initial load
duke
parents:
diff changeset
73 mdo->initialize(method);
a61af66fc99e Initial load
duke
parents:
diff changeset
74
a61af66fc99e Initial load
duke
parents:
diff changeset
75 assert(mdo->is_parsable(), "should be parsable here.");
a61af66fc99e Initial load
duke
parents:
diff changeset
76 assert(size == mdo->object_size(), "wrong size for methodDataOop");
a61af66fc99e Initial load
duke
parents:
diff changeset
77 return mdo;
a61af66fc99e Initial load
duke
parents:
diff changeset
78 }
a61af66fc99e Initial load
duke
parents:
diff changeset
79
a61af66fc99e Initial load
duke
parents:
diff changeset
80
a61af66fc99e Initial load
duke
parents:
diff changeset
81 void methodDataKlass::oop_follow_contents(oop obj) {
a61af66fc99e Initial load
duke
parents:
diff changeset
82 assert (obj->is_methodData(), "object must be method data");
a61af66fc99e Initial load
duke
parents:
diff changeset
83 methodDataOop m = methodDataOop(obj);
a61af66fc99e Initial load
duke
parents:
diff changeset
84
a61af66fc99e Initial load
duke
parents:
diff changeset
85 obj->follow_header();
a61af66fc99e Initial load
duke
parents:
diff changeset
86 MarkSweep::mark_and_push(m->adr_method());
a61af66fc99e Initial load
duke
parents:
diff changeset
87 ResourceMark rm;
a61af66fc99e Initial load
duke
parents:
diff changeset
88 for (ProfileData* data = m->first_data();
a61af66fc99e Initial load
duke
parents:
diff changeset
89 m->is_valid(data);
a61af66fc99e Initial load
duke
parents:
diff changeset
90 data = m->next_data(data)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
91 data->follow_contents();
a61af66fc99e Initial load
duke
parents:
diff changeset
92 }
a61af66fc99e Initial load
duke
parents:
diff changeset
93 }
a61af66fc99e Initial load
duke
parents:
diff changeset
94
a61af66fc99e Initial load
duke
parents:
diff changeset
95 #ifndef SERIALGC
a61af66fc99e Initial load
duke
parents:
diff changeset
96 void methodDataKlass::oop_follow_contents(ParCompactionManager* cm,
a61af66fc99e Initial load
duke
parents:
diff changeset
97 oop obj) {
a61af66fc99e Initial load
duke
parents:
diff changeset
98 assert (obj->is_methodData(), "object must be method data");
a61af66fc99e Initial load
duke
parents:
diff changeset
99 methodDataOop m = methodDataOop(obj);
a61af66fc99e Initial load
duke
parents:
diff changeset
100
a61af66fc99e Initial load
duke
parents:
diff changeset
101 obj->follow_header(cm);
a61af66fc99e Initial load
duke
parents:
diff changeset
102 PSParallelCompact::mark_and_push(cm, m->adr_method());
a61af66fc99e Initial load
duke
parents:
diff changeset
103 ResourceMark rm;
a61af66fc99e Initial load
duke
parents:
diff changeset
104 for (ProfileData* data = m->first_data();
a61af66fc99e Initial load
duke
parents:
diff changeset
105 m->is_valid(data);
a61af66fc99e Initial load
duke
parents:
diff changeset
106 data = m->next_data(data)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
107 data->follow_contents(cm);
a61af66fc99e Initial load
duke
parents:
diff changeset
108 }
a61af66fc99e Initial load
duke
parents:
diff changeset
109 }
a61af66fc99e Initial load
duke
parents:
diff changeset
110 #endif // SERIALGC
a61af66fc99e Initial load
duke
parents:
diff changeset
111
113
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
112
0
a61af66fc99e Initial load
duke
parents:
diff changeset
113 int methodDataKlass::oop_oop_iterate(oop obj, OopClosure* blk) {
a61af66fc99e Initial load
duke
parents:
diff changeset
114 assert (obj->is_methodData(), "object must be method data");
a61af66fc99e Initial load
duke
parents:
diff changeset
115 methodDataOop m = methodDataOop(obj);
a61af66fc99e Initial load
duke
parents:
diff changeset
116 // Get size before changing pointers
a61af66fc99e Initial load
duke
parents:
diff changeset
117 // Don't call size() or oop_size() since that is a virtual call.
a61af66fc99e Initial load
duke
parents:
diff changeset
118 int size = m->object_size();
a61af66fc99e Initial load
duke
parents:
diff changeset
119
a61af66fc99e Initial load
duke
parents:
diff changeset
120 obj->oop_iterate_header(blk);
a61af66fc99e Initial load
duke
parents:
diff changeset
121 blk->do_oop(m->adr_method());
a61af66fc99e Initial load
duke
parents:
diff changeset
122 ResourceMark rm;
a61af66fc99e Initial load
duke
parents:
diff changeset
123 for (ProfileData* data = m->first_data();
a61af66fc99e Initial load
duke
parents:
diff changeset
124 m->is_valid(data);
a61af66fc99e Initial load
duke
parents:
diff changeset
125 data = m->next_data(data)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
126 data->oop_iterate(blk);
a61af66fc99e Initial load
duke
parents:
diff changeset
127 }
a61af66fc99e Initial load
duke
parents:
diff changeset
128 return size;
a61af66fc99e Initial load
duke
parents:
diff changeset
129 }
a61af66fc99e Initial load
duke
parents:
diff changeset
130
a61af66fc99e Initial load
duke
parents:
diff changeset
131 int methodDataKlass::oop_oop_iterate_m(oop obj, OopClosure* blk, MemRegion mr) {
a61af66fc99e Initial load
duke
parents:
diff changeset
132 assert (obj->is_methodData(), "object must be method data");
a61af66fc99e Initial load
duke
parents:
diff changeset
133 methodDataOop m = methodDataOop(obj);
a61af66fc99e Initial load
duke
parents:
diff changeset
134 // Get size before changing pointers
a61af66fc99e Initial load
duke
parents:
diff changeset
135 // Don't call size() or oop_size() since that is a virtual call.
a61af66fc99e Initial load
duke
parents:
diff changeset
136 int size = m->object_size();
a61af66fc99e Initial load
duke
parents:
diff changeset
137
a61af66fc99e Initial load
duke
parents:
diff changeset
138 obj->oop_iterate_header(blk, mr);
a61af66fc99e Initial load
duke
parents:
diff changeset
139 oop* adr = m->adr_method();
a61af66fc99e Initial load
duke
parents:
diff changeset
140 if (mr.contains(adr)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
141 blk->do_oop(m->adr_method());
a61af66fc99e Initial load
duke
parents:
diff changeset
142 }
a61af66fc99e Initial load
duke
parents:
diff changeset
143 ResourceMark rm;
a61af66fc99e Initial load
duke
parents:
diff changeset
144 for (ProfileData* data = m->first_data();
a61af66fc99e Initial load
duke
parents:
diff changeset
145 m->is_valid(data);
a61af66fc99e Initial load
duke
parents:
diff changeset
146 data = m->next_data(data)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
147 data->oop_iterate_m(blk, mr);
a61af66fc99e Initial load
duke
parents:
diff changeset
148 }
a61af66fc99e Initial load
duke
parents:
diff changeset
149 return size;
a61af66fc99e Initial load
duke
parents:
diff changeset
150 }
a61af66fc99e Initial load
duke
parents:
diff changeset
151
a61af66fc99e Initial load
duke
parents:
diff changeset
152 int methodDataKlass::oop_adjust_pointers(oop obj) {
a61af66fc99e Initial load
duke
parents:
diff changeset
153 assert(obj->is_methodData(), "should be method data");
a61af66fc99e Initial load
duke
parents:
diff changeset
154 methodDataOop m = methodDataOop(obj);
a61af66fc99e Initial load
duke
parents:
diff changeset
155 // Get size before changing pointers
a61af66fc99e Initial load
duke
parents:
diff changeset
156 // Don't call size() or oop_size() since that is a virtual call.
a61af66fc99e Initial load
duke
parents:
diff changeset
157 int size = m->object_size();
a61af66fc99e Initial load
duke
parents:
diff changeset
158
a61af66fc99e Initial load
duke
parents:
diff changeset
159 obj->adjust_header();
a61af66fc99e Initial load
duke
parents:
diff changeset
160 MarkSweep::adjust_pointer(m->adr_method());
a61af66fc99e Initial load
duke
parents:
diff changeset
161 ResourceMark rm;
a61af66fc99e Initial load
duke
parents:
diff changeset
162 ProfileData* data;
a61af66fc99e Initial load
duke
parents:
diff changeset
163 for (data = m->first_data(); m->is_valid(data); data = m->next_data(data)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
164 data->adjust_pointers();
a61af66fc99e Initial load
duke
parents:
diff changeset
165 }
a61af66fc99e Initial load
duke
parents:
diff changeset
166 return size;
a61af66fc99e Initial load
duke
parents:
diff changeset
167 }
a61af66fc99e Initial load
duke
parents:
diff changeset
168
a61af66fc99e Initial load
duke
parents:
diff changeset
169
a61af66fc99e Initial load
duke
parents:
diff changeset
170 #ifndef SERIALGC
a61af66fc99e Initial load
duke
parents:
diff changeset
171 void methodDataKlass::oop_push_contents(PSPromotionManager* pm, oop obj) {
a61af66fc99e Initial load
duke
parents:
diff changeset
172 assert (obj->is_methodData(), "object must be method data");
a61af66fc99e Initial load
duke
parents:
diff changeset
173 methodDataOop m = methodDataOop(obj);
a61af66fc99e Initial load
duke
parents:
diff changeset
174 // This should never point into the young gen.
113
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
175 assert(!PSScavenge::should_scavenge(m->adr_method()), "Sanity");
0
a61af66fc99e Initial load
duke
parents:
diff changeset
176 }
a61af66fc99e Initial load
duke
parents:
diff changeset
177
a61af66fc99e Initial load
duke
parents:
diff changeset
178 int methodDataKlass::oop_update_pointers(ParCompactionManager* cm, oop obj) {
a61af66fc99e Initial load
duke
parents:
diff changeset
179 assert(obj->is_methodData(), "should be method data");
a61af66fc99e Initial load
duke
parents:
diff changeset
180 methodDataOop m = methodDataOop(obj);
a61af66fc99e Initial load
duke
parents:
diff changeset
181
a61af66fc99e Initial load
duke
parents:
diff changeset
182 PSParallelCompact::adjust_pointer(m->adr_method());
a61af66fc99e Initial load
duke
parents:
diff changeset
183
a61af66fc99e Initial load
duke
parents:
diff changeset
184 ResourceMark rm;
a61af66fc99e Initial load
duke
parents:
diff changeset
185 ProfileData* data;
a61af66fc99e Initial load
duke
parents:
diff changeset
186 for (data = m->first_data(); m->is_valid(data); data = m->next_data(data)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
187 data->update_pointers();
a61af66fc99e Initial load
duke
parents:
diff changeset
188 }
a61af66fc99e Initial load
duke
parents:
diff changeset
189 return m->object_size();
a61af66fc99e Initial load
duke
parents:
diff changeset
190 }
a61af66fc99e Initial load
duke
parents:
diff changeset
191 #endif // SERIALGC
a61af66fc99e Initial load
duke
parents:
diff changeset
192
a61af66fc99e Initial load
duke
parents:
diff changeset
193 #ifndef PRODUCT
a61af66fc99e Initial load
duke
parents:
diff changeset
194
a61af66fc99e Initial load
duke
parents:
diff changeset
195 // Printing
a61af66fc99e Initial load
duke
parents:
diff changeset
196 void methodDataKlass::oop_print_on(oop obj, outputStream* st) {
a61af66fc99e Initial load
duke
parents:
diff changeset
197 assert(obj->is_methodData(), "should be method data");
a61af66fc99e Initial load
duke
parents:
diff changeset
198 methodDataOop m = methodDataOop(obj);
a61af66fc99e Initial load
duke
parents:
diff changeset
199 st->print("method data for ");
a61af66fc99e Initial load
duke
parents:
diff changeset
200 m->method()->print_value_on(st);
a61af66fc99e Initial load
duke
parents:
diff changeset
201 st->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
202 m->print_data_on(st);
a61af66fc99e Initial load
duke
parents:
diff changeset
203 }
a61af66fc99e Initial load
duke
parents:
diff changeset
204
1155
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 196
diff changeset
205 #endif //PRODUCT
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 196
diff changeset
206
0
a61af66fc99e Initial load
duke
parents:
diff changeset
207 void methodDataKlass::oop_print_value_on(oop obj, outputStream* st) {
a61af66fc99e Initial load
duke
parents:
diff changeset
208 assert(obj->is_methodData(), "should be method data");
a61af66fc99e Initial load
duke
parents:
diff changeset
209 methodDataOop m = methodDataOop(obj);
a61af66fc99e Initial load
duke
parents:
diff changeset
210 st->print("method data for ");
a61af66fc99e Initial load
duke
parents:
diff changeset
211 m->method()->print_value_on(st);
a61af66fc99e Initial load
duke
parents:
diff changeset
212 }
a61af66fc99e Initial load
duke
parents:
diff changeset
213
a61af66fc99e Initial load
duke
parents:
diff changeset
214 const char* methodDataKlass::internal_name() const {
a61af66fc99e Initial load
duke
parents:
diff changeset
215 return "{method data}";
a61af66fc99e Initial load
duke
parents:
diff changeset
216 }
a61af66fc99e Initial load
duke
parents:
diff changeset
217
a61af66fc99e Initial load
duke
parents:
diff changeset
218
a61af66fc99e Initial load
duke
parents:
diff changeset
219 // Verification
a61af66fc99e Initial load
duke
parents:
diff changeset
220 void methodDataKlass::oop_verify_on(oop obj, outputStream* st) {
a61af66fc99e Initial load
duke
parents:
diff changeset
221 Klass::oop_verify_on(obj, st);
a61af66fc99e Initial load
duke
parents:
diff changeset
222 guarantee(obj->is_methodData(), "object must be method data");
a61af66fc99e Initial load
duke
parents:
diff changeset
223 methodDataOop m = methodDataOop(obj);
a61af66fc99e Initial load
duke
parents:
diff changeset
224 guarantee(m->is_perm(), "should be in permspace");
a61af66fc99e Initial load
duke
parents:
diff changeset
225 m->verify_data_on(st);
a61af66fc99e Initial load
duke
parents:
diff changeset
226 }