From 3243300465113c9f3095a5602c8e0255ba98220d Mon Sep 17 00:00:00 2001 From: Stewart X Addison Date: Fri, 30 Jun 2023 11:02:20 +0100 Subject: [PATCH] Configure JDK19+ on Linux with hsdis capstone support --- build-farm/platform-specific-configurations/linux.sh | 6 ++++++ sbin/build.sh | 9 +++++++++ 2 files changed, 15 insertions(+) diff --git a/build-farm/platform-specific-configurations/linux.sh b/build-farm/platform-specific-configurations/linux.sh index 94d43424ea..a7215aa02d 100755 --- a/build-farm/platform-specific-configurations/linux.sh +++ b/build-farm/platform-specific-configurations/linux.sh @@ -338,6 +338,12 @@ elif [ -r /usr/bin/gcc-7 ]; then [ -r /usr/bin/g++-7 ] && export CXX=/usr/bin/g++-7 fi +if [ "$JAVA_FEATURE_VERSION" -ge 20 ]; then + if [ -r /usr/local/lib/libcapstone.so.4 ]; then + export CONFIGURE_ARGS_FOR_ANY_PLATFORM="${CONFIGURE_ARGS_FOR_ANY_PLATFORM} --with-capstone=/usr/local" + fi +fi + if [ "${VARIANT}" == "${BUILD_VARIANT_BISHENG}" ]; then # BUILD_C/CXX required for native (non-cross) RISC-V builds of Bisheng if [ -n "$CXX" ]; then diff --git a/sbin/build.sh b/sbin/build.sh index 23f524e4be..4e8c04ccc0 100755 --- a/sbin/build.sh +++ b/sbin/build.sh @@ -90,6 +90,14 @@ configureShenandoahBuildParameter() { fi } +# capstone disassembler support is available in JDK19+ +configureCapstoneBuildParameter() { + if [[ "${BUILD_CONFIG[OPENJDK_FEATURE_NUMBER]}" -ge 19 && "${BUILD_CONFIG[OS_KERNEL_NAME]}" = "linux" ]]; then + addConfigureArg "--enable-hsdis-bundling" "" + addConfigureArg "--with-hsdis=" "capstone" + addConfigureArg "--with-cwcapstone=" "/usr/local" + fi +} # Configure reproducible build # jdk-17 and jdk-19+ support reproducible builds configureReproducibleBuildParameter() { @@ -492,6 +500,7 @@ configureFreetypeLocation() { configureCommandParameters() { configureVersionStringParameter configureBootJDKConfigureParameter + configureCapstoneBuildParameter configureShenandoahBuildParameter configureMacOSCodesignParameter configureDebugParameters