Commit 66c7f7a6 authored by Matthew Wilcox (Oracle)'s avatar Matthew Wilcox (Oracle) Committed by Linus Torvalds

mm: remove the total_mapcount argument from page_trans_huge_map_swapcount()

Now that we don't report it to the caller of reuse_swap_page(), we don't
need to request it from page_trans_huge_map_swapcount().

Link: https://lkml.kernel.org/r/20211220205943.456187-2-willy@infradead.orgSigned-off-by: default avatarMatthew Wilcox (Oracle) <willy@infradead.org>
Reviewed-by: default avatarWilliam Kucharski <william.kucharski@oracle.com>
Acked-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
Cc: David Hildenbrand <david@redhat.com>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent 020e8765
...@@ -1601,31 +1601,30 @@ static bool page_swapped(struct page *page) ...@@ -1601,31 +1601,30 @@ static bool page_swapped(struct page *page)
return false; return false;
} }
static int page_trans_huge_map_swapcount(struct page *page, int *total_mapcount, static int page_trans_huge_map_swapcount(struct page *page,
int *total_swapcount) int *total_swapcount)
{ {
int i, map_swapcount, _total_mapcount, _total_swapcount; int i, map_swapcount, _total_swapcount;
unsigned long offset = 0; unsigned long offset = 0;
struct swap_info_struct *si; struct swap_info_struct *si;
struct swap_cluster_info *ci = NULL; struct swap_cluster_info *ci = NULL;
unsigned char *map = NULL; unsigned char *map = NULL;
int mapcount, swapcount = 0; int swapcount = 0;
/* hugetlbfs shouldn't call it */ /* hugetlbfs shouldn't call it */
VM_BUG_ON_PAGE(PageHuge(page), page); VM_BUG_ON_PAGE(PageHuge(page), page);
if (!IS_ENABLED(CONFIG_THP_SWAP) || likely(!PageTransCompound(page))) { if (!IS_ENABLED(CONFIG_THP_SWAP) || likely(!PageTransCompound(page))) {
mapcount = page_trans_huge_mapcount(page, total_mapcount);
if (PageSwapCache(page)) if (PageSwapCache(page))
swapcount = page_swapcount(page); swapcount = page_swapcount(page);
if (total_swapcount) if (total_swapcount)
*total_swapcount = swapcount; *total_swapcount = swapcount;
return mapcount + swapcount; return swapcount + page_trans_huge_mapcount(page, NULL);
} }
page = compound_head(page); page = compound_head(page);
_total_mapcount = _total_swapcount = map_swapcount = 0; _total_swapcount = map_swapcount = 0;
if (PageSwapCache(page)) { if (PageSwapCache(page)) {
swp_entry_t entry; swp_entry_t entry;
...@@ -1639,8 +1638,7 @@ static int page_trans_huge_map_swapcount(struct page *page, int *total_mapcount, ...@@ -1639,8 +1638,7 @@ static int page_trans_huge_map_swapcount(struct page *page, int *total_mapcount,
if (map) if (map)
ci = lock_cluster(si, offset); ci = lock_cluster(si, offset);
for (i = 0; i < HPAGE_PMD_NR; i++) { for (i = 0; i < HPAGE_PMD_NR; i++) {
mapcount = atomic_read(&page[i]._mapcount) + 1; int mapcount = atomic_read(&page[i]._mapcount) + 1;
_total_mapcount += mapcount;
if (map) { if (map) {
swapcount = swap_count(map[offset + i]); swapcount = swap_count(map[offset + i]);
_total_swapcount += swapcount; _total_swapcount += swapcount;
...@@ -1648,19 +1646,14 @@ static int page_trans_huge_map_swapcount(struct page *page, int *total_mapcount, ...@@ -1648,19 +1646,14 @@ static int page_trans_huge_map_swapcount(struct page *page, int *total_mapcount,
map_swapcount = max(map_swapcount, mapcount + swapcount); map_swapcount = max(map_swapcount, mapcount + swapcount);
} }
unlock_cluster(ci); unlock_cluster(ci);
if (PageDoubleMap(page)) {
if (PageDoubleMap(page))
map_swapcount -= 1; map_swapcount -= 1;
_total_mapcount -= HPAGE_PMD_NR;
}
mapcount = compound_mapcount(page);
map_swapcount += mapcount;
_total_mapcount += mapcount;
if (total_mapcount)
*total_mapcount = _total_mapcount;
if (total_swapcount) if (total_swapcount)
*total_swapcount = _total_swapcount; *total_swapcount = _total_swapcount;
return map_swapcount; return map_swapcount + compound_mapcount(page);
} }
/* /*
...@@ -1671,13 +1664,12 @@ static int page_trans_huge_map_swapcount(struct page *page, int *total_mapcount, ...@@ -1671,13 +1664,12 @@ static int page_trans_huge_map_swapcount(struct page *page, int *total_mapcount,
*/ */
bool reuse_swap_page(struct page *page) bool reuse_swap_page(struct page *page)
{ {
int count, total_mapcount, total_swapcount; int count, total_swapcount;
VM_BUG_ON_PAGE(!PageLocked(page), page); VM_BUG_ON_PAGE(!PageLocked(page), page);
if (unlikely(PageKsm(page))) if (unlikely(PageKsm(page)))
return false; return false;
count = page_trans_huge_map_swapcount(page, &total_mapcount, count = page_trans_huge_map_swapcount(page, &total_swapcount);
&total_swapcount);
if (count == 1 && PageSwapCache(page) && if (count == 1 && PageSwapCache(page) &&
(likely(!PageTransCompound(page)) || (likely(!PageTransCompound(page)) ||
/* The remaining swap count will be freed soon */ /* The remaining swap count will be freed soon */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment