8228485: JVM crashes when bootstrap method for condy triggers loading of class whose static initializer throws exception
Add case for JVM_CONSTANT_Dynamic in error_message function. Reviewed-by: dholmes, shade
This commit is contained in:
parent
f2e1bfa38a
commit
221da20713
@ -760,6 +760,10 @@ Symbol* ConstantPool::exception_message(const constantPoolHandle& this_cp, int w
|
|||||||
// return the method type signature in the error message
|
// return the method type signature in the error message
|
||||||
message = this_cp->method_type_signature_at(which);
|
message = this_cp->method_type_signature_at(which);
|
||||||
break;
|
break;
|
||||||
|
case JVM_CONSTANT_Dynamic:
|
||||||
|
// return the name of the condy in the error message
|
||||||
|
message = this_cp->uncached_name_ref_at(which);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
ShouldNotReachHere();
|
ShouldNotReachHere();
|
||||||
}
|
}
|
||||||
|
65
test/hotspot/jtreg/runtime/condy/staticInit/Example.jasm
Normal file
65
test/hotspot/jtreg/runtime/condy/staticInit/Example.jasm
Normal file
@ -0,0 +1,65 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2019, 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
// This class gets an initialization error in a condy invokestatic. Need jasm so that StaticInit isn't
|
||||||
|
// initialized before the condy call.
|
||||||
|
// Test that second invocation gets same error as first.
|
||||||
|
|
||||||
|
public class Example
|
||||||
|
version 55:0
|
||||||
|
{
|
||||||
|
|
||||||
|
|
||||||
|
static Method $jacocoInit:"(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/Class;)Ljava/lang/Object;"
|
||||||
|
stack 1 locals 3
|
||||||
|
{
|
||||||
|
invokestatic Method StaticInit.get:"()Ljava/lang/Object;";
|
||||||
|
areturn;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Method foo:"()V"
|
||||||
|
stack 1 locals 2
|
||||||
|
{
|
||||||
|
ldc Dynamic REF_invokeStatic:Example.$jacocoInit:"(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/Class;)Ljava/lang/Object;":$jacocoData:"Ljava/lang/Object;";
|
||||||
|
astore_1;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Method main:"([Ljava/lang/String;)V"
|
||||||
|
stack 1 locals 2
|
||||||
|
{
|
||||||
|
try t0;
|
||||||
|
invokestatic Method Example.foo:"()V";
|
||||||
|
endtry t0;
|
||||||
|
goto L7;
|
||||||
|
catch t0 java/lang/Error;
|
||||||
|
stack_frame_type stack1;
|
||||||
|
stack_map class java/lang/Error;
|
||||||
|
astore_1;
|
||||||
|
aload_1;
|
||||||
|
invokevirtual Method java/lang/Error.printStackTrace:"()V";
|
||||||
|
L7: stack_frame_type same;
|
||||||
|
invokestatic Method Example.foo:"()V";
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
} // end Class Example
|
33
test/hotspot/jtreg/runtime/condy/staticInit/StaticInit.java
Normal file
33
test/hotspot/jtreg/runtime/condy/staticInit/StaticInit.java
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2019, 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
class StaticInit {
|
||||||
|
static {
|
||||||
|
if (true)
|
||||||
|
throw new RuntimeException();
|
||||||
|
}
|
||||||
|
|
||||||
|
static Object get() {
|
||||||
|
return new Object();
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,53 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2019, 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* @test
|
||||||
|
* @bug 8228485
|
||||||
|
* @summary Correctly handle initialization error for Condy BSM.
|
||||||
|
* @modules java.base/jdk.internal.misc
|
||||||
|
* @library /test/lib
|
||||||
|
* @compile Example.jasm
|
||||||
|
* @compile StaticInit.java
|
||||||
|
* @run main/othervm TestInitException
|
||||||
|
*/
|
||||||
|
|
||||||
|
import jdk.test.lib.process.ProcessTools;
|
||||||
|
import jdk.test.lib.process.OutputAnalyzer;
|
||||||
|
|
||||||
|
public class TestInitException {
|
||||||
|
public static void main(java.lang.String[] unused) throws Exception {
|
||||||
|
ProcessBuilder pb = ProcessTools.createJavaProcessBuilder("Example");
|
||||||
|
OutputAnalyzer oa = new OutputAnalyzer(pb.start());
|
||||||
|
// First call stack trace
|
||||||
|
oa.shouldContain("at Example.$jacocoInit(Example.jasm)");
|
||||||
|
oa.shouldContain("Caused by: java.lang.RuntimeException");
|
||||||
|
oa.shouldContain("at StaticInit.<clinit>(StaticInit.java:27)");
|
||||||
|
// Second call stack trace, with the message
|
||||||
|
oa.shouldContain("java.lang.ExceptionInInitializerError: $jacocoData");
|
||||||
|
oa.shouldContain("at Example.foo(Example.jasm)");
|
||||||
|
oa.shouldContain("at Example.main(Example.jasm)");
|
||||||
|
oa.shouldHaveExitValue(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user