本文整理匯總了Java中jdk.vm.ci.meta.MetaAccessProvider類的典型用法代碼示例。如果您正苦於以下問題:Java MetaAccessProvider類的具體用法?Java MetaAccessProvider怎麽用?Java MetaAccessProvider使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
MetaAccessProvider類屬於jdk.vm.ci.meta包,在下文中一共展示了MetaAccessProvider類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: eagerlyParseMethod
import jdk.vm.ci.meta.MetaAccessProvider; //導入依賴的package包/類
@SuppressWarnings("try")
private void eagerlyParseMethod(Class<C> clazz, String methodName) {
RuntimeProvider rt = Graal.getRequiredCapability(RuntimeProvider.class);
Providers providers = rt.getHostBackend().getProviders();
MetaAccessProvider metaAccess = providers.getMetaAccess();
PhaseSuite<HighTierContext> graphBuilderSuite = new PhaseSuite<>();
Plugins plugins = new Plugins(new InvocationPlugins());
GraphBuilderConfiguration config = GraphBuilderConfiguration.getDefault(plugins).withEagerResolving(true);
graphBuilderSuite.appendPhase(new GraphBuilderPhase(config));
HighTierContext context = new HighTierContext(providers, graphBuilderSuite, OptimisticOptimizations.NONE);
Assume.assumeTrue(VerifyPhase.class.desiredAssertionStatus());
final Method m = getMethod(clazz, methodName);
ResolvedJavaMethod method = metaAccess.lookupJavaMethod(m);
OptionValues options = getInitialOptions();
DebugContext debug = DebugContext.create(options, DebugHandlersFactory.LOADER);
StructuredGraph graph = new StructuredGraph.Builder(options, debug).method(method).build();
try (DebugCloseable s = debug.disableIntercept(); DebugContext.Scope ds = debug.scope("GraphBuilding", graph, method)) {
graphBuilderSuite.apply(graph, context);
} catch (Throwable e) {
throw debug.handle(e);
}
}
示例2: checkInjectedArgument
import jdk.vm.ci.meta.MetaAccessProvider; //導入依賴的package包/類
protected boolean checkInjectedArgument(GraphBuilderContext b, ValueNode arg, ResolvedJavaMethod foldAnnotatedMethod) {
if (arg.isNullConstant()) {
return true;
}
MetaAccessProvider metaAccess = b.getMetaAccess();
ResolvedJavaMethod executeMethod = metaAccess.lookupJavaMethod(getExecuteMethod());
ResolvedJavaType thisClass = metaAccess.lookupJavaType(getClass());
ResolvedJavaMethod thisExecuteMethod = thisClass.resolveConcreteMethod(executeMethod, thisClass);
if (b.getMethod().equals(thisExecuteMethod)) {
// The "execute" method of this plugin is itself being compiled. In (only) this context,
// the injected argument of the call to the @Fold annotated method will be non-null.
return true;
}
throw new AssertionError("must pass null to injected argument of " + foldAnnotatedMethod.format("%H.%n(%p)") + ", not " + arg);
}
示例3: testBailoutUsage
import jdk.vm.ci.meta.MetaAccessProvider; //導入依賴的package包/類
@SuppressWarnings("try")
private static void testBailoutUsage(Class<?> c) {
RuntimeProvider rt = Graal.getRequiredCapability(RuntimeProvider.class);
Providers providers = rt.getHostBackend().getProviders();
MetaAccessProvider metaAccess = providers.getMetaAccess();
PhaseSuite<HighTierContext> graphBuilderSuite = new PhaseSuite<>();
Plugins plugins = new Plugins(new InvocationPlugins());
GraphBuilderConfiguration config = GraphBuilderConfiguration.getDefault(plugins).withEagerResolving(true);
graphBuilderSuite.appendPhase(new GraphBuilderPhase(config));
HighTierContext context = new HighTierContext(providers, graphBuilderSuite, OptimisticOptimizations.NONE);
OptionValues options = getInitialOptions();
DebugContext debug = DebugContext.create(options, DebugHandlersFactory.LOADER);
for (Method m : c.getDeclaredMethods()) {
if (!Modifier.isNative(m.getModifiers()) && !Modifier.isAbstract(m.getModifiers())) {
ResolvedJavaMethod method = metaAccess.lookupJavaMethod(m);
StructuredGraph graph = new StructuredGraph.Builder(options, debug).method(method).build();
graphBuilderSuite.apply(graph, context);
try (DebugCloseable s = debug.disableIntercept()) {
new VerifyBailoutUsage().apply(graph, context);
}
}
}
}
示例4: tryConstantFold
import jdk.vm.ci.meta.MetaAccessProvider; //導入依賴的package包/類
private static ValueNode tryConstantFold(ValueNode array, ValueNode index, MetaAccessProvider metaAccess, ConstantReflectionProvider constantReflection) {
if (array.isConstant() && !array.isNullConstant() && index.isConstant()) {
JavaConstant arrayConstant = array.asJavaConstant();
if (arrayConstant != null) {
int stableDimension = ((ConstantNode) array).getStableDimension();
if (stableDimension > 0) {
JavaConstant constant = constantReflection.readArrayElement(arrayConstant, index.asJavaConstant().asInt());
boolean isDefaultStable = ((ConstantNode) array).isDefaultStable();
if (constant != null && (isDefaultStable || !constant.isDefaultForKind())) {
return ConstantNode.forConstant(constant, stableDimension - 1, isDefaultStable, metaAccess);
}
}
}
}
return null;
}
示例5: create
import jdk.vm.ci.meta.MetaAccessProvider; //導入依賴的package包/類
public static ValueNode create(MetaAccessProvider metaAccess, ConstantReflectionProvider constantReflection, ValueNode value, JavaKind boxingKind) {
ValueNode synonym = findSynonym(metaAccess, constantReflection, value, boxingKind);
if (synonym != null) {
return synonym;
}
return new UnboxNode(value, boxingKind);
}
示例6: createHints
import jdk.vm.ci.meta.MetaAccessProvider; //導入依賴的package包/類
static Hints createHints(TypeCheckHints hints, MetaAccessProvider metaAccess, boolean positiveOnly, StructuredGraph graph) {
ConstantNode[] hubs = new ConstantNode[hints.hints.length];
boolean[] isPositive = new boolean[hints.hints.length];
int index = 0;
for (int i = 0; i < hubs.length; i++) {
if (!positiveOnly || hints.hints[i].positive) {
hubs[index] = ConstantNode.forConstant(KlassPointerStamp.klassNonNull(), ((HotSpotResolvedObjectType) hints.hints[i].type).klass(), metaAccess, graph);
isPositive[index] = hints.hints[i].positive;
index++;
}
}
if (positiveOnly && index != hubs.length) {
assert index < hubs.length;
hubs = Arrays.copyOf(hubs, index);
isPositive = Arrays.copyOf(isPositive, index);
}
return new Hints(hubs, isPositive);
}
示例7: getSpecialClasses
import jdk.vm.ci.meta.MetaAccessProvider; //導入依賴的package包/類
private static List<ResolvedJavaType> getSpecialClasses(MetaAccessProvider meta) {
// @formatter:off
return Arrays.asList(meta.lookupJavaType(Snippets.class),
meta.lookupJavaType(HotSpotClassSubstitutions.class),
meta.lookupJavaType(GraalDirectives.class),
meta.lookupJavaType(ClassSubstitution.class));
// @formatter:on
}
示例8: isIllegalUsage
import jdk.vm.ci.meta.MetaAccessProvider; //導入依賴的package包/類
/**
* Checks whether the type of {@code x} is assignable to the restricted type and that {@code y}
* is not a null constant.
*/
private boolean isIllegalUsage(ResolvedJavaMethod method, ValueNode x, ValueNode y, MetaAccessProvider metaAccess) {
if (isAssignableToRestrictedType(x, metaAccess) && !isNullConstant(y)) {
if (isEqualsMethod(method) && isThisParameter(x) || isThisParameter(y)) {
return false;
}
return true;
}
return false;
}
示例9: create
import jdk.vm.ci.meta.MetaAccessProvider; //導入依賴的package包/類
public static LogicNode create(ConstantReflectionProvider constantReflection, MetaAccessProvider metaAccess, OptionValues options, Integer smallestCompareWidth,
ValueNode x, ValueNode y) {
LogicNode value = OP.canonical(constantReflection, metaAccess, options, smallestCompareWidth, OP.getCondition(), false, x, y);
if (value != null) {
return value;
}
return create(x, y);
}
示例10: canonicalizeBoxing
import jdk.vm.ci.meta.MetaAccessProvider; //導入依賴的package包/類
public static FloatingNode canonicalizeBoxing(BoxNode box, MetaAccessProvider metaAccess, ConstantReflectionProvider constantReflection) {
ValueNode value = box.getValue();
if (value.isConstant()) {
JavaConstant sourceConstant = value.asJavaConstant();
if (sourceConstant.getJavaKind() != box.getBoxingKind() && sourceConstant.getJavaKind().isNumericInteger()) {
switch (box.getBoxingKind()) {
case Boolean:
sourceConstant = JavaConstant.forBoolean(sourceConstant.asLong() != 0L);
break;
case Byte:
sourceConstant = JavaConstant.forByte((byte) sourceConstant.asLong());
break;
case Char:
sourceConstant = JavaConstant.forChar((char) sourceConstant.asLong());
break;
case Short:
sourceConstant = JavaConstant.forShort((short) sourceConstant.asLong());
break;
}
}
JavaConstant boxedConstant = constantReflection.boxPrimitive(sourceConstant);
if (boxedConstant != null && sourceConstant.getJavaKind() == box.getBoxingKind()) {
return ConstantNode.forConstant(boxedConstant, metaAccess, box.graph());
}
}
return null;
}
示例11: checkConstantArgument
import jdk.vm.ci.meta.MetaAccessProvider; //導入依賴的package包/類
private static boolean checkConstantArgument(MetaAccessProvider metaAccess, final ResolvedJavaMethod method, Signature signature, int i, String name, Object arg, JavaKind kind) {
ResolvedJavaType type = signature.getParameterType(i, method.getDeclaringClass()).resolve(method.getDeclaringClass());
if (metaAccess.lookupJavaType(WordBase.class).isAssignableFrom(type)) {
assert arg instanceof JavaConstant : method + ": word constant parameters must be passed boxed in a Constant value: " + arg;
return true;
}
if (kind != JavaKind.Object) {
assert arg != null && kind.toBoxedJavaClass() == arg.getClass() : method + ": wrong value kind for " + name + ": expected " + kind + ", got " +
(arg == null ? "null" : arg.getClass().getSimpleName());
}
return true;
}
示例12: checkVarargs
import jdk.vm.ci.meta.MetaAccessProvider; //導入依賴的package包/類
private static boolean checkVarargs(MetaAccessProvider metaAccess, final ResolvedJavaMethod method, Signature signature, int i, String name, Varargs varargs) {
ResolvedJavaType type = (ResolvedJavaType) signature.getParameterType(i, method.getDeclaringClass());
assert type.isArray() : "varargs parameter must be an array type";
assert type.getComponentType().isAssignableFrom(metaAccess.lookupJavaType(varargs.componentType)) : "componentType for " + name + " not matching " + type.toJavaName() + " instance: " +
varargs.componentType;
return true;
}
示例13: forConstant
import jdk.vm.ci.meta.MetaAccessProvider; //導入依賴的package包/類
public static ConstantNode forConstant(JavaConstant constant, int stableDimension, boolean isDefaultStable, MetaAccessProvider metaAccess) {
if (constant.getJavaKind().getStackKind() == JavaKind.Int && constant.getJavaKind() != JavaKind.Int) {
return forInt(constant.asInt());
}
if (constant.getJavaKind() == JavaKind.Object) {
return new ConstantNode(constant, StampFactory.forConstant(constant, metaAccess), stableDimension, isDefaultStable);
} else {
assert stableDimension == 0;
return createPrimitive(constant);
}
}
示例14: constant
import jdk.vm.ci.meta.MetaAccessProvider; //導入依賴的package包/類
@Override
public Stamp constant(Constant c, MetaAccessProvider meta) {
if (JavaConstant.NULL_POINTER.equals(c)) {
return METHOD_ALWAYS_NULL;
} else {
assert c instanceof HotSpotMetaspaceConstant;
return METHOD_NON_NULL;
}
}
示例15: buildInitialGraph
import jdk.vm.ci.meta.MetaAccessProvider; //導入依賴的package包/類
/**
* Builds the initial graph for a replacement.
*/
@SuppressWarnings("try")
protected StructuredGraph buildInitialGraph(DebugContext debug, BytecodeProvider bytecodeProvider, final ResolvedJavaMethod methodToParse, Object[] args) {
// Replacements cannot have optimistic assumptions since they have
// to be valid for the entire run of the VM.
final StructuredGraph graph = new StructuredGraph.Builder(replacements.options, debug).method(methodToParse).build();
// Replacements are not user code so they do not participate in unsafe access
// tracking
graph.disableUnsafeAccessTracking();
try (DebugContext.Scope s = debug.scope("buildInitialGraph", graph)) {
MetaAccessProvider metaAccess = replacements.providers.getMetaAccess();
Plugins plugins = new Plugins(replacements.graphBuilderPlugins);
GraphBuilderConfiguration config = GraphBuilderConfiguration.getSnippetDefault(plugins);
if (args != null) {
plugins.prependParameterPlugin(new ConstantBindingParameterPlugin(args, metaAccess, replacements.snippetReflection));
}
IntrinsicContext initialIntrinsicContext = null;
if (method.getAnnotation(Snippet.class) == null) {
// Post-parse inlined intrinsic
initialIntrinsicContext = new IntrinsicContext(substitutedMethod, method, bytecodeProvider, INLINE_AFTER_PARSING);
} else {
// Snippet
ResolvedJavaMethod original = substitutedMethod != null ? substitutedMethod : method;
initialIntrinsicContext = new IntrinsicContext(original, method, bytecodeProvider, INLINE_AFTER_PARSING);
}
createGraphBuilder(metaAccess, replacements.providers.getStampProvider(), replacements.providers.getConstantReflection(), replacements.providers.getConstantFieldProvider(), config,
OptimisticOptimizations.NONE, initialIntrinsicContext).apply(graph);
new CanonicalizerPhase().apply(graph, new PhaseContext(replacements.providers));
} catch (Throwable e) {
throw debug.handle(e);
}
return graph;
}