]> git.ipfire.org Git - thirdparty/libvirt.git/log
thirdparty/libvirt.git
2 weeks agoqemuxml2argvmock: Fix behaviour of 'virCommandPass' mock
Peter Krempa [Fri, 15 May 2026 12:34:27 +0000 (14:34 +0200)] 
qemuxml2argvmock: Fix behaviour of 'virCommandPass' mock

The 'virCommandPass' mock in 'qemuxml2argvmock.so' skipped passing most
FDs to the real implementation of 'virCommandPass', except for few fake
FDs that were hardcoded.

This meant that if a test case had an valid FD that it used for testing
that FD would be leaked. At the same time fake fds 1730, 1731, 1732
would be actually passed to the virCommand itself although the FD was
invalid.

Since neither of the above makes sense fix the implementation the
following way:

 - refuse to pass any STDIO fds
     They are real and they would break test program output. Some tests
     do try to use them errorneously; they will be addressed later.

 - pass real FDs to virCommand
    Real FDs can be properly handled by virCommand. Especially they will
    be closed once the virCommand object is disposed of.

 - don't pass fake FDs
    They create extra noise e.g. in valgrind. Skip those as it makes no
    sense to handle those.

This patch addresses most failures that valgrind reports with
--track-fds=all.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
2 weeks agoqemuFDPassLogFDInfo: Check if FD is valid before 'fstat'-ing it
Peter Krempa [Mon, 18 May 2026 08:38:12 +0000 (10:38 +0200)] 
qemuFDPassLogFDInfo: Check if FD is valid before 'fstat'-ing it

Some test cases (qemuxmlconftest) currently use made up descriptors,
which cause e.g. valgrind to be unhappy:

 ==831186== File descriptor 1729 Invalid file descriptor
 ==831186==    at 0x531042E: fgetxattr (in /usr/lib64/libc.so.6)
 ==831186==    by 0x5AE2846: ??? (in /usr/lib64/libselinux.so.1)
 ==831186==    by 0x5AE7093: fgetfilecon_raw (in /usr/lib64/libselinux.so.1)
 ==831186==    by 0x4EB736F: qemuFDPassLogFDInfo (qemu_fd.c:92)
 ==831186==    by 0x4EB7B8E: qemuFDPassDirectTransferCommand (qemu_fd.c:443)

when tracking FDs. Since 'qemuFDPassLogFDInfo' just logs information
about the FD we can simply not query the FD if it's made up.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
2 weeks agoutil: command: Extract common parts of FD closing to virCommandMassClose
Peter Krempa [Wed, 13 May 2026 09:15:03 +0000 (11:15 +0200)] 
util: command: Extract common parts of FD closing to virCommandMassClose

Extract the lookup of used FDs and their setup to virCommandMassClose
rather than duplicate it in the two functions we have for using
different modes of FD closing.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
2 weeks agoqemu: Stop mocking 'qemuOpenChrChardevUNIXSocket'
Peter Krempa [Wed, 13 May 2026 15:39:06 +0000 (17:39 +0200)] 
qemu: Stop mocking 'qemuOpenChrChardevUNIXSocket'

The tests now use 'testQemuPrepareHostBackendChardevOne' which replaces
'qemuProcessPrepareHostBackendChardevOne' which is skipped as it is a
host setup step.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
2 weeks agoqemuxmlconftest: Remove unused 'monitor_chr' from testCompareXMLToArgv
Peter Krempa [Wed, 13 May 2026 15:14:54 +0000 (17:14 +0200)] 
qemuxmlconftest: Remove unused 'monitor_chr' from testCompareXMLToArgv

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
2 weeks agovirsh: fix entering interactive session
Roman Bogorodskiy [Sat, 23 May 2026 07:24:48 +0000 (09:24 +0200)] 
virsh: fix entering interactive session

When entering an interactive session, that is, without a command
specified:

  virsh --connect $URI

virsh currently segfaults because it tries to access
ctl->cmd->def->handler and the ctl->cmd is NULL.

Fix by checking if ctl->cmd is not NULL before doing further checks.

Fixes: b489eb8d6b52d4183754a5d1da55006148a331e4
Signed-off-by: Roman Bogorodskiy <bogorodskiy@gmail.com>
Reviewed-by: Peter Krempa <pkrempa@redhat.com>
2 weeks agoci: Fix --engine flag positioning in helper script
Radoslaw Smigielski via Devel [Fri, 22 May 2026 16:57:48 +0000 (18:57 +0200)] 
ci: Fix --engine flag positioning in helper script

The --engine flag was being added to positional_args before the "run"
subcommand, which resulted in incorrect lcitool invocations:

  lcitool container --engine podman run ...  (wrong)

This caused "invalid choice: 'podman'" errors because lcitool expected
a COMMAND argument at that position.

Fix by moving the --engine flag to opts array, which is added after
the "run" subcommand, resulting in the correct command structure:

  lcitool container run --engine podman ...  (correct)

Example:

 $ ./ci/helper run fedora-44 --job codestyle --engine podman
  usage: lcitool container [-h] COMMAND ...
 lcitool container: error: argument COMMAND: invalid choice: 'podman' (choose from engines, build, run, shell)

The same error happens if "--engine" option is set to different
than "auto" value.

Signed-off-by: Radoslaw Smigielski <rsmigiel@redhat.com>
Reviewed-by: Peter Krempa <pkrempa@redhat.com>
3 weeks agoNEWS: add latest ZFS driver changes
George Melikov [Tue, 19 May 2026 16:00:17 +0000 (19:00 +0300)] 
NEWS: add latest ZFS driver changes

Signed-off-by: George Melikov <mail@gmelikov.ru>
Reviewed-by: Roman Bogorodskiy <bogorodskiy@gmail.com>
3 weeks agoNEWS: add missing ZFS driver new feature to 11.7.0
George Melikov [Tue, 19 May 2026 16:05:07 +0000 (19:05 +0300)] 
NEWS: add missing ZFS driver new feature to 11.7.0

Document native volume resizing support.

Signed-off-by: George Melikov <mail@gmelikov.ru>
Reviewed-by: Roman Bogorodskiy <bogorodskiy@gmail.com>
3 weeks agoqemu: emit channel lifecycle event
Lucas Kornicki [Tue, 19 May 2026 13:11:36 +0000 (15:11 +0200)] 
qemu: emit channel lifecycle event

Emit the channel lifecycle event on VSERPORT_CHANGE
and when refreshing virtio state.

On "org.qemu.guest_agent.0" channel state change both
agent and channel lifecycle events are emitted in that order.

Signed-off-by: Lucas Kornicki <lucas.kornicki@nutanix.com>
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
3 weeks agoconf,remote: add channel lifecycle domain event
Lucas Kornicki [Tue, 19 May 2026 13:11:35 +0000 (15:11 +0200)] 
conf,remote: add channel lifecycle domain event

Add support for a new domain event which can be used to track
the state of any virtio channel.

Previously one could only monitor the "org.qemu.guest_agent.0" channel
which had a dedicated agent lifecycle event. The channel lifecycle event
will be emitted alongside the agent specific one.

Signed-off-by: Lucas Kornicki <lucas.kornicki@nutanix.com>
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
3 weeks agobhyve: implement the domainSetMemoryParameters API
Roman Bogorodskiy [Mon, 18 May 2026 17:30:19 +0000 (19:30 +0200)] 
bhyve: implement the domainSetMemoryParameters API

Signed-off-by: Roman Bogorodskiy <bogorodskiy@gmail.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
3 weeks agobhyve: process: factor out rctl(8) code
Roman Bogorodskiy [Mon, 18 May 2026 16:33:12 +0000 (18:33 +0200)] 
bhyve: process: factor out rctl(8) code

Factor out all rctl(8) execution code to bhyve_rctl.c.

Signed-off-by: Roman Bogorodskiy <bogorodskiy@gmail.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
3 weeks agobhyve: implement the domainGetMemoryParameters API
Roman Bogorodskiy [Sat, 16 May 2026 08:30:32 +0000 (10:30 +0200)] 
bhyve: implement the domainGetMemoryParameters API

Implement the domainGetMemoryParameters() API for the bhyve driver.
To parse live limits execute rctl(8) to list the active rules and parse
them.

Introduce the bhyve_rctl.c for working with rctl(8).

Signed-off-by: Roman Bogorodskiy <bogorodskiy@gmail.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
3 weeks agobhyve: add memtune support
Roman Bogorodskiy [Fri, 15 May 2026 14:32:54 +0000 (16:32 +0200)] 
bhyve: add memtune support

Add support of the memtune's hard_limit configuration:

  <memtune>
    <hard_limit ... >
  </memtune>

to the bhyve driver.

Just like in the block I/O tuning case, memory limits are set using the
rctl(8) tool.

Syntax for that is:

 rctl -a process:<pid>:memoryuse:deny=1073741824

Extend bhyveSetResourceLimits() to execute this command if it's
requested by the domain XML.

Signed-off-by: Roman Bogorodskiy <bogorodskiy@gmail.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
3 weeks agocpu_map: Add DiamondRapids CPU model
Jiri Denemark [Thu, 7 May 2026 11:24:36 +0000 (13:24 +0200)] 
cpu_map: Add DiamondRapids CPU model

Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
3 weeks agocpu_map: Add new versions of GraniteRapids CPU model
Jiri Denemark [Thu, 7 May 2026 11:23:25 +0000 (13:23 +0200)] 
cpu_map: Add new versions of GraniteRapids CPU model

Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
3 weeks agocpu_map: Add new versions of SapphireRapids CPU model
Jiri Denemark [Thu, 7 May 2026 11:22:42 +0000 (13:22 +0200)] 
cpu_map: Add new versions of SapphireRapids CPU model

Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
3 weeks agocpu_map: Add new versions of SierraForest CPU model
Jiri Denemark [Thu, 7 May 2026 11:21:34 +0000 (13:21 +0200)] 
cpu_map: Add new versions of SierraForest CPU model

Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
3 weeks agocpu_map: Add new versions of ClearwaterForest CPU model
Jiri Denemark [Thu, 7 May 2026 11:20:18 +0000 (13:20 +0200)] 
cpu_map: Add new versions of ClearwaterForest CPU model

Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
3 weeks agosync_qemu_models_i386: Add missing features to translation map
Jiri Denemark [Thu, 7 May 2026 11:14:11 +0000 (13:14 +0200)] 
sync_qemu_models_i386: Add missing features to translation map

Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
3 weeks agocpu_map: Add APX (Advanced Performance Extensions) CPUID features
Jiri Denemark [Thu, 7 May 2026 10:50:35 +0000 (12:50 +0200)] 
cpu_map: Add APX (Advanced Performance Extensions) CPUID features

QEMU commit 60caf14339262b10423e21b1d7d39ad7edec82b7

Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
3 weeks agocpu_map: Add avx10-vnni-int CPU feature
Jiri Denemark [Thu, 7 May 2026 10:47:49 +0000 (12:47 +0200)] 
cpu_map: Add avx10-vnni-int CPU feature

QEMU commit 24a9bc108840812dfb94edc65962c1998120f77b

Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
3 weeks agocpu_map: Add CPUID feature for MOVRS
Jiri Denemark [Thu, 7 May 2026 10:37:11 +0000 (12:37 +0200)] 
cpu_map: Add CPUID feature for MOVRS

QEMU commit f8e830300c9edeaa142fe4cc244d63770a3be4f5

Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
3 weeks agocpu_map: Add CET related CPU features
Jiri Denemark [Thu, 7 May 2026 10:00:28 +0000 (12:00 +0200)] 
cpu_map: Add CET related CPU features

QEMU commit 2f25476ae7f3b4c28fde64584a04734b14c8fd37

Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
3 weeks agocpu_map: Add CPUID features for AMX instructions
Jiri Denemark [Thu, 7 May 2026 09:46:48 +0000 (11:46 +0200)] 
cpu_map: Add CPUID features for AMX instructions

The features are reported in a 0x1 subleaf of 0x1e CPUID leaf.

QEMU commit 956b8f0fc38a5ead18d9bf5ceba0861627738835 (some feature were
later renamed by 85dc6147e79140f17b7e4333ec14f302bf9b5e97, which
happened in the same QEMU release so we don't need to care about the
original names).

Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
3 weeks agocpu_map: Add gmet and vmx-mbec features for nested virtualization
Jiri Denemark [Thu, 7 May 2026 09:40:57 +0000 (11:40 +0200)] 
cpu_map: Add gmet and vmx-mbec features for nested virtualization

QEMU commits 746a823a17f25393cc8c0cd1257f6dcef757bc09 and
bfff4b2ae5452463ab8c14b4a8a020288b5ff5d8

Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
3 weeks agosync_qemu_models_i386: Convert family/model to decimal
Jiri Denemark [Wed, 20 May 2026 09:56:35 +0000 (11:56 +0200)] 
sync_qemu_models_i386: Convert family/model to decimal

QEMU defines some CPU models with hexadecimal family, but our CPU map
loading code expects decimals.

Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
3 weeks agosync_qemu_models_i386: Remove forgotten parentheses
Jiri Denemark [Thu, 7 May 2026 08:58:44 +0000 (10:58 +0200)] 
sync_qemu_models_i386: Remove forgotten parentheses

children variable is a list returned by getchildren().

Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
3 weeks agoconf: Assert virDomainChrDeviceState and virConnectDomainEventAgentLifecycleState...
Michal Privoznik [Wed, 20 May 2026 10:42:34 +0000 (12:42 +0200)] 
conf: Assert virDomainChrDeviceState and virConnectDomainEventAgentLifecycleState enums are in sync

When QEMU driver emits agent connected/disconnected events (inside of
processSerialChangedEvent()) it declares a variable of
virDomainChrDeviceState enum, and then passes this variable to
virDomainEventAgentLifecycleNewFromObj(). But we document the agent
lifecycle state to be of virConnectDomainEventAgentLifecycleState enum.

Therefore, make sure values from
virConnectDomainEventAgentLifecycleState enum are of the same value as
those in virDomainChrDeviceState enum.

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
3 weeks agocpu_map: Add Neoverse-V2 CPU model
Jonathan Davies [Tue, 19 May 2026 13:04:17 +0000 (14:04 +0100)] 
cpu_map: Add Neoverse-V2 CPU model

Add Neoverse V2 as a supported cpu model.

Signed-off-by: Jonathan Davies <jonathan.davies@nutanix.com>
Reviewed-by: Jiri Denemark <jdenemar@redhat.com>
3 weeks agovirnetdevbandwidth: Only clear qdisc for defined directions
Wesley Hershberger via Devel [Thu, 7 May 2026 17:03:15 +0000 (12:03 -0500)] 
virnetdevbandwidth: Only clear qdisc for defined directions

When virNetDevBandwidthSet is called for a macvtap device in
qemu_command and qemu_hotplug, qemuDomainInterfaceSetDefaultQDisc has
been called already, setting the iface qdisc to 'noqueue'. If the
interface has an inbound-only bandwidth limit, the outgoing qdisc
on the device will be reset to the system default.

<interface type="direct">
  ...
  <bandwidth>
    <inbound average='3125000' peak='3125000'/>
  </bandwidth>
</interface>

This only clears the qdisc on an interface before a bandwidth limit is
actually set.

Closes: https://gitlab.com/libvirt/libvirt/-/work_items/875
Signed-off-by: Wesley Hershberger <wesley.hershberger@canonical.com>
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
3 weeks agovirnetdevbandwidth: Split virNetDevBandwidthClear into two helpers
Wesley Hershberger via Devel [Thu, 7 May 2026 17:03:14 +0000 (12:03 -0500)] 
virnetdevbandwidth: Split virNetDevBandwidthClear into two helpers

This allows virNetDevBandwidthSet to clear only the interface's qdisc
for directions where bandwidth is defined (see the next patch)

Signed-off-by: Wesley Hershberger <wesley.hershberger@canonical.com>
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
3 weeks agovirTypedParamsValidateTemplate: Fix counting of templates
Peter Krempa [Sat, 16 May 2026 07:52:30 +0000 (09:52 +0200)] 
virTypedParamsValidateTemplate: Fix counting of templates

There are 2 bugs in virTypedParamsValidateTemplate's counting of the
passed amount of templates:
 - the condition looked for empty strings rather than non-empty ones
 - the count was 1 more than the amount of templates due to use of
   post-increment directly in the condition

Fixes: 45617351585caa2c5bcc51af48bd32fd750e7afd
Closes: https://gitlab.com/libvirt/libvirt/-/work_items/880
Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Jiri Denemark <jdenemar@redhat.com>
3 weeks agoutil: virobject: Add debug refcounting output
Peter Krempa [Thu, 30 Apr 2026 05:32:30 +0000 (07:32 +0200)] 
util: virobject: Add debug refcounting output

virObject internally uses g_object which doesn't expose the internal
reference count. When debug logging we log ref/unref operations but when
reading logs it's hard to follow if a precise reference count is needed
at some points.

Add a private reference counter variable and use it in debug messages of
virObject operations.

The code is designed so that it can be disabled if ever needed since
it's just for debugging. For now let's keep it enabled.

With all the informaton added the logs look like (timestamps trimmed):

 debug : virObjectRef:424 : OBJECT_REF: obj=0x7fffac001d30 classname=qemuMonitor refs=3
 debug : virObjectUnref:392 : OBJECT_UNREF: obj=0x7fffac001d30 classname=qemuMonitor refs=2
 debug : virObjectNew:264 : OBJECT_NEW: obj=0x7fffac00db70 classname=virDomainEventAgentLifecycle
 debug : virObjectUnref:392 : OBJECT_UNREF: obj=0x7fffac00db70 classname=virDomainEventAgentLifecycle refs=0
 debug : vir_object_finalize:328 : OBJECT_DISPOSE: obj=0x7fffac00db70 classname=virDomainEventAgentLifecycle

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
3 weeks agovirNetClientStreamEventRemoveCallback: Add debug log
Peter Krempa [Wed, 29 Apr 2026 11:37:58 +0000 (13:37 +0200)] 
virNetClientStreamEventRemoveCallback: Add debug log

Log when removing event callback including internal state.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
3 weeks agoremoteClientFree: Add debug log of parameters
Peter Krempa [Wed, 29 Apr 2026 11:37:06 +0000 (13:37 +0200)] 
remoteClientFree: Add debug log of parameters

Add a debug log when remote client is beng disposed of.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
3 weeks agodaemonRemoveClientStream: Add debug log
Peter Krempa [Thu, 14 May 2026 15:43:05 +0000 (17:43 +0200)] 
daemonRemoveClientStream: Add debug log

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
3 weeks agoutil: object: Add class name to the Ref/Unref/Dispose debug messages
Peter Krempa [Thu, 30 Apr 2026 05:56:54 +0000 (07:56 +0200)] 
util: object: Add class name to the Ref/Unref/Dispose debug messages

Since the object stores the pointer to the parent class object
internally we can add the name of the class of the object to the debug
messages. Since the debug messages are based on probe points propagate
it into the probe point rather than adding separate debug message.

For virObjectUnref, this also fixes the ordering of the messages to be
'unref->dispose' by invoking the PROBE before unref rather than the
other way around which didn't make sense in the logs and wouldn't allow
accessing the class pointer from the already disposed-of object.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
3 weeks agoutil: object: Downgrade PROBE points to PROBE_DEBUG
Peter Krempa [Thu, 30 Apr 2026 05:41:14 +0000 (07:41 +0200)] 
util: object: Downgrade PROBE points to PROBE_DEBUG

The debug messages related to PROBE points in object handling don't
really need to be logged with the 'info' priority. Downshift them to
'debug'.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
3 weeks agoutil: probe: Add 'PROBE_DEBUG'
Peter Krempa [Thu, 30 Apr 2026 05:39:00 +0000 (07:39 +0200)] 
util: probe: Add 'PROBE_DEBUG'

The standard 'PROBE' macro uses the 'info' priority for the log entry
corresponding to the probe point. While in some cases it makes sense to
log above debug priority in others it does not. Add the possibility to
pick a lower priority level.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
3 weeks agolibvirt_probes: Fix alignment of 'virobject' probe points
Peter Krempa [Thu, 30 Apr 2026 05:44:31 +0000 (07:44 +0200)] 
libvirt_probes: Fix alignment of 'virobject' probe points

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
3 weeks agoremote_driver: Don't leak opaque pointer passed to 'virStreamEventAddCallback'
Peter Krempa [Thu, 14 May 2026 15:19:55 +0000 (17:19 +0200)] 
remote_driver: Don't leak opaque pointer passed to 'virStreamEventAddCallback'

In the implementation of the virStream events in the remote driver, the
freeing of the passed opaque data for the callback was guarded by:

  if (!cbdata->cb && cbdata->ff)
     (cbdata->ff)(cbdata->opaque);

thus if the 'cb' is passed to 'virStreamEventAddCallback' the private
data would never be freed once 'virStreamEventRemoveCallback' is called.

The issue can be reproduced both in client applications which would
register the stream callback and also in the libvirt daemons, when
modular daemons are used. The virStream remote driver client code is in
such deployments also used to tunnel requests from the hypervisor daemon
(virtqemud) to sub-daemons (virstoraged).

In those cases the leak is amplified as the stream event callback is
internally used to do the tunnelling and the daemon dispatch code stores
a reference to the 'virNetClient' object associated with the connection.
As this causes the last reference on the virNetClient object to be still
active, the corresponding connection to the storage daemon isn't closed
either, leaking a FD both in virtqemud and virtstoraged.

Internally the data is stored in 'struct remoteStreamCallbackData' which
is defined only in 'remote_driver.c' and there's no code which would
update the 'cb' field, thus the leak can't be avoided.

Remove the check for 'cb'. My assumption is that this was supposed to
mimic the 'dispatching' field  in 'util/fdstream.c' or similar logic in
other dispatch functions.

