From: Greg KH <gregkh@linuxfoundation.org>
To: Alex Williamson <alex.williamson@redhat.com>
Cc: stuart.yoder@freescale.com, kvm@vger.kernel.org,
jan.kiszka@siemens.com, will.deacon@arm.com,
linux-kernel@vger.kernel.org, mhocko@suse.cz,
bhelgaas@google.com, Varun.Sethi@freescale.com,
kvmarm@lists.cs.columbia.edu, rafael.j.wysocki@intel.com,
agraf@suse.de, linux-pci@vger.kernel.org, linux@roeck-us.net,
konrad.wilk@oracle.com, d.kasatkin@samsung.com, tj@kernel.org,
scottwood@freescale.com, a.motakis@virtualopensystems.com,
tech@virtualopensystems.com, Bharat.Bhushan@freescale.com,
toshi.kani@hp.com, kim.phillips@linaro.org,
a.rigo@virtualopensystems.com, iommu@lists.linux-foundation.org,
joe@perches.com, christoffer.dall@linaro.org
Subject: Re: [RFC PATCH] PCI: Introduce new device binding path using pci_dev.driver_override
Date: Tue, 1 Apr 2014 09:47:25 -0700 [thread overview]
Message-ID: <20140401164725.GA4649@kroah.com> (raw)
In-Reply-To: <20140401161851.18815.31108.stgit@bling.home>
On Tue, Apr 01, 2014 at 10:28:54AM -0600, Alex Williamson wrote:
> The driver_override field allows us to specify the driver for a device
> rather than relying on the driver to provide a positive match of the
> device. This shortcuts the existing process of looking up the vendor
> and device ID, adding them to the driver new_id, binding the device,
> then removing the ID, but it also provides a couple advantages.
>
> First, the above process allows the driver to bind to any device
> matching the new_id for the window where it's enabled. This is often
> not desired, such as the case of trying to bind a single device to a
> meta driver like pci-stub or vfio-pci. Using driver_override we can
> do this deterministically using:
>
> echo pci-stub > /sys/bus/pci/devices/0000:03:00.0/driver_override
> echo 0000:03:00.0 > /sys/bus/pci/devices/0000:03:00.0/driver/unbind
> echo 0000:03:00.0 > /sys/bus/pci/drivers_probe
>
> Previously we could not invoke drivers_probe after adding a device
> to new_id for a driver as we get non-deterministic behavior whether
> the driver we intend or the standard driver will claim the device.
> Now it becomes a deterministic process, only the driver matching
> driver_override will probe the device.
>
> To return the device to the standard driver, we simply clear the
> driver_override and reprobe the device, ex:
>
> echo > /sys/bus/pci/devices/0000:03:00.0/preferred_driver
> echo 0000:03:00.0 > /sys/bus/pci/devices/0000:03:00.0/driver/unbind
> echo 0000:03:00.0 > /sys/bus/pci/drivers_probe
>
> Another advantage to this approach is that we can specify a driver
> override to force a specific binding or prevent any binding. For
> instance when an IOMMU group is exposed to userspace through VFIO
> we require that all devices within that group are owned by VFIO.
> However, devices can be hot-added into an IOMMU group, in which case
> we want to prevent the device from binding to any driver (preferred
> driver = "none") or perhaps have it automatically bind to vfio-pci.
> With driver_override it's a simple matter for this field to be set
> internally when the device is first discovered to prevent driver
> matches.
>
> Signed-off-by: Alex Williamson <alex.williamson@redhat.com>
> ---
>
> Apologies for the exceptionally long cc list, this is a follow-up to
> Stuart's "Subject: mechanism to allow a driver to bind to any device"
> thread. This is effectively a v2 of the proof-of-concept patch I
> posted in that thread. This version changes to use a dummy id struct
> to return on an "override" match, which removes the collateral damage
> and greatly simplifies the patch. This feels fairly well baked for
> PCI and I would expect that platform drivers could do a similar
> implementation. From there perhaps we can discuss whether there's
> any advantage to placing driver_override on struct device. The logic
> for incorporating it into the match still needs to happen per bus
> driver, so it might only contribute to consistency of the show/store
> sysfs attributes to move it up to struct device. Please comment.
> Thanks,
>
> Alex
>
> drivers/pci/pci-driver.c | 25 ++++++++++++++++++++++---
> drivers/pci/pci-sysfs.c | 40 ++++++++++++++++++++++++++++++++++++++++
> include/linux/pci.h | 1 +
> 3 files changed, 63 insertions(+), 3 deletions(-)
No Documentation/ABI/ update to reflect the ABI you are creating?
thanks,
greg k-h
next prev parent reply other threads:[~2014-04-01 16:47 UTC|newest]
Thread overview: 19+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-04-01 16:28 [RFC PATCH] PCI: Introduce new device binding path using pci_dev.driver_override Alex Williamson
2014-04-01 16:28 ` Alex Williamson
2014-04-01 16:47 ` Greg KH [this message]
[not found] ` <20140401164725.GA4649-U8xfFu+wG4EAvxtiuMwx3w@public.gmane.org>
2014-04-01 17:15 ` Alex Williamson
2014-04-01 17:15 ` Alex Williamson
2014-04-02 0:39 ` Christoffer Dall
2014-04-01 23:52 ` Kim Phillips
2014-04-02 0:23 ` Greg KH
2014-04-02 22:06 ` Kim Phillips
2014-04-02 23:02 ` Alex Williamson
2014-04-05 1:35 ` Kim Phillips
2014-04-05 1:35 ` Kim Phillips
2014-04-05 2:07 ` Guenter Roeck
[not found] ` <20140401161851.18815.31108.stgit-xdHQ/5r00wBBDLzU/O5InQ@public.gmane.org>
2014-04-10 20:52 ` Stuart Yoder
2014-04-10 20:52 ` Stuart Yoder
[not found] ` <9b087b78bf9e41628cca2bd9e6f6a1c2-ufbTtyGzTTT8GZusEWM6WuO6mTEJWrR4XA4E9RH9d+qIuWR1G4zioA@public.gmane.org>
2014-04-10 21:15 ` Alex Williamson
2014-04-10 21:15 ` Alex Williamson
[not found] ` <1397164516.3142.51.camel-85EaTFmN5p//9pzu0YdTqQ@public.gmane.org>
2014-04-10 22:16 ` Alex Williamson
2014-04-10 22:16 ` Alex Williamson
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=20140401164725.GA4649@kroah.com \
--to=gregkh@linuxfoundation.org \
--cc=Bharat.Bhushan@freescale.com \
--cc=Varun.Sethi@freescale.com \
--cc=a.motakis@virtualopensystems.com \
--cc=a.rigo@virtualopensystems.com \
--cc=agraf@suse.de \
--cc=alex.williamson@redhat.com \
--cc=bhelgaas@google.com \
--cc=christoffer.dall@linaro.org \
--cc=d.kasatkin@samsung.com \
--cc=iommu@lists.linux-foundation.org \
--cc=jan.kiszka@siemens.com \
--cc=joe@perches.com \
--cc=kim.phillips@linaro.org \
--cc=konrad.wilk@oracle.com \
--cc=kvm@vger.kernel.org \
--cc=kvmarm@lists.cs.columbia.edu \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-pci@vger.kernel.org \
--cc=linux@roeck-us.net \
--cc=mhocko@suse.cz \
--cc=rafael.j.wysocki@intel.com \
--cc=scottwood@freescale.com \
--cc=stuart.yoder@freescale.com \
--cc=tech@virtualopensystems.com \
--cc=tj@kernel.org \
--cc=toshi.kani@hp.com \
--cc=will.deacon@arm.com \
/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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.