src/jdk.internal.vm.compiler/share/classes/org.graalvm.compiler.nodes/src/org/graalvm/compiler/nodes/graphbuilderconf/GraphBuilderContext.java
author dlong
Tue, 24 Sep 2019 12:47:15 -0400
changeset 58299 6df94ce3ab2f
parent 54601 c40b2a190173
permissions -rw-r--r--
8229201: Update Graal Reviewed-by: kvn
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
     1
/*
58299
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 54601
diff changeset
     2
 * Copyright (c) 2015, 2019, Oracle and/or its affiliates. All rights reserved.
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
     4
 *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
     7
 * published by the Free Software Foundation.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
     8
 *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    13
 * accompanied this code).
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    14
 *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    18
 *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    21
 * questions.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    22
 */
50858
2d3e99a72541 8205824: Update Graal
never
parents: 50609
diff changeset
    23
2d3e99a72541 8205824: Update Graal
never
parents: 50609
diff changeset
    24
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    25
package org.graalvm.compiler.nodes.graphbuilderconf;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    26
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    27
import static jdk.vm.ci.meta.DeoptimizationAction.InvalidateReprofile;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    28
import static jdk.vm.ci.meta.DeoptimizationReason.NullCheckException;
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    29
import static org.graalvm.compiler.core.common.type.StampFactory.objectNonNull;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    30
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    31
import org.graalvm.compiler.bytecode.Bytecode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    32
import org.graalvm.compiler.bytecode.BytecodeProvider;
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    33
import org.graalvm.compiler.core.common.type.AbstractPointerStamp;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    34
import org.graalvm.compiler.core.common.type.Stamp;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    35
import org.graalvm.compiler.core.common.type.StampFactory;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    36
import org.graalvm.compiler.core.common.type.StampPair;
51436
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
    37
import org.graalvm.compiler.debug.GraalError;
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
    38
import org.graalvm.compiler.nodes.AbstractBeginNode;
50858
2d3e99a72541 8205824: Update Graal
never
parents: 50609
diff changeset
    39
import org.graalvm.compiler.nodes.AbstractMergeNode;
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    40
import org.graalvm.compiler.nodes.CallTargetNode;
46807
8b2c620d7092 8186158: Update Graal
iveresov
parents: 46393
diff changeset
    41
import org.graalvm.compiler.nodes.CallTargetNode.InvokeKind;
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    42
import org.graalvm.compiler.nodes.ConstantNode;
52910
583fd71c47d6 8214023: Update Graal
dlong
parents: 51436
diff changeset
    43
import org.graalvm.compiler.nodes.DynamicPiNode;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    44
import org.graalvm.compiler.nodes.FixedGuardNode;
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    45
import org.graalvm.compiler.nodes.Invoke;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    46
import org.graalvm.compiler.nodes.LogicNode;
48190
25cfedf27edc 8192814: Update Graal
dlong
parents: 47798
diff changeset
    47
import org.graalvm.compiler.nodes.NodeView;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    48
import org.graalvm.compiler.nodes.PiNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    49
import org.graalvm.compiler.nodes.StateSplit;
54601
c40b2a190173 8221598: Update Graal
jwilhelm
parents: 54084
diff changeset
    50
import org.graalvm.compiler.nodes.StructuredGraph;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    51
import org.graalvm.compiler.nodes.ValueNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    52
import org.graalvm.compiler.nodes.calc.IsNullNode;
50609
bf414874c28f 8204231: Update Graal
dlong
parents: 48190
diff changeset
    53
import org.graalvm.compiler.nodes.calc.NarrowNode;
bf414874c28f 8204231: Update Graal
dlong
parents: 48190
diff changeset
    54
import org.graalvm.compiler.nodes.calc.SignExtendNode;
bf414874c28f 8204231: Update Graal
dlong
parents: 48190
diff changeset
    55
import org.graalvm.compiler.nodes.calc.ZeroExtendNode;
51436
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
    56
import org.graalvm.compiler.nodes.extended.BytecodeExceptionNode.BytecodeExceptionKind;
52910
583fd71c47d6 8214023: Update Graal
dlong
parents: 51436
diff changeset
    57
