From a3ee39cb81f05955e9e3ea983fb046a0e3283e51 Mon Sep 17 00:00:00 2001 From: Goetz Lindenmaier Date: Tue, 29 Oct 2019 15:08:19 +0100 Subject: [PATCH] 8232921: assert(is_object_aligned(result)) failed: address not aligned Reviewed-by: coleenp, rschmelter --- src/hotspot/share/classfile/javaClasses.cpp | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/src/hotspot/share/classfile/javaClasses.cpp b/src/hotspot/share/classfile/javaClasses.cpp index afa97970263..e929b7f521c 100644 --- a/src/hotspot/share/classfile/javaClasses.cpp +++ b/src/hotspot/share/classfile/javaClasses.cpp @@ -1962,6 +1962,8 @@ static inline bool version_matches(Method* method, int version) { // This class provides a simple wrapper over the internal structure of // exception backtrace to insulate users of the backtrace from needing // to know what it looks like. +// The code of this class is not GC safe. Allocations can only happen +// in expand(). class BacktraceBuilder: public StackObj { friend class BacktraceIterator; private: @@ -2110,10 +2112,14 @@ class BacktraceBuilder: public StackObj { void set_has_hidden_top_frame(TRAPS) { if (_has_hidden_top_frame == NULL) { - jvalue prim; - prim.z = 1; - PauseNoSafepointVerifier pnsv(&_nsv); - _has_hidden_top_frame = java_lang_boxing_object::create(T_BOOLEAN, &prim, CHECK); + // It would be nice to add java/lang/Boolean::TRUE here + // to indicate that this backtrace has a hidden top frame. + // But this code is used before TRUE is allocated. + // Therefor let's just use an arbitrary legal oop + // available right here. We only test for != null + // anyways. _methods is a short[]. + assert(_methods != NULL, "we need a legal oop"); + _has_hidden_top_frame = _methods; _head->obj_at_put(trace_hidden_offset, _has_hidden_top_frame); } }