linux-mm.kvack.org archive mirror
 help / color / mirror / Atom feed
* [PATCH] mm/gup: add missing gup_must_unshare() check to gup_huge_pgd()
@ 2023-05-06 14:05 Lorenzo Stoakes
  2023-05-08  0:30 ` Andrew Morton
  0 siblings, 1 reply; 4+ messages in thread
From: Lorenzo Stoakes @ 2023-05-06 14:05 UTC (permalink / raw)
  To: linux-mm, linux-kernel, Andrew Morton; +Cc: David Hildenbrand, Lorenzo Stoakes

All other instances of gup_huge_pXd() perform the unshare check, so update
the PGD-specific function to do so as well.

While checking pgd_write() might seem unusual, this function already
performs such a check via pgd_access_permitted() so this is in line with
the existing implementation.

Suggested-by: David Hildenbrand <david@redhat.com>
Signed-off-by: Lorenzo Stoakes <lstoakes@gmail.com>
---
 mm/gup.c | 5 +++++
 1 file changed, 5 insertions(+)

diff --git a/mm/gup.c b/mm/gup.c
index ef43ffb3d1fe..78a5198e3212 100644
--- a/mm/gup.c
+++ b/mm/gup.c
@@ -2898,6 +2898,11 @@ static int gup_huge_pgd(pgd_t orig, pgd_t *pgdp, unsigned long addr,
 		return 0;
 	}
 
+	if (!pgd_write(orig) && gup_must_unshare(NULL, flags, &folio->page)) {
+		gup_put_folio(folio, refs, flags);
+		return 0;
+	}
+
 	*nr += refs;
 	folio_set_referenced(folio);
 	return 1;
-- 
2.40.1


^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2023-05-08  1:00 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2023-05-06 14:05 [PATCH] mm/gup: add missing gup_must_unshare() check to gup_huge_pgd() Lorenzo Stoakes
2023-05-08  0:30 ` Andrew Morton
2023-05-08  0:45   ` David Hildenbrand
2023-05-08  1:00     ` Andrew Morton

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox