aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/vfio/pci
diff options
context:
space:
mode:
authorAlex Williamson <alex.williamson@redhat.com>2012-10-10 11:10:32 -0400
committerAlex Williamson <alex.williamson@redhat.com>2012-10-10 11:10:32 -0400
commit9dbdfd23b7638d054f3b0e70c64dfb9f297f2a9f (patch)
tree85b24e35aea412ea63bae6b71a679b9d030c06fa /drivers/vfio/pci
parent34002f54d2bd8e8ac04f0da0847f71a8a06a5d38 (diff)
vfio: Move PCI INTx eventfd setting earlier
We need to be ready to recieve an interrupt as soon as we call request_irq, so our eventfd context setting needs to be moved earlier. Without this, an interrupt from our device or one sharing the interrupt line can pass a NULL into eventfd_signal and oops. Cc: stable@vger.kernel.org Signed-off-by: Alex Williamson <alex.williamson@redhat.com>
Diffstat (limited to 'drivers/vfio/pci')
-rw-r--r--drivers/vfio/pci/vfio_pci_intrs.c5
1 files changed, 3 insertions, 2 deletions
diff --git a/drivers/vfio/pci/vfio_pci_intrs.c b/drivers/vfio/pci/vfio_pci_intrs.c
index d8dedc7d3910..c8139a598f84 100644
--- a/drivers/vfio/pci/vfio_pci_intrs.c
+++ b/drivers/vfio/pci/vfio_pci_intrs.c
@@ -400,19 +400,20 @@ static int vfio_intx_set_signal(struct vfio_pci_device *vdev, int fd)
400 return PTR_ERR(trigger); 400 return PTR_ERR(trigger);
401 } 401 }
402 402
403 vdev->ctx[0].trigger = trigger;
404
403 if (!vdev->pci_2_3) 405 if (!vdev->pci_2_3)
404 irqflags = 0; 406 irqflags = 0;
405 407
406 ret = request_irq(pdev->irq, vfio_intx_handler, 408 ret = request_irq(pdev->irq, vfio_intx_handler,
407 irqflags, vdev->ctx[0].name, vdev); 409 irqflags, vdev->ctx[0].name, vdev);
408 if (ret) { 410 if (ret) {
411 vdev->ctx[0].trigger = NULL;
409 kfree(vdev->ctx[0].name); 412 kfree(vdev->ctx[0].name);
410 eventfd_ctx_put(trigger); 413 eventfd_ctx_put(trigger);
411 return ret; 414 return ret;
412 } 415 }
413 416
414 vdev->ctx[0].trigger = trigger;
415
416 /* 417 /*
417 * INTx disable will stick across the new irq setup, 418 * INTx disable will stick across the new irq setup,
418 * disable_irq won't. 419 * disable_irq won't.