8295029: runtime/cds/appcds/LotsOfClasses.java fail with jfx
Reviewed-by: iklam, ccheung, gziemski
This commit is contained in:
parent
0233ba763d
commit
37f93b6728
@ -604,23 +604,16 @@ const int _default_loader_dictionary_size = 107;
|
|||||||
Dictionary* ClassLoaderData::create_dictionary() {
|
Dictionary* ClassLoaderData::create_dictionary() {
|
||||||
assert(!has_class_mirror_holder(), "class mirror holder cld does not have a dictionary");
|
assert(!has_class_mirror_holder(), "class mirror holder cld does not have a dictionary");
|
||||||
int size;
|
int size;
|
||||||
bool resizable = false;
|
|
||||||
if (_the_null_class_loader_data == NULL) {
|
if (_the_null_class_loader_data == NULL) {
|
||||||
size = _boot_loader_dictionary_size;
|
size = _boot_loader_dictionary_size;
|
||||||
resizable = true;
|
|
||||||
} else if (class_loader()->is_a(vmClasses::reflect_DelegatingClassLoader_klass())) {
|
} else if (class_loader()->is_a(vmClasses::reflect_DelegatingClassLoader_klass())) {
|
||||||
size = 1; // there's only one class in relection class loader and no initiated classes
|
size = 1; // there's only one class in relection class loader and no initiated classes
|
||||||
} else if (is_system_class_loader_data()) {
|
} else if (is_system_class_loader_data()) {
|
||||||
size = _boot_loader_dictionary_size;
|
size = _boot_loader_dictionary_size;
|
||||||
resizable = true;
|
|
||||||
} else {
|
} else {
|
||||||
size = _default_loader_dictionary_size;
|
size = _default_loader_dictionary_size;
|
||||||
resizable = true;
|
|
||||||
}
|
}
|
||||||
if (!DynamicallyResizeSystemDictionaries || DumpSharedSpaces) {
|
return new Dictionary(this, size);
|
||||||
resizable = false;
|
|
||||||
}
|
|
||||||
return new Dictionary(this, size, resizable);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Tell the GC to keep this klass alive. Needed while iterating ClassLoaderDataGraph,
|
// Tell the GC to keep this klass alive. Needed while iterating ClassLoaderDataGraph,
|
||||||
|
@ -53,8 +53,8 @@ const size_t END_SIZE = 24;
|
|||||||
// If a chain gets to 100 something might be wrong
|
// If a chain gets to 100 something might be wrong
|
||||||
const size_t REHASH_LEN = 100;
|
const size_t REHASH_LEN = 100;
|
||||||
|
|
||||||
Dictionary::Dictionary(ClassLoaderData* loader_data, size_t table_size, bool resizable)
|
Dictionary::Dictionary(ClassLoaderData* loader_data, size_t table_size)
|
||||||
: _resizable(resizable), _number_of_entries(0), _loader_data(loader_data) {
|
: _number_of_entries(0), _loader_data(loader_data) {
|
||||||
|
|
||||||
size_t start_size_log_2 = MAX2(ceil_log2(table_size), (size_t)2); // 2 is minimum size even though some dictionaries only have one entry
|
size_t start_size_log_2 = MAX2(ceil_log2(table_size), (size_t)2); // 2 is minimum size even though some dictionaries only have one entry
|
||||||
size_t current_size = ((size_t)1) << start_size_log_2;
|
size_t current_size = ((size_t)1) << start_size_log_2;
|
||||||
@ -104,8 +104,7 @@ int Dictionary::table_size() const {
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool Dictionary::check_if_needs_resize() {
|
bool Dictionary::check_if_needs_resize() {
|
||||||
return (_resizable &&
|
return ((_number_of_entries > (_resize_load_trigger * table_size())) &&
|
||||||
(_number_of_entries > (_resize_load_trigger * table_size())) &&
|
|
||||||
!_table->is_max_size_reached());
|
!_table->is_max_size_reached());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -480,8 +479,8 @@ void DictionaryEntry::print_count(outputStream *st) {
|
|||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
void Dictionary::print_size(outputStream* st) const {
|
void Dictionary::print_size(outputStream* st) const {
|
||||||
st->print_cr("Java dictionary (table_size=%d, classes=%d, resizable=%s)",
|
st->print_cr("Java dictionary (table_size=%d, classes=%d)",
|
||||||
table_size(), _number_of_entries, BOOL_TO_STR(_resizable));
|
table_size(), _number_of_entries);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Dictionary::print_on(outputStream* st) const {
|
void Dictionary::print_on(outputStream* st) const {
|
||||||
|
@ -41,7 +41,6 @@ template <typename T> class GrowableArray;
|
|||||||
class DictionaryEntry;
|
class DictionaryEntry;
|
||||||
|
|
||||||
class Dictionary : public CHeapObj<mtClass> {
|
class Dictionary : public CHeapObj<mtClass> {
|
||||||
bool _resizable;
|
|
||||||
int _number_of_entries;
|
int _number_of_entries;
|
||||||
|
|
||||||
class Config {
|
class Config {
|
||||||
@ -63,7 +62,7 @@ class Dictionary : public CHeapObj<mtClass> {
|
|||||||
int table_size() const;
|
int table_size() const;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
Dictionary(ClassLoaderData* loader_data, size_t table_size, bool resizable = false);
|
Dictionary(ClassLoaderData* loader_data, size_t table_size);
|
||||||
~Dictionary();
|
~Dictionary();
|
||||||
|
|
||||||
void add_klass(JavaThread* current, Symbol* class_name, InstanceKlass* obj);
|
void add_klass(JavaThread* current, Symbol* class_name, InstanceKlass* obj);
|
||||||
|
@ -676,9 +676,6 @@ const int ObjectAlignmentInBytes = 8;
|
|||||||
notproduct(bool, PrintClassLoaderDataGraphAtExit, false, \
|
notproduct(bool, PrintClassLoaderDataGraphAtExit, false, \
|
||||||
"Print the class loader data graph at exit") \
|
"Print the class loader data graph at exit") \
|
||||||
\
|
\
|
||||||
product(bool, DynamicallyResizeSystemDictionaries, true, DIAGNOSTIC, \
|
|
||||||
"Dynamically resize system dictionaries as needed") \
|
|
||||||
\
|
|
||||||
product(bool, AllowParallelDefineClass, false, \
|
product(bool, AllowParallelDefineClass, false, \
|
||||||
"Allow parallel defineClass requests for class loaders " \
|
"Allow parallel defineClass requests for class loaders " \
|
||||||
"registering as parallel capable") \
|
"registering as parallel capable") \
|
||||||
|
Loading…
x
Reference in New Issue
Block a user