From: Stefan Hajnoczi <stefanha@redhat.com>
To: "Alex Bennée" <alex.bennee@linaro.org>
Cc: qemu-devel@nongnu.org, Paolo Bonzini <pbonzini@redhat.com>
Subject: Re: [PULL 26/54] configure: unify creation of cross-compilation Makefiles
Date: Thu, 6 Oct 2022 16:33:02 -0400 [thread overview]
Message-ID: <Yz87fr2/PLMdX6wK@fedora> (raw)
In-Reply-To: <20221004130138.2299307-27-alex.bennee@linaro.org>
[-- Attachment #1: Type: text/plain, Size: 5797 bytes --]
On Tue, Oct 04, 2022 at 02:01:10PM +0100, Alex Bennée wrote:
> From: Paolo Bonzini <pbonzini@redhat.com>
>
> Let write_target_makefile handle both host and container cross compilers.
>
> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
> Signed-off-by: Alex Bennée <alex.bennee@linaro.org>
> Message-Id: <20220929114231.583801-27-alex.bennee@linaro.org>
I think this commit breaks bisection:
configure: line 2498: syntax error near unexpected token `('
configure: line 2498: ` echo "run-tcg-tests-$target: $qemu\$(EXESUF)" >> Makefile.prereqs'
It has already been merged into qemu.git/master, so there's no fixing it
now. I wanted to leave a comment in case someone hits this problem in
the future and wonders what's going on.
I had to use git bisect skip.
Stefan
>
> diff --git a/configure b/configure
> index cbeac99b2b..8b495d4453 100755
> --- a/configure
> +++ b/configure
> @@ -2157,51 +2157,49 @@ probe_target_compiler() {
>
> write_target_makefile() {
> echo "EXTRA_CFLAGS=$target_cflags"
> - if test -n "$target_cc"; then
> - echo "CC=$target_cc"
> - echo "CCAS=$target_ccas"
> - fi
> - if test -n "$target_ar"; then
> - echo "AR=$target_ar"
> - fi
> - if test -n "$target_as"; then
> - echo "AS=$target_as"
> - fi
> - if test -n "$target_ld"; then
> - echo "LD=$target_ld"
> - fi
> - if test -n "$target_nm"; then
> - echo "NM=$target_nm"
> - fi
> - if test -n "$target_objcopy"; then
> - echo "OBJCOPY=$target_objcopy"
> - fi
> - if test -n "$target_ranlib"; then
> - echo "RANLIB=$target_ranlib"
> - fi
> - if test -n "$target_strip"; then
> - echo "STRIP=$target_strip"
> - fi
> -}
> -
> -write_container_target_makefile() {
> - echo "$1: docker-image-$container_image" >> Makefile.prereqs
> - echo "EXTRA_CFLAGS=$target_cflags"
> - if test -n "$container_cross_cc"; then
> - echo "CC=$docker_py cc --cc $container_cross_cc -i qemu/$container_image -s $source_path --"
> - echo "CCAS=$docker_py cc --cc $container_cross_cc -i qemu/$container_image -s $source_path --"
> + if test -z "$target_cc" && test -z "$target_as"; then
> + test -z "$container_image" && error_exit "Internal error: could not find cross compiler for $1?"
> + echo "$1: docker-image-$container_image" >> Makefile.prereqs
> + if test -n "$container_cross_cc"; then
> + echo "CC=$docker_py cc --cc $container_cross_cc -i qemu/$container_image -s $source_path --"
> + echo "CCAS=$docker_py cc --cc $container_cross_cc -i qemu/$container_image -s $source_path --"
> + fi
> + echo "AR=$docker_py cc --cc $container_cross_ar -i qemu/$container_image -s $source_path --"
> + echo "AS=$docker_py cc --cc $container_cross_as -i qemu/$container_image -s $source_path --"
> + echo "LD=$docker_py cc --cc $container_cross_ld -i qemu/$container_image -s $source_path --"
> + echo "NM=$docker_py cc --cc $container_cross_nm -i qemu/$container_image -s $source_path --"
> + echo "OBJCOPY=$docker_py cc --cc $container_cross_objcopy -i qemu/$container_image -s $source_path --"
> + echo "RANLIB=$docker_py cc --cc $container_cross_ranlib -i qemu/$container_image -s $source_path --"
> + echo "STRIP=$docker_py cc --cc $container_cross_strip -i qemu/$container_image -s $source_path --"
> + else
> + if test -n "$target_cc"; then
> + echo "CC=$target_cc"
> + echo "CCAS=$target_ccas"
> + fi
> + if test -n "$target_ar"; then
> + echo "AR=$target_ar"
> + fi
> + if test -n "$target_as"; then
> + echo "AS=$target_as"
> + fi
> + if test -n "$target_ld"; then
> + echo "LD=$target_ld"
> + fi
> + if test -n "$target_nm"; then
> + echo "NM=$target_nm"
> + fi
> + if test -n "$target_objcopy"; then
> + echo "OBJCOPY=$target_objcopy"
> + fi
> + if test -n "$target_ranlib"; then
> + echo "RANLIB=$target_ranlib"
> + fi
> + if test -n "$target_strip"; then
> + echo "STRIP=$target_strip"
> + fi
> fi
> - echo "AR=$docker_py cc --cc $container_cross_ar -i qemu/$container_image -s $source_path --"
> - echo "AS=$docker_py cc --cc $container_cross_as -i qemu/$container_image -s $source_path --"
> - echo "LD=$docker_py cc --cc $container_cross_ld -i qemu/$container_image -s $source_path --"
> - echo "NM=$docker_py cc --cc $container_cross_nm -i qemu/$container_image -s $source_path --"
> - echo "OBJCOPY=$docker_py cc --cc $container_cross_objcopy -i qemu/$container_image -s $source_path --"
> - echo "RANLIB=$docker_py cc --cc $container_cross_ranlib -i qemu/$container_image -s $source_path --"
> - echo "STRIP=$docker_py cc --cc $container_cross_strip -i qemu/$container_image -s $source_path --"
> }
>
> -
> -
> ##########################################
> # check for vfio_user_server
>
> @@ -2560,15 +2558,9 @@ for target in $target_list; do
> ;;
> esac
>
> - probe_target_compiler $target
> - if test $got_cross_cc = yes; then
> - write_target_makefile >> "$config_target_mak"
> - elif test -n "$container_image"; then
> - build_static=y
> - write_container_target_makefile build-tcg-tests-$target >> "$config_target_mak"
> - got_cross_cc=yes
> - fi
> - if test $got_cross_cc = yes; then
> + if probe_target_compiler $target || test -n "$container_image"; then
> + test -n "$container_image" && build_static=y
> + write_target_makefile "build-tcg-tests-$target >> "$config_target_mak"
> mkdir -p "tests/tcg/$target"
> ln -sf "$source_path/tests/tcg/Makefile.target" "tests/tcg/$target/Makefile"
> ln -sf "../config-$target.mak" "tests/tcg/$target/config-target.mak"
> --
> 2.34.1
>
[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 488 bytes --]
next prev parent reply other threads:[~2022-10-06 20:34 UTC|newest]
Thread overview: 64+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-10-04 13:00 [PULL 00/54] testing, gdbstub, plugin and gitdm updates Alex Bennée
2022-10-04 13:00 ` [PULL 01/54] scripts/ci/setup: ninja missing from build-environment Alex Bennée
2022-10-04 13:00 ` [PULL 02/54] scripts/ci/setup: Fix libxen requirements Alex Bennée
2022-10-04 13:00 ` [PULL 03/54] scripts/ci/setup: spice-server only on x86 aarch64 Alex Bennée
2022-10-04 13:00 ` [PULL 04/54] tests/docker: run script use realpath instead of readlink Alex Bennée
2022-10-04 13:00 ` [PULL 05/54] configure: move detected gdb to TCG's config-host.mak Alex Bennée
2022-10-04 13:00 ` [PULL 06/54] target/hexagon: add flex/bison/glib2 to qemu.yml Alex Bennée
2022-10-04 13:00 ` [PULL 07/54] target/hexagon: regenerate docker/cirrus files Alex Bennée
2022-10-04 13:00 ` [PULL 08/54] target/hexagon: manually add flex/bison/glib2 to remaining containers Alex Bennée
2022-10-04 13:00 ` [PULL 09/54] tests/docker: update fedora-win[32|64]-cross with lcitool Alex Bennée
2022-10-04 13:00 ` [PULL 10/54] tests/docker: move alpine from edge to tagged release Alex Bennée
2022-10-04 13:00 ` [PULL 11/54] tests/qtest: bump up QOS_PATH_MAX_ELEMENT_SIZE Alex Bennée
2022-10-04 13:00 ` [PULL 12/54] configure: do not invoke as/ld directly for pc-bios/optionrom Alex Bennée
2022-10-04 13:00 ` [PULL 13/54] pc-bios/optionrom: detect CC options just once Alex Bennée
2022-10-04 13:00 ` [PULL 14/54] pc-bios/s390-ccw: " Alex Bennée
2022-10-04 13:00 ` [PULL 15/54] vof: add distclean target Alex Bennée
2022-10-04 13:01 ` [PULL 16/54] build: add recursive distclean rules Alex Bennée
2022-10-04 13:01 ` [PULL 17/54] configure: return status code from probe_target_compiler Alex Bennée
2022-10-04 13:01 ` [PULL 18/54] configure: store container engine in config-host.mak Alex Bennée
2022-10-04 13:01 ` [PULL 19/54] tests: simplify Makefile invocation for tests/tcg Alex Bennée
2022-10-04 13:01 ` [PULL 20/54] tests/tcg: remove -f from Makefile invocation Alex Bennée
2022-10-04 13:01 ` [PULL 21/54] tests/tcg: add distclean rule Alex Bennée
2022-10-04 13:01 ` [PULL 22/54] tests/tcg: unify ppc64 and ppc64le Makefiles Alex Bennée
2022-10-04 13:01 ` [PULL 23/54] tests/tcg: clean up calls to run-test Alex Bennée
2022-10-04 13:01 ` [PULL 24/54] tests/tcg: move compiler tests to Makefiles Alex Bennée
2022-10-04 13:01 ` [PULL 25/54] configure: move tests/tcg/Makefile.prereqs to root build directory Alex Bennée
2022-10-04 13:01 ` [PULL 26/54] configure: unify creation of cross-compilation Makefiles Alex Bennée
2022-10-06 20:33 ` Stefan Hajnoczi [this message]
2022-10-04 13:01 ` [PULL 27/54] configure: cleanup creation of tests/tcg target config Alex Bennée
2022-10-04 13:01 ` [PULL 28/54] configure: build ROMs with container-based cross compilers Alex Bennée
2022-10-06 20:37 ` Stefan Hajnoczi
2022-10-10 12:54 ` Daniel P. Berrangé
2022-10-10 13:07 ` Daniel P. Berrangé
2022-10-10 13:47 ` Alex Bennée
2022-10-04 13:01 ` [PULL 29/54] pc-bios/optionrom: Adopt meson style Make output Alex Bennée
2022-10-04 13:01 ` [PULL 30/54] pc-bios/s390-ccw: " Alex Bennée
2022-10-04 13:01 ` [PULL 31/54] pc-bios/vof: " Alex Bennée
2022-10-04 13:01 ` [PULL 32/54] monitor: expose monitor_puts to rest of code Alex Bennée
2022-10-04 13:01 ` [PULL 33/54] disas: generalise plugin_printf and use for monitor_disas Alex Bennée
2022-10-04 13:01 ` [PULL 34/54] disas: use result of ->read_memory_func Alex Bennée
2022-10-04 13:01 ` [PULL 35/54] plugins: extend execlog to filter matches Alex Bennée
2022-10-04 13:01 ` [PULL 36/54] plugins: Assert mmu_idx in range before use in qemu_plugin_get_hwaddr Alex Bennée
2022-10-04 13:01 ` [PULL 37/54] docs/devel: clean-up qemu invocations in tcg-plugins Alex Bennée
2022-10-04 13:01 ` [PULL 38/54] docs/devel: move API to end of tcg-plugins.rst Alex Bennée
2022-10-04 13:01 ` [PULL 39/54] contrib/plugins: reset skip when matching in execlog Alex Bennée
2022-10-04 13:01 ` [PULL 40/54] docs/devel: document the test plugins Alex Bennée
2022-10-04 13:01 ` [PULL 41/54] semihosting: update link to spec Alex Bennée
2022-10-04 13:01 ` [PULL 42/54] gdbstub: move into its own sub directory Alex Bennée
2022-10-04 13:01 ` [PULL 43/54] gdbstub: move sstep flags probing into AccelClass Alex Bennée
2022-10-04 13:01 ` [PULL 44/54] gdbstub: move breakpoint logic to accel ops Alex Bennée
2022-10-04 13:01 ` [PULL 45/54] gdbstub: move guest debug support check to ops Alex Bennée
2022-10-04 13:01 ` [PULL 46/54] accel/kvm: move kvm_update_guest_debug to inline stub Alex Bennée
2022-10-04 13:01 ` [PULL 47/54] contrib/gitdm: add mapping for Loongson Technology Alex Bennée
2022-10-04 13:01 ` [PULL 48/54] contrib/gitdm: add Paul to individual contributors Alex Bennée
2022-10-04 13:01 ` [PULL 49/54] contrib/gitdm: add WANG Xuerui to individual contributers Alex Bennée
2022-10-04 13:01 ` [PULL 50/54] contrib/gitdm: add ISCAS to the academics group Alex Bennée
2022-10-04 13:01 ` [PULL 51/54] contrib/gitdm: add China Telecom to the domain map Alex Bennée
2022-10-04 13:01 ` [PULL 52/54] contrib/gitdm: add Simon to individual contributors Alex Bennée
2022-10-04 16:06 ` Simon Safar via
2022-10-04 13:01 ` [PULL 53/54] contrib/gitdm: add Université Grenoble Alpes Alex Bennée
2022-10-04 13:01 ` [PULL 54/54] plugins: add [pre|post]fork helpers to linux-user Alex Bennée
2022-10-05 14:16 ` [PULL 00/54] testing, gdbstub, plugin and gitdm updates Stefan Hajnoczi
2022-10-05 15:23 ` Alex Bennée
2022-10-05 23:17 ` Paolo Bonzini
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=Yz87fr2/PLMdX6wK@fedora \
--to=stefanha@redhat.com \
--cc=alex.bennee@linaro.org \
--cc=pbonzini@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).