[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <c7dd8ac53170cafab5489f98d3da13f65cd67a1a.camel@pengutronix.de>
Date: Fri, 20 Jun 2025 22:45:41 +0200
From: Lucas Stach <l.stach@...gutronix.de>
To: Robin Murphy <robin.murphy@....com>, Benjamin Gaignard
<benjamin.gaignard@...labora.com>, joro@...tes.org, will@...nel.org,
robh@...nel.org, krzk+dt@...nel.org, conor+dt@...nel.org, heiko@...ech.de,
nicolas.dufresne@...labora.com, jgg@...pe.ca
Cc: iommu@...ts.linux.dev, devicetree@...r.kernel.org,
linux-kernel@...r.kernel.org, linux-arm-kernel@...ts.infradead.org,
linux-rockchip@...ts.infradead.org, kernel@...labora.com
Subject: Re: [PATCH v3 3/5] iommu: Add verisilicon IOMMU driver
Am Freitag, dem 20.06.2025 um 20:37 +0100 schrieb Robin Murphy:
> On 19/06/2025 2:12 pm, Benjamin Gaignard wrote:
> > The Verisilicon IOMMU hardware block can be found in combination
> > with Verisilicon hardware video codecs (encoders or decoders) on
> > different SoCs.
> > Enable it will allow us to use non contiguous memory allocators
> > for Verisilicon video codecs.
> >
> > Signed-off-by: Benjamin Gaignard <benjamin.gaignard@...labora.com>
> > ---
>
[...]
> I'm especially curious what this "pta" really is - is the comment above
> just wrong, and you've actually got a 3-level pagetable supporting
> somewhere between 33 and 42 bits of VA? If not, then the additional
> level of indirection would very much seem to imply some kind of
> mechanism for accommodating multiple pagetables at once, and in that
> case, is it like a PASID table where the client device gets to choose
> which entry to use, or a StreamID table to disambiguate multiple client
> devices? (Where in the latter case it should most likely belong to the
> IOMMU rather than the domain, and you probably want nonzero #iommu-cells
> in the DT binding for the client IDs).
>
PTA is short for page table array and it's another level of indirection
to select the page tables to be used for the specific translation. On
the Vivante GPU, where this MMU IP originated, the GPU can select the
index into this array to be used for a specific command stream to
implement GPU client isolation, so it's much like a PASID table.
I have no idea if and how the integration with the video codecs can
select the PTA index.
Regards,
Lucas
Powered by blists - more mailing lists