Linux IOMMU Development
 help / color / mirror / Atom feed
From: Alex Williamson <alex.williamson-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
To: Antonios Motakis
	<a.motakis-lrHrjnjw1UfHK3s98zE1ajGjJy/sRE9J@public.gmane.org>
Cc: Eric Auger <eric.auger-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org>,
	Marc Zyngier <marc.zyngier-5wv7dgnIgG8@public.gmane.org>,
	Will Deacon <will.deacon-5wv7dgnIgG8@public.gmane.org>,
	Linux IOMMU
	<iommu-cunTk1MwBs9QetFLy7KEm3xJsTq8ys+cHZ5vskTnxNA@public.gmane.org>,
	VirtualOpenSystems Technical Team
	<tech-lrHrjnjw1UfHK3s98zE1ajGjJy/sRE9J@public.gmane.org>,
	kvm-arm
	<kvmarm-FPEHb7Xf0XXUo1n7N8X6UoWGPAHP3yOg@public.gmane.org>,
	Christoffer Dall
	<christoffer.dall-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org>
Subject: Re: [PATCH v10 00/20] VFIO support for platform and ARM AMBA devices
Date: Tue, 09 Dec 2014 08:08:17 -0700	[thread overview]
Message-ID: <1418137697.1095.126.camel@bling.home> (raw)
In-Reply-To: <CAG8rG2wB9KtjYGEL91TDS9AiKFHjPHJKjqyRPJj7wqKP6c+Knw-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>

On Tue, 2014-12-09 at 15:24 +0100, Antonios Motakis wrote:
> On Sun, Dec 7, 2014 at 8:12 PM, Alex Williamson
> <alex.williamson-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org> wrote:
> >
> > On Thu, 2014-11-27 at 18:32 +0100, Antonios Motakis wrote:
> > > This patch series aims to implement VFIO support for platform devices that
> > > reside behind an IOMMU. Examples of such devices are devices behind an ARM
> > > SMMU, or behind a Samsung Exynos System MMU.
> > >
> > > The API used is based on the existing VFIO API that is also used with PCI
> > > devices. Only devices that include a basic set of IRQs and memory regions are
> > > targeted; devices with complex relationships with other devices on a device
> > > tree are not taken into account at this stage.
> > >
> > > This patch series may be applied on the following series/patches:
> > >  - [PATCH] driver core: amba: add device binding path 'driver_override'
> > >  - [PATCH v3 0/6] vfio: type1: support for ARM SMMUS with VFIO_IOMMU_TYPE1
> > >
> > > A copy can be cloned from the branch vfio-platform-v10 at:
> > > git-9UaJU3cA/F/QT0dZR+AlfA@public.gmane.org:virtualopensystems/linux-kvm-arm.git
> >
> > Hi Antonios,
> >
> > Sorry for the delay in reviewing.  Between this and your v3 0/6 series,
> > the only nits I have are:
> >
> >       * 2/6 is unneeded, Will already provided a patch to enable type1
> >         on ARM that's currently in -next.  That patch is easily dropped
> >         with no modification to the series, no need to resend.
> >       * 04/20 has a kasprintf() with unchecked return value.
> >
> > If you want to just send a new 04/20 with that trivial fix, that'd be
> > fine.  Looks like I'll need to wait until Joerg's next branch pull is
> > accepted before I can merge these in.  Thanks,
> 
> Done. However if I'm not missing something, it seems this would still
> be blocked by the patch "driver core: amba: add device binding path
> 'driver_override'" (at least the AMBA part).

If you want to wait for that to be accepted, it's fine by me.  Thanks,

Alex

> > > Changes since v9:
> > >  - Reworked the splitting of the patches that decouple virqfd from PCI
> > >  - Some styling issues and typos
> > >  - Removed superfluous includes
> > >  - AMBA devices are now named vfio-amba- suffixed by the AMBA device id
> > >  - Several other cleanups and fixes
> > > Changes since v8:
> > >  - Separate irq handler for edge and level triggered interrupts
> > >  - Mutex based lock for VFIO fd open/release
> > >  - Fixed bug where the first region of a platform device wasn't exposed
> > >  - Read only regions can be MMAPed only read only
> > >  - Code cleanups
> > > Changes since v7:
> > >  - Some initial placeholder functionality for PIO resources
> > >  - Cleaned up code for IRQ triggering, masking and unmasking
> > >  - Some functionality has been removed from this series and posted separately:
> > >    - VFIO_IOMMU_TYPE1 support for ARM SMMUs
> > >    - IOMMU NOEXEC patches
> > >    - driver_override functionality for AMBA devices
> > >  - Several fixes
> > > Changes since v6:
> > >  - Integrated support for AMBA devices
> > >  - Numerous cleanups and fixes
> > > Changes since v5:
> > >  - Full eventfd support for IRQ masking and unmasking.
> > >  - Changed IOMMU_EXEC to IOMMU_NOEXEC, along with related flags in VFIO.
> > >  - Other fixes based on reviewer comments.
> > > Changes since v4:
> > >  - Use static offsets for each region in the VFIO device fd
> > >  - Include patch in the series for the ARM SMMU to expose IOMMU_EXEC
> > >    availability via IOMMU_CAP_DMA_EXEC
> > >  - Rebased on VFIO multi domain support:
> > >    - IOMMU_EXEC is now available if at least one IOMMU in the container
> > >      supports it
> > >    - Expose IOMMU_EXEC if available via the capability VFIO_IOMMU_PROT_EXEC
> > >  - Some bug fixes
> > > Changes since v3:
> > >  - Use Kim Phillips' driver_probe_device()
> > > Changes since v2:
> > >  - Fixed Read/Write and MMAP on device regions
> > >  - Removed dependency on Device Tree
> > >  - Interrupts support
> > >  - Interrupt masking/unmasking
> > >  - Automask level sensitive interrupts
> > >  - Introduced VFIO_DMA_MAP_FLAG_EXEC
> > >  - Code clean ups
> > >
> > > Antonios Motakis (20):
> > >   vfio/platform: initial skeleton of VFIO support for platform devices
> > >   vfio: platform: probe to devices on the platform bus
> > >   vfio: platform: add the VFIO PLATFORM module to Kconfig
> > >   vfio: amba: VFIO support for AMBA devices
> > >   vfio: amba: add the VFIO for AMBA devices module to Kconfig
> > >   vfio/platform: return info for bound device
> > >   vfio/platform: return info for device memory mapped IO regions
> > >   vfio/platform: read and write support for the device fd
> > >   vfio/platform: support MMAP of MMIO regions
> > >   vfio/platform: return IRQ info
> > >   vfio/platform: initial interrupts support code
> > >   vfio/platform: trigger an interrupt via eventfd
> > >   vfio/platform: support for level sensitive interrupts
> > >   vfio: add a vfio_ prefix to virqfd_enable and virqfd_disable and
> > >     export
> > >   vfio: virqfd: rename vfio_pci_virqfd_init and vfio_pci_virqfd_exit
> > >   vfio: add local lock for virqfd instead of depending on VFIO PCI
> > >   vfio: pass an opaque pointer on virqfd initialization
> > >   vfio: move eventfd support code for VFIO_PCI to a separate file
> > >   vfio: initialize the virqfd workqueue in VFIO generic code
> > >   vfio/platform: implement IRQ masking/unmasking via an eventfd
> > >
> > >  drivers/vfio/Kconfig                          |   1 +
> > >  drivers/vfio/Makefile                         |   5 +-
> > >  drivers/vfio/pci/vfio_pci.c                   |   8 -
> > >  drivers/vfio/pci/vfio_pci_intrs.c             | 238 +-----------
> > >  drivers/vfio/pci/vfio_pci_private.h           |   3 -
> > >  drivers/vfio/platform/Kconfig                 |  19 +
> > >  drivers/vfio/platform/Makefile                |   8 +
> > >  drivers/vfio/platform/vfio_amba.c             | 110 ++++++
> > >  drivers/vfio/platform/vfio_platform.c         | 103 +++++
> > >  drivers/vfio/platform/vfio_platform_common.c  | 520 ++++++++++++++++++++++++++
> > >  drivers/vfio/platform/vfio_platform_irq.c     | 331 ++++++++++++++++
> > >  drivers/vfio/platform/vfio_platform_private.h |  82 ++++
> > >  drivers/vfio/vfio.c                           |   8 +
> > >  drivers/vfio/virqfd.c                         | 213 +++++++++++
> > >  include/linux/vfio.h                          |  27 ++
> > >  include/uapi/linux/vfio.h                     |   2 +
> > >  16 files changed, 1442 insertions(+), 236 deletions(-)
> > >  create mode 100644 drivers/vfio/platform/Kconfig
> > >  create mode 100644 drivers/vfio/platform/Makefile
> > >  create mode 100644 drivers/vfio/platform/vfio_amba.c
> > >  create mode 100644 drivers/vfio/platform/vfio_platform.c
> > >  create mode 100644 drivers/vfio/platform/vfio_platform_common.c
> > >  create mode 100644 drivers/vfio/platform/vfio_platform_irq.c
> > >  create mode 100644 drivers/vfio/platform/vfio_platform_private.h
> > >  create mode 100644 drivers/vfio/virqfd.c
> > >
> >
> >
> >

  parent reply	other threads:[~2014-12-09 15:08 UTC|newest]

