Commit b69eea82 authored by Darrick J. Wong's avatar Darrick J. Wong

iomap: pass writeback errors to the mapping

Modern-day mapping_set_error has the ability to squash the usual
negative error code into something appropriate for long-term storage in
a struct address_space -- ENOSPC becomes AS_ENOSPC, and everything else
becomes EIO.  iomap squashes /everything/ to EIO, just as XFS did before
that, but this doesn't make sense.

Fix this by making it so that we can pass ENOSPC to userspace when
writeback fails due to space problems.
Signed-off-by: default avatarDarrick J. Wong <djwong@kernel.org>
Reviewed-by: default avatarMatthew Wilcox (Oracle) <willy@infradead.org>
parent ae44f9c2
...@@ -1026,7 +1026,7 @@ iomap_finish_page_writeback(struct inode *inode, struct page *page, ...@@ -1026,7 +1026,7 @@ iomap_finish_page_writeback(struct inode *inode, struct page *page,
if (error) { if (error) {
SetPageError(page); SetPageError(page);
mapping_set_error(inode->i_mapping, -EIO); mapping_set_error(inode->i_mapping, error);
} }
WARN_ON_ONCE(i_blocks_per_page(inode, page) > 1 && !iop); WARN_ON_ONCE(i_blocks_per_page(inode, page) > 1 && !iop);
......
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