WSL2-Linux-Kernel/drivers/md/bcache
Matthew Mirvish 5a1922adc5 bcache: fix variable length array abuse in btree_iter
[ Upstream commit 3a861560ccb35f2a4f0a4b8207fa7c2a35fc7f31 ]

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>
Signed-off-by: Sasha Levin <sashal@kernel.org>
2024-07-05 09:14:36 +02:00
..
Kconfig
Makefile
alloc.c
bcache.h bcache: avoid oversize memory allocation by small stripe_size 2023-12-20 15:17:39 +01:00
bset.c bcache: fix variable length array abuse in btree_iter 2024-07-05 09:14:36 +02:00
bset.h bcache: fix variable length array abuse in btree_iter 2024-07-05 09:14:36 +02:00
btree.c bcache: fix variable length array abuse in btree_iter 2024-07-05 09:14:36 +02:00
btree.h bcache: fixup btree_cache_wait list damage 2023-07-23 13:47:32 +02:00
closure.c
closure.h
debug.c
debug.h
extents.c
extents.h
features.c
features.h
io.c
journal.c bcache: avoid journal no-space deadlock by reserving 1 journal bucket 2022-06-09 10:23:29 +02:00
journal.h bcache: avoid journal no-space deadlock by reserving 1 journal bucket 2022-06-09 10:23:29 +02:00
movinggc.c
request.c md: bcache: check the return value of kzalloc() in detached_dev_do_request() 2022-06-09 10:23:32 +02:00
request.h
stats.c
stats.h
super.c bcache: fix variable length array abuse in btree_iter 2024-07-05 09:14:36 +02:00
sysfs.c bcache: fix variable length array abuse in btree_iter 2024-07-05 09:14:36 +02:00
sysfs.h
trace.c
util.c
util.h
writeback.c bcache: fix variable length array abuse in btree_iter 2024-07-05 09:14:36 +02:00
writeback.h bcache: improve multithreaded bch_sectors_dirty_init() 2022-06-09 10:23:28 +02:00