mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-11-30 23:54:04 +08:00
afs: Fix partial writeback of large files on fsync and close
In commite87b03f583
("afs: Prepare for use of THPs"), the return value for afs_write_back_from_locked_page was changed from a number of pages to a length in bytes. The loop in afs_writepages_region uses the return value to compute the index that will be used to find dirty pages in the next iteration, but treats it as a number of pages and wrongly multiplies it by PAGE_SIZE. This gives a very large index value, potentially skipping any dirty data that was not covered in the first pass, which is limited to 256M. This causes fsync(), and indirectly close(), to only do a partial writeback of a large file's dirty data. The rest is eventually written back by background threads after dirty_expire_centisecs. Fixes:e87b03f583
("afs: Prepare for use of THPs") Signed-off-by: Marc Dionne <marc.dionne@auristor.com> Signed-off-by: David Howells <dhowells@redhat.com> Reviewed-by: Jeffrey Altman <jaltman@auristor.com> cc: linux-afs@lists.infradead.org Link: https://lore.kernel.org/r/20210604175504.4055-1-marc.c.dionne@gmail.com/ Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
parent
614124bea7
commit
dc2557308e
@ -730,7 +730,7 @@ static int afs_writepages_region(struct address_space *mapping,
|
||||
return ret;
|
||||
}
|
||||
|
||||
start += ret * PAGE_SIZE;
|
||||
start += ret;
|
||||
|
||||
cond_resched();
|
||||
} while (wbc->nr_to_write > 0);
|
||||
|
Loading…
Reference in New Issue
Block a user