libvirt/src
Laine Stump 70d15c9ac6 qemu: initially reserve one open pcie-root-port for hotplug
For machinetypes with a pci-root bus (all legacy PCI), libvirt will
make a "fake" reservation for one extra slot prior to assigning
addresses to unaddressed PCI endpoint devices in the domain. This will
trigger auto-adding of a pci-bridge for the final device to be
assigned an address *if that device would have otherwise instead been
the last device on the last available pci-bridge*; thus it assures
that there will always be at least one slot left open in the domain's
bus topology for expansion (which is important both for hotplug (since
a new pci-bridge can't be added while the guest is running) as well as
for offline additions to the config (since adding a new device might
otherwise in some cases require re-addressing existing devices, which
we want to avoid)).

It's important to note that for the above case (legacy PCI), we must
check for the special case of all slots on all buses being occupied
*prior to assigning any addresses*, and avoid attempting to reserve
the extra address in that case, because there is no free address in
the existing topology, so no place to auto-add a pci-bridge for
expansion (i.e. it would always fail anyway). Since that condition can
only be reached by manual intervention, this is acceptable.

For machinetypes with pcie-root (Q35, aarch64 virt), libvirt's
methodology for automatically expanding the bus topology is different
- pcie-root-ports are plugged into slots (soon to be functions) of
pcie-root as needed, and the new endpoint devices are assigned to the
single slot in each pcie-root-port. This is done so that the devices
are, by default, hotpluggable (the slots of pcie-root don't support
hotplug, but the single slot of the pcie-root-port does). Since
pcie-root-ports can only be plugged into pcie-root, and we don't
auto-assign endpoint devices to the pcie-root slots, this means
topology expansion doesn't compete with endpoint devices for slots, so
we don't need to worry about checking for all "useful" slots being
free *prior* to assigning addresses to new endpoint devices - as a
matter of fact, if we attempt to reserve the open slots before the
used slots, it can lead to errors.

Instead this patch just reserves one slot for a "future potential"
PCIe device after doing the assignment for actual devices, but only
if the only PCI controller defined prior to starting address
assignment was pcie-root, and only if we auto-added at least one PCI
controller during address assignment. This assures two things:

1) that reserving the open slots will only be done when the domain is
   initially defined, never at any time after, and

2) that if the user understands enough about PCI controllers that they
   are adding them manually, that we don't mess up their plan by
   adding extras - if they know enough to add one pcie-root-port, or
   to manually assign addresses such that no pcie-root-ports are
   needed, they know enough to add extra pcie-root-ports if they want
   them (this could be called the "libguestfs clause", since
   libguestfs needs to be able to create domains with as few
   devices/controllers as possible).

