src/jdk.internal.vm.compiler/share/classes/org.graalvm.compiler.nodes/src/org/graalvm/compiler/nodes/graphbuilderconf/InvocationPlugins.java
author dlong
Tue, 24 Sep 2019 12:47:15 -0400
changeset 58299 6df94ce3ab2f
parent 54601 c40b2a190173
child 58877 aec7bf35d6f5
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 java.lang.String.format;
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    28
import static jdk.vm.ci.services.Services.IS_BUILDING_NATIVE_IMAGE;
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
    29
import static jdk.vm.ci.services.Services.IS_IN_NATIVE_IMAGE;
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
    30
import static org.graalvm.compiler.nodes.graphbuilderconf.InvocationPlugins.LateClassPlugins.CLOSED_LATE_CLASS_PLUGIN;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    31
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
    32
import java.lang.reflect.Constructor;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    33
import java.lang.reflect.Method;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    34
import java.lang.reflect.Modifier;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    35
import java.lang.reflect.Type;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    36
import java.util.ArrayList;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    37
import java.util.Arrays;
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
    38
import java.util.Collections;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    39
import java.util.List;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    40
import java.util.Map;
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
    41
49873
26ebfe8ce852 8199755: Update Graal
dlong
parents: 48861
diff changeset
    42
import jdk.internal.vm.compiler.collections.EconomicMap;
26ebfe8ce852 8199755: Update Graal
dlong
parents: 48861
diff changeset
    43
import jdk.internal.vm.compiler.collections.Equivalence;
26ebfe8ce852 8199755: Update Graal
dlong
parents: 48861
diff changeset
    44
import jdk.internal.vm.compiler.collections.MapCursor;
26ebfe8ce852 8199755: Update Graal
dlong
parents: 48861
diff changeset
    45
import jdk.internal.vm.compiler.collections.Pair;
26ebfe8ce852 8199755: Update Graal
dlong
parents: 48861
diff changeset
    46
import jdk.internal.vm.compiler.collections.UnmodifiableEconomicMap;
26ebfe8ce852 8199755: Update Graal
dlong
parents: 48861
diff changeset
    47
import jdk.internal.vm.compiler.collections.UnmodifiableMapCursor;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    48
import org.graalvm.compiler.api.replacements.MethodSubstitution;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    49
import org.graalvm.compiler.api.replacements.MethodSubstitutionRegistry;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    50
import org.graalvm.compiler.bytecode.BytecodeProvider;
49873
26ebfe8ce852 8199755: Update Graal
dlong
parents: 48861
diff changeset
    51
import org.graalvm.compiler.core.common.SuppressFBWarnings;
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
    52
import org.graalvm.compiler.debug.Assertions;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    53
import org.graalvm.compiler.debug.GraalError;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    54
import org.graalvm.compiler.graph.Node;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    55
import org.graalvm.compiler.graph.iterators.NodeIterable;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    56
import org.graalvm.compiler.nodes.ValueNode;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    57
import org.graalvm.compiler.nodes.graphbuilderconf.InvocationPlugin.Receiver;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    58
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    59
import jdk.vm.ci.meta.MetaUtil;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    60
import jdk.vm.ci.meta.ResolvedJavaMethod;
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
    61
import jdk.vm.ci.meta.ResolvedJavaType;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
    62
