[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PULL 01/13] vhost_net: fix assertion triggered by batch of host notifie
From: |
Michael S. Tsirkin |
Subject: |
[PULL 01/13] vhost_net: fix assertion triggered by batch of host notifiers processing |
Date: |
Wed, 27 Nov 2024 08:57:29 -0500 |
From: zuoboqun <zuoboqun@baidu.com>
When the backend of vhost_net restarts during the vm is running, vhost_net
is stopped and started. The virtio_device_grab_ioeventfd() fucntion in
vhost_net_enable_notifiers() will result in a call to
virtio_bus_set_host_notifier()(assign=false).
And now virtio_device_grab_ioeventfd() is batched in a single transaction
with virtio_bus_set_host_notifier()(assign=true).
This triggers the following assertion:
kvm_mem_ioeventfd_del: error deleting ioeventfd: Bad file descriptor
This patch moves virtio_device_grab_ioeventfd() out of the batch to fix
this problem.
To be noted that the for loop to release ioeventfd should start from i+1,
not i, because the i-th ioeventfd has already been released in
vhost_dev_disable_notifiers_nvqs().
Fixes: 6166799f6 ("vhost_net: configure all host notifiers in a single MR
transaction")
Signed-off-by: Zuo Boqun <zuoboqun@baidu.com>
Reported-by: Gao Shiyuan <gaoshiyuan@baidu.com>
Message-Id: <20241115080312.3184-1-zuoboqun@baidu.com>
Acked-by: Stefano Garzarella <sgarzare@redhat.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
---
hw/net/vhost_net.c | 35 ++++++++++++++++++++++++-----------
1 file changed, 24 insertions(+), 11 deletions(-)
diff --git a/hw/net/vhost_net.c b/hw/net/vhost_net.c
index 997aab0557..891f235a0a 100644
--- a/hw/net/vhost_net.c
+++ b/hw/net/vhost_net.c
@@ -229,9 +229,24 @@ static int vhost_net_enable_notifiers(VirtIODevice *dev,
int nvhosts = data_queue_pairs + cvq;
struct vhost_net *net;
struct vhost_dev *hdev;
- int r, i, j;
+ int r, i, j, k;
NetClientState *peer;
+ /*
+ * We will pass the notifiers to the kernel, make sure that QEMU
+ * doesn't interfere.
+ */
+ for (i = 0; i < nvhosts; i++) {
+ r = virtio_device_grab_ioeventfd(dev);
+ if (r < 0) {
+ error_report("vhost %d binding does not support host notifiers",
i);
+ for (k = 0; k < i; k++) {
+ virtio_device_release_ioeventfd(dev);
+ }
+ return r;
+ }
+ }
+
/*
* Batch all the host notifiers in a single transaction to avoid
* quadratic time complexity in address_space_update_ioeventfds().
@@ -247,16 +262,6 @@ static int vhost_net_enable_notifiers(VirtIODevice *dev,
net = get_vhost_net(peer);
hdev = &net->dev;
- /*
- * We will pass the notifiers to the kernel, make sure that QEMU
- * doesn't interfere.
- */
- r = virtio_device_grab_ioeventfd(dev);
- if (r < 0) {
- error_report("binding does not support host notifiers");
- memory_region_transaction_commit();
- goto fail_nvhosts;
- }
for (j = 0; j < hdev->nvqs; j++) {
r = virtio_bus_set_host_notifier(VIRTIO_BUS(qbus),
@@ -277,6 +282,14 @@ static int vhost_net_enable_notifiers(VirtIODevice *dev,
return 0;
fail_nvhosts:
vhost_net_disable_notifiers_nvhosts(dev, ncs, data_queue_pairs, i);
+ /*
+ * This for loop starts from i+1, not i, because the i-th ioeventfd
+ * has already been released in vhost_dev_disable_notifiers_nvqs().
+ */
+ for (k = i + 1; k < nvhosts; k++) {
+ virtio_device_release_ioeventfd(dev);
+ }
+
return r;
}
--
MST
- [PULL 00/13] virtio,pc,pci: bug fixes, new test, Michael S. Tsirkin, 2024/11/27
- [PULL 01/13] vhost_net: fix assertion triggered by batch of host notifiers processing,
Michael S. Tsirkin <=
- [PULL 02/13] qtest: allow ACPI DSDT Table changes, Michael S. Tsirkin, 2024/11/27
- [PULL 03/13] Revert "hw/acpi: Update ACPI `_STA` method with QOM vCPU ACPI Hotplug states", Michael S. Tsirkin, 2024/11/27
- [PULL 04/13] Revert "hw/acpi: Make CPUs ACPI `presence` conditional during vCPU hot-unplug", Michael S. Tsirkin, 2024/11/27
- [PULL 06/13] hw/cxl: Check for zero length features in cmd_features_set_feature(), Michael S. Tsirkin, 2024/11/27
- [PULL 07/13] qapi: fix device-sync-config since-version, Michael S. Tsirkin, 2024/11/27
- [PULL 05/13] tests/acpi: update expected blobs, Michael S. Tsirkin, 2024/11/27
- [PULL 10/13] bios-tables-test: Allow for new acpihmat-generic-x test data., Michael S. Tsirkin, 2024/11/27
- [PULL 09/13] qapi/qom: Change Since entry for AcpiGenericPortProperties to 9.2, Michael S. Tsirkin, 2024/11/27
- [PULL 11/13] bios-tables-test: Add complex SRAT / HMAT test for GI GP, Michael S. Tsirkin, 2024/11/27
- [PULL 12/13] bios-tables-test: Add data for complex numa test (GI, GP etc), Michael S. Tsirkin, 2024/11/27