mirror of
https://github.com/openjdk/jdk.git
synced 2025-09-20 02:54:35 +02:00
8026822: metaspace/flags/maxMetaspaceSize throws OOM of unexpected type.java.lang.OutOfMemoryError: Compressed class space
Incorporate chunk size when seeing if OutOfMemoryError was caused by Metaspace or Compressed class space. Reviewed-by: stefank, coleenp
This commit is contained in:
parent
86cd1aaa73
commit
bf7f4866eb
3 changed files with 22 additions and 4 deletions
|
@ -3312,6 +3312,11 @@ MetaWord* Metaspace::allocate(ClassLoaderData* loader_data, size_t word_size,
|
|||
return result;
|
||||
}
|
||||
|
||||
size_t Metaspace::class_chunk_size(size_t word_size) {
|
||||
assert(using_class_space(), "Has to use class space");
|
||||
return class_vsm()->calc_chunk_size(word_size);
|
||||
}
|
||||
|
||||
void Metaspace::report_metadata_oome(ClassLoaderData* loader_data, size_t word_size, MetadataType mdtype, TRAPS) {
|
||||
// If result is still null, we are out of memory.
|
||||
if (Verbose && TraceMetadataChunkAllocation) {
|
||||
|
@ -3323,9 +3328,19 @@ void Metaspace::report_metadata_oome(ClassLoaderData* loader_data, size_t word_s
|
|||
MetaspaceAux::dump(gclog_or_tty);
|
||||
}
|
||||
|
||||
bool out_of_compressed_class_space = false;
|
||||
if (is_class_space_allocation(mdtype)) {
|
||||
Metaspace* metaspace = loader_data->metaspace_non_null();
|
||||
out_of_compressed_class_space =
|
||||
MetaspaceAux::committed_bytes(Metaspace::ClassType) +
|
||||
(metaspace->class_chunk_size(word_size) * BytesPerWord) >
|
||||
CompressedClassSpaceSize;
|
||||
}
|
||||
|
||||
// -XX:+HeapDumpOnOutOfMemoryError and -XX:OnOutOfMemoryError support
|
||||
const char* space_string = is_class_space_allocation(mdtype) ? "Compressed class space" :
|
||||
"Metadata space";
|
||||
const char* space_string = out_of_compressed_class_space ?
|
||||
"Compressed class space" : "Metaspace";
|
||||
|
||||
report_java_out_of_memory(space_string);
|
||||
|
||||
if (JvmtiExport::should_post_resource_exhausted()) {
|
||||
|
@ -3338,7 +3353,7 @@ void Metaspace::report_metadata_oome(ClassLoaderData* loader_data, size_t word_s
|
|||
vm_exit_during_initialization("OutOfMemoryError", space_string);
|
||||
}
|
||||
|
||||
if (is_class_space_allocation(mdtype)) {
|
||||
if (out_of_compressed_class_space) {
|
||||
THROW_OOP(Universe::out_of_memory_error_class_metaspace());
|
||||
} else {
|
||||
THROW_OOP(Universe::out_of_memory_error_metaspace());
|
||||
|
|
|
@ -192,6 +192,8 @@ class Metaspace : public CHeapObj<mtClass> {
|
|||
AllocRecord * _alloc_record_head;
|
||||
AllocRecord * _alloc_record_tail;
|
||||
|
||||
size_t class_chunk_size(size_t word_size);
|
||||
|
||||
public:
|
||||
|
||||
Metaspace(Mutex* lock, MetaspaceType type);
|
||||
|
@ -252,6 +254,7 @@ class Metaspace : public CHeapObj<mtClass> {
|
|||
static bool is_class_space_allocation(MetadataType mdType) {
|
||||
return mdType == ClassType && using_class_space();
|
||||
}
|
||||
|
||||
};
|
||||
|
||||
class MetaspaceAux : AllStatic {
|
||||
|
|
|
@ -1029,7 +1029,7 @@ bool universe_post_init() {
|
|||
Handle msg = java_lang_String::create_from_str("Java heap space", CHECK_false);
|
||||
java_lang_Throwable::set_message(Universe::_out_of_memory_error_java_heap, msg());
|
||||
|
||||
msg = java_lang_String::create_from_str("Metadata space", CHECK_false);
|
||||
msg = java_lang_String::create_from_str("Metaspace", CHECK_false);
|
||||
java_lang_Throwable::set_message(Universe::_out_of_memory_error_metaspace, msg());
|
||||
msg = java_lang_String::create_from_str("Compressed class space", CHECK_false);
|
||||
java_lang_Throwable::set_message(Universe::_out_of_memory_error_class_metaspace, msg());
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue