ext4: handle EOF correctly in ext4_bio_write_page()
We need to zero out part of a page which beyond EOF before setting uptodate, otherwise, mapread or write will see non-zero data beyond EOF. Signed-off-by: Yongqiang Yang <xiaoqiangnk@gmail.com> Signed-off-by: "Theodore Ts'o" <tytso@mit.edu> Cc: stable@kernel.org
This commit is contained in:
parent
5b5ffa49d4
commit
5a0dc7365c
@ -385,6 +385,18 @@ int ext4_bio_write_page(struct ext4_io_submit *io,
|
|||||||
|
|
||||||
block_end = block_start + blocksize;
|
block_end = block_start + blocksize;
|
||||||
if (block_start >= len) {
|
if (block_start >= len) {
|
||||||
|
/*
|
||||||
|
* Comments copied from block_write_full_page_endio:
|
||||||
|
*
|
||||||
|
* The page straddles i_size. It must be zeroed out on
|
||||||
|
* each and every writepage invocation because it may
|
||||||
|
* be mmapped. "A file is mapped in multiples of the
|
||||||
|
* page size. For a file that is not a multiple of
|
||||||
|
* the page size, the remaining memory is zeroed when
|
||||||
|
* mapped, and writes to that region are not written
|
||||||
|
* out to the file."
|
||||||
|
*/
|
||||||
|
zero_user_segment(page, block_start, block_end);
|
||||||
clear_buffer_dirty(bh);
|
clear_buffer_dirty(bh);
|
||||||
set_buffer_uptodate(bh);
|
set_buffer_uptodate(bh);
|
||||||
continue;
|
continue;
|
||||||
|
Loading…
Reference in New Issue
Block a user