import jdk.vm.ci.meta.Signature;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    63
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    64
/**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    65
 * Manages a set of {@link InvocationPlugin}s.
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
    66
 *
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
    67
 * Most plugins are registered during initialization (i.e., before
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
    68
 * {@link #lookupInvocation(ResolvedJavaMethod)} or {@link #getBindings} is called). These
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
    69
 * registrations can be made with {@link Registration},
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
    70
 * {@link #register(InvocationPlugin, String, String, Type...)},
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
    71
 * {@link #register(InvocationPlugin, Type, String, Type...)} or
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
    72
 * {@link #registerOptional(InvocationPlugin, Type, String, Type...)}. Initialization is not
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
    73
 * thread-safe and so must only be performed by a single thread.
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
    74
 *
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
    75
 * Plugins that are not guaranteed to be made during initialization must use
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
    76
 * {@link LateRegistration}.
43972
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
public class InvocationPlugins {
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 static class InvocationPluginReceiver implements InvocationPlugin.Receiver {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    81
        private final GraphBuilderContext parser;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    82
        private ValueNode[] args;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    83
        private 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
        public InvocationPluginReceiver(GraphBuilderContext parser) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    86
            this.parser = parser;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    87
        }
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
        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    90
        public ValueNode get(boolean performNullCheck) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    91
            assert args != null : "Cannot get the receiver of a static method";
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    92
            if (!performNullCheck) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    93
                return args[0];
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    94
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    95
            if (value == null) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    96
                value = parser.nullCheckedValue(args[0]);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    97
                if (value != args[0]) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    98
                    args[0] = value;
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
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   101
            return value;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   102
        }
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
        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   105
        public boolean isConstant() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   106
            return args[0].isConstant();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   107
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   108
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   109
        public InvocationPluginReceiver init(ResolvedJavaMethod targetMethod, ValueNode[] newArgs) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   110
            if (!targetMethod.isStatic()) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   111
                this.args = newArgs;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   112
                this.value = null;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   113
                return this;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   114
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   115
            return null;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   116
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   117
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   118
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   119
    /**
48861
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
   120
     * A symbol for an already resolved method.
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
   121
     */
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
   122
    public static class ResolvedJavaSymbol implements Type {
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
   123
        private final ResolvedJavaType resolved;
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
   124
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
   125
        public ResolvedJavaSymbol(ResolvedJavaType type) {
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
   126
            this.resolved = type;
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
   127
        }
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
   128
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
   129
        public ResolvedJavaType getResolved() {
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
   130
            return resolved;
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
   131
        }
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
   132
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
   133
        @Override
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
   134
        public String toString() {
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
   135
            return resolved.toJavaName();
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
   136
        }
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
   137
    }
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
   138
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
   139
    /**
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   140
     * A symbol that is lazily {@linkplain OptionalLazySymbol#resolve() resolved} to a {@link Type}.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   141
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   142
    static class OptionalLazySymbol implements Type {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   143
        private static final Class<?> MASK_NULL = OptionalLazySymbol.class;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   144
        private final String name;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   145
        private Class<?> resolved;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   146
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   147
        OptionalLazySymbol(String name) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   148
            this.name = name;
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   149
            if (IS_BUILDING_NATIVE_IMAGE) {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   150
                resolve();
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   151
            }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   152
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   153
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   154
        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   155
        public String getTypeName() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   156
            return name;
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
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   159
        /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   160
         * Gets the resolved {@link Class} corresponding to this symbol or {@code null} if
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   161
         * resolution fails.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   162
         */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   163
        public Class<?> resolve() {
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   164
            if (!IS_IN_NATIVE_IMAGE && resolved == null) {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   165
                Class<?> resolvedOrNull = resolveClass(name, true);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   166
                resolved = resolvedOrNull == null ? MASK_NULL : resolvedOrNull;
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
            return resolved == MASK_NULL ? null : resolved;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   169
        }
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
        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   172
        public String toString() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   173
            return name;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   174
        }
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
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
     * Utility for {@linkplain InvocationPlugins#register(InvocationPlugin, Class, String, Class...)
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   179
     * registration} of invocation plugins.
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
    public static class Registration implements MethodSubstitutionRegistry {
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
        private final InvocationPlugins plugins;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   184
        private final Type declaringType;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   185
        private final BytecodeProvider methodSubstitutionBytecodeProvider;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   186
        private boolean allowOverwrite;
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
        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   189
        public Class<?> getReceiverType() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   190
            return Receiver.class;
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
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   193
        /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   194
         * Creates an object for registering {@link InvocationPlugin}s for methods declared by a
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   195
         * given class.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   196
         *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   197
         * @param plugins where to register the plugins
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   198
         * @param declaringType the class declaring the methods for which plugins will be registered
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   199
         *            via this object
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   200
         */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   201
        public Registration(InvocationPlugins plugins, Type declaringType) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   202
            this.plugins = plugins;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   203
            this.declaringType = declaringType;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   204
            this.methodSubstitutionBytecodeProvider = null;
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
         * Creates an object for registering {@link InvocationPlugin}s for methods declared by a
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   209
         * given class.
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
         * @param plugins where to register the plugins
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   212
         * @param declaringType the class declaring the methods for which plugins will be registered
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   213
         *            via this object
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   214
         * @param methodSubstitutionBytecodeProvider provider used to get the bytecodes to parse for
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   215
         *            method substitutions
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
        public Registration(InvocationPlugins plugins, Type declaringType, BytecodeProvider methodSubstitutionBytecodeProvider) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   218
            this.plugins = plugins;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   219
            this.declaringType = declaringType;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   220
            this.methodSubstitutionBytecodeProvider = methodSubstitutionBytecodeProvider;
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
        /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   224
         * Creates an object for registering {@link InvocationPlugin}s for methods declared by a
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   225
         * given class.
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
         * @param plugins where to register the plugins
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   228
         * @param declaringClassName the name of the class class declaring the methods for which
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   229
         *            plugins will be registered via this object
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   230
         */
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   231
        public Registration(InvocationPlugins plugins, String declaringClassName) {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   232
            this.plugins = plugins;
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   233
            this.declaringType = new OptionalLazySymbol(declaringClassName);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   234
            this.methodSubstitutionBytecodeProvider = null;
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   235
        }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   236
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   237
        /**
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   238
         * Creates an object for registering {@link InvocationPlugin}s for methods declared by a
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   239
         * given class.
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   240
         *
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   241
         * @param plugins where to register the plugins
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   242
         * @param declaringClassName the name of the class class declaring the methods for which
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   243
         *            plugins will be registered via this object
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   244
         * @param methodSubstitutionBytecodeProvider provider used to get the bytecodes to parse for
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   245
         *            method substitutions
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   246
         */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   247
        public Registration(InvocationPlugins plugins, String declaringClassName, BytecodeProvider methodSubstitutionBytecodeProvider) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   248
            this.plugins = plugins;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   249
            this.declaringType = new OptionalLazySymbol(declaringClassName);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   250
            this.methodSubstitutionBytecodeProvider = methodSubstitutionBytecodeProvider;
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
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   253
        /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   254
         * Configures this registration to allow or disallow overwriting of invocation plugins.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   255
         */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   256
        public Registration setAllowOverwrite(boolean allowOverwrite) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   257
            this.allowOverwrite = allowOverwrite;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   258
            return this;
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
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   261
        /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   262
         * Registers a plugin for a method with no arguments.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   263
         *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   264
         * @param name the name of the method
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   265
         * @param plugin the plugin to be registered
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   266
         */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   267
        public void register0(String name, InvocationPlugin plugin) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   268
            plugins.register(plugin, false, allowOverwrite, declaringType, name);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   269
        }
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
        /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   272
         * Registers a plugin for a method with 1 argument.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   273
         *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   274
         * @param name the name of the method
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   275
         * @param plugin the plugin to be registered
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
        public void register1(String name, Type arg, InvocationPlugin plugin) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   278
            plugins.register(plugin, false, allowOverwrite, declaringType, name, arg);
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
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   281
        /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   282
         * Registers a plugin for a method with 2 arguments.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   283
         *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   284
         * @param name the name of the method
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   285
         * @param plugin the plugin to be registered
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   286
         */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   287
        public void register2(String name, Type arg1, Type arg2, InvocationPlugin plugin) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   288
            plugins.register(plugin, false, allowOverwrite, declaringType, name, arg1, arg2);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   289
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   290
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
         * Registers a plugin for a method with 3 arguments.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   293
         *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   294
         * @param name the name of the method
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   295
         * @param plugin the plugin to be registered
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   296
         */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   297
        public void register3(String name, Type arg1, Type arg2, Type arg3, InvocationPlugin plugin) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   298
            plugins.register(plugin, false, allowOverwrite, declaringType, name, arg1, arg2, arg3);
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
         * Registers a plugin for a method with 4 arguments.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   303
         *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   304
         * @param name the name of the method
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   305
         * @param plugin the plugin to be registered
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   306
         */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   307
        public void register4(String name, Type arg1, Type arg2, Type arg3, Type arg4, InvocationPlugin plugin) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   308
            plugins.register(plugin, false, allowOverwrite, declaringType, name, arg1, arg2, arg3, arg4);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   309
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   310
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   311
        /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   312
         * Registers a plugin for a method with 5 arguments.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   313
         *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   314
         * @param name the name of the method
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   315
         * @param plugin the plugin to be registered
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   316
         */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   317
        public void register5(String name, Type arg1, Type arg2, Type arg3, Type arg4, Type arg5, InvocationPlugin plugin) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   318
            plugins.register(plugin, false, allowOverwrite, declaringType, name, arg1, arg2, arg3, arg4, arg5);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   319
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   320
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   321
        /**
44836
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   322
         * Registers a plugin for a method with 6 arguments.
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   323
         *
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   324
         * @param name the name of the method
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   325
         * @param plugin the plugin to be registered
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   326
         */
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   327
        public void register6(String name, Type arg1, Type arg2, Type arg3, Type arg4, Type arg5, Type arg6, InvocationPlugin plugin) {
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   328
            plugins.register(plugin, false, allowOverwrite, declaringType, name, arg1, arg2, arg3, arg4, arg5, arg6);
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   329
        }
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   330
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   331
        /**
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   332
         * Registers a plugin for a method with 7 arguments.
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   333
         *
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   334
         * @param name the name of the method
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   335
         * @param plugin the plugin to be registered
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   336
         */
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   337
        public void register7(String name, Type arg1, Type arg2, Type arg3, Type arg4, Type arg5, Type arg6, Type arg7, InvocationPlugin plugin) {
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   338
            plugins.register(plugin, false, allowOverwrite, declaringType, name, arg1, arg2, arg3, arg4, arg5, arg6, arg7);
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   339
        }
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   340
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   341
        /**
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   342
         * Registers a plugin for an optional method with no arguments.
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
         * @param name the name of the method
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   345
         * @param plugin the plugin to be registered
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
        public void registerOptional0(String name, InvocationPlugin plugin) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   348
            plugins.register(plugin, true, allowOverwrite, declaringType, name);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   349
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   350
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
         * Registers a plugin for an optional method with 1 argument.
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
         * @param name the name of the method
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   355
         * @param plugin the plugin to be registered
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   356
         */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   357
        public void registerOptional1(String name, Type arg, InvocationPlugin plugin) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   358
            plugins.register(plugin, true, allowOverwrite, declaringType, name, arg);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   359
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   360
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   361
        /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   362
         * Registers a plugin for an optional method with 2 arguments.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   363
         *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   364
         * @param name the name of the method
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   365
         * @param plugin the plugin to be registered
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   366
         */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   367
        public void registerOptional2(String name, Type arg1, Type arg2, InvocationPlugin plugin) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   368
            plugins.register(plugin, true, allowOverwrite, declaringType, name, arg1, arg2);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   369
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   370
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   371
        /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   372
         * Registers a plugin for an optional method with 3 arguments.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   373
         *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   374
         * @param name the name of the method
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   375
         * @param plugin the plugin to be registered
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
        public void registerOptional3(String name, Type arg1, Type arg2, Type arg3, InvocationPlugin plugin) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   378
            plugins.register(plugin, true, allowOverwrite, declaringType, name, arg1, arg2, arg3);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   379
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   380
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   381
        /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   382
         * Registers a plugin for an optional method with 4 arguments.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   383
         *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   384
         * @param name the name of the method
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   385
         * @param plugin the plugin to be registered
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   386
         */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   387
        public void registerOptional4(String name, Type arg1, Type arg2, Type arg3, Type arg4, InvocationPlugin plugin) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   388
            plugins.register(plugin, true, allowOverwrite, declaringType, name, arg1, arg2, arg3, arg4);
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
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   391
        /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   392
         * Registers a plugin that implements a method based on the bytecode of a substitute method.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   393
         *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   394
         * @param substituteDeclaringClass the class declaring the substitute method
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   395
         * @param name the name of both the original and substitute method
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   396
         * @param argumentTypes the argument types of the method. Element 0 of this array must be
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   397
         *            the {@link Class} value for {@link InvocationPlugin.Receiver} iff the method
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   398
         *            is non-static. Upon returning, element 0 will have been rewritten to
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   399
         *            {@code declaringClass}
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   400
         */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   401
        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   402
        public void registerMethodSubstitution(Class<?> substituteDeclaringClass, String name, Type... argumentTypes) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   403
            registerMethodSubstitution(substituteDeclaringClass, name, name, argumentTypes);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   404
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   405
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   406
        /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   407
         * Registers a plugin that implements a method based on the bytecode of a substitute method.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   408
         *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   409
         * @param substituteDeclaringClass the class declaring the substitute method
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   410
         * @param name the name of both the original method
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   411
         * @param substituteName the name of the substitute method
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   412
         * @param argumentTypes the argument types of the method. Element 0 of this array must be
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   413
         *            the {@link Class} value for {@link InvocationPlugin.Receiver} iff the method
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   414
         *            is non-static. Upon returning, element 0 will have been rewritten to
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   415
         *            {@code declaringClass}
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   416
         */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   417
        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   418
        public void registerMethodSubstitution(Class<?> substituteDeclaringClass, String name, String substituteName, Type... argumentTypes) {
44836
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   419
            MethodSubstitutionPlugin plugin = createMethodSubstitution(substituteDeclaringClass, substituteName, argumentTypes);
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   420
            plugins.register(plugin, false, allowOverwrite, declaringType, name, argumentTypes);
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   421
        }
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   422
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   423
        public MethodSubstitutionPlugin createMethodSubstitution(Class<?> substituteDeclaringClass, String substituteName, Type... argumentTypes) {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   424
            assert methodSubstitutionBytecodeProvider != null : "Registration used for method substitutions requires a non-null methodSubstitutionBytecodeProvider";
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   425
            MethodSubstitutionPlugin plugin = new MethodSubstitutionPlugin(methodSubstitutionBytecodeProvider, substituteDeclaringClass, substituteName, argumentTypes);
44836
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   426
            return plugin;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   427
        }
44836
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   428
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   429
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   430
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   431
    /**
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   432
     * Utility for registering plugins after Graal may have been initialized. Registrations made via
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   433
     * this class are not finalized until {@link #close} is called.
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   434
     */
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   435
    public static class LateRegistration implements AutoCloseable {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   436
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   437
        private InvocationPlugins plugins;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   438
        private final List<Binding> bindings = new ArrayList<>();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   439
        private final Type declaringType;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   440
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   441
        /**
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   442
         * Creates an object for registering {@link InvocationPlugin}s for methods declared by a
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   443
         * given class.
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   444
         *
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   445
         * @param plugins where to register the plugins
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   446
         * @param declaringType the class declaring the methods for which plugins will be registered
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   447
         *            via this object
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   448
         */
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   449
        public LateRegistration(InvocationPlugins plugins, Type declaringType) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   450
            this.plugins = plugins;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   451
            this.declaringType = declaringType;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   452
        }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   453
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   454
        /**
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   455
         * Registers an invocation plugin for a given method. There must be no plugin currently
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   456
         * registered for {@code method}.
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   457
         *
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   458
         * @param argumentTypes the argument types of the method. Element 0 of this array must be
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   459
         *            the {@link Class} value for {@link InvocationPlugin.Receiver} iff the method
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   460
         *            is non-static. Upon returning, element 0 will have been rewritten to
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   461
         *            {@code declaringClass}
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   462
         */
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   463
        public void register(InvocationPlugin plugin, String name, Type... argumentTypes) {
51436
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   464
            assert plugins != null : String.format("Late registrations of invocation plugins for %s is already closed", declaringType);
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   465
            boolean isStatic = argumentTypes.length == 0 || argumentTypes[0] != InvocationPlugin.Receiver.class;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   466
            if (!isStatic) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   467
                argumentTypes[0] = declaringType;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   468
            }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   469
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   470
            assert isStatic || argumentTypes[0] == declaringType;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   471
            Binding binding = new Binding(plugin, isStatic, name, argumentTypes);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   472
            bindings.add(binding);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   473
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   474
            assert IS_IN_NATIVE_IMAGE || Checks.check(this.plugins, declaringType, binding);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   475
            assert IS_IN_NATIVE_IMAGE || Checks.checkResolvable(false, declaringType, binding);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   476
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   477
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   478
        @Override
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   479
        public void close() {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   480
            assert plugins != null : String.format("Late registrations of invocation plugins for %s is already closed", declaringType);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   481
            plugins.registerLate(declaringType, bindings);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   482
            plugins = null;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   483
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   484
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   485
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   486
    /**
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   487
     * Associates an {@link InvocationPlugin} with the details of a method it substitutes.
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   488
     */
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   489
    public static class Binding {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   490
        /**
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   491
         * The plugin this binding is for.
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   492
         */
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   493
        public final InvocationPlugin plugin;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   494
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   495
        /**
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   496
         * Specifies if the associated method is static.
44836
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   497
         */
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   498
        public final boolean isStatic;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   499
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   500
        /**
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   501
         * The name of the associated method.
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   502
         */
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   503
        public final String name;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   504
44836
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   505
        /**
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   506
         * A partial
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   507
         * <a href="http://docs.oracle.com/javase/specs/jvms/se7/html/jvms-4.html#jvms-4.3.3">method
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   508
         * descriptor</a> for the associated method. The descriptor includes enclosing {@code '('}
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   509
         * and {@code ')'} characters but omits the return type suffix.
44836
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   510
         */
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   511
        public final String argumentsDescriptor;
44836
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   512
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   513
        /**
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   514
         * Link in a list of bindings.
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   515
         */
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   516
        private Binding next;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   517
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   518
        Binding(InvocationPlugin data, boolean isStatic, String name, Type... argumentTypes) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   519
            this.plugin = data;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   520
            this.isStatic = isStatic;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   521
            this.name = name;
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   522
            StringBuilder buf = new StringBuilder();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   523
            buf.append('(');
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   524
            for (int i = isStatic ? 0 : 1; i < argumentTypes.length; i++) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   525
                buf.append(MetaUtil.toInternalName(argumentTypes[i].getTypeName()));
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   526
            }
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   527
            buf.append(')');
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   528
            this.argumentsDescriptor = buf.toString();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   529
            assert !name.equals("<init>") || !isStatic : this;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   530
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   531
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   532
        Binding(ResolvedJavaMethod resolved, InvocationPlugin data) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   533
            this.plugin = data;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   534
            this.isStatic = resolved.isStatic();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   535
            this.name = resolved.getName();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   536
            Signature sig = resolved.getSignature();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   537
            String desc = sig.toMethodDescriptor();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   538
            assert desc.indexOf(')') != -1 : desc;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   539
            this.argumentsDescriptor = desc.substring(0, desc.indexOf(')') + 1);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   540
            assert !name.equals("<init>") || !isStatic : this;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   541
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   542
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   543
        @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   544
        public String toString() {
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   545
            return name + argumentsDescriptor;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   546
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   547
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   548
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   549
    /**
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   550
     * Plugin registrations for already resolved methods. If non-null, then {@link #registrations}
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   551
     * is null and no further registrations can be made.
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   552
     */
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   553
    private final UnmodifiableEconomicMap<ResolvedJavaMethod, InvocationPlugin> resolvedRegistrations;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   554
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   555
    /**
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   556
     * Map from class names in {@linkplain MetaUtil#toInternalName(String) internal} form to the
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   557
     * invocation plugin bindings for the class. Tf non-null, then {@link #resolvedRegistrations}
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   558
     * will be null.
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   559
     */
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   560
    private final EconomicMap<String, ClassPlugins> registrations;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   561
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   562
    /**
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   563
     * Deferred registrations as well as the guard for delimiting the initial registration phase.
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   564
     * The guard uses double-checked locking which is why this field is {@code volatile}.
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   565
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   566
    private volatile List<Runnable> deferredRegistrations = new ArrayList<>();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   567
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   568
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   569
     * Adds a {@link Runnable} for doing registration deferred until the first time
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   570
     * {@link #get(ResolvedJavaMethod)} or {@link #closeRegistration()} is called on this object.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   571
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   572
    public void defer(Runnable deferrable) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   573
        assert deferredRegistrations != null : "registration is closed";
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   574
        deferredRegistrations.add(deferrable);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   575
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   576
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   577
    /**
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   578
     * Support for registering plugins once this object may be accessed by multiple threads.
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   579
     */
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   580
    private volatile LateClassPlugins lateRegistrations;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   581
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   582
    /**
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   583
     * Per-class bindings.
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   584
     */
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   585
    static class ClassPlugins {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   586
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   587
        /**
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   588
         * Maps method names to binding lists.
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   589
         */
51436
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   590
        final EconomicMap<String, Binding> bindings = EconomicMap.create(Equivalence.DEFAULT);
44836
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   591
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   592
        /**
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   593
         * Gets the invocation plugin for a given method.
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   594
         *
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   595
         * @return the invocation plugin for {@code method} or {@code null}
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   596
         */
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   597
        InvocationPlugin get(ResolvedJavaMethod method) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   598
            assert !method.isBridge();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   599
            Binding binding = bindings.get(method.getName());
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   600
            while (binding != null) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   601
                if (method.isStatic() == binding.isStatic) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   602
                    if (method.getSignature().toMethodDescriptor().startsWith(binding.argumentsDescriptor)) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   603
                        return binding.plugin;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   604
                    }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   605
                }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   606
                binding = binding.next;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   607
            }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   608
            return null;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   609
        }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   610
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   611
        public void register(Binding binding, boolean allowOverwrite) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   612
            if (allowOverwrite) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   613
                if (lookup(binding) != null) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   614
                    register(binding);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   615
                    return;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   616
                }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   617
            } else {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   618
                assert lookup(binding) == null : "a value is already registered for " + binding;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   619
            }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   620
            register(binding);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   621
        }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   622
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   623
        InvocationPlugin lookup(Binding binding) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   624
            Binding b = bindings.get(binding.name);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   625
            while (b != null) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   626
                if (b.isStatic == binding.isStatic && b.argumentsDescriptor.equals(binding.argumentsDescriptor)) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   627
                    return b.plugin;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   628
                }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   629
                b = b.next;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   630
            }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   631
            return null;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   632
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   633
44836
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   634
        /**
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   635
         * Registers {@code binding}.
44836
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   636
         */
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   637
        void register(Binding binding) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   638
            Binding head = bindings.get(binding.name);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   639
            assert binding.next == null;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   640
            binding.next = head;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   641
            bindings.put(binding.name, binding);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   642
        }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   643
    }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   644
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   645
    static class LateClassPlugins extends ClassPlugins {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   646
        static final String CLOSED_LATE_CLASS_PLUGIN = "-----";
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   647
        private final String className;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   648
        private final LateClassPlugins next;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   649
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   650
        LateClassPlugins(LateClassPlugins next, String className) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   651
            assert next == null || next.className != CLOSED_LATE_CLASS_PLUGIN : "Late registration of invocation plugins is closed";
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   652
            this.next = next;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   653
            this.className = className;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   654
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   655
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   656
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   657
    /**
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   658
     * Registers a binding of a method to an invocation plugin.
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   659
     *
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   660
     * @param plugin invocation plugin to be associated with the specified method
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   661
     * @param isStatic specifies if the method is static
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   662
     * @param declaringClass the class declaring the method
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   663
     * @param name the name of the method
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   664
     * @param argumentTypes the argument types of the method. Element 0 of this array must be
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   665
     *            {@code declaringClass} iff the method is non-static.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   666
     * @return an object representing the method
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   667
     */
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   668
    Binding put(InvocationPlugin plugin, boolean isStatic, boolean allowOverwrite, Type declaringClass, String name, Type... argumentTypes) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   669
        assert resolvedRegistrations == null : "registration is closed";
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   670
        String internalName = MetaUtil.toInternalName(declaringClass.getTypeName());
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   671
        assert isStatic || argumentTypes[0] == declaringClass;
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   672
        assert deferredRegistrations != null : "initial registration is closed - use " + LateRegistration.class.getName() + " for late registrations";
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   673
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   674
        ClassPlugins classPlugins = registrations.get(internalName);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   675
        if (classPlugins == null) {
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   676
            classPlugins = new ClassPlugins();
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   677
            registrations.put(internalName, classPlugins);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   678
        }
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   679
        Binding binding = new Binding(plugin, isStatic, name, argumentTypes);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   680
        classPlugins.register(binding, allowOverwrite);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   681
        return binding;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   682
    }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   683
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   684
    InvocationPlugin get(ResolvedJavaMethod method) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   685
        if (resolvedRegistrations != null) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   686
            return resolvedRegistrations.get(method);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   687
        } else {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   688
            if (!method.isBridge()) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   689
                ResolvedJavaType declaringClass = method.getDeclaringClass();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   690
                flushDeferrables();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   691
                String internalName = declaringClass.getName();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   692
                ClassPlugins classPlugins = registrations.get(internalName);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   693
                InvocationPlugin res = null;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   694
                if (classPlugins != null) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   695
                    res = classPlugins.get(method);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   696
                }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   697
                if (res == null) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   698
                    LateClassPlugins lcp = findLateClassPlugins(internalName);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   699
                    if (lcp != null) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   700
                        res = lcp.get(method);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   701
                    }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   702
                }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   703
                if (res != null) {
50330
2cbc42a5764b 8202670: Update Graal
dlong
parents: 49873
diff changeset
   704
                    // A decorator plugin is trusted since it does not replace
58299
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 54601
diff changeset
   705
                    // the method it intrinsifies. A GeneratedInvocationPlugin
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 54601
diff changeset
   706
                    // is trusted since it only exists for @NodeIntrinsics and
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 54601
diff changeset
   707
                    // @Fold annotated methods (i.e., trusted Graal code).
6df94ce3ab2f 8229201: Update Graal
dlong
parents: 54601
diff changeset
   708
                    if (res.isDecorator() || res instanceof GeneratedInvocationPlugin || canBeIntrinsified(declaringClass)) {
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   709
                        return res;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   710
                    }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   711
                }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   712
                if (testExtensions != null) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   713
                    // Avoid the synchronization in the common case that there
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   714
                    // are no test extensions.
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   715
                    synchronized (this) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   716
                        if (testExtensions != null) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   717
                            List<Binding> bindings = testExtensions.get(internalName);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   718
                            if (bindings != null) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   719
                                String name = method.getName();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   720
                                String descriptor = method.getSignature().toMethodDescriptor();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   721
                                for (Binding b : bindings) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   722
                                    if (b.isStatic == method.isStatic() &&
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   723
                                                    b.name.equals(name) &&
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   724
                                                    descriptor.startsWith(b.argumentsDescriptor)) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   725
                                        return b.plugin;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   726
                                    }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   727
                                }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   728
                            }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   729
                        }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   730
                    }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   731
                }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   732
            } else {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   733
                // Supporting plugins for bridge methods would require including
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   734
                // the return type in the registered signature. Until needed,
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   735
                // this extra complexity is best avoided.
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   736
            }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   737
        }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   738
        return null;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   739
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   740
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   741
    /**
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   742
     * Determines if methods in a given class can have invocation plugins.
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   743
     *
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   744
     * @param declaringClass the class to test
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   745
     */
