]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
dm array: fix unreleased btree blocks on closing a faulty array cursor
authorMing-Hung Tsai <mtsai@redhat.com>
Thu, 5 Dec 2024 11:41:52 +0000 (19:41 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Sat, 1 Feb 2025 17:22:18 +0000 (18:22 +0100)
[ Upstream commit 626f128ee9c4133b1cfce4be2b34a1508949370e ]

The cached block pointer in dm_array_cursor might be NULL if it reaches
an unreadable array block, or the array is empty. Therefore,
dm_array_cursor_end() should call dm_btree_cursor_end() unconditionally,
to prevent leaving unreleased btree blocks.

This fix can be verified using the "array_cursor/iterate/empty" test
in dm-unit:
  dm-unit run /pdata/array_cursor/iterate/empty --kernel-dir <KERNEL_DIR>

Signed-off-by: Ming-Hung Tsai <mtsai@redhat.com>
Fixes: fdd1315aa5f0 ("dm array: introduce cursor api")
Reviewed-by: Joe Thornber <thornber@redhat.com>
Signed-off-by: Mike Snitzer <snitzer@kernel.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/md/persistent-data/dm-array.c

index 849eb1b97c4395caedc122d45112d4013d34a21a..f97de343a39848d759e66f233c5a9004eee1f847 100644 (file)
@@ -950,10 +950,10 @@ EXPORT_SYMBOL_GPL(dm_array_cursor_begin);
 
 void dm_array_cursor_end(struct dm_array_cursor *c)
 {
-       if (c->block) {
+       if (c->block)
                unlock_ablock(c->info, c->block);
-               dm_btree_cursor_end(&c->cursor);
-       }
+
+       dm_btree_cursor_end(&c->cursor);
 }
 EXPORT_SYMBOL_GPL(dm_array_cursor_end);