diff options
author | Chris Mason <chris.mason@oracle.com> | 2008-07-17 12:53:51 -0400 |
---|---|---|
committer | Chris Mason <chris.mason@oracle.com> | 2008-09-25 11:04:04 -0400 |
commit | 247e743cbe6e655768c3679f84821e03c1577902 (patch) | |
tree | edc2b27284365f019859a936885bd100960eb659 /fs/btrfs/disk-io.c | |
parent | e6dcd2dc9c489108648e2ed543315dd134d50a9a (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/disk-io.c')
-rw-r--r-- | fs/btrfs/disk-io.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/fs/btrfs/disk-io.c b/fs/btrfs/disk-io.c index 4a5ebafb935a..66466d125c05 100644 --- a/fs/btrfs/disk-io.c +++ b/fs/btrfs/disk-io.c | |||
@@ -1329,11 +1329,13 @@ struct btrfs_root *open_ctree(struct super_block *sb, | |||
1329 | */ | 1329 | */ |
1330 | btrfs_init_workers(&fs_info->workers, fs_info->thread_pool_size); | 1330 | btrfs_init_workers(&fs_info->workers, fs_info->thread_pool_size); |
1331 | btrfs_init_workers(&fs_info->submit_workers, fs_info->thread_pool_size); | 1331 | btrfs_init_workers(&fs_info->submit_workers, fs_info->thread_pool_size); |
1332 | btrfs_init_workers(&fs_info->fixup_workers, 1); | ||
1332 | btrfs_init_workers(&fs_info->endio_workers, fs_info->thread_pool_size); | 1333 | btrfs_init_workers(&fs_info->endio_workers, fs_info->thread_pool_size); |
1333 | btrfs_init_workers(&fs_info->endio_write_workers, | 1334 | btrfs_init_workers(&fs_info->endio_write_workers, |
1334 | fs_info->thread_pool_size); | 1335 | fs_info->thread_pool_size); |
1335 | btrfs_start_workers(&fs_info->workers, 1); | 1336 | btrfs_start_workers(&fs_info->workers, 1); |
1336 | btrfs_start_workers(&fs_info->submit_workers, 1); | 1337 | btrfs_start_workers(&fs_info->submit_workers, 1); |
1338 | btrfs_start_workers(&fs_info->fixup_workers, 1); | ||
1337 | btrfs_start_workers(&fs_info->endio_workers, fs_info->thread_pool_size); | 1339 | btrfs_start_workers(&fs_info->endio_workers, fs_info->thread_pool_size); |
1338 | btrfs_start_workers(&fs_info->endio_write_workers, | 1340 | btrfs_start_workers(&fs_info->endio_write_workers, |
1339 | fs_info->thread_pool_size); | 1341 | fs_info->thread_pool_size); |
@@ -1454,6 +1456,7 @@ fail_tree_root: | |||
1454 | fail_sys_array: | 1456 | fail_sys_array: |
1455 | fail_sb_buffer: | 1457 | fail_sb_buffer: |
1456 | extent_io_tree_empty_lru(&BTRFS_I(fs_info->btree_inode)->io_tree); | 1458 | extent_io_tree_empty_lru(&BTRFS_I(fs_info->btree_inode)->io_tree); |
1459 | btrfs_stop_workers(&fs_info->fixup_workers); | ||
1457 | btrfs_stop_workers(&fs_info->workers); | 1460 | btrfs_stop_workers(&fs_info->workers); |
1458 | btrfs_stop_workers(&fs_info->endio_workers); | 1461 | btrfs_stop_workers(&fs_info->endio_workers); |
1459 | btrfs_stop_workers(&fs_info->endio_write_workers); | 1462 | btrfs_stop_workers(&fs_info->endio_write_workers); |
@@ -1710,6 +1713,7 @@ int close_ctree(struct btrfs_root *root) | |||
1710 | 1713 | ||
1711 | truncate_inode_pages(fs_info->btree_inode->i_mapping, 0); | 1714 | truncate_inode_pages(fs_info->btree_inode->i_mapping, 0); |
1712 | 1715 | ||
1716 | btrfs_stop_workers(&fs_info->fixup_workers); | ||
1713 | btrfs_stop_workers(&fs_info->workers); | 1717 | btrfs_stop_workers(&fs_info->workers); |
1714 | btrfs_stop_workers(&fs_info->endio_workers); | 1718 | btrfs_stop_workers(&fs_info->endio_workers); |
1715 | btrfs_stop_workers(&fs_info->endio_write_workers); | 1719 | btrfs_stop_workers(&fs_info->endio_write_workers); |