99 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			99 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
 | |
| From: Xueming Li <xuemingl@nvidia.com>
 | |
| Date: Mon, 7 Feb 2022 15:19:28 +0800
 | |
| Subject: [PATCH] vhost-user: remove VirtQ notifier restore
 | |
| 
 | |
| Notifier set when vhost-user backend asks qemu to mmap an FD and
 | |
| offset. When vhost-user backend restart or getting killed, VQ notifier
 | |
| FD and mmap addresses become invalid. After backend restart, MR contains
 | |
| the invalid address will be restored and fail on notifier access.
 | |
| 
 | |
| On the other hand, qemu should munmap the notifier, release underlying
 | |
| hardware resources to enable backend restart and allocate hardware
 | |
| notifier resources correctly.
 | |
| 
 | |
| Qemu shouldn't reference and use resources of disconnected backend.
 | |
| 
 | |
| This patch removes VQ notifier restore, uses the default vhost-user
 | |
| notifier to avoid invalid address access.
 | |
| 
 | |
| After backend restart, the backend should ask qemu to install a hardware
 | |
| notifier if needed.
 | |
| 
 | |
| Fixes: 44866521bd6e ("vhost-user: support registering external host notifiers")
 | |
| Cc: qemu-stable@nongnu.org
 | |
| Signed-off-by: Xueming Li <xuemingl@nvidia.com>
 | |
| Message-Id: <20220207071929.527149-2-xuemingl@nvidia.com>
 | |
| Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
 | |
| Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
 | |
| (cherry picked from commit e867144b73b3c5009266b6df07d5ff44acfb82c3)
 | |
| Signed-off-by: Thomas Lamprecht <t.lamprecht@proxmox.com>
 | |
| ---
 | |
|  hw/virtio/vhost-user.c         | 19 +------------------
 | |
|  include/hw/virtio/vhost-user.h |  1 -
 | |
|  2 files changed, 1 insertion(+), 19 deletions(-)
 | |
| 
 | |
| diff --git a/hw/virtio/vhost-user.c b/hw/virtio/vhost-user.c
 | |
| index bf6e50223c..c671719e9b 100644
 | |
| --- a/hw/virtio/vhost-user.c
 | |
| +++ b/hw/virtio/vhost-user.c
 | |
| @@ -1143,19 +1143,6 @@ static int vhost_user_set_vring_num(struct vhost_dev *dev,
 | |
|      return vhost_set_vring(dev, VHOST_USER_SET_VRING_NUM, ring);
 | |
|  }
 | |
|  
 | |
| -static void vhost_user_host_notifier_restore(struct vhost_dev *dev,
 | |
| -                                             int queue_idx)
 | |
| -{
 | |
| -    struct vhost_user *u = dev->opaque;
 | |
| -    VhostUserHostNotifier *n = &u->user->notifier[queue_idx];
 | |
| -    VirtIODevice *vdev = dev->vdev;
 | |
| -
 | |
| -    if (n->addr && !n->set) {
 | |
| -        virtio_queue_set_host_notifier_mr(vdev, queue_idx, &n->mr, true);
 | |
| -        n->set = true;
 | |
| -    }
 | |
| -}
 | |
| -
 | |
|  static void vhost_user_host_notifier_remove(struct vhost_dev *dev,
 | |
|                                              int queue_idx)
 | |
|  {
 | |
| @@ -1163,17 +1150,14 @@ static void vhost_user_host_notifier_remove(struct vhost_dev *dev,
 | |
|      VhostUserHostNotifier *n = &u->user->notifier[queue_idx];
 | |
|      VirtIODevice *vdev = dev->vdev;
 | |
|  
 | |
| -    if (n->addr && n->set) {
 | |
| +    if (n->addr) {
 | |
|          virtio_queue_set_host_notifier_mr(vdev, queue_idx, &n->mr, false);
 | |
| -        n->set = false;
 | |
|      }
 | |
|  }
 | |
|  
 | |
|  static int vhost_user_set_vring_base(struct vhost_dev *dev,
 | |
|                                       struct vhost_vring_state *ring)
 | |
|  {
 | |
| -    vhost_user_host_notifier_restore(dev, ring->index);
 | |
| -
 | |
|      return vhost_set_vring(dev, VHOST_USER_SET_VRING_BASE, ring);
 | |
|  }
 | |
|  
 | |
| @@ -1538,7 +1522,6 @@ static int vhost_user_slave_handle_vring_host_notifier(struct vhost_dev *dev,
 | |
|      }
 | |
|  
 | |
|      n->addr = addr;
 | |
| -    n->set = true;
 | |
|  
 | |
|      return 0;
 | |
|  }
 | |
| diff --git a/include/hw/virtio/vhost-user.h b/include/hw/virtio/vhost-user.h
 | |
| index a9abca3288..f6012b2078 100644
 | |
| --- a/include/hw/virtio/vhost-user.h
 | |
| +++ b/include/hw/virtio/vhost-user.h
 | |
| @@ -14,7 +14,6 @@
 | |
|  typedef struct VhostUserHostNotifier {
 | |
|      MemoryRegion mr;
 | |
|      void *addr;
 | |
| -    bool set;
 | |
|  } VhostUserHostNotifier;
 | |
|  
 | |
|  typedef struct VhostUserState {
 | 