The patch also adds debug statements which I've used to trace this.

The leak of a connection in 'virtqemud' has the following backtrace
under valgrind (note that the pointer is considered reachable and thus
this isn't visible in default config):

==3678343== 136 bytes in 1 blocks are still reachable in loss record 2,680 of 2,964
==3678343==    at 0x48FC6CD: calloc (vg_replace_malloc.c:1616)
==3678343==    by 0x4ED8A91: g_malloc0 (in /usr/lib64/libglib-2.0.so.0.8600.5)
==3678343==    by 0x5019CA2: g_type_class_get (in /usr/lib64/libgobject-2.0.so.0.8600.5)
==3678343==    by 0x5001011: g_object_new_with_properties (in /usr/lib64/libgobject-2.0.so.0.8600.5)
==3678343==    by 0x5001EA0: g_object_new (in /usr/lib64/libgobject-2.0.so.0.8600.5)
==3678343==    by 0x499E653: virObjectNew (virobject.c:252)
==3678343==    by 0x499EA0F: virObjectLockableNew (virobject.c:274)
==3678343==    by 0x4A84651: virNetClientStreamNew (virnetclientstream.c:144)
==3678343==    by 0x4AE82AE: remoteStorageVolUpload (remote_client_bodies.h:8242)
==3678343==    by 0x4BED13D: virStorageVolUpload (libvirt-storage.c:1809)
==3678343==    by 0x4043539: remoteDispatchStorageVolUpload (remote_daemon_dispatch_stubs.h:20248)
==3678343==    by 0x4043539: remoteDispatchStorageVolUploadHelper (remote_daemon_dispatch_stubs.h:20218)
==3678343==    by 0x4A89A2C: virNetServerProgramDispatchCall (virnetserverprogram.c:423)
==3678343==    by 0x4A89A2C: virNetServerProgramDispatch (virnetserverprogram.c:299)

Resolves: https://redhat.atlassian.net/browse/RHEL-170773
Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
3 weeks agovirauth: Verify virConnectAuth::cb is set in virAuthGetPasswordPath()
Michal Privoznik [Fri, 15 May 2026 12:51:15 +0000 (14:51 +0200)] 
virauth: Verify virConnectAuth::cb is set in virAuthGetPasswordPath()

Simirarly to virAuthGetUsernamePath() check whether callback used
to collect credentials is actually set before calling it. This
bug is easily reproducible, for instance as:

  int credtype[] = { VIR_CRED_PASSPHRASE };
  virConnectPtr conn = virConnectOpenAuth("esx://root@example.com/",
                                          &(virConnectAuth){
                                          .credtype = credtype,
                                          .ncredtype = 1,
                                          .cb = NULL
                                          },
                                          0);

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
3 weeks agoNEWS: Add information about VMWare domains having different UUIDs
Martin Kletzander [Thu, 14 May 2026 15:35:04 +0000 (17:35 +0200)] 
NEWS: Add information about VMWare domains having different UUIDs

Signed-off-by: Martin Kletzander <mkletzan@redhat.com>
Reviewed-by: Peter Krempa <pkrempa@redhat.com>
3 weeks agoesx: Track VMs by instanceUuid instead of UUID
Martin Kletzander [Tue, 12 May 2026 10:16:54 +0000 (12:16 +0200)] 
esx: Track VMs by instanceUuid instead of UUID

The difference is that the usual UUID is supposed to be unique per host
and instanceUuid should be unique across the whole cluster.  One could
think of them as HUID and CUID (as the first "U" does apparently mean
something else in the Broadcom world).  That _would_ be fine for our
scenario.  However, that piece of information turns out to be false as
well and the UUID we were using (`config.uuid`, or in VMX the
`uuid.bios`) can be the same in two machines on the same host.

Fortunately the `FindByUuid()` function can also search for VMs based on
their `instanceUuid`, dictated by the so far omitted third parameter.
Unfortunately that parameter is not parsed (or at least properly) before
vSphere API 4.0 (the documentation says 2.0, but we are not using that
namespace and 4.0 is the lowest we can target), which we are not
specifying in the server returns a 500 HTTP error if we use the
`instanceUuid` parameter.

So this patch adds the `SOAPAction: urn:vim25/4.0` header to the cURL
requests which makes that `FindByUuid()` function work even with the
`instanceUuid` set, but without any extra labor.

After that this patch also changes all UUIDs to be parsed from the
`config.instanceUuid` (or `vc.uuid` in the VMX, but there's a fallback
to the old `uuid.bios`) and adjusts tests accordingly.

To give users (and management applications) the possibility to revert
back to the previous (legacy) behaviour a new URI query parameter is
introduced, called `legacy_uuid` which, if set to `1`, still keeps the
code working as it did before this patch.

Last, but not least it changes the parameter to aforementioned function
to be true (unless the legacy behaviour is requested, of course) and
henceforth all searching ought to be done with the more unique ID.

Resolves: https://redhat.atlassian.net/browse/RHEL-174300
Signed-off-by: Martin Kletzander <mkletzan@redhat.com>
Reviewed-by: Peter Krempa <pkrempa@redhat.com>
3 weeks agovirsh: Provide no auth callbacks for bash completer
Michal Privoznik [Thu, 14 May 2026 14:32:30 +0000 (16:32 +0200)] 
virsh: Provide no auth callbacks for bash completer

Our bash completion script parses (partially incomplete) command
line and looks for two arguments: --readonly and --connect
because in the next step it executes virsh with those two
arguments like this:

  virsh --readonly --connect $URI complete -- "text to complete"

Now, whenever virsh sees connection URI specified on its cmd line
it connects to it right away (before executing any command). This
happens inside virshConnect(). Here, virConnectOpenAuth() is
called with the default auth callback (virConnectAuthPtrDefault).
In majority of the cases this is desirable, as it might ask user
for credentials (password for example). But in case of bash
completion this is not desired because bash completion script
must not expect users to input anything (that's why we even
close stdin in cmdComplete()).

Therefore, when connecting from virsh that's executed by the bash
completion script provide no auth callbacks to prevent virsh from
asking for credentials.

Resolves: https://gitlab.com/libvirt/libvirt/-/work_items/879
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
Tested-by: Richrad W.M. Jones <rjones@redhat.com>
3 weeks agovirnetlibsshsession: Check later for auth callback in virNetLibsshAuthenticatePassword()
Michal Privoznik [Fri, 15 May 2026 07:53:10 +0000 (09:53 +0200)] 
virnetlibsshsession: Check later for auth callback in virNetLibsshAuthenticatePassword()

The first thing that virNetLibsshAuthenticatePassword() does is
read password from config file. For this it does not need auth
callback. If that password fails to authenticate then
corresponding callback from the auth callback is called. This is
actual place where auth callback should be checked for.

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
Tested-by: Richrad W.M. Jones <rjones@redhat.com>
3 weeks agovirnetsshsession: Don't check for auth callbacks in virNetSSHAuthenticatePassword()
Michal Privoznik [Thu, 14 May 2026 18:22:04 +0000 (20:22 +0200)] 
virnetsshsession: Don't check for auth callbacks in virNetSSHAuthenticatePassword()

For the VIR_NET_SSH_AUTH_PASSWORD authentication mechanism the
virNetSSHAuthenticatePassword() is called. Inside it,
virAuthGetPasswordPath() is called to obtain password. Firstly
reading from our auth.conf file is attempted and if that fails
then corresponding callback from virConnectAuthCallbackPtr is
called. But virAuthGetPasswordPath() checks whether the callback
is NULL or not. There is no need for
virNetSSHAuthenticatePassword() to check it too. Drop the
duplicate check.

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
Tested-by: Richrad W.M. Jones <rjones@redhat.com>
4 weeks agobhyve: add agent support
Roman Bogorodskiy [Tue, 5 May 2026 05:22:46 +0000 (07:22 +0200)] 
bhyve: add agent support

Implement QEMU Guest Agent support for bhyve. In bhyve it can configured
using the virtio-console device.

This change covers only two APIs using the agent:

 - DomainQemuAgentCommand -- the most generic one.
 - DomainGetHostname -- extended to support not only DHCP lease source,
   but an agent as well.

It shares the qemu agent implementation with the qemu driver.

Signed-off-by: Roman Bogorodskiy <bogorodskiy@gmail.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
4 weeks agoqemu: move qemu_agent.c to hypervisor/
Roman Bogorodskiy [Wed, 13 May 2026 16:22:57 +0000 (18:22 +0200)] 
qemu: move qemu_agent.c to hypervisor/

To prepare for the qemu agent support for the bhyve driver,
move the implementation from qemu/ to hypervisor. This way
this implementation can be shared across multiple drivers.

The move is mostly mechanical except qemuAgentOpen()
which now accepts the "timeout" argument for the agent timeout.
As the original code used QEMU_DOMAIN_PRIVATE() to access
the agent timeout value, this change allows to make the code
driver-independent.

qemuAgentOpenUnix() is wrapped with #ifndef WIN32 so it does not fail on
mingw.

Signed-off-by: Roman Bogorodskiy <bogorodskiy@gmail.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
4 weeks agoNEWS: document resctrl energy monitoring
Jedrzej Wasiukiewicz [Thu, 14 May 2026 14:41:06 +0000 (16:41 +0200)] 
NEWS: document resctrl energy monitoring

Signed-off-by: Jedrzej Wasiukiewicz <jedrzej.wasiukiewicz@intel.com>
Signed-off-by: Christopher M. Cantalupo <christopher.m.cantalupo@intel.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
4 weeks agoqemu: resctrl energy counters via domstats
Jedrzej Wasiukiewicz [Thu, 14 May 2026 14:41:05 +0000 (16:41 +0200)] 
qemu: resctrl energy counters via domstats

Added energy reporting from resctrl PERF_PK_MON through domstats:
  cpu.energy.monitor.count=1
  cpu.energy.monitor.0.name=vcpus_0
  cpu.energy.monitor.0.vcpus=0
  cpu.energy.monitor.0.pkg.count=2
  cpu.energy.monitor.0.pkg.0.id=0
  cpu.energy.monitor.0.pkg.0.core_energy=0.000000
  cpu.energy.monitor.0.pkg.0.activity=0.000000
  cpu.energy.monitor.0.pkg.1.id=1
  cpu.energy.monitor.0.pkg.1.core_energy=2.888203
  cpu.energy.monitor.0.pkg.1.activity=1.718601

Changes:
 - Added VIR_DOMAIN_STATS_CPU_ENERGY_MONITOR_* macros to libvirt-domain.h
 - Added qemuDomainGetStatsEnergy() to qemu_driver.c

Signed-off-by: Jedrzej Wasiukiewicz <jedrzej.wasiukiewicz@intel.com>
Signed-off-by: Christopher M. Cantalupo <christopher.m.cantalupo@intel.com>
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
4 weeks agoconf: add energytune to domain XML
Jedrzej Wasiukiewicz [Thu, 14 May 2026 14:41:04 +0000 (16:41 +0200)] 
conf: add energytune to domain XML

The new XML element is <energytune> under <cputune> following earlier pattern for
resctrl features (cachetune, memorytune). Energytune doesn't currently support
the "tuning" part, only monitoring. I added it as energytune for consistency with
cache and memory features, keeping all resctrl handling under cputune. This also makes
sense with current resctrl architecture - all monitoring groups are part of an
allocation group.

Changes:
 - Added <energytune> parsing to domain_conf.c
 - Added schema definition in domaincommon.rng
 - Documented the element in formatdomain.rst
 - Added energytune test

Signed-off-by: Jedrzej Wasiukiewicz <jedrzej.wasiukiewicz@intel.com>
Signed-off-by: Christopher M. Cantalupo <christopher.m.cantalupo@intel.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
4 weeks agoconf: report energy monitoring in host capabilities
Jedrzej Wasiukiewicz [Thu, 14 May 2026 14:41:03 +0000 (16:41 +0200)] 
conf: report energy monitoring in host capabilities

Expose PERF_PKG_MON energy monitoring capabilities in the host
capabilities XML.
<energy>
  <monitor maxMonitors='576'>
    <feature name='core_energy'/>
    <feature name='activity'/>
  </monitor>
</energy>

Changes:
 - Add virCapabilitiesFormatEnergy() to emit <energy> XML block
 - Add virCapabilitiesInitEnergy() to init from PERF_PKG_MON info
 - Add <energy> element and energyMonitorFeature to capability.rng
 - Update qemu_driver to support VIR_RESCTRL_MONITOR_TYPE_ENERGY
 - Add virCapsHostEnergy struct

Signed-off-by: Jedrzej Wasiukiewicz <jedrzej.wasiukiewicz@intel.com>
Signed-off-by: Christopher M. Cantalupo <christopher.m.cantalupo@intel.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
4 weeks agoutil: add PERF_PKG_MON energy monitoring support in virresctrl
Jedrzej Wasiukiewicz [Thu, 14 May 2026 14:41:02 +0000 (16:41 +0200)] 
util: add PERF_PKG_MON energy monitoring support in virresctrl

Linux 7.0 introduced in resctrl PERF_PKG_MON interface that exposes per-package
energy and performance counters. This patch extends virresctrl implementation
to discover and read energy counters from this new resource type.
(core_energy - Joules, activity - Farads)

Changes:
 - Add Energy features allow-list virResctrlEnergyFeatures
   since PERF_PKG_MON is not prefix-based.
 - Added perf_monitor_info to _virResctrlInfo to contain _virResctrlInfo capabilities
 - New virResctrlGetPerfMonitorInfo following earlier virResctrlGetMonitorInfo
   to check new resource capabilities
 - Added VIR_RESCTRL_MONITOR_TYPE_ENERGY and mapped it to energy allow-list
 - Added dvals/ndvals pair to _virResctrlMonitorStats to support floating-point
   counters and integer counters in single monitor (to support integer perf counters
   in the future).
 - Added floating-point read + parse in virResctrlMonitorGetStats for energy counters
 - Stubbed VIR_RESCTRL_MONITOR_TYPE_ENERGY in qemu_driver

Signed-off-by: Jedrzej Wasiukiewicz <jedrzej.wasiukiewicz@intel.com>
Signed-off-by: Christopher M. Cantalupo <christopher.m.cantalupo@intel.com>
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
4 weeks agoutil: virGetSubIDs: do not limit file size
Ján Tomko [Tue, 12 May 2026 11:10:43 +0000 (13:10 +0200)] 
util: virGetSubIDs: do not limit file size

On systems with many users, this file can be larger than BUFSIZ.
Since the file should only be editable by root and virFileReadAll
reallocates the buffer in increments as needed as opposed to
allocating for 'maxlen' upfront, set the maximum to INT_MAX.

https://gitlab.com/libvirt/libvirt/-/work_items/874

Signed-off-by: Ján Tomko <jtomko@redhat.com>
Reviewed-by: Peter Krempa <pkrempa@redhat.com>
4 weeks agoesx: include viralloc.h for VIR_FREE usage
Ján Tomko [Thu, 14 May 2026 21:29:00 +0000 (23:29 +0200)] 
esx: include viralloc.h for VIR_FREE usage

Fixes: af83ac00eba56e50de70d7d29d1dc7f726786aa5
Signed-off-by: Ján Tomko <jtomko@redhat.com>
4 weeks agoRevert "esx: switch VIR_FREE->g_free in esx*Free*()"
Martin Kletzander [Thu, 14 May 2026 13:52:53 +0000 (15:52 +0200)] 
Revert "esx: switch VIR_FREE->g_free in esx*Free*()"

This reverts commit 443c79dd7f7d4051fc0084baaa6c56a55d2aace4.

Change from VIR_FREE() to g_free meant there is a possible double free
when there is an error during parsing because the parsing it done
directly into the parsedUri member of the esxPrivate, free'd when it
fails and then the caller calls free on it again.  Changing back to
VIR_FREE() means there is no double free and no crash.

Reproducible easily with `virsh -c esx://l?no_verify=2`.

Signed-off-by: Martin Kletzander <mkletzan@redhat.com>
Reviewed-by: Pavel Hrdina <phrdina@redhat.com>
4 weeks agocputest: Detect unused files
Michal Privoznik [Thu, 7 May 2026 09:25:42 +0000 (11:25 +0200)] 
cputest: Detect unused files

Use newly introduced testutils APIs to detect unused files.
This is pretty much straightforward, except for one small thing:
some test cases depend on QEMU (and are NOP if built without it).
Hence the condition in testCaseEnumerate().

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
4 weeks agocputestdata: Drop unused files
Michal Privoznik [Thu, 7 May 2026 09:38:54 +0000 (11:38 +0200)] 
cputestdata: Drop unused files

There are couple of files under tests/cputestdata/ that are not
used by any test case:

1) ppc64-guest-host-model.xml - unused since its introduction in
   v1.2.19-rc1~31
