annotate src/share/vm/ci/ciObjArrayKlass.cpp @ 6725:da91efe96a93

6964458: Reimplement class meta-data storage to use native memory Summary: Remove PermGen, allocate meta-data in metaspace linked to class loaders, rewrite GC walking, rewrite and rename metadata to be C++ classes Reviewed-by: jmasa, stefank, never, coleenp, kvn, brutisso, mgerdin, dholmes, jrose, twisti, roland Contributed-by: jmasa <jon.masamitsu@oracle.com>, stefank <stefan.karlsson@oracle.com>, mgerdin <mikael.gerdin@oracle.com>, never <tom.rodriguez@oracle.com>
author coleenp
date Sat, 01 Sep 2012 13:25:18 -0400
parents ddd894528dbc
children d8ce2825b193
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1 /*
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3785
diff changeset
2 * Copyright (c) 1999, 2012, 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: 0
diff changeset
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 0
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: 0
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: 1552
diff changeset
25 #include "precompiled.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
26 #include "ci/ciInstanceKlass.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
27 #include "ci/ciObjArrayKlass.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
28 #include "ci/ciSymbol.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
29 #include "ci/ciUtilities.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
30 #include "oops/objArrayKlass.hpp"
0
a61af66fc99e Initial load
duke
parents:
diff changeset
31
a61af66fc99e Initial load
duke
parents:
diff changeset
32 // ciObjArrayKlass
a61af66fc99e Initial load
duke
parents:
diff changeset
33 //
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3785
diff changeset
34 // This class represents a Klass* in the HotSpot virtual machine
0
a61af66fc99e Initial load
duke
parents:
diff changeset
35 // whose Klass part is an objArrayKlass.
a61af66fc99e Initial load
duke
parents:
diff changeset
36
a61af66fc99e Initial load
duke
parents:
diff changeset
37 // ------------------------------------------------------------------
a61af66fc99e Initial load
duke
parents:
diff changeset
38 // ciObjArrayKlass::ciObjArrayKlass
a61af66fc99e Initial load
duke
parents:
diff changeset
39 //
a61af66fc99e Initial load
duke
parents:
diff changeset
40 // Constructor for loaded object array klasses.
a61af66fc99e Initial load
duke
parents:
diff changeset
41 ciObjArrayKlass::ciObjArrayKlass(KlassHandle h_k) : ciArrayKlass(h_k) {
a61af66fc99e Initial load
duke
parents:
diff changeset
42 assert(get_Klass()->oop_is_objArray(), "wrong type");
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3785
diff changeset
43 Klass* element_Klass = get_objArrayKlass()->bottom_klass();
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3785
diff changeset
44 _base_element_klass = CURRENT_ENV->get_klass(element_Klass);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
45 assert(_base_element_klass->is_instance_klass() ||
a61af66fc99e Initial load
duke
parents:
diff changeset
46 _base_element_klass->is_type_array_klass(), "bad base klass");
a61af66fc99e Initial load
duke
parents:
diff changeset
47 if (dimension() == 1) {
a61af66fc99e Initial load
duke
parents:
diff changeset
48 _element_klass = _base_element_klass;
a61af66fc99e Initial load
duke
parents:
diff changeset
49 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
50 _element_klass = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
51 }
a61af66fc99e Initial load
duke
parents:
diff changeset
52 if (!ciObjectFactory::is_initialized()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
53 assert(_element_klass->is_java_lang_Object(), "only arrays of object are shared");
a61af66fc99e Initial load
duke
parents:
diff changeset
54 }
a61af66fc99e Initial load
duke
parents:
diff changeset
55 }
a61af66fc99e Initial load
duke
parents:
diff changeset
56
a61af66fc99e Initial load
duke
parents:
diff changeset
57 // ------------------------------------------------------------------
a61af66fc99e Initial load
duke
parents:
diff changeset
58 // ciObjArrayKlass::ciObjArrayKlass
a61af66fc99e Initial load
duke
parents:
diff changeset
59 //
a61af66fc99e Initial load
duke
parents:
diff changeset
60 // Constructor for unloaded object array klasses.
a61af66fc99e Initial load
duke
parents:
diff changeset
61 ciObjArrayKlass::ciObjArrayKlass(ciSymbol* array_name,
a61af66fc99e Initial load
duke
parents:
diff changeset
62 ciKlass* base_element_klass,
a61af66fc99e Initial load
duke
parents:
diff changeset
63 int dimension)
a61af66fc99e Initial load
duke
parents:
diff changeset
64 : ciArrayKlass(array_name,
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3785
diff changeset
65 dimension, T_OBJECT) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
66 _base_element_klass = base_element_klass;
a61af66fc99e Initial load
duke
parents:
diff changeset
67 assert(_base_element_klass->is_instance_klass() ||
a61af66fc99e Initial load
duke
parents:
diff changeset
68 _base_element_klass->is_type_array_klass(), "bad base klass");
a61af66fc99e Initial load
duke
parents:
diff changeset
69 if (dimension == 1) {
a61af66fc99e Initial load
duke
parents:
diff changeset
70 _element_klass = base_element_klass;
a61af66fc99e Initial load
duke
parents:
diff changeset
71 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
72 _element_klass = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
73 }
a61af66fc99e Initial load
duke
parents:
diff changeset
74 }
a61af66fc99e Initial load
duke
parents:
diff changeset
75
a61af66fc99e Initial load
duke
parents:
diff changeset
76 // ------------------------------------------------------------------
a61af66fc99e Initial load
duke
parents:
diff changeset
77 // ciObjArrayKlass::element_klass
a61af66fc99e Initial load
duke
parents:
diff changeset
78 //
a61af66fc99e Initial load
duke
parents:
diff changeset
79 // What is the one-level element type of this array?
a61af66fc99e Initial load
duke
parents:
diff changeset
80 ciKlass* ciObjArrayKlass::element_klass() {
a61af66fc99e Initial load
duke
parents:
diff changeset
81 if (_element_klass == NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
82 assert(dimension() > 1, "_element_klass should not be NULL");
a61af66fc99e Initial load
duke
parents:
diff changeset
83 // Produce the element klass.
a61af66fc99e Initial load
duke
parents:
diff changeset
84 if (is_loaded()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
85 VM_ENTRY_MARK;
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3785
diff changeset
86 Klass* element_Klass = get_objArrayKlass()->element_klass();
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3785
diff changeset
87 _element_klass = CURRENT_THREAD_ENV->get_klass(element_Klass);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
88 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
89 VM_ENTRY_MARK;
a61af66fc99e Initial load
duke
parents:
diff changeset
90 // We are an unloaded array klass. Attempt to fetch our
a61af66fc99e Initial load
duke
parents:
diff changeset
91 // element klass by name.
a61af66fc99e Initial load
duke
parents:
diff changeset
92 _element_klass = CURRENT_THREAD_ENV->get_klass_by_name_impl(
a61af66fc99e Initial load
duke
parents:
diff changeset
93 this,
3785
ddd894528dbc 7056328: JSR 292 invocation sometimes fails in adapters for types not on boot class path
jrose
parents: 2426
diff changeset
94 constantPoolHandle(),
0
a61af66fc99e Initial load
duke
parents:
diff changeset
95 construct_array_name(base_element_klass()->name(),
a61af66fc99e Initial load
duke
parents:
diff changeset
96 dimension() - 1),
a61af66fc99e Initial load
duke
parents:
diff changeset
97 false);
a61af66fc99e Initial load
duke
parents:
diff changeset
98 }
a61af66fc99e Initial load
duke
parents:
diff changeset
99 }
a61af66fc99e Initial load
duke
parents:
diff changeset
100 return _element_klass;
a61af66fc99e Initial load
duke
parents:
diff changeset
101 }
a61af66fc99e Initial load
duke
parents:
diff changeset
102
a61af66fc99e Initial load
duke
parents:
diff changeset
103 // ------------------------------------------------------------------
a61af66fc99e Initial load
duke
parents:
diff changeset
104 // ciObjArrayKlass::construct_array_name
a61af66fc99e Initial load
duke
parents:
diff changeset
105 //
a61af66fc99e Initial load
duke
parents:
diff changeset
106 // Build an array name from an element name and a dimension.
a61af66fc99e Initial load
duke
parents:
diff changeset
107 ciSymbol* ciObjArrayKlass::construct_array_name(ciSymbol* element_name,
a61af66fc99e Initial load
duke
parents:
diff changeset
108 int dimension) {
a61af66fc99e Initial load
duke
parents:
diff changeset
109 EXCEPTION_CONTEXT;
a61af66fc99e Initial load
duke
parents:
diff changeset
110 int element_len = element_name->utf8_length();
a61af66fc99e Initial load
duke
parents:
diff changeset
111
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 1972
diff changeset
112 Symbol* base_name_sym = element_name->get_symbol();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
113 char* name;
a61af66fc99e Initial load
duke
parents:
diff changeset
114
a61af66fc99e Initial load
duke
parents:
diff changeset
115 if (base_name_sym->byte_at(0) == '[' ||
a61af66fc99e Initial load
duke
parents:
diff changeset
116 (base_name_sym->byte_at(0) == 'L' && // watch package name 'Lxx'
a61af66fc99e Initial load
duke
parents:
diff changeset
117 base_name_sym->byte_at(element_len-1) == ';')) {
a61af66fc99e Initial load
duke
parents:
diff changeset
118
a61af66fc99e Initial load
duke
parents:
diff changeset
119 int new_len = element_len + dimension + 1; // for the ['s and '\0'
a61af66fc99e Initial load
duke
parents:
diff changeset
120 name = CURRENT_THREAD_ENV->name_buffer(new_len);
a61af66fc99e Initial load
duke
parents:
diff changeset
121
a61af66fc99e Initial load
duke
parents:
diff changeset
122 int pos = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
123 for ( ; pos < dimension; pos++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
124 name[pos] = '[';
a61af66fc99e Initial load
duke
parents:
diff changeset
125 }
a61af66fc99e Initial load
duke
parents:
diff changeset
126 strncpy(name+pos, (char*)element_name->base(), element_len);
a61af66fc99e Initial load
duke
parents:
diff changeset
127 name[new_len-1] = '\0';
a61af66fc99e Initial load
duke
parents:
diff changeset
128 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
129 int new_len = 3 // for L, ;, and '\0'
a61af66fc99e Initial load
duke
parents:
diff changeset
130 + dimension // for ['s
a61af66fc99e Initial load
duke
parents:
diff changeset
131 + element_len;
a61af66fc99e Initial load
duke
parents:
diff changeset
132
a61af66fc99e Initial load
duke
parents:
diff changeset
133 name = CURRENT_THREAD_ENV->name_buffer(new_len);
a61af66fc99e Initial load
duke
parents:
diff changeset
134 int pos = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
135 for ( ; pos < dimension; pos++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
136 name[pos] = '[';
a61af66fc99e Initial load
duke
parents:
diff changeset
137 }
a61af66fc99e Initial load
duke
parents:
diff changeset
138 name[pos++] = 'L';
a61af66fc99e Initial load
duke
parents:
diff changeset
139 strncpy(name+pos, (char*)element_name->base(), element_len);
a61af66fc99e Initial load
duke
parents:
diff changeset
140 name[new_len-2] = ';';
a61af66fc99e Initial load
duke
parents:
diff changeset
141 name[new_len-1] = '\0';
a61af66fc99e Initial load
duke
parents:
diff changeset
142 }
a61af66fc99e Initial load
duke
parents:
diff changeset
143 return ciSymbol::make(name);
a61af66fc99e Initial load
duke
parents:
diff changeset
144 }
a61af66fc99e Initial load
duke
parents:
diff changeset
145
a61af66fc99e Initial load
duke
parents:
diff changeset
146 // ------------------------------------------------------------------
a61af66fc99e Initial load
duke
parents:
diff changeset
147 // ciObjArrayKlass::make_impl
a61af66fc99e Initial load
duke
parents:
diff changeset
148 //
a61af66fc99e Initial load
duke
parents:
diff changeset
149 // Implementation of make.
a61af66fc99e Initial load
duke
parents:
diff changeset
150 ciObjArrayKlass* ciObjArrayKlass::make_impl(ciKlass* element_klass) {
a61af66fc99e Initial load
duke
parents:
diff changeset
151
a61af66fc99e Initial load
duke
parents:
diff changeset
152 if (element_klass->is_loaded()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
153 EXCEPTION_CONTEXT;
a61af66fc99e Initial load
duke
parents:
diff changeset
154 // The element klass is loaded
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3785
diff changeset
155 Klass* array = element_klass->get_Klass()->array_klass(THREAD);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
156 if (HAS_PENDING_EXCEPTION) {
a61af66fc99e Initial load
duke
parents:
diff changeset
157 CLEAR_PENDING_EXCEPTION;
a61af66fc99e Initial load
duke
parents:
diff changeset
158 CURRENT_THREAD_ENV->record_out_of_memory_failure();
a61af66fc99e Initial load
duke
parents:
diff changeset
159 return ciEnv::unloaded_ciobjarrayklass();
a61af66fc99e Initial load
duke
parents:
diff changeset
160 }
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3785
diff changeset
161 return CURRENT_THREAD_ENV->get_obj_array_klass(array);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
162 }
a61af66fc99e Initial load
duke
parents:
diff changeset
163
a61af66fc99e Initial load
duke
parents:
diff changeset
164 // The array klass was unable to be made or the element klass was
a61af66fc99e Initial load
duke
parents:
diff changeset
165 // not loaded.
a61af66fc99e Initial load
duke
parents:
diff changeset
166 ciSymbol* array_name = construct_array_name(element_klass->name(), 1);
a61af66fc99e Initial load
duke
parents:
diff changeset
167 if (array_name == ciEnv::unloaded_cisymbol()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
168 return ciEnv::unloaded_ciobjarrayklass();
a61af66fc99e Initial load
duke
parents:
diff changeset
169 }
a61af66fc99e Initial load
duke
parents:
diff changeset
170 return
a61af66fc99e Initial load
duke
parents:
diff changeset
171 CURRENT_ENV->get_unloaded_klass(element_klass, array_name)
a61af66fc99e Initial load
duke
parents:
diff changeset
172 ->as_obj_array_klass();
a61af66fc99e Initial load
duke
parents:
diff changeset
173 }
a61af66fc99e Initial load
duke
parents:
diff changeset
174
a61af66fc99e Initial load
duke
parents:
diff changeset
175 // ------------------------------------------------------------------
a61af66fc99e Initial load
duke
parents:
diff changeset
176 // ciObjArrayKlass::make
a61af66fc99e Initial load
duke
parents:
diff changeset
177 //
a61af66fc99e Initial load
duke
parents:
diff changeset
178 // Make an array klass corresponding to the specified primitive type.
a61af66fc99e Initial load
duke
parents:
diff changeset
179 ciObjArrayKlass* ciObjArrayKlass::make(ciKlass* element_klass) {
a61af66fc99e Initial load
duke
parents:
diff changeset
180 GUARDED_VM_ENTRY(return make_impl(element_klass);)
a61af66fc99e Initial load
duke
parents:
diff changeset
181 }