configure: add support for --cross-cc-FOO

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. This is quoted to handle the case
of --cc="ccache gcc".

Signed-off-by: Alex Bennée <alex.bennee@linaro.org>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
This commit is contained in:
Alex Bennée 2018-04-04 20:27:05 +01:00
parent 7a5d936b6f
commit d75402b5ee

91
configure vendored
View File

@ -458,6 +458,13 @@ vxhs=""
libxml2="" libxml2=""
docker="no" 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_cpu="no"
supported_os="no" supported_os="no"
bogus_os="no" bogus_os="no"
@ -488,6 +495,11 @@ for opt do
;; ;;
--disable-debug-info) debug_info="no" --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 esac
done done
# OS specific # OS specific
@ -676,30 +688,37 @@ case "$cpu" in
ppc|ppc64|s390|s390x|sparc64|x32) ppc|ppc64|s390|s390x|sparc64|x32)
cpu="$cpu" cpu="$cpu"
supported_cpu="yes" supported_cpu="yes"
eval "cross_cc_${cpu}=\$host_cc"
;; ;;
i386|i486|i586|i686|i86pc|BePC) i386|i486|i586|i686|i86pc|BePC)
cpu="i386" cpu="i386"
supported_cpu="yes" supported_cpu="yes"
cross_cc_i386=$host_cc
;; ;;
x86_64|amd64) x86_64|amd64)
cpu="x86_64" cpu="x86_64"
supported_cpu="yes" supported_cpu="yes"
cross_cc_x86_64=$host_cc
;; ;;
armv*b|armv*l|arm) armv*b|armv*l|arm)
cpu="arm" cpu="arm"
supported_cpu="yes" supported_cpu="yes"
cross_cc_arm=$host_cc
;; ;;
aarch64) aarch64)
cpu="aarch64" cpu="aarch64"
supported_cpu="yes" supported_cpu="yes"
cross_cc_aarch64=$host_cc
;; ;;
mips*) mips*)
cpu="mips" cpu="mips"
supported_cpu="yes" supported_cpu="yes"
cross_cc_mips=$host_cc
;; ;;
sparc|sun4[cdmuv]) sparc|sun4[cdmuv])
cpu="sparc" cpu="sparc"
supported_cpu="yes" supported_cpu="yes"
cross_cc_sparc=$host_cc
;; ;;
*) *)
# This will result in either an error or falling back to TCI later # This will result in either an error or falling back to TCI later
@ -917,6 +936,8 @@ for opt do
;; ;;
--disable-debug-info) --disable-debug-info)
;; ;;
--cross-cc-*)
;;
--enable-modules) --enable-modules)
modules="yes" modules="yes"
;; ;;
@ -1501,6 +1522,7 @@ Advanced options (experts only):
--extra-cflags=CFLAGS append extra C compiler flags QEMU_CFLAGS --extra-cflags=CFLAGS append extra C compiler flags QEMU_CFLAGS
--extra-cxxflags=CXXFLAGS append extra C++ compiler flags QEMU_CXXFLAGS --extra-cxxflags=CXXFLAGS append extra C++ compiler flags QEMU_CXXFLAGS
--extra-ldflags=LDFLAGS append extra linker flags LDFLAGS --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] --make=MAKE use specified make [$make]
--install=INSTALL use specified install [$install] --install=INSTALL use specified install [$install]
--python=PYTHON use specified python [$python] --python=PYTHON use specified python [$python]
@ -6821,6 +6843,9 @@ case "$target" in
;; ;;
esac esac
target_compiler=""
target_compiler_static=""
mkdir -p $target_dir mkdir -p $target_dir
echo "# Automatically generated by configure - do not modify" > $config_target_mak echo "# Automatically generated by configure - do not modify" > $config_target_mak
@ -6836,19 +6861,23 @@ TARGET_ABI_DIR=""
case "$target_name" in case "$target_name" in
i386) i386)
gdb_xml_files="i386-32bit.xml i386-32bit-core.xml i386-32bit-sse.xml" gdb_xml_files="i386-32bit.xml i386-32bit-core.xml i386-32bit-sse.xml"
target_compiler=$cross_cc_i386
;; ;;
x86_64) x86_64)
TARGET_BASE_ARCH=i386 TARGET_BASE_ARCH=i386
gdb_xml_files="i386-64bit.xml i386-64bit-core.xml i386-64bit-sse.xml" gdb_xml_files="i386-64bit.xml i386-64bit-core.xml i386-64bit-sse.xml"
target_compiler=$cross_cc_x86_64
;; ;;
alpha) alpha)
mttcg="yes" mttcg="yes"
target_compiler=$cross_cc_alpha
;; ;;
arm|armeb) arm|armeb)
TARGET_ARCH=arm TARGET_ARCH=arm
bflt="yes" bflt="yes"
mttcg="yes" mttcg="yes"
gdb_xml_files="arm-core.xml arm-vfp.xml arm-vfp3.xml arm-neon.xml" gdb_xml_files="arm-core.xml arm-vfp.xml arm-vfp3.xml arm-neon.xml"
target_compiler=$cross_cc_arm
;; ;;
aarch64|aarch64_be) aarch64|aarch64_be)
TARGET_ARCH=aarch64 TARGET_ARCH=aarch64
@ -6856,59 +6885,74 @@ case "$target_name" in
bflt="yes" bflt="yes"
mttcg="yes" mttcg="yes"
gdb_xml_files="aarch64-core.xml aarch64-fpu.xml arm-core.xml arm-vfp.xml arm-vfp3.xml arm-neon.xml" 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) cris)
target_compiler=$cross_cc_cris
;; ;;
hppa) hppa)
mttcg="yes" mttcg="yes"
target_compiler=$cross_cc_hppa
;; ;;
lm32) lm32)
target_compiler=$cross_cc_lm32
;; ;;
m68k) m68k)
bflt="yes" bflt="yes"
gdb_xml_files="cf-core.xml cf-fp.xml m68k-fp.xml" gdb_xml_files="cf-core.xml cf-fp.xml m68k-fp.xml"
target_compiler=$cross_cc_m68k
;; ;;
microblaze|microblazeel) microblaze|microblazeel)
TARGET_ARCH=microblaze TARGET_ARCH=microblaze
bflt="yes" bflt="yes"
echo "TARGET_ABI32=y" >> $config_target_mak echo "TARGET_ABI32=y" >> $config_target_mak
target_compiler=$cross_cc_microblaze
;; ;;
mips|mipsel) mips|mipsel)
TARGET_ARCH=mips TARGET_ARCH=mips
target_compiler=$cross_cc_mips
echo "TARGET_ABI_MIPSO32=y" >> $config_target_mak echo "TARGET_ABI_MIPSO32=y" >> $config_target_mak
;; ;;
mipsn32|mipsn32el) mipsn32|mipsn32el)
TARGET_ARCH=mips64 TARGET_ARCH=mips64
TARGET_BASE_ARCH=mips TARGET_BASE_ARCH=mips
target_compiler=$cross_cc_mipsn32
echo "TARGET_ABI_MIPSN32=y" >> $config_target_mak echo "TARGET_ABI_MIPSN32=y" >> $config_target_mak
echo "TARGET_ABI32=y" >> $config_target_mak echo "TARGET_ABI32=y" >> $config_target_mak
;; ;;
mips64|mips64el) mips64|mips64el)
TARGET_ARCH=mips64 TARGET_ARCH=mips64
TARGET_BASE_ARCH=mips TARGET_BASE_ARCH=mips
target_compiler=$cross_cc_mips64
echo "TARGET_ABI_MIPSN64=y" >> $config_target_mak echo "TARGET_ABI_MIPSN64=y" >> $config_target_mak
;; ;;
moxie) moxie)
target_compiler=$cross_cc_moxie
;; ;;
nios2) nios2)
target_compiler=$cross_cc_nios2
;; ;;
or1k) or1k)
target_compiler=$cross_cc_or1k
TARGET_ARCH=openrisc TARGET_ARCH=openrisc
TARGET_BASE_ARCH=openrisc TARGET_BASE_ARCH=openrisc
;; ;;
ppc) ppc)
gdb_xml_files="power-core.xml power-fpu.xml power-altivec.xml power-spe.xml" gdb_xml_files="power-core.xml power-fpu.xml power-altivec.xml power-spe.xml"
target_compiler=$cross_cc_powerpc
;; ;;
ppcemb) ppcemb)
TARGET_BASE_ARCH=ppc TARGET_BASE_ARCH=ppc
TARGET_ABI_DIR=ppc TARGET_ABI_DIR=ppc
gdb_xml_files="power-core.xml power-fpu.xml power-altivec.xml power-spe.xml" gdb_xml_files="power-core.xml power-fpu.xml power-altivec.xml power-spe.xml"
target_compiler=$cross_cc_ppcemb
;; ;;
ppc64) ppc64)
TARGET_BASE_ARCH=ppc TARGET_BASE_ARCH=ppc
TARGET_ABI_DIR=ppc TARGET_ABI_DIR=ppc
mttcg=yes mttcg=yes
gdb_xml_files="power64-core.xml power-fpu.xml power-altivec.xml power-spe.xml power-vsx.xml" gdb_xml_files="power64-core.xml power-fpu.xml power-altivec.xml power-spe.xml power-vsx.xml"
target_compiler=$cross_cc_ppc64
;; ;;
ppc64le) ppc64le)
TARGET_ARCH=ppc64 TARGET_ARCH=ppc64
@ -6916,6 +6960,7 @@ case "$target_name" in
TARGET_ABI_DIR=ppc TARGET_ABI_DIR=ppc
mttcg=yes mttcg=yes
gdb_xml_files="power64-core.xml power-fpu.xml power-altivec.xml power-spe.xml power-vsx.xml" gdb_xml_files="power64-core.xml power-fpu.xml power-altivec.xml power-spe.xml power-vsx.xml"
target_compiler=$cross_cc_ppc64le
;; ;;
ppc64abi32) ppc64abi32)
TARGET_ARCH=ppc64 TARGET_ARCH=ppc64
@ -6923,45 +6968,57 @@ case "$target_name" in
TARGET_ABI_DIR=ppc TARGET_ABI_DIR=ppc
echo "TARGET_ABI32=y" >> $config_target_mak 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" gdb_xml_files="power64-core.xml power-fpu.xml power-altivec.xml power-spe.xml power-vsx.xml"
target_compiler=$cross_cc_ppc64abi32
;; ;;
riscv32) riscv32)
TARGET_BASE_ARCH=riscv TARGET_BASE_ARCH=riscv
TARGET_ABI_DIR=riscv TARGET_ABI_DIR=riscv
mttcg=yes mttcg=yes
target_compiler=$cross_cc_riscv32
;; ;;
riscv64) riscv64)
TARGET_BASE_ARCH=riscv TARGET_BASE_ARCH=riscv
TARGET_ABI_DIR=riscv TARGET_ABI_DIR=riscv
mttcg=yes mttcg=yes
target_compiler=$cross_cc_riscv64
;; ;;
sh4|sh4eb) sh4|sh4eb)
TARGET_ARCH=sh4 TARGET_ARCH=sh4
bflt="yes" bflt="yes"
target_compiler=$cross_cc_sh4
;; ;;
sparc) sparc)
target_compiler=$cross_cc_sparc
;; ;;
sparc64) sparc64)
TARGET_BASE_ARCH=sparc TARGET_BASE_ARCH=sparc
target_compiler=$cross_cc_sparc64
;; ;;
sparc32plus) sparc32plus)
TARGET_ARCH=sparc64 TARGET_ARCH=sparc64
TARGET_BASE_ARCH=sparc TARGET_BASE_ARCH=sparc
TARGET_ABI_DIR=sparc TARGET_ABI_DIR=sparc
target_compiler=$cross_cc_sparc32plus
echo "TARGET_ABI32=y" >> $config_target_mak echo "TARGET_ABI32=y" >> $config_target_mak
;; ;;
s390x) s390x)
mttcg=yes 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" 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) tilegx)
target_compiler=$cross_cc_tilegx
;; ;;
tricore) tricore)
target_compiler=$cross_cc_tricore
;; ;;
unicore32) unicore32)
target_compiler=$cross_cc_unicore32
;; ;;
xtensa|xtensaeb) xtensa|xtensaeb)
TARGET_ARCH=xtensa TARGET_ARCH=xtensa
mttcg="yes" mttcg="yes"
target_compiler=$cross_cc_xtensa
;; ;;
*) *)
error_exit "Unsupported target CPU" error_exit "Unsupported target CPU"
@ -6972,6 +7029,27 @@ if [ "$TARGET_BASE_ARCH" = "" ]; then
TARGET_BASE_ARCH=$TARGET_ARCH TARGET_BASE_ARCH=$TARGET_ARCH
fi 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" symlink "$source_path/Makefile.target" "$target_dir/Makefile"
upper() { upper() {
@ -7045,6 +7123,14 @@ if test "$target_bsd_user" = "yes" ; then
echo "CONFIG_BSD_USER=y" >> $config_target_mak echo "CONFIG_BSD_USER=y" >> $config_target_mak
fi 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 # generate QEMU_CFLAGS/LDFLAGS for targets
cflags="" cflags=""
@ -7167,6 +7253,11 @@ echo "QEMU_CFLAGS+=$cflags" >> $config_target_mak
done # for target in $targets done # for target in $targets
if test -n "$enabled_cross_compilers"; then
echo
echo "NOTE: cross-compilers enabled: $enabled_cross_compilers"
fi
if [ "$fdt" = "git" ]; then if [ "$fdt" = "git" ]; then
echo "config-host.h: subdir-dtc" >> $config_host_mak echo "config-host.h: subdir-dtc" >> $config_host_mak
fi fi