Merge
This commit is contained in:
commit
d048828d66
1
.hgtags
1
.hgtags
@ -249,3 +249,4 @@ b32e2219736e42baaf45daf0ad67ed34f6033799 jdk9-b02
|
|||||||
099891b1d86f3719e116ac717ffdafc90d037fb7 jdk9-b04
|
099891b1d86f3719e116ac717ffdafc90d037fb7 jdk9-b04
|
||||||
dd311791ad6895a3989020dd6c6c46db87972ab8 jdk9-b05
|
dd311791ad6895a3989020dd6c6c46db87972ab8 jdk9-b05
|
||||||
85dbdc227c5e11429b4fc4a8ba763f50107edd6e jdk9-b06
|
85dbdc227c5e11429b4fc4a8ba763f50107edd6e jdk9-b06
|
||||||
|
c826d05f1fb0773f6a28caa763307dd30d90d36e jdk9-b07
|
||||||
|
@ -249,3 +249,4 @@ fd8d51bdf9aadf7ae83e65e8655c53581017c363 jdk9-b03
|
|||||||
cb4c3440bc2748101923e2488506e61009ab1bf5 jdk9-b04
|
cb4c3440bc2748101923e2488506e61009ab1bf5 jdk9-b04
|
||||||
8c63f0b6ada282f27e3a80125e53c3be603f9af7 jdk9-b05
|
8c63f0b6ada282f27e3a80125e53c3be603f9af7 jdk9-b05
|
||||||
d0b525cd31b87abeb6d5b7e3516953eeb13b323c jdk9-b06
|
d0b525cd31b87abeb6d5b7e3516953eeb13b323c jdk9-b06
|
||||||
|
0ea015c298b201c07fa33990f2445b6d0ef3566d jdk9-b07
|
||||||
|
@ -46,10 +46,24 @@ AC_DEFUN([ADD_JVM_ARG_IF_OK],
|
|||||||
# Appends a string to a path variable, only adding the : when needed.
|
# Appends a string to a path variable, only adding the : when needed.
|
||||||
AC_DEFUN([BASIC_APPEND_TO_PATH],
|
AC_DEFUN([BASIC_APPEND_TO_PATH],
|
||||||
[
|
[
|
||||||
if test "x[$]$1" = x; then
|
if test "x$2" != x; then
|
||||||
$1="$2"
|
if test "x[$]$1" = x; then
|
||||||
else
|
$1="$2"
|
||||||
$1="[$]$1:$2"
|
else
|
||||||
|
$1="[$]$1:$2"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
])
|
||||||
|
|
||||||
|
# Prepends a string to a path variable, only adding the : when needed.
|
||||||
|
AC_DEFUN([BASIC_PREPEND_TO_PATH],
|
||||||
|
[
|
||||||
|
if test "x$2" != x; then
|
||||||
|
if test "x[$]$1" = x; then
|
||||||
|
$1="$2"
|
||||||
|
else
|
||||||
|
$1="$2:[$]$1"
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
])
|
])
|
||||||
|
|
||||||
@ -442,43 +456,95 @@ AC_DEFUN_ONCE([BASIC_SETUP_PATHS],
|
|||||||
|
|
||||||
# Locate the directory of this script.
|
# Locate the directory of this script.
|
||||||
AUTOCONF_DIR=$TOPDIR/common/autoconf
|
AUTOCONF_DIR=$TOPDIR/common/autoconf
|
||||||
|
])
|
||||||
|
|
||||||
|
AC_DEFUN_ONCE([BASIC_SETUP_DEVKIT],
|
||||||
|
[
|
||||||
|
AC_ARG_WITH([devkit], [AS_HELP_STRING([--with-devkit],
|
||||||
|
[use this devkit for compilers, tools and resources])],
|
||||||
|
[
|
||||||
|
BASIC_FIXUP_PATH([with_devkit])
|
||||||
|
DEVKIT_ROOT="$with_devkit"
|
||||||
|
# Check for a meta data info file in the root of the devkit
|
||||||
|
if test -f "$DEVKIT_ROOT/devkit.info"; then
|
||||||
|
# This potentially sets the following:
|
||||||
|
# DEVKIT_NAME: A descriptive name of the devkit
|
||||||
|
# DEVKIT_TOOLCHAIN_PATH: Corresponds to --with-toolchain-path
|
||||||
|
# DEVKIT_EXTRA_PATH: Corresponds to --with-extra-path
|
||||||
|
# DEVKIT_SYSROOT: Corresponds to --with-sysroot
|
||||||
|
. $DEVKIT_ROOT/devkit.info
|
||||||
|
fi
|
||||||
|
|
||||||
|
AC_MSG_CHECKING([for devkit])
|
||||||
|
if test "x$DEVKIT_NAME" != x; then
|
||||||
|
AC_MSG_RESULT([$DEVKIT_NAME in $DEVKIT_ROOT])
|
||||||
|
else
|
||||||
|
AC_MSG_RESULT([$DEVKIT_ROOT])
|
||||||
|
fi
|
||||||
|
|
||||||
|
if test "x$DEVKIT_EXTRA_PATH" != x; then
|
||||||
|
BASIC_PREPEND_TO_PATH([EXTRA_PATH],$DEVKIT_EXTRA_PATH)
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Fallback default of just /bin if DEVKIT_PATH is not defined
|
||||||
|
if test "x$DEVKIT_TOOLCHAIN_PATH" = x; then
|
||||||
|
DEVKIT_TOOLCHAIN_PATH="$DEVKIT_ROOT/bin"
|
||||||
|
fi
|
||||||
|
BASIC_PREPEND_TO_PATH([TOOLCHAIN_PATH],$DEVKIT_TOOLCHAIN_PATH)
|
||||||
|
|
||||||
|
# If DEVKIT_SYSROOT is set, use that, otherwise try a couple of known
|
||||||
|
# places for backwards compatiblity.
|
||||||
|
if test "x$DEVKIT_SYSROOT" != x; then
|
||||||
|
SYSROOT="$DEVKIT_SYSROOT"
|
||||||
|
elif test -d "$DEVKIT_ROOT/$host_alias/libc"; then
|
||||||
|
SYSROOT="$DEVKIT_ROOT/$host_alias/libc"
|
||||||
|
elif test -d "$DEVKIT_ROOT/$host/sys-root"; then
|
||||||
|
SYSROOT="$DEVKIT_ROOT/$host/sys-root"
|
||||||
|
fi
|
||||||
|
]
|
||||||
|
)
|
||||||
|
|
||||||
|
# You can force the sysroot if the sysroot encoded into the compiler tools
|
||||||
|
# is not correct.
|
||||||
|
AC_ARG_WITH(sys-root, [AS_HELP_STRING([--with-sys-root],
|
||||||
|
[alias for --with-sysroot for backwards compatability])],
|
||||||
|
[SYSROOT=$with_sys_root]
|
||||||
|
)
|
||||||
|
|
||||||
|
AC_ARG_WITH(sysroot, [AS_HELP_STRING([--with-sysroot],
|
||||||
|
[use this directory as sysroot)])],
|
||||||
|
[SYSROOT=$with_sysroot]
|
||||||
|
)
|
||||||
|
|
||||||
|
AC_ARG_WITH([tools-dir], [AS_HELP_STRING([--with-tools-dir],
|
||||||
|
[alias for --with-toolchain-path for backwards compatibility])],
|
||||||
|
[BASIC_PREPEND_TO_PATH([TOOLCHAIN_PATH],$with_tools_dir)]
|
||||||
|
)
|
||||||
|
|
||||||
|
AC_ARG_WITH([toolchain-path], [AS_HELP_STRING([--with-toolchain-path],
|
||||||
|
[prepend these directories when searching for toolchain binaries (compilers etc)])],
|
||||||
|
[BASIC_PREPEND_TO_PATH([TOOLCHAIN_PATH],$with_toolchain_path)]
|
||||||
|
)
|
||||||
|
|
||||||
|
AC_ARG_WITH([extra-path], [AS_HELP_STRING([--with-extra-path],
|
||||||
|
[prepend these directories to the default path])],
|
||||||
|
[BASIC_PREPEND_TO_PATH([EXTRA_PATH],$with_extra_path)]
|
||||||
|
)
|
||||||
|
|
||||||
|
# Prepend the extra path to the global path
|
||||||
|
BASIC_PREPEND_TO_PATH([PATH],$EXTRA_PATH)
|
||||||
|
|
||||||
if test "x$OPENJDK_BUILD_OS" = "xsolaris"; then
|
if test "x$OPENJDK_BUILD_OS" = "xsolaris"; then
|
||||||
# Add extra search paths on solaris for utilities like ar and as etc...
|
# Add extra search paths on solaris for utilities like ar and as etc...
|
||||||
PATH="$PATH:/usr/ccs/bin:/usr/sfw/bin:/opt/csw/bin"
|
PATH="$PATH:/usr/ccs/bin:/usr/sfw/bin:/opt/csw/bin"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# You can force the sys-root if the sys-root encoded into the cross compiler tools
|
AC_MSG_CHECKING([for sysroot])
|
||||||
# is not correct.
|
AC_MSG_RESULT([$SYSROOT])
|
||||||
AC_ARG_WITH(sys-root, [AS_HELP_STRING([--with-sys-root],
|
AC_MSG_CHECKING([for toolchain path])
|
||||||
[pass this sys-root to the compilers and tools (for cross-compiling)])])
|
AC_MSG_RESULT([$TOOLCHAIN_PATH])
|
||||||
|
AC_MSG_CHECKING([for extra path])
|
||||||
if test "x$with_sys_root" != x; then
|
AC_MSG_RESULT([$EXTRA_PATH])
|
||||||
SYS_ROOT=$with_sys_root
|
|
||||||
else
|
|
||||||
SYS_ROOT=/
|
|
||||||
fi
|
|
||||||
AC_SUBST(SYS_ROOT)
|
|
||||||
|
|
||||||
AC_ARG_WITH([tools-dir], [AS_HELP_STRING([--with-tools-dir],
|
|
||||||
[search this directory for compilers and tools (for cross-compiling)])],
|
|
||||||
[TOOLS_DIR=$with_tools_dir]
|
|
||||||
)
|
|
||||||
|
|
||||||
AC_ARG_WITH([devkit], [AS_HELP_STRING([--with-devkit],
|
|
||||||
[use this directory as base for tools-dir and sys-root (for cross-compiling)])],
|
|
||||||
[
|
|
||||||
if test "x$with_sys_root" != x; then
|
|
||||||
AC_MSG_ERROR([Cannot specify both --with-devkit and --with-sys-root at the same time])
|
|
||||||
fi
|
|
||||||
BASIC_FIXUP_PATH([with_devkit])
|
|
||||||
BASIC_APPEND_TO_PATH([TOOLS_DIR],$with_devkit/bin)
|
|
||||||
if test -d "$with_devkit/$host_alias/libc"; then
|
|
||||||
SYS_ROOT=$with_devkit/$host_alias/libc
|
|
||||||
elif test -d "$with_devkit/$host/sys-root"; then
|
|
||||||
SYS_ROOT=$with_devkit/$host/sys-root
|
|
||||||
fi
|
|
||||||
])
|
|
||||||
])
|
])
|
||||||
|
|
||||||
AC_DEFUN_ONCE([BASIC_SETUP_OUTPUT_DIR],
|
AC_DEFUN_ONCE([BASIC_SETUP_OUTPUT_DIR],
|
||||||
@ -648,10 +714,10 @@ AC_DEFUN([BASIC_CHECK_GNU_MAKE],
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
if test "x$FOUND_MAKE" = x; then
|
if test "x$FOUND_MAKE" = x; then
|
||||||
if test "x$TOOLS_DIR" != x; then
|
if test "x$TOOLCHAIN_PATH" != x; then
|
||||||
# We have a tools-dir, check that as well before giving up.
|
# We have a toolchain path, check that as well before giving up.
|
||||||
OLD_PATH=$PATH
|
OLD_PATH=$PATH
|
||||||
PATH=$TOOLS_DIR:$PATH
|
PATH=$TOOLCHAIN_PATH:$PATH
|
||||||
AC_PATH_PROGS(CHECK_TOOLSDIR_GMAKE, gmake)
|
AC_PATH_PROGS(CHECK_TOOLSDIR_GMAKE, gmake)
|
||||||
BASIC_CHECK_MAKE_VERSION("$CHECK_TOOLSDIR_GMAKE", [gmake in tools-dir])
|
BASIC_CHECK_MAKE_VERSION("$CHECK_TOOLSDIR_GMAKE", [gmake in tools-dir])
|
||||||
if test "x$FOUND_MAKE" = x; then
|
if test "x$FOUND_MAKE" = x; then
|
||||||
|
10
common/autoconf/build-aux/config.guess
vendored
10
common/autoconf/build-aux/config.guess
vendored
@ -76,4 +76,14 @@ if test $? = 0; then
|
|||||||
OUT=powerpc$KERNEL_BITMODE`echo $OUT | sed -e 's/[^-]*//'`
|
OUT=powerpc$KERNEL_BITMODE`echo $OUT | sed -e 's/[^-]*//'`
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# Test and fix little endian PowerPC64.
|
||||||
|
# TODO: should be handled by autoconf-config.guess.
|
||||||
|
if [ "x$OUT" = x ]; then
|
||||||
|
if [ `uname -m` = ppc64le ]; then
|
||||||
|
if [ `uname -s` = Linux ]; then
|
||||||
|
OUT=powerpc64le-unknown-linux-gnu
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
echo $OUT
|
echo $OUT
|
||||||
|
@ -169,8 +169,8 @@ AC_DEFUN([BPERF_SETUP_CCACHE],
|
|||||||
if test "x$enable_ccache" = xyes; then
|
if test "x$enable_ccache" = xyes; then
|
||||||
AC_MSG_RESULT([yes])
|
AC_MSG_RESULT([yes])
|
||||||
OLD_PATH="$PATH"
|
OLD_PATH="$PATH"
|
||||||
if test "x$TOOLS_DIR" != x; then
|
if test "x$TOOLCHAIN_PATH" != x; then
|
||||||
PATH=$TOOLS_DIR:$PATH
|
PATH=$TOOLCHAIN_PATH:$PATH
|
||||||
fi
|
fi
|
||||||
BASIC_REQUIRE_PROGS(CCACHE, ccache)
|
BASIC_REQUIRE_PROGS(CCACHE, ccache)
|
||||||
CCACHE_STATUS="enabled"
|
CCACHE_STATUS="enabled"
|
||||||
|
@ -100,6 +100,9 @@ JDKOPT_SETUP_DEBUG_LEVEL
|
|||||||
# With basic setup done, call the custom early hook.
|
# With basic setup done, call the custom early hook.
|
||||||
CUSTOM_EARLY_HOOK
|
CUSTOM_EARLY_HOOK
|
||||||
|
|
||||||
|
# Check if we have devkits, extra paths or sysroot set.
|
||||||
|
BASIC_SETUP_DEVKIT
|
||||||
|
|
||||||
# To properly create a configuration name, we need to have the OpenJDK target
|
# To properly create a configuration name, we need to have the OpenJDK target
|
||||||
# and options (variants and debug level) parsed.
|
# and options (variants and debug level) parsed.
|
||||||
BASIC_SETUP_OUTPUT_DIR
|
BASIC_SETUP_OUTPUT_DIR
|
||||||
|
@ -119,6 +119,32 @@ AC_DEFUN_ONCE([FLAGS_SETUP_INIT_FLAGS],
|
|||||||
# FIXME: likely bug, should be CCXXFLAGS_JDK? or one for C or CXX.
|
# FIXME: likely bug, should be CCXXFLAGS_JDK? or one for C or CXX.
|
||||||
CCXXFLAGS="$CCXXFLAGS -nologo"
|
CCXXFLAGS="$CCXXFLAGS -nologo"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if test "x$SYSROOT" != "x"; then
|
||||||
|
if test "x$TOOLCHAIN_TYPE" = xsolstudio; then
|
||||||
|
if test "x$OPENJDK_TARGET_OS" = xsolaris; then
|
||||||
|
# Solaris Studio does not have a concept of sysroot. Instead we must
|
||||||
|
# make sure the default include and lib dirs are appended to each
|
||||||
|
# compile and link command line.
|
||||||
|
SYSROOT_CFLAGS="-I$SYSROOT/usr/include"
|
||||||
|
SYSROOT_LDFLAGS="-L$SYSROOT/usr/lib$OPENJDK_TARGET_CPU_ISADIR \
|
||||||
|
-L$SYSROOT/lib$OPENJDK_TARGET_CPU_ISADIR \
|
||||||
|
-L$SYSROOT/usr/ccs/lib$OPENJDK_TARGET_CPU_ISADIR"
|
||||||
|
fi
|
||||||
|
elif test "x$TOOLCHAIN_TYPE" = xgcc; then
|
||||||
|
SYSROOT_CFLAGS="--sysroot=\"$SYSROOT\""
|
||||||
|
SYSROOT_LDFLAGS="--sysroot=\"$SYSROOT\""
|
||||||
|
elif test "x$TOOLCHAIN_TYPE" = xclang; then
|
||||||
|
SYSROOT_CFLAGS="-isysroot \"$SYSROOT\""
|
||||||
|
SYSROOT_LDFLAGS="-isysroot \"$SYSROOT\""
|
||||||
|
fi
|
||||||
|
# Propagate the sysroot args to hotspot
|
||||||
|
LEGACY_EXTRA_CFLAGS="$LEGACY_EXTRA_CFLAGS $SYSROOT_CFLAGS"
|
||||||
|
LEGACY_EXTRA_CXXFLAGS="$LEGACY_EXTRA_CXXFLAGS $SYSROOT_CFLAGS"
|
||||||
|
LEGACY_EXTRA_LDFLAGS="$LEGACY_EXTRA_LDFLAGS $SYSROOT_LDFLAGS"
|
||||||
|
fi
|
||||||
|
AC_SUBST(SYSROOT_CFLAGS)
|
||||||
|
AC_SUBST(SYSROOT_LDFLAGS)
|
||||||
])
|
])
|
||||||
|
|
||||||
AC_DEFUN_ONCE([FLAGS_SETUP_COMPILER_FLAGS_FOR_LIBS],
|
AC_DEFUN_ONCE([FLAGS_SETUP_COMPILER_FLAGS_FOR_LIBS],
|
||||||
@ -421,9 +447,9 @@ AC_DEFUN_ONCE([FLAGS_SETUP_COMPILER_FLAGS_FOR_JDK],
|
|||||||
LDFLAGS_JDK="${LDFLAGS_JDK} $with_extra_ldflags"
|
LDFLAGS_JDK="${LDFLAGS_JDK} $with_extra_ldflags"
|
||||||
|
|
||||||
# Hotspot needs these set in their legacy form
|
# Hotspot needs these set in their legacy form
|
||||||
LEGACY_EXTRA_CFLAGS=$with_extra_cflags
|
LEGACY_EXTRA_CFLAGS="$LEGACY_EXTRA_CFLAGS $with_extra_cflags"
|
||||||
LEGACY_EXTRA_CXXFLAGS=$with_extra_cxxflags
|
LEGACY_EXTRA_CXXFLAGS="$LEGACY_EXTRA_CXXFLAGS $with_extra_cxxflags"
|
||||||
LEGACY_EXTRA_LDFLAGS=$with_extra_ldflags
|
LEGACY_EXTRA_LDFLAGS="$LEGACY_EXTRA_LDFLAGS $with_extra_ldflags"
|
||||||
|
|
||||||
AC_SUBST(LEGACY_EXTRA_CFLAGS)
|
AC_SUBST(LEGACY_EXTRA_CFLAGS)
|
||||||
AC_SUBST(LEGACY_EXTRA_CXXFLAGS)
|
AC_SUBST(LEGACY_EXTRA_CXXFLAGS)
|
||||||
@ -521,7 +547,13 @@ AC_DEFUN_ONCE([FLAGS_SETUP_COMPILER_FLAGS_FOR_JDK],
|
|||||||
CCXXFLAGS_JDK="$CCXXFLAGS_JDK -D_LITTLE_ENDIAN"
|
CCXXFLAGS_JDK="$CCXXFLAGS_JDK -D_LITTLE_ENDIAN"
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
CCXXFLAGS_JDK="$CCXXFLAGS_JDK -D_BIG_ENDIAN"
|
# Same goes for _BIG_ENDIAN. Do we really need to set *ENDIAN on Solaris if they
|
||||||
|
# are defined in the system?
|
||||||
|
if test "x$OPENJDK_TARGET_OS" = xsolaris; then
|
||||||
|
CCXXFLAGS_JDK="$CCXXFLAGS_JDK -D_BIG_ENDIAN="
|
||||||
|
else
|
||||||
|
CCXXFLAGS_JDK="$CCXXFLAGS_JDK -D_BIG_ENDIAN"
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Setup target OS define. Use OS target name but in upper case.
|
# Setup target OS define. Use OS target name but in upper case.
|
||||||
@ -735,4 +767,20 @@ AC_DEFUN_ONCE([FLAGS_SETUP_COMPILER_FLAGS_MISC],
|
|||||||
[COMPILER_SUPPORTS_TARGET_BITS_FLAG=true],
|
[COMPILER_SUPPORTS_TARGET_BITS_FLAG=true],
|
||||||
[COMPILER_SUPPORTS_TARGET_BITS_FLAG=false])
|
[COMPILER_SUPPORTS_TARGET_BITS_FLAG=false])
|
||||||
AC_SUBST(COMPILER_SUPPORTS_TARGET_BITS_FLAG)
|
AC_SUBST(COMPILER_SUPPORTS_TARGET_BITS_FLAG)
|
||||||
|
|
||||||
|
case "${TOOLCHAIN_TYPE}" in
|
||||||
|
microsoft)
|
||||||
|
CFLAGS_WARNINGS_ARE_ERRORS="/WX"
|
||||||
|
;;
|
||||||
|
solstudio)
|
||||||
|
CFLAGS_WARNINGS_ARE_ERRORS="-errtags -errwarn=%all"
|
||||||
|
;;
|
||||||
|
gcc)
|
||||||
|
CFLAGS_WARNINGS_ARE_ERRORS="-Werror"
|
||||||
|
;;
|
||||||
|
clang)
|
||||||
|
CFLAGS_WARNINGS_ARE_ERRORS="-Werror"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
AC_SUBST(CFLAGS_WARNINGS_ARE_ERRORS)
|
||||||
])
|
])
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -200,6 +200,7 @@ AC_DEFUN_ONCE([HELP_PRINT_SUMMARY_AND_WARNINGS],
|
|||||||
printf "\n"
|
printf "\n"
|
||||||
printf "Configuration summary:\n"
|
printf "Configuration summary:\n"
|
||||||
printf "* Debug level: $DEBUG_LEVEL\n"
|
printf "* Debug level: $DEBUG_LEVEL\n"
|
||||||
|
printf "* HS debug level: $HOTSPOT_DEBUG_LEVEL\n"
|
||||||
printf "* JDK variant: $JDK_VARIANT\n"
|
printf "* JDK variant: $JDK_VARIANT\n"
|
||||||
printf "* JVM variants: $with_jvm_variants\n"
|
printf "* JVM variants: $with_jvm_variants\n"
|
||||||
printf "* OpenJDK target: OS: $OPENJDK_TARGET_OS, CPU architecture: $OPENJDK_TARGET_CPU_ARCH, address length: $OPENJDK_TARGET_CPU_BITS\n"
|
printf "* OpenJDK target: OS: $OPENJDK_TARGET_OS, CPU architecture: $OPENJDK_TARGET_CPU_ARCH, address length: $OPENJDK_TARGET_CPU_BITS\n"
|
||||||
|
@ -176,6 +176,7 @@ AC_DEFUN_ONCE([JDKOPT_SETUP_DEBUG_LEVEL],
|
|||||||
#
|
#
|
||||||
# Set the debug level
|
# Set the debug level
|
||||||
# release: no debug information, all optimizations, no asserts.
|
# release: no debug information, all optimizations, no asserts.
|
||||||
|
# optimized: no debug information, all optimizations, no asserts, HotSpot target is 'optimized'.
|
||||||
# fastdebug: debug information (-g), all optimizations, all asserts
|
# fastdebug: debug information (-g), all optimizations, all asserts
|
||||||
# slowdebug: debug information (-g), no optimizations, all asserts
|
# slowdebug: debug information (-g), no optimizations, all asserts
|
||||||
#
|
#
|
||||||
@ -189,7 +190,7 @@ AC_DEFUN_ONCE([JDKOPT_SETUP_DEBUG_LEVEL],
|
|||||||
], [ENABLE_DEBUG="no"])
|
], [ENABLE_DEBUG="no"])
|
||||||
|
|
||||||
AC_ARG_WITH([debug-level], [AS_HELP_STRING([--with-debug-level],
|
AC_ARG_WITH([debug-level], [AS_HELP_STRING([--with-debug-level],
|
||||||
[set the debug level (release, fastdebug, slowdebug) @<:@release@:>@])],
|
[set the debug level (release, fastdebug, slowdebug, optimized (HotSpot build only)) @<:@release@:>@])],
|
||||||
[
|
[
|
||||||
DEBUG_LEVEL="${withval}"
|
DEBUG_LEVEL="${withval}"
|
||||||
if test "x$ENABLE_DEBUG" = xyes; then
|
if test "x$ENABLE_DEBUG" = xyes; then
|
||||||
@ -199,6 +200,7 @@ AC_DEFUN_ONCE([JDKOPT_SETUP_DEBUG_LEVEL],
|
|||||||
AC_MSG_RESULT([$DEBUG_LEVEL])
|
AC_MSG_RESULT([$DEBUG_LEVEL])
|
||||||
|
|
||||||
if test "x$DEBUG_LEVEL" != xrelease && \
|
if test "x$DEBUG_LEVEL" != xrelease && \
|
||||||
|
test "x$DEBUG_LEVEL" != xoptimized && \
|
||||||
test "x$DEBUG_LEVEL" != xfastdebug && \
|
test "x$DEBUG_LEVEL" != xfastdebug && \
|
||||||
test "x$DEBUG_LEVEL" != xslowdebug; then
|
test "x$DEBUG_LEVEL" != xslowdebug; then
|
||||||
AC_MSG_ERROR([Allowed debug levels are: release, fastdebug and slowdebug])
|
AC_MSG_ERROR([Allowed debug levels are: release, fastdebug and slowdebug])
|
||||||
@ -235,8 +237,30 @@ AC_DEFUN_ONCE([JDKOPT_SETUP_DEBUG_LEVEL],
|
|||||||
HOTSPOT_DEBUG_LEVEL="jvmg"
|
HOTSPOT_DEBUG_LEVEL="jvmg"
|
||||||
HOTSPOT_EXPORT="debug"
|
HOTSPOT_EXPORT="debug"
|
||||||
;;
|
;;
|
||||||
|
optimized )
|
||||||
|
VARIANT="OPT"
|
||||||
|
FASTDEBUG="false"
|
||||||
|
DEBUG_CLASSFILES="false"
|
||||||
|
BUILD_VARIANT_RELEASE="-optimized"
|
||||||
|
HOTSPOT_DEBUG_LEVEL="optimized"
|
||||||
|
HOTSPOT_EXPORT="optimized"
|
||||||
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
|
# The debug level 'optimized' is a little special because it is currently only
|
||||||
|
# applicable to the HotSpot build where it means to build a completely
|
||||||
|
# optimized version of the VM without any debugging code (like for the
|
||||||
|
# 'release' debug level which is called 'product' in the HotSpot build) but
|
||||||
|
# with the exception that it can contain additional code which is otherwise
|
||||||
|
# protected by '#ifndef PRODUCT' macros. These 'optimized' builds are used to
|
||||||
|
# test new and/or experimental features which are not intended for customer
|
||||||
|
# shipment. Because these new features need to be tested and benchmarked in
|
||||||
|
# real world scenarios, we want to build the containing JDK at the 'release'
|
||||||
|
# debug level.
|
||||||
|
if test "x$DEBUG_LEVEL" = xoptimized; then
|
||||||
|
DEBUG_LEVEL="release"
|
||||||
|
fi
|
||||||
|
|
||||||
#####
|
#####
|
||||||
# Generate the legacy makefile targets for hotspot.
|
# Generate the legacy makefile targets for hotspot.
|
||||||
# The hotspot api for selecting the build artifacts, really, needs to be improved.
|
# The hotspot api for selecting the build artifacts, really, needs to be improved.
|
||||||
|
@ -110,21 +110,23 @@ AC_DEFUN_ONCE([LIB_SETUP_X11],
|
|||||||
# Check if the user has specified sysroot, but not --x-includes or --x-libraries.
|
# Check if the user has specified sysroot, but not --x-includes or --x-libraries.
|
||||||
# Make a simple check for the libraries at the sysroot, and setup --x-includes and
|
# Make a simple check for the libraries at the sysroot, and setup --x-includes and
|
||||||
# --x-libraries for the sysroot, if that seems to be correct.
|
# --x-libraries for the sysroot, if that seems to be correct.
|
||||||
if test "x$SYS_ROOT" != "x/"; then
|
if test "x$OPENJDK_TARGET_OS" = "xlinux"; then
|
||||||
if test "x$x_includes" = xNONE; then
|
if test "x$SYSROOT" != "x"; then
|
||||||
if test -f "$SYS_ROOT/usr/X11R6/include/X11/Xlib.h"; then
|
if test "x$x_includes" = xNONE; then
|
||||||
x_includes="$SYS_ROOT/usr/X11R6/include"
|
if test -f "$SYSROOT/usr/X11R6/include/X11/Xlib.h"; then
|
||||||
elif test -f "$SYS_ROOT/usr/include/X11/Xlib.h"; then
|
x_includes="$SYSROOT/usr/X11R6/include"
|
||||||
x_includes="$SYS_ROOT/usr/include"
|
elif test -f "$SYSROOT/usr/include/X11/Xlib.h"; then
|
||||||
|
x_includes="$SYSROOT/usr/include"
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
fi
|
if test "x$x_libraries" = xNONE; then
|
||||||
if test "x$x_libraries" = xNONE; then
|
if test -f "$SYSROOT/usr/X11R6/lib/libX11.so"; then
|
||||||
if test -f "$SYS_ROOT/usr/X11R6/lib/libX11.so"; then
|
x_libraries="$SYSROOT/usr/X11R6/lib"
|
||||||
x_libraries="$SYS_ROOT/usr/X11R6/lib"
|
elif test "$SYSROOT/usr/lib64/libX11.so" && test "x$OPENJDK_TARGET_CPU_BITS" = x64; then
|
||||||
elif test "$SYS_ROOT/usr/lib64/libX11.so" && test "x$OPENJDK_TARGET_CPU_BITS" = x64; then
|
x_libraries="$SYSROOT/usr/lib64"
|
||||||
x_libraries="$SYS_ROOT/usr/lib64"
|
elif test -f "$SYSROOT/usr/lib/libX11.so"; then
|
||||||
elif test -f "$SYS_ROOT/usr/lib/libX11.so"; then
|
x_libraries="$SYSROOT/usr/lib"
|
||||||
x_libraries="$SYS_ROOT/usr/lib"
|
fi
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
@ -146,9 +148,12 @@ AC_DEFUN_ONCE([LIB_SETUP_X11],
|
|||||||
|
|
||||||
if test "x$OPENJDK_TARGET_OS" = xsolaris; then
|
if test "x$OPENJDK_TARGET_OS" = xsolaris; then
|
||||||
OPENWIN_HOME="/usr/openwin"
|
OPENWIN_HOME="/usr/openwin"
|
||||||
|
X_CFLAGS="-I$SYSROOT$OPENWIN_HOME/include -I$SYSROOT$OPENWIN_HOME/include/X11/extensions"
|
||||||
|
X_LIBS="-L$SYSROOT$OPENWIN_HOME/sfw/lib$OPENJDK_TARGET_CPU_ISADIR \
|
||||||
|
-L$SYSROOT$OPENWIN_HOME/lib$OPENJDK_TARGET_CPU_ISADIR \
|
||||||
|
-R$OPENWIN_HOME/sfw/lib$OPENJDK_TARGET_CPU_ISADIR \
|
||||||
|
-R$OPENWIN_HOME/lib$OPENJDK_TARGET_CPU_ISADIR"
|
||||||
fi
|
fi
|
||||||
AC_SUBST(OPENWIN_HOME)
|
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# Weird Sol10 something check...TODO change to try compile
|
# Weird Sol10 something check...TODO change to try compile
|
||||||
@ -237,14 +242,14 @@ AC_DEFUN_ONCE([LIB_SETUP_CUPS],
|
|||||||
# Getting nervous now? Lets poke around for standard Solaris third-party
|
# Getting nervous now? Lets poke around for standard Solaris third-party
|
||||||
# package installation locations.
|
# package installation locations.
|
||||||
AC_MSG_CHECKING([for cups headers])
|
AC_MSG_CHECKING([for cups headers])
|
||||||
if test -s /opt/sfw/cups/include/cups/cups.h; then
|
if test -s $SYSROOT/opt/sfw/cups/include/cups/cups.h; then
|
||||||
# An SFW package seems to be installed!
|
# An SFW package seems to be installed!
|
||||||
CUPS_FOUND=yes
|
CUPS_FOUND=yes
|
||||||
CUPS_CFLAGS="-I/opt/sfw/cups/include"
|
CUPS_CFLAGS="-I$SYSROOT/opt/sfw/cups/include"
|
||||||
elif test -s /opt/csw/include/cups/cups.h; then
|
elif test -s $SYSROOT/opt/csw/include/cups/cups.h; then
|
||||||
# A CSW package seems to be installed!
|
# A CSW package seems to be installed!
|
||||||
CUPS_FOUND=yes
|
CUPS_FOUND=yes
|
||||||
CUPS_CFLAGS="-I/opt/csw/include"
|
CUPS_CFLAGS="-I$SYSROOT/opt/csw/include"
|
||||||
fi
|
fi
|
||||||
AC_MSG_RESULT([$CUPS_FOUND])
|
AC_MSG_RESULT([$CUPS_FOUND])
|
||||||
fi
|
fi
|
||||||
@ -398,24 +403,27 @@ AC_DEFUN_ONCE([LIB_SETUP_FREETYPE],
|
|||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if test "x$FOUND_FREETYPE" != xyes; then
|
# If we have a sysroot, assume that's where we are supposed to look and skip pkg-config.
|
||||||
# Check modules using pkg-config, but only if we have it (ugly output results otherwise)
|
if test "x$SYSROOT" = x; then
|
||||||
if test "x$PKG_CONFIG" != x; then
|
if test "x$FOUND_FREETYPE" != xyes; then
|
||||||
PKG_CHECK_MODULES(FREETYPE, freetype2, [FOUND_FREETYPE=yes], [FOUND_FREETYPE=no])
|
# Check modules using pkg-config, but only if we have it (ugly output results otherwise)
|
||||||
if test "x$FOUND_FREETYPE" = xyes; then
|
if test "x$PKG_CONFIG" != x; then
|
||||||
# On solaris, pkg_check adds -lz to freetype libs, which isn't necessary for us.
|
PKG_CHECK_MODULES(FREETYPE, freetype2, [FOUND_FREETYPE=yes], [FOUND_FREETYPE=no])
|
||||||
FREETYPE_LIBS=`$ECHO $FREETYPE_LIBS | $SED 's/-lz//g'`
|
if test "x$FOUND_FREETYPE" = xyes; then
|
||||||
# 64-bit libs for Solaris x86 are installed in the amd64 subdirectory, change lib to lib/amd64
|
# On solaris, pkg_check adds -lz to freetype libs, which isn't necessary for us.
|
||||||
if test "x$OPENJDK_TARGET_OS" = xsolaris && test "x$OPENJDK_TARGET_CPU" = xx86_64; then
|
FREETYPE_LIBS=`$ECHO $FREETYPE_LIBS | $SED 's/-lz//g'`
|
||||||
FREETYPE_LIBS=`$ECHO $FREETYPE_LIBS | $SED 's?/lib?/lib/amd64?g'`
|
# 64-bit libs for Solaris x86 are installed in the amd64 subdirectory, change lib to lib/amd64
|
||||||
fi
|
if test "x$OPENJDK_TARGET_OS" = xsolaris && test "x$OPENJDK_TARGET_CPU" = xx86_64; then
|
||||||
# BDEPS_CHECK_MODULE will set FREETYPE_CFLAGS and _LIBS, but we don't get a lib path for bundling.
|
FREETYPE_LIBS=`$ECHO $FREETYPE_LIBS | $SED 's?/lib?/lib/amd64?g'`
|
||||||
if test "x$BUNDLE_FREETYPE" = xyes; then
|
fi
|
||||||
AC_MSG_NOTICE([Found freetype using pkg-config, but ignoring since we can not bundle that])
|
# BDEPS_CHECK_MODULE will set FREETYPE_CFLAGS and _LIBS, but we don't get a lib path for bundling.
|
||||||
FOUND_FREETYPE=no
|
if test "x$BUNDLE_FREETYPE" = xyes; then
|
||||||
else
|
AC_MSG_NOTICE([Found freetype using pkg-config, but ignoring since we can not bundle that])
|
||||||
AC_MSG_CHECKING([for freetype])
|
FOUND_FREETYPE=no
|
||||||
AC_MSG_RESULT([yes (using pkg-config)])
|
else
|
||||||
|
AC_MSG_CHECKING([for freetype])
|
||||||
|
AC_MSG_RESULT([yes (using pkg-config)])
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
@ -433,21 +441,21 @@ AC_DEFUN_ONCE([LIB_SETUP_FREETYPE],
|
|||||||
LIB_CHECK_POTENTIAL_FREETYPE([$FREETYPE_BASE_DIR/include], [$FREETYPE_BASE_DIR/lib], [well-known location])
|
LIB_CHECK_POTENTIAL_FREETYPE([$FREETYPE_BASE_DIR/include], [$FREETYPE_BASE_DIR/lib], [well-known location])
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
if test "x$SYS_ROOT" = "x/"; then
|
FREETYPE_BASE_DIR="$SYSROOT/usr"
|
||||||
FREETYPE_ROOT=
|
|
||||||
else
|
|
||||||
FREETYPE_ROOT="$SYS_ROOT"
|
|
||||||
fi
|
|
||||||
FREETYPE_BASE_DIR="$FREETYPE_ROOT/usr"
|
|
||||||
LIB_CHECK_POTENTIAL_FREETYPE([$FREETYPE_BASE_DIR/include], [$FREETYPE_BASE_DIR/lib], [well-known location])
|
LIB_CHECK_POTENTIAL_FREETYPE([$FREETYPE_BASE_DIR/include], [$FREETYPE_BASE_DIR/lib], [well-known location])
|
||||||
|
|
||||||
if test "x$FOUND_FREETYPE" != xyes; then
|
if test "x$FOUND_FREETYPE" != xyes; then
|
||||||
FREETYPE_BASE_DIR="$FREETYPE_ROOT/usr/X11"
|
FREETYPE_BASE_DIR="$SYSROOT/usr/X11"
|
||||||
LIB_CHECK_POTENTIAL_FREETYPE([$FREETYPE_BASE_DIR/include], [$FREETYPE_BASE_DIR/lib], [well-known location])
|
LIB_CHECK_POTENTIAL_FREETYPE([$FREETYPE_BASE_DIR/include], [$FREETYPE_BASE_DIR/lib], [well-known location])
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if test "x$FOUND_FREETYPE" != xyes; then
|
if test "x$FOUND_FREETYPE" != xyes; then
|
||||||
FREETYPE_BASE_DIR="$FREETYPE_ROOT/usr"
|
FREETYPE_BASE_DIR="$SYSROOT/usr/sfw"
|
||||||
|
LIB_CHECK_POTENTIAL_FREETYPE([$FREETYPE_BASE_DIR/include], [$FREETYPE_BASE_DIR/lib], [well-known location])
|
||||||
|
fi
|
||||||
|
|
||||||
|
if test "x$FOUND_FREETYPE" != xyes; then
|
||||||
|
FREETYPE_BASE_DIR="$SYSROOT/usr"
|
||||||
if test "x$OPENJDK_TARGET_CPU_BITS" = x64; then
|
if test "x$OPENJDK_TARGET_CPU_BITS" = x64; then
|
||||||
LIB_CHECK_POTENTIAL_FREETYPE([$FREETYPE_BASE_DIR/include], [$FREETYPE_BASE_DIR/lib/x86_64-linux-gnu], [well-known location])
|
LIB_CHECK_POTENTIAL_FREETYPE([$FREETYPE_BASE_DIR/include], [$FREETYPE_BASE_DIR/lib/x86_64-linux-gnu], [well-known location])
|
||||||
else
|
else
|
||||||
@ -577,8 +585,11 @@ AC_DEFUN_ONCE([LIB_SETUP_ALSA],
|
|||||||
if test "x$ALSA_FOUND" = xno; then
|
if test "x$ALSA_FOUND" = xno; then
|
||||||
BDEPS_CHECK_MODULE(ALSA, alsa, xxx, [ALSA_FOUND=yes], [ALSA_FOUND=no])
|
BDEPS_CHECK_MODULE(ALSA, alsa, xxx, [ALSA_FOUND=yes], [ALSA_FOUND=no])
|
||||||
fi
|
fi
|
||||||
if test "x$ALSA_FOUND" = xno; then
|
# Do not try pkg-config if we have a sysroot set.
|
||||||
PKG_CHECK_MODULES(ALSA, alsa, [ALSA_FOUND=yes], [ALSA_FOUND=no])
|
if test "x$SYSROOT" = x; then
|
||||||
|
if test "x$ALSA_FOUND" = xno; then
|
||||||
|
PKG_CHECK_MODULES(ALSA, alsa, [ALSA_FOUND=yes], [ALSA_FOUND=no])
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
if test "x$ALSA_FOUND" = xno; then
|
if test "x$ALSA_FOUND" = xno; then
|
||||||
AC_CHECK_HEADERS([alsa/asoundlib.h],
|
AC_CHECK_HEADERS([alsa/asoundlib.h],
|
||||||
@ -917,7 +928,7 @@ AC_DEFUN_ONCE([LIB_SETUP_STATIC_LINK_LIBSTDCPP],
|
|||||||
|
|
||||||
# libCrun is the c++ runtime-library with SunStudio (roughly the equivalent of gcc's libstdc++.so)
|
# libCrun is the c++ runtime-library with SunStudio (roughly the equivalent of gcc's libstdc++.so)
|
||||||
if test "x$TOOLCHAIN_TYPE" = xsolstudio && test "x$LIBCXX" = x; then
|
if test "x$TOOLCHAIN_TYPE" = xsolstudio && test "x$LIBCXX" = x; then
|
||||||
LIBCXX="/usr/lib${OPENJDK_TARGET_CPU_ISADIR}/libCrun.so.1"
|
LIBCXX="${SYSROOT}/usr/lib${OPENJDK_TARGET_CPU_ISADIR}/libCrun.so.1"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# TODO better (platform agnostic) test
|
# TODO better (platform agnostic) test
|
||||||
|
@ -60,6 +60,12 @@ AC_DEFUN([PLATFORM_EXTRACT_VARS_FROM_CPU],
|
|||||||
VAR_CPU_BITS=64
|
VAR_CPU_BITS=64
|
||||||
VAR_CPU_ENDIAN=big
|
VAR_CPU_ENDIAN=big
|
||||||
;;
|
;;
|
||||||
|
powerpc64le)
|
||||||
|
VAR_CPU=ppc64
|
||||||
|
VAR_CPU_ARCH=ppc
|
||||||
|
VAR_CPU_BITS=64
|
||||||
|
VAR_CPU_ENDIAN=little
|
||||||
|
;;
|
||||||
s390)
|
s390)
|
||||||
VAR_CPU=s390
|
VAR_CPU=s390
|
||||||
VAR_CPU_ARCH=s390
|
VAR_CPU_ARCH=s390
|
||||||
|
@ -130,10 +130,8 @@ ifeq ($(OPENJDK_TARGET_OS), windows)
|
|||||||
export LIB:=@VS_LIB@
|
export LIB:=@VS_LIB@
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# The sys root where standard headers and libraries are found.
|
SYSROOT_CFLAGS := @SYSROOT_CFLAGS@
|
||||||
# Usually not needed since the configure script should have
|
SYSROOT_LDFLAGS := @SYSROOT_LDFLAGS@
|
||||||
# taken it into account already when setting CFLAGS et al.
|
|
||||||
SYS_ROOT:=@SYS_ROOT@
|
|
||||||
|
|
||||||
# Paths to the source code
|
# Paths to the source code
|
||||||
ADD_SRC_ROOT:=@ADD_SRC_ROOT@
|
ADD_SRC_ROOT:=@ADD_SRC_ROOT@
|
||||||
@ -294,7 +292,6 @@ RMICONNECTOR_IIOP=@RMICONNECTOR_IIOP@
|
|||||||
# Necessary additional compiler flags to compile X11
|
# Necessary additional compiler flags to compile X11
|
||||||
X_CFLAGS:=@X_CFLAGS@
|
X_CFLAGS:=@X_CFLAGS@
|
||||||
X_LIBS:=@X_LIBS@
|
X_LIBS:=@X_LIBS@
|
||||||
OPENWIN_HOME:=@OPENWIN_HOME@
|
|
||||||
|
|
||||||
# The lowest required version of macosx to enforce compatiblity for
|
# The lowest required version of macosx to enforce compatiblity for
|
||||||
MACOSX_VERSION_MIN=@MACOSX_VERSION_MIN@
|
MACOSX_VERSION_MIN=@MACOSX_VERSION_MIN@
|
||||||
@ -324,6 +321,8 @@ CXX_O_FLAG_NONE:=@CXX_O_FLAG_NONE@
|
|||||||
C_FLAG_DEPS:=@C_FLAG_DEPS@
|
C_FLAG_DEPS:=@C_FLAG_DEPS@
|
||||||
CXX_FLAG_DEPS:=@CXX_FLAG_DEPS@
|
CXX_FLAG_DEPS:=@CXX_FLAG_DEPS@
|
||||||
|
|
||||||
|
CFLAGS_WARNINGS_ARE_ERRORS:=@CFLAGS_WARNINGS_ARE_ERRORS@
|
||||||
|
|
||||||
# Tools that potentially need to be cross compilation aware.
|
# Tools that potentially need to be cross compilation aware.
|
||||||
CC:=@FIXPATH@ @CCACHE@ @CC@
|
CC:=@FIXPATH@ @CCACHE@ @CC@
|
||||||
|
|
||||||
|
@ -189,6 +189,12 @@ AC_DEFUN_ONCE([TOOLCHAIN_PRE_DETECTION],
|
|||||||
# it for DLL resolution in runtime.
|
# it for DLL resolution in runtime.
|
||||||
if test "x$OPENJDK_BUILD_OS" = "xwindows" && test "x$TOOLCHAIN_TYPE" = "xmicrosoft"; then
|
if test "x$OPENJDK_BUILD_OS" = "xwindows" && test "x$TOOLCHAIN_TYPE" = "xmicrosoft"; then
|
||||||
TOOLCHAIN_SETUP_VISUAL_STUDIO_ENV
|
TOOLCHAIN_SETUP_VISUAL_STUDIO_ENV
|
||||||
|
# Reset path to VS_PATH. It will include everything that was on PATH at the time we
|
||||||
|
# ran TOOLCHAIN_SETUP_VISUAL_STUDIO_ENV.
|
||||||
|
PATH="$VS_PATH"
|
||||||
|
# The microsoft toolchain also requires INCLUDE and LIB to be set.
|
||||||
|
export INCLUDE="$VS_INCLUDE"
|
||||||
|
export LIB="$VS_LIB"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# autoconf magic only relies on PATH, so update it if tools dir is specified
|
# autoconf magic only relies on PATH, so update it if tools dir is specified
|
||||||
@ -202,29 +208,11 @@ AC_DEFUN_ONCE([TOOLCHAIN_PRE_DETECTION],
|
|||||||
PATH="/usr/ccs/bin:$PATH"
|
PATH="/usr/ccs/bin:$PATH"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Finally add TOOLS_DIR at the beginning, to allow --with-tools-dir to
|
# Finally add TOOLCHAIN_PATH at the beginning, to allow --with-tools-dir to
|
||||||
# override all other locations.
|
# override all other locations.
|
||||||
if test "x$TOOLS_DIR" != x; then
|
if test "x$TOOLCHAIN_PATH" != x; then
|
||||||
PATH=$TOOLS_DIR:$PATH
|
PATH=$TOOLCHAIN_PATH:$PATH
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# If a devkit is found on the builddeps server, then prepend its path to the
|
|
||||||
# PATH variable. If there are cross compilers available in the devkit, these
|
|
||||||
# will be found by AC_PROG_CC et al.
|
|
||||||
DEVKIT=
|
|
||||||
BDEPS_CHECK_MODULE(DEVKIT, devkit, xxx,
|
|
||||||
[
|
|
||||||
# Found devkit
|
|
||||||
PATH="$DEVKIT/bin:$PATH"
|
|
||||||
SYS_ROOT="$DEVKIT/${rewritten_target}/sys-root"
|
|
||||||
if test "x$x_includes" = "xNONE"; then
|
|
||||||
x_includes="$SYS_ROOT/usr/include/X11"
|
|
||||||
fi
|
|
||||||
if test "x$x_libraries" = "xNONE"; then
|
|
||||||
x_libraries="$SYS_ROOT/usr/lib"
|
|
||||||
fi
|
|
||||||
],
|
|
||||||
[])
|
|
||||||
])
|
])
|
||||||
|
|
||||||
# Restore path, etc
|
# Restore path, etc
|
||||||
@ -396,15 +384,15 @@ AC_DEFUN([TOOLCHAIN_FIND_COMPILER],
|
|||||||
# used.
|
# used.
|
||||||
|
|
||||||
$1=
|
$1=
|
||||||
# If TOOLS_DIR is set, check for all compiler names in there first
|
# If TOOLCHAIN_PATH is set, check for all compiler names in there first
|
||||||
# before checking the rest of the PATH.
|
# before checking the rest of the PATH.
|
||||||
# FIXME: Now that we prefix the TOOLS_DIR to the PATH in the PRE_DETECTION
|
# FIXME: Now that we prefix the TOOLS_DIR to the PATH in the PRE_DETECTION
|
||||||
# step, this should not be necessary.
|
# step, this should not be necessary.
|
||||||
if test -n "$TOOLS_DIR"; then
|
if test -n "$TOOLCHAIN_PATH"; then
|
||||||
PATH_save="$PATH"
|
PATH_save="$PATH"
|
||||||
PATH="$TOOLS_DIR"
|
PATH="$TOOLCHAIN_PATH"
|
||||||
AC_PATH_PROGS(TOOLS_DIR_$1, $SEARCH_LIST)
|
AC_PATH_PROGS(TOOLCHAIN_PATH_$1, $SEARCH_LIST)
|
||||||
$1=$TOOLS_DIR_$1
|
$1=$TOOLCHAIN_PATH_$1
|
||||||
PATH="$PATH_save"
|
PATH="$PATH_save"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
@ -141,46 +141,44 @@ AC_DEFUN([TOOLCHAIN_SETUP_VISUAL_STUDIO_ENV],
|
|||||||
|
|
||||||
# Lets extract the variables that are set by vcvarsall.bat/vsvars32.bat/vsvars64.bat
|
# Lets extract the variables that are set by vcvarsall.bat/vsvars32.bat/vsvars64.bat
|
||||||
AC_MSG_NOTICE([Trying to extract Visual Studio environment variables])
|
AC_MSG_NOTICE([Trying to extract Visual Studio environment variables])
|
||||||
cd $OUTPUT_ROOT
|
|
||||||
# FIXME: The code betweeen ---- was inlined from a separate script and is not properly adapted
|
|
||||||
# to autoconf standards.
|
|
||||||
|
|
||||||
#----
|
# We need to create a couple of temporary files.
|
||||||
|
VS_ENV_TMP_DIR="$OUTPUT_ROOT/vs-env"
|
||||||
|
$MKDIR -p $VS_ENV_TMP_DIR
|
||||||
|
|
||||||
# Cannot use the VS10 setup script directly (since it only updates the DOS subshell environment)
|
# Cannot use the VS10 setup script directly (since it only updates the DOS subshell environment).
|
||||||
# but calculate the difference in Cygwin environment before/after running it and then
|
# Instead create a shell script which will set the relevant variables when run.
|
||||||
# apply the diff.
|
WINPATH_VS_ENV_CMD="$VS_ENV_CMD"
|
||||||
|
BASIC_WINDOWS_REWRITE_AS_WINDOWS_MIXED_PATH([WINPATH_VS_ENV_CMD])
|
||||||
|
WINPATH_BASH="$BASH"
|
||||||
|
BASIC_WINDOWS_REWRITE_AS_WINDOWS_MIXED_PATH([WINPATH_BASH])
|
||||||
|
|
||||||
if test "x$OPENJDK_BUILD_OS_ENV" = xwindows.cygwin; then
|
# Generate a DOS batch file which runs $VS_ENV_CMD, and then creates a shell
|
||||||
_vs10varsall=`cygpath -a -m -s "$VS_ENV_CMD"`
|
# script (executable by bash) that will setup the important variables.
|
||||||
_dosvs10varsall=`cygpath -a -w -s $_vs10varsall`
|
EXTRACT_VC_ENV_BAT_FILE="$VS_ENV_TMP_DIR/extract-vs-env.bat"
|
||||||
_dosbash=`cygpath -a -w -s \`which bash\`.*`
|
$ECHO "@echo off" > $EXTRACT_VC_ENV_BAT_FILE
|
||||||
else
|
# This will end up something like:
|
||||||
_dosvs10varsall=`cmd //c echo $VS_ENV_CMD`
|
# call C:/progra~2/micros~2.0/vc/bin/amd64/vcvars64.bat
|
||||||
_dosbash=`cmd //c echo \`which bash\``
|
$ECHO "call $WINPATH_VS_ENV_CMD $VS_ENV_ARGS" >> $EXTRACT_VC_ENV_BAT_FILE
|
||||||
fi
|
# These will end up something like:
|
||||||
|
# C:/CygWin/bin/bash -c 'echo VS_PATH=\"$PATH\" > localdevenv.sh
|
||||||
# generate the set of exported vars before/after the vs10 setup
|
# The trailing space for everyone except PATH is no typo, but is needed due
|
||||||
$ECHO "@echo off" > localdevenvtmp.bat
|
# to trailing \ in the Windows paths. These will be stripped later.
|
||||||
$ECHO "$_dosbash -c \"export -p\" > localdevenvtmp.export0" >> localdevenvtmp.bat
|
$ECHO "$WINPATH_BASH -c 'echo VS_PATH="'\"$PATH\" > set-vs-env.sh' >> $EXTRACT_VC_ENV_BAT_FILE
|
||||||
$ECHO "call $_dosvs10varsall $VS_ENV_ARGS" >> localdevenvtmp.bat
|
$ECHO "$WINPATH_BASH -c 'echo VS_INCLUDE="'\"$INCLUDE \" >> set-vs-env.sh' >> $EXTRACT_VC_ENV_BAT_FILE
|
||||||
$ECHO "$_dosbash -c \"export -p\" > localdevenvtmp.export1" >> localdevenvtmp.bat
|
$ECHO "$WINPATH_BASH -c 'echo VS_LIB="'\"$LIB \" >> set-vs-env.sh' >> $EXTRACT_VC_ENV_BAT_FILE
|
||||||
|
$ECHO "$WINPATH_BASH -c 'echo VCINSTALLDIR="'\"$VCINSTALLDIR \" >> set-vs-env.sh' >> $EXTRACT_VC_ENV_BAT_FILE
|
||||||
|
$ECHO "$WINPATH_BASH -c 'echo WindowsSdkDir="'\"$WindowsSdkDir \" >> set-vs-env.sh' >> $EXTRACT_VC_ENV_BAT_FILE
|
||||||
|
$ECHO "$WINPATH_BASH -c 'echo WINDOWSSDKDIR="'\"$WINDOWSSDKDIR \" >> set-vs-env.sh' >> $EXTRACT_VC_ENV_BAT_FILE
|
||||||
|
|
||||||
# Now execute the newly created bat file.
|
# Now execute the newly created bat file.
|
||||||
# The | cat is to stop SetEnv.Cmd to mess with system colors on msys
|
# The | cat is to stop SetEnv.Cmd to mess with system colors on msys.
|
||||||
cmd /c localdevenvtmp.bat | cat
|
# Change directory so we don't need to mess with Windows paths in redirects.
|
||||||
|
cd $VS_ENV_TMP_DIR
|
||||||
# apply the diff (less some non-vs10 vars named by "!")
|
cmd /c extract-vs-env.bat | $CAT
|
||||||
$SORT localdevenvtmp.export0 | $GREP -v "!" > localdevenvtmp.export0.sort
|
|
||||||
$SORT localdevenvtmp.export1 | $GREP -v "!" > localdevenvtmp.export1.sort
|
|
||||||
$COMM -1 -3 localdevenvtmp.export0.sort localdevenvtmp.export1.sort > localdevenv.sh
|
|
||||||
|
|
||||||
# cleanup
|
|
||||||
$RM localdevenvtmp*
|
|
||||||
#----
|
|
||||||
cd $CURDIR
|
cd $CURDIR
|
||||||
if test ! -s $OUTPUT_ROOT/localdevenv.sh; then
|
|
||||||
AC_MSG_RESULT([no])
|
if test ! -s $VS_ENV_TMP_DIR/set-vs-env.sh; then
|
||||||
AC_MSG_NOTICE([Could not succesfully extract the envionment variables needed for the VS setup.])
|
AC_MSG_NOTICE([Could not succesfully extract the envionment variables needed for the VS setup.])
|
||||||
AC_MSG_NOTICE([Try setting --with-tools-dir to the VC/bin directory within the VS installation])
|
AC_MSG_NOTICE([Try setting --with-tools-dir to the VC/bin directory within the VS installation])
|
||||||
AC_MSG_NOTICE([or run "bash.exe -l" from a VS command prompt and then run configure from there.])
|
AC_MSG_NOTICE([or run "bash.exe -l" from a VS command prompt and then run configure from there.])
|
||||||
@ -190,30 +188,36 @@ AC_DEFUN([TOOLCHAIN_SETUP_VISUAL_STUDIO_ENV],
|
|||||||
# Now set all paths and other env variables. This will allow the rest of
|
# Now set all paths and other env variables. This will allow the rest of
|
||||||
# the configure script to find and run the compiler in the proper way.
|
# the configure script to find and run the compiler in the proper way.
|
||||||
AC_MSG_NOTICE([Setting extracted environment variables])
|
AC_MSG_NOTICE([Setting extracted environment variables])
|
||||||
. $OUTPUT_ROOT/localdevenv.sh
|
. $VS_ENV_TMP_DIR/set-vs-env.sh
|
||||||
|
# Now we have VS_PATH, VS_INCLUDE, VS_LIB. For further checking, we
|
||||||
|
# also define VCINSTALLDIR, WindowsSdkDir and WINDOWSSDKDIR.
|
||||||
else
|
else
|
||||||
# We did not find a vsvars bat file, let's hope we are run from a VS command prompt.
|
# We did not find a vsvars bat file, let's hope we are run from a VS command prompt.
|
||||||
AC_MSG_NOTICE([Cannot locate a valid Visual Studio installation, checking current environment])
|
AC_MSG_NOTICE([Cannot locate a valid Visual Studio installation, checking current environment])
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# At this point, we should have corrent variables in the environment, or we can't continue.
|
# At this point, we should have correct variables in the environment, or we can't continue.
|
||||||
AC_MSG_CHECKING([for Visual Studio variables])
|
AC_MSG_CHECKING([for Visual Studio variables])
|
||||||
|
|
||||||
if test "x$VCINSTALLDIR" != x || test "x$WindowsSDKDir" != x || test "x$WINDOWSSDKDIR" != x; then
|
if test "x$VCINSTALLDIR" != x || test "x$WindowsSDKDir" != x || test "x$WINDOWSSDKDIR" != x; then
|
||||||
if test "x$INCLUDE" = x || test "x$LIB" = x; then
|
if test "x$VS_INCLUDE" = x || test "x$VS_LIB" = x; then
|
||||||
AC_MSG_RESULT([present but broken])
|
AC_MSG_RESULT([present but broken])
|
||||||
AC_MSG_ERROR([Your VC command prompt seems broken, INCLUDE and/or LIB is missing.])
|
AC_MSG_ERROR([Your VC command prompt seems broken, INCLUDE and/or LIB is missing.])
|
||||||
else
|
else
|
||||||
AC_MSG_RESULT([ok])
|
AC_MSG_RESULT([ok])
|
||||||
# Remove any trailing \ from INCLUDE and LIB to avoid trouble in spec.gmk.
|
# Remove any trailing "\" and " " from the variables.
|
||||||
VS_INCLUDE=`$ECHO "$INCLUDE" | $SED 's/\\\\$//'`
|
VS_INCLUDE=`$ECHO "$VS_INCLUDE" | $SED 's/\\\\* *$//'`
|
||||||
VS_LIB=`$ECHO "$LIB" | $SED 's/\\\\$//'`
|
VS_LIB=`$ECHO "$VS_LIB" | $SED 's/\\\\* *$//'`
|
||||||
# Remove any paths containing # (typically F#) as that messes up make
|
VCINSTALLDIR=`$ECHO "$VCINSTALLDIR" | $SED 's/\\\\* *$//'`
|
||||||
PATH=`$ECHO "$PATH" | $SED 's/[[^:#]]*#[^:]*://g'`
|
WindowsSDKDir=`$ECHO "$WindowsSDKDir" | $SED 's/\\\\* *$//'`
|
||||||
VS_PATH="$PATH"
|
WINDOWSSDKDIR=`$ECHO "$WINDOWSSDKDIR" | $SED 's/\\\\* *$//'`
|
||||||
|
# Remove any paths containing # (typically F#) as that messes up make. This
|
||||||
|
# is needed if visual studio was installed with F# support.
|
||||||
|
VS_PATH=`$ECHO "$VS_PATH" | $SED 's/[[^:#]]*#[^:]*://g'`
|
||||||
|
|
||||||
|
AC_SUBST(VS_PATH)
|
||||||
AC_SUBST(VS_INCLUDE)
|
AC_SUBST(VS_INCLUDE)
|
||||||
AC_SUBST(VS_LIB)
|
AC_SUBST(VS_LIB)
|
||||||
AC_SUBST(VS_PATH)
|
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
AC_MSG_RESULT([not found])
|
AC_MSG_RESULT([not found])
|
||||||
|
@ -114,7 +114,7 @@ diff_text() {
|
|||||||
fi
|
fi
|
||||||
if test "x$SUFFIX" = "xproperties"; then
|
if test "x$SUFFIX" = "xproperties"; then
|
||||||
# Run through nawk to add possibly missing newline at end of file.
|
# Run through nawk to add possibly missing newline at end of file.
|
||||||
$CAT $OTHER_FILE | $NAWK '{ print }' > $OTHER_FILE.cleaned
|
$CAT $OTHER_FILE | $NAWK '{ print }' | LC_ALL=C $SORT > $OTHER_FILE.cleaned
|
||||||
# Disable this exception since we aren't changing the properties cleaning method yet.
|
# Disable this exception since we aren't changing the properties cleaning method yet.
|
||||||
# $CAT $OTHER_FILE | $SED -e 's/\([^\\]\):/\1\\:/g' -e 's/\([^\\]\)=/\1\\=/g' -e 's/#.*/#/g' \
|
# $CAT $OTHER_FILE | $SED -e 's/\([^\\]\):/\1\\:/g' -e 's/\([^\\]\)=/\1\\=/g' -e 's/#.*/#/g' \
|
||||||
# | $SED -f "$SRC_ROOT/common/makefiles/support/unicode2x.sed" \
|
# | $SED -f "$SRC_ROOT/common/makefiles/support/unicode2x.sed" \
|
||||||
|
@ -24,12 +24,58 @@
|
|||||||
#
|
#
|
||||||
|
|
||||||
# Shell script for a fast parallel forest command
|
# Shell script for a fast parallel forest command
|
||||||
command="$1"
|
|
||||||
pull_extra_base="$2"
|
|
||||||
|
|
||||||
if [ "" = "$command" ] ; then
|
global_opts=""
|
||||||
echo No command to hg supplied!
|
status_output="/dev/stdout"
|
||||||
exit 1
|
qflag="false"
|
||||||
|
vflag="false"
|
||||||
|
sflag="false"
|
||||||
|
while [ $# -gt 0 ]
|
||||||
|
do
|
||||||
|
case $1 in
|
||||||
|
-q | --quiet )
|
||||||
|
qflag="true"
|
||||||
|
global_opts="${global_opts} -q"
|
||||||
|
status_output="/dev/null"
|
||||||
|
;;
|
||||||
|
|
||||||
|
-v | --verbose )
|
||||||
|
vflag="true"
|
||||||
|
global_opts="${global_opts} -v"
|
||||||
|
;;
|
||||||
|
|
||||||
|
-s | --sequential )
|
||||||
|
sflag="true"
|
||||||
|
;;
|
||||||
|
|
||||||
|
'--' ) # no more options
|
||||||
|
shift; break
|
||||||
|
;;
|
||||||
|
|
||||||
|
-*) # bad option
|
||||||
|
usage
|
||||||
|
;;
|
||||||
|
|
||||||
|
* ) # non option
|
||||||
|
break
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
shift
|
||||||
|
done
|
||||||
|
|
||||||
|
|
||||||
|
command="$1"; shift
|
||||||
|
command_args="$@"
|
||||||
|
|
||||||
|
usage() {
|
||||||
|
echo "usage: $0 [-q|--quiet] [-v|--verbose] [-s|--sequential] [--] <command> [commands...]" > ${status_output}
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if [ "x" = "x$command" ] ; then
|
||||||
|
echo "ERROR: No command to hg supplied!"
|
||||||
|
usage
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Clean out the temporary directory that stores the pid files.
|
# Clean out the temporary directory that stores the pid files.
|
||||||
@ -40,17 +86,17 @@ mkdir -p ${tmp}
|
|||||||
safe_interrupt () {
|
safe_interrupt () {
|
||||||
if [ -d ${tmp} ]; then
|
if [ -d ${tmp} ]; then
|
||||||
if [ "`ls ${tmp}/*.pid`" != "" ]; then
|
if [ "`ls ${tmp}/*.pid`" != "" ]; then
|
||||||
echo "Waiting for processes ( `cat ${tmp}/*.pid | tr '\n' ' '`) to terminate nicely!"
|
echo "Waiting for processes ( `cat ${tmp}/*.pid | tr '\n' ' '`) to terminate nicely!" > ${status_output}
|
||||||
sleep 1
|
sleep 1
|
||||||
# Pipe stderr to dev/null to silence kill, that complains when trying to kill
|
# Pipe stderr to dev/null to silence kill, that complains when trying to kill
|
||||||
# a subprocess that has already exited.
|
# a subprocess that has already exited.
|
||||||
kill -TERM `cat ${tmp}/*.pid | tr '\n' ' '` 2> /dev/null
|
kill -TERM `cat ${tmp}/*.pid | tr '\n' ' '` 2> /dev/null
|
||||||
wait
|
wait
|
||||||
echo Interrupt complete!
|
echo "Interrupt complete!" > ${status_output}
|
||||||
fi
|
fi
|
||||||
|
rm -f -r ${tmp}
|
||||||
fi
|
fi
|
||||||
rm -f -r ${tmp}
|
exit 130
|
||||||
exit 1
|
|
||||||
}
|
}
|
||||||
|
|
||||||
nice_exit () {
|
nice_exit () {
|
||||||
@ -58,39 +104,44 @@ nice_exit () {
|
|||||||
if [ "`ls ${tmp}`" != "" ]; then
|
if [ "`ls ${tmp}`" != "" ]; then
|
||||||
wait
|
wait
|
||||||
fi
|
fi
|
||||||
|
rm -f -r ${tmp}
|
||||||
fi
|
fi
|
||||||
rm -f -r ${tmp}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
trap 'safe_interrupt' INT QUIT
|
trap 'safe_interrupt' INT QUIT
|
||||||
trap 'nice_exit' EXIT
|
trap 'nice_exit' EXIT
|
||||||
|
|
||||||
|
subrepos="corba jaxp jaxws langtools jdk hotspot nashorn"
|
||||||
|
subrepos_extra="closed jdk/src/closed jdk/make/closed jdk/test/closed hotspot/make/closed hotspot/src/closed hotspot/test/closed deploy install sponsors pubs"
|
||||||
|
|
||||||
# Only look in specific locations for possible forests (avoids long searches)
|
# Only look in specific locations for possible forests (avoids long searches)
|
||||||
pull_default=""
|
pull_default=""
|
||||||
repos=""
|
repos=""
|
||||||
repos_extra=""
|
repos_extra=""
|
||||||
if [ "${command}" = "clone" -o "${command}" = "fclone" ] ; then
|
if [ "${command}" = "clone" -o "${command}" = "fclone" -o "${command}" = "tclone" ] ; then
|
||||||
subrepos="corba jaxp jaxws langtools jdk hotspot nashorn"
|
if [ ! -f .hg/hgrc ] ; then
|
||||||
if [ -f .hg/hgrc ] ; then
|
echo "ERROR: Need initial repository to use this script" > ${status_output}
|
||||||
pull_default=`hg paths default`
|
|
||||||
if [ "${pull_default}" = "" ] ; then
|
|
||||||
echo "ERROR: Need initial clone with 'hg paths default' defined"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
if [ "${pull_default}" = "" ] ; then
|
|
||||||
echo "ERROR: Need initial repository to use this script"
|
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
pull_default=`hg paths default`
|
||||||
|
if [ "${pull_default}" = "" ] ; then
|
||||||
|
echo "ERROR: Need initial clone with 'hg paths default' defined" > ${status_output}
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
for i in ${subrepos} ; do
|
for i in ${subrepos} ; do
|
||||||
if [ ! -f ${i}/.hg/hgrc ] ; then
|
if [ ! -f ${i}/.hg/hgrc ] ; then
|
||||||
repos="${repos} ${i}"
|
repos="${repos} ${i}"
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
if [ "${pull_extra_base}" != "" ] ; then
|
if [ "${command_args}" != "" ] ; then
|
||||||
subrepos_extra="closed jdk/src/closed jdk/make/closed jdk/test/closed hotspot/make/closed hotspot/src/closed hotspot/test/closed deploy install sponsors pubs"
|
|
||||||
pull_default_tail=`echo ${pull_default} | sed -e 's@^.*://[^/]*/\(.*\)@\1@'`
|
pull_default_tail=`echo ${pull_default} | sed -e 's@^.*://[^/]*/\(.*\)@\1@'`
|
||||||
pull_extra="${pull_extra_base}/${pull_default_tail}"
|
if [ "x${pull_default}" = "x${pull_default_tail}" ] ; then
|
||||||
|
echo "ERROR: Need initial clone from non-local source" > ${status_output}
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
pull_extra="${command_args}/${pull_default_tail}"
|
||||||
for i in ${subrepos_extra} ; do
|
for i in ${subrepos_extra} ; do
|
||||||
if [ ! -f ${i}/.hg/hgrc ] ; then
|
if [ ! -f ${i}/.hg/hgrc ] ; then
|
||||||
repos_extra="${repos_extra} ${i}"
|
repos_extra="${repos_extra} ${i}"
|
||||||
@ -100,78 +151,115 @@ if [ "${command}" = "clone" -o "${command}" = "fclone" ] ; then
|
|||||||
at_a_time=2
|
at_a_time=2
|
||||||
# Any repos to deal with?
|
# Any repos to deal with?
|
||||||
if [ "${repos}" = "" -a "${repos_extra}" = "" ] ; then
|
if [ "${repos}" = "" -a "${repos_extra}" = "" ] ; then
|
||||||
|
echo "No repositories to process." > ${status_output}
|
||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
hgdirs=`ls -d ./.hg ./*/.hg ./*/*/.hg ./*/*/*/.hg ./*/*/*/*/.hg 2>/dev/null`
|
for i in . ${subrepos} ${subrepos_extra} ; do
|
||||||
# Derive repository names from the .hg directory locations
|
if [ -d ${i}/.hg ] ; then
|
||||||
for i in ${hgdirs} ; do
|
repos="${repos} ${i}"
|
||||||
repos="${repos} `echo ${i} | sed -e 's@/.hg$@@'`"
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
|
# Any repos to deal with?
|
||||||
|
if [ "${repos}" = "" ] ; then
|
||||||
|
echo "No repositories to process." > ${status_output}
|
||||||
|
exit
|
||||||
|
fi
|
||||||
|
|
||||||
|
# any of the repos locked?
|
||||||
for i in ${repos} ; do
|
for i in ${repos} ; do
|
||||||
if [ -h ${i}/.hg/store/lock -o -f ${i}/.hg/store/lock ] ; then
|
if [ -h ${i}/.hg/store/lock -o -f ${i}/.hg/store/lock ] ; then
|
||||||
locked="${i} ${locked}"
|
locked="${i} ${locked}"
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
at_a_time=8
|
|
||||||
# Any repos to deal with?
|
|
||||||
if [ "${repos}" = "" ] ; then
|
|
||||||
echo "No repositories to process."
|
|
||||||
exit
|
|
||||||
fi
|
|
||||||
if [ "${locked}" != "" ] ; then
|
if [ "${locked}" != "" ] ; then
|
||||||
echo "These repositories are locked: ${locked}"
|
echo "ERROR: These repositories are locked: ${locked}" > ${status_output}
|
||||||
exit
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
at_a_time=8
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Echo out what repositories we do a command on.
|
# Echo out what repositories we do a command on.
|
||||||
echo "# Repositories: ${repos} ${repos_extra}"
|
echo "# Repositories: ${repos} ${repos_extra}" > ${status_output}
|
||||||
echo
|
|
||||||
|
|
||||||
# Run the supplied command on all repos in parallel.
|
if [ "${command}" = "serve" ] ; then
|
||||||
n=0
|
# "serve" is run for all the repos.
|
||||||
for i in ${repos} ${repos_extra} ; do
|
(
|
||||||
n=`expr ${n} '+' 1`
|
(
|
||||||
repopidfile=`echo ${i} | sed -e 's@./@@' -e 's@/@_@g'`
|
(
|
||||||
reponame=`echo ${i} | sed -e :a -e 's/^.\{1,20\}$/ &/;ta'`
|
echo "[web]"
|
||||||
pull_base="${pull_default}"
|
echo "description = $(basename $(pwd))"
|
||||||
for j in $repos_extra ; do
|
echo "allow_push = *"
|
||||||
|
echo "push_ssl = False"
|
||||||
|
|
||||||
|
echo "[paths]"
|
||||||
|
for i in ${repos} ${repos_extra} ; do
|
||||||
|
if [ "${i}" != "." ] ; then
|
||||||
|
echo "/$(basename $(pwd))/${i} = ${i}"
|
||||||
|
else
|
||||||
|
echo "/$(basename $(pwd)) = $(pwd)"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
) > ${tmp}/serve.web-conf
|
||||||
|
|
||||||
|
echo "serving root repo $(basename $(pwd))"
|
||||||
|
|
||||||
|
(PYTHONUNBUFFERED=true hg${global_opts} serve -A ${status_output} -E ${status_output} --pid-file ${tmp}/serve.pid --web-conf ${tmp}/serve.web-conf; echo "$?" > ${tmp}/serve.pid.rc ) 2>&1 &
|
||||||
|
) 2>&1 | sed -e "s@^@serve: @" > ${status_output}
|
||||||
|
) &
|
||||||
|
else
|
||||||
|
# Run the supplied command on all repos in parallel.
|
||||||
|
n=0
|
||||||
|
for i in ${repos} ${repos_extra} ; do
|
||||||
|
n=`expr ${n} '+' 1`
|
||||||
|
repopidfile=`echo ${i} | sed -e 's@./@@' -e 's@/@_@g'`
|
||||||
|
reponame=`echo ${i} | sed -e :a -e 's/^.\{1,20\}$/ &/;ta'`
|
||||||
|
pull_base="${pull_default}"
|
||||||
|
for j in $repos_extra ; do
|
||||||
if [ "$i" = "$j" ] ; then
|
if [ "$i" = "$j" ] ; then
|
||||||
pull_base="${pull_extra}"
|
pull_base="${pull_extra}"
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
(
|
|
||||||
(
|
(
|
||||||
if [ "${command}" = "clone" -o "${command}" = "fclone" ] ; then
|
(
|
||||||
pull_newrepo="`echo ${pull_base}/${i} | sed -e 's@\([^:]/\)//*@\1@g'`"
|
if [ "${command}" = "clone" -o "${command}" = "fclone" -o "${command}" = "tclone" ] ; then
|
||||||
echo hg clone ${pull_newrepo} ${i}
|
pull_newrepo="`echo ${pull_base}/${i} | sed -e 's@\([^:]/\)//*@\1@g'`"
|
||||||
path="`dirname ${i}`"
|
path="`dirname ${i}`"
|
||||||
if [ "${path}" != "." ] ; then
|
if [ "${path}" != "." ] ; then
|
||||||
times=0
|
times=0
|
||||||
while [ ! -d "${path}" ] ## nested repo, ensure containing dir exists
|
while [ ! -d "${path}" ] ## nested repo, ensure containing dir exists
|
||||||
do
|
do
|
||||||
times=`expr ${times} '+' 1`
|
times=`expr ${times} '+' 1`
|
||||||
if [ `expr ${times} '%' 10` -eq 0 ] ; then
|
if [ `expr ${times} '%' 10` -eq 0 ] ; then
|
||||||
echo ${path} still not created, waiting...
|
echo "${path} still not created, waiting..." > ${status_output}
|
||||||
fi
|
fi
|
||||||
sleep 5
|
sleep 5
|
||||||
done
|
done
|
||||||
|
fi
|
||||||
|
echo "hg clone ${pull_newrepo} ${i}" > ${status_output}
|
||||||
|
(PYTHONUNBUFFERED=true hg${global_opts} clone ${pull_newrepo} ${i}; echo "$?" > ${tmp}/${repopidfile}.pid.rc ) 2>&1 &
|
||||||
|
else
|
||||||
|
echo "cd ${i} && hg${global_opts} ${command} ${command_args}" > ${status_output}
|
||||||
|
cd ${i} && (PYTHONUNBUFFERED=true hg${global_opts} ${command} ${command_args}; echo "$?" > ${tmp}/${repopidfile}.pid.rc ) 2>&1 &
|
||||||
fi
|
fi
|
||||||
(PYTHONUNBUFFERED=true hg clone ${pull_newrepo} ${i}; echo "$?" > ${tmp}/${repopidfile}.pid.rc )&
|
|
||||||
else
|
|
||||||
echo "cd ${i} && hg $*"
|
|
||||||
cd ${i} && (PYTHONUNBUFFERED=true hg "$@"; echo "$?" > ${tmp}/${repopidfile}.pid.rc )&
|
|
||||||
fi
|
|
||||||
echo $! > ${tmp}/${repopidfile}.pid
|
|
||||||
) 2>&1 | sed -e "s@^@${reponame}: @") &
|
|
||||||
|
|
||||||
if [ `expr ${n} '%' ${at_a_time}` -eq 0 ] ; then
|
echo $! > ${tmp}/${repopidfile}.pid
|
||||||
sleep 2
|
) 2>&1 | sed -e "s@^@${reponame}: @" > ${status_output}
|
||||||
echo Waiting 5 secs before spawning next background command.
|
) &
|
||||||
sleep 3
|
|
||||||
fi
|
if [ `expr ${n} '%' ${at_a_time}` -eq 0 -a "${sflag}" = "false" ] ; then
|
||||||
done
|
sleep 2
|
||||||
|
echo "Waiting 5 secs before spawning next background command." > ${status_output}
|
||||||
|
sleep 3
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "${sflag}" = "true" ] ; then
|
||||||
|
wait
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
fi
|
||||||
|
|
||||||
# Wait for all hg commands to complete
|
# Wait for all hg commands to complete
|
||||||
wait
|
wait
|
||||||
|
|
||||||
@ -181,7 +269,8 @@ if [ -d ${tmp} ]; then
|
|||||||
for rc in ${tmp}/*.pid.rc ; do
|
for rc in ${tmp}/*.pid.rc ; do
|
||||||
exit_code=`cat ${rc} | tr -d ' \n\r'`
|
exit_code=`cat ${rc} | tr -d ' \n\r'`
|
||||||
if [ "${exit_code}" != "0" ] ; then
|
if [ "${exit_code}" != "0" ] ; then
|
||||||
echo "WARNING: ${rc} exited abnormally."
|
repo="`echo ${rc} | sed -e s@^${tmp}@@ -e 's@/*\([^/]*\)\.pid\.rc$@\1@' -e 's@_@/@g'`"
|
||||||
|
echo "WARNING: ${repo} exited abnormally." > ${status_output}
|
||||||
ec=1
|
ec=1
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2011, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2011, 2014, 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
|
||||||
@ -29,7 +29,7 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <malloc.h>
|
#include <malloc.h>
|
||||||
|
|
||||||
void report_error()
|
void report_error(char const * msg)
|
||||||
{
|
{
|
||||||
LPVOID lpMsgBuf;
|
LPVOID lpMsgBuf;
|
||||||
DWORD dw = GetLastError();
|
DWORD dw = GetLastError();
|
||||||
@ -46,8 +46,8 @@ void report_error()
|
|||||||
NULL);
|
NULL);
|
||||||
|
|
||||||
fprintf(stderr,
|
fprintf(stderr,
|
||||||
"Could not start process! Failed with error %d: %s\n",
|
"%s Failed with error %d: %s\n",
|
||||||
dw, lpMsgBuf);
|
msg, dw, lpMsgBuf);
|
||||||
|
|
||||||
LocalFree(lpMsgBuf);
|
LocalFree(lpMsgBuf);
|
||||||
}
|
}
|
||||||
@ -56,7 +56,7 @@ void report_error()
|
|||||||
* Test if pos points to /cygdrive/_/ where _ can
|
* Test if pos points to /cygdrive/_/ where _ can
|
||||||
* be any character.
|
* be any character.
|
||||||
*/
|
*/
|
||||||
int is_cygdrive_here(int pos, char *in, int len)
|
int is_cygdrive_here(int pos, char const *in, int len)
|
||||||
{
|
{
|
||||||
// Length of /cygdrive/c/ is 12
|
// Length of /cygdrive/c/ is 12
|
||||||
if (pos+12 > len) return 0;
|
if (pos+12 > len) return 0;
|
||||||
@ -81,16 +81,17 @@ int is_cygdrive_here(int pos, char *in, int len)
|
|||||||
* Works in place since drive letter is always
|
* Works in place since drive letter is always
|
||||||
* shorter than /cygdrive/
|
* shorter than /cygdrive/
|
||||||
*/
|
*/
|
||||||
char *replace_cygdrive_cygwin(char *in)
|
char *replace_cygdrive_cygwin(char const *in)
|
||||||
{
|
{
|
||||||
int len = strlen(in);
|
size_t len = strlen(in);
|
||||||
char *out = malloc(len+1);
|
char *out = (char*) malloc(len+1);
|
||||||
int i,j;
|
int i,j;
|
||||||
|
|
||||||
if (len < 12) {
|
if (len < 12) {
|
||||||
strcpy(out, in);
|
memmove(out, in, len + 1);
|
||||||
return out;
|
return out;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (i = 0, j = 0; i<len;) {
|
for (i = 0, j = 0; i<len;) {
|
||||||
if (is_cygdrive_here(i, in, len)) {
|
if (is_cygdrive_here(i, in, len)) {
|
||||||
out[j++] = in[i+10];
|
out[j++] = in[i+10];
|
||||||
@ -102,7 +103,7 @@ char *replace_cygdrive_cygwin(char *in)
|
|||||||
j++;
|
j++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
out[j] = 0;
|
out[j] = '\0';
|
||||||
return out;
|
return out;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -110,7 +111,7 @@ void append(char **b, size_t *bl, size_t *u, char *add, size_t addlen)
|
|||||||
{
|
{
|
||||||
while ( (addlen+*u+1) > *bl) {
|
while ( (addlen+*u+1) > *bl) {
|
||||||
*bl *= 2;
|
*bl *= 2;
|
||||||
*b = realloc(*b, *bl);
|
*b = (char*) realloc(*b, *bl);
|
||||||
}
|
}
|
||||||
memcpy(*b+*u, add, addlen);
|
memcpy(*b+*u, add, addlen);
|
||||||
*u += addlen;
|
*u += addlen;
|
||||||
@ -125,7 +126,7 @@ char *replace_substring(char *in, char *sub, char *rep)
|
|||||||
int in_len = strlen(in);
|
int in_len = strlen(in);
|
||||||
int sub_len = strlen(sub);
|
int sub_len = strlen(sub);
|
||||||
int rep_len = strlen(rep);
|
int rep_len = strlen(rep);
|
||||||
char *out = malloc(in_len - sub_len + rep_len + 1);
|
char *out = (char *) malloc(in_len - sub_len + rep_len + 1);
|
||||||
char *p;
|
char *p;
|
||||||
|
|
||||||
if (!(p = strstr(in, sub))) {
|
if (!(p = strstr(in, sub))) {
|
||||||
@ -145,7 +146,7 @@ char *replace_substring(char *in, char *sub, char *rep)
|
|||||||
char* msys_path_list; // @-separated list of paths prefix to look for
|
char* msys_path_list; // @-separated list of paths prefix to look for
|
||||||
char* msys_path_list_end; // Points to last \0 in msys_path_list.
|
char* msys_path_list_end; // Points to last \0 in msys_path_list.
|
||||||
|
|
||||||
void setup_msys_path_list(char* argument)
|
void setup_msys_path_list(char const * argument)
|
||||||
{
|
{
|
||||||
char* p;
|
char* p;
|
||||||
char* drive_letter_pos;
|
char* drive_letter_pos;
|
||||||
@ -173,7 +174,7 @@ void setup_msys_path_list(char* argument)
|
|||||||
} while (p != NULL);
|
} while (p != NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
char *replace_cygdrive_msys(char *in)
|
char *replace_cygdrive_msys(char const *in)
|
||||||
{
|
{
|
||||||
char* str;
|
char* str;
|
||||||
char* prefix;
|
char* prefix;
|
||||||
@ -195,12 +196,12 @@ char *replace_cygdrive_msys(char *in)
|
|||||||
return str;
|
return str;
|
||||||
}
|
}
|
||||||
|
|
||||||
char*(*replace_cygdrive)(char *in) = NULL;
|
char*(*replace_cygdrive)(char const *in) = NULL;
|
||||||
|
|
||||||
char *files_to_delete[1024];
|
char *files_to_delete[1024];
|
||||||
int num_files_to_delete = 0;
|
int num_files_to_delete = 0;
|
||||||
|
|
||||||
char *fix_at_file(char *in)
|
char *fix_at_file(char const *in)
|
||||||
{
|
{
|
||||||
char *tmpdir;
|
char *tmpdir;
|
||||||
char name[2048];
|
char name[2048];
|
||||||
@ -222,9 +223,13 @@ char *fix_at_file(char *in)
|
|||||||
exit(-1);
|
exit(-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
tmpdir = getenv("TMP");
|
tmpdir = getenv("TEMP");
|
||||||
if (tmpdir == NULL) {
|
if (tmpdir == NULL) {
|
||||||
|
#if _WIN64
|
||||||
|
tmpdir = "c:/cygwin64/tmp";
|
||||||
|
#else
|
||||||
tmpdir = "c:/cygwin/tmp";
|
tmpdir = "c:/cygwin/tmp";
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
_snprintf(name, sizeof(name), "%s\\atfile_XXXXXX", tmpdir);
|
_snprintf(name, sizeof(name), "%s\\atfile_XXXXXX", tmpdir);
|
||||||
|
|
||||||
@ -240,7 +245,7 @@ char *fix_at_file(char *in)
|
|||||||
exit(-1);
|
exit(-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
buffer = malloc(buflen);
|
buffer = (char*) malloc(buflen);
|
||||||
while((blocklen = fread(block,1,sizeof(block),atin)) > 0) {
|
while((blocklen = fread(block,1,sizeof(block),atin)) > 0) {
|
||||||
append(&buffer, &buflen, &used, block, blocklen);
|
append(&buffer, &buflen, &used, block, blocklen);
|
||||||
}
|
}
|
||||||
@ -257,84 +262,229 @@ char *fix_at_file(char *in)
|
|||||||
fclose(atout);
|
fclose(atout);
|
||||||
free(fixed);
|
free(fixed);
|
||||||
free(buffer);
|
free(buffer);
|
||||||
files_to_delete[num_files_to_delete] = malloc(strlen(name)+1);
|
files_to_delete[num_files_to_delete] = (char*) malloc(strlen(name)+1);
|
||||||
strcpy(files_to_delete[num_files_to_delete], name);
|
strcpy(files_to_delete[num_files_to_delete], name);
|
||||||
num_files_to_delete++;
|
num_files_to_delete++;
|
||||||
atname = malloc(strlen(name)+2);
|
atname = (char*) malloc(strlen(name)+2);
|
||||||
atname[0] = '@';
|
atname[0] = '@';
|
||||||
strcpy(atname+1, name);
|
strcpy(atname+1, name);
|
||||||
return atname;
|
return atname;
|
||||||
}
|
}
|
||||||
|
|
||||||
int main(int argc, char **argv)
|
// given an argument, convert it to the windows command line safe quoted version
|
||||||
|
// using rules from:
|
||||||
|
// http://blogs.msdn.com/b/twistylittlepassagesallalike/archive/2011/04/23/everyone-quotes-arguments-the-wrong-way.aspx
|
||||||
|
// caller is responsible for freeing both input and output.
|
||||||
|
char * quote_arg(char const * in_arg) {
|
||||||
|
char *quoted = NULL;
|
||||||
|
char *current = quoted;
|
||||||
|
int pass;
|
||||||
|
|
||||||
|
if(strpbrk(in_arg, " \t\n\v\r\\\"") == NULL) {
|
||||||
|
return _strdup(in_arg);
|
||||||
|
}
|
||||||
|
|
||||||
|
// process the arg twice. Once to calculate the size and then to copy it.
|
||||||
|
for(pass=1; pass<=2; pass++) {
|
||||||
|
char const *arg = in_arg;
|
||||||
|
|
||||||
|
// initial "
|
||||||
|
if(pass == 2) {
|
||||||
|
*current = '\"';
|
||||||
|
}
|
||||||
|
current++;
|
||||||
|
|
||||||
|
// process string to be quoted until NUL
|
||||||
|
do {
|
||||||
|
int escapes = 0;
|
||||||
|
|
||||||
|
while (*arg == '\\') {
|
||||||
|
// count escapes.
|
||||||
|
escapes++;
|
||||||
|
arg++;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (*arg == '\0') {
|
||||||
|
// escape the escapes before final "
|
||||||
|
escapes *= 2;
|
||||||
|
} else if (*arg == '"') {
|
||||||
|
// escape the escapes and the "
|
||||||
|
escapes = escapes * 2 + 1;
|
||||||
|
} else {
|
||||||
|
// escapes aren't special, just echo them.
|
||||||
|
}
|
||||||
|
|
||||||
|
// emit some escapes
|
||||||
|
while (escapes > 0) {
|
||||||
|
if (pass == 2) {
|
||||||
|
*current = '\\';
|
||||||
|
}
|
||||||
|
current++;
|
||||||
|
escapes--;
|
||||||
|
}
|
||||||
|
|
||||||
|
// and the current char
|
||||||
|
if (pass == 2) {
|
||||||
|
*current = *arg;
|
||||||
|
}
|
||||||
|
current++;
|
||||||
|
} while( *arg++ != '\0');
|
||||||
|
|
||||||
|
// allocate the buffer
|
||||||
|
if (pass == 1) {
|
||||||
|
size_t alloc = (size_t) (current - quoted + (ptrdiff_t) 2);
|
||||||
|
current = quoted = (char*) calloc(alloc, sizeof(char));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// final " and \0
|
||||||
|
*(current - 1) = '"';
|
||||||
|
*current = '\0';
|
||||||
|
|
||||||
|
return quoted;
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(int argc, char const ** argv)
|
||||||
{
|
{
|
||||||
STARTUPINFO si;
|
STARTUPINFO si;
|
||||||
PROCESS_INFORMATION pi;
|
PROCESS_INFORMATION pi;
|
||||||
unsigned short rc;
|
unsigned short rc;
|
||||||
|
|
||||||
char *new_at_file;
|
|
||||||
char *old_at_file;
|
|
||||||
char *line;
|
char *line;
|
||||||
int i;
|
char *current;
|
||||||
|
int i, cmd;
|
||||||
DWORD exitCode;
|
DWORD exitCode;
|
||||||
|
|
||||||
if (argc<3 || argv[1][0] != '-' || (argv[1][1] != 'c' && argv[1][1] != 'm')) {
|
if (argc<2 || argv[1][0] != '-' || (argv[1][1] != 'c' && argv[1][1] != 'm')) {
|
||||||
fprintf(stderr, "Usage: fixpath -c|m<path@path@...> /cygdrive/c/WINDOWS/notepad.exe /cygdrive/c/x/test.txt\n");
|
fprintf(stderr, "Usage: fixpath -c|m<path@path@...> /cygdrive/c/WINDOWS/notepad.exe [/cygdrive/c/x/test.txt|@/cygdrive/c/x/atfile]\n");
|
||||||
exit(0);
|
exit(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (getenv("DEBUG_FIXPATH") != NULL) {
|
if (getenv("DEBUG_FIXPATH") != NULL) {
|
||||||
fprintf(stderr, "fixpath input line >%s<\n", strstr(GetCommandLine(), argv[1]));
|
char const * cmdline = GetCommandLine();
|
||||||
|
fprintf(stderr, "fixpath input line >%s<\n", strstr( cmdline , argv[1]));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (argv[1][1] == 'c' && argv[1][2] == '\0') {
|
if (argv[1][1] == 'c' && argv[1][2] == '\0') {
|
||||||
if (getenv("DEBUG_FIXPATH") != NULL) {
|
if (getenv("DEBUG_FIXPATH") != NULL) {
|
||||||
fprintf(stderr, "using cygwin mode\n");
|
fprintf(stderr, "fixpath using cygwin mode\n");
|
||||||
}
|
}
|
||||||
replace_cygdrive = replace_cygdrive_cygwin;
|
replace_cygdrive = replace_cygdrive_cygwin;
|
||||||
} else if (argv[1][1] == 'm') {
|
} else if (argv[1][1] == 'm') {
|
||||||
if (getenv("DEBUG_FIXPATH") != NULL) {
|
if (getenv("DEBUG_FIXPATH") != NULL) {
|
||||||
fprintf(stderr, "using msys mode, with path list: %s\n", &argv[1][2]);
|
fprintf(stderr, "fixpath using msys mode, with path list: %s\n", &argv[1][2]);
|
||||||
}
|
}
|
||||||
setup_msys_path_list(argv[1]);
|
setup_msys_path_list(argv[1]);
|
||||||
replace_cygdrive = replace_cygdrive_msys;
|
replace_cygdrive = replace_cygdrive_msys;
|
||||||
} else {
|
} else {
|
||||||
fprintf(stderr, "Unknown mode: %s\n", argv[1]);
|
fprintf(stderr, "fixpath Unknown mode: %s\n", argv[1]);
|
||||||
exit(-1);
|
exit(-1);
|
||||||
}
|
}
|
||||||
line = replace_cygdrive(strstr(GetCommandLine(), argv[2]));
|
|
||||||
|
|
||||||
for (i=1; i<argc; ++i) {
|
i = 2;
|
||||||
if (argv[i][0] == '@') {
|
|
||||||
// Found at-file! Fix it!
|
// handle assignments
|
||||||
old_at_file = replace_cygdrive(argv[i]);
|
while (i < argc) {
|
||||||
new_at_file = fix_at_file(old_at_file);
|
char const * assignment = strchr(argv[i], '=');
|
||||||
line = replace_substring(line, old_at_file, new_at_file);
|
if (assignment != NULL && assignment != argv[i]) {
|
||||||
}
|
size_t var_len = (size_t) (assignment - argv[i] + (ptrdiff_t) 1);
|
||||||
|
char *var = (char *) calloc(var_len, sizeof(char));
|
||||||
|
char *val = replace_cygdrive(assignment + 1);
|
||||||
|
memmove(var, argv[i], var_len);
|
||||||
|
var[var_len - 1] = '\0';
|
||||||
|
strupr(var);
|
||||||
|
|
||||||
|
if (getenv("DEBUG_FIXPATH") != NULL) {
|
||||||
|
fprintf(stderr, "fixpath setting var >%s< to >%s<\n", var, val);
|
||||||
|
}
|
||||||
|
|
||||||
|
rc = SetEnvironmentVariable(var, val);
|
||||||
|
if(!rc) {
|
||||||
|
// Could not set var for some reason. Try to report why.
|
||||||
|
const int msg_len = 80 + var_len + strlen(val);
|
||||||
|
char * msg = (char *) alloca(msg_len);
|
||||||
|
_snprintf_s(msg, msg_len, _TRUNCATE, "Could not set environment variable [%s=%s]", var, val);
|
||||||
|
report_error(msg);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
free(var);
|
||||||
|
free(val);
|
||||||
|
} else {
|
||||||
|
// no more assignments;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
i++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// remember index of the command
|
||||||
|
cmd = i;
|
||||||
|
|
||||||
|
// handle command and it's args.
|
||||||
|
while (i < argc) {
|
||||||
|
char const *replaced = replace_cygdrive(argv[i]);
|
||||||
|
if(replaced[0] == '@') {
|
||||||
|
// Found at-file! Fix it!
|
||||||
|
replaced = fix_at_file(replaced);
|
||||||
|
}
|
||||||
|
argv[i] = quote_arg(replaced);
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
|
||||||
|
// determine the length of the line
|
||||||
|
line = NULL;
|
||||||
|
// args
|
||||||
|
for(i = cmd; i < argc; i++) {
|
||||||
|
line += (ptrdiff_t) strlen(argv[i]);
|
||||||
|
}
|
||||||
|
// spaces and null
|
||||||
|
line += (ptrdiff_t) (argc - cmd + 1);
|
||||||
|
// allocate
|
||||||
|
line = (char*) calloc(line - (char*) NULL, sizeof(char));
|
||||||
|
|
||||||
|
// copy in args.
|
||||||
|
current = line;
|
||||||
|
for(i = cmd; i < argc; i++) {
|
||||||
|
ptrdiff_t len = strlen(argv[i]);
|
||||||
|
if (i != cmd) {
|
||||||
|
*current++ = ' ';
|
||||||
|
}
|
||||||
|
memmove(current, argv[i], len);
|
||||||
|
current += len;
|
||||||
|
}
|
||||||
|
*current = '\0';
|
||||||
|
|
||||||
if (getenv("DEBUG_FIXPATH") != NULL) {
|
if (getenv("DEBUG_FIXPATH") != NULL) {
|
||||||
fprintf(stderr, "fixpath converted line >%s<\n", line);
|
fprintf(stderr, "fixpath converted line >%s<\n", line);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(cmd == argc) {
|
||||||
|
if (getenv("DEBUG_FIXPATH") != NULL) {
|
||||||
|
fprintf(stderr, "fixpath no command provided!\n");
|
||||||
|
}
|
||||||
|
exit(0);
|
||||||
|
}
|
||||||
|
|
||||||
ZeroMemory(&si,sizeof(si));
|
ZeroMemory(&si,sizeof(si));
|
||||||
si.cb=sizeof(si);
|
si.cb=sizeof(si);
|
||||||
ZeroMemory(&pi,sizeof(pi));
|
ZeroMemory(&pi,sizeof(pi));
|
||||||
|
|
||||||
|
fflush(stderr);
|
||||||
|
fflush(stdout);
|
||||||
|
|
||||||
rc = CreateProcess(NULL,
|
rc = CreateProcess(NULL,
|
||||||
line,
|
line,
|
||||||
0,
|
0,
|
||||||
0,
|
0,
|
||||||
TRUE,
|
TRUE,
|
||||||
0,
|
0,
|
||||||
0,
|
NULL,
|
||||||
0,
|
NULL,
|
||||||
&si,
|
&si,
|
||||||
&pi);
|
&pi);
|
||||||
if(!rc) {
|
if(!rc) {
|
||||||
// Could not start process for some reason. Try to report why:
|
// Could not start process for some reason. Try to report why:
|
||||||
report_error();
|
report_error("Could not start process!");
|
||||||
exit(rc);
|
exit(126);
|
||||||
}
|
}
|
||||||
|
|
||||||
WaitForSingleObject(pi.hProcess,INFINITE);
|
WaitForSingleObject(pi.hProcess,INFINITE);
|
||||||
@ -342,15 +492,21 @@ int main(int argc, char **argv)
|
|||||||
|
|
||||||
if (getenv("DEBUG_FIXPATH") != NULL) {
|
if (getenv("DEBUG_FIXPATH") != NULL) {
|
||||||
for (i=0; i<num_files_to_delete; ++i) {
|
for (i=0; i<num_files_to_delete; ++i) {
|
||||||
fprintf(stderr, "Not deleting temporary fixpath file %s\n",
|
fprintf(stderr, "fixpath Not deleting temporary file %s\n",
|
||||||
files_to_delete[i]);
|
files_to_delete[i]);
|
||||||
}
|
}
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
for (i=0; i<num_files_to_delete; ++i) {
|
for (i=0; i<num_files_to_delete; ++i) {
|
||||||
remove(files_to_delete[i]);
|
remove(files_to_delete[i]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (exitCode != 0) {
|
||||||
|
if (getenv("DEBUG_FIXPATH") != NULL) {
|
||||||
|
fprintf(stderr, "fixpath exit code %d\n",
|
||||||
|
exitCode);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
exit(exitCode);
|
exit(exitCode);
|
||||||
}
|
}
|
||||||
|
@ -249,3 +249,4 @@ d338b892a13db19b093f85cf5f949a4504e4d31f jdk9-b03
|
|||||||
1ed19de263e1e0772da0269118cdd9deeb9fff04 jdk9-b04
|
1ed19de263e1e0772da0269118cdd9deeb9fff04 jdk9-b04
|
||||||
167c39eb44731a5d66770d0f00e231164653a2ff jdk9-b05
|
167c39eb44731a5d66770d0f00e231164653a2ff jdk9-b05
|
||||||
a4bf701ac316946c2e5e83138ad8e687da6a4b30 jdk9-b06
|
a4bf701ac316946c2e5e83138ad8e687da6a4b30 jdk9-b06
|
||||||
|
6c8563600a71394c949405189ddd66267a88d8cd jdk9-b07
|
||||||
|
@ -253,6 +253,13 @@ public class SocketOrChannelAcceptorImpl
|
|||||||
// registered with the selector. Otherwise if the bytes
|
// registered with the selector. Otherwise if the bytes
|
||||||
// are read on the connection it will attempt a time stamp
|
// are read on the connection it will attempt a time stamp
|
||||||
// but the cache will be null, resulting in NPE.
|
// but the cache will be null, resulting in NPE.
|
||||||
|
|
||||||
|
// A connection needs to be timestamped before putting to the cache.
|
||||||
|
// Otherwise the newly created connection (with 0 timestamp) could be
|
||||||
|
// incorrectly reclaimed by concurrent reclaim() call OR if there
|
||||||
|
// will be no events on this connection then it could be reclaimed
|
||||||
|
// by upcoming reclaim() call.
|
||||||
|
getConnectionCache().stampTime(connection);
|
||||||
getConnectionCache().put(this, connection);
|
getConnectionCache().put(this, connection);
|
||||||
|
|
||||||
if (connection.shouldRegisterServerReadEvent()) {
|
if (connection.shouldRegisterServerReadEvent()) {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2002, 2013, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2002, 2014, 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
|
||||||
@ -25,6 +25,8 @@
|
|||||||
|
|
||||||
package com.sun.corba.se.spi.orb;
|
package com.sun.corba.se.spi.orb;
|
||||||
|
|
||||||
|
import java.lang.reflect.InvocationTargetException;
|
||||||
|
import java.lang.reflect.Method;
|
||||||
import java.util.Map ;
|
import java.util.Map ;
|
||||||
import java.util.HashMap ;
|
import java.util.HashMap ;
|
||||||
import java.util.Properties ;
|
import java.util.Properties ;
|
||||||
@ -97,8 +99,7 @@ import com.sun.corba.se.impl.logging.OMGSystemException ;
|
|||||||
|
|
||||||
import com.sun.corba.se.impl.presentation.rmi.PresentationManagerImpl ;
|
import com.sun.corba.se.impl.presentation.rmi.PresentationManagerImpl ;
|
||||||
|
|
||||||
import sun.awt.AppContext;
|
import sun.misc.JavaAWTAccess;
|
||||||
import sun.corba.SharedSecrets;
|
|
||||||
|
|
||||||
public abstract class ORB extends com.sun.corba.se.org.omg.CORBA.ORB
|
public abstract class ORB extends com.sun.corba.se.org.omg.CORBA.ORB
|
||||||
implements Broker, TypeCodeFactory
|
implements Broker, TypeCodeFactory
|
||||||
@ -170,6 +171,13 @@ public abstract class ORB extends com.sun.corba.se.org.omg.CORBA.ORB
|
|||||||
// representing LogDomain and ExceptionGroup.
|
// representing LogDomain and ExceptionGroup.
|
||||||
private Map wrapperMap ;
|
private Map wrapperMap ;
|
||||||
|
|
||||||
|
static class Holder {
|
||||||
|
static final PresentationManager defaultPresentationManager =
|
||||||
|
setupPresentationManager();
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final Map<Object, PresentationManager> pmContexts = new HashMap<>();
|
||||||
|
|
||||||
private static Map staticWrapperMap = new ConcurrentHashMap();
|
private static Map staticWrapperMap = new ConcurrentHashMap();
|
||||||
|
|
||||||
protected MonitoringManager monitoringManager;
|
protected MonitoringManager monitoringManager;
|
||||||
@ -201,8 +209,9 @@ public abstract class ORB extends com.sun.corba.se.org.omg.CORBA.ORB
|
|||||||
|
|
||||||
try {
|
try {
|
||||||
// First try the configured class name, if any
|
// First try the configured class name, if any
|
||||||
Class<?> cls = SharedSecrets.getJavaCorbaAccess().loadClass( className ) ;
|
Class<?> cls =
|
||||||
sff = (PresentationManager.StubFactoryFactory)cls.newInstance() ;
|
sun.corba.SharedSecrets.getJavaCorbaAccess().loadClass(className);
|
||||||
|
sff = (PresentationManager.StubFactoryFactory)cls.newInstance();
|
||||||
} catch (Exception exc) {
|
} catch (Exception exc) {
|
||||||
// Use the default. Log the error as a warning.
|
// Use the default. Log the error as a warning.
|
||||||
staticWrapper.errorInSettingDynamicStubFactoryFactory(
|
staticWrapper.errorInSettingDynamicStubFactoryFactory(
|
||||||
@ -235,13 +244,34 @@ public abstract class ORB extends com.sun.corba.se.org.omg.CORBA.ORB
|
|||||||
*/
|
*/
|
||||||
public static PresentationManager getPresentationManager()
|
public static PresentationManager getPresentationManager()
|
||||||
{
|
{
|
||||||
AppContext ac = AppContext.getAppContext();
|
SecurityManager sm = System.getSecurityManager();
|
||||||
PresentationManager pm = (PresentationManager) ac.get(PresentationManager.class);
|
JavaAWTAccess javaAwtAccess = sun.misc.SharedSecrets.getJavaAWTAccess();
|
||||||
if (pm == null) {
|
if (sm != null && javaAwtAccess != null) {
|
||||||
pm = setupPresentationManager();
|
Object appletContext;
|
||||||
ac.put(PresentationManager.class, pm);
|
try {
|
||||||
|
Class<?> clazz = JavaAWTAccess.class;
|
||||||
|
Method method = clazz.getMethod("getAppletContext");
|
||||||
|
appletContext = method.invoke(javaAwtAccess);
|
||||||
|
} catch (IllegalAccessException | InvocationTargetException | NoSuchMethodException e) {
|
||||||
|
InternalError err = new InternalError();
|
||||||
|
err.initCause(e);
|
||||||
|
throw err;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (appletContext != null) {
|
||||||
|
synchronized (pmContexts) {
|
||||||
|
PresentationManager pm = pmContexts.get(appletContext);
|
||||||
|
if (pm == null) {
|
||||||
|
pm = setupPresentationManager();
|
||||||
|
pmContexts.put(appletContext, pm);
|
||||||
|
}
|
||||||
|
return pm;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return pm;
|
|
||||||
|
// No security manager or AppletAppContext
|
||||||
|
return Holder.defaultPresentationManager;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Get the appropriate StubFactoryFactory. This
|
/** Get the appropriate StubFactoryFactory. This
|
||||||
|
@ -38,11 +38,11 @@ package org.omg.CORBA;
|
|||||||
* OMG specifications :
|
* OMG specifications :
|
||||||
* <ul>
|
* <ul>
|
||||||
* <li> ORB core as defined by CORBA 2.3.1
|
* <li> ORB core as defined by CORBA 2.3.1
|
||||||
* (<a href="http://cgi.omg.org/cgi-bin/doc?formal/99-10-07">formal/99-10-07</a>)
|
* (<a href="http://www.omg.org/cgi-bin/doc?formal/99-10-07">formal/99-10-07</a>)
|
||||||
* </li>
|
* </li>
|
||||||
*
|
*
|
||||||
* <li> IDL/Java Language Mapping as defined in
|
* <li> IDL/Java Language Mapping as defined in
|
||||||
* <a href="http://cgi.omg.org/cgi-bin/doc?ptc/00-01-08">ptc/00-01-08</a>
|
* <a href="http://www.omg.org/cgi-bin/doc?ptc/00-01-08">ptc/00-01-08</a>
|
||||||
* </li>
|
* </li>
|
||||||
* </ul>
|
* </ul>
|
||||||
*/
|
*/
|
||||||
|
@ -38,11 +38,11 @@ package org.omg.CORBA;
|
|||||||
* OMG specifications :
|
* OMG specifications :
|
||||||
* <ul>
|
* <ul>
|
||||||
* <li> ORB core as defined by CORBA 2.3.1
|
* <li> ORB core as defined by CORBA 2.3.1
|
||||||
* (<a href="http://cgi.omg.org/cgi-bin/doc?formal/99-10-07">formal/99-10-07</a>)
|
* (<a href="http://www.omg.org/cgi-bin/doc?formal/99-10-07">formal/99-10-07</a>)
|
||||||
* </li>
|
* </li>
|
||||||
*
|
*
|
||||||
* <li> IDL/Java Language Mapping as defined in
|
* <li> IDL/Java Language Mapping as defined in
|
||||||
* <a href="http://cgi.omg.org/cgi-bin/doc?ptc/00-01-08">ptc/00-01-08</a>
|
* <a href="http://www.omg.org/cgi-bin/doc?ptc/00-01-08">ptc/00-01-08</a>
|
||||||
* </li>
|
* </li>
|
||||||
* </ul>
|
* </ul>
|
||||||
*/
|
*/
|
||||||
|
@ -38,11 +38,11 @@ package org.omg.CORBA;
|
|||||||
* OMG specifications :
|
* OMG specifications :
|
||||||
* <ul>
|
* <ul>
|
||||||
* <li> ORB core as defined by CORBA 2.3.1
|
* <li> ORB core as defined by CORBA 2.3.1
|
||||||
* (<a href="http://cgi.omg.org/cgi-bin/doc?formal/99-10-07">formal/99-10-07</a>)
|
* (<a href="http://www.omg.org/cgi-bin/doc?formal/99-10-07">formal/99-10-07</a>)
|
||||||
* </li>
|
* </li>
|
||||||
*
|
*
|
||||||
* <li> IDL/Java Language Mapping as defined in
|
* <li> IDL/Java Language Mapping as defined in
|
||||||
* <a href="http://cgi.omg.org/cgi-bin/doc?ptc/00-01-08">ptc/00-01-08</a>
|
* <a href="http://www.omg.org/cgi-bin/doc?ptc/00-01-08">ptc/00-01-08</a>
|
||||||
* </li>
|
* </li>
|
||||||
* </ul>
|
* </ul>
|
||||||
*/
|
*/
|
||||||
|
@ -38,11 +38,11 @@ package org.omg.CORBA;
|
|||||||
* OMG specifications :
|
* OMG specifications :
|
||||||
* <ul>
|
* <ul>
|
||||||
* <li> ORB core as defined by CORBA 2.3.1
|
* <li> ORB core as defined by CORBA 2.3.1
|
||||||
* (<a href="http://cgi.omg.org/cgi-bin/doc?formal/99-10-07">formal/99-10-07</a>)
|
* (<a href="http://www.omg.org/cgi-bin/doc?formal/99-10-07">formal/99-10-07</a>)
|
||||||
* </li>
|
* </li>
|
||||||
*
|
*
|
||||||
* <li> IDL/Java Language Mapping as defined in
|
* <li> IDL/Java Language Mapping as defined in
|
||||||
* <a href="http://cgi.omg.org/cgi-bin/doc?ptc/00-01-08">ptc/00-01-08</a>
|
* <a href="http://www.omg.org/cgi-bin/doc?ptc/00-01-08">ptc/00-01-08</a>
|
||||||
* </li>
|
* </li>
|
||||||
* </ul>
|
* </ul>
|
||||||
*/
|
*/
|
||||||
|
@ -38,11 +38,11 @@ package org.omg.CORBA;
|
|||||||
* OMG specifications :
|
* OMG specifications :
|
||||||
* <ul>
|
* <ul>
|
||||||
* <li> ORB core as defined by CORBA 2.3.1
|
* <li> ORB core as defined by CORBA 2.3.1
|
||||||
* (<a href="http://cgi.omg.org/cgi-bin/doc?formal/99-10-07">formal/99-10-07</a>)
|
* (<a href="http://www.omg.org/cgi-bin/doc?formal/99-10-07">formal/99-10-07</a>)
|
||||||
* </li>
|
* </li>
|
||||||
*
|
*
|
||||||
* <li> IDL/Java Language Mapping as defined in
|
* <li> IDL/Java Language Mapping as defined in
|
||||||
* <a href="http://cgi.omg.org/cgi-bin/doc?ptc/00-01-08">ptc/00-01-08</a>
|
* <a href="http://www.omg.org/cgi-bin/doc?ptc/00-01-08">ptc/00-01-08</a>
|
||||||
* </li>
|
* </li>
|
||||||
* </ul>
|
* </ul>
|
||||||
*/
|
*/
|
||||||
|
@ -38,11 +38,11 @@ package org.omg.CORBA;
|
|||||||
* OMG specifications :
|
* OMG specifications :
|
||||||
* <ul>
|
* <ul>
|
||||||
* <li> ORB core as defined by CORBA 2.3.1
|
* <li> ORB core as defined by CORBA 2.3.1
|
||||||
* (<a href="http://cgi.omg.org/cgi-bin/doc?formal/99-10-07">formal/99-10-07</a>)
|
* (<a href="http://www.omg.org/cgi-bin/doc?formal/99-10-07">formal/99-10-07</a>)
|
||||||
* </li>
|
* </li>
|
||||||
*
|
*
|
||||||
* <li> IDL/Java Language Mapping as defined in
|
* <li> IDL/Java Language Mapping as defined in
|
||||||
* <a href="http://cgi.omg.org/cgi-bin/doc?ptc/00-01-08">ptc/00-01-08</a>
|
* <a href="http://www.omg.org/cgi-bin/doc?ptc/00-01-08">ptc/00-01-08</a>
|
||||||
* </li>
|
* </li>
|
||||||
* </ul>
|
* </ul>
|
||||||
*/
|
*/
|
||||||
|
@ -38,11 +38,11 @@ package org.omg.CORBA;
|
|||||||
* OMG specifications :
|
* OMG specifications :
|
||||||
* <ul>
|
* <ul>
|
||||||
* <li> ORB core as defined by CORBA 2.3.1
|
* <li> ORB core as defined by CORBA 2.3.1
|
||||||
* (<a href="http://cgi.omg.org/cgi-bin/doc?formal/99-10-07">formal/99-10-07</a>)
|
* (<a href="http://www.omg.org/cgi-bin/doc?formal/99-10-07">formal/99-10-07</a>)
|
||||||
* </li>
|
* </li>
|
||||||
*
|
*
|
||||||
* <li> IDL/Java Language Mapping as defined in
|
* <li> IDL/Java Language Mapping as defined in
|
||||||
* <a href="http://cgi.omg.org/cgi-bin/doc?ptc/00-01-08">ptc/00-01-08</a>
|
* <a href="http://www.omg.org/cgi-bin/doc?ptc/00-01-08">ptc/00-01-08</a>
|
||||||
* </li>
|
* </li>
|
||||||
* </ul>
|
* </ul>
|
||||||
*/
|
*/
|
||||||
|
@ -38,11 +38,11 @@ package org.omg.CORBA;
|
|||||||
* OMG specifications :
|
* OMG specifications :
|
||||||
* <ul>
|
* <ul>
|
||||||
* <li> ORB core as defined by CORBA 2.3.1
|
* <li> ORB core as defined by CORBA 2.3.1
|
||||||
* (<a href="http://cgi.omg.org/cgi-bin/doc?formal/99-10-07">formal/99-10-07</a>)
|
* (<a href="http://www.omg.org/cgi-bin/doc?formal/99-10-07">formal/99-10-07</a>)
|
||||||
* </li>
|
* </li>
|
||||||
*
|
*
|
||||||
* <li> IDL/Java Language Mapping as defined in
|
* <li> IDL/Java Language Mapping as defined in
|
||||||
* <a href="http://cgi.omg.org/cgi-bin/doc?ptc/00-01-08">ptc/00-01-08</a>
|
* <a href="http://www.omg.org/cgi-bin/doc?ptc/00-01-08">ptc/00-01-08</a>
|
||||||
* </li>
|
* </li>
|
||||||
* </ul>
|
* </ul>
|
||||||
*/
|
*/
|
||||||
|
@ -44,11 +44,11 @@ package org.omg.CORBA;
|
|||||||
* OMG specifications :
|
* OMG specifications :
|
||||||
* <ul>
|
* <ul>
|
||||||
* <li> ORB core as defined by CORBA 2.3.1
|
* <li> ORB core as defined by CORBA 2.3.1
|
||||||
* (<a href="http://cgi.omg.org/cgi-bin/doc?formal/99-10-07">formal/99-10-07</a>)
|
* (<a href="http://www.omg.org/cgi-bin/doc?formal/99-10-07">formal/99-10-07</a>)
|
||||||
* </li>
|
* </li>
|
||||||
*
|
*
|
||||||
* <li> IDL/Java Language Mapping as defined in
|
* <li> IDL/Java Language Mapping as defined in
|
||||||
* <a href="http://cgi.omg.org/cgi-bin/doc?ptc/00-01-08">ptc/00-01-08</a>
|
* <a href="http://www.omg.org/cgi-bin/doc?ptc/00-01-08">ptc/00-01-08</a>
|
||||||
* </li>
|
* </li>
|
||||||
* </ul>
|
* </ul>
|
||||||
*/
|
*/
|
||||||
|
@ -38,11 +38,11 @@ package org.omg.CORBA;
|
|||||||
* OMG specifications :
|
* OMG specifications :
|
||||||
* <ul>
|
* <ul>
|
||||||
* <li> ORB core as defined by CORBA 2.3.1
|
* <li> ORB core as defined by CORBA 2.3.1
|
||||||
* (<a href="http://cgi.omg.org/cgi-bin/doc?formal/99-10-07">formal/99-10-07</a>)
|
* (<a href="http://www.omg.org/cgi-bin/doc?formal/99-10-07">formal/99-10-07</a>)
|
||||||
* </li>
|
* </li>
|
||||||
*
|
*
|
||||||
* <li> IDL/Java Language Mapping as defined in
|
* <li> IDL/Java Language Mapping as defined in
|
||||||
* <a href="http://cgi.omg.org/cgi-bin/doc?ptc/00-01-08">ptc/00-01-08</a>
|
* <a href="http://www.omg.org/cgi-bin/doc?ptc/00-01-08">ptc/00-01-08</a>
|
||||||
* </li>
|
* </li>
|
||||||
* </ul>
|
* </ul>
|
||||||
*/
|
*/
|
||||||
|
@ -38,11 +38,11 @@ package org.omg.CORBA;
|
|||||||
* OMG specifications :
|
* OMG specifications :
|
||||||
* <ul>
|
* <ul>
|
||||||
* <li> ORB core as defined by CORBA 2.3.1
|
* <li> ORB core as defined by CORBA 2.3.1
|
||||||
* (<a href="http://cgi.omg.org/cgi-bin/doc?formal/99-10-07">formal/99-10-07</a>)
|
* (<a href="http://www.omg.org/cgi-bin/doc?formal/99-10-07">formal/99-10-07</a>)
|
||||||
* </li>
|
* </li>
|
||||||
*
|
*
|
||||||
* <li> IDL/Java Language Mapping as defined in
|
* <li> IDL/Java Language Mapping as defined in
|
||||||
* <a href="http://cgi.omg.org/cgi-bin/doc?ptc/00-01-08">ptc/00-01-08</a>
|
* <a href="http://www.omg.org/cgi-bin/doc?ptc/00-01-08">ptc/00-01-08</a>
|
||||||
* </li>
|
* </li>
|
||||||
* </ul>
|
* </ul>
|
||||||
*/
|
*/
|
||||||
|
@ -38,11 +38,11 @@ package org.omg.CORBA;
|
|||||||
* OMG specifications :
|
* OMG specifications :
|
||||||
* <ul>
|
* <ul>
|
||||||
* <li> ORB core as defined by CORBA 2.3.1
|
* <li> ORB core as defined by CORBA 2.3.1
|
||||||
* (<a href="http://cgi.omg.org/cgi-bin/doc?formal/99-10-07">formal/99-10-07</a>)
|
* (<a href="http://www.omg.org/cgi-bin/doc?formal/99-10-07">formal/99-10-07</a>)
|
||||||
* </li>
|
* </li>
|
||||||
*
|
*
|
||||||
* <li> IDL/Java Language Mapping as defined in
|
* <li> IDL/Java Language Mapping as defined in
|
||||||
* <a href="http://cgi.omg.org/cgi-bin/doc?ptc/00-01-08">ptc/00-01-08</a>
|
* <a href="http://www.omg.org/cgi-bin/doc?ptc/00-01-08">ptc/00-01-08</a>
|
||||||
* </li>
|
* </li>
|
||||||
* </ul>
|
* </ul>
|
||||||
*/
|
*/
|
||||||
|
@ -38,11 +38,11 @@ package org.omg.CORBA;
|
|||||||
* OMG specifications :
|
* OMG specifications :
|
||||||
* <ul>
|
* <ul>
|
||||||
* <li> ORB core as defined by CORBA 2.3.1
|
* <li> ORB core as defined by CORBA 2.3.1
|
||||||
* (<a href="http://cgi.omg.org/cgi-bin/doc?formal/99-10-07">formal/99-10-07</a>)
|
* (<a href="http://www.omg.org/cgi-bin/doc?formal/99-10-07">formal/99-10-07</a>)
|
||||||
* </li>
|
* </li>
|
||||||
*
|
*
|
||||||
* <li> IDL/Java Language Mapping as defined in
|
* <li> IDL/Java Language Mapping as defined in
|
||||||
* <a href="http://cgi.omg.org/cgi-bin/doc?ptc/00-01-08">ptc/00-01-08</a>
|
* <a href="http://www.omg.org/cgi-bin/doc?ptc/00-01-08">ptc/00-01-08</a>
|
||||||
* </li>
|
* </li>
|
||||||
* </ul>
|
* </ul>
|
||||||
*/
|
*/
|
||||||
|
@ -48,11 +48,11 @@ package org.omg.CORBA;
|
|||||||
* OMG specifications :
|
* OMG specifications :
|
||||||
* <ul>
|
* <ul>
|
||||||
* <li> ORB core as defined by CORBA 2.3.1
|
* <li> ORB core as defined by CORBA 2.3.1
|
||||||
* (<a href="http://cgi.omg.org/cgi-bin/doc?formal/99-10-07">formal/99-10-07</a>)
|
* (<a href="http://www.omg.org/cgi-bin/doc?formal/99-10-07">formal/99-10-07</a>)
|
||||||
* </li>
|
* </li>
|
||||||
*
|
*
|
||||||
* <li> IDL/Java Language Mapping as defined in
|
* <li> IDL/Java Language Mapping as defined in
|
||||||
* <a href="http://cgi.omg.org/cgi-bin/doc?ptc/00-01-08">ptc/00-01-08</a>
|
* <a href="http://www.omg.org/cgi-bin/doc?ptc/00-01-08">ptc/00-01-08</a>
|
||||||
* </li>
|
* </li>
|
||||||
* </ul>
|
* </ul>
|
||||||
*/
|
*/
|
||||||
|
@ -18,26 +18,26 @@ href="http://www.omg.org/">www.omg.org</a> to search for the correct specificati
|
|||||||
<ul>
|
<ul>
|
||||||
<li>
|
<li>
|
||||||
CORBA 2.3.1 (<a
|
CORBA 2.3.1 (<a
|
||||||
href="http://cgi.omg.org/cgi-bin/doc?formal/99-10-07">formal/99-10-07</a>)</li>
|
href="http://www.omg.org/cgi-bin/doc?formal/99-10-07">formal/99-10-07</a>)</li>
|
||||||
|
|
||||||
<li>
|
<li>
|
||||||
IDL to Java language mapping (<a
|
IDL to Java language mapping (<a
|
||||||
href="http://cgi.omg.org/cgi-bin/doc?ptc/00-01-08">ptc/00-01-08</a>)</li>
|
href="http://www.omg.org/cgi-bin/doc?ptc/00-01-08">ptc/00-01-08</a>)</li>
|
||||||
|
|
||||||
<li>Revised IDL to Java language mapping (<a
|
<li>Revised IDL to Java language mapping (<a
|
||||||
href="http://cgi.omg.org/cgi-bin/doc?ptc/00-11-03">ptc/00-11-03</a>)</li>
|
href="http://www.omg.org/cgi-bin/doc?ptc/00-11-03">ptc/00-11-03</a>)</li>
|
||||||
|
|
||||||
<li>
|
<li>
|
||||||
Java to IDL language mapping (<a
|
Java to IDL language mapping (<a
|
||||||
href="http://cgi.omg.org/cgi-bin/doc?ptc/00-01-06">ptc/00-01-06</a>)</li>
|
href="http://www.omg.org/cgi-bin/doc?ptc/00-01-06">ptc/00-01-06</a>)</li>
|
||||||
|
|
||||||
<li>
|
<li>
|
||||||
Interoperable Naming Service (<a
|
Interoperable Naming Service (<a
|
||||||
href="http://cgi.omg.org/cgi-bin/doc?ptc/00-08-07">ptc/00-08-07</a>)</li>
|
href="http://www.omg.org/cgi-bin/doc?ptc/00-08-07">ptc/00-08-07</a>)</li>
|
||||||
|
|
||||||
<li>
|
<li>
|
||||||
Portable Interceptors (<a
|
Portable Interceptors (<a
|
||||||
href="http://cgi.omg.org/cgi-bin/doc?ptc/2001-03-04">ptc/2001-03-04</a>)</li>
|
href="http://www.omg.org/cgi-bin/doc?ptc/2001-03-04">ptc/2001-03-04</a>)</li>
|
||||||
</ul>
|
</ul>
|
||||||
These are the only specifications referenced by this document.
|
These are the only specifications referenced by this document.
|
||||||
|
|
||||||
|
@ -8,7 +8,7 @@
|
|||||||
|
|
||||||
<H1>IDL-to-Java Generated Files</H1>
|
<H1>IDL-to-Java Generated Files</H1>
|
||||||
|
|
||||||
<P>The files that are generated by the IDL-to-Java compiler, in accordance with the <em><a href="http://cgi.omg.org/cgi-bin/doc?ptc/00-01-08">IDL-to-Java Language Mapping Specification</a></em>, which is implemented in Java<sup><font size="-2">TM</font></sup> SE 6 according the <a href="compliance.html">compliance</a> document.
|
<P>The files that are generated by the IDL-to-Java compiler, in accordance with the <em><a href="http://www.omg.org/cgi-bin/doc?ptc/00-01-08">IDL-to-Java Language Mapping Specification</a></em>, which is implemented in Java<sup><font size="-2">TM</font></sup> SE 6 according the <a href="compliance.html">compliance</a> document.
|
||||||
|
|
||||||
|
|
||||||
<P>In general IDL names and identifiers are mapped to Java names and identifiers with no change. Because of the nature of the Java language, a single IDL construct may be mapped to several (differently named) Java constructs. The additional names are constructed by appending a descriptive suffix. For example, the IDL interface <tt>foo</tt> is mapped to the Java interfaces <tt>foo</tt> and <tt>fooOperations</tt>, and additional Java classes <tt>fooHelper</tt>, <tt>fooHolder</tt>, <tt>fooPOA</tt>, and optionally <tt>fooPOATie</tt>.
|
<P>In general IDL names and identifiers are mapped to Java names and identifiers with no change. Because of the nature of the Java language, a single IDL construct may be mapped to several (differently named) Java constructs. The additional names are constructed by appending a descriptive suffix. For example, the IDL interface <tt>foo</tt> is mapped to the Java interfaces <tt>foo</tt> and <tt>fooOperations</tt>, and additional Java classes <tt>fooHelper</tt>, <tt>fooHolder</tt>, <tt>fooPOA</tt>, and optionally <tt>fooPOATie</tt>.
|
||||||
|
@ -344,7 +344,7 @@ public final class AccountHolder implements
|
|||||||
</PRE>
|
</PRE>
|
||||||
|
|
||||||
<P>For more information on Holder classes, see Chapter 1.4, <em>Mapping for
|
<P>For more information on Holder classes, see Chapter 1.4, <em>Mapping for
|
||||||
Basic Types</em> in the <a href="http://cgi.omg.org/cgi-bin/doc?ptc/00-01-08">
|
Basic Types</em> in the <a href="http://www.omg.org/cgi-bin/doc?ptc/00-01-08">
|
||||||
<em>OMG IDL to Java Language Mapping</em></a>. The Holder classes defined
|
<em>OMG IDL to Java Language Mapping</em></a>. The Holder classes defined
|
||||||
in the package <TT>org.omg.CORBA</TT> are:
|
in the package <TT>org.omg.CORBA</TT> are:
|
||||||
<PRE>
|
<PRE>
|
||||||
|
@ -331,7 +331,7 @@ Context.
|
|||||||
|
|
||||||
<ul>
|
<ul>
|
||||||
<li>Interoperable Naming Service (<a
|
<li>Interoperable Naming Service (<a
|
||||||
href="http://cgi.omg.org/cgi-bin/doc?ptc/00-08-07">ptc/00-08-07</a>)
|
href="http://www.omg.org/cgi-bin/doc?ptc/00-08-07">ptc/00-08-07</a>)
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
<h2>Related Documentation</h2>
|
<h2>Related Documentation</h2>
|
||||||
|
@ -33,8 +33,8 @@
|
|||||||
<body bgcolor="white">
|
<body bgcolor="white">
|
||||||
<P>This package contains the <tt>Dynamic</tt> module specified in the OMG Portable
|
<P>This package contains the <tt>Dynamic</tt> module specified in the OMG Portable
|
||||||
Interceptor specification,
|
Interceptor specification,
|
||||||
<a href="http://cgi.omg.org/cgi-bin/doc?ptc/2000-08-06">
|
<a href="http://www.omg.org/cgi-bin/doc?ptc/2000-08-06">
|
||||||
http://cgi.omg.org/cgi-bin/doc?ptc/2000-08-06</a>, section 21.9. Please
|
ptc/2000-08-06</a>, section 21.9. Please
|
||||||
refer to that OMG specification for further details.
|
refer to that OMG specification for further details.
|
||||||
|
|
||||||
|
|
||||||
|
@ -38,8 +38,8 @@ interface of the
|
|||||||
<tt>DynamicAny</tt> module
|
<tt>DynamicAny</tt> module
|
||||||
specified in the OMG <em>The Common Object Request Broker: Architecture and
|
specified in the OMG <em>The Common Object Request Broker: Architecture and
|
||||||
Specification</em>,
|
Specification</em>,
|
||||||
<a href="http://cgi.omg.org/cgi-bin/doc?formal/99-10-07">
|
<a href="http://www.omg.org/cgi-bin/doc?formal/99-10-07">
|
||||||
http://cgi.omg.org/cgi-bin/doc?formal/99-10-07</a>, section 9.2.2. Please
|
formal/99-10-07</a>, section 9.2.2. Please
|
||||||
refer to that OMG specification for further details.
|
refer to that OMG specification for further details.
|
||||||
|
|
||||||
<H3>Package Specification</H3>
|
<H3>Package Specification</H3>
|
||||||
|
@ -34,8 +34,8 @@
|
|||||||
interface of the <tt>DynamicAny</tt> module
|
interface of the <tt>DynamicAny</tt> module
|
||||||
specified in the OMG <em>The Common Object Request Broker: Architecture and
|
specified in the OMG <em>The Common Object Request Broker: Architecture and
|
||||||
Specification</em>,
|
Specification</em>,
|
||||||
<a href="http://cgi.omg.org/cgi-bin/doc?formal/99-10-07">
|
<a href="http://www.omg.org/cgi-bin/doc?formal/99-10-07">
|
||||||
http://cgi.omg.org/cgi-bin/doc?formal/99-10-07</a>, section 9.2. Please
|
formal/99-10-07</a>, section 9.2. Please
|
||||||
refer to that OMG specification for further details.
|
refer to that OMG specification for further details.
|
||||||
|
|
||||||
|
|
||||||
|
@ -33,8 +33,8 @@ questions.
|
|||||||
<P>This package contains the <TT>IOP</tt> module specified in the OMG document
|
<P>This package contains the <TT>IOP</tt> module specified in the OMG document
|
||||||
<em>The Common
|
<em>The Common
|
||||||
Object Request Broker: Architecture and Specification</em>,
|
Object Request Broker: Architecture and Specification</em>,
|
||||||
<a href="http://cgi.omg.org/cgi-bin/doc?formal/99-10-07">
|
<a href="http://www.omg.org/cgi-bin/doc?formal/99-10-07">
|
||||||
http://cgi.omg.org/cgi-bin/doc?formal/99-10-07</a>, section 13.6. Please
|
formal/99-10-07</a>, section 13.6. Please
|
||||||
refer to that OMG specification for further details.
|
refer to that OMG specification for further details.
|
||||||
|
|
||||||
<P>Please note that we do not provide all parts of the <tt>IOP</tt> module from
|
<P>Please note that we do not provide all parts of the <tt>IOP</tt> module from
|
||||||
|
@ -32,8 +32,8 @@ questions.
|
|||||||
<body bgcolor="white">
|
<body bgcolor="white">
|
||||||
<P>This package contains the <tt>Messaging</tt> module specified in the OMG CORBA
|
<P>This package contains the <tt>Messaging</tt> module specified in the OMG CORBA
|
||||||
Messaging specification,
|
Messaging specification,
|
||||||
<a href="http://cgi.omg.org/cgi-bin/doc?formal/99-10-07">
|
<a href="http://www.omg.org/cgi-bin/doc?formal/99-10-07">
|
||||||
http://cgi.omg.org/cgi-bin/doc?formal/99-10-07</a>. Please refer to that OMG
|
formal/99-10-07</a>. Please refer to that OMG
|
||||||
specification for further details.
|
specification for further details.
|
||||||
|
|
||||||
<P>Please note that we do not provide all parts of the <tt>Messaging</tt> module from
|
<P>Please note that we do not provide all parts of the <tt>Messaging</tt> module from
|
||||||
|
@ -33,8 +33,8 @@ questions.
|
|||||||
<P>This package contains the exceptions and typedefs from the <tt>ORBInitInfo</tt>
|
<P>This package contains the exceptions and typedefs from the <tt>ORBInitInfo</tt>
|
||||||
local interface of the <tt>PortableInterceptor</tt> module specified in the OMG
|
local interface of the <tt>PortableInterceptor</tt> module specified in the OMG
|
||||||
Portable Interceptor specification,
|
Portable Interceptor specification,
|
||||||
<a href="http://cgi.omg.org/cgi-bin/doc?ptc/2000-08-06">
|
<a href="http://www.omg.org/cgi-bin/doc?ptc/2000-08-06">
|
||||||
http://cgi.omg.org/cgi-bin/doc?ptc/2000-08-06</a>, section 21.7.2. Please
|
ptc/2000-08-06</a>, section 21.7.2. Please
|
||||||
refer to that OMG specification for further details.
|
refer to that OMG specification for further details.
|
||||||
|
|
||||||
|
|
||||||
|
@ -409,3 +409,4 @@ b2fee789d23f3cdabb3db4e51af43038e5692d3a jdk9-b03
|
|||||||
3812c088b9456ee22c933e88aee1ece71f4e783a jdk9-b04
|
3812c088b9456ee22c933e88aee1ece71f4e783a jdk9-b04
|
||||||
bdc5311e1db7598589b77015119b821bf8c828bd jdk9-b05
|
bdc5311e1db7598589b77015119b821bf8c828bd jdk9-b05
|
||||||
52377a30a3f87b62d6135706997b8c7a47366e37 jdk9-b06
|
52377a30a3f87b62d6135706997b8c7a47366e37 jdk9-b06
|
||||||
|
52f7edf2589d9f9d35db3008bc5377f279de9c18 jdk9-b07
|
||||||
|
@ -958,7 +958,7 @@ address InterpreterGenerator::generate_native_entry(bool synchronized) {
|
|||||||
|
|
||||||
// reset handle block
|
// reset handle block
|
||||||
__ ld_ptr(G2_thread, in_bytes(JavaThread::active_handles_offset()), G3_scratch);
|
__ ld_ptr(G2_thread, in_bytes(JavaThread::active_handles_offset()), G3_scratch);
|
||||||
__ st_ptr(G0, G3_scratch, JNIHandleBlock::top_offset_in_bytes());
|
__ st(G0, G3_scratch, JNIHandleBlock::top_offset_in_bytes());
|
||||||
|
|
||||||
|
|
||||||
// handle exceptions (exception handling will handle unlocking!)
|
// handle exceptions (exception handling will handle unlocking!)
|
||||||
|
@ -2687,7 +2687,7 @@ nmethod* SharedRuntime::generate_native_wrapper(MacroAssembler* masm,
|
|||||||
if (!is_critical_native) {
|
if (!is_critical_native) {
|
||||||
// reset handle block
|
// reset handle block
|
||||||
__ ld_ptr(G2_thread, in_bytes(JavaThread::active_handles_offset()), L5);
|
__ ld_ptr(G2_thread, in_bytes(JavaThread::active_handles_offset()), L5);
|
||||||
__ st_ptr(G0, L5, JNIHandleBlock::top_offset_in_bytes());
|
__ st(G0, L5, JNIHandleBlock::top_offset_in_bytes());
|
||||||
|
|
||||||
__ ld_ptr(G2_thread, in_bytes(Thread::pending_exception_offset()), G3_scratch);
|
__ ld_ptr(G2_thread, in_bytes(Thread::pending_exception_offset()), G3_scratch);
|
||||||
check_forward_pending_exception(masm, G3_scratch);
|
check_forward_pending_exception(masm, G3_scratch);
|
||||||
|
@ -1147,7 +1147,7 @@ address InterpreterGenerator::generate_native_entry(bool synchronized) {
|
|||||||
|
|
||||||
// reset handle block
|
// reset handle block
|
||||||
__ ld_ptr(G2_thread, JavaThread::active_handles_offset(), G3_scratch);
|
__ ld_ptr(G2_thread, JavaThread::active_handles_offset(), G3_scratch);
|
||||||
__ st_ptr(G0, G3_scratch, JNIHandleBlock::top_offset_in_bytes());
|
__ st(G0, G3_scratch, JNIHandleBlock::top_offset_in_bytes());
|
||||||
|
|
||||||
// If we have an oop result store it where it will be safe for any further gc
|
// If we have an oop result store it where it will be safe for any further gc
|
||||||
// until we return now that we've released the handle it might be protected by
|
// until we return now that we've released the handle it might be protected by
|
||||||
|
@ -1358,7 +1358,7 @@ address InterpreterGenerator::generate_native_entry(bool synchronized) {
|
|||||||
|
|
||||||
// reset handle block
|
// reset handle block
|
||||||
__ movptr(t, Address(thread, JavaThread::active_handles_offset()));
|
__ movptr(t, Address(thread, JavaThread::active_handles_offset()));
|
||||||
__ movptr(Address(t, JNIHandleBlock::top_offset_in_bytes()), (int32_t)NULL_WORD);
|
__ movl(Address(t, JNIHandleBlock::top_offset_in_bytes()), (int32_t)NULL_WORD);
|
||||||
|
|
||||||
// If result was an oop then unbox and save it in the frame
|
// If result was an oop then unbox and save it in the frame
|
||||||
{ Label L;
|
{ Label L;
|
||||||
|
@ -162,7 +162,7 @@ define_pd_global(uintx, TypeProfileLevel, 111);
|
|||||||
"Number of milliseconds to wait before start calculating aborts " \
|
"Number of milliseconds to wait before start calculating aborts " \
|
||||||
"for RTM locking") \
|
"for RTM locking") \
|
||||||
\
|
\
|
||||||
experimental(bool, UseRTMXendForLockBusy, false, \
|
experimental(bool, UseRTMXendForLockBusy, true, \
|
||||||
"Use RTM Xend instead of Xabort when lock busy") \
|
"Use RTM Xend instead of Xabort when lock busy") \
|
||||||
\
|
\
|
||||||
/* assembler */ \
|
/* assembler */ \
|
||||||
|
@ -1488,11 +1488,10 @@ void MacroAssembler::rtm_stack_locking(Register objReg, Register tmpReg, Registe
|
|||||||
movl(retry_on_abort_count_Reg, RTMRetryCount); // Retry on abort
|
movl(retry_on_abort_count_Reg, RTMRetryCount); // Retry on abort
|
||||||
bind(L_rtm_retry);
|
bind(L_rtm_retry);
|
||||||
}
|
}
|
||||||
if (!UseRTMXendForLockBusy) {
|
movptr(tmpReg, Address(objReg, 0));
|
||||||
movptr(tmpReg, Address(objReg, 0));
|
testptr(tmpReg, markOopDesc::monitor_value); // inflated vs stack-locked|neutral|biased
|
||||||
testptr(tmpReg, markOopDesc::monitor_value); // inflated vs stack-locked|neutral|biased
|
jcc(Assembler::notZero, IsInflated);
|
||||||
jcc(Assembler::notZero, IsInflated);
|
|
||||||
}
|
|
||||||
if (PrintPreciseRTMLockingStatistics || profile_rtm) {
|
if (PrintPreciseRTMLockingStatistics || profile_rtm) {
|
||||||
Label L_noincrement;
|
Label L_noincrement;
|
||||||
if (RTMTotalCountIncrRate > 1) {
|
if (RTMTotalCountIncrRate > 1) {
|
||||||
@ -1512,10 +1511,7 @@ void MacroAssembler::rtm_stack_locking(Register objReg, Register tmpReg, Registe
|
|||||||
Register abort_status_Reg = tmpReg; // status of abort is stored in RAX
|
Register abort_status_Reg = tmpReg; // status of abort is stored in RAX
|
||||||
if (UseRTMXendForLockBusy) {
|
if (UseRTMXendForLockBusy) {
|
||||||
xend();
|
xend();
|
||||||
movptr(tmpReg, Address(objReg, 0));
|
movptr(abort_status_Reg, 0x2); // Set the abort status to 2 (so we can retry)
|
||||||
testptr(tmpReg, markOopDesc::monitor_value); // inflated vs stack-locked|neutral|biased
|
|
||||||
jcc(Assembler::notZero, IsInflated);
|
|
||||||
movptr(abort_status_Reg, 0x1); // Set the abort status to 1 (as xabort does)
|
|
||||||
jmp(L_decrement_retry);
|
jmp(L_decrement_retry);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
@ -2266,7 +2266,7 @@ nmethod* SharedRuntime::generate_native_wrapper(MacroAssembler* masm,
|
|||||||
if (!is_critical_native) {
|
if (!is_critical_native) {
|
||||||
// reset handle block
|
// reset handle block
|
||||||
__ movptr(rcx, Address(thread, JavaThread::active_handles_offset()));
|
__ movptr(rcx, Address(thread, JavaThread::active_handles_offset()));
|
||||||
__ movptr(Address(rcx, JNIHandleBlock::top_offset_in_bytes()), NULL_WORD);
|
__ movl(Address(rcx, JNIHandleBlock::top_offset_in_bytes()), NULL_WORD);
|
||||||
|
|
||||||
// Any exception pending?
|
// Any exception pending?
|
||||||
__ cmpptr(Address(thread, in_bytes(Thread::pending_exception_offset())), (int32_t)NULL_WORD);
|
__ cmpptr(Address(thread, in_bytes(Thread::pending_exception_offset())), (int32_t)NULL_WORD);
|
||||||
|
@ -2509,7 +2509,7 @@ nmethod* SharedRuntime::generate_native_wrapper(MacroAssembler* masm,
|
|||||||
if (!is_critical_native) {
|
if (!is_critical_native) {
|
||||||
// reset handle block
|
// reset handle block
|
||||||
__ movptr(rcx, Address(r15_thread, JavaThread::active_handles_offset()));
|
__ movptr(rcx, Address(r15_thread, JavaThread::active_handles_offset()));
|
||||||
__ movptr(Address(rcx, JNIHandleBlock::top_offset_in_bytes()), (int32_t)NULL_WORD);
|
__ movl(Address(rcx, JNIHandleBlock::top_offset_in_bytes()), (int32_t)NULL_WORD);
|
||||||
}
|
}
|
||||||
|
|
||||||
// pop our frame
|
// pop our frame
|
||||||
|
@ -1287,7 +1287,7 @@ address InterpreterGenerator::generate_native_entry(bool synchronized) {
|
|||||||
|
|
||||||
// reset handle block
|
// reset handle block
|
||||||
__ movptr(t, Address(thread, JavaThread::active_handles_offset()));
|
__ movptr(t, Address(thread, JavaThread::active_handles_offset()));
|
||||||
__ movptr(Address(t, JNIHandleBlock::top_offset_in_bytes()), NULL_WORD);
|
__ movl(Address(t, JNIHandleBlock::top_offset_in_bytes()), NULL_WORD);
|
||||||
|
|
||||||
// If result was an oop then unbox and save it in the frame
|
// If result was an oop then unbox and save it in the frame
|
||||||
{ Label L;
|
{ Label L;
|
||||||
|
@ -1259,7 +1259,7 @@ address InterpreterGenerator::generate_native_entry(bool synchronized) {
|
|||||||
|
|
||||||
// reset handle block
|
// reset handle block
|
||||||
__ movptr(t, Address(r15_thread, JavaThread::active_handles_offset()));
|
__ movptr(t, Address(r15_thread, JavaThread::active_handles_offset()));
|
||||||
__ movptr(Address(t, JNIHandleBlock::top_offset_in_bytes()), (int32_t)NULL_WORD);
|
__ movl(Address(t, JNIHandleBlock::top_offset_in_bytes()), (int32_t)NULL_WORD);
|
||||||
|
|
||||||
// If result is an oop unbox and store it in frame where gc will see it
|
// If result is an oop unbox and store it in frame where gc will see it
|
||||||
// and result handler will pick it up
|
// and result handler will pick it up
|
||||||
|
@ -810,11 +810,11 @@ void StringTable::buckets_oops_do(OopClosure* f, int start_idx, int end_idx) {
|
|||||||
const int limit = the_table()->table_size();
|
const int limit = the_table()->table_size();
|
||||||
|
|
||||||
assert(0 <= start_idx && start_idx <= limit,
|
assert(0 <= start_idx && start_idx <= limit,
|
||||||
err_msg("start_idx (" INT32_FORMAT ") is out of bounds", start_idx));
|
err_msg("start_idx (%d) is out of bounds", start_idx));
|
||||||
assert(0 <= end_idx && end_idx <= limit,
|
assert(0 <= end_idx && end_idx <= limit,
|
||||||
err_msg("end_idx (" INT32_FORMAT ") is out of bounds", end_idx));
|
err_msg("end_idx (%d) is out of bounds", end_idx));
|
||||||
assert(start_idx <= end_idx,
|
assert(start_idx <= end_idx,
|
||||||
err_msg("Index ordering: start_idx=" INT32_FORMAT", end_idx=" INT32_FORMAT,
|
err_msg("Index ordering: start_idx=%d, end_idx=%d",
|
||||||
start_idx, end_idx));
|
start_idx, end_idx));
|
||||||
|
|
||||||
for (int i = start_idx; i < end_idx; i += 1) {
|
for (int i = start_idx; i < end_idx; i += 1) {
|
||||||
@ -833,11 +833,11 @@ void StringTable::buckets_unlink_or_oops_do(BoolObjectClosure* is_alive, OopClos
|
|||||||
const int limit = the_table()->table_size();
|
const int limit = the_table()->table_size();
|
||||||
|
|
||||||
assert(0 <= start_idx && start_idx <= limit,
|
assert(0 <= start_idx && start_idx <= limit,
|
||||||
err_msg("start_idx (" INT32_FORMAT ") is out of bounds", start_idx));
|
err_msg("start_idx (%d) is out of bounds", start_idx));
|
||||||
assert(0 <= end_idx && end_idx <= limit,
|
assert(0 <= end_idx && end_idx <= limit,
|
||||||
err_msg("end_idx (" INT32_FORMAT ") is out of bounds", end_idx));
|
err_msg("end_idx (%d) is out of bounds", end_idx));
|
||||||
assert(start_idx <= end_idx,
|
assert(start_idx <= end_idx,
|
||||||
err_msg("Index ordering: start_idx=" INT32_FORMAT", end_idx=" INT32_FORMAT,
|
err_msg("Index ordering: start_idx=%d, end_idx=%d",
|
||||||
start_idx, end_idx));
|
start_idx, end_idx));
|
||||||
|
|
||||||
for (int i = start_idx; i < end_idx; ++i) {
|
for (int i = start_idx; i < end_idx; ++i) {
|
||||||
|
@ -57,10 +57,10 @@ ConcurrentG1Refine::ConcurrentG1Refine(G1CollectedHeap* g1h) :
|
|||||||
|
|
||||||
_threads = NEW_C_HEAP_ARRAY(ConcurrentG1RefineThread*, _n_threads, mtGC);
|
_threads = NEW_C_HEAP_ARRAY(ConcurrentG1RefineThread*, _n_threads, mtGC);
|
||||||
|
|
||||||
int worker_id_offset = (int)DirtyCardQueueSet::num_par_ids();
|
uint worker_id_offset = DirtyCardQueueSet::num_par_ids();
|
||||||
|
|
||||||
ConcurrentG1RefineThread *next = NULL;
|
ConcurrentG1RefineThread *next = NULL;
|
||||||
for (int i = _n_threads - 1; i >= 0; i--) {
|
for (uint i = _n_threads - 1; i != UINT_MAX; i--) {
|
||||||
ConcurrentG1RefineThread* t = new ConcurrentG1RefineThread(this, next, worker_id_offset, i);
|
ConcurrentG1RefineThread* t = new ConcurrentG1RefineThread(this, next, worker_id_offset, i);
|
||||||
assert(t != NULL, "Conc refine should have been created");
|
assert(t != NULL, "Conc refine should have been created");
|
||||||
if (t->osthread() == NULL) {
|
if (t->osthread() == NULL) {
|
||||||
@ -87,7 +87,7 @@ void ConcurrentG1Refine::init() {
|
|||||||
|
|
||||||
void ConcurrentG1Refine::stop() {
|
void ConcurrentG1Refine::stop() {
|
||||||
if (_threads != NULL) {
|
if (_threads != NULL) {
|
||||||
for (int i = 0; i < _n_threads; i++) {
|
for (uint i = 0; i < _n_threads; i++) {
|
||||||
_threads[i]->stop();
|
_threads[i]->stop();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -96,7 +96,7 @@ void ConcurrentG1Refine::stop() {
|
|||||||
void ConcurrentG1Refine::reinitialize_threads() {
|
void ConcurrentG1Refine::reinitialize_threads() {
|
||||||
reset_threshold_step();
|
reset_threshold_step();
|
||||||
if (_threads != NULL) {
|
if (_threads != NULL) {
|
||||||
for (int i = 0; i < _n_threads; i++) {
|
for (uint i = 0; i < _n_threads; i++) {
|
||||||
_threads[i]->initialize();
|
_threads[i]->initialize();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -104,7 +104,7 @@ void ConcurrentG1Refine::reinitialize_threads() {
|
|||||||
|
|
||||||
ConcurrentG1Refine::~ConcurrentG1Refine() {
|
ConcurrentG1Refine::~ConcurrentG1Refine() {
|
||||||
if (_threads != NULL) {
|
if (_threads != NULL) {
|
||||||
for (int i = 0; i < _n_threads; i++) {
|
for (uint i = 0; i < _n_threads; i++) {
|
||||||
delete _threads[i];
|
delete _threads[i];
|
||||||
}
|
}
|
||||||
FREE_C_HEAP_ARRAY(ConcurrentG1RefineThread*, _threads, mtGC);
|
FREE_C_HEAP_ARRAY(ConcurrentG1RefineThread*, _threads, mtGC);
|
||||||
@ -113,7 +113,7 @@ ConcurrentG1Refine::~ConcurrentG1Refine() {
|
|||||||
|
|
||||||
void ConcurrentG1Refine::threads_do(ThreadClosure *tc) {
|
void ConcurrentG1Refine::threads_do(ThreadClosure *tc) {
|
||||||
if (_threads != NULL) {
|
if (_threads != NULL) {
|
||||||
for (int i = 0; i < _n_threads; i++) {
|
for (uint i = 0; i < _n_threads; i++) {
|
||||||
tc->do_thread(_threads[i]);
|
tc->do_thread(_threads[i]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -121,20 +121,20 @@ void ConcurrentG1Refine::threads_do(ThreadClosure *tc) {
|
|||||||
|
|
||||||
void ConcurrentG1Refine::worker_threads_do(ThreadClosure * tc) {
|
void ConcurrentG1Refine::worker_threads_do(ThreadClosure * tc) {
|
||||||
if (_threads != NULL) {
|
if (_threads != NULL) {
|
||||||
for (int i = 0; i < worker_thread_num(); i++) {
|
for (uint i = 0; i < worker_thread_num(); i++) {
|
||||||
tc->do_thread(_threads[i]);
|
tc->do_thread(_threads[i]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int ConcurrentG1Refine::thread_num() {
|
uint ConcurrentG1Refine::thread_num() {
|
||||||
int n_threads = (G1ConcRefinementThreads > 0) ? G1ConcRefinementThreads
|
uint n_threads = (G1ConcRefinementThreads > 0) ? G1ConcRefinementThreads
|
||||||
: ParallelGCThreads;
|
: ParallelGCThreads;
|
||||||
return MAX2<int>(n_threads, 1);
|
return MAX2<uint>(n_threads, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ConcurrentG1Refine::print_worker_threads_on(outputStream* st) const {
|
void ConcurrentG1Refine::print_worker_threads_on(outputStream* st) const {
|
||||||
for (int i = 0; i < _n_threads; ++i) {
|
for (uint i = 0; i < _n_threads; ++i) {
|
||||||
_threads[i]->print_on(st);
|
_threads[i]->print_on(st);
|
||||||
st->cr();
|
st->cr();
|
||||||
}
|
}
|
||||||
|
@ -39,8 +39,8 @@ class DirtyCardQueue;
|
|||||||
|
|
||||||
class ConcurrentG1Refine: public CHeapObj<mtGC> {
|
class ConcurrentG1Refine: public CHeapObj<mtGC> {
|
||||||
ConcurrentG1RefineThread** _threads;
|
ConcurrentG1RefineThread** _threads;
|
||||||
int _n_threads;
|
uint _n_threads;
|
||||||
int _n_worker_threads;
|
uint _n_worker_threads;
|
||||||
/*
|
/*
|
||||||
* The value of the update buffer queue length falls into one of 3 zones:
|
* The value of the update buffer queue length falls into one of 3 zones:
|
||||||
* green, yellow, red. If the value is in [0, green) nothing is
|
* green, yellow, red. If the value is in [0, green) nothing is
|
||||||
@ -88,7 +88,7 @@ class ConcurrentG1Refine: public CHeapObj<mtGC> {
|
|||||||
// The RS sampling thread
|
// The RS sampling thread
|
||||||
ConcurrentG1RefineThread * sampling_thread() const;
|
ConcurrentG1RefineThread * sampling_thread() const;
|
||||||
|
|
||||||
static int thread_num();
|
static uint thread_num();
|
||||||
|
|
||||||
void print_worker_threads_on(outputStream* st) const;
|
void print_worker_threads_on(outputStream* st) const;
|
||||||
|
|
||||||
@ -100,8 +100,8 @@ class ConcurrentG1Refine: public CHeapObj<mtGC> {
|
|||||||
int yellow_zone() const { return _yellow_zone; }
|
int yellow_zone() const { return _yellow_zone; }
|
||||||
int red_zone() const { return _red_zone; }
|
int red_zone() const { return _red_zone; }
|
||||||
|
|
||||||
int total_thread_num() const { return _n_threads; }
|
uint total_thread_num() const { return _n_threads; }
|
||||||
int worker_thread_num() const { return _n_worker_threads; }
|
uint worker_thread_num() const { return _n_worker_threads; }
|
||||||
|
|
||||||
int thread_threshold_step() const { return _thread_threshold_step; }
|
int thread_threshold_step() const { return _thread_threshold_step; }
|
||||||
|
|
||||||
|
@ -33,7 +33,7 @@
|
|||||||
|
|
||||||
ConcurrentG1RefineThread::
|
ConcurrentG1RefineThread::
|
||||||
ConcurrentG1RefineThread(ConcurrentG1Refine* cg1r, ConcurrentG1RefineThread *next,
|
ConcurrentG1RefineThread(ConcurrentG1Refine* cg1r, ConcurrentG1RefineThread *next,
|
||||||
int worker_id_offset, int worker_id) :
|
uint worker_id_offset, uint worker_id) :
|
||||||
ConcurrentGCThread(),
|
ConcurrentGCThread(),
|
||||||
_worker_id_offset(worker_id_offset),
|
_worker_id_offset(worker_id_offset),
|
||||||
_worker_id(worker_id),
|
_worker_id(worker_id),
|
||||||
|
@ -38,8 +38,8 @@ class ConcurrentG1RefineThread: public ConcurrentGCThread {
|
|||||||
|
|
||||||
double _vtime_start; // Initial virtual time.
|
double _vtime_start; // Initial virtual time.
|
||||||
double _vtime_accum; // Initial virtual time.
|
double _vtime_accum; // Initial virtual time.
|
||||||
int _worker_id;
|
uint _worker_id;
|
||||||
int _worker_id_offset;
|
uint _worker_id_offset;
|
||||||
|
|
||||||
// The refinement threads collection is linked list. A predecessor can activate a successor
|
// The refinement threads collection is linked list. A predecessor can activate a successor
|
||||||
// when the number of the rset update buffer crosses a certain threshold. A successor
|
// when the number of the rset update buffer crosses a certain threshold. A successor
|
||||||
@ -71,7 +71,7 @@ public:
|
|||||||
virtual void run();
|
virtual void run();
|
||||||
// Constructor
|
// Constructor
|
||||||
ConcurrentG1RefineThread(ConcurrentG1Refine* cg1r, ConcurrentG1RefineThread* next,
|
ConcurrentG1RefineThread(ConcurrentG1Refine* cg1r, ConcurrentG1RefineThread* next,
|
||||||
int worker_id_offset, int worker_id);
|
uint worker_id_offset, uint worker_id);
|
||||||
|
|
||||||
void initialize();
|
void initialize();
|
||||||
|
|
||||||
|
@ -567,8 +567,8 @@ ConcurrentMark::ConcurrentMark(G1CollectedHeap* g1h, ReservedSpace heap_rs) :
|
|||||||
_root_regions.init(_g1h, this);
|
_root_regions.init(_g1h, this);
|
||||||
|
|
||||||
if (ConcGCThreads > ParallelGCThreads) {
|
if (ConcGCThreads > ParallelGCThreads) {
|
||||||
warning("Can't have more ConcGCThreads (" UINT32_FORMAT ") "
|
warning("Can't have more ConcGCThreads (" UINTX_FORMAT ") "
|
||||||
"than ParallelGCThreads (" UINT32_FORMAT ").",
|
"than ParallelGCThreads (" UINTX_FORMAT ").",
|
||||||
ConcGCThreads, ParallelGCThreads);
|
ConcGCThreads, ParallelGCThreads);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -1804,7 +1804,6 @@ class G1ParNoteEndTask;
|
|||||||
|
|
||||||
class G1NoteEndOfConcMarkClosure : public HeapRegionClosure {
|
class G1NoteEndOfConcMarkClosure : public HeapRegionClosure {
|
||||||
G1CollectedHeap* _g1;
|
G1CollectedHeap* _g1;
|
||||||
int _worker_num;
|
|
||||||
size_t _max_live_bytes;
|
size_t _max_live_bytes;
|
||||||
uint _regions_claimed;
|
uint _regions_claimed;
|
||||||
size_t _freed_bytes;
|
size_t _freed_bytes;
|
||||||
@ -1817,10 +1816,9 @@ class G1NoteEndOfConcMarkClosure : public HeapRegionClosure {
|
|||||||
|
|
||||||
public:
|
public:
|
||||||
G1NoteEndOfConcMarkClosure(G1CollectedHeap* g1,
|
G1NoteEndOfConcMarkClosure(G1CollectedHeap* g1,
|
||||||
int worker_num,
|
|
||||||
FreeRegionList* local_cleanup_list,
|
FreeRegionList* local_cleanup_list,
|
||||||
HRRSCleanupTask* hrrs_cleanup_task) :
|
HRRSCleanupTask* hrrs_cleanup_task) :
|
||||||
_g1(g1), _worker_num(worker_num),
|
_g1(g1),
|
||||||
_max_live_bytes(0), _regions_claimed(0),
|
_max_live_bytes(0), _regions_claimed(0),
|
||||||
_freed_bytes(0),
|
_freed_bytes(0),
|
||||||
_claimed_region_time(0.0), _max_region_time(0.0),
|
_claimed_region_time(0.0), _max_region_time(0.0),
|
||||||
@ -1893,7 +1891,7 @@ public:
|
|||||||
double start = os::elapsedTime();
|
double start = os::elapsedTime();
|
||||||
FreeRegionList local_cleanup_list("Local Cleanup List");
|
FreeRegionList local_cleanup_list("Local Cleanup List");
|
||||||
HRRSCleanupTask hrrs_cleanup_task;
|
HRRSCleanupTask hrrs_cleanup_task;
|
||||||
G1NoteEndOfConcMarkClosure g1_note_end(_g1h, worker_id, &local_cleanup_list,
|
G1NoteEndOfConcMarkClosure g1_note_end(_g1h, &local_cleanup_list,
|
||||||
&hrrs_cleanup_task);
|
&hrrs_cleanup_task);
|
||||||
if (G1CollectedHeap::use_parallel_gc_threads()) {
|
if (G1CollectedHeap::use_parallel_gc_threads()) {
|
||||||
_g1h->heap_region_par_iterate_chunked(&g1_note_end, worker_id,
|
_g1h->heap_region_par_iterate_chunked(&g1_note_end, worker_id,
|
||||||
@ -2145,7 +2143,7 @@ void ConcurrentMark::completeCleanup() {
|
|||||||
|
|
||||||
G1CollectedHeap* g1h = G1CollectedHeap::heap();
|
G1CollectedHeap* g1h = G1CollectedHeap::heap();
|
||||||
|
|
||||||
_cleanup_list.verify_list();
|
_cleanup_list.verify_optional();
|
||||||
FreeRegionList tmp_free_list("Tmp Free List");
|
FreeRegionList tmp_free_list("Tmp Free List");
|
||||||
|
|
||||||
if (G1ConcRegionFreeingVerbose) {
|
if (G1ConcRegionFreeingVerbose) {
|
||||||
|
@ -34,12 +34,12 @@
|
|||||||
|
|
||||||
bool DirtyCardQueue::apply_closure(CardTableEntryClosure* cl,
|
bool DirtyCardQueue::apply_closure(CardTableEntryClosure* cl,
|
||||||
bool consume,
|
bool consume,
|
||||||
size_t worker_i) {
|
uint worker_i) {
|
||||||
bool res = true;
|
bool res = true;
|
||||||
if (_buf != NULL) {
|
if (_buf != NULL) {
|
||||||
res = apply_closure_to_buffer(cl, _buf, _index, _sz,
|
res = apply_closure_to_buffer(cl, _buf, _index, _sz,
|
||||||
consume,
|
consume,
|
||||||
(int) worker_i);
|
worker_i);
|
||||||
if (res && consume) _index = _sz;
|
if (res && consume) _index = _sz;
|
||||||
}
|
}
|
||||||
return res;
|
return res;
|
||||||
@ -49,7 +49,7 @@ bool DirtyCardQueue::apply_closure_to_buffer(CardTableEntryClosure* cl,
|
|||||||
void** buf,
|
void** buf,
|
||||||
size_t index, size_t sz,
|
size_t index, size_t sz,
|
||||||
bool consume,
|
bool consume,
|
||||||
int worker_i) {
|
uint worker_i) {
|
||||||
if (cl == NULL) return true;
|
if (cl == NULL) return true;
|
||||||
for (size_t i = index; i < sz; i += oopSize) {
|
for (size_t i = index; i < sz; i += oopSize) {
|
||||||
int ind = byte_index_to_index((int)i);
|
int ind = byte_index_to_index((int)i);
|
||||||
@ -79,8 +79,8 @@ DirtyCardQueueSet::DirtyCardQueueSet(bool notify_when_complete) :
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Determines how many mutator threads can process the buffers in parallel.
|
// Determines how many mutator threads can process the buffers in parallel.
|
||||||
size_t DirtyCardQueueSet::num_par_ids() {
|
uint DirtyCardQueueSet::num_par_ids() {
|
||||||
return os::processor_count();
|
return (uint)os::processor_count();
|
||||||
}
|
}
|
||||||
|
|
||||||
void DirtyCardQueueSet::initialize(Monitor* cbl_mon, Mutex* fl_lock,
|
void DirtyCardQueueSet::initialize(Monitor* cbl_mon, Mutex* fl_lock,
|
||||||
@ -103,7 +103,7 @@ void DirtyCardQueueSet::set_closure(CardTableEntryClosure* closure) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void DirtyCardQueueSet::iterate_closure_all_threads(bool consume,
|
void DirtyCardQueueSet::iterate_closure_all_threads(bool consume,
|
||||||
size_t worker_i) {
|
uint worker_i) {
|
||||||
assert(SafepointSynchronize::is_at_safepoint(), "Must be at safepoint.");
|
assert(SafepointSynchronize::is_at_safepoint(), "Must be at safepoint.");
|
||||||
for(JavaThread* t = Threads::first(); t; t = t->next()) {
|
for(JavaThread* t = Threads::first(); t; t = t->next()) {
|
||||||
bool b = t->dirty_card_queue().apply_closure(_closure, consume);
|
bool b = t->dirty_card_queue().apply_closure(_closure, consume);
|
||||||
@ -126,11 +126,11 @@ bool DirtyCardQueueSet::mut_process_buffer(void** buf) {
|
|||||||
|
|
||||||
// We get the the number of any par_id that this thread
|
// We get the the number of any par_id that this thread
|
||||||
// might have already claimed.
|
// might have already claimed.
|
||||||
int worker_i = thread->get_claimed_par_id();
|
uint worker_i = thread->get_claimed_par_id();
|
||||||
|
|
||||||
// If worker_i is not -1 then the thread has already claimed
|
// If worker_i is not UINT_MAX then the thread has already claimed
|
||||||
// a par_id. We make note of it using the already_claimed value
|
// a par_id. We make note of it using the already_claimed value
|
||||||
if (worker_i != -1) {
|
if (worker_i != UINT_MAX) {
|
||||||
already_claimed = true;
|
already_claimed = true;
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
@ -142,7 +142,7 @@ bool DirtyCardQueueSet::mut_process_buffer(void** buf) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool b = false;
|
bool b = false;
|
||||||
if (worker_i != -1) {
|
if (worker_i != UINT_MAX) {
|
||||||
b = DirtyCardQueue::apply_closure_to_buffer(_closure, buf, 0,
|
b = DirtyCardQueue::apply_closure_to_buffer(_closure, buf, 0,
|
||||||
_sz, true, worker_i);
|
_sz, true, worker_i);
|
||||||
if (b) Atomic::inc(&_processed_buffers_mut);
|
if (b) Atomic::inc(&_processed_buffers_mut);
|
||||||
@ -154,8 +154,8 @@ bool DirtyCardQueueSet::mut_process_buffer(void** buf) {
|
|||||||
// we release the id
|
// we release the id
|
||||||
_free_ids->release_par_id(worker_i);
|
_free_ids->release_par_id(worker_i);
|
||||||
|
|
||||||
// and set the claimed_id in the thread to -1
|
// and set the claimed_id in the thread to UINT_MAX
|
||||||
thread->set_claimed_par_id(-1);
|
thread->set_claimed_par_id(UINT_MAX);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return b;
|
return b;
|
||||||
@ -186,7 +186,7 @@ DirtyCardQueueSet::get_completed_buffer(int stop_at) {
|
|||||||
|
|
||||||
bool DirtyCardQueueSet::
|
bool DirtyCardQueueSet::
|
||||||
apply_closure_to_completed_buffer_helper(CardTableEntryClosure* cl,
|
apply_closure_to_completed_buffer_helper(CardTableEntryClosure* cl,
|
||||||
int worker_i,
|
uint worker_i,
|
||||||
BufferNode* nd) {
|
BufferNode* nd) {
|
||||||
if (nd != NULL) {
|
if (nd != NULL) {
|
||||||
void **buf = BufferNode::make_buffer_from_node(nd);
|
void **buf = BufferNode::make_buffer_from_node(nd);
|
||||||
@ -208,7 +208,7 @@ apply_closure_to_completed_buffer_helper(CardTableEntryClosure* cl,
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool DirtyCardQueueSet::apply_closure_to_completed_buffer(CardTableEntryClosure* cl,
|
bool DirtyCardQueueSet::apply_closure_to_completed_buffer(CardTableEntryClosure* cl,
|
||||||
int worker_i,
|
uint worker_i,
|
||||||
int stop_at,
|
int stop_at,
|
||||||
bool during_pause) {
|
bool during_pause) {
|
||||||
assert(!during_pause || stop_at == 0, "Should not leave any completed buffers during a pause");
|
assert(!during_pause || stop_at == 0, "Should not leave any completed buffers during a pause");
|
||||||
@ -218,7 +218,7 @@ bool DirtyCardQueueSet::apply_closure_to_completed_buffer(CardTableEntryClosure*
|
|||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool DirtyCardQueueSet::apply_closure_to_completed_buffer(int worker_i,
|
bool DirtyCardQueueSet::apply_closure_to_completed_buffer(uint worker_i,
|
||||||
int stop_at,
|
int stop_at,
|
||||||
bool during_pause) {
|
bool during_pause) {
|
||||||
return apply_closure_to_completed_buffer(_closure, worker_i,
|
return apply_closure_to_completed_buffer(_closure, worker_i,
|
||||||
|
@ -36,7 +36,7 @@ class CardTableEntryClosure: public CHeapObj<mtGC> {
|
|||||||
public:
|
public:
|
||||||
// Process the card whose card table entry is "card_ptr". If returns
|
// Process the card whose card table entry is "card_ptr". If returns
|
||||||
// "false", terminate the iteration early.
|
// "false", terminate the iteration early.
|
||||||
virtual bool do_card_ptr(jbyte* card_ptr, int worker_i = 0) = 0;
|
virtual bool do_card_ptr(jbyte* card_ptr, uint worker_i = 0) = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
// A ptrQueue whose elements are "oops", pointers to object heads.
|
// A ptrQueue whose elements are "oops", pointers to object heads.
|
||||||
@ -53,7 +53,7 @@ public:
|
|||||||
// deletes processed entries from logs.
|
// deletes processed entries from logs.
|
||||||
bool apply_closure(CardTableEntryClosure* cl,
|
bool apply_closure(CardTableEntryClosure* cl,
|
||||||
bool consume = true,
|
bool consume = true,
|
||||||
size_t worker_i = 0);
|
uint worker_i = 0);
|
||||||
|
|
||||||
// Apply the closure to all elements of "buf", down to "index"
|
// Apply the closure to all elements of "buf", down to "index"
|
||||||
// (inclusive.) If returns "false", then a closure application returned
|
// (inclusive.) If returns "false", then a closure application returned
|
||||||
@ -63,7 +63,7 @@ public:
|
|||||||
static bool apply_closure_to_buffer(CardTableEntryClosure* cl,
|
static bool apply_closure_to_buffer(CardTableEntryClosure* cl,
|
||||||
void** buf, size_t index, size_t sz,
|
void** buf, size_t index, size_t sz,
|
||||||
bool consume = true,
|
bool consume = true,
|
||||||
int worker_i = 0);
|
uint worker_i = 0);
|
||||||
void **get_buf() { return _buf;}
|
void **get_buf() { return _buf;}
|
||||||
void set_buf(void **buf) {_buf = buf;}
|
void set_buf(void **buf) {_buf = buf;}
|
||||||
size_t get_index() { return _index;}
|
size_t get_index() { return _index;}
|
||||||
@ -98,7 +98,7 @@ public:
|
|||||||
|
|
||||||
// The number of parallel ids that can be claimed to allow collector or
|
// The number of parallel ids that can be claimed to allow collector or
|
||||||
// mutator threads to do card-processing work.
|
// mutator threads to do card-processing work.
|
||||||
static size_t num_par_ids();
|
static uint num_par_ids();
|
||||||
|
|
||||||
static void handle_zero_index_for_thread(JavaThread* t);
|
static void handle_zero_index_for_thread(JavaThread* t);
|
||||||
|
|
||||||
@ -115,7 +115,7 @@ public:
|
|||||||
// change in the future.) If "consume" is true, processed entries are
|
// change in the future.) If "consume" is true, processed entries are
|
||||||
// discarded.
|
// discarded.
|
||||||
void iterate_closure_all_threads(bool consume = true,
|
void iterate_closure_all_threads(bool consume = true,
|
||||||
size_t worker_i = 0);
|
uint worker_i = 0);
|
||||||
|
|
||||||
// If there exists some completed buffer, pop it, then apply the
|
// If there exists some completed buffer, pop it, then apply the
|
||||||
// registered closure to all its elements, nulling out those elements
|
// registered closure to all its elements, nulling out those elements
|
||||||
@ -124,7 +124,7 @@ public:
|
|||||||
// but is only partially completed before a "yield" happens, the
|
// but is only partially completed before a "yield" happens, the
|
||||||
// partially completed buffer (with its processed elements set to NULL)
|
// partially completed buffer (with its processed elements set to NULL)
|
||||||
// is returned to the completed buffer set, and this call returns false.
|
// is returned to the completed buffer set, and this call returns false.
|
||||||
bool apply_closure_to_completed_buffer(int worker_i = 0,
|
bool apply_closure_to_completed_buffer(uint worker_i = 0,
|
||||||
int stop_at = 0,
|
int stop_at = 0,
|
||||||
bool during_pause = false);
|
bool during_pause = false);
|
||||||
|
|
||||||
@ -136,13 +136,13 @@ public:
|
|||||||
// partially completed buffer (with its processed elements set to NULL)
|
// partially completed buffer (with its processed elements set to NULL)
|
||||||
// is returned to the completed buffer set, and this call returns false.
|
// is returned to the completed buffer set, and this call returns false.
|
||||||
bool apply_closure_to_completed_buffer(CardTableEntryClosure* cl,
|
bool apply_closure_to_completed_buffer(CardTableEntryClosure* cl,
|
||||||
int worker_i = 0,
|
uint worker_i = 0,
|
||||||
int stop_at = 0,
|
int stop_at = 0,
|
||||||
bool during_pause = false);
|
bool during_pause = false);
|
||||||
|
|
||||||
// Helper routine for the above.
|
// Helper routine for the above.
|
||||||
bool apply_closure_to_completed_buffer_helper(CardTableEntryClosure* cl,
|
bool apply_closure_to_completed_buffer_helper(CardTableEntryClosure* cl,
|
||||||
int worker_i,
|
uint worker_i,
|
||||||
BufferNode* nd);
|
BufferNode* nd);
|
||||||
|
|
||||||
BufferNode* get_completed_buffer(int stop_at);
|
BufferNode* get_completed_buffer(int stop_at);
|
||||||
|
@ -304,26 +304,26 @@ void G1BlockOffsetArray::check_all_cards(size_t start_card, size_t end_card) con
|
|||||||
if (c - start_card > BlockOffsetArray::power_to_cards_back(1)) {
|
if (c - start_card > BlockOffsetArray::power_to_cards_back(1)) {
|
||||||
guarantee(entry > N_words,
|
guarantee(entry > N_words,
|
||||||
err_msg("Should be in logarithmic region - "
|
err_msg("Should be in logarithmic region - "
|
||||||
"entry: " UINT32_FORMAT ", "
|
"entry: %u, "
|
||||||
"_array->offset_array(c): " UINT32_FORMAT ", "
|
"_array->offset_array(c): %u, "
|
||||||
"N_words: " UINT32_FORMAT,
|
"N_words: %u",
|
||||||
entry, _array->offset_array(c), N_words));
|
(uint)entry, (uint)_array->offset_array(c), (uint)N_words));
|
||||||
}
|
}
|
||||||
size_t backskip = BlockOffsetArray::entry_to_cards_back(entry);
|
size_t backskip = BlockOffsetArray::entry_to_cards_back(entry);
|
||||||
size_t landing_card = c - backskip;
|
size_t landing_card = c - backskip;
|
||||||
guarantee(landing_card >= (start_card - 1), "Inv");
|
guarantee(landing_card >= (start_card - 1), "Inv");
|
||||||
if (landing_card >= start_card) {
|
if (landing_card >= start_card) {
|
||||||
guarantee(_array->offset_array(landing_card) <= entry,
|
guarantee(_array->offset_array(landing_card) <= entry,
|
||||||
err_msg("Monotonicity - landing_card offset: " UINT32_FORMAT ", "
|
err_msg("Monotonicity - landing_card offset: %u, "
|
||||||
"entry: " UINT32_FORMAT,
|
"entry: %u",
|
||||||
_array->offset_array(landing_card), entry));
|
(uint)_array->offset_array(landing_card), (uint)entry));
|
||||||
} else {
|
} else {
|
||||||
guarantee(landing_card == start_card - 1, "Tautology");
|
guarantee(landing_card == start_card - 1, "Tautology");
|
||||||
// Note that N_words is the maximum offset value
|
// Note that N_words is the maximum offset value
|
||||||
guarantee(_array->offset_array(landing_card) <= N_words,
|
guarantee(_array->offset_array(landing_card) <= N_words,
|
||||||
err_msg("landing card offset: " UINT32_FORMAT ", "
|
err_msg("landing card offset: %u, "
|
||||||
"N_words: " UINT32_FORMAT,
|
"N_words: %u",
|
||||||
_array->offset_array(landing_card), N_words));
|
(uint)_array->offset_array(landing_card), (uint)N_words));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -554,21 +554,20 @@ void G1BlockOffsetArray::alloc_block_work2(HeapWord** threshold_, size_t* index_
|
|||||||
(_array->offset_array(orig_index) > 0 &&
|
(_array->offset_array(orig_index) > 0 &&
|
||||||
_array->offset_array(orig_index) <= N_words),
|
_array->offset_array(orig_index) <= N_words),
|
||||||
err_msg("offset array should have been set - "
|
err_msg("offset array should have been set - "
|
||||||
"orig_index offset: " UINT32_FORMAT ", "
|
"orig_index offset: %u, "
|
||||||
"blk_start: " PTR_FORMAT ", "
|
"blk_start: " PTR_FORMAT ", "
|
||||||
"boundary: " PTR_FORMAT,
|
"boundary: " PTR_FORMAT,
|
||||||
_array->offset_array(orig_index),
|
(uint)_array->offset_array(orig_index),
|
||||||
blk_start, boundary));
|
blk_start, boundary));
|
||||||
for (size_t j = orig_index + 1; j <= end_index; j++) {
|
for (size_t j = orig_index + 1; j <= end_index; j++) {
|
||||||
assert(_array->offset_array(j) > 0 &&
|
assert(_array->offset_array(j) > 0 &&
|
||||||
_array->offset_array(j) <=
|
_array->offset_array(j) <=
|
||||||
(u_char) (N_words+BlockOffsetArray::N_powers-1),
|
(u_char) (N_words+BlockOffsetArray::N_powers-1),
|
||||||
err_msg("offset array should have been set - "
|
err_msg("offset array should have been set - "
|
||||||
UINT32_FORMAT " not > 0 OR "
|
"%u not > 0 OR %u not <= %u",
|
||||||
UINT32_FORMAT " not <= " UINT32_FORMAT,
|
(uint) _array->offset_array(j),
|
||||||
_array->offset_array(j),
|
(uint) _array->offset_array(j),
|
||||||
_array->offset_array(j),
|
(uint) (N_words+BlockOffsetArray::N_powers-1)));
|
||||||
(u_char) (N_words+BlockOffsetArray::N_powers-1)));
|
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
@ -146,8 +146,8 @@ private:
|
|||||||
void check_offset(size_t offset, const char* msg) const {
|
void check_offset(size_t offset, const char* msg) const {
|
||||||
assert(offset <= N_words,
|
assert(offset <= N_words,
|
||||||
err_msg("%s - "
|
err_msg("%s - "
|
||||||
"offset: " UINT32_FORMAT", N_words: " UINT32_FORMAT,
|
"offset: " SIZE_FORMAT", N_words: %u",
|
||||||
msg, offset, N_words));
|
msg, offset, (uint)N_words));
|
||||||
}
|
}
|
||||||
|
|
||||||
// Bounds checking accessors:
|
// Bounds checking accessors:
|
||||||
|
@ -102,7 +102,7 @@ public:
|
|||||||
ConcurrentG1Refine* cg1r) :
|
ConcurrentG1Refine* cg1r) :
|
||||||
_sts(sts), _g1rs(g1rs), _cg1r(cg1r), _concurrent(true)
|
_sts(sts), _g1rs(g1rs), _cg1r(cg1r), _concurrent(true)
|
||||||
{}
|
{}
|
||||||
bool do_card_ptr(jbyte* card_ptr, int worker_i) {
|
bool do_card_ptr(jbyte* card_ptr, uint worker_i) {
|
||||||
bool oops_into_cset = _g1rs->refine_card(card_ptr, worker_i, false);
|
bool oops_into_cset = _g1rs->refine_card(card_ptr, worker_i, false);
|
||||||
// This path is executed by the concurrent refine or mutator threads,
|
// This path is executed by the concurrent refine or mutator threads,
|
||||||
// concurrently, and so we do not care if card_ptr contains references
|
// concurrently, and so we do not care if card_ptr contains references
|
||||||
@ -131,7 +131,7 @@ public:
|
|||||||
{
|
{
|
||||||
for (int i = 0; i < 256; i++) _histo[i] = 0;
|
for (int i = 0; i < 256; i++) _histo[i] = 0;
|
||||||
}
|
}
|
||||||
bool do_card_ptr(jbyte* card_ptr, int worker_i) {
|
bool do_card_ptr(jbyte* card_ptr, uint worker_i) {
|
||||||
if (_g1h->is_in_reserved(_ctbs->addr_for(card_ptr))) {
|
if (_g1h->is_in_reserved(_ctbs->addr_for(card_ptr))) {
|
||||||
_calls++;
|
_calls++;
|
||||||
unsigned char* ujb = (unsigned char*)card_ptr;
|
unsigned char* ujb = (unsigned char*)card_ptr;
|
||||||
@ -160,7 +160,7 @@ public:
|
|||||||
RedirtyLoggedCardTableEntryClosure() :
|
RedirtyLoggedCardTableEntryClosure() :
|
||||||
_calls(0), _g1h(G1CollectedHeap::heap()), _ctbs(_g1h->g1_barrier_set()) {}
|
_calls(0), _g1h(G1CollectedHeap::heap()), _ctbs(_g1h->g1_barrier_set()) {}
|
||||||
|
|
||||||
bool do_card_ptr(jbyte* card_ptr, int worker_i) {
|
bool do_card_ptr(jbyte* card_ptr, uint worker_i) {
|
||||||
if (_g1h->is_in_reserved(_ctbs->addr_for(card_ptr))) {
|
if (_g1h->is_in_reserved(_ctbs->addr_for(card_ptr))) {
|
||||||
_calls++;
|
_calls++;
|
||||||
*card_ptr = 0;
|
*card_ptr = 0;
|
||||||
@ -1288,7 +1288,7 @@ bool G1CollectedHeap::do_collection(bool explicit_gc,
|
|||||||
print_heap_before_gc();
|
print_heap_before_gc();
|
||||||
trace_heap_before_gc(gc_tracer);
|
trace_heap_before_gc(gc_tracer);
|
||||||
|
|
||||||
size_t metadata_prev_used = MetaspaceAux::allocated_used_bytes();
|
size_t metadata_prev_used = MetaspaceAux::used_bytes();
|
||||||
|
|
||||||
verify_region_sets_optional();
|
verify_region_sets_optional();
|
||||||
|
|
||||||
@ -2314,7 +2314,7 @@ void G1CollectedHeap::check_gc_time_stamps() {
|
|||||||
void G1CollectedHeap::iterate_dirty_card_closure(CardTableEntryClosure* cl,
|
void G1CollectedHeap::iterate_dirty_card_closure(CardTableEntryClosure* cl,
|
||||||
DirtyCardQueue* into_cset_dcq,
|
DirtyCardQueue* into_cset_dcq,
|
||||||
bool concurrent,
|
bool concurrent,
|
||||||
int worker_i) {
|
uint worker_i) {
|
||||||
// Clean cards in the hot card cache
|
// Clean cards in the hot card cache
|
||||||
G1HotCardCache* hot_card_cache = _cg1r->hot_card_cache();
|
G1HotCardCache* hot_card_cache = _cg1r->hot_card_cache();
|
||||||
hot_card_cache->drain(worker_i, g1_rem_set(), into_cset_dcq);
|
hot_card_cache->drain(worker_i, g1_rem_set(), into_cset_dcq);
|
||||||
@ -2843,7 +2843,7 @@ void G1CollectedHeap::clear_cset_start_regions() {
|
|||||||
|
|
||||||
// Given the id of a worker, obtain or calculate a suitable
|
// Given the id of a worker, obtain or calculate a suitable
|
||||||
// starting region for iterating over the current collection set.
|
// starting region for iterating over the current collection set.
|
||||||
HeapRegion* G1CollectedHeap::start_cset_region_for_worker(int worker_i) {
|
HeapRegion* G1CollectedHeap::start_cset_region_for_worker(uint worker_i) {
|
||||||
assert(get_gc_time_stamp() > 0, "should have been updated by now");
|
assert(get_gc_time_stamp() > 0, "should have been updated by now");
|
||||||
|
|
||||||
HeapRegion* result = NULL;
|
HeapRegion* result = NULL;
|
||||||
@ -5103,7 +5103,7 @@ g1_process_strong_roots(bool is_scavenging,
|
|||||||
OopClosure* scan_non_heap_roots,
|
OopClosure* scan_non_heap_roots,
|
||||||
OopsInHeapRegionClosure* scan_rs,
|
OopsInHeapRegionClosure* scan_rs,
|
||||||
G1KlassScanClosure* scan_klasses,
|
G1KlassScanClosure* scan_klasses,
|
||||||
int worker_i) {
|
uint worker_i) {
|
||||||
|
|
||||||
// First scan the strong roots
|
// First scan the strong roots
|
||||||
double ext_roots_start = os::elapsedTime();
|
double ext_roots_start = os::elapsedTime();
|
||||||
@ -5207,10 +5207,10 @@ public:
|
|||||||
|
|
||||||
~G1StringSymbolTableUnlinkTask() {
|
~G1StringSymbolTableUnlinkTask() {
|
||||||
guarantee(!_process_strings || !_do_in_parallel || StringTable::parallel_claimed_index() >= _initial_string_table_size,
|
guarantee(!_process_strings || !_do_in_parallel || StringTable::parallel_claimed_index() >= _initial_string_table_size,
|
||||||
err_msg("claim value "INT32_FORMAT" after unlink less than initial string table size "INT32_FORMAT,
|
err_msg("claim value %d after unlink less than initial string table size %d",
|
||||||
StringTable::parallel_claimed_index(), _initial_string_table_size));
|
StringTable::parallel_claimed_index(), _initial_string_table_size));
|
||||||
guarantee(!_process_symbols || !_do_in_parallel || SymbolTable::parallel_claimed_index() >= _initial_symbol_table_size,
|
guarantee(!_process_symbols || !_do_in_parallel || SymbolTable::parallel_claimed_index() >= _initial_symbol_table_size,
|
||||||
err_msg("claim value "INT32_FORMAT" after unlink less than initial symbol table size "INT32_FORMAT,
|
err_msg("claim value %d after unlink less than initial symbol table size %d",
|
||||||
SymbolTable::parallel_claimed_index(), _initial_symbol_table_size));
|
SymbolTable::parallel_claimed_index(), _initial_symbol_table_size));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -5275,7 +5275,7 @@ void G1CollectedHeap::unlink_string_and_symbol_table(BoolObjectClosure* is_alive
|
|||||||
|
|
||||||
class RedirtyLoggedCardTableEntryFastClosure : public CardTableEntryClosure {
|
class RedirtyLoggedCardTableEntryFastClosure : public CardTableEntryClosure {
|
||||||
public:
|
public:
|
||||||
bool do_card_ptr(jbyte* card_ptr, int worker_i) {
|
bool do_card_ptr(jbyte* card_ptr, uint worker_i) {
|
||||||
*card_ptr = CardTableModRefBS::dirty_card_val();
|
*card_ptr = CardTableModRefBS::dirty_card_val();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -845,7 +845,7 @@ protected:
|
|||||||
OopClosure* scan_non_heap_roots,
|
OopClosure* scan_non_heap_roots,
|
||||||
OopsInHeapRegionClosure* scan_rs,
|
OopsInHeapRegionClosure* scan_rs,
|
||||||
G1KlassScanClosure* scan_klasses,
|
G1KlassScanClosure* scan_klasses,
|
||||||
int worker_i);
|
uint worker_i);
|
||||||
|
|
||||||
// Notifies all the necessary spaces that the committed space has
|
// Notifies all the necessary spaces that the committed space has
|
||||||
// been updated (either expanded or shrunk). It should be called
|
// been updated (either expanded or shrunk). It should be called
|
||||||
@ -1139,7 +1139,7 @@ public:
|
|||||||
|
|
||||||
void iterate_dirty_card_closure(CardTableEntryClosure* cl,
|
void iterate_dirty_card_closure(CardTableEntryClosure* cl,
|
||||||
DirtyCardQueue* into_cset_dcq,
|
DirtyCardQueue* into_cset_dcq,
|
||||||
bool concurrent, int worker_i);
|
bool concurrent, uint worker_i);
|
||||||
|
|
||||||
// The shared block offset table array.
|
// The shared block offset table array.
|
||||||
G1BlockOffsetSharedArray* bot_shared() const { return _bot_shared; }
|
G1BlockOffsetSharedArray* bot_shared() const { return _bot_shared; }
|
||||||
@ -1370,7 +1370,7 @@ public:
|
|||||||
|
|
||||||
// Given the id of a worker, obtain or calculate a suitable
|
// Given the id of a worker, obtain or calculate a suitable
|
||||||
// starting region for iterating over the current collection set.
|
// starting region for iterating over the current collection set.
|
||||||
HeapRegion* start_cset_region_for_worker(int worker_i);
|
HeapRegion* start_cset_region_for_worker(uint worker_i);
|
||||||
|
|
||||||
// This is a convenience method that is used by the
|
// This is a convenience method that is used by the
|
||||||
// HeapRegionIterator classes to calculate the starting region for
|
// HeapRegionIterator classes to calculate the starting region for
|
||||||
|
@ -1204,7 +1204,7 @@ void G1CollectorPolicy::record_heap_size_info_at_start(bool full) {
|
|||||||
(_young_list_target_length * HeapRegion::GrainBytes) - _survivor_used_bytes_before_gc;
|
(_young_list_target_length * HeapRegion::GrainBytes) - _survivor_used_bytes_before_gc;
|
||||||
|
|
||||||
if (full) {
|
if (full) {
|
||||||
_metaspace_used_bytes_before_gc = MetaspaceAux::allocated_used_bytes();
|
_metaspace_used_bytes_before_gc = MetaspaceAux::used_bytes();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -147,7 +147,7 @@ template <class T>
|
|||||||
void WorkerDataArray<T>::verify() {
|
void WorkerDataArray<T>::verify() {
|
||||||
for (uint i = 0; i < _length; i++) {
|
for (uint i = 0; i < _length; i++) {
|
||||||
assert(_data[i] != _uninitialized,
|
assert(_data[i] != _uninitialized,
|
||||||
err_msg("Invalid data for worker " UINT32_FORMAT ", data: %lf, uninitialized: %lf",
|
err_msg("Invalid data for worker %u, data: %lf, uninitialized: %lf",
|
||||||
i, (double)_data[i], (double)_uninitialized));
|
i, (double)_data[i], (double)_uninitialized));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -246,8 +246,8 @@ void G1GCPhaseTimes::print_stats(int level, const char* str, double value) {
|
|||||||
LineBuffer(level).append_and_print_cr("[%s: %.1lf ms]", str, value);
|
LineBuffer(level).append_and_print_cr("[%s: %.1lf ms]", str, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
void G1GCPhaseTimes::print_stats(int level, const char* str, double value, int workers) {
|
void G1GCPhaseTimes::print_stats(int level, const char* str, double value, uint workers) {
|
||||||
LineBuffer(level).append_and_print_cr("[%s: %.1lf ms, GC Workers: %d]", str, value, workers);
|
LineBuffer(level).append_and_print_cr("[%s: %.1lf ms, GC Workers: %u]", str, value, workers);
|
||||||
}
|
}
|
||||||
|
|
||||||
double G1GCPhaseTimes::accounted_time_ms() {
|
double G1GCPhaseTimes::accounted_time_ms() {
|
||||||
|
@ -161,7 +161,7 @@ class G1GCPhaseTimes : public CHeapObj<mtGC> {
|
|||||||
|
|
||||||
// Helper methods for detailed logging
|
// Helper methods for detailed logging
|
||||||
void print_stats(int level, const char* str, double value);
|
void print_stats(int level, const char* str, double value);
|
||||||
void print_stats(int level, const char* str, double value, int workers);
|
void print_stats(int level, const char* str, double value, uint workers);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
G1GCPhaseTimes(uint max_gc_threads);
|
G1GCPhaseTimes(uint max_gc_threads);
|
||||||
|
@ -44,9 +44,9 @@ void G1HotCardCache::initialize() {
|
|||||||
_hot_cache_idx = 0;
|
_hot_cache_idx = 0;
|
||||||
|
|
||||||
// For refining the cards in the hot cache in parallel
|
// For refining the cards in the hot cache in parallel
|
||||||
int n_workers = (ParallelGCThreads > 0 ?
|
uint n_workers = (ParallelGCThreads > 0 ?
|
||||||
_g1h->workers()->total_workers() : 1);
|
_g1h->workers()->total_workers() : 1);
|
||||||
_hot_cache_par_chunk_size = MAX2(1, _hot_cache_size / n_workers);
|
_hot_cache_par_chunk_size = MAX2(1, _hot_cache_size / (int)n_workers);
|
||||||
_hot_cache_par_claimed_idx = 0;
|
_hot_cache_par_claimed_idx = 0;
|
||||||
|
|
||||||
_card_counts.initialize();
|
_card_counts.initialize();
|
||||||
@ -89,7 +89,7 @@ jbyte* G1HotCardCache::insert(jbyte* card_ptr) {
|
|||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
void G1HotCardCache::drain(int worker_i,
|
void G1HotCardCache::drain(uint worker_i,
|
||||||
G1RemSet* g1rs,
|
G1RemSet* g1rs,
|
||||||
DirtyCardQueue* into_cset_dcq) {
|
DirtyCardQueue* into_cset_dcq) {
|
||||||
if (!default_use_cache()) {
|
if (!default_use_cache()) {
|
||||||
@ -122,8 +122,8 @@ void G1HotCardCache::drain(int worker_i,
|
|||||||
// RSet updating while within an evacuation pause.
|
// RSet updating while within an evacuation pause.
|
||||||
// In this case worker_i should be the id of a GC worker thread
|
// In this case worker_i should be the id of a GC worker thread
|
||||||
assert(SafepointSynchronize::is_at_safepoint(), "Should be at a safepoint");
|
assert(SafepointSynchronize::is_at_safepoint(), "Should be at a safepoint");
|
||||||
assert(worker_i < (int) (ParallelGCThreads == 0 ? 1 : ParallelGCThreads),
|
assert(worker_i < (ParallelGCThreads == 0 ? 1 : ParallelGCThreads),
|
||||||
err_msg("incorrect worker id: "INT32_FORMAT, worker_i));
|
err_msg("incorrect worker id: %u", worker_i));
|
||||||
|
|
||||||
into_cset_dcq->enqueue(card_ptr);
|
into_cset_dcq->enqueue(card_ptr);
|
||||||
}
|
}
|
||||||
|
@ -99,7 +99,7 @@ class G1HotCardCache: public CHeapObj<mtGC> {
|
|||||||
|
|
||||||
// Refine the cards that have delayed as a result of
|
// Refine the cards that have delayed as a result of
|
||||||
// being in the cache.
|
// being in the cache.
|
||||||
void drain(int worker_i, G1RemSet* g1rs, DirtyCardQueue* into_cset_dcq);
|
void drain(uint worker_i, G1RemSet* g1rs, DirtyCardQueue* into_cset_dcq);
|
||||||
|
|
||||||
// Set up for parallel processing of the cards in the hot cache
|
// Set up for parallel processing of the cards in the hot cache
|
||||||
void reset_hot_cache_claimed_index() {
|
void reset_hot_cache_claimed_index() {
|
||||||
|
@ -234,14 +234,14 @@ class G1UpdateRSOrPushRefOopClosure: public ExtendedOopClosure {
|
|||||||
HeapRegion* _from;
|
HeapRegion* _from;
|
||||||
OopsInHeapRegionClosure* _push_ref_cl;
|
OopsInHeapRegionClosure* _push_ref_cl;
|
||||||
bool _record_refs_into_cset;
|
bool _record_refs_into_cset;
|
||||||
int _worker_i;
|
uint _worker_i;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
G1UpdateRSOrPushRefOopClosure(G1CollectedHeap* g1h,
|
G1UpdateRSOrPushRefOopClosure(G1CollectedHeap* g1h,
|
||||||
G1RemSet* rs,
|
G1RemSet* rs,
|
||||||
OopsInHeapRegionClosure* push_ref_cl,
|
OopsInHeapRegionClosure* push_ref_cl,
|
||||||
bool record_refs_into_cset,
|
bool record_refs_into_cset,
|
||||||
int worker_i = 0);
|
uint worker_i = 0);
|
||||||
|
|
||||||
void set_from(HeapRegion* from) {
|
void set_from(HeapRegion* from) {
|
||||||
assert(from != NULL, "from region must be non-NULL");
|
assert(from != NULL, "from region must be non-NULL");
|
||||||
|
@ -113,14 +113,14 @@ class ScanRSClosure : public HeapRegionClosure {
|
|||||||
G1SATBCardTableModRefBS *_ct_bs;
|
G1SATBCardTableModRefBS *_ct_bs;
|
||||||
|
|
||||||
double _strong_code_root_scan_time_sec;
|
double _strong_code_root_scan_time_sec;
|
||||||
int _worker_i;
|
uint _worker_i;
|
||||||
int _block_size;
|
int _block_size;
|
||||||
bool _try_claimed;
|
bool _try_claimed;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
ScanRSClosure(OopsInHeapRegionClosure* oc,
|
ScanRSClosure(OopsInHeapRegionClosure* oc,
|
||||||
CodeBlobToOopClosure* code_root_cl,
|
CodeBlobToOopClosure* code_root_cl,
|
||||||
int worker_i) :
|
uint worker_i) :
|
||||||
_oc(oc),
|
_oc(oc),
|
||||||
_code_root_cl(code_root_cl),
|
_code_root_cl(code_root_cl),
|
||||||
_strong_code_root_scan_time_sec(0.0),
|
_strong_code_root_scan_time_sec(0.0),
|
||||||
@ -162,7 +162,7 @@ public:
|
|||||||
|
|
||||||
void printCard(HeapRegion* card_region, size_t card_index,
|
void printCard(HeapRegion* card_region, size_t card_index,
|
||||||
HeapWord* card_start) {
|
HeapWord* card_start) {
|
||||||
gclog_or_tty->print_cr("T %d Region [" PTR_FORMAT ", " PTR_FORMAT ") "
|
gclog_or_tty->print_cr("T %u Region [" PTR_FORMAT ", " PTR_FORMAT ") "
|
||||||
"RS names card %p: "
|
"RS names card %p: "
|
||||||
"[" PTR_FORMAT ", " PTR_FORMAT ")",
|
"[" PTR_FORMAT ", " PTR_FORMAT ")",
|
||||||
_worker_i,
|
_worker_i,
|
||||||
@ -241,7 +241,7 @@ public:
|
|||||||
|
|
||||||
void G1RemSet::scanRS(OopsInHeapRegionClosure* oc,
|
void G1RemSet::scanRS(OopsInHeapRegionClosure* oc,
|
||||||
CodeBlobToOopClosure* code_root_cl,
|
CodeBlobToOopClosure* code_root_cl,
|
||||||
int worker_i) {
|
uint worker_i) {
|
||||||
double rs_time_start = os::elapsedTime();
|
double rs_time_start = os::elapsedTime();
|
||||||
HeapRegion *startRegion = _g1->start_cset_region_for_worker(worker_i);
|
HeapRegion *startRegion = _g1->start_cset_region_for_worker(worker_i);
|
||||||
|
|
||||||
@ -274,13 +274,13 @@ public:
|
|||||||
DirtyCardQueue* into_cset_dcq) :
|
DirtyCardQueue* into_cset_dcq) :
|
||||||
_g1rs(g1h->g1_rem_set()), _into_cset_dcq(into_cset_dcq)
|
_g1rs(g1h->g1_rem_set()), _into_cset_dcq(into_cset_dcq)
|
||||||
{}
|
{}
|
||||||
bool do_card_ptr(jbyte* card_ptr, int worker_i) {
|
bool do_card_ptr(jbyte* card_ptr, uint worker_i) {
|
||||||
// The only time we care about recording cards that
|
// The only time we care about recording cards that
|
||||||
// contain references that point into the collection set
|
// contain references that point into the collection set
|
||||||
// is during RSet updating within an evacuation pause.
|
// is during RSet updating within an evacuation pause.
|
||||||
// In this case worker_i should be the id of a GC worker thread.
|
// In this case worker_i should be the id of a GC worker thread.
|
||||||
assert(SafepointSynchronize::is_at_safepoint(), "not during an evacuation pause");
|
assert(SafepointSynchronize::is_at_safepoint(), "not during an evacuation pause");
|
||||||
assert(worker_i < (int) (ParallelGCThreads == 0 ? 1 : ParallelGCThreads), "should be a GC worker");
|
assert(worker_i < (ParallelGCThreads == 0 ? 1 : ParallelGCThreads), "should be a GC worker");
|
||||||
|
|
||||||
if (_g1rs->refine_card(card_ptr, worker_i, true)) {
|
if (_g1rs->refine_card(card_ptr, worker_i, true)) {
|
||||||
// 'card_ptr' contains references that point into the collection
|
// 'card_ptr' contains references that point into the collection
|
||||||
@ -295,7 +295,7 @@ public:
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
void G1RemSet::updateRS(DirtyCardQueue* into_cset_dcq, int worker_i) {
|
void G1RemSet::updateRS(DirtyCardQueue* into_cset_dcq, uint worker_i) {
|
||||||
double start = os::elapsedTime();
|
double start = os::elapsedTime();
|
||||||
// Apply the given closure to all remaining log entries.
|
// Apply the given closure to all remaining log entries.
|
||||||
RefineRecordRefsIntoCSCardTableEntryClosure into_cset_update_rs_cl(_g1, into_cset_dcq);
|
RefineRecordRefsIntoCSCardTableEntryClosure into_cset_update_rs_cl(_g1, into_cset_dcq);
|
||||||
@ -320,14 +320,14 @@ void G1RemSet::cleanupHRRS() {
|
|||||||
|
|
||||||
void G1RemSet::oops_into_collection_set_do(OopsInHeapRegionClosure* oc,
|
void G1RemSet::oops_into_collection_set_do(OopsInHeapRegionClosure* oc,
|
||||||
CodeBlobToOopClosure* code_root_cl,
|
CodeBlobToOopClosure* code_root_cl,
|
||||||
int worker_i) {
|
uint worker_i) {
|
||||||
#if CARD_REPEAT_HISTO
|
#if CARD_REPEAT_HISTO
|
||||||
ct_freq_update_histo_and_reset();
|
ct_freq_update_histo_and_reset();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// We cache the value of 'oc' closure into the appropriate slot in the
|
// We cache the value of 'oc' closure into the appropriate slot in the
|
||||||
// _cset_rs_update_cl for this worker
|
// _cset_rs_update_cl for this worker
|
||||||
assert(worker_i < (int)n_workers(), "sanity");
|
assert(worker_i < n_workers(), "sanity");
|
||||||
_cset_rs_update_cl[worker_i] = oc;
|
_cset_rs_update_cl[worker_i] = oc;
|
||||||
|
|
||||||
// A DirtyCardQueue that is used to hold cards containing references
|
// A DirtyCardQueue that is used to hold cards containing references
|
||||||
@ -399,7 +399,7 @@ public:
|
|||||||
_g1(g1), _ct_bs(bs)
|
_g1(g1), _ct_bs(bs)
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
bool do_card_ptr(jbyte* card_ptr, int worker_i) {
|
bool do_card_ptr(jbyte* card_ptr, uint worker_i) {
|
||||||
// Construct the region representing the card.
|
// Construct the region representing the card.
|
||||||
HeapWord* start = _ct_bs->addr_for(card_ptr);
|
HeapWord* start = _ct_bs->addr_for(card_ptr);
|
||||||
// And find the region containing it.
|
// And find the region containing it.
|
||||||
@ -543,7 +543,7 @@ G1UpdateRSOrPushRefOopClosure(G1CollectedHeap* g1h,
|
|||||||
G1RemSet* rs,
|
G1RemSet* rs,
|
||||||
OopsInHeapRegionClosure* push_ref_cl,
|
OopsInHeapRegionClosure* push_ref_cl,
|
||||||
bool record_refs_into_cset,
|
bool record_refs_into_cset,
|
||||||
int worker_i) :
|
uint worker_i) :
|
||||||
_g1(g1h), _g1_rem_set(rs), _from(NULL),
|
_g1(g1h), _g1_rem_set(rs), _from(NULL),
|
||||||
_record_refs_into_cset(record_refs_into_cset),
|
_record_refs_into_cset(record_refs_into_cset),
|
||||||
_push_ref_cl(push_ref_cl), _worker_i(worker_i) { }
|
_push_ref_cl(push_ref_cl), _worker_i(worker_i) { }
|
||||||
@ -552,7 +552,7 @@ G1UpdateRSOrPushRefOopClosure(G1CollectedHeap* g1h,
|
|||||||
// into the collection set, if we're checking for such references;
|
// into the collection set, if we're checking for such references;
|
||||||
// false otherwise.
|
// false otherwise.
|
||||||
|
|
||||||
bool G1RemSet::refine_card(jbyte* card_ptr, int worker_i,
|
bool G1RemSet::refine_card(jbyte* card_ptr, uint worker_i,
|
||||||
bool check_for_refs_into_cset) {
|
bool check_for_refs_into_cset) {
|
||||||
|
|
||||||
// If the card is no longer dirty, nothing to do.
|
// If the card is no longer dirty, nothing to do.
|
||||||
|
@ -97,7 +97,7 @@ public:
|
|||||||
// In the sequential case this param will be ignored.
|
// In the sequential case this param will be ignored.
|
||||||
void oops_into_collection_set_do(OopsInHeapRegionClosure* blk,
|
void oops_into_collection_set_do(OopsInHeapRegionClosure* blk,
|
||||||
CodeBlobToOopClosure* code_root_cl,
|
CodeBlobToOopClosure* code_root_cl,
|
||||||
int worker_i);
|
uint worker_i);
|
||||||
|
|
||||||
// Prepare for and cleanup after an oops_into_collection_set_do
|
// Prepare for and cleanup after an oops_into_collection_set_do
|
||||||
// call. Must call each of these once before and after (in sequential
|
// call. Must call each of these once before and after (in sequential
|
||||||
@ -109,9 +109,9 @@ public:
|
|||||||
|
|
||||||
void scanRS(OopsInHeapRegionClosure* oc,
|
void scanRS(OopsInHeapRegionClosure* oc,
|
||||||
CodeBlobToOopClosure* code_root_cl,
|
CodeBlobToOopClosure* code_root_cl,
|
||||||
int worker_i);
|
uint worker_i);
|
||||||
|
|
||||||
void updateRS(DirtyCardQueue* into_cset_dcq, int worker_i);
|
void updateRS(DirtyCardQueue* into_cset_dcq, uint worker_i);
|
||||||
|
|
||||||
CardTableModRefBS* ct_bs() { return _ct_bs; }
|
CardTableModRefBS* ct_bs() { return _ct_bs; }
|
||||||
size_t cardsScanned() { return _total_cards_scanned; }
|
size_t cardsScanned() { return _total_cards_scanned; }
|
||||||
@ -138,7 +138,7 @@ public:
|
|||||||
// if the given card contains oops that have references into the
|
// if the given card contains oops that have references into the
|
||||||
// current collection set.
|
// current collection set.
|
||||||
virtual bool refine_card(jbyte* card_ptr,
|
virtual bool refine_card(jbyte* card_ptr,
|
||||||
int worker_i,
|
uint worker_i,
|
||||||
bool check_for_refs_into_cset);
|
bool check_for_refs_into_cset);
|
||||||
|
|
||||||
// Print accumulated summary info from the start of the VM.
|
// Print accumulated summary info from the start of the VM.
|
||||||
@ -171,12 +171,12 @@ public:
|
|||||||
class UpdateRSOopClosure: public ExtendedOopClosure {
|
class UpdateRSOopClosure: public ExtendedOopClosure {
|
||||||
HeapRegion* _from;
|
HeapRegion* _from;
|
||||||
G1RemSet* _rs;
|
G1RemSet* _rs;
|
||||||
int _worker_i;
|
uint _worker_i;
|
||||||
|
|
||||||
template <class T> void do_oop_work(T* p);
|
template <class T> void do_oop_work(T* p);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
UpdateRSOopClosure(G1RemSet* rs, int worker_i = 0) :
|
UpdateRSOopClosure(G1RemSet* rs, uint worker_i = 0) :
|
||||||
_from(NULL), _rs(rs), _worker_i(worker_i)
|
_from(NULL), _rs(rs), _worker_i(worker_i)
|
||||||
{}
|
{}
|
||||||
|
|
||||||
|
@ -390,7 +390,7 @@ void FromCardCache::shrink(uint new_num_regions) {
|
|||||||
void FromCardCache::print(outputStream* out) {
|
void FromCardCache::print(outputStream* out) {
|
||||||
for (uint i = 0; i < HeapRegionRemSet::num_par_rem_sets(); i++) {
|
for (uint i = 0; i < HeapRegionRemSet::num_par_rem_sets(); i++) {
|
||||||
for (uint j = 0; j < _max_regions; j++) {
|
for (uint j = 0; j < _max_regions; j++) {
|
||||||
out->print_cr("_from_card_cache["UINT32_FORMAT"]["UINT32_FORMAT"] = "INT32_FORMAT".",
|
out->print_cr("_from_card_cache[%u][%u] = %d.",
|
||||||
i, j, at(i, j));
|
i, j, at(i, j));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -430,7 +430,7 @@ void OtherRegionsTable::add_reference(OopOrNarrowOopStar from, int tid) {
|
|||||||
int from_card = (int)(uintptr_t(from) >> CardTableModRefBS::card_shift);
|
int from_card = (int)(uintptr_t(from) >> CardTableModRefBS::card_shift);
|
||||||
|
|
||||||
if (G1TraceHeapRegionRememberedSet) {
|
if (G1TraceHeapRegionRememberedSet) {
|
||||||
gclog_or_tty->print_cr("Table for [" PTR_FORMAT "...): card %d (cache = "INT32_FORMAT")",
|
gclog_or_tty->print_cr("Table for [" PTR_FORMAT "...): card %d (cache = %d)",
|
||||||
hr()->bottom(), from_card,
|
hr()->bottom(), from_card,
|
||||||
FromCardCache::at((uint)tid, cur_hrs_ind));
|
FromCardCache::at((uint)tid, cur_hrs_ind));
|
||||||
}
|
}
|
||||||
@ -853,13 +853,13 @@ OtherRegionsTable::do_cleanup_work(HRRSCleanupTask* hrrs_cleanup_task) {
|
|||||||
// This can be done by either mutator threads together with the
|
// This can be done by either mutator threads together with the
|
||||||
// concurrent refinement threads or GC threads.
|
// concurrent refinement threads or GC threads.
|
||||||
uint HeapRegionRemSet::num_par_rem_sets() {
|
uint HeapRegionRemSet::num_par_rem_sets() {
|
||||||
return (uint)MAX2(DirtyCardQueueSet::num_par_ids() + ConcurrentG1Refine::thread_num(), ParallelGCThreads);
|
return MAX2(DirtyCardQueueSet::num_par_ids() + ConcurrentG1Refine::thread_num(), (uint)ParallelGCThreads);
|
||||||
}
|
}
|
||||||
|
|
||||||
HeapRegionRemSet::HeapRegionRemSet(G1BlockOffsetSharedArray* bosa,
|
HeapRegionRemSet::HeapRegionRemSet(G1BlockOffsetSharedArray* bosa,
|
||||||
HeapRegion* hr)
|
HeapRegion* hr)
|
||||||
: _bosa(bosa),
|
: _bosa(bosa),
|
||||||
_m(Mutex::leaf, FormatBuffer<128>("HeapRegionRemSet lock #"UINT32_FORMAT, hr->hrs_index()), true),
|
_m(Mutex::leaf, FormatBuffer<128>("HeapRegionRemSet lock #%u", hr->hrs_index()), true),
|
||||||
_code_roots(), _other_regions(hr, &_m) {
|
_code_roots(), _other_regions(hr, &_m) {
|
||||||
reset_for_par_iteration();
|
reset_for_par_iteration();
|
||||||
}
|
}
|
||||||
|
@ -30,7 +30,7 @@
|
|||||||
inline void HeapRegionSetBase::add(HeapRegion* hr) {
|
inline void HeapRegionSetBase::add(HeapRegion* hr) {
|
||||||
check_mt_safety();
|
check_mt_safety();
|
||||||
assert(hr->containing_set() == NULL, hrs_ext_msg(this, "should not already have a containing set %u"));
|
assert(hr->containing_set() == NULL, hrs_ext_msg(this, "should not already have a containing set %u"));
|
||||||
assert(hr->next() == NULL, hrs_ext_msg(this, "should not already be linked"));
|
assert(hr->next() == NULL && hr->prev() == NULL, hrs_ext_msg(this, "should not already be linked"));
|
||||||
|
|
||||||
_count.increment(1u, hr->capacity());
|
_count.increment(1u, hr->capacity());
|
||||||
hr->set_containing_set(this);
|
hr->set_containing_set(this);
|
||||||
@ -40,7 +40,7 @@ inline void HeapRegionSetBase::add(HeapRegion* hr) {
|
|||||||
inline void HeapRegionSetBase::remove(HeapRegion* hr) {
|
inline void HeapRegionSetBase::remove(HeapRegion* hr) {
|
||||||
check_mt_safety();
|
check_mt_safety();
|
||||||
verify_region(hr);
|
verify_region(hr);
|
||||||
assert(hr->next() == NULL, hrs_ext_msg(this, "should already be unlinked"));
|
assert(hr->next() == NULL && hr->prev() == NULL, hrs_ext_msg(this, "should already be unlinked"));
|
||||||
|
|
||||||
hr->set_containing_set(NULL);
|
hr->set_containing_set(NULL);
|
||||||
assert(_count.length() > 0, hrs_ext_msg(this, "pre-condition"));
|
assert(_count.length() > 0, hrs_ext_msg(this, "pre-condition"));
|
||||||
|
@ -290,7 +290,7 @@ void SATBMarkQueueSet::iterate_closure_all_threads() {
|
|||||||
shared_satb_queue()->apply_closure_and_empty(_closure);
|
shared_satb_queue()->apply_closure_and_empty(_closure);
|
||||||
}
|
}
|
||||||
|
|
||||||
void SATBMarkQueueSet::par_iterate_closure_all_threads(int worker) {
|
void SATBMarkQueueSet::par_iterate_closure_all_threads(uint worker) {
|
||||||
SharedHeap* sh = SharedHeap::heap();
|
SharedHeap* sh = SharedHeap::heap();
|
||||||
int parity = sh->strong_roots_parity();
|
int parity = sh->strong_roots_parity();
|
||||||
|
|
||||||
@ -315,7 +315,7 @@ void SATBMarkQueueSet::par_iterate_closure_all_threads(int worker) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool SATBMarkQueueSet::apply_closure_to_completed_buffer_work(bool par,
|
bool SATBMarkQueueSet::apply_closure_to_completed_buffer_work(bool par,
|
||||||
int worker) {
|
uint worker) {
|
||||||
BufferNode* nd = NULL;
|
BufferNode* nd = NULL;
|
||||||
{
|
{
|
||||||
MutexLockerEx x(_cbl_mon, Mutex::_no_safepoint_check_flag);
|
MutexLockerEx x(_cbl_mon, Mutex::_no_safepoint_check_flag);
|
||||||
|
@ -84,7 +84,7 @@ class SATBMarkQueueSet: public PtrQueueSet {
|
|||||||
// Utility function to support sequential and parallel versions. If
|
// Utility function to support sequential and parallel versions. If
|
||||||
// "par" is true, then "worker" is the par thread id; if "false", worker
|
// "par" is true, then "worker" is the par thread id; if "false", worker
|
||||||
// is ignored.
|
// is ignored.
|
||||||
bool apply_closure_to_completed_buffer_work(bool par, int worker);
|
bool apply_closure_to_completed_buffer_work(bool par, uint worker);
|
||||||
|
|
||||||
#ifdef ASSERT
|
#ifdef ASSERT
|
||||||
void dump_active_states(bool expected_active);
|
void dump_active_states(bool expected_active);
|
||||||
@ -124,7 +124,7 @@ public:
|
|||||||
// be called serially and at a safepoint.
|
// be called serially and at a safepoint.
|
||||||
void iterate_closure_all_threads();
|
void iterate_closure_all_threads();
|
||||||
// Parallel version of the above.
|
// Parallel version of the above.
|
||||||
void par_iterate_closure_all_threads(int worker);
|
void par_iterate_closure_all_threads(uint worker);
|
||||||
|
|
||||||
// If there exists some completed buffer, pop it, then apply the
|
// If there exists some completed buffer, pop it, then apply the
|
||||||
// registered closure to all its elements, and return true. If no
|
// registered closure to all its elements, and return true. If no
|
||||||
@ -133,7 +133,7 @@ public:
|
|||||||
return apply_closure_to_completed_buffer_work(false, 0);
|
return apply_closure_to_completed_buffer_work(false, 0);
|
||||||
}
|
}
|
||||||
// Parallel version of the above.
|
// Parallel version of the above.
|
||||||
bool par_apply_closure_to_completed_buffer(int worker) {
|
bool par_apply_closure_to_completed_buffer(uint worker) {
|
||||||
return apply_closure_to_completed_buffer_work(true, worker);
|
return apply_closure_to_completed_buffer_work(true, worker);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -184,7 +184,7 @@ bool PSMarkSweep::invoke_no_policy(bool clear_all_softrefs) {
|
|||||||
size_t prev_used = heap->used();
|
size_t prev_used = heap->used();
|
||||||
|
|
||||||
// Capture metadata size before collection for sizing.
|
// Capture metadata size before collection for sizing.
|
||||||
size_t metadata_prev_used = MetaspaceAux::allocated_used_bytes();
|
size_t metadata_prev_used = MetaspaceAux::used_bytes();
|
||||||
|
|
||||||
// For PrintGCDetails
|
// For PrintGCDetails
|
||||||
size_t old_gen_prev_used = old_gen->used_in_bytes();
|
size_t old_gen_prev_used = old_gen->used_in_bytes();
|
||||||
|
@ -928,7 +928,7 @@ public:
|
|||||||
_heap_used = heap->used();
|
_heap_used = heap->used();
|
||||||
_young_gen_used = heap->young_gen()->used_in_bytes();
|
_young_gen_used = heap->young_gen()->used_in_bytes();
|
||||||
_old_gen_used = heap->old_gen()->used_in_bytes();
|
_old_gen_used = heap->old_gen()->used_in_bytes();
|
||||||
_metadata_used = MetaspaceAux::allocated_used_bytes();
|
_metadata_used = MetaspaceAux::used_bytes();
|
||||||
};
|
};
|
||||||
|
|
||||||
size_t heap_used() const { return _heap_used; }
|
size_t heap_used() const { return _heap_used; }
|
||||||
|
@ -62,16 +62,16 @@ public:
|
|||||||
};
|
};
|
||||||
|
|
||||||
class MetaspaceSizes : public StackObj {
|
class MetaspaceSizes : public StackObj {
|
||||||
size_t _capacity;
|
size_t _committed;
|
||||||
size_t _used;
|
size_t _used;
|
||||||
size_t _reserved;
|
size_t _reserved;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
MetaspaceSizes() : _capacity(0), _used(0), _reserved(0) {}
|
MetaspaceSizes() : _committed(0), _used(0), _reserved(0) {}
|
||||||
MetaspaceSizes(size_t capacity, size_t used, size_t reserved) :
|
MetaspaceSizes(size_t committed, size_t used, size_t reserved) :
|
||||||
_capacity(capacity), _used(used), _reserved(reserved) {}
|
_committed(committed), _used(used), _reserved(reserved) {}
|
||||||
|
|
||||||
size_t capacity() const { return _capacity; }
|
size_t committed() const { return _committed; }
|
||||||
size_t used() const { return _used; }
|
size_t used() const { return _used; }
|
||||||
size_t reserved() const { return _reserved; }
|
size_t reserved() const { return _reserved; }
|
||||||
};
|
};
|
||||||
|
@ -258,7 +258,7 @@ void GCTracer::send_gc_heap_summary_event(GCWhen::Type when, const GCHeapSummary
|
|||||||
static TraceStructMetaspaceSizes to_trace_struct(const MetaspaceSizes& sizes) {
|
static TraceStructMetaspaceSizes to_trace_struct(const MetaspaceSizes& sizes) {
|
||||||
TraceStructMetaspaceSizes meta_sizes;
|
TraceStructMetaspaceSizes meta_sizes;
|
||||||
|
|
||||||
meta_sizes.set_capacity(sizes.capacity());
|
meta_sizes.set_committed(sizes.committed());
|
||||||
meta_sizes.set_used(sizes.used());
|
meta_sizes.set_used(sizes.used());
|
||||||
meta_sizes.set_reserved(sizes.reserved());
|
meta_sizes.set_reserved(sizes.reserved());
|
||||||
|
|
||||||
|
@ -85,16 +85,16 @@ GCHeapSummary CollectedHeap::create_heap_summary() {
|
|||||||
|
|
||||||
MetaspaceSummary CollectedHeap::create_metaspace_summary() {
|
MetaspaceSummary CollectedHeap::create_metaspace_summary() {
|
||||||
const MetaspaceSizes meta_space(
|
const MetaspaceSizes meta_space(
|
||||||
MetaspaceAux::allocated_capacity_bytes(),
|
MetaspaceAux::committed_bytes(),
|
||||||
MetaspaceAux::allocated_used_bytes(),
|
MetaspaceAux::used_bytes(),
|
||||||
MetaspaceAux::reserved_bytes());
|
MetaspaceAux::reserved_bytes());
|
||||||
const MetaspaceSizes data_space(
|
const MetaspaceSizes data_space(
|
||||||
MetaspaceAux::allocated_capacity_bytes(Metaspace::NonClassType),
|
MetaspaceAux::committed_bytes(Metaspace::NonClassType),
|
||||||
MetaspaceAux::allocated_used_bytes(Metaspace::NonClassType),
|
MetaspaceAux::used_bytes(Metaspace::NonClassType),
|
||||||
MetaspaceAux::reserved_bytes(Metaspace::NonClassType));
|
MetaspaceAux::reserved_bytes(Metaspace::NonClassType));
|
||||||
const MetaspaceSizes class_space(
|
const MetaspaceSizes class_space(
|
||||||
MetaspaceAux::allocated_capacity_bytes(Metaspace::ClassType),
|
MetaspaceAux::committed_bytes(Metaspace::ClassType),
|
||||||
MetaspaceAux::allocated_used_bytes(Metaspace::ClassType),
|
MetaspaceAux::used_bytes(Metaspace::ClassType),
|
||||||
MetaspaceAux::reserved_bytes(Metaspace::ClassType));
|
MetaspaceAux::reserved_bytes(Metaspace::ClassType));
|
||||||
|
|
||||||
const MetaspaceChunkFreeListSummary& ms_chunk_free_list_summary =
|
const MetaspaceChunkFreeListSummary& ms_chunk_free_list_summary =
|
||||||
|
@ -257,6 +257,12 @@ void GenCollectorPolicy::assert_size_info() {
|
|||||||
assert(_min_gen0_size % _gen_alignment == 0, "_min_gen0_size alignment");
|
assert(_min_gen0_size % _gen_alignment == 0, "_min_gen0_size alignment");
|
||||||
assert(_initial_gen0_size % _gen_alignment == 0, "_initial_gen0_size alignment");
|
assert(_initial_gen0_size % _gen_alignment == 0, "_initial_gen0_size alignment");
|
||||||
assert(_max_gen0_size % _gen_alignment == 0, "_max_gen0_size alignment");
|
assert(_max_gen0_size % _gen_alignment == 0, "_max_gen0_size alignment");
|
||||||
|
assert(_min_gen0_size <= bound_minus_alignment(_min_gen0_size, _min_heap_byte_size),
|
||||||
|
"Ergonomics made minimum young generation larger than minimum heap");
|
||||||
|
assert(_initial_gen0_size <= bound_minus_alignment(_initial_gen0_size, _initial_heap_byte_size),
|
||||||
|
"Ergonomics made initial young generation larger than initial heap");
|
||||||
|
assert(_max_gen0_size <= bound_minus_alignment(_max_gen0_size, _max_heap_byte_size),
|
||||||
|
"Ergonomics made maximum young generation lager than maximum heap");
|
||||||
}
|
}
|
||||||
|
|
||||||
void TwoGenerationCollectorPolicy::assert_size_info() {
|
void TwoGenerationCollectorPolicy::assert_size_info() {
|
||||||
@ -267,6 +273,9 @@ void TwoGenerationCollectorPolicy::assert_size_info() {
|
|||||||
assert(_max_gen1_size % _gen_alignment == 0, "_max_gen1_size alignment");
|
assert(_max_gen1_size % _gen_alignment == 0, "_max_gen1_size alignment");
|
||||||
assert(_initial_gen1_size % _gen_alignment == 0, "_initial_gen1_size alignment");
|
assert(_initial_gen1_size % _gen_alignment == 0, "_initial_gen1_size alignment");
|
||||||
assert(_max_heap_byte_size <= (_max_gen0_size + _max_gen1_size), "Total maximum heap sizes must be sum of generation maximum sizes");
|
assert(_max_heap_byte_size <= (_max_gen0_size + _max_gen1_size), "Total maximum heap sizes must be sum of generation maximum sizes");
|
||||||
|
assert(_min_gen0_size + _min_gen1_size <= _min_heap_byte_size, "Minimum generation sizes exceed minimum heap size");
|
||||||
|
assert(_initial_gen0_size + _initial_gen1_size == _initial_heap_byte_size, "Initial generation sizes should match initial heap size");
|
||||||
|
assert(_max_gen0_size + _max_gen1_size == _max_heap_byte_size, "Maximum generation sizes should match maximum heap size");
|
||||||
}
|
}
|
||||||
#endif // ASSERT
|
#endif // ASSERT
|
||||||
|
|
||||||
@ -303,20 +312,26 @@ void GenCollectorPolicy::initialize_flags() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Make sure NewSize allows an old generation to fit even if set on the command line
|
||||||
|
if (FLAG_IS_CMDLINE(NewSize) && NewSize >= _initial_heap_byte_size) {
|
||||||
|
warning("NewSize was set larger than initial heap size, will use initial heap size.");
|
||||||
|
NewSize = bound_minus_alignment(NewSize, _initial_heap_byte_size);
|
||||||
|
}
|
||||||
|
|
||||||
// Now take the actual NewSize into account. We will silently increase NewSize
|
// Now take the actual NewSize into account. We will silently increase NewSize
|
||||||
// if the user specified a smaller or unaligned value.
|
// if the user specified a smaller or unaligned value.
|
||||||
smallest_new_size = MAX2(smallest_new_size, (uintx)align_size_down(NewSize, _gen_alignment));
|
uintx bounded_new_size = bound_minus_alignment(NewSize, MaxHeapSize);
|
||||||
if (smallest_new_size != NewSize) {
|
bounded_new_size = MAX2(smallest_new_size, (uintx)align_size_down(bounded_new_size, _gen_alignment));
|
||||||
|
if (bounded_new_size != NewSize) {
|
||||||
// Do not use FLAG_SET_ERGO to update NewSize here, since this will override
|
// Do not use FLAG_SET_ERGO to update NewSize here, since this will override
|
||||||
// if NewSize was set on the command line or not. This information is needed
|
// if NewSize was set on the command line or not. This information is needed
|
||||||
// later when setting the initial and minimum young generation size.
|
// later when setting the initial and minimum young generation size.
|
||||||
NewSize = smallest_new_size;
|
NewSize = bounded_new_size;
|
||||||
}
|
}
|
||||||
|
_min_gen0_size = smallest_new_size;
|
||||||
_initial_gen0_size = NewSize;
|
_initial_gen0_size = NewSize;
|
||||||
|
|
||||||
if (!FLAG_IS_DEFAULT(MaxNewSize)) {
|
if (!FLAG_IS_DEFAULT(MaxNewSize)) {
|
||||||
uintx min_new_size = MAX2(_gen_alignment, _min_gen0_size);
|
|
||||||
|
|
||||||
if (MaxNewSize >= MaxHeapSize) {
|
if (MaxNewSize >= MaxHeapSize) {
|
||||||
// Make sure there is room for an old generation
|
// Make sure there is room for an old generation
|
||||||
uintx smaller_max_new_size = MaxHeapSize - _gen_alignment;
|
uintx smaller_max_new_size = MaxHeapSize - _gen_alignment;
|
||||||
@ -330,8 +345,8 @@ void GenCollectorPolicy::initialize_flags() {
|
|||||||
FLAG_SET_ERGO(uintx, NewSize, MaxNewSize);
|
FLAG_SET_ERGO(uintx, NewSize, MaxNewSize);
|
||||||
_initial_gen0_size = NewSize;
|
_initial_gen0_size = NewSize;
|
||||||
}
|
}
|
||||||
} else if (MaxNewSize < min_new_size) {
|
} else if (MaxNewSize < _initial_gen0_size) {
|
||||||
FLAG_SET_ERGO(uintx, MaxNewSize, min_new_size);
|
FLAG_SET_ERGO(uintx, MaxNewSize, _initial_gen0_size);
|
||||||
} else if (!is_size_aligned(MaxNewSize, _gen_alignment)) {
|
} else if (!is_size_aligned(MaxNewSize, _gen_alignment)) {
|
||||||
FLAG_SET_ERGO(uintx, MaxNewSize, align_size_down(MaxNewSize, _gen_alignment));
|
FLAG_SET_ERGO(uintx, MaxNewSize, align_size_down(MaxNewSize, _gen_alignment));
|
||||||
}
|
}
|
||||||
@ -361,7 +376,9 @@ void TwoGenerationCollectorPolicy::initialize_flags() {
|
|||||||
GenCollectorPolicy::initialize_flags();
|
GenCollectorPolicy::initialize_flags();
|
||||||
|
|
||||||
if (!is_size_aligned(OldSize, _gen_alignment)) {
|
if (!is_size_aligned(OldSize, _gen_alignment)) {
|
||||||
FLAG_SET_ERGO(uintx, OldSize, align_size_down(OldSize, _gen_alignment));
|
// Setting OldSize directly to preserve information about the possible
|
||||||
|
// setting of OldSize on the command line.
|
||||||
|
OldSize = align_size_down(OldSize, _gen_alignment);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (FLAG_IS_CMDLINE(OldSize) && FLAG_IS_DEFAULT(MaxHeapSize)) {
|
if (FLAG_IS_CMDLINE(OldSize) && FLAG_IS_DEFAULT(MaxHeapSize)) {
|
||||||
@ -400,6 +417,20 @@ void TwoGenerationCollectorPolicy::initialize_flags() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Update NewSize, if possible, to avoid sizing gen0 to small when only
|
||||||
|
// OldSize is set on the command line.
|
||||||
|
if (FLAG_IS_CMDLINE(OldSize) && !FLAG_IS_CMDLINE(NewSize)) {
|
||||||
|
if (OldSize < _initial_heap_byte_size) {
|
||||||
|
size_t new_size = _initial_heap_byte_size - OldSize;
|
||||||
|
// Need to compare against the flag value for max since _max_gen0_size
|
||||||
|
// might not have been set yet.
|
||||||
|
if (new_size >= _min_gen0_size && new_size <= MaxNewSize) {
|
||||||
|
FLAG_SET_ERGO(uintx, NewSize, new_size);
|
||||||
|
_initial_gen0_size = NewSize;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
always_do_update_barrier = UseConcMarkSweepGC;
|
always_do_update_barrier = UseConcMarkSweepGC;
|
||||||
|
|
||||||
DEBUG_ONLY(TwoGenerationCollectorPolicy::assert_flags();)
|
DEBUG_ONLY(TwoGenerationCollectorPolicy::assert_flags();)
|
||||||
@ -441,57 +472,37 @@ void GenCollectorPolicy::initialize_size_info() {
|
|||||||
// Given the maximum gen0 size, determine the initial and
|
// Given the maximum gen0 size, determine the initial and
|
||||||
// minimum gen0 sizes.
|
// minimum gen0 sizes.
|
||||||
|
|
||||||
if (_max_heap_byte_size == _min_heap_byte_size) {
|
if (_max_heap_byte_size == _initial_heap_byte_size) {
|
||||||
// The maximum and minimum heap sizes are the same so the generations
|
// The maxium and initial heap sizes are the same so the generation's
|
||||||
// minimum and initial must be the same as its maximum.
|
// initial size must be the same as it maximum size. Use NewSize as the
|
||||||
_min_gen0_size = max_new_size;
|
// size if set on command line.
|
||||||
_initial_gen0_size = max_new_size;
|
size_t fixed_young_size = FLAG_IS_CMDLINE(NewSize) ? NewSize : max_new_size;
|
||||||
_max_gen0_size = max_new_size;
|
|
||||||
|
_initial_gen0_size = fixed_young_size;
|
||||||
|
_max_gen0_size = fixed_young_size;
|
||||||
|
|
||||||
|
// Also update the minimum size if min == initial == max.
|
||||||
|
if (_max_heap_byte_size == _min_heap_byte_size) {
|
||||||
|
_min_gen0_size = fixed_young_size;
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
size_t desired_new_size = 0;
|
size_t desired_new_size = 0;
|
||||||
if (FLAG_IS_CMDLINE(NewSize)) {
|
if (FLAG_IS_CMDLINE(NewSize)) {
|
||||||
// If NewSize is set on the command line, we must use it as
|
// If NewSize is set on the command line, we should use it as
|
||||||
// the initial size and it also makes sense to use it as the
|
// the initial size, but make sure it is within the heap bounds.
|
||||||
// lower limit.
|
|
||||||
_min_gen0_size = NewSize;
|
|
||||||
desired_new_size = NewSize;
|
|
||||||
max_new_size = MAX2(max_new_size, NewSize);
|
|
||||||
} else if (FLAG_IS_ERGO(NewSize)) {
|
|
||||||
// If NewSize is set ergonomically, we should use it as a lower
|
|
||||||
// limit, but use NewRatio to calculate the initial size.
|
|
||||||
_min_gen0_size = NewSize;
|
|
||||||
desired_new_size =
|
desired_new_size =
|
||||||
MAX2(scale_by_NewRatio_aligned(_initial_heap_byte_size), NewSize);
|
MIN2(max_new_size, bound_minus_alignment(NewSize, _initial_heap_byte_size));
|
||||||
max_new_size = MAX2(max_new_size, NewSize);
|
_min_gen0_size = bound_minus_alignment(desired_new_size, _min_heap_byte_size);
|
||||||
} else {
|
} else {
|
||||||
// For the case where NewSize is the default, use NewRatio
|
// For the case where NewSize is not set on the command line, use
|
||||||
// to size the minimum and initial generation sizes.
|
// NewRatio to size the initial generation size. Use the current
|
||||||
// Use the default NewSize as the floor for these values. If
|
// NewSize as the floor, because if NewRatio is overly large, the resulting
|
||||||
// NewRatio is overly large, the resulting sizes can be too small.
|
// size can be too small.
|
||||||
_min_gen0_size = MAX2(scale_by_NewRatio_aligned(_min_heap_byte_size), NewSize);
|
|
||||||
desired_new_size =
|
desired_new_size =
|
||||||
MAX2(scale_by_NewRatio_aligned(_initial_heap_byte_size), NewSize);
|
MIN2(max_new_size, MAX2(scale_by_NewRatio_aligned(_initial_heap_byte_size), NewSize));
|
||||||
}
|
}
|
||||||
|
|
||||||
assert(_min_gen0_size > 0, "Sanity check");
|
|
||||||
_initial_gen0_size = desired_new_size;
|
_initial_gen0_size = desired_new_size;
|
||||||
_max_gen0_size = max_new_size;
|
_max_gen0_size = max_new_size;
|
||||||
|
|
||||||
// At this point the desirable initial and minimum sizes have been
|
|
||||||
// determined without regard to the maximum sizes.
|
|
||||||
|
|
||||||
// Bound the sizes by the corresponding overall heap sizes.
|
|
||||||
_min_gen0_size = bound_minus_alignment(_min_gen0_size, _min_heap_byte_size);
|
|
||||||
_initial_gen0_size = bound_minus_alignment(_initial_gen0_size, _initial_heap_byte_size);
|
|
||||||
_max_gen0_size = bound_minus_alignment(_max_gen0_size, _max_heap_byte_size);
|
|
||||||
|
|
||||||
// At this point all three sizes have been checked against the
|
|
||||||
// maximum sizes but have not been checked for consistency among the three.
|
|
||||||
|
|
||||||
// Final check min <= initial <= max
|
|
||||||
_min_gen0_size = MIN2(_min_gen0_size, _max_gen0_size);
|
|
||||||
_initial_gen0_size = MAX2(MIN2(_initial_gen0_size, _max_gen0_size), _min_gen0_size);
|
|
||||||
_min_gen0_size = MIN2(_min_gen0_size, _initial_gen0_size);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Write back to flags if necessary.
|
// Write back to flags if necessary.
|
||||||
@ -512,33 +523,6 @@ void GenCollectorPolicy::initialize_size_info() {
|
|||||||
DEBUG_ONLY(GenCollectorPolicy::assert_size_info();)
|
DEBUG_ONLY(GenCollectorPolicy::assert_size_info();)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Call this method during the sizing of the gen1 to make
|
|
||||||
// adjustments to gen0 because of gen1 sizing policy. gen0 initially has
|
|
||||||
// the most freedom in sizing because it is done before the
|
|
||||||
// policy for gen1 is applied. Once gen1 policies have been applied,
|
|
||||||
// there may be conflicts in the shape of the heap and this method
|
|
||||||
// is used to make the needed adjustments. The application of the
|
|
||||||
// policies could be more sophisticated (iterative for example) but
|
|
||||||
// keeping it simple also seems a worthwhile goal.
|
|
||||||
bool TwoGenerationCollectorPolicy::adjust_gen0_sizes(size_t* gen0_size_ptr,
|
|
||||||
size_t* gen1_size_ptr,
|
|
||||||
const size_t heap_size) {
|
|
||||||
bool result = false;
|
|
||||||
|
|
||||||
if ((*gen0_size_ptr + *gen1_size_ptr) > heap_size) {
|
|
||||||
uintx smallest_new_size = young_gen_size_lower_bound();
|
|
||||||
if ((heap_size < (*gen0_size_ptr + _min_gen1_size)) &&
|
|
||||||
(heap_size >= _min_gen1_size + smallest_new_size)) {
|
|
||||||
// Adjust gen0 down to accommodate _min_gen1_size
|
|
||||||
*gen0_size_ptr = align_size_down_bounded(heap_size - _min_gen1_size, _gen_alignment);
|
|
||||||
result = true;
|
|
||||||
} else {
|
|
||||||
*gen1_size_ptr = align_size_down_bounded(heap_size - *gen0_size_ptr, _gen_alignment);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Minimum sizes of the generations may be different than
|
// Minimum sizes of the generations may be different than
|
||||||
// the initial sizes. An inconsistency is permitted here
|
// the initial sizes. An inconsistency is permitted here
|
||||||
// in the total size that can be specified explicitly by
|
// in the total size that can be specified explicitly by
|
||||||
@ -564,56 +548,63 @@ void TwoGenerationCollectorPolicy::initialize_size_info() {
|
|||||||
// with the overall heap size). In either case make
|
// with the overall heap size). In either case make
|
||||||
// the minimum, maximum and initial sizes consistent
|
// the minimum, maximum and initial sizes consistent
|
||||||
// with the gen0 sizes and the overall heap sizes.
|
// with the gen0 sizes and the overall heap sizes.
|
||||||
_min_gen1_size = MAX2(_min_heap_byte_size - _min_gen0_size, _gen_alignment);
|
_min_gen1_size = _gen_alignment;
|
||||||
_initial_gen1_size = MAX2(_initial_heap_byte_size - _initial_gen0_size, _gen_alignment);
|
_initial_gen1_size = MIN2(_max_gen1_size, MAX2(_initial_heap_byte_size - _initial_gen0_size, _min_gen1_size));
|
||||||
// _max_gen1_size has already been made consistent above
|
// _max_gen1_size has already been made consistent above
|
||||||
FLAG_SET_ERGO(uintx, OldSize, _initial_gen1_size);
|
FLAG_SET_ERGO(uintx, OldSize, _initial_gen1_size);
|
||||||
} else {
|
} else {
|
||||||
// OldSize has been explicitly set on the command line. Use the
|
// OldSize has been explicitly set on the command line. Use it
|
||||||
// OldSize and then determine the consequences.
|
// for the initial size but make sure the minimum allow a young
|
||||||
_min_gen1_size = MIN2(OldSize, _min_heap_byte_size - _min_gen0_size);
|
// generation to fit as well.
|
||||||
_initial_gen1_size = OldSize;
|
|
||||||
|
|
||||||
// If the user has explicitly set an OldSize that is inconsistent
|
// If the user has explicitly set an OldSize that is inconsistent
|
||||||
// with other command line flags, issue a warning.
|
// with other command line flags, issue a warning.
|
||||||
// The generation minimums and the overall heap minimum should
|
// The generation minimums and the overall heap minimum should
|
||||||
// be within one generation alignment.
|
// be within one generation alignment.
|
||||||
if ((_min_gen1_size + _min_gen0_size + _gen_alignment) < _min_heap_byte_size) {
|
|
||||||
warning("Inconsistency between minimum heap size and minimum "
|
|
||||||
"generation sizes: using minimum heap = " SIZE_FORMAT,
|
|
||||||
_min_heap_byte_size);
|
|
||||||
}
|
|
||||||
if (OldSize > _max_gen1_size) {
|
if (OldSize > _max_gen1_size) {
|
||||||
warning("Inconsistency between maximum heap size and maximum "
|
warning("Inconsistency between maximum heap size and maximum "
|
||||||
"generation sizes: using maximum heap = " SIZE_FORMAT
|
"generation sizes: using maximum heap = " SIZE_FORMAT
|
||||||
" -XX:OldSize flag is being ignored",
|
" -XX:OldSize flag is being ignored",
|
||||||
_max_heap_byte_size);
|
_max_heap_byte_size);
|
||||||
}
|
FLAG_SET_ERGO(uintx, OldSize, _max_gen1_size);
|
||||||
// If there is an inconsistency between the OldSize and the minimum and/or
|
|
||||||
// initial size of gen0, since OldSize was explicitly set, OldSize wins.
|
|
||||||
if (adjust_gen0_sizes(&_min_gen0_size, &_min_gen1_size, _min_heap_byte_size)) {
|
|
||||||
if (PrintGCDetails && Verbose) {
|
|
||||||
gclog_or_tty->print_cr("2: Minimum gen0 " SIZE_FORMAT " Initial gen0 "
|
|
||||||
SIZE_FORMAT " Maximum gen0 " SIZE_FORMAT,
|
|
||||||
_min_gen0_size, _initial_gen0_size, _max_gen0_size);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// The same as above for the old gen initial size.
|
|
||||||
if (adjust_gen0_sizes(&_initial_gen0_size, &_initial_gen1_size,
|
|
||||||
_initial_heap_byte_size)) {
|
|
||||||
if (PrintGCDetails && Verbose) {
|
|
||||||
gclog_or_tty->print_cr("3: Minimum gen0 " SIZE_FORMAT " Initial gen0 "
|
|
||||||
SIZE_FORMAT " Maximum gen0 " SIZE_FORMAT,
|
|
||||||
_min_gen0_size, _initial_gen0_size, _max_gen0_size);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
_min_gen1_size = MIN2(OldSize, _min_heap_byte_size - _min_gen0_size);
|
||||||
|
_initial_gen1_size = OldSize;
|
||||||
}
|
}
|
||||||
|
|
||||||
_min_gen1_size = MIN2(_min_gen1_size, _max_gen1_size);
|
// The initial generation sizes should match the initial heap size,
|
||||||
|
// if not issue a warning and resize the generations. This behavior
|
||||||
|
// differs from JDK8 where the generation sizes have higher priority
|
||||||
|
// than the initial heap size.
|
||||||
|
if ((_initial_gen1_size + _initial_gen0_size) != _initial_heap_byte_size) {
|
||||||
|
warning("Inconsistency between generation sizes and heap size, resizing "
|
||||||
|
"the generations to fit the heap.");
|
||||||
|
|
||||||
// Make sure that min gen1 <= initial gen1 <= max gen1.
|
size_t desired_gen0_size = _initial_heap_byte_size - _initial_gen1_size;
|
||||||
_initial_gen1_size = MAX2(_initial_gen1_size, _min_gen1_size);
|
if (_initial_heap_byte_size < _initial_gen1_size) {
|
||||||
_initial_gen1_size = MIN2(_initial_gen1_size, _max_gen1_size);
|
// Old want all memory, use minimum for young and rest for old
|
||||||
|
_initial_gen0_size = _min_gen0_size;
|
||||||
|
_initial_gen1_size = _initial_heap_byte_size - _min_gen0_size;
|
||||||
|
} else if (desired_gen0_size > _max_gen0_size) {
|
||||||
|
// Need to increase both young and old generation
|
||||||
|
_initial_gen0_size = _max_gen0_size;
|
||||||
|
_initial_gen1_size = _initial_heap_byte_size - _max_gen0_size;
|
||||||
|
} else if (desired_gen0_size < _min_gen0_size) {
|
||||||
|
// Need to decrease both young and old generation
|
||||||
|
_initial_gen0_size = _min_gen0_size;
|
||||||
|
_initial_gen1_size = _initial_heap_byte_size - _min_gen0_size;
|
||||||
|
} else {
|
||||||
|
// The young generation boundaries allow us to only update the
|
||||||
|
// young generation.
|
||||||
|
_initial_gen0_size = desired_gen0_size;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (PrintGCDetails && Verbose) {
|
||||||
|
gclog_or_tty->print_cr("2: Minimum gen0 " SIZE_FORMAT " Initial gen0 "
|
||||||
|
SIZE_FORMAT " Maximum gen0 " SIZE_FORMAT,
|
||||||
|
_min_gen0_size, _initial_gen0_size, _max_gen0_size);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Write back to flags if necessary
|
// Write back to flags if necessary
|
||||||
if (NewSize != _initial_gen0_size) {
|
if (NewSize != _initial_gen0_size) {
|
||||||
@ -994,56 +985,88 @@ void MarkSweepPolicy::initialize_gc_policy_counters() {
|
|||||||
// verify that there are some basic rules for NewSize honored by the policies.
|
// verify that there are some basic rules for NewSize honored by the policies.
|
||||||
class TestGenCollectorPolicy {
|
class TestGenCollectorPolicy {
|
||||||
public:
|
public:
|
||||||
static void test() {
|
static void test_new_size() {
|
||||||
size_t flag_value;
|
size_t flag_value;
|
||||||
|
|
||||||
save_flags();
|
save_flags();
|
||||||
|
|
||||||
// Set some limits that makes the math simple.
|
|
||||||
FLAG_SET_ERGO(uintx, MaxHeapSize, 180 * M);
|
|
||||||
FLAG_SET_ERGO(uintx, InitialHeapSize, 120 * M);
|
|
||||||
Arguments::set_min_heap_size(40 * M);
|
|
||||||
|
|
||||||
// If NewSize is set on the command line, it should be used
|
// If NewSize is set on the command line, it should be used
|
||||||
// for both min and initial young size if less than min heap.
|
// for both min and initial young size if less than min heap.
|
||||||
flag_value = 20 * M;
|
flag_value = 20 * M;
|
||||||
|
set_basic_flag_values();
|
||||||
FLAG_SET_CMDLINE(uintx, NewSize, flag_value);
|
FLAG_SET_CMDLINE(uintx, NewSize, flag_value);
|
||||||
verify_min(flag_value);
|
verify_gen0_min(flag_value);
|
||||||
verify_initial(flag_value);
|
|
||||||
|
set_basic_flag_values();
|
||||||
|
FLAG_SET_CMDLINE(uintx, NewSize, flag_value);
|
||||||
|
verify_gen0_initial(flag_value);
|
||||||
|
|
||||||
// If NewSize is set on command line, but is larger than the min
|
// If NewSize is set on command line, but is larger than the min
|
||||||
// heap size, it should only be used for initial young size.
|
// heap size, it should only be used for initial young size.
|
||||||
flag_value = 80 * M;
|
flag_value = 80 * M;
|
||||||
|
set_basic_flag_values();
|
||||||
FLAG_SET_CMDLINE(uintx, NewSize, flag_value);
|
FLAG_SET_CMDLINE(uintx, NewSize, flag_value);
|
||||||
verify_initial(flag_value);
|
verify_gen0_initial(flag_value);
|
||||||
|
|
||||||
// If NewSize has been ergonomically set, the collector policy
|
// If NewSize has been ergonomically set, the collector policy
|
||||||
// should use it for min but calculate the initial young size
|
// should use it for min but calculate the initial young size
|
||||||
// using NewRatio.
|
// using NewRatio.
|
||||||
flag_value = 20 * M;
|
flag_value = 20 * M;
|
||||||
|
set_basic_flag_values();
|
||||||
FLAG_SET_ERGO(uintx, NewSize, flag_value);
|
FLAG_SET_ERGO(uintx, NewSize, flag_value);
|
||||||
verify_min(flag_value);
|
verify_gen0_min(flag_value);
|
||||||
verify_scaled_initial(InitialHeapSize);
|
|
||||||
|
set_basic_flag_values();
|
||||||
|
FLAG_SET_ERGO(uintx, NewSize, flag_value);
|
||||||
|
verify_scaled_gen0_initial(InitialHeapSize);
|
||||||
|
|
||||||
restore_flags();
|
restore_flags();
|
||||||
|
}
|
||||||
|
|
||||||
|
static void test_old_size() {
|
||||||
|
size_t flag_value;
|
||||||
|
|
||||||
|
save_flags();
|
||||||
|
|
||||||
|
// If OldSize is set on the command line, it should be used
|
||||||
|
// for both min and initial old size if less than min heap.
|
||||||
|
flag_value = 20 * M;
|
||||||
|
set_basic_flag_values();
|
||||||
|
FLAG_SET_CMDLINE(uintx, OldSize, flag_value);
|
||||||
|
verify_gen1_min(flag_value);
|
||||||
|
|
||||||
|
set_basic_flag_values();
|
||||||
|
FLAG_SET_CMDLINE(uintx, OldSize, flag_value);
|
||||||
|
verify_gen1_initial(flag_value);
|
||||||
|
|
||||||
|
// If MaxNewSize is large, the maximum OldSize will be less than
|
||||||
|
// what's requested on the command line and it should be reset
|
||||||
|
// ergonomically.
|
||||||
|
flag_value = 30 * M;
|
||||||
|
set_basic_flag_values();
|
||||||
|
FLAG_SET_CMDLINE(uintx, OldSize, flag_value);
|
||||||
|
FLAG_SET_CMDLINE(uintx, MaxNewSize, 170*M);
|
||||||
|
// Calculate what we expect the flag to be.
|
||||||
|
flag_value = MaxHeapSize - MaxNewSize;
|
||||||
|
verify_gen1_initial(flag_value);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void verify_min(size_t expected) {
|
static void verify_gen0_min(size_t expected) {
|
||||||
MarkSweepPolicy msp;
|
MarkSweepPolicy msp;
|
||||||
msp.initialize_all();
|
msp.initialize_all();
|
||||||
|
|
||||||
assert(msp.min_gen0_size() <= expected, err_msg("%zu > %zu", msp.min_gen0_size(), expected));
|
assert(msp.min_gen0_size() <= expected, err_msg("%zu > %zu", msp.min_gen0_size(), expected));
|
||||||
}
|
}
|
||||||
|
|
||||||
static void verify_initial(size_t expected) {
|
static void verify_gen0_initial(size_t expected) {
|
||||||
MarkSweepPolicy msp;
|
MarkSweepPolicy msp;
|
||||||
msp.initialize_all();
|
msp.initialize_all();
|
||||||
|
|
||||||
assert(msp.initial_gen0_size() == expected, err_msg("%zu != %zu", msp.initial_gen0_size(), expected));
|
assert(msp.initial_gen0_size() == expected, err_msg("%zu != %zu", msp.initial_gen0_size(), expected));
|
||||||
}
|
}
|
||||||
|
|
||||||
static void verify_scaled_initial(size_t initial_heap_size) {
|
static void verify_scaled_gen0_initial(size_t initial_heap_size) {
|
||||||
MarkSweepPolicy msp;
|
MarkSweepPolicy msp;
|
||||||
msp.initialize_all();
|
msp.initialize_all();
|
||||||
|
|
||||||
@ -1053,6 +1076,21 @@ public:
|
|||||||
err_msg("NewSize should have been set ergonomically to %zu, but was %zu", expected, NewSize));
|
err_msg("NewSize should have been set ergonomically to %zu, but was %zu", expected, NewSize));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void verify_gen1_min(size_t expected) {
|
||||||
|
MarkSweepPolicy msp;
|
||||||
|
msp.initialize_all();
|
||||||
|
|
||||||
|
assert(msp.min_gen1_size() <= expected, err_msg("%zu > %zu", msp.min_gen1_size(), expected));
|
||||||
|
}
|
||||||
|
|
||||||
|
static void verify_gen1_initial(size_t expected) {
|
||||||
|
MarkSweepPolicy msp;
|
||||||
|
msp.initialize_all();
|
||||||
|
|
||||||
|
assert(msp.initial_gen1_size() == expected, err_msg("%zu != %zu", msp.initial_gen1_size(), expected));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
static size_t original_InitialHeapSize;
|
static size_t original_InitialHeapSize;
|
||||||
static size_t original_MaxHeapSize;
|
static size_t original_MaxHeapSize;
|
||||||
@ -1061,6 +1099,15 @@ private:
|
|||||||
static size_t original_NewSize;
|
static size_t original_NewSize;
|
||||||
static size_t original_OldSize;
|
static size_t original_OldSize;
|
||||||
|
|
||||||
|
static void set_basic_flag_values() {
|
||||||
|
FLAG_SET_ERGO(uintx, MaxHeapSize, 180 * M);
|
||||||
|
FLAG_SET_ERGO(uintx, InitialHeapSize, 100 * M);
|
||||||
|
FLAG_SET_ERGO(uintx, OldSize, 4 * M);
|
||||||
|
FLAG_SET_ERGO(uintx, NewSize, 1 * M);
|
||||||
|
FLAG_SET_ERGO(uintx, MaxNewSize, 80 * M);
|
||||||
|
Arguments::set_min_heap_size(40 * M);
|
||||||
|
}
|
||||||
|
|
||||||
static void save_flags() {
|
static void save_flags() {
|
||||||
original_InitialHeapSize = InitialHeapSize;
|
original_InitialHeapSize = InitialHeapSize;
|
||||||
original_MaxHeapSize = MaxHeapSize;
|
original_MaxHeapSize = MaxHeapSize;
|
||||||
@ -1088,7 +1135,11 @@ size_t TestGenCollectorPolicy::original_NewSize = 0;
|
|||||||
size_t TestGenCollectorPolicy::original_OldSize = 0;
|
size_t TestGenCollectorPolicy::original_OldSize = 0;
|
||||||
|
|
||||||
void TestNewSize_test() {
|
void TestNewSize_test() {
|
||||||
TestGenCollectorPolicy::test();
|
TestGenCollectorPolicy::test_new_size();
|
||||||
|
}
|
||||||
|
|
||||||
|
void TestOldSize_test() {
|
||||||
|
TestGenCollectorPolicy::test_old_size();
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -248,13 +248,13 @@ friend class TestGenCollectorPolicy;
|
|||||||
// Compute max heap alignment.
|
// Compute max heap alignment.
|
||||||
size_t compute_max_alignment();
|
size_t compute_max_alignment();
|
||||||
|
|
||||||
// Scale the base_size by NewRatio according to
|
// Scale the base_size by NewRatio according to
|
||||||
// result = base_size / (NewRatio + 1)
|
// result = base_size / (NewRatio + 1)
|
||||||
// and align by min_alignment()
|
// and align by min_alignment()
|
||||||
size_t scale_by_NewRatio_aligned(size_t base_size);
|
size_t scale_by_NewRatio_aligned(size_t base_size);
|
||||||
|
|
||||||
// Bound the value by the given maximum minus the min_alignment.
|
// Bound the value by the given maximum minus the min_alignment.
|
||||||
size_t bound_minus_alignment(size_t desired_size, size_t maximum_size);
|
size_t bound_minus_alignment(size_t desired_size, size_t maximum_size);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
GenCollectorPolicy();
|
GenCollectorPolicy();
|
||||||
@ -335,10 +335,6 @@ class TwoGenerationCollectorPolicy : public GenCollectorPolicy {
|
|||||||
virtual CollectorPolicy::Name kind() {
|
virtual CollectorPolicy::Name kind() {
|
||||||
return CollectorPolicy::TwoGenerationCollectorPolicyKind;
|
return CollectorPolicy::TwoGenerationCollectorPolicyKind;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Returns true if gen0 sizes were adjusted
|
|
||||||
bool adjust_gen0_sizes(size_t* gen0_size_ptr, size_t* gen1_size_ptr,
|
|
||||||
const size_t heap_size);
|
|
||||||
};
|
};
|
||||||
|
|
||||||
class MarkSweepPolicy : public TwoGenerationCollectorPolicy {
|
class MarkSweepPolicy : public TwoGenerationCollectorPolicy {
|
||||||
|
@ -374,7 +374,7 @@ void GenCollectedHeap::do_collection(bool full,
|
|||||||
|
|
||||||
ClearedAllSoftRefs casr(do_clear_all_soft_refs, collector_policy());
|
ClearedAllSoftRefs casr(do_clear_all_soft_refs, collector_policy());
|
||||||
|
|
||||||
const size_t metadata_prev_used = MetaspaceAux::allocated_used_bytes();
|
const size_t metadata_prev_used = MetaspaceAux::used_bytes();
|
||||||
|
|
||||||
print_heap_before_gc();
|
print_heap_before_gc();
|
||||||
|
|
||||||
|
@ -1447,7 +1447,7 @@ void MetaspaceGC::compute_new_size() {
|
|||||||
uint current_shrink_factor = _shrink_factor;
|
uint current_shrink_factor = _shrink_factor;
|
||||||
_shrink_factor = 0;
|
_shrink_factor = 0;
|
||||||
|
|
||||||
const size_t used_after_gc = MetaspaceAux::allocated_capacity_bytes();
|
const size_t used_after_gc = MetaspaceAux::capacity_bytes();
|
||||||
const size_t capacity_until_GC = MetaspaceGC::capacity_until_GC();
|
const size_t capacity_until_GC = MetaspaceGC::capacity_until_GC();
|
||||||
|
|
||||||
const double minimum_free_percentage = MinMetaspaceFreeRatio / 100.0;
|
const double minimum_free_percentage = MinMetaspaceFreeRatio / 100.0;
|
||||||
@ -2538,8 +2538,8 @@ void SpaceManager::mangle_freed_chunks() {
|
|||||||
// MetaspaceAux
|
// MetaspaceAux
|
||||||
|
|
||||||
|
|
||||||
size_t MetaspaceAux::_allocated_capacity_words[] = {0, 0};
|
size_t MetaspaceAux::_capacity_words[] = {0, 0};
|
||||||
size_t MetaspaceAux::_allocated_used_words[] = {0, 0};
|
size_t MetaspaceAux::_used_words[] = {0, 0};
|
||||||
|
|
||||||
size_t MetaspaceAux::free_bytes(Metaspace::MetadataType mdtype) {
|
size_t MetaspaceAux::free_bytes(Metaspace::MetadataType mdtype) {
|
||||||
VirtualSpaceList* list = Metaspace::get_space_list(mdtype);
|
VirtualSpaceList* list = Metaspace::get_space_list(mdtype);
|
||||||
@ -2552,38 +2552,38 @@ size_t MetaspaceAux::free_bytes() {
|
|||||||
|
|
||||||
void MetaspaceAux::dec_capacity(Metaspace::MetadataType mdtype, size_t words) {
|
void MetaspaceAux::dec_capacity(Metaspace::MetadataType mdtype, size_t words) {
|
||||||
assert_lock_strong(SpaceManager::expand_lock());
|
assert_lock_strong(SpaceManager::expand_lock());
|
||||||
assert(words <= allocated_capacity_words(mdtype),
|
assert(words <= capacity_words(mdtype),
|
||||||
err_msg("About to decrement below 0: words " SIZE_FORMAT
|
err_msg("About to decrement below 0: words " SIZE_FORMAT
|
||||||
" is greater than _allocated_capacity_words[%u] " SIZE_FORMAT,
|
" is greater than _capacity_words[%u] " SIZE_FORMAT,
|
||||||
words, mdtype, allocated_capacity_words(mdtype)));
|
words, mdtype, capacity_words(mdtype)));
|
||||||
_allocated_capacity_words[mdtype] -= words;
|
_capacity_words[mdtype] -= words;
|
||||||
}
|
}
|
||||||
|
|
||||||
void MetaspaceAux::inc_capacity(Metaspace::MetadataType mdtype, size_t words) {
|
void MetaspaceAux::inc_capacity(Metaspace::MetadataType mdtype, size_t words) {
|
||||||
assert_lock_strong(SpaceManager::expand_lock());
|
assert_lock_strong(SpaceManager::expand_lock());
|
||||||
// Needs to be atomic
|
// Needs to be atomic
|
||||||
_allocated_capacity_words[mdtype] += words;
|
_capacity_words[mdtype] += words;
|
||||||
}
|
}
|
||||||
|
|
||||||
void MetaspaceAux::dec_used(Metaspace::MetadataType mdtype, size_t words) {
|
void MetaspaceAux::dec_used(Metaspace::MetadataType mdtype, size_t words) {
|
||||||
assert(words <= allocated_used_words(mdtype),
|
assert(words <= used_words(mdtype),
|
||||||
err_msg("About to decrement below 0: words " SIZE_FORMAT
|
err_msg("About to decrement below 0: words " SIZE_FORMAT
|
||||||
" is greater than _allocated_used_words[%u] " SIZE_FORMAT,
|
" is greater than _used_words[%u] " SIZE_FORMAT,
|
||||||
words, mdtype, allocated_used_words(mdtype)));
|
words, mdtype, used_words(mdtype)));
|
||||||
// For CMS deallocation of the Metaspaces occurs during the
|
// For CMS deallocation of the Metaspaces occurs during the
|
||||||
// sweep which is a concurrent phase. Protection by the expand_lock()
|
// sweep which is a concurrent phase. Protection by the expand_lock()
|
||||||
// is not enough since allocation is on a per Metaspace basis
|
// is not enough since allocation is on a per Metaspace basis
|
||||||
// and protected by the Metaspace lock.
|
// and protected by the Metaspace lock.
|
||||||
jlong minus_words = (jlong) - (jlong) words;
|
jlong minus_words = (jlong) - (jlong) words;
|
||||||
Atomic::add_ptr(minus_words, &_allocated_used_words[mdtype]);
|
Atomic::add_ptr(minus_words, &_used_words[mdtype]);
|
||||||
}
|
}
|
||||||
|
|
||||||
void MetaspaceAux::inc_used(Metaspace::MetadataType mdtype, size_t words) {
|
void MetaspaceAux::inc_used(Metaspace::MetadataType mdtype, size_t words) {
|
||||||
// _allocated_used_words tracks allocations for
|
// _used_words tracks allocations for
|
||||||
// each piece of metadata. Those allocations are
|
// each piece of metadata. Those allocations are
|
||||||
// generally done concurrently by different application
|
// generally done concurrently by different application
|
||||||
// threads so must be done atomically.
|
// threads so must be done atomically.
|
||||||
Atomic::add_ptr(words, &_allocated_used_words[mdtype]);
|
Atomic::add_ptr(words, &_used_words[mdtype]);
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t MetaspaceAux::used_bytes_slow(Metaspace::MetadataType mdtype) {
|
size_t MetaspaceAux::used_bytes_slow(Metaspace::MetadataType mdtype) {
|
||||||
@ -2630,16 +2630,16 @@ size_t MetaspaceAux::capacity_bytes_slow(Metaspace::MetadataType mdtype) {
|
|||||||
|
|
||||||
size_t MetaspaceAux::capacity_bytes_slow() {
|
size_t MetaspaceAux::capacity_bytes_slow() {
|
||||||
#ifdef PRODUCT
|
#ifdef PRODUCT
|
||||||
// Use allocated_capacity_bytes() in PRODUCT instead of this function.
|
// Use capacity_bytes() in PRODUCT instead of this function.
|
||||||
guarantee(false, "Should not call capacity_bytes_slow() in the PRODUCT");
|
guarantee(false, "Should not call capacity_bytes_slow() in the PRODUCT");
|
||||||
#endif
|
#endif
|
||||||
size_t class_capacity = capacity_bytes_slow(Metaspace::ClassType);
|
size_t class_capacity = capacity_bytes_slow(Metaspace::ClassType);
|
||||||
size_t non_class_capacity = capacity_bytes_slow(Metaspace::NonClassType);
|
size_t non_class_capacity = capacity_bytes_slow(Metaspace::NonClassType);
|
||||||
assert(allocated_capacity_bytes() == class_capacity + non_class_capacity,
|
assert(capacity_bytes() == class_capacity + non_class_capacity,
|
||||||
err_msg("bad accounting: allocated_capacity_bytes() " SIZE_FORMAT
|
err_msg("bad accounting: capacity_bytes() " SIZE_FORMAT
|
||||||
" class_capacity + non_class_capacity " SIZE_FORMAT
|
" class_capacity + non_class_capacity " SIZE_FORMAT
|
||||||
" class_capacity " SIZE_FORMAT " non_class_capacity " SIZE_FORMAT,
|
" class_capacity " SIZE_FORMAT " non_class_capacity " SIZE_FORMAT,
|
||||||
allocated_capacity_bytes(), class_capacity + non_class_capacity,
|
capacity_bytes(), class_capacity + non_class_capacity,
|
||||||
class_capacity, non_class_capacity));
|
class_capacity, non_class_capacity));
|
||||||
|
|
||||||
return class_capacity + non_class_capacity;
|
return class_capacity + non_class_capacity;
|
||||||
@ -2699,14 +2699,14 @@ void MetaspaceAux::print_metaspace_change(size_t prev_metadata_used) {
|
|||||||
"->" SIZE_FORMAT
|
"->" SIZE_FORMAT
|
||||||
"(" SIZE_FORMAT ")",
|
"(" SIZE_FORMAT ")",
|
||||||
prev_metadata_used,
|
prev_metadata_used,
|
||||||
allocated_used_bytes(),
|
used_bytes(),
|
||||||
reserved_bytes());
|
reserved_bytes());
|
||||||
} else {
|
} else {
|
||||||
gclog_or_tty->print(" " SIZE_FORMAT "K"
|
gclog_or_tty->print(" " SIZE_FORMAT "K"
|
||||||
"->" SIZE_FORMAT "K"
|
"->" SIZE_FORMAT "K"
|
||||||
"(" SIZE_FORMAT "K)",
|
"(" SIZE_FORMAT "K)",
|
||||||
prev_metadata_used/K,
|
prev_metadata_used/K,
|
||||||
allocated_used_bytes()/K,
|
used_bytes()/K,
|
||||||
reserved_bytes()/K);
|
reserved_bytes()/K);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2722,8 +2722,8 @@ void MetaspaceAux::print_on(outputStream* out) {
|
|||||||
"capacity " SIZE_FORMAT "K, "
|
"capacity " SIZE_FORMAT "K, "
|
||||||
"committed " SIZE_FORMAT "K, "
|
"committed " SIZE_FORMAT "K, "
|
||||||
"reserved " SIZE_FORMAT "K",
|
"reserved " SIZE_FORMAT "K",
|
||||||
allocated_used_bytes()/K,
|
used_bytes()/K,
|
||||||
allocated_capacity_bytes()/K,
|
capacity_bytes()/K,
|
||||||
committed_bytes()/K,
|
committed_bytes()/K,
|
||||||
reserved_bytes()/K);
|
reserved_bytes()/K);
|
||||||
|
|
||||||
@ -2734,8 +2734,8 @@ void MetaspaceAux::print_on(outputStream* out) {
|
|||||||
"capacity " SIZE_FORMAT "K, "
|
"capacity " SIZE_FORMAT "K, "
|
||||||
"committed " SIZE_FORMAT "K, "
|
"committed " SIZE_FORMAT "K, "
|
||||||
"reserved " SIZE_FORMAT "K",
|
"reserved " SIZE_FORMAT "K",
|
||||||
allocated_used_bytes(ct)/K,
|
used_bytes(ct)/K,
|
||||||
allocated_capacity_bytes(ct)/K,
|
capacity_bytes(ct)/K,
|
||||||
committed_bytes(ct)/K,
|
committed_bytes(ct)/K,
|
||||||
reserved_bytes(ct)/K);
|
reserved_bytes(ct)/K);
|
||||||
}
|
}
|
||||||
@ -2837,42 +2837,42 @@ void MetaspaceAux::verify_free_chunks() {
|
|||||||
|
|
||||||
void MetaspaceAux::verify_capacity() {
|
void MetaspaceAux::verify_capacity() {
|
||||||
#ifdef ASSERT
|
#ifdef ASSERT
|
||||||
size_t running_sum_capacity_bytes = allocated_capacity_bytes();
|
size_t running_sum_capacity_bytes = capacity_bytes();
|
||||||
// For purposes of the running sum of capacity, verify against capacity
|
// For purposes of the running sum of capacity, verify against capacity
|
||||||
size_t capacity_in_use_bytes = capacity_bytes_slow();
|
size_t capacity_in_use_bytes = capacity_bytes_slow();
|
||||||
assert(running_sum_capacity_bytes == capacity_in_use_bytes,
|
assert(running_sum_capacity_bytes == capacity_in_use_bytes,
|
||||||
err_msg("allocated_capacity_words() * BytesPerWord " SIZE_FORMAT
|
err_msg("capacity_words() * BytesPerWord " SIZE_FORMAT
|
||||||
" capacity_bytes_slow()" SIZE_FORMAT,
|
" capacity_bytes_slow()" SIZE_FORMAT,
|
||||||
running_sum_capacity_bytes, capacity_in_use_bytes));
|
running_sum_capacity_bytes, capacity_in_use_bytes));
|
||||||
for (Metaspace::MetadataType i = Metaspace::ClassType;
|
for (Metaspace::MetadataType i = Metaspace::ClassType;
|
||||||
i < Metaspace:: MetadataTypeCount;
|
i < Metaspace:: MetadataTypeCount;
|
||||||
i = (Metaspace::MetadataType)(i + 1)) {
|
i = (Metaspace::MetadataType)(i + 1)) {
|
||||||
size_t capacity_in_use_bytes = capacity_bytes_slow(i);
|
size_t capacity_in_use_bytes = capacity_bytes_slow(i);
|
||||||
assert(allocated_capacity_bytes(i) == capacity_in_use_bytes,
|
assert(capacity_bytes(i) == capacity_in_use_bytes,
|
||||||
err_msg("allocated_capacity_bytes(%u) " SIZE_FORMAT
|
err_msg("capacity_bytes(%u) " SIZE_FORMAT
|
||||||
" capacity_bytes_slow(%u)" SIZE_FORMAT,
|
" capacity_bytes_slow(%u)" SIZE_FORMAT,
|
||||||
i, allocated_capacity_bytes(i), i, capacity_in_use_bytes));
|
i, capacity_bytes(i), i, capacity_in_use_bytes));
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void MetaspaceAux::verify_used() {
|
void MetaspaceAux::verify_used() {
|
||||||
#ifdef ASSERT
|
#ifdef ASSERT
|
||||||
size_t running_sum_used_bytes = allocated_used_bytes();
|
size_t running_sum_used_bytes = used_bytes();
|
||||||
// For purposes of the running sum of used, verify against used
|
// For purposes of the running sum of used, verify against used
|
||||||
size_t used_in_use_bytes = used_bytes_slow();
|
size_t used_in_use_bytes = used_bytes_slow();
|
||||||
assert(allocated_used_bytes() == used_in_use_bytes,
|
assert(used_bytes() == used_in_use_bytes,
|
||||||
err_msg("allocated_used_bytes() " SIZE_FORMAT
|
err_msg("used_bytes() " SIZE_FORMAT
|
||||||
" used_bytes_slow()" SIZE_FORMAT,
|
" used_bytes_slow()" SIZE_FORMAT,
|
||||||
allocated_used_bytes(), used_in_use_bytes));
|
used_bytes(), used_in_use_bytes));
|
||||||
for (Metaspace::MetadataType i = Metaspace::ClassType;
|
for (Metaspace::MetadataType i = Metaspace::ClassType;
|
||||||
i < Metaspace:: MetadataTypeCount;
|
i < Metaspace:: MetadataTypeCount;
|
||||||
i = (Metaspace::MetadataType)(i + 1)) {
|
i = (Metaspace::MetadataType)(i + 1)) {
|
||||||
size_t used_in_use_bytes = used_bytes_slow(i);
|
size_t used_in_use_bytes = used_bytes_slow(i);
|
||||||
assert(allocated_used_bytes(i) == used_in_use_bytes,
|
assert(used_bytes(i) == used_in_use_bytes,
|
||||||
err_msg("allocated_used_bytes(%u) " SIZE_FORMAT
|
err_msg("used_bytes(%u) " SIZE_FORMAT
|
||||||
" used_bytes_slow(%u)" SIZE_FORMAT,
|
" used_bytes_slow(%u)" SIZE_FORMAT,
|
||||||
i, allocated_used_bytes(i), i, used_in_use_bytes));
|
i, used_bytes(i), i, used_in_use_bytes));
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
@ -280,11 +280,11 @@ class MetaspaceAux : AllStatic {
|
|||||||
// allocated to a Metaspace. This is used instead of
|
// allocated to a Metaspace. This is used instead of
|
||||||
// iterating over all the classloaders. One for each
|
// iterating over all the classloaders. One for each
|
||||||
// type of Metadata
|
// type of Metadata
|
||||||
static size_t _allocated_capacity_words[Metaspace:: MetadataTypeCount];
|
static size_t _capacity_words[Metaspace:: MetadataTypeCount];
|
||||||
// Running sum of space in all Metachunks that have
|
// Running sum of space in all Metachunks that
|
||||||
// are being used for metadata. One for each
|
// are being used for metadata. One for each
|
||||||
// type of Metadata.
|
// type of Metadata.
|
||||||
static size_t _allocated_used_words[Metaspace:: MetadataTypeCount];
|
static size_t _used_words[Metaspace:: MetadataTypeCount];
|
||||||
|
|
||||||
public:
|
public:
|
||||||
// Decrement and increment _allocated_capacity_words
|
// Decrement and increment _allocated_capacity_words
|
||||||
@ -308,32 +308,32 @@ class MetaspaceAux : AllStatic {
|
|||||||
static size_t free_chunks_total_bytes();
|
static size_t free_chunks_total_bytes();
|
||||||
static size_t free_chunks_total_bytes(Metaspace::MetadataType mdtype);
|
static size_t free_chunks_total_bytes(Metaspace::MetadataType mdtype);
|
||||||
|
|
||||||
static size_t allocated_capacity_words(Metaspace::MetadataType mdtype) {
|
static size_t capacity_words(Metaspace::MetadataType mdtype) {
|
||||||
return _allocated_capacity_words[mdtype];
|
return _capacity_words[mdtype];
|
||||||
}
|
}
|
||||||
static size_t allocated_capacity_words() {
|
static size_t capacity_words() {
|
||||||
return allocated_capacity_words(Metaspace::NonClassType) +
|
return capacity_words(Metaspace::NonClassType) +
|
||||||
allocated_capacity_words(Metaspace::ClassType);
|
capacity_words(Metaspace::ClassType);
|
||||||
}
|
}
|
||||||
static size_t allocated_capacity_bytes(Metaspace::MetadataType mdtype) {
|
static size_t capacity_bytes(Metaspace::MetadataType mdtype) {
|
||||||
return allocated_capacity_words(mdtype) * BytesPerWord;
|
return capacity_words(mdtype) * BytesPerWord;
|
||||||
}
|
}
|
||||||
static size_t allocated_capacity_bytes() {
|
static size_t capacity_bytes() {
|
||||||
return allocated_capacity_words() * BytesPerWord;
|
return capacity_words() * BytesPerWord;
|
||||||
}
|
}
|
||||||
|
|
||||||
static size_t allocated_used_words(Metaspace::MetadataType mdtype) {
|
static size_t used_words(Metaspace::MetadataType mdtype) {
|
||||||
return _allocated_used_words[mdtype];
|
return _used_words[mdtype];
|
||||||
}
|
}
|
||||||
static size_t allocated_used_words() {
|
static size_t used_words() {
|
||||||
return allocated_used_words(Metaspace::NonClassType) +
|
return used_words(Metaspace::NonClassType) +
|
||||||
allocated_used_words(Metaspace::ClassType);
|
used_words(Metaspace::ClassType);
|
||||||
}
|
}
|
||||||
static size_t allocated_used_bytes(Metaspace::MetadataType mdtype) {
|
static size_t used_bytes(Metaspace::MetadataType mdtype) {
|
||||||
return allocated_used_words(mdtype) * BytesPerWord;
|
return used_words(mdtype) * BytesPerWord;
|
||||||
}
|
}
|
||||||
static size_t allocated_used_bytes() {
|
static size_t used_bytes() {
|
||||||
return allocated_used_words() * BytesPerWord;
|
return used_words() * BytesPerWord;
|
||||||
}
|
}
|
||||||
|
|
||||||
static size_t free_bytes();
|
static size_t free_bytes();
|
||||||
|
@ -66,7 +66,7 @@ class MetaspacePerfCounters: public CHeapObj<mtInternal> {
|
|||||||
MetaspacePerfCounters* MetaspaceCounters::_perf_counters = NULL;
|
MetaspacePerfCounters* MetaspaceCounters::_perf_counters = NULL;
|
||||||
|
|
||||||
size_t MetaspaceCounters::used() {
|
size_t MetaspaceCounters::used() {
|
||||||
return MetaspaceAux::allocated_used_bytes();
|
return MetaspaceAux::used_bytes();
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t MetaspaceCounters::capacity() {
|
size_t MetaspaceCounters::capacity() {
|
||||||
@ -98,7 +98,7 @@ void MetaspaceCounters::update_performance_counters() {
|
|||||||
MetaspacePerfCounters* CompressedClassSpaceCounters::_perf_counters = NULL;
|
MetaspacePerfCounters* CompressedClassSpaceCounters::_perf_counters = NULL;
|
||||||
|
|
||||||
size_t CompressedClassSpaceCounters::used() {
|
size_t CompressedClassSpaceCounters::used() {
|
||||||
return MetaspaceAux::allocated_used_bytes(Metaspace::ClassType);
|
return MetaspaceAux::used_bytes(Metaspace::ClassType);
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t CompressedClassSpaceCounters::capacity() {
|
size_t CompressedClassSpaceCounters::capacity() {
|
||||||
|
@ -3408,6 +3408,10 @@ static void purge_previous_versions_internal(InstanceKlass* ik, int emcp_method_
|
|||||||
("purge: %s(%s): prev method @%d in version @%d is alive",
|
("purge: %s(%s): prev method @%d in version @%d is alive",
|
||||||
method->name()->as_C_string(),
|
method->name()->as_C_string(),
|
||||||
method->signature()->as_C_string(), j, i));
|
method->signature()->as_C_string(), j, i));
|
||||||
|
if (method->method_data() != NULL) {
|
||||||
|
// Clean out any weak method links
|
||||||
|
method->method_data()->clean_weak_method_links();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -3417,6 +3421,14 @@ static void purge_previous_versions_internal(InstanceKlass* ik, int emcp_method_
|
|||||||
("purge: previous version stats: live=%d, deleted=%d", live_count,
|
("purge: previous version stats: live=%d, deleted=%d", live_count,
|
||||||
deleted_count));
|
deleted_count));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Array<Method*>* methods = ik->methods();
|
||||||
|
int num_methods = methods->length();
|
||||||
|
for (int index2 = 0; index2 < num_methods; ++index2) {
|
||||||
|
if (methods->at(index2)->method_data() != NULL) {
|
||||||
|
methods->at(index2)->method_data()->clean_weak_method_links();
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// External interface for use during class unloading.
|
// External interface for use during class unloading.
|
||||||
|
@ -1531,9 +1531,35 @@ void MethodData::clean_extra_data_helper(DataLayout* dp, int shift, bool reset)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Remove SpeculativeTrapData entries that reference an unloaded
|
class CleanExtraDataClosure : public StackObj {
|
||||||
// method
|
public:
|
||||||
void MethodData::clean_extra_data(BoolObjectClosure* is_alive) {
|
virtual bool is_live(Method* m) = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
// Check for entries that reference an unloaded method
|
||||||
|
class CleanExtraDataKlassClosure : public CleanExtraDataClosure {
|
||||||
|
private:
|
||||||
|
BoolObjectClosure* _is_alive;
|
||||||
|
public:
|
||||||
|
CleanExtraDataKlassClosure(BoolObjectClosure* is_alive) : _is_alive(is_alive) {}
|
||||||
|
bool is_live(Method* m) {
|
||||||
|
return m->method_holder()->is_loader_alive(_is_alive);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// Check for entries that reference a redefined method
|
||||||
|
class CleanExtraDataMethodClosure : public CleanExtraDataClosure {
|
||||||
|
public:
|
||||||
|
CleanExtraDataMethodClosure() {}
|
||||||
|
bool is_live(Method* m) {
|
||||||
|
return m->on_stack();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
// Remove SpeculativeTrapData entries that reference an unloaded or
|
||||||
|
// redefined method
|
||||||
|
void MethodData::clean_extra_data(CleanExtraDataClosure* cl) {
|
||||||
DataLayout* dp = extra_data_base();
|
DataLayout* dp = extra_data_base();
|
||||||
DataLayout* end = extra_data_limit();
|
DataLayout* end = extra_data_limit();
|
||||||
|
|
||||||
@ -1544,7 +1570,7 @@ void MethodData::clean_extra_data(BoolObjectClosure* is_alive) {
|
|||||||
SpeculativeTrapData* data = new SpeculativeTrapData(dp);
|
SpeculativeTrapData* data = new SpeculativeTrapData(dp);
|
||||||
Method* m = data->method();
|
Method* m = data->method();
|
||||||
assert(m != NULL, "should have a method");
|
assert(m != NULL, "should have a method");
|
||||||
if (!m->method_holder()->is_loader_alive(is_alive)) {
|
if (!cl->is_live(m)) {
|
||||||
// "shift" accumulates the number of cells for dead
|
// "shift" accumulates the number of cells for dead
|
||||||
// SpeculativeTrapData entries that have been seen so
|
// SpeculativeTrapData entries that have been seen so
|
||||||
// far. Following entries must be shifted left by that many
|
// far. Following entries must be shifted left by that many
|
||||||
@ -1575,9 +1601,9 @@ void MethodData::clean_extra_data(BoolObjectClosure* is_alive) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Verify there's no unloaded method referenced by a
|
// Verify there's no unloaded or redefined method referenced by a
|
||||||
// SpeculativeTrapData entry
|
// SpeculativeTrapData entry
|
||||||
void MethodData::verify_extra_data_clean(BoolObjectClosure* is_alive) {
|
void MethodData::verify_extra_data_clean(CleanExtraDataClosure* cl) {
|
||||||
#ifdef ASSERT
|
#ifdef ASSERT
|
||||||
DataLayout* dp = extra_data_base();
|
DataLayout* dp = extra_data_base();
|
||||||
DataLayout* end = extra_data_limit();
|
DataLayout* end = extra_data_limit();
|
||||||
@ -1587,7 +1613,7 @@ void MethodData::verify_extra_data_clean(BoolObjectClosure* is_alive) {
|
|||||||
case DataLayout::speculative_trap_data_tag: {
|
case DataLayout::speculative_trap_data_tag: {
|
||||||
SpeculativeTrapData* data = new SpeculativeTrapData(dp);
|
SpeculativeTrapData* data = new SpeculativeTrapData(dp);
|
||||||
Method* m = data->method();
|
Method* m = data->method();
|
||||||
assert(m != NULL && m->method_holder()->is_loader_alive(is_alive), "Method should exist");
|
assert(m != NULL && cl->is_live(m), "Method should exist");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case DataLayout::bit_data_tag:
|
case DataLayout::bit_data_tag:
|
||||||
@ -1613,6 +1639,19 @@ void MethodData::clean_method_data(BoolObjectClosure* is_alive) {
|
|||||||
parameters->clean_weak_klass_links(is_alive);
|
parameters->clean_weak_klass_links(is_alive);
|
||||||
}
|
}
|
||||||
|
|
||||||
clean_extra_data(is_alive);
|
CleanExtraDataKlassClosure cl(is_alive);
|
||||||
verify_extra_data_clean(is_alive);
|
clean_extra_data(&cl);
|
||||||
|
verify_extra_data_clean(&cl);
|
||||||
|
}
|
||||||
|
|
||||||
|
void MethodData::clean_weak_method_links() {
|
||||||
|
for (ProfileData* data = first_data();
|
||||||
|
is_valid(data);
|
||||||
|
data = next_data(data)) {
|
||||||
|
data->clean_weak_method_links();
|
||||||
|
}
|
||||||
|
|
||||||
|
CleanExtraDataMethodClosure cl;
|
||||||
|
clean_extra_data(&cl);
|
||||||
|
verify_extra_data_clean(&cl);
|
||||||
}
|
}
|
||||||
|
@ -251,6 +251,9 @@ public:
|
|||||||
|
|
||||||
// GC support
|
// GC support
|
||||||
void clean_weak_klass_links(BoolObjectClosure* cl);
|
void clean_weak_klass_links(BoolObjectClosure* cl);
|
||||||
|
|
||||||
|
// Redefinition support
|
||||||
|
void clean_weak_method_links();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@ -506,6 +509,9 @@ public:
|
|||||||
// GC support
|
// GC support
|
||||||
virtual void clean_weak_klass_links(BoolObjectClosure* is_alive_closure) {}
|
virtual void clean_weak_klass_links(BoolObjectClosure* is_alive_closure) {}
|
||||||
|
|
||||||
|
// Redefinition support
|
||||||
|
virtual void clean_weak_method_links() {}
|
||||||
|
|
||||||
// CI translation: ProfileData can represent both MethodDataOop data
|
// CI translation: ProfileData can represent both MethodDataOop data
|
||||||
// as well as CIMethodData data. This function is provided for translating
|
// as well as CIMethodData data. This function is provided for translating
|
||||||
// an oop in a ProfileData to the ci equivalent. Generally speaking,
|
// an oop in a ProfileData to the ci equivalent. Generally speaking,
|
||||||
@ -1989,6 +1995,7 @@ public:
|
|||||||
//
|
//
|
||||||
|
|
||||||
CC_INTERP_ONLY(class BytecodeInterpreter;)
|
CC_INTERP_ONLY(class BytecodeInterpreter;)
|
||||||
|
class CleanExtraDataClosure;
|
||||||
|
|
||||||
class MethodData : public Metadata {
|
class MethodData : public Metadata {
|
||||||
friend class VMStructs;
|
friend class VMStructs;
|
||||||
@ -2146,9 +2153,9 @@ private:
|
|||||||
static bool profile_parameters_jsr292_only();
|
static bool profile_parameters_jsr292_only();
|
||||||
static bool profile_all_parameters();
|
static bool profile_all_parameters();
|
||||||
|
|
||||||
void clean_extra_data(BoolObjectClosure* is_alive);
|
void clean_extra_data(CleanExtraDataClosure* cl);
|
||||||
void clean_extra_data_helper(DataLayout* dp, int shift, bool reset = false);
|
void clean_extra_data_helper(DataLayout* dp, int shift, bool reset = false);
|
||||||
void verify_extra_data_clean(BoolObjectClosure* is_alive);
|
void verify_extra_data_clean(CleanExtraDataClosure* cl);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
static int header_size() {
|
static int header_size() {
|
||||||
@ -2440,6 +2447,8 @@ public:
|
|||||||
static bool profile_return_jsr292_only();
|
static bool profile_return_jsr292_only();
|
||||||
|
|
||||||
void clean_method_data(BoolObjectClosure* is_alive);
|
void clean_method_data(BoolObjectClosure* is_alive);
|
||||||
|
|
||||||
|
void clean_weak_method_links();
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // SHARE_VM_OOPS_METHODDATAOOP_HPP
|
#endif // SHARE_VM_OOPS_METHODDATAOOP_HPP
|
||||||
|
@ -70,6 +70,7 @@ public:
|
|||||||
|
|
||||||
JVMState* ParseGenerator::generate(JVMState* jvms, Parse* parent_parser) {
|
JVMState* ParseGenerator::generate(JVMState* jvms, Parse* parent_parser) {
|
||||||
Compile* C = Compile::current();
|
Compile* C = Compile::current();
|
||||||
|
C->print_inlining_update(this);
|
||||||
|
|
||||||
if (is_osr()) {
|
if (is_osr()) {
|
||||||
// The JVMS for a OSR has a single argument (see its TypeFunc).
|
// The JVMS for a OSR has a single argument (see its TypeFunc).
|
||||||
@ -126,6 +127,7 @@ class DirectCallGenerator : public CallGenerator {
|
|||||||
|
|
||||||
JVMState* DirectCallGenerator::generate(JVMState* jvms, Parse* parent_parser) {
|
JVMState* DirectCallGenerator::generate(JVMState* jvms, Parse* parent_parser) {
|
||||||
GraphKit kit(jvms);
|
GraphKit kit(jvms);
|
||||||
|
kit.C->print_inlining_update(this);
|
||||||
bool is_static = method()->is_static();
|
bool is_static = method()->is_static();
|
||||||
address target = is_static ? SharedRuntime::get_resolve_static_call_stub()
|
address target = is_static ? SharedRuntime::get_resolve_static_call_stub()
|
||||||
: SharedRuntime::get_resolve_opt_virtual_call_stub();
|
: SharedRuntime::get_resolve_opt_virtual_call_stub();
|
||||||
@ -178,6 +180,8 @@ JVMState* VirtualCallGenerator::generate(JVMState* jvms, Parse* parent_parser) {
|
|||||||
GraphKit kit(jvms);
|
GraphKit kit(jvms);
|
||||||
Node* receiver = kit.argument(0);
|
Node* receiver = kit.argument(0);
|
||||||
|
|
||||||
|
kit.C->print_inlining_update(this);
|
||||||
|
|
||||||
if (kit.C->log() != NULL) {
|
if (kit.C->log() != NULL) {
|
||||||
kit.C->log()->elem("virtual_call bci='%d'", jvms->bci());
|
kit.C->log()->elem("virtual_call bci='%d'", jvms->bci());
|
||||||
}
|
}
|
||||||
@ -271,14 +275,13 @@ class LateInlineCallGenerator : public DirectCallGenerator {
|
|||||||
LateInlineCallGenerator(ciMethod* method, CallGenerator* inline_cg) :
|
LateInlineCallGenerator(ciMethod* method, CallGenerator* inline_cg) :
|
||||||
DirectCallGenerator(method, true), _inline_cg(inline_cg) {}
|
DirectCallGenerator(method, true), _inline_cg(inline_cg) {}
|
||||||
|
|
||||||
virtual bool is_late_inline() const { return true; }
|
virtual bool is_late_inline() const { return true; }
|
||||||
|
|
||||||
// Convert the CallStaticJava into an inline
|
// Convert the CallStaticJava into an inline
|
||||||
virtual void do_late_inline();
|
virtual void do_late_inline();
|
||||||
|
|
||||||
virtual JVMState* generate(JVMState* jvms, Parse* parent_parser) {
|
virtual JVMState* generate(JVMState* jvms, Parse* parent_parser) {
|
||||||
Compile *C = Compile::current();
|
Compile *C = Compile::current();
|
||||||
C->print_inlining_skip(this);
|
|
||||||
|
|
||||||
// Record that this call site should be revisited once the main
|
// Record that this call site should be revisited once the main
|
||||||
// parse is finished.
|
// parse is finished.
|
||||||
@ -296,10 +299,11 @@ class LateInlineCallGenerator : public DirectCallGenerator {
|
|||||||
virtual void print_inlining_late(const char* msg) {
|
virtual void print_inlining_late(const char* msg) {
|
||||||
CallNode* call = call_node();
|
CallNode* call = call_node();
|
||||||
Compile* C = Compile::current();
|
Compile* C = Compile::current();
|
||||||
C->print_inlining_insert(this);
|
C->print_inlining_assert_ready();
|
||||||
C->print_inlining(method(), call->jvms()->depth()-1, call->jvms()->bci(), msg);
|
C->print_inlining(method(), call->jvms()->depth()-1, call->jvms()->bci(), msg);
|
||||||
|
C->print_inlining_move_to(this);
|
||||||
|
C->print_inlining_update_delayed(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
void LateInlineCallGenerator::do_late_inline() {
|
void LateInlineCallGenerator::do_late_inline() {
|
||||||
@ -360,6 +364,10 @@ void LateInlineCallGenerator::do_late_inline() {
|
|||||||
map->set_argument(jvms, i1, call->in(TypeFunc::Parms + i1));
|
map->set_argument(jvms, i1, call->in(TypeFunc::Parms + i1));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
C->print_inlining_assert_ready();
|
||||||
|
|
||||||
|
C->print_inlining_move_to(this);
|
||||||
|
|
||||||
// This check is done here because for_method_handle_inline() method
|
// This check is done here because for_method_handle_inline() method
|
||||||
// needs jvms for inlined state.
|
// needs jvms for inlined state.
|
||||||
if (!do_late_inline_check(jvms)) {
|
if (!do_late_inline_check(jvms)) {
|
||||||
@ -367,8 +375,6 @@ void LateInlineCallGenerator::do_late_inline() {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
C->print_inlining_insert(this);
|
|
||||||
|
|
||||||
CompileLog* log = C->log();
|
CompileLog* log = C->log();
|
||||||
if (log != NULL) {
|
if (log != NULL) {
|
||||||
log->head("late_inline method='%d'", log->identify(method()));
|
log->head("late_inline method='%d'", log->identify(method()));
|
||||||
@ -388,7 +394,7 @@ void LateInlineCallGenerator::do_late_inline() {
|
|||||||
C->set_default_node_notes(entry_nn);
|
C->set_default_node_notes(entry_nn);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Now perform the inling using the synthesized JVMState
|
// Now perform the inlining using the synthesized JVMState
|
||||||
JVMState* new_jvms = _inline_cg->generate(jvms, NULL);
|
JVMState* new_jvms = _inline_cg->generate(jvms, NULL);
|
||||||
if (new_jvms == NULL) return; // no change
|
if (new_jvms == NULL) return; // no change
|
||||||
if (C->failing()) return;
|
if (C->failing()) return;
|
||||||
@ -431,6 +437,7 @@ class LateInlineMHCallGenerator : public LateInlineCallGenerator {
|
|||||||
|
|
||||||
virtual JVMState* generate(JVMState* jvms, Parse* parent_parser) {
|
virtual JVMState* generate(JVMState* jvms, Parse* parent_parser) {
|
||||||
JVMState* new_jvms = LateInlineCallGenerator::generate(jvms, parent_parser);
|
JVMState* new_jvms = LateInlineCallGenerator::generate(jvms, parent_parser);
|
||||||
|
|
||||||
if (_input_not_const) {
|
if (_input_not_const) {
|
||||||
// inlining won't be possible so no need to enqueue right now.
|
// inlining won't be possible so no need to enqueue right now.
|
||||||
call_node()->set_generator(this);
|
call_node()->set_generator(this);
|
||||||
@ -439,17 +446,14 @@ class LateInlineMHCallGenerator : public LateInlineCallGenerator {
|
|||||||
}
|
}
|
||||||
return new_jvms;
|
return new_jvms;
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void print_inlining_late(const char* msg) {
|
|
||||||
if (!_input_not_const) return;
|
|
||||||
LateInlineCallGenerator::print_inlining_late(msg);
|
|
||||||
}
|
|
||||||
};
|
};
|
||||||
|
|
||||||
bool LateInlineMHCallGenerator::do_late_inline_check(JVMState* jvms) {
|
bool LateInlineMHCallGenerator::do_late_inline_check(JVMState* jvms) {
|
||||||
|
|
||||||
CallGenerator* cg = for_method_handle_inline(jvms, _caller, method(), _input_not_const);
|
CallGenerator* cg = for_method_handle_inline(jvms, _caller, method(), _input_not_const);
|
||||||
|
|
||||||
|
Compile::current()->print_inlining_update_delayed(this);
|
||||||
|
|
||||||
if (!_input_not_const) {
|
if (!_input_not_const) {
|
||||||
_attempt++;
|
_attempt++;
|
||||||
}
|
}
|
||||||
@ -479,8 +483,6 @@ class LateInlineStringCallGenerator : public LateInlineCallGenerator {
|
|||||||
|
|
||||||
virtual JVMState* generate(JVMState* jvms, Parse* parent_parser) {
|
virtual JVMState* generate(JVMState* jvms, Parse* parent_parser) {
|
||||||
Compile *C = Compile::current();
|
Compile *C = Compile::current();
|
||||||
C->print_inlining_skip(this);
|
|
||||||
|
|
||||||
C->add_string_late_inline(this);
|
C->add_string_late_inline(this);
|
||||||
|
|
||||||
JVMState* new_jvms = DirectCallGenerator::generate(jvms, parent_parser);
|
JVMState* new_jvms = DirectCallGenerator::generate(jvms, parent_parser);
|
||||||
@ -502,7 +504,6 @@ class LateInlineBoxingCallGenerator : public LateInlineCallGenerator {
|
|||||||
|
|
||||||
virtual JVMState* generate(JVMState* jvms, Parse* parent_parser) {
|
virtual JVMState* generate(JVMState* jvms, Parse* parent_parser) {
|
||||||
Compile *C = Compile::current();
|
Compile *C = Compile::current();
|
||||||
C->print_inlining_skip(this);
|
|
||||||
|
|
||||||
C->add_boxing_late_inline(this);
|
C->add_boxing_late_inline(this);
|
||||||
|
|
||||||
@ -554,6 +555,8 @@ CallGenerator* CallGenerator::for_warm_call(WarmCallInfo* ci,
|
|||||||
|
|
||||||
JVMState* WarmCallGenerator::generate(JVMState* jvms, Parse* parent_parser) {
|
JVMState* WarmCallGenerator::generate(JVMState* jvms, Parse* parent_parser) {
|
||||||
Compile* C = Compile::current();
|
Compile* C = Compile::current();
|
||||||
|
C->print_inlining_update(this);
|
||||||
|
|
||||||
if (C->log() != NULL) {
|
if (C->log() != NULL) {
|
||||||
C->log()->elem("warm_call bci='%d'", jvms->bci());
|
C->log()->elem("warm_call bci='%d'", jvms->bci());
|
||||||
}
|
}
|
||||||
@ -632,6 +635,7 @@ CallGenerator* CallGenerator::for_predicted_call(ciKlass* predicted_receiver,
|
|||||||
|
|
||||||
JVMState* PredictedCallGenerator::generate(JVMState* jvms, Parse* parent_parser) {
|
JVMState* PredictedCallGenerator::generate(JVMState* jvms, Parse* parent_parser) {
|
||||||
GraphKit kit(jvms);
|
GraphKit kit(jvms);
|
||||||
|
kit.C->print_inlining_update(this);
|
||||||
PhaseGVN& gvn = kit.gvn();
|
PhaseGVN& gvn = kit.gvn();
|
||||||
// We need an explicit receiver null_check before checking its type.
|
// We need an explicit receiver null_check before checking its type.
|
||||||
// We share a map with the caller, so his JVMS gets adjusted.
|
// We share a map with the caller, so his JVMS gets adjusted.
|
||||||
@ -779,6 +783,9 @@ CallGenerator* CallGenerator::for_method_handle_inline(JVMState* jvms, ciMethod*
|
|||||||
assert(cg == NULL || !cg->is_late_inline() || cg->is_mh_late_inline(), "no late inline here");
|
assert(cg == NULL || !cg->is_late_inline() || cg->is_mh_late_inline(), "no late inline here");
|
||||||
if (cg != NULL && cg->is_inline())
|
if (cg != NULL && cg->is_inline())
|
||||||
return cg;
|
return cg;
|
||||||
|
} else {
|
||||||
|
const char* msg = "receiver not constant";
|
||||||
|
if (PrintInlining) C->print_inlining(callee, jvms->depth() - 1, jvms->bci(), msg);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -844,11 +851,13 @@ CallGenerator* CallGenerator::for_method_handle_inline(JVMState* jvms, ciMethod*
|
|||||||
// provide us with a type
|
// provide us with a type
|
||||||
speculative_receiver_type = receiver_type->speculative_type();
|
speculative_receiver_type = receiver_type->speculative_type();
|
||||||
}
|
}
|
||||||
|
|
||||||
CallGenerator* cg = C->call_generator(target, vtable_index, call_does_dispatch, jvms, true, PROB_ALWAYS, speculative_receiver_type, true, true);
|
CallGenerator* cg = C->call_generator(target, vtable_index, call_does_dispatch, jvms, true, PROB_ALWAYS, speculative_receiver_type, true, true);
|
||||||
assert(cg == NULL || !cg->is_late_inline() || cg->is_mh_late_inline(), "no late inline here");
|
assert(cg == NULL || !cg->is_late_inline() || cg->is_mh_late_inline(), "no late inline here");
|
||||||
if (cg != NULL && cg->is_inline())
|
if (cg != NULL && cg->is_inline())
|
||||||
return cg;
|
return cg;
|
||||||
|
} else {
|
||||||
|
const char* msg = "member_name not constant";
|
||||||
|
if (PrintInlining) C->print_inlining(callee, jvms->depth() - 1, jvms->bci(), msg);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -904,6 +913,7 @@ JVMState* PredictedIntrinsicGenerator::generate(JVMState* jvms, Parse* parent_pa
|
|||||||
if (kit.failing())
|
if (kit.failing())
|
||||||
return NULL; // might happen because of NodeCountInliningCutoff
|
return NULL; // might happen because of NodeCountInliningCutoff
|
||||||
|
|
||||||
|
kit.C->print_inlining_update(this);
|
||||||
SafePointNode* slow_map = NULL;
|
SafePointNode* slow_map = NULL;
|
||||||
JVMState* slow_jvms;
|
JVMState* slow_jvms;
|
||||||
if (slow_ctl != NULL) {
|
if (slow_ctl != NULL) {
|
||||||
@ -1017,6 +1027,7 @@ CallGenerator::for_uncommon_trap(ciMethod* m,
|
|||||||
|
|
||||||
JVMState* UncommonTrapCallGenerator::generate(JVMState* jvms, Parse* parent_parser) {
|
JVMState* UncommonTrapCallGenerator::generate(JVMState* jvms, Parse* parent_parser) {
|
||||||
GraphKit kit(jvms);
|
GraphKit kit(jvms);
|
||||||
|
kit.C->print_inlining_update(this);
|
||||||
// Take the trap with arguments pushed on the stack. (Cf. null_check_receiver).
|
// Take the trap with arguments pushed on the stack. (Cf. null_check_receiver).
|
||||||
int nargs = method()->arg_size();
|
int nargs = method()->arg_size();
|
||||||
kit.inc_sp(nargs);
|
kit.inc_sp(nargs);
|
||||||
|
@ -662,6 +662,7 @@ Compile::Compile( ciEnv* ci_env, C2Compiler* compiler, ciMethod* target, int osr
|
|||||||
_inlining_progress(false),
|
_inlining_progress(false),
|
||||||
_inlining_incrementally(false),
|
_inlining_incrementally(false),
|
||||||
_print_inlining_list(NULL),
|
_print_inlining_list(NULL),
|
||||||
|
_print_inlining_stream(NULL),
|
||||||
_print_inlining_idx(0),
|
_print_inlining_idx(0),
|
||||||
_preserve_jvm_state(0) {
|
_preserve_jvm_state(0) {
|
||||||
C = this;
|
C = this;
|
||||||
@ -723,9 +724,7 @@ Compile::Compile( ciEnv* ci_env, C2Compiler* compiler, ciMethod* target, int osr
|
|||||||
PhaseGVN gvn(node_arena(), estimated_size);
|
PhaseGVN gvn(node_arena(), estimated_size);
|
||||||
set_initial_gvn(&gvn);
|
set_initial_gvn(&gvn);
|
||||||
|
|
||||||
if (print_inlining() || print_intrinsics()) {
|
print_inlining_init();
|
||||||
_print_inlining_list = new (comp_arena())GrowableArray<PrintInliningBuffer>(comp_arena(), 1, 1, PrintInliningBuffer());
|
|
||||||
}
|
|
||||||
{ // Scope for timing the parser
|
{ // Scope for timing the parser
|
||||||
TracePhase t3("parse", &_t_parser, true);
|
TracePhase t3("parse", &_t_parser, true);
|
||||||
|
|
||||||
@ -967,6 +966,7 @@ Compile::Compile( ciEnv* ci_env,
|
|||||||
_inlining_progress(false),
|
_inlining_progress(false),
|
||||||
_inlining_incrementally(false),
|
_inlining_incrementally(false),
|
||||||
_print_inlining_list(NULL),
|
_print_inlining_list(NULL),
|
||||||
|
_print_inlining_stream(NULL),
|
||||||
_print_inlining_idx(0),
|
_print_inlining_idx(0),
|
||||||
_preserve_jvm_state(0),
|
_preserve_jvm_state(0),
|
||||||
_allowed_reasons(0) {
|
_allowed_reasons(0) {
|
||||||
@ -2023,6 +2023,8 @@ void Compile::Optimize() {
|
|||||||
ResourceMark rm;
|
ResourceMark rm;
|
||||||
int loop_opts_cnt;
|
int loop_opts_cnt;
|
||||||
|
|
||||||
|
print_inlining_reinit();
|
||||||
|
|
||||||
NOT_PRODUCT( verify_graph_edges(); )
|
NOT_PRODUCT( verify_graph_edges(); )
|
||||||
|
|
||||||
print_method(PHASE_AFTER_PARSING);
|
print_method(PHASE_AFTER_PARSING);
|
||||||
@ -3755,30 +3757,114 @@ void Compile::ConstantTable::fill_jump_table(CodeBuffer& cb, MachConstantNode* n
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Compile::dump_inlining() {
|
// The message about the current inlining is accumulated in
|
||||||
|
// _print_inlining_stream and transfered into the _print_inlining_list
|
||||||
|
// once we know whether inlining succeeds or not. For regular
|
||||||
|
// inlining, messages are appended to the buffer pointed by
|
||||||
|
// _print_inlining_idx in the _print_inlining_list. For late inlining,
|
||||||
|
// a new buffer is added after _print_inlining_idx in the list. This
|
||||||
|
// way we can update the inlining message for late inlining call site
|
||||||
|
// when the inlining is attempted again.
|
||||||
|
void Compile::print_inlining_init() {
|
||||||
if (print_inlining() || print_intrinsics()) {
|
if (print_inlining() || print_intrinsics()) {
|
||||||
|
_print_inlining_stream = new stringStream();
|
||||||
|
_print_inlining_list = new (comp_arena())GrowableArray<PrintInliningBuffer>(comp_arena(), 1, 1, PrintInliningBuffer());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void Compile::print_inlining_reinit() {
|
||||||
|
if (print_inlining() || print_intrinsics()) {
|
||||||
|
// Re allocate buffer when we change ResourceMark
|
||||||
|
_print_inlining_stream = new stringStream();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void Compile::print_inlining_reset() {
|
||||||
|
_print_inlining_stream->reset();
|
||||||
|
}
|
||||||
|
|
||||||
|
void Compile::print_inlining_commit() {
|
||||||
|
assert(print_inlining() || print_intrinsics(), "PrintInlining off?");
|
||||||
|
// Transfer the message from _print_inlining_stream to the current
|
||||||
|
// _print_inlining_list buffer and clear _print_inlining_stream.
|
||||||
|
_print_inlining_list->at(_print_inlining_idx).ss()->write(_print_inlining_stream->as_string(), _print_inlining_stream->size());
|
||||||
|
print_inlining_reset();
|
||||||
|
}
|
||||||
|
|
||||||
|
void Compile::print_inlining_push() {
|
||||||
|
// Add new buffer to the _print_inlining_list at current position
|
||||||
|
_print_inlining_idx++;
|
||||||
|
_print_inlining_list->insert_before(_print_inlining_idx, PrintInliningBuffer());
|
||||||
|
}
|
||||||
|
|
||||||
|
Compile::PrintInliningBuffer& Compile::print_inlining_current() {
|
||||||
|
return _print_inlining_list->at(_print_inlining_idx);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Compile::print_inlining_update(CallGenerator* cg) {
|
||||||
|
if (print_inlining() || print_intrinsics()) {
|
||||||
|
if (!cg->is_late_inline()) {
|
||||||
|
if (print_inlining_current().cg() != NULL) {
|
||||||
|
print_inlining_push();
|
||||||
|
}
|
||||||
|
print_inlining_commit();
|
||||||
|
} else {
|
||||||
|
if (print_inlining_current().cg() != cg &&
|
||||||
|
(print_inlining_current().cg() != NULL ||
|
||||||
|
print_inlining_current().ss()->size() != 0)) {
|
||||||
|
print_inlining_push();
|
||||||
|
}
|
||||||
|
print_inlining_commit();
|
||||||
|
print_inlining_current().set_cg(cg);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void Compile::print_inlining_move_to(CallGenerator* cg) {
|
||||||
|
// We resume inlining at a late inlining call site. Locate the
|
||||||
|
// corresponding inlining buffer so that we can update it.
|
||||||
|
if (print_inlining()) {
|
||||||
|
for (int i = 0; i < _print_inlining_list->length(); i++) {
|
||||||
|
if (_print_inlining_list->adr_at(i)->cg() == cg) {
|
||||||
|
_print_inlining_idx = i;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
ShouldNotReachHere();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void Compile::print_inlining_update_delayed(CallGenerator* cg) {
|
||||||
|
if (print_inlining()) {
|
||||||
|
assert(_print_inlining_stream->size() > 0, "missing inlining msg");
|
||||||
|
assert(print_inlining_current().cg() == cg, "wrong entry");
|
||||||
|
// replace message with new message
|
||||||
|
_print_inlining_list->at_put(_print_inlining_idx, PrintInliningBuffer());
|
||||||
|
print_inlining_commit();
|
||||||
|
print_inlining_current().set_cg(cg);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void Compile::print_inlining_assert_ready() {
|
||||||
|
assert(!_print_inlining || _print_inlining_stream->size() == 0, "loosing data");
|
||||||
|
}
|
||||||
|
|
||||||
|
void Compile::dump_inlining() {
|
||||||
|
bool do_print_inlining = print_inlining() || print_intrinsics();
|
||||||
|
if (do_print_inlining) {
|
||||||
// Print inlining message for candidates that we couldn't inline
|
// Print inlining message for candidates that we couldn't inline
|
||||||
// for lack of space or non constant receiver
|
// for lack of space
|
||||||
for (int i = 0; i < _late_inlines.length(); i++) {
|
for (int i = 0; i < _late_inlines.length(); i++) {
|
||||||
CallGenerator* cg = _late_inlines.at(i);
|
CallGenerator* cg = _late_inlines.at(i);
|
||||||
cg->print_inlining_late("live nodes > LiveNodeCountInliningCutoff");
|
if (!cg->is_mh_late_inline()) {
|
||||||
}
|
const char* msg = "live nodes > LiveNodeCountInliningCutoff";
|
||||||
Unique_Node_List useful;
|
if (do_print_inlining) {
|
||||||
useful.push(root());
|
cg->print_inlining_late(msg);
|
||||||
for (uint next = 0; next < useful.size(); ++next) {
|
}
|
||||||
Node* n = useful.at(next);
|
|
||||||
if (n->is_Call() && n->as_Call()->generator() != NULL && n->as_Call()->generator()->call_node() == n) {
|
|
||||||
CallNode* call = n->as_Call();
|
|
||||||
CallGenerator* cg = call->generator();
|
|
||||||
cg->print_inlining_late("receiver not constant");
|
|
||||||
}
|
|
||||||
uint max = n->len();
|
|
||||||
for ( uint i = 0; i < max; ++i ) {
|
|
||||||
Node *m = n->in(i);
|
|
||||||
if ( m == NULL ) continue;
|
|
||||||
useful.push(m);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
if (do_print_inlining) {
|
||||||
for (int i = 0; i < _print_inlining_list->length(); i++) {
|
for (int i = 0; i < _print_inlining_list->length(); i++) {
|
||||||
tty->print(_print_inlining_list->adr_at(i)->ss()->as_string());
|
tty->print(_print_inlining_list->adr_at(i)->ss()->as_string());
|
||||||
}
|
}
|
||||||
|
@ -416,6 +416,7 @@ class Compile : public Phase {
|
|||||||
void set_cg(CallGenerator* cg) { _cg = cg; }
|
void set_cg(CallGenerator* cg) { _cg = cg; }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
stringStream* _print_inlining_stream;
|
||||||
GrowableArray<PrintInliningBuffer>* _print_inlining_list;
|
GrowableArray<PrintInliningBuffer>* _print_inlining_list;
|
||||||
int _print_inlining_idx;
|
int _print_inlining_idx;
|
||||||
|
|
||||||
@ -433,33 +434,24 @@ class Compile : public Phase {
|
|||||||
|
|
||||||
void* _replay_inline_data; // Pointer to data loaded from file
|
void* _replay_inline_data; // Pointer to data loaded from file
|
||||||
|
|
||||||
|
void print_inlining_init();
|
||||||
|
void print_inlining_reinit();
|
||||||
|
void print_inlining_commit();
|
||||||
|
void print_inlining_push();
|
||||||
|
PrintInliningBuffer& print_inlining_current();
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
outputStream* print_inlining_stream() const {
|
outputStream* print_inlining_stream() const {
|
||||||
return _print_inlining_list->adr_at(_print_inlining_idx)->ss();
|
assert(print_inlining() || print_intrinsics(), "PrintInlining off?");
|
||||||
|
return _print_inlining_stream;
|
||||||
}
|
}
|
||||||
|
|
||||||
void print_inlining_skip(CallGenerator* cg) {
|
void print_inlining_update(CallGenerator* cg);
|
||||||
if (_print_inlining) {
|
void print_inlining_update_delayed(CallGenerator* cg);
|
||||||
_print_inlining_list->adr_at(_print_inlining_idx)->set_cg(cg);
|
void print_inlining_move_to(CallGenerator* cg);
|
||||||
_print_inlining_idx++;
|
void print_inlining_assert_ready();
|
||||||
_print_inlining_list->insert_before(_print_inlining_idx, PrintInliningBuffer());
|
void print_inlining_reset();
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void print_inlining_insert(CallGenerator* cg) {
|
|
||||||
if (_print_inlining) {
|
|
||||||
for (int i = 0; i < _print_inlining_list->length(); i++) {
|
|
||||||
if (_print_inlining_list->adr_at(i)->cg() == cg) {
|
|
||||||
_print_inlining_list->insert_before(i+1, PrintInliningBuffer());
|
|
||||||
_print_inlining_idx = i+1;
|
|
||||||
_print_inlining_list->adr_at(i)->set_cg(NULL);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
ShouldNotReachHere();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void print_inlining(ciMethod* method, int inline_level, int bci, const char* msg = NULL) {
|
void print_inlining(ciMethod* method, int inline_level, int bci, const char* msg = NULL) {
|
||||||
stringStream ss;
|
stringStream ss;
|
||||||
|
@ -294,6 +294,8 @@ CallGenerator* Compile::call_generator(ciMethod* callee, int vtable_index, bool
|
|||||||
// There was no special inlining tactic, or it bailed out.
|
// There was no special inlining tactic, or it bailed out.
|
||||||
// Use a more generic tactic, like a simple call.
|
// Use a more generic tactic, like a simple call.
|
||||||
if (call_does_dispatch) {
|
if (call_does_dispatch) {
|
||||||
|
const char* msg = "virtual call";
|
||||||
|
if (PrintInlining) print_inlining(callee, jvms->depth() - 1, jvms->bci(), msg);
|
||||||
return CallGenerator::for_virtual_call(callee, vtable_index);
|
return CallGenerator::for_virtual_call(callee, vtable_index);
|
||||||
} else {
|
} else {
|
||||||
// Class Hierarchy Analysis or Type Profile reveals a unique target,
|
// Class Hierarchy Analysis or Type Profile reveals a unique target,
|
||||||
@ -396,6 +398,8 @@ void Parse::do_call() {
|
|||||||
// our contribution to it is cleaned up right here.
|
// our contribution to it is cleaned up right here.
|
||||||
kill_dead_locals();
|
kill_dead_locals();
|
||||||
|
|
||||||
|
C->print_inlining_assert_ready();
|
||||||
|
|
||||||
// Set frequently used booleans
|
// Set frequently used booleans
|
||||||
const bool is_virtual = bc() == Bytecodes::_invokevirtual;
|
const bool is_virtual = bc() == Bytecodes::_invokevirtual;
|
||||||
const bool is_virtual_or_interface = is_virtual || bc() == Bytecodes::_invokeinterface;
|
const bool is_virtual_or_interface = is_virtual || bc() == Bytecodes::_invokeinterface;
|
||||||
@ -531,7 +535,8 @@ void Parse::do_call() {
|
|||||||
// intrinsic was expecting to optimize. Should always be possible to
|
// intrinsic was expecting to optimize. Should always be possible to
|
||||||
// get a normal java call that may inline in that case
|
// get a normal java call that may inline in that case
|
||||||
cg = C->call_generator(cg->method(), vtable_index, call_does_dispatch, jvms, try_inline, prof_factor(), speculative_receiver_type, /* allow_intrinsics= */ false);
|
cg = C->call_generator(cg->method(), vtable_index, call_does_dispatch, jvms, try_inline, prof_factor(), speculative_receiver_type, /* allow_intrinsics= */ false);
|
||||||
if ((new_jvms = cg->generate(jvms, this)) == NULL) {
|
new_jvms = cg->generate(jvms, this);
|
||||||
|
if (new_jvms == NULL) {
|
||||||
guarantee(failing(), "call failed to generate: calls should work");
|
guarantee(failing(), "call failed to generate: calls should work");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -620,6 +620,7 @@ JVMState* LibraryIntrinsic::generate(JVMState* jvms, Parse* parent_parser) {
|
|||||||
}
|
}
|
||||||
// Push the result from the inlined method onto the stack.
|
// Push the result from the inlined method onto the stack.
|
||||||
kit.push_result();
|
kit.push_result();
|
||||||
|
C->print_inlining_update(this);
|
||||||
return kit.transfer_exceptions_into_jvms();
|
return kit.transfer_exceptions_into_jvms();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -637,6 +638,7 @@ JVMState* LibraryIntrinsic::generate(JVMState* jvms, Parse* parent_parser) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
C->gather_intrinsic_statistics(intrinsic_id(), is_virtual(), Compile::_intrinsic_failed);
|
C->gather_intrinsic_statistics(intrinsic_id(), is_virtual(), Compile::_intrinsic_failed);
|
||||||
|
C->print_inlining_update(this);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3877,6 +3877,7 @@ void TestMetaspaceAux_test();
|
|||||||
void TestMetachunk_test();
|
void TestMetachunk_test();
|
||||||
void TestVirtualSpaceNode_test();
|
void TestVirtualSpaceNode_test();
|
||||||
void TestNewSize_test();
|
void TestNewSize_test();
|
||||||
|
void TestOldSize_test();
|
||||||
void TestKlass_test();
|
void TestKlass_test();
|
||||||
void TestBitMap_test();
|
void TestBitMap_test();
|
||||||
#if INCLUDE_ALL_GCS
|
#if INCLUDE_ALL_GCS
|
||||||
@ -3903,6 +3904,7 @@ void execute_internal_vm_tests() {
|
|||||||
run_unit_test(AltHashing::test_alt_hash());
|
run_unit_test(AltHashing::test_alt_hash());
|
||||||
run_unit_test(test_loggc_filename());
|
run_unit_test(test_loggc_filename());
|
||||||
run_unit_test(TestNewSize_test());
|
run_unit_test(TestNewSize_test());
|
||||||
|
run_unit_test(TestOldSize_test());
|
||||||
run_unit_test(TestKlass_test());
|
run_unit_test(TestKlass_test());
|
||||||
run_unit_test(TestBitMap_test());
|
run_unit_test(TestBitMap_test());
|
||||||
#if INCLUDE_VM_STRUCTS
|
#if INCLUDE_VM_STRUCTS
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user