8008549: NPG: SystemDictionary::find(...) unnecessarily keeps class loaders alive
SystemDictionary::find(...) should not create and register ClassLoaderData objects for class loaders. Co-authored-by: Erik Helin <erik.helin@oracle.com> Reviewed-by: coleenp, acorn
This commit is contained in:
parent
1a74b23a2f
commit
9ed09d08f5
@ -234,6 +234,7 @@ class ClassLoaderData : public CHeapObj<mtClass> {
|
|||||||
void add_to_deallocate_list(Metadata* m);
|
void add_to_deallocate_list(Metadata* m);
|
||||||
|
|
||||||
static ClassLoaderData* class_loader_data(oop loader);
|
static ClassLoaderData* class_loader_data(oop loader);
|
||||||
|
static ClassLoaderData* class_loader_data_or_null(oop loader);
|
||||||
static ClassLoaderData* anonymous_class_loader_data(oop loader, TRAPS);
|
static ClassLoaderData* anonymous_class_loader_data(oop loader, TRAPS);
|
||||||
static void print_loader(ClassLoaderData *loader_data, outputStream *out);
|
static void print_loader(ClassLoaderData *loader_data, outputStream *out);
|
||||||
|
|
||||||
|
@ -25,9 +25,15 @@
|
|||||||
#include "classfile/classLoaderData.hpp"
|
#include "classfile/classLoaderData.hpp"
|
||||||
#include "classfile/javaClasses.hpp"
|
#include "classfile/javaClasses.hpp"
|
||||||
|
|
||||||
|
inline ClassLoaderData* ClassLoaderData::class_loader_data_or_null(oop loader) {
|
||||||
|
if (loader == NULL) {
|
||||||
|
return ClassLoaderData::the_null_class_loader_data();
|
||||||
|
}
|
||||||
|
return java_lang_ClassLoader::loader_data(loader);
|
||||||
|
}
|
||||||
|
|
||||||
inline ClassLoaderData* ClassLoaderData::class_loader_data(oop loader) {
|
inline ClassLoaderData* ClassLoaderData::class_loader_data(oop loader) {
|
||||||
if (loader == NULL) return ClassLoaderData::the_null_class_loader_data();
|
ClassLoaderData* loader_data = class_loader_data_or_null(loader);
|
||||||
ClassLoaderData* loader_data = java_lang_ClassLoader::loader_data(loader);
|
|
||||||
assert(loader_data != NULL, "Must be");
|
assert(loader_data != NULL, "Must be");
|
||||||
return loader_data;
|
return loader_data;
|
||||||
}
|
}
|
||||||
|
@ -347,6 +347,7 @@ void Dictionary::add_klass(Symbol* class_name, ClassLoaderData* loader_data,
|
|||||||
assert_locked_or_safepoint(SystemDictionary_lock);
|
assert_locked_or_safepoint(SystemDictionary_lock);
|
||||||
assert(obj() != NULL, "adding NULL obj");
|
assert(obj() != NULL, "adding NULL obj");
|
||||||
assert(obj()->name() == class_name, "sanity check on name");
|
assert(obj()->name() == class_name, "sanity check on name");
|
||||||
|
assert(loader_data != NULL, "Must be non-NULL");
|
||||||
|
|
||||||
unsigned int hash = compute_hash(class_name, loader_data);
|
unsigned int hash = compute_hash(class_name, loader_data);
|
||||||
int index = hash_to_index(hash);
|
int index = hash_to_index(hash);
|
||||||
|
@ -875,7 +875,13 @@ Klass* SystemDictionary::find(Symbol* class_name,
|
|||||||
// of the call to resolve_instance_class_or_null().
|
// of the call to resolve_instance_class_or_null().
|
||||||
// See evaluation 6790209 and 4474172 for more details.
|
// See evaluation 6790209 and 4474172 for more details.
|
||||||
class_loader = Handle(THREAD, java_lang_ClassLoader::non_reflection_class_loader(class_loader()));
|
class_loader = Handle(THREAD, java_lang_ClassLoader::non_reflection_class_loader(class_loader()));
|
||||||
ClassLoaderData* loader_data = register_loader(class_loader, CHECK_NULL);
|
ClassLoaderData* loader_data = ClassLoaderData::class_loader_data_or_null(class_loader());
|
||||||
|
|
||||||
|
if (loader_data == NULL) {
|
||||||
|
// If the ClassLoaderData has not been setup,
|
||||||
|
// then the class loader has no entries in the dictionary.
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
unsigned int d_hash = dictionary()->compute_hash(class_name, loader_data);
|
unsigned int d_hash = dictionary()->compute_hash(class_name, loader_data);
|
||||||
int d_index = dictionary()->hash_to_index(d_hash);
|
int d_index = dictionary()->hash_to_index(d_hash);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user