2) ppc64-host+guest-host-model.xml - Same
3) x86_64-bogus-vendor.xml - Introduced in v0.8.7~195 under
   slightly different name, then renamed to the current name (in
   v3.1.0-rc1~3) but never used actually.

Just drop these three files.

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
4 weeks agonetworkxmlconftest: Detect unused files
Michal Privoznik [Wed, 6 May 2026 12:45:25 +0000 (14:45 +0200)] 
networkxmlconftest: Detect unused files

Use newly introduced testutils APIs to detect unused files.
This is pretty much straightforward except for one test case:
hostdev. This test case queries sysfs under the hood and thus is
expected to succeed on Linux and fail everywhere else. Though,
hostdev.expect.xml is thus used on Linux only. Therefore, do not
collect it on non-Linux platforms.

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
4 weeks agonetworkxmlconfdata: Remove passthrough-pf.conf
Michal Privoznik [Wed, 6 May 2026 13:42:13 +0000 (15:42 +0200)] 
networkxmlconfdata: Remove passthrough-pf.conf

The passthrough-pf.conf file is not used really, because the test
case is defined as:

  DO_TEST_VALIDATE_ERROR("passthrough-pf");

meaning the test is expected to fail in XML validation phase.
Hence, no .conf file is ever generated for it. Remove the file.

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
4 weeks agoqemuxmlconftest: Switch to virTestEnumerateTestCases()
Michal Privoznik [Wed, 6 May 2026 12:27:11 +0000 (14:27 +0200)] 
qemuxmlconftest: Switch to virTestEnumerateTestCases()

The qemuxmlconftest detects unused files in qemuxmlconfdata/
directory. But it uses its own implementation for that. But now
that there's a generic implementation available, switch to that.

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
4 weeks agotestutils: Introduce unused file detection
Michal Privoznik [Wed, 6 May 2026 12:05:43 +0000 (14:05 +0200)] 
testutils: Introduce unused file detection

This is basically a generalized version of what we have in
qemuxmlconftest (functions testConfXMLEnumerate(),
testQemuConfMarkUsed() and testConfXMLCheck()). The idea is to
reuse the code in other tests.

There's one slight difference to the original - while
qemuxmlconftest always allocated the hash table, in this
generalized version NULL table is okay.

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
4 weeks agoqemuDomainSetIOThreadParams: Move typed parameter validation to top level
Peter Krempa [Thu, 23 Apr 2026 08:51:22 +0000 (10:51 +0200)] 
qemuDomainSetIOThreadParams: Move typed parameter validation to top level

This will allow introspecting them.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
4 weeks agoqemuDomainSetSchedulerParameters: Make typed parameters introspectable
Peter Krempa [Thu, 23 Apr 2026 11:54:49 +0000 (13:54 +0200)] 
qemuDomainSetSchedulerParameters: Make typed parameters introspectable

For making introspection possible both qemuDomainSetSchedulerParameters
and qemuDomainSetSchedulerParametersFlags need to have the check
present.

Refactor the flag validation to make it present in both APIs.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
4 weeks agoutil: hostmem: Make parameters for 'virHostMemSetParameters' introspectable
Peter Krempa [Thu, 23 Apr 2026 11:13:52 +0000 (13:13 +0200)] 
util: hostmem: Make parameters for 'virHostMemSetParameters' introspectable

Refactor the validation using 'virTypedParamsValidateTemplate' and
export the template so that 'qemuNodeSetMemoryParameters' can expose
them via introspection.

In addition since 'virHostMemSetParameters' is conditionally compiled,
platforms which don't support it will not expose given params.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
4 weeks agoqemu: Reimplement 'qemuDomainValidateBlockIoTune' using 'virTypedParamsValidateTemplate'
Peter Krempa [Thu, 23 Apr 2026 11:28:43 +0000 (13:28 +0200)] 
qemu: Reimplement 'qemuDomainValidateBlockIoTune' using 'virTypedParamsValidateTemplate'

Make the block io tuning params introspectable.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
4 weeks agoqemu: migration: Use 'virTypedParamsValidateTemplate' for migration params
Peter Krempa [Fri, 24 Apr 2026 12:53:13 +0000 (14:53 +0200)] 
qemu: migration: Use 'virTypedParamsValidateTemplate' for migration params

Refactor the code to use the new helper for validating migration params
and making them later available for introspection.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
4 weeks agoutil: typedparam: Introduce 'virTypedParamsValidateTemplate'
Peter Krempa [Wed, 22 Apr 2026 08:11:31 +0000 (10:11 +0200)] 
util: typedparam: Introduce 'virTypedParamsValidateTemplate'

While 'virTypedParamsValidate', which uses varargs to pass the template
to validate parameters against, is convenient for single uses we have
multiple occasions where we want to validate the same list of parameters
in muliple places. We use either a macro which expands to the parameter
list in place or a function which encapsulates the validation.

For introspection of input typed parameters we'll need to have the list
of supported typed parameters in each function which uses them as input
and either of the approaches is inconvenient for generating the
introspection parts.

Refactor 'virTypedParamsValidate', to split the actual validation
internals into ''virTypedParamsValidateInternal' and create two
wrappers:
 - 'virTypedParamsValidate' which uses varargs
 - 'virTypedParamsValidateTemplate' which uses an array of structs
    containing the template.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
4 weeks agoqemuDomainGetMetadata: Add top-level flag validation
Peter Krempa [Thu, 2 Apr 2026 14:46:46 +0000 (16:46 +0200)] 
qemuDomainGetMetadata: Add top-level flag validation

The implementation uses 'virDomainObjGetMetadata'
internally. To have a top level flag validation for the upcoming flag
introspection export the supported flags as a macro and add a
'virCheckFlags'.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
4 weeks agoqemuConnectDomainQemuMonitorEventRegister: Add top-level flag validation
Peter Krempa [Thu, 2 Apr 2026 14:46:46 +0000 (16:46 +0200)] 
qemuConnectDomainQemuMonitorEventRegister: Add top-level flag validation

The implementation uses 'virDomainQemuMonitorEventStateRegisterID'
internally. To have a top level flag validation for the upcoming flag
introspection export the supported flags as a macro and add a
'virCheckFlags'.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
4 weeks agoqemuDomainQemuMonitorCommand: Add top-level flag validation
Peter Krempa [Thu, 2 Apr 2026 14:46:46 +0000 (16:46 +0200)] 
qemuDomainQemuMonitorCommand: Add top-level flag validation

The implementation uses 'qemuDomainQemuMonitorCommandWithFiles'
internally. To have a top level flag validation for the upcoming flag
introspection export the supported flags as a macro and add a
'virCheckFlags'.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
4 weeks agoqemuDomainManagedSaveDefineXML: Add top-level flag validation
Peter Krempa [Thu, 2 Apr 2026 14:46:46 +0000 (16:46 +0200)] 
qemuDomainManagedSaveDefineXML: Add top-level flag validation

The implementation for managed save uses 'qemuDomainSaveImageDefineXML'
internally which validates the flags. To have a top level flag
validation for the upcoming flag introspection export the supported
flags as a macro and add a 'virCheckFlags' to
'qemuDomainManagedSaveDefineXML'.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
4 weeks agoqemuDomainDetachDeviceAlias: Move 'flags' validation to top level
Peter Krempa [Thu, 2 Apr 2026 14:28:23 +0000 (16:28 +0200)] 
qemuDomainDetachDeviceAlias: Move 'flags' validation to top level

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
4 weeks agoqemuDomainGetLaunchSecurityInfo: Move flag check to top level
Peter Krempa [Thu, 2 Apr 2026 14:27:13 +0000 (16:27 +0200)] 
qemuDomainGetLaunchSecurityInfo: Move flag check to top level

The flag check inside 'qemuDomainGetSEVInfo' makes no sense because it
only validates the 'VIR_TYPED_PARAM_STRING_OKAY' which is not actually
used.

Remove the 'flags parameter from 'qemuDomainGetSEVInfo' and validate
flags at 'qemuDomainGetLaunchSecurityInfo'

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
4 weeks agoqemu: snapshot: Move flag checks to top level functions
Peter Krempa [Thu, 2 Apr 2026 14:20:57 +0000 (16:20 +0200)] 
qemu: snapshot: Move flag checks to top level functions

Move the 'virCheckFlags' invocations to the top level driver function so
that they become available for introspection.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
4 weeks agoqemuDomainRestore(Flags|Params): Refactor flag checking
Peter Krempa [Thu, 2 Apr 2026 14:19:21 +0000 (16:19 +0200)] 
qemuDomainRestore(Flags|Params): Refactor flag checking

Create QEMU_DOMAIN_RESTORE_FLAGS define which collects all the flags
used by either of the implementations of the 'Restore' API and move the
flag checking into the implementation function so that it's available
later for introspection.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
4 weeks agoqemu: checkpoint: Move 'virCheckFlags' to top level functions
Peter Krempa [Thu, 2 Apr 2026 13:41:24 +0000 (15:41 +0200)] 
qemu: checkpoint: Move 'virCheckFlags' to top level functions

Move the flag check to the top level to allow programatic introspection
of supported flags.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
4 weeks agoqemu: dump: Move 'virCheckFlags' to top level functions
Peter Krempa [Thu, 2 Apr 2026 13:41:24 +0000 (15:41 +0200)] 
qemu: dump: Move 'virCheckFlags' to top level functions

Move the flag check to the top level to allow programatic introspection
of supported flags.

Extract the supported flags as a macro so that they can be reused in
both coredump APIs.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
4 weeks agoqemu: attach/detach device: Move 'virCheckFlags' to top level functions
Peter Krempa [Thu, 2 Apr 2026 13:41:24 +0000 (15:41 +0200)] 
qemu: attach/detach device: Move 'virCheckFlags' to top level functions

Move the flag check to the top level to allow programatic introspection
of supported flags.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
4 weeks agoqemu: backup: Move 'virCheckFlags' to top level functions
Peter Krempa [Thu, 2 Apr 2026 13:41:24 +0000 (15:41 +0200)] 
qemu: backup: Move 'virCheckFlags' to top level functions

Move the flag check to the top level to allow programatic introspection
of supported flags.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
4 weeks agovirNodeSuspend: Remove unused 'flags'
Peter Krempa [Thu, 2 Apr 2026 14:45:06 +0000 (16:45 +0200)] 
virNodeSuspend: Remove unused 'flags'

Remove the unused argument and bump the 'virCheckFlags' calls to the top
level.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
4 weeks agovirHostMemGet(Stats|Parameters): Remove unused 'flags'
Peter Krempa [Thu, 2 Apr 2026 14:44:25 +0000 (16:44 +0200)] 
virHostMemGet(Stats|Parameters): Remove unused 'flags'

The utility functions which get memory stats don't actually use the
flags. Remove the argument and move the 'virCheckFlags' to driver
implementation.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
4 weeks agovirHostCPUGet(Map|Stats): Remove unused 'flags'
Peter Krempa [Thu, 2 Apr 2026 14:44:25 +0000 (16:44 +0200)] 
virHostCPUGet(Map|Stats): Remove unused 'flags'

The utility functions which get CPU map and stats don't actually use the
flags. Remove the argument and move the 'virCheckFlags' to driver
implementation.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
4 weeks agoscripts: check-symfile: Allow also symbols in 'readonly' section
Peter Krempa [Mon, 27 Apr 2026 10:05:06 +0000 (12:05 +0200)] 
scripts: check-symfile: Allow also symbols in 'readonly' section

Validate also variables exported as 'extern' e.g. from the util
submodule.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
4 weeks agoutil: typedparam: Refactor and fix typed param validation
Peter Krempa [Wed, 22 Apr 2026 12:48:46 +0000 (14:48 +0200)] 
util: typedparam: Refactor and fix typed param validation

'virTypedParamsValidate' has special logic to handle the internal
VIR_TYPED_PARAM_UNSIGNED type, but unfortunately the implementation of
the error which is reported is flawed as it only updated the
'expecttype' string when the type actually matched. In cases when it
didn't we'd report the following error:

  error: invalid argument: invalid type 'string' for parameter 'poll_shrink', expected '(null)'

To fix it we can re-implement the validation part by using
virTypedParamValidateType simply by adding the VIR_TYPED_PARAM_UNSIGNED
to 'virTypedParameterTypeToString' handling which is now private and
adding logic to allow either one of the unsigned types, which allows us
to use the same function in both cases, simplifying the code.

Fixes: 07652410a7af98ca03281c4bfe20415ced26a44a
Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
4 weeks agoutil: typedparam: Unexport virTypedParameterTypeFromString/virTypedParameterTypeToString
Peter Krempa [Wed, 22 Apr 2026 12:39:27 +0000 (14:39 +0200)] 
util: typedparam: Unexport virTypedParameterTypeFromString/virTypedParameterTypeToString

The enum handler implementation has already some special values,
upcoming patches will add more so keep the only internal to avoid
surprises.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
4 weeks agoutil: Replace open-coded internals of VIR_TYPED_PARAMS_DEBUG with 'virTypedParamDebugstr'
Peter Krempa [Wed, 22 Apr 2026 12:36:22 +0000 (14:36 +0200)] 
util: Replace open-coded internals of VIR_TYPED_PARAMS_DEBUG with 'virTypedParamDebugstr'

Replace the internals of the macro by a function so that
'virTypedParameterToString' doesn't need to be exported as it also
adds mappings for values which don't exist in the public API.

This change also prevents a NULL to be passed to string formatters in
case when the caller sends an unknown typed parameter type as we now
also make sure that the type is in range.

Fixes: 54dd75fd97339dd49a54554e9327e5680c72132b
Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
4 weeks agoutil: virTypedParamValidateType: Don't report unknown typed parameter type as '(null)'
Peter Krempa [Wed, 22 Apr 2026 09:58:07 +0000 (11:58 +0200)] 
util: virTypedParamValidateType: Don't report unknown typed parameter type as '(null)'

If the actual type of the typed parameter is an invalid number the type
checker would still attempt to convert it to a string resulting in an
attempt to print a NULL string. libc saves us from the crash but the
error message is still wrong. Fix it.

Fixes: 54dd75fd97339dd49a54554e9327e5680c72132b
Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
4 weeks agoutil: typedparam: Convert VIR_TYPED_PARAM_CHECK_TYPE into a function
Peter Krempa [Wed, 22 Apr 2026 09:54:35 +0000 (11:54 +0200)] 
util: typedparam: Convert VIR_TYPED_PARAM_CHECK_TYPE into a function

Create 'virTypedParamValidateType' which will use the same logic
encapsulated in a function. Use the error message wording from
'virTypedParamsValidate' as it contains less fluff.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
4 weeks agoqemu: driver: Unify coding style
Peter Krempa [Thu, 2 Apr 2026 13:22:41 +0000 (15:22 +0200)] 
qemu: driver: Unify coding style

Reformat qemu_driver.c to use the contemporary coding style. It will
help also for the upcoming script for generating list of supported flags
for APIs.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
4 weeks agoremote_protocol-structs: fix mis-aligned 'remote_domain_set_throttle_group_args'
Peter Krempa [Mon, 20 Apr 2026 08:13:05 +0000 (10:13 +0200)] 
remote_protocol-structs: fix mis-aligned 'remote_domain_set_throttle_group_args'

Fixes: a10b3ffebb6c498b357fd546c737d152cdf3e77d
Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
4 weeks agovirStorageSource: note that capacity/allocation/physical are stale caches
Denis V. Lunev [Mon, 11 May 2026 21:55:24 +0000 (23:55 +0200)] 
virStorageSource: note that capacity/allocation/physical are stale caches

These three fields are cached values that do not reflect reality unless
the caller refreshes them. 'allocation' is in addition ultra-unreliable:
any guest write into a previously unallocated part of a sparse image
invalidates it, even right after a refresh.

Document this on the struct so new callers do not trust the values.

Signed-off-by: Denis V. Lunev <den@openvz.org>
Reviewed-by: Peter Krempa <pkrempa@redhat.com>
4 weeks agoAPI/qemu: add async unplug flag to virDomainSetVcpu
Akash Kulhalli via Devel [Wed, 29 Apr 2026 12:13:29 +0000 (17:43 +0530)] 
API/qemu: add async unplug flag to virDomainSetVcpu

Add VIR_DOMAIN_SETVCPU_ASYNC_UNPLUG for virDomainSetVcpu().

Define a dedicated virDomainSetVcpuBehaviour flag type and wire the
new flag through the QEMU driver. As with setvcpus async unplug,
success indicates request acceptance while final completion is
reported by the vcpu-removed event.

Update the API documentation and add virsh support for the async path to
the setvcpu subcommand.

Signed-off-by: Akash Kulhalli <akash.kulhalli@oracle.com>
Reviewed-by: Peter Krempa <pkrempa@redhat.com>
4 weeks agoAPI/qemu: add async unplug flag to virDomainSetVcpusFlags
Akash Kulhalli via Devel [Wed, 29 Apr 2026 12:13:28 +0000 (17:43 +0530)] 
API/qemu: add async unplug flag to virDomainSetVcpusFlags

Add VIR_DOMAIN_VCPU_ASYNC_UNPLUG for virDomainSetVcpusFlags().

With this flag, success indicates that QEMU accepted the unplug
request, while final completion is reported by the vcpu-removed
event. Rejected requests continue to be reported by the
device-removal-failed event.

Wire the flag through the QEMU driver, document its semantics, and
add virsh support for the async path in the setvcpus subcommand.

Signed-off-by: Akash Kulhalli <akash.kulhalli@oracle.com>
Reviewed-by: Peter Krempa <pkrempa@redhat.com>
4 weeks agoqemu: thread async vcpu unplug through internal helpers
Akash Kulhalli via Devel [Wed, 29 Apr 2026 12:13:27 +0000 (17:43 +0530)] 
qemu: thread async vcpu unplug through internal helpers

Thread an async_unplug flag through the internal QEMU vCPU unplug
helpers.

When set, the unplug path returns after QEMU accepts the device
deletion request and leaves final completion to the existing
DEVICE_DELETED handling routines.

All callers still pass false, so this does not change behaviour yet.

Signed-off-by: Akash Kulhalli <akash.kulhalli@oracle.com>
Reviewed-by: Peter Krempa <pkrempa@redhat.com>
4 weeks agoqemu: emit vcpu-removed event on unplug completion
Akash Kulhalli via Devel [Wed, 29 Apr 2026 12:13:26 +0000 (17:43 +0530)] 
qemu: emit vcpu-removed event on unplug completion

Emit the vcpu-removed event when QEMU vCPU unplug completes.

Hook this into qemuDomainRemoveVcpu(), which covers both the
synchronous completion path and the DEVICE_DELETED-driven alias
removal path.

Some architectures may have multiple vcpus grouped under a single qemu
vcpu object; on those platforms a `vcpu-removed` event will be emitted
for each vcpu that is removed from this group.

Signed-off-by: Akash Kulhalli <akash.kulhalli@oracle.com>
Reviewed-by: Peter Krempa <pkrempa@redhat.com>
4 weeks agoconf,remote: add vcpu-removed domain event
Akash Kulhalli via Devel [Wed, 29 Apr 2026 12:13:25 +0000 (17:43 +0530)] 
conf,remote: add vcpu-removed domain event

Add a new domain event for completed vCPU removal.

Wire the event through the internal event framework and extend the
remote protocol so remote clients can receive it. Update virsh and
the event-test example accordingly.

The event is not emitted anywhere yet.

Signed-off-by: Akash Kulhalli <akash.kulhalli@oracle.com>
Reviewed-by: Peter Krempa <pkrempa@redhat.com>