mm: zswap: modify zswap_stored_pages to be atomic_long_t
authorKanchana P Sridhar <kanchana.p.sridhar@intel.com>
Tue, 1 Oct 2024 05:32:20 +0000 (22:32 -0700)
committerAndrew Morton <akpm@linux-foundation.org>
Fri, 1 Nov 2024 04:28:54 +0000 (21:28 -0700)
For zswap_store() to support large folios, we need to be able to do a
batch update of zswap_stored_pages upon successful store of all pages in
the folio.  For this, we need to add folio_nr_pages(), which returns a
long, to zswap_stored_pages.

Link: https://lkml.kernel.org/r/20241001053222.6944-6-kanchana.p.sridhar@intel.com
Signed-off-by: Kanchana P Sridhar <kanchana.p.sridhar@intel.com>
Acked-by: Yosry Ahmed <yosryahmed@google.com>
Acked-by: Johannes Weiner <hannes@cmpxchg.org>
Reviewed-by: Nhat Pham <nphamcs@gmail.com>
Cc: Chengming Zhou <chengming.zhou@linux.dev>
Cc: "Huang, Ying" <ying.huang@intel.com>
Cc: Matthew Wilcox <willy@infradead.org>
Cc: Ryan Roberts <ryan.roberts@arm.com>
Cc: Shakeel Butt <shakeel.butt@linux.dev>
Cc: Usama Arif <usamaarif642@gmail.com>
Cc: Wajdi Feghali <wajdi.k.feghali@intel.com>
Cc: "Zou, Nanhai" <nanhai.zou@intel.com>
Cc: Barry Song <21cnbao@gmail.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
fs/proc/meminfo.c
include/linux/zswap.h
mm/zswap.c

index 245171d9164be3d2387cdc7711ae0909d3f5f59a..8ba9b14723902c793a6fcde38230e314af8fd2f2 100644 (file)
@@ -91,7 +91,7 @@ static int meminfo_proc_show(struct seq_file *m, void *v)
 #ifdef CONFIG_ZSWAP
        show_val_kb(m, "Zswap:          ", zswap_total_pages());
        seq_printf(m,  "Zswapped:       %8lu kB\n",
-                  (unsigned long)atomic_read(&zswap_stored_pages) <<
+                  (unsigned long)atomic_long_read(&zswap_stored_pages) <<
                   (PAGE_SHIFT - 10));
 #endif
        show_val_kb(m, "Dirty:          ",
index 9cd1beef0654873e47cf84114505630ac9c3720d..d961ead91bf1e868d3fa1de57dd080db19e603a4 100644 (file)
@@ -7,7 +7,7 @@
 
 struct lruvec;
 
-extern atomic_t zswap_stored_pages;
+extern atomic_long_t zswap_stored_pages;
 
 #ifdef CONFIG_ZSWAP
 
index f8a39f675a6006d9e121e93226fc9b4313b32fce..4427c88fb9e4b850819b27c0f11defb0b5182b67 100644 (file)
@@ -43,7 +43,7 @@
 * statistics
 **********************************/
 /* The number of compressed pages currently stored in zswap */
-atomic_t zswap_stored_pages = ATOMIC_INIT(0);
+atomic_long_t zswap_stored_pages = ATOMIC_INIT(0);
 
 /*
  * The statistics below are not protected from concurrent access for
@@ -801,7 +801,7 @@ static void zswap_entry_free(struct zswap_entry *entry)
                obj_cgroup_put(entry->objcg);
        }
        zswap_entry_cache_free(entry);
-       atomic_dec(&zswap_stored_pages);
+       atomic_long_dec(&zswap_stored_pages);
 }
 
 /*********************************
@@ -1231,7 +1231,7 @@ static unsigned long zswap_shrinker_count(struct shrinker *shrinker,
                nr_stored = memcg_page_state(memcg, MEMCG_ZSWAPPED);
        } else {
                nr_backing = zswap_total_pages();
-               nr_stored = atomic_read(&zswap_stored_pages);
+               nr_stored = atomic_long_read(&zswap_stored_pages);
        }
 
        if (!nr_stored)
@@ -1500,7 +1500,7 @@ bool zswap_store(struct folio *folio)
        }
 
        /* update stats */
-       atomic_inc(&zswap_stored_pages);
+       atomic_long_inc(&zswap_stored_pages);
        count_vm_event(ZSWPOUT);
 
        return true;
@@ -1649,6 +1649,13 @@ static int debugfs_get_total_size(void *data, u64 *val)
 }
 DEFINE_DEBUGFS_ATTRIBUTE(total_size_fops, debugfs_get_total_size, NULL, "%llu\n");
 
+static int debugfs_get_stored_pages(void *data, u64 *val)
+{
+       *val = atomic_long_read(&zswap_stored_pages);
+       return 0;
+}
+DEFINE_DEBUGFS_ATTRIBUTE(stored_pages_fops, debugfs_get_stored_pages, NULL, "%llu\n");
+
 static int zswap_debugfs_init(void)
 {
        if (!debugfs_initialized())
@@ -1672,8 +1679,8 @@ static int zswap_debugfs_init(void)
                           zswap_debugfs_root, &zswap_written_back_pages);
        debugfs_create_file("pool_total_size", 0444,
                            zswap_debugfs_root, NULL, &total_size_fops);
-       debugfs_create_atomic_t("stored_pages", 0444,
-                               zswap_debugfs_root, &zswap_stored_pages);
+       debugfs_create_file("stored_pages", 0444,
+                           zswap_debugfs_root, NULL, &stored_pages_fops);
 
        return 0;
 }