2016-12-08 10:35:30 +01:00
|
|
|
dnl The QEMU driver
|
|
|
|
dnl
|
|
|
|
dnl Copyright (C) 2016 Red Hat, Inc.
|
|
|
|
dnl
|
|
|
|
dnl This library is free software; you can redistribute it and/or
|
|
|
|
dnl modify it under the terms of the GNU Lesser General Public
|
|
|
|
dnl License as published by the Free Software Foundation; either
|
|
|
|
dnl version 2.1 of the License, or (at your option) any later version.
|
|
|
|
dnl
|
|
|
|
dnl This library is distributed in the hope that it will be useful,
|
|
|
|
dnl but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
dnl MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
dnl Lesser General Public License for more details.
|
|
|
|
dnl
|
|
|
|
dnl You should have received a copy of the GNU Lesser General Public
|
|
|
|
dnl License along with this library. If not, see
|
|
|
|
dnl <http://www.gnu.org/licenses/>.
|
|
|
|
dnl
|
|
|
|
|
|
|
|
AC_DEFUN([LIBVIRT_DRIVER_ARG_QEMU], [
|
2019-03-14 13:30:26 +01:00
|
|
|
LIBVIRT_ARG_WITH_FEATURE([QEMU], [QEMU/KVM], [check])
|
2016-12-22 12:49:51 +01:00
|
|
|
LIBVIRT_ARG_WITH([QEMU_USER], [username to run QEMU system instance as],
|
|
|
|
['platform dependent'])
|
|
|
|
LIBVIRT_ARG_WITH([QEMU_GROUP], [groupname to run QEMU system instance as],
|
|
|
|
['platform dependent'])
|
2016-12-08 10:35:30 +01:00
|
|
|
])
|
|
|
|
|
|
|
|
AC_DEFUN([LIBVIRT_DRIVER_CHECK_QEMU], [
|
2019-03-13 16:40:14 +01:00
|
|
|
dnl There is no way qemu driver will work without JSON support
|
|
|
|
AC_REQUIRE([LIBVIRT_CHECK_YAJL])
|
|
|
|
if test "$with_qemu:$with_yajl" = "yes:no"; then
|
2019-04-02 23:50:37 +02:00
|
|
|
AC_MSG_ERROR([YAJL 2 is required to build QEMU driver])
|
2019-03-13 16:40:14 +01:00
|
|
|
fi
|
|
|
|
if test "$with_qemu" = "check"; then
|
|
|
|
with_qemu=$with_yajl
|
|
|
|
fi
|
|
|
|
|
2016-12-08 10:35:30 +01:00
|
|
|
if test "$with_qemu" = "yes" ; then
|
|
|
|
AC_DEFINE_UNQUOTED([WITH_QEMU], 1, [whether QEMU driver is enabled])
|
|
|
|
fi
|
|
|
|
AM_CONDITIONAL([WITH_QEMU], [test "$with_qemu" = "yes"])
|
2016-12-12 15:35:07 +01:00
|
|
|
|
2019-04-02 11:04:46 +02:00
|
|
|
if test $with_freebsd = yes || test $with_macos = yes; then
|
2016-12-12 15:35:07 +01:00
|
|
|
default_qemu_user=root
|
|
|
|
default_qemu_group=wheel
|
|
|
|
else
|
m4: Run QEMU under a distro-specific user when possible
Our current defaults are root:wheel on FreeBSD and macOS, root:root
everywhere else.
Looking at what downstream distributions actually do, we can see that
these defaults are overriden the vast majority of the time, with a
number of variations showing up in the wild:
* qemu:qemu -> Used by CentOS, Fedora, Gentoo, OpenSUSE, RHEL
and... As it turns out, our very own spec file :)
* libvirt-qemu:libvirt-qemu -> Used by Debian.
* libvirt-qemu:kvm -> Used by Ubuntu.
* nobody:nobody -> Used by Arch Linux.
Based on this information, we can do a better job at integrating with
downstream packages: if the distro-specific user and group already
exist on the system then we use them, and if not (or we're building
on an unknown OS) we just use root:root as we would have before.
This change makes it less likely that people building from source
will end up running their guests as root, which is a very desiderable
outcome from the security point of view.
Signed-off-by: Andrea Bolognani <abologna@redhat.com>
Reviewed-by: Daniel P. Berrangé <berrange@redhat.com>
2019-03-26 11:01:32 +01:00
|
|
|
# Try to integrate gracefully with downstream packages by running QEMU
|
|
|
|
# processes using the same user and group they would
|
|
|
|
case $(grep ^ID= /etc/os-release 2>/dev/null) in
|
|
|
|
*arch*)
|
|
|
|
default_qemu_user=nobody
|
|
|
|
default_qemu_group=nobody
|
|
|
|
;;
|
|
|
|
*centos*|*fedora*|*gentoo*|*rhel*|*suse*)
|
|
|
|
default_qemu_user=qemu
|
|
|
|
default_qemu_group=qemu
|
|
|
|
;;
|
|
|
|
*debian*)
|
|
|
|
default_qemu_user=libvirt-qemu
|
|
|
|
default_qemu_group=libvirt-qemu
|
|
|
|
;;
|
|
|
|
*ubuntu*)
|
|
|
|
default_qemu_user=libvirt-qemu
|
|
|
|
default_qemu_group=kvm
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
default_qemu_user=root
|
|
|
|
default_qemu_group=root
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
# If the expected user and group don't exist, or we haven't hit any
|
|
|
|
# of the cases above because we're running on an unknown OS, the only
|
|
|
|
# sensible fallback is root:root
|
|
|
|
AC_MSG_CHECKING([for QEMU credentials ($default_qemu_user:$default_qemu_group)])
|
|
|
|
if getent passwd "$default_qemu_user" >/dev/null 2>&1 && \
|
|
|
|
getent group "$default_qemu_group" >/dev/null 2>&1; then
|
|
|
|
AC_MSG_RESULT([ok])
|
|
|
|
else
|
|
|
|
AC_MSG_RESULT([not found, using root:root instead])
|
|
|
|
default_qemu_user=root
|
|
|
|
default_qemu_group=root
|
|
|
|
fi
|
2016-12-12 15:35:07 +01:00
|
|
|
fi
|
|
|
|
|
|
|
|
if test "x$with_qemu_user" = "xplatform dependent" ; then
|
|
|
|
QEMU_USER="$default_qemu_user"
|
|
|
|
else
|
|
|
|
QEMU_USER="$with_qemu_user"
|
|
|
|
fi
|
|
|
|
if test "x$with_qemu_group" = "xplatform dependent" ; then
|
|
|
|
QEMU_GROUP="$default_qemu_group"
|
|
|
|
else
|
|
|
|
QEMU_GROUP="$with_qemu_group"
|
|
|
|
fi
|
|
|
|
AC_DEFINE_UNQUOTED([QEMU_USER], ["$QEMU_USER"], [QEMU user account])
|
|
|
|
AC_DEFINE_UNQUOTED([QEMU_GROUP], ["$QEMU_GROUP"], [QEMU group account])
|
2016-12-12 18:18:30 +01:00
|
|
|
|
|
|
|
AC_PATH_PROG([QEMU_BRIDGE_HELPER], [qemu-bridge-helper],
|
|
|
|
[/usr/libexec/qemu-bridge-helper],
|
|
|
|
[/usr/libexec:/usr/lib/qemu:/usr/lib])
|
|
|
|
AC_DEFINE_UNQUOTED([QEMU_BRIDGE_HELPER], ["$QEMU_BRIDGE_HELPER"],
|
|
|
|
[QEMU bridge helper])
|
2017-12-15 10:42:40 +01:00
|
|
|
AC_PATH_PROG([QEMU_PR_HELPER], [qemu-pr-helper],
|
|
|
|
[/usr/bin/qemu-pr-helper],
|
|
|
|
[/usr/bin:/usr/libexec])
|
|
|
|
AC_DEFINE_UNQUOTED([QEMU_PR_HELPER], ["$QEMU_PR_HELPER"],
|
|
|
|
[QEMU PR helper])
|
2019-08-08 18:55:03 +04:00
|
|
|
AC_PATH_PROG([QEMU_SLIRP_HELPER], [slirp-helper],
|
|
|
|
[/usr/bin/slirp-helper],
|
|
|
|
[/usr/bin:/usr/libexec])
|
|
|
|
AC_DEFINE_UNQUOTED([QEMU_SLIRP_HELPER], ["$QEMU_SLIRP_HELPER"],
|
|
|
|
[QEMU slirp helper])
|
2020-02-25 10:55:06 +01:00
|
|
|
|
|
|
|
AC_PATH_PROG([QEMU_DBUS_DAEMON], [dbus-daemon],
|
|
|
|
[/usr/bin/dbus-daemon],
|
|
|
|
[/usr/bin:/usr/libexec])
|
|
|
|
AC_DEFINE_UNQUOTED([QEMU_DBUS_DAEMON], ["$QEMU_DBUS_DAEMON"],
|
|
|
|
[QEMU dbus daemon])
|
2016-12-08 10:35:30 +01:00
|
|
|
])
|
|
|
|
|
|
|
|
AC_DEFUN([LIBVIRT_DRIVER_RESULT_QEMU], [
|
|
|
|
LIBVIRT_RESULT([QEMU], [$with_qemu])
|
|
|
|
])
|
2016-12-12 15:35:07 +01:00
|
|
|
|
|
|
|
AC_DEFUN([LIBVIRT_RESULT_QEMU_PRIVILEGES], [
|
2019-03-26 16:58:30 +01:00
|
|
|
if test "$QEMU_USER" = "root"; then
|
|
|
|
LIBVIRT_RESULT([QEMU], [$QEMU_USER:$QEMU_GROUP],
|
|
|
|
[!!! running QEMU as root is strongly discouraged !!!])
|
|
|
|
else
|
|
|
|
LIBVIRT_RESULT([QEMU], [$QEMU_USER:$QEMU_GROUP])
|
|
|
|
fi
|
2016-12-12 15:35:07 +01:00
|
|
|
])
|