48861
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
   746
    public boolean canBeIntrinsified(ResolvedJavaType declaringClass) {
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   747
        return true;
44836
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   748
    }
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   749
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   750
    LateClassPlugins findLateClassPlugins(String internalClassName) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   751
        for (LateClassPlugins lcp = lateRegistrations; lcp != null; lcp = lcp.next) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   752
            if (lcp.className.equals(internalClassName)) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   753
                return lcp;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   754
            }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   755
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   756
        return null;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   757
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   758
46509
b32d3928ad6a 8181369: Update Graal
iveresov
parents: 46459
diff changeset
   759
    @SuppressWarnings("serial")
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   760
    static class InvocationPluginRegistrationError extends GraalError {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   761
        InvocationPluginRegistrationError(Throwable cause) {
46509
b32d3928ad6a 8181369: Update Graal
iveresov
parents: 46459
diff changeset
   762
            super(cause);
b32d3928ad6a 8181369: Update Graal
iveresov
parents: 46459
diff changeset
   763
        }
b32d3928ad6a 8181369: Update Graal
iveresov
parents: 46459
diff changeset
   764
    }
b32d3928ad6a 8181369: Update Graal
iveresov
parents: 46459
diff changeset
   765
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   766
    private void flushDeferrables() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   767
        if (deferredRegistrations != null) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   768
            synchronized (this) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   769
                if (deferredRegistrations != null) {
46509
b32d3928ad6a 8181369: Update Graal
iveresov
parents: 46459
diff changeset
   770
                    try {
b32d3928ad6a 8181369: Update Graal
iveresov
parents: 46459
diff changeset
   771
                        for (Runnable deferrable : deferredRegistrations) {
b32d3928ad6a 8181369: Update Graal
iveresov
parents: 46459
diff changeset
   772
                            deferrable.run();
b32d3928ad6a 8181369: Update Graal
iveresov
parents: 46459
diff changeset
   773
                        }
b32d3928ad6a 8181369: Update Graal
iveresov
parents: 46459
diff changeset
   774
                        deferredRegistrations = null;
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   775
                    } catch (InvocationPluginRegistrationError t) {
46509
b32d3928ad6a 8181369: Update Graal
iveresov
parents: 46459
diff changeset
   776
                        throw t;
b32d3928ad6a 8181369: Update Graal
iveresov
parents: 46459
diff changeset
   777
                    } catch (Throwable t) {
b32d3928ad6a 8181369: Update Graal
iveresov
parents: 46459
diff changeset
   778
                        /*
b32d3928ad6a 8181369: Update Graal
iveresov
parents: 46459
diff changeset
   779
                         * Something went wrong during registration but it's possible we'll end up
b32d3928ad6a 8181369: Update Graal
iveresov
parents: 46459
diff changeset
   780
                         * coming back into this code. nulling out deferredRegistrations would just
b32d3928ad6a 8181369: Update Graal
iveresov
parents: 46459
diff changeset
   781
                         * cause other things to break and rerunning them would cause errors about
b32d3928ad6a 8181369: Update Graal
iveresov
parents: 46459
diff changeset
   782
                         * already registered plugins, so rethrow the original exception during
b32d3928ad6a 8181369: Update Graal
iveresov
parents: 46459
diff changeset
   783
                         * later invocations.
b32d3928ad6a 8181369: Update Graal
iveresov
parents: 46459
diff changeset
   784
                         */
b32d3928ad6a 8181369: Update Graal
iveresov
parents: 46459
diff changeset
   785
                        deferredRegistrations.clear();
b32d3928ad6a 8181369: Update Graal
iveresov
parents: 46459
diff changeset
   786
                        Runnable rethrow = new Runnable() {
b32d3928ad6a 8181369: Update Graal
iveresov
parents: 46459
diff changeset
   787
                            @Override
b32d3928ad6a 8181369: Update Graal
iveresov
parents: 46459
diff changeset
   788
                            public void run() {
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   789
                                throw new InvocationPluginRegistrationError(t);
46509
b32d3928ad6a 8181369: Update Graal
iveresov
parents: 46459
diff changeset
   790
                            }
b32d3928ad6a 8181369: Update Graal
iveresov
parents: 46459
diff changeset
   791
                        };
b32d3928ad6a 8181369: Update Graal
iveresov
parents: 46459
diff changeset
   792
                        deferredRegistrations.add(rethrow);
b32d3928ad6a 8181369: Update Graal
iveresov
parents: 46459
diff changeset
   793
                        rethrow.run();
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   794
                    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   795
                }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   796
            }
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   797
        }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   798
    }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   799
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   800
    private volatile EconomicMap<String, List<Binding>> testExtensions;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   801
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   802
    private static int findBinding(List<Binding> list, Binding key) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   803
        for (int i = 0; i < list.size(); i++) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   804
            Binding b = list.get(i);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   805
            if (b.isStatic == key.isStatic && b.name.equals(key.name) && b.argumentsDescriptor.equals(key.argumentsDescriptor)) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   806
                return i;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   807
            }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   808
        }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   809
        return -1;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   810
    }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   811
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   812
    /**
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   813
     * Extends the plugins in this object with those from {@code other}. The added plugins should be
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   814
     * {@linkplain #removeTestPlugins(InvocationPlugins) removed} after the test.
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   815
     *
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   816
     * This extension mechanism exists only for tests that want to add extra invocation plugins
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   817
     * after the compiler has been initialized.
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   818
     *
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   819
     * @param ignored if non-null, the bindings from {@code other} already in this object prior to
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   820
     *            calling this method are added to this list. These bindings are not added to this
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   821
     *            object.
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   822
     */
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   823
    public synchronized void addTestPlugins(InvocationPlugins other, List<Pair<String, Binding>> ignored) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   824
        assert resolvedRegistrations == null : "registration is closed";
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   825
        EconomicMap<String, List<Binding>> otherBindings = other.getBindings(true, false);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   826
        if (otherBindings.isEmpty()) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   827
            return;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   828
        }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   829
        if (testExtensions == null) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   830
            testExtensions = EconomicMap.create();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   831
        }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   832
        MapCursor<String, List<Binding>> c = otherBindings.getEntries();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   833
        while (c.advance()) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   834
            String declaringClass = c.getKey();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   835
            List<Binding> bindings = testExtensions.get(declaringClass);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   836
            if (bindings == null) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   837
                bindings = new ArrayList<>();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   838
                testExtensions.put(declaringClass, bindings);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   839
            }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   840
            for (Binding b : c.getValue()) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   841
                int index = findBinding(bindings, b);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   842
                if (index != -1) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   843
                    if (ignored != null) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   844
                        ignored.add(Pair.create(declaringClass, b));
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   845
                    }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   846
                } else {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   847
                    bindings.add(b);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   848
                }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   849
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   850
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   851
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   852
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   853
    /**
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   854
     * Removes the plugins from {@code other} in this object that were added by
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   855
     * {@link #addTestPlugins}.
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   856
     */
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   857
    public synchronized void removeTestPlugins(InvocationPlugins other) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   858
        assert resolvedRegistrations == null : "registration is closed";
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   859
        if (testExtensions != null) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   860
            MapCursor<String, List<Binding>> c = other.getBindings(false).getEntries();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   861
            while (c.advance()) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   862
                String declaringClass = c.getKey();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   863
                List<Binding> bindings = testExtensions.get(declaringClass);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   864
                if (bindings != null) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   865
                    for (Binding b : c.getValue()) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   866
                        int index = findBinding(bindings, b);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   867
                        if (index != -1) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   868
                            bindings.remove(index);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   869
                        }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   870
                    }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   871
                    if (bindings.isEmpty()) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   872
                        testExtensions.removeKey(declaringClass);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   873
                    }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   874
                }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   875
            }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   876
            if (testExtensions.isEmpty()) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   877
                testExtensions = null;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   878
            }
44836
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   879
        }
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   880
    }
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
   881
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   882
    synchronized void registerLate(Type declaringType, List<Binding> bindings) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   883
        String internalName = MetaUtil.toInternalName(declaringType.getTypeName());
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   884
        assert findLateClassPlugins(internalName) == null : "Cannot have more than one late registration of invocation plugins for " + internalName;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   885
        LateClassPlugins lateClassPlugins = new LateClassPlugins(lateRegistrations, internalName);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   886
        for (Binding b : bindings) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   887
            lateClassPlugins.register(b);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   888
        }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   889
        lateRegistrations = lateClassPlugins;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   890
    }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   891
49873
26ebfe8ce852 8199755: Update Graal
dlong
parents: 48861
diff changeset
   892
    @SuppressFBWarnings(value = "ES_COMPARING_STRINGS_WITH_EQ", justification = "string literal object identity used as sentinel")
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   893
    private synchronized boolean closeLateRegistrations() {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   894
        if (lateRegistrations == null || lateRegistrations.className != CLOSED_LATE_CLASS_PLUGIN) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   895
            lateRegistrations = new LateClassPlugins(lateRegistrations, CLOSED_LATE_CLASS_PLUGIN);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   896
        }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   897
        return true;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   898
    }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   899
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   900
    /**
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   901
     * Processes deferred registrations and then closes this object for future registration.
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   902
     */
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   903
    public void closeRegistration() {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   904
        assert closeLateRegistrations();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   905
        flushDeferrables();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   906
    }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   907
