filemap: remove PageHWPoison check from next_uptodate_page()
Pages are individually marked as suffering from hardware poisoning. Checking that the head page is not hardware poisoned doesn't make sense; we might be after a subpage. We check each page individually before we use it, so this was an optimisation gone wrong. It will cause us to fall back to the slow path when there was no need to do that Link: https://lkml.kernel.org/r/20211120174429.2596303-1-willy@infradead.org Signed-off-by: Matthew Wilcox (Oracle) <willy@infradead.org> Reviewed-by: Naoya Horiguchi <naoya.horiguchi@nec.com> Cc: Yang Shi <shy828301@gmail.com> Cc: "Kirill A . Shutemov" <kirill.shutemov@linux.intel.com> Cc: Hugh Dickins <hughd@google.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
parent
d020d9e63d
commit
0c941cf30b
@ -3253,8 +3253,6 @@ static struct page *next_uptodate_page(struct page *page,
|
|||||||
goto skip;
|
goto skip;
|
||||||
if (!PageUptodate(page) || PageReadahead(page))
|
if (!PageUptodate(page) || PageReadahead(page))
|
||||||
goto skip;
|
goto skip;
|
||||||
if (PageHWPoison(page))
|
|
||||||
goto skip;
|
|
||||||
if (!trylock_page(page))
|
if (!trylock_page(page))
|
||||||
goto skip;
|
goto skip;
|
||||||
if (page->mapping != mapping)
|
if (page->mapping != mapping)
|
||||||
|
Loading…
Reference in New Issue
Block a user