|
@@ -385,6 +385,18 @@ int ext4_bio_write_page(struct ext4_io_submit *io,
|
|
|
|
|
|
block_end = block_start + blocksize;
|
|
|
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);
|
|
|
set_buffer_uptodate(bh);
|
|
|
continue;
|