linux-stable/fs/erofs
Gao Xiang dc8b6bd587 erofs: validate the extent length for uncompressed pclusters
[ Upstream commit c505feba4c ]

syzkaller reported a KASAN use-after-free:
https://syzkaller.appspot.com/bug?extid=2ae90e873e97f1faf6f2

The referenced fuzzed image actually has two issues:
 - m_pa == 0 as a non-inlined pcluster;
 - The logical length is longer than its physical length.

The first issue has already been addressed.  This patch addresses
the second issue by checking the extent length validity.

Reported-by: syzbot+2ae90e873e97f1faf6f2@syzkaller.appspotmail.com
Fixes: 02827e1796 ("staging: erofs: add erofs_map_blocks_iter")
Reviewed-by: Chao Yu <chao@kernel.org>
Signed-off-by: Gao Xiang <hsiangkao@linux.alibaba.com>
Link: https://lore.kernel.org/r/20221205150050.47784-2-hsiangkao@linux.alibaba.com
Signed-off-by: Sasha Levin <sashal@kernel.org>
2022-12-31 13:25:46 +01:00
..
Kconfig erofs: register fscache volume 2022-05-18 00:11:19 +08:00
Makefile erofs: register fscache volume 2022-05-18 00:11:19 +08:00
compress.h erofs: introduce multi-reference pclusters (fully-referenced) 2022-07-22 21:44:27 +08:00
data.c erofs: get rid of erofs_prepare_dio() helper 2022-07-22 21:46:03 +08:00
decompressor.c erofs: support interlaced uncompressed data for compressed files 2022-12-31 13:25:46 +01:00
decompressor_lzma.c erofs: wake up all waiters after z_erofs_lzma_head ready 2022-07-09 06:32:29 +08:00
dir.c erofs: update ctx->pos for every emitted dirent 2022-07-31 22:26:29 +08:00
erofs_fs.h erofs: support interlaced uncompressed data for compressed files 2022-12-31 13:25:46 +01:00
fscache.c erofs: fix missing xas_retry() in fscache mode 2022-11-26 09:27:36 +01:00
inode.c erofs: fix order >= MAX_ORDER warning due to crafted negative i_size 2022-10-21 12:37:59 +02:00
internal.h erofs: support interlaced uncompressed data for compressed files 2022-12-31 13:25:46 +01:00
namei.c erofs: make filesystem exportable 2022-05-17 23:48:54 +08:00
pcpubuf.c erofs: get rid of ->lru usage 2021-10-25 08:22:59 +08:00
super.c erofs: use kill_anon_super() to kill super in fscache mode 2022-10-21 12:38:00 +02:00
sysfs.c erofs: add 'fsid' mount option 2022-05-18 00:11:21 +08:00
tagptr.h erofs: clean up file headers & footers 2021-06-08 00:41:24 +08:00
utils.c mm: shrinkers: provide shrinkers with names 2022-07-03 18:08:40 -07:00
xattr.c erofs: use meta buffers for xattr operations 2022-01-04 23:47:08 +08:00
xattr.h erofs: use meta buffers for xattr operations 2022-01-04 23:47:08 +08:00
zdata.c erofs: Fix pcluster memleak when its block address is zero 2022-12-31 13:25:46 +01:00
zdata.h erofs: shouldn't churn the mapping page for duplicated copies 2022-10-29 10:08:33 +02:00
zmap.c erofs: validate the extent length for uncompressed pclusters 2022-12-31 13:25:46 +01:00