2003-03-07 02:23:54 +03:00
|
|
|
#!/bin/sh
|
|
|
|
#
|
2003-03-23 23:17:16 +03:00
|
|
|
# qemu configure script (c) 2003 Fabrice Bellard
|
2003-03-07 02:23:54 +03:00
|
|
|
#
|
2014-05-23 20:07:24 +04:00
|
|
|
|
2014-05-28 14:39:17 +04:00
|
|
|
# Unset some variables known to interfere with behavior of common tools,
|
|
|
|
# just as autoconf does.
|
|
|
|
CLICOLOR_FORCE= GREP_OPTIONS=
|
|
|
|
unset CLICOLOR_FORCE GREP_OPTIONS
|
|
|
|
|
2015-10-28 20:56:40 +03:00
|
|
|
# Don't allow CCACHE, if present, to use cached results of compile tests!
|
|
|
|
export CCACHE_RECACHE=yes
|
|
|
|
|
2020-08-21 13:22:04 +03:00
|
|
|
# make source path absolute
|
|
|
|
source_path=$(cd "$(dirname -- "$0")"; pwd)
|
|
|
|
|
|
|
|
if test "$PWD" = "$source_path"
|
|
|
|
then
|
|
|
|
echo "Using './build' as the directory for build output"
|
|
|
|
|
|
|
|
MARKER=build/auto-created-by-configure
|
|
|
|
|
|
|
|
if test -e build
|
|
|
|
then
|
|
|
|
if test -f $MARKER
|
|
|
|
then
|
|
|
|
rm -rf build
|
|
|
|
else
|
|
|
|
echo "ERROR: ./build dir already exists and was not previously created by configure"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
mkdir build
|
|
|
|
touch $MARKER
|
|
|
|
|
|
|
|
cat > GNUmakefile <<'EOF'
|
|
|
|
# This file is auto-generated by configure to support in-source tree
|
|
|
|
# 'make' command invocation
|
|
|
|
|
|
|
|
ifeq ($(MAKECMDGOALS),)
|
|
|
|
recurse: all
|
|
|
|
endif
|
|
|
|
|
|
|
|
.NOTPARALLEL: %
|
|
|
|
%: force
|
|
|
|
@echo 'changing dir to build for $(MAKE) "$(MAKECMDGOALS)"...'
|
|
|
|
@$(MAKE) -C build -f Makefile $(MAKECMDGOALS)
|
|
|
|
@if test "$(MAKECMDGOALS)" = "distclean" && \
|
|
|
|
test -e build/auto-created-by-configure ; \
|
|
|
|
then \
|
|
|
|
rm -rf build GNUmakefile ; \
|
|
|
|
fi
|
|
|
|
force: ;
|
|
|
|
.PHONY: force
|
|
|
|
GNUmakefile: ;
|
|
|
|
|
|
|
|
EOF
|
|
|
|
cd build
|
|
|
|
exec $source_path/configure "$@"
|
|
|
|
fi
|
|
|
|
|
2014-05-23 20:07:24 +04:00
|
|
|
# Temporary directory used for files created while
|
|
|
|
# configure runs. Since it is in the build directory
|
|
|
|
# we can safely blow away any previous version of it
|
|
|
|
# (and we need not jump through hoops to try to delete
|
|
|
|
# it when configure exits.)
|
|
|
|
TMPDIR1="config-temp"
|
|
|
|
rm -rf "${TMPDIR1}"
|
|
|
|
mkdir -p "${TMPDIR1}"
|
|
|
|
if [ $? -ne 0 ]; then
|
|
|
|
echo "ERROR: failed to create temporary directory"
|
|
|
|
exit 1
|
2003-03-07 02:23:54 +03:00
|
|
|
fi
|
|
|
|
|
2014-05-23 20:07:24 +04:00
|
|
|
TMPB="qemu-conf"
|
|
|
|
TMPC="${TMPDIR1}/${TMPB}.c"
|
2014-01-03 06:12:46 +04:00
|
|
|
TMPO="${TMPDIR1}/${TMPB}.o"
|
2014-02-25 22:27:49 +04:00
|
|
|
TMPCXX="${TMPDIR1}/${TMPB}.cxx"
|
2014-05-23 20:07:24 +04:00
|
|
|
TMPE="${TMPDIR1}/${TMPB}.exe"
|
2018-10-21 20:56:29 +03:00
|
|
|
TMPTXT="${TMPDIR1}/${TMPB}.txt"
|
2003-03-07 02:23:54 +03:00
|
|
|
|
2010-04-23 15:44:10 +04:00
|
|
|
rm -f config.log
|
2008-11-29 23:09:56 +03:00
|
|
|
|
2011-11-23 21:26:44 +04:00
|
|
|
# Print a helpful header at the top of config.log
|
|
|
|
echo "# QEMU configure log $(date)" >> config.log
|
2012-03-07 16:16:29 +04:00
|
|
|
printf "# Configured with:" >> config.log
|
|
|
|
printf " '%s'" "$0" "$@" >> config.log
|
|
|
|
echo >> config.log
|
2011-11-23 21:26:44 +04:00
|
|
|
echo "#" >> config.log
|
|
|
|
|
2017-07-03 17:58:28 +03:00
|
|
|
print_error() {
|
|
|
|
(echo
|
2013-04-08 15:11:26 +04:00
|
|
|
echo "ERROR: $1"
|
|
|
|
while test -n "$2"; do
|
|
|
|
echo " $2"
|
|
|
|
shift
|
|
|
|
done
|
2017-07-03 17:58:28 +03:00
|
|
|
echo) >&2
|
|
|
|
}
|
|
|
|
|
|
|
|
error_exit() {
|
|
|
|
print_error "$@"
|
2013-04-08 15:11:26 +04:00
|
|
|
exit 1
|
|
|
|
}
|
|
|
|
|
2014-02-25 22:27:49 +04:00
|
|
|
do_compiler() {
|
|
|
|
# Run the compiler, capturing its output to the log. First argument
|
|
|
|
# is compiler binary to execute.
|
|
|
|
local compiler="$1"
|
|
|
|
shift
|
2017-09-25 18:41:03 +03:00
|
|
|
if test -n "$BASH_VERSION"; then eval '
|
|
|
|
echo >>config.log "
|
|
|
|
funcs: ${FUNCNAME[*]}
|
|
|
|
lines: ${BASH_LINENO[*]}"
|
|
|
|
'; fi
|
2014-02-25 22:27:49 +04:00
|
|
|
echo $compiler "$@" >> config.log
|
|
|
|
$compiler "$@" >> config.log 2>&1 || return $?
|
2012-07-18 18:10:28 +04:00
|
|
|
# Test passed. If this is an --enable-werror build, rerun
|
|
|
|
# the test with -Werror and bail out if it fails. This
|
|
|
|
# makes warning-generating-errors in configure test code
|
|
|
|
# obvious to developers.
|
|
|
|
if test "$werror" != "yes"; then
|
|
|
|
return 0
|
|
|
|
fi
|
|
|
|
# Don't bother rerunning the compile if we were already using -Werror
|
|
|
|
case "$*" in
|
|
|
|
*-Werror*)
|
|
|
|
return 0
|
|
|
|
;;
|
|
|
|
esac
|
2014-02-25 22:27:49 +04:00
|
|
|
echo $compiler -Werror "$@" >> config.log
|
|
|
|
$compiler -Werror "$@" >> config.log 2>&1 && return $?
|
2013-04-08 15:11:26 +04:00
|
|
|
error_exit "configure test passed without -Werror but failed with -Werror." \
|
|
|
|
"This is probably a bug in the configure script. The failing command" \
|
|
|
|
"will be at the bottom of config.log." \
|
|
|
|
"You can run configure with --disable-werror to bypass this check."
|
2012-07-18 18:10:28 +04:00
|
|
|
}
|
|
|
|
|
2014-02-25 22:27:49 +04:00
|
|
|
do_cc() {
|
|
|
|
do_compiler "$cc" "$@"
|
|
|
|
}
|
|
|
|
|
|
|
|
do_cxx() {
|
|
|
|
do_compiler "$cxx" "$@"
|
|
|
|
}
|
|
|
|
|
2020-06-17 23:13:06 +03:00
|
|
|
# Append $2 to the variable named $1, with space separation
|
|
|
|
add_to() {
|
|
|
|
eval $1=\${$1:+\"\$$1 \"}\$2
|
|
|
|
}
|
|
|
|
|
2014-02-25 22:27:49 +04:00
|
|
|
update_cxxflags() {
|
|
|
|
# Set QEMU_CXXFLAGS from QEMU_CFLAGS by filtering out those
|
|
|
|
# options which some versions of GCC's C++ compiler complain about
|
|
|
|
# because they only make sense for C programs.
|
2019-07-29 13:50:04 +03:00
|
|
|
QEMU_CXXFLAGS="$QEMU_CXXFLAGS -D__STDC_LIMIT_MACROS -D__STDC_CONSTANT_MACROS -D__STDC_FORMAT_MACROS"
|
2020-09-23 12:26:15 +03:00
|
|
|
CONFIGURE_CXXFLAGS=$(echo "$CONFIGURE_CFLAGS" | sed s/-std=gnu99/-std=gnu++11/)
|
2014-02-25 22:27:49 +04:00
|
|
|
for arg in $QEMU_CFLAGS; do
|
|
|
|
case $arg in
|
|
|
|
-Wstrict-prototypes|-Wmissing-prototypes|-Wnested-externs|\
|
|
|
|
-Wold-style-declaration|-Wold-style-definition|-Wredundant-decls)
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
QEMU_CXXFLAGS=${QEMU_CXXFLAGS:+$QEMU_CXXFLAGS }$arg
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
done
|
|
|
|
}
|
|
|
|
|
2009-08-03 16:46:03 +04:00
|
|
|
compile_object() {
|
2015-03-26 01:57:39 +03:00
|
|
|
local_cflags="$1"
|
2020-09-23 12:26:15 +03:00
|
|
|
do_cc $CFLAGS $CONFIGURE_CFLAGS $QEMU_CFLAGS $local_cflags -c -o $TMPO $TMPC
|
2009-08-03 16:46:03 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
compile_prog() {
|
|
|
|
local_cflags="$1"
|
|
|
|
local_ldflags="$2"
|
2020-09-23 12:26:15 +03:00
|
|
|
do_cc $CFLAGS $CONFIGURE_CFLAGS $QEMU_CFLAGS $local_cflags -o $TMPE $TMPC \
|
|
|
|
$LDFLAGS $CONFIGURE_LDFLAGS $QEMU_LDFLAGS $local_ldflags
|
2009-08-03 16:46:03 +04:00
|
|
|
}
|
|
|
|
|
2010-12-23 13:43:58 +03:00
|
|
|
# symbolically link $1 to $2. Portable version of "ln -sf".
|
|
|
|
symlink() {
|
2012-03-19 16:20:47 +04:00
|
|
|
rm -rf "$2"
|
2012-06-06 12:57:00 +04:00
|
|
|
mkdir -p "$(dirname "$2")"
|
2012-03-19 16:20:47 +04:00
|
|
|
ln -s "$1" "$2"
|
2010-12-23 13:43:58 +03:00
|
|
|
}
|
|
|
|
|
2010-01-29 00:26:51 +03:00
|
|
|
# check whether a command is available to this shell (may be either an
|
|
|
|
# executable or a builtin)
|
|
|
|
has() {
|
|
|
|
type "$1" >/dev/null 2>&1
|
|
|
|
}
|
|
|
|
|
2019-08-21 10:21:16 +03:00
|
|
|
version_ge () {
|
|
|
|
local_ver1=`echo $1 | tr . ' '`
|
|
|
|
local_ver2=`echo $2 | tr . ' '`
|
|
|
|
while true; do
|
|
|
|
set x $local_ver1
|
|
|
|
local_first=${2-0}
|
2020-08-21 23:35:58 +03:00
|
|
|
# 'shift 2' if $2 is set, or 'shift' if $2 is not set
|
|
|
|
shift ${2:+2}
|
2019-08-21 10:21:16 +03:00
|
|
|
local_ver1=$*
|
|
|
|
set x $local_ver2
|
|
|
|
# the second argument finished, the first must be greater or equal
|
|
|
|
test $# = 1 && return 0
|
|
|
|
test $local_first -lt $2 && return 1
|
|
|
|
test $local_first -gt $2 && return 0
|
2020-08-21 23:35:58 +03:00
|
|
|
shift ${2:+2}
|
2019-08-21 10:21:16 +03:00
|
|
|
local_ver2=$*
|
|
|
|
done
|
|
|
|
}
|
|
|
|
|
2014-05-27 17:02:14 +04:00
|
|
|
have_backend () {
|
|
|
|
echo "$trace_backends" | grep "$1" >/dev/null
|
|
|
|
}
|
|
|
|
|
2012-09-17 13:59:41 +04:00
|
|
|
glob() {
|
|
|
|
eval test -z '"${1#'"$2"'}"'
|
|
|
|
}
|
|
|
|
|
2017-08-23 13:16:23 +03:00
|
|
|
ld_has() {
|
|
|
|
$ld --help 2>/dev/null | grep ".$1" >/dev/null 2>&1
|
|
|
|
}
|
|
|
|
|
2019-05-26 17:47:47 +03:00
|
|
|
if printf %s\\n "$source_path" "$PWD" | grep -q "[[:space:]:]";
|
|
|
|
then
|
|
|
|
error_exit "main directory cannot contain spaces nor colons"
|
|
|
|
fi
|
|
|
|
|
2019-05-26 17:47:46 +03:00
|
|
|
# default parameters
|
2009-08-03 16:45:55 +04:00
|
|
|
cpu=""
|
2013-07-24 19:56:03 +04:00
|
|
|
iasl="iasl"
|
2003-10-01 00:54:24 +04:00
|
|
|
interp_prefix="/usr/gnemul/qemu-%M"
|
2003-06-09 23:53:12 +04:00
|
|
|
static="no"
|
2003-03-07 02:23:54 +03:00
|
|
|
cross_prefix=""
|
2008-06-26 01:04:05 +04:00
|
|
|
audio_drv_list=""
|
2013-05-29 15:35:40 +04:00
|
|
|
block_drv_rw_whitelist=""
|
|
|
|
block_drv_ro_whitelist=""
|
2012-12-07 19:39:13 +04:00
|
|
|
host_cc="cc"
|
2009-10-10 01:13:41 +04:00
|
|
|
audio_win_int=""
|
2011-08-12 00:38:12 +04:00
|
|
|
libs_qga=""
|
2012-02-08 16:54:13 +04:00
|
|
|
debug_info="yes"
|
2020-12-05 02:06:11 +03:00
|
|
|
lto="false"
|
2014-03-28 20:19:02 +04:00
|
|
|
stack_protector=""
|
2020-05-29 23:51:21 +03:00
|
|
|
safe_stack=""
|
2019-11-28 18:35:24 +03:00
|
|
|
use_containers="yes"
|
2020-04-30 22:01:14 +03:00
|
|
|
gdb_bin=$(command -v "gdb-multiarch" || command -v "gdb")
|
2008-12-29 20:14:15 +03:00
|
|
|
|
2017-09-29 13:11:58 +03:00
|
|
|
if test -e "$source_path/.git"
|
|
|
|
then
|
2017-10-26 15:52:26 +03:00
|
|
|
git_update=yes
|
2017-09-29 13:11:58 +03:00
|
|
|
git_submodules="ui/keycodemapdb"
|
2018-03-09 05:09:40 +03:00
|
|
|
git_submodules="$git_submodules tests/fp/berkeley-testfloat-3"
|
|
|
|
git_submodules="$git_submodules tests/fp/berkeley-softfloat-3"
|
2017-09-29 13:11:58 +03:00
|
|
|
else
|
2017-10-26 15:52:26 +03:00
|
|
|
git_update=no
|
2017-09-29 13:11:58 +03:00
|
|
|
git_submodules=""
|
2018-04-18 20:11:51 +03:00
|
|
|
|
|
|
|
if ! test -f "$source_path/ui/keycodemapdb/README"
|
|
|
|
then
|
|
|
|
echo
|
|
|
|
echo "ERROR: missing file $source_path/ui/keycodemapdb/README"
|
|
|
|
echo
|
|
|
|
echo "This is not a GIT checkout but module content appears to"
|
|
|
|
echo "be missing. Do not use 'git archive' or GitHub download links"
|
|
|
|
echo "to acquire QEMU source archives. Non-GIT builds are only"
|
|
|
|
echo "supported with source archives linked from:"
|
|
|
|
echo
|
2019-07-22 16:07:39 +03:00
|
|
|
echo " https://www.qemu.org/download/#source"
|
2018-04-18 20:11:51 +03:00
|
|
|
echo
|
|
|
|
echo "Developers working with GIT can use scripts/archive-source.sh"
|
|
|
|
echo "if they need to create valid source archives."
|
|
|
|
echo
|
|
|
|
exit 1
|
|
|
|
fi
|
2017-09-29 13:11:58 +03:00
|
|
|
fi
|
2017-10-20 17:02:43 +03:00
|
|
|
git="git"
|
2008-12-29 20:14:15 +03:00
|
|
|
|
2012-09-27 00:04:38 +04:00
|
|
|
# Don't accept a target_list environment variable.
|
|
|
|
unset target_list
|
2019-03-19 14:59:12 +03:00
|
|
|
unset target_list_exclude
|
2010-12-23 13:43:50 +03:00
|
|
|
|
|
|
|
# Default value for a variable defining feature "foo".
|
|
|
|
# * foo="no" feature will only be used if --enable-foo arg is given
|
|
|
|
# * foo="" feature will be searched for, and if found, will be used
|
|
|
|
# unless --disable-foo is given
|
|
|
|
# * foo="yes" this value will only be set by --enable-foo flag.
|
|
|
|
# feature will searched for,
|
|
|
|
# if not found, configure exits with error
|
|
|
|
#
|
|
|
|
# Always add --enable-foo and --disable-foo command line args.
|
|
|
|
# Distributions want to ensure that several features are compiled in, and it
|
|
|
|
# is impossible without a --enable-foo that exits if a feature is not found.
|
|
|
|
|
2020-12-10 22:04:13 +03:00
|
|
|
default_feature=""
|
|
|
|
# parse CC options second
|
|
|
|
for opt do
|
|
|
|
optarg=$(expr "x$opt" : 'x[^=]*=\(.*\)')
|
|
|
|
case "$opt" in
|
|
|
|
--without-default-features)
|
|
|
|
default_feature="no"
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
done
|
|
|
|
|
2020-11-17 15:02:17 +03:00
|
|
|
brlapi="auto"
|
2020-11-17 14:43:15 +03:00
|
|
|
curl="auto"
|
2020-10-13 02:43:48 +03:00
|
|
|
iconv="auto"
|
|
|
|
curses="auto"
|
2020-10-16 01:06:25 +03:00
|
|
|
docs="auto"
|
2020-10-05 12:31:15 +03:00
|
|
|
fdt="auto"
|
2013-11-06 14:44:06 +04:00
|
|
|
netmap="no"
|
2020-02-06 16:17:15 +03:00
|
|
|
sdl="auto"
|
|
|
|
sdl_image="auto"
|
2020-10-08 13:31:33 +03:00
|
|
|
virtiofsd="auto"
|
2020-11-17 16:46:21 +03:00
|
|
|
virtfs="auto"
|
2020-10-15 13:09:27 +03:00
|
|
|
libudev="auto"
|
2020-09-16 19:07:29 +03:00
|
|
|
mpath="auto"
|
2020-02-06 17:48:52 +03:00
|
|
|
vnc="enabled"
|
2020-09-01 14:51:16 +03:00
|
|
|
sparse="auto"
|
2020-12-10 22:04:13 +03:00
|
|
|
vde="$default_feature"
|
2020-02-06 17:48:52 +03:00
|
|
|
vnc_sasl="auto"
|
|
|
|
vnc_jpeg="auto"
|
|
|
|
vnc_png="auto"
|
2020-08-24 18:24:29 +03:00
|
|
|
xkbcommon="auto"
|
2020-12-10 22:04:13 +03:00
|
|
|
xen="$default_feature"
|
|
|
|
xen_ctrl_version="$default_feature"
|
2020-09-18 11:57:25 +03:00
|
|
|
xen_pci_passthrough="auto"
|
2020-12-10 22:04:13 +03:00
|
|
|
linux_aio="$default_feature"
|
|
|
|
linux_io_uring="$default_feature"
|
2020-11-17 16:46:58 +03:00
|
|
|
cap_ng="auto"
|
2020-11-17 16:45:24 +03:00
|
|
|
attr="auto"
|
2020-12-10 22:04:13 +03:00
|
|
|
xfs="$default_feature"
|
2020-09-18 11:57:25 +03:00
|
|
|
tcg="enabled"
|
2020-12-10 22:04:13 +03:00
|
|
|
membarrier="$default_feature"
|
|
|
|
vhost_net="$default_feature"
|
|
|
|
vhost_crypto="$default_feature"
|
|
|
|
vhost_scsi="$default_feature"
|
|
|
|
vhost_vsock="$default_feature"
|
2020-11-10 20:11:21 +03:00
|
|
|
vhost_user="no"
|
2020-11-10 20:11:19 +03:00
|
|
|
vhost_user_blk_server="auto"
|
2020-12-10 22:04:13 +03:00
|
|
|
vhost_user_fs="$default_feature"
|
2020-09-18 12:22:37 +03:00
|
|
|
kvm="auto"
|
|
|
|
hax="auto"
|
|
|
|
hvf="auto"
|
|
|
|
whpx="auto"
|
2020-12-10 22:04:13 +03:00
|
|
|
rdma="$default_feature"
|
|
|
|
pvrdma="$default_feature"
|
2010-12-23 13:43:50 +03:00
|
|
|
gprof="no"
|
|
|
|
debug_tcg="no"
|
|
|
|
debug="no"
|
2018-01-16 18:11:51 +03:00
|
|
|
sanitizers="no"
|
2020-06-12 22:02:23 +03:00
|
|
|
tsan="no"
|
2020-12-10 22:04:13 +03:00
|
|
|
fortify_source="$default_feature"
|
2010-12-23 13:43:50 +03:00
|
|
|
strip_opt="yes"
|
2011-10-19 09:07:18 +04:00
|
|
|
tcg_interpreter="no"
|
2010-12-23 13:43:50 +03:00
|
|
|
bigendian="no"
|
|
|
|
mingw32="no"
|
2012-05-01 22:45:39 +04:00
|
|
|
gcov="no"
|
2020-12-10 22:04:13 +03:00
|
|
|
EXESUF="$default_feature"
|
2019-12-12 15:30:36 +03:00
|
|
|
HOST_DSOSUF=".so"
|
2014-02-10 10:48:56 +04:00
|
|
|
modules="no"
|
2020-03-10 17:58:06 +03:00
|
|
|
module_upgrades="no"
|
2010-12-23 13:43:50 +03:00
|
|
|
prefix="/usr/local"
|
2020-08-26 14:04:13 +03:00
|
|
|
qemu_suffix="qemu"
|
2020-10-05 12:31:15 +03:00
|
|
|
slirp="auto"
|
2010-12-23 13:43:50 +03:00
|
|
|
oss_lib=""
|
|
|
|
bsd="no"
|
|
|
|
linux="no"
|
|
|
|
solaris="no"
|
|
|
|
profiler="no"
|
2020-09-01 18:28:59 +03:00
|
|
|
cocoa="auto"
|
2010-12-23 13:43:50 +03:00
|
|
|
softmmu="yes"
|
|
|
|
linux_user="no"
|
|
|
|
bsd_user="no"
|
2020-10-16 10:32:52 +03:00
|
|
|
blobs="true"
|
2010-12-23 13:43:50 +03:00
|
|
|
pkgversion=""
|
2011-11-15 22:12:17 +04:00
|
|
|
pie=""
|
2013-05-10 16:16:40 +04:00
|
|
|
qom_cast_debug="yes"
|
2016-01-07 16:55:31 +03:00
|
|
|
trace_backends="log"
|
2010-12-23 13:43:50 +03:00
|
|
|
trace_file="trace"
|
2020-12-10 22:04:13 +03:00
|
|
|
spice="$default_feature"
|
2020-11-17 15:11:25 +03:00
|
|
|
rbd="auto"
|
2020-12-10 22:04:13 +03:00
|
|
|
smartcard="$default_feature"
|
2020-08-26 14:42:04 +03:00
|
|
|
u2f="auto"
|
2020-12-10 22:04:13 +03:00
|
|
|
libusb="$default_feature"
|
|
|
|
usb_redir="$default_feature"
|
|
|
|
opengl="$default_feature"
|
2015-12-03 14:56:34 +03:00
|
|
|
opengl_dmabuf="no"
|
2017-07-19 07:40:18 +03:00
|
|
|
cpuid_h="no"
|
2020-12-10 22:04:13 +03:00
|
|
|
avx2_opt="$default_feature"
|
2020-09-13 22:19:25 +03:00
|
|
|
capstone="auto"
|
2020-11-17 15:11:25 +03:00
|
|
|
lzo="auto"
|
2020-11-17 15:32:34 +03:00
|
|
|
snappy="auto"
|
2020-11-17 15:07:52 +03:00
|
|
|
bzip2="auto"
|
2020-11-17 15:35:28 +03:00
|
|
|
lzfse="auto"
|
2020-11-17 15:37:39 +03:00
|
|
|
zstd="auto"
|
2020-12-10 22:04:13 +03:00
|
|
|
guest_agent="$default_feature"
|
2013-08-07 19:40:03 +04:00
|
|
|
guest_agent_with_vss="no"
|
2015-07-08 02:10:09 +03:00
|
|
|
guest_agent_ntddscsi="no"
|
2020-12-10 22:04:13 +03:00
|
|
|
guest_agent_msi="$default_feature"
|
|
|
|
vss_win32_sdk="$default_feature"
|
2013-08-07 19:40:03 +04:00
|
|
|
win_sdk="no"
|
2020-12-10 22:04:13 +03:00
|
|
|
want_tools="$default_feature"
|
2020-11-17 15:11:25 +03:00
|
|
|
libiscsi="auto"
|
2020-11-17 15:11:25 +03:00
|
|
|
libnfs="auto"
|
2012-02-28 15:25:50 +04:00
|
|
|
coroutine=""
|
2020-12-10 22:04:13 +03:00
|
|
|
coroutine_pool="$default_feature"
|
2016-09-27 12:58:45 +03:00
|
|
|
debug_stack_usage="no"
|
2017-07-14 21:04:05 +03:00
|
|
|
crypto_afalg="no"
|
2020-12-05 02:06:14 +03:00
|
|
|
cfi="false"
|
|
|
|
cfi_debug="false"
|
2020-11-17 16:22:24 +03:00
|
|
|
seccomp="auto"
|
2020-11-17 15:01:26 +03:00
|
|
|
glusterfs="auto"
|
2020-12-10 22:04:13 +03:00
|
|
|
gtk="$default_feature"
|
2015-05-26 13:26:21 +03:00
|
|
|
gtk_gl="no"
|
2016-06-06 12:05:06 +03:00
|
|
|
tls_priority="NORMAL"
|
2020-12-10 22:04:13 +03:00
|
|
|
gnutls="$default_feature"
|
|
|
|
nettle="$default_feature"
|
2019-10-14 19:28:27 +03:00
|
|
|
nettle_xts="no"
|
2020-12-10 22:04:13 +03:00
|
|
|
gcrypt="$default_feature"
|
2016-12-13 13:42:55 +03:00
|
|
|
gcrypt_hmac="no"
|
2019-10-14 19:28:27 +03:00
|
|
|
gcrypt_xts="no"
|
|
|
|
qemu_private_xts="yes"
|
2020-12-10 22:04:13 +03:00
|
|
|
auth_pam="$default_feature"
|
|
|
|
vte="$default_feature"
|
|
|
|
virglrenderer="$default_feature"
|
|
|
|
tpm="$default_feature"
|
|
|
|
libssh="$default_feature"
|
|
|
|
live_block_migration=${default_feature:-yes}
|
|
|
|
numa="$default_feature"
|
2015-03-26 06:03:12 +03:00
|
|
|
tcmalloc="no"
|
2015-06-19 13:56:58 +03:00
|
|
|
jemalloc="no"
|
2020-12-10 22:04:13 +03:00
|
|
|
replication=${default_feature:-yes}
|
|
|
|
bochs=${default_feature:-yes}
|
|
|
|
cloop=${default_feature:-yes}
|
|
|
|
dmg=${default_feature:-yes}
|
|
|
|
qcow1=${default_feature:-yes}
|
|
|
|
vdi=${default_feature:-yes}
|
|
|
|
vvfat=${default_feature:-yes}
|
|
|
|
qed=${default_feature:-yes}
|
|
|
|
parallels=${default_feature:-yes}
|
2020-10-02 14:32:43 +03:00
|
|
|
sheepdog="no"
|
2020-12-10 22:04:13 +03:00
|
|
|
libxml2="$default_feature"
|
2018-06-13 15:23:08 +03:00
|
|
|
debug_mutex="no"
|
2020-12-10 22:04:13 +03:00
|
|
|
libpmem="$default_feature"
|
2020-11-20 10:38:22 +03:00
|
|
|
default_devices="true"
|
2019-06-13 16:52:25 +03:00
|
|
|
plugins="no"
|
2020-02-20 07:11:14 +03:00
|
|
|
fuzzing="no"
|
2020-05-20 16:20:23 +03:00
|
|
|
rng_none="no"
|
2020-12-10 22:04:13 +03:00
|
|
|
secret_keyring="$default_feature"
|
|
|
|
libdaxctl="$default_feature"
|
2019-06-10 13:05:14 +03:00
|
|
|
meson=""
|
2020-08-26 09:04:15 +03:00
|
|
|
ninja=""
|
2019-06-10 13:05:14 +03:00
|
|
|
skip_meson=no
|
2020-12-10 22:04:12 +03:00
|
|
|
gettext="auto"
|
2020-10-27 22:05:41 +03:00
|
|
|
fuse="auto"
|
2020-10-27 22:05:46 +03:00
|
|
|
fuse_lseek="auto"
|
2010-12-23 13:43:50 +03:00
|
|
|
|
2020-09-01 18:15:30 +03:00
|
|
|
malloc_trim="auto"
|
2017-03-21 17:31:57 +03:00
|
|
|
|
2020-12-10 22:04:13 +03:00
|
|
|
# parse CC options second
|
2008-12-29 20:14:15 +03:00
|
|
|
for opt do
|
2016-05-16 16:10:20 +03:00
|
|
|
optarg=$(expr "x$opt" : 'x[^=]*=\(.*\)')
|
2008-12-29 20:14:15 +03:00
|
|
|
case "$opt" in
|
|
|
|
--cross-prefix=*) cross_prefix="$optarg"
|
|
|
|
;;
|
2010-12-23 13:43:48 +03:00
|
|
|
--cc=*) CC="$optarg"
|
2008-12-29 20:14:15 +03:00
|
|
|
;;
|
2013-08-07 19:39:36 +04:00
|
|
|
--cxx=*) CXX="$optarg"
|
|
|
|
;;
|
2009-08-03 16:45:55 +04:00
|
|
|
--cpu=*) cpu="$optarg"
|
|
|
|
;;
|
2015-06-03 11:56:37 +03:00
|
|
|
--extra-cflags=*) QEMU_CFLAGS="$QEMU_CFLAGS $optarg"
|
build-sys: clean up flags included in the linker command line
Some of the CFLAGS that are discovered during configure, for example
compiler warnings, are being included on the linker command line because
QEMU_CFLAGS is added to it. Other flags, such as the -m32, appear twice
because they are included in both QEMU_CFLAGS and LDFLAGS. All this
leads to confusion with respect to what goes in which Makefile variables
(and we have plenty).
So, introduce QEMU_LDFLAGS for flags discovered by configure, following
the lead of QEMU_CFLAGS, and stop adding to it:
1) options that are already in CFLAGS, for example "-g"
2) duplicate options
At the same time, options that _are_ needed by both compiler and linker
must now be added to both QEMU_CFLAGS and QEMU_LDFLAGS, which is clearer.
This is mostly -fsanitize options. For now, --extra-cflags has this behavior
(but --extra-cxxflags does not).
Meson will not include CFLAGS on the linker command line, do the same in our
build system as well.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
2019-12-11 17:34:27 +03:00
|
|
|
QEMU_LDFLAGS="$QEMU_LDFLAGS $optarg"
|
2009-08-03 16:46:02 +04:00
|
|
|
;;
|
2017-06-06 16:07:47 +03:00
|
|
|
--extra-cxxflags=*) QEMU_CXXFLAGS="$QEMU_CXXFLAGS $optarg"
|
|
|
|
;;
|
build-sys: clean up flags included in the linker command line
Some of the CFLAGS that are discovered during configure, for example
compiler warnings, are being included on the linker command line because
QEMU_CFLAGS is added to it. Other flags, such as the -m32, appear twice
because they are included in both QEMU_CFLAGS and LDFLAGS. All this
leads to confusion with respect to what goes in which Makefile variables
(and we have plenty).
So, introduce QEMU_LDFLAGS for flags discovered by configure, following
the lead of QEMU_CFLAGS, and stop adding to it:
1) options that are already in CFLAGS, for example "-g"
2) duplicate options
At the same time, options that _are_ needed by both compiler and linker
must now be added to both QEMU_CFLAGS and QEMU_LDFLAGS, which is clearer.
This is mostly -fsanitize options. For now, --extra-cflags has this behavior
(but --extra-cxxflags does not).
Meson will not include CFLAGS on the linker command line, do the same in our
build system as well.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
2019-12-11 17:34:27 +03:00
|
|
|
--extra-ldflags=*) QEMU_LDFLAGS="$QEMU_LDFLAGS $optarg"
|
2013-01-04 13:15:53 +04:00
|
|
|
EXTRA_LDFLAGS="$optarg"
|
2009-08-03 16:46:02 +04:00
|
|
|
;;
|
2012-02-08 16:54:13 +04:00
|
|
|
--enable-debug-info) debug_info="yes"
|
|
|
|
;;
|
|
|
|
--disable-debug-info) debug_info="no"
|
|
|
|
;;
|
2018-04-04 22:27:05 +03:00
|
|
|
--cross-cc-*[!a-zA-Z0-9_-]*=*) error_exit "Passed bad --cross-cc-FOO option"
|
|
|
|
;;
|
2018-04-13 13:07:58 +03:00
|
|
|
--cross-cc-cflags-*) cc_arch=${opt#--cross-cc-flags-}; cc_arch=${cc_arch%%=*}
|
|
|
|
eval "cross_cc_cflags_${cc_arch}=\$optarg"
|
2019-08-07 17:35:23 +03:00
|
|
|
cross_cc_vars="$cross_cc_vars cross_cc_cflags_${cc_arch}"
|
2018-04-13 13:07:58 +03:00
|
|
|
;;
|
2018-04-04 22:27:05 +03:00
|
|
|
--cross-cc-*) cc_arch=${opt#--cross-cc-}; cc_arch=${cc_arch%%=*}
|
2019-08-07 17:35:23 +03:00
|
|
|
cc_archs="$cc_archs $cc_arch"
|
2018-04-04 22:27:05 +03:00
|
|
|
eval "cross_cc_${cc_arch}=\$optarg"
|
2019-08-07 17:35:23 +03:00
|
|
|
cross_cc_vars="$cross_cc_vars cross_cc_${cc_arch}"
|
2018-04-04 22:27:05 +03:00
|
|
|
;;
|
2008-12-29 20:14:15 +03:00
|
|
|
esac
|
|
|
|
done
|
|
|
|
# OS specific
|
|
|
|
# Using uname is really, really broken. Once we have the right set of checks
|
2012-02-26 21:46:12 +04:00
|
|
|
# we can eliminate its usage altogether.
|
2008-12-29 20:14:15 +03:00
|
|
|
|
2012-12-07 19:39:13 +04:00
|
|
|
# Preferred compiler:
|
|
|
|
# ${CC} (if set)
|
|
|
|
# ${cross_prefix}gcc (if cross-prefix specified)
|
|
|
|
# system compiler
|
|
|
|
if test -z "${CC}${cross_prefix}"; then
|
|
|
|
cc="$host_cc"
|
|
|
|
else
|
|
|
|
cc="${CC-${cross_prefix}gcc}"
|
|
|
|
fi
|
|
|
|
|
2013-08-07 19:39:36 +04:00
|
|
|
if test -z "${CXX}${cross_prefix}"; then
|
|
|
|
cxx="c++"
|
|
|
|
else
|
|
|
|
cxx="${CXX-${cross_prefix}g++}"
|
|
|
|
fi
|
|
|
|
|
2011-08-05 02:10:08 +04:00
|
|
|
ar="${AR-${cross_prefix}ar}"
|
2016-07-08 07:49:36 +03:00
|
|
|
as="${AS-${cross_prefix}as}"
|
2016-06-23 20:39:18 +03:00
|
|
|
ccas="${CCAS-$cc}"
|
2013-01-05 14:10:27 +04:00
|
|
|
cpp="${CPP-$cc -E}"
|
2011-08-05 02:10:08 +04:00
|
|
|
objcopy="${OBJCOPY-${cross_prefix}objcopy}"
|
|
|
|
ld="${LD-${cross_prefix}ld}"
|
2017-11-08 04:10:46 +03:00
|
|
|
ranlib="${RANLIB-${cross_prefix}ranlib}"
|
2014-09-18 23:55:08 +04:00
|
|
|
nm="${NM-${cross_prefix}nm}"
|
2011-08-05 02:10:08 +04:00
|
|
|
strip="${STRIP-${cross_prefix}strip}"
|
|
|
|
windres="${WINDRES-${cross_prefix}windres}"
|
2012-01-31 23:03:45 +04:00
|
|
|
pkg_config_exe="${PKG_CONFIG-${cross_prefix}pkg-config}"
|
|
|
|
query_pkg_config() {
|
|
|
|
"${pkg_config_exe}" ${QEMU_PKG_CONFIG_FLAGS} "$@"
|
|
|
|
}
|
|
|
|
pkg_config=query_pkg_config
|
ui/sdl2 : initial port to SDL 2.0 (v2.0)
I've ported the SDL1.2 code over, and rewritten it to use the SDL2 interface.
The biggest changes were in the input handling, where SDL2 has done a major
overhaul, and I've had to include a generated translation file to get from
SDL2 codes back to qemu compatible ones. I'm still not sure how the keyboard
layout code works in qemu, so there may be further work if someone can point
me a test case that works with SDL1.2 and doesn't with SDL2.
Some SDL env vars we used to set are no longer used by SDL2,
Windows, OSX support is untested,
I don't think we can link to SDL1.2 and SDL2 at the same time, so I felt
using --with-sdlabi=2.0 to select the new code should be fine, like how
gtk does it.
v1.1: fix keys in text console
v1.2: fix shutdown, cleanups a bit of code, support ARGB cursor
v2.0: merge the SDL multihead patch into this, g_new the number of consoles
needed, wrap DCL inside per-console structure.
Signed-off-by: Dave Airlie <airlied@redhat.com>
Fixes & improvements by kraxel:
* baum build fix
* remove text console logic
* adapt to new input core
* codestyle fixups
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
2013-12-10 08:05:51 +04:00
|
|
|
sdl2_config="${SDL2_CONFIG-${cross_prefix}sdl2-config}"
|
2008-12-29 20:14:15 +03:00
|
|
|
|
2013-10-22 00:03:06 +04:00
|
|
|
# If the user hasn't specified ARFLAGS, default to 'rv', just as make does.
|
|
|
|
ARFLAGS="${ARFLAGS-rv}"
|
|
|
|
|
2009-11-11 14:50:09 +03:00
|
|
|
# default flags for all hosts
|
2016-09-12 16:10:08 +03:00
|
|
|
# We use -fwrapv to tell the compiler that we require a C dialect where
|
|
|
|
# left shift of signed integers is well defined and has the expected
|
|
|
|
# 2s-complement style results. (Both clang and gcc agree that it
|
|
|
|
# provides these semantics.)
|
2020-02-03 17:22:17 +03:00
|
|
|
QEMU_CFLAGS="-fno-strict-aliasing -fno-common -fwrapv $QEMU_CFLAGS"
|
|
|
|
QEMU_CFLAGS="-Wundef -Wwrite-strings -Wmissing-prototypes $QEMU_CFLAGS"
|
2013-02-23 00:08:51 +04:00
|
|
|
QEMU_CFLAGS="-Wstrict-prototypes -Wredundant-decls $QEMU_CFLAGS"
|
2009-11-11 14:50:09 +03:00
|
|
|
QEMU_CFLAGS="-D_GNU_SOURCE -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE $QEMU_CFLAGS"
|
2020-09-23 12:26:15 +03:00
|
|
|
|
|
|
|
# Flags that are needed during configure but later taken care of by Meson
|
|
|
|
CONFIGURE_CFLAGS="-std=gnu99 -Wall"
|
|
|
|
CONFIGURE_LDFLAGS=
|
2020-02-03 17:22:17 +03:00
|
|
|
|
2009-11-11 14:50:09 +03:00
|
|
|
|
2008-12-29 20:14:15 +03:00
|
|
|
check_define() {
|
|
|
|
cat > $TMPC <<EOF
|
|
|
|
#if !defined($1)
|
2011-11-23 21:26:43 +04:00
|
|
|
#error $1 not defined
|
2008-12-29 20:14:15 +03:00
|
|
|
#endif
|
|
|
|
int main(void) { return 0; }
|
|
|
|
EOF
|
2009-08-03 16:46:03 +04:00
|
|
|
compile_object
|
2008-12-29 20:14:15 +03:00
|
|
|
}
|
|
|
|
|
2015-06-10 10:07:35 +03:00
|
|
|
check_include() {
|
|
|
|
cat > $TMPC <<EOF
|
|
|
|
#include <$1>
|
|
|
|
int main(void) { return 0; }
|
|
|
|
EOF
|
|
|
|
compile_object
|
|
|
|
}
|
|
|
|
|
2015-03-26 01:57:37 +03:00
|
|
|
write_c_skeleton() {
|
|
|
|
cat > $TMPC <<EOF
|
|
|
|
int main(void) { return 0; }
|
|
|
|
EOF
|
|
|
|
}
|
|
|
|
|
2020-02-20 07:11:14 +03:00
|
|
|
write_c_fuzzer_skeleton() {
|
|
|
|
cat > $TMPC <<EOF
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <sys/types.h>
|
|
|
|
int LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size);
|
|
|
|
int LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size) { return 0; }
|
|
|
|
EOF
|
|
|
|
}
|
|
|
|
|
2012-08-14 18:35:34 +04:00
|
|
|
if check_define __linux__ ; then
|
|
|
|
targetos="Linux"
|
|
|
|
elif check_define _WIN32 ; then
|
|
|
|
targetos='MINGW32'
|
|
|
|
elif check_define __OpenBSD__ ; then
|
|
|
|
targetos='OpenBSD'
|
|
|
|
elif check_define __sun__ ; then
|
|
|
|
targetos='SunOS'
|
|
|
|
elif check_define __HAIKU__ ; then
|
|
|
|
targetos='Haiku'
|
2017-07-13 18:15:32 +03:00
|
|
|
elif check_define __FreeBSD__ ; then
|
|
|
|
targetos='FreeBSD'
|
|
|
|
elif check_define __FreeBSD_kernel__ && check_define __GLIBC__; then
|
|
|
|
targetos='GNU/kFreeBSD'
|
|
|
|
elif check_define __DragonFly__ ; then
|
|
|
|
targetos='DragonFly'
|
|
|
|
elif check_define __NetBSD__; then
|
|
|
|
targetos='NetBSD'
|
|
|
|
elif check_define __APPLE__; then
|
|
|
|
targetos='Darwin'
|
2012-08-14 18:35:34 +04:00
|
|
|
else
|
2017-07-13 18:15:32 +03:00
|
|
|
# This is a fatal error, but don't report it yet, because we
|
|
|
|
# might be going to just print the --help text, or it might
|
|
|
|
# be the result of a missing compiler.
|
|
|
|
targetos='bogus'
|
2012-08-14 18:35:34 +04:00
|
|
|
fi
|
|
|
|
|
|
|
|
# Some host OSes need non-standard checks for which CPU to use.
|
|
|
|
# Note that these checks are broken for cross-compilation: if you're
|
|
|
|
# cross-compiling to one of these OSes then you'll need to specify
|
|
|
|
# the correct CPU with the --cpu option.
|
|
|
|
case $targetos in
|
|
|
|
Darwin)
|
|
|
|
# on Leopard most of the system is 32-bit, so we have to ask the kernel if we can
|
|
|
|
# run 64-bit userspace code.
|
|
|
|
# If the user didn't specify a CPU explicitly and the kernel says this is
|
|
|
|
# 64 bit hw, then assume x86_64. Otherwise fall through to the usual detection code.
|
|
|
|
if test -z "$cpu" && test "$(sysctl -n hw.optional.x86_64)" = "1"; then
|
|
|
|
cpu="x86_64"
|
|
|
|
fi
|
2020-10-27 15:06:03 +03:00
|
|
|
HOST_DSOSUF=".dylib"
|
2012-08-14 18:35:34 +04:00
|
|
|
;;
|
|
|
|
SunOS)
|
2016-05-16 16:10:20 +03:00
|
|
|
# $(uname -m) returns i86pc even on an x86_64 box, so default based on isainfo
|
2012-08-14 18:35:34 +04:00
|
|
|
if test -z "$cpu" && test "$(isainfo -k)" = "amd64"; then
|
|
|
|
cpu="x86_64"
|
|
|
|
fi
|
|
|
|
esac
|
|
|
|
|
2009-08-03 16:45:55 +04:00
|
|
|
if test ! -z "$cpu" ; then
|
|
|
|
# command line argument
|
|
|
|
:
|
|
|
|
elif check_define __i386__ ; then
|
2008-12-29 20:14:15 +03:00
|
|
|
cpu="i386"
|
|
|
|
elif check_define __x86_64__ ; then
|
2013-08-20 23:20:05 +04:00
|
|
|
if check_define __ILP32__ ; then
|
|
|
|
cpu="x32"
|
|
|
|
else
|
|
|
|
cpu="x86_64"
|
|
|
|
fi
|
2008-12-31 19:55:26 +03:00
|
|
|
elif check_define __sparc__ ; then
|
|
|
|
if check_define __arch64__ ; then
|
|
|
|
cpu="sparc64"
|
|
|
|
else
|
|
|
|
cpu="sparc"
|
|
|
|
fi
|
2009-01-14 21:39:52 +03:00
|
|
|
elif check_define _ARCH_PPC ; then
|
|
|
|
if check_define _ARCH_PPC64 ; then
|
2019-05-02 01:38:18 +03:00
|
|
|
if check_define _LITTLE_ENDIAN ; then
|
|
|
|
cpu="ppc64le"
|
|
|
|
else
|
|
|
|
cpu="ppc64"
|
|
|
|
fi
|
2009-01-14 21:39:52 +03:00
|
|
|
else
|
|
|
|
cpu="ppc"
|
|
|
|
fi
|
2009-10-17 16:17:47 +04:00
|
|
|
elif check_define __mips__ ; then
|
|
|
|
cpu="mips"
|
2010-06-13 14:28:21 +04:00
|
|
|
elif check_define __s390__ ; then
|
|
|
|
if check_define __s390x__ ; then
|
|
|
|
cpu="s390x"
|
|
|
|
else
|
|
|
|
cpu="s390"
|
|
|
|
fi
|
2018-12-19 22:20:19 +03:00
|
|
|
elif check_define __riscv ; then
|
|
|
|
if check_define _LP64 ; then
|
|
|
|
cpu="riscv64"
|
|
|
|
else
|
|
|
|
cpu="riscv32"
|
|
|
|
fi
|
2011-11-30 13:57:48 +04:00
|
|
|
elif check_define __arm__ ; then
|
|
|
|
cpu="arm"
|
2013-06-12 19:20:23 +04:00
|
|
|
elif check_define __aarch64__ ; then
|
|
|
|
cpu="aarch64"
|
2008-12-29 20:14:15 +03:00
|
|
|
else
|
2016-05-16 16:10:20 +03:00
|
|
|
cpu=$(uname -m)
|
2008-12-29 20:14:15 +03:00
|
|
|
fi
|
|
|
|
|
2011-12-24 17:07:25 +04:00
|
|
|
ARCH=
|
|
|
|
# Normalise host CPU name and set ARCH.
|
|
|
|
# Note that this case should only have supported host CPUs, not guests.
|
2003-03-07 02:23:54 +03:00
|
|
|
case "$cpu" in
|
2019-09-28 22:03:34 +03:00
|
|
|
ppc|ppc64|s390x|sparc64|x32|riscv32|riscv64)
|
2017-03-21 17:31:57 +03:00
|
|
|
;;
|
2019-05-02 01:38:18 +03:00
|
|
|
ppc64le)
|
|
|
|
ARCH="ppc64"
|
|
|
|
;;
|
2003-03-07 02:23:54 +03:00
|
|
|
i386|i486|i586|i686|i86pc|BePC)
|
2003-08-11 01:36:04 +04:00
|
|
|
cpu="i386"
|
2003-03-07 02:23:54 +03:00
|
|
|
;;
|
2008-04-12 02:04:22 +04:00
|
|
|
x86_64|amd64)
|
|
|
|
cpu="x86_64"
|
|
|
|
;;
|
2011-11-30 13:57:48 +04:00
|
|
|
armv*b|armv*l|arm)
|
|
|
|
cpu="arm"
|
2003-03-07 02:23:54 +03:00
|
|
|
;;
|
2013-06-12 19:20:23 +04:00
|
|
|
aarch64)
|
|
|
|
cpu="aarch64"
|
|
|
|
;;
|
2009-10-17 16:17:47 +04:00
|
|
|
mips*)
|
|
|
|
cpu="mips"
|
|
|
|
;;
|
2007-04-16 22:27:06 +04:00
|
|
|
sparc|sun4[cdmuv])
|
2003-05-13 22:59:59 +04:00
|
|
|
cpu="sparc"
|
|
|
|
;;
|
2003-03-07 02:23:54 +03:00
|
|
|
*)
|
2011-12-24 17:07:25 +04:00
|
|
|
# This will result in either an error or falling back to TCI later
|
|
|
|
ARCH=unknown
|
2003-03-07 02:23:54 +03:00
|
|
|
;;
|
|
|
|
esac
|
2011-12-24 17:07:25 +04:00
|
|
|
if test -z "$ARCH"; then
|
|
|
|
ARCH="$cpu"
|
|
|
|
fi
|
2009-08-12 20:20:24 +04:00
|
|
|
|
2003-03-07 02:23:54 +03:00
|
|
|
# OS specific
|
2009-08-03 16:46:13 +04:00
|
|
|
|
2003-03-07 02:23:54 +03:00
|
|
|
case $targetos in
|
2004-04-01 03:37:16 +04:00
|
|
|
MINGW32*)
|
2009-08-03 16:46:13 +04:00
|
|
|
mingw32="yes"
|
2015-06-04 00:03:46 +03:00
|
|
|
audio_possible_drivers="dsound sdl"
|
2015-06-10 10:07:35 +03:00
|
|
|
if check_include dsound.h; then
|
|
|
|
audio_drv_list="dsound"
|
|
|
|
else
|
|
|
|
audio_drv_list=""
|
|
|
|
fi
|
2017-03-21 17:31:57 +03:00
|
|
|
supported_os="yes"
|
2020-08-24 19:31:09 +03:00
|
|
|
pie="no"
|
2004-04-01 03:37:16 +04:00
|
|
|
;;
|
2007-06-23 20:03:36 +04:00
|
|
|
GNU/kFreeBSD)
|
2009-11-29 20:00:41 +03:00
|
|
|
bsd="yes"
|
2019-01-24 14:20:55 +03:00
|
|
|
audio_drv_list="oss try-sdl"
|
2015-06-04 00:03:44 +03:00
|
|
|
audio_possible_drivers="oss sdl pa"
|
2007-06-23 20:03:36 +04:00
|
|
|
;;
|
2004-05-12 23:32:15 +04:00
|
|
|
FreeBSD)
|
2009-08-03 16:46:13 +04:00
|
|
|
bsd="yes"
|
2010-12-23 13:43:49 +03:00
|
|
|
make="${MAKE-gmake}"
|
2019-01-24 14:20:55 +03:00
|
|
|
audio_drv_list="oss try-sdl"
|
2015-06-04 00:03:44 +03:00
|
|
|
audio_possible_drivers="oss sdl pa"
|
2010-03-26 00:32:16 +03:00
|
|
|
# needed for kinfo_getvmmap(3) in libutil.h
|
2013-11-06 14:44:06 +04:00
|
|
|
netmap="" # enable netmap autodetect
|
2004-05-12 23:32:15 +04:00
|
|
|
;;
|
2009-03-07 23:06:23 +03:00
|
|
|
DragonFly)
|
2009-08-03 16:46:13 +04:00
|
|
|
bsd="yes"
|
2010-12-23 13:43:49 +03:00
|
|
|
make="${MAKE-gmake}"
|
2019-01-24 14:20:55 +03:00
|
|
|
audio_drv_list="oss try-sdl"
|
2015-06-04 00:03:44 +03:00
|
|
|
audio_possible_drivers="oss sdl pa"
|
2009-03-07 23:06:23 +03:00
|
|
|
;;
|
2004-05-12 23:32:15 +04:00
|
|
|
NetBSD)
|
2009-08-03 16:46:13 +04:00
|
|
|
bsd="yes"
|
2010-12-23 13:43:49 +03:00
|
|
|
make="${MAKE-gmake}"
|
2019-01-24 14:20:55 +03:00
|
|
|
audio_drv_list="oss try-sdl"
|
2015-06-04 00:03:44 +03:00
|
|
|
audio_possible_drivers="oss sdl"
|
2009-08-03 16:46:13 +04:00
|
|
|
oss_lib="-lossaudio"
|
2004-05-12 23:32:15 +04:00
|
|
|
;;
|
|
|
|
OpenBSD)
|
2009-08-03 16:46:13 +04:00
|
|
|
bsd="yes"
|
2010-12-23 13:43:49 +03:00
|
|
|
make="${MAKE-gmake}"
|
2019-01-24 14:20:52 +03:00
|
|
|
audio_drv_list="try-sdl"
|
2015-06-04 00:03:44 +03:00
|
|
|
audio_possible_drivers="sdl"
|
2004-05-12 23:32:15 +04:00
|
|
|
;;
|
2004-07-06 01:25:26 +04:00
|
|
|
Darwin)
|
2009-08-03 16:46:13 +04:00
|
|
|
bsd="yes"
|
|
|
|
darwin="yes"
|
|
|
|
if [ "$cpu" = "x86_64" ] ; then
|
2009-08-03 16:46:21 +04:00
|
|
|
QEMU_CFLAGS="-arch x86_64 $QEMU_CFLAGS"
|
build-sys: clean up flags included in the linker command line
Some of the CFLAGS that are discovered during configure, for example
compiler warnings, are being included on the linker command line because
QEMU_CFLAGS is added to it. Other flags, such as the -m32, appear twice
because they are included in both QEMU_CFLAGS and LDFLAGS. All this
leads to confusion with respect to what goes in which Makefile variables
(and we have plenty).
So, introduce QEMU_LDFLAGS for flags discovered by configure, following
the lead of QEMU_CFLAGS, and stop adding to it:
1) options that are already in CFLAGS, for example "-g"
2) duplicate options
At the same time, options that _are_ needed by both compiler and linker
must now be added to both QEMU_CFLAGS and QEMU_LDFLAGS, which is clearer.
This is mostly -fsanitize options. For now, --extra-cflags has this behavior
(but --extra-cxxflags does not).
Meson will not include CFLAGS on the linker command line, do the same in our
build system as well.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
2019-12-11 17:34:27 +03:00
|
|
|
QEMU_LDFLAGS="-arch x86_64 $QEMU_LDFLAGS"
|
2009-08-03 16:46:13 +04:00
|
|
|
fi
|
2020-09-01 18:28:59 +03:00
|
|
|
cocoa="enabled"
|
2019-01-24 14:20:55 +03:00
|
|
|
audio_drv_list="coreaudio try-sdl"
|
2015-06-04 00:03:45 +03:00
|
|
|
audio_possible_drivers="coreaudio sdl"
|
build-sys: clean up flags included in the linker command line
Some of the CFLAGS that are discovered during configure, for example
compiler warnings, are being included on the linker command line because
QEMU_CFLAGS is added to it. Other flags, such as the -m32, appear twice
because they are included in both QEMU_CFLAGS and LDFLAGS. All this
leads to confusion with respect to what goes in which Makefile variables
(and we have plenty).
So, introduce QEMU_LDFLAGS for flags discovered by configure, following
the lead of QEMU_CFLAGS, and stop adding to it:
1) options that are already in CFLAGS, for example "-g"
2) duplicate options
At the same time, options that _are_ needed by both compiler and linker
must now be added to both QEMU_CFLAGS and QEMU_LDFLAGS, which is clearer.
This is mostly -fsanitize options. For now, --extra-cflags has this behavior
(but --extra-cxxflags does not).
Meson will not include CFLAGS on the linker command line, do the same in our
build system as well.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
2019-12-11 17:34:27 +03:00
|
|
|
QEMU_LDFLAGS="-framework CoreFoundation -framework IOKit $QEMU_LDFLAGS"
|
2012-08-12 01:34:39 +04:00
|
|
|
# Disable attempts to use ObjectiveC features in os/object.h since they
|
|
|
|
# won't work when we're compiling with gcc as a C compiler.
|
|
|
|
QEMU_CFLAGS="-DOS_OBJECT_USE_OBJC=0 $QEMU_CFLAGS"
|
2004-07-06 01:25:26 +04:00
|
|
|
;;
|
2006-04-26 02:36:06 +04:00
|
|
|
SunOS)
|
2009-08-03 16:46:13 +04:00
|
|
|
solaris="yes"
|
2010-12-23 13:43:49 +03:00
|
|
|
make="${MAKE-gmake}"
|
2011-09-03 00:53:28 +04:00
|
|
|
smbd="${SMBD-/usr/sfw/sbin/smbd}"
|
2009-08-03 16:46:13 +04:00
|
|
|
if test -f /usr/include/sys/soundcard.h ; then
|
2019-01-24 14:20:55 +03:00
|
|
|
audio_drv_list="oss try-sdl"
|
2009-08-03 16:46:13 +04:00
|
|
|
fi
|
|
|
|
audio_possible_drivers="oss sdl"
|
2009-09-12 16:36:04 +04:00
|
|
|
# needed for CMSG_ macros in sys/socket.h
|
|
|
|
QEMU_CFLAGS="-D_XOPEN_SOURCE=600 $QEMU_CFLAGS"
|
|
|
|
# needed for TIOCWIN* defines in termios.h
|
|
|
|
QEMU_CFLAGS="-D__EXTENSIONS__ $QEMU_CFLAGS"
|
2007-02-11 03:31:33 +03:00
|
|
|
;;
|
2010-09-20 02:50:43 +04:00
|
|
|
Haiku)
|
|
|
|
haiku="yes"
|
2020-11-14 11:51:22 +03:00
|
|
|
QEMU_CFLAGS="-DB_USE_POSITIVE_POSIX_ERRORS -D_BSD_SOURCE $QEMU_CFLAGS"
|
2010-09-20 02:50:43 +04:00
|
|
|
;;
|
2017-03-21 17:31:57 +03:00
|
|
|
Linux)
|
2019-02-19 15:42:57 +03:00
|
|
|
audio_drv_list="try-pa oss"
|
2015-06-04 00:03:44 +03:00
|
|
|
audio_possible_drivers="oss alsa sdl pa"
|
2009-08-03 16:46:13 +04:00
|
|
|
linux="yes"
|
|
|
|
linux_user="yes"
|
2020-12-10 22:04:13 +03:00
|
|
|
vhost_user=${default_feature:-yes}
|
2017-03-21 17:31:57 +03:00
|
|
|
;;
|
2003-03-07 02:23:54 +03:00
|
|
|
esac
|
|
|
|
|
2004-05-12 23:32:15 +04:00
|
|
|
if [ "$bsd" = "yes" ] ; then
|
2006-04-16 17:28:56 +04:00
|
|
|
if [ "$darwin" != "yes" ] ; then
|
2012-04-26 13:57:39 +04:00
|
|
|
bsd_user="yes"
|
2004-07-06 01:25:26 +04:00
|
|
|
fi
|
2004-05-12 23:32:15 +04:00
|
|
|
fi
|
|
|
|
|
2010-12-23 13:43:49 +03:00
|
|
|
: ${make=${MAKE-make}}
|
2020-09-01 13:38:04 +03:00
|
|
|
|
2019-03-27 20:07:01 +03:00
|
|
|
# We prefer python 3.x. A bare 'python' is traditionally
|
|
|
|
# python 2.x, but some distros have it as python 3.x, so
|
2019-10-17 01:42:37 +03:00
|
|
|
# we check that too
|
2019-03-27 20:07:01 +03:00
|
|
|
python=
|
2019-08-21 10:21:16 +03:00
|
|
|
explicit_python=no
|
2019-10-17 01:42:37 +03:00
|
|
|
for binary in "${PYTHON-python3}" python
|
2019-03-27 20:07:01 +03:00
|
|
|
do
|
|
|
|
if has "$binary"
|
|
|
|
then
|
2019-06-10 13:03:44 +03:00
|
|
|
python=$(command -v "$binary")
|
2019-03-27 20:07:01 +03:00
|
|
|
break
|
|
|
|
fi
|
|
|
|
done
|
2020-02-14 20:18:41 +03:00
|
|
|
|
|
|
|
|
2020-03-03 18:06:20 +03:00
|
|
|
# Check for ancillary tools used in testing
|
|
|
|
genisoimage=
|
2020-05-19 16:22:48 +03:00
|
|
|
for binary in genisoimage mkisofs
|
2020-03-03 18:06:20 +03:00
|
|
|
do
|
|
|
|
if has $binary
|
|
|
|
then
|
|
|
|
genisoimage=$(command -v "$binary")
|
|
|
|
break
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
2011-09-03 00:53:28 +04:00
|
|
|
: ${smbd=${SMBD-/usr/sbin/smbd}}
|
2010-12-23 13:43:49 +03:00
|
|
|
|
2012-08-12 01:34:40 +04:00
|
|
|
# Default objcc to clang if available, otherwise use CC
|
|
|
|
if has clang; then
|
|
|
|
objcc=clang
|
|
|
|
else
|
|
|
|
objcc="$cc"
|
|
|
|
fi
|
|
|
|
|
2009-08-03 16:46:07 +04:00
|
|
|
if test "$mingw32" = "yes" ; then
|
|
|
|
EXESUF=".exe"
|
2019-12-12 15:30:36 +03:00
|
|
|
HOST_DSOSUF=".dll"
|
2015-11-26 14:13:12 +03:00
|
|
|
# MinGW needs -mthreads for TLS and macro _MT.
|
2020-09-23 12:26:15 +03:00
|
|
|
CONFIGURE_CFLAGS="-mthreads $CONFIGURE_CFLAGS"
|
2015-03-26 01:57:37 +03:00
|
|
|
write_c_skeleton;
|
2020-08-18 13:17:01 +03:00
|
|
|
prefix="/qemu"
|
2020-08-26 14:04:12 +03:00
|
|
|
qemu_suffix=""
|
2017-08-22 16:55:04 +03:00
|
|
|
libs_qga="-lws2_32 -lwinmm -lpowrprof -lwtsapi32 -lwininet -liphlpapi -lnetapi32 $libs_qga"
|
2009-08-03 16:46:07 +04:00
|
|
|
fi
|
|
|
|
|
2009-06-11 22:28:25 +04:00
|
|
|
werror=""
|
2007-11-11 23:17:03 +03:00
|
|
|
|
2003-03-07 02:23:54 +03:00
|
|
|
for opt do
|
2016-05-16 16:10:20 +03:00
|
|
|
optarg=$(expr "x$opt" : 'x[^=]*=\(.*\)')
|
2003-03-07 02:23:54 +03:00
|
|
|
case "$opt" in
|
2005-12-18 22:14:49 +03:00
|
|
|
--help|-h) show_help=yes
|
|
|
|
;;
|
2011-04-07 09:12:28 +04:00
|
|
|
--version|-V) exec cat $source_path/VERSION
|
|
|
|
;;
|
2006-04-16 17:28:56 +04:00
|
|
|
--prefix=*) prefix="$optarg"
|
2003-03-07 02:23:54 +03:00
|
|
|
;;
|
2006-04-16 17:28:56 +04:00
|
|
|
--interp-prefix=*) interp_prefix="$optarg"
|
2003-04-11 04:16:16 +04:00
|
|
|
;;
|
2008-12-29 20:14:15 +03:00
|
|
|
--cross-prefix=*)
|
2003-03-07 02:23:54 +03:00
|
|
|
;;
|
2008-12-29 20:14:15 +03:00
|
|
|
--cc=*)
|
2003-03-07 02:23:54 +03:00
|
|
|
;;
|
2006-04-16 17:28:56 +04:00
|
|
|
--host-cc=*) host_cc="$optarg"
|
2005-07-23 18:27:54 +04:00
|
|
|
;;
|
2013-08-07 19:39:36 +04:00
|
|
|
--cxx=*)
|
|
|
|
;;
|
2013-11-24 13:38:05 +04:00
|
|
|
--iasl=*) iasl="$optarg"
|
|
|
|
;;
|
2012-08-12 01:34:40 +04:00
|
|
|
--objcc=*) objcc="$optarg"
|
|
|
|
;;
|
2006-04-16 17:28:56 +04:00
|
|
|
--make=*) make="$optarg"
|
2003-03-07 02:23:54 +03:00
|
|
|
;;
|
2020-09-01 13:38:04 +03:00
|
|
|
--install=*)
|
2006-04-17 17:57:12 +04:00
|
|
|
;;
|
2019-08-21 10:21:16 +03:00
|
|
|
--python=*) python="$optarg" ; explicit_python=yes
|
2011-07-23 01:08:09 +04:00
|
|
|
;;
|
2020-02-13 20:56:18 +03:00
|
|
|
--sphinx-build=*) sphinx_build="$optarg"
|
|
|
|
;;
|
2019-06-10 13:05:14 +03:00
|
|
|
--skip-meson) skip_meson=yes
|
|
|
|
;;
|
|
|
|
--meson=*) meson="$optarg"
|
|
|
|
;;
|
2020-08-26 09:04:15 +03:00
|
|
|
--ninja=*) ninja="$optarg"
|
|
|
|
;;
|
2011-09-03 00:53:28 +04:00
|
|
|
--smbd=*) smbd="$optarg"
|
|
|
|
;;
|
2009-08-03 16:46:02 +04:00
|
|
|
--extra-cflags=*)
|
2003-03-07 02:23:54 +03:00
|
|
|
;;
|
2017-06-06 16:07:47 +03:00
|
|
|
--extra-cxxflags=*)
|
|
|
|
;;
|
2009-08-03 16:46:02 +04:00
|
|
|
--extra-ldflags=*)
|
2003-03-07 02:23:54 +03:00
|
|
|
;;
|
2012-02-08 16:54:13 +04:00
|
|
|
--enable-debug-info)
|
|
|
|
;;
|
|
|
|
--disable-debug-info)
|
|
|
|
;;
|
2018-04-04 22:27:05 +03:00
|
|
|
--cross-cc-*)
|
|
|
|
;;
|
2014-02-10 10:48:56 +04:00
|
|
|
--enable-modules)
|
|
|
|
modules="yes"
|
2015-11-02 17:06:23 +03:00
|
|
|
;;
|
|
|
|
--disable-modules)
|
|
|
|
modules="no"
|
2014-02-10 10:48:56 +04:00
|
|
|
;;
|
2020-03-10 17:58:06 +03:00
|
|
|
--disable-module-upgrades) module_upgrades="no"
|
|
|
|
;;
|
|
|
|
--enable-module-upgrades) module_upgrades="yes"
|
|
|
|
;;
|
2009-08-03 16:45:55 +04:00
|
|
|
--cpu=*)
|
2003-03-07 02:23:54 +03:00
|
|
|
;;
|
2006-04-16 17:28:56 +04:00
|
|
|
--target-list=*) target_list="$optarg"
|
2019-03-19 14:59:12 +03:00
|
|
|
if test "$target_list_exclude"; then
|
|
|
|
error_exit "Can't mix --target-list with --target-list-exclude"
|
|
|
|
fi
|
|
|
|
;;
|
|
|
|
--target-list-exclude=*) target_list_exclude="$optarg"
|
|
|
|
if test "$target_list"; then
|
|
|
|
error_exit "Can't mix --target-list-exclude with --target-list"
|
|
|
|
fi
|
2003-06-16 00:25:43 +04:00
|
|
|
;;
|
2014-05-27 17:02:14 +04:00
|
|
|
--enable-trace-backends=*) trace_backends="$optarg"
|
|
|
|
;;
|
|
|
|
# XXX: backwards compatibility
|
|
|
|
--enable-trace-backend=*) trace_backends="$optarg"
|
2010-05-22 20:52:39 +04:00
|
|
|
;;
|
2010-12-23 13:44:02 +03:00
|
|
|
--with-trace-file=*) trace_file="$optarg"
|
2010-07-13 12:26:32 +04:00
|
|
|
;;
|
2020-11-20 10:38:22 +03:00
|
|
|
--with-default-devices) default_devices="true"
|
2019-01-23 09:56:17 +03:00
|
|
|
;;
|
2020-11-20 10:38:22 +03:00
|
|
|
--without-default-devices) default_devices="false"
|
2019-01-23 09:56:17 +03:00
|
|
|
;;
|
2020-12-10 22:04:13 +03:00
|
|
|
--without-default-features) # processed above
|
|
|
|
;;
|
2003-03-07 02:23:54 +03:00
|
|
|
--enable-gprof) gprof="yes"
|
|
|
|
;;
|
2012-05-01 22:45:39 +04:00
|
|
|
--enable-gcov) gcov="yes"
|
|
|
|
;;
|
2010-01-31 14:23:45 +03:00
|
|
|
--static)
|
|
|
|
static="yes"
|
2012-01-31 23:03:45 +04:00
|
|
|
QEMU_PKG_CONFIG_FLAGS="--static $QEMU_PKG_CONFIG_FLAGS"
|
2003-06-09 23:53:12 +04:00
|
|
|
;;
|
2010-05-26 18:08:26 +04:00
|
|
|
--mandir=*) mandir="$optarg"
|
|
|
|
;;
|
|
|
|
--bindir=*) bindir="$optarg"
|
|
|
|
;;
|
2011-05-15 13:08:59 +04:00
|
|
|
--libdir=*) libdir="$optarg"
|
|
|
|
;;
|
2012-06-07 01:11:00 +04:00
|
|
|
--libexecdir=*) libexecdir="$optarg"
|
|
|
|
;;
|
2011-06-27 13:58:20 +04:00
|
|
|
--includedir=*) includedir="$optarg"
|
|
|
|
;;
|
2012-04-18 23:55:49 +04:00
|
|
|
--datadir=*) datadir="$optarg"
|
2010-05-26 18:08:26 +04:00
|
|
|
;;
|
2020-08-26 14:04:12 +03:00
|
|
|
--with-suffix=*) qemu_suffix="$optarg"
|
2012-04-18 23:55:50 +04:00
|
|
|
;;
|
2020-10-15 22:07:42 +03:00
|
|
|
--docdir=*) docdir="$optarg"
|
2010-05-26 18:08:26 +04:00
|
|
|
;;
|
2020-10-16 11:35:10 +03:00
|
|
|
--localedir=*) localedir="$optarg"
|
|
|
|
;;
|
2010-03-08 16:09:48 +03:00
|
|
|
--sysconfdir=*) sysconfdir="$optarg"
|
2010-01-21 19:30:29 +03:00
|
|
|
;;
|
2012-10-04 01:35:57 +04:00
|
|
|
--localstatedir=*) local_statedir="$optarg"
|
|
|
|
;;
|
2017-09-14 14:42:36 +03:00
|
|
|
--firmwarepath=*) firmwarepath="$optarg"
|
|
|
|
;;
|
2018-04-18 10:50:44 +03:00
|
|
|
--host=*|--build=*|\
|
|
|
|
--disable-dependency-tracking|\
|
2012-10-04 01:35:57 +04:00
|
|
|
--sbindir=*|--sharedstatedir=*|\
|
2020-10-16 11:35:10 +03:00
|
|
|
--oldincludedir=*|--datarootdir=*|--infodir=*|\
|
2011-11-24 16:11:31 +04:00
|
|
|
--htmldir=*|--dvidir=*|--pdfdir=*|--psdir=*)
|
|
|
|
# These switches are silently ignored, for compatibility with
|
|
|
|
# autoconf-generated configure scripts. This allows QEMU's
|
|
|
|
# configure to be used by RPM and similar macros that set
|
|
|
|
# lots of directory switches by default.
|
|
|
|
;;
|
2020-02-06 16:17:15 +03:00
|
|
|
--disable-sdl) sdl="disabled"
|
2003-08-11 01:36:04 +04:00
|
|
|
;;
|
2020-02-06 16:17:15 +03:00
|
|
|
--enable-sdl) sdl="enabled"
|
2009-08-12 20:29:53 +04:00
|
|
|
;;
|
2020-02-06 16:17:15 +03:00
|
|
|
--disable-sdl-image) sdl_image="disabled"
|
2019-01-10 15:00:47 +03:00
|
|
|
;;
|
2020-02-06 16:17:15 +03:00
|
|
|
--enable-sdl-image) sdl_image="enabled"
|
2019-01-10 15:00:47 +03:00
|
|
|
;;
|
2013-05-10 16:16:40 +04:00
|
|
|
--disable-qom-cast-debug) qom_cast_debug="no"
|
|
|
|
;;
|
|
|
|
--enable-qom-cast-debug) qom_cast_debug="yes"
|
|
|
|
;;
|
2020-11-17 16:46:21 +03:00
|
|
|
--disable-virtfs) virtfs="disabled"
|
2012-02-24 12:30:42 +04:00
|
|
|
;;
|
2020-11-17 16:46:21 +03:00
|
|
|
--enable-virtfs) virtfs="enabled"
|
2012-02-24 12:30:42 +04:00
|
|
|
;;
|
2020-10-15 13:09:27 +03:00
|
|
|
--disable-libudev) libudev="disabled"
|
|
|
|
;;
|
|
|
|
--enable-libudev) libudev="enabled"
|
|
|
|
;;
|
2020-10-08 13:31:33 +03:00
|
|
|
--disable-virtiofsd) virtiofsd="disabled"
|
|
|
|
;;
|
|
|
|
--enable-virtiofsd) virtiofsd="enabled"
|
|
|
|
;;
|
2020-09-16 19:07:29 +03:00
|
|
|
--disable-mpath) mpath="disabled"
|
2017-08-22 07:50:55 +03:00
|
|
|
;;
|
2020-09-16 19:07:29 +03:00
|
|
|
--enable-mpath) mpath="enabled"
|
2017-08-22 07:50:55 +03:00
|
|
|
;;
|
2020-02-06 17:48:52 +03:00
|
|
|
--disable-vnc) vnc="disabled"
|
2011-03-16 15:33:36 +03:00
|
|
|
;;
|
2020-02-06 17:48:52 +03:00
|
|
|
--enable-vnc) vnc="enabled"
|
2011-03-16 15:33:36 +03:00
|
|
|
;;
|
2020-12-10 22:04:12 +03:00
|
|
|
--disable-gettext) gettext="disabled"
|
2019-09-19 20:02:09 +03:00
|
|
|
;;
|
2020-12-10 22:04:12 +03:00
|
|
|
--enable-gettext) gettext="enabled"
|
2019-09-19 20:02:09 +03:00
|
|
|
;;
|
2008-08-21 22:00:53 +04:00
|
|
|
--oss-lib=*) oss_lib="$optarg"
|
|
|
|
;;
|
2008-06-26 01:04:05 +04:00
|
|
|
--audio-drv-list=*) audio_drv_list="$optarg"
|
2004-11-14 22:57:29 +03:00
|
|
|
;;
|
2016-05-16 16:10:20 +03:00
|
|
|
--block-drv-rw-whitelist=*|--block-drv-whitelist=*) block_drv_rw_whitelist=$(echo "$optarg" | sed -e 's/,/ /g')
|
2013-05-29 15:35:40 +04:00
|
|
|
;;
|
2016-05-16 16:10:20 +03:00
|
|
|
--block-drv-ro-whitelist=*) block_drv_ro_whitelist=$(echo "$optarg" | sed -e 's/,/ /g')
|
2009-10-27 20:41:44 +03:00
|
|
|
;;
|
2009-04-13 22:45:38 +04:00
|
|
|
--enable-debug-tcg) debug_tcg="yes"
|
|
|
|
;;
|
|
|
|
--disable-debug-tcg) debug_tcg="no"
|
|
|
|
;;
|
2009-06-04 14:39:04 +04:00
|
|
|
--enable-debug)
|
|
|
|
# Enable debugging options that aren't excessively noisy
|
|
|
|
debug_tcg="yes"
|
2018-04-25 05:54:59 +03:00
|
|
|
debug_mutex="yes"
|
2009-06-04 14:39:04 +04:00
|
|
|
debug="yes"
|
|
|
|
strip_opt="no"
|
2015-11-03 23:43:42 +03:00
|
|
|
fortify_source="no"
|
2009-06-04 14:39:04 +04:00
|
|
|
;;
|
2018-01-16 18:11:51 +03:00
|
|
|
--enable-sanitizers) sanitizers="yes"
|
|
|
|
;;
|
|
|
|
--disable-sanitizers) sanitizers="no"
|
|
|
|
;;
|
2020-06-12 22:02:23 +03:00
|
|
|
--enable-tsan) tsan="yes"
|
|
|
|
;;
|
|
|
|
--disable-tsan) tsan="no"
|
|
|
|
;;
|
2020-09-01 14:51:16 +03:00
|
|
|
--enable-sparse) sparse="enabled"
|
2008-10-07 23:16:17 +04:00
|
|
|
;;
|
2020-09-01 14:51:16 +03:00
|
|
|
--disable-sparse) sparse="disabled"
|
2008-10-07 23:16:17 +04:00
|
|
|
;;
|
2009-04-05 21:41:02 +04:00
|
|
|
--disable-strip) strip_opt="no"
|
|
|
|
;;
|
2020-02-06 17:48:52 +03:00
|
|
|
--disable-vnc-sasl) vnc_sasl="disabled"
|
Add SASL authentication support ("Daniel P. Berrange")
This patch adds the new SASL authentication protocol to the VNC server.
It is enabled by setting the 'sasl' flag when launching VNC. SASL can
optionally provide encryption via its SSF layer, if a suitable mechanism
is configured (eg, GSSAPI/Kerberos, or Digest-MD5). If an SSF layer is
not available, then it should be combined with the x509 VNC authentication
protocol which provides encryption.
eg, if using GSSAPI
qemu -vnc localhost:1,sasl
eg if using TLS/x509 for encryption
qemu -vnc localhost:1,sasl,tls,x509
By default the Cyrus SASL library will look for its configuration in
the file /etc/sasl2/qemu.conf. For non-root users, this can be overridden
by setting the SASL_CONF_PATH environment variable, eg to make it look in
$HOME/.sasl2. NB unprivileged users may not have access to the full range
of SASL mechanisms, since some of them require some administrative privileges
to configure. The patch includes an example SASL configuration file which
illustrates config for GSSAPI and Digest-MD5, though it should be noted that
the latter is not really considered secure any more.
Most of the SASL authentication code is located in a separate source file,
vnc-auth-sasl.c. The main vnc.c file only contains minimal integration
glue, specifically parsing of command line flags / setup, and calls to
start the SASL auth process, to do encoding/decoding for data.
There are several possible stacks for reading & writing of data, depending
on the combo of VNC authentication methods in use
- Clear. read/write straight to socket
- TLS. read/write via GNUTLS helpers
- SASL. encode/decode via SASL SSF layer, then read/write to socket
- SASL+TLS. encode/decode via SASL SSF layer, then read/write via GNUTLS
Hence, the vnc_client_read & vnc_client_write methods have been refactored
a little.
vnc_client_read: main entry point for reading, calls either
- vnc_client_read_plain reading, with no intermediate decoding
- vnc_client_read_sasl reading, with SASL SSF decoding
These two methods, then call vnc_client_read_buf(). This decides
whether to write to the socket directly or write via GNUTLS.
The situation is the same for writing data. More extensive comments
have been added in the code / patch. The vnc_client_read_sasl and
vnc_client_write_sasl method implementations live in the separate
vnc-auth-sasl.c file.
The state required for the SASL auth mechanism is kept in a separate
VncStateSASL struct, defined in vnc-auth-sasl.h and included in the
main VncState.
The configure script probes for SASL and automatically enables it
if found, unless --disable-vnc-sasl was given to override it.
Makefile | 7
Makefile.target | 5
b/qemu.sasl | 34 ++
b/vnc-auth-sasl.c | 626 ++++++++++++++++++++++++++++++++++++++++++++++++++++
b/vnc-auth-sasl.h | 67 +++++
configure | 34 ++
qemu-doc.texi | 97 ++++++++
vnc-auth-vencrypt.c | 12
vnc.c | 249 ++++++++++++++++++--
vnc.h | 31 ++
10 files changed, 1129 insertions(+), 33 deletions(-)
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@6724 c046a42c-6fe2-441c-8c8c-71466251a162
2009-03-06 23:27:28 +03:00
|
|
|
;;
|
2020-02-06 17:48:52 +03:00
|
|
|
--enable-vnc-sasl) vnc_sasl="enabled"
|
2009-08-12 20:20:29 +04:00
|
|
|
;;
|
2020-02-06 17:48:52 +03:00
|
|
|
--disable-vnc-jpeg) vnc_jpeg="disabled"
|
2010-07-07 22:57:49 +04:00
|
|
|
;;
|
2020-02-06 17:48:52 +03:00
|
|
|
--enable-vnc-jpeg) vnc_jpeg="enabled"
|
2010-07-07 22:57:49 +04:00
|
|
|
;;
|
2020-02-06 17:48:52 +03:00
|
|
|
--disable-vnc-png) vnc_png="disabled"
|
2010-07-07 22:57:56 +04:00
|
|
|
;;
|
2020-02-06 17:48:52 +03:00
|
|
|
--enable-vnc-png) vnc_png="enabled"
|
2010-07-07 22:57:56 +04:00
|
|
|
;;
|
2020-10-05 12:31:15 +03:00
|
|
|
--disable-slirp) slirp="disabled"
|
2005-10-30 21:58:22 +03:00
|
|
|
;;
|
2020-11-20 13:19:38 +03:00
|
|
|
--enable-slirp) slirp="enabled"
|
|
|
|
;;
|
2020-10-05 12:31:15 +03:00
|
|
|
--enable-slirp=git) slirp="internal"
|
2019-04-24 14:00:41 +03:00
|
|
|
;;
|
2019-02-12 19:25:23 +03:00
|
|
|
--enable-slirp=system) slirp="system"
|
|
|
|
;;
|
2008-07-23 22:14:33 +04:00
|
|
|
--disable-vde) vde="no"
|
2008-07-19 13:56:24 +04:00
|
|
|
;;
|
2009-08-12 20:20:27 +04:00
|
|
|
--enable-vde) vde="yes"
|
|
|
|
;;
|
2013-11-06 14:44:06 +04:00
|
|
|
--disable-netmap) netmap="no"
|
|
|
|
;;
|
|
|
|
--enable-netmap) netmap="yes"
|
|
|
|
;;
|
2020-09-18 11:57:25 +03:00
|
|
|
--disable-xen) xen="disabled"
|
2009-04-22 19:19:10 +04:00
|
|
|
;;
|
2020-09-18 11:57:25 +03:00
|
|
|
--enable-xen) xen="enabled"
|
2009-08-12 20:29:55 +04:00
|
|
|
;;
|
2020-09-18 11:57:25 +03:00
|
|
|
--disable-xen-pci-passthrough) xen_pci_passthrough="disabled"
|
2012-06-21 19:32:59 +04:00
|
|
|
;;
|
2020-09-18 11:57:25 +03:00
|
|
|
--enable-xen-pci-passthrough) xen_pci_passthrough="enabled"
|
2012-06-21 19:32:59 +04:00
|
|
|
;;
|
2020-11-17 15:02:17 +03:00
|
|
|
--disable-brlapi) brlapi="disabled"
|
2008-04-08 10:01:02 +04:00
|
|
|
;;
|
2020-11-17 15:02:17 +03:00
|
|
|
--enable-brlapi) brlapi="enabled"
|
2009-08-12 20:20:26 +04:00
|
|
|
;;
|
2020-09-18 11:57:25 +03:00
|
|
|
--disable-kvm) kvm="disabled"
|
2008-11-05 19:04:33 +03:00
|
|
|
;;
|
2020-09-18 11:57:25 +03:00
|
|
|
--enable-kvm) kvm="enabled"
|
2009-08-12 20:29:56 +04:00
|
|
|
;;
|
2020-09-18 11:57:25 +03:00
|
|
|
--disable-hax) hax="disabled"
|
2016-10-27 09:43:08 +03:00
|
|
|
;;
|
2020-09-18 11:57:25 +03:00
|
|
|
--enable-hax) hax="enabled"
|
2016-10-27 09:43:08 +03:00
|
|
|
;;
|
2020-09-18 11:57:25 +03:00
|
|
|
--disable-hvf) hvf="disabled"
|
i386: hvf: add code base from Google's QEMU repository
This file begins tracking the files that will be the code base for HVF
support in QEMU. This code base is part of Google's QEMU version of
their Android emulator, and can be found at
https://android.googlesource.com/platform/external/qemu/+/emu-master-dev
This code is based on Veertu Inc's vdhh (Veertu Desktop Hosted
Hypervisor), found at https://github.com/veertuinc/vdhh. Everything is
appropriately licensed under GPL v2-or-later, except for the code inside
x86_task.c and x86_task.h, which, deriving from KVM (the Linux kernel),
is licensed GPL v2-only.
This code base already implements a very great deal of functionality,
although Google's version removed from Vertuu's the support for APIC
page and hyperv-related stuff. According to the Android Emulator Release
Notes, Revision 26.1.3 (August 2017), "Hypervisor.framework is now
enabled by default on macOS for 32-bit x86 images to improve performance
and macOS compatibility", although we better use with caution for, as the
same Revision warns us, "If you experience issues with it specifically,
please file a bug report...". The code hasn't seen much update in the
last 5 months, so I think that we can further develop the code with
occasional visiting Google's repository to see if there has been any
update.
On top of Google's code, the following changes were made:
- add code to the configure script to support the --enable-hvf argument.
If the OS is Darwin, it checks for presence of HVF in the system. The
patch also adds strings related to HVF in the file qemu-options.hx.
QEMU will only support the modern syntax style '-M accel=hvf' no enable
hvf; the legacy '-enable-hvf' will not be supported.
- fix styling issues
- add glue code to cpus.c
- move HVFX86EmulatorState field to CPUX86State, changing the
the emulation functions to have a parameter with signature 'CPUX86State *'
instead of 'CPUState *' so we don't have to get the 'env'.
Signed-off-by: Sergio Andres Gomez Del Real <Sergio.G.DelReal@gmail.com>
Message-Id: <20170913090522.4022-2-Sergio.G.DelReal@gmail.com>
Message-Id: <20170913090522.4022-3-Sergio.G.DelReal@gmail.com>
Message-Id: <20170913090522.4022-5-Sergio.G.DelReal@gmail.com>
Message-Id: <20170913090522.4022-6-Sergio.G.DelReal@gmail.com>
Message-Id: <20170905035457.3753-7-Sergio.G.DelReal@gmail.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
2017-09-13 12:05:09 +03:00
|
|
|
;;
|
2020-09-18 11:57:25 +03:00
|
|
|
--enable-hvf) hvf="enabled"
|
i386: hvf: add code base from Google's QEMU repository
This file begins tracking the files that will be the code base for HVF
support in QEMU. This code base is part of Google's QEMU version of
their Android emulator, and can be found at
https://android.googlesource.com/platform/external/qemu/+/emu-master-dev
This code is based on Veertu Inc's vdhh (Veertu Desktop Hosted
Hypervisor), found at https://github.com/veertuinc/vdhh. Everything is
appropriately licensed under GPL v2-or-later, except for the code inside
x86_task.c and x86_task.h, which, deriving from KVM (the Linux kernel),
is licensed GPL v2-only.
This code base already implements a very great deal of functionality,
although Google's version removed from Vertuu's the support for APIC
page and hyperv-related stuff. According to the Android Emulator Release
Notes, Revision 26.1.3 (August 2017), "Hypervisor.framework is now
enabled by default on macOS for 32-bit x86 images to improve performance
and macOS compatibility", although we better use with caution for, as the
same Revision warns us, "If you experience issues with it specifically,
please file a bug report...". The code hasn't seen much update in the
last 5 months, so I think that we can further develop the code with
occasional visiting Google's repository to see if there has been any
update.
On top of Google's code, the following changes were made:
- add code to the configure script to support the --enable-hvf argument.
If the OS is Darwin, it checks for presence of HVF in the system. The
patch also adds strings related to HVF in the file qemu-options.hx.
QEMU will only support the modern syntax style '-M accel=hvf' no enable
hvf; the legacy '-enable-hvf' will not be supported.
- fix styling issues
- add glue code to cpus.c
- move HVFX86EmulatorState field to CPUX86State, changing the
the emulation functions to have a parameter with signature 'CPUX86State *'
instead of 'CPUState *' so we don't have to get the 'env'.
Signed-off-by: Sergio Andres Gomez Del Real <Sergio.G.DelReal@gmail.com>
Message-Id: <20170913090522.4022-2-Sergio.G.DelReal@gmail.com>
Message-Id: <20170913090522.4022-3-Sergio.G.DelReal@gmail.com>
Message-Id: <20170913090522.4022-5-Sergio.G.DelReal@gmail.com>
Message-Id: <20170913090522.4022-6-Sergio.G.DelReal@gmail.com>
Message-Id: <20170905035457.3753-7-Sergio.G.DelReal@gmail.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
2017-09-13 12:05:09 +03:00
|
|
|
;;
|
2020-09-18 11:57:25 +03:00
|
|
|
--disable-whpx) whpx="disabled"
|
2018-01-23 00:07:46 +03:00
|
|
|
;;
|
2020-09-18 11:57:25 +03:00
|
|
|
--enable-whpx) whpx="enabled"
|
2018-01-23 00:07:46 +03:00
|
|
|
;;
|
2011-10-19 09:07:18 +04:00
|
|
|
--disable-tcg-interpreter) tcg_interpreter="no"
|
|
|
|
;;
|
|
|
|
--enable-tcg-interpreter) tcg_interpreter="yes"
|
|
|
|
;;
|
2020-11-17 16:46:58 +03:00
|
|
|
--disable-cap-ng) cap_ng="disabled"
|
2012-01-26 18:42:26 +04:00
|
|
|
;;
|
2020-11-17 16:46:58 +03:00
|
|
|
--enable-cap-ng) cap_ng="enabled"
|
2012-01-26 18:42:26 +04:00
|
|
|
;;
|
2020-09-18 11:57:25 +03:00
|
|
|
--disable-tcg) tcg="disabled"
|
2017-07-03 17:59:07 +03:00
|
|
|
;;
|
2020-09-18 11:57:25 +03:00
|
|
|
--enable-tcg) tcg="enabled"
|
2017-07-03 17:59:07 +03:00
|
|
|
;;
|
2020-09-01 18:15:30 +03:00
|
|
|
--disable-malloc-trim) malloc_trim="disabled"
|
2017-12-20 16:16:46 +03:00
|
|
|
;;
|
2020-09-01 18:15:30 +03:00
|
|
|
--enable-malloc-trim) malloc_trim="enabled"
|
2017-12-20 16:16:46 +03:00
|
|
|
;;
|
2010-03-24 12:26:51 +03:00
|
|
|
--disable-spice) spice="no"
|
|
|
|
;;
|
|
|
|
--enable-spice) spice="yes"
|
|
|
|
;;
|
2020-11-17 15:11:25 +03:00
|
|
|
--disable-libiscsi) libiscsi="disabled"
|
2011-10-25 12:24:24 +04:00
|
|
|
;;
|
2020-11-17 15:11:25 +03:00
|
|
|
--enable-libiscsi) libiscsi="enabled"
|
2011-10-25 12:24:24 +04:00
|
|
|
;;
|
2020-11-17 15:11:25 +03:00
|
|
|
--disable-libnfs) libnfs="disabled"
|
2014-02-03 13:26:13 +04:00
|
|
|
;;
|
2020-11-17 15:11:25 +03:00
|
|
|
--enable-libnfs) libnfs="enabled"
|
2014-02-03 13:26:13 +04:00
|
|
|
;;
|
2006-02-09 01:39:17 +03:00
|
|
|
--enable-profiler) profiler="yes"
|
|
|
|
;;
|
2020-09-01 18:28:59 +03:00
|
|
|
--disable-cocoa) cocoa="disabled"
|
2011-11-10 22:40:07 +04:00
|
|
|
;;
|
2008-06-28 23:13:06 +04:00
|
|
|
--enable-cocoa)
|
2020-09-01 18:28:59 +03:00
|
|
|
cocoa="enabled" ;
|
2016-05-16 16:10:20 +03:00
|
|
|
audio_drv_list="coreaudio $(echo $audio_drv_list | sed s,coreaudio,,g)"
|
2005-10-30 21:58:22 +03:00
|
|
|
;;
|
2006-03-19 19:31:11 +03:00
|
|
|
--disable-system) softmmu="no"
|
2006-03-19 17:54:16 +03:00
|
|
|
;;
|
2006-03-19 19:31:11 +03:00
|
|
|
--enable-system) softmmu="yes"
|
2006-03-19 17:54:16 +03:00
|
|
|
;;
|
2009-07-30 14:14:59 +04:00
|
|
|
--disable-user)
|
|
|
|
linux_user="no" ;
|
|
|
|
bsd_user="no" ;
|
|
|
|
;;
|
|
|
|
--enable-user) ;;
|
2007-01-18 23:06:33 +03:00
|
|
|
--disable-linux-user) linux_user="no"
|
2006-03-19 17:54:16 +03:00
|
|
|
;;
|
2007-01-18 23:06:33 +03:00
|
|
|
--enable-linux-user) linux_user="yes"
|
|
|
|
;;
|
2008-10-26 23:33:16 +03:00
|
|
|
--disable-bsd-user) bsd_user="no"
|
|
|
|
;;
|
|
|
|
--enable-bsd-user) bsd_user="yes"
|
|
|
|
;;
|
2011-11-15 22:12:17 +04:00
|
|
|
--enable-pie) pie="yes"
|
2009-09-12 03:17:55 +04:00
|
|
|
;;
|
2011-11-15 22:12:17 +04:00
|
|
|
--disable-pie) pie="no"
|
2009-09-12 03:17:55 +04:00
|
|
|
;;
|
2007-11-11 23:17:03 +03:00
|
|
|
--enable-werror) werror="yes"
|
|
|
|
;;
|
|
|
|
--disable-werror) werror="no"
|
|
|
|
;;
|
2020-12-05 02:06:11 +03:00
|
|
|
--enable-lto) lto="true"
|
|
|
|
;;
|
|
|
|
--disable-lto) lto="false"
|
|
|
|
;;
|
2014-03-28 20:19:02 +04:00
|
|
|
--enable-stack-protector) stack_protector="yes"
|
|
|
|
;;
|
|
|
|
--disable-stack-protector) stack_protector="no"
|
|
|
|
;;
|
2020-05-29 23:51:21 +03:00
|
|
|
--enable-safe-stack) safe_stack="yes"
|
|
|
|
;;
|
|
|
|
--disable-safe-stack) safe_stack="no"
|
|
|
|
;;
|
2020-12-05 02:06:14 +03:00
|
|
|
--enable-cfi)
|
|
|
|
cfi="true";
|
|
|
|
lto="true";
|
|
|
|
;;
|
|
|
|
--disable-cfi) cfi="false"
|
|
|
|
;;
|
|
|
|
--enable-cfi-debug) cfi_debug="true"
|
|
|
|
;;
|
|
|
|
--disable-cfi-debug) cfi_debug="false"
|
|
|
|
;;
|
2020-10-13 02:43:48 +03:00
|
|
|
--disable-curses) curses="disabled"
|
2008-02-10 19:33:14 +03:00
|
|
|
;;
|
2020-10-13 02:43:48 +03:00
|
|
|
--enable-curses) curses="enabled"
|
2009-08-12 20:20:30 +04:00
|
|
|
;;
|
2020-10-13 02:43:48 +03:00
|
|
|
--disable-iconv) iconv="disabled"
|
2019-03-11 16:51:26 +03:00
|
|
|
;;
|
2020-10-13 02:43:48 +03:00
|
|
|
--enable-iconv) iconv="enabled"
|
2019-03-11 16:51:26 +03:00
|
|
|
;;
|
2020-11-17 14:43:15 +03:00
|
|
|
--disable-curl) curl="disabled"
|
2009-05-11 19:41:42 +04:00
|
|
|
;;
|
2020-11-17 14:43:15 +03:00
|
|
|
--enable-curl) curl="enabled"
|
2009-08-12 20:29:47 +04:00
|
|
|
;;
|
2020-10-05 12:31:15 +03:00
|
|
|
--disable-fdt) fdt="disabled"
|
2009-08-12 20:29:54 +04:00
|
|
|
;;
|
2020-10-05 12:31:15 +03:00
|
|
|
--enable-fdt) fdt="enabled"
|
|
|
|
;;
|
|
|
|
--enable-fdt=git) fdt="internal"
|
|
|
|
;;
|
|
|
|
--enable-fdt=system) fdt="system"
|
2009-08-12 20:29:54 +04:00
|
|
|
;;
|
2009-08-20 18:58:35 +04:00
|
|
|
--disable-linux-aio) linux_aio="no"
|
|
|
|
;;
|
|
|
|
--enable-linux-aio) linux_aio="yes"
|
|
|
|
;;
|
2020-01-20 17:18:44 +03:00
|
|
|
--disable-linux-io-uring) linux_io_uring="no"
|
|
|
|
;;
|
|
|
|
--enable-linux-io-uring) linux_io_uring="yes"
|
|
|
|
;;
|
2020-11-17 16:45:24 +03:00
|
|
|
--disable-attr) attr="disabled"
|
2010-06-15 00:34:41 +04:00
|
|
|
;;
|
2020-11-17 16:45:24 +03:00
|
|
|
--enable-attr) attr="enabled"
|
2010-06-15 00:34:41 +04:00
|
|
|
;;
|
2018-02-16 12:05:23 +03:00
|
|
|
--disable-membarrier) membarrier="no"
|
|
|
|
;;
|
|
|
|
--enable-membarrier) membarrier="yes"
|
|
|
|
;;
|
2020-10-16 10:32:52 +03:00
|
|
|
--disable-blobs) blobs="false"
|
2008-11-27 18:45:16 +03:00
|
|
|
;;
|
2018-02-15 14:06:47 +03:00
|
|
|
--with-pkgversion=*) pkgversion="$optarg"
|
2009-04-08 03:17:49 +04:00
|
|
|
;;
|
2012-02-28 15:25:50 +04:00
|
|
|
--with-coroutine=*) coroutine="$optarg"
|
|
|
|
;;
|
2013-09-11 18:42:35 +04:00
|
|
|
--disable-coroutine-pool) coroutine_pool="no"
|
|
|
|
;;
|
|
|
|
--enable-coroutine-pool) coroutine_pool="yes"
|
|
|
|
;;
|
2016-09-27 12:58:45 +03:00
|
|
|
--enable-debug-stack-usage) debug_stack_usage="yes"
|
|
|
|
;;
|
2017-07-14 21:04:05 +03:00
|
|
|
--enable-crypto-afalg) crypto_afalg="yes"
|
|
|
|
;;
|
|
|
|
--disable-crypto-afalg) crypto_afalg="no"
|
|
|
|
;;
|
2020-10-16 01:06:25 +03:00
|
|
|
--disable-docs) docs="disabled"
|
2009-05-14 17:25:04 +04:00
|
|
|
;;
|
2020-10-16 01:06:25 +03:00
|
|
|
--enable-docs) docs="enabled"
|
2009-08-12 20:29:51 +04:00
|
|
|
;;
|
2010-03-17 14:08:17 +03:00
|
|
|
--disable-vhost-net) vhost_net="no"
|
|
|
|
;;
|
|
|
|
--enable-vhost-net) vhost_net="yes"
|
|
|
|
;;
|
2018-03-01 16:46:28 +03:00
|
|
|
--disable-vhost-crypto) vhost_crypto="no"
|
|
|
|
;;
|
2019-02-14 20:35:53 +03:00
|
|
|
--enable-vhost-crypto) vhost_crypto="yes"
|
2018-03-01 16:46:28 +03:00
|
|
|
;;
|
vhost-scsi: new device supporting the tcm_vhost Linux kernel module
The WWPN specified in configfs is passed to "-device vhost-scsi-pci".
The tgpt field of the SET_ENDPOINT ioctl is obsolete now, so it is not
available from the QEMU command-line. Instead, I hardcode it to zero.
Changes in Patch-v2:
- Add vhost_scsi_get_features() in order to determine feature bits
supports by host kernel (mst + nab)
- Re-enable usage of DEFINE_VIRTIO_COMMON_FEATURES, and allow
EVENT_IDX to be disabled by host in vhost_scsi_get_features()
- Drop unused hotplug bit in DEFINE_VHOST_SCSI_PROPERTIES
Changes in Patch-v1:
- Set event_idx=off by default (nab, thanks asias)
- Disable hotplug feature bit for v3.9 tcm_vhost kernel code, need to
re-enable in v3.10 (nab)
- Update to latest qemu.git/master HEAD
Changes in WIP-V3:
- Drop ioeventfd vhost_scsi_properties (asias, thanks stefanha)
- Add CONFIG_VHOST_SCSI (asias, thanks stefanha)
- Add hotplug feature bit
Changes in WIP-V2:
- Add backend guest masking support (nab)
- Bump ABI_VERSION to 1 (nab)
- Set up set_guest_notifiers (asias)
- Set up vs->dev.vq_index (asias)
- Drop vs->vs.vdev.{set,clear}_vhost_endpoint (asias)
- Drop VIRTIO_CONFIG_S_DRIVER check in vhost_scsi_set_status (asias)
Howto:
Use the latest seabios, at least commit b44a7be17b
git clone git://git.seabios.org/seabios.git
make
cp out/bios.bin /usr/share/qemu/bios.bin
qemu -device vhost-scsi-pci,wwpn=naa.6001405bd4e8476d,event_idx=off
...
Cc: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Nicholas Bellinger <nab@linux-iscsi.org>
Signed-off-by: Asias He <asias@redhat.com>
[ Rebase on top of VirtIOSCSICommon patch, fix bugs in feature
negotiation and irqfd masking - Paolo ]
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
2013-03-29 05:08:16 +04:00
|
|
|
--disable-vhost-scsi) vhost_scsi="no"
|
|
|
|
;;
|
|
|
|
--enable-vhost-scsi) vhost_scsi="yes"
|
|
|
|
;;
|
2016-08-16 15:27:22 +03:00
|
|
|
--disable-vhost-vsock) vhost_vsock="no"
|
|
|
|
;;
|
|
|
|
--enable-vhost-vsock) vhost_vsock="yes"
|
|
|
|
;;
|
2020-11-10 20:11:19 +03:00
|
|
|
--disable-vhost-user-blk-server) vhost_user_blk_server="disabled"
|
2020-10-27 20:35:18 +03:00
|
|
|
;;
|
2020-11-10 20:11:19 +03:00
|
|
|
--enable-vhost-user-blk-server) vhost_user_blk_server="enabled"
|
2020-10-27 20:35:18 +03:00
|
|
|
;;
|
2019-09-30 13:51:34 +03:00
|
|
|
--disable-vhost-user-fs) vhost_user_fs="no"
|
|
|
|
;;
|
|
|
|
--enable-vhost-user-fs) vhost_user_fs="yes"
|
|
|
|
;;
|
2014-11-20 11:49:44 +03:00
|
|
|
--disable-opengl) opengl="no"
|
2011-03-08 01:32:39 +03:00
|
|
|
;;
|
2014-11-20 11:49:44 +03:00
|
|
|
--enable-opengl) opengl="yes"
|
2011-03-08 01:32:39 +03:00
|
|
|
;;
|
2020-11-17 15:11:25 +03:00
|
|
|
--disable-rbd) rbd="disabled"
|
2010-12-06 22:53:01 +03:00
|
|
|
;;
|
2020-11-17 15:11:25 +03:00
|
|
|
--enable-rbd) rbd="enabled"
|
2010-12-06 22:53:01 +03:00
|
|
|
;;
|
2012-01-24 21:42:40 +04:00
|
|
|
--disable-xfsctl) xfs="no"
|
|
|
|
;;
|
|
|
|
--enable-xfsctl) xfs="yes"
|
|
|
|
;;
|
2015-08-30 12:48:40 +03:00
|
|
|
--disable-smartcard) smartcard="no"
|
libcacard: initial commit
libcacard emulates a Common Access Card (CAC) which is a standard
for smartcards. It is used by the emulated ccid card introduced in
a following patch. Docs are available in docs/libcacard.txt
Signed-off-by: Alon Levy <alevy@redhat.com>
---
changes from v24->v25:
* Fix out of tree builds.
* Fix build with linux-user targets.
changes from v23->v24: (Jes Sorensen review 2)
* Makefile.target: use obj-$(CONFIG_*) +=
* remove unrequired includes, include qemu-common before qemu-thread
* required adding #define NO_NSPR_10_SUPPORT (harmless)
changes from v22->v23:
* configure fixes: (reported by Stefan Hajnoczi)
* test a = b, not a == b (second isn't portable)
* quote $source_path in case it contains spaces
- this doesn't really help since there are many other places
that need similar fixes, not introduced by this patch.
changes from v21->v22:
* fix configure to not link libcacard if nss not found
(reported by Stefan Hajnoczi)
* fix vscclient linkage with simpletrace backend
(reported by Stefan Hajnoczi)
* card_7816.c: add missing break in ERROR_DATA_NOT_FOUND
(reported by William van de Velde)
changes from v20->v21: (Jes Sorensen review)
* use qemu infrastructure: qemu-thread, qemu-common (qemu_malloc
and qemu_free), error_report
* assert instead of ASSERT
* cosmetic fixes
* use strpbrk and isspace
* add --disable-nss --enable-nss here, instead of in the final patch.
* split vscclient, passthru and docs to following patches.
changes from v19->v20:
* checkpatch.pl
changes from v15->v16:
Build:
* don't erase self with distclean
* fix make clean after make distclean
* Makefile: make vscclient link quiet
Behavioral:
* vcard_emul_nss: load coolkey in more situations
* vscclient:
* use hton,ntoh
* send init on connect, only start vevent thread on response
* read payload after header check, before type switch
* remove Reconnect
* update for vscard_common changes, empty Flush implementation
Style/Whitespace:
* fix wrong variable usage
* remove unused variable
* use only C style comments
* add copyright header
* fix tabulation
Signed-off-by: Alon Levy <alevy@redhat.com>
libcacard: fix out of tree builds
2010-11-28 17:36:38 +03:00
|
|
|
;;
|
2015-08-30 12:48:40 +03:00
|
|
|
--enable-smartcard) smartcard="yes"
|
libcacard: initial commit
libcacard emulates a Common Access Card (CAC) which is a standard
for smartcards. It is used by the emulated ccid card introduced in
a following patch. Docs are available in docs/libcacard.txt
Signed-off-by: Alon Levy <alevy@redhat.com>
---
changes from v24->v25:
* Fix out of tree builds.
* Fix build with linux-user targets.
changes from v23->v24: (Jes Sorensen review 2)
* Makefile.target: use obj-$(CONFIG_*) +=
* remove unrequired includes, include qemu-common before qemu-thread
* required adding #define NO_NSPR_10_SUPPORT (harmless)
changes from v22->v23:
* configure fixes: (reported by Stefan Hajnoczi)
* test a = b, not a == b (second isn't portable)
* quote $source_path in case it contains spaces
- this doesn't really help since there are many other places
that need similar fixes, not introduced by this patch.
changes from v21->v22:
* fix configure to not link libcacard if nss not found
(reported by Stefan Hajnoczi)
* fix vscclient linkage with simpletrace backend
(reported by Stefan Hajnoczi)
* card_7816.c: add missing break in ERROR_DATA_NOT_FOUND
(reported by William van de Velde)
changes from v20->v21: (Jes Sorensen review)
* use qemu infrastructure: qemu-thread, qemu-common (qemu_malloc
and qemu_free), error_report
* assert instead of ASSERT
* cosmetic fixes
* use strpbrk and isspace
* add --disable-nss --enable-nss here, instead of in the final patch.
* split vscclient, passthru and docs to following patches.
changes from v19->v20:
* checkpatch.pl
changes from v15->v16:
Build:
* don't erase self with distclean
* fix make clean after make distclean
* Makefile: make vscclient link quiet
Behavioral:
* vcard_emul_nss: load coolkey in more situations
* vscclient:
* use hton,ntoh
* send init on connect, only start vevent thread on response
* read payload after header check, before type switch
* remove Reconnect
* update for vscard_common changes, empty Flush implementation
Style/Whitespace:
* fix wrong variable usage
* remove unused variable
* use only C style comments
* add copyright header
* fix tabulation
Signed-off-by: Alon Levy <alevy@redhat.com>
libcacard: fix out of tree builds
2010-11-28 17:36:38 +03:00
|
|
|
;;
|
2020-08-26 14:42:04 +03:00
|
|
|
--disable-u2f) u2f="disabled"
|
|
|
|
;;
|
|
|
|
--enable-u2f) u2f="enabled"
|
|
|
|
;;
|
2012-11-30 19:02:11 +04:00
|
|
|
--disable-libusb) libusb="no"
|
|
|
|
;;
|
|
|
|
--enable-libusb) libusb="yes"
|
|
|
|
;;
|
2011-07-19 13:04:10 +04:00
|
|
|
--disable-usb-redir) usb_redir="no"
|
|
|
|
;;
|
|
|
|
--enable-usb-redir) usb_redir="yes"
|
|
|
|
;;
|
2020-08-28 20:33:54 +03:00
|
|
|
--disable-zlib-test)
|
2011-07-26 13:30:40 +04:00
|
|
|
;;
|
2020-11-17 15:11:25 +03:00
|
|
|
--disable-lzo) lzo="disabled"
|
2014-04-29 10:21:16 +04:00
|
|
|
;;
|
2020-11-17 15:11:25 +03:00
|
|
|
--enable-lzo) lzo="enabled"
|
2014-02-18 10:11:30 +04:00
|
|
|
;;
|
2020-11-17 15:32:34 +03:00
|
|
|
--disable-snappy) snappy="disabled"
|
2014-04-29 10:21:16 +04:00
|
|
|
;;
|
2020-11-17 15:32:34 +03:00
|
|
|
--enable-snappy) snappy="enabled"
|
2014-02-18 10:11:30 +04:00
|
|
|
;;
|
2020-11-17 15:07:52 +03:00
|
|
|
--disable-bzip2) bzip2="disabled"
|
2015-01-06 20:48:14 +03:00
|
|
|
;;
|
2020-11-17 15:07:52 +03:00
|
|
|
--enable-bzip2) bzip2="enabled"
|
2015-01-06 20:48:14 +03:00
|
|
|
;;
|
2020-11-17 15:35:28 +03:00
|
|
|
--enable-lzfse) lzfse="enabled"
|
2018-11-05 18:08:04 +03:00
|
|
|
;;
|
2020-11-17 15:35:28 +03:00
|
|
|
--disable-lzfse) lzfse="disabled"
|
2018-11-05 18:08:04 +03:00
|
|
|
;;
|
2020-11-17 15:37:39 +03:00
|
|
|
--disable-zstd) zstd="disabled"
|
2019-12-17 23:15:24 +03:00
|
|
|
;;
|
2020-11-17 15:37:39 +03:00
|
|
|
--enable-zstd) zstd="enabled"
|
2019-12-17 23:15:24 +03:00
|
|
|
;;
|
2011-08-01 23:52:57 +04:00
|
|
|
--enable-guest-agent) guest_agent="yes"
|
|
|
|
;;
|
|
|
|
--disable-guest-agent) guest_agent="no"
|
|
|
|
;;
|
2015-05-06 14:57:40 +03:00
|
|
|
--enable-guest-agent-msi) guest_agent_msi="yes"
|
|
|
|
;;
|
|
|
|
--disable-guest-agent-msi) guest_agent_msi="no"
|
|
|
|
;;
|
2013-08-07 19:40:03 +04:00
|
|
|
--with-vss-sdk) vss_win32_sdk=""
|
|
|
|
;;
|
|
|
|
--with-vss-sdk=*) vss_win32_sdk="$optarg"
|
|
|
|
;;
|
|
|
|
--without-vss-sdk) vss_win32_sdk="no"
|
|
|
|
;;
|
|
|
|
--with-win-sdk) win_sdk=""
|
|
|
|
;;
|
|
|
|
--with-win-sdk=*) win_sdk="$optarg"
|
|
|
|
;;
|
|
|
|
--without-win-sdk) win_sdk="no"
|
|
|
|
;;
|
2012-09-10 15:26:29 +04:00
|
|
|
--enable-tools) want_tools="yes"
|
|
|
|
;;
|
|
|
|
--disable-tools) want_tools="no"
|
|
|
|
;;
|
2020-11-17 16:22:24 +03:00
|
|
|
--enable-seccomp) seccomp="enabled"
|
2012-08-15 01:44:05 +04:00
|
|
|
;;
|
2020-11-17 16:22:24 +03:00
|
|
|
--disable-seccomp) seccomp="disabled"
|
2012-08-15 01:44:05 +04:00
|
|
|
;;
|
2020-11-17 15:01:26 +03:00
|
|
|
--disable-glusterfs) glusterfs="disabled"
|
2012-09-24 13:12:45 +04:00
|
|
|
;;
|
2018-10-19 23:38:59 +03:00
|
|
|
--disable-avx2) avx2_opt="no"
|
|
|
|
;;
|
|
|
|
--enable-avx2) avx2_opt="yes"
|
|
|
|
;;
|
2020-02-29 15:34:34 +03:00
|
|
|
--disable-avx512f) avx512f_opt="no"
|
|
|
|
;;
|
|
|
|
--enable-avx512f) avx512f_opt="yes"
|
|
|
|
;;
|
|
|
|
|
2020-11-17 15:01:26 +03:00
|
|
|
--enable-glusterfs) glusterfs="enabled"
|
2012-09-24 13:12:45 +04:00
|
|
|
;;
|
2014-09-10 10:17:51 +04:00
|
|
|
--disable-virtio-blk-data-plane|--enable-virtio-blk-data-plane)
|
|
|
|
echo "$0: $opt is obsolete, virtio-blk data-plane is always on" >&2
|
2012-11-14 18:04:15 +04:00
|
|
|
;;
|
2016-09-21 07:27:16 +03:00
|
|
|
--enable-vhdx|--disable-vhdx)
|
|
|
|
echo "$0: $opt is obsolete, VHDX driver is always built" >&2
|
|
|
|
;;
|
2016-09-21 07:27:21 +03:00
|
|
|
--enable-uuid|--disable-uuid)
|
|
|
|
echo "$0: $opt is obsolete, UUID support is always built" >&2
|
|
|
|
;;
|
2013-02-20 17:43:20 +04:00
|
|
|
--disable-gtk) gtk="no"
|
|
|
|
;;
|
|
|
|
--enable-gtk) gtk="yes"
|
|
|
|
;;
|
2016-06-06 12:05:06 +03:00
|
|
|
--tls-priority=*) tls_priority="$optarg"
|
|
|
|
;;
|
2015-07-01 20:10:29 +03:00
|
|
|
--disable-gnutls) gnutls="no"
|
|
|
|
;;
|
|
|
|
--enable-gnutls) gnutls="yes"
|
|
|
|
;;
|
2015-10-16 18:36:53 +03:00
|
|
|
--disable-nettle) nettle="no"
|
|
|
|
;;
|
|
|
|
--enable-nettle) nettle="yes"
|
|
|
|
;;
|
|
|
|
--disable-gcrypt) gcrypt="no"
|
|
|
|
;;
|
|
|
|
--enable-gcrypt) gcrypt="yes"
|
|
|
|
;;
|
authz: add QAuthZPAM object type for authorizing using PAM
Add an authorization backend that talks to PAM to check whether the user
identity is allowed. This only uses the PAM account validation facility,
which is essentially just a check to see if the provided username is permitted
access. It doesn't use the authentication or session parts of PAM, since
that's dealt with by the relevant part of QEMU (eg VNC server).
Consider starting QEMU with a VNC server and telling it to use TLS with
x509 client certificates and configuring it to use an PAM to validate
the x509 distinguished name. In this example we're telling it to use PAM
for the QAuthZ impl with a service name of "qemu-vnc"
$ qemu-system-x86_64 \
-object tls-creds-x509,id=tls0,dir=/home/berrange/security/qemutls,\
endpoint=server,verify-peer=yes \
-object authz-pam,id=authz0,service=qemu-vnc \
-vnc :1,tls-creds=tls0,tls-authz=authz0
This requires an /etc/pam/qemu-vnc file to be created with the auth
rules. A very simple file based whitelist can be setup using
$ cat > /etc/pam/qemu-vnc <<EOF
account requisite pam_listfile.so item=user sense=allow file=/etc/qemu/vnc.allow
EOF
The /etc/qemu/vnc.allow file simply contains one username per line. Any
username not in the file is denied. The usernames in this example are
the x509 distinguished name from the client's x509 cert.
$ cat > /etc/qemu/vnc.allow <<EOF
CN=laptop.berrange.com,O=Berrange Home,L=London,ST=London,C=GB
EOF
More interesting would be to configure PAM to use an LDAP backend, so
that the QEMU authorization check data can be centralized instead of
requiring each compute host to have file maintained.
The main limitation with this PAM module is that the rules apply to all
QEMU instances on the host. Setting up different rules per VM, would
require creating a separate PAM service name & config file for every
guest. An alternative approach for the future might be to not pass in
the plain username to PAM, but instead combine the VM name or UUID with
the username. This requires further consideration though.
Tested-by: Philippe Mathieu-Daudé <philmd@redhat.com>
Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com>
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
2016-07-27 16:13:56 +03:00
|
|
|
--disable-auth-pam) auth_pam="no"
|
|
|
|
;;
|
|
|
|
--enable-auth-pam) auth_pam="yes"
|
|
|
|
;;
|
2013-07-22 18:01:54 +04:00
|
|
|
--enable-rdma) rdma="yes"
|
|
|
|
;;
|
|
|
|
--disable-rdma) rdma="no"
|
|
|
|
;;
|
2018-08-16 18:16:37 +03:00
|
|
|
--enable-pvrdma) pvrdma="yes"
|
|
|
|
;;
|
|
|
|
--disable-pvrdma) pvrdma="no"
|
|
|
|
;;
|
2014-02-19 10:04:34 +04:00
|
|
|
--disable-vte) vte="no"
|
|
|
|
;;
|
|
|
|
--enable-vte) vte="yes"
|
|
|
|
;;
|
2014-07-11 14:51:43 +04:00
|
|
|
--disable-virglrenderer) virglrenderer="no"
|
|
|
|
;;
|
|
|
|
--enable-virglrenderer) virglrenderer="yes"
|
|
|
|
;;
|
2014-06-16 23:32:47 +04:00
|
|
|
--disable-tpm) tpm="no"
|
|
|
|
;;
|
2013-02-27 21:47:52 +04:00
|
|
|
--enable-tpm) tpm="yes"
|
|
|
|
;;
|
2019-06-20 23:08:40 +03:00
|
|
|
--disable-libssh) libssh="no"
|
2013-04-09 18:30:53 +04:00
|
|
|
;;
|
2019-06-20 23:08:40 +03:00
|
|
|
--enable-libssh) libssh="yes"
|
2013-04-09 18:30:53 +04:00
|
|
|
;;
|
2017-05-15 17:05:29 +03:00
|
|
|
--disable-live-block-migration) live_block_migration="no"
|
|
|
|
;;
|
|
|
|
--enable-live-block-migration) live_block_migration="yes"
|
|
|
|
;;
|
2014-05-14 13:43:28 +04:00
|
|
|
--disable-numa) numa="no"
|
|
|
|
;;
|
|
|
|
--enable-numa) numa="yes"
|
|
|
|
;;
|
2018-01-12 12:01:19 +03:00
|
|
|
--disable-libxml2) libxml2="no"
|
|
|
|
;;
|
|
|
|
--enable-libxml2) libxml2="yes"
|
|
|
|
;;
|
2015-03-26 06:03:12 +03:00
|
|
|
--disable-tcmalloc) tcmalloc="no"
|
|
|
|
;;
|
|
|
|
--enable-tcmalloc) tcmalloc="yes"
|
|
|
|
;;
|
2015-06-19 13:56:58 +03:00
|
|
|
--disable-jemalloc) jemalloc="no"
|
|
|
|
;;
|
|
|
|
--enable-jemalloc) jemalloc="yes"
|
|
|
|
;;
|
2016-07-27 10:01:48 +03:00
|
|
|
--disable-replication) replication="no"
|
|
|
|
;;
|
|
|
|
--enable-replication) replication="yes"
|
|
|
|
;;
|
2018-11-07 09:36:44 +03:00
|
|
|
--disable-bochs) bochs="no"
|
|
|
|
;;
|
|
|
|
--enable-bochs) bochs="yes"
|
|
|
|
;;
|
|
|
|
--disable-cloop) cloop="no"
|
|
|
|
;;
|
|
|
|
--enable-cloop) cloop="yes"
|
|
|
|
;;
|
|
|
|
--disable-dmg) dmg="no"
|
|
|
|
;;
|
|
|
|
--enable-dmg) dmg="yes"
|
|
|
|
;;
|
|
|
|
--disable-qcow1) qcow1="no"
|
|
|
|
;;
|
|
|
|
--enable-qcow1) qcow1="yes"
|
|
|
|
;;
|
|
|
|
--disable-vdi) vdi="no"
|
|
|
|
;;
|
|
|
|
--enable-vdi) vdi="yes"
|
|
|
|
;;
|
|
|
|
--disable-vvfat) vvfat="no"
|
|
|
|
;;
|
|
|
|
--enable-vvfat) vvfat="yes"
|
|
|
|
;;
|
|
|
|
--disable-qed) qed="no"
|
|
|
|
;;
|
|
|
|
--enable-qed) qed="yes"
|
|
|
|
;;
|
|
|
|
--disable-parallels) parallels="no"
|
|
|
|
;;
|
|
|
|
--enable-parallels) parallels="yes"
|
|
|
|
;;
|
|
|
|
--disable-sheepdog) sheepdog="no"
|
|
|
|
;;
|
|
|
|
--enable-sheepdog) sheepdog="yes"
|
|
|
|
;;
|
2017-08-03 12:07:46 +03:00
|
|
|
--disable-vhost-user) vhost_user="no"
|
|
|
|
;;
|
2019-02-14 20:35:53 +03:00
|
|
|
--enable-vhost-user) vhost_user="yes"
|
|
|
|
;;
|
2020-07-01 17:55:37 +03:00
|
|
|
--disable-vhost-vdpa) vhost_vdpa="no"
|
|
|
|
;;
|
|
|
|
--enable-vhost-vdpa) vhost_vdpa="yes"
|
|
|
|
;;
|
2019-02-14 20:35:53 +03:00
|
|
|
--disable-vhost-kernel) vhost_kernel="no"
|
|
|
|
;;
|
|
|
|
--enable-vhost-kernel) vhost_kernel="yes"
|
2017-08-03 12:07:46 +03:00
|
|
|
;;
|
2020-09-13 22:19:25 +03:00
|
|
|
--disable-capstone) capstone="disabled"
|
2017-09-14 19:41:12 +03:00
|
|
|
;;
|
2020-09-13 22:19:25 +03:00
|
|
|
--enable-capstone) capstone="enabled"
|
2017-09-14 19:41:12 +03:00
|
|
|
;;
|
2020-09-13 22:19:25 +03:00
|
|
|
--enable-capstone=git) capstone="internal"
|
2017-09-28 19:01:23 +03:00
|
|
|
;;
|
|
|
|
--enable-capstone=system) capstone="system"
|
|
|
|
;;
|
2017-10-20 17:02:43 +03:00
|
|
|
--with-git=*) git="$optarg"
|
|
|
|
;;
|
2017-10-26 15:52:26 +03:00
|
|
|
--enable-git-update) git_update=yes
|
|
|
|
;;
|
|
|
|
--disable-git-update) git_update=no
|
|
|
|
;;
|
2018-06-13 15:23:08 +03:00
|
|
|
--enable-debug-mutex) debug_mutex=yes
|
|
|
|
;;
|
|
|
|
--disable-debug-mutex) debug_mutex=no
|
|
|
|
;;
|
2018-07-18 10:47:59 +03:00
|
|
|
--enable-libpmem) libpmem=yes
|
|
|
|
;;
|
|
|
|
--disable-libpmem) libpmem=no
|
|
|
|
;;
|
2020-08-24 18:24:29 +03:00
|
|
|
--enable-xkbcommon) xkbcommon="enabled"
|
2019-09-14 17:51:55 +03:00
|
|
|
;;
|
2020-08-24 18:24:29 +03:00
|
|
|
--disable-xkbcommon) xkbcommon="disabled"
|
2019-09-14 17:51:55 +03:00
|
|
|
;;
|
2019-06-13 16:52:25 +03:00
|
|
|
--enable-plugins) plugins="yes"
|
|
|
|
;;
|
|
|
|
--disable-plugins) plugins="no"
|
|
|
|
;;
|
2019-11-28 18:35:24 +03:00
|
|
|
--enable-containers) use_containers="yes"
|
|
|
|
;;
|
|
|
|
--disable-containers) use_containers="no"
|
|
|
|
;;
|
2020-02-20 07:11:14 +03:00
|
|
|
--enable-fuzzing) fuzzing=yes
|
|
|
|
;;
|
|
|
|
--disable-fuzzing) fuzzing=no
|
|
|
|
;;
|
2020-03-16 20:21:48 +03:00
|
|
|
--gdb=*) gdb_bin="$optarg"
|
|
|
|
;;
|
2020-05-20 16:20:23 +03:00
|
|
|
--enable-rng-none) rng_none=yes
|
|
|
|
;;
|
|
|
|
--disable-rng-none) rng_none=no
|
|
|
|
;;
|
2020-05-25 14:19:12 +03:00
|
|
|
--enable-keyring) secret_keyring="yes"
|
|
|
|
;;
|
|
|
|
--disable-keyring) secret_keyring="no"
|
|
|
|
;;
|
2020-04-29 11:50:11 +03:00
|
|
|
--enable-libdaxctl) libdaxctl=yes
|
|
|
|
;;
|
|
|
|
--disable-libdaxctl) libdaxctl=no
|
|
|
|
;;
|
2020-10-27 22:05:41 +03:00
|
|
|
--enable-fuse) fuse="enabled"
|
|
|
|
;;
|
|
|
|
--disable-fuse) fuse="disabled"
|
|
|
|
;;
|
2020-10-27 22:05:46 +03:00
|
|
|
--enable-fuse-lseek) fuse_lseek="enabled"
|
|
|
|
;;
|
|
|
|
--disable-fuse-lseek) fuse_lseek="disabled"
|
|
|
|
;;
|
2014-04-18 10:55:36 +04:00
|
|
|
*)
|
|
|
|
echo "ERROR: unknown option $opt"
|
|
|
|
echo "Try '$0 --help' for more information"
|
|
|
|
exit 1
|
2007-11-17 13:24:32 +03:00
|
|
|
;;
|
2003-03-07 02:23:54 +03:00
|
|
|
esac
|
|
|
|
done
|
|
|
|
|
2019-07-11 18:13:39 +03:00
|
|
|
libdir="${libdir:-$prefix/lib}"
|
|
|
|
libexecdir="${libexecdir:-$prefix/libexec}"
|
|
|
|
includedir="${includedir:-$prefix/include}"
|
|
|
|
|
|
|
|
if test "$mingw32" = "yes" ; then
|
|
|
|
mandir="$prefix"
|
|
|
|
datadir="$prefix"
|
2020-08-26 14:04:14 +03:00
|
|
|
docdir="$prefix"
|
2019-07-11 18:13:39 +03:00
|
|
|
bindir="$prefix"
|
|
|
|
sysconfdir="$prefix"
|
2020-10-16 10:19:14 +03:00
|
|
|
local_statedir="$prefix"
|
2019-07-11 18:13:39 +03:00
|
|
|
else
|
|
|
|
mandir="${mandir:-$prefix/share/man}"
|
|
|
|
datadir="${datadir:-$prefix/share}"
|
2020-08-26 14:04:14 +03:00
|
|
|
docdir="${docdir:-$prefix/share/doc}"
|
2019-07-11 18:13:39 +03:00
|
|
|
bindir="${bindir:-$prefix/bin}"
|
|
|
|
sysconfdir="${sysconfdir:-$prefix/etc}"
|
|
|
|
local_statedir="${local_statedir:-$prefix/var}"
|
|
|
|
fi
|
2020-10-16 10:19:14 +03:00
|
|
|
firmwarepath="${firmwarepath:-$datadir/qemu-firmware}"
|
|
|
|
localedir="${localedir:-$datadir/locale}"
|
2019-07-11 18:13:39 +03:00
|
|
|
|
2008-01-31 14:32:10 +03:00
|
|
|
case "$cpu" in
|
2013-08-29 02:48:21 +04:00
|
|
|
ppc)
|
|
|
|
CPU_CFLAGS="-m32"
|
build-sys: clean up flags included in the linker command line
Some of the CFLAGS that are discovered during configure, for example
compiler warnings, are being included on the linker command line because
QEMU_CFLAGS is added to it. Other flags, such as the -m32, appear twice
because they are included in both QEMU_CFLAGS and LDFLAGS. All this
leads to confusion with respect to what goes in which Makefile variables
(and we have plenty).
So, introduce QEMU_LDFLAGS for flags discovered by configure, following
the lead of QEMU_CFLAGS, and stop adding to it:
1) options that are already in CFLAGS, for example "-g"
2) duplicate options
At the same time, options that _are_ needed by both compiler and linker
must now be added to both QEMU_CFLAGS and QEMU_LDFLAGS, which is clearer.
This is mostly -fsanitize options. For now, --extra-cflags has this behavior
(but --extra-cxxflags does not).
Meson will not include CFLAGS on the linker command line, do the same in our
build system as well.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
2019-12-11 17:34:27 +03:00
|
|
|
QEMU_LDFLAGS="-m32 $QEMU_LDFLAGS"
|
2013-08-29 02:48:21 +04:00
|
|
|
;;
|
|
|
|
ppc64)
|
|
|
|
CPU_CFLAGS="-m64"
|
build-sys: clean up flags included in the linker command line
Some of the CFLAGS that are discovered during configure, for example
compiler warnings, are being included on the linker command line because
QEMU_CFLAGS is added to it. Other flags, such as the -m32, appear twice
because they are included in both QEMU_CFLAGS and LDFLAGS. All this
leads to confusion with respect to what goes in which Makefile variables
(and we have plenty).
So, introduce QEMU_LDFLAGS for flags discovered by configure, following
the lead of QEMU_CFLAGS, and stop adding to it:
1) options that are already in CFLAGS, for example "-g"
2) duplicate options
At the same time, options that _are_ needed by both compiler and linker
must now be added to both QEMU_CFLAGS and QEMU_LDFLAGS, which is clearer.
This is mostly -fsanitize options. For now, --extra-cflags has this behavior
(but --extra-cxxflags does not).
Meson will not include CFLAGS on the linker command line, do the same in our
build system as well.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
2019-12-11 17:34:27 +03:00
|
|
|
QEMU_LDFLAGS="-m64 $QEMU_LDFLAGS"
|
2013-08-29 02:48:21 +04:00
|
|
|
;;
|
2012-09-21 21:34:21 +04:00
|
|
|
sparc)
|
2017-04-26 20:39:08 +03:00
|
|
|
CPU_CFLAGS="-m32 -mv8plus -mcpu=ultrasparc"
|
build-sys: clean up flags included in the linker command line
Some of the CFLAGS that are discovered during configure, for example
compiler warnings, are being included on the linker command line because
QEMU_CFLAGS is added to it. Other flags, such as the -m32, appear twice
because they are included in both QEMU_CFLAGS and LDFLAGS. All this
leads to confusion with respect to what goes in which Makefile variables
(and we have plenty).
So, introduce QEMU_LDFLAGS for flags discovered by configure, following
the lead of QEMU_CFLAGS, and stop adding to it:
1) options that are already in CFLAGS, for example "-g"
2) duplicate options
At the same time, options that _are_ needed by both compiler and linker
must now be added to both QEMU_CFLAGS and QEMU_LDFLAGS, which is clearer.
This is mostly -fsanitize options. For now, --extra-cflags has this behavior
(but --extra-cxxflags does not).
Meson will not include CFLAGS on the linker command line, do the same in our
build system as well.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
2019-12-11 17:34:27 +03:00
|
|
|
QEMU_LDFLAGS="-m32 -mv8plus $QEMU_LDFLAGS"
|
2007-04-16 22:27:06 +04:00
|
|
|
;;
|
2009-08-03 16:46:11 +04:00
|
|
|
sparc64)
|
2013-04-18 08:46:14 +04:00
|
|
|
CPU_CFLAGS="-m64 -mcpu=ultrasparc"
|
build-sys: clean up flags included in the linker command line
Some of the CFLAGS that are discovered during configure, for example
compiler warnings, are being included on the linker command line because
QEMU_CFLAGS is added to it. Other flags, such as the -m32, appear twice
because they are included in both QEMU_CFLAGS and LDFLAGS. All this
leads to confusion with respect to what goes in which Makefile variables
(and we have plenty).
So, introduce QEMU_LDFLAGS for flags discovered by configure, following
the lead of QEMU_CFLAGS, and stop adding to it:
1) options that are already in CFLAGS, for example "-g"
2) duplicate options
At the same time, options that _are_ needed by both compiler and linker
must now be added to both QEMU_CFLAGS and QEMU_LDFLAGS, which is clearer.
This is mostly -fsanitize options. For now, --extra-cflags has this behavior
(but --extra-cxxflags does not).
Meson will not include CFLAGS on the linker command line, do the same in our
build system as well.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
2019-12-11 17:34:27 +03:00
|
|
|
QEMU_LDFLAGS="-m64 $QEMU_LDFLAGS"
|
2007-04-16 22:27:06 +04:00
|
|
|
;;
|
2007-11-19 00:22:10 +03:00
|
|
|
s390)
|
2014-03-31 21:40:49 +04:00
|
|
|
CPU_CFLAGS="-m31"
|
build-sys: clean up flags included in the linker command line
Some of the CFLAGS that are discovered during configure, for example
compiler warnings, are being included on the linker command line because
QEMU_CFLAGS is added to it. Other flags, such as the -m32, appear twice
because they are included in both QEMU_CFLAGS and LDFLAGS. All this
leads to confusion with respect to what goes in which Makefile variables
(and we have plenty).
So, introduce QEMU_LDFLAGS for flags discovered by configure, following
the lead of QEMU_CFLAGS, and stop adding to it:
1) options that are already in CFLAGS, for example "-g"
2) duplicate options
At the same time, options that _are_ needed by both compiler and linker
must now be added to both QEMU_CFLAGS and QEMU_LDFLAGS, which is clearer.
This is mostly -fsanitize options. For now, --extra-cflags has this behavior
(but --extra-cxxflags does not).
Meson will not include CFLAGS on the linker command line, do the same in our
build system as well.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
2019-12-11 17:34:27 +03:00
|
|
|
QEMU_LDFLAGS="-m31 $QEMU_LDFLAGS"
|
2010-06-04 23:14:09 +04:00
|
|
|
;;
|
|
|
|
s390x)
|
2014-03-31 21:40:49 +04:00
|
|
|
CPU_CFLAGS="-m64"
|
build-sys: clean up flags included in the linker command line
Some of the CFLAGS that are discovered during configure, for example
compiler warnings, are being included on the linker command line because
QEMU_CFLAGS is added to it. Other flags, such as the -m32, appear twice
because they are included in both QEMU_CFLAGS and LDFLAGS. All this
leads to confusion with respect to what goes in which Makefile variables
(and we have plenty).
So, introduce QEMU_LDFLAGS for flags discovered by configure, following
the lead of QEMU_CFLAGS, and stop adding to it:
1) options that are already in CFLAGS, for example "-g"
2) duplicate options
At the same time, options that _are_ needed by both compiler and linker
must now be added to both QEMU_CFLAGS and QEMU_LDFLAGS, which is clearer.
This is mostly -fsanitize options. For now, --extra-cflags has this behavior
(but --extra-cxxflags does not).
Meson will not include CFLAGS on the linker command line, do the same in our
build system as well.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
2019-12-11 17:34:27 +03:00
|
|
|
QEMU_LDFLAGS="-m64 $QEMU_LDFLAGS"
|
2007-11-19 00:22:10 +03:00
|
|
|
;;
|
2008-01-31 14:32:10 +03:00
|
|
|
i386)
|
2013-04-18 08:46:14 +04:00
|
|
|
CPU_CFLAGS="-m32"
|
build-sys: clean up flags included in the linker command line
Some of the CFLAGS that are discovered during configure, for example
compiler warnings, are being included on the linker command line because
QEMU_CFLAGS is added to it. Other flags, such as the -m32, appear twice
because they are included in both QEMU_CFLAGS and LDFLAGS. All this
leads to confusion with respect to what goes in which Makefile variables
(and we have plenty).
So, introduce QEMU_LDFLAGS for flags discovered by configure, following
the lead of QEMU_CFLAGS, and stop adding to it:
1) options that are already in CFLAGS, for example "-g"
2) duplicate options
At the same time, options that _are_ needed by both compiler and linker
must now be added to both QEMU_CFLAGS and QEMU_LDFLAGS, which is clearer.
This is mostly -fsanitize options. For now, --extra-cflags has this behavior
(but --extra-cxxflags does not).
Meson will not include CFLAGS on the linker command line, do the same in our
build system as well.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
2019-12-11 17:34:27 +03:00
|
|
|
QEMU_LDFLAGS="-m32 $QEMU_LDFLAGS"
|
2008-01-31 14:32:10 +03:00
|
|
|
;;
|
|
|
|
x86_64)
|
2016-06-30 07:10:59 +03:00
|
|
|
# ??? Only extremely old AMD cpus do not have cmpxchg16b.
|
|
|
|
# If we truly care, we should simply detect this case at
|
|
|
|
# runtime and generate the fallback to serial emulation.
|
|
|
|
CPU_CFLAGS="-m64 -mcx16"
|
build-sys: clean up flags included in the linker command line
Some of the CFLAGS that are discovered during configure, for example
compiler warnings, are being included on the linker command line because
QEMU_CFLAGS is added to it. Other flags, such as the -m32, appear twice
because they are included in both QEMU_CFLAGS and LDFLAGS. All this
leads to confusion with respect to what goes in which Makefile variables
(and we have plenty).
So, introduce QEMU_LDFLAGS for flags discovered by configure, following
the lead of QEMU_CFLAGS, and stop adding to it:
1) options that are already in CFLAGS, for example "-g"
2) duplicate options
At the same time, options that _are_ needed by both compiler and linker
must now be added to both QEMU_CFLAGS and QEMU_LDFLAGS, which is clearer.
This is mostly -fsanitize options. For now, --extra-cflags has this behavior
(but --extra-cxxflags does not).
Meson will not include CFLAGS on the linker command line, do the same in our
build system as well.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
2019-12-11 17:34:27 +03:00
|
|
|
QEMU_LDFLAGS="-m64 $QEMU_LDFLAGS"
|
2011-04-12 12:27:03 +04:00
|
|
|
;;
|
2013-08-20 23:20:05 +04:00
|
|
|
x32)
|
|
|
|
CPU_CFLAGS="-mx32"
|
build-sys: clean up flags included in the linker command line
Some of the CFLAGS that are discovered during configure, for example
compiler warnings, are being included on the linker command line because
QEMU_CFLAGS is added to it. Other flags, such as the -m32, appear twice
because they are included in both QEMU_CFLAGS and LDFLAGS. All this
leads to confusion with respect to what goes in which Makefile variables
(and we have plenty).
So, introduce QEMU_LDFLAGS for flags discovered by configure, following
the lead of QEMU_CFLAGS, and stop adding to it:
1) options that are already in CFLAGS, for example "-g"
2) duplicate options
At the same time, options that _are_ needed by both compiler and linker
must now be added to both QEMU_CFLAGS and QEMU_LDFLAGS, which is clearer.
This is mostly -fsanitize options. For now, --extra-cflags has this behavior
(but --extra-cxxflags does not).
Meson will not include CFLAGS on the linker command line, do the same in our
build system as well.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
2019-12-11 17:34:27 +03:00
|
|
|
QEMU_LDFLAGS="-mx32 $QEMU_LDFLAGS"
|
2013-08-20 23:20:05 +04:00
|
|
|
;;
|
2012-10-09 07:16:49 +04:00
|
|
|
# No special flags required for other host CPUs
|
2007-04-16 22:27:06 +04:00
|
|
|
esac
|
|
|
|
|
2019-08-07 17:35:23 +03:00
|
|
|
eval "cross_cc_${cpu}=\$host_cc"
|
|
|
|
cross_cc_vars="$cross_cc_vars cross_cc_${cpu}"
|
2013-04-18 08:46:14 +04:00
|
|
|
QEMU_CFLAGS="$CPU_CFLAGS $QEMU_CFLAGS"
|
|
|
|
|
2016-06-13 13:32:24 +03:00
|
|
|
# For user-mode emulation the host arch has to be one we explicitly
|
|
|
|
# support, even if we're using TCI.
|
|
|
|
if [ "$ARCH" = "unknown" ]; then
|
|
|
|
bsd_user="no"
|
|
|
|
linux_user="no"
|
|
|
|
fi
|
|
|
|
|
2011-05-03 17:50:13 +04:00
|
|
|
default_target_list=""
|
2020-09-21 11:37:49 +03:00
|
|
|
deprecated_targets_list=ppc64abi32-linux-user,tilegx-linux-user,lm32-softmmu,unicore32-softmmu
|
|
|
|
deprecated_features=""
|
2013-05-20 19:16:15 +04:00
|
|
|
mak_wilds=""
|
|
|
|
|
|
|
|
if [ "$softmmu" = "yes" ]; then
|
2020-09-18 13:44:16 +03:00
|
|
|
mak_wilds="${mak_wilds} $source_path/default-configs/targets/*-softmmu.mak"
|
2011-05-03 17:50:13 +04:00
|
|
|
fi
|
2013-05-20 19:16:15 +04:00
|
|
|
if [ "$linux_user" = "yes" ]; then
|
2020-09-18 13:44:16 +03:00
|
|
|
mak_wilds="${mak_wilds} $source_path/default-configs/targets/*-linux-user.mak"
|
2011-05-03 17:50:13 +04:00
|
|
|
fi
|
2013-05-20 19:16:15 +04:00
|
|
|
if [ "$bsd_user" = "yes" ]; then
|
2020-09-18 13:44:16 +03:00
|
|
|
mak_wilds="${mak_wilds} $source_path/default-configs/targets/*-bsd-user.mak"
|
2011-05-03 17:50:13 +04:00
|
|
|
fi
|
|
|
|
|
2020-09-15 16:43:13 +03:00
|
|
|
# If the user doesn't explicitly specify a deprecated target we will
|
|
|
|
# skip it.
|
|
|
|
if test -z "$target_list"; then
|
|
|
|
if test -z "$target_list_exclude"; then
|
|
|
|
target_list_exclude="$deprecated_targets_list"
|
|
|
|
else
|
|
|
|
target_list_exclude="$target_list_exclude,$deprecated_targets_list"
|
|
|
|
fi
|
2020-09-09 14:27:37 +03:00
|
|
|
fi
|
|
|
|
|
|
|
|
for config in $mak_wilds; do
|
|
|
|
target="$(basename "$config" .mak)"
|
2020-09-15 16:43:14 +03:00
|
|
|
if echo "$target_list_exclude" | grep -vq "$target"; then
|
2020-09-09 14:27:37 +03:00
|
|
|
default_target_list="${default_target_list} $target"
|
|
|
|
fi
|
|
|
|
done
|
2013-05-20 19:16:15 +04:00
|
|
|
|
2017-03-28 16:44:18 +03:00
|
|
|
# Enumerate public trace backends for --help output
|
2017-04-26 16:36:07 +03:00
|
|
|
trace_backend_list=$(echo $(grep -le '^PUBLIC = True$' "$source_path"/scripts/tracetool/backend/*.py | sed -e 's/^.*\/\(.*\)\.py$/\1/'))
|
2017-03-28 16:44:18 +03:00
|
|
|
|
2006-04-08 18:26:41 +04:00
|
|
|
if test x"$show_help" = x"yes" ; then
|
|
|
|
cat << EOF
|
|
|
|
|
|
|
|
Usage: configure [options]
|
|
|
|
Options: [defaults in brackets after descriptions]
|
|
|
|
|
2013-12-19 01:09:39 +04:00
|
|
|
Standard options:
|
|
|
|
--help print this message
|
|
|
|
--prefix=PREFIX install in PREFIX [$prefix]
|
|
|
|
--interp-prefix=PREFIX where to find shared libraries, etc.
|
|
|
|
use %M for cpu name [$interp_prefix]
|
2020-10-29 23:14:49 +03:00
|
|
|
--target-list=LIST set target list (default: build all non-deprecated)
|
2013-12-19 01:09:39 +04:00
|
|
|
$(echo Available targets: $default_target_list | \
|
|
|
|
fold -s -w 53 | sed -e 's/^/ /')
|
2020-10-29 23:14:49 +03:00
|
|
|
$(echo Deprecated targets: $deprecated_targets_list | \
|
|
|
|
fold -s -w 53 | sed -e 's/^/ /')
|
2019-03-19 14:59:12 +03:00
|
|
|
--target-list-exclude=LIST exclude a set of targets from the default target-list
|
2013-12-19 01:09:39 +04:00
|
|
|
|
|
|
|
Advanced options (experts only):
|
|
|
|
--cross-prefix=PREFIX use PREFIX for compile tools [$cross_prefix]
|
|
|
|
--cc=CC use C compiler CC [$cc]
|
|
|
|
--iasl=IASL use ACPI compiler IASL [$iasl]
|
|
|
|
--host-cc=CC use C compiler CC [$host_cc] for code run at
|
|
|
|
build time
|
|
|
|
--cxx=CXX use C++ compiler CXX [$cxx]
|
|
|
|
--objcc=OBJCC use Objective-C compiler OBJCC [$objcc]
|
|
|
|
--extra-cflags=CFLAGS append extra C compiler flags QEMU_CFLAGS
|
2017-06-06 16:07:47 +03:00
|
|
|
--extra-cxxflags=CXXFLAGS append extra C++ compiler flags QEMU_CXXFLAGS
|
2013-12-19 01:09:39 +04:00
|
|
|
--extra-ldflags=LDFLAGS append extra linker flags LDFLAGS
|
2018-04-04 22:27:05 +03:00
|
|
|
--cross-cc-ARCH=CC use compiler when building ARCH guest test cases
|
2018-04-13 13:07:58 +03:00
|
|
|
--cross-cc-flags-ARCH= use compiler flags when building ARCH guest tests
|
2013-12-19 01:09:39 +04:00
|
|
|
--make=MAKE use specified make [$make]
|
|
|
|
--python=PYTHON use specified python [$python]
|
2020-02-13 20:56:18 +03:00
|
|
|
--sphinx-build=SPHINX use specified sphinx-build [$sphinx_build]
|
2019-06-10 13:05:14 +03:00
|
|
|
--meson=MESON use specified meson [$meson]
|
2020-08-26 09:04:15 +03:00
|
|
|
--ninja=NINJA use specified ninja [$ninja]
|
2013-12-19 01:09:39 +04:00
|
|
|
--smbd=SMBD use specified smbd [$smbd]
|
2018-03-27 18:09:30 +03:00
|
|
|
--with-git=GIT use specified git [$git]
|
2013-12-19 01:09:39 +04:00
|
|
|
--static enable static build [$static]
|
|
|
|
--mandir=PATH install man pages in PATH
|
2020-08-26 14:04:13 +03:00
|
|
|
--datadir=PATH install firmware in PATH/$qemu_suffix
|
2020-10-16 11:35:10 +03:00
|
|
|
--localedir=PATH install translation in PATH/$qemu_suffix
|
2020-08-26 14:04:13 +03:00
|
|
|
--docdir=PATH install documentation in PATH/$qemu_suffix
|
2013-12-19 01:09:39 +04:00
|
|
|
--bindir=PATH install binaries in PATH
|
|
|
|
--libdir=PATH install libraries in PATH
|
2018-03-27 18:09:30 +03:00
|
|
|
--libexecdir=PATH install helper binaries in PATH
|
2020-08-26 14:04:13 +03:00
|
|
|
--sysconfdir=PATH install config in PATH/$qemu_suffix
|
2013-12-19 01:09:39 +04:00
|
|
|
--localstatedir=PATH install local state in PATH (set at runtime on win32)
|
2017-09-14 14:42:36 +03:00
|
|
|
--firmwarepath=PATH search PATH for firmware files
|
2020-07-01 16:56:21 +03:00
|
|
|
--efi-aarch64=PATH PATH of efi file to use for aarch64 VMs.
|
2020-08-26 14:04:14 +03:00
|
|
|
--with-suffix=SUFFIX suffix for QEMU data inside datadir/libdir/sysconfdir/docdir [$qemu_suffix]
|
2018-03-27 18:09:30 +03:00
|
|
|
--with-pkgversion=VERS use specified string as sub-version of the package
|
2020-12-14 13:34:47 +03:00
|
|
|
--without-default-features default all --enable-* options to "disabled"
|
|
|
|
--without-default-devices do not include any device that is not needed to
|
|
|
|
start the emulator (only use if you are including
|
|
|
|
desired devices in default-configs/devices/)
|
2013-12-19 01:09:39 +04:00
|
|
|
--enable-debug enable common debug build options
|
2018-01-16 18:11:51 +03:00
|
|
|
--enable-sanitizers enable default sanitizers
|
2020-06-12 22:02:23 +03:00
|
|
|
--enable-tsan enable thread sanitizer
|
2013-12-19 01:09:39 +04:00
|
|
|
--disable-strip disable stripping binaries
|
|
|
|
--disable-werror disable compilation abort on warning
|
2014-03-28 20:19:02 +04:00
|
|
|
--disable-stack-protector disable compiler-provided stack protection
|
2013-12-19 01:09:39 +04:00
|
|
|
--audio-drv-list=LIST set audio drivers list:
|
|
|
|
Available drivers: $audio_possible_drivers
|
|
|
|
--block-drv-whitelist=L Same as --block-drv-rw-whitelist=L
|
|
|
|
--block-drv-rw-whitelist=L
|
|
|
|
set block driver read-write whitelist
|
|
|
|
(affects only QEMU, not qemu-img)
|
|
|
|
--block-drv-ro-whitelist=L
|
|
|
|
set block driver read-only whitelist
|
|
|
|
(affects only QEMU, not qemu-img)
|
2014-05-27 17:02:14 +04:00
|
|
|
--enable-trace-backends=B Set trace backend
|
2017-03-28 16:44:18 +03:00
|
|
|
Available backends: $trace_backend_list
|
2013-12-19 01:09:39 +04:00
|
|
|
--with-trace-file=NAME Full PATH,NAME of file to store traces
|
|
|
|
Default:trace-<pid>
|
2015-06-17 22:19:26 +03:00
|
|
|
--disable-slirp disable SLIRP userspace network connectivity
|
|
|
|
--enable-tcg-interpreter enable TCG with bytecode interpreter (TCI)
|
2017-12-20 16:16:46 +03:00
|
|
|
--enable-malloc-trim enable libc malloc_trim() for memory optimization
|
2015-06-17 22:19:26 +03:00
|
|
|
--oss-lib path to OSS library
|
|
|
|
--cpu=CPU Build for host CPU [$cpu]
|
2013-12-19 01:09:39 +04:00
|
|
|
--with-coroutine=BACKEND coroutine backend. Supported options:
|
2017-04-28 15:24:44 +03:00
|
|
|
ucontext, sigaltstack, windows
|
2013-12-19 01:09:39 +04:00
|
|
|
--enable-gcov enable test coverage analysis with gcov
|
2015-06-17 22:19:26 +03:00
|
|
|
--disable-blobs disable installing provided firmware blobs
|
|
|
|
--with-vss-sdk=SDK-path enable Windows VSS support in QEMU Guest Agent
|
|
|
|
--with-win-sdk=SDK-path path to Windows Platform SDK (to build VSS .tlb)
|
2016-06-06 12:05:06 +03:00
|
|
|
--tls-priority default TLS protocol/cipher priority string
|
2017-03-10 13:14:05 +03:00
|
|
|
--enable-gprof QEMU profiling with gprof
|
|
|
|
--enable-profiler profiler support
|
|
|
|
--enable-debug-stack-usage
|
|
|
|
track the maximum stack usage of stacks created by qemu_alloc_stack
|
2019-06-13 16:52:25 +03:00
|
|
|
--enable-plugins
|
|
|
|
enable plugins via shared library loading
|
2019-11-28 18:35:24 +03:00
|
|
|
--disable-containers don't use containers for cross-building
|
2020-03-16 20:21:48 +03:00
|
|
|
--gdb=GDB-path gdb to use for gdbstub tests [$gdb_bin]
|
2015-06-17 22:19:26 +03:00
|
|
|
|
|
|
|
Optional features, enabled with --enable-FEATURE and
|
2020-12-10 22:04:13 +03:00
|
|
|
disabled with --disable-FEATURE, default is enabled if available
|
|
|
|
(unless built with --without-default-features):
|
2015-06-17 22:19:26 +03:00
|
|
|
|
|
|
|
system all system emulation targets
|
|
|
|
user supported user emulation targets
|
|
|
|
linux-user all linux usermode emulation targets
|
|
|
|
bsd-user all BSD usermode emulation targets
|
|
|
|
docs build documentation
|
|
|
|
guest-agent build the QEMU Guest Agent
|
|
|
|
guest-agent-msi build guest agent Windows MSI installation package
|
|
|
|
pie Position Independent Executables
|
2019-07-18 15:04:13 +03:00
|
|
|
modules modules support (non-Windows)
|
2020-03-10 17:58:06 +03:00
|
|
|
module-upgrades try to load modules from alternate paths for upgrades
|
2015-06-17 22:19:26 +03:00
|
|
|
debug-tcg TCG debugging (default is disabled)
|
|
|
|
debug-info debugging information
|
2020-12-05 02:06:11 +03:00
|
|
|
lto Enable Link-Time Optimization.
|
2015-06-17 22:19:26 +03:00
|
|
|
sparse sparse checker
|
2020-05-29 23:51:21 +03:00
|
|
|
safe-stack SafeStack Stack Smash Protection. Depends on
|
|
|
|
clang/llvm >= 3.7 and requires coroutine backend ucontext.
|
2020-12-05 02:06:14 +03:00
|
|
|
cfi Enable Control-Flow Integrity for indirect function calls.
|
|
|
|
In case of a cfi violation, QEMU is terminated with SIGILL
|
|
|
|
Depends on lto and is incompatible with modules
|
|
|
|
Automatically enables Link-Time Optimization (lto)
|
|
|
|
cfi-debug In case of a cfi violation, a message containing the line that
|
|
|
|
triggered the error is written to stderr. After the error,
|
|
|
|
QEMU is still terminated with SIGILL
|
2015-07-01 20:10:29 +03:00
|
|
|
gnutls GNUTLS cryptography support
|
2015-10-16 18:36:53 +03:00
|
|
|
nettle nettle cryptography support
|
|
|
|
gcrypt libgcrypt cryptography support
|
authz: add QAuthZPAM object type for authorizing using PAM
Add an authorization backend that talks to PAM to check whether the user
identity is allowed. This only uses the PAM account validation facility,
which is essentially just a check to see if the provided username is permitted
access. It doesn't use the authentication or session parts of PAM, since
that's dealt with by the relevant part of QEMU (eg VNC server).
Consider starting QEMU with a VNC server and telling it to use TLS with
x509 client certificates and configuring it to use an PAM to validate
the x509 distinguished name. In this example we're telling it to use PAM
for the QAuthZ impl with a service name of "qemu-vnc"
$ qemu-system-x86_64 \
-object tls-creds-x509,id=tls0,dir=/home/berrange/security/qemutls,\
endpoint=server,verify-peer=yes \
-object authz-pam,id=authz0,service=qemu-vnc \
-vnc :1,tls-creds=tls0,tls-authz=authz0
This requires an /etc/pam/qemu-vnc file to be created with the auth
rules. A very simple file based whitelist can be setup using
$ cat > /etc/pam/qemu-vnc <<EOF
account requisite pam_listfile.so item=user sense=allow file=/etc/qemu/vnc.allow
EOF
The /etc/qemu/vnc.allow file simply contains one username per line. Any
username not in the file is denied. The usernames in this example are
the x509 distinguished name from the client's x509 cert.
$ cat > /etc/qemu/vnc.allow <<EOF
CN=laptop.berrange.com,O=Berrange Home,L=London,ST=London,C=GB
EOF
More interesting would be to configure PAM to use an LDAP backend, so
that the QEMU authorization check data can be centralized instead of
requiring each compute host to have file maintained.
The main limitation with this PAM module is that the rules apply to all
QEMU instances on the host. Setting up different rules per VM, would
require creating a separate PAM service name & config file for every
guest. An alternative approach for the future might be to not pass in
the plain username to PAM, but instead combine the VM name or UUID with
the username. This requires further consideration though.
Tested-by: Philippe Mathieu-Daudé <philmd@redhat.com>
Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com>
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
2016-07-27 16:13:56 +03:00
|
|
|
auth-pam PAM access control
|
2015-06-17 22:19:26 +03:00
|
|
|
sdl SDL UI
|
2019-05-17 21:32:46 +03:00
|
|
|
sdl-image SDL Image support for icons
|
2015-06-17 22:19:26 +03:00
|
|
|
gtk gtk UI
|
|
|
|
vte vte support for the gtk UI
|
|
|
|
curses curses UI
|
2019-03-11 16:51:26 +03:00
|
|
|
iconv font glyph conversion support
|
2015-06-17 22:19:26 +03:00
|
|
|
vnc VNC UI support
|
|
|
|
vnc-sasl SASL encryption for VNC server
|
|
|
|
vnc-jpeg JPEG lossy compression for VNC server
|
|
|
|
vnc-png PNG compression for VNC server
|
|
|
|
cocoa Cocoa UI (Mac OS X only)
|
|
|
|
virtfs VirtFS
|
2020-10-08 13:31:33 +03:00
|
|
|
virtiofsd build virtiofs daemon (virtiofsd)
|
2020-10-15 13:09:27 +03:00
|
|
|
libudev Use libudev to enumerate host devices
|
2017-08-22 07:50:55 +03:00
|
|
|
mpath Multipath persistent reservation passthrough
|
2015-06-17 22:19:26 +03:00
|
|
|
xen xen backend driver support
|
2018-05-04 12:17:56 +03:00
|
|
|
xen-pci-passthrough PCI passthrough support for Xen
|
2015-06-17 22:19:26 +03:00
|
|
|
brlapi BrlAPI (Braile)
|
|
|
|
curl curl connectivity
|
2018-02-16 12:05:23 +03:00
|
|
|
membarrier membarrier system call (for Linux 4.14+ or Windows)
|
2015-06-17 22:19:26 +03:00
|
|
|
fdt fdt device tree
|
|
|
|
kvm KVM acceleration support
|
2017-01-10 13:59:57 +03:00
|
|
|
hax HAX acceleration support
|
i386: hvf: add code base from Google's QEMU repository
This file begins tracking the files that will be the code base for HVF
support in QEMU. This code base is part of Google's QEMU version of
their Android emulator, and can be found at
https://android.googlesource.com/platform/external/qemu/+/emu-master-dev
This code is based on Veertu Inc's vdhh (Veertu Desktop Hosted
Hypervisor), found at https://github.com/veertuinc/vdhh. Everything is
appropriately licensed under GPL v2-or-later, except for the code inside
x86_task.c and x86_task.h, which, deriving from KVM (the Linux kernel),
is licensed GPL v2-only.
This code base already implements a very great deal of functionality,
although Google's version removed from Vertuu's the support for APIC
page and hyperv-related stuff. According to the Android Emulator Release
Notes, Revision 26.1.3 (August 2017), "Hypervisor.framework is now
enabled by default on macOS for 32-bit x86 images to improve performance
and macOS compatibility", although we better use with caution for, as the
same Revision warns us, "If you experience issues with it specifically,
please file a bug report...". The code hasn't seen much update in the
last 5 months, so I think that we can further develop the code with
occasional visiting Google's repository to see if there has been any
update.
On top of Google's code, the following changes were made:
- add code to the configure script to support the --enable-hvf argument.
If the OS is Darwin, it checks for presence of HVF in the system. The
patch also adds strings related to HVF in the file qemu-options.hx.
QEMU will only support the modern syntax style '-M accel=hvf' no enable
hvf; the legacy '-enable-hvf' will not be supported.
- fix styling issues
- add glue code to cpus.c
- move HVFX86EmulatorState field to CPUX86State, changing the
the emulation functions to have a parameter with signature 'CPUX86State *'
instead of 'CPUState *' so we don't have to get the 'env'.
Signed-off-by: Sergio Andres Gomez Del Real <Sergio.G.DelReal@gmail.com>
Message-Id: <20170913090522.4022-2-Sergio.G.DelReal@gmail.com>
Message-Id: <20170913090522.4022-3-Sergio.G.DelReal@gmail.com>
Message-Id: <20170913090522.4022-5-Sergio.G.DelReal@gmail.com>
Message-Id: <20170913090522.4022-6-Sergio.G.DelReal@gmail.com>
Message-Id: <20170905035457.3753-7-Sergio.G.DelReal@gmail.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
2017-09-13 12:05:09 +03:00
|
|
|
hvf Hypervisor.framework acceleration support
|
2018-01-23 00:07:46 +03:00
|
|
|
whpx Windows Hypervisor Platform acceleration support
|
2018-08-16 18:16:37 +03:00
|
|
|
rdma Enable RDMA-based migration
|
|
|
|
pvrdma Enable PVRDMA support
|
2015-06-17 22:19:26 +03:00
|
|
|
vde support for vde network
|
|
|
|
netmap support for netmap network
|
|
|
|
linux-aio Linux AIO support
|
2020-01-20 17:18:44 +03:00
|
|
|
linux-io-uring Linux io_uring support
|
2015-06-17 22:19:26 +03:00
|
|
|
cap-ng libcap-ng support
|
|
|
|
attr attr and xattr support
|
2019-02-14 20:35:53 +03:00
|
|
|
vhost-net vhost-net kernel acceleration support
|
|
|
|
vhost-vsock virtio sockets device support
|
|
|
|
vhost-scsi vhost-scsi kernel target support
|
|
|
|
vhost-crypto vhost-user-crypto backend support
|
|
|
|
vhost-kernel vhost kernel backend support
|
|
|
|
vhost-user vhost-user backend support
|
2020-10-27 20:35:18 +03:00
|
|
|
vhost-user-blk-server vhost-user-blk server support
|
2020-07-01 17:55:37 +03:00
|
|
|
vhost-vdpa vhost-vdpa kernel backend support
|
2015-06-17 22:19:26 +03:00
|
|
|
spice spice
|
|
|
|
rbd rados block device (rbd)
|
|
|
|
libiscsi iscsi support
|
|
|
|
libnfs nfs support
|
2015-08-30 12:48:40 +03:00
|
|
|
smartcard smartcard support (libcacard)
|
2020-08-26 14:42:04 +03:00
|
|
|
u2f U2F support (u2f-emu)
|
2015-06-17 22:19:26 +03:00
|
|
|
libusb libusb (for usb passthrough)
|
2017-05-15 17:05:29 +03:00
|
|
|
live-block-migration Block migration in the main migration stream
|
2015-06-17 22:19:26 +03:00
|
|
|
usb-redir usb network redirection support
|
|
|
|
lzo support of lzo compression library
|
|
|
|
snappy support of snappy compression library
|
|
|
|
bzip2 support of bzip2 compression library
|
|
|
|
(for reading bzip2-compressed dmg images)
|
2018-11-05 18:08:04 +03:00
|
|
|
lzfse support of lzfse compression library
|
|
|
|
(for reading lzfse-compressed dmg images)
|
2019-12-17 23:15:24 +03:00
|
|
|
zstd support for zstd compression library
|
2020-05-07 11:25:20 +03:00
|
|
|
(for migration compression and qcow2 cluster compression)
|
2015-06-17 22:19:26 +03:00
|
|
|
seccomp seccomp support
|
|
|
|
coroutine-pool coroutine freelist (better performance)
|
|
|
|
glusterfs GlusterFS backend
|
|
|
|
tpm TPM support
|
2019-06-20 23:08:40 +03:00
|
|
|
libssh ssh block device support
|
2015-06-17 22:19:26 +03:00
|
|
|
numa libnuma support
|
2018-01-12 12:01:19 +03:00
|
|
|
libxml2 for Parallels image format
|
2015-06-17 22:19:26 +03:00
|
|
|
tcmalloc tcmalloc support
|
2015-06-19 13:56:58 +03:00
|
|
|
jemalloc jemalloc support
|
2018-10-19 23:38:59 +03:00
|
|
|
avx2 AVX2 optimization support
|
2020-02-29 15:34:34 +03:00
|
|
|
avx512f AVX512F optimization support
|
2016-07-27 10:01:48 +03:00
|
|
|
replication replication support
|
2017-03-10 13:14:05 +03:00
|
|
|
opengl opengl support
|
|
|
|
virglrenderer virgl rendering support
|
|
|
|
xfsctl xfsctl support
|
|
|
|
qom-cast-debug cast debugging support
|
2019-02-07 22:36:03 +03:00
|
|
|
tools build qemu-io, qemu-nbd and qemu-img tools
|
2018-11-07 09:36:44 +03:00
|
|
|
bochs bochs image format support
|
|
|
|
cloop cloop image format support
|
|
|
|
dmg dmg image format support
|
|
|
|
qcow1 qcow v1 image format support
|
|
|
|
vdi vdi image format support
|
|
|
|
vvfat vvfat image format support
|
|
|
|
qed qed image format support
|
|
|
|
parallels parallels image format support
|
2020-10-02 14:32:43 +03:00
|
|
|
sheepdog sheepdog block driver support (deprecated)
|
2017-07-14 21:04:05 +03:00
|
|
|
crypto-afalg Linux AF_ALG crypto backend driver
|
2017-09-14 19:41:12 +03:00
|
|
|
capstone capstone disassembler support
|
2018-06-13 15:23:08 +03:00
|
|
|
debug-mutex mutex debugging support
|
2018-07-18 10:47:59 +03:00
|
|
|
libpmem libpmem support
|
2019-09-14 17:51:55 +03:00
|
|
|
xkbcommon xkbcommon support
|
2020-05-20 16:20:23 +03:00
|
|
|
rng-none dummy RNG, avoid using /dev/(u)random and getrandom()
|
2020-04-29 11:50:11 +03:00
|
|
|
libdaxctl libdaxctl support
|
2020-10-27 22:05:41 +03:00
|
|
|
fuse FUSE block device export
|
2020-10-27 22:05:46 +03:00
|
|
|
fuse-lseek SEEK_HOLE/SEEK_DATA support for FUSE exports
|
2013-12-19 01:09:39 +04:00
|
|
|
|
|
|
|
NOTE: The object files are built at the place where configure is launched
|
2006-04-08 18:26:41 +04:00
|
|
|
EOF
|
2014-04-18 10:55:36 +04:00
|
|
|
exit 0
|
2006-04-08 18:26:41 +04:00
|
|
|
fi
|
|
|
|
|
2019-03-11 13:20:34 +03:00
|
|
|
# Remove old dependency files to make sure that they get properly regenerated
|
2019-05-10 11:11:59 +03:00
|
|
|
rm -f */config-devices.mak.d
|
2019-03-11 13:20:34 +03:00
|
|
|
|
2019-03-27 20:07:01 +03:00
|
|
|
if test -z "$python"
|
|
|
|
then
|
|
|
|
error_exit "Python not found. Use --python=/path/to/python"
|
2017-03-28 16:44:18 +03:00
|
|
|
fi
|
2020-08-25 23:27:55 +03:00
|
|
|
if ! has "$make"
|
|
|
|
then
|
|
|
|
error_exit "GNU make ($make) not found"
|
|
|
|
fi
|
2017-03-28 16:44:18 +03:00
|
|
|
|
|
|
|
# Note that if the Python conditional here evaluates True we will exit
|
|
|
|
# with status 1 which is a shell 'false' value.
|
2020-09-25 18:40:27 +03:00
|
|
|
if ! $python -c 'import sys; sys.exit(sys.version_info < (3,6))'; then
|
|
|
|
error_exit "Cannot use '$python', Python >= 3.6 is required." \
|
2017-03-28 16:44:18 +03:00
|
|
|
"Use --python=/path/to/python to specify a supported Python."
|
|
|
|
fi
|
|
|
|
|
2018-11-09 18:07:07 +03:00
|
|
|
# Preserve python version since some functionality is dependent on it
|
2019-08-26 18:58:32 +03:00
|
|
|
python_version=$($python -c 'import sys; print("%d.%d.%d" % (sys.version_info[0], sys.version_info[1], sys.version_info[2]))' 2>/dev/null)
|
2018-11-09 18:07:07 +03:00
|
|
|
|
2017-03-28 16:44:18 +03:00
|
|
|
# Suppress writing compiled files
|
|
|
|
python="$python -B"
|
|
|
|
|
2019-08-21 10:21:16 +03:00
|
|
|
if test -z "$meson"; then
|
2020-10-15 10:20:45 +03:00
|
|
|
if test "$explicit_python" = no && has meson && version_ge "$(meson --version)" 0.55.3; then
|
2019-08-21 10:21:16 +03:00
|
|
|
meson=meson
|
|
|
|
elif test -e "${source_path}/.git" && test $git_update = 'yes' ; then
|
|
|
|
meson=git
|
|
|
|
elif test -e "${source_path}/meson/meson.py" ; then
|
|
|
|
meson=internal
|
|
|
|
else
|
|
|
|
if test "$explicit_python" = yes; then
|
|
|
|
error_exit "--python requires using QEMU's embedded Meson distribution, but it was not found."
|
|
|
|
else
|
|
|
|
error_exit "Meson not found. Use --meson=/path/to/meson"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
else
|
|
|
|
# Meson uses its own Python interpreter to invoke other Python scripts,
|
|
|
|
# but the user wants to use the one they specified with --python.
|
|
|
|
#
|
|
|
|
# We do not want to override the distro Python interpreter (and sometimes
|
|
|
|
# cannot: for example in Homebrew /usr/bin/meson is a bash script), so
|
|
|
|
# just require --meson=git|internal together with --python.
|
|
|
|
if test "$explicit_python" = yes; then
|
|
|
|
case "$meson" in
|
|
|
|
git | internal) ;;
|
|
|
|
*) error_exit "--python requires using QEMU's embedded Meson distribution." ;;
|
|
|
|
esac
|
|
|
|
fi
|
2019-06-10 13:05:14 +03:00
|
|
|
fi
|
|
|
|
|
2019-08-21 10:21:16 +03:00
|
|
|
if test "$meson" = git; then
|
|
|
|
git_submodules="${git_submodules} meson"
|
2019-06-10 13:05:14 +03:00
|
|
|
fi
|
2019-08-21 10:21:16 +03:00
|
|
|
|
|
|
|
case "$meson" in
|
|
|
|
git | internal)
|
|
|
|
meson="$python ${source_path}/meson/meson.py"
|
|
|
|
;;
|
2020-09-04 17:00:26 +03:00
|
|
|
*) meson=$(command -v "$meson") ;;
|
2019-08-21 10:21:16 +03:00
|
|
|
esac
|
|
|
|
|
2020-08-13 16:28:11 +03:00
|
|
|
# Probe for ninja
|
2020-08-26 09:04:15 +03:00
|
|
|
|
|
|
|
if test -z "$ninja"; then
|
|
|
|
for c in ninja ninja-build samu; do
|
|
|
|
if has $c; then
|
|
|
|
ninja=$(command -v "$c")
|
|
|
|
break
|
|
|
|
fi
|
|
|
|
done
|
2020-08-13 16:28:11 +03:00
|
|
|
if test -z "$ninja"; then
|
|
|
|
error_exit "Cannot find Ninja"
|
|
|
|
fi
|
2020-08-26 09:04:15 +03:00
|
|
|
fi
|
2019-06-10 13:05:14 +03:00
|
|
|
|
2017-11-02 12:09:06 +03:00
|
|
|
# Check that the C compiler works. Doing this here before testing
|
|
|
|
# the host CPU ensures that we had a valid CC to autodetect the
|
|
|
|
# $cpu var (and we should bail right here if that's not the case).
|
|
|
|
# It also allows the help message to be printed without a CC.
|
|
|
|
write_c_skeleton;
|
|
|
|
if compile_object ; then
|
|
|
|
: C compiler works ok
|
|
|
|
else
|
|
|
|
error_exit "\"$cc\" either does not exist or does not work"
|
|
|
|
fi
|
|
|
|
if ! compile_prog ; then
|
|
|
|
error_exit "\"$cc\" cannot build an executable (is your linker broken?)"
|
|
|
|
fi
|
|
|
|
|
2014-02-25 22:27:49 +04:00
|
|
|
# Consult white-list to determine whether to enable werror
|
|
|
|
# by default. Only enable by default for git builds
|
|
|
|
if test -z "$werror" ; then
|
2019-02-28 07:35:03 +03:00
|
|
|
if test -e "$source_path/.git" && \
|
2019-02-05 05:39:37 +03:00
|
|
|
{ test "$linux" = "yes" || test "$mingw32" = "yes"; }; then
|
2014-02-25 22:27:49 +04:00
|
|
|
werror="yes"
|
|
|
|
else
|
|
|
|
werror="no"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2020-11-20 12:34:10 +03:00
|
|
|
if test "$targetos" = "bogus"; then
|
2017-03-28 16:01:52 +03:00
|
|
|
# Now that we know that we're not printing the help and that
|
|
|
|
# the compiler works (so the results of the check_defines we used
|
|
|
|
# to identify the OS are reliable), if we didn't recognize the
|
|
|
|
# host OS we should stop now.
|
2017-07-13 18:15:32 +03:00
|
|
|
error_exit "Unrecognized host OS (uname -s reports '$(uname -s)')"
|
2017-03-28 16:01:52 +03:00
|
|
|
fi
|
|
|
|
|
configure: Add a test for the minimum compiler version
So far we only had implicit requirements for the minimum compiler version,
e.g. we require at least GCC 4.1 for the support of atomics. However,
such old compiler versions are not tested anymore by the developers, so
they are not really supported anymore. Since we recently declared explicitly
what platforms we intend to support, we can also get more explicit on the
compiler version now. The supported distributions use the following version
of GCC:
RHEL-7: 4.8.5
Debian (Stretch): 6.3.0
Debian (Jessie): 4.8.4
OpenBSD (ports): 4.9.4
FreeBSD (ports): 8.2.0
OpenSUSE Leap 15: 7.3.1
Ubuntu (Xenial): 5.3.1
macOS (Homebrew): 8.2.0
So we can safely assume GCC 4.8 these days. For Clang, the situation is
a little bit more ambiguous, since it is sometimes not available in the
main distros but rather third party repositories. At least Debian Jessie
uses version 3.5, and EPEL7 for RHEL7 uses 3.4, so let's use 3.4 as
minimum Clang version now - we still can adjust this later if necessary.
Unfortunately Apple uses different version numbers for the Clang that is
included in their Xcode suite, so we need to check the version numbers
for Xcode separately. Xcode 5.1 seems to be the first one that has been
shipped with LLVM 3.4, so use this version as the minimum there.
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
Signed-off-by: Thomas Huth <thuth@redhat.com>
2018-12-03 12:12:32 +03:00
|
|
|
# Check whether the compiler matches our minimum requirements:
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#if defined(__clang_major__) && defined(__clang_minor__)
|
|
|
|
# ifdef __apple_build_version__
|
|
|
|
# if __clang_major__ < 5 || (__clang_major__ == 5 && __clang_minor__ < 1)
|
|
|
|
# error You need at least XCode Clang v5.1 to compile QEMU
|
|
|
|
# endif
|
|
|
|
# else
|
|
|
|
# if __clang_major__ < 3 || (__clang_major__ == 3 && __clang_minor__ < 4)
|
|
|
|
# error You need at least Clang v3.4 to compile QEMU
|
|
|
|
# endif
|
|
|
|
# endif
|
|
|
|
#elif defined(__GNUC__) && defined(__GNUC_MINOR__)
|
|
|
|
# if __GNUC__ < 4 || (__GNUC__ == 4 && __GNUC_MINOR__ < 8)
|
|
|
|
# error You need at least GCC v4.8 to compile QEMU
|
|
|
|
# endif
|
|
|
|
#else
|
|
|
|
# error You either need GCC or Clang to compiler QEMU
|
|
|
|
#endif
|
|
|
|
int main (void) { return 0; }
|
|
|
|
EOF
|
|
|
|
if ! compile_prog "" "" ; then
|
|
|
|
error_exit "You need at least GCC v4.8 or Clang v3.4 (or XCode Clang v5.1)"
|
|
|
|
fi
|
|
|
|
|
2020-06-17 23:13:06 +03:00
|
|
|
# Accumulate -Wfoo and -Wno-bar separately.
|
|
|
|
# We will list all of the enable flags first, and the disable flags second.
|
|
|
|
# Note that we do not add -Werror, because that would enable it for all
|
|
|
|
# configure tests. If a configure test failed due to -Werror this would
|
|
|
|
# just silently disable some features, so it's too error prone.
|
|
|
|
|
|
|
|
warn_flags=
|
|
|
|
add_to warn_flags -Wold-style-declaration
|
|
|
|
add_to warn_flags -Wold-style-definition
|
|
|
|
add_to warn_flags -Wtype-limits
|
|
|
|
add_to warn_flags -Wformat-security
|
|
|
|
add_to warn_flags -Wformat-y2k
|
|
|
|
add_to warn_flags -Winit-self
|
|
|
|
add_to warn_flags -Wignored-qualifiers
|
|
|
|
add_to warn_flags -Wempty-body
|
|
|
|
add_to warn_flags -Wnested-externs
|
|
|
|
add_to warn_flags -Wendif-labels
|
|
|
|
add_to warn_flags -Wexpansion-to-defined
|
2020-12-11 18:24:26 +03:00
|
|
|
add_to warn_flags -Wimplicit-fallthrough=2
|
2020-06-17 23:13:06 +03:00
|
|
|
|
|
|
|
nowarn_flags=
|
|
|
|
add_to nowarn_flags -Wno-initializer-overrides
|
|
|
|
add_to nowarn_flags -Wno-missing-include-dirs
|
|
|
|
add_to nowarn_flags -Wno-shift-negative-value
|
|
|
|
add_to nowarn_flags -Wno-string-plus-int
|
|
|
|
add_to nowarn_flags -Wno-typedef-redefinition
|
2020-06-17 23:13:07 +03:00
|
|
|
add_to nowarn_flags -Wno-tautological-type-limit-compare
|
2020-06-17 23:13:08 +03:00
|
|
|
add_to nowarn_flags -Wno-psabi
|
2020-06-17 23:13:06 +03:00
|
|
|
|
|
|
|
gcc_flags="$warn_flags $nowarn_flags"
|
2015-03-26 01:57:37 +03:00
|
|
|
|
|
|
|
cc_has_warning_flag() {
|
|
|
|
write_c_skeleton;
|
|
|
|
|
2012-10-28 01:19:07 +04:00
|
|
|
# Use the positive sense of the flag when testing for -Wno-wombat
|
|
|
|
# support (gcc will happily accept the -Wno- form of unknown
|
|
|
|
# warning options).
|
2015-03-26 01:57:37 +03:00
|
|
|
optflag="$(echo $1 | sed -e 's/^-Wno-/-W/')"
|
|
|
|
compile_prog "-Werror $optflag" ""
|
|
|
|
}
|
|
|
|
|
|
|
|
for flag in $gcc_flags; do
|
|
|
|
if cc_has_warning_flag $flag ; then
|
|
|
|
QEMU_CFLAGS="$QEMU_CFLAGS $flag"
|
2010-12-23 13:43:52 +03:00
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
2014-07-02 12:05:24 +04:00
|
|
|
if test "$stack_protector" != "no"; then
|
2015-11-12 17:04:28 +03:00
|
|
|
cat > $TMPC << EOF
|
|
|
|
int main(int argc, char *argv[])
|
|
|
|
{
|
|
|
|
char arr[64], *p = arr, *c = argv[0];
|
|
|
|
while (*c) {
|
|
|
|
*p++ = *c++;
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
2014-03-28 20:19:02 +04:00
|
|
|
gcc_flags="-fstack-protector-strong -fstack-protector-all"
|
2014-07-02 12:05:24 +04:00
|
|
|
sp_on=0
|
2014-03-28 20:19:02 +04:00
|
|
|
for flag in $gcc_flags; do
|
2014-04-11 20:13:52 +04:00
|
|
|
# We need to check both a compile and a link, since some compiler
|
|
|
|
# setups fail only on a .c->.o compile and some only at link time
|
2020-02-03 17:22:17 +03:00
|
|
|
if compile_object "-Werror $flag" &&
|
2014-04-11 20:13:52 +04:00
|
|
|
compile_prog "-Werror $flag" ""; then
|
2014-03-28 20:19:02 +04:00
|
|
|
QEMU_CFLAGS="$QEMU_CFLAGS $flag"
|
build-sys: clean up flags included in the linker command line
Some of the CFLAGS that are discovered during configure, for example
compiler warnings, are being included on the linker command line because
QEMU_CFLAGS is added to it. Other flags, such as the -m32, appear twice
because they are included in both QEMU_CFLAGS and LDFLAGS. All this
leads to confusion with respect to what goes in which Makefile variables
(and we have plenty).
So, introduce QEMU_LDFLAGS for flags discovered by configure, following
the lead of QEMU_CFLAGS, and stop adding to it:
1) options that are already in CFLAGS, for example "-g"
2) duplicate options
At the same time, options that _are_ needed by both compiler and linker
must now be added to both QEMU_CFLAGS and QEMU_LDFLAGS, which is clearer.
This is mostly -fsanitize options. For now, --extra-cflags has this behavior
(but --extra-cxxflags does not).
Meson will not include CFLAGS on the linker command line, do the same in our
build system as well.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
2019-12-11 17:34:27 +03:00
|
|
|
QEMU_LDFLAGS="$QEMU_LDFLAGS $flag"
|
2014-07-02 12:05:24 +04:00
|
|
|
sp_on=1
|
2014-03-28 20:19:02 +04:00
|
|
|
break
|
|
|
|
fi
|
|
|
|
done
|
2014-07-02 12:05:24 +04:00
|
|
|
if test "$stack_protector" = yes; then
|
|
|
|
if test $sp_on = 0; then
|
|
|
|
error_exit "Stack protector not supported"
|
|
|
|
fi
|
|
|
|
fi
|
2013-02-26 02:31:12 +04:00
|
|
|
fi
|
|
|
|
|
2017-10-20 13:11:32 +03:00
|
|
|
# Disable -Wmissing-braces on older compilers that warn even for
|
|
|
|
# the "universal" C zero initializer {0}.
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
struct {
|
|
|
|
int a[2];
|
|
|
|
} x = {0};
|
|
|
|
EOF
|
|
|
|
if compile_object "-Werror" "" ; then
|
|
|
|
:
|
|
|
|
else
|
|
|
|
QEMU_CFLAGS="$QEMU_CFLAGS -Wno-missing-braces"
|
|
|
|
fi
|
|
|
|
|
2019-07-18 15:04:13 +03:00
|
|
|
# Our module code doesn't support Windows
|
|
|
|
if test "$modules" = "yes" && test "$mingw32" = "yes" ; then
|
|
|
|
error_exit "Modules are not available for Windows"
|
|
|
|
fi
|
|
|
|
|
2020-03-10 17:58:06 +03:00
|
|
|
# module_upgrades is only reasonable if modules are enabled
|
|
|
|
if test "$modules" = "no" && test "$module_upgrades" = "yes" ; then
|
|
|
|
error_exit "Can't enable module-upgrades as Modules are not enabled"
|
|
|
|
fi
|
|
|
|
|
2018-12-03 13:41:38 +03:00
|
|
|
# Static linking is not possible with modules or PIE
|
2011-11-15 22:12:17 +04:00
|
|
|
if test "$static" = "yes" ; then
|
2014-02-25 20:36:55 +04:00
|
|
|
if test "$modules" = "yes" ; then
|
|
|
|
error_exit "static and modules are mutually incompatible"
|
|
|
|
fi
|
2011-11-15 22:12:17 +04:00
|
|
|
fi
|
|
|
|
|
2015-04-29 14:09:02 +03:00
|
|
|
# Unconditional check for compiler __thread support
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
static __thread int tls_var;
|
|
|
|
int main(void) { return tls_var; }
|
|
|
|
EOF
|
|
|
|
|
|
|
|
if ! compile_prog "-Werror" "" ; then
|
|
|
|
error_exit "Your compiler does not support the __thread specifier for " \
|
|
|
|
"Thread-Local Storage (TLS). Please upgrade to a version that does."
|
|
|
|
fi
|
|
|
|
|
2019-12-18 02:54:56 +03:00
|
|
|
cat > $TMPC << EOF
|
2011-11-23 13:24:25 +04:00
|
|
|
|
|
|
|
#ifdef __linux__
|
|
|
|
# define THREAD __thread
|
|
|
|
#else
|
|
|
|
# define THREAD
|
|
|
|
#endif
|
|
|
|
static THREAD int tls_var;
|
|
|
|
int main(void) { return tls_var; }
|
2011-11-15 22:12:17 +04:00
|
|
|
EOF
|
2019-08-15 22:41:51 +03:00
|
|
|
|
2019-12-18 02:54:56 +03:00
|
|
|
# Check we support --no-pie first; we will need this for building ROMs.
|
|
|
|
if compile_prog "-Werror -fno-pie" "-no-pie"; then
|
|
|
|
CFLAGS_NOPIE="-fno-pie"
|
|
|
|
fi
|
|
|
|
|
2019-12-18 04:30:14 +03:00
|
|
|
if test "$static" = "yes"; then
|
2020-04-03 22:11:50 +03:00
|
|
|
if test "$pie" != "no" && compile_prog "-Werror -fPIE -DPIE" "-static-pie"; then
|
2020-09-23 12:26:15 +03:00
|
|
|
CONFIGURE_CFLAGS="-fPIE -DPIE $CONFIGURE_CFLAGS"
|
2019-12-18 04:30:14 +03:00
|
|
|
QEMU_LDFLAGS="-static-pie $QEMU_LDFLAGS"
|
|
|
|
pie="yes"
|
|
|
|
elif test "$pie" = "yes"; then
|
|
|
|
error_exit "-static-pie not available due to missing toolchain support"
|
|
|
|
else
|
|
|
|
QEMU_LDFLAGS="-static $QEMU_LDFLAGS"
|
|
|
|
pie="no"
|
|
|
|
fi
|
|
|
|
elif test "$pie" = "no"; then
|
2020-09-23 12:26:15 +03:00
|
|
|
CONFIGURE_CFLAGS="$CFLAGS_NOPIE $CONFIGURE_CFLAGS"
|
2020-04-03 22:11:50 +03:00
|
|
|
elif compile_prog "-Werror -fPIE -DPIE" "-pie"; then
|
2020-09-23 12:26:15 +03:00
|
|
|
CONFIGURE_CFLAGS="-fPIE -DPIE $CONFIGURE_CFLAGS"
|
|
|
|
CONFIGURE_LDFLAGS="-pie $CONFIGURE_LDFLAGS"
|
2019-12-18 04:15:01 +03:00
|
|
|
pie="yes"
|
|
|
|
elif test "$pie" = "yes"; then
|
|
|
|
error_exit "PIE not available due to missing toolchain support"
|
|
|
|
else
|
|
|
|
echo "Disabling PIE due to missing toolchain support"
|
|
|
|
pie="no"
|
2011-11-15 22:12:17 +04:00
|
|
|
fi
|
|
|
|
|
2019-12-18 03:00:39 +03:00
|
|
|
# Detect support for PT_GNU_RELRO + DT_BIND_NOW.
|
|
|
|
# The combination is known as "full relro", because .got.plt is read-only too.
|
|
|
|
if compile_prog "" "-Wl,-z,relro -Wl,-z,now" ; then
|
|
|
|
QEMU_LDFLAGS="-Wl,-z,relro -Wl,-z,now $QEMU_LDFLAGS"
|
|
|
|
fi
|
|
|
|
|
2013-04-17 18:26:47 +04:00
|
|
|
##########################################
|
|
|
|
# __sync_fetch_and_and requires at least -march=i486. Many toolchains
|
|
|
|
# use i686 as default anyway, but for those that don't, an explicit
|
|
|
|
# specification is necessary
|
|
|
|
|
|
|
|
if test "$cpu" = "i386"; then
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
static int sfaa(int *ptr)
|
|
|
|
{
|
|
|
|
return __sync_fetch_and_and(ptr, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
int val = 42;
|
2013-05-11 23:46:58 +04:00
|
|
|
val = __sync_val_compare_and_swap(&val, 0, 1);
|
2013-04-17 18:26:47 +04:00
|
|
|
sfaa(&val);
|
|
|
|
return val;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if ! compile_prog "" "" ; then
|
|
|
|
QEMU_CFLAGS="-march=i486 $QEMU_CFLAGS"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
#########################################
|
2006-04-26 02:36:06 +04:00
|
|
|
# Solaris specific configure tool chain decisions
|
2013-04-17 18:26:47 +04:00
|
|
|
|
2006-04-26 02:36:06 +04:00
|
|
|
if test "$solaris" = "yes" ; then
|
2010-01-20 13:35:54 +03:00
|
|
|
if has ar; then
|
|
|
|
:
|
|
|
|
else
|
2006-04-26 02:36:06 +04:00
|
|
|
if test -f /usr/ccs/bin/ar ; then
|
2013-04-08 15:11:26 +04:00
|
|
|
error_exit "No path includes ar" \
|
|
|
|
"Add /usr/ccs/bin to your path and rerun configure"
|
2006-04-26 02:36:06 +04:00
|
|
|
fi
|
2013-04-08 15:11:26 +04:00
|
|
|
error_exit "No path includes ar"
|
2006-04-26 02:36:06 +04:00
|
|
|
fi
|
2007-09-17 01:08:06 +04:00
|
|
|
fi
|
2006-04-26 02:36:06 +04:00
|
|
|
|
2012-09-27 00:04:38 +04:00
|
|
|
if test -z "${target_list+xxx}" ; then
|
2020-09-21 11:37:49 +03:00
|
|
|
default_targets=yes
|
2017-07-03 17:58:28 +03:00
|
|
|
for target in $default_target_list; do
|
2020-09-21 11:37:49 +03:00
|
|
|
target_list="$target_list $target"
|
2017-07-03 17:58:28 +03:00
|
|
|
done
|
|
|
|
target_list="${target_list# }"
|
2012-09-14 17:17:03 +04:00
|
|
|
else
|
2020-09-21 11:37:49 +03:00
|
|
|
default_targets=no
|
2016-05-16 16:10:20 +03:00
|
|
|
target_list=$(echo "$target_list" | sed -e 's/,/ /g')
|
2017-07-03 17:58:28 +03:00
|
|
|
for target in $target_list; do
|
|
|
|
# Check that we recognised the target name; this allows a more
|
|
|
|
# friendly error message than if we let it fall through.
|
|
|
|
case " $default_target_list " in
|
|
|
|
*" $target "*)
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
error_exit "Unknown target name '$target'"
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
done
|
2012-09-14 17:17:03 +04:00
|
|
|
fi
|
2013-05-20 19:16:16 +04:00
|
|
|
|
2020-09-21 11:37:49 +03:00
|
|
|
for target in $target_list; do
|
|
|
|
# if a deprecated target is enabled we note it here
|
|
|
|
if echo "$deprecated_targets_list" | grep -q "$target"; then
|
|
|
|
add_to deprecated_features $target
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
2010-05-26 18:08:17 +04:00
|
|
|
# see if system emulation was really requested
|
|
|
|
case " $target_list " in
|
|
|
|
*"-softmmu "*) softmmu=yes
|
|
|
|
;;
|
|
|
|
*) softmmu=no
|
|
|
|
;;
|
|
|
|
esac
|
2005-01-11 02:18:50 +03:00
|
|
|
|
2009-08-12 20:20:25 +04:00
|
|
|
feature_not_found() {
|
|
|
|
feature=$1
|
2014-01-24 05:39:10 +04:00
|
|
|
remedy=$2
|
2009-08-12 20:20:25 +04:00
|
|
|
|
2013-04-08 15:11:26 +04:00
|
|
|
error_exit "User requested feature $feature" \
|
2014-01-24 05:39:10 +04:00
|
|
|
"configure was not able to find it." \
|
|
|
|
"$remedy"
|
2009-08-12 20:20:25 +04:00
|
|
|
}
|
|
|
|
|
2003-03-07 02:23:54 +03:00
|
|
|
# ---
|
|
|
|
# big/little endian test
|
|
|
|
cat > $TMPC << EOF
|
2013-07-01 07:30:18 +04:00
|
|
|
short big_endian[] = { 0x4269, 0x4765, 0x4e64, 0x4961, 0x4e00, 0, };
|
|
|
|
short little_endian[] = { 0x694c, 0x7454, 0x654c, 0x6e45, 0x6944, 0x6e41, 0, };
|
|
|
|
extern int foo(short *, short *);
|
|
|
|
int main(int argc, char *argv[]) {
|
|
|
|
return foo(big_endian, little_endian);
|
2003-03-07 02:23:54 +03:00
|
|
|
}
|
|
|
|
EOF
|
|
|
|
|
2013-07-01 07:30:18 +04:00
|
|
|
if compile_object ; then
|
2018-01-30 16:38:28 +03:00
|
|
|
if strings -a $TMPO | grep -q BiGeNdIaN ; then
|
2013-07-01 07:30:18 +04:00
|
|
|
bigendian="yes"
|
2018-01-30 16:38:28 +03:00
|
|
|
elif strings -a $TMPO | grep -q LiTtLeEnDiAn ; then
|
2013-07-01 07:30:18 +04:00
|
|
|
bigendian="no"
|
|
|
|
else
|
|
|
|
echo big/little test failed
|
2011-11-30 13:57:48 +04:00
|
|
|
fi
|
2013-07-01 07:30:18 +04:00
|
|
|
else
|
|
|
|
echo big/little test failed
|
2003-03-07 02:23:54 +03:00
|
|
|
fi
|
|
|
|
|
2020-02-17 16:33:27 +03:00
|
|
|
##########################################
|
|
|
|
# system tools
|
|
|
|
if test -z "$want_tools"; then
|
|
|
|
if test "$softmmu" = "no"; then
|
|
|
|
want_tools=no
|
|
|
|
else
|
|
|
|
want_tools=yes
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2015-08-14 18:10:52 +03:00
|
|
|
##########################################
|
|
|
|
# cocoa implies not SDL or GTK
|
|
|
|
# (the cocoa UI code currently assumes it is always the active UI
|
|
|
|
# and doesn't interact well with other UI frontend code)
|
2020-09-01 18:28:59 +03:00
|
|
|
if test "$cocoa" = "enabled"; then
|
|
|
|
if test "$sdl" = "enabled"; then
|
2015-08-14 18:10:52 +03:00
|
|
|
error_exit "Cocoa and SDL UIs cannot both be enabled at once"
|
|
|
|
fi
|
|
|
|
if test "$gtk" = "yes"; then
|
|
|
|
error_exit "Cocoa and GTK UIs cannot both be enabled at once"
|
|
|
|
fi
|
|
|
|
gtk=no
|
2020-02-06 16:17:15 +03:00
|
|
|
sdl=disabled
|
2015-08-14 18:10:52 +03:00
|
|
|
fi
|
|
|
|
|
2016-10-11 18:46:23 +03:00
|
|
|
# Some versions of Mac OS X incorrectly define SIZE_MAX
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
int main(int argc, char *argv[]) {
|
|
|
|
return printf("%zu", SIZE_MAX);
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
have_broken_size_max=no
|
|
|
|
if ! compile_object -Werror ; then
|
|
|
|
have_broken_size_max=yes
|
|
|
|
fi
|
|
|
|
|
2014-07-01 16:58:08 +04:00
|
|
|
##########################################
|
|
|
|
# L2TPV3 probe
|
|
|
|
|
|
|
|
cat > $TMPC <<EOF
|
|
|
|
#include <sys/socket.h>
|
2014-08-01 23:20:24 +04:00
|
|
|
#include <linux/ip.h>
|
2014-07-01 16:58:08 +04:00
|
|
|
int main(void) { return sizeof(struct mmsghdr); }
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
l2tpv3=yes
|
|
|
|
else
|
|
|
|
l2tpv3=no
|
|
|
|
fi
|
|
|
|
|
2020-07-13 16:36:09 +03:00
|
|
|
cat > $TMPC <<EOF
|
|
|
|
#include <sys/mman.h>
|
|
|
|
int main(int argc, char *argv[]) {
|
|
|
|
return mlockall(MCL_FUTURE);
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
have_mlockall=yes
|
|
|
|
else
|
|
|
|
have_mlockall=no
|
|
|
|
fi
|
|
|
|
|
2019-02-14 20:35:53 +03:00
|
|
|
#########################################
|
|
|
|
# vhost interdependencies and host support
|
|
|
|
|
|
|
|
# vhost backends
|
2020-11-10 20:11:21 +03:00
|
|
|
if test "$vhost_user" = "yes" && test "$linux" != "yes"; then
|
|
|
|
error_exit "vhost-user is only available on Linux"
|
2019-02-14 20:35:53 +03:00
|
|
|
fi
|
2020-07-01 17:55:37 +03:00
|
|
|
test "$vhost_vdpa" = "" && vhost_vdpa=$linux
|
|
|
|
if test "$vhost_vdpa" = "yes" && test "$linux" != "yes"; then
|
|
|
|
error_exit "vhost-vdpa is only available on Linux"
|
|
|
|
fi
|
2019-02-14 20:35:53 +03:00
|
|
|
test "$vhost_kernel" = "" && vhost_kernel=$linux
|
|
|
|
if test "$vhost_kernel" = "yes" && test "$linux" != "yes"; then
|
|
|
|
error_exit "vhost-kernel is only available on Linux"
|
|
|
|
fi
|
|
|
|
|
|
|
|
# vhost-kernel devices
|
|
|
|
test "$vhost_scsi" = "" && vhost_scsi=$vhost_kernel
|
|
|
|
if test "$vhost_scsi" = "yes" && test "$vhost_kernel" != "yes"; then
|
|
|
|
error_exit "--enable-vhost-scsi requires --enable-vhost-kernel"
|
|
|
|
fi
|
|
|
|
test "$vhost_vsock" = "" && vhost_vsock=$vhost_kernel
|
|
|
|
if test "$vhost_vsock" = "yes" && test "$vhost_kernel" != "yes"; then
|
|
|
|
error_exit "--enable-vhost-vsock requires --enable-vhost-kernel"
|
|
|
|
fi
|
|
|
|
|
|
|
|
# vhost-user backends
|
|
|
|
test "$vhost_net_user" = "" && vhost_net_user=$vhost_user
|
|
|
|
if test "$vhost_net_user" = "yes" && test "$vhost_user" = "no"; then
|
|
|
|
error_exit "--enable-vhost-net-user requires --enable-vhost-user"
|
|
|
|
fi
|
|
|
|
test "$vhost_crypto" = "" && vhost_crypto=$vhost_user
|
|
|
|
if test "$vhost_crypto" = "yes" && test "$vhost_user" = "no"; then
|
|
|
|
error_exit "--enable-vhost-crypto requires --enable-vhost-user"
|
|
|
|
fi
|
2019-09-30 13:51:34 +03:00
|
|
|
test "$vhost_user_fs" = "" && vhost_user_fs=$vhost_user
|
|
|
|
if test "$vhost_user_fs" = "yes" && test "$vhost_user" = "no"; then
|
|
|
|
error_exit "--enable-vhost-user-fs requires --enable-vhost-user"
|
|
|
|
fi
|
2020-07-01 17:55:37 +03:00
|
|
|
#vhost-vdpa backends
|
|
|
|
test "$vhost_net_vdpa" = "" && vhost_net_vdpa=$vhost_vdpa
|
|
|
|
if test "$vhost_net_vdpa" = "yes" && test "$vhost_vdpa" = "no"; then
|
|
|
|
error_exit "--enable-vhost-net-vdpa requires --enable-vhost-vdpa"
|
|
|
|
fi
|
2019-02-14 20:35:53 +03:00
|
|
|
|
2020-09-25 00:00:23 +03:00
|
|
|
# OR the vhost-kernel, vhost-vdpa and vhost-user values for simplicity
|
2019-02-14 20:35:53 +03:00
|
|
|
if test "$vhost_net" = ""; then
|
|
|
|
test "$vhost_net_user" = "yes" && vhost_net=yes
|
2020-09-25 00:00:23 +03:00
|
|
|
test "$vhost_net_vdpa" = "yes" && vhost_net=yes
|
2019-02-14 20:35:53 +03:00
|
|
|
test "$vhost_kernel" = "yes" && vhost_net=yes
|
|
|
|
fi
|
|
|
|
|
2012-12-16 14:29:45 +04:00
|
|
|
##########################################
|
|
|
|
# pkg-config probe
|
|
|
|
|
|
|
|
if ! has "$pkg_config_exe"; then
|
2013-04-08 15:11:26 +04:00
|
|
|
error_exit "pkg-config binary '$pkg_config_exe' not found"
|
2012-12-16 14:29:45 +04:00
|
|
|
fi
|
|
|
|
|
2009-08-12 20:29:49 +04:00
|
|
|
##########################################
|
|
|
|
# NPTL probe
|
|
|
|
|
2013-07-16 21:45:00 +04:00
|
|
|
if test "$linux_user" = "yes"; then
|
2009-08-12 20:29:49 +04:00
|
|
|
cat > $TMPC <<EOF
|
2008-05-29 18:34:11 +04:00
|
|
|
#include <sched.h>
|
2008-06-02 19:45:44 +04:00
|
|
|
#include <linux/futex.h>
|
2011-12-17 12:27:30 +04:00
|
|
|
int main(void) {
|
2008-05-29 18:34:11 +04:00
|
|
|
#if !defined(CLONE_SETTLS) || !defined(FUTEX_WAIT)
|
|
|
|
#error bork
|
|
|
|
#endif
|
2011-12-17 12:27:30 +04:00
|
|
|
return 0;
|
2008-05-29 18:34:11 +04:00
|
|
|
}
|
|
|
|
EOF
|
2013-07-16 21:45:00 +04:00
|
|
|
if ! compile_object ; then
|
2014-01-24 05:39:10 +04:00
|
|
|
feature_not_found "nptl" "Install glibc and linux kernel headers."
|
2009-08-12 20:29:49 +04:00
|
|
|
fi
|
2008-05-29 18:34:11 +04:00
|
|
|
fi
|
|
|
|
|
2009-04-22 19:19:10 +04:00
|
|
|
##########################################
|
|
|
|
# xen probe
|
|
|
|
|
2020-09-18 11:57:25 +03:00
|
|
|
if test "$xen" != "disabled" ; then
|
2017-03-27 10:42:45 +03:00
|
|
|
# Check whether Xen library path is specified via --extra-ldflags to avoid
|
|
|
|
# overriding this setting with pkg-config output. If not, try pkg-config
|
|
|
|
# to obtain all needed flags.
|
|
|
|
|
|
|
|
if ! echo $EXTRA_LDFLAGS | grep tools/libxc > /dev/null && \
|
|
|
|
$pkg_config --exists xencontrol ; then
|
|
|
|
xen_ctrl_version="$(printf '%d%02d%02d' \
|
|
|
|
$($pkg_config --modversion xencontrol | sed 's/\./ /g') )"
|
2020-09-18 11:57:25 +03:00
|
|
|
xen=enabled
|
2020-07-27 17:00:48 +03:00
|
|
|
xen_pc="xencontrol xenstore xenforeignmemory xengnttab"
|
2017-03-27 10:42:45 +03:00
|
|
|
xen_pc="$xen_pc xenevtchn xendevicemodel"
|
2017-09-25 18:01:48 +03:00
|
|
|
if $pkg_config --exists xentoolcore; then
|
|
|
|
xen_pc="$xen_pc xentoolcore"
|
|
|
|
fi
|
2019-08-15 14:15:32 +03:00
|
|
|
xen_cflags="$($pkg_config --cflags $xen_pc)"
|
|
|
|
xen_libs="$($pkg_config --libs $xen_pc)"
|
2017-03-27 10:42:45 +03:00
|
|
|
else
|
2011-02-25 19:20:34 +03:00
|
|
|
|
2020-07-27 17:00:48 +03:00
|
|
|
xen_libs="-lxenstore -lxenctrl"
|
2017-05-11 14:35:42 +03:00
|
|
|
xen_stable_libs="-lxenforeignmemory -lxengnttab -lxenevtchn"
|
2011-12-17 12:27:39 +04:00
|
|
|
|
2017-03-27 10:42:45 +03:00
|
|
|
# First we test whether Xen headers and libraries are available.
|
|
|
|
# If no, we are done and there is no Xen support.
|
|
|
|
# If yes, more tests are run to detect the Xen version.
|
|
|
|
|
|
|
|
# Xen (any)
|
|
|
|
cat > $TMPC <<EOF
|
2009-04-22 19:19:10 +04:00
|
|
|
#include <xenctrl.h>
|
2011-12-17 12:27:39 +04:00
|
|
|
int main(void) {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
2017-03-27 10:42:45 +03:00
|
|
|
if ! compile_prog "" "$xen_libs" ; then
|
|
|
|
# Xen not found
|
2020-09-18 11:57:25 +03:00
|
|
|
if test "$xen" = "enabled" ; then
|
2017-03-27 10:42:45 +03:00
|
|
|
feature_not_found "xen" "Install xen devel"
|
|
|
|
fi
|
2020-09-18 11:57:25 +03:00
|
|
|
xen=disabled
|
2011-12-17 12:27:39 +04:00
|
|
|
|
2017-03-27 10:42:45 +03:00
|
|
|
# Xen unstable
|
|
|
|
elif
|
|
|
|
cat > $TMPC <<EOF &&
|
2017-10-23 12:27:27 +03:00
|
|
|
#undef XC_WANT_COMPAT_DEVICEMODEL_API
|
|
|
|
#define __XEN_TOOLS__
|
|
|
|
#include <xendevicemodel.h>
|
2018-05-15 19:40:53 +03:00
|
|
|
#include <xenforeignmemory.h>
|
2017-10-23 12:27:27 +03:00
|
|
|
int main(void) {
|
|
|
|
xendevicemodel_handle *xd;
|
2018-05-15 19:40:53 +03:00
|
|
|
xenforeignmemory_handle *xfmem;
|
2017-10-23 12:27:27 +03:00
|
|
|
|
|
|
|
xd = xendevicemodel_open(0, 0);
|
|
|
|
xendevicemodel_pin_memory_cacheattr(xd, 0, 0, 0, 0);
|
|
|
|
|
2018-05-15 19:40:53 +03:00
|
|
|
xfmem = xenforeignmemory_open(0, 0);
|
|
|
|
xenforeignmemory_map_resource(xfmem, 0, 0, 0, 0, 0, NULL, 0, 0);
|
|
|
|
|
2017-10-23 12:27:27 +03:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
compile_prog "" "$xen_libs -lxendevicemodel $xen_stable_libs -lxentoolcore"
|
|
|
|
then
|
|
|
|
xen_stable_libs="-lxendevicemodel $xen_stable_libs -lxentoolcore"
|
|
|
|
xen_ctrl_version=41100
|
2020-09-18 11:57:25 +03:00
|
|
|
xen=enabled
|
2017-10-23 12:27:27 +03:00
|
|
|
elif
|
|
|
|
cat > $TMPC <<EOF &&
|
2017-07-11 01:40:02 +03:00
|
|
|
#undef XC_WANT_COMPAT_MAP_FOREIGN_API
|
|
|
|
#include <xenforeignmemory.h>
|
2017-09-25 18:01:48 +03:00
|
|
|
#include <xentoolcore.h>
|
2017-07-11 01:40:02 +03:00
|
|
|
int main(void) {
|
|
|
|
xenforeignmemory_handle *xfmem;
|
|
|
|
|
|
|
|
xfmem = xenforeignmemory_open(0, 0);
|
|
|
|
xenforeignmemory_map2(xfmem, 0, 0, 0, 0, 0, 0, 0);
|
2017-09-25 18:01:48 +03:00
|
|
|
xentoolcore_restrict_all(0);
|
2017-07-11 01:40:02 +03:00
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
2017-09-25 18:01:48 +03:00
|
|
|
compile_prog "" "$xen_libs -lxendevicemodel $xen_stable_libs -lxentoolcore"
|
2017-07-11 01:40:02 +03:00
|
|
|
then
|
2017-09-25 18:01:48 +03:00
|
|
|
xen_stable_libs="-lxendevicemodel $xen_stable_libs -lxentoolcore"
|
2017-07-11 01:40:02 +03:00
|
|
|
xen_ctrl_version=41000
|
2020-09-18 11:57:25 +03:00
|
|
|
xen=enabled
|
2017-07-11 01:40:02 +03:00
|
|
|
elif
|
|
|
|
cat > $TMPC <<EOF &&
|
2017-03-07 13:55:33 +03:00
|
|
|
#undef XC_WANT_COMPAT_DEVICEMODEL_API
|
|
|
|
#define __XEN_TOOLS__
|
|
|
|
#include <xendevicemodel.h>
|
|
|
|
int main(void) {
|
|
|
|
xendevicemodel_handle *xd;
|
|
|
|
|
|
|
|
xd = xendevicemodel_open(0, 0);
|
|
|
|
xendevicemodel_close(xd);
|
2011-12-17 12:27:39 +04:00
|
|
|
|
2017-03-07 13:55:33 +03:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
2017-03-27 10:42:45 +03:00
|
|
|
compile_prog "" "$xen_libs -lxendevicemodel $xen_stable_libs"
|
|
|
|
then
|
|
|
|
xen_stable_libs="-lxendevicemodel $xen_stable_libs"
|
|
|
|
xen_ctrl_version=40900
|
2020-09-18 11:57:25 +03:00
|
|
|
xen=enabled
|
2017-03-27 10:42:45 +03:00
|
|
|
elif
|
|
|
|
cat > $TMPC <<EOF &&
|
2016-09-14 22:10:03 +03:00
|
|
|
/*
|
|
|
|
* If we have stable libs the we don't want the libxc compat
|
|
|
|
* layers, regardless of what CFLAGS we may have been given.
|
|
|
|
*
|
|
|
|
* Also, check if xengnttab_grant_copy_segment_t is defined and
|
|
|
|
* grant copy operation is implemented.
|
|
|
|
*/
|
|
|
|
#undef XC_WANT_COMPAT_EVTCHN_API
|
|
|
|
#undef XC_WANT_COMPAT_GNTTAB_API
|
|
|
|
#undef XC_WANT_COMPAT_MAP_FOREIGN_API
|
|
|
|
#include <xenctrl.h>
|
|
|
|
#include <xenstore.h>
|
|
|
|
#include <xenevtchn.h>
|
|
|
|
#include <xengnttab.h>
|
|
|
|
#include <xenforeignmemory.h>
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <xen/hvm/hvm_info_table.h>
|
|
|
|
#if !defined(HVM_MAX_VCPUS)
|
|
|
|
# error HVM_MAX_VCPUS not defined
|
|
|
|
#endif
|
|
|
|
int main(void) {
|
|
|
|
xc_interface *xc = NULL;
|
|
|
|
xenforeignmemory_handle *xfmem;
|
|
|
|
xenevtchn_handle *xe;
|
|
|
|
xengnttab_handle *xg;
|
|
|
|
xengnttab_grant_copy_segment_t* seg = NULL;
|
|
|
|
|
|
|
|
xs_daemon_open();
|
|
|
|
|
|
|
|
xc = xc_interface_open(0, 0, 0);
|
|
|
|
xc_hvm_set_mem_type(0, 0, HVMMEM_ram_ro, 0, 0);
|
|
|
|
xc_domain_add_to_physmap(0, 0, XENMAPSPACE_gmfn, 0, 0);
|
|
|
|
xc_hvm_inject_msi(xc, 0, 0xf0000000, 0x00000000);
|
|
|
|
xc_hvm_create_ioreq_server(xc, 0, HVM_IOREQSRV_BUFIOREQ_ATOMIC, NULL);
|
|
|
|
|
|
|
|
xfmem = xenforeignmemory_open(0, 0);
|
|
|
|
xenforeignmemory_map(xfmem, 0, 0, 0, 0, 0);
|
|
|
|
|
|
|
|
xe = xenevtchn_open(0, 0);
|
|
|
|
xenevtchn_fd(xe);
|
|
|
|
|
|
|
|
xg = xengnttab_open(0, 0);
|
|
|
|
xengnttab_grant_copy(xg, 0, seg);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
2017-03-27 10:42:45 +03:00
|
|
|
compile_prog "" "$xen_libs $xen_stable_libs"
|
|
|
|
then
|
|
|
|
xen_ctrl_version=40800
|
2020-09-18 11:57:25 +03:00
|
|
|
xen=enabled
|
2017-03-27 10:42:45 +03:00
|
|
|
elif
|
|
|
|
cat > $TMPC <<EOF &&
|
2016-01-15 16:23:42 +03:00
|
|
|
/*
|
|
|
|
* If we have stable libs the we don't want the libxc compat
|
|
|
|
* layers, regardless of what CFLAGS we may have been given.
|
|
|
|
*/
|
|
|
|
#undef XC_WANT_COMPAT_EVTCHN_API
|
|
|
|
#undef XC_WANT_COMPAT_GNTTAB_API
|
|
|
|
#undef XC_WANT_COMPAT_MAP_FOREIGN_API
|
|
|
|
#include <xenctrl.h>
|
|
|
|
#include <xenstore.h>
|
|
|
|
#include <xenevtchn.h>
|
|
|
|
#include <xengnttab.h>
|
|
|
|
#include <xenforeignmemory.h>
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <xen/hvm/hvm_info_table.h>
|
|
|
|
#if !defined(HVM_MAX_VCPUS)
|
|
|
|
# error HVM_MAX_VCPUS not defined
|
|
|
|
#endif
|
|
|
|
int main(void) {
|
|
|
|
xc_interface *xc = NULL;
|
|
|
|
xenforeignmemory_handle *xfmem;
|
|
|
|
xenevtchn_handle *xe;
|
|
|
|
xengnttab_handle *xg;
|
|
|
|
|
|
|
|
xs_daemon_open();
|
|
|
|
|
|
|
|
xc = xc_interface_open(0, 0, 0);
|
|
|
|
xc_hvm_set_mem_type(0, 0, HVMMEM_ram_ro, 0, 0);
|
|
|
|
xc_domain_add_to_physmap(0, 0, XENMAPSPACE_gmfn, 0, 0);
|
|
|
|
xc_hvm_inject_msi(xc, 0, 0xf0000000, 0x00000000);
|
|
|
|
xc_hvm_create_ioreq_server(xc, 0, HVM_IOREQSRV_BUFIOREQ_ATOMIC, NULL);
|
|
|
|
|
|
|
|
xfmem = xenforeignmemory_open(0, 0);
|
|
|
|
xenforeignmemory_map(xfmem, 0, 0, 0, 0, 0);
|
|
|
|
|
|
|
|
xe = xenevtchn_open(0, 0);
|
|
|
|
xenevtchn_fd(xe);
|
|
|
|
|
|
|
|
xg = xengnttab_open(0, 0);
|
|
|
|
xengnttab_map_grant_ref(xg, 0, 0, 0);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
2017-03-27 10:42:45 +03:00
|
|
|
compile_prog "" "$xen_libs $xen_stable_libs"
|
|
|
|
then
|
|
|
|
xen_ctrl_version=40701
|
2020-09-18 11:57:25 +03:00
|
|
|
xen=enabled
|
2017-03-27 10:42:45 +03:00
|
|
|
|
|
|
|
# Xen 4.6
|
|
|
|
elif
|
|
|
|
cat > $TMPC <<EOF &&
|
2015-11-13 20:38:06 +03:00
|
|
|
#include <xenctrl.h>
|
2012-06-21 15:44:35 +04:00
|
|
|
#include <xenstore.h>
|
2011-02-25 19:20:34 +03:00
|
|
|
#include <stdint.h>
|
|
|
|
#include <xen/hvm/hvm_info_table.h>
|
|
|
|
#if !defined(HVM_MAX_VCPUS)
|
|
|
|
# error HVM_MAX_VCPUS not defined
|
|
|
|
#endif
|
2015-07-24 12:38:28 +03:00
|
|
|
int main(void) {
|
|
|
|
xc_interface *xc;
|
|
|
|
xs_daemon_open();
|
|
|
|
xc = xc_interface_open(0, 0, 0);
|
|
|
|
xc_hvm_set_mem_type(0, 0, HVMMEM_ram_ro, 0, 0);
|
|
|
|
xc_gnttab_open(NULL, 0);
|
|
|
|
xc_domain_add_to_physmap(0, 0, XENMAPSPACE_gmfn, 0, 0);
|
|
|
|
xc_hvm_inject_msi(xc, 0, 0xf0000000, 0x00000000);
|
|
|
|
xc_hvm_create_ioreq_server(xc, 0, HVM_IOREQSRV_BUFIOREQ_ATOMIC, NULL);
|
2015-06-29 19:51:05 +03:00
|
|
|
xc_reserved_device_memory_map(xc, 0, 0, 0, 0, NULL, 0);
|
2015-07-24 12:38:28 +03:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
2017-03-27 10:42:45 +03:00
|
|
|
compile_prog "" "$xen_libs"
|
|
|
|
then
|
|
|
|
xen_ctrl_version=40600
|
2020-09-18 11:57:25 +03:00
|
|
|
xen=enabled
|
2017-03-27 10:42:45 +03:00
|
|
|
|
|
|
|
# Xen 4.5
|
|
|
|
elif
|
|
|
|
cat > $TMPC <<EOF &&
|
2015-07-24 12:38:28 +03:00
|
|
|
#include <xenctrl.h>
|
|
|
|
#include <xenstore.h>
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <xen/hvm/hvm_info_table.h>
|
|
|
|
#if !defined(HVM_MAX_VCPUS)
|
|
|
|
# error HVM_MAX_VCPUS not defined
|
|
|
|
#endif
|
2015-01-20 14:06:19 +03:00
|
|
|
int main(void) {
|
|
|
|
xc_interface *xc;
|
|
|
|
xs_daemon_open();
|
|
|
|
xc = xc_interface_open(0, 0, 0);
|
|
|
|
xc_hvm_set_mem_type(0, 0, HVMMEM_ram_ro, 0, 0);
|
|
|
|
xc_gnttab_open(NULL, 0);
|
|
|
|
xc_domain_add_to_physmap(0, 0, XENMAPSPACE_gmfn, 0, 0);
|
|
|
|
xc_hvm_inject_msi(xc, 0, 0xf0000000, 0x00000000);
|
|
|
|
xc_hvm_create_ioreq_server(xc, 0, 0, NULL);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
2017-03-27 10:42:45 +03:00
|
|
|
compile_prog "" "$xen_libs"
|
|
|
|
then
|
|
|
|
xen_ctrl_version=40500
|
2020-09-18 11:57:25 +03:00
|
|
|
xen=enabled
|
2015-01-20 14:06:19 +03:00
|
|
|
|
2017-03-27 10:42:45 +03:00
|
|
|
elif
|
|
|
|
cat > $TMPC <<EOF &&
|
2015-01-20 14:06:19 +03:00
|
|
|
#include <xenctrl.h>
|
|
|
|
#include <xenstore.h>
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <xen/hvm/hvm_info_table.h>
|
|
|
|
#if !defined(HVM_MAX_VCPUS)
|
|
|
|
# error HVM_MAX_VCPUS not defined
|
|
|
|
#endif
|
2012-04-17 21:04:18 +04:00
|
|
|
int main(void) {
|
|
|
|
xc_interface *xc;
|
|
|
|
xs_daemon_open();
|
|
|
|
xc = xc_interface_open(0, 0, 0);
|
|
|
|
xc_hvm_set_mem_type(0, 0, HVMMEM_ram_ro, 0, 0);
|
|
|
|
xc_gnttab_open(NULL, 0);
|
|
|
|
xc_domain_add_to_physmap(0, 0, XENMAPSPACE_gmfn, 0, 0);
|
|
|
|
xc_hvm_inject_msi(xc, 0, 0xf0000000, 0x00000000);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
2017-03-27 10:42:45 +03:00
|
|
|
compile_prog "" "$xen_libs"
|
|
|
|
then
|
|
|
|
xen_ctrl_version=40200
|
2020-09-18 11:57:25 +03:00
|
|
|
xen=enabled
|
2012-04-17 21:04:18 +04:00
|
|
|
|
2017-03-27 10:42:45 +03:00
|
|
|
else
|
2020-09-18 11:57:25 +03:00
|
|
|
if test "$xen" = "enabled" ; then
|
2017-03-27 10:42:45 +03:00
|
|
|
feature_not_found "xen (unsupported version)" \
|
|
|
|
"Install a supported xen (xen 4.2 or newer)"
|
|
|
|
fi
|
2020-09-18 11:57:25 +03:00
|
|
|
xen=disabled
|
2009-08-12 20:29:55 +04:00
|
|
|
fi
|
2011-02-25 19:20:34 +03:00
|
|
|
|
2020-09-18 11:57:25 +03:00
|
|
|
if test "$xen" = enabled; then
|
2017-03-27 10:42:45 +03:00
|
|
|
if test $xen_ctrl_version -ge 40701 ; then
|
2019-08-15 14:15:32 +03:00
|
|
|
xen_libs="$xen_libs $xen_stable_libs "
|
2017-03-27 10:42:45 +03:00
|
|
|
fi
|
2016-01-15 16:23:42 +03:00
|
|
|
fi
|
2011-02-25 19:20:34 +03:00
|
|
|
fi
|
2009-04-22 19:19:10 +04:00
|
|
|
fi
|
|
|
|
|
2015-01-09 22:08:49 +03:00
|
|
|
##########################################
|
|
|
|
# X11 probe
|
|
|
|
if $pkg_config --exists "x11"; then
|
2018-03-01 13:05:42 +03:00
|
|
|
have_x11=yes
|
2016-05-16 16:10:20 +03:00
|
|
|
x11_cflags=$($pkg_config --cflags x11)
|
|
|
|
x11_libs=$($pkg_config --libs x11)
|
2015-01-09 22:08:49 +03:00
|
|
|
fi
|
|
|
|
|
2013-02-20 17:43:20 +04:00
|
|
|
##########################################
|
|
|
|
# GTK probe
|
|
|
|
|
|
|
|
if test "$gtk" != "no"; then
|
2018-08-22 16:15:52 +03:00
|
|
|
gtkpackage="gtk+-3.0"
|
|
|
|
gtkx11package="gtk+-x11-3.0"
|
2020-05-16 10:20:14 +03:00
|
|
|
gtkversion="3.22.0"
|
2014-02-19 10:04:34 +04:00
|
|
|
if $pkg_config --exists "$gtkpackage >= $gtkversion"; then
|
2016-05-16 16:10:20 +03:00
|
|
|
gtk_cflags=$($pkg_config --cflags $gtkpackage)
|
|
|
|
gtk_libs=$($pkg_config --libs $gtkpackage)
|
|
|
|
gtk_version=$($pkg_config --modversion $gtkpackage)
|
2014-05-29 00:33:06 +04:00
|
|
|
if $pkg_config --exists "$gtkx11package >= $gtkversion"; then
|
2018-03-01 13:05:42 +03:00
|
|
|
need_x11=yes
|
2015-01-09 22:08:49 +03:00
|
|
|
gtk_cflags="$gtk_cflags $x11_cflags"
|
|
|
|
gtk_libs="$gtk_libs $x11_libs"
|
2014-05-29 00:33:06 +04:00
|
|
|
fi
|
2014-02-19 10:04:34 +04:00
|
|
|
gtk="yes"
|
|
|
|
elif test "$gtk" = "yes"; then
|
2017-06-06 13:53:36 +03:00
|
|
|
feature_not_found "gtk" "Install gtk3-devel"
|
2014-02-19 10:04:34 +04:00
|
|
|
else
|
|
|
|
gtk="no"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2015-07-01 20:10:29 +03:00
|
|
|
|
|
|
|
##########################################
|
|
|
|
# GNUTLS probe
|
|
|
|
|
|
|
|
if test "$gnutls" != "no"; then
|
2019-05-10 04:24:35 +03:00
|
|
|
pass="no"
|
2018-07-18 13:55:05 +03:00
|
|
|
if $pkg_config --exists "gnutls >= 3.1.18"; then
|
2016-05-16 16:10:20 +03:00
|
|
|
gnutls_cflags=$($pkg_config --cflags gnutls)
|
|
|
|
gnutls_libs=$($pkg_config --libs gnutls)
|
2019-05-10 04:24:35 +03:00
|
|
|
# Packaging for the static libraries is not always correct.
|
|
|
|
# At least ubuntu 18.04 ships only shared libraries.
|
|
|
|
write_c_skeleton
|
|
|
|
if compile_prog "" "$gnutls_libs" ; then
|
|
|
|
pass="yes"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
if test "$pass" = "no" && test "$gnutls" = "yes"; then
|
2018-07-18 13:55:05 +03:00
|
|
|
feature_not_found "gnutls" "Install gnutls devel >= 3.1.18"
|
2015-07-01 20:10:29 +03:00
|
|
|
else
|
2019-05-10 04:24:35 +03:00
|
|
|
gnutls="$pass"
|
2015-07-01 20:10:29 +03:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2015-10-16 18:36:53 +03:00
|
|
|
|
|
|
|
# If user didn't give a --disable/enable-gcrypt flag,
|
|
|
|
# then mark as disabled if user requested nettle
|
2018-07-18 13:55:05 +03:00
|
|
|
# explicitly
|
2015-10-16 18:36:53 +03:00
|
|
|
if test -z "$gcrypt"
|
|
|
|
then
|
2018-07-18 13:55:05 +03:00
|
|
|
if test "$nettle" = "yes"
|
2015-10-16 18:36:53 +03:00
|
|
|
then
|
|
|
|
gcrypt="no"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
# If user didn't give a --disable/enable-nettle flag,
|
|
|
|
# then mark as disabled if user requested gcrypt
|
2018-07-18 13:55:05 +03:00
|
|
|
# explicitly
|
2015-10-16 18:36:53 +03:00
|
|
|
if test -z "$nettle"
|
|
|
|
then
|
2018-07-18 13:55:05 +03:00
|
|
|
if test "$gcrypt" = "yes"
|
2015-10-16 18:36:53 +03:00
|
|
|
then
|
|
|
|
nettle="no"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2018-07-18 13:55:05 +03:00
|
|
|
has_libgcrypt() {
|
2015-10-16 18:36:53 +03:00
|
|
|
if ! has "libgcrypt-config"
|
|
|
|
then
|
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
if test -n "$cross_prefix"
|
|
|
|
then
|
2016-05-16 16:10:20 +03:00
|
|
|
host=$(libgcrypt-config --host)
|
2015-10-16 18:36:53 +03:00
|
|
|
if test "$host-" != $cross_prefix
|
|
|
|
then
|
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2018-07-18 13:55:05 +03:00
|
|
|
maj=`libgcrypt-config --version | awk -F . '{print $1}'`
|
|
|
|
min=`libgcrypt-config --version | awk -F . '{print $2}'`
|
|
|
|
|
|
|
|
if test $maj != 1 || test $min -lt 5
|
|
|
|
then
|
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
|
2015-10-16 18:36:53 +03:00
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
2018-07-18 13:55:05 +03:00
|
|
|
|
|
|
|
if test "$nettle" != "no"; then
|
2019-05-10 04:24:35 +03:00
|
|
|
pass="no"
|
2018-07-18 13:55:05 +03:00
|
|
|
if $pkg_config --exists "nettle >= 2.7.1"; then
|
2018-07-18 13:55:05 +03:00
|
|
|
nettle_cflags=$($pkg_config --cflags nettle)
|
|
|
|
nettle_libs=$($pkg_config --libs nettle)
|
|
|
|
nettle_version=$($pkg_config --modversion nettle)
|
2019-05-10 04:24:35 +03:00
|
|
|
# Link test to make sure the given libraries work (e.g for static).
|
|
|
|
write_c_skeleton
|
|
|
|
if compile_prog "" "$nettle_libs" ; then
|
|
|
|
if test -z "$gcrypt"; then
|
|
|
|
gcrypt="no"
|
|
|
|
fi
|
|
|
|
pass="yes"
|
2018-07-18 13:55:05 +03:00
|
|
|
fi
|
2019-05-10 04:24:35 +03:00
|
|
|
fi
|
2019-10-14 19:28:27 +03:00
|
|
|
if test "$pass" = "yes"
|
|
|
|
then
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <nettle/xts.h>
|
|
|
|
int main(void) {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "$nettle_cflags" "$nettle_libs" ; then
|
|
|
|
nettle_xts=yes
|
|
|
|
qemu_private_xts=no
|
|
|
|
fi
|
|
|
|
fi
|
2019-05-10 04:24:35 +03:00
|
|
|
if test "$pass" = "no" && test "$nettle" = "yes"; then
|
|
|
|
feature_not_found "nettle" "Install nettle devel >= 2.7.1"
|
2018-07-18 13:55:05 +03:00
|
|
|
else
|
2019-05-10 04:24:35 +03:00
|
|
|
nettle="$pass"
|
2018-07-18 13:55:05 +03:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2015-10-16 18:36:53 +03:00
|
|
|
if test "$gcrypt" != "no"; then
|
2019-05-10 04:24:35 +03:00
|
|
|
pass="no"
|
2018-07-18 13:55:05 +03:00
|
|
|
if has_libgcrypt; then
|
2016-05-16 16:10:20 +03:00
|
|
|
gcrypt_cflags=$(libgcrypt-config --cflags)
|
|
|
|
gcrypt_libs=$(libgcrypt-config --libs)
|
2019-05-10 04:24:35 +03:00
|
|
|
# Debian has removed -lgpg-error from libgcrypt-config
|
2015-10-16 18:36:53 +03:00
|
|
|
# as it "spreads unnecessary dependencies" which in
|
|
|
|
# turn breaks static builds...
|
|
|
|
if test "$static" = "yes"
|
|
|
|
then
|
|
|
|
gcrypt_libs="$gcrypt_libs -lgpg-error"
|
|
|
|
fi
|
2016-12-13 13:42:55 +03:00
|
|
|
|
2019-05-10 04:24:35 +03:00
|
|
|
# Link test to make sure the given libraries work (e.g for static).
|
|
|
|
write_c_skeleton
|
|
|
|
if compile_prog "" "$gcrypt_libs" ; then
|
|
|
|
pass="yes"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
if test "$pass" = "yes"; then
|
|
|
|
gcrypt="yes"
|
2016-12-13 13:42:55 +03:00
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <gcrypt.h>
|
|
|
|
int main(void) {
|
|
|
|
gcry_mac_hd_t handle;
|
|
|
|
gcry_mac_open(&handle, GCRY_MAC_HMAC_MD5,
|
|
|
|
GCRY_MAC_FLAG_SECURE, NULL);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "$gcrypt_cflags" "$gcrypt_libs" ; then
|
|
|
|
gcrypt_hmac=yes
|
|
|
|
fi
|
2019-10-14 19:28:27 +03:00
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <gcrypt.h>
|
|
|
|
int main(void) {
|
|
|
|
gcry_cipher_hd_t handle;
|
|
|
|
gcry_cipher_open(&handle, GCRY_CIPHER_AES, GCRY_CIPHER_MODE_XTS, 0);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "$gcrypt_cflags" "$gcrypt_libs" ; then
|
|
|
|
gcrypt_xts=yes
|
|
|
|
qemu_private_xts=no
|
|
|
|
fi
|
2019-05-10 04:24:35 +03:00
|
|
|
elif test "$gcrypt" = "yes"; then
|
|
|
|
feature_not_found "gcrypt" "Install gcrypt devel >= 1.5.0"
|
2015-07-01 20:10:33 +03:00
|
|
|
else
|
2019-05-10 04:24:35 +03:00
|
|
|
gcrypt="no"
|
2015-07-01 20:10:33 +03:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2015-07-01 20:10:29 +03:00
|
|
|
|
2015-10-16 18:36:53 +03:00
|
|
|
if test "$gcrypt" = "yes" && test "$nettle" = "yes"
|
|
|
|
then
|
|
|
|
error_exit "Only one of gcrypt & nettle can be enabled"
|
|
|
|
fi
|
|
|
|
|
2015-04-13 16:01:39 +03:00
|
|
|
##########################################
|
|
|
|
# libtasn1 - only for the TLS creds/session test suite
|
|
|
|
|
|
|
|
tasn1=yes
|
2015-09-21 19:25:34 +03:00
|
|
|
tasn1_cflags=""
|
|
|
|
tasn1_libs=""
|
2015-04-13 16:01:39 +03:00
|
|
|
if $pkg_config --exists "libtasn1"; then
|
2016-05-16 16:10:20 +03:00
|
|
|
tasn1_cflags=$($pkg_config --cflags libtasn1)
|
|
|
|
tasn1_libs=$($pkg_config --libs libtasn1)
|
2015-04-13 16:01:39 +03:00
|
|
|
else
|
|
|
|
tasn1=no
|
|
|
|
fi
|
|
|
|
|
2015-07-01 20:10:34 +03:00
|
|
|
|
authz: add QAuthZPAM object type for authorizing using PAM
Add an authorization backend that talks to PAM to check whether the user
identity is allowed. This only uses the PAM account validation facility,
which is essentially just a check to see if the provided username is permitted
access. It doesn't use the authentication or session parts of PAM, since
that's dealt with by the relevant part of QEMU (eg VNC server).
Consider starting QEMU with a VNC server and telling it to use TLS with
x509 client certificates and configuring it to use an PAM to validate
the x509 distinguished name. In this example we're telling it to use PAM
for the QAuthZ impl with a service name of "qemu-vnc"
$ qemu-system-x86_64 \
-object tls-creds-x509,id=tls0,dir=/home/berrange/security/qemutls,\
endpoint=server,verify-peer=yes \
-object authz-pam,id=authz0,service=qemu-vnc \
-vnc :1,tls-creds=tls0,tls-authz=authz0
This requires an /etc/pam/qemu-vnc file to be created with the auth
rules. A very simple file based whitelist can be setup using
$ cat > /etc/pam/qemu-vnc <<EOF
account requisite pam_listfile.so item=user sense=allow file=/etc/qemu/vnc.allow
EOF
The /etc/qemu/vnc.allow file simply contains one username per line. Any
username not in the file is denied. The usernames in this example are
the x509 distinguished name from the client's x509 cert.
$ cat > /etc/qemu/vnc.allow <<EOF
CN=laptop.berrange.com,O=Berrange Home,L=London,ST=London,C=GB
EOF
More interesting would be to configure PAM to use an LDAP backend, so
that the QEMU authorization check data can be centralized instead of
requiring each compute host to have file maintained.
The main limitation with this PAM module is that the rules apply to all
QEMU instances on the host. Setting up different rules per VM, would
require creating a separate PAM service name & config file for every
guest. An alternative approach for the future might be to not pass in
the plain username to PAM, but instead combine the VM name or UUID with
the username. This requires further consideration though.
Tested-by: Philippe Mathieu-Daudé <philmd@redhat.com>
Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com>
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
2016-07-27 16:13:56 +03:00
|
|
|
##########################################
|
|
|
|
# PAM probe
|
|
|
|
|
|
|
|
if test "$auth_pam" != "no"; then
|
|
|
|
cat > $TMPC <<EOF
|
|
|
|
#include <security/pam_appl.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
int main(void) {
|
|
|
|
const char *service_name = "qemu";
|
|
|
|
const char *user = "frank";
|
2019-04-04 12:17:25 +03:00
|
|
|
const struct pam_conv pam_conv = { 0 };
|
authz: add QAuthZPAM object type for authorizing using PAM
Add an authorization backend that talks to PAM to check whether the user
identity is allowed. This only uses the PAM account validation facility,
which is essentially just a check to see if the provided username is permitted
access. It doesn't use the authentication or session parts of PAM, since
that's dealt with by the relevant part of QEMU (eg VNC server).
Consider starting QEMU with a VNC server and telling it to use TLS with
x509 client certificates and configuring it to use an PAM to validate
the x509 distinguished name. In this example we're telling it to use PAM
for the QAuthZ impl with a service name of "qemu-vnc"
$ qemu-system-x86_64 \
-object tls-creds-x509,id=tls0,dir=/home/berrange/security/qemutls,\
endpoint=server,verify-peer=yes \
-object authz-pam,id=authz0,service=qemu-vnc \
-vnc :1,tls-creds=tls0,tls-authz=authz0
This requires an /etc/pam/qemu-vnc file to be created with the auth
rules. A very simple file based whitelist can be setup using
$ cat > /etc/pam/qemu-vnc <<EOF
account requisite pam_listfile.so item=user sense=allow file=/etc/qemu/vnc.allow
EOF
The /etc/qemu/vnc.allow file simply contains one username per line. Any
username not in the file is denied. The usernames in this example are
the x509 distinguished name from the client's x509 cert.
$ cat > /etc/qemu/vnc.allow <<EOF
CN=laptop.berrange.com,O=Berrange Home,L=London,ST=London,C=GB
EOF
More interesting would be to configure PAM to use an LDAP backend, so
that the QEMU authorization check data can be centralized instead of
requiring each compute host to have file maintained.
The main limitation with this PAM module is that the rules apply to all
QEMU instances on the host. Setting up different rules per VM, would
require creating a separate PAM service name & config file for every
guest. An alternative approach for the future might be to not pass in
the plain username to PAM, but instead combine the VM name or UUID with
the username. This requires further consideration though.
Tested-by: Philippe Mathieu-Daudé <philmd@redhat.com>
Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com>
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
2016-07-27 16:13:56 +03:00
|
|
|
pam_handle_t *pamh = NULL;
|
2019-04-04 12:17:25 +03:00
|
|
|
pam_start(service_name, user, &pam_conv, &pamh);
|
authz: add QAuthZPAM object type for authorizing using PAM
Add an authorization backend that talks to PAM to check whether the user
identity is allowed. This only uses the PAM account validation facility,
which is essentially just a check to see if the provided username is permitted
access. It doesn't use the authentication or session parts of PAM, since
that's dealt with by the relevant part of QEMU (eg VNC server).
Consider starting QEMU with a VNC server and telling it to use TLS with
x509 client certificates and configuring it to use an PAM to validate
the x509 distinguished name. In this example we're telling it to use PAM
for the QAuthZ impl with a service name of "qemu-vnc"
$ qemu-system-x86_64 \
-object tls-creds-x509,id=tls0,dir=/home/berrange/security/qemutls,\
endpoint=server,verify-peer=yes \
-object authz-pam,id=authz0,service=qemu-vnc \
-vnc :1,tls-creds=tls0,tls-authz=authz0
This requires an /etc/pam/qemu-vnc file to be created with the auth
rules. A very simple file based whitelist can be setup using
$ cat > /etc/pam/qemu-vnc <<EOF
account requisite pam_listfile.so item=user sense=allow file=/etc/qemu/vnc.allow
EOF
The /etc/qemu/vnc.allow file simply contains one username per line. Any
username not in the file is denied. The usernames in this example are
the x509 distinguished name from the client's x509 cert.
$ cat > /etc/qemu/vnc.allow <<EOF
CN=laptop.berrange.com,O=Berrange Home,L=London,ST=London,C=GB
EOF
More interesting would be to configure PAM to use an LDAP backend, so
that the QEMU authorization check data can be centralized instead of
requiring each compute host to have file maintained.
The main limitation with this PAM module is that the rules apply to all
QEMU instances on the host. Setting up different rules per VM, would
require creating a separate PAM service name & config file for every
guest. An alternative approach for the future might be to not pass in
the plain username to PAM, but instead combine the VM name or UUID with
the username. This requires further consideration though.
Tested-by: Philippe Mathieu-Daudé <philmd@redhat.com>
Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com>
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
2016-07-27 16:13:56 +03:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "-lpam" ; then
|
|
|
|
auth_pam=yes
|
|
|
|
else
|
|
|
|
if test "$auth_pam" = "yes"; then
|
|
|
|
feature_not_found "PAM" "Install PAM development package"
|
|
|
|
else
|
|
|
|
auth_pam=no
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2014-02-19 10:04:34 +04:00
|
|
|
##########################################
|
|
|
|
# VTE probe
|
|
|
|
|
|
|
|
if test "$vte" != "no"; then
|
2018-08-22 16:15:52 +03:00
|
|
|
vteminversion="0.32.0"
|
|
|
|
if $pkg_config --exists "vte-2.91"; then
|
|
|
|
vtepackage="vte-2.91"
|
2013-02-25 19:20:44 +04:00
|
|
|
else
|
2018-08-22 16:15:52 +03:00
|
|
|
vtepackage="vte-2.90"
|
2013-02-25 19:20:44 +04:00
|
|
|
fi
|
2016-05-06 21:03:12 +03:00
|
|
|
if $pkg_config --exists "$vtepackage >= $vteminversion"; then
|
2016-05-16 16:10:20 +03:00
|
|
|
vte_cflags=$($pkg_config --cflags $vtepackage)
|
|
|
|
vte_libs=$($pkg_config --libs $vtepackage)
|
|
|
|
vteversion=$($pkg_config --modversion $vtepackage)
|
2014-02-19 10:04:34 +04:00
|
|
|
vte="yes"
|
|
|
|
elif test "$vte" = "yes"; then
|
2018-08-22 16:15:52 +03:00
|
|
|
feature_not_found "vte" "Install libvte-2.90/2.91 devel"
|
2013-07-18 19:42:01 +04:00
|
|
|
else
|
2014-02-19 10:04:34 +04:00
|
|
|
vte="no"
|
2013-02-20 17:43:20 +04:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2013-07-22 18:01:54 +04:00
|
|
|
##########################################
|
|
|
|
# RDMA needs OpenFabrics libraries
|
|
|
|
if test "$rdma" != "no" ; then
|
|
|
|
cat > $TMPC <<EOF
|
|
|
|
#include <rdma/rdma_cma.h>
|
|
|
|
int main(void) { return 0; }
|
|
|
|
EOF
|
2018-02-09 16:23:18 +03:00
|
|
|
rdma_libs="-lrdmacm -libverbs -libumad"
|
2013-07-22 18:01:54 +04:00
|
|
|
if compile_prog "" "$rdma_libs" ; then
|
|
|
|
rdma="yes"
|
|
|
|
else
|
|
|
|
if test "$rdma" = "yes" ; then
|
|
|
|
error_exit \
|
2018-02-09 16:23:18 +03:00
|
|
|
" OpenFabrics librdmacm/libibverbs/libibumad not present." \
|
2013-07-22 18:01:54 +04:00
|
|
|
" Your options:" \
|
2018-02-09 16:23:18 +03:00
|
|
|
" (1) Fast: Install infiniband packages (devel) from your distro." \
|
2013-07-22 18:01:54 +04:00
|
|
|
" (2) Cleanest: Install libraries from www.openfabrics.org" \
|
|
|
|
" (3) Also: Install softiwarp if you don't have RDMA hardware"
|
|
|
|
fi
|
|
|
|
rdma="no"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2018-08-16 18:16:37 +03:00
|
|
|
##########################################
|
|
|
|
# PVRDMA detection
|
|
|
|
|
|
|
|
cat > $TMPC <<EOF &&
|
|
|
|
#include <sys/mman.h>
|
|
|
|
|
|
|
|
int
|
|
|
|
main(void)
|
|
|
|
{
|
|
|
|
char buf = 0;
|
|
|
|
void *addr = &buf;
|
|
|
|
addr = mremap(addr, 0, 1, MREMAP_MAYMOVE | MREMAP_FIXED);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
|
|
|
|
if test "$rdma" = "yes" ; then
|
|
|
|
case "$pvrdma" in
|
|
|
|
"")
|
|
|
|
if compile_prog "" ""; then
|
|
|
|
pvrdma="yes"
|
|
|
|
else
|
|
|
|
pvrdma="no"
|
|
|
|
fi
|
|
|
|
;;
|
|
|
|
"yes")
|
|
|
|
if ! compile_prog "" ""; then
|
|
|
|
error_exit "PVRDMA is not supported since mremap is not implemented"
|
|
|
|
fi
|
|
|
|
pvrdma="yes"
|
|
|
|
;;
|
|
|
|
"no")
|
|
|
|
pvrdma="no"
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
else
|
|
|
|
if test "$pvrdma" = "yes" ; then
|
|
|
|
error_exit "PVRDMA requires rdma suppport"
|
|
|
|
fi
|
|
|
|
pvrdma="no"
|
|
|
|
fi
|
2014-02-22 01:21:15 +04:00
|
|
|
|
2019-08-18 16:21:06 +03:00
|
|
|
# Let's see if enhanced reg_mr is supported
|
|
|
|
if test "$pvrdma" = "yes" ; then
|
|
|
|
|
|
|
|
cat > $TMPC <<EOF &&
|
|
|
|
#include <infiniband/verbs.h>
|
|
|
|
|
|
|
|
int
|
|
|
|
main(void)
|
|
|
|
{
|
|
|
|
struct ibv_mr *mr;
|
|
|
|
struct ibv_pd *pd = NULL;
|
|
|
|
size_t length = 10;
|
|
|
|
uint64_t iova = 0;
|
|
|
|
int access = 0;
|
|
|
|
void *addr = NULL;
|
|
|
|
|
|
|
|
mr = ibv_reg_mr_iova(pd, addr, length, iova, access);
|
|
|
|
|
|
|
|
ibv_dereg_mr(mr);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if ! compile_prog "" "-libverbs"; then
|
|
|
|
QEMU_CFLAGS="$QEMU_CFLAGS -DLEGACY_RDMA_REG_MR"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2009-10-01 22:10:37 +04:00
|
|
|
##########################################
|
2016-12-02 22:48:54 +03:00
|
|
|
# xfsctl() probe, used for file-posix.c
|
2010-12-17 13:41:15 +03:00
|
|
|
if test "$xfs" != "no" ; then
|
|
|
|
cat > $TMPC << EOF
|
2011-12-17 12:27:36 +04:00
|
|
|
#include <stddef.h> /* NULL */
|
2010-12-17 13:41:15 +03:00
|
|
|
#include <xfs/xfs.h>
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
xfsctl(NULL, 0, 0, NULL);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
xfs="yes"
|
|
|
|
else
|
|
|
|
if test "$xfs" = "yes" ; then
|
2020-09-17 10:50:20 +03:00
|
|
|
feature_not_found "xfs" "Install xfsprogs/xfslibs devel"
|
2010-12-17 13:41:15 +03:00
|
|
|
fi
|
|
|
|
xfs=no
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2008-07-19 13:56:24 +04:00
|
|
|
##########################################
|
|
|
|
# vde libraries probe
|
2009-08-12 20:20:27 +04:00
|
|
|
if test "$vde" != "no" ; then
|
2009-07-27 18:13:19 +04:00
|
|
|
vde_libs="-lvdeplug"
|
2008-07-19 13:56:24 +04:00
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <libvdeplug.h>
|
2008-09-07 20:42:53 +04:00
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
struct vde_open_args a = {0, 0, 0};
|
2012-07-18 18:10:25 +04:00
|
|
|
char s[] = "";
|
|
|
|
vde_open(s, s, &a);
|
2008-09-07 20:42:53 +04:00
|
|
|
return 0;
|
|
|
|
}
|
2008-07-19 13:56:24 +04:00
|
|
|
EOF
|
2009-08-03 16:46:03 +04:00
|
|
|
if compile_prog "" "$vde_libs" ; then
|
2009-07-27 18:13:19 +04:00
|
|
|
vde=yes
|
2009-08-12 20:20:27 +04:00
|
|
|
else
|
|
|
|
if test "$vde" = "yes" ; then
|
2014-01-24 05:39:10 +04:00
|
|
|
feature_not_found "vde" "Install vde (Virtual Distributed Ethernet) devel"
|
2009-08-12 20:20:27 +04:00
|
|
|
fi
|
|
|
|
vde=no
|
2009-07-27 18:13:19 +04:00
|
|
|
fi
|
2008-07-19 13:56:24 +04:00
|
|
|
fi
|
|
|
|
|
2013-11-06 14:44:06 +04:00
|
|
|
##########################################
|
2014-02-20 18:40:43 +04:00
|
|
|
# netmap support probe
|
|
|
|
# Apart from looking for netmap headers, we make sure that the host API version
|
|
|
|
# supports the netmap backend (>=11). The upper bound (15) is meant to simulate
|
|
|
|
# a minor/major version number. Minor new features will be marked with values up
|
|
|
|
# to 15, and if something happens that requires a change to the backend we will
|
|
|
|
# move above 15, submit the backend fixes and modify this two bounds.
|
2013-11-06 14:44:06 +04:00
|
|
|
if test "$netmap" != "no" ; then
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <inttypes.h>
|
|
|
|
#include <net/if.h>
|
|
|
|
#include <net/netmap.h>
|
|
|
|
#include <net/netmap_user.h>
|
2014-02-20 18:40:43 +04:00
|
|
|
#if (NETMAP_API < 11) || (NETMAP_API > 15)
|
|
|
|
#error
|
|
|
|
#endif
|
2013-11-06 14:44:06 +04:00
|
|
|
int main(void) { return 0; }
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
netmap=yes
|
|
|
|
else
|
|
|
|
if test "$netmap" = "yes" ; then
|
|
|
|
feature_not_found "netmap"
|
|
|
|
fi
|
|
|
|
netmap=no
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2007-01-06 00:25:54 +03:00
|
|
|
##########################################
|
2008-06-28 23:13:06 +04:00
|
|
|
# Sound support libraries probe
|
2007-01-06 00:25:54 +03:00
|
|
|
|
2016-05-16 16:10:20 +03:00
|
|
|
audio_drv_list=$(echo "$audio_drv_list" | sed -e 's/,/ /g')
|
2008-06-28 23:13:06 +04:00
|
|
|
for drv in $audio_drv_list; do
|
|
|
|
case $drv in
|
2019-01-24 14:20:51 +03:00
|
|
|
alsa | try-alsa)
|
2019-01-24 14:20:50 +03:00
|
|
|
if $pkg_config alsa --exists; then
|
|
|
|
alsa_libs=$($pkg_config alsa --libs)
|
2020-08-17 13:47:55 +03:00
|
|
|
alsa_cflags=$($pkg_config alsa --cflags)
|
|
|
|
alsa=yes
|
2019-01-24 14:20:51 +03:00
|
|
|
if test "$drv" = "try-alsa"; then
|
|
|
|
audio_drv_list=$(echo "$audio_drv_list" | sed -e 's/try-alsa/alsa/')
|
|
|
|
fi
|
2019-01-24 14:20:50 +03:00
|
|
|
else
|
2019-01-24 14:20:51 +03:00
|
|
|
if test "$drv" = "try-alsa"; then
|
|
|
|
audio_drv_list=$(echo "$audio_drv_list" | sed -e 's/try-alsa//')
|
|
|
|
else
|
|
|
|
error_exit "$drv check failed" \
|
|
|
|
"Make sure to have the $drv libs and headers installed."
|
|
|
|
fi
|
2019-01-24 14:20:50 +03:00
|
|
|
fi
|
2008-06-28 23:13:06 +04:00
|
|
|
;;
|
|
|
|
|
2019-01-24 14:20:51 +03:00
|
|
|
pa | try-pa)
|
2019-01-24 14:20:50 +03:00
|
|
|
if $pkg_config libpulse --exists; then
|
2020-08-17 13:47:55 +03:00
|
|
|
libpulse=yes
|
2019-01-24 14:20:50 +03:00
|
|
|
pulse_libs=$($pkg_config libpulse --libs)
|
2020-08-17 13:47:55 +03:00
|
|
|
pulse_cflags=$($pkg_config libpulse --cflags)
|
2019-01-24 14:20:51 +03:00
|
|
|
if test "$drv" = "try-pa"; then
|
|
|
|
audio_drv_list=$(echo "$audio_drv_list" | sed -e 's/try-pa/pa/')
|
|
|
|
fi
|
2019-01-24 14:20:50 +03:00
|
|
|
else
|
2019-01-24 14:20:51 +03:00
|
|
|
if test "$drv" = "try-pa"; then
|
|
|
|
audio_drv_list=$(echo "$audio_drv_list" | sed -e 's/try-pa//')
|
|
|
|
else
|
|
|
|
error_exit "$drv check failed" \
|
|
|
|
"Make sure to have the $drv libs and headers installed."
|
|
|
|
fi
|
2019-01-24 14:20:50 +03:00
|
|
|
fi
|
2008-07-03 01:03:08 +04:00
|
|
|
;;
|
|
|
|
|
2017-03-20 12:05:43 +03:00
|
|
|
sdl)
|
|
|
|
if test "$sdl" = "no"; then
|
|
|
|
error_exit "sdl not found or disabled, can not use sdl audio driver"
|
|
|
|
fi
|
|
|
|
;;
|
|
|
|
|
2019-01-24 14:20:51 +03:00
|
|
|
try-sdl)
|
|
|
|
if test "$sdl" = "no"; then
|
|
|
|
audio_drv_list=$(echo "$audio_drv_list" | sed -e 's/try-sdl//')
|
|
|
|
else
|
|
|
|
audio_drv_list=$(echo "$audio_drv_list" | sed -e 's/try-sdl/sdl/')
|
|
|
|
fi
|
|
|
|
;;
|
|
|
|
|
2009-08-03 16:46:29 +04:00
|
|
|
coreaudio)
|
2017-09-07 11:29:13 +03:00
|
|
|
coreaudio_libs="-framework CoreAudio"
|
2009-08-03 16:46:29 +04:00
|
|
|
;;
|
|
|
|
|
2009-08-03 16:46:30 +04:00
|
|
|
dsound)
|
2017-09-07 11:29:13 +03:00
|
|
|
dsound_libs="-lole32 -ldxguid"
|
2009-10-10 01:13:41 +04:00
|
|
|
audio_win_int="yes"
|
2009-08-03 16:46:30 +04:00
|
|
|
;;
|
|
|
|
|
|
|
|
oss)
|
2017-09-07 11:29:13 +03:00
|
|
|
oss_libs="$oss_lib"
|
2009-08-03 16:46:30 +04:00
|
|
|
;;
|
|
|
|
|
2020-04-29 08:53:58 +03:00
|
|
|
jack | try-jack)
|
|
|
|
if $pkg_config jack --exists; then
|
2020-08-17 13:47:55 +03:00
|
|
|
libjack=yes
|
2020-04-29 08:53:58 +03:00
|
|
|
jack_libs=$($pkg_config jack --libs)
|
|
|
|
if test "$drv" = "try-jack"; then
|
|
|
|
audio_drv_list=$(echo "$audio_drv_list" | sed -e 's/try-jack/jack/')
|
|
|
|
fi
|
|
|
|
else
|
|
|
|
if test "$drv" = "try-jack"; then
|
|
|
|
audio_drv_list=$(echo "$audio_drv_list" | sed -e 's/try-jack//')
|
|
|
|
else
|
|
|
|
error_exit "$drv check failed" \
|
|
|
|
"Make sure to have the $drv libs and headers installed."
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
;;
|
|
|
|
|
2008-07-19 20:15:16 +04:00
|
|
|
*)
|
2008-07-19 20:57:30 +04:00
|
|
|
echo "$audio_possible_drivers" | grep -q "\<$drv\>" || {
|
2013-04-08 15:11:26 +04:00
|
|
|
error_exit "Unknown driver '$drv' selected" \
|
|
|
|
"Possible drivers are: $audio_possible_drivers"
|
2008-07-19 20:15:16 +04:00
|
|
|
}
|
|
|
|
;;
|
2008-06-28 23:13:06 +04:00
|
|
|
esac
|
|
|
|
done
|
2007-01-06 00:25:54 +03:00
|
|
|
|
2011-07-19 23:50:29 +04:00
|
|
|
##########################################
|
|
|
|
# glib support probe
|
2012-04-05 15:01:54 +04:00
|
|
|
|
2018-05-04 17:34:46 +03:00
|
|
|
glib_req_ver=2.48
|
2014-02-25 20:36:55 +04:00
|
|
|
glib_modules=gthread-2.0
|
|
|
|
if test "$modules" = yes; then
|
2018-03-08 11:53:00 +03:00
|
|
|
glib_modules="$glib_modules gmodule-export-2.0"
|
2014-02-25 20:36:55 +04:00
|
|
|
fi
|
2017-08-31 01:39:53 +03:00
|
|
|
if test "$plugins" = yes; then
|
|
|
|
glib_modules="$glib_modules gmodule-2.0"
|
|
|
|
fi
|
2014-02-10 10:48:57 +04:00
|
|
|
|
2014-02-25 20:36:55 +04:00
|
|
|
for i in $glib_modules; do
|
2014-02-10 10:48:57 +04:00
|
|
|
if $pkg_config --atleast-version=$glib_req_ver $i; then
|
2016-05-16 16:10:20 +03:00
|
|
|
glib_cflags=$($pkg_config --cflags $i)
|
|
|
|
glib_libs=$($pkg_config --libs $i)
|
2014-02-10 10:48:57 +04:00
|
|
|
else
|
|
|
|
error_exit "glib-$glib_req_ver $i is required to compile QEMU"
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
2020-09-01 15:41:17 +03:00
|
|
|
# This workaround is required due to a bug in pkg-config file for glib as it
|
|
|
|
# doesn't define GLIB_STATIC_COMPILATION for pkg-config --static
|
|
|
|
|
|
|
|
if test "$static" = yes && test "$mingw32" = yes; then
|
|
|
|
glib_cflags="-DGLIB_STATIC_COMPILATION $glib_cflags"
|
|
|
|
fi
|
|
|
|
|
2019-02-21 14:07:00 +03:00
|
|
|
if $pkg_config --atleast-version=$glib_req_ver gio-2.0; then
|
|
|
|
gio_cflags=$($pkg_config --cflags gio-2.0)
|
|
|
|
gio_libs=$($pkg_config --libs gio-2.0)
|
2019-09-27 10:34:42 +03:00
|
|
|
gdbus_codegen=$($pkg_config --variable=gdbus_codegen gio-2.0)
|
2020-01-10 14:27:25 +03:00
|
|
|
if [ ! -x "$gdbus_codegen" ]; then
|
|
|
|
gdbus_codegen=
|
|
|
|
fi
|
2020-11-02 19:52:17 +03:00
|
|
|
# Check that the libraries actually work -- Ubuntu 18.04 ships
|
|
|
|
# with pkg-config --static --libs data for gio-2.0 that is missing
|
|
|
|
# -lblkid and will give a link error.
|
2020-11-17 15:56:33 +03:00
|
|
|
cat > $TMPC <<EOF
|
|
|
|
#include <gio/gio.h>
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
g_dbus_proxy_new_sync(0, 0, 0, 0, 0, 0, 0, 0);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "$gio_cflags" "$gio_libs" ; then
|
2020-11-02 19:52:17 +03:00
|
|
|
gio=yes
|
|
|
|
else
|
|
|
|
gio=no
|
|
|
|
fi
|
2019-02-21 14:07:00 +03:00
|
|
|
else
|
|
|
|
gio=no
|
|
|
|
fi
|
|
|
|
|
2019-09-27 10:34:42 +03:00
|
|
|
if $pkg_config --atleast-version=$glib_req_ver gio-unix-2.0; then
|
|
|
|
gio_cflags="$gio_cflags $($pkg_config --cflags gio-unix-2.0)"
|
|
|
|
gio_libs="$gio_libs $($pkg_config --libs gio-unix-2.0)"
|
|
|
|
fi
|
|
|
|
|
2016-01-27 12:00:45 +03:00
|
|
|
# Sanity check that the current size_t matches the
|
|
|
|
# size that glib thinks it should be. This catches
|
|
|
|
# problems on multi-arch where people try to build
|
|
|
|
# 32-bit QEMU while pointing at 64-bit glib headers
|
|
|
|
cat > $TMPC <<EOF
|
|
|
|
#include <glib.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
|
|
|
|
#define QEMU_BUILD_BUG_ON(x) \
|
|
|
|
typedef char qemu_build_bug_on[(x)?-1:1] __attribute__((unused));
|
|
|
|
|
|
|
|
int main(void) {
|
|
|
|
QEMU_BUILD_BUG_ON(sizeof(size_t) != GLIB_SIZEOF_SIZE_T);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
|
2020-09-01 15:41:17 +03:00
|
|
|
if ! compile_prog "$glib_cflags" "$glib_libs" ; then
|
2016-01-27 12:00:45 +03:00
|
|
|
error_exit "sizeof(size_t) doesn't match GLIB_SIZEOF_SIZE_T."\
|
|
|
|
"You probably need to set PKG_CONFIG_LIBDIR"\
|
|
|
|
"to point to the right pkg-config files for your"\
|
|
|
|
"build target"
|
|
|
|
fi
|
|
|
|
|
2015-03-26 01:57:38 +03:00
|
|
|
# Silence clang 3.5.0 warnings about glib attribute __alloc_size__ usage
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <glib.h>
|
|
|
|
int main(void) { return 0; }
|
|
|
|
EOF
|
|
|
|
if ! compile_prog "$glib_cflags -Werror" "$glib_libs" ; then
|
|
|
|
if cc_has_warning_flag "-Wno-unknown-attributes"; then
|
|
|
|
glib_cflags="-Wno-unknown-attributes $glib_cflags"
|
2020-09-23 12:26:15 +03:00
|
|
|
CONFIGURE_CFLAGS="-Wno-unknown-attributes $CONFIGURE_CFLAGS"
|
2015-03-26 01:57:38 +03:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2020-03-17 20:55:34 +03:00
|
|
|
# Silence clang warnings triggered by glib < 2.57.2
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <glib.h>
|
|
|
|
typedef struct Foo {
|
|
|
|
int i;
|
|
|
|
} Foo;
|
|
|
|
static void foo_free(Foo *f)
|
|
|
|
{
|
|
|
|
g_free(f);
|
|
|
|
}
|
|
|
|
G_DEFINE_AUTOPTR_CLEANUP_FUNC(Foo, foo_free);
|
|
|
|
int main(void) { return 0; }
|
|
|
|
EOF
|
|
|
|
if ! compile_prog "$glib_cflags -Werror" "$glib_libs" ; then
|
|
|
|
if cc_has_warning_flag "-Wno-unused-function"; then
|
|
|
|
glib_cflags="$glib_cflags -Wno-unused-function"
|
2020-09-23 12:26:15 +03:00
|
|
|
CONFIGURE_CFLAGS="$CONFIGURE_CFLAGS -Wno-unused-function"
|
2020-03-17 20:55:34 +03:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2014-02-10 10:48:57 +04:00
|
|
|
##########################################
|
|
|
|
# SHA command probe for modules
|
|
|
|
if test "$modules" = yes; then
|
|
|
|
shacmd_probe="sha1sum sha1 shasum"
|
|
|
|
for c in $shacmd_probe; do
|
2014-12-04 09:18:16 +03:00
|
|
|
if has $c; then
|
2014-02-10 10:48:57 +04:00
|
|
|
shacmd="$c"
|
|
|
|
break
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
if test "$shacmd" = ""; then
|
|
|
|
error_exit "one of the checksum commands is required to enable modules: $shacmd_probe"
|
|
|
|
fi
|
2011-07-19 23:50:29 +04:00
|
|
|
fi
|
|
|
|
|
2008-08-15 22:20:52 +04:00
|
|
|
##########################################
|
2009-04-24 22:03:15 +04:00
|
|
|
# pthread probe
|
2011-08-08 04:02:11 +04:00
|
|
|
PTHREADLIBS_LIST="-pthread -lpthread -lpthreadGC2"
|
2008-12-12 19:41:40 +03:00
|
|
|
|
2009-08-11 01:39:39 +04:00
|
|
|
pthread=no
|
2009-04-24 22:03:15 +04:00
|
|
|
cat > $TMPC << EOF
|
2008-12-12 19:41:40 +03:00
|
|
|
#include <pthread.h>
|
2011-12-17 12:27:32 +04:00
|
|
|
static void *f(void *p) { return NULL; }
|
|
|
|
int main(void) {
|
|
|
|
pthread_t thread;
|
|
|
|
pthread_create(&thread, 0, f, 0);
|
|
|
|
return 0;
|
|
|
|
}
|
2008-08-15 22:20:52 +04:00
|
|
|
EOF
|
2010-09-20 02:50:44 +04:00
|
|
|
if compile_prog "" "" ; then
|
|
|
|
pthread=yes
|
|
|
|
else
|
|
|
|
for pthread_lib in $PTHREADLIBS_LIST; do
|
|
|
|
if compile_prog "" "$pthread_lib" ; then
|
|
|
|
pthread=yes
|
2012-04-20 18:36:12 +04:00
|
|
|
found=no
|
|
|
|
for lib_entry in $LIBS; do
|
|
|
|
if test "$lib_entry" = "$pthread_lib"; then
|
|
|
|
found=yes
|
|
|
|
break
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
if test "$found" = "no"; then
|
|
|
|
LIBS="$pthread_lib $LIBS"
|
|
|
|
fi
|
2010-09-20 02:50:44 +04:00
|
|
|
break
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
fi
|
2008-08-15 22:20:52 +04:00
|
|
|
|
2019-02-05 05:39:37 +03:00
|
|
|
if test "$mingw32" != yes && test "$pthread" = no; then
|
2013-04-08 15:11:26 +04:00
|
|
|
error_exit "pthread check failed" \
|
|
|
|
"Make sure to have the pthread libs and headers installed."
|
2009-04-24 22:03:15 +04:00
|
|
|
fi
|
|
|
|
|
2018-12-17 23:26:01 +03:00
|
|
|
# check for pthread_setname_np with thread id
|
|
|
|
pthread_setname_np_w_tid=no
|
2014-03-12 15:48:18 +04:00
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <pthread.h>
|
|
|
|
|
|
|
|
static void *f(void *p) { return NULL; }
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
pthread_t thread;
|
|
|
|
pthread_create(&thread, 0, f, 0);
|
|
|
|
pthread_setname_np(thread, "QEMU");
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "$pthread_lib" ; then
|
2018-12-17 23:26:01 +03:00
|
|
|
pthread_setname_np_w_tid=yes
|
|
|
|
fi
|
|
|
|
|
|
|
|
# check for pthread_setname_np without thread id
|
|
|
|
pthread_setname_np_wo_tid=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <pthread.h>
|
|
|
|
|
2020-07-16 08:12:22 +03:00
|
|
|
static void *f(void *p) { pthread_setname_np("QEMU"); return NULL; }
|
2018-12-17 23:26:01 +03:00
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
pthread_t thread;
|
|
|
|
pthread_create(&thread, 0, f, 0);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "$pthread_lib" ; then
|
|
|
|
pthread_setname_np_wo_tid=yes
|
2014-03-12 15:48:18 +04:00
|
|
|
fi
|
|
|
|
|
2013-04-09 18:30:53 +04:00
|
|
|
##########################################
|
2019-06-20 23:08:40 +03:00
|
|
|
# libssh probe
|
|
|
|
if test "$libssh" != "no" ; then
|
|
|
|
if $pkg_config --exists libssh; then
|
|
|
|
libssh_cflags=$($pkg_config libssh --cflags)
|
|
|
|
libssh_libs=$($pkg_config libssh --libs)
|
|
|
|
libssh=yes
|
2013-04-09 18:30:53 +04:00
|
|
|
else
|
2019-06-20 23:08:40 +03:00
|
|
|
if test "$libssh" = "yes" ; then
|
|
|
|
error_exit "libssh required for --enable-libssh"
|
2013-04-09 18:30:53 +04:00
|
|
|
fi
|
2019-06-20 23:08:40 +03:00
|
|
|
libssh=no
|
2013-04-09 18:30:53 +04:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2013-04-09 18:30:54 +04:00
|
|
|
##########################################
|
2019-06-20 23:08:40 +03:00
|
|
|
# Check for libssh 0.8
|
|
|
|
# This is done like this instead of using the LIBSSH_VERSION_* and
|
|
|
|
# SSH_VERSION_* macros because some distributions in the past shipped
|
|
|
|
# snapshots of the future 0.8 from Git, and those snapshots did not
|
|
|
|
# have updated version numbers (still referring to 0.7.0).
|
2013-04-09 18:30:54 +04:00
|
|
|
|
2019-06-20 23:08:40 +03:00
|
|
|
if test "$libssh" = "yes"; then
|
2013-04-09 18:30:54 +04:00
|
|
|
cat > $TMPC <<EOF
|
2019-06-20 23:08:40 +03:00
|
|
|
#include <libssh/libssh.h>
|
|
|
|
int main(void) { return ssh_get_server_publickey(NULL, NULL); }
|
2013-04-09 18:30:54 +04:00
|
|
|
EOF
|
2019-06-20 23:08:40 +03:00
|
|
|
if compile_prog "$libssh_cflags" "$libssh_libs"; then
|
|
|
|
libssh_cflags="-DHAVE_LIBSSH_0_8 $libssh_cflags"
|
2013-04-09 18:30:54 +04:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2009-08-20 18:58:35 +04:00
|
|
|
##########################################
|
|
|
|
# linux-aio probe
|
|
|
|
|
|
|
|
if test "$linux_aio" != "no" ; then
|
|
|
|
cat > $TMPC <<EOF
|
|
|
|
#include <libaio.h>
|
|
|
|
#include <sys/eventfd.h>
|
2010-10-05 23:28:17 +04:00
|
|
|
#include <stddef.h>
|
2009-08-20 18:58:35 +04:00
|
|
|
int main(void) { io_setup(0, NULL); io_set_eventfd(NULL, 0); eventfd(0, 0); return 0; }
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "-laio" ; then
|
|
|
|
linux_aio=yes
|
|
|
|
else
|
|
|
|
if test "$linux_aio" = "yes" ; then
|
2014-01-24 05:39:10 +04:00
|
|
|
feature_not_found "linux AIO" "Install libaio devel"
|
2009-08-20 18:58:35 +04:00
|
|
|
fi
|
2009-08-31 20:18:12 +04:00
|
|
|
linux_aio=no
|
2009-08-20 18:58:35 +04:00
|
|
|
fi
|
|
|
|
fi
|
2020-01-20 17:18:44 +03:00
|
|
|
##########################################
|
|
|
|
# linux-io-uring probe
|
|
|
|
|
|
|
|
if test "$linux_io_uring" != "no" ; then
|
|
|
|
if $pkg_config liburing; then
|
|
|
|
linux_io_uring_cflags=$($pkg_config --cflags liburing)
|
|
|
|
linux_io_uring_libs=$($pkg_config --libs liburing)
|
|
|
|
linux_io_uring=yes
|
|
|
|
else
|
|
|
|
if test "$linux_io_uring" = "yes" ; then
|
|
|
|
feature_not_found "linux io_uring" "Install liburing devel"
|
|
|
|
fi
|
|
|
|
linux_io_uring=no
|
|
|
|
fi
|
|
|
|
fi
|
2009-08-20 18:58:35 +04:00
|
|
|
|
2013-03-18 19:37:50 +04:00
|
|
|
##########################################
|
2019-01-23 09:56:07 +03:00
|
|
|
# TPM emulation is only on POSIX
|
2013-03-18 19:37:50 +04:00
|
|
|
|
2019-01-23 09:56:07 +03:00
|
|
|
if test "$tpm" = ""; then
|
|
|
|
if test "$mingw32" = "yes"; then
|
|
|
|
tpm=no
|
|
|
|
else
|
|
|
|
tpm=yes
|
|
|
|
fi
|
|
|
|
elif test "$tpm" = "yes"; then
|
|
|
|
if test "$mingw32" = "yes" ; then
|
|
|
|
error_exit "TPM emulation only available on POSIX systems"
|
|
|
|
fi
|
2013-03-18 19:37:50 +04:00
|
|
|
fi
|
|
|
|
|
2008-12-05 23:05:26 +03:00
|
|
|
##########################################
|
|
|
|
# iovec probe
|
|
|
|
cat > $TMPC <<EOF
|
2009-01-14 21:03:53 +03:00
|
|
|
#include <sys/types.h>
|
2008-12-05 23:05:26 +03:00
|
|
|
#include <sys/uio.h>
|
2009-01-14 21:03:53 +03:00
|
|
|
#include <unistd.h>
|
2011-12-17 12:27:33 +04:00
|
|
|
int main(void) { return sizeof(struct iovec); }
|
2008-12-05 23:05:26 +03:00
|
|
|
EOF
|
|
|
|
iovec=no
|
2009-08-03 16:46:03 +04:00
|
|
|
if compile_prog "" "" ; then
|
2008-12-05 23:05:26 +03:00
|
|
|
iovec=yes
|
|
|
|
fi
|
|
|
|
|
2009-04-07 22:43:28 +04:00
|
|
|
##########################################
|
|
|
|
# preadv probe
|
|
|
|
cat > $TMPC <<EOF
|
|
|
|
#include <sys/types.h>
|
|
|
|
#include <sys/uio.h>
|
|
|
|
#include <unistd.h>
|
2012-08-10 00:21:25 +04:00
|
|
|
int main(void) { return preadv(0, 0, 0, 0); }
|
2009-04-07 22:43:28 +04:00
|
|
|
EOF
|
|
|
|
preadv=no
|
2009-08-03 16:46:03 +04:00
|
|
|
if compile_prog "" "" ; then
|
2009-04-07 22:43:28 +04:00
|
|
|
preadv=yes
|
|
|
|
fi
|
|
|
|
|
2008-12-16 13:43:48 +03:00
|
|
|
##########################################
|
|
|
|
# fdt probe
|
2019-06-21 16:05:44 +03:00
|
|
|
|
2020-10-05 12:31:15 +03:00
|
|
|
case "$fdt" in
|
|
|
|
auto | enabled | internal)
|
|
|
|
# Simpler to always update submodule, even if not needed.
|
|
|
|
if test -e "${source_path}/.git" && test $git_update = 'yes' ; then
|
|
|
|
git_submodules="${git_submodules} dtc"
|
|
|
|
fi
|
|
|
|
;;
|
|
|
|
esac
|
2008-12-16 13:43:48 +03:00
|
|
|
|
2011-03-08 01:32:39 +03:00
|
|
|
##########################################
|
2015-10-26 20:45:48 +03:00
|
|
|
# opengl probe (for sdl2, gtk, milkymist-tmu2)
|
2015-03-16 12:03:53 +03:00
|
|
|
|
2019-05-24 16:09:42 +03:00
|
|
|
gbm="no"
|
|
|
|
if $pkg_config gbm; then
|
|
|
|
gbm_cflags="$($pkg_config --cflags gbm)"
|
|
|
|
gbm_libs="$($pkg_config --libs gbm)"
|
|
|
|
gbm="yes"
|
|
|
|
fi
|
|
|
|
|
2014-11-20 11:49:44 +03:00
|
|
|
if test "$opengl" != "no" ; then
|
2018-06-30 19:54:48 +03:00
|
|
|
opengl_pkgs="epoxy gbm"
|
2018-03-01 13:05:43 +03:00
|
|
|
if $pkg_config $opengl_pkgs; then
|
|
|
|
opengl_cflags="$($pkg_config --cflags $opengl_pkgs)"
|
|
|
|
opengl_libs="$($pkg_config --libs $opengl_pkgs)"
|
2014-11-20 11:49:44 +03:00
|
|
|
opengl=yes
|
2015-05-26 13:26:21 +03:00
|
|
|
if test "$gtk" = "yes" && $pkg_config --exists "$gtkpackage >= 3.16"; then
|
|
|
|
gtk_gl="yes"
|
|
|
|
fi
|
2011-03-08 01:32:39 +03:00
|
|
|
else
|
2014-11-20 11:49:44 +03:00
|
|
|
if test "$opengl" = "yes" ; then
|
2015-05-11 13:24:43 +03:00
|
|
|
feature_not_found "opengl" "Please install opengl (mesa) devel pkgs: $opengl_pkgs"
|
2011-03-08 01:32:39 +03:00
|
|
|
fi
|
2015-01-09 22:08:49 +03:00
|
|
|
opengl_cflags=""
|
2014-11-20 11:49:44 +03:00
|
|
|
opengl_libs=""
|
|
|
|
opengl=no
|
2011-03-08 01:32:39 +03:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2015-12-03 14:56:34 +03:00
|
|
|
if test "$opengl" = "yes"; then
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <epoxy/egl.h>
|
|
|
|
#ifndef EGL_MESA_image_dma_buf_export
|
|
|
|
# error mesa/epoxy lacks support for dmabufs (mesa 10.6+)
|
|
|
|
#endif
|
|
|
|
int main(void) { return 0; }
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
opengl_dmabuf=yes
|
|
|
|
fi
|
|
|
|
fi
|
block: Support Archipelago as a QEMU block backend
VM Image on Archipelago volume is specified like this:
file.driver=archipelago,file.volume=<volumename>[,file.mport=<mapperd_port>[,
file.vport=<vlmcd_port>][,file.segment=<segment_name>]]
'archipelago' is the protocol.
'mport' is the port number on which mapperd is listening. This is optional
and if not specified, QEMU will make Archipelago to use the default port.
'vport' is the port number on which vlmcd is listening. This is optional
and if not specified, QEMU will make Archipelago to use the default port.
'segment' is the name of the shared memory segment Archipelago stack is using.
This is optional and if not specified, QEMU will make Archipelago to use the
default value, 'archipelago'.
Examples:
file.driver=archipelago,file.volume=my_vm_volume
file.driver=archipelago,file.volume=my_vm_volume,file.mport=123
file.driver=archipelago,file.volume=my_vm_volume,file.mport=123,
file.vport=1234
file.driver=archipelago,file.volume=my_vm_volume,file.mport=123,
file.vport=1234,file.segment=my_segment
Signed-off-by: Chrysostomos Nanakos <cnanakos@grnet.gr>
Reviewed-by: Stefan Hajnoczi <stefanha@redhat.com>
Signed-off-by: Kevin Wolf <kwolf@redhat.com>
2014-08-04 18:35:32 +04:00
|
|
|
|
2019-02-05 05:39:37 +03:00
|
|
|
if test "$opengl" = "yes" && test "$have_x11" = "yes"; then
|
2019-01-30 15:00:03 +03:00
|
|
|
for target in $target_list; do
|
|
|
|
case $target in
|
|
|
|
lm32-softmmu) # milkymist-tmu2 requires X11 and OpenGL
|
|
|
|
need_x11=yes
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
done
|
|
|
|
fi
|
|
|
|
|
2018-01-12 12:01:19 +03:00
|
|
|
##########################################
|
|
|
|
# libxml2 probe
|
|
|
|
if test "$libxml2" != "no" ; then
|
|
|
|
if $pkg_config --exists libxml-2.0; then
|
|
|
|
libxml2="yes"
|
|
|
|
libxml2_cflags=$($pkg_config --cflags libxml-2.0)
|
|
|
|
libxml2_libs=$($pkg_config --libs libxml-2.0)
|
|
|
|
else
|
|
|
|
if test "$libxml2" = "yes"; then
|
|
|
|
feature_not_found "libxml2" "Install libxml2 devel"
|
|
|
|
fi
|
|
|
|
libxml2="no"
|
|
|
|
fi
|
|
|
|
fi
|
block: Support Archipelago as a QEMU block backend
VM Image on Archipelago volume is specified like this:
file.driver=archipelago,file.volume=<volumename>[,file.mport=<mapperd_port>[,
file.vport=<vlmcd_port>][,file.segment=<segment_name>]]
'archipelago' is the protocol.
'mport' is the port number on which mapperd is listening. This is optional
and if not specified, QEMU will make Archipelago to use the default port.
'vport' is the port number on which vlmcd is listening. This is optional
and if not specified, QEMU will make Archipelago to use the default port.
'segment' is the name of the shared memory segment Archipelago stack is using.
This is optional and if not specified, QEMU will make Archipelago to use the
default value, 'archipelago'.
Examples:
file.driver=archipelago,file.volume=my_vm_volume
file.driver=archipelago,file.volume=my_vm_volume,file.mport=123
file.driver=archipelago,file.volume=my_vm_volume,file.mport=123,
file.vport=1234
file.driver=archipelago,file.volume=my_vm_volume,file.mport=123,
file.vport=1234,file.segment=my_segment
Signed-off-by: Chrysostomos Nanakos <cnanakos@grnet.gr>
Reviewed-by: Stefan Hajnoczi <stefanha@redhat.com>
Signed-off-by: Kevin Wolf <kwolf@redhat.com>
2014-08-04 18:35:32 +04:00
|
|
|
|
2009-04-15 23:48:17 +04:00
|
|
|
# Check for inotify functions when we are building linux-user
|
2009-04-15 20:12:13 +04:00
|
|
|
# emulator. This is done because older glibc versions don't
|
|
|
|
# have syscall stubs for these implemented. In that case we
|
|
|
|
# don't provide them even if kernel supports them.
|
|
|
|
#
|
|
|
|
inotify=no
|
2009-06-29 18:26:11 +04:00
|
|
|
cat > $TMPC << EOF
|
2009-04-15 20:12:13 +04:00
|
|
|
#include <sys/inotify.h>
|
|
|
|
|
|
|
|
int
|
|
|
|
main(void)
|
|
|
|
{
|
|
|
|
/* try to start inotify */
|
2009-04-17 17:50:32 +04:00
|
|
|
return inotify_init();
|
2009-04-15 20:12:13 +04:00
|
|
|
}
|
|
|
|
EOF
|
2009-08-03 16:46:03 +04:00
|
|
|
if compile_prog "" "" ; then
|
2009-06-29 18:26:11 +04:00
|
|
|
inotify=yes
|
2009-04-15 20:12:13 +04:00
|
|
|
fi
|
|
|
|
|
2010-03-26 18:25:11 +03:00
|
|
|
inotify1=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <sys/inotify.h>
|
|
|
|
|
|
|
|
int
|
|
|
|
main(void)
|
|
|
|
{
|
|
|
|
/* try to start inotify */
|
|
|
|
return inotify_init1(0);
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
inotify1=yes
|
|
|
|
fi
|
|
|
|
|
2009-05-05 13:10:04 +04:00
|
|
|
# check if pipe2 is there
|
|
|
|
pipe2=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <unistd.h>
|
|
|
|
#include <fcntl.h>
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
int pipefd[2];
|
2012-08-20 22:45:08 +04:00
|
|
|
return pipe2(pipefd, O_CLOEXEC);
|
2009-05-05 13:10:04 +04:00
|
|
|
}
|
|
|
|
EOF
|
2009-08-03 16:46:03 +04:00
|
|
|
if compile_prog "" "" ; then
|
2009-05-05 13:10:04 +04:00
|
|
|
pipe2=yes
|
|
|
|
fi
|
|
|
|
|
2009-12-02 14:24:42 +03:00
|
|
|
# check if accept4 is there
|
|
|
|
accept4=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <sys/socket.h>
|
|
|
|
#include <stddef.h>
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
accept4(0, NULL, NULL, SOCK_CLOEXEC);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
accept4=yes
|
|
|
|
fi
|
|
|
|
|
2009-05-16 17:02:41 +04:00
|
|
|
# check if tee/splice is there. vmsplice was added same time.
|
|
|
|
splice=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <unistd.h>
|
|
|
|
#include <fcntl.h>
|
|
|
|
#include <limits.h>
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
2011-12-17 12:27:35 +04:00
|
|
|
int len, fd = 0;
|
2009-05-16 17:02:41 +04:00
|
|
|
len = tee(STDIN_FILENO, STDOUT_FILENO, INT_MAX, SPLICE_F_NONBLOCK);
|
|
|
|
splice(STDIN_FILENO, NULL, fd, NULL, len, SPLICE_F_MOVE);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
2009-08-03 16:46:03 +04:00
|
|
|
if compile_prog "" "" ; then
|
2009-05-16 17:02:41 +04:00
|
|
|
splice=yes
|
|
|
|
fi
|
|
|
|
|
2014-05-14 13:43:28 +04:00
|
|
|
##########################################
|
|
|
|
# libnuma probe
|
|
|
|
|
|
|
|
if test "$numa" != "no" ; then
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <numa.h>
|
|
|
|
int main(void) { return numa_available(); }
|
|
|
|
EOF
|
|
|
|
|
|
|
|
if compile_prog "" "-lnuma" ; then
|
|
|
|
numa=yes
|
2019-07-24 18:23:16 +03:00
|
|
|
numa_libs="-lnuma"
|
2014-05-14 13:43:28 +04:00
|
|
|
else
|
|
|
|
if test "$numa" = "yes" ; then
|
|
|
|
feature_not_found "numa" "install numactl devel"
|
|
|
|
fi
|
|
|
|
numa=no
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2020-09-01 18:15:30 +03:00
|
|
|
malloc=system
|
2015-06-19 13:56:58 +03:00
|
|
|
if test "$tcmalloc" = "yes" && test "$jemalloc" = "yes" ; then
|
|
|
|
echo "ERROR: tcmalloc && jemalloc can't be used at the same time"
|
|
|
|
exit 1
|
2020-09-01 18:15:30 +03:00
|
|
|
elif test "$tcmalloc" = "yes" ; then
|
|
|
|
malloc=tcmalloc
|
|
|
|
elif test "$jemalloc" = "yes" ; then
|
|
|
|
malloc=jemalloc
|
2015-06-19 13:56:58 +03:00
|
|
|
fi
|
|
|
|
|
2010-10-11 22:31:15 +04:00
|
|
|
##########################################
|
|
|
|
# signalfd probe
|
|
|
|
signalfd="no"
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <unistd.h>
|
|
|
|
#include <sys/syscall.h>
|
|
|
|
#include <signal.h>
|
|
|
|
int main(void) { return syscall(SYS_signalfd, -1, NULL, _NSIG / 8); }
|
|
|
|
EOF
|
|
|
|
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
signalfd=yes
|
|
|
|
fi
|
|
|
|
|
qemu-io: Add generic function for reinitializing optind.
On FreeBSD 11.2:
$ nbdkit memory size=1M --run './qemu-io -f raw -c "aio_write 0 512" $nbd'
Parsing error: non-numeric argument, or extraneous/unrecognized suffix -- aio_write
After main option parsing, we reinitialize optind so we can parse each
command. However reinitializing optind to 0 does not work on FreeBSD.
What happens when you do this is optind remains 0 after the option
parsing loop, and the result is we try to parse argv[optind] ==
argv[0] == "aio_write" as if it was the first parameter.
The FreeBSD manual page says:
In order to use getopt() to evaluate multiple sets of arguments, or to
evaluate a single set of arguments multiple times, the variable optreset
must be set to 1 before the second and each additional set of calls to
getopt(), and the variable optind must be reinitialized.
(From the rest of the man page it is clear that optind must be
reinitialized to 1).
The glibc man page says:
A program that scans multiple argument vectors, or rescans the same
vector more than once, and wants to make use of GNU extensions such as
'+' and '-' at the start of optstring, or changes the value of
POSIXLY_CORRECT between scans, must reinitialize getopt() by resetting
optind to 0, rather than the traditional value of 1. (Resetting to 0
forces the invocation of an internal initialization routine that
rechecks POSIXLY_CORRECT and checks for GNU extensions in optstring.)
This commit introduces an OS-portability function called
qemu_reset_optind which provides a way of resetting optind that works
on FreeBSD and platforms that use optreset, while keeping it the same
as now on other platforms.
Note that the qemu codebase sets optind in many other places, but in
those other places it's setting a local variable and not using getopt.
This change is only needed in places where we are using getopt and the
associated global variable optind.
Signed-off-by: Richard W.M. Jones <rjones@redhat.com>
Message-id: 20190118101114.11759-2-rjones@redhat.com
Reviewed-by: Daniel P. Berrangé <berrange@redhat.com>
Reviewed-by: Eric Blake <eblake@redhat.com>
Signed-off-by: Max Reitz <mreitz@redhat.com>
2019-01-18 13:11:14 +03:00
|
|
|
# check if optreset global is declared by <getopt.h>
|
|
|
|
optreset="no"
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <getopt.h>
|
|
|
|
int main(void) { return optreset; }
|
|
|
|
EOF
|
|
|
|
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
optreset=yes
|
|
|
|
fi
|
|
|
|
|
2009-08-12 16:08:24 +04:00
|
|
|
# check if eventfd is supported
|
|
|
|
eventfd=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <sys/eventfd.h>
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
2011-12-17 12:27:37 +04:00
|
|
|
return eventfd(0, EFD_NONBLOCK | EFD_CLOEXEC);
|
2009-08-12 16:08:24 +04:00
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
eventfd=yes
|
|
|
|
fi
|
|
|
|
|
2015-10-09 18:17:16 +03:00
|
|
|
# check if memfd is supported
|
|
|
|
memfd=no
|
|
|
|
cat > $TMPC << EOF
|
2017-11-28 13:51:27 +03:00
|
|
|
#include <sys/mman.h>
|
2015-10-09 18:17:16 +03:00
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
return memfd_create("foo", MFD_ALLOW_SEALING);
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
memfd=yes
|
|
|
|
fi
|
|
|
|
|
2018-10-08 19:35:19 +03:00
|
|
|
# check for usbfs
|
|
|
|
have_usbfs=no
|
|
|
|
if test "$linux_user" = "yes"; then
|
2019-02-14 00:18:27 +03:00
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <linux/usbdevice_fs.h>
|
|
|
|
|
|
|
|
#ifndef USBDEVFS_GET_CAPABILITIES
|
|
|
|
#error "USBDEVFS_GET_CAPABILITIES undefined"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef USBDEVFS_DISCONNECT_CLAIM
|
|
|
|
#error "USBDEVFS_DISCONNECT_CLAIM undefined"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" ""; then
|
2018-10-08 19:35:19 +03:00
|
|
|
have_usbfs=yes
|
|
|
|
fi
|
|
|
|
fi
|
2015-10-09 18:17:16 +03:00
|
|
|
|
2009-09-17 21:22:14 +04:00
|
|
|
# check for fallocate
|
|
|
|
fallocate=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <fcntl.h>
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
fallocate(0, 0, 0, 0);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
2012-04-04 20:03:15 +04:00
|
|
|
if compile_prog "" "" ; then
|
2009-09-17 21:22:14 +04:00
|
|
|
fallocate=yes
|
|
|
|
fi
|
|
|
|
|
2013-01-14 19:26:52 +04:00
|
|
|
# check for fallocate hole punching
|
|
|
|
fallocate_punch_hole=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <fcntl.h>
|
|
|
|
#include <linux/falloc.h>
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
fallocate(0, FALLOC_FL_PUNCH_HOLE | FALLOC_FL_KEEP_SIZE, 0, 0);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
fallocate_punch_hole=yes
|
|
|
|
fi
|
|
|
|
|
2015-01-30 11:42:14 +03:00
|
|
|
# check that fallocate supports range zeroing inside the file
|
|
|
|
fallocate_zero_range=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <fcntl.h>
|
|
|
|
#include <linux/falloc.h>
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
fallocate(0, FALLOC_FL_ZERO_RANGE, 0, 0);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
fallocate_zero_range=yes
|
|
|
|
fi
|
|
|
|
|
2014-09-29 19:12:59 +04:00
|
|
|
# check for posix_fallocate
|
|
|
|
posix_fallocate=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <fcntl.h>
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
posix_fallocate(0, 0, 0);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
posix_fallocate=yes
|
|
|
|
fi
|
|
|
|
|
2011-01-06 14:05:10 +03:00
|
|
|
# check for sync_file_range
|
|
|
|
sync_file_range=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <fcntl.h>
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
sync_file_range(0, 0, 0, 0);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
2012-04-04 20:03:15 +04:00
|
|
|
if compile_prog "" "" ; then
|
2011-01-06 14:05:10 +03:00
|
|
|
sync_file_range=yes
|
|
|
|
fi
|
|
|
|
|
2011-01-10 16:11:24 +03:00
|
|
|
# check for linux/fiemap.h and FS_IOC_FIEMAP
|
|
|
|
fiemap=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <sys/ioctl.h>
|
|
|
|
#include <linux/fs.h>
|
|
|
|
#include <linux/fiemap.h>
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
ioctl(0, FS_IOC_FIEMAP, 0);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
2012-04-04 20:03:15 +04:00
|
|
|
if compile_prog "" "" ; then
|
2011-01-10 16:11:24 +03:00
|
|
|
fiemap=yes
|
|
|
|
fi
|
|
|
|
|
2009-09-17 21:22:14 +04:00
|
|
|
# check for dup3
|
|
|
|
dup3=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <unistd.h>
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
dup3(0, 0, 0);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
2009-11-03 12:54:44 +03:00
|
|
|
if compile_prog "" "" ; then
|
2009-09-17 21:22:14 +04:00
|
|
|
dup3=yes
|
|
|
|
fi
|
|
|
|
|
2013-08-21 19:02:43 +04:00
|
|
|
# check for ppoll support
|
|
|
|
ppoll=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <poll.h>
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
struct pollfd pfd = { .fd = 0, .events = 0, .revents = 0 };
|
|
|
|
ppoll(&pfd, 1, 0, 0);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
ppoll=yes
|
|
|
|
fi
|
|
|
|
|
2013-08-21 19:02:44 +04:00
|
|
|
# check for prctl(PR_SET_TIMERSLACK , ... ) support
|
|
|
|
prctl_pr_set_timerslack=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <sys/prctl.h>
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
prctl(PR_SET_TIMERSLACK, 1, 0, 0, 0);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
prctl_pr_set_timerslack=yes
|
|
|
|
fi
|
|
|
|
|
2011-02-15 21:35:05 +03:00
|
|
|
# check for epoll support
|
|
|
|
epoll=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <sys/epoll.h>
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
epoll_create(0);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
2012-04-04 20:03:15 +04:00
|
|
|
if compile_prog "" "" ; then
|
2011-02-15 21:35:05 +03:00
|
|
|
epoll=yes
|
|
|
|
fi
|
|
|
|
|
2016-06-06 21:58:11 +03:00
|
|
|
# epoll_create1 is a later addition
|
|
|
|
# so we must check separately for its presence
|
2011-02-15 21:35:05 +03:00
|
|
|
epoll_create1=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <sys/epoll.h>
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
2011-04-26 19:56:40 +04:00
|
|
|
/* Note that we use epoll_create1 as a value, not as
|
|
|
|
* a function being called. This is necessary so that on
|
|
|
|
* old SPARC glibc versions where the function was present in
|
|
|
|
* the library but not declared in the header file we will
|
|
|
|
* fail the configure check. (Otherwise we will get a compiler
|
|
|
|
* warning but not an error, and will proceed to fail the
|
|
|
|
* qemu compile where we compile with -Werror.)
|
|
|
|
*/
|
2012-08-10 00:21:25 +04:00
|
|
|
return (int)(uintptr_t)&epoll_create1;
|
2011-02-15 21:35:05 +03:00
|
|
|
}
|
|
|
|
EOF
|
2012-04-04 20:03:15 +04:00
|
|
|
if compile_prog "" "" ; then
|
2011-02-15 21:35:05 +03:00
|
|
|
epoll_create1=yes
|
|
|
|
fi
|
|
|
|
|
2013-02-08 11:31:55 +04:00
|
|
|
# check for sendfile support
|
|
|
|
sendfile=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <sys/sendfile.h>
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
return sendfile(0, 0, 0, 0);
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
sendfile=yes
|
|
|
|
fi
|
|
|
|
|
2014-06-22 14:25:42 +04:00
|
|
|
# check for timerfd support (glibc 2.8 and newer)
|
|
|
|
timerfd=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <sys/timerfd.h>
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
return(timerfd_create(CLOCK_REALTIME, 0));
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
timerfd=yes
|
|
|
|
fi
|
|
|
|
|
2014-08-12 16:58:57 +04:00
|
|
|
# check for setns and unshare support
|
|
|
|
setns=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <sched.h>
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
int ret;
|
|
|
|
ret = setns(0, 0);
|
|
|
|
ret = unshare(0);
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
setns=yes
|
|
|
|
fi
|
|
|
|
|
2016-10-10 14:23:29 +03:00
|
|
|
# clock_adjtime probe
|
|
|
|
clock_adjtime=no
|
|
|
|
cat > $TMPC <<EOF
|
|
|
|
#include <time.h>
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
return clock_adjtime(0, 0);
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
clock_adjtime=no
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
clock_adjtime=yes
|
|
|
|
fi
|
|
|
|
|
2016-10-10 14:23:30 +03:00
|
|
|
# syncfs probe
|
|
|
|
syncfs=no
|
|
|
|
cat > $TMPC <<EOF
|
|
|
|
#include <unistd.h>
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
return syncfs(0);
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
syncfs=no
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
syncfs=yes
|
|
|
|
fi
|
|
|
|
|
2009-10-11 14:44:07 +04:00
|
|
|
# Search for bswap_32 function
|
2009-08-03 16:45:58 +04:00
|
|
|
byteswap_h=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <byteswap.h>
|
|
|
|
int main(void) { return bswap_32(0); }
|
|
|
|
EOF
|
2009-08-03 16:46:03 +04:00
|
|
|
if compile_prog "" "" ; then
|
2009-08-03 16:45:58 +04:00
|
|
|
byteswap_h=yes
|
|
|
|
fi
|
|
|
|
|
2013-01-05 15:17:38 +04:00
|
|
|
# Search for bswap32 function
|
2009-08-03 16:45:58 +04:00
|
|
|
bswap_h=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <sys/endian.h>
|
|
|
|
#include <sys/types.h>
|
|
|
|
#include <machine/bswap.h>
|
|
|
|
int main(void) { return bswap32(0); }
|
|
|
|
EOF
|
2009-08-03 16:46:03 +04:00
|
|
|
if compile_prog "" "" ; then
|
2009-08-03 16:45:58 +04:00
|
|
|
bswap_h=yes
|
|
|
|
fi
|
|
|
|
|
2008-12-12 23:02:52 +03:00
|
|
|
##########################################
|
|
|
|
# Do we need librt
|
2012-09-12 13:06:51 +04:00
|
|
|
# uClibc provides 2 versions of clock_gettime(), one with realtime
|
|
|
|
# support and one without. This means that the clock_gettime() don't
|
|
|
|
# need -lrt. We still need it for timer_create() so we check for this
|
|
|
|
# function in addition.
|
2008-12-12 23:02:52 +03:00
|
|
|
cat > $TMPC <<EOF
|
|
|
|
#include <signal.h>
|
|
|
|
#include <time.h>
|
2012-09-12 13:06:51 +04:00
|
|
|
int main(void) {
|
|
|
|
timer_create(CLOCK_REALTIME, NULL, NULL);
|
|
|
|
return clock_gettime(CLOCK_REALTIME, NULL);
|
|
|
|
}
|
2008-12-12 23:02:52 +03:00
|
|
|
EOF
|
|
|
|
|
2009-08-03 16:46:03 +04:00
|
|
|
if compile_prog "" "" ; then
|
2009-08-03 16:46:17 +04:00
|
|
|
:
|
2012-09-12 13:06:51 +04:00
|
|
|
# we need pthread for static linking. use previous pthread test result
|
2014-05-31 01:10:20 +04:00
|
|
|
elif compile_prog "" "$pthread_lib -lrt" ; then
|
|
|
|
LIBS="$LIBS -lrt"
|
2008-12-12 23:02:52 +03:00
|
|
|
fi
|
|
|
|
|
2020-09-01 13:28:38 +03:00
|
|
|
# Check whether we have openpty() in either libc or libutil
|
configure: Add a proper check for openpty() in libutil
On Linux (and maybe some BSDs), we require libutil for the openpty()
function. However, this library is not available on some other systems, so
we currently use a fragile if-statement in the configure script to check
whether we need the library or not. Unfortunately, we also hard-coded a
"-lutil" in the tests/Makefile.include file, so this breaks the build on
Solaris, for example (see buglink below). To fix the issue, add the "-lutil"
to "libs_tools" in the configure script instead, then this gets properly
propagated to the tests, too.
And while we're at it, also replace the fragile if-statement in the confi-
gure script with a proper link-check for the availability of this function.
Buglink: https://bugs.launchpad.net/qemu/+bug/1777252
Signed-off-by: Thomas Huth <thuth@redhat.com>
Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com>
Tested-by: Philippe Mathieu-Daudé <philmd@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
2019-01-17 20:14:08 +03:00
|
|
|
cat > $TMPC << EOF
|
|
|
|
extern int openpty(int *am, int *as, char *name, void *termp, void *winp);
|
|
|
|
int main(void) { return openpty(0, 0, 0, 0, 0); }
|
|
|
|
EOF
|
|
|
|
|
2020-06-29 15:13:24 +03:00
|
|
|
have_openpty="no"
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
have_openpty="yes"
|
|
|
|
else
|
configure: Add a proper check for openpty() in libutil
On Linux (and maybe some BSDs), we require libutil for the openpty()
function. However, this library is not available on some other systems, so
we currently use a fragile if-statement in the configure script to check
whether we need the library or not. Unfortunately, we also hard-coded a
"-lutil" in the tests/Makefile.include file, so this breaks the build on
Solaris, for example (see buglink below). To fix the issue, add the "-lutil"
to "libs_tools" in the configure script instead, then this gets properly
propagated to the tests, too.
And while we're at it, also replace the fragile if-statement in the confi-
gure script with a proper link-check for the availability of this function.
Buglink: https://bugs.launchpad.net/qemu/+bug/1777252
Signed-off-by: Thomas Huth <thuth@redhat.com>
Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com>
Tested-by: Philippe Mathieu-Daudé <philmd@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
2019-01-17 20:14:08 +03:00
|
|
|
if compile_prog "" "-lutil" ; then
|
2020-06-29 15:13:24 +03:00
|
|
|
have_openpty="yes"
|
configure: Add a proper check for openpty() in libutil
On Linux (and maybe some BSDs), we require libutil for the openpty()
function. However, this library is not available on some other systems, so
we currently use a fragile if-statement in the configure script to check
whether we need the library or not. Unfortunately, we also hard-coded a
"-lutil" in the tests/Makefile.include file, so this breaks the build on
Solaris, for example (see buglink below). To fix the issue, add the "-lutil"
to "libs_tools" in the configure script instead, then this gets properly
propagated to the tests, too.
And while we're at it, also replace the fragile if-statement in the confi-
gure script with a proper link-check for the availability of this function.
Buglink: https://bugs.launchpad.net/qemu/+bug/1777252
Signed-off-by: Thomas Huth <thuth@redhat.com>
Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com>
Tested-by: Philippe Mathieu-Daudé <philmd@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
2019-01-17 20:14:08 +03:00
|
|
|
fi
|
2009-08-03 16:46:32 +04:00
|
|
|
fi
|
|
|
|
|
2009-09-12 13:58:46 +04:00
|
|
|
##########################################
|
2010-03-24 12:26:51 +03:00
|
|
|
# spice probe
|
|
|
|
if test "$spice" != "no" ; then
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <spice.h>
|
|
|
|
int main(void) { spice_server_new(); return 0; }
|
|
|
|
EOF
|
2011-01-24 15:20:29 +03:00
|
|
|
spice_cflags=$($pkg_config --cflags spice-protocol spice-server 2>/dev/null)
|
|
|
|
spice_libs=$($pkg_config --libs spice-protocol spice-server 2>/dev/null)
|
2018-11-28 18:59:32 +03:00
|
|
|
if $pkg_config --atleast-version=0.12.5 spice-server && \
|
2013-08-27 23:09:13 +04:00
|
|
|
$pkg_config --atleast-version=0.12.3 spice-protocol && \
|
2010-03-24 12:26:51 +03:00
|
|
|
compile_prog "$spice_cflags" "$spice_libs" ; then
|
|
|
|
spice="yes"
|
|
|
|
else
|
|
|
|
if test "$spice" = "yes" ; then
|
2014-06-26 13:34:50 +04:00
|
|
|
feature_not_found "spice" \
|
2018-11-28 18:59:32 +03:00
|
|
|
"Install spice-server(>=0.12.5) and spice-protocol(>=0.12.3) devel"
|
2010-03-24 12:26:51 +03:00
|
|
|
fi
|
|
|
|
spice="no"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2015-08-30 12:48:40 +03:00
|
|
|
# check for smartcard support
|
|
|
|
if test "$smartcard" != "no"; then
|
2018-04-03 13:34:37 +03:00
|
|
|
if $pkg_config --atleast-version=2.5.1 libcacard; then
|
2015-08-30 12:48:40 +03:00
|
|
|
libcacard_cflags=$($pkg_config --cflags libcacard)
|
|
|
|
libcacard_libs=$($pkg_config --libs libcacard)
|
|
|
|
smartcard="yes"
|
2012-12-20 23:39:36 +04:00
|
|
|
else
|
2015-08-30 12:48:40 +03:00
|
|
|
if test "$smartcard" = "yes"; then
|
|
|
|
feature_not_found "smartcard" "Install libcacard devel"
|
libcacard: initial commit
libcacard emulates a Common Access Card (CAC) which is a standard
for smartcards. It is used by the emulated ccid card introduced in
a following patch. Docs are available in docs/libcacard.txt
Signed-off-by: Alon Levy <alevy@redhat.com>
---
changes from v24->v25:
* Fix out of tree builds.
* Fix build with linux-user targets.
changes from v23->v24: (Jes Sorensen review 2)
* Makefile.target: use obj-$(CONFIG_*) +=
* remove unrequired includes, include qemu-common before qemu-thread
* required adding #define NO_NSPR_10_SUPPORT (harmless)
changes from v22->v23:
* configure fixes: (reported by Stefan Hajnoczi)
* test a = b, not a == b (second isn't portable)
* quote $source_path in case it contains spaces
- this doesn't really help since there are many other places
that need similar fixes, not introduced by this patch.
changes from v21->v22:
* fix configure to not link libcacard if nss not found
(reported by Stefan Hajnoczi)
* fix vscclient linkage with simpletrace backend
(reported by Stefan Hajnoczi)
* card_7816.c: add missing break in ERROR_DATA_NOT_FOUND
(reported by William van de Velde)
changes from v20->v21: (Jes Sorensen review)
* use qemu infrastructure: qemu-thread, qemu-common (qemu_malloc
and qemu_free), error_report
* assert instead of ASSERT
* cosmetic fixes
* use strpbrk and isspace
* add --disable-nss --enable-nss here, instead of in the final patch.
* split vscclient, passthru and docs to following patches.
changes from v19->v20:
* checkpatch.pl
changes from v15->v16:
Build:
* don't erase self with distclean
* fix make clean after make distclean
* Makefile: make vscclient link quiet
Behavioral:
* vcard_emul_nss: load coolkey in more situations
* vscclient:
* use hton,ntoh
* send init on connect, only start vevent thread on response
* read payload after header check, before type switch
* remove Reconnect
* update for vscard_common changes, empty Flush implementation
Style/Whitespace:
* fix wrong variable usage
* remove unused variable
* use only C style comments
* add copyright header
* fix tabulation
Signed-off-by: Alon Levy <alevy@redhat.com>
libcacard: fix out of tree builds
2010-11-28 17:36:38 +03:00
|
|
|
fi
|
2015-08-30 12:48:40 +03:00
|
|
|
smartcard="no"
|
libcacard: initial commit
libcacard emulates a Common Access Card (CAC) which is a standard
for smartcards. It is used by the emulated ccid card introduced in
a following patch. Docs are available in docs/libcacard.txt
Signed-off-by: Alon Levy <alevy@redhat.com>
---
changes from v24->v25:
* Fix out of tree builds.
* Fix build with linux-user targets.
changes from v23->v24: (Jes Sorensen review 2)
* Makefile.target: use obj-$(CONFIG_*) +=
* remove unrequired includes, include qemu-common before qemu-thread
* required adding #define NO_NSPR_10_SUPPORT (harmless)
changes from v22->v23:
* configure fixes: (reported by Stefan Hajnoczi)
* test a = b, not a == b (second isn't portable)
* quote $source_path in case it contains spaces
- this doesn't really help since there are many other places
that need similar fixes, not introduced by this patch.
changes from v21->v22:
* fix configure to not link libcacard if nss not found
(reported by Stefan Hajnoczi)
* fix vscclient linkage with simpletrace backend
(reported by Stefan Hajnoczi)
* card_7816.c: add missing break in ERROR_DATA_NOT_FOUND
(reported by William van de Velde)
changes from v20->v21: (Jes Sorensen review)
* use qemu infrastructure: qemu-thread, qemu-common (qemu_malloc
and qemu_free), error_report
* assert instead of ASSERT
* cosmetic fixes
* use strpbrk and isspace
* add --disable-nss --enable-nss here, instead of in the final patch.
* split vscclient, passthru and docs to following patches.
changes from v19->v20:
* checkpatch.pl
changes from v15->v16:
Build:
* don't erase self with distclean
* fix make clean after make distclean
* Makefile: make vscclient link quiet
Behavioral:
* vcard_emul_nss: load coolkey in more situations
* vscclient:
* use hton,ntoh
* send init on connect, only start vevent thread on response
* read payload after header check, before type switch
* remove Reconnect
* update for vscard_common changes, empty Flush implementation
Style/Whitespace:
* fix wrong variable usage
* remove unused variable
* use only C style comments
* add copyright header
* fix tabulation
Signed-off-by: Alon Levy <alevy@redhat.com>
libcacard: fix out of tree builds
2010-11-28 17:36:38 +03:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2012-11-30 19:02:11 +04:00
|
|
|
# check for libusb
|
|
|
|
if test "$libusb" != "no" ; then
|
2013-08-27 23:09:13 +04:00
|
|
|
if $pkg_config --atleast-version=1.0.13 libusb-1.0; then
|
2012-11-30 19:02:11 +04:00
|
|
|
libusb="yes"
|
2013-08-27 23:09:12 +04:00
|
|
|
libusb_cflags=$($pkg_config --cflags libusb-1.0)
|
|
|
|
libusb_libs=$($pkg_config --libs libusb-1.0)
|
2012-11-30 19:02:11 +04:00
|
|
|
else
|
|
|
|
if test "$libusb" = "yes"; then
|
2014-06-26 13:34:50 +04:00
|
|
|
feature_not_found "libusb" "Install libusb devel >= 1.0.13"
|
2012-11-30 19:02:11 +04:00
|
|
|
fi
|
|
|
|
libusb="no"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2011-07-19 13:04:10 +04:00
|
|
|
# check for usbredirparser for usb network redirection support
|
|
|
|
if test "$usb_redir" != "no" ; then
|
2013-08-27 23:09:13 +04:00
|
|
|
if $pkg_config --atleast-version=0.6 libusbredirparser-0.5; then
|
2011-07-19 13:04:10 +04:00
|
|
|
usb_redir="yes"
|
2013-08-27 23:09:12 +04:00
|
|
|
usb_redir_cflags=$($pkg_config --cflags libusbredirparser-0.5)
|
|
|
|
usb_redir_libs=$($pkg_config --libs libusbredirparser-0.5)
|
2011-07-19 13:04:10 +04:00
|
|
|
else
|
|
|
|
if test "$usb_redir" = "yes"; then
|
2014-01-24 05:39:10 +04:00
|
|
|
feature_not_found "usb-redir" "Install usbredir devel"
|
2011-07-19 13:04:10 +04:00
|
|
|
fi
|
|
|
|
usb_redir="no"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2013-08-07 19:40:03 +04:00
|
|
|
##########################################
|
|
|
|
# check if we have VSS SDK headers for win
|
|
|
|
|
2019-02-05 05:39:37 +03:00
|
|
|
if test "$mingw32" = "yes" && test "$guest_agent" != "no" && \
|
|
|
|
test "$vss_win32_sdk" != "no" ; then
|
2013-08-07 19:40:03 +04:00
|
|
|
case "$vss_win32_sdk" in
|
configure: mark qemu-ga VSS includes as system headers
As of e4650c81, we do w32 builds with -Werror enabled. Unfortunately
for cases where we enable VSS support in qemu-ga, we still have
warnings generated by VSS includes that ship as part of the Microsoft
VSS SDK.
We can selectively address a number of these warnings using
#pragma GCC diagnostic ignored ...
but at least one of these:
warning: ‘typedef’ was ignored in this declaration
resulting from declarations of the form:
typedef struct Blah { ... };
does not provide a specific command-line/pragma option to disable
warnings of the sort.
To allow VSS builds to succeed, the next-best option is disabling
these warnings on a per-file basis. pragmas like #pragma GCC
system_header can be used to declare subsequent includes/declarations
as being exempt from normal warnings, but this must be done within
a header file.
Since we don't control the VSS SDK, we'd need to rely on a
intermediate header include to accomplish this, and
since different objects in the VSS link target rely on different
headers from the VSS SDK, this would become somewhat of a rat's nest
(though not totally unmanageable).
The next step up in granularity is just marking the entire VSS
SDK include path as system headers via -isystem. This is a bit more
heavy-handed, but since this SDK hasn't changed since 2005, there's
likely little to be gained from selectively disabling warnings
anyway, so we implement that approach here.
This fixes the -Werror failures in both the configure test and the
qga build due to shared reliance on $vss_win32_include. For the
same reason, this also enforces a new dependency on -isystem support
in the C/C++ compiler when building QGA with VSS enabled.
Cc: Thomas Huth <thuth@redhat.com>
Cc: Stefan Weil <sw@weilnetz.de>
Cc: Paolo Bonzini <pbonzini@redhat.com>
Reviewed-by: Thomas Huth <thuth@redhat.com>
Signed-off-by: Michael Roth <mdroth@linux.vnet.ibm.com>
2016-06-29 01:31:49 +03:00
|
|
|
"") vss_win32_include="-isystem $source_path" ;;
|
2013-08-07 19:40:03 +04:00
|
|
|
*\ *) # The SDK is installed in "Program Files" by default, but we cannot
|
|
|
|
# handle path with spaces. So we symlink the headers into ".sdk/vss".
|
configure: mark qemu-ga VSS includes as system headers
As of e4650c81, we do w32 builds with -Werror enabled. Unfortunately
for cases where we enable VSS support in qemu-ga, we still have
warnings generated by VSS includes that ship as part of the Microsoft
VSS SDK.
We can selectively address a number of these warnings using
#pragma GCC diagnostic ignored ...
but at least one of these:
warning: ‘typedef’ was ignored in this declaration
resulting from declarations of the form:
typedef struct Blah { ... };
does not provide a specific command-line/pragma option to disable
warnings of the sort.
To allow VSS builds to succeed, the next-best option is disabling
these warnings on a per-file basis. pragmas like #pragma GCC
system_header can be used to declare subsequent includes/declarations
as being exempt from normal warnings, but this must be done within
a header file.
Since we don't control the VSS SDK, we'd need to rely on a
intermediate header include to accomplish this, and
since different objects in the VSS link target rely on different
headers from the VSS SDK, this would become somewhat of a rat's nest
(though not totally unmanageable).
The next step up in granularity is just marking the entire VSS
SDK include path as system headers via -isystem. This is a bit more
heavy-handed, but since this SDK hasn't changed since 2005, there's
likely little to be gained from selectively disabling warnings
anyway, so we implement that approach here.
This fixes the -Werror failures in both the configure test and the
qga build due to shared reliance on $vss_win32_include. For the
same reason, this also enforces a new dependency on -isystem support
in the C/C++ compiler when building QGA with VSS enabled.
Cc: Thomas Huth <thuth@redhat.com>
Cc: Stefan Weil <sw@weilnetz.de>
Cc: Paolo Bonzini <pbonzini@redhat.com>
Reviewed-by: Thomas Huth <thuth@redhat.com>
Signed-off-by: Michael Roth <mdroth@linux.vnet.ibm.com>
2016-06-29 01:31:49 +03:00
|
|
|
vss_win32_include="-isystem $source_path/.sdk/vss"
|
2013-08-07 19:40:03 +04:00
|
|
|
symlink "$vss_win32_sdk/inc" "$source_path/.sdk/vss/inc"
|
|
|
|
;;
|
configure: mark qemu-ga VSS includes as system headers
As of e4650c81, we do w32 builds with -Werror enabled. Unfortunately
for cases where we enable VSS support in qemu-ga, we still have
warnings generated by VSS includes that ship as part of the Microsoft
VSS SDK.
We can selectively address a number of these warnings using
#pragma GCC diagnostic ignored ...
but at least one of these:
warning: ‘typedef’ was ignored in this declaration
resulting from declarations of the form:
typedef struct Blah { ... };
does not provide a specific command-line/pragma option to disable
warnings of the sort.
To allow VSS builds to succeed, the next-best option is disabling
these warnings on a per-file basis. pragmas like #pragma GCC
system_header can be used to declare subsequent includes/declarations
as being exempt from normal warnings, but this must be done within
a header file.
Since we don't control the VSS SDK, we'd need to rely on a
intermediate header include to accomplish this, and
since different objects in the VSS link target rely on different
headers from the VSS SDK, this would become somewhat of a rat's nest
(though not totally unmanageable).
The next step up in granularity is just marking the entire VSS
SDK include path as system headers via -isystem. This is a bit more
heavy-handed, but since this SDK hasn't changed since 2005, there's
likely little to be gained from selectively disabling warnings
anyway, so we implement that approach here.
This fixes the -Werror failures in both the configure test and the
qga build due to shared reliance on $vss_win32_include. For the
same reason, this also enforces a new dependency on -isystem support
in the C/C++ compiler when building QGA with VSS enabled.
Cc: Thomas Huth <thuth@redhat.com>
Cc: Stefan Weil <sw@weilnetz.de>
Cc: Paolo Bonzini <pbonzini@redhat.com>
Reviewed-by: Thomas Huth <thuth@redhat.com>
Signed-off-by: Michael Roth <mdroth@linux.vnet.ibm.com>
2016-06-29 01:31:49 +03:00
|
|
|
*) vss_win32_include="-isystem $vss_win32_sdk"
|
2013-08-07 19:40:03 +04:00
|
|
|
esac
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#define __MIDL_user_allocate_free_DEFINED__
|
|
|
|
#include <inc/win2003/vss.h>
|
|
|
|
int main(void) { return VSS_CTX_BACKUP; }
|
|
|
|
EOF
|
|
|
|
if compile_prog "$vss_win32_include" "" ; then
|
|
|
|
guest_agent_with_vss="yes"
|
|
|
|
QEMU_CFLAGS="$QEMU_CFLAGS $vss_win32_include"
|
2016-09-21 07:27:21 +03:00
|
|
|
libs_qga="-lole32 -loleaut32 -lshlwapi -lstdc++ -Wl,--enable-stdcall-fixup $libs_qga"
|
2015-08-27 00:19:41 +03:00
|
|
|
qga_vss_provider="qga/vss-win32/qga-vss.dll qga/vss-win32/qga-vss.tlb"
|
2013-08-07 19:40:03 +04:00
|
|
|
else
|
|
|
|
if test "$vss_win32_sdk" != "" ; then
|
|
|
|
echo "ERROR: Please download and install Microsoft VSS SDK:"
|
|
|
|
echo "ERROR: http://www.microsoft.com/en-us/download/details.aspx?id=23490"
|
|
|
|
echo "ERROR: On POSIX-systems, you can extract the SDK headers by:"
|
|
|
|
echo "ERROR: scripts/extract-vsssdk-headers setup.exe"
|
|
|
|
echo "ERROR: The headers are extracted in the directory \`inc'."
|
|
|
|
feature_not_found "VSS support"
|
|
|
|
fi
|
|
|
|
guest_agent_with_vss="no"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
##########################################
|
|
|
|
# lookup Windows platform SDK (if not specified)
|
|
|
|
# The SDK is needed only to build .tlb (type library) file of guest agent
|
|
|
|
# VSS provider from the source. It is usually unnecessary because the
|
|
|
|
# pre-compiled .tlb file is included.
|
|
|
|
|
2019-02-05 05:39:37 +03:00
|
|
|
if test "$mingw32" = "yes" && test "$guest_agent" != "no" && \
|
|
|
|
test "$guest_agent_with_vss" = "yes" ; then
|
2013-08-07 19:40:03 +04:00
|
|
|
if test -z "$win_sdk"; then
|
|
|
|
programfiles="$PROGRAMFILES"
|
|
|
|
test -n "$PROGRAMW6432" && programfiles="$PROGRAMW6432"
|
|
|
|
if test -n "$programfiles"; then
|
|
|
|
win_sdk=$(ls -d "$programfiles/Microsoft SDKs/Windows/v"* | tail -1) 2>/dev/null
|
|
|
|
else
|
|
|
|
feature_not_found "Windows SDK"
|
|
|
|
fi
|
|
|
|
elif test "$win_sdk" = "no"; then
|
|
|
|
win_sdk=""
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2015-07-08 02:10:09 +03:00
|
|
|
##########################################
|
|
|
|
# check if mingw environment provides a recent ntddscsi.h
|
2019-02-05 05:39:37 +03:00
|
|
|
if test "$mingw32" = "yes" && test "$guest_agent" != "no"; then
|
2015-07-08 02:10:09 +03:00
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <windows.h>
|
|
|
|
#include <ntddscsi.h>
|
|
|
|
int main(void) {
|
|
|
|
#if !defined(IOCTL_SCSI_GET_ADDRESS)
|
|
|
|
#error Missing required ioctl definitions
|
|
|
|
#endif
|
|
|
|
SCSI_ADDRESS addr = { .Lun = 0, .TargetId = 0, .PathId = 0 };
|
|
|
|
return addr.Lun;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
guest_agent_ntddscsi=yes
|
2019-01-29 01:30:56 +03:00
|
|
|
libs_qga="-lsetupapi -lcfgmgr32 $libs_qga"
|
2015-07-08 02:10:09 +03:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2014-07-11 14:51:43 +04:00
|
|
|
##########################################
|
|
|
|
# virgl renderer probe
|
|
|
|
|
|
|
|
if test "$virglrenderer" != "no" ; then
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <virglrenderer.h>
|
|
|
|
int main(void) { virgl_renderer_poll(); return 0; }
|
|
|
|
EOF
|
|
|
|
virgl_cflags=$($pkg_config --cflags virglrenderer 2>/dev/null)
|
|
|
|
virgl_libs=$($pkg_config --libs virglrenderer 2>/dev/null)
|
2018-05-25 18:36:09 +03:00
|
|
|
virgl_version=$($pkg_config --modversion virglrenderer 2>/dev/null)
|
2014-07-11 14:51:43 +04:00
|
|
|
if $pkg_config virglrenderer >/dev/null 2>&1 && \
|
|
|
|
compile_prog "$virgl_cflags" "$virgl_libs" ; then
|
|
|
|
virglrenderer="yes"
|
|
|
|
else
|
|
|
|
if test "$virglrenderer" = "yes" ; then
|
|
|
|
feature_not_found "virglrenderer"
|
|
|
|
fi
|
|
|
|
virglrenderer="no"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2017-09-14 19:41:12 +03:00
|
|
|
##########################################
|
|
|
|
# capstone
|
|
|
|
|
2017-09-28 19:01:23 +03:00
|
|
|
case "$capstone" in
|
2020-09-13 22:19:25 +03:00
|
|
|
auto | enabled | internal)
|
|
|
|
# Simpler to always update submodule, even if not needed.
|
|
|
|
if test -e "${source_path}/.git" && test $git_update = 'yes' ; then
|
2017-09-28 19:01:23 +03:00
|
|
|
git_submodules="${git_submodules} capstone"
|
|
|
|
fi
|
|
|
|
;;
|
|
|
|
esac
|
2017-09-14 19:41:12 +03:00
|
|
|
|
2009-09-20 10:56:26 +04:00
|
|
|
##########################################
|
|
|
|
# check if we have fdatasync
|
|
|
|
|
|
|
|
fdatasync=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <unistd.h>
|
2011-05-30 02:22:48 +04:00
|
|
|
int main(void) {
|
|
|
|
#if defined(_POSIX_SYNCHRONIZED_IO) && _POSIX_SYNCHRONIZED_IO > 0
|
|
|
|
return fdatasync(0);
|
|
|
|
#else
|
2012-04-06 23:33:20 +04:00
|
|
|
#error Not supported
|
2011-05-30 02:22:48 +04:00
|
|
|
#endif
|
|
|
|
}
|
2009-09-20 10:56:26 +04:00
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
fdatasync=yes
|
|
|
|
fi
|
|
|
|
|
2010-09-25 15:26:05 +04:00
|
|
|
##########################################
|
|
|
|
# check if we have madvise
|
|
|
|
|
|
|
|
madvise=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <sys/types.h>
|
|
|
|
#include <sys/mman.h>
|
2010-10-05 23:28:17 +04:00
|
|
|
#include <stddef.h>
|
2010-09-25 15:26:05 +04:00
|
|
|
int main(void) { return madvise(NULL, 0, MADV_DONTNEED); }
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
madvise=yes
|
|
|
|
fi
|
|
|
|
|
|
|
|
##########################################
|
|
|
|
# check if we have posix_madvise
|
|
|
|
|
|
|
|
posix_madvise=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <sys/mman.h>
|
2010-10-05 23:28:17 +04:00
|
|
|
#include <stddef.h>
|
2010-09-25 15:26:05 +04:00
|
|
|
int main(void) { return posix_madvise(NULL, 0, POSIX_MADV_DONTNEED); }
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
posix_madvise=yes
|
|
|
|
fi
|
|
|
|
|
2018-01-04 20:39:36 +03:00
|
|
|
##########################################
|
|
|
|
# check if we have posix_memalign()
|
|
|
|
|
|
|
|
posix_memalign=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <stdlib.h>
|
|
|
|
int main(void) {
|
|
|
|
void *p;
|
|
|
|
return posix_memalign(&p, 8, 8);
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
posix_memalign=yes
|
|
|
|
fi
|
|
|
|
|
2016-08-04 16:44:14 +03:00
|
|
|
##########################################
|
|
|
|
# check if we have posix_syslog
|
|
|
|
|
|
|
|
posix_syslog=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <syslog.h>
|
|
|
|
int main(void) { openlog("qemu", LOG_PID, LOG_DAEMON); syslog(LOG_INFO, "configure"); return 0; }
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
posix_syslog=yes
|
|
|
|
fi
|
|
|
|
|
2017-09-05 15:19:32 +03:00
|
|
|
##########################################
|
|
|
|
# check if we have sem_timedwait
|
|
|
|
|
|
|
|
sem_timedwait=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <semaphore.h>
|
2019-06-17 14:41:14 +03:00
|
|
|
int main(void) { sem_t s; struct timespec t = {0}; return sem_timedwait(&s, &t); }
|
2017-09-05 15:19:32 +03:00
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
sem_timedwait=yes
|
|
|
|
fi
|
|
|
|
|
2018-06-29 13:32:10 +03:00
|
|
|
##########################################
|
|
|
|
# check if we have strchrnul
|
|
|
|
|
|
|
|
strchrnul=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <string.h>
|
|
|
|
int main(void);
|
|
|
|
// Use a haystack that the compiler shouldn't be able to constant fold
|
|
|
|
char *haystack = (char*)&main;
|
|
|
|
int main(void) { return strchrnul(haystack, 'x') != &haystack[6]; }
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
strchrnul=yes
|
|
|
|
fi
|
|
|
|
|
2019-04-16 22:08:56 +03:00
|
|
|
#########################################
|
|
|
|
# check if we have st_atim
|
|
|
|
|
|
|
|
st_atim=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <sys/stat.h>
|
|
|
|
#include <stddef.h>
|
|
|
|
int main(void) { return offsetof(struct stat, st_atim); }
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
st_atim=yes
|
|
|
|
fi
|
|
|
|
|
2010-05-22 20:52:39 +04:00
|
|
|
##########################################
|
|
|
|
# check if trace backend exists
|
|
|
|
|
2014-05-27 17:02:14 +04:00
|
|
|
$python "$source_path/scripts/tracetool.py" "--backends=$trace_backends" --check-backends > /dev/null 2> /dev/null
|
2010-05-22 20:52:39 +04:00
|
|
|
if test "$?" -ne 0 ; then
|
2014-05-27 17:02:14 +04:00
|
|
|
error_exit "invalid trace backends" \
|
|
|
|
"Please choose supported trace backends."
|
2010-05-22 20:52:39 +04:00
|
|
|
fi
|
|
|
|
|
2010-05-23 00:11:33 +04:00
|
|
|
##########################################
|
|
|
|
# For 'ust' backend, test if ust headers are present
|
2014-05-27 17:02:14 +04:00
|
|
|
if have_backend "ust"; then
|
2010-05-23 00:11:33 +04:00
|
|
|
cat > $TMPC << EOF
|
2014-01-30 07:47:54 +04:00
|
|
|
#include <lttng/tracepoint.h>
|
2010-05-23 00:11:33 +04:00
|
|
|
int main(void) { return 0; }
|
|
|
|
EOF
|
2016-11-28 18:52:17 +03:00
|
|
|
if compile_prog "" "-Wl,--no-as-needed -ldl" ; then
|
2014-01-30 07:47:54 +04:00
|
|
|
if $pkg_config lttng-ust --exists; then
|
2016-05-16 16:10:20 +03:00
|
|
|
lttng_ust_libs=$($pkg_config --libs lttng-ust)
|
2014-01-30 07:47:54 +04:00
|
|
|
else
|
2016-11-28 18:52:17 +03:00
|
|
|
lttng_ust_libs="-llttng-ust -ldl"
|
2014-01-30 07:47:54 +04:00
|
|
|
fi
|
|
|
|
if $pkg_config liburcu-bp --exists; then
|
2016-05-16 16:10:20 +03:00
|
|
|
urcu_bp_libs=$($pkg_config --libs liburcu-bp)
|
2014-01-30 07:47:54 +04:00
|
|
|
else
|
|
|
|
urcu_bp_libs="-lurcu-bp"
|
|
|
|
fi
|
2010-05-23 00:11:33 +04:00
|
|
|
else
|
2014-01-30 07:47:54 +04:00
|
|
|
error_exit "Trace backend 'ust' missing lttng-ust header files"
|
2010-05-23 00:11:33 +04:00
|
|
|
fi
|
|
|
|
fi
|
2010-11-12 16:20:24 +03:00
|
|
|
|
|
|
|
##########################################
|
|
|
|
# For 'dtrace' backend, test if 'dtrace' command is present
|
2014-05-27 17:02:14 +04:00
|
|
|
if have_backend "dtrace"; then
|
2010-11-12 16:20:24 +03:00
|
|
|
if ! has 'dtrace' ; then
|
2013-04-08 15:11:26 +04:00
|
|
|
error_exit "dtrace command is not found in PATH $PATH"
|
2010-11-12 16:20:24 +03:00
|
|
|
fi
|
2010-11-12 16:20:25 +03:00
|
|
|
trace_backend_stap="no"
|
|
|
|
if has 'stap' ; then
|
|
|
|
trace_backend_stap="yes"
|
2020-11-19 17:14:57 +03:00
|
|
|
|
|
|
|
# Workaround to avoid dtrace(1) producing a file with 'hidden' symbol
|
|
|
|
# visibility. Define STAP_SDT_V2 to produce 'default' symbol visibility
|
|
|
|
# instead. QEMU --enable-modules depends on this because the SystemTap
|
|
|
|
# semaphores are linked into the main binary and not the module's shared
|
|
|
|
# object.
|
|
|
|
QEMU_CFLAGS="$QEMU_CFLAGS -DSTAP_SDT_V2"
|
2010-11-12 16:20:25 +03:00
|
|
|
fi
|
2010-11-12 16:20:24 +03:00
|
|
|
fi
|
|
|
|
|
2011-07-11 16:57:43 +04:00
|
|
|
##########################################
|
2012-02-28 15:25:50 +04:00
|
|
|
# check and set a backend for coroutine
|
2011-06-09 21:41:06 +04:00
|
|
|
|
2013-04-08 15:11:27 +04:00
|
|
|
# We prefer ucontext, but it's not always possible. The fallback
|
2017-04-28 15:24:44 +03:00
|
|
|
# is sigcontext. On Windows the only valid backend is the Windows
|
|
|
|
# specific one.
|
2013-04-08 15:11:27 +04:00
|
|
|
|
|
|
|
ucontext_works=no
|
|
|
|
if test "$darwin" != "yes"; then
|
|
|
|
cat > $TMPC << EOF
|
2011-06-09 21:41:06 +04:00
|
|
|
#include <ucontext.h>
|
2012-02-23 20:20:05 +04:00
|
|
|
#ifdef __stub_makecontext
|
|
|
|
#error Ignoring glibc stub makecontext which will always fail
|
|
|
|
#endif
|
2011-12-17 12:27:29 +04:00
|
|
|
int main(void) { makecontext(0, 0, 0); return 0; }
|
2011-06-09 21:41:06 +04:00
|
|
|
EOF
|
2013-04-08 15:11:27 +04:00
|
|
|
if compile_prog "" "" ; then
|
|
|
|
ucontext_works=yes
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
if test "$coroutine" = ""; then
|
|
|
|
if test "$mingw32" = "yes"; then
|
|
|
|
coroutine=win32
|
|
|
|
elif test "$ucontext_works" = "yes"; then
|
|
|
|
coroutine=ucontext
|
|
|
|
else
|
|
|
|
coroutine=sigaltstack
|
2011-06-09 21:41:06 +04:00
|
|
|
fi
|
2012-02-28 15:25:50 +04:00
|
|
|
else
|
2013-04-08 15:11:27 +04:00
|
|
|
case $coroutine in
|
|
|
|
windows)
|
|
|
|
if test "$mingw32" != "yes"; then
|
|
|
|
error_exit "'windows' coroutine backend only valid for Windows"
|
|
|
|
fi
|
|
|
|
# Unfortunately the user visible backend name doesn't match the
|
|
|
|
# coroutine-*.c filename for this case, so we have to adjust it here.
|
|
|
|
coroutine=win32
|
|
|
|
;;
|
|
|
|
ucontext)
|
|
|
|
if test "$ucontext_works" != "yes"; then
|
|
|
|
feature_not_found "ucontext"
|
|
|
|
fi
|
|
|
|
;;
|
2017-04-28 15:24:44 +03:00
|
|
|
sigaltstack)
|
2013-04-08 15:11:27 +04:00
|
|
|
if test "$mingw32" = "yes"; then
|
|
|
|
error_exit "only the 'windows' coroutine backend is valid for Windows"
|
|
|
|
fi
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
error_exit "unknown coroutine backend $coroutine"
|
|
|
|
;;
|
|
|
|
esac
|
2011-06-09 21:41:06 +04:00
|
|
|
fi
|
|
|
|
|
2013-09-11 18:42:35 +04:00
|
|
|
if test "$coroutine_pool" = ""; then
|
2017-04-28 15:24:44 +03:00
|
|
|
coroutine_pool=yes
|
2013-09-11 18:42:35 +04:00
|
|
|
fi
|
|
|
|
|
2016-09-27 12:58:45 +03:00
|
|
|
if test "$debug_stack_usage" = "yes"; then
|
|
|
|
if test "$coroutine_pool" = "yes"; then
|
|
|
|
echo "WARN: disabling coroutine pool for stack usage debugging"
|
|
|
|
coroutine_pool=no
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2020-05-29 23:51:21 +03:00
|
|
|
##################################################
|
|
|
|
# SafeStack
|
|
|
|
|
|
|
|
|
|
|
|
if test "$safe_stack" = "yes"; then
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
int main(int argc, char *argv[])
|
|
|
|
{
|
|
|
|
#if ! __has_feature(safe_stack)
|
|
|
|
#error SafeStack Disabled
|
|
|
|
#endif
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
flag="-fsanitize=safe-stack"
|
|
|
|
# Check that safe-stack is supported and enabled.
|
|
|
|
if compile_prog "-Werror $flag" "$flag"; then
|
|
|
|
# Flag needed both at compilation and at linking
|
|
|
|
QEMU_CFLAGS="$QEMU_CFLAGS $flag"
|
|
|
|
QEMU_LDFLAGS="$QEMU_LDFLAGS $flag"
|
|
|
|
else
|
|
|
|
error_exit "SafeStack not supported by your compiler"
|
|
|
|
fi
|
|
|
|
if test "$coroutine" != "ucontext"; then
|
|
|
|
error_exit "SafeStack is only supported by the coroutine backend ucontext"
|
|
|
|
fi
|
|
|
|
else
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
int main(int argc, char *argv[])
|
|
|
|
{
|
|
|
|
#if defined(__has_feature)
|
|
|
|
#if __has_feature(safe_stack)
|
|
|
|
#error SafeStack Enabled
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if test "$safe_stack" = "no"; then
|
|
|
|
# Make sure that safe-stack is disabled
|
|
|
|
if ! compile_prog "-Werror" ""; then
|
|
|
|
# SafeStack was already enabled, try to explicitly remove the feature
|
|
|
|
flag="-fno-sanitize=safe-stack"
|
|
|
|
if ! compile_prog "-Werror $flag" "$flag"; then
|
|
|
|
error_exit "Configure cannot disable SafeStack"
|
|
|
|
fi
|
|
|
|
QEMU_CFLAGS="$QEMU_CFLAGS $flag"
|
|
|
|
QEMU_LDFLAGS="$QEMU_LDFLAGS $flag"
|
|
|
|
fi
|
|
|
|
else # "$safe_stack" = ""
|
|
|
|
# Set safe_stack to yes or no based on pre-existing flags
|
|
|
|
if compile_prog "-Werror" ""; then
|
|
|
|
safe_stack="no"
|
|
|
|
else
|
|
|
|
safe_stack="yes"
|
|
|
|
if test "$coroutine" != "ucontext"; then
|
|
|
|
error_exit "SafeStack is only supported by the coroutine backend ucontext"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
fi
|
2016-09-27 12:58:45 +03:00
|
|
|
|
2011-10-12 17:41:24 +04:00
|
|
|
##########################################
|
|
|
|
# check if we have open_by_handle_at
|
|
|
|
|
2012-06-19 00:11:06 +04:00
|
|
|
open_by_handle_at=no
|
2011-10-12 17:41:24 +04:00
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <fcntl.h>
|
2012-06-06 23:35:57 +04:00
|
|
|
#if !defined(AT_EMPTY_PATH)
|
|
|
|
# error missing definition
|
|
|
|
#else
|
2011-12-17 12:27:29 +04:00
|
|
|
int main(void) { struct file_handle fh; return open_by_handle_at(0, &fh, 0); }
|
2012-06-06 23:35:57 +04:00
|
|
|
#endif
|
2011-10-12 17:41:24 +04:00
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
open_by_handle_at=yes
|
|
|
|
fi
|
|
|
|
|
2011-10-12 17:41:25 +04:00
|
|
|
########################################
|
|
|
|
# check if we have linux/magic.h
|
|
|
|
|
|
|
|
linux_magic_h=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <linux/magic.h>
|
|
|
|
int main(void) {
|
2011-12-17 12:27:29 +04:00
|
|
|
return 0;
|
2011-10-12 17:41:25 +04:00
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
linux_magic_h=yes
|
|
|
|
fi
|
|
|
|
|
2012-06-29 15:40:27 +04:00
|
|
|
########################################
|
2014-09-25 23:07:54 +04:00
|
|
|
# check if we have valgrind/valgrind.h
|
2012-06-29 15:40:27 +04:00
|
|
|
|
|
|
|
valgrind_h=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <valgrind/valgrind.h>
|
|
|
|
int main(void) {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
valgrind_h=yes
|
|
|
|
fi
|
|
|
|
|
2012-05-23 22:48:04 +04:00
|
|
|
########################################
|
|
|
|
# check if environ is declared
|
|
|
|
|
|
|
|
has_environ=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <unistd.h>
|
|
|
|
int main(void) {
|
2012-08-10 00:21:25 +04:00
|
|
|
environ = 0;
|
2012-05-23 22:48:04 +04:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
has_environ=yes
|
|
|
|
fi
|
|
|
|
|
2012-12-29 02:17:02 +04:00
|
|
|
########################################
|
|
|
|
# check if cpuid.h is usable.
|
|
|
|
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <cpuid.h>
|
|
|
|
int main(void) {
|
2014-02-20 23:42:53 +04:00
|
|
|
unsigned a, b, c, d;
|
|
|
|
int max = __get_cpuid_max(0, 0);
|
|
|
|
|
|
|
|
if (max >= 1) {
|
|
|
|
__cpuid(1, a, b, c, d);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (max >= 7) {
|
|
|
|
__cpuid_count(7, 0, a, b, c, d);
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
2012-12-29 02:17:02 +04:00
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
cpuid_h=yes
|
|
|
|
fi
|
|
|
|
|
2017-07-19 07:40:18 +03:00
|
|
|
##########################################
|
|
|
|
# avx2 optimization requirement check
|
|
|
|
#
|
|
|
|
# There is no point enabling this if cpuid.h is not usable,
|
|
|
|
# since we won't be able to select the new routines.
|
|
|
|
|
2019-02-05 05:39:37 +03:00
|
|
|
if test "$cpuid_h" = "yes" && test "$avx2_opt" != "no"; then
|
2017-07-19 07:40:18 +03:00
|
|
|
cat > $TMPC << EOF
|
|
|
|
#pragma GCC push_options
|
|
|
|
#pragma GCC target("avx2")
|
|
|
|
#include <cpuid.h>
|
|
|
|
#include <immintrin.h>
|
|
|
|
static int bar(void *a) {
|
|
|
|
__m256i x = *(__m256i *)a;
|
|
|
|
return _mm256_testz_si256(x, x);
|
|
|
|
}
|
|
|
|
int main(int argc, char *argv[]) { return bar(argv[0]); }
|
|
|
|
EOF
|
|
|
|
if compile_object "" ; then
|
|
|
|
avx2_opt="yes"
|
2018-10-19 23:38:59 +03:00
|
|
|
else
|
|
|
|
avx2_opt="no"
|
2017-07-19 07:40:18 +03:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2020-02-29 15:34:34 +03:00
|
|
|
##########################################
|
|
|
|
# avx512f optimization requirement check
|
|
|
|
#
|
|
|
|
# There is no point enabling this if cpuid.h is not usable,
|
|
|
|
# since we won't be able to select the new routines.
|
|
|
|
# by default, it is turned off.
|
|
|
|
# if user explicitly want to enable it, check environment
|
|
|
|
|
|
|
|
if test "$cpuid_h" = "yes" && test "$avx512f_opt" = "yes"; then
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#pragma GCC push_options
|
|
|
|
#pragma GCC target("avx512f")
|
|
|
|
#include <cpuid.h>
|
|
|
|
#include <immintrin.h>
|
|
|
|
static int bar(void *a) {
|
|
|
|
__m512i x = *(__m512i *)a;
|
|
|
|
return _mm512_test_epi64_mask(x, x);
|
|
|
|
}
|
|
|
|
int main(int argc, char *argv[])
|
|
|
|
{
|
|
|
|
return bar(argv[0]);
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if ! compile_object "" ; then
|
|
|
|
avx512f_opt="no"
|
|
|
|
fi
|
|
|
|
else
|
|
|
|
avx512f_opt="no"
|
|
|
|
fi
|
|
|
|
|
2013-02-17 00:46:59 +04:00
|
|
|
########################################
|
|
|
|
# check if __[u]int128_t is usable.
|
|
|
|
|
|
|
|
int128=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
__int128_t a;
|
|
|
|
__uint128_t b;
|
|
|
|
int main (void) {
|
|
|
|
a = a + b;
|
|
|
|
b = a * b;
|
2013-06-21 17:01:31 +04:00
|
|
|
a = a * a;
|
2013-02-17 00:46:59 +04:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
int128=yes
|
|
|
|
fi
|
2012-12-29 02:17:02 +04:00
|
|
|
|
2016-06-30 07:10:59 +03:00
|
|
|
#########################################
|
|
|
|
# See if 128-bit atomic operations are supported.
|
|
|
|
|
|
|
|
atomic128=no
|
|
|
|
if test "$int128" = "yes"; then
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
unsigned __int128 x = 0, y = 0;
|
|
|
|
y = __atomic_load_16(&x, 0);
|
|
|
|
__atomic_store_16(&x, y, 0);
|
|
|
|
__atomic_compare_exchange_16(&x, &y, x, 0, 0, 0);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
atomic128=yes
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2018-08-16 02:31:47 +03:00
|
|
|
cmpxchg128=no
|
2019-02-05 05:39:37 +03:00
|
|
|
if test "$int128" = yes && test "$atomic128" = no; then
|
2018-08-16 02:31:47 +03:00
|
|
|
cat > $TMPC << EOF
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
unsigned __int128 x = 0, y = 0;
|
|
|
|
__sync_val_compare_and_swap_16(&x, y, x);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
cmpxchg128=yes
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2016-09-02 22:23:57 +03:00
|
|
|
#########################################
|
|
|
|
# See if 64-bit atomic operations are supported.
|
|
|
|
# Note that without __atomic builtins, we can only
|
|
|
|
# assume atomic loads/stores max at pointer size.
|
|
|
|
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <stdint.h>
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
uint64_t x = 0, y = 0;
|
|
|
|
#ifdef __ATOMIC_RELAXED
|
2020-07-16 13:23:48 +03:00
|
|
|
y = __atomic_load_n(&x, __ATOMIC_RELAXED);
|
|
|
|
__atomic_store_n(&x, y, __ATOMIC_RELAXED);
|
|
|
|
__atomic_compare_exchange_n(&x, &y, x, 0, __ATOMIC_RELAXED, __ATOMIC_RELAXED);
|
|
|
|
__atomic_exchange_n(&x, y, __ATOMIC_RELAXED);
|
|
|
|
__atomic_fetch_add(&x, y, __ATOMIC_RELAXED);
|
2016-09-02 22:23:57 +03:00
|
|
|
#else
|
|
|
|
typedef char is_host64[sizeof(void *) >= sizeof(uint64_t) ? 1 : -1];
|
|
|
|
__sync_lock_test_and_set(&x, y);
|
|
|
|
__sync_val_compare_and_swap(&x, y, 0);
|
|
|
|
__sync_fetch_and_add(&x, y);
|
|
|
|
#endif
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
atomic64=yes
|
|
|
|
fi
|
|
|
|
|
2018-10-21 20:56:29 +03:00
|
|
|
#########################################
|
|
|
|
# See if --dynamic-list is supported by the linker
|
|
|
|
ld_dynamic_list="no"
|
|
|
|
if test "$static" = "no" ; then
|
|
|
|
cat > $TMPTXT <<EOF
|
|
|
|
{
|
|
|
|
foo;
|
|
|
|
};
|
|
|
|
EOF
|
|
|
|
|
|
|
|
cat > $TMPC <<EOF
|
|
|
|
#include <stdio.h>
|
|
|
|
void foo(void);
|
|
|
|
|
|
|
|
void foo(void)
|
|
|
|
{
|
|
|
|
printf("foo\n");
|
|
|
|
}
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
foo();
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
|
|
|
|
if compile_prog "" "-Wl,--dynamic-list=$TMPTXT" ; then
|
|
|
|
ld_dynamic_list="yes"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
#########################################
|
|
|
|
# See if -exported_symbols_list is supported by the linker
|
|
|
|
|
|
|
|
ld_exported_symbols_list="no"
|
|
|
|
if test "$static" = "no" ; then
|
|
|
|
cat > $TMPTXT <<EOF
|
|
|
|
_foo
|
|
|
|
EOF
|
|
|
|
|
|
|
|
if compile_prog "" "-Wl,-exported_symbols_list,$TMPTXT" ; then
|
|
|
|
ld_exported_symbols_list="yes"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
if test "$plugins" = "yes" &&
|
|
|
|
test "$ld_dynamic_list" = "no" &&
|
|
|
|
test "$ld_exported_symbols_list" = "no" ; then
|
|
|
|
error_exit \
|
|
|
|
"Plugin support requires dynamic linking and specifying a set of symbols " \
|
|
|
|
"that are exported to plugins. Unfortunately your linker doesn't " \
|
|
|
|
"support the flag (--dynamic-list or -exported_symbols_list) used " \
|
|
|
|
"for this purpose. You can't build with --static."
|
|
|
|
fi
|
|
|
|
|
2019-10-14 02:12:19 +03:00
|
|
|
########################################
|
|
|
|
# See if __attribute__((alias)) is supported.
|
|
|
|
# This false for Xcode 9, but has been remedied for Xcode 10.
|
|
|
|
# Unfortunately, travis uses Xcode 9 by default.
|
|
|
|
|
|
|
|
attralias=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
int x = 1;
|
|
|
|
extern const int y __attribute__((alias("x")));
|
|
|
|
int main(void) { return 0; }
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
attralias=yes
|
|
|
|
fi
|
|
|
|
|
2013-02-18 21:11:15 +04:00
|
|
|
########################################
|
|
|
|
# check if getauxval is available.
|
|
|
|
|
|
|
|
getauxval=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <sys/auxv.h>
|
|
|
|
int main(void) {
|
|
|
|
return getauxval(AT_HWCAP) == 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
getauxval=yes
|
|
|
|
fi
|
|
|
|
|
2015-03-26 01:57:39 +03:00
|
|
|
########################################
|
|
|
|
# check if ccache is interfering with
|
|
|
|
# semantic analysis of macros
|
|
|
|
|
2015-10-28 20:56:40 +03:00
|
|
|
unset CCACHE_CPP2
|
2015-03-26 01:57:39 +03:00
|
|
|
ccache_cpp2=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
static const int Z = 1;
|
|
|
|
#define fn() ({ Z; })
|
|
|
|
#define TAUT(X) ((X) == Z)
|
|
|
|
#define PAREN(X, Y) (X == Y)
|
|
|
|
#define ID(X) (X)
|
|
|
|
int main(int argc, char *argv[])
|
|
|
|
{
|
|
|
|
int x = 0, y = 0;
|
|
|
|
x = ID(x);
|
|
|
|
x = fn();
|
|
|
|
fn();
|
|
|
|
if (PAREN(x, y)) return 0;
|
|
|
|
if (TAUT(Z)) return 0;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
|
|
|
|
if ! compile_object "-Werror"; then
|
|
|
|
ccache_cpp2=yes
|
|
|
|
fi
|
|
|
|
|
2015-11-03 23:43:42 +03:00
|
|
|
#################################################
|
|
|
|
# clang does not support glibc + FORTIFY_SOURCE.
|
|
|
|
|
|
|
|
if test "$fortify_source" != "no"; then
|
|
|
|
if echo | $cc -dM -E - | grep __clang__ > /dev/null 2>&1 ; then
|
|
|
|
fortify_source="no";
|
2017-06-26 18:25:24 +03:00
|
|
|
elif test -n "$cxx" && has $cxx &&
|
2015-11-12 19:29:49 +03:00
|
|
|
echo | $cxx -dM -E - | grep __clang__ >/dev/null 2>&1 ; then
|
2015-11-03 23:43:42 +03:00
|
|
|
fortify_source="no";
|
|
|
|
else
|
|
|
|
fortify_source="yes"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2018-06-01 12:26:43 +03:00
|
|
|
###############################################
|
|
|
|
# Check if copy_file_range is provided by glibc
|
|
|
|
have_copy_file_range=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <unistd.h>
|
|
|
|
int main(void) {
|
|
|
|
copy_file_range(0, NULL, 0, NULL, 0, 0);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
have_copy_file_range=yes
|
|
|
|
fi
|
|
|
|
|
2016-04-29 20:15:23 +03:00
|
|
|
##########################################
|
|
|
|
# check if struct fsxattr is available via linux/fs.h
|
|
|
|
|
|
|
|
have_fsxattr=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <linux/fs.h>
|
|
|
|
struct fsxattr foo;
|
|
|
|
int main(void) {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
have_fsxattr=yes
|
|
|
|
fi
|
|
|
|
|
2018-02-16 12:05:23 +03:00
|
|
|
##########################################
|
|
|
|
# check for usable membarrier system call
|
|
|
|
if test "$membarrier" = "yes"; then
|
|
|
|
have_membarrier=no
|
|
|
|
if test "$mingw32" = "yes" ; then
|
|
|
|
have_membarrier=yes
|
|
|
|
elif test "$linux" = "yes" ; then
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <linux/membarrier.h>
|
|
|
|
#include <sys/syscall.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
int main(void) {
|
|
|
|
syscall(__NR_membarrier, MEMBARRIER_CMD_QUERY, 0);
|
|
|
|
syscall(__NR_membarrier, MEMBARRIER_CMD_SHARED, 0);
|
|
|
|
exit(0);
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
have_membarrier=yes
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
if test "$have_membarrier" = "no"; then
|
|
|
|
feature_not_found "membarrier" "membarrier system call not available"
|
|
|
|
fi
|
|
|
|
else
|
|
|
|
# Do not enable it by default even for Mingw32, because it doesn't
|
|
|
|
# work on Wine.
|
|
|
|
membarrier=no
|
|
|
|
fi
|
|
|
|
|
2016-06-08 20:34:32 +03:00
|
|
|
##########################################
|
|
|
|
# check if rtnetlink.h exists and is useful
|
2016-06-02 23:14:15 +03:00
|
|
|
have_rtnetlink=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <linux/rtnetlink.h>
|
|
|
|
int main(void) {
|
|
|
|
return IFLA_PROTO_DOWN;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
have_rtnetlink=yes
|
|
|
|
fi
|
|
|
|
|
2016-10-14 12:00:55 +03:00
|
|
|
##########################################
|
|
|
|
# check for usable AF_VSOCK environment
|
|
|
|
have_af_vsock=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <errno.h>
|
|
|
|
#include <sys/types.h>
|
|
|
|
#include <sys/socket.h>
|
|
|
|
#if !defined(AF_VSOCK)
|
|
|
|
# error missing AF_VSOCK flag
|
|
|
|
#endif
|
|
|
|
#include <linux/vm_sockets.h>
|
|
|
|
int main(void) {
|
|
|
|
int sock, ret;
|
|
|
|
struct sockaddr_vm svm;
|
|
|
|
socklen_t len = sizeof(svm);
|
|
|
|
sock = socket(AF_VSOCK, SOCK_STREAM, 0);
|
|
|
|
ret = getpeername(sock, (struct sockaddr *)&svm, &len);
|
|
|
|
if ((ret == -1) && (errno == ENOTCONN)) {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
have_af_vsock=yes
|
|
|
|
fi
|
|
|
|
|
2017-07-14 21:04:05 +03:00
|
|
|
##########################################
|
|
|
|
# check for usable AF_ALG environment
|
2020-02-03 18:55:34 +03:00
|
|
|
have_afalg=no
|
2017-07-14 21:04:05 +03:00
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <errno.h>
|
|
|
|
#include <sys/types.h>
|
|
|
|
#include <sys/socket.h>
|
|
|
|
#include <linux/if_alg.h>
|
|
|
|
int main(void) {
|
|
|
|
int sock;
|
|
|
|
sock = socket(AF_ALG, SOCK_SEQPACKET, 0);
|
|
|
|
return sock;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
have_afalg=yes
|
|
|
|
fi
|
|
|
|
if test "$crypto_afalg" = "yes"
|
|
|
|
then
|
|
|
|
if test "$have_afalg" != "yes"
|
|
|
|
then
|
|
|
|
error_exit "AF_ALG requested but could not be detected"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
i386: hvf: add code base from Google's QEMU repository
This file begins tracking the files that will be the code base for HVF
support in QEMU. This code base is part of Google's QEMU version of
their Android emulator, and can be found at
https://android.googlesource.com/platform/external/qemu/+/emu-master-dev
This code is based on Veertu Inc's vdhh (Veertu Desktop Hosted
Hypervisor), found at https://github.com/veertuinc/vdhh. Everything is
appropriately licensed under GPL v2-or-later, except for the code inside
x86_task.c and x86_task.h, which, deriving from KVM (the Linux kernel),
is licensed GPL v2-only.
This code base already implements a very great deal of functionality,
although Google's version removed from Vertuu's the support for APIC
page and hyperv-related stuff. According to the Android Emulator Release
Notes, Revision 26.1.3 (August 2017), "Hypervisor.framework is now
enabled by default on macOS for 32-bit x86 images to improve performance
and macOS compatibility", although we better use with caution for, as the
same Revision warns us, "If you experience issues with it specifically,
please file a bug report...". The code hasn't seen much update in the
last 5 months, so I think that we can further develop the code with
occasional visiting Google's repository to see if there has been any
update.
On top of Google's code, the following changes were made:
- add code to the configure script to support the --enable-hvf argument.
If the OS is Darwin, it checks for presence of HVF in the system. The
patch also adds strings related to HVF in the file qemu-options.hx.
QEMU will only support the modern syntax style '-M accel=hvf' no enable
hvf; the legacy '-enable-hvf' will not be supported.
- fix styling issues
- add glue code to cpus.c
- move HVFX86EmulatorState field to CPUX86State, changing the
the emulation functions to have a parameter with signature 'CPUX86State *'
instead of 'CPUState *' so we don't have to get the 'env'.
Signed-off-by: Sergio Andres Gomez Del Real <Sergio.G.DelReal@gmail.com>
Message-Id: <20170913090522.4022-2-Sergio.G.DelReal@gmail.com>
Message-Id: <20170913090522.4022-3-Sergio.G.DelReal@gmail.com>
Message-Id: <20170913090522.4022-5-Sergio.G.DelReal@gmail.com>
Message-Id: <20170913090522.4022-6-Sergio.G.DelReal@gmail.com>
Message-Id: <20170905035457.3753-7-Sergio.G.DelReal@gmail.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
2017-09-13 12:05:09 +03:00
|
|
|
#################################################
|
build: include sys/sysmacros.h for major() and minor()
The definition of the major() and minor() macros are moving within glibc to
<sys/sysmacros.h>. Include this header when it is available to avoid the
following sorts of build-stopping messages:
qga/commands-posix.c: In function ‘dev_major_minor’:
qga/commands-posix.c:656:13: error: In the GNU C Library, "major" is defined
by <sys/sysmacros.h>. For historical compatibility, it is
currently defined by <sys/types.h> as well, but we plan to
remove this soon. To use "major", include <sys/sysmacros.h>
directly. If you did not intend to use a system-defined macro
"major", you should undefine it after including <sys/types.h>. [-Werror]
*devmajor = major(st.st_rdev);
^~~~~~~~~~~~~~~~~~~~~~~~~~
qga/commands-posix.c:657:13: error: In the GNU C Library, "minor" is defined
by <sys/sysmacros.h>. For historical compatibility, it is
currently defined by <sys/types.h> as well, but we plan to
remove this soon. To use "minor", include <sys/sysmacros.h>
directly. If you did not intend to use a system-defined macro
"minor", you should undefine it after including <sys/types.h>. [-Werror]
*devminor = minor(st.st_rdev);
^~~~~~~~~~~~~~~~~~~~~~~~~~
The additional include allows the build to complete on Fedora 26 (Rawhide)
with glibc version 2.24.90.
Signed-off-by: Christopher Covington <cov@codeaurora.org>
Reviewed-by: Eric Blake <eblake@redhat.com>
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
2016-12-28 23:04:33 +03:00
|
|
|
# check for sysmacros.h
|
|
|
|
|
|
|
|
have_sysmacros=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <sys/sysmacros.h>
|
|
|
|
int main(void) {
|
|
|
|
return makedev(0, 0);
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
have_sysmacros=yes
|
|
|
|
fi
|
|
|
|
|
2017-03-14 19:59:53 +03:00
|
|
|
##########################################
|
|
|
|
# check for _Static_assert()
|
|
|
|
|
|
|
|
have_static_assert=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
_Static_assert(1, "success");
|
|
|
|
int main(void) {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
have_static_assert=yes
|
|
|
|
fi
|
|
|
|
|
2017-07-17 16:58:33 +03:00
|
|
|
##########################################
|
|
|
|
# check for utmpx.h, it is missing e.g. on OpenBSD
|
|
|
|
|
|
|
|
have_utmpx=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <utmpx.h>
|
|
|
|
struct utmpx user_info;
|
|
|
|
int main(void) {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
have_utmpx=yes
|
|
|
|
fi
|
|
|
|
|
2019-03-14 06:57:28 +03:00
|
|
|
##########################################
|
|
|
|
# check for getrandom()
|
|
|
|
|
|
|
|
have_getrandom=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <sys/random.h>
|
|
|
|
int main(void) {
|
|
|
|
return getrandom(0, 0, GRND_NONBLOCK);
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
have_getrandom=yes
|
|
|
|
fi
|
|
|
|
|
2018-01-16 18:11:51 +03:00
|
|
|
##########################################
|
|
|
|
# checks for sanitizers
|
|
|
|
|
|
|
|
have_asan=no
|
|
|
|
have_ubsan=no
|
2018-01-16 18:11:52 +03:00
|
|
|
have_asan_iface_h=no
|
|
|
|
have_asan_iface_fiber=no
|
2018-01-16 18:11:51 +03:00
|
|
|
|
|
|
|
if test "$sanitizers" = "yes" ; then
|
2018-02-16 00:25:47 +03:00
|
|
|
write_c_skeleton
|
2018-01-16 18:11:51 +03:00
|
|
|
if compile_prog "$CPU_CFLAGS -Werror -fsanitize=address" ""; then
|
|
|
|
have_asan=yes
|
|
|
|
fi
|
2018-02-16 00:25:47 +03:00
|
|
|
|
|
|
|
# we could use a simple skeleton for flags checks, but this also
|
|
|
|
# detect the static linking issue of ubsan, see also:
|
|
|
|
# https://gcc.gnu.org/bugzilla/show_bug.cgi?id=84285
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <stdlib.h>
|
|
|
|
int main(void) {
|
|
|
|
void *tmp = malloc(10);
|
2020-05-25 01:12:04 +03:00
|
|
|
if (tmp != NULL) {
|
|
|
|
return *(int *)(tmp + 2);
|
|
|
|
}
|
2020-07-07 20:13:25 +03:00
|
|
|
return 1;
|
2018-02-16 00:25:47 +03:00
|
|
|
}
|
|
|
|
EOF
|
2018-01-16 18:11:51 +03:00
|
|
|
if compile_prog "$CPU_CFLAGS -Werror -fsanitize=undefined" ""; then
|
|
|
|
have_ubsan=yes
|
|
|
|
fi
|
2018-01-16 18:11:52 +03:00
|
|
|
|
|
|
|
if check_include "sanitizer/asan_interface.h" ; then
|
|
|
|
have_asan_iface_h=yes
|
|
|
|
fi
|
|
|
|
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <sanitizer/asan_interface.h>
|
|
|
|
int main(void) {
|
|
|
|
__sanitizer_start_switch_fiber(0, 0, 0);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "$CPU_CFLAGS -Werror -fsanitize=address" "" ; then
|
|
|
|
have_asan_iface_fiber=yes
|
|
|
|
fi
|
2018-01-16 18:11:51 +03:00
|
|
|
fi
|
|
|
|
|
2020-02-20 07:11:14 +03:00
|
|
|
##########################################
|
|
|
|
# checks for fuzzer
|
2020-09-02 20:36:51 +03:00
|
|
|
if test "$fuzzing" = "yes" && test -z "${LIB_FUZZING_ENGINE+xxx}"; then
|
2020-02-20 07:11:14 +03:00
|
|
|
write_c_fuzzer_skeleton
|
2020-07-06 22:55:31 +03:00
|
|
|
if compile_prog "$CPU_CFLAGS -Werror -fsanitize=fuzzer" ""; then
|
2020-08-03 18:04:25 +03:00
|
|
|
have_fuzzer=yes
|
|
|
|
else
|
|
|
|
error_exit "Your compiler doesn't support -fsanitize=fuzzer"
|
|
|
|
exit 1
|
2020-02-20 07:11:14 +03:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2020-06-12 22:02:23 +03:00
|
|
|
# Thread sanitizer is, for now, much noisier than the other sanitizers;
|
|
|
|
# keep it separate until that is not the case.
|
|
|
|
if test "$tsan" = "yes" && test "$sanitizers" = "yes"; then
|
|
|
|
error_exit "TSAN is not supported with other sanitiziers."
|
|
|
|
fi
|
|
|
|
have_tsan=no
|
|
|
|
have_tsan_iface_fiber=no
|
|
|
|
if test "$tsan" = "yes" ; then
|
|
|
|
write_c_skeleton
|
|
|
|
if compile_prog "$CPU_CFLAGS -Werror -fsanitize=thread" "" ; then
|
|
|
|
have_tsan=yes
|
|
|
|
fi
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <sanitizer/tsan_interface.h>
|
|
|
|
int main(void) {
|
|
|
|
__tsan_create_fiber(0);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "$CPU_CFLAGS -Werror -fsanitize=thread" "" ; then
|
|
|
|
have_tsan_iface_fiber=yes
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2018-07-18 10:47:59 +03:00
|
|
|
##########################################
|
|
|
|
# check for libpmem
|
|
|
|
|
|
|
|
if test "$libpmem" != "no"; then
|
|
|
|
if $pkg_config --exists "libpmem"; then
|
|
|
|
libpmem="yes"
|
|
|
|
libpmem_libs=$($pkg_config --libs libpmem)
|
|
|
|
libpmem_cflags=$($pkg_config --cflags libpmem)
|
|
|
|
else
|
|
|
|
if test "$libpmem" = "yes" ; then
|
|
|
|
feature_not_found "libpmem" "Install nvml or pmdk"
|
|
|
|
fi
|
|
|
|
libpmem="no"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2020-04-29 11:50:11 +03:00
|
|
|
##########################################
|
|
|
|
# check for libdaxctl
|
|
|
|
|
|
|
|
if test "$libdaxctl" != "no"; then
|
|
|
|
if $pkg_config --atleast-version=57 "libdaxctl"; then
|
|
|
|
libdaxctl="yes"
|
|
|
|
libdaxctl_libs=$($pkg_config --libs libdaxctl)
|
|
|
|
libdaxctl_cflags=$($pkg_config --cflags libdaxctl)
|
|
|
|
else
|
|
|
|
if test "$libdaxctl" = "yes" ; then
|
|
|
|
feature_not_found "libdaxctl" "Install libdaxctl"
|
|
|
|
fi
|
|
|
|
libdaxctl="no"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2019-02-12 19:25:23 +03:00
|
|
|
##########################################
|
|
|
|
# check for slirp
|
|
|
|
|
|
|
|
case "$slirp" in
|
2020-10-05 12:31:15 +03:00
|
|
|
auto | enabled | internal)
|
|
|
|
# Simpler to always update submodule, even if not needed.
|
|
|
|
if test -e "${source_path}/.git" && test $git_update = 'yes' ; then
|
2019-04-24 14:00:41 +03:00
|
|
|
git_submodules="${git_submodules} slirp"
|
|
|
|
fi
|
2019-02-12 19:25:23 +03:00
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
2020-05-25 14:19:12 +03:00
|
|
|
##########################################
|
|
|
|
# check for usable __NR_keyctl syscall
|
|
|
|
|
|
|
|
if test "$linux" = "yes" ; then
|
|
|
|
|
|
|
|
have_keyring=no
|
|
|
|
cat > $TMPC << EOF
|
|
|
|
#include <errno.h>
|
|
|
|
#include <asm/unistd.h>
|
|
|
|
#include <linux/keyctl.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
int main(void) {
|
|
|
|
return syscall(__NR_keyctl, KEYCTL_READ, 0, NULL, NULL, 0);
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
if compile_prog "" "" ; then
|
|
|
|
have_keyring=yes
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
if test "$secret_keyring" != "no"
|
|
|
|
then
|
2020-07-01 16:56:15 +03:00
|
|
|
if test "$have_keyring" = "yes"
|
2020-05-25 14:19:12 +03:00
|
|
|
then
|
|
|
|
secret_keyring=yes
|
|
|
|
else
|
|
|
|
if test "$secret_keyring" = "yes"
|
|
|
|
then
|
|
|
|
error_exit "syscall __NR_keyctl requested, \
|
|
|
|
but not implemented on your system"
|
|
|
|
else
|
|
|
|
secret_keyring=no
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2010-05-23 00:11:33 +04:00
|
|
|
##########################################
|
2009-08-03 16:45:59 +04:00
|
|
|
# End of CC checks
|
|
|
|
# After here, no more $cc or $ld runs
|
|
|
|
|
2018-01-16 18:11:52 +03:00
|
|
|
write_c_skeleton
|
|
|
|
|
2012-05-01 22:45:39 +04:00
|
|
|
if test "$gcov" = "yes" ; then
|
2019-10-04 16:35:16 +03:00
|
|
|
:
|
2015-11-03 23:43:42 +03:00
|
|
|
elif test "$fortify_source" = "yes" ; then
|
2020-02-03 17:22:17 +03:00
|
|
|
QEMU_CFLAGS="-U_FORTIFY_SOURCE -D_FORTIFY_SOURCE=2 $QEMU_CFLAGS"
|
|
|
|
debug=no
|
|
|
|
fi
|
|
|
|
|
|
|
|
case "$ARCH" in
|
|
|
|
alpha)
|
|
|
|
# Ensure there's only a single GP
|
|
|
|
QEMU_CFLAGS="-msmall-data $QEMU_CFLAGS"
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
if test "$gprof" = "yes" ; then
|
|
|
|
QEMU_CFLAGS="-p $QEMU_CFLAGS"
|
|
|
|
QEMU_LDFLAGS="-p $QEMU_LDFLAGS"
|
|
|
|
fi
|
2009-09-30 03:10:55 +04:00
|
|
|
|
2018-01-16 18:11:51 +03:00
|
|
|
if test "$have_asan" = "yes"; then
|
build-sys: clean up flags included in the linker command line
Some of the CFLAGS that are discovered during configure, for example
compiler warnings, are being included on the linker command line because
QEMU_CFLAGS is added to it. Other flags, such as the -m32, appear twice
because they are included in both QEMU_CFLAGS and LDFLAGS. All this
leads to confusion with respect to what goes in which Makefile variables
(and we have plenty).
So, introduce QEMU_LDFLAGS for flags discovered by configure, following
the lead of QEMU_CFLAGS, and stop adding to it:
1) options that are already in CFLAGS, for example "-g"
2) duplicate options
At the same time, options that _are_ needed by both compiler and linker
must now be added to both QEMU_CFLAGS and QEMU_LDFLAGS, which is clearer.
This is mostly -fsanitize options. For now, --extra-cflags has this behavior
(but --extra-cxxflags does not).
Meson will not include CFLAGS on the linker command line, do the same in our
build system as well.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
2019-12-11 17:34:27 +03:00
|
|
|
QEMU_CFLAGS="-fsanitize=address $QEMU_CFLAGS"
|
|
|
|
QEMU_LDFLAGS="-fsanitize=address $QEMU_LDFLAGS"
|
2018-01-16 18:11:52 +03:00
|
|
|
if test "$have_asan_iface_h" = "no" ; then
|
|
|
|
echo "ASAN build enabled, but ASAN header missing." \
|
|
|
|
"Without code annotation, the report may be inferior."
|
|
|
|
elif test "$have_asan_iface_fiber" = "no" ; then
|
|
|
|
echo "ASAN build enabled, but ASAN header is too old." \
|
|
|
|
"Without code annotation, the report may be inferior."
|
|
|
|
fi
|
2018-01-16 18:11:51 +03:00
|
|
|
fi
|
2020-06-12 22:02:23 +03:00
|
|
|
if test "$have_tsan" = "yes" ; then
|
|
|
|
if test "$have_tsan_iface_fiber" = "yes" ; then
|
|
|
|
QEMU_CFLAGS="-fsanitize=thread $QEMU_CFLAGS"
|
|
|
|
QEMU_LDFLAGS="-fsanitize=thread $QEMU_LDFLAGS"
|
|
|
|
else
|
|
|
|
error_exit "Cannot enable TSAN due to missing fiber annotation interface."
|
|
|
|
fi
|
|
|
|
elif test "$tsan" = "yes" ; then
|
|
|
|
error_exit "Cannot enable TSAN due to missing sanitize thread interface."
|
|
|
|
fi
|
2018-01-16 18:11:51 +03:00
|
|
|
if test "$have_ubsan" = "yes"; then
|
build-sys: clean up flags included in the linker command line
Some of the CFLAGS that are discovered during configure, for example
compiler warnings, are being included on the linker command line because
QEMU_CFLAGS is added to it. Other flags, such as the -m32, appear twice
because they are included in both QEMU_CFLAGS and LDFLAGS. All this
leads to confusion with respect to what goes in which Makefile variables
(and we have plenty).
So, introduce QEMU_LDFLAGS for flags discovered by configure, following
the lead of QEMU_CFLAGS, and stop adding to it:
1) options that are already in CFLAGS, for example "-g"
2) duplicate options
At the same time, options that _are_ needed by both compiler and linker
must now be added to both QEMU_CFLAGS and QEMU_LDFLAGS, which is clearer.
This is mostly -fsanitize options. For now, --extra-cflags has this behavior
(but --extra-cxxflags does not).
Meson will not include CFLAGS on the linker command line, do the same in our
build system as well.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
2019-12-11 17:34:27 +03:00
|
|
|
QEMU_CFLAGS="-fsanitize=undefined $QEMU_CFLAGS"
|
|
|
|
QEMU_LDFLAGS="-fsanitize=undefined $QEMU_LDFLAGS"
|
2018-01-16 18:11:51 +03:00
|
|
|
fi
|
|
|
|
|
2018-10-23 14:23:10 +03:00
|
|
|
##########################################
|
|
|
|
|
2020-06-12 22:02:23 +03:00
|
|
|
# Exclude --warn-common with TSan to suppress warnings from the TSan libraries.
|
|
|
|
if test "$solaris" = "no" && test "$tsan" = "no"; then
|
2009-08-03 16:45:59 +04:00
|
|
|
if $ld --version 2>/dev/null | grep "GNU ld" >/dev/null 2>/dev/null ; then
|
build-sys: clean up flags included in the linker command line
Some of the CFLAGS that are discovered during configure, for example
compiler warnings, are being included on the linker command line because
QEMU_CFLAGS is added to it. Other flags, such as the -m32, appear twice
because they are included in both QEMU_CFLAGS and LDFLAGS. All this
leads to confusion with respect to what goes in which Makefile variables
(and we have plenty).
So, introduce QEMU_LDFLAGS for flags discovered by configure, following
the lead of QEMU_CFLAGS, and stop adding to it:
1) options that are already in CFLAGS, for example "-g"
2) duplicate options
At the same time, options that _are_ needed by both compiler and linker
must now be added to both QEMU_CFLAGS and QEMU_LDFLAGS, which is clearer.
This is mostly -fsanitize options. For now, --extra-cflags has this behavior
(but --extra-cxxflags does not).
Meson will not include CFLAGS on the linker command line, do the same in our
build system as well.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
2019-12-11 17:34:27 +03:00
|
|
|
QEMU_LDFLAGS="-Wl,--warn-common $QEMU_LDFLAGS"
|
2009-08-03 16:45:59 +04:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2010-09-19 12:36:34 +04:00
|
|
|
# Use ASLR, no-SEH and DEP if available
|
|
|
|
if test "$mingw32" = "yes" ; then
|
2020-10-05 16:34:34 +03:00
|
|
|
flags="--no-seh --nxcompat"
|
|
|
|
|
|
|
|
# Disable ASLR for debug builds to allow debugging with gdb
|
|
|
|
if test "$debug" = "no" ; then
|
|
|
|
flags="--dynamicbase $flags"
|
|
|
|
fi
|
|
|
|
|
|
|
|
for flag in $flags; do
|
2017-08-23 13:16:23 +03:00
|
|
|
if ld_has $flag ; then
|
build-sys: clean up flags included in the linker command line
Some of the CFLAGS that are discovered during configure, for example
compiler warnings, are being included on the linker command line because
QEMU_CFLAGS is added to it. Other flags, such as the -m32, appear twice
because they are included in both QEMU_CFLAGS and LDFLAGS. All this
leads to confusion with respect to what goes in which Makefile variables
(and we have plenty).
So, introduce QEMU_LDFLAGS for flags discovered by configure, following
the lead of QEMU_CFLAGS, and stop adding to it:
1) options that are already in CFLAGS, for example "-g"
2) duplicate options
At the same time, options that _are_ needed by both compiler and linker
must now be added to both QEMU_CFLAGS and QEMU_LDFLAGS, which is clearer.
This is mostly -fsanitize options. For now, --extra-cflags has this behavior
(but --extra-cxxflags does not).
Meson will not include CFLAGS on the linker command line, do the same in our
build system as well.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
2019-12-11 17:34:27 +03:00
|
|
|
QEMU_LDFLAGS="-Wl,$flag $QEMU_LDFLAGS"
|
2010-09-19 12:36:34 +04:00
|
|
|
fi
|
|
|
|
done
|
|
|
|
fi
|
|
|
|
|
2017-07-14 11:33:44 +03:00
|
|
|
# We can only support ivshmem if we have eventfd
|
|
|
|
if [ "$eventfd" = "yes" ]; then
|
|
|
|
ivshmem=yes
|
|
|
|
fi
|
|
|
|
|
2015-08-26 18:49:13 +03:00
|
|
|
# Probe for guest agent support/options
|
|
|
|
|
2013-07-31 14:22:07 +04:00
|
|
|
if [ "$guest_agent" != "no" ]; then
|
2019-04-01 17:12:20 +03:00
|
|
|
if [ "$softmmu" = no -a "$want_tools" = no ] ; then
|
|
|
|
guest_agent=no
|
|
|
|
elif [ "$linux" = "yes" -o "$bsd" = "yes" -o "$solaris" = "yes" -o "$mingw32" = "yes" ] ; then
|
2013-07-31 14:22:07 +04:00
|
|
|
guest_agent=yes
|
|
|
|
elif [ "$guest_agent" != yes ]; then
|
|
|
|
guest_agent=no
|
|
|
|
else
|
|
|
|
error_exit "Guest agent is not supported on this platform"
|
2010-05-26 18:08:29 +04:00
|
|
|
fi
|
2012-05-29 13:40:24 +04:00
|
|
|
fi
|
2010-05-26 18:08:29 +04:00
|
|
|
|
2015-08-26 18:49:13 +03:00
|
|
|
# Guest agent Window MSI package
|
|
|
|
|
|
|
|
if test "$guest_agent" != yes; then
|
|
|
|
if test "$guest_agent_msi" = yes; then
|
|
|
|
error_exit "MSI guest agent package requires guest agent enabled"
|
|
|
|
fi
|
|
|
|
guest_agent_msi=no
|
|
|
|
elif test "$mingw32" != "yes"; then
|
|
|
|
if test "$guest_agent_msi" = "yes"; then
|
|
|
|
error_exit "MSI guest agent package is available only for MinGW Windows cross-compilation"
|
|
|
|
fi
|
|
|
|
guest_agent_msi=no
|
|
|
|
elif ! has wixl; then
|
|
|
|
if test "$guest_agent_msi" = "yes"; then
|
|
|
|
error_exit "MSI guest agent package requires wixl tool installed ( usually from msitools package )"
|
|
|
|
fi
|
|
|
|
guest_agent_msi=no
|
2015-08-26 19:14:31 +03:00
|
|
|
else
|
|
|
|
# we support qemu-ga, mingw32, and wixl: default to MSI enabled if it wasn't
|
|
|
|
# disabled explicitly
|
|
|
|
if test "$guest_agent_msi" != "no"; then
|
|
|
|
guest_agent_msi=yes
|
|
|
|
fi
|
2015-08-26 18:49:13 +03:00
|
|
|
fi
|
|
|
|
|
2015-08-26 19:14:31 +03:00
|
|
|
if test "$guest_agent_msi" = "yes"; then
|
2015-08-26 18:49:13 +03:00
|
|
|
if test "$guest_agent_with_vss" = "yes"; then
|
|
|
|
QEMU_GA_MSI_WITH_VSS="-D InstallVss"
|
|
|
|
fi
|
|
|
|
|
|
|
|
if test "$QEMU_GA_MANUFACTURER" = ""; then
|
|
|
|
QEMU_GA_MANUFACTURER=QEMU
|
|
|
|
fi
|
|
|
|
|
|
|
|
if test "$QEMU_GA_DISTRO" = ""; then
|
|
|
|
QEMU_GA_DISTRO=Linux
|
|
|
|
fi
|
|
|
|
|
|
|
|
if test "$QEMU_GA_VERSION" = ""; then
|
2016-05-16 16:10:20 +03:00
|
|
|
QEMU_GA_VERSION=$(cat $source_path/VERSION)
|
2015-08-26 18:49:13 +03:00
|
|
|
fi
|
|
|
|
|
2016-05-16 16:10:20 +03:00
|
|
|
QEMU_GA_MSI_MINGW_DLL_PATH="-D Mingw_dlls=$($pkg_config --variable=prefix glib-2.0)/bin"
|
2015-08-26 18:49:13 +03:00
|
|
|
|
|
|
|
case "$cpu" in
|
|
|
|
x86_64)
|
|
|
|
QEMU_GA_MSI_ARCH="-a x64 -D Arch=64"
|
|
|
|
;;
|
|
|
|
i386)
|
|
|
|
QEMU_GA_MSI_ARCH="-D Arch=32"
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
error_exit "CPU $cpu not supported for building installation package"
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
fi
|
|
|
|
|
2010-05-26 18:08:29 +04:00
|
|
|
# Mac OS X ships with a broken assembler
|
|
|
|
roms=
|
2019-02-05 05:39:37 +03:00
|
|
|
if { test "$cpu" = "i386" || test "$cpu" = "x86_64"; } && \
|
|
|
|
test "$targetos" != "Darwin" && test "$targetos" != "SunOS" && \
|
2020-11-14 12:49:31 +03:00
|
|
|
test "$targetos" != "Haiku" && test "$softmmu" = yes ; then
|
2016-08-08 19:11:28 +03:00
|
|
|
# Different host OS linkers have different ideas about the name of the ELF
|
2017-11-08 02:46:11 +03:00
|
|
|
# emulation. Linux and OpenBSD/amd64 use 'elf_i386'; FreeBSD uses the _fbsd
|
|
|
|
# variant; OpenBSD/i386 uses the _obsd variant; and Windows uses i386pe.
|
|
|
|
for emu in elf_i386 elf_i386_fbsd elf_i386_obsd i386pe; do
|
2016-08-08 19:11:28 +03:00
|
|
|
if "$ld" -verbose 2>&1 | grep -q "^[[:space:]]*$emu[[:space:]]*$"; then
|
|
|
|
ld_i386_emulation="$emu"
|
|
|
|
roms="optionrom"
|
|
|
|
break
|
|
|
|
fi
|
|
|
|
done
|
2010-05-26 18:08:29 +04:00
|
|
|
fi
|
|
|
|
|
2019-01-14 15:52:26 +03:00
|
|
|
# Only build s390-ccw bios if we're on s390x and the compiler has -march=z900
|
2013-04-23 05:23:03 +04:00
|
|
|
if test "$cpu" = "s390x" ; then
|
2019-01-14 15:52:26 +03:00
|
|
|
write_c_skeleton
|
|
|
|
if compile_prog "-march=z900" ""; then
|
|
|
|
roms="$roms s390-ccw"
|
2020-06-15 10:49:19 +03:00
|
|
|
# SLOF is required for building the s390-ccw firmware on s390x,
|
|
|
|
# since it is using the libnet code from SLOF for network booting.
|
|
|
|
if test -e "${source_path}/.git" ; then
|
|
|
|
git_submodules="${git_submodules} roms/SLOF"
|
|
|
|
fi
|
2019-01-14 15:52:26 +03:00
|
|
|
fi
|
2013-04-23 05:23:03 +04:00
|
|
|
fi
|
|
|
|
|
2017-06-06 16:07:47 +03:00
|
|
|
# Check that the C++ compiler exists and works with the C compiler.
|
|
|
|
# All the QEMU_CXXFLAGS are based on QEMU_CFLAGS. Keep this at the end to don't miss any other that could be added.
|
|
|
|
if has $cxx; then
|
|
|
|
cat > $TMPC <<EOF
|
|
|
|
int c_function(void);
|
|
|
|
int main(void) { return c_function(); }
|
|
|
|
EOF
|
|
|
|
|
|
|
|
compile_object
|
|
|
|
|
|
|
|
cat > $TMPCXX <<EOF
|
|
|
|
extern "C" {
|
|
|
|
int c_function(void);
|
|
|
|
}
|
|
|
|
int c_function(void) { return 42; }
|
|
|
|
EOF
|
|
|
|
|
|
|
|
update_cxxflags
|
|
|
|
|
2020-09-23 12:26:15 +03:00
|
|
|
if do_cxx $CXXFLAGS $CONFIGURE_CXXFLAGS $QEMU_CXXFLAGS -o $TMPE $TMPCXX $TMPO $QEMU_LDFLAGS; then
|
2017-06-06 16:07:47 +03:00
|
|
|
# C++ compiler $cxx works ok with C compiler $cc
|
|
|
|
:
|
|
|
|
else
|
|
|
|
echo "C++ compiler $cxx does not work with C compiler $cc"
|
|
|
|
echo "Disabling C++ specific optional code"
|
|
|
|
cxx=
|
|
|
|
fi
|
|
|
|
else
|
|
|
|
echo "No C++ compiler available; disabling C++ specific optional code"
|
|
|
|
cxx=
|
|
|
|
fi
|
|
|
|
|
2020-09-02 20:00:49 +03:00
|
|
|
if test $git_update = 'yes' ; then
|
|
|
|
(cd "${source_path}" && GIT="$git" "./scripts/git-submodule.sh" update "$git_submodules")
|
|
|
|
fi
|
|
|
|
|
2009-07-16 20:34:18 +04:00
|
|
|
config_host_mak="config-host.mak"
|
|
|
|
|
|
|
|
echo "# Automatically generated by configure - do not modify" > $config_host_mak
|
|
|
|
echo >> $config_host_mak
|
|
|
|
|
2010-10-21 12:18:35 +04:00
|
|
|
echo all: >> $config_host_mak
|
2017-10-20 17:02:43 +03:00
|
|
|
echo "GIT=$git" >> $config_host_mak
|
2017-09-29 13:11:56 +03:00
|
|
|
echo "GIT_SUBMODULES=$git_submodules" >> $config_host_mak
|
2017-10-26 15:52:26 +03:00
|
|
|
echo "GIT_UPDATE=$git_update" >> $config_host_mak
|
2009-07-27 18:12:49 +04:00
|
|
|
|
2009-07-16 20:34:18 +04:00
|
|
|
echo "ARCH=$ARCH" >> $config_host_mak
|
2013-04-17 18:26:43 +04:00
|
|
|
|
2009-04-13 22:45:38 +04:00
|
|
|
if test "$debug_tcg" = "yes" ; then
|
2009-07-27 18:13:25 +04:00
|
|
|
echo "CONFIG_DEBUG_TCG=y" >> $config_host_mak
|
2009-04-13 22:45:38 +04:00
|
|
|
fi
|
2009-04-05 21:41:02 +04:00
|
|
|
if test "$strip_opt" = "yes" ; then
|
2010-08-05 04:21:34 +04:00
|
|
|
echo "STRIP=${strip}" >> $config_host_mak
|
2009-04-05 21:41:02 +04:00
|
|
|
fi
|
2003-03-07 02:23:54 +03:00
|
|
|
if test "$bigendian" = "yes" ; then
|
2009-07-27 18:13:06 +04:00
|
|
|
echo "HOST_WORDS_BIGENDIAN=y" >> $config_host_mak
|
2003-08-11 01:36:04 +04:00
|
|
|
fi
|
2004-04-01 03:37:16 +04:00
|
|
|
if test "$mingw32" = "yes" ; then
|
2009-07-16 20:34:18 +04:00
|
|
|
echo "CONFIG_WIN32=y" >> $config_host_mak
|
2013-08-07 19:40:03 +04:00
|
|
|
if test "$guest_agent_with_vss" = "yes" ; then
|
|
|
|
echo "CONFIG_QGA_VSS=y" >> $config_host_mak
|
2015-08-27 00:19:41 +03:00
|
|
|
echo "QGA_VSS_PROVIDER=$qga_vss_provider" >> $config_host_mak
|
2013-08-07 19:40:03 +04:00
|
|
|
echo "WIN_SDK=\"$win_sdk\"" >> $config_host_mak
|
|
|
|
fi
|
2015-07-08 02:10:09 +03:00
|
|
|
if test "$guest_agent_ntddscsi" = "yes" ; then
|
2018-10-23 14:23:16 +03:00
|
|
|
echo "CONFIG_QGA_NTDDSCSI=y" >> $config_host_mak
|
2015-07-08 02:10:09 +03:00
|
|
|
fi
|
2015-08-26 19:14:31 +03:00
|
|
|
if test "$guest_agent_msi" = "yes"; then
|
2020-09-14 12:52:31 +03:00
|
|
|
echo "CONFIG_QGA_MSI=y" >> $config_host_mak
|
2015-05-06 14:57:40 +03:00
|
|
|
echo "QEMU_GA_MSI_MINGW_DLL_PATH=${QEMU_GA_MSI_MINGW_DLL_PATH}" >> $config_host_mak
|
|
|
|
echo "QEMU_GA_MSI_WITH_VSS=${QEMU_GA_MSI_WITH_VSS}" >> $config_host_mak
|
|
|
|
echo "QEMU_GA_MSI_ARCH=${QEMU_GA_MSI_ARCH}" >> $config_host_mak
|
|
|
|
echo "QEMU_GA_MANUFACTURER=${QEMU_GA_MANUFACTURER}" >> $config_host_mak
|
|
|
|
echo "QEMU_GA_DISTRO=${QEMU_GA_DISTRO}" >> $config_host_mak
|
|
|
|
echo "QEMU_GA_VERSION=${QEMU_GA_VERSION}" >> $config_host_mak
|
|
|
|
fi
|
2007-02-28 00:04:49 +03:00
|
|
|
else
|
2009-07-27 18:13:07 +04:00
|
|
|
echo "CONFIG_POSIX=y" >> $config_host_mak
|
2009-10-22 20:49:11 +04:00
|
|
|
fi
|
|
|
|
|
|
|
|
if test "$linux" = "yes" ; then
|
|
|
|
echo "CONFIG_LINUX=y" >> $config_host_mak
|
2004-04-01 03:37:16 +04:00
|
|
|
fi
|
2008-08-15 22:33:42 +04:00
|
|
|
|
2004-07-06 01:25:26 +04:00
|
|
|
if test "$darwin" = "yes" ; then
|
2009-07-16 20:34:18 +04:00
|
|
|
echo "CONFIG_DARWIN=y" >> $config_host_mak
|
2004-07-06 01:25:26 +04:00
|
|
|
fi
|
2008-11-18 04:42:22 +03:00
|
|
|
|
2006-04-26 02:36:06 +04:00
|
|
|
if test "$solaris" = "yes" ; then
|
2009-07-16 20:34:18 +04:00
|
|
|
echo "CONFIG_SOLARIS=y" >> $config_host_mak
|
2006-04-26 02:36:06 +04:00
|
|
|
fi
|
2010-09-20 02:50:43 +04:00
|
|
|
if test "$haiku" = "yes" ; then
|
|
|
|
echo "CONFIG_HAIKU=y" >> $config_host_mak
|
|
|
|
fi
|
2003-08-11 01:36:04 +04:00
|
|
|
if test "$static" = "yes" ; then
|
2009-07-16 20:34:18 +04:00
|
|
|
echo "CONFIG_STATIC=y" >> $config_host_mak
|
2003-03-07 02:23:54 +03:00
|
|
|
fi
|
2011-07-30 00:40:45 +04:00
|
|
|
if test "$profiler" = "yes" ; then
|
2009-07-27 18:13:25 +04:00
|
|
|
echo "CONFIG_PROFILER=y" >> $config_host_mak
|
2006-02-09 01:39:17 +03:00
|
|
|
fi
|
2019-07-18 13:24:29 +03:00
|
|
|
if test "$want_tools" = "yes" ; then
|
|
|
|
echo "CONFIG_TOOLS=y" >> $config_host_mak
|
|
|
|
fi
|
2019-07-18 14:19:02 +03:00
|
|
|
if test "$guest_agent" = "yes" ; then
|
|
|
|
echo "CONFIG_GUEST_AGENT=y" >> $config_host_mak
|
|
|
|
fi
|
2020-10-05 12:31:15 +03:00
|
|
|
echo "CONFIG_SMBD_COMMAND=\"$smbd\"" >> $config_host_mak
|
2008-07-19 13:56:24 +04:00
|
|
|
if test "$vde" = "yes" ; then
|
2009-07-16 20:34:18 +04:00
|
|
|
echo "CONFIG_VDE=y" >> $config_host_mak
|
2017-09-07 11:35:52 +03:00
|
|
|
echo "VDE_LIBS=$vde_libs" >> $config_host_mak
|
2008-07-19 13:56:24 +04:00
|
|
|
fi
|
2013-11-06 14:44:06 +04:00
|
|
|
if test "$netmap" = "yes" ; then
|
|
|
|
echo "CONFIG_NETMAP=y" >> $config_host_mak
|
|
|
|
fi
|
2014-07-01 16:58:08 +04:00
|
|
|
if test "$l2tpv3" = "yes" ; then
|
|
|
|
echo "CONFIG_L2TPV3=y" >> $config_host_mak
|
|
|
|
fi
|
2020-02-04 19:11:04 +03:00
|
|
|
if test "$gprof" = "yes" ; then
|
|
|
|
echo "CONFIG_GPROF=y" >> $config_host_mak
|
|
|
|
fi
|
2009-07-27 18:13:25 +04:00
|
|
|
echo "CONFIG_AUDIO_DRIVERS=$audio_drv_list" >> $config_host_mak
|
2008-06-26 01:04:05 +04:00
|
|
|
for drv in $audio_drv_list; do
|
2018-03-01 13:05:46 +03:00
|
|
|
def=CONFIG_AUDIO_$(echo $drv | LC_ALL=C tr '[a-z]' '[A-Z]')
|
2019-12-12 15:30:36 +03:00
|
|
|
echo "$def=y" >> $config_host_mak
|
2008-06-26 01:04:05 +04:00
|
|
|
done
|
2020-08-17 13:47:55 +03:00
|
|
|
if test "$alsa" = "yes" ; then
|
|
|
|
echo "CONFIG_ALSA=y" >> $config_host_mak
|
|
|
|
fi
|
2017-09-07 11:29:13 +03:00
|
|
|
echo "ALSA_LIBS=$alsa_libs" >> $config_host_mak
|
2020-08-17 13:47:55 +03:00
|
|
|
echo "ALSA_CFLAGS=$alsa_cflags" >> $config_host_mak
|
|
|
|
if test "$libpulse" = "yes" ; then
|
|
|
|
echo "CONFIG_LIBPULSE=y" >> $config_host_mak
|
|
|
|
fi
|
2017-09-07 11:29:13 +03:00
|
|
|
echo "PULSE_LIBS=$pulse_libs" >> $config_host_mak
|
2020-08-17 13:47:55 +03:00
|
|
|
echo "PULSE_CFLAGS=$pulse_cflags" >> $config_host_mak
|
2017-09-07 11:29:13 +03:00
|
|
|
echo "COREAUDIO_LIBS=$coreaudio_libs" >> $config_host_mak
|
|
|
|
echo "DSOUND_LIBS=$dsound_libs" >> $config_host_mak
|
|
|
|
echo "OSS_LIBS=$oss_libs" >> $config_host_mak
|
2020-08-17 13:47:55 +03:00
|
|
|
if test "$libjack" = "yes" ; then
|
|
|
|
echo "CONFIG_LIBJACK=y" >> $config_host_mak
|
|
|
|
fi
|
2020-04-29 08:53:58 +03:00
|
|
|
echo "JACK_LIBS=$jack_libs" >> $config_host_mak
|
2009-10-10 01:13:41 +04:00
|
|
|
if test "$audio_win_int" = "yes" ; then
|
|
|
|
echo "CONFIG_AUDIO_WIN_INT=y" >> $config_host_mak
|
|
|
|
fi
|
2013-05-29 15:35:40 +04:00
|
|
|
echo "CONFIG_BDRV_RW_WHITELIST=$block_drv_rw_whitelist" >> $config_host_mak
|
|
|
|
echo "CONFIG_BDRV_RO_WHITELIST=$block_drv_ro_whitelist" >> $config_host_mak
|
2010-12-17 13:41:15 +03:00
|
|
|
if test "$xfs" = "yes" ; then
|
|
|
|
echo "CONFIG_XFS=y" >> $config_host_mak
|
|
|
|
fi
|
2016-05-16 16:10:20 +03:00
|
|
|
qemu_version=$(head $source_path/VERSION)
|
2009-07-27 18:13:25 +04:00
|
|
|
echo "PKGVERSION=$pkgversion" >>$config_host_mak
|
2009-07-16 20:34:18 +04:00
|
|
|
echo "SRC_PATH=$source_path" >> $config_host_mak
|
2018-07-04 09:30:11 +03:00
|
|
|
echo "TARGET_DIRS=$target_list" >> $config_host_mak
|
2014-02-10 10:48:56 +04:00
|
|
|
if test "$modules" = "yes"; then
|
2014-02-10 10:48:57 +04:00
|
|
|
# $shacmd can generate a hash started with digit, which the compiler doesn't
|
|
|
|
# like as an symbol. So prefix it with an underscore
|
2016-05-16 16:10:20 +03:00
|
|
|
echo "CONFIG_STAMP=_$( (echo $qemu_version; echo $pkgversion; cat $0) | $shacmd - | cut -f1 -d\ )" >> $config_host_mak
|
2014-02-10 10:48:56 +04:00
|
|
|
echo "CONFIG_MODULES=y" >> $config_host_mak
|
|
|
|
fi
|
2020-03-10 17:58:06 +03:00
|
|
|
if test "$module_upgrades" = "yes"; then
|
|
|
|
echo "CONFIG_MODULE_UPGRADES=y" >> $config_host_mak
|
|
|
|
fi
|
2019-02-05 05:39:37 +03:00
|
|
|
if test "$have_x11" = "yes" && test "$need_x11" = "yes"; then
|
2018-03-01 13:05:42 +03:00
|
|
|
echo "CONFIG_X11=y" >> $config_host_mak
|
|
|
|
echo "X11_CFLAGS=$x11_cflags" >> $config_host_mak
|
|
|
|
echo "X11_LIBS=$x11_libs" >> $config_host_mak
|
|
|
|
fi
|
2009-05-05 13:10:04 +04:00
|
|
|
if test "$pipe2" = "yes" ; then
|
2009-07-27 18:13:25 +04:00
|
|
|
echo "CONFIG_PIPE2=y" >> $config_host_mak
|
2009-05-05 13:10:04 +04:00
|
|
|
fi
|
2009-12-02 14:24:42 +03:00
|
|
|
if test "$accept4" = "yes" ; then
|
|
|
|
echo "CONFIG_ACCEPT4=y" >> $config_host_mak
|
|
|
|
fi
|
2009-05-16 17:02:41 +04:00
|
|
|
if test "$splice" = "yes" ; then
|
2009-07-27 18:13:25 +04:00
|
|
|
echo "CONFIG_SPLICE=y" >> $config_host_mak
|
2009-05-16 17:02:41 +04:00
|
|
|
fi
|
2009-08-12 16:08:24 +04:00
|
|
|
if test "$eventfd" = "yes" ; then
|
|
|
|
echo "CONFIG_EVENTFD=y" >> $config_host_mak
|
|
|
|
fi
|
2015-10-09 18:17:16 +03:00
|
|
|
if test "$memfd" = "yes" ; then
|
|
|
|
echo "CONFIG_MEMFD=y" >> $config_host_mak
|
|
|
|
fi
|
2018-10-08 19:35:19 +03:00
|
|
|
if test "$have_usbfs" = "yes" ; then
|
|
|
|
echo "CONFIG_USBFS=y" >> $config_host_mak
|
|
|
|
fi
|
2009-09-17 21:22:14 +04:00
|
|
|
if test "$fallocate" = "yes" ; then
|
|
|
|
echo "CONFIG_FALLOCATE=y" >> $config_host_mak
|
|
|
|
fi
|
2013-01-14 19:26:52 +04:00
|
|
|
if test "$fallocate_punch_hole" = "yes" ; then
|
|
|
|
echo "CONFIG_FALLOCATE_PUNCH_HOLE=y" >> $config_host_mak
|
|
|
|
fi
|
2015-01-30 11:42:14 +03:00
|
|
|
if test "$fallocate_zero_range" = "yes" ; then
|
|
|
|
echo "CONFIG_FALLOCATE_ZERO_RANGE=y" >> $config_host_mak
|
|
|
|
fi
|
2014-09-29 19:12:59 +04:00
|
|
|
if test "$posix_fallocate" = "yes" ; then
|
|
|
|
echo "CONFIG_POSIX_FALLOCATE=y" >> $config_host_mak
|
|
|
|
fi
|
2011-01-06 14:05:10 +03:00
|
|
|
if test "$sync_file_range" = "yes" ; then
|
|
|
|
echo "CONFIG_SYNC_FILE_RANGE=y" >> $config_host_mak
|
|
|
|
fi
|
2011-01-10 16:11:24 +03:00
|
|
|
if test "$fiemap" = "yes" ; then
|
|
|
|
echo "CONFIG_FIEMAP=y" >> $config_host_mak
|
|
|
|
fi
|
2009-09-17 21:22:14 +04:00
|
|
|
if test "$dup3" = "yes" ; then
|
|
|
|
echo "CONFIG_DUP3=y" >> $config_host_mak
|
|
|
|
fi
|
2013-08-21 19:02:43 +04:00
|
|
|
if test "$ppoll" = "yes" ; then
|
|
|
|
echo "CONFIG_PPOLL=y" >> $config_host_mak
|
|
|
|
fi
|
2013-08-21 19:02:44 +04:00
|
|
|
if test "$prctl_pr_set_timerslack" = "yes" ; then
|
|
|
|
echo "CONFIG_PRCTL_PR_SET_TIMERSLACK=y" >> $config_host_mak
|
|
|
|
fi
|
2011-02-15 21:35:05 +03:00
|
|
|
if test "$epoll" = "yes" ; then
|
|
|
|
echo "CONFIG_EPOLL=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
if test "$epoll_create1" = "yes" ; then
|
|
|
|
echo "CONFIG_EPOLL_CREATE1=y" >> $config_host_mak
|
|
|
|
fi
|
2013-02-08 11:31:55 +04:00
|
|
|
if test "$sendfile" = "yes" ; then
|
|
|
|
echo "CONFIG_SENDFILE=y" >> $config_host_mak
|
|
|
|
fi
|
2014-06-22 14:25:42 +04:00
|
|
|
if test "$timerfd" = "yes" ; then
|
|
|
|
echo "CONFIG_TIMERFD=y" >> $config_host_mak
|
|
|
|
fi
|
2014-08-12 16:58:57 +04:00
|
|
|
if test "$setns" = "yes" ; then
|
|
|
|
echo "CONFIG_SETNS=y" >> $config_host_mak
|
|
|
|
fi
|
2016-10-10 14:23:29 +03:00
|
|
|
if test "$clock_adjtime" = "yes" ; then
|
|
|
|
echo "CONFIG_CLOCK_ADJTIME=y" >> $config_host_mak
|
|
|
|
fi
|
2016-10-10 14:23:30 +03:00
|
|
|
if test "$syncfs" = "yes" ; then
|
|
|
|
echo "CONFIG_SYNCFS=y" >> $config_host_mak
|
|
|
|
fi
|
2009-04-15 20:12:13 +04:00
|
|
|
if test "$inotify" = "yes" ; then
|
2009-07-27 18:13:25 +04:00
|
|
|
echo "CONFIG_INOTIFY=y" >> $config_host_mak
|
2009-04-15 20:12:13 +04:00
|
|
|
fi
|
2010-03-26 18:25:11 +03:00
|
|
|
if test "$inotify1" = "yes" ; then
|
|
|
|
echo "CONFIG_INOTIFY1=y" >> $config_host_mak
|
|
|
|
fi
|
2017-09-05 15:19:32 +03:00
|
|
|
if test "$sem_timedwait" = "yes" ; then
|
|
|
|
echo "CONFIG_SEM_TIMEDWAIT=y" >> $config_host_mak
|
|
|
|
fi
|
2018-06-29 13:32:10 +03:00
|
|
|
if test "$strchrnul" = "yes" ; then
|
|
|
|
echo "HAVE_STRCHRNUL=y" >> $config_host_mak
|
|
|
|
fi
|
2019-04-16 22:08:56 +03:00
|
|
|
if test "$st_atim" = "yes" ; then
|
|
|
|
echo "HAVE_STRUCT_STAT_ST_ATIM=y" >> $config_host_mak
|
|
|
|
fi
|
2009-08-03 16:45:58 +04:00
|
|
|
if test "$byteswap_h" = "yes" ; then
|
|
|
|
echo "CONFIG_BYTESWAP_H=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
if test "$bswap_h" = "yes" ; then
|
|
|
|
echo "CONFIG_MACHINE_BSWAP_H=y" >> $config_host_mak
|
|
|
|
fi
|
2013-02-20 17:43:20 +04:00
|
|
|
if test "$gtk" = "yes" ; then
|
2019-12-12 15:30:36 +03:00
|
|
|
echo "CONFIG_GTK=y" >> $config_host_mak
|
2013-02-20 17:43:20 +04:00
|
|
|
echo "GTK_CFLAGS=$gtk_cflags" >> $config_host_mak
|
2015-12-03 14:56:34 +03:00
|
|
|
echo "GTK_LIBS=$gtk_libs" >> $config_host_mak
|
2015-05-26 13:26:21 +03:00
|
|
|
if test "$gtk_gl" = "yes" ; then
|
|
|
|
echo "CONFIG_GTK_GL=y" >> $config_host_mak
|
|
|
|
fi
|
2014-02-19 10:04:34 +04:00
|
|
|
fi
|
2019-02-21 14:07:00 +03:00
|
|
|
if test "$gio" = "yes" ; then
|
|
|
|
echo "CONFIG_GIO=y" >> $config_host_mak
|
|
|
|
echo "GIO_CFLAGS=$gio_cflags" >> $config_host_mak
|
|
|
|
echo "GIO_LIBS=$gio_libs" >> $config_host_mak
|
2019-09-27 10:34:42 +03:00
|
|
|
echo "GDBUS_CODEGEN=$gdbus_codegen" >> $config_host_mak
|
2019-02-21 14:07:00 +03:00
|
|
|
fi
|
2016-06-06 12:05:06 +03:00
|
|
|
echo "CONFIG_TLS_PRIORITY=\"$tls_priority\"" >> $config_host_mak
|
2015-07-01 20:10:29 +03:00
|
|
|
if test "$gnutls" = "yes" ; then
|
|
|
|
echo "CONFIG_GNUTLS=y" >> $config_host_mak
|
2020-08-19 15:44:56 +03:00
|
|
|
echo "GNUTLS_CFLAGS=$gnutls_cflags" >> $config_host_mak
|
|
|
|
echo "GNUTLS_LIBS=$gnutls_libs" >> $config_host_mak
|
2015-07-01 20:10:29 +03:00
|
|
|
fi
|
2015-10-16 18:36:53 +03:00
|
|
|
if test "$gcrypt" = "yes" ; then
|
|
|
|
echo "CONFIG_GCRYPT=y" >> $config_host_mak
|
2016-12-13 13:42:55 +03:00
|
|
|
if test "$gcrypt_hmac" = "yes" ; then
|
|
|
|
echo "CONFIG_GCRYPT_HMAC=y" >> $config_host_mak
|
|
|
|
fi
|
2020-09-01 16:30:49 +03:00
|
|
|
echo "GCRYPT_CFLAGS=$gcrypt_cflags" >> $config_host_mak
|
|
|
|
echo "GCRYPT_LIBS=$gcrypt_libs" >> $config_host_mak
|
2015-07-01 20:10:33 +03:00
|
|
|
fi
|
2015-10-16 18:36:53 +03:00
|
|
|
if test "$nettle" = "yes" ; then
|
|
|
|
echo "CONFIG_NETTLE=y" >> $config_host_mak
|
crypto: fix build with nettle >= 3.0.0
In nettle 3, cbc_encrypt() accepts 'nettle_cipher_func' instead of
'nettle_crypt_func' and these two differ in 'const' qualifier of the
first argument. The build fails with:
In file included from crypto/cipher.c:71:0:
./crypto/cipher-nettle.c: In function ‘qcrypto_cipher_encrypt’:
./crypto/cipher-nettle.c:154:38: error: passing argument 2 of
‘nettle_cbc_encrypt’ from incompatible pointer type
cbc_encrypt(ctx->ctx_encrypt, ctx->alg_encrypt,
^
In file included from ./crypto/cipher-nettle.c:24:0,
from crypto/cipher.c:71:
/usr/include/nettle/cbc.h:48:1: note: expected
‘void (*)(const void *, size_t, uint8_t *, const uint8_t *)
but argument is of type
‘void (*)( void *, size_t, uint8_t *, const uint8_t *)
To allow both versions, we switch to the new definition and #if typedef
it for old versions.
Signed-off-by: Radim Krčmář <rkrcmar@redhat.com>
Message-Id: <1436548682-9315-2-git-send-email-rkrcmar@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
2015-07-10 20:18:00 +03:00
|
|
|
echo "CONFIG_NETTLE_VERSION_MAJOR=${nettle_version%%.*}" >> $config_host_mak
|
2020-08-19 15:44:56 +03:00
|
|
|
echo "NETTLE_CFLAGS=$nettle_cflags" >> $config_host_mak
|
|
|
|
echo "NETTLE_LIBS=$nettle_libs" >> $config_host_mak
|
2015-07-01 20:10:34 +03:00
|
|
|
fi
|
2019-10-14 19:28:27 +03:00
|
|
|
if test "$qemu_private_xts" = "yes" ; then
|
|
|
|
echo "CONFIG_QEMU_PRIVATE_XTS=y" >> $config_host_mak
|
|
|
|
fi
|
2015-04-13 16:01:39 +03:00
|
|
|
if test "$tasn1" = "yes" ; then
|
|
|
|
echo "CONFIG_TASN1=y" >> $config_host_mak
|
|
|
|
fi
|
authz: add QAuthZPAM object type for authorizing using PAM
Add an authorization backend that talks to PAM to check whether the user
identity is allowed. This only uses the PAM account validation facility,
which is essentially just a check to see if the provided username is permitted
access. It doesn't use the authentication or session parts of PAM, since
that's dealt with by the relevant part of QEMU (eg VNC server).
Consider starting QEMU with a VNC server and telling it to use TLS with
x509 client certificates and configuring it to use an PAM to validate
the x509 distinguished name. In this example we're telling it to use PAM
for the QAuthZ impl with a service name of "qemu-vnc"
$ qemu-system-x86_64 \
-object tls-creds-x509,id=tls0,dir=/home/berrange/security/qemutls,\
endpoint=server,verify-peer=yes \
-object authz-pam,id=authz0,service=qemu-vnc \
-vnc :1,tls-creds=tls0,tls-authz=authz0
This requires an /etc/pam/qemu-vnc file to be created with the auth
rules. A very simple file based whitelist can be setup using
$ cat > /etc/pam/qemu-vnc <<EOF
account requisite pam_listfile.so item=user sense=allow file=/etc/qemu/vnc.allow
EOF
The /etc/qemu/vnc.allow file simply contains one username per line. Any
username not in the file is denied. The usernames in this example are
the x509 distinguished name from the client's x509 cert.
$ cat > /etc/qemu/vnc.allow <<EOF
CN=laptop.berrange.com,O=Berrange Home,L=London,ST=London,C=GB
EOF
More interesting would be to configure PAM to use an LDAP backend, so
that the QEMU authorization check data can be centralized instead of
requiring each compute host to have file maintained.
The main limitation with this PAM module is that the rules apply to all
QEMU instances on the host. Setting up different rules per VM, would
require creating a separate PAM service name & config file for every
guest. An alternative approach for the future might be to not pass in
the plain username to PAM, but instead combine the VM name or UUID with
the username. This requires further consideration though.
Tested-by: Philippe Mathieu-Daudé <philmd@redhat.com>
Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com>
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
2016-07-27 16:13:56 +03:00
|
|
|
if test "$auth_pam" = "yes" ; then
|
|
|
|
echo "CONFIG_AUTH_PAM=y" >> $config_host_mak
|
|
|
|
fi
|
2016-10-11 18:46:23 +03:00
|
|
|
if test "$have_broken_size_max" = "yes" ; then
|
|
|
|
echo "HAVE_BROKEN_SIZE_MAX=y" >> $config_host_mak
|
|
|
|
fi
|
2020-06-29 15:13:24 +03:00
|
|
|
if test "$have_openpty" = "yes" ; then
|
|
|
|
echo "HAVE_OPENPTY=y" >> $config_host_mak
|
|
|
|
fi
|
2016-04-29 20:15:23 +03:00
|
|
|
|
|
|
|
# Work around a system header bug with some kernel/XFS header
|
|
|
|
# versions where they both try to define 'struct fsxattr':
|
|
|
|
# xfs headers will not try to redefine structs from linux headers
|
|
|
|
# if this macro is set.
|
|
|
|
if test "$have_fsxattr" = "yes" ; then
|
|
|
|
echo "HAVE_FSXATTR=y" >> $config_host_mak
|
|
|
|
fi
|
2018-06-01 12:26:43 +03:00
|
|
|
if test "$have_copy_file_range" = "yes" ; then
|
|
|
|
echo "HAVE_COPY_FILE_RANGE=y" >> $config_host_mak
|
|
|
|
fi
|
2014-02-19 10:04:34 +04:00
|
|
|
if test "$vte" = "yes" ; then
|
|
|
|
echo "CONFIG_VTE=y" >> $config_host_mak
|
2013-02-20 17:43:20 +04:00
|
|
|
echo "VTE_CFLAGS=$vte_cflags" >> $config_host_mak
|
2018-03-01 13:05:44 +03:00
|
|
|
echo "VTE_LIBS=$vte_libs" >> $config_host_mak
|
2013-02-20 17:43:20 +04:00
|
|
|
fi
|
2014-07-11 14:51:43 +04:00
|
|
|
if test "$virglrenderer" = "yes" ; then
|
|
|
|
echo "CONFIG_VIRGL=y" >> $config_host_mak
|
|
|
|
echo "VIRGL_CFLAGS=$virgl_cflags" >> $config_host_mak
|
|
|
|
echo "VIRGL_LIBS=$virgl_libs" >> $config_host_mak
|
|
|
|
fi
|
2020-09-18 11:57:25 +03:00
|
|
|
if test "$xen" = "enabled" ; then
|
2011-06-22 00:59:07 +04:00
|
|
|
echo "CONFIG_XEN_BACKEND=y" >> $config_host_mak
|
2011-02-25 19:20:34 +03:00
|
|
|
echo "CONFIG_XEN_CTRL_INTERFACE_VERSION=$xen_ctrl_version" >> $config_host_mak
|
2019-08-15 14:15:32 +03:00
|
|
|
echo "XEN_CFLAGS=$xen_cflags" >> $config_host_mak
|
|
|
|
echo "XEN_LIBS=$xen_libs" >> $config_host_mak
|
2009-04-22 19:19:10 +04:00
|
|
|
fi
|
2009-08-20 18:58:35 +04:00
|
|
|
if test "$linux_aio" = "yes" ; then
|
|
|
|
echo "CONFIG_LINUX_AIO=y" >> $config_host_mak
|
|
|
|
fi
|
2020-01-20 17:18:44 +03:00
|
|
|
if test "$linux_io_uring" = "yes" ; then
|
|
|
|
echo "CONFIG_LINUX_IO_URING=y" >> $config_host_mak
|
|
|
|
echo "LINUX_IO_URING_CFLAGS=$linux_io_uring_cflags" >> $config_host_mak
|
|
|
|
echo "LINUX_IO_URING_LIBS=$linux_io_uring_libs" >> $config_host_mak
|
|
|
|
fi
|
vhost-scsi: new device supporting the tcm_vhost Linux kernel module
The WWPN specified in configfs is passed to "-device vhost-scsi-pci".
The tgpt field of the SET_ENDPOINT ioctl is obsolete now, so it is not
available from the QEMU command-line. Instead, I hardcode it to zero.
Changes in Patch-v2:
- Add vhost_scsi_get_features() in order to determine feature bits
supports by host kernel (mst + nab)
- Re-enable usage of DEFINE_VIRTIO_COMMON_FEATURES, and allow
EVENT_IDX to be disabled by host in vhost_scsi_get_features()
- Drop unused hotplug bit in DEFINE_VHOST_SCSI_PROPERTIES
Changes in Patch-v1:
- Set event_idx=off by default (nab, thanks asias)
- Disable hotplug feature bit for v3.9 tcm_vhost kernel code, need to
re-enable in v3.10 (nab)
- Update to latest qemu.git/master HEAD
Changes in WIP-V3:
- Drop ioeventfd vhost_scsi_properties (asias, thanks stefanha)
- Add CONFIG_VHOST_SCSI (asias, thanks stefanha)
- Add hotplug feature bit
Changes in WIP-V2:
- Add backend guest masking support (nab)
- Bump ABI_VERSION to 1 (nab)
- Set up set_guest_notifiers (asias)
- Set up vs->dev.vq_index (asias)
- Drop vs->vs.vdev.{set,clear}_vhost_endpoint (asias)
- Drop VIRTIO_CONFIG_S_DRIVER check in vhost_scsi_set_status (asias)
Howto:
Use the latest seabios, at least commit b44a7be17b
git clone git://git.seabios.org/seabios.git
make
cp out/bios.bin /usr/share/qemu/bios.bin
qemu -device vhost-scsi-pci,wwpn=naa.6001405bd4e8476d,event_idx=off
...
Cc: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Nicholas Bellinger <nab@linux-iscsi.org>
Signed-off-by: Asias He <asias@redhat.com>
[ Rebase on top of VirtIOSCSICommon patch, fix bugs in feature
negotiation and irqfd masking - Paolo ]
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
2013-03-29 05:08:16 +04:00
|
|
|
if test "$vhost_scsi" = "yes" ; then
|
|
|
|
echo "CONFIG_VHOST_SCSI=y" >> $config_host_mak
|
|
|
|
fi
|
2019-02-14 20:35:52 +03:00
|
|
|
if test "$vhost_net" = "yes" ; then
|
|
|
|
echo "CONFIG_VHOST_NET=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
if test "$vhost_net_user" = "yes" ; then
|
2019-02-14 20:35:49 +03:00
|
|
|
echo "CONFIG_VHOST_NET_USER=y" >> $config_host_mak
|
2014-06-10 14:02:16 +04:00
|
|
|
fi
|
2020-07-01 17:55:37 +03:00
|
|
|
if test "$vhost_net_vdpa" = "yes" ; then
|
|
|
|
echo "CONFIG_VHOST_NET_VDPA=y" >> $config_host_mak
|
|
|
|
fi
|
2018-03-01 16:46:28 +03:00
|
|
|
if test "$vhost_crypto" = "yes" ; then
|
|
|
|
echo "CONFIG_VHOST_CRYPTO=y" >> $config_host_mak
|
|
|
|
fi
|
2016-08-16 15:27:22 +03:00
|
|
|
if test "$vhost_vsock" = "yes" ; then
|
|
|
|
echo "CONFIG_VHOST_VSOCK=y" >> $config_host_mak
|
2020-05-22 15:25:11 +03:00
|
|
|
if test "$vhost_user" = "yes" ; then
|
|
|
|
echo "CONFIG_VHOST_USER_VSOCK=y" >> $config_host_mak
|
|
|
|
fi
|
2016-08-16 15:27:22 +03:00
|
|
|
fi
|
2019-02-14 20:35:53 +03:00
|
|
|
if test "$vhost_kernel" = "yes" ; then
|
|
|
|
echo "CONFIG_VHOST_KERNEL=y" >> $config_host_mak
|
|
|
|
fi
|
2017-08-03 12:07:46 +03:00
|
|
|
if test "$vhost_user" = "yes" ; then
|
|
|
|
echo "CONFIG_VHOST_USER=y" >> $config_host_mak
|
|
|
|
fi
|
2020-07-01 17:55:37 +03:00
|
|
|
if test "$vhost_vdpa" = "yes" ; then
|
|
|
|
echo "CONFIG_VHOST_VDPA=y" >> $config_host_mak
|
|
|
|
fi
|
2019-09-30 13:51:34 +03:00
|
|
|
if test "$vhost_user_fs" = "yes" ; then
|
|
|
|
echo "CONFIG_VHOST_USER_FS=y" >> $config_host_mak
|
|
|
|
fi
|
2008-12-05 23:05:26 +03:00
|
|
|
if test "$iovec" = "yes" ; then
|
2009-07-27 18:13:25 +04:00
|
|
|
echo "CONFIG_IOVEC=y" >> $config_host_mak
|
2008-12-05 23:05:26 +03:00
|
|
|
fi
|
2009-04-07 22:43:28 +04:00
|
|
|
if test "$preadv" = "yes" ; then
|
2009-07-27 18:13:25 +04:00
|
|
|
echo "CONFIG_PREADV=y" >> $config_host_mak
|
2009-04-07 22:43:28 +04:00
|
|
|
fi
|
2018-02-16 12:05:23 +03:00
|
|
|
if test "$membarrier" = "yes" ; then
|
|
|
|
echo "CONFIG_MEMBARRIER=y" >> $config_host_mak
|
|
|
|
fi
|
2010-10-11 22:31:15 +04:00
|
|
|
if test "$signalfd" = "yes" ; then
|
|
|
|
echo "CONFIG_SIGNALFD=y" >> $config_host_mak
|
|
|
|
fi
|
qemu-io: Add generic function for reinitializing optind.
On FreeBSD 11.2:
$ nbdkit memory size=1M --run './qemu-io -f raw -c "aio_write 0 512" $nbd'
Parsing error: non-numeric argument, or extraneous/unrecognized suffix -- aio_write
After main option parsing, we reinitialize optind so we can parse each
command. However reinitializing optind to 0 does not work on FreeBSD.
What happens when you do this is optind remains 0 after the option
parsing loop, and the result is we try to parse argv[optind] ==
argv[0] == "aio_write" as if it was the first parameter.
The FreeBSD manual page says:
In order to use getopt() to evaluate multiple sets of arguments, or to
evaluate a single set of arguments multiple times, the variable optreset
must be set to 1 before the second and each additional set of calls to
getopt(), and the variable optind must be reinitialized.
(From the rest of the man page it is clear that optind must be
reinitialized to 1).
The glibc man page says:
A program that scans multiple argument vectors, or rescans the same
vector more than once, and wants to make use of GNU extensions such as
'+' and '-' at the start of optstring, or changes the value of
POSIXLY_CORRECT between scans, must reinitialize getopt() by resetting
optind to 0, rather than the traditional value of 1. (Resetting to 0
forces the invocation of an internal initialization routine that
rechecks POSIXLY_CORRECT and checks for GNU extensions in optstring.)
This commit introduces an OS-portability function called
qemu_reset_optind which provides a way of resetting optind that works
on FreeBSD and platforms that use optreset, while keeping it the same
as now on other platforms.
Note that the qemu codebase sets optind in many other places, but in
those other places it's setting a local variable and not using getopt.
This change is only needed in places where we are using getopt and the
associated global variable optind.
Signed-off-by: Richard W.M. Jones <rjones@redhat.com>
Message-id: 20190118101114.11759-2-rjones@redhat.com
Reviewed-by: Daniel P. Berrangé <berrange@redhat.com>
Reviewed-by: Eric Blake <eblake@redhat.com>
Signed-off-by: Max Reitz <mreitz@redhat.com>
2019-01-18 13:11:14 +03:00
|
|
|
if test "$optreset" = "yes" ; then
|
|
|
|
echo "HAVE_OPTRESET=y" >> $config_host_mak
|
|
|
|
fi
|
2020-09-18 11:57:25 +03:00
|
|
|
if test "$tcg" = "enabled"; then
|
2017-07-03 17:59:07 +03:00
|
|
|
if test "$tcg_interpreter" = "yes" ; then
|
|
|
|
echo "CONFIG_TCG_INTERPRETER=y" >> $config_host_mak
|
|
|
|
fi
|
2011-10-19 09:07:18 +04:00
|
|
|
fi
|
2009-09-20 10:56:26 +04:00
|
|
|
if test "$fdatasync" = "yes" ; then
|
|
|
|
echo "CONFIG_FDATASYNC=y" >> $config_host_mak
|
|
|
|
fi
|
2010-09-25 15:26:05 +04:00
|
|
|
if test "$madvise" = "yes" ; then
|
|
|
|
echo "CONFIG_MADVISE=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
if test "$posix_madvise" = "yes" ; then
|
|
|
|
echo "CONFIG_POSIX_MADVISE=y" >> $config_host_mak
|
|
|
|
fi
|
2018-01-04 20:39:36 +03:00
|
|
|
if test "$posix_memalign" = "yes" ; then
|
|
|
|
echo "CONFIG_POSIX_MEMALIGN=y" >> $config_host_mak
|
|
|
|
fi
|
2010-03-24 12:26:51 +03:00
|
|
|
if test "$spice" = "yes" ; then
|
|
|
|
echo "CONFIG_SPICE=y" >> $config_host_mak
|
2019-07-29 16:40:07 +03:00
|
|
|
echo "SPICE_CFLAGS=$spice_cflags" >> $config_host_mak
|
|
|
|
echo "SPICE_LIBS=$spice_libs" >> $config_host_mak
|
2010-03-24 12:26:51 +03:00
|
|
|
fi
|
2010-10-17 13:40:07 +04:00
|
|
|
|
2015-08-30 12:48:40 +03:00
|
|
|
if test "$smartcard" = "yes" ; then
|
|
|
|
echo "CONFIG_SMARTCARD=y" >> $config_host_mak
|
2017-09-07 11:29:16 +03:00
|
|
|
echo "SMARTCARD_CFLAGS=$libcacard_cflags" >> $config_host_mak
|
|
|
|
echo "SMARTCARD_LIBS=$libcacard_libs" >> $config_host_mak
|
libcacard: initial commit
libcacard emulates a Common Access Card (CAC) which is a standard
for smartcards. It is used by the emulated ccid card introduced in
a following patch. Docs are available in docs/libcacard.txt
Signed-off-by: Alon Levy <alevy@redhat.com>
---
changes from v24->v25:
* Fix out of tree builds.
* Fix build with linux-user targets.
changes from v23->v24: (Jes Sorensen review 2)
* Makefile.target: use obj-$(CONFIG_*) +=
* remove unrequired includes, include qemu-common before qemu-thread
* required adding #define NO_NSPR_10_SUPPORT (harmless)
changes from v22->v23:
* configure fixes: (reported by Stefan Hajnoczi)
* test a = b, not a == b (second isn't portable)
* quote $source_path in case it contains spaces
- this doesn't really help since there are many other places
that need similar fixes, not introduced by this patch.
changes from v21->v22:
* fix configure to not link libcacard if nss not found
(reported by Stefan Hajnoczi)
* fix vscclient linkage with simpletrace backend
(reported by Stefan Hajnoczi)
* card_7816.c: add missing break in ERROR_DATA_NOT_FOUND
(reported by William van de Velde)
changes from v20->v21: (Jes Sorensen review)
* use qemu infrastructure: qemu-thread, qemu-common (qemu_malloc
and qemu_free), error_report
* assert instead of ASSERT
* cosmetic fixes
* use strpbrk and isspace
* add --disable-nss --enable-nss here, instead of in the final patch.
* split vscclient, passthru and docs to following patches.
changes from v19->v20:
* checkpatch.pl
changes from v15->v16:
Build:
* don't erase self with distclean
* fix make clean after make distclean
* Makefile: make vscclient link quiet
Behavioral:
* vcard_emul_nss: load coolkey in more situations
* vscclient:
* use hton,ntoh
* send init on connect, only start vevent thread on response
* read payload after header check, before type switch
* remove Reconnect
* update for vscard_common changes, empty Flush implementation
Style/Whitespace:
* fix wrong variable usage
* remove unused variable
* use only C style comments
* add copyright header
* fix tabulation
Signed-off-by: Alon Levy <alevy@redhat.com>
libcacard: fix out of tree builds
2010-11-28 17:36:38 +03:00
|
|
|
fi
|
|
|
|
|
2012-11-30 19:02:11 +04:00
|
|
|
if test "$libusb" = "yes" ; then
|
|
|
|
echo "CONFIG_USB_LIBUSB=y" >> $config_host_mak
|
2017-09-07 11:29:17 +03:00
|
|
|
echo "LIBUSB_CFLAGS=$libusb_cflags" >> $config_host_mak
|
|
|
|
echo "LIBUSB_LIBS=$libusb_libs" >> $config_host_mak
|
2012-11-30 19:02:11 +04:00
|
|
|
fi
|
|
|
|
|
2011-07-19 13:04:10 +04:00
|
|
|
if test "$usb_redir" = "yes" ; then
|
|
|
|
echo "CONFIG_USB_REDIR=y" >> $config_host_mak
|
2017-09-07 11:29:18 +03:00
|
|
|
echo "USB_REDIR_CFLAGS=$usb_redir_cflags" >> $config_host_mak
|
|
|
|
echo "USB_REDIR_LIBS=$usb_redir_libs" >> $config_host_mak
|
2011-07-19 13:04:10 +04:00
|
|
|
fi
|
|
|
|
|
2014-11-20 11:49:44 +03:00
|
|
|
if test "$opengl" = "yes" ; then
|
|
|
|
echo "CONFIG_OPENGL=y" >> $config_host_mak
|
2020-09-01 15:41:17 +03:00
|
|
|
echo "OPENGL_CFLAGS=$opengl_cflags" >> $config_host_mak
|
2014-11-20 11:49:44 +03:00
|
|
|
echo "OPENGL_LIBS=$opengl_libs" >> $config_host_mak
|
2015-12-03 14:56:34 +03:00
|
|
|
if test "$opengl_dmabuf" = "yes" ; then
|
|
|
|
echo "CONFIG_OPENGL_DMABUF=y" >> $config_host_mak
|
|
|
|
fi
|
2011-03-08 01:32:39 +03:00
|
|
|
fi
|
|
|
|
|
2019-05-24 16:09:42 +03:00
|
|
|
if test "$gbm" = "yes" ; then
|
|
|
|
echo "CONFIG_GBM=y" >> $config_host_mak
|
|
|
|
echo "GBM_LIBS=$gbm_libs" >> $config_host_mak
|
|
|
|
echo "GBM_CFLAGS=$gbm_cflags" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
2016-03-08 08:53:16 +03:00
|
|
|
if test "$avx2_opt" = "yes" ; then
|
|
|
|
echo "CONFIG_AVX2_OPT=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
|
2020-02-29 15:34:34 +03:00
|
|
|
if test "$avx512f_opt" = "yes" ; then
|
|
|
|
echo "CONFIG_AVX512F_OPT=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
|
2004-07-06 01:25:26 +04:00
|
|
|
# XXX: suppress that
|
2004-05-12 23:32:15 +04:00
|
|
|
if [ "$bsd" = "yes" ] ; then
|
2009-07-27 18:13:25 +04:00
|
|
|
echo "CONFIG_BSD=y" >> $config_host_mak
|
2004-05-12 23:32:15 +04:00
|
|
|
fi
|
|
|
|
|
2013-05-10 16:16:40 +04:00
|
|
|
if test "$qom_cast_debug" = "yes" ; then
|
|
|
|
echo "CONFIG_QOM_CAST_DEBUG=y" >> $config_host_mak
|
|
|
|
fi
|
2011-06-09 21:41:06 +04:00
|
|
|
|
2013-04-08 15:11:27 +04:00
|
|
|
echo "CONFIG_COROUTINE_BACKEND=$coroutine" >> $config_host_mak
|
2013-09-11 18:42:35 +04:00
|
|
|
if test "$coroutine_pool" = "yes" ; then
|
|
|
|
echo "CONFIG_COROUTINE_POOL=1" >> $config_host_mak
|
|
|
|
else
|
|
|
|
echo "CONFIG_COROUTINE_POOL=0" >> $config_host_mak
|
|
|
|
fi
|
2009-12-09 21:59:36 +03:00
|
|
|
|
2016-09-27 12:58:45 +03:00
|
|
|
if test "$debug_stack_usage" = "yes" ; then
|
|
|
|
echo "CONFIG_DEBUG_STACK_USAGE=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
|
2017-07-14 21:04:05 +03:00
|
|
|
if test "$crypto_afalg" = "yes" ; then
|
|
|
|
echo "CONFIG_AF_ALG=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
|
2011-10-12 17:41:24 +04:00
|
|
|
if test "$open_by_handle_at" = "yes" ; then
|
|
|
|
echo "CONFIG_OPEN_BY_HANDLE=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
|
2011-10-12 17:41:25 +04:00
|
|
|
if test "$linux_magic_h" = "yes" ; then
|
|
|
|
echo "CONFIG_LINUX_MAGIC_H=y" >> $config_host_mak
|
2012-05-23 22:48:04 +04:00
|
|
|
fi
|
|
|
|
|
2012-06-29 15:40:27 +04:00
|
|
|
if test "$valgrind_h" = "yes" ; then
|
|
|
|
echo "CONFIG_VALGRIND_H=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
|
2018-01-16 18:11:52 +03:00
|
|
|
if test "$have_asan_iface_fiber" = "yes" ; then
|
|
|
|
echo "CONFIG_ASAN_IFACE_FIBER=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
|
2020-06-12 22:02:23 +03:00
|
|
|
if test "$have_tsan" = "yes" && test "$have_tsan_iface_fiber" = "yes" ; then
|
|
|
|
echo "CONFIG_TSAN=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
|
2012-05-23 22:48:04 +04:00
|
|
|
if test "$has_environ" = "yes" ; then
|
|
|
|
echo "CONFIG_HAS_ENVIRON=y" >> $config_host_mak
|
2011-10-12 17:41:25 +04:00
|
|
|
fi
|
|
|
|
|
2012-12-29 02:17:02 +04:00
|
|
|
if test "$cpuid_h" = "yes" ; then
|
|
|
|
echo "CONFIG_CPUID_H=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
|
2013-02-17 00:46:59 +04:00
|
|
|
if test "$int128" = "yes" ; then
|
|
|
|
echo "CONFIG_INT128=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
|
2016-06-30 07:10:59 +03:00
|
|
|
if test "$atomic128" = "yes" ; then
|
|
|
|
echo "CONFIG_ATOMIC128=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
|
2018-08-16 02:31:47 +03:00
|
|
|
if test "$cmpxchg128" = "yes" ; then
|
|
|
|
echo "CONFIG_CMPXCHG128=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
|
2016-09-02 22:23:57 +03:00
|
|
|
if test "$atomic64" = "yes" ; then
|
|
|
|
echo "CONFIG_ATOMIC64=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
|
2019-10-14 02:12:19 +03:00
|
|
|
if test "$attralias" = "yes" ; then
|
|
|
|
echo "CONFIG_ATTRIBUTE_ALIAS=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
|
2013-02-18 21:11:15 +04:00
|
|
|
if test "$getauxval" = "yes" ; then
|
|
|
|
echo "CONFIG_GETAUXVAL=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
|
2019-06-20 23:08:40 +03:00
|
|
|
if test "$libssh" = "yes" ; then
|
2019-12-12 15:30:36 +03:00
|
|
|
echo "CONFIG_LIBSSH=y" >> $config_host_mak
|
2019-06-20 23:08:40 +03:00
|
|
|
echo "LIBSSH_CFLAGS=$libssh_cflags" >> $config_host_mak
|
|
|
|
echo "LIBSSH_LIBS=$libssh_libs" >> $config_host_mak
|
2013-04-09 18:30:53 +04:00
|
|
|
fi
|
|
|
|
|
2017-05-15 17:05:29 +03:00
|
|
|
if test "$live_block_migration" = "yes" ; then
|
|
|
|
echo "CONFIG_LIVE_BLOCK_MIGRATION=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
|
2013-03-18 19:37:50 +04:00
|
|
|
if test "$tpm" = "yes"; then
|
2019-07-11 20:08:36 +03:00
|
|
|
echo 'CONFIG_TPM=y' >> $config_host_mak
|
2013-03-18 19:37:50 +04:00
|
|
|
fi
|
|
|
|
|
2014-05-27 17:02:14 +04:00
|
|
|
echo "TRACE_BACKENDS=$trace_backends" >> $config_host_mak
|
|
|
|
if have_backend "nop"; then
|
2011-08-31 22:30:43 +04:00
|
|
|
echo "CONFIG_TRACE_NOP=y" >> $config_host_mak
|
2010-06-24 15:34:53 +04:00
|
|
|
fi
|
2014-05-27 17:02:14 +04:00
|
|
|
if have_backend "simple"; then
|
2011-08-31 22:30:43 +04:00
|
|
|
echo "CONFIG_TRACE_SIMPLE=y" >> $config_host_mak
|
|
|
|
# Set the appropriate trace file.
|
2011-06-02 21:58:06 +04:00
|
|
|
trace_file="\"$trace_file-\" FMT_pid"
|
2010-07-13 12:26:32 +04:00
|
|
|
fi
|
2016-01-07 16:55:30 +03:00
|
|
|
if have_backend "log"; then
|
|
|
|
echo "CONFIG_TRACE_LOG=y" >> $config_host_mak
|
2011-08-31 22:30:43 +04:00
|
|
|
fi
|
2014-05-27 17:02:14 +04:00
|
|
|
if have_backend "ust"; then
|
2011-08-31 22:30:43 +04:00
|
|
|
echo "CONFIG_TRACE_UST=y" >> $config_host_mak
|
2020-08-19 15:44:56 +03:00
|
|
|
echo "LTTNG_UST_LIBS=$lttng_ust_libs" >> $config_host_mak
|
|
|
|
echo "URCU_BP_LIBS=$urcu_bp_libs" >> $config_host_mak
|
2011-08-31 22:30:43 +04:00
|
|
|
fi
|
2014-05-27 17:02:14 +04:00
|
|
|
if have_backend "dtrace"; then
|
2011-08-31 22:30:43 +04:00
|
|
|
echo "CONFIG_TRACE_DTRACE=y" >> $config_host_mak
|
|
|
|
if test "$trace_backend_stap" = "yes" ; then
|
|
|
|
echo "CONFIG_TRACE_SYSTEMTAP=y" >> $config_host_mak
|
|
|
|
fi
|
2010-11-12 16:20:25 +03:00
|
|
|
fi
|
2014-05-27 17:02:14 +04:00
|
|
|
if have_backend "ftrace"; then
|
2013-04-11 15:25:15 +04:00
|
|
|
if test "$linux" = "yes" ; then
|
|
|
|
echo "CONFIG_TRACE_FTRACE=y" >> $config_host_mak
|
|
|
|
else
|
2014-01-24 05:39:10 +04:00
|
|
|
feature_not_found "ftrace(trace backend)" "ftrace requires Linux"
|
2013-04-11 15:25:15 +04:00
|
|
|
fi
|
|
|
|
fi
|
2016-08-04 16:44:14 +03:00
|
|
|
if have_backend "syslog"; then
|
|
|
|
if test "$posix_syslog" = "yes" ; then
|
|
|
|
echo "CONFIG_TRACE_SYSLOG=y" >> $config_host_mak
|
|
|
|
else
|
|
|
|
feature_not_found "syslog(trace backend)" "syslog not available"
|
|
|
|
fi
|
|
|
|
fi
|
2010-07-13 12:26:32 +04:00
|
|
|
echo "CONFIG_TRACE_FILE=$trace_file" >> $config_host_mak
|
|
|
|
|
2013-07-22 18:01:54 +04:00
|
|
|
if test "$rdma" = "yes" ; then
|
|
|
|
echo "CONFIG_RDMA=y" >> $config_host_mak
|
2017-09-07 11:42:30 +03:00
|
|
|
echo "RDMA_LIBS=$rdma_libs" >> $config_host_mak
|
2013-07-22 18:01:54 +04:00
|
|
|
fi
|
|
|
|
|
2018-08-16 18:16:37 +03:00
|
|
|
if test "$pvrdma" = "yes" ; then
|
|
|
|
echo "CONFIG_PVRDMA=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
|
2016-06-02 23:14:15 +03:00
|
|
|
if test "$have_rtnetlink" = "yes" ; then
|
|
|
|
echo "CONFIG_RTNETLINK=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
|
2018-01-12 12:01:19 +03:00
|
|
|
if test "$libxml2" = "yes" ; then
|
|
|
|
echo "CONFIG_LIBXML2=y" >> $config_host_mak
|
|
|
|
echo "LIBXML2_CFLAGS=$libxml2_cflags" >> $config_host_mak
|
|
|
|
echo "LIBXML2_LIBS=$libxml2_libs" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
|
2016-07-27 10:01:48 +03:00
|
|
|
if test "$replication" = "yes" ; then
|
|
|
|
echo "CONFIG_REPLICATION=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
|
2016-10-14 12:00:55 +03:00
|
|
|
if test "$have_af_vsock" = "yes" ; then
|
|
|
|
echo "CONFIG_AF_VSOCK=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
|
build: include sys/sysmacros.h for major() and minor()
The definition of the major() and minor() macros are moving within glibc to
<sys/sysmacros.h>. Include this header when it is available to avoid the
following sorts of build-stopping messages:
qga/commands-posix.c: In function ‘dev_major_minor’:
qga/commands-posix.c:656:13: error: In the GNU C Library, "major" is defined
by <sys/sysmacros.h>. For historical compatibility, it is
currently defined by <sys/types.h> as well, but we plan to
remove this soon. To use "major", include <sys/sysmacros.h>
directly. If you did not intend to use a system-defined macro
"major", you should undefine it after including <sys/types.h>. [-Werror]
*devmajor = major(st.st_rdev);
^~~~~~~~~~~~~~~~~~~~~~~~~~
qga/commands-posix.c:657:13: error: In the GNU C Library, "minor" is defined
by <sys/sysmacros.h>. For historical compatibility, it is
currently defined by <sys/types.h> as well, but we plan to
remove this soon. To use "minor", include <sys/sysmacros.h>
directly. If you did not intend to use a system-defined macro
"minor", you should undefine it after including <sys/types.h>. [-Werror]
*devminor = minor(st.st_rdev);
^~~~~~~~~~~~~~~~~~~~~~~~~~
The additional include allows the build to complete on Fedora 26 (Rawhide)
with glibc version 2.24.90.
Signed-off-by: Christopher Covington <cov@codeaurora.org>
Reviewed-by: Eric Blake <eblake@redhat.com>
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
2016-12-28 23:04:33 +03:00
|
|
|
if test "$have_sysmacros" = "yes" ; then
|
|
|
|
echo "CONFIG_SYSMACROS=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
|
2017-03-14 19:59:53 +03:00
|
|
|
if test "$have_static_assert" = "yes" ; then
|
|
|
|
echo "CONFIG_STATIC_ASSERT=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
|
2017-07-17 16:58:33 +03:00
|
|
|
if test "$have_utmpx" = "yes" ; then
|
|
|
|
echo "HAVE_UTMPX=y" >> $config_host_mak
|
|
|
|
fi
|
2019-03-14 06:57:28 +03:00
|
|
|
if test "$have_getrandom" = "yes" ; then
|
|
|
|
echo "CONFIG_GETRANDOM=y" >> $config_host_mak
|
|
|
|
fi
|
2017-07-14 11:33:44 +03:00
|
|
|
if test "$ivshmem" = "yes" ; then
|
|
|
|
echo "CONFIG_IVSHMEM=y" >> $config_host_mak
|
2017-09-14 19:41:12 +03:00
|
|
|
fi
|
2018-06-13 15:23:08 +03:00
|
|
|
if test "$debug_mutex" = "yes" ; then
|
|
|
|
echo "CONFIG_DEBUG_MUTEX=y" >> $config_host_mak
|
|
|
|
fi
|
2017-07-14 11:33:44 +03:00
|
|
|
|
2014-03-12 15:48:18 +04:00
|
|
|
# Hold two types of flag:
|
|
|
|
# CONFIG_THREAD_SETNAME_BYTHREAD - we've got a way of setting the name on
|
|
|
|
# a thread we have a handle to
|
2018-12-17 23:26:01 +03:00
|
|
|
# CONFIG_PTHREAD_SETNAME_NP_W_TID - A way of doing it on a particular
|
2014-03-12 15:48:18 +04:00
|
|
|
# platform
|
2018-12-17 23:26:01 +03:00
|
|
|
if test "$pthread_setname_np_w_tid" = "yes" ; then
|
|
|
|
echo "CONFIG_THREAD_SETNAME_BYTHREAD=y" >> $config_host_mak
|
|
|
|
echo "CONFIG_PTHREAD_SETNAME_NP_W_TID=y" >> $config_host_mak
|
|
|
|
elif test "$pthread_setname_np_wo_tid" = "yes" ; then
|
2014-03-12 15:48:18 +04:00
|
|
|
echo "CONFIG_THREAD_SETNAME_BYTHREAD=y" >> $config_host_mak
|
2018-12-17 23:26:01 +03:00
|
|
|
echo "CONFIG_PTHREAD_SETNAME_NP_WO_TID=y" >> $config_host_mak
|
2014-03-12 15:48:18 +04:00
|
|
|
fi
|
|
|
|
|
2018-07-18 10:47:59 +03:00
|
|
|
if test "$libpmem" = "yes" ; then
|
|
|
|
echo "CONFIG_LIBPMEM=y" >> $config_host_mak
|
2019-08-18 18:51:17 +03:00
|
|
|
echo "LIBPMEM_LIBS=$libpmem_libs" >> $config_host_mak
|
|
|
|
echo "LIBPMEM_CFLAGS=$libpmem_cflags" >> $config_host_mak
|
2018-07-18 10:47:59 +03:00
|
|
|
fi
|
|
|
|
|
2020-04-29 11:50:11 +03:00
|
|
|
if test "$libdaxctl" = "yes" ; then
|
|
|
|
echo "CONFIG_LIBDAXCTL=y" >> $config_host_mak
|
2020-08-24 18:52:12 +03:00
|
|
|
echo "LIBDAXCTL_LIBS=$libdaxctl_libs" >> $config_host_mak
|
2020-04-29 11:50:11 +03:00
|
|
|
fi
|
|
|
|
|
2018-11-07 09:36:44 +03:00
|
|
|
if test "$bochs" = "yes" ; then
|
|
|
|
echo "CONFIG_BOCHS=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
if test "$cloop" = "yes" ; then
|
|
|
|
echo "CONFIG_CLOOP=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
if test "$dmg" = "yes" ; then
|
|
|
|
echo "CONFIG_DMG=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
if test "$qcow1" = "yes" ; then
|
|
|
|
echo "CONFIG_QCOW1=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
if test "$vdi" = "yes" ; then
|
|
|
|
echo "CONFIG_VDI=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
if test "$vvfat" = "yes" ; then
|
|
|
|
echo "CONFIG_VVFAT=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
if test "$qed" = "yes" ; then
|
|
|
|
echo "CONFIG_QED=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
if test "$parallels" = "yes" ; then
|
|
|
|
echo "CONFIG_PARALLELS=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
if test "$sheepdog" = "yes" ; then
|
2020-10-02 14:32:43 +03:00
|
|
|
add_to deprecated_features "sheepdog"
|
2018-11-07 09:36:44 +03:00
|
|
|
echo "CONFIG_SHEEPDOG=y" >> $config_host_mak
|
|
|
|
fi
|
2020-07-13 16:36:09 +03:00
|
|
|
if test "$have_mlockall" = "yes" ; then
|
|
|
|
echo "HAVE_MLOCKALL=y" >> $config_host_mak
|
|
|
|
fi
|
2020-02-20 07:11:14 +03:00
|
|
|
if test "$fuzzing" = "yes" ; then
|
2020-09-02 20:36:51 +03:00
|
|
|
# If LIB_FUZZING_ENGINE is set, assume we are running on OSS-Fuzz, and the
|
|
|
|
# needed CFLAGS have already been provided
|
|
|
|
if test -z "${LIB_FUZZING_ENGINE+xxx}" ; then
|
|
|
|
QEMU_CFLAGS="$QEMU_CFLAGS -fsanitize=fuzzer-no-link"
|
|
|
|
FUZZ_EXE_LDFLAGS="-fsanitize=fuzzer"
|
|
|
|
else
|
|
|
|
FUZZ_EXE_LDFLAGS="$LIB_FUZZING_ENGINE"
|
|
|
|
fi
|
2020-02-20 07:11:14 +03:00
|
|
|
fi
|
2018-11-07 09:36:44 +03:00
|
|
|
|
2019-06-13 16:52:25 +03:00
|
|
|
if test "$plugins" = "yes" ; then
|
|
|
|
echo "CONFIG_PLUGIN=y" >> $config_host_mak
|
2018-10-21 20:56:29 +03:00
|
|
|
# Copy the export object list to the build dir
|
|
|
|
if test "$ld_dynamic_list" = "yes" ; then
|
|
|
|
echo "CONFIG_HAS_LD_DYNAMIC_LIST=yes" >> $config_host_mak
|
|
|
|
ld_symbols=qemu-plugins-ld.symbols
|
|
|
|
cp "$source_path/plugins/qemu-plugins.symbols" $ld_symbols
|
|
|
|
elif test "$ld_exported_symbols_list" = "yes" ; then
|
|
|
|
echo "CONFIG_HAS_LD_EXPORTED_SYMBOLS_LIST=yes" >> $config_host_mak
|
|
|
|
ld64_symbols=qemu-plugins-ld64.symbols
|
|
|
|
echo "# Automatically generated by configure - do not modify" > $ld64_symbols
|
|
|
|
grep 'qemu_' "$source_path/plugins/qemu-plugins.symbols" | sed 's/;//g' | \
|
|
|
|
sed -E 's/^[[:space:]]*(.*)/_\1/' >> $ld64_symbols
|
|
|
|
else
|
|
|
|
error_exit \
|
|
|
|
"If \$plugins=yes, either \$ld_dynamic_list or " \
|
|
|
|
"\$ld_exported_symbols_list should have been set to 'yes'."
|
|
|
|
fi
|
2019-06-13 16:52:25 +03:00
|
|
|
fi
|
|
|
|
|
2020-03-16 20:21:48 +03:00
|
|
|
if test -n "$gdb_bin" ; then
|
|
|
|
echo "HAVE_GDB_BIN=$gdb_bin" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
|
2020-05-25 14:19:12 +03:00
|
|
|
if test "$secret_keyring" = "yes" ; then
|
|
|
|
echo "CONFIG_SECRET_KEYRING=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
|
2009-07-16 20:34:18 +04:00
|
|
|
echo "ROMS=$roms" >> $config_host_mak
|
2009-07-27 18:12:49 +04:00
|
|
|
echo "MAKE=$make" >> $config_host_mak
|
2011-07-23 01:08:09 +04:00
|
|
|
echo "PYTHON=$python" >> $config_host_mak
|
2020-03-03 18:06:20 +03:00
|
|
|
echo "GENISOIMAGE=$genisoimage" >> $config_host_mak
|
2019-06-10 13:05:14 +03:00
|
|
|
echo "MESON=$meson" >> $config_host_mak
|
2020-08-13 16:28:11 +03:00
|
|
|
echo "NINJA=$ninja" >> $config_host_mak
|
2009-07-27 18:12:49 +04:00
|
|
|
echo "CC=$cc" >> $config_host_mak
|
2013-07-24 19:56:03 +04:00
|
|
|
if $iasl -h > /dev/null 2>&1; then
|
2020-08-04 19:14:26 +03:00
|
|
|
echo "CONFIG_IASL=$iasl" >> $config_host_mak
|
2013-07-24 19:56:03 +04:00
|
|
|
fi
|
2013-08-07 19:39:36 +04:00
|
|
|
echo "CXX=$cxx" >> $config_host_mak
|
2012-08-12 01:34:40 +04:00
|
|
|
echo "OBJCC=$objcc" >> $config_host_mak
|
2009-07-27 18:12:49 +04:00
|
|
|
echo "AR=$ar" >> $config_host_mak
|
2013-10-22 00:03:06 +04:00
|
|
|
echo "ARFLAGS=$ARFLAGS" >> $config_host_mak
|
2016-07-08 07:49:36 +03:00
|
|
|
echo "AS=$as" >> $config_host_mak
|
2016-06-23 20:39:18 +03:00
|
|
|
echo "CCAS=$ccas" >> $config_host_mak
|
2013-01-05 14:10:27 +04:00
|
|
|
echo "CPP=$cpp" >> $config_host_mak
|
2009-07-27 18:12:49 +04:00
|
|
|
echo "OBJCOPY=$objcopy" >> $config_host_mak
|
|
|
|
echo "LD=$ld" >> $config_host_mak
|
2017-11-08 04:10:46 +03:00
|
|
|
echo "RANLIB=$ranlib" >> $config_host_mak
|
2014-09-18 23:55:08 +04:00
|
|
|
echo "NM=$nm" >> $config_host_mak
|
2019-09-19 16:07:36 +03:00
|
|
|
echo "PKG_CONFIG=$pkg_config_exe" >> $config_host_mak
|
2010-09-26 20:07:57 +04:00
|
|
|
echo "WINDRES=$windres" >> $config_host_mak
|
2013-12-11 04:49:08 +04:00
|
|
|
echo "CFLAGS_NOPIE=$CFLAGS_NOPIE" >> $config_host_mak
|
2009-08-03 16:46:21 +04:00
|
|
|
echo "QEMU_CFLAGS=$QEMU_CFLAGS" >> $config_host_mak
|
2017-06-06 16:07:47 +03:00
|
|
|
echo "QEMU_CXXFLAGS=$QEMU_CXXFLAGS" >> $config_host_mak
|
2020-08-19 15:44:56 +03:00
|
|
|
echo "GLIB_CFLAGS=$glib_cflags" >> $config_host_mak
|
|
|
|
echo "GLIB_LIBS=$glib_libs" >> $config_host_mak
|
2018-04-16 02:05:19 +03:00
|
|
|
echo "QEMU_LDFLAGS=$QEMU_LDFLAGS" >> $config_host_mak
|
2016-08-08 19:11:28 +03:00
|
|
|
echo "LD_I386_EMULATION=$ld_i386_emulation" >> $config_host_mak
|
2009-07-27 18:12:49 +04:00
|
|
|
echo "EXESUF=$EXESUF" >> $config_host_mak
|
2019-12-12 15:30:36 +03:00
|
|
|
echo "HOST_DSOSUF=$HOST_DSOSUF" >> $config_host_mak
|
2019-07-18 14:19:02 +03:00
|
|
|
echo "LIBS_QGA=$libs_qga" >> $config_host_mak
|
2015-09-21 19:25:34 +03:00
|
|
|
echo "TASN1_LIBS=$tasn1_libs" >> $config_host_mak
|
|
|
|
echo "TASN1_CFLAGS=$tasn1_cflags" >> $config_host_mak
|
2012-05-01 22:45:39 +04:00
|
|
|
if test "$gcov" = "yes" ; then
|
|
|
|
echo "CONFIG_GCOV=y" >> $config_host_mak
|
|
|
|
fi
|
2009-07-27 18:12:49 +04:00
|
|
|
|
2020-02-20 07:11:14 +03:00
|
|
|
if test "$fuzzing" != "no"; then
|
|
|
|
echo "CONFIG_FUZZ=y" >> $config_host_mak
|
|
|
|
fi
|
2020-09-02 20:36:51 +03:00
|
|
|
echo "FUZZ_EXE_LDFLAGS=$FUZZ_EXE_LDFLAGS" >> $config_host_mak
|
2018-10-23 14:23:10 +03:00
|
|
|
|
2020-05-20 16:20:23 +03:00
|
|
|
if test "$rng_none" = "yes"; then
|
|
|
|
echo "CONFIG_RNG_NONE=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
|
2011-11-30 15:59:04 +04:00
|
|
|
# use included Linux headers
|
|
|
|
if test "$linux" = "yes" ; then
|
2012-06-14 19:14:33 +04:00
|
|
|
mkdir -p linux-headers
|
2011-11-30 15:59:04 +04:00
|
|
|
case "$cpu" in
|
2013-08-20 23:20:05 +04:00
|
|
|
i386|x86_64|x32)
|
2012-08-03 16:51:25 +04:00
|
|
|
linux_arch=x86
|
2011-11-30 15:59:04 +04:00
|
|
|
;;
|
2019-05-02 01:38:18 +03:00
|
|
|
ppc|ppc64|ppc64le)
|
2012-08-03 16:51:25 +04:00
|
|
|
linux_arch=powerpc
|
2011-11-30 15:59:04 +04:00
|
|
|
;;
|
|
|
|
s390x)
|
2012-08-03 16:51:25 +04:00
|
|
|
linux_arch=s390
|
|
|
|
;;
|
2013-06-12 19:20:23 +04:00
|
|
|
aarch64)
|
|
|
|
linux_arch=arm64
|
|
|
|
;;
|
2014-06-18 02:10:36 +04:00
|
|
|
mips64)
|
|
|
|
linux_arch=mips
|
|
|
|
;;
|
2012-08-03 16:51:25 +04:00
|
|
|
*)
|
|
|
|
# For most CPUs the kernel architecture name and QEMU CPU name match.
|
|
|
|
linux_arch="$cpu"
|
2011-11-30 15:59:04 +04:00
|
|
|
;;
|
|
|
|
esac
|
2012-08-03 16:51:25 +04:00
|
|
|
# For non-KVM architectures we will not have asm headers
|
|
|
|
if [ -e "$source_path/linux-headers/asm-$linux_arch" ]; then
|
|
|
|
symlink "$source_path/linux-headers/asm-$linux_arch" linux-headers/asm
|
|
|
|
fi
|
2011-11-30 15:59:04 +04:00
|
|
|
fi
|
|
|
|
|
2005-10-30 21:58:22 +03:00
|
|
|
for target in $target_list; do
|
2020-09-21 11:37:49 +03:00
|
|
|
target_dir="$target"
|
|
|
|
target_name=$(echo $target | cut -d '-' -f 1)
|
|
|
|
mkdir -p $target_dir
|
|
|
|
case $target in
|
|
|
|
*-user) symlink "../qemu-$target_name" "$target_dir/qemu-$target_name" ;;
|
|
|
|
*) symlink "../qemu-system-$target_name" "$target_dir/qemu-system-$target_name" ;;
|
|
|
|
esac
|
|
|
|
done
|
2003-03-07 02:23:54 +03:00
|
|
|
|
2020-09-18 13:37:21 +03:00
|
|
|
echo "CONFIG_QEMU_INTERP_PREFIX=$interp_prefix" | sed 's/%M/@0@/' >> $config_host_mak
|
2020-09-21 11:37:49 +03:00
|
|
|
if test "$default_targets" = "yes"; then
|
|
|
|
echo "CONFIG_DEFAULT_TARGETS=y" >> $config_host_mak
|
|
|
|
fi
|
2013-04-18 08:47:31 +04:00
|
|
|
|
2014-05-14 13:43:28 +04:00
|
|
|
if test "$numa" = "yes"; then
|
|
|
|
echo "CONFIG_NUMA=y" >> $config_host_mak
|
2019-07-24 18:23:16 +03:00
|
|
|
echo "NUMA_LIBS=$numa_libs" >> $config_host_mak
|
2014-05-14 13:43:28 +04:00
|
|
|
fi
|
|
|
|
|
2015-03-26 01:57:39 +03:00
|
|
|
if test "$ccache_cpp2" = "yes"; then
|
|
|
|
echo "export CCACHE_CPP2=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
|
2020-05-29 23:51:21 +03:00
|
|
|
if test "$safe_stack" = "yes"; then
|
|
|
|
echo "CONFIG_SAFESTACK=y" >> $config_host_mak
|
|
|
|
fi
|
|
|
|
|
2018-11-02 14:52:38 +03:00
|
|
|
# If we're using a separate build tree, set it up now.
|
|
|
|
# DIRS are directories which we simply mkdir in the build tree;
|
|
|
|
# LINKS are things to symlink back into the source tree
|
|
|
|
# (these can be both files and directories).
|
|
|
|
# Caution: do not add files or directories here using wildcards. This
|
|
|
|
# will result in problems later if a new file matching the wildcard is
|
|
|
|
# added to the source tree -- nothing will cause configure to be rerun
|
|
|
|
# so the build tree will be missing the link back to the new file, and
|
|
|
|
# tests might fail. Prefer to keep the relevant files in their own
|
|
|
|
# directory and symlink the directory instead.
|
2020-08-27 13:26:17 +03:00
|
|
|
# UNLINK is used to remove symlinks from older development versions
|
|
|
|
# that might get into the way when doing "git update" without doing
|
|
|
|
# a "make distclean" in between.
|
2019-09-10 17:41:20 +03:00
|
|
|
DIRS="tests tests/tcg tests/tcg/lm32 tests/qapi-schema tests/qtest/libqos"
|
|
|
|
DIRS="$DIRS tests/qtest tests/qemu-iotests tests/vm tests/fp tests/qgraph"
|
2017-08-22 07:50:18 +03:00
|
|
|
DIRS="$DIRS docs docs/interop fsdev scsi"
|
2019-07-16 08:27:43 +03:00
|
|
|
DIRS="$DIRS pc-bios/optionrom pc-bios/s390-ccw"
|
2020-06-22 16:12:40 +03:00
|
|
|
DIRS="$DIRS roms/seabios"
|
2020-09-09 14:27:41 +03:00
|
|
|
DIRS="$DIRS contrib/plugins/"
|
2019-08-07 17:35:23 +03:00
|
|
|
LINKS="Makefile"
|
2019-09-19 20:02:09 +03:00
|
|
|
LINKS="$LINKS tests/tcg/lm32/Makefile"
|
2020-08-06 15:08:31 +03:00
|
|
|
LINKS="$LINKS tests/tcg/Makefile.target"
|
2020-08-24 10:40:57 +03:00
|
|
|
LINKS="$LINKS pc-bios/optionrom/Makefile"
|
2018-11-02 14:52:38 +03:00
|
|
|
LINKS="$LINKS pc-bios/s390-ccw/Makefile"
|
2020-06-22 16:12:40 +03:00
|
|
|
LINKS="$LINKS roms/seabios/Makefile"
|
2018-11-02 14:52:38 +03:00
|
|
|
LINKS="$LINKS pc-bios/qemu-icon.bmp"
|
|
|
|
LINKS="$LINKS .gdbinit scripts" # scripts needed by relative path in .gdbinit
|
2018-11-02 14:52:39 +03:00
|
|
|
LINKS="$LINKS tests/acceptance tests/data"
|
|
|
|
LINKS="$LINKS tests/qemu-iotests/check"
|
2019-02-06 19:29:01 +03:00
|
|
|
LINKS="$LINKS python"
|
2020-09-09 14:27:41 +03:00
|
|
|
LINKS="$LINKS contrib/plugins/Makefile "
|
2020-08-27 13:26:17 +03:00
|
|
|
UNLINK="pc-bios/keymaps"
|
2011-06-24 22:58:37 +04:00
|
|
|
for bios_file in \
|
|
|
|
$source_path/pc-bios/*.bin \
|
2020-06-22 08:09:32 +03:00
|
|
|
$source_path/pc-bios/*.elf \
|
2016-10-26 05:18:03 +03:00
|
|
|
$source_path/pc-bios/*.lid \
|
2011-06-24 22:58:37 +04:00
|
|
|
$source_path/pc-bios/*.rom \
|
|
|
|
$source_path/pc-bios/*.dtb \
|
2013-04-29 08:52:06 +04:00
|
|
|
$source_path/pc-bios/*.img \
|
2011-06-24 22:58:37 +04:00
|
|
|
$source_path/pc-bios/openbios-* \
|
2014-01-20 03:25:40 +04:00
|
|
|
$source_path/pc-bios/u-boot.* \
|
2019-03-08 03:19:35 +03:00
|
|
|
$source_path/pc-bios/edk2-*.fd.bz2 \
|
2011-06-24 22:58:37 +04:00
|
|
|
$source_path/pc-bios/palcode-*
|
|
|
|
do
|
2018-11-02 14:52:38 +03:00
|
|
|
LINKS="$LINKS pc-bios/$(basename $bios_file)"
|
2010-12-23 13:43:59 +03:00
|
|
|
done
|
|
|
|
mkdir -p $DIRS
|
2018-11-02 14:52:38 +03:00
|
|
|
for f in $LINKS ; do
|
2020-09-01 10:23:47 +03:00
|
|
|
if [ -e "$source_path/$f" ]; then
|
2011-06-03 20:10:40 +04:00
|
|
|
symlink "$source_path/$f" "$f"
|
|
|
|
fi
|
2010-12-23 13:43:59 +03:00
|
|
|
done
|
2020-08-27 13:26:17 +03:00
|
|
|
for f in $UNLINK ; do
|
|
|
|
if [ -L "$f" ]; then
|
|
|
|
rm -f "$f"
|
|
|
|
fi
|
|
|
|
done
|
2009-05-19 19:17:58 +04:00
|
|
|
|
2019-08-07 17:35:23 +03:00
|
|
|
(for i in $cross_cc_vars; do
|
|
|
|
export $i
|
|
|
|
done
|
2019-11-28 18:35:24 +03:00
|
|
|
export target_list source_path use_containers
|
2019-08-07 17:35:23 +03:00
|
|
|
$source_path/tests/tcg/configure.sh)
|
|
|
|
|
2009-09-04 19:13:29 +04:00
|
|
|
# temporary config to build submodules
|
2020-06-22 16:12:40 +03:00
|
|
|
for rom in seabios; do
|
2009-09-04 19:13:29 +04:00
|
|
|
config_mak=roms/$rom/config.mak
|
2010-03-02 00:20:29 +03:00
|
|
|
echo "# Automatically generated by configure - do not modify" > $config_mak
|
2009-09-04 19:13:29 +04:00
|
|
|
echo "SRC_PATH=$source_path/roms/$rom" >> $config_mak
|
2016-07-08 07:49:36 +03:00
|
|
|
echo "AS=$as" >> $config_mak
|
2016-06-23 20:39:18 +03:00
|
|
|
echo "CCAS=$ccas" >> $config_mak
|
2009-09-04 19:13:29 +04:00
|
|
|
echo "CC=$cc" >> $config_mak
|
|
|
|
echo "BCC=bcc" >> $config_mak
|
2013-01-05 14:10:27 +04:00
|
|
|
echo "CPP=$cpp" >> $config_mak
|
2009-09-04 19:13:29 +04:00
|
|
|
echo "OBJCOPY=objcopy" >> $config_mak
|
2013-07-24 19:56:03 +04:00
|
|
|
echo "IASL=$iasl" >> $config_mak
|
2009-09-04 19:13:29 +04:00
|
|
|
echo "LD=$ld" >> $config_mak
|
2017-11-08 04:10:46 +03:00
|
|
|
echo "RANLIB=$ranlib" >> $config_mak
|
2009-09-04 19:13:29 +04:00
|
|
|
done
|
|
|
|
|
2019-06-10 13:05:14 +03:00
|
|
|
if test "$skip_meson" = no; then
|
2019-07-13 00:47:54 +03:00
|
|
|
cross="config-meson.cross.new"
|
|
|
|
meson_quote() {
|
2020-09-23 12:26:17 +03:00
|
|
|
echo "'$(echo $* | sed "s/ /','/g")'"
|
2019-07-13 00:47:54 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
echo "# Automatically generated by configure - do not modify" > $cross
|
|
|
|
echo "[properties]" >> $cross
|
|
|
|
test -z "$cxx" && echo "link_language = 'c'" >> $cross
|
2020-09-23 12:26:17 +03:00
|
|
|
echo "[built-in options]" >> $cross
|
|
|
|
echo "c_args = [${CFLAGS:+$(meson_quote $CFLAGS)}]" >> $cross
|
|
|
|
echo "cpp_args = [${CXXFLAGS:+$(meson_quote $CXXFLAGS)}]" >> $cross
|
|
|
|
echo "c_link_args = [${LDFLAGS:+$(meson_quote $LDFLAGS)}]" >> $cross
|
|
|
|
echo "cpp_link_args = [${LDFLAGS:+$(meson_quote $LDFLAGS)}]" >> $cross
|
2019-07-13 00:47:54 +03:00
|
|
|
echo "[binaries]" >> $cross
|
2020-09-23 12:26:17 +03:00
|
|
|
echo "c = [$(meson_quote $cc)]" >> $cross
|
|
|
|
test -n "$cxx" && echo "cpp = [$(meson_quote $cxx)]" >> $cross
|
|
|
|
echo "ar = [$(meson_quote $ar)]" >> $cross
|
|
|
|
echo "nm = [$(meson_quote $nm)]" >> $cross
|
|
|
|
echo "pkgconfig = [$(meson_quote $pkg_config_exe)]" >> $cross
|
|
|
|
echo "ranlib = [$(meson_quote $ranlib)]" >> $cross
|
2020-09-01 15:06:28 +03:00
|
|
|
if has $sdl2_config; then
|
2020-09-23 12:26:17 +03:00
|
|
|
echo "sdl2-config = [$(meson_quote $sdl2_config)]" >> $cross
|
2020-09-01 15:06:28 +03:00
|
|
|
fi
|
2020-09-23 12:26:17 +03:00
|
|
|
echo "strip = [$(meson_quote $strip)]" >> $cross
|
|
|
|
echo "windres = [$(meson_quote $windres)]" >> $cross
|
2019-07-13 00:47:54 +03:00
|
|
|
if test -n "$cross_prefix"; then
|
|
|
|
cross_arg="--cross-file config-meson.cross"
|
|
|
|
echo "[host_machine]" >> $cross
|
|
|
|
if test "$mingw32" = "yes" ; then
|
|
|
|
echo "system = 'windows'" >> $cross
|
|
|
|
fi
|
2020-08-22 22:35:48 +03:00
|
|
|
if test "$linux" = "yes" ; then
|
|
|
|
echo "system = 'linux'" >> $cross
|
|
|
|
fi
|
2019-07-13 00:47:54 +03:00
|
|
|
case "$ARCH" in
|
|
|
|
i386|x86_64)
|
|
|
|
echo "cpu_family = 'x86'" >> $cross
|
|
|
|
;;
|
|
|
|
ppc64le)
|
|
|
|
echo "cpu_family = 'ppc64'" >> $cross
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
echo "cpu_family = '$ARCH'" >> $cross
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
echo "cpu = '$cpu'" >> $cross
|
|
|
|
if test "$bigendian" = "yes" ; then
|
|
|
|
echo "endian = 'big'" >> $cross
|
|
|
|
else
|
|
|
|
echo "endian = 'little'" >> $cross
|
|
|
|
fi
|
|
|
|
else
|
|
|
|
cross_arg="--native-file config-meson.cross"
|
|
|
|
fi
|
|
|
|
mv $cross config-meson.cross
|
|
|
|
|
2019-06-10 13:05:14 +03:00
|
|
|
rm -rf meson-private meson-info meson-logs
|
2020-10-19 13:56:16 +03:00
|
|
|
unset staticpic
|
|
|
|
if ! version_ge "$($meson --version)" 0.56.0; then
|
|
|
|
staticpic=$(if test "$pie" = yes; then echo true; else echo false; fi)
|
|
|
|
fi
|
2020-08-13 16:28:11 +03:00
|
|
|
NINJA=$ninja $meson setup \
|
2020-08-18 13:17:01 +03:00
|
|
|
--prefix "$prefix" \
|
|
|
|
--libdir "$libdir" \
|
|
|
|
--libexecdir "$libexecdir" \
|
|
|
|
--bindir "$bindir" \
|
|
|
|
--includedir "$includedir" \
|
|
|
|
--datadir "$datadir" \
|
|
|
|
--mandir "$mandir" \
|
|
|
|
--sysconfdir "$sysconfdir" \
|
2020-10-16 10:19:14 +03:00
|
|
|
--localedir "$localedir" \
|
2020-08-18 13:17:01 +03:00
|
|
|
--localstatedir "$local_statedir" \
|
|
|
|
-Ddocdir="$docdir" \
|
2020-10-16 10:19:14 +03:00
|
|
|
-Dqemu_firmwarepath="$firmwarepath" \
|
2020-08-26 14:04:15 +03:00
|
|
|
-Dqemu_suffix="$qemu_suffix" \
|
2019-06-10 13:05:14 +03:00
|
|
|
-Doptimization=$(if test "$debug" = yes; then echo 0; else echo 2; fi) \
|
|
|
|
-Ddebug=$(if test "$debug_info" = yes; then echo true; else echo false; fi) \
|
|
|
|
-Dwerror=$(if test "$werror" = yes; then echo true; else echo false; fi) \
|
|
|
|
-Dstrip=$(if test "$strip_opt" = yes; then echo true; else echo false; fi) \
|
2019-09-17 14:39:36 +03:00
|
|
|
-Db_pie=$(if test "$pie" = yes; then echo true; else echo false; fi) \
|
2020-10-19 13:56:16 +03:00
|
|
|
${staticpic:+-Db_staticpic=$staticpic} \
|
2019-10-04 16:35:16 +03:00
|
|
|
-Db_coverage=$(if test "$gcov" = yes; then echo true; else echo false; fi) \
|
2020-12-05 02:06:14 +03:00
|
|
|
-Db_lto=$lto -Dcfi=$cfi -Dcfi_debug=$cfi_debug \
|
2020-10-13 02:43:44 +03:00
|
|
|
-Dmalloc=$malloc -Dmalloc_trim=$malloc_trim -Dsparse=$sparse \
|
|
|
|
-Dkvm=$kvm -Dhax=$hax -Dwhpx=$whpx -Dhvf=$hvf \
|
|
|
|
-Dxen=$xen -Dxen_pci_passthrough=$xen_pci_passthrough -Dtcg=$tcg \
|
|
|
|
-Dcocoa=$cocoa -Dmpath=$mpath -Dsdl=$sdl -Dsdl_image=$sdl_image \
|
|
|
|
-Dvnc=$vnc -Dvnc_sasl=$vnc_sasl -Dvnc_jpeg=$vnc_jpeg -Dvnc_png=$vnc_png \
|
2020-10-08 13:31:33 +03:00
|
|
|
-Dgettext=$gettext -Dxkbcommon=$xkbcommon -Du2f=$u2f -Dvirtiofsd=$virtiofsd \
|
2020-11-17 15:02:17 +03:00
|
|
|
-Dcapstone=$capstone -Dslirp=$slirp -Dfdt=$fdt -Dbrlapi=$brlapi \
|
2020-11-17 15:11:25 +03:00
|
|
|
-Dcurl=$curl -Dglusterfs=$glusterfs -Dbzip2=$bzip2 -Dlibiscsi=$libiscsi \
|
2020-11-17 15:11:25 +03:00
|
|
|
-Dlibnfs=$libnfs -Diconv=$iconv -Dcurses=$curses -Dlibudev=$libudev\
|
2020-11-17 15:35:28 +03:00
|
|
|
-Drbd=$rbd -Dlzo=$lzo -Dsnappy=$snappy -Dlzfse=$lzfse \
|
2020-11-17 16:46:58 +03:00
|
|
|
-Dzstd=$zstd -Dseccomp=$seccomp -Dvirtfs=$virtfs -Dcap_ng=$cap_ng \
|
2020-11-20 10:38:22 +03:00
|
|
|
-Dattr=$attr -Ddefault_devices=$default_devices \
|
2020-10-16 10:32:52 +03:00
|
|
|
-Ddocs=$docs -Dsphinx_build=$sphinx_build -Dinstall_blobs=$blobs \
|
2020-11-10 20:11:19 +03:00
|
|
|
-Dvhost_user_blk_server=$vhost_user_blk_server \
|
2020-10-27 22:05:46 +03:00
|
|
|
-Dfuse=$fuse -Dfuse_lseek=$fuse_lseek \
|
2020-12-10 22:04:13 +03:00
|
|
|
$(if test "$default_features" = no; then echo "-Dauto_features=disabled"; fi) \
|
2019-07-13 00:47:54 +03:00
|
|
|
$cross_arg \
|
2019-06-10 13:05:14 +03:00
|
|
|
"$PWD" "$source_path"
|
|
|
|
|
|
|
|
if test "$?" -ne 0 ; then
|
|
|
|
error_exit "meson setup failed"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2020-09-09 14:27:37 +03:00
|
|
|
if test -n "${deprecated_features}"; then
|
|
|
|
echo "Warning, deprecated features enabled."
|
|
|
|
echo "Please see docs/system/deprecated.rst"
|
|
|
|
echo " features: ${deprecated_features}"
|
|
|
|
fi
|
|
|
|
|
2014-03-09 19:37:49 +04:00
|
|
|
# Save the configure command line for later reuse.
|
|
|
|
cat <<EOD >config.status
|
|
|
|
#!/bin/sh
|
|
|
|
# Generated by configure.
|
|
|
|
# Run this file to recreate the current configuration.
|
|
|
|
# Compiler output produced by configure, useful for debugging
|
|
|
|
# configure, is in config.log if it exists.
|
|
|
|
EOD
|
configure: preserve various environment variables in config.status
The config.status script is auto-generated by configure upon
completion. The intention is that config.status can be later invoked by
the developer directly, or by make indirectly, to re-detect the same
environment that configure originally used.
The current config.status script, however, only contains a record of the
command line arguments to configure. Various environment variables have
an effect on what configure will find. In particular PKG_CONFIG_LIBDIR &
PKG_CONFIG_PATH vars will affect what libraries pkg-config finds. The
PATH var will affect what toolchain binaries and XXXX-config scripts are
found. The LD_LIBRARY_PATH var will affect what libraries are
found. Most commands have env variables that will override the name/path
of the default version configure finds.
All these key env variables should be recorded in the config.status script.
Autoconf would also preserve CFLAGS, LDFLAGS, LIBS, CPPFLAGS, but QEMU
deals with those differently, expecting extra flags to be set using
configure args, rather than env variables. At the end of the script we
also don't have the original values of those env vars, as we modify them
during configure.
Reviewed-by: Eric Blake <eblake@redhat.com>
Reviewed-by: Stefan Weil <sw@weilnetz.de>
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
Message-Id: <20180904123603.10016-1-berrange@redhat.com>
Reviewed-by: Thomas Huth <thuth@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Signed-off-by: Daniel P. Berrangé <berrange@redhat.com>
2018-09-04 15:36:03 +03:00
|
|
|
|
|
|
|
preserve_env() {
|
|
|
|
envname=$1
|
|
|
|
|
|
|
|
eval envval=\$$envname
|
|
|
|
|
|
|
|
if test -n "$envval"
|
|
|
|
then
|
|
|
|
echo "$envname='$envval'" >> config.status
|
|
|
|
echo "export $envname" >> config.status
|
|
|
|
else
|
|
|
|
echo "unset $envname" >> config.status
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
# Preserve various env variables that influence what
|
|
|
|
# features/build target configure will detect
|
|
|
|
preserve_env AR
|
|
|
|
preserve_env AS
|
|
|
|
preserve_env CC
|
|
|
|
preserve_env CPP
|
|
|
|
preserve_env CXX
|
|
|
|
preserve_env INSTALL
|
|
|
|
preserve_env LD
|
|
|
|
preserve_env LD_LIBRARY_PATH
|
|
|
|
preserve_env LIBTOOL
|
|
|
|
preserve_env MAKE
|
|
|
|
preserve_env NM
|
|
|
|
preserve_env OBJCOPY
|
|
|
|
preserve_env PATH
|
|
|
|
preserve_env PKG_CONFIG
|
|
|
|
preserve_env PKG_CONFIG_LIBDIR
|
|
|
|
preserve_env PKG_CONFIG_PATH
|
|
|
|
preserve_env PYTHON
|
|
|
|
preserve_env SDL2_CONFIG
|
|
|
|
preserve_env SMBD
|
|
|
|
preserve_env STRIP
|
|
|
|
preserve_env WINDRES
|
|
|
|
|
2014-03-09 19:37:49 +04:00
|
|
|
printf "exec" >>config.status
|
2019-06-10 13:05:14 +03:00
|
|
|
for i in "$0" "$@"; do
|
|
|
|
test "$i" = --skip-meson || printf " '%s'" "$i" >>config.status
|
|
|
|
done
|
2016-01-12 14:58:48 +03:00
|
|
|
echo ' "$@"' >>config.status
|
2014-03-09 19:37:49 +04:00
|
|
|
chmod +x config.status
|
|
|
|
|
2014-05-23 20:07:24 +04:00
|
|
|
rm -r "$TMPDIR1"
|