51436
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   908
    /**
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   909
     * Determines if this object currently contains any plugins (in any state of registration). If
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   910
     * this object has any {@link #defer(Runnable) deferred registrations}, it is assumed that
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   911
     * executing them will result in at least one plugin being registered.
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   912
     */
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   913
    public boolean isEmpty() {
51436
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   914
        if (parent != null && !parent.isEmpty()) {
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   915
            return false;
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   916
        }
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   917
        UnmodifiableEconomicMap<ResolvedJavaMethod, InvocationPlugin> resolvedRegs = resolvedRegistrations;
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   918
        if (resolvedRegs != null) {
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   919
            if (!resolvedRegs.isEmpty()) {
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   920
                return false;
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   921
            }
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   922
        }
51436
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   923
        List<Runnable> deferred = deferredRegistrations;
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   924
        if (deferred != null) {
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   925
            if (!deferred.isEmpty()) {
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   926
                return false;
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   927
            }
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   928
        }
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   929
        for (LateClassPlugins late = lateRegistrations; late != null; late = late.next) {
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   930
            if (!late.bindings.isEmpty()) {
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   931
                return false;
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   932
            }
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   933
        }
091c0d22e735 8206992: Update Graal
iveresov
parents: 50858
diff changeset
   934
        return registrations.size() == 0;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   935
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   936
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   937
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   938
     * The plugins {@linkplain #lookupInvocation(ResolvedJavaMethod) searched} before searching in
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   939
     * this object.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   940
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   941
    protected final InvocationPlugins parent;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   942
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   943
    /**
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   944
     * Creates a set of invocation plugins with no parent.
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   945
     */
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   946
    public InvocationPlugins() {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   947
        this(null);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   948
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   949
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   950
    /**
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   951
     * Creates a set of invocation plugins.
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   952
     *
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   953
     * @param parent if non-null, this object will be searched first when looking up plugins
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   954
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   955
    public InvocationPlugins(InvocationPlugins parent) {
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   956
        InvocationPlugins p = parent;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   957
        this.parent = p;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   958
        this.registrations = EconomicMap.create();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   959
        this.resolvedRegistrations = null;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   960
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   961
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   962
    /**
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   963
     * Creates a closed set of invocation plugins for a set of resolved methods. Such an object
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   964
     * cannot have further plugins registered.
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   965
     */
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   966
    public InvocationPlugins(Map<ResolvedJavaMethod, InvocationPlugin> plugins, InvocationPlugins parent) {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   967
        this.parent = parent;
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   968
        this.registrations = null;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   969
        this.deferredRegistrations = null;
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   970
        EconomicMap<ResolvedJavaMethod, InvocationPlugin> map = EconomicMap.create(plugins.size());
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   971
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   972
        for (Map.Entry<ResolvedJavaMethod, InvocationPlugin> entry : plugins.entrySet()) {
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   973
            map.put(entry.getKey(), entry.getValue());
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   974
        }
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   975
        this.resolvedRegistrations = map;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   976
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   977
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   978
    protected void register(InvocationPlugin plugin, boolean isOptional, boolean allowOverwrite, Type declaringClass, String name, Type... argumentTypes) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   979
        boolean isStatic = argumentTypes.length == 0 || argumentTypes[0] != InvocationPlugin.Receiver.class;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   980
        if (!isStatic) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   981
            argumentTypes[0] = declaringClass;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   982
        }
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   983
        Binding binding = put(plugin, isStatic, allowOverwrite, declaringClass, name, argumentTypes);
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   984
        assert IS_IN_NATIVE_IMAGE || Checks.check(this, declaringClass, binding);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
   985
        assert IS_IN_NATIVE_IMAGE || Checks.checkResolvable(isOptional, declaringClass, binding);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   986
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   987
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   988
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   989
     * Registers an invocation plugin for a given method. There must be no plugin currently
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   990
     * registered for {@code method}.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   991
     *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   992
     * @param argumentTypes the argument types of the method. Element 0 of this array must be the
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   993
     *            {@link Class} value for {@link InvocationPlugin.Receiver} iff the method is
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   994
     *            non-static. Upon returning, element 0 will have been rewritten to
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   995
     *            {@code declaringClass}
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   996
     */
50609
bf414874c28f 8204231: Update Graal
dlong
parents: 50330
diff changeset
   997
    public final void register(InvocationPlugin plugin, Type declaringClass, String name, Type... argumentTypes) {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   998
        register(plugin, false, false, declaringClass, name, argumentTypes);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   999
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1000
50609
bf414874c28f 8204231: Update Graal
dlong
parents: 50330
diff changeset
  1001
    public final void register(InvocationPlugin plugin, String declaringClass, String name, Type... argumentTypes) {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1002
        register(plugin, false, false, new OptionalLazySymbol(declaringClass), name, argumentTypes);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1003
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1004
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1005
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1006
     * Registers an invocation plugin for a given, optional method. There must be no plugin
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1007
     * currently registered for {@code method}.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1008
     *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1009
     * @param argumentTypes the argument types of the method. Element 0 of this array must be the
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1010
     *            {@link Class} value for {@link InvocationPlugin.Receiver} iff the method is
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1011
     *            non-static. Upon returning, element 0 will have been rewritten to
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1012
     *            {@code declaringClass}
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1013
     */
50609
bf414874c28f 8204231: Update Graal
dlong
parents: 50330
diff changeset
  1014
    public final void registerOptional(InvocationPlugin plugin, Type declaringClass, String name, Type... argumentTypes) {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1015
        register(plugin, true, false, declaringClass, name, argumentTypes);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1016
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1017
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1018
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1019
     * Gets the plugin for a given method.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1020
     *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1021
     * @param method the method to lookup
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1022
     * @return the plugin associated with {@code method} or {@code null} if none exists
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1023
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1024
    public InvocationPlugin lookupInvocation(ResolvedJavaMethod method) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1025
        if (parent != null) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1026
            InvocationPlugin plugin = parent.lookupInvocation(method);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1027
            if (plugin != null) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1028
                return plugin;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1029
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1030
        }
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
  1031
        InvocationPlugin invocationPlugin = get(method);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
  1032
        return invocationPlugin;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1033
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1034
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1035
    /**
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1036
     * Gets the set of registered invocation plugins.
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1037
     *
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1038
     * @return a map from class names in {@linkplain MetaUtil#toInternalName(String) internal} form
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1039
     *         to the invocation plugin bindings for methods in the class
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1040
     */
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1041
    public EconomicMap<String, List<Binding>> getBindings(boolean includeParents) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1042
        return getBindings(includeParents, true);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1043
    }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1044
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1045
    /**
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1046
     * Gets the set of registered invocation plugins.
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1047
     *
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1048
     * @return a map from class names in {@linkplain MetaUtil#toInternalName(String) internal} form
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1049
     *         to the invocation plugin bindings for methods in the class
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1050
     */
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1051
    private EconomicMap<String, List<Binding>> getBindings(boolean includeParents, boolean flushDeferrables) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1052
        EconomicMap<String, List<Binding>> res = EconomicMap.create(Equivalence.DEFAULT);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1053
        if (parent != null && includeParents) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1054
            res.putAll(parent.getBindings(true, flushDeferrables));
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1055
        }
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1056
        if (resolvedRegistrations != null) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1057
            UnmodifiableMapCursor<ResolvedJavaMethod, InvocationPlugin> cursor = resolvedRegistrations.getEntries();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1058
            while (cursor.advance()) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1059
                ResolvedJavaMethod method = cursor.getKey();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1060
                InvocationPlugin plugin = cursor.getValue();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1061
                String type = method.getDeclaringClass().getName();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1062
                List<Binding> bindings = res.get(type);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1063
                if (bindings == null) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1064
                    bindings = new ArrayList<>();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1065
                    res.put(type, bindings);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1066
                }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1067
                bindings.add(new Binding(method, plugin));
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1068
            }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1069
        } else {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1070
            if (flushDeferrables) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1071
                flushDeferrables();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1072
            }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1073
            MapCursor<String, ClassPlugins> classes = registrations.getEntries();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1074
            while (classes.advance()) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1075
                String type = classes.getKey();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1076
                ClassPlugins cp = classes.getValue();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1077
                collectBindingsTo(res, type, cp);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1078
            }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1079
            for (LateClassPlugins lcp = lateRegistrations; lcp != null; lcp = lcp.next) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1080
                String type = lcp.className;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1081
                collectBindingsTo(res, type, lcp);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1082
            }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1083
            if (testExtensions != null) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1084
                // Avoid the synchronization in the common case that there
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1085
                // are no test extensions.
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1086
                synchronized (this) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1087
                    if (testExtensions != null) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1088
                        MapCursor<String, List<Binding>> c = testExtensions.getEntries();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1089
                        while (c.advance()) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1090
                            String name = c.getKey();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1091
                            List<Binding> bindings = res.get(name);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1092
                            if (bindings == null) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1093
                                bindings = new ArrayList<>();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1094
                                res.put(name, bindings);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1095
                            }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1096
                            bindings.addAll(c.getValue());
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1097
                        }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1098
                    }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1099
                }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1100
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1101
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1102
        return res;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1103
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1104
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1105
    private static void collectBindingsTo(EconomicMap<String, List<Binding>> res, String type, ClassPlugins cp) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1106
        MapCursor<String, Binding> methods = cp.bindings.getEntries();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1107
        while (methods.advance()) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1108
            List<Binding> bindings = res.get(type);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1109
            if (bindings == null) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1110
                bindings = new ArrayList<>();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1111
                res.put(type, bindings);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1112
            }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1113
            for (Binding b = methods.getValue(); b != null; b = b.next) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1114
                bindings.add(b);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1115
            }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1116
        }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1117
    }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1118
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1119
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1120
     * Gets the invocation plugins {@linkplain #lookupInvocation(ResolvedJavaMethod) searched}
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1121
     * before searching in this object.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1122
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1123
    public InvocationPlugins getParent() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1124
        return parent;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1125
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1126
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1127
    @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1128
    public String toString() {
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1129
        UnmodifiableMapCursor<String, List<Binding>> entries = getBindings(false, false).getEntries();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1130
        List<String> all = new ArrayList<>();
46344
694c102fd8ed 8177046: Update Graal
iveresov
parents: 43972
diff changeset
  1131
        while (entries.advance()) {
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1132
            String c = MetaUtil.internalNameToJava(entries.getKey(), true, false);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1133
            for (Binding b : entries.getValue()) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1134
                all.add(c + '.' + b);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1135
            }
44836
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
  1136
        }
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1137
        Collections.sort(all);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1138
        StringBuilder buf = new StringBuilder();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1139
        String nl = String.format("%n");
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1140
        for (String s : all) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1141
            if (buf.length() != 0) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1142
                buf.append(nl);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1143
            }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1144
            buf.append(s);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1145
        }
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1146
        if (parent != null) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1147
            if (buf.length() != 0) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1148
                buf.append(nl);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1149
            }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1150
            buf.append("// parent").append(nl).append(parent);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1151
        }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1152
        return buf.toString();
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1153
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1154
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1155
    /**
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1156
     * Code only used in assertions. Putting this in a separate class reduces class load time.
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1157
     */
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1158
    private static class Checks {
44836
45196b7066e3 8177845: Need a mechanism to load Graal
dnsimon
parents: 43972
diff changeset
  1159
        private static final int MAX_ARITY = 7;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1160
        /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1161
         * The set of all {@link InvocationPlugin#apply} method signatures.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1162
         */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1163
        static final Class<?>[][] SIGS;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1164
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1165
        static {
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
  1166
            if (!Assertions.assertionsEnabled() && !IS_BUILDING_NATIVE_IMAGE) {
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1167
                throw new GraalError("%s must only be used in assertions", Checks.class.getName());
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1168
            }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1169
            ArrayList<Class<?>[]> sigs = new ArrayList<>(MAX_ARITY);
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
  1170
            if (!IS_IN_NATIVE_IMAGE) {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
  1171
                for (Method method : InvocationPlugin.class.getDeclaredMethods()) {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
  1172
                    if (!Modifier.isStatic(method.getModifiers()) && method.getName().equals("apply")) {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
  1173
                        Class<?>[] sig = method.getParameterTypes();
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
  1174
                        assert sig[0] == GraphBuilderContext.class;
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
  1175
                        assert sig[1] == ResolvedJavaMethod.class;
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
  1176
                        assert sig[2] == InvocationPlugin.Receiver.class;
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
  1177
                        assert Arrays.asList(sig).subList(3, sig.length).stream().allMatch(c -> c == ValueNode.class);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
  1178
                        while (sigs.size() < sig.length - 2) {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
  1179
                            sigs.add(null);
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
  1180
                        }
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
  1181
                        sigs.set(sig.length - 3, sig);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1182
                    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1183
                }
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
  1184
                assert sigs.indexOf(null) == -1 : format("need to add an apply() method to %s that takes %d %s arguments ", InvocationPlugin.class.getName(), sigs.indexOf(null),
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
  1185
                                ValueNode.class.getSimpleName());
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1186
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1187
            SIGS = sigs.toArray(new Class<?>[sigs.size()][]);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1188
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1189
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1190
        static boolean containsBinding(InvocationPlugins p, Type declaringType, Binding key) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1191
            String internalName = MetaUtil.toInternalName(declaringType.getTypeName());
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1192
            ClassPlugins classPlugins = p.registrations.get(internalName);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1193
            return classPlugins != null && classPlugins.lookup(key) != null;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1194
        }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1195
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1196
        public static boolean check(InvocationPlugins plugins, Type declaringType, Binding binding) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1197
            InvocationPlugin plugin = binding.plugin;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1198
            InvocationPlugins p = plugins.parent;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1199
            while (p != null) {
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1200
                assert !containsBinding(p, declaringType, binding) : "a plugin is already registered for " + binding;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1201
                p = p.parent;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1202
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1203
            if (plugin instanceof ForeignCallPlugin || plugin instanceof GeneratedInvocationPlugin) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1204
                return true;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1205
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1206
            if (plugin instanceof MethodSubstitutionPlugin) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1207
                MethodSubstitutionPlugin msplugin = (MethodSubstitutionPlugin) plugin;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1208
                Method substitute = msplugin.getJavaSubstitute();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1209
                assert substitute.getAnnotation(MethodSubstitution.class) != null : format("Substitute method must be annotated with @%s: %s", MethodSubstitution.class.getSimpleName(), substitute);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1210
                return true;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1211
            }
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1212
            int arguments = parseParameters(binding.argumentsDescriptor).size();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1213
            assert arguments < SIGS.length : format("need to extend %s to support method with %d arguments: %s", InvocationPlugin.class.getSimpleName(), arguments, binding);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1214
            for (Method m : plugin.getClass().getDeclaredMethods()) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1215
                if (m.getName().equals("apply")) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1216
                    Class<?>[] parameterTypes = m.getParameterTypes();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1217
                    if (Arrays.equals(SIGS[arguments], parameterTypes)) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1218
                        return true;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1219
                    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1220
                }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1221
            }
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1222
            throw new AssertionError(format("graph builder plugin for %s not found", binding));
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1223
        }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1224
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1225
        static boolean checkResolvable(boolean isOptional, Type declaringType, Binding binding) {
48861
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1226
            if (declaringType instanceof ResolvedJavaSymbol) {
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1227
                return checkResolvable(isOptional, ((ResolvedJavaSymbol) declaringType).getResolved(), binding);
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1228
            }
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1229
            Class<?> declaringClass = InvocationPlugins.resolveType(declaringType, isOptional);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1230
            if (declaringClass == null) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1231
                return true;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1232
            }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1233
            if (binding.name.equals("<init>")) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1234
                if (resolveConstructor(declaringClass, binding) == null && !isOptional) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1235
                    throw new AssertionError(String.format("Constructor not found: %s%s", declaringClass.getName(), binding.argumentsDescriptor));
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1236
                }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1237
            } else {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1238
                if (resolveMethod(declaringClass, binding) == null && !isOptional) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1239
                    throw new AssertionError(String.format("Method not found: %s.%s%s", declaringClass.getName(), binding.name, binding.argumentsDescriptor));
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1240
                }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1241
            }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1242
            return true;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1243
        }
