# HG changeset patch # User ihse # Date 1520870454 -3600 # Node ID 564802b01ded9d70d619d065c0febf6b36efd105 # Parent 3a225d9cabe1de92554a7dd27db34a1209656a59 8199451: Create linux-aarch64 cross-compilation devkit, and fix cross-compilation Reviewed-by: aph, erikj diff -r 3a225d9cabe1 -r 564802b01ded make/autoconf/flags.m4 --- a/make/autoconf/flags.m4 Mon Mar 12 10:04:12 2018 -0400 +++ b/make/autoconf/flags.m4 Mon Mar 12 17:00:54 2018 +0100 @@ -362,8 +362,10 @@ if test "x$BUILD_SYSROOT" != x; then FLAGS_SETUP_SYSROOT_FLAGS([BUILD_]) else - BUILD_SYSROOT_CFLAGS="$SYSROOT_CFLAGS" - BUILD_SYSROOT_LDFLAGS="$SYSROOT_LDFLAGS" + if test "x$COMPILE_TYPE" != "xcross"; then + BUILD_SYSROOT_CFLAGS="$SYSROOT_CFLAGS" + BUILD_SYSROOT_LDFLAGS="$SYSROOT_LDFLAGS" + fi fi AC_SUBST(BUILD_SYSROOT_CFLAGS) AC_SUBST(BUILD_SYSROOT_LDFLAGS) diff -r 3a225d9cabe1 -r 564802b01ded make/conf/jib-profiles.js --- a/make/conf/jib-profiles.js Mon Mar 12 10:04:12 2018 -0400 +++ b/make/conf/jib-profiles.js Mon Mar 12 17:00:54 2018 +0100 @@ -232,7 +232,8 @@ common.main_profile_names = [ "linux-x64", "linux-x86", "macosx-x64", "solaris-x64", "solaris-sparcv9", "windows-x64", "windows-x86", - "linux-arm64", "linux-arm-vfp-hflt", "linux-arm-vfp-hflt-dyn" + "linux-aarch64", "linux-arm64", "linux-arm-vfp-hflt", + "linux-arm-vfp-hflt-dyn" ]; // These are the base setttings for all the main build profiles. @@ -465,6 +466,16 @@ configure_args: concat(common.configure_args_32bit), }, + "linux-aarch64": { + target_os: "linux", + target_cpu: "aarch64", + build_cpu: "x64", + dependencies: ["devkit", "autoconf", "build_devkit", "cups"], + configure_args: [ + "--openjdk-target=aarch64-linux-gnu" + ], + }, + "linux-arm64": { target_os: "linux", target_cpu: "aarch64", @@ -582,6 +593,9 @@ "windows-x86": { platform: "windows-x86", }, + "linux-aarch64": { + platform: "linux-aarch64", + }, "linux-arm64": { platform: "linux-arm64-vfp-hflt", }, @@ -781,7 +795,9 @@ solaris_x64: "SS12u4-Solaris11u1+1.0", solaris_sparcv9: "SS12u4-Solaris11u1+1.1", windows_x64: "VS2013SP4+1.0", - linux_aarch64: "gcc-linaro-aarch64-linux-gnu-4.8-2013.11_linux+1.0", + linux_aarch64: (input.profile != null && input.profile.indexOf("arm64") >= 0 + ? "gcc-linaro-aarch64-linux-gnu-4.8-2013.11_linux+1.0" + : "gcc7.3.0-Fedora27+1.0"), linux_arm: (input.profile != null && input.profile.indexOf("hflt") >= 0 ? "gcc-linaro-arm-linux-gnueabihf-raspbian-2012.09-20120921_linux+1.0" : "arm-linaro-4.7+1.0") diff -r 3a225d9cabe1 -r 564802b01ded make/devkit/Makefile --- a/make/devkit/Makefile Mon Mar 12 10:04:12 2018 -0400 +++ b/make/devkit/Makefile Mon Mar 12 17:00:54 2018 +0100 @@ -41,7 +41,7 @@ # To build the full set of crosstools for additional platforms, use a command # line looking like this: # -# make tars platforms="x86_64-unknown-linux-gnu sparc64-unknown-linux-gnu" +# make cross_compile_target="aarch64-linux-gnu" BASE_OS=Fedora27 # # This is the makefile which iterates over all host and target platforms. # @@ -57,8 +57,13 @@ # # By default just build for the current platform, which is assumed to be Linux # -platforms := $(me) -host_platforms := $(platforms) +ifeq ($(cross_compile_target), ) + platforms := $(me) + host_platforms := $(platforms) +else + platforms := $(cross_compile_target) + host_platforms := $(me) +endif target_platforms := $(platforms) $(info host_platforms $(host_platforms)) $(info target_platforms $(target_platforms)) diff -r 3a225d9cabe1 -r 564802b01ded make/devkit/Tools.gmk --- a/make/devkit/Tools.gmk Mon Mar 12 10:04:12 2018 -0400 +++ b/make/devkit/Tools.gmk Mon Mar 12 17:00:54 2018 +0100 @@ -46,6 +46,16 @@ ARCH := $(word 1,$(subst -, ,$(TARGET))) $(info ARCH=$(ARCH)) +ifeq ($(BASE_OS), OEL6) + OEL_URL := http://yum.oracle.com/repo/OracleLinux/OL6/4/base/$(ARCH)/ + LINUX_VERSION := OEL6.4 +else ifeq ($(BASE_OS), Fedora27) + OEL_URL := https://dl.fedoraproject.org/pub/fedora-secondary/releases/27/Everything/$(ARCH)/os/Packages/ + LINUX_VERSION := Fedora 27 +else + $(error Unknown base OS $(BASE_OS)) +endif + ########################################################################################## # Define external dependencies @@ -79,10 +89,7 @@ MPC := http://ftp.gnu.org/pub/gnu/mpc/${mpc_ver}.tar.gz GDB := http://ftp.gnu.org/gnu/gdb/${gdb_ver}.tar.xz -OEL_URL := http://yum.oracle.com/repo/OracleLinux/OL6/4/base/$(ARCH)/ - -# RPMs in OEL6.4 -LINUX_VERSION := OEL6.4 +# RPMs used by all BASE_OS RPM_LIST := \ kernel-headers \ glibc glibc-headers glibc-devel \ @@ -180,10 +187,10 @@ RPM_ARCHS += i386 i686 endif endif -else ifeq ($(ARCH),i686)) - RPM_ARCHS := i386 i686 +else ifeq ($(ARCH),i686) + RPM_ARCHS := i386 i686 noarch else - RPM_ARCHS := $(ARCH) + RPM_ARCHS := $(ARCH) noarch endif RPM_FILE_LIST := $(sort $(foreach a, $(RPM_ARCHS), \ @@ -453,6 +460,12 @@ @echo 'done' $(gdb): $(gcc) +else + $(BUILDDIR)/$(gdb_ver)/Makefile: + $(info Faking $@, not used when cross-compiling) + mkdir -p $(@D) + echo "install:" > $@ + @echo 'done' endif ########################################################################################## @@ -531,7 +544,7 @@ echo '' >> $@ echo 'DEVKIT_NAME="$(gcc_ver) - $(LINUX_VERSION)"' >> $@ echo 'DEVKIT_TOOLCHAIN_PATH="$$DEVKIT_ROOT/bin"' >> $@ - echo 'DEVKIT_SYSROOT="$$DEVKIT_ROOT/$$host/sysroot"' >> $@ + echo 'DEVKIT_SYSROOT="$$DEVKIT_ROOT/$(TARGET)/sysroot"' >> $@ echo 'DEVKIT_EXTRA_PATH="$$DEVKIT_ROOT/bin"' >> $@ ##########################################################################################