Re: [RFC v2 0/6] IRQ bypass manager and irqfd consumer

From: Alex Williamson
Date: Tue Jul 07 2015 - 13:18:01 EST


On Mon, 2015-07-06 at 14:11 +0200, Eric Auger wrote:
> This series introduces and extends the IRQ bypass manager written
> by Alex and transforms irqfd into an IRQ bypass manager consumer.
> The producer part, in my case the VFIO platform driver will be introduced
> separately. That code should be usable by both ARM IRQ forwarding
> and Intel Posted Interrupts.
>
> The IRQ bypass manager enables to setup a negotiated link between an
> IRQ producer and an IRQ consumer (typically the VFIO driver and KVM irqfd).
>
> The series currently includes Alex's code which was sent my email.
> Its structure obvioulsy will adapt to Alex's will.
>
> Also the irq bypass manager gets compiled/linked on arm/arm64 along
> with KVM and VFIO platform driver.
>
> can be found at:
> https://git.linaro.org/people/eric.auger/linux.git/shortlog/refs/heads/v4.2-rc1-bypass-fwd-v2


Thanks for taking this from a skeleton to a functional implementation,
Eric! I'm happy with the way this is progressing. Once we're confident
Feng can use your extensions, I'd be happy to merge those back into the
irq bypass manager and propose it upstream.

Hosting the bypass manager in kernel/irq seemed appropriate, but really
it could be anywhere. Does anyone have a different preference or
specifically want it under their scope? We had originally thought of
this as an IOMMU service, but I think we've generalized it beyond that.
I expect we should also add the necessary hooks to turn it into a
loadable module to keep the tinification folks happy, I'll incorporate
the current working changes and post a version with that. Thanks,

Alex

> History:
> v1 -> v2:
> - isolate the bypass manager and irqfd consumer in this series
> - take into account Paolo's comments and use container_of strategy and
> remove additional fields introduced in v1.
> - create kvm_irqfd.h
> - add unregistration in irqfd_shutdown
>
> v1: originally part of [RFC 00/17] ARM IRQ forward control based on IRQ
> bypass manager (https://lkml.org/lkml/2015/7/2/268)
>
>
> Eric Auger (6):
> KVM: arm/arm64: select IRQ_BYPASS_MANAGER
> VFIO: platform: select IRQ_BYPASS_MANAGER
> irq: bypass: Extend skeleton for ARM forwarding control
> KVM: create kvm_irqfd.h
> KVM: introduce kvm_arch functions for IRQ bypass
> KVM: eventfd: add irq bypass consumer management
>
> arch/arm/kvm/Kconfig | 1 +
> arch/arm64/kvm/Kconfig | 1 +
> drivers/vfio/platform/Kconfig | 1 +
> include/linux/irqbypass.h | 19 ++++++--
> include/linux/kvm_host.h | 37 ++++++++++++++
> include/linux/kvm_irqfd.h | 70 +++++++++++++++++++++++++++
> kernel/irq/bypass.c | 44 +++++++++++++++--
> virt/kvm/Kconfig | 3 ++
> virt/kvm/eventfd.c | 109 +++++++++++++-----------------------------
> 9 files changed, 203 insertions(+), 82 deletions(-)
> create mode 100644 include/linux/kvm_irqfd.h
>



--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/