Re: [RFC PATCH 00/16] 1GB THP support on x86_64

From: Zi Yan
Date: Wed Sep 02 2020 - 15:05:47 EST


On 2 Sep 2020, at 14:48, Jason Gunthorpe wrote:

> On Wed, Sep 02, 2020 at 02:45:37PM -0400, Zi Yan wrote:
>
>>> Surprised this doesn't touch mm/pagewalk.c ?
>>
>> 1GB PUD page support is present for DAX purpose, so the code is there
>> in mm/pagewalk.c already. I only needed to supply ops->pud_entry when using
>> the functions in mm/pagewalk.c. :)
>
> Yes, but doesn't this change what is possible under the mmap_sem
> without the page table locks?
>
> ie I would expect some thing like pmd_trans_unstable() to be required
> as well for lockless walkers. (and I don't think the pmd code is 100%
> right either)
>

Right. I missed that. Thanks for pointing it out.
The code like this, right?

diff --git a/mm/pagewalk.c b/mm/pagewalk.c
index e81640d9f177..4fe6ce4a92eb 100644
--- a/mm/pagewalk.c
+++ b/mm/pagewalk.c
@@ -152,10 +152,11 @@ static int walk_pud_range(p4d_t *p4d, unsigned long addr, unsigned long end,
!(ops->pmd_entry || ops->pte_entry))
continue;

- if (walk->vma)
+ if (walk->vma) {
split_huge_pud(walk->vma, pud, addr);
- if (pud_none(*pud))
- goto again;
+ if (pud_trans_unstable(pud))
+ goto again;
+ }

err = walk_pmd_range(pud, addr, next, walk);
if (err)



Best Regards,
Yan Zi

Attachment: signature.asc
Description: OpenPGP digital signature