From 03b7a8586a77983b1851ddd3f4555fe2fca57919 Mon Sep 17 00:00:00 2001 From: Leonid Mesnik Date: Wed, 29 May 2024 14:59:19 +0000 Subject: [PATCH] 8332259: JvmtiTrace::safe_get_thread_name fails if current thread is in native state Reviewed-by: dholmes, sspitsyn --- src/hotspot/share/prims/jvmtiEnter.xsl | 9 +++++++++ src/hotspot/share/prims/jvmtiTrace.cpp | 9 ++++++++- 2 files changed, 17 insertions(+), 1 deletion(-) diff --git a/src/hotspot/share/prims/jvmtiEnter.xsl b/src/hotspot/share/prims/jvmtiEnter.xsl index f275da0cc86..59b70a162eb 100644 --- a/src/hotspot/share/prims/jvmtiEnter.xsl +++ b/src/hotspot/share/prims/jvmtiEnter.xsl @@ -450,6 +450,15 @@ struct jvmtiInterface_1_ jvmti PreserveExceptionMark __em(this_thread); + + + if (trace_flags) { + + curr_thread_name = JvmtiTrace::safe_get_current_thread_name(); + + } + + diff --git a/src/hotspot/share/prims/jvmtiTrace.cpp b/src/hotspot/share/prims/jvmtiTrace.cpp index 9ed139bd882..002f59957ea 100644 --- a/src/hotspot/share/prims/jvmtiTrace.cpp +++ b/src/hotspot/share/prims/jvmtiTrace.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2023, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2024, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -30,6 +30,7 @@ #include "memory/resourceArea.hpp" #include "prims/jvmtiTrace.hpp" #include "runtime/javaThread.hpp" +#include "runtime/javaThread.inline.hpp" // // class JvmtiTrace @@ -277,6 +278,12 @@ const char *JvmtiTrace::safe_get_thread_name(Thread *thread) { if (!thread->is_Java_thread()) { return thread->name(); } + if (Thread::current()->is_Java_thread()) { + JavaThreadState current_state = JavaThread::cast(Thread::current())->thread_state(); + if (current_state == _thread_in_native || current_state == _thread_blocked) { + return "not readable"; + } + } JavaThread* java_thread = JavaThread::cast(thread); oop threadObj = java_thread->jvmti_vthread(); if (threadObj == nullptr) {