]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
ext4: set type of ac_groups_linear_remaining to __u32 to avoid overflow
authorBaokun Li <libaokun1@huawei.com>
Tue, 19 Mar 2024 11:33:23 +0000 (19:33 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Sun, 16 Jun 2024 11:47:44 +0000 (13:47 +0200)
commit 9a9f3a9842927e4af7ca10c19c94dad83bebd713 upstream.

Now ac_groups_linear_remaining is of type __u16 and s_mb_max_linear_groups
is of type unsigned int, so an overflow occurs when setting a value above
65535 through the mb_max_linear_groups sysfs interface. Therefore, the
type of ac_groups_linear_remaining is set to __u32 to avoid overflow.

Fixes: 196e402adf2e ("ext4: improve cr 0 / cr 1 group scanning")
CC: stable@kernel.org
Signed-off-by: Baokun Li <libaokun1@huawei.com>
Reviewed-by: Zhang Yi <yi.zhang@huawei.com>
Reviewed-by: Jan Kara <jack@suse.cz>
Link: https://lore.kernel.org/r/20240319113325.3110393-8-libaokun1@huawei.com
Signed-off-by: Theodore Ts'o <tytso@mit.edu>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
fs/ext4/mballoc.h

index d7aeb5da7d86768c10efdc7ef38b4a6cee38ca78..498af2abc5d885f8fd223e598dc280eac1456cc6 100644 (file)
@@ -194,8 +194,8 @@ struct ext4_allocation_context {
 
        __u32 ac_groups_considered;
        __u32 ac_flags;         /* allocation hints */
+       __u32 ac_groups_linear_remaining;
        __u16 ac_groups_scanned;
-       __u16 ac_groups_linear_remaining;
        __u16 ac_found;
        __u16 ac_cX_found[EXT4_MB_NUM_CRS];
        __u16 ac_tail;