mirror of
https://github.com/openjdk/jdk.git
synced 2025-08-28 15:24:43 +02:00
8271055: Crash during deoptimization with "assert(bb->is_reachable()) failed: getting result from unreachable basicblock" with -XX:+VerifyStack
Co-authored-by: Yi Yang <yyang@openjdk.org> Co-authored-by: Yi Yang <qingfeng.yy@alibaba-inc.com> Reviewed-by: vlivanov, thartmann
This commit is contained in:
parent
b6935dfb86
commit
e44dc638b8
3 changed files with 121 additions and 1 deletions
|
@ -704,6 +704,21 @@ void Deoptimization::unwind_callee_save_values(frame* f, vframeArray* vframe_arr
|
||||||
assert(f->is_interpreted_frame(), "must be interpreted");
|
assert(f->is_interpreted_frame(), "must be interpreted");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifndef PRODUCT
|
||||||
|
static bool falls_through(Bytecodes::Code bc) {
|
||||||
|
switch (bc) {
|
||||||
|
// List may be incomplete. Here we really only care about bytecodes where compiled code
|
||||||
|
// can deoptimize.
|
||||||
|
case Bytecodes::_goto:
|
||||||
|
case Bytecodes::_goto_w:
|
||||||
|
case Bytecodes::_athrow:
|
||||||
|
return false;
|
||||||
|
default:
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
// Return BasicType of value being returned
|
// Return BasicType of value being returned
|
||||||
JRT_LEAF(BasicType, Deoptimization::unpack_frames(JavaThread* thread, int exec_mode))
|
JRT_LEAF(BasicType, Deoptimization::unpack_frames(JavaThread* thread, int exec_mode))
|
||||||
|
|
||||||
|
@ -801,7 +816,7 @@ JRT_LEAF(BasicType, Deoptimization::unpack_frames(JavaThread* thread, int exec_m
|
||||||
// calls. It seems to be hard to tell whether the compiler
|
// calls. It seems to be hard to tell whether the compiler
|
||||||
// has emitted debug information matching the "state before"
|
// has emitted debug information matching the "state before"
|
||||||
// a given bytecode or the state after, so we try both
|
// a given bytecode or the state after, so we try both
|
||||||
if (!Bytecodes::is_invoke(cur_code) && cur_code != Bytecodes::_athrow) {
|
if (!Bytecodes::is_invoke(cur_code) && falls_through(cur_code)) {
|
||||||
// Get expression stack size for the next bytecode
|
// Get expression stack size for the next bytecode
|
||||||
InterpreterOopMap next_mask;
|
InterpreterOopMap next_mask;
|
||||||
OopMapCache::compute_one_oop_map(mh, str.bci(), &next_mask);
|
OopMapCache::compute_one_oop_map(mh, str.bci(), &next_mask);
|
||||||
|
|
63
test/hotspot/jtreg/compiler/interpreter/Custom.jasm
Normal file
63
test/hotspot/jtreg/compiler/interpreter/Custom.jasm
Normal file
|
@ -0,0 +1,63 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2022, 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
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package compiler/interpreter;
|
||||||
|
|
||||||
|
/* JASM simplified from the following Java pattern:
|
||||||
|
*
|
||||||
|
* public class Custom {
|
||||||
|
*
|
||||||
|
* static void test(int v) {
|
||||||
|
* int i8 = 1;
|
||||||
|
* try {
|
||||||
|
* v += 1;
|
||||||
|
* } catch (ArithmeticException exc1) {
|
||||||
|
* } finally {
|
||||||
|
* for (; i8 < 100; i8++) {
|
||||||
|
* }
|
||||||
|
* }
|
||||||
|
* }
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
super public class Custom {
|
||||||
|
|
||||||
|
public static Method test:"(I)V" stack 2 locals 3 {
|
||||||
|
iconst_1;
|
||||||
|
istore_1;
|
||||||
|
try t0;
|
||||||
|
iinc 0, 1;
|
||||||
|
endtry t0;
|
||||||
|
Loop:
|
||||||
|
iload_1;
|
||||||
|
bipush 100;
|
||||||
|
if_icmpge Lexit;
|
||||||
|
iinc 1, 1;
|
||||||
|
goto Loop; // deoptimize here on backwards branch
|
||||||
|
catch t0 java/lang/ArithmeticException; // unreachable block
|
||||||
|
astore_2;
|
||||||
|
Lexit:
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,42 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2022, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* Copyright (c) 2021, Alibaba Group Holding Limited. 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
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* @test VerifyStackWithUnreachableBlock
|
||||||
|
* @bug 8271055
|
||||||
|
* @compile Custom.jasm VerifyStackWithUnreachableBlock.java
|
||||||
|
* @summary Using VerifyStack for method that contains unreachable basic blocks
|
||||||
|
* @run main/othervm -XX:+IgnoreUnrecognizedVMOptions -XX:+VerifyStack compiler.interpreter.VerifyStackWithUnreachableBlock
|
||||||
|
*/
|
||||||
|
|
||||||
|
package compiler.interpreter;
|
||||||
|
|
||||||
|
public class VerifyStackWithUnreachableBlock {
|
||||||
|
public static void main(String[] strArr) {
|
||||||
|
for (int i = 0; i < 10000; i++) {
|
||||||
|
Custom.test(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue