mm: remove head_compound_mapcount() and _ptr functions
authorMatthew Wilcox (Oracle) <willy@infradead.org>
Wed, 11 Jan 2023 14:29:01 +0000 (14:29 +0000)
committerAndrew Morton <akpm@linux-foundation.org>
Fri, 3 Feb 2023 06:32:58 +0000 (22:32 -0800)
folio_mapcount_ptr(), compound_mapcount_ptr() and subpages_mapcount_ptr()
are all now unused.

Link: https://lkml.kernel.org/r/20230111142915.1001531-16-willy@infradead.org
Signed-off-by: Matthew Wilcox (Oracle) <willy@infradead.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
include/linux/mm.h
include/linux/mm_types.h

index a6afa6c51a4dac0bb585348415dca51b7ecdfb59..7ff6e2410aa339b1948459dc49a65f38825198b0 100644 (file)
@@ -831,16 +831,7 @@ static inline int is_vmalloc_or_module_addr(const void *x)
 static inline int folio_entire_mapcount(struct folio *folio)
 {
        VM_BUG_ON_FOLIO(!folio_test_large(folio), folio);
-       return atomic_read(folio_mapcount_ptr(folio)) + 1;
-}
-
-/*
- * Mapcount of compound page as a whole, does not include mapped sub-pages.
- * Must be called only on head of compound page.
- */
-static inline int head_compound_mapcount(struct page *head)
-{
-       return atomic_read(compound_mapcount_ptr(head)) + 1;
+       return atomic_read(&folio->_entire_mapcount) + 1;
 }
 
 /*
@@ -905,11 +896,11 @@ static inline int total_mapcount(struct page *page)
 static inline bool folio_large_is_mapped(struct folio *folio)
 {
        /*
-        * Reading folio_mapcount_ptr() below could be omitted if hugetlb
+        * Reading _entire_mapcount below could be omitted if hugetlb
         * participated in incrementing nr_pages_mapped when compound mapped.
         */
        return atomic_read(&folio->_nr_pages_mapped) > 0 ||
-               atomic_read(folio_mapcount_ptr(folio)) >= 0;
+               atomic_read(&folio->_entire_mapcount) >= 0;
 }
 
 /**
index 70cbda7683081450470fc74cc434cc10ee44c286..ffcf21fbaaf0faadb268edc8d8ba5890eabe32c7 100644 (file)
@@ -421,22 +421,6 @@ FOLIO_MATCH(hugetlb_cgroup_rsvd, _hugetlb_cgroup_rsvd);
 FOLIO_MATCH(hugetlb_hwpoison, _hugetlb_hwpoison);
 #undef FOLIO_MATCH
 
-static inline atomic_t *folio_mapcount_ptr(struct folio *folio)
-{
-       struct page *tail = &folio->page + 1;
-       return &tail->compound_mapcount;
-}
-
-static inline atomic_t *compound_mapcount_ptr(struct page *page)
-{
-       return &page[1].compound_mapcount;
-}
-
-static inline atomic_t *subpages_mapcount_ptr(struct page *page)
-{
-       return &page[1].subpages_mapcount;
-}
-
 /*
  * Used for sizing the vmemmap region on some architectures
  */