syzbot


BUG: Bad page state in prep_new_page

Status: premoderation: reported C repro on 2025/09/04 16:41
Bug presence: origin:upstream
[Documentation on labels]
Reported-by: syzbot+b7981b791bc48b59ca14@syzkaller.appspotmail.com
First crash: 15d, last: 1d01h
Bug presence (2)
Date Name Commit Repro Result
2025/09/13 lts (merge base) d90ecb2b1308 C [report] BUG: Bad page state in netfs_perform_write
2025/09/13 upstream (ToT) 22f20375f5b7 C [report] BUG: Bad page state in netfs_perform_write
Last patch testing requests (1)
Created Duration User Patch Repo Result
2025/09/19 05:04 13m retest repro android16-6.12 report log

Sample crash report:
BUG: Bad page state in process syz.2.46  pfn:12f79e
page: refcount:0 mapcount:0 mapping:ffff8881241314e8 index:0x0 pfn:0x12f79e
aops:v9fs_addr_operations ino:2 dentry name(?):"/"
flags: 0x4000000000000001(locked|zone=1)
raw: 4000000000000001 dead000000000100 dead000000000122 ffff8881241314e8
raw: 0000000000000000 0000000000000000 00000000ffffffff 0000000000000000
page dumped because: PAGE_FLAGS_CHECK_AT_FREE flag(s) set
page_owner tracks the page as allocated
page last allocated via order 0, migratetype Movable, gfp_mask 0x141cca(GFP_HIGHUSER_MOVABLE|__GFP_COMP|__GFP_WRITE), pid 411, tgid 411 (syz.2.46), ts 28145749306, free_ts 24216994896
 set_page_owner include/linux/page_owner.h:35 [inline]
 post_alloc_hook+0x3b9/0x3f0 mm/page_alloc.c:1826
 prep_new_page+0x1c/0x120 mm/page_alloc.c:1834
 get_page_from_freelist+0x48ce/0x4960 mm/page_alloc.c:3914
 __alloc_pages_noprof+0x31f/0x7b0 mm/page_alloc.c:5258
 __folio_alloc_noprof+0x14/0x80 mm/page_alloc.c:5291
 __folio_alloc_node_noprof include/linux/gfp.h:280 [inline]
 folio_alloc_noprof include/linux/gfp.h:322 [inline]
 filemap_alloc_folio_noprof include/linux/pagemap.h:674 [inline]
 __filemap_get_folio+0x54c/0x9d0 mm/filemap.c:1984
 netfs_grab_folio_for_write fs/netfs/buffered_write.c:47 [inline]
 netfs_perform_write+0x4b2/0x1f70 fs/netfs/buffered_write.c:172
 netfs_buffered_write_iter_locked+0xa3/0x1c0 fs/netfs/buffered_write.c:447
 netfs_file_write_iter+0x189/0x440 fs/netfs/buffered_write.c:486
 v9fs_file_write_iter+0xac/0xe0 fs/9p/vfs_file.c:407
 do_iter_readv_writev+0x4f2/0x6a0 fs/read_write.c:-1
 vfs_writev+0x485/0xcf0 fs/read_write.c:1076
 do_pwritev fs/read_write.c:1177 [inline]
 __do_sys_pwritev2 fs/read_write.c:1236 [inline]
 __se_sys_pwritev2+0x1ad/0x2b0 fs/read_write.c:1227
 __x64_sys_pwritev2+0xc3/0xf0 fs/read_write.c:1227
 x64_sys_call+0x2938/0x2ee0 arch/x86/include/generated/asm/syscalls_64.h:329
 do_syscall_x64 arch/x86/entry/common.c:52 [inline]
 do_syscall_64+0x58/0xf0 arch/x86/entry/common.c:83
