summaryrefslogtreecommitdiff
path: root/mm/readahead.c
diff options
context:
space:
mode:
authorMatthew Wilcox (Oracle) <willy@infradead.org>2022-05-03 00:09:31 -0400
committerMatthew Wilcox (Oracle) <willy@infradead.org>2022-05-05 00:47:29 -0400
commit170f37d6aa6ad4582eefd7459015de79e244536e (patch)
treeef00e910fd14cf1e14dd739d00575127b6655df1 /mm/readahead.c
parenta7391ad3572431a354c927cf8896e86e50d7d0bf (diff)
downloadlwn-170f37d6aa6ad4582eefd7459015de79e244536e.tar.gz
lwn-170f37d6aa6ad4582eefd7459015de79e244536e.zip
block: Do not call folio_next() on an unreferenced folio
It is unsafe to call folio_next() on a folio unless you hold a reference on it that prevents it from being split or freed. After returning from the iterator, iomap calls folio_end_writeback() which may drop the last reference to the page, or allow the page to be split. If that happens, the iterator will not advance far enough through the bio_vec, leading to assertion failures like the BUG() in folio_end_writeback() that checks we're not trying to end writeback on a page not currently under writeback. Other assertion failures were also seen, but they're all explained by this one bug. Fix the bug by remembering where the next folio starts before returning from the iterator. There are other ways of fixing this bug, but this seems the simplest. Reported-by: Darrick J. Wong <djwong@kernel.org> Tested-by: Darrick J. Wong <djwong@kernel.org> Reported-by: Brian Foster <bfoster@redhat.com> Tested-by: Brian Foster <bfoster@redhat.com> Signed-off-by: Matthew Wilcox (Oracle) <willy@infradead.org>
Diffstat (limited to 'mm/readahead.c')
0 files changed, 0 insertions, 0 deletions