diff --git a/make/hotspot/symbols/symbols-unix b/make/hotspot/symbols/symbols-unix index de444eae41c..97aa40b970b 100644 --- a/make/hotspot/symbols/symbols-unix +++ b/make/hotspot/symbols/symbols-unix @@ -123,7 +123,7 @@ JVM_GetPermittedSubclasses JVM_GetPrimitiveArrayElement JVM_GetProperties JVM_GetProtectionDomain -JVM_GetRandomSeedForCDSDump +JVM_GetRandomSeedForDumping JVM_GetRecordComponents JVM_GetSimpleBinaryName JVM_GetStackAccessControlContext @@ -143,8 +143,8 @@ JVM_InternString JVM_Interrupt JVM_InvokeMethod JVM_IsArrayClass -JVM_IsCDSDumpingEnabled -JVM_IsCDSSharingEnabled +JVM_IsDynamicDumpingEnabled +JVM_IsSharingEnabled JVM_IsConstructorIx JVM_IsHiddenClass JVM_IsInterface diff --git a/src/hotspot/share/include/jvm.h b/src/hotspot/share/include/jvm.h index 15b064dcb7d..fb9dfba4301 100644 --- a/src/hotspot/share/include/jvm.h +++ b/src/hotspot/share/include/jvm.h @@ -198,13 +198,13 @@ JVM_LookupLambdaProxyClassFromArchive(JNIEnv* env, jclass caller, jboolean initialize); JNIEXPORT jboolean JNICALL -JVM_IsCDSDumpingEnabled(JNIEnv* env); +JVM_IsDynamicDumpingEnabled(JNIEnv* env); JNIEXPORT jboolean JNICALL -JVM_IsCDSSharingEnabled(JNIEnv* env); +JVM_IsSharingEnabled(JNIEnv* env); JNIEXPORT jlong JNICALL -JVM_GetRandomSeedForCDSDump(); +JVM_GetRandomSeedForDumping(); /* * java.lang.Throwable diff --git a/src/hotspot/share/prims/jvm.cpp b/src/hotspot/share/prims/jvm.cpp index e6313ba37f2..2ff1c5e8a79 100644 --- a/src/hotspot/share/prims/jvm.cpp +++ b/src/hotspot/share/prims/jvm.cpp @@ -3833,18 +3833,18 @@ JVM_ENTRY(jclass, JVM_LookupLambdaProxyClassFromArchive(JNIEnv* env, #endif // INCLUDE_CDS JVM_END -JVM_ENTRY(jboolean, JVM_IsCDSDumpingEnabled(JNIEnv* env)) - JVMWrapper("JVM_IsCDSDumpingEnable"); +JVM_ENTRY(jboolean, JVM_IsDynamicDumpingEnabled(JNIEnv* env)) + JVMWrapper("JVM_IsDynamicDumpingEnable"); return DynamicDumpSharedSpaces; JVM_END -JVM_ENTRY(jboolean, JVM_IsCDSSharingEnabled(JNIEnv* env)) - JVMWrapper("JVM_IsCDSSharingEnable"); +JVM_ENTRY(jboolean, JVM_IsSharingEnabled(JNIEnv* env)) + JVMWrapper("JVM_IsSharingEnable"); return UseSharedSpaces; JVM_END -JVM_ENTRY_NO_ENV(jlong, JVM_GetRandomSeedForCDSDump()) - JVMWrapper("JVM_GetRandomSeedForCDSDump"); +JVM_ENTRY_NO_ENV(jlong, JVM_GetRandomSeedForDumping()) + JVMWrapper("JVM_GetRandomSeedForDumping"); if (DumpSharedSpaces) { const char* release = Abstract_VM_Version::vm_release(); const char* dbg_level = Abstract_VM_Version::jdk_debug_level(); @@ -3859,7 +3859,7 @@ JVM_ENTRY_NO_ENV(jlong, JVM_GetRandomSeedForCDSDump()) if (seed == 0) { // don't let this ever be zero. seed = 0x87654321; } - log_debug(cds)("JVM_GetRandomSeedForCDSDump() = " JLONG_FORMAT, seed); + log_debug(cds)("JVM_GetRandomSeedForDumping() = " JLONG_FORMAT, seed); return seed; } else { return 0; diff --git a/src/java.base/share/classes/java/lang/Byte.java b/src/java.base/share/classes/java/lang/Byte.java index e71eba7b2d5..4aeb73bbe8a 100644 --- a/src/java.base/share/classes/java/lang/Byte.java +++ b/src/java.base/share/classes/java/lang/Byte.java @@ -26,7 +26,7 @@ package java.lang; import jdk.internal.HotSpotIntrinsicCandidate; -import jdk.internal.misc.VM; +import jdk.internal.misc.CDS; import java.lang.constant.Constable; import java.lang.constant.DynamicConstantDesc; @@ -108,7 +108,7 @@ public final class Byte extends Number implements Comparable, Constable { final int size = -(-128) + 127 + 1; // Load and use the archived cache if it exists - VM.initializeFromArchive(ByteCache.class); + CDS.initializeFromArchive(ByteCache.class); if (archivedCache == null || archivedCache.length != size) { Byte[] c = new Byte[size]; byte value = (byte)-128; diff --git a/src/java.base/share/classes/java/lang/Character.java b/src/java.base/share/classes/java/lang/Character.java index dd69413f1b8..d50d7fdb118 100644 --- a/src/java.base/share/classes/java/lang/Character.java +++ b/src/java.base/share/classes/java/lang/Character.java @@ -26,7 +26,7 @@ package java.lang; import jdk.internal.HotSpotIntrinsicCandidate; -import jdk.internal.misc.VM; +import jdk.internal.misc.CDS; import java.lang.constant.Constable; import java.lang.constant.DynamicConstantDesc; @@ -8516,7 +8516,7 @@ class Character implements java.io.Serializable, Comparable, Constabl int size = 127 + 1; // Load and use the archived cache if it exists - VM.initializeFromArchive(CharacterCache.class); + CDS.initializeFromArchive(CharacterCache.class); if (archivedCache == null || archivedCache.length != size) { Character[] c = new Character[size]; for (int i = 0; i < size; i++) { diff --git a/src/java.base/share/classes/java/lang/Integer.java b/src/java.base/share/classes/java/lang/Integer.java index cf67cc42d74..735d194fbde 100644 --- a/src/java.base/share/classes/java/lang/Integer.java +++ b/src/java.base/share/classes/java/lang/Integer.java @@ -33,6 +33,7 @@ import java.util.Objects; import java.util.Optional; import jdk.internal.HotSpotIntrinsicCandidate; +import jdk.internal.misc.CDS; import jdk.internal.misc.VM; import static java.lang.String.COMPACT_STRINGS; @@ -1023,7 +1024,7 @@ public final class Integer extends Number high = h; // Load IntegerCache.archivedCache from archive, if possible - VM.initializeFromArchive(IntegerCache.class); + CDS.initializeFromArchive(IntegerCache.class); int size = (high - low) + 1; // Use the archived cache if it exists and is large enough diff --git a/src/java.base/share/classes/java/lang/Long.java b/src/java.base/share/classes/java/lang/Long.java index 953f352a873..808a87b1c47 100644 --- a/src/java.base/share/classes/java/lang/Long.java +++ b/src/java.base/share/classes/java/lang/Long.java @@ -34,7 +34,7 @@ import java.util.Objects; import java.util.Optional; import jdk.internal.HotSpotIntrinsicCandidate; -import jdk.internal.misc.VM; +import jdk.internal.misc.CDS; import static java.lang.String.COMPACT_STRINGS; import static java.lang.String.LATIN1; @@ -1169,7 +1169,7 @@ public final class Long extends Number int size = -(-128) + 127 + 1; // Load and use the archived cache if it exists - VM.initializeFromArchive(LongCache.class); + CDS.initializeFromArchive(LongCache.class); if (archivedCache == null || archivedCache.length != size) { Long[] c = new Long[size]; long value = -128; diff --git a/src/java.base/share/classes/java/lang/Module.java b/src/java.base/share/classes/java/lang/Module.java index 3d5734f7a91..7d0a0d08888 100644 --- a/src/java.base/share/classes/java/lang/Module.java +++ b/src/java.base/share/classes/java/lang/Module.java @@ -55,6 +55,7 @@ import java.util.stream.Stream; import jdk.internal.loader.BuiltinClassLoader; import jdk.internal.loader.BootLoader; import jdk.internal.loader.ClassLoaders; +import jdk.internal.misc.CDS; import jdk.internal.misc.VM; import jdk.internal.module.IllegalAccessLogger; import jdk.internal.module.ModuleLoaderMap; @@ -277,7 +278,7 @@ public final class Module implements AnnotatedElement { } static { - VM.initializeFromArchive(ArchivedData.class); + CDS.initializeFromArchive(ArchivedData.class); } } diff --git a/src/java.base/share/classes/java/lang/Short.java b/src/java.base/share/classes/java/lang/Short.java index 53ca694291d..c0651847466 100644 --- a/src/java.base/share/classes/java/lang/Short.java +++ b/src/java.base/share/classes/java/lang/Short.java @@ -26,7 +26,7 @@ package java.lang; import jdk.internal.HotSpotIntrinsicCandidate; -import jdk.internal.misc.VM; +import jdk.internal.misc.CDS; import java.lang.constant.Constable; import java.lang.constant.DynamicConstantDesc; @@ -234,7 +234,7 @@ public final class Short extends Number implements Comparable, Constable int size = -(-128) + 127 + 1; // Load and use the archived cache if it exists - VM.initializeFromArchive(ShortCache.class); + CDS.initializeFromArchive(ShortCache.class); if (archivedCache == null || archivedCache.length != size) { Short[] c = new Short[size]; short value = -128; diff --git a/src/java.base/share/classes/java/lang/invoke/LambdaProxyClassArchive.java b/src/java.base/share/classes/java/lang/invoke/LambdaProxyClassArchive.java index bad015a5624..9ad06751108 100644 --- a/src/java.base/share/classes/java/lang/invoke/LambdaProxyClassArchive.java +++ b/src/java.base/share/classes/java/lang/invoke/LambdaProxyClassArchive.java @@ -26,15 +26,15 @@ package java.lang.invoke; import jdk.internal.loader.BuiltinClassLoader; -import jdk.internal.misc.VM; +import jdk.internal.misc.CDS; final class LambdaProxyClassArchive { private static final boolean dumpArchive; private static final boolean sharingEnabled; static { - dumpArchive = VM.isCDSDumpingEnabled(); - sharingEnabled = VM.isCDSSharingEnabled(); + dumpArchive = CDS.isDynamicDumpingEnabled(); + sharingEnabled = CDS.isSharingEnabled(); } /** diff --git a/src/java.base/share/classes/java/lang/module/Configuration.java b/src/java.base/share/classes/java/lang/module/Configuration.java index 9a9cb533eee..e1b1f39cc32 100644 --- a/src/java.base/share/classes/java/lang/module/Configuration.java +++ b/src/java.base/share/classes/java/lang/module/Configuration.java @@ -41,7 +41,7 @@ import java.util.Set; import java.util.stream.Collectors; import java.util.stream.Stream; -import jdk.internal.misc.VM; +import jdk.internal.misc.CDS; import jdk.internal.module.ModuleReferenceImpl; import jdk.internal.module.ModuleTarget; import jdk.internal.vm.annotation.Stable; @@ -110,7 +110,7 @@ public final class Configuration { static { // Initialize EMPTY_CONFIGURATION from the archive. - VM.initializeFromArchive(Configuration.class); + CDS.initializeFromArchive(Configuration.class); // Create a new empty Configuration if there is no archived version. if (EMPTY_CONFIGURATION == null) { EMPTY_CONFIGURATION = new Configuration(); diff --git a/src/java.base/share/classes/java/util/ImmutableCollections.java b/src/java.base/share/classes/java/util/ImmutableCollections.java index ccf92e2f421..716986b0efd 100644 --- a/src/java.base/share/classes/java/util/ImmutableCollections.java +++ b/src/java.base/share/classes/java/util/ImmutableCollections.java @@ -37,7 +37,7 @@ import java.util.function.Function; import java.util.function.Predicate; import java.util.function.UnaryOperator; import jdk.internal.access.SharedSecrets; -import jdk.internal.misc.VM; +import jdk.internal.misc.CDS; import jdk.internal.vm.annotation.Stable; /** @@ -76,7 +76,7 @@ class ImmutableCollections { // derived from the JVM build/version, so can we generate the exact same // CDS archive for the same JDK build. This makes it possible to verify the // consistency of the JDK build. - long seed = VM.getRandomSeedForCDSDump(); + long seed = CDS.getRandomSeedForDumping(); if (seed == 0) { seed = System.nanoTime(); } @@ -100,7 +100,7 @@ class ImmutableCollections { static final MapN EMPTY_MAP; static { - VM.initializeFromArchive(ImmutableCollections.class); + CDS.initializeFromArchive(ImmutableCollections.class); if (archivedObjects == null) { EMPTY = new Object(); EMPTY_LIST = new ListN<>(); diff --git a/src/java.base/share/classes/java/util/jar/Attributes.java b/src/java.base/share/classes/java/util/jar/Attributes.java index 79cb2fe1c47..d2cd77d5a3b 100644 --- a/src/java.base/share/classes/java/util/jar/Attributes.java +++ b/src/java.base/share/classes/java/util/jar/Attributes.java @@ -34,7 +34,7 @@ import java.util.Map; import java.util.Objects; import java.util.Set; -import jdk.internal.misc.VM; +import jdk.internal.misc.CDS; import jdk.internal.vm.annotation.Stable; import sun.nio.cs.UTF_8; @@ -672,7 +672,7 @@ public class Attributes implements Map, Cloneable { static { - VM.initializeFromArchive(Attributes.Name.class); + CDS.initializeFromArchive(Attributes.Name.class); if (KNOWN_NAMES == null) { MANIFEST_VERSION = new Name("Manifest-Version"); diff --git a/src/java.base/share/classes/jdk/internal/loader/ArchivedClassLoaders.java b/src/java.base/share/classes/jdk/internal/loader/ArchivedClassLoaders.java index 48cd4e2e6dc..7113b521f4d 100644 --- a/src/java.base/share/classes/jdk/internal/loader/ArchivedClassLoaders.java +++ b/src/java.base/share/classes/jdk/internal/loader/ArchivedClassLoaders.java @@ -25,7 +25,7 @@ package jdk.internal.loader; import java.util.Map; -import jdk.internal.misc.VM; +import jdk.internal.misc.CDS; import jdk.internal.module.ServicesCatalog; /** @@ -91,6 +91,6 @@ class ArchivedClassLoaders { } static { - VM.initializeFromArchive(ArchivedClassLoaders.class); + CDS.initializeFromArchive(ArchivedClassLoaders.class); } } diff --git a/src/java.base/share/classes/jdk/internal/math/FDBigInteger.java b/src/java.base/share/classes/jdk/internal/math/FDBigInteger.java index b522d3121a0..f6d868dfcc2 100644 --- a/src/java.base/share/classes/jdk/internal/math/FDBigInteger.java +++ b/src/java.base/share/classes/jdk/internal/math/FDBigInteger.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2013, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -24,7 +24,7 @@ */ package jdk.internal.math; -import jdk.internal.misc.VM; +import jdk.internal.misc.CDS; import java.math.BigInteger; import java.util.Arrays; @@ -84,7 +84,7 @@ public /*@ spec_bigint_math @*/ class FDBigInteger { // Initialize FDBigInteger cache of powers of 5. static { - VM.initializeFromArchive(FDBigInteger.class); + CDS.initializeFromArchive(FDBigInteger.class); Object[] caches = archivedCaches; if (caches == null) { long[] long5pow = { diff --git a/src/java.base/share/classes/jdk/internal/misc/VM.java b/src/java.base/share/classes/jdk/internal/misc/VM.java index 5681a79558f..f0b32c30f6e 100644 --- a/src/java.base/share/classes/jdk/internal/misc/VM.java +++ b/src/java.base/share/classes/jdk/internal/misc/VM.java @@ -457,31 +457,6 @@ public class VM { } private static native void initialize(); - /** - * Initialize archived static fields in the given Class using archived - * values from CDS dump time. Also initialize the classes of objects in - * the archived graph referenced by those fields. - * - * Those static fields remain as uninitialized if there is no mapped CDS - * java heap data or there is any error during initialization of the - * object class in the archived graph. - */ - public static native void initializeFromArchive(Class c); - - public static native void defineArchivedModules(ClassLoader platformLoader, ClassLoader systemLoader); - - public static native long getRandomSeedForCDSDump(); - - /** - * Check if CDS dynamic dumping is enabled via the DynamicDumpSharedSpaces flag. - */ - public static native boolean isCDSDumpingEnabled(); - - /** - * Check if CDS sharing is enabled by via the UseSharedSpaces flag. - */ - public static native boolean isCDSSharingEnabled(); - /** * Provides access to information on buffer usage. */ diff --git a/src/java.base/share/classes/jdk/internal/module/ArchivedBootLayer.java b/src/java.base/share/classes/jdk/internal/module/ArchivedBootLayer.java index 90bd5eaa51e..decf27e8cb7 100644 --- a/src/java.base/share/classes/jdk/internal/module/ArchivedBootLayer.java +++ b/src/java.base/share/classes/jdk/internal/module/ArchivedBootLayer.java @@ -24,7 +24,7 @@ */ package jdk.internal.module; -import jdk.internal.misc.VM; +import jdk.internal.misc.CDS; /** * Used by ModuleBootstrap for archiving the boot layer and the builder needed to @@ -59,6 +59,6 @@ class ArchivedBootLayer { } static { - VM.initializeFromArchive(ArchivedBootLayer.class); + CDS.initializeFromArchive(ArchivedBootLayer.class); } } diff --git a/src/java.base/share/classes/jdk/internal/module/ArchivedModuleGraph.java b/src/java.base/share/classes/jdk/internal/module/ArchivedModuleGraph.java index 6b038238eb1..4d9f5eb7f62 100644 --- a/src/java.base/share/classes/jdk/internal/module/ArchivedModuleGraph.java +++ b/src/java.base/share/classes/jdk/internal/module/ArchivedModuleGraph.java @@ -29,7 +29,7 @@ import java.util.Set; import java.util.function.Function; import java.lang.module.Configuration; import java.lang.module.ModuleFinder; -import jdk.internal.misc.VM; +import jdk.internal.misc.CDS; /** * Used by ModuleBootstrap for archiving the configuration for the boot layer, @@ -123,6 +123,6 @@ class ArchivedModuleGraph { } static { - VM.initializeFromArchive(ArchivedModuleGraph.class); + CDS.initializeFromArchive(ArchivedModuleGraph.class); } } diff --git a/src/java.base/share/classes/jdk/internal/module/ModuleBootstrap.java b/src/java.base/share/classes/jdk/internal/module/ModuleBootstrap.java index bc872c44917..9d999a80e9b 100644 --- a/src/java.base/share/classes/jdk/internal/module/ModuleBootstrap.java +++ b/src/java.base/share/classes/jdk/internal/module/ModuleBootstrap.java @@ -54,7 +54,7 @@ import jdk.internal.access.SharedSecrets; import jdk.internal.loader.BootLoader; import jdk.internal.loader.BuiltinClassLoader; import jdk.internal.loader.ClassLoaders; -import jdk.internal.misc.VM; +import jdk.internal.misc.CDS; import jdk.internal.perf.PerfCounter; /** @@ -167,7 +167,7 @@ public final class ModuleBootstrap { assert canUseArchivedBootLayer(); bootLayer = archivedBootLayer.bootLayer(); BootLoader.getUnnamedModule(); // trigger of BootLoader. - VM.defineArchivedModules(ClassLoaders.platformClassLoader(), ClassLoaders.appClassLoader()); + CDS.defineArchivedModules(ClassLoaders.platformClassLoader(), ClassLoaders.appClassLoader()); // assume boot layer has at least one module providing a service // that is mapped to the application class loader. diff --git a/src/java.base/share/classes/sun/util/locale/BaseLocale.java b/src/java.base/share/classes/sun/util/locale/BaseLocale.java index 27ad70001a1..b520771f20a 100644 --- a/src/java.base/share/classes/sun/util/locale/BaseLocale.java +++ b/src/java.base/share/classes/sun/util/locale/BaseLocale.java @@ -32,7 +32,7 @@ package sun.util.locale; -import jdk.internal.misc.VM; +import jdk.internal.misc.CDS; import jdk.internal.vm.annotation.Stable; import java.lang.ref.SoftReference; @@ -62,7 +62,7 @@ public final class BaseLocale { ROOT = 18, NUM_CONSTANTS = 19; static { - VM.initializeFromArchive(BaseLocale.class); + CDS.initializeFromArchive(BaseLocale.class); BaseLocale[] baseLocales = constantBaseLocales; if (baseLocales == null) { baseLocales = new BaseLocale[NUM_CONSTANTS]; diff --git a/src/java.base/share/native/libjava/CDS.c b/src/java.base/share/native/libjava/CDS.c new file mode 100644 index 00000000000..9cad87ead44 --- /dev/null +++ b/src/java.base/share/native/libjava/CDS.c @@ -0,0 +1,55 @@ +/* + * Copyright (c) 2020, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. Oracle designates this + * particular file as subject to the "Classpath" exception as provided + * by Oracle in the LICENSE file that accompanied this code. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +#include "jvm.h" +#include "jdk_internal_misc_CDS.h" + +JNIEXPORT void JNICALL +Java_jdk_internal_misc_CDS_initializeFromArchive(JNIEnv *env, jclass ignore, + jclass c) { + JVM_InitializeFromArchive(env, c); +} + +JNIEXPORT void JNICALL +Java_jdk_internal_misc_CDS_defineArchivedModules(JNIEnv *env, jclass ignore, + jobject platform_loader, + jobject system_loader) { + JVM_DefineArchivedModules(env, platform_loader, system_loader); +} + +JNIEXPORT jlong JNICALL +Java_jdk_internal_misc_CDS_getRandomSeedForDumping(JNIEnv *env, jclass ignore) { + return JVM_GetRandomSeedForDumping(); +} + +JNIEXPORT jboolean JNICALL +Java_jdk_internal_misc_CDS_isDynamicDumpingEnabled(JNIEnv *env, jclass jcls) { + return JVM_IsDynamicDumpingEnabled(env); +} + +JNIEXPORT jboolean JNICALL +Java_jdk_internal_misc_CDS_isSharingEnabled(JNIEnv *env, jclass jcls) { + return JVM_IsSharingEnabled(env); +} diff --git a/src/java.base/share/native/libjava/VM.c b/src/java.base/share/native/libjava/VM.c index ffc7e680014..099ad46fff1 100644 --- a/src/java.base/share/native/libjava/VM.c +++ b/src/java.base/share/native/libjava/VM.c @@ -55,31 +55,3 @@ JNIEXPORT jobjectArray JNICALL Java_jdk_internal_misc_VM_getRuntimeArguments(JNIEnv *env, jclass cls) { return JVM_GetVmArguments(env); } - -JNIEXPORT void JNICALL -Java_jdk_internal_misc_VM_initializeFromArchive(JNIEnv *env, jclass ignore, - jclass c) { - JVM_InitializeFromArchive(env, c); -} - -JNIEXPORT void JNICALL -Java_jdk_internal_misc_VM_defineArchivedModules(JNIEnv *env, jclass ignore, - jobject platform_loader, - jobject system_loader) { - JVM_DefineArchivedModules(env, platform_loader, system_loader); -} - -JNIEXPORT jlong JNICALL -Java_jdk_internal_misc_VM_getRandomSeedForCDSDump(JNIEnv *env, jclass ignore) { - return JVM_GetRandomSeedForCDSDump(); -} - -JNIEXPORT jboolean JNICALL -Java_jdk_internal_misc_VM_isCDSDumpingEnabled(JNIEnv *env, jclass jcls) { - return JVM_IsCDSDumpingEnabled(env); -} - -JNIEXPORT jboolean JNICALL -Java_jdk_internal_misc_VM_isCDSSharingEnabled(JNIEnv *env, jclass jcls) { - return JVM_IsCDSSharingEnabled(env); -}