xref: /openbmc/qemu/configure (revision b3b5472d)
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}"
70563661c0SPeter Maydellif ! mkdir -p "${TMPDIR1}"; then
718cd05ab6SPeter Maydell    echo "ERROR: failed to create temporary directory"
728cd05ab6SPeter Maydell    exit 1
737d13299dSbellardfi
747d13299dSbellard
758cd05ab6SPeter MaydellTMPB="qemu-conf"
768cd05ab6SPeter MaydellTMPC="${TMPDIR1}/${TMPB}.c"
7766518bf6SDon SlutzTMPO="${TMPDIR1}/${TMPB}.o"
789c83ffd8SPeter MaydellTMPCXX="${TMPDIR1}/${TMPB}.cxx"
794cb37d11SPhilippe Mathieu-DaudéTMPM="${TMPDIR1}/${TMPB}.m"
808cd05ab6SPeter MaydellTMPE="${TMPDIR1}/${TMPB}.exe"
817d13299dSbellard
82da1d85e3SGerd Hoffmannrm -f config.log
839ac81bbbSmalc
84b48e3611SPeter Maydell# Print a helpful header at the top of config.log
85b48e3611SPeter Maydellecho "# QEMU configure log $(date)" >> config.log
86979ae168SPeter Maydellprintf "# Configured with:" >> config.log
87979ae168SPeter Maydellprintf " '%s'" "$0" "$@" >> config.log
88979ae168SPeter Maydellecho >> config.log
89b48e3611SPeter Maydellecho "#" >> config.log
90b48e3611SPeter Maydell
91835af899SPaolo Bonziniquote_sh() {
92835af899SPaolo Bonzini    printf "%s" "$1" | sed "s,','\\\\'',g; s,.*,'&',"
93835af899SPaolo Bonzini}
94835af899SPaolo Bonzini
95d880a3baSPaolo Bonziniprint_error() {
96d880a3baSPaolo Bonzini    (echo
9776ad07a4SPeter Maydell    echo "ERROR: $1"
9876ad07a4SPeter Maydell    while test -n "$2"; do
9976ad07a4SPeter Maydell        echo "       $2"
10076ad07a4SPeter Maydell        shift
10176ad07a4SPeter Maydell    done
102d880a3baSPaolo Bonzini    echo) >&2
103d880a3baSPaolo Bonzini}
104d880a3baSPaolo Bonzini
105d880a3baSPaolo Bonzinierror_exit() {
106d880a3baSPaolo Bonzini    print_error "$@"
10776ad07a4SPeter Maydell    exit 1
10876ad07a4SPeter Maydell}
10976ad07a4SPeter Maydell
1109c83ffd8SPeter Maydelldo_compiler() {
1119c83ffd8SPeter Maydell  # Run the compiler, capturing its output to the log. First argument
1129c83ffd8SPeter Maydell  # is compiler binary to execute.
113*b3b5472dSPeter Maydell  compiler="$1"
114cd362defSPaolo Bonzini  shift
115cd362defSPaolo Bonzini  if test -n "$BASH_VERSION"; then eval '
116cd362defSPaolo Bonzini      echo >>config.log "
117cd362defSPaolo Bonzinifuncs: ${FUNCNAME[*]}
118cd362defSPaolo Bonzinilines: ${BASH_LINENO[*]}"
119cd362defSPaolo Bonzini  '; fi
120cd362defSPaolo Bonzini  echo $compiler "$@" >> config.log
121cd362defSPaolo Bonzini  $compiler "$@" >> config.log 2>&1 || return $?
122cd362defSPaolo Bonzini}
123cd362defSPaolo Bonzini
124cd362defSPaolo Bonzinido_compiler_werror() {
125cd362defSPaolo Bonzini    # Run the compiler, capturing its output to the log. First argument
126cd362defSPaolo Bonzini    # is compiler binary to execute.
127630d86b7SDavid CARLIER    compiler="$1"
1289c83ffd8SPeter Maydell    shift
1298bbe05d7SIan Jackson    if test -n "$BASH_VERSION"; then eval '
1308bbe05d7SIan Jackson        echo >>config.log "
1318bbe05d7SIan Jacksonfuncs: ${FUNCNAME[*]}
1328bbe05d7SIan Jacksonlines: ${BASH_LINENO[*]}"
1338bbe05d7SIan Jackson    '; fi
1349c83ffd8SPeter Maydell    echo $compiler "$@" >> config.log
1359c83ffd8SPeter Maydell    $compiler "$@" >> config.log 2>&1 || return $?
1368dc38a78SPeter Maydell    # Test passed. If this is an --enable-werror build, rerun
1378dc38a78SPeter Maydell    # the test with -Werror and bail out if it fails. This
1388dc38a78SPeter Maydell    # makes warning-generating-errors in configure test code
1398dc38a78SPeter Maydell    # obvious to developers.
1408dc38a78SPeter Maydell    if test "$werror" != "yes"; then
1418dc38a78SPeter Maydell        return 0
1428dc38a78SPeter Maydell    fi
1438dc38a78SPeter Maydell    # Don't bother rerunning the compile if we were already using -Werror
1448dc38a78SPeter Maydell    case "$*" in
1458dc38a78SPeter Maydell        *-Werror*)
1468dc38a78SPeter Maydell           return 0
1478dc38a78SPeter Maydell        ;;
1488dc38a78SPeter Maydell    esac
1499c83ffd8SPeter Maydell    echo $compiler -Werror "$@" >> config.log
1509c83ffd8SPeter Maydell    $compiler -Werror "$@" >> config.log 2>&1 && return $?
15176ad07a4SPeter Maydell    error_exit "configure test passed without -Werror but failed with -Werror." \
15276ad07a4SPeter Maydell        "This is probably a bug in the configure script. The failing command" \
15376ad07a4SPeter Maydell        "will be at the bottom of config.log." \
15476ad07a4SPeter Maydell        "You can run configure with --disable-werror to bypass this check."
1558dc38a78SPeter Maydell}
1568dc38a78SPeter Maydell
1579c83ffd8SPeter Maydelldo_cc() {
158cd362defSPaolo Bonzini    do_compiler_werror "$cc" $CPU_CFLAGS "$@"
1599c83ffd8SPeter Maydell}
1609c83ffd8SPeter Maydell
1619c83ffd8SPeter Maydelldo_cxx() {
162cd362defSPaolo Bonzini    do_compiler_werror "$cxx" $CPU_CFLAGS "$@"
1639c83ffd8SPeter Maydell}
1649c83ffd8SPeter Maydell
1654cb37d11SPhilippe Mathieu-Daudédo_objc() {
166cd362defSPaolo Bonzini    do_compiler_werror "$objcc" $CPU_CFLAGS "$@"
1674cb37d11SPhilippe Mathieu-Daudé}
1684cb37d11SPhilippe Mathieu-Daudé
16900849b92SRichard Henderson# Append $2 to the variable named $1, with space separation
17000849b92SRichard Hendersonadd_to() {
17100849b92SRichard Henderson    eval $1=\${$1:+\"\$$1 \"}\$2
17200849b92SRichard Henderson}
17300849b92SRichard Henderson
1749c83ffd8SPeter Maydellupdate_cxxflags() {
1759c83ffd8SPeter Maydell    # Set QEMU_CXXFLAGS from QEMU_CFLAGS by filtering out those
1769c83ffd8SPeter Maydell    # options which some versions of GCC's C++ compiler complain about
1779c83ffd8SPeter Maydell    # because they only make sense for C programs.
178de38c0ccSPaolo Bonzini    QEMU_CXXFLAGS="-D__STDC_LIMIT_MACROS -D__STDC_CONSTANT_MACROS -D__STDC_FORMAT_MACROS"
1798a9d3d56SRichard Henderson    CONFIGURE_CXXFLAGS=$(echo "$CONFIGURE_CFLAGS" | sed s/-std=gnu11/-std=gnu++11/)
1809c83ffd8SPeter Maydell    for arg in $QEMU_CFLAGS; do
1819c83ffd8SPeter Maydell        case $arg in
1829c83ffd8SPeter Maydell            -Wstrict-prototypes|-Wmissing-prototypes|-Wnested-externs|\
1839c83ffd8SPeter Maydell            -Wold-style-declaration|-Wold-style-definition|-Wredundant-decls)
1849c83ffd8SPeter Maydell                ;;
1859c83ffd8SPeter Maydell            *)
1869c83ffd8SPeter Maydell                QEMU_CXXFLAGS=${QEMU_CXXFLAGS:+$QEMU_CXXFLAGS }$arg
1879c83ffd8SPeter Maydell                ;;
1889c83ffd8SPeter Maydell        esac
1899c83ffd8SPeter Maydell    done
1909c83ffd8SPeter Maydell}
1919c83ffd8SPeter Maydell
19252166aa0SJuan Quintelacompile_object() {
193fd0e6053SJohn Snow  local_cflags="$1"
194a2866660SPaolo Bonzini  do_cc $CFLAGS $EXTRA_CFLAGS $CONFIGURE_CFLAGS $QEMU_CFLAGS $local_cflags -c -o $TMPO $TMPC
19552166aa0SJuan Quintela}
19652166aa0SJuan Quintela
19752166aa0SJuan Quintelacompile_prog() {
19852166aa0SJuan Quintela  local_cflags="$1"
19952166aa0SJuan Quintela  local_ldflags="$2"
200a2866660SPaolo Bonzini  do_cc $CFLAGS $EXTRA_CFLAGS $CONFIGURE_CFLAGS $QEMU_CFLAGS $local_cflags -o $TMPE $TMPC \
201a2866660SPaolo Bonzini      $LDFLAGS $EXTRA_LDFLAGS $CONFIGURE_LDFLAGS $QEMU_LDFLAGS $local_ldflags
20252166aa0SJuan Quintela}
20352166aa0SJuan Quintela
20411568d6dSPaolo Bonzini# symbolically link $1 to $2.  Portable version of "ln -sf".
20511568d6dSPaolo Bonzinisymlink() {
20672b8b5a1SStefan Weil  rm -rf "$2"
207ec5b06d7SAnthony Liguori  mkdir -p "$(dirname "$2")"
20872b8b5a1SStefan Weil  ln -s "$1" "$2"
20911568d6dSPaolo Bonzini}
21011568d6dSPaolo Bonzini
2110dba6195SLoïc Minier# check whether a command is available to this shell (may be either an
2120dba6195SLoïc Minier# executable or a builtin)
2130dba6195SLoïc Minierhas() {
2140dba6195SLoïc Minier    type "$1" >/dev/null 2>&1
2150dba6195SLoïc Minier}
2160dba6195SLoïc Minier
2170a01d76fSMarc-André Lureauversion_ge () {
2182df52b9bSAlex Bennée    local_ver1=$(expr "$1" : '\([0-9.]*\)' | tr . ' ')
2192df52b9bSAlex Bennée    local_ver2=$(echo "$2" | tr . ' ')
2200a01d76fSMarc-André Lureau    while true; do
2210a01d76fSMarc-André Lureau        set x $local_ver1
2220a01d76fSMarc-André Lureau        local_first=${2-0}
223c44a33e2SStefano Garzarella        # 'shift 2' if $2 is set, or 'shift' if $2 is not set
224c44a33e2SStefano Garzarella        shift ${2:+2}
2250a01d76fSMarc-André Lureau        local_ver1=$*
2260a01d76fSMarc-André Lureau        set x $local_ver2
2270a01d76fSMarc-André Lureau        # the second argument finished, the first must be greater or equal
2280a01d76fSMarc-André Lureau        test $# = 1 && return 0
2290a01d76fSMarc-André Lureau        test $local_first -lt $2 && return 1
2300a01d76fSMarc-André Lureau        test $local_first -gt $2 && return 0
231c44a33e2SStefano Garzarella        shift ${2:+2}
2320a01d76fSMarc-André Lureau        local_ver2=$*
2330a01d76fSMarc-André Lureau    done
2340a01d76fSMarc-André Lureau}
2350a01d76fSMarc-André Lureau
2363b6b7550SPaolo Bonziniglob() {
2373b6b7550SPaolo Bonzini    eval test -z '"${1#'"$2"'}"'
2383b6b7550SPaolo Bonzini}
2393b6b7550SPaolo Bonzini
2404ace32e2SAntonio Ospiteif printf %s\\n "$source_path" "$PWD" | grep -q "[[:space:]:]";
2414ace32e2SAntonio Ospitethen
2424ace32e2SAntonio Ospite  error_exit "main directory cannot contain spaces nor colons"
2434ace32e2SAntonio Ospitefi
2444ace32e2SAntonio Ospite
24514211825SAntonio Ospite# default parameters
2462ff6b91eSJuan Quintelacpu=""
24743ce4dfeSbellardstatic="no"
2483812c0c4SJoelle van Dynecross_compile="no"
2497d13299dSbellardcross_prefix=""
250e49d021eSPeter Maydellhost_cc="cc"
25163678e17SSteven Noonanstack_protector=""
2521e4f6065SDaniele Buonosafe_stack=""
253afc3a8f9SAlex Bennéeuse_containers="yes"
254f2385398SAlex Bennéegdb_bin=$(command -v "gdb-multiarch" || command -v "gdb")
255ac0df51dSaliguori
25692712822SDaniel P. Berrangeif test -e "$source_path/.git"
25792712822SDaniel P. Berrangethen
2587d7dbf9dSDan Streetman    git_submodules_action="update"
25992712822SDaniel P. Berrangeelse
2607d7dbf9dSDan Streetman    git_submodules_action="ignore"
26192712822SDaniel P. Berrangefi
2622d652f24SPaolo Bonzini
2632d652f24SPaolo Bonzinigit_submodules="ui/keycodemapdb"
264cc84d63aSDaniel P. Berrangegit="git"
265ac0df51dSaliguori
266afb63ebdSStefan Weil# Don't accept a target_list environment variable.
267afb63ebdSStefan Weilunset target_list
268447e133fSAlex Bennéeunset target_list_exclude
269377529c0SPaolo Bonzini
270377529c0SPaolo Bonzini# Default value for a variable defining feature "foo".
271377529c0SPaolo Bonzini#  * foo="no"  feature will only be used if --enable-foo arg is given
272377529c0SPaolo Bonzini#  * foo=""    feature will be searched for, and if found, will be used
273377529c0SPaolo Bonzini#              unless --disable-foo is given
274377529c0SPaolo Bonzini#  * foo="yes" this value will only be set by --enable-foo flag.
275377529c0SPaolo Bonzini#              feature will searched for,
276377529c0SPaolo Bonzini#              if not found, configure exits with error
277377529c0SPaolo Bonzini#
278377529c0SPaolo Bonzini# Always add --enable-foo and --disable-foo command line args.
279377529c0SPaolo Bonzini# Distributions want to ensure that several features are compiled in, and it
280377529c0SPaolo Bonzini# is impossible without a --enable-foo that exits if a feature is not found.
281377529c0SPaolo Bonzini
282c87ea116SAlex Bennéedefault_feature=""
283c87ea116SAlex Bennée# parse CC options second
284c87ea116SAlex Bennéefor opt do
285c87ea116SAlex Bennée  optarg=$(expr "x$opt" : 'x[^=]*=\(.*\)')
286c87ea116SAlex Bennée  case "$opt" in
287c87ea116SAlex Bennée      --without-default-features)
288c87ea116SAlex Bennée          default_feature="no"
289c87ea116SAlex Bennée  ;;
290c87ea116SAlex Bennée  esac
291c87ea116SAlex Bennéedone
292c87ea116SAlex Bennée
293a2866660SPaolo BonziniEXTRA_CFLAGS=""
294a2866660SPaolo BonziniEXTRA_CXXFLAGS=""
295e910c7d9SPhilippe Mathieu-DaudéEXTRA_OBJCFLAGS=""
296a2866660SPaolo BonziniEXTRA_LDFLAGS=""
297a2866660SPaolo Bonzini
298377529c0SPaolo Bonzinidebug_tcg="no"
299247724cbSMarc-André Lureausanitizers="no"
3000aebab04SLingfeng Yangtsan="no"
3011f3f2bfeSMichael Tokarevfortify_source="yes"
302c7328271SMiroslav RezaninaEXESUF=""
30317969268SFam Zhengmodules="no"
304377529c0SPaolo Bonziniprefix="/usr/local"
30510ff82d1SMarc-André Lureauqemu_suffix="qemu"
306377529c0SPaolo Bonzinisoftmmu="yes"
307b915a2f1SPaolo Bonzinilinux_user=""
308b915a2f1SPaolo Bonzinibsd_user=""
30940d6444eSAvi Kivitypie=""
310519175a2SAlex Barcelocoroutine=""
311ba4dd2aaSAlex Bennéeplugins="$default_feature"
312a5665051SPaolo Bonzinimeson=""
31348328880SPaolo Bonzinininja=""
314c09c1ce7SPaolo Bonzinibindir="bin"
315a5665051SPaolo Bonziniskip_meson=no
31655116968SJagannathan Ramanvfio_user_server="disabled"
317377529c0SPaolo Bonzini
3183b4da132SPaolo Bonzini# The following Meson options are handled manually (still they
3193b4da132SPaolo Bonzini# are included in the automatically generated help message)
3203b4da132SPaolo Bonzini
3213b4da132SPaolo Bonzini# 1. Track which submodules are needed
3220577e84dSThomas Huthif test "$default_feature" = no ; then
3230577e84dSThomas Huth  slirp="disabled"
3240577e84dSThomas Huthelse
3253b4da132SPaolo Bonzini  slirp="auto"
3260577e84dSThomas Huthfi
3270577e84dSThomas Huthfdt="auto"
3283b4da132SPaolo Bonzini
329c54b59eeSPaolo Bonzini# 2. Automatically enable/disable other options
3307630156dSPhilippe Mathieu-Daudétcg="auto"
3313b4da132SPaolo Bonzinicfi="false"
3323b4da132SPaolo Bonzini
333c87ea116SAlex Bennée# parse CC options second
334ac0df51dSaliguorifor opt do
33589138857SStefan Weil  optarg=$(expr "x$opt" : 'x[^=]*=\(.*\)')
336ac0df51dSaliguori  case "$opt" in
337ac0df51dSaliguori  --cross-prefix=*) cross_prefix="$optarg"
3383812c0c4SJoelle van Dyne                    cross_compile="yes"
339ac0df51dSaliguori  ;;
3403d8df640SPaolo Bonzini  --cc=*) CC="$optarg"
341ac0df51dSaliguori  ;;
34283f73fceSTomoki Sekiyama  --cxx=*) CXX="$optarg"
34383f73fceSTomoki Sekiyama  ;;
3442ff6b91eSJuan Quintela  --cpu=*) cpu="$optarg"
3452ff6b91eSJuan Quintela  ;;
346a2866660SPaolo Bonzini  --extra-cflags=*)
347a2866660SPaolo Bonzini    EXTRA_CFLAGS="$EXTRA_CFLAGS $optarg"
348a2866660SPaolo Bonzini    EXTRA_CXXFLAGS="$EXTRA_CXXFLAGS $optarg"
349e910c7d9SPhilippe Mathieu-Daudé    EXTRA_OBJCFLAGS="$EXTRA_OBJCFLAGS $optarg"
350e2a2ed06SJuan Quintela    ;;
351a2866660SPaolo Bonzini  --extra-cxxflags=*) EXTRA_CXXFLAGS="$EXTRA_CXXFLAGS $optarg"
35211cde1c8SBruno Dominguez  ;;
353e910c7d9SPhilippe Mathieu-Daudé  --extra-objcflags=*) EXTRA_OBJCFLAGS="$EXTRA_OBJCFLAGS $optarg"
354e910c7d9SPhilippe Mathieu-Daudé  ;;
355a2866660SPaolo Bonzini  --extra-ldflags=*) EXTRA_LDFLAGS="$EXTRA_LDFLAGS $optarg"
356e2a2ed06SJuan Quintela  ;;
357d75402b5SAlex Bennée  --cross-cc-*[!a-zA-Z0-9_-]*=*) error_exit "Passed bad --cross-cc-FOO option"
358d75402b5SAlex Bennée  ;;
359479ca4ccSMatheus Ferst  --cross-cc-cflags-*) cc_arch=${opt#--cross-cc-cflags-}; cc_arch=${cc_arch%%=*}
360d422b2bcSAlex Bennée                      eval "cross_cc_cflags_${cc_arch}=\$optarg"
361d422b2bcSAlex Bennée  ;;
362d75402b5SAlex Bennée  --cross-cc-*) cc_arch=${opt#--cross-cc-}; cc_arch=${cc_arch%%=*}
363d75402b5SAlex Bennée                eval "cross_cc_${cc_arch}=\$optarg"
364d75402b5SAlex Bennée  ;;
3655adb43beSPaolo Bonzini  --cross-prefix-*[!a-zA-Z0-9_-]*=*) error_exit "Passed bad --cross-prefix-FOO option"
3665adb43beSPaolo Bonzini  ;;
3675adb43beSPaolo Bonzini  --cross-prefix-*) cc_arch=${opt#--cross-prefix-}; cc_arch=${cc_arch%%=*}
3685adb43beSPaolo Bonzini                    eval "cross_prefix_${cc_arch}=\$optarg"
3695adb43beSPaolo Bonzini  ;;
370ac0df51dSaliguori  esac
371ac0df51dSaliguoridone
372ac0df51dSaliguori# OS specific
373ac0df51dSaliguori# Using uname is really, really broken.  Once we have the right set of checks
37493148aa5SStefan Weil# we can eliminate its usage altogether.
375ac0df51dSaliguori
376e49d021eSPeter Maydell# Preferred compiler:
377e49d021eSPeter Maydell#  ${CC} (if set)
378e49d021eSPeter Maydell#  ${cross_prefix}gcc (if cross-prefix specified)
379e49d021eSPeter Maydell#  system compiler
380e49d021eSPeter Maydellif test -z "${CC}${cross_prefix}"; then
381e49d021eSPeter Maydell  cc="$host_cc"
382e49d021eSPeter Maydellelse
383b3198cc2SStuart Yoder  cc="${CC-${cross_prefix}gcc}"
384e49d021eSPeter Maydellfi
385e49d021eSPeter Maydell
38683f73fceSTomoki Sekiyamaif test -z "${CXX}${cross_prefix}"; then
38783f73fceSTomoki Sekiyama  cxx="c++"
38883f73fceSTomoki Sekiyamaelse
38983f73fceSTomoki Sekiyama  cxx="${CXX-${cross_prefix}g++}"
39083f73fceSTomoki Sekiyamafi
39183f73fceSTomoki Sekiyama
392b3198cc2SStuart Yoderar="${AR-${cross_prefix}ar}"
393cdbd727cSRichard Hendersonas="${AS-${cross_prefix}as}"
3945f6f0e27SRichard Hendersonccas="${CCAS-$cc}"
395b3198cc2SStuart Yoderobjcopy="${OBJCOPY-${cross_prefix}objcopy}"
396b3198cc2SStuart Yoderld="${LD-${cross_prefix}ld}"
3979f81aeb5SAlistair Francisranlib="${RANLIB-${cross_prefix}ranlib}"
3984852ee95SStefan Weilnm="${NM-${cross_prefix}nm}"
39935acbb30SPaolo Bonzinismbd="$SMBD"
400b3198cc2SStuart Yoderstrip="${STRIP-${cross_prefix}strip}"
401158bb224SKonstantin Kostiukwidl="${WIDL-${cross_prefix}widl}"
402b3198cc2SStuart Yoderwindres="${WINDRES-${cross_prefix}windres}"
40317884d7bSSergei Trofimovichpkg_config_exe="${PKG_CONFIG-${cross_prefix}pkg-config}"
40417884d7bSSergei Trofimovichquery_pkg_config() {
40517884d7bSSergei Trofimovich    "${pkg_config_exe}" ${QEMU_PKG_CONFIG_FLAGS} "$@"
40617884d7bSSergei Trofimovich}
40717884d7bSSergei Trofimovichpkg_config=query_pkg_config
40847c03744SDave Airliesdl2_config="${SDL2_CONFIG-${cross_prefix}sdl2-config}"
409ac0df51dSaliguori
410be17dc90SMichael S. Tsirkin# default flags for all hosts
4112d31515bSPeter Maydell# We use -fwrapv to tell the compiler that we require a C dialect where
4122d31515bSPeter Maydell# left shift of signed integers is well defined and has the expected
4132d31515bSPeter Maydell# 2s-complement style results. (Both clang and gcc agree that it
4142d31515bSPeter Maydell# provides these semantics.)
415de38c0ccSPaolo BonziniQEMU_CFLAGS="-fno-strict-aliasing -fno-common -fwrapv"
416086d5f75SPaolo BonziniQEMU_CFLAGS="-Wundef -Wwrite-strings -Wmissing-prototypes $QEMU_CFLAGS"
417c95e3080SKevin WolfQEMU_CFLAGS="-Wstrict-prototypes -Wredundant-decls $QEMU_CFLAGS"
418be17dc90SMichael S. TsirkinQEMU_CFLAGS="-D_GNU_SOURCE -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE $QEMU_CFLAGS"
4195770e8afSPaolo Bonzini
420de38c0ccSPaolo BonziniQEMU_LDFLAGS=
421de38c0ccSPaolo Bonzini
4225770e8afSPaolo Bonzini# Flags that are needed during configure but later taken care of by Meson
4238a9d3d56SRichard HendersonCONFIGURE_CFLAGS="-std=gnu11 -Wall"
4245770e8afSPaolo BonziniCONFIGURE_LDFLAGS=
425086d5f75SPaolo Bonzini
426be17dc90SMichael S. Tsirkin
427ac0df51dSaliguoricheck_define() {
428ac0df51dSaliguoricat > $TMPC <<EOF
429ac0df51dSaliguori#if !defined($1)
430fd786e1aSPeter Maydell#error $1 not defined
431ac0df51dSaliguori#endif
432ac0df51dSaliguoriint main(void) { return 0; }
433ac0df51dSaliguoriEOF
43452166aa0SJuan Quintela  compile_object
435ac0df51dSaliguori}
436ac0df51dSaliguori
437307119e7SGerd Hoffmanncheck_include() {
438307119e7SGerd Hoffmanncat > $TMPC <<EOF
439307119e7SGerd Hoffmann#include <$1>
440307119e7SGerd Hoffmannint main(void) { return 0; }
441307119e7SGerd HoffmannEOF
442307119e7SGerd Hoffmann  compile_object
443307119e7SGerd Hoffmann}
444307119e7SGerd Hoffmann
44593b25869SJohn Snowwrite_c_skeleton() {
44693b25869SJohn Snow    cat > $TMPC <<EOF
44793b25869SJohn Snowint main(void) { return 0; }
44893b25869SJohn SnowEOF
44993b25869SJohn Snow}
45093b25869SJohn Snow
451bbea4050SPeter Maydellif check_define __linux__ ; then
452ba7c60c2SPaolo Bonzini  targetos=linux
453bbea4050SPeter Maydellelif check_define _WIN32 ; then
454ba7c60c2SPaolo Bonzini  targetos=windows
455bbea4050SPeter Maydellelif check_define __OpenBSD__ ; then
456ba7c60c2SPaolo Bonzini  targetos=openbsd
457bbea4050SPeter Maydellelif check_define __sun__ ; then
458ba7c60c2SPaolo Bonzini  targetos=sunos
459bbea4050SPeter Maydellelif check_define __HAIKU__ ; then
460ba7c60c2SPaolo Bonzini  targetos=haiku
461951fedfcSPeter Maydellelif check_define __FreeBSD__ ; then
462ba7c60c2SPaolo Bonzini  targetos=freebsd
463951fedfcSPeter Maydellelif check_define __FreeBSD_kernel__ && check_define __GLIBC__; then
464ba7c60c2SPaolo Bonzini  targetos=gnu/kfreebsd
465951fedfcSPeter Maydellelif check_define __DragonFly__ ; then
466ba7c60c2SPaolo Bonzini  targetos=dragonfly
467951fedfcSPeter Maydellelif check_define __NetBSD__; then
468ba7c60c2SPaolo Bonzini  targetos=netbsd
469951fedfcSPeter Maydellelif check_define __APPLE__; then
470ba7c60c2SPaolo Bonzini  targetos=darwin
471bbea4050SPeter Maydellelse
472951fedfcSPeter Maydell  # This is a fatal error, but don't report it yet, because we
473951fedfcSPeter Maydell  # might be going to just print the --help text, or it might
474951fedfcSPeter Maydell  # be the result of a missing compiler.
475ba7c60c2SPaolo Bonzini  targetos=bogus
476bbea4050SPeter Maydellfi
477bbea4050SPeter Maydell
47865eff01bSPaolo Bonzini# OS specific
47965eff01bSPaolo Bonzini
4803b0d8643SPaolo Bonzinimingw32="no"
4813b0d8643SPaolo Bonzinibsd="no"
4823b0d8643SPaolo Bonzinilinux="no"
4833b0d8643SPaolo Bonzinisolaris="no"
48465eff01bSPaolo Bonzinicase $targetos in
48565eff01bSPaolo Bonziniwindows)
48665eff01bSPaolo Bonzini  mingw32="yes"
48765eff01bSPaolo Bonzini  plugins="no"
48865eff01bSPaolo Bonzini  pie="no"
48965eff01bSPaolo Bonzini;;
49065eff01bSPaolo Bonzinignu/kfreebsd)
49165eff01bSPaolo Bonzini  bsd="yes"
49265eff01bSPaolo Bonzini;;
49365eff01bSPaolo Bonzinifreebsd)
49465eff01bSPaolo Bonzini  bsd="yes"
49565eff01bSPaolo Bonzini  make="${MAKE-gmake}"
49665eff01bSPaolo Bonzini  # needed for kinfo_getvmmap(3) in libutil.h
49765eff01bSPaolo Bonzini;;
49865eff01bSPaolo Bonzinidragonfly)
49965eff01bSPaolo Bonzini  bsd="yes"
50065eff01bSPaolo Bonzini  make="${MAKE-gmake}"
50165eff01bSPaolo Bonzini;;
50265eff01bSPaolo Bonzininetbsd)
50365eff01bSPaolo Bonzini  bsd="yes"
50465eff01bSPaolo Bonzini  make="${MAKE-gmake}"
50565eff01bSPaolo Bonzini;;
50665eff01bSPaolo Bonziniopenbsd)
50765eff01bSPaolo Bonzini  bsd="yes"
50865eff01bSPaolo Bonzini  make="${MAKE-gmake}"
50965eff01bSPaolo Bonzini;;
51065eff01bSPaolo Bonzinidarwin)
51165eff01bSPaolo Bonzini  bsd="yes"
51265eff01bSPaolo Bonzini  darwin="yes"
51365eff01bSPaolo Bonzini  # Disable attempts to use ObjectiveC features in os/object.h since they
51465eff01bSPaolo Bonzini  # won't work when we're compiling with gcc as a C compiler.
51565eff01bSPaolo Bonzini  QEMU_CFLAGS="-DOS_OBJECT_USE_OBJC=0 $QEMU_CFLAGS"
51665eff01bSPaolo Bonzini;;
51765eff01bSPaolo Bonzinisunos)
51865eff01bSPaolo Bonzini  solaris="yes"
51965eff01bSPaolo Bonzini  make="${MAKE-gmake}"
52065eff01bSPaolo Bonzini# needed for CMSG_ macros in sys/socket.h
52165eff01bSPaolo Bonzini  QEMU_CFLAGS="-D_XOPEN_SOURCE=600 $QEMU_CFLAGS"
52265eff01bSPaolo Bonzini# needed for TIOCWIN* defines in termios.h
52365eff01bSPaolo Bonzini  QEMU_CFLAGS="-D__EXTENSIONS__ $QEMU_CFLAGS"
52465eff01bSPaolo Bonzini  # $(uname -m) returns i86pc even on an x86_64 box, so default based on isainfo
52565eff01bSPaolo Bonzini  # Note that this check is broken for cross-compilation: if you're
526bbea4050SPeter Maydell  # cross-compiling to one of these OSes then you'll need to specify
527bbea4050SPeter Maydell  # the correct CPU with the --cpu option.
528bbea4050SPeter Maydell  if test -z "$cpu" && test "$(isainfo -k)" = "amd64"; then
529bbea4050SPeter Maydell    cpu="x86_64"
530bbea4050SPeter Maydell  fi
53165eff01bSPaolo Bonzini;;
53265eff01bSPaolo Bonzinihaiku)
53365eff01bSPaolo Bonzini  pie="no"
53465eff01bSPaolo Bonzini  QEMU_CFLAGS="-DB_USE_POSITIVE_POSIX_ERRORS -D_BSD_SOURCE -fPIC $QEMU_CFLAGS"
53565eff01bSPaolo Bonzini;;
53665eff01bSPaolo Bonzinilinux)
53765eff01bSPaolo Bonzini  linux="yes"
53865eff01bSPaolo Bonzini;;
539bbea4050SPeter Maydellesac
540bbea4050SPeter Maydell
5412ff6b91eSJuan Quintelaif test ! -z "$cpu" ; then
5422ff6b91eSJuan Quintela  # command line argument
5432ff6b91eSJuan Quintela  :
5442ff6b91eSJuan Quintelaelif check_define __i386__ ; then
545ac0df51dSaliguori  cpu="i386"
546ac0df51dSaliguorielif check_define __x86_64__ ; then
547c72b26ecSRichard Henderson  if check_define __ILP32__ ; then
548c72b26ecSRichard Henderson    cpu="x32"
549c72b26ecSRichard Henderson  else
550ac0df51dSaliguori    cpu="x86_64"
551c72b26ecSRichard Henderson  fi
5523aa9bd6cSblueswir1elif check_define __sparc__ ; then
5533aa9bd6cSblueswir1  if check_define __arch64__ ; then
5543aa9bd6cSblueswir1    cpu="sparc64"
5553aa9bd6cSblueswir1  else
5563aa9bd6cSblueswir1    cpu="sparc"
5573aa9bd6cSblueswir1  fi
558fdf7ed96Smalcelif check_define _ARCH_PPC ; then
559fdf7ed96Smalc  if check_define _ARCH_PPC64 ; then
560f8378accSRichard Henderson    if check_define _LITTLE_ENDIAN ; then
561f8378accSRichard Henderson      cpu="ppc64le"
562f8378accSRichard Henderson    else
563fdf7ed96Smalc      cpu="ppc64"
564f8378accSRichard Henderson    fi
565ac0df51dSaliguori  else
566fdf7ed96Smalc    cpu="ppc"
567fdf7ed96Smalc  fi
568afa05235SAurelien Jarnoelif check_define __mips__ ; then
569afa05235SAurelien Jarno  cpu="mips"
570d66ed0eaSAurelien Jarnoelif check_define __s390__ ; then
571d66ed0eaSAurelien Jarno  if check_define __s390x__ ; then
572d66ed0eaSAurelien Jarno    cpu="s390x"
573d66ed0eaSAurelien Jarno  else
574d66ed0eaSAurelien Jarno    cpu="s390"
575d66ed0eaSAurelien Jarno  fi
576c4f80543SAlistair Franciselif check_define __riscv ; then
577ba0e7333SRichard Henderson  cpu="riscv"
57821d89f84SPeter Maydellelif check_define __arm__ ; then
57921d89f84SPeter Maydell  cpu="arm"
5801f080313SClaudio Fontanaelif check_define __aarch64__ ; then
5811f080313SClaudio Fontana  cpu="aarch64"
582dfcf900bSWANG Xueruielif check_define __loongarch64 ; then
583dfcf900bSWANG Xuerui  cpu="loongarch64"
584fdf7ed96Smalcelse
58589138857SStefan Weil  cpu=$(uname -m)
586ac0df51dSaliguorifi
587ac0df51dSaliguori
588823eb013SPaolo Bonzini# Normalise host CPU name, set multilib cflags
589359bc95dSPeter Maydell# Note that this case should only have supported host CPUs, not guests.
5907d13299dSbellardcase "$cpu" in
591e4da0e39SPaolo Bonzini  armv*b|armv*l|arm)
592e4da0e39SPaolo Bonzini    cpu="arm" ;;
593e4da0e39SPaolo Bonzini
5947d13299dSbellard  i386|i486|i586|i686|i86pc|BePC)
59597a847bcSbellard    cpu="i386"
596e4da0e39SPaolo Bonzini    CPU_CFLAGS="-m32" ;;
597e4da0e39SPaolo Bonzini  x32)
5984da270beSPaolo Bonzini    cpu="x86_64"
599e4da0e39SPaolo Bonzini    CPU_CFLAGS="-mx32" ;;
600aaa5fa14Saurel32  x86_64|amd64)
601aaa5fa14Saurel32    cpu="x86_64"
602e4da0e39SPaolo Bonzini    # ??? Only extremely old AMD cpus do not have cmpxchg16b.
603e4da0e39SPaolo Bonzini    # If we truly care, we should simply detect this case at
604e4da0e39SPaolo Bonzini    # runtime and generate the fallback to serial emulation.
605e4da0e39SPaolo Bonzini    CPU_CFLAGS="-m64 -mcx16" ;;
606e4da0e39SPaolo Bonzini
607afa05235SAurelien Jarno  mips*)
608e4da0e39SPaolo Bonzini    cpu="mips" ;;
609e4da0e39SPaolo Bonzini
610e4da0e39SPaolo Bonzini  ppc)
611e4da0e39SPaolo Bonzini    CPU_CFLAGS="-m32" ;;
612e4da0e39SPaolo Bonzini  ppc64)
613ced5cfffSMiroslav Rezanina    CPU_CFLAGS="-m64 -mbig-endian" ;;
614e4da0e39SPaolo Bonzini  ppc64le)
615d8ff892dSPaolo Bonzini    cpu="ppc64"
616ced5cfffSMiroslav Rezanina    CPU_CFLAGS="-m64 -mlittle-endian" ;;
617e4da0e39SPaolo Bonzini
618e4da0e39SPaolo Bonzini  s390)
619823eb013SPaolo Bonzini    CPU_CFLAGS="-m31" ;;
620e4da0e39SPaolo Bonzini  s390x)
621e4da0e39SPaolo Bonzini    CPU_CFLAGS="-m64" ;;
622e4da0e39SPaolo Bonzini
6233142255cSblueswir1  sparc|sun4[cdmuv])
624ae228531Sbellard    cpu="sparc"
625e4da0e39SPaolo Bonzini    CPU_CFLAGS="-m32 -mv8plus -mcpu=ultrasparc" ;;
626e4da0e39SPaolo Bonzini  sparc64)
627e4da0e39SPaolo Bonzini    CPU_CFLAGS="-m64 -mcpu=ultrasparc" ;;
6287d13299dSbellardesac
629e2d52ad3SJuan Quintela
6300db4a067SPaolo Bonzini: ${make=${MAKE-make}}
631b6daf4d3SPaolo Bonzini
632faf44142SDaniel P. Berrangé# We prefer python 3.x. A bare 'python' is traditionally
633faf44142SDaniel P. Berrangé# python 2.x, but some distros have it as python 3.x, so
634ddf90699SEduardo Habkost# we check that too
635faf44142SDaniel P. Berrangépython=
6360a01d76fSMarc-André Lureauexplicit_python=no
637ddf90699SEduardo Habkostfor binary in "${PYTHON-python3}" python
638faf44142SDaniel P. Berrangédo
639faf44142SDaniel P. Berrangé    if has "$binary"
640faf44142SDaniel P. Berrangé    then
64195c5f2deSPaolo Bonzini        python=$(command -v "$binary")
642faf44142SDaniel P. Berrangé        break
643faf44142SDaniel P. Berrangé    fi
644faf44142SDaniel P. Berrangédone
645903458c8SMarkus Armbruster
646903458c8SMarkus Armbruster
64739d87c8cSAlex Bennée# Check for ancillary tools used in testing
64839d87c8cSAlex Bennéegenisoimage=
6493df437c7SAlex Bennéefor binary in genisoimage mkisofs
65039d87c8cSAlex Bennéedo
65139d87c8cSAlex Bennée    if has $binary
65239d87c8cSAlex Bennée    then
65339d87c8cSAlex Bennée        genisoimage=$(command -v "$binary")
65439d87c8cSAlex Bennée        break
65539d87c8cSAlex Bennée    fi
65639d87c8cSAlex Bennéedone
65739d87c8cSAlex Bennée
6583c4a4d0dSPeter Maydell# Default objcc to clang if available, otherwise use CC
6593c4a4d0dSPeter Maydellif has clang; then
6603c4a4d0dSPeter Maydell  objcc=clang
6613c4a4d0dSPeter Maydellelse
6623c4a4d0dSPeter Maydell  objcc="$cc"
6633c4a4d0dSPeter Maydellfi
6643c4a4d0dSPeter Maydell
6653457a3f8SJuan Quintelaif test "$mingw32" = "yes" ; then
6663457a3f8SJuan Quintela  EXESUF=".exe"
66778e9d4adSStefan Weil  # MinGW needs -mthreads for TLS and macro _MT.
6685770e8afSPaolo Bonzini  CONFIGURE_CFLAGS="-mthreads $CONFIGURE_CFLAGS"
66993b25869SJohn Snow  write_c_skeleton;
670d17f305aSPaolo Bonzini  prefix="/qemu"
671c09c1ce7SPaolo Bonzini  bindir=""
67277433a5fSMarc-André Lureau  qemu_suffix=""
6733457a3f8SJuan Quintelafi
6743457a3f8SJuan Quintela
675487fefdbSAnthony Liguoriwerror=""
67685aa5189Sbellard
6778154f5e6SAkihiko Odakimeson_option_build_array() {
6788154f5e6SAkihiko Odaki  printf '['
679c5cfdabaSPeter Maydell  (if test "$targetos" = windows; then
6808154f5e6SAkihiko Odaki    IFS=\;
6818154f5e6SAkihiko Odaki  else
6828154f5e6SAkihiko Odaki    IFS=:
6838154f5e6SAkihiko Odaki  fi
6848154f5e6SAkihiko Odaki  for e in $1; do
68565842b03SPeter Maydell    printf '"""'
68665842b03SPeter Maydell    # backslash escape any '\' and '"' characters
68765842b03SPeter Maydell    printf "%s" "$e" | sed -e 's/\([\"]\)/\\\1/g'
68865842b03SPeter Maydell    printf '""",'
6898154f5e6SAkihiko Odaki  done)
6908154f5e6SAkihiko Odaki  printf ']\n'
6918154f5e6SAkihiko Odaki}
6928154f5e6SAkihiko Odaki
69364708615SPeter Maydell. "$source_path/scripts/meson-buildoptions.sh"
69461d63097SPaolo Bonzini
69561d63097SPaolo Bonzinimeson_options=
696c54b59eeSPaolo Bonzinimeson_option_add() {
697c54b59eeSPaolo Bonzini  meson_options="$meson_options $(quote_sh "$1")"
698c54b59eeSPaolo Bonzini}
69961d63097SPaolo Bonzinimeson_option_parse() {
70061d63097SPaolo Bonzini  meson_options="$meson_options $(_meson_option_parse "$@")"
70161d63097SPaolo Bonzini  if test $? -eq 1; then
70261d63097SPaolo Bonzini    echo "ERROR: unknown option $1"
70361d63097SPaolo Bonzini    echo "Try '$0 --help' for more information"
70461d63097SPaolo Bonzini    exit 1
70561d63097SPaolo Bonzini  fi
70661d63097SPaolo Bonzini}
70761d63097SPaolo Bonzini
7087d13299dSbellardfor opt do
70989138857SStefan Weil  optarg=$(expr "x$opt" : 'x[^=]*=\(.*\)')
7107d13299dSbellard  case "$opt" in
7112efc3265Sbellard  --help|-h) show_help=yes
7122efc3265Sbellard  ;;
71364708615SPeter Maydell  --version|-V) exec cat "$source_path/VERSION"
71499123e13SMike Frysinger  ;;
715b1a550a0Spbrook  --prefix=*) prefix="$optarg"
7167d13299dSbellard  ;;
717ac0df51dSaliguori  --cross-prefix=*)
7187d13299dSbellard  ;;
719ac0df51dSaliguori  --cc=*)
7207d13299dSbellard  ;;
721b1a550a0Spbrook  --host-cc=*) host_cc="$optarg"
72283469015Sbellard  ;;
72383f73fceSTomoki Sekiyama  --cxx=*)
72483f73fceSTomoki Sekiyama  ;;
7253c4a4d0dSPeter Maydell  --objcc=*) objcc="$optarg"
7263c4a4d0dSPeter Maydell  ;;
727b1a550a0Spbrook  --make=*) make="$optarg"
7287d13299dSbellard  ;;
729b6daf4d3SPaolo Bonzini  --install=*)
7306a882643Spbrook  ;;
7310a01d76fSMarc-André Lureau  --python=*) python="$optarg" ; explicit_python=yes
732c886edfbSBlue Swirl  ;;
733a5665051SPaolo Bonzini  --skip-meson) skip_meson=yes
734a5665051SPaolo Bonzini  ;;
735a5665051SPaolo Bonzini  --meson=*) meson="$optarg"
736a5665051SPaolo Bonzini  ;;
73748328880SPaolo Bonzini  --ninja=*) ninja="$optarg"
73848328880SPaolo Bonzini  ;;
739e2d8830eSBrad  --smbd=*) smbd="$optarg"
740e2d8830eSBrad  ;;
741e2a2ed06SJuan Quintela  --extra-cflags=*)
7427d13299dSbellard  ;;
74311cde1c8SBruno Dominguez  --extra-cxxflags=*)
74411cde1c8SBruno Dominguez  ;;
745e910c7d9SPhilippe Mathieu-Daudé  --extra-objcflags=*)
746e910c7d9SPhilippe Mathieu-Daudé  ;;
747e2a2ed06SJuan Quintela  --extra-ldflags=*)
7487d13299dSbellard  ;;
749d75402b5SAlex Bennée  --cross-cc-*)
750d75402b5SAlex Bennée  ;;
7515adb43beSPaolo Bonzini  --cross-prefix-*)
7525adb43beSPaolo Bonzini  ;;
753c54b59eeSPaolo Bonzini  --enable-debug-info) meson_option_add -Ddebug=true
75428609749SPaolo Bonzini  ;;
755c54b59eeSPaolo Bonzini  --disable-debug-info) meson_option_add -Ddebug=false
75628609749SPaolo Bonzini  ;;
75717969268SFam Zheng  --enable-modules)
75817969268SFam Zheng      modules="yes"
75917969268SFam Zheng  ;;
7603aa88b31SStefan Hajnoczi  --disable-modules)
7613aa88b31SStefan Hajnoczi      modules="no"
7623aa88b31SStefan Hajnoczi  ;;
7632ff6b91eSJuan Quintela  --cpu=*)
7647d13299dSbellard  ;;
765b1a550a0Spbrook  --target-list=*) target_list="$optarg"
766447e133fSAlex Bennée                   if test "$target_list_exclude"; then
767447e133fSAlex Bennée                       error_exit "Can't mix --target-list with --target-list-exclude"
768447e133fSAlex Bennée                   fi
769447e133fSAlex Bennée  ;;
770447e133fSAlex Bennée  --target-list-exclude=*) target_list_exclude="$optarg"
771447e133fSAlex Bennée                   if test "$target_list"; then
772447e133fSAlex Bennée                       error_exit "Can't mix --target-list-exclude with --target-list"
773447e133fSAlex Bennée                   fi
774de83cd02Sbellard  ;;
775c54b59eeSPaolo Bonzini  --with-default-devices) meson_option_add -Ddefault_devices=true
776f3494749SPaolo Bonzini  ;;
777c54b59eeSPaolo Bonzini  --without-default-devices) meson_option_add -Ddefault_devices=false
778f3494749SPaolo Bonzini  ;;
779d1d5e9eeSAlex Bennée  --with-devices-*[!a-zA-Z0-9_-]*=*) error_exit "Passed bad --with-devices-FOO option"
780d1d5e9eeSAlex Bennée  ;;
781d1d5e9eeSAlex Bennée  --with-devices-*) device_arch=${opt#--with-devices-};
782d1d5e9eeSAlex Bennée                    device_arch=${device_arch%%=*}
783d1d5e9eeSAlex Bennée                    cf=$source_path/configs/devices/$device_arch-softmmu/$optarg.mak
784d1d5e9eeSAlex Bennée                    if test -f "$cf"; then
785d1d5e9eeSAlex Bennée                        device_archs="$device_archs $device_arch"
786d1d5e9eeSAlex Bennée                        eval "devices_${device_arch}=\$optarg"
787d1d5e9eeSAlex Bennée                    else
788d1d5e9eeSAlex Bennée                        error_exit "File $cf does not exist"
789d1d5e9eeSAlex Bennée                    fi
790d1d5e9eeSAlex Bennée  ;;
791c87ea116SAlex Bennée  --without-default-features) # processed above
792c87ea116SAlex Bennée  ;;
79379427693SLoïc Minier  --static)
79479427693SLoïc Minier    static="yes"
79517884d7bSSergei Trofimovich    QEMU_PKG_CONFIG_FLAGS="--static $QEMU_PKG_CONFIG_FLAGS"
79643ce4dfeSbellard  ;;
7970b24e75fSPaolo Bonzini  --bindir=*) bindir="$optarg"
7980b24e75fSPaolo Bonzini  ;;
79977433a5fSMarc-André Lureau  --with-suffix=*) qemu_suffix="$optarg"
800023d3d67SEduardo Habkost  ;;
801181ce1d0SOlaf Hering  --host=*|--build=*|\
802181ce1d0SOlaf Hering  --disable-dependency-tracking|\
803785c23aeSLuiz Capitulino  --sbindir=*|--sharedstatedir=*|\
804fe0038beSPaolo Bonzini  --oldincludedir=*|--datarootdir=*|--infodir=*|\
805023ddd74SMax Filippov  --htmldir=*|--dvidir=*|--pdfdir=*|--psdir=*)
806023ddd74SMax Filippov    # These switches are silently ignored, for compatibility with
807023ddd74SMax Filippov    # autoconf-generated configure scripts. This allows QEMU's
808023ddd74SMax Filippov    # configure to be used by RPM and similar macros that set
809023ddd74SMax Filippov    # lots of directory switches by default.
810023ddd74SMax Filippov  ;;
811f8393946Saurel32  --enable-debug-tcg) debug_tcg="yes"
812f8393946Saurel32  ;;
813f8393946Saurel32  --disable-debug-tcg) debug_tcg="no"
814f8393946Saurel32  ;;
815f3d08ee6SPaul Brook  --enable-debug)
816f3d08ee6SPaul Brook      # Enable debugging options that aren't excessively noisy
817f3d08ee6SPaul Brook      debug_tcg="yes"
818c55cf6abSPaolo Bonzini      meson_option_parse --enable-debug-mutex ""
819c54b59eeSPaolo Bonzini      meson_option_add -Doptimization=0
820b553a042SJohn Snow      fortify_source="no"
821f3d08ee6SPaul Brook  ;;
822247724cbSMarc-André Lureau  --enable-sanitizers) sanitizers="yes"
823247724cbSMarc-André Lureau  ;;
824247724cbSMarc-André Lureau  --disable-sanitizers) sanitizers="no"
825247724cbSMarc-André Lureau  ;;
8260aebab04SLingfeng Yang  --enable-tsan) tsan="yes"
8270aebab04SLingfeng Yang  ;;
8280aebab04SLingfeng Yang  --disable-tsan) tsan="no"
8290aebab04SLingfeng Yang  ;;
8304d34a86bSPaolo Bonzini  --disable-slirp) slirp="disabled"
831c20709aaSbellard  ;;
832fd6fc214SPaolo Bonzini  --enable-slirp) slirp="enabled"
833fd6fc214SPaolo Bonzini  ;;
8344d34a86bSPaolo Bonzini  --enable-slirp=git) slirp="internal"
8357c57bdd8SMarc-André Lureau  ;;
83603a3c0b3SPaolo Bonzini  --enable-slirp=*) slirp="$optarg"
837675b9b53SMarc-André Lureau  ;;
8381badb709SPaolo Bonzini  --disable-tcg) tcg="disabled"
839d1a14257SAlex Bennée                 plugins="no"
840b3f6ea7eSPaolo Bonzini  ;;
8411badb709SPaolo Bonzini  --enable-tcg) tcg="enabled"
842b3f6ea7eSPaolo Bonzini  ;;
843cad25d69Spbrook  --disable-system) softmmu="no"
8440a8e90f4Spbrook  ;;
845cad25d69Spbrook  --enable-system) softmmu="yes"
8460a8e90f4Spbrook  ;;
8470953a80fSZachary Amsden  --disable-user)
8480953a80fSZachary Amsden      linux_user="no" ;
8490953a80fSZachary Amsden      bsd_user="no" ;
8500953a80fSZachary Amsden  ;;
8510953a80fSZachary Amsden  --enable-user) ;;
852831b7825Sths  --disable-linux-user) linux_user="no"
8530a8e90f4Spbrook  ;;
854831b7825Sths  --enable-linux-user) linux_user="yes"
855831b7825Sths  ;;
85684778508Sblueswir1  --disable-bsd-user) bsd_user="no"
85784778508Sblueswir1  ;;
85884778508Sblueswir1  --enable-bsd-user) bsd_user="yes"
85984778508Sblueswir1  ;;
86040d6444eSAvi Kivity  --enable-pie) pie="yes"
86134005a00SKirill A. Shutemov  ;;
86240d6444eSAvi Kivity  --disable-pie) pie="no"
86334005a00SKirill A. Shutemov  ;;
86485aa5189Sbellard  --enable-werror) werror="yes"
86585aa5189Sbellard  ;;
86685aa5189Sbellard  --disable-werror) werror="no"
86785aa5189Sbellard  ;;
86863678e17SSteven Noonan  --enable-stack-protector) stack_protector="yes"
86963678e17SSteven Noonan  ;;
87063678e17SSteven Noonan  --disable-stack-protector) stack_protector="no"
87163678e17SSteven Noonan  ;;
8721e4f6065SDaniele Buono  --enable-safe-stack) safe_stack="yes"
8731e4f6065SDaniele Buono  ;;
8741e4f6065SDaniele Buono  --disable-safe-stack) safe_stack="no"
8751e4f6065SDaniele Buono  ;;
8769e62ba48SDaniele Buono  --enable-cfi)
8779e62ba48SDaniele Buono      cfi="true";
878c54b59eeSPaolo Bonzini      meson_option_add -Db_lto=true
8799e62ba48SDaniele Buono  ;;
8809e62ba48SDaniele Buono  --disable-cfi) cfi="false"
8819e62ba48SDaniele Buono  ;;
882fbb4121dSPaolo Bonzini  --disable-fdt) fdt="disabled"
8832df87df7SJuan Quintela  ;;
884fbb4121dSPaolo Bonzini  --enable-fdt) fdt="enabled"
885fbb4121dSPaolo Bonzini  ;;
886fbb4121dSPaolo Bonzini  --enable-fdt=git) fdt="internal"
887fbb4121dSPaolo Bonzini  ;;
88803a3c0b3SPaolo Bonzini  --enable-fdt=*) fdt="$optarg"
8892df87df7SJuan Quintela  ;;
890519175a2SAlex Barcelo  --with-coroutine=*) coroutine="$optarg"
891519175a2SAlex Barcelo  ;;
8921ffb3bbbSPaolo Bonzini  --disable-zlib-test)
8931ece9905SAlon Levy  ;;
89452b53c04SFam Zheng  --disable-virtio-blk-data-plane|--enable-virtio-blk-data-plane)
89552b53c04SFam Zheng      echo "$0: $opt is obsolete, virtio-blk data-plane is always on" >&2
896583f6e7bSStefan Hajnoczi  ;;
897cb6414dfSFam Zheng  --enable-vhdx|--disable-vhdx)
898cb6414dfSFam Zheng      echo "$0: $opt is obsolete, VHDX driver is always built" >&2
899cb6414dfSFam Zheng  ;;
900315d3184SFam Zheng  --enable-uuid|--disable-uuid)
901315d3184SFam Zheng      echo "$0: $opt is obsolete, UUID support is always built" >&2
902315d3184SFam Zheng  ;;
903cc84d63aSDaniel P. Berrange  --with-git=*) git="$optarg"
904cc84d63aSDaniel P. Berrange  ;;
9057d7dbf9dSDan Streetman  --with-git-submodules=*)
9067d7dbf9dSDan Streetman      git_submodules_action="$optarg"
907f62bbee5SDaniel P. Berrange  ;;
9089b8e4298SAlex Bennée  --enable-plugins) if test "$mingw32" = "yes"; then
9099b8e4298SAlex Bennée                        error_exit "TCG plugins not currently supported on Windows platforms"
9109b8e4298SAlex Bennée                    else
9119b8e4298SAlex Bennée                        plugins="yes"
9129b8e4298SAlex Bennée                    fi
91340e8c6f4SAlex Bennée  ;;
91440e8c6f4SAlex Bennée  --disable-plugins) plugins="no"
91540e8c6f4SAlex Bennée  ;;
916afc3a8f9SAlex Bennée  --enable-containers) use_containers="yes"
917afc3a8f9SAlex Bennée  ;;
918afc3a8f9SAlex Bennée  --disable-containers) use_containers="no"
919afc3a8f9SAlex Bennée  ;;
920f48e590aSAlex Bennée  --gdb=*) gdb_bin="$optarg"
921f48e590aSAlex Bennée  ;;
9223b4da132SPaolo Bonzini  # backwards compatibility options
9233b4da132SPaolo Bonzini  --enable-trace-backend=*) meson_option_parse "--enable-trace-backends=$optarg" "$optarg"
9243b4da132SPaolo Bonzini  ;;
9253b4da132SPaolo Bonzini  --disable-blobs) meson_option_parse --disable-install-blobs ""
9263b4da132SPaolo Bonzini  ;;
92755116968SJagannathan Raman  --enable-vfio-user-server) vfio_user_server="enabled"
92855116968SJagannathan Raman  ;;
92955116968SJagannathan Raman  --disable-vfio-user-server) vfio_user_server="disabled"
93055116968SJagannathan Raman  ;;
9313b4da132SPaolo Bonzini  --enable-tcmalloc) meson_option_parse --enable-malloc=tcmalloc tcmalloc
9323b4da132SPaolo Bonzini  ;;
9333b4da132SPaolo Bonzini  --enable-jemalloc) meson_option_parse --enable-malloc=jemalloc jemalloc
9343b4da132SPaolo Bonzini  ;;
9353b4da132SPaolo Bonzini  # everything else has the same name in configure and meson
9364fda6011SPaolo Bonzini  --*) meson_option_parse "$opt" "$optarg"
9377f1559c6Sbalrog  ;;
9387d13299dSbellard  esac
9397d13299dSbellarddone
9407d13299dSbellard
941d1a14257SAlex Bennée# test for any invalid configuration combinations
942d1a14257SAlex Bennéeif test "$plugins" = "yes" -a "$tcg" = "disabled"; then
943d1a14257SAlex Bennée    error_exit "Can't enable plugins on non-TCG builds"
944d1a14257SAlex Bennéefi
945d1a14257SAlex Bennée
9467d7dbf9dSDan Streetmancase $git_submodules_action in
9477d7dbf9dSDan Streetman    update|validate)
9487d7dbf9dSDan Streetman        if test ! -e "$source_path/.git"; then
9497d7dbf9dSDan Streetman            echo "ERROR: cannot $git_submodules_action git submodules without .git"
9507d7dbf9dSDan Streetman            exit 1
9517d7dbf9dSDan Streetman        fi
9527d7dbf9dSDan Streetman    ;;
9537d7dbf9dSDan Streetman    ignore)
954b80fd281SPaolo Bonzini        if ! test -f "$source_path/ui/keycodemapdb/README"
955b80fd281SPaolo Bonzini        then
956b80fd281SPaolo Bonzini            echo
957b80fd281SPaolo Bonzini            echo "ERROR: missing GIT submodules"
958b80fd281SPaolo Bonzini            echo
959b80fd281SPaolo Bonzini            if test -e "$source_path/.git"; then
960b80fd281SPaolo Bonzini                echo "--with-git-submodules=ignore specified but submodules were not"
961b80fd281SPaolo Bonzini                echo "checked out.  Please initialize and update submodules."
962b80fd281SPaolo Bonzini            else
963b80fd281SPaolo Bonzini                echo "This is not a GIT checkout but module content appears to"
964b80fd281SPaolo Bonzini                echo "be missing. Do not use 'git archive' or GitHub download links"
965b80fd281SPaolo Bonzini                echo "to acquire QEMU source archives. Non-GIT builds are only"
966b80fd281SPaolo Bonzini                echo "supported with source archives linked from:"
967b80fd281SPaolo Bonzini                echo
968b80fd281SPaolo Bonzini                echo "  https://www.qemu.org/download/#source"
969b80fd281SPaolo Bonzini                echo
970b80fd281SPaolo Bonzini                echo "Developers working with GIT can use scripts/archive-source.sh"
971b80fd281SPaolo Bonzini                echo "if they need to create valid source archives."
972b80fd281SPaolo Bonzini            fi
973b80fd281SPaolo Bonzini            echo
974b80fd281SPaolo Bonzini            exit 1
975b80fd281SPaolo Bonzini        fi
9767d7dbf9dSDan Streetman    ;;
9777d7dbf9dSDan Streetman    *)
9787d7dbf9dSDan Streetman        echo "ERROR: invalid --with-git-submodules= value '$git_submodules_action'"
9797d7dbf9dSDan Streetman        exit 1
9807d7dbf9dSDan Streetman    ;;
9817d7dbf9dSDan Streetmanesac
9827d7dbf9dSDan Streetman
98360e0df25SPeter Maydelldefault_target_list=""
9846e92f823SPeter Maydellmak_wilds=""
9856e92f823SPeter Maydell
986b915a2f1SPaolo Bonziniif [ "$linux_user" != no ]; then
98764708615SPeter Maydell    if [ "$targetos" = linux ] && [ -d "$source_path/linux-user/include/host/$cpu" ]; then
988b915a2f1SPaolo Bonzini        linux_user=yes
989b915a2f1SPaolo Bonzini    elif [ "$linux_user" = yes ]; then
990b915a2f1SPaolo Bonzini        error_exit "linux-user not supported on this architecture"
991b915a2f1SPaolo Bonzini    fi
992b915a2f1SPaolo Bonzinifi
993b915a2f1SPaolo Bonziniif [ "$bsd_user" != no ]; then
994b915a2f1SPaolo Bonzini    if [ "$bsd_user" = "" ]; then
995b915a2f1SPaolo Bonzini        test $targetos = freebsd && bsd_user=yes
996b915a2f1SPaolo Bonzini    fi
99764708615SPeter Maydell    if [ "$bsd_user" = yes ] && ! [ -d "$source_path/bsd-user/$targetos" ]; then
998b915a2f1SPaolo Bonzini        error_exit "bsd-user not supported on this host OS"
999b915a2f1SPaolo Bonzini    fi
1000b915a2f1SPaolo Bonzinifi
100160e0df25SPeter Maydellif [ "$softmmu" = "yes" ]; then
1002812b31d3SAlex Bennée    mak_wilds="${mak_wilds} $source_path/configs/targets/*-softmmu.mak"
100360e0df25SPeter Maydellfi
100460e0df25SPeter Maydellif [ "$linux_user" = "yes" ]; then
1005812b31d3SAlex Bennée    mak_wilds="${mak_wilds} $source_path/configs/targets/*-linux-user.mak"
100660e0df25SPeter Maydellfi
100760e0df25SPeter Maydellif [ "$bsd_user" = "yes" ]; then
1008812b31d3SAlex Bennée    mak_wilds="${mak_wilds} $source_path/configs/targets/*-bsd-user.mak"
100960e0df25SPeter Maydellfi
101060e0df25SPeter Maydell
1011447e133fSAlex Bennéefor config in $mak_wilds; do
1012447e133fSAlex Bennée    target="$(basename "$config" .mak)"
101398db9a06SAlex Bennée    if echo "$target_list_exclude" | grep -vq "$target"; then
1014447e133fSAlex Bennée        default_target_list="${default_target_list} $target"
1015447e133fSAlex Bennée    fi
1016447e133fSAlex Bennéedone
10176e92f823SPeter Maydell
1018af5db58eSpbrookif test x"$show_help" = x"yes" ; then
1019af5db58eSpbrookcat << EOF
1020af5db58eSpbrook
1021af5db58eSpbrookUsage: configure [options]
1022af5db58eSpbrookOptions: [defaults in brackets after descriptions]
1023af5db58eSpbrook
102408fb77edSStefan WeilStandard options:
102508fb77edSStefan Weil  --help                   print this message
102608fb77edSStefan Weil  --prefix=PREFIX          install in PREFIX [$prefix]
102774154d7eSThomas Huth  --target-list=LIST       set target list (default: build all)
102808fb77edSStefan Weil$(echo Available targets: $default_target_list | \
102908fb77edSStefan Weil  fold -s -w 53 | sed -e 's/^/                           /')
1030447e133fSAlex Bennée  --target-list-exclude=LIST exclude a set of targets from the default target-list
103108fb77edSStefan Weil
103208fb77edSStefan WeilAdvanced options (experts only):
10333812c0c4SJoelle van Dyne  --cross-prefix=PREFIX    use PREFIX for compile tools, PREFIX can be blank [$cross_prefix]
103408fb77edSStefan Weil  --cc=CC                  use C compiler CC [$cc]
103508fb77edSStefan Weil  --host-cc=CC             use C compiler CC [$host_cc] for code run at
103608fb77edSStefan Weil                           build time
103708fb77edSStefan Weil  --cxx=CXX                use C++ compiler CXX [$cxx]
103808fb77edSStefan Weil  --objcc=OBJCC            use Objective-C compiler OBJCC [$objcc]
1039a2866660SPaolo Bonzini  --extra-cflags=CFLAGS    append extra C compiler flags CFLAGS
1040a2866660SPaolo Bonzini  --extra-cxxflags=CXXFLAGS append extra C++ compiler flags CXXFLAGS
1041e910c7d9SPhilippe Mathieu-Daudé  --extra-objcflags=OBJCFLAGS append extra Objective C compiler flags OBJCFLAGS
104208fb77edSStefan Weil  --extra-ldflags=LDFLAGS  append extra linker flags LDFLAGS
1043d75402b5SAlex Bennée  --cross-cc-ARCH=CC       use compiler when building ARCH guest test cases
1044479ca4ccSMatheus Ferst  --cross-cc-cflags-ARCH=  use compiler flags when building ARCH guest tests
10455adb43beSPaolo Bonzini  --cross-prefix-ARCH=PREFIX cross compiler prefix when building ARCH guest test cases
104608fb77edSStefan Weil  --make=MAKE              use specified make [$make]
104708fb77edSStefan Weil  --python=PYTHON          use specified python [$python]
1048a5665051SPaolo Bonzini  --meson=MESON            use specified meson [$meson]
104948328880SPaolo Bonzini  --ninja=NINJA            use specified ninja [$ninja]
105008fb77edSStefan Weil  --smbd=SMBD              use specified smbd [$smbd]
1051db1b5f13SThomas Huth  --with-git=GIT           use specified git [$git]
10527d7dbf9dSDan Streetman  --with-git-submodules=update   update git submodules (default if .git dir exists)
10537d7dbf9dSDan Streetman  --with-git-submodules=validate fail if git submodules are not up to date
10547d7dbf9dSDan Streetman  --with-git-submodules=ignore   do not update or check git submodules (default if no .git dir)
105508fb77edSStefan Weil  --static                 enable static build [$static]
105608fb77edSStefan Weil  --bindir=PATH            install binaries in PATH
1057ca8c0909SMarc-André Lureau  --with-suffix=SUFFIX     suffix for QEMU data inside datadir/libdir/sysconfdir/docdir [$qemu_suffix]
1058c035c8d6SPaolo Bonzini  --without-default-features default all --enable-* options to "disabled"
1059c035c8d6SPaolo Bonzini  --without-default-devices  do not include any device that is not needed to
1060c035c8d6SPaolo Bonzini                           start the emulator (only use if you are including
1061d1d5e9eeSAlex Bennée                           desired devices in configs/devices/)
1062d1d5e9eeSAlex Bennée  --with-devices-ARCH=NAME override default configs/devices
106308fb77edSStefan Weil  --enable-debug           enable common debug build options
1064247724cbSMarc-André Lureau  --enable-sanitizers      enable default sanitizers
10650aebab04SLingfeng Yang  --enable-tsan            enable thread sanitizer
106608fb77edSStefan Weil  --disable-werror         disable compilation abort on warning
106763678e17SSteven Noonan  --disable-stack-protector disable compiler-provided stack protection
1068c23f23b9SMichael Tokarev  --cpu=CPU                Build for host CPU [$cpu]
106908fb77edSStefan Weil  --with-coroutine=BACKEND coroutine backend. Supported options:
107033c53c54SDaniel P. Berrange                           ucontext, sigaltstack, windows
107140e8c6f4SAlex Bennée  --enable-plugins
107240e8c6f4SAlex Bennée                           enable plugins via shared library loading
1073afc3a8f9SAlex Bennée  --disable-containers     don't use containers for cross-building
1074f48e590aSAlex Bennée  --gdb=GDB-path           gdb to use for gdbstub tests [$gdb_bin]
107561d63097SPaolo BonziniEOF
107661d63097SPaolo Bonzini  meson_options_help
107761d63097SPaolo Bonzinicat << EOF
1078c23f23b9SMichael Tokarev  system          all system emulation targets
1079c23f23b9SMichael Tokarev  user            supported user emulation targets
1080c23f23b9SMichael Tokarev  linux-user      all linux usermode emulation targets
1081c23f23b9SMichael Tokarev  bsd-user        all BSD usermode emulation targets
1082c23f23b9SMichael Tokarev  pie             Position Independent Executables
108321e709aaSMarc-André Lureau  modules         modules support (non-Windows)
1084c23f23b9SMichael Tokarev  debug-tcg       TCG debugging (default is disabled)
1085c23f23b9SMichael Tokarev  debug-info      debugging information
10861e4f6065SDaniele Buono  safe-stack      SafeStack Stack Smash Protection. Depends on
10871e4f6065SDaniele Buono                  clang/llvm >= 3.7 and requires coroutine backend ucontext.
108808fb77edSStefan Weil
108908fb77edSStefan WeilNOTE: The object files are built at the place where configure is launched
1090af5db58eSpbrookEOF
10912d2ad6d0SFam Zhengexit 0
1092af5db58eSpbrookfi
1093af5db58eSpbrook
10949c790242SThomas Huth# Remove old dependency files to make sure that they get properly regenerated
1095002d8c13SPeter Maydellrm -f ./*/config-devices.mak.d
10969c790242SThomas Huth
1097faf44142SDaniel P. Berrangéif test -z "$python"
1098faf44142SDaniel P. Berrangéthen
1099c53eeaf7SStefan Hajnoczi    error_exit "Python not found. Use --python=/path/to/python"
1100c53eeaf7SStefan Hajnoczifi
11018e2c76bdSRoman Bolshakovif ! has "$make"
11028e2c76bdSRoman Bolshakovthen
11038e2c76bdSRoman Bolshakov    error_exit "GNU make ($make) not found"
11048e2c76bdSRoman Bolshakovfi
1105c53eeaf7SStefan Hajnoczi
1106c53eeaf7SStefan Hajnoczi# Note that if the Python conditional here evaluates True we will exit
1107c53eeaf7SStefan Hajnoczi# with status 1 which is a shell 'false' value.
11081b11f28dSThomas Huthif ! $python -c 'import sys; sys.exit(sys.version_info < (3,6))'; then
11091b11f28dSThomas Huth  error_exit "Cannot use '$python', Python >= 3.6 is required." \
1110c53eeaf7SStefan Hajnoczi      "Use --python=/path/to/python to specify a supported Python."
1111c53eeaf7SStefan Hajnoczifi
1112c53eeaf7SStefan Hajnoczi
1113c53eeaf7SStefan Hajnoczi# Suppress writing compiled files
1114c53eeaf7SStefan Hajnoczipython="$python -B"
1115c53eeaf7SStefan Hajnoczi
11160a01d76fSMarc-André Lureauif test -z "$meson"; then
11176638cae5SPaolo Bonzini    if test "$explicit_python" = no && has meson && version_ge "$(meson --version)" 0.59.3; then
11180a01d76fSMarc-André Lureau        meson=meson
111964708615SPeter Maydell    elif test "$git_submodules_action" != 'ignore' ; then
11200a01d76fSMarc-André Lureau        meson=git
11210a01d76fSMarc-André Lureau    elif test -e "${source_path}/meson/meson.py" ; then
11220a01d76fSMarc-André Lureau        meson=internal
11230a01d76fSMarc-André Lureau    else
11240a01d76fSMarc-André Lureau        if test "$explicit_python" = yes; then
11250a01d76fSMarc-André Lureau            error_exit "--python requires using QEMU's embedded Meson distribution, but it was not found."
11260a01d76fSMarc-André Lureau        else
1127a5665051SPaolo Bonzini            error_exit "Meson not found.  Use --meson=/path/to/meson"
1128a5665051SPaolo Bonzini        fi
11290a01d76fSMarc-André Lureau    fi
11300a01d76fSMarc-André Lureauelse
11310a01d76fSMarc-André Lureau    # Meson uses its own Python interpreter to invoke other Python scripts,
11320a01d76fSMarc-André Lureau    # but the user wants to use the one they specified with --python.
11330a01d76fSMarc-André Lureau    #
11340a01d76fSMarc-André Lureau    # We do not want to override the distro Python interpreter (and sometimes
11350a01d76fSMarc-André Lureau    # cannot: for example in Homebrew /usr/bin/meson is a bash script), so
11360a01d76fSMarc-André Lureau    # just require --meson=git|internal together with --python.
11370a01d76fSMarc-André Lureau    if test "$explicit_python" = yes; then
11380a01d76fSMarc-André Lureau        case "$meson" in
11390a01d76fSMarc-André Lureau            git | internal) ;;
11400a01d76fSMarc-André Lureau            *) error_exit "--python requires using QEMU's embedded Meson distribution." ;;
11410a01d76fSMarc-André Lureau        esac
11420a01d76fSMarc-André Lureau    fi
11430a01d76fSMarc-André Lureaufi
1144a5665051SPaolo Bonzini
11450a01d76fSMarc-André Lureauif test "$meson" = git; then
11460a01d76fSMarc-André Lureau    git_submodules="${git_submodules} meson"
11470a01d76fSMarc-André Lureaufi
11480a01d76fSMarc-André Lureau
11490a01d76fSMarc-André Lureaucase "$meson" in
11500a01d76fSMarc-André Lureau    git | internal)
11510a01d76fSMarc-André Lureau        meson="$python ${source_path}/meson/meson.py"
11520a01d76fSMarc-André Lureau        ;;
115384ec0c24SPaolo Bonzini    *) meson=$(command -v "$meson") ;;
11540a01d76fSMarc-André Lureauesac
11550a01d76fSMarc-André Lureau
115609e93326SPaolo Bonzini# Probe for ninja
115748328880SPaolo Bonzini
115848328880SPaolo Bonziniif test -z "$ninja"; then
115948328880SPaolo Bonzini    for c in ninja ninja-build samu; do
116048328880SPaolo Bonzini        if has $c; then
116148328880SPaolo Bonzini            ninja=$(command -v "$c")
116248328880SPaolo Bonzini            break
116348328880SPaolo Bonzini        fi
116448328880SPaolo Bonzini    done
116509e93326SPaolo Bonzini    if test -z "$ninja"; then
116609e93326SPaolo Bonzini      error_exit "Cannot find Ninja"
116709e93326SPaolo Bonzini    fi
116848328880SPaolo Bonzinifi
1169a5665051SPaolo Bonzini
11709aae6e54SDaniel Henrique Barboza# Check that the C compiler works. Doing this here before testing
11719aae6e54SDaniel Henrique Barboza# the host CPU ensures that we had a valid CC to autodetect the
11729aae6e54SDaniel Henrique Barboza# $cpu var (and we should bail right here if that's not the case).
11739aae6e54SDaniel Henrique Barboza# It also allows the help message to be printed without a CC.
11749aae6e54SDaniel Henrique Barbozawrite_c_skeleton;
11759aae6e54SDaniel Henrique Barbozaif compile_object ; then
11769aae6e54SDaniel Henrique Barboza  : C compiler works ok
11779aae6e54SDaniel Henrique Barbozaelse
11789aae6e54SDaniel Henrique Barboza    error_exit "\"$cc\" either does not exist or does not work"
11799aae6e54SDaniel Henrique Barbozafi
11809aae6e54SDaniel Henrique Barbozaif ! compile_prog ; then
11819aae6e54SDaniel Henrique Barboza    error_exit "\"$cc\" cannot build an executable (is your linker broken?)"
11829aae6e54SDaniel Henrique Barbozafi
11839aae6e54SDaniel Henrique Barboza
11849c83ffd8SPeter Maydell# Consult white-list to determine whether to enable werror
11859c83ffd8SPeter Maydell# by default.  Only enable by default for git builds
11869c83ffd8SPeter Maydellif test -z "$werror" ; then
11877d7dbf9dSDan Streetman    if test "$git_submodules_action" != "ignore" && \
1188e633a5c6SEric Blake        { test "$linux" = "yes" || test "$mingw32" = "yes"; }; then
11899c83ffd8SPeter Maydell        werror="yes"
11909c83ffd8SPeter Maydell    else
11919c83ffd8SPeter Maydell        werror="no"
11929c83ffd8SPeter Maydell    fi
11939c83ffd8SPeter Maydellfi
11949c83ffd8SPeter Maydell
1195975ff037SPaolo Bonziniif test "$targetos" = "bogus"; then
1196fb59dabdSPeter Maydell    # Now that we know that we're not printing the help and that
1197fb59dabdSPeter Maydell    # the compiler works (so the results of the check_defines we used
1198fb59dabdSPeter Maydell    # to identify the OS are reliable), if we didn't recognize the
1199fb59dabdSPeter Maydell    # host OS we should stop now.
1200951fedfcSPeter Maydell    error_exit "Unrecognized host OS (uname -s reports '$(uname -s)')"
1201fb59dabdSPeter Maydellfi
1202fb59dabdSPeter Maydell
1203efc6c070SThomas Huth# Check whether the compiler matches our minimum requirements:
1204efc6c070SThomas Huthcat > $TMPC << EOF
1205efc6c070SThomas Huth#if defined(__clang_major__) && defined(__clang_minor__)
1206efc6c070SThomas Huth# ifdef __apple_build_version__
12072a85a08cSDaniel P. Berrangé#  if __clang_major__ < 10 || (__clang_major__ == 10 && __clang_minor__ < 0)
12082a85a08cSDaniel P. Berrangé#   error You need at least XCode Clang v10.0 to compile QEMU
1209efc6c070SThomas Huth#  endif
1210efc6c070SThomas Huth# else
12112a85a08cSDaniel P. Berrangé#  if __clang_major__ < 6 || (__clang_major__ == 6 && __clang_minor__ < 0)
12122a85a08cSDaniel P. Berrangé#   error You need at least Clang v6.0 to compile QEMU
1213efc6c070SThomas Huth#  endif
1214efc6c070SThomas Huth# endif
1215efc6c070SThomas Huth#elif defined(__GNUC__) && defined(__GNUC_MINOR__)
12163830df5fSnia# if __GNUC__ < 7 || (__GNUC__ == 7 && __GNUC_MINOR__ < 4)
12173830df5fSnia#  error You need at least GCC v7.4.0 to compile QEMU
1218efc6c070SThomas Huth# endif
1219efc6c070SThomas Huth#else
1220efc6c070SThomas Huth# error You either need GCC or Clang to compiler QEMU
1221efc6c070SThomas Huth#endif
1222efc6c070SThomas Huthint main (void) { return 0; }
1223efc6c070SThomas HuthEOF
1224efc6c070SThomas Huthif ! compile_prog "" "" ; then
12253830df5fSnia    error_exit "You need at least GCC v7.4 or Clang v6.0 (or XCode Clang v10.0)"
1226efc6c070SThomas Huthfi
1227efc6c070SThomas Huth
122800849b92SRichard Henderson# Accumulate -Wfoo and -Wno-bar separately.
122900849b92SRichard Henderson# We will list all of the enable flags first, and the disable flags second.
123000849b92SRichard Henderson# Note that we do not add -Werror, because that would enable it for all
123100849b92SRichard Henderson# configure tests. If a configure test failed due to -Werror this would
123200849b92SRichard Henderson# just silently disable some features, so it's too error prone.
123300849b92SRichard Henderson
123400849b92SRichard Hendersonwarn_flags=
123500849b92SRichard Hendersonadd_to warn_flags -Wold-style-declaration
123600849b92SRichard Hendersonadd_to warn_flags -Wold-style-definition
123700849b92SRichard Hendersonadd_to warn_flags -Wtype-limits
123800849b92SRichard Hendersonadd_to warn_flags -Wformat-security
123900849b92SRichard Hendersonadd_to warn_flags -Wformat-y2k
124000849b92SRichard Hendersonadd_to warn_flags -Winit-self
124100849b92SRichard Hendersonadd_to warn_flags -Wignored-qualifiers
124200849b92SRichard Hendersonadd_to warn_flags -Wempty-body
124300849b92SRichard Hendersonadd_to warn_flags -Wnested-externs
124400849b92SRichard Hendersonadd_to warn_flags -Wendif-labels
124500849b92SRichard Hendersonadd_to warn_flags -Wexpansion-to-defined
12460a2ebce9SThomas Huthadd_to warn_flags -Wimplicit-fallthrough=2
124700849b92SRichard Henderson
124800849b92SRichard Hendersonnowarn_flags=
124900849b92SRichard Hendersonadd_to nowarn_flags -Wno-initializer-overrides
125000849b92SRichard Hendersonadd_to nowarn_flags -Wno-missing-include-dirs
125100849b92SRichard Hendersonadd_to nowarn_flags -Wno-shift-negative-value
125200849b92SRichard Hendersonadd_to nowarn_flags -Wno-string-plus-int
125300849b92SRichard Hendersonadd_to nowarn_flags -Wno-typedef-redefinition
1254aabab967SRichard Hendersonadd_to nowarn_flags -Wno-tautological-type-limit-compare
1255bac8d222SRichard Hendersonadd_to nowarn_flags -Wno-psabi
125600849b92SRichard Henderson
125700849b92SRichard Hendersongcc_flags="$warn_flags $nowarn_flags"
125893b25869SJohn Snow
125993b25869SJohn Snowcc_has_warning_flag() {
126093b25869SJohn Snow    write_c_skeleton;
126193b25869SJohn Snow
1262a1d29d6cSPeter Maydell    # Use the positive sense of the flag when testing for -Wno-wombat
1263a1d29d6cSPeter Maydell    # support (gcc will happily accept the -Wno- form of unknown
1264a1d29d6cSPeter Maydell    # warning options).
126593b25869SJohn Snow    optflag="$(echo $1 | sed -e 's/^-Wno-/-W/')"
126693b25869SJohn Snow    compile_prog "-Werror $optflag" ""
126793b25869SJohn Snow}
126893b25869SJohn Snow
12694cb37d11SPhilippe Mathieu-Daudéobjcc_has_warning_flag() {
12704cb37d11SPhilippe Mathieu-Daudé    cat > $TMPM <<EOF
12714cb37d11SPhilippe Mathieu-Daudéint main(void) { return 0; }
12724cb37d11SPhilippe Mathieu-DaudéEOF
12734cb37d11SPhilippe Mathieu-Daudé
12744cb37d11SPhilippe Mathieu-Daudé    # Use the positive sense of the flag when testing for -Wno-wombat
12754cb37d11SPhilippe Mathieu-Daudé    # support (gcc will happily accept the -Wno- form of unknown
12764cb37d11SPhilippe Mathieu-Daudé    # warning options).
12774cb37d11SPhilippe Mathieu-Daudé    optflag="$(echo $1 | sed -e 's/^-Wno-/-W/')"
12784cb37d11SPhilippe Mathieu-Daudé    do_objc -Werror $optflag \
12794cb37d11SPhilippe Mathieu-Daudé      $OBJCFLAGS $EXTRA_OBJCFLAGS $CONFIGURE_OBJCFLAGS $QEMU_OBJCFLAGS \
12804cb37d11SPhilippe Mathieu-Daudé      -o $TMPE $TMPM $QEMU_LDFLAGS
12814cb37d11SPhilippe Mathieu-Daudé}
12824cb37d11SPhilippe Mathieu-Daudé
128393b25869SJohn Snowfor flag in $gcc_flags; do
128493b25869SJohn Snow    if cc_has_warning_flag $flag ; then
12858d05095cSPaolo Bonzini        QEMU_CFLAGS="$QEMU_CFLAGS $flag"
12868d05095cSPaolo Bonzini    fi
12874cb37d11SPhilippe Mathieu-Daudé    if objcc_has_warning_flag $flag ; then
12884cb37d11SPhilippe Mathieu-Daudé        QEMU_OBJCFLAGS="$QEMU_OBJCFLAGS $flag"
12894cb37d11SPhilippe Mathieu-Daudé    fi
12908d05095cSPaolo Bonzinidone
12918d05095cSPaolo Bonzini
129263678e17SSteven Noonanif test "$stack_protector" != "no"; then
1293fccd35a0SRodrigo Rebello  cat > $TMPC << EOF
1294fccd35a0SRodrigo Rebelloint main(int argc, char *argv[])
1295fccd35a0SRodrigo Rebello{
1296fccd35a0SRodrigo Rebello    char arr[64], *p = arr, *c = argv[0];
1297fccd35a0SRodrigo Rebello    while (*c) {
1298fccd35a0SRodrigo Rebello        *p++ = *c++;
1299fccd35a0SRodrigo Rebello    }
1300fccd35a0SRodrigo Rebello    return 0;
1301fccd35a0SRodrigo Rebello}
1302fccd35a0SRodrigo RebelloEOF
130363678e17SSteven Noonan  gcc_flags="-fstack-protector-strong -fstack-protector-all"
13043b463a3fSMiroslav Rezanina  sp_on=0
130563678e17SSteven Noonan  for flag in $gcc_flags; do
1306590e5dd9SPeter Maydell    # We need to check both a compile and a link, since some compiler
1307590e5dd9SPeter Maydell    # setups fail only on a .c->.o compile and some only at link time
1308086d5f75SPaolo Bonzini    if compile_object "-Werror $flag" &&
1309590e5dd9SPeter Maydell       compile_prog "-Werror $flag" ""; then
131063678e17SSteven Noonan      QEMU_CFLAGS="$QEMU_CFLAGS $flag"
1311db5adeaaSPaolo Bonzini      QEMU_LDFLAGS="$QEMU_LDFLAGS $flag"
13123b463a3fSMiroslav Rezanina      sp_on=1
131363678e17SSteven Noonan      break
131463678e17SSteven Noonan    fi
131563678e17SSteven Noonan  done
13163b463a3fSMiroslav Rezanina  if test "$stack_protector" = yes; then
13173b463a3fSMiroslav Rezanina    if test $sp_on = 0; then
13183b463a3fSMiroslav Rezanina      error_exit "Stack protector not supported"
13193b463a3fSMiroslav Rezanina    fi
13203b463a3fSMiroslav Rezanina  fi
132137746c5eSMarc-André Lureaufi
132237746c5eSMarc-André Lureau
132320bc94a2SPaolo Bonzini# Disable -Wmissing-braces on older compilers that warn even for
132420bc94a2SPaolo Bonzini# the "universal" C zero initializer {0}.
132520bc94a2SPaolo Bonzinicat > $TMPC << EOF
132620bc94a2SPaolo Bonzinistruct {
132720bc94a2SPaolo Bonzini  int a[2];
132820bc94a2SPaolo Bonzini} x = {0};
132920bc94a2SPaolo BonziniEOF
133020bc94a2SPaolo Bonziniif compile_object "-Werror" "" ; then
133120bc94a2SPaolo Bonzini  :
133220bc94a2SPaolo Bonzinielse
133320bc94a2SPaolo Bonzini  QEMU_CFLAGS="$QEMU_CFLAGS -Wno-missing-braces"
133420bc94a2SPaolo Bonzinifi
133520bc94a2SPaolo Bonzini
133621e709aaSMarc-André Lureau# Our module code doesn't support Windows
133721e709aaSMarc-André Lureauif test "$modules" = "yes" && test "$mingw32" = "yes" ; then
133821e709aaSMarc-André Lureau  error_exit "Modules are not available for Windows"
133921e709aaSMarc-André Lureaufi
134021e709aaSMarc-André Lureau
13415f2453acSAlex Bennée# Static linking is not possible with plugins, modules or PIE
134240d6444eSAvi Kivityif test "$static" = "yes" ; then
1343aa0d1f44SPaolo Bonzini  if test "$modules" = "yes" ; then
1344aa0d1f44SPaolo Bonzini    error_exit "static and modules are mutually incompatible"
1345aa0d1f44SPaolo Bonzini  fi
13465f2453acSAlex Bennée  if test "$plugins" = "yes"; then
13475f2453acSAlex Bennée    error_exit "static and plugins are mutually incompatible"
1348ba4dd2aaSAlex Bennée  else
1349ba4dd2aaSAlex Bennée    plugins="no"
13505f2453acSAlex Bennée  fi
135140d6444eSAvi Kivityfi
135237650689SPaolo Bonzinitest "$plugins" = "" && plugins=yes
135340d6444eSAvi Kivity
135440d6444eSAvi Kivitycat > $TMPC << EOF
135521d4a791SAvi Kivity
135621d4a791SAvi Kivity#ifdef __linux__
135721d4a791SAvi Kivity#  define THREAD __thread
135821d4a791SAvi Kivity#else
135921d4a791SAvi Kivity#  define THREAD
136021d4a791SAvi Kivity#endif
136121d4a791SAvi Kivitystatic THREAD int tls_var;
136221d4a791SAvi Kivityint main(void) { return tls_var; }
136340d6444eSAvi KivityEOF
1364b2634124SRichard Henderson
136512781462SRichard Hendersonif test "$static" = "yes"; then
1366eca7a8e6SRichard Henderson  if test "$pie" != "no" && compile_prog "-Werror -fPIE -DPIE" "-static-pie"; then
13675770e8afSPaolo Bonzini    CONFIGURE_CFLAGS="-fPIE -DPIE $CONFIGURE_CFLAGS"
136812781462SRichard Henderson    QEMU_LDFLAGS="-static-pie $QEMU_LDFLAGS"
136912781462SRichard Henderson    pie="yes"
137012781462SRichard Henderson  elif test "$pie" = "yes"; then
137112781462SRichard Henderson    error_exit "-static-pie not available due to missing toolchain support"
137212781462SRichard Henderson  else
137312781462SRichard Henderson    QEMU_LDFLAGS="-static $QEMU_LDFLAGS"
137412781462SRichard Henderson    pie="no"
137512781462SRichard Henderson  fi
137612781462SRichard Hendersonelif test "$pie" = "no"; then
1377b9eae9efSPaolo Bonzini  if compile_prog "-Werror -fno-pie" "-no-pie"; then
1378b9eae9efSPaolo Bonzini    CONFIGURE_CFLAGS="-fno-pie $CONFIGURE_CFLAGS"
1379b9eae9efSPaolo Bonzini    CONFIGURE_LDFLAGS="-no-pie $CONFIGURE_LDFLAGS"
1380abafb64bSAlex Bennée    # Meson currently only handles pie as a boolean for now so if we have
1381abafb64bSAlex Bennée    # explicitly disabled PIE we need to extend our cflags because it wont.
1382abafb64bSAlex Bennée    QEMU_CFLAGS="-fno-pie -no-pie $QEMU_CFLAGS"
1383b9eae9efSPaolo Bonzini  fi
1384eca7a8e6SRichard Hendersonelif compile_prog "-Werror -fPIE -DPIE" "-pie"; then
13855770e8afSPaolo Bonzini  CONFIGURE_CFLAGS="-fPIE -DPIE $CONFIGURE_CFLAGS"
13865770e8afSPaolo Bonzini  CONFIGURE_LDFLAGS="-pie $CONFIGURE_LDFLAGS"
138740d6444eSAvi Kivity  pie="yes"
13882c674109SRichard Hendersonelif test "$pie" = "yes"; then
138976ad07a4SPeter Maydell  error_exit "PIE not available due to missing toolchain support"
139040d6444eSAvi Kivityelse
139140d6444eSAvi Kivity  echo "Disabling PIE due to missing toolchain support"
139240d6444eSAvi Kivity  pie="no"
139340d6444eSAvi Kivityfi
139440d6444eSAvi Kivity
1395e6cbd751SRichard Henderson# Detect support for PT_GNU_RELRO + DT_BIND_NOW.
1396e6cbd751SRichard Henderson# The combination is known as "full relro", because .got.plt is read-only too.
1397e6cbd751SRichard Hendersonif compile_prog "" "-Wl,-z,relro -Wl,-z,now" ; then
1398e6cbd751SRichard Henderson  QEMU_LDFLAGS="-Wl,-z,relro -Wl,-z,now $QEMU_LDFLAGS"
1399e6cbd751SRichard Hendersonfi
1400e6cbd751SRichard Henderson
140109dada40SPaolo Bonzini##########################################
140209dada40SPaolo Bonzini# __sync_fetch_and_and requires at least -march=i486. Many toolchains
140309dada40SPaolo Bonzini# use i686 as default anyway, but for those that don't, an explicit
140409dada40SPaolo Bonzini# specification is necessary
140509dada40SPaolo Bonzini
140609dada40SPaolo Bonziniif test "$cpu" = "i386"; then
140709dada40SPaolo Bonzini  cat > $TMPC << EOF
140809dada40SPaolo Bonzinistatic int sfaa(int *ptr)
140909dada40SPaolo Bonzini{
141009dada40SPaolo Bonzini  return __sync_fetch_and_and(ptr, 0);
141109dada40SPaolo Bonzini}
141209dada40SPaolo Bonzini
141309dada40SPaolo Bonziniint main(void)
141409dada40SPaolo Bonzini{
141509dada40SPaolo Bonzini  int val = 42;
14161405b629SStefan Weil  val = __sync_val_compare_and_swap(&val, 0, 1);
141709dada40SPaolo Bonzini  sfaa(&val);
141809dada40SPaolo Bonzini  return val;
141909dada40SPaolo Bonzini}
142009dada40SPaolo BonziniEOF
142109dada40SPaolo Bonzini  if ! compile_prog "" "" ; then
142209dada40SPaolo Bonzini    QEMU_CFLAGS="-march=i486 $QEMU_CFLAGS"
142309dada40SPaolo Bonzini  fi
142409dada40SPaolo Bonzinifi
142509dada40SPaolo Bonzini
1426afb63ebdSStefan Weilif test -z "${target_list+xxx}" ; then
1427fdb75aefSPaolo Bonzini    default_targets=yes
1428d880a3baSPaolo Bonzini    for target in $default_target_list; do
1429d880a3baSPaolo Bonzini        target_list="$target_list $target"
1430d880a3baSPaolo Bonzini    done
1431d880a3baSPaolo Bonzini    target_list="${target_list# }"
1432121afa9eSAnthony Liguorielse
1433fdb75aefSPaolo Bonzini    default_targets=no
143489138857SStefan Weil    target_list=$(echo "$target_list" | sed -e 's/,/ /g')
1435d880a3baSPaolo Bonzini    for target in $target_list; do
143625b48338SPeter Maydell        # Check that we recognised the target name; this allows a more
143725b48338SPeter Maydell        # friendly error message than if we let it fall through.
143825b48338SPeter Maydell        case " $default_target_list " in
143925b48338SPeter Maydell            *" $target "*)
144025b48338SPeter Maydell                ;;
144125b48338SPeter Maydell            *)
144225b48338SPeter Maydell                error_exit "Unknown target name '$target'"
144325b48338SPeter Maydell                ;;
144425b48338SPeter Maydell        esac
144525b48338SPeter Maydell    done
1446d880a3baSPaolo Bonzinifi
144725b48338SPeter Maydell
1448f55fe278SPaolo Bonzini# see if system emulation was really requested
1449f55fe278SPaolo Bonzinicase " $target_list " in
1450f55fe278SPaolo Bonzini  *"-softmmu "*) softmmu=yes
1451f55fe278SPaolo Bonzini  ;;
1452f55fe278SPaolo Bonzini  *) softmmu=no
1453f55fe278SPaolo Bonzini  ;;
1454f55fe278SPaolo Bonziniesac
14555327cf48Sbellard
14567630156dSPhilippe Mathieu-Daudéif test "$tcg" = "auto"; then
14577630156dSPhilippe Mathieu-Daudé  if test -z "$target_list"; then
14587630156dSPhilippe Mathieu-Daudé    tcg="disabled"
14597630156dSPhilippe Mathieu-Daudé  else
14607630156dSPhilippe Mathieu-Daudé    tcg="enabled"
14617630156dSPhilippe Mathieu-Daudé  fi
14627630156dSPhilippe Mathieu-Daudéfi
14637630156dSPhilippe Mathieu-Daudé
14647630156dSPhilippe Mathieu-Daudéif test "$tcg" = "enabled"; then
14657630156dSPhilippe Mathieu-Daudé    git_submodules="$git_submodules tests/fp/berkeley-testfloat-3"
14667630156dSPhilippe Mathieu-Daudé    git_submodules="$git_submodules tests/fp/berkeley-softfloat-3"
14677630156dSPhilippe Mathieu-Daudéfi
14687630156dSPhilippe Mathieu-Daudé
14697d13299dSbellard# ---
14707d13299dSbellard# big/little endian test
14717d13299dSbellardcat > $TMPC << EOF
1472659eb157SThomas Huth#include <stdio.h>
147361cc919fSMike Frysingershort big_endian[] = { 0x4269, 0x4765, 0x4e64, 0x4961, 0x4e00, 0, };
147461cc919fSMike Frysingershort little_endian[] = { 0x694c, 0x7454, 0x654c, 0x6e45, 0x6944, 0x6e41, 0, };
1475659eb157SThomas Huthint main(int argc, char *argv[])
1476659eb157SThomas Huth{
1477659eb157SThomas Huth    return printf("%s %s\n", (char *)big_endian, (char *)little_endian);
14787d13299dSbellard}
14797d13299dSbellardEOF
14807d13299dSbellard
1481659eb157SThomas Huthif compile_prog ; then
1482659eb157SThomas Huth    if strings -a $TMPE | grep -q BiGeNdIaN ; then
148361cc919fSMike Frysinger        bigendian="yes"
1484659eb157SThomas Huth    elif strings -a $TMPE | grep -q LiTtLeEnDiAn ; then
148561cc919fSMike Frysinger        bigendian="no"
14867d13299dSbellard    else
14877d13299dSbellard        echo big/little test failed
1488659eb157SThomas Huth        exit 1
14897d13299dSbellard    fi
14907d13299dSbellardelse
149161cc919fSMike Frysinger    echo big/little test failed
1492659eb157SThomas Huth    exit 1
14937d13299dSbellardfi
14947d13299dSbellard
1495015a33bdSGonglei##########################################
1496779ab5e3SStefan Weil# pkg-config probe
1497779ab5e3SStefan Weil
1498779ab5e3SStefan Weilif ! has "$pkg_config_exe"; then
149976ad07a4SPeter Maydell  error_exit "pkg-config binary '$pkg_config_exe' not found"
1500779ab5e3SStefan Weilfi
1501779ab5e3SStefan Weil
1502779ab5e3SStefan Weil##########################################
1503e18df141SAnthony Liguori# glib support probe
1504a52d28afSPaolo Bonzini
15050ce9b08cSThomas Huth# When bumping glib_req_ver, please check also whether we should increase
15060ce9b08cSThomas Huth# the _WIN32_WINNT setting in osdep.h according to the value from glib
1507b4c6036fSDaniel P. Berrangéglib_req_ver=2.56
1508aa0d1f44SPaolo Bonziniglib_modules=gthread-2.0
1509aa0d1f44SPaolo Bonziniif test "$modules" = yes; then
1510a88afc64SGerd Hoffmann    glib_modules="$glib_modules gmodule-export-2.0"
1511b906acacSPaolo Bonzinielif test "$plugins" = "yes"; then
1512b906acacSPaolo Bonzini    glib_modules="$glib_modules gmodule-no-export-2.0"
151354cb65d8SEmilio G. Cotafi
1514e26110cfSFam Zheng
1515aa0d1f44SPaolo Bonzinifor i in $glib_modules; do
1516e26110cfSFam Zheng    if $pkg_config --atleast-version=$glib_req_ver $i; then
151789138857SStefan Weil        glib_cflags=$($pkg_config --cflags $i)
151889138857SStefan Weil        glib_libs=$($pkg_config --libs $i)
1519e18df141SAnthony Liguori    else
1520e26110cfSFam Zheng        error_exit "glib-$glib_req_ver $i is required to compile QEMU"
1521e26110cfSFam Zheng    fi
1522e26110cfSFam Zhengdone
1523e26110cfSFam Zheng
15245b9e7d05SMarc-André Lureauglib_bindir="$($pkg_config --variable=bindir glib-2.0)"
15255b9e7d05SMarc-André Lureauif test -z "$glib_bindir" ; then
15265b9e7d05SMarc-André Lureau	glib_bindir="$($pkg_config --variable=prefix glib-2.0)"/bin
15275b9e7d05SMarc-André Lureaufi
15285b9e7d05SMarc-André Lureau
1529215b0c2fSPaolo Bonzini# This workaround is required due to a bug in pkg-config file for glib as it
1530215b0c2fSPaolo Bonzini# doesn't define GLIB_STATIC_COMPILATION for pkg-config --static
1531215b0c2fSPaolo Bonzini
1532215b0c2fSPaolo Bonziniif test "$static" = yes && test "$mingw32" = yes; then
1533215b0c2fSPaolo Bonzini    glib_cflags="-DGLIB_STATIC_COMPILATION $glib_cflags"
1534215b0c2fSPaolo Bonzinifi
1535215b0c2fSPaolo Bonzini
1536977a82abSDaniel P. Berrange# Sanity check that the current size_t matches the
1537977a82abSDaniel P. Berrange# size that glib thinks it should be. This catches
1538977a82abSDaniel P. Berrange# problems on multi-arch where people try to build
1539977a82abSDaniel P. Berrange# 32-bit QEMU while pointing at 64-bit glib headers
1540977a82abSDaniel P. Berrangecat > $TMPC <<EOF
1541977a82abSDaniel P. Berrange#include <glib.h>
1542977a82abSDaniel P. Berrange#include <unistd.h>
1543977a82abSDaniel P. Berrange
1544977a82abSDaniel P. Berrange#define QEMU_BUILD_BUG_ON(x) \
1545977a82abSDaniel P. Berrange  typedef char qemu_build_bug_on[(x)?-1:1] __attribute__((unused));
1546977a82abSDaniel P. Berrange
1547977a82abSDaniel P. Berrangeint main(void) {
1548977a82abSDaniel P. Berrange   QEMU_BUILD_BUG_ON(sizeof(size_t) != GLIB_SIZEOF_SIZE_T);
1549977a82abSDaniel P. Berrange   return 0;
1550977a82abSDaniel P. Berrange}
1551977a82abSDaniel P. BerrangeEOF
1552977a82abSDaniel P. Berrange
1553215b0c2fSPaolo Bonziniif ! compile_prog "$glib_cflags" "$glib_libs" ; then
1554977a82abSDaniel P. Berrange    error_exit "sizeof(size_t) doesn't match GLIB_SIZEOF_SIZE_T."\
1555977a82abSDaniel P. Berrange               "You probably need to set PKG_CONFIG_LIBDIR"\
1556977a82abSDaniel P. Berrange	       "to point to the right pkg-config files for your"\
1557977a82abSDaniel P. Berrange	       "build target"
1558977a82abSDaniel P. Berrangefi
1559977a82abSDaniel P. Berrange
15609bda600bSEric Blake# Silence clang warnings triggered by glib < 2.57.2
15619bda600bSEric Blakecat > $TMPC << EOF
15629bda600bSEric Blake#include <glib.h>
15639bda600bSEric Blaketypedef struct Foo {
15649bda600bSEric Blake    int i;
15659bda600bSEric Blake} Foo;
15669bda600bSEric Blakestatic void foo_free(Foo *f)
15679bda600bSEric Blake{
15689bda600bSEric Blake    g_free(f);
15699bda600bSEric Blake}
1570e0e7fe07SMarc-André LureauG_DEFINE_AUTOPTR_CLEANUP_FUNC(Foo, foo_free)
15719bda600bSEric Blakeint main(void) { return 0; }
15729bda600bSEric BlakeEOF
15739bda600bSEric Blakeif ! compile_prog "$glib_cflags -Werror" "$glib_libs" ; then
15749bda600bSEric Blake    if cc_has_warning_flag "-Wno-unused-function"; then
15759bda600bSEric Blake        glib_cflags="$glib_cflags -Wno-unused-function"
15765770e8afSPaolo Bonzini        CONFIGURE_CFLAGS="$CONFIGURE_CFLAGS -Wno-unused-function"
15779bda600bSEric Blake    fi
15789bda600bSEric Blakefi
15799bda600bSEric Blake
1580e26110cfSFam Zheng##########################################
1581f652e6afSaurel32# fdt probe
1582e169e1e1SPeter Maydell
1583fbb4121dSPaolo Bonzinicase "$fdt" in
1584fbb4121dSPaolo Bonzini  auto | enabled | internal)
1585fbb4121dSPaolo Bonzini    # Simpler to always update submodule, even if not needed.
1586aef45d51SDaniel P. Berrange    git_submodules="${git_submodules} dtc"
1587fbb4121dSPaolo Bonzini    ;;
1588fbb4121dSPaolo Bonziniesac
1589f652e6afSaurel32
159020ff075bSMichael Walle##########################################
1591519175a2SAlex Barcelo# check and set a backend for coroutine
1592d0e2fce5SAneesh Kumar K.V
15937c2acc70SPeter Maydell# We prefer ucontext, but it's not always possible. The fallback
159433c53c54SDaniel P. Berrange# is sigcontext. On Windows the only valid backend is the Windows
159533c53c54SDaniel P. Berrange# specific one.
15967c2acc70SPeter Maydell
15977c2acc70SPeter Maydellucontext_works=no
1598d0e2fce5SAneesh Kumar K.Vif test "$darwin" != "yes"; then
1599d0e2fce5SAneesh Kumar K.V  cat > $TMPC << EOF
1600d0e2fce5SAneesh Kumar K.V#include <ucontext.h>
1601cdf84806SPeter Maydell#ifdef __stub_makecontext
1602cdf84806SPeter Maydell#error Ignoring glibc stub makecontext which will always fail
1603cdf84806SPeter Maydell#endif
160475cafad7SStefan Weilint main(void) { makecontext(0, 0, 0); return 0; }
1605d0e2fce5SAneesh Kumar K.VEOF
1606d0e2fce5SAneesh Kumar K.V  if compile_prog "" "" ; then
16077c2acc70SPeter Maydell    ucontext_works=yes
1608d0e2fce5SAneesh Kumar K.V  fi
1609519175a2SAlex Barcelofi
16107c2acc70SPeter Maydell
16117c2acc70SPeter Maydellif test "$coroutine" = ""; then
16127c2acc70SPeter Maydell  if test "$mingw32" = "yes"; then
16137c2acc70SPeter Maydell    coroutine=win32
16147c2acc70SPeter Maydell  elif test "$ucontext_works" = "yes"; then
16157c2acc70SPeter Maydell    coroutine=ucontext
1616519175a2SAlex Barcelo  else
16177c2acc70SPeter Maydell    coroutine=sigaltstack
16187c2acc70SPeter Maydell  fi
16197c2acc70SPeter Maydellelse
16207c2acc70SPeter Maydell  case $coroutine in
16217c2acc70SPeter Maydell  windows)
16227c2acc70SPeter Maydell    if test "$mingw32" != "yes"; then
16237c2acc70SPeter Maydell      error_exit "'windows' coroutine backend only valid for Windows"
16247c2acc70SPeter Maydell    fi
16257c2acc70SPeter Maydell    # Unfortunately the user visible backend name doesn't match the
16267c2acc70SPeter Maydell    # coroutine-*.c filename for this case, so we have to adjust it here.
16277c2acc70SPeter Maydell    coroutine=win32
16287c2acc70SPeter Maydell    ;;
16297c2acc70SPeter Maydell  ucontext)
16307c2acc70SPeter Maydell    if test "$ucontext_works" != "yes"; then
16317cb58448SPaolo Bonzini      error_exit "'ucontext' backend requested but makecontext not available"
16327c2acc70SPeter Maydell    fi
16337c2acc70SPeter Maydell    ;;
163433c53c54SDaniel P. Berrange  sigaltstack)
16357c2acc70SPeter Maydell    if test "$mingw32" = "yes"; then
16367c2acc70SPeter Maydell      error_exit "only the 'windows' coroutine backend is valid for Windows"
16377c2acc70SPeter Maydell    fi
16387c2acc70SPeter Maydell    ;;
16397c2acc70SPeter Maydell  *)
164076ad07a4SPeter Maydell    error_exit "unknown coroutine backend $coroutine"
16417c2acc70SPeter Maydell    ;;
16427c2acc70SPeter Maydell  esac
1643d0e2fce5SAneesh Kumar K.Vfi
1644d0e2fce5SAneesh Kumar K.V
16451e4f6065SDaniele Buono##################################################
16461e4f6065SDaniele Buono# SafeStack
16471e4f6065SDaniele Buono
16481e4f6065SDaniele Buono
16491e4f6065SDaniele Buonoif test "$safe_stack" = "yes"; then
16501e4f6065SDaniele Buonocat > $TMPC << EOF
16511e4f6065SDaniele Buonoint main(int argc, char *argv[])
16521e4f6065SDaniele Buono{
16531e4f6065SDaniele Buono#if ! __has_feature(safe_stack)
16541e4f6065SDaniele Buono#error SafeStack Disabled
16551e4f6065SDaniele Buono#endif
16561e4f6065SDaniele Buono    return 0;
16571e4f6065SDaniele Buono}
16581e4f6065SDaniele BuonoEOF
16591e4f6065SDaniele Buono  flag="-fsanitize=safe-stack"
16601e4f6065SDaniele Buono  # Check that safe-stack is supported and enabled.
16611e4f6065SDaniele Buono  if compile_prog "-Werror $flag" "$flag"; then
16621e4f6065SDaniele Buono    # Flag needed both at compilation and at linking
16631e4f6065SDaniele Buono    QEMU_CFLAGS="$QEMU_CFLAGS $flag"
16641e4f6065SDaniele Buono    QEMU_LDFLAGS="$QEMU_LDFLAGS $flag"
16651e4f6065SDaniele Buono  else
16661e4f6065SDaniele Buono    error_exit "SafeStack not supported by your compiler"
16671e4f6065SDaniele Buono  fi
16681e4f6065SDaniele Buono  if test "$coroutine" != "ucontext"; then
16691e4f6065SDaniele Buono    error_exit "SafeStack is only supported by the coroutine backend ucontext"
16701e4f6065SDaniele Buono  fi
16711e4f6065SDaniele Buonoelse
16721e4f6065SDaniele Buonocat > $TMPC << EOF
16731e4f6065SDaniele Buonoint main(int argc, char *argv[])
16741e4f6065SDaniele Buono{
16751e4f6065SDaniele Buono#if defined(__has_feature)
16761e4f6065SDaniele Buono#if __has_feature(safe_stack)
16771e4f6065SDaniele Buono#error SafeStack Enabled
16781e4f6065SDaniele Buono#endif
16791e4f6065SDaniele Buono#endif
16801e4f6065SDaniele Buono    return 0;
16811e4f6065SDaniele Buono}
16821e4f6065SDaniele BuonoEOF
16831e4f6065SDaniele Buonoif test "$safe_stack" = "no"; then
16841e4f6065SDaniele Buono  # Make sure that safe-stack is disabled
16851e4f6065SDaniele Buono  if ! compile_prog "-Werror" ""; then
16861e4f6065SDaniele Buono    # SafeStack was already enabled, try to explicitly remove the feature
16871e4f6065SDaniele Buono    flag="-fno-sanitize=safe-stack"
16881e4f6065SDaniele Buono    if ! compile_prog "-Werror $flag" "$flag"; then
16891e4f6065SDaniele Buono      error_exit "Configure cannot disable SafeStack"
16901e4f6065SDaniele Buono    fi
16911e4f6065SDaniele Buono    QEMU_CFLAGS="$QEMU_CFLAGS $flag"
16921e4f6065SDaniele Buono    QEMU_LDFLAGS="$QEMU_LDFLAGS $flag"
16931e4f6065SDaniele Buono  fi
16941e4f6065SDaniele Buonoelse # "$safe_stack" = ""
16951e4f6065SDaniele Buono  # Set safe_stack to yes or no based on pre-existing flags
16961e4f6065SDaniele Buono  if compile_prog "-Werror" ""; then
16971e4f6065SDaniele Buono    safe_stack="no"
16981e4f6065SDaniele Buono  else
16991e4f6065SDaniele Buono    safe_stack="yes"
17001e4f6065SDaniele Buono    if test "$coroutine" != "ucontext"; then
17011e4f6065SDaniele Buono      error_exit "SafeStack is only supported by the coroutine backend ucontext"
17021e4f6065SDaniele Buono    fi
17031e4f6065SDaniele Buono  fi
17041e4f6065SDaniele Buonofi
17051e4f6065SDaniele Buonofi
17067d992e4dSPeter Lieven
170776a347e1SRichard Henderson########################################
1708fd0e6053SJohn Snow# check if ccache is interfering with
1709fd0e6053SJohn Snow# semantic analysis of macros
1710fd0e6053SJohn Snow
17115e4dfd3dSJohn Snowunset CCACHE_CPP2
1712fd0e6053SJohn Snowccache_cpp2=no
1713fd0e6053SJohn Snowcat > $TMPC << EOF
1714fd0e6053SJohn Snowstatic const int Z = 1;
1715fd0e6053SJohn Snow#define fn() ({ Z; })
1716fd0e6053SJohn Snow#define TAUT(X) ((X) == Z)
1717fd0e6053SJohn Snow#define PAREN(X, Y) (X == Y)
1718fd0e6053SJohn Snow#define ID(X) (X)
1719fd0e6053SJohn Snowint main(int argc, char *argv[])
1720fd0e6053SJohn Snow{
1721fd0e6053SJohn Snow    int x = 0, y = 0;
1722fd0e6053SJohn Snow    x = ID(x);
1723fd0e6053SJohn Snow    x = fn();
1724fd0e6053SJohn Snow    fn();
1725fd0e6053SJohn Snow    if (PAREN(x, y)) return 0;
1726fd0e6053SJohn Snow    if (TAUT(Z)) return 0;
1727fd0e6053SJohn Snow    return 0;
1728fd0e6053SJohn Snow}
1729fd0e6053SJohn SnowEOF
1730fd0e6053SJohn Snow
1731fd0e6053SJohn Snowif ! compile_object "-Werror"; then
1732fd0e6053SJohn Snow    ccache_cpp2=yes
1733fd0e6053SJohn Snowfi
1734fd0e6053SJohn Snow
1735b553a042SJohn Snow#################################################
1736b553a042SJohn Snow# clang does not support glibc + FORTIFY_SOURCE.
1737b553a042SJohn Snow
1738b553a042SJohn Snowif test "$fortify_source" != "no"; then
1739b553a042SJohn Snow  if echo | $cc -dM -E - | grep __clang__ > /dev/null 2>&1 ; then
1740b553a042SJohn Snow    fortify_source="no";
1741e189091fSPeter Maydell  elif test -n "$cxx" && has $cxx &&
1742cfcc7c14SJohn Snow       echo | $cxx -dM -E - | grep __clang__ >/dev/null 2>&1 ; then
1743b553a042SJohn Snow    fortify_source="no";
1744b553a042SJohn Snow  else
1745b553a042SJohn Snow    fortify_source="yes"
1746b553a042SJohn Snow  fi
1747b553a042SJohn Snowfi
1748b553a042SJohn Snow
1749d2042378SAneesh Kumar K.V##########################################
1750247724cbSMarc-André Lureau# checks for sanitizers
1751247724cbSMarc-André Lureau
1752247724cbSMarc-André Lureauhave_asan=no
1753247724cbSMarc-André Lureauhave_ubsan=no
1754d83414e1SMarc-André Lureauhave_asan_iface_h=no
1755d83414e1SMarc-André Lureauhave_asan_iface_fiber=no
1756247724cbSMarc-André Lureau
1757247724cbSMarc-André Lureauif test "$sanitizers" = "yes" ; then
1758b9f44da2SMarc-André Lureau  write_c_skeleton
1759247724cbSMarc-André Lureau  if compile_prog "$CPU_CFLAGS -Werror -fsanitize=address" ""; then
1760247724cbSMarc-André Lureau      have_asan=yes
1761247724cbSMarc-André Lureau  fi
1762b9f44da2SMarc-André Lureau
1763b9f44da2SMarc-André Lureau  # we could use a simple skeleton for flags checks, but this also
1764b9f44da2SMarc-André Lureau  # detect the static linking issue of ubsan, see also:
1765b9f44da2SMarc-André Lureau  # https://gcc.gnu.org/bugzilla/show_bug.cgi?id=84285
1766b9f44da2SMarc-André Lureau  cat > $TMPC << EOF
1767b9f44da2SMarc-André Lureau#include <stdlib.h>
1768b9f44da2SMarc-André Lureauint main(void) {
1769b9f44da2SMarc-André Lureau    void *tmp = malloc(10);
1770f2dfe54cSLeonid Bloch    if (tmp != NULL) {
1771b9f44da2SMarc-André Lureau        return *(int *)(tmp + 2);
1772b9f44da2SMarc-André Lureau    }
1773d1abf3fcSOlaf Hering    return 1;
1774f2dfe54cSLeonid Bloch}
1775b9f44da2SMarc-André LureauEOF
1776247724cbSMarc-André Lureau  if compile_prog "$CPU_CFLAGS -Werror -fsanitize=undefined" ""; then
1777247724cbSMarc-André Lureau      have_ubsan=yes
1778247724cbSMarc-André Lureau  fi
1779d83414e1SMarc-André Lureau
1780d83414e1SMarc-André Lureau  if check_include "sanitizer/asan_interface.h" ; then
1781d83414e1SMarc-André Lureau      have_asan_iface_h=yes
1782d83414e1SMarc-André Lureau  fi
1783d83414e1SMarc-André Lureau
1784d83414e1SMarc-André Lureau  cat > $TMPC << EOF
1785d83414e1SMarc-André Lureau#include <sanitizer/asan_interface.h>
1786d83414e1SMarc-André Lureauint main(void) {
1787d83414e1SMarc-André Lureau  __sanitizer_start_switch_fiber(0, 0, 0);
1788d83414e1SMarc-André Lureau  return 0;
1789d83414e1SMarc-André Lureau}
1790d83414e1SMarc-André LureauEOF
1791d83414e1SMarc-André Lureau  if compile_prog "$CPU_CFLAGS -Werror -fsanitize=address" "" ; then
1792d83414e1SMarc-André Lureau      have_asan_iface_fiber=yes
1793d83414e1SMarc-André Lureau  fi
1794247724cbSMarc-André Lureaufi
1795247724cbSMarc-André Lureau
17960aebab04SLingfeng Yang# Thread sanitizer is, for now, much noisier than the other sanitizers;
17970aebab04SLingfeng Yang# keep it separate until that is not the case.
17980aebab04SLingfeng Yangif test "$tsan" = "yes" && test "$sanitizers" = "yes"; then
17990aebab04SLingfeng Yang  error_exit "TSAN is not supported with other sanitiziers."
18000aebab04SLingfeng Yangfi
18010aebab04SLingfeng Yanghave_tsan=no
18020aebab04SLingfeng Yanghave_tsan_iface_fiber=no
18030aebab04SLingfeng Yangif test "$tsan" = "yes" ; then
18040aebab04SLingfeng Yang  write_c_skeleton
18050aebab04SLingfeng Yang  if compile_prog "$CPU_CFLAGS -Werror -fsanitize=thread" "" ; then
18060aebab04SLingfeng Yang      have_tsan=yes
18070aebab04SLingfeng Yang  fi
18080aebab04SLingfeng Yang  cat > $TMPC << EOF
18090aebab04SLingfeng Yang#include <sanitizer/tsan_interface.h>
18100aebab04SLingfeng Yangint main(void) {
18110aebab04SLingfeng Yang  __tsan_create_fiber(0);
18120aebab04SLingfeng Yang  return 0;
18130aebab04SLingfeng Yang}
18140aebab04SLingfeng YangEOF
18150aebab04SLingfeng Yang  if compile_prog "$CPU_CFLAGS -Werror -fsanitize=thread" "" ; then
18160aebab04SLingfeng Yang      have_tsan_iface_fiber=yes
18170aebab04SLingfeng Yang  fi
18180aebab04SLingfeng Yangfi
18190aebab04SLingfeng Yang
1820adc28027SAlexander Bulekov##########################################
1821675b9b53SMarc-André Lureau# check for slirp
1822675b9b53SMarc-André Lureau
1823675b9b53SMarc-André Lureaucase "$slirp" in
18244d34a86bSPaolo Bonzini  auto | enabled | internal)
18254d34a86bSPaolo Bonzini    # Simpler to always update submodule, even if not needed.
18267c57bdd8SMarc-André Lureau    git_submodules="${git_submodules} slirp"
1827675b9b53SMarc-André Lureau    ;;
1828675b9b53SMarc-André Lureauesac
1829675b9b53SMarc-André Lureau
183054e7aac0SAlexey Krasikov##########################################
1831cd362defSPaolo Bonzini# functions to probe cross compilers
1832cd362defSPaolo Bonzini
1833cd362defSPaolo Bonzinicontainer="no"
1834cd362defSPaolo Bonziniif test $use_containers = "yes"; then
1835cd362defSPaolo Bonzini    if has "docker" || has "podman"; then
183664708615SPeter Maydell        container=$($python "$source_path"/tests/docker/docker.py probe)
1837cd362defSPaolo Bonzini    fi
1838cd362defSPaolo Bonzinifi
1839cd362defSPaolo Bonzini
1840cd362defSPaolo Bonzini# cross compilers defaults, can be overridden with --cross-cc-ARCH
18415adb43beSPaolo Bonzini: ${cross_prefix_aarch64="aarch64-linux-gnu-"}
18425adb43beSPaolo Bonzini: ${cross_prefix_aarch64_be="$cross_prefix_aarch64"}
18435adb43beSPaolo Bonzini: ${cross_prefix_alpha="alpha-linux-gnu-"}
18445adb43beSPaolo Bonzini: ${cross_prefix_arm="arm-linux-gnueabihf-"}
18455adb43beSPaolo Bonzini: ${cross_prefix_armeb="$cross_prefix_arm"}
18465adb43beSPaolo Bonzini: ${cross_prefix_hexagon="hexagon-unknown-linux-musl-"}
184734bb43b0SSong Gao: ${cross_prefix_loongarch64="loongarch64-unknown-linux-gnu-"}
18485adb43beSPaolo Bonzini: ${cross_prefix_hppa="hppa-linux-gnu-"}
18495adb43beSPaolo Bonzini: ${cross_prefix_i386="i686-linux-gnu-"}
18505adb43beSPaolo Bonzini: ${cross_prefix_m68k="m68k-linux-gnu-"}
18515adb43beSPaolo Bonzini: ${cross_prefix_microblaze="microblaze-linux-musl-"}
18525adb43beSPaolo Bonzini: ${cross_prefix_mips64el="mips64el-linux-gnuabi64-"}
18535adb43beSPaolo Bonzini: ${cross_prefix_mips64="mips64-linux-gnuabi64-"}
18545adb43beSPaolo Bonzini: ${cross_prefix_mipsel="mipsel-linux-gnu-"}
18555adb43beSPaolo Bonzini: ${cross_prefix_mips="mips-linux-gnu-"}
18565adb43beSPaolo Bonzini: ${cross_prefix_nios2="nios2-linux-gnu-"}
18575adb43beSPaolo Bonzini: ${cross_prefix_ppc="powerpc-linux-gnu-"}
18585adb43beSPaolo Bonzini: ${cross_prefix_ppc64="powerpc64-linux-gnu-"}
18595adb43beSPaolo Bonzini: ${cross_prefix_ppc64le="$cross_prefix_ppc64"}
18605adb43beSPaolo Bonzini: ${cross_prefix_riscv64="riscv64-linux-gnu-"}
18615adb43beSPaolo Bonzini: ${cross_prefix_s390x="s390x-linux-gnu-"}
18625adb43beSPaolo Bonzini: ${cross_prefix_sh4="sh4-linux-gnu-"}
18635adb43beSPaolo Bonzini: ${cross_prefix_sparc64="sparc64-linux-gnu-"}
18645adb43beSPaolo Bonzini: ${cross_prefix_sparc="$cross_prefix_sparc64"}
18655adb43beSPaolo Bonzini: ${cross_prefix_x86_64="x86_64-linux-gnu-"}
18665adb43beSPaolo Bonzini
1867cd362defSPaolo Bonzini: ${cross_cc_aarch64_be="$cross_cc_aarch64"}
1868cd362defSPaolo Bonzini: ${cross_cc_cflags_aarch64_be="-mbig-endian"}
186946af66edSPaolo Bonzini: ${cross_cc_armeb="$cross_cc_arm"}
1870cd362defSPaolo Bonzini: ${cross_cc_cflags_armeb="-mbig-endian"}
1871cd362defSPaolo Bonzini: ${cross_cc_hexagon="hexagon-unknown-linux-musl-clang"}
1872cd362defSPaolo Bonzini: ${cross_cc_cflags_hexagon="-mv67 -O2 -static"}
1873cd362defSPaolo Bonzini: ${cross_cc_cflags_i386="-m32"}
1874d44f2f96SPaolo Bonzini: ${cross_cc_cflags_ppc="-m32 -mbig-endian"}
1875cd362defSPaolo Bonzini: ${cross_cc_cflags_ppc64="-m64 -mbig-endian"}
1876cd362defSPaolo Bonzini: ${cross_cc_ppc64le="$cross_cc_ppc64"}
1877cd362defSPaolo Bonzini: ${cross_cc_cflags_ppc64le="-m64 -mlittle-endian"}
1878cd362defSPaolo Bonzini: ${cross_cc_cflags_sparc64="-m64 -mcpu=ultrasparc"}
187946af66edSPaolo Bonzini: ${cross_cc_sparc="$cross_cc_sparc64"}
188046af66edSPaolo Bonzini: ${cross_cc_cflags_sparc="-m32 -mcpu=supersparc"}
1881cd362defSPaolo Bonzini: ${cross_cc_cflags_x86_64="-m64"}
1882cd362defSPaolo Bonzini
18835adb43beSPaolo Bonzinicompute_target_variable() {
188492e288fcSPaolo Bonzini  eval "$2="
18855adb43beSPaolo Bonzini  if eval test -n "\"\${cross_prefix_$1}\""; then
18865adb43beSPaolo Bonzini    if eval has "\"\${cross_prefix_$1}\$3\""; then
18875adb43beSPaolo Bonzini      eval "$2=\"\${cross_prefix_$1}\$3\""
18885adb43beSPaolo Bonzini    fi
18895adb43beSPaolo Bonzini  fi
18905adb43beSPaolo Bonzini}
1891cd362defSPaolo Bonzini
189252f08deaSPaolo Bonzini# probe_target_compiler TARGET
189352f08deaSPaolo Bonzini#
189452f08deaSPaolo Bonzini# Look for a compiler for the given target, either native or cross.
189552f08deaSPaolo Bonzini# Set variables target_* if a compiler is found, and container_cross_*
189652f08deaSPaolo Bonzini# if a Docker-based cross-compiler image is known for the target.
189752f08deaSPaolo Bonzini# Set got_cross_cc to yes/no depending on whether a non-container-based
189852f08deaSPaolo Bonzini# compiler was found.
189952f08deaSPaolo Bonzini#
190052f08deaSPaolo Bonzini# If TARGET is a user-mode emulation target, also set build_static to
190152f08deaSPaolo Bonzini# "y" if static linking is possible.
190252f08deaSPaolo Bonzini#
1903cd362defSPaolo Bonziniprobe_target_compiler() {
1904cd362defSPaolo Bonzini  # reset all output variables
190592e288fcSPaolo Bonzini  got_cross_cc=no
1906cd362defSPaolo Bonzini  container_image=
1907cd362defSPaolo Bonzini  container_hosts=
1908cd362defSPaolo Bonzini  container_cross_cc=
190987eb014cSPaolo Bonzini  container_cross_ar=
1910cd362defSPaolo Bonzini  container_cross_as=
1911cd362defSPaolo Bonzini  container_cross_ld=
191287eb014cSPaolo Bonzini  container_cross_nm=
191387eb014cSPaolo Bonzini  container_cross_objcopy=
191487eb014cSPaolo Bonzini  container_cross_ranlib=
191587eb014cSPaolo Bonzini  container_cross_strip=
1916cd362defSPaolo Bonzini
191752f08deaSPaolo Bonzini  target_arch=${1%%-*}
191852f08deaSPaolo Bonzini  case $target_arch in
1919cd362defSPaolo Bonzini    aarch64) container_hosts="x86_64 aarch64" ;;
1920cd362defSPaolo Bonzini    alpha) container_hosts=x86_64 ;;
1921cd362defSPaolo Bonzini    arm) container_hosts="x86_64 aarch64" ;;
1922cd362defSPaolo Bonzini    cris) container_hosts=x86_64 ;;
1923cd362defSPaolo Bonzini    hexagon) container_hosts=x86_64 ;;
1924cd362defSPaolo Bonzini    hppa) container_hosts=x86_64 ;;
1925cd362defSPaolo Bonzini    i386) container_hosts=x86_64 ;;
1926b70ec50bSRichard Henderson    loongarch64) container_hosts=x86_64 ;;
1927cd362defSPaolo Bonzini    m68k) container_hosts=x86_64 ;;
1928cd362defSPaolo Bonzini    microblaze) container_hosts=x86_64 ;;
1929cd362defSPaolo Bonzini    mips64el) container_hosts=x86_64 ;;
1930cd362defSPaolo Bonzini    mips64) container_hosts=x86_64 ;;
1931cd362defSPaolo Bonzini    mipsel) container_hosts=x86_64 ;;
1932cd362defSPaolo Bonzini    mips) container_hosts=x86_64 ;;
1933cd362defSPaolo Bonzini    nios2) container_hosts=x86_64 ;;
1934cd362defSPaolo Bonzini    ppc) container_hosts=x86_64 ;;
1935cd362defSPaolo Bonzini    ppc64|ppc64le) container_hosts=x86_64 ;;
1936cd362defSPaolo Bonzini    riscv64) container_hosts=x86_64 ;;
1937cd362defSPaolo Bonzini    s390x) container_hosts=x86_64 ;;
1938cd362defSPaolo Bonzini    sh4) container_hosts=x86_64 ;;
1939cd362defSPaolo Bonzini    sparc64) container_hosts=x86_64 ;;
1940cd362defSPaolo Bonzini    tricore) container_hosts=x86_64 ;;
1941cd362defSPaolo Bonzini    x86_64) container_hosts="aarch64 ppc64el x86_64" ;;
1942cd362defSPaolo Bonzini    xtensa*) container_hosts=x86_64 ;;
1943cd362defSPaolo Bonzini  esac
1944cd362defSPaolo Bonzini
1945cd362defSPaolo Bonzini  for host in $container_hosts; do
1946cd362defSPaolo Bonzini    test "$container" != no || continue
1947cd362defSPaolo Bonzini    test "$host" = "$cpu" || continue
194852f08deaSPaolo Bonzini    case $target_arch in
1949cd362defSPaolo Bonzini      aarch64)
1950cd362defSPaolo Bonzini        # We don't have any bigendian build tools so we only use this for AArch64
1951cd362defSPaolo Bonzini        container_image=debian-arm64-cross
19525adb43beSPaolo Bonzini        container_cross_prefix=aarch64-linux-gnu-
19535adb43beSPaolo Bonzini        container_cross_cc=${container_cross_prefix}gcc-10
1954cd362defSPaolo Bonzini        ;;
1955cd362defSPaolo Bonzini      alpha)
1956cd362defSPaolo Bonzini        container_image=debian-alpha-cross
19575adb43beSPaolo Bonzini        container_cross_prefix=alpha-linux-gnu-
1958cd362defSPaolo Bonzini        ;;
1959cd362defSPaolo Bonzini      arm)
1960cd362defSPaolo Bonzini        # We don't have any bigendian build tools so we only use this for ARM
1961cd362defSPaolo Bonzini        container_image=debian-armhf-cross
19625adb43beSPaolo Bonzini        container_cross_prefix=arm-linux-gnueabihf-
1963cd362defSPaolo Bonzini        ;;
1964cd362defSPaolo Bonzini      cris)
1965cd362defSPaolo Bonzini        container_image=fedora-cris-cross
19665adb43beSPaolo Bonzini        container_cross_prefix=cris-linux-gnu-
1967cd362defSPaolo Bonzini        ;;
1968cd362defSPaolo Bonzini      hexagon)
1969cd362defSPaolo Bonzini        container_image=debian-hexagon-cross
19705adb43beSPaolo Bonzini        container_cross_prefix=hexagon-unknown-linux-musl-
19715adb43beSPaolo Bonzini        container_cross_cc=${container_cross_prefix}clang
1972cd362defSPaolo Bonzini        ;;
1973cd362defSPaolo Bonzini      hppa)
1974cd362defSPaolo Bonzini        container_image=debian-hppa-cross
19755adb43beSPaolo Bonzini        container_cross_prefix=hppa-linux-gnu-
1976cd362defSPaolo Bonzini        ;;
1977cd362defSPaolo Bonzini      i386)
1978cd362defSPaolo Bonzini        container_image=fedora-i386-cross
19795adb43beSPaolo Bonzini        container_cross_prefix=
1980cd362defSPaolo Bonzini        ;;
1981b70ec50bSRichard Henderson      loongarch64)
1982b70ec50bSRichard Henderson        container_image=debian-loongarch-cross
1983b70ec50bSRichard Henderson        container_cross_prefix=loongarch64-unknown-linux-gnu-
1984b70ec50bSRichard Henderson        ;;
1985cd362defSPaolo Bonzini      m68k)
1986cd362defSPaolo Bonzini        container_image=debian-m68k-cross
19875adb43beSPaolo Bonzini        container_cross_prefix=m68k-linux-gnu-
1988cd362defSPaolo Bonzini        ;;
1989cd362defSPaolo Bonzini      microblaze)
1990cd362defSPaolo Bonzini        container_image=debian-microblaze-cross
19915adb43beSPaolo Bonzini        container_cross_prefix=microblaze-linux-musl-
1992cd362defSPaolo Bonzini        ;;
1993cd362defSPaolo Bonzini      mips64el)
1994cd362defSPaolo Bonzini        container_image=debian-mips64el-cross
19955adb43beSPaolo Bonzini        container_cross_prefix=mips64el-linux-gnuabi64-
1996cd362defSPaolo Bonzini        ;;
1997cd362defSPaolo Bonzini      mips64)
1998cd362defSPaolo Bonzini        container_image=debian-mips64-cross
19995adb43beSPaolo Bonzini        container_cross_prefix=mips64-linux-gnuabi64-
2000cd362defSPaolo Bonzini        ;;
2001cd362defSPaolo Bonzini      mipsel)
2002cd362defSPaolo Bonzini        container_image=debian-mipsel-cross
20035adb43beSPaolo Bonzini        container_cross_prefix=mipsel-linux-gnu-
2004cd362defSPaolo Bonzini        ;;
2005cd362defSPaolo Bonzini      mips)
2006cd362defSPaolo Bonzini        container_image=debian-mips-cross
20075adb43beSPaolo Bonzini        container_cross_prefix=mips-linux-gnu-
2008cd362defSPaolo Bonzini        ;;
2009cd362defSPaolo Bonzini      nios2)
2010cd362defSPaolo Bonzini        container_image=debian-nios2-cross
20115adb43beSPaolo Bonzini        container_cross_prefix=nios2-linux-gnu-
2012cd362defSPaolo Bonzini        ;;
2013cd362defSPaolo Bonzini      ppc)
2014cd362defSPaolo Bonzini        container_image=debian-powerpc-test-cross
20155adb43beSPaolo Bonzini        container_cross_prefix=powerpc-linux-gnu-
20165adb43beSPaolo Bonzini        container_cross_cc=${container_cross_prefix}gcc-10
2017cd362defSPaolo Bonzini        ;;
2018cd362defSPaolo Bonzini      ppc64|ppc64le)
2019cd362defSPaolo Bonzini        container_image=debian-powerpc-test-cross
2020705c881fSRichard Henderson        container_cross_prefix=powerpc${target_arch#ppc}-linux-gnu-
20215adb43beSPaolo Bonzini        container_cross_cc=${container_cross_prefix}gcc-10
2022cd362defSPaolo Bonzini        ;;
2023cd362defSPaolo Bonzini      riscv64)
2024cd362defSPaolo Bonzini        container_image=debian-riscv64-test-cross
20255adb43beSPaolo Bonzini        container_cross_prefix=riscv64-linux-gnu-
2026cd362defSPaolo Bonzini        ;;
2027cd362defSPaolo Bonzini      s390x)
2028cd362defSPaolo Bonzini        container_image=debian-s390x-cross
20295adb43beSPaolo Bonzini        container_cross_prefix=s390x-linux-gnu-
2030cd362defSPaolo Bonzini        ;;
2031cd362defSPaolo Bonzini      sh4)
2032cd362defSPaolo Bonzini        container_image=debian-sh4-cross
20335adb43beSPaolo Bonzini        container_cross_prefix=sh4-linux-gnu-
2034cd362defSPaolo Bonzini        ;;
2035cd362defSPaolo Bonzini      sparc64)
2036cd362defSPaolo Bonzini        container_image=debian-sparc64-cross
20375adb43beSPaolo Bonzini        container_cross_prefix=sparc64-linux-gnu-
2038cd362defSPaolo Bonzini        ;;
2039cd362defSPaolo Bonzini      tricore)
2040cd362defSPaolo Bonzini        container_image=debian-tricore-cross
20415adb43beSPaolo Bonzini        container_cross_prefix=tricore-
2042cd362defSPaolo Bonzini        container_cross_as=tricore-as
2043cd362defSPaolo Bonzini        container_cross_ld=tricore-ld
20445adb43beSPaolo Bonzini        break
2045cd362defSPaolo Bonzini        ;;
2046cd362defSPaolo Bonzini      x86_64)
2047cd362defSPaolo Bonzini        container_image=debian-amd64-cross
20485adb43beSPaolo Bonzini        container_cross_prefix=x86_64-linux-gnu-
2049cd362defSPaolo Bonzini        ;;
2050cd362defSPaolo Bonzini      xtensa*)
2051cd362defSPaolo Bonzini        container_hosts=x86_64
2052cd362defSPaolo Bonzini        container_image=debian-xtensa-cross
2053cd362defSPaolo Bonzini
2054cd362defSPaolo Bonzini        # default to the dc232b cpu
20555adb43beSPaolo Bonzini        container_cross_prefix=/opt/2020.07/xtensa-dc232b-elf/bin/xtensa-dc232b-elf-
2056cd362defSPaolo Bonzini        ;;
2057cd362defSPaolo Bonzini    esac
20585adb43beSPaolo Bonzini    : ${container_cross_cc:=${container_cross_prefix}gcc}
205987eb014cSPaolo Bonzini    : ${container_cross_ar:=${container_cross_prefix}ar}
20605adb43beSPaolo Bonzini    : ${container_cross_as:=${container_cross_prefix}as}
20615adb43beSPaolo Bonzini    : ${container_cross_ld:=${container_cross_prefix}ld}
206287eb014cSPaolo Bonzini    : ${container_cross_nm:=${container_cross_prefix}nm}
206387eb014cSPaolo Bonzini    : ${container_cross_objcopy:=${container_cross_prefix}objcopy}
206487eb014cSPaolo Bonzini    : ${container_cross_ranlib:=${container_cross_prefix}ranlib}
206587eb014cSPaolo Bonzini    : ${container_cross_strip:=${container_cross_prefix}strip}
2066cd362defSPaolo Bonzini  done
2067cd362defSPaolo Bonzini
206892e288fcSPaolo Bonzini  try=cross
206992e288fcSPaolo Bonzini  case "$target_arch:$cpu" in
207092e288fcSPaolo Bonzini    aarch64_be:aarch64 | \
207192e288fcSPaolo Bonzini    armeb:arm | \
207292e288fcSPaolo Bonzini    i386:x86_64 | \
207392e288fcSPaolo Bonzini    mips*:mips64 | \
207492e288fcSPaolo Bonzini    ppc*:ppc64 | \
207592e288fcSPaolo Bonzini    sparc:sparc64 | \
207692e288fcSPaolo Bonzini    "$cpu:$cpu")
207792e288fcSPaolo Bonzini      try='native cross' ;;
207892e288fcSPaolo Bonzini  esac
207952f08deaSPaolo Bonzini  eval "target_cflags=\${cross_cc_cflags_$target_arch}"
2080*b3b5472dSPeter Maydell  for thistry in $try; do
2081*b3b5472dSPeter Maydell    case $thistry in
208292e288fcSPaolo Bonzini    native)
208392e288fcSPaolo Bonzini      target_cc=$cc
208492e288fcSPaolo Bonzini      target_ccas=$ccas
208592e288fcSPaolo Bonzini      target_ar=$ar
208692e288fcSPaolo Bonzini      target_as=$as
208792e288fcSPaolo Bonzini      target_ld=$ld
208892e288fcSPaolo Bonzini      target_nm=$nm
208992e288fcSPaolo Bonzini      target_objcopy=$objcopy
209092e288fcSPaolo Bonzini      target_ranlib=$ranlib
209192e288fcSPaolo Bonzini      target_strip=$strip
209292e288fcSPaolo Bonzini      ;;
209392e288fcSPaolo Bonzini    cross)
209492e288fcSPaolo Bonzini      target_cc=
209552f08deaSPaolo Bonzini      if eval test -n "\"\${cross_cc_$target_arch}\""; then
209652f08deaSPaolo Bonzini        if eval has "\"\${cross_cc_$target_arch}\""; then
209752f08deaSPaolo Bonzini          eval "target_cc=\"\${cross_cc_$target_arch}\""
2098cd362defSPaolo Bonzini        fi
20995adb43beSPaolo Bonzini      else
210052f08deaSPaolo Bonzini        compute_target_variable $target_arch target_cc gcc
2101cd362defSPaolo Bonzini      fi
210287eb014cSPaolo Bonzini      target_ccas=$target_cc
210352f08deaSPaolo Bonzini      compute_target_variable $target_arch target_ar ar
210452f08deaSPaolo Bonzini      compute_target_variable $target_arch target_as as
210552f08deaSPaolo Bonzini      compute_target_variable $target_arch target_ld ld
210652f08deaSPaolo Bonzini      compute_target_variable $target_arch target_nm nm
210752f08deaSPaolo Bonzini      compute_target_variable $target_arch target_objcopy objcopy
210852f08deaSPaolo Bonzini      compute_target_variable $target_arch target_ranlib ranlib
210952f08deaSPaolo Bonzini      compute_target_variable $target_arch target_strip strip
2110640aabc8SPaolo Bonzini      ;;
2111640aabc8SPaolo Bonzini    esac
211292e288fcSPaolo Bonzini
21132ad60f6fSPaolo Bonzini    if test -n "$target_cc"; then
211452f08deaSPaolo Bonzini      case $target_arch in
21152ad60f6fSPaolo Bonzini        i386|x86_64)
21162ad60f6fSPaolo Bonzini          if $target_cc --version | grep -qi "clang"; then
211792e288fcSPaolo Bonzini            continue
21182ad60f6fSPaolo Bonzini          fi
21192ad60f6fSPaolo Bonzini          ;;
21202ad60f6fSPaolo Bonzini      esac
212192e288fcSPaolo Bonzini    elif test -n "$target_as" && test -n "$target_ld"; then
212292e288fcSPaolo Bonzini      # Special handling for assembler only targets
212392e288fcSPaolo Bonzini      case $target in
212492e288fcSPaolo Bonzini        tricore-softmmu)
212592e288fcSPaolo Bonzini          build_static=
212692e288fcSPaolo Bonzini          got_cross_cc=yes
212792e288fcSPaolo Bonzini          break
212892e288fcSPaolo Bonzini          ;;
212992e288fcSPaolo Bonzini        *)
213092e288fcSPaolo Bonzini          continue
213192e288fcSPaolo Bonzini          ;;
213292e288fcSPaolo Bonzini      esac
213392e288fcSPaolo Bonzini    else
213492e288fcSPaolo Bonzini      continue
213592e288fcSPaolo Bonzini    fi
213692e288fcSPaolo Bonzini
213792e288fcSPaolo Bonzini    write_c_skeleton
213892e288fcSPaolo Bonzini    case $1 in
213992e288fcSPaolo Bonzini      *-softmmu)
214092e288fcSPaolo Bonzini        if do_compiler "$target_cc" $target_cflags -o $TMPO -c $TMPC &&
214192e288fcSPaolo Bonzini          do_compiler "$target_cc" $target_cflags -r -nostdlib -o "${TMPDIR1}/${TMPB}2.o" "$TMPO" -lgcc; then
214292e288fcSPaolo Bonzini          got_cross_cc=yes
214392e288fcSPaolo Bonzini          break
214492e288fcSPaolo Bonzini        fi
214592e288fcSPaolo Bonzini        ;;
214692e288fcSPaolo Bonzini      *)
214792e288fcSPaolo Bonzini        if do_compiler "$target_cc" $target_cflags -o $TMPE $TMPC -static ; then
214892e288fcSPaolo Bonzini          build_static=y
214992e288fcSPaolo Bonzini          got_cross_cc=yes
215092e288fcSPaolo Bonzini          break
215192e288fcSPaolo Bonzini        fi
215292e288fcSPaolo Bonzini        if do_compiler "$target_cc" $target_cflags -o $TMPE $TMPC ; then
215392e288fcSPaolo Bonzini          build_static=
215492e288fcSPaolo Bonzini          got_cross_cc=yes
215592e288fcSPaolo Bonzini          break
215692e288fcSPaolo Bonzini        fi
215792e288fcSPaolo Bonzini        ;;
215892e288fcSPaolo Bonzini    esac
215992e288fcSPaolo Bonzini  done
216092e288fcSPaolo Bonzini  if test $got_cross_cc != yes; then
216192e288fcSPaolo Bonzini    build_static=
216292e288fcSPaolo Bonzini    target_cc=
216392e288fcSPaolo Bonzini    target_ccas=
216492e288fcSPaolo Bonzini    target_ar=
216592e288fcSPaolo Bonzini    target_as=
216692e288fcSPaolo Bonzini    target_ld=
216792e288fcSPaolo Bonzini    target_nm=
216892e288fcSPaolo Bonzini    target_objcopy=
216992e288fcSPaolo Bonzini    target_ranlib=
217092e288fcSPaolo Bonzini    target_strip=
21712ad60f6fSPaolo Bonzini  fi
2172cd362defSPaolo Bonzini}
2173cd362defSPaolo Bonzini
2174cd362defSPaolo Bonziniwrite_target_makefile() {
2175e81785abSPaolo Bonzini  echo "EXTRA_CFLAGS=$target_cflags"
2176cd362defSPaolo Bonzini  if test -n "$target_cc"; then
2177cd362defSPaolo Bonzini    echo "CC=$target_cc"
217887eb014cSPaolo Bonzini    echo "CCAS=$target_ccas"
217987eb014cSPaolo Bonzini  fi
218087eb014cSPaolo Bonzini  if test -n "$target_ar"; then
218187eb014cSPaolo Bonzini    echo "AR=$target_ar"
2182cd362defSPaolo Bonzini  fi
2183cd362defSPaolo Bonzini  if test -n "$target_as"; then
2184cd362defSPaolo Bonzini    echo "AS=$target_as"
2185cd362defSPaolo Bonzini  fi
2186cd362defSPaolo Bonzini  if test -n "$target_ld"; then
2187cd362defSPaolo Bonzini    echo "LD=$target_ld"
2188cd362defSPaolo Bonzini  fi
218987eb014cSPaolo Bonzini  if test -n "$target_nm"; then
219087eb014cSPaolo Bonzini    echo "NM=$target_nm"
219187eb014cSPaolo Bonzini  fi
219287eb014cSPaolo Bonzini  if test -n "$target_objcopy"; then
219387eb014cSPaolo Bonzini    echo "OBJCOPY=$target_objcopy"
219487eb014cSPaolo Bonzini  fi
219587eb014cSPaolo Bonzini  if test -n "$target_ranlib"; then
219687eb014cSPaolo Bonzini    echo "RANLIB=$target_ranlib"
219787eb014cSPaolo Bonzini  fi
219887eb014cSPaolo Bonzini  if test -n "$target_strip"; then
219987eb014cSPaolo Bonzini    echo "STRIP=$target_strip"
220087eb014cSPaolo Bonzini  fi
2201cd362defSPaolo Bonzini}
2202cd362defSPaolo Bonzini
2203cd362defSPaolo Bonziniwrite_container_target_makefile() {
2204e81785abSPaolo Bonzini  echo "EXTRA_CFLAGS=$target_cflags"
2205cd362defSPaolo Bonzini  if test -n "$container_cross_cc"; then
2206cd362defSPaolo Bonzini    echo "CC=\$(DOCKER_SCRIPT) cc --cc $container_cross_cc -i qemu/$container_image -s $source_path --"
220787eb014cSPaolo Bonzini    echo "CCAS=\$(DOCKER_SCRIPT) cc --cc $container_cross_cc -i qemu/$container_image -s $source_path --"
2208cd362defSPaolo Bonzini  fi
220987eb014cSPaolo Bonzini  echo "AR=\$(DOCKER_SCRIPT) cc --cc $container_cross_ar -i qemu/$container_image -s $source_path --"
2210cd362defSPaolo Bonzini  echo "AS=\$(DOCKER_SCRIPT) cc --cc $container_cross_as -i qemu/$container_image -s $source_path --"
2211cd362defSPaolo Bonzini  echo "LD=\$(DOCKER_SCRIPT) cc --cc $container_cross_ld -i qemu/$container_image -s $source_path --"
221287eb014cSPaolo Bonzini  echo "NM=\$(DOCKER_SCRIPT) cc --cc $container_cross_nm -i qemu/$container_image -s $source_path --"
221387eb014cSPaolo Bonzini  echo "OBJCOPY=\$(DOCKER_SCRIPT) cc --cc $container_cross_objcopy -i qemu/$container_image -s $source_path --"
221487eb014cSPaolo Bonzini  echo "RANLIB=\$(DOCKER_SCRIPT) cc --cc $container_cross_ranlib -i qemu/$container_image -s $source_path --"
221587eb014cSPaolo Bonzini  echo "STRIP=\$(DOCKER_SCRIPT) cc --cc $container_cross_strip -i qemu/$container_image -s $source_path --"
2216cd362defSPaolo Bonzini}
2217cd362defSPaolo Bonzini
2218cd362defSPaolo Bonzini
2219cd362defSPaolo Bonzini
2220cd362defSPaolo Bonzini##########################################
222155116968SJagannathan Raman# check for vfio_user_server
222255116968SJagannathan Raman
222355116968SJagannathan Ramancase "$vfio_user_server" in
222455116968SJagannathan Raman  enabled )
222555116968SJagannathan Raman    if test "$git_submodules_action" != "ignore"; then
222655116968SJagannathan Raman      git_submodules="${git_submodules} subprojects/libvfio-user"
222755116968SJagannathan Raman    fi
222855116968SJagannathan Raman    ;;
222955116968SJagannathan Ramanesac
223055116968SJagannathan Raman
223155116968SJagannathan Raman##########################################
2232e86ecd4bSJuan Quintela# End of CC checks
2233e86ecd4bSJuan Quintela# After here, no more $cc or $ld runs
2234e86ecd4bSJuan Quintela
2235d83414e1SMarc-André Lureauwrite_c_skeleton
2236d83414e1SMarc-André Lureau
2237df42fa7dSPaolo Bonziniif test "$fortify_source" = "yes" ; then
2238086d5f75SPaolo Bonzini  QEMU_CFLAGS="-U_FORTIFY_SOURCE -D_FORTIFY_SOURCE=2 $QEMU_CFLAGS"
2239086d5f75SPaolo Bonzinifi
2240086d5f75SPaolo Bonzini
2241247724cbSMarc-André Lureauif test "$have_asan" = "yes"; then
2242db5adeaaSPaolo Bonzini  QEMU_CFLAGS="-fsanitize=address $QEMU_CFLAGS"
2243db5adeaaSPaolo Bonzini  QEMU_LDFLAGS="-fsanitize=address $QEMU_LDFLAGS"
2244d83414e1SMarc-André Lureau  if test "$have_asan_iface_h" = "no" ; then
2245d83414e1SMarc-André Lureau      echo "ASAN build enabled, but ASAN header missing." \
2246d83414e1SMarc-André Lureau           "Without code annotation, the report may be inferior."
2247d83414e1SMarc-André Lureau  elif test "$have_asan_iface_fiber" = "no" ; then
2248d83414e1SMarc-André Lureau      echo "ASAN build enabled, but ASAN header is too old." \
2249d83414e1SMarc-André Lureau           "Without code annotation, the report may be inferior."
2250d83414e1SMarc-André Lureau  fi
2251247724cbSMarc-André Lureaufi
22520aebab04SLingfeng Yangif test "$have_tsan" = "yes" ; then
22530aebab04SLingfeng Yang  if test "$have_tsan_iface_fiber" = "yes" ; then
22540aebab04SLingfeng Yang    QEMU_CFLAGS="-fsanitize=thread $QEMU_CFLAGS"
22550aebab04SLingfeng Yang    QEMU_LDFLAGS="-fsanitize=thread $QEMU_LDFLAGS"
22560aebab04SLingfeng Yang  else
22570aebab04SLingfeng Yang    error_exit "Cannot enable TSAN due to missing fiber annotation interface."
22580aebab04SLingfeng Yang  fi
22590aebab04SLingfeng Yangelif test "$tsan" = "yes" ; then
22600aebab04SLingfeng Yang  error_exit "Cannot enable TSAN due to missing sanitize thread interface."
22610aebab04SLingfeng Yangfi
2262247724cbSMarc-André Lureauif test "$have_ubsan" = "yes"; then
2263db5adeaaSPaolo Bonzini  QEMU_CFLAGS="-fsanitize=undefined $QEMU_CFLAGS"
2264db5adeaaSPaolo Bonzini  QEMU_LDFLAGS="-fsanitize=undefined $QEMU_LDFLAGS"
2265247724cbSMarc-André Lureaufi
2266247724cbSMarc-André Lureau
22676542aa9cSPeter Lieven##########################################
22683efac6ebSTomáš Golembiovský
22690aebab04SLingfeng Yang# Exclude --warn-common with TSan to suppress warnings from the TSan libraries.
22700aebab04SLingfeng Yangif test "$solaris" = "no" && test "$tsan" = "no"; then
2271e86ecd4bSJuan Quintela    if $ld --version 2>/dev/null | grep "GNU ld" >/dev/null 2>/dev/null ; then
2272db5adeaaSPaolo Bonzini        QEMU_LDFLAGS="-Wl,--warn-common $QEMU_LDFLAGS"
2273e86ecd4bSJuan Quintela    fi
2274e86ecd4bSJuan Quintelafi
2275e86ecd4bSJuan Quintela
2276b846ab7cSPaolo Bonzini# Guest agent Windows MSI package
22779d6bc27bSMichael Roth
22789d6bc27bSMichael Rothif test "$QEMU_GA_MANUFACTURER" = ""; then
22799d6bc27bSMichael Roth  QEMU_GA_MANUFACTURER=QEMU
22809d6bc27bSMichael Rothfi
22819d6bc27bSMichael Rothif test "$QEMU_GA_DISTRO" = ""; then
22829d6bc27bSMichael Roth  QEMU_GA_DISTRO=Linux
22839d6bc27bSMichael Rothfi
22849d6bc27bSMichael Rothif test "$QEMU_GA_VERSION" = ""; then
228564708615SPeter Maydell    QEMU_GA_VERSION=$(cat "$source_path"/VERSION)
22869d6bc27bSMichael Rothfi
22879d6bc27bSMichael Roth
228833ab4787SPaolo Bonzini
228933ab4787SPaolo Bonzini#######################################
229033ab4787SPaolo Bonzini# cross-compiled firmware targets
229133ab4787SPaolo Bonzini
2292ad388845SPaolo Bonzini# Set up build tree symlinks that point back into the source tree
2293ad388845SPaolo Bonzini# (these can be both files and directories).
2294ad388845SPaolo Bonzini# Caution: avoid adding files or directories here using wildcards. This
2295ad388845SPaolo Bonzini# will result in problems later if a new file matching the wildcard is
2296ad388845SPaolo Bonzini# added to the source tree -- nothing will cause configure to be rerun
2297ad388845SPaolo Bonzini# so the build tree will be missing the link back to the new file, and
2298ad388845SPaolo Bonzini# tests might fail. Prefer to keep the relevant files in their own
2299ad388845SPaolo Bonzini# directory and symlink the directory instead.
2300ad388845SPaolo BonziniLINKS="Makefile"
2301ad388845SPaolo BonziniLINKS="$LINKS tests/tcg/Makefile.target"
2302ad388845SPaolo BonziniLINKS="$LINKS pc-bios/optionrom/Makefile"
2303ad388845SPaolo BonziniLINKS="$LINKS pc-bios/s390-ccw/Makefile"
2304d695918fSPaolo BonziniLINKS="$LINKS pc-bios/vof/Makefile"
2305ad388845SPaolo BonziniLINKS="$LINKS .gdbinit scripts" # scripts needed by relative path in .gdbinit
2306ad388845SPaolo BonziniLINKS="$LINKS tests/avocado tests/data"
2307ad388845SPaolo BonziniLINKS="$LINKS tests/qemu-iotests/check"
2308ad388845SPaolo BonziniLINKS="$LINKS python"
2309ad388845SPaolo BonziniLINKS="$LINKS contrib/plugins/Makefile "
2310ad388845SPaolo Bonzinifor f in $LINKS ; do
2311ad388845SPaolo Bonzini    if [ -e "$source_path/$f" ]; then
2312cc3c71e8SPeter Maydell        mkdir -p "$(dirname ./"$f")"
2313ad388845SPaolo Bonzini        symlink "$source_path/$f" "$f"
2314ad388845SPaolo Bonzini    fi
2315ad388845SPaolo Bonzinidone
2316ad388845SPaolo Bonzini
2317ca35f780SPaolo Bonzini# Mac OS X ships with a broken assembler
2318ca35f780SPaolo Bonziniroms=
231952f08deaSPaolo Bonziniprobe_target_compiler i386-softmmu
232033ab4787SPaolo Bonziniif test -n "$target_cc" &&
2321ba7c60c2SPaolo Bonzini        test "$targetos" != "darwin" && test "$targetos" != "sunos" && \
2322ba7c60c2SPaolo Bonzini        test "$targetos" != "haiku" && test "$softmmu" = yes ; then
2323e57218b6SPeter Maydell    # Different host OS linkers have different ideas about the name of the ELF
2324c65d5e4eSBrad Smith    # emulation. Linux and OpenBSD/amd64 use 'elf_i386'; FreeBSD uses the _fbsd
2325c65d5e4eSBrad Smith    # variant; OpenBSD/i386 uses the _obsd variant; and Windows uses i386pe.
2326c65d5e4eSBrad Smith    for emu in elf_i386 elf_i386_fbsd elf_i386_obsd i386pe; do
2327d466d416SPeter Maydell        if "$target_ld" -verbose 2>&1 | grep -q "^[[:space:]]*${emu}[[:space:]]*$"; then
2328e57218b6SPeter Maydell            ld_i386_emulation="$emu"
2329e57218b6SPeter Maydell            break
2330e57218b6SPeter Maydell        fi
2331e57218b6SPeter Maydell    done
233233ab4787SPaolo Bonzini    if test -n "$ld_i386_emulation"; then
233376ca98b0SPaolo Bonzini        roms="pc-bios/optionrom"
233433ab4787SPaolo Bonzini        config_mak=pc-bios/optionrom/config.mak
233533ab4787SPaolo Bonzini        echo "# Automatically generated by configure - do not modify" > $config_mak
233633ab4787SPaolo Bonzini        echo "TOPSRC_DIR=$source_path" >> $config_mak
233733ab4787SPaolo Bonzini        echo "LD_I386_EMULATION=$ld_i386_emulation" >> $config_mak
233833ab4787SPaolo Bonzini        write_target_makefile >> $config_mak
233933ab4787SPaolo Bonzini    fi
2340ca35f780SPaolo Bonzinifi
2341ca35f780SPaolo Bonzini
234252f08deaSPaolo Bonziniprobe_target_compiler ppc-softmmu
2343d695918fSPaolo Bonziniif test -n "$target_cc" && test "$softmmu" = yes; then
234476ca98b0SPaolo Bonzini    roms="$roms pc-bios/vof"
2345d695918fSPaolo Bonzini    config_mak=pc-bios/vof/config.mak
2346d695918fSPaolo Bonzini    echo "# Automatically generated by configure - do not modify" > $config_mak
2347d695918fSPaolo Bonzini    echo "SRC_DIR=$source_path/pc-bios/vof" >> $config_mak
2348d695918fSPaolo Bonzini    write_target_makefile >> $config_mak
2349d695918fSPaolo Bonzinifi
2350d695918fSPaolo Bonzini
23519ffed426SPaolo Bonzini# Only build s390-ccw bios if the compiler has -march=z900 or -march=z10
23529ffed426SPaolo Bonzini# (which is the lowest architecture level that Clang supports)
235352f08deaSPaolo Bonziniprobe_target_compiler s390x-softmmu
23549ffed426SPaolo Bonziniif test -n "$target_cc" && test "$softmmu" = yes; then
23552e33c3f8SThomas Huth  write_c_skeleton
23569ffed426SPaolo Bonzini  do_compiler "$target_cc" $target_cc_cflags -march=z900 -o $TMPO -c $TMPC
2357a5b2afd5SThomas Huth  has_z900=$?
23589ffed426SPaolo Bonzini  if [ $has_z900 = 0 ] || do_compiler "$target_cc" $target_cc_cflags -march=z10 -msoft-float -Werror -o $TMPO -c $TMPC; then
2359a5b2afd5SThomas Huth    if [ $has_z900 != 0 ]; then
2360a5b2afd5SThomas Huth      echo "WARNING: Your compiler does not support the z900!"
2361a5b2afd5SThomas Huth      echo "         The s390-ccw bios will only work with guest CPUs >= z10."
2362a5b2afd5SThomas Huth    fi
236376ca98b0SPaolo Bonzini    roms="$roms pc-bios/s390-ccw"
23649ffed426SPaolo Bonzini    config_mak=pc-bios/s390-ccw/config-host.mak
23659ffed426SPaolo Bonzini    echo "# Automatically generated by configure - do not modify" > $config_mak
23669ffed426SPaolo Bonzini    echo "SRC_PATH=$source_path/pc-bios/s390-ccw" >> $config_mak
23679ffed426SPaolo Bonzini    write_target_makefile >> $config_mak
23681ef6bfc2SPhilippe Mathieu-Daudé    # SLOF is required for building the s390-ccw firmware on s390x,
23691ef6bfc2SPhilippe Mathieu-Daudé    # since it is using the libnet code from SLOF for network booting.
23701ef6bfc2SPhilippe Mathieu-Daudé    git_submodules="${git_submodules} roms/SLOF"
23711ef6bfc2SPhilippe Mathieu-Daudé  fi
23729933c305SChristian Borntraegerfi
23739933c305SChristian Borntraeger
23749ffed426SPaolo Bonzini#######################################
23759ffed426SPaolo Bonzini# generate config-host.mak
23769ffed426SPaolo Bonzini
237711cde1c8SBruno Dominguez# Check that the C++ compiler exists and works with the C compiler.
237811cde1c8SBruno 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.
237911cde1c8SBruno Dominguezif has $cxx; then
238011cde1c8SBruno Dominguez    cat > $TMPC <<EOF
238111cde1c8SBruno Dominguezint c_function(void);
238211cde1c8SBruno Dominguezint main(void) { return c_function(); }
238311cde1c8SBruno DominguezEOF
238411cde1c8SBruno Dominguez
238511cde1c8SBruno Dominguez    compile_object
238611cde1c8SBruno Dominguez
238711cde1c8SBruno Dominguez    cat > $TMPCXX <<EOF
238811cde1c8SBruno Dominguezextern "C" {
238911cde1c8SBruno Dominguez   int c_function(void);
239011cde1c8SBruno Dominguez}
239111cde1c8SBruno Dominguezint c_function(void) { return 42; }
239211cde1c8SBruno DominguezEOF
239311cde1c8SBruno Dominguez
239411cde1c8SBruno Dominguez    update_cxxflags
239511cde1c8SBruno Dominguez
2396a2866660SPaolo Bonzini    if do_cxx $CXXFLAGS $EXTRA_CXXFLAGS $CONFIGURE_CXXFLAGS $QEMU_CXXFLAGS -o $TMPE $TMPCXX $TMPO $QEMU_LDFLAGS; then
239711cde1c8SBruno Dominguez        # C++ compiler $cxx works ok with C compiler $cc
239811cde1c8SBruno Dominguez        :
239911cde1c8SBruno Dominguez    else
240011cde1c8SBruno Dominguez        echo "C++ compiler $cxx does not work with C compiler $cc"
240111cde1c8SBruno Dominguez        echo "Disabling C++ specific optional code"
240211cde1c8SBruno Dominguez        cxx=
240311cde1c8SBruno Dominguez    fi
240411cde1c8SBruno Dominguezelse
240511cde1c8SBruno Dominguez    echo "No C++ compiler available; disabling C++ specific optional code"
240611cde1c8SBruno Dominguez    cxx=
240711cde1c8SBruno Dominguezfi
240811cde1c8SBruno Dominguez
24097d7dbf9dSDan Streetmanif ! (GIT="$git" "$source_path/scripts/git-submodule.sh" "$git_submodules_action" "$git_submodules"); then
24107d7dbf9dSDan Streetman    exit 1
24115d91a2edSYonggang Luofi
24125d91a2edSYonggang Luo
241398ec69acSJuan Quintelaconfig_host_mak="config-host.mak"
241497a847bcSbellard
241598ec69acSJuan Quintelaecho "# Automatically generated by configure - do not modify" > $config_host_mak
241698ec69acSJuan Quintelaecho >> $config_host_mak
241798ec69acSJuan Quintela
2418e6c3b0f7SPaolo Bonziniecho all: >> $config_host_mak
2419cc84d63aSDaniel P. Berrangeecho "GIT=$git" >> $config_host_mak
2420aef45d51SDaniel P. Berrangeecho "GIT_SUBMODULES=$git_submodules" >> $config_host_mak
24217d7dbf9dSDan Streetmanecho "GIT_SUBMODULES_ACTION=$git_submodules_action" >> $config_host_mak
2422804edf29SJuan Quintela
2423f8393946Saurel32if test "$debug_tcg" = "yes" ; then
24242358a494SJuan Quintela  echo "CONFIG_DEBUG_TCG=y" >> $config_host_mak
2425f8393946Saurel32fi
242667b915a5Sbellardif test "$mingw32" = "yes" ; then
242798ec69acSJuan Quintela  echo "CONFIG_WIN32=y" >> $config_host_mak
24289dacf32dSYossi Hindin  echo "QEMU_GA_MANUFACTURER=${QEMU_GA_MANUFACTURER}" >> $config_host_mak
24299dacf32dSYossi Hindin  echo "QEMU_GA_DISTRO=${QEMU_GA_DISTRO}" >> $config_host_mak
24309dacf32dSYossi Hindin  echo "QEMU_GA_VERSION=${QEMU_GA_VERSION}" >> $config_host_mak
2431210fa556Spbrookelse
243235f4df27SJuan Quintela  echo "CONFIG_POSIX=y" >> $config_host_mak
2433210fa556Spbrookfi
2434128ab2ffSblueswir1
2435dffcb71cSMark McLoughlinif test "$linux" = "yes" ; then
2436dffcb71cSMark McLoughlin  echo "CONFIG_LINUX=y" >> $config_host_mak
2437dffcb71cSMark McLoughlinfi
2438dffcb71cSMark McLoughlin
243983fb7adfSbellardif test "$darwin" = "yes" ; then
244098ec69acSJuan Quintela  echo "CONFIG_DARWIN=y" >> $config_host_mak
244183fb7adfSbellardfi
2442b29fe3edSmalc
2443ec530c81Sbellardif test "$solaris" = "yes" ; then
244498ec69acSJuan Quintela  echo "CONFIG_SOLARIS=y" >> $config_host_mak
2445ec530c81Sbellardfi
244697a847bcSbellardif test "$static" = "yes" ; then
244798ec69acSJuan Quintela  echo "CONFIG_STATIC=y" >> $config_host_mak
244897a847bcSbellardfi
244998ec69acSJuan Quintelaecho "SRC_PATH=$source_path" >> $config_host_mak
24502b1f35b9SAlex Bennéeecho "TARGET_DIRS=$target_list" >> $config_host_mak
245117969268SFam Zhengif test "$modules" = "yes"; then
245217969268SFam Zheng  echo "CONFIG_MODULES=y" >> $config_host_mak
245317969268SFam Zhengfi
2454277abf15SJan Vesely
245583fb7adfSbellard# XXX: suppress that
24567d3505c5Sbellardif [ "$bsd" = "yes" ] ; then
24572358a494SJuan Quintela  echo "CONFIG_BSD=y" >> $config_host_mak
24587d3505c5Sbellardfi
24597d3505c5Sbellard
24607c2acc70SPeter Maydellecho "CONFIG_COROUTINE_BACKEND=$coroutine" >> $config_host_mak
24617d992e4dSPeter Lieven
2462d83414e1SMarc-André Lureauif test "$have_asan_iface_fiber" = "yes" ; then
2463d83414e1SMarc-André Lureau    echo "CONFIG_ASAN_IFACE_FIBER=y" >> $config_host_mak
2464d83414e1SMarc-André Lureaufi
2465d83414e1SMarc-André Lureau
24660aebab04SLingfeng Yangif test "$have_tsan" = "yes" && test "$have_tsan_iface_fiber" = "yes" ; then
24670aebab04SLingfeng Yang    echo "CONFIG_TSAN=y" >> $config_host_mak
24680aebab04SLingfeng Yangfi
24690aebab04SLingfeng Yang
247040e8c6f4SAlex Bennéeif test "$plugins" = "yes" ; then
247140e8c6f4SAlex Bennée    echo "CONFIG_PLUGIN=y" >> $config_host_mak
247240e8c6f4SAlex Bennéefi
247340e8c6f4SAlex Bennée
2474f48e590aSAlex Bennéeif test -n "$gdb_bin"; then
2475b1863cccSAlex Bennée    gdb_version=$($gdb_bin --version | head -n 1)
2476d6a66c81SAlex Bennée    if version_ge ${gdb_version##* } 9.1; then
2477f48e590aSAlex Bennée        echo "HAVE_GDB_BIN=$gdb_bin" >> $config_host_mak
2478f48e590aSAlex Bennée    fi
2479b1863cccSAlex Bennéefi
2480f48e590aSAlex Bennée
248198ec69acSJuan Quintelaecho "ROMS=$roms" >> $config_host_mak
2482804edf29SJuan Quintelaecho "MAKE=$make" >> $config_host_mak
2483c886edfbSBlue Swirlecho "PYTHON=$python" >> $config_host_mak
248439d87c8cSAlex Bennéeecho "GENISOIMAGE=$genisoimage" >> $config_host_mak
2485a5665051SPaolo Bonziniecho "MESON=$meson" >> $config_host_mak
248609e93326SPaolo Bonziniecho "NINJA=$ninja" >> $config_host_mak
2487804edf29SJuan Quintelaecho "CC=$cc" >> $config_host_mak
2488a558ee17SJuan Quintelaecho "QEMU_CFLAGS=$QEMU_CFLAGS" >> $config_host_mak
248911cde1c8SBruno Dominguezecho "QEMU_CXXFLAGS=$QEMU_CXXFLAGS" >> $config_host_mak
24904cb37d11SPhilippe Mathieu-Daudéecho "QEMU_OBJCFLAGS=$QEMU_OBJCFLAGS" >> $config_host_mak
2491a81df1b6SPaolo Bonziniecho "GLIB_CFLAGS=$glib_cflags" >> $config_host_mak
2492a81df1b6SPaolo Bonziniecho "GLIB_LIBS=$glib_libs" >> $config_host_mak
24935b9e7d05SMarc-André Lureauecho "GLIB_BINDIR=$glib_bindir" >> $config_host_mak
2494d83acfd0SMarc-André Lureauecho "GLIB_VERSION=$(pkg-config --modversion glib-2.0)" >> $config_host_mak
24958a99e9a3SPhilippe Mathieu-Daudéecho "QEMU_LDFLAGS=$QEMU_LDFLAGS" >> $config_host_mak
2496804edf29SJuan Quintelaecho "EXESUF=$EXESUF" >> $config_host_mak
2497804edf29SJuan Quintela
24986efd7517SPeter Maydell# use included Linux headers
24996efd7517SPeter Maydellif test "$linux" = "yes" ; then
2500a307beb6SAndreas Färber  mkdir -p linux-headers
25016efd7517SPeter Maydell  case "$cpu" in
25024da270beSPaolo Bonzini  i386|x86_64)
250308312a63SPeter Maydell    linux_arch=x86
25046efd7517SPeter Maydell    ;;
2505d8ff892dSPaolo Bonzini  ppc|ppc64)
250608312a63SPeter Maydell    linux_arch=powerpc
25076efd7517SPeter Maydell    ;;
25086efd7517SPeter Maydell  s390x)
250908312a63SPeter Maydell    linux_arch=s390
251008312a63SPeter Maydell    ;;
25111f080313SClaudio Fontana  aarch64)
25121f080313SClaudio Fontana    linux_arch=arm64
25131f080313SClaudio Fontana    ;;
2514dfcf900bSWANG Xuerui  loongarch*)
2515dfcf900bSWANG Xuerui    linux_arch=loongarch
2516dfcf900bSWANG Xuerui    ;;
2517222e7d11SSanjay Lal  mips64)
2518222e7d11SSanjay Lal    linux_arch=mips
2519222e7d11SSanjay Lal    ;;
252008312a63SPeter Maydell  *)
252108312a63SPeter Maydell    # For most CPUs the kernel architecture name and QEMU CPU name match.
252208312a63SPeter Maydell    linux_arch="$cpu"
25236efd7517SPeter Maydell    ;;
25246efd7517SPeter Maydell  esac
252508312a63SPeter Maydell    # For non-KVM architectures we will not have asm headers
252608312a63SPeter Maydell    if [ -e "$source_path/linux-headers/asm-$linux_arch" ]; then
252708312a63SPeter Maydell      symlink "$source_path/linux-headers/asm-$linux_arch" linux-headers/asm
252808312a63SPeter Maydell    fi
25296efd7517SPeter Maydellfi
25306efd7517SPeter Maydell
253197a847bcSbellardfor target in $target_list; do
253297a847bcSbellard    target_dir="$target"
253357a93f16SPhilippe Mathieu-Daudé    target_name=$(echo $target | cut -d '-' -f 1)$EXESUF
253464708615SPeter Maydell    mkdir -p "$target_dir"
2535fdb75aefSPaolo Bonzini    case $target in
2536fdb75aefSPaolo Bonzini        *-user) symlink "../qemu-$target_name" "$target_dir/qemu-$target_name" ;;
2537fdb75aefSPaolo Bonzini        *) symlink "../qemu-system-$target_name" "$target_dir/qemu-system-$target_name" ;;
25382408a527Saurel32    esac
253956aebc89Spbrookdone
25407d13299dSbellard
2541fdb75aefSPaolo Bonziniif test "$default_targets" = "yes"; then
2542fdb75aefSPaolo Bonzini  echo "CONFIG_DEFAULT_TARGETS=y" >> $config_host_mak
2543fdb75aefSPaolo Bonzinifi
2544a540f158SPeter Crosthwaite
2545fd0e6053SJohn Snowif test "$ccache_cpp2" = "yes"; then
2546fd0e6053SJohn Snow  echo "export CCACHE_CPP2=y" >> $config_host_mak
2547fd0e6053SJohn Snowfi
2548fd0e6053SJohn Snow
25491e4f6065SDaniele Buonoif test "$safe_stack" = "yes"; then
25501e4f6065SDaniele Buono  echo "CONFIG_SAFESTACK=y" >> $config_host_mak
25511e4f6065SDaniele Buonofi
25521e4f6065SDaniele Buono
2553cd362defSPaolo Bonzini# tests/tcg configuration
2554cd362defSPaolo Bonzini(makefile=tests/tcg/Makefile.prereqs
2555cd362defSPaolo Bonziniecho "# Automatically generated by configure - do not modify" > $makefile
2556cd362defSPaolo Bonzini
2557cd362defSPaolo Bonziniconfig_host_mak=tests/tcg/config-host.mak
2558cd362defSPaolo Bonziniecho "# Automatically generated by configure - do not modify" > $config_host_mak
2559cd362defSPaolo Bonziniecho "SRC_PATH=$source_path" >> $config_host_mak
2560cd362defSPaolo Bonziniecho "HOST_CC=$host_cc" >> $config_host_mak
2561cd362defSPaolo Bonzini
2562cd362defSPaolo Bonzinitcg_tests_targets=
2563cd362defSPaolo Bonzinifor target in $target_list; do
2564cd362defSPaolo Bonzini  arch=${target%%-*}
2565cd362defSPaolo Bonzini
2566cd362defSPaolo Bonzini  config_target_mak=tests/tcg/config-$target.mak
2567cd362defSPaolo Bonzini
2568cd362defSPaolo Bonzini  echo "# Automatically generated by configure - do not modify" > $config_target_mak
256964708615SPeter Maydell  echo "TARGET_NAME=$arch" >> "$config_target_mak"
2570cd362defSPaolo Bonzini  case $target in
2571c48a5c47SPaolo Bonzini    xtensa*-linux-user)
2572c48a5c47SPaolo Bonzini      # the toolchain is not complete with headers, only build softmmu tests
2573c48a5c47SPaolo Bonzini      continue
2574c48a5c47SPaolo Bonzini      ;;
2575cd362defSPaolo Bonzini    *-softmmu)
257664708615SPeter Maydell      test -f "$source_path/tests/tcg/$arch/Makefile.softmmu-target" || continue
2577cd362defSPaolo Bonzini      qemu="qemu-system-$arch"
2578cd362defSPaolo Bonzini      ;;
2579cd362defSPaolo Bonzini    *-linux-user|*-bsd-user)
2580cd362defSPaolo Bonzini      qemu="qemu-$arch"
2581cd362defSPaolo Bonzini      ;;
2582cd362defSPaolo Bonzini  esac
2583cd362defSPaolo Bonzini
258452f08deaSPaolo Bonzini  probe_target_compiler $target
2585cd362defSPaolo Bonzini  if test $got_cross_cc = yes; then
2586cd362defSPaolo Bonzini      # Test for compiler features for optional tests. We only do this
2587cd362defSPaolo Bonzini      # for cross compilers because ensuring the docker containers based
2588cd362defSPaolo Bonzini      # compilers is a requirememt for adding a new test that needs a
2589cd362defSPaolo Bonzini      # compiler feature.
2590cd362defSPaolo Bonzini
259164708615SPeter Maydell      echo "BUILD_STATIC=$build_static" >> "$config_target_mak"
259264708615SPeter Maydell      write_target_makefile >> "$config_target_mak"
2593cd362defSPaolo Bonzini      case $target in
2594cd362defSPaolo Bonzini          aarch64-*)
2595cd362defSPaolo Bonzini              if do_compiler "$target_cc" $target_cflags \
2596cd362defSPaolo Bonzini                             -march=armv8.1-a+sve -o $TMPE $TMPC; then
259764708615SPeter Maydell                  echo "CROSS_CC_HAS_SVE=y" >> "$config_target_mak"
2598cd362defSPaolo Bonzini              fi
2599cd362defSPaolo Bonzini              if do_compiler "$target_cc" $target_cflags \
2600cd362defSPaolo Bonzini                             -march=armv8.1-a+sve2 -o $TMPE $TMPC; then
260164708615SPeter Maydell                  echo "CROSS_CC_HAS_SVE2=y" >> "$config_target_mak"
2602cd362defSPaolo Bonzini              fi
2603cd362defSPaolo Bonzini              if do_compiler "$target_cc" $target_cflags \
2604cd362defSPaolo Bonzini                             -march=armv8.3-a -o $TMPE $TMPC; then
260564708615SPeter Maydell                  echo "CROSS_CC_HAS_ARMV8_3=y" >> "$config_target_mak"
2606cd362defSPaolo Bonzini              fi
2607cd362defSPaolo Bonzini              if do_compiler "$target_cc" $target_cflags \
2608cd362defSPaolo Bonzini                             -mbranch-protection=standard -o $TMPE $TMPC; then
260964708615SPeter Maydell                  echo "CROSS_CC_HAS_ARMV8_BTI=y" >> "$config_target_mak"
2610cd362defSPaolo Bonzini              fi
2611cd362defSPaolo Bonzini              if do_compiler "$target_cc" $target_cflags \
2612cd362defSPaolo Bonzini                             -march=armv8.5-a+memtag -o $TMPE $TMPC; then
261364708615SPeter Maydell                  echo "CROSS_CC_HAS_ARMV8_MTE=y" >> "$config_target_mak"
2614cd362defSPaolo Bonzini              fi
2615cd362defSPaolo Bonzini              ;;
2616cd362defSPaolo Bonzini          ppc*)
2617cd362defSPaolo Bonzini              if do_compiler "$target_cc" $target_cflags \
2618cd362defSPaolo Bonzini                             -mpower8-vector -o $TMPE $TMPC; then
261964708615SPeter Maydell                  echo "CROSS_CC_HAS_POWER8_VECTOR=y" >> "$config_target_mak"
2620cd362defSPaolo Bonzini              fi
2621cd362defSPaolo Bonzini              if do_compiler "$target_cc" $target_cflags \
2622cd362defSPaolo Bonzini                             -mpower10 -o $TMPE $TMPC; then
262364708615SPeter Maydell                  echo "CROSS_CC_HAS_POWER10=y" >> "$config_target_mak"
2624cd362defSPaolo Bonzini              fi
2625cd362defSPaolo Bonzini              ;;
2626cd362defSPaolo Bonzini          i386-linux-user)
2627cd362defSPaolo Bonzini              if do_compiler "$target_cc" $target_cflags \
2628cd362defSPaolo Bonzini                             -Werror -fno-pie -o $TMPE $TMPC; then
262964708615SPeter Maydell                  echo "CROSS_CC_HAS_I386_NOPIE=y" >> "$config_target_mak"
2630cd362defSPaolo Bonzini              fi
2631cd362defSPaolo Bonzini              ;;
2632cd362defSPaolo Bonzini      esac
2633cd362defSPaolo Bonzini  elif test -n "$container_image"; then
2634cd362defSPaolo Bonzini      echo "build-tcg-tests-$target: docker-image-$container_image" >> $makefile
263564708615SPeter Maydell      echo "BUILD_STATIC=y" >> "$config_target_mak"
263664708615SPeter Maydell      write_container_target_makefile >> "$config_target_mak"
2637cd362defSPaolo Bonzini      case $target in
2638cd362defSPaolo Bonzini          aarch64-*)
263964708615SPeter Maydell              echo "CROSS_CC_HAS_SVE=y" >> "$config_target_mak"
264064708615SPeter Maydell              echo "CROSS_CC_HAS_SVE2=y" >> "$config_target_mak"
264164708615SPeter Maydell              echo "CROSS_CC_HAS_ARMV8_3=y" >> "$config_target_mak"
264264708615SPeter Maydell              echo "CROSS_CC_HAS_ARMV8_BTI=y" >> "$config_target_mak"
264364708615SPeter Maydell              echo "CROSS_CC_HAS_ARMV8_MTE=y" >> "$config_target_mak"
2644cd362defSPaolo Bonzini              ;;
2645cd362defSPaolo Bonzini          ppc*)
264664708615SPeter Maydell              echo "CROSS_CC_HAS_POWER8_VECTOR=y" >> "$config_target_mak"
264764708615SPeter Maydell              echo "CROSS_CC_HAS_POWER10=y" >> "$config_target_mak"
2648cd362defSPaolo Bonzini              ;;
2649cd362defSPaolo Bonzini          i386-linux-user)
265064708615SPeter Maydell              echo "CROSS_CC_HAS_I386_NOPIE=y" >> "$config_target_mak"
2651cd362defSPaolo Bonzini              ;;
2652cd362defSPaolo Bonzini      esac
2653cd362defSPaolo Bonzini      got_cross_cc=yes
2654cd362defSPaolo Bonzini  fi
2655cd362defSPaolo Bonzini  if test $got_cross_cc = yes; then
2656cd362defSPaolo Bonzini      mkdir -p tests/tcg/$target
265764708615SPeter Maydell      echo "QEMU=$PWD/$qemu" >> "$config_target_mak"
2658cd362defSPaolo Bonzini      echo "run-tcg-tests-$target: $qemu\$(EXESUF)" >> $makefile
2659cd362defSPaolo Bonzini      tcg_tests_targets="$tcg_tests_targets $target"
2660cd362defSPaolo Bonzini  fi
26612038f8c8SPaolo Bonzinidone
2662cd362defSPaolo Bonziniecho "TCG_TESTS_TARGETS=$tcg_tests_targets" >> $makefile)
26632038f8c8SPaolo Bonzini
2664a5665051SPaolo Bonziniif test "$skip_meson" = no; then
2665fc929892SMarc-André Lureau  cross="config-meson.cross.new"
2666fc929892SMarc-André Lureau  meson_quote() {
2667ac7ebcc5SPaolo Bonzini    test $# = 0 && return
266847b30835SPaolo Bonzini    echo "'$(echo $* | sed "s/ /','/g")'"
2669fc929892SMarc-André Lureau  }
2670fc929892SMarc-André Lureau
2671fc929892SMarc-André Lureau  echo "# Automatically generated by configure - do not modify" > $cross
2672fc929892SMarc-André Lureau  echo "[properties]" >> $cross
2673d1d5e9eeSAlex Bennée
2674d1d5e9eeSAlex Bennée  # unroll any custom device configs
2675d1d5e9eeSAlex Bennée  for a in $device_archs; do
2676d1d5e9eeSAlex Bennée      eval "c=\$devices_${a}"
2677d1d5e9eeSAlex Bennée      echo "${a}-softmmu = '$c'" >> $cross
2678d1d5e9eeSAlex Bennée  done
2679d1d5e9eeSAlex Bennée
2680fc929892SMarc-André Lureau  test -z "$cxx" && echo "link_language = 'c'" >> $cross
268147b30835SPaolo Bonzini  echo "[built-in options]" >> $cross
2682a2866660SPaolo Bonzini  echo "c_args = [$(meson_quote $CFLAGS $EXTRA_CFLAGS)]" >> $cross
2683a2866660SPaolo Bonzini  echo "cpp_args = [$(meson_quote $CXXFLAGS $EXTRA_CXXFLAGS)]" >> $cross
2684e910c7d9SPhilippe Mathieu-Daudé  test -n "$objcc" && echo "objc_args = [$(meson_quote $OBJCFLAGS $EXTRA_OBJCFLAGS)]" >> $cross
2685a2866660SPaolo Bonzini  echo "c_link_args = [$(meson_quote $CFLAGS $LDFLAGS $EXTRA_CFLAGS $EXTRA_LDFLAGS)]" >> $cross
2686a2866660SPaolo Bonzini  echo "cpp_link_args = [$(meson_quote $CXXFLAGS $LDFLAGS $EXTRA_CXXFLAGS $EXTRA_LDFLAGS)]" >> $cross
2687fc929892SMarc-André Lureau  echo "[binaries]" >> $cross
26884dba2789SPaolo Bonzini  echo "c = [$(meson_quote $cc $CPU_CFLAGS)]" >> $cross
26894dba2789SPaolo Bonzini  test -n "$cxx" && echo "cpp = [$(meson_quote $cxx $CPU_CFLAGS)]" >> $cross
26904dba2789SPaolo Bonzini  test -n "$objcc" && echo "objc = [$(meson_quote $objcc $CPU_CFLAGS)]" >> $cross
269147b30835SPaolo Bonzini  echo "ar = [$(meson_quote $ar)]" >> $cross
269247b30835SPaolo Bonzini  echo "nm = [$(meson_quote $nm)]" >> $cross
269347b30835SPaolo Bonzini  echo "pkgconfig = [$(meson_quote $pkg_config_exe)]" >> $cross
269447b30835SPaolo Bonzini  echo "ranlib = [$(meson_quote $ranlib)]" >> $cross
2695e8178514SPaolo Bonzini  if has $sdl2_config; then
269647b30835SPaolo Bonzini    echo "sdl2-config = [$(meson_quote $sdl2_config)]" >> $cross
2697e8178514SPaolo Bonzini  fi
269847b30835SPaolo Bonzini  echo "strip = [$(meson_quote $strip)]" >> $cross
2699158bb224SKonstantin Kostiuk  echo "widl = [$(meson_quote $widl)]" >> $cross
270047b30835SPaolo Bonzini  echo "windres = [$(meson_quote $windres)]" >> $cross
27013812c0c4SJoelle van Dyne  if test "$cross_compile" = "yes"; then
2702fc929892SMarc-André Lureau    cross_arg="--cross-file config-meson.cross"
2703fc929892SMarc-André Lureau    echo "[host_machine]" >> $cross
2704ba7c60c2SPaolo Bonzini    echo "system = '$targetos'" >> $cross
2705823eb013SPaolo Bonzini    case "$cpu" in
2706f6bca9dfSJoelle van Dyne        i386)
2707fc929892SMarc-André Lureau            echo "cpu_family = 'x86'" >> $cross
2708fc929892SMarc-André Lureau            ;;
2709fc929892SMarc-André Lureau        *)
2710823eb013SPaolo Bonzini            echo "cpu_family = '$cpu'" >> $cross
2711fc929892SMarc-André Lureau            ;;
2712fc929892SMarc-André Lureau    esac
2713fc929892SMarc-André Lureau    echo "cpu = '$cpu'" >> $cross
2714fc929892SMarc-André Lureau    if test "$bigendian" = "yes" ; then
2715fc929892SMarc-André Lureau        echo "endian = 'big'" >> $cross
2716fc929892SMarc-André Lureau    else
2717fc929892SMarc-André Lureau        echo "endian = 'little'" >> $cross
2718fc929892SMarc-André Lureau    fi
2719fc929892SMarc-André Lureau  else
2720fc929892SMarc-André Lureau    cross_arg="--native-file config-meson.cross"
2721fc929892SMarc-André Lureau  fi
2722fc929892SMarc-André Lureau  mv $cross config-meson.cross
2723fc929892SMarc-André Lureau
2724a5665051SPaolo Bonzini  rm -rf meson-private meson-info meson-logs
27250a31e3a0SPaolo Bonzini
27260a31e3a0SPaolo Bonzini  # Built-in options
27270a31e3a0SPaolo Bonzini  test "$bindir" != "bin" && meson_option_add "-Dbindir=$bindir"
27280a31e3a0SPaolo Bonzini  test "$default_feature" = no && meson_option_add -Dauto_features=disabled
27290a31e3a0SPaolo Bonzini  test "$pie" = no && meson_option_add -Db_pie=false
27300a31e3a0SPaolo Bonzini  test "$werror" = yes && meson_option_add -Dwerror=true
27310a31e3a0SPaolo Bonzini
27320a31e3a0SPaolo Bonzini  # QEMU options
27330a31e3a0SPaolo Bonzini  test "$cfi" != false && meson_option_add "-Dcfi=$cfi"
27340a31e3a0SPaolo Bonzini  test "$fdt" != auto && meson_option_add "-Dfdt=$fdt"
27350a31e3a0SPaolo Bonzini  test -n "${LIB_FUZZING_ENGINE+xxx}" && meson_option_add "-Dfuzzing_engine=$LIB_FUZZING_ENGINE"
27360a31e3a0SPaolo Bonzini  test "$qemu_suffix" != qemu && meson_option_add "-Dqemu_suffix=$qemu_suffix"
27370a31e3a0SPaolo Bonzini  test "$slirp" != auto && meson_option_add "-Dslirp=$slirp"
27380a31e3a0SPaolo Bonzini  test "$smbd" != '' && meson_option_add "-Dsmbd=$smbd"
27390a31e3a0SPaolo Bonzini  test "$tcg" != enabled && meson_option_add "-Dtcg=$tcg"
274055116968SJagannathan Raman  test "$vfio_user_server" != auto && meson_option_add "-Dvfio_user_server=$vfio_user_server"
274161d63097SPaolo Bonzini  run_meson() {
27420a31e3a0SPaolo Bonzini    NINJA=$ninja $meson setup --prefix "$prefix" "$@" $cross_arg "$PWD" "$source_path"
274361d63097SPaolo Bonzini  }
274461d63097SPaolo Bonzini  eval run_meson $meson_options
2745a5665051SPaolo Bonzini  if test "$?" -ne 0 ; then
2746a5665051SPaolo Bonzini      error_exit "meson setup failed"
2747a5665051SPaolo Bonzini  fi
2748699d3884SPaolo Bonzinielse
2749699d3884SPaolo Bonzini  if test -f meson-private/cmd_line.txt; then
2750699d3884SPaolo Bonzini    # Adjust old command line options whose type was changed
2751699d3884SPaolo Bonzini    # Avoids having to use "setup --wipe" when Meson is upgraded
2752699d3884SPaolo Bonzini    perl -i -ne '
2753699d3884SPaolo Bonzini      s/^gettext = true$/gettext = auto/;
2754699d3884SPaolo Bonzini      s/^gettext = false$/gettext = disabled/;
2755654d6b04SPaolo Bonzini      /^b_staticpic/ && next;
2756699d3884SPaolo Bonzini      print;' meson-private/cmd_line.txt
2757699d3884SPaolo Bonzini  fi
2758a5665051SPaolo Bonzinifi
2759a5665051SPaolo Bonzini
2760dc655404SMichael S. Tsirkin# Save the configure command line for later reuse.
2761dc655404SMichael S. Tsirkincat <<EOD >config.status
2762dc655404SMichael S. Tsirkin#!/bin/sh
2763dc655404SMichael S. Tsirkin# Generated by configure.
2764dc655404SMichael S. Tsirkin# Run this file to recreate the current configuration.
2765dc655404SMichael S. Tsirkin# Compiler output produced by configure, useful for debugging
2766dc655404SMichael S. Tsirkin# configure, is in config.log if it exists.
2767dc655404SMichael S. TsirkinEOD
2768e811da7fSDaniel P. Berrangé
2769e811da7fSDaniel P. Berrangépreserve_env() {
2770e811da7fSDaniel P. Berrangé    envname=$1
2771e811da7fSDaniel P. Berrangé
2772e811da7fSDaniel P. Berrangé    eval envval=\$$envname
2773e811da7fSDaniel P. Berrangé
2774e811da7fSDaniel P. Berrangé    if test -n "$envval"
2775e811da7fSDaniel P. Berrangé    then
2776e811da7fSDaniel P. Berrangé	echo "$envname='$envval'" >> config.status
2777e811da7fSDaniel P. Berrangé	echo "export $envname" >> config.status
2778e811da7fSDaniel P. Berrangé    else
2779e811da7fSDaniel P. Berrangé	echo "unset $envname" >> config.status
2780e811da7fSDaniel P. Berrangé    fi
2781e811da7fSDaniel P. Berrangé}
2782e811da7fSDaniel P. Berrangé
2783e811da7fSDaniel P. Berrangé# Preserve various env variables that influence what
2784e811da7fSDaniel P. Berrangé# features/build target configure will detect
2785e811da7fSDaniel P. Berrangépreserve_env AR
2786e811da7fSDaniel P. Berrangépreserve_env AS
2787e811da7fSDaniel P. Berrangépreserve_env CC
27888009da03SPaolo Bonzinipreserve_env CFLAGS
2789e811da7fSDaniel P. Berrangépreserve_env CXX
27908009da03SPaolo Bonzinipreserve_env CXXFLAGS
2791e811da7fSDaniel P. Berrangépreserve_env LD
27928009da03SPaolo Bonzinipreserve_env LDFLAGS
2793e811da7fSDaniel P. Berrangépreserve_env LD_LIBRARY_PATH
2794e811da7fSDaniel P. Berrangépreserve_env MAKE
2795e811da7fSDaniel P. Berrangépreserve_env NM
2796b5569e5bSPaolo Bonzinipreserve_env OBJCFLAGS
2797e811da7fSDaniel P. Berrangépreserve_env OBJCOPY
2798e811da7fSDaniel P. Berrangépreserve_env PATH
2799e811da7fSDaniel P. Berrangépreserve_env PKG_CONFIG
2800e811da7fSDaniel P. Berrangépreserve_env PKG_CONFIG_LIBDIR
2801e811da7fSDaniel P. Berrangépreserve_env PKG_CONFIG_PATH
2802e811da7fSDaniel P. Berrangépreserve_env PYTHON
2803e811da7fSDaniel P. Berrangépreserve_env SDL2_CONFIG
2804e811da7fSDaniel P. Berrangépreserve_env SMBD
2805e811da7fSDaniel P. Berrangépreserve_env STRIP
2806158bb224SKonstantin Kostiukpreserve_env WIDL
2807e811da7fSDaniel P. Berrangépreserve_env WINDRES
2808e811da7fSDaniel P. Berrangé
2809dc655404SMichael S. Tsirkinprintf "exec" >>config.status
2810a5665051SPaolo Bonzinifor i in "$0" "$@"; do
2811835af899SPaolo Bonzini  test "$i" = --skip-meson || printf " %s" "$(quote_sh "$i")" >>config.status
2812a5665051SPaolo Bonzinidone
2813cf7cc929SDr. David Alan Gilbertecho ' "$@"' >>config.status
2814dc655404SMichael S. Tsirkinchmod +x config.status
2815dc655404SMichael S. Tsirkin
28168cd05ab6SPeter Maydellrm -r "$TMPDIR1"
2817