general protection fault, probably for non-canonical address 0xdffffc0000000001: 0000 [#1] PREEMPT SMP KASAN KASAN: null-ptr-deref in range [0x0000000000000008-0x000000000000000f] CPU: 0 PID: 21987 Comm: syz-executor.2 Not tainted 6.7.0-rc6-next-20231221-syzkaller #0 Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS Google 11/17/2023 RIP: 0010:scatterwalk_start include/crypto/scatterwalk.h:63 [inline] RIP: 0010:scatterwalk_pagedone include/crypto/scatterwalk.h:83 [inline] RIP: 0010:scatterwalk_pagedone include/crypto/scatterwalk.h:72 [inline] RIP: 0010:scatterwalk_copychunks+0x3e0/0x560 crypto/scatterwalk.c:50 Code: f0 48 c1 e8 03 80 3c 08 00 0f 85 81 01 00 00 49 8d 44 24 08 4d 89 26 48 bf 00 00 00 00 00 fc ff df 48 89 44 24 10 48 c1 e8 03 <0f> b6 04 38 84 c0 74 08 3c 03 0f 8e 47 01 00 00 48 8b 44 24 08 41 RSP: 0018:ffffc90016c965e0 EFLAGS: 00010202 RAX: 0000000000000001 RBX: 0000000000000000 RCX: dffffc0000000000 RDX: 0000000000040000 RSI: ffffffff8465c984 RDI: dffffc0000000000 RBP: 0000000000001000 R08: 0000000000000005 R09: 0000000000000000 R10: 0000000000000002 R11: 029f6882029f4b82 R12: 0000000000000000 R13: 0000000000000014 R14: ffffc90016c96678 R15: 0000000000001000 FS: 00007f52a18476c0(0000) GS:ffff8880b9800000(0000) knlGS:0000000000000000 CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033 CR2: 00007f11532cb2e0 CR3: 000000002050e000 CR4: 00000000003506f0 Call Trace: scatterwalk_map_and_copy+0x151/0x1d0 crypto/scatterwalk.c:67 scomp_acomp_comp_decomp+0x3a3/0x780 crypto/scompress.c:149 crypto_acomp_compress include/crypto/acompress.h:302 [inline] zswap_store+0x98b/0x2430 mm/zswap.c:1666 swap_writepage+0x8e/0x220 mm/page_io.c:198 shmem_writepage+0x76b/0x1050 mm/shmem.c:1518 pageout+0x399/0x9e0 mm/vmscan.c:656 shrink_folio_list+0x2f47/0x3ea0 mm/vmscan.c:1319 evict_folios+0x6e6/0x1b90 mm/vmscan.c:4503 try_to_shrink_lruvec+0x638/0xa10 mm/vmscan.c:4708 lru_gen_shrink_lruvec mm/vmscan.c:4853 [inline] shrink_lruvec+0x314/0x29a0 mm/vmscan.c:5626 shrink_node_memcgs mm/vmscan.c:5846 [inline] shrink_node+0x81b/0x3740 mm/vmscan.c:5881 shrink_zones mm/vmscan.c:6120 [inline] do_try_to_free_pages+0x36a/0x1930 mm/vmscan.c:6182 try_to_free_mem_cgroup_pages+0x31f/0x780 mm/vmscan.c:6497 try_charge_memcg+0x3d1/0x1190 mm/memcontrol.c:2763 obj_cgroup_charge_pages mm/memcontrol.c:3276 [inline] __memcg_kmem_charge_page+0xdb/0x2a0 mm/memcontrol.c:3302 __alloc_pages+0x263/0x2410 mm/page_alloc.c:4621 __alloc_pages_node include/linux/gfp.h:238 [inline] alloc_pages_node include/linux/gfp.h:261 [inline] bpf_ringbuf_area_alloc kernel/bpf/ringbuf.c:122 [inline] bpf_ringbuf_alloc kernel/bpf/ringbuf.c:170 [inline] ringbuf_map_alloc kernel/bpf/ringbuf.c:204 [inline] ringbuf_map_alloc+0x294/0x790 kernel/bpf/ringbuf.c:186 map_create+0x548/0x1b90 kernel/bpf/syscall.c:1237 __sys_bpf+0xa32/0x4a00 kernel/bpf/syscall.c:5409 __do_sys_bpf kernel/bpf/syscall.c:5531 [inline] __se_sys_bpf kernel/bpf/syscall.c:5529 [inline] __x64_sys_bpf+0x78/0xc0 kernel/bpf/syscall.c:5529 do_syscall_x64 arch/x86/entry/common.c:52 [inline] do_syscall_64+0x40/0x110 arch/x86/entry/common.c:83 entry_SYSCALL_64_after_hwframe+0x62/0x6a RIP: 0033:0x7f52a0a7cce9 Code: 28 00 00 00 75 05 48 83 c4 28 c3 e8 e1 20 00 00 90 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 b0 ff ff ff f7 d8 64 89 01 48 RSP: 002b:00007f52a18470c8 EFLAGS: 00000246 ORIG_RAX: 0000000000000141 RAX: ffffffffffffffda RBX: 00007f52a0b9bf80 RCX: 00007f52a0a7cce9 RDX: 00000000000000a0 RSI: 0000000020001300 RDI: 0000000000000000 RBP: 00007f52a0ac947a R08: 0000000000000000 R09: 0000000000000000 R10: 0000000000000000 R11: 0000000000000246 R12: 0000000000000000 R13: 000000000000000b R14: 00007f52a0b9bf80 R15: 00007ffd9a43f998 Modules linked in: ---[ end trace 0000000000000000 ]--- RIP: 0010:scatterwalk_start include/crypto/scatterwalk.h:63 [inline] RIP: 0010:scatterwalk_pagedone include/crypto/scatterwalk.h:83 [inline] RIP: 0010:scatterwalk_pagedone include/crypto/scatterwalk.h:72 [inline] RIP: 0010:scatterwalk_copychunks+0x3e0/0x560 crypto/scatterwalk.c:50 Code: f0 48 c1 e8 03 80 3c 08 00 0f 85 81 01 00 00 49 8d 44 24 08 4d 89 26 48 bf 00 00 00 00 00 fc ff df 48 89 44 24 10 48 c1 e8 03 <0f> b6 04 38 84 c0 74 08 3c 03 0f 8e 47 01 00 00 48 8b 44 24 08 41 RSP: 0018:ffffc90016c965e0 EFLAGS: 00010202 RAX: 0000000000000001 RBX: 0000000000000000 RCX: dffffc0000000000 RDX: 0000000000040000 RSI: ffffffff8465c984 RDI: dffffc0000000000 RBP: 0000000000001000 R08: 0000000000000005 R09: 0000000000000000 R10: 0000000000000002 R11: 029f6882029f4b82 R12: 0000000000000000 R13: 0000000000000014 R14: ffffc90016c96678 R15: 0000000000001000 FS: 00007f52a18476c0(0000) GS:ffff8880b9800000(0000) knlGS:0000000000000000 CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033 CR2: 00007f11532cb2e0 CR3: 000000002050e000 CR4: 00000000003506f0 ---------------- Code disassembly (best guess): 0: f0 48 c1 e8 03 lock shr $0x3,%rax 5: 80 3c 08 00 cmpb $0x0,(%rax,%rcx,1) 9: 0f 85 81 01 00 00 jne 0x190 f: 49 8d 44 24 08 lea 0x8(%r12),%rax 14: 4d 89 26 mov %r12,(%r14) 17: 48 bf 00 00 00 00 00 movabs $0xdffffc0000000000,%rdi 1e: fc ff df 21: 48 89 44 24 10 mov %rax,0x10(%rsp) 26: 48 c1 e8 03 shr $0x3,%rax * 2a: 0f b6 04 38 movzbl (%rax,%rdi,1),%eax <-- trapping instruction 2e: 84 c0 test %al,%al 30: 74 08 je 0x3a 32: 3c 03 cmp $0x3,%al 34: 0f 8e 47 01 00 00 jle 0x181 3a: 48 8b 44 24 08 mov 0x8(%rsp),%rax 3f: 41 rex.B