mirror of
https://github.com/openjdk/jdk.git
synced 2025-09-22 20:14:43 +02:00
Merge
This commit is contained in:
commit
1c281a9fb3
77 changed files with 1099 additions and 1236 deletions
1
.hgtags
1
.hgtags
|
@ -215,3 +215,4 @@ f09ab0c416185e3cba371e81bcb6a16060c90f44 jdk8-b90
|
||||||
80b6c3172dc2cfceb022411292d290a967f9c728 jdk8-b91
|
80b6c3172dc2cfceb022411292d290a967f9c728 jdk8-b91
|
||||||
2fd6acba737b01e705e1f7c33588c922a3787f13 jdk8-b92
|
2fd6acba737b01e705e1f7c33588c922a3787f13 jdk8-b92
|
||||||
b72ae39e1329fefae50d4690db4fde43f3841a95 jdk8-b93
|
b72ae39e1329fefae50d4690db4fde43f3841a95 jdk8-b93
|
||||||
|
0d804e3b955dce406af6a79ac1cc35c696aff7fb jdk8-b94
|
||||||
|
|
|
@ -215,3 +215,4 @@ e1a929afcfc492470d50be0b6b0e8dc77d3760b9 jdk8-b88
|
||||||
cb51fb4789ac0b8be4056482077ddfb8f3bd3805 jdk8-b91
|
cb51fb4789ac0b8be4056482077ddfb8f3bd3805 jdk8-b91
|
||||||
3a36c926a7aafa9d4a892a45ef3678e87ad8359b jdk8-b92
|
3a36c926a7aafa9d4a892a45ef3678e87ad8359b jdk8-b92
|
||||||
27c51c6e31c1ef36afa0e6efb031f9b13f26c12b jdk8-b93
|
27c51c6e31c1ef36afa0e6efb031f9b13f26c12b jdk8-b93
|
||||||
|
50d2bde060f2a9bbbe4da0c8986e20aca61f2e2e jdk8-b94
|
||||||
|
|
|
@ -363,7 +363,11 @@ AC_ARG_WITH([devkit], [AS_HELP_STRING([--with-devkit],
|
||||||
AC_MSG_ERROR([Cannot specify both --with-devkit and --with-tools-dir at the same time])
|
AC_MSG_ERROR([Cannot specify both --with-devkit and --with-tools-dir at the same time])
|
||||||
fi
|
fi
|
||||||
TOOLS_DIR=$with_devkit/bin
|
TOOLS_DIR=$with_devkit/bin
|
||||||
SYS_ROOT=$with_devkit/$host_alias/libc
|
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
|
||||||
])
|
])
|
||||||
|
|
||||||
])
|
])
|
||||||
|
|
|
@ -162,7 +162,12 @@ AC_DEFUN([BPERF_SETUP_CCACHE],
|
||||||
[disable using ccache to speed up recompilations @<:@enabled@:>@])],
|
[disable using ccache to speed up recompilations @<:@enabled@:>@])],
|
||||||
[ENABLE_CCACHE=${enable_ccache}], [ENABLE_CCACHE=yes])
|
[ENABLE_CCACHE=${enable_ccache}], [ENABLE_CCACHE=yes])
|
||||||
if test "x$ENABLE_CCACHE" = xyes; then
|
if test "x$ENABLE_CCACHE" = xyes; then
|
||||||
|
OLD_PATH="$PATH"
|
||||||
|
if test "x$TOOLS_DIR" != x; then
|
||||||
|
PATH=$TOOLS_DIR:$PATH
|
||||||
|
fi
|
||||||
AC_PATH_PROG(CCACHE, ccache)
|
AC_PATH_PROG(CCACHE, ccache)
|
||||||
|
PATH="$OLD_PATH"
|
||||||
else
|
else
|
||||||
AC_MSG_CHECKING([for ccache])
|
AC_MSG_CHECKING([for ccache])
|
||||||
AC_MSG_RESULT([explicitly disabled])
|
AC_MSG_RESULT([explicitly disabled])
|
||||||
|
|
|
@ -3782,7 +3782,7 @@ fi
|
||||||
#CUSTOM_AUTOCONF_INCLUDE
|
#CUSTOM_AUTOCONF_INCLUDE
|
||||||
|
|
||||||
# Do not change or remove the following line, it is needed for consistency checks:
|
# Do not change or remove the following line, it is needed for consistency checks:
|
||||||
DATE_WHEN_GENERATED=1370949244
|
DATE_WHEN_GENERATED=1371547824
|
||||||
|
|
||||||
###############################################################################
|
###############################################################################
|
||||||
#
|
#
|
||||||
|
@ -7471,7 +7471,11 @@ if test "${with_devkit+set}" = set; then :
|
||||||
as_fn_error $? "Cannot specify both --with-devkit and --with-tools-dir at the same time" "$LINENO" 5
|
as_fn_error $? "Cannot specify both --with-devkit and --with-tools-dir at the same time" "$LINENO" 5
|
||||||
fi
|
fi
|
||||||
TOOLS_DIR=$with_devkit/bin
|
TOOLS_DIR=$with_devkit/bin
|
||||||
SYS_ROOT=$with_devkit/$host_alias/libc
|
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
|
||||||
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
@ -29144,7 +29148,6 @@ CXX_FLAG_DEPS="-MMD -MF"
|
||||||
|
|
||||||
case $COMPILER_TYPE in
|
case $COMPILER_TYPE in
|
||||||
CC )
|
CC )
|
||||||
D_FLAG="-g"
|
|
||||||
case $COMPILER_NAME in
|
case $COMPILER_NAME in
|
||||||
gcc )
|
gcc )
|
||||||
case $OPENJDK_TARGET_OS in
|
case $OPENJDK_TARGET_OS in
|
||||||
|
@ -29159,17 +29162,17 @@ case $COMPILER_TYPE in
|
||||||
C_O_FLAG_HI="-O3"
|
C_O_FLAG_HI="-O3"
|
||||||
C_O_FLAG_NORM="-O2"
|
C_O_FLAG_NORM="-O2"
|
||||||
C_O_FLAG_NONE="-O0"
|
C_O_FLAG_NONE="-O0"
|
||||||
CFLAGS_DEBUG_SYMBOLS="-g"
|
|
||||||
CXXFLAGS_DEBUG_SYMBOLS="-g"
|
|
||||||
if test "x$OPENJDK_TARGET_CPU_BITS" = "x64" && test "x$DEBUG_LEVEL" = "xfastdebug"; then
|
|
||||||
CFLAGS_DEBUG_SYMBOLS="-g1"
|
|
||||||
CXXFLAGS_DEBUG_SYMBOLS="-g1"
|
|
||||||
fi
|
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
CXX_O_FLAG_HI="$C_O_FLAG_HI"
|
CXX_O_FLAG_HI="$C_O_FLAG_HI"
|
||||||
CXX_O_FLAG_NORM="$C_O_FLAG_NORM"
|
CXX_O_FLAG_NORM="$C_O_FLAG_NORM"
|
||||||
CXX_O_FLAG_NONE="$C_O_FLAG_NONE"
|
CXX_O_FLAG_NONE="$C_O_FLAG_NONE"
|
||||||
|
CFLAGS_DEBUG_SYMBOLS="-g"
|
||||||
|
CXXFLAGS_DEBUG_SYMBOLS="-g"
|
||||||
|
if test "x$OPENJDK_TARGET_CPU_BITS" = "x64" && test "x$DEBUG_LEVEL" = "xfastdebug"; then
|
||||||
|
CFLAGS_DEBUG_SYMBOLS="-g1"
|
||||||
|
CXXFLAGS_DEBUG_SYMBOLS="-g1"
|
||||||
|
fi
|
||||||
;;
|
;;
|
||||||
ossc )
|
ossc )
|
||||||
#
|
#
|
||||||
|
@ -29250,7 +29253,6 @@ case $COMPILER_TYPE in
|
||||||
esac
|
esac
|
||||||
;;
|
;;
|
||||||
CL )
|
CL )
|
||||||
D_FLAG=
|
|
||||||
C_O_FLAG_HIGHEST="-O2"
|
C_O_FLAG_HIGHEST="-O2"
|
||||||
C_O_FLAG_HI="-O1"
|
C_O_FLAG_HI="-O1"
|
||||||
C_O_FLAG_NORM="-O1"
|
C_O_FLAG_NORM="-O1"
|
||||||
|
@ -29389,6 +29391,28 @@ esac
|
||||||
|
|
||||||
###############################################################################
|
###############################################################################
|
||||||
|
|
||||||
|
# Adjust flags according to debug level.
|
||||||
|
case $DEBUG_LEVEL in
|
||||||
|
fastdebug )
|
||||||
|
CFLAGS_JDK="$CFLAGS_JDK $CFLAGS_DEBUG_SYMBOLS"
|
||||||
|
CXXFLAGS_JDK="$CXXFLAGS_JDK $CXXFLAGS_DEBUG_SYMBOLS"
|
||||||
|
C_O_FLAG_HI="$C_O_FLAG_NORM"
|
||||||
|
C_O_FLAG_NORM="$C_O_FLAG_NORM"
|
||||||
|
CXX_O_FLAG_HI="$CXX_O_FLAG_NORM"
|
||||||
|
CXX_O_FLAG_NORM="$CXX_O_FLAG_NORM"
|
||||||
|
JAVAC_FLAGS="$JAVAC_FLAGS -g"
|
||||||
|
;;
|
||||||
|
slowdebug )
|
||||||
|
CFLAGS_JDK="$CFLAGS_JDK $CFLAGS_DEBUG_SYMBOLS"
|
||||||
|
CXXFLAGS_JDK="$CXXFLAGS_JDK $CXXFLAGS_DEBUG_SYMBOLS"
|
||||||
|
C_O_FLAG_HI="$C_O_FLAG_NONE"
|
||||||
|
C_O_FLAG_NORM="$C_O_FLAG_NONE"
|
||||||
|
CXX_O_FLAG_HI="$CXX_O_FLAG_NONE"
|
||||||
|
CXX_O_FLAG_NORM="$CXX_O_FLAG_NONE"
|
||||||
|
JAVAC_FLAGS="$JAVAC_FLAGS -g"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
CCXXFLAGS_JDK="$CCXXFLAGS_JDK $ADD_LP64"
|
CCXXFLAGS_JDK="$CCXXFLAGS_JDK $ADD_LP64"
|
||||||
|
|
||||||
# The package path is used only on macosx?
|
# The package path is used only on macosx?
|
||||||
|
@ -29532,23 +29556,6 @@ else
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Adjust flags according to debug level.
|
|
||||||
case $DEBUG_LEVEL in
|
|
||||||
fastdebug )
|
|
||||||
CFLAGS="$CFLAGS $D_FLAG"
|
|
||||||
JAVAC_FLAGS="$JAVAC_FLAGS -g"
|
|
||||||
;;
|
|
||||||
slowdebug )
|
|
||||||
CFLAGS="$CFLAGS $D_FLAG"
|
|
||||||
C_O_FLAG_HI="$C_O_FLAG_NONE"
|
|
||||||
C_O_FLAG_NORM="$C_O_FLAG_NONE"
|
|
||||||
CXX_O_FLAG_HI="$CXX_O_FLAG_NONE"
|
|
||||||
CXX_O_FLAG_NORM="$CXX_O_FLAG_NONE"
|
|
||||||
JAVAC_FLAGS="$JAVAC_FLAGS -g"
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -29907,11 +29914,17 @@ if test "x$SYS_ROOT" != "x/"; then
|
||||||
if test "x$x_includes" = xNONE; then
|
if test "x$x_includes" = xNONE; then
|
||||||
if test -f "$SYS_ROOT/usr/X11R6/include/X11/Xlib.h"; then
|
if test -f "$SYS_ROOT/usr/X11R6/include/X11/Xlib.h"; then
|
||||||
x_includes="$SYS_ROOT/usr/X11R6/include"
|
x_includes="$SYS_ROOT/usr/X11R6/include"
|
||||||
|
elif test -f "$SYS_ROOT/usr/include/X11/Xlib.h"; then
|
||||||
|
x_includes="$SYS_ROOT/usr/include"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
if test "x$x_libraries" = xNONE; then
|
if test "x$x_libraries" = xNONE; then
|
||||||
if test -f "$SYS_ROOT/usr/X11R6/lib/libX11.so"; then
|
if test -f "$SYS_ROOT/usr/X11R6/lib/libX11.so"; then
|
||||||
x_libraries="$SYS_ROOT/usr/X11R6/lib"
|
x_libraries="$SYS_ROOT/usr/X11R6/lib"
|
||||||
|
elif test "$SYS_ROOT/usr/lib64/libX11.so" && test "x$OPENJDK_TARGET_CPU_BITS" = x64; then
|
||||||
|
x_libraries="$SYS_ROOT/usr/lib64"
|
||||||
|
elif test -f "$SYS_ROOT/usr/lib/libX11.so"; then
|
||||||
|
x_libraries="$SYS_ROOT/usr/lib"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
@ -30642,8 +30655,7 @@ fi
|
||||||
if test "x$OPENJDK_TARGET_OS" = xlinux; then
|
if test "x$OPENJDK_TARGET_OS" = xlinux; then
|
||||||
if test -d "$SYS_ROOT/usr/X11R6"; then
|
if test -d "$SYS_ROOT/usr/X11R6"; then
|
||||||
OPENWIN_HOME="$SYS_ROOT/usr/X11R6"
|
OPENWIN_HOME="$SYS_ROOT/usr/X11R6"
|
||||||
fi
|
elif test -d "$SYS_ROOT/usr/include/X11"; then
|
||||||
if test -d "$SYS_ROOT/usr/include/X11"; then
|
|
||||||
OPENWIN_HOME="$SYS_ROOT/usr"
|
OPENWIN_HOME="$SYS_ROOT/usr"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
@ -31536,12 +31548,12 @@ fi
|
||||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for freetype in some standard locations" >&5
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for freetype in some standard locations" >&5
|
||||||
$as_echo_n "checking for freetype in some standard locations... " >&6; }
|
$as_echo_n "checking for freetype in some standard locations... " >&6; }
|
||||||
|
|
||||||
if test -s /usr/X11/include/ft2build.h && test -d /usr/X11/include/freetype2/freetype; then
|
if test -s $SYS_ROOT/usr/X11/include/ft2build.h && test -d $SYS_ROOT/usr/X11/include/freetype2/freetype; then
|
||||||
DEFAULT_FREETYPE_CFLAGS="-I/usr/X11/include/freetype2 -I/usr/X11/include"
|
DEFAULT_FREETYPE_CFLAGS="-I$SYS_ROOT/usr/X11/include/freetype2 -I$SYS_ROOT/usr/X11/include"
|
||||||
DEFAULT_FREETYPE_LIBS="-L/usr/X11/lib -lfreetype"
|
DEFAULT_FREETYPE_LIBS="-L$SYS_ROOT/usr/X11/lib -lfreetype"
|
||||||
fi
|
fi
|
||||||
if test -s /usr/include/ft2build.h && test -d /usr/include/freetype2/freetype; then
|
if test -s $SYS_ROOT/usr/include/ft2build.h && test -d $SYS_ROOT/usr/include/freetype2/freetype; then
|
||||||
DEFAULT_FREETYPE_CFLAGS="-I/usr/include/freetype2"
|
DEFAULT_FREETYPE_CFLAGS="-I$SYS_ROOT/usr/include/freetype2"
|
||||||
DEFAULT_FREETYPE_LIBS="-lfreetype"
|
DEFAULT_FREETYPE_LIBS="-lfreetype"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
@ -33217,6 +33229,10 @@ else
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if test "x$ENABLE_CCACHE" = xyes; then
|
if test "x$ENABLE_CCACHE" = xyes; then
|
||||||
|
OLD_PATH="$PATH"
|
||||||
|
if test "x$TOOLS_DIR" != x; then
|
||||||
|
PATH=$TOOLS_DIR:$PATH
|
||||||
|
fi
|
||||||
# Extract the first word of "ccache", so it can be a program name with args.
|
# Extract the first word of "ccache", so it can be a program name with args.
|
||||||
set dummy ccache; ac_word=$2
|
set dummy ccache; ac_word=$2
|
||||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5
|
||||||
|
@ -33257,6 +33273,7 @@ $as_echo "no" >&6; }
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
PATH="$OLD_PATH"
|
||||||
else
|
else
|
||||||
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for ccache" >&5
|
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for ccache" >&5
|
||||||
$as_echo_n "checking for ccache... " >&6; }
|
$as_echo_n "checking for ccache... " >&6; }
|
||||||
|
|
|
@ -123,11 +123,17 @@ if test "x$SYS_ROOT" != "x/"; then
|
||||||
if test "x$x_includes" = xNONE; then
|
if test "x$x_includes" = xNONE; then
|
||||||
if test -f "$SYS_ROOT/usr/X11R6/include/X11/Xlib.h"; then
|
if test -f "$SYS_ROOT/usr/X11R6/include/X11/Xlib.h"; then
|
||||||
x_includes="$SYS_ROOT/usr/X11R6/include"
|
x_includes="$SYS_ROOT/usr/X11R6/include"
|
||||||
|
elif test -f "$SYS_ROOT/usr/include/X11/Xlib.h"; then
|
||||||
|
x_includes="$SYS_ROOT/usr/include"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
if test "x$x_libraries" = xNONE; then
|
if test "x$x_libraries" = xNONE; then
|
||||||
if test -f "$SYS_ROOT/usr/X11R6/lib/libX11.so"; then
|
if test -f "$SYS_ROOT/usr/X11R6/lib/libX11.so"; then
|
||||||
x_libraries="$SYS_ROOT/usr/X11R6/lib"
|
x_libraries="$SYS_ROOT/usr/X11R6/lib"
|
||||||
|
elif test "$SYS_ROOT/usr/lib64/libX11.so" && test "x$OPENJDK_TARGET_CPU_BITS" = x64; then
|
||||||
|
x_libraries="$SYS_ROOT/usr/lib64"
|
||||||
|
elif test -f "$SYS_ROOT/usr/lib/libX11.so"; then
|
||||||
|
x_libraries="$SYS_ROOT/usr/lib"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
@ -153,8 +159,7 @@ fi
|
||||||
if test "x$OPENJDK_TARGET_OS" = xlinux; then
|
if test "x$OPENJDK_TARGET_OS" = xlinux; then
|
||||||
if test -d "$SYS_ROOT/usr/X11R6"; then
|
if test -d "$SYS_ROOT/usr/X11R6"; then
|
||||||
OPENWIN_HOME="$SYS_ROOT/usr/X11R6"
|
OPENWIN_HOME="$SYS_ROOT/usr/X11R6"
|
||||||
fi
|
elif test -d "$SYS_ROOT/usr/include/X11"; then
|
||||||
if test -d "$SYS_ROOT/usr/include/X11"; then
|
|
||||||
OPENWIN_HOME="$SYS_ROOT/usr"
|
OPENWIN_HOME="$SYS_ROOT/usr"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
@ -359,12 +364,12 @@ else
|
||||||
if test "x$FREETYPE2_FOUND" = xno; then
|
if test "x$FREETYPE2_FOUND" = xno; then
|
||||||
AC_MSG_CHECKING([for freetype in some standard locations])
|
AC_MSG_CHECKING([for freetype in some standard locations])
|
||||||
|
|
||||||
if test -s /usr/X11/include/ft2build.h && test -d /usr/X11/include/freetype2/freetype; then
|
if test -s $SYS_ROOT/usr/X11/include/ft2build.h && test -d $SYS_ROOT/usr/X11/include/freetype2/freetype; then
|
||||||
DEFAULT_FREETYPE_CFLAGS="-I/usr/X11/include/freetype2 -I/usr/X11/include"
|
DEFAULT_FREETYPE_CFLAGS="-I$SYS_ROOT/usr/X11/include/freetype2 -I$SYS_ROOT/usr/X11/include"
|
||||||
DEFAULT_FREETYPE_LIBS="-L/usr/X11/lib -lfreetype"
|
DEFAULT_FREETYPE_LIBS="-L$SYS_ROOT/usr/X11/lib -lfreetype"
|
||||||
fi
|
fi
|
||||||
if test -s /usr/include/ft2build.h && test -d /usr/include/freetype2/freetype; then
|
if test -s $SYS_ROOT/usr/include/ft2build.h && test -d $SYS_ROOT/usr/include/freetype2/freetype; then
|
||||||
DEFAULT_FREETYPE_CFLAGS="-I/usr/include/freetype2"
|
DEFAULT_FREETYPE_CFLAGS="-I$SYS_ROOT/usr/include/freetype2"
|
||||||
DEFAULT_FREETYPE_LIBS="-lfreetype"
|
DEFAULT_FREETYPE_LIBS="-lfreetype"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
|
@ -275,6 +275,8 @@ FREETYPE2_LIBS:=@FREETYPE2_LIBS@
|
||||||
FREETYPE2_CFLAGS:=@FREETYPE2_CFLAGS@
|
FREETYPE2_CFLAGS:=@FREETYPE2_CFLAGS@
|
||||||
USING_SYSTEM_FT_LIB=@USING_SYSTEM_FT_LIB@
|
USING_SYSTEM_FT_LIB=@USING_SYSTEM_FT_LIB@
|
||||||
CUPS_CFLAGS:=@CUPS_CFLAGS@
|
CUPS_CFLAGS:=@CUPS_CFLAGS@
|
||||||
|
ALSA_LIBS:=@ALSA_LIBS@
|
||||||
|
ALSA_CFLAGS:=@ALSA_CFLAGS@
|
||||||
|
|
||||||
PACKAGE_PATH=@PACKAGE_PATH@
|
PACKAGE_PATH=@PACKAGE_PATH@
|
||||||
|
|
||||||
|
|
|
@ -629,7 +629,6 @@ CXX_FLAG_DEPS="-MMD -MF"
|
||||||
|
|
||||||
case $COMPILER_TYPE in
|
case $COMPILER_TYPE in
|
||||||
CC )
|
CC )
|
||||||
D_FLAG="-g"
|
|
||||||
case $COMPILER_NAME in
|
case $COMPILER_NAME in
|
||||||
gcc )
|
gcc )
|
||||||
case $OPENJDK_TARGET_OS in
|
case $OPENJDK_TARGET_OS in
|
||||||
|
@ -644,17 +643,17 @@ case $COMPILER_TYPE in
|
||||||
C_O_FLAG_HI="-O3"
|
C_O_FLAG_HI="-O3"
|
||||||
C_O_FLAG_NORM="-O2"
|
C_O_FLAG_NORM="-O2"
|
||||||
C_O_FLAG_NONE="-O0"
|
C_O_FLAG_NONE="-O0"
|
||||||
CFLAGS_DEBUG_SYMBOLS="-g"
|
|
||||||
CXXFLAGS_DEBUG_SYMBOLS="-g"
|
|
||||||
if test "x$OPENJDK_TARGET_CPU_BITS" = "x64" && test "x$DEBUG_LEVEL" = "xfastdebug"; then
|
|
||||||
CFLAGS_DEBUG_SYMBOLS="-g1"
|
|
||||||
CXXFLAGS_DEBUG_SYMBOLS="-g1"
|
|
||||||
fi
|
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
CXX_O_FLAG_HI="$C_O_FLAG_HI"
|
CXX_O_FLAG_HI="$C_O_FLAG_HI"
|
||||||
CXX_O_FLAG_NORM="$C_O_FLAG_NORM"
|
CXX_O_FLAG_NORM="$C_O_FLAG_NORM"
|
||||||
CXX_O_FLAG_NONE="$C_O_FLAG_NONE"
|
CXX_O_FLAG_NONE="$C_O_FLAG_NONE"
|
||||||
|
CFLAGS_DEBUG_SYMBOLS="-g"
|
||||||
|
CXXFLAGS_DEBUG_SYMBOLS="-g"
|
||||||
|
if test "x$OPENJDK_TARGET_CPU_BITS" = "x64" && test "x$DEBUG_LEVEL" = "xfastdebug"; then
|
||||||
|
CFLAGS_DEBUG_SYMBOLS="-g1"
|
||||||
|
CXXFLAGS_DEBUG_SYMBOLS="-g1"
|
||||||
|
fi
|
||||||
;;
|
;;
|
||||||
ossc )
|
ossc )
|
||||||
#
|
#
|
||||||
|
@ -735,7 +734,6 @@ case $COMPILER_TYPE in
|
||||||
esac
|
esac
|
||||||
;;
|
;;
|
||||||
CL )
|
CL )
|
||||||
D_FLAG=
|
|
||||||
C_O_FLAG_HIGHEST="-O2"
|
C_O_FLAG_HIGHEST="-O2"
|
||||||
C_O_FLAG_HI="-O1"
|
C_O_FLAG_HI="-O1"
|
||||||
C_O_FLAG_NORM="-O1"
|
C_O_FLAG_NORM="-O1"
|
||||||
|
@ -861,6 +859,28 @@ esac
|
||||||
|
|
||||||
###############################################################################
|
###############################################################################
|
||||||
|
|
||||||
|
# Adjust flags according to debug level.
|
||||||
|
case $DEBUG_LEVEL in
|
||||||
|
fastdebug )
|
||||||
|
CFLAGS_JDK="$CFLAGS_JDK $CFLAGS_DEBUG_SYMBOLS"
|
||||||
|
CXXFLAGS_JDK="$CXXFLAGS_JDK $CXXFLAGS_DEBUG_SYMBOLS"
|
||||||
|
C_O_FLAG_HI="$C_O_FLAG_NORM"
|
||||||
|
C_O_FLAG_NORM="$C_O_FLAG_NORM"
|
||||||
|
CXX_O_FLAG_HI="$CXX_O_FLAG_NORM"
|
||||||
|
CXX_O_FLAG_NORM="$CXX_O_FLAG_NORM"
|
||||||
|
JAVAC_FLAGS="$JAVAC_FLAGS -g"
|
||||||
|
;;
|
||||||
|
slowdebug )
|
||||||
|
CFLAGS_JDK="$CFLAGS_JDK $CFLAGS_DEBUG_SYMBOLS"
|
||||||
|
CXXFLAGS_JDK="$CXXFLAGS_JDK $CXXFLAGS_DEBUG_SYMBOLS"
|
||||||
|
C_O_FLAG_HI="$C_O_FLAG_NONE"
|
||||||
|
C_O_FLAG_NORM="$C_O_FLAG_NONE"
|
||||||
|
CXX_O_FLAG_HI="$CXX_O_FLAG_NONE"
|
||||||
|
CXX_O_FLAG_NORM="$CXX_O_FLAG_NONE"
|
||||||
|
JAVAC_FLAGS="$JAVAC_FLAGS -g"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
CCXXFLAGS_JDK="$CCXXFLAGS_JDK $ADD_LP64"
|
CCXXFLAGS_JDK="$CCXXFLAGS_JDK $ADD_LP64"
|
||||||
|
|
||||||
# The package path is used only on macosx?
|
# The package path is used only on macosx?
|
||||||
|
@ -1004,23 +1024,6 @@ else
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Adjust flags according to debug level.
|
|
||||||
case $DEBUG_LEVEL in
|
|
||||||
fastdebug )
|
|
||||||
CFLAGS="$CFLAGS $D_FLAG"
|
|
||||||
JAVAC_FLAGS="$JAVAC_FLAGS -g"
|
|
||||||
;;
|
|
||||||
slowdebug )
|
|
||||||
CFLAGS="$CFLAGS $D_FLAG"
|
|
||||||
C_O_FLAG_HI="$C_O_FLAG_NONE"
|
|
||||||
C_O_FLAG_NORM="$C_O_FLAG_NONE"
|
|
||||||
CXX_O_FLAG_HI="$CXX_O_FLAG_NONE"
|
|
||||||
CXX_O_FLAG_NORM="$CXX_O_FLAG_NONE"
|
|
||||||
JAVAC_FLAGS="$JAVAC_FLAGS -g"
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
|
|
||||||
AC_SUBST(CFLAGS_JDKLIB)
|
AC_SUBST(CFLAGS_JDKLIB)
|
||||||
AC_SUBST(CFLAGS_JDKEXE)
|
AC_SUBST(CFLAGS_JDKEXE)
|
||||||
|
|
||||||
|
|
|
@ -108,7 +108,11 @@ define add_native_source
|
||||||
# setting -showIncludes, all included files are printed. These are filtered out and
|
# setting -showIncludes, all included files are printed. These are filtered out and
|
||||||
# parsed into make dependences.
|
# parsed into make dependences.
|
||||||
ifeq ($(COMPILER_TYPE),CL)
|
ifeq ($(COMPILER_TYPE),CL)
|
||||||
$$($1_$2_COMP) $$($1_$2_FLAGS) -showIncludes $$($1_$2_DEBUG_OUT_FLAGS) $(CC_OUT_OPTION)$$($1_$2_OBJ) $2 | $(TEE) $$($1_$2_DEP).raw | $(GREP) -v "^Note: including file:"
|
($$($1_$2_COMP) $$($1_$2_FLAGS) -showIncludes $$($1_$2_DEBUG_OUT_FLAGS) \
|
||||||
|
$(CC_OUT_OPTION)$$($1_$2_OBJ) $2 ; echo $$$$? > $$($1_$2_DEP).exitvalue) \
|
||||||
|
| $(TEE) $$($1_$2_DEP).raw | $(GREP) -v "^Note: including file:" \
|
||||||
|
&& exit `cat $$($1_$2_DEP).exitvalue`
|
||||||
|
$(RM) $$($1_$2_DEP).exitvalue
|
||||||
($(ECHO) $$@: \\ \
|
($(ECHO) $$@: \\ \
|
||||||
&& $(SED) -e '/^Note: including file:/!d' \
|
&& $(SED) -e '/^Note: including file:/!d' \
|
||||||
-e 's|Note: including file: *||' \
|
-e 's|Note: including file: *||' \
|
||||||
|
|
123
common/makefiles/devkit/Makefile
Normal file
123
common/makefiles/devkit/Makefile
Normal file
|
@ -0,0 +1,123 @@
|
||||||
|
#
|
||||||
|
# Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
#
|
||||||
|
# This code is free software; you can redistribute it and/or modify it
|
||||||
|
# under the terms of the GNU General Public License version 2 only, as
|
||||||
|
# published by the Free Software Foundation. Oracle designates this
|
||||||
|
# particular file as subject to the "Classpath" exception as provided
|
||||||
|
# by Oracle in the LICENSE file that accompanied this code.
|
||||||
|
#
|
||||||
|
# This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
# version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
# accompanied this code).
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License version
|
||||||
|
# 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
#
|
||||||
|
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
# or visit www.oracle.com if you need additional information or have any
|
||||||
|
# questions.
|
||||||
|
#
|
||||||
|
|
||||||
|
##########################################################################################
|
||||||
|
#
|
||||||
|
# This Makefile, together with Tools.gmk, can be used to compile a set of
|
||||||
|
# gcc based cross compilation, portable, self contained packages, capable
|
||||||
|
# of building OpenJDK.
|
||||||
|
#
|
||||||
|
# In addition to the makefiles, access to Oracle Linux installation
|
||||||
|
# media is required. This has been tested against Oracle Enterprise Linux
|
||||||
|
# 5.5. Set variables RPM_DIR_x86_64 and RPM_DIR_i686 respectively to point
|
||||||
|
# to directory containing the RPMs.
|
||||||
|
#
|
||||||
|
# By default this Makefile will build crosstools for:
|
||||||
|
# * i686-unknown-linux-gnu
|
||||||
|
# * x86_64-unknown-linux-gnu
|
||||||
|
# The x86_64 version of the compilers will work in multi arch mode and will
|
||||||
|
# be able to compile 32bit binaries with the -m32 flag. This makes the
|
||||||
|
# explicit cross compiler for i686 somewhat redundant and is a known issue.
|
||||||
|
#
|
||||||
|
# To build the full set of crosstools, use a command line looking like this:
|
||||||
|
#
|
||||||
|
# make tars RPM_DIR_x86_64=/tmp/oel55-x86_64/Server/ RPM_DIR_i686=/tmp/oel55-i686/Server/
|
||||||
|
#
|
||||||
|
# To create a x86_64 package without the redundant i686 cross compiler, do
|
||||||
|
# like this:
|
||||||
|
#
|
||||||
|
# make tars platforms=x86_64-unknown-linux-gnu RPM_DIR_x86_64=/tmp/oel55-x86_64/Server/ RPM_DIR_i686=/tmp/oel55-i686/Server/
|
||||||
|
|
||||||
|
#
|
||||||
|
# Main makefile which iterates over all host and target platforms.
|
||||||
|
#
|
||||||
|
|
||||||
|
os := $(shell uname -o)
|
||||||
|
cpu := x86_64
|
||||||
|
#$(shell uname -p)
|
||||||
|
|
||||||
|
#
|
||||||
|
# This wrapper script can handle exactly these platforms
|
||||||
|
#
|
||||||
|
platforms := $(foreach p,x86_64 i686,$(p)-unknown-linux-gnu)
|
||||||
|
#platforms := $(foreach p,x86_64,$(p)-unknown-linux-gnu)
|
||||||
|
|
||||||
|
# Figure out what platform this is building on.
|
||||||
|
me := $(cpu)-$(if $(findstring Linux,$(os)),unknown-linux-gnu)
|
||||||
|
|
||||||
|
$(info Building on platform $(me))
|
||||||
|
|
||||||
|
all compile : $(platforms)
|
||||||
|
|
||||||
|
ifeq (,$(SKIP_ME))
|
||||||
|
$(foreach p,$(filter-out $(me),$(platforms)),$(eval $(p) : $$(me)))
|
||||||
|
endif
|
||||||
|
|
||||||
|
OUTPUT_ROOT = $(abspath ../../../build/devkit)
|
||||||
|
RESULT = $(OUTPUT_ROOT)/result
|
||||||
|
|
||||||
|
submakevars = HOST=$@ BUILD=$(me) \
|
||||||
|
RESULT=$(RESULT) PREFIX=$(RESULT)/$@ \
|
||||||
|
OUTPUT_ROOT=$(OUTPUT_ROOT)
|
||||||
|
$(platforms) :
|
||||||
|
@echo 'Building compilers for $@'
|
||||||
|
@echo 'Targets: $(platforms)'
|
||||||
|
for p in $@ $(filter-out $@,$(platforms)); do \
|
||||||
|
$(MAKE) -f Tools.gmk all $(submakevars) \
|
||||||
|
TARGET=$$p || exit 1 ; \
|
||||||
|
done
|
||||||
|
@echo 'Building ccache program for $@'
|
||||||
|
$(MAKE) -f Tools.gmk ccache $(submakevars) TARGET=$@
|
||||||
|
@echo 'All done"'
|
||||||
|
|
||||||
|
$(foreach a,i686 x86_64,$(eval $(a) : $(filter $(a)%,$(platforms))))
|
||||||
|
|
||||||
|
ia32 : i686
|
||||||
|
today := $(shell date +%Y%m%d)
|
||||||
|
|
||||||
|
|
||||||
|
define Mktar
|
||||||
|
$(1)_tar = $$(RESULT)/sdk-$(1)-$$(today).tar.gz
|
||||||
|
$$($(1)_tar) : PLATFORM = $(1)
|
||||||
|
TARFILES += $$($(1)_tar)
|
||||||
|
$$($(1)_tar) : $(1) $$(shell find $$(RESULT)/$(1))
|
||||||
|
endef
|
||||||
|
|
||||||
|
$(foreach p,$(platforms),$(eval $(call Mktar,$(p))))
|
||||||
|
|
||||||
|
tars : all $(TARFILES)
|
||||||
|
onlytars : $(TARFILES)
|
||||||
|
%.tar.gz :
|
||||||
|
@echo 'Creating compiler package $@'
|
||||||
|
cd $(RESULT)/$(PLATFORM) && tar -czf $@ *
|
||||||
|
touch $@
|
||||||
|
|
||||||
|
clean :
|
||||||
|
rm -rf build result
|
||||||
|
|
||||||
|
FORCE :
|
||||||
|
.PHONY : $(configs) $(platforms)
|
||||||
|
|
||||||
|
|
473
common/makefiles/devkit/Tools.gmk
Normal file
473
common/makefiles/devkit/Tools.gmk
Normal file
|
@ -0,0 +1,473 @@
|
||||||
|
#
|
||||||
|
# Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
#
|
||||||
|
# This code is free software; you can redistribute it and/or modify it
|
||||||
|
# under the terms of the GNU General Public License version 2 only, as
|
||||||
|
# published by the Free Software Foundation. Oracle designates this
|
||||||
|
# particular file as subject to the "Classpath" exception as provided
|
||||||
|
# by Oracle in the LICENSE file that accompanied this code.
|
||||||
|
#
|
||||||
|
# This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
# version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
# accompanied this code).
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License version
|
||||||
|
# 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
#
|
||||||
|
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
# or visit www.oracle.com if you need additional information or have any
|
||||||
|
# questions.
|
||||||
|
#
|
||||||
|
|
||||||
|
##########################################################################################
|
||||||
|
#
|
||||||
|
# Workhorse makefile for creating ONE cross compiler
|
||||||
|
# Needs either to be from BUILD -> BUILD OR have
|
||||||
|
# BUILD -> HOST prebuilt
|
||||||
|
#
|
||||||
|
# NOTE: There is a bug here. We don't limit the
|
||||||
|
# PATH when building BUILD -> BUILD, which means that
|
||||||
|
# if you configure after you've once build the BUILD->BUILD
|
||||||
|
# compiler THAT one will be picked up as the compiler for itself.
|
||||||
|
# This is not so great, especially if you did a partial delete
|
||||||
|
# of the target tree.
|
||||||
|
#
|
||||||
|
# Fix this...
|
||||||
|
#
|
||||||
|
|
||||||
|
$(info TARGET=$(TARGET))
|
||||||
|
$(info HOST=$(HOST))
|
||||||
|
$(info BUILD=$(BUILD))
|
||||||
|
|
||||||
|
ARCH := $(word 1,$(subst -, ,$(TARGET)))
|
||||||
|
|
||||||
|
##########################################################################################
|
||||||
|
# Define external dependencies
|
||||||
|
|
||||||
|
# Latest that could be made to work.
|
||||||
|
gcc_ver := gcc-4.7.3
|
||||||
|
binutils_ver := binutils-2.22
|
||||||
|
ccache_ver := ccache-3.1.9
|
||||||
|
mpfr_ver := mpfr-3.0.1
|
||||||
|
gmp_ver := gmp-4.3.2
|
||||||
|
mpc_ver := mpc-1.0.1
|
||||||
|
|
||||||
|
GCC := http://ftp.gnu.org/pub/gnu/gcc/$(gcc_ver)/$(gcc_ver).tar.bz2
|
||||||
|
BINUTILS := http://ftp.gnu.org/pub/gnu/binutils/$(binutils_ver).tar.bz2
|
||||||
|
CCACHE := http://samba.org/ftp/ccache/$(ccache_ver).tar.gz
|
||||||
|
MPFR := http://www.mpfr.org/${mpfr_ver}/${mpfr_ver}.tar.bz2
|
||||||
|
GMP := http://ftp.gnu.org/pub/gnu/gmp/${gmp_ver}.tar.bz2
|
||||||
|
MPC := http://www.multiprecision.org/mpc/download/${mpc_ver}.tar.gz
|
||||||
|
|
||||||
|
# RPMs in OEL5.5
|
||||||
|
RPM_LIST := \
|
||||||
|
kernel-headers \
|
||||||
|
glibc-2 glibc-headers glibc-devel \
|
||||||
|
cups-libs cups-devel \
|
||||||
|
libX11 libX11-devel \
|
||||||
|
xorg-x11-proto-devel \
|
||||||
|
alsa-lib alsa-lib-devel \
|
||||||
|
libXext libXext-devel \
|
||||||
|
libXtst libXtst-devel \
|
||||||
|
libXrender libXrender-devel \
|
||||||
|
freetype freetype-devel \
|
||||||
|
libXt libXt-devel \
|
||||||
|
libSM libSM-devel \
|
||||||
|
libICE libICE-devel \
|
||||||
|
libXi libXi-devel \
|
||||||
|
libXdmcp libXdmcp-devel \
|
||||||
|
libXau libXau-devel \
|
||||||
|
libgcc
|
||||||
|
|
||||||
|
|
||||||
|
ifeq ($(ARCH),x86_64)
|
||||||
|
RPM_DIR ?= $(RPM_DIR_x86_64)
|
||||||
|
RPM_ARCHS := x86_64
|
||||||
|
ifeq ($(BUILD),$(HOST))
|
||||||
|
ifeq ($(TARGET),$(HOST))
|
||||||
|
# When building the native compiler for x86_64, enable mixed mode.
|
||||||
|
RPM_ARCHS += i386 i686
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
else
|
||||||
|
RPM_DIR ?= $(RPM_DIR_i686)
|
||||||
|
RPM_ARCHS := i386 i686
|
||||||
|
endif
|
||||||
|
|
||||||
|
# Sort to remove duplicates
|
||||||
|
RPM_FILE_LIST := $(sort $(foreach a,$(RPM_ARCHS),$(wildcard $(patsubst %,$(RPM_DIR)/%*$a.rpm,$(RPM_LIST)))))
|
||||||
|
|
||||||
|
ifeq ($(RPM_FILE_LIST),)
|
||||||
|
$(error Found no RPMs, RPM_DIR must point to list of directories to search for RPMs)
|
||||||
|
endif
|
||||||
|
|
||||||
|
##########################################################################################
|
||||||
|
# Define common directories and files
|
||||||
|
|
||||||
|
# Ensure we have 32-bit libs also for x64. We enable mixed-mode.
|
||||||
|
ifeq (x86_64,$(ARCH))
|
||||||
|
LIBDIRS := lib64 lib
|
||||||
|
CFLAGS_lib := -m32
|
||||||
|
else
|
||||||
|
LIBDIRS := lib
|
||||||
|
endif
|
||||||
|
|
||||||
|
# Define directories
|
||||||
|
RESULT := $(OUTPUT_ROOT)/result
|
||||||
|
BUILDDIR := $(OUTPUT_ROOT)/$(HOST)/$(TARGET)
|
||||||
|
PREFIX := $(RESULT)/$(HOST)
|
||||||
|
TARGETDIR := $(PREFIX)/$(TARGET)
|
||||||
|
SYSROOT := $(TARGETDIR)/sys-root
|
||||||
|
DOWNLOAD := $(OUTPUT_ROOT)/download
|
||||||
|
SRCDIR := $(OUTPUT_ROOT)/src
|
||||||
|
|
||||||
|
# Marker file for unpacking rpms
|
||||||
|
rpms := $(SYSROOT)/rpms_unpacked
|
||||||
|
|
||||||
|
# Need to patch libs that are linker scripts to use non-absolute paths
|
||||||
|
libs := $(SYSROOT)/libs_patched
|
||||||
|
|
||||||
|
##########################################################################################
|
||||||
|
# Unpack source packages
|
||||||
|
|
||||||
|
# Generate downloading + unpacking of sources.
|
||||||
|
define Download
|
||||||
|
$(1)_DIR = $(abspath $(SRCDIR)/$(basename $(basename $(notdir $($(1))))))
|
||||||
|
$(1)_CFG = $$($(1)_DIR)/configure
|
||||||
|
$(1)_FILE = $(DOWNLOAD)/$(notdir $($(1)))
|
||||||
|
|
||||||
|
$$($(1)_CFG) : $$($(1)_FILE)
|
||||||
|
mkdir -p $$(SRCDIR)
|
||||||
|
tar -C $$(SRCDIR) -x$$(if $$(findstring .gz, $$<),z,j)f $$<
|
||||||
|
$$(foreach p,$$(abspath $$(wildcard $$(notdir $$($(1)_DIR)).patch)), \
|
||||||
|
echo PATCHING $$(p) ; \
|
||||||
|
patch -d $$($(1)_DIR) -p1 -i $$(p) ; \
|
||||||
|
)
|
||||||
|
touch $$@
|
||||||
|
|
||||||
|
$$($(1)_FILE) :
|
||||||
|
wget -P $(DOWNLOAD) $$($(1))
|
||||||
|
endef
|
||||||
|
|
||||||
|
# Download and unpack all source packages
|
||||||
|
$(foreach p,GCC BINUTILS CCACHE MPFR GMP MPC,$(eval $(call Download,$(p))))
|
||||||
|
|
||||||
|
##########################################################################################
|
||||||
|
# Unpack RPMS
|
||||||
|
|
||||||
|
# Note. For building linux you should install rpm2cpio.
|
||||||
|
define unrpm
|
||||||
|
$(SYSROOT)/$(notdir $(1)).unpacked \
|
||||||
|
: $(1)
|
||||||
|
$$(rpms) : $(SYSROOT)/$(notdir $(1)).unpacked
|
||||||
|
endef
|
||||||
|
|
||||||
|
%.unpacked :
|
||||||
|
$(info Unpacking target rpms and libraries from $<)
|
||||||
|
@(mkdir -p $(@D); \
|
||||||
|
cd $(@D); \
|
||||||
|
rpm2cpio $< | \
|
||||||
|
cpio --extract --make-directories \
|
||||||
|
-f \
|
||||||
|
"./usr/share/doc/*" \
|
||||||
|
"./usr/share/man/*" \
|
||||||
|
"./usr/X11R6/man/*" \
|
||||||
|
"*/X11/locale/*" \
|
||||||
|
|| die ; )
|
||||||
|
touch $@
|
||||||
|
|
||||||
|
$(foreach p,$(RPM_FILE_LIST),$(eval $(call unrpm,$(p))))
|
||||||
|
|
||||||
|
##########################################################################################
|
||||||
|
|
||||||
|
# Note: MUST create a <sys-root>/usr/lib even if not really needed.
|
||||||
|
# gcc will use a path relative to it to resolve lib64. (x86_64).
|
||||||
|
# we're creating multi-lib compiler with 32bit libc as well, so we should
|
||||||
|
# have it anyway, but just to make sure...
|
||||||
|
# Patch libc.so and libpthread.so to force linking against libraries in sysroot
|
||||||
|
# and not the ones installed on the build machine.
|
||||||
|
$(libs) : $(rpms)
|
||||||
|
@echo Patching libc and pthreads
|
||||||
|
@(for f in `find $(SYSROOT) -name libc.so -o -name libpthread.so`; do \
|
||||||
|
(cat $$f | sed -e 's|/usr/lib64/||g' \
|
||||||
|
-e 's|/usr/lib/||g' \
|
||||||
|
-e 's|/lib64/||g' \
|
||||||
|
-e 's|/lib/||g' ) > $$f.tmp ; \
|
||||||
|
mv $$f.tmp $$f ; \
|
||||||
|
done)
|
||||||
|
@mkdir -p $(SYSROOT)/usr/lib
|
||||||
|
@touch $@
|
||||||
|
|
||||||
|
##########################################################################################
|
||||||
|
|
||||||
|
# Define marker files for each source package to be compiled
|
||||||
|
$(foreach t,binutils mpfr gmp mpc gcc ccache,$(eval $(t) = $(TARGETDIR)/$($(t)_ver).done))
|
||||||
|
|
||||||
|
##########################################################################################
|
||||||
|
|
||||||
|
# Default base config
|
||||||
|
CONFIG = --target=$(TARGET) \
|
||||||
|
--host=$(HOST) --build=$(BUILD) \
|
||||||
|
--prefix=$(PREFIX)
|
||||||
|
|
||||||
|
PATHEXT = $(RESULT)/$(BUILD)/bin:
|
||||||
|
|
||||||
|
PATHPRE = PATH=$(PATHEXT)$(PATH)
|
||||||
|
BUILDPAR = -j16
|
||||||
|
|
||||||
|
# Default commands to when making
|
||||||
|
MAKECMD =
|
||||||
|
INSTALLCMD = install
|
||||||
|
|
||||||
|
|
||||||
|
declare_tools = CC$(1)=$(2)gcc LD$(1)=$(2)ld AR$(1)=$(2)ar AS$(1)=$(2)as RANLIB$(1)=$(2)ranlib CXX$(1)=$(2)g++ OBJDUMP$(1)=$(2)objdump
|
||||||
|
|
||||||
|
ifeq ($(HOST),$(BUILD))
|
||||||
|
ifeq ($(HOST),$(TARGET))
|
||||||
|
TOOLS = $(call declare_tools,_FOR_TARGET,)
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
|
TOOLS ?= $(call declare_tools,_FOR_TARGET,$(TARGET)-)
|
||||||
|
|
||||||
|
##########################################################################################
|
||||||
|
|
||||||
|
# Create a TARGET bfd + libiberty only.
|
||||||
|
# Configure one or two times depending on mulitlib arch.
|
||||||
|
# If multilib, the second should be 32-bit, and we resolve
|
||||||
|
# CFLAG_<name> to most likely -m32.
|
||||||
|
define mk_bfd
|
||||||
|
$$(info Libs for $(1))
|
||||||
|
$$(BUILDDIR)/$$(binutils_ver)-$(subst /,-,$(1))/Makefile \
|
||||||
|
: CFLAGS += $$(CFLAGS_$(1))
|
||||||
|
$$(BUILDDIR)/$$(binutils_ver)-$(subst /,-,$(1))/Makefile \
|
||||||
|
: LIBDIRS = --libdir=$(TARGETDIR)/$(1)
|
||||||
|
|
||||||
|
bfdlib += $$(TARGETDIR)/$$(binutils_ver)-$(subst /,-,$(1)).done
|
||||||
|
bfdmakes += $$(BUILDDIR)/$$(binutils_ver)-$(subst /,-,$(1))/Makefile
|
||||||
|
endef
|
||||||
|
|
||||||
|
# Create one set of bfds etc for each multilib arch
|
||||||
|
$(foreach l,$(LIBDIRS),$(eval $(call mk_bfd,$(l))))
|
||||||
|
|
||||||
|
# Only build these two libs.
|
||||||
|
$(bfdlib) : MAKECMD = all-libiberty all-bfd
|
||||||
|
$(bfdlib) : INSTALLCMD = install-libiberty install-bfd
|
||||||
|
|
||||||
|
# Building targets libbfd + libiberty. HOST==TARGET, i.e not
|
||||||
|
# for a cross env.
|
||||||
|
$(bfdmakes) : CONFIG = --target=$(TARGET) \
|
||||||
|
--host=$(TARGET) --build=$(BUILD) \
|
||||||
|
--prefix=$(TARGETDIR) \
|
||||||
|
--with-sysroot=$(SYSROOT) \
|
||||||
|
$(LIBDIRS)
|
||||||
|
|
||||||
|
$(bfdmakes) : TOOLS = $(call declare_tools,_FOR_TARGET,$(TARGET)-) $(call declare_tools,,$(TARGET)-)
|
||||||
|
|
||||||
|
##########################################################################################
|
||||||
|
|
||||||
|
$(gcc) \
|
||||||
|
$(binutils) \
|
||||||
|
$(gmp) \
|
||||||
|
$(mpfr) \
|
||||||
|
$(mpc) \
|
||||||
|
$(bfdmakes) \
|
||||||
|
$(ccache) : ENVS += $(TOOLS)
|
||||||
|
|
||||||
|
# libdir to work around hateful bfd stuff installing into wrong dirs...
|
||||||
|
# ensure we have 64 bit bfd support in the HOST library. I.e our
|
||||||
|
# compiler on i686 will know 64 bit symbols, BUT later
|
||||||
|
# we build just the libs again for TARGET, then with whatever the arch
|
||||||
|
# wants.
|
||||||
|
$(BUILDDIR)/$(binutils_ver)/Makefile : CONFIG += --enable-64-bit-bfd --libdir=$(PREFIX)/$(word 1,$(LIBDIRS))
|
||||||
|
|
||||||
|
# Makefile creation. Simply run configure in build dir.
|
||||||
|
$(bfdmakes) \
|
||||||
|
$(BUILDDIR)/$(binutils_ver)/Makefile \
|
||||||
|
: $(BINUTILS_CFG)
|
||||||
|
$(info Configuring $@. Log in $(@D)/log.config)
|
||||||
|
@mkdir -p $(@D)
|
||||||
|
( \
|
||||||
|
cd $(@D) ; \
|
||||||
|
$(PATHPRE) $(ENVS) CFLAGS="$(CFLAGS)" \
|
||||||
|
$(BINUTILS_CFG) \
|
||||||
|
$(CONFIG) \
|
||||||
|
--with-sysroot=$(SYSROOT) \
|
||||||
|
--disable-nls \
|
||||||
|
--program-prefix=$(TARGET)- \
|
||||||
|
--enable-multilib \
|
||||||
|
) > $(@D)/log.config 2>&1
|
||||||
|
@echo 'done'
|
||||||
|
|
||||||
|
$(BUILDDIR)/$(mpfr_ver)/Makefile \
|
||||||
|
: $(MPFR_CFG)
|
||||||
|
$(info Configuring $@. Log in $(@D)/log.config)
|
||||||
|
@mkdir -p $(@D)
|
||||||
|
( \
|
||||||
|
cd $(@D) ; \
|
||||||
|
$(PATHPRE) $(ENVS) CFLAGS="$(CFLAGS)" \
|
||||||
|
$(MPFR_CFG) \
|
||||||
|
$(CONFIG) \
|
||||||
|
--program-prefix=$(TARGET)- \
|
||||||
|
--enable-shared=no \
|
||||||
|
--with-gmp=$(PREFIX) \
|
||||||
|
) > $(@D)/log.config 2>&1
|
||||||
|
@echo 'done'
|
||||||
|
|
||||||
|
$(BUILDDIR)/$(gmp_ver)/Makefile \
|
||||||
|
: $(GMP_CFG)
|
||||||
|
$(info Configuring $@. Log in $(@D)/log.config)
|
||||||
|
@mkdir -p $(@D)
|
||||||
|
( \
|
||||||
|
cd $(@D) ; \
|
||||||
|
$(PATHPRE) $(ENVS) CFLAGS="$(CFLAGS)" \
|
||||||
|
$(GMP_CFG) \
|
||||||
|
--host=$(HOST) --build=$(BUILD) \
|
||||||
|
--prefix=$(PREFIX) \
|
||||||
|
--disable-nls \
|
||||||
|
--program-prefix=$(TARGET)- \
|
||||||
|
--enable-shared=no \
|
||||||
|
--with-mpfr=$(PREFIX) \
|
||||||
|
) > $(@D)/log.config 2>&1
|
||||||
|
@echo 'done'
|
||||||
|
|
||||||
|
$(BUILDDIR)/$(mpc_ver)/Makefile \
|
||||||
|
: $(MPC_CFG)
|
||||||
|
$(info Configuring $@. Log in $(@D)/log.config)
|
||||||
|
@mkdir -p $(@D)
|
||||||
|
( \
|
||||||
|
cd $(@D) ; \
|
||||||
|
$(PATHPRE) $(ENVS) CFLAGS="$(CFLAGS)" \
|
||||||
|
$(MPC_CFG) \
|
||||||
|
$(CONFIG) \
|
||||||
|
--program-prefix=$(TARGET)- \
|
||||||
|
--enable-shared=no \
|
||||||
|
--with-mpfr=$(PREFIX) \
|
||||||
|
--with-gmp=$(PREFIX) \
|
||||||
|
) > $(@D)/log.config 2>&1
|
||||||
|
@echo 'done'
|
||||||
|
|
||||||
|
# Only valid if glibc target -> linux
|
||||||
|
# proper destructor handling for c++
|
||||||
|
ifneq (,$(findstring linux,$(TARGET)))
|
||||||
|
$(BUILDDIR)/$(gcc_ver)/Makefile : CONFIG += --enable-__cxa_atexit
|
||||||
|
endif
|
||||||
|
|
||||||
|
# Want:
|
||||||
|
# c,c++
|
||||||
|
# shared libs
|
||||||
|
# multilib (-m32/-m64 on x64)
|
||||||
|
# skip native language.
|
||||||
|
# and link and assemble with the binutils we created
|
||||||
|
# earlier, so --with-gnu*
|
||||||
|
$(BUILDDIR)/$(gcc_ver)/Makefile \
|
||||||
|
: $(GCC_CFG)
|
||||||
|
$(info Configuring $@. Log in $(@D)/log.config)
|
||||||
|
mkdir -p $(@D)
|
||||||
|
( \
|
||||||
|
cd $(@D) ; \
|
||||||
|
$(PATHPRE) $(ENVS) $(GCC_CFG) $(EXTRA_CFLAGS) \
|
||||||
|
$(CONFIG) \
|
||||||
|
--with-sysroot=$(SYSROOT) \
|
||||||
|
--enable-languages=c,c++ \
|
||||||
|
--enable-shared \
|
||||||
|
--enable-multilib \
|
||||||
|
--disable-nls \
|
||||||
|
--with-gnu-as \
|
||||||
|
--with-gnu-ld \
|
||||||
|
--with-mpfr=$(PREFIX) \
|
||||||
|
--with-gmp=$(PREFIX) \
|
||||||
|
--with-mpc=$(PREFIX) \
|
||||||
|
) > $(@D)/log.config 2>&1
|
||||||
|
@echo 'done'
|
||||||
|
|
||||||
|
# need binutils for gcc
|
||||||
|
$(gcc) : $(binutils)
|
||||||
|
|
||||||
|
# as of 4.3 or so need these for doing config
|
||||||
|
$(BUILDDIR)/$(gcc_ver)/Makefile : $(gmp) $(mpfr) $(mpc)
|
||||||
|
$(mpfr) : $(gmp)
|
||||||
|
$(mpc) : $(gmp) $(mpfr)
|
||||||
|
|
||||||
|
##########################################################################################
|
||||||
|
# very straightforward. just build a ccache. it is only for host.
|
||||||
|
$(BUILDDIR)/$(ccache_ver)/Makefile \
|
||||||
|
: $(CCACHE_CFG)
|
||||||
|
$(info Configuring $@. Log in $(@D)/log.config)
|
||||||
|
@mkdir -p $(@D)
|
||||||
|
@( \
|
||||||
|
cd $(@D) ; \
|
||||||
|
$(PATHPRE) $(ENVS) $(CCACHE_CFG) \
|
||||||
|
$(CONFIG) \
|
||||||
|
) > $(@D)/log.config 2>&1
|
||||||
|
@echo 'done'
|
||||||
|
|
||||||
|
gccpatch = $(TARGETDIR)/gcc-patched
|
||||||
|
|
||||||
|
##########################################################################################
|
||||||
|
# For some reason cpp is not created as a target-compiler
|
||||||
|
ifeq ($(HOST),$(TARGET))
|
||||||
|
$(gccpatch) : $(gcc) link_libs
|
||||||
|
@echo -n 'Creating compiler symlinks...'
|
||||||
|
@for f in cpp; do \
|
||||||
|
if [ ! -e $(PREFIX)/bin/$(TARGET)-$$f ];\
|
||||||
|
then \
|
||||||
|
cd $(PREFIX)/bin && \
|
||||||
|
ln -s $$f $(TARGET)-$$f ; \
|
||||||
|
fi \
|
||||||
|
done
|
||||||
|
@touch $@
|
||||||
|
@echo 'done'
|
||||||
|
|
||||||
|
##########################################################################################
|
||||||
|
# Ugly at best. Seems that when we compile host->host compiler, that are NOT
|
||||||
|
# the BUILD compiler, the result will not try searching for libs in package root.
|
||||||
|
# "Solve" this by create links from the target libdirs to where they are.
|
||||||
|
link_libs:
|
||||||
|
@echo -n 'Creating library symlinks...'
|
||||||
|
@$(foreach l,$(LIBDIRS), \
|
||||||
|
for f in `cd $(PREFIX)/$(l) && ls`; do \
|
||||||
|
if [ ! -e $(TARGETDIR)/$(l)/$$f ]; then \
|
||||||
|
mkdir -p $(TARGETDIR)/$(l) && \
|
||||||
|
cd $(TARGETDIR)/$(l)/ && \
|
||||||
|
ln -s $(if $(findstring /,$(l)),../,)../../$(l)/$$f $$f; \
|
||||||
|
fi \
|
||||||
|
done;)
|
||||||
|
@echo 'done'
|
||||||
|
else
|
||||||
|
$(gccpatch) :
|
||||||
|
@echo 'done'
|
||||||
|
endif
|
||||||
|
|
||||||
|
##########################################################################################
|
||||||
|
# Build in two steps.
|
||||||
|
# make <default>
|
||||||
|
# make install.
|
||||||
|
# Use path to our build hosts cross tools
|
||||||
|
# Always need to build cross tools for build host self.
|
||||||
|
$(TARGETDIR)/%.done : $(BUILDDIR)/%/Makefile
|
||||||
|
$(info Building $(basename $@). Log in $(<D)/log.build)
|
||||||
|
$(PATHPRE) $(ENVS) $(MAKE) $(BUILDPAR) -f $< -C $(<D) $(MAKECMD) $(MAKECMD.$(notdir $@)) > $(<D)/log.build 2>&1
|
||||||
|
@echo -n 'installing...'
|
||||||
|
$(PATHPRE) $(MAKE) $(INSTALLPAR) -f $< -C $(<D) $(INSTALLCMD) $(MAKECMD.$(notdir $@)) > $(<D)/log.install 2>&1
|
||||||
|
@touch $@
|
||||||
|
@echo 'done'
|
||||||
|
|
||||||
|
##########################################################################################
|
||||||
|
|
||||||
|
bfdlib : $(bfdlib)
|
||||||
|
binutils : $(binutils)
|
||||||
|
rpms : $(rpms)
|
||||||
|
libs : $(libs)
|
||||||
|
sysroot : rpms libs
|
||||||
|
gcc : sysroot $(gcc) $(gccpatch)
|
||||||
|
all : binutils gcc bfdlib
|
||||||
|
|
||||||
|
# this is only built for host. so separate.
|
||||||
|
ccache : $(ccache)
|
||||||
|
|
||||||
|
.PHONY : gcc all binutils bfdlib link_libs rpms libs sysroot
|
|
@ -215,3 +215,4 @@ c8286839d0df04aba819ec4bef12b86babccf30e jdk8-b90
|
||||||
8f7ffb296385f85a4a6d53f9f2d4a7b13a8fa1ff jdk8-b91
|
8f7ffb296385f85a4a6d53f9f2d4a7b13a8fa1ff jdk8-b91
|
||||||
717aa26f8e0a1c0e768aebb3a763aca56db0c83e jdk8-b92
|
717aa26f8e0a1c0e768aebb3a763aca56db0c83e jdk8-b92
|
||||||
8dc9d7ccbb2d77fd89bc321bb02e67c152aca257 jdk8-b93
|
8dc9d7ccbb2d77fd89bc321bb02e67c152aca257 jdk8-b93
|
||||||
|
22f5d7f261d9d61a953d2d9a53f2e9ce0ca361d1 jdk8-b94
|
||||||
|
|
|
@ -349,3 +349,7 @@ b19517cecc2e91636d7c16ba2f35e3d3dc628099 hs25-b33
|
||||||
573d86d412cd9d3df7912194c1a540be50e9544e jdk8-b93
|
573d86d412cd9d3df7912194c1a540be50e9544e jdk8-b93
|
||||||
b786c04b7be15194febe88dc1f0c9443e737a84b hs25-b35
|
b786c04b7be15194febe88dc1f0c9443e737a84b hs25-b35
|
||||||
3c78a14da19d26d6937af5f98b97e2a21c653b04 hs25-b36
|
3c78a14da19d26d6937af5f98b97e2a21c653b04 hs25-b36
|
||||||
|
1beed1f6f9edefe47ba8ed1355fbd3e7606b8288 jdk8-b94
|
||||||
|
69689078dff8b21e6df30870464f5d736eebdf72 hs25-b37
|
||||||
|
5d65c078cd0ac455aa5e58a09844c7acce54b487 jdk8-b95
|
||||||
|
2cc5a9d1ba66dfdff578918b393c727bd9450210 hs25-b38
|
||||||
|
|
|
@ -35,7 +35,7 @@ HOTSPOT_VM_COPYRIGHT=Copyright 2013
|
||||||
|
|
||||||
HS_MAJOR_VER=25
|
HS_MAJOR_VER=25
|
||||||
HS_MINOR_VER=0
|
HS_MINOR_VER=0
|
||||||
HS_BUILD_NUMBER=37
|
HS_BUILD_NUMBER=39
|
||||||
|
|
||||||
JDK_MAJOR_VER=1
|
JDK_MAJOR_VER=1
|
||||||
JDK_MINOR_VER=8
|
JDK_MINOR_VER=8
|
||||||
|
|
|
@ -57,7 +57,6 @@ class Assembler : public AbstractAssembler {
|
||||||
fbp_op2 = 5,
|
fbp_op2 = 5,
|
||||||
br_op2 = 2,
|
br_op2 = 2,
|
||||||
bp_op2 = 1,
|
bp_op2 = 1,
|
||||||
cb_op2 = 7, // V8
|
|
||||||
sethi_op2 = 4
|
sethi_op2 = 4
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -145,7 +144,6 @@ class Assembler : public AbstractAssembler {
|
||||||
ldsh_op3 = 0x0a,
|
ldsh_op3 = 0x0a,
|
||||||
ldx_op3 = 0x0b,
|
ldx_op3 = 0x0b,
|
||||||
|
|
||||||
ldstub_op3 = 0x0d,
|
|
||||||
stx_op3 = 0x0e,
|
stx_op3 = 0x0e,
|
||||||
swap_op3 = 0x0f,
|
swap_op3 = 0x0f,
|
||||||
|
|
||||||
|
@ -163,15 +161,6 @@ class Assembler : public AbstractAssembler {
|
||||||
|
|
||||||
prefetch_op3 = 0x2d,
|
prefetch_op3 = 0x2d,
|
||||||
|
|
||||||
|
|
||||||
ldc_op3 = 0x30,
|
|
||||||
ldcsr_op3 = 0x31,
|
|
||||||
lddc_op3 = 0x33,
|
|
||||||
stc_op3 = 0x34,
|
|
||||||
stcsr_op3 = 0x35,
|
|
||||||
stdcq_op3 = 0x36,
|
|
||||||
stdc_op3 = 0x37,
|
|
||||||
|
|
||||||
casa_op3 = 0x3c,
|
casa_op3 = 0x3c,
|
||||||
casxa_op3 = 0x3e,
|
casxa_op3 = 0x3e,
|
||||||
|
|
||||||
|
@ -574,17 +563,11 @@ class Assembler : public AbstractAssembler {
|
||||||
static void vis3_only() { assert( VM_Version::has_vis3(), "This instruction only works on SPARC with VIS3"); }
|
static void vis3_only() { assert( VM_Version::has_vis3(), "This instruction only works on SPARC with VIS3"); }
|
||||||
|
|
||||||
// instruction only in v9
|
// instruction only in v9
|
||||||
static void v9_only() { assert( VM_Version::v9_instructions_work(), "This instruction only works on SPARC V9"); }
|
static void v9_only() { } // do nothing
|
||||||
|
|
||||||
// instruction only in v8
|
|
||||||
static void v8_only() { assert( VM_Version::v8_instructions_work(), "This instruction only works on SPARC V8"); }
|
|
||||||
|
|
||||||
// instruction deprecated in v9
|
// instruction deprecated in v9
|
||||||
static void v9_dep() { } // do nothing for now
|
static void v9_dep() { } // do nothing for now
|
||||||
|
|
||||||
// some float instructions only exist for single prec. on v8
|
|
||||||
static void v8_s_only(FloatRegisterImpl::Width w) { if (w != FloatRegisterImpl::S) v9_only(); }
|
|
||||||
|
|
||||||
// v8 has no CC field
|
// v8 has no CC field
|
||||||
static void v8_no_cc(CC cc) { if (cc) v9_only(); }
|
static void v8_no_cc(CC cc) { if (cc) v9_only(); }
|
||||||
|
|
||||||
|
@ -730,11 +713,6 @@ public:
|
||||||
inline void bp( Condition c, bool a, CC cc, Predict p, address d, relocInfo::relocType rt = relocInfo::none );
|
inline void bp( Condition c, bool a, CC cc, Predict p, address d, relocInfo::relocType rt = relocInfo::none );
|
||||||
inline void bp( Condition c, bool a, CC cc, Predict p, Label& L );
|
inline void bp( Condition c, bool a, CC cc, Predict p, Label& L );
|
||||||
|
|
||||||
// pp 121 (V8)
|
|
||||||
|
|
||||||
inline void cb( Condition c, bool a, address d, relocInfo::relocType rt = relocInfo::none );
|
|
||||||
inline void cb( Condition c, bool a, Label& L );
|
|
||||||
|
|
||||||
// pp 149
|
// pp 149
|
||||||
|
|
||||||
inline void call( address d, relocInfo::relocType rt = relocInfo::runtime_call_type );
|
inline void call( address d, relocInfo::relocType rt = relocInfo::runtime_call_type );
|
||||||
|
@ -775,8 +753,8 @@ public:
|
||||||
|
|
||||||
// pp 157
|
// pp 157
|
||||||
|
|
||||||
void fcmp( FloatRegisterImpl::Width w, CC cc, FloatRegister s1, FloatRegister s2) { v8_no_cc(cc); emit_int32( op(arith_op) | cmpcc(cc) | op3(fpop2_op3) | fs1(s1, w) | opf(0x50 + w) | fs2(s2, w)); }
|
void fcmp( FloatRegisterImpl::Width w, CC cc, FloatRegister s1, FloatRegister s2) { emit_int32( op(arith_op) | cmpcc(cc) | op3(fpop2_op3) | fs1(s1, w) | opf(0x50 + w) | fs2(s2, w)); }
|
||||||
void fcmpe( FloatRegisterImpl::Width w, CC cc, FloatRegister s1, FloatRegister s2) { v8_no_cc(cc); emit_int32( op(arith_op) | cmpcc(cc) | op3(fpop2_op3) | fs1(s1, w) | opf(0x54 + w) | fs2(s2, w)); }
|
void fcmpe( FloatRegisterImpl::Width w, CC cc, FloatRegister s1, FloatRegister s2) { emit_int32( op(arith_op) | cmpcc(cc) | op3(fpop2_op3) | fs1(s1, w) | opf(0x54 + w) | fs2(s2, w)); }
|
||||||
|
|
||||||
// pp 159
|
// pp 159
|
||||||
|
|
||||||
|
@ -794,21 +772,11 @@ public:
|
||||||
|
|
||||||
// pp 162
|
// pp 162
|
||||||
|
|
||||||
void fmov( FloatRegisterImpl::Width w, FloatRegister s, FloatRegister d ) { v8_s_only(w); emit_int32( op(arith_op) | fd(d, w) | op3(fpop1_op3) | opf(0x00 + w) | fs2(s, w)); }
|
void fmov( FloatRegisterImpl::Width w, FloatRegister s, FloatRegister d ) { emit_int32( op(arith_op) | fd(d, w) | op3(fpop1_op3) | opf(0x00 + w) | fs2(s, w)); }
|
||||||
|
|
||||||
void fneg( FloatRegisterImpl::Width w, FloatRegister s, FloatRegister d ) { v8_s_only(w); emit_int32( op(arith_op) | fd(d, w) | op3(fpop1_op3) | opf(0x04 + w) | fs2(s, w)); }
|
void fneg( FloatRegisterImpl::Width w, FloatRegister s, FloatRegister d ) { emit_int32( op(arith_op) | fd(d, w) | op3(fpop1_op3) | opf(0x04 + w) | fs2(s, w)); }
|
||||||
|
|
||||||
// page 144 sparc v8 architecture (double prec works on v8 if the source and destination registers are the same). fnegs is the only instruction available
|
void fabs( FloatRegisterImpl::Width w, FloatRegister s, FloatRegister d ) { emit_int32( op(arith_op) | fd(d, w) | op3(fpop1_op3) | opf(0x08 + w) | fs2(s, w)); }
|
||||||
// on v8 to do negation of single, double and quad precision floats.
|
|
||||||
|
|
||||||
void fneg( FloatRegisterImpl::Width w, FloatRegister sd ) { if (VM_Version::v9_instructions_work()) emit_int32( op(arith_op) | fd(sd, w) | op3(fpop1_op3) | opf(0x04 + w) | fs2(sd, w)); else emit_int32( op(arith_op) | fd(sd, w) | op3(fpop1_op3) | opf(0x05) | fs2(sd, w)); }
|
|
||||||
|
|
||||||
void fabs( FloatRegisterImpl::Width w, FloatRegister s, FloatRegister d ) { v8_s_only(w); emit_int32( op(arith_op) | fd(d, w) | op3(fpop1_op3) | opf(0x08 + w) | fs2(s, w)); }
|
|
||||||
|
|
||||||
// page 144 sparc v8 architecture (double prec works on v8 if the source and destination registers are the same). fabss is the only instruction available
|
|
||||||
// on v8 to do abs operation on single/double/quad precision floats.
|
|
||||||
|
|
||||||
void fabs( FloatRegisterImpl::Width w, FloatRegister sd ) { if (VM_Version::v9_instructions_work()) emit_int32( op(arith_op) | fd(sd, w) | op3(fpop1_op3) | opf(0x08 + w) | fs2(sd, w)); else emit_int32( op(arith_op) | fd(sd, w) | op3(fpop1_op3) | opf(0x09) | fs2(sd, w)); }
|
|
||||||
|
|
||||||
// pp 163
|
// pp 163
|
||||||
|
|
||||||
|
@ -839,11 +807,6 @@ public:
|
||||||
void impdep1( int id1, int const19a ) { v9_only(); emit_int32( op(arith_op) | fcn(id1) | op3(impdep1_op3) | u_field(const19a, 18, 0)); }
|
void impdep1( int id1, int const19a ) { v9_only(); emit_int32( op(arith_op) | fcn(id1) | op3(impdep1_op3) | u_field(const19a, 18, 0)); }
|
||||||
void impdep2( int id1, int const19a ) { v9_only(); emit_int32( op(arith_op) | fcn(id1) | op3(impdep2_op3) | u_field(const19a, 18, 0)); }
|
void impdep2( int id1, int const19a ) { v9_only(); emit_int32( op(arith_op) | fcn(id1) | op3(impdep2_op3) | u_field(const19a, 18, 0)); }
|
||||||
|
|
||||||
// pp 149 (v8)
|
|
||||||
|
|
||||||
void cpop1( int opc, int cr1, int cr2, int crd ) { v8_only(); emit_int32( op(arith_op) | fcn(crd) | op3(impdep1_op3) | u_field(cr1, 18, 14) | opf(opc) | u_field(cr2, 4, 0)); }
|
|
||||||
void cpop2( int opc, int cr1, int cr2, int crd ) { v8_only(); emit_int32( op(arith_op) | fcn(crd) | op3(impdep2_op3) | u_field(cr1, 18, 14) | opf(opc) | u_field(cr2, 4, 0)); }
|
|
||||||
|
|
||||||
// pp 170
|
// pp 170
|
||||||
|
|
||||||
void jmpl( Register s1, Register s2, Register d );
|
void jmpl( Register s1, Register s2, Register d );
|
||||||
|
@ -860,16 +823,6 @@ public:
|
||||||
inline void ldxfsr( Register s1, Register s2 );
|
inline void ldxfsr( Register s1, Register s2 );
|
||||||
inline void ldxfsr( Register s1, int simm13a);
|
inline void ldxfsr( Register s1, int simm13a);
|
||||||
|
|
||||||
// pp 94 (v8)
|
|
||||||
|
|
||||||
inline void ldc( Register s1, Register s2, int crd );
|
|
||||||
inline void ldc( Register s1, int simm13a, int crd);
|
|
||||||
inline void lddc( Register s1, Register s2, int crd );
|
|
||||||
inline void lddc( Register s1, int simm13a, int crd);
|
|
||||||
inline void ldcsr( Register s1, Register s2, int crd );
|
|
||||||
inline void ldcsr( Register s1, int simm13a, int crd);
|
|
||||||
|
|
||||||
|
|
||||||
// 173
|
// 173
|
||||||
|
|
||||||
void ldfa( FloatRegisterImpl::Width w, Register s1, Register s2, int ia, FloatRegister d ) { v9_only(); emit_int32( op(ldst_op) | fd(d, w) | alt_op3(ldf_op3 | alt_bit_op3, w) | rs1(s1) | imm_asi(ia) | rs2(s2) ); }
|
void ldfa( FloatRegisterImpl::Width w, Register s1, Register s2, int ia, FloatRegister d ) { v9_only(); emit_int32( op(ldst_op) | fd(d, w) | alt_op3(ldf_op3 | alt_bit_op3, w) | rs1(s1) | imm_asi(ia) | rs2(s2) ); }
|
||||||
|
@ -910,18 +863,6 @@ public:
|
||||||
void lduwa( Register s1, int simm13a, Register d ) { emit_int32( op(ldst_op) | rd(d) | op3(lduw_op3 | alt_bit_op3) | rs1(s1) | immed(true) | simm(simm13a, 13) ); }
|
void lduwa( Register s1, int simm13a, Register d ) { emit_int32( op(ldst_op) | rd(d) | op3(lduw_op3 | alt_bit_op3) | rs1(s1) | immed(true) | simm(simm13a, 13) ); }
|
||||||
void ldxa( Register s1, Register s2, int ia, Register d ) { v9_only(); emit_int32( op(ldst_op) | rd(d) | op3(ldx_op3 | alt_bit_op3) | rs1(s1) | imm_asi(ia) | rs2(s2) ); }
|
void ldxa( Register s1, Register s2, int ia, Register d ) { v9_only(); emit_int32( op(ldst_op) | rd(d) | op3(ldx_op3 | alt_bit_op3) | rs1(s1) | imm_asi(ia) | rs2(s2) ); }
|
||||||
void ldxa( Register s1, int simm13a, Register d ) { v9_only(); emit_int32( op(ldst_op) | rd(d) | op3(ldx_op3 | alt_bit_op3) | rs1(s1) | immed(true) | simm(simm13a, 13) ); }
|
void ldxa( Register s1, int simm13a, Register d ) { v9_only(); emit_int32( op(ldst_op) | rd(d) | op3(ldx_op3 | alt_bit_op3) | rs1(s1) | immed(true) | simm(simm13a, 13) ); }
|
||||||
void ldda( Register s1, Register s2, int ia, Register d ) { v9_dep(); emit_int32( op(ldst_op) | rd(d) | op3(ldd_op3 | alt_bit_op3) | rs1(s1) | imm_asi(ia) | rs2(s2) ); }
|
|
||||||
void ldda( Register s1, int simm13a, Register d ) { v9_dep(); emit_int32( op(ldst_op) | rd(d) | op3(ldd_op3 | alt_bit_op3) | rs1(s1) | immed(true) | simm(simm13a, 13) ); }
|
|
||||||
|
|
||||||
// pp 179
|
|
||||||
|
|
||||||
inline void ldstub( Register s1, Register s2, Register d );
|
|
||||||
inline void ldstub( Register s1, int simm13a, Register d);
|
|
||||||
|
|
||||||
// pp 180
|
|
||||||
|
|
||||||
void ldstuba( Register s1, Register s2, int ia, Register d ) { emit_int32( op(ldst_op) | rd(d) | op3(ldstub_op3 | alt_bit_op3) | rs1(s1) | imm_asi(ia) | rs2(s2) ); }
|
|
||||||
void ldstuba( Register s1, int simm13a, Register d ) { emit_int32( op(ldst_op) | rd(d) | op3(ldstub_op3 | alt_bit_op3) | rs1(s1) | immed(true) | simm(simm13a, 13) ); }
|
|
||||||
|
|
||||||
// pp 181
|
// pp 181
|
||||||
|
|
||||||
|
@ -992,11 +933,6 @@ public:
|
||||||
void smulcc( Register s1, Register s2, Register d ) { emit_int32( op(arith_op) | rd(d) | op3(smul_op3 | cc_bit_op3) | rs1(s1) | rs2(s2) ); }
|
void smulcc( Register s1, Register s2, Register d ) { emit_int32( op(arith_op) | rd(d) | op3(smul_op3 | cc_bit_op3) | rs1(s1) | rs2(s2) ); }
|
||||||
void smulcc( Register s1, int simm13a, Register d ) { emit_int32( op(arith_op) | rd(d) | op3(smul_op3 | cc_bit_op3) | rs1(s1) | immed(true) | simm(simm13a, 13) ); }
|
void smulcc( Register s1, int simm13a, Register d ) { emit_int32( op(arith_op) | rd(d) | op3(smul_op3 | cc_bit_op3) | rs1(s1) | immed(true) | simm(simm13a, 13) ); }
|
||||||
|
|
||||||
// pp 199
|
|
||||||
|
|
||||||
void mulscc( Register s1, Register s2, Register d ) { v9_dep(); emit_int32( op(arith_op) | rd(d) | op3(mulscc_op3) | rs1(s1) | rs2(s2) ); }
|
|
||||||
void mulscc( Register s1, int simm13a, Register d ) { v9_dep(); emit_int32( op(arith_op) | rd(d) | op3(mulscc_op3) | rs1(s1) | immed(true) | simm(simm13a, 13) ); }
|
|
||||||
|
|
||||||
// pp 201
|
// pp 201
|
||||||
|
|
||||||
void nop() { emit_int32( op(branch_op) | op2(sethi_op2) ); }
|
void nop() { emit_int32( op(branch_op) | op2(sethi_op2) ); }
|
||||||
|
@ -1116,17 +1052,6 @@ public:
|
||||||
void stda( Register d, Register s1, Register s2, int ia ) { emit_int32( op(ldst_op) | rd(d) | op3(std_op3 | alt_bit_op3) | rs1(s1) | imm_asi(ia) | rs2(s2) ); }
|
void stda( Register d, Register s1, Register s2, int ia ) { emit_int32( op(ldst_op) | rd(d) | op3(std_op3 | alt_bit_op3) | rs1(s1) | imm_asi(ia) | rs2(s2) ); }
|
||||||
void stda( Register d, Register s1, int simm13a ) { emit_int32( op(ldst_op) | rd(d) | op3(std_op3 | alt_bit_op3) | rs1(s1) | immed(true) | simm(simm13a, 13) ); }
|
void stda( Register d, Register s1, int simm13a ) { emit_int32( op(ldst_op) | rd(d) | op3(std_op3 | alt_bit_op3) | rs1(s1) | immed(true) | simm(simm13a, 13) ); }
|
||||||
|
|
||||||
// pp 97 (v8)
|
|
||||||
|
|
||||||
inline void stc( int crd, Register s1, Register s2 );
|
|
||||||
inline void stc( int crd, Register s1, int simm13a);
|
|
||||||
inline void stdc( int crd, Register s1, Register s2 );
|
|
||||||
inline void stdc( int crd, Register s1, int simm13a);
|
|
||||||
inline void stcsr( int crd, Register s1, Register s2 );
|
|
||||||
inline void stcsr( int crd, Register s1, int simm13a);
|
|
||||||
inline void stdcq( int crd, Register s1, Register s2 );
|
|
||||||
inline void stdcq( int crd, Register s1, int simm13a);
|
|
||||||
|
|
||||||
// pp 230
|
// pp 230
|
||||||
|
|
||||||
void sub( Register s1, Register s2, Register d ) { emit_int32( op(arith_op) | rd(d) | op3(sub_op3 ) | rs1(s1) | rs2(s2) ); }
|
void sub( Register s1, Register s2, Register d ) { emit_int32( op(arith_op) | rd(d) | op3(sub_op3 ) | rs1(s1) | rs2(s2) ); }
|
||||||
|
@ -1153,20 +1078,16 @@ public:
|
||||||
|
|
||||||
void taddcc( Register s1, Register s2, Register d ) { emit_int32( op(arith_op) | rd(d) | op3(taddcc_op3 ) | rs1(s1) | rs2(s2) ); }
|
void taddcc( Register s1, Register s2, Register d ) { emit_int32( op(arith_op) | rd(d) | op3(taddcc_op3 ) | rs1(s1) | rs2(s2) ); }
|
||||||
void taddcc( Register s1, int simm13a, Register d ) { emit_int32( op(arith_op) | rd(d) | op3(taddcc_op3 ) | rs1(s1) | immed(true) | simm(simm13a, 13) ); }
|
void taddcc( Register s1, int simm13a, Register d ) { emit_int32( op(arith_op) | rd(d) | op3(taddcc_op3 ) | rs1(s1) | immed(true) | simm(simm13a, 13) ); }
|
||||||
void taddcctv( Register s1, Register s2, Register d ) { v9_dep(); emit_int32( op(arith_op) | rd(d) | op3(taddcctv_op3) | rs1(s1) | rs2(s2) ); }
|
|
||||||
void taddcctv( Register s1, int simm13a, Register d ) { v9_dep(); emit_int32( op(arith_op) | rd(d) | op3(taddcctv_op3) | rs1(s1) | immed(true) | simm(simm13a, 13) ); }
|
|
||||||
|
|
||||||
// pp 235
|
// pp 235
|
||||||
|
|
||||||
void tsubcc( Register s1, Register s2, Register d ) { emit_int32( op(arith_op) | rd(d) | op3(tsubcc_op3 ) | rs1(s1) | rs2(s2) ); }
|
void tsubcc( Register s1, Register s2, Register d ) { emit_int32( op(arith_op) | rd(d) | op3(tsubcc_op3 ) | rs1(s1) | rs2(s2) ); }
|
||||||
void tsubcc( Register s1, int simm13a, Register d ) { emit_int32( op(arith_op) | rd(d) | op3(tsubcc_op3 ) | rs1(s1) | immed(true) | simm(simm13a, 13) ); }
|
void tsubcc( Register s1, int simm13a, Register d ) { emit_int32( op(arith_op) | rd(d) | op3(tsubcc_op3 ) | rs1(s1) | immed(true) | simm(simm13a, 13) ); }
|
||||||
void tsubcctv( Register s1, Register s2, Register d ) { emit_int32( op(arith_op) | rd(d) | op3(tsubcctv_op3) | rs1(s1) | rs2(s2) ); }
|
|
||||||
void tsubcctv( Register s1, int simm13a, Register d ) { emit_int32( op(arith_op) | rd(d) | op3(tsubcctv_op3) | rs1(s1) | immed(true) | simm(simm13a, 13) ); }
|
|
||||||
|
|
||||||
// pp 237
|
// pp 237
|
||||||
|
|
||||||
void trap( Condition c, CC cc, Register s1, Register s2 ) { v8_no_cc(cc); emit_int32( op(arith_op) | cond(c) | op3(trap_op3) | rs1(s1) | trapcc(cc) | rs2(s2)); }
|
void trap( Condition c, CC cc, Register s1, Register s2 ) { emit_int32( op(arith_op) | cond(c) | op3(trap_op3) | rs1(s1) | trapcc(cc) | rs2(s2)); }
|
||||||
void trap( Condition c, CC cc, Register s1, int trapa ) { v8_no_cc(cc); emit_int32( op(arith_op) | cond(c) | op3(trap_op3) | rs1(s1) | trapcc(cc) | immed(true) | u_field(trapa, 6, 0)); }
|
void trap( Condition c, CC cc, Register s1, int trapa ) { emit_int32( op(arith_op) | cond(c) | op3(trap_op3) | rs1(s1) | trapcc(cc) | immed(true) | u_field(trapa, 6, 0)); }
|
||||||
// simple uncond. trap
|
// simple uncond. trap
|
||||||
void trap( int trapa ) { trap( always, icc, G0, trapa ); }
|
void trap( int trapa ) { trap( always, icc, G0, trapa ); }
|
||||||
|
|
||||||
|
|
|
@ -63,9 +63,6 @@ inline void Assembler::fb( Condition c, bool a, Label& L ) { fb(c, a, target(L))
|
||||||
inline void Assembler::fbp( Condition c, bool a, CC cc, Predict p, address d, relocInfo::relocType rt ) { v9_only(); cti(); emit_data( op(branch_op) | annul(a) | cond(c) | op2(fbp_op2) | branchcc(cc) | predict(p) | wdisp(intptr_t(d), intptr_t(pc()), 19), rt); has_delay_slot(); }
|
inline void Assembler::fbp( Condition c, bool a, CC cc, Predict p, address d, relocInfo::relocType rt ) { v9_only(); cti(); emit_data( op(branch_op) | annul(a) | cond(c) | op2(fbp_op2) | branchcc(cc) | predict(p) | wdisp(intptr_t(d), intptr_t(pc()), 19), rt); has_delay_slot(); }
|
||||||
inline void Assembler::fbp( Condition c, bool a, CC cc, Predict p, Label& L ) { fbp(c, a, cc, p, target(L)); }
|
inline void Assembler::fbp( Condition c, bool a, CC cc, Predict p, Label& L ) { fbp(c, a, cc, p, target(L)); }
|
||||||
|
|
||||||
inline void Assembler::cb( Condition c, bool a, address d, relocInfo::relocType rt ) { v8_only(); cti(); emit_data( op(branch_op) | annul(a) | cond(c) | op2(cb_op2) | wdisp(intptr_t(d), intptr_t(pc()), 22), rt); has_delay_slot(); }
|
|
||||||
inline void Assembler::cb( Condition c, bool a, Label& L ) { cb(c, a, target(L)); }
|
|
||||||
|
|
||||||
inline void Assembler::br( Condition c, bool a, address d, relocInfo::relocType rt ) { v9_dep(); cti(); emit_data( op(branch_op) | annul(a) | cond(c) | op2(br_op2) | wdisp(intptr_t(d), intptr_t(pc()), 22), rt); has_delay_slot(); }
|
inline void Assembler::br( Condition c, bool a, address d, relocInfo::relocType rt ) { v9_dep(); cti(); emit_data( op(branch_op) | annul(a) | cond(c) | op2(br_op2) | wdisp(intptr_t(d), intptr_t(pc()), 22), rt); has_delay_slot(); }
|
||||||
inline void Assembler::br( Condition c, bool a, Label& L ) { br(c, a, target(L)); }
|
inline void Assembler::br( Condition c, bool a, Label& L ) { br(c, a, target(L)); }
|
||||||
|
|
||||||
|
@ -88,18 +85,9 @@ inline void Assembler::jmpl( Register s1, int simm13a, Register d, RelocationHol
|
||||||
inline void Assembler::ldf(FloatRegisterImpl::Width w, Register s1, Register s2, FloatRegister d) { emit_int32( op(ldst_op) | fd(d, w) | alt_op3(ldf_op3, w) | rs1(s1) | rs2(s2) ); }
|
inline void Assembler::ldf(FloatRegisterImpl::Width w, Register s1, Register s2, FloatRegister d) { emit_int32( op(ldst_op) | fd(d, w) | alt_op3(ldf_op3, w) | rs1(s1) | rs2(s2) ); }
|
||||||
inline void Assembler::ldf(FloatRegisterImpl::Width w, Register s1, int simm13a, FloatRegister d, RelocationHolder const& rspec) { emit_data( op(ldst_op) | fd(d, w) | alt_op3(ldf_op3, w) | rs1(s1) | immed(true) | simm(simm13a, 13), rspec); }
|
inline void Assembler::ldf(FloatRegisterImpl::Width w, Register s1, int simm13a, FloatRegister d, RelocationHolder const& rspec) { emit_data( op(ldst_op) | fd(d, w) | alt_op3(ldf_op3, w) | rs1(s1) | immed(true) | simm(simm13a, 13), rspec); }
|
||||||
|
|
||||||
inline void Assembler::ldfsr( Register s1, Register s2) { v9_dep(); emit_int32( op(ldst_op) | op3(ldfsr_op3) | rs1(s1) | rs2(s2) ); }
|
|
||||||
inline void Assembler::ldfsr( Register s1, int simm13a) { v9_dep(); emit_data( op(ldst_op) | op3(ldfsr_op3) | rs1(s1) | immed(true) | simm(simm13a, 13)); }
|
|
||||||
inline void Assembler::ldxfsr( Register s1, Register s2) { v9_only(); emit_int32( op(ldst_op) | rd(G1) | op3(ldfsr_op3) | rs1(s1) | rs2(s2) ); }
|
inline void Assembler::ldxfsr( Register s1, Register s2) { v9_only(); emit_int32( op(ldst_op) | rd(G1) | op3(ldfsr_op3) | rs1(s1) | rs2(s2) ); }
|
||||||
inline void Assembler::ldxfsr( Register s1, int simm13a) { v9_only(); emit_data( op(ldst_op) | rd(G1) | op3(ldfsr_op3) | rs1(s1) | immed(true) | simm(simm13a, 13)); }
|
inline void Assembler::ldxfsr( Register s1, int simm13a) { v9_only(); emit_data( op(ldst_op) | rd(G1) | op3(ldfsr_op3) | rs1(s1) | immed(true) | simm(simm13a, 13)); }
|
||||||
|
|
||||||
inline void Assembler::ldc( Register s1, Register s2, int crd) { v8_only(); emit_int32( op(ldst_op) | fcn(crd) | op3(ldc_op3 ) | rs1(s1) | rs2(s2) ); }
|
|
||||||
inline void Assembler::ldc( Register s1, int simm13a, int crd) { v8_only(); emit_data( op(ldst_op) | fcn(crd) | op3(ldc_op3 ) | rs1(s1) | immed(true) | simm(simm13a, 13)); }
|
|
||||||
inline void Assembler::lddc( Register s1, Register s2, int crd) { v8_only(); emit_int32( op(ldst_op) | fcn(crd) | op3(lddc_op3 ) | rs1(s1) | rs2(s2) ); }
|
|
||||||
inline void Assembler::lddc( Register s1, int simm13a, int crd) { v8_only(); emit_data( op(ldst_op) | fcn(crd) | op3(lddc_op3 ) | rs1(s1) | immed(true) | simm(simm13a, 13)); }
|
|
||||||
inline void Assembler::ldcsr( Register s1, Register s2, int crd) { v8_only(); emit_int32( op(ldst_op) | fcn(crd) | op3(ldcsr_op3) | rs1(s1) | rs2(s2) ); }
|
|
||||||
inline void Assembler::ldcsr( Register s1, int simm13a, int crd) { v8_only(); emit_data( op(ldst_op) | fcn(crd) | op3(ldcsr_op3) | rs1(s1) | immed(true) | simm(simm13a, 13)); }
|
|
||||||
|
|
||||||
inline void Assembler::ldsb( Register s1, Register s2, Register d) { emit_int32( op(ldst_op) | rd(d) | op3(ldsb_op3) | rs1(s1) | rs2(s2) ); }
|
inline void Assembler::ldsb( Register s1, Register s2, Register d) { emit_int32( op(ldst_op) | rd(d) | op3(ldsb_op3) | rs1(s1) | rs2(s2) ); }
|
||||||
inline void Assembler::ldsb( Register s1, int simm13a, Register d) { emit_data( op(ldst_op) | rd(d) | op3(ldsb_op3) | rs1(s1) | immed(true) | simm(simm13a, 13)); }
|
inline void Assembler::ldsb( Register s1, int simm13a, Register d) { emit_data( op(ldst_op) | rd(d) | op3(ldsb_op3) | rs1(s1) | immed(true) | simm(simm13a, 13)); }
|
||||||
|
|
||||||
|
@ -119,9 +107,6 @@ inline void Assembler::ldx( Register s1, int simm13a, Register d) { v9_only();
|
||||||
inline void Assembler::ldd( Register s1, Register s2, Register d) { v9_dep(); assert(d->is_even(), "not even"); emit_int32( op(ldst_op) | rd(d) | op3(ldd_op3) | rs1(s1) | rs2(s2) ); }
|
inline void Assembler::ldd( Register s1, Register s2, Register d) { v9_dep(); assert(d->is_even(), "not even"); emit_int32( op(ldst_op) | rd(d) | op3(ldd_op3) | rs1(s1) | rs2(s2) ); }
|
||||||
inline void Assembler::ldd( Register s1, int simm13a, Register d) { v9_dep(); assert(d->is_even(), "not even"); emit_data( op(ldst_op) | rd(d) | op3(ldd_op3) | rs1(s1) | immed(true) | simm(simm13a, 13)); }
|
inline void Assembler::ldd( Register s1, int simm13a, Register d) { v9_dep(); assert(d->is_even(), "not even"); emit_data( op(ldst_op) | rd(d) | op3(ldd_op3) | rs1(s1) | immed(true) | simm(simm13a, 13)); }
|
||||||
|
|
||||||
inline void Assembler::ldstub( Register s1, Register s2, Register d) { emit_int32( op(ldst_op) | rd(d) | op3(ldstub_op3) | rs1(s1) | rs2(s2) ); }
|
|
||||||
inline void Assembler::ldstub( Register s1, int simm13a, Register d) { emit_data( op(ldst_op) | rd(d) | op3(ldstub_op3) | rs1(s1) | immed(true) | simm(simm13a, 13)); }
|
|
||||||
|
|
||||||
inline void Assembler::rett( Register s1, Register s2 ) { cti(); emit_int32( op(arith_op) | op3(rett_op3) | rs1(s1) | rs2(s2)); has_delay_slot(); }
|
inline void Assembler::rett( Register s1, Register s2 ) { cti(); emit_int32( op(arith_op) | op3(rett_op3) | rs1(s1) | rs2(s2)); has_delay_slot(); }
|
||||||
inline void Assembler::rett( Register s1, int simm13a, relocInfo::relocType rt) { cti(); emit_data( op(arith_op) | op3(rett_op3) | rs1(s1) | immed(true) | simm(simm13a, 13), rt); has_delay_slot(); }
|
inline void Assembler::rett( Register s1, int simm13a, relocInfo::relocType rt) { cti(); emit_data( op(arith_op) | op3(rett_op3) | rs1(s1) | immed(true) | simm(simm13a, 13), rt); has_delay_slot(); }
|
||||||
|
|
||||||
|
@ -132,8 +117,6 @@ inline void Assembler::sethi( int imm22a, Register d, RelocationHolder const& rs
|
||||||
inline void Assembler::stf( FloatRegisterImpl::Width w, FloatRegister d, Register s1, Register s2) { emit_int32( op(ldst_op) | fd(d, w) | alt_op3(stf_op3, w) | rs1(s1) | rs2(s2) ); }
|
inline void Assembler::stf( FloatRegisterImpl::Width w, FloatRegister d, Register s1, Register s2) { emit_int32( op(ldst_op) | fd(d, w) | alt_op3(stf_op3, w) | rs1(s1) | rs2(s2) ); }
|
||||||
inline void Assembler::stf( FloatRegisterImpl::Width w, FloatRegister d, Register s1, int simm13a) { emit_data( op(ldst_op) | fd(d, w) | alt_op3(stf_op3, w) | rs1(s1) | immed(true) | simm(simm13a, 13)); }
|
inline void Assembler::stf( FloatRegisterImpl::Width w, FloatRegister d, Register s1, int simm13a) { emit_data( op(ldst_op) | fd(d, w) | alt_op3(stf_op3, w) | rs1(s1) | immed(true) | simm(simm13a, 13)); }
|
||||||
|
|
||||||
inline void Assembler::stfsr( Register s1, Register s2) { v9_dep(); emit_int32( op(ldst_op) | op3(stfsr_op3) | rs1(s1) | rs2(s2) ); }
|
|
||||||
inline void Assembler::stfsr( Register s1, int simm13a) { v9_dep(); emit_data( op(ldst_op) | op3(stfsr_op3) | rs1(s1) | immed(true) | simm(simm13a, 13)); }
|
|
||||||
inline void Assembler::stxfsr( Register s1, Register s2) { v9_only(); emit_int32( op(ldst_op) | rd(G1) | op3(stfsr_op3) | rs1(s1) | rs2(s2) ); }
|
inline void Assembler::stxfsr( Register s1, Register s2) { v9_only(); emit_int32( op(ldst_op) | rd(G1) | op3(stfsr_op3) | rs1(s1) | rs2(s2) ); }
|
||||||
inline void Assembler::stxfsr( Register s1, int simm13a) { v9_only(); emit_data( op(ldst_op) | rd(G1) | op3(stfsr_op3) | rs1(s1) | immed(true) | simm(simm13a, 13)); }
|
inline void Assembler::stxfsr( Register s1, int simm13a) { v9_only(); emit_data( op(ldst_op) | rd(G1) | op3(stfsr_op3) | rs1(s1) | immed(true) | simm(simm13a, 13)); }
|
||||||
|
|
||||||
|
@ -152,17 +135,6 @@ inline void Assembler::stx( Register d, Register s1, int simm13a) { v9_only();
|
||||||
inline void Assembler::std( Register d, Register s1, Register s2) { v9_dep(); assert(d->is_even(), "not even"); emit_int32( op(ldst_op) | rd(d) | op3(std_op3) | rs1(s1) | rs2(s2) ); }
|
inline void Assembler::std( Register d, Register s1, Register s2) { v9_dep(); assert(d->is_even(), "not even"); emit_int32( op(ldst_op) | rd(d) | op3(std_op3) | rs1(s1) | rs2(s2) ); }
|
||||||
inline void Assembler::std( Register d, Register s1, int simm13a) { v9_dep(); assert(d->is_even(), "not even"); emit_data( op(ldst_op) | rd(d) | op3(std_op3) | rs1(s1) | immed(true) | simm(simm13a, 13)); }
|
inline void Assembler::std( Register d, Register s1, int simm13a) { v9_dep(); assert(d->is_even(), "not even"); emit_data( op(ldst_op) | rd(d) | op3(std_op3) | rs1(s1) | immed(true) | simm(simm13a, 13)); }
|
||||||
|
|
||||||
// v8 p 99
|
|
||||||
|
|
||||||
inline void Assembler::stc( int crd, Register s1, Register s2) { v8_only(); emit_int32( op(ldst_op) | fcn(crd) | op3(stc_op3 ) | rs1(s1) | rs2(s2) ); }
|
|
||||||
inline void Assembler::stc( int crd, Register s1, int simm13a) { v8_only(); emit_data( op(ldst_op) | fcn(crd) | op3(stc_op3 ) | rs1(s1) | immed(true) | simm(simm13a, 13)); }
|
|
||||||
inline void Assembler::stdc( int crd, Register s1, Register s2) { v8_only(); emit_int32( op(ldst_op) | fcn(crd) | op3(stdc_op3) | rs1(s1) | rs2(s2) ); }
|
|
||||||
inline void Assembler::stdc( int crd, Register s1, int simm13a) { v8_only(); emit_data( op(ldst_op) | fcn(crd) | op3(stdc_op3) | rs1(s1) | immed(true) | simm(simm13a, 13)); }
|
|
||||||
inline void Assembler::stcsr( int crd, Register s1, Register s2) { v8_only(); emit_int32( op(ldst_op) | fcn(crd) | op3(stcsr_op3) | rs1(s1) | rs2(s2) ); }
|
|
||||||
inline void Assembler::stcsr( int crd, Register s1, int simm13a) { v8_only(); emit_data( op(ldst_op) | fcn(crd) | op3(stcsr_op3) | rs1(s1) | immed(true) | simm(simm13a, 13)); }
|
|
||||||
inline void Assembler::stdcq( int crd, Register s1, Register s2) { v8_only(); emit_int32( op(ldst_op) | fcn(crd) | op3(stdcq_op3) | rs1(s1) | rs2(s2) ); }
|
|
||||||
inline void Assembler::stdcq( int crd, Register s1, int simm13a) { v8_only(); emit_data( op(ldst_op) | fcn(crd) | op3(stdcq_op3) | rs1(s1) | immed(true) | simm(simm13a, 13)); }
|
|
||||||
|
|
||||||
// pp 231
|
// pp 231
|
||||||
|
|
||||||
inline void Assembler::swap( Register s1, Register s2, Register d) { v9_dep(); emit_int32( op(ldst_op) | rd(d) | op3(swap_op3) | rs1(s1) | rs2(s2) ); }
|
inline void Assembler::swap( Register s1, Register s2, Register d) { v9_dep(); emit_int32( op(ldst_op) | rd(d) | op3(swap_op3) | rs1(s1) | rs2(s2) ); }
|
||||||
|
|
|
@ -597,13 +597,6 @@ void LIR_Assembler::emit_op3(LIR_Op3* op) {
|
||||||
|
|
||||||
__ sra(Rdividend, 31, Rscratch);
|
__ sra(Rdividend, 31, Rscratch);
|
||||||
__ wry(Rscratch);
|
__ wry(Rscratch);
|
||||||
if (!VM_Version::v9_instructions_work()) {
|
|
||||||
// v9 doesn't require these nops
|
|
||||||
__ nop();
|
|
||||||
__ nop();
|
|
||||||
__ nop();
|
|
||||||
__ nop();
|
|
||||||
}
|
|
||||||
|
|
||||||
add_debug_info_for_div0_here(op->info());
|
add_debug_info_for_div0_here(op->info());
|
||||||
|
|
||||||
|
@ -652,10 +645,6 @@ void LIR_Assembler::emit_opBranch(LIR_OpBranch* op) {
|
||||||
case lir_cond_lessEqual: acond = (is_unordered ? Assembler::f_unorderedOrLessOrEqual : Assembler::f_lessOrEqual); break;
|
case lir_cond_lessEqual: acond = (is_unordered ? Assembler::f_unorderedOrLessOrEqual : Assembler::f_lessOrEqual); break;
|
||||||
case lir_cond_greaterEqual: acond = (is_unordered ? Assembler::f_unorderedOrGreaterOrEqual: Assembler::f_greaterOrEqual); break;
|
case lir_cond_greaterEqual: acond = (is_unordered ? Assembler::f_unorderedOrGreaterOrEqual: Assembler::f_greaterOrEqual); break;
|
||||||
default : ShouldNotReachHere();
|
default : ShouldNotReachHere();
|
||||||
};
|
|
||||||
|
|
||||||
if (!VM_Version::v9_instructions_work()) {
|
|
||||||
__ nop();
|
|
||||||
}
|
}
|
||||||
__ fb( acond, false, Assembler::pn, *(op->label()));
|
__ fb( acond, false, Assembler::pn, *(op->label()));
|
||||||
} else {
|
} else {
|
||||||
|
@ -725,9 +714,6 @@ void LIR_Assembler::emit_opConvert(LIR_OpConvert* op) {
|
||||||
Label L;
|
Label L;
|
||||||
// result must be 0 if value is NaN; test by comparing value to itself
|
// result must be 0 if value is NaN; test by comparing value to itself
|
||||||
__ fcmp(FloatRegisterImpl::S, Assembler::fcc0, rsrc, rsrc);
|
__ fcmp(FloatRegisterImpl::S, Assembler::fcc0, rsrc, rsrc);
|
||||||
if (!VM_Version::v9_instructions_work()) {
|
|
||||||
__ nop();
|
|
||||||
}
|
|
||||||
__ fb(Assembler::f_unordered, true, Assembler::pn, L);
|
__ fb(Assembler::f_unordered, true, Assembler::pn, L);
|
||||||
__ delayed()->st(G0, addr); // annuled if contents of rsrc is not NaN
|
__ delayed()->st(G0, addr); // annuled if contents of rsrc is not NaN
|
||||||
__ ftoi(FloatRegisterImpl::S, rsrc, rsrc);
|
__ ftoi(FloatRegisterImpl::S, rsrc, rsrc);
|
||||||
|
@ -1909,7 +1895,7 @@ void LIR_Assembler::arith_op(LIR_Code code, LIR_Opr left, LIR_Opr right, LIR_Opr
|
||||||
switch (code) {
|
switch (code) {
|
||||||
case lir_add: __ add (lreg, rreg, res); break;
|
case lir_add: __ add (lreg, rreg, res); break;
|
||||||
case lir_sub: __ sub (lreg, rreg, res); break;
|
case lir_sub: __ sub (lreg, rreg, res); break;
|
||||||
case lir_mul: __ mult (lreg, rreg, res); break;
|
case lir_mul: __ mulx (lreg, rreg, res); break;
|
||||||
default: ShouldNotReachHere();
|
default: ShouldNotReachHere();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1924,7 +1910,7 @@ void LIR_Assembler::arith_op(LIR_Code code, LIR_Opr left, LIR_Opr right, LIR_Opr
|
||||||
switch (code) {
|
switch (code) {
|
||||||
case lir_add: __ add (lreg, simm13, res); break;
|
case lir_add: __ add (lreg, simm13, res); break;
|
||||||
case lir_sub: __ sub (lreg, simm13, res); break;
|
case lir_sub: __ sub (lreg, simm13, res); break;
|
||||||
case lir_mul: __ mult (lreg, simm13, res); break;
|
case lir_mul: __ mulx (lreg, simm13, res); break;
|
||||||
default: ShouldNotReachHere();
|
default: ShouldNotReachHere();
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -1936,7 +1922,7 @@ void LIR_Assembler::arith_op(LIR_Code code, LIR_Opr left, LIR_Opr right, LIR_Opr
|
||||||
switch (code) {
|
switch (code) {
|
||||||
case lir_add: __ add (lreg, (int)con, res); break;
|
case lir_add: __ add (lreg, (int)con, res); break;
|
||||||
case lir_sub: __ sub (lreg, (int)con, res); break;
|
case lir_sub: __ sub (lreg, (int)con, res); break;
|
||||||
case lir_mul: __ mult (lreg, (int)con, res); break;
|
case lir_mul: __ mulx (lreg, (int)con, res); break;
|
||||||
default: ShouldNotReachHere();
|
default: ShouldNotReachHere();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -3234,48 +3220,26 @@ void LIR_Assembler::volatile_move_op(LIR_Opr src, LIR_Opr dest, BasicType type,
|
||||||
Register base = mem_addr->base()->as_register();
|
Register base = mem_addr->base()->as_register();
|
||||||
if (src->is_register() && dest->is_address()) {
|
if (src->is_register() && dest->is_address()) {
|
||||||
// G4 is high half, G5 is low half
|
// G4 is high half, G5 is low half
|
||||||
if (VM_Version::v9_instructions_work()) {
|
// clear the top bits of G5, and scale up G4
|
||||||
// clear the top bits of G5, and scale up G4
|
__ srl (src->as_register_lo(), 0, G5);
|
||||||
__ srl (src->as_register_lo(), 0, G5);
|
__ sllx(src->as_register_hi(), 32, G4);
|
||||||
__ sllx(src->as_register_hi(), 32, G4);
|
// combine the two halves into the 64 bits of G4
|
||||||
// combine the two halves into the 64 bits of G4
|
__ or3(G4, G5, G4);
|
||||||
__ or3(G4, G5, G4);
|
null_check_offset = __ offset();
|
||||||
null_check_offset = __ offset();
|
if (idx == noreg) {
|
||||||
if (idx == noreg) {
|
__ stx(G4, base, disp);
|
||||||
__ stx(G4, base, disp);
|
|
||||||
} else {
|
|
||||||
__ stx(G4, base, idx);
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
__ mov (src->as_register_hi(), G4);
|
__ stx(G4, base, idx);
|
||||||
__ mov (src->as_register_lo(), G5);
|
|
||||||
null_check_offset = __ offset();
|
|
||||||
if (idx == noreg) {
|
|
||||||
__ std(G4, base, disp);
|
|
||||||
} else {
|
|
||||||
__ std(G4, base, idx);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
} else if (src->is_address() && dest->is_register()) {
|
} else if (src->is_address() && dest->is_register()) {
|
||||||
null_check_offset = __ offset();
|
null_check_offset = __ offset();
|
||||||
if (VM_Version::v9_instructions_work()) {
|
if (idx == noreg) {
|
||||||
if (idx == noreg) {
|
__ ldx(base, disp, G5);
|
||||||
__ ldx(base, disp, G5);
|
|
||||||
} else {
|
|
||||||
__ ldx(base, idx, G5);
|
|
||||||
}
|
|
||||||
__ srax(G5, 32, dest->as_register_hi()); // fetch the high half into hi
|
|
||||||
__ mov (G5, dest->as_register_lo()); // copy low half into lo
|
|
||||||
} else {
|
} else {
|
||||||
if (idx == noreg) {
|
__ ldx(base, idx, G5);
|
||||||
__ ldd(base, disp, G4);
|
|
||||||
} else {
|
|
||||||
__ ldd(base, idx, G4);
|
|
||||||
}
|
|
||||||
// G4 is high half, G5 is low half
|
|
||||||
__ mov (G4, dest->as_register_hi());
|
|
||||||
__ mov (G5, dest->as_register_lo());
|
|
||||||
}
|
}
|
||||||
|
__ srax(G5, 32, dest->as_register_hi()); // fetch the high half into hi
|
||||||
|
__ mov (G5, dest->as_register_lo()); // copy low half into lo
|
||||||
} else {
|
} else {
|
||||||
Unimplemented();
|
Unimplemented();
|
||||||
}
|
}
|
||||||
|
|
|
@ -108,7 +108,7 @@ void C1_MacroAssembler::lock_object(Register Rmark, Register Roop, Register Rbox
|
||||||
|
|
||||||
// compare object markOop with Rmark and if equal exchange Rscratch with object markOop
|
// compare object markOop with Rmark and if equal exchange Rscratch with object markOop
|
||||||
assert(mark_addr.disp() == 0, "cas must take a zero displacement");
|
assert(mark_addr.disp() == 0, "cas must take a zero displacement");
|
||||||
casx_under_lock(mark_addr.base(), Rmark, Rscratch, (address)StubRoutines::Sparc::atomic_memory_operation_lock_addr());
|
cas_ptr(mark_addr.base(), Rmark, Rscratch);
|
||||||
// if compare/exchange succeeded we found an unlocked object and we now have locked it
|
// if compare/exchange succeeded we found an unlocked object and we now have locked it
|
||||||
// hence we are done
|
// hence we are done
|
||||||
cmp(Rmark, Rscratch);
|
cmp(Rmark, Rscratch);
|
||||||
|
@ -149,7 +149,7 @@ void C1_MacroAssembler::unlock_object(Register Rmark, Register Roop, Register Rb
|
||||||
|
|
||||||
// Check if it is still a light weight lock, this is is true if we see
|
// Check if it is still a light weight lock, this is is true if we see
|
||||||
// the stack address of the basicLock in the markOop of the object
|
// the stack address of the basicLock in the markOop of the object
|
||||||
casx_under_lock(mark_addr.base(), Rbox, Rmark, (address)StubRoutines::Sparc::atomic_memory_operation_lock_addr());
|
cas_ptr(mark_addr.base(), Rbox, Rmark);
|
||||||
cmp(Rbox, Rmark);
|
cmp(Rbox, Rmark);
|
||||||
|
|
||||||
brx(Assembler::notEqual, false, Assembler::pn, slow_case);
|
brx(Assembler::notEqual, false, Assembler::pn, slow_case);
|
||||||
|
@ -276,7 +276,7 @@ void C1_MacroAssembler::initialize_object(
|
||||||
sub(var_size_in_bytes, hdr_size_in_bytes, t2); // compute size of body
|
sub(var_size_in_bytes, hdr_size_in_bytes, t2); // compute size of body
|
||||||
initialize_body(t1, t2);
|
initialize_body(t1, t2);
|
||||||
#ifndef _LP64
|
#ifndef _LP64
|
||||||
} else if (VM_Version::v9_instructions_work() && con_size_in_bytes < threshold * 2) {
|
} else if (con_size_in_bytes < threshold * 2) {
|
||||||
// on v9 we can do double word stores to fill twice as much space.
|
// on v9 we can do double word stores to fill twice as much space.
|
||||||
assert(hdr_size_in_bytes % 8 == 0, "double word aligned");
|
assert(hdr_size_in_bytes % 8 == 0, "double word aligned");
|
||||||
assert(con_size_in_bytes % 8 == 0, "double word aligned");
|
assert(con_size_in_bytes % 8 == 0, "double word aligned");
|
||||||
|
|
|
@ -30,5 +30,4 @@
|
||||||
|
|
||||||
void Compile::pd_compiler2_init() {
|
void Compile::pd_compiler2_init() {
|
||||||
guarantee(CodeEntryAlignment >= InteriorEntryAlignment, "" );
|
guarantee(CodeEntryAlignment >= InteriorEntryAlignment, "" );
|
||||||
guarantee( VM_Version::v9_instructions_work(), "Server compiler does not run on V8 systems" );
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -30,8 +30,7 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
static const char* pd_cpu_opts() {
|
static const char* pd_cpu_opts() {
|
||||||
return (VM_Version::v9_instructions_work()?
|
return "v9only";
|
||||||
(VM_Version::v8_instructions_work()? "" : "v9only") : "v8only");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif // CPU_SPARC_VM_DISASSEMBLER_SPARC_HPP
|
#endif // CPU_SPARC_VM_DISASSEMBLER_SPARC_HPP
|
||||||
|
|
|
@ -110,8 +110,5 @@ define_pd_global(uintx, CMSYoungGenPerWorker, 16*M); // default max size of CMS
|
||||||
\
|
\
|
||||||
product(uintx, ArraycopyDstPrefetchDistance, 0, \
|
product(uintx, ArraycopyDstPrefetchDistance, 0, \
|
||||||
"Distance to prefetch destination array in arracopy") \
|
"Distance to prefetch destination array in arracopy") \
|
||||||
\
|
|
||||||
develop(intx, V8AtomicOperationUnderLockSpinCount, 50, \
|
|
||||||
"Number of times to spin wait on a v8 atomic operation lock") \
|
|
||||||
|
|
||||||
#endif // CPU_SPARC_VM_GLOBALS_SPARC_HPP
|
#endif // CPU_SPARC_VM_GLOBALS_SPARC_HPP
|
||||||
|
|
|
@ -1210,8 +1210,7 @@ void InterpreterMacroAssembler::lock_object(Register lock_reg, Register Object)
|
||||||
st_ptr(mark_reg, lock_addr, BasicLock::displaced_header_offset_in_bytes());
|
st_ptr(mark_reg, lock_addr, BasicLock::displaced_header_offset_in_bytes());
|
||||||
// compare and exchange object_addr, markOop | 1, stack address of basicLock
|
// compare and exchange object_addr, markOop | 1, stack address of basicLock
|
||||||
assert(mark_addr.disp() == 0, "cas must take a zero displacement");
|
assert(mark_addr.disp() == 0, "cas must take a zero displacement");
|
||||||
casx_under_lock(mark_addr.base(), mark_reg, temp_reg,
|
cas_ptr(mark_addr.base(), mark_reg, temp_reg);
|
||||||
(address)StubRoutines::Sparc::atomic_memory_operation_lock_addr());
|
|
||||||
|
|
||||||
// if the compare and exchange succeeded we are done (we saw an unlocked object)
|
// if the compare and exchange succeeded we are done (we saw an unlocked object)
|
||||||
cmp_and_brx_short(mark_reg, temp_reg, Assembler::equal, Assembler::pt, done);
|
cmp_and_brx_short(mark_reg, temp_reg, Assembler::equal, Assembler::pt, done);
|
||||||
|
@ -1291,8 +1290,7 @@ void InterpreterMacroAssembler::unlock_object(Register lock_reg) {
|
||||||
// we expect to see the stack address of the basicLock in case the
|
// we expect to see the stack address of the basicLock in case the
|
||||||
// lock is still a light weight lock (lock_reg)
|
// lock is still a light weight lock (lock_reg)
|
||||||
assert(mark_addr.disp() == 0, "cas must take a zero displacement");
|
assert(mark_addr.disp() == 0, "cas must take a zero displacement");
|
||||||
casx_under_lock(mark_addr.base(), lock_reg, displaced_header_reg,
|
cas_ptr(mark_addr.base(), lock_reg, displaced_header_reg);
|
||||||
(address)StubRoutines::Sparc::atomic_memory_operation_lock_addr());
|
|
||||||
cmp(lock_reg, displaced_header_reg);
|
cmp(lock_reg, displaced_header_reg);
|
||||||
brx(Assembler::equal, true, Assembler::pn, done);
|
brx(Assembler::equal, true, Assembler::pn, done);
|
||||||
delayed()->st_ptr(G0, lockobj_addr); // free entry
|
delayed()->st_ptr(G0, lockobj_addr); // free entry
|
||||||
|
|
|
@ -118,7 +118,6 @@ int MacroAssembler::patched_branch(int dest_pos, int inst, int inst_pos) {
|
||||||
case bp_op2: m = wdisp( word_aligned_ones, 0, 19); v = wdisp( dest_pos, inst_pos, 19); break;
|
case bp_op2: m = wdisp( word_aligned_ones, 0, 19); v = wdisp( dest_pos, inst_pos, 19); break;
|
||||||
case fb_op2: m = wdisp( word_aligned_ones, 0, 22); v = wdisp( dest_pos, inst_pos, 22); break;
|
case fb_op2: m = wdisp( word_aligned_ones, 0, 22); v = wdisp( dest_pos, inst_pos, 22); break;
|
||||||
case br_op2: m = wdisp( word_aligned_ones, 0, 22); v = wdisp( dest_pos, inst_pos, 22); break;
|
case br_op2: m = wdisp( word_aligned_ones, 0, 22); v = wdisp( dest_pos, inst_pos, 22); break;
|
||||||
case cb_op2: m = wdisp( word_aligned_ones, 0, 22); v = wdisp( dest_pos, inst_pos, 22); break;
|
|
||||||
case bpr_op2: {
|
case bpr_op2: {
|
||||||
if (is_cbcond(inst)) {
|
if (is_cbcond(inst)) {
|
||||||
m = wdisp10(word_aligned_ones, 0);
|
m = wdisp10(word_aligned_ones, 0);
|
||||||
|
@ -149,7 +148,6 @@ int MacroAssembler::branch_destination(int inst, int pos) {
|
||||||
case bp_op2: r = inv_wdisp( inst, pos, 19); break;
|
case bp_op2: r = inv_wdisp( inst, pos, 19); break;
|
||||||
case fb_op2: r = inv_wdisp( inst, pos, 22); break;
|
case fb_op2: r = inv_wdisp( inst, pos, 22); break;
|
||||||
case br_op2: r = inv_wdisp( inst, pos, 22); break;
|
case br_op2: r = inv_wdisp( inst, pos, 22); break;
|
||||||
case cb_op2: r = inv_wdisp( inst, pos, 22); break;
|
|
||||||
case bpr_op2: {
|
case bpr_op2: {
|
||||||
if (is_cbcond(inst)) {
|
if (is_cbcond(inst)) {
|
||||||
r = inv_wdisp10(inst, pos);
|
r = inv_wdisp10(inst, pos);
|
||||||
|
@ -325,12 +323,6 @@ void MacroAssembler::breakpoint_trap() {
|
||||||
trap(ST_RESERVED_FOR_USER_0);
|
trap(ST_RESERVED_FOR_USER_0);
|
||||||
}
|
}
|
||||||
|
|
||||||
// flush windows (except current) using flushw instruction if avail.
|
|
||||||
void MacroAssembler::flush_windows() {
|
|
||||||
if (VM_Version::v9_instructions_work()) flushw();
|
|
||||||
else flush_windows_trap();
|
|
||||||
}
|
|
||||||
|
|
||||||
// Write serialization page so VM thread can do a pseudo remote membar
|
// Write serialization page so VM thread can do a pseudo remote membar
|
||||||
// We use the current thread pointer to calculate a thread specific
|
// We use the current thread pointer to calculate a thread specific
|
||||||
// offset to write to within the page. This minimizes bus traffic
|
// offset to write to within the page. This minimizes bus traffic
|
||||||
|
@ -358,88 +350,6 @@ void MacroAssembler::leave() {
|
||||||
Unimplemented();
|
Unimplemented();
|
||||||
}
|
}
|
||||||
|
|
||||||
void MacroAssembler::mult(Register s1, Register s2, Register d) {
|
|
||||||
if(VM_Version::v9_instructions_work()) {
|
|
||||||
mulx (s1, s2, d);
|
|
||||||
} else {
|
|
||||||
smul (s1, s2, d);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void MacroAssembler::mult(Register s1, int simm13a, Register d) {
|
|
||||||
if(VM_Version::v9_instructions_work()) {
|
|
||||||
mulx (s1, simm13a, d);
|
|
||||||
} else {
|
|
||||||
smul (s1, simm13a, d);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef ASSERT
|
|
||||||
void MacroAssembler::read_ccr_v8_assert(Register ccr_save) {
|
|
||||||
const Register s1 = G3_scratch;
|
|
||||||
const Register s2 = G4_scratch;
|
|
||||||
Label get_psr_test;
|
|
||||||
// Get the condition codes the V8 way.
|
|
||||||
read_ccr_trap(s1);
|
|
||||||
mov(ccr_save, s2);
|
|
||||||
// This is a test of V8 which has icc but not xcc
|
|
||||||
// so mask off the xcc bits
|
|
||||||
and3(s2, 0xf, s2);
|
|
||||||
// Compare condition codes from the V8 and V9 ways.
|
|
||||||
subcc(s2, s1, G0);
|
|
||||||
br(Assembler::notEqual, true, Assembler::pt, get_psr_test);
|
|
||||||
delayed()->breakpoint_trap();
|
|
||||||
bind(get_psr_test);
|
|
||||||
}
|
|
||||||
|
|
||||||
void MacroAssembler::write_ccr_v8_assert(Register ccr_save) {
|
|
||||||
const Register s1 = G3_scratch;
|
|
||||||
const Register s2 = G4_scratch;
|
|
||||||
Label set_psr_test;
|
|
||||||
// Write out the saved condition codes the V8 way
|
|
||||||
write_ccr_trap(ccr_save, s1, s2);
|
|
||||||
// Read back the condition codes using the V9 instruction
|
|
||||||
rdccr(s1);
|
|
||||||
mov(ccr_save, s2);
|
|
||||||
// This is a test of V8 which has icc but not xcc
|
|
||||||
// so mask off the xcc bits
|
|
||||||
and3(s2, 0xf, s2);
|
|
||||||
and3(s1, 0xf, s1);
|
|
||||||
// Compare the V8 way with the V9 way.
|
|
||||||
subcc(s2, s1, G0);
|
|
||||||
br(Assembler::notEqual, true, Assembler::pt, set_psr_test);
|
|
||||||
delayed()->breakpoint_trap();
|
|
||||||
bind(set_psr_test);
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
#define read_ccr_v8_assert(x)
|
|
||||||
#define write_ccr_v8_assert(x)
|
|
||||||
#endif // ASSERT
|
|
||||||
|
|
||||||
void MacroAssembler::read_ccr(Register ccr_save) {
|
|
||||||
if (VM_Version::v9_instructions_work()) {
|
|
||||||
rdccr(ccr_save);
|
|
||||||
// Test code sequence used on V8. Do not move above rdccr.
|
|
||||||
read_ccr_v8_assert(ccr_save);
|
|
||||||
} else {
|
|
||||||
read_ccr_trap(ccr_save);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void MacroAssembler::write_ccr(Register ccr_save) {
|
|
||||||
if (VM_Version::v9_instructions_work()) {
|
|
||||||
// Test code sequence used on V8. Do not move below wrccr.
|
|
||||||
write_ccr_v8_assert(ccr_save);
|
|
||||||
wrccr(ccr_save);
|
|
||||||
} else {
|
|
||||||
const Register temp_reg1 = G3_scratch;
|
|
||||||
const Register temp_reg2 = G4_scratch;
|
|
||||||
write_ccr_trap(ccr_save, temp_reg1, temp_reg2);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// Calls to C land
|
// Calls to C land
|
||||||
|
|
||||||
#ifdef ASSERT
|
#ifdef ASSERT
|
||||||
|
@ -465,8 +375,8 @@ void MacroAssembler::get_thread() {
|
||||||
#ifdef ASSERT
|
#ifdef ASSERT
|
||||||
AddressLiteral last_get_thread_addrlit(&last_get_thread);
|
AddressLiteral last_get_thread_addrlit(&last_get_thread);
|
||||||
set(last_get_thread_addrlit, L3);
|
set(last_get_thread_addrlit, L3);
|
||||||
inc(L4, get_pc(L4) + 2 * BytesPerInstWord); // skip getpc() code + inc + st_ptr to point L4 at call
|
rdpc(L4);
|
||||||
st_ptr(L4, L3, 0);
|
inc(L4, 3 * BytesPerInstWord); // skip rdpc + inc + st_ptr to point L4 at call st_ptr(L4, L3, 0);
|
||||||
#endif
|
#endif
|
||||||
call(CAST_FROM_FN_PTR(address, reinitialize_thread), relocInfo::runtime_call_type);
|
call(CAST_FROM_FN_PTR(address, reinitialize_thread), relocInfo::runtime_call_type);
|
||||||
delayed()->nop();
|
delayed()->nop();
|
||||||
|
@ -1327,7 +1237,7 @@ void RegistersForDebugging::print(outputStream* s) {
|
||||||
|
|
||||||
void RegistersForDebugging::save_registers(MacroAssembler* a) {
|
void RegistersForDebugging::save_registers(MacroAssembler* a) {
|
||||||
a->sub(FP, round_to(sizeof(RegistersForDebugging), sizeof(jdouble)) - STACK_BIAS, O0);
|
a->sub(FP, round_to(sizeof(RegistersForDebugging), sizeof(jdouble)) - STACK_BIAS, O0);
|
||||||
a->flush_windows();
|
a->flushw();
|
||||||
int i;
|
int i;
|
||||||
for (i = 0; i < 8; ++i) {
|
for (i = 0; i < 8; ++i) {
|
||||||
a->ld_ptr(as_iRegister(i)->address_in_saved_window().after_save(), L1); a->st_ptr( L1, O0, i_offset(i));
|
a->ld_ptr(as_iRegister(i)->address_in_saved_window().after_save(), L1); a->st_ptr( L1, O0, i_offset(i));
|
||||||
|
@ -1338,7 +1248,7 @@ void RegistersForDebugging::save_registers(MacroAssembler* a) {
|
||||||
for (i = 0; i < 32; ++i) {
|
for (i = 0; i < 32; ++i) {
|
||||||
a->stf(FloatRegisterImpl::S, as_FloatRegister(i), O0, f_offset(i));
|
a->stf(FloatRegisterImpl::S, as_FloatRegister(i), O0, f_offset(i));
|
||||||
}
|
}
|
||||||
for (i = 0; i < (VM_Version::v9_instructions_work() ? 64 : 32); i += 2) {
|
for (i = 0; i < 64; i += 2) {
|
||||||
a->stf(FloatRegisterImpl::D, as_FloatRegister(i), O0, d_offset(i));
|
a->stf(FloatRegisterImpl::D, as_FloatRegister(i), O0, d_offset(i));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1350,7 +1260,7 @@ void RegistersForDebugging::restore_registers(MacroAssembler* a, Register r) {
|
||||||
for (int j = 0; j < 32; ++j) {
|
for (int j = 0; j < 32; ++j) {
|
||||||
a->ldf(FloatRegisterImpl::S, O0, f_offset(j), as_FloatRegister(j));
|
a->ldf(FloatRegisterImpl::S, O0, f_offset(j), as_FloatRegister(j));
|
||||||
}
|
}
|
||||||
for (int k = 0; k < (VM_Version::v9_instructions_work() ? 64 : 32); k += 2) {
|
for (int k = 0; k < 64; k += 2) {
|
||||||
a->ldf(FloatRegisterImpl::D, O0, d_offset(k), as_FloatRegister(k));
|
a->ldf(FloatRegisterImpl::D, O0, d_offset(k), as_FloatRegister(k));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1465,8 +1375,6 @@ address MacroAssembler::_verify_oop_implicit_branch[3] = { NULL };
|
||||||
// the high bits of the O-regs if they contain Long values. Acts as a 'leaf'
|
// the high bits of the O-regs if they contain Long values. Acts as a 'leaf'
|
||||||
// call.
|
// call.
|
||||||
void MacroAssembler::verify_oop_subroutine() {
|
void MacroAssembler::verify_oop_subroutine() {
|
||||||
assert( VM_Version::v9_instructions_work(), "VerifyOops not supported for V8" );
|
|
||||||
|
|
||||||
// Leaf call; no frame.
|
// Leaf call; no frame.
|
||||||
Label succeed, fail, null_or_fail;
|
Label succeed, fail, null_or_fail;
|
||||||
|
|
||||||
|
@ -1870,26 +1778,17 @@ void MacroAssembler::lcmp( Register Ra_hi, Register Ra_low,
|
||||||
// And the equals case for the high part does not need testing,
|
// And the equals case for the high part does not need testing,
|
||||||
// since that triplet is reached only after finding the high halves differ.
|
// since that triplet is reached only after finding the high halves differ.
|
||||||
|
|
||||||
if (VM_Version::v9_instructions_work()) {
|
mov(-1, Rresult);
|
||||||
mov(-1, Rresult);
|
ba(done);
|
||||||
ba(done); delayed()-> movcc(greater, false, icc, 1, Rresult);
|
delayed()->movcc(greater, false, icc, 1, Rresult);
|
||||||
} else {
|
|
||||||
br(less, true, pt, done); delayed()-> set(-1, Rresult);
|
|
||||||
br(greater, true, pt, done); delayed()-> set( 1, Rresult);
|
|
||||||
}
|
|
||||||
|
|
||||||
bind( check_low_parts );
|
bind(check_low_parts);
|
||||||
|
|
||||||
if (VM_Version::v9_instructions_work()) {
|
mov( -1, Rresult);
|
||||||
mov( -1, Rresult);
|
movcc(equal, false, icc, 0, Rresult);
|
||||||
movcc(equal, false, icc, 0, Rresult);
|
movcc(greaterUnsigned, false, icc, 1, Rresult);
|
||||||
movcc(greaterUnsigned, false, icc, 1, Rresult);
|
|
||||||
} else {
|
bind(done);
|
||||||
set(-1, Rresult);
|
|
||||||
br(equal, true, pt, done); delayed()->set( 0, Rresult);
|
|
||||||
br(greaterUnsigned, true, pt, done); delayed()->set( 1, Rresult);
|
|
||||||
}
|
|
||||||
bind( done );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void MacroAssembler::lneg( Register Rhi, Register Rlow ) {
|
void MacroAssembler::lneg( Register Rhi, Register Rlow ) {
|
||||||
|
@ -2117,119 +2016,24 @@ void MacroAssembler::store_sized_value(Register src, Address dst, size_t size_in
|
||||||
void MacroAssembler::float_cmp( bool is_float, int unordered_result,
|
void MacroAssembler::float_cmp( bool is_float, int unordered_result,
|
||||||
FloatRegister Fa, FloatRegister Fb,
|
FloatRegister Fa, FloatRegister Fb,
|
||||||
Register Rresult) {
|
Register Rresult) {
|
||||||
|
if (is_float) {
|
||||||
fcmp(is_float ? FloatRegisterImpl::S : FloatRegisterImpl::D, fcc0, Fa, Fb);
|
fcmp(FloatRegisterImpl::S, fcc0, Fa, Fb);
|
||||||
|
|
||||||
Condition lt = unordered_result == -1 ? f_unorderedOrLess : f_less;
|
|
||||||
Condition eq = f_equal;
|
|
||||||
Condition gt = unordered_result == 1 ? f_unorderedOrGreater : f_greater;
|
|
||||||
|
|
||||||
if (VM_Version::v9_instructions_work()) {
|
|
||||||
|
|
||||||
mov(-1, Rresult);
|
|
||||||
movcc(eq, true, fcc0, 0, Rresult);
|
|
||||||
movcc(gt, true, fcc0, 1, Rresult);
|
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
Label done;
|
fcmp(FloatRegisterImpl::D, fcc0, Fa, Fb);
|
||||||
|
}
|
||||||
|
|
||||||
set( -1, Rresult );
|
if (unordered_result == 1) {
|
||||||
//fb(lt, true, pn, done); delayed()->set( -1, Rresult );
|
mov( -1, Rresult);
|
||||||
fb( eq, true, pn, done); delayed()->set( 0, Rresult );
|
movcc(f_equal, true, fcc0, 0, Rresult);
|
||||||
fb( gt, true, pn, done); delayed()->set( 1, Rresult );
|
movcc(f_unorderedOrGreater, true, fcc0, 1, Rresult);
|
||||||
|
} else {
|
||||||
bind (done);
|
mov( -1, Rresult);
|
||||||
|
movcc(f_equal, true, fcc0, 0, Rresult);
|
||||||
|
movcc(f_greater, true, fcc0, 1, Rresult);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void MacroAssembler::fneg( FloatRegisterImpl::Width w, FloatRegister s, FloatRegister d)
|
|
||||||
{
|
|
||||||
if (VM_Version::v9_instructions_work()) {
|
|
||||||
Assembler::fneg(w, s, d);
|
|
||||||
} else {
|
|
||||||
if (w == FloatRegisterImpl::S) {
|
|
||||||
Assembler::fneg(w, s, d);
|
|
||||||
} else if (w == FloatRegisterImpl::D) {
|
|
||||||
// number() does a sanity check on the alignment.
|
|
||||||
assert(((s->encoding(FloatRegisterImpl::D) & 1) == 0) &&
|
|
||||||
((d->encoding(FloatRegisterImpl::D) & 1) == 0), "float register alignment check");
|
|
||||||
|
|
||||||
Assembler::fneg(FloatRegisterImpl::S, s, d);
|
|
||||||
Assembler::fmov(FloatRegisterImpl::S, s->successor(), d->successor());
|
|
||||||
} else {
|
|
||||||
assert(w == FloatRegisterImpl::Q, "Invalid float register width");
|
|
||||||
|
|
||||||
// number() does a sanity check on the alignment.
|
|
||||||
assert(((s->encoding(FloatRegisterImpl::D) & 3) == 0) &&
|
|
||||||
((d->encoding(FloatRegisterImpl::D) & 3) == 0), "float register alignment check");
|
|
||||||
|
|
||||||
Assembler::fneg(FloatRegisterImpl::S, s, d);
|
|
||||||
Assembler::fmov(FloatRegisterImpl::S, s->successor(), d->successor());
|
|
||||||
Assembler::fmov(FloatRegisterImpl::S, s->successor()->successor(), d->successor()->successor());
|
|
||||||
Assembler::fmov(FloatRegisterImpl::S, s->successor()->successor()->successor(), d->successor()->successor()->successor());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void MacroAssembler::fmov( FloatRegisterImpl::Width w, FloatRegister s, FloatRegister d)
|
|
||||||
{
|
|
||||||
if (VM_Version::v9_instructions_work()) {
|
|
||||||
Assembler::fmov(w, s, d);
|
|
||||||
} else {
|
|
||||||
if (w == FloatRegisterImpl::S) {
|
|
||||||
Assembler::fmov(w, s, d);
|
|
||||||
} else if (w == FloatRegisterImpl::D) {
|
|
||||||
// number() does a sanity check on the alignment.
|
|
||||||
assert(((s->encoding(FloatRegisterImpl::D) & 1) == 0) &&
|
|
||||||
((d->encoding(FloatRegisterImpl::D) & 1) == 0), "float register alignment check");
|
|
||||||
|
|
||||||
Assembler::fmov(FloatRegisterImpl::S, s, d);
|
|
||||||
Assembler::fmov(FloatRegisterImpl::S, s->successor(), d->successor());
|
|
||||||
} else {
|
|
||||||
assert(w == FloatRegisterImpl::Q, "Invalid float register width");
|
|
||||||
|
|
||||||
// number() does a sanity check on the alignment.
|
|
||||||
assert(((s->encoding(FloatRegisterImpl::D) & 3) == 0) &&
|
|
||||||
((d->encoding(FloatRegisterImpl::D) & 3) == 0), "float register alignment check");
|
|
||||||
|
|
||||||
Assembler::fmov(FloatRegisterImpl::S, s, d);
|
|
||||||
Assembler::fmov(FloatRegisterImpl::S, s->successor(), d->successor());
|
|
||||||
Assembler::fmov(FloatRegisterImpl::S, s->successor()->successor(), d->successor()->successor());
|
|
||||||
Assembler::fmov(FloatRegisterImpl::S, s->successor()->successor()->successor(), d->successor()->successor()->successor());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void MacroAssembler::fabs( FloatRegisterImpl::Width w, FloatRegister s, FloatRegister d)
|
|
||||||
{
|
|
||||||
if (VM_Version::v9_instructions_work()) {
|
|
||||||
Assembler::fabs(w, s, d);
|
|
||||||
} else {
|
|
||||||
if (w == FloatRegisterImpl::S) {
|
|
||||||
Assembler::fabs(w, s, d);
|
|
||||||
} else if (w == FloatRegisterImpl::D) {
|
|
||||||
// number() does a sanity check on the alignment.
|
|
||||||
assert(((s->encoding(FloatRegisterImpl::D) & 1) == 0) &&
|
|
||||||
((d->encoding(FloatRegisterImpl::D) & 1) == 0), "float register alignment check");
|
|
||||||
|
|
||||||
Assembler::fabs(FloatRegisterImpl::S, s, d);
|
|
||||||
Assembler::fmov(FloatRegisterImpl::S, s->successor(), d->successor());
|
|
||||||
} else {
|
|
||||||
assert(w == FloatRegisterImpl::Q, "Invalid float register width");
|
|
||||||
|
|
||||||
// number() does a sanity check on the alignment.
|
|
||||||
assert(((s->encoding(FloatRegisterImpl::D) & 3) == 0) &&
|
|
||||||
((d->encoding(FloatRegisterImpl::D) & 3) == 0), "float register alignment check");
|
|
||||||
|
|
||||||
Assembler::fabs(FloatRegisterImpl::S, s, d);
|
|
||||||
Assembler::fmov(FloatRegisterImpl::S, s->successor(), d->successor());
|
|
||||||
Assembler::fmov(FloatRegisterImpl::S, s->successor()->successor(), d->successor()->successor());
|
|
||||||
Assembler::fmov(FloatRegisterImpl::S, s->successor()->successor()->successor(), d->successor()->successor()->successor());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void MacroAssembler::save_all_globals_into_locals() {
|
void MacroAssembler::save_all_globals_into_locals() {
|
||||||
mov(G1,L1);
|
mov(G1,L1);
|
||||||
mov(G2,L2);
|
mov(G2,L2);
|
||||||
|
@ -2250,135 +2054,6 @@ void MacroAssembler::restore_globals_from_locals() {
|
||||||
mov(L7,G7);
|
mov(L7,G7);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Use for 64 bit operation.
|
|
||||||
void MacroAssembler::casx_under_lock(Register top_ptr_reg, Register top_reg, Register ptr_reg, address lock_addr, bool use_call_vm)
|
|
||||||
{
|
|
||||||
// store ptr_reg as the new top value
|
|
||||||
#ifdef _LP64
|
|
||||||
casx(top_ptr_reg, top_reg, ptr_reg);
|
|
||||||
#else
|
|
||||||
cas_under_lock(top_ptr_reg, top_reg, ptr_reg, lock_addr, use_call_vm);
|
|
||||||
#endif // _LP64
|
|
||||||
}
|
|
||||||
|
|
||||||
// [RGV] This routine does not handle 64 bit operations.
|
|
||||||
// use casx_under_lock() or casx directly!!!
|
|
||||||
void MacroAssembler::cas_under_lock(Register top_ptr_reg, Register top_reg, Register ptr_reg, address lock_addr, bool use_call_vm)
|
|
||||||
{
|
|
||||||
// store ptr_reg as the new top value
|
|
||||||
if (VM_Version::v9_instructions_work()) {
|
|
||||||
cas(top_ptr_reg, top_reg, ptr_reg);
|
|
||||||
} else {
|
|
||||||
|
|
||||||
// If the register is not an out nor global, it is not visible
|
|
||||||
// after the save. Allocate a register for it, save its
|
|
||||||
// value in the register save area (the save may not flush
|
|
||||||
// registers to the save area).
|
|
||||||
|
|
||||||
Register top_ptr_reg_after_save;
|
|
||||||
Register top_reg_after_save;
|
|
||||||
Register ptr_reg_after_save;
|
|
||||||
|
|
||||||
if (top_ptr_reg->is_out() || top_ptr_reg->is_global()) {
|
|
||||||
top_ptr_reg_after_save = top_ptr_reg->after_save();
|
|
||||||
} else {
|
|
||||||
Address reg_save_addr = top_ptr_reg->address_in_saved_window();
|
|
||||||
top_ptr_reg_after_save = L0;
|
|
||||||
st(top_ptr_reg, reg_save_addr);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (top_reg->is_out() || top_reg->is_global()) {
|
|
||||||
top_reg_after_save = top_reg->after_save();
|
|
||||||
} else {
|
|
||||||
Address reg_save_addr = top_reg->address_in_saved_window();
|
|
||||||
top_reg_after_save = L1;
|
|
||||||
st(top_reg, reg_save_addr);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (ptr_reg->is_out() || ptr_reg->is_global()) {
|
|
||||||
ptr_reg_after_save = ptr_reg->after_save();
|
|
||||||
} else {
|
|
||||||
Address reg_save_addr = ptr_reg->address_in_saved_window();
|
|
||||||
ptr_reg_after_save = L2;
|
|
||||||
st(ptr_reg, reg_save_addr);
|
|
||||||
}
|
|
||||||
|
|
||||||
const Register& lock_reg = L3;
|
|
||||||
const Register& lock_ptr_reg = L4;
|
|
||||||
const Register& value_reg = L5;
|
|
||||||
const Register& yield_reg = L6;
|
|
||||||
const Register& yieldall_reg = L7;
|
|
||||||
|
|
||||||
save_frame();
|
|
||||||
|
|
||||||
if (top_ptr_reg_after_save == L0) {
|
|
||||||
ld(top_ptr_reg->address_in_saved_window().after_save(), top_ptr_reg_after_save);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (top_reg_after_save == L1) {
|
|
||||||
ld(top_reg->address_in_saved_window().after_save(), top_reg_after_save);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (ptr_reg_after_save == L2) {
|
|
||||||
ld(ptr_reg->address_in_saved_window().after_save(), ptr_reg_after_save);
|
|
||||||
}
|
|
||||||
|
|
||||||
Label(retry_get_lock);
|
|
||||||
Label(not_same);
|
|
||||||
Label(dont_yield);
|
|
||||||
|
|
||||||
assert(lock_addr, "lock_address should be non null for v8");
|
|
||||||
set((intptr_t)lock_addr, lock_ptr_reg);
|
|
||||||
// Initialize yield counter
|
|
||||||
mov(G0,yield_reg);
|
|
||||||
mov(G0, yieldall_reg);
|
|
||||||
set(StubRoutines::Sparc::locked, lock_reg);
|
|
||||||
|
|
||||||
bind(retry_get_lock);
|
|
||||||
cmp_and_br_short(yield_reg, V8AtomicOperationUnderLockSpinCount, Assembler::less, Assembler::pt, dont_yield);
|
|
||||||
|
|
||||||
if(use_call_vm) {
|
|
||||||
Untested("Need to verify global reg consistancy");
|
|
||||||
call_VM(noreg, CAST_FROM_FN_PTR(address, SharedRuntime::yield_all), yieldall_reg);
|
|
||||||
} else {
|
|
||||||
// Save the regs and make space for a C call
|
|
||||||
save(SP, -96, SP);
|
|
||||||
save_all_globals_into_locals();
|
|
||||||
call(CAST_FROM_FN_PTR(address,os::yield_all));
|
|
||||||
delayed()->mov(yieldall_reg, O0);
|
|
||||||
restore_globals_from_locals();
|
|
||||||
restore();
|
|
||||||
}
|
|
||||||
|
|
||||||
// reset the counter
|
|
||||||
mov(G0,yield_reg);
|
|
||||||
add(yieldall_reg, 1, yieldall_reg);
|
|
||||||
|
|
||||||
bind(dont_yield);
|
|
||||||
// try to get lock
|
|
||||||
Assembler::swap(lock_ptr_reg, 0, lock_reg);
|
|
||||||
|
|
||||||
// did we get the lock?
|
|
||||||
cmp(lock_reg, StubRoutines::Sparc::unlocked);
|
|
||||||
br(Assembler::notEqual, true, Assembler::pn, retry_get_lock);
|
|
||||||
delayed()->add(yield_reg,1,yield_reg);
|
|
||||||
|
|
||||||
// yes, got lock. do we have the same top?
|
|
||||||
ld(top_ptr_reg_after_save, 0, value_reg);
|
|
||||||
cmp_and_br_short(value_reg, top_reg_after_save, Assembler::notEqual, Assembler::pn, not_same);
|
|
||||||
|
|
||||||
// yes, same top.
|
|
||||||
st(ptr_reg_after_save, top_ptr_reg_after_save, 0);
|
|
||||||
membar(Assembler::StoreStore);
|
|
||||||
|
|
||||||
bind(not_same);
|
|
||||||
mov(value_reg, ptr_reg_after_save);
|
|
||||||
st(lock_reg, lock_ptr_reg, 0); // unlock
|
|
||||||
|
|
||||||
restore();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
RegisterOrConstant MacroAssembler::delayed_value_impl(intptr_t* delayed_value_addr,
|
RegisterOrConstant MacroAssembler::delayed_value_impl(intptr_t* delayed_value_addr,
|
||||||
Register tmp,
|
Register tmp,
|
||||||
int offset) {
|
int offset) {
|
||||||
|
@ -2970,7 +2645,7 @@ void MacroAssembler::biased_locking_enter(Register obj_reg, Register mark_reg,
|
||||||
markOopDesc::biased_lock_mask_in_place | markOopDesc::age_mask_in_place | markOopDesc::epoch_mask_in_place,
|
markOopDesc::biased_lock_mask_in_place | markOopDesc::age_mask_in_place | markOopDesc::epoch_mask_in_place,
|
||||||
mark_reg);
|
mark_reg);
|
||||||
or3(G2_thread, mark_reg, temp_reg);
|
or3(G2_thread, mark_reg, temp_reg);
|
||||||
casn(mark_addr.base(), mark_reg, temp_reg);
|
cas_ptr(mark_addr.base(), mark_reg, temp_reg);
|
||||||
// If the biasing toward our thread failed, this means that
|
// If the biasing toward our thread failed, this means that
|
||||||
// another thread succeeded in biasing it toward itself and we
|
// another thread succeeded in biasing it toward itself and we
|
||||||
// need to revoke that bias. The revocation will occur in the
|
// need to revoke that bias. The revocation will occur in the
|
||||||
|
@ -2998,7 +2673,7 @@ void MacroAssembler::biased_locking_enter(Register obj_reg, Register mark_reg,
|
||||||
load_klass(obj_reg, temp_reg);
|
load_klass(obj_reg, temp_reg);
|
||||||
ld_ptr(Address(temp_reg, Klass::prototype_header_offset()), temp_reg);
|
ld_ptr(Address(temp_reg, Klass::prototype_header_offset()), temp_reg);
|
||||||
or3(G2_thread, temp_reg, temp_reg);
|
or3(G2_thread, temp_reg, temp_reg);
|
||||||
casn(mark_addr.base(), mark_reg, temp_reg);
|
cas_ptr(mark_addr.base(), mark_reg, temp_reg);
|
||||||
// If the biasing toward our thread failed, this means that
|
// If the biasing toward our thread failed, this means that
|
||||||
// another thread succeeded in biasing it toward itself and we
|
// another thread succeeded in biasing it toward itself and we
|
||||||
// need to revoke that bias. The revocation will occur in the
|
// need to revoke that bias. The revocation will occur in the
|
||||||
|
@ -3027,7 +2702,7 @@ void MacroAssembler::biased_locking_enter(Register obj_reg, Register mark_reg,
|
||||||
// bits in this situation. Should attempt to preserve them.
|
// bits in this situation. Should attempt to preserve them.
|
||||||
load_klass(obj_reg, temp_reg);
|
load_klass(obj_reg, temp_reg);
|
||||||
ld_ptr(Address(temp_reg, Klass::prototype_header_offset()), temp_reg);
|
ld_ptr(Address(temp_reg, Klass::prototype_header_offset()), temp_reg);
|
||||||
casn(mark_addr.base(), mark_reg, temp_reg);
|
cas_ptr(mark_addr.base(), mark_reg, temp_reg);
|
||||||
// Fall through to the normal CAS-based lock, because no matter what
|
// Fall through to the normal CAS-based lock, because no matter what
|
||||||
// the result of the above CAS, some thread must have succeeded in
|
// the result of the above CAS, some thread must have succeeded in
|
||||||
// removing the bias bit from the object's header.
|
// removing the bias bit from the object's header.
|
||||||
|
@ -3058,15 +2733,6 @@ void MacroAssembler::biased_locking_exit (Address mark_addr, Register temp_reg,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// CASN -- 32-64 bit switch hitter similar to the synthetic CASN provided by
|
|
||||||
// Solaris/SPARC's "as". Another apt name would be cas_ptr()
|
|
||||||
|
|
||||||
void MacroAssembler::casn (Register addr_reg, Register cmp_reg, Register set_reg ) {
|
|
||||||
casx_under_lock (addr_reg, cmp_reg, set_reg, (address)StubRoutines::Sparc::atomic_memory_operation_lock_addr());
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// compiler_lock_object() and compiler_unlock_object() are direct transliterations
|
// compiler_lock_object() and compiler_unlock_object() are direct transliterations
|
||||||
// of i486.ad fast_lock() and fast_unlock(). See those methods for detailed comments.
|
// of i486.ad fast_lock() and fast_unlock(). See those methods for detailed comments.
|
||||||
// The code could be tightened up considerably.
|
// The code could be tightened up considerably.
|
||||||
|
@ -3129,8 +2795,7 @@ void MacroAssembler::compiler_lock_object(Register Roop, Register Rmark,
|
||||||
|
|
||||||
// compare object markOop with Rmark and if equal exchange Rscratch with object markOop
|
// compare object markOop with Rmark and if equal exchange Rscratch with object markOop
|
||||||
assert(mark_addr.disp() == 0, "cas must take a zero displacement");
|
assert(mark_addr.disp() == 0, "cas must take a zero displacement");
|
||||||
casx_under_lock(mark_addr.base(), Rmark, Rscratch,
|
cas_ptr(mark_addr.base(), Rmark, Rscratch);
|
||||||
(address)StubRoutines::Sparc::atomic_memory_operation_lock_addr());
|
|
||||||
|
|
||||||
// if compare/exchange succeeded we found an unlocked object and we now have locked it
|
// if compare/exchange succeeded we found an unlocked object and we now have locked it
|
||||||
// hence we are done
|
// hence we are done
|
||||||
|
@ -3176,7 +2841,7 @@ void MacroAssembler::compiler_lock_object(Register Roop, Register Rmark,
|
||||||
mov(Rbox, Rscratch);
|
mov(Rbox, Rscratch);
|
||||||
or3(Rmark, markOopDesc::unlocked_value, Rmark);
|
or3(Rmark, markOopDesc::unlocked_value, Rmark);
|
||||||
assert(mark_addr.disp() == 0, "cas must take a zero displacement");
|
assert(mark_addr.disp() == 0, "cas must take a zero displacement");
|
||||||
casn(mark_addr.base(), Rmark, Rscratch);
|
cas_ptr(mark_addr.base(), Rmark, Rscratch);
|
||||||
cmp(Rmark, Rscratch);
|
cmp(Rmark, Rscratch);
|
||||||
brx(Assembler::equal, false, Assembler::pt, done);
|
brx(Assembler::equal, false, Assembler::pt, done);
|
||||||
delayed()->sub(Rscratch, SP, Rscratch);
|
delayed()->sub(Rscratch, SP, Rscratch);
|
||||||
|
@ -3207,7 +2872,7 @@ void MacroAssembler::compiler_lock_object(Register Roop, Register Rmark,
|
||||||
// Invariant: if we acquire the lock then _recursions should be 0.
|
// Invariant: if we acquire the lock then _recursions should be 0.
|
||||||
add(Rmark, ObjectMonitor::owner_offset_in_bytes()-2, Rmark);
|
add(Rmark, ObjectMonitor::owner_offset_in_bytes()-2, Rmark);
|
||||||
mov(G2_thread, Rscratch);
|
mov(G2_thread, Rscratch);
|
||||||
casn(Rmark, G0, Rscratch);
|
cas_ptr(Rmark, G0, Rscratch);
|
||||||
cmp(Rscratch, G0);
|
cmp(Rscratch, G0);
|
||||||
// Intentional fall-through into done
|
// Intentional fall-through into done
|
||||||
} else {
|
} else {
|
||||||
|
@ -3240,7 +2905,7 @@ void MacroAssembler::compiler_lock_object(Register Roop, Register Rmark,
|
||||||
mov(0, Rscratch);
|
mov(0, Rscratch);
|
||||||
or3(Rmark, markOopDesc::unlocked_value, Rmark);
|
or3(Rmark, markOopDesc::unlocked_value, Rmark);
|
||||||
assert(mark_addr.disp() == 0, "cas must take a zero displacement");
|
assert(mark_addr.disp() == 0, "cas must take a zero displacement");
|
||||||
casn(mark_addr.base(), Rmark, Rscratch);
|
cas_ptr(mark_addr.base(), Rmark, Rscratch);
|
||||||
// prefetch (mark_addr, Assembler::severalWritesAndPossiblyReads);
|
// prefetch (mark_addr, Assembler::severalWritesAndPossiblyReads);
|
||||||
cmp(Rscratch, Rmark);
|
cmp(Rscratch, Rmark);
|
||||||
brx(Assembler::notZero, false, Assembler::pn, Recursive);
|
brx(Assembler::notZero, false, Assembler::pn, Recursive);
|
||||||
|
@ -3266,7 +2931,7 @@ void MacroAssembler::compiler_lock_object(Register Roop, Register Rmark,
|
||||||
// the fast-path stack-lock code from the interpreter and always passed
|
// the fast-path stack-lock code from the interpreter and always passed
|
||||||
// control to the "slow" operators in synchronizer.cpp.
|
// control to the "slow" operators in synchronizer.cpp.
|
||||||
|
|
||||||
// RScratch contains the fetched obj->mark value from the failed CASN.
|
// RScratch contains the fetched obj->mark value from the failed CAS.
|
||||||
#ifdef _LP64
|
#ifdef _LP64
|
||||||
sub(Rscratch, STACK_BIAS, Rscratch);
|
sub(Rscratch, STACK_BIAS, Rscratch);
|
||||||
#endif
|
#endif
|
||||||
|
@ -3300,7 +2965,7 @@ void MacroAssembler::compiler_lock_object(Register Roop, Register Rmark,
|
||||||
// Invariant: if we acquire the lock then _recursions should be 0.
|
// Invariant: if we acquire the lock then _recursions should be 0.
|
||||||
add(Rmark, ObjectMonitor::owner_offset_in_bytes()-2, Rmark);
|
add(Rmark, ObjectMonitor::owner_offset_in_bytes()-2, Rmark);
|
||||||
mov(G2_thread, Rscratch);
|
mov(G2_thread, Rscratch);
|
||||||
casn(Rmark, G0, Rscratch);
|
cas_ptr(Rmark, G0, Rscratch);
|
||||||
cmp(Rscratch, G0);
|
cmp(Rscratch, G0);
|
||||||
// ST box->displaced_header = NonZero.
|
// ST box->displaced_header = NonZero.
|
||||||
// Any non-zero value suffices:
|
// Any non-zero value suffices:
|
||||||
|
@ -3336,8 +3001,7 @@ void MacroAssembler::compiler_unlock_object(Register Roop, Register Rmark,
|
||||||
// Check if it is still a light weight lock, this is is true if we see
|
// Check if it is still a light weight lock, this is is true if we see
|
||||||
// the stack address of the basicLock in the markOop of the object
|
// the stack address of the basicLock in the markOop of the object
|
||||||
assert(mark_addr.disp() == 0, "cas must take a zero displacement");
|
assert(mark_addr.disp() == 0, "cas must take a zero displacement");
|
||||||
casx_under_lock(mark_addr.base(), Rbox, Rmark,
|
cas_ptr(mark_addr.base(), Rbox, Rmark);
|
||||||
(address)StubRoutines::Sparc::atomic_memory_operation_lock_addr());
|
|
||||||
ba(done);
|
ba(done);
|
||||||
delayed()->cmp(Rbox, Rmark);
|
delayed()->cmp(Rbox, Rmark);
|
||||||
bind(done);
|
bind(done);
|
||||||
|
@ -3398,7 +3062,7 @@ void MacroAssembler::compiler_unlock_object(Register Roop, Register Rmark,
|
||||||
delayed()->andcc(G0, G0, G0);
|
delayed()->andcc(G0, G0, G0);
|
||||||
add(Rmark, ObjectMonitor::owner_offset_in_bytes()-2, Rmark);
|
add(Rmark, ObjectMonitor::owner_offset_in_bytes()-2, Rmark);
|
||||||
mov(G2_thread, Rscratch);
|
mov(G2_thread, Rscratch);
|
||||||
casn(Rmark, G0, Rscratch);
|
cas_ptr(Rmark, G0, Rscratch);
|
||||||
// invert icc.zf and goto done
|
// invert icc.zf and goto done
|
||||||
br_notnull(Rscratch, false, Assembler::pt, done);
|
br_notnull(Rscratch, false, Assembler::pt, done);
|
||||||
delayed()->cmp(G0, G0);
|
delayed()->cmp(G0, G0);
|
||||||
|
@ -3440,7 +3104,7 @@ void MacroAssembler::compiler_unlock_object(Register Roop, Register Rmark,
|
||||||
// A prototype implementation showed excellent results, although
|
// A prototype implementation showed excellent results, although
|
||||||
// the scavenger and timeout code was rather involved.
|
// the scavenger and timeout code was rather involved.
|
||||||
|
|
||||||
casn(mark_addr.base(), Rbox, Rscratch);
|
cas_ptr(mark_addr.base(), Rbox, Rscratch);
|
||||||
cmp(Rbox, Rscratch);
|
cmp(Rbox, Rscratch);
|
||||||
// Intentional fall through into done ...
|
// Intentional fall through into done ...
|
||||||
|
|
||||||
|
@ -3540,7 +3204,8 @@ void MacroAssembler::eden_allocate(
|
||||||
|
|
||||||
if (CMSIncrementalMode || !Universe::heap()->supports_inline_contig_alloc()) {
|
if (CMSIncrementalMode || !Universe::heap()->supports_inline_contig_alloc()) {
|
||||||
// No allocation in the shared eden.
|
// No allocation in the shared eden.
|
||||||
ba_short(slow_case);
|
ba(slow_case);
|
||||||
|
delayed()->nop();
|
||||||
} else {
|
} else {
|
||||||
// get eden boundaries
|
// get eden boundaries
|
||||||
// note: we need both top & top_addr!
|
// note: we need both top & top_addr!
|
||||||
|
@ -3583,7 +3248,7 @@ void MacroAssembler::eden_allocate(
|
||||||
// Compare obj with the value at top_addr; if still equal, swap the value of
|
// Compare obj with the value at top_addr; if still equal, swap the value of
|
||||||
// end with the value at top_addr. If not equal, read the value at top_addr
|
// end with the value at top_addr. If not equal, read the value at top_addr
|
||||||
// into end.
|
// into end.
|
||||||
casx_under_lock(top_addr, obj, end, (address)StubRoutines::Sparc::atomic_memory_operation_lock_addr());
|
cas_ptr(top_addr, obj, end);
|
||||||
// if someone beat us on the allocation, try again, otherwise continue
|
// if someone beat us on the allocation, try again, otherwise continue
|
||||||
cmp(obj, end);
|
cmp(obj, end);
|
||||||
brx(Assembler::notEqual, false, Assembler::pn, retry);
|
brx(Assembler::notEqual, false, Assembler::pn, retry);
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2013, 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
|
||||||
|
@ -963,7 +963,7 @@ public:
|
||||||
inline void sub(Register s1, RegisterOrConstant s2, Register d, int offset = 0);
|
inline void sub(Register s1, RegisterOrConstant s2, Register d, int offset = 0);
|
||||||
|
|
||||||
using Assembler::swap;
|
using Assembler::swap;
|
||||||
inline void swap(Address& a, Register d, int offset = 0);
|
inline void swap(const Address& a, Register d, int offset = 0);
|
||||||
|
|
||||||
// address pseudos: make these names unlike instruction names to avoid confusion
|
// address pseudos: make these names unlike instruction names to avoid confusion
|
||||||
inline intptr_t load_pc_address( Register reg, int bytes_to_skip );
|
inline intptr_t load_pc_address( Register reg, int bytes_to_skip );
|
||||||
|
@ -1056,13 +1056,6 @@ public:
|
||||||
|
|
||||||
void breakpoint_trap();
|
void breakpoint_trap();
|
||||||
void breakpoint_trap(Condition c, CC cc);
|
void breakpoint_trap(Condition c, CC cc);
|
||||||
void flush_windows_trap();
|
|
||||||
void clean_windows_trap();
|
|
||||||
void get_psr_trap();
|
|
||||||
void set_psr_trap();
|
|
||||||
|
|
||||||
// V8/V9 flush_windows
|
|
||||||
void flush_windows();
|
|
||||||
|
|
||||||
// Support for serializing memory accesses between threads
|
// Support for serializing memory accesses between threads
|
||||||
void serialize_memory(Register thread, Register tmp1, Register tmp2);
|
void serialize_memory(Register thread, Register tmp1, Register tmp2);
|
||||||
|
@ -1071,14 +1064,6 @@ public:
|
||||||
void enter();
|
void enter();
|
||||||
void leave();
|
void leave();
|
||||||
|
|
||||||
// V8/V9 integer multiply
|
|
||||||
void mult(Register s1, Register s2, Register d);
|
|
||||||
void mult(Register s1, int simm13a, Register d);
|
|
||||||
|
|
||||||
// V8/V9 read and write of condition codes.
|
|
||||||
void read_ccr(Register d);
|
|
||||||
void write_ccr(Register s);
|
|
||||||
|
|
||||||
// Manipulation of C++ bools
|
// Manipulation of C++ bools
|
||||||
// These are idioms to flag the need for care with accessing bools but on
|
// These are idioms to flag the need for care with accessing bools but on
|
||||||
// this platform we assume byte size
|
// this platform we assume byte size
|
||||||
|
@ -1162,21 +1147,6 @@ public:
|
||||||
// check_and_forward_exception to handle exceptions when it is safe
|
// check_and_forward_exception to handle exceptions when it is safe
|
||||||
void check_and_forward_exception(Register scratch_reg);
|
void check_and_forward_exception(Register scratch_reg);
|
||||||
|
|
||||||
private:
|
|
||||||
// For V8
|
|
||||||
void read_ccr_trap(Register ccr_save);
|
|
||||||
void write_ccr_trap(Register ccr_save1, Register scratch1, Register scratch2);
|
|
||||||
|
|
||||||
#ifdef ASSERT
|
|
||||||
// For V8 debugging. Uses V8 instruction sequence and checks
|
|
||||||
// result with V9 insturctions rdccr and wrccr.
|
|
||||||
// Uses Gscatch and Gscatch2
|
|
||||||
void read_ccr_v8_assert(Register ccr_save);
|
|
||||||
void write_ccr_v8_assert(Register ccr_save);
|
|
||||||
#endif // ASSERT
|
|
||||||
|
|
||||||
public:
|
|
||||||
|
|
||||||
// Write to card table for - register is destroyed afterwards.
|
// Write to card table for - register is destroyed afterwards.
|
||||||
void card_table_write(jbyte* byte_map_base, Register tmp, Register obj);
|
void card_table_write(jbyte* byte_map_base, Register tmp, Register obj);
|
||||||
|
|
||||||
|
@ -1314,20 +1284,9 @@ public:
|
||||||
FloatRegister Fa, FloatRegister Fb,
|
FloatRegister Fa, FloatRegister Fb,
|
||||||
Register Rresult);
|
Register Rresult);
|
||||||
|
|
||||||
void fneg( FloatRegisterImpl::Width w, FloatRegister s, FloatRegister d);
|
|
||||||
void fneg( FloatRegisterImpl::Width w, FloatRegister sd ) { Assembler::fneg(w, sd); }
|
|
||||||
void fmov( FloatRegisterImpl::Width w, FloatRegister s, FloatRegister d);
|
|
||||||
void fabs( FloatRegisterImpl::Width w, FloatRegister s, FloatRegister d);
|
|
||||||
|
|
||||||
void save_all_globals_into_locals();
|
void save_all_globals_into_locals();
|
||||||
void restore_globals_from_locals();
|
void restore_globals_from_locals();
|
||||||
|
|
||||||
void casx_under_lock(Register top_ptr_reg, Register top_reg, Register ptr_reg,
|
|
||||||
address lock_addr=0, bool use_call_vm=false);
|
|
||||||
void cas_under_lock(Register top_ptr_reg, Register top_reg, Register ptr_reg,
|
|
||||||
address lock_addr=0, bool use_call_vm=false);
|
|
||||||
void casn (Register addr_reg, Register cmp_reg, Register set_reg) ;
|
|
||||||
|
|
||||||
// These set the icc condition code to equal if the lock succeeded
|
// These set the icc condition code to equal if the lock succeeded
|
||||||
// and notEqual if it failed and requires a slow case
|
// and notEqual if it failed and requires a slow case
|
||||||
void compiler_lock_object(Register Roop, Register Rmark, Register Rbox,
|
void compiler_lock_object(Register Roop, Register Rmark, Register Rbox,
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2013, 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
|
||||||
|
@ -229,10 +229,7 @@ inline void MacroAssembler::sll_ptr( Register s1, RegisterOrConstant s2, Registe
|
||||||
// Use the right branch for the platform
|
// Use the right branch for the platform
|
||||||
|
|
||||||
inline void MacroAssembler::br( Condition c, bool a, Predict p, address d, relocInfo::relocType rt ) {
|
inline void MacroAssembler::br( Condition c, bool a, Predict p, address d, relocInfo::relocType rt ) {
|
||||||
if (VM_Version::v9_instructions_work())
|
Assembler::bp(c, a, icc, p, d, rt);
|
||||||
Assembler::bp(c, a, icc, p, d, rt);
|
|
||||||
else
|
|
||||||
Assembler::br(c, a, d, rt);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void MacroAssembler::br( Condition c, bool a, Predict p, Label& L ) {
|
inline void MacroAssembler::br( Condition c, bool a, Predict p, Label& L ) {
|
||||||
|
@ -268,10 +265,7 @@ inline void MacroAssembler::bp( Condition c, bool a, CC cc, Predict p, Label& L
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void MacroAssembler::fb( Condition c, bool a, Predict p, address d, relocInfo::relocType rt ) {
|
inline void MacroAssembler::fb( Condition c, bool a, Predict p, address d, relocInfo::relocType rt ) {
|
||||||
if (VM_Version::v9_instructions_work())
|
fbp(c, a, fcc0, p, d, rt);
|
||||||
fbp(c, a, fcc0, p, d, rt);
|
|
||||||
else
|
|
||||||
Assembler::fb(c, a, d, rt);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void MacroAssembler::fb( Condition c, bool a, Predict p, Label& L ) {
|
inline void MacroAssembler::fb( Condition c, bool a, Predict p, Label& L ) {
|
||||||
|
@ -334,7 +328,7 @@ inline void MacroAssembler::callr( Register s1, int simm13a, RelocationHolder co
|
||||||
|
|
||||||
// prefetch instruction
|
// prefetch instruction
|
||||||
inline void MacroAssembler::iprefetch( address d, relocInfo::relocType rt ) {
|
inline void MacroAssembler::iprefetch( address d, relocInfo::relocType rt ) {
|
||||||
if (VM_Version::v9_instructions_work())
|
Assembler::bp( never, true, xcc, pt, d, rt );
|
||||||
Assembler::bp( never, true, xcc, pt, d, rt );
|
Assembler::bp( never, true, xcc, pt, d, rt );
|
||||||
}
|
}
|
||||||
inline void MacroAssembler::iprefetch( Label& L) { iprefetch( target(L) ); }
|
inline void MacroAssembler::iprefetch( Label& L) { iprefetch( target(L) ); }
|
||||||
|
@ -344,15 +338,7 @@ inline void MacroAssembler::iprefetch( Label& L) { iprefetch( target(L) ); }
|
||||||
// returns delta from gotten pc to addr after
|
// returns delta from gotten pc to addr after
|
||||||
inline int MacroAssembler::get_pc( Register d ) {
|
inline int MacroAssembler::get_pc( Register d ) {
|
||||||
int x = offset();
|
int x = offset();
|
||||||
if (VM_Version::v9_instructions_work())
|
rdpc(d);
|
||||||
rdpc(d);
|
|
||||||
else {
|
|
||||||
Label lbl;
|
|
||||||
Assembler::call(lbl, relocInfo::none); // No relocation as this is call to pc+0x8
|
|
||||||
if (d == O7) delayed()->nop();
|
|
||||||
else delayed()->mov(O7, d);
|
|
||||||
bind(lbl);
|
|
||||||
}
|
|
||||||
return offset() - x;
|
return offset() - x;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -646,41 +632,26 @@ inline void MacroAssembler::ldf(FloatRegisterImpl::Width w, const Address& a, Fl
|
||||||
// returns if membar generates anything, obviously this code should mirror
|
// returns if membar generates anything, obviously this code should mirror
|
||||||
// membar below.
|
// membar below.
|
||||||
inline bool MacroAssembler::membar_has_effect( Membar_mask_bits const7a ) {
|
inline bool MacroAssembler::membar_has_effect( Membar_mask_bits const7a ) {
|
||||||
if( !os::is_MP() ) return false; // Not needed on single CPU
|
if (!os::is_MP())
|
||||||
if( VM_Version::v9_instructions_work() ) {
|
return false; // Not needed on single CPU
|
||||||
const Membar_mask_bits effective_mask =
|
const Membar_mask_bits effective_mask =
|
||||||
Membar_mask_bits(const7a & ~(LoadLoad | LoadStore | StoreStore));
|
Membar_mask_bits(const7a & ~(LoadLoad | LoadStore | StoreStore));
|
||||||
return (effective_mask != 0);
|
return (effective_mask != 0);
|
||||||
} else {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void MacroAssembler::membar( Membar_mask_bits const7a ) {
|
inline void MacroAssembler::membar( Membar_mask_bits const7a ) {
|
||||||
// Uniprocessors do not need memory barriers
|
// Uniprocessors do not need memory barriers
|
||||||
if (!os::is_MP()) return;
|
if (!os::is_MP())
|
||||||
|
return;
|
||||||
// Weakened for current Sparcs and TSO. See the v9 manual, sections 8.4.3,
|
// Weakened for current Sparcs and TSO. See the v9 manual, sections 8.4.3,
|
||||||
// 8.4.4.3, a.31 and a.50.
|
// 8.4.4.3, a.31 and a.50.
|
||||||
if( VM_Version::v9_instructions_work() ) {
|
// Under TSO, setting bit 3, 2, or 0 is redundant, so the only value
|
||||||
// Under TSO, setting bit 3, 2, or 0 is redundant, so the only value
|
// of the mmask subfield of const7a that does anything that isn't done
|
||||||
// of the mmask subfield of const7a that does anything that isn't done
|
// implicitly is StoreLoad.
|
||||||
// implicitly is StoreLoad.
|
const Membar_mask_bits effective_mask =
|
||||||
const Membar_mask_bits effective_mask =
|
Membar_mask_bits(const7a & ~(LoadLoad | LoadStore | StoreStore));
|
||||||
Membar_mask_bits(const7a & ~(LoadLoad | LoadStore | StoreStore));
|
if (effective_mask != 0) {
|
||||||
if ( effective_mask != 0 ) {
|
Assembler::membar(effective_mask);
|
||||||
Assembler::membar( effective_mask );
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
// stbar is the closest there is on v8. Equivalent to membar(StoreStore). We
|
|
||||||
// do not issue the stbar because to my knowledge all v8 machines implement TSO,
|
|
||||||
// which guarantees that all stores behave as if an stbar were issued just after
|
|
||||||
// each one of them. On these machines, stbar ought to be a nop. There doesn't
|
|
||||||
// appear to be an equivalent of membar(StoreLoad) on v8: TSO doesn't require it,
|
|
||||||
// it can't be specified by stbar, nor have I come up with a way to simulate it.
|
|
||||||
//
|
|
||||||
// Addendum. Dave says that ldstub guarantees a write buffer flush to coherent
|
|
||||||
// space. Put one here to be on the safe side.
|
|
||||||
Assembler::ldstub(SP, 0, G0);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -748,7 +719,7 @@ inline void MacroAssembler::sub(Register s1, RegisterOrConstant s2, Register d,
|
||||||
if (offset != 0) sub(d, offset, d);
|
if (offset != 0) sub(d, offset, d);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void MacroAssembler::swap(Address& a, Register d, int offset) {
|
inline void MacroAssembler::swap(const Address& a, Register d, int offset) {
|
||||||
relocate(a.rspec(offset));
|
relocate(a.rspec(offset));
|
||||||
if (a.has_index()) { assert(offset == 0, ""); swap(a.base(), a.index(), d ); }
|
if (a.has_index()) { assert(offset == 0, ""); swap(a.base(), a.index(), d ); }
|
||||||
else { swap(a.base(), a.disp() + offset, d); }
|
else { swap(a.base(), a.disp() + offset, d); }
|
||||||
|
|
|
@ -162,7 +162,7 @@ void NativeCall::replace_mt_safe(address instr_addr, address code_buffer) {
|
||||||
int i1 = ((int*)code_buffer)[1];
|
int i1 = ((int*)code_buffer)[1];
|
||||||
int* contention_addr = (int*) n_call->addr_at(1*BytesPerInstWord);
|
int* contention_addr = (int*) n_call->addr_at(1*BytesPerInstWord);
|
||||||
assert(inv_op(*contention_addr) == Assembler::arith_op ||
|
assert(inv_op(*contention_addr) == Assembler::arith_op ||
|
||||||
*contention_addr == nop_instruction() || !VM_Version::v9_instructions_work(),
|
*contention_addr == nop_instruction(),
|
||||||
"must not interfere with original call");
|
"must not interfere with original call");
|
||||||
// The set_long_at calls do the ICacheInvalidate so we just need to do them in reverse order
|
// The set_long_at calls do the ICacheInvalidate so we just need to do them in reverse order
|
||||||
n_call->set_long_at(1*BytesPerInstWord, i1);
|
n_call->set_long_at(1*BytesPerInstWord, i1);
|
||||||
|
@ -181,7 +181,7 @@ void NativeCall::replace_mt_safe(address instr_addr, address code_buffer) {
|
||||||
// Make sure the first-patched instruction, which may co-exist
|
// Make sure the first-patched instruction, which may co-exist
|
||||||
// briefly with the call, will do something harmless.
|
// briefly with the call, will do something harmless.
|
||||||
assert(inv_op(*contention_addr) == Assembler::arith_op ||
|
assert(inv_op(*contention_addr) == Assembler::arith_op ||
|
||||||
*contention_addr == nop_instruction() || !VM_Version::v9_instructions_work(),
|
*contention_addr == nop_instruction(),
|
||||||
"must not interfere with original call");
|
"must not interfere with original call");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -933,11 +933,7 @@ void NativeJump::patch_verified_entry(address entry, address verified_entry, add
|
||||||
int code_size = 1 * BytesPerInstWord;
|
int code_size = 1 * BytesPerInstWord;
|
||||||
CodeBuffer cb(verified_entry, code_size + 1);
|
CodeBuffer cb(verified_entry, code_size + 1);
|
||||||
MacroAssembler* a = new MacroAssembler(&cb);
|
MacroAssembler* a = new MacroAssembler(&cb);
|
||||||
if (VM_Version::v9_instructions_work()) {
|
a->ldsw(G0, 0, O7); // "ld" must agree with code in the signal handler
|
||||||
a->ldsw(G0, 0, O7); // "ld" must agree with code in the signal handler
|
|
||||||
} else {
|
|
||||||
a->lduw(G0, 0, O7); // "ld" must agree with code in the signal handler
|
|
||||||
}
|
|
||||||
ICache::invalidate_range(verified_entry, code_size);
|
ICache::invalidate_range(verified_entry, code_size);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1024,7 +1020,7 @@ void NativeGeneralJump::replace_mt_safe(address instr_addr, address code_buffer)
|
||||||
int i1 = ((int*)code_buffer)[1];
|
int i1 = ((int*)code_buffer)[1];
|
||||||
int* contention_addr = (int*) h_jump->addr_at(1*BytesPerInstWord);
|
int* contention_addr = (int*) h_jump->addr_at(1*BytesPerInstWord);
|
||||||
assert(inv_op(*contention_addr) == Assembler::arith_op ||
|
assert(inv_op(*contention_addr) == Assembler::arith_op ||
|
||||||
*contention_addr == nop_instruction() || !VM_Version::v9_instructions_work(),
|
*contention_addr == nop_instruction(),
|
||||||
"must not interfere with original call");
|
"must not interfere with original call");
|
||||||
// The set_long_at calls do the ICacheInvalidate so we just need to do them in reverse order
|
// The set_long_at calls do the ICacheInvalidate so we just need to do them in reverse order
|
||||||
h_jump->set_long_at(1*BytesPerInstWord, i1);
|
h_jump->set_long_at(1*BytesPerInstWord, i1);
|
||||||
|
@ -1043,6 +1039,6 @@ void NativeGeneralJump::replace_mt_safe(address instr_addr, address code_buffer)
|
||||||
// Make sure the first-patched instruction, which may co-exist
|
// Make sure the first-patched instruction, which may co-exist
|
||||||
// briefly with the call, will do something harmless.
|
// briefly with the call, will do something harmless.
|
||||||
assert(inv_op(*contention_addr) == Assembler::arith_op ||
|
assert(inv_op(*contention_addr) == Assembler::arith_op ||
|
||||||
*contention_addr == nop_instruction() || !VM_Version::v9_instructions_work(),
|
*contention_addr == nop_instruction(),
|
||||||
"must not interfere with original call");
|
"must not interfere with original call");
|
||||||
}
|
}
|
||||||
|
|
|
@ -70,8 +70,7 @@ class NativeInstruction VALUE_OBJ_CLASS_SPEC {
|
||||||
bool is_zombie() {
|
bool is_zombie() {
|
||||||
int x = long_at(0);
|
int x = long_at(0);
|
||||||
return is_op3(x,
|
return is_op3(x,
|
||||||
VM_Version::v9_instructions_work() ?
|
Assembler::ldsw_op3,
|
||||||
Assembler::ldsw_op3 : Assembler::lduw_op3,
|
|
||||||
Assembler::ldst_op)
|
Assembler::ldst_op)
|
||||||
&& Assembler::inv_rs1(x) == G0
|
&& Assembler::inv_rs1(x) == G0
|
||||||
&& Assembler::inv_rd(x) == O7;
|
&& Assembler::inv_rd(x) == O7;
|
||||||
|
|
|
@ -249,12 +249,10 @@ class FloatRegisterImpl: public AbstractRegisterImpl {
|
||||||
|
|
||||||
case D:
|
case D:
|
||||||
assert(c < 64 && (c & 1) == 0, "bad double float register");
|
assert(c < 64 && (c & 1) == 0, "bad double float register");
|
||||||
assert(c < 32 || VM_Version::v9_instructions_work(), "V9 float work only on V9 platform");
|
|
||||||
return (c & 0x1e) | ((c & 0x20) >> 5);
|
return (c & 0x1e) | ((c & 0x20) >> 5);
|
||||||
|
|
||||||
case Q:
|
case Q:
|
||||||
assert(c < 64 && (c & 3) == 0, "bad quad float register");
|
assert(c < 64 && (c & 3) == 0, "bad quad float register");
|
||||||
assert(c < 32 || VM_Version::v9_instructions_work(), "V9 float work only on V9 platform");
|
|
||||||
return (c & 0x1c) | ((c & 0x20) >> 5);
|
return (c & 0x1c) | ((c & 0x20) >> 5);
|
||||||
}
|
}
|
||||||
ShouldNotReachHere();
|
ShouldNotReachHere();
|
||||||
|
|
|
@ -2459,7 +2459,7 @@ nmethod* SharedRuntime::generate_native_wrapper(MacroAssembler* masm,
|
||||||
|
|
||||||
// Finally just about ready to make the JNI call
|
// Finally just about ready to make the JNI call
|
||||||
|
|
||||||
__ flush_windows();
|
__ flushw();
|
||||||
if (inner_frame_created) {
|
if (inner_frame_created) {
|
||||||
__ restore();
|
__ restore();
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -2778,10 +2778,7 @@ enc_class Fast_Unlock(iRegP oop, iRegP box, o7RegP scratch, iRegP scratch2) %{
|
||||||
Register Rold = reg_to_register_object($old$$reg);
|
Register Rold = reg_to_register_object($old$$reg);
|
||||||
Register Rnew = reg_to_register_object($new$$reg);
|
Register Rnew = reg_to_register_object($new$$reg);
|
||||||
|
|
||||||
// casx_under_lock picks 1 of 3 encodings:
|
__ cas_ptr(Rmem, Rold, Rnew); // Swap(*Rmem,Rnew) if *Rmem == Rold
|
||||||
// For 32-bit pointers you get a 32-bit CAS
|
|
||||||
// For 64-bit pointers you get a 64-bit CASX
|
|
||||||
__ casn(Rmem, Rold, Rnew); // Swap(*Rmem,Rnew) if *Rmem == Rold
|
|
||||||
__ cmp( Rold, Rnew );
|
__ cmp( Rold, Rnew );
|
||||||
%}
|
%}
|
||||||
|
|
||||||
|
@ -3067,7 +3064,7 @@ enc_class enc_Array_Equals(o0RegP ary1, o1RegP ary2, g3RegP tmp1, notemp_iRegI r
|
||||||
AddressLiteral last_rethrow_addrlit(&last_rethrow);
|
AddressLiteral last_rethrow_addrlit(&last_rethrow);
|
||||||
__ sethi(last_rethrow_addrlit, L1);
|
__ sethi(last_rethrow_addrlit, L1);
|
||||||
Address addr(L1, last_rethrow_addrlit.low10());
|
Address addr(L1, last_rethrow_addrlit.low10());
|
||||||
__ get_pc(L2);
|
__ rdpc(L2);
|
||||||
__ inc(L2, 3 * BytesPerInstWord); // skip this & 2 more insns to point at jump_to
|
__ inc(L2, 3 * BytesPerInstWord); // skip this & 2 more insns to point at jump_to
|
||||||
__ st_ptr(L2, addr);
|
__ st_ptr(L2, addr);
|
||||||
__ restore();
|
__ restore();
|
||||||
|
|
|
@ -566,7 +566,7 @@ class StubGenerator: public StubCodeGenerator {
|
||||||
StubCodeMark mark(this, "StubRoutines", "flush_callers_register_windows");
|
StubCodeMark mark(this, "StubRoutines", "flush_callers_register_windows");
|
||||||
address start = __ pc();
|
address start = __ pc();
|
||||||
|
|
||||||
__ flush_windows();
|
__ flushw();
|
||||||
__ retl(false);
|
__ retl(false);
|
||||||
__ delayed()->add( FP, STACK_BIAS, O0 );
|
__ delayed()->add( FP, STACK_BIAS, O0 );
|
||||||
// The returned value must be a stack pointer whose register save area
|
// The returned value must be a stack pointer whose register save area
|
||||||
|
@ -575,67 +575,9 @@ class StubGenerator: public StubCodeGenerator {
|
||||||
return start;
|
return start;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Helper functions for v8 atomic operations.
|
|
||||||
//
|
|
||||||
void get_v8_oop_lock_ptr(Register lock_ptr_reg, Register mark_oop_reg, Register scratch_reg) {
|
|
||||||
if (mark_oop_reg == noreg) {
|
|
||||||
address lock_ptr = (address)StubRoutines::Sparc::atomic_memory_operation_lock_addr();
|
|
||||||
__ set((intptr_t)lock_ptr, lock_ptr_reg);
|
|
||||||
} else {
|
|
||||||
assert(scratch_reg != noreg, "just checking");
|
|
||||||
address lock_ptr = (address)StubRoutines::Sparc::_v8_oop_lock_cache;
|
|
||||||
__ set((intptr_t)lock_ptr, lock_ptr_reg);
|
|
||||||
__ and3(mark_oop_reg, StubRoutines::Sparc::v8_oop_lock_mask_in_place, scratch_reg);
|
|
||||||
__ add(lock_ptr_reg, scratch_reg, lock_ptr_reg);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void generate_v8_lock_prologue(Register lock_reg, Register lock_ptr_reg, Register yield_reg, Label& retry, Label& dontyield, Register mark_oop_reg = noreg, Register scratch_reg = noreg) {
|
|
||||||
|
|
||||||
get_v8_oop_lock_ptr(lock_ptr_reg, mark_oop_reg, scratch_reg);
|
|
||||||
__ set(StubRoutines::Sparc::locked, lock_reg);
|
|
||||||
// Initialize yield counter
|
|
||||||
__ mov(G0,yield_reg);
|
|
||||||
|
|
||||||
__ BIND(retry);
|
|
||||||
__ cmp_and_br_short(yield_reg, V8AtomicOperationUnderLockSpinCount, Assembler::less, Assembler::pt, dontyield);
|
|
||||||
|
|
||||||
// This code can only be called from inside the VM, this
|
|
||||||
// stub is only invoked from Atomic::add(). We do not
|
|
||||||
// want to use call_VM, because _last_java_sp and such
|
|
||||||
// must already be set.
|
|
||||||
//
|
|
||||||
// Save the regs and make space for a C call
|
|
||||||
__ save(SP, -96, SP);
|
|
||||||
__ save_all_globals_into_locals();
|
|
||||||
BLOCK_COMMENT("call os::naked_sleep");
|
|
||||||
__ call(CAST_FROM_FN_PTR(address, os::naked_sleep));
|
|
||||||
__ delayed()->nop();
|
|
||||||
__ restore_globals_from_locals();
|
|
||||||
__ restore();
|
|
||||||
// reset the counter
|
|
||||||
__ mov(G0,yield_reg);
|
|
||||||
|
|
||||||
__ BIND(dontyield);
|
|
||||||
|
|
||||||
// try to get lock
|
|
||||||
__ swap(lock_ptr_reg, 0, lock_reg);
|
|
||||||
|
|
||||||
// did we get the lock?
|
|
||||||
__ cmp(lock_reg, StubRoutines::Sparc::unlocked);
|
|
||||||
__ br(Assembler::notEqual, true, Assembler::pn, retry);
|
|
||||||
__ delayed()->add(yield_reg,1,yield_reg);
|
|
||||||
|
|
||||||
// yes, got lock. do the operation here.
|
|
||||||
}
|
|
||||||
|
|
||||||
void generate_v8_lock_epilogue(Register lock_reg, Register lock_ptr_reg, Register yield_reg, Label& retry, Label& dontyield, Register mark_oop_reg = noreg, Register scratch_reg = noreg) {
|
|
||||||
__ st(lock_reg, lock_ptr_reg, 0); // unlock
|
|
||||||
}
|
|
||||||
|
|
||||||
// Support for jint Atomic::xchg(jint exchange_value, volatile jint* dest).
|
// Support for jint Atomic::xchg(jint exchange_value, volatile jint* dest).
|
||||||
//
|
//
|
||||||
// Arguments :
|
// Arguments:
|
||||||
//
|
//
|
||||||
// exchange_value: O0
|
// exchange_value: O0
|
||||||
// dest: O1
|
// dest: O1
|
||||||
|
@ -656,33 +598,14 @@ class StubGenerator: public StubCodeGenerator {
|
||||||
__ mov(O0, O3); // scratch copy of exchange value
|
__ mov(O0, O3); // scratch copy of exchange value
|
||||||
__ ld(O1, 0, O2); // observe the previous value
|
__ ld(O1, 0, O2); // observe the previous value
|
||||||
// try to replace O2 with O3
|
// try to replace O2 with O3
|
||||||
__ cas_under_lock(O1, O2, O3,
|
__ cas(O1, O2, O3);
|
||||||
(address)StubRoutines::Sparc::atomic_memory_operation_lock_addr(),false);
|
|
||||||
__ cmp_and_br_short(O2, O3, Assembler::notEqual, Assembler::pn, retry);
|
__ cmp_and_br_short(O2, O3, Assembler::notEqual, Assembler::pn, retry);
|
||||||
|
|
||||||
__ retl(false);
|
__ retl(false);
|
||||||
__ delayed()->mov(O2, O0); // report previous value to caller
|
__ delayed()->mov(O2, O0); // report previous value to caller
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
if (VM_Version::v9_instructions_work()) {
|
__ retl(false);
|
||||||
__ retl(false);
|
__ delayed()->swap(O1, 0, O0);
|
||||||
__ delayed()->swap(O1, 0, O0);
|
|
||||||
} else {
|
|
||||||
const Register& lock_reg = O2;
|
|
||||||
const Register& lock_ptr_reg = O3;
|
|
||||||
const Register& yield_reg = O4;
|
|
||||||
|
|
||||||
Label retry;
|
|
||||||
Label dontyield;
|
|
||||||
|
|
||||||
generate_v8_lock_prologue(lock_reg, lock_ptr_reg, yield_reg, retry, dontyield);
|
|
||||||
// got the lock, do the swap
|
|
||||||
__ swap(O1, 0, O0);
|
|
||||||
|
|
||||||
generate_v8_lock_epilogue(lock_reg, lock_ptr_reg, yield_reg, retry, dontyield);
|
|
||||||
__ retl(false);
|
|
||||||
__ delayed()->nop();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return start;
|
return start;
|
||||||
|
@ -691,7 +614,7 @@ class StubGenerator: public StubCodeGenerator {
|
||||||
|
|
||||||
// Support for jint Atomic::cmpxchg(jint exchange_value, volatile jint* dest, jint compare_value)
|
// Support for jint Atomic::cmpxchg(jint exchange_value, volatile jint* dest, jint compare_value)
|
||||||
//
|
//
|
||||||
// Arguments :
|
// Arguments:
|
||||||
//
|
//
|
||||||
// exchange_value: O0
|
// exchange_value: O0
|
||||||
// dest: O1
|
// dest: O1
|
||||||
|
@ -701,15 +624,12 @@ class StubGenerator: public StubCodeGenerator {
|
||||||
//
|
//
|
||||||
// O0: the value previously stored in dest
|
// O0: the value previously stored in dest
|
||||||
//
|
//
|
||||||
// Overwrites (v8): O3,O4,O5
|
|
||||||
//
|
|
||||||
address generate_atomic_cmpxchg() {
|
address generate_atomic_cmpxchg() {
|
||||||
StubCodeMark mark(this, "StubRoutines", "atomic_cmpxchg");
|
StubCodeMark mark(this, "StubRoutines", "atomic_cmpxchg");
|
||||||
address start = __ pc();
|
address start = __ pc();
|
||||||
|
|
||||||
// cmpxchg(dest, compare_value, exchange_value)
|
// cmpxchg(dest, compare_value, exchange_value)
|
||||||
__ cas_under_lock(O1, O2, O0,
|
__ cas(O1, O2, O0);
|
||||||
(address)StubRoutines::Sparc::atomic_memory_operation_lock_addr(),false);
|
|
||||||
__ retl(false);
|
__ retl(false);
|
||||||
__ delayed()->nop();
|
__ delayed()->nop();
|
||||||
|
|
||||||
|
@ -718,7 +638,7 @@ class StubGenerator: public StubCodeGenerator {
|
||||||
|
|
||||||
// Support for jlong Atomic::cmpxchg(jlong exchange_value, volatile jlong *dest, jlong compare_value)
|
// Support for jlong Atomic::cmpxchg(jlong exchange_value, volatile jlong *dest, jlong compare_value)
|
||||||
//
|
//
|
||||||
// Arguments :
|
// Arguments:
|
||||||
//
|
//
|
||||||
// exchange_value: O1:O0
|
// exchange_value: O1:O0
|
||||||
// dest: O2
|
// dest: O2
|
||||||
|
@ -728,17 +648,12 @@ class StubGenerator: public StubCodeGenerator {
|
||||||
//
|
//
|
||||||
// O1:O0: the value previously stored in dest
|
// O1:O0: the value previously stored in dest
|
||||||
//
|
//
|
||||||
// This only works on V9, on V8 we don't generate any
|
|
||||||
// code and just return NULL.
|
|
||||||
//
|
|
||||||
// Overwrites: G1,G2,G3
|
// Overwrites: G1,G2,G3
|
||||||
//
|
//
|
||||||
address generate_atomic_cmpxchg_long() {
|
address generate_atomic_cmpxchg_long() {
|
||||||
StubCodeMark mark(this, "StubRoutines", "atomic_cmpxchg_long");
|
StubCodeMark mark(this, "StubRoutines", "atomic_cmpxchg_long");
|
||||||
address start = __ pc();
|
address start = __ pc();
|
||||||
|
|
||||||
if (!VM_Version::supports_cx8())
|
|
||||||
return NULL;;
|
|
||||||
__ sllx(O0, 32, O0);
|
__ sllx(O0, 32, O0);
|
||||||
__ srl(O1, 0, O1);
|
__ srl(O1, 0, O1);
|
||||||
__ or3(O0,O1,O0); // O0 holds 64-bit value from compare_value
|
__ or3(O0,O1,O0); // O0 holds 64-bit value from compare_value
|
||||||
|
@ -756,7 +671,7 @@ class StubGenerator: public StubCodeGenerator {
|
||||||
|
|
||||||
// Support for jint Atomic::add(jint add_value, volatile jint* dest).
|
// Support for jint Atomic::add(jint add_value, volatile jint* dest).
|
||||||
//
|
//
|
||||||
// Arguments :
|
// Arguments:
|
||||||
//
|
//
|
||||||
// add_value: O0 (e.g., +1 or -1)
|
// add_value: O0 (e.g., +1 or -1)
|
||||||
// dest: O1
|
// dest: O1
|
||||||
|
@ -765,47 +680,22 @@ class StubGenerator: public StubCodeGenerator {
|
||||||
//
|
//
|
||||||
// O0: the new value stored in dest
|
// O0: the new value stored in dest
|
||||||
//
|
//
|
||||||
// Overwrites (v9): O3
|
// Overwrites: O3
|
||||||
// Overwrites (v8): O3,O4,O5
|
|
||||||
//
|
//
|
||||||
address generate_atomic_add() {
|
address generate_atomic_add() {
|
||||||
StubCodeMark mark(this, "StubRoutines", "atomic_add");
|
StubCodeMark mark(this, "StubRoutines", "atomic_add");
|
||||||
address start = __ pc();
|
address start = __ pc();
|
||||||
__ BIND(_atomic_add_stub);
|
__ BIND(_atomic_add_stub);
|
||||||
|
|
||||||
if (VM_Version::v9_instructions_work()) {
|
Label(retry);
|
||||||
Label(retry);
|
__ BIND(retry);
|
||||||
__ BIND(retry);
|
|
||||||
|
|
||||||
__ lduw(O1, 0, O2);
|
__ lduw(O1, 0, O2);
|
||||||
__ add(O0, O2, O3);
|
__ add(O0, O2, O3);
|
||||||
__ cas(O1, O2, O3);
|
__ cas(O1, O2, O3);
|
||||||
__ cmp_and_br_short(O2, O3, Assembler::notEqual, Assembler::pn, retry);
|
__ cmp_and_br_short(O2, O3, Assembler::notEqual, Assembler::pn, retry);
|
||||||
__ retl(false);
|
__ retl(false);
|
||||||
__ delayed()->add(O0, O2, O0); // note that cas made O2==O3
|
__ delayed()->add(O0, O2, O0); // note that cas made O2==O3
|
||||||
} else {
|
|
||||||
const Register& lock_reg = O2;
|
|
||||||
const Register& lock_ptr_reg = O3;
|
|
||||||
const Register& value_reg = O4;
|
|
||||||
const Register& yield_reg = O5;
|
|
||||||
|
|
||||||
Label(retry);
|
|
||||||
Label(dontyield);
|
|
||||||
|
|
||||||
generate_v8_lock_prologue(lock_reg, lock_ptr_reg, yield_reg, retry, dontyield);
|
|
||||||
// got lock, do the increment
|
|
||||||
__ ld(O1, 0, value_reg);
|
|
||||||
__ add(O0, value_reg, value_reg);
|
|
||||||
__ st(value_reg, O1, 0);
|
|
||||||
|
|
||||||
// %%% only for RMO and PSO
|
|
||||||
__ membar(Assembler::StoreStore);
|
|
||||||
|
|
||||||
generate_v8_lock_epilogue(lock_reg, lock_ptr_reg, yield_reg, retry, dontyield);
|
|
||||||
|
|
||||||
__ retl(false);
|
|
||||||
__ delayed()->mov(value_reg, O0);
|
|
||||||
}
|
|
||||||
|
|
||||||
return start;
|
return start;
|
||||||
}
|
}
|
||||||
|
@ -841,7 +731,7 @@ class StubGenerator: public StubCodeGenerator {
|
||||||
__ mov(G3, L3);
|
__ mov(G3, L3);
|
||||||
__ mov(G4, L4);
|
__ mov(G4, L4);
|
||||||
__ mov(G5, L5);
|
__ mov(G5, L5);
|
||||||
for (i = 0; i < (VM_Version::v9_instructions_work() ? 64 : 32); i += 2) {
|
for (i = 0; i < 64; i += 2) {
|
||||||
__ stf(FloatRegisterImpl::D, as_FloatRegister(i), preserve_addr, i * wordSize);
|
__ stf(FloatRegisterImpl::D, as_FloatRegister(i), preserve_addr, i * wordSize);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -855,7 +745,7 @@ class StubGenerator: public StubCodeGenerator {
|
||||||
__ mov(L3, G3);
|
__ mov(L3, G3);
|
||||||
__ mov(L4, G4);
|
__ mov(L4, G4);
|
||||||
__ mov(L5, G5);
|
__ mov(L5, G5);
|
||||||
for (i = 0; i < (VM_Version::v9_instructions_work() ? 64 : 32); i += 2) {
|
for (i = 0; i < 64; i += 2) {
|
||||||
__ ldf(FloatRegisterImpl::D, preserve_addr, as_FloatRegister(i), i * wordSize);
|
__ ldf(FloatRegisterImpl::D, preserve_addr, as_FloatRegister(i), i * wordSize);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -52,7 +52,3 @@ address StubRoutines::Sparc::_stop_subroutine_entry = NULL;
|
||||||
address StubRoutines::Sparc::_flush_callers_register_windows_entry = CAST_FROM_FN_PTR(address, bootstrap_flush_windows);
|
address StubRoutines::Sparc::_flush_callers_register_windows_entry = CAST_FROM_FN_PTR(address, bootstrap_flush_windows);
|
||||||
|
|
||||||
address StubRoutines::Sparc::_partial_subtype_check = NULL;
|
address StubRoutines::Sparc::_partial_subtype_check = NULL;
|
||||||
|
|
||||||
int StubRoutines::Sparc::_atomic_memory_operation_lock = StubRoutines::Sparc::unlocked;
|
|
||||||
|
|
||||||
int StubRoutines::Sparc::_v8_oop_lock_cache[StubRoutines::Sparc::nof_v8_oop_lock_cache_entries];
|
|
||||||
|
|
|
@ -47,46 +47,14 @@ enum /* platform_dependent_constants */ {
|
||||||
class Sparc {
|
class Sparc {
|
||||||
friend class StubGenerator;
|
friend class StubGenerator;
|
||||||
|
|
||||||
public:
|
|
||||||
enum { nof_instance_allocators = 10 };
|
|
||||||
|
|
||||||
// allocator lock values
|
|
||||||
enum {
|
|
||||||
unlocked = 0,
|
|
||||||
locked = 1
|
|
||||||
};
|
|
||||||
|
|
||||||
enum {
|
|
||||||
v8_oop_lock_ignore_bits = 2,
|
|
||||||
v8_oop_lock_bits = 4,
|
|
||||||
nof_v8_oop_lock_cache_entries = 1 << (v8_oop_lock_bits+v8_oop_lock_ignore_bits),
|
|
||||||
v8_oop_lock_mask = right_n_bits(v8_oop_lock_bits),
|
|
||||||
v8_oop_lock_mask_in_place = v8_oop_lock_mask << v8_oop_lock_ignore_bits
|
|
||||||
};
|
|
||||||
|
|
||||||
static int _v8_oop_lock_cache[nof_v8_oop_lock_cache_entries];
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
static address _test_stop_entry;
|
static address _test_stop_entry;
|
||||||
static address _stop_subroutine_entry;
|
static address _stop_subroutine_entry;
|
||||||
static address _flush_callers_register_windows_entry;
|
static address _flush_callers_register_windows_entry;
|
||||||
|
|
||||||
static int _atomic_memory_operation_lock;
|
|
||||||
|
|
||||||
static address _partial_subtype_check;
|
static address _partial_subtype_check;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
// %%% global lock for everyone who needs to use atomic_compare_and_exchange
|
|
||||||
// %%% or atomic_increment -- should probably use more locks for more
|
|
||||||
// %%% scalability-- for instance one for each eden space or group of
|
|
||||||
|
|
||||||
// address of the lock for atomic_compare_and_exchange
|
|
||||||
static int* atomic_memory_operation_lock_addr() { return &_atomic_memory_operation_lock; }
|
|
||||||
|
|
||||||
// accessor and mutator for _atomic_memory_operation_lock
|
|
||||||
static int atomic_memory_operation_lock() { return _atomic_memory_operation_lock; }
|
|
||||||
static void set_atomic_memory_operation_lock(int value) { _atomic_memory_operation_lock = value; }
|
|
||||||
|
|
||||||
// test assembler stop routine by setting registers
|
// test assembler stop routine by setting registers
|
||||||
static void (*test_stop_entry()) () { return CAST_TO_FN_PTR(void (*)(void), _test_stop_entry); }
|
static void (*test_stop_entry()) () { return CAST_TO_FN_PTR(void (*)(void), _test_stop_entry); }
|
||||||
|
|
||||||
|
|
|
@ -1054,7 +1054,7 @@ address InterpreterGenerator::generate_native_entry(bool synchronized) {
|
||||||
// flush the windows now. We don't care about the current (protection) frame
|
// flush the windows now. We don't care about the current (protection) frame
|
||||||
// only the outer frames
|
// only the outer frames
|
||||||
|
|
||||||
__ flush_windows();
|
__ flushw();
|
||||||
|
|
||||||
// mark windows as flushed
|
// mark windows as flushed
|
||||||
Address flags(G2_thread, JavaThread::frame_anchor_offset() + JavaFrameAnchor::flags_offset());
|
Address flags(G2_thread, JavaThread::frame_anchor_offset() + JavaFrameAnchor::flags_offset());
|
||||||
|
|
|
@ -1338,14 +1338,13 @@ void TemplateTable::lneg() {
|
||||||
|
|
||||||
void TemplateTable::fneg() {
|
void TemplateTable::fneg() {
|
||||||
transition(ftos, ftos);
|
transition(ftos, ftos);
|
||||||
__ fneg(FloatRegisterImpl::S, Ftos_f);
|
__ fneg(FloatRegisterImpl::S, Ftos_f, Ftos_f);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void TemplateTable::dneg() {
|
void TemplateTable::dneg() {
|
||||||
transition(dtos, dtos);
|
transition(dtos, dtos);
|
||||||
// v8 has fnegd if source and dest are the same
|
__ fneg(FloatRegisterImpl::D, Ftos_f, Ftos_f);
|
||||||
__ fneg(FloatRegisterImpl::D, Ftos_f);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -1470,19 +1469,10 @@ void TemplateTable::convert() {
|
||||||
__ st_long(Otos_l, __ d_tmp);
|
__ st_long(Otos_l, __ d_tmp);
|
||||||
__ ldf(FloatRegisterImpl::D, __ d_tmp, Ftos_d);
|
__ ldf(FloatRegisterImpl::D, __ d_tmp, Ftos_d);
|
||||||
|
|
||||||
if (VM_Version::v9_instructions_work()) {
|
if (bytecode() == Bytecodes::_l2f) {
|
||||||
if (bytecode() == Bytecodes::_l2f) {
|
__ fxtof(FloatRegisterImpl::S, Ftos_d, Ftos_f);
|
||||||
__ fxtof(FloatRegisterImpl::S, Ftos_d, Ftos_f);
|
|
||||||
} else {
|
|
||||||
__ fxtof(FloatRegisterImpl::D, Ftos_d, Ftos_d);
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
__ call_VM_leaf(
|
__ fxtof(FloatRegisterImpl::D, Ftos_d, Ftos_d);
|
||||||
Lscratch,
|
|
||||||
bytecode() == Bytecodes::_l2f
|
|
||||||
? CAST_FROM_FN_PTR(address, SharedRuntime::l2f)
|
|
||||||
: CAST_FROM_FN_PTR(address, SharedRuntime::l2d)
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -1490,11 +1480,6 @@ void TemplateTable::convert() {
|
||||||
Label isNaN;
|
Label isNaN;
|
||||||
// result must be 0 if value is NaN; test by comparing value to itself
|
// result must be 0 if value is NaN; test by comparing value to itself
|
||||||
__ fcmp(FloatRegisterImpl::S, Assembler::fcc0, Ftos_f, Ftos_f);
|
__ fcmp(FloatRegisterImpl::S, Assembler::fcc0, Ftos_f, Ftos_f);
|
||||||
// According to the v8 manual, you have to have a non-fp instruction
|
|
||||||
// between fcmp and fb.
|
|
||||||
if (!VM_Version::v9_instructions_work()) {
|
|
||||||
__ nop();
|
|
||||||
}
|
|
||||||
__ fb(Assembler::f_unordered, true, Assembler::pn, isNaN);
|
__ fb(Assembler::f_unordered, true, Assembler::pn, isNaN);
|
||||||
__ delayed()->clr(Otos_i); // NaN
|
__ delayed()->clr(Otos_i); // NaN
|
||||||
__ ftoi(FloatRegisterImpl::S, Ftos_f, F30);
|
__ ftoi(FloatRegisterImpl::S, Ftos_f, F30);
|
||||||
|
@ -1537,16 +1522,7 @@ void TemplateTable::convert() {
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Bytecodes::_d2f:
|
case Bytecodes::_d2f:
|
||||||
if (VM_Version::v9_instructions_work()) {
|
|
||||||
__ ftof( FloatRegisterImpl::D, FloatRegisterImpl::S, Ftos_d, Ftos_f);
|
__ ftof( FloatRegisterImpl::D, FloatRegisterImpl::S, Ftos_d, Ftos_f);
|
||||||
}
|
|
||||||
else {
|
|
||||||
// must uncache tos
|
|
||||||
__ push_d();
|
|
||||||
__ pop_i(O0);
|
|
||||||
__ pop_i(O1);
|
|
||||||
__ call_VM_leaf(Lscratch, CAST_FROM_FN_PTR(address, SharedRuntime::d2f));
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default: ShouldNotReachHere();
|
default: ShouldNotReachHere();
|
||||||
|
@ -1956,17 +1932,8 @@ void TemplateTable::fast_binaryswitch() {
|
||||||
__ ld( Rarray, Rscratch, Rscratch );
|
__ ld( Rarray, Rscratch, Rscratch );
|
||||||
// (Rscratch is already in the native byte-ordering.)
|
// (Rscratch is already in the native byte-ordering.)
|
||||||
__ cmp( Rkey, Rscratch );
|
__ cmp( Rkey, Rscratch );
|
||||||
if ( VM_Version::v9_instructions_work() ) {
|
__ movcc( Assembler::less, false, Assembler::icc, Rh, Rj ); // j = h if (key < array[h].fast_match())
|
||||||
__ movcc( Assembler::less, false, Assembler::icc, Rh, Rj ); // j = h if (key < array[h].fast_match())
|
__ movcc( Assembler::greaterEqual, false, Assembler::icc, Rh, Ri ); // i = h if (key >= array[h].fast_match())
|
||||||
__ movcc( Assembler::greaterEqual, false, Assembler::icc, Rh, Ri ); // i = h if (key >= array[h].fast_match())
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
Label end_of_if;
|
|
||||||
__ br( Assembler::less, true, Assembler::pt, end_of_if );
|
|
||||||
__ delayed()->mov( Rh, Rj ); // if (<) Rj = Rh
|
|
||||||
__ mov( Rh, Ri ); // else i = h
|
|
||||||
__ bind(end_of_if); // }
|
|
||||||
}
|
|
||||||
|
|
||||||
// while (i+1 < j)
|
// while (i+1 < j)
|
||||||
__ bind( entry );
|
__ bind( entry );
|
||||||
|
@ -3418,9 +3385,7 @@ void TemplateTable::_new() {
|
||||||
// has been allocated.
|
// has been allocated.
|
||||||
__ cmp_and_brx_short(RnewTopValue, RendValue, Assembler::greaterUnsigned, Assembler::pn, slow_case);
|
__ cmp_and_brx_short(RnewTopValue, RendValue, Assembler::greaterUnsigned, Assembler::pn, slow_case);
|
||||||
|
|
||||||
__ casx_under_lock(RtopAddr, RoldTopValue, RnewTopValue,
|
__ cas_ptr(RtopAddr, RoldTopValue, RnewTopValue);
|
||||||
VM_Version::v9_instructions_work() ? NULL :
|
|
||||||
(address)StubRoutines::Sparc::atomic_memory_operation_lock_addr());
|
|
||||||
|
|
||||||
// if someone beat us on the allocation, try again, otherwise continue
|
// if someone beat us on the allocation, try again, otherwise continue
|
||||||
__ cmp_and_brx_short(RoldTopValue, RnewTopValue, Assembler::notEqual, Assembler::pn, retry);
|
__ cmp_and_brx_short(RoldTopValue, RnewTopValue, Assembler::notEqual, Assembler::pn, retry);
|
||||||
|
@ -3701,14 +3666,7 @@ void TemplateTable::monitorenter() {
|
||||||
|
|
||||||
__ verify_oop(O4); // verify each monitor's oop
|
__ verify_oop(O4); // verify each monitor's oop
|
||||||
__ tst(O4); // is this entry unused?
|
__ tst(O4); // is this entry unused?
|
||||||
if (VM_Version::v9_instructions_work())
|
__ movcc( Assembler::zero, false, Assembler::ptr_cc, O3, O1);
|
||||||
__ movcc( Assembler::zero, false, Assembler::ptr_cc, O3, O1);
|
|
||||||
else {
|
|
||||||
Label L;
|
|
||||||
__ br( Assembler::zero, true, Assembler::pn, L );
|
|
||||||
__ delayed()->mov(O3, O1); // rememeber this one if match
|
|
||||||
__ bind(L);
|
|
||||||
}
|
|
||||||
|
|
||||||
__ cmp(O4, O0); // check if current entry is for same object
|
__ cmp(O4, O0); // check if current entry is for same object
|
||||||
__ brx( Assembler::equal, false, Assembler::pn, exit );
|
__ brx( Assembler::equal, false, Assembler::pn, exit );
|
||||||
|
|
|
@ -75,23 +75,14 @@ void VM_Version::initialize() {
|
||||||
FLAG_SET_DEFAULT(AllocatePrefetchStyle, 1);
|
FLAG_SET_DEFAULT(AllocatePrefetchStyle, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (has_v9()) {
|
guarantee(VM_Version::has_v9(), "only SPARC v9 is supported");
|
||||||
assert(ArraycopySrcPrefetchDistance < 4096, "invalid value");
|
|
||||||
if (ArraycopySrcPrefetchDistance >= 4096)
|
assert(ArraycopySrcPrefetchDistance < 4096, "invalid value");
|
||||||
ArraycopySrcPrefetchDistance = 4064;
|
if (ArraycopySrcPrefetchDistance >= 4096)
|
||||||
assert(ArraycopyDstPrefetchDistance < 4096, "invalid value");
|
ArraycopySrcPrefetchDistance = 4064;
|
||||||
if (ArraycopyDstPrefetchDistance >= 4096)
|
assert(ArraycopyDstPrefetchDistance < 4096, "invalid value");
|
||||||
ArraycopyDstPrefetchDistance = 4064;
|
if (ArraycopyDstPrefetchDistance >= 4096)
|
||||||
} else {
|
ArraycopyDstPrefetchDistance = 4064;
|
||||||
if (ArraycopySrcPrefetchDistance > 0) {
|
|
||||||
warning("prefetch instructions are not available on this CPU");
|
|
||||||
FLAG_SET_DEFAULT(ArraycopySrcPrefetchDistance, 0);
|
|
||||||
}
|
|
||||||
if (ArraycopyDstPrefetchDistance > 0) {
|
|
||||||
warning("prefetch instructions are not available on this CPU");
|
|
||||||
FLAG_SET_DEFAULT(ArraycopyDstPrefetchDistance, 0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
UseSSE = 0; // Only on x86 and x64
|
UseSSE = 0; // Only on x86 and x64
|
||||||
|
|
||||||
|
|
|
@ -177,10 +177,6 @@ public:
|
||||||
return AllocatePrefetchDistance > 0 ? AllocatePrefetchStyle : 0;
|
return AllocatePrefetchDistance > 0 ? AllocatePrefetchStyle : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Legacy
|
|
||||||
static bool v8_instructions_work() { return has_v8() && !has_v9(); }
|
|
||||||
static bool v9_instructions_work() { return has_v9(); }
|
|
||||||
|
|
||||||
// Assembler testing
|
// Assembler testing
|
||||||
static void allow_all();
|
static void allow_all();
|
||||||
static void revert();
|
static void revert();
|
||||||
|
|
|
@ -1429,6 +1429,8 @@ static void unpack_array_argument(MacroAssembler* masm, VMRegPair reg, BasicType
|
||||||
assert(!length_arg.first()->is_Register() || length_arg.first()->as_Register() != tmp_reg,
|
assert(!length_arg.first()->is_Register() || length_arg.first()->as_Register() != tmp_reg,
|
||||||
"possible collision");
|
"possible collision");
|
||||||
|
|
||||||
|
__ block_comment("unpack_array_argument {");
|
||||||
|
|
||||||
// Pass the length, ptr pair
|
// Pass the length, ptr pair
|
||||||
Label is_null, done;
|
Label is_null, done;
|
||||||
VMRegPair tmp;
|
VMRegPair tmp;
|
||||||
|
@ -1453,6 +1455,8 @@ static void unpack_array_argument(MacroAssembler* masm, VMRegPair reg, BasicType
|
||||||
move_ptr(masm, tmp, body_arg);
|
move_ptr(masm, tmp, body_arg);
|
||||||
move32_64(masm, tmp, length_arg);
|
move32_64(masm, tmp, length_arg);
|
||||||
__ bind(done);
|
__ bind(done);
|
||||||
|
|
||||||
|
__ block_comment("} unpack_array_argument");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -2170,27 +2174,34 @@ nmethod* SharedRuntime::generate_native_wrapper(MacroAssembler* masm,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// point c_arg at the first arg that is already loaded in case we
|
int c_arg;
|
||||||
// need to spill before we call out
|
|
||||||
int c_arg = total_c_args - total_in_args;
|
|
||||||
|
|
||||||
// Pre-load a static method's oop into r14. Used both by locking code and
|
// Pre-load a static method's oop into r14. Used both by locking code and
|
||||||
// the normal JNI call code.
|
// the normal JNI call code.
|
||||||
if (method->is_static() && !is_critical_native) {
|
if (!is_critical_native) {
|
||||||
|
// point c_arg at the first arg that is already loaded in case we
|
||||||
|
// need to spill before we call out
|
||||||
|
c_arg = total_c_args - total_in_args;
|
||||||
|
|
||||||
// load oop into a register
|
if (method->is_static()) {
|
||||||
__ movoop(oop_handle_reg, JNIHandles::make_local(method->method_holder()->java_mirror()));
|
|
||||||
|
|
||||||
// Now handlize the static class mirror it's known not-null.
|
// load oop into a register
|
||||||
__ movptr(Address(rsp, klass_offset), oop_handle_reg);
|
__ movoop(oop_handle_reg, JNIHandles::make_local(method->method_holder()->java_mirror()));
|
||||||
map->set_oop(VMRegImpl::stack2reg(klass_slot_offset));
|
|
||||||
|
|
||||||
// Now get the handle
|
// Now handlize the static class mirror it's known not-null.
|
||||||
__ lea(oop_handle_reg, Address(rsp, klass_offset));
|
__ movptr(Address(rsp, klass_offset), oop_handle_reg);
|
||||||
// store the klass handle as second argument
|
map->set_oop(VMRegImpl::stack2reg(klass_slot_offset));
|
||||||
__ movptr(c_rarg1, oop_handle_reg);
|
|
||||||
// and protect the arg if we must spill
|
// Now get the handle
|
||||||
c_arg--;
|
__ lea(oop_handle_reg, Address(rsp, klass_offset));
|
||||||
|
// store the klass handle as second argument
|
||||||
|
__ movptr(c_rarg1, oop_handle_reg);
|
||||||
|
// and protect the arg if we must spill
|
||||||
|
c_arg--;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
// For JNI critical methods we need to save all registers in save_args.
|
||||||
|
c_arg = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Change state to native (we save the return address in the thread, since it might not
|
// Change state to native (we save the return address in the thread, since it might not
|
||||||
|
|
|
@ -1,47 +0,0 @@
|
||||||
/*
|
|
||||||
* Copyright (c) 1999, 2010, Oracle and/or its affiliates. All rights reserved.
|
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
||||||
*
|
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
|
||||||
* under the terms of the GNU General Public License version 2 only, as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This code is distributed in the hope that it will be useful, but WITHOUT
|
|
||||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
||||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
||||||
* version 2 for more details (a copy is included in the LICENSE file that
|
|
||||||
* accompanied this code).
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License version
|
|
||||||
* 2 along with this work; if not, write to the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
||||||
*
|
|
||||||
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
|
||||||
* or visit www.oracle.com if you need additional information or have any
|
|
||||||
* questions.
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "precompiled.hpp"
|
|
||||||
#include "asm/macroAssembler.hpp"
|
|
||||||
#include "runtime/os.hpp"
|
|
||||||
#include "runtime/threadLocalStorage.hpp"
|
|
||||||
|
|
||||||
#include <asm-sparc/traps.h>
|
|
||||||
|
|
||||||
void MacroAssembler::read_ccr_trap(Register ccr_save) {
|
|
||||||
// No implementation
|
|
||||||
breakpoint_trap();
|
|
||||||
}
|
|
||||||
|
|
||||||
void MacroAssembler::write_ccr_trap(Register ccr_save, Register scratch1, Register scratch2) {
|
|
||||||
// No implementation
|
|
||||||
breakpoint_trap();
|
|
||||||
}
|
|
||||||
|
|
||||||
void MacroAssembler::flush_windows_trap() { trap(SP_TRAP_FWIN); }
|
|
||||||
void MacroAssembler::clean_windows_trap() { trap(SP_TRAP_CWIN); }
|
|
||||||
|
|
||||||
// Use software breakpoint trap until we figure out how to do this on Linux
|
|
||||||
void MacroAssembler::get_psr_trap() { trap(SP_TRAP_SBPT); }
|
|
||||||
void MacroAssembler::set_psr_trap() { trap(SP_TRAP_SBPT); }
|
|
|
@ -169,7 +169,6 @@ inline jlong Atomic::cmpxchg (jlong exchange_value, volatile jlong*
|
||||||
: "memory");
|
: "memory");
|
||||||
return rv;
|
return rv;
|
||||||
#else
|
#else
|
||||||
assert(VM_Version::v9_instructions_work(), "cas only supported on v9");
|
|
||||||
volatile jlong_accessor evl, cvl, rv;
|
volatile jlong_accessor evl, cvl, rv;
|
||||||
evl.long_value = exchange_value;
|
evl.long_value = exchange_value;
|
||||||
cvl.long_value = compare_value;
|
cvl.long_value = compare_value;
|
||||||
|
|
|
@ -1,61 +0,0 @@
|
||||||
/*
|
|
||||||
* Copyright (c) 1999, 2010, Oracle and/or its affiliates. All rights reserved.
|
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
||||||
*
|
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
|
||||||
* under the terms of the GNU General Public License version 2 only, as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This code is distributed in the hope that it will be useful, but WITHOUT
|
|
||||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
||||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
||||||
* version 2 for more details (a copy is included in the LICENSE file that
|
|
||||||
* accompanied this code).
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License version
|
|
||||||
* 2 along with this work; if not, write to the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
||||||
*
|
|
||||||
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
|
||||||
* or visit www.oracle.com if you need additional information or have any
|
|
||||||
* questions.
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "precompiled.hpp"
|
|
||||||
#include "asm/macroAssembler.inline.hpp"
|
|
||||||
#include "runtime/os.hpp"
|
|
||||||
#include "runtime/threadLocalStorage.hpp"
|
|
||||||
|
|
||||||
#include <sys/trap.h> // For trap numbers
|
|
||||||
#include <v9/sys/psr_compat.h> // For V8 compatibility
|
|
||||||
|
|
||||||
void MacroAssembler::read_ccr_trap(Register ccr_save) {
|
|
||||||
// Execute a trap to get the PSR, mask and shift
|
|
||||||
// to get the condition codes.
|
|
||||||
get_psr_trap();
|
|
||||||
nop();
|
|
||||||
set(PSR_ICC, ccr_save);
|
|
||||||
and3(O0, ccr_save, ccr_save);
|
|
||||||
srl(ccr_save, PSR_ICC_SHIFT, ccr_save);
|
|
||||||
}
|
|
||||||
|
|
||||||
void MacroAssembler::write_ccr_trap(Register ccr_save, Register scratch1, Register scratch2) {
|
|
||||||
// Execute a trap to get the PSR, shift back
|
|
||||||
// the condition codes, mask the condition codes
|
|
||||||
// back into and PSR and trap to write back the
|
|
||||||
// PSR.
|
|
||||||
sll(ccr_save, PSR_ICC_SHIFT, scratch2);
|
|
||||||
get_psr_trap();
|
|
||||||
nop();
|
|
||||||
set(~PSR_ICC, scratch1);
|
|
||||||
and3(O0, scratch1, O0);
|
|
||||||
or3(O0, scratch2, O0);
|
|
||||||
set_psr_trap();
|
|
||||||
nop();
|
|
||||||
}
|
|
||||||
|
|
||||||
void MacroAssembler::flush_windows_trap() { trap(ST_FLUSH_WINDOWS); }
|
|
||||||
void MacroAssembler::clean_windows_trap() { trap(ST_CLEAN_WINDOWS); }
|
|
||||||
void MacroAssembler::get_psr_trap() { trap(ST_GETPSR); }
|
|
||||||
void MacroAssembler::set_psr_trap() { trap(ST_SETPSR); }
|
|
|
@ -60,21 +60,10 @@ inline jlong Atomic::load(volatile jlong* src) { return *src; }
|
||||||
|
|
||||||
#else
|
#else
|
||||||
|
|
||||||
extern "C" void _Atomic_move_long_v8(volatile jlong* src, volatile jlong* dst);
|
|
||||||
extern "C" void _Atomic_move_long_v9(volatile jlong* src, volatile jlong* dst);
|
extern "C" void _Atomic_move_long_v9(volatile jlong* src, volatile jlong* dst);
|
||||||
|
|
||||||
inline void Atomic_move_long(volatile jlong* src, volatile jlong* dst) {
|
inline void Atomic_move_long(volatile jlong* src, volatile jlong* dst) {
|
||||||
#ifdef COMPILER2
|
|
||||||
// Compiler2 does not support v8, it is used only for v9.
|
|
||||||
_Atomic_move_long_v9(src, dst);
|
_Atomic_move_long_v9(src, dst);
|
||||||
#else
|
|
||||||
// The branch is cheaper then emulated LDD.
|
|
||||||
if (VM_Version::v9_instructions_work()) {
|
|
||||||
_Atomic_move_long_v9(src, dst);
|
|
||||||
} else {
|
|
||||||
_Atomic_move_long_v8(src, dst);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
inline jlong Atomic::load(volatile jlong* src) {
|
inline jlong Atomic::load(volatile jlong* src) {
|
||||||
|
@ -209,7 +198,6 @@ inline jlong Atomic::cmpxchg (jlong exchange_value, volatile jlong*
|
||||||
: "memory");
|
: "memory");
|
||||||
return rv;
|
return rv;
|
||||||
#else //_LP64
|
#else //_LP64
|
||||||
assert(VM_Version::v9_instructions_work(), "cas only supported on v9");
|
|
||||||
volatile jlong_accessor evl, cvl, rv;
|
volatile jlong_accessor evl, cvl, rv;
|
||||||
evl.long_value = exchange_value;
|
evl.long_value = exchange_value;
|
||||||
cvl.long_value = compare_value;
|
cvl.long_value = compare_value;
|
||||||
|
@ -318,7 +306,6 @@ inline jlong Atomic::cmpxchg (jlong exchange_value, volatile jlong*
|
||||||
// Return 64 bit value in %o0
|
// Return 64 bit value in %o0
|
||||||
return _Atomic_cas64((intptr_t)exchange_value, (intptr_t *)dest, (intptr_t)compare_value);
|
return _Atomic_cas64((intptr_t)exchange_value, (intptr_t *)dest, (intptr_t)compare_value);
|
||||||
#else // _LP64
|
#else // _LP64
|
||||||
assert (VM_Version::v9_instructions_work(), "only supported on v9");
|
|
||||||
// Return 64 bit value in %o0,%o1 by hand
|
// Return 64 bit value in %o0,%o1 by hand
|
||||||
return _Atomic_casl(exchange_value, dest, compare_value);
|
return _Atomic_casl(exchange_value, dest, compare_value);
|
||||||
#endif // _LP64
|
#endif // _LP64
|
||||||
|
|
|
@ -152,23 +152,6 @@
|
||||||
.nonvolatile
|
.nonvolatile
|
||||||
.end
|
.end
|
||||||
|
|
||||||
// Support for jlong Atomic::load and Atomic::store on v8.
|
|
||||||
//
|
|
||||||
// void _Atomic_move_long_v8(volatile jlong* src, volatile jlong* dst)
|
|
||||||
//
|
|
||||||
// Arguments:
|
|
||||||
// src: O0
|
|
||||||
// dest: O1
|
|
||||||
//
|
|
||||||
// Overwrites O2 and O3
|
|
||||||
|
|
||||||
.inline _Atomic_move_long_v8,2
|
|
||||||
.volatile
|
|
||||||
ldd [%o0], %o2
|
|
||||||
std %o2, [%o1]
|
|
||||||
.nonvolatile
|
|
||||||
.end
|
|
||||||
|
|
||||||
// Support for jlong Atomic::load and Atomic::store on v9.
|
// Support for jlong Atomic::load and Atomic::store on v9.
|
||||||
//
|
//
|
||||||
// void _Atomic_move_long_v9(volatile jlong* src, volatile jlong* dst)
|
// void _Atomic_move_long_v9(volatile jlong* src, volatile jlong* dst)
|
||||||
|
|
|
@ -235,6 +235,9 @@ bool InstructForm::is_parm(FormDict &globals) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool InstructForm::is_ideal_negD() const {
|
||||||
|
return (_matrule && _matrule->_rChild && strcmp(_matrule->_rChild->_opType, "NegD") == 0);
|
||||||
|
}
|
||||||
|
|
||||||
// Return 'true' if this instruction matches an ideal 'Copy*' node
|
// Return 'true' if this instruction matches an ideal 'Copy*' node
|
||||||
int InstructForm::is_ideal_copy() const {
|
int InstructForm::is_ideal_copy() const {
|
||||||
|
@ -533,6 +536,12 @@ bool InstructForm::rematerialize(FormDict &globals, RegisterForm *registers ) {
|
||||||
if( data_type != Form::none )
|
if( data_type != Form::none )
|
||||||
rematerialize = true;
|
rematerialize = true;
|
||||||
|
|
||||||
|
// Ugly: until a better fix is implemented, disable rematerialization for
|
||||||
|
// negD nodes because they are proved to be problematic.
|
||||||
|
if (is_ideal_negD()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
// Constants
|
// Constants
|
||||||
if( _components.count() == 1 && _components[0]->is(Component::USE_DEF) )
|
if( _components.count() == 1 && _components[0]->is(Component::USE_DEF) )
|
||||||
rematerialize = true;
|
rematerialize = true;
|
||||||
|
|
|
@ -147,6 +147,7 @@ public:
|
||||||
virtual int is_empty_encoding() const; // _size=0 and/or _insencode empty
|
virtual int is_empty_encoding() const; // _size=0 and/or _insencode empty
|
||||||
virtual int is_tls_instruction() const; // tlsLoadP rule or ideal ThreadLocal
|
virtual int is_tls_instruction() const; // tlsLoadP rule or ideal ThreadLocal
|
||||||
virtual int is_ideal_copy() const; // node matches ideal 'Copy*'
|
virtual int is_ideal_copy() const; // node matches ideal 'Copy*'
|
||||||
|
virtual bool is_ideal_negD() const; // node matches ideal 'NegD'
|
||||||
virtual bool is_ideal_if() const; // node matches ideal 'If'
|
virtual bool is_ideal_if() const; // node matches ideal 'If'
|
||||||
virtual bool is_ideal_fastlock() const; // node matches 'FastLock'
|
virtual bool is_ideal_fastlock() const; // node matches 'FastLock'
|
||||||
virtual bool is_ideal_membar() const; // node matches ideal 'MemBarXXX'
|
virtual bool is_ideal_membar() const; // node matches ideal 'MemBarXXX'
|
||||||
|
|
|
@ -201,23 +201,24 @@ void LIR_OprDesc::validate_type() const {
|
||||||
|
|
||||||
#ifdef ASSERT
|
#ifdef ASSERT
|
||||||
if (!is_pointer() && !is_illegal()) {
|
if (!is_pointer() && !is_illegal()) {
|
||||||
|
OprKind kindfield = kind_field(); // Factored out because of compiler bug, see 8002160
|
||||||
switch (as_BasicType(type_field())) {
|
switch (as_BasicType(type_field())) {
|
||||||
case T_LONG:
|
case T_LONG:
|
||||||
assert((kind_field() == cpu_register || kind_field() == stack_value) &&
|
assert((kindfield == cpu_register || kindfield == stack_value) &&
|
||||||
size_field() == double_size, "must match");
|
size_field() == double_size, "must match");
|
||||||
break;
|
break;
|
||||||
case T_FLOAT:
|
case T_FLOAT:
|
||||||
// FP return values can be also in CPU registers on ARM and PPC (softfp ABI)
|
// FP return values can be also in CPU registers on ARM and PPC (softfp ABI)
|
||||||
assert((kind_field() == fpu_register || kind_field() == stack_value
|
assert((kindfield == fpu_register || kindfield == stack_value
|
||||||
ARM_ONLY(|| kind_field() == cpu_register)
|
ARM_ONLY(|| kindfield == cpu_register)
|
||||||
PPC_ONLY(|| kind_field() == cpu_register) ) &&
|
PPC_ONLY(|| kindfield == cpu_register) ) &&
|
||||||
size_field() == single_size, "must match");
|
size_field() == single_size, "must match");
|
||||||
break;
|
break;
|
||||||
case T_DOUBLE:
|
case T_DOUBLE:
|
||||||
// FP return values can be also in CPU registers on ARM and PPC (softfp ABI)
|
// FP return values can be also in CPU registers on ARM and PPC (softfp ABI)
|
||||||
assert((kind_field() == fpu_register || kind_field() == stack_value
|
assert((kindfield == fpu_register || kindfield == stack_value
|
||||||
ARM_ONLY(|| kind_field() == cpu_register)
|
ARM_ONLY(|| kindfield == cpu_register)
|
||||||
PPC_ONLY(|| kind_field() == cpu_register) ) &&
|
PPC_ONLY(|| kindfield == cpu_register) ) &&
|
||||||
size_field() == double_size, "must match");
|
size_field() == double_size, "must match");
|
||||||
break;
|
break;
|
||||||
case T_BOOLEAN:
|
case T_BOOLEAN:
|
||||||
|
@ -229,7 +230,7 @@ void LIR_OprDesc::validate_type() const {
|
||||||
case T_OBJECT:
|
case T_OBJECT:
|
||||||
case T_METADATA:
|
case T_METADATA:
|
||||||
case T_ARRAY:
|
case T_ARRAY:
|
||||||
assert((kind_field() == cpu_register || kind_field() == stack_value) &&
|
assert((kindfield == cpu_register || kindfield == stack_value) &&
|
||||||
size_field() == single_size, "must match");
|
size_field() == single_size, "must match");
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
|
|
@ -598,6 +598,8 @@ StringTable* StringTable::_the_table = NULL;
|
||||||
|
|
||||||
bool StringTable::_needs_rehashing = false;
|
bool StringTable::_needs_rehashing = false;
|
||||||
|
|
||||||
|
volatile int StringTable::_parallel_claimed_idx = 0;
|
||||||
|
|
||||||
// Pick hashing algorithm
|
// Pick hashing algorithm
|
||||||
unsigned int StringTable::hash_string(const jchar* s, int len) {
|
unsigned int StringTable::hash_string(const jchar* s, int len) {
|
||||||
return use_alternate_hashcode() ? AltHashing::murmur3_32(seed(), s, len) :
|
return use_alternate_hashcode() ? AltHashing::murmur3_32(seed(), s, len) :
|
||||||
|
@ -761,8 +763,18 @@ void StringTable::unlink_or_oops_do(BoolObjectClosure* is_alive, OopClosure* f)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void StringTable::oops_do(OopClosure* f) {
|
void StringTable::buckets_do(OopClosure* f, int start_idx, int end_idx) {
|
||||||
for (int i = 0; i < the_table()->table_size(); ++i) {
|
const int limit = the_table()->table_size();
|
||||||
|
|
||||||
|
assert(0 <= start_idx && start_idx <= limit,
|
||||||
|
err_msg("start_idx (" INT32_FORMAT ") oob?", start_idx));
|
||||||
|
assert(0 <= end_idx && end_idx <= limit,
|
||||||
|
err_msg("end_idx (" INT32_FORMAT ") oob?", end_idx));
|
||||||
|
assert(start_idx <= end_idx,
|
||||||
|
err_msg("Ordering: start_idx=" INT32_FORMAT", end_idx=" INT32_FORMAT,
|
||||||
|
start_idx, end_idx));
|
||||||
|
|
||||||
|
for (int i = start_idx; i < end_idx; i += 1) {
|
||||||
HashtableEntry<oop, mtSymbol>* entry = the_table()->bucket(i);
|
HashtableEntry<oop, mtSymbol>* entry = the_table()->bucket(i);
|
||||||
while (entry != NULL) {
|
while (entry != NULL) {
|
||||||
assert(!entry->is_shared(), "CDS not used for the StringTable");
|
assert(!entry->is_shared(), "CDS not used for the StringTable");
|
||||||
|
@ -774,6 +786,27 @@ void StringTable::oops_do(OopClosure* f) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void StringTable::oops_do(OopClosure* f) {
|
||||||
|
buckets_do(f, 0, the_table()->table_size());
|
||||||
|
}
|
||||||
|
|
||||||
|
void StringTable::possibly_parallel_oops_do(OopClosure* f) {
|
||||||
|
const int ClaimChunkSize = 32;
|
||||||
|
const int limit = the_table()->table_size();
|
||||||
|
|
||||||
|
for (;;) {
|
||||||
|
// Grab next set of buckets to scan
|
||||||
|
int start_idx = Atomic::add(ClaimChunkSize, &_parallel_claimed_idx) - ClaimChunkSize;
|
||||||
|
if (start_idx >= limit) {
|
||||||
|
// End of table
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
int end_idx = MIN2(limit, start_idx + ClaimChunkSize);
|
||||||
|
buckets_do(f, start_idx, end_idx);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void StringTable::verify() {
|
void StringTable::verify() {
|
||||||
for (int i = 0; i < the_table()->table_size(); ++i) {
|
for (int i = 0; i < the_table()->table_size(); ++i) {
|
||||||
HashtableEntry<oop, mtSymbol>* p = the_table()->bucket(i);
|
HashtableEntry<oop, mtSymbol>* p = the_table()->bucket(i);
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2013, 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
|
||||||
|
@ -246,12 +246,19 @@ private:
|
||||||
// Set if one bucket is out of balance due to hash algorithm deficiency
|
// Set if one bucket is out of balance due to hash algorithm deficiency
|
||||||
static bool _needs_rehashing;
|
static bool _needs_rehashing;
|
||||||
|
|
||||||
|
// Claimed high water mark for parallel chunked scanning
|
||||||
|
static volatile int _parallel_claimed_idx;
|
||||||
|
|
||||||
static oop intern(Handle string_or_null, jchar* chars, int length, TRAPS);
|
static oop intern(Handle string_or_null, jchar* chars, int length, TRAPS);
|
||||||
oop basic_add(int index, Handle string_or_null, jchar* name, int len,
|
oop basic_add(int index, Handle string_or_null, jchar* name, int len,
|
||||||
unsigned int hashValue, TRAPS);
|
unsigned int hashValue, TRAPS);
|
||||||
|
|
||||||
oop lookup(int index, jchar* chars, int length, unsigned int hashValue);
|
oop lookup(int index, jchar* chars, int length, unsigned int hashValue);
|
||||||
|
|
||||||
|
// Apply the give oop closure to the entries to the buckets
|
||||||
|
// in the range [start_idx, end_idx).
|
||||||
|
static void buckets_do(OopClosure* f, int start_idx, int end_idx);
|
||||||
|
|
||||||
StringTable() : Hashtable<oop, mtSymbol>((int)StringTableSize,
|
StringTable() : Hashtable<oop, mtSymbol>((int)StringTableSize,
|
||||||
sizeof (HashtableEntry<oop, mtSymbol>)) {}
|
sizeof (HashtableEntry<oop, mtSymbol>)) {}
|
||||||
|
|
||||||
|
@ -277,9 +284,12 @@ public:
|
||||||
unlink_or_oops_do(cl, NULL);
|
unlink_or_oops_do(cl, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Invoke "f->do_oop" on the locations of all oops in the table.
|
// Serially invoke "f->do_oop" on the locations of all oops in the table.
|
||||||
static void oops_do(OopClosure* f);
|
static void oops_do(OopClosure* f);
|
||||||
|
|
||||||
|
// Possibly parallel version of the above
|
||||||
|
static void possibly_parallel_oops_do(OopClosure* f);
|
||||||
|
|
||||||
// Hashing algorithm, used as the hash value used by the
|
// Hashing algorithm, used as the hash value used by the
|
||||||
// StringTable for bucket selection and comparison (stored in the
|
// StringTable for bucket selection and comparison (stored in the
|
||||||
// HashtableEntry structures). This is used in the String.intern() method.
|
// HashtableEntry structures). This is used in the String.intern() method.
|
||||||
|
@ -315,5 +325,8 @@ public:
|
||||||
// Rehash the symbol table if it gets out of balance
|
// Rehash the symbol table if it gets out of balance
|
||||||
static void rehash_table();
|
static void rehash_table();
|
||||||
static bool needs_rehashing() { return _needs_rehashing; }
|
static bool needs_rehashing() { return _needs_rehashing; }
|
||||||
|
|
||||||
|
// Parallel chunked scanning
|
||||||
|
static void clear_parallel_claimed_index() { _parallel_claimed_idx = 0; }
|
||||||
};
|
};
|
||||||
#endif // SHARE_VM_CLASSFILE_SYMBOLTABLE_HPP
|
#endif // SHARE_VM_CLASSFILE_SYMBOLTABLE_HPP
|
||||||
|
|
|
@ -1250,14 +1250,13 @@ uint PSAdaptiveSizePolicy::compute_survivor_space_size_and_threshold(
|
||||||
avg_promoted()->deviation());
|
avg_promoted()->deviation());
|
||||||
}
|
}
|
||||||
|
|
||||||
gclog_or_tty->print( " avg_promoted_padded_avg: %f"
|
gclog_or_tty->print_cr( " avg_promoted_padded_avg: %f"
|
||||||
" avg_pretenured_padded_avg: %f"
|
" avg_pretenured_padded_avg: %f"
|
||||||
" tenuring_thresh: %d"
|
" tenuring_thresh: %d"
|
||||||
" target_size: " SIZE_FORMAT,
|
" target_size: " SIZE_FORMAT,
|
||||||
avg_promoted()->padded_average(),
|
avg_promoted()->padded_average(),
|
||||||
_avg_pretenured->padded_average(),
|
_avg_pretenured->padded_average(),
|
||||||
tenuring_threshold, target_size);
|
tenuring_threshold, target_size);
|
||||||
tty->cr();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
set_survivor_size(target_size);
|
set_survivor_size(target_size);
|
||||||
|
@ -1279,7 +1278,7 @@ void PSAdaptiveSizePolicy::update_averages(bool is_survivor_overflow,
|
||||||
avg_promoted()->sample(promoted + _avg_pretenured->padded_average());
|
avg_promoted()->sample(promoted + _avg_pretenured->padded_average());
|
||||||
|
|
||||||
if (PrintAdaptiveSizePolicy) {
|
if (PrintAdaptiveSizePolicy) {
|
||||||
gclog_or_tty->print(
|
gclog_or_tty->print_cr(
|
||||||
"AdaptiveSizePolicy::update_averages:"
|
"AdaptiveSizePolicy::update_averages:"
|
||||||
" survived: " SIZE_FORMAT
|
" survived: " SIZE_FORMAT
|
||||||
" promoted: " SIZE_FORMAT
|
" promoted: " SIZE_FORMAT
|
||||||
|
|
|
@ -732,13 +732,21 @@ public:
|
||||||
// is set so that we always use malloc except for Solaris where we set the
|
// is set so that we always use malloc except for Solaris where we set the
|
||||||
// limit to get mapped memory.
|
// limit to get mapped memory.
|
||||||
template <class E, MEMFLAGS F>
|
template <class E, MEMFLAGS F>
|
||||||
class ArrayAllocator : StackObj {
|
class ArrayAllocator VALUE_OBJ_CLASS_SPEC {
|
||||||
char* _addr;
|
char* _addr;
|
||||||
bool _use_malloc;
|
bool _use_malloc;
|
||||||
size_t _size;
|
size_t _size;
|
||||||
|
bool _free_in_destructor;
|
||||||
public:
|
public:
|
||||||
ArrayAllocator() : _addr(NULL), _use_malloc(false), _size(0) { }
|
ArrayAllocator(bool free_in_destructor = true) :
|
||||||
~ArrayAllocator() { free(); }
|
_addr(NULL), _use_malloc(false), _size(0), _free_in_destructor(free_in_destructor) { }
|
||||||
|
|
||||||
|
~ArrayAllocator() {
|
||||||
|
if (_free_in_destructor) {
|
||||||
|
free();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
E* allocate(size_t length);
|
E* allocate(size_t length);
|
||||||
void free();
|
void free();
|
||||||
};
|
};
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2000, 2013, 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
|
||||||
|
@ -47,7 +47,6 @@ enum SH_process_strong_roots_tasks {
|
||||||
SH_PS_SystemDictionary_oops_do,
|
SH_PS_SystemDictionary_oops_do,
|
||||||
SH_PS_ClassLoaderDataGraph_oops_do,
|
SH_PS_ClassLoaderDataGraph_oops_do,
|
||||||
SH_PS_jvmti_oops_do,
|
SH_PS_jvmti_oops_do,
|
||||||
SH_PS_StringTable_oops_do,
|
|
||||||
SH_PS_CodeCache_oops_do,
|
SH_PS_CodeCache_oops_do,
|
||||||
// Leave this one last.
|
// Leave this one last.
|
||||||
SH_PS_NumElements
|
SH_PS_NumElements
|
||||||
|
@ -127,6 +126,8 @@ SharedHeap::StrongRootsScope::StrongRootsScope(SharedHeap* outer, bool activate)
|
||||||
{
|
{
|
||||||
if (_active) {
|
if (_active) {
|
||||||
outer->change_strong_roots_parity();
|
outer->change_strong_roots_parity();
|
||||||
|
// Zero the claimed high water mark in the StringTable
|
||||||
|
StringTable::clear_parallel_claimed_index();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -154,14 +155,16 @@ void SharedHeap::process_strong_roots(bool activate_scope,
|
||||||
// Global (strong) JNI handles
|
// Global (strong) JNI handles
|
||||||
if (!_process_strong_tasks->is_task_claimed(SH_PS_JNIHandles_oops_do))
|
if (!_process_strong_tasks->is_task_claimed(SH_PS_JNIHandles_oops_do))
|
||||||
JNIHandles::oops_do(roots);
|
JNIHandles::oops_do(roots);
|
||||||
|
|
||||||
// All threads execute this; the individual threads are task groups.
|
// All threads execute this; the individual threads are task groups.
|
||||||
CLDToOopClosure roots_from_clds(roots);
|
CLDToOopClosure roots_from_clds(roots);
|
||||||
CLDToOopClosure* roots_from_clds_p = (is_scavenging ? NULL : &roots_from_clds);
|
CLDToOopClosure* roots_from_clds_p = (is_scavenging ? NULL : &roots_from_clds);
|
||||||
if (ParallelGCThreads > 0) {
|
if (CollectedHeap::use_parallel_gc_threads()) {
|
||||||
Threads::possibly_parallel_oops_do(roots, roots_from_clds_p ,code_roots);
|
Threads::possibly_parallel_oops_do(roots, roots_from_clds_p, code_roots);
|
||||||
} else {
|
} else {
|
||||||
Threads::oops_do(roots, roots_from_clds_p, code_roots);
|
Threads::oops_do(roots, roots_from_clds_p, code_roots);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!_process_strong_tasks-> is_task_claimed(SH_PS_ObjectSynchronizer_oops_do))
|
if (!_process_strong_tasks-> is_task_claimed(SH_PS_ObjectSynchronizer_oops_do))
|
||||||
ObjectSynchronizer::oops_do(roots);
|
ObjectSynchronizer::oops_do(roots);
|
||||||
if (!_process_strong_tasks->is_task_claimed(SH_PS_FlatProfiler_oops_do))
|
if (!_process_strong_tasks->is_task_claimed(SH_PS_FlatProfiler_oops_do))
|
||||||
|
@ -189,8 +192,12 @@ void SharedHeap::process_strong_roots(bool activate_scope,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!_process_strong_tasks->is_task_claimed(SH_PS_StringTable_oops_do)) {
|
// All threads execute the following. A specific chunk of buckets
|
||||||
if (so & SO_Strings) {
|
// from the StringTable are the individual tasks.
|
||||||
|
if (so & SO_Strings) {
|
||||||
|
if (CollectedHeap::use_parallel_gc_threads()) {
|
||||||
|
StringTable::possibly_parallel_oops_do(roots);
|
||||||
|
} else {
|
||||||
StringTable::oops_do(roots);
|
StringTable::oops_do(roots);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2000, 2013, 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
|
||||||
|
@ -406,10 +406,10 @@
|
||||||
develop(intx, WarmCallMaxSize, 999999, \
|
develop(intx, WarmCallMaxSize, 999999, \
|
||||||
"size of the largest inlinable method") \
|
"size of the largest inlinable method") \
|
||||||
\
|
\
|
||||||
product(intx, MaxNodeLimit, 65000, \
|
product(intx, MaxNodeLimit, 80000, \
|
||||||
"Maximum number of nodes") \
|
"Maximum number of nodes") \
|
||||||
\
|
\
|
||||||
product(intx, NodeLimitFudgeFactor, 1000, \
|
product(intx, NodeLimitFudgeFactor, 2000, \
|
||||||
"Fudge Factor for certain optimizations") \
|
"Fudge Factor for certain optimizations") \
|
||||||
\
|
\
|
||||||
product(bool, UseJumpTables, true, \
|
product(bool, UseJumpTables, true, \
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2000, 2013, 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
|
||||||
|
@ -435,6 +435,9 @@ void PhaseChaitin::Register_Allocate() {
|
||||||
// Insert un-coalesced copies. Visit all Phis. Where inputs to a Phi do
|
// Insert un-coalesced copies. Visit all Phis. Where inputs to a Phi do
|
||||||
// not match the Phi itself, insert a copy.
|
// not match the Phi itself, insert a copy.
|
||||||
coalesce.insert_copies(_matcher);
|
coalesce.insert_copies(_matcher);
|
||||||
|
if (C->failing()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// After aggressive coalesce, attempt a first cut at coloring.
|
// After aggressive coalesce, attempt a first cut at coloring.
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2010, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2013, 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
|
||||||
|
@ -240,6 +240,8 @@ void PhaseAggressiveCoalesce::insert_copies( Matcher &matcher ) {
|
||||||
_unique = C->unique();
|
_unique = C->unique();
|
||||||
|
|
||||||
for( uint i=0; i<_phc._cfg._num_blocks; i++ ) {
|
for( uint i=0; i<_phc._cfg._num_blocks; i++ ) {
|
||||||
|
C->check_node_count(NodeLimitFudgeFactor, "out of nodes in coalesce");
|
||||||
|
if (C->failing()) return;
|
||||||
Block *b = _phc._cfg._blocks[i];
|
Block *b = _phc._cfg._blocks[i];
|
||||||
uint cnt = b->num_preds(); // Number of inputs to the Phi
|
uint cnt = b->num_preds(); // Number of inputs to the Phi
|
||||||
|
|
||||||
|
|
|
@ -985,6 +985,8 @@ Node *Matcher::xform( Node *n, int max_stack ) {
|
||||||
mstack.push(n, Visit, NULL, -1); // set NULL as parent to indicate root
|
mstack.push(n, Visit, NULL, -1); // set NULL as parent to indicate root
|
||||||
|
|
||||||
while (mstack.is_nonempty()) {
|
while (mstack.is_nonempty()) {
|
||||||
|
C->check_node_count(NodeLimitFudgeFactor, "too many nodes matching instructions");
|
||||||
|
if (C->failing()) return NULL;
|
||||||
n = mstack.node(); // Leave node on stack
|
n = mstack.node(); // Leave node on stack
|
||||||
Node_State nstate = mstack.state();
|
Node_State nstate = mstack.state();
|
||||||
if (nstate == Visit) {
|
if (nstate == Visit) {
|
||||||
|
|
|
@ -2930,7 +2930,9 @@ MemBarNode* MemBarNode::make(Compile* C, int opcode, int atp, Node* pn) {
|
||||||
Node *MemBarNode::Ideal(PhaseGVN *phase, bool can_reshape) {
|
Node *MemBarNode::Ideal(PhaseGVN *phase, bool can_reshape) {
|
||||||
if (remove_dead_region(phase, can_reshape)) return this;
|
if (remove_dead_region(phase, can_reshape)) return this;
|
||||||
// Don't bother trying to transform a dead node
|
// Don't bother trying to transform a dead node
|
||||||
if (in(0) && in(0)->is_top()) return NULL;
|
if (in(0) && in(0)->is_top()) {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
// Eliminate volatile MemBars for scalar replaced objects.
|
// Eliminate volatile MemBars for scalar replaced objects.
|
||||||
if (can_reshape && req() == (Precedent+1)) {
|
if (can_reshape && req() == (Precedent+1)) {
|
||||||
|
@ -2939,6 +2941,14 @@ Node *MemBarNode::Ideal(PhaseGVN *phase, bool can_reshape) {
|
||||||
if ((opc == Op_MemBarAcquire || opc == Op_MemBarVolatile)) {
|
if ((opc == Op_MemBarAcquire || opc == Op_MemBarVolatile)) {
|
||||||
// Volatile field loads and stores.
|
// Volatile field loads and stores.
|
||||||
Node* my_mem = in(MemBarNode::Precedent);
|
Node* my_mem = in(MemBarNode::Precedent);
|
||||||
|
// The MembarAquire may keep an unused LoadNode alive through the Precedent edge
|
||||||
|
if ((my_mem != NULL) && (opc == Op_MemBarAcquire) && (my_mem->outcnt() == 1)) {
|
||||||
|
assert(my_mem->unique_out() == this, "sanity");
|
||||||
|
phase->hash_delete(this);
|
||||||
|
del_req(Precedent);
|
||||||
|
phase->is_IterGVN()->_worklist.push(my_mem); // remove dead node later
|
||||||
|
my_mem = NULL;
|
||||||
|
}
|
||||||
if (my_mem != NULL && my_mem->is_Mem()) {
|
if (my_mem != NULL && my_mem->is_Mem()) {
|
||||||
const TypeOopPtr* t_oop = my_mem->in(MemNode::Address)->bottom_type()->isa_oopptr();
|
const TypeOopPtr* t_oop = my_mem->in(MemNode::Address)->bottom_type()->isa_oopptr();
|
||||||
// Check for scalar replaced object reference.
|
// Check for scalar replaced object reference.
|
||||||
|
|
|
@ -3241,24 +3241,10 @@ JVM_ENTRY(jobject, JVM_CurrentClassLoader(JNIEnv *env))
|
||||||
JVM_END
|
JVM_END
|
||||||
|
|
||||||
|
|
||||||
// Utility object for collecting method holders walking down the stack
|
|
||||||
class KlassLink: public ResourceObj {
|
|
||||||
public:
|
|
||||||
KlassHandle klass;
|
|
||||||
KlassLink* next;
|
|
||||||
|
|
||||||
KlassLink(KlassHandle k) { klass = k; next = NULL; }
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
JVM_ENTRY(jobjectArray, JVM_GetClassContext(JNIEnv *env))
|
JVM_ENTRY(jobjectArray, JVM_GetClassContext(JNIEnv *env))
|
||||||
JVMWrapper("JVM_GetClassContext");
|
JVMWrapper("JVM_GetClassContext");
|
||||||
ResourceMark rm(THREAD);
|
ResourceMark rm(THREAD);
|
||||||
JvmtiVMObjectAllocEventCollector oam;
|
JvmtiVMObjectAllocEventCollector oam;
|
||||||
// Collect linked list of (handles to) method holders
|
|
||||||
KlassLink* first = NULL;
|
|
||||||
KlassLink* last = NULL;
|
|
||||||
int depth = 0;
|
|
||||||
vframeStream vfst(thread);
|
vframeStream vfst(thread);
|
||||||
|
|
||||||
if (SystemDictionary::reflect_CallerSensitive_klass() != NULL) {
|
if (SystemDictionary::reflect_CallerSensitive_klass() != NULL) {
|
||||||
|
@ -3272,32 +3258,23 @@ JVM_ENTRY(jobjectArray, JVM_GetClassContext(JNIEnv *env))
|
||||||
}
|
}
|
||||||
|
|
||||||
// Collect method holders
|
// Collect method holders
|
||||||
|
GrowableArray<KlassHandle>* klass_array = new GrowableArray<KlassHandle>();
|
||||||
for (; !vfst.at_end(); vfst.security_next()) {
|
for (; !vfst.at_end(); vfst.security_next()) {
|
||||||
Method* m = vfst.method();
|
Method* m = vfst.method();
|
||||||
// Native frames are not returned
|
// Native frames are not returned
|
||||||
if (!m->is_ignored_by_security_stack_walk() && !m->is_native()) {
|
if (!m->is_ignored_by_security_stack_walk() && !m->is_native()) {
|
||||||
Klass* holder = m->method_holder();
|
Klass* holder = m->method_holder();
|
||||||
assert(holder->is_klass(), "just checking");
|
assert(holder->is_klass(), "just checking");
|
||||||
depth++;
|
klass_array->append(holder);
|
||||||
KlassLink* l = new KlassLink(KlassHandle(thread, holder));
|
|
||||||
if (first == NULL) {
|
|
||||||
first = last = l;
|
|
||||||
} else {
|
|
||||||
last->next = l;
|
|
||||||
last = l;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Create result array of type [Ljava/lang/Class;
|
// Create result array of type [Ljava/lang/Class;
|
||||||
objArrayOop result = oopFactory::new_objArray(SystemDictionary::Class_klass(), depth, CHECK_NULL);
|
objArrayOop result = oopFactory::new_objArray(SystemDictionary::Class_klass(), klass_array->length(), CHECK_NULL);
|
||||||
// Fill in mirrors corresponding to method holders
|
// Fill in mirrors corresponding to method holders
|
||||||
int index = 0;
|
for (int i = 0; i < klass_array->length(); i++) {
|
||||||
while (first != NULL) {
|
result->obj_at_put(i, klass_array->at(i)->java_mirror());
|
||||||
result->obj_at_put(index++, first->klass()->java_mirror());
|
|
||||||
first = first->next;
|
|
||||||
}
|
}
|
||||||
assert(index == depth, "just checking");
|
|
||||||
|
|
||||||
return (jobjectArray) JNIHandles::make_local(env, result);
|
return (jobjectArray) JNIHandles::make_local(env, result);
|
||||||
JVM_END
|
JVM_END
|
||||||
|
|
|
@ -1566,6 +1566,15 @@ julong Arguments::limit_by_allocatable_memory(julong limit) {
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Arguments::set_heap_base_min_address() {
|
||||||
|
if (FLAG_IS_DEFAULT(HeapBaseMinAddress) && UseG1GC && HeapBaseMinAddress < 1*G) {
|
||||||
|
// By default HeapBaseMinAddress is 2G on all platforms except Solaris x86.
|
||||||
|
// G1 currently needs a lot of C-heap, so on Solaris we have to give G1
|
||||||
|
// some extra space for the C-heap compared to other collectors.
|
||||||
|
FLAG_SET_ERGO(uintx, HeapBaseMinAddress, 1*G);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void Arguments::set_heap_size() {
|
void Arguments::set_heap_size() {
|
||||||
if (!FLAG_IS_DEFAULT(DefaultMaxRAMFraction)) {
|
if (!FLAG_IS_DEFAULT(DefaultMaxRAMFraction)) {
|
||||||
// Deprecated flag
|
// Deprecated flag
|
||||||
|
@ -1885,21 +1894,6 @@ bool Arguments::check_vm_args_consistency() {
|
||||||
// Note: Needs platform-dependent factoring.
|
// Note: Needs platform-dependent factoring.
|
||||||
bool status = true;
|
bool status = true;
|
||||||
|
|
||||||
#if ( (defined(COMPILER2) && defined(SPARC)))
|
|
||||||
// NOTE: The call to VM_Version_init depends on the fact that VM_Version_init
|
|
||||||
// on sparc doesn't require generation of a stub as is the case on, e.g.,
|
|
||||||
// x86. Normally, VM_Version_init must be called from init_globals in
|
|
||||||
// init.cpp, which is called by the initial java thread *after* arguments
|
|
||||||
// have been parsed. VM_Version_init gets called twice on sparc.
|
|
||||||
extern void VM_Version_init();
|
|
||||||
VM_Version_init();
|
|
||||||
if (!VM_Version::has_v9()) {
|
|
||||||
jio_fprintf(defaultStream::error_stream(),
|
|
||||||
"V8 Machine detected, Server requires V9\n");
|
|
||||||
status = false;
|
|
||||||
}
|
|
||||||
#endif /* COMPILER2 && SPARC */
|
|
||||||
|
|
||||||
// Allow both -XX:-UseStackBanging and -XX:-UseBoundThreads in non-product
|
// Allow both -XX:-UseStackBanging and -XX:-UseBoundThreads in non-product
|
||||||
// builds so the cost of stack banging can be measured.
|
// builds so the cost of stack banging can be measured.
|
||||||
#if (defined(PRODUCT) && defined(SOLARIS))
|
#if (defined(PRODUCT) && defined(SOLARIS))
|
||||||
|
@ -3525,6 +3519,8 @@ jint Arguments::parse(const JavaVMInitArgs* args) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
set_heap_base_min_address();
|
||||||
|
|
||||||
// Set heap size based on available physical memory
|
// Set heap size based on available physical memory
|
||||||
set_heap_size();
|
set_heap_size();
|
||||||
|
|
||||||
|
|
|
@ -315,6 +315,8 @@ class Arguments : AllStatic {
|
||||||
// limits the given memory size by the maximum amount of memory this process is
|
// limits the given memory size by the maximum amount of memory this process is
|
||||||
// currently allowed to allocate or reserve.
|
// currently allowed to allocate or reserve.
|
||||||
static julong limit_by_allocatable_memory(julong size);
|
static julong limit_by_allocatable_memory(julong size);
|
||||||
|
// Setup HeapBaseMinAddress
|
||||||
|
static void set_heap_base_min_address();
|
||||||
// Setup heap size
|
// Setup heap size
|
||||||
static void set_heap_size();
|
static void set_heap_size();
|
||||||
// Based on automatic selection criteria, should the
|
// Based on automatic selection criteria, should the
|
||||||
|
|
|
@ -41,7 +41,7 @@
|
||||||
|
|
||||||
|
|
||||||
BitMap::BitMap(bm_word_t* map, idx_t size_in_bits) :
|
BitMap::BitMap(bm_word_t* map, idx_t size_in_bits) :
|
||||||
_map(map), _size(size_in_bits)
|
_map(map), _size(size_in_bits), _map_allocator(false)
|
||||||
{
|
{
|
||||||
assert(sizeof(bm_word_t) == BytesPerWord, "Implementation assumption.");
|
assert(sizeof(bm_word_t) == BytesPerWord, "Implementation assumption.");
|
||||||
assert(size_in_bits >= 0, "just checking");
|
assert(size_in_bits >= 0, "just checking");
|
||||||
|
@ -49,7 +49,7 @@ BitMap::BitMap(bm_word_t* map, idx_t size_in_bits) :
|
||||||
|
|
||||||
|
|
||||||
BitMap::BitMap(idx_t size_in_bits, bool in_resource_area) :
|
BitMap::BitMap(idx_t size_in_bits, bool in_resource_area) :
|
||||||
_map(NULL), _size(0)
|
_map(NULL), _size(0), _map_allocator(false)
|
||||||
{
|
{
|
||||||
assert(sizeof(bm_word_t) == BytesPerWord, "Implementation assumption.");
|
assert(sizeof(bm_word_t) == BytesPerWord, "Implementation assumption.");
|
||||||
resize(size_in_bits, in_resource_area);
|
resize(size_in_bits, in_resource_area);
|
||||||
|
@ -65,8 +65,10 @@ void BitMap::resize(idx_t size_in_bits, bool in_resource_area) {
|
||||||
if (in_resource_area) {
|
if (in_resource_area) {
|
||||||
_map = NEW_RESOURCE_ARRAY(bm_word_t, new_size_in_words);
|
_map = NEW_RESOURCE_ARRAY(bm_word_t, new_size_in_words);
|
||||||
} else {
|
} else {
|
||||||
if (old_map != NULL) FREE_C_HEAP_ARRAY(bm_word_t, _map, mtInternal);
|
if (old_map != NULL) {
|
||||||
_map = NEW_C_HEAP_ARRAY(bm_word_t, new_size_in_words, mtInternal);
|
_map_allocator.free();
|
||||||
|
}
|
||||||
|
_map = _map_allocator.allocate(new_size_in_words);
|
||||||
}
|
}
|
||||||
Copy::disjoint_words((HeapWord*)old_map, (HeapWord*) _map,
|
Copy::disjoint_words((HeapWord*)old_map, (HeapWord*) _map,
|
||||||
MIN2(old_size_in_words, new_size_in_words));
|
MIN2(old_size_in_words, new_size_in_words));
|
||||||
|
|
|
@ -48,6 +48,7 @@ class BitMap VALUE_OBJ_CLASS_SPEC {
|
||||||
} RangeSizeHint;
|
} RangeSizeHint;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
ArrayAllocator<bm_word_t, mtInternal> _map_allocator;
|
||||||
bm_word_t* _map; // First word in bitmap
|
bm_word_t* _map; // First word in bitmap
|
||||||
idx_t _size; // Size of bitmap (in bits)
|
idx_t _size; // Size of bitmap (in bits)
|
||||||
|
|
||||||
|
@ -113,7 +114,7 @@ class BitMap VALUE_OBJ_CLASS_SPEC {
|
||||||
public:
|
public:
|
||||||
|
|
||||||
// Constructs a bitmap with no map, and size 0.
|
// Constructs a bitmap with no map, and size 0.
|
||||||
BitMap() : _map(NULL), _size(0) {}
|
BitMap() : _map(NULL), _size(0), _map_allocator(false) {}
|
||||||
|
|
||||||
// Constructs a bitmap with the given map and size.
|
// Constructs a bitmap with the given map and size.
|
||||||
BitMap(bm_word_t* map, idx_t size_in_bits);
|
BitMap(bm_word_t* map, idx_t size_in_bits);
|
||||||
|
|
|
@ -215,3 +215,4 @@ eddbc8ad2435a89f64729512337c9f2669e4dd85 jdk8-b87
|
||||||
e3065fb07877c7e96e8b93416fe2ab9a4c9eb2a5 jdk8-b91
|
e3065fb07877c7e96e8b93416fe2ab9a4c9eb2a5 jdk8-b91
|
||||||
1ab5d8d6eab81e65c6c3cf21739474cd67a0e7cf jdk8-b92
|
1ab5d8d6eab81e65c6c3cf21739474cd67a0e7cf jdk8-b92
|
||||||
d583a491d63c49eeda4869525048075da1cb596e jdk8-b93
|
d583a491d63c49eeda4869525048075da1cb596e jdk8-b93
|
||||||
|
c84658e1740df64931005a9bc4c8ecef38eb47c3 jdk8-b94
|
||||||
|
|
|
@ -215,3 +215,4 @@ a5e7c2f093c9996ab3419db1565094a07b059e9c jdk8-b86
|
||||||
0bb1a9fa56b037d072efdaae5f5b73a0f23c966c jdk8-b91
|
0bb1a9fa56b037d072efdaae5f5b73a0f23c966c jdk8-b91
|
||||||
a0f604766ca14818e2a7b1558cc399499caabf75 jdk8-b92
|
a0f604766ca14818e2a7b1558cc399499caabf75 jdk8-b92
|
||||||
7386eca865e1f7216637cdf8dcf3f5d5c255f208 jdk8-b93
|
7386eca865e1f7216637cdf8dcf3f5d5c255f208 jdk8-b93
|
||||||
|
254c53fd97ab24942043adcfa5c1a0a38a3b274e jdk8-b94
|
||||||
|
|
|
@ -215,3 +215,4 @@ c63eda8f63008a4398d2c22ac8d72f7fef6f9238 jdk8-b90
|
||||||
169451cf0cc53bde5af24f9820ea3f35ec4b4df4 jdk8-b91
|
169451cf0cc53bde5af24f9820ea3f35ec4b4df4 jdk8-b91
|
||||||
a2a2a91075ad85becbe10a39d7fd04ef9bea8df5 jdk8-b92
|
a2a2a91075ad85becbe10a39d7fd04ef9bea8df5 jdk8-b92
|
||||||
691d6c6cd332d98b0f0221445a73906776f31f72 jdk8-b93
|
691d6c6cd332d98b0f0221445a73906776f31f72 jdk8-b93
|
||||||
|
51479fa56b7c4363c6d87c2e8b898d8185cf4b22 jdk8-b94
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
#
|
#
|
||||||
# Copyright (c) 2011, 2012, Oracle and/or its affiliates. All rights reserved.
|
# Copyright (c) 2011, 2013, 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
|
||||||
|
@ -42,6 +42,11 @@ FILES_c = VMJFR.c
|
||||||
|
|
||||||
AUTO_FILES_JAVA_DIRS = com/oracle/jrockit/jfr oracle/jrockit/jfr
|
AUTO_FILES_JAVA_DIRS = com/oracle/jrockit/jfr oracle/jrockit/jfr
|
||||||
|
|
||||||
|
JFC_XSD = oracle/jrockit/jfr/settings/jfc.xsd
|
||||||
|
JFC_XSD_SRC = $(CLOSED_SHARE_SRC)/classes/$(JFC_XSD)
|
||||||
|
JFC_XSD_FILE = $(CLASSDESTDIR)/$(JFC_XSD)
|
||||||
|
|
||||||
|
|
||||||
# Find C source files
|
# Find C source files
|
||||||
#
|
#
|
||||||
vpath %.c $(CLOSED_SHARE_SRC)/native/oracle/jfr
|
vpath %.c $(CLOSED_SHARE_SRC)/native/oracle/jfr
|
||||||
|
@ -59,15 +64,17 @@ clean clobber::
|
||||||
$(RM) -r $(CLASSDESTDIR)/com/oracle/jrockit/jfr
|
$(RM) -r $(CLASSDESTDIR)/com/oracle/jrockit/jfr
|
||||||
$(RM) -r $(CLASSDESTDIR)/oracle/jrockit/jfr
|
$(RM) -r $(CLASSDESTDIR)/oracle/jrockit/jfr
|
||||||
|
|
||||||
|
# Copy pre-shipped .jfc files
|
||||||
# Copy pre-shipped .jfs files
|
|
||||||
JFR_LIBDIR = $(LIBDIR)/jfr
|
JFR_LIBDIR = $(LIBDIR)/jfr
|
||||||
JFR_SRCDIR = $(CLOSED_SHARE_SRC)/lib/jfr
|
JFC_SRCDIR = $(CLOSED_SHARE_SRC)/classes/oracle/jrockit/jfr/settings
|
||||||
|
|
||||||
$(JFR_LIBDIR)/%.jfs: $(JFR_SRCDIR)/%.jfs
|
$(JFR_LIBDIR)/%.jfc: $(JFC_SRCDIR)/%.jfc
|
||||||
$(install-file)
|
$(install-file)
|
||||||
|
|
||||||
JFS_FILES := $(subst $(JFR_SRCDIR),$(JFR_LIBDIR),$(wildcard $(JFR_SRCDIR)/*.jfs))
|
JFC_FILES := $(subst $(JFC_SRCDIR),$(JFR_LIBDIR),$(wildcard $(JFC_SRCDIR)/*.jfc))
|
||||||
|
|
||||||
all build : $(JFS_FILES)
|
$(JFC_XSD_FILE) : $(JFC_XSD_SRC)
|
||||||
|
$(install-file)
|
||||||
|
|
||||||
|
all build : $(JFC_FILES) $(JFC_XSD_FILE)
|
||||||
|
|
||||||
|
|
|
@ -2916,7 +2916,7 @@ $(eval $(call SetupNativeCompilation,BUILD_LIBJSOUNDALSA,\
|
||||||
PLATFORM_API_LinuxOS_ALSA_Ports.c,\
|
PLATFORM_API_LinuxOS_ALSA_Ports.c,\
|
||||||
LANG:=C,\
|
LANG:=C,\
|
||||||
OPTIMIZATION:=LOW, \
|
OPTIMIZATION:=LOW, \
|
||||||
CFLAGS:=$(CFLAGS_JDKLIB) \
|
CFLAGS:=$(CFLAGS_JDKLIB) $(ALSA_CFLAGS) \
|
||||||
$(LIBJSOUND_CFLAGS) \
|
$(LIBJSOUND_CFLAGS) \
|
||||||
-DUSE_DAUDIO=TRUE \
|
-DUSE_DAUDIO=TRUE \
|
||||||
-DUSE_PORTS=TRUE \
|
-DUSE_PORTS=TRUE \
|
||||||
|
@ -2925,7 +2925,7 @@ $(eval $(call SetupNativeCompilation,BUILD_LIBJSOUNDALSA,\
|
||||||
MAPFILE:=$(JDK_TOPDIR)/makefiles/mapfiles/libjsoundalsa/mapfile-vers, \
|
MAPFILE:=$(JDK_TOPDIR)/makefiles/mapfiles/libjsoundalsa/mapfile-vers, \
|
||||||
LDFLAGS:=$(LDFLAGS_JDKLIB)\
|
LDFLAGS:=$(LDFLAGS_JDKLIB)\
|
||||||
$(call SET_SHARED_LIBRARY_ORIGIN),\
|
$(call SET_SHARED_LIBRARY_ORIGIN),\
|
||||||
LDFLAGS_SUFFIX:=-lasound -ljava -ljvm,\
|
LDFLAGS_SUFFIX:=$(ALSA_LIBS) -ljava -ljvm,\
|
||||||
OBJECT_DIR:=$(JDK_OUTPUTDIR)/objs/libjsoundalsa,\
|
OBJECT_DIR:=$(JDK_OUTPUTDIR)/objs/libjsoundalsa,\
|
||||||
DEBUG_SYMBOLS:=$(DEBUG_ALL_BINARIES)))
|
DEBUG_SYMBOLS:=$(DEBUG_ALL_BINARIES)))
|
||||||
|
|
||||||
|
|
|
@ -537,3 +537,22 @@ $(JDK_OUTPUTDIR)/lib/sound.properties : $(JDK_TOPDIR)/src/share/lib/sound.proper
|
||||||
COPY_FILES += $(JDK_OUTPUTDIR)/lib/sound.properties
|
COPY_FILES += $(JDK_OUTPUTDIR)/lib/sound.properties
|
||||||
|
|
||||||
##########################################################################################
|
##########################################################################################
|
||||||
|
|
||||||
|
ifndef OPENJDK
|
||||||
|
ifeq ($(ENABLE_JFR), true)
|
||||||
|
|
||||||
|
JFR_CONFIGURATION_DIR_SRC := $(JDK_TOPDIR)/src/closed/share/classes/oracle/jrockit/jfr/settings/
|
||||||
|
JFR_CONFIGURATION_DIR_DST := $(LIBDIR)/jfr/
|
||||||
|
|
||||||
|
JFR_SRC_FILES = $(wildcard $(JFR_CONFIGURATION_DIR_SRC)/*.jfc)
|
||||||
|
JFR_TARGET_FILES = $(subst $(JFR_CONFIGURATION_DIR_SRC),$(JFR_CONFIGURATION_DIR_DST),$(JFR_SRC_FILES))
|
||||||
|
|
||||||
|
$(JFR_CONFIGURATION_DIR_DST)/%.jfc : $(JFR_CONFIGURATION_DIR_SRC)/%.jfc
|
||||||
|
$(call install-file)
|
||||||
|
|
||||||
|
COPY_FILES += $(JFR_TARGET_FILES)
|
||||||
|
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
|
##########################################################################################
|
||||||
|
|
|
@ -91,6 +91,12 @@ ifndef OPENJDK
|
||||||
$(SWING_PLAF_WINDOWS_RESOURCES_DIR_CLOSED)/icons/JavaCup32.png
|
$(SWING_PLAF_WINDOWS_RESOURCES_DIR_CLOSED)/icons/JavaCup32.png
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
ifndef OPENJDK
|
||||||
|
JFR_CONFIGURATION_DIR_CLOSED = $(JDK_TOPDIR)/src/closed/share/classes/oracle/jrockit/jfr/settings
|
||||||
|
COPY_FILES += \
|
||||||
|
$(JFR_CONFIGURATION_DIR_CLOSED)/jfc.xsd
|
||||||
|
endif
|
||||||
|
|
||||||
SWING_PLAF_BASIC_RESOURCES_DIR = $(JDK_TOPDIR)/src/share/classes/javax/swing/plaf/basic
|
SWING_PLAF_BASIC_RESOURCES_DIR = $(JDK_TOPDIR)/src/share/classes/javax/swing/plaf/basic
|
||||||
COPY_FILES += \
|
COPY_FILES += \
|
||||||
$(wildcard $(SWING_PLAF_BASIC_RESOURCES_DIR)/icons/*.png)
|
$(wildcard $(SWING_PLAF_BASIC_RESOURCES_DIR)/icons/*.png)
|
||||||
|
|
|
@ -426,6 +426,7 @@ ifndef OPENJDK
|
||||||
ifeq ($(ENABLE_JFR), true)
|
ifeq ($(ENABLE_JFR), true)
|
||||||
$(eval $(call SetupArchive,BUILD_JFR_JAR,,\
|
$(eval $(call SetupArchive,BUILD_JFR_JAR,,\
|
||||||
SRCS:=$(JDK_OUTPUTDIR)/classes,\
|
SRCS:=$(JDK_OUTPUTDIR)/classes,\
|
||||||
|
SUFFIXES:=.class .jfc .xsd,\
|
||||||
INCLUDES:=com/oracle/jrockit/jfr \
|
INCLUDES:=com/oracle/jrockit/jfr \
|
||||||
oracle/jrockit/jfr,\
|
oracle/jrockit/jfr,\
|
||||||
JAR:=$(IMAGES_OUTPUTDIR)/lib/jfr.jar,\
|
JAR:=$(IMAGES_OUTPUTDIR)/lib/jfr.jar,\
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
#
|
#
|
||||||
# Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved.
|
# Copyright (c) 2012, 2013, Oracle and/or its affiliates. All rights reserved.
|
||||||
# ORACLE PROPRIETARY/CONFIDENTIAL. Use is subject to license terms.
|
# ORACLE PROPRIETARY/CONFIDENTIAL. Use is subject to license terms.
|
||||||
#
|
#
|
||||||
|
|
||||||
|
@ -17,7 +17,7 @@ SUNWprivate_1.1 {
|
||||||
Java_oracle_jrockit_jfr_VMJFR_addConstPool;
|
Java_oracle_jrockit_jfr_VMJFR_addConstPool;
|
||||||
Java_oracle_jrockit_jfr_VMJFR_removeConstPool;
|
Java_oracle_jrockit_jfr_VMJFR_removeConstPool;
|
||||||
Java_oracle_jrockit_jfr_VMJFR_storeConstPool;
|
Java_oracle_jrockit_jfr_VMJFR_storeConstPool;
|
||||||
Java_oracle_jrockit_jfr_VMJFR_classID;
|
Java_oracle_jrockit_jfr_VMJFR_classID0;
|
||||||
Java_oracle_jrockit_jfr_VMJFR_stackTraceID;
|
Java_oracle_jrockit_jfr_VMJFR_stackTraceID;
|
||||||
Java_oracle_jrockit_jfr_VMJFR_threadID;
|
Java_oracle_jrockit_jfr_VMJFR_threadID;
|
||||||
Java_oracle_jrockit_jfr_VMJFR_rotate;
|
Java_oracle_jrockit_jfr_VMJFR_rotate;
|
||||||
|
@ -33,7 +33,8 @@ SUNWprivate_1.1 {
|
||||||
Java_oracle_jrockit_jfr_VMJFR_setPeriod;
|
Java_oracle_jrockit_jfr_VMJFR_setPeriod;
|
||||||
Java_oracle_jrockit_jfr_VMJFR_getPeriod;
|
Java_oracle_jrockit_jfr_VMJFR_getPeriod;
|
||||||
Java_oracle_jrockit_jfr_VMJFR_descriptors;
|
Java_oracle_jrockit_jfr_VMJFR_descriptors;
|
||||||
JNI_OnLoad;
|
Java_oracle_jrockit_jfr_VMJFR_redefineClass0;
|
||||||
|
JNI_OnLoad;
|
||||||
local:
|
local:
|
||||||
*;
|
*;
|
||||||
};
|
};
|
||||||
|
|
|
@ -36,6 +36,7 @@ SUNWprivate_1.1 {
|
||||||
JLI_ReportExceptionDescription;
|
JLI_ReportExceptionDescription;
|
||||||
JLI_GetStdArgs;
|
JLI_GetStdArgs;
|
||||||
JLI_GetStdArgc;
|
JLI_GetStdArgc;
|
||||||
|
|
||||||
local:
|
local:
|
||||||
*;
|
*;
|
||||||
};
|
};
|
||||||
|
|
|
@ -202,6 +202,7 @@ package.access=sun.,\
|
||||||
com.sun.org.glassfish.,\
|
com.sun.org.glassfish.,\
|
||||||
com.oracle.xmlns.internal.,\
|
com.oracle.xmlns.internal.,\
|
||||||
com.oracle.webservices.internal.,\
|
com.oracle.webservices.internal.,\
|
||||||
|
oracle.jrockit.jfr.,\
|
||||||
jdk.internal.,\
|
jdk.internal.,\
|
||||||
jdk.nashorn.internal.,\
|
jdk.nashorn.internal.,\
|
||||||
jdk.nashorn.tools.
|
jdk.nashorn.tools.
|
||||||
|
@ -243,6 +244,7 @@ package.definition=sun.,\
|
||||||
com.sun.org.glassfish.,\
|
com.sun.org.glassfish.,\
|
||||||
com.oracle.xmlns.internal.,\
|
com.oracle.xmlns.internal.,\
|
||||||
com.oracle.webservices.internal.,\
|
com.oracle.webservices.internal.,\
|
||||||
|
oracle.jrockit.jfr.,\
|
||||||
jdk.internal.,\
|
jdk.internal.,\
|
||||||
jdk.nashorn.internal.,\
|
jdk.nashorn.internal.,\
|
||||||
jdk.nashorn.tools.
|
jdk.nashorn.tools.
|
||||||
|
|
|
@ -206,7 +206,8 @@ package.access=sun.,\
|
||||||
jdk.internal.,\
|
jdk.internal.,\
|
||||||
jdk.nashorn.internal.,\
|
jdk.nashorn.internal.,\
|
||||||
jdk.nashorn.tools.,\
|
jdk.nashorn.tools.,\
|
||||||
apple.
|
apple.,\
|
||||||
|
oracle.jrockit.jfr.
|
||||||
|
|
||||||
#
|
#
|
||||||
# List of comma-separated packages that start with or equal this string
|
# List of comma-separated packages that start with or equal this string
|
||||||
|
@ -247,7 +248,8 @@ package.definition=sun.,\
|
||||||
jdk.internal.,\
|
jdk.internal.,\
|
||||||
jdk.nashorn.internal.,\
|
jdk.nashorn.internal.,\
|
||||||
jdk.nashorn.tools.,\
|
jdk.nashorn.tools.,\
|
||||||
apple.
|
apple.,\
|
||||||
|
oracle.jrockit.jfr.
|
||||||
|
|
||||||
#
|
#
|
||||||
# Determines whether this properties file can be appended to
|
# Determines whether this properties file can be appended to
|
||||||
|
|
|
@ -204,6 +204,7 @@ package.access=sun.,\
|
||||||
com.sun.org.glassfish.,\
|
com.sun.org.glassfish.,\
|
||||||
com.oracle.xmlns.internal.,\
|
com.oracle.xmlns.internal.,\
|
||||||
com.oracle.webservices.internal.,\
|
com.oracle.webservices.internal.,\
|
||||||
|
oracle.jrockit.jfr.,\
|
||||||
jdk.internal.,\
|
jdk.internal.,\
|
||||||
jdk.nashorn.internal.,\
|
jdk.nashorn.internal.,\
|
||||||
jdk.nashorn.tools.
|
jdk.nashorn.tools.
|
||||||
|
@ -244,6 +245,7 @@ package.definition=sun.,\
|
||||||
com.sun.org.glassfish.,\
|
com.sun.org.glassfish.,\
|
||||||
com.oracle.xmlns.internal.,\
|
com.oracle.xmlns.internal.,\
|
||||||
com.oracle.webservices.internal.,\
|
com.oracle.webservices.internal.,\
|
||||||
|
oracle.jrockit.jfr.,\
|
||||||
jdk.internal.,\
|
jdk.internal.,\
|
||||||
jdk.nashorn.internal.,\
|
jdk.nashorn.internal.,\
|
||||||
jdk.nashorn.tools.
|
jdk.nashorn.tools.
|
||||||
|
|
|
@ -203,6 +203,7 @@ package.access=sun.,\
|
||||||
com.sun.org.glassfish.,\
|
com.sun.org.glassfish.,\
|
||||||
com.oracle.xmlns.internal.,\
|
com.oracle.xmlns.internal.,\
|
||||||
com.oracle.webservices.internal.,\
|
com.oracle.webservices.internal.,\
|
||||||
|
oracle.jrockit.jfr.,\
|
||||||
jdk.internal.,\
|
jdk.internal.,\
|
||||||
jdk.nashorn.internal.,\
|
jdk.nashorn.internal.,\
|
||||||
jdk.nashorn.tools.,\
|
jdk.nashorn.tools.,\
|
||||||
|
@ -244,6 +245,7 @@ package.definition=sun.,\
|
||||||
com.sun.org.glassfish.,\
|
com.sun.org.glassfish.,\
|
||||||
com.oracle.xmlns.internal.,\
|
com.oracle.xmlns.internal.,\
|
||||||
com.oracle.webservices.internal.,\
|
com.oracle.webservices.internal.,\
|
||||||
|
oracle.jrockit.jfr.,\
|
||||||
jdk.internal.,\
|
jdk.internal.,\
|
||||||
jdk.nashorn.internal.,\
|
jdk.nashorn.internal.,\
|
||||||
jdk.nashorn.tools.,\
|
jdk.nashorn.tools.,\
|
||||||
|
|
|
@ -215,3 +215,4 @@ e19283cd30a43fca94d8f7639c73ef66db493b1e jdk8-b90
|
||||||
997c0fae2b12108959387862be54b78ca0ae3fca jdk8-b91
|
997c0fae2b12108959387862be54b78ca0ae3fca jdk8-b91
|
||||||
149890642a0ed5138a4f16fe08ddbfeb8f8a1cb4 jdk8-b92
|
149890642a0ed5138a4f16fe08ddbfeb8f8a1cb4 jdk8-b92
|
||||||
2c5a568ee36eb2d9471483b7a310c49ed545db55 jdk8-b93
|
2c5a568ee36eb2d9471483b7a310c49ed545db55 jdk8-b93
|
||||||
|
48c6e6ab7c815fd41d747f0218f8041c22f3a460 jdk8-b94
|
||||||
|
|
|
@ -203,3 +203,4 @@ e0378f0a50dafdcfb7b04f6401d320f89884baa1 jdk8-b85
|
||||||
6b9f4120380091b8b1751a825b9f84bf1be224fe jdk8-b91
|
6b9f4120380091b8b1751a825b9f84bf1be224fe jdk8-b91
|
||||||
dee23cce5235b594a96d3361b65eacc97bd5a583 jdk8-b92
|
dee23cce5235b594a96d3361b65eacc97bd5a583 jdk8-b92
|
||||||
ddbf41575a2bdb12ccb9f91e169018bf04073038 jdk8-b93
|
ddbf41575a2bdb12ccb9f91e169018bf04073038 jdk8-b93
|
||||||
|
d92b756bc73966f1bfd111f44f3216cea3bba129 jdk8-b94
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue