build: try both native and cross compilers
Configure is trying to fall back on cross compilers for targets that can have bi-arch or bi-endian toolchains, but there are many corner cases where just checking the name can go wrong. For example, the RHEL ppc64le compiler is bi-arch and bi-endian, but multilibs are disabled. Therefore it cannot be used to build 32-bit hosted binaries like the linux-user TCG tests. Trying the cross compiler first also does not work, and an example for this is also ppc64le. The powerpc64-linux-gnu-gcc binary from the cross-gcc package is theoretically multilib-friendly, but it cannot find the CRT files on a ppc64le host, because they are not in the .../le multilib subdirectory. This can be fixed by testing both the native compiler and the cross compiler, and proceeding with the first one that works. To do this, move the compiler usability check from the tests/tcg snippet to inside probe_target_compiler and, while at it, restrict the softmmu emulation target to basically a test for the presence of libgcc. Tested-by: Matheus Kowalczuk Ferst <matheus.ferst@eldorado.org.br> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
parent
52f08deaf8
commit
92e288fcfb
133
configure
vendored
133
configure
vendored
@ -1868,6 +1868,7 @@ fi
|
||||
: ${cross_cc_cflags_x86_64="-m64"}
|
||||
|
||||
compute_target_variable() {
|
||||
eval "$2="
|
||||
if eval test -n "\"\${cross_prefix_$1}\""; then
|
||||
if eval has "\"\${cross_prefix_$1}\$3\""; then
|
||||
eval "$2=\"\${cross_prefix_$1}\$3\""
|
||||
@ -1888,6 +1889,7 @@ compute_target_variable() {
|
||||
#
|
||||
probe_target_compiler() {
|
||||
# reset all output variables
|
||||
got_cross_cc=no
|
||||
container_image=
|
||||
container_hosts=
|
||||
container_cross_cc=
|
||||
@ -1898,14 +1900,6 @@ probe_target_compiler() {
|
||||
container_cross_objcopy=
|
||||
container_cross_ranlib=
|
||||
container_cross_strip=
|
||||
target_cc=
|
||||
target_ar=
|
||||
target_as=
|
||||
target_ld=
|
||||
target_nm=
|
||||
target_objcopy=
|
||||
target_ranlib=
|
||||
target_strip=
|
||||
|
||||
target_arch=${1%%-*}
|
||||
case $target_arch in
|
||||
@ -2053,7 +2047,34 @@ probe_target_compiler() {
|
||||
: ${container_cross_strip:=${container_cross_prefix}strip}
|
||||
done
|
||||
|
||||
local t try
|
||||
try=cross
|
||||
case "$target_arch:$cpu" in
|
||||
aarch64_be:aarch64 | \
|
||||
armeb:arm | \
|
||||
i386:x86_64 | \
|
||||
mips*:mips64 | \
|
||||
ppc*:ppc64 | \
|
||||
sparc:sparc64 | \
|
||||
"$cpu:$cpu")
|
||||
try='native cross' ;;
|
||||
esac
|
||||
eval "target_cflags=\${cross_cc_cflags_$target_arch}"
|
||||
for t in $try; do
|
||||
case $t in
|
||||
native)
|
||||
target_cc=$cc
|
||||
target_ccas=$ccas
|
||||
target_ar=$ar
|
||||
target_as=$as
|
||||
target_ld=$ld
|
||||
target_nm=$nm
|
||||
target_objcopy=$objcopy
|
||||
target_ranlib=$ranlib
|
||||
target_strip=$strip
|
||||
;;
|
||||
cross)
|
||||
target_cc=
|
||||
if eval test -n "\"\${cross_cc_$target_arch}\""; then
|
||||
if eval has "\"\${cross_cc_$target_arch}\""; then
|
||||
eval "target_cc=\"\${cross_cc_$target_arch}\""
|
||||
@ -2069,35 +2090,68 @@ probe_target_compiler() {
|
||||
compute_target_variable $target_arch target_objcopy objcopy
|
||||
compute_target_variable $target_arch target_ranlib ranlib
|
||||
compute_target_variable $target_arch target_strip strip
|
||||
case "$target_arch:$cpu" in
|
||||
aarch64_be:aarch64 | \
|
||||
armeb:arm | \
|
||||
i386:x86_64 | \
|
||||
mips*:mips64 | \
|
||||
ppc*:ppc64 | \
|
||||
sparc:sparc64 | \
|
||||
"$cpu:$cpu")
|
||||
: ${target_cc:=$cc}
|
||||
: ${target_ccas:=$ccas}
|
||||
: ${target_as:=$as}
|
||||
: ${target_ld:=$ld}
|
||||
: ${target_ar:=$ar}
|
||||
: ${target_as:=$as}
|
||||
: ${target_ld:=$ld}
|
||||
: ${target_nm:=$nm}
|
||||
: ${target_objcopy:=$objcopy}
|
||||
: ${target_ranlib:=$ranlib}
|
||||
: ${target_strip:=$strip}
|
||||
;;
|
||||
esac
|
||||
|
||||
if test -n "$target_cc"; then
|
||||
case $target_arch in
|
||||
i386|x86_64)
|
||||
if $target_cc --version | grep -qi "clang"; then
|
||||
unset target_cc
|
||||
continue
|
||||
fi
|
||||
;;
|
||||
esac
|
||||
elif test -n "$target_as" && test -n "$target_ld"; then
|
||||
# Special handling for assembler only targets
|
||||
case $target in
|
||||
tricore-softmmu)
|
||||
build_static=
|
||||
got_cross_cc=yes
|
||||
break
|
||||
;;
|
||||
*)
|
||||
continue
|
||||
;;
|
||||
esac
|
||||
else
|
||||
continue
|
||||
fi
|
||||
|
||||
write_c_skeleton
|
||||
case $1 in
|
||||
*-softmmu)
|
||||
if do_compiler "$target_cc" $target_cflags -o $TMPO -c $TMPC &&
|
||||
do_compiler "$target_cc" $target_cflags -r -nostdlib -o "${TMPDIR1}/${TMPB}2.o" "$TMPO" -lgcc; then
|
||||
got_cross_cc=yes
|
||||
break
|
||||
fi
|
||||
;;
|
||||
*)
|
||||
if do_compiler "$target_cc" $target_cflags -o $TMPE $TMPC -static ; then
|
||||
build_static=y
|
||||
got_cross_cc=yes
|
||||
break
|
||||
fi
|
||||
if do_compiler "$target_cc" $target_cflags -o $TMPE $TMPC ; then
|
||||
build_static=
|
||||
got_cross_cc=yes
|
||||
break
|
||||
fi
|
||||
;;
|
||||
esac
|
||||
done
|
||||
if test $got_cross_cc != yes; then
|
||||
build_static=
|
||||
target_cc=
|
||||
target_ccas=
|
||||
target_cflags=
|
||||
target_ar=
|
||||
target_as=
|
||||
target_ld=
|
||||
target_nm=
|
||||
target_objcopy=
|
||||
target_ranlib=
|
||||
target_strip=
|
||||
fi
|
||||
}
|
||||
|
||||
@ -2519,29 +2573,6 @@ for target in $target_list; do
|
||||
esac
|
||||
|
||||
probe_target_compiler $target
|
||||
got_cross_cc=no
|
||||
unset build_static
|
||||
|
||||
if test -n "$target_cc"; then
|
||||
write_c_skeleton
|
||||
if ! do_compiler "$target_cc" $target_cflags \
|
||||
-o $TMPE $TMPC -static ; then
|
||||
# For host systems we might get away with building without -static
|
||||
if do_compiler "$target_cc" $target_cflags \
|
||||
-o $TMPE $TMPC ; then
|
||||
got_cross_cc=yes
|
||||
fi
|
||||
else
|
||||
got_cross_cc=yes
|
||||
build_static=y
|
||||
fi
|
||||
elif test -n "$target_as" && test -n "$target_ld"; then
|
||||
# Special handling for assembler only tests
|
||||
case $target in
|
||||
tricore-softmmu) got_cross_cc=yes ;;
|
||||
esac
|
||||
fi
|
||||
|
||||
if test $got_cross_cc = yes; then
|
||||
# Test for compiler features for optional tests. We only do this
|
||||
# for cross compilers because ensuring the docker containers based
|
||||
|
Loading…
Reference in New Issue
Block a user