]> git.itanic.dy.fi Git - linux-stable/commitdiff
ext4: fix lost error code reporting in __ext4_fill_super()
authorTheodore Ts'o <tytso@mit.edu>
Thu, 27 Apr 2023 23:18:01 +0000 (19:18 -0400)
committerTheodore Ts'o <tytso@mit.edu>
Fri, 28 Apr 2023 16:56:40 +0000 (12:56 -0400)
When code was factored out of __ext4_fill_super() into
ext4_percpu_param_init() the error return was discarded.  This meant
that it was possible for __ext4_fill_super() to return zero,
indicating success, without the struct super getting completely filled
in, leading to a potential NULL pointer dereference.

Reported-by: syzbot+bbf0f9a213c94f283a5c@syzkaller.appspotmail.com
Fixes: 1f79467c8a6b ("ext4: factor out ext4_percpu_param_init() ...")
Link: https://syzkaller.appspot.com/bug?id=6dac47d5e58af770c0055f680369586ec32e144c
Signed-off-by: Theodore Ts'o <tytso@mit.edu>
Reviewed-by: Jason Yan <yanaijie@huawei.com>
fs/ext4/super.c

index f16492b8c98d622edc3cdeac029b6004b5a7979e..8ed6450effaa3b542f7810a247932fe1891f3dab 100644 (file)
@@ -5502,7 +5502,8 @@ static int __ext4_fill_super(struct fs_context *fc, struct super_block *sb)
                sbi->s_journal->j_commit_callback =
                        ext4_journal_commit_callback;
 
-       if (ext4_percpu_param_init(sbi))
+       err = ext4_percpu_param_init(sbi);
+       if (err)
                goto failed_mount6;
 
        if (ext4_has_feature_flex_bg(sb))