Commit 1ae48a63 authored by Jan Kara's avatar Jan Kara Committed by Theodore Ts'o

ext4: use redirty_page_for_writepage() in ext4_bio_write_page()

When we cannot write a page we should use redirty_page_for_writepage()
instead of plain set_page_dirty(). That tells writeback code we have
problems, redirties only the page (redirtying buffers is not needed),
and updates mm accounting of failed page writes.

Also move clearing of buffer dirty flag after io_submit_add_bh(). At that
moment we are sure buffer will be going to disk.
Signed-off-by: default avatarJan Kara <jack@suse.cz>
Signed-off-by: default avatar"Theodore Ts'o" <tytso@mit.edu>
parent 36ade451
...@@ -23,6 +23,7 @@ ...@@ -23,6 +23,7 @@
#include <linux/workqueue.h> #include <linux/workqueue.h>
#include <linux/kernel.h> #include <linux/kernel.h>
#include <linux/slab.h> #include <linux/slab.h>
#include <linux/mm.h>
#include "ext4_jbd2.h" #include "ext4_jbd2.h"
#include "xattr.h" #include "xattr.h"
...@@ -434,7 +435,7 @@ int ext4_bio_write_page(struct ext4_io_submit *io, ...@@ -434,7 +435,7 @@ int ext4_bio_write_page(struct ext4_io_submit *io,
io_page = kmem_cache_alloc(io_page_cachep, GFP_NOFS); io_page = kmem_cache_alloc(io_page_cachep, GFP_NOFS);
if (!io_page) { if (!io_page) {
set_page_dirty(page); redirty_page_for_writepage(wbc, page);
unlock_page(page); unlock_page(page);
return -ENOMEM; return -ENOMEM;
} }
...@@ -466,7 +467,6 @@ int ext4_bio_write_page(struct ext4_io_submit *io, ...@@ -466,7 +467,6 @@ int ext4_bio_write_page(struct ext4_io_submit *io,
set_buffer_uptodate(bh); set_buffer_uptodate(bh);
continue; continue;
} }
clear_buffer_dirty(bh);
ret = io_submit_add_bh(io, io_page, inode, wbc, bh); ret = io_submit_add_bh(io, io_page, inode, wbc, bh);
if (ret) { if (ret) {
/* /*
...@@ -474,9 +474,10 @@ int ext4_bio_write_page(struct ext4_io_submit *io, ...@@ -474,9 +474,10 @@ int ext4_bio_write_page(struct ext4_io_submit *io,
* we can do but mark the page as dirty, and * we can do but mark the page as dirty, and
* better luck next time. * better luck next time.
*/ */
set_page_dirty(page); redirty_page_for_writepage(wbc, page);
break; break;
} }
clear_buffer_dirty(bh);
} }
unlock_page(page); unlock_page(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