[RFC PATCH 09/11] btrfs: have sync_fs op report writeback errors when passed a since pointer

From: Jeff Layton
Date: Fri May 18 2018 - 07:39:38 EST


From: Jeff Layton <jlayton@xxxxxxxxxx>

Signed-off-by: Jeff Layton <jlayton@xxxxxxxxxx>
---
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