From 63f939636a5fe9871f5f9057c93ed5b1a9924265 Mon Sep 17 00:00:00 2001 From: Magnus Ihse Bursie Date: Fri, 21 Feb 2020 18:37:10 +0100 Subject: [PATCH] 8239708: Split basics.m4 into basic.m4 and util.m4 Reviewed-by: erikj --- make/autoconf/basic.m4 | 544 ++++++ make/autoconf/basic_tools.m4 | 475 +++++ make/autoconf/basic_windows.m4 | 183 ++ make/autoconf/basics.m4 | 1552 ----------------- make/autoconf/boot-jdk.m4 | 36 +- make/autoconf/build-performance.m4 | 10 +- make/autoconf/configure.ac | 5 +- make/autoconf/flags.m4 | 8 +- make/autoconf/hotspot.m4 | 6 +- make/autoconf/jdk-options.m4 | 6 +- make/autoconf/jvm-features.m4 | 36 +- make/autoconf/lib-tests.m4 | 4 +- make/autoconf/libraries.m4 | 2 +- make/autoconf/source-dirs.m4 | 2 +- make/autoconf/toolchain.m4 | 123 +- make/autoconf/toolchain_windows.m4 | 42 +- make/autoconf/util.m4 | 378 ++++ make/autoconf/util_paths.m4 | 232 +++ .../{basics_windows.m4 => util_windows.m4} | 222 +-- 19 files changed, 1984 insertions(+), 1882 deletions(-) create mode 100644 make/autoconf/basic.m4 create mode 100644 make/autoconf/basic_tools.m4 create mode 100644 make/autoconf/basic_windows.m4 delete mode 100644 make/autoconf/basics.m4 create mode 100644 make/autoconf/util.m4 create mode 100644 make/autoconf/util_paths.m4 rename make/autoconf/{basics_windows.m4 => util_windows.m4} (65%) diff --git a/make/autoconf/basic.m4 b/make/autoconf/basic.m4 new file mode 100644 index 00000000000..9536d99551f --- /dev/null +++ b/make/autoconf/basic.m4 @@ -0,0 +1,544 @@ +# +# Copyright (c) 2011, 2020, Oracle and/or its affiliates. All rights reserved. +# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. +# +# This code is free software; you can redistribute it and/or modify it +# under the terms of the GNU General Public License version 2 only, as +# published by the Free Software Foundation. Oracle designates this +# particular file as subject to the "Classpath" exception as provided +# by Oracle in the LICENSE file that accompanied this code. +# +# This code is distributed in the hope that it will be useful, but WITHOUT +# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or +# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License +# version 2 for more details (a copy is included in the LICENSE file that +# accompanied this code). +# +# You should have received a copy of the GNU General Public License version +# 2 along with this work; if not, write to the Free Software Foundation, +# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. +# +# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA +# or visit www.oracle.com if you need additional information or have any +# questions. +# + +m4_include([basic_tools.m4]) +m4_include([basic_windows.m4]) + +############################################################################### +AC_DEFUN_ONCE([BASIC_INIT], +[ + # Save the original command line. This is passed to us by the wrapper configure script. + AC_SUBST(CONFIGURE_COMMAND_LINE) + # AUTOCONF might be set in the environment by the user. Preserve for "make reconfigure". + AC_SUBST(AUTOCONF) + # Save the path variable before it gets changed + ORIGINAL_PATH="$PATH" + AC_SUBST(ORIGINAL_PATH) + DATE_WHEN_CONFIGURED=`date` + AC_SUBST(DATE_WHEN_CONFIGURED) + AC_MSG_NOTICE([Configuration created at $DATE_WHEN_CONFIGURED.]) +]) + +############################################################################### +# Check that there are no unprocessed overridden variables left. +# If so, they are an incorrect argument and we will exit with an error. +AC_DEFUN([BASIC_CHECK_LEFTOVER_OVERRIDDEN], +[ + if test "x$CONFIGURE_OVERRIDDEN_VARIABLES" != x; then + # Replace the separating ! with spaces before presenting for end user. + unknown_variables=${CONFIGURE_OVERRIDDEN_VARIABLES//!/ } + AC_MSG_WARN([The following variables might be unknown to configure: $unknown_variables]) + fi +]) + +############################################################################### +# Setup basic configuration paths, and platform-specific stuff related to PATHs. +AC_DEFUN_ONCE([BASIC_SETUP_PATHS], +[ + # Save the current directory this script was started from + CONFIGURE_START_DIR="$PWD" + + # We might need to rewrite ORIGINAL_PATH, if it includes "#", to quote them + # for make. We couldn't do this when we retrieved ORIGINAL_PATH, since SED + # was not available at that time. + REWRITTEN_PATH=`$ECHO "$ORIGINAL_PATH" | $SED -e 's/#/\\\\#/g'` + if test "x$REWRITTEN_PATH" != "x$ORIGINAL_PATH"; then + ORIGINAL_PATH="$REWRITTEN_PATH" + AC_MSG_NOTICE([Rewriting ORIGINAL_PATH to $REWRITTEN_PATH]) + fi + + if test "x$OPENJDK_TARGET_OS" = "xwindows"; then + PATH_SEP=";" + EXE_SUFFIX=".exe" + BASIC_CHECK_PATHS_WINDOWS + else + PATH_SEP=":" + EXE_SUFFIX="" + fi + AC_SUBST(PATH_SEP) + AC_SUBST(EXE_SUFFIX) + + # We get the top-level directory from the supporting wrappers. + AC_MSG_CHECKING([for top-level directory]) + AC_MSG_RESULT([$TOPDIR]) + AC_SUBST(TOPDIR) + AC_SUBST(CONFIGURE_START_DIR) + + # We can only call UTIL_FIXUP_PATH after BASIC_CHECK_PATHS_WINDOWS. + UTIL_FIXUP_PATH(CONFIGURE_START_DIR) + UTIL_FIXUP_PATH(TOPDIR) + + # Locate the directory of this script. + AUTOCONF_DIR=$TOPDIR/make/autoconf + + # Setup username (for use in adhoc version strings etc) + # Outer [ ] to quote m4. + [ USERNAME=`$ECHO "$USER" | $TR -d -c '[a-z][A-Z][0-9]'` ] + AC_SUBST(USERNAME) +]) + +############################################################################### +# Evaluates platform specific overrides for devkit variables. +# $1: Name of variable +AC_DEFUN([BASIC_EVAL_DEVKIT_VARIABLE], +[ + if test "x[$]$1" = x; then + eval $1="\${$1_${OPENJDK_TARGET_CPU}}" + fi +]) + +############################################################################### +AC_DEFUN_ONCE([BASIC_SETUP_DEVKIT], +[ + AC_ARG_WITH([devkit], [AS_HELP_STRING([--with-devkit], + [use this devkit for compilers, tools and resources])]) + + if test "x$with_devkit" = xyes; then + AC_MSG_ERROR([--with-devkit must have a value]) + elif test "x$with_devkit" != x && test "x$with_devkit" != xno; then + UTIL_FIXUP_PATH([with_devkit]) + DEVKIT_ROOT="$with_devkit" + # Check for a meta data info file in the root of the devkit + if test -f "$DEVKIT_ROOT/devkit.info"; then + . $DEVKIT_ROOT/devkit.info + # This potentially sets the following: + # A descriptive name of the devkit + BASIC_EVAL_DEVKIT_VARIABLE([DEVKIT_NAME]) + # Corresponds to --with-extra-path + BASIC_EVAL_DEVKIT_VARIABLE([DEVKIT_EXTRA_PATH]) + # Corresponds to --with-toolchain-path + BASIC_EVAL_DEVKIT_VARIABLE([DEVKIT_TOOLCHAIN_PATH]) + # Corresponds to --with-sysroot + BASIC_EVAL_DEVKIT_VARIABLE([DEVKIT_SYSROOT]) + + # Identifies the Visual Studio version in the devkit + BASIC_EVAL_DEVKIT_VARIABLE([DEVKIT_VS_VERSION]) + # The Visual Studio include environment variable + BASIC_EVAL_DEVKIT_VARIABLE([DEVKIT_VS_INCLUDE]) + # The Visual Studio lib environment variable + BASIC_EVAL_DEVKIT_VARIABLE([DEVKIT_VS_LIB]) + # Corresponds to --with-msvcr-dll + BASIC_EVAL_DEVKIT_VARIABLE([DEVKIT_MSVCR_DLL]) + # Corresponds to --with-msvcp-dll + BASIC_EVAL_DEVKIT_VARIABLE([DEVKIT_MSVCP_DLL]) + # Corresponds to --with-ucrt-dll-dir + BASIC_EVAL_DEVKIT_VARIABLE([DEVKIT_UCRT_DLL_DIR]) + fi + + AC_MSG_CHECKING([for devkit]) + if test "x$DEVKIT_NAME" != x; then + AC_MSG_RESULT([$DEVKIT_NAME in $DEVKIT_ROOT]) + else + AC_MSG_RESULT([$DEVKIT_ROOT]) + fi + + UTIL_PREPEND_TO_PATH([EXTRA_PATH],$DEVKIT_EXTRA_PATH) + + # Fallback default of just /bin if DEVKIT_PATH is not defined + if test "x$DEVKIT_TOOLCHAIN_PATH" = x; then + DEVKIT_TOOLCHAIN_PATH="$DEVKIT_ROOT/bin" + fi + UTIL_PREPEND_TO_PATH([TOOLCHAIN_PATH],$DEVKIT_TOOLCHAIN_PATH) + + # If DEVKIT_SYSROOT is set, use that, otherwise try a couple of known + # places for backwards compatiblity. + if test "x$DEVKIT_SYSROOT" != x; then + SYSROOT="$DEVKIT_SYSROOT" + elif test -d "$DEVKIT_ROOT/$host_alias/libc"; then + SYSROOT="$DEVKIT_ROOT/$host_alias/libc" + elif test -d "$DEVKIT_ROOT/$host/sys-root"; then + SYSROOT="$DEVKIT_ROOT/$host/sys-root" + fi + + if test "x$DEVKIT_ROOT" != x; then + DEVKIT_LIB_DIR="$DEVKIT_ROOT/lib" + if test "x$OPENJDK_TARGET_CPU_BITS" = x64; then + DEVKIT_LIB_DIR="$DEVKIT_ROOT/lib64" + fi + AC_SUBST(DEVKIT_LIB_DIR) + fi + fi + + # You can force the sysroot if the sysroot encoded into the compiler tools + # is not correct. + AC_ARG_WITH(sys-root, [AS_HELP_STRING([--with-sys-root], + [alias for --with-sysroot for backwards compatability])], + [SYSROOT=$with_sys_root] + ) + + AC_ARG_WITH(sysroot, [AS_HELP_STRING([--with-sysroot], + [use this directory as sysroot])], + [SYSROOT=$with_sysroot] + ) + + AC_ARG_WITH([tools-dir], [AS_HELP_STRING([--with-tools-dir], + [alias for --with-toolchain-path for backwards compatibility])], + [UTIL_PREPEND_TO_PATH([TOOLCHAIN_PATH],$with_tools_dir)] + ) + + AC_ARG_WITH([toolchain-path], [AS_HELP_STRING([--with-toolchain-path], + [prepend these directories when searching for toolchain binaries (compilers etc)])], + [UTIL_PREPEND_TO_PATH([TOOLCHAIN_PATH],$with_toolchain_path)] + ) + + AC_ARG_WITH([extra-path], [AS_HELP_STRING([--with-extra-path], + [prepend these directories to the default path])], + [UTIL_PREPEND_TO_PATH([EXTRA_PATH],$with_extra_path)] + ) + + if test "x$OPENJDK_BUILD_OS" = "xmacosx"; then + # If a devkit has been supplied, find xcodebuild in the toolchain_path. + # If not, detect if Xcode is installed by running xcodebuild -version + # if no Xcode installed, xcodebuild exits with 1 + # if Xcode is installed, even if xcode-select is misconfigured, then it exits with 0 + if test "x$DEVKIT_ROOT" != x || /usr/bin/xcodebuild -version >/dev/null 2>&1; then + # We need to use xcodebuild in the toolchain dir provided by the user, this will + # fall back on the stub binary in /usr/bin/xcodebuild + AC_PATH_PROG([XCODEBUILD], [xcodebuild], [/usr/bin/xcodebuild], [$TOOLCHAIN_PATH]) + else + # this should result in SYSROOT being empty, unless --with-sysroot is provided + # when only the command line tools are installed there are no SDKs, so headers + # are copied into the system frameworks + XCODEBUILD= + AC_SUBST(XCODEBUILD) + fi + + AC_MSG_CHECKING([for sdk name]) + AC_ARG_WITH([sdk-name], [AS_HELP_STRING([--with-sdk-name], + [use the platform SDK of the given name. @<:@macosx@:>@])], + [SDKNAME=$with_sdk_name] + ) + AC_MSG_RESULT([$SDKNAME]) + + # if toolchain path is specified then don't rely on system headers, they may not compile + HAVE_SYSTEM_FRAMEWORK_HEADERS=0 + test -z "$TOOLCHAIN_PATH" && \ + HAVE_SYSTEM_FRAMEWORK_HEADERS=`test ! -f /System/Library/Frameworks/Foundation.framework/Headers/Foundation.h; echo $?` + + if test -z "$SYSROOT"; then + if test -n "$XCODEBUILD"; then + # if we don't have system headers, use default SDK name (last resort) + if test -z "$SDKNAME" -a $HAVE_SYSTEM_FRAMEWORK_HEADERS -eq 0; then + SDKNAME=${SDKNAME:-macosx} + fi + + if test -n "$SDKNAME"; then + # Call xcodebuild to determine SYSROOT + SYSROOT=`"$XCODEBUILD" -sdk $SDKNAME -version | $GREP '^Path: ' | $SED 's/Path: //'` + fi + else + if test $HAVE_SYSTEM_FRAMEWORK_HEADERS -eq 0; then + AC_MSG_ERROR([No xcodebuild tool and no system framework headers found, use --with-sysroot or --with-sdk-name to provide a path to a valid SDK]) + fi + fi + else + # warn user if --with-sdk-name was also set + if test -n "$with_sdk_name"; then + AC_MSG_WARN([Both SYSROOT and --with-sdk-name are set, only SYSROOT will be used]) + fi + fi + + if test $HAVE_SYSTEM_FRAMEWORK_HEADERS -eq 0 -a -z "$SYSROOT"; then + # If no system framework headers, then SYSROOT must be set, or we won't build + AC_MSG_ERROR([Unable to determine SYSROOT and no headers found in /System/Library/Frameworks. Check Xcode configuration, --with-sysroot or --with-sdk-name arguments.]) + fi + + # Perform a basic sanity test + if test ! -f "$SYSROOT/System/Library/Frameworks/Foundation.framework/Headers/Foundation.h"; then + if test -z "$SYSROOT"; then + AC_MSG_ERROR([Unable to find required framework headers, provide a path to an SDK via --with-sysroot or --with-sdk-name and be sure Xcode is installed properly]) + else + AC_MSG_ERROR([Invalid SDK or SYSROOT path, dependent framework headers not found]) + fi + fi + + # set SDKROOT too, Xcode tools will pick it up + SDKROOT="$SYSROOT" + AC_SUBST(SDKROOT) + fi + + # Prepend the extra path to the global path + UTIL_PREPEND_TO_PATH([PATH],$EXTRA_PATH) + + AC_MSG_CHECKING([for sysroot]) + AC_MSG_RESULT([$SYSROOT]) + AC_MSG_CHECKING([for toolchain path]) + AC_MSG_RESULT([$TOOLCHAIN_PATH]) + AC_MSG_CHECKING([for extra path]) + AC_MSG_RESULT([$EXTRA_PATH]) +]) + +############################################################################### +AC_DEFUN_ONCE([BASIC_SETUP_OUTPUT_DIR], +[ + + AC_ARG_WITH(conf-name, [AS_HELP_STRING([--with-conf-name], + [use this as the name of the configuration @<:@generated from important configuration options@:>@])], + [ CONF_NAME=${with_conf_name} ]) + + # Test from where we are running configure, in or outside of src root. + AC_MSG_CHECKING([where to store configuration]) + if test "x$CONFIGURE_START_DIR" = "x$TOPDIR" \ + || test "x$CONFIGURE_START_DIR" = "x$CUSTOM_ROOT" \ + || test "x$CONFIGURE_START_DIR" = "x$TOPDIR/make/autoconf" \ + || test "x$CONFIGURE_START_DIR" = "x$TOPDIR/make" ; then + # We are running configure from the src root. + # Create a default ./build/target-variant-debuglevel output root. + if test "x${CONF_NAME}" = x; then + AC_MSG_RESULT([in default location]) + CONF_NAME="${OPENJDK_TARGET_OS}-${OPENJDK_TARGET_CPU}-${JVM_VARIANTS_WITH_AND}-${DEBUG_LEVEL}" + else + AC_MSG_RESULT([in build directory with custom name]) + fi + + if test "x$CUSTOM_ROOT" != x; then + WORKSPACE_ROOT="${CUSTOM_ROOT}" + else + WORKSPACE_ROOT="${TOPDIR}" + fi + OUTPUTDIR="${WORKSPACE_ROOT}/build/${CONF_NAME}" + $MKDIR -p "$OUTPUTDIR" + if test ! -d "$OUTPUTDIR"; then + AC_MSG_ERROR([Could not create build directory $OUTPUTDIR]) + fi + else + # We are running configure from outside of the src dir. + # Then use the current directory as output dir! + # If configuration is situated in normal build directory, just use the build + # directory name as configuration name, otherwise use the complete path. + if test "x${CONF_NAME}" = x; then + CONF_NAME=`$ECHO $CONFIGURE_START_DIR | $SED -e "s!^${TOPDIR}/build/!!"` + fi + OUTPUTDIR="$CONFIGURE_START_DIR" + AC_MSG_RESULT([in current directory]) + + # WARNING: This might be a bad thing to do. You need to be sure you want to + # have a configuration in this directory. Do some sanity checks! + + if test ! -e "$OUTPUTDIR/spec.gmk"; then + # If we have a spec.gmk, we have run here before and we are OK. Otherwise, check for + # other files + files_present=`$LS $OUTPUTDIR` + # Configure has already touched config.log and confdefs.h in the current dir when this check + # is performed. + filtered_files=`$ECHO "$files_present" \ + | $SED -e 's/config.log//g' \ + -e 's/configure.log//g' \ + -e 's/confdefs.h//g' \ + -e 's/configure-support//g' \ + -e 's/ //g' \ + | $TR -d '\n'` + if test "x$filtered_files" != x; then + AC_MSG_NOTICE([Current directory is $CONFIGURE_START_DIR.]) + AC_MSG_NOTICE([Since this is not the source root, configure will output the configuration here]) + AC_MSG_NOTICE([(as opposed to creating a configuration in /build/).]) + AC_MSG_NOTICE([However, this directory is not empty. This is not allowed, since it could]) + AC_MSG_NOTICE([seriously mess up just about everything.]) + AC_MSG_NOTICE([Try 'cd $TOPDIR' and restart configure]) + AC_MSG_NOTICE([(or create a new empty directory and cd to it).]) + AC_MSG_ERROR([Will not continue creating configuration in $CONFIGURE_START_DIR]) + fi + fi + fi + AC_MSG_CHECKING([what configuration name to use]) + AC_MSG_RESULT([$CONF_NAME]) + + UTIL_FIXUP_PATH(OUTPUTDIR) + + CONFIGURESUPPORT_OUTPUTDIR="$OUTPUTDIR/configure-support" + $MKDIR -p "$CONFIGURESUPPORT_OUTPUTDIR" + + SPEC="$OUTPUTDIR/spec.gmk" + AC_SUBST(SPEC) + AC_SUBST(CONF_NAME) + AC_SUBST(OUTPUTDIR) + AC_SUBST(WORKSPACE_ROOT) + AC_SUBST(CONFIGURESUPPORT_OUTPUTDIR) + + # The spec.gmk file contains all variables for the make system. + AC_CONFIG_FILES([$OUTPUTDIR/spec.gmk:$AUTOCONF_DIR/spec.gmk.in]) + # The bootcycle-spec.gmk file contains support for boot cycle builds. + AC_CONFIG_FILES([$OUTPUTDIR/bootcycle-spec.gmk:$AUTOCONF_DIR/bootcycle-spec.gmk.in]) + # The buildjdk-spec.gmk file contains support for building a buildjdk when cross compiling. + AC_CONFIG_FILES([$OUTPUTDIR/buildjdk-spec.gmk:$AUTOCONF_DIR/buildjdk-spec.gmk.in]) + # The compare.sh is used to compare the build output to other builds. + AC_CONFIG_FILES([$OUTPUTDIR/compare.sh:$AUTOCONF_DIR/compare.sh.in]) + # The generated Makefile knows where the spec.gmk is and where the source is. + # You can run make from the OUTPUTDIR, or from the top-level Makefile + # which will look for generated configurations + AC_CONFIG_FILES([$OUTPUTDIR/Makefile:$AUTOCONF_DIR/Makefile.in]) +]) + +############################################################################### +# Check if build directory is on local disk. If not possible to determine, +# we prefer to claim it's local. +# Argument 1: directory to test +# Argument 2: what to do if it is on local disk +# Argument 3: what to do otherwise (remote disk or failure) +AC_DEFUN([BASIC_CHECK_DIR_ON_LOCAL_DISK], +[ + # df -l lists only local disks; if the given directory is not found then + # a non-zero exit code is given + if test "x$DF" = x; then + if test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.msys"; then + # msys does not have df; use Windows "net use" instead. + IS_NETWORK_DISK=`net use | grep \`pwd -W | cut -d ":" -f 1 | tr a-z A-Z\`:` + if test "x$IS_NETWORK_DISK" = x; then + $2 + else + $3 + fi + else + # No df here, say it's local + $2 + fi + else + # JDK-8189619 + # df on AIX does not understand -l. On modern AIXes it understands "-T local" which + # is the same. On older AIXes we just continue to live with a "not local build" warning. + if test "x$OPENJDK_TARGET_OS" = xaix; then + DF_LOCAL_ONLY_OPTION='-T local' + else + DF_LOCAL_ONLY_OPTION='-l' + fi + if $DF $DF_LOCAL_ONLY_OPTION $1 > /dev/null 2>&1; then + $2 + else + # In WSL, local Windows drives are considered remote by df, but we are + # required to build into a directory accessible from windows, so consider + # them local here. + if test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.wsl"; then + if $DF $1 | $GREP -q "^[[A-Z]]:"; then + $2 + else + $3 + fi + else + $3 + fi + fi + fi +]) + +############################################################################### +# Check that source files have basic read permissions set. This might +# not be the case in cygwin in certain conditions. +AC_DEFUN_ONCE([BASIC_CHECK_SRC_PERMS], +[ + if test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.cygwin"; then + file_to_test="$TOPDIR/LICENSE" + if test `$STAT -c '%a' "$file_to_test"` -lt 400; then + AC_MSG_ERROR([Bad file permissions on src files. This is usually caused by cloning the repositories with a non cygwin hg in a directory not created in cygwin.]) + fi + fi +]) + +############################################################################### +AC_DEFUN_ONCE([BASIC_TEST_USABILITY_ISSUES], +[ + AC_MSG_CHECKING([if build directory is on local disk]) + BASIC_CHECK_DIR_ON_LOCAL_DISK($OUTPUTDIR, + [OUTPUT_DIR_IS_LOCAL="yes"], + [OUTPUT_DIR_IS_LOCAL="no"]) + AC_MSG_RESULT($OUTPUT_DIR_IS_LOCAL) + + BASIC_CHECK_SRC_PERMS + + # Check if the user has any old-style ALT_ variables set. + FOUND_ALT_VARIABLES=`env | grep ^ALT_` + + # Before generating output files, test if they exist. If they do, this is a reconfigure. + # Since we can't properly handle the dependencies for this, warn the user about the situation + if test -e $OUTPUTDIR/spec.gmk; then + IS_RECONFIGURE=yes + else + IS_RECONFIGURE=no + fi +]) + +################################################################################ +# +# Default make target +# +AC_DEFUN_ONCE([BASIC_SETUP_DEFAULT_MAKE_TARGET], +[ + AC_ARG_WITH(default-make-target, [AS_HELP_STRING([--with-default-make-target], + [set the default make target @<:@exploded-image@:>@])]) + if test "x$with_default_make_target" = "x" \ + || test "x$with_default_make_target" = "xyes"; then + DEFAULT_MAKE_TARGET="exploded-image" + elif test "x$with_default_make_target" = "xno"; then + AC_MSG_ERROR([--without-default-make-target is not a valid option]) + else + DEFAULT_MAKE_TARGET="$with_default_make_target" + fi + + AC_SUBST(DEFAULT_MAKE_TARGET) +]) + +############################################################################### +# Setup the default value for LOG= +# +AC_DEFUN_ONCE([BASIC_SETUP_DEFAULT_LOG], +[ + AC_ARG_WITH(log, [AS_HELP_STRING([--with-log], + [[default vaue for make LOG argument [warn]]])]) + AC_MSG_CHECKING([for default LOG value]) + if test "x$with_log" = x; then + DEFAULT_LOG="" + else + # Syntax for valid LOG options is a bit too complex for it to be worth + # implementing a test for correctness in configure. Just accept it. + DEFAULT_LOG=$with_log + fi + AC_MSG_RESULT([$DEFAULT_LOG]) + AC_SUBST(DEFAULT_LOG) +]) + +############################################################################### +# Code to run after AC_OUTPUT +AC_DEFUN_ONCE([BASIC_POST_CONFIG_OUTPUT], +[ + # Try to move config.log (generated by autoconf) to the configure-support directory. + if test -e ./config.log; then + $MV -f ./config.log "$CONFIGURESUPPORT_OUTPUTDIR/config.log" 2> /dev/null + fi + + # Rotate our log file (configure.log) + if test -e "$OUTPUTDIR/configure.log.old"; then + $RM -f "$OUTPUTDIR/configure.log.old" + fi + if test -e "$OUTPUTDIR/configure.log"; then + $MV -f "$OUTPUTDIR/configure.log" "$OUTPUTDIR/configure.log.old" 2> /dev/null + fi + + # Move configure.log from current directory to the build output root + if test -e ./configure.log; then + $MV -f ./configure.log "$OUTPUTDIR/configure.log" 2> /dev/null + fi + + # Make the compare script executable + $CHMOD +x $OUTPUTDIR/compare.sh +]) diff --git a/make/autoconf/basic_tools.m4 b/make/autoconf/basic_tools.m4 new file mode 100644 index 00000000000..95577d9422b --- /dev/null +++ b/make/autoconf/basic_tools.m4 @@ -0,0 +1,475 @@ +# +# Copyright (c) 2011, 2020, Oracle and/or its affiliates. All rights reserved. +# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. +# +# This code is free software; you can redistribute it and/or modify it +# under the terms of the GNU General Public License version 2 only, as +# published by the Free Software Foundation. Oracle designates this +# particular file as subject to the "Classpath" exception as provided +# by Oracle in the LICENSE file that accompanied this code. +# +# This code is distributed in the hope that it will be useful, but WITHOUT +# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or +# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License +# version 2 for more details (a copy is included in the LICENSE file that +# accompanied this code). +# +# You should have received a copy of the GNU General Public License version +# 2 along with this work; if not, write to the Free Software Foundation, +# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. +# +# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA +# or visit www.oracle.com if you need additional information or have any +# questions. +# + +############################################################################### +# Setup the most fundamental tools that relies on not much else to set up, +# but is used by much of the early bootstrap code. +AC_DEFUN_ONCE([BASIC_SETUP_FUNDAMENTAL_TOOLS], +[ + # Start with tools that do not need have cross compilation support + # and can be expected to be found in the default PATH. These tools are + # used by configure. + + # First are all the simple required tools. + UTIL_REQUIRE_PROGS(BASENAME, basename) + UTIL_REQUIRE_PROGS(BASH, bash) + UTIL_REQUIRE_PROGS(CAT, cat) + UTIL_REQUIRE_PROGS(CHMOD, chmod) + UTIL_REQUIRE_PROGS(CMP, cmp) + UTIL_REQUIRE_PROGS(COMM, comm) + UTIL_REQUIRE_PROGS(CP, cp) + UTIL_REQUIRE_PROGS(CUT, cut) + UTIL_REQUIRE_PROGS(DATE, date) + UTIL_REQUIRE_PROGS(DIFF, [gdiff diff]) + UTIL_REQUIRE_PROGS(DIRNAME, dirname) + UTIL_REQUIRE_PROGS(ECHO, echo) + UTIL_REQUIRE_PROGS(EXPR, expr) + UTIL_REQUIRE_PROGS(FILE, file) + UTIL_REQUIRE_PROGS(FIND, find) + UTIL_REQUIRE_PROGS(HEAD, head) + UTIL_REQUIRE_PROGS(GUNZIP, gunzip) + UTIL_REQUIRE_PROGS(GZIP, pigz gzip) + UTIL_REQUIRE_PROGS(LN, ln) + UTIL_REQUIRE_PROGS(LS, ls) + # gmkdir is known to be safe for concurrent invocations with -p flag. + UTIL_REQUIRE_PROGS(MKDIR, [gmkdir mkdir]) + UTIL_REQUIRE_PROGS(MKTEMP, mktemp) + UTIL_REQUIRE_PROGS(MV, mv) + UTIL_REQUIRE_PROGS(NAWK, [nawk gawk awk]) + UTIL_REQUIRE_PROGS(PRINTF, printf) + UTIL_REQUIRE_PROGS(READLINK, [greadlink readlink]) + UTIL_REQUIRE_PROGS(RM, rm) + UTIL_REQUIRE_PROGS(RMDIR, rmdir) + UTIL_REQUIRE_PROGS(SH, sh) + UTIL_REQUIRE_PROGS(SORT, sort) + UTIL_REQUIRE_PROGS(TAIL, tail) + UTIL_REQUIRE_PROGS(TAR, gtar tar) + UTIL_REQUIRE_PROGS(TEE, tee) + UTIL_REQUIRE_PROGS(TOUCH, touch) + UTIL_REQUIRE_PROGS(TR, tr) + UTIL_REQUIRE_PROGS(UNAME, uname) + UTIL_REQUIRE_PROGS(UNIQ, uniq) + UTIL_REQUIRE_PROGS(WC, wc) + UTIL_REQUIRE_PROGS(WHICH, which) + UTIL_REQUIRE_PROGS(XARGS, xargs) + + # Then required tools that require some special treatment. + UTIL_REQUIRE_SPECIAL(AWK, [AC_PROG_AWK]) + UTIL_REQUIRE_SPECIAL(GREP, [AC_PROG_GREP]) + UTIL_REQUIRE_SPECIAL(EGREP, [AC_PROG_EGREP]) + UTIL_REQUIRE_SPECIAL(FGREP, [AC_PROG_FGREP]) + UTIL_REQUIRE_SPECIAL(SED, [AC_PROG_SED]) + + # Always force rm. + RM="$RM -f" + + # pwd behaves differently on various platforms and some don't support the -L flag. + # Always use the bash builtin pwd to get uniform behavior. + THEPWDCMD=pwd + + # These are not required on all platforms + UTIL_PATH_PROGS(CYGPATH, cygpath) + UTIL_PATH_PROGS(WSLPATH, wslpath) + UTIL_PATH_PROGS(DF, df) + UTIL_PATH_PROGS(CPIO, [cpio bsdcpio]) + UTIL_PATH_PROGS(NICE, nice) + + UTIL_PATH_PROGS(LSB_RELEASE, lsb_release) + UTIL_PATH_PROGS(CMD, [cmd.exe /mnt/c/Windows/System32/cmd.exe]) +]) + +############################################################################### +# Check if we have found a usable version of make +# $1: the path to a potential make binary (or empty) +# $2: the description on how we found this +AC_DEFUN([BASIC_CHECK_MAKE_VERSION], +[ + MAKE_CANDIDATE="$1" + DESCRIPTION="$2" + + # On Cygwin, we require a newer version of make than on other platforms + if test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.cygwin"; then + MAKE_VERSION_EXPR="-e 4\." + MAKE_REQUIRED_VERSION="4.0" + else + MAKE_VERSION_EXPR="-e 3\.8[[12]] -e 4\." + MAKE_REQUIRED_VERSION="3.81" + fi + + if test "x$MAKE_CANDIDATE" != x; then + AC_MSG_NOTICE([Testing potential make at $MAKE_CANDIDATE, found using $DESCRIPTION]) + MAKE_VERSION_STRING=`$MAKE_CANDIDATE --version | $HEAD -n 1` + IS_GNU_MAKE=`$ECHO $MAKE_VERSION_STRING | $GREP 'GNU Make'` + if test "x$IS_GNU_MAKE" = x; then + AC_MSG_NOTICE([Found potential make at $MAKE_CANDIDATE, however, this is not GNU Make. Ignoring.]) + else + IS_MODERN_MAKE=`$ECHO $MAKE_VERSION_STRING | $GREP $MAKE_VERSION_EXPR` + if test "x$IS_MODERN_MAKE" = x; then + AC_MSG_NOTICE([Found GNU make at $MAKE_CANDIDATE, however this is not version $MAKE_REQUIRED_VERSION or later. (it is: $MAKE_VERSION_STRING). Ignoring.]) + else + if test "x$OPENJDK_BUILD_OS" = "xwindows"; then + if test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.cygwin"; then + MAKE_EXPECTED_ENV='cygwin' + elif test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.msys"; then + MAKE_EXPECTED_ENV='msys' + elif test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.wsl"; then + MAKE_EXPECTED_ENV='x86_64-.*-linux-gnu' + else + AC_MSG_ERROR([Unknown Windows environment]) + fi + MAKE_BUILT_FOR=`$MAKE_CANDIDATE --version | $GREP -i 'built for'` + IS_MAKE_CORRECT_ENV=`$ECHO $MAKE_BUILT_FOR | $GREP $MAKE_EXPECTED_ENV` + else + # Not relevant for non-Windows + IS_MAKE_CORRECT_ENV=true + fi + if test "x$IS_MAKE_CORRECT_ENV" = x; then + AC_MSG_NOTICE([Found GNU make version $MAKE_VERSION_STRING at $MAKE_CANDIDATE, but it is not for $MAKE_EXPECTED_ENV (it says: $MAKE_BUILT_FOR). Ignoring.]) + else + FOUND_MAKE=$MAKE_CANDIDATE + UTIL_FIXUP_EXECUTABLE(FOUND_MAKE) + fi + fi + fi + fi +]) + +############################################################################### +AC_DEFUN([BASIC_CHECK_MAKE_OUTPUT_SYNC], +[ + # Check if make supports the output sync option and if so, setup using it. + AC_MSG_CHECKING([if make --output-sync is supported]) + if $MAKE --version -O > /dev/null 2>&1; then + OUTPUT_SYNC_SUPPORTED=true + AC_MSG_RESULT([yes]) + AC_MSG_CHECKING([for output-sync value]) + AC_ARG_WITH([output-sync], [AS_HELP_STRING([--with-output-sync], + [set make output sync type if supported by make. @<:@recurse@:>@])], + [OUTPUT_SYNC=$with_output_sync]) + if test "x$OUTPUT_SYNC" = "x"; then + OUTPUT_SYNC=none + fi + AC_MSG_RESULT([$OUTPUT_SYNC]) + if ! $MAKE --version -O$OUTPUT_SYNC > /dev/null 2>&1; then + AC_MSG_ERROR([Make did not the support the value $OUTPUT_SYNC as output sync type.]) + fi + else + OUTPUT_SYNC_SUPPORTED=false + AC_MSG_RESULT([no]) + fi + AC_SUBST(OUTPUT_SYNC_SUPPORTED) + AC_SUBST(OUTPUT_SYNC) +]) + +############################################################################### +# Goes looking for a usable version of GNU make. +AC_DEFUN([BASIC_CHECK_GNU_MAKE], +[ + UTIL_SETUP_TOOL([MAKE], + [ + # Try our hardest to locate a correct version of GNU make + AC_PATH_PROGS(CHECK_GMAKE, gmake) + BASIC_CHECK_MAKE_VERSION("$CHECK_GMAKE", [gmake in PATH]) + + if test "x$FOUND_MAKE" = x; then + AC_PATH_PROGS(CHECK_MAKE, make) + BASIC_CHECK_MAKE_VERSION("$CHECK_MAKE", [make in PATH]) + fi + + if test "x$FOUND_MAKE" = x; then + if test "x$TOOLCHAIN_PATH" != x; then + # We have a toolchain path, check that as well before giving up. + OLD_PATH=$PATH + PATH=$TOOLCHAIN_PATH:$PATH + AC_PATH_PROGS(CHECK_TOOLSDIR_GMAKE, gmake) + BASIC_CHECK_MAKE_VERSION("$CHECK_TOOLSDIR_GMAKE", [gmake in tools-dir]) + if test "x$FOUND_MAKE" = x; then + AC_PATH_PROGS(CHECK_TOOLSDIR_MAKE, make) + BASIC_CHECK_MAKE_VERSION("$CHECK_TOOLSDIR_MAKE", [make in tools-dir]) + fi + PATH=$OLD_PATH + fi + fi + + if test "x$FOUND_MAKE" = x; then + AC_MSG_ERROR([Cannot find GNU make $MAKE_REQUIRED_VERSION or newer! Please put it in the path, or add e.g. MAKE=/opt/gmake3.81/make as argument to configure.]) + fi + ],[ + # If MAKE was set by user, verify the version + BASIC_CHECK_MAKE_VERSION("$MAKE", [user supplied MAKE=$MAKE]) + if test "x$FOUND_MAKE" = x; then + AC_MSG_ERROR([The specified make (by MAKE=$MAKE) is not GNU make $MAKE_REQUIRED_VERSION or newer.]) + fi + ]) + + MAKE=$FOUND_MAKE + AC_SUBST(MAKE) + AC_MSG_NOTICE([Using GNU make at $FOUND_MAKE (version: $MAKE_VERSION_STRING)]) + + BASIC_CHECK_MAKE_OUTPUT_SYNC +]) + +############################################################################### +AC_DEFUN([BASIC_CHECK_FIND_DELETE], +[ + # Test if find supports -delete + AC_MSG_CHECKING([if find supports -delete]) + FIND_DELETE="-delete" + + DELETEDIR=`$MKTEMP -d tmp.XXXXXXXXXX` || (echo Could not create temporary directory!; exit $?) + + echo Hejsan > $DELETEDIR/TestIfFindSupportsDelete + + TEST_DELETE=`$FIND "$DELETEDIR" -name TestIfFindSupportsDelete $FIND_DELETE 2>&1` + if test -f $DELETEDIR/TestIfFindSupportsDelete; then + # No, it does not. + $RM $DELETEDIR/TestIfFindSupportsDelete + if test "x$OPENJDK_TARGET_OS" = "xaix"; then + # AIX 'find' is buggy if called with '-exec {} \+' and an empty file list + FIND_DELETE="-print | $XARGS $RM" + else + FIND_DELETE="-exec $RM \{\} \+" + fi + AC_MSG_RESULT([no]) + else + AC_MSG_RESULT([yes]) + fi + $RMDIR $DELETEDIR + AC_SUBST(FIND_DELETE) +]) + +############################################################################### +AC_DEFUN([BASIC_CHECK_TAR], +[ + # Test which kind of tar was found + if test "x$($TAR --version | $GREP "GNU tar")" != "x"; then + TAR_TYPE="gnu" + elif test "x$($TAR --version | $GREP "bsdtar")" != "x"; then + TAR_TYPE="bsd" + elif test "x$($TAR -v | $GREP "bsdtar")" != "x"; then + TAR_TYPE="bsd" + elif test "x$OPENJDK_BUILD_OS" = "xsolaris"; then + TAR_TYPE="solaris" + elif test "x$OPENJDK_BUILD_OS" = "xaix"; then + TAR_TYPE="aix" + fi + AC_MSG_CHECKING([what type of tar was found]) + AC_MSG_RESULT([$TAR_TYPE]) + + TAR_CREATE_FILE_PARAM="" + + if test "x$TAR_TYPE" = "xgnu"; then + TAR_INCLUDE_PARAM="T" + TAR_SUPPORTS_TRANSFORM="true" + if test "x$OPENJDK_TARGET_OS" = "xsolaris"; then + # When using gnu tar for Solaris targets, need to use compatibility mode + TAR_CREATE_EXTRA_PARAM="--format=ustar" + fi + elif test "x$TAR_TYPE" = "aix"; then + # -L InputList of aix tar: name of file listing the files and directories + # that need to be archived or extracted + TAR_INCLUDE_PARAM="L" + TAR_SUPPORTS_TRANSFORM="false" + else + TAR_INCLUDE_PARAM="I" + TAR_SUPPORTS_TRANSFORM="false" + fi + AC_SUBST(TAR_TYPE) + AC_SUBST(TAR_CREATE_EXTRA_PARAM) + AC_SUBST(TAR_INCLUDE_PARAM) + AC_SUBST(TAR_SUPPORTS_TRANSFORM) +]) + +############################################################################### +AC_DEFUN([BASIC_CHECK_GREP], +[ + # Test that grep supports -Fx with a list of pattern which includes null pattern. + # This is a problem for the grep resident on AIX. + AC_MSG_CHECKING([that grep ($GREP) -Fx handles empty lines in the pattern list correctly]) + # Multiple subsequent spaces.. + STACK_SPACES='aaa bbb ccc' + # ..converted to subsequent newlines, causes STACK_LIST to be a list with some empty + # patterns in it. + STACK_LIST=${STACK_SPACES// /$'\n'} + NEEDLE_SPACES='ccc bbb aaa' + NEEDLE_LIST=${NEEDLE_SPACES// /$'\n'} + RESULT="$($GREP -Fvx "$STACK_LIST" <<< "$NEEDLE_LIST")" + if test "x$RESULT" == "x"; then + AC_MSG_RESULT([yes]) + else + if test "x$OPENJDK_TARGET_OS" = "xaix"; then + ADDINFO="Please make sure you use GNU grep, usually found at /opt/freeware/bin." + fi + AC_MSG_ERROR([grep does not handle -Fx correctly. ${ADDINFO}]) + fi +]) + +############################################################################### +AC_DEFUN_ONCE([BASIC_SETUP_COMPLEX_TOOLS], +[ + BASIC_CHECK_GNU_MAKE + + BASIC_CHECK_FIND_DELETE + BASIC_CHECK_TAR + BASIC_CHECK_GREP + BASIC_SETUP_PANDOC + + # These tools might not be installed by default, + # need hint on how to install them. + UTIL_REQUIRE_PROGS(UNZIP, unzip) + # Since zip uses "ZIP" as a environment variable for passing options, we need + # to name our variable differently, hence ZIPEXE. + UTIL_REQUIRE_PROGS(ZIPEXE, zip) + + # Non-required basic tools + + UTIL_PATH_PROGS(LDD, ldd) + if test "x$LDD" = "x"; then + # List shared lib dependencies is used for + # debug output and checking for forbidden dependencies. + # We can build without it. + LDD="true" + fi + UTIL_PATH_PROGS(READELF, [greadelf readelf]) + UTIL_PATH_PROGS(DOT, dot) + UTIL_PATH_PROGS(HG, hg) + UTIL_PATH_PROGS(GIT, git) + UTIL_PATH_PROGS(STAT, stat) + UTIL_PATH_PROGS(TIME, time) + UTIL_PATH_PROGS(FLOCK, flock) + # Dtrace is usually found in /usr/sbin on Solaris, but that directory may not + # be in the user path. + UTIL_PATH_PROGS(DTRACE, dtrace, $PATH:/usr/sbin) + UTIL_PATH_PROGS(PATCH, [gpatch patch]) + # Check if it's GNU time + IS_GNU_TIME=`$TIME --version 2>&1 | $GREP 'GNU time'` + if test "x$IS_GNU_TIME" != x; then + IS_GNU_TIME=yes + else + IS_GNU_TIME=no + fi + AC_SUBST(IS_GNU_TIME) + + if test "x$OPENJDK_TARGET_OS" = "xmacosx"; then + UTIL_REQUIRE_PROGS(DSYMUTIL, dsymutil) + UTIL_REQUIRE_PROGS(MIG, mig) + UTIL_REQUIRE_PROGS(XATTR, xattr) + UTIL_PATH_PROGS(CODESIGN, codesign) + + if test "x$CODESIGN" != "x"; then + # Check for user provided code signing identity. + # If no identity was provided, fall back to "openjdk_codesign". + AC_ARG_WITH([macosx-codesign-identity], [AS_HELP_STRING([--with-macosx-codesign-identity], + [specify the code signing identity])], + [MACOSX_CODESIGN_IDENTITY=$with_macosx_codesign_identity], + [MACOSX_CODESIGN_IDENTITY=openjdk_codesign] + ) + + AC_SUBST(MACOSX_CODESIGN_IDENTITY) + + # Verify that the codesign certificate is present + AC_MSG_CHECKING([if codesign certificate is present]) + $RM codesign-testfile + $TOUCH codesign-testfile + $CODESIGN -s "$MACOSX_CODESIGN_IDENTITY" codesign-testfile 2>&AS_MESSAGE_LOG_FD >&AS_MESSAGE_LOG_FD || CODESIGN= + $RM codesign-testfile + if test "x$CODESIGN" = x; then + AC_MSG_RESULT([no]) + else + AC_MSG_RESULT([yes]) + fi + fi + UTIL_REQUIRE_PROGS(SETFILE, SetFile) + elif test "x$OPENJDK_TARGET_OS" = "xsolaris"; then + UTIL_REQUIRE_PROGS(ELFEDIT, elfedit) + fi + if ! test "x$OPENJDK_TARGET_OS" = "xwindows"; then + UTIL_REQUIRE_BUILTIN_PROGS(ULIMIT, ulimit) + fi +]) + +############################################################################### +# Check for support for specific options in bash +AC_DEFUN_ONCE([BASIC_CHECK_BASH_OPTIONS], +[ + # Check bash version + # Extra [ ] to stop m4 mangling + [ BASH_VER=`$BASH --version | $SED -n -e 's/^.*bash.*ersion *\([0-9.]*\).*$/\1/ p'` ] + AC_MSG_CHECKING([bash version]) + AC_MSG_RESULT([$BASH_VER]) + + BASH_MAJOR=`$ECHO $BASH_VER | $CUT -d . -f 1` + BASH_MINOR=`$ECHO $BASH_VER | $CUT -d . -f 2` + if test $BASH_MAJOR -lt 3 || (test $BASH_MAJOR -eq 3 && test $BASH_MINOR -lt 2); then + AC_MSG_ERROR([bash version 3.2 or better is required]) + fi + + # Test if bash supports pipefail. + AC_MSG_CHECKING([if bash supports pipefail]) + if ${BASH} -c 'set -o pipefail'; then + BASH_ARGS="$BASH_ARGS -o pipefail" + AC_MSG_RESULT([yes]) + else + AC_MSG_RESULT([no]) + fi + + AC_MSG_CHECKING([if bash supports errexit (-e)]) + if ${BASH} -e -c 'true'; then + BASH_ARGS="$BASH_ARGS -e" + AC_MSG_RESULT([yes]) + else + AC_MSG_RESULT([no]) + fi + + AC_SUBST(BASH_ARGS) +]) + +################################################################################ +# +# Setup Pandoc +# +AC_DEFUN_ONCE([BASIC_SETUP_PANDOC], +[ + UTIL_PATH_PROGS(PANDOC, pandoc) + + PANDOC_MARKDOWN_FLAG="markdown" + if test -n "$PANDOC"; then + AC_MSG_CHECKING(if the pandoc smart extension needs to be disabled for markdown) + if $PANDOC --list-extensions | $GREP -q '\+smart'; then + AC_MSG_RESULT([yes]) + PANDOC_MARKDOWN_FLAG="markdown-smart" + else + AC_MSG_RESULT([no]) + fi + fi + + if test -n "$PANDOC"; then + ENABLE_PANDOC="true" + else + ENABLE_PANDOC="false" + fi + AC_SUBST(ENABLE_PANDOC) + AC_SUBST(PANDOC_MARKDOWN_FLAG) +]) diff --git a/make/autoconf/basic_windows.m4 b/make/autoconf/basic_windows.m4 new file mode 100644 index 00000000000..11fb231d825 --- /dev/null +++ b/make/autoconf/basic_windows.m4 @@ -0,0 +1,183 @@ +# +# Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. +# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. +# +# This code is free software; you can redistribute it and/or modify it +# under the terms of the GNU General Public License version 2 only, as +# published by the Free Software Foundation. Oracle designates this +# particular file as subject to the "Classpath" exception as provided +# by Oracle in the LICENSE file that accompanied this code. +# +# This code is distributed in the hope that it will be useful, but WITHOUT +# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or +# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License +# version 2 for more details (a copy is included in the LICENSE file that +# accompanied this code). +# +# You should have received a copy of the GNU General Public License version +# 2 along with this work; if not, write to the Free Software Foundation, +# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. +# +# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA +# or visit www.oracle.com if you need additional information or have any +# questions. +# + +# Setup basic configuration paths, and platform-specific stuff related to PATHs. +AC_DEFUN([BASIC_CHECK_PATHS_WINDOWS], +[ + SRC_ROOT_LENGTH=`$THEPWDCMD -L|$WC -m` + if test $SRC_ROOT_LENGTH -gt 100; then + AC_MSG_ERROR([Your base path is too long. It is $SRC_ROOT_LENGTH characters long, but only 100 is supported]) + fi + + if test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.cygwin"; then + AC_MSG_CHECKING([cygwin release]) + CYGWIN_VERSION=`$UNAME -r` + AC_MSG_RESULT([$CYGWIN_VERSION]) + WINDOWS_ENV_VENDOR='cygwin' + WINDOWS_ENV_VERSION="$CYGWIN_VERSION" + + CYGWIN_VERSION_OLD=`$ECHO $CYGWIN_VERSION | $GREP -e '^1\.[0-6]'` + if test "x$CYGWIN_VERSION_OLD" != x; then + AC_MSG_NOTICE([Your cygwin is too old. You are running $CYGWIN_VERSION, but at least cygwin 1.7 is required. Please upgrade.]) + AC_MSG_ERROR([Cannot continue]) + fi + if test "x$CYGPATH" = x; then + AC_MSG_ERROR([Something is wrong with your cygwin installation since I cannot find cygpath.exe in your path]) + fi + AC_MSG_CHECKING([cygwin root directory as unix-style path]) + # The cmd output ends with Windows line endings (CR/LF) + cygwin_winpath_root=`cd / ; cmd /c cd | $TR -d '\r\n'` + # Force cygpath to report the proper root by including a trailing space, and then stripping it off again. + CYGWIN_ROOT_PATH=`$CYGPATH -u "$cygwin_winpath_root " | $CUT -f 1 -d " "` + AC_MSG_RESULT([$CYGWIN_ROOT_PATH]) + WINDOWS_ENV_ROOT_PATH="$CYGWIN_ROOT_PATH" + test_cygdrive_prefix=`$ECHO $CYGWIN_ROOT_PATH | $GREP ^/cygdrive/` + if test "x$test_cygdrive_prefix" = x; then + AC_MSG_ERROR([Your cygdrive prefix is not /cygdrive. This is currently not supported. Change with mount -c.]) + fi + elif test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.msys"; then + AC_MSG_CHECKING([msys release]) + MSYS_VERSION=`$UNAME -r` + AC_MSG_RESULT([$MSYS_VERSION]) + + WINDOWS_ENV_VENDOR='msys' + WINDOWS_ENV_VERSION="$MSYS_VERSION" + + AC_MSG_CHECKING([msys root directory as unix-style path]) + # The cmd output ends with Windows line endings (CR/LF), the grep command will strip that away + MSYS_ROOT_PATH=`cd / ; cmd /c cd | $GREP ".*"` + UTIL_REWRITE_AS_UNIX_PATH(MSYS_ROOT_PATH) + AC_MSG_RESULT([$MSYS_ROOT_PATH]) + WINDOWS_ENV_ROOT_PATH="$MSYS_ROOT_PATH" + elif test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.wsl"; then + AC_MSG_CHECKING([Windows version]) + # m4 replaces [ and ] so we use @<:@ and @:>@ instead + WINDOWS_VERSION=`$CMD /c ver.exe | $EGREP -o '(@<:@0-9@:>@+\.)+@<:@0-9@:>@+'` + AC_MSG_RESULT([$WINDOWS_VERSION]) + + AC_MSG_CHECKING([WSL kernel version]) + WSL_KERNEL_VERSION=`$UNAME -v` + AC_MSG_RESULT([$WSL_KERNEL_VERSION]) + + AC_MSG_CHECKING([WSL kernel release]) + WSL_KERNEL_RELEASE=`$UNAME -r` + AC_MSG_RESULT([$WSL_KERNEL_RELEASE]) + + AC_MSG_CHECKING([WSL distribution]) + WSL_DISTRIBUTION=`$LSB_RELEASE -d | sed 's/Description:\t//'` + AC_MSG_RESULT([$WSL_DISTRIBUTION]) + + WINDOWS_ENV_VENDOR='WSL' + WINDOWS_ENV_VERSION="$WSL_DISTRIBUTION $WSL_KERNEL_VERSION $WSL_KERNEL_RELEASE (on Windows build $WINDOWS_VERSION)" + else + AC_MSG_ERROR([Unknown Windows environment. Neither cygwin, msys, nor wsl was detected.]) + fi + + # Test if windows or unix (cygwin/msys) find is first in path. + AC_MSG_CHECKING([what kind of 'find' is first on the PATH]) + FIND_BINARY_OUTPUT=`find --version 2>&1` + if test "x`echo $FIND_BINARY_OUTPUT | $GREP GNU`" != x; then + AC_MSG_RESULT([unix style]) + elif test "x`echo $FIND_BINARY_OUTPUT | $GREP FIND`" != x; then + AC_MSG_RESULT([Windows]) + AC_MSG_NOTICE([Your path contains Windows tools (C:\Windows\system32) before your unix (cygwin or msys) tools.]) + AC_MSG_NOTICE([This will not work. Please correct and make sure /usr/bin (or similar) is first in path.]) + AC_MSG_ERROR([Cannot continue]) + else + AC_MSG_RESULT([unknown]) + AC_MSG_WARN([It seems that your find utility is non-standard.]) + fi +]) + +AC_DEFUN_ONCE([BASIC_COMPILE_FIXPATH], +[ + # When using cygwin or msys, we need a wrapper binary that renames + # /cygdrive/c/ arguments into c:/ arguments and peeks into + # @files and rewrites these too! This wrapper binary is + # called fixpath. + FIXPATH= + if test "x$OPENJDK_BUILD_OS" = xwindows; then + AC_MSG_CHECKING([if fixpath can be created]) + FIXPATH_SRC="$TOPDIR/make/src/native/fixpath.c" + FIXPATH_BIN="$CONFIGURESUPPORT_OUTPUTDIR/bin/fixpath.exe" + FIXPATH_DIR="$CONFIGURESUPPORT_OUTPUTDIR/fixpath" + if test "x$OPENJDK_BUILD_OS_ENV" = xwindows.cygwin; then + # Important to keep the .exe suffix on Cygwin for Hotspot makefiles + FIXPATH="$FIXPATH_BIN -c" + elif test "x$OPENJDK_BUILD_OS_ENV" = xwindows.msys; then + # Take all collected prefixes and turn them into a -m/c/foo@/c/bar@... command line + # @ was chosen as separator to minimize risk of other tools messing around with it + all_unique_prefixes=`echo "${all_fixpath_prefixes@<:@@@:>@}" \ + | tr ' ' '\n' | $GREP '^/./' | $SORT | $UNIQ` + fixpath_argument_list=`echo $all_unique_prefixes | tr ' ' '@'` + FIXPATH="$FIXPATH_BIN -m$fixpath_argument_list" + elif test "x$OPENJDK_BUILD_OS_ENV" = xwindows.wsl; then + FIXPATH="$FIXPATH_BIN -w" + fi + FIXPATH_SRC_W="$FIXPATH_SRC" + FIXPATH_BIN_W="$FIXPATH_BIN" + UTIL_REWRITE_AS_WINDOWS_MIXED_PATH([FIXPATH_SRC_W]) + UTIL_REWRITE_AS_WINDOWS_MIXED_PATH([FIXPATH_BIN_W]) + $RM -rf $FIXPATH_BIN $FIXPATH_DIR + $MKDIR -p $FIXPATH_DIR $CONFIGURESUPPORT_OUTPUTDIR/bin + cd $FIXPATH_DIR + $CC $FIXPATH_SRC_W -Fe$FIXPATH_BIN_W > $FIXPATH_DIR/fixpath1.log 2>&1 + cd $CONFIGURE_START_DIR + + if test ! -x $FIXPATH_BIN; then + AC_MSG_RESULT([no]) + cat $FIXPATH_DIR/fixpath1.log + AC_MSG_ERROR([Could not create $FIXPATH_BIN]) + fi + AC_MSG_RESULT([yes]) + + if test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.wsl"; then + OLD_WSLENV="$WSLENV" + WSLENV=`$ECHO $WSLENV | $SED 's/PATH\/l://'` + UTIL_APPEND_TO_PATH(WSLENV, "FIXPATH_PATH") + export WSLENV + export FIXPATH_PATH=$VS_PATH_WINDOWS + AC_MSG_NOTICE([FIXPATH_PATH is $FIXPATH_PATH]) + AC_MSG_NOTICE([Rewriting WSLENV from $OLD_WSLENV to $WSLENV]) + fi + + AC_MSG_CHECKING([if fixpath.exe works]) + cd $FIXPATH_DIR + $FIXPATH $CC $FIXPATH_SRC -Fe$FIXPATH_DIR/fixpath2.exe \ + > $FIXPATH_DIR/fixpath2.log 2>&1 + cd $CONFIGURE_START_DIR + if test ! -x $FIXPATH_DIR/fixpath2.exe; then + AC_MSG_RESULT([no]) + cat $FIXPATH_DIR/fixpath2.log + AC_MSG_ERROR([fixpath did not work!]) + fi + AC_MSG_RESULT([yes]) + + FIXPATH_DETACH_FLAG="--detach" + fi + + AC_SUBST(FIXPATH) + AC_SUBST(FIXPATH_DETACH_FLAG) +]) diff --git a/make/autoconf/basics.m4 b/make/autoconf/basics.m4 deleted file mode 100644 index 028890d8428..00000000000 --- a/make/autoconf/basics.m4 +++ /dev/null @@ -1,1552 +0,0 @@ -# -# Copyright (c) 2011, 2020, Oracle and/or its affiliates. All rights reserved. -# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. -# -# This code is free software; you can redistribute it and/or modify it -# under the terms of the GNU General Public License version 2 only, as -# published by the Free Software Foundation. Oracle designates this -# particular file as subject to the "Classpath" exception as provided -# by Oracle in the LICENSE file that accompanied this code. -# -# This code is distributed in the hope that it will be useful, but WITHOUT -# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or -# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License -# version 2 for more details (a copy is included in the LICENSE file that -# accompanied this code). -# -# You should have received a copy of the GNU General Public License version -# 2 along with this work; if not, write to the Free Software Foundation, -# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. -# -# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA -# or visit www.oracle.com if you need additional information or have any -# questions. -# - -############################################################################### -# Create a function/macro that takes a series of named arguments. The call is -# similar to AC_DEFUN, but the setup of the function looks like this: -# BASIC_DEFUN_NAMED([MYFUNC], [FOO *BAR], [$@], [ -# ... do something -# AC_MSG_NOTICE([Value of BAR is ARG_BAR]) -# ]) -# A star (*) in front of a named argument means that it is required and it's -# presence will be verified. To pass e.g. the first value as a normal indexed -# argument, use [m4_shift($@)] as the third argument instead of [$@]. These -# arguments are referenced in the function by their name prefixed by ARG_, e.g. -# "ARG_FOO". -# -# The generated function can be called like this: -# MYFUNC(FOO: [foo-val], -# BAR: [ -# $ECHO hello world -# ]) -# Note that the argument value must start on the same line as the argument name. -# -# Argument 1: Name of the function to define -# Argument 2: List of legal named arguments, with a * prefix for required arguments -# Argument 3: Argument array to treat as named, typically $@ -# Argument 4: The main function body -AC_DEFUN([BASIC_DEFUN_NAMED], -[ - AC_DEFUN($1, [ - m4_foreach(arg, m4_split($2), [ - m4_if(m4_bregexp(arg, [^\*]), -1, - [ - m4_set_add(legal_named_args, arg) - ], - [ - m4_set_add(legal_named_args, m4_substr(arg, 1)) - m4_set_add(required_named_args, m4_substr(arg, 1)) - ] - ) - ]) - - m4_foreach([arg], [$3], [ - m4_define(arg_name, m4_substr(arg, 0, m4_bregexp(arg, [: ]))) - m4_set_contains(legal_named_args, arg_name, [],[AC_MSG_ERROR([Internal error: arg_name is not a valid named argument to [$1]. Valid arguments are 'm4_set_contents(legal_named_args, [ ])'.])]) - m4_set_remove(required_named_args, arg_name) - m4_set_remove(legal_named_args, arg_name) - m4_pushdef([ARG_][]arg_name, m4_substr(arg, m4_incr(m4_incr(m4_bregexp(arg, [: ]))))) - m4_set_add(defined_args, arg_name) - m4_undefine([arg_name]) - ]) - m4_set_empty(required_named_args, [], [ - AC_MSG_ERROR([Internal error: Required named arguments are missing for [$1]. Missing arguments: 'm4_set_contents(required_named_args, [ ])']) - ]) - m4_foreach([arg], m4_indir([m4_dquote]m4_set_listc([legal_named_args])), [ - m4_pushdef([ARG_][]arg, []) - m4_set_add(defined_args, arg) - ]) - m4_set_delete(legal_named_args) - m4_set_delete(required_named_args) - - # Execute function body - $4 - - m4_foreach([arg], m4_indir([m4_dquote]m4_set_listc([defined_args])), [ - m4_popdef([ARG_][]arg) - ]) - - m4_set_delete(defined_args) - ]) -]) - -############################################################################### -# Check if a list of space-separated words are selected only from a list of -# space-separated legal words. Typical use is to see if a user-specified -# set of words is selected from a set of legal words. -# -# Sets the specified variable to list of non-matching (offending) words, or to -# the empty string if all words are matching the legal set. -# -# $1: result variable name -# $2: list of values to check -# $3: list of legal values -AC_DEFUN([BASIC_GET_NON_MATCHING_VALUES], -[ - # grep filter function inspired by a comment to http://stackoverflow.com/a/1617326 - # Notice that the original variant fails on SLES 10 and 11 - # Some grep versions (at least bsd) behaves strangely on the base case with - # no legal_values, so make it explicit. - values_to_check=`$ECHO $2 | $TR ' ' '\n'` - legal_values=`$ECHO $3 | $TR ' ' '\n'` - if test -z "$legal_values"; then - $1="$2" - else - result=`$GREP -Fvx "$legal_values" <<< "$values_to_check" | $GREP -v '^$'` - $1=${result//$'\n'/ } - fi -]) - -############################################################################### -# Check if a list of space-separated words contains any word(s) from a list of -# space-separated illegal words. Typical use is to see if a user-specified -# set of words contains any from a set of illegal words. -# -# Sets the specified variable to list of matching illegal words, or to -# the empty string if no words are matching the illegal set. -# -# $1: result variable name -# $2: list of values to check -# $3: list of illegal values -AC_DEFUN([BASIC_GET_MATCHING_VALUES], -[ - # grep filter function inspired by a comment to http://stackoverflow.com/a/1617326 - # Notice that the original variant fails on SLES 10 and 11 - # Some grep versions (at least bsd) behaves strangely on the base case with - # no legal_values, so make it explicit. - values_to_check=`$ECHO $2 | $TR ' ' '\n'` - illegal_values=`$ECHO $3 | $TR ' ' '\n'` - if test -z "$illegal_values"; then - $1="" - else - result=`$GREP -Fx "$illegal_values" <<< "$values_to_check" | $GREP -v '^$'` - $1=${result//$'\n'/ } - fi -]) - -############################################################################### -# Sort a space-separated list, and remove duplicates. -# -# Sets the specified variable to the resulting list. -# -# $1: result variable name -# $2: list of values to sort -AC_DEFUN([BASIC_SORT_LIST], -[ - values_to_sort=`$ECHO $2 | $TR ' ' '\n'` - result=`$SORT -u <<< "$values_to_sort" | $GREP -v '^$'` - $1=${result//$'\n'/ } -]) - -############################################################################### -# Test if $1 is a valid argument to $3 (often is $JAVA passed as $3) -# If so, then append $1 to $2 \ -# Also set JVM_ARG_OK to true/false depending on outcome. -AC_DEFUN([ADD_JVM_ARG_IF_OK], -[ - $ECHO "Check if jvm arg is ok: $1" >&AS_MESSAGE_LOG_FD - $ECHO "Command: $3 $1 -version" >&AS_MESSAGE_LOG_FD - OUTPUT=`$3 $1 $USER_BOOT_JDK_OPTIONS -version 2>&1` - FOUND_WARN=`$ECHO "$OUTPUT" | $GREP -i warn` - FOUND_VERSION=`$ECHO $OUTPUT | $GREP " version \""` - if test "x$FOUND_VERSION" != x && test "x$FOUND_WARN" = x; then - $2="[$]$2 $1" - JVM_ARG_OK=true - else - $ECHO "Arg failed:" >&AS_MESSAGE_LOG_FD - $ECHO "$OUTPUT" >&AS_MESSAGE_LOG_FD - JVM_ARG_OK=false - fi -]) - -# Appends a string to a path variable, only adding the : when needed. -AC_DEFUN([BASIC_APPEND_TO_PATH], -[ - if test "x$2" != x; then - if test "x[$]$1" = x; then - $1="$2" - else - $1="[$]$1:$2" - fi - fi -]) - -# Prepends a string to a path variable, only adding the : when needed. -AC_DEFUN([BASIC_PREPEND_TO_PATH], -[ - if test "x$2" != x; then - if test "x[$]$1" = x; then - $1="$2" - else - $1="$2:[$]$1" - fi - fi -]) - -################################################################################ -# This will make a path absolute. Assumes it's already a unix path. Also -# resolves ~ to homedir. -AC_DEFUN([BASIC_ABSOLUTE_PATH], -[ - if test "x[$]$1" != x; then - new_path="[$]$1" - - # Use eval to expand a potential ~. This technique does not work if there - # are spaces in the path (which is valid at this point on Windows), so only - # try to apply it if there is an actual ~ first in the path. - if [ [[ "$new_path" = "~"* ]] ]; then - eval new_path="$new_path" - if test ! -f "$new_path" && test ! -d "$new_path"; then - AC_MSG_ERROR([The new_path of $1, which resolves as "$new_path", is not found.]) - fi - fi - - if test -d "$new_path"; then - $1="`cd "$new_path"; $THEPWDCMD -L`" - else - dir="`$DIRNAME "$new_path"`" - base="`$BASENAME "$new_path"`" - $1="`cd "$dir"; $THEPWDCMD -L`/$base" - fi - fi -]) - -############################################################################### -# This will make sure the given variable points to a full and proper -# path. This means: -# 1) There will be no spaces in the path. On unix platforms, -# spaces in the path will result in an error. On Windows, -# the path will be rewritten using short-style to be space-free. -# 2) The path will be absolute, and it will be in unix-style (on -# cygwin). -# $1: The name of the variable to fix -AC_DEFUN([BASIC_FIXUP_PATH], -[ - # Only process if variable expands to non-empty - if test "x[$]$1" != x; then - if test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.cygwin"; then - BASIC_FIXUP_PATH_CYGWIN($1) - elif test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.msys"; then - BASIC_FIXUP_PATH_MSYS($1) - elif test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.wsl"; then - BASIC_FIXUP_PATH_WSL($1) - else - # We're on a unix platform. Hooray! :) - path="[$]$1" - has_space=`$ECHO "$path" | $GREP " "` - if test "x$has_space" != x; then - AC_MSG_NOTICE([The path of $1, which resolves as "$path", is invalid.]) - AC_MSG_ERROR([Spaces are not allowed in this path.]) - fi - - BASIC_ABSOLUTE_PATH(path) - $1="$path" - fi - fi -]) - -############################################################################### -# This will make sure the given variable points to a executable -# with a full and proper path. This means: -# 1) There will be no spaces in the path. On unix platforms, -# spaces in the path will result in an error. On Windows, -# the path will be rewritten using short-style to be space-free. -# 2) The path will be absolute, and it will be in unix-style (on -# cygwin). -# Any arguments given to the executable is preserved. -# If the input variable does not have a directory specification, then -# it need to be in the PATH. -# $1: The name of the variable to fix -AC_DEFUN([BASIC_FIXUP_EXECUTABLE], -[ - # Only process if variable expands to non-empty - - if test "x[$]$1" != x; then - if test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.cygwin"; then - BASIC_FIXUP_EXECUTABLE_CYGWIN($1) - elif test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.msys"; then - BASIC_FIXUP_EXECUTABLE_MSYS($1) - elif test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.wsl"; then - BASIC_FIXUP_EXECUTABLE_WSL($1) - else - # We're on a unix platform. Hooray! :) - # First separate the path from the arguments. This will split at the first - # space. - complete="[$]$1" - path="${complete%% *}" - tmp="$complete EOL" - arguments="${tmp#* }" - - # Cannot rely on the command "which" here since it doesn't always work. - is_absolute_path=`$ECHO "$path" | $GREP ^/` - if test -z "$is_absolute_path"; then - # Path to executable is not absolute. Find it. - IFS_save="$IFS" - IFS=: - for p in $PATH; do - if test -f "$p/$path" && test -x "$p/$path"; then - new_path="$p/$path" - break - fi - done - IFS="$IFS_save" - else - # This is an absolute path, we can use it without further modifications. - new_path="$path" - fi - - if test "x$new_path" = x; then - AC_MSG_NOTICE([The path of $1, which resolves as "$complete", is not found.]) - has_space=`$ECHO "$complete" | $GREP " "` - if test "x$has_space" != x; then - AC_MSG_NOTICE([This might be caused by spaces in the path, which is not allowed.]) - fi - AC_MSG_ERROR([Cannot locate the the path of $1]) - fi - fi - - # Now join together the path and the arguments once again - if test "x$arguments" != xEOL; then - new_complete="$new_path ${arguments% *}" - else - new_complete="$new_path" - fi - - if test "x$complete" != "x$new_complete"; then - $1="$new_complete" - AC_MSG_NOTICE([Rewriting $1 to "$new_complete"]) - fi - fi -]) - -############################################################################### -AC_DEFUN([BASIC_REMOVE_SYMBOLIC_LINKS], -[ - if test "x$OPENJDK_BUILD_OS" != xwindows; then - # Follow a chain of symbolic links. Use readlink - # where it exists, else fall back to horribly - # complicated shell code. - if test "x$READLINK_TESTED" != yes; then - # On MacOSX there is a readlink tool with a different - # purpose than the GNU readlink tool. Check the found readlink. - READLINK_ISGNU=`$READLINK --version 2>&1 | $GREP GNU` - # If READLINK_ISGNU is empty, then it's a non-GNU readlink. Don't use it. - READLINK_TESTED=yes - fi - - if test "x$READLINK" != x && test "x$READLINK_ISGNU" != x; then - $1=`$READLINK -f [$]$1` - else - # Save the current directory for restoring afterwards - STARTDIR=$PWD - COUNTER=0 - sym_link_dir=`$DIRNAME [$]$1` - sym_link_file=`$BASENAME [$]$1` - cd $sym_link_dir - # Use -P flag to resolve symlinks in directories. - cd `$THEPWDCMD -P` - sym_link_dir=`$THEPWDCMD -P` - # Resolve file symlinks - while test $COUNTER -lt 20; do - ISLINK=`$LS -l $sym_link_dir/$sym_link_file | $GREP '\->' | $SED -e 's/.*-> \(.*\)/\1/'` - if test "x$ISLINK" == x; then - # This is not a symbolic link! We are done! - break - fi - # Again resolve directory symlinks since the target of the just found - # link could be in a different directory - cd `$DIRNAME $ISLINK` - sym_link_dir=`$THEPWDCMD -P` - sym_link_file=`$BASENAME $ISLINK` - let COUNTER=COUNTER+1 - done - cd $STARTDIR - $1=$sym_link_dir/$sym_link_file - fi - fi -]) - -############################################################################### -# Register a --with argument but mark it as deprecated -# $1: The name of the with argument to deprecate, not including --with- -AC_DEFUN([BASIC_DEPRECATED_ARG_WITH], -[ - AC_ARG_WITH($1, [AS_HELP_STRING([--with-$1], - [Deprecated. Option is kept for backwards compatibility and is ignored])], - [AC_MSG_WARN([Option --with-$1 is deprecated and will be ignored.])]) -]) - -############################################################################### -# Register a --enable argument but mark it as deprecated -# $1: The name of the with argument to deprecate, not including --enable- -# $2: The name of the argument to deprecate, in shell variable style (i.e. with _ instead of -) -# $3: Messages to user. -AC_DEFUN([BASIC_DEPRECATED_ARG_ENABLE], -[ - AC_ARG_ENABLE($1, [AS_HELP_STRING([--enable-$1], - [Deprecated. Option is kept for backwards compatibility and is ignored])]) - if test "x$enable_$2" != x; then - AC_MSG_WARN([Option --enable-$1 is deprecated and will be ignored.]) - - if test "x$3" != x; then - AC_MSG_WARN([$3]) - fi - - fi -]) - -############################################################################### -# Register an --enable-* argument as an alias for another argument. -# $1: The name of the enable argument for the new alias, not including --enable- -# $2: The full name of the argument of which to make this an alias, including -# --enable- or --with-. -AC_DEFUN([BASIC_ALIASED_ARG_ENABLE], -[ - AC_ARG_ENABLE($1, [AS_HELP_STRING([--enable-$1], [alias for $2])], [ - # Use m4 to strip initial -- from target ($2), convert - to _, prefix enable_ - # to new alias name, and create a shell variable assignment, - # e.g.: enable_old_style="$enable_new_alias" - translit(patsubst($2, --), -, _)="$[enable_]translit($1, -, _)" - ]) -]) - -############################################################################### -AC_DEFUN_ONCE([BASIC_INIT], -[ - # Save the original command line. This is passed to us by the wrapper configure script. - AC_SUBST(CONFIGURE_COMMAND_LINE) - # AUTOCONF might be set in the environment by the user. Preserve for "make reconfigure". - AC_SUBST(AUTOCONF) - # Save the path variable before it gets changed - ORIGINAL_PATH="$PATH" - AC_SUBST(ORIGINAL_PATH) - DATE_WHEN_CONFIGURED=`date` - AC_SUBST(DATE_WHEN_CONFIGURED) - AC_MSG_NOTICE([Configuration created at $DATE_WHEN_CONFIGURED.]) -]) - -############################################################################### -# Test that variable $1 denoting a program is not empty. If empty, exit with an error. -# $1: variable to check -AC_DEFUN([BASIC_CHECK_NONEMPTY], -[ - if test "x[$]$1" = x; then - AC_MSG_ERROR([Could not find required tool for $1]) - fi -]) - -############################################################################### -# Check that there are no unprocessed overridden variables left. -# If so, they are an incorrect argument and we will exit with an error. -AC_DEFUN([BASIC_CHECK_LEFTOVER_OVERRIDDEN], -[ - if test "x$CONFIGURE_OVERRIDDEN_VARIABLES" != x; then - # Replace the separating ! with spaces before presenting for end user. - unknown_variables=${CONFIGURE_OVERRIDDEN_VARIABLES//!/ } - AC_MSG_WARN([The following variables might be unknown to configure: $unknown_variables]) - fi -]) - -############################################################################### -# Setup a tool for the given variable. If correctly specified by the user, -# use that value, otherwise search for the tool using the supplied code snippet. -# $1: variable to set -# $2: code snippet to call to look for the tool -# $3: code snippet to call if variable was used to find tool -AC_DEFUN([BASIC_SETUP_TOOL], -[ - # Publish this variable in the help. - AC_ARG_VAR($1, [Override default value for $1]) - - if [[ -z "${$1+x}" ]]; then - # The variable is not set by user, try to locate tool using the code snippet - $2 - else - # The variable is set, but is it from the command line or the environment? - - # Try to remove the string !$1! from our list. - try_remove_var=${CONFIGURE_OVERRIDDEN_VARIABLES//!$1!/} - if test "x$try_remove_var" = "x$CONFIGURE_OVERRIDDEN_VARIABLES"; then - # If it failed, the variable was not from the command line. Ignore it, - # but warn the user (except for BASH, which is always set by the calling BASH). - if test "x$1" != xBASH; then - AC_MSG_WARN([Ignoring value of $1 from the environment. Use command line variables instead.]) - fi - # Try to locate tool using the code snippet - $2 - else - # If it succeeded, then it was overridden by the user. We will use it - # for the tool. - - # First remove it from the list of overridden variables, so we can test - # for unknown variables in the end. - CONFIGURE_OVERRIDDEN_VARIABLES="$try_remove_var" - - tool_override=[$]$1 - AC_MSG_NOTICE([User supplied override $1="$tool_override"]) - - # Check if we try to supply an empty value - if test "x$tool_override" = x; then - AC_MSG_CHECKING([for $1]) - AC_MSG_RESULT([disabled]) - else - # Split up override in command part and argument part - tool_and_args=($tool_override) - [ tool_command=${tool_and_args[0]} ] - [ unset 'tool_and_args[0]' ] - [ tool_args=${tool_and_args[@]} ] - - # Check if the provided tool contains a complete path. - tool_basename="${tool_command##*/}" - if test "x$tool_basename" = "x$tool_command"; then - # A command without a complete path is provided, search $PATH. - AC_MSG_NOTICE([Will search for user supplied tool "$tool_basename"]) - AC_PATH_PROG($1, $tool_basename) - if test "x[$]$1" = x; then - AC_MSG_ERROR([User supplied tool $1="$tool_basename" could not be found]) - fi - else - # Otherwise we believe it is a complete path. Use it as it is. - AC_MSG_NOTICE([Will use user supplied tool "$tool_command"]) - AC_MSG_CHECKING([for $tool_command]) - if test ! -x "$tool_command"; then - AC_MSG_RESULT([not found]) - AC_MSG_ERROR([User supplied tool $1="$tool_command" does not exist or is not executable]) - fi - $1="$tool_command" - AC_MSG_RESULT([found]) - fi - if test "x$tool_args" != x; then - # If we got arguments, re-append them to the command after the fixup. - $1="[$]$1 $tool_args" - fi - fi - fi - $3 - fi -]) - -############################################################################### -# Call BASIC_SETUP_TOOL with AC_PATH_PROGS to locate the tool -# $1: variable to set -# $2: executable name (or list of names) to look for -# $3: [path] -AC_DEFUN([BASIC_PATH_PROGS], -[ - BASIC_SETUP_TOOL($1, [AC_PATH_PROGS($1, $2, , $3)]) -]) - -############################################################################### -# Call BASIC_SETUP_TOOL with AC_CHECK_TOOLS to locate the tool -# $1: variable to set -# $2: executable name (or list of names) to look for -AC_DEFUN([BASIC_CHECK_TOOLS], -[ - BASIC_SETUP_TOOL($1, [AC_CHECK_TOOLS($1, $2)]) -]) - -############################################################################### -# Like BASIC_PATH_PROGS but fails if no tool was found. -# $1: variable to set -# $2: executable name (or list of names) to look for -# $3: [path] -AC_DEFUN([BASIC_REQUIRE_PROGS], -[ - BASIC_PATH_PROGS($1, $2, , $3) - BASIC_CHECK_NONEMPTY($1) -]) - -############################################################################### -# Like BASIC_SETUP_TOOL but fails if no tool was found. -# $1: variable to set -# $2: autoconf macro to call to look for the special tool -AC_DEFUN([BASIC_REQUIRE_SPECIAL], -[ - BASIC_SETUP_TOOL($1, [$2]) - BASIC_CHECK_NONEMPTY($1) -]) - -############################################################################### -# Like BASIC_REQUIRE_PROGS but also allows for bash built-ins -# $1: variable to set -# $2: executable name (or list of names) to look for -# $3: [path] -AC_DEFUN([BASIC_REQUIRE_BUILTIN_PROGS], -[ - BASIC_SETUP_TOOL($1, [AC_PATH_PROGS($1, $2, , $3)]) - if test "x[$]$1" = x; then - AC_MSG_NOTICE([Required tool $2 not found in PATH, checking built-in]) - if help $2 > /dev/null 2>&1; then - AC_MSG_NOTICE([Found $2 as shell built-in. Using it]) - $1="$2" - else - AC_MSG_ERROR([Required tool $2 also not found as built-in.]) - fi - fi - BASIC_CHECK_NONEMPTY($1) -]) - -############################################################################### -# Setup the most fundamental tools that relies on not much else to set up, -# but is used by much of the early bootstrap code. -AC_DEFUN_ONCE([BASIC_SETUP_FUNDAMENTAL_TOOLS], -[ - # Start with tools that do not need have cross compilation support - # and can be expected to be found in the default PATH. These tools are - # used by configure. - - # First are all the simple required tools. - BASIC_REQUIRE_PROGS(BASENAME, basename) - BASIC_REQUIRE_PROGS(BASH, bash) - BASIC_REQUIRE_PROGS(CAT, cat) - BASIC_REQUIRE_PROGS(CHMOD, chmod) - BASIC_REQUIRE_PROGS(CMP, cmp) - BASIC_REQUIRE_PROGS(COMM, comm) - BASIC_REQUIRE_PROGS(CP, cp) - BASIC_REQUIRE_PROGS(CUT, cut) - BASIC_REQUIRE_PROGS(DATE, date) - BASIC_REQUIRE_PROGS(DIFF, [gdiff diff]) - BASIC_REQUIRE_PROGS(DIRNAME, dirname) - BASIC_REQUIRE_PROGS(ECHO, echo) - BASIC_REQUIRE_PROGS(EXPR, expr) - BASIC_REQUIRE_PROGS(FILE, file) - BASIC_REQUIRE_PROGS(FIND, find) - BASIC_REQUIRE_PROGS(HEAD, head) - BASIC_REQUIRE_PROGS(GUNZIP, gunzip) - BASIC_REQUIRE_PROGS(GZIP, pigz gzip) - BASIC_REQUIRE_PROGS(LN, ln) - BASIC_REQUIRE_PROGS(LS, ls) - # gmkdir is known to be safe for concurrent invocations with -p flag. - BASIC_REQUIRE_PROGS(MKDIR, [gmkdir mkdir]) - BASIC_REQUIRE_PROGS(MKTEMP, mktemp) - BASIC_REQUIRE_PROGS(MV, mv) - BASIC_REQUIRE_PROGS(NAWK, [nawk gawk awk]) - BASIC_REQUIRE_PROGS(PRINTF, printf) - BASIC_REQUIRE_PROGS(READLINK, [greadlink readlink]) - BASIC_REQUIRE_PROGS(RM, rm) - BASIC_REQUIRE_PROGS(RMDIR, rmdir) - BASIC_REQUIRE_PROGS(SH, sh) - BASIC_REQUIRE_PROGS(SORT, sort) - BASIC_REQUIRE_PROGS(TAIL, tail) - BASIC_REQUIRE_PROGS(TAR, gtar tar) - BASIC_REQUIRE_PROGS(TEE, tee) - BASIC_REQUIRE_PROGS(TOUCH, touch) - BASIC_REQUIRE_PROGS(TR, tr) - BASIC_REQUIRE_PROGS(UNAME, uname) - BASIC_REQUIRE_PROGS(UNIQ, uniq) - BASIC_REQUIRE_PROGS(WC, wc) - BASIC_REQUIRE_PROGS(WHICH, which) - BASIC_REQUIRE_PROGS(XARGS, xargs) - - # Then required tools that require some special treatment. - BASIC_REQUIRE_SPECIAL(AWK, [AC_PROG_AWK]) - BASIC_REQUIRE_SPECIAL(GREP, [AC_PROG_GREP]) - BASIC_REQUIRE_SPECIAL(EGREP, [AC_PROG_EGREP]) - BASIC_REQUIRE_SPECIAL(FGREP, [AC_PROG_FGREP]) - BASIC_REQUIRE_SPECIAL(SED, [AC_PROG_SED]) - - # Always force rm. - RM="$RM -f" - - # pwd behaves differently on various platforms and some don't support the -L flag. - # Always use the bash builtin pwd to get uniform behavior. - THEPWDCMD=pwd - - # These are not required on all platforms - BASIC_PATH_PROGS(CYGPATH, cygpath) - BASIC_PATH_PROGS(WSLPATH, wslpath) - BASIC_PATH_PROGS(DF, df) - BASIC_PATH_PROGS(CPIO, [cpio bsdcpio]) - BASIC_PATH_PROGS(NICE, nice) - - BASIC_PATH_PROGS(LSB_RELEASE, lsb_release) - BASIC_PATH_PROGS(CMD, [cmd.exe /mnt/c/Windows/System32/cmd.exe]) -]) - -############################################################################### -# Setup basic configuration paths, and platform-specific stuff related to PATHs. -AC_DEFUN_ONCE([BASIC_SETUP_PATHS], -[ - # Save the current directory this script was started from - CONFIGURE_START_DIR="$PWD" - - # We might need to rewrite ORIGINAL_PATH, if it includes "#", to quote them - # for make. We couldn't do this when we retrieved ORIGINAL_PATH, since SED - # was not available at that time. - REWRITTEN_PATH=`$ECHO "$ORIGINAL_PATH" | $SED -e 's/#/\\\\#/g'` - if test "x$REWRITTEN_PATH" != "x$ORIGINAL_PATH"; then - ORIGINAL_PATH="$REWRITTEN_PATH" - AC_MSG_NOTICE([Rewriting ORIGINAL_PATH to $REWRITTEN_PATH]) - fi - - if test "x$OPENJDK_TARGET_OS" = "xwindows"; then - PATH_SEP=";" - EXE_SUFFIX=".exe" - BASIC_CHECK_PATHS_WINDOWS - else - PATH_SEP=":" - EXE_SUFFIX="" - fi - AC_SUBST(PATH_SEP) - AC_SUBST(EXE_SUFFIX) - - # We get the top-level directory from the supporting wrappers. - AC_MSG_CHECKING([for top-level directory]) - AC_MSG_RESULT([$TOPDIR]) - AC_SUBST(TOPDIR) - AC_SUBST(CONFIGURE_START_DIR) - - # We can only call BASIC_FIXUP_PATH after BASIC_CHECK_PATHS_WINDOWS. - BASIC_FIXUP_PATH(CONFIGURE_START_DIR) - BASIC_FIXUP_PATH(TOPDIR) - - # Locate the directory of this script. - AUTOCONF_DIR=$TOPDIR/make/autoconf - - # Setup username (for use in adhoc version strings etc) - # Outer [ ] to quote m4. - [ USERNAME=`$ECHO "$USER" | $TR -d -c '[a-z][A-Z][0-9]'` ] - AC_SUBST(USERNAME) -]) - -############################################################################### -# Evaluates platform specific overrides for devkit variables. -# $1: Name of variable -AC_DEFUN([BASIC_EVAL_DEVKIT_VARIABLE], -[ - if test "x[$]$1" = x; then - eval $1="\${$1_${OPENJDK_TARGET_CPU}}" - fi -]) - -############################################################################### -AC_DEFUN_ONCE([BASIC_SETUP_DEVKIT], -[ - AC_ARG_WITH([devkit], [AS_HELP_STRING([--with-devkit], - [use this devkit for compilers, tools and resources])]) - - if test "x$with_devkit" = xyes; then - AC_MSG_ERROR([--with-devkit must have a value]) - elif test "x$with_devkit" != x && test "x$with_devkit" != xno; then - BASIC_FIXUP_PATH([with_devkit]) - DEVKIT_ROOT="$with_devkit" - # Check for a meta data info file in the root of the devkit - if test -f "$DEVKIT_ROOT/devkit.info"; then - . $DEVKIT_ROOT/devkit.info - # This potentially sets the following: - # A descriptive name of the devkit - BASIC_EVAL_DEVKIT_VARIABLE([DEVKIT_NAME]) - # Corresponds to --with-extra-path - BASIC_EVAL_DEVKIT_VARIABLE([DEVKIT_EXTRA_PATH]) - # Corresponds to --with-toolchain-path - BASIC_EVAL_DEVKIT_VARIABLE([DEVKIT_TOOLCHAIN_PATH]) - # Corresponds to --with-sysroot - BASIC_EVAL_DEVKIT_VARIABLE([DEVKIT_SYSROOT]) - - # Identifies the Visual Studio version in the devkit - BASIC_EVAL_DEVKIT_VARIABLE([DEVKIT_VS_VERSION]) - # The Visual Studio include environment variable - BASIC_EVAL_DEVKIT_VARIABLE([DEVKIT_VS_INCLUDE]) - # The Visual Studio lib environment variable - BASIC_EVAL_DEVKIT_VARIABLE([DEVKIT_VS_LIB]) - # Corresponds to --with-msvcr-dll - BASIC_EVAL_DEVKIT_VARIABLE([DEVKIT_MSVCR_DLL]) - # Corresponds to --with-msvcp-dll - BASIC_EVAL_DEVKIT_VARIABLE([DEVKIT_MSVCP_DLL]) - # Corresponds to --with-ucrt-dll-dir - BASIC_EVAL_DEVKIT_VARIABLE([DEVKIT_UCRT_DLL_DIR]) - fi - - AC_MSG_CHECKING([for devkit]) - if test "x$DEVKIT_NAME" != x; then - AC_MSG_RESULT([$DEVKIT_NAME in $DEVKIT_ROOT]) - else - AC_MSG_RESULT([$DEVKIT_ROOT]) - fi - - BASIC_PREPEND_TO_PATH([EXTRA_PATH],$DEVKIT_EXTRA_PATH) - - # Fallback default of just /bin if DEVKIT_PATH is not defined - if test "x$DEVKIT_TOOLCHAIN_PATH" = x; then - DEVKIT_TOOLCHAIN_PATH="$DEVKIT_ROOT/bin" - fi - BASIC_PREPEND_TO_PATH([TOOLCHAIN_PATH],$DEVKIT_TOOLCHAIN_PATH) - - # If DEVKIT_SYSROOT is set, use that, otherwise try a couple of known - # places for backwards compatiblity. - if test "x$DEVKIT_SYSROOT" != x; then - SYSROOT="$DEVKIT_SYSROOT" - elif test -d "$DEVKIT_ROOT/$host_alias/libc"; then - SYSROOT="$DEVKIT_ROOT/$host_alias/libc" - elif test -d "$DEVKIT_ROOT/$host/sys-root"; then - SYSROOT="$DEVKIT_ROOT/$host/sys-root" - fi - - if test "x$DEVKIT_ROOT" != x; then - DEVKIT_LIB_DIR="$DEVKIT_ROOT/lib" - if test "x$OPENJDK_TARGET_CPU_BITS" = x64; then - DEVKIT_LIB_DIR="$DEVKIT_ROOT/lib64" - fi - AC_SUBST(DEVKIT_LIB_DIR) - fi - fi - - # You can force the sysroot if the sysroot encoded into the compiler tools - # is not correct. - AC_ARG_WITH(sys-root, [AS_HELP_STRING([--with-sys-root], - [alias for --with-sysroot for backwards compatability])], - [SYSROOT=$with_sys_root] - ) - - AC_ARG_WITH(sysroot, [AS_HELP_STRING([--with-sysroot], - [use this directory as sysroot])], - [SYSROOT=$with_sysroot] - ) - - AC_ARG_WITH([tools-dir], [AS_HELP_STRING([--with-tools-dir], - [alias for --with-toolchain-path for backwards compatibility])], - [BASIC_PREPEND_TO_PATH([TOOLCHAIN_PATH],$with_tools_dir)] - ) - - AC_ARG_WITH([toolchain-path], [AS_HELP_STRING([--with-toolchain-path], - [prepend these directories when searching for toolchain binaries (compilers etc)])], - [BASIC_PREPEND_TO_PATH([TOOLCHAIN_PATH],$with_toolchain_path)] - ) - - AC_ARG_WITH([extra-path], [AS_HELP_STRING([--with-extra-path], - [prepend these directories to the default path])], - [BASIC_PREPEND_TO_PATH([EXTRA_PATH],$with_extra_path)] - ) - - if test "x$OPENJDK_BUILD_OS" = "xmacosx"; then - # If a devkit has been supplied, find xcodebuild in the toolchain_path. - # If not, detect if Xcode is installed by running xcodebuild -version - # if no Xcode installed, xcodebuild exits with 1 - # if Xcode is installed, even if xcode-select is misconfigured, then it exits with 0 - if test "x$DEVKIT_ROOT" != x || /usr/bin/xcodebuild -version >/dev/null 2>&1; then - # We need to use xcodebuild in the toolchain dir provided by the user, this will - # fall back on the stub binary in /usr/bin/xcodebuild - AC_PATH_PROG([XCODEBUILD], [xcodebuild], [/usr/bin/xcodebuild], [$TOOLCHAIN_PATH]) - else - # this should result in SYSROOT being empty, unless --with-sysroot is provided - # when only the command line tools are installed there are no SDKs, so headers - # are copied into the system frameworks - XCODEBUILD= - AC_SUBST(XCODEBUILD) - fi - - AC_MSG_CHECKING([for sdk name]) - AC_ARG_WITH([sdk-name], [AS_HELP_STRING([--with-sdk-name], - [use the platform SDK of the given name. @<:@macosx@:>@])], - [SDKNAME=$with_sdk_name] - ) - AC_MSG_RESULT([$SDKNAME]) - - # if toolchain path is specified then don't rely on system headers, they may not compile - HAVE_SYSTEM_FRAMEWORK_HEADERS=0 - test -z "$TOOLCHAIN_PATH" && \ - HAVE_SYSTEM_FRAMEWORK_HEADERS=`test ! -f /System/Library/Frameworks/Foundation.framework/Headers/Foundation.h; echo $?` - - if test -z "$SYSROOT"; then - if test -n "$XCODEBUILD"; then - # if we don't have system headers, use default SDK name (last resort) - if test -z "$SDKNAME" -a $HAVE_SYSTEM_FRAMEWORK_HEADERS -eq 0; then - SDKNAME=${SDKNAME:-macosx} - fi - - if test -n "$SDKNAME"; then - # Call xcodebuild to determine SYSROOT - SYSROOT=`"$XCODEBUILD" -sdk $SDKNAME -version | $GREP '^Path: ' | $SED 's/Path: //'` - fi - else - if test $HAVE_SYSTEM_FRAMEWORK_HEADERS -eq 0; then - AC_MSG_ERROR([No xcodebuild tool and no system framework headers found, use --with-sysroot or --with-sdk-name to provide a path to a valid SDK]) - fi - fi - else - # warn user if --with-sdk-name was also set - if test -n "$with_sdk_name"; then - AC_MSG_WARN([Both SYSROOT and --with-sdk-name are set, only SYSROOT will be used]) - fi - fi - - if test $HAVE_SYSTEM_FRAMEWORK_HEADERS -eq 0 -a -z "$SYSROOT"; then - # If no system framework headers, then SYSROOT must be set, or we won't build - AC_MSG_ERROR([Unable to determine SYSROOT and no headers found in /System/Library/Frameworks. Check Xcode configuration, --with-sysroot or --with-sdk-name arguments.]) - fi - - # Perform a basic sanity test - if test ! -f "$SYSROOT/System/Library/Frameworks/Foundation.framework/Headers/Foundation.h"; then - if test -z "$SYSROOT"; then - AC_MSG_ERROR([Unable to find required framework headers, provide a path to an SDK via --with-sysroot or --with-sdk-name and be sure Xcode is installed properly]) - else - AC_MSG_ERROR([Invalid SDK or SYSROOT path, dependent framework headers not found]) - fi - fi - - # set SDKROOT too, Xcode tools will pick it up - SDKROOT="$SYSROOT" - AC_SUBST(SDKROOT) - fi - - # Prepend the extra path to the global path - BASIC_PREPEND_TO_PATH([PATH],$EXTRA_PATH) - - AC_MSG_CHECKING([for sysroot]) - AC_MSG_RESULT([$SYSROOT]) - AC_MSG_CHECKING([for toolchain path]) - AC_MSG_RESULT([$TOOLCHAIN_PATH]) - AC_MSG_CHECKING([for extra path]) - AC_MSG_RESULT([$EXTRA_PATH]) -]) - -############################################################################### -AC_DEFUN_ONCE([BASIC_SETUP_OUTPUT_DIR], -[ - - AC_ARG_WITH(conf-name, [AS_HELP_STRING([--with-conf-name], - [use this as the name of the configuration @<:@generated from important configuration options@:>@])], - [ CONF_NAME=${with_conf_name} ]) - - # Test from where we are running configure, in or outside of src root. - AC_MSG_CHECKING([where to store configuration]) - if test "x$CONFIGURE_START_DIR" = "x$TOPDIR" \ - || test "x$CONFIGURE_START_DIR" = "x$CUSTOM_ROOT" \ - || test "x$CONFIGURE_START_DIR" = "x$TOPDIR/make/autoconf" \ - || test "x$CONFIGURE_START_DIR" = "x$TOPDIR/make" ; then - # We are running configure from the src root. - # Create a default ./build/target-variant-debuglevel output root. - if test "x${CONF_NAME}" = x; then - AC_MSG_RESULT([in default location]) - CONF_NAME="${OPENJDK_TARGET_OS}-${OPENJDK_TARGET_CPU}-${JVM_VARIANTS_WITH_AND}-${DEBUG_LEVEL}" - else - AC_MSG_RESULT([in build directory with custom name]) - fi - - if test "x$CUSTOM_ROOT" != x; then - WORKSPACE_ROOT="${CUSTOM_ROOT}" - else - WORKSPACE_ROOT="${TOPDIR}" - fi - OUTPUTDIR="${WORKSPACE_ROOT}/build/${CONF_NAME}" - $MKDIR -p "$OUTPUTDIR" - if test ! -d "$OUTPUTDIR"; then - AC_MSG_ERROR([Could not create build directory $OUTPUTDIR]) - fi - else - # We are running configure from outside of the src dir. - # Then use the current directory as output dir! - # If configuration is situated in normal build directory, just use the build - # directory name as configuration name, otherwise use the complete path. - if test "x${CONF_NAME}" = x; then - CONF_NAME=`$ECHO $CONFIGURE_START_DIR | $SED -e "s!^${TOPDIR}/build/!!"` - fi - OUTPUTDIR="$CONFIGURE_START_DIR" - AC_MSG_RESULT([in current directory]) - - # WARNING: This might be a bad thing to do. You need to be sure you want to - # have a configuration in this directory. Do some sanity checks! - - if test ! -e "$OUTPUTDIR/spec.gmk"; then - # If we have a spec.gmk, we have run here before and we are OK. Otherwise, check for - # other files - files_present=`$LS $OUTPUTDIR` - # Configure has already touched config.log and confdefs.h in the current dir when this check - # is performed. - filtered_files=`$ECHO "$files_present" \ - | $SED -e 's/config.log//g' \ - -e 's/configure.log//g' \ - -e 's/confdefs.h//g' \ - -e 's/configure-support//g' \ - -e 's/ //g' \ - | $TR -d '\n'` - if test "x$filtered_files" != x; then - AC_MSG_NOTICE([Current directory is $CONFIGURE_START_DIR.]) - AC_MSG_NOTICE([Since this is not the source root, configure will output the configuration here]) - AC_MSG_NOTICE([(as opposed to creating a configuration in /build/).]) - AC_MSG_NOTICE([However, this directory is not empty. This is not allowed, since it could]) - AC_MSG_NOTICE([seriously mess up just about everything.]) - AC_MSG_NOTICE([Try 'cd $TOPDIR' and restart configure]) - AC_MSG_NOTICE([(or create a new empty directory and cd to it).]) - AC_MSG_ERROR([Will not continue creating configuration in $CONFIGURE_START_DIR]) - fi - fi - fi - AC_MSG_CHECKING([what configuration name to use]) - AC_MSG_RESULT([$CONF_NAME]) - - BASIC_FIXUP_PATH(OUTPUTDIR) - - CONFIGURESUPPORT_OUTPUTDIR="$OUTPUTDIR/configure-support" - $MKDIR -p "$CONFIGURESUPPORT_OUTPUTDIR" - - SPEC="$OUTPUTDIR/spec.gmk" - AC_SUBST(SPEC) - AC_SUBST(CONF_NAME) - AC_SUBST(OUTPUTDIR) - AC_SUBST(WORKSPACE_ROOT) - AC_SUBST(CONFIGURESUPPORT_OUTPUTDIR) - - # The spec.gmk file contains all variables for the make system. - AC_CONFIG_FILES([$OUTPUTDIR/spec.gmk:$AUTOCONF_DIR/spec.gmk.in]) - # The bootcycle-spec.gmk file contains support for boot cycle builds. - AC_CONFIG_FILES([$OUTPUTDIR/bootcycle-spec.gmk:$AUTOCONF_DIR/bootcycle-spec.gmk.in]) - # The buildjdk-spec.gmk file contains support for building a buildjdk when cross compiling. - AC_CONFIG_FILES([$OUTPUTDIR/buildjdk-spec.gmk:$AUTOCONF_DIR/buildjdk-spec.gmk.in]) - # The compare.sh is used to compare the build output to other builds. - AC_CONFIG_FILES([$OUTPUTDIR/compare.sh:$AUTOCONF_DIR/compare.sh.in]) - # The generated Makefile knows where the spec.gmk is and where the source is. - # You can run make from the OUTPUTDIR, or from the top-level Makefile - # which will look for generated configurations - AC_CONFIG_FILES([$OUTPUTDIR/Makefile:$AUTOCONF_DIR/Makefile.in]) -]) - -#%%% Simple tools %%% - -############################################################################### -# Check if we have found a usable version of make -# $1: the path to a potential make binary (or empty) -# $2: the description on how we found this -AC_DEFUN([BASIC_CHECK_MAKE_VERSION], -[ - MAKE_CANDIDATE="$1" - DESCRIPTION="$2" - - # On Cygwin, we require a newer version of make than on other platforms - if test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.cygwin"; then - MAKE_VERSION_EXPR="-e 4\." - MAKE_REQUIRED_VERSION="4.0" - else - MAKE_VERSION_EXPR="-e 3\.8[[12]] -e 4\." - MAKE_REQUIRED_VERSION="3.81" - fi - - if test "x$MAKE_CANDIDATE" != x; then - AC_MSG_NOTICE([Testing potential make at $MAKE_CANDIDATE, found using $DESCRIPTION]) - MAKE_VERSION_STRING=`$MAKE_CANDIDATE --version | $HEAD -n 1` - IS_GNU_MAKE=`$ECHO $MAKE_VERSION_STRING | $GREP 'GNU Make'` - if test "x$IS_GNU_MAKE" = x; then - AC_MSG_NOTICE([Found potential make at $MAKE_CANDIDATE, however, this is not GNU Make. Ignoring.]) - else - IS_MODERN_MAKE=`$ECHO $MAKE_VERSION_STRING | $GREP $MAKE_VERSION_EXPR` - if test "x$IS_MODERN_MAKE" = x; then - AC_MSG_NOTICE([Found GNU make at $MAKE_CANDIDATE, however this is not version $MAKE_REQUIRED_VERSION or later. (it is: $MAKE_VERSION_STRING). Ignoring.]) - else - if test "x$OPENJDK_BUILD_OS" = "xwindows"; then - if test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.cygwin"; then - MAKE_EXPECTED_ENV='cygwin' - elif test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.msys"; then - MAKE_EXPECTED_ENV='msys' - elif test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.wsl"; then - MAKE_EXPECTED_ENV='x86_64-.*-linux-gnu' - else - AC_MSG_ERROR([Unknown Windows environment]) - fi - MAKE_BUILT_FOR=`$MAKE_CANDIDATE --version | $GREP -i 'built for'` - IS_MAKE_CORRECT_ENV=`$ECHO $MAKE_BUILT_FOR | $GREP $MAKE_EXPECTED_ENV` - else - # Not relevant for non-Windows - IS_MAKE_CORRECT_ENV=true - fi - if test "x$IS_MAKE_CORRECT_ENV" = x; then - AC_MSG_NOTICE([Found GNU make version $MAKE_VERSION_STRING at $MAKE_CANDIDATE, but it is not for $MAKE_EXPECTED_ENV (it says: $MAKE_BUILT_FOR). Ignoring.]) - else - FOUND_MAKE=$MAKE_CANDIDATE - BASIC_FIXUP_EXECUTABLE(FOUND_MAKE) - fi - fi - fi - fi -]) - -############################################################################### -AC_DEFUN([BASIC_CHECK_MAKE_OUTPUT_SYNC], -[ - # Check if make supports the output sync option and if so, setup using it. - AC_MSG_CHECKING([if make --output-sync is supported]) - if $MAKE --version -O > /dev/null 2>&1; then - OUTPUT_SYNC_SUPPORTED=true - AC_MSG_RESULT([yes]) - AC_MSG_CHECKING([for output-sync value]) - AC_ARG_WITH([output-sync], [AS_HELP_STRING([--with-output-sync], - [set make output sync type if supported by make. @<:@recurse@:>@])], - [OUTPUT_SYNC=$with_output_sync]) - if test "x$OUTPUT_SYNC" = "x"; then - OUTPUT_SYNC=none - fi - AC_MSG_RESULT([$OUTPUT_SYNC]) - if ! $MAKE --version -O$OUTPUT_SYNC > /dev/null 2>&1; then - AC_MSG_ERROR([Make did not the support the value $OUTPUT_SYNC as output sync type.]) - fi - else - OUTPUT_SYNC_SUPPORTED=false - AC_MSG_RESULT([no]) - fi - AC_SUBST(OUTPUT_SYNC_SUPPORTED) - AC_SUBST(OUTPUT_SYNC) -]) - -############################################################################### -# Goes looking for a usable version of GNU make. -AC_DEFUN([BASIC_CHECK_GNU_MAKE], -[ - BASIC_SETUP_TOOL([MAKE], - [ - # Try our hardest to locate a correct version of GNU make - AC_PATH_PROGS(CHECK_GMAKE, gmake) - BASIC_CHECK_MAKE_VERSION("$CHECK_GMAKE", [gmake in PATH]) - - if test "x$FOUND_MAKE" = x; then - AC_PATH_PROGS(CHECK_MAKE, make) - BASIC_CHECK_MAKE_VERSION("$CHECK_MAKE", [make in PATH]) - fi - - if test "x$FOUND_MAKE" = x; then - if test "x$TOOLCHAIN_PATH" != x; then - # We have a toolchain path, check that as well before giving up. - OLD_PATH=$PATH - PATH=$TOOLCHAIN_PATH:$PATH - AC_PATH_PROGS(CHECK_TOOLSDIR_GMAKE, gmake) - BASIC_CHECK_MAKE_VERSION("$CHECK_TOOLSDIR_GMAKE", [gmake in tools-dir]) - if test "x$FOUND_MAKE" = x; then - AC_PATH_PROGS(CHECK_TOOLSDIR_MAKE, make) - BASIC_CHECK_MAKE_VERSION("$CHECK_TOOLSDIR_MAKE", [make in tools-dir]) - fi - PATH=$OLD_PATH - fi - fi - - if test "x$FOUND_MAKE" = x; then - AC_MSG_ERROR([Cannot find GNU make $MAKE_REQUIRED_VERSION or newer! Please put it in the path, or add e.g. MAKE=/opt/gmake3.81/make as argument to configure.]) - fi - ],[ - # If MAKE was set by user, verify the version - BASIC_CHECK_MAKE_VERSION("$MAKE", [user supplied MAKE=$MAKE]) - if test "x$FOUND_MAKE" = x; then - AC_MSG_ERROR([The specified make (by MAKE=$MAKE) is not GNU make $MAKE_REQUIRED_VERSION or newer.]) - fi - ]) - - MAKE=$FOUND_MAKE - AC_SUBST(MAKE) - AC_MSG_NOTICE([Using GNU make at $FOUND_MAKE (version: $MAKE_VERSION_STRING)]) - - BASIC_CHECK_MAKE_OUTPUT_SYNC -]) - -############################################################################### -AC_DEFUN([BASIC_CHECK_FIND_DELETE], -[ - # Test if find supports -delete - AC_MSG_CHECKING([if find supports -delete]) - FIND_DELETE="-delete" - - DELETEDIR=`$MKTEMP -d tmp.XXXXXXXXXX` || (echo Could not create temporary directory!; exit $?) - - echo Hejsan > $DELETEDIR/TestIfFindSupportsDelete - - TEST_DELETE=`$FIND "$DELETEDIR" -name TestIfFindSupportsDelete $FIND_DELETE 2>&1` - if test -f $DELETEDIR/TestIfFindSupportsDelete; then - # No, it does not. - $RM $DELETEDIR/TestIfFindSupportsDelete - if test "x$OPENJDK_TARGET_OS" = "xaix"; then - # AIX 'find' is buggy if called with '-exec {} \+' and an empty file list - FIND_DELETE="-print | $XARGS $RM" - else - FIND_DELETE="-exec $RM \{\} \+" - fi - AC_MSG_RESULT([no]) - else - AC_MSG_RESULT([yes]) - fi - $RMDIR $DELETEDIR - AC_SUBST(FIND_DELETE) -]) - -############################################################################### -AC_DEFUN([BASIC_CHECK_TAR], -[ - # Test which kind of tar was found - if test "x$($TAR --version | $GREP "GNU tar")" != "x"; then - TAR_TYPE="gnu" - elif test "x$($TAR --version | $GREP "bsdtar")" != "x"; then - TAR_TYPE="bsd" - elif test "x$($TAR -v | $GREP "bsdtar")" != "x"; then - TAR_TYPE="bsd" - elif test "x$OPENJDK_BUILD_OS" = "xsolaris"; then - TAR_TYPE="solaris" - elif test "x$OPENJDK_BUILD_OS" = "xaix"; then - TAR_TYPE="aix" - fi - AC_MSG_CHECKING([what type of tar was found]) - AC_MSG_RESULT([$TAR_TYPE]) - - TAR_CREATE_FILE_PARAM="" - - if test "x$TAR_TYPE" = "xgnu"; then - TAR_INCLUDE_PARAM="T" - TAR_SUPPORTS_TRANSFORM="true" - if test "x$OPENJDK_TARGET_OS" = "xsolaris"; then - # When using gnu tar for Solaris targets, need to use compatibility mode - TAR_CREATE_EXTRA_PARAM="--format=ustar" - fi - elif test "x$TAR_TYPE" = "aix"; then - # -L InputList of aix tar: name of file listing the files and directories - # that need to be archived or extracted - TAR_INCLUDE_PARAM="L" - TAR_SUPPORTS_TRANSFORM="false" - else - TAR_INCLUDE_PARAM="I" - TAR_SUPPORTS_TRANSFORM="false" - fi - AC_SUBST(TAR_TYPE) - AC_SUBST(TAR_CREATE_EXTRA_PARAM) - AC_SUBST(TAR_INCLUDE_PARAM) - AC_SUBST(TAR_SUPPORTS_TRANSFORM) -]) - -############################################################################### -AC_DEFUN([BASIC_CHECK_GREP], -[ - # Test that grep supports -Fx with a list of pattern which includes null pattern. - # This is a problem for the grep resident on AIX. - AC_MSG_CHECKING([that grep ($GREP) -Fx handles empty lines in the pattern list correctly]) - # Multiple subsequent spaces.. - STACK_SPACES='aaa bbb ccc' - # ..converted to subsequent newlines, causes STACK_LIST to be a list with some empty - # patterns in it. - STACK_LIST=${STACK_SPACES// /$'\n'} - NEEDLE_SPACES='ccc bbb aaa' - NEEDLE_LIST=${NEEDLE_SPACES// /$'\n'} - RESULT="$($GREP -Fvx "$STACK_LIST" <<< "$NEEDLE_LIST")" - if test "x$RESULT" == "x"; then - AC_MSG_RESULT([yes]) - else - if test "x$OPENJDK_TARGET_OS" = "xaix"; then - ADDINFO="Please make sure you use GNU grep, usually found at /opt/freeware/bin." - fi - AC_MSG_ERROR([grep does not handle -Fx correctly. ${ADDINFO}]) - fi -]) - -############################################################################### -AC_DEFUN_ONCE([BASIC_SETUP_COMPLEX_TOOLS], -[ - BASIC_CHECK_GNU_MAKE - - BASIC_CHECK_FIND_DELETE - BASIC_CHECK_TAR - BASIC_CHECK_GREP - BASIC_SETUP_PANDOC - - # These tools might not be installed by default, - # need hint on how to install them. - BASIC_REQUIRE_PROGS(UNZIP, unzip) - # Since zip uses "ZIP" as a environment variable for passing options, we need - # to name our variable differently, hence ZIPEXE. - BASIC_REQUIRE_PROGS(ZIPEXE, zip) - - # Non-required basic tools - - BASIC_PATH_PROGS(LDD, ldd) - if test "x$LDD" = "x"; then - # List shared lib dependencies is used for - # debug output and checking for forbidden dependencies. - # We can build without it. - LDD="true" - fi - BASIC_PATH_PROGS(READELF, [greadelf readelf]) - BASIC_PATH_PROGS(DOT, dot) - BASIC_PATH_PROGS(HG, hg) - BASIC_PATH_PROGS(GIT, git) - BASIC_PATH_PROGS(STAT, stat) - BASIC_PATH_PROGS(TIME, time) - BASIC_PATH_PROGS(FLOCK, flock) - # Dtrace is usually found in /usr/sbin on Solaris, but that directory may not - # be in the user path. - BASIC_PATH_PROGS(DTRACE, dtrace, $PATH:/usr/sbin) - BASIC_PATH_PROGS(PATCH, [gpatch patch]) - # Check if it's GNU time - IS_GNU_TIME=`$TIME --version 2>&1 | $GREP 'GNU time'` - if test "x$IS_GNU_TIME" != x; then - IS_GNU_TIME=yes - else - IS_GNU_TIME=no - fi - AC_SUBST(IS_GNU_TIME) - - if test "x$OPENJDK_TARGET_OS" = "xmacosx"; then - BASIC_REQUIRE_PROGS(DSYMUTIL, dsymutil) - BASIC_REQUIRE_PROGS(MIG, mig) - BASIC_REQUIRE_PROGS(XATTR, xattr) - BASIC_PATH_PROGS(CODESIGN, codesign) - - if test "x$CODESIGN" != "x"; then - # Check for user provided code signing identity. - # If no identity was provided, fall back to "openjdk_codesign". - AC_ARG_WITH([macosx-codesign-identity], [AS_HELP_STRING([--with-macosx-codesign-identity], - [specify the code signing identity])], - [MACOSX_CODESIGN_IDENTITY=$with_macosx_codesign_identity], - [MACOSX_CODESIGN_IDENTITY=openjdk_codesign] - ) - - AC_SUBST(MACOSX_CODESIGN_IDENTITY) - - # Verify that the codesign certificate is present - AC_MSG_CHECKING([if codesign certificate is present]) - $RM codesign-testfile - $TOUCH codesign-testfile - $CODESIGN -s "$MACOSX_CODESIGN_IDENTITY" codesign-testfile 2>&AS_MESSAGE_LOG_FD >&AS_MESSAGE_LOG_FD || CODESIGN= - $RM codesign-testfile - if test "x$CODESIGN" = x; then - AC_MSG_RESULT([no]) - else - AC_MSG_RESULT([yes]) - fi - fi - BASIC_REQUIRE_PROGS(SETFILE, SetFile) - elif test "x$OPENJDK_TARGET_OS" = "xsolaris"; then - BASIC_REQUIRE_PROGS(ELFEDIT, elfedit) - fi - if ! test "x$OPENJDK_TARGET_OS" = "xwindows"; then - BASIC_REQUIRE_BUILTIN_PROGS(ULIMIT, ulimit) - fi -]) - -############################################################################### -# Check if build directory is on local disk. If not possible to determine, -# we prefer to claim it's local. -# Argument 1: directory to test -# Argument 2: what to do if it is on local disk -# Argument 3: what to do otherwise (remote disk or failure) -AC_DEFUN([BASIC_CHECK_DIR_ON_LOCAL_DISK], -[ - # df -l lists only local disks; if the given directory is not found then - # a non-zero exit code is given - if test "x$DF" = x; then - if test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.msys"; then - # msys does not have df; use Windows "net use" instead. - IS_NETWORK_DISK=`net use | grep \`pwd -W | cut -d ":" -f 1 | tr a-z A-Z\`:` - if test "x$IS_NETWORK_DISK" = x; then - $2 - else - $3 - fi - else - # No df here, say it's local - $2 - fi - else - # JDK-8189619 - # df on AIX does not understand -l. On modern AIXes it understands "-T local" which - # is the same. On older AIXes we just continue to live with a "not local build" warning. - if test "x$OPENJDK_TARGET_OS" = xaix; then - DF_LOCAL_ONLY_OPTION='-T local' - else - DF_LOCAL_ONLY_OPTION='-l' - fi - if $DF $DF_LOCAL_ONLY_OPTION $1 > /dev/null 2>&1; then - $2 - else - # In WSL, local Windows drives are considered remote by df, but we are - # required to build into a directory accessible from windows, so consider - # them local here. - if test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.wsl"; then - if $DF $1 | $GREP -q "^[[A-Z]]:"; then - $2 - else - $3 - fi - else - $3 - fi - fi - fi -]) - -############################################################################### -# Check that source files have basic read permissions set. This might -# not be the case in cygwin in certain conditions. -AC_DEFUN_ONCE([BASIC_CHECK_SRC_PERMS], -[ - if test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.cygwin"; then - file_to_test="$TOPDIR/LICENSE" - if test `$STAT -c '%a' "$file_to_test"` -lt 400; then - AC_MSG_ERROR([Bad file permissions on src files. This is usually caused by cloning the repositories with a non cygwin hg in a directory not created in cygwin.]) - fi - fi -]) - -############################################################################### -AC_DEFUN_ONCE([BASIC_TEST_USABILITY_ISSUES], -[ - AC_MSG_CHECKING([if build directory is on local disk]) - BASIC_CHECK_DIR_ON_LOCAL_DISK($OUTPUTDIR, - [OUTPUT_DIR_IS_LOCAL="yes"], - [OUTPUT_DIR_IS_LOCAL="no"]) - AC_MSG_RESULT($OUTPUT_DIR_IS_LOCAL) - - BASIC_CHECK_SRC_PERMS - - # Check if the user has any old-style ALT_ variables set. - FOUND_ALT_VARIABLES=`env | grep ^ALT_` - - # Before generating output files, test if they exist. If they do, this is a reconfigure. - # Since we can't properly handle the dependencies for this, warn the user about the situation - if test -e $OUTPUTDIR/spec.gmk; then - IS_RECONFIGURE=yes - else - IS_RECONFIGURE=no - fi -]) - -############################################################################### -# Check for support for specific options in bash -AC_DEFUN_ONCE([BASIC_CHECK_BASH_OPTIONS], -[ - # Check bash version - # Extra [ ] to stop m4 mangling - [ BASH_VER=`$BASH --version | $SED -n -e 's/^.*bash.*ersion *\([0-9.]*\).*$/\1/ p'` ] - AC_MSG_CHECKING([bash version]) - AC_MSG_RESULT([$BASH_VER]) - - BASH_MAJOR=`$ECHO $BASH_VER | $CUT -d . -f 1` - BASH_MINOR=`$ECHO $BASH_VER | $CUT -d . -f 2` - if test $BASH_MAJOR -lt 3 || (test $BASH_MAJOR -eq 3 && test $BASH_MINOR -lt 2); then - AC_MSG_ERROR([bash version 3.2 or better is required]) - fi - - # Test if bash supports pipefail. - AC_MSG_CHECKING([if bash supports pipefail]) - if ${BASH} -c 'set -o pipefail'; then - BASH_ARGS="$BASH_ARGS -o pipefail" - AC_MSG_RESULT([yes]) - else - AC_MSG_RESULT([no]) - fi - - AC_MSG_CHECKING([if bash supports errexit (-e)]) - if ${BASH} -e -c 'true'; then - BASH_ARGS="$BASH_ARGS -e" - AC_MSG_RESULT([yes]) - else - AC_MSG_RESULT([no]) - fi - - AC_SUBST(BASH_ARGS) -]) - -################################################################################ -# -# Setup Pandoc -# -AC_DEFUN_ONCE([BASIC_SETUP_PANDOC], -[ - BASIC_PATH_PROGS(PANDOC, pandoc) - - PANDOC_MARKDOWN_FLAG="markdown" - if test -n "$PANDOC"; then - AC_MSG_CHECKING(if the pandoc smart extension needs to be disabled for markdown) - if $PANDOC --list-extensions | $GREP -q '\+smart'; then - AC_MSG_RESULT([yes]) - PANDOC_MARKDOWN_FLAG="markdown-smart" - else - AC_MSG_RESULT([no]) - fi - fi - - if test -n "$PANDOC"; then - ENABLE_PANDOC="true" - else - ENABLE_PANDOC="false" - fi - AC_SUBST(ENABLE_PANDOC) - AC_SUBST(PANDOC_MARKDOWN_FLAG) -]) - -################################################################################ -# -# Default make target -# -AC_DEFUN_ONCE([BASIC_SETUP_DEFAULT_MAKE_TARGET], -[ - AC_ARG_WITH(default-make-target, [AS_HELP_STRING([--with-default-make-target], - [set the default make target @<:@exploded-image@:>@])]) - if test "x$with_default_make_target" = "x" \ - || test "x$with_default_make_target" = "xyes"; then - DEFAULT_MAKE_TARGET="exploded-image" - elif test "x$with_default_make_target" = "xno"; then - AC_MSG_ERROR([--without-default-make-target is not a valid option]) - else - DEFAULT_MAKE_TARGET="$with_default_make_target" - fi - - AC_SUBST(DEFAULT_MAKE_TARGET) -]) - -############################################################################### -# Setup the default value for LOG= -# -AC_DEFUN_ONCE([BASIC_SETUP_DEFAULT_LOG], -[ - AC_ARG_WITH(log, [AS_HELP_STRING([--with-log], - [[default vaue for make LOG argument [warn]]])]) - AC_MSG_CHECKING([for default LOG value]) - if test "x$with_log" = x; then - DEFAULT_LOG="" - else - # Syntax for valid LOG options is a bit too complex for it to be worth - # implementing a test for correctness in configure. Just accept it. - DEFAULT_LOG=$with_log - fi - AC_MSG_RESULT([$DEFAULT_LOG]) - AC_SUBST(DEFAULT_LOG) -]) - -############################################################################### -# Code to run after AC_OUTPUT -AC_DEFUN_ONCE([BASIC_POST_CONFIG_OUTPUT], -[ - # Try to move config.log (generated by autoconf) to the configure-support directory. - if test -e ./config.log; then - $MV -f ./config.log "$CONFIGURESUPPORT_OUTPUTDIR/config.log" 2> /dev/null - fi - - # Rotate our log file (configure.log) - if test -e "$OUTPUTDIR/configure.log.old"; then - $RM -f "$OUTPUTDIR/configure.log.old" - fi - if test -e "$OUTPUTDIR/configure.log"; then - $MV -f "$OUTPUTDIR/configure.log" "$OUTPUTDIR/configure.log.old" 2> /dev/null - fi - - # Move configure.log from current directory to the build output root - if test -e ./configure.log; then - $MV -f ./configure.log "$OUTPUTDIR/configure.log" 2> /dev/null - fi - - # Make the compare script executable - $CHMOD +x $OUTPUTDIR/compare.sh -]) diff --git a/make/autoconf/boot-jdk.m4 b/make/autoconf/boot-jdk.m4 index 8aa2547f429..841f0e9bbe7 100644 --- a/make/autoconf/boot-jdk.m4 +++ b/make/autoconf/boot-jdk.m4 @@ -97,7 +97,7 @@ AC_DEFUN([BOOTJDK_DO_CHECK], else # We're done! :-) BOOT_JDK_FOUND=yes - BASIC_FIXUP_PATH(BOOT_JDK) + UTIL_FIXUP_PATH(BOOT_JDK) AC_MSG_CHECKING([for Boot JDK]) AC_MSG_RESULT([$BOOT_JDK]) AC_MSG_CHECKING([Boot JDK version]) @@ -150,7 +150,7 @@ AC_DEFUN([BOOTJDK_CHECK_JAVA_HOME], [ if test "x$JAVA_HOME" != x; then JAVA_HOME_PROCESSED="$JAVA_HOME" - BASIC_FIXUP_PATH(JAVA_HOME_PROCESSED) + UTIL_FIXUP_PATH(JAVA_HOME_PROCESSED) if test ! -d "$JAVA_HOME_PROCESSED"; then AC_MSG_NOTICE([Your JAVA_HOME points to a non-existing directory!]) else @@ -177,7 +177,7 @@ AC_DEFUN([BOOTJDK_CHECK_JAVA_IN_PATH_IS_SYMLINK], # Lets find the JDK/JRE directory by following symbolic links. # Linux/GNU systems often have links from /usr/bin/java to # /etc/alternatives/java to the real JDK binary. - BASIC_REMOVE_SYMBOLIC_LINKS(BINARY) + UTIL_REMOVE_SYMBOLIC_LINKS(BINARY) BOOT_JDK=`dirname "$BINARY"` BOOT_JDK=`cd "$BOOT_JDK/.."; pwd` if test -x "$BOOT_JDK/bin/javac" && test -x "$BOOT_JDK/bin/java"; then @@ -241,7 +241,7 @@ AC_DEFUN([BOOTJDK_FIND_BEST_JDK_IN_WINDOWS_VIRTUAL_DIRECTORY], [ if test "x[$]$1" != x; then VIRTUAL_DIR="[$]$1/Java" - BASIC_WINDOWS_REWRITE_AS_UNIX_PATH(VIRTUAL_DIR) + UTIL_REWRITE_AS_UNIX_PATH(VIRTUAL_DIR) BOOTJDK_FIND_BEST_JDK_IN_DIRECTORY($VIRTUAL_DIR) fi ]) @@ -269,7 +269,7 @@ AC_DEFUN([BOOTJDK_CHECK_WELL_KNOWN_LOCATIONS], AC_DEFUN([BOOTJDK_CHECK_TOOL_IN_BOOTJDK], [ # Use user overridden value if available, otherwise locate tool in the Boot JDK. - BASIC_SETUP_TOOL($1, + UTIL_SETUP_TOOL($1, [ AC_MSG_CHECKING([for $2 in Boot JDK]) $1=$BOOT_JDK/bin/$2 @@ -362,7 +362,7 @@ AC_DEFUN_ONCE([BOOTJDK_SETUP_BOOT_JDK], # Try to enable CDS AC_MSG_CHECKING([for local Boot JDK Class Data Sharing (CDS)]) BOOT_JDK_CDS_ARCHIVE=$CONFIGURESUPPORT_OUTPUTDIR/classes.jsa - ADD_JVM_ARG_IF_OK([-XX:+UnlockDiagnosticVMOptions -XX:-VerifySharedSpaces -XX:SharedArchiveFile=$BOOT_JDK_CDS_ARCHIVE],boot_jdk_cds_args,[$JAVA]) + UTIL_ADD_JVM_ARG_IF_OK([-XX:+UnlockDiagnosticVMOptions -XX:-VerifySharedSpaces -XX:SharedArchiveFile=$BOOT_JDK_CDS_ARCHIVE],boot_jdk_cds_args,[$JAVA]) if test "x$boot_jdk_cds_args" != x; then # Try creating a CDS archive @@ -391,18 +391,18 @@ AC_DEFUN_ONCE([BOOTJDK_SETUP_BOOT_JDK_ARGUMENTS], AC_MSG_CHECKING([flags for boot jdk java command] ) # Force en-US environment - ADD_JVM_ARG_IF_OK([-Duser.language=en -Duser.country=US],boot_jdk_jvmargs,[$JAVA]) + UTIL_ADD_JVM_ARG_IF_OK([-Duser.language=en -Duser.country=US],boot_jdk_jvmargs,[$JAVA]) if test "x$BOOTJDK_USE_LOCAL_CDS" = xtrue; then # Use our own CDS archive - ADD_JVM_ARG_IF_OK([$boot_jdk_cds_args -Xshare:auto],boot_jdk_jvmargs,[$JAVA]) + UTIL_ADD_JVM_ARG_IF_OK([$boot_jdk_cds_args -Xshare:auto],boot_jdk_jvmargs,[$JAVA]) else # Otherwise optimistically use the system-wide one, if one is present - ADD_JVM_ARG_IF_OK([-Xshare:auto],boot_jdk_jvmargs,[$JAVA]) + UTIL_ADD_JVM_ARG_IF_OK([-Xshare:auto],boot_jdk_jvmargs,[$JAVA]) fi # Finally append user provided options to allow them to override. - ADD_JVM_ARG_IF_OK([$USER_BOOT_JDK_OPTIONS],boot_jdk_jvmargs,[$JAVA]) + UTIL_ADD_JVM_ARG_IF_OK([$USER_BOOT_JDK_OPTIONS],boot_jdk_jvmargs,[$JAVA]) AC_MSG_RESULT([$boot_jdk_jvmargs]) @@ -413,7 +413,7 @@ AC_DEFUN_ONCE([BOOTJDK_SETUP_BOOT_JDK_ARGUMENTS], AC_MSG_CHECKING([flags for boot jdk java command for big workloads]) # Starting amount of heap memory. - ADD_JVM_ARG_IF_OK([-Xms64M],boot_jdk_jvmargs_big,[$JAVA]) + UTIL_ADD_JVM_ARG_IF_OK([-Xms64M],boot_jdk_jvmargs_big,[$JAVA]) BOOTCYCLE_JVM_ARGS_BIG=-Xms64M # Maximum amount of heap memory and stack size. @@ -441,8 +441,8 @@ AC_DEFUN_ONCE([BOOTJDK_SETUP_BOOT_JDK_ARGUMENTS], STACK_SIZE=$STACK_SIZE_64 JVM_MAX_HEAP=$JVM_HEAP_LIMIT_64 fi - ADD_JVM_ARG_IF_OK([-Xmx${JVM_MAX_HEAP}M],boot_jdk_jvmargs_big,[$JAVA]) - ADD_JVM_ARG_IF_OK([-XX:ThreadStackSize=$STACK_SIZE],boot_jdk_jvmargs_big,[$JAVA]) + UTIL_ADD_JVM_ARG_IF_OK([-Xmx${JVM_MAX_HEAP}M],boot_jdk_jvmargs_big,[$JAVA]) + UTIL_ADD_JVM_ARG_IF_OK([-XX:ThreadStackSize=$STACK_SIZE],boot_jdk_jvmargs_big,[$JAVA]) AC_MSG_RESULT([$boot_jdk_jvmargs_big]) @@ -469,10 +469,10 @@ AC_DEFUN_ONCE([BOOTJDK_SETUP_BOOT_JDK_ARGUMENTS], AC_MSG_CHECKING([flags for boot jdk java command for small workloads]) # Use serial gc for small short lived tools if possible - ADD_JVM_ARG_IF_OK([-XX:+UseSerialGC],boot_jdk_jvmargs_small,[$JAVA]) - ADD_JVM_ARG_IF_OK([-Xms32M],boot_jdk_jvmargs_small,[$JAVA]) - ADD_JVM_ARG_IF_OK([-Xmx512M],boot_jdk_jvmargs_small,[$JAVA]) - ADD_JVM_ARG_IF_OK([-XX:TieredStopAtLevel=1],boot_jdk_jvmargs_small,[$JAVA]) + UTIL_ADD_JVM_ARG_IF_OK([-XX:+UseSerialGC],boot_jdk_jvmargs_small,[$JAVA]) + UTIL_ADD_JVM_ARG_IF_OK([-Xms32M],boot_jdk_jvmargs_small,[$JAVA]) + UTIL_ADD_JVM_ARG_IF_OK([-Xmx512M],boot_jdk_jvmargs_small,[$JAVA]) + UTIL_ADD_JVM_ARG_IF_OK([-XX:TieredStopAtLevel=1],boot_jdk_jvmargs_small,[$JAVA]) AC_MSG_RESULT([$boot_jdk_jvmargs_small]) @@ -531,7 +531,7 @@ AC_DEFUN([BOOTJDK_CHECK_BUILD_JDK], else # We're done! BUILD_JDK_FOUND=yes - BASIC_FIXUP_PATH(BUILD_JDK) + UTIL_FIXUP_PATH(BUILD_JDK) AC_MSG_CHECKING([for Build JDK]) AC_MSG_RESULT([$BUILD_JDK]) AC_MSG_CHECKING([Build JDK version]) diff --git a/make/autoconf/build-performance.m4 b/make/autoconf/build-performance.m4 index dbda3abe597..9ec19c2643c 100644 --- a/make/autoconf/build-performance.m4 +++ b/make/autoconf/build-performance.m4 @@ -180,7 +180,7 @@ AC_DEFUN([BPERF_SETUP_CCACHE], if test "x$TOOLCHAIN_PATH" != x; then PATH=$TOOLCHAIN_PATH:$PATH fi - BASIC_REQUIRE_PROGS(CCACHE, ccache) + UTIL_REQUIRE_PROGS(CCACHE, ccache) PATH="$OLD_PATH" CCACHE_VERSION=[`$CCACHE --version | head -n1 | $SED 's/[A-Za-z ]*//'`] CCACHE_STATUS="Active ($CCACHE_VERSION)" @@ -288,12 +288,12 @@ AC_DEFUN([BPERF_SETUP_ICECC], [enable distribted compilation of native code using icecc/icecream @<:@disabled@:>@])]) if test "x${enable_icecc}" = "xyes"; then - BASIC_REQUIRE_PROGS(ICECC_CMD, icecc) + UTIL_REQUIRE_PROGS(ICECC_CMD, icecc) old_path="$PATH" # Look for icecc-create-env in some known places PATH="$PATH:/usr/lib/icecc:/usr/lib64/icecc" - BASIC_REQUIRE_PROGS(ICECC_CREATE_ENV, icecc-create-env) + UTIL_REQUIRE_PROGS(ICECC_CREATE_ENV, icecc-create-env) # Use icecc-create-env to create a minimal compilation environment that can # be sent to the other hosts in the icecream cluster. icecc_create_env_log="${CONFIGURESUPPORT_OUTPUTDIR}/icecc/icecc_create_env.log" @@ -308,7 +308,7 @@ AC_DEFUN([BPERF_SETUP_ICECC], elif test "x$TOOLCHAIN_TYPE" = "xclang"; then # For clang, the icecc compilerwrapper is needed. It usually resides next # to icecc-create-env. - BASIC_REQUIRE_PROGS(ICECC_WRAPPER, compilerwrapper) + UTIL_REQUIRE_PROGS(ICECC_WRAPPER, compilerwrapper) BPERF_RUN_ICECC_CREATE_ENV([--clang ${CC} ${ICECC_WRAPPER}], ${icecc_create_env_log}) else AC_MSG_ERROR([Can only create icecc compiler packages for toolchain types gcc and clang]) @@ -442,7 +442,7 @@ AC_DEFUN_ONCE([BPERF_SETUP_SMART_JAVAC], if test "$MX_VALUE" -lt "512"; then MX_VALUE=512 fi - ADD_JVM_ARG_IF_OK([-Xms${MS_VALUE}M -Xmx${MX_VALUE}M],SJAVAC_SERVER_JAVA_FLAGS,[$SJAVAC_SERVER_JAVA]) + UTIL_ADD_JVM_ARG_IF_OK([-Xms${MS_VALUE}M -Xmx${MX_VALUE}M],SJAVAC_SERVER_JAVA_FLAGS,[$SJAVAC_SERVER_JAVA]) AC_SUBST(SJAVAC_SERVER_JAVA_FLAGS) AC_ARG_ENABLE([sjavac], [AS_HELP_STRING([--enable-sjavac], diff --git a/make/autoconf/configure.ac b/make/autoconf/configure.ac index 122364d02f5..decf29accd3 100644 --- a/make/autoconf/configure.ac +++ b/make/autoconf/configure.ac @@ -47,9 +47,9 @@ AC_DEFUN_ONCE([CUSTOM_SUMMARY_AND_WARNINGS_HOOK]) #CUSTOM_AUTOCONF_INCLUDE # Include these first... -m4_include([basics.m4]) -m4_include([basics_windows.m4]) +m4_include([util.m4]) # ... then the rest +m4_include([basic.m4]) m4_include([boot-jdk.m4]) m4_include([build-performance.m4]) m4_include([flags.m4]) @@ -62,7 +62,6 @@ m4_include([libraries.m4]) m4_include([platform.m4]) m4_include([source-dirs.m4]) m4_include([toolchain.m4]) -m4_include([toolchain_windows.m4]) ############################################################################### # diff --git a/make/autoconf/flags.m4 b/make/autoconf/flags.m4 index 131ce7a6338..582cd65d0df 100644 --- a/make/autoconf/flags.m4 +++ b/make/autoconf/flags.m4 @@ -430,7 +430,7 @@ AC_DEFUN([FLAGS_SETUP_FLAGS], # IF_FALSE: [RUN-IF-FALSE]) # ------------------------------------------------------------ # Check that the C compiler supports an argument -BASIC_DEFUN_NAMED([FLAGS_C_COMPILER_CHECK_ARGUMENTS], +UTIL_DEFUN_NAMED([FLAGS_C_COMPILER_CHECK_ARGUMENTS], [*ARGUMENT IF_TRUE IF_FALSE PREFIX], [$@], [ AC_MSG_CHECKING([if ARG_PREFIX[CC] supports "ARG_ARGUMENT"]) @@ -461,7 +461,7 @@ BASIC_DEFUN_NAMED([FLAGS_C_COMPILER_CHECK_ARGUMENTS], # IF_FALSE: [RUN-IF-FALSE]) # ------------------------------------------------------------ # Check that the C++ compiler supports an argument -BASIC_DEFUN_NAMED([FLAGS_CXX_COMPILER_CHECK_ARGUMENTS], +UTIL_DEFUN_NAMED([FLAGS_CXX_COMPILER_CHECK_ARGUMENTS], [*ARGUMENT IF_TRUE IF_FALSE PREFIX], [$@], [ AC_MSG_CHECKING([if ARG_PREFIX[CXX] supports "ARG_ARGUMENT"]) @@ -492,7 +492,7 @@ BASIC_DEFUN_NAMED([FLAGS_CXX_COMPILER_CHECK_ARGUMENTS], # IF_FALSE: [RUN-IF-FALSE]) # ------------------------------------------------------------ # Check that the C and C++ compilers support an argument -BASIC_DEFUN_NAMED([FLAGS_COMPILER_CHECK_ARGUMENTS], +UTIL_DEFUN_NAMED([FLAGS_COMPILER_CHECK_ARGUMENTS], [*ARGUMENT IF_TRUE IF_FALSE PREFIX], [$@], [ FLAGS_C_COMPILER_CHECK_ARGUMENTS(ARGUMENT: [ARG_ARGUMENT], @@ -524,7 +524,7 @@ BASIC_DEFUN_NAMED([FLAGS_COMPILER_CHECK_ARGUMENTS], # IF_FALSE: [RUN-IF-FALSE]) # ------------------------------------------------------------ # Check that the linker support an argument -BASIC_DEFUN_NAMED([FLAGS_LINKER_CHECK_ARGUMENTS], +UTIL_DEFUN_NAMED([FLAGS_LINKER_CHECK_ARGUMENTS], [*ARGUMENT IF_TRUE IF_FALSE], [$@], [ AC_MSG_CHECKING([if linker supports "ARG_ARGUMENT"]) diff --git a/make/autoconf/hotspot.m4 b/make/autoconf/hotspot.m4 index 1110366f468..91507bc0261 100644 --- a/make/autoconf/hotspot.m4 +++ b/make/autoconf/hotspot.m4 @@ -75,7 +75,7 @@ AC_DEFUN_ONCE([HOTSPOT_SETUP_JVM_VARIANTS], AC_MSG_RESULT([$JVM_VARIANTS]) # Check that the selected variants are valid - BASIC_GET_NON_MATCHING_VALUES(INVALID_VARIANTS, $JVM_VARIANTS, \ + UTIL_GET_NON_MATCHING_VALUES(INVALID_VARIANTS, $JVM_VARIANTS, \ $VALID_JVM_VARIANTS) if test "x$INVALID_VARIANTS" != x; then AC_MSG_NOTICE([Unknown variant(s) specified: "$INVALID_VARIANTS"]) @@ -85,7 +85,7 @@ AC_DEFUN_ONCE([HOTSPOT_SETUP_JVM_VARIANTS], # All "special" variants share the same output directory ("server") VALID_MULTIPLE_JVM_VARIANTS="server client minimal" - BASIC_GET_NON_MATCHING_VALUES(INVALID_MULTIPLE_VARIANTS, $JVM_VARIANTS, \ + UTIL_GET_NON_MATCHING_VALUES(INVALID_MULTIPLE_VARIANTS, $JVM_VARIANTS, \ $VALID_MULTIPLE_JVM_VARIANTS) if test "x$INVALID_MULTIPLE_VARIANTS" != x && \ test "x$BUILDING_MULTIPLE_JVM_VARIANTS" = xtrue; then @@ -182,5 +182,5 @@ AC_DEFUN_ONCE([HOTSPOT_SETUP_MISC], fi # --with-cpu-port is no longer supported - BASIC_DEPRECATED_ARG_WITH(with-cpu-port) + UTIL_DEPRECATED_ARG_WITH(with-cpu-port) ]) diff --git a/make/autoconf/jdk-options.m4 b/make/autoconf/jdk-options.m4 index 26d875deb18..58980154ea9 100644 --- a/make/autoconf/jdk-options.m4 +++ b/make/autoconf/jdk-options.m4 @@ -34,7 +34,7 @@ AC_DEFUN_ONCE([JDKOPT_SETUP_JDK_VARIANT], [ # Deprecated in JDK 12 - BASIC_DEPRECATED_ARG_WITH([jdk-variant]) + UTIL_DEPRECATED_ARG_WITH([jdk-variant]) ]) ############################################################################### @@ -473,14 +473,14 @@ AC_DEFUN_ONCE([JDKOPT_SETUP_CODE_COVERAGE], AC_MSG_ERROR([Invalid JCov bundle: "$JCOV_HOME/lib/jcov.jar" does not exist]) fi JCOV_ENABLED="true" - BASIC_FIXUP_PATH(JCOV_HOME) + UTIL_FIXUP_PATH(JCOV_HOME) if test "x$with_jcov_input_jdk" != "x" ; then JCOV_INPUT_JDK="$with_jcov_input_jdk" if test ! -f "$JCOV_INPUT_JDK/bin/java$EXE_SUFFIX"; then AC_MSG_RESULT([fail]) AC_MSG_ERROR([Invalid JDK bundle: "$JCOV_INPUT_JDK/bin/java$EXE_SUFFIX" does not exist]) fi - BASIC_FIXUP_PATH(JCOV_INPUT_JDK) + UTIL_FIXUP_PATH(JCOV_INPUT_JDK) fi if test "x$with_jcov_filters" != "x" ; then JCOV_FILTERS="$with_jcov_filters" diff --git a/make/autoconf/jvm-features.m4 b/make/autoconf/jvm-features.m4 index 536071cff58..20a20babdec 100644 --- a/make/autoconf/jvm-features.m4 +++ b/make/autoconf/jvm-features.m4 @@ -63,14 +63,14 @@ define(jvm_features_deprecated, m4_normalize( AC_DEFUN_ONCE([JVM_FEATURES_PARSE_OPTIONS], [ # Setup shell variables from the m4 lists - BASIC_SORT_LIST(JVM_FEATURES_VALID, "jvm_features_valid") - BASIC_SORT_LIST(JVM_FEATURES_DEPRECATED, "jvm_features_deprecated") + UTIL_SORT_LIST(JVM_FEATURES_VALID, "jvm_features_valid") + UTIL_SORT_LIST(JVM_FEATURES_DEPRECATED, "jvm_features_deprecated") # For historical reasons, some jvm features have their own, shorter names. # Keep those as aliases for the --enable-jvm-feature-* style arguments. - BASIC_ALIASED_ARG_ENABLE(aot, --enable-jvm-feature-aot) - BASIC_ALIASED_ARG_ENABLE(cds, --enable-jvm-feature-cds) - BASIC_ALIASED_ARG_ENABLE(dtrace, --enable-jvm-feature-dtrace) + UTIL_ALIASED_ARG_ENABLE(aot, --enable-jvm-feature-aot) + UTIL_ALIASED_ARG_ENABLE(cds, --enable-jvm-feature-cds) + UTIL_ALIASED_ARG_ENABLE(dtrace, --enable-jvm-feature-dtrace) # First check for features using the # --with-jvm-features="<[-]feature>[,<[-]feature> ...]" syntax. @@ -86,7 +86,7 @@ AC_DEFUN_ONCE([JVM_FEATURES_PARSE_OPTIONS], $AWK '{ for (i=1; i<=NF; i++) if (match($i, /^-.*/)) printf("%s ", substr($i, 2))}'` # Verify that the user has provided only valid (or deprecated) features - BASIC_GET_NON_MATCHING_VALUES(invalid_features, $JVM_FEATURES_ENABLED \ + UTIL_GET_NON_MATCHING_VALUES(invalid_features, $JVM_FEATURES_ENABLED \ $JVM_FEATURES_DISABLED, $JVM_FEATURES_VALID $JVM_FEATURES_DEPRECATED) if test "x$invalid_features" != x; then AC_MSG_NOTICE([Unknown JVM features specified: '$invalid_features']) @@ -95,14 +95,14 @@ AC_DEFUN_ONCE([JVM_FEATURES_PARSE_OPTIONS], fi # Check if the user has provided deprecated features - BASIC_GET_MATCHING_VALUES(deprecated_features, $JVM_FEATURES_ENABLED \ + UTIL_GET_MATCHING_VALUES(deprecated_features, $JVM_FEATURES_ENABLED \ $JVM_FEATURES_DISABLED, $JVM_FEATURES_DEPRECATED) if test "x$deprecated_features" != x; then AC_MSG_WARN([Deprecated JVM features specified (will be ignored): '$deprecated_features']) # Filter out deprecated features - BASIC_GET_NON_MATCHING_VALUES(JVM_FEATURES_ENABLED, \ + UTIL_GET_NON_MATCHING_VALUES(JVM_FEATURES_ENABLED, \ $JVM_FEATURES_ENABLED, $deprecated_features) - BASIC_GET_NON_MATCHING_VALUES(JVM_FEATURES_DISABLED, \ + UTIL_GET_NON_MATCHING_VALUES(JVM_FEATURES_DISABLED, \ $JVM_FEATURES_DISABLED, $deprecated_features) fi fi @@ -145,14 +145,14 @@ AC_DEFUN_ONCE([JVM_FEATURES_PARSE_OPTIONS], # Warn if the user has both enabled and disabled a feature # If this happens, disable will override enable. - BASIC_GET_MATCHING_VALUES(enabled_and_disabled, $JVM_FEATURES_ENABLED, \ + UTIL_GET_MATCHING_VALUES(enabled_and_disabled, $JVM_FEATURES_ENABLED, \ $JVM_FEATURES_DISABLED) if test "x$enabled_and_disabled" != x; then AC_MSG_WARN([Disabling of these features will override enabling: '$enabled_and_disabled']) fi # Clean up lists and announce results to user - BASIC_SORT_LIST(JVM_FEATURES_ENABLED, $JVM_FEATURES_ENABLED) + UTIL_SORT_LIST(JVM_FEATURES_ENABLED, $JVM_FEATURES_ENABLED) AC_MSG_CHECKING([for JVM features enabled by the user]) if test "x$JVM_FEATURES_ENABLED" != x; then AC_MSG_RESULT(['$JVM_FEATURES_ENABLED']) @@ -160,7 +160,7 @@ AC_DEFUN_ONCE([JVM_FEATURES_PARSE_OPTIONS], AC_MSG_RESULT([none]) fi - BASIC_SORT_LIST(JVM_FEATURES_DISABLED, $JVM_FEATURES_DISABLED) + UTIL_SORT_LIST(JVM_FEATURES_DISABLED, $JVM_FEATURES_DISABLED) AC_MSG_CHECKING([for JVM features disabled by the user]) if test "x$JVM_FEATURES_DISABLED" != x; then AC_MSG_RESULT(['$JVM_FEATURES_DISABLED']) @@ -482,7 +482,7 @@ AC_DEFUN([JVM_FEATURES_CALCULATE_ACTIVE], # The default is set to all valid features except those unavailable or listed # in a filter. if test "x$variant" != xcustom; then - BASIC_GET_NON_MATCHING_VALUES(default_for_variant, $JVM_FEATURES_VALID, \ + UTIL_GET_NON_MATCHING_VALUES(default_for_variant, $JVM_FEATURES_VALID, \ $JVM_FEATURES_PLATFORM_UNAVAILABLE $JVM_FEATURES_VARIANT_UNAVAILABLE \ $JVM_FEATURES_PLATFORM_FILTER $JVM_FEATURES_VARIANT_FILTER) else @@ -492,7 +492,7 @@ AC_DEFUN([JVM_FEATURES_CALCULATE_ACTIVE], fi # Verify that explicitly enabled features are available - BASIC_GET_MATCHING_VALUES(enabled_but_unavailable, $JVM_FEATURES_ENABLED, \ + UTIL_GET_MATCHING_VALUES(enabled_but_unavailable, $JVM_FEATURES_ENABLED, \ $JVM_FEATURES_PLATFORM_UNAVAILABLE $JVM_FEATURES_VARIANT_UNAVAILABLE) if test "x$enabled_but_unavailable" != x; then AC_MSG_NOTICE([ERROR: Unavailable JVM features explicitly enabled for '$variant': '$enabled_but_unavailable']) @@ -500,12 +500,12 @@ AC_DEFUN([JVM_FEATURES_CALCULATE_ACTIVE], fi # Notify the user if their command line options has no real effect - BASIC_GET_MATCHING_VALUES(enabled_but_default, $JVM_FEATURES_ENABLED, \ + UTIL_GET_MATCHING_VALUES(enabled_but_default, $JVM_FEATURES_ENABLED, \ $default_for_variant) if test "x$enabled_but_default" != x; then AC_MSG_NOTICE([Default JVM features explicitly enabled for '$variant': '$enabled_but_default']) fi - BASIC_GET_MATCHING_VALUES(disabled_but_unavailable, $JVM_FEATURES_DISABLED, \ + UTIL_GET_MATCHING_VALUES(disabled_but_unavailable, $JVM_FEATURES_DISABLED, \ $JVM_FEATURES_PLATFORM_UNAVAILABLE $JVM_FEATURES_VARIANT_UNAVAILABLE) if test "x$disabled_but_unavailable" != x; then AC_MSG_NOTICE([Unavailable JVM features explicitly disabled for '$variant': '$disabled_but_unavailable']) @@ -513,7 +513,7 @@ AC_DEFUN([JVM_FEATURES_CALCULATE_ACTIVE], # JVM_FEATURES_ACTIVE is the set of all default features and all explicitly # enabled features, with the explicitly disabled features filtered out. - BASIC_GET_NON_MATCHING_VALUES(JVM_FEATURES_ACTIVE, $default_for_variant \ + UTIL_GET_NON_MATCHING_VALUES(JVM_FEATURES_ACTIVE, $default_for_variant \ $JVM_FEATURES_ENABLED, $JVM_FEATURES_DISABLED) ]) @@ -613,7 +613,7 @@ AC_DEFUN_ONCE([JVM_FEATURES_SETUP], JVM_FEATURES_VERIFY($variant) # Keep feature list sorted and free of duplicates - BASIC_SORT_LIST(JVM_FEATURES_ACTIVE, $JVM_FEATURES_ACTIVE) + UTIL_SORT_LIST(JVM_FEATURES_ACTIVE, $JVM_FEATURES_ACTIVE) AC_MSG_CHECKING([JVM features to use for variant '$variant']) AC_MSG_RESULT(['$JVM_FEATURES_ACTIVE']) diff --git a/make/autoconf/lib-tests.m4 b/make/autoconf/lib-tests.m4 index 043d94a7a84..b1437024332 100644 --- a/make/autoconf/lib-tests.m4 +++ b/make/autoconf/lib-tests.m4 @@ -51,7 +51,7 @@ AC_DEFUN_ONCE([LIB_TESTS_SETUP_GRAALUNIT], fi fi - BASIC_FIXUP_PATH([GRAALUNIT_LIB]) + UTIL_FIXUP_PATH([GRAALUNIT_LIB]) AC_SUBST(GRAALUNIT_LIB) ]) @@ -77,7 +77,7 @@ AC_DEFUN_ONCE([LIB_TESTS_SETUP_JMH], AC_MSG_RESULT([no, error]) AC_MSG_ERROR([$JMH_HOME does not exist or is not a directory]) fi - BASIC_FIXUP_PATH([JMH_HOME]) + UTIL_FIXUP_PATH([JMH_HOME]) jar_names="jmh-core jmh-generator-annprocess jopt-simple commons-math3" for jar in $jar_names; do diff --git a/make/autoconf/libraries.m4 b/make/autoconf/libraries.m4 index 8e6674f839d..8618077d1bb 100644 --- a/make/autoconf/libraries.m4 +++ b/make/autoconf/libraries.m4 @@ -207,7 +207,7 @@ AC_DEFUN_ONCE([LIB_SETUP_SOLARIS_STLPORT], fi if test -f "$STLPORT_LIB"; then AC_MSG_RESULT([yes, $STLPORT_LIB]) - BASIC_FIXUP_PATH([STLPORT_LIB]) + UTIL_FIXUP_PATH([STLPORT_LIB]) else AC_MSG_RESULT([no, not found at $STLPORT_LIB, cannot build Hotspot gtests]) fi diff --git a/make/autoconf/source-dirs.m4 b/make/autoconf/source-dirs.m4 index 617ef0c4b4f..8ac7c542cab 100644 --- a/make/autoconf/source-dirs.m4 +++ b/make/autoconf/source-dirs.m4 @@ -46,7 +46,7 @@ AC_DEFUN_ONCE([SRCDIRS_SETUP_IMPORT_MODULES], && test "x$with_import_modules" != "xno"; then if test -d "$with_import_modules"; then IMPORT_MODULES_TOPDIR="$with_import_modules" - BASIC_FIXUP_PATH([IMPORT_MODULES_TOPDIR]) + UTIL_FIXUP_PATH([IMPORT_MODULES_TOPDIR]) elif test -e "$with_import_modules"; then IMPORT_MODULES_TOPDIR="$CONFIGURESUPPORT_OUTPUTDIR/import-modules" $RM -rf "$IMPORT_MODULES_TOPDIR" diff --git a/make/autoconf/toolchain.m4 b/make/autoconf/toolchain.m4 index 01bef676deb..698f4cd75f4 100644 --- a/make/autoconf/toolchain.m4 +++ b/make/autoconf/toolchain.m4 @@ -32,6 +32,7 @@ # compilers and related tools that are used. ######################################################################## +m4_include([toolchain_windows.m4]) # All valid toolchains, regardless of platform (used by help.m4) VALID_TOOLCHAINS_all="gcc clang solstudio xlc microsoft" @@ -92,7 +93,7 @@ AC_DEFUN([TOOLCHAIN_PREPARE_FOR_VERSION_COMPARISONS], # IF_AT_LEAST: block to run if the compiler is at least this version (>=) # IF_OLDER_THAN: block to run if the compiler is older than this version (<) # PREFIX: Optional variable prefix for compiler to compare version for (OPENJDK_BUILD_) -BASIC_DEFUN_NAMED([TOOLCHAIN_CHECK_COMPILER_VERSION], +UTIL_DEFUN_NAMED([TOOLCHAIN_CHECK_COMPILER_VERSION], [*VERSION PREFIX IF_AT_LEAST IF_OLDER_THAN], [$@], [ # Need to assign to a variable since m4 is blocked from modifying parts in []. @@ -143,7 +144,7 @@ AC_DEFUN([TOOLCHAIN_PREPARE_FOR_LD_VERSION_COMPARISONS], # IF_AT_LEAST: block to run if the compiler is at least this version (>=) # IF_OLDER_THAN: block to run if the compiler is older than this version (<) # PREFIX: Optional variable prefix for compiler to compare version for (OPENJDK_BUILD_) -BASIC_DEFUN_NAMED([TOOLCHAIN_CHECK_LINKER_VERSION], +UTIL_DEFUN_NAMED([TOOLCHAIN_CHECK_LINKER_VERSION], [*VERSION PREFIX IF_AT_LEAST IF_OLDER_THAN], [$@], [ # Need to assign to a variable since m4 is blocked from modifying parts in []. @@ -349,8 +350,8 @@ AC_DEFUN_ONCE([TOOLCHAIN_PRE_DETECTION], if test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.wsl"; then # Append VS_PATH. In WSL, VS_PATH will not contain the WSL env path needed # for using basic Unix tools, so need to keep the original PATH. - BASIC_APPEND_TO_PATH(PATH, $VS_PATH) - BASIC_APPEND_TO_PATH(WSLENV, "PATH/l:LIB:INCLUDE") + UTIL_APPEND_TO_PATH(PATH, $VS_PATH) + UTIL_APPEND_TO_PATH(WSLENV, "PATH/l:LIB:INCLUDE") export WSLENV else # Reset path to VS_PATH. It will include everything that was on PATH at the time we @@ -580,12 +581,12 @@ AC_DEFUN([TOOLCHAIN_FIND_COMPILER], fi # Now we have a compiler binary in $1. Make sure it's okay. - BASIC_FIXUP_EXECUTABLE($1) + UTIL_FIXUP_EXECUTABLE($1) TEST_COMPILER="[$]$1" AC_MSG_CHECKING([resolved symbolic links for $1]) SYMLINK_ORIGINAL="$TEST_COMPILER" - BASIC_REMOVE_SYMBOLIC_LINKS(SYMLINK_ORIGINAL) + UTIL_REMOVE_SYMBOLIC_LINKS(SYMLINK_ORIGINAL) if test "x$TEST_COMPILER" = "x$SYMLINK_ORIGINAL"; then AC_MSG_RESULT([no symlink]) else @@ -716,9 +717,9 @@ AC_DEFUN_ONCE([TOOLCHAIN_DETECT_TOOLCHAIN_CORE], # Setup the preprocessor (CPP and CXXCPP) # AC_PROG_CPP - BASIC_FIXUP_EXECUTABLE(CPP) + UTIL_FIXUP_EXECUTABLE(CPP) AC_PROG_CXXCPP - BASIC_FIXUP_EXECUTABLE(CXXCPP) + UTIL_FIXUP_EXECUTABLE(CXXCPP) # # Setup the linker (LD) @@ -728,7 +729,7 @@ AC_DEFUN_ONCE([TOOLCHAIN_DETECT_TOOLCHAIN_CORE], # Make sure we reject /usr/bin/link (as determined in CYGWIN_LINK), which is # a cygwin program for something completely different. AC_CHECK_PROG([LD], [link$EXE_SUFFIX],[link$EXE_SUFFIX],,, [$CYGWIN_LINK]) - BASIC_FIXUP_EXECUTABLE(LD) + UTIL_FIXUP_EXECUTABLE(LD) # Verify that we indeed succeeded with this trick. AC_MSG_CHECKING([if the found link.exe is actually the Visual Studio linker]) "$LD" --version > /dev/null @@ -746,8 +747,8 @@ AC_DEFUN_ONCE([TOOLCHAIN_DETECT_TOOLCHAIN_CORE], LD="$CC" LDCXX="$CXX" # jaotc expects 'ld' as the linker rather than the compiler. - BASIC_CHECK_TOOLS([LD_JAOTC], ld) - BASIC_FIXUP_EXECUTABLE(LD_JAOTC) + UTIL_CHECK_TOOLS([LD_JAOTC], ld) + UTIL_FIXUP_EXECUTABLE(LD_JAOTC) fi AC_SUBST(LD) AC_SUBST(LD_JAOTC) @@ -769,8 +770,8 @@ AC_DEFUN_ONCE([TOOLCHAIN_DETECT_TOOLCHAIN_CORE], # Setup the assembler (AS) # if test "x$OPENJDK_TARGET_OS" = xsolaris; then - BASIC_PATH_PROGS(AS, as) - BASIC_FIXUP_EXECUTABLE(AS) + UTIL_PATH_PROGS(AS, as) + UTIL_FIXUP_EXECUTABLE(AS) if test "x$AS" = x; then AC_MSG_ERROR([Solaris assembler (as) is required. Please install via "pkg install pkg:/developer/assembler".]) fi @@ -787,11 +788,11 @@ AC_DEFUN_ONCE([TOOLCHAIN_DETECT_TOOLCHAIN_CORE], # The corresponding ar tool is lib.exe (used to create static libraries) AC_CHECK_PROG([AR], [lib$EXE_SUFFIX],[lib$EXE_SUFFIX],,,) elif test "x$TOOLCHAIN_TYPE" = xgcc; then - BASIC_CHECK_TOOLS(AR, ar gcc-ar) + UTIL_CHECK_TOOLS(AR, ar gcc-ar) else - BASIC_CHECK_TOOLS(AR, ar) + UTIL_CHECK_TOOLS(AR, ar) fi - BASIC_FIXUP_EXECUTABLE(AR) + UTIL_FIXUP_EXECUTABLE(AR) ]) # Setup additional tools that is considered a part of the toolchain, but not the @@ -800,22 +801,22 @@ AC_DEFUN_ONCE([TOOLCHAIN_DETECT_TOOLCHAIN_CORE], AC_DEFUN_ONCE([TOOLCHAIN_DETECT_TOOLCHAIN_EXTRA], [ if test "x$OPENJDK_TARGET_OS" = "xmacosx"; then - BASIC_PATH_PROGS(LIPO, lipo) - BASIC_FIXUP_EXECUTABLE(LIPO) - BASIC_REQUIRE_PROGS(OTOOL, otool) - BASIC_FIXUP_EXECUTABLE(OTOOL) - BASIC_REQUIRE_PROGS(INSTALL_NAME_TOOL, install_name_tool) - BASIC_FIXUP_EXECUTABLE(INSTALL_NAME_TOOL) + UTIL_PATH_PROGS(LIPO, lipo) + UTIL_FIXUP_EXECUTABLE(LIPO) + UTIL_REQUIRE_PROGS(OTOOL, otool) + UTIL_FIXUP_EXECUTABLE(OTOOL) + UTIL_REQUIRE_PROGS(INSTALL_NAME_TOOL, install_name_tool) + UTIL_FIXUP_EXECUTABLE(INSTALL_NAME_TOOL) fi if test "x$TOOLCHAIN_TYPE" = xmicrosoft; then AC_CHECK_PROG([MT], [mt$EXE_SUFFIX], [mt$EXE_SUFFIX],,, [/usr/bin/mt]) - BASIC_FIXUP_EXECUTABLE(MT) + UTIL_FIXUP_EXECUTABLE(MT) # Setup the resource compiler (RC) AC_CHECK_PROG([RC], [rc$EXE_SUFFIX], [rc$EXE_SUFFIX],,, [/usr/bin/rc]) - BASIC_FIXUP_EXECUTABLE(RC) + UTIL_FIXUP_EXECUTABLE(RC) AC_CHECK_PROG([DUMPBIN], [dumpbin$EXE_SUFFIX], [dumpbin$EXE_SUFFIX],,,) - BASIC_FIXUP_EXECUTABLE(DUMPBIN) + UTIL_FIXUP_EXECUTABLE(DUMPBIN) # We need to check for 'msbuild.exe' because at the place where we expect to # find 'msbuild.exe' there's also a directory called 'msbuild' and configure # won't find the 'msbuild.exe' executable in that case (and the @@ -827,22 +828,22 @@ AC_DEFUN_ONCE([TOOLCHAIN_DETECT_TOOLCHAIN_EXTRA], fi if test "x$OPENJDK_TARGET_OS" = xsolaris; then - BASIC_PATH_PROGS(STRIP, strip) - BASIC_FIXUP_EXECUTABLE(STRIP) - BASIC_PATH_PROGS(NM, nm) - BASIC_FIXUP_EXECUTABLE(NM) - BASIC_PATH_PROGS(GNM, gnm) - BASIC_FIXUP_EXECUTABLE(GNM) + UTIL_PATH_PROGS(STRIP, strip) + UTIL_FIXUP_EXECUTABLE(STRIP) + UTIL_PATH_PROGS(NM, nm) + UTIL_FIXUP_EXECUTABLE(NM) + UTIL_PATH_PROGS(GNM, gnm) + UTIL_FIXUP_EXECUTABLE(GNM) elif test "x$OPENJDK_TARGET_OS" != xwindows; then # FIXME: we should unify this with the solaris case above. - BASIC_CHECK_TOOLS(STRIP, strip) - BASIC_FIXUP_EXECUTABLE(STRIP) + UTIL_CHECK_TOOLS(STRIP, strip) + UTIL_FIXUP_EXECUTABLE(STRIP) if test "x$TOOLCHAIN_TYPE" = xgcc; then - BASIC_CHECK_TOOLS(NM, nm gcc-nm) + UTIL_CHECK_TOOLS(NM, nm gcc-nm) else - BASIC_CHECK_TOOLS(NM, nm) + UTIL_CHECK_TOOLS(NM, nm) fi - BASIC_FIXUP_EXECUTABLE(NM) + UTIL_FIXUP_EXECUTABLE(NM) GNM="$NM" AC_SUBST(GNM) fi @@ -850,10 +851,10 @@ AC_DEFUN_ONCE([TOOLCHAIN_DETECT_TOOLCHAIN_EXTRA], # objcopy is used for moving debug symbols to separate files when # full debug symbols are enabled. if test "x$OPENJDK_TARGET_OS" = xsolaris || test "x$OPENJDK_TARGET_OS" = xlinux; then - BASIC_CHECK_TOOLS(OBJCOPY, [gobjcopy objcopy]) + UTIL_CHECK_TOOLS(OBJCOPY, [gobjcopy objcopy]) # Only call fixup if objcopy was found. if test -n "$OBJCOPY"; then - BASIC_FIXUP_EXECUTABLE(OBJCOPY) + UTIL_FIXUP_EXECUTABLE(OBJCOPY) if test "x$OPENJDK_BUILD_OS" = xsolaris; then # objcopy prior to 2.21.1 on solaris is broken and is not usable. # Rewrite objcopy version output to VALID_VERSION or BAD_VERSION. @@ -894,18 +895,18 @@ AC_DEFUN_ONCE([TOOLCHAIN_DETECT_TOOLCHAIN_EXTRA], fi fi - BASIC_CHECK_TOOLS(OBJDUMP, [gobjdump objdump]) + UTIL_CHECK_TOOLS(OBJDUMP, [gobjdump objdump]) if test "x$OBJDUMP" != x; then - # Only used for compare.sh; we can live without it. BASIC_FIXUP_EXECUTABLE + # Only used for compare.sh; we can live without it. UTIL_FIXUP_EXECUTABLE # bails if argument is missing. - BASIC_FIXUP_EXECUTABLE(OBJDUMP) + UTIL_FIXUP_EXECUTABLE(OBJDUMP) fi case $TOOLCHAIN_TYPE in gcc|clang|solstudio) - BASIC_CHECK_TOOLS(CXXFILT, [c++filt]) - BASIC_CHECK_NONEMPTY(CXXFILT) - BASIC_FIXUP_EXECUTABLE(CXXFILT) + UTIL_CHECK_TOOLS(CXXFILT, [c++filt]) + UTIL_CHECK_NONEMPTY(CXXFILT) + UTIL_FIXUP_EXECUTABLE(CXXFILT) ;; esac ]) @@ -933,7 +934,7 @@ AC_DEFUN_ONCE([TOOLCHAIN_SETUP_BUILD_COMPILERS], if test ! -d "$with_build_devkit"; then AC_MSG_ERROR([--with-build-devkit points to non existing dir: $with_build_devkit]) else - BASIC_FIXUP_PATH([with_build_devkit]) + UTIL_FIXUP_PATH([with_build_devkit]) BUILD_DEVKIT_ROOT="$with_build_devkit" # Check for a meta data info file in the root of the devkit if test -f "$BUILD_DEVKIT_ROOT/devkit.info"; then @@ -977,18 +978,18 @@ AC_DEFUN_ONCE([TOOLCHAIN_SETUP_BUILD_COMPILERS], # FIXME: we should list the discovered compilers as an exclude pattern! # If we do that, we can do this detection before POST_DETECTION, and still # find the build compilers in the tools dir, if needed. - BASIC_REQUIRE_PROGS(BUILD_CC, [cl cc gcc]) - BASIC_FIXUP_EXECUTABLE(BUILD_CC) - BASIC_REQUIRE_PROGS(BUILD_CXX, [cl CC g++]) - BASIC_FIXUP_EXECUTABLE(BUILD_CXX) - BASIC_PATH_PROGS(BUILD_NM, nm gcc-nm) - BASIC_FIXUP_EXECUTABLE(BUILD_NM) - BASIC_PATH_PROGS(BUILD_AR, ar gcc-ar) - BASIC_FIXUP_EXECUTABLE(BUILD_AR) - BASIC_PATH_PROGS(BUILD_OBJCOPY, objcopy) - BASIC_FIXUP_EXECUTABLE(BUILD_OBJCOPY) - BASIC_PATH_PROGS(BUILD_STRIP, strip) - BASIC_FIXUP_EXECUTABLE(BUILD_STRIP) + UTIL_REQUIRE_PROGS(BUILD_CC, [cl cc gcc]) + UTIL_FIXUP_EXECUTABLE(BUILD_CC) + UTIL_REQUIRE_PROGS(BUILD_CXX, [cl CC g++]) + UTIL_FIXUP_EXECUTABLE(BUILD_CXX) + UTIL_PATH_PROGS(BUILD_NM, nm gcc-nm) + UTIL_FIXUP_EXECUTABLE(BUILD_NM) + UTIL_PATH_PROGS(BUILD_AR, ar gcc-ar) + UTIL_FIXUP_EXECUTABLE(BUILD_AR) + UTIL_PATH_PROGS(BUILD_OBJCOPY, objcopy) + UTIL_FIXUP_EXECUTABLE(BUILD_OBJCOPY) + UTIL_PATH_PROGS(BUILD_STRIP, strip) + UTIL_FIXUP_EXECUTABLE(BUILD_STRIP) # Assume the C compiler is the assembler BUILD_AS="$BUILD_CC -c" # Just like for the target compiler, use the compiler as linker @@ -1082,7 +1083,7 @@ AC_DEFUN_ONCE([TOOLCHAIN_SETUP_JTREG], elif test "x$with_jtreg" != xyes && test "x$with_jtreg" != x; then # An explicit path is specified, use it. JT_HOME="$with_jtreg" - BASIC_FIXUP_PATH([JT_HOME]) + UTIL_FIXUP_PATH([JT_HOME]) if test ! -d "$JT_HOME"; then AC_MSG_ERROR([jtreg home directory from --with-jtreg=$with_jtreg does not exist]) fi @@ -1122,7 +1123,7 @@ AC_DEFUN_ONCE([TOOLCHAIN_SETUP_JTREG], if test "x$JT_HOME" = x; then # JT_HOME is not set in environment, or was deemed invalid. # Try to find jtreg on path - BASIC_PATH_PROGS(JTREGEXE, jtreg) + UTIL_PATH_PROGS(JTREGEXE, jtreg) if test "x$JTREGEXE" != x; then # That's good, now try to derive JT_HOME JT_HOME=`(cd $($DIRNAME $JTREGEXE)/.. && pwd)` @@ -1148,8 +1149,8 @@ AC_DEFUN_ONCE([TOOLCHAIN_SETUP_JTREG], fi fi - BASIC_FIXUP_EXECUTABLE(JTREGEXE) - BASIC_FIXUP_PATH(JT_HOME) + UTIL_FIXUP_EXECUTABLE(JTREGEXE) + UTIL_FIXUP_PATH(JT_HOME) AC_SUBST(JT_HOME) AC_SUBST(JTREGEXE) ]) diff --git a/make/autoconf/toolchain_windows.m4 b/make/autoconf/toolchain_windows.m4 index 90482ab78f8..462d14a0f69 100644 --- a/make/autoconf/toolchain_windows.m4 +++ b/make/autoconf/toolchain_windows.m4 @@ -112,7 +112,7 @@ AC_DEFUN([TOOLCHAIN_CHECK_POSSIBLE_VISUAL_STUDIO_ROOT], VS_BASE="$2" METHOD="$3" - BASIC_WINDOWS_REWRITE_AS_UNIX_PATH(VS_BASE) + UTIL_REWRITE_AS_UNIX_PATH(VS_BASE) # In VS 2017 and VS 2019, the default installation is in a subdir named after the edition. # Find the first one present and use that. if test "x$VS_EDITIONS" != x; then @@ -160,7 +160,7 @@ AC_DEFUN([TOOLCHAIN_CHECK_POSSIBLE_WIN_SDK_ROOT], VS_VERSION="$1" WIN_SDK_BASE="$2" METHOD="$3" - BASIC_WINDOWS_REWRITE_AS_UNIX_PATH(WIN_SDK_BASE) + UTIL_REWRITE_AS_UNIX_PATH(WIN_SDK_BASE) if test -d "$WIN_SDK_BASE"; then # There have been cases of partial or broken SDK installations. A missing # lib dir is not going to work. @@ -313,7 +313,7 @@ AC_DEFUN([TOOLCHAIN_FIND_VISUAL_STUDIO], VS_PATH_WINDOWS="" for i in $TOOLCHAIN_PATH; do path=$i - BASIC_WINDOWS_REWRITE_AS_WINDOWS_MIXED_PATH([path]) + UTIL_REWRITE_AS_WINDOWS_MIXED_PATH([path]) VS_PATH_WINDOWS="$VS_PATH_WINDOWS;$path" done IFS="$OLDIFS" @@ -331,14 +331,14 @@ AC_DEFUN([TOOLCHAIN_FIND_VISUAL_STUDIO], IFS=";" for i in $DEVKIT_VS_INCLUDE; do ipath=$i - BASIC_WINDOWS_REWRITE_AS_WINDOWS_MIXED_PATH([ipath]) + UTIL_REWRITE_AS_WINDOWS_MIXED_PATH([ipath]) VS_INCLUDE="$VS_INCLUDE;$ipath" done # Convert DEVKIT_VS_LIB into VS_LIB so that it can still be exported # as LIB for compiler invocations without SYSROOT_LDFLAGS for i in $DEVKIT_VS_LIB; do libpath=$i - BASIC_WINDOWS_REWRITE_AS_WINDOWS_MIXED_PATH([libpath]) + UTIL_REWRITE_AS_WINDOWS_MIXED_PATH([libpath]) VS_LIB="$VS_LIB;$libpath" done IFS="$OLDIFS" @@ -408,7 +408,7 @@ AC_DEFUN([TOOLCHAIN_SETUP_VISUAL_STUDIO_ENV], if test "x$DEVKIT_VS_VERSION" = x; then if test "x$VS_ENV_CMD" != x; then # We have found a Visual Studio environment on disk, let's extract variables from the vsvars bat file. - BASIC_FIXUP_EXECUTABLE(VS_ENV_CMD) + UTIL_FIXUP_EXECUTABLE(VS_ENV_CMD) # Lets extract the variables that are set by vcvarsall.bat/vsvars32.bat/vsvars64.bat AC_MSG_NOTICE([Trying to extract Visual Studio environment variables]) @@ -420,13 +420,13 @@ AC_DEFUN([TOOLCHAIN_SETUP_VISUAL_STUDIO_ENV], # Cannot use the VS10 setup script directly (since it only updates the DOS subshell environment). # Instead create a shell script which will set the relevant variables when run. WINPATH_VS_ENV_CMD="$VS_ENV_CMD" - BASIC_WINDOWS_REWRITE_AS_WINDOWS_MIXED_PATH([WINPATH_VS_ENV_CMD]) + UTIL_REWRITE_AS_WINDOWS_MIXED_PATH([WINPATH_VS_ENV_CMD]) if test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.wsl"; then WINPATH_BASH="bash" else WINPATH_BASH="$BASH" - BASIC_WINDOWS_REWRITE_AS_WINDOWS_MIXED_PATH([WINPATH_BASH]) + UTIL_REWRITE_AS_WINDOWS_MIXED_PATH([WINPATH_BASH]) fi # Generate a DOS batch file which runs $VS_ENV_CMD, and then creates a shell @@ -521,10 +521,10 @@ AC_DEFUN([TOOLCHAIN_SETUP_VISUAL_STUDIO_ENV], IFS="$OLDIFS" # Check that directory exists before calling fixup_path testpath=$path - BASIC_WINDOWS_REWRITE_AS_UNIX_PATH([testpath]) + UTIL_REWRITE_AS_UNIX_PATH([testpath]) if test -d "$testpath"; then - BASIC_FIXUP_PATH([path]) - BASIC_APPEND_TO_PATH(VS_PATH, $path) + UTIL_FIXUP_PATH([path]) + UTIL_APPEND_TO_PATH(VS_PATH, $path) fi IFS=";" fi @@ -576,9 +576,9 @@ AC_DEFUN([TOOLCHAIN_SETUP_VISUAL_STUDIO_ENV], IFS="$OLDIFS" # Check that directory exists before calling fixup_path testpath=$ipath - BASIC_WINDOWS_REWRITE_AS_UNIX_PATH([testpath]) + UTIL_REWRITE_AS_UNIX_PATH([testpath]) if test -d "$testpath"; then - BASIC_FIXUP_PATH([ipath]) + UTIL_FIXUP_PATH([ipath]) SYSROOT_CFLAGS="$SYSROOT_CFLAGS -I$ipath" fi IFS=";" @@ -592,9 +592,9 @@ AC_DEFUN([TOOLCHAIN_SETUP_VISUAL_STUDIO_ENV], IFS="$OLDIFS" # Check that directory exists before calling fixup_path testpath=$libpath - BASIC_WINDOWS_REWRITE_AS_UNIX_PATH([testpath]) + UTIL_REWRITE_AS_UNIX_PATH([testpath]) if test -d "$testpath"; then - BASIC_FIXUP_PATH([libpath]) + UTIL_FIXUP_PATH([libpath]) SYSROOT_LDFLAGS="$SYSROOT_LDFLAGS -libpath:$libpath" fi IFS=";" @@ -665,7 +665,7 @@ AC_DEFUN([TOOLCHAIN_SETUP_MSVC_DLL], if test "x$MSVC_DLL" = x; then if test "x$VCINSTALLDIR" != x; then CYGWIN_VC_INSTALL_DIR="$VCINSTALLDIR" - BASIC_FIXUP_PATH(CYGWIN_VC_INSTALL_DIR) + UTIL_FIXUP_PATH(CYGWIN_VC_INSTALL_DIR) if test "$VS_VERSION" -lt 2017; then # Probe: Using well-known location from Visual Studio 12.0 and older if test "x$OPENJDK_TARGET_CPU_BITS" = x64; then @@ -675,7 +675,7 @@ AC_DEFUN([TOOLCHAIN_SETUP_MSVC_DLL], fi else CYGWIN_VC_TOOLS_REDIST_DIR="$VCToolsRedistDir" - BASIC_FIXUP_PATH(CYGWIN_VC_TOOLS_REDIST_DIR) + UTIL_FIXUP_PATH(CYGWIN_VC_TOOLS_REDIST_DIR) # Probe: Using well-known location from VS 2017 and VS 2019 if test "x$OPENJDK_TARGET_CPU_BITS" = x64; then POSSIBLE_MSVC_DLL="`ls $CYGWIN_VC_TOOLS_REDIST_DIR/x64/Microsoft.VC${VS_VERSION_INTERNAL}.CRT/$DLL_NAME`" @@ -702,7 +702,7 @@ AC_DEFUN([TOOLCHAIN_SETUP_MSVC_DLL], if test "x$MSVC_DLL" = x; then # Probe: Look in the Windows system32 directory CYGWIN_SYSTEMROOT="$SYSTEMROOT" - BASIC_WINDOWS_REWRITE_AS_UNIX_PATH(CYGWIN_SYSTEMROOT) + UTIL_REWRITE_AS_UNIX_PATH(CYGWIN_SYSTEMROOT) POSSIBLE_MSVC_DLL="$CYGWIN_SYSTEMROOT/system32/$DLL_NAME" TOOLCHAIN_CHECK_POSSIBLE_MSVC_DLL([$DLL_NAME], [$POSSIBLE_MSVC_DLL], [well-known location in SYSTEMROOT]) @@ -712,7 +712,7 @@ AC_DEFUN([TOOLCHAIN_SETUP_MSVC_DLL], # Probe: If Visual Studio Express is installed, there is usually one with the debugger if test "x$VS100COMNTOOLS" != x; then CYGWIN_VS_TOOLS_DIR="$VS100COMNTOOLS/.." - BASIC_WINDOWS_REWRITE_AS_UNIX_PATH(CYGWIN_VS_TOOLS_DIR) + UTIL_REWRITE_AS_UNIX_PATH(CYGWIN_VS_TOOLS_DIR) if test "x$OPENJDK_TARGET_CPU_BITS" = x64; then POSSIBLE_MSVC_DLL=`$FIND "$CYGWIN_VS_TOOLS_DIR" -name $DLL_NAME \ | $GREP -i /x64/ | $HEAD --lines 1` @@ -814,14 +814,14 @@ AC_DEFUN([TOOLCHAIN_SETUP_VS_RUNTIME_DLLS], else AC_MSG_RESULT([$with_ucrt_dll_dir]) UCRT_DLL_DIR="$with_ucrt_dll_dir" - BASIC_FIXUP_PATH([UCRT_DLL_DIR]) + UTIL_FIXUP_PATH([UCRT_DLL_DIR]) fi elif test "x$DEVKIT_UCRT_DLL_DIR" != "x"; then UCRT_DLL_DIR="$DEVKIT_UCRT_DLL_DIR" AC_MSG_RESULT($UCRT_DLL_DIR) else CYGWIN_WINDOWSSDKDIR="${WINDOWSSDKDIR}" - BASIC_FIXUP_PATH([CYGWIN_WINDOWSSDKDIR]) + UTIL_FIXUP_PATH([CYGWIN_WINDOWSSDKDIR]) dll_subdir=$OPENJDK_TARGET_CPU if test "x$dll_subdir" = "xx86_64"; then dll_subdir="x64" diff --git a/make/autoconf/util.m4 b/make/autoconf/util.m4 new file mode 100644 index 00000000000..cf5f1a46b4b --- /dev/null +++ b/make/autoconf/util.m4 @@ -0,0 +1,378 @@ +# +# Copyright (c) 2011, 2020, Oracle and/or its affiliates. All rights reserved. +# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. +# +# This code is free software; you can redistribute it and/or modify it +# under the terms of the GNU General Public License version 2 only, as +# published by the Free Software Foundation. Oracle designates this +# particular file as subject to the "Classpath" exception as provided +# by Oracle in the LICENSE file that accompanied this code. +# +# This code is distributed in the hope that it will be useful, but WITHOUT +# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or +# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License +# version 2 for more details (a copy is included in the LICENSE file that +# accompanied this code). +# +# You should have received a copy of the GNU General Public License version +# 2 along with this work; if not, write to the Free Software Foundation, +# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. +# +# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA +# or visit www.oracle.com if you need additional information or have any +# questions. +# + +m4_include([util_paths.m4]) +m4_include([util_windows.m4]) + +############################################################################### +# Create a function/macro that takes a series of named arguments. The call is +# similar to AC_DEFUN, but the setup of the function looks like this: +# UTIL_DEFUN_NAMED([MYFUNC], [FOO *BAR], [$@], [ +# ... do something +# AC_MSG_NOTICE([Value of BAR is ARG_BAR]) +# ]) +# A star (*) in front of a named argument means that it is required and it's +# presence will be verified. To pass e.g. the first value as a normal indexed +# argument, use [m4_shift($@)] as the third argument instead of [$@]. These +# arguments are referenced in the function by their name prefixed by ARG_, e.g. +# "ARG_FOO". +# +# The generated function can be called like this: +# MYFUNC(FOO: [foo-val], +# BAR: [ +# $ECHO hello world +# ]) +# Note that the argument value must start on the same line as the argument name. +# +# Argument 1: Name of the function to define +# Argument 2: List of legal named arguments, with a * prefix for required arguments +# Argument 3: Argument array to treat as named, typically $@ +# Argument 4: The main function body +AC_DEFUN([UTIL_DEFUN_NAMED], +[ + AC_DEFUN($1, [ + m4_foreach(arg, m4_split($2), [ + m4_if(m4_bregexp(arg, [^\*]), -1, + [ + m4_set_add(legal_named_args, arg) + ], + [ + m4_set_add(legal_named_args, m4_substr(arg, 1)) + m4_set_add(required_named_args, m4_substr(arg, 1)) + ] + ) + ]) + + m4_foreach([arg], [$3], [ + m4_define(arg_name, m4_substr(arg, 0, m4_bregexp(arg, [: ]))) + m4_set_contains(legal_named_args, arg_name, [],[AC_MSG_ERROR([Internal error: arg_name is not a valid named argument to [$1]. Valid arguments are 'm4_set_contents(legal_named_args, [ ])'.])]) + m4_set_remove(required_named_args, arg_name) + m4_set_remove(legal_named_args, arg_name) + m4_pushdef([ARG_][]arg_name, m4_substr(arg, m4_incr(m4_incr(m4_bregexp(arg, [: ]))))) + m4_set_add(defined_args, arg_name) + m4_undefine([arg_name]) + ]) + m4_set_empty(required_named_args, [], [ + AC_MSG_ERROR([Internal error: Required named arguments are missing for [$1]. Missing arguments: 'm4_set_contents(required_named_args, [ ])']) + ]) + m4_foreach([arg], m4_indir([m4_dquote]m4_set_listc([legal_named_args])), [ + m4_pushdef([ARG_][]arg, []) + m4_set_add(defined_args, arg) + ]) + m4_set_delete(legal_named_args) + m4_set_delete(required_named_args) + + # Execute function body + $4 + + m4_foreach([arg], m4_indir([m4_dquote]m4_set_listc([defined_args])), [ + m4_popdef([ARG_][]arg) + ]) + + m4_set_delete(defined_args) + ]) +]) + +############################################################################### +# Check if a list of space-separated words are selected only from a list of +# space-separated legal words. Typical use is to see if a user-specified +# set of words is selected from a set of legal words. +# +# Sets the specified variable to list of non-matching (offending) words, or to +# the empty string if all words are matching the legal set. +# +# $1: result variable name +# $2: list of values to check +# $3: list of legal values +AC_DEFUN([UTIL_GET_NON_MATCHING_VALUES], +[ + # grep filter function inspired by a comment to http://stackoverflow.com/a/1617326 + # Notice that the original variant fails on SLES 10 and 11 + # Some grep versions (at least bsd) behaves strangely on the base case with + # no legal_values, so make it explicit. + values_to_check=`$ECHO $2 | $TR ' ' '\n'` + legal_values=`$ECHO $3 | $TR ' ' '\n'` + if test -z "$legal_values"; then + $1="$2" + else + result=`$GREP -Fvx "$legal_values" <<< "$values_to_check" | $GREP -v '^$'` + $1=${result//$'\n'/ } + fi +]) + +############################################################################### +# Check if a list of space-separated words contains any word(s) from a list of +# space-separated illegal words. Typical use is to see if a user-specified +# set of words contains any from a set of illegal words. +# +# Sets the specified variable to list of matching illegal words, or to +# the empty string if no words are matching the illegal set. +# +# $1: result variable name +# $2: list of values to check +# $3: list of illegal values +AC_DEFUN([UTIL_GET_MATCHING_VALUES], +[ + # grep filter function inspired by a comment to http://stackoverflow.com/a/1617326 + # Notice that the original variant fails on SLES 10 and 11 + # Some grep versions (at least bsd) behaves strangely on the base case with + # no legal_values, so make it explicit. + values_to_check=`$ECHO $2 | $TR ' ' '\n'` + illegal_values=`$ECHO $3 | $TR ' ' '\n'` + if test -z "$illegal_values"; then + $1="" + else + result=`$GREP -Fx "$illegal_values" <<< "$values_to_check" | $GREP -v '^$'` + $1=${result//$'\n'/ } + fi +]) + +############################################################################### +# Sort a space-separated list, and remove duplicates. +# +# Sets the specified variable to the resulting list. +# +# $1: result variable name +# $2: list of values to sort +AC_DEFUN([UTIL_SORT_LIST], +[ + values_to_sort=`$ECHO $2 | $TR ' ' '\n'` + result=`$SORT -u <<< "$values_to_sort" | $GREP -v '^$'` + $1=${result//$'\n'/ } +]) + +############################################################################### +# Test if $1 is a valid argument to $3 (often is $JAVA passed as $3) +# If so, then append $1 to $2 \ +# Also set JVM_ARG_OK to true/false depending on outcome. +AC_DEFUN([UTIL_ADD_JVM_ARG_IF_OK], +[ + $ECHO "Check if jvm arg is ok: $1" >&AS_MESSAGE_LOG_FD + $ECHO "Command: $3 $1 -version" >&AS_MESSAGE_LOG_FD + OUTPUT=`$3 $1 $USER_BOOT_JDK_OPTIONS -version 2>&1` + FOUND_WARN=`$ECHO "$OUTPUT" | $GREP -i warn` + FOUND_VERSION=`$ECHO $OUTPUT | $GREP " version \""` + if test "x$FOUND_VERSION" != x && test "x$FOUND_WARN" = x; then + $2="[$]$2 $1" + JVM_ARG_OK=true + else + $ECHO "Arg failed:" >&AS_MESSAGE_LOG_FD + $ECHO "$OUTPUT" >&AS_MESSAGE_LOG_FD + JVM_ARG_OK=false + fi +]) + +############################################################################### +# Register a --with argument but mark it as deprecated +# $1: The name of the with argument to deprecate, not including --with- +AC_DEFUN([UTIL_DEPRECATED_ARG_WITH], +[ + AC_ARG_WITH($1, [AS_HELP_STRING([--with-$1], + [Deprecated. Option is kept for backwards compatibility and is ignored])], + [AC_MSG_WARN([Option --with-$1 is deprecated and will be ignored.])]) +]) + +############################################################################### +# Register a --enable argument but mark it as deprecated +# $1: The name of the with argument to deprecate, not including --enable- +# $2: The name of the argument to deprecate, in shell variable style (i.e. with _ instead of -) +# $3: Messages to user. +AC_DEFUN([UTIL_DEPRECATED_ARG_ENABLE], +[ + AC_ARG_ENABLE($1, [AS_HELP_STRING([--enable-$1], + [Deprecated. Option is kept for backwards compatibility and is ignored])]) + if test "x$enable_$2" != x; then + AC_MSG_WARN([Option --enable-$1 is deprecated and will be ignored.]) + + if test "x$3" != x; then + AC_MSG_WARN([$3]) + fi + + fi +]) + +############################################################################### +# Register an --enable-* argument as an alias for another argument. +# $1: The name of the enable argument for the new alias, not including --enable- +# $2: The full name of the argument of which to make this an alias, including +# --enable- or --with-. +AC_DEFUN([UTIL_ALIASED_ARG_ENABLE], +[ + AC_ARG_ENABLE($1, [AS_HELP_STRING([--enable-$1], [alias for $2])], [ + # Use m4 to strip initial -- from target ($2), convert - to _, prefix enable_ + # to new alias name, and create a shell variable assignment, + # e.g.: enable_old_style="$enable_new_alias" + translit(patsubst($2, --), -, _)="$[enable_]translit($1, -, _)" + ]) +]) + +############################################################################### +# Test that variable $1 denoting a program is not empty. If empty, exit with an error. +# $1: variable to check +AC_DEFUN([UTIL_CHECK_NONEMPTY], +[ + if test "x[$]$1" = x; then + AC_MSG_ERROR([Could not find required tool for $1]) + fi +]) + +############################################################################### +# Setup a tool for the given variable. If correctly specified by the user, +# use that value, otherwise search for the tool using the supplied code snippet. +# $1: variable to set +# $2: code snippet to call to look for the tool +# $3: code snippet to call if variable was used to find tool +AC_DEFUN([UTIL_SETUP_TOOL], +[ + # Publish this variable in the help. + AC_ARG_VAR($1, [Override default value for $1]) + + if [[ -z "${$1+x}" ]]; then + # The variable is not set by user, try to locate tool using the code snippet + $2 + else + # The variable is set, but is it from the command line or the environment? + + # Try to remove the string !$1! from our list. + try_remove_var=${CONFIGURE_OVERRIDDEN_VARIABLES//!$1!/} + if test "x$try_remove_var" = "x$CONFIGURE_OVERRIDDEN_VARIABLES"; then + # If it failed, the variable was not from the command line. Ignore it, + # but warn the user (except for BASH, which is always set by the calling BASH). + if test "x$1" != xBASH; then + AC_MSG_WARN([Ignoring value of $1 from the environment. Use command line variables instead.]) + fi + # Try to locate tool using the code snippet + $2 + else + # If it succeeded, then it was overridden by the user. We will use it + # for the tool. + + # First remove it from the list of overridden variables, so we can test + # for unknown variables in the end. + CONFIGURE_OVERRIDDEN_VARIABLES="$try_remove_var" + + tool_override=[$]$1 + AC_MSG_NOTICE([User supplied override $1="$tool_override"]) + + # Check if we try to supply an empty value + if test "x$tool_override" = x; then + AC_MSG_CHECKING([for $1]) + AC_MSG_RESULT([disabled]) + else + # Split up override in command part and argument part + tool_and_args=($tool_override) + [ tool_command=${tool_and_args[0]} ] + [ unset 'tool_and_args[0]' ] + [ tool_args=${tool_and_args[@]} ] + + # Check if the provided tool contains a complete path. + tool_basename="${tool_command##*/}" + if test "x$tool_basename" = "x$tool_command"; then + # A command without a complete path is provided, search $PATH. + AC_MSG_NOTICE([Will search for user supplied tool "$tool_basename"]) + AC_PATH_PROG($1, $tool_basename) + if test "x[$]$1" = x; then + AC_MSG_ERROR([User supplied tool $1="$tool_basename" could not be found]) + fi + else + # Otherwise we believe it is a complete path. Use it as it is. + AC_MSG_NOTICE([Will use user supplied tool "$tool_command"]) + AC_MSG_CHECKING([for $tool_command]) + if test ! -x "$tool_command"; then + AC_MSG_RESULT([not found]) + AC_MSG_ERROR([User supplied tool $1="$tool_command" does not exist or is not executable]) + fi + $1="$tool_command" + AC_MSG_RESULT([found]) + fi + if test "x$tool_args" != x; then + # If we got arguments, re-append them to the command after the fixup. + $1="[$]$1 $tool_args" + fi + fi + fi + $3 + fi +]) + +############################################################################### +# Call UTIL_SETUP_TOOL with AC_PATH_PROGS to locate the tool +# $1: variable to set +# $2: executable name (or list of names) to look for +# $3: [path] +AC_DEFUN([UTIL_PATH_PROGS], +[ + UTIL_SETUP_TOOL($1, [AC_PATH_PROGS($1, $2, , $3)]) +]) + +############################################################################### +# Call UTIL_SETUP_TOOL with AC_CHECK_TOOLS to locate the tool +# $1: variable to set +# $2: executable name (or list of names) to look for +AC_DEFUN([UTIL_CHECK_TOOLS], +[ + UTIL_SETUP_TOOL($1, [AC_CHECK_TOOLS($1, $2)]) +]) + +############################################################################### +# Like UTIL_PATH_PROGS but fails if no tool was found. +# $1: variable to set +# $2: executable name (or list of names) to look for +# $3: [path] +AC_DEFUN([UTIL_REQUIRE_PROGS], +[ + UTIL_PATH_PROGS($1, $2, , $3) + UTIL_CHECK_NONEMPTY($1) +]) + +############################################################################### +# Like UTIL_SETUP_TOOL but fails if no tool was found. +# $1: variable to set +# $2: autoconf macro to call to look for the special tool +AC_DEFUN([UTIL_REQUIRE_SPECIAL], +[ + UTIL_SETUP_TOOL($1, [$2]) + UTIL_CHECK_NONEMPTY($1) +]) + +############################################################################### +# Like UTIL_REQUIRE_PROGS but also allows for bash built-ins +# $1: variable to set +# $2: executable name (or list of names) to look for +# $3: [path] +AC_DEFUN([UTIL_REQUIRE_BUILTIN_PROGS], +[ + UTIL_SETUP_TOOL($1, [AC_PATH_PROGS($1, $2, , $3)]) + if test "x[$]$1" = x; then + AC_MSG_NOTICE([Required tool $2 not found in PATH, checking built-in]) + if help $2 > /dev/null 2>&1; then + AC_MSG_NOTICE([Found $2 as shell built-in. Using it]) + $1="$2" + else + AC_MSG_ERROR([Required tool $2 also not found as built-in.]) + fi + fi + UTIL_CHECK_NONEMPTY($1) +]) diff --git a/make/autoconf/util_paths.m4 b/make/autoconf/util_paths.m4 new file mode 100644 index 00000000000..9a3d3e2bb04 --- /dev/null +++ b/make/autoconf/util_paths.m4 @@ -0,0 +1,232 @@ +# +# Copyright (c) 2011, 2020, Oracle and/or its affiliates. All rights reserved. +# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. +# +# This code is free software; you can redistribute it and/or modify it +# under the terms of the GNU General Public License version 2 only, as +# published by the Free Software Foundation. Oracle designates this +# particular file as subject to the "Classpath" exception as provided +# by Oracle in the LICENSE file that accompanied this code. +# +# This code is distributed in the hope that it will be useful, but WITHOUT +# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or +# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License +# version 2 for more details (a copy is included in the LICENSE file that +# accompanied this code). +# +# You should have received a copy of the GNU General Public License version +# 2 along with this work; if not, write to the Free Software Foundation, +# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. +# +# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA +# or visit www.oracle.com if you need additional information or have any +# questions. +# + +# Appends a string to a path variable, only adding the : when needed. +AC_DEFUN([UTIL_APPEND_TO_PATH], +[ + if test "x$2" != x; then + if test "x[$]$1" = x; then + $1="$2" + else + $1="[$]$1:$2" + fi + fi +]) + +# Prepends a string to a path variable, only adding the : when needed. +AC_DEFUN([UTIL_PREPEND_TO_PATH], +[ + if test "x$2" != x; then + if test "x[$]$1" = x; then + $1="$2" + else + $1="$2:[$]$1" + fi + fi +]) + +################################################################################ +# This will make a path absolute. Assumes it's already a unix path. Also +# resolves ~ to homedir. +AC_DEFUN([UTIL_ABSOLUTE_PATH], +[ + if test "x[$]$1" != x; then + new_path="[$]$1" + + # Use eval to expand a potential ~. This technique does not work if there + # are spaces in the path (which is valid at this point on Windows), so only + # try to apply it if there is an actual ~ first in the path. + if [ [[ "$new_path" = "~"* ]] ]; then + eval new_path="$new_path" + if test ! -f "$new_path" && test ! -d "$new_path"; then + AC_MSG_ERROR([The new_path of $1, which resolves as "$new_path", is not found.]) + fi + fi + + if test -d "$new_path"; then + $1="`cd "$new_path"; $THEPWDCMD -L`" + else + dir="`$DIRNAME "$new_path"`" + base="`$BASENAME "$new_path"`" + $1="`cd "$dir"; $THEPWDCMD -L`/$base" + fi + fi +]) + +############################################################################### +# This will make sure the given variable points to a full and proper +# path. This means: +# 1) There will be no spaces in the path. On unix platforms, +# spaces in the path will result in an error. On Windows, +# the path will be rewritten using short-style to be space-free. +# 2) The path will be absolute, and it will be in unix-style (on +# cygwin). +# $1: The name of the variable to fix +AC_DEFUN([UTIL_FIXUP_PATH], +[ + # Only process if variable expands to non-empty + if test "x[$]$1" != x; then + if test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.cygwin"; then + UTIL_FIXUP_PATH_CYGWIN($1) + elif test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.msys"; then + UTIL_FIXUP_PATH_MSYS($1) + elif test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.wsl"; then + UTIL_FIXUP_PATH_WSL($1) + else + # We're on a unix platform. Hooray! :) + path="[$]$1" + has_space=`$ECHO "$path" | $GREP " "` + if test "x$has_space" != x; then + AC_MSG_NOTICE([The path of $1, which resolves as "$path", is invalid.]) + AC_MSG_ERROR([Spaces are not allowed in this path.]) + fi + + UTIL_ABSOLUTE_PATH(path) + $1="$path" + fi + fi +]) + +############################################################################### +# This will make sure the given variable points to a executable +# with a full and proper path. This means: +# 1) There will be no spaces in the path. On unix platforms, +# spaces in the path will result in an error. On Windows, +# the path will be rewritten using short-style to be space-free. +# 2) The path will be absolute, and it will be in unix-style (on +# cygwin). +# Any arguments given to the executable is preserved. +# If the input variable does not have a directory specification, then +# it need to be in the PATH. +# $1: The name of the variable to fix +AC_DEFUN([UTIL_FIXUP_EXECUTABLE], +[ + # Only process if variable expands to non-empty + + if test "x[$]$1" != x; then + if test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.cygwin"; then + UTIL_FIXUP_EXECUTABLE_CYGWIN($1) + elif test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.msys"; then + UTIL_FIXUP_EXECUTABLE_MSYS($1) + elif test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.wsl"; then + UTIL_FIXUP_EXECUTABLE_WSL($1) + else + # We're on a unix platform. Hooray! :) + # First separate the path from the arguments. This will split at the first + # space. + complete="[$]$1" + path="${complete%% *}" + tmp="$complete EOL" + arguments="${tmp#* }" + + # Cannot rely on the command "which" here since it doesn't always work. + is_absolute_path=`$ECHO "$path" | $GREP ^/` + if test -z "$is_absolute_path"; then + # Path to executable is not absolute. Find it. + IFS_save="$IFS" + IFS=: + for p in $PATH; do + if test -f "$p/$path" && test -x "$p/$path"; then + new_path="$p/$path" + break + fi + done + IFS="$IFS_save" + else + # This is an absolute path, we can use it without further modifications. + new_path="$path" + fi + + if test "x$new_path" = x; then + AC_MSG_NOTICE([The path of $1, which resolves as "$complete", is not found.]) + has_space=`$ECHO "$complete" | $GREP " "` + if test "x$has_space" != x; then + AC_MSG_NOTICE([This might be caused by spaces in the path, which is not allowed.]) + fi + AC_MSG_ERROR([Cannot locate the the path of $1]) + fi + fi + + # Now join together the path and the arguments once again + if test "x$arguments" != xEOL; then + new_complete="$new_path ${arguments% *}" + else + new_complete="$new_path" + fi + + if test "x$complete" != "x$new_complete"; then + $1="$new_complete" + AC_MSG_NOTICE([Rewriting $1 to "$new_complete"]) + fi + fi +]) + +############################################################################### +AC_DEFUN([UTIL_REMOVE_SYMBOLIC_LINKS], +[ + if test "x$OPENJDK_BUILD_OS" != xwindows; then + # Follow a chain of symbolic links. Use readlink + # where it exists, else fall back to horribly + # complicated shell code. + if test "x$READLINK_TESTED" != yes; then + # On MacOSX there is a readlink tool with a different + # purpose than the GNU readlink tool. Check the found readlink. + READLINK_ISGNU=`$READLINK --version 2>&1 | $GREP GNU` + # If READLINK_ISGNU is empty, then it's a non-GNU readlink. Don't use it. + READLINK_TESTED=yes + fi + + if test "x$READLINK" != x && test "x$READLINK_ISGNU" != x; then + $1=`$READLINK -f [$]$1` + else + # Save the current directory for restoring afterwards + STARTDIR=$PWD + COUNTER=0 + sym_link_dir=`$DIRNAME [$]$1` + sym_link_file=`$BASENAME [$]$1` + cd $sym_link_dir + # Use -P flag to resolve symlinks in directories. + cd `$THEPWDCMD -P` + sym_link_dir=`$THEPWDCMD -P` + # Resolve file symlinks + while test $COUNTER -lt 20; do + ISLINK=`$LS -l $sym_link_dir/$sym_link_file | $GREP '\->' | $SED -e 's/.*-> \(.*\)/\1/'` + if test "x$ISLINK" == x; then + # This is not a symbolic link! We are done! + break + fi + # Again resolve directory symlinks since the target of the just found + # link could be in a different directory + cd `$DIRNAME $ISLINK` + sym_link_dir=`$THEPWDCMD -P` + sym_link_file=`$BASENAME $ISLINK` + let COUNTER=COUNTER+1 + done + cd $STARTDIR + $1=$sym_link_dir/$sym_link_file + fi + fi +]) + diff --git a/make/autoconf/basics_windows.m4 b/make/autoconf/util_windows.m4 similarity index 65% rename from make/autoconf/basics_windows.m4 rename to make/autoconf/util_windows.m4 index 1c2536c72ce..625f360f2f9 100644 --- a/make/autoconf/basics_windows.m4 +++ b/make/autoconf/util_windows.m4 @@ -23,7 +23,7 @@ # questions. # -AC_DEFUN([BASIC_WINDOWS_REWRITE_AS_UNIX_PATH], +AC_DEFUN([UTIL_REWRITE_AS_UNIX_PATH], [ windows_path="[$]$1" if test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.cygwin"; then @@ -42,7 +42,7 @@ AC_DEFUN([BASIC_WINDOWS_REWRITE_AS_UNIX_PATH], fi ]) -AC_DEFUN([BASIC_WINDOWS_REWRITE_AS_WINDOWS_MIXED_PATH], +AC_DEFUN([UTIL_REWRITE_AS_WINDOWS_MIXED_PATH], [ unix_path="[$]$1" if test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.cygwin"; then @@ -60,7 +60,7 @@ AC_DEFUN([BASIC_WINDOWS_REWRITE_AS_WINDOWS_MIXED_PATH], # Helper function which possibly converts a path using DOS-style short mode. # If so, the updated path is stored in $new_path. # $1: The path to check -AC_DEFUN([BASIC_MAKE_WINDOWS_SPACE_SAFE_CYGWIN], +AC_DEFUN([UTIL_MAKE_WINDOWS_SPACE_SAFE_CYGWIN], [ input_path="$1" # Check if we need to convert this using DOS-style short mode. If the path @@ -96,7 +96,7 @@ AC_DEFUN([BASIC_MAKE_WINDOWS_SPACE_SAFE_CYGWIN], # Helper function which possibly converts a path using DOS-style short mode. # If so, the updated path is stored in $new_path. # $1: The path to check -AC_DEFUN([BASIC_MAKE_WINDOWS_SPACE_SAFE_MSYS], +AC_DEFUN([UTIL_MAKE_WINDOWS_SPACE_SAFE_MSYS], [ input_path="$1" # Check if we need to convert this using DOS-style short mode. If the path @@ -113,7 +113,7 @@ AC_DEFUN([BASIC_MAKE_WINDOWS_SPACE_SAFE_MSYS], # Helper function which possibly converts a path using DOS-style short mode. # If so, the updated path is stored in $new_path. # $1: The path to check -AC_DEFUN([BASIC_MAKE_WINDOWS_SPACE_SAFE_WSL], +AC_DEFUN([UTIL_MAKE_WINDOWS_SPACE_SAFE_WSL], [ input_path="$1" # Check if we need to convert this using DOS-style short mode. If the path @@ -124,31 +124,31 @@ AC_DEFUN([BASIC_MAKE_WINDOWS_SPACE_SAFE_WSL], if test "x$has_forbidden_chars" != x; then # Now convert it to mixed DOS-style, short mode (no spaces, and / instead of \) TOPDIR_windows="$TOPDIR" - BASIC_WINDOWS_REWRITE_AS_WINDOWS_MIXED_PATH([TOPDIR_windows]) + UTIL_REWRITE_AS_WINDOWS_MIXED_PATH([TOPDIR_windows]) # First convert to Windows path to make input valid for cmd - BASIC_WINDOWS_REWRITE_AS_WINDOWS_MIXED_PATH([input_path]) + UTIL_REWRITE_AS_WINDOWS_MIXED_PATH([input_path]) new_path=`$CMD /c $TOPDIR_windows/make/scripts/windowsShortName.bat "$input_path" \ | $SED -e 's|\r||g' \ | $TR \\\\\\\\ / | $TR 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz'` # Rewrite back to unix style - BASIC_WINDOWS_REWRITE_AS_UNIX_PATH([new_path]) + UTIL_REWRITE_AS_UNIX_PATH([new_path]) fi ]) -# FIXME: The BASIC_FIXUP_*_CYGWIN/MSYS is most likely too convoluted +# FIXME: The UTIL_FIXUP_*_CYGWIN/MSYS is most likely too convoluted # and could probably be heavily simplified. However, all changes in this # area tend to need lot of testing in different scenarios, and in lack of # proper unit testing, cleaning this up has not been deemed worth the effort # at the moment. -AC_DEFUN([BASIC_FIXUP_PATH_CYGWIN], +AC_DEFUN([UTIL_FIXUP_PATH_CYGWIN], [ # Input might be given as Windows format, start by converting to # unix format. path="[$]$1" new_path=`$CYGPATH -u "$path"` - BASIC_ABSOLUTE_PATH(new_path) + UTIL_ABSOLUTE_PATH(new_path) # Cygwin tries to hide some aspects of the Windows file system, such that binaries are # named .exe but called without that suffix. Therefore, "foo" and "foo.exe" are considered @@ -165,7 +165,7 @@ AC_DEFUN([BASIC_FIXUP_PATH_CYGWIN], # Call helper function which possibly converts this using DOS-style short mode. # If so, the updated path is stored in $new_path. - BASIC_MAKE_WINDOWS_SPACE_SAFE_CYGWIN([$new_path]) + UTIL_MAKE_WINDOWS_SPACE_SAFE_CYGWIN([$new_path]) if test "x$path" != "x$new_path"; then $1="$new_path" @@ -173,7 +173,7 @@ AC_DEFUN([BASIC_FIXUP_PATH_CYGWIN], fi ]) -AC_DEFUN([BASIC_FIXUP_PATH_MSYS], +AC_DEFUN([UTIL_FIXUP_PATH_MSYS], [ path="[$]$1" has_colon=`$ECHO $path | $GREP ^.:` @@ -183,10 +183,10 @@ AC_DEFUN([BASIC_FIXUP_PATH_MSYS], new_path=`cmd //c echo $path` fi - BASIC_ABSOLUTE_PATH(new_path) + UTIL_ABSOLUTE_PATH(new_path) - BASIC_MAKE_WINDOWS_SPACE_SAFE_MSYS([$new_path]) - BASIC_WINDOWS_REWRITE_AS_UNIX_PATH(new_path) + UTIL_MAKE_WINDOWS_SPACE_SAFE_MSYS([$new_path]) + UTIL_REWRITE_AS_UNIX_PATH(new_path) if test "x$path" != "x$new_path"; then $1="$new_path" AC_MSG_NOTICE([Rewriting $1 to "$new_path"]) @@ -196,18 +196,18 @@ AC_DEFUN([BASIC_FIXUP_PATH_MSYS], all_fixpath_prefixes=("${all_fixpath_prefixes@<:@@@:>@}" "${new_path:0:10}") ]) -AC_DEFUN([BASIC_FIXUP_PATH_WSL], +AC_DEFUN([UTIL_FIXUP_PATH_WSL], [ # Input might be given as Windows format, start by converting to # unix format. new_path="[$]$1" - BASIC_WINDOWS_REWRITE_AS_UNIX_PATH([new_path]) + UTIL_REWRITE_AS_UNIX_PATH([new_path]) - BASIC_ABSOLUTE_PATH(new_path) + UTIL_ABSOLUTE_PATH(new_path) # Call helper function which possibly converts this using DOS-style short mode. # If so, the updated path is stored in $new_path. - BASIC_MAKE_WINDOWS_SPACE_SAFE_WSL([$new_path]) + UTIL_MAKE_WINDOWS_SPACE_SAFE_WSL([$new_path]) if test "x$path" != "x$new_path"; then $1="$new_path" @@ -215,7 +215,7 @@ AC_DEFUN([BASIC_FIXUP_PATH_WSL], fi ]) -AC_DEFUN([BASIC_FIXUP_EXECUTABLE_CYGWIN], +AC_DEFUN([UTIL_FIXUP_EXECUTABLE_CYGWIN], [ # First separate the path from the arguments. This will split at the first # space. @@ -291,12 +291,12 @@ AC_DEFUN([BASIC_FIXUP_EXECUTABLE_CYGWIN], # Call helper function which possibly converts this using DOS-style short mode. # If so, the updated path is stored in $new_path. new_path="$input_to_shortpath" - BASIC_MAKE_WINDOWS_SPACE_SAFE_CYGWIN([$input_to_shortpath]) + UTIL_MAKE_WINDOWS_SPACE_SAFE_CYGWIN([$input_to_shortpath]) # remove trailing .exe if any new_path="${new_path/%.exe/}" ]) -AC_DEFUN([BASIC_FIXUP_EXECUTABLE_MSYS], +AC_DEFUN([UTIL_FIXUP_EXECUTABLE_MSYS], [ # First separate the path from the arguments. This will split at the first # space. @@ -308,7 +308,7 @@ AC_DEFUN([BASIC_FIXUP_EXECUTABLE_MSYS], # Input might be given as Windows format, start by converting to # unix format. new_path="$path" - BASIC_WINDOWS_REWRITE_AS_UNIX_PATH(new_path) + UTIL_REWRITE_AS_UNIX_PATH(new_path) # Now try to locate executable using which new_path=`$WHICH "$new_path" 2> /dev/null` @@ -321,7 +321,7 @@ AC_DEFUN([BASIC_FIXUP_EXECUTABLE_MSYS], path="$complete" arguments="EOL" new_path="$path" - BASIC_WINDOWS_REWRITE_AS_UNIX_PATH(new_path) + UTIL_REWRITE_AS_UNIX_PATH(new_path) new_path=`$WHICH "$new_path" 2> /dev/null` # bat and cmd files are not always considered executable in MSYS causing which @@ -330,7 +330,7 @@ AC_DEFUN([BASIC_FIXUP_EXECUTABLE_MSYS], && test "x`$ECHO \"$path\" | $GREP -i -e \"\\.bat$\" -e \"\\.cmd$\"`" != x \ && test "x`$LS \"$path\" 2>/dev/null`" != x; then new_path="$path" - BASIC_WINDOWS_REWRITE_AS_UNIX_PATH(new_path) + UTIL_REWRITE_AS_UNIX_PATH(new_path) fi if test "x$new_path" = x; then @@ -352,9 +352,9 @@ AC_DEFUN([BASIC_FIXUP_EXECUTABLE_MSYS], else # Not in mixed or Windows style, start by that. new_path=`cmd //c echo $new_path` - BASIC_MAKE_WINDOWS_SPACE_SAFE_MSYS([$new_path]) + UTIL_MAKE_WINDOWS_SPACE_SAFE_MSYS([$new_path]) # Output is in $new_path - BASIC_WINDOWS_REWRITE_AS_UNIX_PATH(new_path) + UTIL_REWRITE_AS_UNIX_PATH(new_path) # remove trailing .exe if any new_path="${new_path/%.exe/}" @@ -363,7 +363,7 @@ AC_DEFUN([BASIC_FIXUP_EXECUTABLE_MSYS], fi ]) -AC_DEFUN([BASIC_FIXUP_EXECUTABLE_WSL], +AC_DEFUN([UTIL_FIXUP_EXECUTABLE_WSL], [ # First separate the path from the arguments. This will split at the first # space. @@ -375,7 +375,7 @@ AC_DEFUN([BASIC_FIXUP_EXECUTABLE_WSL], # Input might be given as Windows format, start by converting to # unix format. new_path="$path" - BASIC_WINDOWS_REWRITE_AS_UNIX_PATH([new_path]) + UTIL_REWRITE_AS_UNIX_PATH([new_path]) # Now try to locate executable using which new_path_bak="$new_path" @@ -394,7 +394,7 @@ AC_DEFUN([BASIC_FIXUP_EXECUTABLE_WSL], path="$complete" arguments="EOL" new_path="$path" - BASIC_WINDOWS_REWRITE_AS_UNIX_PATH([new_path]) + UTIL_REWRITE_AS_UNIX_PATH([new_path]) new_path_bak="$new_path" new_path=`$WHICH "$new_path" 2> /dev/null` # bat and cmd files are not considered executable in WSL @@ -433,164 +433,6 @@ AC_DEFUN([BASIC_FIXUP_EXECUTABLE_WSL], # Call helper function which possibly converts this using DOS-style short mode. # If so, the updated path is stored in $new_path. new_path="$input_to_shortpath" - BASIC_MAKE_WINDOWS_SPACE_SAFE_WSL([$input_to_shortpath]) + UTIL_MAKE_WINDOWS_SPACE_SAFE_WSL([$input_to_shortpath]) ]) -# Setup basic configuration paths, and platform-specific stuff related to PATHs. -AC_DEFUN([BASIC_CHECK_PATHS_WINDOWS], -[ - SRC_ROOT_LENGTH=`$THEPWDCMD -L|$WC -m` - if test $SRC_ROOT_LENGTH -gt 100; then - AC_MSG_ERROR([Your base path is too long. It is $SRC_ROOT_LENGTH characters long, but only 100 is supported]) - fi - - if test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.cygwin"; then - AC_MSG_CHECKING([cygwin release]) - CYGWIN_VERSION=`$UNAME -r` - AC_MSG_RESULT([$CYGWIN_VERSION]) - WINDOWS_ENV_VENDOR='cygwin' - WINDOWS_ENV_VERSION="$CYGWIN_VERSION" - - CYGWIN_VERSION_OLD=`$ECHO $CYGWIN_VERSION | $GREP -e '^1\.[0-6]'` - if test "x$CYGWIN_VERSION_OLD" != x; then - AC_MSG_NOTICE([Your cygwin is too old. You are running $CYGWIN_VERSION, but at least cygwin 1.7 is required. Please upgrade.]) - AC_MSG_ERROR([Cannot continue]) - fi - if test "x$CYGPATH" = x; then - AC_MSG_ERROR([Something is wrong with your cygwin installation since I cannot find cygpath.exe in your path]) - fi - AC_MSG_CHECKING([cygwin root directory as unix-style path]) - # The cmd output ends with Windows line endings (CR/LF) - cygwin_winpath_root=`cd / ; cmd /c cd | $TR -d '\r\n'` - # Force cygpath to report the proper root by including a trailing space, and then stripping it off again. - CYGWIN_ROOT_PATH=`$CYGPATH -u "$cygwin_winpath_root " | $CUT -f 1 -d " "` - AC_MSG_RESULT([$CYGWIN_ROOT_PATH]) - WINDOWS_ENV_ROOT_PATH="$CYGWIN_ROOT_PATH" - test_cygdrive_prefix=`$ECHO $CYGWIN_ROOT_PATH | $GREP ^/cygdrive/` - if test "x$test_cygdrive_prefix" = x; then - AC_MSG_ERROR([Your cygdrive prefix is not /cygdrive. This is currently not supported. Change with mount -c.]) - fi - elif test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.msys"; then - AC_MSG_CHECKING([msys release]) - MSYS_VERSION=`$UNAME -r` - AC_MSG_RESULT([$MSYS_VERSION]) - - WINDOWS_ENV_VENDOR='msys' - WINDOWS_ENV_VERSION="$MSYS_VERSION" - - AC_MSG_CHECKING([msys root directory as unix-style path]) - # The cmd output ends with Windows line endings (CR/LF), the grep command will strip that away - MSYS_ROOT_PATH=`cd / ; cmd /c cd | $GREP ".*"` - BASIC_WINDOWS_REWRITE_AS_UNIX_PATH(MSYS_ROOT_PATH) - AC_MSG_RESULT([$MSYS_ROOT_PATH]) - WINDOWS_ENV_ROOT_PATH="$MSYS_ROOT_PATH" - elif test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.wsl"; then - AC_MSG_CHECKING([Windows version]) - # m4 replaces [ and ] so we use @<:@ and @:>@ instead - WINDOWS_VERSION=`$CMD /c ver.exe | $EGREP -o '(@<:@0-9@:>@+\.)+@<:@0-9@:>@+'` - AC_MSG_RESULT([$WINDOWS_VERSION]) - - AC_MSG_CHECKING([WSL kernel version]) - WSL_KERNEL_VERSION=`$UNAME -v` - AC_MSG_RESULT([$WSL_KERNEL_VERSION]) - - AC_MSG_CHECKING([WSL kernel release]) - WSL_KERNEL_RELEASE=`$UNAME -r` - AC_MSG_RESULT([$WSL_KERNEL_RELEASE]) - - AC_MSG_CHECKING([WSL distribution]) - WSL_DISTRIBUTION=`$LSB_RELEASE -d | sed 's/Description:\t//'` - AC_MSG_RESULT([$WSL_DISTRIBUTION]) - - WINDOWS_ENV_VENDOR='WSL' - WINDOWS_ENV_VERSION="$WSL_DISTRIBUTION $WSL_KERNEL_VERSION $WSL_KERNEL_RELEASE (on Windows build $WINDOWS_VERSION)" - else - AC_MSG_ERROR([Unknown Windows environment. Neither cygwin, msys, nor wsl was detected.]) - fi - - # Test if windows or unix (cygwin/msys) find is first in path. - AC_MSG_CHECKING([what kind of 'find' is first on the PATH]) - FIND_BINARY_OUTPUT=`find --version 2>&1` - if test "x`echo $FIND_BINARY_OUTPUT | $GREP GNU`" != x; then - AC_MSG_RESULT([unix style]) - elif test "x`echo $FIND_BINARY_OUTPUT | $GREP FIND`" != x; then - AC_MSG_RESULT([Windows]) - AC_MSG_NOTICE([Your path contains Windows tools (C:\Windows\system32) before your unix (cygwin or msys) tools.]) - AC_MSG_NOTICE([This will not work. Please correct and make sure /usr/bin (or similar) is first in path.]) - AC_MSG_ERROR([Cannot continue]) - else - AC_MSG_RESULT([unknown]) - AC_MSG_WARN([It seems that your find utility is non-standard.]) - fi -]) - -AC_DEFUN_ONCE([BASIC_COMPILE_FIXPATH], -[ - # When using cygwin or msys, we need a wrapper binary that renames - # /cygdrive/c/ arguments into c:/ arguments and peeks into - # @files and rewrites these too! This wrapper binary is - # called fixpath. - FIXPATH= - if test "x$OPENJDK_BUILD_OS" = xwindows; then - AC_MSG_CHECKING([if fixpath can be created]) - FIXPATH_SRC="$TOPDIR/make/src/native/fixpath.c" - FIXPATH_BIN="$CONFIGURESUPPORT_OUTPUTDIR/bin/fixpath.exe" - FIXPATH_DIR="$CONFIGURESUPPORT_OUTPUTDIR/fixpath" - if test "x$OPENJDK_BUILD_OS_ENV" = xwindows.cygwin; then - # Important to keep the .exe suffix on Cygwin for Hotspot makefiles - FIXPATH="$FIXPATH_BIN -c" - elif test "x$OPENJDK_BUILD_OS_ENV" = xwindows.msys; then - # Take all collected prefixes and turn them into a -m/c/foo@/c/bar@... command line - # @ was chosen as separator to minimize risk of other tools messing around with it - all_unique_prefixes=`echo "${all_fixpath_prefixes@<:@@@:>@}" \ - | tr ' ' '\n' | $GREP '^/./' | $SORT | $UNIQ` - fixpath_argument_list=`echo $all_unique_prefixes | tr ' ' '@'` - FIXPATH="$FIXPATH_BIN -m$fixpath_argument_list" - elif test "x$OPENJDK_BUILD_OS_ENV" = xwindows.wsl; then - FIXPATH="$FIXPATH_BIN -w" - fi - FIXPATH_SRC_W="$FIXPATH_SRC" - FIXPATH_BIN_W="$FIXPATH_BIN" - BASIC_WINDOWS_REWRITE_AS_WINDOWS_MIXED_PATH([FIXPATH_SRC_W]) - BASIC_WINDOWS_REWRITE_AS_WINDOWS_MIXED_PATH([FIXPATH_BIN_W]) - $RM -rf $FIXPATH_BIN $FIXPATH_DIR - $MKDIR -p $FIXPATH_DIR $CONFIGURESUPPORT_OUTPUTDIR/bin - cd $FIXPATH_DIR - $CC $FIXPATH_SRC_W -Fe$FIXPATH_BIN_W > $FIXPATH_DIR/fixpath1.log 2>&1 - cd $CONFIGURE_START_DIR - - if test ! -x $FIXPATH_BIN; then - AC_MSG_RESULT([no]) - cat $FIXPATH_DIR/fixpath1.log - AC_MSG_ERROR([Could not create $FIXPATH_BIN]) - fi - AC_MSG_RESULT([yes]) - - if test "x$OPENJDK_BUILD_OS_ENV" = "xwindows.wsl"; then - OLD_WSLENV="$WSLENV" - WSLENV=`$ECHO $WSLENV | $SED 's/PATH\/l://'` - BASIC_APPEND_TO_PATH(WSLENV, "FIXPATH_PATH") - export WSLENV - export FIXPATH_PATH=$VS_PATH_WINDOWS - AC_MSG_NOTICE([FIXPATH_PATH is $FIXPATH_PATH]) - AC_MSG_NOTICE([Rewriting WSLENV from $OLD_WSLENV to $WSLENV]) - fi - - AC_MSG_CHECKING([if fixpath.exe works]) - cd $FIXPATH_DIR - $FIXPATH $CC $FIXPATH_SRC -Fe$FIXPATH_DIR/fixpath2.exe \ - > $FIXPATH_DIR/fixpath2.log 2>&1 - cd $CONFIGURE_START_DIR - if test ! -x $FIXPATH_DIR/fixpath2.exe; then - AC_MSG_RESULT([no]) - cat $FIXPATH_DIR/fixpath2.log - AC_MSG_ERROR([fixpath did not work!]) - fi - AC_MSG_RESULT([yes]) - - FIXPATH_DETACH_FLAG="--detach" - fi - - AC_SUBST(FIXPATH) - AC_SUBST(FIXPATH_DETACH_FLAG) -])