bcachefs: Add a persistent counter for bucket invalidation
authorKent Overstreet <kent.overstreet@gmail.com>
Mon, 13 Jun 2022 23:45:07 +0000 (19:45 -0400)
committerKent Overstreet <kent.overstreet@linux.dev>
Sun, 22 Oct 2023 21:09:33 +0000 (17:09 -0400)
Signed-off-by: Kent Overstreet <kent.overstreet@gmail.com>
fs/bcachefs/alloc_background.c
fs/bcachefs/bcachefs_format.h

index 982cd185b1afa6b80d34e86fa93556e6a40276b9..543ec0c45883d7374db200c4d5b11b01672ca000 100644 (file)
@@ -1173,11 +1173,16 @@ static void bch2_do_invalidates_work(struct work_struct *work)
                s64 nr_to_invalidate =
                        should_invalidate_buckets(ca, bch2_dev_usage_read(ca));
 
-               while (!ret && nr_to_invalidate-- >= 0)
+               while (nr_to_invalidate-- >= 0) {
                        ret = __bch2_trans_do(&trans, NULL, NULL,
                                              BTREE_INSERT_USE_RESERVE|
                                              BTREE_INSERT_NOFAIL,
                                        invalidate_one_bucket(&trans, ca));
+                       if (ret)
+                               break;
+
+                       this_cpu_inc(c->counters[BCH_COUNTER_bucket_invalidate]);
+               }
        }
 
        bch2_trans_exit(&trans);
index 079ad93ab34e9b39641d6893272d733ebea4b5f6..944cc6247a842c7c076e1f44b7fb0cfe6dbd2205 100644 (file)
@@ -1326,10 +1326,11 @@ struct bch_sb_field_disk_groups {
 
 /* BCH_SB_FIELD_counters */
 
-#define BCH_PERSISTENT_COUNTERS()      \
-       x(io_read,  0)                  \
-       x(io_write, 1)                  \
-       x(io_move,  2)
+#define BCH_PERSISTENT_COUNTERS()                      \
+       x(io_read,              0)                      \
+       x(io_write,             1)                      \
+       x(io_move,              2)                      \
+       x(bucket_invalidate,    3)
 
 enum bch_persistent_counters {
 #define x(t, n, ...) BCH_COUNTER_##t,