From: Alex Williamson <alex.williamson-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
To: Antonios Motakis
<a.motakis-lrHrjnjw1UfHK3s98zE1ajGjJy/sRE9J@public.gmane.org>
Cc: "open list:VFIO DRIVER"
<kvm-u79uwXL29TY76Z2rM5mHXA@public.gmane.org>,
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>,
open list <linux-kernel-u79uwXL29TY76Z2rM5mHXA@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 v8 07/18] vfio/platform: return info for device memory mapped IO regions
Date: Wed, 22 Oct 2014 10:46:29 -0600 [thread overview]
Message-ID: <1413996389.4202.218.camel@ul30vt.home> (raw)
In-Reply-To: <CAG8rG2yiqBk2Y+b0WvcZGypNj3XhGDNet-GM3yOYaLiHc4pU=w@mail.gmail.com>
On Wed, 2014-10-22 at 15:54 +0200, Antonios Motakis wrote:
> On Tue, Oct 21, 2014 at 6:34 PM, Alex Williamson
> <alex.williamson-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org> wrote:
> > On Mon, 2014-10-13 at 15:10 +0200, Antonios Motakis wrote:
> >> This patch enables the IOCTLs VFIO_DEVICE_GET_REGION_INFO ioctl call,
> >> which allows the user to learn about the available MMIO resources of
> >> a device.
> >>
> >> Signed-off-by: Antonios Motakis <a.motakis-lrHrjnjw1UfHK3s98zE1ajGjJy/sRE9J@public.gmane.org>
> >> ---
> >> drivers/vfio/platform/vfio_platform_common.c | 93 +++++++++++++++++++++++++--
> >> drivers/vfio/platform/vfio_platform_private.h | 22 +++++++
> >> 2 files changed, 111 insertions(+), 4 deletions(-)
> >>
> >> diff --git a/drivers/vfio/platform/vfio_platform_common.c b/drivers/vfio/platform/vfio_platform_common.c
> >> index 1e4073f..8a7e474 100644
> >> --- a/drivers/vfio/platform/vfio_platform_common.c
> >> +++ b/drivers/vfio/platform/vfio_platform_common.c
> >> @@ -27,17 +27,84 @@
> >>
> >> #include "vfio_platform_private.h"
> >>
> >> +static int vfio_platform_regions_init(struct vfio_platform_device *vdev)
> >> +{
> >> + int cnt = 0, i;
> >> +
> >> + while (vdev->get_resource(vdev, cnt))
> >> + cnt++;
> >> +
> >> + vdev->regions = kcalloc(cnt, sizeof(struct vfio_platform_region),
> >> + GFP_KERNEL);
> >> + if (!vdev->regions)
> >> + return -ENOMEM;
> >> +
> >> + for (i = 0; i < cnt; i++) {
> >> + struct resource *res =
> >> + vdev->get_resource(vdev, i);
> >> +
> >> + if (!res)
> >> + goto err;
> >> +
> >> + vdev->regions[i].addr = res->start;
> >> + vdev->regions[i].size = resource_size(res);
> >> + vdev->regions[i].flags = 0;
> >> +
> >> + switch (resource_type(res)) {
> >> + case IORESOURCE_MEM:
> >> + vdev->regions[i].type = VFIO_PLATFORM_REGION_TYPE_MMIO;
> >> + break;
> >> + case IORESOURCE_IO:
> >> + vdev->regions[i].type = VFIO_PLATFORM_REGION_TYPE_PIO;
> >> + break;
> >
> > Ok, we have support for PIO in platform now (thanks!), does the user
> > know what type of region they're dealing with? Do they care? For PCI
> > the user tests the PCI BAR in config space to determine which type it
> > is. I'm guessing that platform would do something similar against the
> > device tree or ACPI, right?
>
> Maybe is worthwhile to add an explicit flag in
> VFIO_DEVICE_GET_REGION_INFO for PIO regions. For platform devices I
> don't know if we can always rely on DT or ACPI info to be available.
> For VFIO PCI the BAR is always implemented, and while I have proposed
> an RFC to return DT information, I don't think we can assume how a
> device is described in the host, whether DT, ACPI, or dark magic.
Is this already handled by the fact that vfio-platform is not meant to
be a generic meta driver to the same extent as vfio-pci? There is no
self-describing config space on platform devices like there is on PCI,
so the user will need to know in advance somehow what the device is and
what resources/irqs it uses. We do need to make sure though that we
provide a userspace ABI that allows them to match VFIO indexes to the
device in a predictable way. It's not fully clear to me how that works.
Thanks,
Alex
next prev parent reply other threads:[~2014-10-22 16:46 UTC|newest]
Thread overview: 35+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-10-13 13:10 [PATCH v8 00/18] VFIO support for platform and AMBA devices on ARM Antonios Motakis
[not found] ` <1413205825-6370-1-git-send-email-a.motakis-lrHrjnjw1UfHK3s98zE1ajGjJy/sRE9J@public.gmane.org>
2014-10-13 13:10 ` [PATCH v8 01/18] vfio/platform: initial skeleton of VFIO support for platform devices Antonios Motakis
2014-10-13 13:10 ` [PATCH v8 02/18] vfio: platform: probe to devices on the platform bus Antonios Motakis
[not found] ` <1413205825-6370-3-git-send-email-a.motakis-lrHrjnjw1UfHK3s98zE1ajGjJy/sRE9J@public.gmane.org>
2014-10-21 16:17 ` Alex Williamson
[not found] ` <1413908269.4202.135.camel-85EaTFmN5p//9pzu0YdTqQ@public.gmane.org>
2014-10-21 16:37 ` Eric Auger
[not found] ` <54468BDA.6050606-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org>
2014-10-22 13:53 ` Antonios Motakis
2014-10-13 13:10 ` [PATCH v8 03/18] vfio: platform: add the VFIO PLATFORM module to Kconfig Antonios Motakis
2014-10-13 13:10 ` [PATCH v8 04/18] vfio: amba: VFIO support for AMBA devices Antonios Motakis
2014-10-13 13:10 ` [PATCH v8 05/18] vfio: amba: add the VFIO for AMBA devices module to Kconfig Antonios Motakis
2014-10-13 13:10 ` [PATCH v8 06/18] vfio/platform: return info for bound device Antonios Motakis
2014-10-13 13:10 ` [PATCH v8 07/18] vfio/platform: return info for device memory mapped IO regions Antonios Motakis
[not found] ` <1413205825-6370-8-git-send-email-a.motakis-lrHrjnjw1UfHK3s98zE1ajGjJy/sRE9J@public.gmane.org>
2014-10-21 16:34 ` Alex Williamson
[not found] ` <1413909282.4202.141.camel-85EaTFmN5p//9pzu0YdTqQ@public.gmane.org>
2014-10-21 18:18 ` Bharat.Bhushan-KZfg59tc24xl57MIdRCFDg
[not found] ` <e1fd19d05dd04b9ab5d65a495b5fabad-GeMU99Gfrru4FpqPz9FowuO6mTEJWrR4XA4E9RH9d+qIuWR1G4zioA@public.gmane.org>
2014-10-21 18:57 ` Alex Williamson
2014-10-22 13:54 ` Antonios Motakis
2014-10-22 16:46 ` Alex Williamson [this message]
[not found] ` <1413996389.4202.218.camel-85EaTFmN5p//9pzu0YdTqQ@public.gmane.org>
2014-10-22 17:53 ` Antonios Motakis
2014-10-13 13:10 ` [PATCH v8 08/18] vfio/platform: read and write support for the device fd Antonios Motakis
2014-10-13 13:10 ` [PATCH v8 09/18] vfio/platform: support MMAP of MMIO regions Antonios Motakis
[not found] ` <1413205825-6370-10-git-send-email-a.motakis-lrHrjnjw1UfHK3s98zE1ajGjJy/sRE9J@public.gmane.org>
2014-10-21 16:51 ` Alex Williamson
[not found] ` <1413910307.4202.148.camel-85EaTFmN5p//9pzu0YdTqQ@public.gmane.org>
2014-10-22 13:55 ` Antonios Motakis
[not found] ` <CAG8rG2yUmpzzfEYVqA0H+5LcBcLjFY=j43t420Sa7FLnfmG8Ug-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2014-10-22 16:56 ` Alex Williamson
2014-10-13 13:10 ` [PATCH v8 10/18] vfio/platform: return IRQ info Antonios Motakis
2014-10-13 13:10 ` [PATCH v8 11/18] vfio/platform: initial interrupts support code Antonios Motakis
2014-10-13 13:10 ` [PATCH v8 12/18] vfio/platform: trigger an interrupt via eventfd Antonios Motakis
2014-10-13 13:10 ` [PATCH v8 13/18] vfio/platform: support for maskable and automasked interrupts Antonios Motakis
[not found] ` <1413205825-6370-14-git-send-email-a.motakis-lrHrjnjw1UfHK3s98zE1ajGjJy/sRE9J@public.gmane.org>
2014-10-21 17:47 ` Alex Williamson
[not found] ` <1413913638.4202.153.camel-85EaTFmN5p//9pzu0YdTqQ@public.gmane.org>
2014-10-22 13:55 ` Antonios Motakis
2014-10-13 13:10 ` [PATCH v8 14/18] vfio: move eventfd support code for VFIO_PCI to a separate file Antonios Motakis
[not found] ` <1413205825-6370-15-git-send-email-a.motakis-lrHrjnjw1UfHK3s98zE1ajGjJy/sRE9J@public.gmane.org>
2014-10-21 17:55 ` Alex Williamson
[not found] ` <1413914126.4202.157.camel-85EaTFmN5p//9pzu0YdTqQ@public.gmane.org>
2014-10-22 13:56 ` Antonios Motakis
2014-10-13 13:10 ` [PATCH v8 15/18] vfio: add local lock in virqfd instead of depending on VFIO PCI Antonios Motakis
2014-10-13 13:10 ` [PATCH v8 16/18] vfio: pass an opaque pointer on virqfd initialization Antonios Motakis
2014-10-13 13:10 ` [PATCH v8 17/18] vfio: initialize the virqfd workqueue in VFIO generic code Antonios Motakis
2014-10-13 13:10 ` [PATCH v8 18/18] vfio/platform: implement IRQ masking/unmasking via an eventfd 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=1413996389.4202.218.camel@ul30vt.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=kvm-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
--cc=kvmarm-FPEHb7Xf0XXUo1n7N8X6UoWGPAHP3yOg@public.gmane.org \
--cc=linux-kernel-u79uwXL29TY76Z2rM5mHXA@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;
as well as URLs for NNTP newsgroup(s).