Merge
This commit is contained in:
commit
6bcbb519a6
@ -359,3 +359,4 @@ f900d5afd9c83a0df8f36161c27c5e4c86a66f4c jdk-9+111
|
|||||||
1d992540870ff33fe6cc550443388588df9b9e4f jdk-9+114
|
1d992540870ff33fe6cc550443388588df9b9e4f jdk-9+114
|
||||||
09617ce980b99d49abfd54dacfed353c47e2a115 jdk-9+115
|
09617ce980b99d49abfd54dacfed353c47e2a115 jdk-9+115
|
||||||
6743a8e0cab7b5f6f4a0575f6664892f0ab740af jdk-9+116
|
6743a8e0cab7b5f6f4a0575f6664892f0ab740af jdk-9+116
|
||||||
|
e882bcdbdac436523f3d5681611d3118a3804ea7 jdk-9+117
|
||||||
|
@ -435,6 +435,9 @@ AC_DEFUN([BOOTJDK_CHECK_BUILD_JDK],
|
|||||||
elif test ! -x "$BUILD_JDK/bin/jlink"; then
|
elif test ! -x "$BUILD_JDK/bin/jlink"; then
|
||||||
AC_MSG_NOTICE([Potential Build JDK found at $BUILD_JDK did not contain bin/jlink; ignoring])
|
AC_MSG_NOTICE([Potential Build JDK found at $BUILD_JDK did not contain bin/jlink; ignoring])
|
||||||
BUILD_JDK_FOUND=no
|
BUILD_JDK_FOUND=no
|
||||||
|
elif test ! -x "$BUILD_JDK/bin/jmod"; then
|
||||||
|
AC_MSG_NOTICE([Potential Build JDK found at $BUILD_JDK did not contain bin/jmod; ignoring])
|
||||||
|
BUILD_JDK_FOUND=no
|
||||||
elif test ! -x "$BUILD_JDK/bin/javac"; then
|
elif test ! -x "$BUILD_JDK/bin/javac"; then
|
||||||
# Do we have a bin/javac?
|
# Do we have a bin/javac?
|
||||||
AC_MSG_NOTICE([Potential Build JDK found at $BUILD_JDK did not contain bin/javac; ignoring])
|
AC_MSG_NOTICE([Potential Build JDK found at $BUILD_JDK did not contain bin/javac; ignoring])
|
||||||
@ -474,7 +477,8 @@ AC_DEFUN([BOOTJDK_SETUP_BUILD_JDK],
|
|||||||
AC_ARG_WITH(build-jdk, [AS_HELP_STRING([--with-build-jdk],
|
AC_ARG_WITH(build-jdk, [AS_HELP_STRING([--with-build-jdk],
|
||||||
[path to JDK of same version as is being built@<:@the newly built JDK@:>@])])
|
[path to JDK of same version as is being built@<:@the newly built JDK@:>@])])
|
||||||
|
|
||||||
CREATE_BUILDJDK_FOR_HOST=false
|
CREATE_BUILDJDK=false
|
||||||
|
EXTERNAL_BUILDJDK=false
|
||||||
BUILD_JDK_FOUND="no"
|
BUILD_JDK_FOUND="no"
|
||||||
if test "x$with_build_jdk" != "x"; then
|
if test "x$with_build_jdk" != "x"; then
|
||||||
BOOTJDK_CHECK_BUILD_JDK([
|
BOOTJDK_CHECK_BUILD_JDK([
|
||||||
@ -483,6 +487,7 @@ AC_DEFUN([BOOTJDK_SETUP_BUILD_JDK],
|
|||||||
BUILD_JDK_FOUND=maybe
|
BUILD_JDK_FOUND=maybe
|
||||||
AC_MSG_NOTICE([Found potential Build JDK using configure arguments])
|
AC_MSG_NOTICE([Found potential Build JDK using configure arguments])
|
||||||
fi])
|
fi])
|
||||||
|
EXTERNAL_BUILDJDK=true
|
||||||
else
|
else
|
||||||
if test "x$COMPILE_TYPE" = "xcross"; then
|
if test "x$COMPILE_TYPE" = "xcross"; then
|
||||||
BUILD_JDK="\$(BUILDJDK_OUTPUTDIR)/jdk"
|
BUILD_JDK="\$(BUILDJDK_OUTPUTDIR)/jdk"
|
||||||
@ -498,6 +503,11 @@ AC_DEFUN([BOOTJDK_SETUP_BUILD_JDK],
|
|||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
JMOD="$BUILD_JDK/bin/jmod"
|
||||||
|
JLINK="$BUILD_JDK/bin/jlink"
|
||||||
|
AC_SUBST(JMOD)
|
||||||
|
AC_SUBST(JLINK)
|
||||||
|
|
||||||
if test "x$BUILD_JDK_FOUND" != "xyes"; then
|
if test "x$BUILD_JDK_FOUND" != "xyes"; then
|
||||||
AC_MSG_CHECKING([for Build JDK])
|
AC_MSG_CHECKING([for Build JDK])
|
||||||
AC_MSG_RESULT([no])
|
AC_MSG_RESULT([no])
|
||||||
@ -506,4 +516,5 @@ AC_DEFUN([BOOTJDK_SETUP_BUILD_JDK],
|
|||||||
|
|
||||||
AC_SUBST(CREATE_BUILDJDK)
|
AC_SUBST(CREATE_BUILDJDK)
|
||||||
AC_SUBST(BUILD_JDK)
|
AC_SUBST(BUILD_JDK)
|
||||||
|
AC_SUBST(EXTERNAL_BUILDJDK)
|
||||||
])
|
])
|
||||||
|
@ -46,6 +46,7 @@ HOTSPOT_OUTPUTDIR := $(patsubst $(BUILD_OUTPUT)%,$(BUILDJDK_OUTPUTDIR)%,$(HOTSPO
|
|||||||
HOTSPOT_DIST := $(patsubst $(BUILD_OUTPUT)%,$(BUILDJDK_OUTPUTDIR)%,$(HOTSPOT_DIST))
|
HOTSPOT_DIST := $(patsubst $(BUILD_OUTPUT)%,$(BUILDJDK_OUTPUTDIR)%,$(HOTSPOT_DIST))
|
||||||
SUPPORT_OUTPUTDIR := $(patsubst $(BUILD_OUTPUT)%,$(BUILDJDK_OUTPUTDIR)%,$(SUPPORT_OUTPUTDIR))
|
SUPPORT_OUTPUTDIR := $(patsubst $(BUILD_OUTPUT)%,$(BUILDJDK_OUTPUTDIR)%,$(SUPPORT_OUTPUTDIR))
|
||||||
JDK_OUTPUTDIR := $(patsubst $(BUILD_OUTPUT)%,$(BUILDJDK_OUTPUTDIR)%,$(JDK_OUTPUTDIR))
|
JDK_OUTPUTDIR := $(patsubst $(BUILD_OUTPUT)%,$(BUILDJDK_OUTPUTDIR)%,$(JDK_OUTPUTDIR))
|
||||||
|
IMAGES_OUTPUTDIR := $(patsubst $(BUILD_OUTPUT)%,$(BUILDJDK_OUTPUTDIR)%,$(IMAGES_OUTPUTDIR))
|
||||||
|
|
||||||
OPENJDK_BUILD_CPU_LEGACY := @OPENJDK_BUILD_CPU_LEGACY@
|
OPENJDK_BUILD_CPU_LEGACY := @OPENJDK_BUILD_CPU_LEGACY@
|
||||||
OPENJDK_BUILD_CPU_LEGACY_LIB := @OPENJDK_BUILD_CPU_LEGACY_LIB@
|
OPENJDK_BUILD_CPU_LEGACY_LIB := @OPENJDK_BUILD_CPU_LEGACY_LIB@
|
||||||
|
@ -896,8 +896,11 @@ JAXWS_TOPDIR
|
|||||||
JAXP_TOPDIR
|
JAXP_TOPDIR
|
||||||
CORBA_TOPDIR
|
CORBA_TOPDIR
|
||||||
LANGTOOLS_TOPDIR
|
LANGTOOLS_TOPDIR
|
||||||
|
EXTERNAL_BUILDJDK
|
||||||
BUILD_JDK
|
BUILD_JDK
|
||||||
CREATE_BUILDJDK
|
CREATE_BUILDJDK
|
||||||
|
JLINK
|
||||||
|
JMOD
|
||||||
BOOT_JDK_BITS
|
BOOT_JDK_BITS
|
||||||
JAVAC_FLAGS
|
JAVAC_FLAGS
|
||||||
BOOT_JDK_MODULAR
|
BOOT_JDK_MODULAR
|
||||||
@ -5070,7 +5073,7 @@ VS_SDK_PLATFORM_NAME_2013=
|
|||||||
#CUSTOM_AUTOCONF_INCLUDE
|
#CUSTOM_AUTOCONF_INCLUDE
|
||||||
|
|
||||||
# Do not change or remove the following line, it is needed for consistency checks:
|
# Do not change or remove the following line, it is needed for consistency checks:
|
||||||
DATE_WHEN_GENERATED=1462204427
|
DATE_WHEN_GENERATED=1462806878
|
||||||
|
|
||||||
###############################################################################
|
###############################################################################
|
||||||
#
|
#
|
||||||
@ -30171,7 +30174,8 @@ if test "${with_build_jdk+set}" = set; then :
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
CREATE_BUILDJDK_FOR_HOST=false
|
CREATE_BUILDJDK=false
|
||||||
|
EXTERNAL_BUILDJDK=false
|
||||||
BUILD_JDK_FOUND="no"
|
BUILD_JDK_FOUND="no"
|
||||||
if test "x$with_build_jdk" != "x"; then
|
if test "x$with_build_jdk" != "x"; then
|
||||||
|
|
||||||
@ -30196,6 +30200,10 @@ $as_echo "$as_me: Potential Build JDK found at $BUILD_JDK did not contain bin/ja
|
|||||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: Potential Build JDK found at $BUILD_JDK did not contain bin/jlink; ignoring" >&5
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: Potential Build JDK found at $BUILD_JDK did not contain bin/jlink; ignoring" >&5
|
||||||
$as_echo "$as_me: Potential Build JDK found at $BUILD_JDK did not contain bin/jlink; ignoring" >&6;}
|
$as_echo "$as_me: Potential Build JDK found at $BUILD_JDK did not contain bin/jlink; ignoring" >&6;}
|
||||||
BUILD_JDK_FOUND=no
|
BUILD_JDK_FOUND=no
|
||||||
|
elif test ! -x "$BUILD_JDK/bin/jmod"; then
|
||||||
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: Potential Build JDK found at $BUILD_JDK did not contain bin/jmod; ignoring" >&5
|
||||||
|
$as_echo "$as_me: Potential Build JDK found at $BUILD_JDK did not contain bin/jmod; ignoring" >&6;}
|
||||||
|
BUILD_JDK_FOUND=no
|
||||||
elif test ! -x "$BUILD_JDK/bin/javac"; then
|
elif test ! -x "$BUILD_JDK/bin/javac"; then
|
||||||
# Do we have a bin/javac?
|
# Do we have a bin/javac?
|
||||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: Potential Build JDK found at $BUILD_JDK did not contain bin/javac; ignoring" >&5
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: Potential Build JDK found at $BUILD_JDK did not contain bin/javac; ignoring" >&5
|
||||||
@ -30364,6 +30372,7 @@ $as_echo "$BUILD_JDK_VERSION" >&6; }
|
|||||||
fi # end check build jdk found
|
fi # end check build jdk found
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
EXTERNAL_BUILDJDK=true
|
||||||
else
|
else
|
||||||
if test "x$COMPILE_TYPE" = "xcross"; then
|
if test "x$COMPILE_TYPE" = "xcross"; then
|
||||||
BUILD_JDK="\$(BUILDJDK_OUTPUTDIR)/jdk"
|
BUILD_JDK="\$(BUILDJDK_OUTPUTDIR)/jdk"
|
||||||
@ -30383,6 +30392,11 @@ $as_echo "yes, will use output dir" >&6; }
|
|||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
JMOD="$BUILD_JDK/bin/jmod"
|
||||||
|
JLINK="$BUILD_JDK/bin/jlink"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if test "x$BUILD_JDK_FOUND" != "xyes"; then
|
if test "x$BUILD_JDK_FOUND" != "xyes"; then
|
||||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for Build JDK" >&5
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for Build JDK" >&5
|
||||||
$as_echo_n "checking for Build JDK... " >&6; }
|
$as_echo_n "checking for Build JDK... " >&6; }
|
||||||
@ -30395,6 +30409,7 @@ $as_echo "no" >&6; }
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
###############################################################################
|
###############################################################################
|
||||||
#
|
#
|
||||||
# Configure the sources to use. We can add or override individual directories.
|
# Configure the sources to use. We can add or override individual directories.
|
||||||
|
@ -283,6 +283,7 @@ BOOT_JDK:=@BOOT_JDK@
|
|||||||
|
|
||||||
BUILD_JDK:=@BUILD_JDK@
|
BUILD_JDK:=@BUILD_JDK@
|
||||||
CREATE_BUILDJDK:=@CREATE_BUILDJDK@
|
CREATE_BUILDJDK:=@CREATE_BUILDJDK@
|
||||||
|
EXTERNAL_BUILDJDK:=@EXTERNAL_BUILDJDK@
|
||||||
|
|
||||||
# When compiling Java source to be run by the boot jdk
|
# When compiling Java source to be run by the boot jdk
|
||||||
# use these extra flags, eg -source 6 -target 6
|
# use these extra flags, eg -source 6 -target 6
|
||||||
@ -542,6 +543,8 @@ JAVA_CMD:=@JAVA@
|
|||||||
JAVAC_CMD:=@JAVAC@
|
JAVAC_CMD:=@JAVAC@
|
||||||
JAVAH_CMD:=@JAVAH@
|
JAVAH_CMD:=@JAVAH@
|
||||||
JAR_CMD:=@JAR@
|
JAR_CMD:=@JAR@
|
||||||
|
JLINK_CMD := @JLINK@
|
||||||
|
JMOD_CMD := @JMOD@
|
||||||
JARSIGNER_CMD:=@JARSIGNER@
|
JARSIGNER_CMD:=@JARSIGNER@
|
||||||
SJAVAC_SERVER_JAVA_CMD:=@SJAVAC_SERVER_JAVA@
|
SJAVAC_SERVER_JAVA_CMD:=@SJAVAC_SERVER_JAVA@
|
||||||
# These variables are meant to be used. They are defined with = instead of := to make
|
# These variables are meant to be used. They are defined with = instead of := to make
|
||||||
@ -552,6 +555,8 @@ JAVA_JAVAC=@FIXPATH@ $(JAVA_CMD) $(JAVA_FLAGS_JAVAC) $(JAVA_FLAGS)
|
|||||||
JAVAC=@FIXPATH@ $(JAVAC_CMD)
|
JAVAC=@FIXPATH@ $(JAVAC_CMD)
|
||||||
JAVAH=@FIXPATH@ $(JAVAH_CMD)
|
JAVAH=@FIXPATH@ $(JAVAH_CMD)
|
||||||
JAR=@FIXPATH@ $(JAR_CMD)
|
JAR=@FIXPATH@ $(JAR_CMD)
|
||||||
|
JLINK = @FIXPATH@ $(JLINK_CMD) $(JAVA_TOOL_FLAGS_SMALL)
|
||||||
|
JMOD = @FIXPATH@ $(JMOD_CMD) $(JAVA_TOOL_FLAGS_SMALL)
|
||||||
JARSIGNER=@FIXPATH@ $(JARSIGNER_CMD)
|
JARSIGNER=@FIXPATH@ $(JARSIGNER_CMD)
|
||||||
# A specific java binary with specific options can be used to run
|
# A specific java binary with specific options can be used to run
|
||||||
# the long running background sjavac servers and other long running tasks.
|
# the long running background sjavac servers and other long running tasks.
|
||||||
@ -569,14 +574,15 @@ BUILD_JAVA=@FIXPATH@ $(BUILD_JDK)/bin/java $(BUILD_JAVA_FLAGS)
|
|||||||
# Use ?= as this can be overridden from bootcycle-spec.gmk
|
# Use ?= as this can be overridden from bootcycle-spec.gmk
|
||||||
BOOT_JDK_MODULAR ?= @BOOT_JDK_MODULAR@
|
BOOT_JDK_MODULAR ?= @BOOT_JDK_MODULAR@
|
||||||
|
|
||||||
|
INTERIM_OVERRIDE_MODULES := java.compiler jdk.compiler \
|
||||||
|
jdk.jdeps jdk.javadoc jdk.rmic
|
||||||
ifeq ($(BOOT_JDK_MODULAR), true)
|
ifeq ($(BOOT_JDK_MODULAR), true)
|
||||||
INTERIM_OVERRIDE_MODULES_ARGS = -Xpatch:$(BUILDTOOLS_OUTPUTDIR)/override_modules
|
INTERIM_OVERRIDE_MODULES_ARGS = $(foreach m, $(INTERIM_OVERRIDE_MODULES), \
|
||||||
|
-Xpatch:$m=$(BUILDTOOLS_OUTPUTDIR)/override_modules/$m)
|
||||||
INTERIM_LANGTOOLS_ARGS = $(INTERIM_OVERRIDE_MODULES_ARGS)
|
INTERIM_LANGTOOLS_ARGS = $(INTERIM_OVERRIDE_MODULES_ARGS)
|
||||||
JAVAC_MAIN_CLASS = -m jdk.compiler/com.sun.tools.javac.Main
|
JAVAC_MAIN_CLASS = -m jdk.compiler/com.sun.tools.javac.Main
|
||||||
JAVADOC_MAIN_CLASS = -m jdk.javadoc/jdk.javadoc.internal.tool.Main
|
JAVADOC_MAIN_CLASS = -m jdk.javadoc/jdk.javadoc.internal.tool.Main
|
||||||
else
|
else
|
||||||
INTERIM_OVERRIDE_MODULES := java.compiler jdk.compiler \
|
|
||||||
jdk.jdeps jdk.javadoc jdk.rmic
|
|
||||||
INTERIM_OVERRIDE_MODULES_ARGS = \
|
INTERIM_OVERRIDE_MODULES_ARGS = \
|
||||||
-Xbootclasspath/p:$(call PathList, \
|
-Xbootclasspath/p:$(call PathList, \
|
||||||
$(addprefix $(BUILDTOOLS_OUTPUTDIR)/override_modules/, \
|
$(addprefix $(BUILDTOOLS_OUTPUTDIR)/override_modules/, \
|
||||||
@ -591,12 +597,8 @@ endif
|
|||||||
NEW_JAVAC = $(INTERIM_LANGTOOLS_ARGS) $(JAVAC_MAIN_CLASS)
|
NEW_JAVAC = $(INTERIM_LANGTOOLS_ARGS) $(JAVAC_MAIN_CLASS)
|
||||||
NEW_JAVADOC = $(INTERIM_LANGTOOLS_ARGS) $(JAVADOC_MAIN_CLASS)
|
NEW_JAVADOC = $(INTERIM_LANGTOOLS_ARGS) $(JAVADOC_MAIN_CLASS)
|
||||||
|
|
||||||
# JLink/Jmod are run using the BUILD_JDK, which is normally the jdk output dir.
|
|
||||||
JLINK_KEEP_PACKAGED_MODULES:=@JLINK_KEEP_PACKAGED_MODULES@
|
JLINK_KEEP_PACKAGED_MODULES:=@JLINK_KEEP_PACKAGED_MODULES@
|
||||||
|
|
||||||
JLINK = @FIXPATH@ $(BUILD_JDK)/bin/jlink $(JAVA_TOOL_FLAGS_SMALL)
|
|
||||||
JMOD = @FIXPATH@ $(BUILD_JDK)/bin/jmod $(JAVA_TOOL_FLAGS_SMALL)
|
|
||||||
|
|
||||||
# Base flags for RC
|
# Base flags for RC
|
||||||
# Guarding this against resetting value. Legacy make files include spec multiple
|
# Guarding this against resetting value. Legacy make files include spec multiple
|
||||||
# times.
|
# times.
|
||||||
@ -776,6 +778,9 @@ TEST_IMAGE_DIR=$(IMAGES_OUTPUTDIR)/$(TEST_IMAGE_SUBDIR)
|
|||||||
SYMBOLS_IMAGE_SUBDIR:=symbols
|
SYMBOLS_IMAGE_SUBDIR:=symbols
|
||||||
SYMBOLS_IMAGE_DIR=$(IMAGES_OUTPUTDIR)/$(SYMBOLS_IMAGE_SUBDIR)
|
SYMBOLS_IMAGE_DIR=$(IMAGES_OUTPUTDIR)/$(SYMBOLS_IMAGE_SUBDIR)
|
||||||
|
|
||||||
|
# Interim image
|
||||||
|
INTERIM_IMAGE_DIR := $(SUPPORT_OUTPUTDIR)/interim-image
|
||||||
|
|
||||||
# Macosx bundles directory definitions
|
# Macosx bundles directory definitions
|
||||||
JDK_MACOSX_BUNDLE_SUBDIR=jdk-bundle/jdk-$(VERSION_NUMBER).jdk/Contents
|
JDK_MACOSX_BUNDLE_SUBDIR=jdk-bundle/jdk-$(VERSION_NUMBER).jdk/Contents
|
||||||
JRE_MACOSX_BUNDLE_SUBDIR=jre-bundle/jre-$(VERSION_NUMBER).jre/Contents
|
JRE_MACOSX_BUNDLE_SUBDIR=jre-bundle/jre-$(VERSION_NUMBER).jre/Contents
|
||||||
|
@ -404,7 +404,7 @@ var getJibProfilesDependencies = function (input, common) {
|
|||||||
jtreg: {
|
jtreg: {
|
||||||
server: "javare",
|
server: "javare",
|
||||||
revision: "4.2",
|
revision: "4.2",
|
||||||
build_number: "b01",
|
build_number: "b02",
|
||||||
checksum_file: "MD5_VALUES",
|
checksum_file: "MD5_VALUES",
|
||||||
file: "jtreg_bin-4.2.zip",
|
file: "jtreg_bin-4.2.zip",
|
||||||
environment_name: "JT_HOME"
|
environment_name: "JT_HOME"
|
||||||
|
@ -519,3 +519,4 @@ c569f8d89269fb6205b90f727581eb8cc04132f9 jdk-9+113
|
|||||||
b64432bae5271735fd53300b2005b713e98ef411 jdk-9+114
|
b64432bae5271735fd53300b2005b713e98ef411 jdk-9+114
|
||||||
88dd08d7be0fe7fb9f1914b1628f0aae9bf56e25 jdk-9+115
|
88dd08d7be0fe7fb9f1914b1628f0aae9bf56e25 jdk-9+115
|
||||||
61a214186dae6811dd989e9165e42f7dbf02acde jdk-9+116
|
61a214186dae6811dd989e9165e42f7dbf02acde jdk-9+116
|
||||||
|
88170d3642905b9e6cac03e8efcc976885a7e6da jdk-9+117
|
||||||
|
@ -140,6 +140,7 @@ PerfCounter* ClassLoader::_unsafe_defineClassCallCounter = NULL;
|
|||||||
PerfCounter* ClassLoader::_isUnsyncloadClass = NULL;
|
PerfCounter* ClassLoader::_isUnsyncloadClass = NULL;
|
||||||
PerfCounter* ClassLoader::_load_instance_class_failCounter = NULL;
|
PerfCounter* ClassLoader::_load_instance_class_failCounter = NULL;
|
||||||
|
|
||||||
|
GrowableArray<ModuleClassPathList*>* ClassLoader::_xpatch_entries = NULL;
|
||||||
ClassPathEntry* ClassLoader::_first_entry = NULL;
|
ClassPathEntry* ClassLoader::_first_entry = NULL;
|
||||||
ClassPathEntry* ClassLoader::_last_entry = NULL;
|
ClassPathEntry* ClassLoader::_last_entry = NULL;
|
||||||
int ClassLoader::_num_entries = 0;
|
int ClassLoader::_num_entries = 0;
|
||||||
@ -179,6 +180,44 @@ bool ClassLoader::string_ends_with(const char* str, const char* str_to_find) {
|
|||||||
return (strncmp(str + (str_len - str_to_find_len), str_to_find, str_to_find_len) == 0);
|
return (strncmp(str + (str_len - str_to_find_len), str_to_find, str_to_find_len) == 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Used to obtain the package name from a fully qualified class name.
|
||||||
|
// It is the responsibility of the caller to establish ResourceMark.
|
||||||
|
const char* ClassLoader::package_from_name(const char* class_name) {
|
||||||
|
const char* last_slash = strrchr(class_name, '/');
|
||||||
|
if (last_slash == NULL) {
|
||||||
|
// No package name
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
int length = last_slash - class_name;
|
||||||
|
|
||||||
|
// A class name could have just the slash character in the name,
|
||||||
|
// resulting in a negative length.
|
||||||
|
if (length <= 0) {
|
||||||
|
// No package name
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
// drop name after last slash (including slash)
|
||||||
|
// Ex., "java/lang/String.class" => "java/lang"
|
||||||
|
char* pkg_name = NEW_RESOURCE_ARRAY(char, length + 1);
|
||||||
|
strncpy(pkg_name, class_name, length);
|
||||||
|
*(pkg_name+length) = '\0';
|
||||||
|
|
||||||
|
return (const char *)pkg_name;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Given a fully qualified class name, find its defining package in the class loader's
|
||||||
|
// package entry table.
|
||||||
|
static PackageEntry* get_package_entry(const char* class_name, ClassLoaderData* loader_data, TRAPS) {
|
||||||
|
ResourceMark rm(THREAD);
|
||||||
|
const char *pkg_name = ClassLoader::package_from_name(class_name);
|
||||||
|
if (pkg_name == NULL) {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
PackageEntryTable* pkgEntryTable = loader_data->packages();
|
||||||
|
TempNewSymbol pkg_symbol = SymbolTable::new_symbol(pkg_name, CHECK_NULL);
|
||||||
|
return pkgEntryTable->lookup_only(pkg_symbol);
|
||||||
|
}
|
||||||
|
|
||||||
ClassPathDirEntry::ClassPathDirEntry(const char* dir) : ClassPathEntry() {
|
ClassPathDirEntry::ClassPathDirEntry(const char* dir) : ClassPathEntry() {
|
||||||
char* copy = NEW_C_HEAP_ARRAY(char, strlen(dir)+1, mtClass);
|
char* copy = NEW_C_HEAP_ARRAY(char, strlen(dir)+1, mtClass);
|
||||||
@ -281,8 +320,7 @@ u1* ClassPathZipEntry::open_entry(const char* name, jint* filesize, bool nul_ter
|
|||||||
#if INCLUDE_CDS
|
#if INCLUDE_CDS
|
||||||
u1* ClassPathZipEntry::open_versioned_entry(const char* name, jint* filesize, TRAPS) {
|
u1* ClassPathZipEntry::open_versioned_entry(const char* name, jint* filesize, TRAPS) {
|
||||||
u1* buffer = NULL;
|
u1* buffer = NULL;
|
||||||
if (!_is_boot_append) {
|
if (DumpSharedSpaces) {
|
||||||
assert(DumpSharedSpaces, "Should be called only for non-boot entries during dump time");
|
|
||||||
// We presume default is multi-release enabled
|
// We presume default is multi-release enabled
|
||||||
const char* multi_ver = Arguments::get_property("jdk.util.jar.enableMultiRelease");
|
const char* multi_ver = Arguments::get_property("jdk.util.jar.enableMultiRelease");
|
||||||
const char* verstr = Arguments::get_property("jdk.util.jar.version");
|
const char* verstr = Arguments::get_property("jdk.util.jar.version");
|
||||||
@ -402,31 +440,6 @@ ClassPathImageEntry::~ClassPathImageEntry() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void ClassPathImageEntry::name_to_package(const char* name, char* buffer, int length) {
|
|
||||||
const char *pslash = strrchr(name, '/');
|
|
||||||
if (pslash == NULL) {
|
|
||||||
buffer[0] = '\0';
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
int len = pslash - name;
|
|
||||||
#if INCLUDE_CDS
|
|
||||||
if (len <= 0 && DumpSharedSpaces) {
|
|
||||||
buffer[0] = '\0';
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
assert(len > 0, "Bad length for package name");
|
|
||||||
if (len >= length) {
|
|
||||||
buffer[0] = '\0';
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
// drop name after last slash (including slash)
|
|
||||||
// Ex., "java/lang/String.class" => "java/lang"
|
|
||||||
strncpy(buffer, name, len);
|
|
||||||
// ensure string termination (strncpy does not guarantee)
|
|
||||||
buffer[len] = '\0';
|
|
||||||
}
|
|
||||||
|
|
||||||
// For a class in a named module, look it up in the jimage file using this syntax:
|
// For a class in a named module, look it up in the jimage file using this syntax:
|
||||||
// /<module-name>/<package-name>/<base-class>
|
// /<module-name>/<package-name>/<base-class>
|
||||||
//
|
//
|
||||||
@ -439,15 +452,10 @@ ClassFileStream* ClassPathImageEntry::open_stream(const char* name, TRAPS) {
|
|||||||
JImageLocationRef location = (*JImageFindResource)(_jimage, "", get_jimage_version_string(), name, &size);
|
JImageLocationRef location = (*JImageFindResource)(_jimage, "", get_jimage_version_string(), name, &size);
|
||||||
|
|
||||||
if (location == 0) {
|
if (location == 0) {
|
||||||
char package[JIMAGE_MAX_PATH];
|
ResourceMark rm;
|
||||||
name_to_package(name, package, JIMAGE_MAX_PATH);
|
const char* pkg_name = ClassLoader::package_from_name(name);
|
||||||
|
|
||||||
#if INCLUDE_CDS
|
if (pkg_name != NULL) {
|
||||||
if (package[0] == '\0' && DumpSharedSpaces) {
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
if (package[0] != '\0') {
|
|
||||||
if (!Universe::is_module_initialized()) {
|
if (!Universe::is_module_initialized()) {
|
||||||
location = (*JImageFindResource)(_jimage, "java.base", get_jimage_version_string(), name, &size);
|
location = (*JImageFindResource)(_jimage, "java.base", get_jimage_version_string(), name, &size);
|
||||||
#if INCLUDE_CDS
|
#if INCLUDE_CDS
|
||||||
@ -455,7 +463,7 @@ ClassFileStream* ClassPathImageEntry::open_stream(const char* name, TRAPS) {
|
|||||||
// modules defined for other class loaders. So, for now, get their module
|
// modules defined for other class loaders. So, for now, get their module
|
||||||
// names from the "modules" jimage file.
|
// names from the "modules" jimage file.
|
||||||
if (DumpSharedSpaces && location == 0) {
|
if (DumpSharedSpaces && location == 0) {
|
||||||
const char* module_name = (*JImagePackageToModule)(_jimage, package);
|
const char* module_name = (*JImagePackageToModule)(_jimage, pkg_name);
|
||||||
if (module_name != NULL) {
|
if (module_name != NULL) {
|
||||||
location = (*JImageFindResource)(_jimage, module_name, get_jimage_version_string(), name, &size);
|
location = (*JImageFindResource)(_jimage, module_name, get_jimage_version_string(), name, &size);
|
||||||
}
|
}
|
||||||
@ -463,13 +471,7 @@ ClassFileStream* ClassPathImageEntry::open_stream(const char* name, TRAPS) {
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
// Get boot class loader's package entry table
|
PackageEntry* package_entry = get_package_entry(name, ClassLoaderData::the_null_class_loader_data(), THREAD);
|
||||||
PackageEntryTable* pkgEntryTable =
|
|
||||||
ClassLoaderData::the_null_class_loader_data()->packages();
|
|
||||||
// Get package's package entry
|
|
||||||
TempNewSymbol pkg_symbol = SymbolTable::new_symbol(package, CHECK_NULL);
|
|
||||||
PackageEntry* package_entry = pkgEntryTable->lookup_only(pkg_symbol);
|
|
||||||
|
|
||||||
if (package_entry != NULL) {
|
if (package_entry != NULL) {
|
||||||
ResourceMark rm;
|
ResourceMark rm;
|
||||||
// Get the module name
|
// Get the module name
|
||||||
@ -542,6 +544,33 @@ void ClassLoader::exit_with_path_failure(const char* error, const char* message)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
ModuleClassPathList::ModuleClassPathList(Symbol* module_name) {
|
||||||
|
_module_name = module_name;
|
||||||
|
_module_first_entry = NULL;
|
||||||
|
_module_last_entry = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
ModuleClassPathList::~ModuleClassPathList() {
|
||||||
|
// Clean out each ClassPathEntry on list
|
||||||
|
ClassPathEntry* e = _module_first_entry;
|
||||||
|
while (e != NULL) {
|
||||||
|
ClassPathEntry* next_entry = e->next();
|
||||||
|
delete e;
|
||||||
|
e = next_entry;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void ModuleClassPathList::add_to_list(ClassPathEntry* new_entry) {
|
||||||
|
if (new_entry != NULL) {
|
||||||
|
if (_module_last_entry == NULL) {
|
||||||
|
_module_first_entry = _module_last_entry = new_entry;
|
||||||
|
} else {
|
||||||
|
_module_last_entry->set_next(new_entry);
|
||||||
|
_module_last_entry = new_entry;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void ClassLoader::trace_class_path(const char* msg, const char* name) {
|
void ClassLoader::trace_class_path(const char* msg, const char* name) {
|
||||||
if (log_is_enabled(Info, classpath)) {
|
if (log_is_enabled(Info, classpath)) {
|
||||||
ResourceMark rm;
|
ResourceMark rm;
|
||||||
@ -619,6 +648,61 @@ bool ClassLoader::check_shared_paths_misc_info(void *buf, int size) {
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
// Construct the array of module/path pairs as specified to -Xpatch
|
||||||
|
// for the boot loader to search ahead of the jimage, if the class being
|
||||||
|
// loaded is defined to a module that has been specified to -Xpatch.
|
||||||
|
void ClassLoader::setup_xpatch_entries() {
|
||||||
|
Thread* THREAD = Thread::current();
|
||||||
|
GrowableArray<ModuleXPatchPath*>* xpatch_args = Arguments::get_xpatchprefix();
|
||||||
|
int num_of_entries = xpatch_args->length();
|
||||||
|
|
||||||
|
// Set up the boot loader's xpatch_entries list
|
||||||
|
_xpatch_entries = new (ResourceObj::C_HEAP, mtInternal) GrowableArray<ModuleClassPathList*>(num_of_entries, true);
|
||||||
|
|
||||||
|
for (int i = 0; i < num_of_entries; i++) {
|
||||||
|
const char* module_name = (xpatch_args->at(i))->module_name();
|
||||||
|
Symbol* const module_sym = SymbolTable::lookup(module_name, (int)strlen(module_name), CHECK);
|
||||||
|
assert(module_sym != NULL, "Failed to obtain Symbol for module name");
|
||||||
|
ModuleClassPathList* module_cpl = new ModuleClassPathList(module_sym);
|
||||||
|
|
||||||
|
char* class_path = (xpatch_args->at(i))->path_string();
|
||||||
|
int len = (int)strlen(class_path);
|
||||||
|
int end = 0;
|
||||||
|
// Iterate over the module's class path entries
|
||||||
|
for (int start = 0; start < len; start = end) {
|
||||||
|
while (class_path[end] && class_path[end] != os::path_separator()[0]) {
|
||||||
|
end++;
|
||||||
|
}
|
||||||
|
EXCEPTION_MARK;
|
||||||
|
ResourceMark rm(THREAD);
|
||||||
|
char* path = NEW_RESOURCE_ARRAY(char, end - start + 1);
|
||||||
|
strncpy(path, &class_path[start], end - start);
|
||||||
|
path[end - start] = '\0';
|
||||||
|
|
||||||
|
struct stat st;
|
||||||
|
if (os::stat(path, &st) == 0) {
|
||||||
|
// File or directory found
|
||||||
|
Thread* THREAD = Thread::current();
|
||||||
|
ClassPathEntry* new_entry = create_class_path_entry(path, &st, false, false, CHECK);
|
||||||
|
// If the path specification is valid, enter it into this module's list
|
||||||
|
if (new_entry != NULL) {
|
||||||
|
module_cpl->add_to_list(new_entry);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
while (class_path[end] == os::path_separator()[0]) {
|
||||||
|
end++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Record the module into the list of -Xpatch entries only if
|
||||||
|
// valid ClassPathEntrys have been created
|
||||||
|
if (module_cpl->module_first_entry() != NULL) {
|
||||||
|
_xpatch_entries->push(module_cpl);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void ClassLoader::setup_search_path(const char *class_path, bool bootstrap_search) {
|
void ClassLoader::setup_search_path(const char *class_path, bool bootstrap_search) {
|
||||||
int offset = 0;
|
int offset = 0;
|
||||||
int len = (int)strlen(class_path);
|
int len = (int)strlen(class_path);
|
||||||
@ -850,8 +934,29 @@ bool ClassLoader::update_class_path_entry_list(const char *path,
|
|||||||
}
|
}
|
||||||
|
|
||||||
void ClassLoader::print_bootclasspath() {
|
void ClassLoader::print_bootclasspath() {
|
||||||
ClassPathEntry* e = _first_entry;
|
ClassPathEntry* e;
|
||||||
tty->print("[bootclasspath= ");
|
tty->print("[bootclasspath= ");
|
||||||
|
|
||||||
|
// Print -Xpatch module/path specifications first
|
||||||
|
if (_xpatch_entries != NULL) {
|
||||||
|
ResourceMark rm;
|
||||||
|
int num_of_entries = _xpatch_entries->length();
|
||||||
|
for (int i = 0; i < num_of_entries; i++) {
|
||||||
|
ModuleClassPathList* mpl = _xpatch_entries->at(i);
|
||||||
|
tty->print("%s=", mpl->module_name()->as_C_string());
|
||||||
|
e = mpl->module_first_entry();
|
||||||
|
while (e != NULL) {
|
||||||
|
tty->print("%s", e->name());
|
||||||
|
e = e->next();
|
||||||
|
if (e != NULL) {
|
||||||
|
tty->print("%s", os::path_separator());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
tty->print(" ;");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
e = _first_entry;
|
||||||
while (e != NULL) {
|
while (e != NULL) {
|
||||||
tty->print("%s ;", e->name());
|
tty->print("%s ;", e->name());
|
||||||
e = e->next();
|
e = e->next();
|
||||||
@ -941,6 +1046,7 @@ int ClassLoader::crc32(int crc, const char* buf, int len) {
|
|||||||
|
|
||||||
#if INCLUDE_CDS
|
#if INCLUDE_CDS
|
||||||
void ClassLoader::initialize_module_loader_map(JImageFile* jimage) {
|
void ClassLoader::initialize_module_loader_map(JImageFile* jimage) {
|
||||||
|
ResourceMark rm;
|
||||||
jlong size;
|
jlong size;
|
||||||
JImageLocationRef location = (*JImageFindResource)(jimage, "java.base", get_jimage_version_string(), MODULE_LOADER_MAP, &size);
|
JImageLocationRef location = (*JImageFindResource)(jimage, "java.base", get_jimage_version_string(), MODULE_LOADER_MAP, &size);
|
||||||
if (location == 0) {
|
if (location == 0) {
|
||||||
@ -985,7 +1091,6 @@ void ClassLoader::initialize_module_loader_map(JImageFile* jimage) {
|
|||||||
begin_ptr = ++end_ptr;
|
begin_ptr = ++end_ptr;
|
||||||
end_ptr = strchr(begin_ptr, '\n');
|
end_ptr = strchr(begin_ptr, '\n');
|
||||||
}
|
}
|
||||||
FREE_RESOURCE_ARRAY(u1, buffer, size);
|
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -1106,8 +1211,7 @@ s2 ClassLoader::module_to_classloader(const char* module_name) {
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
s2 ClassLoader::classloader_type(Symbol* class_name, ClassPathEntry* e,
|
s2 ClassLoader::classloader_type(Symbol* class_name, ClassPathEntry* e, int classpath_index, TRAPS) {
|
||||||
int classpath_index, TRAPS) {
|
|
||||||
#if INCLUDE_CDS
|
#if INCLUDE_CDS
|
||||||
// obtain the classloader type based on the class name.
|
// obtain the classloader type based on the class name.
|
||||||
// First obtain the package name based on the class name. Then obtain
|
// First obtain the package name based on the class name. Then obtain
|
||||||
@ -1157,12 +1261,11 @@ const char* ClassLoader::file_name_for_class_name(const char* class_name,
|
|||||||
}
|
}
|
||||||
|
|
||||||
instanceKlassHandle ClassLoader::load_class(Symbol* name, bool search_append_only, TRAPS) {
|
instanceKlassHandle ClassLoader::load_class(Symbol* name, bool search_append_only, TRAPS) {
|
||||||
|
|
||||||
assert(name != NULL, "invariant");
|
assert(name != NULL, "invariant");
|
||||||
assert(THREAD->is_Java_thread(), "must be a JavaThread");
|
assert(THREAD->is_Java_thread(), "must be a JavaThread");
|
||||||
|
|
||||||
ResourceMark rm;
|
ResourceMark rm(THREAD);
|
||||||
HandleMark hm;
|
HandleMark hm(THREAD);
|
||||||
|
|
||||||
const char* const class_name = name->as_C_string();
|
const char* const class_name = name->as_C_string();
|
||||||
|
|
||||||
@ -1178,30 +1281,101 @@ instanceKlassHandle ClassLoader::load_class(Symbol* name, bool search_append_onl
|
|||||||
// Lookup stream for parsing .class file
|
// Lookup stream for parsing .class file
|
||||||
ClassFileStream* stream = NULL;
|
ClassFileStream* stream = NULL;
|
||||||
s2 classpath_index = 0;
|
s2 classpath_index = 0;
|
||||||
|
ClassPathEntry* e = NULL;
|
||||||
|
|
||||||
// If DumpSharedSpaces is true, boot loader visibility boundaries are set
|
// If DumpSharedSpaces is true, boot loader visibility boundaries are set
|
||||||
// to be _first_entry to the end (all path entries).
|
// to be _first_entry to the end (all path entries). No -Xpatch entries are
|
||||||
|
// included since CDS and AppCDS are not supported if -Xpatch is specified.
|
||||||
//
|
//
|
||||||
// If search_append_only is true, boot loader visibility boundaries are
|
// If search_append_only is true, boot loader visibility boundaries are
|
||||||
// set to be _fist_append_entry to the end. This includes:
|
// set to be _first_append_entry to the end. This includes:
|
||||||
// [-Xbootclasspath/a]; [jvmti appended entries]
|
// [-Xbootclasspath/a]; [jvmti appended entries]
|
||||||
//
|
//
|
||||||
// If both DumpSharedSpaces and search_append_only are false, boot loader
|
// If both DumpSharedSpaces and search_append_only are false, boot loader
|
||||||
// visibility boundaries are set to be _first_entry to the entry before
|
// visibility boundaries are set to be _first_entry to the entry before
|
||||||
// the _first_append_entry. This would include:
|
// the _first_append_entry. This would include:
|
||||||
// [-Xpatch:<dirs>]; [exploded build | modules]
|
// [-Xpatch:<module>=<file>(<pathsep><file>)*]; [exploded build | jimage]
|
||||||
//
|
//
|
||||||
// DumpSharedSpaces and search_append_only are mutually exclusive and cannot
|
// DumpSharedSpaces and search_append_only are mutually exclusive and cannot
|
||||||
// be true at the same time.
|
// be true at the same time.
|
||||||
ClassPathEntry* e = (search_append_only ? _first_append_entry : _first_entry);
|
assert(!(DumpSharedSpaces && search_append_only), "DumpSharedSpaces and search_append_only are both true");
|
||||||
ClassPathEntry* last_e =
|
|
||||||
(search_append_only || DumpSharedSpaces ? NULL : _first_append_entry);
|
|
||||||
|
|
||||||
{
|
// Load Attempt #1: -Xpatch
|
||||||
if (search_append_only) {
|
// Determine the class' defining module. If it appears in the _xpatch_entries,
|
||||||
|
// attempt to load the class from those locations specific to the module.
|
||||||
|
// Note: The -Xpatch entries are never searched if the boot loader's
|
||||||
|
// visibility boundary is limited to only searching the append entries.
|
||||||
|
if (_xpatch_entries != NULL && !search_append_only && !DumpSharedSpaces) {
|
||||||
|
// Find the module in the boot loader's module entry table
|
||||||
|
PackageEntry* pkg_entry = get_package_entry(class_name, ClassLoaderData::the_null_class_loader_data(), THREAD);
|
||||||
|
ModuleEntry* mod_entry = (pkg_entry != NULL) ? pkg_entry->module() : NULL;
|
||||||
|
|
||||||
|
// If the module system has not defined java.base yet, then
|
||||||
|
// classes loaded are assumed to be defined to java.base.
|
||||||
|
// When java.base is eventually defined by the module system,
|
||||||
|
// all packages of classes that have been previously loaded
|
||||||
|
// are verified in ModuleEntryTable::verify_javabase_packages().
|
||||||
|
if (!Universe::is_module_initialized() &&
|
||||||
|
!ModuleEntryTable::javabase_defined() &&
|
||||||
|
mod_entry == NULL) {
|
||||||
|
mod_entry = ModuleEntryTable::javabase_module();
|
||||||
|
}
|
||||||
|
|
||||||
|
// The module must be a named module
|
||||||
|
if (mod_entry != NULL && mod_entry->is_named()) {
|
||||||
|
int num_of_entries = _xpatch_entries->length();
|
||||||
|
const Symbol* class_module_name = mod_entry->name();
|
||||||
|
|
||||||
|
// Loop through all the xpatch entries looking for module
|
||||||
|
for (int i = 0; i < num_of_entries; i++) {
|
||||||
|
ModuleClassPathList* module_cpl = _xpatch_entries->at(i);
|
||||||
|
Symbol* module_cpl_name = module_cpl->module_name();
|
||||||
|
|
||||||
|
if (module_cpl_name->fast_compare(class_module_name) == 0) {
|
||||||
|
// Class' module has been located, attempt to load
|
||||||
|
// the class from the module's ClassPathEntry list.
|
||||||
|
e = module_cpl->module_first_entry();
|
||||||
|
while (e != NULL) {
|
||||||
|
stream = e->open_stream(file_name, CHECK_NULL);
|
||||||
|
// No context.check is required since both CDS
|
||||||
|
// and AppCDS are turned off if -Xpatch is specified.
|
||||||
|
if (NULL != stream) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
e = e->next();
|
||||||
|
}
|
||||||
|
// If the module was located in the xpatch entries, break out
|
||||||
|
// even if the class was not located successfully from that module's
|
||||||
|
// ClassPathEntry list. There will not be another valid entry for
|
||||||
|
// that module in the _xpatch_entries array.
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Load Attempt #2: [exploded build | jimage]
|
||||||
|
if (!search_append_only && (NULL == stream)) {
|
||||||
|
e = _first_entry;
|
||||||
|
while ((e != NULL) && (e != _first_append_entry)) {
|
||||||
|
stream = e->open_stream(file_name, CHECK_NULL);
|
||||||
|
if (!context.check(stream, classpath_index)) {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
if (NULL != stream) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
e = e->next();
|
||||||
|
++classpath_index;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Load Attempt #3: [-Xbootclasspath/a]; [jvmti appended entries]
|
||||||
|
if ((search_append_only || DumpSharedSpaces) && (NULL == stream)) {
|
||||||
// For the boot loader append path search, must calculate
|
// For the boot loader append path search, must calculate
|
||||||
// the starting classpath_index prior to attempting to
|
// the starting classpath_index prior to attempting to
|
||||||
// load the classfile.
|
// load the classfile.
|
||||||
|
if (search_append_only) {
|
||||||
ClassPathEntry *tmp_e = _first_entry;
|
ClassPathEntry *tmp_e = _first_entry;
|
||||||
while ((tmp_e != NULL) && (tmp_e != _first_append_entry)) {
|
while ((tmp_e != NULL) && (tmp_e != _first_append_entry)) {
|
||||||
tmp_e = tmp_e->next();
|
tmp_e = tmp_e->next();
|
||||||
@ -1209,11 +1383,8 @@ instanceKlassHandle ClassLoader::load_class(Symbol* name, bool search_append_onl
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Attempt to load the classfile from either:
|
e = _first_append_entry;
|
||||||
// - [-Xpatch:dir]; exploded build | modules
|
while (e != NULL) {
|
||||||
// or
|
|
||||||
// - [-Xbootclasspath/a]; [jvmti appended entries]
|
|
||||||
while ((e != NULL) && (e != last_e)) {
|
|
||||||
stream = e->open_stream(file_name, CHECK_NULL);
|
stream = e->open_stream(file_name, CHECK_NULL);
|
||||||
if (!context.check(stream, classpath_index)) {
|
if (!context.check(stream, classpath_index)) {
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -1384,10 +1555,23 @@ int ClassLoader::compute_Object_vtable() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void classLoader_init() {
|
void classLoader_init1() {
|
||||||
ClassLoader::initialize();
|
ClassLoader::initialize();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Complete the ClassPathEntry setup for the boot loader
|
||||||
|
void classLoader_init2() {
|
||||||
|
// Setup the list of module/path pairs for -Xpatch processing
|
||||||
|
// This must be done after the SymbolTable is created in order
|
||||||
|
// to use fast_compare on module names instead of a string compare.
|
||||||
|
if (Arguments::get_xpatchprefix() != NULL) {
|
||||||
|
ClassLoader::setup_xpatch_entries();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Determine if this is an exploded build
|
||||||
|
ClassLoader::set_has_jimage();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
bool ClassLoader::get_canonical_path(const char* orig, char* out, int len) {
|
bool ClassLoader::get_canonical_path(const char* orig, char* out, int len) {
|
||||||
assert(orig != NULL && out != NULL && len > 0, "bad arguments");
|
assert(orig != NULL && out != NULL && len > 0, "bad arguments");
|
||||||
@ -1431,17 +1615,19 @@ void ClassLoader::create_javabase() {
|
|||||||
}
|
}
|
||||||
ModuleEntryTable::set_javabase_module(jb_module);
|
ModuleEntryTable::set_javabase_module(jb_module);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// When looking for the jimage file, only
|
void ClassLoader::set_has_jimage() {
|
||||||
// search the boot loader's module path which
|
// Determine if this is an exploded build. When looking for
|
||||||
// can consist of [-Xpatch]; exploded build | modules
|
// the jimage file, only search the piece of the boot
|
||||||
// Do not search the boot loader's append path.
|
// loader's boot class path which contains [exploded build | jimage].
|
||||||
|
// Do not search the boot loader's xpatch entries or append path.
|
||||||
ClassPathEntry* e = _first_entry;
|
ClassPathEntry* e = _first_entry;
|
||||||
ClassPathEntry* last_e = _first_append_entry;
|
ClassPathEntry* last_e = _first_append_entry;
|
||||||
while ((e != NULL) && (e != last_e)) {
|
while ((e != NULL) && (e != last_e)) {
|
||||||
JImageFile *jimage = e->jimage();
|
JImageFile *jimage = e->jimage();
|
||||||
if (jimage != NULL && e->is_jrt()) {
|
if (jimage != NULL && e->is_jrt()) {
|
||||||
set_has_jimage(true);
|
_has_jimage = true;
|
||||||
#if INCLUDE_CDS
|
#if INCLUDE_CDS
|
||||||
ClassLoader::initialize_module_loader_map(jimage);
|
ClassLoader::initialize_module_loader_map(jimage);
|
||||||
#endif
|
#endif
|
||||||
|
@ -142,13 +142,30 @@ public:
|
|||||||
JImageFile* jimage() const { return _jimage; }
|
JImageFile* jimage() const { return _jimage; }
|
||||||
ClassPathImageEntry(JImageFile* jimage, const char* name);
|
ClassPathImageEntry(JImageFile* jimage, const char* name);
|
||||||
~ClassPathImageEntry();
|
~ClassPathImageEntry();
|
||||||
void name_to_package(const char* name, char* package, int length);
|
|
||||||
ClassFileStream* open_stream(const char* name, TRAPS);
|
ClassFileStream* open_stream(const char* name, TRAPS);
|
||||||
|
|
||||||
// Debugging
|
// Debugging
|
||||||
NOT_PRODUCT(void compile_the_world(Handle loader, TRAPS);)
|
NOT_PRODUCT(void compile_the_world(Handle loader, TRAPS);)
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// ModuleClassPathList contains a linked list of ClassPathEntry's
|
||||||
|
// that have been specified for a specific module. Currently,
|
||||||
|
// the only way to specify a module/path pair is via the -Xpatch
|
||||||
|
// command line option.
|
||||||
|
class ModuleClassPathList : public CHeapObj<mtClass> {
|
||||||
|
private:
|
||||||
|
Symbol* _module_name;
|
||||||
|
// First and last entries of class path entries for a specific module
|
||||||
|
ClassPathEntry* _module_first_entry;
|
||||||
|
ClassPathEntry* _module_last_entry;
|
||||||
|
public:
|
||||||
|
Symbol* module_name() const { return _module_name; }
|
||||||
|
ClassPathEntry* module_first_entry() const { return _module_first_entry; }
|
||||||
|
ModuleClassPathList(Symbol* module_name);
|
||||||
|
~ModuleClassPathList();
|
||||||
|
void add_to_list(ClassPathEntry* new_entry);
|
||||||
|
};
|
||||||
|
|
||||||
class SharedPathsMiscInfo;
|
class SharedPathsMiscInfo;
|
||||||
|
|
||||||
class ClassLoader: AllStatic {
|
class ClassLoader: AllStatic {
|
||||||
@ -195,21 +212,31 @@ class ClassLoader: AllStatic {
|
|||||||
static PerfCounter* _isUnsyncloadClass;
|
static PerfCounter* _isUnsyncloadClass;
|
||||||
static PerfCounter* _load_instance_class_failCounter;
|
static PerfCounter* _load_instance_class_failCounter;
|
||||||
|
|
||||||
// First entry in linked list of ClassPathEntry instances.
|
// The boot class path consists of 3 ordered pieces:
|
||||||
// This consists of entries made up by:
|
// 1. the module/path pairs specified to -Xpatch
|
||||||
// - boot loader modules
|
// -Xpatch:<module>=<file>(<pathsep><file>)*
|
||||||
// [-Xpatch]; exploded build | modules;
|
// 2. the base piece
|
||||||
// - boot loader append path
|
// [exploded build | jimage]
|
||||||
|
// 3. boot loader append path
|
||||||
// [-Xbootclasspath/a]; [jvmti appended entries]
|
// [-Xbootclasspath/a]; [jvmti appended entries]
|
||||||
|
//
|
||||||
|
// The boot loader must obey this order when attempting
|
||||||
|
// to load a class.
|
||||||
|
|
||||||
|
// Contains the module/path pairs specified to -Xpatch
|
||||||
|
static GrowableArray<ModuleClassPathList*>* _xpatch_entries;
|
||||||
|
|
||||||
|
// Contains the ClassPathEntry instances that include
|
||||||
|
// both the base piece and the boot loader append path.
|
||||||
static ClassPathEntry* _first_entry;
|
static ClassPathEntry* _first_entry;
|
||||||
// Last entry in linked list of ClassPathEntry instances
|
// Last entry in linked list of ClassPathEntry instances
|
||||||
static ClassPathEntry* _last_entry;
|
static ClassPathEntry* _last_entry;
|
||||||
static int _num_entries;
|
static int _num_entries;
|
||||||
|
|
||||||
// Pointer into the linked list of ClassPathEntry instances.
|
|
||||||
// Marks the start of:
|
// Marks the start of:
|
||||||
// - the boot loader's append path
|
// - the boot loader's append path
|
||||||
// [-Xbootclasspath/a]; [jvmti appended entries]
|
// [-Xbootclasspath/a]; [jvmti appended entries]
|
||||||
|
// within the linked list of ClassPathEntry instances.
|
||||||
static ClassPathEntry* _first_append_entry;
|
static ClassPathEntry* _first_append_entry;
|
||||||
|
|
||||||
static const char* _shared_archive;
|
static const char* _shared_archive;
|
||||||
@ -325,11 +352,11 @@ class ClassLoader: AllStatic {
|
|||||||
return _load_instance_class_failCounter;
|
return _load_instance_class_failCounter;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Sets _has_jimage to TRUE if "modules" jimage file exists
|
// Set up the module/path pairs as specified to -Xpatch
|
||||||
static void set_has_jimage(bool val) {
|
static void setup_xpatch_entries();
|
||||||
_has_jimage = val;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
// Sets _has_jimage to TRUE if "modules" jimage file exists
|
||||||
|
static void set_has_jimage();
|
||||||
static bool has_jimage() { return _has_jimage; }
|
static bool has_jimage() { return _has_jimage; }
|
||||||
|
|
||||||
// Create the ModuleEntry for java.base
|
// Create the ModuleEntry for java.base
|
||||||
@ -416,6 +443,9 @@ class ClassLoader: AllStatic {
|
|||||||
|
|
||||||
static bool string_ends_with(const char* str, const char* str_to_find);
|
static bool string_ends_with(const char* str, const char* str_to_find);
|
||||||
|
|
||||||
|
// obtain package name from a fully qualified class name
|
||||||
|
static const char* package_from_name(const char* class_name);
|
||||||
|
|
||||||
static bool is_jrt(const char* name) { return string_ends_with(name, MODULES_IMAGE_NAME); }
|
static bool is_jrt(const char* name) { return string_ends_with(name, MODULES_IMAGE_NAME); }
|
||||||
|
|
||||||
// Debugging
|
// Debugging
|
||||||
|
@ -133,68 +133,31 @@ static PackageEntry* get_package_entry_by_name(Symbol* package,
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Check if -Xpatch:<dirs> was specified. If so, prepend each <dir>/module_name,
|
// If using exploded build, append <java.home>/modules/module_name, if it exists,
|
||||||
// if it exists, to bootpath so boot loader can find the class files. Also, if
|
// to the system boot class path in order for the boot loader to locate class files.
|
||||||
// using exploded modules, append <java.home>/modules/module_name, if it exists,
|
static void add_to_exploded_build_list(char *module_name, TRAPS) {
|
||||||
// to bootpath so that its class files can be found by the boot loader.
|
assert(!ClassLoader::has_jimage(), "Exploded build not applicable");
|
||||||
static void add_to_boot_loader_list(char *module_name, TRAPS) {
|
// java.base is handled by os::set_boot_path
|
||||||
// java.base should be handled by argument parsing.
|
|
||||||
assert(strcmp(module_name, "java.base") != 0, "Unexpected java.base module name");
|
assert(strcmp(module_name, "java.base") != 0, "Unexpected java.base module name");
|
||||||
|
|
||||||
char file_sep = os::file_separator()[0];
|
char file_sep = os::file_separator()[0];
|
||||||
size_t module_len = strlen(module_name);
|
size_t module_len = strlen(module_name);
|
||||||
|
|
||||||
// If -Xpatch is set then add <patch-dir>/module_name paths.
|
|
||||||
char** patch_dirs = Arguments::patch_dirs();
|
|
||||||
if (patch_dirs != NULL) {
|
|
||||||
int dir_count = Arguments::patch_dirs_count();
|
|
||||||
for (int x = 0; x < dir_count; x++) {
|
|
||||||
// Really shouldn't be NULL, but check can't hurt
|
|
||||||
if (patch_dirs[x] != NULL) {
|
|
||||||
size_t len = strlen(patch_dirs[x]);
|
|
||||||
if (len != 0) { // Ignore empty strings.
|
|
||||||
len = len + module_len + 2;
|
|
||||||
char* prefix_path = NEW_C_HEAP_ARRAY(char, len, mtInternal);
|
|
||||||
jio_snprintf(prefix_path, len, "%s%c%s", patch_dirs[x], file_sep, module_name);
|
|
||||||
|
|
||||||
// See if Xpatch module path exists.
|
|
||||||
struct stat st;
|
|
||||||
if ((os::stat(prefix_path, &st) != 0)) {
|
|
||||||
FREE_C_HEAP_ARRAY(char, prefix_path);
|
|
||||||
} else {
|
|
||||||
{
|
|
||||||
HandleMark hm;
|
|
||||||
Handle loader_lock = Handle(THREAD, SystemDictionary::system_loader_lock());
|
|
||||||
ObjectLocker ol(loader_lock, THREAD);
|
|
||||||
ClassLoader::prepend_to_list(prefix_path);
|
|
||||||
}
|
|
||||||
log_info(classload)("opened: -Xpatch %s", prefix_path);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// If "modules" jimage does not exist then assume exploded form
|
|
||||||
// ${java.home}/modules/<module-name>
|
|
||||||
char* path = NULL;
|
|
||||||
if (!ClassLoader::has_jimage()) {
|
|
||||||
const char* home = Arguments::get_java_home();
|
const char* home = Arguments::get_java_home();
|
||||||
size_t len = strlen(home) + module_len + 32;
|
size_t len = strlen(home) + module_len + 32;
|
||||||
path = NEW_C_HEAP_ARRAY(char, len, mtInternal);
|
char* path = NEW_C_HEAP_ARRAY(char, len, mtInternal);
|
||||||
jio_snprintf(path, len, "%s%cmodules%c%s", home, file_sep, file_sep, module_name);
|
jio_snprintf(path, len, "%s%cmodules%c%s", home, file_sep, file_sep, module_name);
|
||||||
struct stat st;
|
struct stat st;
|
||||||
// See if exploded module path exists.
|
// See if exploded module path exists
|
||||||
if ((os::stat(path, &st) != 0)) {
|
if ((os::stat(path, &st) != 0)) {
|
||||||
FREE_C_HEAP_ARRAY(char, path);
|
FREE_C_HEAP_ARRAY(char, path);
|
||||||
path = NULL;
|
path = NULL;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
if (path != NULL) {
|
if (path != NULL) {
|
||||||
HandleMark hm;
|
HandleMark hm;
|
||||||
Handle loader_lock = Handle(THREAD, SystemDictionary::system_loader_lock());
|
Handle loader_lock = Handle(THREAD, SystemDictionary::system_loader_lock());
|
||||||
ObjectLocker ol(loader_lock, THREAD);
|
ObjectLocker ol(loader_lock, THREAD);
|
||||||
|
|
||||||
log_info(classload)("opened: %s", path);
|
log_info(classload)("opened: %s", path);
|
||||||
ClassLoader::add_to_list(path);
|
ClassLoader::add_to_list(path);
|
||||||
}
|
}
|
||||||
@ -493,13 +456,12 @@ void Modules::define_module(jobject module, jstring version,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (loader == NULL && !Universe::is_module_initialized()) {
|
// If the module is defined to the boot loader and an exploded build is being
|
||||||
// Now that the module is defined, if it is in the bootloader, make sure that
|
// used, prepend <java.home>/modules/modules_name, if it exists, to the system boot class path.
|
||||||
// its classes can be found. Check if -Xpatch:<path> was specified. If
|
if (loader == NULL &&
|
||||||
// so prepend <path>/module_name, if it exists, to bootpath. Also, if using
|
!Universe::is_module_initialized() &&
|
||||||
// exploded modules, prepend <java.home>/modules/module_name, if it exists,
|
!ClassLoader::has_jimage()) {
|
||||||
// to bootpath.
|
add_to_exploded_build_list(module_name, CHECK);
|
||||||
add_to_boot_loader_list(module_name, CHECK);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -880,7 +880,7 @@ bool FileMapInfo::FileMapHeader::validate() {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Arguments::patch_dirs() != NULL) {
|
if (Arguments::get_xpatchprefix() != NULL) {
|
||||||
FileMapInfo::fail_continue("The shared archive file cannot be used with -Xpatch.");
|
FileMapInfo::fail_continue("The shared archive file cannot be used with -Xpatch.");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -43,10 +43,10 @@
|
|||||||
// for the x64 platform
|
// for the x64 platform
|
||||||
#define DEFAULT_VTBL_COMMON_CODE_SIZE (1*K) // conservative size of the "common_code" for the x64 platform
|
#define DEFAULT_VTBL_COMMON_CODE_SIZE (1*K) // conservative size of the "common_code" for the x64 platform
|
||||||
|
|
||||||
#define DEFAULT_SHARED_READ_WRITE_SIZE (NOT_LP64(12*M) LP64_ONLY(16*M))
|
#define DEFAULT_SHARED_READ_WRITE_SIZE (NOT_LP64(8*M) LP64_ONLY(10*M))
|
||||||
#define MIN_SHARED_READ_WRITE_SIZE (NOT_LP64(7*M) LP64_ONLY(12*M))
|
#define MIN_SHARED_READ_WRITE_SIZE (NOT_LP64(7*M) LP64_ONLY(10*M))
|
||||||
|
|
||||||
#define DEFAULT_SHARED_READ_ONLY_SIZE (NOT_LP64(12*M) LP64_ONLY(16*M))
|
#define DEFAULT_SHARED_READ_ONLY_SIZE (NOT_LP64(8*M) LP64_ONLY(10*M))
|
||||||
#define MIN_SHARED_READ_ONLY_SIZE (NOT_LP64(8*M) LP64_ONLY(9*M))
|
#define MIN_SHARED_READ_ONLY_SIZE (NOT_LP64(8*M) LP64_ONLY(9*M))
|
||||||
|
|
||||||
// the MIN_SHARED_MISC_DATA_SIZE and MIN_SHARED_MISC_CODE_SIZE estimates are based on
|
// the MIN_SHARED_MISC_DATA_SIZE and MIN_SHARED_MISC_CODE_SIZE estimates are based on
|
||||||
|
@ -415,9 +415,13 @@ static bool check_inlined_mh_linker_info(ciMethod* symbolic_info, ciMethod* reso
|
|||||||
if (symbolic_info->arg_size() != (resolved_method->arg_size() + has_appendix)) {
|
if (symbolic_info->arg_size() != (resolved_method->arg_size() + has_appendix)) {
|
||||||
return false; // Total size of arguments on stack mismatch.
|
return false; // Total size of arguments on stack mismatch.
|
||||||
}
|
}
|
||||||
|
if (!symbolic_info->return_type()->is_void()) {
|
||||||
|
// Only check the return type if the symbolic method is not void
|
||||||
|
// i.e. the return value of the resolved method can be dropped
|
||||||
if (!check_type(symbolic_info->return_type(), resolved_method->return_type())) {
|
if (!check_type(symbolic_info->return_type(), resolved_method->return_type())) {
|
||||||
return false; // Return value size or type mismatch encountered.
|
return false; // Return value size or type mismatch encountered.
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
switch (symbolic_info->intrinsic_id()) {
|
switch (symbolic_info->intrinsic_id()) {
|
||||||
case vmIntrinsics::_linkToVirtual:
|
case vmIntrinsics::_linkToVirtual:
|
||||||
|
@ -84,8 +84,6 @@ const char* Arguments::_java_vendor_url_bug = DEFAULT_VENDOR_URL_BUG;
|
|||||||
const char* Arguments::_sun_java_launcher = DEFAULT_JAVA_LAUNCHER;
|
const char* Arguments::_sun_java_launcher = DEFAULT_JAVA_LAUNCHER;
|
||||||
int Arguments::_sun_java_launcher_pid = -1;
|
int Arguments::_sun_java_launcher_pid = -1;
|
||||||
bool Arguments::_sun_java_launcher_is_altjvm = false;
|
bool Arguments::_sun_java_launcher_is_altjvm = false;
|
||||||
int Arguments::_patch_dirs_count = 0;
|
|
||||||
char** Arguments::_patch_dirs = NULL;
|
|
||||||
int Arguments::_bootclassloader_append_index = -1;
|
int Arguments::_bootclassloader_append_index = -1;
|
||||||
|
|
||||||
// These parameters are reset in method parse_vm_init_args()
|
// These parameters are reset in method parse_vm_init_args()
|
||||||
@ -112,6 +110,7 @@ SystemProperty *Arguments::_java_home = NULL;
|
|||||||
SystemProperty *Arguments::_java_class_path = NULL;
|
SystemProperty *Arguments::_java_class_path = NULL;
|
||||||
SystemProperty *Arguments::_jdk_boot_class_path_append = NULL;
|
SystemProperty *Arguments::_jdk_boot_class_path_append = NULL;
|
||||||
|
|
||||||
|
GrowableArray<ModuleXPatchPath*> *Arguments::_xpatchprefix = NULL;
|
||||||
PathString *Arguments::_system_boot_class_path = NULL;
|
PathString *Arguments::_system_boot_class_path = NULL;
|
||||||
|
|
||||||
char* Arguments::_ext_dirs = NULL;
|
char* Arguments::_ext_dirs = NULL;
|
||||||
@ -579,204 +578,6 @@ static bool verify_special_jvm_flags() {
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Constructs the system boot class path from the following components, in order:
|
|
||||||
//
|
|
||||||
// prefix // from -Xpatch:...
|
|
||||||
// base // from os::get_system_properties()
|
|
||||||
// suffix // from -Xbootclasspath/a:...
|
|
||||||
//
|
|
||||||
// This could be AllStatic, but it isn't needed after argument processing is
|
|
||||||
// complete. After argument processing, the combined components are copied
|
|
||||||
// to Arguments::_system_boot_class_path via a call to Arguments::set_sysclasspath.
|
|
||||||
class ArgumentBootClassPath: public StackObj {
|
|
||||||
public:
|
|
||||||
ArgumentBootClassPath(const char* base);
|
|
||||||
~ArgumentBootClassPath();
|
|
||||||
|
|
||||||
inline void set_base(const char* base);
|
|
||||||
inline void add_prefix(const char* prefix);
|
|
||||||
inline void add_suffix_to_prefix(const char* suffix);
|
|
||||||
inline void add_suffix(const char* suffix);
|
|
||||||
inline void reset_path(const char* base);
|
|
||||||
|
|
||||||
inline const char* get_base() const { return _items[_bcp_base]; }
|
|
||||||
inline const char* get_prefix() const { return _items[_bcp_prefix]; }
|
|
||||||
inline const char* get_suffix() const { return _items[_bcp_suffix]; }
|
|
||||||
|
|
||||||
// Combine all the components into a single c-heap-allocated string; caller
|
|
||||||
// must free the string if/when no longer needed.
|
|
||||||
char* combined_path();
|
|
||||||
|
|
||||||
private:
|
|
||||||
// Utility routines.
|
|
||||||
static char* add_to_path(const char* path, const char* str, bool prepend);
|
|
||||||
static char* add_jars_to_path(char* path, const char* directory);
|
|
||||||
|
|
||||||
inline void reset_item_at(int index);
|
|
||||||
|
|
||||||
// Array indices for the items that make up the sysclasspath. All except the
|
|
||||||
// base are allocated in the C heap and freed by this class.
|
|
||||||
enum {
|
|
||||||
_bcp_prefix, // was -Xpatch:...
|
|
||||||
_bcp_base, // the default system boot class path
|
|
||||||
_bcp_suffix, // from -Xbootclasspath/a:...
|
|
||||||
_bcp_nitems // the number of items, must be last.
|
|
||||||
};
|
|
||||||
|
|
||||||
const char* _items[_bcp_nitems];
|
|
||||||
};
|
|
||||||
|
|
||||||
ArgumentBootClassPath::ArgumentBootClassPath(const char* base) {
|
|
||||||
memset(_items, 0, sizeof(_items));
|
|
||||||
_items[_bcp_base] = base;
|
|
||||||
}
|
|
||||||
|
|
||||||
ArgumentBootClassPath::~ArgumentBootClassPath() {
|
|
||||||
// Free everything except the base.
|
|
||||||
for (int i = 0; i < _bcp_nitems; ++i) {
|
|
||||||
if (i != _bcp_base) reset_item_at(i);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
inline void ArgumentBootClassPath::set_base(const char* base) {
|
|
||||||
_items[_bcp_base] = base;
|
|
||||||
}
|
|
||||||
|
|
||||||
inline void ArgumentBootClassPath::add_prefix(const char* prefix) {
|
|
||||||
_items[_bcp_prefix] = add_to_path(_items[_bcp_prefix], prefix, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
inline void ArgumentBootClassPath::add_suffix_to_prefix(const char* suffix) {
|
|
||||||
_items[_bcp_prefix] = add_to_path(_items[_bcp_prefix], suffix, false);
|
|
||||||
}
|
|
||||||
|
|
||||||
inline void ArgumentBootClassPath::add_suffix(const char* suffix) {
|
|
||||||
_items[_bcp_suffix] = add_to_path(_items[_bcp_suffix], suffix, false);
|
|
||||||
}
|
|
||||||
|
|
||||||
inline void ArgumentBootClassPath::reset_item_at(int index) {
|
|
||||||
assert(index < _bcp_nitems && index != _bcp_base, "just checking");
|
|
||||||
if (_items[index] != NULL) {
|
|
||||||
FREE_C_HEAP_ARRAY(char, _items[index]);
|
|
||||||
_items[index] = NULL;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
inline void ArgumentBootClassPath::reset_path(const char* base) {
|
|
||||||
// Clear the prefix and suffix.
|
|
||||||
reset_item_at(_bcp_prefix);
|
|
||||||
reset_item_at(_bcp_suffix);
|
|
||||||
set_base(base);
|
|
||||||
}
|
|
||||||
|
|
||||||
//------------------------------------------------------------------------------
|
|
||||||
|
|
||||||
|
|
||||||
// Combine the bootclasspath elements, some of which may be null, into a single
|
|
||||||
// c-heap-allocated string.
|
|
||||||
char* ArgumentBootClassPath::combined_path() {
|
|
||||||
assert(_items[_bcp_base] != NULL, "empty default sysclasspath");
|
|
||||||
|
|
||||||
size_t lengths[_bcp_nitems];
|
|
||||||
size_t total_len = 0;
|
|
||||||
|
|
||||||
const char separator = *os::path_separator();
|
|
||||||
|
|
||||||
// Get the lengths.
|
|
||||||
int i;
|
|
||||||
for (i = 0; i < _bcp_nitems; ++i) {
|
|
||||||
if (i == _bcp_suffix) {
|
|
||||||
// Record index of boot loader's append path.
|
|
||||||
Arguments::set_bootclassloader_append_index((int)total_len);
|
|
||||||
}
|
|
||||||
if (_items[i] != NULL) {
|
|
||||||
lengths[i] = strlen(_items[i]);
|
|
||||||
// Include space for the separator char (or a NULL for the last item).
|
|
||||||
total_len += lengths[i] + 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
assert(total_len > 0, "empty sysclasspath not allowed");
|
|
||||||
|
|
||||||
// Copy the _items to a single string.
|
|
||||||
char* cp = NEW_C_HEAP_ARRAY(char, total_len, mtArguments);
|
|
||||||
char* cp_tmp = cp;
|
|
||||||
for (i = 0; i < _bcp_nitems; ++i) {
|
|
||||||
if (_items[i] != NULL) {
|
|
||||||
memcpy(cp_tmp, _items[i], lengths[i]);
|
|
||||||
cp_tmp += lengths[i];
|
|
||||||
*cp_tmp++ = separator;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*--cp_tmp = '\0'; // Replace the extra separator.
|
|
||||||
return cp;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Note: path must be c-heap-allocated (or NULL); it is freed if non-null.
|
|
||||||
char*
|
|
||||||
ArgumentBootClassPath::add_to_path(const char* path, const char* str, bool prepend) {
|
|
||||||
char *cp;
|
|
||||||
|
|
||||||
assert(str != NULL, "just checking");
|
|
||||||
if (path == NULL) {
|
|
||||||
size_t len = strlen(str) + 1;
|
|
||||||
cp = NEW_C_HEAP_ARRAY(char, len, mtArguments);
|
|
||||||
memcpy(cp, str, len); // copy the trailing null
|
|
||||||
} else {
|
|
||||||
const char separator = *os::path_separator();
|
|
||||||
size_t old_len = strlen(path);
|
|
||||||
size_t str_len = strlen(str);
|
|
||||||
size_t len = old_len + str_len + 2;
|
|
||||||
|
|
||||||
if (prepend) {
|
|
||||||
cp = NEW_C_HEAP_ARRAY(char, len, mtArguments);
|
|
||||||
char* cp_tmp = cp;
|
|
||||||
memcpy(cp_tmp, str, str_len);
|
|
||||||
cp_tmp += str_len;
|
|
||||||
*cp_tmp = separator;
|
|
||||||
memcpy(++cp_tmp, path, old_len + 1); // copy the trailing null
|
|
||||||
FREE_C_HEAP_ARRAY(char, path);
|
|
||||||
} else {
|
|
||||||
cp = REALLOC_C_HEAP_ARRAY(char, path, len, mtArguments);
|
|
||||||
char* cp_tmp = cp + old_len;
|
|
||||||
*cp_tmp = separator;
|
|
||||||
memcpy(++cp_tmp, str, str_len + 1); // copy the trailing null
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return cp;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Scan the directory and append any jar or zip files found to path.
|
|
||||||
// Note: path must be c-heap-allocated (or NULL); it is freed if non-null.
|
|
||||||
char* ArgumentBootClassPath::add_jars_to_path(char* path, const char* directory) {
|
|
||||||
DIR* dir = os::opendir(directory);
|
|
||||||
if (dir == NULL) return path;
|
|
||||||
|
|
||||||
char dir_sep[2] = { '\0', '\0' };
|
|
||||||
size_t directory_len = strlen(directory);
|
|
||||||
const char fileSep = *os::file_separator();
|
|
||||||
if (directory[directory_len - 1] != fileSep) dir_sep[0] = fileSep;
|
|
||||||
|
|
||||||
/* Scan the directory for jars/zips, appending them to path. */
|
|
||||||
struct dirent *entry;
|
|
||||||
char *dbuf = NEW_C_HEAP_ARRAY(char, os::readdir_buf_size(directory), mtArguments);
|
|
||||||
while ((entry = os::readdir(dir, (dirent *) dbuf)) != NULL) {
|
|
||||||
const char* name = entry->d_name;
|
|
||||||
const char* ext = name + strlen(name) - 4;
|
|
||||||
bool isJarOrZip = ext > name &&
|
|
||||||
(os::file_name_strcmp(ext, ".jar") == 0 ||
|
|
||||||
os::file_name_strcmp(ext, ".zip") == 0);
|
|
||||||
if (isJarOrZip) {
|
|
||||||
char* jarpath = NEW_C_HEAP_ARRAY(char, directory_len + 2 + strlen(name), mtArguments);
|
|
||||||
sprintf(jarpath, "%s%s%s", directory, dir_sep, name);
|
|
||||||
path = add_to_path(path, jarpath, false);
|
|
||||||
FREE_C_HEAP_ARRAY(char, jarpath);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
FREE_C_HEAP_ARRAY(char, dbuf);
|
|
||||||
os::closedir(dir);
|
|
||||||
return path;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Parses a memory size specification string.
|
// Parses a memory size specification string.
|
||||||
static bool atomull(const char *s, julong* result) {
|
static bool atomull(const char *s, julong* result) {
|
||||||
julong n = 0;
|
julong n = 0;
|
||||||
@ -2687,9 +2488,7 @@ Arguments::ArgsRange Arguments::parse_memory_size(const char* s,
|
|||||||
jint Arguments::parse_vm_init_args(const JavaVMInitArgs *java_tool_options_args,
|
jint Arguments::parse_vm_init_args(const JavaVMInitArgs *java_tool_options_args,
|
||||||
const JavaVMInitArgs *java_options_args,
|
const JavaVMInitArgs *java_options_args,
|
||||||
const JavaVMInitArgs *cmd_line_args) {
|
const JavaVMInitArgs *cmd_line_args) {
|
||||||
// For components of the system classpath.
|
bool xpatch_javabase = false;
|
||||||
ArgumentBootClassPath bcp(Arguments::get_sysclasspath());
|
|
||||||
bool bcp_assembly_required = false;
|
|
||||||
|
|
||||||
// Save default settings for some mode flags
|
// Save default settings for some mode flags
|
||||||
Arguments::_AlwaysCompileLoopMethods = AlwaysCompileLoopMethods;
|
Arguments::_AlwaysCompileLoopMethods = AlwaysCompileLoopMethods;
|
||||||
@ -2706,29 +2505,26 @@ jint Arguments::parse_vm_init_args(const JavaVMInitArgs *java_tool_options_args,
|
|||||||
|
|
||||||
// Parse args structure generated from JAVA_TOOL_OPTIONS environment
|
// Parse args structure generated from JAVA_TOOL_OPTIONS environment
|
||||||
// variable (if present).
|
// variable (if present).
|
||||||
jint result = parse_each_vm_init_arg(
|
jint result = parse_each_vm_init_arg(java_tool_options_args, &xpatch_javabase, Flag::ENVIRON_VAR);
|
||||||
java_tool_options_args, &bcp, &bcp_assembly_required, Flag::ENVIRON_VAR);
|
|
||||||
if (result != JNI_OK) {
|
if (result != JNI_OK) {
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Parse args structure generated from the command line flags.
|
// Parse args structure generated from the command line flags.
|
||||||
result = parse_each_vm_init_arg(cmd_line_args, &bcp, &bcp_assembly_required,
|
result = parse_each_vm_init_arg(cmd_line_args, &xpatch_javabase, Flag::COMMAND_LINE);
|
||||||
Flag::COMMAND_LINE);
|
|
||||||
if (result != JNI_OK) {
|
if (result != JNI_OK) {
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Parse args structure generated from the _JAVA_OPTIONS environment
|
// Parse args structure generated from the _JAVA_OPTIONS environment
|
||||||
// variable (if present) (mimics classic VM)
|
// variable (if present) (mimics classic VM)
|
||||||
result = parse_each_vm_init_arg(
|
result = parse_each_vm_init_arg(java_options_args, &xpatch_javabase, Flag::ENVIRON_VAR);
|
||||||
java_options_args, &bcp, &bcp_assembly_required, Flag::ENVIRON_VAR);
|
|
||||||
if (result != JNI_OK) {
|
if (result != JNI_OK) {
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Do final processing now that all arguments have been parsed
|
// Do final processing now that all arguments have been parsed
|
||||||
result = finalize_vm_init_args(&bcp, bcp_assembly_required);
|
result = finalize_vm_init_args();
|
||||||
if (result != JNI_OK) {
|
if (result != JNI_OK) {
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
@ -2781,10 +2577,7 @@ bool valid_jdwp_agent(char *name, bool is_path) {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
jint Arguments::parse_each_vm_init_arg(const JavaVMInitArgs* args,
|
jint Arguments::parse_each_vm_init_arg(const JavaVMInitArgs* args, bool* xpatch_javabase, Flag::Flags origin) {
|
||||||
ArgumentBootClassPath* bcp_p,
|
|
||||||
bool* bcp_assembly_required_p,
|
|
||||||
Flag::Flags origin) {
|
|
||||||
// For match_option to return remaining or value part of option string
|
// For match_option to return remaining or value part of option string
|
||||||
const char* tail;
|
const char* tail;
|
||||||
|
|
||||||
@ -2840,8 +2633,8 @@ jint Arguments::parse_each_vm_init_arg(const JavaVMInitArgs* args,
|
|||||||
return JNI_EINVAL;
|
return JNI_EINVAL;
|
||||||
// -bootclasspath/a:
|
// -bootclasspath/a:
|
||||||
} else if (match_option(option, "-Xbootclasspath/a:", &tail)) {
|
} else if (match_option(option, "-Xbootclasspath/a:", &tail)) {
|
||||||
bcp_p->add_suffix(tail);
|
Arguments::set_bootclassloader_append_index((int)strlen(Arguments::get_sysclasspath())+1);
|
||||||
*bcp_assembly_required_p = true;
|
Arguments::append_sysclasspath(tail);
|
||||||
// -bootclasspath/p:
|
// -bootclasspath/p:
|
||||||
} else if (match_option(option, "-Xbootclasspath/p:", &tail)) {
|
} else if (match_option(option, "-Xbootclasspath/p:", &tail)) {
|
||||||
jio_fprintf(defaultStream::output_stream(),
|
jio_fprintf(defaultStream::output_stream(),
|
||||||
@ -2901,9 +2694,8 @@ jint Arguments::parse_each_vm_init_arg(const JavaVMInitArgs* args,
|
|||||||
if (tail != NULL) {
|
if (tail != NULL) {
|
||||||
char *options = strcpy(NEW_C_HEAP_ARRAY(char, strlen(tail) + 1, mtArguments), tail);
|
char *options = strcpy(NEW_C_HEAP_ARRAY(char, strlen(tail) + 1, mtArguments), tail);
|
||||||
add_init_agent("instrument", options, false);
|
add_init_agent("instrument", options, false);
|
||||||
// java agents need module java.instrument. Also -addmods ALL-SYSTEM because
|
// java agents need module java.instrument
|
||||||
// the java agent is in the unmamed module of the application class loader
|
if (!Arguments::append_to_addmods_property("java.instrument")) {
|
||||||
if (!Arguments::append_to_addmods_property("java.instrument,ALL-SYSTEM")) {
|
|
||||||
return JNI_ENOMEM;
|
return JNI_ENOMEM;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -3181,37 +2973,30 @@ jint Arguments::parse_each_vm_init_arg(const JavaVMInitArgs* args,
|
|||||||
return JNI_ERR;
|
return JNI_ERR;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
if (match_option(option, "-Djdk.launcher.patch.0=", &tail)) {
|
if (match_option(option, "-Djdk.launcher.patch.", &tail)) {
|
||||||
// -Xpatch
|
// -Djdk.launcher.patch.#=<module>=<file>(<pathsep><file>)*
|
||||||
int dir_count;
|
// The number, #, specified will be increasing with each -Xpatch
|
||||||
char** patch_dirs = os::split_path(tail, &dir_count);
|
// specified on the command line.
|
||||||
if (patch_dirs == NULL) {
|
// Pick up module name, following the -D property's equal sign.
|
||||||
jio_fprintf(defaultStream::output_stream(),
|
const char* property_equal = strchr(tail, '=');
|
||||||
"Bad value for -Xpatch.\n");
|
if (property_equal == NULL) {
|
||||||
|
jio_fprintf(defaultStream::output_stream(), "Missing '=' in -Xpatch specification\n");
|
||||||
return JNI_ERR;
|
return JNI_ERR;
|
||||||
}
|
} else {
|
||||||
set_patch_dirs(patch_dirs);
|
// Find the equal sign between the module name and the path specification
|
||||||
set_patch_dirs_count(dir_count);
|
const char* module_equal = strchr(property_equal + 1, '=');
|
||||||
|
if (module_equal == NULL) {
|
||||||
// Create a path for each patch dir consisting of dir/java.base.
|
jio_fprintf(defaultStream::output_stream(), "Bad value for -Xpatch, no module name specified\n");
|
||||||
char file_sep = os::file_separator()[0];
|
return JNI_ERR;
|
||||||
for (int x = 0; x < dir_count; x++) {
|
} else {
|
||||||
// Really shouldn't be NULL, but check can't hurt
|
// Pick out the module name, in between the two equal signs
|
||||||
if (patch_dirs[x] != NULL) {
|
size_t module_len = module_equal - property_equal - 1;
|
||||||
size_t len = strlen(patch_dirs[x]);
|
char* module_name = NEW_C_HEAP_ARRAY(char, module_len+1, mtArguments);
|
||||||
if (len != 0) { // Ignore empty strings.
|
memcpy(module_name, property_equal + 1, module_len);
|
||||||
len += 11; // file_sep + "java.base" + null terminator.
|
*(module_name + module_len) = '\0';
|
||||||
char* dir = NEW_C_HEAP_ARRAY(char, len, mtArguments);
|
// The path piece begins one past the module_equal sign
|
||||||
jio_snprintf(dir, len, "%s%cjava.base", patch_dirs[x], file_sep);
|
Arguments::add_xpatchprefix(module_name, module_equal + 1, xpatch_javabase);
|
||||||
|
FREE_C_HEAP_ARRAY(char, module_name);
|
||||||
// See if Xpatch module path exists.
|
|
||||||
struct stat st;
|
|
||||||
if ((os::stat(dir, &st) == 0)) {
|
|
||||||
bcp_p->add_prefix(dir);
|
|
||||||
*bcp_assembly_required_p = true;
|
|
||||||
}
|
|
||||||
FREE_C_HEAP_ARRAY(char, dir);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -3474,6 +3259,27 @@ jint Arguments::parse_each_vm_init_arg(const JavaVMInitArgs* args,
|
|||||||
return JNI_OK;
|
return JNI_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Arguments::add_xpatchprefix(const char* module_name, const char* path, bool* xpatch_javabase) {
|
||||||
|
// For java.base check for duplicate -Xpatch options being specified on the command line.
|
||||||
|
// This check is only required for java.base, all other duplicate module specifications
|
||||||
|
// will be checked during module system initialization. The module system initialization
|
||||||
|
// will throw an ExceptionInInitializerError if this situation occurs.
|
||||||
|
if (strcmp(module_name, "java.base") == 0) {
|
||||||
|
if (*xpatch_javabase) {
|
||||||
|
vm_exit_during_initialization("Cannot specify java.base more than once to -Xpatch");
|
||||||
|
} else {
|
||||||
|
*xpatch_javabase = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Create GrowableArray lazily, only if -Xpatch has been specified
|
||||||
|
if (_xpatchprefix == NULL) {
|
||||||
|
_xpatchprefix = new (ResourceObj::C_HEAP, mtArguments) GrowableArray<ModuleXPatchPath*>(10, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
_xpatchprefix->push(new ModuleXPatchPath(module_name, path));
|
||||||
|
}
|
||||||
|
|
||||||
// Set property jdk.boot.class.path.append to the contents of the bootclasspath
|
// Set property jdk.boot.class.path.append to the contents of the bootclasspath
|
||||||
// that follows either the jimage file or exploded module directories. The
|
// that follows either the jimage file or exploded module directories. The
|
||||||
// property will contain -Xbootclasspath/a and/or jvmti appended additions.
|
// property will contain -Xbootclasspath/a and/or jvmti appended additions.
|
||||||
@ -3572,7 +3378,7 @@ static int check_non_empty_dirs(const char* path) {
|
|||||||
return nonEmptyDirs;
|
return nonEmptyDirs;
|
||||||
}
|
}
|
||||||
|
|
||||||
jint Arguments::finalize_vm_init_args(ArgumentBootClassPath* bcp_p, bool bcp_assembly_required) {
|
jint Arguments::finalize_vm_init_args() {
|
||||||
// check if the default lib/endorsed directory exists; if so, error
|
// check if the default lib/endorsed directory exists; if so, error
|
||||||
char path[JVM_MAXPATHLEN];
|
char path[JVM_MAXPATHLEN];
|
||||||
const char* fileSep = os::file_separator();
|
const char* fileSep = os::file_separator();
|
||||||
@ -3608,17 +3414,7 @@ jint Arguments::finalize_vm_init_args(ArgumentBootClassPath* bcp_p, bool bcp_ass
|
|||||||
return JNI_ERR;
|
return JNI_ERR;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (bcp_assembly_required) {
|
|
||||||
// Assemble the bootclasspath elements into the final path.
|
|
||||||
char *combined_path = bcp_p->combined_path();
|
|
||||||
Arguments::set_sysclasspath(combined_path);
|
|
||||||
FREE_C_HEAP_ARRAY(char, combined_path);
|
|
||||||
} else {
|
|
||||||
// At this point in sysclasspath processing anything
|
|
||||||
// added would be considered in the boot loader's append path.
|
|
||||||
// Record this index, including +1 for the file separator character.
|
|
||||||
Arguments::set_bootclassloader_append_index(((int)strlen(Arguments::get_sysclasspath()))+1);
|
Arguments::set_bootclassloader_append_index(((int)strlen(Arguments::get_sysclasspath()))+1);
|
||||||
}
|
|
||||||
|
|
||||||
// This must be done after all arguments have been processed.
|
// This must be done after all arguments have been processed.
|
||||||
// java_compiler() true means set to "NONE" or empty.
|
// java_compiler() true means set to "NONE" or empty.
|
||||||
@ -3667,6 +3463,12 @@ jint Arguments::finalize_vm_init_args(ArgumentBootClassPath* bcp_p, bool bcp_ass
|
|||||||
UNSUPPORTED_OPTION(TieredCompilation);
|
UNSUPPORTED_OPTION(TieredCompilation);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if INCLUDE_JVMCI
|
||||||
|
if (EnableJVMCI && !append_to_addmods_property("jdk.vm.ci")) {
|
||||||
|
return JNI_ENOMEM;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
// If we are running in a headless jre, force java.awt.headless property
|
// If we are running in a headless jre, force java.awt.headless property
|
||||||
// to be true unless the property has already been set.
|
// to be true unless the property has already been set.
|
||||||
// Also allow the OS environment variable JAVA_AWT_HEADLESS to set headless state.
|
// Also allow the OS environment variable JAVA_AWT_HEADLESS to set headless state.
|
||||||
@ -3968,7 +3770,7 @@ jint Arguments::parse_options_buffer(const char* name, char* buffer, const size_
|
|||||||
|
|
||||||
void Arguments::set_shared_spaces_flags() {
|
void Arguments::set_shared_spaces_flags() {
|
||||||
if (DumpSharedSpaces) {
|
if (DumpSharedSpaces) {
|
||||||
if (Arguments::patch_dirs() != NULL) {
|
if (Arguments::get_xpatchprefix() != NULL) {
|
||||||
vm_exit_during_initialization(
|
vm_exit_during_initialization(
|
||||||
"Cannot use the following option when dumping the shared archive", "-Xpatch");
|
"Cannot use the following option when dumping the shared archive", "-Xpatch");
|
||||||
}
|
}
|
||||||
|
@ -41,12 +41,10 @@ extern "C" {
|
|||||||
typedef jint (JNICALL *vfprintf_hook_t)(FILE *fp, const char *format, va_list args) ATTRIBUTE_PRINTF(2, 0);
|
typedef jint (JNICALL *vfprintf_hook_t)(FILE *fp, const char *format, va_list args) ATTRIBUTE_PRINTF(2, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Forward declarations
|
// PathString is used as:
|
||||||
class ArgumentBootClassPath;
|
// - the underlying value for a SystemProperty
|
||||||
|
// - the path portion of an -Xpatch module/path pair
|
||||||
// PathString is used as the underlying value container for a
|
// - the string that represents the system boot class path, Arguments::_system_boot_class_path.
|
||||||
// SystemProperty and for the string that represents the system
|
|
||||||
// boot class path, Arguments::_system_boot_class_path.
|
|
||||||
class PathString : public CHeapObj<mtArguments> {
|
class PathString : public CHeapObj<mtArguments> {
|
||||||
protected:
|
protected:
|
||||||
char* _value;
|
char* _value;
|
||||||
@ -92,7 +90,6 @@ class PathString : public CHeapObj<mtArguments> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Constructor
|
|
||||||
PathString(const char* value) {
|
PathString(const char* value) {
|
||||||
if (value == NULL) {
|
if (value == NULL) {
|
||||||
_value = NULL;
|
_value = NULL;
|
||||||
@ -101,6 +98,43 @@ class PathString : public CHeapObj<mtArguments> {
|
|||||||
strcpy(_value, value);
|
strcpy(_value, value);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
~PathString() {
|
||||||
|
if (_value != NULL) {
|
||||||
|
FreeHeap(_value);
|
||||||
|
_value = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// ModuleXPatchPath records the module/path pair as specified to -Xpatch.
|
||||||
|
class ModuleXPatchPath : public CHeapObj<mtInternal> {
|
||||||
|
private:
|
||||||
|
char* _module_name;
|
||||||
|
PathString* _path;
|
||||||
|
public:
|
||||||
|
ModuleXPatchPath(const char* module_name, const char* path) {
|
||||||
|
assert(module_name != NULL && path != NULL, "Invalid module name or path value");
|
||||||
|
size_t len = strlen(module_name) + 1;
|
||||||
|
_module_name = AllocateHeap(len, mtInternal);
|
||||||
|
strncpy(_module_name, module_name, len); // copy the trailing null
|
||||||
|
_path = new PathString(path);
|
||||||
|
}
|
||||||
|
|
||||||
|
~ModuleXPatchPath() {
|
||||||
|
if (_module_name != NULL) {
|
||||||
|
FreeHeap(_module_name);
|
||||||
|
_module_name = NULL;
|
||||||
|
}
|
||||||
|
if (_path != NULL) {
|
||||||
|
delete _path;
|
||||||
|
_path = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void set_path(const char* path) { _path->set_value(path); }
|
||||||
|
inline const char* module_name() const { return _module_name; }
|
||||||
|
inline char* path_string() const { return _path->value(); }
|
||||||
};
|
};
|
||||||
|
|
||||||
// Element describing System and User (-Dkey=value flags) defined property.
|
// Element describing System and User (-Dkey=value flags) defined property.
|
||||||
@ -314,10 +348,19 @@ class Arguments : AllStatic {
|
|||||||
static SystemProperty *_java_class_path;
|
static SystemProperty *_java_class_path;
|
||||||
static SystemProperty *_jdk_boot_class_path_append;
|
static SystemProperty *_jdk_boot_class_path_append;
|
||||||
|
|
||||||
|
// -Xpatch:module=<file>(<pathsep><file>)*
|
||||||
|
// Each element contains the associated module name, path
|
||||||
|
// string pair as specified to -Xpatch.
|
||||||
|
static GrowableArray<ModuleXPatchPath*>* _xpatchprefix;
|
||||||
|
|
||||||
// The constructed value of the system class path after
|
// The constructed value of the system class path after
|
||||||
// argument processing and JVMTI OnLoad additions via
|
// argument processing and JVMTI OnLoad additions via
|
||||||
// calls to AddToBootstrapClassLoaderSearch. This is the
|
// calls to AddToBootstrapClassLoaderSearch. This is the
|
||||||
// final form before ClassLoader::setup_bootstrap_search().
|
// final form before ClassLoader::setup_bootstrap_search().
|
||||||
|
// Note: since -Xpatch is a module name/path pair, the system
|
||||||
|
// boot class path string no longer contains the "prefix" to
|
||||||
|
// the boot class path base piece as it did when
|
||||||
|
// -Xbootclasspath/p was supported.
|
||||||
static PathString *_system_boot_class_path;
|
static PathString *_system_boot_class_path;
|
||||||
|
|
||||||
// temporary: to emit warning if the default ext dirs are not empty.
|
// temporary: to emit warning if the default ext dirs are not empty.
|
||||||
@ -373,12 +416,6 @@ class Arguments : AllStatic {
|
|||||||
// mark the boot loader's append path observability boundary.
|
// mark the boot loader's append path observability boundary.
|
||||||
static int _bootclassloader_append_index;
|
static int _bootclassloader_append_index;
|
||||||
|
|
||||||
// -Xpatch flag
|
|
||||||
static char** _patch_dirs;
|
|
||||||
static int _patch_dirs_count;
|
|
||||||
static void set_patch_dirs(char** dirs) { _patch_dirs = dirs; }
|
|
||||||
static void set_patch_dirs_count(int count) { _patch_dirs_count = count; }
|
|
||||||
|
|
||||||
// -Xdebug flag
|
// -Xdebug flag
|
||||||
static bool _xdebug_mode;
|
static bool _xdebug_mode;
|
||||||
static void set_xdebug_mode(bool arg) { _xdebug_mode = arg; }
|
static void set_xdebug_mode(bool arg) { _xdebug_mode = arg; }
|
||||||
@ -465,8 +502,8 @@ class Arguments : AllStatic {
|
|||||||
static jint parse_vm_init_args(const JavaVMInitArgs *java_tool_options_args,
|
static jint parse_vm_init_args(const JavaVMInitArgs *java_tool_options_args,
|
||||||
const JavaVMInitArgs *java_options_args,
|
const JavaVMInitArgs *java_options_args,
|
||||||
const JavaVMInitArgs *cmd_line_args);
|
const JavaVMInitArgs *cmd_line_args);
|
||||||
static jint parse_each_vm_init_arg(const JavaVMInitArgs* args, ArgumentBootClassPath* bcp_p, bool* bcp_assembly_required_p, Flag::Flags origin);
|
static jint parse_each_vm_init_arg(const JavaVMInitArgs* args, bool* xpatch_javabase, Flag::Flags origin);
|
||||||
static jint finalize_vm_init_args(ArgumentBootClassPath* bcp_p, bool bcp_assembly_required);
|
static jint finalize_vm_init_args();
|
||||||
static bool is_bad_option(const JavaVMOption* option, jboolean ignore, const char* option_type);
|
static bool is_bad_option(const JavaVMOption* option, jboolean ignore, const char* option_type);
|
||||||
|
|
||||||
static bool is_bad_option(const JavaVMOption* option, jboolean ignore) {
|
static bool is_bad_option(const JavaVMOption* option, jboolean ignore) {
|
||||||
@ -637,12 +674,11 @@ class Arguments : AllStatic {
|
|||||||
return _bootclassloader_append_index;
|
return _bootclassloader_append_index;
|
||||||
}
|
}
|
||||||
static void set_bootclassloader_append_index(int value) {
|
static void set_bootclassloader_append_index(int value) {
|
||||||
|
// Set only if the index has not been set yet
|
||||||
|
if (_bootclassloader_append_index == -1) {
|
||||||
_bootclassloader_append_index = value;
|
_bootclassloader_append_index = value;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
// -Xpatch
|
|
||||||
static char** patch_dirs() { return _patch_dirs; }
|
|
||||||
static int patch_dirs_count() { return _patch_dirs_count; }
|
|
||||||
|
|
||||||
// -Xrun
|
// -Xrun
|
||||||
static AgentLibrary* libraries() { return _libraryList.first(); }
|
static AgentLibrary* libraries() { return _libraryList.first(); }
|
||||||
@ -701,8 +737,8 @@ class Arguments : AllStatic {
|
|||||||
static void set_library_path(const char *value) { _java_library_path->set_value(value); }
|
static void set_library_path(const char *value) { _java_library_path->set_value(value); }
|
||||||
static void set_ext_dirs(char *value) { _ext_dirs = os::strdup_check_oom(value); }
|
static void set_ext_dirs(char *value) { _ext_dirs = os::strdup_check_oom(value); }
|
||||||
|
|
||||||
// Set up of the underlying system boot class path
|
// Set up the underlying pieces of the system boot class path
|
||||||
static void set_jdkbootclasspath_append();
|
static void add_xpatchprefix(const char *module_name, const char *path, bool* xpatch_javabase);
|
||||||
static void set_sysclasspath(const char *value) {
|
static void set_sysclasspath(const char *value) {
|
||||||
_system_boot_class_path->set_value(value);
|
_system_boot_class_path->set_value(value);
|
||||||
set_jdkbootclasspath_append();
|
set_jdkbootclasspath_append();
|
||||||
@ -711,10 +747,14 @@ class Arguments : AllStatic {
|
|||||||
_system_boot_class_path->append_value(value);
|
_system_boot_class_path->append_value(value);
|
||||||
set_jdkbootclasspath_append();
|
set_jdkbootclasspath_append();
|
||||||
}
|
}
|
||||||
|
static void set_jdkbootclasspath_append();
|
||||||
|
|
||||||
|
static GrowableArray<ModuleXPatchPath*>* get_xpatchprefix() { return _xpatchprefix; }
|
||||||
|
static char* get_sysclasspath() { return _system_boot_class_path->value(); }
|
||||||
|
static char* get_jdk_boot_class_path_append() { return _jdk_boot_class_path_append->value(); }
|
||||||
|
|
||||||
static char* get_java_home() { return _java_home->value(); }
|
static char* get_java_home() { return _java_home->value(); }
|
||||||
static char* get_dll_dir() { return _sun_boot_library_path->value(); }
|
static char* get_dll_dir() { return _sun_boot_library_path->value(); }
|
||||||
static char* get_sysclasspath() { return _system_boot_class_path->value(); }
|
|
||||||
static char* get_ext_dirs() { return _ext_dirs; }
|
static char* get_ext_dirs() { return _ext_dirs; }
|
||||||
static char* get_appclasspath() { return _java_class_path->value(); }
|
static char* get_appclasspath() { return _java_class_path->value(); }
|
||||||
static void fix_appclasspath();
|
static void fix_appclasspath();
|
||||||
|
@ -52,7 +52,8 @@ void SuspendibleThreadSet_init() NOT_ALL_GCS_RETURN;
|
|||||||
// Initialization done by Java thread in init_globals()
|
// Initialization done by Java thread in init_globals()
|
||||||
void management_init();
|
void management_init();
|
||||||
void bytecodes_init();
|
void bytecodes_init();
|
||||||
void classLoader_init();
|
void classLoader_init1();
|
||||||
|
void classLoader_init2(); // note: ClassLoader need 2-phase init
|
||||||
void compilationPolicy_init();
|
void compilationPolicy_init();
|
||||||
void codeCache_init();
|
void codeCache_init();
|
||||||
void VM_Version_init();
|
void VM_Version_init();
|
||||||
@ -102,7 +103,7 @@ jint init_globals() {
|
|||||||
HandleMark hm;
|
HandleMark hm;
|
||||||
management_init();
|
management_init();
|
||||||
bytecodes_init();
|
bytecodes_init();
|
||||||
classLoader_init();
|
classLoader_init1();
|
||||||
compilationPolicy_init();
|
compilationPolicy_init();
|
||||||
codeCache_init();
|
codeCache_init();
|
||||||
CodeCacheExtensions::initialize();
|
CodeCacheExtensions::initialize();
|
||||||
@ -116,6 +117,7 @@ jint init_globals() {
|
|||||||
if (status != JNI_OK)
|
if (status != JNI_OK)
|
||||||
return status;
|
return status;
|
||||||
|
|
||||||
|
classLoader_init2(); // after SymbolTable creation, set up -Xpatch entries
|
||||||
CodeCacheExtensions::complete_step(CodeCacheExtensionsSteps::Universe);
|
CodeCacheExtensions::complete_step(CodeCacheExtensionsSteps::Universe);
|
||||||
interpreter_init(); // before any methods loaded
|
interpreter_init(); // before any methods loaded
|
||||||
CodeCacheExtensions::complete_step(CodeCacheExtensionsSteps::Interpreter);
|
CodeCacheExtensions::complete_step(CodeCacheExtensionsSteps::Interpreter);
|
||||||
|
@ -36,9 +36,12 @@ groups=TEST.groups [closed/TEST.groups]
|
|||||||
requires.extraPropDefns = ../../test/jtreg-ext/requires/VMProps.java
|
requires.extraPropDefns = ../../test/jtreg-ext/requires/VMProps.java
|
||||||
requires.properties=sun.arch.data.model
|
requires.properties=sun.arch.data.model
|
||||||
|
|
||||||
# Tests using jtreg 4.2 b01 features
|
# Tests using jtreg 4.2 b02 features
|
||||||
requiredVersion=4.2 b01
|
requiredVersion=4.2 b02
|
||||||
|
|
||||||
# Path to libraries in the topmost test directory. This is needed so @library
|
# Path to libraries in the topmost test directory. This is needed so @library
|
||||||
# does not need ../../ notation to reach them
|
# does not need ../../ notation to reach them
|
||||||
external.lib.roots = ../../
|
external.lib.roots = ../../
|
||||||
|
|
||||||
|
# Use new form of -Xpatch
|
||||||
|
useNewXpatch=true
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2014, 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -30,7 +30,7 @@
|
|||||||
* @build AndnTestI
|
* @build AndnTestI
|
||||||
* @run main ClassFileInstaller sun.hotspot.WhiteBox
|
* @run main ClassFileInstaller sun.hotspot.WhiteBox
|
||||||
* sun.hotspot.WhiteBox$WhiteBoxPermission
|
* sun.hotspot.WhiteBox$WhiteBoxPermission
|
||||||
* @run main/bootclasspath -Xbatch -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI
|
* @run main/bootclasspath/othervm -Xbatch -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI
|
||||||
* -XX:+IgnoreUnrecognizedVMOptions -XX:+UseBMI1Instructions AndnTestI
|
* -XX:+IgnoreUnrecognizedVMOptions -XX:+UseBMI1Instructions AndnTestI
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2014, 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -30,7 +30,7 @@
|
|||||||
* @build AndnTestL
|
* @build AndnTestL
|
||||||
* @run main ClassFileInstaller sun.hotspot.WhiteBox
|
* @run main ClassFileInstaller sun.hotspot.WhiteBox
|
||||||
* sun.hotspot.WhiteBox$WhiteBoxPermission
|
* sun.hotspot.WhiteBox$WhiteBoxPermission
|
||||||
* @run main/bootclasspath -Xbatch -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI
|
* @run main/bootclasspath/othervm -Xbatch -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI
|
||||||
* -XX:+IgnoreUnrecognizedVMOptions -XX:+UseBMI1Instructions AndnTestL
|
* -XX:+IgnoreUnrecognizedVMOptions -XX:+UseBMI1Instructions AndnTestL
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -27,7 +27,7 @@
|
|||||||
* @modules java.base/jdk.internal.org.objectweb.asm
|
* @modules java.base/jdk.internal.org.objectweb.asm
|
||||||
* @library patches
|
* @library patches
|
||||||
* @build java.base/java.lang.invoke.MethodHandleHelper
|
* @build java.base/java.lang.invoke.MethodHandleHelper
|
||||||
* @run main/bootclasspath -Xbatch -XX:+IgnoreUnrecognizedVMOptions -Xlog:classunload
|
* @run main/bootclasspath/othervm -Xbatch -XX:+IgnoreUnrecognizedVMOptions -Xlog:classunload
|
||||||
* -XX:+PrintCompilation -XX:+TraceDependencies -XX:+TraceReferenceGC
|
* -XX:+PrintCompilation -XX:+TraceDependencies -XX:+TraceReferenceGC
|
||||||
* -verbose:gc compiler.jsr292.CallSiteDepContextTest
|
* -verbose:gc compiler.jsr292.CallSiteDepContextTest
|
||||||
*/
|
*/
|
||||||
|
@ -25,7 +25,7 @@
|
|||||||
* @test
|
* @test
|
||||||
* @bug 8067247
|
* @bug 8067247
|
||||||
* @library /test/lib /compiler/whitebox /
|
* @library /test/lib /compiler/whitebox /
|
||||||
* @run main/bootclasspath -Xcomp -Xbatch
|
* @run main/bootclasspath/othervm -Xcomp -Xbatch
|
||||||
* -XX:CompileCommand=compileonly,InvokerGC::test
|
* -XX:CompileCommand=compileonly,InvokerGC::test
|
||||||
* -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI
|
* -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI
|
||||||
* InvokerGC
|
* InvokerGC
|
||||||
|
@ -28,7 +28,7 @@
|
|||||||
* @modules java.base/jdk.internal.vm.annotation
|
* @modules java.base/jdk.internal.vm.annotation
|
||||||
* @build java.base/java.lang.invoke.MethodHandleHelper
|
* @build java.base/java.lang.invoke.MethodHandleHelper
|
||||||
* @build sun.hotspot.WhiteBox
|
* @build sun.hotspot.WhiteBox
|
||||||
* @run main/bootclasspath -XX:+IgnoreUnrecognizedVMOptions
|
* @run main/bootclasspath/othervm -XX:+IgnoreUnrecognizedVMOptions
|
||||||
* -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI
|
* -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI
|
||||||
* -Xbatch -XX:-TieredCompilation -XX:CICompilerCount=1
|
* -Xbatch -XX:-TieredCompilation -XX:CICompilerCount=1
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
|
@ -29,7 +29,7 @@
|
|||||||
* @build java.base/java.lang.invoke.MethodHandleHelper
|
* @build java.base/java.lang.invoke.MethodHandleHelper
|
||||||
* @build sun.hotspot.WhiteBox
|
* @build sun.hotspot.WhiteBox
|
||||||
* @build compiler.jsr292.NonInlinedCall.InvokeTest
|
* @build compiler.jsr292.NonInlinedCall.InvokeTest
|
||||||
* @run main/bootclasspath -XX:+IgnoreUnrecognizedVMOptions
|
* @run main/bootclasspath/othervm -XX:+IgnoreUnrecognizedVMOptions
|
||||||
* -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI
|
* -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI
|
||||||
* -Xbatch -XX:-TieredCompilation -XX:CICompilerCount=1
|
* -Xbatch -XX:-TieredCompilation -XX:CICompilerCount=1
|
||||||
* compiler.jsr292.NonInlinedCall.InvokeTest
|
* compiler.jsr292.NonInlinedCall.InvokeTest
|
||||||
|
@ -35,7 +35,7 @@
|
|||||||
* @run main ClassFileInstaller sun.hotspot.WhiteBox
|
* @run main ClassFileInstaller sun.hotspot.WhiteBox
|
||||||
* sun.hotspot.WhiteBox$WhiteBoxPermission
|
* sun.hotspot.WhiteBox$WhiteBoxPermission
|
||||||
* compiler.jsr292.NonInlinedCall.RedefineTest
|
* compiler.jsr292.NonInlinedCall.RedefineTest
|
||||||
* @run main/bootclasspath -javaagent:agent.jar
|
* @run main/bootclasspath/othervm -javaagent:agent.jar
|
||||||
* -XX:+IgnoreUnrecognizedVMOptions
|
* -XX:+IgnoreUnrecognizedVMOptions
|
||||||
* -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI
|
* -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI
|
||||||
* -Xbatch -XX:-TieredCompilation -XX:CICompilerCount=1
|
* -Xbatch -XX:-TieredCompilation -XX:CICompilerCount=1
|
||||||
|
@ -26,7 +26,7 @@
|
|||||||
* @bug 8058828
|
* @bug 8058828
|
||||||
* @modules java.base/jdk.internal.org.objectweb.asm
|
* @modules java.base/jdk.internal.org.objectweb.asm
|
||||||
* java.base/jdk.internal.misc
|
* java.base/jdk.internal.misc
|
||||||
* @run main/bootclasspath -Xbatch VMAnonymousClasses
|
* @run main/bootclasspath/othervm -Xbatch VMAnonymousClasses
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import jdk.internal.org.objectweb.asm.ClassWriter;
|
import jdk.internal.org.objectweb.asm.ClassWriter;
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -31,23 +31,23 @@
|
|||||||
* @build sun.hotspot.WhiteBox
|
* @build sun.hotspot.WhiteBox
|
||||||
* @build compiler.stable.TestStableBoolean
|
* @build compiler.stable.TestStableBoolean
|
||||||
*
|
*
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
* compiler.stable.TestStableBoolean
|
* compiler.stable.TestStableBoolean
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:-FoldStableValues
|
* -XX:-FoldStableValues
|
||||||
* compiler.stable.TestStableBoolean
|
* compiler.stable.TestStableBoolean
|
||||||
*
|
*
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
||||||
* -XX:+TieredCompilation -XX:TieredStopAtLevel=1
|
* -XX:+TieredCompilation -XX:TieredStopAtLevel=1
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
* compiler.stable.TestStableBoolean
|
* compiler.stable.TestStableBoolean
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
||||||
* -XX:+TieredCompilation -XX:TieredStopAtLevel=1
|
* -XX:+TieredCompilation -XX:TieredStopAtLevel=1
|
||||||
* -XX:-FoldStableValues
|
* -XX:-FoldStableValues
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -31,23 +31,23 @@
|
|||||||
* @build sun.hotspot.WhiteBox
|
* @build sun.hotspot.WhiteBox
|
||||||
* @build compiler.stable.TestStableByte
|
* @build compiler.stable.TestStableByte
|
||||||
*
|
*
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
* compiler.stable.TestStableByte
|
* compiler.stable.TestStableByte
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
* compiler.stable.TestStableByte
|
* compiler.stable.TestStableByte
|
||||||
*
|
*
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
* compiler.stable.TestStableByte
|
* compiler.stable.TestStableByte
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -31,23 +31,23 @@
|
|||||||
* @build sun.hotspot.WhiteBox
|
* @build sun.hotspot.WhiteBox
|
||||||
* @build compiler.stable.TestStableChar
|
* @build compiler.stable.TestStableChar
|
||||||
*
|
*
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
* compiler.stable.TestStableChar
|
* compiler.stable.TestStableChar
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
* compiler.stable.TestStableChar
|
* compiler.stable.TestStableChar
|
||||||
*
|
*
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
* compiler.stable.TestStableChar
|
* compiler.stable.TestStableChar
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -31,23 +31,23 @@
|
|||||||
* @build sun.hotspot.WhiteBox
|
* @build sun.hotspot.WhiteBox
|
||||||
* @build compiler.stable.TestStableDouble
|
* @build compiler.stable.TestStableDouble
|
||||||
*
|
*
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
* compiler.stable.TestStableDouble
|
* compiler.stable.TestStableDouble
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
* compiler.stable.TestStableDouble
|
* compiler.stable.TestStableDouble
|
||||||
*
|
*
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
* compiler.stable.TestStableDouble
|
* compiler.stable.TestStableDouble
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -31,23 +31,23 @@
|
|||||||
* @build sun.hotspot.WhiteBox
|
* @build sun.hotspot.WhiteBox
|
||||||
* @build compiler.stable.TestStableFloat
|
* @build compiler.stable.TestStableFloat
|
||||||
*
|
*
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
* compiler.stable.TestStableFloat
|
* compiler.stable.TestStableFloat
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
* compiler.stable.TestStableFloat
|
* compiler.stable.TestStableFloat
|
||||||
*
|
*
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
* compiler.stable.TestStableFloat
|
* compiler.stable.TestStableFloat
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -31,23 +31,23 @@
|
|||||||
* @build sun.hotspot.WhiteBox
|
* @build sun.hotspot.WhiteBox
|
||||||
* @build compiler.stable.TestStableInt
|
* @build compiler.stable.TestStableInt
|
||||||
*
|
*
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
* compiler.stable.TestStableInt
|
* compiler.stable.TestStableInt
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
* compiler.stable.TestStableInt
|
* compiler.stable.TestStableInt
|
||||||
*
|
*
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
* compiler.stable.TestStableInt
|
* compiler.stable.TestStableInt
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -31,23 +31,23 @@
|
|||||||
* @build sun.hotspot.WhiteBox
|
* @build sun.hotspot.WhiteBox
|
||||||
* @build compiler.stable.TestStableLong
|
* @build compiler.stable.TestStableLong
|
||||||
*
|
*
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
* compiler.stable.TestStableLong
|
* compiler.stable.TestStableLong
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
* compiler.stable.TestStableLong
|
* compiler.stable.TestStableLong
|
||||||
*
|
*
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
* compiler.stable.TestStableLong
|
* compiler.stable.TestStableLong
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -30,7 +30,7 @@
|
|||||||
* @library /testlibrary /test/lib
|
* @library /testlibrary /test/lib
|
||||||
* @modules java.base/jdk.internal.vm.annotation
|
* @modules java.base/jdk.internal.vm.annotation
|
||||||
*
|
*
|
||||||
* @run main/bootclasspath -Xcomp -XX:CompileOnly=::testCompile
|
* @run main/bootclasspath/othervm -Xcomp -XX:CompileOnly=::testCompile
|
||||||
* compiler.stable.TestStableMemoryBarrier
|
* compiler.stable.TestStableMemoryBarrier
|
||||||
*
|
*
|
||||||
* @author hui.shi@linaro.org
|
* @author hui.shi@linaro.org
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -31,23 +31,23 @@
|
|||||||
* @build sun.hotspot.WhiteBox
|
* @build sun.hotspot.WhiteBox
|
||||||
* @build compiler.stable.TestStableObject
|
* @build compiler.stable.TestStableObject
|
||||||
*
|
*
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
* compiler.stable.TestStableObject
|
* compiler.stable.TestStableObject
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
* compiler.stable.TestStableObject
|
* compiler.stable.TestStableObject
|
||||||
*
|
*
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
* compiler.stable.TestStableObject
|
* compiler.stable.TestStableObject
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2014, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -31,23 +31,23 @@
|
|||||||
* @build sun.hotspot.WhiteBox
|
* @build sun.hotspot.WhiteBox
|
||||||
* @build compiler.stable.TestStableShort
|
* @build compiler.stable.TestStableShort
|
||||||
*
|
*
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
* compiler.stable.TestStableShort
|
* compiler.stable.TestStableShort
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
* compiler.stable.TestStableShort
|
* compiler.stable.TestStableShort
|
||||||
*
|
*
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
* compiler.stable.TestStableShort
|
* compiler.stable.TestStableShort
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
* -XX:CompileOnly=::get,::get1,::get2,::get3,::get4
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
|
@ -31,26 +31,26 @@
|
|||||||
* @build sun.hotspot.WhiteBox
|
* @build sun.hotspot.WhiteBox
|
||||||
* @build compiler.stable.TestStableUByte
|
* @build compiler.stable.TestStableUByte
|
||||||
*
|
*
|
||||||
* @run main/bootclasspath -XX:+IgnoreUnrecognizedVMOptions -XX:+AlwaysIncrementalInline
|
* @run main/bootclasspath/othervm -XX:+IgnoreUnrecognizedVMOptions -XX:+AlwaysIncrementalInline
|
||||||
* -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
* -XX:CompileOnly=::get,::get1
|
* -XX:CompileOnly=::get,::get1
|
||||||
* compiler.stable.TestStableUByte
|
* compiler.stable.TestStableUByte
|
||||||
* @run main/bootclasspath -XX:+IgnoreUnrecognizedVMOptions -XX:+AlwaysIncrementalInline
|
* @run main/bootclasspath/othervm -XX:+IgnoreUnrecognizedVMOptions -XX:+AlwaysIncrementalInline
|
||||||
* -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:-FoldStableValues
|
* -XX:-FoldStableValues
|
||||||
* -XX:CompileOnly=::get,::get1
|
* -XX:CompileOnly=::get,::get1
|
||||||
* compiler.stable.TestStableUByte
|
* compiler.stable.TestStableUByte
|
||||||
*
|
*
|
||||||
* @run main/bootclasspath -XX:+IgnoreUnrecognizedVMOptions -XX:+AlwaysIncrementalInline
|
* @run main/bootclasspath/othervm -XX:+IgnoreUnrecognizedVMOptions -XX:+AlwaysIncrementalInline
|
||||||
* -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:+TieredCompilation -XX:TieredStopAtLevel=1
|
* -XX:+TieredCompilation -XX:TieredStopAtLevel=1
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
* -XX:CompileOnly=::get,::get1
|
* -XX:CompileOnly=::get,::get1
|
||||||
* compiler.stable.TestStableUByte
|
* compiler.stable.TestStableUByte
|
||||||
* @run main/bootclasspath -XX:+IgnoreUnrecognizedVMOptions -XX:+AlwaysIncrementalInline
|
* @run main/bootclasspath/othervm -XX:+IgnoreUnrecognizedVMOptions -XX:+AlwaysIncrementalInline
|
||||||
* -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:+TieredCompilation -XX:TieredStopAtLevel=1
|
* -XX:+TieredCompilation -XX:TieredStopAtLevel=1
|
||||||
* -XX:-FoldStableValues
|
* -XX:-FoldStableValues
|
||||||
|
@ -31,26 +31,26 @@
|
|||||||
* @build sun.hotspot.WhiteBox
|
* @build sun.hotspot.WhiteBox
|
||||||
* @build compiler.stable.TestStableUShort
|
* @build compiler.stable.TestStableUShort
|
||||||
*
|
*
|
||||||
* @run main/bootclasspath -XX:+IgnoreUnrecognizedVMOptions -XX:+AlwaysIncrementalInline
|
* @run main/bootclasspath/othervm -XX:+IgnoreUnrecognizedVMOptions -XX:+AlwaysIncrementalInline
|
||||||
* -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
* -XX:CompileOnly=::get,::get1
|
* -XX:CompileOnly=::get,::get1
|
||||||
* compiler.stable.TestStableUShort
|
* compiler.stable.TestStableUShort
|
||||||
* @run main/bootclasspath -XX:+IgnoreUnrecognizedVMOptions -XX:+AlwaysIncrementalInline
|
* @run main/bootclasspath/othervm -XX:+IgnoreUnrecognizedVMOptions -XX:+AlwaysIncrementalInline
|
||||||
* -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:-TieredCompilation
|
* -XX:-TieredCompilation
|
||||||
* -XX:-FoldStableValues
|
* -XX:-FoldStableValues
|
||||||
* -XX:CompileOnly=::get,::get1
|
* -XX:CompileOnly=::get,::get1
|
||||||
* compiler.stable.TestStableUShort
|
* compiler.stable.TestStableUShort
|
||||||
*
|
*
|
||||||
* @run main/bootclasspath -XX:+IgnoreUnrecognizedVMOptions -XX:+AlwaysIncrementalInline
|
* @run main/bootclasspath/othervm -XX:+IgnoreUnrecognizedVMOptions -XX:+AlwaysIncrementalInline
|
||||||
* -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:+TieredCompilation -XX:TieredStopAtLevel=1
|
* -XX:+TieredCompilation -XX:TieredStopAtLevel=1
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
* -XX:CompileOnly=::get,::get1
|
* -XX:CompileOnly=::get,::get1
|
||||||
* compiler.stable.TestStableUShort
|
* compiler.stable.TestStableUShort
|
||||||
* @run main/bootclasspath -XX:+IgnoreUnrecognizedVMOptions -XX:+AlwaysIncrementalInline
|
* @run main/bootclasspath/othervm -XX:+IgnoreUnrecognizedVMOptions -XX:+AlwaysIncrementalInline
|
||||||
* -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
* -XX:+UnlockDiagnosticVMOptions -XX:+WhiteBoxAPI -Xcomp
|
||||||
* -XX:+TieredCompilation -XX:TieredStopAtLevel=1
|
* -XX:+TieredCompilation -XX:TieredStopAtLevel=1
|
||||||
* -XX:-FoldStableValues
|
* -XX:-FoldStableValues
|
||||||
|
@ -33,21 +33,23 @@
|
|||||||
* @modules java.base/jdk.internal.org.objectweb.asm
|
* @modules java.base/jdk.internal.org.objectweb.asm
|
||||||
* java.base/jdk.internal.vm.annotation
|
* java.base/jdk.internal.vm.annotation
|
||||||
* java.base/jdk.internal.misc
|
* java.base/jdk.internal.misc
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions
|
||||||
* -Xbatch -XX:-TieredCompilation
|
* -Xbatch -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
* -XX:CompileCommand=dontinline,UnsafeGetConstantField.checkGetAddress()
|
* -XX:CompileCommand=dontinline,UnsafeGetConstantField.checkGetAddress()
|
||||||
* -XX:CompileCommand=dontinline,*.test*
|
* -XX:CompileCommand=dontinline,*.test*
|
||||||
* -XX:+UseUnalignedAccesses
|
* -XX:+UseUnalignedAccesses
|
||||||
|
* -XaddReads:java.base=ALL-UNNAMED
|
||||||
* compiler.unsafe.UnsafeGetConstantField
|
* compiler.unsafe.UnsafeGetConstantField
|
||||||
*
|
*
|
||||||
* @run main/bootclasspath -XX:+UnlockDiagnosticVMOptions
|
* @run main/bootclasspath/othervm -XX:+UnlockDiagnosticVMOptions
|
||||||
* -Xbatch -XX:-TieredCompilation
|
* -Xbatch -XX:-TieredCompilation
|
||||||
* -XX:+FoldStableValues
|
* -XX:+FoldStableValues
|
||||||
* -XX:CompileCommand=dontinline,UnsafeGetConstantField.checkGetAddress()
|
* -XX:CompileCommand=dontinline,UnsafeGetConstantField.checkGetAddress()
|
||||||
* -XX:CompileCommand=dontinline,*.test*
|
* -XX:CompileCommand=dontinline,*.test*
|
||||||
* -XX:CompileCommand=inline,*Unsafe.get*
|
* -XX:CompileCommand=inline,*Unsafe.get*
|
||||||
* -XX:-UseUnalignedAccesses
|
* -XX:-UseUnalignedAccesses
|
||||||
|
* -XaddReads:java.base=ALL-UNNAMED
|
||||||
* compiler.unsafe.UnsafeGetConstantField
|
* compiler.unsafe.UnsafeGetConstantField
|
||||||
*/
|
*/
|
||||||
package compiler.unsafe;
|
package compiler.unsafe;
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -48,7 +48,7 @@ public class BootstrapRedefine {
|
|||||||
"-Xmodule:java.base"),
|
"-Xmodule:java.base"),
|
||||||
"mods/java.base");
|
"mods/java.base");
|
||||||
|
|
||||||
ProcessBuilder pb = ProcessTools.createJavaProcessBuilder("-Xpatch:mods", "-version");
|
ProcessBuilder pb = ProcessTools.createJavaProcessBuilder("-Xpatch:java.base=mods/java.base", "-version");
|
||||||
new OutputAnalyzer(pb.start())
|
new OutputAnalyzer(pb.start())
|
||||||
.shouldContain("Incompatible definition of java.lang.Object")
|
.shouldContain("Incompatible definition of java.lang.Object")
|
||||||
.shouldHaveExitValue(1);
|
.shouldHaveExitValue(1);
|
||||||
|
@ -35,7 +35,7 @@ import jdk.test.lib.*;
|
|||||||
public class MaxMetaspaceSize {
|
public class MaxMetaspaceSize {
|
||||||
public static void main(String[] args) throws Exception {
|
public static void main(String[] args) throws Exception {
|
||||||
ProcessBuilder pb = ProcessTools.createJavaProcessBuilder(
|
ProcessBuilder pb = ProcessTools.createJavaProcessBuilder(
|
||||||
"-XX:MaxMetaspaceSize=20m", "-Xshare:dump");
|
"-XX:MaxMetaspaceSize=10m", "-Xshare:dump");
|
||||||
OutputAnalyzer output = new OutputAnalyzer(pb.start());
|
OutputAnalyzer output = new OutputAnalyzer(pb.start());
|
||||||
output.shouldContain("is not large enough.\nEither don't specify the -XX:MaxMetaspaceSize=<size>\nor increase the size to at least");
|
output.shouldContain("is not large enough.\nEither don't specify the -XX:MaxMetaspaceSize=<size>\nor increase the size to at least");
|
||||||
output.shouldHaveExitValue(2);
|
output.shouldHaveExitValue(2);
|
||||||
|
@ -119,9 +119,9 @@ public class GetSysPkgTest {
|
|||||||
getPkg("java/nio/charset", "jrt:/java.base");
|
getPkg("java/nio/charset", "jrt:/java.base");
|
||||||
|
|
||||||
// Test a package in a module not owned by boot loader.
|
// Test a package in a module not owned by boot loader.
|
||||||
Class clss = Class.forName("javax.activation.DataHandler");
|
Class clss = Class.forName("jdk.nio.zipfs.ZipPath");
|
||||||
if (clss == null)
|
if (clss == null)
|
||||||
throw new RuntimeException("Could not find class javax.activation.DataHandler");
|
throw new RuntimeException("Could not find class jdk.nio.zipfs.ZipPath");
|
||||||
getPkg("javax/activation", null); // Not owned by boot loader
|
getPkg("javax/activation", null); // Not owned by boot loader
|
||||||
|
|
||||||
// Test a package not in jimage file.
|
// Test a package not in jimage file.
|
||||||
|
@ -209,9 +209,9 @@ public class DiffCL_Umod {
|
|||||||
// now use the same loader to load class p1.c1Loose
|
// now use the same loader to load class p1.c1Loose
|
||||||
Class p1_c1_class = MyDiffClassLoader.loader1.loadClass("p1.c1Loose");
|
Class p1_c1_class = MyDiffClassLoader.loader1.loadClass("p1.c1Loose");
|
||||||
|
|
||||||
// change m1 to be a loose module
|
// change m1 to read all unnamed modules
|
||||||
Module m1 = layer.findModule("m1").get();
|
Module m1 = layer.findModule("m1").get();
|
||||||
jdk.internal.module.Modules.addReads(m1, null);
|
jdk.internal.module.Modules.addReadsAllUnnamed(m1);
|
||||||
|
|
||||||
try {
|
try {
|
||||||
p1_c1_class.newInstance();
|
p1_c1_class.newInstance();
|
||||||
|
@ -200,9 +200,9 @@ public class Umod {
|
|||||||
// now use the same loader to load class p1.c1Loose
|
// now use the same loader to load class p1.c1Loose
|
||||||
Class p1_c1_class = loader.loadClass("p1.c1Loose");
|
Class p1_c1_class = loader.loadClass("p1.c1Loose");
|
||||||
|
|
||||||
// change m1 to be a loose module
|
// change m1 to read all unnamed modules
|
||||||
Module m1 = layer.findModule("m1").get();
|
Module m1 = layer.findModule("m1").get();
|
||||||
jdk.internal.module.Modules.addReads(m1, null);
|
jdk.internal.module.Modules.addReadsAllUnnamed(m1);
|
||||||
|
|
||||||
try {
|
try {
|
||||||
p1_c1_class.newInstance();
|
p1_c1_class.newInstance();
|
||||||
|
@ -48,7 +48,7 @@ public class JVMAddReadsModule {
|
|||||||
assertNotNull(to_module, "Module should not be null");
|
assertNotNull(to_module, "Module should not be null");
|
||||||
ModuleHelper.DefineModule(to_module, "9.0", "to_module/here", new String[] { "yourpackage" });
|
ModuleHelper.DefineModule(to_module, "9.0", "to_module/here", new String[] { "yourpackage" });
|
||||||
|
|
||||||
// Null from_module argument, expect an NPE
|
// Null from_module argument, expect NPE
|
||||||
try {
|
try {
|
||||||
ModuleHelper.AddReadsModule(null, to_module);
|
ModuleHelper.AddReadsModule(null, to_module);
|
||||||
throw new RuntimeException("Failed to get the expected NPE");
|
throw new RuntimeException("Failed to get the expected NPE");
|
||||||
@ -56,14 +56,15 @@ public class JVMAddReadsModule {
|
|||||||
// Expected
|
// Expected
|
||||||
}
|
}
|
||||||
|
|
||||||
// Null to_module argument, do not expect an NPE
|
// Null to_module argument, expect NPE
|
||||||
try {
|
try {
|
||||||
ModuleHelper.AddReadsModule(from_module, null);
|
ModuleHelper.AddReadsModule(from_module, null);
|
||||||
} catch(NullPointerException e) {
|
|
||||||
throw new RuntimeException("Unexpected NPE was thrown");
|
throw new RuntimeException("Unexpected NPE was thrown");
|
||||||
|
} catch (NullPointerException e) {
|
||||||
|
// Expected
|
||||||
}
|
}
|
||||||
|
|
||||||
// Null from_module and to_module arguments, expect an NPE
|
// Null from_module and to_module arguments, expect NPE
|
||||||
try {
|
try {
|
||||||
ModuleHelper.AddReadsModule(null, null);
|
ModuleHelper.AddReadsModule(null, null);
|
||||||
throw new RuntimeException("Failed to get the expected NPE");
|
throw new RuntimeException("Failed to get the expected NPE");
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -83,7 +83,7 @@ public class XpatchVisibility {
|
|||||||
"p2" + File.separator + "Vis2_B.class"));
|
"p2" + File.separator + "Vis2_B.class"));
|
||||||
|
|
||||||
new OutputAnalyzer(ProcessTools.createJavaProcessBuilder(
|
new OutputAnalyzer(ProcessTools.createJavaProcessBuilder(
|
||||||
"-Xpatch:mods2",
|
"-Xpatch:java.base=mods2/java.base",
|
||||||
"-XaddExports:java.base/p2=ALL-UNNAMED",
|
"-XaddExports:java.base/p2=ALL-UNNAMED",
|
||||||
"Vis2_A")
|
"Vis2_A")
|
||||||
.start()).shouldHaveExitValue(0);
|
.start()).shouldHaveExitValue(0);
|
||||||
|
96
hotspot/test/runtime/modules/Xpatch/BasicJarBuilder.java
Normal file
96
hotspot/test/runtime/modules/Xpatch/BasicJarBuilder.java
Normal file
@ -0,0 +1,96 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2015, 2016, 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.
|
||||||
|
*
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* @summary Simple jar builder
|
||||||
|
* Input: jarName className1 className2 ...
|
||||||
|
* do not specify extensions, just the names
|
||||||
|
* E.g. prot_domain ProtDomainA ProtDomainB
|
||||||
|
* Output: A jar containing compiled classes, placed in a test classes folder
|
||||||
|
*/
|
||||||
|
|
||||||
|
import jdk.test.lib.*;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import sun.tools.jar.Main;
|
||||||
|
|
||||||
|
// Using JarBuilder requires that all to-be-jarred classes should be placed
|
||||||
|
// in the current working directory, aka "."
|
||||||
|
public class BasicJarBuilder {
|
||||||
|
private static final String classDir = System.getProperty("test.classes");
|
||||||
|
|
||||||
|
public static void build(boolean classesInWorkDir, String jarName,
|
||||||
|
String ...classNames) throws Exception {
|
||||||
|
|
||||||
|
if (classesInWorkDir) {
|
||||||
|
createSimpleJar(".", classDir + File.separator + jarName + ".jar", classNames);
|
||||||
|
} else {
|
||||||
|
build(jarName, classNames);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void build(String jarName, String ...classNames) throws Exception {
|
||||||
|
createSimpleJar(classDir, classDir + File.separator + jarName + ".jar",
|
||||||
|
classNames);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void createSimpleJar(String jarclassDir, String jarName,
|
||||||
|
String[] classNames) throws Exception {
|
||||||
|
ArrayList<String> args = new ArrayList<String>();
|
||||||
|
args.add("cf");
|
||||||
|
args.add(jarName);
|
||||||
|
addClassArgs(args, jarclassDir, classNames);
|
||||||
|
createJar(args);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void addClassArgs(ArrayList<String> args, String jarclassDir,
|
||||||
|
String[] classNames) {
|
||||||
|
|
||||||
|
for (String name : classNames) {
|
||||||
|
args.add("-C");
|
||||||
|
args.add(jarclassDir);
|
||||||
|
args.add(name + ".class");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void createJar(ArrayList<String> args) {
|
||||||
|
Main jarTool = new Main(System.out, System.err, "jar");
|
||||||
|
if (!jarTool.run(args.toArray(new String[1]))) {
|
||||||
|
throw new RuntimeException("jar operation failed");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get full path to the test jar
|
||||||
|
public static String getTestJar(String jar) {
|
||||||
|
File dir = new File(System.getProperty("test.classes", "."));
|
||||||
|
File jarFile = new File(dir, jar);
|
||||||
|
if (!jarFile.exists()) {
|
||||||
|
throw new RuntimeException("Cannot find " + jarFile.getPath());
|
||||||
|
}
|
||||||
|
if (!jarFile.isFile()) {
|
||||||
|
throw new RuntimeException("Not a regular file: " + jarFile.getPath());
|
||||||
|
}
|
||||||
|
return jarFile.getPath();
|
||||||
|
}
|
||||||
|
}
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -57,7 +57,8 @@ public class Xpatch2Dirs {
|
|||||||
"mods2/java.desktop");
|
"mods2/java.desktop");
|
||||||
|
|
||||||
ProcessBuilder pb = ProcessTools.createJavaProcessBuilder(
|
ProcessBuilder pb = ProcessTools.createJavaProcessBuilder(
|
||||||
"-Xpatch:mods" + File.pathSeparator + "mods2",
|
"-Xpatch:java.naming=mods/java.naming",
|
||||||
|
"-Xpatch:java.desktop=mods2/java.desktop",
|
||||||
"Xpatch2DirsMain", "javax.naming.spi.NamingManager", "java.beans.Encoder");
|
"Xpatch2DirsMain", "javax.naming.spi.NamingManager", "java.beans.Encoder");
|
||||||
|
|
||||||
OutputAnalyzer oa = new OutputAnalyzer(pb.start());
|
OutputAnalyzer oa = new OutputAnalyzer(pb.start());
|
||||||
|
45
hotspot/test/runtime/modules/Xpatch/XpatchDupJavaBase.java
Normal file
45
hotspot/test/runtime/modules/Xpatch/XpatchDupJavaBase.java
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2016, 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.
|
||||||
|
*
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* @test
|
||||||
|
* @summary VM exit initialization results if java.base is specificed more than once to Xpatch.
|
||||||
|
* @library /testlibrary
|
||||||
|
*/
|
||||||
|
|
||||||
|
import jdk.test.lib.*;
|
||||||
|
|
||||||
|
public class XpatchDupJavaBase {
|
||||||
|
// The VM should exit initialization if java.base is specified
|
||||||
|
// more than once to -Xpatch.
|
||||||
|
public static void main(String args[]) throws Exception {
|
||||||
|
ProcessBuilder pb = ProcessTools.createJavaProcessBuilder(
|
||||||
|
"-Xpatch:java.base=javabase_dir",
|
||||||
|
"-Xpatch:java.base=javabase_dir",
|
||||||
|
"-version");
|
||||||
|
OutputAnalyzer output = new OutputAnalyzer(pb.start());
|
||||||
|
output.shouldContain("Cannot specify java.base more than once to -Xpatch");
|
||||||
|
output.shouldHaveExitValue(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
47
hotspot/test/runtime/modules/Xpatch/XpatchDupModule.java
Normal file
47
hotspot/test/runtime/modules/Xpatch/XpatchDupModule.java
Normal file
@ -0,0 +1,47 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2016, 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.
|
||||||
|
*
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* @test
|
||||||
|
* @summary Module system initialization exception results if a module is specificed twice to Xpatch.
|
||||||
|
* @library /testlibrary
|
||||||
|
*/
|
||||||
|
|
||||||
|
import jdk.test.lib.*;
|
||||||
|
|
||||||
|
public class XpatchDupModule {
|
||||||
|
|
||||||
|
// The module system initialization should generate an ExceptionInInitializerError
|
||||||
|
// if -Xpatch is specified with the same module more than once.
|
||||||
|
|
||||||
|
public static void main(String args[]) throws Exception {
|
||||||
|
ProcessBuilder pb = ProcessTools.createJavaProcessBuilder(
|
||||||
|
"-Xpatch:module1=module1_dir",
|
||||||
|
"-Xpatch:module1=module1_dir",
|
||||||
|
"-version");
|
||||||
|
OutputAnalyzer output = new OutputAnalyzer(pb.start());
|
||||||
|
output.shouldContain("java.lang.ExceptionInInitializerError");
|
||||||
|
output.shouldHaveExitValue(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
56
hotspot/test/runtime/modules/Xpatch/XpatchJavaBase.java
Normal file
56
hotspot/test/runtime/modules/Xpatch/XpatchJavaBase.java
Normal file
@ -0,0 +1,56 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2016, 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.
|
||||||
|
*
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* @test
|
||||||
|
* @bug 8130399
|
||||||
|
* @summary Make sure -Xpatch works for java.base.
|
||||||
|
* @library /testlibrary
|
||||||
|
* @compile XpatchMain.java
|
||||||
|
* @run main XpatchJavaBase
|
||||||
|
*/
|
||||||
|
|
||||||
|
import jdk.test.lib.*;
|
||||||
|
|
||||||
|
public class XpatchJavaBase {
|
||||||
|
|
||||||
|
public static void main(String[] args) throws Exception {
|
||||||
|
String source = "package java.lang; " +
|
||||||
|
"public class NewClass { " +
|
||||||
|
" static { " +
|
||||||
|
" System.out.println(\"I pass!\"); " +
|
||||||
|
" } " +
|
||||||
|
"}";
|
||||||
|
|
||||||
|
ClassFileInstaller.writeClassToDisk("java/lang/NewClass",
|
||||||
|
InMemoryJavaCompiler.compile("java.lang.NewClass", source, "-Xmodule:java.base"),
|
||||||
|
"mods/java.base");
|
||||||
|
|
||||||
|
ProcessBuilder pb = ProcessTools.createJavaProcessBuilder("-Xpatch:java.base=mods/java.base",
|
||||||
|
"XpatchMain", "java.lang.NewClass");
|
||||||
|
|
||||||
|
new OutputAnalyzer(pb.start())
|
||||||
|
.shouldContain("I pass!")
|
||||||
|
.shouldHaveExitValue(0);
|
||||||
|
}
|
||||||
|
}
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -46,7 +46,7 @@ public class XpatchTest {
|
|||||||
InMemoryJavaCompiler.compile("javax.naming.spi.NamingManager", source, "-Xmodule:java.naming"),
|
InMemoryJavaCompiler.compile("javax.naming.spi.NamingManager", source, "-Xmodule:java.naming"),
|
||||||
"mods/java.naming");
|
"mods/java.naming");
|
||||||
|
|
||||||
ProcessBuilder pb = ProcessTools.createJavaProcessBuilder("-Xpatch:mods",
|
ProcessBuilder pb = ProcessTools.createJavaProcessBuilder("-Xpatch:java.naming=mods/java.naming",
|
||||||
"XpatchMain", "javax.naming.spi.NamingManager");
|
"XpatchMain", "javax.naming.spi.NamingManager");
|
||||||
|
|
||||||
new OutputAnalyzer(pb.start())
|
new OutputAnalyzer(pb.start())
|
||||||
|
83
hotspot/test/runtime/modules/Xpatch/XpatchTestJar.java
Normal file
83
hotspot/test/runtime/modules/Xpatch/XpatchTestJar.java
Normal file
@ -0,0 +1,83 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2016, 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.
|
||||||
|
*
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* @test
|
||||||
|
* @summary Make sure -Xpatch works when a jar file is specified for a module
|
||||||
|
* @library /testlibrary
|
||||||
|
* @modules java.base/jdk.internal.misc
|
||||||
|
* jdk.jartool/sun.tools.jar
|
||||||
|
* @build BasicJarBuilder
|
||||||
|
* @compile XpatchMain.java
|
||||||
|
* @run main XpatchTestJar
|
||||||
|
*/
|
||||||
|
|
||||||
|
import jdk.test.lib.*;
|
||||||
|
|
||||||
|
public class XpatchTestJar {
|
||||||
|
private static String moduleJar;
|
||||||
|
|
||||||
|
public static void main(String[] args) throws Exception {
|
||||||
|
|
||||||
|
// Create a class file in the module java.naming. This class file
|
||||||
|
// will be put in the javanaming.jar file.
|
||||||
|
String source = "package javax.naming.spi; " +
|
||||||
|
"public class NamingManager { " +
|
||||||
|
" static { " +
|
||||||
|
" System.out.println(\"I pass!\"); " +
|
||||||
|
" } " +
|
||||||
|
"}";
|
||||||
|
|
||||||
|
ClassFileInstaller.writeClassToDisk("javax/naming/spi/NamingManager",
|
||||||
|
InMemoryJavaCompiler.compile("javax.naming.spi.NamingManager", source, "-Xmodule:java.naming"),
|
||||||
|
System.getProperty("test.classes"));
|
||||||
|
|
||||||
|
// Build the jar file that will be used for the module "java.naming".
|
||||||
|
BasicJarBuilder.build("javanaming", "javax/naming/spi/NamingManager");
|
||||||
|
moduleJar = BasicJarBuilder.getTestJar("javanaming.jar");
|
||||||
|
|
||||||
|
// Just to make sure we are not fooled by the class file being on the
|
||||||
|
// class path where all the test classes are stored, write the NamingManager.class
|
||||||
|
// file out again with output that does not contain what OutputAnalyzer
|
||||||
|
// expects. This will provide confidence that the contents of the class
|
||||||
|
// is truly coming from the jar file and not the class file.
|
||||||
|
source = "package javax.naming.spi; " +
|
||||||
|
"public class NamingManager { " +
|
||||||
|
" static { " +
|
||||||
|
" System.out.println(\"Fail!\"); " +
|
||||||
|
" } " +
|
||||||
|
"}";
|
||||||
|
|
||||||
|
ClassFileInstaller.writeClassToDisk("javax/naming/spi/NamingManager",
|
||||||
|
InMemoryJavaCompiler.compile("javax.naming.spi.NamingManager", source, "-Xmodule:java.naming"),
|
||||||
|
System.getProperty("test.classes"));
|
||||||
|
|
||||||
|
// Supply -Xpatch with the name of the jar file for the module java.naming.
|
||||||
|
ProcessBuilder pb = ProcessTools.createJavaProcessBuilder("-Xpatch:java.naming=" + moduleJar,
|
||||||
|
"XpatchMain", "javax.naming.spi.NamingManager");
|
||||||
|
|
||||||
|
new OutputAnalyzer(pb.start())
|
||||||
|
.shouldContain("I pass!")
|
||||||
|
.shouldHaveExitValue(0);
|
||||||
|
}
|
||||||
|
}
|
105
hotspot/test/runtime/modules/Xpatch/XpatchTestJarDir.java
Normal file
105
hotspot/test/runtime/modules/Xpatch/XpatchTestJarDir.java
Normal file
@ -0,0 +1,105 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2016, 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.
|
||||||
|
*
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* @test
|
||||||
|
* @summary Make sure -Xpatch works when a jar file and a directory is specified for a module
|
||||||
|
* @library /testlibrary
|
||||||
|
* @modules java.base/jdk.internal.misc
|
||||||
|
* jdk.jartool/sun.tools.jar
|
||||||
|
* @build BasicJarBuilder
|
||||||
|
* @compile Xpatch2DirsMain.java
|
||||||
|
* @run main XpatchTestJarDir
|
||||||
|
*/
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.nio.file.Files;
|
||||||
|
import jdk.test.lib.*;
|
||||||
|
|
||||||
|
public class XpatchTestJarDir {
|
||||||
|
private static String moduleJar;
|
||||||
|
|
||||||
|
public static void main(String[] args) throws Exception {
|
||||||
|
|
||||||
|
// Create a class file in the module java.naming. This class file
|
||||||
|
// will be put in the javanaming.jar file.
|
||||||
|
String source = "package javax.naming.spi; " +
|
||||||
|
"public class NamingManager1 { " +
|
||||||
|
" static { " +
|
||||||
|
" System.out.println(\"I pass one!\"); " +
|
||||||
|
" } " +
|
||||||
|
"}";
|
||||||
|
|
||||||
|
ClassFileInstaller.writeClassToDisk("javax/naming/spi/NamingManager1",
|
||||||
|
InMemoryJavaCompiler.compile("javax.naming.spi.NamingManager1", source, "-Xmodule:java.naming"),
|
||||||
|
System.getProperty("test.classes"));
|
||||||
|
|
||||||
|
// Build the jar file that will be used for the module "java.naming".
|
||||||
|
BasicJarBuilder.build("javanaming", "javax/naming/spi/NamingManager1");
|
||||||
|
moduleJar = BasicJarBuilder.getTestJar("javanaming.jar");
|
||||||
|
|
||||||
|
// Just to make sure we are not fooled by the class file being on the
|
||||||
|
// class path where all the test classes are stored, write the NamingManager.class
|
||||||
|
// file out again with output that does not contain what OutputAnalyzer
|
||||||
|
// expects. This will provide confidence that the contents of the class
|
||||||
|
// is truly coming from the jar file and not the class file.
|
||||||
|
source = "package javax.naming.spi; " +
|
||||||
|
"public class NamingManager1 { " +
|
||||||
|
" static { " +
|
||||||
|
" System.out.println(\"Fail!\"); " +
|
||||||
|
" } " +
|
||||||
|
"}";
|
||||||
|
|
||||||
|
ClassFileInstaller.writeClassToDisk("javax/naming/spi/NamingManager1",
|
||||||
|
InMemoryJavaCompiler.compile("javax.naming.spi.NamingManager1", source, "-Xmodule:java.naming"),
|
||||||
|
System.getProperty("test.classes"));
|
||||||
|
|
||||||
|
// Create a second class file in the module java.naming. This class file
|
||||||
|
// will be put in the mods/java.naming directory.
|
||||||
|
source = "package javax.naming.spi; " +
|
||||||
|
"public class NamingManager2 { " +
|
||||||
|
" static { " +
|
||||||
|
" System.out.println(\"I pass two!\"); " +
|
||||||
|
" } " +
|
||||||
|
"}";
|
||||||
|
|
||||||
|
ClassFileInstaller.writeClassToDisk("javax/naming/spi/NamingManager2",
|
||||||
|
InMemoryJavaCompiler.compile("javax.naming.spi.NamingManager2", source, "-Xmodule:java.naming"),
|
||||||
|
(System.getProperty("test.classes") + "/mods/java.naming"));
|
||||||
|
|
||||||
|
|
||||||
|
// Supply -Xpatch with the name of the jar file for the module java.naming.
|
||||||
|
ProcessBuilder pb = ProcessTools.createJavaProcessBuilder("-Xpatch:java.naming=" +
|
||||||
|
moduleJar +
|
||||||
|
File.pathSeparator +
|
||||||
|
System.getProperty("test.classes") + "/mods/java.naming",
|
||||||
|
"Xpatch2DirsMain",
|
||||||
|
"javax.naming.spi.NamingManager1",
|
||||||
|
"javax.naming.spi.NamingManager2");
|
||||||
|
|
||||||
|
new OutputAnalyzer(pb.start())
|
||||||
|
.shouldContain("I pass one!")
|
||||||
|
.shouldContain("I pass two!")
|
||||||
|
.shouldHaveExitValue(0);
|
||||||
|
}
|
||||||
|
}
|
@ -24,7 +24,7 @@
|
|||||||
/*
|
/*
|
||||||
* @test
|
* @test
|
||||||
* @bug 8069469
|
* @bug 8069469
|
||||||
* @summary Make sure -XX:+TraceClassLoading works properly with "modules" jimage,
|
* @summary Make sure -Xlog:classload=info works properly with "modules" jimage,
|
||||||
-Xpatch, and with -Xbootclasspath/a
|
-Xpatch, and with -Xbootclasspath/a
|
||||||
* @library /testlibrary
|
* @library /testlibrary
|
||||||
* @compile XpatchMain.java
|
* @compile XpatchMain.java
|
||||||
@ -44,24 +44,23 @@ public class XpatchTraceCL {
|
|||||||
" } " +
|
" } " +
|
||||||
"}";
|
"}";
|
||||||
|
|
||||||
// Test -XX:+TraceClassLoading output for -Xpatch
|
// Test -Xlog:classload=info output for -Xpatch
|
||||||
ClassFileInstaller.writeClassToDisk("javax/naming/spi/NamingManager",
|
ClassFileInstaller.writeClassToDisk("javax/naming/spi/NamingManager",
|
||||||
InMemoryJavaCompiler.compile("javax.naming.spi.NamingManager", source, "-Xmodule:java.naming"),
|
InMemoryJavaCompiler.compile("javax.naming.spi.NamingManager", source, "-Xmodule:java.naming"),
|
||||||
"mods/java.naming");
|
"mods/java.naming");
|
||||||
|
|
||||||
ProcessBuilder pb = ProcessTools.createJavaProcessBuilder("-Xpatch:mods",
|
ProcessBuilder pb = ProcessTools.createJavaProcessBuilder("-Xpatch:java.naming=mods/java.naming",
|
||||||
"-XX:+TraceClassLoading", "XpatchMain", "javax.naming.spi.NamingManager");
|
"-Xlog:classload=info", "XpatchMain", "javax.naming.spi.NamingManager");
|
||||||
|
|
||||||
OutputAnalyzer output = new OutputAnalyzer(pb.start());
|
OutputAnalyzer output = new OutputAnalyzer(pb.start());
|
||||||
// "modules" jimage case.
|
// "modules" jimage case.
|
||||||
output.shouldContain("[classload] java.lang.Thread source: jrt:/java.base");
|
output.shouldContain("[classload] java.lang.Thread source: jrt:/java.base");
|
||||||
// -Xpatch case.
|
// -Xpatch case.
|
||||||
output.shouldContain("[classload] javax.naming.spi.NamingManager source: mods" +
|
output.shouldContain("[classload] javax.naming.spi.NamingManager source: mods/java.naming");
|
||||||
File.separator + "java.naming");
|
|
||||||
// -cp case.
|
// -cp case.
|
||||||
output.shouldContain("[classload] XpatchMain source: file");
|
output.shouldContain("[classload] XpatchMain source: file");
|
||||||
|
|
||||||
// Test -XX:+TraceClassLoading output for -Xbootclasspath/a
|
// Test -Xlog:classload=info output for -Xbootclasspath/a
|
||||||
source = "package XpatchTraceCL_pkg; " +
|
source = "package XpatchTraceCL_pkg; " +
|
||||||
"public class ItIsI { " +
|
"public class ItIsI { " +
|
||||||
" static { " +
|
" static { " +
|
||||||
@ -74,7 +73,7 @@ public class XpatchTraceCL {
|
|||||||
"xbcp");
|
"xbcp");
|
||||||
|
|
||||||
pb = ProcessTools.createJavaProcessBuilder("-Xbootclasspath/a:xbcp",
|
pb = ProcessTools.createJavaProcessBuilder("-Xbootclasspath/a:xbcp",
|
||||||
"-XX:+TraceClassLoading", "XpatchMain", "XpatchTraceCL_pkg.ItIsI");
|
"-Xlog:classload=info", "XpatchMain", "XpatchTraceCL_pkg.ItIsI");
|
||||||
output = new OutputAnalyzer(pb.start());
|
output = new OutputAnalyzer(pb.start());
|
||||||
// -Xbootclasspath/a case.
|
// -Xbootclasspath/a case.
|
||||||
output.shouldContain("[classload] XpatchTraceCL_pkg.ItIsI source: xbcp");
|
output.shouldContain("[classload] XpatchTraceCL_pkg.ItIsI source: xbcp");
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -35,7 +35,7 @@ public class XpatchCDS {
|
|||||||
|
|
||||||
public static void main(String args[]) throws Throwable {
|
public static void main(String args[]) throws Throwable {
|
||||||
System.out.println("Test that -Xpatch and -Xshare:dump are incompatibable");
|
System.out.println("Test that -Xpatch and -Xshare:dump are incompatibable");
|
||||||
ProcessBuilder pb = ProcessTools.createJavaProcessBuilder("-Xpatch:.", "-Xshare:dump");
|
ProcessBuilder pb = ProcessTools.createJavaProcessBuilder("-Xpatch:java.naming=mods/java.naming", "-Xshare:dump");
|
||||||
OutputAnalyzer output = new OutputAnalyzer(pb.start());
|
OutputAnalyzer output = new OutputAnalyzer(pb.start());
|
||||||
output.shouldContain("Cannot use the following option when dumping the shared archive: -Xpatch");
|
output.shouldContain("Cannot use the following option when dumping the shared archive: -Xpatch");
|
||||||
|
|
||||||
@ -52,7 +52,7 @@ public class XpatchCDS {
|
|||||||
"-XX:+UnlockDiagnosticVMOptions",
|
"-XX:+UnlockDiagnosticVMOptions",
|
||||||
"-XX:SharedArchiveFile=" + filename,
|
"-XX:SharedArchiveFile=" + filename,
|
||||||
"-Xshare:on",
|
"-Xshare:on",
|
||||||
"-Xpatch:.",
|
"-Xpatch:java.naming=mods/java.naming",
|
||||||
"-version");
|
"-version");
|
||||||
output = new OutputAnalyzer(pb.start());
|
output = new OutputAnalyzer(pb.start());
|
||||||
output.shouldContain("The shared archive file cannot be used with -Xpatch");
|
output.shouldContain("The shared archive file cannot be used with -Xpatch");
|
||||||
|
@ -359,3 +359,4 @@ b2a69d66dc65ad1d3aeb3bd362cf5bb0deba040e jdk-9+111
|
|||||||
bb8379287f3736f38c52b2d1418784e2592461d1 jdk-9+114
|
bb8379287f3736f38c52b2d1418784e2592461d1 jdk-9+114
|
||||||
35225b837d66582037eeadeb471c13235dfd793d jdk-9+115
|
35225b837d66582037eeadeb471c13235dfd793d jdk-9+115
|
||||||
baeb5edb38939cdb78ae0ac6f4fd368465cbf188 jdk-9+116
|
baeb5edb38939cdb78ae0ac6f4fd368465cbf188 jdk-9+116
|
||||||
|
4da0f73ce03aaf245b92cc040cc0ab0e3fa54dc2 jdk-9+117
|
||||||
|
74
jdk/make/GenerateClasslist.gmk
Normal file
74
jdk/make/GenerateClasslist.gmk
Normal file
@ -0,0 +1,74 @@
|
|||||||
|
#
|
||||||
|
# Copyright (c) 2016, 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.
|
||||||
|
#
|
||||||
|
|
||||||
|
################################################################################
|
||||||
|
# Generate classlist
|
||||||
|
################################################################################
|
||||||
|
|
||||||
|
default: all
|
||||||
|
|
||||||
|
include $(SPEC)
|
||||||
|
include MakeBase.gmk
|
||||||
|
include Tools.gmk
|
||||||
|
include JarArchive.gmk
|
||||||
|
|
||||||
|
################################################################################
|
||||||
|
# Create a jar with our generator class. Using a jar is intentional since it
|
||||||
|
# will load more classes
|
||||||
|
|
||||||
|
$(eval $(call SetupJarArchive, CLASSLIST_JAR, \
|
||||||
|
SRCS := $(BUILDTOOLS_OUTPUTDIR)/jdk_tools_classes, \
|
||||||
|
INCLUDES := build/tools/classlist, \
|
||||||
|
JAR := $(SUPPORT_OUTPUTDIR)/classlist.jar, \
|
||||||
|
))
|
||||||
|
|
||||||
|
TARGETS += $(CLASSLIST_JAR)
|
||||||
|
|
||||||
|
################################################################################
|
||||||
|
|
||||||
|
CLASSLIST_FILE := $(SUPPORT_OUTPUTDIR)/classlist/classlist
|
||||||
|
|
||||||
|
# If an external buildjdk has been supplied, we don't build a separate interim
|
||||||
|
# image, so just use the external build jdk instead.
|
||||||
|
ifeq ($(EXTERNAL_BUILDJDK), true)
|
||||||
|
INTERIM_IMAGE_DIR := $(BUILD_JDK)
|
||||||
|
endif
|
||||||
|
|
||||||
|
$(CLASSLIST_FILE): $(INTERIM_IMAGE_DIR)/bin/java$(EXE_SUFFIX) $(CLASSLIST_JAR)
|
||||||
|
$(call MakeDir, $(@D))
|
||||||
|
$(call LogInfo, Generating lib/classlist)
|
||||||
|
$(FIXPATH) $(INTERIM_IMAGE_DIR)/bin/java -XX:DumpLoadedClassList=$@.tmp \
|
||||||
|
-cp $(SUPPORT_OUTPUTDIR)/classlist.jar \
|
||||||
|
build.tools.classlist.HelloClasslist $(LOG_DEBUG) 2>&1
|
||||||
|
# Filter out generated classes, remove after JDK-8149977
|
||||||
|
$(FIXPATH) $(INTERIM_IMAGE_DIR)/bin/java -XX:DumpLoadedClassList=$@ \
|
||||||
|
-Xshare:dump -XX:SharedClassListFile=$@.tmp $(LOG_DEBUG) 2>&1
|
||||||
|
$(RM) $@.tmp
|
||||||
|
|
||||||
|
TARGETS += $(CLASSLIST_FILE)
|
||||||
|
|
||||||
|
################################################################################
|
||||||
|
|
||||||
|
all: $(TARGETS)
|
@ -96,7 +96,13 @@ TOOL_CHARSETMAPPING = $(JAVA_SMALL) -cp $(BUILDTOOLS_OUTPUTDIR)/jdk_tools_classe
|
|||||||
TOOL_SPP = $(JAVA_SMALL) -cp $(BUILDTOOLS_OUTPUTDIR)/jdk_tools_classes build.tools.spp.Spp
|
TOOL_SPP = $(JAVA_SMALL) -cp $(BUILDTOOLS_OUTPUTDIR)/jdk_tools_classes build.tools.spp.Spp
|
||||||
|
|
||||||
# Nimbus is used somewhere in the swing build.
|
# Nimbus is used somewhere in the swing build.
|
||||||
|
|
||||||
|
ifeq ($(BOOT_JDK_MODULAR), true)
|
||||||
|
COMPILENIMBUS_ADD_MODS := -addmods java.xml.bind
|
||||||
|
endif
|
||||||
|
|
||||||
TOOL_GENERATENIMBUS = $(JAVA_SMALL) -cp $(BUILDTOOLS_OUTPUTDIR)/jdk_tools_classes \
|
TOOL_GENERATENIMBUS = $(JAVA_SMALL) -cp $(BUILDTOOLS_OUTPUTDIR)/jdk_tools_classes \
|
||||||
|
$(COMPILENIMBUS_ADD_MODS) \
|
||||||
build.tools.generatenimbus.Generator
|
build.tools.generatenimbus.Generator
|
||||||
|
|
||||||
TOOL_WRAPPERGENERATOR = $(JAVA_SMALL) -cp $(BUILDTOOLS_OUTPUTDIR)/jdk_tools_classes \
|
TOOL_WRAPPERGENERATOR = $(JAVA_SMALL) -cp $(BUILDTOOLS_OUTPUTDIR)/jdk_tools_classes \
|
||||||
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
@ -206,7 +206,8 @@ ColorData.img_oda_green 28
|
|||||||
ColorData.img_oda_blue 32
|
ColorData.img_oda_blue 32
|
||||||
ColorData.pGrayInverseLutData 36
|
ColorData.pGrayInverseLutData 36
|
||||||
ColorData.screendata 40
|
ColorData.screendata 40
|
||||||
ColorData 44
|
ColorData.representsPrimaries 44
|
||||||
|
ColorData 48
|
||||||
XFontStruct.ext_data 0
|
XFontStruct.ext_data 0
|
||||||
XFontStruct.fid 4
|
XFontStruct.fid 4
|
||||||
XFontStruct.direction 8
|
XFontStruct.direction 8
|
||||||
|
@ -206,6 +206,7 @@ ColorData.img_oda_green 56
|
|||||||
ColorData.img_oda_blue 64
|
ColorData.img_oda_blue 64
|
||||||
ColorData.pGrayInverseLutData 72
|
ColorData.pGrayInverseLutData 72
|
||||||
ColorData.screendata 80
|
ColorData.screendata 80
|
||||||
|
ColorData.representsPrimaries 84
|
||||||
ColorData 88
|
ColorData 88
|
||||||
XFontStruct.ext_data 0
|
XFontStruct.ext_data 0
|
||||||
XFontStruct.fid 8
|
XFontStruct.fid 8
|
||||||
|
@ -206,6 +206,7 @@ ColorData.img_oda_green 56
|
|||||||
ColorData.img_oda_blue 64
|
ColorData.img_oda_blue 64
|
||||||
ColorData.pGrayInverseLutData 72
|
ColorData.pGrayInverseLutData 72
|
||||||
ColorData.screendata 80
|
ColorData.screendata 80
|
||||||
|
ColorData.representsPrimaries 84
|
||||||
ColorData 88
|
ColorData 88
|
||||||
XFontStruct.ext_data 0
|
XFontStruct.ext_data 0
|
||||||
XFontStruct.fid 8
|
XFontStruct.fid 8
|
||||||
|
@ -749,6 +749,7 @@ ColorData
|
|||||||
img_oda_blue pointer byte
|
img_oda_blue pointer byte
|
||||||
pGrayInverseLutData pointer int
|
pGrayInverseLutData pointer int
|
||||||
screendata int
|
screendata int
|
||||||
|
representsPrimaries int
|
||||||
|
|
||||||
AwtGraphicsConfigData
|
AwtGraphicsConfigData
|
||||||
awt_depth int
|
awt_depth int
|
||||||
|
@ -75,14 +75,3 @@ $(GENDATA_JAVA_SECURITY): $(BUILD_TOOLS) $(GENDATA_JAVA_SECURITY_SRC) $(RESTRICT
|
|||||||
TARGETS += $(GENDATA_JAVA_SECURITY)
|
TARGETS += $(GENDATA_JAVA_SECURITY)
|
||||||
|
|
||||||
################################################################################
|
################################################################################
|
||||||
|
|
||||||
$(SUPPORT_OUTPUTDIR)/modules_libs/java.base/classlist: \
|
|
||||||
$(JDK_TOPDIR)/make/data/classlist/classlist.$(OPENJDK_TARGET_OS)
|
|
||||||
$(call MakeDir, $(@D))
|
|
||||||
$(RM) $@ $@.tmp
|
|
||||||
$(TOOL_ADDJSUM) $< $@.tmp
|
|
||||||
$(MV) $@.tmp $@
|
|
||||||
|
|
||||||
TARGETS += $(SUPPORT_OUTPUTDIR)/modules_libs/java.base/classlist
|
|
||||||
|
|
||||||
################################################################################
|
|
||||||
|
@ -62,10 +62,13 @@ $(eval $(call SetupJavaCompilation,BUILD_BREAKITERATOR_LD, \
|
|||||||
BIN := $(BREAK_ITERATOR_CLASSES)/jdk.localedata))
|
BIN := $(BREAK_ITERATOR_CLASSES)/jdk.localedata))
|
||||||
|
|
||||||
ifeq ($(BOOT_JDK_MODULAR), true)
|
ifeq ($(BOOT_JDK_MODULAR), true)
|
||||||
BREAK_ITERATOR_BOOTCLASSPATH := -Xpatch:$(BREAK_ITERATOR_CLASSES) \
|
BREAK_ITERATOR_BOOTCLASSPATH := \
|
||||||
|
-Xpatch:java.base=$(BREAK_ITERATOR_CLASSES)/java.base \
|
||||||
|
-Xpatch:jdk.localedata=$(BREAK_ITERATOR_CLASSES)/jdk.localedata \
|
||||||
-XaddExports:java.base/sun.text=ALL-UNNAMED \
|
-XaddExports:java.base/sun.text=ALL-UNNAMED \
|
||||||
-XaddExports:java.base/sun.text.resources=ALL-UNNAMED \
|
-XaddExports:java.base/sun.text.resources=ALL-UNNAMED \
|
||||||
-XaddExports:jdk.localedata/sun.text.resources.ext=ALL-UNNAMED
|
-XaddExports:jdk.localedata/sun.text.resources.ext=ALL-UNNAMED \
|
||||||
|
#
|
||||||
else
|
else
|
||||||
BREAK_ITERATOR_BOOTCLASSPATH := -Xbootclasspath/p:$(call PathList, \
|
BREAK_ITERATOR_BOOTCLASSPATH := -Xbootclasspath/p:$(call PathList, \
|
||||||
$(BREAK_ITERATOR_CLASSES)/java.base \
|
$(BREAK_ITERATOR_CLASSES)/java.base \
|
||||||
|
@ -31,7 +31,7 @@ $(eval $(call IncludeCustomExtension, jdk, launcher/Launcher-java.desktop.gmk))
|
|||||||
ifndef BUILD_HEADLESS_ONLY
|
ifndef BUILD_HEADLESS_ONLY
|
||||||
$(eval $(call SetupBuildLauncher, appletviewer, \
|
$(eval $(call SetupBuildLauncher, appletviewer, \
|
||||||
MAIN_CLASS := sun.applet.Main, \
|
MAIN_CLASS := sun.applet.Main, \
|
||||||
JAVA_ARGS := -addmods ALL-SYSTEM, \
|
JAVA_ARGS := -addmods ALL-DEFAULT, \
|
||||||
LIBS_unix := $(X_LIBS), \
|
LIBS_unix := $(X_LIBS), \
|
||||||
))
|
))
|
||||||
endif
|
endif
|
||||||
|
@ -27,4 +27,5 @@ include LauncherCommon.gmk
|
|||||||
|
|
||||||
$(eval $(call SetupBuildLauncher, jrunscript, \
|
$(eval $(call SetupBuildLauncher, jrunscript, \
|
||||||
MAIN_CLASS := com.sun.tools.script.shell.Main, \
|
MAIN_CLASS := com.sun.tools.script.shell.Main, \
|
||||||
|
JAVA_ARGS := -addmods ALL-DEFAULT, \
|
||||||
))
|
))
|
||||||
|
@ -27,6 +27,7 @@ include LauncherCommon.gmk
|
|||||||
|
|
||||||
$(eval $(call SetupBuildLauncher, javac, \
|
$(eval $(call SetupBuildLauncher, javac, \
|
||||||
MAIN_CLASS := com.sun.tools.javac.Main, \
|
MAIN_CLASS := com.sun.tools.javac.Main, \
|
||||||
|
JAVA_ARGS := -addmods ALL-DEFAULT, \
|
||||||
CFLAGS := -DEXPAND_CLASSPATH_WILDCARDS \
|
CFLAGS := -DEXPAND_CLASSPATH_WILDCARDS \
|
||||||
-DNEVER_ACT_AS_SERVER_CLASS_MACHINE, \
|
-DNEVER_ACT_AS_SERVER_CLASS_MACHINE, \
|
||||||
))
|
))
|
||||||
|
@ -27,6 +27,7 @@ include LauncherCommon.gmk
|
|||||||
|
|
||||||
$(eval $(call SetupBuildLauncher, javadoc, \
|
$(eval $(call SetupBuildLauncher, javadoc, \
|
||||||
MAIN_CLASS := jdk.javadoc.internal.tool.Main, \
|
MAIN_CLASS := jdk.javadoc.internal.tool.Main, \
|
||||||
|
JAVA_ARGS := -addmods ALL-DEFAULT, \
|
||||||
CFLAGS := -DEXPAND_CLASSPATH_WILDCARDS \
|
CFLAGS := -DEXPAND_CLASSPATH_WILDCARDS \
|
||||||
-DNEVER_ACT_AS_SERVER_CLASS_MACHINE, \
|
-DNEVER_ACT_AS_SERVER_CLASS_MACHINE, \
|
||||||
))
|
))
|
||||||
|
@ -32,6 +32,7 @@ $(eval $(call SetupBuildLauncher, jimage,\
|
|||||||
|
|
||||||
$(eval $(call SetupBuildLauncher, jlink,\
|
$(eval $(call SetupBuildLauncher, jlink,\
|
||||||
MAIN_CLASS := jdk.tools.jlink.internal.Main, \
|
MAIN_CLASS := jdk.tools.jlink.internal.Main, \
|
||||||
|
JAVA_ARGS := -addmods ALL-DEFAULT, \
|
||||||
CFLAGS := -DENABLE_ARG_FILES \
|
CFLAGS := -DENABLE_ARG_FILES \
|
||||||
-DEXPAND_CLASSPATH_WILDCARDS \
|
-DEXPAND_CLASSPATH_WILDCARDS \
|
||||||
-DNEVER_ACT_AS_SERVER_CLASS_MACHINE, \
|
-DNEVER_ACT_AS_SERVER_CLASS_MACHINE, \
|
||||||
|
@ -27,6 +27,6 @@ include LauncherCommon.gmk
|
|||||||
|
|
||||||
$(eval $(call SetupBuildLauncher, jjs, \
|
$(eval $(call SetupBuildLauncher, jjs, \
|
||||||
MAIN_CLASS := jdk.nashorn.tools.jjs.Main, \
|
MAIN_CLASS := jdk.nashorn.tools.jjs.Main, \
|
||||||
JAVA_ARGS := -addmods ALL-SYSTEM, \
|
JAVA_ARGS := -addmods ALL-DEFAULT, \
|
||||||
CFLAGS := -DENABLE_ARG_FILES, \
|
CFLAGS := -DENABLE_ARG_FILES, \
|
||||||
))
|
))
|
||||||
|
@ -0,0 +1,79 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2016, 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This application is meant to be run to create a classlist file representing
|
||||||
|
* common use.
|
||||||
|
*
|
||||||
|
* The classlist is produced by adding -XX:DumpLoadedClassList=classlist
|
||||||
|
*/
|
||||||
|
package build.tools.classlist;
|
||||||
|
|
||||||
|
import java.net.InetAddress;
|
||||||
|
import java.time.LocalDateTime;
|
||||||
|
import java.time.ZoneId;
|
||||||
|
import java.time.format.DateTimeFormatter;
|
||||||
|
import java.util.stream.Stream;
|
||||||
|
import java.util.logging.*;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.Date;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Locale;
|
||||||
|
import java.text.DateFormat;
|
||||||
|
|
||||||
|
import static java.util.stream.Collectors.*;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This class is used to generate a classlist during build. Intent
|
||||||
|
* is to touch a reasonable amount of JDK classes that are commonly
|
||||||
|
* loaded and used early.
|
||||||
|
*/
|
||||||
|
public class HelloClasslist {
|
||||||
|
|
||||||
|
private static final Logger LOGGER = Logger.getLogger("Hello");
|
||||||
|
|
||||||
|
public static void main(String ... args) {
|
||||||
|
|
||||||
|
List<String> strings = Arrays.asList("Hello", "World!", "From: ",
|
||||||
|
InetAddress.getLoopbackAddress().toString());
|
||||||
|
|
||||||
|
String helloWorld = strings.parallelStream()
|
||||||
|
.map(s -> s.toLowerCase(Locale.ROOT))
|
||||||
|
.collect(joining(","));
|
||||||
|
|
||||||
|
Stream.of(helloWorld.split(","))
|
||||||
|
.forEach(System.out::println);
|
||||||
|
|
||||||
|
String newDate = DateTimeFormatter.ISO_LOCAL_DATE_TIME.format(
|
||||||
|
LocalDateTime.now(ZoneId.of("GMT")));
|
||||||
|
|
||||||
|
String oldDate = String.format("%s%n",
|
||||||
|
DateFormat.getDateInstance(DateFormat.DEFAULT, Locale.ROOT)
|
||||||
|
.format(new Date()));
|
||||||
|
|
||||||
|
LOGGER.log(Level.INFO, "New Date: " + newDate + " - old: " + oldDate);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -102,7 +102,7 @@ public class LinuxFileSystemProvider extends UnixFileSystemProvider {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
FileTypeDetector getFileTypeDetector() {
|
FileTypeDetector getFileTypeDetector() {
|
||||||
String userHome = GetPropertyAction.getProperty("user.home");
|
String userHome = GetPropertyAction.privilegedGetProperty("user.home");
|
||||||
Path userMimeTypes = Paths.get(userHome, ".mime.types");
|
Path userMimeTypes = Paths.get(userHome, ".mime.types");
|
||||||
Path etcMimeTypes = Paths.get("/etc/mime.types");
|
Path etcMimeTypes = Paths.get("/etc/mime.types");
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2005, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2005, 2016, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -53,7 +53,7 @@ iepoll(int epfd, struct epoll_event *events, int numfds, jlong timeout)
|
|||||||
start = t.tv_sec * 1000 + t.tv_usec / 1000;
|
start = t.tv_sec * 1000 + t.tv_usec / 1000;
|
||||||
|
|
||||||
for (;;) {
|
for (;;) {
|
||||||
int res = epoll_wait(epfd, events, numfds, timeout);
|
int res = epoll_wait(epfd, events, numfds, remaining);
|
||||||
if (res < 0 && errno == EINTR) {
|
if (res < 0 && errno == EINTR) {
|
||||||
if (remaining >= 0) {
|
if (remaining >= 0) {
|
||||||
gettimeofday(&t, NULL);
|
gettimeofday(&t, NULL);
|
||||||
|
@ -84,7 +84,8 @@ class KQueueArrayWrapper {
|
|||||||
static {
|
static {
|
||||||
IOUtil.load();
|
IOUtil.load();
|
||||||
initStructSizes();
|
initStructSizes();
|
||||||
String datamodel = GetPropertyAction.getProperty("sun.arch.data.model");
|
String datamodel =
|
||||||
|
GetPropertyAction.privilegedGetProperty("sun.arch.data.model");
|
||||||
is64bit = "64".equals(datamodel);
|
is64bit = "64".equals(datamodel);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -29,8 +29,6 @@ import java.nio.file.*;
|
|||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
import java.security.AccessController;
|
|
||||||
import sun.security.action.GetPropertyAction;
|
|
||||||
|
|
||||||
import static sun.nio.fs.MacOSXNativeDispatcher.*;
|
import static sun.nio.fs.MacOSXNativeDispatcher.*;
|
||||||
|
|
||||||
|
@ -46,8 +46,8 @@ public class MacOSXFileSystemProvider extends BsdFileSystemProvider {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
FileTypeDetector getFileTypeDetector() {
|
FileTypeDetector getFileTypeDetector() {
|
||||||
Path userMimeTypes = Paths.get(
|
Path userMimeTypes = Paths.get(GetPropertyAction
|
||||||
GetPropertyAction.getProperty("user.home"), ".mime.types");
|
.privilegedGetProperty("user.home"), ".mime.types");
|
||||||
|
|
||||||
return chain(new MimeTypesFileTypeDetector(userMimeTypes),
|
return chain(new MimeTypesFileTypeDetector(userMimeTypes),
|
||||||
new UTIFileTypeDetector());
|
new UTIFileTypeDetector());
|
||||||
|
@ -262,4 +262,14 @@ abstract class HmacCore extends MacSpi implements Cloneable {
|
|||||||
super("SHA-512", 128);
|
super("SHA-512", 128);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
public static final class HmacSHA512_224 extends HmacCore {
|
||||||
|
public HmacSHA512_224() throws NoSuchAlgorithmException {
|
||||||
|
super("SHA-512/224", 128);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public static final class HmacSHA512_256 extends HmacCore {
|
||||||
|
public HmacSHA512_256() throws NoSuchAlgorithmException {
|
||||||
|
super("SHA-512/256", 128);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -704,6 +704,12 @@ public final class SunJCE extends Provider {
|
|||||||
put("Alg.Alias.Mac.OID.1.2.840.113549.2.11", "HmacSHA512");
|
put("Alg.Alias.Mac.OID.1.2.840.113549.2.11", "HmacSHA512");
|
||||||
put("Alg.Alias.Mac.1.2.840.113549.2.11", "HmacSHA512");
|
put("Alg.Alias.Mac.1.2.840.113549.2.11", "HmacSHA512");
|
||||||
|
|
||||||
|
// TODO: aliases with OIDs
|
||||||
|
put("Mac.HmacSHA512/224",
|
||||||
|
"com.sun.crypto.provider.HmacCore$HmacSHA512_224");
|
||||||
|
put("Mac.HmacSHA512/256",
|
||||||
|
"com.sun.crypto.provider.HmacCore$HmacSHA512_256");
|
||||||
|
|
||||||
put("Mac.HmacPBESHA1",
|
put("Mac.HmacPBESHA1",
|
||||||
"com.sun.crypto.provider.HmacPKCS12PBESHA1");
|
"com.sun.crypto.provider.HmacPKCS12PBESHA1");
|
||||||
|
|
||||||
|
@ -1896,7 +1896,7 @@ public class File
|
|||||||
|
|
||||||
// temporary directory location
|
// temporary directory location
|
||||||
private static final File tmpdir = new File(
|
private static final File tmpdir = new File(
|
||||||
GetPropertyAction.getProperty("java.io.tmpdir"));
|
GetPropertyAction.privilegedGetProperty("java.io.tmpdir"));
|
||||||
static File location() {
|
static File location() {
|
||||||
return tmpdir;
|
return tmpdir;
|
||||||
}
|
}
|
||||||
|
@ -470,7 +470,7 @@ public final class Class<T> implements java.io.Serializable,
|
|||||||
* expression with an empty argument list. The class is initialized if it
|
* expression with an empty argument list. The class is initialized if it
|
||||||
* has not already been initialized.
|
* has not already been initialized.
|
||||||
*
|
*
|
||||||
* <p>Note that this method propagates any exception thrown by the
|
* @deprecated This method propagates any exception thrown by the
|
||||||
* nullary constructor, including a checked exception. Use of
|
* nullary constructor, including a checked exception. Use of
|
||||||
* this method effectively bypasses the compile-time exception
|
* this method effectively bypasses the compile-time exception
|
||||||
* checking that would otherwise be performed by the compiler.
|
* checking that would otherwise be performed by the compiler.
|
||||||
@ -500,6 +500,7 @@ public final class Class<T> implements java.io.Serializable,
|
|||||||
* of this class.
|
* of this class.
|
||||||
*/
|
*/
|
||||||
@CallerSensitive
|
@CallerSensitive
|
||||||
|
@Deprecated(since="9")
|
||||||
public T newInstance()
|
public T newInstance()
|
||||||
throws InstantiationException, IllegalAccessException
|
throws InstantiationException, IllegalAccessException
|
||||||
{
|
{
|
||||||
|
@ -2615,7 +2615,7 @@ public abstract class ClassLoader {
|
|||||||
ServicesCatalog createOrGetServicesCatalog() {
|
ServicesCatalog createOrGetServicesCatalog() {
|
||||||
ServicesCatalog catalog = servicesCatalog;
|
ServicesCatalog catalog = servicesCatalog;
|
||||||
if (catalog == null) {
|
if (catalog == null) {
|
||||||
catalog = new ServicesCatalog();
|
catalog = ServicesCatalog.create();
|
||||||
boolean set = trySetObjectField("servicesCatalog", catalog);
|
boolean set = trySetObjectField("servicesCatalog", catalog);
|
||||||
if (!set) {
|
if (!set) {
|
||||||
// beaten by someone else
|
// beaten by someone else
|
||||||
|
@ -468,7 +468,7 @@ public final class ProcessBuilder
|
|||||||
*/
|
*/
|
||||||
public abstract static class Redirect {
|
public abstract static class Redirect {
|
||||||
private static final File NULL_FILE = new File(
|
private static final File NULL_FILE = new File(
|
||||||
(GetPropertyAction.getProperty("os.name")
|
(GetPropertyAction.privilegedGetProperty("os.name")
|
||||||
.startsWith("Windows") ? "NUL" : "/dev/null")
|
.startsWith("Windows") ? "NUL" : "/dev/null")
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@ -29,21 +29,20 @@ import jdk.internal.misc.SharedSecrets;
|
|||||||
|
|
||||||
import static java.lang.StackWalker.Option.*;
|
import static java.lang.StackWalker.Option.*;
|
||||||
import java.lang.StackWalker.StackFrame;
|
import java.lang.StackWalker.StackFrame;
|
||||||
import java.lang.reflect.Module;
|
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
import java.util.OptionalInt;
|
import java.util.OptionalInt;
|
||||||
|
|
||||||
class StackFrameInfo implements StackFrame {
|
class StackFrameInfo implements StackFrame {
|
||||||
private final static JavaLangInvokeAccess jlInvokeAccess =
|
private final static JavaLangInvokeAccess JLIA =
|
||||||
SharedSecrets.getJavaLangInvokeAccess();
|
SharedSecrets.getJavaLangInvokeAccess();
|
||||||
|
|
||||||
// Footprint improvement: MemberName::clazz can replace
|
// Footprint improvement: MemberName::clazz can replace
|
||||||
// StackFrameInfo::declaringClass.
|
// StackFrameInfo::declaringClass.
|
||||||
|
|
||||||
final StackWalker walker;
|
private final StackWalker walker;
|
||||||
final Class<?> declaringClass;
|
private final Class<?> declaringClass;
|
||||||
final Object memberName;
|
private final Object memberName;
|
||||||
final short bci;
|
private final short bci;
|
||||||
private volatile StackTraceElement ste;
|
private volatile StackTraceElement ste;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -54,9 +53,17 @@ class StackFrameInfo implements StackFrame {
|
|||||||
this.walker = walker;
|
this.walker = walker;
|
||||||
this.declaringClass = null;
|
this.declaringClass = null;
|
||||||
this.bci = -1;
|
this.bci = -1;
|
||||||
this.memberName = jlInvokeAccess.newMemberName();
|
this.memberName = JLIA.newMemberName();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// package-private called by StackStreamFactory to skip
|
||||||
|
// the capability check
|
||||||
|
Class<?> declaringClass() {
|
||||||
|
return declaringClass;
|
||||||
|
}
|
||||||
|
|
||||||
|
// ----- implementation of StackFrame methods
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getClassName() {
|
public String getClassName() {
|
||||||
return declaringClass.getName();
|
return declaringClass.getName();
|
||||||
@ -70,31 +77,39 @@ class StackFrameInfo implements StackFrame {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getMethodName() {
|
public String getMethodName() {
|
||||||
return jlInvokeAccess.getName(memberName);
|
return JLIA.getName(memberName);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public final Optional<String> getFileName() {
|
public int getByteCodeIndex() {
|
||||||
StackTraceElement ste = toStackTraceElement();
|
return bci;
|
||||||
return ste.getFileName() != null ? Optional.of(ste.getFileName()) : Optional.empty();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public final OptionalInt getLineNumber() {
|
public String getFileName() {
|
||||||
StackTraceElement ste = toStackTraceElement();
|
if (isNativeMethod())
|
||||||
return ste.getLineNumber() > 0 ? OptionalInt.of(ste.getLineNumber()) : OptionalInt.empty();
|
return null;
|
||||||
|
|
||||||
|
return toStackTraceElement().getFileName();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public final boolean isNativeMethod() {
|
public int getLineNumber() {
|
||||||
StackTraceElement ste = toStackTraceElement();
|
if (isNativeMethod())
|
||||||
return ste.isNativeMethod();
|
return -2;
|
||||||
|
|
||||||
|
return toStackTraceElement().getLineNumber();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isNativeMethod() {
|
||||||
|
return JLIA.isNative(memberName);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
StackTraceElement ste = toStackTraceElement();
|
return toStackTraceElement().toString();
|
||||||
return ste.toString();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -78,7 +78,8 @@ final class StackStreamFactory {
|
|||||||
* Performance work and extensive testing is needed to replace the
|
* Performance work and extensive testing is needed to replace the
|
||||||
* VM built-in backtrace filled in Throwable with the StackWalker.
|
* VM built-in backtrace filled in Throwable with the StackWalker.
|
||||||
*/
|
*/
|
||||||
final static boolean isDebug = getProperty("stackwalk.debug", false);
|
final static boolean isDebug =
|
||||||
|
"true".equals(GetPropertyAction.privilegedGetProperty("stackwalk.debug"));
|
||||||
|
|
||||||
static <T> StackFrameTraverser<T>
|
static <T> StackFrameTraverser<T>
|
||||||
makeStackTraverser(StackWalker walker, Function<? super Stream<StackFrame>, ? extends T> function)
|
makeStackTraverser(StackWalker walker, Function<? super Stream<StackFrame>, ? extends T> function)
|
||||||
@ -491,7 +492,7 @@ final class StackStreamFactory {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
final Class<?> at(int index) {
|
final Class<?> at(int index) {
|
||||||
return stackFrames[index].declaringClass;
|
return stackFrames[index].declaringClass();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -760,7 +761,7 @@ final class StackStreamFactory {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
final Class<?> at(int index) {
|
final Class<?> at(int index) {
|
||||||
return stackFrames[index].declaringClass;
|
return stackFrames[index].declaringClass();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -988,11 +989,4 @@ final class StackStreamFactory {
|
|||||||
c.getName().startsWith("java.lang.invoke.LambdaForm");
|
c.getName().startsWith("java.lang.invoke.LambdaForm");
|
||||||
}
|
}
|
||||||
|
|
||||||
private static boolean getProperty(String key, boolean value) {
|
|
||||||
String s = GetPropertyAction.getProperty(key);
|
|
||||||
if (s != null) {
|
|
||||||
return Boolean.parseBoolean(s);
|
|
||||||
}
|
|
||||||
return value;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -126,6 +126,20 @@ public final class StackWalker {
|
|||||||
*/
|
*/
|
||||||
public Class<?> getDeclaringClass();
|
public Class<?> getDeclaringClass();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the index to the code array of the {@code Code} attribute
|
||||||
|
* containing the execution point represented by this stack frame.
|
||||||
|
* The code array gives the actual bytes of Java Virtual Machine code
|
||||||
|
* that implement the method.
|
||||||
|
*
|
||||||
|
* @return the index to the code array of the {@code Code} attribute
|
||||||
|
* containing the execution point represented by this stack frame,
|
||||||
|
* or a negative number if the method is native.
|
||||||
|
*
|
||||||
|
* @jvms 4.7.3 The {@code Code} Attribute
|
||||||
|
*/
|
||||||
|
public int getByteCodeIndex();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the name of the source file containing the execution point
|
* Returns the name of the source file containing the execution point
|
||||||
* represented by this stack frame. Generally, this corresponds
|
* represented by this stack frame. Generally, this corresponds
|
||||||
@ -135,12 +149,12 @@ public final class StackWalker {
|
|||||||
* other than a file, such as an entry in a source repository.
|
* other than a file, such as an entry in a source repository.
|
||||||
*
|
*
|
||||||
* @return the name of the file containing the execution point
|
* @return the name of the file containing the execution point
|
||||||
* represented by this stack frame, or empty {@code Optional}
|
* represented by this stack frame, or {@code null} if
|
||||||
* is unavailable.
|
* this information is unavailable.
|
||||||
*
|
*
|
||||||
* @jvms 4.7.10 The {@code SourceFile} Attribute
|
* @jvms 4.7.10 The {@code SourceFile} Attribute
|
||||||
*/
|
*/
|
||||||
public Optional<String> getFileName();
|
public String getFileName();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the line number of the source line containing the execution
|
* Returns the line number of the source line containing the execution
|
||||||
@ -150,12 +164,12 @@ public final class StackWalker {
|
|||||||
* Specification</cite>.
|
* Specification</cite>.
|
||||||
*
|
*
|
||||||
* @return the line number of the source line containing the execution
|
* @return the line number of the source line containing the execution
|
||||||
* point represented by this stack frame, or empty
|
* point represented by this stack frame, or a negative number if
|
||||||
* {@code Optional} if this information is unavailable.
|
* this information is unavailable.
|
||||||
*
|
*
|
||||||
* @jvms 4.7.12 The {@code LineNumberTable} Attribute
|
* @jvms 4.7.12 The {@code LineNumberTable} Attribute
|
||||||
*/
|
*/
|
||||||
public OptionalInt getLineNumber();
|
public int getLineNumber();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns {@code true} if the method containing the execution point
|
* Returns {@code true} if the method containing the execution point
|
||||||
|
@ -69,7 +69,6 @@ import jdk.internal.logger.LazyLoggers;
|
|||||||
import jdk.internal.logger.LocalizedLoggerWrapper;
|
import jdk.internal.logger.LocalizedLoggerWrapper;
|
||||||
|
|
||||||
import jdk.internal.module.ModuleBootstrap;
|
import jdk.internal.module.ModuleBootstrap;
|
||||||
import jdk.internal.module.Modules;
|
|
||||||
import jdk.internal.module.ServicesCatalog;
|
import jdk.internal.module.ServicesCatalog;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -1924,10 +1923,6 @@ public final class System {
|
|||||||
// initialize the module system
|
// initialize the module system
|
||||||
System.bootLayer = ModuleBootstrap.boot();
|
System.bootLayer = ModuleBootstrap.boot();
|
||||||
|
|
||||||
// base module needs to be loose (CODETOOLS-7901619)
|
|
||||||
Module base = Object.class.getModule();
|
|
||||||
Modules.addReads(base, null);
|
|
||||||
|
|
||||||
// module system initialized
|
// module system initialized
|
||||||
VM.initLevel(2);
|
VM.initLevel(2);
|
||||||
}
|
}
|
||||||
|
@ -33,8 +33,6 @@ import sun.invoke.util.VerifyType;
|
|||||||
import sun.invoke.util.Wrapper;
|
import sun.invoke.util.Wrapper;
|
||||||
|
|
||||||
import java.lang.ref.WeakReference;
|
import java.lang.ref.WeakReference;
|
||||||
import java.lang.reflect.Field;
|
|
||||||
import java.lang.reflect.Method;
|
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
|
|
||||||
|
@ -88,7 +88,7 @@ import static jdk.internal.org.objectweb.asm.Opcodes.*;
|
|||||||
|
|
||||||
static {
|
static {
|
||||||
final String key = "jdk.internal.lambda.dumpProxyClasses";
|
final String key = "jdk.internal.lambda.dumpProxyClasses";
|
||||||
String path = GetPropertyAction.getProperty(key);
|
String path = GetPropertyAction.privilegedGetProperty(key);
|
||||||
dumper = (null == path) ? null : ProxyClassesDumper.getInstance(path);
|
dumper = (null == path) ? null : ProxyClassesDumper.getInstance(path);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -396,7 +396,7 @@ class Invokers {
|
|||||||
LambdaForm lform = new LambdaForm(name + ":VarHandle_invoke_MT_" + shortenSignature(basicTypeSignature(mtype)),
|
LambdaForm lform = new LambdaForm(name + ":VarHandle_invoke_MT_" + shortenSignature(basicTypeSignature(mtype)),
|
||||||
ARG_LIMIT + 1, names);
|
ARG_LIMIT + 1, names);
|
||||||
|
|
||||||
lform.prepare();
|
lform.compileToBytecode();
|
||||||
return lform;
|
return lform;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -448,7 +448,7 @@ class Invokers {
|
|||||||
LambdaForm lform = new LambdaForm(name + ":VarHandle_exactInvoker" + shortenSignature(basicTypeSignature(mtype)),
|
LambdaForm lform = new LambdaForm(name + ":VarHandle_exactInvoker" + shortenSignature(basicTypeSignature(mtype)),
|
||||||
ARG_LIMIT, names);
|
ARG_LIMIT, names);
|
||||||
|
|
||||||
lform.prepare();
|
lform.compileToBytecode();
|
||||||
return lform;
|
return lform;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -497,44 +497,33 @@ class Invokers {
|
|||||||
|
|
||||||
/*non-public*/ static
|
/*non-public*/ static
|
||||||
@ForceInline
|
@ForceInline
|
||||||
MethodHandle checkVarHandleGenericType(VarHandle vh, VarHandle.AccessDescriptor vad) {
|
MethodHandle checkVarHandleGenericType(VarHandle handle, VarHandle.AccessDescriptor ad) {
|
||||||
MethodType expected = vad.symbolicMethodType;
|
// Test for exact match on invoker types
|
||||||
MethodType actual = VarHandle.AccessType.getMethodType(vad.type, vh);
|
// TODO match with erased types and add cast of return value to lambda form
|
||||||
|
MethodHandle mh = handle.getMethodHandle(ad.mode);
|
||||||
MemberName mn = VarHandle.AccessMode.getMemberName(vad.mode, vh.vform);
|
if (mh.type() == ad.symbolicMethodTypeInvoker) {
|
||||||
if (mn == null)
|
|
||||||
throw vh.unsupported();
|
|
||||||
// TODO the following MH is not constant, cache in stable field array
|
|
||||||
// on VarForm?
|
|
||||||
MethodHandle mh = DirectMethodHandle.make(mn);
|
|
||||||
if (actual == expected) {
|
|
||||||
return mh;
|
return mh;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
// Adapt to the actual (which should never fail since mh's method
|
return mh.asType(ad.symbolicMethodTypeInvoker);
|
||||||
// type is in the basic form), then to the expected (which my fail
|
|
||||||
// if the symbolic type descriptor does not match)
|
|
||||||
// TODO optimize for the case of actual.erased() == expected.erased()
|
|
||||||
return mh.asType(actual.insertParameterTypes(0, VarHandle.class)).
|
|
||||||
asType(expected.insertParameterTypes(0, VarHandle.class));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*non-public*/ static
|
/*non-public*/ static
|
||||||
@ForceInline
|
@ForceInline
|
||||||
void checkVarHandleExactType(VarHandle vh, VarHandle.AccessDescriptor vad) {
|
void checkVarHandleExactType(VarHandle handle, VarHandle.AccessDescriptor ad) {
|
||||||
MethodType expected = vad.symbolicMethodType;
|
MethodType erasedTarget = handle.vform.methodType_table[ad.type];
|
||||||
MethodType actual = VarHandle.AccessType.getMethodType(vad.type, vh);
|
MethodType erasedSymbolic = ad.symbolicMethodTypeErased;
|
||||||
if (actual != expected)
|
if (erasedTarget != erasedSymbolic)
|
||||||
throw newWrongMethodTypeException(expected, actual);
|
throw newWrongMethodTypeException(erasedTarget, erasedSymbolic);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*non-public*/ static
|
/*non-public*/ static
|
||||||
@ForceInline
|
@ForceInline
|
||||||
MemberName getVarHandleMemberName(VarHandle vh, VarHandle.AccessDescriptor vad) {
|
MemberName getVarHandleMemberName(VarHandle handle, VarHandle.AccessDescriptor ad) {
|
||||||
MemberName mn = VarHandle.AccessMode.getMemberName(vad.mode, vh.vform);
|
MemberName mn = handle.vform.memberName_table[ad.mode];
|
||||||
if (mn == null) {
|
if (mn == null) {
|
||||||
throw vh.unsupported();
|
throw handle.unsupported();
|
||||||
}
|
}
|
||||||
return mn;
|
return mn;
|
||||||
}
|
}
|
||||||
|
@ -25,6 +25,8 @@
|
|||||||
|
|
||||||
package java.lang.invoke;
|
package java.lang.invoke;
|
||||||
|
|
||||||
|
import jdk.internal.misc.JavaLangInvokeAccess;
|
||||||
|
import jdk.internal.misc.SharedSecrets;
|
||||||
import sun.invoke.util.BytecodeDescriptor;
|
import sun.invoke.util.BytecodeDescriptor;
|
||||||
import sun.invoke.util.VerifyAccess;
|
import sun.invoke.util.VerifyAccess;
|
||||||
|
|
||||||
@ -1143,15 +1145,25 @@ import java.util.Objects;
|
|||||||
}
|
}
|
||||||
|
|
||||||
static {
|
static {
|
||||||
// Allow privileged classes outside of java.lang
|
// StackFrameInfo stores Member and this provides the shared secrets
|
||||||
jdk.internal.misc.SharedSecrets.setJavaLangInvokeAccess(new jdk.internal.misc.JavaLangInvokeAccess() {
|
// for stack walker to access MemberName information.
|
||||||
|
SharedSecrets.setJavaLangInvokeAccess(new JavaLangInvokeAccess() {
|
||||||
|
@Override
|
||||||
public Object newMemberName() {
|
public Object newMemberName() {
|
||||||
return new MemberName();
|
return new MemberName();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public String getName(Object mname) {
|
public String getName(Object mname) {
|
||||||
MemberName memberName = (MemberName)mname;
|
MemberName memberName = (MemberName)mname;
|
||||||
return memberName.getName();
|
return memberName.getName();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isNative(Object mname) {
|
||||||
|
MemberName memberName = (MemberName)mname;
|
||||||
|
return memberName.isNative();
|
||||||
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -430,14 +430,14 @@ class MethodHandleNatives {
|
|||||||
|
|
||||||
// If not polymorphic in the return type, such as the compareAndSet
|
// If not polymorphic in the return type, such as the compareAndSet
|
||||||
// methods that return boolean
|
// methods that return boolean
|
||||||
if (ak.isPolyMorphicInReturnType) {
|
if (ak.at.isMonomorphicInReturnType) {
|
||||||
if (ak.returnType != mtype.returnType()) {
|
if (ak.at.returnType != mtype.returnType()) {
|
||||||
// The caller contains a different return type than that
|
// The caller contains a different return type than that
|
||||||
// defined by the method
|
// defined by the method
|
||||||
throw newNoSuchMethodErrorOnVarHandle(name, mtype);
|
throw newNoSuchMethodErrorOnVarHandle(name, mtype);
|
||||||
}
|
}
|
||||||
// Adjust the return type of the signature method type
|
// Adjust the return type of the signature method type
|
||||||
sigType = sigType.changeReturnType(ak.returnType);
|
sigType = sigType.changeReturnType(ak.at.returnType);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Get the guard method type for linking
|
// Get the guard method type for linking
|
||||||
@ -455,26 +455,25 @@ class MethodHandleNatives {
|
|||||||
MemberName linker = new MemberName(
|
MemberName linker = new MemberName(
|
||||||
VarHandleGuards.class, "guard_" + getVarHandleMethodSignature(sigType),
|
VarHandleGuards.class, "guard_" + getVarHandleMethodSignature(sigType),
|
||||||
guardType, REF_invokeStatic);
|
guardType, REF_invokeStatic);
|
||||||
try {
|
|
||||||
return MemberName.getFactory().resolveOrFail(
|
linker = MemberName.getFactory().resolveOrNull(REF_invokeStatic, linker,
|
||||||
REF_invokeStatic, linker, VarHandleGuards.class, ReflectiveOperationException.class);
|
VarHandleGuards.class);
|
||||||
} catch (ReflectiveOperationException ex) {
|
if (linker != null) {
|
||||||
|
return linker;
|
||||||
|
}
|
||||||
// Fall back to lambda form linkage if guard method is not available
|
// Fall back to lambda form linkage if guard method is not available
|
||||||
// TODO Optionally log fallback ?
|
// TODO Optionally log fallback ?
|
||||||
}
|
}
|
||||||
}
|
|
||||||
return Invokers.varHandleInvokeLinkerMethod(name, mtype);
|
return Invokers.varHandleInvokeLinkerMethod(name, mtype);
|
||||||
}
|
}
|
||||||
static String getVarHandleMethodSignature(MethodType mt) {
|
static String getVarHandleMethodSignature(MethodType mt) {
|
||||||
StringBuilder sb = new StringBuilder(mt.parameterCount() + 1);
|
StringBuilder sb = new StringBuilder(mt.parameterCount() + 2);
|
||||||
|
|
||||||
for (int i = 0; i < mt.parameterCount(); i++) {
|
for (int i = 0; i < mt.parameterCount(); i++) {
|
||||||
Class<?> pt = mt.parameterType(i);
|
Class<?> pt = mt.parameterType(i);
|
||||||
sb.append(getCharType(pt));
|
sb.append(getCharType(pt));
|
||||||
}
|
}
|
||||||
|
|
||||||
sb.append('_').append(getCharType(mt.returnType()));
|
sb.append('_').append(getCharType(mt.returnType()));
|
||||||
|
|
||||||
return sb.toString();
|
return sb.toString();
|
||||||
}
|
}
|
||||||
static char getCharType(Class<?> pt) {
|
static char getCharType(Class<?> pt) {
|
||||||
|
@ -53,7 +53,7 @@ import sun.security.action.GetPropertyAction;
|
|||||||
static final boolean VAR_HANDLE_GUARDS;
|
static final boolean VAR_HANDLE_GUARDS;
|
||||||
|
|
||||||
static {
|
static {
|
||||||
Properties props = GetPropertyAction.getProperties();
|
Properties props = GetPropertyAction.privilegedGetProperties();
|
||||||
DEBUG_METHOD_HANDLE_NAMES = Boolean.parseBoolean(
|
DEBUG_METHOD_HANDLE_NAMES = Boolean.parseBoolean(
|
||||||
props.getProperty("java.lang.invoke.MethodHandle.DEBUG_NAMES"));
|
props.getProperty("java.lang.invoke.MethodHandle.DEBUG_NAMES"));
|
||||||
DUMP_CLASS_FILES = Boolean.parseBoolean(
|
DUMP_CLASS_FILES = Boolean.parseBoolean(
|
||||||
|
@ -197,7 +197,7 @@ public final class StringConcatFactory {
|
|||||||
// DEBUG = false; // implied
|
// DEBUG = false; // implied
|
||||||
// DUMPER = null; // implied
|
// DUMPER = null; // implied
|
||||||
|
|
||||||
Properties props = GetPropertyAction.getProperties();
|
Properties props = GetPropertyAction.privilegedGetProperties();
|
||||||
final String strategy =
|
final String strategy =
|
||||||
props.getProperty("java.lang.invoke.stringConcat");
|
props.getProperty("java.lang.invoke.stringConcat");
|
||||||
CACHE_ENABLE = Boolean.parseBoolean(
|
CACHE_ENABLE = Boolean.parseBoolean(
|
||||||
|
@ -24,42 +24,102 @@
|
|||||||
*/
|
*/
|
||||||
package java.lang.invoke;
|
package java.lang.invoke;
|
||||||
|
|
||||||
|
import jdk.internal.vm.annotation.ForceInline;
|
||||||
import jdk.internal.vm.annotation.Stable;
|
import jdk.internal.vm.annotation.Stable;
|
||||||
|
|
||||||
import java.lang.invoke.VarHandle.AccessMode;
|
import java.lang.invoke.VarHandle.AccessMode;
|
||||||
import java.lang.reflect.Method;
|
import java.lang.reflect.Method;
|
||||||
import java.lang.reflect.Modifier;
|
import java.lang.reflect.Modifier;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A var handle form containing a set of member name, one for each operation.
|
* A var handle form containing a set of member name, one for each operation.
|
||||||
* Each member characterizes a static method.
|
* Each member characterizes a static method.
|
||||||
*/
|
*/
|
||||||
class VarForm {
|
final class VarForm {
|
||||||
|
|
||||||
// Holds VarForm for VarHandle implementation classes
|
final @Stable MethodType[] methodType_table;
|
||||||
private static final ClassValue<VarForm> VFORMS
|
|
||||||
= new ClassValue<>() {
|
|
||||||
@Override
|
|
||||||
protected VarForm computeValue(Class<?> impl) {
|
|
||||||
return new VarForm(linkFromStatic(impl));
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
final @Stable MemberName[] table;
|
final @Stable MemberName[] memberName_table;
|
||||||
|
|
||||||
VarForm(MemberName[] table) {
|
VarForm(Class<?> implClass, Class<?> receiver, Class<?> value, Class<?>... intermediate) {
|
||||||
this.table = table;
|
this.methodType_table = new MethodType[VarHandle.AccessType.values().length];
|
||||||
|
|
||||||
|
// TODO lazily calculate
|
||||||
|
this.memberName_table = linkFromStatic(implClass);
|
||||||
|
|
||||||
|
// (Receiver, <Intermediates>)
|
||||||
|
List<Class<?>> l = new ArrayList<>();
|
||||||
|
if (receiver != null)
|
||||||
|
l.add(receiver);
|
||||||
|
l.addAll(Arrays.asList(intermediate));
|
||||||
|
|
||||||
|
// (Receiver, <Intermediates>)Value
|
||||||
|
methodType_table[VarHandle.AccessType.GET.ordinal()] =
|
||||||
|
MethodType.methodType(value, l).erase();
|
||||||
|
|
||||||
|
// (Receiver, <Intermediates>, Value)void
|
||||||
|
l.add(value);
|
||||||
|
methodType_table[VarHandle.AccessType.SET.ordinal()] =
|
||||||
|
MethodType.methodType(void.class, l).erase();
|
||||||
|
|
||||||
|
// (Receiver, <Intermediates>, Value)Value
|
||||||
|
methodType_table[VarHandle.AccessType.GET_AND_UPDATE.ordinal()] =
|
||||||
|
MethodType.methodType(value, l).erase();
|
||||||
|
|
||||||
|
// (Receiver, <Intermediates>, Value, Value)boolean
|
||||||
|
l.add(value);
|
||||||
|
methodType_table[VarHandle.AccessType.COMPARE_AND_SWAP.ordinal()] =
|
||||||
|
MethodType.methodType(boolean.class, l).erase();
|
||||||
|
|
||||||
|
// (Receiver, <Intermediates>, Value, Value)Value
|
||||||
|
methodType_table[VarHandle.AccessType.COMPARE_AND_EXCHANGE.ordinal()] =
|
||||||
|
MethodType.methodType(value, l).erase();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
@ForceInline
|
||||||
* Creates a var form given an VarHandle implementation class.
|
final MethodType getMethodType(int type) {
|
||||||
* Each signature polymorphic method is linked to a static method of the
|
return methodType_table[type];
|
||||||
* same name on the implementation class or a super class.
|
|
||||||
*/
|
|
||||||
static VarForm createFromStatic(Class<? extends VarHandle> impl) {
|
|
||||||
return VFORMS.get(impl);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ForceInline
|
||||||
|
final MemberName getMemberName(int mode) {
|
||||||
|
// TODO calculate lazily
|
||||||
|
MemberName mn = memberName_table[mode];
|
||||||
|
if (mn == null) {
|
||||||
|
throw new UnsupportedOperationException();
|
||||||
|
}
|
||||||
|
return mn;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Stable
|
||||||
|
MethodType[] methodType_V_table;
|
||||||
|
|
||||||
|
@ForceInline
|
||||||
|
final MethodType[] getMethodType_V_init() {
|
||||||
|
MethodType[] table = new MethodType[VarHandle.AccessType.values().length];
|
||||||
|
for (int i = 0; i < methodType_table.length; i++) {
|
||||||
|
MethodType mt = methodType_table[i];
|
||||||
|
// TODO only adjust for sig-poly methods returning Object
|
||||||
|
table[i] = mt.changeReturnType(void.class);
|
||||||
|
}
|
||||||
|
methodType_V_table = table;
|
||||||
|
return table;
|
||||||
|
}
|
||||||
|
|
||||||
|
@ForceInline
|
||||||
|
final MethodType getMethodType_V(int type) {
|
||||||
|
MethodType[] table = methodType_V_table;
|
||||||
|
if (table == null) {
|
||||||
|
table = getMethodType_V_init();
|
||||||
|
}
|
||||||
|
return table[type];
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Link all signature polymorphic methods.
|
* Link all signature polymorphic methods.
|
||||||
*/
|
*/
|
||||||
|
@ -27,10 +27,9 @@ package java.lang.invoke;
|
|||||||
|
|
||||||
import jdk.internal.HotSpotIntrinsicCandidate;
|
import jdk.internal.HotSpotIntrinsicCandidate;
|
||||||
import jdk.internal.vm.annotation.ForceInline;
|
import jdk.internal.vm.annotation.ForceInline;
|
||||||
|
import jdk.internal.vm.annotation.Stable;
|
||||||
|
|
||||||
import java.lang.reflect.Method;
|
import java.lang.reflect.Method;
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.Arrays;
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
@ -406,42 +405,10 @@ import static java.lang.invoke.MethodHandleStatics.newInternalError;
|
|||||||
* @since 9
|
* @since 9
|
||||||
*/
|
*/
|
||||||
public abstract class VarHandle {
|
public abstract class VarHandle {
|
||||||
// Use explicit final fields rather than an @Stable array as
|
|
||||||
// this can reduce the memory per handle
|
|
||||||
// e.g. by 24 bytes on 64 bit architectures
|
|
||||||
final MethodType typeGet;
|
|
||||||
final MethodType typeSet;
|
|
||||||
final MethodType typeCompareSwap;
|
|
||||||
final MethodType typeCompareExchange;
|
|
||||||
final MethodType typeGetAndUpdate;
|
|
||||||
|
|
||||||
final VarForm vform;
|
final VarForm vform;
|
||||||
|
|
||||||
VarHandle(VarForm vform, Class<?> receiver, Class<?> value, Class<?>... intermediate) {
|
VarHandle(VarForm vform) {
|
||||||
this.vform = vform;
|
this.vform = vform;
|
||||||
|
|
||||||
// (Receiver, <Intermediates>)
|
|
||||||
List<Class<?>> l = new ArrayList<>();
|
|
||||||
if (receiver != null)
|
|
||||||
l.add(receiver);
|
|
||||||
l.addAll(Arrays.asList(intermediate));
|
|
||||||
|
|
||||||
// (Receiver, <Intermediates>)Value
|
|
||||||
this.typeGet = MethodType.methodType(value, l);
|
|
||||||
|
|
||||||
// (Receiver, <Intermediates>, Value)void
|
|
||||||
l.add(value);
|
|
||||||
this.typeSet = MethodType.methodType(void.class, l);
|
|
||||||
|
|
||||||
// (Receiver, <Intermediates>, Value)Value
|
|
||||||
this.typeGetAndUpdate = MethodType.methodType(value, l);
|
|
||||||
|
|
||||||
// (Receiver, <Intermediates>, Value, Value)boolean
|
|
||||||
l.add(value);
|
|
||||||
this.typeCompareSwap = MethodType.methodType(boolean.class, l);
|
|
||||||
|
|
||||||
// (Receiver, <Intermediates>, Value, Value)Value
|
|
||||||
this.typeCompareExchange = MethodType.methodType(value, l);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
RuntimeException unsupported() {
|
RuntimeException unsupported() {
|
||||||
@ -1090,36 +1057,83 @@ public abstract class VarHandle {
|
|||||||
Object addAndGet(Object... args);
|
Object addAndGet(Object... args);
|
||||||
|
|
||||||
enum AccessType {
|
enum AccessType {
|
||||||
GET, // 0
|
GET(Object.class) {
|
||||||
SET, // 1
|
@Override
|
||||||
COMPARE_AND_SWAP, // 2
|
MethodType accessModeType(Class<?> receiver, Class<?> value,
|
||||||
COMPARE_AND_EXCHANGE, // 3
|
Class<?>... intermediate) {
|
||||||
GET_AND_UPDATE; // 4
|
Class<?>[] ps = allocateParameters(0, receiver, intermediate);
|
||||||
|
fillParameters(ps, receiver, intermediate);
|
||||||
|
return MethodType.methodType(value, ps);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
SET(void.class) {
|
||||||
|
@Override
|
||||||
|
MethodType accessModeType(Class<?> receiver, Class<?> value,
|
||||||
|
Class<?>... intermediate) {
|
||||||
|
Class<?>[] ps = allocateParameters(1, receiver, intermediate);
|
||||||
|
int i = fillParameters(ps, receiver, intermediate);
|
||||||
|
ps[i] = value;
|
||||||
|
return MethodType.methodType(void.class, ps);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
COMPARE_AND_SWAP(boolean.class) {
|
||||||
|
@Override
|
||||||
|
MethodType accessModeType(Class<?> receiver, Class<?> value,
|
||||||
|
Class<?>... intermediate) {
|
||||||
|
Class<?>[] ps = allocateParameters(2, receiver, intermediate);
|
||||||
|
int i = fillParameters(ps, receiver, intermediate);
|
||||||
|
ps[i++] = value;
|
||||||
|
ps[i] = value;
|
||||||
|
return MethodType.methodType(boolean.class, ps);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
COMPARE_AND_EXCHANGE(Object.class) {
|
||||||
|
@Override
|
||||||
|
MethodType accessModeType(Class<?> receiver, Class<?> value,
|
||||||
|
Class<?>... intermediate) {
|
||||||
|
Class<?>[] ps = allocateParameters(2, receiver, intermediate);
|
||||||
|
int i = fillParameters(ps, receiver, intermediate);
|
||||||
|
ps[i++] = value;
|
||||||
|
ps[i] = value;
|
||||||
|
return MethodType.methodType(value, ps);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
GET_AND_UPDATE(Object.class) {
|
||||||
|
@Override
|
||||||
|
MethodType accessModeType(Class<?> receiver, Class<?> value,
|
||||||
|
Class<?>... intermediate) {
|
||||||
|
Class<?>[] ps = allocateParameters(1, receiver, intermediate);
|
||||||
|
int i = fillParameters(ps, receiver, intermediate);
|
||||||
|
ps[i] = value;
|
||||||
|
return MethodType.methodType(value, ps);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
MethodType getMethodType(VarHandle vh) {
|
final Class<?> returnType;
|
||||||
return getMethodType(this.ordinal(), vh);
|
final boolean isMonomorphicInReturnType;
|
||||||
|
|
||||||
|
AccessType(Class<?> returnType) {
|
||||||
|
this.returnType = returnType;
|
||||||
|
isMonomorphicInReturnType = returnType != Object.class;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ForceInline
|
abstract MethodType accessModeType(Class<?> receiver, Class<?> value,
|
||||||
static MethodType getMethodType(int ordinal, VarHandle vh) {
|
Class<?>... intermediate);
|
||||||
if (ordinal == 0) {
|
|
||||||
return vh.typeGet;
|
private static Class<?>[] allocateParameters(int values,
|
||||||
}
|
Class<?> receiver, Class<?>... intermediate) {
|
||||||
else if (ordinal == 1) {
|
int size = ((receiver != null) ? 1 : 0) + intermediate.length + values;
|
||||||
return vh.typeSet;
|
return new Class<?>[size];
|
||||||
}
|
|
||||||
else if (ordinal == 2) {
|
|
||||||
return vh.typeCompareSwap;
|
|
||||||
}
|
|
||||||
else if (ordinal == 3) {
|
|
||||||
return vh.typeCompareExchange;
|
|
||||||
}
|
|
||||||
else if (ordinal == 4) {
|
|
||||||
return vh.typeGetAndUpdate;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
throw new IllegalStateException("Illegal access type: " + ordinal);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static int fillParameters(Class<?>[] ps,
|
||||||
|
Class<?> receiver, Class<?>... intermediate) {
|
||||||
|
int i = 0;
|
||||||
|
if (receiver != null)
|
||||||
|
ps[i++] = receiver;
|
||||||
|
for (int j = 0; j < intermediate.length; j++)
|
||||||
|
ps[i++] = intermediate[j];
|
||||||
|
return i;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1133,115 +1147,115 @@ public abstract class VarHandle {
|
|||||||
* method
|
* method
|
||||||
* {@link VarHandle#get VarHandle.get}
|
* {@link VarHandle#get VarHandle.get}
|
||||||
*/
|
*/
|
||||||
GET("get", AccessType.GET, Object.class),
|
GET("get", AccessType.GET),
|
||||||
/**
|
/**
|
||||||
* The access mode whose access is specified by the corresponding
|
* The access mode whose access is specified by the corresponding
|
||||||
* method
|
* method
|
||||||
* {@link VarHandle#set VarHandle.set}
|
* {@link VarHandle#set VarHandle.set}
|
||||||
*/
|
*/
|
||||||
SET("set", AccessType.SET, void.class),
|
SET("set", AccessType.SET),
|
||||||
/**
|
/**
|
||||||
* The access mode whose access is specified by the corresponding
|
* The access mode whose access is specified by the corresponding
|
||||||
* method
|
* method
|
||||||
* {@link VarHandle#getVolatile VarHandle.getVolatile}
|
* {@link VarHandle#getVolatile VarHandle.getVolatile}
|
||||||
*/
|
*/
|
||||||
GET_VOLATILE("getVolatile", AccessType.GET, Object.class),
|
GET_VOLATILE("getVolatile", AccessType.GET),
|
||||||
/**
|
/**
|
||||||
* The access mode whose access is specified by the corresponding
|
* The access mode whose access is specified by the corresponding
|
||||||
* method
|
* method
|
||||||
* {@link VarHandle#setVolatile VarHandle.setVolatile}
|
* {@link VarHandle#setVolatile VarHandle.setVolatile}
|
||||||
*/
|
*/
|
||||||
SET_VOLATILE("setVolatile", AccessType.SET, void.class),
|
SET_VOLATILE("setVolatile", AccessType.SET),
|
||||||
/**
|
/**
|
||||||
* The access mode whose access is specified by the corresponding
|
* The access mode whose access is specified by the corresponding
|
||||||
* method
|
* method
|
||||||
* {@link VarHandle#getAcquire VarHandle.getAcquire}
|
* {@link VarHandle#getAcquire VarHandle.getAcquire}
|
||||||
*/
|
*/
|
||||||
GET_ACQUIRE("getAcquire", AccessType.GET, Object.class),
|
GET_ACQUIRE("getAcquire", AccessType.GET),
|
||||||
/**
|
/**
|
||||||
* The access mode whose access is specified by the corresponding
|
* The access mode whose access is specified by the corresponding
|
||||||
* method
|
* method
|
||||||
* {@link VarHandle#setRelease VarHandle.setRelease}
|
* {@link VarHandle#setRelease VarHandle.setRelease}
|
||||||
*/
|
*/
|
||||||
SET_RELEASE("setRelease", AccessType.SET, void.class),
|
SET_RELEASE("setRelease", AccessType.SET),
|
||||||
/**
|
/**
|
||||||
* The access mode whose access is specified by the corresponding
|
* The access mode whose access is specified by the corresponding
|
||||||
* method
|
* method
|
||||||
* {@link VarHandle#getOpaque VarHandle.getOpaque}
|
* {@link VarHandle#getOpaque VarHandle.getOpaque}
|
||||||
*/
|
*/
|
||||||
GET_OPAQUE("getOpaque", AccessType.GET, Object.class),
|
GET_OPAQUE("getOpaque", AccessType.GET),
|
||||||
/**
|
/**
|
||||||
* The access mode whose access is specified by the corresponding
|
* The access mode whose access is specified by the corresponding
|
||||||
* method
|
* method
|
||||||
* {@link VarHandle#setOpaque VarHandle.setOpaque}
|
* {@link VarHandle#setOpaque VarHandle.setOpaque}
|
||||||
*/
|
*/
|
||||||
SET_OPAQUE("setOpaque", AccessType.SET, void.class),
|
SET_OPAQUE("setOpaque", AccessType.SET),
|
||||||
/**
|
/**
|
||||||
* The access mode whose access is specified by the corresponding
|
* The access mode whose access is specified by the corresponding
|
||||||
* method
|
* method
|
||||||
* {@link VarHandle#compareAndSet VarHandle.compareAndSet}
|
* {@link VarHandle#compareAndSet VarHandle.compareAndSet}
|
||||||
*/
|
*/
|
||||||
COMPARE_AND_SET("compareAndSet", AccessType.COMPARE_AND_SWAP, boolean.class),
|
COMPARE_AND_SET("compareAndSet", AccessType.COMPARE_AND_SWAP),
|
||||||
/**
|
/**
|
||||||
* The access mode whose access is specified by the corresponding
|
* The access mode whose access is specified by the corresponding
|
||||||
* method
|
* method
|
||||||
* {@link VarHandle#compareAndExchangeVolatile VarHandle.compareAndExchangeVolatile}
|
* {@link VarHandle#compareAndExchangeVolatile VarHandle.compareAndExchangeVolatile}
|
||||||
*/
|
*/
|
||||||
COMPARE_AND_EXCHANGE_VOLATILE("compareAndExchangeVolatile", AccessType.COMPARE_AND_EXCHANGE, Object.class),
|
COMPARE_AND_EXCHANGE_VOLATILE("compareAndExchangeVolatile", AccessType.COMPARE_AND_EXCHANGE),
|
||||||
/**
|
/**
|
||||||
* The access mode whose access is specified by the corresponding
|
* The access mode whose access is specified by the corresponding
|
||||||
* method
|
* method
|
||||||
* {@link VarHandle#compareAndExchangeAcquire VarHandle.compareAndExchangeAcquire}
|
* {@link VarHandle#compareAndExchangeAcquire VarHandle.compareAndExchangeAcquire}
|
||||||
*/
|
*/
|
||||||
COMPARE_AND_EXCHANGE_ACQUIRE("compareAndExchangeAcquire", AccessType.COMPARE_AND_EXCHANGE, Object.class),
|
COMPARE_AND_EXCHANGE_ACQUIRE("compareAndExchangeAcquire", AccessType.COMPARE_AND_EXCHANGE),
|
||||||
/**
|
/**
|
||||||
* The access mode whose access is specified by the corresponding
|
* The access mode whose access is specified by the corresponding
|
||||||
* method
|
* method
|
||||||
* {@link VarHandle#compareAndExchangeRelease VarHandle.compareAndExchangeRelease}
|
* {@link VarHandle#compareAndExchangeRelease VarHandle.compareAndExchangeRelease}
|
||||||
*/
|
*/
|
||||||
COMPARE_AND_EXCHANGE_RELEASE("compareAndExchangeRelease", AccessType.COMPARE_AND_EXCHANGE, Object.class),
|
COMPARE_AND_EXCHANGE_RELEASE("compareAndExchangeRelease", AccessType.COMPARE_AND_EXCHANGE),
|
||||||
/**
|
/**
|
||||||
* The access mode whose access is specified by the corresponding
|
* The access mode whose access is specified by the corresponding
|
||||||
* method
|
* method
|
||||||
* {@link VarHandle#weakCompareAndSet VarHandle.weakCompareAndSet}
|
* {@link VarHandle#weakCompareAndSet VarHandle.weakCompareAndSet}
|
||||||
*/
|
*/
|
||||||
WEAK_COMPARE_AND_SET("weakCompareAndSet", AccessType.COMPARE_AND_SWAP, boolean.class),
|
WEAK_COMPARE_AND_SET("weakCompareAndSet", AccessType.COMPARE_AND_SWAP),
|
||||||
/**
|
/**
|
||||||
* The access mode whose access is specified by the corresponding
|
* The access mode whose access is specified by the corresponding
|
||||||
* method
|
* method
|
||||||
* {@link VarHandle#weakCompareAndSetVolatile VarHandle.weakCompareAndSetVolatile}
|
* {@link VarHandle#weakCompareAndSetVolatile VarHandle.weakCompareAndSetVolatile}
|
||||||
*/
|
*/
|
||||||
WEAK_COMPARE_AND_SET_VOLATILE("weakCompareAndSetVolatile", AccessType.COMPARE_AND_SWAP, boolean.class),
|
WEAK_COMPARE_AND_SET_VOLATILE("weakCompareAndSetVolatile", AccessType.COMPARE_AND_SWAP),
|
||||||
/**
|
/**
|
||||||
* The access mode whose access is specified by the corresponding
|
* The access mode whose access is specified by the corresponding
|
||||||
* method
|
* method
|
||||||
* {@link VarHandle#weakCompareAndSetAcquire VarHandle.weakCompareAndSetAcquire}
|
* {@link VarHandle#weakCompareAndSetAcquire VarHandle.weakCompareAndSetAcquire}
|
||||||
*/
|
*/
|
||||||
WEAK_COMPARE_AND_SET_ACQUIRE("weakCompareAndSetAcquire", AccessType.COMPARE_AND_SWAP, boolean.class),
|
WEAK_COMPARE_AND_SET_ACQUIRE("weakCompareAndSetAcquire", AccessType.COMPARE_AND_SWAP),
|
||||||
/**
|
/**
|
||||||
* The access mode whose access is specified by the corresponding
|
* The access mode whose access is specified by the corresponding
|
||||||
* method
|
* method
|
||||||
* {@link VarHandle#weakCompareAndSetRelease VarHandle.weakCompareAndSetRelease}
|
* {@link VarHandle#weakCompareAndSetRelease VarHandle.weakCompareAndSetRelease}
|
||||||
*/
|
*/
|
||||||
WEAK_COMPARE_AND_SET_RELEASE("weakCompareAndSetRelease", AccessType.COMPARE_AND_SWAP, boolean.class),
|
WEAK_COMPARE_AND_SET_RELEASE("weakCompareAndSetRelease", AccessType.COMPARE_AND_SWAP),
|
||||||
/**
|
/**
|
||||||
* The access mode whose access is specified by the corresponding
|
* The access mode whose access is specified by the corresponding
|
||||||
* method
|
* method
|
||||||
* {@link VarHandle#getAndSet VarHandle.getAndSet}
|
* {@link VarHandle#getAndSet VarHandle.getAndSet}
|
||||||
*/
|
*/
|
||||||
GET_AND_SET("getAndSet", AccessType.GET_AND_UPDATE, Object.class),
|
GET_AND_SET("getAndSet", AccessType.GET_AND_UPDATE),
|
||||||
/**
|
/**
|
||||||
* The access mode whose access is specified by the corresponding
|
* The access mode whose access is specified by the corresponding
|
||||||
* method
|
* method
|
||||||
* {@link VarHandle#getAndAdd VarHandle.getAndAdd}
|
* {@link VarHandle#getAndAdd VarHandle.getAndAdd}
|
||||||
*/
|
*/
|
||||||
GET_AND_ADD("getAndAdd", AccessType.GET_AND_UPDATE, Object.class),
|
GET_AND_ADD("getAndAdd", AccessType.GET_AND_UPDATE),
|
||||||
/**
|
/**
|
||||||
* The access mode whose access is specified by the corresponding
|
* The access mode whose access is specified by the corresponding
|
||||||
* method
|
* method
|
||||||
* {@link VarHandle#addAndGet VarHandle.addAndGet}
|
* {@link VarHandle#addAndGet VarHandle.addAndGet}
|
||||||
*/
|
*/
|
||||||
ADD_AND_GET("addAndGet", AccessType.GET_AND_UPDATE, Object.class),
|
ADD_AND_GET("addAndGet", AccessType.GET_AND_UPDATE),
|
||||||
;
|
;
|
||||||
|
|
||||||
static final Map<String, AccessMode> methodNameToAccessMode;
|
static final Map<String, AccessMode> methodNameToAccessMode;
|
||||||
@ -1256,10 +1270,8 @@ public abstract class VarHandle {
|
|||||||
|
|
||||||
final String methodName;
|
final String methodName;
|
||||||
final AccessType at;
|
final AccessType at;
|
||||||
final boolean isPolyMorphicInReturnType;
|
|
||||||
final Class<?> returnType;
|
|
||||||
|
|
||||||
AccessMode(final String methodName, AccessType at, Class<?> returnType) {
|
AccessMode(final String methodName, AccessType at) {
|
||||||
this.methodName = methodName;
|
this.methodName = methodName;
|
||||||
this.at = at;
|
this.at = at;
|
||||||
|
|
||||||
@ -1267,10 +1279,7 @@ public abstract class VarHandle {
|
|||||||
assert methodName.equals(toMethodName(name()));
|
assert methodName.equals(toMethodName(name()));
|
||||||
// Assert that return type is correct
|
// Assert that return type is correct
|
||||||
// Otherwise, when disabled avoid using reflection
|
// Otherwise, when disabled avoid using reflection
|
||||||
assert returnType == getReturnType(methodName);
|
assert at.returnType == getReturnType(methodName);
|
||||||
|
|
||||||
this.returnType = returnType;
|
|
||||||
isPolyMorphicInReturnType = returnType != Object.class;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -1324,17 +1333,21 @@ public abstract class VarHandle {
|
|||||||
|
|
||||||
@ForceInline
|
@ForceInline
|
||||||
static MemberName getMemberName(int ordinal, VarForm vform) {
|
static MemberName getMemberName(int ordinal, VarForm vform) {
|
||||||
return vform.table[ordinal];
|
return vform.memberName_table[ordinal];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static final class AccessDescriptor {
|
static final class AccessDescriptor {
|
||||||
final MethodType symbolicMethodType;
|
final MethodType symbolicMethodTypeErased;
|
||||||
|
final MethodType symbolicMethodTypeInvoker;
|
||||||
|
final Class<?> returnType;
|
||||||
final int type;
|
final int type;
|
||||||
final int mode;
|
final int mode;
|
||||||
|
|
||||||
public AccessDescriptor(MethodType symbolicMethodType, int type, int mode) {
|
public AccessDescriptor(MethodType symbolicMethodType, int type, int mode) {
|
||||||
this.symbolicMethodType = symbolicMethodType;
|
this.symbolicMethodTypeErased = symbolicMethodType.erase();
|
||||||
|
this.symbolicMethodTypeInvoker = symbolicMethodType.insertParameterTypes(0, VarHandle.class);
|
||||||
|
this.returnType = symbolicMethodType.returnType();
|
||||||
this.type = type;
|
this.type = type;
|
||||||
this.mode = mode;
|
this.mode = mode;
|
||||||
}
|
}
|
||||||
@ -1346,6 +1359,7 @@ public abstract class VarHandle {
|
|||||||
* @return the variable type of variables referenced by this VarHandle
|
* @return the variable type of variables referenced by this VarHandle
|
||||||
*/
|
*/
|
||||||
public final Class<?> varType() {
|
public final Class<?> varType() {
|
||||||
|
MethodType typeSet = accessModeType(AccessMode.SET);
|
||||||
return typeSet.parameterType(typeSet.parameterCount() - 1);
|
return typeSet.parameterType(typeSet.parameterCount() - 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1356,6 +1370,7 @@ public abstract class VarHandle {
|
|||||||
* list is unmodifiable
|
* list is unmodifiable
|
||||||
*/
|
*/
|
||||||
public final List<Class<?>> coordinateTypes() {
|
public final List<Class<?>> coordinateTypes() {
|
||||||
|
MethodType typeGet = accessModeType(AccessMode.GET);
|
||||||
return typeGet.parameterList();
|
return typeGet.parameterList();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1374,9 +1389,15 @@ public abstract class VarHandle {
|
|||||||
* @return the access mode type for the given access mode
|
* @return the access mode type for the given access mode
|
||||||
*/
|
*/
|
||||||
public final MethodType accessModeType(AccessMode accessMode) {
|
public final MethodType accessModeType(AccessMode accessMode) {
|
||||||
return accessMode.at.getMethodType(this);
|
TypesAndInvokers tis = getTypesAndInvokers();
|
||||||
|
MethodType mt = tis.methodType_table[accessMode.at.ordinal()];
|
||||||
|
if (mt == null) {
|
||||||
|
mt = tis.methodType_table[accessMode.at.ordinal()] =
|
||||||
|
accessModeTypeUncached(accessMode);
|
||||||
}
|
}
|
||||||
|
return mt;
|
||||||
|
}
|
||||||
|
abstract MethodType accessModeTypeUncached(AccessMode accessMode);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns {@code true} if the given access mode is supported, otherwise
|
* Returns {@code true} if the given access mode is supported, otherwise
|
||||||
@ -1417,9 +1438,8 @@ public abstract class VarHandle {
|
|||||||
public final MethodHandle toMethodHandle(AccessMode accessMode) {
|
public final MethodHandle toMethodHandle(AccessMode accessMode) {
|
||||||
MemberName mn = AccessMode.getMemberName(accessMode.ordinal(), vform);
|
MemberName mn = AccessMode.getMemberName(accessMode.ordinal(), vform);
|
||||||
if (mn != null) {
|
if (mn != null) {
|
||||||
return DirectMethodHandle.make(mn).
|
MethodHandle mh = getMethodHandle(accessMode.ordinal());
|
||||||
bindTo(this).
|
return mh.bindTo(this);
|
||||||
asType(accessMode.at.getMethodType(this));
|
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
// Ensure an UnsupportedOperationException is thrown
|
// Ensure an UnsupportedOperationException is thrown
|
||||||
@ -1428,6 +1448,51 @@ public abstract class VarHandle {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Stable
|
||||||
|
TypesAndInvokers typesAndInvokers;
|
||||||
|
|
||||||
|
static class TypesAndInvokers {
|
||||||
|
final @Stable
|
||||||
|
MethodType[] methodType_table =
|
||||||
|
new MethodType[VarHandle.AccessType.values().length];
|
||||||
|
|
||||||
|
final @Stable
|
||||||
|
MethodHandle[] methodHandle_table =
|
||||||
|
new MethodHandle[AccessMode.values().length];
|
||||||
|
}
|
||||||
|
|
||||||
|
@ForceInline
|
||||||
|
private final TypesAndInvokers getTypesAndInvokers() {
|
||||||
|
TypesAndInvokers tis = typesAndInvokers;
|
||||||
|
if (tis == null) {
|
||||||
|
tis = typesAndInvokers = new TypesAndInvokers();
|
||||||
|
}
|
||||||
|
return tis;
|
||||||
|
}
|
||||||
|
|
||||||
|
@ForceInline
|
||||||
|
final MethodHandle getMethodHandle(int mode) {
|
||||||
|
TypesAndInvokers tis = getTypesAndInvokers();
|
||||||
|
MethodHandle mh = tis.methodHandle_table[mode];
|
||||||
|
if (mh == null) {
|
||||||
|
mh = tis.methodHandle_table[mode] = getMethodHandleUncached(tis, mode);
|
||||||
|
}
|
||||||
|
return mh;
|
||||||
|
}
|
||||||
|
private final MethodHandle getMethodHandleUncached(TypesAndInvokers tis, int mode) {
|
||||||
|
MethodType mt = accessModeType(AccessMode.values()[mode]).
|
||||||
|
insertParameterTypes(0, VarHandle.class);
|
||||||
|
MemberName mn = vform.getMemberName(mode);
|
||||||
|
DirectMethodHandle dmh = DirectMethodHandle.make(mn);
|
||||||
|
// Such a method handle must not be publically exposed directly
|
||||||
|
// otherwise it can be cracked, it must be transformed or rebound
|
||||||
|
// before exposure
|
||||||
|
MethodHandle mh = dmh.copyWith(mt, dmh.form);
|
||||||
|
assert mh.type().erase() == mn.getMethodType().erase();
|
||||||
|
return mh;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/*non-public*/
|
/*non-public*/
|
||||||
final void updateVarForm(VarForm newVForm) {
|
final void updateVarForm(VarForm newVForm) {
|
||||||
if (vform == newVForm) return;
|
if (vform == newVForm) return;
|
||||||
@ -1453,6 +1518,10 @@ public abstract class VarHandle {
|
|||||||
catch (ReflectiveOperationException e) {
|
catch (ReflectiveOperationException e) {
|
||||||
throw newInternalError(e);
|
throw newInternalError(e);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// The VarHandleGuards must be initialized to ensure correct
|
||||||
|
// compilation of the guard methods
|
||||||
|
UNSAFE.ensureClassInitialized(VarHandleGuards.class);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user