Commit ffda9d30 authored by Nick Piggin's avatar Nick Piggin Committed by Linus Torvalds

[PATCH] fs: fix __block_write_full_page error case buffer submission

Andrew noticed that unlocking the page before submitting all buffers for
writeout could cause problems if the IO completes before we've finished
messing around with the page buffers, and they subsequently get freed.

Even if there were no bug, it is a good idea to bring the error case
into line with the common case here.
Signed-off-by: default avatarNick Piggin <npiggin@suse.de>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent bc56bba8
...@@ -1743,7 +1743,6 @@ static int __block_write_full_page(struct inode *inode, struct page *page, ...@@ -1743,7 +1743,6 @@ static int __block_write_full_page(struct inode *inode, struct page *page,
SetPageError(page); SetPageError(page);
BUG_ON(PageWriteback(page)); BUG_ON(PageWriteback(page));
set_page_writeback(page); set_page_writeback(page);
unlock_page(page);
do { do {
struct buffer_head *next = bh->b_this_page; struct buffer_head *next = bh->b_this_page;
if (buffer_async_write(bh)) { if (buffer_async_write(bh)) {
...@@ -1753,6 +1752,7 @@ static int __block_write_full_page(struct inode *inode, struct page *page, ...@@ -1753,6 +1752,7 @@ static int __block_write_full_page(struct inode *inode, struct page *page,
} }
bh = next; bh = next;
} while (bh != head); } while (bh != head);
unlock_page(page);
goto done; goto done;
} }
......
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