summaryrefslogtreecommitdiffstats
path: root/mm/mlock.c
diff options
context:
space:
mode:
authorMatthew Wilcox (Oracle) <willy@infradead.org>2022-02-15 19:33:59 +0100
committerMatthew Wilcox (Oracle) <willy@infradead.org>2022-03-21 17:59:02 +0100
commitdcc5d337c5e62761ee71f2e25c7aa890b1aa41a2 (patch)
treef77619f9b0067bf4e52f69cf586659ba2cdd4c2e /mm/mlock.c
parentmm/rmap: Use a folio in page_mkclean_one() (diff)
downloadlinux-dcc5d337c5e62761ee71f2e25c7aa890b1aa41a2.tar.xz
linux-dcc5d337c5e62761ee71f2e25c7aa890b1aa41a2.zip
mm/mlock: Add mlock_vma_folio()
Convert mlock_page() into mlock_folio() and convert the callers. Keep mlock_vma_page() as a wrapper. Signed-off-by: Matthew Wilcox (Oracle) <willy@infradead.org>
Diffstat (limited to 'mm/mlock.c')
-rw-r--r--mm/mlock.c22
1 files changed, 11 insertions, 11 deletions
diff --git a/mm/mlock.c b/mm/mlock.c
index d28e56529e5b..833d482746d9 100644
--- a/mm/mlock.c
+++ b/mm/mlock.c
@@ -218,23 +218,23 @@ bool need_mlock_page_drain(int cpu)
}
/**
- * mlock_page - mlock a page already on (or temporarily off) LRU
- * @page: page to be mlocked, either a normal page or a THP head.
+ * mlock_folio - mlock a folio already on (or temporarily off) LRU
+ * @folio: folio to be mlocked.
*/
-void mlock_page(struct page *page)
+void mlock_folio(struct folio *folio)
{
struct pagevec *pvec = &get_cpu_var(mlock_pvec);
- if (!TestSetPageMlocked(page)) {
- int nr_pages = thp_nr_pages(page);
+ if (!folio_test_set_mlocked(folio)) {
+ int nr_pages = folio_nr_pages(folio);
- mod_zone_page_state(page_zone(page), NR_MLOCK, nr_pages);
+ zone_stat_mod_folio(folio, NR_MLOCK, nr_pages);
__count_vm_events(UNEVICTABLE_PGMLOCKED, nr_pages);
}
- get_page(page);
- if (!pagevec_add(pvec, mlock_lru(page)) ||
- PageHead(page) || lru_cache_disabled())
+ folio_get(folio);
+ if (!pagevec_add(pvec, mlock_lru(&folio->page)) ||
+ folio_test_large(folio) || lru_cache_disabled())
mlock_pagevec(pvec);
put_cpu_var(mlock_pvec);
}
@@ -296,7 +296,7 @@ static int mlock_pte_range(pmd_t *pmd, unsigned long addr,
goto out;
page = pmd_page(*pmd);
if (vma->vm_flags & VM_LOCKED)
- mlock_page(page);
+ mlock_folio(page_folio(page));
else
munlock_page(page);
goto out;
@@ -312,7 +312,7 @@ static int mlock_pte_range(pmd_t *pmd, unsigned long addr,
if (PageTransCompound(page))
continue;
if (vma->vm_flags & VM_LOCKED)
- mlock_page(page);
+ mlock_folio(page_folio(page));
else
munlock_page(page);
}