]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
NFS: fsync() should report filesystem errors over EINTR/ERESTARTSYS
authorTrond Myklebust <trond.myklebust@hammerspace.com>
Sat, 14 May 2022 14:27:01 +0000 (10:27 -0400)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 9 Jun 2022 08:26:13 +0000 (10:26 +0200)
[ Upstream commit 9641d9bc9b75f11f70646f5c6ee9f5f519a1012e ]

If the commit to disk is interrupted, we should still first check for
filesystem errors so that we can report them in preference to the error
due to the signal.

Fixes: 2197e9b06c22 ("NFS: Fix up fsync() when the server rebooted")
Signed-off-by: Trond Myklebust <trond.myklebust@hammerspace.com>
Signed-off-by: Anna Schumaker <Anna.Schumaker@Netapp.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
fs/nfs/file.c

index d8583f57ff99f9b05f8891f93957aeb0c9f7869a..ce761c88d260bdf95d994313e526e7839653657d 100644 (file)
@@ -209,15 +209,16 @@ static int
 nfs_file_fsync_commit(struct file *file, int datasync)
 {
        struct inode *inode = file_inode(file);
-       int ret;
+       int ret, ret2;
 
        dprintk("NFS: fsync file(%pD2) datasync %d\n", file, datasync);
 
        nfs_inc_stats(inode, NFSIOS_VFSFSYNC);
        ret = nfs_commit_inode(inode, FLUSH_SYNC);
-       if (ret < 0)
-               return ret;
-       return file_check_and_advance_wb_err(file);
+       ret2 = file_check_and_advance_wb_err(file);
+       if (ret2 < 0)
+               return ret2;
+       return ret;
 }
 
 int