diff options
author | Alex Williamson <alex.williamson@redhat.com> | 2012-10-10 11:10:32 -0400 |
---|---|---|
committer | Alex Williamson <alex.williamson@redhat.com> | 2012-10-10 11:10:32 -0400 |
commit | 9dbdfd23b7638d054f3b0e70c64dfb9f297f2a9f (patch) | |
tree | 85b24e35aea412ea63bae6b71a679b9d030c06fa /drivers | |
parent | 34002f54d2bd8e8ac04f0da0847f71a8a06a5d38 (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')
-rw-r--r-- | drivers/vfio/pci/vfio_pci_intrs.c | 5 |
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. |