[PATCH v2 0/2] iommu: Allow passing custom allocators to pgtable drivers
Robin Murphy
robin.murphy at arm.com
Wed Nov 22 09:23:34 PST 2023
On 2023-11-20 3:45 pm, Jason Gunthorpe wrote:
> On Mon, Nov 20, 2023 at 04:14:18PM +0100, Boris Brezillon wrote:
>> On Mon, 20 Nov 2023 10:46:04 -0400
>> Jason Gunthorpe <jgg at ziepe.ca> wrote:
>>
>>> On Mon, Nov 20, 2023 at 03:38:38PM +0100, Boris Brezillon wrote:
>>>
>>>>> At LPC there was quite a lot if interest in improving the io page
>>>>> table stuff to work better. Based on that I'm even more against adding
>>>>> an external allocator at this time. :\
>>>>
>>>> I'm sure this has been discussed with the IOMMU maintainers, but I'd
>>>> really like to hear it from them if you don't mind. Especially since,
>>>> as I mentioned, the custom allocator idea comes from Robin, not me...
>>>
>>> It is a community effort - this is my opinion. We now understand this
>>> io page table area needs a lot of work to meet all the new needs. I'm
>>> against hacking it up like this and making that work harder.
>>
>> Consider it a hack if you like, but the thing is pretty self-contained,
>> and I doubt it will get to a point where things become unmaintainable
>> before you get the generic caching system working. Not to mention
>> Gaurav's use case, which can't really be solved with your caching
>> solution.
>
> Gaurav doesn't need a custom allocator, he needs a way to manage
> sharing page table memory with the hypervisor. A different set of ops
> that don't replace the entire allocator would be fine for them.
>
> The issue with taking away the alloc_page is that it complicates the
> ability for the common code to use the struct page fields and more. We
> already know we are going to need those to do some of the things that
> are being asked for, eg RCU freeing and refcounting.
Oh come on, for all the things you claim are simple, you don't think
it's trivial to make the fancy stuff conditional? (Hint: we already have
control flow all over which is conditional on the cfg and/or calling
context, and that future stuff may well end up wanting to be conditional
in its own right anyway since not all io-pgtable-arm users will need or
want it).
Having already 90% prototyped deferred freeing (oh, to be able to get
back to fun things like that...), I see no significant impediment to
fitting that in around this. Certainly no worse than fitting it around
the !coherent_walk DMA API bits - in fact if anything, punting all that
lot into custom allocator hooks starts to look like an attractive idea
once we have the means (it really wants to be using dma_alloc_pages()
these days).
>>> I would not expect a resolution in a few weeks.
>>
>> OOC, what's the time frame?
>
> The larger need has been discussed is considerable work, I would be
> surprised if something could be merged in less than 6 months,
> especially with the upcoming holiday season
>
>> I've maintained a subsystem for a few years, so I know what it means
>> to contribute upstream and ask or being asked to extend the core to do
>> something the right way. I'm generally patient and try to follow
>> maintainers' recommendations, but there's some point where waiting is
>> no more an option, and you have to be more pragmatic, because there's
>> always a better way of doing things, and perfection is often the enemy
>> of good...
>
> Here I am not talking about perfection, I am concerned about messing
> up work that I now see as important for other iommu drivers related
> things by making a hack for a DRM driver (which as I've said has,
> unravelling these hacks has been traumatic for many of us
> historically)
In your own words, this is a community effort. You do not own this code,
and you do not get to prevent the community from solving multiple
problems they have now, in a way which is reasonable now, just because
*you* don't like it, and *you* believe it might possibly make it harder
to do something at some indeterminate point in future. Your objection is
noted, but as above, I for one do not see a convincing basis for it anyway.
You know what *the community* sees as important? Not having to maintain
multiple copies of near-identical pagetable code, because maintenance is
an established and very real concern. This is why we have the io-pgtable
library in the first place, and why we adapted io-pgtable-arm to support
panfrost when that came along. If supporting panfrost and panthor as
io-pgtable users really does ever become a practical problem at some
point in the future, we will work to address that problem at that point.
In the meantime, we can get on with the common goal of making Linux do
the things people want it to do, in the best way that the maintainers
are happy to maintain. This is not "a hack for a DRM driver", it's a
simple and convenient generalisation of part of io-pgtable, in keeping
with the design of io-pgtable (user-provided callbacks are nothing new),
and straightforwardly serving at least two completely different
use-cases already.
Thanks,
Robin.
More information about the linux-arm-kernel
mailing list