Ack to merge through DRM? WAS Re: [PATCH v2 1/5] mm: Add write-protect and clean utilities for address space ranges

Thomas Hellström (VMware) thomas_os at shipmail.org
Thu Sep 26 20:09:13 UTC 2019


Hi,

On 9/26/19 9:19 PM, Linus Torvalds wrote:
> On Thu, Sep 26, 2019 at 5:03 AM Thomas Hellström (VMware)
> <thomas_os at shipmail.org> wrote:
>> I wonder if I can get an ack from an mm maintainer to merge this through
>> DRM along with the vmwgfx patches? Andrew? Matthew?
> It would have helped to actually point to the patch itself, instead of
> just quoting the commit message.
>
> Looks like this:
>
>       https://lore.kernel.org/lkml/20190926115548.44000-2-thomas_os@shipmail.org/
>
> but why is the code in question not just using the regular page
> walkers. The commit log shows no explanation of what's so special
> about this?
>
> Is the only reason the locking magic? Because if that's the reason,
> then afaik we already have a function for that: it's
> __walk_page_range().
>
> Yes, it's static right now, but that's imho not a reason to duplicate
> all the walking (badly).
>
> Is there some other magic reason that isn't documented?
>
>                Linus

There is a discussion around this subject in

https://lore.kernel.org/lkml/20190926115548.44000-1-thomas_os@shipmail.org/

The main point is that there is an assert in pud_trans_huge_lock() that 
the mmap_sem is held, and we don't have it. Presumably we should be able 
to get away with the i_mmap_lock, but in addition I would have had to 
include the walk_as_pte_range() as the walk::pmd_entry anyway, so the 
amount of duplicated page walk code isn't that big.

That said, if people are OK with me modifying the assert in 
pud_trans_huge_lock() and make __walk_page_range non-static, it should 
probably be possible to make it work, yes.

Thanks,
Thomas




More information about the dri-devel mailing list