From 5179fc3488b5c183c778be7e2210bfaa9f1b0af1 Mon Sep 17 00:00:00 2001 From: Coleen Phillimore Date: Mon, 26 Oct 2015 13:11:36 -0400 Subject: [PATCH] 8139163: InstanceKlass::cast passes through NULL Reduce raw (InstanceKlass*) casts and InstanceKlass::cast, which no long allows null Reviewed-by: twisti, kbarrett --- .../cpu/aarch64/vm/methodHandles_aarch64.cpp | 2 +- hotspot/src/cpu/ppc/vm/methodHandles_ppc.cpp | 2 +- .../src/cpu/sparc/vm/methodHandles_sparc.cpp | 2 +- hotspot/src/cpu/x86/vm/methodHandles_x86.cpp | 2 +- hotspot/src/share/vm/ci/ciInstanceKlass.hpp | 4 +- hotspot/src/share/vm/ci/ciMethod.cpp | 2 +- hotspot/src/share/vm/ci/ciReplay.cpp | 8 +-- .../share/vm/classfile/bytecodeAssembler.hpp | 4 +- .../share/vm/classfile/classFileParser.cpp | 15 ++-- hotspot/src/share/vm/classfile/dictionary.cpp | 16 ++--- hotspot/src/share/vm/classfile/dictionary.hpp | 3 +- .../src/share/vm/classfile/javaClasses.cpp | 48 ++++++------- .../share/vm/classfile/systemDictionary.cpp | 21 +++--- .../share/vm/classfile/systemDictionary.hpp | 26 +++---- hotspot/src/share/vm/classfile/verifier.cpp | 2 +- hotspot/src/share/vm/code/dependencies.cpp | 12 ++-- hotspot/src/share/vm/code/nmethod.cpp | 2 +- .../src/share/vm/gc/g1/g1CollectedHeap.cpp | 3 +- hotspot/src/share/vm/gc/g1/heapRegion.cpp | 2 +- .../vm/interpreter/bytecodeInterpreter.cpp | 9 +-- .../src/share/vm/interpreter/linkResolver.cpp | 18 ++--- hotspot/src/share/vm/jvmci/jvmciCompiler.cpp | 4 +- .../src/share/vm/jvmci/jvmciJavaClasses.hpp | 2 +- .../src/share/vm/memory/heapInspection.cpp | 3 +- .../src/share/vm/memory/metaspaceShared.cpp | 2 +- hotspot/src/share/vm/memory/oopFactory.cpp | 5 +- hotspot/src/share/vm/memory/universe.cpp | 25 ++++--- hotspot/src/share/vm/oops/constantPool.cpp | 4 +- hotspot/src/share/vm/oops/instanceKlass.cpp | 54 ++++++-------- hotspot/src/share/vm/oops/instanceKlass.hpp | 5 +- hotspot/src/share/vm/oops/klass.cpp | 14 ++-- hotspot/src/share/vm/oops/klass.hpp | 4 +- hotspot/src/share/vm/oops/klassVtable.cpp | 23 +++--- hotspot/src/share/vm/oops/method.cpp | 5 +- hotspot/src/share/vm/prims/jvm.cpp | 2 +- .../share/vm/prims/jvmtiRedefineClasses.cpp | 4 +- hotspot/src/share/vm/prims/jvmtiTagMap.cpp | 2 +- hotspot/src/share/vm/runtime/reflection.cpp | 6 +- hotspot/src/share/vm/runtime/thread.cpp | 6 +- hotspot/src/share/vm/runtime/vmStructs.cpp | 72 +++++++++---------- hotspot/src/share/vm/services/heapDumper.cpp | 8 +-- .../src/share/vm/services/threadService.cpp | 12 ++-- hotspot/src/share/vm/utilities/exceptions.cpp | 2 +- 43 files changed, 215 insertions(+), 252 deletions(-) diff --git a/hotspot/src/cpu/aarch64/vm/methodHandles_aarch64.cpp b/hotspot/src/cpu/aarch64/vm/methodHandles_aarch64.cpp index ba8c3cc31b9..dedabb6729b 100644 --- a/hotspot/src/cpu/aarch64/vm/methodHandles_aarch64.cpp +++ b/hotspot/src/cpu/aarch64/vm/methodHandles_aarch64.cpp @@ -62,7 +62,7 @@ static int check_nonzero(const char* xname, int x) { void MethodHandles::verify_klass(MacroAssembler* _masm, Register obj, SystemDictionary::WKID klass_id, const char* error_message) { - Klass** klass_addr = SystemDictionary::well_known_klass_addr(klass_id); + InstanceKlass** klass_addr = SystemDictionary::well_known_klass_addr(klass_id); KlassHandle klass = SystemDictionary::well_known_klass(klass_id); Register temp = rscratch2; Register temp2 = rscratch1; // used by MacroAssembler::cmpptr diff --git a/hotspot/src/cpu/ppc/vm/methodHandles_ppc.cpp b/hotspot/src/cpu/ppc/vm/methodHandles_ppc.cpp index 980c043f9e7..fed5e53c206 100644 --- a/hotspot/src/cpu/ppc/vm/methodHandles_ppc.cpp +++ b/hotspot/src/cpu/ppc/vm/methodHandles_ppc.cpp @@ -73,7 +73,7 @@ void MethodHandles::verify_klass(MacroAssembler* _masm, Register obj_reg, SystemDictionary::WKID klass_id, Register temp_reg, Register temp2_reg, const char* error_message) { - Klass** klass_addr = SystemDictionary::well_known_klass_addr(klass_id); + InstanceKlass** klass_addr = SystemDictionary::well_known_klass_addr(klass_id); KlassHandle klass = SystemDictionary::well_known_klass(klass_id); Label L_ok, L_bad; BLOCK_COMMENT("verify_klass {"); diff --git a/hotspot/src/cpu/sparc/vm/methodHandles_sparc.cpp b/hotspot/src/cpu/sparc/vm/methodHandles_sparc.cpp index 5246059b470..4d51de2921a 100644 --- a/hotspot/src/cpu/sparc/vm/methodHandles_sparc.cpp +++ b/hotspot/src/cpu/sparc/vm/methodHandles_sparc.cpp @@ -69,7 +69,7 @@ void MethodHandles::verify_klass(MacroAssembler* _masm, Register obj_reg, SystemDictionary::WKID klass_id, Register temp_reg, Register temp2_reg, const char* error_message) { - Klass** klass_addr = SystemDictionary::well_known_klass_addr(klass_id); + InstanceKlass** klass_addr = SystemDictionary::well_known_klass_addr(klass_id); KlassHandle klass = SystemDictionary::well_known_klass(klass_id); bool did_save = false; if (temp_reg == noreg || temp2_reg == noreg) { diff --git a/hotspot/src/cpu/x86/vm/methodHandles_x86.cpp b/hotspot/src/cpu/x86/vm/methodHandles_x86.cpp index be97c30acf1..757c263169b 100644 --- a/hotspot/src/cpu/x86/vm/methodHandles_x86.cpp +++ b/hotspot/src/cpu/x86/vm/methodHandles_x86.cpp @@ -63,7 +63,7 @@ static int check_nonzero(const char* xname, int x) { void MethodHandles::verify_klass(MacroAssembler* _masm, Register obj, SystemDictionary::WKID klass_id, const char* error_message) { - Klass** klass_addr = SystemDictionary::well_known_klass_addr(klass_id); + InstanceKlass** klass_addr = SystemDictionary::well_known_klass_addr(klass_id); KlassHandle klass = SystemDictionary::well_known_klass(klass_id); Register temp = rdi; Register temp2 = noreg; diff --git a/hotspot/src/share/vm/ci/ciInstanceKlass.hpp b/hotspot/src/share/vm/ci/ciInstanceKlass.hpp index 080acd380e1..b0d3234af6e 100644 --- a/hotspot/src/share/vm/ci/ciInstanceKlass.hpp +++ b/hotspot/src/share/vm/ci/ciInstanceKlass.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2015, 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 @@ -81,7 +81,7 @@ protected: ciInstanceKlass(ciSymbol* name, jobject loader, jobject protection_domain); InstanceKlass* get_instanceKlass() const { - return (InstanceKlass*)get_Klass(); + return InstanceKlass::cast(get_Klass()); } oop loader(); diff --git a/hotspot/src/share/vm/ci/ciMethod.cpp b/hotspot/src/share/vm/ci/ciMethod.cpp index a0e184fa9ed..e457458f080 100644 --- a/hotspot/src/share/vm/ci/ciMethod.cpp +++ b/hotspot/src/share/vm/ci/ciMethod.cpp @@ -745,7 +745,7 @@ ciMethod* ciMethod::find_monomorphic_target(ciInstanceKlass* caller, #ifndef PRODUCT if (TraceDependencies && target() != NULL && target() != root_m->get_Method()) { tty->print("found a non-root unique target method"); - tty->print_cr(" context = %s", InstanceKlass::cast(actual_recv->get_Klass())->external_name()); + tty->print_cr(" context = %s", actual_recv->get_Klass()->external_name()); tty->print(" method = "); target->print_short_name(tty); tty->cr(); diff --git a/hotspot/src/share/vm/ci/ciReplay.cpp b/hotspot/src/share/vm/ci/ciReplay.cpp index 3e22b50d2c4..27a5c1c8c16 100644 --- a/hotspot/src/share/vm/ci/ciReplay.cpp +++ b/hotspot/src/share/vm/ci/ciReplay.cpp @@ -530,15 +530,15 @@ class CompileReplay : public StackObj { if (_imethod != NULL) { return; // Replay Inlining } - Klass* k = method->method_holder(); - ((InstanceKlass*)k)->initialize(THREAD); + InstanceKlass* ik = method->method_holder(); + ik->initialize(THREAD); if (HAS_PENDING_EXCEPTION) { oop throwable = PENDING_EXCEPTION; java_lang_Throwable::print(throwable, tty); tty->cr(); if (ReplayIgnoreInitErrors) { CLEAR_PENDING_EXCEPTION; - ((InstanceKlass*)k)->set_init_state(InstanceKlass::fully_initialized); + ik->set_init_state(InstanceKlass::fully_initialized); } else { return; } @@ -842,7 +842,7 @@ class CompileReplay : public StackObj { } else if (field_signature[0] == 'L') { Symbol* klass_name = SymbolTable::lookup(field_signature, (int)strlen(field_signature), CHECK); KlassHandle kelem = resolve_klass(field_signature, CHECK); - oop value = ((InstanceKlass*)kelem())->allocate_instance(CHECK); + oop value = InstanceKlass::cast(kelem())->allocate_instance(CHECK); java_mirror->obj_field_put(fd.offset(), value); } else { report_error("unhandled staticfield"); diff --git a/hotspot/src/share/vm/classfile/bytecodeAssembler.hpp b/hotspot/src/share/vm/classfile/bytecodeAssembler.hpp index 74301472a63..01e338e0b55 100644 --- a/hotspot/src/share/vm/classfile/bytecodeAssembler.hpp +++ b/hotspot/src/share/vm/classfile/bytecodeAssembler.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012, 2015, 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 @@ -140,7 +140,7 @@ class BytecodeConstantPool : ResourceObj { BytecodeCPEntry const& at(u2 index) const { return _entries.at(index); } InstanceKlass* pool_holder() const { - return InstanceKlass::cast(_orig->pool_holder()); + return _orig->pool_holder(); } u2 utf8(Symbol* sym) { diff --git a/hotspot/src/share/vm/classfile/classFileParser.cpp b/hotspot/src/share/vm/classfile/classFileParser.cpp index 632390a2278..a726ac45f30 100644 --- a/hotspot/src/share/vm/classfile/classFileParser.cpp +++ b/hotspot/src/share/vm/classfile/classFileParser.cpp @@ -822,7 +822,7 @@ Array* ClassFileParser::parse_interfaces(int length, debug_only(No_Safepoint_Verifier nsv;) for (index = 0; index < length; index++) { Klass* k = _local_interfaces->at(index); - Symbol* name = InstanceKlass::cast(k)->name(); + Symbol* name = k->name(); // If no duplicates, add (name, NULL) in hashtable interface_names. if (!put_after_lookup(name, NULL, interface_names)) { dup = true; @@ -4315,13 +4315,13 @@ instanceKlassHandle ClassFileParser::parseClassFile(Symbol* name, if (caller != NULL) { tty->print("[Loaded %s by instance of %s]\n", this_klass->external_name(), - InstanceKlass::cast(caller)->external_name()); + caller->external_name()); } else { tty->print("[Loaded %s]\n", this_klass->external_name()); } } else { tty->print("[Loaded %s from %s]\n", this_klass->external_name(), - InstanceKlass::cast(class_loader->klass())->external_name()); + class_loader->klass()->external_name()); } } @@ -4330,7 +4330,7 @@ instanceKlassHandle ClassFileParser::parseClassFile(Symbol* name, // print out the superclass. const char * from = this_klass()->external_name(); if (this_klass->java_super() != NULL) { - tty->print("RESOLVE %s %s (super)\n", from, InstanceKlass::cast(this_klass->java_super())->external_name()); + tty->print("RESOLVE %s %s (super)\n", from, this_klass->java_super()->external_name()); } // print out each of the interface classes referred to by this class. Array* local_interfaces = this_klass->local_interfaces(); @@ -4338,8 +4338,7 @@ instanceKlassHandle ClassFileParser::parseClassFile(Symbol* name, int length = local_interfaces->length(); for (int i = 0; i < length; i++) { Klass* k = local_interfaces->at(i); - InstanceKlass* to_class = InstanceKlass::cast(k); - const char * to = to_class->external_name(); + const char * to = k->external_name(); tty->print("RESOLVE %s %s (interface)\n", from, to); } } @@ -4687,7 +4686,7 @@ void ClassFileParser::check_super_class_access(instanceKlassHandle this_klass, T vmSymbols::java_lang_IllegalAccessError(), "class %s cannot access its superclass %s", this_klass->external_name(), - InstanceKlass::cast(super)->external_name() + super->external_name() ); return; } @@ -4707,7 +4706,7 @@ void ClassFileParser::check_super_interface_access(instanceKlassHandle this_klas vmSymbols::java_lang_IllegalAccessError(), "class %s cannot access its superinterface %s", this_klass->external_name(), - InstanceKlass::cast(k)->external_name() + k->external_name() ); return; } diff --git a/hotspot/src/share/vm/classfile/dictionary.cpp b/hotspot/src/share/vm/classfile/dictionary.cpp index 3621af33f83..a443cc69aaa 100644 --- a/hotspot/src/share/vm/classfile/dictionary.cpp +++ b/hotspot/src/share/vm/classfile/dictionary.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2015, 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 @@ -78,7 +78,7 @@ void Dictionary::free_entry(DictionaryEntry* entry) { bool DictionaryEntry::contains_protection_domain(oop protection_domain) const { #ifdef ASSERT - if (protection_domain == InstanceKlass::cast(klass())->protection_domain()) { + if (protection_domain == klass()->protection_domain()) { // Ensure this doesn't show up in the pd_set (invariant) bool in_pd_set = false; for (ProtectionDomainEntry* current = _pd_set; @@ -96,7 +96,7 @@ bool DictionaryEntry::contains_protection_domain(oop protection_domain) const { } #endif /* ASSERT */ - if (protection_domain == InstanceKlass::cast(klass())->protection_domain()) { + if (protection_domain == klass()->protection_domain()) { // Succeeds trivially return true; } @@ -275,7 +275,7 @@ void Dictionary::classes_do(void f(Klass*)) { probe != NULL; probe = probe->next()) { Klass* k = probe->klass(); - if (probe->loader_data() == InstanceKlass::cast(k)->class_loader_data()) { + if (probe->loader_data() == k->class_loader_data()) { f(k); } } @@ -290,7 +290,7 @@ void Dictionary::classes_do(void f(Klass*, TRAPS), TRAPS) { probe != NULL; probe = probe->next()) { Klass* k = probe->klass(); - if (probe->loader_data() == InstanceKlass::cast(k)->class_loader_data()) { + if (probe->loader_data() == k->class_loader_data()) { f(k, CHECK); } } @@ -322,7 +322,7 @@ void Dictionary::methods_do(void f(Method*)) { probe != NULL; probe = probe->next()) { Klass* k = probe->klass(); - if (probe->loader_data() == InstanceKlass::cast(k)->class_loader_data()) { + if (probe->loader_data() == k->class_loader_data()) { // only take klass is we have the entry with the defining class loader InstanceKlass::cast(k)->methods_do(f); } @@ -476,7 +476,7 @@ void Dictionary::reorder_dictionary() { DictionaryEntry* p = master_list; master_list = master_list->next(); p->set_next(NULL); - Symbol* class_name = InstanceKlass::cast((Klass*)(p->klass()))->name(); + Symbol* class_name = p->klass()->name(); // Since the null class loader data isn't copied to the CDS archive, // compute the hash with NULL for loader data. unsigned int hash = compute_hash(class_name, NULL); @@ -723,7 +723,7 @@ void Dictionary::print(bool details) { Klass* e = probe->klass(); ClassLoaderData* loader_data = probe->loader_data(); bool is_defining_class = - (loader_data == InstanceKlass::cast(e)->class_loader_data()); + (loader_data == e->class_loader_data()); tty->print("%s%s", ((!details) || is_defining_class) ? " " : "^", e->external_name()); diff --git a/hotspot/src/share/vm/classfile/dictionary.hpp b/hotspot/src/share/vm/classfile/dictionary.hpp index 7ce8d34e5f5..1f6b568670e 100644 --- a/hotspot/src/share/vm/classfile/dictionary.hpp +++ b/hotspot/src/share/vm/classfile/dictionary.hpp @@ -323,8 +323,7 @@ class DictionaryEntry : public HashtableEntry { bool equals(Symbol* class_name, ClassLoaderData* loader_data) const { Klass* klass = (Klass*)literal(); - return (InstanceKlass::cast(klass)->name() == class_name && - _loader_data == loader_data); + return (klass->name() == class_name && _loader_data == loader_data); } void print() { diff --git a/hotspot/src/share/vm/classfile/javaClasses.cpp b/hotspot/src/share/vm/classfile/javaClasses.cpp index 9851534a9da..04117471382 100644 --- a/hotspot/src/share/vm/classfile/javaClasses.cpp +++ b/hotspot/src/share/vm/classfile/javaClasses.cpp @@ -114,17 +114,17 @@ static bool find_field(InstanceKlass* ik, // Helpful routine for computing field offsets at run time rather than hardcoding them static void compute_offset(int &dest_offset, - Klass* klass_oop, Symbol* name_symbol, Symbol* signature_symbol, + Klass* klass, Symbol* name_symbol, Symbol* signature_symbol, bool is_static = false, bool allow_super = false) { fieldDescriptor fd; - InstanceKlass* ik = InstanceKlass::cast(klass_oop); + InstanceKlass* ik = InstanceKlass::cast(klass); if (!find_field(ik, name_symbol, signature_symbol, &fd, is_static, allow_super)) { ResourceMark rm; tty->print_cr("Invalid layout of %s at %s", ik->external_name(), name_symbol->as_C_string()); #ifndef PRODUCT - klass_oop->print(); + ik->print(); tty->print_cr("all fields:"); - for (AllFieldStream fs(InstanceKlass::cast(klass_oop)); !fs.done(); fs.next()) { + for (AllFieldStream fs(ik); !fs.done(); fs.next()) { tty->print_cr(" name: %s, sig: %s, flags: %08x", fs.name()->as_C_string(), fs.signature()->as_C_string(), fs.access_flags().as_int()); } #endif //PRODUCT @@ -136,10 +136,10 @@ compute_offset(int &dest_offset, // Same as above but for "optional" offsets that might not be present in certain JDK versions static void compute_optional_offset(int& dest_offset, - Klass* klass_oop, Symbol* name_symbol, Symbol* signature_symbol, + Klass* klass, Symbol* name_symbol, Symbol* signature_symbol, bool allow_super = false) { fieldDescriptor fd; - InstanceKlass* ik = InstanceKlass::cast(klass_oop); + InstanceKlass* ik = InstanceKlass::cast(klass); if (find_field(ik, name_symbol, signature_symbol, &fd, allow_super)) { dest_offset = fd.offset(); } @@ -174,7 +174,7 @@ Handle java_lang_String::basic_create(int length, TRAPS) { // Create the String object first, so there's a chance that the String // and the char array it points to end up in the same cache line. oop obj; - obj = InstanceKlass::cast(SystemDictionary::String_klass())->allocate_instance(CHECK_NH); + obj = SystemDictionary::String_klass()->allocate_instance(CHECK_NH); // Create the char array. The String object must be handlized here // because GC can happen as a result of the allocation attempt. @@ -1236,7 +1236,7 @@ void java_lang_ThreadGroup::compute_offsets() { } oop java_lang_Throwable::unassigned_stacktrace() { - InstanceKlass* ik = InstanceKlass::cast(SystemDictionary::Throwable_klass()); + InstanceKlass* ik = SystemDictionary::Throwable_klass(); address addr = ik->static_field_addr(static_unassigned_stacktrace_offset); if (UseCompressedOops) { return oopDesc::load_decode_heap_oop((narrowOop *)addr); @@ -1293,7 +1293,7 @@ void java_lang_Throwable::print(oop throwable, outputStream* st) { ResourceMark rm; Klass* k = throwable->klass(); assert(k != NULL, "just checking"); - st->print("%s", InstanceKlass::cast(k)->external_name()); + st->print("%s", k->external_name()); oop msg = message(throwable); if (msg != NULL) { st->print(": %s", java_lang_String::as_utf8_string(msg)); @@ -1305,7 +1305,7 @@ void java_lang_Throwable::print(Handle throwable, outputStream* st) { ResourceMark rm; Klass* k = throwable->klass(); assert(k != NULL, "just checking"); - st->print("%s", InstanceKlass::cast(k)->external_name()); + st->print("%s", k->external_name()); oop msg = message(throwable); if (msg != NULL) { st->print(": %s", java_lang_String::as_utf8_string(msg)); @@ -2663,13 +2663,13 @@ void java_lang_boxing_object::print(BasicType type, jvalue* value, outputStream* // Support for java_lang_ref_Reference HeapWord *java_lang_ref_Reference::pending_list_lock_addr() { - InstanceKlass* ik = InstanceKlass::cast(SystemDictionary::Reference_klass()); + InstanceKlass* ik = SystemDictionary::Reference_klass(); address addr = ik->static_field_addr(static_lock_offset); return (HeapWord*) addr; } oop java_lang_ref_Reference::pending_list_lock() { - InstanceKlass* ik = InstanceKlass::cast(SystemDictionary::Reference_klass()); + InstanceKlass* ik = SystemDictionary::Reference_klass(); address addr = ik->static_field_addr(static_lock_offset); if (UseCompressedOops) { return oopDesc::load_decode_heap_oop((narrowOop *)addr); @@ -2679,7 +2679,7 @@ oop java_lang_ref_Reference::pending_list_lock() { } HeapWord *java_lang_ref_Reference::pending_list_addr() { - InstanceKlass* ik = InstanceKlass::cast(SystemDictionary::Reference_klass()); + InstanceKlass* ik = SystemDictionary::Reference_klass(); address addr = ik->static_field_addr(static_pending_offset); // XXX This might not be HeapWord aligned, almost rather be char *. return (HeapWord*)addr; @@ -2702,13 +2702,13 @@ jlong java_lang_ref_SoftReference::timestamp(oop ref) { } jlong java_lang_ref_SoftReference::clock() { - InstanceKlass* ik = InstanceKlass::cast(SystemDictionary::SoftReference_klass()); + InstanceKlass* ik = SystemDictionary::SoftReference_klass(); jlong* offset = (jlong*)ik->static_field_addr(static_clock_offset); return *offset; } void java_lang_ref_SoftReference::set_clock(jlong value) { - InstanceKlass* ik = InstanceKlass::cast(SystemDictionary::SoftReference_klass()); + InstanceKlass* ik = SystemDictionary::SoftReference_klass(); jlong* offset = (jlong*)ik->static_field_addr(static_clock_offset); *offset = value; } @@ -3033,7 +3033,7 @@ int java_security_AccessControlContext::_isAuthorized_offset = -1; void java_security_AccessControlContext::compute_offsets() { assert(_isPrivileged_offset == 0, "offsets should be initialized only once"); fieldDescriptor fd; - InstanceKlass* ik = InstanceKlass::cast(SystemDictionary::AccessControlContext_klass()); + InstanceKlass* ik = SystemDictionary::AccessControlContext_klass(); if (!ik->find_local_field(vmSymbols::context_name(), vmSymbols::protectiondomain_signature(), &fd)) { fatal("Invalid layout of java.security.AccessControlContext"); @@ -3066,9 +3066,9 @@ bool java_security_AccessControlContext::is_authorized(Handle context) { oop java_security_AccessControlContext::create(objArrayHandle context, bool isPrivileged, Handle privileged_context, TRAPS) { assert(_isPrivileged_offset != 0, "offsets should have been initialized"); // Ensure klass is initialized - InstanceKlass::cast(SystemDictionary::AccessControlContext_klass())->initialize(CHECK_0); + SystemDictionary::AccessControlContext_klass()->initialize(CHECK_0); // Allocate result - oop result = InstanceKlass::cast(SystemDictionary::AccessControlContext_klass())->allocate_instance(CHECK_0); + oop result = SystemDictionary::AccessControlContext_klass()->allocate_instance(CHECK_0); // Fill in values result->obj_field_put(_context_offset, context()); result->obj_field_put(_privilegedContext_offset, privileged_context()); @@ -3190,7 +3190,7 @@ int java_lang_System::err_offset_in_bytes() { bool java_lang_System::has_security_manager() { - InstanceKlass* ik = InstanceKlass::cast(SystemDictionary::System_klass()); + InstanceKlass* ik = SystemDictionary::System_klass(); address addr = ik->static_field_addr(static_security_offset); if (UseCompressedOops) { return oopDesc::load_decode_heap_oop((narrowOop *)addr) != NULL; @@ -3630,8 +3630,8 @@ void JavaClasses::check_offsets() { #endif // PRODUCT int InjectedField::compute_offset() { - Klass* klass_oop = klass(); - for (AllFieldStream fs(InstanceKlass::cast(klass_oop)); !fs.done(); fs.next()) { + InstanceKlass* ik = InstanceKlass::cast(klass()); + for (AllFieldStream fs(ik); !fs.done(); fs.next()) { if (!may_be_java && !fs.access_flags().is_internal()) { // Only look at injected fields continue; @@ -3641,11 +3641,11 @@ int InjectedField::compute_offset() { } } ResourceMark rm; - tty->print_cr("Invalid layout of %s at %s/%s%s", InstanceKlass::cast(klass_oop)->external_name(), name()->as_C_string(), signature()->as_C_string(), may_be_java ? " (may_be_java)" : ""); + tty->print_cr("Invalid layout of %s at %s/%s%s", ik->external_name(), name()->as_C_string(), signature()->as_C_string(), may_be_java ? " (may_be_java)" : ""); #ifndef PRODUCT - klass_oop->print(); + ik->print(); tty->print_cr("all fields:"); - for (AllFieldStream fs(InstanceKlass::cast(klass_oop)); !fs.done(); fs.next()) { + for (AllFieldStream fs(ik); !fs.done(); fs.next()) { tty->print_cr(" name: %s, sig: %s, flags: %08x", fs.name()->as_C_string(), fs.signature()->as_C_string(), fs.access_flags().as_int()); } #endif //PRODUCT diff --git a/hotspot/src/share/vm/classfile/systemDictionary.cpp b/hotspot/src/share/vm/classfile/systemDictionary.cpp index 4e867e2805f..1da2defd067 100644 --- a/hotspot/src/share/vm/classfile/systemDictionary.cpp +++ b/hotspot/src/share/vm/classfile/systemDictionary.cpp @@ -88,10 +88,10 @@ const int SystemDictionary::_primelist[_prime_array_size] = {1009,2017,4049,50 oop SystemDictionary::_system_loader_lock_obj = NULL; -Klass* SystemDictionary::_well_known_klasses[SystemDictionary::WKID_LIMIT] +InstanceKlass* SystemDictionary::_well_known_klasses[SystemDictionary::WKID_LIMIT] = { NULL /*, NULL...*/ }; -Klass* SystemDictionary::_box_klasses[T_VOID+1] = { NULL /*, NULL...*/ }; +InstanceKlass* SystemDictionary::_box_klasses[T_VOID+1] = { NULL /*, NULL...*/ }; oop SystemDictionary::_java_system_loader = NULL; @@ -99,7 +99,7 @@ bool SystemDictionary::_has_loadClassInternal = false; bool SystemDictionary::_has_checkPackageAccess = false; // lazily initialized klass variables -Klass* volatile SystemDictionary::_abstract_ownable_synchronizer_klass = NULL; +InstanceKlass* volatile SystemDictionary::_abstract_ownable_synchronizer_klass = NULL; // ---------------------------------------------------------------------------- @@ -357,7 +357,7 @@ Klass* SystemDictionary::resolve_super_or_fail(Symbol* child_name, // so we don't throw an exception here. // see: nsk redefclass014 & java.lang.instrument Instrument032 if ((childk != NULL ) && (is_superclass) && - ((quicksuperk = InstanceKlass::cast(childk)->super()) != NULL) && + ((quicksuperk = childk->super()) != NULL) && ((quicksuperk->name() == class_name) && (quicksuperk->class_loader() == class_loader()))) { @@ -1257,8 +1257,7 @@ instanceKlassHandle SystemDictionary::load_shared_class(instanceKlassHandle ik, } // notify a class loaded from shared object - ClassLoadingService::notify_class_loaded(InstanceKlass::cast(ik()), - true /* shared class */); + ClassLoadingService::notify_class_loaded(ik(), true /* shared class */); } return ik; } @@ -1805,7 +1804,7 @@ void SystemDictionary::load_abstract_ownable_synchronizer_klass(TRAPS) { Klass* k = resolve_or_fail(vmSymbols::java_util_concurrent_locks_AbstractOwnableSynchronizer(), true, CHECK); // Force a fence to prevent any read before the write completes OrderAccess::fence(); - _abstract_ownable_synchronizer_klass = k; + _abstract_ownable_synchronizer_klass = InstanceKlass::cast(k); } } @@ -1846,14 +1845,16 @@ bool SystemDictionary::initialize_wk_klass(WKID id, int init_opt, TRAPS) { int info = wk_init_info[id - FIRST_WKID]; int sid = (info >> CEIL_LG_OPTION_LIMIT); Symbol* symbol = vmSymbols::symbol_at((vmSymbols::SID)sid); - Klass** klassp = &_well_known_klasses[id]; + InstanceKlass** klassp = &_well_known_klasses[id]; bool must_load = (init_opt < SystemDictionary::Opt); if ((*klassp) == NULL) { + Klass* k; if (must_load) { - (*klassp) = resolve_or_fail(symbol, true, CHECK_0); // load required class + k = resolve_or_fail(symbol, true, CHECK_0); // load required class } else { - (*klassp) = resolve_or_null(symbol, CHECK_0); // load optional klass + k = resolve_or_null(symbol, CHECK_0); // load optional klass } + (*klassp) = (k == NULL) ? NULL : InstanceKlass::cast(k); } return ((*klassp) != NULL); } diff --git a/hotspot/src/share/vm/classfile/systemDictionary.hpp b/hotspot/src/share/vm/classfile/systemDictionary.hpp index 191c2c30239..20a2bd5c620 100644 --- a/hotspot/src/share/vm/classfile/systemDictionary.hpp +++ b/hotspot/src/share/vm/classfile/systemDictionary.hpp @@ -403,15 +403,15 @@ public: static void initialize(TRAPS); // Fast access to commonly used classes (preloaded) - static Klass* check_klass(Klass* k) { + static InstanceKlass* check_klass(InstanceKlass* k) { assert(k != NULL, "preloaded klass not initialized"); return k; } - static Klass* check_klass_Pre( Klass* k) { return check_klass(k); } - static Klass* check_klass_Opt( Klass* k) { return k; } + static InstanceKlass* check_klass_Pre(InstanceKlass* k) { return check_klass(k); } + static InstanceKlass* check_klass_Opt(InstanceKlass* k) { return k; } - JVMCI_ONLY(static Klass* check_klass_Jvmci(Klass* k) { return k; }) + JVMCI_ONLY(static InstanceKlass* check_klass_Jvmci(InstanceKlass* k) { return k; }) static bool initialize_wk_klass(WKID id, int init_opt, TRAPS); static void initialize_wk_klasses_until(WKID limit_id, WKID &start_id, TRAPS); @@ -422,19 +422,19 @@ public: public: #define WK_KLASS_DECLARE(name, symbol, option) \ - static Klass* name() { return check_klass_##option(_well_known_klasses[WK_KLASS_ENUM_NAME(name)]); } \ - static Klass** name##_addr() { \ + static InstanceKlass* name() { return check_klass_##option(_well_known_klasses[WK_KLASS_ENUM_NAME(name)]); } \ + static InstanceKlass** name##_addr() { \ return &SystemDictionary::_well_known_klasses[SystemDictionary::WK_KLASS_ENUM_NAME(name)]; \ } WK_KLASSES_DO(WK_KLASS_DECLARE); #undef WK_KLASS_DECLARE - static Klass* well_known_klass(WKID id) { + static InstanceKlass* well_known_klass(WKID id) { assert(id >= (int)FIRST_WKID && id < (int)WKID_LIMIT, "oob"); return _well_known_klasses[id]; } - static Klass** well_known_klass_addr(WKID id) { + static InstanceKlass** well_known_klass_addr(WKID id) { assert(id >= (int)FIRST_WKID && id < (int)WKID_LIMIT, "oob"); return &_well_known_klasses[id]; } @@ -442,7 +442,7 @@ public: // Local definition for direct access to the private array: #define WK_KLASS(name) _well_known_klasses[SystemDictionary::WK_KLASS_ENUM_NAME(name)] - static Klass* box_klass(BasicType t) { + static InstanceKlass* box_klass(BasicType t) { assert((uint)t < T_VOID+1, "range check"); return check_klass(_box_klasses[t]); } @@ -450,7 +450,7 @@ public: // methods returning lazily loaded klasses // The corresponding method to load the class must be called before calling them. - static Klass* abstract_ownable_synchronizer_klass() { return check_klass(_abstract_ownable_synchronizer_klass); } + static InstanceKlass* abstract_ownable_synchronizer_klass() { return check_klass(_abstract_ownable_synchronizer_klass); } static void load_abstract_ownable_synchronizer_klass(TRAPS); @@ -700,13 +700,13 @@ protected: TRAPS); // Variables holding commonly used klasses (preloaded) - static Klass* _well_known_klasses[]; + static InstanceKlass* _well_known_klasses[]; // Lazily loaded klasses - static Klass* volatile _abstract_ownable_synchronizer_klass; + static InstanceKlass* volatile _abstract_ownable_synchronizer_klass; // table of box klasses (int_klass, etc.) - static Klass* _box_klasses[T_VOID+1]; + static InstanceKlass* _box_klasses[T_VOID+1]; static oop _java_system_loader; diff --git a/hotspot/src/share/vm/classfile/verifier.cpp b/hotspot/src/share/vm/classfile/verifier.cpp index 53609110799..d1537011db8 100644 --- a/hotspot/src/share/vm/classfile/verifier.cpp +++ b/hotspot/src/share/vm/classfile/verifier.cpp @@ -184,7 +184,7 @@ bool Verifier::verify(instanceKlassHandle klass, Verifier::Mode mode, bool shoul if (HAS_PENDING_EXCEPTION) { tty->print("Verification for %s has", klassName); tty->print_cr(" exception pending %s ", - InstanceKlass::cast(PENDING_EXCEPTION->klass())->external_name()); + PENDING_EXCEPTION->klass()->external_name()); } else if (exception_name != NULL) { tty->print_cr("Verification for %s failed", klassName); } diff --git a/hotspot/src/share/vm/code/dependencies.cpp b/hotspot/src/share/vm/code/dependencies.cpp index ed77e17b7f5..b326c010dab 100644 --- a/hotspot/src/share/vm/code/dependencies.cpp +++ b/hotspot/src/share/vm/code/dependencies.cpp @@ -1086,8 +1086,8 @@ class ClassHierarchyWalker { Method* lm = k->lookup_method(m->name(), m->signature()); if (lm == NULL && k->oop_is_instance()) { // It might be an interface method - lm = ((InstanceKlass*)k)->lookup_method_in_ordered_interfaces(m->name(), - m->signature()); + lm = InstanceKlass::cast(k)->lookup_method_in_ordered_interfaces(m->name(), + m->signature()); } if (lm == m) // Method m is inherited into ctxk. @@ -1840,20 +1840,20 @@ void DepChange::print() { Klass* k = str.klass(); switch (str.change_type()) { case Change_new_type: - tty->print_cr(" dependee = %s", InstanceKlass::cast(k)->external_name()); + tty->print_cr(" dependee = %s", k->external_name()); break; case Change_new_sub: if (!WizardMode) { ++nsup; } else { - tty->print_cr(" context super = %s", InstanceKlass::cast(k)->external_name()); + tty->print_cr(" context super = %s", k->external_name()); } break; case Change_new_impl: if (!WizardMode) { ++nint; } else { - tty->print_cr(" context interface = %s", InstanceKlass::cast(k)->external_name()); + tty->print_cr(" context interface = %s", k->external_name()); } break; } @@ -1885,7 +1885,7 @@ bool DepChange::ContextStream::next() { case Change_new_sub: // 6598190: brackets workaround Sun Studio C++ compiler bug 6629277 { - _klass = InstanceKlass::cast(_klass)->super(); + _klass = _klass->super(); if (_klass != NULL) { return true; } diff --git a/hotspot/src/share/vm/code/nmethod.cpp b/hotspot/src/share/vm/code/nmethod.cpp index 68b50e59060..a84555b4289 100644 --- a/hotspot/src/share/vm/code/nmethod.cpp +++ b/hotspot/src/share/vm/code/nmethod.cpp @@ -3021,7 +3021,7 @@ void nmethod::print_dependencies() { deps.print_dependency(); Klass* ctxk = deps.context_type(); if (ctxk != NULL) { - if (ctxk->oop_is_instance() && ((InstanceKlass*)ctxk)->is_dependent_nmethod(this)) { + if (ctxk->oop_is_instance() && InstanceKlass::cast(ctxk)->is_dependent_nmethod(this)) { tty->print_cr(" [nmethod<=klass]%s", ctxk->external_name()); } } diff --git a/hotspot/src/share/vm/gc/g1/g1CollectedHeap.cpp b/hotspot/src/share/vm/gc/g1/g1CollectedHeap.cpp index 9270855bfb4..b3287da65a3 100644 --- a/hotspot/src/share/vm/gc/g1/g1CollectedHeap.cpp +++ b/hotspot/src/share/vm/gc/g1/g1CollectedHeap.cpp @@ -4592,7 +4592,8 @@ class G1KlassCleaningTask : public StackObj { klass =_klass_iterator.next_klass(); } while (klass != NULL && !klass->oop_is_instance()); - return (InstanceKlass*)klass; + // this can be null so don't call InstanceKlass::cast + return static_cast(klass); } public: diff --git a/hotspot/src/share/vm/gc/g1/heapRegion.cpp b/hotspot/src/share/vm/gc/g1/heapRegion.cpp index 75e017ff3c2..565300f88aa 100644 --- a/hotspot/src/share/vm/gc/g1/heapRegion.cpp +++ b/hotspot/src/share/vm/gc/g1/heapRegion.cpp @@ -660,7 +660,7 @@ public: void print_object(outputStream* out, oop obj) { #ifdef PRODUCT Klass* k = obj->klass(); - const char* class_name = InstanceKlass::cast(k)->external_name(); + const char* class_name = k->external_name(); out->print_cr("class name %s", class_name); #else // PRODUCT obj->print_on(out); diff --git a/hotspot/src/share/vm/interpreter/bytecodeInterpreter.cpp b/hotspot/src/share/vm/interpreter/bytecodeInterpreter.cpp index a9252c2bfa7..19954f1ff84 100644 --- a/hotspot/src/share/vm/interpreter/bytecodeInterpreter.cpp +++ b/hotspot/src/share/vm/interpreter/bytecodeInterpreter.cpp @@ -2148,11 +2148,8 @@ run: if (!constants->tag_at(index).is_unresolved_klass()) { // Make sure klass is initialized and doesn't have a finalizer Klass* entry = constants->slot_at(index).get_klass(); - assert(entry->is_klass(), "Should be resolved klass"); - Klass* k_entry = (Klass*) entry; - assert(k_entry->oop_is_instance(), "Should be InstanceKlass"); - InstanceKlass* ik = (InstanceKlass*) k_entry; - if ( ik->is_initialized() && ik->can_be_fastpath_allocated() ) { + InstanceKlass* ik = InstanceKlass::cast(entry); + if (ik->is_initialized() && ik->can_be_fastpath_allocated() ) { size_t obj_size = ik->size_helper(); oop result = NULL; // If the TLAB isn't pre-zeroed then we'll have to do it @@ -2611,7 +2608,7 @@ run: but using InstanceKlass::cast(STACK_OBJECT(-parms)->klass()) causes in assertion failure because rcvr->klass()->oop_is_instance() == 0 However it seems to have a vtable in the right location. Huh? - + Because vtables have the same offset for ArrayKlass and InstanceKlass. */ callee = (Method*) rcvrKlass->start_of_vtable()[ cache->f2_as_index()]; // Profile virtual call. diff --git a/hotspot/src/share/vm/interpreter/linkResolver.cpp b/hotspot/src/share/vm/interpreter/linkResolver.cpp index 55fe49f4e9b..a155e8580ba 100644 --- a/hotspot/src/share/vm/interpreter/linkResolver.cpp +++ b/hotspot/src/share/vm/interpreter/linkResolver.cpp @@ -307,12 +307,14 @@ methodHandle LinkResolver::lookup_method_in_klasses(const LinkInfo& link_info, return methodHandle(THREAD, result); } + InstanceKlass* ik = InstanceKlass::cast(klass()); + // JDK 8, JVMS 5.4.3.4: Interface method resolution should // ignore static and non-public methods of java.lang.Object, // like clone, finalize, registerNatives. if (in_imethod_resolve && result != NULL && - klass->is_interface() && + ik->is_interface() && (result->is_static() || !result->is_public()) && result->method_holder() == SystemDictionary::Object_klass()) { result = NULL; @@ -321,11 +323,11 @@ methodHandle LinkResolver::lookup_method_in_klasses(const LinkInfo& link_info, // Before considering default methods, check for an overpass in the // current class if a method has not been found. if (result == NULL) { - result = InstanceKlass::cast(klass())->find_method(name, signature); + result = ik->find_method(name, signature); } if (result == NULL) { - Array* default_methods = InstanceKlass::cast(klass())->default_methods(); + Array* default_methods = ik->default_methods(); if (default_methods != NULL) { result = InstanceKlass::find_method(default_methods, name, signature); } @@ -374,21 +376,21 @@ int LinkResolver::vtable_index_of_interface_method(KlassHandle klass, int vtable_index = Method::invalid_vtable_index; Symbol* name = resolved_method->name(); Symbol* signature = resolved_method->signature(); + InstanceKlass* ik = InstanceKlass::cast(klass()); // First check in default method array - if (!resolved_method->is_abstract() && - (InstanceKlass::cast(klass())->default_methods() != NULL)) { - int index = InstanceKlass::find_method_index(InstanceKlass::cast(klass())->default_methods(), + if (!resolved_method->is_abstract() && ik->default_methods() != NULL) { + int index = InstanceKlass::find_method_index(ik->default_methods(), name, signature, Klass::find_overpass, Klass::find_static, Klass::find_private); if (index >= 0 ) { - vtable_index = InstanceKlass::cast(klass())->default_vtable_indices()->at(index); + vtable_index = ik->default_vtable_indices()->at(index); } } if (vtable_index == Method::invalid_vtable_index) { // get vtable_index for miranda methods ResourceMark rm; - klassVtable *vt = InstanceKlass::cast(klass())->vtable(); + klassVtable *vt = ik->vtable(); vtable_index = vt->index_of_miranda(name, signature); } return vtable_index; diff --git a/hotspot/src/share/vm/jvmci/jvmciCompiler.cpp b/hotspot/src/share/vm/jvmci/jvmciCompiler.cpp index ca747e6bc7c..06ef2f6246c 100644 --- a/hotspot/src/share/vm/jvmci/jvmciCompiler.cpp +++ b/hotspot/src/share/vm/jvmci/jvmciCompiler.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2011, 2015, 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 @@ -72,7 +72,7 @@ void JVMCICompiler::bootstrap() { } jlong start = os::javaTimeMillis(); - Array* objectMethods = InstanceKlass::cast(SystemDictionary::Object_klass())->methods(); + Array* objectMethods = SystemDictionary::Object_klass()->methods(); // Initialize compile queue with a selected set of methods. int len = objectMethods->length(); for (int i = 0; i < len; i++) { diff --git a/hotspot/src/share/vm/jvmci/jvmciJavaClasses.hpp b/hotspot/src/share/vm/jvmci/jvmciJavaClasses.hpp index bfd81623cd8..d72b8f9f658 100644 --- a/hotspot/src/share/vm/jvmci/jvmciJavaClasses.hpp +++ b/hotspot/src/share/vm/jvmci/jvmciJavaClasses.hpp @@ -306,7 +306,7 @@ class name : AllStatic { } \ static void compute_offsets(); \ public: \ - static InstanceKlass* klass() { return SystemDictionary::name##_klass() == NULL ? NULL : InstanceKlass::cast(SystemDictionary::name##_klass()); } + static InstanceKlass* klass() { return SystemDictionary::name##_klass(); } #define END_CLASS }; diff --git a/hotspot/src/share/vm/memory/heapInspection.cpp b/hotspot/src/share/vm/memory/heapInspection.cpp index 6f24c4917af..610c33b05b6 100644 --- a/hotspot/src/share/vm/memory/heapInspection.cpp +++ b/hotspot/src/share/vm/memory/heapInspection.cpp @@ -348,8 +348,7 @@ void KlassHierarchy::print_class_hierarchy(outputStream* st, bool print_interfac for(int i = 0; i < elements.length(); i++) { KlassInfoEntry* cie = elements.at(i); - const InstanceKlass* k = (InstanceKlass*)cie->klass(); - Klass* super = ((InstanceKlass*)k)->java_super(); + Klass* super = cie->klass()->super(); // Set the index for the class. cie->set_index(i + 1); diff --git a/hotspot/src/share/vm/memory/metaspaceShared.cpp b/hotspot/src/share/vm/memory/metaspaceShared.cpp index 71507120a70..06700063c90 100644 --- a/hotspot/src/share/vm/memory/metaspaceShared.cpp +++ b/hotspot/src/share/vm/memory/metaspaceShared.cpp @@ -680,7 +680,7 @@ void VM_PopulateDumpSharedSpace::doit() { void MetaspaceShared::link_one_shared_class(Klass* obj, TRAPS) { Klass* k = obj; if (k->oop_is_instance()) { - InstanceKlass* ik = (InstanceKlass*) k; + InstanceKlass* ik = InstanceKlass::cast(k); // Link the class to cause the bytecodes to be rewritten and the // cpcache to be created. Class verification is done according // to -Xverify setting. diff --git a/hotspot/src/share/vm/memory/oopFactory.cpp b/hotspot/src/share/vm/memory/oopFactory.cpp index 1e214b328d3..c759e696dac 100644 --- a/hotspot/src/share/vm/memory/oopFactory.cpp +++ b/hotspot/src/share/vm/memory/oopFactory.cpp @@ -82,9 +82,8 @@ typeArrayOop oopFactory::new_typeArray_nozero(BasicType type, int length, TRAPS) objArrayOop oopFactory::new_objArray(Klass* klass, int length, TRAPS) { assert(klass->is_klass(), "must be instance class"); if (klass->oop_is_array()) { - return ((ArrayKlass*)klass)->allocate_arrayArray(1, length, THREAD); + return ArrayKlass::cast(klass)->allocate_arrayArray(1, length, THREAD); } else { - assert (klass->oop_is_instance(), "new object array with klass not an InstanceKlass"); - return ((InstanceKlass*)klass)->allocate_objArray(1, length, THREAD); + return InstanceKlass::cast(klass)->allocate_objArray(1, length, THREAD); } } diff --git a/hotspot/src/share/vm/memory/universe.cpp b/hotspot/src/share/vm/memory/universe.cpp index fa22f5bfdcc..57c4563766b 100644 --- a/hotspot/src/share/vm/memory/universe.cpp +++ b/hotspot/src/share/vm/memory/universe.cpp @@ -409,7 +409,7 @@ void Universe::genesis(TRAPS) { int i = 0; while (i < size) { // Allocate dummy in old generation - oop dummy = InstanceKlass::cast(SystemDictionary::Object_klass())->allocate_instance(CHECK); + oop dummy = SystemDictionary::Object_klass()->allocate_instance(CHECK); dummy_array->obj_at_put(i++, dummy); } { @@ -484,8 +484,8 @@ void Universe::initialize_basic_type_mirrors(TRAPS) { _mirrors[T_LONG] = _long_mirror; _mirrors[T_SHORT] = _short_mirror; _mirrors[T_VOID] = _void_mirror; - //_mirrors[T_OBJECT] = InstanceKlass::cast(_object_klass)->java_mirror(); - //_mirrors[T_ARRAY] = InstanceKlass::cast(_object_klass)->java_mirror(); + //_mirrors[T_OBJECT] = _object_klass->java_mirror(); + //_mirrors[T_ARRAY] = _object_klass->java_mirror(); } void Universe::fixup_mirrors(TRAPS) { @@ -546,8 +546,7 @@ void Universe::reinitialize_vtable_of(KlassHandle k_h, TRAPS) { klassVtable* vt = ko->vtable(); if (vt) vt->initialize_vtable(false, CHECK); if (ko->oop_is_instance()) { - InstanceKlass* ik = (InstanceKlass*)ko; - for (KlassHandle s_h(THREAD, ik->subklass()); + for (KlassHandle s_h(THREAD, ko->subklass()); s_h() != NULL; s_h = KlassHandle(THREAD, s_h()->next_sibling())) { reinitialize_vtable_of(s_h, CHECK); @@ -998,8 +997,8 @@ bool universe_post_init() { // Setup static method for registering finalizers // The finalizer klass must be linked before looking up the method, in // case it needs to get rewritten. - InstanceKlass::cast(SystemDictionary::Finalizer_klass())->link_class(CHECK_false); - Method* m = InstanceKlass::cast(SystemDictionary::Finalizer_klass())->find_method( + SystemDictionary::Finalizer_klass()->link_class(CHECK_false); + Method* m = SystemDictionary::Finalizer_klass()->find_method( vmSymbols::register_method_name(), vmSymbols::register_method_signature()); if (m == NULL || !m->is_static()) { @@ -1009,8 +1008,8 @@ bool universe_post_init() { Universe::_finalizer_register_cache->init( SystemDictionary::Finalizer_klass(), m); - InstanceKlass::cast(SystemDictionary::misc_Unsafe_klass())->link_class(CHECK_false); - m = InstanceKlass::cast(SystemDictionary::misc_Unsafe_klass())->find_method( + SystemDictionary::misc_Unsafe_klass()->link_class(CHECK_false); + m = SystemDictionary::misc_Unsafe_klass()->find_method( vmSymbols::throwIllegalAccessError_name(), vmSymbols::void_method_signature()); if (m != NULL && !m->is_static()) { @@ -1023,8 +1022,8 @@ bool universe_post_init() { SystemDictionary::misc_Unsafe_klass(), m); // Setup method for registering loaded classes in class loader vector - InstanceKlass::cast(SystemDictionary::ClassLoader_klass())->link_class(CHECK_false); - m = InstanceKlass::cast(SystemDictionary::ClassLoader_klass())->find_method(vmSymbols::addClass_name(), vmSymbols::class_void_signature()); + SystemDictionary::ClassLoader_klass()->link_class(CHECK_false); + m = SystemDictionary::ClassLoader_klass()->find_method(vmSymbols::addClass_name(), vmSymbols::class_void_signature()); if (m == NULL || m->is_static()) { tty->print_cr("Unable to link/verify ClassLoader.addClass method"); return false; // initialization failed (cannot throw exception yet) @@ -1033,8 +1032,8 @@ bool universe_post_init() { SystemDictionary::ClassLoader_klass(), m); // Setup method for checking protection domain - InstanceKlass::cast(SystemDictionary::ProtectionDomain_klass())->link_class(CHECK_false); - m = InstanceKlass::cast(SystemDictionary::ProtectionDomain_klass())-> + SystemDictionary::ProtectionDomain_klass()->link_class(CHECK_false); + m = SystemDictionary::ProtectionDomain_klass()-> find_method(vmSymbols::impliesCreateAccessControlContext_name(), vmSymbols::void_boolean_signature()); // Allow NULL which should only happen with bootstrapping. diff --git a/hotspot/src/share/vm/oops/constantPool.cpp b/hotspot/src/share/vm/oops/constantPool.cpp index 329aedf57cc..9037624ca58 100644 --- a/hotspot/src/share/vm/oops/constantPool.cpp +++ b/hotspot/src/share/vm/oops/constantPool.cpp @@ -198,11 +198,11 @@ void ConstantPool::trace_class_resolution(const constantPoolHandle& this_cp, Kla if (source_file != NULL) { tty->print("RESOLVE %s %s %s:%d\n", this_cp->pool_holder()->external_name(), - InstanceKlass::cast(k())->external_name(), source_file, line_number); + k->external_name(), source_file, line_number); } else { tty->print("RESOLVE %s %s\n", this_cp->pool_holder()->external_name(), - InstanceKlass::cast(k())->external_name()); + k->external_name()); } } } diff --git a/hotspot/src/share/vm/oops/instanceKlass.cpp b/hotspot/src/share/vm/oops/instanceKlass.cpp index 33c3900151c..eac34c665ce 100644 --- a/hotspot/src/share/vm/oops/instanceKlass.cpp +++ b/hotspot/src/share/vm/oops/instanceKlass.cpp @@ -742,7 +742,7 @@ void InstanceKlass::initialize_impl(instanceKlassHandle this_k, TRAPS) { // A class could already be verified, since it has been reflected upon. this_k->link_class(CHECK); - DTRACE_CLASSINIT_PROBE(required, InstanceKlass::cast(this_k()), -1); + DTRACE_CLASSINIT_PROBE(required, this_k(), -1); bool wait = false; @@ -765,19 +765,19 @@ void InstanceKlass::initialize_impl(instanceKlassHandle this_k, TRAPS) { // Step 3 if (this_k->is_being_initialized() && this_k->is_reentrant_initialization(self)) { - DTRACE_CLASSINIT_PROBE_WAIT(recursive, InstanceKlass::cast(this_k()), -1,wait); + DTRACE_CLASSINIT_PROBE_WAIT(recursive, this_k(), -1,wait); return; } // Step 4 if (this_k->is_initialized()) { - DTRACE_CLASSINIT_PROBE_WAIT(concurrent, InstanceKlass::cast(this_k()), -1,wait); + DTRACE_CLASSINIT_PROBE_WAIT(concurrent, this_k(), -1,wait); return; } // Step 5 if (this_k->is_in_error_state()) { - DTRACE_CLASSINIT_PROBE_WAIT(erroneous, InstanceKlass::cast(this_k()), -1,wait); + DTRACE_CLASSINIT_PROBE_WAIT(erroneous, this_k(), -1,wait); ResourceMark rm(THREAD); const char* desc = "Could not initialize class "; const char* className = this_k->external_name(); @@ -810,7 +810,7 @@ void InstanceKlass::initialize_impl(instanceKlassHandle this_k, TRAPS) { this_k->set_initialization_state_and_notify(initialization_error, THREAD); // Locks object, set state, and notify all waiting threads CLEAR_PENDING_EXCEPTION; // ignore any exception thrown, superclass initialization error is thrown below } - DTRACE_CLASSINIT_PROBE_WAIT(super__failed, InstanceKlass::cast(this_k()), -1,wait); + DTRACE_CLASSINIT_PROBE_WAIT(super__failed, this_k(), -1,wait); THROW_OOP(e()); } } @@ -826,7 +826,7 @@ void InstanceKlass::initialize_impl(instanceKlassHandle this_k, TRAPS) { { assert(THREAD->is_Java_thread(), "non-JavaThread in initialize_impl"); JavaThread* jt = (JavaThread*)THREAD; - DTRACE_CLASSINIT_PROBE_WAIT(clinit, InstanceKlass::cast(this_k()), -1,wait); + DTRACE_CLASSINIT_PROBE_WAIT(clinit, this_k(), -1,wait); // Timer includes any side effects of class initialization (resolution, // etc), but not recursive entry into call_class_initializer(). PerfClassTraceTime timer(ClassLoader::perf_class_init_time(), @@ -860,7 +860,7 @@ void InstanceKlass::initialize_impl(instanceKlassHandle this_k, TRAPS) { // JVMTI internal flag reset is needed in order to report ExceptionInInitializerError JvmtiExport::clear_detected_exception((JavaThread*)THREAD); } - DTRACE_CLASSINIT_PROBE_WAIT(error, InstanceKlass::cast(this_k()), -1,wait); + DTRACE_CLASSINIT_PROBE_WAIT(error, this_k(), -1,wait); if (e->is_a(SystemDictionary::Error_klass())) { THROW_OOP(e()); } else { @@ -870,7 +870,7 @@ void InstanceKlass::initialize_impl(instanceKlassHandle this_k, TRAPS) { &args); } } - DTRACE_CLASSINIT_PROBE_WAIT(end, InstanceKlass::cast(this_k()), -1,wait); + DTRACE_CLASSINIT_PROBE_WAIT(end, this_k(), -1,wait); } @@ -907,7 +907,7 @@ void InstanceKlass::add_implementor(Klass* k) { // Filter out subclasses whose supers already implement me. // (Note: CHA must walk subclasses of direct implementors // in order to locate indirect implementors.) - Klass* sk = InstanceKlass::cast(k)->super(); + Klass* sk = k->super(); if (sk != NULL && InstanceKlass::cast(sk)->implements_interface(this)) // We only need to check one immediate superclass, since the // implements_interface query looks at transitive_interfaces. @@ -955,8 +955,7 @@ bool InstanceKlass::can_be_primary_super_slow() const { GrowableArray* InstanceKlass::compute_secondary_supers(int num_extra_slots) { // The secondaries are the implemented interfaces. - InstanceKlass* ik = InstanceKlass::cast(this); - Array* interfaces = ik->transitive_interfaces(); + Array* interfaces = transitive_interfaces(); int num_secondaries = num_extra_slots + interfaces->length(); if (num_secondaries == 0) { // Must share this for correct bootstrapping! @@ -1532,7 +1531,7 @@ Method* InstanceKlass::uncached_lookup_method(Symbol* name, Symbol* signature, O if (method != NULL) { return method; } - klass = InstanceKlass::cast(klass)->super(); + klass = klass->super(); overpass_local_mode = skip_overpass; // Always ignore overpass methods in superclasses } return NULL; @@ -1541,13 +1540,13 @@ Method* InstanceKlass::uncached_lookup_method(Symbol* name, Symbol* signature, O #ifdef ASSERT // search through class hierarchy and return true if this class or // one of the superclasses was redefined -bool InstanceKlass::has_redefined_this_or_super() const { - const InstanceKlass* klass = this; +bool InstanceKlass::has_redefined_this_or_super() { + Klass* klass = this; while (klass != NULL) { - if (klass->has_been_redefined()) { + if (InstanceKlass::cast(klass)->has_been_redefined()) { return true; } - klass = InstanceKlass::cast(klass->super()); + klass = klass->super(); } return false; } @@ -2325,32 +2324,18 @@ const char* InstanceKlass::signature_name() const { // different verisons of is_same_class_package bool InstanceKlass::is_same_class_package(Klass* class2) { - Klass* class1 = this; - oop classloader1 = InstanceKlass::cast(class1)->class_loader(); - Symbol* classname1 = class1->name(); - if (class2->oop_is_objArray()) { class2 = ObjArrayKlass::cast(class2)->bottom_klass(); } - oop classloader2; - if (class2->oop_is_instance()) { - classloader2 = InstanceKlass::cast(class2)->class_loader(); - } else { - assert(class2->oop_is_typeArray(), "should be type array"); - classloader2 = NULL; - } + oop classloader2 = class2->class_loader(); Symbol* classname2 = class2->name(); - return InstanceKlass::is_same_class_package(classloader1, classname1, + return InstanceKlass::is_same_class_package(class_loader(), name(), classloader2, classname2); } bool InstanceKlass::is_same_class_package(oop classloader2, Symbol* classname2) { - Klass* class1 = this; - oop classloader1 = InstanceKlass::cast(class1)->class_loader(); - Symbol* classname1 = class1->name(); - - return InstanceKlass::is_same_class_package(classloader1, classname1, + return InstanceKlass::is_same_class_package(class_loader(), name(), classloader2, classname2); } @@ -2910,7 +2895,8 @@ void InstanceKlass::print_on(outputStream* st) const { ((InstanceKlass*)this)->do_local_static_fields(&print_static_field); st->print_cr(BULLET"---- non-static fields (%d words):", nonstatic_field_size()); FieldPrinter print_nonstatic_field(st); - ((InstanceKlass*)this)->do_nonstatic_fields(&print_nonstatic_field); + InstanceKlass* ik = const_cast(this); + ik->do_nonstatic_fields(&print_nonstatic_field); st->print(BULLET"non-static oop maps: "); OopMapBlock* map = start_of_nonstatic_oop_maps(); diff --git a/hotspot/src/share/vm/oops/instanceKlass.hpp b/hotspot/src/share/vm/oops/instanceKlass.hpp index ebcfaa17b90..fd58248dd7b 100644 --- a/hotspot/src/share/vm/oops/instanceKlass.hpp +++ b/hotspot/src/share/vm/oops/instanceKlass.hpp @@ -862,7 +862,7 @@ public: #ifdef ASSERT // check whether this class or one of its superclasses was redefined - bool has_redefined_this_or_super() const; + bool has_redefined_this_or_super(); #endif // Access to the implementor of an interface. @@ -922,7 +922,8 @@ public: // Casting from Klass* static InstanceKlass* cast(Klass* k) { - assert(k == NULL || k->oop_is_instance(), "cast to InstanceKlass"); + assert(k != NULL, "k should not be null"); + assert(k->oop_is_instance(), "cast to InstanceKlass"); return static_cast(k); } diff --git a/hotspot/src/share/vm/oops/klass.cpp b/hotspot/src/share/vm/oops/klass.cpp index d4be10a3a35..0435116486f 100644 --- a/hotspot/src/share/vm/oops/klass.cpp +++ b/hotspot/src/share/vm/oops/klass.cpp @@ -557,9 +557,11 @@ Klass* Klass::array_klass_impl(bool or_null, TRAPS) { oop Klass::class_loader() const { return class_loader_data()->class_loader(); } +// In product mode, this function doesn't have virtual function calls so +// there might be some performance advantage to handling InstanceKlass here. const char* Klass::external_name() const { if (oop_is_instance()) { - InstanceKlass* ik = (InstanceKlass*) this; + const InstanceKlass* ik = static_cast(this); if (ik->is_anonymous()) { intptr_t hash = 0; if (ik->java_mirror() != NULL) { @@ -687,14 +689,8 @@ void Klass::oop_verify_on(oop obj, outputStream* st) { #ifndef PRODUCT bool Klass::verify_vtable_index(int i) { - if (oop_is_instance()) { - int limit = ((InstanceKlass*)this)->vtable_length()/vtableEntry::size(); - assert(i >= 0 && i < limit, "index %d out of bounds %d", i, limit); - } else { - assert(oop_is_array(), "Must be"); - int limit = ((ArrayKlass*)this)->vtable_length()/vtableEntry::size(); - assert(i >= 0 && i < limit, "index %d out of bounds %d", i, limit); - } + int limit = vtable_length()/vtableEntry::size(); + assert(i >= 0 && i < limit, "index %d out of bounds %d", i, limit); return true; } diff --git a/hotspot/src/share/vm/oops/klass.hpp b/hotspot/src/share/vm/oops/klass.hpp index aa8aabb61fa..4b8ac7f9d53 100644 --- a/hotspot/src/share/vm/oops/klass.hpp +++ b/hotspot/src/share/vm/oops/klass.hpp @@ -373,8 +373,8 @@ protected: #endif // vtables - virtual klassVtable* vtable() const { return NULL; } - virtual int vtable_length() const { return 0; } + virtual klassVtable* vtable() const = 0; + virtual int vtable_length() const = 0; // subclass check bool is_subclass_of(const Klass* k) const; diff --git a/hotspot/src/share/vm/oops/klassVtable.cpp b/hotspot/src/share/vm/oops/klassVtable.cpp index 9872b3fca55..4f58a59e7f3 100644 --- a/hotspot/src/share/vm/oops/klassVtable.cpp +++ b/hotspot/src/share/vm/oops/klassVtable.cpp @@ -39,9 +39,7 @@ #include "utilities/copy.hpp" inline InstanceKlass* klassVtable::ik() const { - Klass* k = _klass(); - assert(k->oop_is_instance(), "not an InstanceKlass"); - return (InstanceKlass*)k; + return InstanceKlass::cast(_klass()); } @@ -66,8 +64,7 @@ void klassVtable::compute_vtable_size_and_num_mirandas( int vtable_length = 0; // start off with super's vtable length - InstanceKlass* sk = (InstanceKlass*)super; - vtable_length = super == NULL ? 0 : sk->vtable_length(); + vtable_length = super == NULL ? 0 : super->vtable_length(); // go thru each method in the methods table to see if it needs a new entry int len = methods->length(); @@ -131,10 +128,7 @@ int klassVtable::initialize_from_super(KlassHandle super) { return 0; } else { // copy methods from superKlass - // can't inherit from array class, so must be InstanceKlass - assert(super->oop_is_instance(), "must be instance klass"); - InstanceKlass* sk = (InstanceKlass*)super(); - klassVtable* superVtable = sk->vtable(); + klassVtable* superVtable = super->vtable(); assert(superVtable->length() <= _length, "vtable too short"); #ifdef ASSERT superVtable->verify(tty, true); @@ -143,7 +137,7 @@ int klassVtable::initialize_from_super(KlassHandle super) { #ifndef PRODUCT if (PrintVtables && Verbose) { ResourceMark rm; - tty->print_cr("copy vtable from %s to %s size %d", sk->internal_name(), klass()->internal_name(), _length); + tty->print_cr("copy vtable from %s to %s size %d", super->internal_name(), klass()->internal_name(), _length); } #endif return superVtable->length(); @@ -303,7 +297,7 @@ InstanceKlass* klassVtable::find_transitive_override(InstanceKlass* initialsuper break; } // if no override found yet, continue to search up - superk = InstanceKlass::cast(superk->super()); + superk = superk->super() == NULL ? NULL : InstanceKlass::cast(superk->super()); } return superk; @@ -761,15 +755,14 @@ bool klassVtable::is_miranda(Method* m, Array* class_methods, return false; } - InstanceKlass* cursuper; - // Iterate on all superclasses, which should have instanceKlasses + // Iterate on all superclasses, which should be InstanceKlasses. // Note that we explicitly look for overpasses at each level. // Overpasses may or may not exist for supers for pass 1, // they should have been created for pass 2 and later. - for (cursuper = InstanceKlass::cast(super); cursuper != NULL; cursuper = (InstanceKlass*)cursuper->super()) + for (Klass* cursuper = super; cursuper != NULL; cursuper = cursuper->super()) { - if (cursuper->find_local_method(name, signature, + if (InstanceKlass::cast(cursuper)->find_local_method(name, signature, Klass::find_overpass, Klass::skip_static, Klass::skip_private) != NULL) { return false; } diff --git a/hotspot/src/share/vm/oops/method.cpp b/hotspot/src/share/vm/oops/method.cpp index b4796454b3a..8c2e6f6462a 100644 --- a/hotspot/src/share/vm/oops/method.cpp +++ b/hotspot/src/share/vm/oops/method.cpp @@ -299,10 +299,7 @@ int Method::size(bool is_native) { Symbol* Method::klass_name() const { - Klass* k = method_holder(); - assert(k->is_klass(), "must be klass"); - InstanceKlass* ik = (InstanceKlass*) k; - return ik->name(); + return method_holder()->name(); } diff --git a/hotspot/src/share/vm/prims/jvm.cpp b/hotspot/src/share/vm/prims/jvm.cpp index c4e5b4e4a41..475301700d3 100644 --- a/hotspot/src/share/vm/prims/jvm.cpp +++ b/hotspot/src/share/vm/prims/jvm.cpp @@ -1156,7 +1156,7 @@ static bool is_authorized(Handle context, instanceKlassHandle klass, TRAPS) { // Create an AccessControlContext with a protection domain with null codesource // and null permissions - which gives no permissions. oop create_dummy_access_control_context(TRAPS) { - InstanceKlass* pd_klass = InstanceKlass::cast(SystemDictionary::ProtectionDomain_klass()); + InstanceKlass* pd_klass = SystemDictionary::ProtectionDomain_klass(); Handle obj = pd_klass->allocate_instance_handle(CHECK_NULL); // Call constructor ProtectionDomain(null, null); JavaValue result(T_VOID); diff --git a/hotspot/src/share/vm/prims/jvmtiRedefineClasses.cpp b/hotspot/src/share/vm/prims/jvmtiRedefineClasses.cpp index df8783987c3..c57cf8e7827 100644 --- a/hotspot/src/share/vm/prims/jvmtiRedefineClasses.cpp +++ b/hotspot/src/share/vm/prims/jvmtiRedefineClasses.cpp @@ -104,7 +104,7 @@ bool VM_RedefineClasses::doit_prologue() { ClassLoaderData* cld = _scratch_classes[i]->class_loader_data(); // Free the memory for this class at class unloading time. Not before // because CMS might think this is still live. - cld->add_to_deallocate_list((InstanceKlass*)_scratch_classes[i]); + cld->add_to_deallocate_list(InstanceKlass::cast(_scratch_classes[i])); } } // Free os::malloc allocated memory in load_new_class_version. @@ -4133,7 +4133,7 @@ void VM_RedefineClasses::increment_class_counter(InstanceKlass *ik, TRAPS) { subk = subk->next_sibling()) { if (subk->oop_is_instance()) { // Only update instanceKlasses - InstanceKlass *subik = (InstanceKlass*)subk; + InstanceKlass *subik = InstanceKlass::cast(subk); // recursively do subclasses of the current subclass increment_class_counter(subik, THREAD); } diff --git a/hotspot/src/share/vm/prims/jvmtiTagMap.cpp b/hotspot/src/share/vm/prims/jvmtiTagMap.cpp index ecc28a28d32..9f53a3f32cd 100644 --- a/hotspot/src/share/vm/prims/jvmtiTagMap.cpp +++ b/hotspot/src/share/vm/prims/jvmtiTagMap.cpp @@ -588,7 +588,7 @@ class CallbackWrapper : public StackObj { _obj_tag = (_entry == NULL) ? 0 : _entry->tag(); // get the class and the class's tag value - assert(InstanceKlass::cast(SystemDictionary::Class_klass())->is_mirror_instance_klass(), "Is not?"); + assert(SystemDictionary::Class_klass()->is_mirror_instance_klass(), "Is not?"); _klass_tag = tag_for(tag_map, _o->klass()->java_mirror()); } diff --git a/hotspot/src/share/vm/runtime/reflection.cpp b/hotspot/src/share/vm/runtime/reflection.cpp index 443e6cd184e..d610527cf36 100644 --- a/hotspot/src/share/vm/runtime/reflection.cpp +++ b/hotspot/src/share/vm/runtime/reflection.cpp @@ -647,11 +647,9 @@ Handle Reflection::new_type(Symbol* signature, KlassHandle k, TRAPS) { return Handle(THREAD, Universe::java_mirror(type)); } - oop loader = InstanceKlass::cast(k())->class_loader(); - oop protection_domain = k()->protection_domain(); Klass* result = SystemDictionary::resolve_or_fail(signature, - Handle(THREAD, loader), - Handle(THREAD, protection_domain), + Handle(THREAD, k->class_loader()), + Handle(THREAD, k->protection_domain()), true, CHECK_(Handle())); if (TraceClassResolution) { diff --git a/hotspot/src/share/vm/runtime/thread.cpp b/hotspot/src/share/vm/runtime/thread.cpp index 1fa6e2a7325..f57cc8a4053 100644 --- a/hotspot/src/share/vm/runtime/thread.cpp +++ b/hotspot/src/share/vm/runtime/thread.cpp @@ -2101,7 +2101,7 @@ void JavaThread::check_and_handle_async_exceptions(bool check_unsafe_error) { frame f = last_frame(); tty->print(" (pc: " INTPTR_FORMAT " sp: " INTPTR_FORMAT " )", p2i(f.pc()), p2i(f.sp())); } - tty->print_cr(" of type: %s", InstanceKlass::cast(_pending_async_exception->klass())->external_name()); + tty->print_cr(" of type: %s", _pending_async_exception->klass()->external_name()); } _pending_async_exception = NULL; clear_has_async_exception(); @@ -2219,10 +2219,10 @@ void JavaThread::send_thread_stop(oop java_throwable) { if (TraceExceptions) { ResourceMark rm; - tty->print_cr("Pending Async. exception installed of type: %s", InstanceKlass::cast(_pending_async_exception->klass())->external_name()); + tty->print_cr("Pending Async. exception installed of type: %s", _pending_async_exception->klass()->external_name()); } // for AbortVMOnException flag - Exceptions::debug_check_abort(InstanceKlass::cast(_pending_async_exception->klass())->external_name()); + Exceptions::debug_check_abort(_pending_async_exception->klass()->external_name()); } } diff --git a/hotspot/src/share/vm/runtime/vmStructs.cpp b/hotspot/src/share/vm/runtime/vmStructs.cpp index 012a2574343..b9bf5efb1c5 100644 --- a/hotspot/src/share/vm/runtime/vmStructs.cpp +++ b/hotspot/src/share/vm/runtime/vmStructs.cpp @@ -688,42 +688,42 @@ typedef CompactHashtable SymbolCompactHashTable; static_field(SystemDictionary, _shared_dictionary, Dictionary*) \ static_field(SystemDictionary, _system_loader_lock_obj, oop) \ static_field(SystemDictionary, _loader_constraints, LoaderConstraintTable*) \ - static_field(SystemDictionary, WK_KLASS(Object_klass), Klass*) \ - static_field(SystemDictionary, WK_KLASS(String_klass), Klass*) \ - static_field(SystemDictionary, WK_KLASS(Class_klass), Klass*) \ - static_field(SystemDictionary, WK_KLASS(Cloneable_klass), Klass*) \ - static_field(SystemDictionary, WK_KLASS(ClassLoader_klass), Klass*) \ - static_field(SystemDictionary, WK_KLASS(Serializable_klass), Klass*) \ - static_field(SystemDictionary, WK_KLASS(System_klass), Klass*) \ - static_field(SystemDictionary, WK_KLASS(Throwable_klass), Klass*) \ - static_field(SystemDictionary, WK_KLASS(ThreadDeath_klass), Klass*) \ - static_field(SystemDictionary, WK_KLASS(Error_klass), Klass*) \ - static_field(SystemDictionary, WK_KLASS(Exception_klass), Klass*) \ - static_field(SystemDictionary, WK_KLASS(RuntimeException_klass), Klass*) \ - static_field(SystemDictionary, WK_KLASS(ClassNotFoundException_klass), Klass*) \ - static_field(SystemDictionary, WK_KLASS(NoClassDefFoundError_klass), Klass*) \ - static_field(SystemDictionary, WK_KLASS(LinkageError_klass), Klass*) \ - static_field(SystemDictionary, WK_KLASS(ClassCastException_klass), Klass*) \ - static_field(SystemDictionary, WK_KLASS(ArrayStoreException_klass), Klass*) \ - static_field(SystemDictionary, WK_KLASS(VirtualMachineError_klass), Klass*) \ - static_field(SystemDictionary, WK_KLASS(OutOfMemoryError_klass), Klass*) \ - static_field(SystemDictionary, WK_KLASS(StackOverflowError_klass), Klass*) \ - static_field(SystemDictionary, WK_KLASS(ProtectionDomain_klass), Klass*) \ - static_field(SystemDictionary, WK_KLASS(AccessControlContext_klass), Klass*) \ - static_field(SystemDictionary, WK_KLASS(SecureClassLoader_klass), Klass*) \ - static_field(SystemDictionary, WK_KLASS(Reference_klass), Klass*) \ - static_field(SystemDictionary, WK_KLASS(SoftReference_klass), Klass*) \ - static_field(SystemDictionary, WK_KLASS(WeakReference_klass), Klass*) \ - static_field(SystemDictionary, WK_KLASS(FinalReference_klass), Klass*) \ - static_field(SystemDictionary, WK_KLASS(PhantomReference_klass), Klass*) \ - static_field(SystemDictionary, WK_KLASS(Cleaner_klass), Klass*) \ - static_field(SystemDictionary, WK_KLASS(Finalizer_klass), Klass*) \ - static_field(SystemDictionary, WK_KLASS(Thread_klass), Klass*) \ - static_field(SystemDictionary, WK_KLASS(ThreadGroup_klass), Klass*) \ - static_field(SystemDictionary, WK_KLASS(Properties_klass), Klass*) \ - static_field(SystemDictionary, WK_KLASS(StringBuffer_klass), Klass*) \ - static_field(SystemDictionary, WK_KLASS(MethodHandle_klass), Klass*) \ - static_field(SystemDictionary, _box_klasses[0], Klass*) \ + static_field(SystemDictionary, WK_KLASS(Object_klass), InstanceKlass*) \ + static_field(SystemDictionary, WK_KLASS(String_klass), InstanceKlass*) \ + static_field(SystemDictionary, WK_KLASS(Class_klass), InstanceKlass*) \ + static_field(SystemDictionary, WK_KLASS(Cloneable_klass), InstanceKlass*) \ + static_field(SystemDictionary, WK_KLASS(ClassLoader_klass), InstanceKlass*) \ + static_field(SystemDictionary, WK_KLASS(Serializable_klass), InstanceKlass*) \ + static_field(SystemDictionary, WK_KLASS(System_klass), InstanceKlass*) \ + static_field(SystemDictionary, WK_KLASS(Throwable_klass), InstanceKlass*) \ + static_field(SystemDictionary, WK_KLASS(ThreadDeath_klass), InstanceKlass*) \ + static_field(SystemDictionary, WK_KLASS(Error_klass), InstanceKlass*) \ + static_field(SystemDictionary, WK_KLASS(Exception_klass), InstanceKlass*) \ + static_field(SystemDictionary, WK_KLASS(RuntimeException_klass), InstanceKlass*) \ + static_field(SystemDictionary, WK_KLASS(ClassNotFoundException_klass), InstanceKlass*) \ + static_field(SystemDictionary, WK_KLASS(NoClassDefFoundError_klass), InstanceKlass*) \ + static_field(SystemDictionary, WK_KLASS(LinkageError_klass), InstanceKlass*) \ + static_field(SystemDictionary, WK_KLASS(ClassCastException_klass), InstanceKlass*) \ + static_field(SystemDictionary, WK_KLASS(ArrayStoreException_klass), InstanceKlass*) \ + static_field(SystemDictionary, WK_KLASS(VirtualMachineError_klass), InstanceKlass*) \ + static_field(SystemDictionary, WK_KLASS(OutOfMemoryError_klass), InstanceKlass*) \ + static_field(SystemDictionary, WK_KLASS(StackOverflowError_klass), InstanceKlass*) \ + static_field(SystemDictionary, WK_KLASS(ProtectionDomain_klass), InstanceKlass*) \ + static_field(SystemDictionary, WK_KLASS(AccessControlContext_klass), InstanceKlass*) \ + static_field(SystemDictionary, WK_KLASS(SecureClassLoader_klass), InstanceKlass*) \ + static_field(SystemDictionary, WK_KLASS(Reference_klass), InstanceKlass*) \ + static_field(SystemDictionary, WK_KLASS(SoftReference_klass), InstanceKlass*) \ + static_field(SystemDictionary, WK_KLASS(WeakReference_klass), InstanceKlass*) \ + static_field(SystemDictionary, WK_KLASS(FinalReference_klass), InstanceKlass*) \ + static_field(SystemDictionary, WK_KLASS(PhantomReference_klass), InstanceKlass*) \ + static_field(SystemDictionary, WK_KLASS(Cleaner_klass), InstanceKlass*) \ + static_field(SystemDictionary, WK_KLASS(Finalizer_klass), InstanceKlass*) \ + static_field(SystemDictionary, WK_KLASS(Thread_klass), InstanceKlass*) \ + static_field(SystemDictionary, WK_KLASS(ThreadGroup_klass), InstanceKlass*) \ + static_field(SystemDictionary, WK_KLASS(Properties_klass), InstanceKlass*) \ + static_field(SystemDictionary, WK_KLASS(StringBuffer_klass), InstanceKlass*) \ + static_field(SystemDictionary, WK_KLASS(MethodHandle_klass), InstanceKlass*) \ + static_field(SystemDictionary, _box_klasses[0], InstanceKlass*) \ static_field(SystemDictionary, _java_system_loader, oop) \ \ /*************/ \ diff --git a/hotspot/src/share/vm/services/heapDumper.cpp b/hotspot/src/share/vm/services/heapDumper.cpp index 937d909b6f4..7e4109fbf9c 100644 --- a/hotspot/src/share/vm/services/heapDumper.cpp +++ b/hotspot/src/share/vm/services/heapDumper.cpp @@ -895,9 +895,7 @@ void DumperSupport::dump_instance(DumpWriter* writer, oop o) { // creates HPROF_GC_CLASS_DUMP record for the given class and each of // its array classes void DumperSupport::dump_class_and_array_classes(DumpWriter* writer, Klass* k) { - Klass* klass = k; - assert(klass->oop_is_instance(), "not an InstanceKlass"); - InstanceKlass* ik = (InstanceKlass*)klass; + InstanceKlass* ik = InstanceKlass::cast(k); // Ignore the class if it hasn't been initialized yet if (!ik->is_linked()) { @@ -939,7 +937,7 @@ void DumperSupport::dump_class_and_array_classes(DumpWriter* writer, Klass* k) { dump_instance_field_descriptors(writer, k); // array classes - k = klass->array_klass_or_null(); + k = k->array_klass_or_null(); while (k != NULL) { Klass* klass = k; assert(klass->oop_is_objArray(), "not an ObjArrayKlass"); @@ -1396,7 +1394,7 @@ class VM_HeapDumper : public VM_GC_Operation { if (oome) { assert(!Thread::current()->is_VM_thread(), "Dump from OutOfMemoryError cannot be called by the VMThread"); // get OutOfMemoryError zero-parameter constructor - InstanceKlass* oome_ik = InstanceKlass::cast(SystemDictionary::OutOfMemoryError_klass()); + InstanceKlass* oome_ik = SystemDictionary::OutOfMemoryError_klass(); _oome_constructor = oome_ik->find_method(vmSymbols::object_initializer_name(), vmSymbols::void_method_signature()); // get thread throwing OOME when generating the heap dump at OOME diff --git a/hotspot/src/share/vm/services/threadService.cpp b/hotspot/src/share/vm/services/threadService.cpp index 0551deff70c..d0598e46195 100644 --- a/hotspot/src/share/vm/services/threadService.cpp +++ b/hotspot/src/share/vm/services/threadService.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2015, 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 @@ -505,8 +505,7 @@ void StackFrameInfo::print_on(outputStream* st) const { int len = (_locked_monitors != NULL ? _locked_monitors->length() : 0); for (int i = 0; i < len; i++) { oop o = _locked_monitors->at(i); - InstanceKlass* ik = InstanceKlass::cast(o->klass()); - st->print_cr("\t- locked <" INTPTR_FORMAT "> (a %s)", p2i(o), ik->external_name()); + st->print_cr("\t- locked <" INTPTR_FORMAT "> (a %s)", p2i(o), o->klass()->external_name()); } } @@ -729,8 +728,7 @@ void ConcurrentLocksDump::print_locks_on(JavaThread* t, outputStream* st) { for (int i = 0; i < locks->length(); i++) { instanceOop obj = locks->at(i); - InstanceKlass* ik = InstanceKlass::cast(obj->klass()); - st->print_cr("\t- <" INTPTR_FORMAT "> (a %s)", p2i(obj), ik->external_name()); + st->print_cr("\t- <" INTPTR_FORMAT "> (a %s)", p2i(obj), obj->klass()->external_name()); } st->cr(); } @@ -887,7 +885,7 @@ void DeadlockCycle::print_on(outputStream* st) const { oop obj = (oop)waitingToLockMonitor->object(); if (obj != NULL) { st->print(" (object " INTPTR_FORMAT ", a %s)", p2i(obj), - (InstanceKlass::cast(obj->klass()))->external_name()); + obj->klass()->external_name()); if (!currentThread->current_pending_monitor_is_from_java()) { owner_desc = "\n in JNI, which is held by"; @@ -911,7 +909,7 @@ void DeadlockCycle::print_on(outputStream* st) const { } else { st->print(" waiting for ownable synchronizer " INTPTR_FORMAT ", (a %s)", p2i(waitingToLockBlocker), - (InstanceKlass::cast(waitingToLockBlocker->klass()))->external_name()); + waitingToLockBlocker->klass()->external_name()); assert(waitingToLockBlocker->is_a(SystemDictionary::abstract_ownable_synchronizer_klass()), "Must be an AbstractOwnableSynchronizer"); oop ownerObj = java_util_concurrent_locks_AbstractOwnableSynchronizer::get_owner_threadObj(waitingToLockBlocker); diff --git a/hotspot/src/share/vm/utilities/exceptions.cpp b/hotspot/src/share/vm/utilities/exceptions.cpp index 7b6c5ea4008..ef14a9ff121 100644 --- a/hotspot/src/share/vm/utilities/exceptions.cpp +++ b/hotspot/src/share/vm/utilities/exceptions.cpp @@ -502,5 +502,5 @@ void Exceptions::debug_check_abort_helper(Handle exception, const char* message) message = java_lang_String::as_utf8_string(msg); } } - debug_check_abort(InstanceKlass::cast(exception()->klass())->external_name(), message); + debug_check_abort(exception()->klass()->external_name(), message); }