diff options
-rw-r--r-- | fs/btrfs/extent-tree.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/fs/btrfs/extent-tree.c b/fs/btrfs/extent-tree.c index a400951e8678..689d25ac6a68 100644 --- a/fs/btrfs/extent-tree.c +++ b/fs/btrfs/extent-tree.c | |||
@@ -2042,6 +2042,11 @@ int btrfs_discard_extent(struct btrfs_root *root, u64 bytenr, | |||
2042 | struct btrfs_bio *bbio = NULL; | 2042 | struct btrfs_bio *bbio = NULL; |
2043 | 2043 | ||
2044 | 2044 | ||
2045 | /* | ||
2046 | * Avoid races with device replace and make sure our bbio has devices | ||
2047 | * associated to its stripes that don't go away while we are discarding. | ||
2048 | */ | ||
2049 | btrfs_bio_counter_inc_blocked(root->fs_info); | ||
2045 | /* Tell the block device(s) that the sectors can be discarded */ | 2050 | /* Tell the block device(s) that the sectors can be discarded */ |
2046 | ret = btrfs_map_block(root->fs_info, REQ_DISCARD, | 2051 | ret = btrfs_map_block(root->fs_info, REQ_DISCARD, |
2047 | bytenr, &num_bytes, &bbio, 0); | 2052 | bytenr, &num_bytes, &bbio, 0); |
@@ -2074,6 +2079,7 @@ int btrfs_discard_extent(struct btrfs_root *root, u64 bytenr, | |||
2074 | } | 2079 | } |
2075 | btrfs_put_bbio(bbio); | 2080 | btrfs_put_bbio(bbio); |
2076 | } | 2081 | } |
2082 | btrfs_bio_counter_dec(root->fs_info); | ||
2077 | 2083 | ||
2078 | if (actual_bytes) | 2084 | if (actual_bytes) |
2079 | *actual_bytes = discarded_bytes; | 2085 | *actual_bytes = discarded_bytes; |