From: Murilo Opsfelder Araujo <muriloo@linux.ibm.com>
To: "Alex Bennée" <alex.bennee@linaro.org>,
peter.maydell@linaro.org, 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
Subject: Re: [Qemu-devel] [PATCH v3 03/46] configure: add support for --cross-cc-FOO
Date: Wed, 25 Apr 2018 13:27:20 -0300 [thread overview]
Message-ID: <bb44b0dc-d0c2-2ff3-1815-00b80f199848@linux.ibm.com> (raw)
In-Reply-To: <20180424152405.10304-4-alex.bennee@linaro.org>
On 04/24/2018 12:23 PM, Alex Bennée wrote:
> 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>
>
> ---
> 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
> ---
> configure | 79 +++++++++++++++++++++++++++++++++++++++++++++++++++++++
> 1 file changed, 79 insertions(+)
>
> diff --git a/configure b/configure
> index b0ae632ee4..caa838a0d0 100755
> --- a/configure
> +++ b/configure
> @@ -453,6 +453,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"
Do we need to have default values for all targets?
> +
> +enabled_cross_compilers=""
> +
> supported_cpu="no"
> supported_os="no"
> bogus_os="no"
> @@ -483,6 +490,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"
> + ;;
Do we need to verify if a valid --cross-cc-FOO was passed, in case of a
typo?
> esac
> done
> # OS specific
> @@ -675,10 +687,12 @@ case "$cpu" in
> i386|i486|i586|i686|i86pc|BePC)
> cpu="i386"
> supported_cpu="yes"
> + cross_cc_i386=gcc
> ;;
> x86_64|amd64)
> cpu="x86_64"
> supported_cpu="yes"
> + cross_cc_x86_64=gcc
> ;;
> armv*b|armv*l|arm)
> cpu="arm"
> @@ -912,6 +926,8 @@ for opt do
> ;;
> --disable-debug-info)
> ;;
> + --cross-cc-*)
> + ;;
> --enable-modules)
> modules="yes"
> ;;
> @@ -6777,6 +6793,8 @@ case "$target" in
> ;;
> esac
>
> +target_compiler=""
> +
> mkdir -p $target_dir
> echo "# Automatically generated by configure - do not modify" > $config_target_mak
>
> @@ -6792,19 +6810,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
> @@ -6812,58 +6834,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
> @@ -6871,6 +6908,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
> @@ -6878,45 +6916,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"
> @@ -6927,6 +6977,25 @@ 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
> +
> + cat > $TMPC << EOF
> +#include <stdio.h>
> +int main(void) {
> + printf("Hello World!\n");
> +}
> +EOF
Can this be replaced by write_c_skeleton?
> +
> + if ! do_compiler $target_compiler -o $TMPE $TMPC -static ; then
> + target_compiler=""
> + else
> + enabled_cross_compilers="${enabled_cross_compilers} ${target_compiler}"
> + fi
> +else
> + target_compiler=""
> +fi
> +
> symlink "$source_path/Makefile.target" "$target_dir/Makefile"
>
> upper() {
> @@ -7000,6 +7069,10 @@ 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
> +fi
> +
> # generate QEMU_CFLAGS/LDFLAGS for targets
>
> cflags=""
> @@ -7122,6 +7195,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 [ "$dtc_internal" = "yes" ]; then
> echo "config-host.h: subdir-dtc" >> $config_host_mak
> fi
>
next prev parent reply other threads:[~2018-04-25 16:27 UTC|newest]
Thread overview: 102+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-04-24 15:23 [Qemu-devel] [PATCH v3 00/46] fix building of tests/tcg Alex Bennée
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 01/46] docker: add "probe" command for configure Alex Bennée
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 02/46] configure: add test for docker availability Alex Bennée
2018-04-25 0:06 ` Richard Henderson
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 03/46] configure: add support for --cross-cc-FOO Alex Bennée
2018-04-25 0:10 ` Richard Henderson
2018-04-25 9:10 ` Alex Bennée
2018-04-25 16:27 ` Murilo Opsfelder Araujo [this message]
2018-05-16 15:18 ` Alex Bennée
2018-05-16 17:36 ` Murilo Opsfelder Araujo
2018-05-16 20:37 ` Alex Bennée
2018-04-25 17:03 ` Peter Maydell
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 04/46] configure: move i386_cc to cross_cc_i386 Alex Bennée
2018-04-25 0:11 ` Richard Henderson
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 05/46] configure: allow user to specify --cross-cc-cflags-foo= Alex Bennée
2018-04-25 0:12 ` Richard Henderson
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 06/46] configure: set cross_cc_FOO for host compiler Alex Bennée
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 07/46] Makefile: Rename TARGET_DIRS to TARGET_LIST Alex Bennée
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 08/46] docker: Add "cc" subcommand Alex Bennée
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 09/46] docker: extend "cc" command to accept compiler Alex Bennée
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 10/46] docker: allow "cc" command to run in user context Alex Bennée
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 11/46] docker: Makefile.include introduce DOCKER_SCRIPT Alex Bennée
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 12/46] tests/tcg: move architecture independent tests into subdir Alex Bennée
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 13/46] tests/tcg/multiarch: Build fix for linux-test Alex Bennée
2018-04-25 0:13 ` Richard Henderson
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 14/46] tests/tcg/multiarch: enable additional linux-test tests Alex Bennée
2018-04-25 0:14 ` Richard Henderson
2018-04-25 4:07 ` Philippe Mathieu-Daudé
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 15/46] tests/tcg/multiarch: move most output to stdout Alex Bennée
2018-04-25 0:14 ` Richard Henderson
2018-04-25 4:06 ` Philippe Mathieu-Daudé
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 16/46] tests/tcg: move i386 specific tests into subdir Alex Bennée
2018-04-25 0:15 ` Richard Henderson
2018-04-25 3:27 ` Philippe Mathieu-Daudé
2018-04-25 9:08 ` Alex Bennée
2018-04-25 13:42 ` Philippe Mathieu-Daudé
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 17/46] docker: Add fedora-i386-cross image Alex Bennée
2018-04-24 23:04 ` Philippe Mathieu-Daudé
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 18/46] tests/tcg: enable building for i386 Alex Bennée
2018-04-25 3:33 ` Philippe Mathieu-Daudé
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 19/46] tests/tcg/i386: Build fix for hello-i386 Alex Bennée
2018-04-25 0:22 ` Richard Henderson
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 20/46] tests/tcg/i386: fix test-i386 Alex Bennée
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 21/46] tests/tcg/i386: fix test-i386-fprem Alex Bennée
2018-04-25 0:23 ` Richard Henderson
2018-04-25 3:26 ` Thomas Huth
2018-04-25 8:46 ` Alex Bennée
2018-04-25 3:42 ` Philippe Mathieu-Daudé
2018-04-25 8:45 ` Alex Bennée
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 22/46] tests/tcg/i386: disable i386 version of test-i386-ssse Alex Bennée
2018-04-25 21:28 ` Richard Henderson
2018-04-26 8:59 ` Alex Bennée
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 23/46] tests/tcg/x86_64: add Makefile.target Alex Bennée
2018-04-25 4:03 ` Philippe Mathieu-Daudé
2018-04-25 8:43 ` Alex Bennée
2018-04-25 14:01 ` Philippe Mathieu-Daudé
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 24/46] tests/tcg/i386/test-i386: use modern vector_size attributes Alex Bennée
2018-04-25 3:47 ` Philippe Mathieu-Daudé
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 25/46] tests/tcg/i386/test-i386: fix printf format Alex Bennée
2018-04-25 14:06 ` Philippe Mathieu-Daudé
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 26/46] tests/tcg: move ARM specific tests into subdir Alex Bennée
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 27/46] tests/tcg/arm: fix up test-arm-iwmmxt test Alex Bennée
2018-04-25 3:48 ` Philippe Mathieu-Daudé
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 28/46] tests/tcg/aarch64: add Makefile.target Alex Bennée
2018-04-25 3:57 ` Philippe Mathieu-Daudé
2018-04-25 8:43 ` Alex Bennée
2018-04-25 14:21 ` Philippe Mathieu-Daudé
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 29/46] tests/tcg/aarch64: add fcvt test cases for AArch64 Alex Bennée
2018-04-25 14:22 ` Philippe Mathieu-Daudé
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 30/46] tests/tcg: move MIPS specific tests into subdir Alex Bennée
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 31/46] tests/tcg: enable building for MIPS Alex Bennée
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 32/46] tests/tcg/mips: include common mips hello-mips Alex Bennée
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 33/46] tests/tcg: enable building for s390x Alex Bennée
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 34/46] tests/tcg: enable building for ppc64 Alex Bennée
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 35/46] tests/tcg: enable building for Alpha Alex Bennée
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 36/46] tests/tcg/alpha: add Alpha specific tests Alex Bennée
2018-04-24 18:28 ` Richard Henderson
2018-04-25 9:11 ` Alex Bennée
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 37/46] tests/tcg/alpha: fix warnings about write() Alex Bennée
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 38/46] tests/tcg: enable building for HPPA Alex Bennée
2018-04-25 14:08 ` Philippe Mathieu-Daudé
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 39/46] tests/tcg: enable building for m68k Alex Bennée
2018-04-25 14:28 ` Philippe Mathieu-Daudé
2018-04-24 15:23 ` [Qemu-devel] [PATCH v3 40/46] tests/tcg: enable building for sh4 Alex Bennée
2018-04-25 14:16 ` Philippe Mathieu-Daudé
2018-04-24 15:24 ` [Qemu-devel] [PATCH v3 41/46] tests/tcg: enable building for sparc64 Alex Bennée
2018-04-24 15:24 ` [Qemu-devel] [PATCH v3 42/46] tests/tcg: enable building for mips64 Alex Bennée
2018-04-24 15:24 ` [Qemu-devel] [PATCH v3 43/46] tests/tcg/Makefile: update to be called from Makefile.target Alex Bennée
2018-04-25 21:26 ` Richard Henderson
2018-04-26 9:30 ` Alex Bennée
2018-04-26 20:51 ` Richard Henderson
2018-04-24 15:24 ` [Qemu-devel] [PATCH v3 44/46] Makefile.target: add (clean-)guest-tests targets Alex Bennée
2018-04-24 15:24 ` [Qemu-devel] [PATCH v3 45/46] tests/Makefile.include: add [build|clean|check]-tcg targets Alex Bennée
2018-04-24 23:13 ` Philippe Mathieu-Daudé
2018-04-25 14:15 ` Philippe Mathieu-Daudé
2018-04-25 15:40 ` Alex Bennée
2018-04-25 3:18 ` Philippe Mathieu-Daudé
2018-04-24 15:24 ` [Qemu-devel] [PATCH v3 46/46] tests/tcg: override runners for broken tests (!UPSTREAM) Alex Bennée
2018-04-24 16:58 ` [Qemu-devel] [PATCH v3 00/46] fix building of tests/tcg no-reply
2018-04-25 1:25 ` Philippe Mathieu-Daudé
2018-04-25 6:57 ` Samuel Thibault
2018-04-25 8:39 ` 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=bb44b0dc-d0c2-2ff3-1815-00b80f199848@linux.ibm.com \
--to=muriloo@linux.ibm.com \
--cc=agraf@suse.de \
--cc=alex.bennee@linaro.org \
--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=peter.maydell@linaro.org \
--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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).