/*
* Copyright (c) 2011, 2020, 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 org.graalvm.compiler.hotspot;
import java.io.PrintStream;
import java.util.Map;
import org.graalvm.compiler.api.runtime.GraalRuntime;
import org.graalvm.compiler.core.CompilationWrapper.ExceptionAction;
import org.graalvm.compiler.core.common.CompilationIdentifier;
import org.graalvm.compiler.debug.DebugContext;
import org.graalvm.compiler.debug.DebugHandlersFactory;
import org.graalvm.compiler.debug.DiagnosticsOutputDirectory;
import org.graalvm.compiler.hotspot.meta.HotSpotProviders;
import org.graalvm.compiler.options.OptionValues;
import org.graalvm.compiler.replacements.SnippetCounter.Group;
import org.graalvm.compiler.runtime.RuntimeProvider;
import jdk.vm.ci.code.TargetDescription;
//JaCoCo Exclude
Configuration information for the HotSpot Graal runtime.
/**
* Configuration information for the HotSpot Graal runtime.
*/
public interface HotSpotGraalRuntimeProvider extends GraalRuntime, RuntimeProvider, Group.Factory {
default TargetDescription getTarget() {
return getHostBackend().getTarget();
}
HotSpotProviders getHostProviders();
@Override
default String getName() {
return getClass().getSimpleName();
}
HotSpotGraalRuntime.HotSpotGC getGarbageCollector();
@Override
HotSpotBackend getHostBackend();
GraalHotSpotVMConfig getVMConfig();
Opens a debug context for compiling compilable
. The DebugContext.close()
method should be called on the returned object once the compilation is finished. Params: - compilationOptions – the options used to configure the compilation debug context
- compilationId – a system wide unique compilation id
- compilable – the input to the compilation
- logStream – the log stream to use in this context
/**
* Opens a debug context for compiling {@code compilable}. The {@link DebugContext#close()}
* method should be called on the returned object once the compilation is finished.
*
* @param compilationOptions the options used to configure the compilation debug context
* @param compilationId a system wide unique compilation id
* @param compilable the input to the compilation
* @param logStream the log stream to use in this context
*/
DebugContext openDebugContext(OptionValues compilationOptions, CompilationIdentifier compilationId, Object compilable, Iterable<DebugHandlersFactory> factories, PrintStream logStream);
Gets the option values associated with this runtime.
/**
* Gets the option values associated with this runtime.
*/
OptionValues getOptions();
Determines if the VM is currently bootstrapping the JVMCI compiler.
/**
* Determines if the VM is currently bootstrapping the JVMCI compiler.
*/
boolean isBootstrapping();
This runtime has been requested to shutdown.
/**
* This runtime has been requested to shutdown.
*/
boolean isShutdown();
Gets a directory into which diagnostics such crash reports and dumps should be written.
/**
* Gets a directory into which diagnostics such crash reports and dumps should be written.
*/
DiagnosticsOutputDirectory getOutputDirectory();
Gets the map used to count compilation problems at each ExceptionAction
level. All updates and queries to the map should be synchronized. /**
* Gets the map used to count compilation problems at each {@link ExceptionAction} level. All
* updates and queries to the map should be synchronized.
*/
Map<ExceptionAction, Integer> getCompilationProblemsPerAction();
Returns the unique compiler configuration name that is in use. Useful for users to find out
which configuration is in use.
/**
* Returns the unique compiler configuration name that is in use. Useful for users to find out
* which configuration is in use.
*/
String getCompilerConfigurationName();
Returns the instance holding the instrumentation data structures.
/**
* Returns the instance holding the instrumentation data structures.
*/
Instrumentation getInstrumentation();
}