2018-06-07 17:38:34 -07:00
|
|
|
/*
|
2020-01-08 14:36:48 +01:00
|
|
|
* Copyright (c) 2018, 2020, Oracle and/or its affiliates. All rights reserved.
|
2018-06-07 17:38:34 -07:00
|
|
|
* 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 sun.hotspot.code;
|
|
|
|
|
2018-08-13 13:24:55 -07:00
|
|
|
import java.lang.reflect.Executable;
|
2018-06-07 17:38:34 -07:00
|
|
|
import sun.hotspot.WhiteBox;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* API to obtain information about enabled JIT compilers
|
|
|
|
* retrieved from the VM with the WhiteBox API.
|
|
|
|
*/
|
|
|
|
public class Compiler {
|
|
|
|
|
|
|
|
private static final WhiteBox WB = WhiteBox.getWhiteBox();
|
|
|
|
|
2020-01-08 14:36:48 +01:00
|
|
|
/**
|
|
|
|
* Check if C2 or JVMCI were included in the VM build
|
|
|
|
*
|
|
|
|
* @return true if either C2 or JVMCI were included in the VM build.
|
|
|
|
*/
|
|
|
|
public static boolean isC2OrJVMCIIncludedInVmBuild() {
|
|
|
|
return WB.isC2OrJVMCIIncludedInVmBuild();
|
|
|
|
}
|
|
|
|
|
2020-12-03 13:42:50 +00:00
|
|
|
/**
|
|
|
|
* Check if JVMCI is enabled.
|
|
|
|
*
|
|
|
|
* @return true if JVMCI is enabled
|
|
|
|
*/
|
|
|
|
public static boolean isJVMCIEnabled() {
|
|
|
|
Boolean enableJvmci = WB.getBooleanVMFlag("EnableJVMCI");
|
|
|
|
if (enableJvmci == null || !enableJvmci) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2018-06-07 17:38:34 -07:00
|
|
|
/**
|
|
|
|
* Check if Graal is used as JIT compiler.
|
|
|
|
*
|
|
|
|
* Graal is enabled if following conditions are true:
|
|
|
|
* - we are not in Interpreter mode
|
|
|
|
* - UseJVMCICompiler flag is true
|
|
|
|
* - jvmci.Compiler variable is equal to 'graal'
|
|
|
|
* - TieredCompilation is not used or TieredStopAtLevel is greater than 3
|
|
|
|
* No need to check client mode because it set UseJVMCICompiler to false.
|
|
|
|
*
|
|
|
|
* @return true if Graal is used as JIT compiler.
|
|
|
|
*/
|
|
|
|
public static boolean isGraalEnabled() {
|
|
|
|
Boolean useCompiler = WB.getBooleanVMFlag("UseCompiler");
|
|
|
|
if (useCompiler == null || !useCompiler) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
Boolean useJvmciComp = WB.getBooleanVMFlag("UseJVMCICompiler");
|
|
|
|
if (useJvmciComp == null || !useJvmciComp) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
Boolean tieredCompilation = WB.getBooleanVMFlag("TieredCompilation");
|
|
|
|
Long compLevel = WB.getIntxVMFlag("TieredStopAtLevel");
|
|
|
|
// if TieredCompilation is enabled and compilation level is <= 3 then no Graal is used
|
|
|
|
if (tieredCompilation != null && tieredCompilation &&
|
|
|
|
compLevel != null && compLevel <= 3) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Check if C2 is used as JIT compiler.
|
|
|
|
*
|
|
|
|
* C2 is enabled if following conditions are true:
|
|
|
|
* - we are not in Interpreter mode
|
|
|
|
* - we are in Server compilation mode
|
|
|
|
* - TieredCompilation is not used or TieredStopAtLevel is greater than 3
|
|
|
|
* - Graal is not used
|
|
|
|
*
|
|
|
|
* @return true if C2 is used as JIT compiler.
|
|
|
|
*/
|
|
|
|
public static boolean isC2Enabled() {
|
|
|
|
Boolean useCompiler = WB.getBooleanVMFlag("UseCompiler");
|
|
|
|
if (useCompiler == null || !useCompiler) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
Boolean serverMode = WB.getBooleanVMFlag("ProfileInterpreter");
|
|
|
|
if (serverMode == null || !serverMode) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
Boolean tieredCompilation = WB.getBooleanVMFlag("TieredCompilation");
|
|
|
|
Long compLevel = WB.getIntxVMFlag("TieredStopAtLevel");
|
|
|
|
// if TieredCompilation is enabled and compilation level is <= 3 then no Graal is used
|
|
|
|
if (tieredCompilation != null && tieredCompilation &&
|
|
|
|
compLevel != null && compLevel <= 3) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (isGraalEnabled()) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Check if C1 is used as JIT compiler.
|
|
|
|
*
|
|
|
|
* C1 is enabled if following conditions are true:
|
|
|
|
* - we are not in Interpreter mode
|
|
|
|
* - we are not in Server compilation mode
|
|
|
|
* - TieredCompilation is used in Server mode
|
|
|
|
*
|
|
|
|
* @return true if C1 is used as JIT compiler.
|
|
|
|
*/
|
|
|
|
public static boolean isC1Enabled() {
|
|
|
|
Boolean useCompiler = WB.getBooleanVMFlag("UseCompiler");
|
|
|
|
if (useCompiler == null || !useCompiler) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
Boolean serverMode = WB.getBooleanVMFlag("ProfileInterpreter");
|
|
|
|
if (serverMode == null || !serverMode) {
|
|
|
|
return true; // Client mode
|
|
|
|
}
|
|
|
|
|
|
|
|
Boolean tieredCompilation = WB.getBooleanVMFlag("TieredCompilation");
|
|
|
|
// C1 is not used in server mode if TieredCompilation is off.
|
|
|
|
if (tieredCompilation != null && !tieredCompilation) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
2018-08-13 13:24:55 -07:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Determine if the compiler corresponding to the compilation level 'compLevel'
|
|
|
|
* provides an intrinsic for 'class'.'method'.
|
|
|
|
*/
|
|
|
|
public static boolean isIntrinsicAvailable(int compLevel, String klass, String method, Class<?>... parameterTypes) {
|
|
|
|
Executable intrinsicMethod;
|
|
|
|
try {
|
|
|
|
intrinsicMethod = Class.forName(klass).getDeclaredMethod(method, parameterTypes);
|
|
|
|
} catch (NoSuchMethodException e) {
|
|
|
|
throw new RuntimeException("Test bug, '" + method + "' method unavailable. " + e);
|
|
|
|
} catch (ClassNotFoundException e) {
|
|
|
|
throw new RuntimeException("Test bug, '" + klass + "' class unavailable. " + e);
|
|
|
|
}
|
|
|
|
return WB.isIntrinsicAvailable(intrinsicMethod, compLevel);
|
|
|
|
}
|
2018-06-07 17:38:34 -07:00
|
|
|
}
|