]> www.infradead.org Git - users/hch/dma-mapping.git/commitdiff
vdpa: add bind_mm/unbind_mm callbacks
authorStefano Garzarella <sgarzare@redhat.com>
Tue, 4 Apr 2023 13:13:18 +0000 (15:13 +0200)
committerMichael S. Tsirkin <mst@redhat.com>
Fri, 21 Apr 2023 07:02:33 +0000 (03:02 -0400)
These new optional callbacks is used to bind/unbind the device to
a specific address space so the vDPA framework can use VA when
these callbacks are implemented.

Suggested-by: Jason Wang <jasowang@redhat.com>
Acked-by: Jason Wang <jasowang@redhat.com>
Signed-off-by: Stefano Garzarella <sgarzare@redhat.com>
Message-Id: <20230404131326.44403-2-sgarzare@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
include/linux/vdpa.h

index f2064fa2d2da9a54968b9247e21e47e1329de079..2f1af73b3a1a3e08e1dae532f586b7122aee9d63 100644 (file)
@@ -305,6 +305,14 @@ struct vdpa_map_file {
  *                             @vdev: vdpa device
  *                             @idx: virtqueue index
  *                             Returns pointer to structure device or error (NULL)
+ * @bind_mm:                   Bind the device to a specific address space
+ *                             so the vDPA framework can use VA when this
+ *                             callback is implemented. (optional)
+ *                             @vdev: vdpa device
+ *                             @mm: address space to bind
+ * @unbind_mm:                 Unbind the device from the address space
+ *                             bound using the bind_mm callback. (optional)
+ *                             @vdev: vdpa device
  * @free:                      Free resources that belongs to vDPA (optional)
  *                             @vdev: vdpa device
  */
@@ -370,6 +378,8 @@ struct vdpa_config_ops {
        int (*set_group_asid)(struct vdpa_device *vdev, unsigned int group,
                              unsigned int asid);
        struct device *(*get_vq_dma_dev)(struct vdpa_device *vdev, u16 idx);
+       int (*bind_mm)(struct vdpa_device *vdev, struct mm_struct *mm);
+       void (*unbind_mm)(struct vdpa_device *vdev);
 
        /* Free device resources */
        void (*free)(struct vdpa_device *vdev);