diff options
author | Chris Mason <clm@fb.com> | 2017-02-27 16:11:53 -0500 |
---|---|---|
committer | Chris Mason <clm@fb.com> | 2017-02-27 16:11:53 -0500 |
commit | ef6ebf324216eaea95ff30da5a8e78e2a4311eba (patch) | |
tree | 5357c0d811540028845a3e303a1bf2101b9a22a6 /fs/btrfs/disk-io.c | |
parent | 6288d6eabc7505f42dda34a2c2962f91914be3a4 (diff) | |
parent | 263d3995c93c6020576f6c93506412a0b9d1e932 (diff) |
Merge branch 'for-chris-4.11' of git://git.kernel.org/pub/scm/linux/kernel/git/fdmanana/linux into for-linus-4.11
Diffstat (limited to 'fs/btrfs/disk-io.c')
-rw-r--r-- | fs/btrfs/disk-io.c | 15 |
1 files changed, 10 insertions, 5 deletions
diff --git a/fs/btrfs/disk-io.c b/fs/btrfs/disk-io.c index 2b06f557c176..32a9ec11888d 100644 --- a/fs/btrfs/disk-io.c +++ b/fs/btrfs/disk-io.c | |||
@@ -2205,11 +2205,9 @@ static void btrfs_stop_all_workers(struct btrfs_fs_info *fs_info) | |||
2205 | btrfs_destroy_workqueue(fs_info->delalloc_workers); | 2205 | btrfs_destroy_workqueue(fs_info->delalloc_workers); |
2206 | btrfs_destroy_workqueue(fs_info->workers); | 2206 | btrfs_destroy_workqueue(fs_info->workers); |
2207 | btrfs_destroy_workqueue(fs_info->endio_workers); | 2207 | btrfs_destroy_workqueue(fs_info->endio_workers); |
2208 | btrfs_destroy_workqueue(fs_info->endio_meta_workers); | ||
2209 | btrfs_destroy_workqueue(fs_info->endio_raid56_workers); | 2208 | btrfs_destroy_workqueue(fs_info->endio_raid56_workers); |
2210 | btrfs_destroy_workqueue(fs_info->endio_repair_workers); | 2209 | btrfs_destroy_workqueue(fs_info->endio_repair_workers); |
2211 | btrfs_destroy_workqueue(fs_info->rmw_workers); | 2210 | btrfs_destroy_workqueue(fs_info->rmw_workers); |
2212 | btrfs_destroy_workqueue(fs_info->endio_meta_write_workers); | ||
2213 | btrfs_destroy_workqueue(fs_info->endio_write_workers); | 2211 | btrfs_destroy_workqueue(fs_info->endio_write_workers); |
2214 | btrfs_destroy_workqueue(fs_info->endio_freespace_worker); | 2212 | btrfs_destroy_workqueue(fs_info->endio_freespace_worker); |
2215 | btrfs_destroy_workqueue(fs_info->submit_workers); | 2213 | btrfs_destroy_workqueue(fs_info->submit_workers); |
@@ -2219,6 +2217,13 @@ static void btrfs_stop_all_workers(struct btrfs_fs_info *fs_info) | |||
2219 | btrfs_destroy_workqueue(fs_info->flush_workers); | 2217 | btrfs_destroy_workqueue(fs_info->flush_workers); |
2220 | btrfs_destroy_workqueue(fs_info->qgroup_rescan_workers); | 2218 | btrfs_destroy_workqueue(fs_info->qgroup_rescan_workers); |
2221 | btrfs_destroy_workqueue(fs_info->extent_workers); | 2219 | btrfs_destroy_workqueue(fs_info->extent_workers); |
2220 | /* | ||
2221 | * Now that all other work queues are destroyed, we can safely destroy | ||
2222 | * the queues used for metadata I/O, since tasks from those other work | ||
2223 | * queues can do metadata I/O operations. | ||
2224 | */ | ||
2225 | btrfs_destroy_workqueue(fs_info->endio_meta_workers); | ||
2226 | btrfs_destroy_workqueue(fs_info->endio_meta_write_workers); | ||
2222 | } | 2227 | } |
2223 | 2228 | ||
2224 | static void free_root_extent_buffers(struct btrfs_root *root) | 2229 | static void free_root_extent_buffers(struct btrfs_root *root) |
@@ -3261,7 +3266,6 @@ fail_fsdev_sysfs: | |||
3261 | 3266 | ||
3262 | fail_block_groups: | 3267 | fail_block_groups: |
3263 | btrfs_put_block_group_cache(fs_info); | 3268 | btrfs_put_block_group_cache(fs_info); |
3264 | btrfs_free_block_groups(fs_info); | ||
3265 | 3269 | ||
3266 | fail_tree_roots: | 3270 | fail_tree_roots: |
3267 | free_root_pointers(fs_info, 1); | 3271 | free_root_pointers(fs_info, 1); |
@@ -3269,6 +3273,7 @@ fail_tree_roots: | |||
3269 | 3273 | ||
3270 | fail_sb_buffer: | 3274 | fail_sb_buffer: |
3271 | btrfs_stop_all_workers(fs_info); | 3275 | btrfs_stop_all_workers(fs_info); |
3276 | btrfs_free_block_groups(fs_info); | ||
3272 | fail_alloc: | 3277 | fail_alloc: |
3273 | fail_iput: | 3278 | fail_iput: |
3274 | btrfs_mapping_tree_free(&fs_info->mapping_tree); | 3279 | btrfs_mapping_tree_free(&fs_info->mapping_tree); |
@@ -3977,8 +3982,6 @@ void close_ctree(struct btrfs_fs_info *fs_info) | |||
3977 | 3982 | ||
3978 | btrfs_put_block_group_cache(fs_info); | 3983 | btrfs_put_block_group_cache(fs_info); |
3979 | 3984 | ||
3980 | btrfs_free_block_groups(fs_info); | ||
3981 | |||
3982 | /* | 3985 | /* |
3983 | * we must make sure there is not any read request to | 3986 | * we must make sure there is not any read request to |
3984 | * submit after we stopping all workers. | 3987 | * submit after we stopping all workers. |
@@ -3986,6 +3989,8 @@ void close_ctree(struct btrfs_fs_info *fs_info) | |||
3986 | invalidate_inode_pages2(fs_info->btree_inode->i_mapping); | 3989 | invalidate_inode_pages2(fs_info->btree_inode->i_mapping); |
3987 | btrfs_stop_all_workers(fs_info); | 3990 | btrfs_stop_all_workers(fs_info); |
3988 | 3991 | ||
3992 | btrfs_free_block_groups(fs_info); | ||
3993 | |||
3989 | clear_bit(BTRFS_FS_OPEN, &fs_info->flags); | 3994 | clear_bit(BTRFS_FS_OPEN, &fs_info->flags); |
3990 | free_root_pointers(fs_info, 1); | 3995 | free_root_pointers(fs_info, 1); |
3991 | 3996 | ||