aboutsummaryrefslogtreecommitdiffstats
path: root/fs/btrfs/extent_io.c
diff options
context:
space:
mode:
authorChris Mason <chris.mason@oracle.com>2008-07-17 12:53:51 -0400
committerChris Mason <chris.mason@oracle.com>2008-09-25 11:04:04 -0400
commit247e743cbe6e655768c3679f84821e03c1577902 (patch)
treeedc2b27284365f019859a936885bd100960eb659 /fs/btrfs/extent_io.c
parente6dcd2dc9c489108648e2ed543315dd134d50a9a (diff)
Btrfs: Use async helpers to deal with pages that have been improperly dirtied
Higher layers sometimes call set_page_dirty without asking the filesystem to help. This causes many problems for the data=ordered and cow code. This commit detects pages that haven't been properly setup for IO and kicks off an async helper to deal with them. Signed-off-by: Chris Mason <chris.mason@oracle.com>
Diffstat (limited to 'fs/btrfs/extent_io.c')
-rw-r--r--fs/btrfs/extent_io.c10
1 files changed, 10 insertions, 0 deletions
diff --git a/fs/btrfs/extent_io.c b/fs/btrfs/extent_io.c
index 3f82a6e9ca4f..feff16cb9b40 100644
--- a/fs/btrfs/extent_io.c
+++ b/fs/btrfs/extent_io.c
@@ -2050,6 +2050,16 @@ static int __extent_writepage(struct page *page, struct writeback_control *wbc,
2050 lock_extent(tree, start, page_end, GFP_NOFS); 2050 lock_extent(tree, start, page_end, GFP_NOFS);
2051 unlock_start = start; 2051 unlock_start = start;
2052 2052
2053 if (tree->ops && tree->ops->writepage_start_hook) {
2054 ret = tree->ops->writepage_start_hook(page, start, page_end);
2055 if (ret == -EAGAIN) {
2056 unlock_extent(tree, start, page_end, GFP_NOFS);
2057 redirty_page_for_writepage(wbc, page);
2058 unlock_page(page);
2059 return 0;
2060 }
2061 }
2062
2053 end = page_end; 2063 end = page_end;
2054 if (test_range_bit(tree, start, page_end, EXTENT_DELALLOC, 0)) { 2064 if (test_range_bit(tree, start, page_end, EXTENT_DELALLOC, 0)) {
2055 printk("found delalloc bits after lock_extent\n"); 2065 printk("found delalloc bits after lock_extent\n");