Thread overview: 29+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2014-11-27 17:32 [PATCH v10 00/20] VFIO support for platform and ARM AMBA devices Antonios Motakis
     [not found] ` <1417109580-10505-1-git-send-email-a.motakis-lrHrjnjw1UfHK3s98zE1ajGjJy/sRE9J@public.gmane.org>
2014-11-27 17:32   ` [PATCH v10 01/20] vfio/platform: initial skeleton of VFIO support for platform devices Antonios Motakis
2014-11-27 17:32   ` [PATCH v10 02/20] vfio: platform: probe to devices on the platform bus Antonios Motakis
2014-11-27 17:32   ` [PATCH v10 03/20] vfio: platform: add the VFIO PLATFORM module to Kconfig Antonios Motakis
2014-11-27 17:32   ` [PATCH v10 04/20] vfio: amba: VFIO support for AMBA devices Antonios Motakis
     [not found]     ` <1417109580-10505-5-git-send-email-a.motakis-lrHrjnjw1UfHK3s98zE1ajGjJy/sRE9J@public.gmane.org>
2014-12-09 14:18       ` Antonios Motakis
2014-11-27 17:32   ` [PATCH v10 05/20] vfio: amba: add the VFIO for AMBA devices module to Kconfig Antonios Motakis
2014-11-27 17:32   ` [PATCH v10 06/20] vfio/platform: return info for bound device Antonios Motakis
2014-11-27 17:32   ` [PATCH v10 07/20] vfio/platform: return info for device memory mapped IO regions Antonios Motakis
2014-11-27 17:32   ` [PATCH v10 08/20] vfio/platform: read and write support for the device fd Antonios Motakis
2014-11-27 17:32   ` [PATCH v10 09/20] vfio/platform: support MMAP of MMIO regions Antonios Motakis
2014-11-27 17:32   ` [PATCH v10 10/20] vfio/platform: return IRQ info Antonios Motakis
2014-11-27 17:32   ` [PATCH v10 11/20] vfio/platform: initial interrupts support code Antonios Motakis
2014-11-27 17:32   ` [PATCH v10 12/20] vfio/platform: trigger an interrupt via eventfd Antonios Motakis
2014-11-27 17:32   ` [PATCH v10 13/20] vfio/platform: support for level sensitive interrupts Antonios Motakis
2014-11-27 17:32   ` [PATCH v10 14/20] vfio: add a vfio_ prefix to virqfd_enable and virqfd_disable and export Antonios Motakis
2014-11-27 17:32   ` [PATCH v10 15/20] vfio: virqfd: rename vfio_pci_virqfd_init and vfio_pci_virqfd_exit Antonios Motakis
2014-11-27 17:32   ` [PATCH v10 16/20] vfio: add local lock for virqfd instead of depending on VFIO PCI Antonios Motakis
2014-11-27 17:32   ` [PATCH v10 17/20] vfio: pass an opaque pointer on virqfd initialization Antonios Motakis
2014-11-27 17:32   ` [PATCH v10 18/20] vfio: move eventfd support code for VFIO_PCI to a separate file Antonios Motakis
2014-11-27 17:32   ` [PATCH v10 19/20] vfio: initialize the virqfd workqueue in VFIO generic code Antonios Motakis
2014-11-27 17:33   ` [PATCH v10 20/20] vfio/platform: implement IRQ masking/unmasking via an eventfd Antonios Motakis
2014-11-28 18:05   ` [PATCH v10 00/20] VFIO support for platform and ARM AMBA devices Eric Auger
     [not found]     ` <5478B963.5050707-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org>
2014-12-01 12:45       ` Antonios Motakis
     [not found]         ` <CAG8rG2wAt-wa26wBPA+2stb+Xn=B52thd8osRHWQm9WeQZbO1Q-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2014-12-01 14:29           ` Eric Auger
2014-12-07 19:12   ` Alex Williamson
     [not found]     ` <1417979565.1095.22.camel-xdHQ/5r00wBBDLzU/O5InQ@public.gmane.org>
2014-12-09 14:24       ` Antonios Motakis
     [not found]         ` <CAG8rG2wB9KtjYGEL91TDS9AiKFHjPHJKjqyRPJj7wqKP6c+Knw-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2014-12-09 15:08           ` Alex Williamson [this message]
     [not found]             ` <1418137697.1095.126.camel-xdHQ/5r00wBBDLzU/O5InQ@public.gmane.org>
2014-12-10 14:00               ` Antonios Motakis

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1418137697.1095.126.camel@bling.home \
    --to=alex.williamson-h+wxahxf7alqt0dzr+alfa@public.gmane.org \
    --cc=a.motakis-lrHrjnjw1UfHK3s98zE1ajGjJy/sRE9J@public.gmane.org \
    --cc=christoffer.dall-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org \
    --cc=eric.auger-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org \
    --cc=iommu-cunTk1MwBs9QetFLy7KEm3xJsTq8ys+cHZ5vskTnxNA@public.gmane.org \
    --cc=kvmarm-FPEHb7Xf0XXUo1n7N8X6UoWGPAHP3yOg@public.gmane.org \
    --cc=marc.zyngier-5wv7dgnIgG8@public.gmane.org \
    --cc=tech-lrHrjnjw1UfHK3s98zE1ajGjJy/sRE9J@public.gmane.org \
    --cc=will.deacon-5wv7dgnIgG8@public.gmane.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox