[syzbot] [mm?] [reiserfs?] kernel panic: stack is corrupted in ___slab_alloc

19 views
Skip to first unread message

syzbot

unread,
Jul 2, 2023, 1:17:58ā€ÆPM7/2/23
to 42.h...@gmail.com, ak...@linux-foundation.org, c...@linux.com, iamjoon...@lge.com, kees...@chromium.org, linux-...@vger.kernel.org, linux-h...@vger.kernel.org, linux-...@vger.kernel.org, linu...@kvack.org, pen...@kernel.org, reiserf...@vger.kernel.org, rien...@google.com, roman.g...@linux.dev, syzkall...@googlegroups.com, vba...@suse.cz
Hello,

syzbot found the following issue on:

HEAD commit: e8f75c0270d9 Merge tag 'x86_sgx_for_v6.5' of git://git.ker..
git tree: upstream
console output: https://syzkaller.appspot.com/x/log.txt?x=168b84fb280000
kernel config: https://syzkaller.appspot.com/x/.config?x=a98ec7f738e43bd4
dashboard link: https://syzkaller.appspot.com/bug?extid=cf0693aee9ea61dda749
compiler: gcc (Debian 10.2.1-6) 10.2.1 20210110, GNU ld (GNU Binutils for Debian) 2.35.2
syz repro: https://syzkaller.appspot.com/x/repro.syz?x=10310670a80000
C reproducer: https://syzkaller.appspot.com/x/repro.c?x=1220c777280000

Downloadable assets:
disk image: https://storage.googleapis.com/syzbot-assets/f27c1d41217a/disk-e8f75c02.raw.xz
vmlinux: https://storage.googleapis.com/syzbot-assets/843ae5d5c810/vmlinux-e8f75c02.xz
kernel image: https://storage.googleapis.com/syzbot-assets/da48bc4c0ec1/bzImage-e8f75c02.xz
mounted in repro: https://storage.googleapis.com/syzbot-assets/658601e354e4/mount_0.gz

IMPORTANT: if you fix the issue, please add the following tag to the commit:
Reported-by: syzbot+cf0693...@syzkaller.appspotmail.com

Kernel panic - not syncing: stack-protector: Kernel stack is corrupted in: ___slab_alloc+0x12c3/0x1400 mm/slub.c:3270
CPU: 0 PID: 5009 Comm: syz-executor248 Not tainted 6.4.0-syzkaller-01406-ge8f75c0270d9 #0
Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS Google 05/27/2023
Call Trace:
<TASK>
__dump_stack lib/dump_stack.c:88 [inline]
dump_stack_lvl+0xd9/0x150 lib/dump_stack.c:106
panic+0x686/0x730 kernel/panic.c:340
__stack_chk_fail+0x19/0x20 kernel/panic.c:759
___slab_alloc+0x12c3/0x1400 mm/slub.c:3270


---
This report is generated by a bot. It may contain errors.
See https://goo.gl/tpsmEJ for more information about syzbot.
syzbot engineers can be reached at syzk...@googlegroups.com.

syzbot will keep track of this issue. See:
https://goo.gl/tpsmEJ#status for how to communicate with syzbot.

If the bug is already fixed, let syzbot know by replying with:
#syz fix: exact-commit-title

If you want syzbot to run the reproducer, reply with:
#syz test: git://repo/address.git branch-or-commit-hash
If you attach or paste a git patch, syzbot will apply it before testing.

If you want to change bug's subsystems, reply with:
#syz set subsystems: new-subsystem
(See the list of subsystem names on the web dashboard)

If the bug is a duplicate of another bug, reply with:
#syz dup: exact-subject-of-another-report

If you want to undo deduplication, reply with:
#syz undup

David Rientjes

unread,
Jul 3, 2023, 3:14:29ā€ÆAM7/3/23
to syzbot, 42.h...@gmail.com, Andrew Morton, c...@linux.com, iamjoon...@lge.com, kees...@chromium.org, linux-...@vger.kernel.org, linux-h...@vger.kernel.org, linux-...@vger.kernel.org, linu...@kvack.org, pen...@kernel.org, reiserf...@vger.kernel.org, roman.g...@linux.dev, syzkall...@googlegroups.com, Vlastimil Babka, Jan Kara
This is happening during while mounting reiserfs, so I'm inclined to think
it's more of a reisterfs issue than a slab allocator issue :/

Dmitry Vyukov

unread,
Jul 3, 2023, 3:17:28ā€ÆAM7/3/23
to David Rientjes, syzbot, 42.h...@gmail.com, Andrew Morton, c...@linux.com, iamjoon...@lge.com, kees...@chromium.org, linux-...@vger.kernel.org, linux-h...@vger.kernel.org, linux-...@vger.kernel.org, linu...@kvack.org, pen...@kernel.org, reiserf...@vger.kernel.org, roman.g...@linux.dev, syzkall...@googlegroups.com, Vlastimil Babka, Jan Kara
Now we can make it official :)

#syz set subsystems: reiserfs

To remove from open mm issues:

https://syzkaller.appspot.com/upstream/s/mm

to reiserfs issues:

https://syzkaller.appspot.com/upstream/s/reiserfs

Lameter, Christopher

unread,
Jul 7, 2023, 4:56:11ā€ÆAM7/7/23
to Dmitry Vyukov, David Rientjes, syzbot, 42.h...@gmail.com, Andrew Morton, iamjoon...@lge.com, kees...@chromium.org, linux-...@vger.kernel.org, linux-h...@vger.kernel.org, linux-...@vger.kernel.org, linu...@kvack.org, pen...@kernel.org, reiserf...@vger.kernel.org, roman.g...@linux.dev, syzkall...@googlegroups.com, Vlastimil Babka, Jan Kara
On Mon, 3 Jul 2023, Dmitry Vyukov wrote:

>> This is happening during while mounting reiserfs, so I'm inclined to think
>> it's more of a reisterfs issue than a slab allocator issue :/

Have you tried to run with the "slub_debug" kernel option to figure out
what got corrupted?

Dmitry Vyukov

unread,
Jul 10, 2023, 3:43:50ā€ÆAM7/10/23
to Lameter, Christopher, David Rientjes, syzbot, 42.h...@gmail.com, Andrew Morton, iamjoon...@lge.com, kees...@chromium.org, linux-...@vger.kernel.org, linux-h...@vger.kernel.org, linux-...@vger.kernel.org, linu...@kvack.org, pen...@kernel.org, reiserf...@vger.kernel.org, roman.g...@linux.dev, syzkall...@googlegroups.com, Vlastimil Babka, Jan Kara
Can slub_debug detect anything that KASAN can't?
I would assume KASAN can detect more bugs (e.g. stack/globals) and
report way better. And it was already enabled in the config.

Vlastimil Babka

unread,
Jul 10, 2023, 3:48:36ā€ÆAM7/10/23
to Dmitry Vyukov, Lameter, Christopher, David Rientjes, syzbot, 42.h...@gmail.com, Andrew Morton, iamjoon...@lge.com, kees...@chromium.org, linux-...@vger.kernel.org, linux-h...@vger.kernel.org, linux-...@vger.kernel.org, linu...@kvack.org, pen...@kernel.org, reiserf...@vger.kernel.org, roman.g...@linux.dev, syzkall...@googlegroups.com, Jan Kara
On 7/10/23 09:43, Dmitry Vyukov wrote:
> On Thu, 6 Jul 2023 at 20:33, Lameter, Christopher
> <c...@os.amperecomputing.com> wrote:
>>
>> On Mon, 3 Jul 2023, Dmitry Vyukov wrote:
>>
>> >> This is happening during while mounting reiserfs, so I'm inclined to think
>> >> it's more of a reisterfs issue than a slab allocator issue :/
>>
>> Have you tried to run with the "slub_debug" kernel option to figure out
>> what got corrupted?
>
> Can slub_debug detect anything that KASAN can't?

Probably not, KASAN will find out a bad write at the moment it happens,
while slub_debug only later from corrupted red zone/poison.

> I would assume KASAN can detect more bugs (e.g. stack/globals) and
> report way better. And it was already enabled in the config.

Anyway this is a stack corruption, not slab layout corruption. It's probably
hard to distinguish a legitimate stack write from an overrun so even KASAN
could not catch it immediately?

Dmitry Vyukov

unread,
Jul 10, 2023, 3:53:12ā€ÆAM7/10/23
to Vlastimil Babka, Lameter, Christopher, David Rientjes, syzbot, 42.h...@gmail.com, Andrew Morton, iamjoon...@lge.com, kees...@chromium.org, linux-...@vger.kernel.org, linux-h...@vger.kernel.org, linux-...@vger.kernel.org, linu...@kvack.org, pen...@kernel.org, reiserf...@vger.kernel.org, roman.g...@linux.dev, syzkall...@googlegroups.com, Jan Kara
KASAN can detect stack out-of-bounds writes.
However, use-after-return detection support was never implemented in
KASAN (user-space ASAN can detect them as well).
User-space MSAN can also detect use-after-scope, I think it's not
implemented in KMSAN as well.

If we ever get to the root cause of this bug, it may be useful to
analyze why it wasn't detected and if it's possible to make such bugs
detected.

syzbot

unread,
Mar 3, 2024, 4:21:05ā€ÆAMMar 3
to 42.h...@gmail.com, ak...@linux-foundation.org, ax...@kernel.dk, bra...@kernel.org, c...@linux.com, c...@os.amperecomputing.com, dvy...@google.com, iamjoon...@lge.com, ja...@suse.cz, kees...@chromium.org, linux-...@vger.kernel.org, linux-h...@vger.kernel.org, linux-...@vger.kernel.org, linu...@kvack.org, pen...@kernel.org, reiserf...@vger.kernel.org, rien...@google.com, roman.g...@linux.dev, syzkall...@googlegroups.com, vba...@suse.cz
syzbot suspects this issue was fixed by commit:

commit 6f861765464f43a71462d52026fbddfc858239a5
Author: Jan Kara <ja...@suse.cz>
Date: Wed Nov 1 17:43:10 2023 +0000

fs: Block writes to mounted block devices

bisection log: https://syzkaller.appspot.com/x/bisect.txt?x=1629e3ca180000
start commit: e8f75c0270d9 Merge tag 'x86_sgx_for_v6.5' of git://git.ker..
git tree: upstream
If the result looks correct, please mark the issue as fixed by replying with:

#syz fix: fs: Block writes to mounted block devices

For information about bisection process see: https://goo.gl/tpsmEJ#bisection

syzbot

unread,
Apr 15, 2024, 10:05:15ā€ÆPMĀ (11 days ago)Ā Apr 15
to syzkall...@googlegroups.com
Auto-closing this bug as obsolete.
No recent activity, existing reproducers are no longer triggering the issue.
Reply all
Reply to author
Forward
0 new messages