libvirt/src
Daniel P. Berrangé 1902356231 qemu: keep capabilities when running QEMU as root
When QEMU uid/gid is set to non-root this is pointless as if we just
used a regular setuid/setgid call, the process will have all its
capabilities cleared anyway by the kernel.

When QEMU uid/gid is set to root, this is almost (always?) never
what people actually want. People make QEMU run as root in order
to access some privileged resource that libvirt doesn't support
yet and this often requires capabilities. As a result they have
to go find the qemu.conf param to turn this off. This is not
viable for libguestfs - they want to control everything via the
XML security label to request running as root regardless of the
qemu.conf settings for user/group.

Clearing capabilities was implemented originally because there
was a proposal in Fedora to change permissions such that root,
with no capabilities would not be able to compromise the system.
ie a locked down root account. This never went anywhere though,
and as a result clearing capabilities when running as root does
not really get us any security benefit AFAICT. The root user
can easily do something like create a cronjob, which will then
faithfully be run with full capabilities, trivially bypassing
the restriction we place.

IOW, our clearing of capabilities is both useless from a security
POV, and breaks valid use cases when people need to run as root.

This removes the clear_emulator_capabilities configuration
option from qemu.conf, and always runs QEMU with capabilities
when root.  The behaviour when non-root is unchanged.

Reviewed-by: Cole Robinson <crobinso@redhat.com>
Signed-off-by: Daniel P. Berrangé <berrange@redhat.com>
2019-12-11 16:01:20 +00:00
..
access src: rewrite polkit ACL generator in Python 2019-11-20 14:45:25 +00:00
admin src: rewrite driver name checker in Python 2019-11-20 14:45:25 +00:00
bhyve use g_ascii_isspace instead of c_isspace from gnulib 2019-12-10 13:49:24 +01:00
conf use g_ascii_isspace instead of c_isspace from gnulib 2019-12-10 13:49:24 +01:00
cpu conf: make virCPUDef into a ref counted struct 2019-12-09 10:17:27 +00:00
cpu_map cpu_map: Drop pconfig from Icelake-Server CPU model 2019-11-12 20:14:16 +01:00
esx conf: drop virCapsPtr param from snapshot & checkpoint APIs 2019-12-09 10:17:27 +00:00
hyperv conf: drop virCapsPtr param from domain formatting APIs 2019-12-09 10:17:27 +00:00
interface use g_ascii_isspace instead of c_isspace from gnulib 2019-12-10 13:49:24 +01:00
keycodemapdb@317d3eeb96 src: update keycodemapdb submodule 2019-12-11 14:28:40 +00:00
libxl use g_ascii_isdigit instead of c_isdigit frum gnulib 2019-12-10 13:49:24 +01:00
locking docs: convert virtlockd man page from pod to rst 2019-12-11 14:28:41 +00:00
logging docs: convert virtlogd man page from pod to rst 2019-12-11 14:28:41 +00:00
lxc lxc: Refresh capabilities if they have never been initalized 2019-12-10 10:12:48 -05:00
network all: don't wait for driver lock during startup 2019-11-26 15:46:47 +01:00
node_device use g_ascii_isalnum instead of c_isalnum from gnulib 2019-12-10 13:49:23 +01:00
nwfilter util: consolidate on one free callback for hash data 2019-11-22 14:21:28 +00:00
openvz conf: move NUMA capabilities into self contained object 2019-12-09 10:17:27 +00:00
phyp conf: move NUMA capabilities into self contained object 2019-12-09 10:17:27 +00:00
qemu qemu: keep capabilities when running QEMU as root 2019-12-11 16:01:20 +00:00
remote docs: convert libvirtd man page from pod to rst 2019-12-11 14:28:41 +00:00
rpc use g_ascii_isspace instead of c_isspace from gnulib 2019-12-10 13:49:24 +01:00
secret secret_driver.c: remove unneeded cleanup label 2019-11-12 17:54:01 +01:00
security security: apparmor: Label externalDataStore 2019-12-10 10:14:58 -05:00
storage use g_ascii_isdigit instead of c_isdigit frum gnulib 2019-12-10 13:49:24 +01:00
test conf: move NUMA capabilities into self contained object 2019-12-09 10:17:27 +00:00
util docs: convert virkeycode*/virkeyname* man pages from pod to rst 2019-12-11 14:28:41 +00:00
vbox conf: move NUMA capabilities into self contained object 2019-12-09 10:17:27 +00:00
vmware conf: move NUMA capabilities into self contained object 2019-12-09 10:17:27 +00:00
vmx use g_ascii_tolower instead of c_tolower from gnulib 2019-12-10 13:49:24 +01:00
vz vz: drop virCapsPtr param from many API domain parse calls 2019-12-09 14:46:14 +00:00
admin_protocol-structs remote: don't pull anonymous enums into rpc protocol structs 2019-10-01 14:27:15 +01:00
datatypes.c datatypes: use g_strdup instead of VIR_STRDUP 2019-10-21 12:51:56 +02:00
datatypes.h datatypes: Fix comment for the _virNetwork struct 2019-11-12 08:51:50 +01:00
driver-hypervisor.h backup: Introduce virDomainBackup APIs 2019-12-10 12:41:56 +01:00
driver-interface.h
driver-network.h
driver-nodedev.h
driver-nwfilter.h
driver-secret.h
driver-state.h remote: in per-driver daemons ensure that state initialize succeeds 2019-08-09 14:06:31 +01:00
driver-storage.h
driver-stream.h
driver.c Use g_strdup_printf instead of virAsprintf everywhere 2019-11-12 16:15:59 +01:00
driver.h Use G_GNUC_WARN_UNUSED_RESULT instead of ATTRIBUTE_RETURN_CHECK 2019-10-15 11:25:22 +02:00
internal.h use g_ascii_strncasecmp instead of c_strncasecmp from gnulib 2019-12-10 14:08:51 +01:00
libvirt_atomic.syms
libvirt_driver_modules.syms
libvirt_esx.syms
libvirt_internal.h remote: in per-driver daemons ensure that state initialize succeeds 2019-08-09 14:06:31 +01:00
libvirt_libssh2.syms
libvirt_libssh.syms
libvirt_linux.syms
libvirt_lxc.syms
libvirt_openvz.syms
libvirt_private.syms backup: Parse and output backup XML 2019-12-10 12:41:56 +01:00
libvirt_probes.d
libvirt_public.syms backup: Introduce virDomainBackup APIs 2019-12-10 12:41:56 +01:00
libvirt_qemu_probes.d
libvirt_qemu.syms
libvirt_remote.syms remote: pass identity across to newly opened daemons 2019-09-16 11:25:53 +01:00
libvirt_sasl.syms
libvirt_vmware.syms
libvirt_vmx.syms
libvirt-domain-checkpoint.c backup: Introduce virDomainBackup APIs 2019-12-10 12:41:56 +01:00
libvirt-domain-snapshot.c libvirt-<module>: Check caller-provided buffers to be NULL with size > 0 2019-11-21 18:16:35 +01:00
libvirt-domain.c doc: Document quirk of getting block job info for a 'backup' blockjob 2019-12-10 12:41:58 +01:00
libvirt-host.c libvirt-<module>: Check caller-provided buffers to be NULL with size > 0 2019-11-21 18:16:35 +01:00
libvirt-interface.c libvirt-<module>: Check caller-provided buffers to be NULL with size > 0 2019-11-21 18:16:35 +01:00
libvirt-lxc.c
libvirt-lxc.pc.in Fix src/ pkg-config API XML paths 2019-12-10 09:47:26 -05:00
libvirt-network.c libvirt-<module>: Check caller-provided buffers to be NULL with size > 0 2019-11-21 18:16:35 +01:00
libvirt-nodedev.c libvirt-<module>: Check caller-provided buffers to be NULL with size > 0 2019-11-21 18:16:35 +01:00
libvirt-nwfilter.c libvirt-<module>: Check caller-provided buffers to be NULL with size > 0 2019-11-21 18:16:35 +01:00
libvirt-qemu.c
libvirt-qemu.pc.in Fix src/ pkg-config API XML paths 2019-12-10 09:47:26 -05:00
libvirt-secret.c libvirt-<module>: Check caller-provided buffers to be NULL with size > 0 2019-11-21 18:16:35 +01:00
libvirt-storage.c libvirt-<module>: Check caller-provided buffers to be NULL with size > 0 2019-11-21 18:16:35 +01:00
libvirt-stream.c Drop needless ret variable 2019-10-24 08:10:37 +02:00
libvirt.c libvirt.c: remove unneeded cleanup label 2019-11-12 17:54:01 +01:00
libvirt.conf
libvirt.pc.in Fix src/ pkg-config API XML paths 2019-12-10 09:47:26 -05:00
lock_protocol-structs
lxc_monitor_protocol-structs
lxc_protocol-structs
Makefile.am docs: remove build recipes related to pod2man usage 2019-12-11 14:28:41 +00:00
qemu_protocol-structs
README xenapi: remove driver 2019-09-03 15:37:54 -06:00
remote_protocol-structs backup: Implement backup APIs for remote driver 2019-12-10 12:41:56 +01:00
virkeepaliveprotocol-structs
virnetprotocol-structs

       libvirt library code README
       ===========================

