jbd2: simplify journal_clean_one_cp_list()
authorZhang Yi <yi.zhang@huawei.com>
Thu, 10 Jun 2021 11:24:38 +0000 (19:24 +0800)
committerTheodore Ts'o <tytso@mit.edu>
Thu, 24 Jun 2021 14:55:39 +0000 (10:55 -0400)
Now that __try_to_free_cp_buf() remove checkpointed buffer or transaction
when the buffer is not 'busy', which is only called by
journal_clean_one_cp_list(). This patch simplify this function by remove
__try_to_free_cp_buf() and invoke __cp_buffer_busy() directly.

Signed-off-by: Zhang Yi <yi.zhang@huawei.com>
Reviewed-by: Jan Kara <jack@suse.cz>
Link: https://lore.kernel.org/r/20210610112440.3438139-7-yi.zhang@huawei.com
Signed-off-by: Theodore Ts'o <tytso@mit.edu>
fs/jbd2/checkpoint.c

index 1abdae44a3d848f0e2a5f2df45df4a30e533af4a..51d1eb2ffeb95069f1c1529f3233980040c63cde 100644 (file)
@@ -91,25 +91,6 @@ static inline bool __cp_buffer_busy(struct journal_head *jh)
        return (jh->b_transaction || buffer_locked(bh) || buffer_dirty(bh));
 }
 
-/*
- * Try to release a checkpointed buffer from its transaction.
- * Returns 1 if we released it and 2 if we also released the
- * whole transaction.
- *
- * Requires j_list_lock
- */
-static int __try_to_free_cp_buf(struct journal_head *jh)
-{
-       int ret = 0;
-       struct buffer_head *bh = jh2bh(jh);
-
-       if (!jh->b_transaction && !buffer_locked(bh) && !buffer_dirty(bh)) {
-               JBUFFER_TRACE(jh, "remove from checkpoint list");
-               ret = __jbd2_journal_remove_checkpoint(jh) + 1;
-       }
-       return ret;
-}
-
 /*
  * __jbd2_log_wait_for_space: wait until there is space in the journal.
  *
@@ -440,7 +421,6 @@ static int journal_clean_one_cp_list(struct journal_head *jh, bool destroy)
 {
        struct journal_head *last_jh;
        struct journal_head *next_jh = jh;
-       int ret;
 
        if (!jh)
                return 0;
@@ -449,13 +429,11 @@ static int journal_clean_one_cp_list(struct journal_head *jh, bool destroy)
        do {
                jh = next_jh;
                next_jh = jh->b_cpnext;
-               if (!destroy)
-                       ret = __try_to_free_cp_buf(jh);
-               else
-                       ret = __jbd2_journal_remove_checkpoint(jh) + 1;
-               if (!ret)
+
+               if (!destroy && __cp_buffer_busy(jh))
                        return 0;
-               if (ret == 2)
+
+               if (__jbd2_journal_remove_checkpoint(jh))
                        return 1;
                /*
                 * This function only frees up some memory