libvirt/src
Laine Stump dd60bd62d3 qemu_hotplug: consolidate all common detach code in qemuDomainDetachDeviceLive
Now that all the qemuDomainDetachPrep*() functions look nearly
identical at the end, we can put one copy of that identical code in
qemuDomainDetachDeviceLive() at the point after the individual prep
functions have been called, and remove the duplicated code from all
the prep functions. The code to locate the target "detach" device
based on the "match" device remains, as do all device-type-specific
validations.

Unfortunately there are a few things going on at once in this patch,
which makes it a bit more difficult to follow than the others; it was
just impossible to do the changes in stages and still have a
buildable/testable tree at each step.

The other changes of note:

* The individual prep functions no longer need their driver or async
  args, so those are removed, as are the local "ret" variables, since
  in all cases the functions just directly return -1 or 0.

* Some of the prep functions were checking for a valid alias and/or
  for attempts to detach a multifunction PCI device, but not all. In
  fact, both checks are valid (or at least harmless) for *all* device
  types, so they are removed from the prep functions, and done a
  single time in the common function.

  (any attempts to *create* an alias when there isn't one has been
  removed, since that is doomed to failure anyway; the only way the
  device wouldn't have an alias is if 1) the domain was created by
  calling virsh qemu-attach to attach an existing qemu process to
  libvirt, and 2) the qemu command that started said process used "old
  style" arguments for creating devices that didn't have any device
  ids. Even if we constructed a device id for one of these devices,
  qemu wouldn't recognize it in the device_del command anyway, so we
  may as well fail earlier with "device missing alias" rather than
  failing later with "couldn't delete device net0".)

* Only one type of device has shutdown code that must not be called
  until after *all* validation of the device is done (including
  checking for multifunction PCI and valid alias, which is done in the
  toplevel common code). For this reason, the Net function has been
  split in two, with the 2nd half (qemuDomainDetachShutdownNet())
  called from the common function, right before sending the delete
  command to qemu.

Signed-off-by: Laine Stump <laine@laine.org>
ACKed-by: Peter Krempa <pkrempa@redhat.com>
2019-03-26 11:05:04 -04:00
..
access Require a semicolon for VIR_ENUM_IMPL calls 2019-02-03 17:46:29 -05:00
admin Enforce a standard header file guard symbol name 2018-12-14 10:47:13 +00:00
bhyve bhyve: fill in virCapsEnum 'report' 2019-03-18 10:51:02 -04:00
conf snapshot: Make virDomainMomentObjListGetNames more generic 2019-03-25 14:53:33 -05:00
cpu Fix names for abs_top_{src,build}dir variables 2019-03-14 10:05:28 +01:00
cpu_map cpu_map: Add more signatures for Skylake-Client CPU models 2019-03-05 14:47:49 +01:00
esx snapshot: Factor out virDomainMomentDef class 2019-03-22 01:18:34 -05:00
hyperv domain: Fix unknown flags diagnosis in virDomainGetXMLDesc 2019-02-19 16:52:51 -06:00
interface Use NULLSTR_EMPTY 2019-02-14 14:09:38 +01:00
keycodemapdb@16e5b07876
libxl libxl: fill in virCapsEnum 'report' 2019-03-18 10:51:02 -04:00
locking Drop support for "Red Hat" init scripts 2019-03-15 18:36:19 +01:00
logging Drop support for "Red Hat" init scripts 2019-03-15 18:36:19 +01:00
lxc Drop needless virtType validation 2019-03-18 09:35:00 -04:00
network network: avoid trying to create global firewall rules if unprivileged 2019-03-19 10:03:02 +00:00
node_device xml: nodedev: make pci capability class element optional 2019-03-22 12:59:56 +03:00
nwfilter nwfilter: fix adding std MAC and IP values to filter binding 2019-03-22 12:03:00 +03:00
openvz domain: Fix unknown flags diagnosis in virDomainGetXMLDesc 2019-02-19 16:52:51 -06:00
phyp domain: Fix unknown flags diagnosis in virDomainGetXMLDesc 2019-02-19 16:52:51 -06:00
qemu qemu_hotplug: consolidate all common detach code in qemuDomainDetachDeviceLive 2019-03-26 11:05:04 -04:00
remote Drop support for "Red Hat" init scripts 2019-03-15 18:36:19 +01:00
rpc rpc: client: stream: fix multi thread abort/finish 2019-02-08 17:16:00 +01:00
secret Enforce a standard header file guard symbol name 2018-12-14 10:47:13 +00:00
security apparmor: Check libvirtd profile status by name 2019-03-13 11:58:11 -06:00
storage rbd: optionally compute volume allocation from capacity 2019-03-19 16:49:24 +01:00
test snapshot: Rename virDomainSnapshotObjPtr 2019-03-22 01:18:34 -05:00
util util: xml: Introduce VIR_AUTOPTR functions for xmlDoc and xmlXPathContext 2019-03-20 08:17:05 +01:00
vbox snapshot: Factor out virDomainMomentDef class 2019-03-22 01:18:34 -05:00
vmware util: Rename virFileHasSuffix() to virStringHasCaseSuffix() 2019-03-07 10:08:47 +01:00
vmx Use virStringHasSuffix() where possible 2019-03-07 10:10:49 +01:00
vz snapshot: Rename virDomainSnapshotObjPtr 2019-03-22 01:18:34 -05:00
xenapi Enforce a standard header file guard symbol name 2018-12-14 10:47:13 +00:00
xenconfig xenconfig: Add support for max_grant_frames 2019-03-13 12:06:52 -06:00
admin_protocol-structs
check-aclperms.pl
check-aclrules.pl
check-driverimpls.pl
check-drivername.pl
check-symfile.pl
check-symsorting.pl
datatypes.c Use NULLSTR_EMPTY 2019-02-14 14:09:38 +01:00
datatypes.h rpc: client stream: dispose private data on stream dispose 2019-02-08 16:51:45 +01:00
driver-hypervisor.h Enforce a standard header file guard symbol name 2018-12-14 10:47:13 +00:00
driver-interface.h Enforce a standard header file guard symbol name 2018-12-14 10:47:13 +00:00
driver-network.h Enforce a standard header file guard symbol name 2018-12-14 10:47:13 +00:00
driver-nodedev.h Enforce a standard header file guard symbol name 2018-12-14 10:47:13 +00:00
driver-nwfilter.h Enforce a standard header file guard symbol name 2018-12-14 10:47:13 +00:00
driver-secret.h Enforce a standard header file guard symbol name 2018-12-14 10:47:13 +00:00
driver-state.h Revert "Separate out StateAutoStart from StateInitialize" 2019-03-06 10:20:31 +01:00
driver-storage.h libvirt: Introduce virConnectGetStoragePoolCapabilities 2019-03-06 11:12:48 -05:00
driver-stream.h Enforce a standard header file guard symbol name 2018-12-14 10:47:13 +00:00
driver.c Fix names for abs_top_{src,build}dir variables 2019-03-14 10:05:28 +01:00
driver.h Enforce a standard header file guard symbol name 2018-12-14 10:47:13 +00:00
dtrace2systemtap.pl Remove all Author(s): lines from source file headers 2018-12-13 16:08:38 +00:00
internal.h Remove EMPTYSTR macro 2019-02-14 14:09:38 +01:00
libvirt_admin_private.syms
libvirt_admin_public.syms
libvirt_atomic.syms
libvirt_driver_modules.syms
libvirt_esx.syms
libvirt_internal.h Enforce a standard header file guard symbol name 2018-12-14 10:47:13 +00:00
libvirt_libssh2.syms
libvirt_libssh.syms
libvirt_linux.syms
libvirt_lxc.syms
libvirt_openvz.syms
libvirt_private.syms snapshot: Rename file for virDomainMomentObj 2019-03-22 01:18:34 -05:00
libvirt_probes.d
libvirt_public.syms libvirt: Introduce virConnectGetStoragePoolCapabilities 2019-03-06 11:12:48 -05:00
libvirt_qemu_probes.d
libvirt_qemu.syms
libvirt_remote.syms rpc: client: incapsulate error checks 2019-02-08 16:51:45 +01:00
libvirt_sasl.syms
libvirt_vmware.syms
libvirt_vmx.syms
libvirt_xenconfig.syms
libvirt-admin.c Use NULLSTR_EMPTY 2019-02-14 14:09:38 +01:00
libvirt-admin.conf
libvirt-domain-snapshot.c snapshot: More clarification about REDEFINE 2019-03-15 08:32:37 -05:00
libvirt-domain.c docs: Consistent spacing in *GetXMLDesc functions 2019-03-13 20:28:52 -05:00
libvirt-host.c
libvirt-interface.c docs: Consistent spacing in *GetXMLDesc functions 2019-03-13 20:28:52 -05:00
libvirt-lxc.c Remove all Author(s): lines from source file headers 2018-12-13 16:08:38 +00:00
libvirt-lxc.pc.in
libvirt-network.c docs: Consistent spacing in *GetXMLDesc functions 2019-03-13 20:28:52 -05:00
libvirt-nodedev.c
libvirt-nwfilter.c docs: Consistent spacing in *GetXMLDesc functions 2019-03-13 20:28:52 -05:00
libvirt-qemu.c Remove all Author(s): lines from source file headers 2018-12-13 16:08:38 +00:00
libvirt-qemu.pc.in
libvirt-secret.c
libvirt-storage.c libvirt: Introduce virConnectGetStoragePoolCapabilities 2019-03-06 11:12:48 -05:00
libvirt-stream.c
libvirt.c Revert "Separate out StateAutoStart from StateInitialize" 2019-03-06 10:20:31 +01:00
libvirt.conf
libvirt.pc.in
lock_protocol-structs
lxc_monitor_protocol-structs
lxc_protocol-structs
Makefile.am Drop support for "Red Hat" init scripts 2019-03-15 18:36:19 +01:00
qemu_protocol-structs
README Drop UML driver 2018-12-17 17:52:46 +01:00
remote_protocol-structs libvirt: Introduce virConnectGetStoragePoolCapabilities 2019-03-06 11:12:48 -05: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
 * xenapi/       - Xen using libxenserver


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