Mercurial > hg > truffle
comparison src/share/vm/memory/oopFactory.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 | 8150fa46d2ed |
children | d8ce2825b193 |
comparison
equal
deleted
inserted
replaced
6724:36d1d483d5d6 | 6725:da91efe96a93 |
---|---|
29 #include "classfile/vmSymbols.hpp" | 29 #include "classfile/vmSymbols.hpp" |
30 #include "gc_interface/collectedHeap.inline.hpp" | 30 #include "gc_interface/collectedHeap.inline.hpp" |
31 #include "memory/oopFactory.hpp" | 31 #include "memory/oopFactory.hpp" |
32 #include "memory/resourceArea.hpp" | 32 #include "memory/resourceArea.hpp" |
33 #include "memory/universe.inline.hpp" | 33 #include "memory/universe.inline.hpp" |
34 #include "oops/compiledICHolderKlass.hpp" | |
35 #include "oops/constMethodKlass.hpp" | |
36 #include "oops/constantPoolKlass.hpp" | |
37 #include "oops/cpCacheKlass.hpp" | |
38 #include "oops/instanceKlass.hpp" | 34 #include "oops/instanceKlass.hpp" |
39 #include "oops/instanceKlassKlass.hpp" | |
40 #include "oops/instanceOop.hpp" | 35 #include "oops/instanceOop.hpp" |
41 #include "oops/klassKlass.hpp" | |
42 #include "oops/klassOop.hpp" | |
43 #include "oops/methodDataKlass.hpp" | |
44 #include "oops/methodKlass.hpp" | |
45 #include "oops/objArrayOop.hpp" | 36 #include "oops/objArrayOop.hpp" |
46 #include "oops/oop.inline.hpp" | 37 #include "oops/oop.inline.hpp" |
47 | 38 |
48 | 39 |
49 typeArrayOop oopFactory::new_charArray(const char* utf8_str, TRAPS) { | 40 typeArrayOop oopFactory::new_charArray(const char* utf8_str, TRAPS) { |
53 UTF8::convert_to_unicode(utf8_str, result->char_at_addr(0), length); | 44 UTF8::convert_to_unicode(utf8_str, result->char_at_addr(0), length); |
54 } | 45 } |
55 return result; | 46 return result; |
56 } | 47 } |
57 | 48 |
58 typeArrayOop oopFactory::new_permanent_charArray(int length, TRAPS) { | 49 typeArrayOop oopFactory::new_tenured_charArray(int length, TRAPS) { |
59 return typeArrayKlass::cast(Universe::charArrayKlassObj())->allocate_permanent(length, THREAD); | 50 return typeArrayKlass::cast(Universe::charArrayKlassObj())->allocate(length, THREAD); |
60 } | 51 } |
61 | 52 |
62 typeArrayOop oopFactory::new_permanent_byteArray(int length, TRAPS) { | 53 typeArrayOop oopFactory::new_typeArray(BasicType type, int length, TRAPS) { |
63 return typeArrayKlass::cast(Universe::byteArrayKlassObj())->allocate_permanent(length, THREAD); | 54 Klass* type_asKlassOop = Universe::typeArrayKlassObj(type); |
55 typeArrayKlass* type_asArrayKlass = typeArrayKlass::cast(type_asKlassOop); | |
56 typeArrayOop result = type_asArrayKlass->allocate(length, THREAD); | |
57 return result; | |
64 } | 58 } |
65 | 59 |
66 | 60 // Create a Java array that points to metadata. |
67 typeArrayOop oopFactory::new_permanent_shortArray(int length, TRAPS) { | 61 // As far as Java code is concerned, a metaData array is either an array of |
68 return typeArrayKlass::cast(Universe::shortArrayKlassObj())->allocate_permanent(length, THREAD); | 62 // int or long depending on pointer size. Only a few things use this, like |
69 } | 63 // stack trace elements in Throwable. They cast Method* into this type. |
70 | 64 // Note:can't point to symbols because there's no way to unreference count |
71 | 65 // them when this object goes away. |
72 typeArrayOop oopFactory::new_permanent_intArray(int length, TRAPS) { | 66 typeArrayOop oopFactory::new_metaDataArray(int length, TRAPS) { |
73 return typeArrayKlass::cast(Universe::intArrayKlassObj())->allocate_permanent(length, THREAD); | 67 BasicType type = LP64_ONLY(T_LONG) NOT_LP64(T_INT); |
74 } | 68 Klass* type_asKlassOop = Universe::typeArrayKlassObj(type); |
75 | |
76 | |
77 typeArrayOop oopFactory::new_typeArray(BasicType type, int length, TRAPS) { | |
78 klassOop type_asKlassOop = Universe::typeArrayKlassObj(type); | |
79 typeArrayKlass* type_asArrayKlass = typeArrayKlass::cast(type_asKlassOop); | 69 typeArrayKlass* type_asArrayKlass = typeArrayKlass::cast(type_asKlassOop); |
80 typeArrayOop result = type_asArrayKlass->allocate_common(length, true, THREAD); | 70 typeArrayOop result = type_asArrayKlass->allocate_common(length, true, THREAD); |
81 return result; | 71 return result; |
82 } | 72 } |
83 | 73 |
84 typeArrayOop oopFactory::new_typeArray_nozero(BasicType type, int length, TRAPS) { | 74 typeArrayOop oopFactory::new_typeArray_nozero(BasicType type, int length, TRAPS) { |
85 klassOop type_asKlassOop = Universe::typeArrayKlassObj(type); | 75 Klass* type_asKlassOop = Universe::typeArrayKlassObj(type); |
86 typeArrayKlass* type_asArrayKlass = typeArrayKlass::cast(type_asKlassOop); | 76 typeArrayKlass* type_asArrayKlass = typeArrayKlass::cast(type_asKlassOop); |
87 typeArrayOop result = type_asArrayKlass->allocate_common(length, false, THREAD); | 77 typeArrayOop result = type_asArrayKlass->allocate_common(length, false, THREAD); |
88 return result; | 78 return result; |
89 } | 79 } |
90 | 80 |
91 | 81 |
92 objArrayOop oopFactory::new_objArray(klassOop klass, int length, TRAPS) { | 82 objArrayOop oopFactory::new_objArray(Klass* klass, int length, TRAPS) { |
93 assert(klass->is_klass(), "must be instance class"); | 83 assert(klass->is_klass(), "must be instance class"); |
94 if (klass->klass_part()->oop_is_array()) { | 84 if (klass->oop_is_array()) { |
95 return ((arrayKlass*)klass->klass_part())->allocate_arrayArray(1, length, THREAD); | 85 return ((arrayKlass*)klass)->allocate_arrayArray(1, length, THREAD); |
96 } else { | 86 } else { |
97 assert (klass->klass_part()->oop_is_instance(), "new object array with klass not an instanceKlass"); | 87 assert (klass->oop_is_instance(), "new object array with klass not an InstanceKlass"); |
98 return ((instanceKlass*)klass->klass_part())->allocate_objArray(1, length, THREAD); | 88 return ((InstanceKlass*)klass)->allocate_objArray(1, length, THREAD); |
99 } | 89 } |
100 } | 90 } |
101 | |
102 objArrayOop oopFactory::new_system_objArray(int length, TRAPS) { | |
103 int size = objArrayOopDesc::object_size(length); | |
104 KlassHandle klass (THREAD, Universe::systemObjArrayKlassObj()); | |
105 objArrayOop o = (objArrayOop) | |
106 Universe::heap()->permanent_array_allocate(klass, size, length, CHECK_NULL); | |
107 // initialization not needed, allocated cleared | |
108 return o; | |
109 } | |
110 | |
111 | |
112 constantPoolOop oopFactory::new_constantPool(int length, | |
113 bool is_conc_safe, | |
114 TRAPS) { | |
115 constantPoolKlass* ck = constantPoolKlass::cast(Universe::constantPoolKlassObj()); | |
116 return ck->allocate(length, is_conc_safe, CHECK_NULL); | |
117 } | |
118 | |
119 | |
120 constantPoolCacheOop oopFactory::new_constantPoolCache(int length, | |
121 TRAPS) { | |
122 constantPoolCacheKlass* ck = constantPoolCacheKlass::cast(Universe::constantPoolCacheKlassObj()); | |
123 return ck->allocate(length, CHECK_NULL); | |
124 } | |
125 | |
126 | |
127 klassOop oopFactory::new_instanceKlass(Symbol* name, int vtable_len, int itable_len, | |
128 int static_field_size, | |
129 unsigned int nonstatic_oop_map_count, | |
130 AccessFlags access_flags, | |
131 ReferenceType rt, | |
132 KlassHandle host_klass, TRAPS) { | |
133 instanceKlassKlass* ikk = instanceKlassKlass::cast(Universe::instanceKlassKlassObj()); | |
134 return ikk->allocate_instance_klass(name, vtable_len, itable_len, | |
135 static_field_size, nonstatic_oop_map_count, | |
136 access_flags, rt, host_klass, CHECK_NULL); | |
137 } | |
138 | |
139 | |
140 constMethodOop oopFactory::new_constMethod(int byte_code_size, | |
141 int compressed_line_number_size, | |
142 int localvariable_table_length, | |
143 int exception_table_length, | |
144 int checked_exceptions_length, | |
145 bool is_conc_safe, | |
146 TRAPS) { | |
147 klassOop cmkObj = Universe::constMethodKlassObj(); | |
148 constMethodKlass* cmk = constMethodKlass::cast(cmkObj); | |
149 return cmk->allocate(byte_code_size, compressed_line_number_size, | |
150 localvariable_table_length, exception_table_length, | |
151 checked_exceptions_length, is_conc_safe, | |
152 CHECK_NULL); | |
153 } | |
154 | |
155 | |
156 methodOop oopFactory::new_method(int byte_code_size, AccessFlags access_flags, | |
157 int compressed_line_number_size, | |
158 int localvariable_table_length, | |
159 int exception_table_length, | |
160 int checked_exceptions_length, | |
161 bool is_conc_safe, | |
162 TRAPS) { | |
163 methodKlass* mk = methodKlass::cast(Universe::methodKlassObj()); | |
164 assert(!access_flags.is_native() || byte_code_size == 0, | |
165 "native methods should not contain byte codes"); | |
166 constMethodOop cm = new_constMethod(byte_code_size, | |
167 compressed_line_number_size, | |
168 localvariable_table_length, | |
169 exception_table_length, | |
170 checked_exceptions_length, | |
171 is_conc_safe, CHECK_NULL); | |
172 constMethodHandle rw(THREAD, cm); | |
173 return mk->allocate(rw, access_flags, CHECK_NULL); | |
174 } | |
175 | |
176 | |
177 methodDataOop oopFactory::new_methodData(methodHandle method, TRAPS) { | |
178 methodDataKlass* mdk = methodDataKlass::cast(Universe::methodDataKlassObj()); | |
179 return mdk->allocate(method, CHECK_NULL); | |
180 } | |
181 | |
182 | |
183 compiledICHolderOop oopFactory::new_compiledICHolder(methodHandle method, KlassHandle klass, TRAPS) { | |
184 compiledICHolderKlass* ck = (compiledICHolderKlass*) Universe::compiledICHolderKlassObj()->klass_part(); | |
185 compiledICHolderOop c = ck->allocate(CHECK_NULL); | |
186 c->set_holder_method(method()); | |
187 c->set_holder_klass(klass()); | |
188 return c; | |
189 } |