From 7c96608d9a2f3ea552b2daf1fe0772a0faac46c6 Mon Sep 17 00:00:00 2001 From: Doug Simon Date: Tue, 6 Sep 2022 15:18:02 +0000 Subject: [PATCH] 8293403: JfrResolution::on_jvmci_resolution crashes when caller is null Reviewed-by: never --- src/hotspot/share/jfr/instrumentation/jfrResolution.cpp | 6 ++++-- test/jdk/jdk/jfr/jvm/TestGetEventWriter.java | 6 ++++++ 2 files changed, 10 insertions(+), 2 deletions(-) diff --git a/src/hotspot/share/jfr/instrumentation/jfrResolution.cpp b/src/hotspot/share/jfr/instrumentation/jfrResolution.cpp index 0257e91a9a9..c5a53036caf 100644 --- a/src/hotspot/share/jfr/instrumentation/jfrResolution.cpp +++ b/src/hotspot/share/jfr/instrumentation/jfrResolution.cpp @@ -127,8 +127,10 @@ void JfrResolution::on_c2_resolution(const Parse * parse, const ciKlass * holder #if INCLUDE_JVMCI // JVMCI void JfrResolution::on_jvmci_resolution(const Method* caller, const Method* target, TRAPS) { - if (is_compiler_linking_event_writer(target->method_holder()->name(), target->name()) && !IS_METHOD_BLESSED(caller)) { - THROW_MSG(vmSymbols::java_lang_IllegalAccessError(), link_error_msg); + if (is_compiler_linking_event_writer(target->method_holder()->name(), target->name())) { + if (caller == nullptr || !IS_METHOD_BLESSED(caller)) { + THROW_MSG(vmSymbols::java_lang_IllegalAccessError(), link_error_msg); + } } } #endif diff --git a/test/jdk/jdk/jfr/jvm/TestGetEventWriter.java b/test/jdk/jdk/jfr/jvm/TestGetEventWriter.java index da1729dee80..ec68d41f66b 100644 --- a/test/jdk/jdk/jfr/jvm/TestGetEventWriter.java +++ b/test/jdk/jdk/jfr/jvm/TestGetEventWriter.java @@ -371,6 +371,12 @@ public class TestGetEventWriter { throw new AssertionError("Expected IllegalAccessError"); } catch (IllegalAccessError e) { } + try { + // Test looking up with null caller + cp.lookupMethod(cpi, 184, null); + throw new AssertionError("Expected IllegalAccessError"); + } catch (IllegalAccessError e) { + } // Ignore all subsequent instructions return;