8296904: Improve handling of macos xcode toolchain

Reviewed-by: mbaesken
Backport-of: 470f3424fcce0e41b75cccdd5e3a56771cd07ff5
This commit is contained in:
Christoph Langer 2022-11-30 22:00:43 +00:00
parent d153a8c0ca
commit 7275da49c0
3 changed files with 69 additions and 44 deletions

View File

@ -239,26 +239,26 @@
<table> <table>
<thead> <thead>
<tr class="header"> <tr class="header">
<th style="text-align: left;">Operating system</th> <th>Operating system</th>
<th style="text-align: left;">Supported toolchain</th> <th>Supported toolchain</th>
</tr> </tr>
</thead> </thead>
<tbody> <tbody>
<tr class="odd"> <tr class="odd">
<td style="text-align: left;">Linux</td> <td>Linux</td>
<td style="text-align: left;">gcc, clang</td> <td>gcc, clang</td>
</tr> </tr>
<tr class="even"> <tr class="even">
<td style="text-align: left;">macOS</td> <td>macOS</td>
<td style="text-align: left;">Apple Xcode (using clang)</td> <td>Apple Xcode (using clang)</td>
</tr> </tr>
<tr class="odd"> <tr class="odd">
<td style="text-align: left;">AIX</td> <td>AIX</td>
<td style="text-align: left;">IBM XL C/C++</td> <td>IBM XL C/C++</td>
</tr> </tr>
<tr class="even"> <tr class="even">
<td style="text-align: left;">Windows</td> <td>Windows</td>
<td style="text-align: left;">Microsoft Visual Studio</td> <td>Microsoft Visual Studio</td>
</tr> </tr>
</tbody> </tbody>
</table> </table>
@ -266,22 +266,22 @@
<table> <table>
<thead> <thead>
<tr class="header"> <tr class="header">
<th style="text-align: left;">Operating system</th> <th>Operating system</th>
<th style="text-align: left;">Toolchain version</th> <th>Toolchain version</th>
</tr> </tr>
</thead> </thead>
<tbody> <tbody>
<tr class="odd"> <tr class="odd">
<td style="text-align: left;">Linux</td> <td>Linux</td>
<td style="text-align: left;">gcc 11.2.0</td> <td>gcc 11.2.0</td>
</tr> </tr>
<tr class="even"> <tr class="even">
<td style="text-align: left;">macOS</td> <td>macOS</td>
<td style="text-align: left;">Apple Xcode 10.1 (using clang 10.0.0)</td> <td>Apple Xcode 10.1 (using clang 10.0.0)</td>
</tr> </tr>
<tr class="odd"> <tr class="odd">
<td style="text-align: left;">Windows</td> <td>Windows</td>
<td style="text-align: left;">Microsoft Visual Studio 2022 update 17.1.0</td> <td>Microsoft Visual Studio 2022 update 17.1.0</td>
</tr> </tr>
</tbody> </tbody>
</table> </table>
@ -295,9 +295,13 @@
<p>To use clang instead of gcc on Linux, use <code>--with-toolchain-type=clang</code>.</p> <p>To use clang instead of gcc on Linux, use <code>--with-toolchain-type=clang</code>.</p>
<h3 id="apple-xcode">Apple Xcode</h3> <h3 id="apple-xcode">Apple Xcode</h3>
<p>The oldest supported version of Xcode is 8.</p> <p>The oldest supported version of Xcode is 8.</p>
<p>You will need the Xcode command lines developers tools to be able to build the JDK. (Actually, <em>only</em> the command lines tools are needed, not the IDE.) The simplest way to install these is to run:</p> <p>You will need the Xcode command line developer tools to be able to build the JDK. (Actually, <em>only</em> the command line tools are needed, not the IDE.) The simplest way to install these is to run:</p>
<pre><code>xcode-select --install</code></pre> <pre><code>xcode-select --install</code></pre>
<p>It is advisable to keep an older version of Xcode for building the JDK when updating Xcode. This <a href="http://iosdevelopertips.com/xcode/install-multiple-versions-of-xcode.html">blog page</a> has good suggestions on managing multiple Xcode versions. To use a specific version of Xcode, use <code>xcode-select -s</code> before running <code>configure</code>, or use <code>--with-toolchain-path</code> to point to the version of Xcode to use, e.g. <code>configure --with-toolchain-path=/Applications/Xcode8.app/Contents/Developer/usr/bin</code></p> <p>When updating Xcode, it is advisable to keep an older version for building the JDK. To use a specific version of Xcode you have multiple options:</p>
<ul>
<li>Use <code>xcode-select -s</code> before running <code>configure</code>, e.g. <code>xcode-select -s /Applications/Xcode13.1.app</code>. The drawback is that the setting is system wide and you may have to revert it after an OpenJDK build.</li>
<li>Use configure option <code>--with-xcode-path</code>, e.g. <code>configure --with-xcode-path=/Applications/Xcode13.1.app</code> This allows using a specific Xcode version for an OpenJDK build, independently of the active Xcode version by <code>xcode-select</code>.</li>
</ul>
<p>If you have recently (inadvertently) updated your OS and/or Xcode version, and the JDK can no longer be built, please see the section on <a href="#problems-with-the-build-environment">Problems with the Build Environment</a>, and <a href="#getting-help">Getting Help</a> to find out if there are any recent, non-merged patches available for this update.</p> <p>If you have recently (inadvertently) updated your OS and/or Xcode version, and the JDK can no longer be built, please see the section on <a href="#problems-with-the-build-environment">Problems with the Build Environment</a>, and <a href="#getting-help">Getting Help</a> to find out if there are any recent, non-merged patches available for this update.</p>
<h3 id="microsoft-visual-studio">Microsoft Visual Studio</h3> <h3 id="microsoft-visual-studio">Microsoft Visual Studio</h3>
<p>For aarch64 machines running Windows the minimum accepted version is Visual Studio 2019 (16.8 or higher). For all other platforms the minimum accepted version of Visual Studio is 2017. Older versions will not be accepted by <code>configure</code> and will not work. For all platforms the maximum accepted version of Visual Studio is 2022.</p> <p>For aarch64 machines running Windows the minimum accepted version is Visual Studio 2019 (16.8 or higher). For all other platforms the minimum accepted version of Visual Studio is 2017. Older versions will not be accepted by <code>configure</code> and will not work. For all platforms the maximum accepted version of Visual Studio is 2022.</p>

View File

@ -313,12 +313,12 @@ be able to run on the target platform. In theory, toolchain and operating
system should be independent factors, but in practice there's more or less a system should be independent factors, but in practice there's more or less a
one-to-one correlation between target operating system and toolchain. one-to-one correlation between target operating system and toolchain.
Operating system Supported toolchain | Operating system | Supported toolchain |
------------------ ------------------------- | ------------------ | ------------------------- |
Linux gcc, clang | Linux | gcc, clang |
macOS Apple Xcode (using clang) | macOS | Apple Xcode (using clang) |
AIX IBM XL C/C++ | AIX | IBM XL C/C++ |
Windows Microsoft Visual Studio | Windows | Microsoft Visual Studio |
Please see the individual sections on the toolchains for version Please see the individual sections on the toolchains for version
recommendations. As a reference, these versions of the toolchains are used, at recommendations. As a reference, these versions of the toolchains are used, at
@ -327,11 +327,11 @@ possible to compile the JDK with both older and newer versions, but the closer
you stay to this list, the more likely you are to compile successfully without you stay to this list, the more likely you are to compile successfully without
issues. issues.
Operating system Toolchain version | Operating system | Toolchain version |
------------------ ------------------------------------------------------- | ------------------ | ------------------------------------------ |
Linux gcc 11.2.0 | Linux | gcc 11.2.0 |
macOS Apple Xcode 10.1 (using clang 10.0.0) | macOS | Apple Xcode 10.1 (using clang 10.0.0) |
Windows Microsoft Visual Studio 2022 update 17.1.0 | Windows | Microsoft Visual Studio 2022 update 17.1.0 |
All compilers are expected to be able to compile to the C99 language standard, All compilers are expected to be able to compile to the C99 language standard,
as some C99 features are used in the source code. Microsoft Visual Studio as some C99 features are used in the source code. Microsoft Visual Studio
@ -359,20 +359,20 @@ To use clang instead of gcc on Linux, use `--with-toolchain-type=clang`.
The oldest supported version of Xcode is 8. The oldest supported version of Xcode is 8.
You will need the Xcode command lines developers tools to be able to build You will need the Xcode command line developer tools to be able to build
the JDK. (Actually, *only* the command lines tools are needed, not the IDE.) the JDK. (Actually, *only* the command line tools are needed, not the IDE.)
The simplest way to install these is to run: The simplest way to install these is to run:
``` ```
xcode-select --install xcode-select --install
``` ```
It is advisable to keep an older version of Xcode for building the JDK when When updating Xcode, it is advisable to keep an older version for building the JDK.
updating Xcode. This [blog page]( To use a specific version of Xcode you have multiple options:
http://iosdevelopertips.com/xcode/install-multiple-versions-of-xcode.html) has
good suggestions on managing multiple Xcode versions. To use a specific version * Use `xcode-select -s` before running `configure`, e.g. `xcode-select -s /Applications/Xcode13.1.app`. The drawback is that the setting
of Xcode, use `xcode-select -s` before running `configure`, or use is system wide and you may have to revert it after an OpenJDK build.
`--with-toolchain-path` to point to the version of Xcode to use, e.g. * Use configure option `--with-xcode-path`, e.g. `configure --with-xcode-path=/Applications/Xcode13.1.app`
`configure --with-toolchain-path=/Applications/Xcode8.app/Contents/Developer/usr/bin` This allows using a specific Xcode version for an OpenJDK build, independently of the active Xcode version by `xcode-select`.
If you have recently (inadvertently) updated your OS and/or Xcode version, and If you have recently (inadvertently) updated your OS and/or Xcode version, and
the JDK can no longer be built, please see the section on [Problems with the the JDK can no longer be built, please see the section on [Problems with the

View File

@ -139,6 +139,15 @@ AC_DEFUN([BASIC_SETUP_XCODE_SYSROOT],
if test $? -ne 0; then if test $? -ne 0; then
AC_MSG_ERROR([The xcodebuild tool in the devkit reports an error: $XCODEBUILD_OUTPUT]) AC_MSG_ERROR([The xcodebuild tool in the devkit reports an error: $XCODEBUILD_OUTPUT])
fi fi
elif test "x$TOOLCHAIN_PATH" != x; then
UTIL_LOOKUP_PROGS(XCODEBUILD, xcodebuild, $TOOLCHAIN_PATH)
if test "x$XCODEBUILD" != x; then
XCODEBUILD_OUTPUT=`"$XCODEBUILD" -version 2>&1`
if test $? -ne 0; then
AC_MSG_WARN([Ignoring the located xcodebuild tool $XCODEBUILD due to an error: $XCODEBUILD_OUTPUT])
XCODEBUILD=
fi
fi
else else
UTIL_LOOKUP_PROGS(XCODEBUILD, xcodebuild) UTIL_LOOKUP_PROGS(XCODEBUILD, xcodebuild)
if test "x$XCODEBUILD" != x; then if test "x$XCODEBUILD" != x; then
@ -288,6 +297,22 @@ AC_DEFUN_ONCE([BASIC_SETUP_DEVKIT],
[UTIL_PREPEND_TO_PATH([TOOLCHAIN_PATH],$with_toolchain_path)] [UTIL_PREPEND_TO_PATH([TOOLCHAIN_PATH],$with_toolchain_path)]
) )
AC_ARG_WITH([xcode-path], [AS_HELP_STRING([--with-xcode-path],
[set up toolchain on Mac OS using a path to an Xcode installation])])
if test "x$with_xcode_path" != x; then
if test "x$OPENJDK_BUILD_OS" = "xmacosx"; then
UTIL_PREPEND_TO_PATH([TOOLCHAIN_PATH],
$with_xcode_path/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin:$with_xcode_path/Contents/Developer/usr/bin)
else
AC_MSG_WARN([Option --with-xcode-path is only valid on Mac OS, ignoring.])
fi
fi
AC_MSG_CHECKING([for toolchain path])
AC_MSG_RESULT([$TOOLCHAIN_PATH])
AC_SUBST(TOOLCHAIN_PATH)
AC_ARG_WITH([extra-path], [AS_HELP_STRING([--with-extra-path], AC_ARG_WITH([extra-path], [AS_HELP_STRING([--with-extra-path],
[prepend these directories to the default path])], [prepend these directories to the default path])],
[UTIL_PREPEND_TO_PATH([EXTRA_PATH],$with_extra_path)] [UTIL_PREPEND_TO_PATH([EXTRA_PATH],$with_extra_path)]
@ -304,10 +329,6 @@ AC_DEFUN_ONCE([BASIC_SETUP_DEVKIT],
AC_MSG_RESULT([$SYSROOT]) AC_MSG_RESULT([$SYSROOT])
AC_SUBST(SYSROOT) AC_SUBST(SYSROOT)
AC_MSG_CHECKING([for toolchain path])
AC_MSG_RESULT([$TOOLCHAIN_PATH])
AC_SUBST(TOOLCHAIN_PATH)
AC_MSG_CHECKING([for extra path]) AC_MSG_CHECKING([for extra path])
AC_MSG_RESULT([$EXTRA_PATH]) AC_MSG_RESULT([$EXTRA_PATH])
]) ])