]> www.infradead.org Git - users/jedix/linux-maple.git/commitdiff
mm/pagemap: recognize uffd-wp bit for shmem/hugetlbfs
authorPeter Xu <peterx@redhat.com>
Thu, 14 Apr 2022 19:16:52 +0000 (12:16 -0700)
committerLiam R. Howlett <Liam.Howlett@oracle.com>
Thu, 14 Apr 2022 21:49:52 +0000 (17:49 -0400)
This requires the pagemap code to be able to recognize the newly
introduced swap special pte for uffd-wp, meanwhile the general case for
hugetlb that we recently start to support.  It should make pagemap uffd-wp
support complete.

Link: https://lkml.kernel.org/r/20220405014923.15047-1-peterx@redhat.com
Signed-off-by: Peter Xu <peterx@redhat.com>
Cc: Alistair Popple <apopple@nvidia.com>
Cc: Andrea Arcangeli <aarcange@redhat.com>
Cc: Axel Rasmussen <axelrasmussen@google.com>
Cc: David Hildenbrand <david@redhat.com>
Cc: Hugh Dickins <hughd@google.com>
Cc: Jerome Glisse <jglisse@redhat.com>
Cc: "Kirill A . Shutemov" <kirill@shutemov.name>
Cc: Matthew Wilcox <willy@infradead.org>
Cc: Mike Kravetz <mike.kravetz@oracle.com>
Cc: Mike Rapoport <rppt@linux.vnet.ibm.com>
Cc: Nadav Amit <nadav.amit@gmail.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
fs/proc/task_mmu.c

index 1f948af611d8b9517ea8dec5d151f9b3d6cd8afc..81bfb947481ada6013ddd0a8399ab21656abfc84 100644 (file)
@@ -1427,6 +1427,8 @@ static pagemap_entry_t pte_to_pagemap_entry(struct pagemapread *pm,
                migration = is_migration_entry(entry);
                if (is_pfn_swap_entry(entry))
                        page = pfn_swap_entry_to_page(entry);
+               if (pte_marker_entry_uffd_wp(entry))
+                       flags |= PM_UFFD_WP;
        }
 
        if (page && !PageAnon(page))
@@ -1562,10 +1564,15 @@ static int pagemap_hugetlb_range(pte_t *ptep, unsigned long hmask,
                if (page_mapcount(page) == 1)
                        flags |= PM_MMAP_EXCLUSIVE;
 
+               if (huge_pte_uffd_wp(pte))
+                       flags |= PM_UFFD_WP;
+
                flags |= PM_PRESENT;
                if (pm->show_pfn)
                        frame = pte_pfn(pte) +
                                ((addr & ~hmask) >> PAGE_SHIFT);
+       } else if (pte_swp_uffd_wp_any(pte)) {
+               flags |= PM_UFFD_WP;
        }
 
        for (; addr != end; addr += PAGE_SIZE) {