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, 28 Feb 2022 15:19:51 +0000 (16:19 +0100)
commit7d6d952ce2df806abe4774da84bff249035b2961
treefd73ec2ecab4691425cb2b7331978e921b1aa7f3
parent4ef205ebc6fffd2085ace09ddd32e03b4837cbaf
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