memcg: convert get_obj_cgroup_from_page to get_obj_cgroup_from_folio
authorMatthew Wilcox (Oracle) <willy@infradead.org>
Sat, 15 Jul 2023 04:23:41 +0000 (05:23 +0100)
committerAndrew Morton <akpm@linux-foundation.org>
Mon, 21 Aug 2023 20:37:26 +0000 (13:37 -0700)
As the one caller now has a folio, pass it in and use it.  Removes three
calls to compound_head().

Link: https://lkml.kernel.org/r/20230715042343.434588-4-willy@infradead.org
Signed-off-by: Matthew Wilcox (Oracle) <willy@infradead.org>
Cc: Christoph Hellwig <hch@infradead.org>
Cc: Domenico Cerasuolo <cerasuolodomenico@gmail.com>
Cc: Johannes Weiner <hannes@cmpxchg.org>
Cc: Nhat Pham <nphamcs@gmail.com>
Cc: Vitaly Wool <vitaly.wool@konsulko.com>
Cc: Yosry Ahmed <yosryahmed@google.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
include/linux/memcontrol.h
mm/memcontrol.c
mm/zswap.c

index 58eb7ca656995291a597e56c344aaa81e3e2865e..058fb748e128440718cc83d7b24afa5be6cdaad0 100644 (file)
@@ -1759,7 +1759,7 @@ int __memcg_kmem_charge_page(struct page *page, gfp_t gfp, int order);
 void __memcg_kmem_uncharge_page(struct page *page, int order);
 
 struct obj_cgroup *get_obj_cgroup_from_current(void);
-struct obj_cgroup *get_obj_cgroup_from_page(struct page *page);
+struct obj_cgroup *get_obj_cgroup_from_folio(struct folio *folio);
 
 int obj_cgroup_charge(struct obj_cgroup *objcg, gfp_t gfp, size_t size);
 void obj_cgroup_uncharge(struct obj_cgroup *objcg, size_t size);
@@ -1843,7 +1843,7 @@ static inline void __memcg_kmem_uncharge_page(struct page *page, int order)
 {
 }
 
-static inline struct obj_cgroup *get_obj_cgroup_from_page(struct page *page)
+static inline struct obj_cgroup *get_obj_cgroup_from_folio(struct folio *folio)
 {
        return NULL;
 }
index 51772df1abc52252ece4ce73d646c5a32b5cb788..062d925336cbdba87cb05ddc7c952d9fb96131b4 100644 (file)
@@ -3036,21 +3036,21 @@ __always_inline struct obj_cgroup *get_obj_cgroup_from_current(void)
        return objcg;
 }
 
-struct obj_cgroup *get_obj_cgroup_from_page(struct page *page)
+struct obj_cgroup *get_obj_cgroup_from_folio(struct folio *folio)
 {
        struct obj_cgroup *objcg;
 
        if (!memcg_kmem_online())
                return NULL;
 
-       if (PageMemcgKmem(page)) {
-               objcg = __folio_objcg(page_folio(page));
+       if (folio_memcg_kmem(folio)) {
+               objcg = __folio_objcg(folio);
                obj_cgroup_get(objcg);
        } else {
                struct mem_cgroup *memcg;
 
                rcu_read_lock();
-               memcg = __folio_memcg(page_folio(page));
+               memcg = __folio_memcg(folio);
                if (memcg)
                        objcg = __get_obj_cgroup_from_memcg(memcg);
                else
index df3054e6a3a99e88c73e69b8696fb4a722a67992..9df33298f2dca90bf1102934176fdd57fe9d970b 100644 (file)
@@ -1258,7 +1258,7 @@ bool zswap_store(struct folio *folio)
         * cgroup-aware entry LRU, we will push out entries system-wide based on
         * local cgroup limits.
         */
-       objcg = get_obj_cgroup_from_page(page);
+       objcg = get_obj_cgroup_from_folio(folio);
        if (objcg && !obj_cgroup_may_zswap(objcg))
                goto reject;