Commit bdc5e102 authored by Antonios Motakis's avatar Antonios Motakis Committed by Alex Williamson

vfio: add a vfio_ prefix to virqfd_enable and virqfd_disable and export

We want to reuse virqfd functionality in multiple VFIO drivers; before
moving these functions to core VFIO, add the vfio_ prefix to the
virqfd_enable and virqfd_disable functions, and export them so they can
be used from other modules.
Signed-off-by: default avatarAntonios Motakis <a.motakis@virtualopensystems.com>
Signed-off-by: default avatarBaptiste Reynal <b.reynal@virtualopensystems.com>
Reviewed-by: default avatarEric Auger <eric.auger@linaro.org>
Tested-by: default avatarEric Auger <eric.auger@linaro.org>
Signed-off-by: default avatarAlex Williamson <alex.williamson@redhat.com>
parent 06211b40
...@@ -126,7 +126,7 @@ static void virqfd_inject(struct work_struct *work) ...@@ -126,7 +126,7 @@ static void virqfd_inject(struct work_struct *work)
virqfd->thread(virqfd->vdev, virqfd->data); virqfd->thread(virqfd->vdev, virqfd->data);
} }
static int virqfd_enable(struct vfio_pci_device *vdev, int vfio_virqfd_enable(struct vfio_pci_device *vdev,
int (*handler)(struct vfio_pci_device *, void *), int (*handler)(struct vfio_pci_device *, void *),
void (*thread)(struct vfio_pci_device *, void *), void (*thread)(struct vfio_pci_device *, void *),
void *data, struct virqfd **pvirqfd, int fd) void *data, struct virqfd **pvirqfd, int fd)
...@@ -215,9 +215,9 @@ static int virqfd_enable(struct vfio_pci_device *vdev, ...@@ -215,9 +215,9 @@ static int virqfd_enable(struct vfio_pci_device *vdev,
return ret; return ret;
} }
EXPORT_SYMBOL_GPL(vfio_virqfd_enable);
static void virqfd_disable(struct vfio_pci_device *vdev, void vfio_virqfd_disable(struct vfio_pci_device *vdev, struct virqfd **pvirqfd)
struct virqfd **pvirqfd)
{ {
unsigned long flags; unsigned long flags;
...@@ -237,6 +237,7 @@ static void virqfd_disable(struct vfio_pci_device *vdev, ...@@ -237,6 +237,7 @@ static void virqfd_disable(struct vfio_pci_device *vdev,
*/ */
flush_workqueue(vfio_irqfd_cleanup_wq); flush_workqueue(vfio_irqfd_cleanup_wq);
} }
EXPORT_SYMBOL_GPL(vfio_virqfd_disable);
/* /*
* INTx * INTx
...@@ -440,8 +441,8 @@ static int vfio_intx_set_signal(struct vfio_pci_device *vdev, int fd) ...@@ -440,8 +441,8 @@ static int vfio_intx_set_signal(struct vfio_pci_device *vdev, int fd)
static void vfio_intx_disable(struct vfio_pci_device *vdev) static void vfio_intx_disable(struct vfio_pci_device *vdev)
{ {
vfio_intx_set_signal(vdev, -1); vfio_intx_set_signal(vdev, -1);
virqfd_disable(vdev, &vdev->ctx[0].unmask); vfio_virqfd_disable(vdev, &vdev->ctx[0].unmask);
virqfd_disable(vdev, &vdev->ctx[0].mask); vfio_virqfd_disable(vdev, &vdev->ctx[0].mask);
vdev->irq_type = VFIO_PCI_NUM_IRQS; vdev->irq_type = VFIO_PCI_NUM_IRQS;
vdev->num_ctx = 0; vdev->num_ctx = 0;
kfree(vdev->ctx); kfree(vdev->ctx);
...@@ -605,8 +606,8 @@ static void vfio_msi_disable(struct vfio_pci_device *vdev, bool msix) ...@@ -605,8 +606,8 @@ static void vfio_msi_disable(struct vfio_pci_device *vdev, bool msix)
vfio_msi_set_block(vdev, 0, vdev->num_ctx, NULL, msix); vfio_msi_set_block(vdev, 0, vdev->num_ctx, NULL, msix);
for (i = 0; i < vdev->num_ctx; i++) { for (i = 0; i < vdev->num_ctx; i++) {
virqfd_disable(vdev, &vdev->ctx[i].unmask); vfio_virqfd_disable(vdev, &vdev->ctx[i].unmask);
virqfd_disable(vdev, &vdev->ctx[i].mask); vfio_virqfd_disable(vdev, &vdev->ctx[i].mask);
} }
if (msix) { if (msix) {
...@@ -639,11 +640,12 @@ static int vfio_pci_set_intx_unmask(struct vfio_pci_device *vdev, ...@@ -639,11 +640,12 @@ static int vfio_pci_set_intx_unmask(struct vfio_pci_device *vdev,
} else if (flags & VFIO_IRQ_SET_DATA_EVENTFD) { } else if (flags & VFIO_IRQ_SET_DATA_EVENTFD) {
int32_t fd = *(int32_t *)data; int32_t fd = *(int32_t *)data;
if (fd >= 0) if (fd >= 0)
return virqfd_enable(vdev, vfio_pci_intx_unmask_handler, return vfio_virqfd_enable(vdev,
vfio_pci_intx_unmask_handler,
vfio_send_intx_eventfd, NULL, vfio_send_intx_eventfd, NULL,
&vdev->ctx[0].unmask, fd); &vdev->ctx[0].unmask, fd);
virqfd_disable(vdev, &vdev->ctx[0].unmask); vfio_virqfd_disable(vdev, &vdev->ctx[0].unmask);
} }
return 0; return 0;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment