From 1376f330119c832d24a986cc915cb2f82768a02c Mon Sep 17 00:00:00 2001 From: Justin King Date: Fri, 2 Dec 2022 11:31:19 +0000 Subject: [PATCH] 8297911: Memory leak in JfrUpcalls::on_retransform Reviewed-by: mgronlun --- .../jfrEventClassTransformer.cpp | 29 +++++++++---------- src/hotspot/share/jfr/jni/jfrUpcalls.cpp | 4 +-- 2 files changed, 14 insertions(+), 19 deletions(-) diff --git a/src/hotspot/share/jfr/instrumentation/jfrEventClassTransformer.cpp b/src/hotspot/share/jfr/instrumentation/jfrEventClassTransformer.cpp index 54f056dc432..4e4856b84d5 100644 --- a/src/hotspot/share/jfr/instrumentation/jfrEventClassTransformer.cpp +++ b/src/hotspot/share/jfr/instrumentation/jfrEventClassTransformer.cpp @@ -1524,22 +1524,19 @@ static ClassFileStream* retransform_bytes(const Klass* existing_klass, const Cla DEBUG_ONLY(JfrJavaSupport::check_java_thread_in_vm(THREAD)); jint size_of_new_bytes = 0; unsigned char* new_bytes = NULL; - { - ResourceMark rm(THREAD); - const ClassFileStream* const stream = parser.clone_stream(); - assert(stream != NULL, "invariant"); - const jclass clazz = static_cast(JfrJavaSupport::local_jni_handle(existing_klass->java_mirror(), THREAD)); - JfrUpcalls::on_retransform(JfrTraceId::load_raw(existing_klass), - clazz, - stream->length(), - stream->buffer(), - &size_of_new_bytes, - &new_bytes, - THREAD); - JfrJavaSupport::destroy_local_jni_handle(clazz); - if (has_pending_exception(THREAD)) { - return NULL; - } + const ClassFileStream* const stream = parser.clone_stream(); + assert(stream != NULL, "invariant"); + const jclass clazz = static_cast(JfrJavaSupport::local_jni_handle(existing_klass->java_mirror(), THREAD)); + JfrUpcalls::on_retransform(JfrTraceId::load_raw(existing_klass), + clazz, + stream->length(), + stream->buffer(), + &size_of_new_bytes, + &new_bytes, + THREAD); + JfrJavaSupport::destroy_local_jni_handle(clazz); + if (has_pending_exception(THREAD)) { + return NULL; } assert(new_bytes != NULL, "invariant"); assert(size_of_new_bytes > 0, "invariant"); diff --git a/src/hotspot/share/jfr/jni/jfrUpcalls.cpp b/src/hotspot/share/jfr/jni/jfrUpcalls.cpp index 673b647e309..480c01ed2fe 100644 --- a/src/hotspot/share/jfr/jni/jfrUpcalls.cpp +++ b/src/hotspot/share/jfr/jni/jfrUpcalls.cpp @@ -141,9 +141,7 @@ void JfrUpcalls::on_retransform(jlong trace_id, CHECK); assert(new_byte_array != NULL, "invariant"); assert(new_bytes_length > 0, "invariant"); - // memory space must be malloced as mtInternal - // as it will be deallocated by JVMTI routines - unsigned char* const new_bytes = (unsigned char* const)os::malloc(new_bytes_length, mtInternal); + unsigned char* const new_bytes = NEW_RESOURCE_ARRAY_IN_THREAD_RETURN_NULL(THREAD, unsigned char, new_bytes_length); if (new_bytes == NULL) { log_error_and_throw_oom(new_bytes_length, THREAD); // unwinds }