diff --git a/src/hotspot/share/c1/c1_Canonicalizer.cpp b/src/hotspot/share/c1/c1_Canonicalizer.cpp index 15b21029b6808..f5a1d14e69431 100644 --- a/src/hotspot/share/c1/c1_Canonicalizer.cpp +++ b/src/hotspot/share/c1/c1_Canonicalizer.cpp @@ -536,17 +536,6 @@ void Canonicalizer::do_Intrinsic (Intrinsic* x) { } break; } - case vmIntrinsics::_isPrimitive : { - assert(x->number_of_arguments() == 1, "wrong type"); - - // Class.isPrimitive is known on constant classes: - InstanceConstant* c = x->argument_at(0)->type()->as_InstanceConstant(); - if (c != nullptr && !c->value()->is_null_object()) { - ciType* t = c->value()->java_mirror_type(); - set_constant(t->is_primitive_type()); - } - break; - } default: break; } diff --git a/src/hotspot/share/c1/c1_Compiler.cpp b/src/hotspot/share/c1/c1_Compiler.cpp index 7d2e6ee75d9ae..1e55b7006dd9a 100644 --- a/src/hotspot/share/c1/c1_Compiler.cpp +++ b/src/hotspot/share/c1/c1_Compiler.cpp @@ -155,7 +155,6 @@ bool Compiler::is_intrinsic_supported(vmIntrinsics::ID id) { case vmIntrinsics::_longBitsToDouble: case vmIntrinsics::_getClass: case vmIntrinsics::_isInstance: - case vmIntrinsics::_isPrimitive: case vmIntrinsics::_currentCarrierThread: case vmIntrinsics::_currentThread: case vmIntrinsics::_scopedValueCache: diff --git a/src/hotspot/share/c1/c1_LIRGenerator.cpp b/src/hotspot/share/c1/c1_LIRGenerator.cpp index 325b8d193ea2d..959e49749c5e5 100644 --- a/src/hotspot/share/c1/c1_LIRGenerator.cpp +++ b/src/hotspot/share/c1/c1_LIRGenerator.cpp @@ -1278,25 +1278,6 @@ void LIRGenerator::do_getClass(Intrinsic* x) { LIR_OprFact::address(new LIR_Address(temp, T_OBJECT)), result); } -// java.lang.Class::isPrimitive() -void LIRGenerator::do_isPrimitive(Intrinsic* x) { - assert(x->number_of_arguments() == 1, "wrong type"); - - LIRItem rcvr(x->argument_at(0), this); - rcvr.load_item(); - LIR_Opr temp = new_register(T_METADATA); - LIR_Opr result = rlock_result(x); - - CodeEmitInfo* info = nullptr; - if (x->needs_null_check()) { - info = state_for(x); - } - - __ move(new LIR_Address(rcvr.result(), java_lang_Class::klass_offset(), T_ADDRESS), temp, info); - __ cmp(lir_cond_notEqual, temp, LIR_OprFact::metadataConst(nullptr)); - __ cmove(lir_cond_notEqual, LIR_OprFact::intConst(0), LIR_OprFact::intConst(1), result, T_BOOLEAN); -} - void LIRGenerator::do_getObjectSize(Intrinsic* x) { assert(x->number_of_arguments() == 3, "wrong type"); LIR_Opr result_reg = rlock_result(x); @@ -2914,7 +2895,6 @@ void LIRGenerator::do_Intrinsic(Intrinsic* x) { case vmIntrinsics::_Object_init: do_RegisterFinalizer(x); break; case vmIntrinsics::_isInstance: do_isInstance(x); break; - case vmIntrinsics::_isPrimitive: do_isPrimitive(x); break; case vmIntrinsics::_getClass: do_getClass(x); break; case vmIntrinsics::_getObjectSize: do_getObjectSize(x); break; case vmIntrinsics::_currentCarrierThread: do_currentCarrierThread(x); break; diff --git a/src/hotspot/share/c1/c1_LIRGenerator.hpp b/src/hotspot/share/c1/c1_LIRGenerator.hpp index 18997e2dd1a72..73bd883a7468e 100644 --- a/src/hotspot/share/c1/c1_LIRGenerator.hpp +++ b/src/hotspot/share/c1/c1_LIRGenerator.hpp @@ -254,7 +254,6 @@ class LIRGenerator: public InstructionVisitor, public BlockClosure { void do_RegisterFinalizer(Intrinsic* x); void do_isInstance(Intrinsic* x); - void do_isPrimitive(Intrinsic* x); void do_getClass(Intrinsic* x); void do_getObjectSize(Intrinsic* x); void do_currentCarrierThread(Intrinsic* x); diff --git a/src/hotspot/share/classfile/javaClasses.cpp b/src/hotspot/share/classfile/javaClasses.cpp index d6d1f799253cc..a224ef481b025 100644 --- a/src/hotspot/share/classfile/javaClasses.cpp +++ b/src/hotspot/share/classfile/javaClasses.cpp @@ -868,6 +868,7 @@ int java_lang_Class::_classData_offset; int java_lang_Class::_classRedefinedCount_offset; int java_lang_Class::_reflectionData_offset; int java_lang_Class::_modifiers_offset; +int java_lang_Class::_is_primitive_offset; bool java_lang_Class::_offsets_computed = false; GrowableArray* java_lang_Class::_fixup_mirror_list = nullptr; @@ -1062,7 +1063,7 @@ void java_lang_Class::allocate_mirror(Klass* k, bool is_scratch, Handle protecti set_klass(mirror(), k); // Set the modifiers flag. - int computed_modifiers = k->compute_modifier_flags(); + u2 computed_modifiers = k->compute_modifier_flags(); set_modifiers(mirror(), computed_modifiers); InstanceMirrorKlass* mk = InstanceMirrorKlass::cast(mirror->klass()); @@ -1272,8 +1273,11 @@ void java_lang_Class::set_protection_domain(oop java_class, oop pd) { void java_lang_Class::set_component_mirror(oop java_class, oop comp_mirror) { assert(_component_mirror_offset != 0, "must be set"); - java_class->obj_field_put(_component_mirror_offset, comp_mirror); - } + assert(java_lang_Class::as_Klass(java_class) != nullptr && + java_lang_Class::as_Klass(java_class)->is_array_klass(), "must be"); + java_class->obj_field_put(_component_mirror_offset, comp_mirror); +} + oop java_lang_Class::component_mirror(oop java_class) { assert(_component_mirror_offset != 0, "must be set"); return java_class->obj_field(_component_mirror_offset); @@ -1347,9 +1351,14 @@ void java_lang_Class::set_source_file(oop java_class, oop source_file) { java_class->obj_field_put(_source_file_offset, source_file); } +void java_lang_Class::set_is_primitive(oop java_class) { + assert(_is_primitive_offset != 0, "must be set"); + java_class->bool_field_put(_is_primitive_offset, true); +} + + oop java_lang_Class::create_basic_type_mirror(const char* basic_type_name, BasicType type, TRAPS) { - // This should be improved by adding a field at the Java level or by - // introducing a new VM klass (see comment in ClassFileParser) + // Mirrors for basic types have a null klass field, which makes them special. oop java_class = InstanceMirrorKlass::cast(vmClasses::Class_klass())->allocate_instance(nullptr, CHECK_NULL); if (type != T_VOID) { Klass* aklass = Universe::typeArrayKlass(type); @@ -1361,6 +1370,7 @@ oop java_lang_Class::create_basic_type_mirror(const char* basic_type_name, Basic assert(static_oop_field_count(java_class) == 0, "should have been zeroed by allocation"); #endif set_modifiers(java_class, JVM_ACC_ABSTRACT | JVM_ACC_FINAL | JVM_ACC_PUBLIC); + set_is_primitive(java_class); return java_class; } @@ -1500,8 +1510,9 @@ oop java_lang_Class::primitive_mirror(BasicType t) { macro(_classData_offset, k, "classData", object_signature, false); \ macro(_reflectionData_offset, k, "reflectionData", java_lang_ref_SoftReference_signature, false); \ macro(_signers_offset, k, "signers", object_array_signature, false); \ - macro(_modifiers_offset, k, vmSymbols::modifiers_name(), int_signature, false); \ - macro(_protection_domain_offset, k, "protectionDomain", java_security_ProtectionDomain_signature, false); + macro(_modifiers_offset, k, vmSymbols::modifiers_name(), char_signature, false); \ + macro(_protection_domain_offset, k, "protectionDomain", java_security_ProtectionDomain_signature, false); \ + macro(_is_primitive_offset, k, "primitive", bool_signature, false); void java_lang_Class::compute_offsets() { if (_offsets_computed) { @@ -1537,12 +1548,12 @@ void java_lang_Class::set_classRedefinedCount(oop the_class_mirror, int value) { int java_lang_Class::modifiers(oop the_class_mirror) { assert(_modifiers_offset != 0, "offsets should have been initialized"); - return the_class_mirror->int_field(_modifiers_offset); + return the_class_mirror->char_field(_modifiers_offset); } -void java_lang_Class::set_modifiers(oop the_class_mirror, int value) { +void java_lang_Class::set_modifiers(oop the_class_mirror, u2 value) { assert(_modifiers_offset != 0, "offsets should have been initialized"); - the_class_mirror->int_field_put(_modifiers_offset, value); + the_class_mirror->char_field_put(_modifiers_offset, value); } diff --git a/src/hotspot/share/classfile/javaClasses.hpp b/src/hotspot/share/classfile/javaClasses.hpp index 43b358f6c4642..37ca22e92957b 100644 --- a/src/hotspot/share/classfile/javaClasses.hpp +++ b/src/hotspot/share/classfile/javaClasses.hpp @@ -257,6 +257,7 @@ class java_lang_Class : AllStatic { static int _classRedefinedCount_offset; static int _reflectionData_offset; static int _modifiers_offset; + static int _is_primitive_offset; static bool _offsets_computed; @@ -302,6 +303,7 @@ class java_lang_Class : AllStatic { static bool is_instance(oop obj); static bool is_primitive(oop java_class); + static void set_is_primitive(oop java_class); static BasicType primitive_type(oop java_class); static oop primitive_mirror(BasicType t); // JVM_NewArray support @@ -338,7 +340,7 @@ class java_lang_Class : AllStatic { static void set_source_file(oop java_class, oop source_file); static int modifiers(oop java_class); - static void set_modifiers(oop java_class, int value); + static void set_modifiers(oop java_class, u2 value); static size_t oop_size(oop java_class); static void set_oop_size(HeapWord* java_class, size_t size); diff --git a/src/hotspot/share/classfile/javaClasses.inline.hpp b/src/hotspot/share/classfile/javaClasses.inline.hpp index 6a698e02298bf..66ecca4bbeaa4 100644 --- a/src/hotspot/share/classfile/javaClasses.inline.hpp +++ b/src/hotspot/share/classfile/javaClasses.inline.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, 2024, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2025, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -293,11 +293,13 @@ inline Klass* java_lang_Class::as_Klass(oop java_class) { inline bool java_lang_Class::is_primitive(oop java_class) { // should assert: - //assert(java_lang_Class::is_instance(java_class), "must be a Class object"); + // assert(java_lang_Class::is_instance(java_class), "must be a Class object"); bool is_primitive = (java_class->metadata_field(_klass_offset) == nullptr); #ifdef ASSERT - if (is_primitive) { + // The heapwalker walks through Classes that have had their Klass pointers removed, so can't assert this. + // assert(is_primitive == java_class->bool_field(_is_primitive_offset), "must match what we told Java"); + if (java_class->bool_field(_is_primitive_offset)) { Klass* k = ((Klass*)java_class->metadata_field(_array_klass_offset)); assert(k == nullptr || is_java_primitive(ArrayKlass::cast(k)->element_type()), "Should be either the T_VOID primitive or a java primitive"); diff --git a/src/hotspot/share/classfile/vmIntrinsics.cpp b/src/hotspot/share/classfile/vmIntrinsics.cpp index aaeb54f0d32fe..2943f9d4af379 100644 --- a/src/hotspot/share/classfile/vmIntrinsics.cpp +++ b/src/hotspot/share/classfile/vmIntrinsics.cpp @@ -256,9 +256,6 @@ bool vmIntrinsics::disabled_by_jvm_flags(vmIntrinsics::ID id) { switch (id) { case vmIntrinsics::_isInstance: case vmIntrinsics::_isAssignableFrom: - case vmIntrinsics::_isInterface: - case vmIntrinsics::_isArray: - case vmIntrinsics::_isPrimitive: case vmIntrinsics::_isHidden: case vmIntrinsics::_getSuperclass: case vmIntrinsics::_Class_cast: diff --git a/src/hotspot/share/classfile/vmIntrinsics.hpp b/src/hotspot/share/classfile/vmIntrinsics.hpp index 16f6ff024d0c6..8262472481117 100644 --- a/src/hotspot/share/classfile/vmIntrinsics.hpp +++ b/src/hotspot/share/classfile/vmIntrinsics.hpp @@ -304,12 +304,6 @@ class methodHandle; do_name( isAssignableFrom_name, "isAssignableFrom") \ do_intrinsic(_isInstance, java_lang_Class, isInstance_name, object_boolean_signature, F_RN) \ do_name( isInstance_name, "isInstance") \ - do_intrinsic(_isInterface, java_lang_Class, isInterface_name, void_boolean_signature, F_RN) \ - do_name( isInterface_name, "isInterface") \ - do_intrinsic(_isArray, java_lang_Class, isArray_name, void_boolean_signature, F_RN) \ - do_name( isArray_name, "isArray") \ - do_intrinsic(_isPrimitive, java_lang_Class, isPrimitive_name, void_boolean_signature, F_RN) \ - do_name( isPrimitive_name, "isPrimitive") \ do_intrinsic(_isHidden, java_lang_Class, isHidden_name, void_boolean_signature, F_RN) \ do_name( isHidden_name, "isHidden") \ do_intrinsic(_getSuperclass, java_lang_Class, getSuperclass_name, void_class_signature, F_RN) \ diff --git a/src/hotspot/share/include/jvm.h b/src/hotspot/share/include/jvm.h index c2a1a3f53f6ca..c1d20387d0db9 100644 --- a/src/hotspot/share/include/jvm.h +++ b/src/hotspot/share/include/jvm.h @@ -546,21 +546,9 @@ JVM_GetClassInterfaces(JNIEnv *env, jclass cls); JNIEXPORT jboolean JNICALL JVM_IsInterface(JNIEnv *env, jclass cls); -JNIEXPORT jobject JNICALL -JVM_GetProtectionDomain(JNIEnv *env, jclass cls); - -JNIEXPORT jboolean JNICALL -JVM_IsArrayClass(JNIEnv *env, jclass cls); - -JNIEXPORT jboolean JNICALL -JVM_IsPrimitiveClass(JNIEnv *env, jclass cls); - JNIEXPORT jboolean JNICALL JVM_IsHiddenClass(JNIEnv *env, jclass cls); -JNIEXPORT jint JNICALL -JVM_GetClassModifiers(JNIEnv *env, jclass cls); - JNIEXPORT jobjectArray JNICALL JVM_GetDeclaredClasses(JNIEnv *env, jclass ofClass); diff --git a/src/hotspot/share/opto/c2compiler.cpp b/src/hotspot/share/opto/c2compiler.cpp index e126697ed05d3..0d0cb73d8470e 100644 --- a/src/hotspot/share/opto/c2compiler.cpp +++ b/src/hotspot/share/opto/c2compiler.cpp @@ -749,9 +749,6 @@ bool C2Compiler::is_intrinsic_supported(vmIntrinsics::ID id) { case vmIntrinsics::_clone: case vmIntrinsics::_isAssignableFrom: case vmIntrinsics::_isInstance: - case vmIntrinsics::_isInterface: - case vmIntrinsics::_isArray: - case vmIntrinsics::_isPrimitive: case vmIntrinsics::_isHidden: case vmIntrinsics::_getSuperclass: case vmIntrinsics::_getClassAccessFlags: diff --git a/src/hotspot/share/opto/library_call.cpp b/src/hotspot/share/opto/library_call.cpp index 1e503ca6bef0f..3b5fbde24a5c3 100644 --- a/src/hotspot/share/opto/library_call.cpp +++ b/src/hotspot/share/opto/library_call.cpp @@ -515,9 +515,6 @@ bool LibraryCallKit::try_to_inline(int predicate) { case vmIntrinsics::_isAssignableFrom: return inline_native_subtype_check(); case vmIntrinsics::_isInstance: - case vmIntrinsics::_isInterface: - case vmIntrinsics::_isArray: - case vmIntrinsics::_isPrimitive: case vmIntrinsics::_isHidden: case vmIntrinsics::_getSuperclass: case vmIntrinsics::_getClassAccessFlags: return inline_native_Class_query(intrinsic_id()); @@ -3890,17 +3887,6 @@ bool LibraryCallKit::inline_native_Class_query(vmIntrinsics::ID id) { prim_return_value = intcon(0); obj = argument(1); break; - case vmIntrinsics::_isInterface: - prim_return_value = intcon(0); - break; - case vmIntrinsics::_isArray: - prim_return_value = intcon(0); - expect_prim = true; // cf. ObjectStreamClass.getClassSignature - break; - case vmIntrinsics::_isPrimitive: - prim_return_value = intcon(1); - expect_prim = true; // obviously - break; case vmIntrinsics::_isHidden: prim_return_value = intcon(0); break; @@ -3969,28 +3955,6 @@ bool LibraryCallKit::inline_native_Class_query(vmIntrinsics::ID id) { query_value = gen_instanceof(obj, kls, safe_for_replace); break; - case vmIntrinsics::_isInterface: - // (To verify this code sequence, check the asserts in JVM_IsInterface.) - if (generate_interface_guard(kls, region) != nullptr) - // A guard was added. If the guard is taken, it was an interface. - phi->add_req(intcon(1)); - // If we fall through, it's a plain class. - query_value = intcon(0); - break; - - case vmIntrinsics::_isArray: - // (To verify this code sequence, check the asserts in JVM_IsArrayClass.) - if (generate_array_guard(kls, region) != nullptr) - // A guard was added. If the guard is taken, it was an array. - phi->add_req(intcon(1)); - // If we fall through, it's a plain class. - query_value = intcon(0); - break; - - case vmIntrinsics::_isPrimitive: - query_value = intcon(0); // "normal" path produces false - break; - case vmIntrinsics::_isHidden: // (To verify this code sequence, check the asserts in JVM_IsHiddenClass.) if (generate_hidden_class_guard(kls, region) != nullptr) diff --git a/src/hotspot/share/prims/jvm.cpp b/src/hotspot/share/prims/jvm.cpp index 33d82045b6eae..ccb15485b07e5 100644 --- a/src/hotspot/share/prims/jvm.cpp +++ b/src/hotspot/share/prims/jvm.cpp @@ -1187,20 +1187,6 @@ JVM_ENTRY(jobjectArray, JVM_GetClassInterfaces(JNIEnv *env, jclass cls)) JVM_END -JVM_ENTRY(jboolean, JVM_IsInterface(JNIEnv *env, jclass cls)) - oop mirror = JNIHandles::resolve_non_null(cls); - if (java_lang_Class::is_primitive(mirror)) { - return JNI_FALSE; - } - Klass* k = java_lang_Class::as_Klass(mirror); - jboolean result = k->is_interface(); - assert(!result || k->is_instance_klass(), - "all interfaces are instance types"); - // The compiler intrinsic for isInterface tests the - // Klass::_access_flags bits in the same way. - return result; -JVM_END - JVM_ENTRY(jboolean, JVM_IsHiddenClass(JNIEnv *env, jclass cls)) oop mirror = JNIHandles::resolve_non_null(cls); if (java_lang_Class::is_primitive(mirror)) { @@ -1259,18 +1245,6 @@ JVM_ENTRY(jobject, JVM_FindScopedValueBindings(JNIEnv *env, jclass cls)) return nullptr; JVM_END -JVM_ENTRY(jboolean, JVM_IsArrayClass(JNIEnv *env, jclass cls)) - Klass* k = java_lang_Class::as_Klass(JNIHandles::resolve_non_null(cls)); - return (k != nullptr) && k->is_array_klass() ? true : false; -JVM_END - - -JVM_ENTRY(jboolean, JVM_IsPrimitiveClass(JNIEnv *env, jclass cls)) - oop mirror = JNIHandles::resolve_non_null(cls); - return (jboolean) java_lang_Class::is_primitive(mirror); -JVM_END - - JVM_ENTRY(jobjectArray, JVM_GetDeclaredClasses(JNIEnv *env, jclass ofClass)) JvmtiVMObjectAllocEventCollector oam; // ofClass is a reference to a java_lang_Class object. The mirror object @@ -2305,7 +2279,23 @@ JVM_END // The function returns a Klass* of the _scratch_class if the verifier // was invoked in the middle of the class redefinition. // Otherwise it returns its argument value which is the _the_class Klass*. -// Please, refer to the description in the jvmtiThreadSate.hpp. +// Please, refer to the description in the jvmtiThreadState.hpp. + +JVM_ENTRY(jboolean, JVM_IsInterface(JNIEnv *env, jclass cls)) + oop mirror = JNIHandles::resolve_non_null(cls); + if (java_lang_Class::is_primitive(mirror)) { + return JNI_FALSE; + } + Klass* k = java_lang_Class::as_Klass(mirror); + // This isn't necessary since answer is the same since redefinition + // has already checked this matches for the scratch class. + // k = JvmtiThreadState::class_to_verify_considering_redefinition(k, thread); + jboolean result = k->is_interface(); + assert(!result || k->is_instance_klass(), + "all interfaces are instance types"); + return result; +JVM_END + JVM_ENTRY(const char*, JVM_GetClassNameUTF(JNIEnv *env, jclass cls)) Klass* k = java_lang_Class::as_Klass(JNIHandles::resolve_non_null(cls)); diff --git a/src/java.base/share/classes/java/lang/Class.java b/src/java.base/share/classes/java/lang/Class.java index 4607858faa8c5..d86baaac3621a 100644 --- a/src/java.base/share/classes/java/lang/Class.java +++ b/src/java.base/share/classes/java/lang/Class.java @@ -236,13 +236,15 @@ private static void runtimeSetup() { * This constructor is not used and prevents the default constructor being * generated. */ - private Class(ClassLoader loader, Class arrayComponentType, int mods, ProtectionDomain pd) { + private Class(ClassLoader loader, Class arrayComponentType, char mods, ProtectionDomain pd, boolean isPrim) { // Initialize final field for classLoader. The initialization value of non-null // prevents future JIT optimizations from assuming this final field is null. + // The following assignments are done directly by the VM without calling this constructor. classLoader = loader; componentType = arrayComponentType; modifiers = mods; protectionDomain = pd; + primitive = isPrim; } /** @@ -790,8 +792,9 @@ public T newInstance() * @return {@code true} if this {@code Class} object represents an interface; * {@code false} otherwise. */ - @IntrinsicCandidate - public native boolean isInterface(); + public boolean isInterface() { + return Modifier.isInterface(modifiers); + } /** @@ -801,8 +804,9 @@ public T newInstance() * {@code false} otherwise. * @since 1.1 */ - @IntrinsicCandidate - public native boolean isArray(); + public boolean isArray() { + return componentType != null; + } /** @@ -843,8 +847,9 @@ public T newInstance() * @since 1.1 * @jls 15.8.2 Class Literals */ - @IntrinsicCandidate - public native boolean isPrimitive(); + public boolean isPrimitive() { + return primitive; + } /** * Returns true if this {@code Class} object represents an annotation @@ -1002,7 +1007,8 @@ public Module getModule() { private transient Object classData; // Set by VM private transient Object[] signers; // Read by VM, mutable - private final transient int modifiers; // Set by the VM + private final transient char modifiers; // Set by the VM + private final transient boolean primitive; // Set by the VM if the Class is a primitive type. // package-private Object getClassData() { @@ -1284,15 +1290,12 @@ public Type[] getGenericInterfaces() { * @since 1.1 */ public Class getComponentType() { - // Only return for array types. Storage may be reused for Class for instance types. - if (isArray()) { - return componentType; - } else { - return null; - } + return componentType; } - private final Class componentType; + // The componentType field's null value is the sole indication that the class + // is an array - see isArray(). + private transient final Class componentType; /* * Returns the {@code Class} representing the element type of an array class. diff --git a/src/java.base/share/classes/jdk/internal/reflect/Reflection.java b/src/java.base/share/classes/jdk/internal/reflect/Reflection.java index e1fe26684c82f..5025b81dd10ed 100644 --- a/src/java.base/share/classes/jdk/internal/reflect/Reflection.java +++ b/src/java.base/share/classes/jdk/internal/reflect/Reflection.java @@ -56,7 +56,7 @@ public class Reflection { fieldFilterMap = Map.of( Reflection.class, ALL_MEMBERS, AccessibleObject.class, ALL_MEMBERS, - Class.class, Set.of("classLoader", "classData", "modifiers", "protectionDomain"), + Class.class, Set.of("classLoader", "classData", "modifiers", "protectionDomain", "primitive"), ClassLoader.class, ALL_MEMBERS, Constructor.class, ALL_MEMBERS, Field.class, ALL_MEMBERS, diff --git a/src/java.base/share/native/libjava/Class.c b/src/java.base/share/native/libjava/Class.c index 47eedaa59d95f..3ab3e764bff8d 100644 --- a/src/java.base/share/native/libjava/Class.c +++ b/src/java.base/share/native/libjava/Class.c @@ -56,10 +56,7 @@ static JNINativeMethod methods[] = { {"initClassName", "()" STR, (void *)&JVM_InitClassName}, {"getSuperclass", "()" CLS, NULL}, {"getInterfaces0", "()[" CLS, (void *)&JVM_GetClassInterfaces}, - {"isInterface", "()Z", (void *)&JVM_IsInterface}, - {"isArray", "()Z", (void *)&JVM_IsArrayClass}, {"isHidden", "()Z", (void *)&JVM_IsHiddenClass}, - {"isPrimitive", "()Z", (void *)&JVM_IsPrimitiveClass}, {"getDeclaredFields0","(Z)[" FLD, (void *)&JVM_GetClassDeclaredFields}, {"getDeclaredMethods0","(Z)[" MHD, (void *)&JVM_GetClassDeclaredMethods}, {"getDeclaredConstructors0","(Z)[" CTR, (void *)&JVM_GetClassDeclaredConstructors}, diff --git a/test/hotspot/jtreg/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestResolvedJavaType.java b/test/hotspot/jtreg/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestResolvedJavaType.java index 6450f9e1e2968..52b52cf647fce 100644 --- a/test/hotspot/jtreg/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestResolvedJavaType.java +++ b/test/hotspot/jtreg/compiler/jvmci/jdk.vm.ci.runtime.test/src/jdk/vm/ci/runtime/test/TestResolvedJavaType.java @@ -929,10 +929,12 @@ private static boolean isHiddenFromReflection(ResolvedJavaField f) { return true; } if (f.getDeclaringClass().equals(metaAccess.lookupJavaType(Class.class))) { - return f.getName().equals("classLoader") || - f.getName().equals("classData") || - f.getName().equals("modifiers") || - f.getName().equals("protectionDomain"); + String name = f.getName(); + return name.equals("classLoader") || + name.equals("classData") || + name.equals("modifiers") || + name.equals("protectionDomain") || + name.equals("primitive"); } if (f.getDeclaringClass().equals(metaAccess.lookupJavaType(Lookup.class))) { return f.getName().equals("allowedModes") || f.getName().equals("lookupClass"); diff --git a/test/jdk/java/lang/reflect/AccessibleObject/ModuleSetAccessibleTest.java b/test/jdk/java/lang/reflect/AccessibleObject/ModuleSetAccessibleTest.java index 08db3265c94a1..8ee5179ea818e 100644 --- a/test/jdk/java/lang/reflect/AccessibleObject/ModuleSetAccessibleTest.java +++ b/test/jdk/java/lang/reflect/AccessibleObject/ModuleSetAccessibleTest.java @@ -148,7 +148,7 @@ public void testJavaLangClass() throws Exception { // non-public constructor Constructor ctor - = Class.class.getDeclaredConstructor(ClassLoader.class, Class.class, int.class, ProtectionDomain.class); + = Class.class.getDeclaredConstructor(ClassLoader.class, Class.class, char.class, ProtectionDomain.class, boolean.class); AccessibleObject[] ctors = { ctor }; try { diff --git a/test/jdk/java/lang/reflect/AccessibleObject/TrySetAccessibleTest.java b/test/jdk/java/lang/reflect/AccessibleObject/TrySetAccessibleTest.java index d08798c8757b3..9574afee40729 100644 --- a/test/jdk/java/lang/reflect/AccessibleObject/TrySetAccessibleTest.java +++ b/test/jdk/java/lang/reflect/AccessibleObject/TrySetAccessibleTest.java @@ -194,7 +194,7 @@ public void testJavaLangClass() throws Exception { // non-public constructor Constructor ctor - = Class.class.getDeclaredConstructor(ClassLoader.class, Class.class, int.class, ProtectionDomain.class); + = Class.class.getDeclaredConstructor(ClassLoader.class, Class.class, char.class, ProtectionDomain.class, boolean.class); AccessibleObject[] ctors = { ctor }; assertFalse(ctor.trySetAccessible()); diff --git a/test/jdk/jdk/internal/reflect/Reflection/Filtering.java b/test/jdk/jdk/internal/reflect/Reflection/Filtering.java index c399b8ff42da3..88d7e23ba5962 100644 --- a/test/jdk/jdk/internal/reflect/Reflection/Filtering.java +++ b/test/jdk/jdk/internal/reflect/Reflection/Filtering.java @@ -57,6 +57,7 @@ private Object[][] sensitiveFields() { { Class.class, "classData" }, { Class.class, "modifiers" }, { Class.class, "protectionDomain" }, + { Class.class, "primitive" }, { ClassLoader.class, "parent" }, { Field.class, "clazz" }, { Field.class, "modifiers" },