xref: /openbmc/qemu/configure (revision 002d8c13)
17d13299dSbellard#!/bin/sh
27d13299dSbellard#
33ef693a0Sbellard# qemu configure script (c) 2003 Fabrice Bellard
47d13299dSbellard#
58cd05ab6SPeter Maydell
699519e67SCornelia Huck# Unset some variables known to interfere with behavior of common tools,
799519e67SCornelia Huck# just as autoconf does.
899519e67SCornelia HuckCLICOLOR_FORCE= GREP_OPTIONS=
999519e67SCornelia Huckunset CLICOLOR_FORCE GREP_OPTIONS
1099519e67SCornelia Huck
115e4dfd3dSJohn Snow# Don't allow CCACHE, if present, to use cached results of compile tests!
125e4dfd3dSJohn Snowexport CCACHE_RECACHE=yes
135e4dfd3dSJohn Snow
14dedad027SDaniel P. Berrangé# make source path absolute
15dedad027SDaniel P. Berrangésource_path=$(cd "$(dirname -- "$0")"; pwd)
16dedad027SDaniel P. Berrangé
17dedad027SDaniel P. Berrangéif test "$PWD" = "$source_path"
18dedad027SDaniel P. Berrangéthen
19dedad027SDaniel P. Berrangé    echo "Using './build' as the directory for build output"
20dedad027SDaniel P. Berrangé
21dedad027SDaniel P. Berrangé    MARKER=build/auto-created-by-configure
22dedad027SDaniel P. Berrangé
23dedad027SDaniel P. Berrangé    if test -e build
24dedad027SDaniel P. Berrangé    then
25dedad027SDaniel P. Berrangé        if test -f $MARKER
26dedad027SDaniel P. Berrangé        then
27dedad027SDaniel P. Berrangé           rm -rf build
28dedad027SDaniel P. Berrangé        else
29dedad027SDaniel P. Berrangé            echo "ERROR: ./build dir already exists and was not previously created by configure"
30dedad027SDaniel P. Berrangé            exit 1
31dedad027SDaniel P. Berrangé        fi
32dedad027SDaniel P. Berrangé    fi
33dedad027SDaniel P. Berrangé
34dedad027SDaniel P. Berrangé    mkdir build
35dedad027SDaniel P. Berrangé    touch $MARKER
36dedad027SDaniel P. Berrangé
37dedad027SDaniel P. Berrangé    cat > GNUmakefile <<'EOF'
38dedad027SDaniel P. Berrangé# This file is auto-generated by configure to support in-source tree
39dedad027SDaniel P. Berrangé# 'make' command invocation
40dedad027SDaniel P. Berrangé
41dedad027SDaniel P. Berrangéifeq ($(MAKECMDGOALS),)
42dedad027SDaniel P. Berrangérecurse: all
43dedad027SDaniel P. Berrangéendif
44dedad027SDaniel P. Berrangé
45dedad027SDaniel P. Berrangé.NOTPARALLEL: %
46dedad027SDaniel P. Berrangé%: force
47dedad027SDaniel P. Berrangé	@echo 'changing dir to build for $(MAKE) "$(MAKECMDGOALS)"...'
48dedad027SDaniel P. Berrangé	@$(MAKE) -C build -f Makefile $(MAKECMDGOALS)
49dedad027SDaniel P. Berrangé	@if test "$(MAKECMDGOALS)" = "distclean" && \
50dedad027SDaniel P. Berrangé	    test -e build/auto-created-by-configure ; \
51dedad027SDaniel P. Berrangé	then \
52dedad027SDaniel P. Berrangé	    rm -rf build GNUmakefile ; \
53dedad027SDaniel P. Berrangé	fi
54dedad027SDaniel P. Berrangéforce: ;
55dedad027SDaniel P. Berrangé.PHONY: force
56dedad027SDaniel P. BerrangéGNUmakefile: ;
57dedad027SDaniel P. Berrangé
58dedad027SDaniel P. BerrangéEOF
59dedad027SDaniel P. Berrangé    cd build
6064708615SPeter Maydell    exec "$source_path/configure" "$@"
61dedad027SDaniel P. Berrangéfi
62dedad027SDaniel P. Berrangé
638cd05ab6SPeter Maydell# Temporary directory used for files created while
648cd05ab6SPeter Maydell# configure runs. Since it is in the build directory
658cd05ab6SPeter Maydell# we can safely blow away any previous version of it
668cd05ab6SPeter Maydell# (and we need not jump through hoops to try to delete
678cd05ab6SPeter Maydell# it when configure exits.)
688cd05ab6SPeter MaydellTMPDIR1="config-temp"
698cd05ab6SPeter Maydellrm -rf "${TMPDIR1}"
708cd05ab6SPeter Maydellmkdir -p "${TMPDIR1}"
718cd05ab6SPeter Maydellif [ $? -ne 0 ]; then
728cd05ab6SPeter Maydell    echo "ERROR: failed to create temporary directory"
738cd05ab6SPeter Maydell    exit 1
747d13299dSbellardfi
757d13299dSbellard
768cd05ab6SPeter MaydellTMPB="qemu-conf"
778cd05ab6SPeter MaydellTMPC="${TMPDIR1}/${TMPB}.c"
7866518bf6SDon SlutzTMPO="${TMPDIR1}/${TMPB}.o"
799c83ffd8SPeter MaydellTMPCXX="${TMPDIR1}/${TMPB}.cxx"
804cb37d11SPhilippe Mathieu-DaudéTMPM="${TMPDIR1}/${TMPB}.m"
818cd05ab6SPeter MaydellTMPE="${TMPDIR1}/${TMPB}.exe"
827d13299dSbellard
83da1d85e3SGerd Hoffmannrm -f config.log
849ac81bbbSmalc
85b48e3611SPeter Maydell# Print a helpful header at the top of config.log
86b48e3611SPeter Maydellecho "# QEMU configure log $(date)" >> config.log
87979ae168SPeter Maydellprintf "# Configured with:" >> config.log
88979ae168SPeter Maydellprintf " '%s'" "$0" "$@" >> config.log
89979ae168SPeter Maydellecho >> config.log
90b48e3611SPeter Maydellecho "#" >> config.log
91b48e3611SPeter Maydell
92835af899SPaolo Bonziniquote_sh() {
93835af899SPaolo Bonzini    printf "%s" "$1" | sed "s,','\\\\'',g; s,.*,'&',"
94835af899SPaolo Bonzini}
95835af899SPaolo Bonzini
96d880a3baSPaolo Bonziniprint_error() {
97d880a3baSPaolo Bonzini    (echo
9876ad07a4SPeter Maydell    echo "ERROR: $1"
9976ad07a4SPeter Maydell    while test -n "$2"; do
10076ad07a4SPeter Maydell        echo "       $2"
10176ad07a4SPeter Maydell        shift
10276ad07a4SPeter Maydell    done
103d880a3baSPaolo Bonzini    echo) >&2
104d880a3baSPaolo Bonzini}
105d880a3baSPaolo Bonzini
106d880a3baSPaolo Bonzinierror_exit() {
107d880a3baSPaolo Bonzini    print_error "$@"
10876ad07a4SPeter Maydell    exit 1
10976ad07a4SPeter Maydell}
11076ad07a4SPeter Maydell
1119c83ffd8SPeter Maydelldo_compiler() {
1129c83ffd8SPeter Maydell  # Run the compiler, capturing its output to the log. First argument
1139c83ffd8SPeter Maydell  # is compiler binary to execute.
114cd362defSPaolo Bonzini  local compiler="$1"
115cd362defSPaolo Bonzini  shift
116cd362defSPaolo Bonzini  if test -n "$BASH_VERSION"; then eval '
117cd362defSPaolo Bonzini      echo >>config.log "
118cd362defSPaolo Bonzinifuncs: ${FUNCNAME[*]}
119cd362defSPaolo Bonzinilines: ${BASH_LINENO[*]}"
120cd362defSPaolo Bonzini  '; fi
121cd362defSPaolo Bonzini  echo $compiler "$@" >> config.log
122cd362defSPaolo Bonzini  $compiler "$@" >> config.log 2>&1 || return $?
123cd362defSPaolo Bonzini}
124cd362defSPaolo Bonzini
125cd362defSPaolo Bonzinido_compiler_werror() {
126cd362defSPaolo Bonzini    # Run the compiler, capturing its output to the log. First argument
127cd362defSPaolo Bonzini    # is compiler binary to execute.
128630d86b7SDavid CARLIER    compiler="$1"
1299c83ffd8SPeter Maydell    shift
1308bbe05d7SIan Jackson    if test -n "$BASH_VERSION"; then eval '
1318bbe05d7SIan Jackson        echo >>config.log "
1328bbe05d7SIan Jacksonfuncs: ${FUNCNAME[*]}
1338bbe05d7SIan Jacksonlines: ${BASH_LINENO[*]}"
1348bbe05d7SIan Jackson    '; fi
1359c83ffd8SPeter Maydell    echo $compiler "$@" >> config.log
1369c83ffd8SPeter Maydell    $compiler "$@" >> config.log 2>&1 || return $?
1378dc38a78SPeter Maydell    # Test passed. If this is an --enable-werror build, rerun
1388dc38a78SPeter Maydell    # the test with -Werror and bail out if it fails. This
1398dc38a78SPeter Maydell    # makes warning-generating-errors in configure test code
1408dc38a78SPeter Maydell    # obvious to developers.
1418dc38a78SPeter Maydell    if test "$werror" != "yes"; then
1428dc38a78SPeter Maydell        return 0
1438dc38a78SPeter Maydell    fi
1448dc38a78SPeter Maydell    # Don't bother rerunning the compile if we were already using -Werror
1458dc38a78SPeter Maydell    case "$*" in
1468dc38a78SPeter Maydell        *-Werror*)
1478dc38a78SPeter Maydell           return 0
1488dc38a78SPeter Maydell        ;;
1498dc38a78SPeter Maydell    esac
1509c83ffd8SPeter Maydell    echo $compiler -Werror "$@" >> config.log
1519c83ffd8SPeter Maydell    $compiler -Werror "$@" >> config.log 2>&1 && return $?
15276ad07a4SPeter Maydell    error_exit "configure test passed without -Werror but failed with -Werror." \
15376ad07a4SPeter Maydell        "This is probably a bug in the configure script. The failing command" \
15476ad07a4SPeter Maydell        "will be at the bottom of config.log." \
15576ad07a4SPeter Maydell        "You can run configure with --disable-werror to bypass this check."
1568dc38a78SPeter Maydell}
1578dc38a78SPeter Maydell
1589c83ffd8SPeter Maydelldo_cc() {
159cd362defSPaolo Bonzini    do_compiler_werror "$cc" $CPU_CFLAGS "$@"
1609c83ffd8SPeter Maydell}
1619c83ffd8SPeter Maydell
1629c83ffd8SPeter Maydelldo_cxx() {
163cd362defSPaolo Bonzini    do_compiler_werror "$cxx" $CPU_CFLAGS "$@"
1649c83ffd8SPeter Maydell}
1659c83ffd8SPeter Maydell
1664cb37d11SPhilippe Mathieu-Daudédo_objc() {
167cd362defSPaolo Bonzini    do_compiler_werror "$objcc" $CPU_CFLAGS "$@"
1684cb37d11SPhilippe Mathieu-Daudé}
1694cb37d11SPhilippe Mathieu-Daudé
17000849b92SRichard Henderson# Append $2 to the variable named $1, with space separation
17100849b92SRichard Hendersonadd_to() {
17200849b92SRichard Henderson    eval $1=\${$1:+\"\$$1 \"}\$2
17300849b92SRichard Henderson}
17400849b92SRichard Henderson
1759c83ffd8SPeter Maydellupdate_cxxflags() {
1769c83ffd8SPeter Maydell    # Set QEMU_CXXFLAGS from QEMU_CFLAGS by filtering out those
1779c83ffd8SPeter Maydell    # options which some versions of GCC's C++ compiler complain about
1789c83ffd8SPeter Maydell    # because they only make sense for C programs.
179de38c0ccSPaolo Bonzini    QEMU_CXXFLAGS="-D__STDC_LIMIT_MACROS -D__STDC_CONSTANT_MACROS -D__STDC_FORMAT_MACROS"
1808a9d3d56SRichard Henderson    CONFIGURE_CXXFLAGS=$(echo "$CONFIGURE_CFLAGS" | sed s/-std=gnu11/-std=gnu++11/)
1819c83ffd8SPeter Maydell    for arg in $QEMU_CFLAGS; do
1829c83ffd8SPeter Maydell        case $arg in
1839c83ffd8SPeter Maydell            -Wstrict-prototypes|-Wmissing-prototypes|-Wnested-externs|\
1849c83ffd8SPeter Maydell            -Wold-style-declaration|-Wold-style-definition|-Wredundant-decls)
1859c83ffd8SPeter Maydell                ;;
1869c83ffd8SPeter Maydell            *)
1879c83ffd8SPeter Maydell                QEMU_CXXFLAGS=${QEMU_CXXFLAGS:+$QEMU_CXXFLAGS }$arg
1889c83ffd8SPeter Maydell                ;;
1899c83ffd8SPeter Maydell        esac
1909c83ffd8SPeter Maydell    done
1919c83ffd8SPeter Maydell}
1929c83ffd8SPeter Maydell
19352166aa0SJuan Quintelacompile_object() {
194fd0e6053SJohn Snow  local_cflags="$1"
195a2866660SPaolo Bonzini  do_cc $CFLAGS $EXTRA_CFLAGS $CONFIGURE_CFLAGS $QEMU_CFLAGS $local_cflags -c -o $TMPO $TMPC
19652166aa0SJuan Quintela}
19752166aa0SJuan Quintela
19852166aa0SJuan Quintelacompile_prog() {
19952166aa0SJuan Quintela  local_cflags="$1"
20052166aa0SJuan Quintela  local_ldflags="$2"
201a2866660SPaolo Bonzini  do_cc $CFLAGS $EXTRA_CFLAGS $CONFIGURE_CFLAGS $QEMU_CFLAGS $local_cflags -o $TMPE $TMPC \
202a2866660SPaolo Bonzini      $LDFLAGS $EXTRA_LDFLAGS $CONFIGURE_LDFLAGS $QEMU_LDFLAGS $local_ldflags
20352166aa0SJuan Quintela}
20452166aa0SJuan Quintela
20511568d6dSPaolo Bonzini# symbolically link $1 to $2.  Portable version of "ln -sf".
20611568d6dSPaolo Bonzinisymlink() {
20772b8b5a1SStefan Weil  rm -rf "$2"
208ec5b06d7SAnthony Liguori  mkdir -p "$(dirname "$2")"
20972b8b5a1SStefan Weil  ln -s "$1" "$2"
21011568d6dSPaolo Bonzini}
21111568d6dSPaolo Bonzini
2120dba6195SLoïc Minier# check whether a command is available to this shell (may be either an
2130dba6195SLoïc Minier# executable or a builtin)
2140dba6195SLoïc Minierhas() {
2150dba6195SLoïc Minier    type "$1" >/dev/null 2>&1
2160dba6195SLoïc Minier}
2170dba6195SLoïc Minier
2180a01d76fSMarc-André Lureauversion_ge () {
2192df52b9bSAlex Bennée    local_ver1=$(expr "$1" : '\([0-9.]*\)' | tr . ' ')
2202df52b9bSAlex Bennée    local_ver2=$(echo "$2" | tr . ' ')
2210a01d76fSMarc-André Lureau    while true; do
2220a01d76fSMarc-André Lureau        set x $local_ver1
2230a01d76fSMarc-André Lureau        local_first=${2-0}
224c44a33e2SStefano Garzarella        # 'shift 2' if $2 is set, or 'shift' if $2 is not set
225c44a33e2SStefano Garzarella        shift ${2:+2}
2260a01d76fSMarc-André Lureau        local_ver1=$*
2270a01d76fSMarc-André Lureau        set x $local_ver2
2280a01d76fSMarc-André Lureau        # the second argument finished, the first must be greater or equal
2290a01d76fSMarc-André Lureau        test $# = 1 && return 0
2300a01d76fSMarc-André Lureau        test $local_first -lt $2 && return 1
2310a01d76fSMarc-André Lureau        test $local_first -gt $2 && return 0
232c44a33e2SStefano Garzarella        shift ${2:+2}
2330a01d76fSMarc-André Lureau        local_ver2=$*
2340a01d76fSMarc-André Lureau    done
2350a01d76fSMarc-André Lureau}
2360a01d76fSMarc-André Lureau
2373b6b7550SPaolo Bonziniglob() {
2383b6b7550SPaolo Bonzini    eval test -z '"${1#'"$2"'}"'
2393b6b7550SPaolo Bonzini}
2403b6b7550SPaolo Bonzini
2414ace32e2SAntonio Ospiteif printf %s\\n "$source_path" "$PWD" | grep -q "[[:space:]:]";
2424ace32e2SAntonio Ospitethen
2434ace32e2SAntonio Ospite  error_exit "main directory cannot contain spaces nor colons"
2444ace32e2SAntonio Ospitefi
2454ace32e2SAntonio Ospite
24614211825SAntonio Ospite# default parameters
2472ff6b91eSJuan Quintelacpu=""
24843ce4dfeSbellardstatic="no"
2493812c0c4SJoelle van Dynecross_compile="no"
2507d13299dSbellardcross_prefix=""
251e49d021eSPeter Maydellhost_cc="cc"
25263678e17SSteven Noonanstack_protector=""
2531e4f6065SDaniele Buonosafe_stack=""
254afc3a8f9SAlex Bennéeuse_containers="yes"
255f2385398SAlex Bennéegdb_bin=$(command -v "gdb-multiarch" || command -v "gdb")
256ac0df51dSaliguori
25792712822SDaniel P. Berrangeif test -e "$source_path/.git"
25892712822SDaniel P. Berrangethen
2597d7dbf9dSDan Streetman    git_submodules_action="update"
26092712822SDaniel P. Berrangeelse
2617d7dbf9dSDan Streetman    git_submodules_action="ignore"
26292712822SDaniel P. Berrangefi
2632d652f24SPaolo Bonzini
2642d652f24SPaolo Bonzinigit_submodules="ui/keycodemapdb"
265cc84d63aSDaniel P. Berrangegit="git"
266ac0df51dSaliguori
267afb63ebdSStefan Weil# Don't accept a target_list environment variable.
268afb63ebdSStefan Weilunset target_list
269447e133fSAlex Bennéeunset target_list_exclude
270377529c0SPaolo Bonzini
271377529c0SPaolo Bonzini# Default value for a variable defining feature "foo".
272377529c0SPaolo Bonzini#  * foo="no"  feature will only be used if --enable-foo arg is given
273377529c0SPaolo Bonzini#  * foo=""    feature will be searched for, and if found, will be used
274377529c0SPaolo Bonzini#              unless --disable-foo is given
275377529c0SPaolo Bonzini#  * foo="yes" this value will only be set by --enable-foo flag.
276377529c0SPaolo Bonzini#              feature will searched for,
277377529c0SPaolo Bonzini#              if not found, configure exits with error
278377529c0SPaolo Bonzini#
279377529c0SPaolo Bonzini# Always add --enable-foo and --disable-foo command line args.
280377529c0SPaolo Bonzini# Distributions want to ensure that several features are compiled in, and it
281377529c0SPaolo Bonzini# is impossible without a --enable-foo that exits if a feature is not found.
282377529c0SPaolo Bonzini
283c87ea116SAlex Bennéedefault_feature=""
284c87ea116SAlex Bennée# parse CC options second
285c87ea116SAlex Bennéefor opt do
286c87ea116SAlex Bennée  optarg=$(expr "x$opt" : 'x[^=]*=\(.*\)')
287c87ea116SAlex Bennée  case "$opt" in
288c87ea116SAlex Bennée      --without-default-features)
289c87ea116SAlex Bennée          default_feature="no"
290c87ea116SAlex Bennée  ;;
291c87ea116SAlex Bennée  esac
292c87ea116SAlex Bennéedone
293c87ea116SAlex Bennée
294a2866660SPaolo BonziniEXTRA_CFLAGS=""
295a2866660SPaolo BonziniEXTRA_CXXFLAGS=""
296e910c7d9SPhilippe Mathieu-DaudéEXTRA_OBJCFLAGS=""
297a2866660SPaolo BonziniEXTRA_LDFLAGS=""
298a2866660SPaolo Bonzini
299377529c0SPaolo Bonzinidebug_tcg="no"
300247724cbSMarc-André Lureausanitizers="no"
3010aebab04SLingfeng Yangtsan="no"
3021f3f2bfeSMichael Tokarevfortify_source="yes"
303c7328271SMiroslav RezaninaEXESUF=""
30417969268SFam Zhengmodules="no"
305377529c0SPaolo Bonziniprefix="/usr/local"
30610ff82d1SMarc-André Lureauqemu_suffix="qemu"
307377529c0SPaolo Bonzinisoftmmu="yes"
308b915a2f1SPaolo Bonzinilinux_user=""
309b915a2f1SPaolo Bonzinibsd_user=""
31040d6444eSAvi Kivitypie=""
311519175a2SAlex Barcelocoroutine=""
312ba4dd2aaSAlex Bennéeplugins="$default_feature"
313a5665051SPaolo Bonzinimeson=""
31448328880SPaolo Bonzinininja=""
315c09c1ce7SPaolo Bonzinibindir="bin"
316a5665051SPaolo Bonziniskip_meson=no
31755116968SJagannathan Ramanvfio_user_server="disabled"
318377529c0SPaolo Bonzini
3193b4da132SPaolo Bonzini# The following Meson options are handled manually (still they
3203b4da132SPaolo Bonzini# are included in the automatically generated help message)
3213b4da132SPaolo Bonzini
3223b4da132SPaolo Bonzini# 1. Track which submodules are needed
3230577e84dSThomas Huthif test "$default_feature" = no ; then
3240577e84dSThomas Huth  slirp="disabled"
3250577e84dSThomas Huthelse
3263b4da132SPaolo Bonzini  slirp="auto"
3270577e84dSThomas Huthfi
3280577e84dSThomas Huthfdt="auto"
3293b4da132SPaolo Bonzini
330c54b59eeSPaolo Bonzini# 2. Automatically enable/disable other options
3317630156dSPhilippe Mathieu-Daudétcg="auto"
3323b4da132SPaolo Bonzinicfi="false"
3333b4da132SPaolo Bonzini
334c87ea116SAlex Bennée# parse CC options second
335ac0df51dSaliguorifor opt do
33689138857SStefan Weil  optarg=$(expr "x$opt" : 'x[^=]*=\(.*\)')
337ac0df51dSaliguori  case "$opt" in
338ac0df51dSaliguori  --cross-prefix=*) cross_prefix="$optarg"
3393812c0c4SJoelle van Dyne                    cross_compile="yes"
340ac0df51dSaliguori  ;;
3413d8df640SPaolo Bonzini  --cc=*) CC="$optarg"
342ac0df51dSaliguori  ;;
34383f73fceSTomoki Sekiyama  --cxx=*) CXX="$optarg"
34483f73fceSTomoki Sekiyama  ;;
3452ff6b91eSJuan Quintela  --cpu=*) cpu="$optarg"
3462ff6b91eSJuan Quintela  ;;
347a2866660SPaolo Bonzini  --extra-cflags=*)
348a2866660SPaolo Bonzini    EXTRA_CFLAGS="$EXTRA_CFLAGS $optarg"
349a2866660SPaolo Bonzini    EXTRA_CXXFLAGS="$EXTRA_CXXFLAGS $optarg"
350e910c7d9SPhilippe Mathieu-Daudé    EXTRA_OBJCFLAGS="$EXTRA_OBJCFLAGS $optarg"
351e2a2ed06SJuan Quintela    ;;
352a2866660SPaolo Bonzini  --extra-cxxflags=*) EXTRA_CXXFLAGS="$EXTRA_CXXFLAGS $optarg"
35311cde1c8SBruno Dominguez  ;;
354e910c7d9SPhilippe Mathieu-Daudé  --extra-objcflags=*) EXTRA_OBJCFLAGS="$EXTRA_OBJCFLAGS $optarg"
355e910c7d9SPhilippe Mathieu-Daudé  ;;
356a2866660SPaolo Bonzini  --extra-ldflags=*) EXTRA_LDFLAGS="$EXTRA_LDFLAGS $optarg"
357e2a2ed06SJuan Quintela  ;;
358d75402b5SAlex Bennée  --cross-cc-*[!a-zA-Z0-9_-]*=*) error_exit "Passed bad --cross-cc-FOO option"
359d75402b5SAlex Bennée  ;;
360479ca4ccSMatheus Ferst  --cross-cc-cflags-*) cc_arch=${opt#--cross-cc-cflags-}; cc_arch=${cc_arch%%=*}
361d422b2bcSAlex Bennée                      eval "cross_cc_cflags_${cc_arch}=\$optarg"
362d422b2bcSAlex Bennée  ;;
363d75402b5SAlex Bennée  --cross-cc-*) cc_arch=${opt#--cross-cc-}; cc_arch=${cc_arch%%=*}
364d75402b5SAlex Bennée                eval "cross_cc_${cc_arch}=\$optarg"
365d75402b5SAlex Bennée  ;;
3665adb43beSPaolo Bonzini  --cross-prefix-*[!a-zA-Z0-9_-]*=*) error_exit "Passed bad --cross-prefix-FOO option"
3675adb43beSPaolo Bonzini  ;;
3685adb43beSPaolo Bonzini  --cross-prefix-*) cc_arch=${opt#--cross-prefix-}; cc_arch=${cc_arch%%=*}
3695adb43beSPaolo Bonzini                    eval "cross_prefix_${cc_arch}=\$optarg"
3705adb43beSPaolo Bonzini  ;;
371ac0df51dSaliguori  esac
372ac0df51dSaliguoridone
373ac0df51dSaliguori# OS specific
374ac0df51dSaliguori# Using uname is really, really broken.  Once we have the right set of checks
37593148aa5SStefan Weil# we can eliminate its usage altogether.
376ac0df51dSaliguori
377e49d021eSPeter Maydell# Preferred compiler:
378e49d021eSPeter Maydell#  ${CC} (if set)
379e49d021eSPeter Maydell#  ${cross_prefix}gcc (if cross-prefix specified)
380e49d021eSPeter Maydell#  system compiler
381e49d021eSPeter Maydellif test -z "${CC}${cross_prefix}"; then
382e49d021eSPeter Maydell  cc="$host_cc"
383e49d021eSPeter Maydellelse
384b3198cc2SStuart Yoder  cc="${CC-${cross_prefix}gcc}"
385e49d021eSPeter Maydellfi
386e49d021eSPeter Maydell
38783f73fceSTomoki Sekiyamaif test -z "${CXX}${cross_prefix}"; then
38883f73fceSTomoki Sekiyama  cxx="c++"
38983f73fceSTomoki Sekiyamaelse
39083f73fceSTomoki Sekiyama  cxx="${CXX-${cross_prefix}g++}"
39183f73fceSTomoki Sekiyamafi
39283f73fceSTomoki Sekiyama
393b3198cc2SStuart Yoderar="${AR-${cross_prefix}ar}"
394cdbd727cSRichard Hendersonas="${AS-${cross_prefix}as}"
3955f6f0e27SRichard Hendersonccas="${CCAS-$cc}"
396b3198cc2SStuart Yoderobjcopy="${OBJCOPY-${cross_prefix}objcopy}"
397b3198cc2SStuart Yoderld="${LD-${cross_prefix}ld}"
3989f81aeb5SAlistair Francisranlib="${RANLIB-${cross_prefix}ranlib}"
3994852ee95SStefan Weilnm="${NM-${cross_prefix}nm}"
40035acbb30SPaolo Bonzinismbd="$SMBD"
401b3198cc2SStuart Yoderstrip="${STRIP-${cross_prefix}strip}"
402158bb224SKonstantin Kostiukwidl="${WIDL-${cross_prefix}widl}"
403b3198cc2SStuart Yoderwindres="${WINDRES-${cross_prefix}windres}"
40417884d7bSSergei Trofimovichpkg_config_exe="${PKG_CONFIG-${cross_prefix}pkg-config}"
40517884d7bSSergei Trofimovichquery_pkg_config() {
40617884d7bSSergei Trofimovich    "${pkg_config_exe}" ${QEMU_PKG_CONFIG_FLAGS} "$@"
40717884d7bSSergei Trofimovich}
40817884d7bSSergei Trofimovichpkg_config=query_pkg_config
40947c03744SDave Airliesdl2_config="${SDL2_CONFIG-${cross_prefix}sdl2-config}"
410ac0df51dSaliguori
411be17dc90SMichael S. Tsirkin# default flags for all hosts
4122d31515bSPeter Maydell# We use -fwrapv to tell the compiler that we require a C dialect where
4132d31515bSPeter Maydell# left shift of signed integers is well defined and has the expected
4142d31515bSPeter Maydell# 2s-complement style results. (Both clang and gcc agree that it
4152d31515bSPeter Maydell# provides these semantics.)
416de38c0ccSPaolo BonziniQEMU_CFLAGS="-fno-strict-aliasing -fno-common -fwrapv"
417086d5f75SPaolo BonziniQEMU_CFLAGS="-Wundef -Wwrite-strings -Wmissing-prototypes $QEMU_CFLAGS"
418c95e3080SKevin WolfQEMU_CFLAGS="-Wstrict-prototypes -Wredundant-decls $QEMU_CFLAGS"
419be17dc90SMichael S. TsirkinQEMU_CFLAGS="-D_GNU_SOURCE -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE $QEMU_CFLAGS"
4205770e8afSPaolo Bonzini
421de38c0ccSPaolo BonziniQEMU_LDFLAGS=
422de38c0ccSPaolo Bonzini
4235770e8afSPaolo Bonzini# Flags that are needed during configure but later taken care of by Meson
4248a9d3d56SRichard HendersonCONFIGURE_CFLAGS="-std=gnu11 -Wall"
4255770e8afSPaolo BonziniCONFIGURE_LDFLAGS=
426086d5f75SPaolo Bonzini
427be17dc90SMichael S. Tsirkin
428ac0df51dSaliguoricheck_define() {
429ac0df51dSaliguoricat > $TMPC <<EOF
430ac0df51dSaliguori#if !defined($1)
431fd786e1aSPeter Maydell#error $1 not defined
432ac0df51dSaliguori#endif
433ac0df51dSaliguoriint main(void) { return 0; }
434ac0df51dSaliguoriEOF
43552166aa0SJuan Quintela  compile_object
436ac0df51dSaliguori}
437ac0df51dSaliguori
438307119e7SGerd Hoffmanncheck_include() {
439307119e7SGerd Hoffmanncat > $TMPC <<EOF
440307119e7SGerd Hoffmann#include <$1>
441307119e7SGerd Hoffmannint main(void) { return 0; }
442307119e7SGerd HoffmannEOF
443307119e7SGerd Hoffmann  compile_object
444307119e7SGerd Hoffmann}
445307119e7SGerd Hoffmann
44693b25869SJohn Snowwrite_c_skeleton() {
44793b25869SJohn Snow    cat > $TMPC <<EOF
44893b25869SJohn Snowint main(void) { return 0; }
44993b25869SJohn SnowEOF
45093b25869SJohn Snow}
45193b25869SJohn Snow
452bbea4050SPeter Maydellif check_define __linux__ ; then
453ba7c60c2SPaolo Bonzini  targetos=linux
454bbea4050SPeter Maydellelif check_define _WIN32 ; then
455ba7c60c2SPaolo Bonzini  targetos=windows
456bbea4050SPeter Maydellelif check_define __OpenBSD__ ; then
457ba7c60c2SPaolo Bonzini  targetos=openbsd
458bbea4050SPeter Maydellelif check_define __sun__ ; then
459ba7c60c2SPaolo Bonzini  targetos=sunos
460bbea4050SPeter Maydellelif check_define __HAIKU__ ; then
461ba7c60c2SPaolo Bonzini  targetos=haiku
462951fedfcSPeter Maydellelif check_define __FreeBSD__ ; then
463ba7c60c2SPaolo Bonzini  targetos=freebsd
464951fedfcSPeter Maydellelif check_define __FreeBSD_kernel__ && check_define __GLIBC__; then
465ba7c60c2SPaolo Bonzini  targetos=gnu/kfreebsd
466951fedfcSPeter Maydellelif check_define __DragonFly__ ; then
467ba7c60c2SPaolo Bonzini  targetos=dragonfly
468951fedfcSPeter Maydellelif check_define __NetBSD__; then
469ba7c60c2SPaolo Bonzini  targetos=netbsd
470951fedfcSPeter Maydellelif check_define __APPLE__; then
471ba7c60c2SPaolo Bonzini  targetos=darwin
472bbea4050SPeter Maydellelse
473951fedfcSPeter Maydell  # This is a fatal error, but don't report it yet, because we
474951fedfcSPeter Maydell  # might be going to just print the --help text, or it might
475951fedfcSPeter Maydell  # be the result of a missing compiler.
476ba7c60c2SPaolo Bonzini  targetos=bogus
477bbea4050SPeter Maydellfi
478bbea4050SPeter Maydell
47965eff01bSPaolo Bonzini# OS specific
48065eff01bSPaolo Bonzini
4813b0d8643SPaolo Bonzinimingw32="no"
4823b0d8643SPaolo Bonzinibsd="no"
4833b0d8643SPaolo Bonzinilinux="no"
4843b0d8643SPaolo Bonzinisolaris="no"
48565eff01bSPaolo Bonzinicase $targetos in
48665eff01bSPaolo Bonziniwindows)
48765eff01bSPaolo Bonzini  mingw32="yes"
48865eff01bSPaolo Bonzini  plugins="no"
48965eff01bSPaolo Bonzini  pie="no"
49065eff01bSPaolo Bonzini;;
49165eff01bSPaolo Bonzinignu/kfreebsd)
49265eff01bSPaolo Bonzini  bsd="yes"
49365eff01bSPaolo Bonzini;;
49465eff01bSPaolo Bonzinifreebsd)
49565eff01bSPaolo Bonzini  bsd="yes"
49665eff01bSPaolo Bonzini  make="${MAKE-gmake}"
49765eff01bSPaolo Bonzini  # needed for kinfo_getvmmap(3) in libutil.h
49865eff01bSPaolo Bonzini;;
49965eff01bSPaolo Bonzinidragonfly)
50065eff01bSPaolo Bonzini  bsd="yes"
50165eff01bSPaolo Bonzini  make="${MAKE-gmake}"
50265eff01bSPaolo Bonzini;;
50365eff01bSPaolo Bonzininetbsd)
50465eff01bSPaolo Bonzini  bsd="yes"
50565eff01bSPaolo Bonzini  make="${MAKE-gmake}"
50665eff01bSPaolo Bonzini;;
50765eff01bSPaolo Bonziniopenbsd)
50865eff01bSPaolo Bonzini  bsd="yes"
50965eff01bSPaolo Bonzini  make="${MAKE-gmake}"
51065eff01bSPaolo Bonzini;;
51165eff01bSPaolo Bonzinidarwin)
51265eff01bSPaolo Bonzini  bsd="yes"
51365eff01bSPaolo Bonzini  darwin="yes"
51465eff01bSPaolo Bonzini  # Disable attempts to use ObjectiveC features in os/object.h since they
51565eff01bSPaolo Bonzini  # won't work when we're compiling with gcc as a C compiler.
51665eff01bSPaolo Bonzini  QEMU_CFLAGS="-DOS_OBJECT_USE_OBJC=0 $QEMU_CFLAGS"
51765eff01bSPaolo Bonzini;;
51865eff01bSPaolo Bonzinisunos)
51965eff01bSPaolo Bonzini  solaris="yes"
52065eff01bSPaolo Bonzini  make="${MAKE-gmake}"
52165eff01bSPaolo Bonzini# needed for CMSG_ macros in sys/socket.h
52265eff01bSPaolo Bonzini  QEMU_CFLAGS="-D_XOPEN_SOURCE=600 $QEMU_CFLAGS"
52365eff01bSPaolo Bonzini# needed for TIOCWIN* defines in termios.h
52465eff01bSPaolo Bonzini  QEMU_CFLAGS="-D__EXTENSIONS__ $QEMU_CFLAGS"
52565eff01bSPaolo Bonzini  # $(uname -m) returns i86pc even on an x86_64 box, so default based on isainfo
52665eff01bSPaolo Bonzini  # Note that this check is broken for cross-compilation: if you're
527bbea4050SPeter Maydell  # cross-compiling to one of these OSes then you'll need to specify
528bbea4050SPeter Maydell  # the correct CPU with the --cpu option.
529bbea4050SPeter Maydell  if test -z "$cpu" && test "$(isainfo -k)" = "amd64"; then
530bbea4050SPeter Maydell    cpu="x86_64"
531bbea4050SPeter Maydell  fi
53265eff01bSPaolo Bonzini;;
53365eff01bSPaolo Bonzinihaiku)
53465eff01bSPaolo Bonzini  pie="no"
53565eff01bSPaolo Bonzini  QEMU_CFLAGS="-DB_USE_POSITIVE_POSIX_ERRORS -D_BSD_SOURCE -fPIC $QEMU_CFLAGS"
53665eff01bSPaolo Bonzini;;
53765eff01bSPaolo Bonzinilinux)
53865eff01bSPaolo Bonzini  linux="yes"
53965eff01bSPaolo Bonzini;;
540bbea4050SPeter Maydellesac
541bbea4050SPeter Maydell
5422ff6b91eSJuan Quintelaif test ! -z "$cpu" ; then
5432ff6b91eSJuan Quintela  # command line argument
5442ff6b91eSJuan Quintela  :
5452ff6b91eSJuan Quintelaelif check_define __i386__ ; then
546ac0df51dSaliguori  cpu="i386"
547ac0df51dSaliguorielif check_define __x86_64__ ; then
548c72b26ecSRichard Henderson  if check_define __ILP32__ ; then
549c72b26ecSRichard Henderson    cpu="x32"
550c72b26ecSRichard Henderson  else
551ac0df51dSaliguori    cpu="x86_64"
552c72b26ecSRichard Henderson  fi
5533aa9bd6cSblueswir1elif check_define __sparc__ ; then
5543aa9bd6cSblueswir1  if check_define __arch64__ ; then
5553aa9bd6cSblueswir1    cpu="sparc64"
5563aa9bd6cSblueswir1  else
5573aa9bd6cSblueswir1    cpu="sparc"
5583aa9bd6cSblueswir1  fi
559fdf7ed96Smalcelif check_define _ARCH_PPC ; then
560fdf7ed96Smalc  if check_define _ARCH_PPC64 ; then
561f8378accSRichard Henderson    if check_define _LITTLE_ENDIAN ; then
562f8378accSRichard Henderson      cpu="ppc64le"
563f8378accSRichard Henderson    else
564fdf7ed96Smalc      cpu="ppc64"
565f8378accSRichard Henderson    fi
566ac0df51dSaliguori  else
567fdf7ed96Smalc    cpu="ppc"
568fdf7ed96Smalc  fi
569afa05235SAurelien Jarnoelif check_define __mips__ ; then
570afa05235SAurelien Jarno  cpu="mips"
571d66ed0eaSAurelien Jarnoelif check_define __s390__ ; then
572d66ed0eaSAurelien Jarno  if check_define __s390x__ ; then
573d66ed0eaSAurelien Jarno    cpu="s390x"
574d66ed0eaSAurelien Jarno  else
575d66ed0eaSAurelien Jarno    cpu="s390"
576d66ed0eaSAurelien Jarno  fi
577c4f80543SAlistair Franciselif check_define __riscv ; then
578ba0e7333SRichard Henderson  cpu="riscv"
57921d89f84SPeter Maydellelif check_define __arm__ ; then
58021d89f84SPeter Maydell  cpu="arm"
5811f080313SClaudio Fontanaelif check_define __aarch64__ ; then
5821f080313SClaudio Fontana  cpu="aarch64"
583dfcf900bSWANG Xueruielif check_define __loongarch64 ; then
584dfcf900bSWANG Xuerui  cpu="loongarch64"
585fdf7ed96Smalcelse
58689138857SStefan Weil  cpu=$(uname -m)
587ac0df51dSaliguorifi
588ac0df51dSaliguori
589823eb013SPaolo Bonzini# Normalise host CPU name, set multilib cflags
590359bc95dSPeter Maydell# Note that this case should only have supported host CPUs, not guests.
5917d13299dSbellardcase "$cpu" in
592e4da0e39SPaolo Bonzini  armv*b|armv*l|arm)
593e4da0e39SPaolo Bonzini    cpu="arm" ;;
594e4da0e39SPaolo Bonzini
5957d13299dSbellard  i386|i486|i586|i686|i86pc|BePC)
59697a847bcSbellard    cpu="i386"
597e4da0e39SPaolo Bonzini    CPU_CFLAGS="-m32" ;;
598e4da0e39SPaolo Bonzini  x32)
5994da270beSPaolo Bonzini    cpu="x86_64"
600e4da0e39SPaolo Bonzini    CPU_CFLAGS="-mx32" ;;
601aaa5fa14Saurel32  x86_64|amd64)
602aaa5fa14Saurel32    cpu="x86_64"
603e4da0e39SPaolo Bonzini    # ??? Only extremely old AMD cpus do not have cmpxchg16b.
604e4da0e39SPaolo Bonzini    # If we truly care, we should simply detect this case at
605e4da0e39SPaolo Bonzini    # runtime and generate the fallback to serial emulation.
606e4da0e39SPaolo Bonzini    CPU_CFLAGS="-m64 -mcx16" ;;
607e4da0e39SPaolo Bonzini
608afa05235SAurelien Jarno  mips*)
609e4da0e39SPaolo Bonzini    cpu="mips" ;;
610e4da0e39SPaolo Bonzini
611e4da0e39SPaolo Bonzini  ppc)
612e4da0e39SPaolo Bonzini    CPU_CFLAGS="-m32" ;;
613e4da0e39SPaolo Bonzini  ppc64)
614ced5cfffSMiroslav Rezanina    CPU_CFLAGS="-m64 -mbig-endian" ;;
615e4da0e39SPaolo Bonzini  ppc64le)
616d8ff892dSPaolo Bonzini    cpu="ppc64"
617ced5cfffSMiroslav Rezanina    CPU_CFLAGS="-m64 -mlittle-endian" ;;
618e4da0e39SPaolo Bonzini
619e4da0e39SPaolo Bonzini  s390)
620823eb013SPaolo Bonzini    CPU_CFLAGS="-m31" ;;
621e4da0e39SPaolo Bonzini  s390x)
622e4da0e39SPaolo Bonzini    CPU_CFLAGS="-m64" ;;
623e4da0e39SPaolo Bonzini
6243142255cSblueswir1  sparc|sun4[cdmuv])
625ae228531Sbellard    cpu="sparc"
626e4da0e39SPaolo Bonzini    CPU_CFLAGS="-m32 -mv8plus -mcpu=ultrasparc" ;;
627e4da0e39SPaolo Bonzini  sparc64)
628e4da0e39SPaolo Bonzini    CPU_CFLAGS="-m64 -mcpu=ultrasparc" ;;
6297d13299dSbellardesac
630e2d52ad3SJuan Quintela
6310db4a067SPaolo Bonzini: ${make=${MAKE-make}}
632b6daf4d3SPaolo Bonzini
633faf44142SDaniel P. Berrangé# We prefer python 3.x. A bare 'python' is traditionally
634faf44142SDaniel P. Berrangé# python 2.x, but some distros have it as python 3.x, so
635ddf90699SEduardo Habkost# we check that too
636faf44142SDaniel P. Berrangépython=
6370a01d76fSMarc-André Lureauexplicit_python=no
638ddf90699SEduardo Habkostfor binary in "${PYTHON-python3}" python
639faf44142SDaniel P. Berrangédo
640faf44142SDaniel P. Berrangé    if has "$binary"
641faf44142SDaniel P. Berrangé    then
64295c5f2deSPaolo Bonzini        python=$(command -v "$binary")
643faf44142SDaniel P. Berrangé        break
644faf44142SDaniel P. Berrangé    fi
645faf44142SDaniel P. Berrangédone
646903458c8SMarkus Armbruster
647903458c8SMarkus Armbruster
64839d87c8cSAlex Bennée# Check for ancillary tools used in testing
64939d87c8cSAlex Bennéegenisoimage=
6503df437c7SAlex Bennéefor binary in genisoimage mkisofs
65139d87c8cSAlex Bennéedo
65239d87c8cSAlex Bennée    if has $binary
65339d87c8cSAlex Bennée    then
65439d87c8cSAlex Bennée        genisoimage=$(command -v "$binary")
65539d87c8cSAlex Bennée        break
65639d87c8cSAlex Bennée    fi
65739d87c8cSAlex Bennéedone
65839d87c8cSAlex Bennée
6593c4a4d0dSPeter Maydell# Default objcc to clang if available, otherwise use CC
6603c4a4d0dSPeter Maydellif has clang; then
6613c4a4d0dSPeter Maydell  objcc=clang
6623c4a4d0dSPeter Maydellelse
6633c4a4d0dSPeter Maydell  objcc="$cc"
6643c4a4d0dSPeter Maydellfi
6653c4a4d0dSPeter Maydell
6663457a3f8SJuan Quintelaif test "$mingw32" = "yes" ; then
6673457a3f8SJuan Quintela  EXESUF=".exe"
66878e9d4adSStefan Weil  # MinGW needs -mthreads for TLS and macro _MT.
6695770e8afSPaolo Bonzini  CONFIGURE_CFLAGS="-mthreads $CONFIGURE_CFLAGS"
67093b25869SJohn Snow  write_c_skeleton;
671d17f305aSPaolo Bonzini  prefix="/qemu"
672c09c1ce7SPaolo Bonzini  bindir=""
67377433a5fSMarc-André Lureau  qemu_suffix=""
6743457a3f8SJuan Quintelafi
6753457a3f8SJuan Quintela
676487fefdbSAnthony Liguoriwerror=""
67785aa5189Sbellard
6788154f5e6SAkihiko Odakimeson_option_build_array() {
6798154f5e6SAkihiko Odaki  printf '['
680c5cfdabaSPeter Maydell  (if test "$targetos" = windows; then
6818154f5e6SAkihiko Odaki    IFS=\;
6828154f5e6SAkihiko Odaki  else
6838154f5e6SAkihiko Odaki    IFS=:
6848154f5e6SAkihiko Odaki  fi
6858154f5e6SAkihiko Odaki  for e in $1; do
68665842b03SPeter Maydell    printf '"""'
68765842b03SPeter Maydell    # backslash escape any '\' and '"' characters
68865842b03SPeter Maydell    printf "%s" "$e" | sed -e 's/\([\"]\)/\\\1/g'
68965842b03SPeter Maydell    printf '""",'
6908154f5e6SAkihiko Odaki  done)
6918154f5e6SAkihiko Odaki  printf ']\n'
6928154f5e6SAkihiko Odaki}
6938154f5e6SAkihiko Odaki
69464708615SPeter Maydell. "$source_path/scripts/meson-buildoptions.sh"
69561d63097SPaolo Bonzini
69661d63097SPaolo Bonzinimeson_options=
697c54b59eeSPaolo Bonzinimeson_option_add() {
698c54b59eeSPaolo Bonzini  meson_options="$meson_options $(quote_sh "$1")"
699c54b59eeSPaolo Bonzini}
70061d63097SPaolo Bonzinimeson_option_parse() {
70161d63097SPaolo Bonzini  meson_options="$meson_options $(_meson_option_parse "$@")"
70261d63097SPaolo Bonzini  if test $? -eq 1; then
70361d63097SPaolo Bonzini    echo "ERROR: unknown option $1"
70461d63097SPaolo Bonzini    echo "Try '$0 --help' for more information"
70561d63097SPaolo Bonzini    exit 1
70661d63097SPaolo Bonzini  fi
70761d63097SPaolo Bonzini}
70861d63097SPaolo Bonzini
7097d13299dSbellardfor opt do
71089138857SStefan Weil  optarg=$(expr "x$opt" : 'x[^=]*=\(.*\)')
7117d13299dSbellard  case "$opt" in
7122efc3265Sbellard  --help|-h) show_help=yes
7132efc3265Sbellard  ;;
71464708615SPeter Maydell  --version|-V) exec cat "$source_path/VERSION"
71599123e13SMike Frysinger  ;;
716b1a550a0Spbrook  --prefix=*) prefix="$optarg"
7177d13299dSbellard  ;;
718ac0df51dSaliguori  --cross-prefix=*)
7197d13299dSbellard  ;;
720ac0df51dSaliguori  --cc=*)
7217d13299dSbellard  ;;
722b1a550a0Spbrook  --host-cc=*) host_cc="$optarg"
72383469015Sbellard  ;;
72483f73fceSTomoki Sekiyama  --cxx=*)
72583f73fceSTomoki Sekiyama  ;;
7263c4a4d0dSPeter Maydell  --objcc=*) objcc="$optarg"
7273c4a4d0dSPeter Maydell  ;;
728b1a550a0Spbrook  --make=*) make="$optarg"
7297d13299dSbellard  ;;
730b6daf4d3SPaolo Bonzini  --install=*)
7316a882643Spbrook  ;;
7320a01d76fSMarc-André Lureau  --python=*) python="$optarg" ; explicit_python=yes
733c886edfbSBlue Swirl  ;;
734a5665051SPaolo Bonzini  --skip-meson) skip_meson=yes
735a5665051SPaolo Bonzini  ;;
736a5665051SPaolo Bonzini  --meson=*) meson="$optarg"
737a5665051SPaolo Bonzini  ;;
73848328880SPaolo Bonzini  --ninja=*) ninja="$optarg"
73948328880SPaolo Bonzini  ;;
740e2d8830eSBrad  --smbd=*) smbd="$optarg"
741e2d8830eSBrad  ;;
742e2a2ed06SJuan Quintela  --extra-cflags=*)
7437d13299dSbellard  ;;
74411cde1c8SBruno Dominguez  --extra-cxxflags=*)
74511cde1c8SBruno Dominguez  ;;
746e910c7d9SPhilippe Mathieu-Daudé  --extra-objcflags=*)
747e910c7d9SPhilippe Mathieu-Daudé  ;;
748e2a2ed06SJuan Quintela  --extra-ldflags=*)
7497d13299dSbellard  ;;
750d75402b5SAlex Bennée  --cross-cc-*)
751d75402b5SAlex Bennée  ;;
7525adb43beSPaolo Bonzini  --cross-prefix-*)
7535adb43beSPaolo Bonzini  ;;
754c54b59eeSPaolo Bonzini  --enable-debug-info) meson_option_add -Ddebug=true
75528609749SPaolo Bonzini  ;;
756c54b59eeSPaolo Bonzini  --disable-debug-info) meson_option_add -Ddebug=false
75728609749SPaolo Bonzini  ;;
75817969268SFam Zheng  --enable-modules)
75917969268SFam Zheng      modules="yes"
76017969268SFam Zheng  ;;
7613aa88b31SStefan Hajnoczi  --disable-modules)
7623aa88b31SStefan Hajnoczi      modules="no"
7633aa88b31SStefan Hajnoczi  ;;
7642ff6b91eSJuan Quintela  --cpu=*)
7657d13299dSbellard  ;;
766b1a550a0Spbrook  --target-list=*) target_list="$optarg"
767447e133fSAlex Bennée                   if test "$target_list_exclude"; then
768447e133fSAlex Bennée                       error_exit "Can't mix --target-list with --target-list-exclude"
769447e133fSAlex Bennée                   fi
770447e133fSAlex Bennée  ;;
771447e133fSAlex Bennée  --target-list-exclude=*) target_list_exclude="$optarg"
772447e133fSAlex Bennée                   if test "$target_list"; then
773447e133fSAlex Bennée                       error_exit "Can't mix --target-list-exclude with --target-list"
774447e133fSAlex Bennée                   fi
775de83cd02Sbellard  ;;
776c54b59eeSPaolo Bonzini  --with-default-devices) meson_option_add -Ddefault_devices=true
777f3494749SPaolo Bonzini  ;;
778c54b59eeSPaolo Bonzini  --without-default-devices) meson_option_add -Ddefault_devices=false
779f3494749SPaolo Bonzini  ;;
780d1d5e9eeSAlex Bennée  --with-devices-*[!a-zA-Z0-9_-]*=*) error_exit "Passed bad --with-devices-FOO option"
781d1d5e9eeSAlex Bennée  ;;
782d1d5e9eeSAlex Bennée  --with-devices-*) device_arch=${opt#--with-devices-};
783d1d5e9eeSAlex Bennée                    device_arch=${device_arch%%=*}
784d1d5e9eeSAlex Bennée                    cf=$source_path/configs/devices/$device_arch-softmmu/$optarg.mak
785d1d5e9eeSAlex Bennée                    if test -f "$cf"; then
786d1d5e9eeSAlex Bennée                        device_archs="$device_archs $device_arch"
787d1d5e9eeSAlex Bennée                        eval "devices_${device_arch}=\$optarg"
788d1d5e9eeSAlex Bennée                    else
789d1d5e9eeSAlex Bennée                        error_exit "File $cf does not exist"
790d1d5e9eeSAlex Bennée                    fi
791d1d5e9eeSAlex Bennée  ;;
792c87ea116SAlex Bennée  --without-default-features) # processed above
793c87ea116SAlex Bennée  ;;
79479427693SLoïc Minier  --static)
79579427693SLoïc Minier    static="yes"
79617884d7bSSergei Trofimovich    QEMU_PKG_CONFIG_FLAGS="--static $QEMU_PKG_CONFIG_FLAGS"
79743ce4dfeSbellard  ;;
7980b24e75fSPaolo Bonzini  --bindir=*) bindir="$optarg"
7990b24e75fSPaolo Bonzini  ;;
80077433a5fSMarc-André Lureau  --with-suffix=*) qemu_suffix="$optarg"
801023d3d67SEduardo Habkost  ;;
802181ce1d0SOlaf Hering  --host=*|--build=*|\
803181ce1d0SOlaf Hering  --disable-dependency-tracking|\
804785c23aeSLuiz Capitulino  --sbindir=*|--sharedstatedir=*|\
805fe0038beSPaolo Bonzini  --oldincludedir=*|--datarootdir=*|--infodir=*|\
806023ddd74SMax Filippov  --htmldir=*|--dvidir=*|--pdfdir=*|--psdir=*)
807023ddd74SMax Filippov    # These switches are silently ignored, for compatibility with
808023ddd74SMax Filippov    # autoconf-generated configure scripts. This allows QEMU's
809023ddd74SMax Filippov    # configure to be used by RPM and similar macros that set
810023ddd74SMax Filippov    # lots of directory switches by default.
811023ddd74SMax Filippov  ;;
812f8393946Saurel32  --enable-debug-tcg) debug_tcg="yes"
813f8393946Saurel32  ;;
814f8393946Saurel32  --disable-debug-tcg) debug_tcg="no"
815f8393946Saurel32  ;;
816f3d08ee6SPaul Brook  --enable-debug)
817f3d08ee6SPaul Brook      # Enable debugging options that aren't excessively noisy
818f3d08ee6SPaul Brook      debug_tcg="yes"
819c55cf6abSPaolo Bonzini      meson_option_parse --enable-debug-mutex ""
820c54b59eeSPaolo Bonzini      meson_option_add -Doptimization=0
821b553a042SJohn Snow      fortify_source="no"
822f3d08ee6SPaul Brook  ;;
823247724cbSMarc-André Lureau  --enable-sanitizers) sanitizers="yes"
824247724cbSMarc-André Lureau  ;;
825247724cbSMarc-André Lureau  --disable-sanitizers) sanitizers="no"
826247724cbSMarc-André Lureau  ;;
8270aebab04SLingfeng Yang  --enable-tsan) tsan="yes"
8280aebab04SLingfeng Yang  ;;
8290aebab04SLingfeng Yang  --disable-tsan) tsan="no"
8300aebab04SLingfeng Yang  ;;
8314d34a86bSPaolo Bonzini  --disable-slirp) slirp="disabled"
832c20709aaSbellard  ;;
833fd6fc214SPaolo Bonzini  --enable-slirp) slirp="enabled"
834fd6fc214SPaolo Bonzini  ;;
8354d34a86bSPaolo Bonzini  --enable-slirp=git) slirp="internal"
8367c57bdd8SMarc-André Lureau  ;;
83703a3c0b3SPaolo Bonzini  --enable-slirp=*) slirp="$optarg"
838675b9b53SMarc-André Lureau  ;;
8391badb709SPaolo Bonzini  --disable-tcg) tcg="disabled"
840d1a14257SAlex Bennée                 plugins="no"
841b3f6ea7eSPaolo Bonzini  ;;
8421badb709SPaolo Bonzini  --enable-tcg) tcg="enabled"
843b3f6ea7eSPaolo Bonzini  ;;
844cad25d69Spbrook  --disable-system) softmmu="no"
8450a8e90f4Spbrook  ;;
846cad25d69Spbrook  --enable-system) softmmu="yes"
8470a8e90f4Spbrook  ;;
8480953a80fSZachary Amsden  --disable-user)
8490953a80fSZachary Amsden      linux_user="no" ;
8500953a80fSZachary Amsden      bsd_user="no" ;
8510953a80fSZachary Amsden  ;;
8520953a80fSZachary Amsden  --enable-user) ;;
853831b7825Sths  --disable-linux-user) linux_user="no"
8540a8e90f4Spbrook  ;;
855831b7825Sths  --enable-linux-user) linux_user="yes"
856831b7825Sths  ;;
85784778508Sblueswir1  --disable-bsd-user) bsd_user="no"
85884778508Sblueswir1  ;;
85984778508Sblueswir1  --enable-bsd-user) bsd_user="yes"
86084778508Sblueswir1  ;;
86140d6444eSAvi Kivity  --enable-pie) pie="yes"
86234005a00SKirill A. Shutemov  ;;
86340d6444eSAvi Kivity  --disable-pie) pie="no"
86434005a00SKirill A. Shutemov  ;;
86585aa5189Sbellard  --enable-werror) werror="yes"
86685aa5189Sbellard  ;;
86785aa5189Sbellard  --disable-werror) werror="no"
86885aa5189Sbellard  ;;
86963678e17SSteven Noonan  --enable-stack-protector) stack_protector="yes"
87063678e17SSteven Noonan  ;;
87163678e17SSteven Noonan  --disable-stack-protector) stack_protector="no"
87263678e17SSteven Noonan  ;;
8731e4f6065SDaniele Buono  --enable-safe-stack) safe_stack="yes"
8741e4f6065SDaniele Buono  ;;
8751e4f6065SDaniele Buono  --disable-safe-stack) safe_stack="no"
8761e4f6065SDaniele Buono  ;;
8779e62ba48SDaniele Buono  --enable-cfi)
8789e62ba48SDaniele Buono      cfi="true";
879c54b59eeSPaolo Bonzini      meson_option_add -Db_lto=true
8809e62ba48SDaniele Buono  ;;
8819e62ba48SDaniele Buono  --disable-cfi) cfi="false"
8829e62ba48SDaniele Buono  ;;
883fbb4121dSPaolo Bonzini  --disable-fdt) fdt="disabled"
8842df87df7SJuan Quintela  ;;
885fbb4121dSPaolo Bonzini  --enable-fdt) fdt="enabled"
886fbb4121dSPaolo Bonzini  ;;
887fbb4121dSPaolo Bonzini  --enable-fdt=git) fdt="internal"
888fbb4121dSPaolo Bonzini  ;;
88903a3c0b3SPaolo Bonzini  --enable-fdt=*) fdt="$optarg"
8902df87df7SJuan Quintela  ;;
891519175a2SAlex Barcelo  --with-coroutine=*) coroutine="$optarg"
892519175a2SAlex Barcelo  ;;
8931ffb3bbbSPaolo Bonzini  --disable-zlib-test)
8941ece9905SAlon Levy  ;;
89552b53c04SFam Zheng  --disable-virtio-blk-data-plane|--enable-virtio-blk-data-plane)
89652b53c04SFam Zheng      echo "$0: $opt is obsolete, virtio-blk data-plane is always on" >&2
897583f6e7bSStefan Hajnoczi  ;;
898cb6414dfSFam Zheng  --enable-vhdx|--disable-vhdx)
899cb6414dfSFam Zheng      echo "$0: $opt is obsolete, VHDX driver is always built" >&2
900cb6414dfSFam Zheng  ;;
901315d3184SFam Zheng  --enable-uuid|--disable-uuid)
902315d3184SFam Zheng      echo "$0: $opt is obsolete, UUID support is always built" >&2
903315d3184SFam Zheng  ;;
904cc84d63aSDaniel P. Berrange  --with-git=*) git="$optarg"
905cc84d63aSDaniel P. Berrange  ;;
9067d7dbf9dSDan Streetman  --with-git-submodules=*)
9077d7dbf9dSDan Streetman      git_submodules_action="$optarg"
908f62bbee5SDaniel P. Berrange  ;;
9099b8e4298SAlex Bennée  --enable-plugins) if test "$mingw32" = "yes"; then
9109b8e4298SAlex Bennée                        error_exit "TCG plugins not currently supported on Windows platforms"
9119b8e4298SAlex Bennée                    else
9129b8e4298SAlex Bennée                        plugins="yes"
9139b8e4298SAlex Bennée                    fi
91440e8c6f4SAlex Bennée  ;;
91540e8c6f4SAlex Bennée  --disable-plugins) plugins="no"
91640e8c6f4SAlex Bennée  ;;
917afc3a8f9SAlex Bennée  --enable-containers) use_containers="yes"
918afc3a8f9SAlex Bennée  ;;
919afc3a8f9SAlex Bennée  --disable-containers) use_containers="no"
920afc3a8f9SAlex Bennée  ;;
921f48e590aSAlex Bennée  --gdb=*) gdb_bin="$optarg"
922f48e590aSAlex Bennée  ;;
9233b4da132SPaolo Bonzini  # backwards compatibility options
9243b4da132SPaolo Bonzini  --enable-trace-backend=*) meson_option_parse "--enable-trace-backends=$optarg" "$optarg"
9253b4da132SPaolo Bonzini  ;;
9263b4da132SPaolo Bonzini  --disable-blobs) meson_option_parse --disable-install-blobs ""
9273b4da132SPaolo Bonzini  ;;
92855116968SJagannathan Raman  --enable-vfio-user-server) vfio_user_server="enabled"
92955116968SJagannathan Raman  ;;
93055116968SJagannathan Raman  --disable-vfio-user-server) vfio_user_server="disabled"
93155116968SJagannathan Raman  ;;
9323b4da132SPaolo Bonzini  --enable-tcmalloc) meson_option_parse --enable-malloc=tcmalloc tcmalloc
9333b4da132SPaolo Bonzini  ;;
9343b4da132SPaolo Bonzini  --enable-jemalloc) meson_option_parse --enable-malloc=jemalloc jemalloc
9353b4da132SPaolo Bonzini  ;;
9363b4da132SPaolo Bonzini  # everything else has the same name in configure and meson
9374fda6011SPaolo Bonzini  --*) meson_option_parse "$opt" "$optarg"
9387f1559c6Sbalrog  ;;
9397d13299dSbellard  esac
9407d13299dSbellarddone
9417d13299dSbellard
942d1a14257SAlex Bennée# test for any invalid configuration combinations
943d1a14257SAlex Bennéeif test "$plugins" = "yes" -a "$tcg" = "disabled"; then
944d1a14257SAlex Bennée    error_exit "Can't enable plugins on non-TCG builds"
945d1a14257SAlex Bennéefi
946d1a14257SAlex Bennée
9477d7dbf9dSDan Streetmancase $git_submodules_action in
9487d7dbf9dSDan Streetman    update|validate)
9497d7dbf9dSDan Streetman        if test ! -e "$source_path/.git"; then
9507d7dbf9dSDan Streetman            echo "ERROR: cannot $git_submodules_action git submodules without .git"
9517d7dbf9dSDan Streetman            exit 1
9527d7dbf9dSDan Streetman        fi
9537d7dbf9dSDan Streetman    ;;
9547d7dbf9dSDan Streetman    ignore)
955b80fd281SPaolo Bonzini        if ! test -f "$source_path/ui/keycodemapdb/README"
956b80fd281SPaolo Bonzini        then
957b80fd281SPaolo Bonzini            echo
958b80fd281SPaolo Bonzini            echo "ERROR: missing GIT submodules"
959b80fd281SPaolo Bonzini            echo
960b80fd281SPaolo Bonzini            if test -e "$source_path/.git"; then
961b80fd281SPaolo Bonzini                echo "--with-git-submodules=ignore specified but submodules were not"
962b80fd281SPaolo Bonzini                echo "checked out.  Please initialize and update submodules."
963b80fd281SPaolo Bonzini            else
964b80fd281SPaolo Bonzini                echo "This is not a GIT checkout but module content appears to"
965b80fd281SPaolo Bonzini                echo "be missing. Do not use 'git archive' or GitHub download links"
966b80fd281SPaolo Bonzini                echo "to acquire QEMU source archives. Non-GIT builds are only"
967b80fd281SPaolo Bonzini                echo "supported with source archives linked from:"
968b80fd281SPaolo Bonzini                echo
969b80fd281SPaolo Bonzini                echo "  https://www.qemu.org/download/#source"
970b80fd281SPaolo Bonzini                echo
971b80fd281SPaolo Bonzini                echo "Developers working with GIT can use scripts/archive-source.sh"
972b80fd281SPaolo Bonzini                echo "if they need to create valid source archives."
973b80fd281SPaolo Bonzini            fi
974b80fd281SPaolo Bonzini            echo
975b80fd281SPaolo Bonzini            exit 1
976b80fd281SPaolo Bonzini        fi
9777d7dbf9dSDan Streetman    ;;
9787d7dbf9dSDan Streetman    *)
9797d7dbf9dSDan Streetman        echo "ERROR: invalid --with-git-submodules= value '$git_submodules_action'"
9807d7dbf9dSDan Streetman        exit 1
9817d7dbf9dSDan Streetman    ;;
9827d7dbf9dSDan Streetmanesac
9837d7dbf9dSDan Streetman
98460e0df25SPeter Maydelldefault_target_list=""
9856e92f823SPeter Maydellmak_wilds=""
9866e92f823SPeter Maydell
987b915a2f1SPaolo Bonziniif [ "$linux_user" != no ]; then
98864708615SPeter Maydell    if [ "$targetos" = linux ] && [ -d "$source_path/linux-user/include/host/$cpu" ]; then
989b915a2f1SPaolo Bonzini        linux_user=yes
990b915a2f1SPaolo Bonzini    elif [ "$linux_user" = yes ]; then
991b915a2f1SPaolo Bonzini        error_exit "linux-user not supported on this architecture"
992b915a2f1SPaolo Bonzini    fi
993b915a2f1SPaolo Bonzinifi
994b915a2f1SPaolo Bonziniif [ "$bsd_user" != no ]; then
995b915a2f1SPaolo Bonzini    if [ "$bsd_user" = "" ]; then
996b915a2f1SPaolo Bonzini        test $targetos = freebsd && bsd_user=yes
997b915a2f1SPaolo Bonzini    fi
99864708615SPeter Maydell    if [ "$bsd_user" = yes ] && ! [ -d "$source_path/bsd-user/$targetos" ]; then
999b915a2f1SPaolo Bonzini        error_exit "bsd-user not supported on this host OS"
1000b915a2f1SPaolo Bonzini    fi
1001b915a2f1SPaolo Bonzinifi
100260e0df25SPeter Maydellif [ "$softmmu" = "yes" ]; then
1003812b31d3SAlex Bennée    mak_wilds="${mak_wilds} $source_path/configs/targets/*-softmmu.mak"
100460e0df25SPeter Maydellfi
100560e0df25SPeter Maydellif [ "$linux_user" = "yes" ]; then
1006812b31d3SAlex Bennée    mak_wilds="${mak_wilds} $source_path/configs/targets/*-linux-user.mak"
100760e0df25SPeter Maydellfi
100860e0df25SPeter Maydellif [ "$bsd_user" = "yes" ]; then
1009812b31d3SAlex Bennée    mak_wilds="${mak_wilds} $source_path/configs/targets/*-bsd-user.mak"
101060e0df25SPeter Maydellfi
101160e0df25SPeter Maydell
1012447e133fSAlex Bennéefor config in $mak_wilds; do
1013447e133fSAlex Bennée    target="$(basename "$config" .mak)"
101498db9a06SAlex Bennée    if echo "$target_list_exclude" | grep -vq "$target"; then
1015447e133fSAlex Bennée        default_target_list="${default_target_list} $target"
1016447e133fSAlex Bennée    fi
1017447e133fSAlex Bennéedone
10186e92f823SPeter Maydell
1019af5db58eSpbrookif test x"$show_help" = x"yes" ; then
1020af5db58eSpbrookcat << EOF
1021af5db58eSpbrook
1022af5db58eSpbrookUsage: configure [options]
1023af5db58eSpbrookOptions: [defaults in brackets after descriptions]
1024af5db58eSpbrook
102508fb77edSStefan WeilStandard options:
102608fb77edSStefan Weil  --help                   print this message
102708fb77edSStefan Weil  --prefix=PREFIX          install in PREFIX [$prefix]
102874154d7eSThomas Huth  --target-list=LIST       set target list (default: build all)
102908fb77edSStefan Weil$(echo Available targets: $default_target_list | \
103008fb77edSStefan Weil  fold -s -w 53 | sed -e 's/^/                           /')
1031447e133fSAlex Bennée  --target-list-exclude=LIST exclude a set of targets from the default target-list
103208fb77edSStefan Weil
103308fb77edSStefan WeilAdvanced options (experts only):
10343812c0c4SJoelle van Dyne  --cross-prefix=PREFIX    use PREFIX for compile tools, PREFIX can be blank [$cross_prefix]
103508fb77edSStefan Weil  --cc=CC                  use C compiler CC [$cc]
103608fb77edSStefan Weil  --host-cc=CC             use C compiler CC [$host_cc] for code run at
103708fb77edSStefan Weil                           build time
103808fb77edSStefan Weil  --cxx=CXX                use C++ compiler CXX [$cxx]
103908fb77edSStefan Weil  --objcc=OBJCC            use Objective-C compiler OBJCC [$objcc]
1040a2866660SPaolo Bonzini  --extra-cflags=CFLAGS    append extra C compiler flags CFLAGS
1041a2866660SPaolo Bonzini  --extra-cxxflags=CXXFLAGS append extra C++ compiler flags CXXFLAGS
1042e910c7d9SPhilippe Mathieu-Daudé  --extra-objcflags=OBJCFLAGS append extra Objective C compiler flags OBJCFLAGS
104308fb77edSStefan Weil  --extra-ldflags=LDFLAGS  append extra linker flags LDFLAGS
1044d75402b5SAlex Bennée  --cross-cc-ARCH=CC       use compiler when building ARCH guest test cases
1045479ca4ccSMatheus Ferst  --cross-cc-cflags-ARCH=  use compiler flags when building ARCH guest tests
10465adb43beSPaolo Bonzini  --cross-prefix-ARCH=PREFIX cross compiler prefix when building ARCH guest test cases
104708fb77edSStefan Weil  --make=MAKE              use specified make [$make]
104808fb77edSStefan Weil  --python=PYTHON          use specified python [$python]
1049a5665051SPaolo Bonzini  --meson=MESON            use specified meson [$meson]
105048328880SPaolo Bonzini  --ninja=NINJA            use specified ninja [$ninja]
105108fb77edSStefan Weil  --smbd=SMBD              use specified smbd [$smbd]
1052db1b5f13SThomas Huth  --with-git=GIT           use specified git [$git]
10537d7dbf9dSDan Streetman  --with-git-submodules=update   update git submodules (default if .git dir exists)
10547d7dbf9dSDan Streetman  --with-git-submodules=validate fail if git submodules are not up to date
10557d7dbf9dSDan Streetman  --with-git-submodules=ignore   do not update or check git submodules (default if no .git dir)
105608fb77edSStefan Weil  --static                 enable static build [$static]
105708fb77edSStefan Weil  --bindir=PATH            install binaries in PATH
1058ca8c0909SMarc-André Lureau  --with-suffix=SUFFIX     suffix for QEMU data inside datadir/libdir/sysconfdir/docdir [$qemu_suffix]
1059c035c8d6SPaolo Bonzini  --without-default-features default all --enable-* options to "disabled"
1060c035c8d6SPaolo Bonzini  --without-default-devices  do not include any device that is not needed to
1061c035c8d6SPaolo Bonzini                           start the emulator (only use if you are including
1062d1d5e9eeSAlex Bennée                           desired devices in configs/devices/)
1063d1d5e9eeSAlex Bennée  --with-devices-ARCH=NAME override default configs/devices
106408fb77edSStefan Weil  --enable-debug           enable common debug build options
1065247724cbSMarc-André Lureau  --enable-sanitizers      enable default sanitizers
10660aebab04SLingfeng Yang  --enable-tsan            enable thread sanitizer
106708fb77edSStefan Weil  --disable-werror         disable compilation abort on warning
106863678e17SSteven Noonan  --disable-stack-protector disable compiler-provided stack protection
1069c23f23b9SMichael Tokarev  --cpu=CPU                Build for host CPU [$cpu]
107008fb77edSStefan Weil  --with-coroutine=BACKEND coroutine backend. Supported options:
107133c53c54SDaniel P. Berrange                           ucontext, sigaltstack, windows
107240e8c6f4SAlex Bennée  --enable-plugins
107340e8c6f4SAlex Bennée                           enable plugins via shared library loading
1074afc3a8f9SAlex Bennée  --disable-containers     don't use containers for cross-building
1075f48e590aSAlex Bennée  --gdb=GDB-path           gdb to use for gdbstub tests [$gdb_bin]
107661d63097SPaolo BonziniEOF
107761d63097SPaolo Bonzini  meson_options_help
107861d63097SPaolo Bonzinicat << EOF
1079c23f23b9SMichael Tokarev  system          all system emulation targets
1080c23f23b9SMichael Tokarev  user            supported user emulation targets
1081c23f23b9SMichael Tokarev  linux-user      all linux usermode emulation targets
1082c23f23b9SMichael Tokarev  bsd-user        all BSD usermode emulation targets
1083c23f23b9SMichael Tokarev  pie             Position Independent Executables
108421e709aaSMarc-André Lureau  modules         modules support (non-Windows)
1085c23f23b9SMichael Tokarev  debug-tcg       TCG debugging (default is disabled)
1086c23f23b9SMichael Tokarev  debug-info      debugging information
10871e4f6065SDaniele Buono  safe-stack      SafeStack Stack Smash Protection. Depends on
10881e4f6065SDaniele Buono                  clang/llvm >= 3.7 and requires coroutine backend ucontext.
108908fb77edSStefan Weil
109008fb77edSStefan WeilNOTE: The object files are built at the place where configure is launched
1091af5db58eSpbrookEOF
10922d2ad6d0SFam Zhengexit 0
1093af5db58eSpbrookfi
1094af5db58eSpbrook
10959c790242SThomas Huth# Remove old dependency files to make sure that they get properly regenerated
1096*002d8c13SPeter Maydellrm -f ./*/config-devices.mak.d
10979c790242SThomas Huth
1098faf44142SDaniel P. Berrangéif test -z "$python"
1099faf44142SDaniel P. Berrangéthen
1100c53eeaf7SStefan Hajnoczi    error_exit "Python not found. Use --python=/path/to/python"
1101c53eeaf7SStefan Hajnoczifi
11028e2c76bdSRoman Bolshakovif ! has "$make"
11038e2c76bdSRoman Bolshakovthen
11048e2c76bdSRoman Bolshakov    error_exit "GNU make ($make) not found"
11058e2c76bdSRoman Bolshakovfi
1106c53eeaf7SStefan Hajnoczi
1107c53eeaf7SStefan Hajnoczi# Note that if the Python conditional here evaluates True we will exit
1108c53eeaf7SStefan Hajnoczi# with status 1 which is a shell 'false' value.
11091b11f28dSThomas Huthif ! $python -c 'import sys; sys.exit(sys.version_info < (3,6))'; then
11101b11f28dSThomas Huth  error_exit "Cannot use '$python', Python >= 3.6 is required." \
1111c53eeaf7SStefan Hajnoczi      "Use --python=/path/to/python to specify a supported Python."
1112c53eeaf7SStefan Hajnoczifi
1113c53eeaf7SStefan Hajnoczi
1114c53eeaf7SStefan Hajnoczi# Suppress writing compiled files
1115c53eeaf7SStefan Hajnoczipython="$python -B"
1116c53eeaf7SStefan Hajnoczi
11170a01d76fSMarc-André Lureauif test -z "$meson"; then
11186638cae5SPaolo Bonzini    if test "$explicit_python" = no && has meson && version_ge "$(meson --version)" 0.59.3; then
11190a01d76fSMarc-André Lureau        meson=meson
112064708615SPeter Maydell    elif test "$git_submodules_action" != 'ignore' ; then
11210a01d76fSMarc-André Lureau        meson=git
11220a01d76fSMarc-André Lureau    elif test -e "${source_path}/meson/meson.py" ; then
11230a01d76fSMarc-André Lureau        meson=internal
11240a01d76fSMarc-André Lureau    else
11250a01d76fSMarc-André Lureau        if test "$explicit_python" = yes; then
11260a01d76fSMarc-André Lureau            error_exit "--python requires using QEMU's embedded Meson distribution, but it was not found."
11270a01d76fSMarc-André Lureau        else
1128a5665051SPaolo Bonzini            error_exit "Meson not found.  Use --meson=/path/to/meson"
1129a5665051SPaolo Bonzini        fi
11300a01d76fSMarc-André Lureau    fi
11310a01d76fSMarc-André Lureauelse
11320a01d76fSMarc-André Lureau    # Meson uses its own Python interpreter to invoke other Python scripts,
11330a01d76fSMarc-André Lureau    # but the user wants to use the one they specified with --python.
11340a01d76fSMarc-André Lureau    #
11350a01d76fSMarc-André Lureau    # We do not want to override the distro Python interpreter (and sometimes
11360a01d76fSMarc-André Lureau    # cannot: for example in Homebrew /usr/bin/meson is a bash script), so
11370a01d76fSMarc-André Lureau    # just require --meson=git|internal together with --python.
11380a01d76fSMarc-André Lureau    if test "$explicit_python" = yes; then
11390a01d76fSMarc-André Lureau        case "$meson" in
11400a01d76fSMarc-André Lureau            git | internal) ;;
11410a01d76fSMarc-André Lureau            *) error_exit "--python requires using QEMU's embedded Meson distribution." ;;
11420a01d76fSMarc-André Lureau        esac
11430a01d76fSMarc-André Lureau    fi
11440a01d76fSMarc-André Lureaufi
1145a5665051SPaolo Bonzini
11460a01d76fSMarc-André Lureauif test "$meson" = git; then
11470a01d76fSMarc-André Lureau    git_submodules="${git_submodules} meson"
11480a01d76fSMarc-André Lureaufi
11490a01d76fSMarc-André Lureau
11500a01d76fSMarc-André Lureaucase "$meson" in
11510a01d76fSMarc-André Lureau    git | internal)
11520a01d76fSMarc-André Lureau        meson="$python ${source_path}/meson/meson.py"
11530a01d76fSMarc-André Lureau        ;;
115484ec0c24SPaolo Bonzini    *) meson=$(command -v "$meson") ;;
11550a01d76fSMarc-André Lureauesac
11560a01d76fSMarc-André Lureau
115709e93326SPaolo Bonzini# Probe for ninja
115848328880SPaolo Bonzini
115948328880SPaolo Bonziniif test -z "$ninja"; then
116048328880SPaolo Bonzini    for c in ninja ninja-build samu; do
116148328880SPaolo Bonzini        if has $c; then
116248328880SPaolo Bonzini            ninja=$(command -v "$c")
116348328880SPaolo Bonzini            break
116448328880SPaolo Bonzini        fi
116548328880SPaolo Bonzini    done
116609e93326SPaolo Bonzini    if test -z "$ninja"; then
116709e93326SPaolo Bonzini      error_exit "Cannot find Ninja"
116809e93326SPaolo Bonzini    fi
116948328880SPaolo Bonzinifi
1170a5665051SPaolo Bonzini
11719aae6e54SDaniel Henrique Barboza# Check that the C compiler works. Doing this here before testing
11729aae6e54SDaniel Henrique Barboza# the host CPU ensures that we had a valid CC to autodetect the
11739aae6e54SDaniel Henrique Barboza# $cpu var (and we should bail right here if that's not the case).
11749aae6e54SDaniel Henrique Barboza# It also allows the help message to be printed without a CC.
11759aae6e54SDaniel Henrique Barbozawrite_c_skeleton;
11769aae6e54SDaniel Henrique Barbozaif compile_object ; then
11779aae6e54SDaniel Henrique Barboza  : C compiler works ok
11789aae6e54SDaniel Henrique Barbozaelse
11799aae6e54SDaniel Henrique Barboza    error_exit "\"$cc\" either does not exist or does not work"
11809aae6e54SDaniel Henrique Barbozafi
11819aae6e54SDaniel Henrique Barbozaif ! compile_prog ; then
11829aae6e54SDaniel Henrique Barboza    error_exit "\"$cc\" cannot build an executable (is your linker broken?)"
11839aae6e54SDaniel Henrique Barbozafi
11849aae6e54SDaniel Henrique Barboza
11859c83ffd8SPeter Maydell# Consult white-list to determine whether to enable werror
11869c83ffd8SPeter Maydell# by default.  Only enable by default for git builds
11879c83ffd8SPeter Maydellif test -z "$werror" ; then
11887d7dbf9dSDan Streetman    if test "$git_submodules_action" != "ignore" && \
1189e633a5c6SEric Blake        { test "$linux" = "yes" || test "$mingw32" = "yes"; }; then
11909c83ffd8SPeter Maydell        werror="yes"
11919c83ffd8SPeter Maydell    else
11929c83ffd8SPeter Maydell        werror="no"
11939c83ffd8SPeter Maydell    fi
11949c83ffd8SPeter Maydellfi
11959c83ffd8SPeter Maydell
1196975ff037SPaolo Bonziniif test "$targetos" = "bogus"; then
1197fb59dabdSPeter Maydell    # Now that we know that we're not printing the help and that
1198fb59dabdSPeter Maydell    # the compiler works (so the results of the check_defines we used
1199fb59dabdSPeter Maydell    # to identify the OS are reliable), if we didn't recognize the
1200fb59dabdSPeter Maydell    # host OS we should stop now.
1201951fedfcSPeter Maydell    error_exit "Unrecognized host OS (uname -s reports '$(uname -s)')"
1202fb59dabdSPeter Maydellfi
1203fb59dabdSPeter Maydell
1204efc6c070SThomas Huth# Check whether the compiler matches our minimum requirements:
1205efc6c070SThomas Huthcat > $TMPC << EOF
1206efc6c070SThomas Huth#if defined(__clang_major__) && defined(__clang_minor__)
1207efc6c070SThomas Huth# ifdef __apple_build_version__
12082a85a08cSDaniel P. Berrangé#  if __clang_major__ < 10 || (__clang_major__ == 10 && __clang_minor__ < 0)
12092a85a08cSDaniel P. Berrangé#   error You need at least XCode Clang v10.0 to compile QEMU
1210efc6c070SThomas Huth#  endif
1211efc6c070SThomas Huth# else
12122a85a08cSDaniel P. Berrangé#  if __clang_major__ < 6 || (__clang_major__ == 6 && __clang_minor__ < 0)
12132a85a08cSDaniel P. Berrangé#   error You need at least Clang v6.0 to compile QEMU
1214efc6c070SThomas Huth#  endif
1215efc6c070SThomas Huth# endif
1216efc6c070SThomas Huth#elif defined(__GNUC__) && defined(__GNUC_MINOR__)
12173830df5fSnia# if __GNUC__ < 7 || (__GNUC__ == 7 && __GNUC_MINOR__ < 4)
12183830df5fSnia#  error You need at least GCC v7.4.0 to compile QEMU
1219efc6c070SThomas Huth# endif
1220efc6c070SThomas Huth#else
1221efc6c070SThomas Huth# error You either need GCC or Clang to compiler QEMU
1222efc6c070SThomas Huth#endif
1223efc6c070SThomas Huthint main (void) { return 0; }
1224efc6c070SThomas HuthEOF
1225efc6c070SThomas Huthif ! compile_prog "" "" ; then
12263830df5fSnia    error_exit "You need at least GCC v7.4 or Clang v6.0 (or XCode Clang v10.0)"
1227efc6c070SThomas Huthfi
1228efc6c070SThomas Huth
122900849b92SRichard Henderson# Accumulate -Wfoo and -Wno-bar separately.
123000849b92SRichard Henderson# We will list all of the enable flags first, and the disable flags second.
123100849b92SRichard Henderson# Note that we do not add -Werror, because that would enable it for all
123200849b92SRichard Henderson# configure tests. If a configure test failed due to -Werror this would
123300849b92SRichard Henderson# just silently disable some features, so it's too error prone.
123400849b92SRichard Henderson
123500849b92SRichard Hendersonwarn_flags=
123600849b92SRichard Hendersonadd_to warn_flags -Wold-style-declaration
123700849b92SRichard Hendersonadd_to warn_flags -Wold-style-definition
123800849b92SRichard Hendersonadd_to warn_flags -Wtype-limits
123900849b92SRichard Hendersonadd_to warn_flags -Wformat-security
124000849b92SRichard Hendersonadd_to warn_flags -Wformat-y2k
124100849b92SRichard Hendersonadd_to warn_flags -Winit-self
124200849b92SRichard Hendersonadd_to warn_flags -Wignored-qualifiers
124300849b92SRichard Hendersonadd_to warn_flags -Wempty-body
124400849b92SRichard Hendersonadd_to warn_flags -Wnested-externs
124500849b92SRichard Hendersonadd_to warn_flags -Wendif-labels
124600849b92SRichard Hendersonadd_to warn_flags -Wexpansion-to-defined
12470a2ebce9SThomas Huthadd_to warn_flags -Wimplicit-fallthrough=2
124800849b92SRichard Henderson
124900849b92SRichard Hendersonnowarn_flags=
125000849b92SRichard Hendersonadd_to nowarn_flags -Wno-initializer-overrides
125100849b92SRichard Hendersonadd_to nowarn_flags -Wno-missing-include-dirs
125200849b92SRichard Hendersonadd_to nowarn_flags -Wno-shift-negative-value
125300849b92SRichard Hendersonadd_to nowarn_flags -Wno-string-plus-int
125400849b92SRichard Hendersonadd_to nowarn_flags -Wno-typedef-redefinition
1255aabab967SRichard Hendersonadd_to nowarn_flags -Wno-tautological-type-limit-compare
1256bac8d222SRichard Hendersonadd_to nowarn_flags -Wno-psabi
125700849b92SRichard Henderson
125800849b92SRichard Hendersongcc_flags="$warn_flags $nowarn_flags"
125993b25869SJohn Snow
126093b25869SJohn Snowcc_has_warning_flag() {
126193b25869SJohn Snow    write_c_skeleton;
126293b25869SJohn Snow
1263a1d29d6cSPeter Maydell    # Use the positive sense of the flag when testing for -Wno-wombat
1264a1d29d6cSPeter Maydell    # support (gcc will happily accept the -Wno- form of unknown
1265a1d29d6cSPeter Maydell    # warning options).
126693b25869SJohn Snow    optflag="$(echo $1 | sed -e 's/^-Wno-/-W/')"
126793b25869SJohn Snow    compile_prog "-Werror $optflag" ""
126893b25869SJohn Snow}
126993b25869SJohn Snow
12704cb37d11SPhilippe Mathieu-Daudéobjcc_has_warning_flag() {
12714cb37d11SPhilippe Mathieu-Daudé    cat > $TMPM <<EOF
12724cb37d11SPhilippe Mathieu-Daudéint main(void) { return 0; }
12734cb37d11SPhilippe Mathieu-DaudéEOF
12744cb37d11SPhilippe Mathieu-Daudé
12754cb37d11SPhilippe Mathieu-Daudé    # Use the positive sense of the flag when testing for -Wno-wombat
12764cb37d11SPhilippe Mathieu-Daudé    # support (gcc will happily accept the -Wno- form of unknown
12774cb37d11SPhilippe Mathieu-Daudé    # warning options).
12784cb37d11SPhilippe Mathieu-Daudé    optflag="$(echo $1 | sed -e 's/^-Wno-/-W/')"
12794cb37d11SPhilippe Mathieu-Daudé    do_objc -Werror $optflag \
12804cb37d11SPhilippe Mathieu-Daudé      $OBJCFLAGS $EXTRA_OBJCFLAGS $CONFIGURE_OBJCFLAGS $QEMU_OBJCFLAGS \
12814cb37d11SPhilippe Mathieu-Daudé      -o $TMPE $TMPM $QEMU_LDFLAGS
12824cb37d11SPhilippe Mathieu-Daudé}
12834cb37d11SPhilippe Mathieu-Daudé
128493b25869SJohn Snowfor flag in $gcc_flags; do
128593b25869SJohn Snow    if cc_has_warning_flag $flag ; then
12868d05095cSPaolo Bonzini        QEMU_CFLAGS="$QEMU_CFLAGS $flag"
12878d05095cSPaolo Bonzini    fi
12884cb37d11SPhilippe Mathieu-Daudé    if objcc_has_warning_flag $flag ; then
12894cb37d11SPhilippe Mathieu-Daudé        QEMU_OBJCFLAGS="$QEMU_OBJCFLAGS $flag"
12904cb37d11SPhilippe Mathieu-Daudé    fi
12918d05095cSPaolo Bonzinidone
12928d05095cSPaolo Bonzini
129363678e17SSteven Noonanif test "$stack_protector" != "no"; then
1294fccd35a0SRodrigo Rebello  cat > $TMPC << EOF
1295fccd35a0SRodrigo Rebelloint main(int argc, char *argv[])
1296fccd35a0SRodrigo Rebello{
1297fccd35a0SRodrigo Rebello    char arr[64], *p = arr, *c = argv[0];
1298fccd35a0SRodrigo Rebello    while (*c) {
1299fccd35a0SRodrigo Rebello        *p++ = *c++;
1300fccd35a0SRodrigo Rebello    }
1301fccd35a0SRodrigo Rebello    return 0;
1302fccd35a0SRodrigo Rebello}
1303fccd35a0SRodrigo RebelloEOF
130463678e17SSteven Noonan  gcc_flags="-fstack-protector-strong -fstack-protector-all"
13053b463a3fSMiroslav Rezanina  sp_on=0
130663678e17SSteven Noonan  for flag in $gcc_flags; do
1307590e5dd9SPeter Maydell    # We need to check both a compile and a link, since some compiler
1308590e5dd9SPeter Maydell    # setups fail only on a .c->.o compile and some only at link time
1309086d5f75SPaolo Bonzini    if compile_object "-Werror $flag" &&
1310590e5dd9SPeter Maydell       compile_prog "-Werror $flag" ""; then
131163678e17SSteven Noonan      QEMU_CFLAGS="$QEMU_CFLAGS $flag"
1312db5adeaaSPaolo Bonzini      QEMU_LDFLAGS="$QEMU_LDFLAGS $flag"
13133b463a3fSMiroslav Rezanina      sp_on=1
131463678e17SSteven Noonan      break
131563678e17SSteven Noonan    fi
131663678e17SSteven Noonan  done
13173b463a3fSMiroslav Rezanina  if test "$stack_protector" = yes; then
13183b463a3fSMiroslav Rezanina    if test $sp_on = 0; then
13193b463a3fSMiroslav Rezanina      error_exit "Stack protector not supported"
13203b463a3fSMiroslav Rezanina    fi
13213b463a3fSMiroslav Rezanina  fi
132237746c5eSMarc-André Lureaufi
132337746c5eSMarc-André Lureau
132420bc94a2SPaolo Bonzini# Disable -Wmissing-braces on older compilers that warn even for
132520bc94a2SPaolo Bonzini# the "universal" C zero initializer {0}.
132620bc94a2SPaolo Bonzinicat > $TMPC << EOF
132720bc94a2SPaolo Bonzinistruct {
132820bc94a2SPaolo Bonzini  int a[2];
132920bc94a2SPaolo Bonzini} x = {0};
133020bc94a2SPaolo BonziniEOF
133120bc94a2SPaolo Bonziniif compile_object "-Werror" "" ; then
133220bc94a2SPaolo Bonzini  :
133320bc94a2SPaolo Bonzinielse
133420bc94a2SPaolo Bonzini  QEMU_CFLAGS="$QEMU_CFLAGS -Wno-missing-braces"
133520bc94a2SPaolo Bonzinifi
133620bc94a2SPaolo Bonzini
133721e709aaSMarc-André Lureau# Our module code doesn't support Windows
133821e709aaSMarc-André Lureauif test "$modules" = "yes" && test "$mingw32" = "yes" ; then
133921e709aaSMarc-André Lureau  error_exit "Modules are not available for Windows"
134021e709aaSMarc-André Lureaufi
134121e709aaSMarc-André Lureau
13425f2453acSAlex Bennée# Static linking is not possible with plugins, modules or PIE
134340d6444eSAvi Kivityif test "$static" = "yes" ; then
1344aa0d1f44SPaolo Bonzini  if test "$modules" = "yes" ; then
1345aa0d1f44SPaolo Bonzini    error_exit "static and modules are mutually incompatible"
1346aa0d1f44SPaolo Bonzini  fi
13475f2453acSAlex Bennée  if test "$plugins" = "yes"; then
13485f2453acSAlex Bennée    error_exit "static and plugins are mutually incompatible"
1349ba4dd2aaSAlex Bennée  else
1350ba4dd2aaSAlex Bennée    plugins="no"
13515f2453acSAlex Bennée  fi
135240d6444eSAvi Kivityfi
135337650689SPaolo Bonzinitest "$plugins" = "" && plugins=yes
135440d6444eSAvi Kivity
135540d6444eSAvi Kivitycat > $TMPC << EOF
135621d4a791SAvi Kivity
135721d4a791SAvi Kivity#ifdef __linux__
135821d4a791SAvi Kivity#  define THREAD __thread
135921d4a791SAvi Kivity#else
136021d4a791SAvi Kivity#  define THREAD
136121d4a791SAvi Kivity#endif
136221d4a791SAvi Kivitystatic THREAD int tls_var;
136321d4a791SAvi Kivityint main(void) { return tls_var; }
136440d6444eSAvi KivityEOF
1365b2634124SRichard Henderson
136612781462SRichard Hendersonif test "$static" = "yes"; then
1367eca7a8e6SRichard Henderson  if test "$pie" != "no" && compile_prog "-Werror -fPIE -DPIE" "-static-pie"; then
13685770e8afSPaolo Bonzini    CONFIGURE_CFLAGS="-fPIE -DPIE $CONFIGURE_CFLAGS"
136912781462SRichard Henderson    QEMU_LDFLAGS="-static-pie $QEMU_LDFLAGS"
137012781462SRichard Henderson    pie="yes"
137112781462SRichard Henderson  elif test "$pie" = "yes"; then
137212781462SRichard Henderson    error_exit "-static-pie not available due to missing toolchain support"
137312781462SRichard Henderson  else
137412781462SRichard Henderson    QEMU_LDFLAGS="-static $QEMU_LDFLAGS"
137512781462SRichard Henderson    pie="no"
137612781462SRichard Henderson  fi
137712781462SRichard Hendersonelif test "$pie" = "no"; then
1378b9eae9efSPaolo Bonzini  if compile_prog "-Werror -fno-pie" "-no-pie"; then
1379b9eae9efSPaolo Bonzini    CONFIGURE_CFLAGS="-fno-pie $CONFIGURE_CFLAGS"
1380b9eae9efSPaolo Bonzini    CONFIGURE_LDFLAGS="-no-pie $CONFIGURE_LDFLAGS"
1381abafb64bSAlex Bennée    # Meson currently only handles pie as a boolean for now so if we have
1382abafb64bSAlex Bennée    # explicitly disabled PIE we need to extend our cflags because it wont.
1383abafb64bSAlex Bennée    QEMU_CFLAGS="-fno-pie -no-pie $QEMU_CFLAGS"
1384b9eae9efSPaolo Bonzini  fi
1385eca7a8e6SRichard Hendersonelif compile_prog "-Werror -fPIE -DPIE" "-pie"; then
13865770e8afSPaolo Bonzini  CONFIGURE_CFLAGS="-fPIE -DPIE $CONFIGURE_CFLAGS"
13875770e8afSPaolo Bonzini  CONFIGURE_LDFLAGS="-pie $CONFIGURE_LDFLAGS"
138840d6444eSAvi Kivity  pie="yes"
13892c674109SRichard Hendersonelif test "$pie" = "yes"; then
139076ad07a4SPeter Maydell  error_exit "PIE not available due to missing toolchain support"
139140d6444eSAvi Kivityelse
139240d6444eSAvi Kivity  echo "Disabling PIE due to missing toolchain support"
139340d6444eSAvi Kivity  pie="no"
139440d6444eSAvi Kivityfi
139540d6444eSAvi Kivity
1396e6cbd751SRichard Henderson# Detect support for PT_GNU_RELRO + DT_BIND_NOW.
1397e6cbd751SRichard Henderson# The combination is known as "full relro", because .got.plt is read-only too.
1398e6cbd751SRichard Hendersonif compile_prog "" "-Wl,-z,relro -Wl,-z,now" ; then
1399e6cbd751SRichard Henderson  QEMU_LDFLAGS="-Wl,-z,relro -Wl,-z,now $QEMU_LDFLAGS"
1400e6cbd751SRichard Hendersonfi
1401e6cbd751SRichard Henderson
140209dada40SPaolo Bonzini##########################################
140309dada40SPaolo Bonzini# __sync_fetch_and_and requires at least -march=i486. Many toolchains
140409dada40SPaolo Bonzini# use i686 as default anyway, but for those that don't, an explicit
140509dada40SPaolo Bonzini# specification is necessary
140609dada40SPaolo Bonzini
140709dada40SPaolo Bonziniif test "$cpu" = "i386"; then
140809dada40SPaolo Bonzini  cat > $TMPC << EOF
140909dada40SPaolo Bonzinistatic int sfaa(int *ptr)
141009dada40SPaolo Bonzini{
141109dada40SPaolo Bonzini  return __sync_fetch_and_and(ptr, 0);
141209dada40SPaolo Bonzini}
141309dada40SPaolo Bonzini
141409dada40SPaolo Bonziniint main(void)
141509dada40SPaolo Bonzini{
141609dada40SPaolo Bonzini  int val = 42;
14171405b629SStefan Weil  val = __sync_val_compare_and_swap(&val, 0, 1);
141809dada40SPaolo Bonzini  sfaa(&val);
141909dada40SPaolo Bonzini  return val;
142009dada40SPaolo Bonzini}
142109dada40SPaolo BonziniEOF
142209dada40SPaolo Bonzini  if ! compile_prog "" "" ; then
142309dada40SPaolo Bonzini    QEMU_CFLAGS="-march=i486 $QEMU_CFLAGS"
142409dada40SPaolo Bonzini  fi
142509dada40SPaolo Bonzinifi
142609dada40SPaolo Bonzini
1427afb63ebdSStefan Weilif test -z "${target_list+xxx}" ; then
1428fdb75aefSPaolo Bonzini    default_targets=yes
1429d880a3baSPaolo Bonzini    for target in $default_target_list; do
1430d880a3baSPaolo Bonzini        target_list="$target_list $target"
1431d880a3baSPaolo Bonzini    done
1432d880a3baSPaolo Bonzini    target_list="${target_list# }"
1433121afa9eSAnthony Liguorielse
1434fdb75aefSPaolo Bonzini    default_targets=no
143589138857SStefan Weil    target_list=$(echo "$target_list" | sed -e 's/,/ /g')
1436d880a3baSPaolo Bonzini    for target in $target_list; do
143725b48338SPeter Maydell        # Check that we recognised the target name; this allows a more
143825b48338SPeter Maydell        # friendly error message than if we let it fall through.
143925b48338SPeter Maydell        case " $default_target_list " in
144025b48338SPeter Maydell            *" $target "*)
144125b48338SPeter Maydell                ;;
144225b48338SPeter Maydell            *)
144325b48338SPeter Maydell                error_exit "Unknown target name '$target'"
144425b48338SPeter Maydell                ;;
144525b48338SPeter Maydell        esac
144625b48338SPeter Maydell    done
1447d880a3baSPaolo Bonzinifi
144825b48338SPeter Maydell
1449f55fe278SPaolo Bonzini# see if system emulation was really requested
1450f55fe278SPaolo Bonzinicase " $target_list " in
1451f55fe278SPaolo Bonzini  *"-softmmu "*) softmmu=yes
1452f55fe278SPaolo Bonzini  ;;
1453f55fe278SPaolo Bonzini  *) softmmu=no
1454f55fe278SPaolo Bonzini  ;;
1455f55fe278SPaolo Bonziniesac
14565327cf48Sbellard
14577630156dSPhilippe Mathieu-Daudéif test "$tcg" = "auto"; then
14587630156dSPhilippe Mathieu-Daudé  if test -z "$target_list"; then
14597630156dSPhilippe Mathieu-Daudé    tcg="disabled"
14607630156dSPhilippe Mathieu-Daudé  else
14617630156dSPhilippe Mathieu-Daudé    tcg="enabled"
14627630156dSPhilippe Mathieu-Daudé  fi
14637630156dSPhilippe Mathieu-Daudéfi
14647630156dSPhilippe Mathieu-Daudé
14657630156dSPhilippe Mathieu-Daudéif test "$tcg" = "enabled"; then
14667630156dSPhilippe Mathieu-Daudé    git_submodules="$git_submodules tests/fp/berkeley-testfloat-3"
14677630156dSPhilippe Mathieu-Daudé    git_submodules="$git_submodules tests/fp/berkeley-softfloat-3"
14687630156dSPhilippe Mathieu-Daudéfi
14697630156dSPhilippe Mathieu-Daudé
14707d13299dSbellard# ---
14717d13299dSbellard# big/little endian test
14727d13299dSbellardcat > $TMPC << EOF
1473659eb157SThomas Huth#include <stdio.h>
147461cc919fSMike Frysingershort big_endian[] = { 0x4269, 0x4765, 0x4e64, 0x4961, 0x4e00, 0, };
147561cc919fSMike Frysingershort little_endian[] = { 0x694c, 0x7454, 0x654c, 0x6e45, 0x6944, 0x6e41, 0, };
1476659eb157SThomas Huthint main(int argc, char *argv[])
1477659eb157SThomas Huth{
1478659eb157SThomas Huth    return printf("%s %s\n", (char *)big_endian, (char *)little_endian);
14797d13299dSbellard}
14807d13299dSbellardEOF
14817d13299dSbellard
1482659eb157SThomas Huthif compile_prog ; then
1483659eb157SThomas Huth    if strings -a $TMPE | grep -q BiGeNdIaN ; then
148461cc919fSMike Frysinger        bigendian="yes"
1485659eb157SThomas Huth    elif strings -a $TMPE | grep -q LiTtLeEnDiAn ; then
148661cc919fSMike Frysinger        bigendian="no"
14877d13299dSbellard    else
14887d13299dSbellard        echo big/little test failed
1489659eb157SThomas Huth        exit 1
14907d13299dSbellard    fi
14917d13299dSbellardelse
149261cc919fSMike Frysinger    echo big/little test failed
1493659eb157SThomas Huth    exit 1
14947d13299dSbellardfi
14957d13299dSbellard
1496015a33bdSGonglei##########################################
1497779ab5e3SStefan Weil# pkg-config probe
1498779ab5e3SStefan Weil
1499779ab5e3SStefan Weilif ! has "$pkg_config_exe"; then
150076ad07a4SPeter Maydell  error_exit "pkg-config binary '$pkg_config_exe' not found"
1501779ab5e3SStefan Weilfi
1502779ab5e3SStefan Weil
1503779ab5e3SStefan Weil##########################################
1504e18df141SAnthony Liguori# glib support probe
1505a52d28afSPaolo Bonzini
15060ce9b08cSThomas Huth# When bumping glib_req_ver, please check also whether we should increase
15070ce9b08cSThomas Huth# the _WIN32_WINNT setting in osdep.h according to the value from glib
1508b4c6036fSDaniel P. Berrangéglib_req_ver=2.56
1509aa0d1f44SPaolo Bonziniglib_modules=gthread-2.0
1510aa0d1f44SPaolo Bonziniif test "$modules" = yes; then
1511a88afc64SGerd Hoffmann    glib_modules="$glib_modules gmodule-export-2.0"
1512b906acacSPaolo Bonzinielif test "$plugins" = "yes"; then
1513b906acacSPaolo Bonzini    glib_modules="$glib_modules gmodule-no-export-2.0"
151454cb65d8SEmilio G. Cotafi
1515e26110cfSFam Zheng
1516aa0d1f44SPaolo Bonzinifor i in $glib_modules; do
1517e26110cfSFam Zheng    if $pkg_config --atleast-version=$glib_req_ver $i; then
151889138857SStefan Weil        glib_cflags=$($pkg_config --cflags $i)
151989138857SStefan Weil        glib_libs=$($pkg_config --libs $i)
1520e18df141SAnthony Liguori    else
1521e26110cfSFam Zheng        error_exit "glib-$glib_req_ver $i is required to compile QEMU"
1522e26110cfSFam Zheng    fi
1523e26110cfSFam Zhengdone
1524e26110cfSFam Zheng
15255b9e7d05SMarc-André Lureauglib_bindir="$($pkg_config --variable=bindir glib-2.0)"
15265b9e7d05SMarc-André Lureauif test -z "$glib_bindir" ; then
15275b9e7d05SMarc-André Lureau	glib_bindir="$($pkg_config --variable=prefix glib-2.0)"/bin
15285b9e7d05SMarc-André Lureaufi
15295b9e7d05SMarc-André Lureau
1530215b0c2fSPaolo Bonzini# This workaround is required due to a bug in pkg-config file for glib as it
1531215b0c2fSPaolo Bonzini# doesn't define GLIB_STATIC_COMPILATION for pkg-config --static
1532215b0c2fSPaolo Bonzini
1533215b0c2fSPaolo Bonziniif test "$static" = yes && test "$mingw32" = yes; then
1534215b0c2fSPaolo Bonzini    glib_cflags="-DGLIB_STATIC_COMPILATION $glib_cflags"
1535215b0c2fSPaolo Bonzinifi
1536215b0c2fSPaolo Bonzini
1537977a82abSDaniel P. Berrange# Sanity check that the current size_t matches the
1538977a82abSDaniel P. Berrange# size that glib thinks it should be. This catches
1539977a82abSDaniel P. Berrange# problems on multi-arch where people try to build
1540977a82abSDaniel P. Berrange# 32-bit QEMU while pointing at 64-bit glib headers
1541977a82abSDaniel P. Berrangecat > $TMPC <<EOF
1542977a82abSDaniel P. Berrange#include <glib.h>
1543977a82abSDaniel P. Berrange#include <unistd.h>
1544977a82abSDaniel P. Berrange
1545977a82abSDaniel P. Berrange#define QEMU_BUILD_BUG_ON(x) \
1546977a82abSDaniel P. Berrange  typedef char qemu_build_bug_on[(x)?-1:1] __attribute__((unused));
1547977a82abSDaniel P. Berrange
1548977a82abSDaniel P. Berrangeint main(void) {
1549977a82abSDaniel P. Berrange   QEMU_BUILD_BUG_ON(sizeof(size_t) != GLIB_SIZEOF_SIZE_T);
1550977a82abSDaniel P. Berrange   return 0;
1551977a82abSDaniel P. Berrange}
1552977a82abSDaniel P. BerrangeEOF
1553977a82abSDaniel P. Berrange
1554215b0c2fSPaolo Bonziniif ! compile_prog "$glib_cflags" "$glib_libs" ; then
1555977a82abSDaniel P. Berrange    error_exit "sizeof(size_t) doesn't match GLIB_SIZEOF_SIZE_T."\
1556977a82abSDaniel P. Berrange               "You probably need to set PKG_CONFIG_LIBDIR"\
1557977a82abSDaniel P. Berrange	       "to point to the right pkg-config files for your"\
1558977a82abSDaniel P. Berrange	       "build target"
1559977a82abSDaniel P. Berrangefi
1560977a82abSDaniel P. Berrange
15619bda600bSEric Blake# Silence clang warnings triggered by glib < 2.57.2
15629bda600bSEric Blakecat > $TMPC << EOF
15639bda600bSEric Blake#include <glib.h>
15649bda600bSEric Blaketypedef struct Foo {
15659bda600bSEric Blake    int i;
15669bda600bSEric Blake} Foo;
15679bda600bSEric Blakestatic void foo_free(Foo *f)
15689bda600bSEric Blake{
15699bda600bSEric Blake    g_free(f);
15709bda600bSEric Blake}
1571e0e7fe07SMarc-André LureauG_DEFINE_AUTOPTR_CLEANUP_FUNC(Foo, foo_free)
15729bda600bSEric Blakeint main(void) { return 0; }
15739bda600bSEric BlakeEOF
15749bda600bSEric Blakeif ! compile_prog "$glib_cflags -Werror" "$glib_libs" ; then
15759bda600bSEric Blake    if cc_has_warning_flag "-Wno-unused-function"; then
15769bda600bSEric Blake        glib_cflags="$glib_cflags -Wno-unused-function"
15775770e8afSPaolo Bonzini        CONFIGURE_CFLAGS="$CONFIGURE_CFLAGS -Wno-unused-function"
15789bda600bSEric Blake    fi
15799bda600bSEric Blakefi
15809bda600bSEric Blake
1581e26110cfSFam Zheng##########################################
1582f652e6afSaurel32# fdt probe
1583e169e1e1SPeter Maydell
1584fbb4121dSPaolo Bonzinicase "$fdt" in
1585fbb4121dSPaolo Bonzini  auto | enabled | internal)
1586fbb4121dSPaolo Bonzini    # Simpler to always update submodule, even if not needed.
1587aef45d51SDaniel P. Berrange    git_submodules="${git_submodules} dtc"
1588fbb4121dSPaolo Bonzini    ;;
1589fbb4121dSPaolo Bonziniesac
1590f652e6afSaurel32
159120ff075bSMichael Walle##########################################
1592519175a2SAlex Barcelo# check and set a backend for coroutine
1593d0e2fce5SAneesh Kumar K.V
15947c2acc70SPeter Maydell# We prefer ucontext, but it's not always possible. The fallback
159533c53c54SDaniel P. Berrange# is sigcontext. On Windows the only valid backend is the Windows
159633c53c54SDaniel P. Berrange# specific one.
15977c2acc70SPeter Maydell
15987c2acc70SPeter Maydellucontext_works=no
1599d0e2fce5SAneesh Kumar K.Vif test "$darwin" != "yes"; then
1600d0e2fce5SAneesh Kumar K.V  cat > $TMPC << EOF
1601d0e2fce5SAneesh Kumar K.V#include <ucontext.h>
1602cdf84806SPeter Maydell#ifdef __stub_makecontext
1603cdf84806SPeter Maydell#error Ignoring glibc stub makecontext which will always fail
1604cdf84806SPeter Maydell#endif
160575cafad7SStefan Weilint main(void) { makecontext(0, 0, 0); return 0; }
1606d0e2fce5SAneesh Kumar K.VEOF
1607d0e2fce5SAneesh Kumar K.V  if compile_prog "" "" ; then
16087c2acc70SPeter Maydell    ucontext_works=yes
1609d0e2fce5SAneesh Kumar K.V  fi
1610519175a2SAlex Barcelofi
16117c2acc70SPeter Maydell
16127c2acc70SPeter Maydellif test "$coroutine" = ""; then
16137c2acc70SPeter Maydell  if test "$mingw32" = "yes"; then
16147c2acc70SPeter Maydell    coroutine=win32
16157c2acc70SPeter Maydell  elif test "$ucontext_works" = "yes"; then
16167c2acc70SPeter Maydell    coroutine=ucontext
1617519175a2SAlex Barcelo  else
16187c2acc70SPeter Maydell    coroutine=sigaltstack
16197c2acc70SPeter Maydell  fi
16207c2acc70SPeter Maydellelse
16217c2acc70SPeter Maydell  case $coroutine in
16227c2acc70SPeter Maydell  windows)
16237c2acc70SPeter Maydell    if test "$mingw32" != "yes"; then
16247c2acc70SPeter Maydell      error_exit "'windows' coroutine backend only valid for Windows"
16257c2acc70SPeter Maydell    fi
16267c2acc70SPeter Maydell    # Unfortunately the user visible backend name doesn't match the
16277c2acc70SPeter Maydell    # coroutine-*.c filename for this case, so we have to adjust it here.
16287c2acc70SPeter Maydell    coroutine=win32
16297c2acc70SPeter Maydell    ;;
16307c2acc70SPeter Maydell  ucontext)
16317c2acc70SPeter Maydell    if test "$ucontext_works" != "yes"; then
16327cb58448SPaolo Bonzini      error_exit "'ucontext' backend requested but makecontext not available"
16337c2acc70SPeter Maydell    fi
16347c2acc70SPeter Maydell    ;;
163533c53c54SDaniel P. Berrange  sigaltstack)
16367c2acc70SPeter Maydell    if test "$mingw32" = "yes"; then
16377c2acc70SPeter Maydell      error_exit "only the 'windows' coroutine backend is valid for Windows"
16387c2acc70SPeter Maydell    fi
16397c2acc70SPeter Maydell    ;;
16407c2acc70SPeter Maydell  *)
164176ad07a4SPeter Maydell    error_exit "unknown coroutine backend $coroutine"
16427c2acc70SPeter Maydell    ;;
16437c2acc70SPeter Maydell  esac
1644d0e2fce5SAneesh Kumar K.Vfi
1645d0e2fce5SAneesh Kumar K.V
16461e4f6065SDaniele Buono##################################################
16471e4f6065SDaniele Buono# SafeStack
16481e4f6065SDaniele Buono
16491e4f6065SDaniele Buono
16501e4f6065SDaniele Buonoif test "$safe_stack" = "yes"; then
16511e4f6065SDaniele Buonocat > $TMPC << EOF
16521e4f6065SDaniele Buonoint main(int argc, char *argv[])
16531e4f6065SDaniele Buono{
16541e4f6065SDaniele Buono#if ! __has_feature(safe_stack)
16551e4f6065SDaniele Buono#error SafeStack Disabled
16561e4f6065SDaniele Buono#endif
16571e4f6065SDaniele Buono    return 0;
16581e4f6065SDaniele Buono}
16591e4f6065SDaniele BuonoEOF
16601e4f6065SDaniele Buono  flag="-fsanitize=safe-stack"
16611e4f6065SDaniele Buono  # Check that safe-stack is supported and enabled.
16621e4f6065SDaniele Buono  if compile_prog "-Werror $flag" "$flag"; then
16631e4f6065SDaniele Buono    # Flag needed both at compilation and at linking
16641e4f6065SDaniele Buono    QEMU_CFLAGS="$QEMU_CFLAGS $flag"
16651e4f6065SDaniele Buono    QEMU_LDFLAGS="$QEMU_LDFLAGS $flag"
16661e4f6065SDaniele Buono  else
16671e4f6065SDaniele Buono    error_exit "SafeStack not supported by your compiler"
16681e4f6065SDaniele Buono  fi
16691e4f6065SDaniele Buono  if test "$coroutine" != "ucontext"; then
16701e4f6065SDaniele Buono    error_exit "SafeStack is only supported by the coroutine backend ucontext"
16711e4f6065SDaniele Buono  fi
16721e4f6065SDaniele Buonoelse
16731e4f6065SDaniele Buonocat > $TMPC << EOF
16741e4f6065SDaniele Buonoint main(int argc, char *argv[])
16751e4f6065SDaniele Buono{
16761e4f6065SDaniele Buono#if defined(__has_feature)
16771e4f6065SDaniele Buono#if __has_feature(safe_stack)
16781e4f6065SDaniele Buono#error SafeStack Enabled
16791e4f6065SDaniele Buono#endif
16801e4f6065SDaniele Buono#endif
16811e4f6065SDaniele Buono    return 0;
16821e4f6065SDaniele Buono}
16831e4f6065SDaniele BuonoEOF
16841e4f6065SDaniele Buonoif test "$safe_stack" = "no"; then
16851e4f6065SDaniele Buono  # Make sure that safe-stack is disabled
16861e4f6065SDaniele Buono  if ! compile_prog "-Werror" ""; then
16871e4f6065SDaniele Buono    # SafeStack was already enabled, try to explicitly remove the feature
16881e4f6065SDaniele Buono    flag="-fno-sanitize=safe-stack"
16891e4f6065SDaniele Buono    if ! compile_prog "-Werror $flag" "$flag"; then
16901e4f6065SDaniele Buono      error_exit "Configure cannot disable SafeStack"
16911e4f6065SDaniele Buono    fi
16921e4f6065SDaniele Buono    QEMU_CFLAGS="$QEMU_CFLAGS $flag"
16931e4f6065SDaniele Buono    QEMU_LDFLAGS="$QEMU_LDFLAGS $flag"
16941e4f6065SDaniele Buono  fi
16951e4f6065SDaniele Buonoelse # "$safe_stack" = ""
16961e4f6065SDaniele Buono  # Set safe_stack to yes or no based on pre-existing flags
16971e4f6065SDaniele Buono  if compile_prog "-Werror" ""; then
16981e4f6065SDaniele Buono    safe_stack="no"
16991e4f6065SDaniele Buono  else
17001e4f6065SDaniele Buono    safe_stack="yes"
17011e4f6065SDaniele Buono    if test "$coroutine" != "ucontext"; then
17021e4f6065SDaniele Buono      error_exit "SafeStack is only supported by the coroutine backend ucontext"
17031e4f6065SDaniele Buono    fi
17041e4f6065SDaniele Buono  fi
17051e4f6065SDaniele Buonofi
17061e4f6065SDaniele Buonofi
17077d992e4dSPeter Lieven
170876a347e1SRichard Henderson########################################
1709fd0e6053SJohn Snow# check if ccache is interfering with
1710fd0e6053SJohn Snow# semantic analysis of macros
1711fd0e6053SJohn Snow
17125e4dfd3dSJohn Snowunset CCACHE_CPP2
1713fd0e6053SJohn Snowccache_cpp2=no
1714fd0e6053SJohn Snowcat > $TMPC << EOF
1715fd0e6053SJohn Snowstatic const int Z = 1;
1716fd0e6053SJohn Snow#define fn() ({ Z; })
1717fd0e6053SJohn Snow#define TAUT(X) ((X) == Z)
1718fd0e6053SJohn Snow#define PAREN(X, Y) (X == Y)
1719fd0e6053SJohn Snow#define ID(X) (X)
1720fd0e6053SJohn Snowint main(int argc, char *argv[])
1721fd0e6053SJohn Snow{
1722fd0e6053SJohn Snow    int x = 0, y = 0;
1723fd0e6053SJohn Snow    x = ID(x);
1724fd0e6053SJohn Snow    x = fn();
1725fd0e6053SJohn Snow    fn();
1726fd0e6053SJohn Snow    if (PAREN(x, y)) return 0;
1727fd0e6053SJohn Snow    if (TAUT(Z)) return 0;
1728fd0e6053SJohn Snow    return 0;
1729fd0e6053SJohn Snow}
1730fd0e6053SJohn SnowEOF
1731fd0e6053SJohn Snow
1732fd0e6053SJohn Snowif ! compile_object "-Werror"; then
1733fd0e6053SJohn Snow    ccache_cpp2=yes
1734fd0e6053SJohn Snowfi
1735fd0e6053SJohn Snow
1736b553a042SJohn Snow#################################################
1737b553a042SJohn Snow# clang does not support glibc + FORTIFY_SOURCE.
1738b553a042SJohn Snow
1739b553a042SJohn Snowif test "$fortify_source" != "no"; then
1740b553a042SJohn Snow  if echo | $cc -dM -E - | grep __clang__ > /dev/null 2>&1 ; then
1741b553a042SJohn Snow    fortify_source="no";
1742e189091fSPeter Maydell  elif test -n "$cxx" && has $cxx &&
1743cfcc7c14SJohn Snow       echo | $cxx -dM -E - | grep __clang__ >/dev/null 2>&1 ; then
1744b553a042SJohn Snow    fortify_source="no";
1745b553a042SJohn Snow  else
1746b553a042SJohn Snow    fortify_source="yes"
1747b553a042SJohn Snow  fi
1748b553a042SJohn Snowfi
1749b553a042SJohn Snow
1750d2042378SAneesh Kumar K.V##########################################
1751247724cbSMarc-André Lureau# checks for sanitizers
1752247724cbSMarc-André Lureau
1753247724cbSMarc-André Lureauhave_asan=no
1754247724cbSMarc-André Lureauhave_ubsan=no
1755d83414e1SMarc-André Lureauhave_asan_iface_h=no
1756d83414e1SMarc-André Lureauhave_asan_iface_fiber=no
1757247724cbSMarc-André Lureau
1758247724cbSMarc-André Lureauif test "$sanitizers" = "yes" ; then
1759b9f44da2SMarc-André Lureau  write_c_skeleton
1760247724cbSMarc-André Lureau  if compile_prog "$CPU_CFLAGS -Werror -fsanitize=address" ""; then
1761247724cbSMarc-André Lureau      have_asan=yes
1762247724cbSMarc-André Lureau  fi
1763b9f44da2SMarc-André Lureau
1764b9f44da2SMarc-André Lureau  # we could use a simple skeleton for flags checks, but this also
1765b9f44da2SMarc-André Lureau  # detect the static linking issue of ubsan, see also:
1766b9f44da2SMarc-André Lureau  # https://gcc.gnu.org/bugzilla/show_bug.cgi?id=84285
1767b9f44da2SMarc-André Lureau  cat > $TMPC << EOF
1768b9f44da2SMarc-André Lureau#include <stdlib.h>
1769b9f44da2SMarc-André Lureauint main(void) {
1770b9f44da2SMarc-André Lureau    void *tmp = malloc(10);
1771f2dfe54cSLeonid Bloch    if (tmp != NULL) {
1772b9f44da2SMarc-André Lureau        return *(int *)(tmp + 2);
1773b9f44da2SMarc-André Lureau    }
1774d1abf3fcSOlaf Hering    return 1;
1775f2dfe54cSLeonid Bloch}
1776b9f44da2SMarc-André LureauEOF
1777247724cbSMarc-André Lureau  if compile_prog "$CPU_CFLAGS -Werror -fsanitize=undefined" ""; then
1778247724cbSMarc-André Lureau      have_ubsan=yes
1779247724cbSMarc-André Lureau  fi
1780d83414e1SMarc-André Lureau
1781d83414e1SMarc-André Lureau  if check_include "sanitizer/asan_interface.h" ; then
1782d83414e1SMarc-André Lureau      have_asan_iface_h=yes
1783d83414e1SMarc-André Lureau  fi
1784d83414e1SMarc-André Lureau
1785d83414e1SMarc-André Lureau  cat > $TMPC << EOF
1786d83414e1SMarc-André Lureau#include <sanitizer/asan_interface.h>
1787d83414e1SMarc-André Lureauint main(void) {
1788d83414e1SMarc-André Lureau  __sanitizer_start_switch_fiber(0, 0, 0);
1789d83414e1SMarc-André Lureau  return 0;
1790d83414e1SMarc-André Lureau}
1791d83414e1SMarc-André LureauEOF
1792d83414e1SMarc-André Lureau  if compile_prog "$CPU_CFLAGS -Werror -fsanitize=address" "" ; then
1793d83414e1SMarc-André Lureau      have_asan_iface_fiber=yes
1794d83414e1SMarc-André Lureau  fi
1795247724cbSMarc-André Lureaufi
1796247724cbSMarc-André Lureau
17970aebab04SLingfeng Yang# Thread sanitizer is, for now, much noisier than the other sanitizers;
17980aebab04SLingfeng Yang# keep it separate until that is not the case.
17990aebab04SLingfeng Yangif test "$tsan" = "yes" && test "$sanitizers" = "yes"; then
18000aebab04SLingfeng Yang  error_exit "TSAN is not supported with other sanitiziers."
18010aebab04SLingfeng Yangfi
18020aebab04SLingfeng Yanghave_tsan=no
18030aebab04SLingfeng Yanghave_tsan_iface_fiber=no
18040aebab04SLingfeng Yangif test "$tsan" = "yes" ; then
18050aebab04SLingfeng Yang  write_c_skeleton
18060aebab04SLingfeng Yang  if compile_prog "$CPU_CFLAGS -Werror -fsanitize=thread" "" ; then
18070aebab04SLingfeng Yang      have_tsan=yes
18080aebab04SLingfeng Yang  fi
18090aebab04SLingfeng Yang  cat > $TMPC << EOF
18100aebab04SLingfeng Yang#include <sanitizer/tsan_interface.h>
18110aebab04SLingfeng Yangint main(void) {
18120aebab04SLingfeng Yang  __tsan_create_fiber(0);
18130aebab04SLingfeng Yang  return 0;
18140aebab04SLingfeng Yang}
18150aebab04SLingfeng YangEOF
18160aebab04SLingfeng Yang  if compile_prog "$CPU_CFLAGS -Werror -fsanitize=thread" "" ; then
18170aebab04SLingfeng Yang      have_tsan_iface_fiber=yes
18180aebab04SLingfeng Yang  fi
18190aebab04SLingfeng Yangfi
18200aebab04SLingfeng Yang
1821adc28027SAlexander Bulekov##########################################
1822675b9b53SMarc-André Lureau# check for slirp
1823675b9b53SMarc-André Lureau
1824675b9b53SMarc-André Lureaucase "$slirp" in
18254d34a86bSPaolo Bonzini  auto | enabled | internal)
18264d34a86bSPaolo Bonzini    # Simpler to always update submodule, even if not needed.
18277c57bdd8SMarc-André Lureau    git_submodules="${git_submodules} slirp"
1828675b9b53SMarc-André Lureau    ;;
1829675b9b53SMarc-André Lureauesac
1830675b9b53SMarc-André Lureau
183154e7aac0SAlexey Krasikov##########################################
1832cd362defSPaolo Bonzini# functions to probe cross compilers
1833cd362defSPaolo Bonzini
1834cd362defSPaolo Bonzinicontainer="no"
1835cd362defSPaolo Bonziniif test $use_containers = "yes"; then
1836cd362defSPaolo Bonzini    if has "docker" || has "podman"; then
183764708615SPeter Maydell        container=$($python "$source_path"/tests/docker/docker.py probe)
1838cd362defSPaolo Bonzini    fi
1839cd362defSPaolo Bonzinifi
1840cd362defSPaolo Bonzini
1841cd362defSPaolo Bonzini# cross compilers defaults, can be overridden with --cross-cc-ARCH
18425adb43beSPaolo Bonzini: ${cross_prefix_aarch64="aarch64-linux-gnu-"}
18435adb43beSPaolo Bonzini: ${cross_prefix_aarch64_be="$cross_prefix_aarch64"}
18445adb43beSPaolo Bonzini: ${cross_prefix_alpha="alpha-linux-gnu-"}
18455adb43beSPaolo Bonzini: ${cross_prefix_arm="arm-linux-gnueabihf-"}
18465adb43beSPaolo Bonzini: ${cross_prefix_armeb="$cross_prefix_arm"}
18475adb43beSPaolo Bonzini: ${cross_prefix_hexagon="hexagon-unknown-linux-musl-"}
184834bb43b0SSong Gao: ${cross_prefix_loongarch64="loongarch64-unknown-linux-gnu-"}
18495adb43beSPaolo Bonzini: ${cross_prefix_hppa="hppa-linux-gnu-"}
18505adb43beSPaolo Bonzini: ${cross_prefix_i386="i686-linux-gnu-"}
18515adb43beSPaolo Bonzini: ${cross_prefix_m68k="m68k-linux-gnu-"}
18525adb43beSPaolo Bonzini: ${cross_prefix_microblaze="microblaze-linux-musl-"}
18535adb43beSPaolo Bonzini: ${cross_prefix_mips64el="mips64el-linux-gnuabi64-"}
18545adb43beSPaolo Bonzini: ${cross_prefix_mips64="mips64-linux-gnuabi64-"}
18555adb43beSPaolo Bonzini: ${cross_prefix_mipsel="mipsel-linux-gnu-"}
18565adb43beSPaolo Bonzini: ${cross_prefix_mips="mips-linux-gnu-"}
18575adb43beSPaolo Bonzini: ${cross_prefix_nios2="nios2-linux-gnu-"}
18585adb43beSPaolo Bonzini: ${cross_prefix_ppc="powerpc-linux-gnu-"}
18595adb43beSPaolo Bonzini: ${cross_prefix_ppc64="powerpc64-linux-gnu-"}
18605adb43beSPaolo Bonzini: ${cross_prefix_ppc64le="$cross_prefix_ppc64"}
18615adb43beSPaolo Bonzini: ${cross_prefix_riscv64="riscv64-linux-gnu-"}
18625adb43beSPaolo Bonzini: ${cross_prefix_s390x="s390x-linux-gnu-"}
18635adb43beSPaolo Bonzini: ${cross_prefix_sh4="sh4-linux-gnu-"}
18645adb43beSPaolo Bonzini: ${cross_prefix_sparc64="sparc64-linux-gnu-"}
18655adb43beSPaolo Bonzini: ${cross_prefix_sparc="$cross_prefix_sparc64"}
18665adb43beSPaolo Bonzini: ${cross_prefix_x86_64="x86_64-linux-gnu-"}
18675adb43beSPaolo Bonzini
1868cd362defSPaolo Bonzini: ${cross_cc_aarch64_be="$cross_cc_aarch64"}
1869cd362defSPaolo Bonzini: ${cross_cc_cflags_aarch64_be="-mbig-endian"}
187046af66edSPaolo Bonzini: ${cross_cc_armeb="$cross_cc_arm"}
1871cd362defSPaolo Bonzini: ${cross_cc_cflags_armeb="-mbig-endian"}
1872cd362defSPaolo Bonzini: ${cross_cc_hexagon="hexagon-unknown-linux-musl-clang"}
1873cd362defSPaolo Bonzini: ${cross_cc_cflags_hexagon="-mv67 -O2 -static"}
1874cd362defSPaolo Bonzini: ${cross_cc_cflags_i386="-m32"}
1875d44f2f96SPaolo Bonzini: ${cross_cc_cflags_ppc="-m32 -mbig-endian"}
1876cd362defSPaolo Bonzini: ${cross_cc_cflags_ppc64="-m64 -mbig-endian"}
1877cd362defSPaolo Bonzini: ${cross_cc_ppc64le="$cross_cc_ppc64"}
1878cd362defSPaolo Bonzini: ${cross_cc_cflags_ppc64le="-m64 -mlittle-endian"}
1879cd362defSPaolo Bonzini: ${cross_cc_cflags_sparc64="-m64 -mcpu=ultrasparc"}
188046af66edSPaolo Bonzini: ${cross_cc_sparc="$cross_cc_sparc64"}
188146af66edSPaolo Bonzini: ${cross_cc_cflags_sparc="-m32 -mcpu=supersparc"}
1882cd362defSPaolo Bonzini: ${cross_cc_cflags_x86_64="-m64"}
1883cd362defSPaolo Bonzini
18845adb43beSPaolo Bonzinicompute_target_variable() {
188592e288fcSPaolo Bonzini  eval "$2="
18865adb43beSPaolo Bonzini  if eval test -n "\"\${cross_prefix_$1}\""; then
18875adb43beSPaolo Bonzini    if eval has "\"\${cross_prefix_$1}\$3\""; then
18885adb43beSPaolo Bonzini      eval "$2=\"\${cross_prefix_$1}\$3\""
18895adb43beSPaolo Bonzini    fi
18905adb43beSPaolo Bonzini  fi
18915adb43beSPaolo Bonzini}
1892cd362defSPaolo Bonzini
189352f08deaSPaolo Bonzini# probe_target_compiler TARGET
189452f08deaSPaolo Bonzini#
189552f08deaSPaolo Bonzini# Look for a compiler for the given target, either native or cross.
189652f08deaSPaolo Bonzini# Set variables target_* if a compiler is found, and container_cross_*
189752f08deaSPaolo Bonzini# if a Docker-based cross-compiler image is known for the target.
189852f08deaSPaolo Bonzini# Set got_cross_cc to yes/no depending on whether a non-container-based
189952f08deaSPaolo Bonzini# compiler was found.
190052f08deaSPaolo Bonzini#
190152f08deaSPaolo Bonzini# If TARGET is a user-mode emulation target, also set build_static to
190252f08deaSPaolo Bonzini# "y" if static linking is possible.
190352f08deaSPaolo Bonzini#
1904cd362defSPaolo Bonziniprobe_target_compiler() {
1905cd362defSPaolo Bonzini  # reset all output variables
190692e288fcSPaolo Bonzini  got_cross_cc=no
1907cd362defSPaolo Bonzini  container_image=
1908cd362defSPaolo Bonzini  container_hosts=
1909cd362defSPaolo Bonzini  container_cross_cc=
191087eb014cSPaolo Bonzini  container_cross_ar=
1911cd362defSPaolo Bonzini  container_cross_as=
1912cd362defSPaolo Bonzini  container_cross_ld=
191387eb014cSPaolo Bonzini  container_cross_nm=
191487eb014cSPaolo Bonzini  container_cross_objcopy=
191587eb014cSPaolo Bonzini  container_cross_ranlib=
191687eb014cSPaolo Bonzini  container_cross_strip=
1917cd362defSPaolo Bonzini
191852f08deaSPaolo Bonzini  target_arch=${1%%-*}
191952f08deaSPaolo Bonzini  case $target_arch in
1920cd362defSPaolo Bonzini    aarch64) container_hosts="x86_64 aarch64" ;;
1921cd362defSPaolo Bonzini    alpha) container_hosts=x86_64 ;;
1922cd362defSPaolo Bonzini    arm) container_hosts="x86_64 aarch64" ;;
1923cd362defSPaolo Bonzini    cris) container_hosts=x86_64 ;;
1924cd362defSPaolo Bonzini    hexagon) container_hosts=x86_64 ;;
1925cd362defSPaolo Bonzini    hppa) container_hosts=x86_64 ;;
1926cd362defSPaolo Bonzini    i386) container_hosts=x86_64 ;;
1927b70ec50bSRichard Henderson    loongarch64) container_hosts=x86_64 ;;
1928cd362defSPaolo Bonzini    m68k) container_hosts=x86_64 ;;
1929cd362defSPaolo Bonzini    microblaze) container_hosts=x86_64 ;;
1930cd362defSPaolo Bonzini    mips64el) container_hosts=x86_64 ;;
1931cd362defSPaolo Bonzini    mips64) container_hosts=x86_64 ;;
1932cd362defSPaolo Bonzini    mipsel) container_hosts=x86_64 ;;
1933cd362defSPaolo Bonzini    mips) container_hosts=x86_64 ;;
1934cd362defSPaolo Bonzini    nios2) container_hosts=x86_64 ;;
1935cd362defSPaolo Bonzini    ppc) container_hosts=x86_64 ;;
1936cd362defSPaolo Bonzini    ppc64|ppc64le) container_hosts=x86_64 ;;
1937cd362defSPaolo Bonzini    riscv64) container_hosts=x86_64 ;;
1938cd362defSPaolo Bonzini    s390x) container_hosts=x86_64 ;;
1939cd362defSPaolo Bonzini    sh4) container_hosts=x86_64 ;;
1940cd362defSPaolo Bonzini    sparc64) container_hosts=x86_64 ;;
1941cd362defSPaolo Bonzini    tricore) container_hosts=x86_64 ;;
1942cd362defSPaolo Bonzini    x86_64) container_hosts="aarch64 ppc64el x86_64" ;;
1943cd362defSPaolo Bonzini    xtensa*) container_hosts=x86_64 ;;
1944cd362defSPaolo Bonzini  esac
1945cd362defSPaolo Bonzini
1946cd362defSPaolo Bonzini  for host in $container_hosts; do
1947cd362defSPaolo Bonzini    test "$container" != no || continue
1948cd362defSPaolo Bonzini    test "$host" = "$cpu" || continue
194952f08deaSPaolo Bonzini    case $target_arch in
1950cd362defSPaolo Bonzini      aarch64)
1951cd362defSPaolo Bonzini        # We don't have any bigendian build tools so we only use this for AArch64
1952cd362defSPaolo Bonzini        container_image=debian-arm64-cross
19535adb43beSPaolo Bonzini        container_cross_prefix=aarch64-linux-gnu-
19545adb43beSPaolo Bonzini        container_cross_cc=${container_cross_prefix}gcc-10
1955cd362defSPaolo Bonzini        ;;
1956cd362defSPaolo Bonzini      alpha)
1957cd362defSPaolo Bonzini        container_image=debian-alpha-cross
19585adb43beSPaolo Bonzini        container_cross_prefix=alpha-linux-gnu-
1959cd362defSPaolo Bonzini        ;;
1960cd362defSPaolo Bonzini      arm)
1961cd362defSPaolo Bonzini        # We don't have any bigendian build tools so we only use this for ARM
1962cd362defSPaolo Bonzini        container_image=debian-armhf-cross
19635adb43beSPaolo Bonzini        container_cross_prefix=arm-linux-gnueabihf-
1964cd362defSPaolo Bonzini        ;;
1965cd362defSPaolo Bonzini      cris)
1966cd362defSPaolo Bonzini        container_image=fedora-cris-cross
19675adb43beSPaolo Bonzini        container_cross_prefix=cris-linux-gnu-
1968cd362defSPaolo Bonzini        ;;
1969cd362defSPaolo Bonzini      hexagon)
1970cd362defSPaolo Bonzini        container_image=debian-hexagon-cross
19715adb43beSPaolo Bonzini        container_cross_prefix=hexagon-unknown-linux-musl-
19725adb43beSPaolo Bonzini        container_cross_cc=${container_cross_prefix}clang
1973cd362defSPaolo Bonzini        ;;
1974cd362defSPaolo Bonzini      hppa)
1975cd362defSPaolo Bonzini        container_image=debian-hppa-cross
19765adb43beSPaolo Bonzini        container_cross_prefix=hppa-linux-gnu-
1977cd362defSPaolo Bonzini        ;;
1978cd362defSPaolo Bonzini      i386)
1979cd362defSPaolo Bonzini        container_image=fedora-i386-cross
19805adb43beSPaolo Bonzini        container_cross_prefix=
1981cd362defSPaolo Bonzini        ;;
1982b70ec50bSRichard Henderson      loongarch64)
1983b70ec50bSRichard Henderson        container_image=debian-loongarch-cross
1984b70ec50bSRichard Henderson        container_cross_prefix=loongarch64-unknown-linux-gnu-
1985b70ec50bSRichard Henderson        ;;
1986cd362defSPaolo Bonzini      m68k)
1987cd362defSPaolo Bonzini        container_image=debian-m68k-cross
19885adb43beSPaolo Bonzini        container_cross_prefix=m68k-linux-gnu-
1989cd362defSPaolo Bonzini        ;;
1990cd362defSPaolo Bonzini      microblaze)
1991cd362defSPaolo Bonzini        container_image=debian-microblaze-cross
19925adb43beSPaolo Bonzini        container_cross_prefix=microblaze-linux-musl-
1993cd362defSPaolo Bonzini        ;;
1994cd362defSPaolo Bonzini      mips64el)
1995cd362defSPaolo Bonzini        container_image=debian-mips64el-cross
19965adb43beSPaolo Bonzini        container_cross_prefix=mips64el-linux-gnuabi64-
1997cd362defSPaolo Bonzini        ;;
1998cd362defSPaolo Bonzini      mips64)
1999cd362defSPaolo Bonzini        container_image=debian-mips64-cross
20005adb43beSPaolo Bonzini        container_cross_prefix=mips64-linux-gnuabi64-
2001cd362defSPaolo Bonzini        ;;
2002cd362defSPaolo Bonzini      mipsel)
2003cd362defSPaolo Bonzini        container_image=debian-mipsel-cross
20045adb43beSPaolo Bonzini        container_cross_prefix=mipsel-linux-gnu-
2005cd362defSPaolo Bonzini        ;;
2006cd362defSPaolo Bonzini      mips)
2007cd362defSPaolo Bonzini        container_image=debian-mips-cross
20085adb43beSPaolo Bonzini        container_cross_prefix=mips-linux-gnu-
2009cd362defSPaolo Bonzini        ;;
2010cd362defSPaolo Bonzini      nios2)
2011cd362defSPaolo Bonzini        container_image=debian-nios2-cross
20125adb43beSPaolo Bonzini        container_cross_prefix=nios2-linux-gnu-
2013cd362defSPaolo Bonzini        ;;
2014cd362defSPaolo Bonzini      ppc)
2015cd362defSPaolo Bonzini        container_image=debian-powerpc-test-cross
20165adb43beSPaolo Bonzini        container_cross_prefix=powerpc-linux-gnu-
20175adb43beSPaolo Bonzini        container_cross_cc=${container_cross_prefix}gcc-10
2018cd362defSPaolo Bonzini        ;;
2019cd362defSPaolo Bonzini      ppc64|ppc64le)
2020cd362defSPaolo Bonzini        container_image=debian-powerpc-test-cross
2021705c881fSRichard Henderson        container_cross_prefix=powerpc${target_arch#ppc}-linux-gnu-
20225adb43beSPaolo Bonzini        container_cross_cc=${container_cross_prefix}gcc-10
2023cd362defSPaolo Bonzini        ;;
2024cd362defSPaolo Bonzini      riscv64)
2025cd362defSPaolo Bonzini        container_image=debian-riscv64-test-cross
20265adb43beSPaolo Bonzini        container_cross_prefix=riscv64-linux-gnu-
2027cd362defSPaolo Bonzini        ;;
2028cd362defSPaolo Bonzini      s390x)
2029cd362defSPaolo Bonzini        container_image=debian-s390x-cross
20305adb43beSPaolo Bonzini        container_cross_prefix=s390x-linux-gnu-
2031cd362defSPaolo Bonzini        ;;
2032cd362defSPaolo Bonzini      sh4)
2033cd362defSPaolo Bonzini        container_image=debian-sh4-cross
20345adb43beSPaolo Bonzini        container_cross_prefix=sh4-linux-gnu-
2035cd362defSPaolo Bonzini        ;;
2036cd362defSPaolo Bonzini      sparc64)
2037cd362defSPaolo Bonzini        container_image=debian-sparc64-cross
20385adb43beSPaolo Bonzini        container_cross_prefix=sparc64-linux-gnu-
2039cd362defSPaolo Bonzini        ;;
2040cd362defSPaolo Bonzini      tricore)
2041cd362defSPaolo Bonzini        container_image=debian-tricore-cross
20425adb43beSPaolo Bonzini        container_cross_prefix=tricore-
2043cd362defSPaolo Bonzini        container_cross_as=tricore-as
2044cd362defSPaolo Bonzini        container_cross_ld=tricore-ld
20455adb43beSPaolo Bonzini        break
2046cd362defSPaolo Bonzini        ;;
2047cd362defSPaolo Bonzini      x86_64)
2048cd362defSPaolo Bonzini        container_image=debian-amd64-cross
20495adb43beSPaolo Bonzini        container_cross_prefix=x86_64-linux-gnu-
2050cd362defSPaolo Bonzini        ;;
2051cd362defSPaolo Bonzini      xtensa*)
2052cd362defSPaolo Bonzini        container_hosts=x86_64
2053cd362defSPaolo Bonzini        container_image=debian-xtensa-cross
2054cd362defSPaolo Bonzini
2055cd362defSPaolo Bonzini        # default to the dc232b cpu
20565adb43beSPaolo Bonzini        container_cross_prefix=/opt/2020.07/xtensa-dc232b-elf/bin/xtensa-dc232b-elf-
2057cd362defSPaolo Bonzini        ;;
2058cd362defSPaolo Bonzini    esac
20595adb43beSPaolo Bonzini    : ${container_cross_cc:=${container_cross_prefix}gcc}
206087eb014cSPaolo Bonzini    : ${container_cross_ar:=${container_cross_prefix}ar}
20615adb43beSPaolo Bonzini    : ${container_cross_as:=${container_cross_prefix}as}
20625adb43beSPaolo Bonzini    : ${container_cross_ld:=${container_cross_prefix}ld}
206387eb014cSPaolo Bonzini    : ${container_cross_nm:=${container_cross_prefix}nm}
206487eb014cSPaolo Bonzini    : ${container_cross_objcopy:=${container_cross_prefix}objcopy}
206587eb014cSPaolo Bonzini    : ${container_cross_ranlib:=${container_cross_prefix}ranlib}
206687eb014cSPaolo Bonzini    : ${container_cross_strip:=${container_cross_prefix}strip}
2067cd362defSPaolo Bonzini  done
2068cd362defSPaolo Bonzini
206992e288fcSPaolo Bonzini  local t try
207092e288fcSPaolo Bonzini  try=cross
207192e288fcSPaolo Bonzini  case "$target_arch:$cpu" in
207292e288fcSPaolo Bonzini    aarch64_be:aarch64 | \
207392e288fcSPaolo Bonzini    armeb:arm | \
207492e288fcSPaolo Bonzini    i386:x86_64 | \
207592e288fcSPaolo Bonzini    mips*:mips64 | \
207692e288fcSPaolo Bonzini    ppc*:ppc64 | \
207792e288fcSPaolo Bonzini    sparc:sparc64 | \
207892e288fcSPaolo Bonzini    "$cpu:$cpu")
207992e288fcSPaolo Bonzini      try='native cross' ;;
208092e288fcSPaolo Bonzini  esac
208152f08deaSPaolo Bonzini  eval "target_cflags=\${cross_cc_cflags_$target_arch}"
208292e288fcSPaolo Bonzini  for t in $try; do
208392e288fcSPaolo Bonzini    case $t in
208492e288fcSPaolo Bonzini    native)
208592e288fcSPaolo Bonzini      target_cc=$cc
208692e288fcSPaolo Bonzini      target_ccas=$ccas
208792e288fcSPaolo Bonzini      target_ar=$ar
208892e288fcSPaolo Bonzini      target_as=$as
208992e288fcSPaolo Bonzini      target_ld=$ld
209092e288fcSPaolo Bonzini      target_nm=$nm
209192e288fcSPaolo Bonzini      target_objcopy=$objcopy
209292e288fcSPaolo Bonzini      target_ranlib=$ranlib
209392e288fcSPaolo Bonzini      target_strip=$strip
209492e288fcSPaolo Bonzini      ;;
209592e288fcSPaolo Bonzini    cross)
209692e288fcSPaolo Bonzini      target_cc=
209752f08deaSPaolo Bonzini      if eval test -n "\"\${cross_cc_$target_arch}\""; then
209852f08deaSPaolo Bonzini        if eval has "\"\${cross_cc_$target_arch}\""; then
209952f08deaSPaolo Bonzini          eval "target_cc=\"\${cross_cc_$target_arch}\""
2100cd362defSPaolo Bonzini        fi
21015adb43beSPaolo Bonzini      else
210252f08deaSPaolo Bonzini        compute_target_variable $target_arch target_cc gcc
2103cd362defSPaolo Bonzini      fi
210487eb014cSPaolo Bonzini      target_ccas=$target_cc
210552f08deaSPaolo Bonzini      compute_target_variable $target_arch target_ar ar
210652f08deaSPaolo Bonzini      compute_target_variable $target_arch target_as as
210752f08deaSPaolo Bonzini      compute_target_variable $target_arch target_ld ld
210852f08deaSPaolo Bonzini      compute_target_variable $target_arch target_nm nm
210952f08deaSPaolo Bonzini      compute_target_variable $target_arch target_objcopy objcopy
211052f08deaSPaolo Bonzini      compute_target_variable $target_arch target_ranlib ranlib
211152f08deaSPaolo Bonzini      compute_target_variable $target_arch target_strip strip
2112640aabc8SPaolo Bonzini      ;;
2113640aabc8SPaolo Bonzini    esac
211492e288fcSPaolo Bonzini
21152ad60f6fSPaolo Bonzini    if test -n "$target_cc"; then
211652f08deaSPaolo Bonzini      case $target_arch in
21172ad60f6fSPaolo Bonzini        i386|x86_64)
21182ad60f6fSPaolo Bonzini          if $target_cc --version | grep -qi "clang"; then
211992e288fcSPaolo Bonzini            continue
21202ad60f6fSPaolo Bonzini          fi
21212ad60f6fSPaolo Bonzini          ;;
21222ad60f6fSPaolo Bonzini      esac
212392e288fcSPaolo Bonzini    elif test -n "$target_as" && test -n "$target_ld"; then
212492e288fcSPaolo Bonzini      # Special handling for assembler only targets
212592e288fcSPaolo Bonzini      case $target in
212692e288fcSPaolo Bonzini        tricore-softmmu)
212792e288fcSPaolo Bonzini          build_static=
212892e288fcSPaolo Bonzini          got_cross_cc=yes
212992e288fcSPaolo Bonzini          break
213092e288fcSPaolo Bonzini          ;;
213192e288fcSPaolo Bonzini        *)
213292e288fcSPaolo Bonzini          continue
213392e288fcSPaolo Bonzini          ;;
213492e288fcSPaolo Bonzini      esac
213592e288fcSPaolo Bonzini    else
213692e288fcSPaolo Bonzini      continue
213792e288fcSPaolo Bonzini    fi
213892e288fcSPaolo Bonzini
213992e288fcSPaolo Bonzini    write_c_skeleton
214092e288fcSPaolo Bonzini    case $1 in
214192e288fcSPaolo Bonzini      *-softmmu)
214292e288fcSPaolo Bonzini        if do_compiler "$target_cc" $target_cflags -o $TMPO -c $TMPC &&
214392e288fcSPaolo Bonzini          do_compiler "$target_cc" $target_cflags -r -nostdlib -o "${TMPDIR1}/${TMPB}2.o" "$TMPO" -lgcc; then
214492e288fcSPaolo Bonzini          got_cross_cc=yes
214592e288fcSPaolo Bonzini          break
214692e288fcSPaolo Bonzini        fi
214792e288fcSPaolo Bonzini        ;;
214892e288fcSPaolo Bonzini      *)
214992e288fcSPaolo Bonzini        if do_compiler "$target_cc" $target_cflags -o $TMPE $TMPC -static ; then
215092e288fcSPaolo Bonzini          build_static=y
215192e288fcSPaolo Bonzini          got_cross_cc=yes
215292e288fcSPaolo Bonzini          break
215392e288fcSPaolo Bonzini        fi
215492e288fcSPaolo Bonzini        if do_compiler "$target_cc" $target_cflags -o $TMPE $TMPC ; then
215592e288fcSPaolo Bonzini          build_static=
215692e288fcSPaolo Bonzini          got_cross_cc=yes
215792e288fcSPaolo Bonzini          break
215892e288fcSPaolo Bonzini        fi
215992e288fcSPaolo Bonzini        ;;
216092e288fcSPaolo Bonzini    esac
216192e288fcSPaolo Bonzini  done
216292e288fcSPaolo Bonzini  if test $got_cross_cc != yes; then
216392e288fcSPaolo Bonzini    build_static=
216492e288fcSPaolo Bonzini    target_cc=
216592e288fcSPaolo Bonzini    target_ccas=
216692e288fcSPaolo Bonzini    target_ar=
216792e288fcSPaolo Bonzini    target_as=
216892e288fcSPaolo Bonzini    target_ld=
216992e288fcSPaolo Bonzini    target_nm=
217092e288fcSPaolo Bonzini    target_objcopy=
217192e288fcSPaolo Bonzini    target_ranlib=
217292e288fcSPaolo Bonzini    target_strip=
21732ad60f6fSPaolo Bonzini  fi
2174cd362defSPaolo Bonzini}
2175cd362defSPaolo Bonzini
2176cd362defSPaolo Bonziniwrite_target_makefile() {
2177e81785abSPaolo Bonzini  echo "EXTRA_CFLAGS=$target_cflags"
2178cd362defSPaolo Bonzini  if test -n "$target_cc"; then
2179cd362defSPaolo Bonzini    echo "CC=$target_cc"
218087eb014cSPaolo Bonzini    echo "CCAS=$target_ccas"
218187eb014cSPaolo Bonzini  fi
218287eb014cSPaolo Bonzini  if test -n "$target_ar"; then
218387eb014cSPaolo Bonzini    echo "AR=$target_ar"
2184cd362defSPaolo Bonzini  fi
2185cd362defSPaolo Bonzini  if test -n "$target_as"; then
2186cd362defSPaolo Bonzini    echo "AS=$target_as"
2187cd362defSPaolo Bonzini  fi
2188cd362defSPaolo Bonzini  if test -n "$target_ld"; then
2189cd362defSPaolo Bonzini    echo "LD=$target_ld"
2190cd362defSPaolo Bonzini  fi
219187eb014cSPaolo Bonzini  if test -n "$target_nm"; then
219287eb014cSPaolo Bonzini    echo "NM=$target_nm"
219387eb014cSPaolo Bonzini  fi
219487eb014cSPaolo Bonzini  if test -n "$target_objcopy"; then
219587eb014cSPaolo Bonzini    echo "OBJCOPY=$target_objcopy"
219687eb014cSPaolo Bonzini  fi
219787eb014cSPaolo Bonzini  if test -n "$target_ranlib"; then
219887eb014cSPaolo Bonzini    echo "RANLIB=$target_ranlib"
219987eb014cSPaolo Bonzini  fi
220087eb014cSPaolo Bonzini  if test -n "$target_strip"; then
220187eb014cSPaolo Bonzini    echo "STRIP=$target_strip"
220287eb014cSPaolo Bonzini  fi
2203cd362defSPaolo Bonzini}
2204cd362defSPaolo Bonzini
2205cd362defSPaolo Bonziniwrite_container_target_makefile() {
2206e81785abSPaolo Bonzini  echo "EXTRA_CFLAGS=$target_cflags"
2207cd362defSPaolo Bonzini  if test -n "$container_cross_cc"; then
2208cd362defSPaolo Bonzini    echo "CC=\$(DOCKER_SCRIPT) cc --cc $container_cross_cc -i qemu/$container_image -s $source_path --"
220987eb014cSPaolo Bonzini    echo "CCAS=\$(DOCKER_SCRIPT) cc --cc $container_cross_cc -i qemu/$container_image -s $source_path --"
2210cd362defSPaolo Bonzini  fi
221187eb014cSPaolo Bonzini  echo "AR=\$(DOCKER_SCRIPT) cc --cc $container_cross_ar -i qemu/$container_image -s $source_path --"
2212cd362defSPaolo Bonzini  echo "AS=\$(DOCKER_SCRIPT) cc --cc $container_cross_as -i qemu/$container_image -s $source_path --"
2213cd362defSPaolo Bonzini  echo "LD=\$(DOCKER_SCRIPT) cc --cc $container_cross_ld -i qemu/$container_image -s $source_path --"
221487eb014cSPaolo Bonzini  echo "NM=\$(DOCKER_SCRIPT) cc --cc $container_cross_nm -i qemu/$container_image -s $source_path --"
221587eb014cSPaolo Bonzini  echo "OBJCOPY=\$(DOCKER_SCRIPT) cc --cc $container_cross_objcopy -i qemu/$container_image -s $source_path --"
221687eb014cSPaolo Bonzini  echo "RANLIB=\$(DOCKER_SCRIPT) cc --cc $container_cross_ranlib -i qemu/$container_image -s $source_path --"
221787eb014cSPaolo Bonzini  echo "STRIP=\$(DOCKER_SCRIPT) cc --cc $container_cross_strip -i qemu/$container_image -s $source_path --"
2218cd362defSPaolo Bonzini}
2219cd362defSPaolo Bonzini
2220cd362defSPaolo Bonzini
2221cd362defSPaolo Bonzini
2222cd362defSPaolo Bonzini##########################################
222355116968SJagannathan Raman# check for vfio_user_server
222455116968SJagannathan Raman
222555116968SJagannathan Ramancase "$vfio_user_server" in
222655116968SJagannathan Raman  enabled )
222755116968SJagannathan Raman    if test "$git_submodules_action" != "ignore"; then
222855116968SJagannathan Raman      git_submodules="${git_submodules} subprojects/libvfio-user"
222955116968SJagannathan Raman    fi
223055116968SJagannathan Raman    ;;
223155116968SJagannathan Ramanesac
223255116968SJagannathan Raman
223355116968SJagannathan Raman##########################################
2234e86ecd4bSJuan Quintela# End of CC checks
2235e86ecd4bSJuan Quintela# After here, no more $cc or $ld runs
2236e86ecd4bSJuan Quintela
2237d83414e1SMarc-André Lureauwrite_c_skeleton
2238d83414e1SMarc-André Lureau
2239df42fa7dSPaolo Bonziniif test "$fortify_source" = "yes" ; then
2240086d5f75SPaolo Bonzini  QEMU_CFLAGS="-U_FORTIFY_SOURCE -D_FORTIFY_SOURCE=2 $QEMU_CFLAGS"
2241086d5f75SPaolo Bonzinifi
2242086d5f75SPaolo Bonzini
2243247724cbSMarc-André Lureauif test "$have_asan" = "yes"; then
2244db5adeaaSPaolo Bonzini  QEMU_CFLAGS="-fsanitize=address $QEMU_CFLAGS"
2245db5adeaaSPaolo Bonzini  QEMU_LDFLAGS="-fsanitize=address $QEMU_LDFLAGS"
2246d83414e1SMarc-André Lureau  if test "$have_asan_iface_h" = "no" ; then
2247d83414e1SMarc-André Lureau      echo "ASAN build enabled, but ASAN header missing." \
2248d83414e1SMarc-André Lureau           "Without code annotation, the report may be inferior."
2249d83414e1SMarc-André Lureau  elif test "$have_asan_iface_fiber" = "no" ; then
2250d83414e1SMarc-André Lureau      echo "ASAN build enabled, but ASAN header is too old." \
2251d83414e1SMarc-André Lureau           "Without code annotation, the report may be inferior."
2252d83414e1SMarc-André Lureau  fi
2253247724cbSMarc-André Lureaufi
22540aebab04SLingfeng Yangif test "$have_tsan" = "yes" ; then
22550aebab04SLingfeng Yang  if test "$have_tsan_iface_fiber" = "yes" ; then
22560aebab04SLingfeng Yang    QEMU_CFLAGS="-fsanitize=thread $QEMU_CFLAGS"
22570aebab04SLingfeng Yang    QEMU_LDFLAGS="-fsanitize=thread $QEMU_LDFLAGS"
22580aebab04SLingfeng Yang  else
22590aebab04SLingfeng Yang    error_exit "Cannot enable TSAN due to missing fiber annotation interface."
22600aebab04SLingfeng Yang  fi
22610aebab04SLingfeng Yangelif test "$tsan" = "yes" ; then
22620aebab04SLingfeng Yang  error_exit "Cannot enable TSAN due to missing sanitize thread interface."
22630aebab04SLingfeng Yangfi
2264247724cbSMarc-André Lureauif test "$have_ubsan" = "yes"; then
2265db5adeaaSPaolo Bonzini  QEMU_CFLAGS="-fsanitize=undefined $QEMU_CFLAGS"
2266db5adeaaSPaolo Bonzini  QEMU_LDFLAGS="-fsanitize=undefined $QEMU_LDFLAGS"
2267247724cbSMarc-André Lureaufi
2268247724cbSMarc-André Lureau
22696542aa9cSPeter Lieven##########################################
22703efac6ebSTomáš Golembiovský
22710aebab04SLingfeng Yang# Exclude --warn-common with TSan to suppress warnings from the TSan libraries.
22720aebab04SLingfeng Yangif test "$solaris" = "no" && test "$tsan" = "no"; then
2273e86ecd4bSJuan Quintela    if $ld --version 2>/dev/null | grep "GNU ld" >/dev/null 2>/dev/null ; then
2274db5adeaaSPaolo Bonzini        QEMU_LDFLAGS="-Wl,--warn-common $QEMU_LDFLAGS"
2275e86ecd4bSJuan Quintela    fi
2276e86ecd4bSJuan Quintelafi
2277e86ecd4bSJuan Quintela
2278b846ab7cSPaolo Bonzini# Guest agent Windows MSI package
22799d6bc27bSMichael Roth
22809d6bc27bSMichael Rothif test "$QEMU_GA_MANUFACTURER" = ""; then
22819d6bc27bSMichael Roth  QEMU_GA_MANUFACTURER=QEMU
22829d6bc27bSMichael Rothfi
22839d6bc27bSMichael Rothif test "$QEMU_GA_DISTRO" = ""; then
22849d6bc27bSMichael Roth  QEMU_GA_DISTRO=Linux
22859d6bc27bSMichael Rothfi
22869d6bc27bSMichael Rothif test "$QEMU_GA_VERSION" = ""; then
228764708615SPeter Maydell    QEMU_GA_VERSION=$(cat "$source_path"/VERSION)
22889d6bc27bSMichael Rothfi
22899d6bc27bSMichael Roth
229033ab4787SPaolo Bonzini
229133ab4787SPaolo Bonzini#######################################
229233ab4787SPaolo Bonzini# cross-compiled firmware targets
229333ab4787SPaolo Bonzini
2294ad388845SPaolo Bonzini# Set up build tree symlinks that point back into the source tree
2295ad388845SPaolo Bonzini# (these can be both files and directories).
2296ad388845SPaolo Bonzini# Caution: avoid adding files or directories here using wildcards. This
2297ad388845SPaolo Bonzini# will result in problems later if a new file matching the wildcard is
2298ad388845SPaolo Bonzini# added to the source tree -- nothing will cause configure to be rerun
2299ad388845SPaolo Bonzini# so the build tree will be missing the link back to the new file, and
2300ad388845SPaolo Bonzini# tests might fail. Prefer to keep the relevant files in their own
2301ad388845SPaolo Bonzini# directory and symlink the directory instead.
2302ad388845SPaolo BonziniLINKS="Makefile"
2303ad388845SPaolo BonziniLINKS="$LINKS tests/tcg/Makefile.target"
2304ad388845SPaolo BonziniLINKS="$LINKS pc-bios/optionrom/Makefile"
2305ad388845SPaolo BonziniLINKS="$LINKS pc-bios/s390-ccw/Makefile"
2306d695918fSPaolo BonziniLINKS="$LINKS pc-bios/vof/Makefile"
2307ad388845SPaolo BonziniLINKS="$LINKS .gdbinit scripts" # scripts needed by relative path in .gdbinit
2308ad388845SPaolo BonziniLINKS="$LINKS tests/avocado tests/data"
2309ad388845SPaolo BonziniLINKS="$LINKS tests/qemu-iotests/check"
2310ad388845SPaolo BonziniLINKS="$LINKS python"
2311ad388845SPaolo BonziniLINKS="$LINKS contrib/plugins/Makefile "
2312ad388845SPaolo Bonzinifor f in $LINKS ; do
2313ad388845SPaolo Bonzini    if [ -e "$source_path/$f" ]; then
2314ad388845SPaolo Bonzini        mkdir -p `dirname ./$f`
2315ad388845SPaolo Bonzini        symlink "$source_path/$f" "$f"
2316ad388845SPaolo Bonzini    fi
2317ad388845SPaolo Bonzinidone
2318ad388845SPaolo Bonzini
2319ca35f780SPaolo Bonzini# Mac OS X ships with a broken assembler
2320ca35f780SPaolo Bonziniroms=
232152f08deaSPaolo Bonziniprobe_target_compiler i386-softmmu
232233ab4787SPaolo Bonziniif test -n "$target_cc" &&
2323ba7c60c2SPaolo Bonzini        test "$targetos" != "darwin" && test "$targetos" != "sunos" && \
2324ba7c60c2SPaolo Bonzini        test "$targetos" != "haiku" && test "$softmmu" = yes ; then
2325e57218b6SPeter Maydell    # Different host OS linkers have different ideas about the name of the ELF
2326c65d5e4eSBrad Smith    # emulation. Linux and OpenBSD/amd64 use 'elf_i386'; FreeBSD uses the _fbsd
2327c65d5e4eSBrad Smith    # variant; OpenBSD/i386 uses the _obsd variant; and Windows uses i386pe.
2328c65d5e4eSBrad Smith    for emu in elf_i386 elf_i386_fbsd elf_i386_obsd i386pe; do
2329d466d416SPeter Maydell        if "$target_ld" -verbose 2>&1 | grep -q "^[[:space:]]*${emu}[[:space:]]*$"; then
2330e57218b6SPeter Maydell            ld_i386_emulation="$emu"
2331e57218b6SPeter Maydell            break
2332e57218b6SPeter Maydell        fi
2333e57218b6SPeter Maydell    done
233433ab4787SPaolo Bonzini    if test -n "$ld_i386_emulation"; then
233576ca98b0SPaolo Bonzini        roms="pc-bios/optionrom"
233633ab4787SPaolo Bonzini        config_mak=pc-bios/optionrom/config.mak
233733ab4787SPaolo Bonzini        echo "# Automatically generated by configure - do not modify" > $config_mak
233833ab4787SPaolo Bonzini        echo "TOPSRC_DIR=$source_path" >> $config_mak
233933ab4787SPaolo Bonzini        echo "LD_I386_EMULATION=$ld_i386_emulation" >> $config_mak
234033ab4787SPaolo Bonzini        write_target_makefile >> $config_mak
234133ab4787SPaolo Bonzini    fi
2342ca35f780SPaolo Bonzinifi
2343ca35f780SPaolo Bonzini
234452f08deaSPaolo Bonziniprobe_target_compiler ppc-softmmu
2345d695918fSPaolo Bonziniif test -n "$target_cc" && test "$softmmu" = yes; then
234676ca98b0SPaolo Bonzini    roms="$roms pc-bios/vof"
2347d695918fSPaolo Bonzini    config_mak=pc-bios/vof/config.mak
2348d695918fSPaolo Bonzini    echo "# Automatically generated by configure - do not modify" > $config_mak
2349d695918fSPaolo Bonzini    echo "SRC_DIR=$source_path/pc-bios/vof" >> $config_mak
2350d695918fSPaolo Bonzini    write_target_makefile >> $config_mak
2351d695918fSPaolo Bonzinifi
2352d695918fSPaolo Bonzini
23539ffed426SPaolo Bonzini# Only build s390-ccw bios if the compiler has -march=z900 or -march=z10
23549ffed426SPaolo Bonzini# (which is the lowest architecture level that Clang supports)
235552f08deaSPaolo Bonziniprobe_target_compiler s390x-softmmu
23569ffed426SPaolo Bonziniif test -n "$target_cc" && test "$softmmu" = yes; then
23572e33c3f8SThomas Huth  write_c_skeleton
23589ffed426SPaolo Bonzini  do_compiler "$target_cc" $target_cc_cflags -march=z900 -o $TMPO -c $TMPC
2359a5b2afd5SThomas Huth  has_z900=$?
23609ffed426SPaolo Bonzini  if [ $has_z900 = 0 ] || do_compiler "$target_cc" $target_cc_cflags -march=z10 -msoft-float -Werror -o $TMPO -c $TMPC; then
2361a5b2afd5SThomas Huth    if [ $has_z900 != 0 ]; then
2362a5b2afd5SThomas Huth      echo "WARNING: Your compiler does not support the z900!"
2363a5b2afd5SThomas Huth      echo "         The s390-ccw bios will only work with guest CPUs >= z10."
2364a5b2afd5SThomas Huth    fi
236576ca98b0SPaolo Bonzini    roms="$roms pc-bios/s390-ccw"
23669ffed426SPaolo Bonzini    config_mak=pc-bios/s390-ccw/config-host.mak
23679ffed426SPaolo Bonzini    echo "# Automatically generated by configure - do not modify" > $config_mak
23689ffed426SPaolo Bonzini    echo "SRC_PATH=$source_path/pc-bios/s390-ccw" >> $config_mak
23699ffed426SPaolo Bonzini    write_target_makefile >> $config_mak
23701ef6bfc2SPhilippe Mathieu-Daudé    # SLOF is required for building the s390-ccw firmware on s390x,
23711ef6bfc2SPhilippe Mathieu-Daudé    # since it is using the libnet code from SLOF for network booting.
23721ef6bfc2SPhilippe Mathieu-Daudé    git_submodules="${git_submodules} roms/SLOF"
23731ef6bfc2SPhilippe Mathieu-Daudé  fi
23749933c305SChristian Borntraegerfi
23759933c305SChristian Borntraeger
23769ffed426SPaolo Bonzini#######################################
23779ffed426SPaolo Bonzini# generate config-host.mak
23789ffed426SPaolo Bonzini
237911cde1c8SBruno Dominguez# Check that the C++ compiler exists and works with the C compiler.
238011cde1c8SBruno Dominguez# All the QEMU_CXXFLAGS are based on QEMU_CFLAGS. Keep this at the end to don't miss any other that could be added.
238111cde1c8SBruno Dominguezif has $cxx; then
238211cde1c8SBruno Dominguez    cat > $TMPC <<EOF
238311cde1c8SBruno Dominguezint c_function(void);
238411cde1c8SBruno Dominguezint main(void) { return c_function(); }
238511cde1c8SBruno DominguezEOF
238611cde1c8SBruno Dominguez
238711cde1c8SBruno Dominguez    compile_object
238811cde1c8SBruno Dominguez
238911cde1c8SBruno Dominguez    cat > $TMPCXX <<EOF
239011cde1c8SBruno Dominguezextern "C" {
239111cde1c8SBruno Dominguez   int c_function(void);
239211cde1c8SBruno Dominguez}
239311cde1c8SBruno Dominguezint c_function(void) { return 42; }
239411cde1c8SBruno DominguezEOF
239511cde1c8SBruno Dominguez
239611cde1c8SBruno Dominguez    update_cxxflags
239711cde1c8SBruno Dominguez
2398a2866660SPaolo Bonzini    if do_cxx $CXXFLAGS $EXTRA_CXXFLAGS $CONFIGURE_CXXFLAGS $QEMU_CXXFLAGS -o $TMPE $TMPCXX $TMPO $QEMU_LDFLAGS; then
239911cde1c8SBruno Dominguez        # C++ compiler $cxx works ok with C compiler $cc
240011cde1c8SBruno Dominguez        :
240111cde1c8SBruno Dominguez    else
240211cde1c8SBruno Dominguez        echo "C++ compiler $cxx does not work with C compiler $cc"
240311cde1c8SBruno Dominguez        echo "Disabling C++ specific optional code"
240411cde1c8SBruno Dominguez        cxx=
240511cde1c8SBruno Dominguez    fi
240611cde1c8SBruno Dominguezelse
240711cde1c8SBruno Dominguez    echo "No C++ compiler available; disabling C++ specific optional code"
240811cde1c8SBruno Dominguez    cxx=
240911cde1c8SBruno Dominguezfi
241011cde1c8SBruno Dominguez
24117d7dbf9dSDan Streetmanif ! (GIT="$git" "$source_path/scripts/git-submodule.sh" "$git_submodules_action" "$git_submodules"); then
24127d7dbf9dSDan Streetman    exit 1
24135d91a2edSYonggang Luofi
24145d91a2edSYonggang Luo
241598ec69acSJuan Quintelaconfig_host_mak="config-host.mak"
241697a847bcSbellard
241798ec69acSJuan Quintelaecho "# Automatically generated by configure - do not modify" > $config_host_mak
241898ec69acSJuan Quintelaecho >> $config_host_mak
241998ec69acSJuan Quintela
2420e6c3b0f7SPaolo Bonziniecho all: >> $config_host_mak
2421cc84d63aSDaniel P. Berrangeecho "GIT=$git" >> $config_host_mak
2422aef45d51SDaniel P. Berrangeecho "GIT_SUBMODULES=$git_submodules" >> $config_host_mak
24237d7dbf9dSDan Streetmanecho "GIT_SUBMODULES_ACTION=$git_submodules_action" >> $config_host_mak
2424804edf29SJuan Quintela
2425f8393946Saurel32if test "$debug_tcg" = "yes" ; then
24262358a494SJuan Quintela  echo "CONFIG_DEBUG_TCG=y" >> $config_host_mak
2427f8393946Saurel32fi
242867b915a5Sbellardif test "$mingw32" = "yes" ; then
242998ec69acSJuan Quintela  echo "CONFIG_WIN32=y" >> $config_host_mak
24309dacf32dSYossi Hindin  echo "QEMU_GA_MANUFACTURER=${QEMU_GA_MANUFACTURER}" >> $config_host_mak
24319dacf32dSYossi Hindin  echo "QEMU_GA_DISTRO=${QEMU_GA_DISTRO}" >> $config_host_mak
24329dacf32dSYossi Hindin  echo "QEMU_GA_VERSION=${QEMU_GA_VERSION}" >> $config_host_mak
2433210fa556Spbrookelse
243435f4df27SJuan Quintela  echo "CONFIG_POSIX=y" >> $config_host_mak
2435210fa556Spbrookfi
2436128ab2ffSblueswir1
2437dffcb71cSMark McLoughlinif test "$linux" = "yes" ; then
2438dffcb71cSMark McLoughlin  echo "CONFIG_LINUX=y" >> $config_host_mak
2439dffcb71cSMark McLoughlinfi
2440dffcb71cSMark McLoughlin
244183fb7adfSbellardif test "$darwin" = "yes" ; then
244298ec69acSJuan Quintela  echo "CONFIG_DARWIN=y" >> $config_host_mak
244383fb7adfSbellardfi
2444b29fe3edSmalc
2445ec530c81Sbellardif test "$solaris" = "yes" ; then
244698ec69acSJuan Quintela  echo "CONFIG_SOLARIS=y" >> $config_host_mak
2447ec530c81Sbellardfi
244897a847bcSbellardif test "$static" = "yes" ; then
244998ec69acSJuan Quintela  echo "CONFIG_STATIC=y" >> $config_host_mak
245097a847bcSbellardfi
245198ec69acSJuan Quintelaecho "SRC_PATH=$source_path" >> $config_host_mak
24522b1f35b9SAlex Bennéeecho "TARGET_DIRS=$target_list" >> $config_host_mak
245317969268SFam Zhengif test "$modules" = "yes"; then
245417969268SFam Zheng  echo "CONFIG_MODULES=y" >> $config_host_mak
245517969268SFam Zhengfi
2456277abf15SJan Vesely
245783fb7adfSbellard# XXX: suppress that
24587d3505c5Sbellardif [ "$bsd" = "yes" ] ; then
24592358a494SJuan Quintela  echo "CONFIG_BSD=y" >> $config_host_mak
24607d3505c5Sbellardfi
24617d3505c5Sbellard
24627c2acc70SPeter Maydellecho "CONFIG_COROUTINE_BACKEND=$coroutine" >> $config_host_mak
24637d992e4dSPeter Lieven
2464d83414e1SMarc-André Lureauif test "$have_asan_iface_fiber" = "yes" ; then
2465d83414e1SMarc-André Lureau    echo "CONFIG_ASAN_IFACE_FIBER=y" >> $config_host_mak
2466d83414e1SMarc-André Lureaufi
2467d83414e1SMarc-André Lureau
24680aebab04SLingfeng Yangif test "$have_tsan" = "yes" && test "$have_tsan_iface_fiber" = "yes" ; then
24690aebab04SLingfeng Yang    echo "CONFIG_TSAN=y" >> $config_host_mak
24700aebab04SLingfeng Yangfi
24710aebab04SLingfeng Yang
247240e8c6f4SAlex Bennéeif test "$plugins" = "yes" ; then
247340e8c6f4SAlex Bennée    echo "CONFIG_PLUGIN=y" >> $config_host_mak
247440e8c6f4SAlex Bennéefi
247540e8c6f4SAlex Bennée
2476f48e590aSAlex Bennéeif test -n "$gdb_bin"; then
2477b1863cccSAlex Bennée    gdb_version=$($gdb_bin --version | head -n 1)
2478d6a66c81SAlex Bennée    if version_ge ${gdb_version##* } 9.1; then
2479f48e590aSAlex Bennée        echo "HAVE_GDB_BIN=$gdb_bin" >> $config_host_mak
2480f48e590aSAlex Bennée    fi
2481b1863cccSAlex Bennéefi
2482f48e590aSAlex Bennée
248398ec69acSJuan Quintelaecho "ROMS=$roms" >> $config_host_mak
2484804edf29SJuan Quintelaecho "MAKE=$make" >> $config_host_mak
2485c886edfbSBlue Swirlecho "PYTHON=$python" >> $config_host_mak
248639d87c8cSAlex Bennéeecho "GENISOIMAGE=$genisoimage" >> $config_host_mak
2487a5665051SPaolo Bonziniecho "MESON=$meson" >> $config_host_mak
248809e93326SPaolo Bonziniecho "NINJA=$ninja" >> $config_host_mak
2489804edf29SJuan Quintelaecho "CC=$cc" >> $config_host_mak
2490a558ee17SJuan Quintelaecho "QEMU_CFLAGS=$QEMU_CFLAGS" >> $config_host_mak
249111cde1c8SBruno Dominguezecho "QEMU_CXXFLAGS=$QEMU_CXXFLAGS" >> $config_host_mak
24924cb37d11SPhilippe Mathieu-Daudéecho "QEMU_OBJCFLAGS=$QEMU_OBJCFLAGS" >> $config_host_mak
2493a81df1b6SPaolo Bonziniecho "GLIB_CFLAGS=$glib_cflags" >> $config_host_mak
2494a81df1b6SPaolo Bonziniecho "GLIB_LIBS=$glib_libs" >> $config_host_mak
24955b9e7d05SMarc-André Lureauecho "GLIB_BINDIR=$glib_bindir" >> $config_host_mak
2496d83acfd0SMarc-André Lureauecho "GLIB_VERSION=$(pkg-config --modversion glib-2.0)" >> $config_host_mak
24978a99e9a3SPhilippe Mathieu-Daudéecho "QEMU_LDFLAGS=$QEMU_LDFLAGS" >> $config_host_mak
2498804edf29SJuan Quintelaecho "EXESUF=$EXESUF" >> $config_host_mak
2499804edf29SJuan Quintela
25006efd7517SPeter Maydell# use included Linux headers
25016efd7517SPeter Maydellif test "$linux" = "yes" ; then
2502a307beb6SAndreas Färber  mkdir -p linux-headers
25036efd7517SPeter Maydell  case "$cpu" in
25044da270beSPaolo Bonzini  i386|x86_64)
250508312a63SPeter Maydell    linux_arch=x86
25066efd7517SPeter Maydell    ;;
2507d8ff892dSPaolo Bonzini  ppc|ppc64)
250808312a63SPeter Maydell    linux_arch=powerpc
25096efd7517SPeter Maydell    ;;
25106efd7517SPeter Maydell  s390x)
251108312a63SPeter Maydell    linux_arch=s390
251208312a63SPeter Maydell    ;;
25131f080313SClaudio Fontana  aarch64)
25141f080313SClaudio Fontana    linux_arch=arm64
25151f080313SClaudio Fontana    ;;
2516dfcf900bSWANG Xuerui  loongarch*)
2517dfcf900bSWANG Xuerui    linux_arch=loongarch
2518dfcf900bSWANG Xuerui    ;;
2519222e7d11SSanjay Lal  mips64)
2520222e7d11SSanjay Lal    linux_arch=mips
2521222e7d11SSanjay Lal    ;;
252208312a63SPeter Maydell  *)
252308312a63SPeter Maydell    # For most CPUs the kernel architecture name and QEMU CPU name match.
252408312a63SPeter Maydell    linux_arch="$cpu"
25256efd7517SPeter Maydell    ;;
25266efd7517SPeter Maydell  esac
252708312a63SPeter Maydell    # For non-KVM architectures we will not have asm headers
252808312a63SPeter Maydell    if [ -e "$source_path/linux-headers/asm-$linux_arch" ]; then
252908312a63SPeter Maydell      symlink "$source_path/linux-headers/asm-$linux_arch" linux-headers/asm
253008312a63SPeter Maydell    fi
25316efd7517SPeter Maydellfi
25326efd7517SPeter Maydell
253397a847bcSbellardfor target in $target_list; do
253497a847bcSbellard    target_dir="$target"
253557a93f16SPhilippe Mathieu-Daudé    target_name=$(echo $target | cut -d '-' -f 1)$EXESUF
253664708615SPeter Maydell    mkdir -p "$target_dir"
2537fdb75aefSPaolo Bonzini    case $target in
2538fdb75aefSPaolo Bonzini        *-user) symlink "../qemu-$target_name" "$target_dir/qemu-$target_name" ;;
2539fdb75aefSPaolo Bonzini        *) symlink "../qemu-system-$target_name" "$target_dir/qemu-system-$target_name" ;;
25402408a527Saurel32    esac
254156aebc89Spbrookdone
25427d13299dSbellard
2543fdb75aefSPaolo Bonziniif test "$default_targets" = "yes"; then
2544fdb75aefSPaolo Bonzini  echo "CONFIG_DEFAULT_TARGETS=y" >> $config_host_mak
2545fdb75aefSPaolo Bonzinifi
2546a540f158SPeter Crosthwaite
2547fd0e6053SJohn Snowif test "$ccache_cpp2" = "yes"; then
2548fd0e6053SJohn Snow  echo "export CCACHE_CPP2=y" >> $config_host_mak
2549fd0e6053SJohn Snowfi
2550fd0e6053SJohn Snow
25511e4f6065SDaniele Buonoif test "$safe_stack" = "yes"; then
25521e4f6065SDaniele Buono  echo "CONFIG_SAFESTACK=y" >> $config_host_mak
25531e4f6065SDaniele Buonofi
25541e4f6065SDaniele Buono
2555cd362defSPaolo Bonzini# tests/tcg configuration
2556cd362defSPaolo Bonzini(makefile=tests/tcg/Makefile.prereqs
2557cd362defSPaolo Bonziniecho "# Automatically generated by configure - do not modify" > $makefile
2558cd362defSPaolo Bonzini
2559cd362defSPaolo Bonziniconfig_host_mak=tests/tcg/config-host.mak
2560cd362defSPaolo Bonziniecho "# Automatically generated by configure - do not modify" > $config_host_mak
2561cd362defSPaolo Bonziniecho "SRC_PATH=$source_path" >> $config_host_mak
2562cd362defSPaolo Bonziniecho "HOST_CC=$host_cc" >> $config_host_mak
2563cd362defSPaolo Bonzini
2564cd362defSPaolo Bonzinitcg_tests_targets=
2565cd362defSPaolo Bonzinifor target in $target_list; do
2566cd362defSPaolo Bonzini  arch=${target%%-*}
2567cd362defSPaolo Bonzini
2568cd362defSPaolo Bonzini  config_target_mak=tests/tcg/config-$target.mak
2569cd362defSPaolo Bonzini
2570cd362defSPaolo Bonzini  echo "# Automatically generated by configure - do not modify" > $config_target_mak
257164708615SPeter Maydell  echo "TARGET_NAME=$arch" >> "$config_target_mak"
2572cd362defSPaolo Bonzini  case $target in
2573c48a5c47SPaolo Bonzini    xtensa*-linux-user)
2574c48a5c47SPaolo Bonzini      # the toolchain is not complete with headers, only build softmmu tests
2575c48a5c47SPaolo Bonzini      continue
2576c48a5c47SPaolo Bonzini      ;;
2577cd362defSPaolo Bonzini    *-softmmu)
257864708615SPeter Maydell      test -f "$source_path/tests/tcg/$arch/Makefile.softmmu-target" || continue
2579cd362defSPaolo Bonzini      qemu="qemu-system-$arch"
2580cd362defSPaolo Bonzini      ;;
2581cd362defSPaolo Bonzini    *-linux-user|*-bsd-user)
2582cd362defSPaolo Bonzini      qemu="qemu-$arch"
2583cd362defSPaolo Bonzini      ;;
2584cd362defSPaolo Bonzini  esac
2585cd362defSPaolo Bonzini
258652f08deaSPaolo Bonzini  probe_target_compiler $target
2587cd362defSPaolo Bonzini  if test $got_cross_cc = yes; then
2588cd362defSPaolo Bonzini      # Test for compiler features for optional tests. We only do this
2589cd362defSPaolo Bonzini      # for cross compilers because ensuring the docker containers based
2590cd362defSPaolo Bonzini      # compilers is a requirememt for adding a new test that needs a
2591cd362defSPaolo Bonzini      # compiler feature.
2592cd362defSPaolo Bonzini
259364708615SPeter Maydell      echo "BUILD_STATIC=$build_static" >> "$config_target_mak"
259464708615SPeter Maydell      write_target_makefile >> "$config_target_mak"
2595cd362defSPaolo Bonzini      case $target in
2596cd362defSPaolo Bonzini          aarch64-*)
2597cd362defSPaolo Bonzini              if do_compiler "$target_cc" $target_cflags \
2598cd362defSPaolo Bonzini                             -march=armv8.1-a+sve -o $TMPE $TMPC; then
259964708615SPeter Maydell                  echo "CROSS_CC_HAS_SVE=y" >> "$config_target_mak"
2600cd362defSPaolo Bonzini              fi
2601cd362defSPaolo Bonzini              if do_compiler "$target_cc" $target_cflags \
2602cd362defSPaolo Bonzini                             -march=armv8.1-a+sve2 -o $TMPE $TMPC; then
260364708615SPeter Maydell                  echo "CROSS_CC_HAS_SVE2=y" >> "$config_target_mak"
2604cd362defSPaolo Bonzini              fi
2605cd362defSPaolo Bonzini              if do_compiler "$target_cc" $target_cflags \
2606cd362defSPaolo Bonzini                             -march=armv8.3-a -o $TMPE $TMPC; then
260764708615SPeter Maydell                  echo "CROSS_CC_HAS_ARMV8_3=y" >> "$config_target_mak"
2608cd362defSPaolo Bonzini              fi
2609cd362defSPaolo Bonzini              if do_compiler "$target_cc" $target_cflags \
2610cd362defSPaolo Bonzini                             -mbranch-protection=standard -o $TMPE $TMPC; then
261164708615SPeter Maydell                  echo "CROSS_CC_HAS_ARMV8_BTI=y" >> "$config_target_mak"
2612cd362defSPaolo Bonzini              fi
2613cd362defSPaolo Bonzini              if do_compiler "$target_cc" $target_cflags \
2614cd362defSPaolo Bonzini                             -march=armv8.5-a+memtag -o $TMPE $TMPC; then
261564708615SPeter Maydell                  echo "CROSS_CC_HAS_ARMV8_MTE=y" >> "$config_target_mak"
2616cd362defSPaolo Bonzini              fi
2617cd362defSPaolo Bonzini              ;;
2618cd362defSPaolo Bonzini          ppc*)
2619cd362defSPaolo Bonzini              if do_compiler "$target_cc" $target_cflags \
2620cd362defSPaolo Bonzini                             -mpower8-vector -o $TMPE $TMPC; then
262164708615SPeter Maydell                  echo "CROSS_CC_HAS_POWER8_VECTOR=y" >> "$config_target_mak"
2622cd362defSPaolo Bonzini              fi
2623cd362defSPaolo Bonzini              if do_compiler "$target_cc" $target_cflags \
2624cd362defSPaolo Bonzini                             -mpower10 -o $TMPE $TMPC; then
262564708615SPeter Maydell                  echo "CROSS_CC_HAS_POWER10=y" >> "$config_target_mak"
2626cd362defSPaolo Bonzini              fi
2627cd362defSPaolo Bonzini              ;;
2628cd362defSPaolo Bonzini          i386-linux-user)
2629cd362defSPaolo Bonzini              if do_compiler "$target_cc" $target_cflags \
2630cd362defSPaolo Bonzini                             -Werror -fno-pie -o $TMPE $TMPC; then
263164708615SPeter Maydell                  echo "CROSS_CC_HAS_I386_NOPIE=y" >> "$config_target_mak"
2632cd362defSPaolo Bonzini              fi
2633cd362defSPaolo Bonzini              ;;
2634cd362defSPaolo Bonzini      esac
2635cd362defSPaolo Bonzini  elif test -n "$container_image"; then
2636cd362defSPaolo Bonzini      echo "build-tcg-tests-$target: docker-image-$container_image" >> $makefile
263764708615SPeter Maydell      echo "BUILD_STATIC=y" >> "$config_target_mak"
263864708615SPeter Maydell      write_container_target_makefile >> "$config_target_mak"
2639cd362defSPaolo Bonzini      case $target in
2640cd362defSPaolo Bonzini          aarch64-*)
264164708615SPeter Maydell              echo "CROSS_CC_HAS_SVE=y" >> "$config_target_mak"
264264708615SPeter Maydell              echo "CROSS_CC_HAS_SVE2=y" >> "$config_target_mak"
264364708615SPeter Maydell              echo "CROSS_CC_HAS_ARMV8_3=y" >> "$config_target_mak"
264464708615SPeter Maydell              echo "CROSS_CC_HAS_ARMV8_BTI=y" >> "$config_target_mak"
264564708615SPeter Maydell              echo "CROSS_CC_HAS_ARMV8_MTE=y" >> "$config_target_mak"
2646cd362defSPaolo Bonzini              ;;
2647cd362defSPaolo Bonzini          ppc*)
264864708615SPeter Maydell              echo "CROSS_CC_HAS_POWER8_VECTOR=y" >> "$config_target_mak"
264964708615SPeter Maydell              echo "CROSS_CC_HAS_POWER10=y" >> "$config_target_mak"
2650cd362defSPaolo Bonzini              ;;
2651cd362defSPaolo Bonzini          i386-linux-user)
265264708615SPeter Maydell              echo "CROSS_CC_HAS_I386_NOPIE=y" >> "$config_target_mak"
2653cd362defSPaolo Bonzini              ;;
2654cd362defSPaolo Bonzini      esac
2655cd362defSPaolo Bonzini      got_cross_cc=yes
2656cd362defSPaolo Bonzini  fi
2657cd362defSPaolo Bonzini  if test $got_cross_cc = yes; then
2658cd362defSPaolo Bonzini      mkdir -p tests/tcg/$target
265964708615SPeter Maydell      echo "QEMU=$PWD/$qemu" >> "$config_target_mak"
2660cd362defSPaolo Bonzini      echo "run-tcg-tests-$target: $qemu\$(EXESUF)" >> $makefile
2661cd362defSPaolo Bonzini      tcg_tests_targets="$tcg_tests_targets $target"
2662cd362defSPaolo Bonzini  fi
26632038f8c8SPaolo Bonzinidone
2664cd362defSPaolo Bonziniecho "TCG_TESTS_TARGETS=$tcg_tests_targets" >> $makefile)
26652038f8c8SPaolo Bonzini
2666a5665051SPaolo Bonziniif test "$skip_meson" = no; then
2667fc929892SMarc-André Lureau  cross="config-meson.cross.new"
2668fc929892SMarc-André Lureau  meson_quote() {
2669ac7ebcc5SPaolo Bonzini    test $# = 0 && return
267047b30835SPaolo Bonzini    echo "'$(echo $* | sed "s/ /','/g")'"
2671fc929892SMarc-André Lureau  }
2672fc929892SMarc-André Lureau
2673fc929892SMarc-André Lureau  echo "# Automatically generated by configure - do not modify" > $cross
2674fc929892SMarc-André Lureau  echo "[properties]" >> $cross
2675d1d5e9eeSAlex Bennée
2676d1d5e9eeSAlex Bennée  # unroll any custom device configs
2677d1d5e9eeSAlex Bennée  for a in $device_archs; do
2678d1d5e9eeSAlex Bennée      eval "c=\$devices_${a}"
2679d1d5e9eeSAlex Bennée      echo "${a}-softmmu = '$c'" >> $cross
2680d1d5e9eeSAlex Bennée  done
2681d1d5e9eeSAlex Bennée
2682fc929892SMarc-André Lureau  test -z "$cxx" && echo "link_language = 'c'" >> $cross
268347b30835SPaolo Bonzini  echo "[built-in options]" >> $cross
2684a2866660SPaolo Bonzini  echo "c_args = [$(meson_quote $CFLAGS $EXTRA_CFLAGS)]" >> $cross
2685a2866660SPaolo Bonzini  echo "cpp_args = [$(meson_quote $CXXFLAGS $EXTRA_CXXFLAGS)]" >> $cross
2686e910c7d9SPhilippe Mathieu-Daudé  test -n "$objcc" && echo "objc_args = [$(meson_quote $OBJCFLAGS $EXTRA_OBJCFLAGS)]" >> $cross
2687a2866660SPaolo Bonzini  echo "c_link_args = [$(meson_quote $CFLAGS $LDFLAGS $EXTRA_CFLAGS $EXTRA_LDFLAGS)]" >> $cross
2688a2866660SPaolo Bonzini  echo "cpp_link_args = [$(meson_quote $CXXFLAGS $LDFLAGS $EXTRA_CXXFLAGS $EXTRA_LDFLAGS)]" >> $cross
2689fc929892SMarc-André Lureau  echo "[binaries]" >> $cross
26904dba2789SPaolo Bonzini  echo "c = [$(meson_quote $cc $CPU_CFLAGS)]" >> $cross
26914dba2789SPaolo Bonzini  test -n "$cxx" && echo "cpp = [$(meson_quote $cxx $CPU_CFLAGS)]" >> $cross
26924dba2789SPaolo Bonzini  test -n "$objcc" && echo "objc = [$(meson_quote $objcc $CPU_CFLAGS)]" >> $cross
269347b30835SPaolo Bonzini  echo "ar = [$(meson_quote $ar)]" >> $cross
269447b30835SPaolo Bonzini  echo "nm = [$(meson_quote $nm)]" >> $cross
269547b30835SPaolo Bonzini  echo "pkgconfig = [$(meson_quote $pkg_config_exe)]" >> $cross
269647b30835SPaolo Bonzini  echo "ranlib = [$(meson_quote $ranlib)]" >> $cross
2697e8178514SPaolo Bonzini  if has $sdl2_config; then
269847b30835SPaolo Bonzini    echo "sdl2-config = [$(meson_quote $sdl2_config)]" >> $cross
2699e8178514SPaolo Bonzini  fi
270047b30835SPaolo Bonzini  echo "strip = [$(meson_quote $strip)]" >> $cross
2701158bb224SKonstantin Kostiuk  echo "widl = [$(meson_quote $widl)]" >> $cross
270247b30835SPaolo Bonzini  echo "windres = [$(meson_quote $windres)]" >> $cross
27033812c0c4SJoelle van Dyne  if test "$cross_compile" = "yes"; then
2704fc929892SMarc-André Lureau    cross_arg="--cross-file config-meson.cross"
2705fc929892SMarc-André Lureau    echo "[host_machine]" >> $cross
2706ba7c60c2SPaolo Bonzini    echo "system = '$targetos'" >> $cross
2707823eb013SPaolo Bonzini    case "$cpu" in
2708f6bca9dfSJoelle van Dyne        i386)
2709fc929892SMarc-André Lureau            echo "cpu_family = 'x86'" >> $cross
2710fc929892SMarc-André Lureau            ;;
2711fc929892SMarc-André Lureau        *)
2712823eb013SPaolo Bonzini            echo "cpu_family = '$cpu'" >> $cross
2713fc929892SMarc-André Lureau            ;;
2714fc929892SMarc-André Lureau    esac
2715fc929892SMarc-André Lureau    echo "cpu = '$cpu'" >> $cross
2716fc929892SMarc-André Lureau    if test "$bigendian" = "yes" ; then
2717fc929892SMarc-André Lureau        echo "endian = 'big'" >> $cross
2718fc929892SMarc-André Lureau    else
2719fc929892SMarc-André Lureau        echo "endian = 'little'" >> $cross
2720fc929892SMarc-André Lureau    fi
2721fc929892SMarc-André Lureau  else
2722fc929892SMarc-André Lureau    cross_arg="--native-file config-meson.cross"
2723fc929892SMarc-André Lureau  fi
2724fc929892SMarc-André Lureau  mv $cross config-meson.cross
2725fc929892SMarc-André Lureau
2726a5665051SPaolo Bonzini  rm -rf meson-private meson-info meson-logs
27270a31e3a0SPaolo Bonzini
27280a31e3a0SPaolo Bonzini  # Built-in options
27290a31e3a0SPaolo Bonzini  test "$bindir" != "bin" && meson_option_add "-Dbindir=$bindir"
27300a31e3a0SPaolo Bonzini  test "$default_feature" = no && meson_option_add -Dauto_features=disabled
27310a31e3a0SPaolo Bonzini  test "$pie" = no && meson_option_add -Db_pie=false
27320a31e3a0SPaolo Bonzini  test "$werror" = yes && meson_option_add -Dwerror=true
27330a31e3a0SPaolo Bonzini
27340a31e3a0SPaolo Bonzini  # QEMU options
27350a31e3a0SPaolo Bonzini  test "$cfi" != false && meson_option_add "-Dcfi=$cfi"
27360a31e3a0SPaolo Bonzini  test "$fdt" != auto && meson_option_add "-Dfdt=$fdt"
27370a31e3a0SPaolo Bonzini  test -n "${LIB_FUZZING_ENGINE+xxx}" && meson_option_add "-Dfuzzing_engine=$LIB_FUZZING_ENGINE"
27380a31e3a0SPaolo Bonzini  test "$qemu_suffix" != qemu && meson_option_add "-Dqemu_suffix=$qemu_suffix"
27390a31e3a0SPaolo Bonzini  test "$slirp" != auto && meson_option_add "-Dslirp=$slirp"
27400a31e3a0SPaolo Bonzini  test "$smbd" != '' && meson_option_add "-Dsmbd=$smbd"
27410a31e3a0SPaolo Bonzini  test "$tcg" != enabled && meson_option_add "-Dtcg=$tcg"
274255116968SJagannathan Raman  test "$vfio_user_server" != auto && meson_option_add "-Dvfio_user_server=$vfio_user_server"
274361d63097SPaolo Bonzini  run_meson() {
27440a31e3a0SPaolo Bonzini    NINJA=$ninja $meson setup --prefix "$prefix" "$@" $cross_arg "$PWD" "$source_path"
274561d63097SPaolo Bonzini  }
274661d63097SPaolo Bonzini  eval run_meson $meson_options
2747a5665051SPaolo Bonzini  if test "$?" -ne 0 ; then
2748a5665051SPaolo Bonzini      error_exit "meson setup failed"
2749a5665051SPaolo Bonzini  fi
2750699d3884SPaolo Bonzinielse
2751699d3884SPaolo Bonzini  if test -f meson-private/cmd_line.txt; then
2752699d3884SPaolo Bonzini    # Adjust old command line options whose type was changed
2753699d3884SPaolo Bonzini    # Avoids having to use "setup --wipe" when Meson is upgraded
2754699d3884SPaolo Bonzini    perl -i -ne '
2755699d3884SPaolo Bonzini      s/^gettext = true$/gettext = auto/;
2756699d3884SPaolo Bonzini      s/^gettext = false$/gettext = disabled/;
2757654d6b04SPaolo Bonzini      /^b_staticpic/ && next;
2758699d3884SPaolo Bonzini      print;' meson-private/cmd_line.txt
2759699d3884SPaolo Bonzini  fi
2760a5665051SPaolo Bonzinifi
2761a5665051SPaolo Bonzini
2762dc655404SMichael S. Tsirkin# Save the configure command line for later reuse.
2763dc655404SMichael S. Tsirkincat <<EOD >config.status
2764dc655404SMichael S. Tsirkin#!/bin/sh
2765dc655404SMichael S. Tsirkin# Generated by configure.
2766dc655404SMichael S. Tsirkin# Run this file to recreate the current configuration.
2767dc655404SMichael S. Tsirkin# Compiler output produced by configure, useful for debugging
2768dc655404SMichael S. Tsirkin# configure, is in config.log if it exists.
2769dc655404SMichael S. TsirkinEOD
2770e811da7fSDaniel P. Berrangé
2771e811da7fSDaniel P. Berrangépreserve_env() {
2772e811da7fSDaniel P. Berrangé    envname=$1
2773e811da7fSDaniel P. Berrangé
2774e811da7fSDaniel P. Berrangé    eval envval=\$$envname
2775e811da7fSDaniel P. Berrangé
2776e811da7fSDaniel P. Berrangé    if test -n "$envval"
2777e811da7fSDaniel P. Berrangé    then
2778e811da7fSDaniel P. Berrangé	echo "$envname='$envval'" >> config.status
2779e811da7fSDaniel P. Berrangé	echo "export $envname" >> config.status
2780e811da7fSDaniel P. Berrangé    else
2781e811da7fSDaniel P. Berrangé	echo "unset $envname" >> config.status
2782e811da7fSDaniel P. Berrangé    fi
2783e811da7fSDaniel P. Berrangé}
2784e811da7fSDaniel P. Berrangé
2785e811da7fSDaniel P. Berrangé# Preserve various env variables that influence what
2786e811da7fSDaniel P. Berrangé# features/build target configure will detect
2787e811da7fSDaniel P. Berrangépreserve_env AR
2788e811da7fSDaniel P. Berrangépreserve_env AS
2789e811da7fSDaniel P. Berrangépreserve_env CC
27908009da03SPaolo Bonzinipreserve_env CFLAGS
2791e811da7fSDaniel P. Berrangépreserve_env CXX
27928009da03SPaolo Bonzinipreserve_env CXXFLAGS
2793e811da7fSDaniel P. Berrangépreserve_env LD
27948009da03SPaolo Bonzinipreserve_env LDFLAGS
2795e811da7fSDaniel P. Berrangépreserve_env LD_LIBRARY_PATH
2796e811da7fSDaniel P. Berrangépreserve_env MAKE
2797e811da7fSDaniel P. Berrangépreserve_env NM
2798b5569e5bSPaolo Bonzinipreserve_env OBJCFLAGS
2799e811da7fSDaniel P. Berrangépreserve_env OBJCOPY
2800e811da7fSDaniel P. Berrangépreserve_env PATH
2801e811da7fSDaniel P. Berrangépreserve_env PKG_CONFIG
2802e811da7fSDaniel P. Berrangépreserve_env PKG_CONFIG_LIBDIR
2803e811da7fSDaniel P. Berrangépreserve_env PKG_CONFIG_PATH
2804e811da7fSDaniel P. Berrangépreserve_env PYTHON
2805e811da7fSDaniel P. Berrangépreserve_env SDL2_CONFIG
2806e811da7fSDaniel P. Berrangépreserve_env SMBD
2807e811da7fSDaniel P. Berrangépreserve_env STRIP
2808158bb224SKonstantin Kostiukpreserve_env WIDL
2809e811da7fSDaniel P. Berrangépreserve_env WINDRES
2810e811da7fSDaniel P. Berrangé
2811dc655404SMichael S. Tsirkinprintf "exec" >>config.status
2812a5665051SPaolo Bonzinifor i in "$0" "$@"; do
2813835af899SPaolo Bonzini  test "$i" = --skip-meson || printf " %s" "$(quote_sh "$i")" >>config.status
2814a5665051SPaolo Bonzinidone
2815cf7cc929SDr. David Alan Gilbertecho ' "$@"' >>config.status
2816dc655404SMichael S. Tsirkinchmod +x config.status
2817dc655404SMichael S. Tsirkin
28188cd05ab6SPeter Maydellrm -r "$TMPDIR1"
2819