import org.graalvm.compiler.nodes.java.InstanceOfDynamicNode;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    58
import org.graalvm.compiler.nodes.type.StampTool;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    59
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    60
import jdk.vm.ci.code.BailoutException;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    61
import jdk.vm.ci.meta.Assumptions;
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    62
import jdk.vm.ci.meta.DeoptimizationAction;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    63
import jdk.vm.ci.meta.DeoptimizationReason;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    64
import jdk.vm.ci.meta.JavaKind;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    65
import jdk.vm.ci.meta.JavaType;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    66
import jdk.vm.ci.meta.ResolvedJavaMethod;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    67
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    68
/**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    69
 * Used by a {@link GraphBuilderPlugin} to interface with an object that parses the bytecode of a
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    70
 * single {@linkplain #getMethod() method} as part of building a {@linkplain #getGraph() graph} .
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    71
 */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    72
public interface GraphBuilderContext extends GraphBuilderTool {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    73
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    74
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    75
     * Pushes a given value to the frame state stack using an explicit kind. This should be used
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    76
     * when {@code value.getJavaKind()} is different from the kind that the bytecode instruction
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    77
     * currently being parsed pushes to the stack.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    78
     *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    79
     * @param kind the kind to use when type checking this operation
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    80
     * @param value the value to push to the stack. The value must already have been
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    81
     *            {@linkplain #append(ValueNode) appended}.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    82
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    83
    void push(JavaKind kind, ValueNode value);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    84
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    85
    /**
51436
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
    86
     * Pops a value from the frame state stack using an explicit kind.
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
    87
     *
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
    88
     * @param slotKind the kind to use when type checking this operation
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
    89
     * @return the value on the top of the stack
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
    90
     */
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
    91
    default ValueNode pop(JavaKind slotKind) {
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
    92
        throw GraalError.unimplemented();
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
    93
    }
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
    94
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
    95
    /**
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    96
     * Adds a node and all its inputs to the graph. If the node is in the graph, returns
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    97
     * immediately. If the node is a {@link StateSplit} with a null
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    98
     * {@linkplain StateSplit#stateAfter() frame state} , the frame state is initialized.
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    99
     *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   100
     * @param value the value to add to the graph and push to the stack. The
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   101
     *            {@code value.getJavaKind()} kind is used when type checking this operation.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   102
     * @return a node equivalent to {@code value} in the graph
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   103
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   104
    default <T extends ValueNode> T add(T value) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   105
        if (value.graph() != null) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   106
            assert !(value instanceof StateSplit) || ((StateSplit) value).stateAfter() != null;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   107
            return value;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   108
        }
50858
2d3e99a72541 8205824: Update Graal
never
parents: 50609
diff changeset
   109
        return GraphBuilderContextUtil.setStateAfterIfNecessary(this, append(value));
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   110
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   111
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   112
    default ValueNode addNonNullCast(ValueNode value) {
48190
25cfedf27edc 8192814: Update Graal
dlong
parents: 47798
diff changeset
   113
        AbstractPointerStamp valueStamp = (AbstractPointerStamp) value.stamp(NodeView.DEFAULT);
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   114
        if (valueStamp.nonNull()) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   115
            return value;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   116
        } else {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   117
            LogicNode isNull = add(IsNullNode.create(value));
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   118
            FixedGuardNode fixedGuard = add(new FixedGuardNode(isNull, DeoptimizationReason.NullCheckException, DeoptimizationAction.None, true));
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   119
            Stamp newStamp = valueStamp.improveWith(StampFactory.objectNonNull());
46371
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   120
            return add(PiNode.create(value, newStamp, fixedGuard));
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   121
        }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   122
    }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   123
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   124
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   125
     * Adds a node with a non-void kind to the graph, pushes it to the stack. If the returned node
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   126
     * is a {@link StateSplit} with a null {@linkplain StateSplit#stateAfter() frame state}, the
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   127
     * frame state is initialized.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   128
     *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   129
     * @param kind the kind to use when type checking this operation
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   130
     * @param value the value to add to the graph and push to the stack
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   131
     * @return a node equivalent to {@code value} in the graph
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   132
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   133
    default <T extends ValueNode> T addPush(JavaKind kind, T value) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   134
        T equivalentValue = value.graph() != null ? value : append(value);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   135
        push(kind, equivalentValue);
50858
2d3e99a72541 8205824: Update Graal
never
parents: 50609
diff changeset
   136
        return GraphBuilderContextUtil.setStateAfterIfNecessary(this, equivalentValue);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   137
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   138
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   139
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   140
     * Handles an invocation that a plugin determines can replace the original invocation (i.e., the
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   141
     * one for which the plugin was applied). This applies all standard graph builder processing to
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   142
     * the replaced invocation including applying any relevant plugins.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   143
     *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   144
     * @param invokeKind the kind of the replacement invocation
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   145
     * @param targetMethod the target of the replacement invocation
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   146
     * @param args the arguments to the replacement invocation
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   147
     * @param forceInlineEverything specifies if all invocations encountered in the scope of
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   148
     *            handling the replaced invoke are to be force inlined
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   149
     */
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   150
    Invoke handleReplacedInvoke(InvokeKind invokeKind, ResolvedJavaMethod targetMethod, ValueNode[] args, boolean forceInlineEverything);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   151
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   152
    void handleReplacedInvoke(CallTargetNode callTarget, JavaKind resultType);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   153
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   154
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   155
     * Intrinsifies an invocation of a given method by inlining the bytecodes of a given
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   156
     * substitution method.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   157
     *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   158
     * @param bytecodeProvider used to get the bytecodes to parse for the substitution method
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   159
     * @param targetMethod the method being intrinsified
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   160
     * @param substitute the intrinsic implementation
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   161
     * @param receiver the receiver, or null for static methods
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   162
     * @param argsIncludingReceiver the arguments with which to inline the invocation
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   163
     *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   164
     * @return whether the intrinsification was successful
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   165
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   166
    boolean intrinsify(BytecodeProvider bytecodeProvider, ResolvedJavaMethod targetMethod, ResolvedJavaMethod substitute, InvocationPlugin.Receiver receiver, ValueNode[] argsIncludingReceiver);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   167
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   168
    /**
54601
c40b2a190173 8221598: Update Graal
jwilhelm
parents: 54084
diff changeset
   169
     * Intrinsifies an invocation of a given method by inlining the graph of a given substitution
c40b2a190173 8221598: Update Graal
jwilhelm
parents: 54084
diff changeset
   170
     * method.
c40b2a190173 8221598: Update Graal
jwilhelm
parents: 54084
diff changeset
   171
     *
c40b2a190173 8221598: Update Graal
jwilhelm
parents: 54084
diff changeset
   172
     * @param targetMethod the method being intrinsified
c40b2a190173 8221598: Update Graal
jwilhelm
parents: 54084
diff changeset
   173
     * @param substituteGraph the intrinsic implementation
c40b2a190173 8221598: Update Graal
jwilhelm
parents: 54084
diff changeset
   174
     * @param receiver the receiver, or null for static methods
c40b2a190173 8221598: Update Graal
jwilhelm
parents: 54084
diff changeset
   175
     * @param argsIncludingReceiver the arguments with which to inline the invocation
c40b2a190173 8221598: Update Graal
jwilhelm
parents: 54084
diff changeset
   176
     *
c40b2a190173 8221598: Update Graal
jwilhelm
parents: 54084
diff changeset
   177
     * @return whether the intrinsification was successful
c40b2a190173 8221598: Update Graal
jwilhelm
parents: 54084
diff changeset
   178
     */
c40b2a190173 8221598: Update Graal
jwilhelm
parents: 54084
diff changeset
   179
    boolean intrinsify(ResolvedJavaMethod targetMethod, StructuredGraph substituteGraph, InvocationPlugin.Receiver receiver, ValueNode[] argsIncludingReceiver);
c40b2a190173 8221598: Update Graal
jwilhelm
parents: 54084
diff changeset
   180
c40b2a190173 8221598: Update Graal
jwilhelm
parents: 54084
diff changeset
   181
    /**
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   182
     * Creates a snap shot of the current frame state with the BCI of the instruction after the one
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   183
     * currently being parsed and assigns it to a given {@linkplain StateSplit#hasSideEffect() side
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   184
     * effect} node.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   185
     *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   186
     * @param sideEffect a side effect node just appended to the graph
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   187
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   188
    void setStateAfter(StateSplit sideEffect);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   189
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   190
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   191
     * Gets the parsing context for the method that inlines the method being parsed by this context.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   192
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   193
    GraphBuilderContext getParent();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   194
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   195
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   196
     * Gets the first ancestor parsing context that is not parsing a {@linkplain #parsingIntrinsic()
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   197
     * intrinsic}.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   198
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   199
    default GraphBuilderContext getNonIntrinsicAncestor() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   200
        GraphBuilderContext ancestor = getParent();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   201
        while (ancestor != null && ancestor.parsingIntrinsic()) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   202
            ancestor = ancestor.getParent();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   203
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   204
        return ancestor;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   205
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   206
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   207
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   208
     * Gets the code being parsed.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   209
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   210
    Bytecode getCode();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   211
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   212
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   213
     * Gets the method being parsed by this context.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   214
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   215
    ResolvedJavaMethod getMethod();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   216
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   217
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   218
     * Gets the index of the bytecode instruction currently being parsed.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   219
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   220
    int bci();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   221
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   222
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   223
     * Gets the kind of invocation currently being parsed.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   224
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   225
    InvokeKind getInvokeKind();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   226
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   227
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   228
     * Gets the return type of the invocation currently being parsed.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   229
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   230
    JavaType getInvokeReturnType();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   231
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   232
    default StampPair getInvokeReturnStamp(Assumptions assumptions) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   233
        JavaType returnType = getInvokeReturnType();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   234
        return StampFactory.forDeclaredType(assumptions, returnType, false);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   235
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   236
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   237
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   238
     * Gets the inline depth of this context. A return value of 0 implies that this is the context
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   239
     * for the parse root.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   240
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   241
    default int getDepth() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   242
        GraphBuilderContext parent = getParent();
46807
8b2c620d7092 8186158: Update Graal
iveresov
parents: 46393
diff changeset
   243
        int result = 0;
8b2c620d7092 8186158: Update Graal
iveresov
parents: 46393
diff changeset
   244
        while (parent != null) {
8b2c620d7092 8186158: Update Graal
iveresov
parents: 46393
diff changeset
   245
            result++;
8b2c620d7092 8186158: Update Graal
iveresov
parents: 46393
diff changeset
   246
            parent = parent.getParent();
8b2c620d7092 8186158: Update Graal
iveresov
parents: 46393
diff changeset
   247
        }
8b2c620d7092 8186158: Update Graal
iveresov
parents: 46393
diff changeset
   248
        return result;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   249
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   250
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   251
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   252
     * Determines if this parsing context is within the bytecode of an intrinsic or a method inlined
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   253
     * by an intrinsic.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   254
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   255
    @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   256
    default boolean parsingIntrinsic() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   257
        return getIntrinsic() != null;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   258
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   259
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   260
    /**
58299
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 54601
diff changeset
   261
     * Determines if a graph builder plugin is enabled under current context.
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 54601
diff changeset
   262
     */
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 54601
diff changeset
   263
    default boolean isPluginEnabled(GraphBuilderPlugin plugin) {
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 54601
diff changeset
   264
        return parsingIntrinsic() || !(plugin instanceof GeneratedInvocationPlugin && ((GeneratedInvocationPlugin) plugin).isGeneratedFromFoldOrNodeIntrinsic());
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 54601
diff changeset
   265
    }
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 54601
diff changeset
   266
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 54601
diff changeset
   267
    /**
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   268
     * Gets the intrinsic of the current parsing context or {@code null} if not
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   269
     * {@link #parsingIntrinsic() parsing an intrinsic}.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   270
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   271
    IntrinsicContext getIntrinsic();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   272
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   273
    BailoutException bailout(String string);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   274
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   275
    default ValueNode nullCheckedValue(ValueNode value) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   276
        return nullCheckedValue(value, InvalidateReprofile);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   277
    }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   278
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   279
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   280
     * Gets a version of a given value that has a {@linkplain StampTool#isPointerNonNull(ValueNode)
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   281
     * non-null} stamp.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   282
     */
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   283
    default ValueNode nullCheckedValue(ValueNode value, DeoptimizationAction action) {
46371
0337d0617e7b 8178088: Update Graal
iveresov
parents: 46344
diff changeset
   284
        if (!StampTool.isPointerNonNull(value)) {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   285
            LogicNode condition = getGraph().unique(IsNullNode.create(value));
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   286
            FixedGuardNode fixedGuard = append(new FixedGuardNode(condition, NullCheckException, action, true));
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   287
            ValueNode nonNullReceiver = getGraph().addOrUniqueWithInputs(PiNode.create(value, objectNonNull(), fixedGuard));
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   288
            // TODO: Propogating the non-null into the frame state would
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   289
            // remove subsequent null-checks on the same value. However,
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   290
            // it currently causes an assertion failure when merging states.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   291
            //
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   292
            // frameState.replace(value, nonNullReceiver);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   293
            return nonNullReceiver;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   294
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   295
        return value;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   296
    }
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   297
52910
583fd71c47d6 8214023: Update Graal
dlong
parents: 51436
diff changeset
   298
    default void genCheckcastDynamic(ValueNode object, ValueNode javaClass) {
583fd71c47d6 8214023: Update Graal
dlong
parents: 51436
diff changeset
   299
        LogicNode condition = InstanceOfDynamicNode.create(getAssumptions(), getConstantReflection(), javaClass, object, true);
583fd71c47d6 8214023: Update Graal
dlong
parents: 51436
diff changeset
   300
        if (condition.isTautology()) {
583fd71c47d6 8214023: Update Graal
dlong
parents: 51436
diff changeset
   301
            addPush(JavaKind.Object, object);
583fd71c47d6 8214023: Update Graal
dlong
parents: 51436
diff changeset
   302
        } else {
583fd71c47d6 8214023: Update Graal
dlong
parents: 51436
diff changeset
   303
            append(condition);
583fd71c47d6 8214023: Update Graal
dlong
parents: 51436
diff changeset
   304
            FixedGuardNode fixedGuard = add(new FixedGuardNode(condition, DeoptimizationReason.ClassCastException, DeoptimizationAction.InvalidateReprofile, false));
583fd71c47d6 8214023: Update Graal
dlong
parents: 51436
diff changeset
   305
            addPush(JavaKind.Object, DynamicPiNode.create(getAssumptions(), getConstantReflection(), object, fixedGuard, javaClass));
583fd71c47d6 8214023: Update Graal
dlong
parents: 51436
diff changeset
   306
        }
583fd71c47d6 8214023: Update Graal
dlong
parents: 51436
diff changeset
   307
    }
583fd71c47d6 8214023: Update Graal
dlong
parents: 51436
diff changeset
   308
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   309
    @SuppressWarnings("unused")
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   310
    default void notifyReplacedCall(ResolvedJavaMethod targetMethod, ConstantNode node) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   311
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   312
    }
47667
390896759aa2 8187438: Update Graal
dlong
parents: 47216
diff changeset
   313
390896759aa2 8187438: Update Graal
dlong
parents: 47216
diff changeset
   314
    /**
390896759aa2 8187438: Update Graal
dlong
parents: 47216
diff changeset
   315
     * Interface whose instances hold inlining information about the current context, in a wider
390896759aa2 8187438: Update Graal
dlong
parents: 47216
diff changeset
   316
     * sense. The wider sense in this case concerns graph building approaches that don't necessarily
390896759aa2 8187438: Update Graal
dlong
parents: 47216
diff changeset
   317
     * keep a chain of {@link GraphBuilderContext} instances normally available through
390896759aa2 8187438: Update Graal
dlong
parents: 47216
diff changeset
   318
     * {@linkplain #getParent()}. Examples of such approaches are partial evaluation and incremental
390896759aa2 8187438: Update Graal
dlong
parents: 47216
diff changeset
   319
     * inlining.
390896759aa2 8187438: Update Graal
dlong
parents: 47216
diff changeset
   320
     */
390896759aa2 8187438: Update Graal
dlong
parents: 47216
diff changeset
   321
    interface ExternalInliningContext {
390896759aa2 8187438: Update Graal
dlong
parents: 47216
diff changeset
   322
        int getInlinedDepth();
390896759aa2 8187438: Update Graal
dlong
parents: 47216
diff changeset
   323
    }
390896759aa2 8187438: Update Graal
dlong
parents: 47216
diff changeset
   324
390896759aa2 8187438: Update Graal
dlong
parents: 47216
diff changeset
   325
    default ExternalInliningContext getExternalInliningContext() {
390896759aa2 8187438: Update Graal
dlong
parents: 47216
diff changeset
   326
        return null;
390896759aa2 8187438: Update Graal
dlong
parents: 47216
diff changeset
   327
    }
390896759aa2 8187438: Update Graal
dlong
parents: 47216
diff changeset
   328
50609
bf414874c28f 8204231: Update Graal
dlong
parents: 48190
diff changeset
   329
    /**
bf414874c28f 8204231: Update Graal
dlong
parents: 48190
diff changeset
   330
     * Adds masking to a given subword value according to a given {@Link JavaKind}, such that the
bf414874c28f 8204231: Update Graal
dlong
parents: 48190
diff changeset
   331
     * masked value falls in the range of the given kind. In the cases where the given kind is not a
bf414874c28f 8204231: Update Graal
dlong
parents: 48190
diff changeset
   332
     * subword kind, the input value is returned immediately.
bf414874c28f 8204231: Update Graal
dlong
parents: 48190
diff changeset
   333
     *
bf414874c28f 8204231: Update Graal
dlong
parents: 48190
diff changeset
   334
     * @param value the value to be masked
bf414874c28f 8204231: Update Graal
dlong
parents: 48190
diff changeset
   335
     * @param kind the kind that specifies the range of the masked value
bf414874c28f 8204231: Update Graal
dlong
parents: 48190
diff changeset
   336
     * @return the masked value
bf414874c28f 8204231: Update Graal
dlong
parents: 48190
diff changeset
   337
     */
bf414874c28f 8204231: Update Graal
dlong
parents: 48190
diff changeset
   338
    default ValueNode maskSubWordValue(ValueNode value, JavaKind kind) {
bf414874c28f 8204231: Update Graal
dlong
parents: 48190
diff changeset
   339
        if (kind == kind.getStackKind()) {
bf414874c28f 8204231: Update Graal
dlong
parents: 48190
diff changeset
   340
            return value;
bf414874c28f 8204231: Update Graal
dlong
parents: 48190
diff changeset
   341
        }
bf414874c28f 8204231: Update Graal
dlong
parents: 48190
diff changeset
   342
        // Subword value
bf414874c28f 8204231: Update Graal
dlong
parents: 48190
diff changeset
   343
        ValueNode narrow = append(NarrowNode.create(value, kind.getBitCount(), NodeView.DEFAULT));
bf414874c28f 8204231: Update Graal
dlong
parents: 48190
diff changeset
   344
        if (kind.isUnsigned()) {
bf414874c28f 8204231: Update Graal
dlong
parents: 48190
diff changeset
   345
            return append(ZeroExtendNode.create(narrow, 32, NodeView.DEFAULT));
bf414874c28f 8204231: Update Graal
dlong
parents: 48190
diff changeset
   346
        } else {
bf414874c28f 8204231: Update Graal
dlong
parents: 48190
diff changeset
   347
            return append(SignExtendNode.create(narrow, 32, NodeView.DEFAULT));
bf414874c28f 8204231: Update Graal
dlong
parents: 48190
diff changeset
   348
        }
bf414874c28f 8204231: Update Graal
dlong
parents: 48190
diff changeset
   349
    }
51436
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   350
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   351
    /**
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   352
     * @return true if an explicit exception check should be emitted.
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   353
     */
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   354
    default boolean needsExplicitException() {
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   355
        return false;
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   356
    }
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   357
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   358
    /**
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   359
     * Generates an exception edge for the current bytecode. When {@link #needsExplicitException()}
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   360
     * returns true, this method should return non-null begin nodes.
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   361
     *
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   362
     * @param exceptionKind the type of exception to be created.
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   363
     * @return a begin node that precedes the actual exception instantiation code.
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   364
     */
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   365
    default AbstractBeginNode genExplicitExceptionEdge(@SuppressWarnings("ununsed") BytecodeExceptionKind exceptionKind) {
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   366
        return null;
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   367
    }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   368
}
50858
2d3e99a72541 8205824: Update Graal
never
parents: 50609
diff changeset
   369
2d3e99a72541 8205824: Update Graal
never
parents: 50609
diff changeset
   370
class GraphBuilderContextUtil {
2d3e99a72541 8205824: Update Graal
never
parents: 50609
diff changeset
   371
    static <T extends ValueNode> T setStateAfterIfNecessary(GraphBuilderContext b, T value) {
2d3e99a72541 8205824: Update Graal
never
parents: 50609
diff changeset
   372
        if (value instanceof StateSplit) {
2d3e99a72541 8205824: Update Graal
never
parents: 50609
diff changeset
   373
            StateSplit stateSplit = (StateSplit) value;
2d3e99a72541 8205824: Update Graal
never
parents: 50609
diff changeset
   374
            if (stateSplit.stateAfter() == null && (stateSplit.hasSideEffect() || stateSplit instanceof AbstractMergeNode)) {
2d3e99a72541 8205824: Update Graal
never
parents: 50609
diff changeset
   375
                b.setStateAfter(stateSplit);
2d3e99a72541 8205824: Update Graal
never
parents: 50609
diff changeset
   376
            }
2d3e99a72541 8205824: Update Graal
never
parents: 50609
diff changeset
   377
        }
2d3e99a72541 8205824: Update Graal
never
parents: 50609
diff changeset
   378
        return value;
2d3e99a72541 8205824: Update Graal
never
parents: 50609
diff changeset
   379
    }
2d3e99a72541 8205824: Update Graal
never
parents: 50609
diff changeset
   380
}