48861
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1244
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1245
        private static boolean checkResolvable(boolean isOptional, ResolvedJavaType declaringType, Binding binding) {
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1246
            if (resolveJavaMethod(declaringType, binding) == null && !isOptional) {
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1247
                throw new AssertionError(String.format("Method not found: %s.%s%s", declaringType.toJavaName(), binding.name, binding.argumentsDescriptor));
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1248
            }
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1249
            return true;
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1250
        }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1251
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1252
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1253
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1254
     * Checks a set of nodes added to the graph by an {@link InvocationPlugin}.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1255
     *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1256
     * @param b the graph builder that applied the plugin
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1257
     * @param plugin a plugin that was just applied
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1258
     * @param newNodes the nodes added to the graph by {@code plugin}
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1259
     * @throws AssertionError if any check fail
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1260
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1261
    public void checkNewNodes(GraphBuilderContext b, InvocationPlugin plugin, NodeIterable<Node> newNodes) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1262
        if (parent != null) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1263
            parent.checkNewNodes(b, plugin, newNodes);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1264
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1265
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1266
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1267
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1268
     * Resolves a name to a class.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1269
     *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1270
     * @param className the name of the class to resolve
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1271
     * @param optional if true, resolution failure returns null
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1272
     * @return the resolved class or null if resolution fails and {@code optional} is true
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1273
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1274
    public static Class<?> resolveClass(String className, boolean optional) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1275
        try {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1276
            // Need to use the system class loader to handle classes
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1277
            // loaded by the application class loader which is not
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1278
            // delegated to by the JVMCI class loader.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1279
            ClassLoader cl = ClassLoader.getSystemClassLoader();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1280
            return Class.forName(className, false, cl);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1281
        } catch (ClassNotFoundException e) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1282
            if (optional) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1283
                return null;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1284
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1285
            throw new GraalError("Could not resolve type " + className);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1286
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1287
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1288
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1289
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1290
     * Resolves a {@link Type} to a {@link Class}.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1291
     *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1292
     * @param type the type to resolve
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1293
     * @param optional if true, resolution failure returns null
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1294
     * @return the resolved class or null if resolution fails and {@code optional} is true
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1295
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1296
    public static Class<?> resolveType(Type type, boolean optional) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1297
        if (type instanceof Class) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1298
            return (Class<?>) type;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1299
        }
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1300
        if (type instanceof OptionalLazySymbol) {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1301
            return ((OptionalLazySymbol) type).resolve();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1302
        }
54084
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
  1303
        if (IS_IN_NATIVE_IMAGE) {
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
  1304
            throw new GraalError("Unresolved type in native image image:" + type.getTypeName());
84f10bbf993f 8218074: Update Graal
jwilhelm
parents: 52910
diff changeset
  1305
        }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1306
        return resolveClass(type.getTypeName(), optional);
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1307
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1308
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1309
    private static List<String> toInternalTypeNames(Class<?>[] types) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1310
        String[] res = new String[types.length];
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1311
        for (int i = 0; i < types.length; i++) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1312
            res[i] = MetaUtil.toInternalName(types[i].getTypeName());
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1313
        }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1314
        return Arrays.asList(res);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1315
    }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1316
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1317
    /**
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1318
     * Resolves a given binding to a method in a given class. If more than one method with the
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1319
     * parameter types matching {@code binding} is found and the return types of all the matching
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1320
     * methods form an inheritance chain, the one with the most specific type is returned; otherwise
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1321
     * {@link NoSuchMethodError} is thrown.
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1322
     *
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1323
     * @param declaringClass the class to search for a method matching {@code binding}
48861
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1324
     * @return the method (if any) in {@code declaringClass} matching {@code binding}
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1325
     */
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1326
    public static Method resolveMethod(Class<?> declaringClass, Binding binding) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1327
        if (binding.name.equals("<init>")) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1328
            return null;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1329
        }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1330
        Method[] methods = declaringClass.getDeclaredMethods();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1331
        List<String> parameterTypeNames = parseParameters(binding.argumentsDescriptor);
48861
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1332
        Method match = null;
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1333
        for (int i = 0; i < methods.length; ++i) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1334
            Method m = methods[i];
48861
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1335
            if (binding.isStatic == Modifier.isStatic(m.getModifiers()) &&
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1336
                            m.getName().equals(binding.name) &&
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1337
                            parameterTypeNames.equals(toInternalTypeNames(m.getParameterTypes()))) {
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1338
                if (match == null) {
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1339
                    match = m;
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1340
                } else if (match.getReturnType().isAssignableFrom(m.getReturnType())) {
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1341
                    // `m` has a more specific return type - choose it
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1342
                    // (`match` is most likely a bridge method)
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1343
                    match = m;
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1344
                } else {
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1345
                    if (!m.getReturnType().isAssignableFrom(match.getReturnType())) {
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1346
                        throw new NoSuchMethodError(String.format(
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1347
                                        "Found 2 methods with same name and parameter types but unrelated return types:%n %s%n %s", match, m));
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1348
                    }
48861
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1349
                }
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1350
            }
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1351
        }
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1352
        return match;
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1353
    }
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1354
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1355
    /**
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1356
     * Same as {@link #resolveMethod(Class, Binding)} and
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1357
     * {@link #resolveConstructor(Class, Binding)} except in terms of {@link ResolvedJavaType} and
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1358
     * {@link ResolvedJavaMethod}.
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1359
     */
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1360
    public static ResolvedJavaMethod resolveJavaMethod(ResolvedJavaType declaringClass, Binding binding) {
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1361
        ResolvedJavaMethod[] methods = declaringClass.getDeclaredMethods();
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1362
        if (binding.name.equals("<init>")) {
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1363
            for (ResolvedJavaMethod m : methods) {
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1364
                if (m.getName().equals("<init>") && m.getSignature().toMethodDescriptor().startsWith(binding.argumentsDescriptor)) {
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1365
                    return m;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1366
                }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1367
            }
48861
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1368
            return null;
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1369
        }
48861
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1370
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1371
        ResolvedJavaMethod match = null;
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1372
        for (int i = 0; i < methods.length; ++i) {
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1373
            ResolvedJavaMethod m = methods[i];
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1374
            if (binding.isStatic == m.isStatic() &&
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1375
                            m.getName().equals(binding.name) &&
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1376
                            m.getSignature().toMethodDescriptor().startsWith(binding.argumentsDescriptor)) {
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1377
                if (match == null) {
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1378
                    match = m;
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1379
                } else {
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1380
                    final ResolvedJavaType matchReturnType = (ResolvedJavaType) match.getSignature().getReturnType(declaringClass);
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1381
                    final ResolvedJavaType mReturnType = (ResolvedJavaType) m.getSignature().getReturnType(declaringClass);
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1382
                    if (matchReturnType.isAssignableFrom(mReturnType)) {
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1383
                        // `m` has a more specific return type - choose it
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1384
                        // (`match` is most likely a bridge method)
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1385
                        match = m;
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1386
                    } else {
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1387
                        if (!mReturnType.isAssignableFrom(matchReturnType)) {
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1388
                            throw new NoSuchMethodError(String.format(
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1389
                                            "Found 2 methods with same name and parameter types but unrelated return types:%n %s%n %s", match, m));
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1390
                        }
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1391
                    }
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1392
                }
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1393
            }
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1394
        }
47f19ff9903c 8194819: Update Graal
iveresov
parents: 47216
diff changeset
  1395
        return match;
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1396
    }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1397
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1398
    /**
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1399
     * Resolves a given binding to a constructor in a given class.
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1400
     *
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1401
     * @param declaringClass the class to search for a constructor matching {@code binding}
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1402
     * @return the constructor (if any) in {@code declaringClass} matching binding
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1403
     */
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1404
    public static Constructor<?> resolveConstructor(Class<?> declaringClass, Binding binding) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1405
        if (!binding.name.equals("<init>")) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1406
            return null;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1407
        }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1408
        Constructor<?>[] constructors = declaringClass.getDeclaredConstructors();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1409
        List<String> parameterTypeNames = parseParameters(binding.argumentsDescriptor);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1410
        for (int i = 0; i < constructors.length; ++i) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1411
            Constructor<?> c = constructors[i];
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1412
            if (parameterTypeNames.equals(toInternalTypeNames(c.getParameterTypes()))) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1413
                return c;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1414
            }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1415
        }
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1416
        return null;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1417
    }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1418
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1419
    private static List<String> parseParameters(String argumentsDescriptor) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1420
        assert argumentsDescriptor.startsWith("(") && argumentsDescriptor.endsWith(")") : argumentsDescriptor;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1421
        List<String> res = new ArrayList<>();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1422
        int cur = 1;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1423
        int end = argumentsDescriptor.length() - 1;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1424
        while (cur != end) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1425
            char first;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1426
            int start = cur;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1427
            do {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1428
                first = argumentsDescriptor.charAt(cur++);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1429
            } while (first == '[');
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1430
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1431
            switch (first) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1432
                case 'L':
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1433
                    int endObject = argumentsDescriptor.indexOf(';', cur);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1434
                    if (endObject == -1) {
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1435
                        throw new GraalError("Invalid object type at index %d in signature: %s", cur, argumentsDescriptor);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1436
                    }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1437
                    cur = endObject + 1;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1438
                    break;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1439
                case 'V':
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1440
                case 'I':
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1441
                case 'B':
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1442
                case 'C':
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1443
                case 'D':
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1444
                case 'F':
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1445
                case 'J':
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1446
                case 'S':
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1447
                case 'Z':
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1448
                    break;
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1449
                default:
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1450
                    throw new GraalError("Invalid character at index %d in signature: %s", cur, argumentsDescriptor);
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1451
            }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1452
            res.add(argumentsDescriptor.substring(start, cur));
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1453
        }
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
  1454
        return res;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1455
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
  1456
}