linux-uconsole/fs/ext4
Theodore Ts'o 100c0ad6c0 ext4: allow ext4_get_group_info() to fail
[ Upstream commit 5354b2af34 ]

Previously, ext4_get_group_info() would treat an invalid group number
as BUG(), since in theory it should never happen.  However, if a
malicious attaker (or fuzzer) modifies the superblock via the block
device while it is the file system is mounted, it is possible for
s_first_data_block to get set to a very large number.  In that case,
when calculating the block group of some block number (such as the
starting block of a preallocation region), could result in an
underflow and very large block group number.  Then the BUG_ON check in
ext4_get_group_info() would fire, resutling in a denial of service
attack that can be triggered by root or someone with write access to
the block device.

For a quality of implementation perspective, it's best that even if
the system administrator does something that they shouldn't, that it
will not trigger a BUG.  So instead of BUG'ing, ext4_get_group_info()
will call ext4_error and return NULL.  We also add fallback code in
all of the callers of ext4_get_group_info() that it might NULL.

Also, since ext4_get_group_info() was already borderline to be an
inline function, un-inline it.  The results in a next reduction of the
compiled text size of ext4 by roughly 2k.

Cc: stable@kernel.org
Link: https://lore.kernel.org/r/20230430154311.579720-2-tytso@mit.edu
Reported-by: syzbot+e2efa3efc15a1c9e95c3@syzkaller.appspotmail.com
Link: https://syzkaller.appspot.com/bug?id=69b28112e098b070f639efb356393af3ffec4220
Signed-off-by: Theodore Ts'o <tytso@mit.edu>
Reviewed-by: Jan Kara <jack@suse.cz>
Signed-off-by: Sasha Levin <sashal@kernel.org>
2023-05-30 12:57:47 +01:00
..
acl.c ext4: use ext4_journal_start/stop for fast commit transactions 2023-05-17 11:47:32 +02:00
acl.h
balloc.c ext4: allow ext4_get_group_info() to fail 2023-05-30 12:57:47 +01:00
bitmap.c
block_validity.c ext4: add ext4_sb_block_valid() refactored out of ext4_inode_block_valid() 2023-03-17 08:45:16 +01:00
dir.c ext4: fix potential infinite loop in ext4_dx_readdir() 2021-10-06 15:56:02 +02:00
ext4.h ext4: allow ext4_get_group_info() to fail 2023-05-30 12:57:47 +01:00
ext4_extents.h ext4: fix EXT_MAX_EXTENT/INDEX to check for zeroed eh_max 2020-06-03 23:16:49 -04:00
ext4_jbd2.c ext4: fix null-ptr-deref in '__ext4_journal_ensure_credits' 2022-01-27 10:54:28 +01:00
ext4_jbd2.h ext4: drop ext4_journal_free_reserved() 2020-06-03 23:16:53 -04:00
extents.c ext4: fix use-after-free read in ext4_find_extent for bigalloc + inline 2023-05-17 11:48:03 +02:00
extents_status.c ext4: fix data races when using cached status extents 2023-05-17 11:48:17 +02:00
extents_status.h
fast_commit.c ext4: don't set up encryption key during jbd2 transaction 2023-01-14 10:16:51 +01:00
fast_commit.h ext4: disable fast-commit of encrypted dir operations 2023-01-14 10:16:51 +01:00
file.c ext4: use ext4_journal_start/stop for fast commit transactions 2023-05-17 11:47:32 +02:00
fsmap.c ext4: fix another off-by-one fsmap error on 1k block filesystems 2023-03-17 08:45:06 +01:00
fsmap.h
fsync.c ext4: make s_mount_flags modifications atomic 2020-11-06 23:01:05 -05:00
hash.c ext4: use generic casefolding support 2020-10-28 13:43:13 -04:00
ialloc.c ext4: allow ext4_get_group_info() to fail 2023-05-30 12:57:47 +01:00
indirect.c ext4: fix various seppling typos 2023-01-14 10:16:43 +01:00
inline.c ext4: bail out of ext4_xattr_ibody_get() fails for any reason 2023-05-17 11:48:17 +02:00
inode-test.c
inode.c ext4: check iomap type only if ext4_iomap_begin() does not fail 2023-05-17 11:48:17 +02:00
ioctl.c ext4: use ext4_journal_start/stop for fast commit transactions 2023-05-17 11:47:32 +02:00
Kconfig ext: EXT4_KUNIT_TESTS should depend on EXT4_FS instead of selecting it 2021-03-04 11:38:15 +01:00
Makefile ext4 / jbd2: add fast commit initialization 2020-10-21 23:22:26 -04:00
mballoc.c ext4: allow ext4_get_group_info() to fail 2023-05-30 12:57:47 +01:00
mballoc.h ext4: fix various seppling typos 2023-01-14 10:16:43 +01:00
migrate.c ext4: fix various seppling typos 2023-01-14 10:16:43 +01:00
mmp.c ext4: fix lockdep warning when enabling MMP 2023-05-30 12:57:47 +01:00
move_extent.c ext4: use common helpers in all places reading metadata buffers 2020-10-18 10:37:14 -04:00
namei.c ext4: fix possible double unlock when moving a directory 2023-03-22 13:30:02 +01:00
page-io.c ext4: fix cgroup writeback accounting with fs-layer encryption 2023-03-17 08:45:06 +01:00
readpage.c Improvements to ext4's block allocator performance for very large file 2020-08-21 11:03:38 -07:00
resize.c ext4: fix corruption when online resizing a 1K bigalloc fs 2023-01-14 10:16:39 +01:00
super.c ext4: allow ext4_get_group_info() to fail 2023-05-30 12:57:47 +01:00
symlink.c ext4: report correct st_size for encrypted symlinks 2021-09-08 08:48:59 +02:00
sysfs.c ext4: add mballoc stats proc file 2023-05-30 12:57:47 +01:00
truncate.h
verity.c fs: ext4: initialize fsdata in pagecache_write() 2023-01-14 10:16:43 +01:00
xattr.c ext4: fix invalid free tracking in ext4_xattr_move_to_block() 2023-05-17 11:48:18 +02:00
xattr.h ext4: remove duplicate definition of ext4_xattr_ibody_inline_set() 2023-04-26 11:27:41 +02:00
xattr_hurd.c ext4: support xattr gnu.* namespace for the Hurd 2020-06-12 13:23:34 -04:00
xattr_security.c
xattr_trusted.c
xattr_user.c