From 680e1a3a2870f726d0f1fd3206de9bb5fc2e8667 Mon Sep 17 00:00:00 2001 From: Max Ockner Date: Mon, 13 Jun 2016 13:47:21 -0400 Subject: [PATCH] 8157490: JCK test vm/jni/DefineClass/dfcl001/dfcl00101m1/dfcl00101m1 crashes when run with -Xlog:classload=info Null stream->source() no longer causes error with -Xlog:class+load Reviewed-by: lfoltan, coleenp --- hotspot/src/share/vm/classfile/classFileParser.cpp | 10 +--------- hotspot/src/share/vm/oops/instanceKlass.cpp | 6 +++++- 2 files changed, 6 insertions(+), 10 deletions(-) diff --git a/hotspot/src/share/vm/classfile/classFileParser.cpp b/hotspot/src/share/vm/classfile/classFileParser.cpp index a09fc8e14d0..c6155dd6560 100644 --- a/hotspot/src/share/vm/classfile/classFileParser.cpp +++ b/hotspot/src/share/vm/classfile/classFileParser.cpp @@ -5356,15 +5356,7 @@ void ClassFileParser::fill_instance_klass(InstanceKlass* ik, bool changed_by_loa if (!is_internal()) { if (log_is_enabled(Info, class, load)) { ResourceMark rm; - const char* module_name = NULL; - static const size_t modules_image_name_len = strlen(MODULES_IMAGE_NAME); - size_t stream_len = strlen(_stream->source()); - // See if _stream->source() ends in "modules" - if (module_entry->is_named() && modules_image_name_len < stream_len && - (strncmp(_stream->source() + stream_len - modules_image_name_len, - MODULES_IMAGE_NAME, modules_image_name_len) == 0)) { - module_name = module_entry->name()->as_C_string(); - } + const char* module_name = (module_entry->name() == NULL) ? UNNAMED_MODULE : module_entry->name()->as_C_string(); if (log_is_enabled(Info, class, load)) { ik->print_loading_log(LogLevel::Info, _loader_data, module_name, _stream); diff --git a/hotspot/src/share/vm/oops/instanceKlass.cpp b/hotspot/src/share/vm/oops/instanceKlass.cpp index 58135b4a5ff..23d885a991f 100644 --- a/hotspot/src/share/vm/oops/instanceKlass.cpp +++ b/hotspot/src/share/vm/oops/instanceKlass.cpp @@ -3004,7 +3004,11 @@ void InstanceKlass::print_loading_log(LogLevel::type type, if (cfs != NULL) { if (cfs->source() != NULL) { if (module_name != NULL) { - log->print(" source: jrt:/%s", module_name); + if (ClassLoader::is_jrt(cfs->source())) { + log->print(" source: jrt:/%s", module_name); + } else { + log->print(" source: %s", cfs->source()); + } } else { log->print(" source: %s", cfs->source()); }