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 | |
| 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>
| -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. |
