Commit 383aa543 authored by Jeff Layton's avatar Jeff Layton

fs: convert __generic_file_fsync to use errseq_t based reporting

Many simple, block-based filesystems use generic_file_fsync as their
fsync operation. Some others (ext* and fat) also call this function
to handle syncing out data.

Switch this code over to use errseq_t based error reporting so that
all of these filesystems get reliable error reporting via fsync,
fdatasync and msync.
Signed-off-by: default avatarJeff Layton <jlayton@redhat.com>
parent 372cf243
...@@ -974,7 +974,7 @@ int __generic_file_fsync(struct file *file, loff_t start, loff_t end, ...@@ -974,7 +974,7 @@ int __generic_file_fsync(struct file *file, loff_t start, loff_t end,
int err; int err;
int ret; int ret;
err = filemap_write_and_wait_range(inode->i_mapping, start, end); err = file_write_and_wait_range(file, start, end);
if (err) if (err)
return err; return err;
...@@ -991,9 +991,11 @@ int __generic_file_fsync(struct file *file, loff_t start, loff_t end, ...@@ -991,9 +991,11 @@ int __generic_file_fsync(struct file *file, loff_t start, loff_t end,
out: out:
inode_unlock(inode); inode_unlock(inode);
/* must call this unconditionally as it clears AS_* error flags */ /* check and advance again to catch errors after syncing out buffers */
err = filemap_check_errors(inode->i_mapping); err = file_check_and_advance_wb_err(file);
return ret ? ret : err; if (ret == 0)
ret = err;
return ret;
} }
EXPORT_SYMBOL(__generic_file_fsync); EXPORT_SYMBOL(__generic_file_fsync);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment