Re: [syzbot] WARNING in split_huge_page_to_list

From: Yang Shi
Date: Tue Aug 24 2021 - 15:10:03 EST


On Tue, Aug 24, 2021 at 4:41 AM Vlastimil Babka <vbabka@xxxxxxx> wrote:
>
> That's VM_WARN_ON_ONCE_PAGE(page_mapped(page), page);
> CC folks involved in 504e070dc08f ("mm: thp: replace DEBUG_VM BUG with VM_WARN
> when unmap fails for split")

There might be race between THP split and page unmap, and THP split
code can handle it, so it is not worth a VM_BUG.

Hugh fixed a couple of potential races, but there might be others.

>
> On 8/20/21 18:48, syzbot wrote:
> > Hello,
> >
> > syzbot found the following issue on:
> >
> > HEAD commit: f87d64319e6f Merge tag 'net-5.14-rc7' of git://git.kernel...
> > git tree: upstream
> > console output: https://syzkaller.appspot.com/x/log.txt?x=1205bd55300000
> > kernel config: https://syzkaller.appspot.com/x/.config?x=3205625db2f96ac9
> > dashboard link: https://syzkaller.appspot.com/bug?extid=0c65e03871b364e714a3
> > compiler: gcc (Debian 10.2.1-6) 10.2.1 20210110, GNU ld (GNU Binutils for Debian) 2.35.1
> >
> > Unfortunately, I don't have any reproducer for this issue yet.
> >
> > IMPORTANT: if you fix the issue, please add the following tag to the commit:
> > Reported-by: syzbot+0c65e03871b364e714a3@xxxxxxxxxxxxxxxxxxxxxxxxx
> >
> > __do_munmap+0x627/0x11c0 mm/mmap.c:2911
> > do_munmap mm/mmap.c:2922 [inline]
> > munmap_vma_range mm/mmap.c:604 [inline]
> > mmap_region+0x85a/0x1760 mm/mmap.c:1753
> > do_mmap+0x86e/0x1180 mm/mmap.c:1584
> > vm_mmap_pgoff+0x1b7/0x290 mm/util.c:519
> > ksys_mmap_pgoff+0x4a8/0x620 mm/mmap.c:1635
> > do_syscall_x64 arch/x86/entry/common.c:50 [inline]
> > do_syscall_64+0x35/0xb0 arch/x86/entry/common.c:80
> > entry_SYSCALL_64_after_hwframe+0x44/0xae
> > ------------[ cut here ]------------
> > WARNING: CPU: 0 PID: 2144 at mm/huge_memory.c:2327 unmap_page mm/huge_memory.c:2327 [inline]
> > WARNING: CPU: 0 PID: 2144 at mm/huge_memory.c:2327 split_huge_page_to_list+0x25eb/0x3e60 mm/huge_memory.c:2700
> > Modules linked in:
> > CPU: 0 PID: 2144 Comm: kswapd1 Not tainted 5.14.0-rc6-syzkaller #0
> > Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS Google 01/01/2011
> > RIP: 0010:unmap_page mm/huge_memory.c:2327 [inline]
> > RIP: 0010:split_huge_page_to_list+0x25eb/0x3e60 mm/huge_memory.c:2700
> > Code: 89 de e8 28 e1 b6 ff 84 db 0f 85 54 e0 ff ff e8 6b d9 b6 ff 48 c7 c6 e0 d8 97 89 48 89 ef e8 9c 72 e9 ff c6 05 05 dd 99 0b 01 <0f> 0b e9 32 e0 ff ff bb 02 00 00 00 e9 64 ef ff ff e8 3f d9 b6 ff
> > RSP: 0018:ffffc900084f76d8 EFLAGS: 00010293
> > RAX: 0000000000000000 RBX: 0000000000000000 RCX: 0000000000000000
> > RDX: ffff88801c44c000 RSI: ffffffff81be0514 RDI: 0000000000000003
> > RBP: ffffea00021c0000 R08: 0000000000000029 R09: 00000000ffffffff
> > R10: ffffffff88ea7679 R11: 00000000ffffffff R12: ffff88814018d2d8
> > R13: ffffea00021c0008 R14: ffffea00021c0000 R15: 0000000000000000
> > FS: 0000000000000000(0000) GS:ffff8880b9c00000(0000) knlGS:0000000000000000
> > CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033
> > CR2: 00007f14895d5000 CR3: 0000000017350000 CR4: 00000000001506f0
> > DR0: 0000000000000000 DR1: 0000000000000000 DR2: 0000000000000000
> > DR3: 0000000000000000 DR6: 00000000fffe0ff0 DR7: 0000000000000400
> > Call Trace:
> > split_huge_page include/linux/huge_mm.h:192 [inline]
> > deferred_split_scan+0x5fa/0xbd0 mm/huge_memory.c:2860
> > do_shrink_slab+0x42d/0xbd0 mm/vmscan.c:709
> > shrink_slab+0x17c/0x6e0 mm/vmscan.c:869
> > shrink_node_memcgs mm/vmscan.c:2868 [inline]
> > shrink_node+0x8d1/0x1df0 mm/vmscan.c:2983
> > kswapd_shrink_node mm/vmscan.c:3726 [inline]
> > balance_pgdat+0x7ce/0x13b0 mm/vmscan.c:3917
> > kswapd+0x5b6/0xdb0 mm/vmscan.c:4176
> > kthread+0x3e5/0x4d0 kernel/kthread.c:319
> > ret_from_fork+0x1f/0x30 arch/x86/entry/entry_64.S:295
> >
> >
> > ---
> > 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 syzkaller@xxxxxxxxxxxxxxxx.
> >
> > syzbot will keep track of this issue. See:
> > https://goo.gl/tpsmEJ#status for how to communicate with syzbot.
> >
>