xfs: remove xfs_start_page_writeback
This helper only has two callers, one of them with a constant error argument. Remove it to make pending changes to the code a little easier. Signed-off-by: Christoph Hellwig <hch@lst.de> Reviewed-by: Brian Foster <bfoster@redhat.com> Reviewed-by: Darrick J. Wong <darrick.wong@oracle.com> Signed-off-by: Darrick J. Wong <darrick.wong@oracle.com>
This commit is contained in:
parent
6d465e8953
commit
1b65d3dd2d
|
@ -494,30 +494,6 @@ allocate_blocks:
|
|||
return 0;
|
||||
}
|
||||
|
||||
STATIC void
|
||||
xfs_start_page_writeback(
|
||||
struct page *page,
|
||||
int clear_dirty)
|
||||
{
|
||||
ASSERT(PageLocked(page));
|
||||
ASSERT(!PageWriteback(page));
|
||||
|
||||
/*
|
||||
* if the page was not fully cleaned, we need to ensure that the higher
|
||||
* layers come back to it correctly. That means we need to keep the page
|
||||
* dirty, and for WB_SYNC_ALL writeback we need to ensure the
|
||||
* PAGECACHE_TAG_TOWRITE index mark is not removed so another attempt to
|
||||
* write this page in this writeback sweep will be made.
|
||||
*/
|
||||
if (clear_dirty) {
|
||||
clear_page_dirty_for_io(page);
|
||||
set_page_writeback(page);
|
||||
} else
|
||||
set_page_writeback_keepwrite(page);
|
||||
|
||||
unlock_page(page);
|
||||
}
|
||||
|
||||
/*
|
||||
* Submit the bio for an ioend. We are passed an ioend with a bio attached to
|
||||
* it, and we submit that bio. The ioend may be used for multiple bio
|
||||
|
@ -858,6 +834,8 @@ xfs_writepage_map(
|
|||
}
|
||||
|
||||
ASSERT(wpc->ioend || list_empty(&submit_list));
|
||||
ASSERT(PageLocked(page));
|
||||
ASSERT(!PageWriteback(page));
|
||||
|
||||
/*
|
||||
* On error, we have to fail the ioend here because we have locked
|
||||
|
@ -877,7 +855,21 @@ xfs_writepage_map(
|
|||
* treated correctly on error.
|
||||
*/
|
||||
if (count) {
|
||||
xfs_start_page_writeback(page, !error);
|
||||
/*
|
||||
* If the page was not fully cleaned, we need to ensure that the
|
||||
* higher layers come back to it correctly. That means we need
|
||||
* to keep the page dirty, and for WB_SYNC_ALL writeback we need
|
||||
* to ensure the PAGECACHE_TAG_TOWRITE index mark is not removed
|
||||
* so another attempt to write this page in this writeback sweep
|
||||
* will be made.
|
||||
*/
|
||||
if (error) {
|
||||
set_page_writeback_keepwrite(page);
|
||||
} else {
|
||||
clear_page_dirty_for_io(page);
|
||||
set_page_writeback(page);
|
||||
}
|
||||
unlock_page(page);
|
||||
|
||||
/*
|
||||
* Preserve the original error if there was one, otherwise catch
|
||||
|
@ -902,7 +894,9 @@ xfs_writepage_map(
|
|||
* race with a partial page truncate on a sub-page block sized
|
||||
* filesystem. In that case we need to mark the page clean.
|
||||
*/
|
||||
xfs_start_page_writeback(page, 1);
|
||||
clear_page_dirty_for_io(page);
|
||||
set_page_writeback(page);
|
||||
unlock_page(page);
|
||||
end_page_writeback(page);
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue