From: "Alex Bennée" <alex.bennee@linaro.org>
To: "Philippe Mathieu-Daudé" <f4bug@amsat.org>
Cc: qemu-devel@nongnu.org, famz@redhat.com, cota@braap.org
Subject: Re: [Qemu-devel] [PATCH v1 02/24] configure: add support for --cross-cc-FOO
Date: Mon, 16 Apr 2018 09:49:53 +0100 [thread overview]
Message-ID: <87h8obbkni.fsf@linaro.org> (raw)
In-Reply-To: <5464750f-75ed-dddc-797c-5ca3561dc7dd@amsat.org>
Philippe Mathieu-Daudé <f4bug@amsat.org> writes:
> On 04/10/2018 04:38 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>
>> ---
>> configure | 50 ++++++++++++++++++++++++++++++++++++++++++++++++++
>> 1 file changed, 50 insertions(+)
>>
>> diff --git a/configure b/configure
>> index b402befe94..b5f3b3fe29 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"
>
> These seems distrib-specific... Should we add a case $distrib) ...?
I think of this more as sensible defaults - I would expect most people
using local cross-compilers to be manually setting them up with the
--cross-cc-FOO flag.
>
>> +
>> +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_0]=*) error_exit "Passed bad --cross-cc-FOO option"
>> + ;;
>> + --cross-cc-*) cc_arch=${opt#--cross-cc-}
>> + eval "cross_cc_${cc_arch}=\$optarg"
>> + ;;
>> 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"
>> ;;
>> @@ -6766,6 +6782,8 @@ case "$target" in
>> ;;
>> esac
>>
>> +target_compiler=""
>> +
>> mkdir -p $target_dir
>> echo "# Automatically generated by configure - do not modify" > $config_target_mak
>>
>> @@ -6794,6 +6812,7 @@ case "$target_name" in
>> 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
>> @@ -6801,6 +6820,7 @@ 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)
>> ;;
>> @@ -6842,6 +6862,7 @@ case "$target_name" in
>> ;;
>> 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
>> @@ -6916,6 +6937,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
>> +
>> + 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() {
>> @@ -6989,6 +7029,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=""
>> @@ -7111,6 +7155,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
>>
--
Alex Bennée
next prev parent reply other threads:[~2018-04-16 8:50 UTC|newest]
Thread overview: 83+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-04-10 19:38 [Qemu-devel] [PATCH v1 00/24] fix building of tests/tcg Alex Bennée
2018-04-10 19:38 ` [Qemu-devel] [PATCH v1 01/24] configure: add test for docker availability Alex Bennée
2018-04-11 8:50 ` Fam Zheng
2018-04-11 10:58 ` Alex Bennée
2018-04-11 12:59 ` Fam Zheng
2018-04-10 19:38 ` [Qemu-devel] [PATCH v1 02/24] configure: add support for --cross-cc-FOO Alex Bennée
2018-04-16 2:04 ` Philippe Mathieu-Daudé
2018-04-16 8:49 ` Alex Bennée [this message]
2018-04-10 19:38 ` [Qemu-devel] [PATCH v1 03/24] configure: move i386_cc to cross_cc_i386 Alex Bennée
2018-04-16 0:01 ` Philippe Mathieu-Daudé
2018-04-16 9:02 ` Alex Bennée
2018-04-16 10:30 ` Philippe Mathieu-Daudé
2018-04-10 19:38 ` [Qemu-devel] [PATCH v1 04/24] Makefile: Rename TARGET_DIRS to TARGET_LIST Alex Bennée
2018-04-12 14:33 ` Philippe Mathieu-Daudé
2018-04-10 19:39 ` [Qemu-devel] [PATCH v1 05/24] docker: Add "cc" subcommand Alex Bennée
2018-04-16 1:48 ` Philippe Mathieu-Daudé
2018-04-10 19:39 ` [Qemu-devel] [PATCH v1 06/24] docker: extend "cc" command to accept compiler Alex Bennée
2018-04-12 8:07 ` Fam Zheng
2018-04-10 19:39 ` [Qemu-devel] [PATCH v1 07/24] docker: allow "cc" command to run in user context Alex Bennée
2018-04-12 8:08 ` Fam Zheng
2018-04-16 0:02 ` Philippe Mathieu-Daudé
2018-04-10 19:39 ` [Qemu-devel] [PATCH v1 08/24] docker: Makefile.include introduce DOCKER_SCRIPT Alex Bennée
2018-04-11 15:10 ` Philippe Mathieu-Daudé
2018-04-10 19:39 ` [Qemu-devel] [PATCH v1 09/24] tests/tcg: move architecture independent tests into subdir Alex Bennée
2018-04-11 10:22 ` Thomas Huth
2018-04-16 0:05 ` Philippe Mathieu-Daudé
2018-04-16 9:01 ` Alex Bennée
2018-04-10 19:39 ` [Qemu-devel] [PATCH v1 10/24] tests/tcg/multiarch: Build fix for linux-test Alex Bennée
2018-04-11 10:25 ` Thomas Huth
[not found] ` <4bc22552-25b4-2a04-dc73-dc17201a2251@amsat.org>
[not found] ` <3b680ef4-3304-99d5-75ef-c4d5d570bb3a@amsat.org>
2018-04-16 8:51 ` Alex Bennée
2018-05-25 10:21 ` Alex Bennée
2018-04-10 19:39 ` [Qemu-devel] [PATCH v1 11/24] tests/tcg: move i386 specific tests into subdir Alex Bennée
2018-04-11 10:30 ` Thomas Huth
2018-04-16 0:08 ` Philippe Mathieu-Daudé
2018-04-10 19:39 ` [Qemu-devel] [PATCH v1 12/24] tests/tcg/i386: Build fix for hello-i386 Alex Bennée
2018-04-11 10:30 ` Thomas Huth
2018-04-16 0:11 ` Philippe Mathieu-Daudé
2018-04-16 8:57 ` Alex Bennée
2018-04-10 19:39 ` [Qemu-devel] [PATCH v1 13/24] tests/tcg/i386: move test-i386-sse.c to tests/tcg/x86_64/test-sse.c Alex Bennée
2018-04-11 15:33 ` Thomas Huth
2018-04-11 16:19 ` Alex Bennée
2018-04-10 19:39 ` [Qemu-devel] [PATCH v1 14/24] tests/tcg/i386: fix test-i386 Alex Bennée
2018-04-11 15:36 ` Thomas Huth
2018-04-16 0:13 ` Philippe Mathieu-Daudé
2018-04-10 19:39 ` [Qemu-devel] [PATCH v1 15/24] tests/tcg/i368: fix hello-i386 Alex Bennée
2018-04-11 15:38 ` Thomas Huth
2018-04-16 0:14 ` Philippe Mathieu-Daudé
2018-04-10 19:39 ` [Qemu-devel] [PATCH v1 16/24] tests/tcg/i386: fix test-i386-fprem Alex Bennée
2018-04-11 15:14 ` Philippe Mathieu-Daudé
2018-04-10 19:39 ` [Qemu-devel] [PATCH v1 17/24] tests/tcg: move ARM specific tests into subdir Alex Bennée
2018-04-11 15:40 ` Thomas Huth
2018-04-16 0:14 ` Philippe Mathieu-Daudé
2018-04-10 19:39 ` [Qemu-devel] [PATCH v1 18/24] tests/tcg/arm: fix hello-arm Alex Bennée
2018-04-11 15:42 ` Thomas Huth
2018-04-16 1:28 ` Philippe Mathieu-Daudé
2018-04-10 19:39 ` [Qemu-devel] [PATCH v1 19/24] tests/tcg: move MIPS specific tests into subdir Alex Bennée
2018-04-16 1:02 ` Philippe Mathieu-Daudé
2018-04-16 1:33 ` Philippe Mathieu-Daudé
2018-04-16 8:56 ` Alex Bennée
2018-04-16 10:21 ` Philippe Mathieu-Daudé
2018-04-10 19:39 ` [Qemu-devel] [PATCH v1 20/24] tests/tcg: enable building for s390x Alex Bennée
2018-04-11 8:36 ` Cornelia Huck
2018-04-16 1:33 ` Philippe Mathieu-Daudé
2018-04-10 19:39 ` [Qemu-devel] [PATCH v1 21/24] tests/tcg: enable building for ppc64 Alex Bennée
2018-04-16 1:36 ` Philippe Mathieu-Daudé
2018-04-16 8:54 ` Alex Bennée
2018-04-10 19:39 ` [Qemu-devel] [PATCH v1 22/24] tests/tcg/Makefile: update to be called from Makefile.target Alex Bennée
2018-04-12 8:13 ` Fam Zheng
2018-04-12 8:47 ` Alex Bennée
2018-04-12 9:14 ` Fam Zheng
2018-04-10 19:39 ` [Qemu-devel] [PATCH v1 23/24] Makefile.target: add (clean-)guest-tests targets Alex Bennée
2018-04-16 1:12 ` Philippe Mathieu-Daudé
2018-04-16 1:52 ` Philippe Mathieu-Daudé
2018-04-16 8:53 ` Alex Bennée
2018-04-16 10:24 ` Philippe Mathieu-Daudé
2018-04-16 17:14 ` Philippe Mathieu-Daudé
2018-04-16 20:08 ` Alex Bennée
2018-04-17 14:41 ` Philippe Mathieu-Daudé
2018-04-17 15:09 ` Alex Bennée
2018-04-10 19:39 ` [Qemu-devel] [PATCH v1 24/24] tests/Makefile.include: add (clean-)check-tcg targets Alex Bennée
2018-04-16 1:53 ` Philippe Mathieu-Daudé
2018-04-10 20:07 ` [Qemu-devel] [PATCH v1 00/24] fix building of tests/tcg no-reply
2018-04-16 10:37 ` Philippe Mathieu-Daudé
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=87h8obbkni.fsf@linaro.org \
--to=alex.bennee@linaro.org \
--cc=cota@braap.org \
--cc=f4bug@amsat.org \
--cc=famz@redhat.com \
--cc=qemu-devel@nongnu.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).