227 lines
7.8 KiB
Diff
227 lines
7.8 KiB
Diff
From ca014e842f05da9d929152c7e5f7cd56d30629e5 Mon Sep 17 00:00:00 2001
|
|
Subject: 8313626: C2 crash due to unexpected exception control flow
|
|
|
|
---
|
|
hotspot/src/share/vm/opto/doCall.cpp | 4 +
|
|
.../compiler/MissingSafepointOnTryCatch.jasm | 112 ++++++++++++++++++
|
|
.../TestMissingSafepointOnTryCatch.java | 66 +++++++++++
|
|
3 files changed, 182 insertions(+)
|
|
create mode 100644 jdk/test/jdk/jfr/event/compiler/MissingSafepointOnTryCatch.jasm
|
|
create mode 100644 jdk/test/jdk/jfr/event/compiler/TestMissingSafepointOnTryCatch.java
|
|
|
|
diff --git a/hotspot/src/share/vm/opto/doCall.cpp b/hotspot/src/share/vm/opto/doCall.cpp
|
|
index 1b2b77c71..7a7aba359 100644
|
|
--- a/hotspot/src/share/vm/opto/doCall.cpp
|
|
+++ b/hotspot/src/share/vm/opto/doCall.cpp
|
|
@@ -892,6 +892,8 @@ void Parse::catch_inline_exceptions(SafePointNode* ex_map) {
|
|
tty->print_cr(" Catching every inline exception bci:%d -> handler_bci:%d", bci(), handler_bci);
|
|
}
|
|
#endif
|
|
+ // If this is a backwards branch in the bytecodes, add safepoint
|
|
+ maybe_add_safepoint(handler_bci);
|
|
merge_exception(handler_bci); // jump to handler
|
|
return; // No more handling to be done here!
|
|
}
|
|
@@ -925,6 +927,8 @@ void Parse::catch_inline_exceptions(SafePointNode* ex_map) {
|
|
tty->cr();
|
|
}
|
|
#endif
|
|
+ // If this is a backwards branch in the bytecodes, add safepoint
|
|
+ maybe_add_safepoint(handler_bci);
|
|
merge_exception(handler_bci);
|
|
}
|
|
set_control(not_subtype_ctrl);
|
|
diff --git a/jdk/test/jdk/jfr/event/compiler/MissingSafepointOnTryCatch.jasm b/jdk/test/jdk/jfr/event/compiler/MissingSafepointOnTryCatch.jasm
|
|
new file mode 100644
|
|
index 000000000..413736e59
|
|
--- /dev/null
|
|
+++ b/jdk/test/jdk/jfr/event/compiler/MissingSafepointOnTryCatch.jasm
|
|
@@ -0,0 +1,112 @@
|
|
+/*
|
|
+ * Copyright (c) 2023, Oracle and/or its affiliates. All rights reserved.
|
|
+ * Copyright (c) 2023, Huawei Technologies Co., Ltd. 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.
|
|
+ */
|
|
+
|
|
+public class MissingSafepointOnTryCatch version 52:0 {
|
|
+
|
|
+ static Method m:"()V" {
|
|
+ return;
|
|
+ }
|
|
+
|
|
+ static Method test1:"()V" stack 1 {
|
|
+ try t;
|
|
+ invokestatic m:"()V";
|
|
+ return;
|
|
+
|
|
+ catch t java/lang/Throwable;
|
|
+ stack_map class java/lang/Throwable;
|
|
+ athrow;
|
|
+ endtry t;
|
|
+ }
|
|
+
|
|
+ static Method test2:"()V" stack 1 {
|
|
+ try t0;
|
|
+ try t1;
|
|
+ invokestatic m:"()V";
|
|
+ endtry t1;
|
|
+ return;
|
|
+
|
|
+ catch t1 java/lang/Exception;
|
|
+ stack_map class java/lang/Exception;
|
|
+ return;
|
|
+
|
|
+ catch t0 java/lang/Throwable;
|
|
+ stack_map class java/lang/Throwable;
|
|
+ athrow;
|
|
+ endtry t0;
|
|
+ }
|
|
+
|
|
+ public static Method th:"()V"
|
|
+ throws java/lang/Exception
|
|
+ stack 2 locals 0
|
|
+ {
|
|
+ new class java/lang/Exception;
|
|
+ dup;
|
|
+ invokespecial Method java/lang/Exception."<init>":"()V";
|
|
+ athrow;
|
|
+ }
|
|
+
|
|
+ static Method test3:"()V" stack 1 locals 2 {
|
|
+ try t;
|
|
+ invokestatic m:"()V";
|
|
+ iconst_1;
|
|
+ istore_0;
|
|
+ iconst_0;
|
|
+ istore_1;
|
|
+ return;
|
|
+ catch t java/lang/Throwable;
|
|
+ stack_map class java/lang/Throwable;
|
|
+ invokestatic th:"()V";
|
|
+ return;
|
|
+ endtry t;
|
|
+ }
|
|
+
|
|
+ static Method test4:"()V" stack 2 locals 2 {
|
|
+ try t;
|
|
+ invokestatic m:"()V";
|
|
+ iconst_1;
|
|
+ istore_0;
|
|
+ iconst_0;
|
|
+ istore_1;
|
|
+ return;
|
|
+ catch t java/lang/Throwable;
|
|
+ stack_map class java/lang/Throwable;
|
|
+ iconst_1;
|
|
+ istore_0;
|
|
+ invokestatic th:"()V";
|
|
+ return;
|
|
+ endtry t;
|
|
+ }
|
|
+
|
|
+ static Method testInfinite:"()V" stack 1 {
|
|
+ try t;
|
|
+ invokestatic th:"()V";
|
|
+ return;
|
|
+
|
|
+ catch t java/lang/Throwable;
|
|
+ stack_map class java/lang/Throwable;
|
|
+ athrow;
|
|
+ endtry t;
|
|
+ }
|
|
+
|
|
+} // end Class MissingSafepointOnTryCatch
|
|
diff --git a/jdk/test/jdk/jfr/event/compiler/TestMissingSafepointOnTryCatch.java b/jdk/test/jdk/jfr/event/compiler/TestMissingSafepointOnTryCatch.java
|
|
new file mode 100644
|
|
index 000000000..fa579b7d4
|
|
--- /dev/null
|
|
+++ b/jdk/test/jdk/jfr/event/compiler/TestMissingSafepointOnTryCatch.java
|
|
@@ -0,0 +1,66 @@
|
|
+/*
|
|
+ * Copyright (c) 2023, Oracle and/or its affiliates. All rights reserved.
|
|
+ * Copyright (c) 2023, Huawei Technologies Co., Ltd. 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
|
|
+ * @bug 8313626
|
|
+ * @library /lib /
|
|
+ * @summary assert(false) failed: malformed control flow to missing safepoint on backedge of a try-catch
|
|
+ * @compile MissingSafepointOnTryCatch.jasm
|
|
+ * @run main/othervm -XX:CompileCommand=quiet
|
|
+ * -XX:CompileCommand=compileonly,MissingSafepointOnTryCatch::test*
|
|
+ * -XX:CompileCommand=dontinline,MissingSafepointOnTryCatch::m
|
|
+ * -XX:CompileCommand=inline,MissingSafepointOnTryCatch::th
|
|
+ * -XX:-TieredCompilation -Xcomp TestMissingSafepointOnTryCatch
|
|
+ */
|
|
+
|
|
+import jdk.test.lib.Utils;
|
|
+
|
|
+public class TestMissingSafepointOnTryCatch {
|
|
+
|
|
+ public static void infiniteLoop() {
|
|
+ try {
|
|
+ Thread thread = new Thread() {
|
|
+ public void run() {
|
|
+ MissingSafepointOnTryCatch.testInfinite();
|
|
+ }
|
|
+ };
|
|
+ thread.setDaemon(true);
|
|
+ thread.start();
|
|
+ Thread.sleep(Utils.adjustTimeout(500));
|
|
+ } catch (Exception e) {}
|
|
+ }
|
|
+
|
|
+ public static void main(String[] args) {
|
|
+ try {
|
|
+ // to make sure java/lang/Exception class is resolved
|
|
+ MissingSafepointOnTryCatch.th();
|
|
+ } catch (Exception e) {}
|
|
+ MissingSafepointOnTryCatch.test1();
|
|
+ MissingSafepointOnTryCatch.test2();
|
|
+ MissingSafepointOnTryCatch.test3();
|
|
+ MissingSafepointOnTryCatch.test4();
|
|
+ infiniteLoop();
|
|
+ }
|
|
+}
|
|
--
|
|
2.22.0
|
|
|