]> git.ipfire.org Git - thirdparty/kernel/stable.git/commit
dm btree: fix order of block initialization in btree_split_beneath
authorZhangXiaoxu <zhangxiaoxu5@huawei.com>
Sat, 17 Aug 2019 05:32:40 +0000 (13:32 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 29 Aug 2019 06:26:44 +0000 (08:26 +0200)
commit09f142a8591c3310a64f98c8e0e2d7f99b986eab
tree0cc94c880859ec8cacf2399be76b1b2d3b0a98fa
parent8e64ca30aefc1fa8810529e5f654a80ae868ed07
dm btree: fix order of block initialization in btree_split_beneath

commit e4f9d6013820d1eba1432d51dd1c5795759aa77f upstream.

When btree_split_beneath() splits a node to two new children, it will
allocate two blocks: left and right.  If right block's allocation
failed, the left block will be unlocked and marked dirty.  If this
happened, the left block'ss content is zero, because it wasn't
initialized with the btree struct before the attempot to allocate the
right block.  Upon return, when flushing the left block to disk, the
validator will fail when check this block.  Then a BUG_ON is raised.

Fix this by completely initializing the left block before allocating and
initializing the right block.

Fixes: 4dcb8b57df359 ("dm btree: fix leak of bufio-backed block in btree_split_beneath error path")
Cc: stable@vger.kernel.org
Signed-off-by: ZhangXiaoxu <zhangxiaoxu5@huawei.com>
Signed-off-by: Mike Snitzer <snitzer@redhat.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/md/persistent-data/dm-btree.c