btrfs: assert we have a write lock when removing and replacing extent maps
authorFilipe Manana <fdmanana@suse.com>
Thu, 3 Feb 2022 15:36:45 +0000 (15:36 +0000)
committerDavid Sterba <dsterba@suse.com>
Mon, 14 Mar 2022 12:13:50 +0000 (13:13 +0100)
commit6d3b050efa079f5bc4d5e2a8f37f0dc0345a2096
treeecceb0732de1c11c49ff354a9b6b328ec285d219
parentad3fc7946b1829213bbdbb2b9ad0d124b31ae4a7
btrfs: assert we have a write lock when removing and replacing extent maps

Removing or replacing an extent map requires holding a write lock on the
extent map's tree. We currently do that everywhere, except in one of the
self tests, where it's harmless since there's no concurrency.

In order to catch possible races in the future, assert that we are holding
a write lock on the extent map tree before removing or replacing an extent
map in the tree, and update the self test to obtain a write lock before
removing extent maps.

Reviewed-by: Johannes Thumshirn <johannes.thumshirn@wdc.com>
Signed-off-by: Filipe Manana <fdmanana@suse.com>
Signed-off-by: David Sterba <dsterba@suse.com>
fs/btrfs/extent_map.c
fs/btrfs/tests/extent-map-tests.c