libvirt/src
Daniel P. Berrangé cfbe9f1201 build: link to glib library
Add the main glib.h to internal.h so that all common code can use it.

Historically glib allowed applications to register an alternative
memory allocator, so mixing g_malloc/g_free with malloc/free was not
safe.

This was feature was dropped in 2.46.0 with:

      commit 3be6ed60aa58095691bd697344765e715a327fc1
      Author: Alexander Larsson <alexl@redhat.com>
      Date:   Sat Jun 27 18:38:42 2015 +0200

        Deprecate and drop support for memory vtables

Applications are still encourged to match g_malloc/g_free, but it is no
longer a mandatory requirement for correctness, just stylistic. This is
explicitly clarified in

    commit 1f24b36607bf708f037396014b2cdbc08d67b275
    Author: Daniel P. Berrangé <berrange@redhat.com>
    Date:   Thu Sep 5 14:37:54 2019 +0100

        gmem: clarify that g_malloc always uses the system allocator

Applications can still use custom allocators in general, but they must
do this by linking to a library that replaces the core malloc/free
implemenentation entirely, instead of via a glib specific call.

This means that libvirt does not need to be concerned about use of
g_malloc/g_free causing an ABI change in the public libary, and can
avoid memory copying when talking to external libraries.

This patch probes for glib, which provides the foundation layer with
a collection of data structures, helper APIs, and platform portability
logic.

Later patches will introduce linkage to gobject which provides the
object type system, built on glib, and gio which providing objects
for various interesting tasks, most notably including DBus client
and server support and portable sockets APIs, but much more too.

Signed-off-by: Daniel P. Berrangé <berrange@redhat.com>
2019-10-14 10:54:42 +01:00
..
access build: link to glib library 2019-10-14 10:54:42 +01:00
admin admin: fix memory leak of typed parameters getting client info 2019-10-01 12:55:59 +01:00
bhyve build: link to glib library 2019-10-14 10:54:42 +01:00
conf qemu: Implement the ccf-assist pSeries feature 2019-10-09 17:51:47 -04:00
cpu cpu_conf: xml to cpu definition parse helper 2019-10-07 10:10:17 +02:00
cpu_map cpu_map: Introduce IA32_ARCH_CAPABILITIES MSR features 2019-06-20 14:02:36 +02:00
esx build: force a UTF-8 locale for python 2019-09-24 15:46:22 +01:00
hyperv build: force a UTF-8 locale for python 2019-09-24 15:46:22 +01:00
interface build: link to glib library 2019-10-14 10:54:42 +01:00
keycodemapdb@6280c94f30 keycodemapdb: Update submodule 2019-04-15 16:18:00 +02:00
libxl build: link to glib library 2019-10-14 10:54:42 +01:00
locking build: link to glib library 2019-10-14 10:54:42 +01:00
logging build: link to glib library 2019-10-14 10:54:42 +01:00
lxc build: link to glib library 2019-10-14 10:54:42 +01:00
network build: link to glib library 2019-10-14 10:54:42 +01:00
node_device build: link to glib library 2019-10-14 10:54:42 +01:00
nwfilter build: link to glib library 2019-10-14 10:54:42 +01:00
openvz qemu: Pass correct qemuCaps to virDomainDeviceDefPostParse 2019-08-09 13:55:54 +02:00
phyp qemu: Pass correct qemuCaps to virDomainDeviceDefPostParse 2019-08-09 13:55:54 +02:00
qemu build: link to glib library 2019-10-14 10:54:42 +01:00
remote build: link to glib library 2019-10-14 10:54:42 +01:00
rpc rpc: fix escaping of shell path for netcat binary 2019-10-01 12:57:07 +01:00
secret build: link to glib library 2019-10-14 10:54:42 +01:00
security build: link to glib library 2019-10-14 10:54:42 +01:00
storage build: link to glib library 2019-10-14 10:54:42 +01:00
test conf: Drop pointless 'domain' argument from virDomainSnapshotRedefinePrep 2019-09-27 15:23:42 +02:00
util storagefile: Fill in meta->externalDataStore 2019-10-11 14:25:59 -04:00
vbox build: link to glib library 2019-10-14 10:54:42 +01:00
vmware lib: Grab write lock when modifying list of domains 2019-09-07 08:22:30 +02:00
vmx lib: Define and use autofree for virConfPtr 2019-09-10 09:34:37 +02:00
vz build: link to glib library 2019-10-14 10:54:42 +01:00
admin_protocol-structs remote: don't pull anonymous enums into rpc protocol structs 2019-10-01 14:27:15 +01:00
check-aclperms.pl
check-aclrules.pl qemu: delete methods which are no longer supported 2019-06-27 14:41:48 +01:00
check-driverimpls.pl maint: Drop dead code in check-driverimpls.pl 2019-07-10 11:46:22 -05:00
check-drivername.pl perl: Don't hardcode interpreter path 2017-09-19 16:04:53 +02:00
check-symfile.pl
check-symsorting.pl
datatypes.c network: add public APIs for network port object 2019-06-17 15:19:54 +01:00
datatypes.h network: add public APIs for network port object 2019-06-17 15:19:54 +01:00
driver-hypervisor.h api: introduce virConnectSetIdentity for passing uid, gid, selinux info 2019-09-16 11:25:01 +01:00
driver-interface.h Use #pragma once in driver headers 2019-06-13 17:05:08 +02:00
driver-network.h network: add public APIs for network port object 2019-06-17 15:19:54 +01:00
driver-nodedev.h Use #pragma once in driver headers 2019-06-13 17:05:08 +02:00
driver-nwfilter.h Use #pragma once in driver headers 2019-06-13 17:05:08 +02:00
driver-secret.h Use #pragma once in driver headers 2019-06-13 17:05:08 +02:00
driver-state.h remote: in per-driver daemons ensure that state initialize succeeds 2019-08-09 14:06:31 +01:00
driver-storage.h Use #pragma once in driver headers 2019-06-13 17:05:08 +02:00
driver-stream.h Use #pragma once in driver headers 2019-06-13 17:05:08 +02:00
driver.c src/driver.c: remove duplicated code in virGetConnect* functions 2019-10-10 13:51:18 -04:00
driver.h driver: Introduce virDriverShouldAutostart() 2019-10-08 16:42:19 +02:00
dtrace2systemtap.pl
internal.h build: link to glib library 2019-10-14 10:54:42 +01:00
libvirt_admin_private.syms
libvirt_admin_public.syms
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 storagefile: Make GetMetadataInternal static 2019-10-11 13:41:21 -04:00
libvirt_probes.d
libvirt_public.syms api: introduce virConnectSetIdentity for passing uid, gid, selinux info 2019-09-16 11:25:01 +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-admin.c util: remove some no-op thread functions 2019-09-19 12:50:21 +01:00
libvirt-admin.conf
libvirt-domain-checkpoint.c backup: Introduce virDomainCheckpoint APIs 2019-07-26 16:48:58 -05:00
libvirt-domain-snapshot.c snapshot: Add VIR_DOMAIN_SNAPSHOT_CREATE_VALIDATE flag 2019-07-10 17:34:58 -05:00
libvirt-domain.c Revert "src: Document autostart for session demon" 2019-10-08 16:42:19 +02:00
libvirt-host.c api: introduce virConnectSetIdentity for passing uid, gid, selinux info 2019-09-16 11:25:01 +01:00
libvirt-interface.c
libvirt-lxc.c
libvirt-lxc.pc.in
libvirt-network.c virNetworkGetDHCPLeases: fix docstring format 2019-06-20 15:49:19 +02:00
libvirt-nodedev.c
libvirt-nwfilter.c
libvirt-qemu.c
libvirt-qemu.pc.in
libvirt-secret.c
libvirt-storage.c storage: Add iscsi-direct pool list type flag 2019-07-13 17:40:09 +02:00
libvirt-stream.c
libvirt.c util: remove some no-op thread functions 2019-09-19 12:50:21 +01:00
libvirt.conf
libvirt.pc.in
lock_protocol-structs
lxc_monitor_protocol-structs
lxc_protocol-structs
Makefile.am build: link to glib library 2019-10-14 10:54:42 +01:00
qemu_protocol-structs
README xenapi: remove driver 2019-09-03 15:37:54 -06:00
remote_protocol-structs remote: don't pull anonymous enums into rpc protocol structs 2019-10-01 14:27:15 +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