Commit 420e05d0 authored by Matthew Wilcox (Oracle)'s avatar Matthew Wilcox (Oracle) Committed by Andrew Morton

fs: remove calls to set and clear the folio error flag

Nobody checks the folio error flag any more, so we can stop setting and
clearing it.  Also remove the documentation suggesting to not bother
setting the error bit.

Link: https://lkml.kernel.org/r/20240807193528.1865100-1-willy@infradead.orgSigned-off-by: default avatarMatthew Wilcox (Oracle) <willy@infradead.org>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
parent 62e73fd8
...@@ -913,8 +913,7 @@ cache in your filesystem. The following members are defined: ...@@ -913,8 +913,7 @@ cache in your filesystem. The following members are defined:
stop attempting I/O, it can simply return. The caller will stop attempting I/O, it can simply return. The caller will
remove the remaining pages from the address space, unlock them remove the remaining pages from the address space, unlock them
and decrement the page refcount. Set PageUptodate if the I/O and decrement the page refcount. Set PageUptodate if the I/O
completes successfully. Setting PageError on any page will be completes successfully.
ignored; simply unlock the page if an I/O error occurs.
``write_begin`` ``write_begin``
Called by the generic buffered write code to ask the filesystem Called by the generic buffered write code to ask the filesystem
......
...@@ -530,7 +530,6 @@ static void __filemap_fdatawait_range(struct address_space *mapping, ...@@ -530,7 +530,6 @@ static void __filemap_fdatawait_range(struct address_space *mapping,
struct folio *folio = fbatch.folios[i]; struct folio *folio = fbatch.folios[i];
folio_wait_writeback(folio); folio_wait_writeback(folio);
folio_clear_error(folio);
} }
folio_batch_release(&fbatch); folio_batch_release(&fbatch);
cond_resched(); cond_resched();
...@@ -2342,13 +2341,6 @@ static int filemap_read_folio(struct file *file, filler_t filler, ...@@ -2342,13 +2341,6 @@ static int filemap_read_folio(struct file *file, filler_t filler,
unsigned long pflags; unsigned long pflags;
int error; int error;
/*
* A previous I/O error may have been due to temporary failures,
* eg. multipath errors. PG_error will be set again if read_folio
* fails.
*/
folio_clear_error(folio);
/* Start the actual read. The read will unlock the page. */ /* Start the actual read. The read will unlock the page. */
if (unlikely(workingset)) if (unlikely(workingset))
psi_memstall_enter(&pflags); psi_memstall_enter(&pflags);
......
...@@ -586,8 +586,6 @@ void folio_migrate_flags(struct folio *newfolio, struct folio *folio) ...@@ -586,8 +586,6 @@ void folio_migrate_flags(struct folio *newfolio, struct folio *folio)
{ {
int cpupid; int cpupid;
if (folio_test_error(folio))
folio_set_error(newfolio);
if (folio_test_referenced(folio)) if (folio_test_referenced(folio))
folio_set_referenced(newfolio); folio_set_referenced(newfolio);
if (folio_test_uptodate(folio)) if (folio_test_uptodate(folio))
......
...@@ -273,9 +273,7 @@ static void sio_write_complete(struct kiocb *iocb, long ret) ...@@ -273,9 +273,7 @@ static void sio_write_complete(struct kiocb *iocb, long ret)
* memory for allocating transmit buffers. * memory for allocating transmit buffers.
* Mark the page dirty and avoid * Mark the page dirty and avoid
* folio_rotate_reclaimable but rate-limit the * folio_rotate_reclaimable but rate-limit the
* messages but do not flag PageError like * messages.
* the normal direct-to-bio case as it could
* be temporary.
*/ */
pr_err_ratelimited("Write error %ld on dio swapfile (%llu)\n", pr_err_ratelimited("Write error %ld on dio swapfile (%llu)\n",
ret, swap_dev_pos(page_swap_entry(page))); ret, swap_dev_pos(page_swap_entry(page)));
......
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