When machine is under heavy memory pressure, it can happen that the page we want to copy data from is paged out from memory before we copy data from it and thus we are called with copied == 0. Generally, we should not file buffers into journal lists if the don't really contain uptodate data. So fix the range of buffers we file to journal list to contain only buffers with copied data. Signed-off-by: Jan Kara <jack@xxxxxxx> --- fs/ext3/inode.c | 2 +- 1 files changed, 1 insertions(+), 1 deletions(-) diff --git a/fs/ext3/inode.c b/fs/ext3/inode.c index 5fa453b..62005c0 100644 --- a/fs/ext3/inode.c +++ b/fs/ext3/inode.c @@ -1261,7 +1261,7 @@ static int ext3_ordered_write_end(struct file *file, int ret = 0, ret2; from = pos & (PAGE_CACHE_SIZE - 1); - to = from + len; + to = from + copied; ret = walk_page_buffers(handle, page_buffers(page), from, to, NULL, ext3_journal_dirty_data); -- 1.6.0.2 -- To unsubscribe from this list: send the line "unsubscribe linux-ext4" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html