The directory provides the bulk of the libvirt codebase. Everything
except for the libvirtd daemon and client tools. The build uses a
large number of libtool convenience libraries - one for each child
directory, and then links them together for the final libvirt.so,
although some bits get linked directly to libvirtd daemon instead.

The files directly in this directory are supporting the public API
entry points & data structures.

There are two core shared modules to be aware of:

 * util/  - a collection of shared APIs that can be used by any
            code. This directory is always in the include path
            for all things built

 * conf/  - APIs for parsing / manipulating all the official XML
            files used by the public API. This directory is only
            in the include path for driver implementation modules

 * vmx/   - VMware VMX config handling (used by esx/ and vmware/)


Then there are the hypervisor implementations:

 * bhyve         - bhyve - The BSD Hypervisor
 * esx/          - VMware ESX and GSX support using vSphere API over SOAP
 * hyperv/       - Microsoft Hyper-V support using WinRM
 * lxc/          - Linux Native Containers
 * openvz/       - OpenVZ containers using cli tools
 * phyp/         - IBM Power Hypervisor using CLI tools over SSH
 * qemu/         - QEMU / KVM using qemu CLI/monitor
 * remote/       - Generic libvirt native RPC client
 * test/         - A "mock" driver for testing
 * vbox/         - Virtual Box using native API
 * vmware/       - VMware Workstation and Player using the vmrun tool
 * xen/          - Xen using hypercalls, XenD SEXPR & XenStore


Finally some secondary drivers that are shared for several HVs.
Currently these are used by LXC, OpenVZ, QEMU and Xen drivers.
The ESX, Hyper-V, Power Hypervisor, Remote, Test & VirtualBox drivers all
implement the secondary drivers directly

 * cpu/          - CPU feature management
 * interface/    - Host network interface management
 * network/      - Virtual NAT networking
 * nwfilter/     - Network traffic filtering rules
 * node_device/  - Host device enumeration
 * secret/       - Secret management
 * security/     - Mandatory access control drivers
 * storage/      - Storage management drivers


Since both the hypervisor and secondary drivers can be built as
dlopen()able modules, it is *FORBIDDEN* to have build dependencies
between these directories. Drivers are only allowed to depend on
the public API, and the internal APIs in the util/ and conf/
directories