]> git-server-git.apps.pok.os.sepia.ceph.com Git - ceph-client.git/commitdiff
fscache, cachefiles: Display stat of culling events
authorDavid Howells <dhowells@redhat.com>
Fri, 22 Oct 2021 08:17:58 +0000 (09:17 +0100)
committerDavid Howells <dhowells@redhat.com>
Fri, 26 Nov 2021 21:23:48 +0000 (21:23 +0000)
Add a stat counter of culling events whereby the cache backend culls a file
to make space (when asked by cachefilesd in this case) and display in
/proc/fs/fscache/stats.

Signed-off-by: David Howells <dhowells@redhat.com>
cc: linux-cachefs@redhat.com

fs/cachefiles/namei.c
fs/fscache/stats.c
include/linux/fscache-cache.h

index 7e24a7a2234dfd4b5d3cbf810bcec5bf8f682dd8..a651da35dcd05903c5b033ea692836b37c70e611 100644 (file)
@@ -803,6 +803,7 @@ int cachefiles_cull(struct cachefiles_cache *cache, struct dentry *dir,
        if (ret < 0)
                goto error;
 
+       fscache_count_culled();
        dput(victim);
        _leave(" = 0");
        return 0;
index db2f4e225dd96d7d5c450ecc0af0504cab161c3e..fc94e5e79f1c6d456bd6e48ac2fe8a5141f70ef6 100644 (file)
@@ -46,6 +46,8 @@ atomic_t fscache_n_no_write_space;
 EXPORT_SYMBOL(fscache_n_no_write_space);
 atomic_t fscache_n_no_create_space;
 EXPORT_SYMBOL(fscache_n_no_create_space);
+atomic_t fscache_n_culled;
+EXPORT_SYMBOL(fscache_n_culled);
 
 /*
  * display the general statistics
@@ -86,9 +88,10 @@ int fscache_stats_show(struct seq_file *m, void *v)
                   atomic_read(&fscache_n_relinquishes_retire),
                   atomic_read(&fscache_n_relinquishes_dropped));
 
-       seq_printf(m, "NoSpace: nwr=%u ncr=%u\n",
+       seq_printf(m, "NoSpace: nwr=%u ncr=%u cull=%u\n",
                   atomic_read(&fscache_n_no_write_space),
-                  atomic_read(&fscache_n_no_create_space));
+                  atomic_read(&fscache_n_no_create_space),
+                  atomic_read(&fscache_n_culled));
 
        seq_printf(m, "IO     : rd=%u wr=%u\n",
                   atomic_read(&fscache_n_read),
index 1d7d431712434050edf70f1a6e9480535b5089b1..7665bcab945e9081e97c19f97540af6379a325ba 100644 (file)
@@ -188,15 +188,18 @@ extern atomic_t fscache_n_read;
 extern atomic_t fscache_n_write;
 extern atomic_t fscache_n_no_write_space;
 extern atomic_t fscache_n_no_create_space;
+extern atomic_t fscache_n_culled;
 #define fscache_count_read() atomic_inc(&fscache_n_read)
 #define fscache_count_write() atomic_inc(&fscache_n_write)
 #define fscache_count_no_write_space() atomic_inc(&fscache_n_no_write_space)
 #define fscache_count_no_create_space() atomic_inc(&fscache_n_no_create_space)
+#define fscache_count_culled() atomic_inc(&fscache_n_culled)
 #else
 #define fscache_count_read() do {} while(0)
 #define fscache_count_write() do {} while(0)
 #define fscache_count_no_write_space() do {} while(0)
 #define fscache_count_no_create_space() do {} while(0)
+#define fscache_count_culled() do {} while(0)
 #endif
 
 #endif /* _LINUX_FSCACHE_CACHE_H */