NFS: Don't report errors from nfs_pageio_complete() more than once
[ Upstream commit c5e483b77cc2edb318da152abe07e33006b975fd ]
Since errors from nfs_pageio_complete() are already being reported
through nfs_async_write_error(), we should not be returning them to the
callers of do_writepages() as well. They will end up being reported
through the generic mechanism instead.
Fixes: 6fbda89b25
("NFS: Replace custom error reporting mechanism with generic one")
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>
This commit is contained in:

committed by
Greg Kroah-Hartman

parent
040242365c
commit
83839a333f
@@ -675,11 +675,7 @@ static int nfs_writepage_locked(struct page *page,
|
|||||||
err = nfs_do_writepage(page, wbc, &pgio);
|
err = nfs_do_writepage(page, wbc, &pgio);
|
||||||
pgio.pg_error = 0;
|
pgio.pg_error = 0;
|
||||||
nfs_pageio_complete(&pgio);
|
nfs_pageio_complete(&pgio);
|
||||||
if (err < 0)
|
|
||||||
return err;
|
return err;
|
||||||
if (nfs_error_is_fatal(pgio.pg_error))
|
|
||||||
return pgio.pg_error;
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int nfs_writepage(struct page *page, struct writeback_control *wbc)
|
int nfs_writepage(struct page *page, struct writeback_control *wbc)
|
||||||
@@ -730,9 +726,6 @@ int nfs_writepages(struct address_space *mapping, struct writeback_control *wbc)
|
|||||||
|
|
||||||
if (err < 0)
|
if (err < 0)
|
||||||
goto out_err;
|
goto out_err;
|
||||||
err = pgio.pg_error;
|
|
||||||
if (nfs_error_is_fatal(err))
|
|
||||||
goto out_err;
|
|
||||||
return 0;
|
return 0;
|
||||||
out_err:
|
out_err:
|
||||||
return err;
|
return err;
|
||||||
|
Reference in New Issue
Block a user