All of lore.kernel.org
 help / color / mirror / Atom feed
From: "Alex Bennée" <alex.bennee@linaro.org>
To: cota@braap.org, famz@redhat.com, berrange@redhat.com,
	f4bug@amsat.org, richard.henderson@linaro.org, balrogg@gmail.com,
	aurelien@aurel32.net, agraf@suse.de
Cc: qemu-devel@nongnu.org, "Alex Bennée" <alex.bennee@linaro.org>
Subject: [Qemu-devel] [PATCH v5 03/49] configure: add support for --cross-cc-FOO
Date: Fri, 25 May 2018 14:38:05 +0100	[thread overview]
Message-ID: <20180525133851.27161-4-alex.bennee@linaro.org> (raw)
In-Reply-To: <20180525133851.27161-1-alex.bennee@linaro.org>

This allows us to specify cross compilers for our guests. This is
useful for building test images/programs. Currently we re-run the
compile test for each target. I couldn't think of a way to cache the
value for a given arch without getting messier configure code.

The cross compiler for the guest is visible to each target as
CROSS_CC_GUEST in config-target.mak.

Signed-off-by: Alex Bennée <alex.bennee@linaro.org>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
---
v3
  - --cross-cc-*[!a-zA-Z0-9_-]*=*) error_exit...
  - --cross-cc-*) cc_arch=${opt#--cross-cc-}; cc_arch=${cc_arch%%=*}
  - add remaining target_compiler definitions
v4
  - also set cross_cc_$cpu=$host_cc
  - try a non-static build if static fails
  - use write_c_skeleton
  - add doc string in help
---
 configure | 92 +++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 92 insertions(+)

diff --git a/configure b/configure
index 2e10956cfc..931725d870 100755
--- a/configure
+++ b/configure
@@ -458,6 +458,13 @@ vxhs=""
 libxml2=""
 docker="no"
 
+# cross compilers defaults, can be overridden with --cross-cc-ARCH
+cross_cc_aarch64="aarch64-linux-gnu-gcc"
+cross_cc_arm="arm-linux-gnueabihf-gcc"
+cross_cc_powerpc="powerpc-linux-gnu-gcc"
+
+enabled_cross_compilers=""
+
 supported_cpu="no"
 supported_os="no"
 bogus_os="no"
@@ -488,6 +495,11 @@ for opt do
   ;;
   --disable-debug-info) debug_info="no"
   ;;
+  --cross-cc-*[!a-zA-Z0-9_-]*=*) error_exit "Passed bad --cross-cc-FOO option"
+  ;;
+  --cross-cc-*) cc_arch=${opt#--cross-cc-}; cc_arch=${cc_arch%%=*}
+                eval "cross_cc_${cc_arch}=\$optarg"
+  ;;
   esac
 done
 # OS specific
@@ -676,30 +688,37 @@ case "$cpu" in
   ppc|ppc64|s390|s390x|sparc64|x32)
     cpu="$cpu"
     supported_cpu="yes"
+    eval "cross_cc_${cpu}=\$host_cc"
   ;;
   i386|i486|i586|i686|i86pc|BePC)
     cpu="i386"
     supported_cpu="yes"
+    cross_cc_i386=$host_cc
   ;;
   x86_64|amd64)
     cpu="x86_64"
     supported_cpu="yes"
+    cross_cc_x86_64=$host_cc
   ;;
   armv*b|armv*l|arm)
     cpu="arm"
     supported_cpu="yes"
+    cross_cc_arm=$host_cc
   ;;
   aarch64)
     cpu="aarch64"
     supported_cpu="yes"
+    cross_cc_aarch64=$host_cc
   ;;
   mips*)
     cpu="mips"
     supported_cpu="yes"
+    cross_cc_mips=$host_cc
   ;;
   sparc|sun4[cdmuv])
     cpu="sparc"
     supported_cpu="yes"
+    cross_cc_sparc=$host_cc
   ;;
   *)
     # This will result in either an error or falling back to TCI later
@@ -917,6 +936,8 @@ for opt do
   ;;
   --disable-debug-info)
   ;;
+  --cross-cc-*)
+  ;;
   --enable-modules)
       modules="yes"
   ;;
@@ -1501,6 +1522,7 @@ Advanced options (experts only):
   --extra-cflags=CFLAGS    append extra C compiler flags QEMU_CFLAGS
   --extra-cxxflags=CXXFLAGS append extra C++ compiler flags QEMU_CXXFLAGS
   --extra-ldflags=LDFLAGS  append extra linker flags LDFLAGS
+  --cross-cc-ARCH=CC       use compiler when building ARCH guest test cases
   --make=MAKE              use specified make [$make]
   --install=INSTALL        use specified install [$install]
   --python=PYTHON          use specified python [$python]
@@ -6811,6 +6833,9 @@ case "$target" in
     ;;
 esac
 
+target_compiler=""
+target_compiler_static=""
+
 mkdir -p $target_dir
 echo "# Automatically generated by configure - do not modify" > $config_target_mak
 
@@ -6826,19 +6851,23 @@ TARGET_ABI_DIR=""
 case "$target_name" in
   i386)
     gdb_xml_files="i386-32bit.xml i386-32bit-core.xml i386-32bit-sse.xml"
+    target_compiler=$cross_cc_i386
   ;;
   x86_64)
     TARGET_BASE_ARCH=i386
     gdb_xml_files="i386-64bit.xml i386-64bit-core.xml i386-64bit-sse.xml"
+    target_compiler=$cross_cc_x86_64
   ;;
   alpha)
     mttcg="yes"
+    target_compiler=$cross_cc_alpha
   ;;
   arm|armeb)
     TARGET_ARCH=arm
     bflt="yes"
     mttcg="yes"
     gdb_xml_files="arm-core.xml arm-vfp.xml arm-vfp3.xml arm-neon.xml"
+    target_compiler=$cross_cc_arm
   ;;
   aarch64|aarch64_be)
     TARGET_ARCH=aarch64
@@ -6846,58 +6875,73 @@ case "$target_name" in
     bflt="yes"
     mttcg="yes"
     gdb_xml_files="aarch64-core.xml aarch64-fpu.xml arm-core.xml arm-vfp.xml arm-vfp3.xml arm-neon.xml"
+    target_compiler=$cross_cc_aarch64
   ;;
   cris)
+    target_compiler=$cross_cc_cris
   ;;
   hppa)
     mttcg="yes"
+    target_compiler=$cross_cc_hppa
   ;;
   lm32)
+    target_compiler=$cross_cc_lm32
   ;;
   m68k)
     bflt="yes"
     gdb_xml_files="cf-core.xml cf-fp.xml m68k-fp.xml"
+    target_compiler=$cross_cc_m68k
   ;;
   microblaze|microblazeel)
     TARGET_ARCH=microblaze
     bflt="yes"
+    target_compiler=$cross_cc_microblaze
   ;;
   mips|mipsel)
     TARGET_ARCH=mips
+    target_compiler=$cross_cc_mips
     echo "TARGET_ABI_MIPSO32=y" >> $config_target_mak
   ;;
   mipsn32|mipsn32el)
     TARGET_ARCH=mips64
     TARGET_BASE_ARCH=mips
+    target_compiler=$cross_cc_mipsn32
     echo "TARGET_ABI_MIPSN32=y" >> $config_target_mak
     echo "TARGET_ABI32=y" >> $config_target_mak
   ;;
   mips64|mips64el)
     TARGET_ARCH=mips64
     TARGET_BASE_ARCH=mips
+    target_compiler=$cross_cc_mips64
     echo "TARGET_ABI_MIPSN64=y" >> $config_target_mak
   ;;
   moxie)
+    target_compiler=$cross_cc_moxie
   ;;
   nios2)
+    target_compiler=$cross_cc_nios2
   ;;
   or1k)
+    target_compiler=$cross_cc_or1k
     TARGET_ARCH=openrisc
     TARGET_BASE_ARCH=openrisc
   ;;
   ppc)
     gdb_xml_files="power-core.xml power-fpu.xml power-altivec.xml power-spe.xml"
+    target_compiler=$cross_cc_powerpc
   ;;
   ppcemb)
     TARGET_BASE_ARCH=ppc
     TARGET_ABI_DIR=ppc
     gdb_xml_files="power-core.xml power-fpu.xml power-altivec.xml power-spe.xml"
+    target_compiler=$cross_cc_ppcemb
   ;;
   ppc64)
     TARGET_BASE_ARCH=ppc
     TARGET_ABI_DIR=ppc
     mttcg=yes
     gdb_xml_files="power64-core.xml power-fpu.xml power-altivec.xml power-spe.xml power-vsx.xml"
+    target_compiler=$cross_cc_ppc64
   ;;
   ppc64le)
     TARGET_ARCH=ppc64
