]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
btrfs: always drop log root tree reference in btrfs_replay_log()
authorFilipe Manana <fdmanana@suse.com>
Wed, 27 Aug 2025 11:10:28 +0000 (12:10 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Sun, 2 Nov 2025 13:18:04 +0000 (22:18 +0900)
[ Upstream commit 2f5b8095ea47b142c56c09755a8b1e14145a2d30 ]

Currently we have this odd behaviour:

1) At btrfs_replay_log() we drop the reference of the log root tree if
   the call to btrfs_recover_log_trees() failed;

2) But if the call to btrfs_recover_log_trees() did not fail, we don't
   drop the reference in btrfs_replay_log() - we expect that
   btrfs_recover_log_trees() does it in case it returns success.

Let's simplify this and make btrfs_replay_log() always drop the reference
on the log root tree, not only this simplifies code as it's what makes
sense since it's btrfs_replay_log() who grabbed the reference in the first
place.

Signed-off-by: Filipe Manana <fdmanana@suse.com>
Reviewed-by: David Sterba <dsterba@suse.com>
Signed-off-by: David Sterba <dsterba@suse.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
fs/btrfs/disk-io.c
fs/btrfs/tree-log.c

index 70fc4e7cc5a0e6cd8885df91c3959455322eb6d0..0b02e36b30558edb666777bbae34c7c76aeca3b8 100644 (file)
@@ -2087,10 +2087,10 @@ static int btrfs_replay_log(struct btrfs_fs_info *fs_info,
 
        /* returns with log_tree_root freed on success */
        ret = btrfs_recover_log_trees(log_tree_root);
+       btrfs_put_root(log_tree_root);
        if (ret) {
                btrfs_handle_fs_error(fs_info, ret,
                                      "Failed to recover log tree");
-               btrfs_put_root(log_tree_root);
                return ret;
        }
 
index 50ed84cb68a69623e17aa0374c0516db57332d42..518cd74191e77a4e94c8b0358c52e227ba85e2f2 100644 (file)
@@ -7469,7 +7469,6 @@ next:
 
        log_root_tree->log_root = NULL;
        clear_bit(BTRFS_FS_LOG_RECOVERING, &fs_info->flags);
-       btrfs_put_root(log_root_tree);
 
        return 0;
 error: