hotspot/src/jdk.internal.vm.compiler/share/classes/org.graalvm.compiler.replacements/src/org/graalvm/compiler/replacements/nodes/MethodHandleNode.java
author iveresov
Wed, 22 Mar 2017 13:42:45 -0700
changeset 46344 694c102fd8ed
parent 43972 1ade39b8381b
child 46371 0337d0617e7b
permissions -rw-r--r--
8177046: Update Graal Summary: Update Graal, make appropriate changes to AOT, and the build system. 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
/*
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
     2
 * Copyright (c) 2013, 2015, Oracle and/or its affiliates. All rights reserved.
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
 */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    23
package org.graalvm.compiler.replacements.nodes;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    24
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    25
import static org.graalvm.compiler.nodeinfo.NodeCycles.CYCLES_UNKNOWN;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    26
import static org.graalvm.compiler.nodeinfo.NodeSize.SIZE_UNKNOWN;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    27
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    28
import java.lang.invoke.MethodHandle;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    29
import java.util.Arrays;
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.core.common.type.StampFactory;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    32
import org.graalvm.compiler.core.common.type.StampPair;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    33
import org.graalvm.compiler.core.common.type.TypeReference;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    34
import org.graalvm.compiler.debug.GraalError;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    35
import org.graalvm.compiler.graph.NodeClass;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    36
import org.graalvm.compiler.graph.spi.Simplifiable;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    37
import org.graalvm.compiler.graph.spi.SimplifierTool;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    38
import org.graalvm.compiler.nodeinfo.NodeInfo;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    39
import org.graalvm.compiler.nodes.CallTargetNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    40
import org.graalvm.compiler.nodes.CallTargetNode.InvokeKind;
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    41
import org.graalvm.compiler.nodes.FixedGuardNode;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    42
import org.graalvm.compiler.nodes.FixedNode;
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    43
import org.graalvm.compiler.nodes.FixedWithNextNode;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    44
import org.graalvm.compiler.nodes.GuardNode;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    45
import org.graalvm.compiler.nodes.InvokeNode;
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    46
import org.graalvm.compiler.nodes.LogicNode;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    47
import org.graalvm.compiler.nodes.PiNode;
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    48
import org.graalvm.compiler.nodes.StructuredGraph;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    49
import org.graalvm.compiler.nodes.ValueNode;
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    50
import org.graalvm.compiler.nodes.extended.AnchoringNode;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    51
import org.graalvm.compiler.nodes.extended.GuardingNode;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    52
import org.graalvm.compiler.nodes.extended.ValueAnchorNode;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    53
import org.graalvm.compiler.nodes.java.InstanceOfNode;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    54
import org.graalvm.compiler.nodes.java.MethodCallTargetNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    55
import org.graalvm.compiler.nodes.type.StampTool;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    56
import org.graalvm.compiler.nodes.util.GraphUtil;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    57
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    58
import jdk.vm.ci.meta.Assumptions;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    59
import jdk.vm.ci.meta.Assumptions.AssumptionResult;
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    60
import jdk.vm.ci.meta.DeoptimizationAction;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    61
import jdk.vm.ci.meta.DeoptimizationReason;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    62
import jdk.vm.ci.meta.JavaConstant;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    63
import jdk.vm.ci.meta.JavaKind;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    64
import jdk.vm.ci.meta.JavaType;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    65
import jdk.vm.ci.meta.MethodHandleAccessProvider;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    66
import jdk.vm.ci.meta.MethodHandleAccessProvider.IntrinsicMethod;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    67
import jdk.vm.ci.meta.ResolvedJavaMethod;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    68
import jdk.vm.ci.meta.ResolvedJavaType;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    69
import jdk.vm.ci.meta.Signature;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    70
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
 * Node for invocation methods defined on the class {@link MethodHandle}.
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
@NodeInfo(cycles = CYCLES_UNKNOWN, size = SIZE_UNKNOWN)
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    75
public final class MethodHandleNode extends MacroStateSplitNode implements Simplifiable {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    76
    public static final NodeClass<MethodHandleNode> TYPE = NodeClass.create(MethodHandleNode.class);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    77
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    78
    protected final IntrinsicMethod intrinsicMethod;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    79
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    80
    public MethodHandleNode(IntrinsicMethod intrinsicMethod, InvokeKind invokeKind, ResolvedJavaMethod targetMethod, int bci, StampPair returnStamp, ValueNode... arguments) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    81
        super(TYPE, invokeKind, targetMethod, bci, returnStamp, arguments);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    82
        this.intrinsicMethod = intrinsicMethod;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    83
    }
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
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    86
     * Attempts to transform application of an intrinsifiable {@link MethodHandle} method into an
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    87
     * invocation on another method with possibly transformed arguments.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    88
     *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    89
     * @param methodHandleAccess objects for accessing the implementation internals of a
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    90
     *            {@link MethodHandle}
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    91
     * @param intrinsicMethod denotes the intrinsifiable {@link MethodHandle} method being processed
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    92
     * @param bci the BCI of the original {@link MethodHandle} call
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    93
     * @param returnStamp return stamp of the original {@link MethodHandle} call
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    94
     * @param arguments arguments to the original {@link MethodHandle} call
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    95
     * @return a more direct invocation derived from the {@link MethodHandle} call or null
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    96
     */
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    97
    public static InvokeNode tryResolveTargetInvoke(GraphAdder adder, MethodHandleAccessProvider methodHandleAccess, IntrinsicMethod intrinsicMethod,
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
    98
                    ResolvedJavaMethod original, int bci,
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    99
                    StampPair returnStamp, ValueNode... arguments) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   100
        switch (intrinsicMethod) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   101
            case INVOKE_BASIC:
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   102
                return getInvokeBasicTarget(adder, intrinsicMethod, methodHandleAccess, original, bci, returnStamp, arguments);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   103
            case LINK_TO_STATIC:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   104
            case LINK_TO_SPECIAL:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   105
            case LINK_TO_VIRTUAL:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   106
            case LINK_TO_INTERFACE:
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   107
                return getLinkToTarget(adder, intrinsicMethod, methodHandleAccess, original, bci, returnStamp, arguments);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   108
            default:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   109
                throw GraalError.shouldNotReachHere();
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
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   112
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   113
    /**
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   114
     * A simple utility class for adding nodes to the graph when building a MethodHandle invoke.
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   115
     */
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   116
    public abstract static class GraphAdder {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   117
        private final StructuredGraph graph;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   118
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   119
        public GraphAdder(StructuredGraph graph) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   120
            this.graph = graph;
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
        /**
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   124
         * Call {@link StructuredGraph#addOrUnique(org.graalvm.compiler.graph.Node)} on {@code node}
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   125
         * and link any {@link FixedWithNextNode}s into the current control flow.
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   126
         *
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   127
         * @param node
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   128
         * @return the newly added node
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   129
         */
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   130
        public abstract <T extends ValueNode> T add(T node);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   131
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   132
        /**
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   133
         * @return an {@link AnchoringNode} if floating guards should be created, otherwise
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   134
         *         {@link FixedGuardNode}s will be used.
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   135
         */
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   136
        public AnchoringNode getGuardAnchor() {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   137
            return null;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   138
        }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   139
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   140
        public Assumptions getAssumptions() {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   141
            return graph.getAssumptions();
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   142
        }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   143
    }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   144
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   145
    @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   146
    public void simplify(SimplifierTool tool) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   147
        MethodHandleAccessProvider methodHandleAccess = tool.getConstantReflection().getMethodHandleAccess();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   148
        ValueNode[] argumentsArray = arguments.toArray(new ValueNode[arguments.size()]);
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   149
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   150
        final FixedNode before = this;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   151
        GraphAdder adder = new GraphAdder(graph()) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   152
            @Override
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   153
            public <T extends ValueNode> T add(T node) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   154
                T added = graph().addOrUnique(node);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   155
                if (added instanceof FixedWithNextNode) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   156
                    graph().addBeforeFixed(before, (FixedWithNextNode) added);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   157
                }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   158
                return added;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   159
            }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   160
        };
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   161
        InvokeNode invoke = tryResolveTargetInvoke(adder, methodHandleAccess, intrinsicMethod, targetMethod, bci, returnStamp, argumentsArray);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   162
        if (invoke != null) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   163
            assert invoke.graph() == null;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   164
            invoke = graph().addOrUniqueWithInputs(invoke);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   165
            invoke.setStateAfter(stateAfter());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   166
            FixedNode currentNext = next();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   167
            replaceAtUsages(invoke);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   168
            GraphUtil.removeFixedWithUnusedInputs(this);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   169
            graph().addBeforeFixed(currentNext, invoke);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   170
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   171
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   172
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   173
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   174
     * Get the receiver of a MethodHandle.invokeBasic call.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   175
     *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   176
     * @return the receiver argument node
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   177
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   178
    private static ValueNode getReceiver(ValueNode[] arguments) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   179
        return arguments[0];
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   180
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   181
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   182
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   183
     * Get the MemberName argument of a MethodHandle.linkTo* call.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   184
     *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   185
     * @return the MemberName argument node (which is the last argument)
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   186
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   187
    private static ValueNode getMemberName(ValueNode[] arguments) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   188
        return arguments[arguments.length - 1];
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
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   192
     * Used for the MethodHandle.invokeBasic method (the {@link IntrinsicMethod#INVOKE_BASIC }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   193
     * method) to get the target {@link InvokeNode} if the method handle receiver is constant.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   194
     *
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   195
     * @param adder
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   196
     *
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   197
     * @return invoke node for the {@link java.lang.invoke.MethodHandle} target
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   198
     */
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   199
    private static InvokeNode getInvokeBasicTarget(GraphAdder adder, IntrinsicMethod intrinsicMethod, MethodHandleAccessProvider methodHandleAccess,
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   200
                    ResolvedJavaMethod original,
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   201
                    int bci,
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   202
                    StampPair returnStamp, ValueNode[] arguments) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   203
        ValueNode methodHandleNode = getReceiver(arguments);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   204
        if (methodHandleNode.isConstant()) {
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   205
            return getTargetInvokeNode(adder, intrinsicMethod, bci, returnStamp, arguments, methodHandleAccess.resolveInvokeBasicTarget(methodHandleNode.asJavaConstant(), true), original);
43972
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
        return null;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   208
    }
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
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   211
     * Used for the MethodHandle.linkTo* methods (the {@link IntrinsicMethod#LINK_TO_STATIC},
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   212
     * {@link IntrinsicMethod#LINK_TO_SPECIAL}, {@link IntrinsicMethod#LINK_TO_VIRTUAL}, and
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   213
     * {@link IntrinsicMethod#LINK_TO_INTERFACE} methods) to get the target {@link InvokeNode} if
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   214
     * the member name argument is constant.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   215
     *
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   216
     * @param adder
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   217
     *
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   218
     * @return invoke node for the member name target
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   219
     */
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   220
    private static InvokeNode getLinkToTarget(GraphAdder adder, IntrinsicMethod intrinsicMethod, MethodHandleAccessProvider methodHandleAccess,
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   221
                    ResolvedJavaMethod original,
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   222
                    int bci,
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   223
                    StampPair returnStamp, ValueNode[] arguments) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   224
        ValueNode memberNameNode = getMemberName(arguments);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   225
        if (memberNameNode.isConstant()) {
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   226
            return getTargetInvokeNode(adder, intrinsicMethod, bci, returnStamp, arguments, methodHandleAccess.resolveLinkToTarget(memberNameNode.asJavaConstant()), original);
43972
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
        return null;
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
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
     * Helper function to get the {@link InvokeNode} for the targetMethod of a
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   233
     * java.lang.invoke.MemberName.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   234
     *
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   235
     * @param adder
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   236
     * @param target the target, already loaded from the member name node
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   237
     *
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   238
     * @return invoke node for the member name target
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   239
     */
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   240
    private static InvokeNode getTargetInvokeNode(GraphAdder adder, IntrinsicMethod intrinsicMethod, int bci, StampPair returnStamp, ValueNode[] originalArguments, ResolvedJavaMethod target,
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   241
                    ResolvedJavaMethod original) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   242
        if (target == null) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   243
            return null;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   244
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   245
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   246
        // In lambda forms we erase signature types to avoid resolving issues
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   247
        // involving class loaders. When we optimize a method handle invoke
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   248
        // to a direct call we must cast the receiver and arguments to its
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   249
        // actual types.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   250
        Signature signature = target.getSignature();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   251
        final boolean isStatic = target.isStatic();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   252
        final int receiverSkip = isStatic ? 0 : 1;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   253
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   254
        Assumptions assumptions = adder.getAssumptions();
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   255
        ResolvedJavaMethod realTarget = null;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   256
        if (target.canBeStaticallyBound()) {
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   257
            realTarget = target;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   258
        } else {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   259
            ResolvedJavaType targetType = target.getDeclaringClass();
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   260
            // Try to bind based on the declaredType
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   261
            AssumptionResult<ResolvedJavaMethod> concreteMethod = targetType.findUniqueConcreteMethod(target);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   262
            if (concreteMethod == null) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   263
                // Try to get the most accurate receiver type
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   264
                if (intrinsicMethod == IntrinsicMethod.LINK_TO_VIRTUAL || intrinsicMethod == IntrinsicMethod.LINK_TO_INTERFACE) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   265
                    ValueNode receiver = getReceiver(originalArguments);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   266
                    TypeReference receiverType = StampTool.typeReferenceOrNull(receiver.stamp());
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   267
                    if (receiverType != null) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   268
                        concreteMethod = receiverType.getType().findUniqueConcreteMethod(target);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   269
                    }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   270
                }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   271
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
            if (concreteMethod != null && concreteMethod.canRecordTo(assumptions)) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   274
                concreteMethod.recordTo(assumptions);
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   275
                realTarget = concreteMethod.getResult();
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   276
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   277
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   278
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   279
        if (realTarget != null) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   280
            // Don't mutate the passed in arguments
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   281
            ValueNode[] arguments = originalArguments.clone();
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   282
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   283
            // Cast receiver to its type.
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   284
            if (!isStatic) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   285
                JavaType receiverType = target.getDeclaringClass();
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   286
                maybeCastArgument(adder, arguments, 0, receiverType);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   287
            }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   288
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   289
            // Cast reference arguments to its type.
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   290
            for (int index = 0; index < signature.getParameterCount(false); index++) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   291
                JavaType parameterType = signature.getParameterType(index, target.getDeclaringClass());
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   292
                maybeCastArgument(adder, arguments, receiverSkip + index, parameterType);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   293
            }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   294
            InvokeNode invoke = createTargetInvokeNode(assumptions, intrinsicMethod, realTarget, original, bci, returnStamp, arguments);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   295
            assert invoke != null : "graph has been modified so this must result an invoke";
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   296
            return invoke;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   297
        }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   298
        return null;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   299
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   300
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   301
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   302
     * Inserts a node to cast the argument at index to the given type if the given type is more
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   303
     * concrete than the argument type.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   304
     *
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   305
     * @param adder
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   306
     * @param index of the argument to be cast
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   307
     * @param type the type the argument should be cast to
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   308
     */
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   309
    private static void maybeCastArgument(GraphAdder adder, ValueNode[] arguments, int index, JavaType type) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   310
        ValueNode argument = arguments[index];
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   311
        if (type instanceof ResolvedJavaType && !((ResolvedJavaType) type).isJavaLangObject()) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   312
            Assumptions assumptions = adder.getAssumptions();
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   313
            TypeReference targetType = TypeReference.create(assumptions, (ResolvedJavaType) type);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   314
            /*
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   315
             * When an argument is a Word type, we can have a mismatch of primitive/object types
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   316
             * here. Not inserting a PiNode is a safe fallback, and Word types need no additional
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   317
             * type information anyway.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   318
             */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   319
            if (targetType != null && !targetType.getType().isPrimitive() && !argument.getStackKind().isPrimitive()) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   320
                ResolvedJavaType argumentType = StampTool.typeOrNull(argument.stamp());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   321
                if (argumentType == null || (argumentType.isAssignableFrom(targetType.getType()) && !argumentType.equals(targetType.getType()))) {
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   322
                    LogicNode inst = InstanceOfNode.createAllowNull(targetType, argument, null, null);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   323
                    if (!inst.isTautology()) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   324
                        inst = adder.add(inst);
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   325
                        AnchoringNode guardAnchor = adder.getGuardAnchor();
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   326
                        DeoptimizationReason reason = DeoptimizationReason.ClassCastException;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   327
                        DeoptimizationAction action = DeoptimizationAction.InvalidateRecompile;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   328
                        JavaConstant speculation = JavaConstant.NULL_POINTER;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   329
                        GuardingNode guard;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   330
                        if (guardAnchor == null) {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   331
                            FixedGuardNode fixedGuard = adder.add(new FixedGuardNode(inst, reason, action, speculation, false));
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   332
                            guard = fixedGuard;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   333
                        } else {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   334
                            GuardNode newGuard = adder.add(new GuardNode(inst, guardAnchor, reason, action, false, speculation));
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   335
                            adder.add(new ValueAnchorNode(newGuard));
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   336
                            guard = newGuard;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   337
                        }
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   338
                        PiNode piNode = adder.add(new PiNode(argument, StampFactory.object(targetType), guard.asNode()));
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   339
                        arguments[index] = piNode;
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   340
                    } else {
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   341
                        inst.safeDelete();
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
   342
                    }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   343
                }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   344
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   345
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   346
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   347
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   348
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   349
     * Creates an {@link InvokeNode} for the given target method. The {@link CallTargetNode} passed
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   350
     * to the InvokeNode is in fact a {@link ResolvedMethodHandleCallTargetNode}.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   351
     *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   352
     * @return invoke node for the member name target
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   353
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   354
    private static InvokeNode createTargetInvokeNode(Assumptions assumptions, IntrinsicMethod intrinsicMethod, ResolvedJavaMethod target, ResolvedJavaMethod original, int bci, StampPair returnStamp,
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   355
                    ValueNode[] arguments) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   356
        InvokeKind targetInvokeKind = target.isStatic() ? InvokeKind.Static : InvokeKind.Special;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   357
        JavaType targetReturnType = target.getSignature().getReturnType(null);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   358
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   359
        // MethodHandleLinkTo* nodes have a trailing MemberName argument which
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   360
        // needs to be popped.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   361
        ValueNode[] targetArguments;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   362
        switch (intrinsicMethod) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   363
            case INVOKE_BASIC:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   364
                targetArguments = arguments;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   365
                break;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   366
            case LINK_TO_STATIC:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   367
            case LINK_TO_SPECIAL:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   368
            case LINK_TO_VIRTUAL:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   369
            case LINK_TO_INTERFACE:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   370
                targetArguments = Arrays.copyOfRange(arguments, 0, arguments.length - 1);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   371
                break;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   372
            default:
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   373
                throw GraalError.shouldNotReachHere();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   374
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   375
        StampPair targetReturnStamp = StampFactory.forDeclaredType(assumptions, targetReturnType, false);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   376
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   377
        MethodCallTargetNode callTarget = ResolvedMethodHandleCallTargetNode.create(targetInvokeKind, target, targetArguments, targetReturnStamp, original, arguments, returnStamp);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   378
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   379
        // The call target can have a different return type than the invoker,
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   380
        // e.g. the target returns an Object but the invoker void. In this case
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   381
        // we need to use the stamp of the invoker. Note: always using the
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   382
        // invoker's stamp would be wrong because it's a less concrete type
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   383
        // (usually java.lang.Object).
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   384
        if (returnStamp.getTrustedStamp().getStackKind() == JavaKind.Void) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   385
            return new InvokeNode(callTarget, bci, StampFactory.forVoid());
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   386
        } else {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   387
            return new InvokeNode(callTarget, bci);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   388
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   389
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   390
}