@@ -6905,6 +6949,7 @@ case "$target_name" in
     TARGET_ABI_DIR=ppc
     mttcg=yes
     gdb_xml_files="power64-core.xml power-fpu.xml power-altivec.xml power-spe.xml power-vsx.xml"
+    target_compiler=$cross_cc_ppc64le
   ;;
   ppc64abi32)
     TARGET_ARCH=ppc64
@@ -6912,45 +6957,57 @@ case "$target_name" in
     TARGET_ABI_DIR=ppc
     echo "TARGET_ABI32=y" >> $config_target_mak
     gdb_xml_files="power64-core.xml power-fpu.xml power-altivec.xml power-spe.xml power-vsx.xml"
+    target_compiler=$cross_cc_ppc64abi32
   ;;
   riscv32)
     TARGET_BASE_ARCH=riscv
     TARGET_ABI_DIR=riscv
     mttcg=yes
+    target_compiler=$cross_cc_riscv32
   ;;
   riscv64)
     TARGET_BASE_ARCH=riscv
     TARGET_ABI_DIR=riscv
     mttcg=yes
+    target_compiler=$cross_cc_riscv64
   ;;
   sh4|sh4eb)
     TARGET_ARCH=sh4
     bflt="yes"
+    target_compiler=$cross_cc_sh4
   ;;
   sparc)
+    target_compiler=$cross_cc_sparc
   ;;
   sparc64)
     TARGET_BASE_ARCH=sparc
+    target_compiler=$cross_cc_sparc64
   ;;
   sparc32plus)
     TARGET_ARCH=sparc64
     TARGET_BASE_ARCH=sparc
     TARGET_ABI_DIR=sparc
+    target_compiler=$cross_cc_sparc32plus
     echo "TARGET_ABI32=y" >> $config_target_mak
   ;;
   s390x)
     mttcg=yes
     gdb_xml_files="s390x-core64.xml s390-acr.xml s390-fpr.xml s390-vx.xml s390-cr.xml s390-virt.xml s390-gs.xml"
+    target_compiler=$cross_cc_s390x
   ;;
   tilegx)
+    target_compiler=$cross_cc_tilegx
   ;;
   tricore)
+    target_compiler=$cross_cc_tricore
   ;;
   unicore32)
+    target_compiler=$cross_cc_unicore32
   ;;
   xtensa|xtensaeb)
     TARGET_ARCH=xtensa
     mttcg="yes"
+    target_compiler=$cross_cc_xtensa
   ;;
   *)
     error_exit "Unsupported target CPU"
@@ -6961,6 +7018,27 @@ if [ "$TARGET_BASE_ARCH" = "" ]; then
   TARGET_BASE_ARCH=$TARGET_ARCH
 fi
 
+# Do we have a cross compiler for this target?
+if has $target_compiler; then
+
+    write_c_skeleton
+
+    if ! do_compiler $target_compiler -o $TMPE $TMPC -static ; then
+        # For host systems we might get away with building without -static
+        if ! do_compiler $target_compiler -o $TMPE $TMPC ; then
+            target_compiler=""
+        else
+            enabled_cross_compilers="${enabled_cross_compilers} ${target_compiler}"
+            target_compiler_static="n"
+        fi
+    else
+        enabled_cross_compilers="${enabled_cross_compilers} ${target_compiler}"
+        target_compiler_static="y"
+    fi
+else
+    target_compiler=""
+fi
+
 symlink "$source_path/Makefile.target" "$target_dir/Makefile"
 
 upper() {
@@ -7034,6 +7112,14 @@ if test "$target_bsd_user" = "yes" ; then
   echo "CONFIG_BSD_USER=y" >> $config_target_mak
 fi
 
+if test -n "$target_compiler"; then
+  echo "CROSS_CC_GUEST=$target_compiler" >> $config_target_mak
+
+  if test -n "$target_compiler_static"; then
+      echo "CROSS_CC_GUEST_STATIC=$target_compiler_static" >> $config_target_mak
+  fi
+fi
+
 # generate QEMU_CFLAGS/LDFLAGS for targets
 
 cflags=""
@@ -7156,6 +7242,12 @@ echo "QEMU_CFLAGS+=$cflags" >> $config_target_mak
 
 done # for target in $targets
 
+if test -n "$enabled_cross_compilers"; then
+    echo
+    echo "NOTE: cross-compilers enabled:"
+    printf '%s\n' $enabled_cross_compilers | sort -u
+fi
+
 if [ "$fdt" = "git" ]; then
   echo "config-host.h: subdir-dtc" >> $config_host_mak
 fi
-- 
2.17.0

  parent reply	other threads:[~2018-05-25 13:39 UTC|newest]

Thread overview: 57+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2018-05-25 13:38 [Qemu-devel] [PATCH v5 00/49] fix buildings of tests/tcg Alex Bennée
2018-05-25 13:38 ` [Qemu-devel] [PATCH v5 01/49] docker: add "probe" command for configure Alex Bennée
2018-05-25 13:38 ` [Qemu-devel] [PATCH v5 02/49] configure: add test for docker availability Alex Bennée
2018-05-25 13:38 ` Alex Bennée [this message]
2018-05-25 13:38 ` [Qemu-devel] [PATCH v5 04/49] configure: move i386_cc to cross_cc_i386 Alex Bennée
2018-05-25 13:38 ` [Qemu-devel] [PATCH v5 05/49] configure: allow user to specify --cross-cc-cflags-foo= Alex Bennée
2018-05-25 13:38 ` [Qemu-devel] [PATCH v5 06/49] configure: set cross_cc_FOO for host compiler Alex Bennée
2018-05-25 13:38 ` [Qemu-devel] [PATCH v5 07/49] Makefile: Rename TARGET_DIRS to TARGET_LIST Alex Bennée
2018-05-25 13:38 ` [Qemu-devel] [PATCH v5 08/49] docker: Add "cc" subcommand Alex Bennée
2018-05-25 13:38 ` [Qemu-devel] [PATCH v5 09/49] docker: extend "cc" command to accept compiler Alex Bennée
2018-05-25 13:38 ` [Qemu-devel] [PATCH v5 10/49] docker: allow "cc" command to run in user context Alex Bennée
2018-05-25 13:38 ` [Qemu-devel] [PATCH v5 11/49] docker: Makefile.include introduce DOCKER_SCRIPT Alex Bennée
2018-05-25 13:38 ` [Qemu-devel] [PATCH v5 12/49] tests/tcg: move architecture independent tests into subdir Alex Bennée
2018-05-25 13:38 ` [Qemu-devel] [PATCH v5 13/49] tests/tcg/multiarch: Build fix for linux-test Alex Bennée
2018-05-25 13:38 ` [Qemu-devel] [PATCH v5 14/49] tests/tcg/multiarch: enable additional linux-test tests Alex Bennée
2018-05-25 13:38 ` [Qemu-devel] [PATCH v5 15/49] tests/tcg/multiarch: move most output to stdout Alex Bennée
2018-05-25 13:38 ` [Qemu-devel] [PATCH v5 16/49] tests/tcg: move i386 specific tests into subdir Alex Bennée
2018-05-25 13:38 ` [Qemu-devel] [PATCH v5 17/49] docker: Add fedora-i386-cross image Alex Bennée
2018-05-25 13:38 ` [Qemu-devel] [PATCH v5 18/49] tests/tcg: enable building for i386 Alex Bennée
2018-05-25 13:38 ` [Qemu-devel] [PATCH v5 19/49] tests/tcg/i386: Build fix for hello-i386 Alex Bennée
2018-05-25 13:38 ` [Qemu-devel] [PATCH v5 20/49] tests/tcg/i386: fix test-i386 Alex Bennée
2018-05-25 14:18 ` [Qemu-devel] [PATCH v5 22/49] tests/tcg/x86_64: add Makefile.target Alex Bennée
2018-05-25 14:18   ` [Qemu-devel] [PATCH v5 23/49] tests/tcg/i386/test-i386: use modern vector_size attributes Alex Bennée
2018-05-25 14:18   ` [Qemu-devel] [PATCH v5 24/49] tests/tcg/i386/test-i386: fix printf format Alex Bennée
2018-05-25 14:18   ` [Qemu-devel] [PATCH v5 25/49] tests/tcg: move ARM specific tests into subdir Alex Bennée
2018-05-25 14:19   ` [Qemu-devel] [PATCH v5 26/49] tests/tcg: enable building for ARM Alex Bennée
2018-05-25 14:19   ` [Qemu-devel] [PATCH v5 27/49] tests/tcg/arm: fix up test-arm-iwmmxt test Alex Bennée
2018-05-25 14:19   ` [Qemu-devel] [PATCH v5 28/49] tests/tcg: enable building for AArch64 Alex Bennée
2018-05-25 14:19   ` [Qemu-devel] [PATCH v5 29/49] tests/tcg/arm: add fcvt test cases for AArch32/64 Alex Bennée
2018-05-25 14:19 ` [Qemu-devel] [PATCH v5 30/49] tests/tcg: move MIPS specific tests into subdir Alex Bennée
2018-05-25 14:19   ` [Qemu-devel] [PATCH v5 31/49] tests/tcg: enable building for MIPS Alex Bennée
2018-05-25 14:19   ` [Qemu-devel] [PATCH v5 32/49] tests/tcg/mips: include common mips hello-mips Alex Bennée
2018-05-25 14:19   ` [Qemu-devel] [PATCH v5 33/49] tests/tcg: enable building for s390x Alex Bennée
2018-05-25 14:19   ` [Qemu-devel] [PATCH v5 34/49] tests/tcg: enable building for ppc64 Alex Bennée
2018-05-25 14:19   ` [Qemu-devel] [PATCH v5 35/49] tests/tcg: enable building for Alpha Alex Bennée
2018-05-26  5:49     ` Philippe Mathieu-Daudé
2018-05-29 12:51       ` Alex Bennée
2018-05-25 14:19   ` [Qemu-devel] [PATCH v5 36/49] tests/tcg/alpha: add Alpha specific tests Alex Bennée
2018-05-25 14:19   ` [Qemu-devel] [PATCH v5 37/49] tests/tcg: enable building for HPPA Alex Bennée
2018-05-25 14:19   ` [Qemu-devel] [PATCH v5 38/49] tests/tcg: enable building for m68k Alex Bennée
2018-05-25 14:19   ` [Qemu-devel] [PATCH v5 39/49] tests/tcg: enable building for sh4 Alex Bennée
2018-05-25 14:19 ` [Qemu-devel] [PATCH v5 40/49] tests/tcg: enable building for sparc64 Alex Bennée
2018-05-25 14:19   ` [Qemu-devel] [PATCH v5 41/49] tests/tcg: enable building for mips64 Alex Bennée
2018-05-25 14:19   ` [Qemu-devel] [PATCH v5 42/49] tests/tcg: enable building for RISCV64 Alex Bennée
2018-05-25 14:19   ` [Qemu-devel] [PATCH v5 43/49] docker: move debian-powerpc-cross to sid based build Alex Bennée
2018-05-28  9:06     ` Fam Zheng
2018-05-25 14:19   ` [Qemu-devel] [PATCH v5 44/49] tests/tcg: enable building for PowerPC Alex Bennée
2018-05-25 14:19   ` [Qemu-devel] [PATCH v5 45/49] tests/tcg/Makefile: update to be called from Makefile.target Alex Bennée
2018-05-26  6:04     ` Philippe Mathieu-Daudé
2018-05-29 12:49       ` Alex Bennée
2018-05-25 14:19   ` [Qemu-devel] [PATCH v5 46/49] Makefile.target: add (clean-/build-)guest-tests targets Alex Bennée
2018-05-25 14:19   ` [Qemu-devel] [PATCH v5 47/49] tests/Makefile.include: add [build|clean|check]-tcg targets Alex Bennée
2018-05-25 14:19   ` [Qemu-devel] [PATCH v5 48/49] tests/tcg: override runners for broken tests Alex Bennée
2018-05-25 14:19   ` [Qemu-devel] [PATCH v5 49/49] tests/tcg: add run, diff, and skip helper macros Alex Bennée
2018-05-25 15:05     ` [Qemu-devel] [PATCH v5.1 " Alex Bennée
2018-05-25 15:04 ` [Qemu-devel] [PATCH v5.1 21/49] tests/tcg/i386: add runner for test-i386-fprem Alex Bennée
2018-05-25 15:15 ` [Qemu-devel] [PATCH v5 00/49] fix buildings of tests/tcg Alex Bennée

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20180525133851.27161-4-alex.bennee@linaro.org \
    --to=alex.bennee@linaro.org \
    --cc=agraf@suse.de \
    --cc=aurelien@aurel32.net \
    --cc=balrogg@gmail.com \
    --cc=berrange@redhat.com \
    --cc=cota@braap.org \
    --cc=f4bug@amsat.org \
    --cc=famz@redhat.com \
    --cc=qemu-devel@nongnu.org \
    --cc=richard.henderson@linaro.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.