]> git.ipfire.org Git - thirdparty/libvirt.git/log
thirdparty/libvirt.git
2 years agomeson: remove obsolete check for ETH_FLAG_RXHASH
Daniel P. Berrangé [Thu, 8 Dec 2022 09:45:20 +0000 (09:45 +0000)] 
meson: remove obsolete check for ETH_FLAG_RXHASH

The ETH_FLAG_RXHASH constant was introduced to Linux in

  commit b00fabb4020d17bda4bea59507e09fadf573088d
  Author: stephen hemminger <shemminger@vyatta.com>
  Date:   Mon Mar 29 14:47:27 2010 +0000

    netdev: ethtool RXHASH flag

This is old enough that all our supported platforms can be assumed
to have this feature.

Reviewed-by: Ján Tomko <jtomko@redhat.com>
Signed-off-by: Daniel P. Berrangé <berrange@redhat.com>
2 years agomeson: remove obsolete check for ETH_FLAG_NTUPLE
Daniel P. Berrangé [Thu, 8 Dec 2022 09:45:20 +0000 (09:45 +0000)] 
meson: remove obsolete check for ETH_FLAG_NTUPLE

The ETH_FLAG_NTUPLE constant was introduced to Linux in

  commit 15682bc488d4af8c9bb998844a94281025e0a333
  Author: Peter P Waskiewicz Jr <peter.p.waskiewicz.jr@intel.com>
  Date:   Wed Feb 10 20:03:05 2010 -0800

    ethtool: Introduce n-tuple filter programming support

This is old enough that all our supported platforms can be assumed
to have this feature.

A typo in the existing condition "NTUBLE" instead of "NTUPLE" meant the
code was never enabled in the first place, which is an illustration of
why it is worth eliminating redundant conditional checks.

Reviewed-by: Ján Tomko <jtomko@redhat.com>
Signed-off-by: Daniel P. Berrangé <berrange@redhat.com>
2 years agomeson: remove obsolete check for ETH_FLAG_TXVLAN/RXVLAN
Daniel P. Berrangé [Thu, 8 Dec 2022 09:45:20 +0000 (09:45 +0000)] 
meson: remove obsolete check for ETH_FLAG_TXVLAN/RXVLAN

The ETH_FLAG_TXVLAN/RXVLAN constants were introduced to Linux in

  commit d5dbda23804156ae6f35025ade5307a49d1db6d7
  Author: Jesse Gross <jesse@nicira.com>
  Date:   Wed Oct 20 13:56:07 2010 +0000

    ethtool: Add support for vlan accleration.

This is old enough that all our supported platforms can be assumed
to have this feature.

Reviewed-by: Ján Tomko <jtomko@redhat.com>
Signed-off-by: Daniel P. Berrangé <berrange@redhat.com>
2 years agomeson: remove obsolete check for ETH_FLAG_LRO
Daniel P. Berrangé [Thu, 8 Dec 2022 09:45:20 +0000 (09:45 +0000)] 
meson: remove obsolete check for ETH_FLAG_LRO

The ETH_FLAG_LRO constant was introduced to Linux in

  commit 3ae7c0b2e3747b50c3a6c63ebb67469e0a6b3203
  Author: Jeff Garzik <jeff@garzik.org>
  Date:   Wed Aug 15 16:00:51 2007 -0700

    [ETHTOOL]: Add ETHTOOL_[GS]FLAGS sub-ioctls

This is old enough that all our supported platforms can be assumed
to have this feature.

Reviewed-by: Ján Tomko <jtomko@redhat.com>
Signed-off-by: Daniel P. Berrangé <berrange@redhat.com>
2 years agomeson: remove obsolete check for ETHTOOL_GFLAGS
Daniel P. Berrangé [Thu, 8 Dec 2022 09:45:20 +0000 (09:45 +0000)] 
meson: remove obsolete check for ETHTOOL_GFLAGS

The ETHTOOL_GFLAGS constant was introduced to Linux in

  commit 3ae7c0b2e3747b50c3a6c63ebb67469e0a6b3203
  Author: Jeff Garzik <jeff@garzik.org>
  Date:   Wed Aug 15 16:00:51 2007 -0700

    [ETHTOOL]: Add ETHTOOL_[GS]FLAGS sub-ioctls

This is old enough that all our supported platforms can be assumed
to have this feature.

Reviewed-by: Ján Tomko <jtomko@redhat.com>
Signed-off-by: Daniel P. Berrangé <berrange@redhat.com>
2 years agomeson: remove obsolete check for ETHTOOL_GGRO
Daniel P. Berrangé [Thu, 8 Dec 2022 09:45:20 +0000 (09:45 +0000)] 
meson: remove obsolete check for ETHTOOL_GGRO

The ETHTOOL_GGRO constant was introduced to Linux in

  commit b240a0e5644eb817c4a397098a40e1ad42a615bc
  Author: Herbert Xu <herbert@gondor.apana.org.au>
  Date:   Mon Dec 15 23:44:31 2008 -0800

    ethtool: Add GGRO and SGRO ops

This is old enough that all our supported platforms can be assumed
to have this feature.

Reviewed-by: Ján Tomko <jtomko@redhat.com>
Signed-off-by: Daniel P. Berrangé <berrange@redhat.com>
2 years agomeson: remove obsolete check for ETHTOOL_GGSO
Daniel P. Berrangé [Thu, 8 Dec 2022 09:45:20 +0000 (09:45 +0000)] 
meson: remove obsolete check for ETHTOOL_GGSO

The ETHTOOL_GGSO constant was introduced to Linux in

  commit 37c3185a02d4b85fbe134bf5204535405dd2c957
  Author: Herbert Xu <herbert@gondor.apana.org.au>
  Date:   Thu Jun 22 03:07:29 2006 -0700

    [NET]: Added GSO toggle

This is old enough that all our supported platforms can be assumed
to have this feature.

Reviewed-by: Ján Tomko <jtomko@redhat.com>
Signed-off-by: Daniel P. Berrangé <berrange@redhat.com>
2 years agonetdev: simplify check for ethtool functionality
Daniel P. Berrangé [Thu, 8 Dec 2022 09:42:09 +0000 (09:42 +0000)] 
netdev: simplify check for ethtool functionality

ethtool is a Linux specific feature that has existed since before Linux
moved to git. Checking against SIOCETHTOOL + WITH_STRUCT_IFREQ is
overkill for our needs.

Reviewed-by: Ján Tomko <jtomko@redhat.com>
Signed-off-by: Daniel P. Berrangé <berrange@redhat.com>
2 years agomeson: drop check for unshare()
Daniel P. Berrangé [Thu, 8 Dec 2022 09:17:37 +0000 (09:17 +0000)] 
meson: drop check for unshare()

The unshare() syscall was introduced to Linux in

  commit 2da436e00f9a5fdd0fb6b31e4b2b2ba82e8f5ab8
  Author: JANAK DESAI <janak@us.ibm.com>
  Date:   Tue Feb 7 12:59:03 2006 -0800

    [PATCH] unshare system call -v5: system call registration for i386

This is old enough that all our supported platforms can be assumed
to have this feature. Furthermore, the virprocess.c file was already
using unshare() with nothing more than a #ifdef __linux__ check.

Reviewed-by: Ján Tomko <jtomko@redhat.com>
Signed-off-by: Daniel P. Berrangé <berrange@redhat.com>
2 years agomeson: remove obsolete check for LO_FLAGS_AUTOCLEAR
Daniel P. Berrangé [Thu, 8 Dec 2022 09:12:25 +0000 (09:12 +0000)] 
meson: remove obsolete check for LO_FLAGS_AUTOCLEAR

The LO_FLAGS_AUTOCLEAR constant was introduced to Linux in

  commit 96c5865559cee0f9cbc5173f3c949f6ce3525581
  Author: David Woodhouse <dwmw2@infradead.org>
  Date:   Wed Feb 6 01:36:27 2008 -0800

    Allow auto-destruction of loop devices

This is old enough that all our supported platforms can be assumed
to have this feature. For added fun this whole meson check was
semantically insane because EPOLL_CLOEXEC is not a valid arg
to unshare().

Reviewed-by: Ján Tomko <jtomko@redhat.com>
Signed-off-by: Daniel P. Berrangé <berrange@redhat.com>
2 years agomeson: remove obsolete check for EPOLL_CLOEXEC
Daniel P. Berrangé [Thu, 8 Dec 2022 09:12:25 +0000 (09:12 +0000)] 
meson: remove obsolete check for EPOLL_CLOEXEC

The EPOLL_CLOEXEC constant was introduced to Linux in

  commit a0998b50c3f0b8fdd265c63e0032f86ebe377dbf
  Author: Ulrich Drepper <drepper@redhat.com>
  Date:   Wed Jul 23 21:29:27 2008 -0700

    flag parameters: epoll_create

This is old enough that all our supported platforms can be assumed
to have this feature. For added fun this whole meson check was
semantically insane because EPOLL_CLOEXEC is not a valid arg
to unshare().

Reviewed-by: Ján Tomko <jtomko@redhat.com>
Signed-off-by: Daniel P. Berrangé <berrange@redhat.com>
2 years agomeson: remove obsolete check for LOOP_CTL_GET_FREE
Daniel P. Berrangé [Thu, 8 Dec 2022 09:03:23 +0000 (09:03 +0000)] 
meson: remove obsolete check for LOOP_CTL_GET_FREE

The LOOP_CTL_GET_FREE constant was introduced to Linux in

  commit 770fe30a46a12b6fb6b63fbe1737654d28e84844
  Author: Kay Sievers <kay.sievers@vrfy.org>
  Date:   Sun Jul 31 22:08:04 2011 +0200

    loop: add management interface for on-demand device allocation

This is old enough that all our supported platforms can be assumed
to have this feature. As a plus point, this meson check is going
to start failing with future GCC. It fails to set _GNU_SOURCE, thus
'unshare' is not defined by the header, and its relying on an
implicit function decl. For added fun this whole meson check was
semantically insane because LOOP_CTL_GET_FREE is not a valid arg
to unshare().

Fixes https://fedoraproject.org/wiki/Toolchain/PortingToModernC
Reviewed-by: Ján Tomko <jtomko@redhat.com>
Signed-off-by: Daniel P. Berrangé <berrange@redhat.com>
2 years agodocs: Add missing elements to formatcaps.rst
Nobuhiro MIKI [Fri, 9 Dec 2022 05:36:26 +0000 (14:36 +0900)] 
docs: Add missing elements to formatcaps.rst

Signed-off-by: Nobuhiro MIKI <nmiki@yahoo-corp.jp>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
2 years agovirnetdevtap.c: Disallow pre-existing TAP devices
Michal Privoznik [Thu, 8 Dec 2022 14:35:36 +0000 (15:35 +0100)] 
virnetdevtap.c: Disallow pre-existing TAP devices

When starting a guest with <interface/> which has the target
device name set (i.e. not generated by us), it may happen that
the TAP device already exists. This then may lead to all sorts of
problems. For instance: for <interface type='network'/> the TAP
device is plugged into the network's bridge, but since the TAP
device is persistent it remains plugged there even after the
guest is shut off. We don't have a code that unplugs TAP devices
from the bridge because TAP devices we create are transient, i.e.
are removed automatically when QEMU closes their FD.

The only exception is <interface type='ethernet'/> with <target
managed='no'/> where we specifically want to let users use
pre-created TAP device and basically not touch it at all.

There's another reason for denying to use a pre-created TAP
devices: if we ever have bug in TAP name generation, we may
re-use a TAP device from another domain.

Resolves: https://bugzilla.redhat.com/show_bug.cgi?id=2144738
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Laine Stump <laine@redhat.com>
2 years agovirnetdev: Make virNetDevGenerateName() return 1 if no name was generated
Michal Privoznik [Thu, 8 Dec 2022 16:48:06 +0000 (17:48 +0100)] 
virnetdev: Make virNetDevGenerateName() return 1 if no name was generated

A caller might be interested in the case when @ifname was already
set and it wasn't a template. In such case the
virNetDevGenerateName() does not touch the @ifname at all and
returns 0 to indicate success. Make it return 1 to distinguish
this case from the other case, in which a new name was generated.

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Laine Stump <laine@redhat.com>
2 years agoFix a log content
liqiang [Mon, 28 Nov 2022 01:57:27 +0000 (09:57 +0800)] 
Fix a log content

Signed-off-by: liqiang <liqiang64@huawei.com>
2 years agotools: Fix style issues in virt-qemu-sev-validate
Andrea Bolognani [Thu, 8 Dec 2022 17:00:13 +0000 (18:00 +0100)] 
tools: Fix style issues in virt-qemu-sev-validate

The script had an incorrect interpreter line until commit
f6a19d7264bb, so the flake8 check would not realize it needed
to pick it up and these issues, some of which were present it
the very first version that was committed, were not being
reported.

Signed-off-by: Andrea Bolognani <abologna@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agotools: Fix interpreter for virt-qemu-sev-validate
Andrea Bolognani [Thu, 8 Dec 2022 15:57:23 +0000 (16:57 +0100)] 
tools: Fix interpreter for virt-qemu-sev-validate

Go through env(1) instead of hardcoding the path to the Python
interpreter, as we already do for all other Python scripts.

Signed-off-by: Andrea Bolognani <abologna@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agodocs: Fix typo in virt-qemu-sev-validate(1)
Andrea Bolognani [Thu, 8 Dec 2022 15:55:32 +0000 (16:55 +0100)] 
docs: Fix typo in virt-qemu-sev-validate(1)

Spotted by Lintian (typo-in-manual-page tag).

Signed-off-by: Andrea Bolognani <abologna@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agotools: Fix install_mode for some scripts
Michal Privoznik [Thu, 8 Dec 2022 07:39:24 +0000 (08:39 +0100)] 
tools: Fix install_mode for some scripts

Scripts from the following list were installed with group write
bit set: virt-xml-validate, virt-pki-validate,
virt-sanlock-cleanup, libvirt-guests.sh. This is very unusual and
in contrast with the way other scripts/binaries are installed.

Resolves: https://bugzilla.redhat.com/show_bug.cgi?id=2151202
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Jiri Denemark <jdenemar@redhat.com>
2 years agovirsh: Add message to terminal when running snapshot-revert
Haruka Ohata [Wed, 30 Nov 2022 08:04:07 +0000 (17:04 +0900)] 
virsh: Add message to terminal when running snapshot-revert

When running virsh snapshot-* command, such as snapshot-create-as /
snapshot-delete, it prints a result message.
On the other hand virsh snapshot-revert command doesn't print a result
message.

So, This patch fixes to add message when running virsh snapshot-revert
command.

    # virsh snapshot-create-as vm1 test1
    Domain snapshot test01 created
    # virsh snapshot-revert vm1 test1

    # virsh snapshot-delete vm1 test1
    Domain snapshot test01 deleted

Signed-off-by: Haruka Ohata <ohata.haruka@fujitsu.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
Signed-off-by: Ján Tomko <jtomko@redhat.com>
2 years agoNEWS: Document change of screenshot format for QEMU
Michal Privoznik [Wed, 7 Dec 2022 11:18:49 +0000 (12:18 +0100)] 
NEWS: Document change of screenshot format for QEMU

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Martin Kletzander <mkletzan@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agoqemu: Prefer PNG for domain screenshots
Michal Privoznik [Wed, 7 Dec 2022 11:04:41 +0000 (12:04 +0100)] 
qemu: Prefer PNG for domain screenshots

Historically, QEMU took screenshots in PPM. While this might use
to be popular format, as of v7.1.0-rc0~125^2~6 it is possible to
take screenshots in PNG. This is more popular and renders almost
everywhere, which is not the case for PPM (for instance, modern
browsers do not render it).

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Martin Kletzander <mkletzan@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agoqemu_monitor: Extend qemuMonitorScreendump() for @format
Michal Privoznik [Wed, 7 Dec 2022 09:50:04 +0000 (10:50 +0100)] 
qemu_monitor: Extend qemuMonitorScreendump() for @format

The 'screendump' command has new argument 'format'. Let's expose
this on our QMP level so that callers can specify the format, if
they wish so.

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Martin Kletzander <mkletzan@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agoqemu_monitor: Debug print all arguments in qemuMonitorScreendump()
Michal Privoznik [Wed, 7 Dec 2022 09:47:20 +0000 (10:47 +0100)] 
qemu_monitor: Debug print all arguments in qemuMonitorScreendump()

For some reason, only @file argument is printed into debug logs.
The rest of arguments was left out. Include all arguments.

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Martin Kletzander <mkletzan@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agoqemu_caps: Introduce QEMU_CAPS_SCREENSHOT_FORMAT_PNG
Michal Privoznik [Wed, 7 Dec 2022 09:45:42 +0000 (10:45 +0100)] 
qemu_caps: Introduce QEMU_CAPS_SCREENSHOT_FORMAT_PNG

In its v7.1.0-rc0~125^2~6 commit, QEMU gained support for taking
screenshots in PNG format. Track this capability.

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Martin Kletzander <mkletzan@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agospec: Remove extra blank lines
Jim Fehlig [Fri, 2 Dec 2022 22:50:05 +0000 (15:50 -0700)] 
spec: Remove extra blank lines

The spec file contains inconsistent use of blank lines. While trying to
make significant changes to the file, I found it hurts both readability
and maintainability. Remove blank lines that interrupt the overall flow
and consistency.

Signed-off-by: Jim Fehlig <jfehlig@suse.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
2 years agoexamples: Install amd-sev-es-vmsa.stp
Andrea Bolognani [Mon, 5 Dec 2022 23:12:32 +0000 (00:12 +0100)] 
examples: Install amd-sev-es-vmsa.stp

Fixes: d154b49a7e813245ff2ef1061c89edff9db0e119
Signed-off-by: Andrea Bolognani <abologna@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agoexamples: Sort list
Andrea Bolognani [Mon, 5 Dec 2022 23:11:33 +0000 (00:11 +0100)] 
examples: Sort list

Signed-off-by: Andrea Bolognani <abologna@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agoqemu: refresh state after reboot initiated from the guest
Kristina Hanicova [Tue, 6 Dec 2022 13:58:19 +0000 (14:58 +0100)] 
qemu: refresh state after reboot initiated from the guest

Internal domain state needs to be refreshed after reset from the guest
side because it may be inconsistent with the internal qemu state.

Signed-off-by: Kristina Hanicova <khanicov@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
Signed-off-by: Ján Tomko <jtomko@redhat.com>
2 years agoqemu: refresh internal domain state after reset
Kristina Hanicova [Tue, 6 Dec 2022 13:58:18 +0000 (14:58 +0100)] 
qemu: refresh internal domain state after reset

Internal domain state may change during the reset and qemu does
not always send events about it.  In case it happens, internal
state of the domain in libvirt would be inconsistent with the
internal state in qemu which could cause additional problems
(e.g. cdrom tray state can change from open to closed).  The
solution is to refresh state after a successful reset to query
qemu about the current internal domain state.

Resolves: https://bugzilla.redhat.com/show_bug.cgi?id=1824722

Signed-off-by: Kristina Hanicova <khanicov@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
Signed-off-by: Ján Tomko <jtomko@redhat.com>
2 years agoqemu: Init ext devices paths on reconnect
Michal Privoznik [Mon, 5 Dec 2022 12:08:39 +0000 (13:08 +0100)] 
qemu: Init ext devices paths on reconnect

Paths for external devices (well, so far only vTPM) are not
stored in the status XML. Therefore, we need to regenerate them
after we've been restarted and reconnecting to a running domain.
Otherwise these will remain NULL which may later lead to a NULL
dereference.

Resolves: https://bugzilla.redhat.com/show_bug.cgi?id=2150760
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agoqemu_extdevice: Expose qemuExtDevicesInitPaths()
Michal Privoznik [Mon, 5 Dec 2022 12:08:25 +0000 (13:08 +0100)] 
qemu_extdevice: Expose qemuExtDevicesInitPaths()

This function is going to be called outside of qemu_extdevice.c.
Expose it to the rest of the driver.

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agoqemu_extdevice: Init paths in qemuExtDevicesPrepareDomain()
Michal Privoznik [Mon, 5 Dec 2022 11:27:24 +0000 (12:27 +0100)] 
qemu_extdevice: Init paths in qemuExtDevicesPrepareDomain()

The path generation phase belongs conceptually into domain
preparation phase and not host preparation. Move
qemuExtDevicesInitPaths() call from qemuExtDevicesPrepareHost()
into qemuExtDevicesPrepareDomain().

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agoqemu_process: Document qemuProcessPrepare{Domain,Host}() order
Michal Privoznik [Mon, 5 Dec 2022 11:18:50 +0000 (12:18 +0100)] 
qemu_process: Document qemuProcessPrepare{Domain,Host}() order

The domain startup process is split into multiple phases. One of
them is preparing the domain (at that point live) XML, private
data, various paths, etc - see qemuProcessPrepareDomain(); the
other prepares the host - see qemuProcessPrepareHost(). It's
obvious that the domain XML preparation function must be called
before the host preparation function (e.g. the host preparation
might try to create a file which path is generated in the domain
preparation phase). Nevertheless, let's document this
expectation.

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agoconf: domain: Remove virDomainDeviceDefCopy
Peter Krempa [Tue, 22 Nov 2022 19:54:45 +0000 (20:54 +0100)] 
conf: domain: Remove virDomainDeviceDefCopy

The function is now unused. Remove it to dissuade anybody from trying to
use it in the future.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agolxcDomainDetachDeviceFlags: Parse XML twice rather than use virDomainDeviceDefCopy
Peter Krempa [Tue, 22 Nov 2022 16:01:31 +0000 (17:01 +0100)] 
lxcDomainDetachDeviceFlags: Parse XML twice rather than use virDomainDeviceDefCopy

'virDomainDeviceDefCopy' formats the definition and parses it back.
Since we already are parsing the XML here, we're better off parsing it
twice and save the formatting step.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agolxcDomainAttachDeviceFlags: Parse XML twice rather than use virDomainDeviceDefCopy
Peter Krempa [Tue, 22 Nov 2022 16:01:31 +0000 (17:01 +0100)] 
lxcDomainAttachDeviceFlags: Parse XML twice rather than use virDomainDeviceDefCopy

'virDomainDeviceDefCopy' formats the definition and parses it back.
Since we already are parsing the XML here, we're better off parsing it
twice and save the formatting step.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agoqemuDomainDetachDeviceLiveAndConfig: Refactor cleanup
Peter Krempa [Tue, 22 Nov 2022 16:07:58 +0000 (17:07 +0100)] 
qemuDomainDetachDeviceLiveAndConfig: Refactor cleanup

Remove the 'cleanup' label and 'ret' variable as we can now directly
return form all cases.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agoqemuDomainDetachDeviceLiveAndConfig: Parse XML twice rather than use virDomainDeviceD...
Peter Krempa [Tue, 22 Nov 2022 16:01:31 +0000 (17:01 +0100)] 
qemuDomainDetachDeviceLiveAndConfig: Parse XML twice rather than use virDomainDeviceDefCopy

'virDomainDeviceDefCopy' formats the definition and parses it back.
Since we already are parsing the XML here, we're better off parsing it
twice and save the formatting step.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agoqemuDomainUpdateDeviceFlags: Parse XML twice rather than use virDomainDeviceDefCopy
Peter Krempa [Tue, 22 Nov 2022 16:01:31 +0000 (17:01 +0100)] 
qemuDomainUpdateDeviceFlags: Parse XML twice rather than use virDomainDeviceDefCopy

'virDomainDeviceDefCopy' formats the definition and parses it back.
Since we already are parsing the XML here, we're better off parsing it
twice and save the formatting step.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agoqemu: driver: Fix formatting of function headers around qemuDomainAttachDevice
Peter Krempa [Tue, 22 Nov 2022 15:56:38 +0000 (16:56 +0100)] 
qemu: driver: Fix formatting of function headers around qemuDomainAttachDevice

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agodocs: drvqemu: Remove inaccuate limitations statement
Peter Krempa [Mon, 21 Nov 2022 12:47:52 +0000 (13:47 +0100)] 
docs: drvqemu: Remove inaccuate limitations statement

We don't refuse override definitions for device which doesn't exist and
the same way don't care about 'remove' being used on a property which is
not actually formatted by libvirt. Drop the paragraph claiming the
contrary.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agodocs: drvqemu: Give example how to query device properties for overriding
Peter Krempa [Mon, 21 Nov 2022 12:46:29 +0000 (13:46 +0100)] 
docs: drvqemu: Give example how to query device properties for overriding

Add an example of invoking qemu with '-device TYPE,?' to query
properties of a given type.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agodocs: drvqemu: Fix and improve docs about device override types
Peter Krempa [Mon, 21 Nov 2022 12:44:54 +0000 (13:44 +0100)] 
docs: drvqemu: Fix and improve docs about device override types

The 'number' override type didn't exist in the final version so change
it to the corresponding 'signed' and 'unsigned'.

Additionally clarify which override type is used for a corresponding
qemu type and also that we use base 10 numbers so users will need to
convert the numbers if needed.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agoqemu: Don't report spurious errors from vCPU tid validation on hotunplug timeout
Shaleen Bathla [Fri, 11 Nov 2022 09:24:38 +0000 (14:54 +0530)] 
qemu: Don't report spurious errors from vCPU tid validation on hotunplug timeout

Use of qemuDomainValidateVcpuInfo in the helpers for hotplug and unplug
of vCPUs can lead to spurious errors reported such as:

  internal error: qemu didn't report thread id for vcpu 'XX'"

The reason for this is that qemuDomainValidateVcpuInfo validates the
state of all vCPUs against the expected state of vCPUs. If an unplug
operation completed before libvirt was unable to process it yet the
expected state could not reflect the current state.

To avoid spurious errors the qemuDomainHotplugAddVcpu and
qemuDomainRemoveVcpu functions are modified to do localized validation
only for the vCPUs they actually modify.

We also now ensure that the cgroups are modified before bailing out on
error for any vCPUs which passed validation.

Additionally in order for qemuDomainRemoveVcpuAlias to be able to find
the unplugged vCPU we must ensure that qemuDomainRefreshVcpuInfo does
not clear out the alias in case when the vCPU is no longer reported by
qemu.

Co-authored-by: Partha Satapathy <partha.satapathy@oracle.com>
Signed-off-by: Shaleen Bathla <shaleen.bathla@oracle.com>
Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agoqemu_tpm: Set log file label on migration
Michal Privoznik [Fri, 2 Dec 2022 15:09:37 +0000 (16:09 +0100)] 
qemu_tpm: Set log file label on migration

Recently, the QEMU driver gained support for migration with TPM
state on a shared volume (e.g. NFS). As a part of that, the
destination side avoids setting seclabels on it to avoid cutting
off the source while it is still using it. Makes sense, except
for a wee bit: the secdriver API does a bit more - it also sets
label on the swtpm log file. And this one definitely needs to be
labeled (it lives under /var/log/swtpm/libvirt/qemu/..., i.e. not
on a shared volume).

Previously, qemuSecurityStartTPMEmulator() took care of that. But
during rework to shared volume migration, the code was changed so
now plain qemuSecurityCommandRun() would be run (i.e. no
relabelling).

But after previous commits, we can now chose whether the TPM
state should be relabelled or just the log file.

Fixes: 2e669ec789231d39e0d5f5f6a201d2a661b8070c
Resolves: https://bugzilla.redhat.com/show_bug.cgi?id=2130192#c7
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agoqemu_tpm: Extend start/stop APIs
Michal Privoznik [Fri, 2 Dec 2022 15:04:41 +0000 (16:04 +0100)] 
qemu_tpm: Extend start/stop APIs

This is basically just a continuation of the previous commit.
Now that the security driver APIs have a boolean flag that
controls setting/restoring seclabel of either both TPM state and
log files, or just the log file, propagate this boolean into
those APIs that start/stop swtpm emulator. For now, just pass
true. The juicy bits are soon to come.

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agosecurity: Extend TPM label APIs
Michal Privoznik [Fri, 2 Dec 2022 14:59:28 +0000 (15:59 +0100)] 
security: Extend TPM label APIs

The virSecurityDomainSetTPMLabels() and
virSecurityDomainRestoreTPMLabels() APIs set/restore label on two
files/directories:

  1) the TPM state (tpm->data.emulator.storagepath), and
  2) the TPM log file (tpm->data.emulator.logfile).

Soon there will be a need to set the label on the log file but
not on the state. Therefore, extend these APIs for a boolean flag
that when set does both, but when unset does only 2).

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agoTranslated using Weblate (Chinese (Simplified) (zh_CN))
Yang Yulin [Sat, 3 Dec 2022 13:19:57 +0000 (14:19 +0100)] 
Translated using Weblate (Chinese (Simplified) (zh_CN))

Currently translated at 99.2% (10294 of 10368 strings)

Translation: libvirt/libvirt
Translate-URL: https://translate.fedoraproject.org/projects/libvirt/libvirt/zh_CN/

Co-authored-by: Yang Yulin <yylteam@icloud.com>
Signed-off-by: Yang Yulin <yylteam@icloud.com>
2 years agovirshFindDisk: Sanitize use of 'tmp' variable
Peter Krempa [Wed, 19 Oct 2022 11:59:17 +0000 (13:59 +0200)] 
virshFindDisk: Sanitize use of 'tmp' variable

The return value of virXMLPropString was assigned into 'tmp' multiple
times and to prevent static analyzers moaning about a potential leak a
short-circuited if logic or was used.

Replace the code by having a helper variable for each possibility and
also replace the for-loop to iterate elements.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agoutil: xml: Introduce virXMLNodeGetSubelement
Peter Krempa [Fri, 2 Dec 2022 09:35:13 +0000 (10:35 +0100)] 
util: xml: Introduce virXMLNodeGetSubelement

Introduce a simple helper fetching a sub-element node by name. This is
meant as a simple replacement for either open-coded versions of this or
use of XPath for this trivial lookup.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agovirshFindDisk: Sanitize removable media check
Peter Krempa [Wed, 19 Oct 2022 11:31:00 +0000 (13:31 +0200)] 
virshFindDisk: Sanitize removable media check

The XPath lookup guarantees that the top level element is always 'disk'
so there's no need to check that it actually is. We can also remove the
two unnecessary temporary variables.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agovirshFindDisk: Use virXPathNodeSet instead of xmlXPathEval
Peter Krempa [Wed, 19 Oct 2022 11:21:23 +0000 (13:21 +0200)] 
virshFindDisk: Use virXPathNodeSet instead of xmlXPathEval

Don't open-code the XPath lookup.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agovirsh: cmdChangeMedia: Refactor cleanup
Peter Krempa [Fri, 2 Dec 2022 09:14:09 +0000 (10:14 +0100)] 
virsh: cmdChangeMedia: Refactor cleanup

Use automatic pointer freeing for the 'disk_node' variable and remove
the 'cleanup' label and 'ret' variable.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agovirsh: cmdDetachDisk: Refactor cleanup
Peter Krempa [Fri, 2 Dec 2022 09:14:09 +0000 (10:14 +0100)] 
virsh: cmdDetachDisk: Refactor cleanup

Use automatic pointer freeing for the 'disk_node' variable and remove
the 'cleanup' label and 'functionReturn' variable.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agovirsh: virshMakeCloneXML: Use virXPathNode instead of xmlXPathEval
Peter Krempa [Thu, 1 Dec 2022 08:39:30 +0000 (09:39 +0100)] 
virsh: virshMakeCloneXML: Use virXPathNode instead of xmlXPathEval

Refactor the code to use the XPath helpers instead of open-coding them.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agovirsh: Add --print-xml flag for 'vol-clone' command
Peter Krempa [Wed, 30 Nov 2022 15:48:23 +0000 (16:48 +0100)] 
virsh: Add --print-xml flag for 'vol-clone' command

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agovirsh: Refactor cleanup in 'cmdVolClone'
Peter Krempa [Wed, 30 Nov 2022 15:40:14 +0000 (16:40 +0100)] 
virsh: Refactor cleanup in 'cmdVolClone'

Automatically free 'newxml' and remove the 'cleanup' label and 'ret'
variable.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agovirsh: cmdDomIfSetLink: Use virXPathNodeSet instead of xmlXpathEval
Peter Krempa [Wed, 19 Oct 2022 08:39:33 +0000 (10:39 +0200)] 
virsh: cmdDomIfSetLink: Use virXPathNodeSet instead of xmlXpathEval

Refactor the XPath lookup to use the internal helper.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agovirsh: Add --print-xml option for 'domif-setlink'
Peter Krempa [Wed, 30 Nov 2022 15:04:03 +0000 (16:04 +0100)] 
virsh: Add --print-xml option for 'domif-setlink'

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agovirshDomainDetachInterface: Use virXPathNodeSet instead of xmlXpathEval
Peter Krempa [Tue, 18 Oct 2022 13:00:59 +0000 (15:00 +0200)] 
virshDomainDetachInterface: Use virXPathNodeSet instead of xmlXpathEval

Refactor the XPath lookup to use the internal helper.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agovirsh: Add --print-xml option for 'detach-interface'
Peter Krempa [Wed, 30 Nov 2022 09:49:26 +0000 (10:49 +0100)] 
virsh: Add --print-xml option for 'detach-interface'

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agoutil: json: Remove unused virJSONValueObjectGetStringArray wrapper
Peter Krempa [Thu, 1 Dec 2022 16:08:44 +0000 (17:08 +0100)] 
util: json: Remove unused virJSONValueObjectGetStringArray wrapper

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
2 years agoqemuAgentSSHGetAuthorizedKeys: Convert last use ofvirJSONValueObjectGetStringArray
Peter Krempa [Thu, 1 Dec 2022 16:07:12 +0000 (17:07 +0100)] 
qemuAgentSSHGetAuthorizedKeys: Convert last use ofvirJSONValueObjectGetStringArray

Use virJSONValueObjectGetArray + virJSONValueArrayToStringList instead
so that the ofvirJSONValueObjectGetStringArray wrapper can be removed.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
2 years agoqemu: monitor: Use qemuMonitorJSONGetReply in conjunction with virJSONValueArrayToStr...
Peter Krempa [Thu, 1 Dec 2022 16:19:50 +0000 (17:19 +0100)] 
qemu: monitor: Use qemuMonitorJSONGetReply in conjunction with virJSONValueArrayToStringList

In two instances (qemuMonitorJSONGetStringListProperty,
qemuMonitorJSONGetStringArray) the return value is checked by
qemuMonitorJSONCheckReply and extracted by
virJSONValueObjectGetStringArray.

We can use qemuMonitorJSONGetReply which returns it directly and then
virJSONValueArrayToStringList to convert it without the additional
lookup.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
2 years agoqemuMonitorJSONGetCPUDefinitions: Avoid double lookup of object
Peter Krempa [Thu, 1 Dec 2022 15:13:41 +0000 (16:13 +0100)] 
qemuMonitorJSONGetCPUDefinitions: Avoid double lookup of object

Using 'virJSONValueObjectHasKey' when we want to access the value
afterwards is wasteful. Fetch the JSON value right away.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
2 years agoqemuMonitorJSONGetCPUDefinitions: Rework lookup of 'unavailable-features'
Peter Krempa [Thu, 1 Dec 2022 15:13:05 +0000 (16:13 +0100)] 
qemuMonitorJSONGetCPUDefinitions: Rework lookup of 'unavailable-features'

Rather than checking that the object has the correct key and then
fetching it again use fetch the array first and then use
virJSONValueArrayToStringList to directly convert it.

Additionally we can avoid the conversion if there are no members
simplifying the surrounding logic.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
2 years agoqemuAgentGetDisks: Don't use virJSONValueObjectGetStringArray for optional data
Peter Krempa [Thu, 1 Dec 2022 16:02:42 +0000 (17:02 +0100)] 
qemuAgentGetDisks: Don't use virJSONValueObjectGetStringArray for optional data

The 'dependencies' field in the return data may be missing in some
cases. Historically 'virJSONValueObjectGetStringArray' didn't report
error in such case, but later refactor (commit 043b50b948ef3c2 ) added
an error in order to use it in other places too.

Unfortunately this results in the error log being spammed with an
irrelevant error in case when qemuAgentGetDisks is invoked on a VM
running windows.

Replace the use of virJSONValueObjectGetStringArray by fetching the
array first and calling virJSONValueArrayToStringList only when we have
an array.

Fixes: 043b50b948ef3c2a4adf5fa32a93ec2589851ac6
Resolves: https://bugzilla.redhat.com/show_bug.cgi?id=2149752
Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
2 years agoutil: json: Split out array->strinlist conversion from virJSONValueObjectGetStringArray
Peter Krempa [Thu, 1 Dec 2022 12:32:07 +0000 (13:32 +0100)] 
util: json: Split out array->strinlist conversion from virJSONValueObjectGetStringArray

Introduce virJSONValueArrayToStringList which does only the conversion
from an array to a stringlist.

This will allow refactoring the callers to be more careful in case when
they want to handle the existance of the member in the parent object
differently.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
2 years agoqemu: monitor: Unify and refactor 'PTY' case in qemuMonitorJSONAttachCharDev
Peter Krempa [Thu, 1 Dec 2022 15:47:29 +0000 (16:47 +0100)] 
qemu: monitor: Unify and refactor 'PTY' case in qemuMonitorJSONAttachCharDev

Use qemuMonitorJSONGetReply and unify the two blocks with the same
condition.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
2 years agoqemu: monitor: Use qemuMonitorJSONGetReply when the value is extracted directly
Peter Krempa [Thu, 1 Dec 2022 15:43:18 +0000 (16:43 +0100)] 
qemu: monitor: Use qemuMonitorJSONGetReply when the value is extracted directly

Use qemuMonitorJSONGetReply in cases where qemuMonitorJSONCheckReply
is followed by virJSONValueObjectGet*(reply, "return").

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
2 years agoqemu: monitor: Use qemuMonitorJSONGetReply for VIR_JSON_TYPE_ARRAY
Peter Krempa [Thu, 1 Dec 2022 15:27:13 +0000 (16:27 +0100)] 
qemu: monitor: Use qemuMonitorJSONGetReply for VIR_JSON_TYPE_ARRAY

Replace usage of the following pattern with the new helper:

  if (qemuMonitorJSONCheckReply(cmd, reply, VIR_JSON_TYPE_ARRAY) < 0)
      return -1;

  data = virJSONValueObjectGetArray(reply, "return");

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
2 years agoqemu: monitor: Use qemuMonitorJSONGetReply for VIR_JSON_TYPE_OBJECT
Peter Krempa [Thu, 1 Dec 2022 15:27:13 +0000 (16:27 +0100)] 
qemu: monitor: Use qemuMonitorJSONGetReply for VIR_JSON_TYPE_OBJECT

Replace usage of the following pattern with the new helper:

  if (qemuMonitorJSONCheckReply(cmd, reply, VIR_JSON_TYPE_OBJECT) < 0)
      return -1;

  data = virJSONValueObjectGetObject(reply, "return");

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
2 years agoqemu: monitor: Introduce qemuMonitorJSONGetReply, a better qemuMonitorJSONCheckReply
Peter Krempa [Thu, 1 Dec 2022 15:18:52 +0000 (16:18 +0100)] 
qemu: monitor: Introduce qemuMonitorJSONGetReply, a better qemuMonitorJSONCheckReply

Rather than simply checking that the 'return' field is of the expected
type we can directly return it as the caller is very likely going to use
it. Extract the code into the new function and add a wrapper to preserve
old functionality.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
2 years agolibxl: migration: Use 'unsigned int' for flags
Peter Krempa [Tue, 22 Nov 2022 12:03:39 +0000 (13:03 +0100)] 
libxl: migration: Use 'unsigned int' for flags

Fix the type for few internal functions. Externally the APIs were
already limiting 'flags' to 'unsigned int'.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agoqemu: migration: Use 'unsigned int' for flags
Peter Krempa [Tue, 22 Nov 2022 10:50:13 +0000 (11:50 +0100)] 
qemu: migration: Use 'unsigned int' for flags

Don't continue with the historical mistake and fix all internal
functions to use a sane type for flags.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agoqemu: processGuestPanicEvent: Use 'unsigned int' for flags
Peter Krempa [Tue, 22 Nov 2022 12:04:02 +0000 (13:04 +0100)] 
qemu: processGuestPanicEvent: Use 'unsigned int' for flags

No need to use 'long'.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agovirsh: vol-create-as: Use 'unsigned int' for flags
Peter Krempa [Tue, 22 Nov 2022 12:04:21 +0000 (13:04 +0100)] 
virsh: vol-create-as: Use 'unsigned int' for flags

The API itself uses 'unsigned int' so use the same type for the local
variable in virsh.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agointernal: Refuse values exceeding range of 'unsigned int' in virCheckFlags
Peter Krempa [Tue, 22 Nov 2022 10:44:50 +0000 (11:44 +0100)] 
internal: Refuse values exceeding range of 'unsigned int' in virCheckFlags

Historically our migration APIs declare 'unsigned long flags'. Since
it's baked into our API we can't change that but we can avoid
compatibility problems by preemptively refusing the extra range on
certain arches to prevent future surprise.

Modify the macro to verify that value passed inside 'flags' doesn't
exceed the range of 'unsigned int'.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2 years agospec: Remove use of %{name} macro
Jim Fehlig [Fri, 2 Dec 2022 00:08:38 +0000 (17:08 -0700)] 
spec: Remove use of %{name} macro

The spec file uses both "libvirt" and "%{name}", but in reality the
expanded value of %{name} will never change. Drop the macro in favor
of the explicit and more readable "libvirt".

Signed-off-by: Jim Fehlig <jfehlig@suse.com>
Reviewed-by: Jiri Denemark <jdenemar@redhat.com>
2 years agoTranslated using Weblate (Chinese (Simplified) (zh_CN))
Daniel P. Berrangé [Fri, 2 Dec 2022 13:09:34 +0000 (14:09 +0100)] 
Translated using Weblate (Chinese (Simplified) (zh_CN))

Currently translated at 99.2% (10292 of 10368 strings)

Translation: libvirt/libvirt
Translate-URL: https://translate.fedoraproject.org/projects/libvirt/libvirt/zh_CN/

Co-authored-by: Daniel P. Berrange <berrange@redhat.com>
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
2 years agoTranslated using Weblate (Chinese (Simplified) (zh_CN))
Yang Yulin [Fri, 2 Dec 2022 13:09:34 +0000 (14:09 +0100)] 
Translated using Weblate (Chinese (Simplified) (zh_CN))

Currently translated at 99.2% (10292 of 10368 strings)

Translation: libvirt/libvirt
Translate-URL: https://translate.fedoraproject.org/projects/libvirt/libvirt/zh_CN/

Co-authored-by: Yang Yulin <yylteam@icloud.com>
Signed-off-by: Yang Yulin <yylteam@icloud.com>
2 years agospec: Remove daemon postun trigger
Jim Fehlig [Tue, 22 Nov 2022 23:18:27 +0000 (16:18 -0700)] 
spec: Remove daemon postun trigger

Remove %triggerpostun for the daemon package. Upgrades from
libvirt < 1.3.0 are now unlikely.

Signed-off-by: Jim Fehlig <jfehlig@suse.com>
Reviewed-by: Daniel P. Berrangé <berrange@redhat.com>
2 years agospec: Remove redundant with_libxl
Jim Fehlig [Tue, 22 Nov 2022 03:56:38 +0000 (20:56 -0700)] 
spec: Remove redundant with_libxl

Signed-off-by: Jim Fehlig <jfehlig@suse.com>
Reviewed-by: Daniel P. Berrangé <berrange@redhat.com>
2 years agocommandtest: Comply with FreeBSD poll()
Michal Privoznik [Thu, 1 Dec 2022 15:23:55 +0000 (16:23 +0100)] 
commandtest: Comply with FreeBSD poll()

In one of recent commits I've introduced a new test case to
commandtest. In the test case I'm using poll() to wait for data
on a pipe (the write end is passed to commandhelper). However, on
FreeBSD the POLLIN semantic is a bit different:

  POLLIN        Data other than high priority data may be read
                without blocking.

Well, the pipe is non-blocking, so even if there's no data to be
read the flag is set (and subsequent read() returns 0). On the
other hand, POLLHUP is set too, BUT, if the commandhelper manages
to write everything into the pipe and die right after we'd get
both POLLIN and POLLHUP after the very first time poll() returns.
That's very unfortunate, but okay - we can just check whether
read() returned zero and break from the reading loop.

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Martin Kletzander <mkletzan@redhat.com>
2 years agotests: Use virTestCompareToString() more
Michal Privoznik [Wed, 30 Nov 2022 08:57:49 +0000 (09:57 +0100)] 
tests: Use virTestCompareToString() more

Instead of using:

  if (STRNEQ(a, b)) {
      virTestDifference(stderr, a, b);
      ...
  }

we can use:

  if (virTestCompareToString(a, b) < ) {
      ...
  }

Generated by the following spatch:

  @@
  expression a, b;
  @@

  - if (STRNEQ(a, b)) {
  + if (virTestCompareToString(a, b) < 0) {
      ...
  -   virTestDifference(stderr, a, b);
      ...
      }

and its variations (STRNEQ_NULLABLE() instead of STRNEQ(), then
in some cases variables passed to STRNEQ() are in reversed order
when compared to virTestCompareToString()).

However, coccinelle failed to recognize the pattern in
testNWFilterEBIPTablesAllTeardown() so I had to fix it manually.
Also, I manually fixed testFormat() in tests/sockettest.c as I
didn't bother writing another spatch rule just for that.

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Jonathon Jongsma <jjongsma@redhat.com>
2 years agotests: Don't wrap virTestDifference() arguments in NULLSTR()
Michal Privoznik [Wed, 30 Nov 2022 08:47:08 +0000 (09:47 +0100)] 
tests: Don't wrap virTestDifference() arguments in NULLSTR()

The virTestDifference() is perfectly capable of handling NULL
arguments. There's no need to wrap arguments in NULLSTR().

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Jonathon Jongsma <jjongsma@redhat.com>
2 years agovirbuftest: Cleanup code around virTestDifference()
Michal Privoznik [Wed, 30 Nov 2022 08:39:46 +0000 (09:39 +0100)] 
virbuftest: Cleanup code around virTestDifference()

Two things are happening here:

1) Call to virTestDifference() is guarded by '!result ||
   STRNEQ(result, _)' check. This is suboptimal since we have
   STRNEQ_NULLABLE().

2) There are couple of VIR_TEST_DEBUG() printings, which are
   useless. If debug is off they don't print anything, and if it
   is on, then much more information is printed by subsequent
   virTestDifference().

This makes the STRNEQ() + virTestDifference() combo look similar
to the rest of tests and thus can be picked up by spatch later.

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Jonathon Jongsma <jjongsma@redhat.com>
2 years agocommandtest: Use virTestCompareToFile() in checkoutput()
Michal Privoznik [Tue, 22 Mar 2022 12:36:38 +0000 (13:36 +0100)] 
commandtest: Use virTestCompareToFile() in checkoutput()

In the commandtest there is checkoutput() function which checks
the latest log of commandhelper (containing things like cmd line
arguments, env vars, FDs, CWD, etc.) and compares that against
expected output. Well, the way this function implements that is
effectively by open coding virTestCompareToFile() except for the
nice feature that the virTestCompareToFile() has:
VIR_TEST_OUTPUT_REGENERATE.

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Jonathon Jongsma <jjongsma@redhat.com>
2 years agocommandtest: Test virCommandSetSendBuffer() with virCommandDoAsyncIO()
Michal Privoznik [Tue, 22 Mar 2022 11:06:22 +0000 (12:06 +0100)] 
commandtest: Test virCommandSetSendBuffer() with virCommandDoAsyncIO()

Introduce a test case which ensures that a daemonized process can
work with virCommandSetSendBuffer() when async IO is enabled.

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Jonathon Jongsma <jjongsma@redhat.com>
2 years agovirCommandSetSendBuffer: Take double pointer of @buffer
Michal Privoznik [Tue, 22 Mar 2022 11:12:02 +0000 (12:12 +0100)] 
virCommandSetSendBuffer: Take double pointer of @buffer

The virCommandSetSendBuffer() function consumes passed @buffer,
but takes it only as plain pointer. Switch to a double pointer to
make this obvious. This allows us then to drop all
g_steal_pointer() in callers.

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Jonathon Jongsma <jjongsma@redhat.com>
2 years agocommandtest: Use unsigned char in test27()
Michal Privoznik [Tue, 22 Mar 2022 11:11:44 +0000 (12:11 +0100)] 
commandtest: Use unsigned char in test27()

In test27() the virCommandSetSendBuffer() is used, which expects
unsigned char. Use that type for variables which are passed to
the function.

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Jonathon Jongsma <jjongsma@redhat.com>
2 years agovirCommandDoAsyncIO: Drop misleading statement about main event loop
Michal Privoznik [Tue, 29 Nov 2022 15:55:16 +0000 (16:55 +0100)] 
virCommandDoAsyncIO: Drop misleading statement about main event loop

Back in v1.0.3-rc1~235 when I was adding virCommandDoAsyncIO(),
the main event loop was used to poll() on the pipe to the child
process. But this was promptly changed to a separate thread
handling I/O in v1.0.3-rc1~127. However, the corresponding
comment to virCommandDoAsyncIO() still documents the original
state.

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Jonathon Jongsma <jjongsma@redhat.com>
2 years agovircommand: Document virCommandSetSendBuffer() behaviour wrt daemonize
Michal Privoznik [Tue, 22 Mar 2022 10:03:10 +0000 (11:03 +0100)] 
vircommand: Document virCommandSetSendBuffer() behaviour wrt daemonize

When virCommandSetSendBuffer() is used over a virCommand that is
(or will be) daemonized, then the command must have
VIR_EXEC_ASYNC_IO flag set no later than at virCommandRunAsync()
phase so that the thread that's doing IO is spawned and thus
buffers can be sent to the process.

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Jonathon Jongsma <jjongsma@redhat.com>
2 years agoconf: report no NUMA nodes when attaching memory device
Kristina Hanicova [Fri, 25 Nov 2022 13:20:53 +0000 (14:20 +0100)] 
conf: report no NUMA nodes when attaching memory device

Error message reports that the guest has '0' NUMA nodes
configured when trying to attach a memory device to a guest with
no NUMA nodes. This may be a little misleading because '0' can
also be node's id.  A more friendly way is to directly report
that the guest has no NUMA nodes.

Resolves: https://bugzilla.redhat.com/show_bug.cgi?id=2142519

Signed-off-by: Kristina Hanicova <khanicov@redhat.com>
Reviewed-by: Jiri Denemark <jdenemar@redhat.com>
2 years agoqemu: Reindent qemuMigrationCookieParse prototype arguments
Jiri Denemark [Wed, 30 Nov 2022 15:10:08 +0000 (16:10 +0100)] 
qemu: Reindent qemuMigrationCookieParse prototype arguments

Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
Reviewed-by: Peter Krempa <pkrempa@redhat.com>
2 years agoqemu: Replace priv with qemuCaps in qemuMigrationCookieParse
Jiri Denemark [Wed, 30 Nov 2022 15:05:56 +0000 (16:05 +0100)] 
qemu: Replace priv with qemuCaps in qemuMigrationCookieParse

QEMU capabilities is the only thing we use from priv so we can just pass
that directly.

Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
Reviewed-by: Peter Krempa <pkrempa@redhat.com>
2 years agoqemu: Reorder qemuMigrationCookieParse arguments
Jiri Denemark [Wed, 30 Nov 2022 14:47:15 +0000 (15:47 +0100)] 
qemu: Reorder qemuMigrationCookieParse arguments

When an internal API takes a vm pointer, it's usually just after the
driver argument.

Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
Reviewed-by: Peter Krempa <pkrempa@redhat.com>
2 years agoPost-release version bump to 9.0.0
Jiri Denemark [Thu, 1 Dec 2022 09:59:27 +0000 (10:59 +0100)] 
Post-release version bump to 9.0.0

Signed-off-by: Jiri Denemark <jdenemar@redhat.com>