/*
 * 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(); }