all lists on lists.proxmox.com
 help / color / mirror / Atom feed
From: Thomas Lamprecht <t.lamprecht@proxmox.com>
To: Proxmox VE development discussion <pve-devel@lists.proxmox.com>,
	Fiona Ebner <f.ebner@proxmox.com>
Subject: [pve-devel] applied: [PATCH v2 qemu-server] qmp helpers: device add/del: use HMP interface
Date: Tue, 4 Feb 2025 17:22:30 +0100	[thread overview]
Message-ID: <afaaee4f-fef3-4a64-b659-1331e0ff9d24@proxmox.com> (raw)
In-Reply-To: <20250204155101.151349-1-f.ebner@proxmox.com>

Am 04.02.25 um 16:51 schrieb Fiona Ebner:
> Fixes device hotplug in combination with QEMU 9.2.
> 
> QEMU commit be93fd5372 ("qdev-monitor: avoid QemuOpts in QMP device_add")
> notes:
> 
>> This patch changes the behavior of QMP device_add but not HMP
>> device_add. QMP clients that sent incorrectly typed device_add QMP
>> commands no longer work. This is a breaking change but clients should be
>> using the correct types already.
> 
> The qemu_deviceadd() helper does not have the required type
> information right now, so switch to using HMP, which still behaves the
> same when passing a device commandline string. QEMU commit be93fd5372
> fixes passing in complex properties via JSON, but the qemu_deviceadd()
> helper never uses any such, as it already only received a string (and
> naively split it up).
> 
> Use HMP for 'device_del' too, simply to keep the qemu_deviceadd() and
> qemu_devicedel() helpers consistent.
> 
> Switching back to QMP using the correct types in the JSON can still be
> done later. Unfortunately, 'qmp-query-schema' does not provide
> device-specific types, so another way is needed.
> 
> A timeout of 30 seconds is used rather then relying on the low default
> like before, since device plug operations require actions by the guest
> kernel and might require IO. Device plug is often an interactive
> operation, so a too high timeout could lead to bad UX. Should specific
> devices need a higher timeout, it can still be increased further for
> them in the future.
> 
> Signed-off-by: Fiona Ebner <f.ebner@proxmox.com>
> ---
> 
> Changes in v2:
> * also mention 'del' in commit title
> * fix commit message (bug #5985 is not actually fixed by this, that
>   requires bumping the timeout for netdev_add)
> * use 30 seconds as a timeout (see commit message for rationale)
> 
>  PVE/QemuServer/QMPHelpers.pm | 5 ++---
>  1 file changed, 2 insertions(+), 3 deletions(-)
> 
>

applied, thanks!

I reduced the timeout to 25s to ensure we got some headroom to the 30s timeout
that the web UI imposes for API requests, so that anything that doesn't triggers
a task-worker gets a nicer error. We can still increase that, before the change
it was only 5s anyway, so even with "just" 25s it's quite a bit longer now.


_______________________________________________
pve-devel mailing list
pve-devel@lists.proxmox.com
https://lists.proxmox.com/cgi-bin/mailman/listinfo/pve-devel


      reply	other threads:[~2025-02-04 16:22 UTC|newest]

Thread overview: 2+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2025-02-04 15:51 [pve-devel] " Fiona Ebner
2025-02-04 16:22 ` Thomas Lamprecht [this message]

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=afaaee4f-fef3-4a64-b659-1331e0ff9d24@proxmox.com \
    --to=t.lamprecht@proxmox.com \
    --cc=f.ebner@proxmox.com \
    --cc=pve-devel@lists.proxmox.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.
Service provided by Proxmox Server Solutions GmbH | Privacy | Legal