[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <54C8FC07.2050003@arm.com>
Date: Wed, 28 Jan 2015 15:11:03 +0000
From: Robin Murphy <robin.murphy@....com>
To: Will Deacon <will.deacon@....com>, Joerg Roedel <joro@...tes.org>
CC: "iommu@...ts.linux-foundation.org" <iommu@...ts.linux-foundation.org>,
Kukjin Kim <kgene@...nel.org>,
David Woodhouse <dwmw2@...radead.org>,
Heiko Stuebner <heiko@...ech.de>,
Hiroshi Doyu <hdoyu@...dia.com>,
Thierry Reding <thierry.reding@...il.com>,
Alex Williamson <alex.williamson@...hat.com>,
Arnd Bergmann <arnd@...db.de>,
"linux-kernel@...r.kernel.org" <linux-kernel@...r.kernel.org>,
Laurent Pinchart <laurent.pinchart@...asonboard.com>,
"jroedel@...e.de" <jroedel@...e.de>
Subject: Re: [PATCH 2/5] iommu: Allocate a default domain for iommu groups
On 28/01/15 14:30, Will Deacon wrote:
> On Tue, Jan 27, 2015 at 12:08:56AM +0000, Joerg Roedel wrote:
>> From: Joerg Roedel <jroedel@...e.de>
>>
>> The default domain will be used (if supported by the iommu
>> driver) when the devices in the iommu group are not attached
>> to any other domain.
>>
>> Signed-off-by: Joerg Roedel <jroedel@...e.de>
>> ---
>> drivers/iommu/iommu.c | 26 +++++++++++++++++++++++---
>> 1 file changed, 23 insertions(+), 3 deletions(-)
>>
>> diff --git a/drivers/iommu/iommu.c b/drivers/iommu/iommu.c
>> index 34636eb..8f33ddd3 100644
>> --- a/drivers/iommu/iommu.c
>> +++ b/drivers/iommu/iommu.c
>> @@ -76,6 +76,9 @@ struct iommu_group_attribute iommu_group_attr_##_name = \
>> #define to_iommu_group(_kobj) \
>> container_of(_kobj, struct iommu_group, kobj)
>>
>> +static struct iommu_domain *__iommu_domain_alloc(struct bus_type *bus,
>> + enum iommu_domain_type type);
>> +
>> static ssize_t iommu_group_attr_show(struct kobject *kobj,
>> struct attribute *__attr, char *buf)
>> {
>> @@ -362,6 +365,17 @@ rename:
>>
>> kobject_get(group->devices_kobj);
>>
>> + /*
>> + * Try to allocate a default domain for the group, if this
>> + * hasn't happened yet. This is not the best place to do that,
>> + * it should happen in iommu_group_alloc(). But we have no
>> + * iommu_ops there yet, so the allocation has to happen here for
>> + * now.
>> + */
>> + if (group->default_domain == NULL)
>> + group->default_domain = __iommu_domain_alloc(dev->bus,
>> + IOMMU_DOMAIN_DMA);
>
> Having a per-group domain is wasteful for IOMMUs that only support a modest
> number of concurrent domains, so in reality I think we need to have one
> domain per IOMMU instance. Is that possible?
Strictly speaking, it is, provided you can identify instances (I've
hacked up such a thing controlled from the DMA mapping side), but
there's a question of how to handle devices with differing DMA ranges.
The Intel IOVA allocator could actually handle them sharing one address
space, since you can perform individual allocations with different
constraints, but I'm not sure if that really makes sense. Perhaps one
domain per dma-ranges variation per instance?
> One problem with the current per-bus approach is that __iommu_domain_alloc
> can't figure out which IOMMU instance corresponds to the group.
Indeed - I think it might make sense to pass devices around instead of
buses, and for now stick in an abstraction like:
static const struct iommu_ops *get_iommu_for_dev(struct device *dev)
{
return dev->bus->iommu_ops;
}
in which we can then later hook up some sort of of_iommu_get_ops-based
lookup for non-PCI devices. Which ends up more or less looking like
Thierry's original idea, but kept private to the IOMMU API internals.
Robin.
--
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