From 5d48da4574f6aacb0db445dd5750566330aa383d Mon Sep 17 00:00:00 2001 From: Patricio Chilano Mateo Date: Thu, 29 Sep 2022 15:35:41 +0000 Subject: [PATCH] 8294370: Fix allocation bug in java_lang_Thread::async_get_stack_trace() Reviewed-by: dholmes, sspitsyn --- src/hotspot/share/classfile/javaClasses.cpp | 16 +++++++++++----- 1 file changed, 11 insertions(+), 5 deletions(-) diff --git a/src/hotspot/share/classfile/javaClasses.cpp b/src/hotspot/share/classfile/javaClasses.cpp index 4f466617754..6d93eac0c26 100644 --- a/src/hotspot/share/classfile/javaClasses.cpp +++ b/src/hotspot/share/classfile/javaClasses.cpp @@ -1934,11 +1934,12 @@ oop java_lang_Thread::async_get_stack_trace(oop java_thread, TRAPS) { GrowableArray* _bcis; GetStackTraceClosure(Handle java_thread) : - HandshakeClosure("GetStackTraceClosure"), _java_thread(java_thread), _depth(0), _retry_handshake(false) { - // Pick some initial length - int init_length = MaxJavaStackTraceDepth / 2; - _methods = new GrowableArray(init_length); - _bcis = new GrowableArray(init_length); + HandshakeClosure("GetStackTraceClosure"), _java_thread(java_thread), _depth(0), _retry_handshake(false), + _methods(nullptr), _bcis(nullptr) { + } + ~GetStackTraceClosure() { + delete _methods; + delete _bcis; } bool read_reset_retry() { @@ -1975,6 +1976,11 @@ oop java_lang_Thread::async_get_stack_trace(oop java_thread, TRAPS) { const int max_depth = MaxJavaStackTraceDepth; const bool skip_hidden = !ShowHiddenFrames; + // Pick minimum length that will cover most cases + int init_length = 64; + _methods = new (ResourceObj::C_HEAP, mtInternal) GrowableArray(init_length, mtInternal); + _bcis = new (ResourceObj::C_HEAP, mtInternal) GrowableArray(init_length, mtInternal); + int total_count = 0; for (vframeStream vfst(thread, false, false, carrier); // we don't process frames as we don't care about oops !vfst.at_end() && (max_depth == 0 || max_depth != total_count);