From dd676c3a98138824ac7f7962d7342d1b2c960c2c Mon Sep 17 00:00:00 2001 From: Vladimir Kozlov Date: Wed, 21 Jun 2017 10:28:27 -0700 Subject: [PATCH] 8181823: [AOT] jaotc doesn't work with Graal Add new flag to indicate when to calculate class fingerprint Reviewed-by: iklam, iveresov --- .../jdk.internal.vm.compiler/share/classes/module-info.java | 1 + hotspot/src/share/vm/oops/instanceKlass.cpp | 2 +- hotspot/src/share/vm/runtime/globals.hpp | 3 +++ hotspot/src/share/vm/runtime/java.cpp | 1 + 4 files changed, 6 insertions(+), 1 deletion(-) diff --git a/hotspot/src/jdk.internal.vm.compiler/share/classes/module-info.java b/hotspot/src/jdk.internal.vm.compiler/share/classes/module-info.java index a3f266dcdc0..3410829a8d0 100644 --- a/hotspot/src/jdk.internal.vm.compiler/share/classes/module-info.java +++ b/hotspot/src/jdk.internal.vm.compiler/share/classes/module-info.java @@ -39,6 +39,7 @@ module jdk.internal.vm.compiler { uses org.graalvm.compiler.debug.TTYStreamProvider; uses org.graalvm.compiler.hotspot.CompilerConfigurationFactory; uses org.graalvm.compiler.hotspot.HotSpotBackendFactory; + uses org.graalvm.compiler.hotspot.HotSpotCodeCacheListener; uses org.graalvm.compiler.options.OptionValuesAccess; uses org.graalvm.compiler.nodes.graphbuilderconf.NodeIntrinsicPluginFactory; diff --git a/hotspot/src/share/vm/oops/instanceKlass.cpp b/hotspot/src/share/vm/oops/instanceKlass.cpp index db7498c07dd..520f914bf29 100644 --- a/hotspot/src/share/vm/oops/instanceKlass.cpp +++ b/hotspot/src/share/vm/oops/instanceKlass.cpp @@ -1954,7 +1954,7 @@ bool InstanceKlass::supers_have_passed_fingerprint_checks() { bool InstanceKlass::should_store_fingerprint() { #if INCLUDE_AOT // We store the fingerprint into the InstanceKlass only in the following 2 cases: - if (EnableJVMCI && !UseJVMCICompiler) { + if (CalculateClassFingerprint) { // (1) We are running AOT to generate a shared library. return true; } diff --git a/hotspot/src/share/vm/runtime/globals.hpp b/hotspot/src/share/vm/runtime/globals.hpp index a17ee5b70b1..08954ff94e1 100644 --- a/hotspot/src/share/vm/runtime/globals.hpp +++ b/hotspot/src/share/vm/runtime/globals.hpp @@ -3387,6 +3387,9 @@ public: diagnostic(bool, UseAOTStrictLoading, false, \ "Exit the VM if any of the AOT libraries has invalid config") \ \ + product(bool, CalculateClassFingerprint, false, \ + "Calculate class fingerprint") \ + \ /* interpreter debugging */ \ develop(intx, BinarySwitchThreshold, 5, \ "Minimal number of lookupswitch entries for rewriting to binary " \ diff --git a/hotspot/src/share/vm/runtime/java.cpp b/hotspot/src/share/vm/runtime/java.cpp index 9810363b88f..aa0fb1d0502 100644 --- a/hotspot/src/share/vm/runtime/java.cpp +++ b/hotspot/src/share/vm/runtime/java.cpp @@ -437,6 +437,7 @@ void before_exit(JavaThread* thread) { Thread* THREAD = thread; JVMCIRuntime::shutdown(THREAD); if (HAS_PENDING_EXCEPTION) { + HandleMark hm(THREAD); Handle exception(THREAD, PENDING_EXCEPTION); CLEAR_PENDING_EXCEPTION; java_lang_Throwable::java_printStackTrace(exception, THREAD);