On Wed, 2015-01-21 at 13:49 +0100, Baptiste Reynal wrote: > From: Antonios Motakis <a.motakis@xxxxxxxxxxxxxxxxxxxxxx> > > This patch allows to set an eventfd for a platform device's interrupt, > and also to trigger the interrupt eventfd from userspace for testing. > Level sensitive interrupts are marked as maskable and are handled in > a later patch. Edge triggered interrupts are not advertised as maskable > and are implemented here using a simple and efficient IRQ handler. > > Signed-off-by: Antonios Motakis <a.motakis@xxxxxxxxxxxxxxxxxxxxxx> > [Baptiste Reynal: fix masked interrupt initialization] > Signed-off-by: Baptiste Reynal <b.reynal@xxxxxxxxxxxxxxxxxxxxxx> > --- > drivers/vfio/platform/vfio_platform_irq.c | 98 ++++++++++++++++++++++++++- > drivers/vfio/platform/vfio_platform_private.h | 2 + > 2 files changed, 98 insertions(+), 2 deletions(-) > > diff --git a/drivers/vfio/platform/vfio_platform_irq.c b/drivers/vfio/platform/vfio_platform_irq.c > index df5c919..4b1ee22 100644 > --- a/drivers/vfio/platform/vfio_platform_irq.c > +++ b/drivers/vfio/platform/vfio_platform_irq.c > @@ -39,12 +39,96 @@ static int vfio_platform_set_irq_unmask(struct vfio_platform_device *vdev, > return -EINVAL; > } > > +static irqreturn_t vfio_irq_handler(int irq, void *dev_id) > +{ > + struct vfio_platform_irq *irq_ctx = dev_id; > + > + eventfd_signal(irq_ctx->trigger, 1); > + > + return IRQ_HANDLED; > +} > + > +static int vfio_set_trigger(struct vfio_platform_device *vdev, int index, > + int fd, irq_handler_t handler) > +{ > + struct vfio_platform_irq *irq = &vdev->irqs[index]; > + struct eventfd_ctx *trigger; > + int ret; > + > + if (irq->trigger) { > + free_irq(irq->hwirq, irq); > + kfree(irq->name); > + eventfd_ctx_put(irq->trigger); > + irq->trigger = NULL; > + } > + > + if (fd < 0) /* Disable only */ > + return 0; > + > + irq->name = kasprintf(GFP_KERNEL, "vfio-irq[%d](%s)", > + irq->hwirq, vdev->name); > + if (!irq->name) > + return -ENOMEM; > + > + trigger = eventfd_ctx_fdget(fd); > + if (IS_ERR(trigger)) { > + kfree(irq->name); > + return PTR_ERR(trigger); > + } > + > + irq->trigger = trigger; > + > + irq_set_status_flags(irq->hwirq, IRQ_NOAUTOEN); > + ret = request_irq(irq->hwirq, handler, 0, irq->name, irq); > + if (ret) { > + kfree(irq->name); > + eventfd_ctx_put(trigger); > + irq->trigger = NULL; > + return ret; > + } > + > + if (!irq->masked) > + enable_irq(irq->hwirq); Unfortunately, irq->masked doesn't exist until the next patch. Thanks, Alex -- To unsubscribe from this list: send the line "unsubscribe kvm" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html