blob: 6df4306c884f31df13a401f79bcfda6af821032d [file] [log] [blame]
bellard7d132992003-03-06 23:23:54 +00001#!/bin/sh
2#
bellard3ef693a2003-03-23 20:17:16 +00003# qemu configure script (c) 2003 Fabrice Bellard
bellard7d132992003-03-06 23:23:54 +00004#
Peter Maydell8cd05ab2014-05-23 17:07:24 +01005
Cornelia Huck99519e62014-05-28 12:39:17 +02006# Unset some variables known to interfere with behavior of common tools,
7# just as autoconf does.
8CLICOLOR_FORCE= GREP_OPTIONS=
9unset CLICOLOR_FORCE GREP_OPTIONS
10
John Snow5e4dfd32015-10-28 13:56:40 -040011# Don't allow CCACHE, if present, to use cached results of compile tests!
12export CCACHE_RECACHE=yes
13
Daniel P. Berrangédedad022020-08-21 12:22:04 +020014# make source path absolute
15source_path=$(cd "$(dirname -- "$0")"; pwd)
16
17if test "$PWD" = "$source_path"
18then
19 echo "Using './build' as the directory for build output"
20
21 MARKER=build/auto-created-by-configure
22
23 if test -e build
24 then
25 if test -f $MARKER
26 then
27 rm -rf build
28 else
29 echo "ERROR: ./build dir already exists and was not previously created by configure"
30 exit 1
31 fi
32 fi
33
34 mkdir build
35 touch $MARKER
36
37 cat > GNUmakefile <<'EOF'
38# This file is auto-generated by configure to support in-source tree
39# 'make' command invocation
40
41ifeq ($(MAKECMDGOALS),)
42recurse: all
43endif
44
45.NOTPARALLEL: %
46%: force
47 @echo 'changing dir to build for $(MAKE) "$(MAKECMDGOALS)"...'
48 @$(MAKE) -C build -f Makefile $(MAKECMDGOALS)
49 @if test "$(MAKECMDGOALS)" = "distclean" && \
50 test -e build/auto-created-by-configure ; \
51 then \
52 rm -rf build GNUmakefile ; \
53 fi
54force: ;
55.PHONY: force
56GNUmakefile: ;
57
58EOF
59 cd build
60 exec $source_path/configure "$@"
61fi
62
Peter Maydell8cd05ab2014-05-23 17:07:24 +010063# Temporary directory used for files created while
64# configure runs. Since it is in the build directory
65# we can safely blow away any previous version of it
66# (and we need not jump through hoops to try to delete
67# it when configure exits.)
68TMPDIR1="config-temp"
69rm -rf "${TMPDIR1}"
70mkdir -p "${TMPDIR1}"
71if [ $? -ne 0 ]; then
72 echo "ERROR: failed to create temporary directory"
73 exit 1
bellard7d132992003-03-06 23:23:54 +000074fi
75
Peter Maydell8cd05ab2014-05-23 17:07:24 +010076TMPB="qemu-conf"
77TMPC="${TMPDIR1}/${TMPB}.c"
Don Slutz66518bf2014-01-02 21:12:46 -050078TMPO="${TMPDIR1}/${TMPB}.o"
Peter Maydell9c83ffd2014-02-25 18:27:49 +000079TMPCXX="${TMPDIR1}/${TMPB}.cxx"
Peter Maydell8cd05ab2014-05-23 17:07:24 +010080TMPE="${TMPDIR1}/${TMPB}.exe"
Emilio G. Cota26fffe22018-10-21 13:56:29 -040081TMPTXT="${TMPDIR1}/${TMPB}.txt"
bellard7d132992003-03-06 23:23:54 +000082
Gerd Hoffmannda1d85e2010-04-23 13:44:10 +020083rm -f config.log
malc9ac81bb2008-11-29 20:09:56 +000084
Peter Maydellb48e3612011-11-23 17:26:44 +000085# Print a helpful header at the top of config.log
86echo "# QEMU configure log $(date)" >> config.log
Peter Maydell979ae162012-03-07 12:16:29 +000087printf "# Configured with:" >> config.log
88printf " '%s'" "$0" "$@" >> config.log
89echo >> config.log
Peter Maydellb48e3612011-11-23 17:26:44 +000090echo "#" >> config.log
91
Paolo Bonzinid880a3b2017-07-03 16:58:28 +020092print_error() {
93 (echo
Peter Maydell76ad07a2013-04-08 12:11:26 +010094 echo "ERROR: $1"
95 while test -n "$2"; do
96 echo " $2"
97 shift
98 done
Paolo Bonzinid880a3b2017-07-03 16:58:28 +020099 echo) >&2
100}
101
102error_exit() {
103 print_error "$@"
Peter Maydell76ad07a2013-04-08 12:11:26 +0100104 exit 1
105}
106
Peter Maydell9c83ffd2014-02-25 18:27:49 +0000107do_compiler() {
108 # Run the compiler, capturing its output to the log. First argument
109 # is compiler binary to execute.
110 local compiler="$1"
111 shift
Ian Jackson8bbe05d2017-09-25 16:41:03 +0100112 if test -n "$BASH_VERSION"; then eval '
113 echo >>config.log "
114funcs: ${FUNCNAME[*]}
115lines: ${BASH_LINENO[*]}"
116 '; fi
Peter Maydell9c83ffd2014-02-25 18:27:49 +0000117 echo $compiler "$@" >> config.log
118 $compiler "$@" >> config.log 2>&1 || return $?
Peter Maydell8dc38a72012-07-18 15:10:28 +0100119 # Test passed. If this is an --enable-werror build, rerun
120 # the test with -Werror and bail out if it fails. This
121 # makes warning-generating-errors in configure test code
122 # obvious to developers.
123 if test "$werror" != "yes"; then
124 return 0
125 fi
126 # Don't bother rerunning the compile if we were already using -Werror
127 case "$*" in
128 *-Werror*)
129 return 0
130 ;;
131 esac
Peter Maydell9c83ffd2014-02-25 18:27:49 +0000132 echo $compiler -Werror "$@" >> config.log
133 $compiler -Werror "$@" >> config.log 2>&1 && return $?
Peter Maydell76ad07a2013-04-08 12:11:26 +0100134 error_exit "configure test passed without -Werror but failed with -Werror." \
135 "This is probably a bug in the configure script. The failing command" \
136 "will be at the bottom of config.log." \
137 "You can run configure with --disable-werror to bypass this check."
Peter Maydell8dc38a72012-07-18 15:10:28 +0100138}
139
Peter Maydell9c83ffd2014-02-25 18:27:49 +0000140do_cc() {
141 do_compiler "$cc" "$@"
142}
143
144do_cxx() {
145 do_compiler "$cxx" "$@"
146}
147
Richard Henderson00849b92020-06-17 13:13:06 -0700148# Append $2 to the variable named $1, with space separation
149add_to() {
150 eval $1=\${$1:+\"\$$1 \"}\$2
151}
152
Peter Maydell9c83ffd2014-02-25 18:27:49 +0000153update_cxxflags() {
154 # Set QEMU_CXXFLAGS from QEMU_CFLAGS by filtering out those
155 # options which some versions of GCC's C++ compiler complain about
156 # because they only make sense for C programs.
Paolo Bonzini53422042019-07-29 12:50:04 +0200157 QEMU_CXXFLAGS="$QEMU_CXXFLAGS -D__STDC_LIMIT_MACROS -D__STDC_CONSTANT_MACROS -D__STDC_FORMAT_MACROS"
Paolo Bonzini5770e8a2020-09-23 05:26:15 -0400158 CONFIGURE_CXXFLAGS=$(echo "$CONFIGURE_CFLAGS" | sed s/-std=gnu99/-std=gnu++11/)
Peter Maydell9c83ffd2014-02-25 18:27:49 +0000159 for arg in $QEMU_CFLAGS; do
160 case $arg in
161 -Wstrict-prototypes|-Wmissing-prototypes|-Wnested-externs|\
162 -Wold-style-declaration|-Wold-style-definition|-Wredundant-decls)
163 ;;
164 *)
165 QEMU_CXXFLAGS=${QEMU_CXXFLAGS:+$QEMU_CXXFLAGS }$arg
166 ;;
167 esac
168 done
169}
170
Juan Quintela52166aa2009-08-03 14:46:03 +0200171compile_object() {
John Snowfd0e6052015-03-25 18:57:39 -0400172 local_cflags="$1"
Paolo Bonzini5770e8a2020-09-23 05:26:15 -0400173 do_cc $CFLAGS $CONFIGURE_CFLAGS $QEMU_CFLAGS $local_cflags -c -o $TMPO $TMPC
Juan Quintela52166aa2009-08-03 14:46:03 +0200174}
175
176compile_prog() {
177 local_cflags="$1"
178 local_ldflags="$2"
Paolo Bonzini5770e8a2020-09-23 05:26:15 -0400179 do_cc $CFLAGS $CONFIGURE_CFLAGS $QEMU_CFLAGS $local_cflags -o $TMPE $TMPC \
180 $LDFLAGS $CONFIGURE_LDFLAGS $QEMU_LDFLAGS $local_ldflags
Juan Quintela52166aa2009-08-03 14:46:03 +0200181}
182
Paolo Bonzini11568d62010-12-23 11:43:58 +0100183# symbolically link $1 to $2. Portable version of "ln -sf".
184symlink() {
Stefan Weil72b8b5a2012-03-19 13:20:47 +0100185 rm -rf "$2"
Anthony Liguoriec5b06d2012-06-06 16:57:00 +0800186 mkdir -p "$(dirname "$2")"
Stefan Weil72b8b5a2012-03-19 13:20:47 +0100187 ln -s "$1" "$2"
Paolo Bonzini11568d62010-12-23 11:43:58 +0100188}
189
Loïc Minier0dba6192010-01-28 21:26:51 +0000190# check whether a command is available to this shell (may be either an
191# executable or a builtin)
192has() {
193 type "$1" >/dev/null 2>&1
194}
195
Marc-André Lureau0a01d762019-08-21 11:21:16 +0400196version_ge () {
197 local_ver1=`echo $1 | tr . ' '`
198 local_ver2=`echo $2 | tr . ' '`
199 while true; do
200 set x $local_ver1
201 local_first=${2-0}
Stefano Garzarellac44a33e2020-08-21 22:35:58 +0200202 # 'shift 2' if $2 is set, or 'shift' if $2 is not set
203 shift ${2:+2}
Marc-André Lureau0a01d762019-08-21 11:21:16 +0400204 local_ver1=$*
205 set x $local_ver2
206 # the second argument finished, the first must be greater or equal
207 test $# = 1 && return 0
208 test $local_first -lt $2 && return 1
209 test $local_first -gt $2 && return 0
Stefano Garzarellac44a33e2020-08-21 22:35:58 +0200210 shift ${2:+2}
Marc-André Lureau0a01d762019-08-21 11:21:16 +0400211 local_ver2=$*
212 done
213}
214
Lluís Vilanova5b808272014-05-27 15:02:14 +0200215have_backend () {
216 echo "$trace_backends" | grep "$1" >/dev/null
217}
218
Paolo Bonzini3b6b7552012-09-17 11:59:41 +0200219glob() {
220 eval test -z '"${1#'"$2"'}"'
221}
222
Christian Borntraegere9a35912017-08-23 12:16:23 +0200223ld_has() {
224 $ld --help 2>/dev/null | grep ".$1" >/dev/null 2>&1
225}
226
Antonio Ospite4ace32e2019-05-26 16:47:47 +0200227if printf %s\\n "$source_path" "$PWD" | grep -q "[[:space:]:]";
228then
229 error_exit "main directory cannot contain spaces nor colons"
230fi
231
Antonio Ospite14211822019-05-26 16:47:46 +0200232# default parameters
Juan Quintela2ff6b912009-08-03 14:45:55 +0200233cpu=""
Michael S. Tsirkina31a8642013-07-24 18:56:03 +0300234iasl="iasl"
bellard1e43adf2003-09-30 20:54:24 +0000235interp_prefix="/usr/gnemul/qemu-%M"
bellard43ce4df2003-06-09 19:53:12 +0000236static="no"
bellard7d132992003-03-06 23:23:54 +0000237cross_prefix=""
malc0c58ac12008-06-25 21:04:05 +0000238audio_drv_list=""
Fam Zhengb64ec4e2013-05-29 19:35:40 +0800239block_drv_rw_whitelist=""
240block_drv_ro_whitelist=""
Peter Maydelle49d0212012-12-07 15:39:13 +0000241host_cc="cc"
malcd5631632009-10-10 01:13:41 +0400242audio_win_int=""
Michael Roth957f1f92011-08-11 15:38:12 -0500243libs_qga=""
Gerd Hoffmann5bc62e02012-02-08 13:54:13 +0100244debug_info="yes"
Steven Noonan63678e12014-03-28 17:19:02 +0100245stack_protector=""
Daniele Buono1e4f6062020-05-29 16:51:21 -0400246safe_stack=""
Alex Bennéeafc3a8f2019-11-28 16:35:24 +0100247use_containers="yes"
Alex Bennéef2385392020-04-30 20:01:14 +0100248gdb_bin=$(command -v "gdb-multiarch" || command -v "gdb")
aliguoriac0df512008-12-29 17:14:15 +0000249
Daniel P. Berrange92712822017-09-29 11:11:58 +0100250if test -e "$source_path/.git"
251then
Daniel P. Berrangef62bbee2017-10-26 13:52:26 +0100252 git_update=yes
Daniel P. Berrange92712822017-09-29 11:11:58 +0100253 git_submodules="ui/keycodemapdb"
Emilio G. Cota3ac1f812018-03-08 21:09:40 -0500254 git_submodules="$git_submodules tests/fp/berkeley-testfloat-3"
255 git_submodules="$git_submodules tests/fp/berkeley-softfloat-3"
Daniel P. Berrange92712822017-09-29 11:11:58 +0100256else
Daniel P. Berrangef62bbee2017-10-26 13:52:26 +0100257 git_update=no
Daniel P. Berrange92712822017-09-29 11:11:58 +0100258 git_submodules=""
Daniel P. Berrangé5c0ef672018-04-18 18:11:51 +0100259
260 if ! test -f "$source_path/ui/keycodemapdb/README"
261 then
262 echo
263 echo "ERROR: missing file $source_path/ui/keycodemapdb/README"
264 echo
265 echo "This is not a GIT checkout but module content appears to"
266 echo "be missing. Do not use 'git archive' or GitHub download links"
267 echo "to acquire QEMU source archives. Non-GIT builds are only"
268 echo "supported with source archives linked from:"
269 echo
Peter Maydella3e3b522019-07-22 14:07:39 +0100270 echo " https://www.qemu.org/download/#source"
Daniel P. Berrangé5c0ef672018-04-18 18:11:51 +0100271 echo
272 echo "Developers working with GIT can use scripts/archive-source.sh"
273 echo "if they need to create valid source archives."
274 echo
275 exit 1
276 fi
Daniel P. Berrange92712822017-09-29 11:11:58 +0100277fi
Daniel P. Berrangecc84d632017-10-20 15:02:43 +0100278git="git"
aliguoriac0df512008-12-29 17:14:15 +0000279
Stefan Weilafb63eb2012-09-26 22:04:38 +0200280# Don't accept a target_list environment variable.
281unset target_list
Alex Bennée447e1332019-03-19 11:59:12 +0000282unset target_list_exclude
Paolo Bonzini377529c2010-12-23 11:43:50 +0100283
284# Default value for a variable defining feature "foo".
285# * foo="no" feature will only be used if --enable-foo arg is given
286# * foo="" feature will be searched for, and if found, will be used
287# unless --disable-foo is given
288# * foo="yes" this value will only be set by --enable-foo flag.
289# feature will searched for,
290# if not found, configure exits with error
291#
292# Always add --enable-foo and --disable-foo command line args.
293# Distributions want to ensure that several features are compiled in, and it
294# is impossible without a --enable-foo that exits if a feature is not found.
295
Paolo Bonzini377529c2010-12-23 11:43:50 +0100296brlapi=""
297curl=""
Yonggang Luo5285e592020-10-13 07:43:48 +0800298iconv="auto"
299curses="auto"
Yonggang Luoe3667662020-10-16 06:06:25 +0800300docs="auto"
Paolo Bonzinifbb41212020-10-05 11:31:15 +0200301fdt="auto"
Vincenzo Maffione58952132013-11-06 11:44:06 +0100302netmap="no"
Paolo Bonzini35be72b2020-02-06 14:17:15 +0100303sdl="auto"
304sdl_image="auto"
Misono Tomohirocece1162020-10-08 19:31:33 +0900305virtiofsd="auto"
Meador Inge983eef52012-02-24 14:00:42 +0530306virtfs=""
Paolo Bonzini5c530152020-10-15 06:09:27 -0400307libudev="auto"
Paolo Bonzini6ec0e152020-09-16 18:07:29 +0200308mpath="auto"
Paolo Bonzinia0b93232020-02-06 15:48:52 +0100309vnc="enabled"
Paolo Bonzinideb62372020-09-01 07:51:16 -0400310sparse="auto"
Paolo Bonzini377529c2010-12-23 11:43:50 +0100311vde=""
Paolo Bonzinia0b93232020-02-06 15:48:52 +0100312vnc_sasl="auto"
313vnc_jpeg="auto"
314vnc_png="auto"
Laurent Vivier4113f4c2020-08-24 17:24:29 +0200315xkbcommon="auto"
Paolo Bonzini377529c2010-12-23 11:43:50 +0100316xen=""
Anthony PERARDd5b93dd2011-02-25 16:20:34 +0000317xen_ctrl_version=""
Paolo Bonzini1badb702020-09-18 04:57:25 -0400318xen_pci_passthrough="auto"
Paolo Bonzini377529c2010-12-23 11:43:50 +0100319linux_aio=""
Aarushi Mehtac10dd852020-01-20 14:18:44 +0000320linux_io_uring=""
Corey Bryant47e98652012-01-26 09:42:26 -0500321cap_ng=""
Paolo Bonzini377529c2010-12-23 11:43:50 +0100322attr=""
Avi Kivity4f26f2b2011-11-09 14:44:52 +0200323libattr=""
Paolo Bonzini377529c2010-12-23 11:43:50 +0100324xfs=""
Paolo Bonzini1badb702020-09-18 04:57:25 -0400325tcg="enabled"
Paolo Bonzinia40161c2018-02-16 10:05:23 +0100326membarrier=""
Paolo Bonzini299e6f12019-02-14 18:35:53 +0100327vhost_net=""
328vhost_crypto=""
329vhost_scsi=""
330vhost_vsock=""
Marc-André Lureaue6a74862017-08-03 11:07:46 +0200331vhost_user=""
Dr. David Alan Gilbert98fc1ad2019-09-30 11:51:34 +0100332vhost_user_fs=""
Paolo Bonzini3bd40ec2020-09-18 05:22:37 -0400333kvm="auto"
334hax="auto"
335hvf="auto"
336whpx="auto"
Michael R. Hines2da776d2013-07-22 10:01:54 -0400337rdma=""
Marcel Apfelbaum21ab34c2018-08-16 18:16:37 +0300338pvrdma=""
Paolo Bonzini377529c2010-12-23 11:43:50 +0100339gprof="no"
340debug_tcg="no"
Paolo Bonzini377529c2010-12-23 11:43:50 +0100341debug="no"
Marc-André Lureau247724c2018-01-16 16:11:51 +0100342sanitizers="no"
Lingfeng Yang0aebab02020-06-12 20:02:23 +0100343tsan="no"
John Snowb553a042015-11-03 15:43:42 -0500344fortify_source=""
Paolo Bonzini377529c2010-12-23 11:43:50 +0100345strip_opt="yes"
Stefan Weil9195b2c2011-10-19 07:07:18 +0200346tcg_interpreter="no"
Paolo Bonzini377529c2010-12-23 11:43:50 +0100347bigendian="no"
348mingw32="no"
Blue Swirl1d728c32012-05-01 18:45:39 +0000349gcov="no"
Paolo Bonzini377529c2010-12-23 11:43:50 +0100350EXESUF=""
Paolo Bonzini484e2cc2019-12-12 13:30:36 +0100351HOST_DSOSUF=".so"
Fam Zheng17969262014-02-10 14:48:56 +0800352modules="no"
Christian Ehrhardtbd83c862020-03-10 15:58:06 +0100353module_upgrades="no"
Paolo Bonzini377529c2010-12-23 11:43:50 +0100354prefix="/usr/local"
Marc-André Lureau10ff82d2020-08-26 15:04:13 +0400355qemu_suffix="qemu"
Paolo Bonzini4d34a862020-10-05 11:31:15 +0200356slirp="auto"
Paolo Bonzini377529c2010-12-23 11:43:50 +0100357oss_lib=""
358bsd="no"
359linux="no"
360solaris="no"
361profiler="no"
Paolo Bonzinib4e312e2020-09-01 11:28:59 -0400362cocoa="auto"
Paolo Bonzini377529c2010-12-23 11:43:50 +0100363softmmu="yes"
364linux_user="no"
Paolo Bonzini377529c2010-12-23 11:43:50 +0100365bsd_user="no"
Paolo Bonzinic8d54502020-10-16 03:32:52 -0400366blobs="true"
Paolo Bonzini377529c2010-12-23 11:43:50 +0100367pkgversion=""
Avi Kivity40d64442011-11-15 20:12:17 +0200368pie=""
Paolo Bonzini3556c232013-05-10 14:16:40 +0200369qom_cast_debug="yes"
Paolo Bonzinibaf86d62016-01-07 16:55:31 +0300370trace_backends="log"
Paolo Bonzini377529c2010-12-23 11:43:50 +0100371trace_file="trace"
372spice=""
373rbd=""
Marc-André Lureau7b02f542015-08-30 11:48:40 +0200374smartcard=""
César Belley0a40bcb2020-08-26 13:42:04 +0200375u2f="auto"
Gerd Hoffmann2b2325f2012-11-30 16:02:11 +0100376libusb=""
Hans de Goede69354a82011-07-19 11:04:10 +0200377usb_redir=""
Gerd Hoffmannda076ff2014-11-20 09:49:44 +0100378opengl=""
Gerd Hoffmann014cb152015-12-03 12:56:34 +0100379opengl_dmabuf="no"
Richard Henderson5dd89902017-07-18 18:40:18 -1000380cpuid_h="no"
Liam Merwick86583a02018-10-19 21:38:59 +0100381avx2_opt=""
Richard Henderson8b18cdb2020-09-13 12:19:25 -0700382capstone="auto"
Stefan Weilb25c9df2014-04-29 08:21:16 +0200383lzo=""
384snappy=""
Peter Wu6b383c02015-01-06 18:48:14 +0100385bzip2=""
Julio Faracco83bc1f92018-11-05 13:08:04 -0200386lzfse=""
Juan Quintela3a678482019-12-17 21:15:24 +0100387zstd=""
Michael Tokareve8ef31a2013-07-31 14:22:07 +0400388guest_agent=""
Tomoki Sekiyamad9840e22013-08-07 11:40:03 -0400389guest_agent_with_vss="no"
Michael Roth50cbebb2015-07-07 18:10:09 -0500390guest_agent_ntddscsi="no"
Yossi Hindin9dacf322015-05-06 14:57:40 +0300391guest_agent_msi=""
Tomoki Sekiyamad9840e22013-08-07 11:40:03 -0400392vss_win32_sdk=""
393win_sdk="no"
Philippe Mathieu-Daudée10ee3f2020-02-17 14:33:27 +0100394want_tools=""
Ronnie Sahlbergc589b242011-10-25 19:24:24 +1100395libiscsi=""
Peter Lieven6542aa92014-02-03 10:26:13 +0100396libnfs=""
Alex Barcelo519175a2012-02-28 12:25:50 +0100397coroutine=""
Stefan Hajnoczi70c60c02013-09-11 16:42:35 +0200398coroutine_pool=""
Peter Lieven7d992e42016-09-27 11:58:45 +0200399debug_stack_usage="no"
Longpeng(Mike)f0d92b52017-07-14 14:04:05 -0400400crypto_afalg="no"
Eduardo Otubof7945732012-08-14 18:44:05 -0300401seccomp=""
Bharata B Raoeb100392012-09-24 14:42:45 +0530402glusterfs=""
Jeff Codyd85fa9e2016-04-05 10:40:09 -0400403glusterfs_xlator_opt="no"
Bharata B Rao0c14fb42013-07-16 21:47:42 +0530404glusterfs_discard="no"
Niels de Vosdf3a4292017-05-28 12:01:14 +0530405glusterfs_fallocate="no"
Bharata B Rao7c815372013-12-21 14:51:25 +0530406glusterfs_zerofill="no"
Prasanna Kumar Kalevere014dbe2019-03-05 16:46:33 +0100407glusterfs_ftruncate_has_stat="no"
Niels de Vos0e3b8912019-03-05 16:46:34 +0100408glusterfs_iocb_has_stat="no"
Anthony Liguoria4ccabc2013-02-20 07:43:20 -0600409gtk=""
Gerd Hoffmann925a0402015-05-26 12:26:21 +0200410gtk_gl="no"
Daniel P. Berrangea1c5e942016-06-06 10:05:06 +0100411tls_priority="NORMAL"
Daniel P. Berrangeddbb0d02015-07-01 18:10:29 +0100412gnutls=""
Daniel P. Berrange91bfcdb2015-10-16 16:36:53 +0100413nettle=""
Daniel P. Berrangédc2207a2019-10-14 17:28:27 +0100414nettle_xts="no"
Daniel P. Berrange91bfcdb2015-10-16 16:36:53 +0100415gcrypt=""
Longpeng(Mike)1f923c72016-12-13 18:42:55 +0800416gcrypt_hmac="no"
Daniel P. Berrangée0576942019-10-14 17:28:27 +0100417gcrypt_xts="no"
418qemu_private_xts="yes"
Daniel P. Berrange8953caf2016-07-27 14:13:56 +0100419auth_pam=""
Stefan Weilbbbf9bf2014-02-19 07:04:34 +0100420vte=""
Gerd Hoffmann9d9e1522014-07-11 12:51:43 +0200421virglrenderer=""
Paolo Bonzini7aaa6a12019-01-23 14:56:07 +0800422tpm=""
Pino Toscanob10d49d2019-06-20 22:08:40 +0200423libssh=""
Dr. David Alan Gilberted1701c2017-05-15 15:05:29 +0100424live_block_migration="yes"
Wanlong Gaoa99d57b2014-05-14 17:43:28 +0800425numa=""
Fam Zheng2847b462015-03-26 11:03:12 +0800426tcmalloc="no"
Alexandre Derumier7b01cb92015-06-19 12:56:58 +0200427jemalloc="no"
Changlong Xiea6b1d4c2016-07-27 15:01:48 +0800428replication="yes"
Jeff Cody2f740132018-11-07 07:36:44 +0100429bochs="yes"
430cloop="yes"
431dmg="yes"
432qcow1="yes"
433vdi="yes"
434vvfat="yes"
435qed="yes"
436parallels="yes"
Daniel P. Berrangée1c42692020-10-02 12:32:43 +0100437sheepdog="no"
Klim Kireeved279a02018-01-12 12:01:19 +0300438libxml2=""
Paolo Bonziniba59fb72018-06-13 14:23:08 +0200439debug_mutex="no"
Junyan He17824402018-07-18 15:47:59 +0800440libpmem=""
Paolo Bonzinif3494742019-01-23 14:56:17 +0800441default_devices="yes"
Alex Bennée40e8c6f2019-06-13 14:52:25 +0100442plugins="no"
Alexander Bulekovadc28022020-02-19 23:11:14 -0500443fuzzing="no"
Marek Marczykowski-Góreckib767d252020-05-20 15:20:23 +0200444rng_none="no"
Alexey Krasikov54e7aac2020-05-25 14:19:12 +0300445secret_keyring=""
Jingqi Liu21b2eca2020-04-29 16:50:11 +0800446libdaxctl=""
Paolo Bonzinia5665052019-06-10 12:05:14 +0200447meson=""
Paolo Bonzini48328882020-08-26 08:04:15 +0200448ninja=""
Paolo Bonzinia5665052019-06-10 12:05:14 +0200449skip_meson=no
Marc-André Lureaue8f3bd72019-09-19 21:02:09 +0400450gettext=""
Paolo Bonzini377529c2010-12-23 11:43:50 +0100451
Peter Maydellfb59dab2017-03-28 14:01:52 +0100452bogus_os="no"
Paolo Bonziniaa087962020-09-01 11:15:30 -0400453malloc_trim="auto"
Peter Maydell898be3e2017-03-21 14:31:57 +0000454
aliguoriac0df512008-12-29 17:14:15 +0000455# parse CC options first
456for opt do
Stefan Weil89138852016-05-16 15:10:20 +0200457 optarg=$(expr "x$opt" : 'x[^=]*=\(.*\)')
aliguoriac0df512008-12-29 17:14:15 +0000458 case "$opt" in
459 --cross-prefix=*) cross_prefix="$optarg"
460 ;;
Paolo Bonzini3d8df642010-12-23 11:43:48 +0100461 --cc=*) CC="$optarg"
aliguoriac0df512008-12-29 17:14:15 +0000462 ;;
Tomoki Sekiyama83f73fc2013-08-07 11:39:36 -0400463 --cxx=*) CXX="$optarg"
464 ;;
Juan Quintela2ff6b912009-08-03 14:45:55 +0200465 --cpu=*) cpu="$optarg"
466 ;;
Alex Bennéede385282015-06-03 09:56:37 +0100467 --extra-cflags=*) QEMU_CFLAGS="$QEMU_CFLAGS $optarg"
Paolo Bonzinidb5adea2019-12-11 15:34:27 +0100468 QEMU_LDFLAGS="$QEMU_LDFLAGS $optarg"
Juan Quintelae2a2ed02009-08-03 14:46:02 +0200469 ;;
Bruno Dominguez11cde1c2017-06-06 14:07:47 +0100470 --extra-cxxflags=*) QEMU_CXXFLAGS="$QEMU_CXXFLAGS $optarg"
Bruno Dominguez11cde1c2017-06-06 14:07:47 +0100471 ;;
Paolo Bonzinidb5adea2019-12-11 15:34:27 +0100472 --extra-ldflags=*) QEMU_LDFLAGS="$QEMU_LDFLAGS $optarg"
Gerd Hoffmannf9943cd2013-01-04 10:15:53 +0100473 EXTRA_LDFLAGS="$optarg"
Juan Quintelae2a2ed02009-08-03 14:46:02 +0200474 ;;
Gerd Hoffmann5bc62e02012-02-08 13:54:13 +0100475 --enable-debug-info) debug_info="yes"
476 ;;
477 --disable-debug-info) debug_info="no"
478 ;;
Alex Bennéed75402b2018-04-04 20:27:05 +0100479 --cross-cc-*[!a-zA-Z0-9_-]*=*) error_exit "Passed bad --cross-cc-FOO option"
480 ;;
Alex Bennéed422b2b2018-04-13 11:07:58 +0100481 --cross-cc-cflags-*) cc_arch=${opt#--cross-cc-flags-}; cc_arch=${cc_arch%%=*}
482 eval "cross_cc_cflags_${cc_arch}=\$optarg"
Paolo Bonzini2038f8c2019-08-07 16:35:23 +0200483 cross_cc_vars="$cross_cc_vars cross_cc_cflags_${cc_arch}"
Alex Bennéed422b2b2018-04-13 11:07:58 +0100484 ;;
Alex Bennéed75402b2018-04-04 20:27:05 +0100485 --cross-cc-*) cc_arch=${opt#--cross-cc-}; cc_arch=${cc_arch%%=*}
Paolo Bonzini2038f8c2019-08-07 16:35:23 +0200486 cc_archs="$cc_archs $cc_arch"
Alex Bennéed75402b2018-04-04 20:27:05 +0100487 eval "cross_cc_${cc_arch}=\$optarg"
Paolo Bonzini2038f8c2019-08-07 16:35:23 +0200488 cross_cc_vars="$cross_cc_vars cross_cc_${cc_arch}"
Alex Bennéed75402b2018-04-04 20:27:05 +0100489 ;;
aliguoriac0df512008-12-29 17:14:15 +0000490 esac
491done
aliguoriac0df512008-12-29 17:14:15 +0000492# OS specific
493# Using uname is really, really broken. Once we have the right set of checks
Stefan Weil93148aa2012-02-26 18:46:12 +0100494# we can eliminate its usage altogether.
aliguoriac0df512008-12-29 17:14:15 +0000495
Peter Maydelle49d0212012-12-07 15:39:13 +0000496# Preferred compiler:
497# ${CC} (if set)
498# ${cross_prefix}gcc (if cross-prefix specified)
499# system compiler
500if test -z "${CC}${cross_prefix}"; then
501 cc="$host_cc"
502else
503 cc="${CC-${cross_prefix}gcc}"
504fi
505
Tomoki Sekiyama83f73fc2013-08-07 11:39:36 -0400506if test -z "${CXX}${cross_prefix}"; then
507 cxx="c++"
508else
509 cxx="${CXX-${cross_prefix}g++}"
510fi
511
Stuart Yoderb3198cc2011-08-04 17:10:08 -0500512ar="${AR-${cross_prefix}ar}"
Richard Hendersoncdbd7272016-07-07 21:49:36 -0700513as="${AS-${cross_prefix}as}"
Richard Henderson5f6f0e22016-06-23 10:39:18 -0700514ccas="${CCAS-$cc}"
Blue Swirl3dd46c72013-01-05 10:10:27 +0000515cpp="${CPP-$cc -E}"
Stuart Yoderb3198cc2011-08-04 17:10:08 -0500516objcopy="${OBJCOPY-${cross_prefix}objcopy}"
517ld="${LD-${cross_prefix}ld}"
Alistair Francis9f81aeb2017-11-07 17:10:46 -0800518ranlib="${RANLIB-${cross_prefix}ranlib}"
Stefan Weil4852ee92014-09-18 21:55:08 +0200519nm="${NM-${cross_prefix}nm}"
Stuart Yoderb3198cc2011-08-04 17:10:08 -0500520strip="${STRIP-${cross_prefix}strip}"
521windres="${WINDRES-${cross_prefix}windres}"
Sergei Trofimovich17884d72012-01-31 22:03:45 +0300522pkg_config_exe="${PKG_CONFIG-${cross_prefix}pkg-config}"
523query_pkg_config() {
524 "${pkg_config_exe}" ${QEMU_PKG_CONFIG_FLAGS} "$@"
525}
526pkg_config=query_pkg_config
Dave Airlie47c03742013-12-10 14:05:51 +1000527sdl2_config="${SDL2_CONFIG-${cross_prefix}sdl2-config}"
aliguoriac0df512008-12-29 17:14:15 +0000528
Peter Maydell45d285a2013-10-21 21:03:06 +0100529# If the user hasn't specified ARFLAGS, default to 'rv', just as make does.
530ARFLAGS="${ARFLAGS-rv}"
531
Michael S. Tsirkinbe17dc92009-11-11 13:50:09 +0200532# default flags for all hosts
Peter Maydell2d315152016-09-12 14:10:08 +0100533# We use -fwrapv to tell the compiler that we require a C dialect where
534# left shift of signed integers is well defined and has the expected
535# 2s-complement style results. (Both clang and gcc agree that it
536# provides these semantics.)
Paolo Bonzini086d5f72020-02-03 15:22:17 +0100537QEMU_CFLAGS="-fno-strict-aliasing -fno-common -fwrapv $QEMU_CFLAGS"
538QEMU_CFLAGS="-Wundef -Wwrite-strings -Wmissing-prototypes $QEMU_CFLAGS"
Kevin Wolfc95e3082013-02-22 21:08:51 +0100539QEMU_CFLAGS="-Wstrict-prototypes -Wredundant-decls $QEMU_CFLAGS"
Michael S. Tsirkinbe17dc92009-11-11 13:50:09 +0200540QEMU_CFLAGS="-D_GNU_SOURCE -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE $QEMU_CFLAGS"
Paolo Bonzini5770e8a2020-09-23 05:26:15 -0400541
542# Flags that are needed during configure but later taken care of by Meson
543CONFIGURE_CFLAGS="-std=gnu99 -Wall"
544CONFIGURE_LDFLAGS=
Paolo Bonzini086d5f72020-02-03 15:22:17 +0100545
Michael S. Tsirkinbe17dc92009-11-11 13:50:09 +0200546
aliguoriac0df512008-12-29 17:14:15 +0000547check_define() {
548cat > $TMPC <<EOF
549#if !defined($1)
Peter Maydellfd786e12011-11-23 17:26:43 +0000550#error $1 not defined
aliguoriac0df512008-12-29 17:14:15 +0000551#endif
552int main(void) { return 0; }
553EOF
Juan Quintela52166aa2009-08-03 14:46:03 +0200554 compile_object
aliguoriac0df512008-12-29 17:14:15 +0000555}
556
Gerd Hoffmann307119e2015-06-10 09:07:35 +0200557check_include() {
558cat > $TMPC <<EOF
559#include <$1>
560int main(void) { return 0; }
561EOF
562 compile_object
563}
564
John Snow93b25862015-03-25 18:57:37 -0400565write_c_skeleton() {
566 cat > $TMPC <<EOF
567int main(void) { return 0; }
568EOF
569}
570
Alexander Bulekovadc28022020-02-19 23:11:14 -0500571write_c_fuzzer_skeleton() {
572 cat > $TMPC <<EOF
573#include <stdint.h>
574#include <sys/types.h>
575int LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size);
576int LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size) { return 0; }
577EOF
578}
579
Peter Maydellbbea4052012-08-14 15:35:34 +0100580if check_define __linux__ ; then
581 targetos="Linux"
582elif check_define _WIN32 ; then
583 targetos='MINGW32'
584elif check_define __OpenBSD__ ; then
585 targetos='OpenBSD'
586elif check_define __sun__ ; then
587 targetos='SunOS'
588elif check_define __HAIKU__ ; then
589 targetos='Haiku'
Peter Maydell951fedf2017-07-13 16:15:32 +0100590elif check_define __FreeBSD__ ; then
591 targetos='FreeBSD'
592elif check_define __FreeBSD_kernel__ && check_define __GLIBC__; then
593 targetos='GNU/kFreeBSD'
594elif check_define __DragonFly__ ; then
595 targetos='DragonFly'
596elif check_define __NetBSD__; then
597 targetos='NetBSD'
598elif check_define __APPLE__; then
599 targetos='Darwin'
Peter Maydellbbea4052012-08-14 15:35:34 +0100600else
Peter Maydell951fedf2017-07-13 16:15:32 +0100601 # This is a fatal error, but don't report it yet, because we
602 # might be going to just print the --help text, or it might
603 # be the result of a missing compiler.
604 targetos='bogus'
605 bogus_os='yes'
Peter Maydellbbea4052012-08-14 15:35:34 +0100606fi
607
608# Some host OSes need non-standard checks for which CPU to use.
609# Note that these checks are broken for cross-compilation: if you're
610# cross-compiling to one of these OSes then you'll need to specify
611# the correct CPU with the --cpu option.
612case $targetos in
613Darwin)
614 # on Leopard most of the system is 32-bit, so we have to ask the kernel if we can
615 # run 64-bit userspace code.
616 # If the user didn't specify a CPU explicitly and the kernel says this is
617 # 64 bit hw, then assume x86_64. Otherwise fall through to the usual detection code.
618 if test -z "$cpu" && test "$(sysctl -n hw.optional.x86_64)" = "1"; then
619 cpu="x86_64"
620 fi
Gerd Hoffmann5869f8d2020-10-27 13:06:03 +0100621 HOST_DSOSUF=".dylib"
Peter Maydellbbea4052012-08-14 15:35:34 +0100622 ;;
623SunOS)
Stefan Weil89138852016-05-16 15:10:20 +0200624 # $(uname -m) returns i86pc even on an x86_64 box, so default based on isainfo
Peter Maydellbbea4052012-08-14 15:35:34 +0100625 if test -z "$cpu" && test "$(isainfo -k)" = "amd64"; then
626 cpu="x86_64"
627 fi
628esac
629
Juan Quintela2ff6b912009-08-03 14:45:55 +0200630if test ! -z "$cpu" ; then
631 # command line argument
632 :
633elif check_define __i386__ ; then
aliguoriac0df512008-12-29 17:14:15 +0000634 cpu="i386"
635elif check_define __x86_64__ ; then
Richard Hendersonc72b26e2013-08-20 12:20:05 -0700636 if check_define __ILP32__ ; then
637 cpu="x32"
638 else
639 cpu="x86_64"
640 fi
blueswir13aa9bd62008-12-31 16:55:26 +0000641elif check_define __sparc__ ; then
blueswir13aa9bd62008-12-31 16:55:26 +0000642 if check_define __arch64__ ; then
643 cpu="sparc64"
644 else
645 cpu="sparc"
646 fi
malcfdf7ed92009-01-14 18:39:52 +0000647elif check_define _ARCH_PPC ; then
648 if check_define _ARCH_PPC64 ; then
Richard Hendersonf8378ac2019-05-01 15:38:18 -0700649 if check_define _LITTLE_ENDIAN ; then
650 cpu="ppc64le"
651 else
652 cpu="ppc64"
653 fi
malcfdf7ed92009-01-14 18:39:52 +0000654 else
655 cpu="ppc"
656 fi
Aurelien Jarnoafa05232009-10-17 14:17:47 +0200657elif check_define __mips__ ; then
658 cpu="mips"
Aurelien Jarnod66ed0e2010-06-13 12:28:21 +0200659elif check_define __s390__ ; then
660 if check_define __s390x__ ; then
661 cpu="s390x"
662 else
663 cpu="s390"
664 fi
Alistair Francisc4f80542018-12-19 19:20:19 +0000665elif check_define __riscv ; then
666 if check_define _LP64 ; then
667 cpu="riscv64"
668 else
669 cpu="riscv32"
670 fi
Peter Maydell21d89f82011-11-30 10:57:48 +0100671elif check_define __arm__ ; then
672 cpu="arm"
Claudio Fontana1f080312013-06-12 16:20:23 +0100673elif check_define __aarch64__ ; then
674 cpu="aarch64"
aliguoriac0df512008-12-29 17:14:15 +0000675else
Stefan Weil89138852016-05-16 15:10:20 +0200676 cpu=$(uname -m)
aliguoriac0df512008-12-29 17:14:15 +0000677fi
678
Peter Maydell359bc952011-12-24 13:07:25 +0000679ARCH=
680# Normalise host CPU name and set ARCH.
681# Note that this case should only have supported host CPUs, not guests.
bellard7d132992003-03-06 23:23:54 +0000682case "$cpu" in
Thomas Huthee35e962019-09-28 21:03:34 +0200683 ppc|ppc64|s390x|sparc64|x32|riscv32|riscv64)
Peter Maydell898be3e2017-03-21 14:31:57 +0000684 ;;
Richard Hendersonf8378ac2019-05-01 15:38:18 -0700685 ppc64le)
686 ARCH="ppc64"
Richard Hendersonf8378ac2019-05-01 15:38:18 -0700687 ;;
bellard7d132992003-03-06 23:23:54 +0000688 i386|i486|i586|i686|i86pc|BePC)
bellard97a847b2003-08-10 21:36:04 +0000689 cpu="i386"
bellard7d132992003-03-06 23:23:54 +0000690 ;;
aurel32aaa5fa12008-04-11 22:04:22 +0000691 x86_64|amd64)
692 cpu="x86_64"
693 ;;
Peter Maydell21d89f82011-11-30 10:57:48 +0100694 armv*b|armv*l|arm)
695 cpu="arm"
bellard7d132992003-03-06 23:23:54 +0000696 ;;
Claudio Fontana1f080312013-06-12 16:20:23 +0100697 aarch64)
698 cpu="aarch64"
699 ;;
Aurelien Jarnoafa05232009-10-17 14:17:47 +0200700 mips*)
701 cpu="mips"
702 ;;
blueswir131422552007-04-16 18:27:06 +0000703 sparc|sun4[cdmuv])
bellardae228532003-05-13 18:59:59 +0000704 cpu="sparc"
705 ;;
bellard7d132992003-03-06 23:23:54 +0000706 *)
Peter Maydell359bc952011-12-24 13:07:25 +0000707 # This will result in either an error or falling back to TCI later
708 ARCH=unknown
bellard7d132992003-03-06 23:23:54 +0000709 ;;
710esac
Peter Maydell359bc952011-12-24 13:07:25 +0000711if test -z "$ARCH"; then
712 ARCH="$cpu"
713fi
Juan Quintelae2d52ad2009-08-12 18:20:24 +0200714
bellard7d132992003-03-06 23:23:54 +0000715# OS specific
Juan Quintela0dbfc672009-08-03 14:46:13 +0200716
bellard7d132992003-03-06 23:23:54 +0000717case $targetos in
bellard67b915a2004-03-31 23:37:16 +0000718MINGW32*)
Juan Quintela0dbfc672009-08-03 14:46:13 +0200719 mingw32="yes"
Paolo Bonzini299e6f12019-02-14 18:35:53 +0100720 vhost_user="no"
Kővágó, Zoltán3cec7cc2015-06-03 23:03:46 +0200721 audio_possible_drivers="dsound sdl"
Gerd Hoffmann307119e2015-06-10 09:07:35 +0200722 if check_include dsound.h; then
723 audio_drv_list="dsound"
724 else
725 audio_drv_list=""
726 fi
Peter Maydell898be3e2017-03-21 14:31:57 +0000727 supported_os="yes"
Daniel P. Berrangéfb648e92020-08-24 17:31:09 +0100728 pie="no"
bellard67b915a2004-03-31 23:37:16 +0000729;;
ths5c40d2b2007-06-23 16:03:36 +0000730GNU/kFreeBSD)
Aurelien Jarnoa167ba52009-11-29 18:00:41 +0100731 bsd="yes"
Gerd Hoffmann6a485412019-01-24 12:20:55 +0100732 audio_drv_list="oss try-sdl"
Kővágó, Zoltán0bac1112015-06-03 23:03:44 +0200733 audio_possible_drivers="oss sdl pa"
ths5c40d2b2007-06-23 16:03:36 +0000734;;
bellard7d3505c2004-05-12 19:32:15 +0000735FreeBSD)
Juan Quintela0dbfc672009-08-03 14:46:13 +0200736 bsd="yes"
Paolo Bonzini0db4a062010-12-23 11:43:49 +0100737 make="${MAKE-gmake}"
Gerd Hoffmann6a485412019-01-24 12:20:55 +0100738 audio_drv_list="oss try-sdl"
Kővágó, Zoltán0bac1112015-06-03 23:03:44 +0200739 audio_possible_drivers="oss sdl pa"
Juergen Lockf01576f2010-03-25 22:32:16 +0100740 # needed for kinfo_getvmmap(3) in libutil.h
Vincenzo Maffione58952132013-11-06 11:44:06 +0100741 netmap="" # enable netmap autodetect
bellard7d3505c2004-05-12 19:32:15 +0000742;;
blueswir1c5e97232009-03-07 20:06:23 +0000743DragonFly)
Juan Quintela0dbfc672009-08-03 14:46:13 +0200744 bsd="yes"
Paolo Bonzini0db4a062010-12-23 11:43:49 +0100745 make="${MAKE-gmake}"
Gerd Hoffmann6a485412019-01-24 12:20:55 +0100746 audio_drv_list="oss try-sdl"
Kővágó, Zoltán0bac1112015-06-03 23:03:44 +0200747 audio_possible_drivers="oss sdl pa"
blueswir1c5e97232009-03-07 20:06:23 +0000748;;
bellard7d3505c2004-05-12 19:32:15 +0000749NetBSD)
Juan Quintela0dbfc672009-08-03 14:46:13 +0200750 bsd="yes"
Paolo Bonzini0db4a062010-12-23 11:43:49 +0100751 make="${MAKE-gmake}"
Gerd Hoffmann6a485412019-01-24 12:20:55 +0100752 audio_drv_list="oss try-sdl"
Kővágó, Zoltán0bac1112015-06-03 23:03:44 +0200753 audio_possible_drivers="oss sdl"
Juan Quintela0dbfc672009-08-03 14:46:13 +0200754 oss_lib="-lossaudio"
bellard7d3505c2004-05-12 19:32:15 +0000755;;
756OpenBSD)
Juan Quintela0dbfc672009-08-03 14:46:13 +0200757 bsd="yes"
Paolo Bonzini0db4a062010-12-23 11:43:49 +0100758 make="${MAKE-gmake}"
Gerd Hoffmannf92c7162019-01-24 12:20:52 +0100759 audio_drv_list="try-sdl"
Kővágó, Zoltán0bac1112015-06-03 23:03:44 +0200760 audio_possible_drivers="sdl"
bellard7d3505c2004-05-12 19:32:15 +0000761;;
bellard83fb7ad2004-07-05 21:25:26 +0000762Darwin)
Juan Quintela0dbfc672009-08-03 14:46:13 +0200763 bsd="yes"
764 darwin="yes"
Juan Quintela0dbfc672009-08-03 14:46:13 +0200765 if [ "$cpu" = "x86_64" ] ; then
Juan Quintelaa558ee12009-08-03 14:46:21 +0200766 QEMU_CFLAGS="-arch x86_64 $QEMU_CFLAGS"
Paolo Bonzinidb5adea2019-12-11 15:34:27 +0100767 QEMU_LDFLAGS="-arch x86_64 $QEMU_LDFLAGS"
Juan Quintela0dbfc672009-08-03 14:46:13 +0200768 fi
Paolo Bonzinib4e312e2020-09-01 11:28:59 -0400769 cocoa="enabled"
Gerd Hoffmann6a485412019-01-24 12:20:55 +0100770 audio_drv_list="coreaudio try-sdl"
Kővágó, Zoltán14382602015-06-03 23:03:45 +0200771 audio_possible_drivers="coreaudio sdl"
Paolo Bonzinidb5adea2019-12-11 15:34:27 +0100772 QEMU_LDFLAGS="-framework CoreFoundation -framework IOKit $QEMU_LDFLAGS"
Peter Maydella0b7cf62012-08-11 22:34:39 +0100773 # Disable attempts to use ObjectiveC features in os/object.h since they
774 # won't work when we're compiling with gcc as a C compiler.
775 QEMU_CFLAGS="-DOS_OBJECT_USE_OBJC=0 $QEMU_CFLAGS"
bellard83fb7ad2004-07-05 21:25:26 +0000776;;
bellardec530c82006-04-25 22:36:06 +0000777SunOS)
Juan Quintela0dbfc672009-08-03 14:46:13 +0200778 solaris="yes"
Paolo Bonzini0db4a062010-12-23 11:43:49 +0100779 make="${MAKE-gmake}"
Brade2d88302011-09-02 16:53:28 -0400780 smbd="${SMBD-/usr/sfw/sbin/smbd}"
Juan Quintela0dbfc672009-08-03 14:46:13 +0200781 if test -f /usr/include/sys/soundcard.h ; then
Gerd Hoffmann6a485412019-01-24 12:20:55 +0100782 audio_drv_list="oss try-sdl"
Juan Quintela0dbfc672009-08-03 14:46:13 +0200783 fi
784 audio_possible_drivers="oss sdl"
Blue Swirld7414292009-09-12 12:36:04 +0000785# needed for CMSG_ macros in sys/socket.h
786 QEMU_CFLAGS="-D_XOPEN_SOURCE=600 $QEMU_CFLAGS"
787# needed for TIOCWIN* defines in termios.h
788 QEMU_CFLAGS="-D__EXTENSIONS__ $QEMU_CFLAGS"
ths86b2bd92007-02-11 00:31:33 +0000789;;
Andreas Färber179cf402010-09-20 00:50:43 +0200790Haiku)
791 haiku="yes"
David CARLIERfc433432020-07-13 14:36:08 +0100792 QEMU_CFLAGS="-DB_USE_POSITIVE_POSIX_ERRORS -DBSD_SOURCE $QEMU_CFLAGS"
Andreas Färber179cf402010-09-20 00:50:43 +0200793;;
Peter Maydell898be3e2017-03-21 14:31:57 +0000794Linux)
Gerd Hoffmann71838342019-02-19 13:42:57 +0100795 audio_drv_list="try-pa oss"
Kővágó, Zoltán0bac1112015-06-03 23:03:44 +0200796 audio_possible_drivers="oss alsa sdl pa"
Juan Quintela0dbfc672009-08-03 14:46:13 +0200797 linux="yes"
798 linux_user="yes"
Peter Maydell898be3e2017-03-21 14:31:57 +0000799;;
bellard7d132992003-03-06 23:23:54 +0000800esac
801
bellard7d3505c2004-05-12 19:32:15 +0000802if [ "$bsd" = "yes" ] ; then
pbrookb1a550a2006-04-16 13:28:56 +0000803 if [ "$darwin" != "yes" ] ; then
Andreas Färber08de3942012-04-26 11:57:39 +0200804 bsd_user="yes"
bellard83fb7ad2004-07-05 21:25:26 +0000805 fi
bellard7d3505c2004-05-12 19:32:15 +0000806fi
807
Paolo Bonzini0db4a062010-12-23 11:43:49 +0100808: ${make=${MAKE-make}}
Paolo Bonzinib6daf4d2020-09-01 06:38:04 -0400809
Daniel P. Berrangéfaf44142019-03-27 17:07:01 +0000810# We prefer python 3.x. A bare 'python' is traditionally
811# python 2.x, but some distros have it as python 3.x, so
Eduardo Habkostddf90692019-10-16 19:42:37 -0300812# we check that too
Daniel P. Berrangéfaf44142019-03-27 17:07:01 +0000813python=
Marc-André Lureau0a01d762019-08-21 11:21:16 +0400814explicit_python=no
Eduardo Habkostddf90692019-10-16 19:42:37 -0300815for binary in "${PYTHON-python3}" python
Daniel P. Berrangéfaf44142019-03-27 17:07:01 +0000816do
817 if has "$binary"
818 then
Paolo Bonzini95c5f2d2019-06-10 12:03:44 +0200819 python=$(command -v "$binary")
Daniel P. Berrangéfaf44142019-03-27 17:07:01 +0000820 break
821 fi
822done
Markus Armbruster903458c2020-02-14 18:18:41 +0100823
Markus Armbruster903458c2020-02-14 18:18:41 +0100824
Alex Bennée39d87c82020-03-03 15:06:20 +0000825# Check for ancillary tools used in testing
826genisoimage=
Alex Bennée3df437c2020-05-19 09:22:48 -0400827for binary in genisoimage mkisofs
Alex Bennée39d87c82020-03-03 15:06:20 +0000828do
829 if has $binary
830 then
831 genisoimage=$(command -v "$binary")
832 break
833 fi
834done
835
Brade2d88302011-09-02 16:53:28 -0400836: ${smbd=${SMBD-/usr/sbin/smbd}}
Paolo Bonzini0db4a062010-12-23 11:43:49 +0100837
Peter Maydell3c4a4d02012-08-11 22:34:40 +0100838# Default objcc to clang if available, otherwise use CC
839if has clang; then
840 objcc=clang
841else
842 objcc="$cc"
843fi
844
Juan Quintela3457a3f2009-08-03 14:46:07 +0200845if test "$mingw32" = "yes" ; then
Juan Quintela3457a3f2009-08-03 14:46:07 +0200846 EXESUF=".exe"
Paolo Bonzini484e2cc2019-12-12 13:30:36 +0100847 HOST_DSOSUF=".dll"
Stefan Weil78e9d4a2015-11-26 12:13:12 +0100848 # MinGW needs -mthreads for TLS and macro _MT.
Paolo Bonzini5770e8a2020-09-23 05:26:15 -0400849 CONFIGURE_CFLAGS="-mthreads $CONFIGURE_CFLAGS"
John Snow93b25862015-03-25 18:57:37 -0400850 write_c_skeleton;
Paolo Bonzinid17f3052020-08-18 12:17:01 +0200851 prefix="/qemu"
Marc-André Lureau77433a52020-08-26 15:04:12 +0400852 qemu_suffix=""
Bishara AbuHattoum105fad62017-08-22 16:55:04 +0300853 libs_qga="-lws2_32 -lwinmm -lpowrprof -lwtsapi32 -lwininet -liphlpapi -lnetapi32 $libs_qga"
Juan Quintela3457a3f2009-08-03 14:46:07 +0200854fi
855
Anthony Liguori487fefd2009-06-11 13:28:25 -0500856werror=""
bellard85aa5182007-11-11 20:17:03 +0000857
bellard7d132992003-03-06 23:23:54 +0000858for opt do
Stefan Weil89138852016-05-16 15:10:20 +0200859 optarg=$(expr "x$opt" : 'x[^=]*=\(.*\)')
bellard7d132992003-03-06 23:23:54 +0000860 case "$opt" in
bellard2efc3262005-12-18 19:14:49 +0000861 --help|-h) show_help=yes
862 ;;
Mike Frysinger99123e12011-04-07 01:12:28 -0400863 --version|-V) exec cat $source_path/VERSION
864 ;;
pbrookb1a550a2006-04-16 13:28:56 +0000865 --prefix=*) prefix="$optarg"
bellard7d132992003-03-06 23:23:54 +0000866 ;;
pbrookb1a550a2006-04-16 13:28:56 +0000867 --interp-prefix=*) interp_prefix="$optarg"
bellard32ce6332003-04-11 00:16:16 +0000868 ;;
aliguoriac0df512008-12-29 17:14:15 +0000869 --cross-prefix=*)
bellard7d132992003-03-06 23:23:54 +0000870 ;;
aliguoriac0df512008-12-29 17:14:15 +0000871 --cc=*)
bellard7d132992003-03-06 23:23:54 +0000872 ;;
pbrookb1a550a2006-04-16 13:28:56 +0000873 --host-cc=*) host_cc="$optarg"
bellard83469012005-07-23 14:27:54 +0000874 ;;
Tomoki Sekiyama83f73fc2013-08-07 11:39:36 -0400875 --cxx=*)
876 ;;
Michael S. Tsirkine007dbe2013-11-24 11:38:05 +0200877 --iasl=*) iasl="$optarg"
878 ;;
Peter Maydell3c4a4d02012-08-11 22:34:40 +0100879 --objcc=*) objcc="$optarg"
880 ;;
pbrookb1a550a2006-04-16 13:28:56 +0000881 --make=*) make="$optarg"
bellard7d132992003-03-06 23:23:54 +0000882 ;;
Paolo Bonzinib6daf4d2020-09-01 06:38:04 -0400883 --install=*)
pbrook6a882642006-04-17 13:57:12 +0000884 ;;
Marc-André Lureau0a01d762019-08-21 11:21:16 +0400885 --python=*) python="$optarg" ; explicit_python=yes
Blue Swirlc886edf2011-07-22 21:08:09 +0000886 ;;
Peter Maydell2eb054c2020-02-13 17:56:18 +0000887 --sphinx-build=*) sphinx_build="$optarg"
888 ;;
Paolo Bonzinia5665052019-06-10 12:05:14 +0200889 --skip-meson) skip_meson=yes
890 ;;
891 --meson=*) meson="$optarg"
892 ;;
Paolo Bonzini48328882020-08-26 08:04:15 +0200893 --ninja=*) ninja="$optarg"
894 ;;
Brade2d88302011-09-02 16:53:28 -0400895 --smbd=*) smbd="$optarg"
896 ;;
Juan Quintelae2a2ed02009-08-03 14:46:02 +0200897 --extra-cflags=*)
bellard7d132992003-03-06 23:23:54 +0000898 ;;
Bruno Dominguez11cde1c2017-06-06 14:07:47 +0100899 --extra-cxxflags=*)
900 ;;
Juan Quintelae2a2ed02009-08-03 14:46:02 +0200901 --extra-ldflags=*)
bellard7d132992003-03-06 23:23:54 +0000902 ;;
Gerd Hoffmann5bc62e02012-02-08 13:54:13 +0100903 --enable-debug-info)
904 ;;
905 --disable-debug-info)
906 ;;
Alex Bennéed75402b2018-04-04 20:27:05 +0100907 --cross-cc-*)
908 ;;
Fam Zheng17969262014-02-10 14:48:56 +0800909 --enable-modules)
910 modules="yes"
911 ;;
Stefan Hajnoczi3aa88b32015-11-02 14:06:23 +0000912 --disable-modules)
913 modules="no"
914 ;;
Christian Ehrhardtbd83c862020-03-10 15:58:06 +0100915 --disable-module-upgrades) module_upgrades="no"
916 ;;
917 --enable-module-upgrades) module_upgrades="yes"
918 ;;
Juan Quintela2ff6b912009-08-03 14:45:55 +0200919 --cpu=*)
bellard7d132992003-03-06 23:23:54 +0000920 ;;
pbrookb1a550a2006-04-16 13:28:56 +0000921 --target-list=*) target_list="$optarg"
Alex Bennée447e1332019-03-19 11:59:12 +0000922 if test "$target_list_exclude"; then
923 error_exit "Can't mix --target-list with --target-list-exclude"
924 fi
925 ;;
926 --target-list-exclude=*) target_list_exclude="$optarg"
927 if test "$target_list"; then
928 error_exit "Can't mix --target-list-exclude with --target-list"
929 fi
bellardde83cd02003-06-15 20:25:43 +0000930 ;;
Lluís Vilanova5b808272014-05-27 15:02:14 +0200931 --enable-trace-backends=*) trace_backends="$optarg"
932 ;;
933 # XXX: backwards compatibility
934 --enable-trace-backend=*) trace_backends="$optarg"
Stefan Hajnoczi94a420b2010-05-22 17:52:39 +0100935 ;;
Paolo Bonzini74242e02010-12-23 11:44:02 +0100936 --with-trace-file=*) trace_file="$optarg"
Prerna Saxena9410b562010-07-13 09:26:32 +0100937 ;;
Paolo Bonzinif3494742019-01-23 14:56:17 +0800938 --with-default-devices) default_devices="yes"
939 ;;
940 --without-default-devices) default_devices="no"
941 ;;
bellard7d132992003-03-06 23:23:54 +0000942 --enable-gprof) gprof="yes"
943 ;;
Blue Swirl1d728c32012-05-01 18:45:39 +0000944 --enable-gcov) gcov="yes"
945 ;;
Loïc Minier79427692010-01-31 12:23:45 +0100946 --static)
947 static="yes"
Sergei Trofimovich17884d72012-01-31 22:03:45 +0300948 QEMU_PKG_CONFIG_FLAGS="--static $QEMU_PKG_CONFIG_FLAGS"
bellard43ce4df2003-06-09 19:53:12 +0000949 ;;
Paolo Bonzini0b24e752010-05-26 16:08:26 +0200950 --mandir=*) mandir="$optarg"
951 ;;
952 --bindir=*) bindir="$optarg"
953 ;;
Alon Levy3aa5d2b2011-05-15 12:08:59 +0300954 --libdir=*) libdir="$optarg"
955 ;;
Michael Tokarev8bf188a2012-06-07 01:11:00 +0400956 --libexecdir=*) libexecdir="$optarg"
957 ;;
Alon Levy0f94d6d2011-06-27 11:58:20 +0200958 --includedir=*) includedir="$optarg"
959 ;;
Eduardo Habkost528ae5b2012-04-18 16:55:49 -0300960 --datadir=*) datadir="$optarg"
Paolo Bonzini0b24e752010-05-26 16:08:26 +0200961 ;;
Marc-André Lureau77433a52020-08-26 15:04:12 +0400962 --with-suffix=*) qemu_suffix="$optarg"
Eduardo Habkost023d3d62012-04-18 16:55:50 -0300963 ;;
Bruce Rogersc6502632020-10-15 13:07:42 -0600964 --docdir=*) docdir="$optarg"
Paolo Bonzini0b24e752010-05-26 16:08:26 +0200965 ;;
Paolo Bonzinife0038b2020-10-16 04:35:10 -0400966 --localedir=*) localedir="$optarg"
967 ;;
Andre Przywaraca2fb932010-03-08 14:09:48 +0100968 --sysconfdir=*) sysconfdir="$optarg"
Anthony Liguori07381cc2010-01-21 10:30:29 -0600969 ;;
Luiz Capitulino785c23a2012-10-03 18:35:57 -0300970 --localstatedir=*) local_statedir="$optarg"
971 ;;
Gerd Hoffmann3d5eeca2017-09-14 13:42:36 +0200972 --firmwarepath=*) firmwarepath="$optarg"
973 ;;
Olaf Hering181ce1d2018-04-18 09:50:44 +0200974 --host=*|--build=*|\
975 --disable-dependency-tracking|\
Luiz Capitulino785c23a2012-10-03 18:35:57 -0300976 --sbindir=*|--sharedstatedir=*|\
Paolo Bonzinife0038b2020-10-16 04:35:10 -0400977 --oldincludedir=*|--datarootdir=*|--infodir=*|\
Max Filippov023ddd72011-11-24 16:11:31 +0400978 --htmldir=*|--dvidir=*|--pdfdir=*|--psdir=*)
979 # These switches are silently ignored, for compatibility with
980 # autoconf-generated configure scripts. This allows QEMU's
981 # configure to be used by RPM and similar macros that set
982 # lots of directory switches by default.
983 ;;
Paolo Bonzini35be72b2020-02-06 14:17:15 +0100984 --disable-sdl) sdl="disabled"
bellard97a847b2003-08-10 21:36:04 +0000985 ;;
Paolo Bonzini35be72b2020-02-06 14:17:15 +0100986 --enable-sdl) sdl="enabled"
Juan Quintelac4198152009-08-12 18:29:53 +0200987 ;;
Paolo Bonzini35be72b2020-02-06 14:17:15 +0100988 --disable-sdl-image) sdl_image="disabled"
Daniel P. Berrangéa442fe22019-01-10 12:00:47 +0000989 ;;
Paolo Bonzini35be72b2020-02-06 14:17:15 +0100990 --enable-sdl-image) sdl_image="enabled"
Daniel P. Berrangéa442fe22019-01-10 12:00:47 +0000991 ;;
Paolo Bonzini3556c232013-05-10 14:16:40 +0200992 --disable-qom-cast-debug) qom_cast_debug="no"
993 ;;
994 --enable-qom-cast-debug) qom_cast_debug="yes"
995 ;;
Meador Inge983eef52012-02-24 14:00:42 +0530996 --disable-virtfs) virtfs="no"
997 ;;
998 --enable-virtfs) virtfs="yes"
999 ;;
Paolo Bonzini5c530152020-10-15 06:09:27 -04001000 --disable-libudev) libudev="disabled"
1001 ;;
1002 --enable-libudev) libudev="enabled"
1003 ;;
Misono Tomohirocece1162020-10-08 19:31:33 +09001004 --disable-virtiofsd) virtiofsd="disabled"
1005 ;;
1006 --enable-virtiofsd) virtiofsd="enabled"
1007 ;;
Paolo Bonzini6ec0e152020-09-16 18:07:29 +02001008 --disable-mpath) mpath="disabled"
Paolo Bonzinife8fc5a2017-08-22 06:50:55 +02001009 ;;
Paolo Bonzini6ec0e152020-09-16 18:07:29 +02001010 --enable-mpath) mpath="enabled"
Paolo Bonzinife8fc5a2017-08-22 06:50:55 +02001011 ;;
Paolo Bonzinia0b93232020-02-06 15:48:52 +01001012 --disable-vnc) vnc="disabled"
Jes Sorensen821601e2011-03-16 13:33:36 +01001013 ;;
Paolo Bonzinia0b93232020-02-06 15:48:52 +01001014 --enable-vnc) vnc="enabled"
Jes Sorensen821601e2011-03-16 13:33:36 +01001015 ;;
Marc-André Lureaue8f3bd72019-09-19 21:02:09 +04001016 --disable-gettext) gettext="false"
1017 ;;
1018 --enable-gettext) gettext="true"
1019 ;;
blueswir12f6a1ab2008-08-21 18:00:53 +00001020 --oss-lib=*) oss_lib="$optarg"
1021 ;;
malc0c58ac12008-06-25 21:04:05 +00001022 --audio-drv-list=*) audio_drv_list="$optarg"
1023 ;;
Stefan Weil89138852016-05-16 15:10:20 +02001024 --block-drv-rw-whitelist=*|--block-drv-whitelist=*) block_drv_rw_whitelist=$(echo "$optarg" | sed -e 's/,/ /g')
Fam Zhengb64ec4e2013-05-29 19:35:40 +08001025 ;;
Stefan Weil89138852016-05-16 15:10:20 +02001026 --block-drv-ro-whitelist=*) block_drv_ro_whitelist=$(echo "$optarg" | sed -e 's/,/ /g')
Markus Armbrustereb852012009-10-27 18:41:44 +01001027 ;;
aurel32f8393942009-04-13 18:45:38 +00001028 --enable-debug-tcg) debug_tcg="yes"
1029 ;;
1030 --disable-debug-tcg) debug_tcg="no"
1031 ;;
Paul Brookf3d08ee2009-06-04 11:39:04 +01001032 --enable-debug)
1033 # Enable debugging options that aren't excessively noisy
1034 debug_tcg="yes"
Peter Xu1fcc6d42018-04-25 10:54:59 +08001035 debug_mutex="yes"
Paul Brookf3d08ee2009-06-04 11:39:04 +01001036 debug="yes"
1037 strip_opt="no"
John Snowb553a042015-11-03 15:43:42 -05001038 fortify_source="no"
Paul Brookf3d08ee2009-06-04 11:39:04 +01001039 ;;
Marc-André Lureau247724c2018-01-16 16:11:51 +01001040 --enable-sanitizers) sanitizers="yes"
1041 ;;
1042 --disable-sanitizers) sanitizers="no"
1043 ;;
Lingfeng Yang0aebab02020-06-12 20:02:23 +01001044 --enable-tsan) tsan="yes"
1045 ;;
1046 --disable-tsan) tsan="no"
1047 ;;
Paolo Bonzinideb62372020-09-01 07:51:16 -04001048 --enable-sparse) sparse="enabled"
aliguori03b4fe72008-10-07 19:16:17 +00001049 ;;
Paolo Bonzinideb62372020-09-01 07:51:16 -04001050 --disable-sparse) sparse="disabled"
aliguori03b4fe72008-10-07 19:16:17 +00001051 ;;
aliguori1625af82009-04-05 17:41:02 +00001052 --disable-strip) strip_opt="no"
1053 ;;
Paolo Bonzinia0b93232020-02-06 15:48:52 +01001054 --disable-vnc-sasl) vnc_sasl="disabled"
aliguori2f9606b2009-03-06 20:27:28 +00001055 ;;
Paolo Bonzinia0b93232020-02-06 15:48:52 +01001056 --enable-vnc-sasl) vnc_sasl="enabled"
Juan Quintelaea784e32009-08-12 18:20:29 +02001057 ;;
Paolo Bonzinia0b93232020-02-06 15:48:52 +01001058 --disable-vnc-jpeg) vnc_jpeg="disabled"
Corentin Chary2f6f5c72010-07-07 20:57:49 +02001059 ;;
Paolo Bonzinia0b93232020-02-06 15:48:52 +01001060 --enable-vnc-jpeg) vnc_jpeg="enabled"
Corentin Chary2f6f5c72010-07-07 20:57:49 +02001061 ;;
Paolo Bonzinia0b93232020-02-06 15:48:52 +01001062 --disable-vnc-png) vnc_png="disabled"
Corentin Charyefe556a2010-07-07 20:57:56 +02001063 ;;
Paolo Bonzinia0b93232020-02-06 15:48:52 +01001064 --enable-vnc-png) vnc_png="enabled"
Corentin Charyefe556a2010-07-07 20:57:56 +02001065 ;;
Paolo Bonzini4d34a862020-10-05 11:31:15 +02001066 --disable-slirp) slirp="disabled"
bellard1d14ffa2005-10-30 18:58:22 +00001067 ;;
Paolo Bonzini4d34a862020-10-05 11:31:15 +02001068 --enable-slirp=git) slirp="internal"
Marc-André Lureau7c57bdd82019-04-24 13:00:41 +02001069 ;;
Marc-André Lureau675b9b52019-02-12 17:25:23 +01001070 --enable-slirp=system) slirp="system"
1071 ;;
aliguorie0e6c8c02008-07-23 18:14:33 +00001072 --disable-vde) vde="no"
ths8a16d272008-07-19 09:56:24 +00001073 ;;
Juan Quinteladfb278b2009-08-12 18:20:27 +02001074 --enable-vde) vde="yes"
1075 ;;
Vincenzo Maffione58952132013-11-06 11:44:06 +01001076 --disable-netmap) netmap="no"
1077 ;;
1078 --enable-netmap) netmap="yes"
1079 ;;
Paolo Bonzini1badb702020-09-18 04:57:25 -04001080 --disable-xen) xen="disabled"
aliguorie37630c2009-04-22 15:19:10 +00001081 ;;
Paolo Bonzini1badb702020-09-18 04:57:25 -04001082 --enable-xen) xen="enabled"
Juan Quintelafc321b42009-08-12 18:29:55 +02001083 ;;
Paolo Bonzini1badb702020-09-18 04:57:25 -04001084 --disable-xen-pci-passthrough) xen_pci_passthrough="disabled"
Anthony PERARDeb6fda02012-06-21 15:32:59 +00001085 ;;
Paolo Bonzini1badb702020-09-18 04:57:25 -04001086 --enable-xen-pci-passthrough) xen_pci_passthrough="enabled"
Anthony PERARDeb6fda02012-06-21 15:32:59 +00001087 ;;
aurel322e4d9fb2008-04-08 06:01:02 +00001088 --disable-brlapi) brlapi="no"
1089 ;;
Juan Quintela4ffcedb2009-08-12 18:20:26 +02001090 --enable-brlapi) brlapi="yes"
1091 ;;
Paolo Bonzini1badb702020-09-18 04:57:25 -04001092 --disable-kvm) kvm="disabled"
aliguori7ba1e612008-11-05 16:04:33 +00001093 ;;
Paolo Bonzini1badb702020-09-18 04:57:25 -04001094 --enable-kvm) kvm="enabled"
Juan Quintelab31a0272009-08-12 18:29:56 +02001095 ;;
Paolo Bonzini1badb702020-09-18 04:57:25 -04001096 --disable-hax) hax="disabled"
zhanghailiang180fb752016-10-27 14:43:08 +08001097 ;;
Paolo Bonzini1badb702020-09-18 04:57:25 -04001098 --enable-hax) hax="enabled"
zhanghailiang180fb752016-10-27 14:43:08 +08001099 ;;
Paolo Bonzini1badb702020-09-18 04:57:25 -04001100 --disable-hvf) hvf="disabled"
Sergio Andres Gomez Del Realc97d6d22017-09-13 04:05:09 -05001101 ;;
Paolo Bonzini1badb702020-09-18 04:57:25 -04001102 --enable-hvf) hvf="enabled"
Sergio Andres Gomez Del Realc97d6d22017-09-13 04:05:09 -05001103 ;;
Paolo Bonzini1badb702020-09-18 04:57:25 -04001104 --disable-whpx) whpx="disabled"
Justin Terry (VM)d661d9a2018-01-22 13:07:46 -08001105 ;;
Paolo Bonzini1badb702020-09-18 04:57:25 -04001106 --enable-whpx) whpx="enabled"
Justin Terry (VM)d661d9a2018-01-22 13:07:46 -08001107 ;;
Stefan Weil9195b2c2011-10-19 07:07:18 +02001108 --disable-tcg-interpreter) tcg_interpreter="no"
1109 ;;
1110 --enable-tcg-interpreter) tcg_interpreter="yes"
1111 ;;
Corey Bryant47e98652012-01-26 09:42:26 -05001112 --disable-cap-ng) cap_ng="no"
1113 ;;
1114 --enable-cap-ng) cap_ng="yes"
1115 ;;
Paolo Bonzini1badb702020-09-18 04:57:25 -04001116 --disable-tcg) tcg="disabled"
Paolo Bonzinib3f6ea72017-07-03 16:59:07 +02001117 ;;
Paolo Bonzini1badb702020-09-18 04:57:25 -04001118 --enable-tcg) tcg="enabled"
Paolo Bonzinib3f6ea72017-07-03 16:59:07 +02001119 ;;
Paolo Bonziniaa087962020-09-01 11:15:30 -04001120 --disable-malloc-trim) malloc_trim="disabled"
Yang Zhong5a22ab72017-12-20 21:16:46 +08001121 ;;
Paolo Bonziniaa087962020-09-01 11:15:30 -04001122 --enable-malloc-trim) malloc_trim="enabled"
Yang Zhong5a22ab72017-12-20 21:16:46 +08001123 ;;
Gerd Hoffmanncd4ec0b2010-03-24 10:26:51 +01001124 --disable-spice) spice="no"
1125 ;;
1126 --enable-spice) spice="yes"
1127 ;;
Ronnie Sahlbergc589b242011-10-25 19:24:24 +11001128 --disable-libiscsi) libiscsi="no"
1129 ;;
1130 --enable-libiscsi) libiscsi="yes"
1131 ;;
Peter Lieven6542aa92014-02-03 10:26:13 +01001132 --disable-libnfs) libnfs="no"
1133 ;;
1134 --enable-libnfs) libnfs="yes"
1135 ;;
bellard05c2a3e2006-02-08 22:39:17 +00001136 --enable-profiler) profiler="yes"
1137 ;;
Paolo Bonzinib4e312e2020-09-01 11:28:59 -04001138 --disable-cocoa) cocoa="disabled"
Pavel Borzenkov14821032011-11-10 22:40:07 +04001139 ;;
malcc2de5c92008-06-28 19:13:06 +00001140 --enable-cocoa)
Paolo Bonzinib4e312e2020-09-01 11:28:59 -04001141 cocoa="enabled" ;
Stefan Weil89138852016-05-16 15:10:20 +02001142 audio_drv_list="coreaudio $(echo $audio_drv_list | sed s,coreaudio,,g)"
bellard1d14ffa2005-10-30 18:58:22 +00001143 ;;
pbrookcad25d62006-03-19 16:31:11 +00001144 --disable-system) softmmu="no"
pbrook0a8e90f2006-03-19 14:54:16 +00001145 ;;
pbrookcad25d62006-03-19 16:31:11 +00001146 --enable-system) softmmu="yes"
pbrook0a8e90f2006-03-19 14:54:16 +00001147 ;;
Zachary Amsden0953a802009-07-30 00:14:59 -10001148 --disable-user)
1149 linux_user="no" ;
1150 bsd_user="no" ;
Zachary Amsden0953a802009-07-30 00:14:59 -10001151 ;;
1152 --enable-user) ;;
ths831b7822007-01-18 20:06:33 +00001153 --disable-linux-user) linux_user="no"
pbrook0a8e90f2006-03-19 14:54:16 +00001154 ;;
ths831b7822007-01-18 20:06:33 +00001155 --enable-linux-user) linux_user="yes"
1156 ;;
blueswir184778502008-10-26 20:33:16 +00001157 --disable-bsd-user) bsd_user="no"
1158 ;;
1159 --enable-bsd-user) bsd_user="yes"
1160 ;;
Avi Kivity40d64442011-11-15 20:12:17 +02001161 --enable-pie) pie="yes"
Kirill A. Shutemov34005a02009-09-12 02:17:55 +03001162 ;;
Avi Kivity40d64442011-11-15 20:12:17 +02001163 --disable-pie) pie="no"
Kirill A. Shutemov34005a02009-09-12 02:17:55 +03001164 ;;
bellard85aa5182007-11-11 20:17:03 +00001165 --enable-werror) werror="yes"
1166 ;;
1167 --disable-werror) werror="no"
1168 ;;
Steven Noonan63678e12014-03-28 17:19:02 +01001169 --enable-stack-protector) stack_protector="yes"
1170 ;;
1171 --disable-stack-protector) stack_protector="no"
1172 ;;
Daniele Buono1e4f6062020-05-29 16:51:21 -04001173 --enable-safe-stack) safe_stack="yes"
1174 ;;
1175 --disable-safe-stack) safe_stack="no"
1176 ;;
Yonggang Luo5285e592020-10-13 07:43:48 +08001177 --disable-curses) curses="disabled"
balrog4d3b6f62008-02-10 16:33:14 +00001178 ;;
Yonggang Luo5285e592020-10-13 07:43:48 +08001179 --enable-curses) curses="enabled"
Juan Quintelac584a6d2009-08-12 18:20:30 +02001180 ;;
Yonggang Luo5285e592020-10-13 07:43:48 +08001181 --disable-iconv) iconv="disabled"
Samuel Thibaulte08bb302019-03-11 14:51:26 +01001182 ;;
Yonggang Luo5285e592020-10-13 07:43:48 +08001183 --enable-iconv) iconv="enabled"
Samuel Thibaulte08bb302019-03-11 14:51:26 +01001184 ;;
Alexander Graf769ce762009-05-11 17:41:42 +02001185 --disable-curl) curl="no"
1186 ;;
Juan Quintela788c8192009-08-12 18:29:47 +02001187 --enable-curl) curl="yes"
1188 ;;
Paolo Bonzinifbb41212020-10-05 11:31:15 +02001189 --disable-fdt) fdt="disabled"
Juan Quintela2df87df2009-08-12 18:29:54 +02001190 ;;
Paolo Bonzinifbb41212020-10-05 11:31:15 +02001191 --enable-fdt) fdt="enabled"
1192 ;;
1193 --enable-fdt=git) fdt="internal"
1194 ;;
1195 --enable-fdt=system) fdt="system"
Juan Quintela2df87df2009-08-12 18:29:54 +02001196 ;;
Christoph Hellwig5c6c3a62009-08-20 16:58:35 +02001197 --disable-linux-aio) linux_aio="no"
1198 ;;
1199 --enable-linux-aio) linux_aio="yes"
1200 ;;
Aarushi Mehtac10dd852020-01-20 14:18:44 +00001201 --disable-linux-io-uring) linux_io_uring="no"
1202 ;;
1203 --enable-linux-io-uring) linux_io_uring="yes"
1204 ;;
Venkateswararao Jujjuri (JV)758e8e32010-06-14 13:34:41 -07001205 --disable-attr) attr="no"
1206 ;;
1207 --enable-attr) attr="yes"
1208 ;;
Paolo Bonzinia40161c2018-02-16 10:05:23 +01001209 --disable-membarrier) membarrier="no"
1210 ;;
1211 --enable-membarrier) membarrier="yes"
1212 ;;
Paolo Bonzinic8d54502020-10-16 03:32:52 -04001213 --disable-blobs) blobs="false"
ths77755342008-11-27 15:45:16 +00001214 ;;
Thomas Huth7e563bf2018-02-15 12:06:47 +01001215 --with-pkgversion=*) pkgversion="$optarg"
pbrook4a19f1e2009-04-07 23:17:49 +00001216 ;;
Alex Barcelo519175a2012-02-28 12:25:50 +01001217 --with-coroutine=*) coroutine="$optarg"
1218 ;;
Stefan Hajnoczi70c60c02013-09-11 16:42:35 +02001219 --disable-coroutine-pool) coroutine_pool="no"
1220 ;;
1221 --enable-coroutine-pool) coroutine_pool="yes"
1222 ;;
Peter Lieven7d992e42016-09-27 11:58:45 +02001223 --enable-debug-stack-usage) debug_stack_usage="yes"
1224 ;;
Longpeng(Mike)f0d92b52017-07-14 14:04:05 -04001225 --enable-crypto-afalg) crypto_afalg="yes"
1226 ;;
1227 --disable-crypto-afalg) crypto_afalg="no"
1228 ;;
Yonggang Luoe3667662020-10-16 06:06:25 +08001229 --disable-docs) docs="disabled"
Anthony Liguori70ec5dc2009-05-14 08:25:04 -05001230 ;;
Yonggang Luoe3667662020-10-16 06:06:25 +08001231 --enable-docs) docs="enabled"
Juan Quintela83a3ab82009-08-12 18:29:51 +02001232 ;;
Michael S. Tsirkind5970052010-03-17 13:08:17 +02001233 --disable-vhost-net) vhost_net="no"
1234 ;;
1235 --enable-vhost-net) vhost_net="yes"
1236 ;;
Gonglei042cea22018-03-01 21:46:28 +08001237 --disable-vhost-crypto) vhost_crypto="no"
1238 ;;
Paolo Bonzini299e6f12019-02-14 18:35:53 +01001239 --enable-vhost-crypto) vhost_crypto="yes"
Gonglei042cea22018-03-01 21:46:28 +08001240 ;;
Nicholas Bellinger5e9be922013-03-29 01:08:16 +00001241 --disable-vhost-scsi) vhost_scsi="no"
1242 ;;
1243 --enable-vhost-scsi) vhost_scsi="yes"
1244 ;;
Stefan Hajnoczifc0b9b02016-08-16 13:27:22 +01001245 --disable-vhost-vsock) vhost_vsock="no"
1246 ;;
1247 --enable-vhost-vsock) vhost_vsock="yes"
1248 ;;
Dr. David Alan Gilbert98fc1ad2019-09-30 11:51:34 +01001249 --disable-vhost-user-fs) vhost_user_fs="no"
1250 ;;
1251 --enable-vhost-user-fs) vhost_user_fs="yes"
1252 ;;
Gerd Hoffmannda076ff2014-11-20 09:49:44 +01001253 --disable-opengl) opengl="no"
Michael Walle20ff0752011-03-07 23:32:39 +01001254 ;;
Gerd Hoffmannda076ff2014-11-20 09:49:44 +01001255 --enable-opengl) opengl="yes"
Michael Walle20ff0752011-03-07 23:32:39 +01001256 ;;
Christian Brunnerf27aaf42010-12-06 20:53:01 +01001257 --disable-rbd) rbd="no"
1258 ;;
1259 --enable-rbd) rbd="yes"
1260 ;;
Sergei Trofimovich8c84cf12012-01-24 20:42:40 +03001261 --disable-xfsctl) xfs="no"
1262 ;;
1263 --enable-xfsctl) xfs="yes"
1264 ;;
Marc-André Lureau7b02f542015-08-30 11:48:40 +02001265 --disable-smartcard) smartcard="no"
Robert Relyea111a38b2010-11-28 16:36:38 +02001266 ;;
Marc-André Lureau7b02f542015-08-30 11:48:40 +02001267 --enable-smartcard) smartcard="yes"
Robert Relyea111a38b2010-11-28 16:36:38 +02001268 ;;
César Belley0a40bcb2020-08-26 13:42:04 +02001269 --disable-u2f) u2f="disabled"
1270 ;;
1271 --enable-u2f) u2f="enabled"
1272 ;;
Gerd Hoffmann2b2325f2012-11-30 16:02:11 +01001273 --disable-libusb) libusb="no"
1274 ;;
1275 --enable-libusb) libusb="yes"
1276 ;;
Hans de Goede69354a82011-07-19 11:04:10 +02001277 --disable-usb-redir) usb_redir="no"
1278 ;;
1279 --enable-usb-redir) usb_redir="yes"
1280 ;;
Paolo Bonzini1ffb3bb2020-08-28 19:33:54 +02001281 --disable-zlib-test)
Alon Levy1ece9902011-07-26 12:30:40 +03001282 ;;
Stefan Weilb25c9df2014-04-29 08:21:16 +02001283 --disable-lzo) lzo="no"
1284 ;;
qiaonuohan607dacd2014-02-18 14:11:30 +08001285 --enable-lzo) lzo="yes"
1286 ;;
Stefan Weilb25c9df2014-04-29 08:21:16 +02001287 --disable-snappy) snappy="no"
1288 ;;
qiaonuohan607dacd2014-02-18 14:11:30 +08001289 --enable-snappy) snappy="yes"
1290 ;;
Peter Wu6b383c02015-01-06 18:48:14 +01001291 --disable-bzip2) bzip2="no"
1292 ;;
1293 --enable-bzip2) bzip2="yes"
1294 ;;
Julio Faracco83bc1f92018-11-05 13:08:04 -02001295 --enable-lzfse) lzfse="yes"
1296 ;;
1297 --disable-lzfse) lzfse="no"
1298 ;;
Juan Quintela3a678482019-12-17 21:15:24 +01001299 --disable-zstd) zstd="no"
1300 ;;
1301 --enable-zstd) zstd="yes"
1302 ;;
Michael Rothd138cee2011-08-01 14:52:57 -05001303 --enable-guest-agent) guest_agent="yes"
1304 ;;
1305 --disable-guest-agent) guest_agent="no"
1306 ;;
Yossi Hindin9dacf322015-05-06 14:57:40 +03001307 --enable-guest-agent-msi) guest_agent_msi="yes"
1308 ;;
1309 --disable-guest-agent-msi) guest_agent_msi="no"
1310 ;;
Tomoki Sekiyamad9840e22013-08-07 11:40:03 -04001311 --with-vss-sdk) vss_win32_sdk=""
1312 ;;
1313 --with-vss-sdk=*) vss_win32_sdk="$optarg"
1314 ;;
1315 --without-vss-sdk) vss_win32_sdk="no"
1316 ;;
1317 --with-win-sdk) win_sdk=""
1318 ;;
1319 --with-win-sdk=*) win_sdk="$optarg"
1320 ;;
1321 --without-win-sdk) win_sdk="no"
1322 ;;
Daniel P. Berrange4b1c11f2012-09-10 12:26:29 +01001323 --enable-tools) want_tools="yes"
1324 ;;
1325 --disable-tools) want_tools="no"
1326 ;;
Eduardo Otubof7945732012-08-14 18:44:05 -03001327 --enable-seccomp) seccomp="yes"
1328 ;;
1329 --disable-seccomp) seccomp="no"
1330 ;;
Bharata B Raoeb100392012-09-24 14:42:45 +05301331 --disable-glusterfs) glusterfs="no"
1332 ;;
Liam Merwick86583a02018-10-19 21:38:59 +01001333 --disable-avx2) avx2_opt="no"
1334 ;;
1335 --enable-avx2) avx2_opt="yes"
1336 ;;
Robert Hoo6b8cd442020-02-29 20:34:34 +08001337 --disable-avx512f) avx512f_opt="no"
1338 ;;
1339 --enable-avx512f) avx512f_opt="yes"
1340 ;;
1341
Bharata B Raoeb100392012-09-24 14:42:45 +05301342 --enable-glusterfs) glusterfs="yes"
1343 ;;
Fam Zheng52b53c02014-09-10 14:17:51 +08001344 --disable-virtio-blk-data-plane|--enable-virtio-blk-data-plane)
1345 echo "$0: $opt is obsolete, virtio-blk data-plane is always on" >&2
Stefan Hajnoczi583f6e72012-11-14 15:04:15 +01001346 ;;
Fam Zhengcb6414d2016-09-21 12:27:16 +08001347 --enable-vhdx|--disable-vhdx)
1348 echo "$0: $opt is obsolete, VHDX driver is always built" >&2
1349 ;;
Fam Zheng315d3182016-09-21 12:27:21 +08001350 --enable-uuid|--disable-uuid)
1351 echo "$0: $opt is obsolete, UUID support is always built" >&2
1352 ;;
Anthony Liguoria4ccabc2013-02-20 07:43:20 -06001353 --disable-gtk) gtk="no"
1354 ;;
1355 --enable-gtk) gtk="yes"
1356 ;;
Daniel P. Berrangea1c5e942016-06-06 10:05:06 +01001357 --tls-priority=*) tls_priority="$optarg"
1358 ;;
Daniel P. Berrangeddbb0d02015-07-01 18:10:29 +01001359 --disable-gnutls) gnutls="no"
1360 ;;
1361 --enable-gnutls) gnutls="yes"
1362 ;;
Daniel P. Berrange91bfcdb2015-10-16 16:36:53 +01001363 --disable-nettle) nettle="no"
1364 ;;
1365 --enable-nettle) nettle="yes"
1366 ;;
1367 --disable-gcrypt) gcrypt="no"
1368 ;;
1369 --enable-gcrypt) gcrypt="yes"
1370 ;;
Daniel P. Berrange8953caf2016-07-27 14:13:56 +01001371 --disable-auth-pam) auth_pam="no"
1372 ;;
1373 --enable-auth-pam) auth_pam="yes"
1374 ;;
Michael R. Hines2da776d2013-07-22 10:01:54 -04001375 --enable-rdma) rdma="yes"
1376 ;;
1377 --disable-rdma) rdma="no"
1378 ;;
Marcel Apfelbaum21ab34c2018-08-16 18:16:37 +03001379 --enable-pvrdma) pvrdma="yes"
1380 ;;
1381 --disable-pvrdma) pvrdma="no"
1382 ;;
Stefan Weilbbbf9bf2014-02-19 07:04:34 +01001383 --disable-vte) vte="no"
1384 ;;
1385 --enable-vte) vte="yes"
1386 ;;
Gerd Hoffmann9d9e1522014-07-11 12:51:43 +02001387 --disable-virglrenderer) virglrenderer="no"
1388 ;;
1389 --enable-virglrenderer) virglrenderer="yes"
1390 ;;
Cole Robinsone91c7932014-06-16 15:32:47 -04001391 --disable-tpm) tpm="no"
1392 ;;
Stefan Bergerab214c22013-02-27 12:47:52 -05001393 --enable-tpm) tpm="yes"
1394 ;;
Pino Toscanob10d49d2019-06-20 22:08:40 +02001395 --disable-libssh) libssh="no"
Richard W.M. Jones0a12ec82013-04-09 15:30:53 +01001396 ;;
Pino Toscanob10d49d2019-06-20 22:08:40 +02001397 --enable-libssh) libssh="yes"
Richard W.M. Jones0a12ec82013-04-09 15:30:53 +01001398 ;;
Dr. David Alan Gilberted1701c2017-05-15 15:05:29 +01001399 --disable-live-block-migration) live_block_migration="no"
1400 ;;
1401 --enable-live-block-migration) live_block_migration="yes"
1402 ;;
Wanlong Gaoa99d57b2014-05-14 17:43:28 +08001403 --disable-numa) numa="no"
1404 ;;
1405 --enable-numa) numa="yes"
1406 ;;
Klim Kireeved279a02018-01-12 12:01:19 +03001407 --disable-libxml2) libxml2="no"
1408 ;;
1409 --enable-libxml2) libxml2="yes"
1410 ;;
Fam Zheng2847b462015-03-26 11:03:12 +08001411 --disable-tcmalloc) tcmalloc="no"
1412 ;;
1413 --enable-tcmalloc) tcmalloc="yes"
1414 ;;
Alexandre Derumier7b01cb92015-06-19 12:56:58 +02001415 --disable-jemalloc) jemalloc="no"
1416 ;;
1417 --enable-jemalloc) jemalloc="yes"
1418 ;;
Changlong Xiea6b1d4c2016-07-27 15:01:48 +08001419 --disable-replication) replication="no"
1420 ;;
1421 --enable-replication) replication="yes"
1422 ;;
Jeff Cody2f740132018-11-07 07:36:44 +01001423 --disable-bochs) bochs="no"
1424 ;;
1425 --enable-bochs) bochs="yes"
1426 ;;
1427 --disable-cloop) cloop="no"
1428 ;;
1429 --enable-cloop) cloop="yes"
1430 ;;
1431 --disable-dmg) dmg="no"
1432 ;;
1433 --enable-dmg) dmg="yes"
1434 ;;
1435 --disable-qcow1) qcow1="no"
1436 ;;
1437 --enable-qcow1) qcow1="yes"
1438 ;;
1439 --disable-vdi) vdi="no"
1440 ;;
1441 --enable-vdi) vdi="yes"
1442 ;;
1443 --disable-vvfat) vvfat="no"
1444 ;;
1445 --enable-vvfat) vvfat="yes"
1446 ;;
1447 --disable-qed) qed="no"
1448 ;;
1449 --enable-qed) qed="yes"
1450 ;;
1451 --disable-parallels) parallels="no"
1452 ;;
1453 --enable-parallels) parallels="yes"
1454 ;;
1455 --disable-sheepdog) sheepdog="no"
1456 ;;
1457 --enable-sheepdog) sheepdog="yes"
1458 ;;
Marc-André Lureaue6a74862017-08-03 11:07:46 +02001459 --disable-vhost-user) vhost_user="no"
1460 ;;
Paolo Bonzini299e6f12019-02-14 18:35:53 +01001461 --enable-vhost-user) vhost_user="yes"
1462 ;;
Cindy Lu108a6482020-07-01 22:55:37 +08001463 --disable-vhost-vdpa) vhost_vdpa="no"
1464 ;;
1465 --enable-vhost-vdpa) vhost_vdpa="yes"
1466 ;;
Paolo Bonzini299e6f12019-02-14 18:35:53 +01001467 --disable-vhost-kernel) vhost_kernel="no"
1468 ;;
1469 --enable-vhost-kernel) vhost_kernel="yes"
Marc-André Lureaue6a74862017-08-03 11:07:46 +02001470 ;;
Richard Henderson8b18cdb2020-09-13 12:19:25 -07001471 --disable-capstone) capstone="disabled"
Richard Henderson8ca80762017-09-14 09:41:12 -07001472 ;;
Richard Henderson8b18cdb2020-09-13 12:19:25 -07001473 --enable-capstone) capstone="enabled"
Richard Henderson8ca80762017-09-14 09:41:12 -07001474 ;;
Richard Henderson8b18cdb2020-09-13 12:19:25 -07001475 --enable-capstone=git) capstone="internal"
Richard Hendersone219c492017-09-28 09:01:23 -07001476 ;;
1477 --enable-capstone=system) capstone="system"
1478 ;;
Daniel P. Berrangecc84d632017-10-20 15:02:43 +01001479 --with-git=*) git="$optarg"
1480 ;;
Daniel P. Berrangef62bbee2017-10-26 13:52:26 +01001481 --enable-git-update) git_update=yes
1482 ;;
1483 --disable-git-update) git_update=no
1484 ;;
Paolo Bonziniba59fb72018-06-13 14:23:08 +02001485 --enable-debug-mutex) debug_mutex=yes
1486 ;;
1487 --disable-debug-mutex) debug_mutex=no
1488 ;;
Junyan He17824402018-07-18 15:47:59 +08001489 --enable-libpmem) libpmem=yes
1490 ;;
1491 --disable-libpmem) libpmem=no
1492 ;;
Laurent Vivier4113f4c2020-08-24 17:24:29 +02001493 --enable-xkbcommon) xkbcommon="enabled"
James Le Cuirot75411912019-09-14 15:51:55 +01001494 ;;
Laurent Vivier4113f4c2020-08-24 17:24:29 +02001495 --disable-xkbcommon) xkbcommon="disabled"
James Le Cuirot75411912019-09-14 15:51:55 +01001496 ;;
Alex Bennée40e8c6f2019-06-13 14:52:25 +01001497 --enable-plugins) plugins="yes"
1498 ;;
1499 --disable-plugins) plugins="no"
1500 ;;
Alex Bennéeafc3a8f2019-11-28 16:35:24 +01001501 --enable-containers) use_containers="yes"
1502 ;;
1503 --disable-containers) use_containers="no"
1504 ;;
Alexander Bulekovadc28022020-02-19 23:11:14 -05001505 --enable-fuzzing) fuzzing=yes
1506 ;;
1507 --disable-fuzzing) fuzzing=no
1508 ;;
Alex Bennéef48e5902020-03-16 17:21:48 +00001509 --gdb=*) gdb_bin="$optarg"
1510 ;;
Marek Marczykowski-Góreckib767d252020-05-20 15:20:23 +02001511 --enable-rng-none) rng_none=yes
1512 ;;
1513 --disable-rng-none) rng_none=no
1514 ;;
Alexey Krasikov54e7aac2020-05-25 14:19:12 +03001515 --enable-keyring) secret_keyring="yes"
1516 ;;
1517 --disable-keyring) secret_keyring="no"
1518 ;;
Jingqi Liu21b2eca2020-04-29 16:50:11 +08001519 --enable-libdaxctl) libdaxctl=yes
1520 ;;
1521 --disable-libdaxctl) libdaxctl=no
1522 ;;
Fam Zheng2d2ad6d2014-04-18 14:55:36 +08001523 *)
1524 echo "ERROR: unknown option $opt"
1525 echo "Try '$0 --help' for more information"
1526 exit 1
balrog7f1559c2007-11-17 10:24:32 +00001527 ;;
bellard7d132992003-03-06 23:23:54 +00001528 esac
1529done
1530
Marc-André Lureau22a87802019-07-11 19:13:39 +04001531libdir="${libdir:-$prefix/lib}"
1532libexecdir="${libexecdir:-$prefix/libexec}"
1533includedir="${includedir:-$prefix/include}"
1534
1535if test "$mingw32" = "yes" ; then
1536 mandir="$prefix"
1537 datadir="$prefix"
Marc-André Lureauca8c0902020-08-26 15:04:14 +04001538 docdir="$prefix"
Marc-André Lureau22a87802019-07-11 19:13:39 +04001539 bindir="$prefix"
1540 sysconfdir="$prefix"
Paolo Bonzini16bf7a32020-10-16 03:19:14 -04001541 local_statedir="$prefix"
Marc-André Lureau22a87802019-07-11 19:13:39 +04001542else
1543 mandir="${mandir:-$prefix/share/man}"
1544 datadir="${datadir:-$prefix/share}"
Marc-André Lureauca8c0902020-08-26 15:04:14 +04001545 docdir="${docdir:-$prefix/share/doc}"
Marc-André Lureau22a87802019-07-11 19:13:39 +04001546 bindir="${bindir:-$prefix/bin}"
1547 sysconfdir="${sysconfdir:-$prefix/etc}"
1548 local_statedir="${local_statedir:-$prefix/var}"
1549fi
Paolo Bonzini16bf7a32020-10-16 03:19:14 -04001550firmwarepath="${firmwarepath:-$datadir/qemu-firmware}"
1551localedir="${localedir:-$datadir/locale}"
Marc-André Lureau22a87802019-07-11 19:13:39 +04001552
bellard40293e52008-01-31 11:32:10 +00001553case "$cpu" in
Richard Hendersone3608d62013-08-28 15:48:21 -07001554 ppc)
1555 CPU_CFLAGS="-m32"
Paolo Bonzinidb5adea2019-12-11 15:34:27 +01001556 QEMU_LDFLAGS="-m32 $QEMU_LDFLAGS"
Richard Hendersone3608d62013-08-28 15:48:21 -07001557 ;;
1558 ppc64)
1559 CPU_CFLAGS="-m64"
Paolo Bonzinidb5adea2019-12-11 15:34:27 +01001560 QEMU_LDFLAGS="-m64 $QEMU_LDFLAGS"
Richard Hendersone3608d62013-08-28 15:48:21 -07001561 ;;
Richard Henderson9b9c37c2012-09-21 10:34:21 -07001562 sparc)
Richard Hendersonf1079bb2017-04-26 10:39:08 -07001563 CPU_CFLAGS="-m32 -mv8plus -mcpu=ultrasparc"
Paolo Bonzinidb5adea2019-12-11 15:34:27 +01001564 QEMU_LDFLAGS="-m32 -mv8plus $QEMU_LDFLAGS"
blueswir131422552007-04-16 18:27:06 +00001565 ;;
Juan Quintelaed968ff2009-08-03 14:46:11 +02001566 sparc64)
Peter Crosthwaite79f3b122013-04-18 14:46:14 +10001567 CPU_CFLAGS="-m64 -mcpu=ultrasparc"
Paolo Bonzinidb5adea2019-12-11 15:34:27 +01001568 QEMU_LDFLAGS="-m64 $QEMU_LDFLAGS"
blueswir131422552007-04-16 18:27:06 +00001569 ;;
ths76d83bd2007-11-18 21:22:10 +00001570 s390)
Richard Henderson061cdd82014-03-31 13:40:49 -04001571 CPU_CFLAGS="-m31"
Paolo Bonzinidb5adea2019-12-11 15:34:27 +01001572 QEMU_LDFLAGS="-m31 $QEMU_LDFLAGS"
Richard Henderson28d7cc42010-06-04 12:14:09 -07001573 ;;
1574 s390x)
Richard Henderson061cdd82014-03-31 13:40:49 -04001575 CPU_CFLAGS="-m64"
Paolo Bonzinidb5adea2019-12-11 15:34:27 +01001576 QEMU_LDFLAGS="-m64 $QEMU_LDFLAGS"
ths76d83bd2007-11-18 21:22:10 +00001577 ;;
bellard40293e52008-01-31 11:32:10 +00001578 i386)
Peter Crosthwaite79f3b122013-04-18 14:46:14 +10001579 CPU_CFLAGS="-m32"
Paolo Bonzinidb5adea2019-12-11 15:34:27 +01001580 QEMU_LDFLAGS="-m32 $QEMU_LDFLAGS"
bellard40293e52008-01-31 11:32:10 +00001581 ;;
1582 x86_64)
Richard Henderson7ebee432016-06-29 21:10:59 -07001583 # ??? Only extremely old AMD cpus do not have cmpxchg16b.
1584 # If we truly care, we should simply detect this case at
1585 # runtime and generate the fallback to serial emulation.
1586 CPU_CFLAGS="-m64 -mcx16"
Paolo Bonzinidb5adea2019-12-11 15:34:27 +01001587 QEMU_LDFLAGS="-m64 $QEMU_LDFLAGS"
Paul Brook379f6692009-07-17 12:48:08 +01001588 ;;
Richard Hendersonc72b26e2013-08-20 12:20:05 -07001589 x32)
1590 CPU_CFLAGS="-mx32"
Paolo Bonzinidb5adea2019-12-11 15:34:27 +01001591 QEMU_LDFLAGS="-mx32 $QEMU_LDFLAGS"
Richard Hendersonc72b26e2013-08-20 12:20:05 -07001592 ;;
Peter Maydell30163d82012-10-09 03:16:49 +00001593 # No special flags required for other host CPUs
blueswir131422552007-04-16 18:27:06 +00001594esac
1595
Paolo Bonzini2038f8c2019-08-07 16:35:23 +02001596eval "cross_cc_${cpu}=\$host_cc"
1597cross_cc_vars="$cross_cc_vars cross_cc_${cpu}"
Peter Crosthwaite79f3b122013-04-18 14:46:14 +10001598QEMU_CFLAGS="$CPU_CFLAGS $QEMU_CFLAGS"
Peter Crosthwaite79f3b122013-04-18 14:46:14 +10001599
Peter Maydellaffc88c2016-06-13 11:32:24 +01001600# For user-mode emulation the host arch has to be one we explicitly
1601# support, even if we're using TCI.
1602if [ "$ARCH" = "unknown" ]; then
1603 bsd_user="no"
1604 linux_user="no"
1605fi
1606
Peter Maydell60e0df22011-05-03 14:50:13 +01001607default_target_list=""
Paolo Bonzinifdb75ae2020-09-21 04:37:49 -04001608deprecated_targets_list=ppc64abi32-linux-user,tilegx-linux-user,lm32-softmmu,unicore32-softmmu
1609deprecated_features=""
Peter Maydell6e92f822013-05-20 16:16:15 +01001610mak_wilds=""
1611
1612if [ "$softmmu" = "yes" ]; then
Paolo Bonzini73362fc2020-09-18 06:44:16 -04001613 mak_wilds="${mak_wilds} $source_path/default-configs/targets/*-softmmu.mak"
Peter Maydell60e0df22011-05-03 14:50:13 +01001614fi
Peter Maydell6e92f822013-05-20 16:16:15 +01001615if [ "$linux_user" = "yes" ]; then
Paolo Bonzini73362fc2020-09-18 06:44:16 -04001616 mak_wilds="${mak_wilds} $source_path/default-configs/targets/*-linux-user.mak"
Peter Maydell60e0df22011-05-03 14:50:13 +01001617fi
Peter Maydell6e92f822013-05-20 16:16:15 +01001618if [ "$bsd_user" = "yes" ]; then
Paolo Bonzini73362fc2020-09-18 06:44:16 -04001619 mak_wilds="${mak_wilds} $source_path/default-configs/targets/*-bsd-user.mak"
Peter Maydell60e0df22011-05-03 14:50:13 +01001620fi
1621
Alex Bennée3a5ae4a2020-09-15 14:43:13 +01001622# If the user doesn't explicitly specify a deprecated target we will
1623# skip it.
1624if test -z "$target_list"; then
1625 if test -z "$target_list_exclude"; then
1626 target_list_exclude="$deprecated_targets_list"
1627 else
1628 target_list_exclude="$target_list_exclude,$deprecated_targets_list"
1629 fi
Alex Bennée2d838d92020-09-09 12:27:37 +01001630fi
1631
Alex Bennée2d838d92020-09-09 12:27:37 +01001632for config in $mak_wilds; do
1633 target="$(basename "$config" .mak)"
Alex Bennée98db9a02020-09-15 14:43:14 +01001634 if echo "$target_list_exclude" | grep -vq "$target"; then
Alex Bennée2d838d92020-09-09 12:27:37 +01001635 default_target_list="${default_target_list} $target"
1636 fi
1637done
Peter Maydell6e92f822013-05-20 16:16:15 +01001638
Stefan Hajnoczic53eeaf2017-03-28 14:44:18 +01001639# Enumerate public trace backends for --help output
Greg Kurz64a60472017-04-26 15:36:07 +02001640trace_backend_list=$(echo $(grep -le '^PUBLIC = True$' "$source_path"/scripts/tracetool/backend/*.py | sed -e 's/^.*\/\(.*\)\.py$/\1/'))
Stefan Hajnoczic53eeaf2017-03-28 14:44:18 +01001641
pbrookaf5db582006-04-08 14:26:41 +00001642if test x"$show_help" = x"yes" ; then
1643cat << EOF
1644
1645Usage: configure [options]
1646Options: [defaults in brackets after descriptions]
1647
Stefan Weil08fb77e2013-12-18 22:09:39 +01001648Standard options:
1649 --help print this message
1650 --prefix=PREFIX install in PREFIX [$prefix]
1651 --interp-prefix=PREFIX where to find shared libraries, etc.
1652 use %M for cpu name [$interp_prefix]
1653 --target-list=LIST set target list (default: build everything)
1654$(echo Available targets: $default_target_list | \
1655 fold -s -w 53 | sed -e 's/^/ /')
Alex Bennée447e1332019-03-19 11:59:12 +00001656 --target-list-exclude=LIST exclude a set of targets from the default target-list
Stefan Weil08fb77e2013-12-18 22:09:39 +01001657
1658Advanced options (experts only):
Stefan Weil08fb77e2013-12-18 22:09:39 +01001659 --cross-prefix=PREFIX use PREFIX for compile tools [$cross_prefix]
1660 --cc=CC use C compiler CC [$cc]
1661 --iasl=IASL use ACPI compiler IASL [$iasl]
1662 --host-cc=CC use C compiler CC [$host_cc] for code run at
1663 build time
1664 --cxx=CXX use C++ compiler CXX [$cxx]
1665 --objcc=OBJCC use Objective-C compiler OBJCC [$objcc]
1666 --extra-cflags=CFLAGS append extra C compiler flags QEMU_CFLAGS
Bruno Dominguez11cde1c2017-06-06 14:07:47 +01001667 --extra-cxxflags=CXXFLAGS append extra C++ compiler flags QEMU_CXXFLAGS
Stefan Weil08fb77e2013-12-18 22:09:39 +01001668 --extra-ldflags=LDFLAGS append extra linker flags LDFLAGS
Alex Bennéed75402b2018-04-04 20:27:05 +01001669 --cross-cc-ARCH=CC use compiler when building ARCH guest test cases
Alex Bennéed422b2b2018-04-13 11:07:58 +01001670 --cross-cc-flags-ARCH= use compiler flags when building ARCH guest tests
Stefan Weil08fb77e2013-12-18 22:09:39 +01001671 --make=MAKE use specified make [$make]
Stefan Weil08fb77e2013-12-18 22:09:39 +01001672 --python=PYTHON use specified python [$python]
Peter Maydell2eb054c2020-02-13 17:56:18 +00001673 --sphinx-build=SPHINX use specified sphinx-build [$sphinx_build]
Paolo Bonzinia5665052019-06-10 12:05:14 +02001674 --meson=MESON use specified meson [$meson]
Paolo Bonzini48328882020-08-26 08:04:15 +02001675 --ninja=NINJA use specified ninja [$ninja]
Stefan Weil08fb77e2013-12-18 22:09:39 +01001676 --smbd=SMBD use specified smbd [$smbd]
Thomas Huthdb1b5f12018-03-27 17:09:30 +02001677 --with-git=GIT use specified git [$git]
Stefan Weil08fb77e2013-12-18 22:09:39 +01001678 --static enable static build [$static]
1679 --mandir=PATH install man pages in PATH
Marc-André Lureau10ff82d2020-08-26 15:04:13 +04001680 --datadir=PATH install firmware in PATH/$qemu_suffix
Paolo Bonzinife0038b2020-10-16 04:35:10 -04001681 --localedir=PATH install translation in PATH/$qemu_suffix
Marc-André Lureau10ff82d2020-08-26 15:04:13 +04001682 --docdir=PATH install documentation in PATH/$qemu_suffix
Stefan Weil08fb77e2013-12-18 22:09:39 +01001683 --bindir=PATH install binaries in PATH
1684 --libdir=PATH install libraries in PATH
Thomas Huthdb1b5f12018-03-27 17:09:30 +02001685 --libexecdir=PATH install helper binaries in PATH
Marc-André Lureau10ff82d2020-08-26 15:04:13 +04001686 --sysconfdir=PATH install config in PATH/$qemu_suffix
Stefan Weil08fb77e2013-12-18 22:09:39 +01001687 --localstatedir=PATH install local state in PATH (set at runtime on win32)
Gerd Hoffmann3d5eeca2017-09-14 13:42:36 +02001688 --firmwarepath=PATH search PATH for firmware files
Robert Foley13336602020-07-01 14:56:21 +01001689 --efi-aarch64=PATH PATH of efi file to use for aarch64 VMs.
Marc-André Lureauca8c0902020-08-26 15:04:14 +04001690 --with-suffix=SUFFIX suffix for QEMU data inside datadir/libdir/sysconfdir/docdir [$qemu_suffix]
Thomas Huthdb1b5f12018-03-27 17:09:30 +02001691 --with-pkgversion=VERS use specified string as sub-version of the package
Stefan Weil08fb77e2013-12-18 22:09:39 +01001692 --enable-debug enable common debug build options
Marc-André Lureau247724c2018-01-16 16:11:51 +01001693 --enable-sanitizers enable default sanitizers
Lingfeng Yang0aebab02020-06-12 20:02:23 +01001694 --enable-tsan enable thread sanitizer
Stefan Weil08fb77e2013-12-18 22:09:39 +01001695 --disable-strip disable stripping binaries
1696 --disable-werror disable compilation abort on warning
Steven Noonan63678e12014-03-28 17:19:02 +01001697 --disable-stack-protector disable compiler-provided stack protection
Stefan Weil08fb77e2013-12-18 22:09:39 +01001698 --audio-drv-list=LIST set audio drivers list:
1699 Available drivers: $audio_possible_drivers
1700 --block-drv-whitelist=L Same as --block-drv-rw-whitelist=L
1701 --block-drv-rw-whitelist=L
1702 set block driver read-write whitelist
1703 (affects only QEMU, not qemu-img)
1704 --block-drv-ro-whitelist=L
1705 set block driver read-only whitelist
1706 (affects only QEMU, not qemu-img)
Lluís Vilanova5b808272014-05-27 15:02:14 +02001707 --enable-trace-backends=B Set trace backend
Stefan Hajnoczic53eeaf2017-03-28 14:44:18 +01001708 Available backends: $trace_backend_list
Stefan Weil08fb77e2013-12-18 22:09:39 +01001709 --with-trace-file=NAME Full PATH,NAME of file to store traces
1710 Default:trace-<pid>
Michael Tokarevc23f23b2015-06-17 22:19:26 +03001711 --disable-slirp disable SLIRP userspace network connectivity
1712 --enable-tcg-interpreter enable TCG with bytecode interpreter (TCI)
Yang Zhong5a22ab72017-12-20 21:16:46 +08001713 --enable-malloc-trim enable libc malloc_trim() for memory optimization
Michael Tokarevc23f23b2015-06-17 22:19:26 +03001714 --oss-lib path to OSS library
1715 --cpu=CPU Build for host CPU [$cpu]
Stefan Weil08fb77e2013-12-18 22:09:39 +01001716 --with-coroutine=BACKEND coroutine backend. Supported options:
Daniel P. Berrange33c53c52017-04-28 13:24:44 +01001717 ucontext, sigaltstack, windows
Stefan Weil08fb77e2013-12-18 22:09:39 +01001718 --enable-gcov enable test coverage analysis with gcov
Michael Tokarevc23f23b2015-06-17 22:19:26 +03001719 --disable-blobs disable installing provided firmware blobs
1720 --with-vss-sdk=SDK-path enable Windows VSS support in QEMU Guest Agent
1721 --with-win-sdk=SDK-path path to Windows Platform SDK (to build VSS .tlb)
Daniel P. Berrangea1c5e942016-06-06 10:05:06 +01001722 --tls-priority default TLS protocol/cipher priority string
Lin Mac12d66a2017-03-10 18:14:05 +08001723 --enable-gprof QEMU profiling with gprof
1724 --enable-profiler profiler support
Lin Mac12d66a2017-03-10 18:14:05 +08001725 --enable-debug-stack-usage
1726 track the maximum stack usage of stacks created by qemu_alloc_stack
Alex Bennée40e8c6f2019-06-13 14:52:25 +01001727 --enable-plugins
1728 enable plugins via shared library loading
Alex Bennéeafc3a8f2019-11-28 16:35:24 +01001729 --disable-containers don't use containers for cross-building
Alex Bennéef48e5902020-03-16 17:21:48 +00001730 --gdb=GDB-path gdb to use for gdbstub tests [$gdb_bin]
Michael Tokarevc23f23b2015-06-17 22:19:26 +03001731
1732Optional features, enabled with --enable-FEATURE and
1733disabled with --disable-FEATURE, default is enabled if available:
1734
1735 system all system emulation targets
1736 user supported user emulation targets
1737 linux-user all linux usermode emulation targets
1738 bsd-user all BSD usermode emulation targets
Michael Tokarevc23f23b2015-06-17 22:19:26 +03001739 docs build documentation
1740 guest-agent build the QEMU Guest Agent
1741 guest-agent-msi build guest agent Windows MSI installation package
1742 pie Position Independent Executables
Marc-André Lureau21e709a2019-07-18 16:04:13 +04001743 modules modules support (non-Windows)
Christian Ehrhardtbd83c862020-03-10 15:58:06 +01001744 module-upgrades try to load modules from alternate paths for upgrades
Michael Tokarevc23f23b2015-06-17 22:19:26 +03001745 debug-tcg TCG debugging (default is disabled)
1746 debug-info debugging information
1747 sparse sparse checker
Daniele Buono1e4f6062020-05-29 16:51:21 -04001748 safe-stack SafeStack Stack Smash Protection. Depends on
1749 clang/llvm >= 3.7 and requires coroutine backend ucontext.
Michael Tokarevc23f23b2015-06-17 22:19:26 +03001750
Daniel P. Berrangeddbb0d02015-07-01 18:10:29 +01001751 gnutls GNUTLS cryptography support
Daniel P. Berrange91bfcdb2015-10-16 16:36:53 +01001752 nettle nettle cryptography support
1753 gcrypt libgcrypt cryptography support
Daniel P. Berrange8953caf2016-07-27 14:13:56 +01001754 auth-pam PAM access control
Michael Tokarevc23f23b2015-06-17 22:19:26 +03001755 sdl SDL UI
Markus Armbruster04c6e162019-05-17 20:32:46 +02001756 sdl-image SDL Image support for icons
Michael Tokarevc23f23b2015-06-17 22:19:26 +03001757 gtk gtk UI
Michael Tokarevc23f23b2015-06-17 22:19:26 +03001758 vte vte support for the gtk UI
1759 curses curses UI
Samuel Thibaulte08bb302019-03-11 14:51:26 +01001760 iconv font glyph conversion support
Michael Tokarevc23f23b2015-06-17 22:19:26 +03001761 vnc VNC UI support
Michael Tokarevc23f23b2015-06-17 22:19:26 +03001762 vnc-sasl SASL encryption for VNC server
1763 vnc-jpeg JPEG lossy compression for VNC server
1764 vnc-png PNG compression for VNC server
Michael Tokarevc23f23b2015-06-17 22:19:26 +03001765 cocoa Cocoa UI (Mac OS X only)
1766 virtfs VirtFS
Misono Tomohirocece1162020-10-08 19:31:33 +09001767 virtiofsd build virtiofs daemon (virtiofsd)
Paolo Bonzini5c530152020-10-15 06:09:27 -04001768 libudev Use libudev to enumerate host devices
Paolo Bonzinife8fc5a2017-08-22 06:50:55 +02001769 mpath Multipath persistent reservation passthrough
Michael Tokarevc23f23b2015-06-17 22:19:26 +03001770 xen xen backend driver support
Anthony PERARD70c292a2018-05-04 10:17:56 +01001771 xen-pci-passthrough PCI passthrough support for Xen
Michael Tokarevc23f23b2015-06-17 22:19:26 +03001772 brlapi BrlAPI (Braile)
1773 curl curl connectivity
Paolo Bonzinia40161c2018-02-16 10:05:23 +01001774 membarrier membarrier system call (for Linux 4.14+ or Windows)
Michael Tokarevc23f23b2015-06-17 22:19:26 +03001775 fdt fdt device tree
Michael Tokarevc23f23b2015-06-17 22:19:26 +03001776 kvm KVM acceleration support
Vincent Palatinb0cb0a62017-01-10 11:59:57 +01001777 hax HAX acceleration support
Sergio Andres Gomez Del Realc97d6d22017-09-13 04:05:09 -05001778 hvf Hypervisor.framework acceleration support
Justin Terry (VM)d661d9a2018-01-22 13:07:46 -08001779 whpx Windows Hypervisor Platform acceleration support
Marcel Apfelbaum21ab34c2018-08-16 18:16:37 +03001780 rdma Enable RDMA-based migration
1781 pvrdma Enable PVRDMA support
Michael Tokarevc23f23b2015-06-17 22:19:26 +03001782 vde support for vde network
1783 netmap support for netmap network
1784 linux-aio Linux AIO support
Aarushi Mehtac10dd852020-01-20 14:18:44 +00001785 linux-io-uring Linux io_uring support
Michael Tokarevc23f23b2015-06-17 22:19:26 +03001786 cap-ng libcap-ng support
1787 attr attr and xattr support
Paolo Bonzini299e6f12019-02-14 18:35:53 +01001788 vhost-net vhost-net kernel acceleration support
1789 vhost-vsock virtio sockets device support
1790 vhost-scsi vhost-scsi kernel target support
1791 vhost-crypto vhost-user-crypto backend support
1792 vhost-kernel vhost kernel backend support
1793 vhost-user vhost-user backend support
Cindy Lu108a6482020-07-01 22:55:37 +08001794 vhost-vdpa vhost-vdpa kernel backend support
Michael Tokarevc23f23b2015-06-17 22:19:26 +03001795 spice spice
1796 rbd rados block device (rbd)
1797 libiscsi iscsi support
1798 libnfs nfs support
Marc-André Lureau7b02f542015-08-30 11:48:40 +02001799 smartcard smartcard support (libcacard)
César Belley0a40bcb2020-08-26 13:42:04 +02001800 u2f U2F support (u2f-emu)
Michael Tokarevc23f23b2015-06-17 22:19:26 +03001801 libusb libusb (for usb passthrough)
Dr. David Alan Gilberted1701c2017-05-15 15:05:29 +01001802 live-block-migration Block migration in the main migration stream
Michael Tokarevc23f23b2015-06-17 22:19:26 +03001803 usb-redir usb network redirection support
1804 lzo support of lzo compression library
1805 snappy support of snappy compression library
1806 bzip2 support of bzip2 compression library
1807 (for reading bzip2-compressed dmg images)
Julio Faracco83bc1f92018-11-05 13:08:04 -02001808 lzfse support of lzfse compression library
1809 (for reading lzfse-compressed dmg images)
Juan Quintela3a678482019-12-17 21:15:24 +01001810 zstd support for zstd compression library
Denis Plotnikovd298ac12020-05-07 11:25:20 +03001811 (for migration compression and qcow2 cluster compression)
Michael Tokarevc23f23b2015-06-17 22:19:26 +03001812 seccomp seccomp support
1813 coroutine-pool coroutine freelist (better performance)
1814 glusterfs GlusterFS backend
Michael Tokarevc23f23b2015-06-17 22:19:26 +03001815 tpm TPM support
Pino Toscanob10d49d2019-06-20 22:08:40 +02001816 libssh ssh block device support
Michael Tokarevc23f23b2015-06-17 22:19:26 +03001817 numa libnuma support
Klim Kireeved279a02018-01-12 12:01:19 +03001818 libxml2 for Parallels image format
Michael Tokarevc23f23b2015-06-17 22:19:26 +03001819 tcmalloc tcmalloc support
Alexandre Derumier7b01cb92015-06-19 12:56:58 +02001820 jemalloc jemalloc support
Liam Merwick86583a02018-10-19 21:38:59 +01001821 avx2 AVX2 optimization support
Robert Hoo6b8cd442020-02-29 20:34:34 +08001822 avx512f AVX512F optimization support
Changlong Xiea6b1d4c2016-07-27 15:01:48 +08001823 replication replication support
Lin Mac12d66a2017-03-10 18:14:05 +08001824 opengl opengl support
1825 virglrenderer virgl rendering support
1826 xfsctl xfsctl support
1827 qom-cast-debug cast debugging support
Cleber Rosa8de73fa2019-02-07 14:36:03 -05001828 tools build qemu-io, qemu-nbd and qemu-img tools
Jeff Cody2f740132018-11-07 07:36:44 +01001829 bochs bochs image format support
1830 cloop cloop image format support
1831 dmg dmg image format support
1832 qcow1 qcow v1 image format support
1833 vdi vdi image format support
1834 vvfat vvfat image format support
1835 qed qed image format support
1836 parallels parallels image format support
Daniel P. Berrangée1c42692020-10-02 12:32:43 +01001837 sheepdog sheepdog block driver support (deprecated)
Longpeng(Mike)f0d92b52017-07-14 14:04:05 -04001838 crypto-afalg Linux AF_ALG crypto backend driver
Richard Henderson8ca80762017-09-14 09:41:12 -07001839 capstone capstone disassembler support
Paolo Bonziniba59fb72018-06-13 14:23:08 +02001840 debug-mutex mutex debugging support
Junyan He17824402018-07-18 15:47:59 +08001841 libpmem libpmem support
James Le Cuirot75411912019-09-14 15:51:55 +01001842 xkbcommon xkbcommon support
Marek Marczykowski-Góreckib767d252020-05-20 15:20:23 +02001843 rng-none dummy RNG, avoid using /dev/(u)random and getrandom()
Jingqi Liu21b2eca2020-04-29 16:50:11 +08001844 libdaxctl libdaxctl support
Stefan Weil08fb77e2013-12-18 22:09:39 +01001845
1846NOTE: The object files are built at the place where configure is launched
pbrookaf5db582006-04-08 14:26:41 +00001847EOF
Fam Zheng2d2ad6d2014-04-18 14:55:36 +08001848exit 0
pbrookaf5db582006-04-08 14:26:41 +00001849fi
1850
Thomas Huth9c790242019-03-11 11:20:34 +01001851# Remove old dependency files to make sure that they get properly regenerated
Thomas Huthbb768f72019-05-10 10:11:59 +02001852rm -f */config-devices.mak.d
Thomas Huth9c790242019-03-11 11:20:34 +01001853
Daniel P. Berrangéfaf44142019-03-27 17:07:01 +00001854if test -z "$python"
1855then
1856 error_exit "Python not found. Use --python=/path/to/python"
Stefan Hajnoczic53eeaf2017-03-28 14:44:18 +01001857fi
1858
1859# Note that if the Python conditional here evaluates True we will exit
1860# with status 1 which is a shell 'false' value.
Thomas Huth1b11f282020-09-25 16:40:27 +01001861if ! $python -c 'import sys; sys.exit(sys.version_info < (3,6))'; then
1862 error_exit "Cannot use '$python', Python >= 3.6 is required." \
Stefan Hajnoczic53eeaf2017-03-28 14:44:18 +01001863 "Use --python=/path/to/python to specify a supported Python."
1864fi
1865
Cleber Rosa755ee702018-11-09 10:07:07 -05001866# Preserve python version since some functionality is dependent on it
Cleber Rosa406ab2f2019-08-26 11:58:32 -04001867python_version=$($python -c 'import sys; print("%d.%d.%d" % (sys.version_info[0], sys.version_info[1], sys.version_info[2]))' 2>/dev/null)
Cleber Rosa755ee702018-11-09 10:07:07 -05001868
Stefan Hajnoczic53eeaf2017-03-28 14:44:18 +01001869# Suppress writing compiled files
1870python="$python -B"
1871
Marc-André Lureau0a01d762019-08-21 11:21:16 +04001872if test -z "$meson"; then
Paolo Bonzini6ebd89c2020-10-15 03:20:45 -04001873 if test "$explicit_python" = no && has meson && version_ge "$(meson --version)" 0.55.3; then
Marc-André Lureau0a01d762019-08-21 11:21:16 +04001874 meson=meson
1875 elif test -e "${source_path}/.git" && test $git_update = 'yes' ; then
1876 meson=git
1877 elif test -e "${source_path}/meson/meson.py" ; then
1878 meson=internal
1879 else
1880 if test "$explicit_python" = yes; then
1881 error_exit "--python requires using QEMU's embedded Meson distribution, but it was not found."
1882 else
1883 error_exit "Meson not found. Use --meson=/path/to/meson"
1884 fi
1885 fi
1886else
1887 # Meson uses its own Python interpreter to invoke other Python scripts,
1888 # but the user wants to use the one they specified with --python.
1889 #
1890 # We do not want to override the distro Python interpreter (and sometimes
1891 # cannot: for example in Homebrew /usr/bin/meson is a bash script), so
1892 # just require --meson=git|internal together with --python.
1893 if test "$explicit_python" = yes; then
1894 case "$meson" in
1895 git | internal) ;;
1896 *) error_exit "--python requires using QEMU's embedded Meson distribution." ;;
1897 esac
1898 fi
Paolo Bonzinia5665052019-06-10 12:05:14 +02001899fi
Paolo Bonzinia5665052019-06-10 12:05:14 +02001900
Marc-André Lureau0a01d762019-08-21 11:21:16 +04001901if test "$meson" = git; then
1902 git_submodules="${git_submodules} meson"
Paolo Bonzinia5665052019-06-10 12:05:14 +02001903fi
Marc-André Lureau0a01d762019-08-21 11:21:16 +04001904
1905case "$meson" in
1906 git | internal)
1907 if ! $python -c 'import pkg_resources' > /dev/null 2>&1; then
1908 error_exit "Python setuptools not found"
1909 fi
1910 meson="$python ${source_path}/meson/meson.py"
1911 ;;
Paolo Bonzini84ec0c22020-09-04 10:00:26 -04001912 *) meson=$(command -v "$meson") ;;
Marc-André Lureau0a01d762019-08-21 11:21:16 +04001913esac
1914
Paolo Bonzini09e93322020-08-13 09:28:11 -04001915# Probe for ninja
Paolo Bonzini48328882020-08-26 08:04:15 +02001916
1917if test -z "$ninja"; then
1918 for c in ninja ninja-build samu; do
1919 if has $c; then
1920 ninja=$(command -v "$c")
1921 break
1922 fi
1923 done
Paolo Bonzini09e93322020-08-13 09:28:11 -04001924 if test -z "$ninja"; then
1925 error_exit "Cannot find Ninja"
1926 fi
Paolo Bonzini48328882020-08-26 08:04:15 +02001927fi
Paolo Bonzinia5665052019-06-10 12:05:14 +02001928
Daniel Henrique Barboza9aae6e52017-11-02 07:09:06 -02001929# Check that the C compiler works. Doing this here before testing
1930# the host CPU ensures that we had a valid CC to autodetect the
1931# $cpu var (and we should bail right here if that's not the case).
1932# It also allows the help message to be printed without a CC.
1933write_c_skeleton;
1934if compile_object ; then
1935 : C compiler works ok
1936else
1937 error_exit "\"$cc\" either does not exist or does not work"
1938fi
1939if ! compile_prog ; then
1940 error_exit "\"$cc\" cannot build an executable (is your linker broken?)"
1941fi
1942
Peter Maydell9c83ffd2014-02-25 18:27:49 +00001943# Consult white-list to determine whether to enable werror
1944# by default. Only enable by default for git builds
Peter Maydell9c83ffd2014-02-25 18:27:49 +00001945if test -z "$werror" ; then
Alexey Kardashevskiyfd737452019-02-28 15:35:03 +11001946 if test -e "$source_path/.git" && \
Eric Blakee633a5c2019-02-04 20:39:37 -06001947 { test "$linux" = "yes" || test "$mingw32" = "yes"; }; then
Peter Maydell9c83ffd2014-02-25 18:27:49 +00001948 werror="yes"
1949 else
1950 werror="no"
1951 fi
1952fi
1953
Peter Maydellfb59dab2017-03-28 14:01:52 +01001954if test "$bogus_os" = "yes"; then
1955 # Now that we know that we're not printing the help and that
1956 # the compiler works (so the results of the check_defines we used
1957 # to identify the OS are reliable), if we didn't recognize the
1958 # host OS we should stop now.
Peter Maydell951fedf2017-07-13 16:15:32 +01001959 error_exit "Unrecognized host OS (uname -s reports '$(uname -s)')"
Peter Maydellfb59dab2017-03-28 14:01:52 +01001960fi
1961
Thomas Huthefc6c072018-12-03 10:12:32 +01001962# Check whether the compiler matches our minimum requirements:
1963cat > $TMPC << EOF
1964#if defined(__clang_major__) && defined(__clang_minor__)
1965# ifdef __apple_build_version__
1966# if __clang_major__ < 5 || (__clang_major__ == 5 && __clang_minor__ < 1)
1967# error You need at least XCode Clang v5.1 to compile QEMU
1968# endif
1969# else
1970# if __clang_major__ < 3 || (__clang_major__ == 3 && __clang_minor__ < 4)
1971# error You need at least Clang v3.4 to compile QEMU
1972# endif
1973# endif
1974#elif defined(__GNUC__) && defined(__GNUC_MINOR__)
1975# if __GNUC__ < 4 || (__GNUC__ == 4 && __GNUC_MINOR__ < 8)
1976# error You need at least GCC v4.8 to compile QEMU
1977# endif
1978#else
1979# error You either need GCC or Clang to compiler QEMU
1980#endif
1981int main (void) { return 0; }
1982EOF
1983if ! compile_prog "" "" ; then
1984 error_exit "You need at least GCC v4.8 or Clang v3.4 (or XCode Clang v5.1)"
1985fi
1986
Richard Henderson00849b92020-06-17 13:13:06 -07001987# Accumulate -Wfoo and -Wno-bar separately.
1988# We will list all of the enable flags first, and the disable flags second.
1989# Note that we do not add -Werror, because that would enable it for all
1990# configure tests. If a configure test failed due to -Werror this would
1991# just silently disable some features, so it's too error prone.
1992
1993warn_flags=
1994add_to warn_flags -Wold-style-declaration
1995add_to warn_flags -Wold-style-definition
1996add_to warn_flags -Wtype-limits
1997add_to warn_flags -Wformat-security
1998add_to warn_flags -Wformat-y2k
1999add_to warn_flags -Winit-self
2000add_to warn_flags -Wignored-qualifiers
2001add_to warn_flags -Wempty-body
2002add_to warn_flags -Wnested-externs
2003add_to warn_flags -Wendif-labels
2004add_to warn_flags -Wexpansion-to-defined
2005
2006nowarn_flags=
2007add_to nowarn_flags -Wno-initializer-overrides
2008add_to nowarn_flags -Wno-missing-include-dirs
2009add_to nowarn_flags -Wno-shift-negative-value
2010add_to nowarn_flags -Wno-string-plus-int
2011add_to nowarn_flags -Wno-typedef-redefinition
Richard Hendersonaabab962020-06-17 13:13:07 -07002012add_to nowarn_flags -Wno-tautological-type-limit-compare
Richard Hendersonbac8d222020-06-17 13:13:08 -07002013add_to nowarn_flags -Wno-psabi
Richard Henderson00849b92020-06-17 13:13:06 -07002014
2015gcc_flags="$warn_flags $nowarn_flags"
John Snow93b25862015-03-25 18:57:37 -04002016
2017cc_has_warning_flag() {
2018 write_c_skeleton;
2019
Peter Maydella1d29d62012-10-27 22:19:07 +01002020 # Use the positive sense of the flag when testing for -Wno-wombat
2021 # support (gcc will happily accept the -Wno- form of unknown
2022 # warning options).
John Snow93b25862015-03-25 18:57:37 -04002023 optflag="$(echo $1 | sed -e 's/^-Wno-/-W/')"
2024 compile_prog "-Werror $optflag" ""
2025}
2026
2027for flag in $gcc_flags; do
2028 if cc_has_warning_flag $flag ; then
2029 QEMU_CFLAGS="$QEMU_CFLAGS $flag"
Paolo Bonzini8d050952010-12-23 11:43:52 +01002030 fi
2031done
2032
Miroslav Rezanina3b463a32014-07-02 10:05:24 +02002033if test "$stack_protector" != "no"; then
Rodrigo Rebellofccd35a2015-11-12 12:04:28 -02002034 cat > $TMPC << EOF
2035int main(int argc, char *argv[])
2036{
2037 char arr[64], *p = arr, *c = argv[0];
2038 while (*c) {
2039 *p++ = *c++;
2040 }
2041 return 0;
2042}
2043EOF
Steven Noonan63678e12014-03-28 17:19:02 +01002044 gcc_flags="-fstack-protector-strong -fstack-protector-all"
Miroslav Rezanina3b463a32014-07-02 10:05:24 +02002045 sp_on=0
Steven Noonan63678e12014-03-28 17:19:02 +01002046 for flag in $gcc_flags; do
Peter Maydell590e5dd2014-04-11 17:13:52 +01002047 # We need to check both a compile and a link, since some compiler
2048 # setups fail only on a .c->.o compile and some only at link time
Paolo Bonzini086d5f72020-02-03 15:22:17 +01002049 if compile_object "-Werror $flag" &&
Peter Maydell590e5dd2014-04-11 17:13:52 +01002050 compile_prog "-Werror $flag" ""; then
Steven Noonan63678e12014-03-28 17:19:02 +01002051 QEMU_CFLAGS="$QEMU_CFLAGS $flag"
Paolo Bonzinidb5adea2019-12-11 15:34:27 +01002052 QEMU_LDFLAGS="$QEMU_LDFLAGS $flag"
Miroslav Rezanina3b463a32014-07-02 10:05:24 +02002053 sp_on=1
Steven Noonan63678e12014-03-28 17:19:02 +01002054 break
2055 fi
2056 done
Miroslav Rezanina3b463a32014-07-02 10:05:24 +02002057 if test "$stack_protector" = yes; then
2058 if test $sp_on = 0; then
2059 error_exit "Stack protector not supported"
2060 fi
2061 fi
Marc-André Lureau37746c52013-02-25 23:31:12 +01002062fi
2063
Paolo Bonzini20bc94a2017-10-20 12:11:32 +02002064# Disable -Wmissing-braces on older compilers that warn even for
2065# the "universal" C zero initializer {0}.
2066cat > $TMPC << EOF
2067struct {
2068 int a[2];
2069} x = {0};
2070EOF
2071if compile_object "-Werror" "" ; then
2072 :
2073else
2074 QEMU_CFLAGS="$QEMU_CFLAGS -Wno-missing-braces"
2075fi
2076
Marc-André Lureau21e709a2019-07-18 16:04:13 +04002077# Our module code doesn't support Windows
2078if test "$modules" = "yes" && test "$mingw32" = "yes" ; then
2079 error_exit "Modules are not available for Windows"
2080fi
2081
Christian Ehrhardtbd83c862020-03-10 15:58:06 +01002082# module_upgrades is only reasonable if modules are enabled
2083if test "$modules" = "no" && test "$module_upgrades" = "yes" ; then
2084 error_exit "Can't enable module-upgrades as Modules are not enabled"
2085fi
2086
Thomas Huthd376e9d2018-12-03 11:41:38 +01002087# Static linking is not possible with modules or PIE
Avi Kivity40d64442011-11-15 20:12:17 +02002088if test "$static" = "yes" ; then
Paolo Bonziniaa0d1f42014-02-25 17:36:55 +01002089 if test "$modules" = "yes" ; then
2090 error_exit "static and modules are mutually incompatible"
2091 fi
Avi Kivity40d64442011-11-15 20:12:17 +02002092fi
2093
Emilio G. Cota768b7852015-04-29 13:09:02 +02002094# Unconditional check for compiler __thread support
2095 cat > $TMPC << EOF
2096static __thread int tls_var;
2097int main(void) { return tls_var; }
2098EOF
2099
2100if ! compile_prog "-Werror" "" ; then
2101 error_exit "Your compiler does not support the __thread specifier for " \
2102 "Thread-Local Storage (TLS). Please upgrade to a version that does."
2103fi
2104
Richard Hendersonb2634122019-12-17 13:54:56 -10002105cat > $TMPC << EOF
Avi Kivity21d4a792011-11-23 11:24:25 +02002106
2107#ifdef __linux__
2108# define THREAD __thread
2109#else
2110# define THREAD
2111#endif
Avi Kivity21d4a792011-11-23 11:24:25 +02002112static THREAD int tls_var;
Avi Kivity21d4a792011-11-23 11:24:25 +02002113int main(void) { return tls_var; }
Avi Kivity40d64442011-11-15 20:12:17 +02002114EOF
Alex Bennée412aeac2019-08-15 19:41:51 +00002115
Richard Hendersonb2634122019-12-17 13:54:56 -10002116# Check we support --no-pie first; we will need this for building ROMs.
2117if compile_prog "-Werror -fno-pie" "-no-pie"; then
2118 CFLAGS_NOPIE="-fno-pie"
2119 LDFLAGS_NOPIE="-no-pie"
2120fi
2121
Richard Henderson12781462019-12-17 15:30:14 -10002122if test "$static" = "yes"; then
Richard Hendersoneca7a8e2020-04-03 20:11:50 +01002123 if test "$pie" != "no" && compile_prog "-Werror -fPIE -DPIE" "-static-pie"; then
Paolo Bonzini5770e8a2020-09-23 05:26:15 -04002124 CONFIGURE_CFLAGS="-fPIE -DPIE $CONFIGURE_CFLAGS"
Richard Henderson12781462019-12-17 15:30:14 -10002125 QEMU_LDFLAGS="-static-pie $QEMU_LDFLAGS"
2126 pie="yes"
2127 elif test "$pie" = "yes"; then
2128 error_exit "-static-pie not available due to missing toolchain support"
2129 else
2130 QEMU_LDFLAGS="-static $QEMU_LDFLAGS"
2131 pie="no"
2132 fi
2133elif test "$pie" = "no"; then
Paolo Bonzini5770e8a2020-09-23 05:26:15 -04002134 CONFIGURE_CFLAGS="$CFLAGS_NOPIE $CONFIGURE_CFLAGS"
2135 CONFIGURE_LDFLAGS="$LDFLAGS_NOPIE $CONFIGURE_LDFLAGS"
Richard Hendersoneca7a8e2020-04-03 20:11:50 +01002136elif compile_prog "-Werror -fPIE -DPIE" "-pie"; then
Paolo Bonzini5770e8a2020-09-23 05:26:15 -04002137 CONFIGURE_CFLAGS="-fPIE -DPIE $CONFIGURE_CFLAGS"
2138 CONFIGURE_LDFLAGS="-pie $CONFIGURE_LDFLAGS"
Richard Henderson2c674102019-12-17 15:15:01 -10002139 pie="yes"
2140elif test "$pie" = "yes"; then
2141 error_exit "PIE not available due to missing toolchain support"
2142else
2143 echo "Disabling PIE due to missing toolchain support"
2144 pie="no"
Avi Kivity40d64442011-11-15 20:12:17 +02002145fi
2146
Richard Hendersone6cbd752019-12-17 14:00:39 -10002147# Detect support for PT_GNU_RELRO + DT_BIND_NOW.
2148# The combination is known as "full relro", because .got.plt is read-only too.
2149if compile_prog "" "-Wl,-z,relro -Wl,-z,now" ; then
2150 QEMU_LDFLAGS="-Wl,-z,relro -Wl,-z,now $QEMU_LDFLAGS"
2151fi
2152
Paolo Bonzini09dada42013-04-17 16:26:47 +02002153##########################################
2154# __sync_fetch_and_and requires at least -march=i486. Many toolchains
2155# use i686 as default anyway, but for those that don't, an explicit
2156# specification is necessary
2157
2158if test "$cpu" = "i386"; then
2159 cat > $TMPC << EOF
2160static int sfaa(int *ptr)
2161{
2162 return __sync_fetch_and_and(ptr, 0);
2163}
2164
2165int main(void)
2166{
2167 int val = 42;
Stefan Weil1405b622013-05-11 21:46:58 +02002168 val = __sync_val_compare_and_swap(&val, 0, 1);
Paolo Bonzini09dada42013-04-17 16:26:47 +02002169 sfaa(&val);
2170 return val;
2171}
2172EOF
2173 if ! compile_prog "" "" ; then
2174 QEMU_CFLAGS="-march=i486 $QEMU_CFLAGS"
2175 fi
2176fi
2177
2178#########################################
bellardec530c82006-04-25 22:36:06 +00002179# Solaris specific configure tool chain decisions
Paolo Bonzini09dada42013-04-17 16:26:47 +02002180
bellardec530c82006-04-25 22:36:06 +00002181if test "$solaris" = "yes" ; then
Loïc Minier6792aa12010-01-20 11:35:54 +01002182 if has ar; then
2183 :
2184 else
bellardec530c82006-04-25 22:36:06 +00002185 if test -f /usr/ccs/bin/ar ; then
Peter Maydell76ad07a2013-04-08 12:11:26 +01002186 error_exit "No path includes ar" \
2187 "Add /usr/ccs/bin to your path and rerun configure"
bellardec530c82006-04-25 22:36:06 +00002188 fi
Peter Maydell76ad07a2013-04-08 12:11:26 +01002189 error_exit "No path includes ar"
bellardec530c82006-04-25 22:36:06 +00002190 fi
ths5fafdf22007-09-16 21:08:06 +00002191fi
bellardec530c82006-04-25 22:36:06 +00002192
Stefan Weilafb63eb2012-09-26 22:04:38 +02002193if test -z "${target_list+xxx}" ; then
Paolo Bonzinifdb75ae2020-09-21 04:37:49 -04002194 default_targets=yes
Paolo Bonzinid880a3b2017-07-03 16:58:28 +02002195 for target in $default_target_list; do
Paolo Bonzinifdb75ae2020-09-21 04:37:49 -04002196 target_list="$target_list $target"
Paolo Bonzinid880a3b2017-07-03 16:58:28 +02002197 done
2198 target_list="${target_list# }"
Anthony Liguori121afa92012-09-14 08:17:03 -05002199else
Paolo Bonzinifdb75ae2020-09-21 04:37:49 -04002200 default_targets=no
Stefan Weil89138852016-05-16 15:10:20 +02002201 target_list=$(echo "$target_list" | sed -e 's/,/ /g')
Paolo Bonzinid880a3b2017-07-03 16:58:28 +02002202 for target in $target_list; do
2203 # Check that we recognised the target name; this allows a more
2204 # friendly error message than if we let it fall through.
2205 case " $default_target_list " in
2206 *" $target "*)
2207 ;;
2208 *)
2209 error_exit "Unknown target name '$target'"
2210 ;;
2211 esac
Paolo Bonzinid880a3b2017-07-03 16:58:28 +02002212 done
bellard5327cf42005-01-10 23:18:50 +00002213fi
Peter Maydell25b48332013-05-20 16:16:16 +01002214
Paolo Bonzinifdb75ae2020-09-21 04:37:49 -04002215for target in $target_list; do
2216 # if a deprecated target is enabled we note it here
2217 if echo "$deprecated_targets_list" | grep -q "$target"; then
2218 add_to deprecated_features $target
2219 fi
2220done
2221
Paolo Bonzinif55fe272010-05-26 16:08:17 +02002222# see if system emulation was really requested
2223case " $target_list " in
2224 *"-softmmu "*) softmmu=yes
2225 ;;
2226 *) softmmu=no
2227 ;;
2228esac
bellard5327cf42005-01-10 23:18:50 +00002229
Juan Quintela249247c2009-08-12 18:20:25 +02002230feature_not_found() {
2231 feature=$1
Stewart Smith21684af2014-01-24 12:39:10 +11002232 remedy=$2
Juan Quintela249247c2009-08-12 18:20:25 +02002233
Peter Maydell76ad07a2013-04-08 12:11:26 +01002234 error_exit "User requested feature $feature" \
Stewart Smith21684af2014-01-24 12:39:10 +11002235 "configure was not able to find it." \
2236 "$remedy"
Juan Quintela249247c2009-08-12 18:20:25 +02002237}
2238
bellard7d132992003-03-06 23:23:54 +00002239# ---
2240# big/little endian test
2241cat > $TMPC << EOF
Mike Frysinger61cc9192013-06-30 23:30:18 -04002242short big_endian[] = { 0x4269, 0x4765, 0x4e64, 0x4961, 0x4e00, 0, };
2243short little_endian[] = { 0x694c, 0x7454, 0x654c, 0x6e45, 0x6944, 0x6e41, 0, };
2244extern int foo(short *, short *);
2245int main(int argc, char *argv[]) {
2246 return foo(big_endian, little_endian);
bellard7d132992003-03-06 23:23:54 +00002247}
2248EOF
2249
Mike Frysinger61cc9192013-06-30 23:30:18 -04002250if compile_object ; then
Alice Frosi12f15c92018-01-30 14:38:28 +01002251 if strings -a $TMPO | grep -q BiGeNdIaN ; then
Mike Frysinger61cc9192013-06-30 23:30:18 -04002252 bigendian="yes"
Alice Frosi12f15c92018-01-30 14:38:28 +01002253 elif strings -a $TMPO | grep -q LiTtLeEnDiAn ; then
Mike Frysinger61cc9192013-06-30 23:30:18 -04002254 bigendian="no"
2255 else
2256 echo big/little test failed
Peter Maydell21d89f82011-11-30 10:57:48 +01002257 fi
Mike Frysinger61cc9192013-06-30 23:30:18 -04002258else
2259 echo big/little test failed
bellard7d132992003-03-06 23:23:54 +00002260fi
2261
Juan Quintelab0a47e72009-08-12 18:29:49 +02002262##########################################
Philippe Mathieu-Daudée10ee3f2020-02-17 14:33:27 +01002263# system tools
2264if test -z "$want_tools"; then
2265 if test "$softmmu" = "no"; then
2266 want_tools=no
2267 else
2268 want_tools=yes
2269 fi
2270fi
2271
2272##########################################
Peter Maydella30878e2015-08-14 16:10:52 +01002273# cocoa implies not SDL or GTK
2274# (the cocoa UI code currently assumes it is always the active UI
2275# and doesn't interact well with other UI frontend code)
Paolo Bonzinib4e312e2020-09-01 11:28:59 -04002276if test "$cocoa" = "enabled"; then
2277 if test "$sdl" = "enabled"; then
Peter Maydella30878e2015-08-14 16:10:52 +01002278 error_exit "Cocoa and SDL UIs cannot both be enabled at once"
2279 fi
2280 if test "$gtk" = "yes"; then
2281 error_exit "Cocoa and GTK UIs cannot both be enabled at once"
2282 fi
2283 gtk=no
Paolo Bonzini35be72b2020-02-06 14:17:15 +01002284 sdl=disabled
Peter Maydella30878e2015-08-14 16:10:52 +01002285fi
2286
Eric Blake6b39b062016-10-11 10:46:23 -05002287# Some versions of Mac OS X incorrectly define SIZE_MAX
2288cat > $TMPC << EOF
2289#include <stdint.h>
2290#include <stdio.h>
2291int main(int argc, char *argv[]) {
2292 return printf("%zu", SIZE_MAX);
2293}
2294EOF
2295have_broken_size_max=no
2296if ! compile_object -Werror ; then
2297 have_broken_size_max=yes
2298fi
2299
Peter Maydella30878e2015-08-14 16:10:52 +01002300##########################################
Gonglei015a33b2014-07-01 20:58:08 +08002301# L2TPV3 probe
2302
2303cat > $TMPC <<EOF
2304#include <sys/socket.h>
Michael Tokarevbff6cb72014-08-01 23:20:24 +04002305#include <linux/ip.h>
Gonglei015a33b2014-07-01 20:58:08 +08002306int main(void) { return sizeof(struct mmsghdr); }
2307EOF
2308if compile_prog "" "" ; then
2309 l2tpv3=yes
2310else
2311 l2tpv3=no
2312fi
2313
David CARLIERc9c8b882020-07-13 14:36:09 +01002314if check_include "pty.h" ; then
2315 pty_h=yes
2316else
2317 pty_h=no
2318fi
2319
David CARLIER195588c2020-07-13 14:36:09 +01002320cat > $TMPC <<EOF
2321#include <sys/mman.h>
2322int main(int argc, char *argv[]) {
2323 return mlockall(MCL_FUTURE);
2324}
2325EOF
2326if compile_prog "" "" ; then
2327 have_mlockall=yes
2328else
2329 have_mlockall=no
2330fi
2331
Paolo Bonzini299e6f12019-02-14 18:35:53 +01002332#########################################
2333# vhost interdependencies and host support
2334
2335# vhost backends
2336test "$vhost_user" = "" && vhost_user=yes
2337if test "$vhost_user" = "yes" && test "$mingw32" = "yes"; then
2338 error_exit "vhost-user isn't available on win32"
2339fi
Cindy Lu108a6482020-07-01 22:55:37 +08002340test "$vhost_vdpa" = "" && vhost_vdpa=$linux
2341if test "$vhost_vdpa" = "yes" && test "$linux" != "yes"; then
2342 error_exit "vhost-vdpa is only available on Linux"
2343fi
Paolo Bonzini299e6f12019-02-14 18:35:53 +01002344test "$vhost_kernel" = "" && vhost_kernel=$linux
2345if test "$vhost_kernel" = "yes" && test "$linux" != "yes"; then
2346 error_exit "vhost-kernel is only available on Linux"
2347fi
2348
2349# vhost-kernel devices
2350test "$vhost_scsi" = "" && vhost_scsi=$vhost_kernel
2351if test "$vhost_scsi" = "yes" && test "$vhost_kernel" != "yes"; then
2352 error_exit "--enable-vhost-scsi requires --enable-vhost-kernel"
2353fi
2354test "$vhost_vsock" = "" && vhost_vsock=$vhost_kernel
2355if test "$vhost_vsock" = "yes" && test "$vhost_kernel" != "yes"; then
2356 error_exit "--enable-vhost-vsock requires --enable-vhost-kernel"
2357fi
2358
2359# vhost-user backends
2360test "$vhost_net_user" = "" && vhost_net_user=$vhost_user
2361if test "$vhost_net_user" = "yes" && test "$vhost_user" = "no"; then
2362 error_exit "--enable-vhost-net-user requires --enable-vhost-user"
2363fi
2364test "$vhost_crypto" = "" && vhost_crypto=$vhost_user
2365if test "$vhost_crypto" = "yes" && test "$vhost_user" = "no"; then
2366 error_exit "--enable-vhost-crypto requires --enable-vhost-user"
2367fi
Dr. David Alan Gilbert98fc1ad2019-09-30 11:51:34 +01002368test "$vhost_user_fs" = "" && vhost_user_fs=$vhost_user
2369if test "$vhost_user_fs" = "yes" && test "$vhost_user" = "no"; then
2370 error_exit "--enable-vhost-user-fs requires --enable-vhost-user"
2371fi
Cindy Lu108a6482020-07-01 22:55:37 +08002372#vhost-vdpa backends
2373test "$vhost_net_vdpa" = "" && vhost_net_vdpa=$vhost_vdpa
2374if test "$vhost_net_vdpa" = "yes" && test "$vhost_vdpa" = "no"; then
2375 error_exit "--enable-vhost-net-vdpa requires --enable-vhost-vdpa"
2376fi
Paolo Bonzini299e6f12019-02-14 18:35:53 +01002377
Laurent Vivier40bc0ca2020-09-24 23:00:23 +02002378# OR the vhost-kernel, vhost-vdpa and vhost-user values for simplicity
Paolo Bonzini299e6f12019-02-14 18:35:53 +01002379if test "$vhost_net" = ""; then
2380 test "$vhost_net_user" = "yes" && vhost_net=yes
Laurent Vivier40bc0ca2020-09-24 23:00:23 +02002381 test "$vhost_net_vdpa" = "yes" && vhost_net=yes
Paolo Bonzini299e6f12019-02-14 18:35:53 +01002382 test "$vhost_kernel" = "yes" && vhost_net=yes
2383fi
2384
Gonglei015a33b2014-07-01 20:58:08 +08002385##########################################
Stefan Weil779ab5e2012-12-16 11:29:45 +01002386# pkg-config probe
2387
2388if ! has "$pkg_config_exe"; then
Peter Maydell76ad07a2013-04-08 12:11:26 +01002389 error_exit "pkg-config binary '$pkg_config_exe' not found"
Stefan Weil779ab5e2012-12-16 11:29:45 +01002390fi
2391
2392##########################################
Juan Quintelab0a47e72009-08-12 18:29:49 +02002393# NPTL probe
2394
Peter Maydell24cb36a2013-07-16 18:45:00 +01002395if test "$linux_user" = "yes"; then
Juan Quintelab0a47e72009-08-12 18:29:49 +02002396 cat > $TMPC <<EOF
pbrookbd0c5662008-05-29 14:34:11 +00002397#include <sched.h>
pbrook30813ce2008-06-02 15:45:44 +00002398#include <linux/futex.h>
Stefan Weil182eacc2011-12-17 09:27:30 +01002399int main(void) {
pbrookbd0c5662008-05-29 14:34:11 +00002400#if !defined(CLONE_SETTLS) || !defined(FUTEX_WAIT)
2401#error bork
2402#endif
Stefan Weil182eacc2011-12-17 09:27:30 +01002403 return 0;
pbrookbd0c5662008-05-29 14:34:11 +00002404}
2405EOF
Peter Maydell24cb36a2013-07-16 18:45:00 +01002406 if ! compile_object ; then
Stewart Smith21684af2014-01-24 12:39:10 +11002407 feature_not_found "nptl" "Install glibc and linux kernel headers."
Juan Quintelab0a47e72009-08-12 18:29:49 +02002408 fi
pbrookbd0c5662008-05-29 14:34:11 +00002409fi
2410
balrogac629222008-10-11 09:56:04 +00002411##########################################
qiaonuohan607dacd2014-02-18 14:11:30 +08002412# lzo check
2413
2414if test "$lzo" != "no" ; then
2415 cat > $TMPC << EOF
2416#include <lzo/lzo1x.h>
2417int main(void) { lzo_version(); return 0; }
2418EOF
2419 if compile_prog "" "-llzo2" ; then
Marc-André Lureau708eab42019-09-03 16:59:33 +04002420 lzo_libs="-llzo2"
Stefan Weilb25c9df2014-04-29 08:21:16 +02002421 lzo="yes"
qiaonuohan607dacd2014-02-18 14:11:30 +08002422 else
Stefan Weilb25c9df2014-04-29 08:21:16 +02002423 if test "$lzo" = "yes"; then
2424 feature_not_found "liblzo2" "Install liblzo2 devel"
2425 fi
2426 lzo="no"
qiaonuohan607dacd2014-02-18 14:11:30 +08002427 fi
qiaonuohan607dacd2014-02-18 14:11:30 +08002428fi
2429
2430##########################################
2431# snappy check
2432
2433if test "$snappy" != "no" ; then
2434 cat > $TMPC << EOF
2435#include <snappy-c.h>
2436int main(void) { snappy_max_compressed_length(4096); return 0; }
2437EOF
2438 if compile_prog "" "-lsnappy" ; then
Marc-André Lureau708eab42019-09-03 16:59:33 +04002439 snappy_libs='-lsnappy'
Stefan Weilb25c9df2014-04-29 08:21:16 +02002440 snappy="yes"
qiaonuohan607dacd2014-02-18 14:11:30 +08002441 else
Stefan Weilb25c9df2014-04-29 08:21:16 +02002442 if test "$snappy" = "yes"; then
2443 feature_not_found "libsnappy" "Install libsnappy devel"
2444 fi
2445 snappy="no"
qiaonuohan607dacd2014-02-18 14:11:30 +08002446 fi
qiaonuohan607dacd2014-02-18 14:11:30 +08002447fi
2448
2449##########################################
Peter Wu6b383c02015-01-06 18:48:14 +01002450# bzip2 check
2451
2452if test "$bzip2" != "no" ; then
2453 cat > $TMPC << EOF
2454#include <bzlib.h>
2455int main(void) { BZ2_bzlibVersion(); return 0; }
2456EOF
2457 if compile_prog "" "-lbz2" ; then
2458 bzip2="yes"
2459 else
2460 if test "$bzip2" = "yes"; then
2461 feature_not_found "libbzip2" "Install libbzip2 devel"
2462 fi
2463 bzip2="no"
2464 fi
2465fi
2466
2467##########################################
Julio Faracco83bc1f92018-11-05 13:08:04 -02002468# lzfse check
2469
2470if test "$lzfse" != "no" ; then
2471 cat > $TMPC << EOF
2472#include <lzfse.h>
2473int main(void) { lzfse_decode_scratch_size(); return 0; }
2474EOF
2475 if compile_prog "" "-llzfse" ; then
2476 lzfse="yes"
2477 else
2478 if test "$lzfse" = "yes"; then
2479 feature_not_found "lzfse" "Install lzfse devel"
2480 fi
2481 lzfse="no"
2482 fi
2483fi
2484
2485##########################################
Juan Quintela3a678482019-12-17 21:15:24 +01002486# zstd check
2487
2488if test "$zstd" != "no" ; then
Juan Quintela297254c2020-03-10 12:14:31 +01002489 libzstd_minver="1.4.0"
2490 if $pkg_config --atleast-version=$libzstd_minver libzstd ; then
Juan Quintela3a678482019-12-17 21:15:24 +01002491 zstd_cflags="$($pkg_config --cflags libzstd)"
2492 zstd_libs="$($pkg_config --libs libzstd)"
Juan Quintela3a678482019-12-17 21:15:24 +01002493 zstd="yes"
2494 else
2495 if test "$zstd" = "yes" ; then
2496 feature_not_found "libzstd" "Install libzstd devel"
2497 fi
2498 zstd="no"
2499 fi
2500fi
2501
2502##########################################
Eduardo Otubof7945732012-08-14 18:44:05 -03002503# libseccomp check
2504
2505if test "$seccomp" != "no" ; then
Helge Deller25ed0ec2019-04-04 20:39:23 +02002506 libseccomp_minver="2.3.0"
2507 if $pkg_config --atleast-version=$libseccomp_minver libseccomp ; then
Fam Zhengc3883e12017-09-07 16:53:16 +08002508 seccomp_cflags="$($pkg_config --cflags libseccomp)"
2509 seccomp_libs="$($pkg_config --libs libseccomp)"
Andrew Jones693e5912015-09-30 11:59:18 -04002510 seccomp="yes"
Eduardo Otubof7945732012-08-14 18:44:05 -03002511 else
Andrew Jones693e5912015-09-30 11:59:18 -04002512 if test "$seccomp" = "yes" ; then
Helge Deller25ed0ec2019-04-04 20:39:23 +02002513 feature_not_found "libseccomp" \
2514 "Install libseccomp devel >= $libseccomp_minver"
Andrew Jones693e5912015-09-30 11:59:18 -04002515 fi
2516 seccomp="no"
Eduardo Otubof7945732012-08-14 18:44:05 -03002517 fi
2518fi
Paolo Bonzini3bd40ec2020-09-18 05:22:37 -04002519
Eduardo Otubof7945732012-08-14 18:44:05 -03002520##########################################
aliguorie37630c2009-04-22 15:19:10 +00002521# xen probe
2522
Paolo Bonzini1badb702020-09-18 04:57:25 -04002523if test "$xen" != "disabled" ; then
Juergen Grossc1cdd9d2017-03-27 09:42:45 +02002524 # Check whether Xen library path is specified via --extra-ldflags to avoid
2525 # overriding this setting with pkg-config output. If not, try pkg-config
2526 # to obtain all needed flags.
Anthony PERARDd5b93dd2011-02-25 16:20:34 +00002527
Juergen Grossc1cdd9d2017-03-27 09:42:45 +02002528 if ! echo $EXTRA_LDFLAGS | grep tools/libxc > /dev/null && \
2529 $pkg_config --exists xencontrol ; then
2530 xen_ctrl_version="$(printf '%d%02d%02d' \
2531 $($pkg_config --modversion xencontrol | sed 's/\./ /g') )"
Paolo Bonzini1badb702020-09-18 04:57:25 -04002532 xen=enabled
Michael Tokarev5b6a8f42020-07-27 17:00:48 +03002533 xen_pc="xencontrol xenstore xenforeignmemory xengnttab"
Juergen Grossc1cdd9d2017-03-27 09:42:45 +02002534 xen_pc="$xen_pc xenevtchn xendevicemodel"
Anthony PERARD58ea9a72017-09-25 16:01:48 +01002535 if $pkg_config --exists xentoolcore; then
2536 xen_pc="$xen_pc xentoolcore"
2537 fi
Marc-André Lureau582ea952019-08-15 15:15:32 +04002538 xen_cflags="$($pkg_config --cflags $xen_pc)"
2539 xen_libs="$($pkg_config --libs $xen_pc)"
Juergen Grossc1cdd9d2017-03-27 09:42:45 +02002540 else
Stefan Weil50ced5b2011-12-17 09:27:39 +01002541
Michael Tokarev5b6a8f42020-07-27 17:00:48 +03002542 xen_libs="-lxenstore -lxenctrl"
Anthony PERARDd9506ca2017-05-11 12:35:42 +01002543 xen_stable_libs="-lxenforeignmemory -lxengnttab -lxenevtchn"
Juergen Grossc1cdd9d2017-03-27 09:42:45 +02002544
2545 # First we test whether Xen headers and libraries are available.
2546 # If no, we are done and there is no Xen support.
2547 # If yes, more tests are run to detect the Xen version.
2548
2549 # Xen (any)
2550 cat > $TMPC <<EOF
aliguorie37630c2009-04-22 15:19:10 +00002551#include <xenctrl.h>
Stefan Weil50ced5b2011-12-17 09:27:39 +01002552int main(void) {
2553 return 0;
2554}
2555EOF
Juergen Grossc1cdd9d2017-03-27 09:42:45 +02002556 if ! compile_prog "" "$xen_libs" ; then
2557 # Xen not found
Paolo Bonzini1badb702020-09-18 04:57:25 -04002558 if test "$xen" = "enabled" ; then
Juergen Grossc1cdd9d2017-03-27 09:42:45 +02002559 feature_not_found "xen" "Install xen devel"
2560 fi
Paolo Bonzini1badb702020-09-18 04:57:25 -04002561 xen=disabled
Stefan Weil50ced5b2011-12-17 09:27:39 +01002562
Juergen Grossc1cdd9d2017-03-27 09:42:45 +02002563 # Xen unstable
2564 elif
2565 cat > $TMPC <<EOF &&
Ross Lagerwall2cbf8902017-10-23 10:27:27 +01002566#undef XC_WANT_COMPAT_DEVICEMODEL_API
2567#define __XEN_TOOLS__
2568#include <xendevicemodel.h>
Paul Durrantd3c49eb2018-05-15 17:40:53 +01002569#include <xenforeignmemory.h>
Ross Lagerwall2cbf8902017-10-23 10:27:27 +01002570int main(void) {
2571 xendevicemodel_handle *xd;
Paul Durrantd3c49eb2018-05-15 17:40:53 +01002572 xenforeignmemory_handle *xfmem;
Ross Lagerwall2cbf8902017-10-23 10:27:27 +01002573
2574 xd = xendevicemodel_open(0, 0);
2575 xendevicemodel_pin_memory_cacheattr(xd, 0, 0, 0, 0);
2576
Paul Durrantd3c49eb2018-05-15 17:40:53 +01002577 xfmem = xenforeignmemory_open(0, 0);
2578 xenforeignmemory_map_resource(xfmem, 0, 0, 0, 0, 0, NULL, 0, 0);
2579
Ross Lagerwall2cbf8902017-10-23 10:27:27 +01002580 return 0;
2581}
2582EOF
2583 compile_prog "" "$xen_libs -lxendevicemodel $xen_stable_libs -lxentoolcore"
2584 then
2585 xen_stable_libs="-lxendevicemodel $xen_stable_libs -lxentoolcore"
2586 xen_ctrl_version=41100
Paolo Bonzini1badb702020-09-18 04:57:25 -04002587 xen=enabled
Ross Lagerwall2cbf8902017-10-23 10:27:27 +01002588 elif
2589 cat > $TMPC <<EOF &&
Igor Druzhinin5ba3d752017-07-10 23:40:02 +01002590#undef XC_WANT_COMPAT_MAP_FOREIGN_API
2591#include <xenforeignmemory.h>
Anthony PERARD58ea9a72017-09-25 16:01:48 +01002592#include <xentoolcore.h>
Igor Druzhinin5ba3d752017-07-10 23:40:02 +01002593int main(void) {
2594 xenforeignmemory_handle *xfmem;
2595
2596 xfmem = xenforeignmemory_open(0, 0);
2597 xenforeignmemory_map2(xfmem, 0, 0, 0, 0, 0, 0, 0);
Anthony PERARD58ea9a72017-09-25 16:01:48 +01002598 xentoolcore_restrict_all(0);
Igor Druzhinin5ba3d752017-07-10 23:40:02 +01002599
2600 return 0;
2601}
2602EOF
Anthony PERARD58ea9a72017-09-25 16:01:48 +01002603 compile_prog "" "$xen_libs -lxendevicemodel $xen_stable_libs -lxentoolcore"
Igor Druzhinin5ba3d752017-07-10 23:40:02 +01002604 then
Anthony PERARD58ea9a72017-09-25 16:01:48 +01002605 xen_stable_libs="-lxendevicemodel $xen_stable_libs -lxentoolcore"
Igor Druzhinin5ba3d752017-07-10 23:40:02 +01002606 xen_ctrl_version=41000
Paolo Bonzini1badb702020-09-18 04:57:25 -04002607 xen=enabled
Igor Druzhinin5ba3d752017-07-10 23:40:02 +01002608 elif
2609 cat > $TMPC <<EOF &&
Paul Durrantda8090c2017-03-07 10:55:33 +00002610#undef XC_WANT_COMPAT_DEVICEMODEL_API
2611#define __XEN_TOOLS__
2612#include <xendevicemodel.h>
2613int main(void) {
2614 xendevicemodel_handle *xd;
2615
2616 xd = xendevicemodel_open(0, 0);
2617 xendevicemodel_close(xd);
2618
2619 return 0;
2620}
2621EOF
Juergen Grossc1cdd9d2017-03-27 09:42:45 +02002622 compile_prog "" "$xen_libs -lxendevicemodel $xen_stable_libs"
2623 then
2624 xen_stable_libs="-lxendevicemodel $xen_stable_libs"
2625 xen_ctrl_version=40900
Paolo Bonzini1badb702020-09-18 04:57:25 -04002626 xen=enabled
Juergen Grossc1cdd9d2017-03-27 09:42:45 +02002627 elif
2628 cat > $TMPC <<EOF &&
Ian Campbell5eeb39c2016-01-15 13:23:42 +00002629/*
2630 * If we have stable libs the we don't want the libxc compat
2631 * layers, regardless of what CFLAGS we may have been given.
Paulina Szubarczykb6eb9b42016-09-14 21:10:03 +02002632 *
2633 * Also, check if xengnttab_grant_copy_segment_t is defined and
2634 * grant copy operation is implemented.
2635 */
2636#undef XC_WANT_COMPAT_EVTCHN_API
2637#undef XC_WANT_COMPAT_GNTTAB_API
2638#undef XC_WANT_COMPAT_MAP_FOREIGN_API
2639#include <xenctrl.h>
2640#include <xenstore.h>
2641#include <xenevtchn.h>
2642#include <xengnttab.h>
2643#include <xenforeignmemory.h>
2644#include <stdint.h>
2645#include <xen/hvm/hvm_info_table.h>
2646#if !defined(HVM_MAX_VCPUS)
2647# error HVM_MAX_VCPUS not defined
2648#endif
2649int main(void) {
2650 xc_interface *xc = NULL;
2651 xenforeignmemory_handle *xfmem;
2652 xenevtchn_handle *xe;
2653 xengnttab_handle *xg;
Paulina Szubarczykb6eb9b42016-09-14 21:10:03 +02002654 xengnttab_grant_copy_segment_t* seg = NULL;
2655
2656 xs_daemon_open();
2657
2658 xc = xc_interface_open(0, 0, 0);
2659 xc_hvm_set_mem_type(0, 0, HVMMEM_ram_ro, 0, 0);
2660 xc_domain_add_to_physmap(0, 0, XENMAPSPACE_gmfn, 0, 0);
2661 xc_hvm_inject_msi(xc, 0, 0xf0000000, 0x00000000);
2662 xc_hvm_create_ioreq_server(xc, 0, HVM_IOREQSRV_BUFIOREQ_ATOMIC, NULL);
Paulina Szubarczykb6eb9b42016-09-14 21:10:03 +02002663
2664 xfmem = xenforeignmemory_open(0, 0);
2665 xenforeignmemory_map(xfmem, 0, 0, 0, 0, 0);
2666
2667 xe = xenevtchn_open(0, 0);
2668 xenevtchn_fd(xe);
2669
2670 xg = xengnttab_open(0, 0);
2671 xengnttab_grant_copy(xg, 0, seg);
2672
2673 return 0;
2674}
2675EOF
Juergen Grossc1cdd9d2017-03-27 09:42:45 +02002676 compile_prog "" "$xen_libs $xen_stable_libs"
2677 then
2678 xen_ctrl_version=40800
Paolo Bonzini1badb702020-09-18 04:57:25 -04002679 xen=enabled
Juergen Grossc1cdd9d2017-03-27 09:42:45 +02002680 elif
2681 cat > $TMPC <<EOF &&
Paulina Szubarczykb6eb9b42016-09-14 21:10:03 +02002682/*
2683 * If we have stable libs the we don't want the libxc compat
2684 * layers, regardless of what CFLAGS we may have been given.
Ian Campbell5eeb39c2016-01-15 13:23:42 +00002685 */
2686#undef XC_WANT_COMPAT_EVTCHN_API
2687#undef XC_WANT_COMPAT_GNTTAB_API
2688#undef XC_WANT_COMPAT_MAP_FOREIGN_API
2689#include <xenctrl.h>
2690#include <xenstore.h>
2691#include <xenevtchn.h>
2692#include <xengnttab.h>
2693#include <xenforeignmemory.h>
2694#include <stdint.h>
2695#include <xen/hvm/hvm_info_table.h>
2696#if !defined(HVM_MAX_VCPUS)
2697# error HVM_MAX_VCPUS not defined
2698#endif
2699int main(void) {
2700 xc_interface *xc = NULL;
2701 xenforeignmemory_handle *xfmem;
2702 xenevtchn_handle *xe;
2703 xengnttab_handle *xg;
Ian Campbell5eeb39c2016-01-15 13:23:42 +00002704
2705 xs_daemon_open();
2706
2707 xc = xc_interface_open(0, 0, 0);
2708 xc_hvm_set_mem_type(0, 0, HVMMEM_ram_ro, 0, 0);
2709 xc_domain_add_to_physmap(0, 0, XENMAPSPACE_gmfn, 0, 0);
2710 xc_hvm_inject_msi(xc, 0, 0xf0000000, 0x00000000);
2711 xc_hvm_create_ioreq_server(xc, 0, HVM_IOREQSRV_BUFIOREQ_ATOMIC, NULL);
Ian Campbell5eeb39c2016-01-15 13:23:42 +00002712
2713 xfmem = xenforeignmemory_open(0, 0);
2714 xenforeignmemory_map(xfmem, 0, 0, 0, 0, 0);
2715
2716 xe = xenevtchn_open(0, 0);
2717 xenevtchn_fd(xe);
2718
2719 xg = xengnttab_open(0, 0);
2720 xengnttab_map_grant_ref(xg, 0, 0, 0);
2721
2722 return 0;
2723}
2724EOF
Juergen Grossc1cdd9d2017-03-27 09:42:45 +02002725 compile_prog "" "$xen_libs $xen_stable_libs"
2726 then
2727 xen_ctrl_version=40701
Paolo Bonzini1badb702020-09-18 04:57:25 -04002728 xen=enabled
Roger Pau Monnecdadde32015-11-13 17:38:06 +00002729
Juergen Grossc1cdd9d2017-03-27 09:42:45 +02002730 # Xen 4.6
2731 elif
2732 cat > $TMPC <<EOF &&
Roger Pau Monnecdadde32015-11-13 17:38:06 +00002733#include <xenctrl.h>
Anthony PERARDe108a3c2012-06-21 11:44:35 +00002734#include <xenstore.h>
Anthony PERARDd5b93dd2011-02-25 16:20:34 +00002735#include <stdint.h>
2736#include <xen/hvm/hvm_info_table.h>
2737#if !defined(HVM_MAX_VCPUS)
2738# error HVM_MAX_VCPUS not defined
2739#endif
2740int main(void) {
2741 xc_interface *xc;
2742 xs_daemon_open();
2743 xc = xc_interface_open(0, 0, 0);
2744 xc_hvm_set_mem_type(0, 0, HVMMEM_ram_ro, 0, 0);
2745 xc_gnttab_open(NULL, 0);
Anthony PERARDb87de242011-05-24 14:34:20 +01002746 xc_domain_add_to_physmap(0, 0, XENMAPSPACE_gmfn, 0, 0);
Stefano Stabellini8688e062012-04-17 17:04:18 +00002747 xc_hvm_inject_msi(xc, 0, 0xf0000000, 0x00000000);
Jan Beulichd8b441a2015-07-24 03:38:28 -06002748 xc_hvm_create_ioreq_server(xc, 0, HVM_IOREQSRV_BUFIOREQ_ATOMIC, NULL);
Konrad Rzeszutek Wilk20a544c2015-06-29 12:51:05 -04002749 xc_reserved_device_memory_map(xc, 0, 0, 0, 0, NULL, 0);
Jan Beulichd8b441a2015-07-24 03:38:28 -06002750 return 0;
2751}
2752EOF
Juergen Grossc1cdd9d2017-03-27 09:42:45 +02002753 compile_prog "" "$xen_libs"
2754 then
2755 xen_ctrl_version=40600
Paolo Bonzini1badb702020-09-18 04:57:25 -04002756 xen=enabled
Jan Beulichd8b441a2015-07-24 03:38:28 -06002757
Juergen Grossc1cdd9d2017-03-27 09:42:45 +02002758 # Xen 4.5
2759 elif
2760 cat > $TMPC <<EOF &&
Jan Beulichd8b441a2015-07-24 03:38:28 -06002761#include <xenctrl.h>
2762#include <xenstore.h>
2763#include <stdint.h>
2764#include <xen/hvm/hvm_info_table.h>
2765#if !defined(HVM_MAX_VCPUS)
2766# error HVM_MAX_VCPUS not defined
2767#endif
2768int main(void) {
2769 xc_interface *xc;
2770 xs_daemon_open();
2771 xc = xc_interface_open(0, 0, 0);
2772 xc_hvm_set_mem_type(0, 0, HVMMEM_ram_ro, 0, 0);
2773 xc_gnttab_open(NULL, 0);
2774 xc_domain_add_to_physmap(0, 0, XENMAPSPACE_gmfn, 0, 0);
2775 xc_hvm_inject_msi(xc, 0, 0xf0000000, 0x00000000);
Paul Durrant3996e852015-01-20 11:06:19 +00002776 xc_hvm_create_ioreq_server(xc, 0, 0, NULL);
2777 return 0;
2778}
2779EOF
Juergen Grossc1cdd9d2017-03-27 09:42:45 +02002780 compile_prog "" "$xen_libs"
2781 then
2782 xen_ctrl_version=40500
Paolo Bonzini1badb702020-09-18 04:57:25 -04002783 xen=enabled
Paul Durrant3996e852015-01-20 11:06:19 +00002784
Juergen Grossc1cdd9d2017-03-27 09:42:45 +02002785 elif
2786 cat > $TMPC <<EOF &&
Paul Durrant3996e852015-01-20 11:06:19 +00002787#include <xenctrl.h>
2788#include <xenstore.h>
2789#include <stdint.h>
2790#include <xen/hvm/hvm_info_table.h>
2791#if !defined(HVM_MAX_VCPUS)
2792# error HVM_MAX_VCPUS not defined
2793#endif
2794int main(void) {
2795 xc_interface *xc;
2796 xs_daemon_open();
2797 xc = xc_interface_open(0, 0, 0);
2798 xc_hvm_set_mem_type(0, 0, HVMMEM_ram_ro, 0, 0);
2799 xc_gnttab_open(NULL, 0);
2800 xc_domain_add_to_physmap(0, 0, XENMAPSPACE_gmfn, 0, 0);
2801 xc_hvm_inject_msi(xc, 0, 0xf0000000, 0x00000000);
Stefano Stabellini8688e062012-04-17 17:04:18 +00002802 return 0;
2803}
2804EOF
Juergen Grossc1cdd9d2017-03-27 09:42:45 +02002805 compile_prog "" "$xen_libs"
2806 then
2807 xen_ctrl_version=40200
Paolo Bonzini1badb702020-09-18 04:57:25 -04002808 xen=enabled
Stefano Stabellini8688e062012-04-17 17:04:18 +00002809
Juergen Grossc1cdd9d2017-03-27 09:42:45 +02002810 else
Paolo Bonzini1badb702020-09-18 04:57:25 -04002811 if test "$xen" = "enabled" ; then
Juergen Grossc1cdd9d2017-03-27 09:42:45 +02002812 feature_not_found "xen (unsupported version)" \
2813 "Install a supported xen (xen 4.2 or newer)"
2814 fi
Paolo Bonzini1badb702020-09-18 04:57:25 -04002815 xen=disabled
Juan Quintelafc321b42009-08-12 18:29:55 +02002816 fi
Anthony PERARDd5b93dd2011-02-25 16:20:34 +00002817
Paolo Bonzini1badb702020-09-18 04:57:25 -04002818 if test "$xen" = enabled; then
Juergen Grossc1cdd9d2017-03-27 09:42:45 +02002819 if test $xen_ctrl_version -ge 40701 ; then
Marc-André Lureau582ea952019-08-15 15:15:32 +04002820 xen_libs="$xen_libs $xen_stable_libs "
Juergen Grossc1cdd9d2017-03-27 09:42:45 +02002821 fi
Ian Campbell5eeb39c2016-01-15 13:23:42 +00002822 fi
Anthony PERARDd5b93dd2011-02-25 16:20:34 +00002823 fi
aliguorie37630c2009-04-22 15:19:10 +00002824fi
2825
Paolo Bonzini1badb702020-09-18 04:57:25 -04002826if test "$xen_pci_passthrough" != "disabled"; then
2827 if test "$xen" = "enabled" && test "$linux" = "yes"; then
2828 xen_pci_passthrough=enabled
Anthony PERARDeb6fda02012-06-21 15:32:59 +00002829 else
Paolo Bonzini1badb702020-09-18 04:57:25 -04002830 if test "$xen_pci_passthrough" = "enabled"; then
Peter Maydell76ad07a2013-04-08 12:11:26 +01002831 error_exit "User requested feature Xen PCI Passthrough" \
2832 " but this feature requires /sys from Linux"
Anthony PERARDeb6fda02012-06-21 15:32:59 +00002833 fi
Paolo Bonzini1badb702020-09-18 04:57:25 -04002834 xen_pci_passthrough=disabled
Anthony PERARDeb6fda02012-06-21 15:32:59 +00002835 fi
2836fi
2837
aliguorie37630c2009-04-22 15:19:10 +00002838##########################################
Marc-André Lureaue8f3bd72019-09-19 21:02:09 +04002839# gettext probe
2840if test "$gettext" != "false" ; then
2841 if has xgettext; then
2842 gettext=true
2843 else
2844 if test "$gettext" = "true" ; then
2845 feature_not_found "gettext" "Install xgettext binary"
2846 fi
2847 gettext=false
2848 fi
2849fi
2850
2851##########################################
Jeremy Whitef676c672015-01-09 13:08:49 -06002852# X11 probe
Jeremy Whitef676c672015-01-09 13:08:49 -06002853if $pkg_config --exists "x11"; then
Gerd Hoffmann87815952018-03-01 11:05:42 +01002854 have_x11=yes
Stefan Weil89138852016-05-16 15:10:20 +02002855 x11_cflags=$($pkg_config --cflags x11)
2856 x11_libs=$($pkg_config --libs x11)
Jeremy Whitef676c672015-01-09 13:08:49 -06002857fi
2858
2859##########################################
Anthony Liguoria4ccabc2013-02-20 07:43:20 -06002860# GTK probe
2861
2862if test "$gtk" != "no"; then
Daniel P. Berrangé89d85cd2018-08-22 14:15:52 +01002863 gtkpackage="gtk+-3.0"
2864 gtkx11package="gtk+-x11-3.0"
Volker Rümelin7b23d122020-05-16 09:20:14 +02002865 gtkversion="3.22.0"
Stefan Weilbbbf9bf2014-02-19 07:04:34 +01002866 if $pkg_config --exists "$gtkpackage >= $gtkversion"; then
Stefan Weil89138852016-05-16 15:10:20 +02002867 gtk_cflags=$($pkg_config --cflags $gtkpackage)
2868 gtk_libs=$($pkg_config --libs $gtkpackage)
2869 gtk_version=$($pkg_config --modversion $gtkpackage)
Gerd Hoffmann0a337ed2014-05-28 22:33:06 +02002870 if $pkg_config --exists "$gtkx11package >= $gtkversion"; then
Gerd Hoffmann87815952018-03-01 11:05:42 +01002871 need_x11=yes
Jeremy Whitef676c672015-01-09 13:08:49 -06002872 gtk_cflags="$gtk_cflags $x11_cflags"
2873 gtk_libs="$gtk_libs $x11_libs"
Gerd Hoffmann0a337ed2014-05-28 22:33:06 +02002874 fi
Stefan Weilbbbf9bf2014-02-19 07:04:34 +01002875 gtk="yes"
2876 elif test "$gtk" = "yes"; then
Gerd Hoffmann5fe309f2017-06-06 12:53:36 +02002877 feature_not_found "gtk" "Install gtk3-devel"
Stefan Weilbbbf9bf2014-02-19 07:04:34 +01002878 else
2879 gtk="no"
2880 fi
2881fi
2882
Daniel P. Berrangeddbb0d02015-07-01 18:10:29 +01002883
2884##########################################
2885# GNUTLS probe
2886
2887if test "$gnutls" != "no"; then
Richard Hendersona73e82e2019-05-09 18:24:35 -07002888 pass="no"
Daniel P. Berrangéa0722402018-07-18 11:55:05 +01002889 if $pkg_config --exists "gnutls >= 3.1.18"; then
Stefan Weil89138852016-05-16 15:10:20 +02002890 gnutls_cflags=$($pkg_config --cflags gnutls)
2891 gnutls_libs=$($pkg_config --libs gnutls)
Richard Hendersona73e82e2019-05-09 18:24:35 -07002892 # Packaging for the static libraries is not always correct.
2893 # At least ubuntu 18.04 ships only shared libraries.
2894 write_c_skeleton
2895 if compile_prog "" "$gnutls_libs" ; then
Richard Hendersona73e82e2019-05-09 18:24:35 -07002896 pass="yes"
2897 fi
2898 fi
2899 if test "$pass" = "no" && test "$gnutls" = "yes"; then
Daniel P. Berrangéa0722402018-07-18 11:55:05 +01002900 feature_not_found "gnutls" "Install gnutls devel >= 3.1.18"
Daniel P. Berrangeddbb0d02015-07-01 18:10:29 +01002901 else
Richard Hendersona73e82e2019-05-09 18:24:35 -07002902 gnutls="$pass"
Daniel P. Berrangeddbb0d02015-07-01 18:10:29 +01002903 fi
Daniel P. Berrangeddbb0d02015-07-01 18:10:29 +01002904fi
2905
Daniel P. Berrange91bfcdb2015-10-16 16:36:53 +01002906
2907# If user didn't give a --disable/enable-gcrypt flag,
2908# then mark as disabled if user requested nettle
Daniel P. Berrangéa0722402018-07-18 11:55:05 +01002909# explicitly
Daniel P. Berrange91bfcdb2015-10-16 16:36:53 +01002910if test -z "$gcrypt"
2911then
Daniel P. Berrangéa0722402018-07-18 11:55:05 +01002912 if test "$nettle" = "yes"
Daniel P. Berrange91bfcdb2015-10-16 16:36:53 +01002913 then
2914 gcrypt="no"
2915 fi
2916fi
2917
2918# If user didn't give a --disable/enable-nettle flag,
2919# then mark as disabled if user requested gcrypt
Daniel P. Berrangéa0722402018-07-18 11:55:05 +01002920# explicitly
Daniel P. Berrange91bfcdb2015-10-16 16:36:53 +01002921if test -z "$nettle"
2922then
Daniel P. Berrangéa0722402018-07-18 11:55:05 +01002923 if test "$gcrypt" = "yes"
Daniel P. Berrange91bfcdb2015-10-16 16:36:53 +01002924 then
2925 nettle="no"
2926 fi
2927fi
2928
Daniel P. Berrangédea7a642018-07-18 11:55:05 +01002929has_libgcrypt() {
Daniel P. Berrange91bfcdb2015-10-16 16:36:53 +01002930 if ! has "libgcrypt-config"
2931 then
2932 return 1
2933 fi
2934
2935 if test -n "$cross_prefix"
2936 then
Stefan Weil89138852016-05-16 15:10:20 +02002937 host=$(libgcrypt-config --host)
Daniel P. Berrange91bfcdb2015-10-16 16:36:53 +01002938 if test "$host-" != $cross_prefix
2939 then
2940 return 1
2941 fi
2942 fi
2943
Daniel P. Berrangédea7a642018-07-18 11:55:05 +01002944 maj=`libgcrypt-config --version | awk -F . '{print $1}'`
2945 min=`libgcrypt-config --version | awk -F . '{print $2}'`
2946
2947 if test $maj != 1 || test $min -lt 5
2948 then
2949 return 1
2950 fi
2951
Daniel P. Berrange91bfcdb2015-10-16 16:36:53 +01002952 return 0
2953}
2954
Daniel P. Berrangéa0722402018-07-18 11:55:05 +01002955
2956if test "$nettle" != "no"; then
Richard Hendersona73e82e2019-05-09 18:24:35 -07002957 pass="no"
Daniel P. Berrangé64dd2f32018-07-18 11:55:05 +01002958 if $pkg_config --exists "nettle >= 2.7.1"; then
Daniel P. Berrangéa0722402018-07-18 11:55:05 +01002959 nettle_cflags=$($pkg_config --cflags nettle)
2960 nettle_libs=$($pkg_config --libs nettle)
2961 nettle_version=$($pkg_config --modversion nettle)
Richard Hendersona73e82e2019-05-09 18:24:35 -07002962 # Link test to make sure the given libraries work (e.g for static).
2963 write_c_skeleton
2964 if compile_prog "" "$nettle_libs" ; then
Richard Hendersona73e82e2019-05-09 18:24:35 -07002965 if test -z "$gcrypt"; then
2966 gcrypt="no"
2967 fi
2968 pass="yes"
Daniel P. Berrangéa0722402018-07-18 11:55:05 +01002969 fi
Richard Hendersona73e82e2019-05-09 18:24:35 -07002970 fi
Daniel P. Berrangédc2207a2019-10-14 17:28:27 +01002971 if test "$pass" = "yes"
2972 then
2973 cat > $TMPC << EOF
2974#include <nettle/xts.h>
2975int main(void) {
2976 return 0;
2977}
2978EOF
2979 if compile_prog "$nettle_cflags" "$nettle_libs" ; then
2980 nettle_xts=yes
2981 qemu_private_xts=no
2982 fi
2983 fi
Richard Hendersona73e82e2019-05-09 18:24:35 -07002984 if test "$pass" = "no" && test "$nettle" = "yes"; then
2985 feature_not_found "nettle" "Install nettle devel >= 2.7.1"
Daniel P. Berrangéa0722402018-07-18 11:55:05 +01002986 else
Richard Hendersona73e82e2019-05-09 18:24:35 -07002987 nettle="$pass"
Daniel P. Berrangéa0722402018-07-18 11:55:05 +01002988 fi
2989fi
2990
Daniel P. Berrange91bfcdb2015-10-16 16:36:53 +01002991if test "$gcrypt" != "no"; then
Richard Hendersona73e82e2019-05-09 18:24:35 -07002992 pass="no"
Daniel P. Berrangédea7a642018-07-18 11:55:05 +01002993 if has_libgcrypt; then
Stefan Weil89138852016-05-16 15:10:20 +02002994 gcrypt_cflags=$(libgcrypt-config --cflags)
2995 gcrypt_libs=$(libgcrypt-config --libs)
Richard Hendersona73e82e2019-05-09 18:24:35 -07002996 # Debian has removed -lgpg-error from libgcrypt-config
Daniel P. Berrange91bfcdb2015-10-16 16:36:53 +01002997 # as it "spreads unnecessary dependencies" which in
2998 # turn breaks static builds...
2999 if test "$static" = "yes"
3000 then
3001 gcrypt_libs="$gcrypt_libs -lgpg-error"
3002 fi
Longpeng(Mike)1f923c72016-12-13 18:42:55 +08003003
Richard Hendersona73e82e2019-05-09 18:24:35 -07003004 # Link test to make sure the given libraries work (e.g for static).
3005 write_c_skeleton
3006 if compile_prog "" "$gcrypt_libs" ; then
Richard Hendersona73e82e2019-05-09 18:24:35 -07003007 pass="yes"
3008 fi
3009 fi
3010 if test "$pass" = "yes"; then
3011 gcrypt="yes"
Longpeng(Mike)1f923c72016-12-13 18:42:55 +08003012 cat > $TMPC << EOF
3013#include <gcrypt.h>
3014int main(void) {
3015 gcry_mac_hd_t handle;
3016 gcry_mac_open(&handle, GCRY_MAC_HMAC_MD5,
3017 GCRY_MAC_FLAG_SECURE, NULL);
3018 return 0;
3019}
3020EOF
3021 if compile_prog "$gcrypt_cflags" "$gcrypt_libs" ; then
3022 gcrypt_hmac=yes
3023 fi
Daniel P. Berrangée0576942019-10-14 17:28:27 +01003024 cat > $TMPC << EOF
3025#include <gcrypt.h>
3026int main(void) {
3027 gcry_cipher_hd_t handle;
3028 gcry_cipher_open(&handle, GCRY_CIPHER_AES, GCRY_CIPHER_MODE_XTS, 0);
3029 return 0;
3030}
3031EOF
3032 if compile_prog "$gcrypt_cflags" "$gcrypt_libs" ; then
3033 gcrypt_xts=yes
3034 qemu_private_xts=no
3035 fi
Richard Hendersona73e82e2019-05-09 18:24:35 -07003036 elif test "$gcrypt" = "yes"; then
3037 feature_not_found "gcrypt" "Install gcrypt devel >= 1.5.0"
Daniel P. Berrange62893b62015-07-01 18:10:33 +01003038 else
Richard Hendersona73e82e2019-05-09 18:24:35 -07003039 gcrypt="no"
Daniel P. Berrange62893b62015-07-01 18:10:33 +01003040 fi
3041fi
3042
Daniel P. Berrangeddbb0d02015-07-01 18:10:29 +01003043
Daniel P. Berrange91bfcdb2015-10-16 16:36:53 +01003044if test "$gcrypt" = "yes" && test "$nettle" = "yes"
3045then
3046 error_exit "Only one of gcrypt & nettle can be enabled"
3047fi
3048
Daniel P. Berrange9a2fd432015-04-13 14:01:39 +01003049##########################################
3050# libtasn1 - only for the TLS creds/session test suite
3051
3052tasn1=yes
Daniel P. Berrange90246032015-09-21 17:25:34 +01003053tasn1_cflags=""
3054tasn1_libs=""
Daniel P. Berrange9a2fd432015-04-13 14:01:39 +01003055if $pkg_config --exists "libtasn1"; then
Stefan Weil89138852016-05-16 15:10:20 +02003056 tasn1_cflags=$($pkg_config --cflags libtasn1)
3057 tasn1_libs=$($pkg_config --libs libtasn1)
Daniel P. Berrange9a2fd432015-04-13 14:01:39 +01003058else
3059 tasn1=no
3060fi
3061
Daniel P. Berrangeed754742015-07-01 18:10:34 +01003062
Stefan Weilbbbf9bf2014-02-19 07:04:34 +01003063##########################################
Daniel P. Berrange8953caf2016-07-27 14:13:56 +01003064# PAM probe
3065
3066if test "$auth_pam" != "no"; then
3067 cat > $TMPC <<EOF
3068#include <security/pam_appl.h>
3069#include <stdio.h>
3070int main(void) {
3071 const char *service_name = "qemu";
3072 const char *user = "frank";
Dr. David Alan Gilbert9c9642d2019-04-04 10:17:25 +01003073 const struct pam_conv pam_conv = { 0 };
Daniel P. Berrange8953caf2016-07-27 14:13:56 +01003074 pam_handle_t *pamh = NULL;
Dr. David Alan Gilbert9c9642d2019-04-04 10:17:25 +01003075 pam_start(service_name, user, &pam_conv, &pamh);
Daniel P. Berrange8953caf2016-07-27 14:13:56 +01003076 return 0;
3077}
3078EOF
3079 if compile_prog "" "-lpam" ; then
3080 auth_pam=yes
3081 else
3082 if test "$auth_pam" = "yes"; then
3083 feature_not_found "PAM" "Install PAM development package"
3084 else
3085 auth_pam=no
3086 fi
3087 fi
3088fi
3089
3090##########################################
Daniel P. Berrange559607e2015-02-27 16:19:33 +00003091# getifaddrs (for tests/test-io-channel-socket )
3092
3093have_ifaddrs_h=yes
3094if ! check_include "ifaddrs.h" ; then
3095 have_ifaddrs_h=no
3096fi
3097
Chen Gange865b972020-06-05 09:32:21 +08003098#########################################
3099# libdrm check
3100have_drm_h=no
3101if check_include "libdrm/drm.h" ; then
3102 have_drm_h=yes
3103fi
3104
David CARLIER2a4b4722020-07-13 14:36:09 +01003105#########################################
3106# sys/signal.h check
3107have_sys_signal_h=no
3108if check_include "sys/signal.h" ; then
3109 have_sys_signal_h=yes
3110fi
3111
Daniel P. Berrange559607e2015-02-27 16:19:33 +00003112##########################################
Stefan Weilbbbf9bf2014-02-19 07:04:34 +01003113# VTE probe
3114
3115if test "$vte" != "no"; then
Daniel P. Berrangé89d85cd2018-08-22 14:15:52 +01003116 vteminversion="0.32.0"
3117 if $pkg_config --exists "vte-2.91"; then
3118 vtepackage="vte-2.91"
Daniel P. Berrange528de902013-02-25 15:20:44 +00003119 else
Daniel P. Berrangé89d85cd2018-08-22 14:15:52 +01003120 vtepackage="vte-2.90"
Daniel P. Berrange528de902013-02-25 15:20:44 +00003121 fi
Cole Robinsonc6feff92016-05-06 14:03:12 -04003122 if $pkg_config --exists "$vtepackage >= $vteminversion"; then
Stefan Weil89138852016-05-16 15:10:20 +02003123 vte_cflags=$($pkg_config --cflags $vtepackage)
3124 vte_libs=$($pkg_config --libs $vtepackage)
3125 vteversion=$($pkg_config --modversion $vtepackage)
Stefan Weilbbbf9bf2014-02-19 07:04:34 +01003126 vte="yes"
3127 elif test "$vte" = "yes"; then
Daniel P. Berrangé89d85cd2018-08-22 14:15:52 +01003128 feature_not_found "vte" "Install libvte-2.90/2.91 devel"
Peter Maydell0d185e62013-07-18 16:42:01 +01003129 else
Stefan Weilbbbf9bf2014-02-19 07:04:34 +01003130 vte="no"
Anthony Liguoria4ccabc2013-02-20 07:43:20 -06003131 fi
3132fi
3133
3134##########################################
Michael R. Hines2da776d2013-07-22 10:01:54 -04003135# RDMA needs OpenFabrics libraries
3136if test "$rdma" != "no" ; then
3137 cat > $TMPC <<EOF
3138#include <rdma/rdma_cma.h>
3139int main(void) { return 0; }
3140EOF
Yuval Shaiaef6d4cc2018-02-09 15:23:18 +02003141 rdma_libs="-lrdmacm -libverbs -libumad"
Michael R. Hines2da776d2013-07-22 10:01:54 -04003142 if compile_prog "" "$rdma_libs" ; then
3143 rdma="yes"
Michael R. Hines2da776d2013-07-22 10:01:54 -04003144 else
3145 if test "$rdma" = "yes" ; then
3146 error_exit \
Yuval Shaiaef6d4cc2018-02-09 15:23:18 +02003147 " OpenFabrics librdmacm/libibverbs/libibumad not present." \
Michael R. Hines2da776d2013-07-22 10:01:54 -04003148 " Your options:" \
Yuval Shaiaef6d4cc2018-02-09 15:23:18 +02003149 " (1) Fast: Install infiniband packages (devel) from your distro." \
Michael R. Hines2da776d2013-07-22 10:01:54 -04003150 " (2) Cleanest: Install libraries from www.openfabrics.org" \
3151 " (3) Also: Install softiwarp if you don't have RDMA hardware"
3152 fi
3153 rdma="no"
3154 fi
3155fi
3156
Marcel Apfelbaum21ab34c2018-08-16 18:16:37 +03003157##########################################
3158# PVRDMA detection
3159
3160cat > $TMPC <<EOF &&
3161#include <sys/mman.h>
3162
3163int
3164main(void)
3165{
3166 char buf = 0;
3167 void *addr = &buf;
3168 addr = mremap(addr, 0, 1, MREMAP_MAYMOVE | MREMAP_FIXED);
3169
3170 return 0;
3171}
3172EOF
3173
3174if test "$rdma" = "yes" ; then
3175 case "$pvrdma" in
3176 "")
3177 if compile_prog "" ""; then
3178 pvrdma="yes"
3179 else
3180 pvrdma="no"
3181 fi
3182 ;;
3183 "yes")
3184 if ! compile_prog "" ""; then
3185 error_exit "PVRDMA is not supported since mremap is not implemented"
3186 fi
3187 pvrdma="yes"
3188 ;;
3189 "no")
3190 pvrdma="no"
3191 ;;
3192 esac
3193else
3194 if test "$pvrdma" = "yes" ; then
3195 error_exit "PVRDMA requires rdma suppport"
3196 fi
3197 pvrdma="no"
3198fi
ths8d5d2d42007-08-25 01:37:51 +00003199
Yuval Shaiaee108582019-08-18 16:21:06 +03003200# Let's see if enhanced reg_mr is supported
3201if test "$pvrdma" = "yes" ; then
3202
3203cat > $TMPC <<EOF &&
3204#include <infiniband/verbs.h>
3205
3206int
3207main(void)
3208{
3209 struct ibv_mr *mr;
3210 struct ibv_pd *pd = NULL;
3211 size_t length = 10;
3212 uint64_t iova = 0;
3213 int access = 0;
3214 void *addr = NULL;
3215
3216 mr = ibv_reg_mr_iova(pd, addr, length, iova, access);
3217
3218 ibv_dereg_mr(mr);
3219
3220 return 0;
3221}
3222EOF
3223 if ! compile_prog "" "-libverbs"; then
3224 QEMU_CFLAGS="$QEMU_CFLAGS -DLEGACY_RDMA_REG_MR"
3225 fi
3226fi
3227
ths8d5d2d42007-08-25 01:37:51 +00003228##########################################
Eric Blakec1bb86c2016-12-02 13:48:54 -06003229# xfsctl() probe, used for file-posix.c
Christoph Hellwigdce512d2010-12-17 11:41:15 +01003230if test "$xfs" != "no" ; then
3231 cat > $TMPC << EOF
Stefan Weilffc41d12011-12-17 09:27:36 +01003232#include <stddef.h> /* NULL */
Christoph Hellwigdce512d2010-12-17 11:41:15 +01003233#include <xfs/xfs.h>
3234int main(void)
3235{
3236 xfsctl(NULL, 0, 0, NULL);
3237 return 0;
3238}
3239EOF
3240 if compile_prog "" "" ; then
3241 xfs="yes"
3242 else
3243 if test "$xfs" = "yes" ; then
zhaolichange3a6e0d2020-09-17 15:50:20 +08003244 feature_not_found "xfs" "Install xfsprogs/xfslibs devel"
Christoph Hellwigdce512d2010-12-17 11:41:15 +01003245 fi
3246 xfs=no
3247 fi
3248fi
3249
3250##########################################
ths8a16d272008-07-19 09:56:24 +00003251# vde libraries probe
Juan Quinteladfb278b2009-08-12 18:20:27 +02003252if test "$vde" != "no" ; then
Juan Quintela4baae0a2009-07-27 16:13:19 +02003253 vde_libs="-lvdeplug"
ths8a16d272008-07-19 09:56:24 +00003254 cat > $TMPC << EOF
3255#include <libvdeplug.h>
pbrook4a7f0e02008-09-07 16:42:53 +00003256int main(void)
3257{
3258 struct vde_open_args a = {0, 0, 0};
Peter Maydellfea08e02012-07-18 15:10:25 +01003259 char s[] = "";
3260 vde_open(s, s, &a);
pbrook4a7f0e02008-09-07 16:42:53 +00003261 return 0;
3262}
ths8a16d272008-07-19 09:56:24 +00003263EOF
Juan Quintela52166aa2009-08-03 14:46:03 +02003264 if compile_prog "" "$vde_libs" ; then
Juan Quintela4baae0a2009-07-27 16:13:19 +02003265 vde=yes
Juan Quinteladfb278b2009-08-12 18:20:27 +02003266 else
3267 if test "$vde" = "yes" ; then
Stewart Smith21684af2014-01-24 12:39:10 +11003268 feature_not_found "vde" "Install vde (Virtual Distributed Ethernet) devel"
Juan Quinteladfb278b2009-08-12 18:20:27 +02003269 fi
3270 vde=no
Juan Quintela4baae0a2009-07-27 16:13:19 +02003271 fi
ths8a16d272008-07-19 09:56:24 +00003272fi
3273
3274##########################################
Vincenzo Maffione0a985b32014-02-20 15:40:43 +01003275# netmap support probe
3276# Apart from looking for netmap headers, we make sure that the host API version
3277# supports the netmap backend (>=11). The upper bound (15) is meant to simulate
3278# a minor/major version number. Minor new features will be marked with values up
3279# to 15, and if something happens that requires a change to the backend we will
3280# move above 15, submit the backend fixes and modify this two bounds.
Vincenzo Maffione58952132013-11-06 11:44:06 +01003281if test "$netmap" != "no" ; then
3282 cat > $TMPC << EOF
3283#include <inttypes.h>
3284#include <net/if.h>
3285#include <net/netmap.h>
3286#include <net/netmap_user.h>
Vincenzo Maffione0a985b32014-02-20 15:40:43 +01003287#if (NETMAP_API < 11) || (NETMAP_API > 15)
3288#error
3289#endif
Vincenzo Maffione58952132013-11-06 11:44:06 +01003290int main(void) { return 0; }
3291EOF
3292 if compile_prog "" "" ; then
3293 netmap=yes
3294 else
3295 if test "$netmap" = "yes" ; then
3296 feature_not_found "netmap"
3297 fi
3298 netmap=no
3299 fi
3300fi
3301
3302##########################################
Corey Bryant47e98652012-01-26 09:42:26 -05003303# libcap-ng library probe
3304if test "$cap_ng" != "no" ; then
3305 cap_libs="-lcap-ng"
3306 cat > $TMPC << EOF
3307#include <cap-ng.h>
3308int main(void)
3309{
3310 capng_capability_to_name(CAPNG_EFFECTIVE);
3311 return 0;
3312}
3313EOF
3314 if compile_prog "" "$cap_libs" ; then
3315 cap_ng=yes
Corey Bryant47e98652012-01-26 09:42:26 -05003316 else
3317 if test "$cap_ng" = "yes" ; then
Stewart Smith21684af2014-01-24 12:39:10 +11003318 feature_not_found "cap_ng" "Install libcap-ng devel"
Corey Bryant47e98652012-01-26 09:42:26 -05003319 fi
3320 cap_ng=no
3321 fi
3322fi
3323
3324##########################################
malcc2de5c92008-06-28 19:13:06 +00003325# Sound support libraries probe
ths8f28f3f2007-01-05 21:25:54 +00003326
Stefan Weil89138852016-05-16 15:10:20 +02003327audio_drv_list=$(echo "$audio_drv_list" | sed -e 's/,/ /g')
malcc2de5c92008-06-28 19:13:06 +00003328for drv in $audio_drv_list; do
3329 case $drv in
Gerd Hoffmanne42975a2019-01-24 12:20:51 +01003330 alsa | try-alsa)
Gerd Hoffmannc80a8672019-01-24 12:20:50 +01003331 if $pkg_config alsa --exists; then
3332 alsa_libs=$($pkg_config alsa --libs)
Paolo Bonzini478e9432020-08-17 12:47:55 +02003333 alsa_cflags=$($pkg_config alsa --cflags)
3334 alsa=yes
Gerd Hoffmanne42975a2019-01-24 12:20:51 +01003335 if test "$drv" = "try-alsa"; then
3336 audio_drv_list=$(echo "$audio_drv_list" | sed -e 's/try-alsa/alsa/')
3337 fi
Gerd Hoffmannc80a8672019-01-24 12:20:50 +01003338 else
Gerd Hoffmanne42975a2019-01-24 12:20:51 +01003339 if test "$drv" = "try-alsa"; then
3340 audio_drv_list=$(echo "$audio_drv_list" | sed -e 's/try-alsa//')
3341 else
3342 error_exit "$drv check failed" \
3343 "Make sure to have the $drv libs and headers installed."
3344 fi
Gerd Hoffmannc80a8672019-01-24 12:20:50 +01003345 fi
malcc2de5c92008-06-28 19:13:06 +00003346 ;;
3347
Gerd Hoffmanne42975a2019-01-24 12:20:51 +01003348 pa | try-pa)
Gerd Hoffmannc80a8672019-01-24 12:20:50 +01003349 if $pkg_config libpulse --exists; then
Paolo Bonzini478e9432020-08-17 12:47:55 +02003350 libpulse=yes
Gerd Hoffmannc80a8672019-01-24 12:20:50 +01003351 pulse_libs=$($pkg_config libpulse --libs)
Paolo Bonzini478e9432020-08-17 12:47:55 +02003352 pulse_cflags=$($pkg_config libpulse --cflags)
Gerd Hoffmanne42975a2019-01-24 12:20:51 +01003353 if test "$drv" = "try-pa"; then
3354 audio_drv_list=$(echo "$audio_drv_list" | sed -e 's/try-pa/pa/')
3355 fi
Gerd Hoffmannc80a8672019-01-24 12:20:50 +01003356 else
Gerd Hoffmanne42975a2019-01-24 12:20:51 +01003357 if test "$drv" = "try-pa"; then
3358 audio_drv_list=$(echo "$audio_drv_list" | sed -e 's/try-pa//')
3359 else
3360 error_exit "$drv check failed" \
3361 "Make sure to have the $drv libs and headers installed."
3362 fi
Gerd Hoffmannc80a8672019-01-24 12:20:50 +01003363 fi
malcb8e59f12008-07-02 21:03:08 +00003364 ;;
3365
Gerd Hoffmann373967b2017-03-20 10:05:43 +01003366 sdl)
3367 if test "$sdl" = "no"; then
3368 error_exit "sdl not found or disabled, can not use sdl audio driver"
3369 fi
3370 ;;
3371
Gerd Hoffmanne42975a2019-01-24 12:20:51 +01003372 try-sdl)
3373 if test "$sdl" = "no"; then
3374 audio_drv_list=$(echo "$audio_drv_list" | sed -e 's/try-sdl//')
3375 else
3376 audio_drv_list=$(echo "$audio_drv_list" | sed -e 's/try-sdl/sdl/')
3377 fi
3378 ;;
3379
Juan Quintela997e6902009-08-03 14:46:29 +02003380 coreaudio)
Fam Zhengb1149912017-09-07 16:29:13 +08003381 coreaudio_libs="-framework CoreAudio"
Juan Quintela997e6902009-08-03 14:46:29 +02003382 ;;
3383
Juan Quintelaa4bf6782009-08-03 14:46:30 +02003384 dsound)
Fam Zhengb1149912017-09-07 16:29:13 +08003385 dsound_libs="-lole32 -ldxguid"
malcd5631632009-10-10 01:13:41 +04003386 audio_win_int="yes"
Juan Quintelaa4bf6782009-08-03 14:46:30 +02003387 ;;
3388
3389 oss)
Fam Zhengb1149912017-09-07 16:29:13 +08003390 oss_libs="$oss_lib"
Juan Quintelaa4bf6782009-08-03 14:46:30 +02003391 ;;
3392
Geoffrey McRae2e445702020-04-29 15:53:58 +10003393 jack | try-jack)
3394 if $pkg_config jack --exists; then
Paolo Bonzini478e9432020-08-17 12:47:55 +02003395 libjack=yes
Geoffrey McRae2e445702020-04-29 15:53:58 +10003396 jack_libs=$($pkg_config jack --libs)
3397 if test "$drv" = "try-jack"; then
3398 audio_drv_list=$(echo "$audio_drv_list" | sed -e 's/try-jack/jack/')
3399 fi
3400 else
3401 if test "$drv" = "try-jack"; then
3402 audio_drv_list=$(echo "$audio_drv_list" | sed -e 's/try-jack//')
3403 else
3404 error_exit "$drv check failed" \
3405 "Make sure to have the $drv libs and headers installed."
3406 fi
3407 fi
3408 ;;
3409
malce4c63a62008-07-19 16:15:16 +00003410 *)
malc1c9b2a52008-07-19 16:57:30 +00003411 echo "$audio_possible_drivers" | grep -q "\<$drv\>" || {
Peter Maydell76ad07a2013-04-08 12:11:26 +01003412 error_exit "Unknown driver '$drv' selected" \
3413 "Possible drivers are: $audio_possible_drivers"
malce4c63a62008-07-19 16:15:16 +00003414 }
3415 ;;
malcc2de5c92008-06-28 19:13:06 +00003416 esac
3417done
ths8f28f3f2007-01-05 21:25:54 +00003418
balrog4d3b6f62008-02-10 16:33:14 +00003419##########################################
aurel322e4d9fb2008-04-08 06:01:02 +00003420# BrlAPI probe
3421
Juan Quintela4ffcedb2009-08-12 18:20:26 +02003422if test "$brlapi" != "no" ; then
Juan Quintelaeb822842009-07-27 16:13:18 +02003423 brlapi_libs="-lbrlapi"
3424 cat > $TMPC << EOF
aurel322e4d9fb2008-04-08 06:01:02 +00003425#include <brlapi.h>
Scott Wood832ce9c2010-10-05 14:28:17 -05003426#include <stddef.h>
aurel322e4d9fb2008-04-08 06:01:02 +00003427int main( void ) { return brlapi__openConnection (NULL, NULL, NULL); }
3428EOF
Juan Quintela52166aa2009-08-03 14:46:03 +02003429 if compile_prog "" "$brlapi_libs" ; then
Juan Quintelaeb822842009-07-27 16:13:18 +02003430 brlapi=yes
Juan Quintela4ffcedb2009-08-12 18:20:26 +02003431 else
3432 if test "$brlapi" = "yes" ; then
Stewart Smith21684af2014-01-24 12:39:10 +11003433 feature_not_found "brlapi" "Install brlapi devel"
Juan Quintela4ffcedb2009-08-12 18:20:26 +02003434 fi
3435 brlapi=no
Juan Quintelaeb822842009-07-27 16:13:18 +02003436 fi
3437fi
aurel322e4d9fb2008-04-08 06:01:02 +00003438
3439##########################################
Alexander Graf769ce762009-05-11 17:41:42 +02003440# curl probe
Juan Quintela788c8192009-08-12 18:29:47 +02003441if test "$curl" != "no" ; then
Stefan Weil65d5d3f2013-08-27 21:09:13 +02003442 if $pkg_config libcurl --exists; then
Michael Tokareva3605bf2013-05-25 13:17:21 +04003443 curlconfig="$pkg_config libcurl"
3444 else
3445 curlconfig=curl-config
3446 fi
Alexander Graf769ce762009-05-11 17:41:42 +02003447 cat > $TMPC << EOF
3448#include <curl/curl.h>
Peter Maydell0b862ce2011-06-09 22:54:29 +01003449int main(void) { curl_easy_init(); curl_multi_setopt(0, 0, 0); return 0; }
Alexander Graf769ce762009-05-11 17:41:42 +02003450EOF
Stefan Weil89138852016-05-16 15:10:20 +02003451 curl_cflags=$($curlconfig --cflags 2>/dev/null)
3452 curl_libs=$($curlconfig --libs 2>/dev/null)
Juan Quintelab1d5a272009-08-03 14:46:05 +02003453 if compile_prog "$curl_cflags" "$curl_libs" ; then
Alexander Graf769ce762009-05-11 17:41:42 +02003454 curl=yes
Juan Quintela788c8192009-08-12 18:29:47 +02003455 else
3456 if test "$curl" = "yes" ; then
Stewart Smith21684af2014-01-24 12:39:10 +11003457 feature_not_found "curl" "Install libcurl devel"
Juan Quintela788c8192009-08-12 18:29:47 +02003458 fi
3459 curl=no
Alexander Graf769ce762009-05-11 17:41:42 +02003460 fi
3461fi # test "$curl"
3462
3463##########################################
Anthony Liguorie18df142011-07-19 14:50:29 -05003464# glib support probe
Paolo Bonzinia52d28a2012-04-05 13:01:54 +02003465
Daniel P. Berrangé00f2cfb2018-05-04 15:34:46 +01003466glib_req_ver=2.48
Paolo Bonziniaa0d1f42014-02-25 17:36:55 +01003467glib_modules=gthread-2.0
3468if test "$modules" = yes; then
Gerd Hoffmanna88afc62018-03-08 09:53:00 +01003469 glib_modules="$glib_modules gmodule-export-2.0"
Paolo Bonziniaa0d1f42014-02-25 17:36:55 +01003470fi
Emilio G. Cota54cb65d2017-08-30 18:39:53 -04003471if test "$plugins" = yes; then
3472 glib_modules="$glib_modules gmodule-2.0"
3473fi
Fam Zhenge26110c2014-02-10 14:48:57 +08003474
Paolo Bonziniaa0d1f42014-02-25 17:36:55 +01003475for i in $glib_modules; do
Fam Zhenge26110c2014-02-10 14:48:57 +08003476 if $pkg_config --atleast-version=$glib_req_ver $i; then
Stefan Weil89138852016-05-16 15:10:20 +02003477 glib_cflags=$($pkg_config --cflags $i)
3478 glib_libs=$($pkg_config --libs $i)
Fam Zhenge26110c2014-02-10 14:48:57 +08003479 else
3480 error_exit "glib-$glib_req_ver $i is required to compile QEMU"
3481 fi
3482done
3483
Paolo Bonzini215b0c22020-09-01 08:41:17 -04003484# This workaround is required due to a bug in pkg-config file for glib as it
3485# doesn't define GLIB_STATIC_COMPILATION for pkg-config --static
3486
3487if test "$static" = yes && test "$mingw32" = yes; then
3488 glib_cflags="-DGLIB_STATIC_COMPILATION $glib_cflags"
3489fi
3490
Marc-André Lureauf876b762019-02-21 12:07:00 +01003491if $pkg_config --atleast-version=$glib_req_ver gio-2.0; then
3492 gio=yes
3493 gio_cflags=$($pkg_config --cflags gio-2.0)
3494 gio_libs=$($pkg_config --libs gio-2.0)
Marc-André Lureau25a97a52019-09-27 11:34:42 +04003495 gdbus_codegen=$($pkg_config --variable=gdbus_codegen gio-2.0)
Marc-André Lureau0dba4892020-01-10 15:27:25 +04003496 if [ ! -x "$gdbus_codegen" ]; then
3497 gdbus_codegen=
3498 fi
Marc-André Lureauf876b762019-02-21 12:07:00 +01003499else
3500 gio=no
3501fi
3502
Marc-André Lureau25a97a52019-09-27 11:34:42 +04003503if $pkg_config --atleast-version=$glib_req_ver gio-unix-2.0; then
3504 gio_cflags="$gio_cflags $($pkg_config --cflags gio-unix-2.0)"
3505 gio_libs="$gio_libs $($pkg_config --libs gio-unix-2.0)"
3506fi
3507
Daniel P. Berrange977a82a2016-01-27 09:00:45 +00003508# Sanity check that the current size_t matches the
3509# size that glib thinks it should be. This catches
3510# problems on multi-arch where people try to build
3511# 32-bit QEMU while pointing at 64-bit glib headers
3512cat > $TMPC <<EOF
3513#include <glib.h>
3514#include <unistd.h>
3515
3516#define QEMU_BUILD_BUG_ON(x) \
3517 typedef char qemu_build_bug_on[(x)?-1:1] __attribute__((unused));
3518
3519int main(void) {
3520 QEMU_BUILD_BUG_ON(sizeof(size_t) != GLIB_SIZEOF_SIZE_T);
3521 return 0;
3522}
3523EOF
3524
Paolo Bonzini215b0c22020-09-01 08:41:17 -04003525if ! compile_prog "$glib_cflags" "$glib_libs" ; then
Daniel P. Berrange977a82a2016-01-27 09:00:45 +00003526 error_exit "sizeof(size_t) doesn't match GLIB_SIZEOF_SIZE_T."\
3527 "You probably need to set PKG_CONFIG_LIBDIR"\
3528 "to point to the right pkg-config files for your"\
3529 "build target"
3530fi
3531
John Snowbbbf2e02015-03-25 18:57:38 -04003532# Silence clang 3.5.0 warnings about glib attribute __alloc_size__ usage
3533cat > $TMPC << EOF
3534#include <glib.h>
3535int main(void) { return 0; }
3536EOF
3537if ! compile_prog "$glib_cflags -Werror" "$glib_libs" ; then
3538 if cc_has_warning_flag "-Wno-unknown-attributes"; then
3539 glib_cflags="-Wno-unknown-attributes $glib_cflags"
Paolo Bonzini5770e8a2020-09-23 05:26:15 -04003540 CONFIGURE_CFLAGS="-Wno-unknown-attributes $CONFIGURE_CFLAGS"
John Snowbbbf2e02015-03-25 18:57:38 -04003541 fi
3542fi
3543
Eric Blake9bda6002020-03-17 12:55:34 -05003544# Silence clang warnings triggered by glib < 2.57.2
3545cat > $TMPC << EOF
3546#include <glib.h>
3547typedef struct Foo {
3548 int i;
3549} Foo;
3550static void foo_free(Foo *f)
3551{
3552 g_free(f);
3553}
3554G_DEFINE_AUTOPTR_CLEANUP_FUNC(Foo, foo_free);
3555int main(void) { return 0; }
3556EOF
3557if ! compile_prog "$glib_cflags -Werror" "$glib_libs" ; then
3558 if cc_has_warning_flag "-Wno-unused-function"; then
3559 glib_cflags="$glib_cflags -Wno-unused-function"
Paolo Bonzini5770e8a2020-09-23 05:26:15 -04003560 CONFIGURE_CFLAGS="$CONFIGURE_CFLAGS -Wno-unused-function"
Eric Blake9bda6002020-03-17 12:55:34 -05003561 fi
3562fi
3563
Fam Zhenge26110c2014-02-10 14:48:57 +08003564##########################################
3565# SHA command probe for modules
3566if test "$modules" = yes; then
3567 shacmd_probe="sha1sum sha1 shasum"
3568 for c in $shacmd_probe; do
Fam Zheng8ccefb92014-12-04 14:18:16 +08003569 if has $c; then
Fam Zhenge26110c2014-02-10 14:48:57 +08003570 shacmd="$c"
3571 break
3572 fi
3573 done
3574 if test "$shacmd" = ""; then
3575 error_exit "one of the checksum commands is required to enable modules: $shacmd_probe"
3576 fi
Anthony Liguorie18df142011-07-19 14:50:29 -05003577fi
3578
3579##########################################
aliguorie5d355d2009-04-24 18:03:15 +00003580# pthread probe
Brad4b29ec42011-08-07 20:02:11 -04003581PTHREADLIBS_LIST="-pthread -lpthread -lpthreadGC2"
aliguori3c529d92008-12-12 16:41:40 +00003582
Christoph Hellwig4dd75c72009-08-10 23:39:39 +02003583pthread=no
aliguorie5d355d2009-04-24 18:03:15 +00003584cat > $TMPC << EOF
aliguori3c529d92008-12-12 16:41:40 +00003585#include <pthread.h>
Stefan Weil7a42bbe2011-12-17 09:27:32 +01003586static void *f(void *p) { return NULL; }
3587int main(void) {
3588 pthread_t thread;
3589 pthread_create(&thread, 0, f, 0);
3590 return 0;
3591}
blueswir1414f0da2008-08-15 18:20:52 +00003592EOF
Andreas Färberbd00d532010-09-20 00:50:44 +02003593if compile_prog "" "" ; then
3594 pthread=yes
3595else
3596 for pthread_lib in $PTHREADLIBS_LIST; do
3597 if compile_prog "" "$pthread_lib" ; then
3598 pthread=yes
Peter Portantee3c56762012-04-20 10:36:12 -04003599 found=no
3600 for lib_entry in $LIBS; do
3601 if test "$lib_entry" = "$pthread_lib"; then
3602 found=yes
3603 break
3604 fi
3605 done
3606 if test "$found" = "no"; then
3607 LIBS="$pthread_lib $LIBS"
3608 fi
Andreas Färberbd00d532010-09-20 00:50:44 +02003609 break
3610 fi
3611 done
3612fi
blueswir1414f0da2008-08-15 18:20:52 +00003613
Eric Blakee633a5c2019-02-04 20:39:37 -06003614if test "$mingw32" != yes && test "$pthread" = no; then
Peter Maydell76ad07a2013-04-08 12:11:26 +01003615 error_exit "pthread check failed" \
3616 "Make sure to have the pthread libs and headers installed."
aliguorie5d355d2009-04-24 18:03:15 +00003617fi
3618
Roman Bolshakov479a5742018-12-17 23:26:01 +03003619# check for pthread_setname_np with thread id
3620pthread_setname_np_w_tid=no
Dr. David Alan Gilbert5c312072014-03-12 11:48:18 +00003621cat > $TMPC << EOF
3622#include <pthread.h>
3623
3624static void *f(void *p) { return NULL; }
3625int main(void)
3626{
3627 pthread_t thread;
3628 pthread_create(&thread, 0, f, 0);
3629 pthread_setname_np(thread, "QEMU");
3630 return 0;
3631}
3632EOF
3633if compile_prog "" "$pthread_lib" ; then
Roman Bolshakov479a5742018-12-17 23:26:01 +03003634 pthread_setname_np_w_tid=yes
3635fi
3636
3637# check for pthread_setname_np without thread id
3638pthread_setname_np_wo_tid=no
3639cat > $TMPC << EOF
3640#include <pthread.h>
3641
Thomas Huth12a9b8d2020-07-16 07:12:22 +02003642static void *f(void *p) { pthread_setname_np("QEMU"); return NULL; }
Roman Bolshakov479a5742018-12-17 23:26:01 +03003643int main(void)
3644{
3645 pthread_t thread;
3646 pthread_create(&thread, 0, f, 0);
3647 return 0;
3648}
3649EOF
3650if compile_prog "" "$pthread_lib" ; then
3651 pthread_setname_np_wo_tid=yes
Dr. David Alan Gilbert5c312072014-03-12 11:48:18 +00003652fi
3653
aliguoribf9298b2008-12-05 20:05:26 +00003654##########################################
Christian Brunnerf27aaf42010-12-06 20:53:01 +01003655# rbd probe
3656if test "$rbd" != "no" ; then
3657 cat > $TMPC <<EOF
3658#include <stdio.h>
Josh Durginad32e9c2011-05-26 16:07:31 -07003659#include <rbd/librbd.h>
Christian Brunnerf27aaf42010-12-06 20:53:01 +01003660int main(void) {
Josh Durginad32e9c2011-05-26 16:07:31 -07003661 rados_t cluster;
3662 rados_create(&cluster, NULL);
Christian Brunnerf27aaf42010-12-06 20:53:01 +01003663 return 0;
3664}
3665EOF
Josh Durginad32e9c2011-05-26 16:07:31 -07003666 rbd_libs="-lrbd -lrados"
3667 if compile_prog "" "$rbd_libs" ; then
3668 rbd=yes
Christian Brunnerf27aaf42010-12-06 20:53:01 +01003669 else
3670 if test "$rbd" = "yes" ; then
Stewart Smith21684af2014-01-24 12:39:10 +11003671 feature_not_found "rados block device" "Install librbd/ceph devel"
Christian Brunnerf27aaf42010-12-06 20:53:01 +01003672 fi
3673 rbd=no
3674 fi
Christian Brunnerf27aaf42010-12-06 20:53:01 +01003675fi
3676
3677##########################################
Pino Toscanob10d49d2019-06-20 22:08:40 +02003678# libssh probe
3679if test "$libssh" != "no" ; then
3680 if $pkg_config --exists libssh; then
3681 libssh_cflags=$($pkg_config libssh --cflags)
3682 libssh_libs=$($pkg_config libssh --libs)
3683 libssh=yes
Richard W.M. Jones0a12ec82013-04-09 15:30:53 +01003684 else
Pino Toscanob10d49d2019-06-20 22:08:40 +02003685 if test "$libssh" = "yes" ; then
3686 error_exit "libssh required for --enable-libssh"
Richard W.M. Jones0a12ec82013-04-09 15:30:53 +01003687 fi
Pino Toscanob10d49d2019-06-20 22:08:40 +02003688 libssh=no
Richard W.M. Jones0a12ec82013-04-09 15:30:53 +01003689 fi
3690fi
3691
3692##########################################
Pino Toscanob10d49d2019-06-20 22:08:40 +02003693# Check for libssh 0.8
3694# This is done like this instead of using the LIBSSH_VERSION_* and
3695# SSH_VERSION_* macros because some distributions in the past shipped
3696# snapshots of the future 0.8 from Git, and those snapshots did not
3697# have updated version numbers (still referring to 0.7.0).
Richard W.M. Jones9a2d4622013-04-09 15:30:54 +01003698
Pino Toscanob10d49d2019-06-20 22:08:40 +02003699if test "$libssh" = "yes"; then
Richard W.M. Jones9a2d4622013-04-09 15:30:54 +01003700 cat > $TMPC <<EOF
Pino Toscanob10d49d2019-06-20 22:08:40 +02003701#include <libssh/libssh.h>
3702int main(void) { return ssh_get_server_publickey(NULL, NULL); }
Richard W.M. Jones9a2d4622013-04-09 15:30:54 +01003703EOF
Pino Toscanob10d49d2019-06-20 22:08:40 +02003704 if compile_prog "$libssh_cflags" "$libssh_libs"; then
3705 libssh_cflags="-DHAVE_LIBSSH_0_8 $libssh_cflags"
Richard W.M. Jones9a2d4622013-04-09 15:30:54 +01003706 fi
3707fi
3708
3709##########################################
Christoph Hellwig5c6c3a62009-08-20 16:58:35 +02003710# linux-aio probe
Christoph Hellwig5c6c3a62009-08-20 16:58:35 +02003711
3712if test "$linux_aio" != "no" ; then
3713 cat > $TMPC <<EOF
3714#include <libaio.h>
3715#include <sys/eventfd.h>
Scott Wood832ce9c2010-10-05 14:28:17 -05003716#include <stddef.h>
Christoph Hellwig5c6c3a62009-08-20 16:58:35 +02003717int main(void) { io_setup(0, NULL); io_set_eventfd(NULL, 0); eventfd(0, 0); return 0; }
3718EOF
3719 if compile_prog "" "-laio" ; then
3720 linux_aio=yes
Christoph Hellwig5c6c3a62009-08-20 16:58:35 +02003721 else
3722 if test "$linux_aio" = "yes" ; then
Stewart Smith21684af2014-01-24 12:39:10 +11003723 feature_not_found "linux AIO" "Install libaio devel"
Christoph Hellwig5c6c3a62009-08-20 16:58:35 +02003724 fi
Luiz Capitulino3cfcae32009-08-31 13:18:12 -03003725 linux_aio=no
Christoph Hellwig5c6c3a62009-08-20 16:58:35 +02003726 fi
3727fi
Aarushi Mehtac10dd852020-01-20 14:18:44 +00003728##########################################
3729# linux-io-uring probe
3730
3731if test "$linux_io_uring" != "no" ; then
3732 if $pkg_config liburing; then
3733 linux_io_uring_cflags=$($pkg_config --cflags liburing)
3734 linux_io_uring_libs=$($pkg_config --libs liburing)
3735 linux_io_uring=yes
3736 else
3737 if test "$linux_io_uring" = "yes" ; then
3738 feature_not_found "linux io_uring" "Install liburing devel"
3739 fi
3740 linux_io_uring=no
3741 fi
3742fi
Christoph Hellwig5c6c3a62009-08-20 16:58:35 +02003743
3744##########################################
Paolo Bonzini7aaa6a12019-01-23 14:56:07 +08003745# TPM emulation is only on POSIX
Paolo Bonzini3b8acc12013-03-18 16:37:50 +01003746
Paolo Bonzini7aaa6a12019-01-23 14:56:07 +08003747if test "$tpm" = ""; then
3748 if test "$mingw32" = "yes"; then
3749 tpm=no
3750 else
3751 tpm=yes
3752 fi
3753elif test "$tpm" = "yes"; then
3754 if test "$mingw32" = "yes" ; then
3755 error_exit "TPM emulation only available on POSIX systems"
3756 fi
Paolo Bonzini3b8acc12013-03-18 16:37:50 +01003757fi
3758
3759##########################################
Venkateswararao Jujjuri (JV)758e8e32010-06-14 13:34:41 -07003760# attr probe
3761
Marc-André Lureauec0d5892019-07-15 15:04:49 +04003762libattr_libs=
Venkateswararao Jujjuri (JV)758e8e32010-06-14 13:34:41 -07003763if test "$attr" != "no" ; then
3764 cat > $TMPC <<EOF
3765#include <stdio.h>
3766#include <sys/types.h>
Pavel Borzenkovf2338fb2011-11-11 00:26:59 +04003767#ifdef CONFIG_LIBATTR
3768#include <attr/xattr.h>
3769#else
Avi Kivity4f26f2b2011-11-09 14:44:52 +02003770#include <sys/xattr.h>
Pavel Borzenkovf2338fb2011-11-11 00:26:59 +04003771#endif
Venkateswararao Jujjuri (JV)758e8e32010-06-14 13:34:41 -07003772int main(void) { getxattr(NULL, NULL, NULL, 0); setxattr(NULL, NULL, NULL, 0, 0); return 0; }
3773EOF
Avi Kivity4f26f2b2011-11-09 14:44:52 +02003774 if compile_prog "" "" ; then
3775 attr=yes
3776 # Older distros have <attr/xattr.h>, and need -lattr:
Pavel Borzenkovf2338fb2011-11-11 00:26:59 +04003777 elif compile_prog "-DCONFIG_LIBATTR" "-lattr" ; then
Venkateswararao Jujjuri (JV)758e8e32010-06-14 13:34:41 -07003778 attr=yes
Marc-André Lureauec0d5892019-07-15 15:04:49 +04003779 libattr_libs="-lattr"
Avi Kivity4f26f2b2011-11-09 14:44:52 +02003780 libattr=yes
Venkateswararao Jujjuri (JV)758e8e32010-06-14 13:34:41 -07003781 else
3782 if test "$attr" = "yes" ; then
Stewart Smith21684af2014-01-24 12:39:10 +11003783 feature_not_found "ATTR" "Install libc6 or libattr devel"
Venkateswararao Jujjuri (JV)758e8e32010-06-14 13:34:41 -07003784 fi
3785 attr=no
3786 fi
3787fi
3788
3789##########################################
aliguoribf9298b2008-12-05 20:05:26 +00003790# iovec probe
3791cat > $TMPC <<EOF
blueswir1db34f0b2009-01-14 18:03:53 +00003792#include <sys/types.h>
aliguoribf9298b2008-12-05 20:05:26 +00003793#include <sys/uio.h>
blueswir1db34f0b2009-01-14 18:03:53 +00003794#include <unistd.h>
Stefan Weilf91f9be2011-12-17 09:27:33 +01003795int main(void) { return sizeof(struct iovec); }
aliguoribf9298b2008-12-05 20:05:26 +00003796EOF
3797iovec=no
Juan Quintela52166aa2009-08-03 14:46:03 +02003798if compile_prog "" "" ; then
aliguoribf9298b2008-12-05 20:05:26 +00003799 iovec=yes
3800fi
3801
aurel32f652e6a2008-12-16 10:43:48 +00003802##########################################
aliguoriceb42de2009-04-07 18:43:28 +00003803# preadv probe
3804cat > $TMPC <<EOF
3805#include <sys/types.h>
3806#include <sys/uio.h>
3807#include <unistd.h>
Blue Swirlc075a722012-08-09 20:21:25 +00003808int main(void) { return preadv(0, 0, 0, 0); }
aliguoriceb42de2009-04-07 18:43:28 +00003809EOF
3810preadv=no
Juan Quintela52166aa2009-08-03 14:46:03 +02003811if compile_prog "" "" ; then
aliguoriceb42de2009-04-07 18:43:28 +00003812 preadv=yes
3813fi
3814
3815##########################################
aurel32f652e6a2008-12-16 10:43:48 +00003816# fdt probe
Paolo Bonzinifbb41212020-10-05 11:31:15 +02003817
3818case "$fdt" in
3819 auto | enabled | internal)
3820 # Simpler to always update submodule, even if not needed.
3821 if test -e "${source_path}/.git" && test $git_update = 'yes' ; then
3822 git_submodules="${git_submodules} dtc"
3823 fi
Peter Maydelle169e1e2013-05-24 16:26:54 +01003824 ;;
Paolo Bonzinifbb41212020-10-05 11:31:15 +02003825esac
aurel32f652e6a2008-12-16 10:43:48 +00003826
Michael Walle20ff0752011-03-07 23:32:39 +01003827##########################################
OGAWA Hirofumifb719562015-10-27 02:45:48 +09003828# opengl probe (for sdl2, gtk, milkymist-tmu2)
Gerd Hoffmannb1546f32015-03-16 10:03:53 +01003829
Marc-André Lureaud52c4542019-05-24 15:09:42 +02003830gbm="no"
3831if $pkg_config gbm; then
3832 gbm_cflags="$($pkg_config --cflags gbm)"
3833 gbm_libs="$($pkg_config --libs gbm)"
3834 gbm="yes"
3835fi
3836
Gerd Hoffmannda076ff2014-11-20 09:49:44 +01003837if test "$opengl" != "no" ; then
Michael Tokarev4939a1d2018-06-30 19:54:48 +03003838 opengl_pkgs="epoxy gbm"
Gerd Hoffmann5f9b1e32018-03-01 11:05:43 +01003839 if $pkg_config $opengl_pkgs; then
3840 opengl_cflags="$($pkg_config --cflags $opengl_pkgs)"
3841 opengl_libs="$($pkg_config --libs $opengl_pkgs)"
Gerd Hoffmannda076ff2014-11-20 09:49:44 +01003842 opengl=yes
Gerd Hoffmann925a0402015-05-26 12:26:21 +02003843 if test "$gtk" = "yes" && $pkg_config --exists "$gtkpackage >= 3.16"; then
3844 gtk_gl="yes"
3845 fi
Michael Walle20ff0752011-03-07 23:32:39 +01003846 else
Gerd Hoffmannda076ff2014-11-20 09:49:44 +01003847 if test "$opengl" = "yes" ; then
Gerd Hoffmanndcf30022015-05-11 12:24:43 +02003848 feature_not_found "opengl" "Please install opengl (mesa) devel pkgs: $opengl_pkgs"
Michael Walle20ff0752011-03-07 23:32:39 +01003849 fi
Jeremy Whitef676c672015-01-09 13:08:49 -06003850 opengl_cflags=""
Gerd Hoffmannda076ff2014-11-20 09:49:44 +01003851 opengl_libs=""
3852 opengl=no
Michael Walle20ff0752011-03-07 23:32:39 +01003853 fi
3854fi
3855
Gerd Hoffmann014cb152015-12-03 12:56:34 +01003856if test "$opengl" = "yes"; then
3857 cat > $TMPC << EOF
3858#include <epoxy/egl.h>
3859#ifndef EGL_MESA_image_dma_buf_export
3860# error mesa/epoxy lacks support for dmabufs (mesa 10.6+)
3861#endif
3862int main(void) { return 0; }
3863EOF
3864 if compile_prog "" "" ; then
3865 opengl_dmabuf=yes
3866 fi
3867fi
Chrysostomos Nanakosc9a12e72014-08-04 17:35:32 +03003868
Eric Blakee633a5c2019-02-04 20:39:37 -06003869if test "$opengl" = "yes" && test "$have_x11" = "yes"; then
Philippe Mathieu-Daudé99e1a932019-01-30 13:00:03 +01003870 for target in $target_list; do
3871 case $target in
3872 lm32-softmmu) # milkymist-tmu2 requires X11 and OpenGL
3873 need_x11=yes
3874 ;;
3875 esac
3876 done
3877fi
3878
Klim Kireeved279a02018-01-12 12:01:19 +03003879##########################################
3880# libxml2 probe
3881if test "$libxml2" != "no" ; then
3882 if $pkg_config --exists libxml-2.0; then
3883 libxml2="yes"
3884 libxml2_cflags=$($pkg_config --cflags libxml-2.0)
3885 libxml2_libs=$($pkg_config --libs libxml-2.0)
3886 else
3887 if test "$libxml2" = "yes"; then
3888 feature_not_found "libxml2" "Install libxml2 devel"
3889 fi
3890 libxml2="no"
3891 fi
3892fi
Chrysostomos Nanakosc9a12e72014-08-04 17:35:32 +03003893
Bharata B Raoeb100392012-09-24 14:42:45 +05303894##########################################
3895# glusterfs probe
3896if test "$glusterfs" != "no" ; then
Stefan Weil65d5d3f2013-08-27 21:09:13 +02003897 if $pkg_config --atleast-version=3 glusterfs-api; then
Bharata B Raoe01bee02013-07-16 21:47:41 +05303898 glusterfs="yes"
Stefan Weil89138852016-05-16 15:10:20 +02003899 glusterfs_cflags=$($pkg_config --cflags glusterfs-api)
3900 glusterfs_libs=$($pkg_config --libs glusterfs-api)
Jeff Codyd85fa9e2016-04-05 10:40:09 -04003901 if $pkg_config --atleast-version=4 glusterfs-api; then
3902 glusterfs_xlator_opt="yes"
3903 fi
Stefan Weil65d5d3f2013-08-27 21:09:13 +02003904 if $pkg_config --atleast-version=5 glusterfs-api; then
Bharata B Rao0c14fb42013-07-16 21:47:42 +05303905 glusterfs_discard="yes"
3906 fi
Bharata B Rao7c815372013-12-21 14:51:25 +05303907 if $pkg_config --atleast-version=6 glusterfs-api; then
Niels de Vosdf3a4292017-05-28 12:01:14 +05303908 glusterfs_fallocate="yes"
Bharata B Rao7c815372013-12-21 14:51:25 +05303909 glusterfs_zerofill="yes"
3910 fi
Prasanna Kumar Kalevere014dbe2019-03-05 16:46:33 +01003911 cat > $TMPC << EOF
3912#include <glusterfs/api/glfs.h>
3913
3914int
3915main(void)
3916{
3917 /* new glfs_ftruncate() passes two additional args */
3918 return glfs_ftruncate(NULL, 0, NULL, NULL);
3919}
3920EOF
3921 if compile_prog "$glusterfs_cflags" "$glusterfs_libs" ; then
3922 glusterfs_ftruncate_has_stat="yes"
3923 fi
Niels de Vos0e3b8912019-03-05 16:46:34 +01003924 cat > $TMPC << EOF
3925#include <glusterfs/api/glfs.h>
3926
3927/* new glfs_io_cbk() passes two additional glfs_stat structs */
3928static void
3929glusterfs_iocb(glfs_fd_t *fd, ssize_t ret, struct glfs_stat *prestat, struct glfs_stat *poststat, void *data)
3930{}
3931
3932int
3933main(void)
3934{
3935 glfs_io_cbk iocb = &glusterfs_iocb;
3936 iocb(NULL, 0 , NULL, NULL, NULL);
3937 return 0;
3938}
3939EOF
3940 if compile_prog "$glusterfs_cflags" "$glusterfs_libs" ; then
3941 glusterfs_iocb_has_stat="yes"
3942 fi
Bharata B Raoeb100392012-09-24 14:42:45 +05303943 else
3944 if test "$glusterfs" = "yes" ; then
Hu Tao8efc9362014-06-26 17:34:50 +08003945 feature_not_found "GlusterFS backend support" \
3946 "Install glusterfs-api devel >= 3"
Bharata B Raoeb100392012-09-24 14:42:45 +05303947 fi
Bharata B Raoe01bee02013-07-16 21:47:41 +05303948 glusterfs="no"
Bharata B Raoeb100392012-09-24 14:42:45 +05303949 fi
3950fi
3951
aurel3239386ac2009-04-15 19:48:17 +00003952# Check for inotify functions when we are building linux-user
aurel323b3f24a2009-04-15 16:12:13 +00003953# emulator. This is done because older glibc versions don't
3954# have syscall stubs for these implemented. In that case we
3955# don't provide them even if kernel supports them.
3956#
3957inotify=no
Riku Voipio67ba57f2009-06-29 17:26:11 +03003958cat > $TMPC << EOF
aurel323b3f24a2009-04-15 16:12:13 +00003959#include <sys/inotify.h>
3960
3961int
3962main(void)
3963{
3964 /* try to start inotify */
aurel328690e422009-04-17 13:50:32 +00003965 return inotify_init();
aurel323b3f24a2009-04-15 16:12:13 +00003966}
3967EOF
Juan Quintela52166aa2009-08-03 14:46:03 +02003968if compile_prog "" "" ; then
Riku Voipio67ba57f2009-06-29 17:26:11 +03003969 inotify=yes
aurel323b3f24a2009-04-15 16:12:13 +00003970fi
3971
Riku Voipioc05c7a72010-03-26 15:25:11 +00003972inotify1=no
3973cat > $TMPC << EOF
3974#include <sys/inotify.h>
3975
3976int
3977main(void)
3978{
3979 /* try to start inotify */
3980 return inotify_init1(0);
3981}
3982EOF
3983if compile_prog "" "" ; then
3984 inotify1=yes
3985fi
3986
Riku Voipio099d6b02009-05-05 12:10:04 +03003987# check if pipe2 is there
3988pipe2=no
3989cat > $TMPC << EOF
Riku Voipio099d6b02009-05-05 12:10:04 +03003990#include <unistd.h>
3991#include <fcntl.h>
3992
3993int main(void)
3994{
3995 int pipefd[2];
Bruce Rogers9bca8162012-08-20 12:45:08 -06003996 return pipe2(pipefd, O_CLOEXEC);
Riku Voipio099d6b02009-05-05 12:10:04 +03003997}
3998EOF
Juan Quintela52166aa2009-08-03 14:46:03 +02003999if compile_prog "" "" ; then
Riku Voipio099d6b02009-05-05 12:10:04 +03004000 pipe2=yes
4001fi
4002
Kevin Wolf40ff6d72009-12-02 12:24:42 +01004003# check if accept4 is there
4004accept4=no
4005cat > $TMPC << EOF
Kevin Wolf40ff6d72009-12-02 12:24:42 +01004006#include <sys/socket.h>
4007#include <stddef.h>
4008
4009int main(void)
4010{
4011 accept4(0, NULL, NULL, SOCK_CLOEXEC);
4012 return 0;
4013}
4014EOF
4015if compile_prog "" "" ; then
4016 accept4=yes
4017fi
4018
vibisreenivasan3ce34df2009-05-16 18:32:41 +05304019# check if tee/splice is there. vmsplice was added same time.
4020splice=no
4021cat > $TMPC << EOF
vibisreenivasan3ce34df2009-05-16 18:32:41 +05304022#include <unistd.h>
4023#include <fcntl.h>
4024#include <limits.h>
4025
4026int main(void)
4027{
Stefan Weil66ea0f22011-12-17 09:27:35 +01004028 int len, fd = 0;
vibisreenivasan3ce34df2009-05-16 18:32:41 +05304029 len = tee(STDIN_FILENO, STDOUT_FILENO, INT_MAX, SPLICE_F_NONBLOCK);
4030 splice(STDIN_FILENO, NULL, fd, NULL, len, SPLICE_F_MOVE);
4031 return 0;
4032}
4033EOF
Juan Quintela52166aa2009-08-03 14:46:03 +02004034if compile_prog "" "" ; then
vibisreenivasan3ce34df2009-05-16 18:32:41 +05304035 splice=yes
4036fi
4037
Marcelo Tosattidcc38d12010-10-11 15:31:15 -03004038##########################################
Wanlong Gaoa99d57b2014-05-14 17:43:28 +08004039# libnuma probe
4040
4041if test "$numa" != "no" ; then
4042 cat > $TMPC << EOF
4043#include <numa.h>
4044int main(void) { return numa_available(); }
4045EOF
4046
4047 if compile_prog "" "-lnuma" ; then
4048 numa=yes
Marc-André Lureauab318052019-07-24 19:23:16 +04004049 numa_libs="-lnuma"
Wanlong Gaoa99d57b2014-05-14 17:43:28 +08004050 else
4051 if test "$numa" = "yes" ; then
4052 feature_not_found "numa" "install numactl devel"
4053 fi
4054 numa=no
4055 fi
4056fi
4057
Paolo Bonziniaa087962020-09-01 11:15:30 -04004058malloc=system
Alexandre Derumier7b01cb92015-06-19 12:56:58 +02004059if test "$tcmalloc" = "yes" && test "$jemalloc" = "yes" ; then
4060 echo "ERROR: tcmalloc && jemalloc can't be used at the same time"
4061 exit 1
Paolo Bonziniaa087962020-09-01 11:15:30 -04004062elif test "$tcmalloc" = "yes" ; then
4063 malloc=tcmalloc
4064elif test "$jemalloc" = "yes" ; then
4065 malloc=jemalloc
Alexandre Derumier7b01cb92015-06-19 12:56:58 +02004066fi
4067
4068##########################################
Marcelo Tosattidcc38d12010-10-11 15:31:15 -03004069# signalfd probe
4070signalfd="no"
4071cat > $TMPC << EOF
Marcelo Tosattidcc38d12010-10-11 15:31:15 -03004072#include <unistd.h>
4073#include <sys/syscall.h>
4074#include <signal.h>
4075int main(void) { return syscall(SYS_signalfd, -1, NULL, _NSIG / 8); }
4076EOF
4077
4078if compile_prog "" "" ; then
4079 signalfd=yes
4080fi
4081
Richard W.M. Jonesd339d762019-01-18 10:11:14 +00004082# check if optreset global is declared by <getopt.h>
4083optreset="no"
4084cat > $TMPC << EOF
4085#include <getopt.h>
4086int main(void) { return optreset; }
4087EOF
4088
4089if compile_prog "" "" ; then
4090 optreset=yes
4091fi
4092
Riku Voipioc2882b92009-08-12 15:08:24 +03004093# check if eventfd is supported
4094eventfd=no
4095cat > $TMPC << EOF
4096#include <sys/eventfd.h>
4097
4098int main(void)
4099{
Stefan Weil55cc7f32011-12-17 09:27:37 +01004100 return eventfd(0, EFD_NONBLOCK | EFD_CLOEXEC);
Riku Voipioc2882b92009-08-12 15:08:24 +03004101}
4102EOF
4103if compile_prog "" "" ; then
4104 eventfd=yes
4105fi
4106
Marc-André Lureau751bcc32015-10-09 17:17:16 +02004107# check if memfd is supported
4108memfd=no
4109cat > $TMPC << EOF
Paolo Bonzini75e5b702017-11-28 11:51:27 +01004110#include <sys/mman.h>
Marc-André Lureau751bcc32015-10-09 17:17:16 +02004111
4112int main(void)
4113{
4114 return memfd_create("foo", MFD_ALLOW_SEALING);
4115}
4116EOF
4117if compile_prog "" "" ; then
4118 memfd=yes
4119fi
4120
Cortland Tölva955727d2018-10-08 09:35:19 -07004121# check for usbfs
4122have_usbfs=no
4123if test "$linux_user" = "yes"; then
Thomas Petazzoni96566d02019-02-13 22:18:27 +01004124 cat > $TMPC << EOF
4125#include <linux/usbdevice_fs.h>
4126
4127#ifndef USBDEVFS_GET_CAPABILITIES
4128#error "USBDEVFS_GET_CAPABILITIES undefined"
4129#endif
4130
4131#ifndef USBDEVFS_DISCONNECT_CLAIM
4132#error "USBDEVFS_DISCONNECT_CLAIM undefined"
4133#endif
4134
4135int main(void)
4136{
4137 return 0;
4138}
4139EOF
4140 if compile_prog "" ""; then
Cortland Tölva955727d2018-10-08 09:35:19 -07004141 have_usbfs=yes
4142 fi
Cortland Tölva955727d2018-10-08 09:35:19 -07004143fi
Marc-André Lureau751bcc32015-10-09 17:17:16 +02004144
Ulrich Hechtd0927932009-09-17 20:22:14 +03004145# check for fallocate
4146fallocate=no
4147cat > $TMPC << EOF
4148#include <fcntl.h>
4149
4150int main(void)
4151{
4152 fallocate(0, 0, 0, 0);
4153 return 0;
4154}
4155EOF
Peter Maydell8fb03152012-04-04 17:03:15 +01004156if compile_prog "" "" ; then
Ulrich Hechtd0927932009-09-17 20:22:14 +03004157 fallocate=yes
4158fi
4159
Kusanagi Kouichi3d4fa432013-01-14 16:26:52 +01004160# check for fallocate hole punching
4161fallocate_punch_hole=no
4162cat > $TMPC << EOF
4163#include <fcntl.h>
4164#include <linux/falloc.h>
4165
4166int main(void)
4167{
4168 fallocate(0, FALLOC_FL_PUNCH_HOLE | FALLOC_FL_KEEP_SIZE, 0, 0);
4169 return 0;
4170}
4171EOF
4172if compile_prog "" "" ; then
4173 fallocate_punch_hole=yes
4174fi
4175
Denis V. Lunevb953f072015-01-30 11:42:14 +03004176# check that fallocate supports range zeroing inside the file
4177fallocate_zero_range=no
4178cat > $TMPC << EOF
4179#include <fcntl.h>
4180#include <linux/falloc.h>
4181
4182int main(void)
4183{
4184 fallocate(0, FALLOC_FL_ZERO_RANGE, 0, 0);
4185 return 0;
4186}
4187EOF
4188if compile_prog "" "" ; then
4189 fallocate_zero_range=yes
4190fi
4191
Kevin Wolfed911432014-09-29 17:12:59 +02004192# check for posix_fallocate
4193posix_fallocate=no
4194cat > $TMPC << EOF
4195#include <fcntl.h>
4196
4197int main(void)
4198{
4199 posix_fallocate(0, 0, 0);
4200 return 0;
4201}
4202EOF
4203if compile_prog "" "" ; then
4204 posix_fallocate=yes
4205fi
4206
Peter Maydellc727f472011-01-06 11:05:10 +00004207# check for sync_file_range
4208sync_file_range=no
4209cat > $TMPC << EOF
4210#include <fcntl.h>
4211
4212int main(void)
4213{
4214 sync_file_range(0, 0, 0, 0);
4215 return 0;
4216}
4217EOF
Peter Maydell8fb03152012-04-04 17:03:15 +01004218if compile_prog "" "" ; then
Peter Maydellc727f472011-01-06 11:05:10 +00004219 sync_file_range=yes
4220fi
4221
Peter Maydelldace20d2011-01-10 13:11:24 +00004222# check for linux/fiemap.h and FS_IOC_FIEMAP
4223fiemap=no
4224cat > $TMPC << EOF
4225#include <sys/ioctl.h>
4226#include <linux/fs.h>
4227#include <linux/fiemap.h>
4228
4229int main(void)
4230{
4231 ioctl(0, FS_IOC_FIEMAP, 0);
4232 return 0;
4233}
4234EOF
Peter Maydell8fb03152012-04-04 17:03:15 +01004235if compile_prog "" "" ; then
Peter Maydelldace20d2011-01-10 13:11:24 +00004236 fiemap=yes
4237fi
4238
Ulrich Hechtd0927932009-09-17 20:22:14 +03004239# check for dup3
4240dup3=no
4241cat > $TMPC << EOF
4242#include <unistd.h>
4243
4244int main(void)
4245{
4246 dup3(0, 0, 0);
4247 return 0;
4248}
4249EOF
Jan Kiszka78f5d722009-11-03 10:54:44 +01004250if compile_prog "" "" ; then
Ulrich Hechtd0927932009-09-17 20:22:14 +03004251 dup3=yes
4252fi
4253
Alex Bligh4e0c6522013-08-21 16:02:43 +01004254# check for ppoll support
4255ppoll=no
4256cat > $TMPC << EOF
4257#include <poll.h>
4258
4259int main(void)
4260{
4261 struct pollfd pfd = { .fd = 0, .events = 0, .revents = 0 };
4262 ppoll(&pfd, 1, 0, 0);
4263 return 0;
4264}
4265EOF
4266if compile_prog "" "" ; then
4267 ppoll=yes
4268fi
4269
Alex Blighcd758dd2013-08-21 16:02:44 +01004270# check for prctl(PR_SET_TIMERSLACK , ... ) support
4271prctl_pr_set_timerslack=no
4272cat > $TMPC << EOF
4273#include <sys/prctl.h>
4274
4275int main(void)
4276{
4277 prctl(PR_SET_TIMERSLACK, 1, 0, 0, 0);
4278 return 0;
4279}
4280EOF
4281if compile_prog "" "" ; then
4282 prctl_pr_set_timerslack=yes
4283fi
4284
Peter Maydell3b6edd12011-02-15 18:35:05 +00004285# check for epoll support
4286epoll=no
4287cat > $TMPC << EOF
4288#include <sys/epoll.h>
4289
4290int main(void)
4291{
4292 epoll_create(0);
4293 return 0;
4294}
4295EOF
Peter Maydell8fb03152012-04-04 17:03:15 +01004296if compile_prog "" "" ; then
Peter Maydell3b6edd12011-02-15 18:35:05 +00004297 epoll=yes
4298fi
4299
Peter Maydell227f0212016-06-06 19:58:11 +01004300# epoll_create1 is a later addition
4301# so we must check separately for its presence
Peter Maydell3b6edd12011-02-15 18:35:05 +00004302epoll_create1=no
4303cat > $TMPC << EOF
4304#include <sys/epoll.h>
4305
4306int main(void)
4307{
Peter Maydell19e83f62011-04-26 16:56:40 +01004308 /* Note that we use epoll_create1 as a value, not as
4309 * a function being called. This is necessary so that on
4310 * old SPARC glibc versions where the function was present in
4311 * the library but not declared in the header file we will
4312 * fail the configure check. (Otherwise we will get a compiler
4313 * warning but not an error, and will proceed to fail the
4314 * qemu compile where we compile with -Werror.)
4315 */
Blue Swirlc075a722012-08-09 20:21:25 +00004316 return (int)(uintptr_t)&epoll_create1;
Peter Maydell3b6edd12011-02-15 18:35:05 +00004317}
4318EOF
Peter Maydell8fb03152012-04-04 17:03:15 +01004319if compile_prog "" "" ; then
Peter Maydell3b6edd12011-02-15 18:35:05 +00004320 epoll_create1=yes
4321fi
4322
Peter Maydella8fd1ab2013-02-08 07:31:55 +00004323# check for sendfile support
4324sendfile=no
4325cat > $TMPC << EOF
4326#include <sys/sendfile.h>
4327
4328int main(void)
4329{
4330 return sendfile(0, 0, 0, 0);
4331}
4332EOF
4333if compile_prog "" "" ; then
4334 sendfile=yes
4335fi
4336
Riku Voipio51834342014-06-22 11:25:42 +01004337# check for timerfd support (glibc 2.8 and newer)
4338timerfd=no
4339cat > $TMPC << EOF
4340#include <sys/timerfd.h>
4341
4342int main(void)
4343{
4344 return(timerfd_create(CLOCK_REALTIME, 0));
4345}
4346EOF
4347if compile_prog "" "" ; then
4348 timerfd=yes
4349fi
4350
Riku Voipio9af5c902014-08-12 15:58:57 +03004351# check for setns and unshare support
4352setns=no
4353cat > $TMPC << EOF
4354#include <sched.h>
4355
4356int main(void)
4357{
4358 int ret;
4359 ret = setns(0, 0);
4360 ret = unshare(0);
4361 return ret;
4362}
4363EOF
4364if compile_prog "" "" ; then
4365 setns=yes
4366fi
4367
Aleksandar Markovic38860a02016-10-10 13:23:29 +02004368# clock_adjtime probe
4369clock_adjtime=no
4370cat > $TMPC <<EOF
4371#include <time.h>
4372
4373int main(void)
4374{
4375 return clock_adjtime(0, 0);
4376}
4377EOF
4378clock_adjtime=no
4379if compile_prog "" "" ; then
4380 clock_adjtime=yes
4381fi
4382
Aleksandar Markovic5a03cd02016-10-10 13:23:30 +02004383# syncfs probe
4384syncfs=no
4385cat > $TMPC <<EOF
4386#include <unistd.h>
4387
4388int main(void)
4389{
4390 return syncfs(0);
4391}
4392EOF
4393syncfs=no
4394if compile_prog "" "" ; then
4395 syncfs=yes
4396fi
4397
Aleksandar Markovicdb37dd82020-01-16 23:49:49 +01004398# check for kcov support (kernel must be 4.4+, compiled with certain options)
4399kcov=no
4400if check_include sys/kcov.h ; then
4401 kcov=yes
4402fi
4403
Filip Bozutad6092e02020-08-23 21:50:07 +02004404# check for btrfs filesystem support (kernel must be 3.9+)
4405btrfs=no
4406if check_include linux/btrfs.h ; then
4407 btrfs=yes
4408fi
4409
Stefan Weilf514f412009-10-11 12:44:07 +02004410# Search for bswap_32 function
Juan Quintela6ae9a1f2009-08-03 14:45:58 +02004411byteswap_h=no
4412cat > $TMPC << EOF
4413#include <byteswap.h>
4414int main(void) { return bswap_32(0); }
4415EOF
Juan Quintela52166aa2009-08-03 14:46:03 +02004416if compile_prog "" "" ; then
Juan Quintela6ae9a1f2009-08-03 14:45:58 +02004417 byteswap_h=yes
4418fi
4419
Stefan Weil75f13592013-01-05 12:17:38 +01004420# Search for bswap32 function
Juan Quintela6ae9a1f2009-08-03 14:45:58 +02004421bswap_h=no
4422cat > $TMPC << EOF
4423#include <sys/endian.h>
4424#include <sys/types.h>
4425#include <machine/bswap.h>
4426int main(void) { return bswap32(0); }
4427EOF
Juan Quintela52166aa2009-08-03 14:46:03 +02004428if compile_prog "" "" ; then
Juan Quintela6ae9a1f2009-08-03 14:45:58 +02004429 bswap_h=yes
4430fi
4431
aliguorida93a1f2008-12-12 20:02:52 +00004432##########################################
Peter Lievene49ab192014-06-04 14:33:26 +02004433# Do we have libiscsi >= 1.9.0
Ronnie Sahlbergc589b242011-10-25 19:24:24 +11004434if test "$libiscsi" != "no" ; then
Peter Lievene49ab192014-06-04 14:33:26 +02004435 if $pkg_config --atleast-version=1.9.0 libiscsi; then
Paolo Bonzini3c33ea92013-02-22 18:14:28 +01004436 libiscsi="yes"
Stefan Weilca871ec2013-08-27 21:09:12 +02004437 libiscsi_cflags=$($pkg_config --cflags libiscsi)
4438 libiscsi_libs=$($pkg_config --libs libiscsi)
Ronnie Sahlbergc589b242011-10-25 19:24:24 +11004439 else
4440 if test "$libiscsi" = "yes" ; then
Peter Lievene49ab192014-06-04 14:33:26 +02004441 feature_not_found "libiscsi" "Install libiscsi >= 1.9.0"
Ronnie Sahlbergc589b242011-10-25 19:24:24 +11004442 fi
4443 libiscsi="no"
4444 fi
4445fi
4446
Ronnie Sahlbergc589b242011-10-25 19:24:24 +11004447##########################################
aliguorida93a1f2008-12-12 20:02:52 +00004448# Do we need librt
Natanael Copa8bacde82012-09-12 09:06:51 +00004449# uClibc provides 2 versions of clock_gettime(), one with realtime
4450# support and one without. This means that the clock_gettime() don't
4451# need -lrt. We still need it for timer_create() so we check for this
4452# function in addition.
aliguorida93a1f2008-12-12 20:02:52 +00004453cat > $TMPC <<EOF
4454#include <signal.h>
4455#include <time.h>
Natanael Copa8bacde82012-09-12 09:06:51 +00004456int main(void) {
4457 timer_create(CLOCK_REALTIME, NULL, NULL);
4458 return clock_gettime(CLOCK_REALTIME, NULL);
4459}
aliguorida93a1f2008-12-12 20:02:52 +00004460EOF
4461
Juan Quintela52166aa2009-08-03 14:46:03 +02004462if compile_prog "" "" ; then
Juan Quintela07ffa4b2009-08-03 14:46:17 +02004463 :
Natanael Copa8bacde82012-09-12 09:06:51 +00004464# we need pthread for static linking. use previous pthread test result
Rick Liu18e588b2014-05-30 14:10:20 -07004465elif compile_prog "" "$pthread_lib -lrt" ; then
4466 LIBS="$LIBS -lrt"
aliguorida93a1f2008-12-12 20:02:52 +00004467fi
4468
Paolo Bonzinif2995ee2020-09-01 06:28:38 -04004469# Check whether we have openpty() in either libc or libutil
Thomas Huthd99e97e2019-01-17 18:14:08 +01004470cat > $TMPC << EOF
4471extern int openpty(int *am, int *as, char *name, void *termp, void *winp);
4472int main(void) { return openpty(0, 0, 0, 0, 0); }
4473EOF
4474
Thomas Huth9df8b202020-06-29 14:13:24 +02004475have_openpty="no"
4476if compile_prog "" "" ; then
4477 have_openpty="yes"
4478else
Thomas Huthd99e97e2019-01-17 18:14:08 +01004479 if compile_prog "" "-lutil" ; then
Thomas Huth9df8b202020-06-29 14:13:24 +02004480 have_openpty="yes"
Thomas Huthd99e97e2019-01-17 18:14:08 +01004481 fi
Juan Quintela6362a532009-08-03 14:46:32 +02004482fi
4483
Blue Swirlde5071c2009-09-12 09:58:46 +00004484##########################################
Gerd Hoffmanncd4ec0b2010-03-24 10:26:51 +01004485# spice probe
4486if test "$spice" != "no" ; then
4487 cat > $TMPC << EOF
4488#include <spice.h>
4489int main(void) { spice_server_new(); return 0; }
4490EOF
Jiri Denemark710fc4f2011-01-24 13:20:29 +01004491 spice_cflags=$($pkg_config --cflags spice-protocol spice-server 2>/dev/null)
4492 spice_libs=$($pkg_config --libs spice-protocol spice-server 2>/dev/null)
Marc-André Lureau1b636652018-11-28 19:59:32 +04004493 if $pkg_config --atleast-version=0.12.5 spice-server && \
Stefan Weil65d5d3f2013-08-27 21:09:13 +02004494 $pkg_config --atleast-version=0.12.3 spice-protocol && \
Gerd Hoffmanncd4ec0b2010-03-24 10:26:51 +01004495 compile_prog "$spice_cflags" "$spice_libs" ; then
4496 spice="yes"
Gerd Hoffmanncd4ec0b2010-03-24 10:26:51 +01004497 else
4498 if test "$spice" = "yes" ; then
Hu Tao8efc9362014-06-26 17:34:50 +08004499 feature_not_found "spice" \
Marc-André Lureau1b636652018-11-28 19:59:32 +04004500 "Install spice-server(>=0.12.5) and spice-protocol(>=0.12.3) devel"
Gerd Hoffmanncd4ec0b2010-03-24 10:26:51 +01004501 fi
4502 spice="no"
4503 fi
4504fi
4505
Marc-André Lureau7b02f542015-08-30 11:48:40 +02004506# check for smartcard support
Marc-André Lureau7b02f542015-08-30 11:48:40 +02004507if test "$smartcard" != "no"; then
Michal Privoznik0f5c6422018-04-03 12:34:37 +02004508 if $pkg_config --atleast-version=2.5.1 libcacard; then
Marc-André Lureau7b02f542015-08-30 11:48:40 +02004509 libcacard_cflags=$($pkg_config --cflags libcacard)
4510 libcacard_libs=$($pkg_config --libs libcacard)
Marc-André Lureau7b02f542015-08-30 11:48:40 +02004511 smartcard="yes"
Paolo Bonziniafd347a2012-12-20 20:39:36 +01004512 else
Marc-André Lureau7b02f542015-08-30 11:48:40 +02004513 if test "$smartcard" = "yes"; then
4514 feature_not_found "smartcard" "Install libcacard devel"
Paolo Bonziniafd347a2012-12-20 20:39:36 +01004515 fi
Marc-André Lureau7b02f542015-08-30 11:48:40 +02004516 smartcard="no"
Paolo Bonziniafd347a2012-12-20 20:39:36 +01004517 fi
Robert Relyea111a38b2010-11-28 16:36:38 +02004518fi
4519
Gerd Hoffmann2b2325f2012-11-30 16:02:11 +01004520# check for libusb
4521if test "$libusb" != "no" ; then
Stefan Weil65d5d3f2013-08-27 21:09:13 +02004522 if $pkg_config --atleast-version=1.0.13 libusb-1.0; then
Gerd Hoffmann2b2325f2012-11-30 16:02:11 +01004523 libusb="yes"
Stefan Weilca871ec2013-08-27 21:09:12 +02004524 libusb_cflags=$($pkg_config --cflags libusb-1.0)
4525 libusb_libs=$($pkg_config --libs libusb-1.0)
Gerd Hoffmann2b2325f2012-11-30 16:02:11 +01004526 else
4527 if test "$libusb" = "yes"; then
Hu Tao8efc9362014-06-26 17:34:50 +08004528 feature_not_found "libusb" "Install libusb devel >= 1.0.13"
Gerd Hoffmann2b2325f2012-11-30 16:02:11 +01004529 fi
4530 libusb="no"
4531 fi
4532fi
4533
Hans de Goede69354a82011-07-19 11:04:10 +02004534# check for usbredirparser for usb network redirection support
4535if test "$usb_redir" != "no" ; then
Stefan Weil65d5d3f2013-08-27 21:09:13 +02004536 if $pkg_config --atleast-version=0.6 libusbredirparser-0.5; then
Hans de Goede69354a82011-07-19 11:04:10 +02004537 usb_redir="yes"
Stefan Weilca871ec2013-08-27 21:09:12 +02004538 usb_redir_cflags=$($pkg_config --cflags libusbredirparser-0.5)
4539 usb_redir_libs=$($pkg_config --libs libusbredirparser-0.5)
Hans de Goede69354a82011-07-19 11:04:10 +02004540 else
4541 if test "$usb_redir" = "yes"; then
Stewart Smith21684af2014-01-24 12:39:10 +11004542 feature_not_found "usb-redir" "Install usbredir devel"
Hans de Goede69354a82011-07-19 11:04:10 +02004543 fi
4544 usb_redir="no"
4545 fi
4546fi
4547
Gerd Hoffmanncd4ec0b2010-03-24 10:26:51 +01004548##########################################
Tomoki Sekiyamad9840e22013-08-07 11:40:03 -04004549# check if we have VSS SDK headers for win
4550
Eric Blakee633a5c2019-02-04 20:39:37 -06004551if test "$mingw32" = "yes" && test "$guest_agent" != "no" && \
4552 test "$vss_win32_sdk" != "no" ; then
Tomoki Sekiyamad9840e22013-08-07 11:40:03 -04004553 case "$vss_win32_sdk" in
Michael Roth690604f2016-06-28 17:31:49 -05004554 "") vss_win32_include="-isystem $source_path" ;;
Tomoki Sekiyamad9840e22013-08-07 11:40:03 -04004555 *\ *) # The SDK is installed in "Program Files" by default, but we cannot
4556 # handle path with spaces. So we symlink the headers into ".sdk/vss".
Michael Roth690604f2016-06-28 17:31:49 -05004557 vss_win32_include="-isystem $source_path/.sdk/vss"
Tomoki Sekiyamad9840e22013-08-07 11:40:03 -04004558 symlink "$vss_win32_sdk/inc" "$source_path/.sdk/vss/inc"
4559 ;;
Michael Roth690604f2016-06-28 17:31:49 -05004560 *) vss_win32_include="-isystem $vss_win32_sdk"
Tomoki Sekiyamad9840e22013-08-07 11:40:03 -04004561 esac
4562 cat > $TMPC << EOF
4563#define __MIDL_user_allocate_free_DEFINED__
4564#include <inc/win2003/vss.h>
4565int main(void) { return VSS_CTX_BACKUP; }
4566EOF
4567 if compile_prog "$vss_win32_include" "" ; then
4568 guest_agent_with_vss="yes"
4569 QEMU_CFLAGS="$QEMU_CFLAGS $vss_win32_include"
Fam Zheng315d3182016-09-21 12:27:21 +08004570 libs_qga="-lole32 -loleaut32 -lshlwapi -lstdc++ -Wl,--enable-stdcall-fixup $libs_qga"
Michael Rothf33ca812015-08-26 16:19:41 -05004571 qga_vss_provider="qga/vss-win32/qga-vss.dll qga/vss-win32/qga-vss.tlb"
Tomoki Sekiyamad9840e22013-08-07 11:40:03 -04004572 else
4573 if test "$vss_win32_sdk" != "" ; then
4574 echo "ERROR: Please download and install Microsoft VSS SDK:"
4575 echo "ERROR: http://www.microsoft.com/en-us/download/details.aspx?id=23490"
4576 echo "ERROR: On POSIX-systems, you can extract the SDK headers by:"
4577 echo "ERROR: scripts/extract-vsssdk-headers setup.exe"
4578 echo "ERROR: The headers are extracted in the directory \`inc'."
4579 feature_not_found "VSS support"
4580 fi
4581 guest_agent_with_vss="no"
4582 fi
4583fi
4584
4585##########################################
4586# lookup Windows platform SDK (if not specified)
4587# The SDK is needed only to build .tlb (type library) file of guest agent
4588# VSS provider from the source. It is usually unnecessary because the
4589# pre-compiled .tlb file is included.
4590
Eric Blakee633a5c2019-02-04 20:39:37 -06004591if test "$mingw32" = "yes" && test "$guest_agent" != "no" && \
4592 test "$guest_agent_with_vss" = "yes" ; then
Tomoki Sekiyamad9840e22013-08-07 11:40:03 -04004593 if test -z "$win_sdk"; then
4594 programfiles="$PROGRAMFILES"
4595 test -n "$PROGRAMW6432" && programfiles="$PROGRAMW6432"
4596 if test -n "$programfiles"; then
4597 win_sdk=$(ls -d "$programfiles/Microsoft SDKs/Windows/v"* | tail -1) 2>/dev/null
4598 else
4599 feature_not_found "Windows SDK"
4600 fi
4601 elif test "$win_sdk" = "no"; then
4602 win_sdk=""
4603 fi
4604fi
4605
4606##########################################
Michael Roth50cbebb2015-07-07 18:10:09 -05004607# check if mingw environment provides a recent ntddscsi.h
Eric Blakee633a5c2019-02-04 20:39:37 -06004608if test "$mingw32" = "yes" && test "$guest_agent" != "no"; then
Michael Roth50cbebb2015-07-07 18:10:09 -05004609 cat > $TMPC << EOF
4610#include <windows.h>
4611#include <ntddscsi.h>
4612int main(void) {
4613#if !defined(IOCTL_SCSI_GET_ADDRESS)
4614#error Missing required ioctl definitions
4615#endif
4616 SCSI_ADDRESS addr = { .Lun = 0, .TargetId = 0, .PathId = 0 };
4617 return addr.Lun;
4618}
4619EOF
4620 if compile_prog "" "" ; then
4621 guest_agent_ntddscsi=yes
Matt Hines996b9cd2019-01-28 14:30:56 -08004622 libs_qga="-lsetupapi -lcfgmgr32 $libs_qga"
Michael Roth50cbebb2015-07-07 18:10:09 -05004623 fi
4624fi
4625
4626##########################################
Gerd Hoffmann9d9e1522014-07-11 12:51:43 +02004627# virgl renderer probe
4628
4629if test "$virglrenderer" != "no" ; then
4630 cat > $TMPC << EOF
4631#include <virglrenderer.h>
4632int main(void) { virgl_renderer_poll(); return 0; }
4633EOF
4634 virgl_cflags=$($pkg_config --cflags virglrenderer 2>/dev/null)
4635 virgl_libs=$($pkg_config --libs virglrenderer 2>/dev/null)
Marc-André Lureau47479c52018-05-25 17:36:09 +02004636 virgl_version=$($pkg_config --modversion virglrenderer 2>/dev/null)
Gerd Hoffmann9d9e1522014-07-11 12:51:43 +02004637 if $pkg_config virglrenderer >/dev/null 2>&1 && \
4638 compile_prog "$virgl_cflags" "$virgl_libs" ; then
4639 virglrenderer="yes"
4640 else
4641 if test "$virglrenderer" = "yes" ; then
4642 feature_not_found "virglrenderer"
4643 fi
4644 virglrenderer="no"
4645 fi
4646fi
4647
4648##########################################
Richard Henderson8ca80762017-09-14 09:41:12 -07004649# capstone
4650
Richard Hendersone219c492017-09-28 09:01:23 -07004651case "$capstone" in
Richard Henderson8b18cdb2020-09-13 12:19:25 -07004652 auto | enabled | internal)
4653 # Simpler to always update submodule, even if not needed.
4654 if test -e "${source_path}/.git" && test $git_update = 'yes' ; then
Richard Hendersone219c492017-09-28 09:01:23 -07004655 git_submodules="${git_submodules} capstone"
4656 fi
Richard Hendersone219c492017-09-28 09:01:23 -07004657 ;;
4658esac
Richard Henderson8ca80762017-09-14 09:41:12 -07004659
4660##########################################
Blue Swirl5f6b9e82009-09-20 06:56:26 +00004661# check if we have fdatasync
4662
4663fdatasync=no
4664cat > $TMPC << EOF
4665#include <unistd.h>
Alexandre Raymondd1722a22011-05-29 18:22:48 -04004666int main(void) {
4667#if defined(_POSIX_SYNCHRONIZED_IO) && _POSIX_SYNCHRONIZED_IO > 0
4668return fdatasync(0);
4669#else
Stefan Weile172fe12012-04-06 21:33:20 +02004670#error Not supported
Alexandre Raymondd1722a22011-05-29 18:22:48 -04004671#endif
4672}
Blue Swirl5f6b9e82009-09-20 06:56:26 +00004673EOF
4674if compile_prog "" "" ; then
4675 fdatasync=yes
4676fi
4677
Stefan Hajnoczi94a420b2010-05-22 17:52:39 +01004678##########################################
Andreas Färbere78815a2010-09-25 11:26:05 +00004679# check if we have madvise
4680
4681madvise=no
4682cat > $TMPC << EOF
4683#include <sys/types.h>
4684#include <sys/mman.h>
Scott Wood832ce9c2010-10-05 14:28:17 -05004685#include <stddef.h>
Andreas Färbere78815a2010-09-25 11:26:05 +00004686int main(void) { return madvise(NULL, 0, MADV_DONTNEED); }
4687EOF
4688if compile_prog "" "" ; then
4689 madvise=yes
4690fi
4691
4692##########################################
4693# check if we have posix_madvise
4694
4695posix_madvise=no
4696cat > $TMPC << EOF
4697#include <sys/mman.h>
Scott Wood832ce9c2010-10-05 14:28:17 -05004698#include <stddef.h>
Andreas Färbere78815a2010-09-25 11:26:05 +00004699int main(void) { return posix_madvise(NULL, 0, POSIX_MADV_DONTNEED); }
4700EOF
4701if compile_prog "" "" ; then
4702 posix_madvise=yes
4703fi
4704
4705##########################################
Andreas Gustafsson9bc5a712018-01-04 19:39:36 +02004706# check if we have posix_memalign()
4707
4708posix_memalign=no
4709cat > $TMPC << EOF
4710#include <stdlib.h>
4711int main(void) {
4712 void *p;
4713 return posix_memalign(&p, 8, 8);
4714}
4715EOF
4716if compile_prog "" "" ; then
4717 posix_memalign=yes
4718fi
4719
4720##########################################
Paul Durrant0a852412016-08-04 14:44:14 +01004721# check if we have posix_syslog
4722
4723posix_syslog=no
4724cat > $TMPC << EOF
4725#include <syslog.h>
4726int main(void) { openlog("qemu", LOG_PID, LOG_DAEMON); syslog(LOG_INFO, "configure"); return 0; }
4727EOF
4728if compile_prog "" "" ; then
4729 posix_syslog=yes
4730fi
4731
4732##########################################
Peter Maydell401bc052017-09-05 13:19:32 +01004733# check if we have sem_timedwait
4734
4735sem_timedwait=no
4736cat > $TMPC << EOF
4737#include <semaphore.h>
Daniel P. Berrangé811294b2019-06-17 12:41:14 +01004738int main(void) { sem_t s; struct timespec t = {0}; return sem_timedwait(&s, &t); }
Peter Maydell401bc052017-09-05 13:19:32 +01004739EOF
4740if compile_prog "" "" ; then
4741 sem_timedwait=yes
4742fi
4743
4744##########################################
Keno Fischer5c99fa32018-06-29 12:32:10 +02004745# check if we have strchrnul
4746
4747strchrnul=no
4748cat > $TMPC << EOF
4749#include <string.h>
4750int main(void);
4751// Use a haystack that the compiler shouldn't be able to constant fold
4752char *haystack = (char*)&main;
4753int main(void) { return strchrnul(haystack, 'x') != &haystack[6]; }
4754EOF
4755if compile_prog "" "" ; then
4756 strchrnul=yes
4757fi
4758
Jiufei Xue8a792b02019-04-17 03:08:56 +08004759#########################################
4760# check if we have st_atim
4761
4762st_atim=no
4763cat > $TMPC << EOF
4764#include <sys/stat.h>
4765#include <stddef.h>
4766int main(void) { return offsetof(struct stat, st_atim); }
4767EOF
4768if compile_prog "" "" ; then
4769 st_atim=yes
4770fi
4771
Keno Fischer5c99fa32018-06-29 12:32:10 +02004772##########################################
Stefan Hajnoczi94a420b2010-05-22 17:52:39 +01004773# check if trace backend exists
4774
Lluís Vilanova5b808272014-05-27 15:02:14 +02004775$python "$source_path/scripts/tracetool.py" "--backends=$trace_backends" --check-backends > /dev/null 2> /dev/null
Stefan Hajnoczi94a420b2010-05-22 17:52:39 +01004776if test "$?" -ne 0 ; then
Lluís Vilanova5b808272014-05-27 15:02:14 +02004777 error_exit "invalid trace backends" \
4778 "Please choose supported trace backends."
Stefan Hajnoczi94a420b2010-05-22 17:52:39 +01004779fi
4780
Stefan Hajnoczi7e24e922010-05-22 21:11:33 +01004781##########################################
4782# For 'ust' backend, test if ust headers are present
Lluís Vilanova5b808272014-05-27 15:02:14 +02004783if have_backend "ust"; then
Stefan Hajnoczi7e24e922010-05-22 21:11:33 +01004784 cat > $TMPC << EOF
Mohamad Gebaibf15f632014-01-29 22:47:54 -05004785#include <lttng/tracepoint.h>
Stefan Hajnoczi7e24e922010-05-22 21:11:33 +01004786int main(void) { return 0; }
4787EOF
Francis Deslauriersc79ed232016-11-28 10:52:17 -05004788 if compile_prog "" "-Wl,--no-as-needed -ldl" ; then
Mohamad Gebaibf15f632014-01-29 22:47:54 -05004789 if $pkg_config lttng-ust --exists; then
Stefan Weil89138852016-05-16 15:10:20 +02004790 lttng_ust_libs=$($pkg_config --libs lttng-ust)
Mohamad Gebaibf15f632014-01-29 22:47:54 -05004791 else
Francis Deslauriersc79ed232016-11-28 10:52:17 -05004792 lttng_ust_libs="-llttng-ust -ldl"
Mohamad Gebaibf15f632014-01-29 22:47:54 -05004793 fi
4794 if $pkg_config liburcu-bp --exists; then
Stefan Weil89138852016-05-16 15:10:20 +02004795 urcu_bp_libs=$($pkg_config --libs liburcu-bp)
Mohamad Gebaibf15f632014-01-29 22:47:54 -05004796 else
4797 urcu_bp_libs="-lurcu-bp"
4798 fi
Stefan Hajnoczi7e24e922010-05-22 21:11:33 +01004799 else
Mohamad Gebaibf15f632014-01-29 22:47:54 -05004800 error_exit "Trace backend 'ust' missing lttng-ust header files"
Stefan Hajnoczi7e24e922010-05-22 21:11:33 +01004801 fi
4802fi
Daniel P. Berrangeb3d08c02010-11-12 13:20:24 +00004803
4804##########################################
4805# For 'dtrace' backend, test if 'dtrace' command is present
Lluís Vilanova5b808272014-05-27 15:02:14 +02004806if have_backend "dtrace"; then
Daniel P. Berrangeb3d08c02010-11-12 13:20:24 +00004807 if ! has 'dtrace' ; then
Peter Maydell76ad07a2013-04-08 12:11:26 +01004808 error_exit "dtrace command is not found in PATH $PATH"
Daniel P. Berrangeb3d08c02010-11-12 13:20:24 +00004809 fi
Daniel P. Berrangec276b172010-11-12 13:20:25 +00004810 trace_backend_stap="no"
4811 if has 'stap' ; then
4812 trace_backend_stap="yes"
4813 fi
Daniel P. Berrangeb3d08c02010-11-12 13:20:24 +00004814fi
4815
Stefan Hajnoczi7e24e922010-05-22 21:11:33 +01004816##########################################
Alex Barcelo519175a2012-02-28 12:25:50 +01004817# check and set a backend for coroutine
Aneesh Kumar K.Vd0e2fce2011-06-09 23:11:06 +05304818
Peter Maydell7c2acc72013-04-08 12:11:27 +01004819# We prefer ucontext, but it's not always possible. The fallback
Daniel P. Berrange33c53c52017-04-28 13:24:44 +01004820# is sigcontext. On Windows the only valid backend is the Windows
4821# specific one.
Peter Maydell7c2acc72013-04-08 12:11:27 +01004822
4823ucontext_works=no
4824if test "$darwin" != "yes"; then
4825 cat > $TMPC << EOF
Aneesh Kumar K.Vd0e2fce2011-06-09 23:11:06 +05304826#include <ucontext.h>
Peter Maydellcdf84802012-02-23 16:20:05 +00004827#ifdef __stub_makecontext
4828#error Ignoring glibc stub makecontext which will always fail
4829#endif
Stefan Weil75cafad2011-12-17 09:27:29 +01004830int main(void) { makecontext(0, 0, 0); return 0; }
Aneesh Kumar K.Vd0e2fce2011-06-09 23:11:06 +05304831EOF
Peter Maydell7c2acc72013-04-08 12:11:27 +01004832 if compile_prog "" "" ; then
4833 ucontext_works=yes
Aneesh Kumar K.Vd0e2fce2011-06-09 23:11:06 +05304834 fi
Peter Maydell7c2acc72013-04-08 12:11:27 +01004835fi
4836
4837if test "$coroutine" = ""; then
4838 if test "$mingw32" = "yes"; then
4839 coroutine=win32
4840 elif test "$ucontext_works" = "yes"; then
4841 coroutine=ucontext
4842 else
4843 coroutine=sigaltstack
4844 fi
Alex Barcelo519175a2012-02-28 12:25:50 +01004845else
Peter Maydell7c2acc72013-04-08 12:11:27 +01004846 case $coroutine in
4847 windows)
4848 if test "$mingw32" != "yes"; then
4849 error_exit "'windows' coroutine backend only valid for Windows"
4850 fi
4851 # Unfortunately the user visible backend name doesn't match the
4852 # coroutine-*.c filename for this case, so we have to adjust it here.
4853 coroutine=win32
4854 ;;
4855 ucontext)
4856 if test "$ucontext_works" != "yes"; then
4857 feature_not_found "ucontext"
4858 fi
4859 ;;
Daniel P. Berrange33c53c52017-04-28 13:24:44 +01004860 sigaltstack)
Peter Maydell7c2acc72013-04-08 12:11:27 +01004861 if test "$mingw32" = "yes"; then
4862 error_exit "only the 'windows' coroutine backend is valid for Windows"
4863 fi
4864 ;;
4865 *)
4866 error_exit "unknown coroutine backend $coroutine"
4867 ;;
4868 esac
Aneesh Kumar K.Vd0e2fce2011-06-09 23:11:06 +05304869fi
4870
Stefan Hajnoczi70c60c02013-09-11 16:42:35 +02004871if test "$coroutine_pool" = ""; then
Daniel P. Berrange33c53c52017-04-28 13:24:44 +01004872 coroutine_pool=yes
Stefan Hajnoczi70c60c02013-09-11 16:42:35 +02004873fi
4874
Peter Lieven7d992e42016-09-27 11:58:45 +02004875if test "$debug_stack_usage" = "yes"; then
Peter Lieven7d992e42016-09-27 11:58:45 +02004876 if test "$coroutine_pool" = "yes"; then
4877 echo "WARN: disabling coroutine pool for stack usage debugging"
4878 coroutine_pool=no
4879 fi
4880fi
4881
Daniele Buono1e4f6062020-05-29 16:51:21 -04004882##################################################
4883# SafeStack
4884
4885
4886if test "$safe_stack" = "yes"; then
4887cat > $TMPC << EOF
4888int main(int argc, char *argv[])
4889{
4890#if ! __has_feature(safe_stack)
4891#error SafeStack Disabled
4892#endif
4893 return 0;
4894}
4895EOF
4896 flag="-fsanitize=safe-stack"
4897 # Check that safe-stack is supported and enabled.
4898 if compile_prog "-Werror $flag" "$flag"; then
4899 # Flag needed both at compilation and at linking
4900 QEMU_CFLAGS="$QEMU_CFLAGS $flag"
4901 QEMU_LDFLAGS="$QEMU_LDFLAGS $flag"
4902 else
4903 error_exit "SafeStack not supported by your compiler"
4904 fi
4905 if test "$coroutine" != "ucontext"; then
4906 error_exit "SafeStack is only supported by the coroutine backend ucontext"
4907 fi
4908else
4909cat > $TMPC << EOF
4910int main(int argc, char *argv[])
4911{
4912#if defined(__has_feature)
4913#if __has_feature(safe_stack)
4914#error SafeStack Enabled
4915#endif
4916#endif
4917 return 0;
4918}
4919EOF
4920if test "$safe_stack" = "no"; then
4921 # Make sure that safe-stack is disabled
4922 if ! compile_prog "-Werror" ""; then
4923 # SafeStack was already enabled, try to explicitly remove the feature
4924 flag="-fno-sanitize=safe-stack"
4925 if ! compile_prog "-Werror $flag" "$flag"; then
4926 error_exit "Configure cannot disable SafeStack"
4927 fi
4928 QEMU_CFLAGS="$QEMU_CFLAGS $flag"
4929 QEMU_LDFLAGS="$QEMU_LDFLAGS $flag"
4930 fi
4931else # "$safe_stack" = ""
4932 # Set safe_stack to yes or no based on pre-existing flags
4933 if compile_prog "-Werror" ""; then
4934 safe_stack="no"
4935 else
4936 safe_stack="yes"
4937 if test "$coroutine" != "ucontext"; then
4938 error_exit "SafeStack is only supported by the coroutine backend ucontext"
4939 fi
4940 fi
4941fi
4942fi
Peter Lieven7d992e42016-09-27 11:58:45 +02004943
Aneesh Kumar K.Vd0e2fce2011-06-09 23:11:06 +05304944##########################################
Aneesh Kumar K.Vd2042372011-10-12 19:11:24 +05304945# check if we have open_by_handle_at
4946
Stefan Weil4e1797f2012-06-18 22:11:06 +02004947open_by_handle_at=no
Aneesh Kumar K.Vd2042372011-10-12 19:11:24 +05304948cat > $TMPC << EOF
4949#include <fcntl.h>
Stefan Weilacc55ba2012-06-06 19:35:57 +00004950#if !defined(AT_EMPTY_PATH)
4951# error missing definition
4952#else
Stefan Weil75cafad2011-12-17 09:27:29 +01004953int main(void) { struct file_handle fh; return open_by_handle_at(0, &fh, 0); }
Stefan Weilacc55ba2012-06-06 19:35:57 +00004954#endif
Aneesh Kumar K.Vd2042372011-10-12 19:11:24 +05304955EOF
4956if compile_prog "" "" ; then
4957 open_by_handle_at=yes
4958fi
4959
Harsh Prateek Borae06a7652011-10-12 19:11:25 +05304960########################################
4961# check if we have linux/magic.h
4962
4963linux_magic_h=no
4964cat > $TMPC << EOF
4965#include <linux/magic.h>
4966int main(void) {
Stefan Weil75cafad2011-12-17 09:27:29 +01004967 return 0;
Harsh Prateek Borae06a7652011-10-12 19:11:25 +05304968}
4969EOF
4970if compile_prog "" "" ; then
4971 linux_magic_h=yes
4972fi
4973
Luiz Capitulino8ab1bf12012-05-23 15:48:04 -03004974########################################
Christian Borntraeger541be922014-09-25 21:07:54 +02004975# check if we have valgrind/valgrind.h
Kevin Wolf3f4349d2012-06-29 13:40:27 +02004976
4977valgrind_h=no
4978cat > $TMPC << EOF
4979#include <valgrind/valgrind.h>
Kevin Wolf3f4349d2012-06-29 13:40:27 +02004980int main(void) {
Kevin Wolf3f4349d2012-06-29 13:40:27 +02004981 return 0;
4982}
4983EOF
4984if compile_prog "" "" ; then
4985 valgrind_h=yes
4986fi
4987
4988########################################
Luiz Capitulino8ab1bf12012-05-23 15:48:04 -03004989# check if environ is declared
4990
4991has_environ=no
4992cat > $TMPC << EOF
4993#include <unistd.h>
4994int main(void) {
Blue Swirlc075a722012-08-09 20:21:25 +00004995 environ = 0;
Luiz Capitulino8ab1bf12012-05-23 15:48:04 -03004996 return 0;
4997}
4998EOF
4999if compile_prog "" "" ; then
5000 has_environ=yes
5001fi
5002
Richard Henderson76a347e2012-12-28 14:17:02 -08005003########################################
5004# check if cpuid.h is usable.
5005
Richard Henderson76a347e2012-12-28 14:17:02 -08005006cat > $TMPC << EOF
5007#include <cpuid.h>
5008int main(void) {
Peter Maydell774d5662014-02-20 19:42:53 +00005009 unsigned a, b, c, d;
5010 int max = __get_cpuid_max(0, 0);
5011
5012 if (max >= 1) {
5013 __cpuid(1, a, b, c, d);
5014 }
5015
5016 if (max >= 7) {
5017 __cpuid_count(7, 0, a, b, c, d);
5018 }
5019
5020 return 0;
Richard Henderson76a347e2012-12-28 14:17:02 -08005021}
5022EOF
5023if compile_prog "" "" ; then
5024 cpuid_h=yes
5025fi
5026
Richard Henderson5dd89902017-07-18 18:40:18 -10005027##########################################
5028# avx2 optimization requirement check
5029#
5030# There is no point enabling this if cpuid.h is not usable,
5031# since we won't be able to select the new routines.
5032
Eric Blakee633a5c2019-02-04 20:39:37 -06005033if test "$cpuid_h" = "yes" && test "$avx2_opt" != "no"; then
Richard Henderson5dd89902017-07-18 18:40:18 -10005034 cat > $TMPC << EOF
5035#pragma GCC push_options
5036#pragma GCC target("avx2")
5037#include <cpuid.h>
5038#include <immintrin.h>
5039static int bar(void *a) {
5040 __m256i x = *(__m256i *)a;
5041 return _mm256_testz_si256(x, x);
5042}
5043int main(int argc, char *argv[]) { return bar(argv[0]); }
5044EOF
5045 if compile_object "" ; then
5046 avx2_opt="yes"
Liam Merwick86583a02018-10-19 21:38:59 +01005047 else
5048 avx2_opt="no"
Richard Henderson5dd89902017-07-18 18:40:18 -10005049 fi
5050fi
5051
Robert Hoo6b8cd442020-02-29 20:34:34 +08005052##########################################
5053# avx512f optimization requirement check
5054#
5055# There is no point enabling this if cpuid.h is not usable,
5056# since we won't be able to select the new routines.
5057# by default, it is turned off.
5058# if user explicitly want to enable it, check environment
5059
5060if test "$cpuid_h" = "yes" && test "$avx512f_opt" = "yes"; then
5061 cat > $TMPC << EOF
5062#pragma GCC push_options
5063#pragma GCC target("avx512f")
5064#include <cpuid.h>
5065#include <immintrin.h>
5066static int bar(void *a) {
5067 __m512i x = *(__m512i *)a;
5068 return _mm512_test_epi64_mask(x, x);
5069}
5070int main(int argc, char *argv[])
5071{
5072 return bar(argv[0]);
5073}
5074EOF
5075 if ! compile_object "" ; then
5076 avx512f_opt="no"
5077 fi
5078else
5079 avx512f_opt="no"
5080fi
5081
Richard Hendersonf5401662013-02-16 12:46:59 -08005082########################################
5083# check if __[u]int128_t is usable.
5084
5085int128=no
5086cat > $TMPC << EOF
5087__int128_t a;
5088__uint128_t b;
5089int main (void) {
5090 a = a + b;
5091 b = a * b;
Peter Maydell464e3672013-06-21 14:01:31 +01005092 a = a * a;
Richard Hendersonf5401662013-02-16 12:46:59 -08005093 return 0;
5094}
5095EOF
5096if compile_prog "" "" ; then
5097 int128=yes
5098fi
Richard Henderson76a347e2012-12-28 14:17:02 -08005099
Richard Henderson7ebee432016-06-29 21:10:59 -07005100#########################################
5101# See if 128-bit atomic operations are supported.
5102
5103atomic128=no
5104if test "$int128" = "yes"; then
5105 cat > $TMPC << EOF
5106int main(void)
5107{
5108 unsigned __int128 x = 0, y = 0;
5109 y = __atomic_load_16(&x, 0);
5110 __atomic_store_16(&x, y, 0);
5111 __atomic_compare_exchange_16(&x, &y, x, 0, 0, 0);
5112 return 0;
5113}
5114EOF
5115 if compile_prog "" "" ; then
5116 atomic128=yes
5117 fi
5118fi
5119
Richard Hendersone6cd4bb2018-08-15 16:31:47 -07005120cmpxchg128=no
Eric Blakee633a5c2019-02-04 20:39:37 -06005121if test "$int128" = yes && test "$atomic128" = no; then
Richard Hendersone6cd4bb2018-08-15 16:31:47 -07005122 cat > $TMPC << EOF
5123int main(void)
5124{
5125 unsigned __int128 x = 0, y = 0;
5126 __sync_val_compare_and_swap_16(&x, y, x);
5127 return 0;
5128}
5129EOF
5130 if compile_prog "" "" ; then
5131 cmpxchg128=yes
5132 fi
5133fi
5134
Richard Hendersondf79b992016-09-02 12:23:57 -07005135#########################################
5136# See if 64-bit atomic operations are supported.
5137# Note that without __atomic builtins, we can only
5138# assume atomic loads/stores max at pointer size.
5139
5140cat > $TMPC << EOF
5141#include <stdint.h>
5142int main(void)
5143{
5144 uint64_t x = 0, y = 0;
5145#ifdef __ATOMIC_RELAXED
Thomas Huth5fe40762020-07-16 12:23:48 +02005146 y = __atomic_load_n(&x, __ATOMIC_RELAXED);
5147 __atomic_store_n(&x, y, __ATOMIC_RELAXED);
5148 __atomic_compare_exchange_n(&x, &y, x, 0, __ATOMIC_RELAXED, __ATOMIC_RELAXED);
5149 __atomic_exchange_n(&x, y, __ATOMIC_RELAXED);
5150 __atomic_fetch_add(&x, y, __ATOMIC_RELAXED);
Richard Hendersondf79b992016-09-02 12:23:57 -07005151#else
5152 typedef char is_host64[sizeof(void *) >= sizeof(uint64_t) ? 1 : -1];
5153 __sync_lock_test_and_set(&x, y);
5154 __sync_val_compare_and_swap(&x, y, 0);
5155 __sync_fetch_and_add(&x, y);
5156#endif
5157 return 0;
5158}
5159EOF
5160if compile_prog "" "" ; then
5161 atomic64=yes
5162fi
5163
Emilio G. Cota26fffe22018-10-21 13:56:29 -04005164#########################################
5165# See if --dynamic-list is supported by the linker
5166ld_dynamic_list="no"
5167if test "$static" = "no" ; then
5168 cat > $TMPTXT <<EOF
5169{
5170 foo;
5171};
5172EOF
5173
5174 cat > $TMPC <<EOF
5175#include <stdio.h>
5176void foo(void);
5177
5178void foo(void)
5179{
5180 printf("foo\n");
5181}
5182
5183int main(void)
5184{
5185 foo();
5186 return 0;
5187}
5188EOF
5189
5190 if compile_prog "" "-Wl,--dynamic-list=$TMPTXT" ; then
5191 ld_dynamic_list="yes"
5192 fi
5193fi
5194
5195#########################################
5196# See if -exported_symbols_list is supported by the linker
5197
5198ld_exported_symbols_list="no"
5199if test "$static" = "no" ; then
5200 cat > $TMPTXT <<EOF
5201 _foo
5202EOF
5203
5204 if compile_prog "" "-Wl,-exported_symbols_list,$TMPTXT" ; then
5205 ld_exported_symbols_list="yes"
5206 fi
5207fi
5208
5209if test "$plugins" = "yes" &&
5210 test "$ld_dynamic_list" = "no" &&
5211 test "$ld_exported_symbols_list" = "no" ; then
5212 error_exit \
5213 "Plugin support requires dynamic linking and specifying a set of symbols " \
5214 "that are exported to plugins. Unfortunately your linker doesn't " \
5215 "support the flag (--dynamic-list or -exported_symbols_list) used " \
5216 "for this purpose. You can't build with --static."
5217fi
5218
Richard Henderson1e6e9ac2013-02-18 09:11:15 -08005219########################################
Richard Hendersondb8aaae2019-10-13 16:12:19 -07005220# See if __attribute__((alias)) is supported.
5221# This false for Xcode 9, but has been remedied for Xcode 10.
5222# Unfortunately, travis uses Xcode 9 by default.
5223
5224attralias=no
5225cat > $TMPC << EOF
5226int x = 1;
5227extern const int y __attribute__((alias("x")));
5228int main(void) { return 0; }
5229EOF
5230if compile_prog "" "" ; then
5231 attralias=yes
5232fi
5233
5234########################################
Richard Henderson1e6e9ac2013-02-18 09:11:15 -08005235# check if getauxval is available.
5236
5237getauxval=no
5238cat > $TMPC << EOF
5239#include <sys/auxv.h>
5240int main(void) {
5241 return getauxval(AT_HWCAP) == 0;
5242}
5243EOF
5244if compile_prog "" "" ; then
5245 getauxval=yes
5246fi
5247
John Snowfd0e6052015-03-25 18:57:39 -04005248########################################
5249# check if ccache is interfering with
5250# semantic analysis of macros
5251
John Snow5e4dfd32015-10-28 13:56:40 -04005252unset CCACHE_CPP2
John Snowfd0e6052015-03-25 18:57:39 -04005253ccache_cpp2=no
5254cat > $TMPC << EOF
5255static const int Z = 1;
5256#define fn() ({ Z; })
5257#define TAUT(X) ((X) == Z)
5258#define PAREN(X, Y) (X == Y)
5259#define ID(X) (X)
5260int main(int argc, char *argv[])
5261{
5262 int x = 0, y = 0;
5263 x = ID(x);
5264 x = fn();
5265 fn();
5266 if (PAREN(x, y)) return 0;
5267 if (TAUT(Z)) return 0;
5268 return 0;
5269}
5270EOF
5271
5272if ! compile_object "-Werror"; then
5273 ccache_cpp2=yes
5274fi
5275
John Snowb553a042015-11-03 15:43:42 -05005276#################################################
5277# clang does not support glibc + FORTIFY_SOURCE.
5278
5279if test "$fortify_source" != "no"; then
5280 if echo | $cc -dM -E - | grep __clang__ > /dev/null 2>&1 ; then
5281 fortify_source="no";
Peter Maydelle1890912017-06-26 16:25:24 +01005282 elif test -n "$cxx" && has $cxx &&
John Snowcfcc7c12015-11-12 11:29:49 -05005283 echo | $cxx -dM -E - | grep __clang__ >/dev/null 2>&1 ; then
John Snowb553a042015-11-03 15:43:42 -05005284 fortify_source="no";
5285 else
5286 fortify_source="yes"
5287 fi
5288fi
5289
Fam Zheng1efad062018-06-01 17:26:43 +08005290###############################################
5291# Check if copy_file_range is provided by glibc
5292have_copy_file_range=no
5293cat > $TMPC << EOF
5294#include <unistd.h>
5295int main(void) {
5296 copy_file_range(0, NULL, 0, NULL, 0, 0);
5297 return 0;
5298}
5299EOF
5300if compile_prog "" "" ; then
5301 have_copy_file_range=yes
5302fi
5303
Aneesh Kumar K.Vd2042372011-10-12 19:11:24 +05305304##########################################
Jan Vesely277abf12016-04-29 13:15:23 -04005305# check if struct fsxattr is available via linux/fs.h
5306
5307have_fsxattr=no
5308cat > $TMPC << EOF
5309#include <linux/fs.h>
5310struct fsxattr foo;
5311int main(void) {
5312 return 0;
5313}
5314EOF
5315if compile_prog "" "" ; then
5316 have_fsxattr=yes
5317fi
5318
Peter Maydellb66e10e2016-06-08 18:34:32 +01005319##########################################
Paolo Bonzinia40161c2018-02-16 10:05:23 +01005320# check for usable membarrier system call
5321if test "$membarrier" = "yes"; then
5322 have_membarrier=no
5323 if test "$mingw32" = "yes" ; then
5324 have_membarrier=yes
5325 elif test "$linux" = "yes" ; then
5326 cat > $TMPC << EOF
5327 #include <linux/membarrier.h>
5328 #include <sys/syscall.h>
5329 #include <unistd.h>
5330 #include <stdlib.h>
5331 int main(void) {
5332 syscall(__NR_membarrier, MEMBARRIER_CMD_QUERY, 0);
5333 syscall(__NR_membarrier, MEMBARRIER_CMD_SHARED, 0);
5334 exit(0);
5335 }
5336EOF
5337 if compile_prog "" "" ; then
5338 have_membarrier=yes
5339 fi
5340 fi
5341 if test "$have_membarrier" = "no"; then
5342 feature_not_found "membarrier" "membarrier system call not available"
5343 fi
5344else
5345 # Do not enable it by default even for Mingw32, because it doesn't
5346 # work on Wine.
5347 membarrier=no
5348fi
5349
5350##########################################
Peter Maydellb66e10e2016-06-08 18:34:32 +01005351# check if rtnetlink.h exists and is useful
Laurent Vivier575b22b2016-06-02 22:14:15 +02005352have_rtnetlink=no
5353cat > $TMPC << EOF
5354#include <linux/rtnetlink.h>
5355int main(void) {
5356 return IFLA_PROTO_DOWN;
5357}
5358EOF
5359if compile_prog "" "" ; then
5360 have_rtnetlink=yes
5361fi
5362
Stefan Hajnoczi6a02c802016-10-14 10:00:55 +01005363##########################################
5364# check for usable AF_VSOCK environment
5365have_af_vsock=no
5366cat > $TMPC << EOF
5367#include <errno.h>
5368#include <sys/types.h>
5369#include <sys/socket.h>
5370#if !defined(AF_VSOCK)
5371# error missing AF_VSOCK flag
5372#endif
5373#include <linux/vm_sockets.h>
5374int main(void) {
5375 int sock, ret;
5376 struct sockaddr_vm svm;
5377 socklen_t len = sizeof(svm);
5378 sock = socket(AF_VSOCK, SOCK_STREAM, 0);
5379 ret = getpeername(sock, (struct sockaddr *)&svm, &len);
5380 if ((ret == -1) && (errno == ENOTCONN)) {
5381 return 0;
5382 }
5383 return -1;
5384}
5385EOF
5386if compile_prog "" "" ; then
5387 have_af_vsock=yes
5388fi
5389
Longpeng(Mike)f0d92b52017-07-14 14:04:05 -04005390##########################################
5391# check for usable AF_ALG environment
Thomas Huth4f673662020-02-03 16:55:34 +01005392have_afalg=no
Longpeng(Mike)f0d92b52017-07-14 14:04:05 -04005393cat > $TMPC << EOF
5394#include <errno.h>
5395#include <sys/types.h>
5396#include <sys/socket.h>
5397#include <linux/if_alg.h>
5398int main(void) {
5399 int sock;
5400 sock = socket(AF_ALG, SOCK_SEQPACKET, 0);
5401 return sock;
5402}
5403EOF
5404if compile_prog "" "" ; then
5405 have_afalg=yes
5406fi
5407if test "$crypto_afalg" = "yes"
5408then
5409 if test "$have_afalg" != "yes"
5410 then
5411 error_exit "AF_ALG requested but could not be detected"
5412 fi
5413fi
5414
5415
James Clarke6969ec62016-06-06 12:02:50 +01005416#################################################
Christopher Covington4d043512016-12-28 15:04:33 -05005417# check for sysmacros.h
5418
5419have_sysmacros=no
5420cat > $TMPC << EOF
5421#include <sys/sysmacros.h>
5422int main(void) {
5423 return makedev(0, 0);
5424}
5425EOF
5426if compile_prog "" "" ; then
5427 have_sysmacros=yes
5428fi
5429
5430##########################################
Andreas Grapentin49e00a12017-03-14 17:59:53 +01005431# check for _Static_assert()
5432
5433have_static_assert=no
5434cat > $TMPC << EOF
5435_Static_assert(1, "success");
5436int main(void) {
5437 return 0;
5438}
5439EOF
5440if compile_prog "" "" ; then
5441 have_static_assert=yes
5442fi
5443
5444##########################################
Tomáš Golembiovskýe6746052017-07-17 15:58:33 +02005445# check for utmpx.h, it is missing e.g. on OpenBSD
5446
5447have_utmpx=no
5448cat > $TMPC << EOF
5449#include <utmpx.h>
5450struct utmpx user_info;
5451int main(void) {
5452 return 0;
5453}
5454EOF
5455if compile_prog "" "" ; then
5456 have_utmpx=yes
5457fi
5458
5459##########################################
Richard Hendersondb1ed1a2019-03-13 20:57:28 -07005460# check for getrandom()
5461
5462have_getrandom=no
5463cat > $TMPC << EOF
5464#include <sys/random.h>
5465int main(void) {
5466 return getrandom(0, 0, GRND_NONBLOCK);
5467}
5468EOF
5469if compile_prog "" "" ; then
5470 have_getrandom=yes
5471fi
5472
5473##########################################
Marc-André Lureau247724c2018-01-16 16:11:51 +01005474# checks for sanitizers
5475
Marc-André Lureau247724c2018-01-16 16:11:51 +01005476have_asan=no
5477have_ubsan=no
Marc-André Lureaud83414e2018-01-16 16:11:52 +01005478have_asan_iface_h=no
5479have_asan_iface_fiber=no
Marc-André Lureau247724c2018-01-16 16:11:51 +01005480
5481if test "$sanitizers" = "yes" ; then
Marc-André Lureaub9f44da2018-02-15 22:25:47 +01005482 write_c_skeleton
Marc-André Lureau247724c2018-01-16 16:11:51 +01005483 if compile_prog "$CPU_CFLAGS -Werror -fsanitize=address" ""; then
5484 have_asan=yes
5485 fi
Marc-André Lureaub9f44da2018-02-15 22:25:47 +01005486
5487 # we could use a simple skeleton for flags checks, but this also
5488 # detect the static linking issue of ubsan, see also:
5489 # https://gcc.gnu.org/bugzilla/show_bug.cgi?id=84285
5490 cat > $TMPC << EOF
5491#include <stdlib.h>
5492int main(void) {
5493 void *tmp = malloc(10);
Leonid Blochf2dfe542020-05-25 01:12:04 +03005494 if (tmp != NULL) {
5495 return *(int *)(tmp + 2);
5496 }
Olaf Heringd1abf3f2020-07-07 19:13:25 +02005497 return 1;
Marc-André Lureaub9f44da2018-02-15 22:25:47 +01005498}
5499EOF
Marc-André Lureau247724c2018-01-16 16:11:51 +01005500 if compile_prog "$CPU_CFLAGS -Werror -fsanitize=undefined" ""; then
5501 have_ubsan=yes
5502 fi
Marc-André Lureaud83414e2018-01-16 16:11:52 +01005503
5504 if check_include "sanitizer/asan_interface.h" ; then
5505 have_asan_iface_h=yes
5506 fi
5507
5508 cat > $TMPC << EOF
5509#include <sanitizer/asan_interface.h>
5510int main(void) {
5511 __sanitizer_start_switch_fiber(0, 0, 0);
5512 return 0;
5513}
5514EOF
5515 if compile_prog "$CPU_CFLAGS -Werror -fsanitize=address" "" ; then
5516 have_asan_iface_fiber=yes
5517 fi
Marc-André Lureau247724c2018-01-16 16:11:51 +01005518fi
5519
5520##########################################
Alexander Bulekovadc28022020-02-19 23:11:14 -05005521# checks for fuzzer
Alexander Bulekov54c9e412020-09-02 13:36:51 -04005522if test "$fuzzing" = "yes" && test -z "${LIB_FUZZING_ENGINE+xxx}"; then
Alexander Bulekovadc28022020-02-19 23:11:14 -05005523 write_c_fuzzer_skeleton
Alexander Bulekovdd016262020-07-06 15:55:31 -04005524 if compile_prog "$CPU_CFLAGS -Werror -fsanitize=fuzzer" ""; then
Paolo Bonzini64ed6f92020-08-03 17:04:25 +02005525 have_fuzzer=yes
5526 else
5527 error_exit "Your compiler doesn't support -fsanitize=fuzzer"
5528 exit 1
Alexander Bulekovadc28022020-02-19 23:11:14 -05005529 fi
5530fi
5531
Lingfeng Yang0aebab02020-06-12 20:02:23 +01005532# Thread sanitizer is, for now, much noisier than the other sanitizers;
5533# keep it separate until that is not the case.
5534if test "$tsan" = "yes" && test "$sanitizers" = "yes"; then
5535 error_exit "TSAN is not supported with other sanitiziers."
5536fi
5537have_tsan=no
5538have_tsan_iface_fiber=no
5539if test "$tsan" = "yes" ; then
5540 write_c_skeleton
5541 if compile_prog "$CPU_CFLAGS -Werror -fsanitize=thread" "" ; then
5542 have_tsan=yes
5543 fi
5544 cat > $TMPC << EOF
5545#include <sanitizer/tsan_interface.h>
5546int main(void) {
5547 __tsan_create_fiber(0);
5548 return 0;
5549}
5550EOF
5551 if compile_prog "$CPU_CFLAGS -Werror -fsanitize=thread" "" ; then
5552 have_tsan_iface_fiber=yes
5553 fi
5554fi
5555
Alexander Bulekovadc28022020-02-19 23:11:14 -05005556##########################################
Junyan He17824402018-07-18 15:47:59 +08005557# check for libpmem
5558
5559if test "$libpmem" != "no"; then
5560 if $pkg_config --exists "libpmem"; then
5561 libpmem="yes"
5562 libpmem_libs=$($pkg_config --libs libpmem)
5563 libpmem_cflags=$($pkg_config --cflags libpmem)
Junyan He17824402018-07-18 15:47:59 +08005564 else
5565 if test "$libpmem" = "yes" ; then
5566 feature_not_found "libpmem" "Install nvml or pmdk"
5567 fi
5568 libpmem="no"
5569 fi
5570fi
5571
5572##########################################
Jingqi Liu21b2eca2020-04-29 16:50:11 +08005573# check for libdaxctl
5574
5575if test "$libdaxctl" != "no"; then
5576 if $pkg_config --atleast-version=57 "libdaxctl"; then
5577 libdaxctl="yes"
5578 libdaxctl_libs=$($pkg_config --libs libdaxctl)
5579 libdaxctl_cflags=$($pkg_config --cflags libdaxctl)
Jingqi Liu21b2eca2020-04-29 16:50:11 +08005580 else
5581 if test "$libdaxctl" = "yes" ; then
5582 feature_not_found "libdaxctl" "Install libdaxctl"
5583 fi
5584 libdaxctl="no"
5585 fi
5586fi
5587
5588##########################################
Marc-André Lureau675b9b52019-02-12 17:25:23 +01005589# check for slirp
5590
5591case "$slirp" in
Paolo Bonzini4d34a862020-10-05 11:31:15 +02005592 auto | enabled | internal)
5593 # Simpler to always update submodule, even if not needed.
5594 if test -e "${source_path}/.git" && test $git_update = 'yes' ; then
Marc-André Lureau7c57bdd82019-04-24 13:00:41 +02005595 git_submodules="${git_submodules} slirp"
5596 fi
Marc-André Lureau675b9b52019-02-12 17:25:23 +01005597 ;;
5598esac
5599
Alexey Krasikov54e7aac2020-05-25 14:19:12 +03005600##########################################
5601# check for usable __NR_keyctl syscall
5602
5603if test "$linux" = "yes" ; then
5604
5605 have_keyring=no
5606 cat > $TMPC << EOF
5607#include <errno.h>
5608#include <asm/unistd.h>
5609#include <linux/keyctl.h>
5610#include <unistd.h>
5611int main(void) {
5612 return syscall(__NR_keyctl, KEYCTL_READ, 0, NULL, NULL, 0);
5613}
5614EOF
5615 if compile_prog "" "" ; then
5616 have_keyring=yes
5617 fi
5618fi
5619if test "$secret_keyring" != "no"
5620then
David Edmondsonb418d262020-07-01 14:56:15 +01005621 if test "$have_keyring" = "yes"
Alexey Krasikov54e7aac2020-05-25 14:19:12 +03005622 then
5623 secret_keyring=yes
5624 else
5625 if test "$secret_keyring" = "yes"
5626 then
5627 error_exit "syscall __NR_keyctl requested, \
5628but not implemented on your system"
5629 else
5630 secret_keyring=no
5631 fi
5632 fi
5633fi
5634
Alexey Krasikov92500362020-05-25 14:19:13 +03005635##########################################
Juan Quintelae86ecd42009-08-03 14:45:59 +02005636# End of CC checks
5637# After here, no more $cc or $ld runs
5638
Marc-André Lureaud83414e2018-01-16 16:11:52 +01005639write_c_skeleton
5640
Blue Swirl1d728c32012-05-01 18:45:39 +00005641if test "$gcov" = "yes" ; then
Marc-André Lureaubf0e56a2019-10-04 17:35:16 +04005642 :
John Snowb553a042015-11-03 15:43:42 -05005643elif test "$fortify_source" = "yes" ; then
Paolo Bonzini086d5f72020-02-03 15:22:17 +01005644 QEMU_CFLAGS="-U_FORTIFY_SOURCE -D_FORTIFY_SOURCE=2 $QEMU_CFLAGS"
5645 debug=no
5646fi
Paolo Bonzini086d5f72020-02-03 15:22:17 +01005647
5648case "$ARCH" in
5649alpha)
5650 # Ensure there's only a single GP
5651 QEMU_CFLAGS="-msmall-data $QEMU_CFLAGS"
5652;;
5653esac
5654
5655if test "$gprof" = "yes" ; then
5656 QEMU_CFLAGS="-p $QEMU_CFLAGS"
5657 QEMU_LDFLAGS="-p $QEMU_LDFLAGS"
5658fi
Juan Quintelaa316e372009-09-30 01:10:55 +02005659
Marc-André Lureau247724c2018-01-16 16:11:51 +01005660if test "$have_asan" = "yes"; then
Paolo Bonzinidb5adea2019-12-11 15:34:27 +01005661 QEMU_CFLAGS="-fsanitize=address $QEMU_CFLAGS"
5662 QEMU_LDFLAGS="-fsanitize=address $QEMU_LDFLAGS"
Marc-André Lureaud83414e2018-01-16 16:11:52 +01005663 if test "$have_asan_iface_h" = "no" ; then
5664 echo "ASAN build enabled, but ASAN header missing." \
5665 "Without code annotation, the report may be inferior."
5666 elif test "$have_asan_iface_fiber" = "no" ; then
5667 echo "ASAN build enabled, but ASAN header is too old." \
5668 "Without code annotation, the report may be inferior."
5669 fi
Marc-André Lureau247724c2018-01-16 16:11:51 +01005670fi
Lingfeng Yang0aebab02020-06-12 20:02:23 +01005671if test "$have_tsan" = "yes" ; then
5672 if test "$have_tsan_iface_fiber" = "yes" ; then
5673 QEMU_CFLAGS="-fsanitize=thread $QEMU_CFLAGS"
5674 QEMU_LDFLAGS="-fsanitize=thread $QEMU_LDFLAGS"
5675 else
5676 error_exit "Cannot enable TSAN due to missing fiber annotation interface."
5677 fi
5678elif test "$tsan" = "yes" ; then
5679 error_exit "Cannot enable TSAN due to missing sanitize thread interface."
5680fi
Marc-André Lureau247724c2018-01-16 16:11:51 +01005681if test "$have_ubsan" = "yes"; then
Paolo Bonzinidb5adea2019-12-11 15:34:27 +01005682 QEMU_CFLAGS="-fsanitize=undefined $QEMU_CFLAGS"
5683 QEMU_LDFLAGS="-fsanitize=undefined $QEMU_LDFLAGS"
Marc-André Lureau247724c2018-01-16 16:11:51 +01005684fi
5685
Peter Lieven6542aa92014-02-03 10:26:13 +01005686##########################################
5687# Do we have libnfs
5688if test "$libnfs" != "no" ; then
Peter Lievenb7d769c2014-03-17 09:37:33 +01005689 if $pkg_config --atleast-version=1.9.3 libnfs; then
Peter Lieven6542aa92014-02-03 10:26:13 +01005690 libnfs="yes"
5691 libnfs_libs=$($pkg_config --libs libnfs)
Peter Lieven6542aa92014-02-03 10:26:13 +01005692 else
5693 if test "$libnfs" = "yes" ; then
Hu Tao8efc9362014-06-26 17:34:50 +08005694 feature_not_found "libnfs" "Install libnfs devel >= 1.9.3"
Peter Lieven6542aa92014-02-03 10:26:13 +01005695 fi
5696 libnfs="no"
5697 fi
5698fi
Blue Swirl1d728c32012-05-01 18:45:39 +00005699
Tomáš Golembiovský3efac6e2018-10-23 13:23:10 +02005700##########################################
Tomáš Golembiovský3efac6e2018-10-23 13:23:10 +02005701
Lingfeng Yang0aebab02020-06-12 20:02:23 +01005702# Exclude --warn-common with TSan to suppress warnings from the TSan libraries.
5703if test "$solaris" = "no" && test "$tsan" = "no"; then
Juan Quintelae86ecd42009-08-03 14:45:59 +02005704 if $ld --version 2>/dev/null | grep "GNU ld" >/dev/null 2>/dev/null ; then
Paolo Bonzinidb5adea2019-12-11 15:34:27 +01005705 QEMU_LDFLAGS="-Wl,--warn-common $QEMU_LDFLAGS"
Juan Quintelae86ecd42009-08-03 14:45:59 +02005706 fi
5707fi
5708
Blue Swirl952afb72010-09-19 08:36:34 +00005709# Use ASLR, no-SEH and DEP if available
5710if test "$mingw32" = "yes" ; then
Mark Cave-Aylandcb8baa72020-10-05 14:34:34 +01005711 flags="--no-seh --nxcompat"
5712
5713 # Disable ASLR for debug builds to allow debugging with gdb
5714 if test "$debug" = "no" ; then
5715 flags="--dynamicbase $flags"
5716 fi
5717
5718 for flag in $flags; do
Christian Borntraegere9a35912017-08-23 12:16:23 +02005719 if ld_has $flag ; then
Paolo Bonzinidb5adea2019-12-11 15:34:27 +01005720 QEMU_LDFLAGS="-Wl,$flag $QEMU_LDFLAGS"
Blue Swirl952afb72010-09-19 08:36:34 +00005721 fi
5722 done
5723fi
5724
Kamil Rytarowskie0580342017-07-14 09:33:44 +01005725# We can only support ivshmem if we have eventfd
5726if [ "$eventfd" = "yes" ]; then
5727 ivshmem=yes
5728fi
5729
Daniel P. Berrange4b1c11f2012-09-10 12:26:29 +01005730if test "$softmmu" = yes ; then
Paolo Bonzinib855f8d2017-08-22 06:50:18 +02005731 if test "$linux" = yes; then
Paolo Bonzini7e462612019-11-29 12:16:32 +01005732 if test "$virtfs" != no && test "$cap_ng" = yes && test "$attr" = yes ; then
Andreas Färberaabfd882012-05-01 01:12:02 +02005733 virtfs=yes
Andreas Färberaabfd882012-05-01 01:12:02 +02005734 else
5735 if test "$virtfs" = yes; then
Paolo Bonzini7e462612019-11-29 12:16:32 +01005736 error_exit "VirtFS requires libcap-ng devel and libattr devel"
Meador Inge983eef52012-02-24 14:00:42 +05305737 fi
Andreas Färber17500372012-05-01 01:12:03 +02005738 virtfs=no
Andreas Färberaabfd882012-05-01 01:12:02 +02005739 fi
Paolo Bonzinib855f8d2017-08-22 06:50:18 +02005740 else
5741 if test "$virtfs" = yes; then
5742 error_exit "VirtFS is supported only on Linux"
5743 fi
5744 virtfs=no
M. Mohan Kumar17bff522011-12-14 13:58:42 +05305745 fi
Gerd Hoffmann6a021532017-10-05 17:33:28 +02005746fi
Michael Roth9d6bc272015-08-26 10:49:13 -05005747
5748# Probe for guest agent support/options
5749
Michael Tokareve8ef31a2013-07-31 14:22:07 +04005750if [ "$guest_agent" != "no" ]; then
Laurent Viviera5125902019-04-01 16:12:20 +02005751 if [ "$softmmu" = no -a "$want_tools" = no ] ; then
5752 guest_agent=no
5753 elif [ "$linux" = "yes" -o "$bsd" = "yes" -o "$solaris" = "yes" -o "$mingw32" = "yes" ] ; then
Michael Tokareve8ef31a2013-07-31 14:22:07 +04005754 guest_agent=yes
5755 elif [ "$guest_agent" != yes ]; then
5756 guest_agent=no
5757 else
5758 error_exit "Guest agent is not supported on this platform"
Paolo Bonzinica35f782010-05-26 16:08:29 +02005759 fi
Paolo Bonzini00c705f2012-05-29 11:40:24 +02005760fi
Paolo Bonzinica35f782010-05-26 16:08:29 +02005761
Michael Roth9d6bc272015-08-26 10:49:13 -05005762# Guest agent Window MSI package
5763
5764if test "$guest_agent" != yes; then
5765 if test "$guest_agent_msi" = yes; then
5766 error_exit "MSI guest agent package requires guest agent enabled"
5767 fi
5768 guest_agent_msi=no
5769elif test "$mingw32" != "yes"; then
5770 if test "$guest_agent_msi" = "yes"; then
5771 error_exit "MSI guest agent package is available only for MinGW Windows cross-compilation"
5772 fi
5773 guest_agent_msi=no
5774elif ! has wixl; then
5775 if test "$guest_agent_msi" = "yes"; then
5776 error_exit "MSI guest agent package requires wixl tool installed ( usually from msitools package )"
5777 fi
5778 guest_agent_msi=no
Michael Roth1a349042015-08-26 11:14:31 -05005779else
5780 # we support qemu-ga, mingw32, and wixl: default to MSI enabled if it wasn't
5781 # disabled explicitly
5782 if test "$guest_agent_msi" != "no"; then
5783 guest_agent_msi=yes
5784 fi
Michael Roth9d6bc272015-08-26 10:49:13 -05005785fi
5786
Michael Roth1a349042015-08-26 11:14:31 -05005787if test "$guest_agent_msi" = "yes"; then
Michael Roth9d6bc272015-08-26 10:49:13 -05005788 if test "$guest_agent_with_vss" = "yes"; then
5789 QEMU_GA_MSI_WITH_VSS="-D InstallVss"
5790 fi
5791
5792 if test "$QEMU_GA_MANUFACTURER" = ""; then
5793 QEMU_GA_MANUFACTURER=QEMU
5794 fi
5795
5796 if test "$QEMU_GA_DISTRO" = ""; then
5797 QEMU_GA_DISTRO=Linux
5798 fi
5799
5800 if test "$QEMU_GA_VERSION" = ""; then
Stefan Weil89138852016-05-16 15:10:20 +02005801 QEMU_GA_VERSION=$(cat $source_path/VERSION)
Michael Roth9d6bc272015-08-26 10:49:13 -05005802 fi
5803
Stefan Weil89138852016-05-16 15:10:20 +02005804 QEMU_GA_MSI_MINGW_DLL_PATH="-D Mingw_dlls=$($pkg_config --variable=prefix glib-2.0)/bin"
Michael Roth9d6bc272015-08-26 10:49:13 -05005805
5806 case "$cpu" in
5807 x86_64)
5808 QEMU_GA_MSI_ARCH="-a x64 -D Arch=64"
5809 ;;
5810 i386)
5811 QEMU_GA_MSI_ARCH="-D Arch=32"
5812 ;;
5813 *)
5814 error_exit "CPU $cpu not supported for building installation package"
5815 ;;
5816 esac
5817fi
5818
Paolo Bonzinica35f782010-05-26 16:08:29 +02005819# Mac OS X ships with a broken assembler
5820roms=
Eric Blakee633a5c2019-02-04 20:39:37 -06005821if { test "$cpu" = "i386" || test "$cpu" = "x86_64"; } && \
5822 test "$targetos" != "Darwin" && test "$targetos" != "SunOS" && \
5823 test "$softmmu" = yes ; then
Peter Maydelle57218b2016-08-08 17:11:28 +01005824 # Different host OS linkers have different ideas about the name of the ELF
Brad Smithc65d5e42017-11-07 18:46:11 -05005825 # emulation. Linux and OpenBSD/amd64 use 'elf_i386'; FreeBSD uses the _fbsd
5826 # variant; OpenBSD/i386 uses the _obsd variant; and Windows uses i386pe.
5827 for emu in elf_i386 elf_i386_fbsd elf_i386_obsd i386pe; do
Peter Maydelle57218b2016-08-08 17:11:28 +01005828 if "$ld" -verbose 2>&1 | grep -q "^[[:space:]]*$emu[[:space:]]*$"; then
5829 ld_i386_emulation="$emu"
5830 roms="optionrom"
5831 break
5832 fi
5833 done
Paolo Bonzinica35f782010-05-26 16:08:29 +02005834fi
Paolo Bonzinica35f782010-05-26 16:08:29 +02005835
Thomas Huth2e33c3f2019-01-14 13:52:26 +01005836# Only build s390-ccw bios if we're on s390x and the compiler has -march=z900
Christian Borntraeger9933c302013-04-23 01:23:03 +00005837if test "$cpu" = "s390x" ; then
Thomas Huth2e33c3f2019-01-14 13:52:26 +01005838 write_c_skeleton
5839 if compile_prog "-march=z900" ""; then
5840 roms="$roms s390-ccw"
Philippe Mathieu-Daudé1ef6bfc2020-06-15 09:49:19 +02005841 # SLOF is required for building the s390-ccw firmware on s390x,
5842 # since it is using the libnet code from SLOF for network booting.
5843 if test -e "${source_path}/.git" ; then
5844 git_submodules="${git_submodules} roms/SLOF"
5845 fi
Thomas Huth2e33c3f2019-01-14 13:52:26 +01005846 fi
Christian Borntraeger9933c302013-04-23 01:23:03 +00005847fi
5848
Bruno Dominguez11cde1c2017-06-06 14:07:47 +01005849# Check that the C++ compiler exists and works with the C compiler.
5850# All the QEMU_CXXFLAGS are based on QEMU_CFLAGS. Keep this at the end to don't miss any other that could be added.
5851if has $cxx; then
5852 cat > $TMPC <<EOF
5853int c_function(void);
5854int main(void) { return c_function(); }
5855EOF
5856
5857 compile_object
5858
5859 cat > $TMPCXX <<EOF
5860extern "C" {
5861 int c_function(void);
5862}
5863int c_function(void) { return 42; }
5864EOF
5865
5866 update_cxxflags
5867
Paolo Bonzini5770e8a2020-09-23 05:26:15 -04005868 if do_cxx $CXXFLAGS $CONFIGURE_CXXFLAGS $QEMU_CXXFLAGS -o $TMPE $TMPCXX $TMPO $QEMU_LDFLAGS; then
Bruno Dominguez11cde1c2017-06-06 14:07:47 +01005869 # C++ compiler $cxx works ok with C compiler $cc
5870 :
5871 else
5872 echo "C++ compiler $cxx does not work with C compiler $cc"
5873 echo "Disabling C++ specific optional code"
5874 cxx=
5875 fi
5876else
5877 echo "No C++ compiler available; disabling C++ specific optional code"
5878 cxx=
5879fi
5880
Yonggang Luo5d91a2e2020-09-03 01:00:49 +08005881if test $git_update = 'yes' ; then
5882 (cd "${source_path}" && GIT="$git" "./scripts/git-submodule.sh" update "$git_submodules")
5883fi
Yonggang Luo5d91a2e2020-09-03 01:00:49 +08005884
Juan Quintela98ec69a2009-07-16 18:34:18 +02005885config_host_mak="config-host.mak"
bellard97a847b2003-08-10 21:36:04 +00005886
Juan Quintela98ec69a2009-07-16 18:34:18 +02005887echo "# Automatically generated by configure - do not modify" > $config_host_mak
Juan Quintela98ec69a2009-07-16 18:34:18 +02005888echo >> $config_host_mak
Juan Quintela98ec69a2009-07-16 18:34:18 +02005889
Paolo Bonzinie6c3b0f2010-10-21 10:18:35 +02005890echo all: >> $config_host_mak
Daniel P. Berrangecc84d632017-10-20 15:02:43 +01005891echo "GIT=$git" >> $config_host_mak
Daniel P. Berrangeaef45d52017-09-29 11:11:56 +01005892echo "GIT_SUBMODULES=$git_submodules" >> $config_host_mak
Daniel P. Berrangef62bbee2017-10-26 13:52:26 +01005893echo "GIT_UPDATE=$git_update" >> $config_host_mak
Juan Quintela804edf22009-07-27 16:12:49 +02005894
Juan Quintela98ec69a2009-07-16 18:34:18 +02005895echo "ARCH=$ARCH" >> $config_host_mak
Paolo Bonzini727e5282013-04-17 16:26:43 +02005896
Paolo Bonzinif3494742019-01-23 14:56:17 +08005897if test "$default_devices" = "yes" ; then
5898 echo "CONFIG_MINIKCONF_MODE=--defconfig" >> $config_host_mak
5899else
5900 echo "CONFIG_MINIKCONF_MODE=--allnoconfig" >> $config_host_mak
5901fi
aurel32f8393942009-04-13 18:45:38 +00005902if test "$debug_tcg" = "yes" ; then
Juan Quintela2358a492009-07-27 16:13:25 +02005903 echo "CONFIG_DEBUG_TCG=y" >> $config_host_mak
aurel32f8393942009-04-13 18:45:38 +00005904fi
aliguori1625af82009-04-05 17:41:02 +00005905if test "$strip_opt" = "yes" ; then
Hollis Blanchard52ba7842010-08-04 17:21:34 -07005906 echo "STRIP=${strip}" >> $config_host_mak
aliguori1625af82009-04-05 17:41:02 +00005907fi
bellard7d132992003-03-06 23:23:54 +00005908if test "$bigendian" = "yes" ; then
Juan Quintelae2542fe2009-07-27 16:13:06 +02005909 echo "HOST_WORDS_BIGENDIAN=y" >> $config_host_mak
bellard97a847b2003-08-10 21:36:04 +00005910fi
bellard67b915a2004-03-31 23:37:16 +00005911if test "$mingw32" = "yes" ; then
Juan Quintela98ec69a2009-07-16 18:34:18 +02005912 echo "CONFIG_WIN32=y" >> $config_host_mak
Stefan Weil89138852016-05-16 15:10:20 +02005913 rc_version=$(cat $source_path/VERSION)
Blue Swirl9fe6de92010-09-26 16:07:57 +00005914 version_major=${rc_version%%.*}
5915 rc_version=${rc_version#*.}
5916 version_minor=${rc_version%%.*}
5917 rc_version=${rc_version#*.}
5918 version_subminor=${rc_version%%.*}
5919 version_micro=0
5920 echo "CONFIG_FILEVERSION=$version_major,$version_minor,$version_subminor,$version_micro" >> $config_host_mak
5921 echo "CONFIG_PRODUCTVERSION=$version_major,$version_minor,$version_subminor,$version_micro" >> $config_host_mak
Tomoki Sekiyamad9840e22013-08-07 11:40:03 -04005922 if test "$guest_agent_with_vss" = "yes" ; then
5923 echo "CONFIG_QGA_VSS=y" >> $config_host_mak
Michael Rothf33ca812015-08-26 16:19:41 -05005924 echo "QGA_VSS_PROVIDER=$qga_vss_provider" >> $config_host_mak
Tomoki Sekiyamad9840e22013-08-07 11:40:03 -04005925 echo "WIN_SDK=\"$win_sdk\"" >> $config_host_mak
5926 fi
Michael Roth50cbebb2015-07-07 18:10:09 -05005927 if test "$guest_agent_ntddscsi" = "yes" ; then
Tomáš Golembiovský76dc75c2018-10-23 13:23:16 +02005928 echo "CONFIG_QGA_NTDDSCSI=y" >> $config_host_mak
Michael Roth50cbebb2015-07-07 18:10:09 -05005929 fi
Michael Roth1a349042015-08-26 11:14:31 -05005930 if test "$guest_agent_msi" = "yes"; then
Stefan Hajnoczi4bad7c32020-09-14 10:52:31 +01005931 echo "CONFIG_QGA_MSI=y" >> $config_host_mak
Yossi Hindin9dacf322015-05-06 14:57:40 +03005932 echo "QEMU_GA_MSI_MINGW_DLL_PATH=${QEMU_GA_MSI_MINGW_DLL_PATH}" >> $config_host_mak
5933 echo "QEMU_GA_MSI_WITH_VSS=${QEMU_GA_MSI_WITH_VSS}" >> $config_host_mak
5934 echo "QEMU_GA_MSI_ARCH=${QEMU_GA_MSI_ARCH}" >> $config_host_mak
5935 echo "QEMU_GA_MANUFACTURER=${QEMU_GA_MANUFACTURER}" >> $config_host_mak
5936 echo "QEMU_GA_DISTRO=${QEMU_GA_DISTRO}" >> $config_host_mak
5937 echo "QEMU_GA_VERSION=${QEMU_GA_VERSION}" >> $config_host_mak
5938 fi
pbrook210fa552007-02-27 21:04:49 +00005939else
Juan Quintela35f4df22009-07-27 16:13:07 +02005940 echo "CONFIG_POSIX=y" >> $config_host_mak
bellard67b915a2004-03-31 23:37:16 +00005941fi
blueswir1128ab2f2008-08-15 18:33:42 +00005942
Mark McLoughlindffcb712009-10-22 17:49:11 +01005943if test "$linux" = "yes" ; then
5944 echo "CONFIG_LINUX=y" >> $config_host_mak
5945fi
5946
bellard83fb7ad2004-07-05 21:25:26 +00005947if test "$darwin" = "yes" ; then
Juan Quintela98ec69a2009-07-16 18:34:18 +02005948 echo "CONFIG_DARWIN=y" >> $config_host_mak
bellard83fb7ad2004-07-05 21:25:26 +00005949fi
malcb29fe3e2008-11-18 01:42:22 +00005950
bellardec530c82006-04-25 22:36:06 +00005951if test "$solaris" = "yes" ; then
Juan Quintela98ec69a2009-07-16 18:34:18 +02005952 echo "CONFIG_SOLARIS=y" >> $config_host_mak
bellardec530c82006-04-25 22:36:06 +00005953fi
Andreas Färber179cf402010-09-20 00:50:43 +02005954if test "$haiku" = "yes" ; then
5955 echo "CONFIG_HAIKU=y" >> $config_host_mak
5956fi
bellard97a847b2003-08-10 21:36:04 +00005957if test "$static" = "yes" ; then
Juan Quintela98ec69a2009-07-16 18:34:18 +02005958 echo "CONFIG_STATIC=y" >> $config_host_mak
bellard97a847b2003-08-10 21:36:04 +00005959fi
Stefan Weil1ba16962011-07-29 22:40:45 +02005960if test "$profiler" = "yes" ; then
Juan Quintela2358a492009-07-27 16:13:25 +02005961 echo "CONFIG_PROFILER=y" >> $config_host_mak
bellard05c2a3e2006-02-08 22:39:17 +00005962fi
Paolo Bonzinic932ce32019-07-18 12:24:29 +02005963if test "$want_tools" = "yes" ; then
5964 echo "CONFIG_TOOLS=y" >> $config_host_mak
5965fi
Paolo Bonzinif15bff22019-07-18 13:19:02 +02005966if test "$guest_agent" = "yes" ; then
5967 echo "CONFIG_GUEST_AGENT=y" >> $config_host_mak
5968fi
Paolo Bonzini4d34a862020-10-05 11:31:15 +02005969echo "CONFIG_SMBD_COMMAND=\"$smbd\"" >> $config_host_mak
ths8a16d272008-07-19 09:56:24 +00005970if test "$vde" = "yes" ; then
Juan Quintela98ec69a2009-07-16 18:34:18 +02005971 echo "CONFIG_VDE=y" >> $config_host_mak
Fam Zhenge2ad6f12017-09-07 16:35:52 +08005972 echo "VDE_LIBS=$vde_libs" >> $config_host_mak
ths8a16d272008-07-19 09:56:24 +00005973fi
Vincenzo Maffione58952132013-11-06 11:44:06 +01005974if test "$netmap" = "yes" ; then
5975 echo "CONFIG_NETMAP=y" >> $config_host_mak
5976fi
Gonglei015a33b2014-07-01 20:58:08 +08005977if test "$l2tpv3" = "yes" ; then
5978 echo "CONFIG_L2TPV3=y" >> $config_host_mak
5979fi
Paolo Bonzini4cc600d2020-02-04 17:11:04 +01005980if test "$gprof" = "yes" ; then
5981 echo "CONFIG_GPROF=y" >> $config_host_mak
5982fi
Corey Bryant47e98652012-01-26 09:42:26 -05005983if test "$cap_ng" = "yes" ; then
Paolo Bonzinia358bca2019-11-29 11:42:53 +01005984 echo "CONFIG_LIBCAP_NG=y" >> $config_host_mak
Paolo Bonzini3f99cf52020-02-05 09:45:39 +01005985 echo "LIBCAP_NG_LIBS=$cap_libs" >> $config_host_mak
Corey Bryant47e98652012-01-26 09:42:26 -05005986fi
Juan Quintela2358a492009-07-27 16:13:25 +02005987echo "CONFIG_AUDIO_DRIVERS=$audio_drv_list" >> $config_host_mak
malc0c58ac12008-06-25 21:04:05 +00005988for drv in $audio_drv_list; do
Gerd Hoffmann1ef1ec22018-03-01 11:05:46 +01005989 def=CONFIG_AUDIO_$(echo $drv | LC_ALL=C tr '[a-z]' '[A-Z]')
Paolo Bonzini484e2cc2019-12-12 13:30:36 +01005990 echo "$def=y" >> $config_host_mak
malc0c58ac12008-06-25 21:04:05 +00005991done
Paolo Bonzini478e9432020-08-17 12:47:55 +02005992if test "$alsa" = "yes" ; then
5993 echo "CONFIG_ALSA=y" >> $config_host_mak
5994fi
Fam Zhengb1149912017-09-07 16:29:13 +08005995echo "ALSA_LIBS=$alsa_libs" >> $config_host_mak
Paolo Bonzini478e9432020-08-17 12:47:55 +02005996echo "ALSA_CFLAGS=$alsa_cflags" >> $config_host_mak
5997if test "$libpulse" = "yes" ; then
5998 echo "CONFIG_LIBPULSE=y" >> $config_host_mak
5999fi
Fam Zhengb1149912017-09-07 16:29:13 +08006000echo "PULSE_LIBS=$pulse_libs" >> $config_host_mak
Paolo Bonzini478e9432020-08-17 12:47:55 +02006001echo "PULSE_CFLAGS=$pulse_cflags" >> $config_host_mak
Fam Zhengb1149912017-09-07 16:29:13 +08006002echo "COREAUDIO_LIBS=$coreaudio_libs" >> $config_host_mak
6003echo "DSOUND_LIBS=$dsound_libs" >> $config_host_mak
6004echo "OSS_LIBS=$oss_libs" >> $config_host_mak
Paolo Bonzini478e9432020-08-17 12:47:55 +02006005if test "$libjack" = "yes" ; then
6006 echo "CONFIG_LIBJACK=y" >> $config_host_mak
6007fi
Geoffrey McRae2e445702020-04-29 15:53:58 +10006008echo "JACK_LIBS=$jack_libs" >> $config_host_mak
malcd5631632009-10-10 01:13:41 +04006009if test "$audio_win_int" = "yes" ; then
6010 echo "CONFIG_AUDIO_WIN_INT=y" >> $config_host_mak
6011fi
Fam Zhengb64ec4e2013-05-29 19:35:40 +08006012echo "CONFIG_BDRV_RW_WHITELIST=$block_drv_rw_whitelist" >> $config_host_mak
6013echo "CONFIG_BDRV_RO_WHITELIST=$block_drv_ro_whitelist" >> $config_host_mak
Christoph Hellwigdce512d2010-12-17 11:41:15 +01006014if test "$xfs" = "yes" ; then
6015 echo "CONFIG_XFS=y" >> $config_host_mak
6016fi
Stefan Weil89138852016-05-16 15:10:20 +02006017qemu_version=$(head $source_path/VERSION)
Juan Quintela2358a492009-07-27 16:13:25 +02006018echo "PKGVERSION=$pkgversion" >>$config_host_mak
Juan Quintela98ec69a2009-07-16 18:34:18 +02006019echo "SRC_PATH=$source_path" >> $config_host_mak
Alex Bennée2b1f35b2018-07-04 07:30:11 +01006020echo "TARGET_DIRS=$target_list" >> $config_host_mak
Fam Zheng17969262014-02-10 14:48:56 +08006021if test "$modules" = "yes"; then
Fam Zhenge26110c2014-02-10 14:48:57 +08006022 # $shacmd can generate a hash started with digit, which the compiler doesn't
6023 # like as an symbol. So prefix it with an underscore
Stefan Weil89138852016-05-16 15:10:20 +02006024 echo "CONFIG_STAMP=_$( (echo $qemu_version; echo $pkgversion; cat $0) | $shacmd - | cut -f1 -d\ )" >> $config_host_mak
Fam Zheng17969262014-02-10 14:48:56 +08006025 echo "CONFIG_MODULES=y" >> $config_host_mak
6026fi
Christian Ehrhardtbd83c862020-03-10 15:58:06 +01006027if test "$module_upgrades" = "yes"; then
6028 echo "CONFIG_MODULE_UPGRADES=y" >> $config_host_mak
6029fi
Eric Blakee633a5c2019-02-04 20:39:37 -06006030if test "$have_x11" = "yes" && test "$need_x11" = "yes"; then
Gerd Hoffmann87815952018-03-01 11:05:42 +01006031 echo "CONFIG_X11=y" >> $config_host_mak
6032 echo "X11_CFLAGS=$x11_cflags" >> $config_host_mak
6033 echo "X11_LIBS=$x11_libs" >> $config_host_mak
6034fi
Riku Voipio099d6b02009-05-05 12:10:04 +03006035if test "$pipe2" = "yes" ; then
Juan Quintela2358a492009-07-27 16:13:25 +02006036 echo "CONFIG_PIPE2=y" >> $config_host_mak
Riku Voipio099d6b02009-05-05 12:10:04 +03006037fi
Kevin Wolf40ff6d72009-12-02 12:24:42 +01006038if test "$accept4" = "yes" ; then
6039 echo "CONFIG_ACCEPT4=y" >> $config_host_mak
6040fi
vibisreenivasan3ce34df2009-05-16 18:32:41 +05306041if test "$splice" = "yes" ; then
Juan Quintela2358a492009-07-27 16:13:25 +02006042 echo "CONFIG_SPLICE=y" >> $config_host_mak
vibisreenivasan3ce34df2009-05-16 18:32:41 +05306043fi
Riku Voipioc2882b92009-08-12 15:08:24 +03006044if test "$eventfd" = "yes" ; then
6045 echo "CONFIG_EVENTFD=y" >> $config_host_mak
6046fi
Marc-André Lureau751bcc32015-10-09 17:17:16 +02006047if test "$memfd" = "yes" ; then
6048 echo "CONFIG_MEMFD=y" >> $config_host_mak
6049fi
Cortland Tölva955727d2018-10-08 09:35:19 -07006050if test "$have_usbfs" = "yes" ; then
6051 echo "CONFIG_USBFS=y" >> $config_host_mak
6052fi
Ulrich Hechtd0927932009-09-17 20:22:14 +03006053if test "$fallocate" = "yes" ; then
6054 echo "CONFIG_FALLOCATE=y" >> $config_host_mak
6055fi
Kusanagi Kouichi3d4fa432013-01-14 16:26:52 +01006056if test "$fallocate_punch_hole" = "yes" ; then
6057 echo "CONFIG_FALLOCATE_PUNCH_HOLE=y" >> $config_host_mak
6058fi
Denis V. Lunevb953f072015-01-30 11:42:14 +03006059if test "$fallocate_zero_range" = "yes" ; then
6060 echo "CONFIG_FALLOCATE_ZERO_RANGE=y" >> $config_host_mak
6061fi
Kevin Wolfed911432014-09-29 17:12:59 +02006062if test "$posix_fallocate" = "yes" ; then
6063 echo "CONFIG_POSIX_FALLOCATE=y" >> $config_host_mak
6064fi
Peter Maydellc727f472011-01-06 11:05:10 +00006065if test "$sync_file_range" = "yes" ; then
6066 echo "CONFIG_SYNC_FILE_RANGE=y" >> $config_host_mak
6067fi
Peter Maydelldace20d2011-01-10 13:11:24 +00006068if test "$fiemap" = "yes" ; then
6069 echo "CONFIG_FIEMAP=y" >> $config_host_mak
6070fi
Ulrich Hechtd0927932009-09-17 20:22:14 +03006071if test "$dup3" = "yes" ; then
6072 echo "CONFIG_DUP3=y" >> $config_host_mak
6073fi
Alex Bligh4e0c6522013-08-21 16:02:43 +01006074if test "$ppoll" = "yes" ; then
6075 echo "CONFIG_PPOLL=y" >> $config_host_mak
6076fi
Alex Blighcd758dd2013-08-21 16:02:44 +01006077if test "$prctl_pr_set_timerslack" = "yes" ; then
6078 echo "CONFIG_PRCTL_PR_SET_TIMERSLACK=y" >> $config_host_mak
6079fi
Peter Maydell3b6edd12011-02-15 18:35:05 +00006080if test "$epoll" = "yes" ; then
6081 echo "CONFIG_EPOLL=y" >> $config_host_mak
6082fi
6083if test "$epoll_create1" = "yes" ; then
6084 echo "CONFIG_EPOLL_CREATE1=y" >> $config_host_mak
6085fi
Peter Maydella8fd1ab2013-02-08 07:31:55 +00006086if test "$sendfile" = "yes" ; then
6087 echo "CONFIG_SENDFILE=y" >> $config_host_mak
6088fi
Riku Voipio51834342014-06-22 11:25:42 +01006089if test "$timerfd" = "yes" ; then
6090 echo "CONFIG_TIMERFD=y" >> $config_host_mak
6091fi
Riku Voipio9af5c902014-08-12 15:58:57 +03006092if test "$setns" = "yes" ; then
6093 echo "CONFIG_SETNS=y" >> $config_host_mak
6094fi
Aleksandar Markovic38860a02016-10-10 13:23:29 +02006095if test "$clock_adjtime" = "yes" ; then
6096 echo "CONFIG_CLOCK_ADJTIME=y" >> $config_host_mak
6097fi
Aleksandar Markovic5a03cd02016-10-10 13:23:30 +02006098if test "$syncfs" = "yes" ; then
6099 echo "CONFIG_SYNCFS=y" >> $config_host_mak
6100fi
Aleksandar Markovicdb37dd82020-01-16 23:49:49 +01006101if test "$kcov" = "yes" ; then
6102 echo "CONFIG_KCOV=y" >> $config_host_mak
6103fi
Filip Bozutad6092e02020-08-23 21:50:07 +02006104if test "$btrfs" = "yes" ; then
6105 echo "CONFIG_BTRFS=y" >> $config_host_mak
6106fi
aurel323b3f24a2009-04-15 16:12:13 +00006107if test "$inotify" = "yes" ; then
Juan Quintela2358a492009-07-27 16:13:25 +02006108 echo "CONFIG_INOTIFY=y" >> $config_host_mak
aurel323b3f24a2009-04-15 16:12:13 +00006109fi
Riku Voipioc05c7a72010-03-26 15:25:11 +00006110if test "$inotify1" = "yes" ; then
6111 echo "CONFIG_INOTIFY1=y" >> $config_host_mak
6112fi
Peter Maydell401bc052017-09-05 13:19:32 +01006113if test "$sem_timedwait" = "yes" ; then
6114 echo "CONFIG_SEM_TIMEDWAIT=y" >> $config_host_mak
6115fi
Keno Fischer5c99fa32018-06-29 12:32:10 +02006116if test "$strchrnul" = "yes" ; then
6117 echo "HAVE_STRCHRNUL=y" >> $config_host_mak
6118fi
Jiufei Xue8a792b02019-04-17 03:08:56 +08006119if test "$st_atim" = "yes" ; then
6120 echo "HAVE_STRUCT_STAT_ST_ATIM=y" >> $config_host_mak
6121fi
Juan Quintela6ae9a1f2009-08-03 14:45:58 +02006122if test "$byteswap_h" = "yes" ; then
6123 echo "CONFIG_BYTESWAP_H=y" >> $config_host_mak
6124fi
6125if test "$bswap_h" = "yes" ; then
6126 echo "CONFIG_MACHINE_BSWAP_H=y" >> $config_host_mak
6127fi
Alexander Graf769ce762009-05-11 17:41:42 +02006128if test "$curl" = "yes" ; then
Paolo Bonzini484e2cc2019-12-12 13:30:36 +01006129 echo "CONFIG_CURL=y" >> $config_host_mak
Juan Quintelab1d5a272009-08-03 14:46:05 +02006130 echo "CURL_CFLAGS=$curl_cflags" >> $config_host_mak
Fam Zheng6ebc91e2014-02-10 14:48:54 +08006131 echo "CURL_LIBS=$curl_libs" >> $config_host_mak
Alexander Graf769ce762009-05-11 17:41:42 +02006132fi
aurel322e4d9fb2008-04-08 06:01:02 +00006133if test "$brlapi" = "yes" ; then
Juan Quintela98ec69a2009-07-16 18:34:18 +02006134 echo "CONFIG_BRLAPI=y" >> $config_host_mak
Fam Zheng8eca2882017-09-07 16:47:00 +08006135 echo "BRLAPI_LIBS=$brlapi_libs" >> $config_host_mak
aurel322e4d9fb2008-04-08 06:01:02 +00006136fi
Anthony Liguoria4ccabc2013-02-20 07:43:20 -06006137if test "$gtk" = "yes" ; then
Paolo Bonzini484e2cc2019-12-12 13:30:36 +01006138 echo "CONFIG_GTK=y" >> $config_host_mak
Anthony Liguoria4ccabc2013-02-20 07:43:20 -06006139 echo "GTK_CFLAGS=$gtk_cflags" >> $config_host_mak
Gerd Hoffmann014cb152015-12-03 12:56:34 +01006140 echo "GTK_LIBS=$gtk_libs" >> $config_host_mak
Gerd Hoffmann925a0402015-05-26 12:26:21 +02006141 if test "$gtk_gl" = "yes" ; then
6142 echo "CONFIG_GTK_GL=y" >> $config_host_mak
6143 fi
Stefan Weilbbbf9bf2014-02-19 07:04:34 +01006144fi
Marc-André Lureauf876b762019-02-21 12:07:00 +01006145if test "$gio" = "yes" ; then
6146 echo "CONFIG_GIO=y" >> $config_host_mak
6147 echo "GIO_CFLAGS=$gio_cflags" >> $config_host_mak
6148 echo "GIO_LIBS=$gio_libs" >> $config_host_mak
Marc-André Lureau25a97a52019-09-27 11:34:42 +04006149 echo "GDBUS_CODEGEN=$gdbus_codegen" >> $config_host_mak
Marc-André Lureauf876b762019-02-21 12:07:00 +01006150fi
Daniel P. Berrangea1c5e942016-06-06 10:05:06 +01006151echo "CONFIG_TLS_PRIORITY=\"$tls_priority\"" >> $config_host_mak
Daniel P. Berrangeddbb0d02015-07-01 18:10:29 +01006152if test "$gnutls" = "yes" ; then
6153 echo "CONFIG_GNUTLS=y" >> $config_host_mak
Paolo Bonzinia81df1b2020-08-19 08:44:56 -04006154 echo "GNUTLS_CFLAGS=$gnutls_cflags" >> $config_host_mak
6155 echo "GNUTLS_LIBS=$gnutls_libs" >> $config_host_mak
Daniel P. Berrangeddbb0d02015-07-01 18:10:29 +01006156fi
Daniel P. Berrange91bfcdb2015-10-16 16:36:53 +01006157if test "$gcrypt" = "yes" ; then
6158 echo "CONFIG_GCRYPT=y" >> $config_host_mak
Longpeng(Mike)1f923c72016-12-13 18:42:55 +08006159 if test "$gcrypt_hmac" = "yes" ; then
6160 echo "CONFIG_GCRYPT_HMAC=y" >> $config_host_mak
6161 fi
Daniel P. Berrangé46859d92020-09-01 14:30:49 +01006162 echo "GCRYPT_CFLAGS=$gcrypt_cflags" >> $config_host_mak
6163 echo "GCRYPT_LIBS=$gcrypt_libs" >> $config_host_mak
Daniel P. Berrange62893b62015-07-01 18:10:33 +01006164fi
Daniel P. Berrange91bfcdb2015-10-16 16:36:53 +01006165if test "$nettle" = "yes" ; then
6166 echo "CONFIG_NETTLE=y" >> $config_host_mak
Radim Krčmářbecaeb72015-07-10 19:18:00 +02006167 echo "CONFIG_NETTLE_VERSION_MAJOR=${nettle_version%%.*}" >> $config_host_mak
Paolo Bonzinia81df1b2020-08-19 08:44:56 -04006168 echo "NETTLE_CFLAGS=$nettle_cflags" >> $config_host_mak
6169 echo "NETTLE_LIBS=$nettle_libs" >> $config_host_mak
Daniel P. Berrangeed754742015-07-01 18:10:34 +01006170fi
Daniel P. Berrangée0576942019-10-14 17:28:27 +01006171if test "$qemu_private_xts" = "yes" ; then
6172 echo "CONFIG_QEMU_PRIVATE_XTS=y" >> $config_host_mak
6173fi
Daniel P. Berrange9a2fd432015-04-13 14:01:39 +01006174if test "$tasn1" = "yes" ; then
6175 echo "CONFIG_TASN1=y" >> $config_host_mak
6176fi
Daniel P. Berrange8953caf2016-07-27 14:13:56 +01006177if test "$auth_pam" = "yes" ; then
6178 echo "CONFIG_AUTH_PAM=y" >> $config_host_mak
6179fi
Daniel P. Berrange559607e2015-02-27 16:19:33 +00006180if test "$have_ifaddrs_h" = "yes" ; then
6181 echo "HAVE_IFADDRS_H=y" >> $config_host_mak
6182fi
Chen Gange865b972020-06-05 09:32:21 +08006183if test "$have_drm_h" = "yes" ; then
6184 echo "HAVE_DRM_H=y" >> $config_host_mak
6185fi
Eric Blake6b39b062016-10-11 10:46:23 -05006186if test "$have_broken_size_max" = "yes" ; then
6187 echo "HAVE_BROKEN_SIZE_MAX=y" >> $config_host_mak
6188fi
Thomas Huth9df8b202020-06-29 14:13:24 +02006189if test "$have_openpty" = "yes" ; then
6190 echo "HAVE_OPENPTY=y" >> $config_host_mak
6191fi
David CARLIER2a4b4722020-07-13 14:36:09 +01006192if test "$have_sys_signal_h" = "yes" ; then
6193 echo "HAVE_SYS_SIGNAL_H=y" >> $config_host_mak
6194fi
Jan Vesely277abf12016-04-29 13:15:23 -04006195
6196# Work around a system header bug with some kernel/XFS header
6197# versions where they both try to define 'struct fsxattr':
6198# xfs headers will not try to redefine structs from linux headers
6199# if this macro is set.
6200if test "$have_fsxattr" = "yes" ; then
6201 echo "HAVE_FSXATTR=y" >> $config_host_mak
6202fi
Fam Zheng1efad062018-06-01 17:26:43 +08006203if test "$have_copy_file_range" = "yes" ; then
6204 echo "HAVE_COPY_FILE_RANGE=y" >> $config_host_mak
6205fi
Stefan Weilbbbf9bf2014-02-19 07:04:34 +01006206if test "$vte" = "yes" ; then
6207 echo "CONFIG_VTE=y" >> $config_host_mak
Anthony Liguoria4ccabc2013-02-20 07:43:20 -06006208 echo "VTE_CFLAGS=$vte_cflags" >> $config_host_mak
Gerd Hoffmanne0fb1292018-03-01 11:05:44 +01006209 echo "VTE_LIBS=$vte_libs" >> $config_host_mak
Anthony Liguoria4ccabc2013-02-20 07:43:20 -06006210fi
Gerd Hoffmann9d9e1522014-07-11 12:51:43 +02006211if test "$virglrenderer" = "yes" ; then
6212 echo "CONFIG_VIRGL=y" >> $config_host_mak
6213 echo "VIRGL_CFLAGS=$virgl_cflags" >> $config_host_mak
6214 echo "VIRGL_LIBS=$virgl_libs" >> $config_host_mak
6215fi
Paolo Bonzini1badb702020-09-18 04:57:25 -04006216if test "$xen" = "enabled" ; then
Jan Kiszka6dbd5882011-06-21 22:59:07 +02006217 echo "CONFIG_XEN_BACKEND=y" >> $config_host_mak
Anthony PERARDd5b93dd2011-02-25 16:20:34 +00006218 echo "CONFIG_XEN_CTRL_INTERFACE_VERSION=$xen_ctrl_version" >> $config_host_mak
Marc-André Lureau582ea952019-08-15 15:15:32 +04006219 echo "XEN_CFLAGS=$xen_cflags" >> $config_host_mak
6220 echo "XEN_LIBS=$xen_libs" >> $config_host_mak
aliguorie37630c2009-04-22 15:19:10 +00006221fi
Christoph Hellwig5c6c3a62009-08-20 16:58:35 +02006222if test "$linux_aio" = "yes" ; then
6223 echo "CONFIG_LINUX_AIO=y" >> $config_host_mak
6224fi
Aarushi Mehtac10dd852020-01-20 14:18:44 +00006225if test "$linux_io_uring" = "yes" ; then
6226 echo "CONFIG_LINUX_IO_URING=y" >> $config_host_mak
6227 echo "LINUX_IO_URING_CFLAGS=$linux_io_uring_cflags" >> $config_host_mak
6228 echo "LINUX_IO_URING_LIBS=$linux_io_uring_libs" >> $config_host_mak
6229fi
Venkateswararao Jujjuri (JV)758e8e32010-06-14 13:34:41 -07006230if test "$attr" = "yes" ; then
6231 echo "CONFIG_ATTR=y" >> $config_host_mak
Marc-André Lureauec0d5892019-07-15 15:04:49 +04006232 echo "LIBATTR_LIBS=$libattr_libs" >> $config_host_mak
Venkateswararao Jujjuri (JV)758e8e32010-06-14 13:34:41 -07006233fi
Avi Kivity4f26f2b2011-11-09 14:44:52 +02006234if test "$libattr" = "yes" ; then
6235 echo "CONFIG_LIBATTR=y" >> $config_host_mak
6236fi
Meador Inge983eef52012-02-24 14:00:42 +05306237if test "$virtfs" = "yes" ; then
6238 echo "CONFIG_VIRTFS=y" >> $config_host_mak
Venkateswararao Jujjuri (JV)758e8e32010-06-14 13:34:41 -07006239fi
Nicholas Bellinger5e9be922013-03-29 01:08:16 +00006240if test "$vhost_scsi" = "yes" ; then
6241 echo "CONFIG_VHOST_SCSI=y" >> $config_host_mak
6242fi
Paolo Bonziniaf3bba72019-02-14 18:35:52 +01006243if test "$vhost_net" = "yes" ; then
6244 echo "CONFIG_VHOST_NET=y" >> $config_host_mak
6245fi
6246if test "$vhost_net_user" = "yes" ; then
Paolo Bonzini56f41de2019-02-14 18:35:49 +01006247 echo "CONFIG_VHOST_NET_USER=y" >> $config_host_mak
Nikolay Nikolaev03ce5742014-06-10 13:02:16 +03006248fi
Cindy Lu108a6482020-07-01 22:55:37 +08006249if test "$vhost_net_vdpa" = "yes" ; then
6250 echo "CONFIG_VHOST_NET_VDPA=y" >> $config_host_mak
6251fi
Gonglei042cea22018-03-01 21:46:28 +08006252if test "$vhost_crypto" = "yes" ; then
6253 echo "CONFIG_VHOST_CRYPTO=y" >> $config_host_mak
6254fi
Stefan Hajnoczifc0b9b02016-08-16 13:27:22 +01006255if test "$vhost_vsock" = "yes" ; then
6256 echo "CONFIG_VHOST_VSOCK=y" >> $config_host_mak
Stefano Garzarella5fe97d82020-05-22 14:25:11 +02006257 if test "$vhost_user" = "yes" ; then
6258 echo "CONFIG_VHOST_USER_VSOCK=y" >> $config_host_mak
6259 fi
Stefan Hajnoczifc0b9b02016-08-16 13:27:22 +01006260fi
Paolo Bonzini299e6f12019-02-14 18:35:53 +01006261if test "$vhost_kernel" = "yes" ; then
6262 echo "CONFIG_VHOST_KERNEL=y" >> $config_host_mak
6263fi
Marc-André Lureaue6a74862017-08-03 11:07:46 +02006264if test "$vhost_user" = "yes" ; then
6265 echo "CONFIG_VHOST_USER=y" >> $config_host_mak
6266fi
Cindy Lu108a6482020-07-01 22:55:37 +08006267if test "$vhost_vdpa" = "yes" ; then
6268 echo "CONFIG_VHOST_VDPA=y" >> $config_host_mak
6269fi
Dr. David Alan Gilbert98fc1ad2019-09-30 11:51:34 +01006270if test "$vhost_user_fs" = "yes" ; then
6271 echo "CONFIG_VHOST_USER_FS=y" >> $config_host_mak
6272fi
aliguoribf9298b2008-12-05 20:05:26 +00006273if test "$iovec" = "yes" ; then
Juan Quintela2358a492009-07-27 16:13:25 +02006274 echo "CONFIG_IOVEC=y" >> $config_host_mak
aliguoribf9298b2008-12-05 20:05:26 +00006275fi
aliguoriceb42de2009-04-07 18:43:28 +00006276if test "$preadv" = "yes" ; then
Juan Quintela2358a492009-07-27 16:13:25 +02006277 echo "CONFIG_PREADV=y" >> $config_host_mak
aliguoriceb42de2009-04-07 18:43:28 +00006278fi
Paolo Bonzinia40161c2018-02-16 10:05:23 +01006279if test "$membarrier" = "yes" ; then
6280 echo "CONFIG_MEMBARRIER=y" >> $config_host_mak
6281fi
Marcelo Tosattidcc38d12010-10-11 15:31:15 -03006282if test "$signalfd" = "yes" ; then
6283 echo "CONFIG_SIGNALFD=y" >> $config_host_mak
6284fi
Richard W.M. Jonesd339d762019-01-18 10:11:14 +00006285if test "$optreset" = "yes" ; then
6286 echo "HAVE_OPTRESET=y" >> $config_host_mak
6287fi
Paolo Bonzini1badb702020-09-18 04:57:25 -04006288if test "$tcg" = "enabled"; then
Paolo Bonzinib3f6ea72017-07-03 16:59:07 +02006289 if test "$tcg_interpreter" = "yes" ; then
6290 echo "CONFIG_TCG_INTERPRETER=y" >> $config_host_mak
6291 fi
Stefan Weil9195b2c2011-10-19 07:07:18 +02006292fi
Blue Swirl5f6b9e82009-09-20 06:56:26 +00006293if test "$fdatasync" = "yes" ; then
6294 echo "CONFIG_FDATASYNC=y" >> $config_host_mak
6295fi
Andreas Färbere78815a2010-09-25 11:26:05 +00006296if test "$madvise" = "yes" ; then
6297 echo "CONFIG_MADVISE=y" >> $config_host_mak
6298fi
6299if test "$posix_madvise" = "yes" ; then
6300 echo "CONFIG_POSIX_MADVISE=y" >> $config_host_mak
6301fi
Andreas Gustafsson9bc5a712018-01-04 19:39:36 +02006302if test "$posix_memalign" = "yes" ; then
6303 echo "CONFIG_POSIX_MEMALIGN=y" >> $config_host_mak
6304fi
Gerd Hoffmanncd4ec0b2010-03-24 10:26:51 +01006305if test "$spice" = "yes" ; then
6306 echo "CONFIG_SPICE=y" >> $config_host_mak
Paolo Bonzini26347332019-07-29 15:40:07 +02006307 echo "SPICE_CFLAGS=$spice_cflags" >> $config_host_mak
6308 echo "SPICE_LIBS=$spice_libs" >> $config_host_mak
Gerd Hoffmanncd4ec0b2010-03-24 10:26:51 +01006309fi
6310
Marc-André Lureau7b02f542015-08-30 11:48:40 +02006311if test "$smartcard" = "yes" ; then
6312 echo "CONFIG_SMARTCARD=y" >> $config_host_mak
Fam Zheng7b62bf52017-09-07 16:29:16 +08006313 echo "SMARTCARD_CFLAGS=$libcacard_cflags" >> $config_host_mak
6314 echo "SMARTCARD_LIBS=$libcacard_libs" >> $config_host_mak
Robert Relyea111a38b2010-11-28 16:36:38 +02006315fi
6316
Gerd Hoffmann2b2325f2012-11-30 16:02:11 +01006317if test "$libusb" = "yes" ; then
6318 echo "CONFIG_USB_LIBUSB=y" >> $config_host_mak
Fam Zhengb878b652017-09-07 16:29:17 +08006319 echo "LIBUSB_CFLAGS=$libusb_cflags" >> $config_host_mak
6320 echo "LIBUSB_LIBS=$libusb_libs" >> $config_host_mak
Gerd Hoffmann2b2325f2012-11-30 16:02:11 +01006321fi
6322
Hans de Goede69354a82011-07-19 11:04:10 +02006323if test "$usb_redir" = "yes" ; then
6324 echo "CONFIG_USB_REDIR=y" >> $config_host_mak
Fam Zhengcc7923f2017-09-07 16:29:18 +08006325 echo "USB_REDIR_CFLAGS=$usb_redir_cflags" >> $config_host_mak
6326 echo "USB_REDIR_LIBS=$usb_redir_libs" >> $config_host_mak
Hans de Goede69354a82011-07-19 11:04:10 +02006327fi
6328
Gerd Hoffmannda076ff2014-11-20 09:49:44 +01006329if test "$opengl" = "yes" ; then
6330 echo "CONFIG_OPENGL=y" >> $config_host_mak
Paolo Bonzinide2d3002020-09-01 08:41:17 -04006331 echo "OPENGL_CFLAGS=$opengl_cflags" >> $config_host_mak
Gerd Hoffmannda076ff2014-11-20 09:49:44 +01006332 echo "OPENGL_LIBS=$opengl_libs" >> $config_host_mak
Gerd Hoffmann014cb152015-12-03 12:56:34 +01006333 if test "$opengl_dmabuf" = "yes" ; then
6334 echo "CONFIG_OPENGL_DMABUF=y" >> $config_host_mak
6335 fi
Michael Walle20ff0752011-03-07 23:32:39 +01006336fi
6337
Marc-André Lureaud52c4542019-05-24 15:09:42 +02006338if test "$gbm" = "yes" ; then
6339 echo "CONFIG_GBM=y" >> $config_host_mak
6340 echo "GBM_LIBS=$gbm_libs" >> $config_host_mak
6341 echo "GBM_CFLAGS=$gbm_cflags" >> $config_host_mak
6342fi
6343
6344
Liang Li99f2dbd2016-03-08 13:53:16 +08006345if test "$avx2_opt" = "yes" ; then
6346 echo "CONFIG_AVX2_OPT=y" >> $config_host_mak
6347fi
6348
Robert Hoo6b8cd442020-02-29 20:34:34 +08006349if test "$avx512f_opt" = "yes" ; then
6350 echo "CONFIG_AVX512F_OPT=y" >> $config_host_mak
6351fi
6352
qiaonuohan607dacd2014-02-18 14:11:30 +08006353if test "$lzo" = "yes" ; then
6354 echo "CONFIG_LZO=y" >> $config_host_mak
Marc-André Lureau708eab42019-09-03 16:59:33 +04006355 echo "LZO_LIBS=$lzo_libs" >> $config_host_mak
qiaonuohan607dacd2014-02-18 14:11:30 +08006356fi
6357
6358if test "$snappy" = "yes" ; then
6359 echo "CONFIG_SNAPPY=y" >> $config_host_mak
Marc-André Lureau708eab42019-09-03 16:59:33 +04006360 echo "SNAPPY_LIBS=$snappy_libs" >> $config_host_mak
qiaonuohan607dacd2014-02-18 14:11:30 +08006361fi
6362
Peter Wu6b383c02015-01-06 18:48:14 +01006363if test "$bzip2" = "yes" ; then
6364 echo "CONFIG_BZIP2=y" >> $config_host_mak
6365 echo "BZIP2_LIBS=-lbz2" >> $config_host_mak
6366fi
6367
Julio Faracco83bc1f92018-11-05 13:08:04 -02006368if test "$lzfse" = "yes" ; then
6369 echo "CONFIG_LZFSE=y" >> $config_host_mak
6370 echo "LZFSE_LIBS=-llzfse" >> $config_host_mak
6371fi
6372
Juan Quintela3a678482019-12-17 21:15:24 +01006373if test "$zstd" = "yes" ; then
6374 echo "CONFIG_ZSTD=y" >> $config_host_mak
Marc-André Lureau5e5733e2019-08-29 22:34:43 +04006375 echo "ZSTD_CFLAGS=$zstd_cflags" >> $config_host_mak
6376 echo "ZSTD_LIBS=$zstd_libs" >> $config_host_mak
Juan Quintela3a678482019-12-17 21:15:24 +01006377fi
6378
Ronnie Sahlbergc589b242011-10-25 19:24:24 +11006379if test "$libiscsi" = "yes" ; then
Paolo Bonzini484e2cc2019-12-12 13:30:36 +01006380 echo "CONFIG_LIBISCSI=y" >> $config_host_mak
Fam Zheng6ebc91e2014-02-10 14:48:54 +08006381 echo "LIBISCSI_CFLAGS=$libiscsi_cflags" >> $config_host_mak
6382 echo "LIBISCSI_LIBS=$libiscsi_libs" >> $config_host_mak
Ronnie Sahlbergc589b242011-10-25 19:24:24 +11006383fi
6384
Peter Lieven6542aa92014-02-03 10:26:13 +01006385if test "$libnfs" = "yes" ; then
Paolo Bonzini484e2cc2019-12-12 13:30:36 +01006386 echo "CONFIG_LIBNFS=y" >> $config_host_mak
Colin Lord4be48792016-08-12 09:27:04 -04006387 echo "LIBNFS_LIBS=$libnfs_libs" >> $config_host_mak
Peter Lieven6542aa92014-02-03 10:26:13 +01006388fi
6389
Eduardo Otubof7945732012-08-14 18:44:05 -03006390if test "$seccomp" = "yes"; then
6391 echo "CONFIG_SECCOMP=y" >> $config_host_mak
Fam Zhengc3883e12017-09-07 16:53:16 +08006392 echo "SECCOMP_CFLAGS=$seccomp_cflags" >> $config_host_mak
6393 echo "SECCOMP_LIBS=$seccomp_libs" >> $config_host_mak
Eduardo Otubof7945732012-08-14 18:44:05 -03006394fi
6395
bellard83fb7ad2004-07-05 21:25:26 +00006396# XXX: suppress that
bellard7d3505c2004-05-12 19:32:15 +00006397if [ "$bsd" = "yes" ] ; then
Juan Quintela2358a492009-07-27 16:13:25 +02006398 echo "CONFIG_BSD=y" >> $config_host_mak
bellard7d3505c2004-05-12 19:32:15 +00006399fi
6400
Paolo Bonzini3556c232013-05-10 14:16:40 +02006401if test "$qom_cast_debug" = "yes" ; then
6402 echo "CONFIG_QOM_CAST_DEBUG=y" >> $config_host_mak
6403fi
Christian Brunnerf27aaf42010-12-06 20:53:01 +01006404if test "$rbd" = "yes" ; then
Paolo Bonzini484e2cc2019-12-12 13:30:36 +01006405 echo "CONFIG_RBD=y" >> $config_host_mak
Fam Zheng6ebc91e2014-02-10 14:48:54 +08006406 echo "RBD_LIBS=$rbd_libs" >> $config_host_mak
Christian Brunnerf27aaf42010-12-06 20:53:01 +01006407fi
Anthony Liguori20ff6c82009-12-09 12:59:36 -06006408
Peter Maydell7c2acc72013-04-08 12:11:27 +01006409echo "CONFIG_COROUTINE_BACKEND=$coroutine" >> $config_host_mak
Stefan Hajnoczi70c60c02013-09-11 16:42:35 +02006410if test "$coroutine_pool" = "yes" ; then
6411 echo "CONFIG_COROUTINE_POOL=1" >> $config_host_mak
6412else
6413 echo "CONFIG_COROUTINE_POOL=0" >> $config_host_mak
6414fi
Aneesh Kumar K.Vd0e2fce2011-06-09 23:11:06 +05306415
Peter Lieven7d992e42016-09-27 11:58:45 +02006416if test "$debug_stack_usage" = "yes" ; then
6417 echo "CONFIG_DEBUG_STACK_USAGE=y" >> $config_host_mak
6418fi
6419
Longpeng(Mike)f0d92b52017-07-14 14:04:05 -04006420if test "$crypto_afalg" = "yes" ; then
6421 echo "CONFIG_AF_ALG=y" >> $config_host_mak
6422fi
6423
Aneesh Kumar K.Vd2042372011-10-12 19:11:24 +05306424if test "$open_by_handle_at" = "yes" ; then
6425 echo "CONFIG_OPEN_BY_HANDLE=y" >> $config_host_mak
6426fi
6427
Harsh Prateek Borae06a7652011-10-12 19:11:25 +05306428if test "$linux_magic_h" = "yes" ; then
6429 echo "CONFIG_LINUX_MAGIC_H=y" >> $config_host_mak
6430fi
6431
Kevin Wolf3f4349d2012-06-29 13:40:27 +02006432if test "$valgrind_h" = "yes" ; then
6433 echo "CONFIG_VALGRIND_H=y" >> $config_host_mak
6434fi
6435
Marc-André Lureaud83414e2018-01-16 16:11:52 +01006436if test "$have_asan_iface_fiber" = "yes" ; then
6437 echo "CONFIG_ASAN_IFACE_FIBER=y" >> $config_host_mak
6438fi
6439
Lingfeng Yang0aebab02020-06-12 20:02:23 +01006440if test "$have_tsan" = "yes" && test "$have_tsan_iface_fiber" = "yes" ; then
6441 echo "CONFIG_TSAN=y" >> $config_host_mak
6442fi
6443
Luiz Capitulino8ab1bf12012-05-23 15:48:04 -03006444if test "$has_environ" = "yes" ; then
6445 echo "CONFIG_HAS_ENVIRON=y" >> $config_host_mak
6446fi
6447
Richard Henderson76a347e2012-12-28 14:17:02 -08006448if test "$cpuid_h" = "yes" ; then
6449 echo "CONFIG_CPUID_H=y" >> $config_host_mak
6450fi
6451
Richard Hendersonf5401662013-02-16 12:46:59 -08006452if test "$int128" = "yes" ; then
6453 echo "CONFIG_INT128=y" >> $config_host_mak
6454fi
6455
Richard Henderson7ebee432016-06-29 21:10:59 -07006456if test "$atomic128" = "yes" ; then
6457 echo "CONFIG_ATOMIC128=y" >> $config_host_mak
6458fi
6459
Richard Hendersone6cd4bb2018-08-15 16:31:47 -07006460if test "$cmpxchg128" = "yes" ; then
6461 echo "CONFIG_CMPXCHG128=y" >> $config_host_mak
6462fi
6463
Richard Hendersondf79b992016-09-02 12:23:57 -07006464if test "$atomic64" = "yes" ; then
6465 echo "CONFIG_ATOMIC64=y" >> $config_host_mak
6466fi
6467
Richard Hendersondb8aaae2019-10-13 16:12:19 -07006468if test "$attralias" = "yes" ; then
6469 echo "CONFIG_ATTRIBUTE_ALIAS=y" >> $config_host_mak
6470fi
6471
Richard Henderson1e6e9ac2013-02-18 09:11:15 -08006472if test "$getauxval" = "yes" ; then
6473 echo "CONFIG_GETAUXVAL=y" >> $config_host_mak
6474fi
6475
Bharata B Raoeb100392012-09-24 14:42:45 +05306476if test "$glusterfs" = "yes" ; then
Paolo Bonzini484e2cc2019-12-12 13:30:36 +01006477 echo "CONFIG_GLUSTERFS=y" >> $config_host_mak
Fam Zheng6ebc91e2014-02-10 14:48:54 +08006478 echo "GLUSTERFS_CFLAGS=$glusterfs_cflags" >> $config_host_mak
6479 echo "GLUSTERFS_LIBS=$glusterfs_libs" >> $config_host_mak
Bharata B Raoeb100392012-09-24 14:42:45 +05306480fi
6481
Jeff Codyd85fa9e2016-04-05 10:40:09 -04006482if test "$glusterfs_xlator_opt" = "yes" ; then
6483 echo "CONFIG_GLUSTERFS_XLATOR_OPT=y" >> $config_host_mak
6484fi
6485
Bharata B Rao0c14fb42013-07-16 21:47:42 +05306486if test "$glusterfs_discard" = "yes" ; then
6487 echo "CONFIG_GLUSTERFS_DISCARD=y" >> $config_host_mak
6488fi
6489
Niels de Vosdf3a4292017-05-28 12:01:14 +05306490if test "$glusterfs_fallocate" = "yes" ; then
6491 echo "CONFIG_GLUSTERFS_FALLOCATE=y" >> $config_host_mak
6492fi
6493
Bharata B Rao7c815372013-12-21 14:51:25 +05306494if test "$glusterfs_zerofill" = "yes" ; then
6495 echo "CONFIG_GLUSTERFS_ZEROFILL=y" >> $config_host_mak
6496fi
6497
Prasanna Kumar Kalevere014dbe2019-03-05 16:46:33 +01006498if test "$glusterfs_ftruncate_has_stat" = "yes" ; then
6499 echo "CONFIG_GLUSTERFS_FTRUNCATE_HAS_STAT=y" >> $config_host_mak
6500fi
6501
Niels de Vos0e3b8912019-03-05 16:46:34 +01006502if test "$glusterfs_iocb_has_stat" = "yes" ; then
6503 echo "CONFIG_GLUSTERFS_IOCB_HAS_STAT=y" >> $config_host_mak
6504fi
6505
Pino Toscanob10d49d2019-06-20 22:08:40 +02006506if test "$libssh" = "yes" ; then
Paolo Bonzini484e2cc2019-12-12 13:30:36 +01006507 echo "CONFIG_LIBSSH=y" >> $config_host_mak
Pino Toscanob10d49d2019-06-20 22:08:40 +02006508 echo "LIBSSH_CFLAGS=$libssh_cflags" >> $config_host_mak
6509 echo "LIBSSH_LIBS=$libssh_libs" >> $config_host_mak
Richard W.M. Jones0a12ec82013-04-09 15:30:53 +01006510fi
6511
Dr. David Alan Gilberted1701c2017-05-15 15:05:29 +01006512if test "$live_block_migration" = "yes" ; then
6513 echo "CONFIG_LIVE_BLOCK_MIGRATION=y" >> $config_host_mak
6514fi
6515
Paolo Bonzini3b8acc12013-03-18 16:37:50 +01006516if test "$tpm" = "yes"; then
Paolo Bonzini3cae16d2019-07-11 19:08:36 +02006517 echo 'CONFIG_TPM=y' >> $config_host_mak
Paolo Bonzini3b8acc12013-03-18 16:37:50 +01006518fi
6519
Lluís Vilanova5b808272014-05-27 15:02:14 +02006520echo "TRACE_BACKENDS=$trace_backends" >> $config_host_mak
6521if have_backend "nop"; then
Lluís6d8a7642011-08-31 20:30:43 +02006522 echo "CONFIG_TRACE_NOP=y" >> $config_host_mak
Prerna Saxena22890ab2010-06-24 17:04:53 +05306523fi
Lluís Vilanova5b808272014-05-27 15:02:14 +02006524if have_backend "simple"; then
Lluís6d8a7642011-08-31 20:30:43 +02006525 echo "CONFIG_TRACE_SIMPLE=y" >> $config_host_mak
6526 # Set the appropriate trace file.
Andreas Färber953ffe02011-06-02 19:58:06 +02006527 trace_file="\"$trace_file-\" FMT_pid"
Prerna Saxena9410b562010-07-13 09:26:32 +01006528fi
Paolo Bonzinied7f5f12016-01-07 16:55:30 +03006529if have_backend "log"; then
6530 echo "CONFIG_TRACE_LOG=y" >> $config_host_mak
Lluís6d8a7642011-08-31 20:30:43 +02006531fi
Lluís Vilanova5b808272014-05-27 15:02:14 +02006532if have_backend "ust"; then
Lluís6d8a7642011-08-31 20:30:43 +02006533 echo "CONFIG_TRACE_UST=y" >> $config_host_mak
Paolo Bonzinia81df1b2020-08-19 08:44:56 -04006534 echo "LTTNG_UST_LIBS=$lttng_ust_libs" >> $config_host_mak
6535 echo "URCU_BP_LIBS=$urcu_bp_libs" >> $config_host_mak
Lluís6d8a7642011-08-31 20:30:43 +02006536fi
Lluís Vilanova5b808272014-05-27 15:02:14 +02006537if have_backend "dtrace"; then
Lluís6d8a7642011-08-31 20:30:43 +02006538 echo "CONFIG_TRACE_DTRACE=y" >> $config_host_mak
6539 if test "$trace_backend_stap" = "yes" ; then
6540 echo "CONFIG_TRACE_SYSTEMTAP=y" >> $config_host_mak
6541 fi
Daniel P. Berrangec276b172010-11-12 13:20:25 +00006542fi
Lluís Vilanova5b808272014-05-27 15:02:14 +02006543if have_backend "ftrace"; then
Eiichi Tsukata781e9542013-04-11 20:25:15 +09006544 if test "$linux" = "yes" ; then
6545 echo "CONFIG_TRACE_FTRACE=y" >> $config_host_mak
Eiichi Tsukata781e9542013-04-11 20:25:15 +09006546 else
Stewart Smith21684af2014-01-24 12:39:10 +11006547 feature_not_found "ftrace(trace backend)" "ftrace requires Linux"
Eiichi Tsukata781e9542013-04-11 20:25:15 +09006548 fi
6549fi
Paul Durrant0a852412016-08-04 14:44:14 +01006550if have_backend "syslog"; then
6551 if test "$posix_syslog" = "yes" ; then
6552 echo "CONFIG_TRACE_SYSLOG=y" >> $config_host_mak
6553 else
6554 feature_not_found "syslog(trace backend)" "syslog not available"
6555 fi
6556fi
Prerna Saxena9410b562010-07-13 09:26:32 +01006557echo "CONFIG_TRACE_FILE=$trace_file" >> $config_host_mak
6558
Michael R. Hines2da776d2013-07-22 10:01:54 -04006559if test "$rdma" = "yes" ; then
6560 echo "CONFIG_RDMA=y" >> $config_host_mak
Fam Zheng392fb642017-09-07 16:42:30 +08006561 echo "RDMA_LIBS=$rdma_libs" >> $config_host_mak
Michael R. Hines2da776d2013-07-22 10:01:54 -04006562fi
6563
Marcel Apfelbaum21ab34c2018-08-16 18:16:37 +03006564if test "$pvrdma" = "yes" ; then
6565 echo "CONFIG_PVRDMA=y" >> $config_host_mak
6566fi
6567
Laurent Vivier575b22b2016-06-02 22:14:15 +02006568if test "$have_rtnetlink" = "yes" ; then
6569 echo "CONFIG_RTNETLINK=y" >> $config_host_mak
6570fi
6571
Klim Kireeved279a02018-01-12 12:01:19 +03006572if test "$libxml2" = "yes" ; then
6573 echo "CONFIG_LIBXML2=y" >> $config_host_mak
6574 echo "LIBXML2_CFLAGS=$libxml2_cflags" >> $config_host_mak
6575 echo "LIBXML2_LIBS=$libxml2_libs" >> $config_host_mak
6576fi
6577
Changlong Xiea6b1d4c2016-07-27 15:01:48 +08006578if test "$replication" = "yes" ; then
6579 echo "CONFIG_REPLICATION=y" >> $config_host_mak
6580fi
6581
Stefan Hajnoczi6a02c802016-10-14 10:00:55 +01006582if test "$have_af_vsock" = "yes" ; then
6583 echo "CONFIG_AF_VSOCK=y" >> $config_host_mak
6584fi
6585
Christopher Covington4d043512016-12-28 15:04:33 -05006586if test "$have_sysmacros" = "yes" ; then
6587 echo "CONFIG_SYSMACROS=y" >> $config_host_mak
6588fi
6589
Andreas Grapentin49e00a12017-03-14 17:59:53 +01006590if test "$have_static_assert" = "yes" ; then
6591 echo "CONFIG_STATIC_ASSERT=y" >> $config_host_mak
6592fi
6593
Tomáš Golembiovskýe6746052017-07-17 15:58:33 +02006594if test "$have_utmpx" = "yes" ; then
6595 echo "HAVE_UTMPX=y" >> $config_host_mak
6596fi
Richard Hendersondb1ed1a2019-03-13 20:57:28 -07006597if test "$have_getrandom" = "yes" ; then
6598 echo "CONFIG_GETRANDOM=y" >> $config_host_mak
6599fi
Kamil Rytarowskie0580342017-07-14 09:33:44 +01006600if test "$ivshmem" = "yes" ; then
6601 echo "CONFIG_IVSHMEM=y" >> $config_host_mak
6602fi
Paolo Bonziniba59fb72018-06-13 14:23:08 +02006603if test "$debug_mutex" = "yes" ; then
6604 echo "CONFIG_DEBUG_MUTEX=y" >> $config_host_mak
6605fi
Kamil Rytarowskie0580342017-07-14 09:33:44 +01006606
Dr. David Alan Gilbert5c312072014-03-12 11:48:18 +00006607# Hold two types of flag:
6608# CONFIG_THREAD_SETNAME_BYTHREAD - we've got a way of setting the name on
6609# a thread we have a handle to
Roman Bolshakov479a5742018-12-17 23:26:01 +03006610# CONFIG_PTHREAD_SETNAME_NP_W_TID - A way of doing it on a particular
Dr. David Alan Gilbert5c312072014-03-12 11:48:18 +00006611# platform
Roman Bolshakov479a5742018-12-17 23:26:01 +03006612if test "$pthread_setname_np_w_tid" = "yes" ; then
Dr. David Alan Gilbert5c312072014-03-12 11:48:18 +00006613 echo "CONFIG_THREAD_SETNAME_BYTHREAD=y" >> $config_host_mak
Roman Bolshakov479a5742018-12-17 23:26:01 +03006614 echo "CONFIG_PTHREAD_SETNAME_NP_W_TID=y" >> $config_host_mak
6615elif test "$pthread_setname_np_wo_tid" = "yes" ; then
6616 echo "CONFIG_THREAD_SETNAME_BYTHREAD=y" >> $config_host_mak
6617 echo "CONFIG_PTHREAD_SETNAME_NP_WO_TID=y" >> $config_host_mak
Dr. David Alan Gilbert5c312072014-03-12 11:48:18 +00006618fi
6619
Junyan He17824402018-07-18 15:47:59 +08006620if test "$libpmem" = "yes" ; then
6621 echo "CONFIG_LIBPMEM=y" >> $config_host_mak
Marc-André Lureauc9322ab2019-08-18 19:51:17 +04006622 echo "LIBPMEM_LIBS=$libpmem_libs" >> $config_host_mak
6623 echo "LIBPMEM_CFLAGS=$libpmem_cflags" >> $config_host_mak
Junyan He17824402018-07-18 15:47:59 +08006624fi
6625
Jingqi Liu21b2eca2020-04-29 16:50:11 +08006626if test "$libdaxctl" = "yes" ; then
6627 echo "CONFIG_LIBDAXCTL=y" >> $config_host_mak
Bruce Rogersc7c91a72020-08-24 09:52:12 -06006628 echo "LIBDAXCTL_LIBS=$libdaxctl_libs" >> $config_host_mak
Jingqi Liu21b2eca2020-04-29 16:50:11 +08006629fi
6630
Jeff Cody2f740132018-11-07 07:36:44 +01006631if test "$bochs" = "yes" ; then
6632 echo "CONFIG_BOCHS=y" >> $config_host_mak
6633fi
6634if test "$cloop" = "yes" ; then
6635 echo "CONFIG_CLOOP=y" >> $config_host_mak
6636fi
6637if test "$dmg" = "yes" ; then
6638 echo "CONFIG_DMG=y" >> $config_host_mak
6639fi
6640if test "$qcow1" = "yes" ; then
6641 echo "CONFIG_QCOW1=y" >> $config_host_mak
6642fi
6643if test "$vdi" = "yes" ; then
6644 echo "CONFIG_VDI=y" >> $config_host_mak
6645fi
6646if test "$vvfat" = "yes" ; then
6647 echo "CONFIG_VVFAT=y" >> $config_host_mak
6648fi
6649if test "$qed" = "yes" ; then
6650 echo "CONFIG_QED=y" >> $config_host_mak
6651fi
6652if test "$parallels" = "yes" ; then
6653 echo "CONFIG_PARALLELS=y" >> $config_host_mak
6654fi
6655if test "$sheepdog" = "yes" ; then
Daniel P. Berrangée1c42692020-10-02 12:32:43 +01006656 add_to deprecated_features "sheepdog"
Jeff Cody2f740132018-11-07 07:36:44 +01006657 echo "CONFIG_SHEEPDOG=y" >> $config_host_mak
6658fi
David CARLIERc9c8b882020-07-13 14:36:09 +01006659if test "$pty_h" = "yes" ; then
6660 echo "HAVE_PTY_H=y" >> $config_host_mak
6661fi
David CARLIER195588c2020-07-13 14:36:09 +01006662if test "$have_mlockall" = "yes" ; then
6663 echo "HAVE_MLOCKALL=y" >> $config_host_mak
6664fi
Alexander Bulekovadc28022020-02-19 23:11:14 -05006665if test "$fuzzing" = "yes" ; then
Alexander Bulekov54c9e412020-09-02 13:36:51 -04006666 # If LIB_FUZZING_ENGINE is set, assume we are running on OSS-Fuzz, and the
6667 # needed CFLAGS have already been provided
6668 if test -z "${LIB_FUZZING_ENGINE+xxx}" ; then
6669 QEMU_CFLAGS="$QEMU_CFLAGS -fsanitize=fuzzer-no-link"
6670 FUZZ_EXE_LDFLAGS="-fsanitize=fuzzer"
6671 else
6672 FUZZ_EXE_LDFLAGS="$LIB_FUZZING_ENGINE"
6673 fi
Alexander Bulekovadc28022020-02-19 23:11:14 -05006674fi
Jeff Cody2f740132018-11-07 07:36:44 +01006675
Alex Bennée40e8c6f2019-06-13 14:52:25 +01006676if test "$plugins" = "yes" ; then
6677 echo "CONFIG_PLUGIN=y" >> $config_host_mak
Emilio G. Cota26fffe22018-10-21 13:56:29 -04006678 # Copy the export object list to the build dir
6679 if test "$ld_dynamic_list" = "yes" ; then
6680 echo "CONFIG_HAS_LD_DYNAMIC_LIST=yes" >> $config_host_mak
6681 ld_symbols=qemu-plugins-ld.symbols
6682 cp "$source_path/plugins/qemu-plugins.symbols" $ld_symbols
6683 elif test "$ld_exported_symbols_list" = "yes" ; then
6684 echo "CONFIG_HAS_LD_EXPORTED_SYMBOLS_LIST=yes" >> $config_host_mak
6685 ld64_symbols=qemu-plugins-ld64.symbols
6686 echo "# Automatically generated by configure - do not modify" > $ld64_symbols
6687 grep 'qemu_' "$source_path/plugins/qemu-plugins.symbols" | sed 's/;//g' | \
6688 sed -E 's/^[[:space:]]*(.*)/_\1/' >> $ld64_symbols
6689 else
6690 error_exit \
6691 "If \$plugins=yes, either \$ld_dynamic_list or " \
6692 "\$ld_exported_symbols_list should have been set to 'yes'."
6693 fi
Alex Bennée40e8c6f2019-06-13 14:52:25 +01006694fi
6695
Alex Bennéef48e5902020-03-16 17:21:48 +00006696if test -n "$gdb_bin" ; then
6697 echo "HAVE_GDB_BIN=$gdb_bin" >> $config_host_mak
6698fi
6699
Alexey Krasikov54e7aac2020-05-25 14:19:12 +03006700if test "$secret_keyring" = "yes" ; then
6701 echo "CONFIG_SECRET_KEYRING=y" >> $config_host_mak
6702fi
6703
Juan Quintela98ec69a2009-07-16 18:34:18 +02006704echo "ROMS=$roms" >> $config_host_mak
Juan Quintela804edf22009-07-27 16:12:49 +02006705echo "MAKE=$make" >> $config_host_mak
Blue Swirlc886edf2011-07-22 21:08:09 +00006706echo "PYTHON=$python" >> $config_host_mak
Alex Bennée39d87c82020-03-03 15:06:20 +00006707echo "GENISOIMAGE=$genisoimage" >> $config_host_mak
Paolo Bonzinia5665052019-06-10 12:05:14 +02006708echo "MESON=$meson" >> $config_host_mak
Paolo Bonzini09e93322020-08-13 09:28:11 -04006709echo "NINJA=$ninja" >> $config_host_mak
Juan Quintela804edf22009-07-27 16:12:49 +02006710echo "CC=$cc" >> $config_host_mak
Michael S. Tsirkina31a8642013-07-24 18:56:03 +03006711if $iasl -h > /dev/null 2>&1; then
Paolo Bonzini859aef02020-08-04 18:14:26 +02006712 echo "CONFIG_IASL=$iasl" >> $config_host_mak
Michael S. Tsirkina31a8642013-07-24 18:56:03 +03006713fi
Tomoki Sekiyama83f73fc2013-08-07 11:39:36 -04006714echo "CXX=$cxx" >> $config_host_mak
Peter Maydell3c4a4d02012-08-11 22:34:40 +01006715echo "OBJCC=$objcc" >> $config_host_mak
Juan Quintela804edf22009-07-27 16:12:49 +02006716echo "AR=$ar" >> $config_host_mak
Peter Maydell45d285a2013-10-21 21:03:06 +01006717echo "ARFLAGS=$ARFLAGS" >> $config_host_mak
Richard Hendersoncdbd7272016-07-07 21:49:36 -07006718echo "AS=$as" >> $config_host_mak
Richard Henderson5f6f0e22016-06-23 10:39:18 -07006719echo "CCAS=$ccas" >> $config_host_mak
Blue Swirl3dd46c72013-01-05 10:10:27 +00006720echo "CPP=$cpp" >> $config_host_mak
Juan Quintela804edf22009-07-27 16:12:49 +02006721echo "OBJCOPY=$objcopy" >> $config_host_mak
6722echo "LD=$ld" >> $config_host_mak
Alistair Francis9f81aeb2017-11-07 17:10:46 -08006723echo "RANLIB=$ranlib" >> $config_host_mak
Stefan Weil4852ee92014-09-18 21:55:08 +02006724echo "NM=$nm" >> $config_host_mak
Alex Bennéedaa79d92019-09-19 14:07:36 +01006725echo "PKG_CONFIG=$pkg_config_exe" >> $config_host_mak
Blue Swirl9fe6de92010-09-26 16:07:57 +00006726echo "WINDRES=$windres" >> $config_host_mak
Brad46eef332013-12-10 19:49:08 -05006727echo "CFLAGS_NOPIE=$CFLAGS_NOPIE" >> $config_host_mak
Juan Quintelaa558ee12009-08-03 14:46:21 +02006728echo "QEMU_CFLAGS=$QEMU_CFLAGS" >> $config_host_mak
Bruno Dominguez11cde1c2017-06-06 14:07:47 +01006729echo "QEMU_CXXFLAGS=$QEMU_CXXFLAGS" >> $config_host_mak
Paolo Bonzinia81df1b2020-08-19 08:44:56 -04006730echo "GLIB_CFLAGS=$glib_cflags" >> $config_host_mak
6731echo "GLIB_LIBS=$glib_libs" >> $config_host_mak
Philippe Mathieu-Daudé8a99e9a2018-04-15 20:05:19 -03006732echo "QEMU_LDFLAGS=$QEMU_LDFLAGS" >> $config_host_mak
Paolo Bonzinidb5adea2019-12-11 15:34:27 +01006733echo "LDFLAGS_NOPIE=$LDFLAGS_NOPIE" >> $config_host_mak
Peter Maydelle57218b2016-08-08 17:11:28 +01006734echo "LD_I386_EMULATION=$ld_i386_emulation" >> $config_host_mak
Juan Quintela804edf22009-07-27 16:12:49 +02006735echo "EXESUF=$EXESUF" >> $config_host_mak
Paolo Bonzini484e2cc2019-12-12 13:30:36 +01006736echo "HOST_DSOSUF=$HOST_DSOSUF" >> $config_host_mak
Paolo Bonzinif15bff22019-07-18 13:19:02 +02006737echo "LIBS_QGA=$libs_qga" >> $config_host_mak
Daniel P. Berrange90246032015-09-21 17:25:34 +01006738echo "TASN1_LIBS=$tasn1_libs" >> $config_host_mak
6739echo "TASN1_CFLAGS=$tasn1_cflags" >> $config_host_mak
Blue Swirl1d728c32012-05-01 18:45:39 +00006740if test "$gcov" = "yes" ; then
6741 echo "CONFIG_GCOV=y" >> $config_host_mak
Blue Swirl1d728c32012-05-01 18:45:39 +00006742fi
Juan Quintela804edf22009-07-27 16:12:49 +02006743
Alexander Bulekovadc28022020-02-19 23:11:14 -05006744if test "$fuzzing" != "no"; then
6745 echo "CONFIG_FUZZ=y" >> $config_host_mak
Alexander Bulekovadc28022020-02-19 23:11:14 -05006746fi
Alexander Bulekov54c9e412020-09-02 13:36:51 -04006747echo "FUZZ_EXE_LDFLAGS=$FUZZ_EXE_LDFLAGS" >> $config_host_mak
Tomáš Golembiovský3efac6e2018-10-23 13:23:10 +02006748
Marek Marczykowski-Góreckib767d252020-05-20 15:20:23 +02006749if test "$rng_none" = "yes"; then
6750 echo "CONFIG_RNG_NONE=y" >> $config_host_mak
6751fi
6752
Peter Maydell6efd7512011-11-30 11:59:04 +00006753# use included Linux headers
6754if test "$linux" = "yes" ; then
Andreas Färbera307beb2012-06-14 15:14:33 +00006755 mkdir -p linux-headers
Peter Maydell6efd7512011-11-30 11:59:04 +00006756 case "$cpu" in
Richard Hendersonc72b26e2013-08-20 12:20:05 -07006757 i386|x86_64|x32)
Peter Maydell08312a62012-08-03 13:51:25 +01006758 linux_arch=x86
Peter Maydell6efd7512011-11-30 11:59:04 +00006759 ;;
Richard Hendersonf8378ac2019-05-01 15:38:18 -07006760 ppc|ppc64|ppc64le)
Peter Maydell08312a62012-08-03 13:51:25 +01006761 linux_arch=powerpc
Peter Maydell6efd7512011-11-30 11:59:04 +00006762 ;;
6763 s390x)
Peter Maydell08312a62012-08-03 13:51:25 +01006764 linux_arch=s390
6765 ;;
Claudio Fontana1f080312013-06-12 16:20:23 +01006766 aarch64)
6767 linux_arch=arm64
6768 ;;
Sanjay Lal222e7d12014-06-17 23:10:36 +01006769 mips64)
6770 linux_arch=mips
6771 ;;
Peter Maydell08312a62012-08-03 13:51:25 +01006772 *)
6773 # For most CPUs the kernel architecture name and QEMU CPU name match.
6774 linux_arch="$cpu"
Peter Maydell6efd7512011-11-30 11:59:04 +00006775 ;;
6776 esac
Peter Maydell08312a62012-08-03 13:51:25 +01006777 # For non-KVM architectures we will not have asm headers
6778 if [ -e "$source_path/linux-headers/asm-$linux_arch" ]; then
6779 symlink "$source_path/linux-headers/asm-$linux_arch" linux-headers/asm
6780 fi
Peter Maydell6efd7512011-11-30 11:59:04 +00006781fi
6782
bellard1d14ffa2005-10-30 18:58:22 +00006783for target in $target_list; do
Paolo Bonzinifdb75ae2020-09-21 04:37:49 -04006784 target_dir="$target"
6785 target_name=$(echo $target | cut -d '-' -f 1)
6786 mkdir -p $target_dir
6787 case $target in
6788 *-user) symlink "../qemu-$target_name" "$target_dir/qemu-$target_name" ;;
6789 *) symlink "../qemu-system-$target_name" "$target_dir/qemu-system-$target_name" ;;
6790 esac
6791done
bellard7d132992003-03-06 23:23:54 +00006792
Paolo Bonzini765686d2020-09-18 06:37:21 -04006793echo "CONFIG_QEMU_INTERP_PREFIX=$interp_prefix" | sed 's/%M/@0@/' >> $config_host_mak
Paolo Bonzinifdb75ae2020-09-21 04:37:49 -04006794if test "$default_targets" = "yes"; then
6795 echo "CONFIG_DEFAULT_TARGETS=y" >> $config_host_mak
6796fi
Peter Crosthwaitea540f152013-04-18 14:47:31 +10006797
Wanlong Gaoa99d57b2014-05-14 17:43:28 +08006798if test "$numa" = "yes"; then
6799 echo "CONFIG_NUMA=y" >> $config_host_mak
Marc-André Lureauab318052019-07-24 19:23:16 +04006800 echo "NUMA_LIBS=$numa_libs" >> $config_host_mak
Wanlong Gaoa99d57b2014-05-14 17:43:28 +08006801fi
6802
John Snowfd0e6052015-03-25 18:57:39 -04006803if test "$ccache_cpp2" = "yes"; then
6804 echo "export CCACHE_CPP2=y" >> $config_host_mak
6805fi
6806
Daniele Buono1e4f6062020-05-29 16:51:21 -04006807if test "$safe_stack" = "yes"; then
6808 echo "CONFIG_SAFESTACK=y" >> $config_host_mak
6809fi
6810
Peter Maydelle29e5c62018-11-02 11:52:38 +00006811# If we're using a separate build tree, set it up now.
6812# DIRS are directories which we simply mkdir in the build tree;
6813# LINKS are things to symlink back into the source tree
6814# (these can be both files and directories).
6815# Caution: do not add files or directories here using wildcards. This
6816# will result in problems later if a new file matching the wildcard is
6817# added to the source tree -- nothing will cause configure to be rerun
6818# so the build tree will be missing the link back to the new file, and
6819# tests might fail. Prefer to keep the relevant files in their own
6820# directory and symlink the directory instead.
Gerd Hoffmann09db9b92020-08-27 12:26:17 +02006821# UNLINK is used to remove symlinks from older development versions
6822# that might get into the way when doing "git update" without doing
6823# a "make distclean" in between.
Thomas Huth1cf43232019-09-10 16:41:20 +02006824DIRS="tests tests/tcg tests/tcg/lm32 tests/qapi-schema tests/qtest/libqos"
6825DIRS="$DIRS tests/qtest tests/qemu-iotests tests/vm tests/fp tests/qgraph"
Paolo Bonzinib855f8d2017-08-22 06:50:18 +02006826DIRS="$DIRS docs docs/interop fsdev scsi"
Alexey Kardashevskiy744a9282019-07-16 15:27:43 +10006827DIRS="$DIRS pc-bios/optionrom pc-bios/s390-ccw"
Gerd Hoffmann8db2a4f2020-06-22 15:12:40 +02006828DIRS="$DIRS roms/seabios"
Alex Bennéec17a3862020-09-09 12:27:41 +01006829DIRS="$DIRS contrib/plugins/"
Paolo Bonzini2038f8c2019-08-07 16:35:23 +02006830LINKS="Makefile"
Marc-André Lureaue8f3bd72019-09-19 21:02:09 +04006831LINKS="$LINKS tests/tcg/lm32/Makefile"
Paolo Bonzini39419962020-08-06 14:08:31 +02006832LINKS="$LINKS tests/tcg/Makefile.target"
Gerd Hoffmannddcf6072020-08-24 09:40:57 +02006833LINKS="$LINKS pc-bios/optionrom/Makefile"
Peter Maydelle29e5c62018-11-02 11:52:38 +00006834LINKS="$LINKS pc-bios/s390-ccw/Makefile"
Gerd Hoffmann8db2a4f2020-06-22 15:12:40 +02006835LINKS="$LINKS roms/seabios/Makefile"
Peter Maydelle29e5c62018-11-02 11:52:38 +00006836LINKS="$LINKS pc-bios/qemu-icon.bmp"
6837LINKS="$LINKS .gdbinit scripts" # scripts needed by relative path in .gdbinit
Peter Maydell39950352018-11-02 11:52:39 +00006838LINKS="$LINKS tests/acceptance tests/data"
6839LINKS="$LINKS tests/qemu-iotests/check"
Cleber Rosa8f8fd9e2019-02-06 11:29:01 -05006840LINKS="$LINKS python"
Alex Bennéec17a3862020-09-09 12:27:41 +01006841LINKS="$LINKS contrib/plugins/Makefile "
Gerd Hoffmann09db9b92020-08-27 12:26:17 +02006842UNLINK="pc-bios/keymaps"
Richard Henderson753d11f2011-06-24 11:58:37 -07006843for bios_file in \
6844 $source_path/pc-bios/*.bin \
Bin Meng3a631b82020-06-22 13:09:32 +08006845 $source_path/pc-bios/*.elf \
Alexey Kardashevskiy225a9ab2016-10-26 13:18:03 +11006846 $source_path/pc-bios/*.lid \
Richard Henderson753d11f2011-06-24 11:58:37 -07006847 $source_path/pc-bios/*.rom \
6848 $source_path/pc-bios/*.dtb \
Dominik Dingele89e33e2013-04-29 04:52:06 +00006849 $source_path/pc-bios/*.img \
Richard Henderson753d11f2011-06-24 11:58:37 -07006850 $source_path/pc-bios/openbios-* \
Alexander Graf4e73c782014-01-20 00:25:40 +01006851 $source_path/pc-bios/u-boot.* \
Laszlo Ersek26ce90f2019-03-08 01:19:35 +01006852 $source_path/pc-bios/edk2-*.fd.bz2 \
Richard Henderson753d11f2011-06-24 11:58:37 -07006853 $source_path/pc-bios/palcode-*
6854do
Peter Maydelle29e5c62018-11-02 11:52:38 +00006855 LINKS="$LINKS pc-bios/$(basename $bios_file)"
Paolo Bonzinid1807a42010-12-23 11:43:59 +01006856done
6857mkdir -p $DIRS
Peter Maydelle29e5c62018-11-02 11:52:38 +00006858for f in $LINKS ; do
Paolo Bonzini0f4d8892020-09-01 03:23:47 -04006859 if [ -e "$source_path/$f" ]; then
Peter Maydellf9245e12011-06-03 17:10:40 +01006860 symlink "$source_path/$f" "$f"
6861 fi
Paolo Bonzinid1807a42010-12-23 11:43:59 +01006862done
Gerd Hoffmann09db9b92020-08-27 12:26:17 +02006863for f in $UNLINK ; do
6864 if [ -L "$f" ]; then
6865 rm -f "$f"
6866 fi
6867done
Paul Brook1ad21342009-05-19 16:17:58 +01006868
Paolo Bonzini2038f8c2019-08-07 16:35:23 +02006869(for i in $cross_cc_vars; do
6870 export $i
6871done
Alex Bennéeafc3a8f2019-11-28 16:35:24 +01006872export target_list source_path use_containers
Paolo Bonzini2038f8c2019-08-07 16:35:23 +02006873$source_path/tests/tcg/configure.sh)
6874
Anthony Liguoric34ebfd2009-09-04 10:13:29 -05006875# temporary config to build submodules
Gerd Hoffmann8db2a4f2020-06-22 15:12:40 +02006876for rom in seabios; do
Anthony Liguoric34ebfd2009-09-04 10:13:29 -05006877 config_mak=roms/$rom/config.mak
Stefan Weil37116c82010-03-01 22:20:29 +01006878 echo "# Automatically generated by configure - do not modify" > $config_mak
Anthony Liguoric34ebfd2009-09-04 10:13:29 -05006879 echo "SRC_PATH=$source_path/roms/$rom" >> $config_mak
Richard Hendersoncdbd7272016-07-07 21:49:36 -07006880 echo "AS=$as" >> $config_mak
Richard Henderson5f6f0e22016-06-23 10:39:18 -07006881 echo "CCAS=$ccas" >> $config_mak
Anthony Liguoric34ebfd2009-09-04 10:13:29 -05006882 echo "CC=$cc" >> $config_mak
6883 echo "BCC=bcc" >> $config_mak
Blue Swirl3dd46c72013-01-05 10:10:27 +00006884 echo "CPP=$cpp" >> $config_mak
Anthony Liguoric34ebfd2009-09-04 10:13:29 -05006885 echo "OBJCOPY=objcopy" >> $config_mak
Michael S. Tsirkina31a8642013-07-24 18:56:03 +03006886 echo "IASL=$iasl" >> $config_mak
Anthony Liguoric34ebfd2009-09-04 10:13:29 -05006887 echo "LD=$ld" >> $config_mak
Alistair Francis9f81aeb2017-11-07 17:10:46 -08006888 echo "RANLIB=$ranlib" >> $config_mak
Anthony Liguoric34ebfd2009-09-04 10:13:29 -05006889done
6890
Max Reitz76c75602014-05-24 23:24:56 +02006891# set up qemu-iotests in this build directory
6892iotests_common_env="tests/qemu-iotests/common.env"
Max Reitz76c75602014-05-24 23:24:56 +02006893
6894echo "# Automatically generated by configure - do not modify" > "$iotests_common_env"
6895echo >> "$iotests_common_env"
6896echo "export PYTHON='$python'" >> "$iotests_common_env"
6897
Paolo Bonzinia5665052019-06-10 12:05:14 +02006898if test "$skip_meson" = no; then
Marc-André Lureaufc929892019-07-13 01:47:54 +04006899cross="config-meson.cross.new"
6900meson_quote() {
Paolo Bonzini47b30832020-09-23 05:26:17 -04006901 echo "'$(echo $* | sed "s/ /','/g")'"
Marc-André Lureaufc929892019-07-13 01:47:54 +04006902}
6903
6904echo "# Automatically generated by configure - do not modify" > $cross
6905echo "[properties]" >> $cross
6906test -z "$cxx" && echo "link_language = 'c'" >> $cross
Paolo Bonzini47b30832020-09-23 05:26:17 -04006907echo "[built-in options]" >> $cross
6908echo "c_args = [${CFLAGS:+$(meson_quote $CFLAGS)}]" >> $cross
6909echo "cpp_args = [${CXXFLAGS:+$(meson_quote $CXXFLAGS)}]" >> $cross
6910echo "c_link_args = [${LDFLAGS:+$(meson_quote $LDFLAGS)}]" >> $cross
6911echo "cpp_link_args = [${LDFLAGS:+$(meson_quote $LDFLAGS)}]" >> $cross
Marc-André Lureaufc929892019-07-13 01:47:54 +04006912echo "[binaries]" >> $cross
Paolo Bonzini47b30832020-09-23 05:26:17 -04006913echo "c = [$(meson_quote $cc)]" >> $cross
6914test -n "$cxx" && echo "cpp = [$(meson_quote $cxx)]" >> $cross
6915echo "ar = [$(meson_quote $ar)]" >> $cross
6916echo "nm = [$(meson_quote $nm)]" >> $cross
6917echo "pkgconfig = [$(meson_quote $pkg_config_exe)]" >> $cross
6918echo "ranlib = [$(meson_quote $ranlib)]" >> $cross
Paolo Bonzinie8178512020-09-01 08:06:28 -04006919if has $sdl2_config; then
Paolo Bonzini47b30832020-09-23 05:26:17 -04006920 echo "sdl2-config = [$(meson_quote $sdl2_config)]" >> $cross
Paolo Bonzinie8178512020-09-01 08:06:28 -04006921fi
Paolo Bonzini47b30832020-09-23 05:26:17 -04006922echo "strip = [$(meson_quote $strip)]" >> $cross
6923echo "windres = [$(meson_quote $windres)]" >> $cross
Marc-André Lureaufc929892019-07-13 01:47:54 +04006924if test -n "$cross_prefix"; then
6925 cross_arg="--cross-file config-meson.cross"
Marc-André Lureaufc929892019-07-13 01:47:54 +04006926 echo "[host_machine]" >> $cross
6927 if test "$mingw32" = "yes" ; then
6928 echo "system = 'windows'" >> $cross
Marc-André Lureaufc929892019-07-13 01:47:54 +04006929 fi
Thomas Huth853b4ba2020-08-22 21:35:48 +02006930 if test "$linux" = "yes" ; then
6931 echo "system = 'linux'" >> $cross
6932 fi
Marc-André Lureaufc929892019-07-13 01:47:54 +04006933 case "$ARCH" in
6934 i386|x86_64)
6935 echo "cpu_family = 'x86'" >> $cross
6936 ;;
6937 ppc64le)
6938 echo "cpu_family = 'ppc64'" >> $cross
6939 ;;
6940 *)
6941 echo "cpu_family = '$ARCH'" >> $cross
6942 ;;
6943 esac
6944 echo "cpu = '$cpu'" >> $cross
6945 if test "$bigendian" = "yes" ; then
6946 echo "endian = 'big'" >> $cross
6947 else
6948 echo "endian = 'little'" >> $cross
6949 fi
6950else
6951 cross_arg="--native-file config-meson.cross"
6952fi
6953mv $cross config-meson.cross
6954
Paolo Bonzinia5665052019-06-10 12:05:14 +02006955rm -rf meson-private meson-info meson-logs
Paolo Bonzini09e93322020-08-13 09:28:11 -04006956NINJA=$ninja $meson setup \
Paolo Bonzinid17f3052020-08-18 12:17:01 +02006957 --prefix "$prefix" \
6958 --libdir "$libdir" \
6959 --libexecdir "$libexecdir" \
6960 --bindir "$bindir" \
6961 --includedir "$includedir" \
6962 --datadir "$datadir" \
6963 --mandir "$mandir" \
6964 --sysconfdir "$sysconfdir" \
Paolo Bonzini16bf7a32020-10-16 03:19:14 -04006965 --localedir "$localedir" \
Paolo Bonzinid17f3052020-08-18 12:17:01 +02006966 --localstatedir "$local_statedir" \
6967 -Ddocdir="$docdir" \
Paolo Bonzini16bf7a32020-10-16 03:19:14 -04006968 -Dqemu_firmwarepath="$firmwarepath" \
Marc-André Lureau73f3aa32020-08-26 15:04:15 +04006969 -Dqemu_suffix="$qemu_suffix" \
Paolo Bonzinia5665052019-06-10 12:05:14 +02006970 -Doptimization=$(if test "$debug" = yes; then echo 0; else echo 2; fi) \
6971 -Ddebug=$(if test "$debug_info" = yes; then echo true; else echo false; fi) \
6972 -Dwerror=$(if test "$werror" = yes; then echo true; else echo false; fi) \
6973 -Dstrip=$(if test "$strip_opt" = yes; then echo true; else echo false; fi) \
Marc-André Lureauda6d48b2019-09-17 15:39:36 +04006974 -Db_pie=$(if test "$pie" = yes; then echo true; else echo false; fi) \
Paolo Bonzini0c3dd502020-10-07 17:00:17 +01006975 -Db_staticpic=$(if test "$pie" = yes; then echo true; else echo false; fi) \
Marc-André Lureaubf0e56a2019-10-04 17:35:16 +04006976 -Db_coverage=$(if test "$gcov" = yes; then echo true; else echo false; fi) \
Yonggang Luo5f8937d2020-10-13 07:43:44 +08006977 -Dmalloc=$malloc -Dmalloc_trim=$malloc_trim -Dsparse=$sparse \
6978 -Dkvm=$kvm -Dhax=$hax -Dwhpx=$whpx -Dhvf=$hvf \
6979 -Dxen=$xen -Dxen_pci_passthrough=$xen_pci_passthrough -Dtcg=$tcg \
6980 -Dcocoa=$cocoa -Dmpath=$mpath -Dsdl=$sdl -Dsdl_image=$sdl_image \
6981 -Dvnc=$vnc -Dvnc_sasl=$vnc_sasl -Dvnc_jpeg=$vnc_jpeg -Dvnc_png=$vnc_png \
Misono Tomohirocece1162020-10-08 19:31:33 +09006982 -Dgettext=$gettext -Dxkbcommon=$xkbcommon -Du2f=$u2f -Dvirtiofsd=$virtiofsd \
Yonggang Luo5f8937d2020-10-13 07:43:44 +08006983 -Dcapstone=$capstone -Dslirp=$slirp -Dfdt=$fdt \
Paolo Bonzini5c530152020-10-15 06:09:27 -04006984 -Diconv=$iconv -Dcurses=$curses -Dlibudev=$libudev\
Paolo Bonzinic8d54502020-10-16 03:32:52 -04006985 -Ddocs=$docs -Dsphinx_build=$sphinx_build -Dinstall_blobs=$blobs \
Marc-André Lureaufc929892019-07-13 01:47:54 +04006986 $cross_arg \
Paolo Bonzinia5665052019-06-10 12:05:14 +02006987 "$PWD" "$source_path"
6988
6989if test "$?" -ne 0 ; then
6990 error_exit "meson setup failed"
6991fi
Paolo Bonzinia5665052019-06-10 12:05:14 +02006992fi
6993
Alex Bennée2d838d92020-09-09 12:27:37 +01006994if test -n "${deprecated_features}"; then
6995 echo "Warning, deprecated features enabled."
6996 echo "Please see docs/system/deprecated.rst"
6997 echo " features: ${deprecated_features}"
6998fi
6999
Michael S. Tsirkindc655402014-03-09 17:37:49 +02007000# Save the configure command line for later reuse.
7001cat <<EOD >config.status
7002#!/bin/sh
7003# Generated by configure.
7004# Run this file to recreate the current configuration.
7005# Compiler output produced by configure, useful for debugging
7006# configure, is in config.log if it exists.
7007EOD
Daniel P. Berrangée811da72018-09-04 13:36:03 +01007008
7009preserve_env() {
7010 envname=$1
7011
7012 eval envval=\$$envname
7013
7014 if test -n "$envval"
7015 then
7016 echo "$envname='$envval'" >> config.status
7017 echo "export $envname" >> config.status
7018 else
7019 echo "unset $envname" >> config.status
7020 fi
7021}
7022
7023# Preserve various env variables that influence what
7024# features/build target configure will detect
7025preserve_env AR
7026preserve_env AS
7027preserve_env CC
7028preserve_env CPP
7029preserve_env CXX
7030preserve_env INSTALL
7031preserve_env LD
7032preserve_env LD_LIBRARY_PATH
7033preserve_env LIBTOOL
7034preserve_env MAKE
7035preserve_env NM
7036preserve_env OBJCOPY
7037preserve_env PATH
7038preserve_env PKG_CONFIG
7039preserve_env PKG_CONFIG_LIBDIR
7040preserve_env PKG_CONFIG_PATH
7041preserve_env PYTHON
Daniel P. Berrangée811da72018-09-04 13:36:03 +01007042preserve_env SDL2_CONFIG
7043preserve_env SMBD
7044preserve_env STRIP
7045preserve_env WINDRES
7046
Michael S. Tsirkindc655402014-03-09 17:37:49 +02007047printf "exec" >>config.status
Paolo Bonzinia5665052019-06-10 12:05:14 +02007048for i in "$0" "$@"; do
7049 test "$i" = --skip-meson || printf " '%s'" "$i" >>config.status
7050done
Dr. David Alan Gilbertcf7cc922016-01-12 11:58:48 +00007051echo ' "$@"' >>config.status
Michael S. Tsirkindc655402014-03-09 17:37:49 +02007052chmod +x config.status
7053
Peter Maydell8cd05ab2014-05-23 17:07:24 +01007054rm -r "$TMPDIR1"