]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
ext4: fix leaking sysfs kobject after failed mount
authorEric Biggers <ebiggers@google.com>
Tue, 22 Sep 2020 16:24:56 +0000 (09:24 -0700)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 18 Nov 2020 17:25:04 +0000 (18:25 +0100)
commit cb8d53d2c97369029cc638c9274ac7be0a316c75 upstream.

ext4_unregister_sysfs() only deletes the kobject.  The reference to it
needs to be put separately, like ext4_put_super() does.

This addresses the syzbot report
"memory leak in kobject_set_name_vargs (3)"
(https://syzkaller.appspot.com/bug?extid=9f864abad79fae7c17e1).

Reported-by: syzbot+9f864abad79fae7c17e1@syzkaller.appspotmail.com
Fixes: 72ba74508b28 ("ext4: release sysfs kobject when failing to enable quotas on mount")
Cc: stable@vger.kernel.org
Signed-off-by: Eric Biggers <ebiggers@google.com>
Link: https://lore.kernel.org/r/20200922162456.93657-1-ebiggers@kernel.org
Reviewed-by: Jan Kara <jack@suse.cz>
Signed-off-by: Theodore Ts'o <tytso@mit.edu>
[sudip: adjust context]
Signed-off-by: Sudip Mukherjee <sudipm.mukherjee@gmail.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
fs/ext4/super.c

index bcd91512bd490142d6dbee1cfc585d20741267a5..7a5a1602ee01d8e07aaf260883d71dc24ea880fe 100644 (file)
@@ -4168,6 +4168,7 @@ cantfind_ext4:
 #ifdef CONFIG_QUOTA
 failed_mount8:
        ext4_unregister_sysfs(sb);
+       kobject_put(&sbi->s_kobj);
 #endif
 failed_mount7:
        ext4_unregister_li_request(sb);