page last free pid 297 tgid 297 stack trace:
 reset_page_owner include/linux/page_owner.h:28 [inline]
 free_pages_prepare mm/page_alloc.c:1352 [inline]
 free_unref_folios+0xcfe/0x1680 mm/page_alloc.c:2901
 folios_put_refs+0x4c9/0x5c0 mm/swap.c:1038
 free_pages_and_swap_cache+0x272/0x460 mm/swap_state.c:333
 __tlb_batch_free_encoded_pages mm/mmu_gather.c:136 [inline]
 tlb_batch_pages_flush mm/mmu_gather.c:149 [inline]
 tlb_flush_mmu_free mm/mmu_gather.c:366 [inline]
 tlb_flush_mmu+0x7ce/0xaf0 mm/mmu_gather.c:373
 tlb_finish_mmu+0xcf/0x1d0 mm/mmu_gather.c:465
 vms_clear_ptes+0x4a6/0x5b0 mm/vma.c:1120
 vms_complete_munmap_vmas+0x1e8/0x6c0 mm/vma.c:1162
 do_vmi_align_munmap+0x507/0x5d0 mm/vma.c:1371
 do_vmi_munmap+0x246/0x2e0 mm/vma.c:1419
 __vm_munmap+0x22b/0x370 mm/mmap.c:1654
 __do_sys_munmap mm/mmap.c:1678 [inline]
 __se_sys_munmap+0xc0/0x3a0 mm/mmap.c:1668
 __x64_sys_munmap+0x5f/0x80 mm/mmap.c:1668
 x64_sys_call+0x9c6/0x2ee0 arch/x86/include/generated/asm/syscalls_64.h:12
 do_syscall_x64 arch/x86/entry/common.c:52 [inline]
 do_syscall_64+0x58/0xf0 arch/x86/entry/common.c:83
 entry_SYSCALL_64_after_hwframe+0x76/0x7e
Modules linked in:
CPU: 0 UID: 0 PID: 411 Comm: syz.2.46 Not tainted syzkaller #0 73b2ef142dafea13a051d13948dec704a9c677a1
Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS Google 07/12/2025
Call Trace:
 <TASK>
 __dump_stack+0x21/0x30 lib/dump_stack.c:94
 dump_stack_lvl+0x10c/0x190 lib/dump_stack.c:120
 dump_stack+0x19/0x20 lib/dump_stack.c:129
 bad_page+0x169/0x1c0 mm/page_alloc.c:594
 free_page_is_bad_report+0x123/0x1d0 mm/page_alloc.c:1057
 free_page_is_bad mm/page_alloc.c:1067 [inline]
 free_pages_prepare mm/page_alloc.c:1343 [inline]
 free_unref_page+0xe88/0xee0 mm/page_alloc.c:2842
 __folio_put+0x24f/0x2a0 mm/swap.c:115
 folio_put include/linux/mm.h:1589 [inline]
 netfs_perform_write+0x1aae/0x1f70 fs/netfs/buffered_write.c:403
 netfs_buffered_write_iter_locked+0xa3/0x1c0 fs/netfs/buffered_write.c:447
 netfs_file_write_iter+0x189/0x440 fs/netfs/buffered_write.c:486
 v9fs_file_write_iter+0xac/0xe0 fs/9p/vfs_file.c:407
 new_sync_write fs/read_write.c:591 [inline]
 vfs_write+0x697/0xe80 fs/read_write.c:684
 ksys_write+0x141/0x250 fs/read_write.c:737
 __do_sys_write fs/read_write.c:749 [inline]
 __se_sys_write fs/read_write.c:746 [inline]
 __x64_sys_write+0x7f/0x90 fs/read_write.c:746
 x64_sys_call+0x271c/0x2ee0 arch/x86/include/generated/asm/syscalls_64.h:2
 do_syscall_x64 arch/x86/entry/common.c:52 [inline]
 do_syscall_64+0x58/0xf0 arch/x86/entry/common.c:83
 entry_SYSCALL_64_after_hwframe+0x76/0x7e
RIP: 0033:0x7f0557b8ebe9
Code: ff ff c3 66 2e 0f 1f 84 00 00 00 00 00 0f 1f 40 00 48 89 f8 48 89 f7 48 89 d6 48 89 ca 4d 89 c2 4d 89 c8 4c 8b 4c 24 08 0f 05 <48> 3d 01 f0 ff ff 73 01 c3 48 c7 c1 a8 ff ff ff f7 d8 64 89 01 48
RSP: 002b:00007ffc84424e48 EFLAGS: 00000246 ORIG_RAX: 0000000000000001
RAX: ffffffffffffffda RBX: 00007f0557dc5fa0 RCX: 00007f0557b8ebe9
RDX: 0000000000000018 RSI: 0000200000000380 RDI: 0000000000000007
RBP: 00007f0557c11e19 R08: 0000000000000000 R09: 0000000000000000
R10: 0000000000000000 R11: 0000000000000246 R12: 0000000000000000
R13: 00007f0557dc5fa0 R14: 00007f0557dc5fa0 R15: 0000000000000003
 </TASK>

Crashes (1):
Time Kernel Commit Syzkaller Config Log Report Syz repro C repro VM info Assets (help?) Manager Title
2025/09/04 16:40 android16-6.12 3a1f856821c2 d291dd2d .config console log report syz / log C [disk image] [vmlinux] [kernel image] ci2-android-6-12-rust BUG: Bad page state in prep_new_page
* Struck through repros no longer work on HEAD.