From: Jeff Layton <[email protected]>

Signed-off-by: Jeff Layton <[email protected]>
---
 fs/btrfs/super.c | 22 ++++++++++++++++------
 1 file changed, 16 insertions(+), 6 deletions(-)

diff --git a/fs/btrfs/super.c b/fs/btrfs/super.c
index 4b3e6676be9d..eac785459f10 100644
--- a/fs/btrfs/super.c
+++ b/fs/btrfs/super.c
@@ -1231,12 +1231,13 @@ int btrfs_sync_fs(struct super_block *sb, int wait, 
errseq_t *since)
        struct btrfs_trans_handle *trans;
        struct btrfs_fs_info *fs_info = btrfs_sb(sb);
        struct btrfs_root *root = fs_info->tree_root;
+       int ret = 0;
 
        trace_btrfs_sync_fs(fs_info, wait);
 
        if (!wait) {
                filemap_flush(fs_info->btree_inode->i_mapping);
-               return 0;
+               goto out;
        }
 
        btrfs_wait_ordered_roots(fs_info, U64_MAX, 0, (u64)-1);
@@ -1250,7 +1251,7 @@ int btrfs_sync_fs(struct super_block *sb, int wait, 
errseq_t *since)
                         * that need to go through commit
                         */
                        if (fs_info->pending_changes == 0)
-                               return 0;
+                               goto out;
                        /*
                         * A non-blocking test if the fs is frozen. We must not
                         * start a new transaction here otherwise a deadlock
@@ -1260,13 +1261,22 @@ int btrfs_sync_fs(struct super_block *sb, int wait, 
errseq_t *since)
                        if (sb_start_write_trylock(sb))
                                sb_end_write(sb);
                        else
-                               return 0;
+                               goto out;
                        trans = btrfs_start_transaction(root, 0);
                }
-               if (IS_ERR(trans))
-                       return PTR_ERR(trans);
+               if (IS_ERR(trans)) {
+                       ret = PTR_ERR(trans);
+                       goto out;
+               }
        }
-       return btrfs_commit_transaction(trans);
+       ret = btrfs_commit_transaction(trans);
+out:
+       if (since) {
+               int ret2 = errseq_check_and_advance(&sb->s_wb_err, since);
+               if (ret == 0)
+                       ret = ret2;
+       }
+       return ret;
 }
 
 static int btrfs_show_options(struct seq_file *seq, struct dentry *dentry)
-- 
2.17.0

Reply via email to