[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20131213021402.GB14192@kroah.com>
Date: Thu, 12 Dec 2013 18:14:02 -0800
From: Greg KH <gregkh@...uxfoundation.org>
To: Grant Likely <grant.likely@...aro.org>
Cc: Hiroshi Doyu <hdoyu@...dia.com>,
Stephen Warren <swarren@...dotorg.org>, swarren@...dia.com,
will.deacon@....com, thierry.reding@...il.com,
robherring2@...il.com, joro@...tes.org, mark.rutland@....com,
devicetree@...r.kernel.org, lorenzo.pieralisi@....com,
linux-kernel@...r.kernel.org, iommu@...ts.linux-foundation.org,
galak@...eaurora.org, linux-tegra@...r.kernel.org,
linux-arm-kernel@...ts.infradead.org
Subject: Re: [PATCHv7 04/12] driver/core: populate devices in order for IOMMUs
On Thu, Dec 12, 2013 at 11:39:20AM +0000, Grant Likely wrote:
> On Thu, 12 Dec 2013 09:57:05 +0200, Hiroshi Doyu <hdoyu@...dia.com> wrote:
> > IOMMU devices on the bus need to be poplulated first, then iommu
> > master devices are done later.
> >
> > With CONFIG_OF_IOMMU, "iommus=" DT binding would be used to identify
> > whether a device can be an iommu msater or not. If a device can, we'll
> > defer to populate that device till an iommu device is populated. Then,
> > those deferred iommu master devices are populated and configured with
> > help of the already populated iommu device.
> >
> > Signed-off-by: Hiroshi Doyu <hdoyu@...dia.com>
> > Cc: Greg Kroah-Hartman <gregkh@...uxfoundation.org>
> > ---
> > This is related to the following discussion:
> > [RFC PATCH] Documentation: devicetree: add description for generic bus properties
> > http://lists.infradead.org/pipermail/linux-arm-kernel/2013-November/215042.html
> >
> > v6:
> > Spinned off only driver core part from:
> > [PATCHv5 2/9] driver/core: populate devices in order for IOMMUs
> >
> > v5:
> > Use "iommus=" binding instread of arm,smmu's "#stream-id-cells".
> >
> > v4:
> > This is newly added, and the successor of the following RFC:
> > [RFC][PATCHv3+ 1/2] driver/core: Add of_iommu_attach()
> > http://lists.linuxfoundation.org/pipermail/iommu/2013-November/006914.html
> >
> > Signed-off-by: Hiroshi Doyu <hdoyu@...dia.com>
> > ---
> > drivers/base/dd.c | 5 +++++
> > 1 file changed, 5 insertions(+)
> >
> > diff --git a/drivers/base/dd.c b/drivers/base/dd.c
> > index 0605176..0605f52 100644
> > --- a/drivers/base/dd.c
> > +++ b/drivers/base/dd.c
> > @@ -25,6 +25,7 @@
> > #include <linux/async.h>
> > #include <linux/pm_runtime.h>
> > #include <linux/pinctrl/devinfo.h>
> > +#include <linux/of_iommu.h>
> >
> > #include "base.h"
> > #include "power/power.h"
> > @@ -273,6 +274,10 @@ static int really_probe(struct device *dev, struct device_driver *drv)
> >
> > dev->driver = drv;
> >
> > + ret = of_iommu_attach(dev);
> > + if (ret)
> > + goto probe_failed;
> > +
>
> As discussed before, I really don't think hooking in to dd.c is the
> right thing to do here, and certainly not as a device tree specific
> function. ACPI or PCI described devices may have the same constraints
> and those won't have DT descriptions.
I agree, this shouldn't be in the driver core.
greg k-h
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists