diff options
author | Matthew Mirvish <matthew@mm12.xyz> | 2024-05-09 03:11:17 +0200 |
---|---|---|
committer | Jens Axboe <axboe@kernel.dk> | 2024-05-09 03:15:01 +0200 |
commit | 3a861560ccb35f2a4f0a4b8207fa7c2a35fc7f31 (patch) | |
tree | abaed8a75822748de1e372b1ae2a828a8545468d /drivers/md/bcache/sysfs.c | |
parent | bcache: Remove usage of the deprecated ida_simple_xx() API (diff) | |
download | linux-3a861560ccb35f2a4f0a4b8207fa7c2a35fc7f31.tar.xz linux-3a861560ccb35f2a4f0a4b8207fa7c2a35fc7f31.zip |
bcache: fix variable length array abuse in btree_iter
btree_iter is used in two ways: either allocated on the stack with a
fixed size MAX_BSETS, or from a mempool with a dynamic size based on the
specific cache set. Previously, the struct had a fixed-length array of
size MAX_BSETS which was indexed out-of-bounds for the dynamically-sized
iterators, which causes UBSAN to complain.
This patch uses the same approach as in bcachefs's sort_iter and splits
the iterator into a btree_iter with a flexible array member and a
btree_iter_stack which embeds a btree_iter as well as a fixed-length
data array.
Cc: stable@vger.kernel.org
Closes: https://bugs.launchpad.net/ubuntu/+source/linux/+bug/2039368
Signed-off-by: Matthew Mirvish <matthew@mm12.xyz>
Signed-off-by: Coly Li <colyli@suse.de>
Link: https://lore.kernel.org/r/20240509011117.2697-3-colyli@suse.de
Signed-off-by: Jens Axboe <axboe@kernel.dk>
Diffstat (limited to 'drivers/md/bcache/sysfs.c')
-rw-r--r-- | drivers/md/bcache/sysfs.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/md/bcache/sysfs.c b/drivers/md/bcache/sysfs.c index 6956beb55326..826b14cae4e5 100644 --- a/drivers/md/bcache/sysfs.c +++ b/drivers/md/bcache/sysfs.c @@ -660,7 +660,7 @@ static unsigned int bch_root_usage(struct cache_set *c) unsigned int bytes = 0; struct bkey *k; struct btree *b; - struct btree_iter iter; + struct btree_iter_stack iter; goto lock_root; |