[PATCH v7 1/9] iommu: Introduce a union to struct iommu_resv_region
Robin Murphy
robin.murphy at arm.com
Mon Oct 11 06:47:14 PDT 2021
On 2021-10-11 06:47, Shameerali Kolothum Thodi wrote:
>
>
>> -----Original Message-----
>> From: Jon Nettleton [mailto:jon at solid-run.com]
>> Sent: 09 October 2021 07:58
>> To: Robin Murphy <robin.murphy at arm.com>
>> Cc: Shameerali Kolothum Thodi <shameerali.kolothum.thodi at huawei.com>;
>> linux-arm-kernel <linux-arm-kernel at lists.infradead.org>; ACPI Devel Maling
>> List <linux-acpi at vger.kernel.org>; Linux IOMMU
>> <iommu at lists.linux-foundation.org>; Linuxarm <linuxarm at huawei.com>;
>> Steven Price <steven.price at arm.com>; Guohanjun (Hanjun Guo)
>> <guohanjun at huawei.com>; yangyicong <yangyicong at huawei.com>; Sami
>> Mujawar <Sami.Mujawar at arm.com>; Will Deacon <will at kernel.org>;
>> wanghuiqiang <wanghuiqiang at huawei.com>
>> Subject: Re: [PATCH v7 1/9] iommu: Introduce a union to struct
>> iommu_resv_region
>>
>> On Fri, Oct 8, 2021 at 2:14 PM Robin Murphy <robin.murphy at arm.com>
>> wrote:
>>>
>>> On 2021-08-05 09:07, Shameer Kolothum wrote:
>>>> A union is introduced to struct iommu_resv_region to hold any
>>>> firmware specific data. This is in preparation to add support for
>>>> IORT RMR reserve regions and the union now holds the RMR specific
>>>> information.
>>>>
>>>> Signed-off-by: Shameer Kolothum
>>>> <shameerali.kolothum.thodi at huawei.com>
>>>> ---
>>>> include/linux/iommu.h | 11 +++++++++++
>>>> 1 file changed, 11 insertions(+)
>>>>
>>>> diff --git a/include/linux/iommu.h b/include/linux/iommu.h index
>>>> 32d448050bf7..bd0e4641c569 100644
>>>> --- a/include/linux/iommu.h
>>>> +++ b/include/linux/iommu.h
>>>> @@ -114,6 +114,13 @@ enum iommu_resv_type {
>>>> IOMMU_RESV_SW_MSI,
>>>> };
>>>>
>>>> +struct iommu_iort_rmr_data {
>>>> +#define IOMMU_RMR_REMAP_PERMITTED (1 << 0)
>>>> + u32 flags;
>>>> + u32 sid; /* Stream Id associated with RMR entry */
>>>> + void *smmu; /* Associated IORT SMMU node pointer */
>>>> +};
>>>
>>> Do we really need to duplicate all this data? AFAICS we could just
>>> save the acpi_iort_rmr pointer in the iommu_resv_region (with a
>>> forward declaration here if necessary) and defer parsing its actual
>>> mappings until the point where we can directly consume the results.
>>
>> From earlier discussions on this patchset, the original goal was also for
>> device-tree mechanisms to be able to hook into this code to support similar
>> RMR's and SMMU initialization, just not through the ACPI / IORT path.
>
> Yes. IIRC, there were some earlier attempts to have DT support for reserved regions
> and there was a suggestion to provide generic interfaces so that when DT solution
> comes up it is easier to add the support.
OK, but in that case why is every single part of it IORT-specific in
either name, description or function?
Regardless, s/acpi_iort_rmr/original firmware descriptor of whatever
variety/ and my comment still stands. If a firmware-specific structure
is still going to exist to begin with, then what do we gain from
interpreting details earlier than needed and wasting memory storing
copies of them? This isn't something we're looking up hundreds of times
per second and need to cache in some more efficient format.
Furthermore, it seems unlikely that the eventual DT solution would end
up being semantically identical to IORT RMRs, so there's every
possibility that the One True Abstract Structure would need changing to
work for another firmware implementation anyway. Heck, it might not even
fit future IORT if it becomes permissible for multiple StreamIDs to
share a single RMR descriptor.
Thanks,
Robin.
More information about the linux-arm-kernel
mailing list