diff options
author | Chris Mason <clm@fb.com> | 2015-04-24 11:00:00 -0700 |
---|---|---|
committer | Chris Mason <clm@fb.com> | 2015-04-24 11:52:25 -0700 |
commit | a3bdccc4e683f0ac69230707ed3fa20e7cf73a79 (patch) | |
tree | 7cec1e92ccfa9fc236190810acb55f025e480d9d /drivers/iio/buffer_cb.c | |
parent | 85db36cfb3de1422aeafb4e2ce83396333b744bb (diff) | |
download | linux-a3bdccc4e683f0ac69230707ed3fa20e7cf73a79.tar.bz2 |
Btrfs: prevent list corruption during free space cache processing
__btrfs_write_out_cache is holding the ctl->tree_lock while it prepares
a list of bitmaps to record in the free space cache. It was dropping
the lock while it worked on other components, which made a window for
free_bitmap() to free the bitmap struct without removing it from the
list.
This changes things to hold the lock the whole time, and also makes sure
we hold the lock during enospc cleanup.
Reported-by: Filipe Manana <fdmanana@suse.com>
Signed-off-by: Chris Mason <clm@fb.com>
Diffstat (limited to 'drivers/iio/buffer_cb.c')
0 files changed, 0 insertions, 0 deletions