1065 // Statically allocate fixup lists because they always get created.
1066 void java_lang_Class::allocate_fixup_lists() {
1067 if (!CDSConfig::is_using_aot_linked_classes()) {
1068 // fixup_mirror_list() is not used when we have preloaded classes. See
1069 // Universe::fixup_mirrors().
1070 GrowableArray<Klass*>* mirror_list =
1071 new (mtClass) GrowableArray<Klass*>(40, mtClass);
1072 set_fixup_mirror_list(mirror_list);
1073
1074 // With AOT-linked classes, java.base module is defined before any class
1075 // is loaded, so there's no need for fixup_module_field_list().
1076 GrowableArray<Klass*>* module_list =
1077 new (mtModule) GrowableArray<Klass*>(500, mtModule);
1078 set_fixup_module_field_list(module_list);
1079 }
1080 }
1081
1082 void java_lang_Class::allocate_mirror(Klass* k, bool is_scratch, Handle protection_domain, Handle classData,
1083 Handle& mirror, Handle& comp_mirror, TRAPS) {
1084 // Allocate mirror (java.lang.Class instance)
1085 oop mirror_oop = InstanceMirrorKlass::cast(vmClasses::Class_klass())->allocate_instance(k, CHECK);
1086 mirror = Handle(THREAD, mirror_oop);
1087
1088 // Setup indirection from mirror->klass
1089 set_klass(mirror(), k);
1090
1091 // Set the modifiers flag.
1092 u2 computed_modifiers = k->compute_modifier_flags();
1093 set_modifiers(mirror(), computed_modifiers);
1094
1095 InstanceMirrorKlass* mk = InstanceMirrorKlass::cast(mirror->klass());
1096 assert(oop_size(mirror()) == mk->instance_size(k), "should have been set");
1097
1098 set_static_oop_field_count(mirror(), mk->compute_static_oop_field_count(mirror()));
1099
1100 // It might also have a component mirror. This mirror must already exist.
1101 if (k->is_array_klass()) {
1102 // The Java code for array classes gets the access flags from the element type.
1103 set_raw_access_flags(mirror(), 0);
1104 if (k->is_typeArray_klass()) {
1105 BasicType type = TypeArrayKlass::cast(k)->element_type();
1366 }
1367 return o;
1368 }
1369
1370 oop java_lang_Class::source_file(oop java_class) {
1371 assert(_source_file_offset != 0, "must be set");
1372 return java_class->obj_field(_source_file_offset);
1373 }
1374
1375 void java_lang_Class::set_source_file(oop java_class, oop source_file) {
1376 assert(_source_file_offset != 0, "must be set");
1377 java_class->obj_field_put(_source_file_offset, source_file);
1378 }
1379
1380 void java_lang_Class::set_is_primitive(oop java_class) {
1381 assert(_is_primitive_offset != 0, "must be set");
1382 java_class->bool_field_put(_is_primitive_offset, true);
1383 }
1384
1385
1386 oop java_lang_Class::create_basic_type_mirror(const char* basic_type_name, BasicType type, TRAPS) {
1387 // Mirrors for basic types have a null klass field, which makes them special.
1388 oop java_class = InstanceMirrorKlass::cast(vmClasses::Class_klass())->allocate_instance(nullptr, CHECK_NULL);
1389 if (type != T_VOID) {
1390 Klass* aklass = Universe::typeArrayKlass(type);
1391 assert(aklass != nullptr, "correct bootstrap");
1392 release_set_array_klass(java_class, aklass);
1393 }
1394 #ifdef ASSERT
1395 InstanceMirrorKlass* mk = InstanceMirrorKlass::cast(vmClasses::Class_klass());
1396 assert(static_oop_field_count(java_class) == 0, "should have been zeroed by allocation");
1397 #endif
1398 set_modifiers(java_class, JVM_ACC_ABSTRACT | JVM_ACC_FINAL | JVM_ACC_PUBLIC);
1399 set_raw_access_flags(java_class, JVM_ACC_ABSTRACT | JVM_ACC_FINAL | JVM_ACC_PUBLIC);
1400
1401 set_is_primitive(java_class);
1402 return java_class;
1403 }
1404
1405 void java_lang_Class::set_klass(oop java_class, Klass* klass) {
1406 assert(is_instance(java_class), "must be a Class object");
1407 java_class->metadata_field_put(_klass_offset, klass);
1408 }
|
1065 // Statically allocate fixup lists because they always get created.
1066 void java_lang_Class::allocate_fixup_lists() {
1067 if (!CDSConfig::is_using_aot_linked_classes()) {
1068 // fixup_mirror_list() is not used when we have preloaded classes. See
1069 // Universe::fixup_mirrors().
1070 GrowableArray<Klass*>* mirror_list =
1071 new (mtClass) GrowableArray<Klass*>(40, mtClass);
1072 set_fixup_mirror_list(mirror_list);
1073
1074 // With AOT-linked classes, java.base module is defined before any class
1075 // is loaded, so there's no need for fixup_module_field_list().
1076 GrowableArray<Klass*>* module_list =
1077 new (mtModule) GrowableArray<Klass*>(500, mtModule);
1078 set_fixup_module_field_list(module_list);
1079 }
1080 }
1081
1082 void java_lang_Class::allocate_mirror(Klass* k, bool is_scratch, Handle protection_domain, Handle classData,
1083 Handle& mirror, Handle& comp_mirror, TRAPS) {
1084 // Allocate mirror (java.lang.Class instance)
1085 oop mirror_oop = InstanceMirrorKlass::cast(vmClasses::Class_klass())->allocate_instance(k, is_scratch, CHECK);
1086 mirror = Handle(THREAD, mirror_oop);
1087
1088 // Setup indirection from mirror->klass
1089 set_klass(mirror(), k);
1090
1091 // Set the modifiers flag.
1092 u2 computed_modifiers = k->compute_modifier_flags();
1093 set_modifiers(mirror(), computed_modifiers);
1094
1095 InstanceMirrorKlass* mk = InstanceMirrorKlass::cast(mirror->klass());
1096 assert(oop_size(mirror()) == mk->instance_size(k), "should have been set");
1097
1098 set_static_oop_field_count(mirror(), mk->compute_static_oop_field_count(mirror()));
1099
1100 // It might also have a component mirror. This mirror must already exist.
1101 if (k->is_array_klass()) {
1102 // The Java code for array classes gets the access flags from the element type.
1103 set_raw_access_flags(mirror(), 0);
1104 if (k->is_typeArray_klass()) {
1105 BasicType type = TypeArrayKlass::cast(k)->element_type();
1366 }
1367 return o;
1368 }
1369
1370 oop java_lang_Class::source_file(oop java_class) {
1371 assert(_source_file_offset != 0, "must be set");
1372 return java_class->obj_field(_source_file_offset);
1373 }
1374
1375 void java_lang_Class::set_source_file(oop java_class, oop source_file) {
1376 assert(_source_file_offset != 0, "must be set");
1377 java_class->obj_field_put(_source_file_offset, source_file);
1378 }
1379
1380 void java_lang_Class::set_is_primitive(oop java_class) {
1381 assert(_is_primitive_offset != 0, "must be set");
1382 java_class->bool_field_put(_is_primitive_offset, true);
1383 }
1384
1385
1386 oop java_lang_Class::create_basic_type_mirror(const char* basic_type_name, BasicType type, bool is_scratch, TRAPS) {
1387 // Mirrors for basic types have a null klass field, which makes them special.
1388 oop java_class = InstanceMirrorKlass::cast(vmClasses::Class_klass())->allocate_instance(nullptr, is_scratch, CHECK_NULL);
1389 if (type != T_VOID) {
1390 Klass* aklass = Universe::typeArrayKlass(type);
1391 assert(aklass != nullptr, "correct bootstrap");
1392 release_set_array_klass(java_class, aklass);
1393 }
1394 #ifdef ASSERT
1395 InstanceMirrorKlass* mk = InstanceMirrorKlass::cast(vmClasses::Class_klass());
1396 assert(static_oop_field_count(java_class) == 0, "should have been zeroed by allocation");
1397 #endif
1398 set_modifiers(java_class, JVM_ACC_ABSTRACT | JVM_ACC_FINAL | JVM_ACC_PUBLIC);
1399 set_raw_access_flags(java_class, JVM_ACC_ABSTRACT | JVM_ACC_FINAL | JVM_ACC_PUBLIC);
1400
1401 set_is_primitive(java_class);
1402 return java_class;
1403 }
1404
1405 void java_lang_Class::set_klass(oop java_class, Klass* klass) {
1406 assert(is_instance(java_class), "must be a Class object");
1407 java_class->metadata_field_put(_klass_offset, klass);
1408 }
|