record_root_in_trans can fail currently, handle this failure properly.

Signed-off-by: Josef Bacik <jo...@toxicpanda.com>
---
 fs/btrfs/transaction.c | 5 +++--
 1 file changed, 3 insertions(+), 2 deletions(-)

diff --git a/fs/btrfs/transaction.c b/fs/btrfs/transaction.c
index 26c91c4eba89..7ee0199fbb95 100644
--- a/fs/btrfs/transaction.c
+++ b/fs/btrfs/transaction.c
@@ -487,6 +487,7 @@ int btrfs_record_root_in_trans(struct btrfs_trans_handle 
*trans,
                               struct btrfs_root *root)
 {
        struct btrfs_fs_info *fs_info = root->fs_info;
+       int ret;
 
        if (!test_bit(BTRFS_ROOT_SHAREABLE, &root->state))
                return 0;
@@ -501,10 +502,10 @@ int btrfs_record_root_in_trans(struct btrfs_trans_handle 
*trans,
                return 0;
 
        mutex_lock(&fs_info->reloc_mutex);
-       record_root_in_trans(trans, root, 0);
+       ret = record_root_in_trans(trans, root, 0);
        mutex_unlock(&fs_info->reloc_mutex);
 
-       return 0;
+       return ret;
 }
 
 static inline int is_transaction_blocked(struct btrfs_transaction *trans)
-- 
2.26.2

Reply via email to