src/jdk.internal.vm.compiler/share/classes/org.graalvm.compiler.serviceprovider/src/org/graalvm/compiler/serviceprovider/GraalServices.java
author mchung
Mon, 22 Oct 2018 17:00:04 -0700
changeset 52220 9c260a6b6471
parent 51436 091c0d22e735
child 52578 7dd81e82d083
permissions -rw-r--r--
8207146: Rename jdk.internal.misc.Unsafe::xxxObject to xxxReference Reviewed-by: dholmes, thartmann
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
     1
/*
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
     2
 * Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
     4
 *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
     7
 * published by the Free Software Foundation.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
     8
 *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    13
 * accompanied this code).
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    14
 *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    18
 *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    21
 * questions.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    22
 */
50858
2d3e99a72541 8205824: Update Graal
never
parents: 49873
diff changeset
    23
2d3e99a72541 8205824: Update Graal
never
parents: 49873
diff changeset
    24
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    25
package org.graalvm.compiler.serviceprovider;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    26
49873
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
    27
import static java.lang.Thread.currentThread;
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
    28
49873
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
    29
import java.io.IOException;
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
    30
import java.io.InputStream;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    31
import java.util.Iterator;
49873
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
    32
import java.util.List;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    33
import java.util.ServiceConfigurationError;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    34
import java.util.ServiceLoader;
49873
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
    35
import java.util.concurrent.atomic.AtomicLong;
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    36
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    37
import jdk.vm.ci.services.JVMCIPermission;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    38
import jdk.vm.ci.services.Services;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    39
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    40
/**
49873
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
    41
 * Interface to functionality that abstracts over which JDK version Graal is running on.
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    42
 */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    43
public final class GraalServices {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    44
49873
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
    45
    private static int getJavaSpecificationVersion() {
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
    46
        String value = System.getProperty("java.specification.version");
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
    47
        if (value.startsWith("1.")) {
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
    48
            value = value.substring(2);
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
    49
        }
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
    50
        return Integer.parseInt(value);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    51
    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    52
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
    53
    /**
49873
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
    54
     * The integer value corresponding to the value of the {@code java.specification.version} system
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
    55
     * property after any leading {@code "1."} has been stripped.
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
    56
     */
49873
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
    57
    public static final int JAVA_SPECIFICATION_VERSION = getJavaSpecificationVersion();
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
    58
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
    59
    /**
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
    60
     * Determines if the Java runtime is version 8 or earlier.
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
    61
     */
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
    62
    public static final boolean Java8OrEarlier = JAVA_SPECIFICATION_VERSION <= 8;
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
    63
52220
9c260a6b6471 8207146: Rename jdk.internal.misc.Unsafe::xxxObject to xxxReference
mchung
parents: 51436
diff changeset
    64
    /**
9c260a6b6471 8207146: Rename jdk.internal.misc.Unsafe::xxxObject to xxxReference
mchung
parents: 51436
diff changeset
    65
     * Determines if the Java runtime is version 11 or earlier.
9c260a6b6471 8207146: Rename jdk.internal.misc.Unsafe::xxxObject to xxxReference
mchung
parents: 51436
diff changeset
    66
     */
9c260a6b6471 8207146: Rename jdk.internal.misc.Unsafe::xxxObject to xxxReference
mchung
parents: 51436
diff changeset
    67
    public static final boolean Java11OrEarlier = JAVA_SPECIFICATION_VERSION <= 11;
9c260a6b6471 8207146: Rename jdk.internal.misc.Unsafe::xxxObject to xxxReference
mchung
parents: 51436
diff changeset
    68
49873
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
    69
    private GraalServices() {
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
    70
    }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    71
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    72
    /**
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    73
     * Gets an {@link Iterable} of the providers available for a given service.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    74
     *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    75
     * @throws SecurityException if on JDK8 and a security manager is present and it denies
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    76
     *             {@link JVMCIPermission}
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 static <S> Iterable<S> load(Class<S> service) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    79
        assert !service.getName().startsWith("jdk.vm.ci") : "JVMCI services must be loaded via " + Services.class.getName();
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
    80
        Iterable<S> iterable = ServiceLoader.load(service);
49873
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
    81
        return new Iterable<>() {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    82
            @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    83
            public Iterator<S> iterator() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    84
                Iterator<S> iterator = iterable.iterator();
49873
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
    85
                return new Iterator<>() {
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    86
                    @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    87
                    public boolean hasNext() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    88
                        return iterator.hasNext();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    89
                    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    90
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    91
                    @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    92
                    public S next() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    93
                        S provider = iterator.next();
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
    94
                        // Allow Graal extensions to access JVMCI
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
    95
                        openJVMCITo(provider.getClass());
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    96
                        return provider;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    97
                    }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    98
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
    99
                    @Override
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   100
                    public void remove() {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   101
                        iterator.remove();
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
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   105
        };
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   106
    }
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
    /**
49873
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   109
     * Opens all JVMCI packages to the module of a given class. This relies on JVMCI already having
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   110
     * opened all its packages to the module defining {@link GraalServices}.
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   111
     *
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   112
     * @param other all JVMCI packages will be opened to the module defining this class
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   113
     */
49873
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   114
    static void openJVMCITo(Class<?> other) {
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   115
        Module jvmciModule = JVMCI_MODULE;
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   116
        Module otherModule = other.getModule();
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   117
        if (jvmciModule != otherModule) {
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   118
            for (String pkg : jvmciModule.getPackages()) {
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   119
                if (!jvmciModule.isOpen(pkg, otherModule)) {
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   120
                    jvmciModule.addOpens(pkg, otherModule);
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   121
                }
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   122
            }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   123
        }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   124
    }
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   125
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   126
    /**
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   127
     * Gets the provider for a given service for which at most one provider must be available.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   128
     *
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   129
     * @param service the service whose provider is being requested
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   130
     * @param required specifies if an {@link InternalError} should be thrown if no provider of
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   131
     *            {@code service} is available
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   132
     * @return the requested provider if available else {@code null}
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   133
     * @throws SecurityException if on JDK8 and a security manager is present and it denies
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   134
     *             {@link JVMCIPermission}
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   135
     */
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   136
    public static <S> S loadSingle(Class<S> service, boolean required) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   137
        assert !service.getName().startsWith("jdk.vm.ci") : "JVMCI services must be loaded via " + Services.class.getName();
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   138
        Iterable<S> providers = load(service);
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   139
        S singleProvider = null;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   140
        try {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   141
            for (Iterator<S> it = providers.iterator(); it.hasNext();) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   142
                singleProvider = it.next();
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   143
                if (it.hasNext()) {
46459
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   144
                    S other = it.next();
7d4e637d3f21 8180267: Update Graal
kvn
parents: 46458
diff changeset
   145
                    throw new InternalError(String.format("Multiple %s providers found: %s, %s", service.getName(), singleProvider.getClass().getName(), other.getClass().getName()));
43972
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
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   148
        } catch (ServiceConfigurationError e) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   149
            // If the service is required we will bail out below.
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   150
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   151
        if (singleProvider == null) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   152
            if (required) {
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   153
                throw new InternalError(String.format("No provider for %s found", service.getName()));
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   154
            }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   155
        }
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   156
        return singleProvider;
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   157
    }
49873
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   158
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   159
    /**
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   160
     * Gets the class file bytes for {@code c}.
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   161
     */
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   162
    public static InputStream getClassfileAsStream(Class<?> c) throws IOException {
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   163
        String classfilePath = c.getName().replace('.', '/') + ".class";
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   164
        return c.getModule().getResourceAsStream(classfilePath);
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   165
    }
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   166
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   167
    private static final Module JVMCI_MODULE = Services.class.getModule();
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   168
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   169
    /**
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   170
     * A JVMCI package dynamically exported to trusted modules.
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   171
     */
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   172
    private static final String JVMCI_RUNTIME_PACKAGE = "jdk.vm.ci.runtime";
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   173
    static {
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   174
        assert JVMCI_MODULE.getPackages().contains(JVMCI_RUNTIME_PACKAGE);
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   175
    }
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   176
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   177
    /**
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   178
     * Determines if invoking {@link Object#toString()} on an instance of {@code c} will only run
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   179
     * trusted code.
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   180
     */
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   181
    public static boolean isToStringTrusted(Class<?> c) {
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   182
        Module module = c.getModule();
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   183
        Module jvmciModule = JVMCI_MODULE;
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   184
        assert jvmciModule.getPackages().contains("jdk.vm.ci.runtime");
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   185
        if (module == jvmciModule || jvmciModule.isOpen(JVMCI_RUNTIME_PACKAGE, module)) {
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   186
            // Can access non-statically-exported package in JVMCI
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   187
            return true;
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   188
        }
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   189
        return false;
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   190
    }
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   191
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   192
    /**
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   193
     * Gets a unique identifier for this execution such as a process ID or a
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   194
     * {@linkplain #getGlobalTimeStamp() fixed timestamp}.
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   195
     */
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   196
    public static String getExecutionID() {
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   197
        return Long.toString(ProcessHandle.current().pid());
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   198
    }
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   199
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   200
    private static final AtomicLong globalTimeStamp = new AtomicLong();
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   201
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   202
    /**
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   203
     * Gets a time stamp for the current process. This method will always return the same value for
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   204
     * the current VM execution.
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   205
     */
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   206
    public static long getGlobalTimeStamp() {
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   207
        if (globalTimeStamp.get() == 0) {
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   208
            globalTimeStamp.compareAndSet(0, System.currentTimeMillis());
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   209
        }
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   210
        return globalTimeStamp.get();
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   211
    }
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   212
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   213
    /**
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   214
     * Returns an approximation of the total amount of memory, in bytes, allocated in heap memory
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   215
     * for the thread of the specified ID. The returned value is an approximation because some Java
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   216
     * virtual machine implementations may use object allocation mechanisms that result in a delay
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   217
     * between the time an object is allocated and the time its size is recorded.
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   218
     * <p>
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   219
     * If the thread of the specified ID is not alive or does not exist, this method returns
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   220
     * {@code -1}. If thread memory allocation measurement is disabled, this method returns
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   221
     * {@code -1}. A thread is alive if it has been started and has not yet died.
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   222
     * <p>
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   223
     * If thread memory allocation measurement is enabled after the thread has started, the Java
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   224
     * virtual machine implementation may choose any time up to and including the time that the
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   225
     * capability is enabled as the point where thread memory allocation measurement starts.
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   226
     *
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   227
     * @param id the thread ID of a thread
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   228
     * @return an approximation of the total memory allocated, in bytes, in heap memory for a thread
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   229
     *         of the specified ID if the thread of the specified ID exists, the thread is alive,
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   230
     *         and thread memory allocation measurement is enabled; {@code -1} otherwise.
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   231
     *
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   232
     * @throws IllegalArgumentException if {@code id} {@code <=} {@code 0}.
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   233
     * @throws UnsupportedOperationException if the Java virtual machine implementation does not
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   234
     *             {@linkplain #isThreadAllocatedMemorySupported() support} thread memory allocation
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   235
     *             measurement.
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   236
     */
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   237
    public static long getThreadAllocatedBytes(long id) {
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   238
        JMXService jmx = JMXService.instance;
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   239
        if (jmx == null) {
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   240
            throw new UnsupportedOperationException();
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   241
        }
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   242
        return jmx.getThreadAllocatedBytes(id);
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   243
    }
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   244
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   245
    /**
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   246
     * Convenience method for calling {@link #getThreadAllocatedBytes(long)} with the id of the
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   247
     * current thread.
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   248
     */
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   249
    public static long getCurrentThreadAllocatedBytes() {
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   250
        return getThreadAllocatedBytes(currentThread().getId());
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   251
    }
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   252
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   253
    /**
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   254
     * Returns the total CPU time for the current thread in nanoseconds. The returned value is of
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   255
     * nanoseconds precision but not necessarily nanoseconds accuracy. If the implementation
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   256
     * distinguishes between user mode time and system mode time, the returned CPU time is the
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   257
     * amount of time that the current thread has executed in user mode or system mode.
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   258
     *
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   259
     * @return the total CPU time for the current thread if CPU time measurement is enabled;
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   260
     *         {@code -1} otherwise.
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   261
     *
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   262
     * @throws UnsupportedOperationException if the Java virtual machine does not
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   263
     *             {@linkplain #isCurrentThreadCpuTimeSupported() support} CPU time measurement for
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   264
     *             the current thread
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   265
     */
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   266
    public static long getCurrentThreadCpuTime() {
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   267
        JMXService jmx = JMXService.instance;
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   268
        if (jmx == null) {
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   269
            throw new UnsupportedOperationException();
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   270
        }
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   271
        return jmx.getCurrentThreadCpuTime();
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   272
    }
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   273
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   274
    /**
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   275
     * Determines if the Java virtual machine implementation supports thread memory allocation
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   276
     * measurement.
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   277
     */
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   278
    public static boolean isThreadAllocatedMemorySupported() {
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   279
        JMXService jmx = JMXService.instance;
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   280
        if (jmx == null) {
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   281
            return false;
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   282
        }
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   283
        return jmx.isThreadAllocatedMemorySupported();
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   284
    }
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   285
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   286
    /**
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   287
     * Determines if the Java virtual machine supports CPU time measurement for the current thread.
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   288
     */
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   289
    public static boolean isCurrentThreadCpuTimeSupported() {
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   290
        JMXService jmx = JMXService.instance;
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   291
        if (jmx == null) {
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   292
            return false;
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   293
        }
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   294
        return jmx.isCurrentThreadCpuTimeSupported();
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   295
    }
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   296
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   297
    /**
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   298
     * Gets the input arguments passed to the Java virtual machine which does not include the
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   299
     * arguments to the {@code main} method. This method returns an empty list if there is no input
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   300
     * argument to the Java virtual machine.
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   301
     * <p>
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   302
     * Some Java virtual machine implementations may take input arguments from multiple different
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   303
     * sources: for examples, arguments passed from the application that launches the Java virtual
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   304
     * machine such as the 'java' command, environment variables, configuration files, etc.
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   305
     * <p>
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   306
     * Typically, not all command-line options to the 'java' command are passed to the Java virtual
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   307
     * machine. Thus, the returned input arguments may not include all command-line options.
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   308
     *
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   309
     * @return the input arguments to the JVM or {@code null} if they are unavailable
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   310
     */
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   311
    public static List<String> getInputArguments() {
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   312
        JMXService jmx = JMXService.instance;
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   313
        if (jmx == null) {
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   314
            return null;
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   315
        }
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   316
        return jmx.getInputArguments();
26ebfe8ce852 8199755: Update Graal
dlong
parents: 49451
diff changeset
   317
    }
43972
1ade39b8381b 8174879: Rename jdk.vm.ci to jdk.internal.vm.ci
kvn
parents:
diff changeset
   318
}