From: Joe Thornber Date: Wed, 24 Nov 2021 17:07:39 +0000 (-0500) Subject: dm btree remove: fix use after free in rebalance_children() X-Git-Tag: accepted/tizen/unified/20230118.172025~4205 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=607beb420b3fe23b948a9bf447d993521a02fbbb;p=platform%2Fkernel%2Flinux-rpi.git dm btree remove: fix use after free in rebalance_children() commit 1b8d2789dad0005fd5e7d35dab26a8e1203fb6da upstream. Move dm_tm_unlock() after dm_tm_dec(). Cc: stable@vger.kernel.org Signed-off-by: Joe Thornber Signed-off-by: Mike Snitzer Signed-off-by: Greg Kroah-Hartman --- diff --git a/drivers/md/persistent-data/dm-btree-remove.c b/drivers/md/persistent-data/dm-btree-remove.c index 7053233..cb670f1 100644 --- a/drivers/md/persistent-data/dm-btree-remove.c +++ b/drivers/md/persistent-data/dm-btree-remove.c @@ -423,9 +423,9 @@ static int rebalance_children(struct shadow_spine *s, memcpy(n, dm_block_data(child), dm_bm_block_size(dm_tm_get_bm(info->tm))); - dm_tm_unlock(info->tm, child); dm_tm_dec(info->tm, dm_block_location(child)); + dm_tm_unlock(info->tm, child); return 0; }