This is set to reserve a single free port for now, but could be
increased in the future if public sentiment goes in that direction
(it's easy to increase later, but essentially impossible to decrease)
2016-11-14 14:23:48 -05:00
..
access conf: Add new secret type "tls" 2016-09-09 08:20:05 -04:00
admin admin: Use the newly introduced close callback handling helpers 2016-11-14 10:18:56 +01:00
bhyve Introduce virDomainChrSourceDefNew for virDomainChrDefPtr 2016-10-21 14:03:36 -04:00
conf qemu: auto-add pcie-root-port/dmi-to-pci-bridge controllers as needed 2016-11-14 14:19:36 -05:00
cpu Move CMT feature filtering to QEMU driver 2016-09-22 15:40:09 +02:00
esx virDomainDefParse{File,String}: Introduce @parseOpaque argument 2016-09-26 16:50:12 +02:00
hyperv hyperv: additional server 2008 wmi classes 2016-09-15 09:27:48 +02:00
interface Fix Multiple Typos 2016-09-22 13:55:09 -04:00
libxl libxl: fix leaking of allocated migration ports 2016-10-24 19:42:10 -06:00
locking src: Treat PID as signed 2016-10-13 17:58:56 +08:00
logging daemon: Split filter parsing and filter defining 2016-10-10 08:27:25 +02:00
lxc lxc.conf: s/QEMU/LXC/ 2016-11-09 18:56:15 +01:00
network loopback is not always just lo 2016-11-02 18:10:39 +00:00
node_device util: Alter return value of virReadFCHost and fix mem leak 2016-10-14 06:47:36 -04:00
nwfilter global: consistently use IP rather than Ip in identifiers 2016-06-26 19:33:07 -04:00
openvz conf: Extend virDomainDeviceDefPostParse for parseOpaque 2016-09-26 16:50:12 +02:00
phyp conf: Extend virDomainDeviceDefPostParse for parseOpaque 2016-09-26 16:50:12 +02:00
qemu qemu: initially reserve one open pcie-root-port for hotplug 2016-11-14 14:23:48 -05:00
remote Change virDomainEventState to virObjectLockable 2016-10-12 12:54:47 +02:00
rpc rpc: virnetserver: Remove dead code checking the client limits 2016-08-02 14:51:13 +02:00
secret secret: Move virStorageSecretType and rename 2016-06-23 12:30:27 -04:00
security Cleanup switch statements on the hostdev subsystem type 2016-11-11 16:58:56 -05:00
storage Change virDomainEventState to virObjectLockable 2016-10-12 12:54:47 +02:00
test test driver: Deny some operations on inactive domains 2016-11-08 13:59:44 +01:00
uml Introduce virDomainChrSourceDefNew for virDomainChrDefPtr 2016-10-21 14:03:36 -04:00
util util: json: add helper to iterate and steal members of json array 2016-11-09 16:47:08 +01:00
vbox Add vbox 5.1 driver file 2016-11-08 11:19:02 +00:00
vmware conf: Extend virDomainDeviceDefPostParse for parseOpaque 2016-09-26 16:50:12 +02:00
vmx Introduce virDomainChrSourceDefNew for virDomainChrDefPtr 2016-10-21 14:03:36 -04:00
vz vz: fixed migration in p2p mode 2016-11-14 21:22:40 +03:00
xen xen: remove legacy hack for RHEL-5 Xen 2016-11-10 16:00:02 +00:00
xenapi conf: Extend virDomainDeviceDefPostParse for parseOpaque 2016-09-26 16:50:12 +02:00
xenconfig xenFormatXLDisk: Unify commas pattern for arguments 2016-10-24 06:12:23 +02:00
admin_protocol-structs admin: Introduce virAdmServerSetClientLimits 2016-05-19 12:31:53 +02:00
check-aclperms.pl
check-aclrules.pl vz: add ACL checks to API calls 2016-08-23 19:48:01 +03:00
check-driverimpls.pl
check-drivername.pl
check-symfile.pl
check-symsorting.pl
datatypes.c admin: Use the newly introduced close callback handling helpers 2016-11-14 10:18:56 +01:00
datatypes.h datatypes: Introduce some admin-related close callback handling helpers 2016-11-14 10:18:56 +01:00
driver-hypervisor.h cpuGetModels: Switch to virArch 2016-09-22 15:40:08 +02:00
driver-interface.h
driver-network.h
driver-nodedev.h Introduce node device lifecycle event APIs 2016-08-02 09:52:00 -04:00
driver-nwfilter.h
driver-secret.h Removing probing of secondary drivers 2015-01-27 12:02:04 +00:00
driver-state.h
driver-storage.h Introduce storage lifecycle event APIs 2016-06-16 12:22:11 -04:00
driver-stream.h
driver.c driver.c:fix a typo 2016-09-21 16:17:22 -04:00
driver.h
dtrace2systemtap.pl
fdstream.c fdstream: don't raise error on SIGPIPE if abort requested 2016-05-02 10:13:05 -04:00
fdstream.h
internal.h internal: Introduce macro for stealing pointers 2016-08-05 08:38:20 +02:00
libvirt_admin_private.syms datatypes: Introduce some admin-related close callback handling helpers 2016-11-14 10:18:56 +01:00
libvirt_admin_public.syms admin: fix virt-admin startup crash by calling virAdmInitialize 2016-06-29 16:33:08 +02:00
libvirt_atomic.syms
libvirt_driver_modules.syms
libvirt_esx.syms
libvirt_gnutls.syms
libvirt_internal.h daemon: add connection close rpc 2016-03-01 14:18:16 +00:00
libvirt_libssh2.syms
libvirt_linux.syms nodeinfo: move host CPU APIs out into virhostcpu.c file 2016-06-09 18:31:11 +01:00
libvirt_lxc.syms Bump release to 2.0.0 and document release schedule & versioning 2016-06-14 10:59:07 +02:00
libvirt_openvz.syms
libvirt_private.syms util: json: add helper to iterate and steal members of json array 2016-11-09 16:47:08 +01:00
libvirt_probes.d
libvirt_public.syms Introduce node device lifecycle event APIs 2016-08-02 09:52:00 -04:00
libvirt_qemu_probes.d
libvirt_qemu.syms
libvirt_remote.syms Rename virNetClient*AddrString 2016-06-23 22:31:20 +02:00
libvirt_sasl.syms virneserverclient: Introduce virNetServerClientHasSASLSession 2016-05-03 15:52:50 +02:00
libvirt_vmware.syms
libvirt_vmx.syms
libvirt_xenconfig.syms xenconfig: support vif bandwidth in sexpr parser and formatter 2016-01-08 18:56:00 -07:00
libvirt_xenxlconfig.syms
libvirt-admin.c admin: Use the newly introduced close callback handling helpers 2016-11-14 10:18:56 +01:00
libvirt-admin.conf admin: Introduce libvirt-admin.conf 2015-11-30 09:36:19 +01:00
libvirt-domain-snapshot.c
libvirt-domain.c docs: Alter descriptions of perf cpu_cycles 2016-10-07 13:27:16 -04:00
libvirt-host.c cpu: Special case models == NULL in cpuGetModels 2016-09-22 15:40:08 +02:00
libvirt-interface.c
libvirt-lxc.c Don't error when attaching security label of model "none" 2016-08-03 10:58:31 +01:00
libvirt-lxc.pc.in
libvirt-network.c
libvirt-nodedev.c Fix various code comment typos 2016-09-26 08:06:30 -04:00
libvirt-nwfilter.c
libvirt-qemu.c
libvirt-qemu.pc.in
libvirt-secret.c
libvirt-storage.c storage: Document wiping formatted volume types 2016-08-02 07:01:57 +02:00
libvirt-stream.c virStream{Recv,Send}All: Increase client buffer 2016-05-02 07:56:38 +02:00
libvirt.c virconf: Fix config file path construction 2016-07-27 12:13:13 +02:00
libvirt.conf admin: Distribute libvirt-admin.conf 2015-12-01 11:44:48 +01:00
libvirt.pc.in
lock_protocol-structs Fix make check with gcc version 5 2016-01-18 15:19:21 +01:00
lxc_monitor_protocol-structs
lxc_protocol-structs
Makefile.am vbox: hookup the 5.1 C API to the unified driver 2016-11-08 09:56:33 +00:00
nodeinfo.c Remove separator argument from virBitmapParse 2016-06-20 12:09:52 +02:00
nodeinfo.h nodeinfo: move host memory APIs out into virhostmem file 2016-06-09 18:43:18 +01:00
qemu_protocol-structs
README
remote_protocol-structs Fix remote_protocol-structs after recent commit 2016-08-23 15:47:10 -04: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
 * uml/          - User Mode Linux
 * 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, UML 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