Commit 071e7310 authored by Alex Williamson's avatar Alex Williamson

vfio/pci: Pass eventfd context to IRQ handler

Create a link back to the vfio_pci_core_device on the eventfd context
object to avoid lookups in the interrupt path.  The context is known
valid in the interrupt handler.
Reviewed-by: default avatarKevin Tian <kevin.tian@intel.com>
Link: https://lore.kernel.org/r/20240401195406.3720453-2-alex.williamson@redhat.comSigned-off-by: default avatarAlex Williamson <alex.williamson@redhat.com>
parent af6605f8
...@@ -23,11 +23,12 @@ ...@@ -23,11 +23,12 @@
#include "vfio_pci_priv.h" #include "vfio_pci_priv.h"
struct vfio_pci_irq_ctx { struct vfio_pci_irq_ctx {
struct eventfd_ctx *trigger; struct vfio_pci_core_device *vdev;
struct virqfd *unmask; struct eventfd_ctx *trigger;
struct virqfd *mask; struct virqfd *unmask;
char *name; struct virqfd *mask;
bool masked; char *name;
bool masked;
struct irq_bypass_producer producer; struct irq_bypass_producer producer;
}; };
...@@ -228,15 +229,11 @@ void vfio_pci_intx_unmask(struct vfio_pci_core_device *vdev) ...@@ -228,15 +229,11 @@ void vfio_pci_intx_unmask(struct vfio_pci_core_device *vdev)
static irqreturn_t vfio_intx_handler(int irq, void *dev_id) static irqreturn_t vfio_intx_handler(int irq, void *dev_id)
{ {
struct vfio_pci_core_device *vdev = dev_id; struct vfio_pci_irq_ctx *ctx = dev_id;
struct vfio_pci_irq_ctx *ctx; struct vfio_pci_core_device *vdev = ctx->vdev;
unsigned long flags; unsigned long flags;
int ret = IRQ_NONE; int ret = IRQ_NONE;
ctx = vfio_irq_ctx_get(vdev, 0);
if (WARN_ON_ONCE(!ctx))
return ret;
spin_lock_irqsave(&vdev->irqlock, flags); spin_lock_irqsave(&vdev->irqlock, flags);
if (!vdev->pci_2_3) { if (!vdev->pci_2_3) {
...@@ -282,6 +279,7 @@ static int vfio_intx_enable(struct vfio_pci_core_device *vdev, ...@@ -282,6 +279,7 @@ static int vfio_intx_enable(struct vfio_pci_core_device *vdev,
ctx->name = name; ctx->name = name;
ctx->trigger = trigger; ctx->trigger = trigger;
ctx->vdev = vdev;
/* /*
* Fill the initial masked state based on virq_disabled. After * Fill the initial masked state based on virq_disabled. After
...@@ -312,7 +310,7 @@ static int vfio_intx_enable(struct vfio_pci_core_device *vdev, ...@@ -312,7 +310,7 @@ static int vfio_intx_enable(struct vfio_pci_core_device *vdev,
vdev->irq_type = VFIO_PCI_INTX_IRQ_INDEX; vdev->irq_type = VFIO_PCI_INTX_IRQ_INDEX;
ret = request_irq(pdev->irq, vfio_intx_handler, ret = request_irq(pdev->irq, vfio_intx_handler,
irqflags, ctx->name, vdev); irqflags, ctx->name, ctx);
if (ret) { if (ret) {
vdev->irq_type = VFIO_PCI_NUM_IRQS; vdev->irq_type = VFIO_PCI_NUM_IRQS;
kfree(name); kfree(name);
...@@ -358,7 +356,7 @@ static void vfio_intx_disable(struct vfio_pci_core_device *vdev) ...@@ -358,7 +356,7 @@ static void vfio_intx_disable(struct vfio_pci_core_device *vdev)
if (ctx) { if (ctx) {
vfio_virqfd_disable(&ctx->unmask); vfio_virqfd_disable(&ctx->unmask);
vfio_virqfd_disable(&ctx->mask); vfio_virqfd_disable(&ctx->mask);
free_irq(pdev->irq, vdev); free_irq(pdev->irq, ctx);
if (ctx->trigger) if (ctx->trigger)
eventfd_ctx_put(ctx->trigger); eventfd_ctx_put(ctx->trigger);
kfree(ctx->name); kfree(ctx->name);
......
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