================================================================== BUG: KASAN: slab-out-of-bounds in copy_array+0x96/0x100 kernel/bpf/verifier.c:1072 Write of size 16 at addr ffff888078590100 by task syz-executor.0/22415 CPU: 0 PID: 22415 Comm: syz-executor.0 Not tainted 6.2.0-rc1-syzkaller #0 Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS Google 10/26/2022 Call Trace: __dump_stack lib/dump_stack.c:88 [inline] dump_stack_lvl+0xd1/0x138 lib/dump_stack.c:106 print_address_description mm/kasan/report.c:306 [inline] print_report+0x15e/0x45d mm/kasan/report.c:417 kasan_report+0xbf/0x1f0 mm/kasan/report.c:517 check_region_inline mm/kasan/generic.c:183 [inline] kasan_check_range+0x141/0x190 mm/kasan/generic.c:189 memcpy+0x3d/0x60 mm/kasan/shadow.c:66 copy_array+0x96/0x100 kernel/bpf/verifier.c:1072 copy_verifier_state+0xa9/0xc60 kernel/bpf/verifier.c:1250 pop_stack+0x8c/0x2f0 kernel/bpf/verifier.c:1314 do_check kernel/bpf/verifier.c:14031 [inline] do_check_common+0x5663/0xbca0 kernel/bpf/verifier.c:16289 do_check_main kernel/bpf/verifier.c:16352 [inline] bpf_check+0x7348/0xacc0 kernel/bpf/verifier.c:16936 bpf_prog_load+0x1543/0x2230 kernel/bpf/syscall.c:2619 __sys_bpf+0x1435/0x5000 kernel/bpf/syscall.c:4979 __do_sys_bpf kernel/bpf/syscall.c:5083 [inline] __se_sys_bpf kernel/bpf/syscall.c:5081 [inline] __ia32_sys_bpf+0x78/0xe0 kernel/bpf/syscall.c:5081 do_syscall_32_irqs_on arch/x86/entry/common.c:112 [inline] __do_fast_syscall_32+0x65/0xf0 arch/x86/entry/common.c:178 do_fast_syscall_32+0x33/0x70 arch/x86/entry/common.c:203 entry_SYSENTER_compat_after_hwframe+0x70/0x82 RIP: 0023:0xf7f73549 Code: 03 74 c0 01 10 05 03 74 b8 01 10 06 03 74 b4 01 10 07 03 74 b0 01 10 08 03 74 d8 01 00 00 00 00 00 51 52 55 89 e5 0f 34 cd 80 <5d> 5a 59 c3 90 90 90 90 8d b4 26 00 00 00 00 8d b4 26 00 00 00 00 RSP: 002b:00000000f7f6e5cc EFLAGS: 00000296 ORIG_RAX: 0000000000000165 RAX: ffffffffffffffda RBX: 0000000000000005 RCX: 00000000200017c0 RDX: 0000000000000048 RSI: 0000000000000000 RDI: 0000000000000000 RBP: 0000000000000000 R08: 0000000000000000 R09: 0000000000000000 R10: 0000000000000000 R11: 0000000000000246 R12: 0000000000000000 R13: 0000000000000000 R14: 0000000000000000 R15: 0000000000000000 Allocated by task 22415: kasan_save_stack+0x22/0x40 mm/kasan/common.c:45 kasan_set_track+0x25/0x30 mm/kasan/common.c:52 ____kasan_kmalloc mm/kasan/common.c:371 [inline] ____kasan_kmalloc mm/kasan/common.c:330 [inline] __kasan_krealloc+0x145/0x180 mm/kasan/common.c:439 kasan_krealloc include/linux/kasan.h:231 [inline] __do_krealloc mm/slab_common.c:1361 [inline] krealloc+0xa8/0x100 mm/slab_common.c:1398 push_jmp_history+0x13e/0x330 kernel/bpf/verifier.c:2592 is_state_visited kernel/bpf/verifier.c:13552 [inline] do_check kernel/bpf/verifier.c:13752 [inline] do_check_common+0x50e5/0xbca0 kernel/bpf/verifier.c:16289 do_check_main kernel/bpf/verifier.c:16352 [inline] bpf_check+0x7348/0xacc0 kernel/bpf/verifier.c:16936 bpf_prog_load+0x1543/0x2230 kernel/bpf/syscall.c:2619 __sys_bpf+0x1435/0x5000 kernel/bpf/syscall.c:4979 __do_sys_bpf kernel/bpf/syscall.c:5083 [inline] __se_sys_bpf kernel/bpf/syscall.c:5081 [inline] __ia32_sys_bpf+0x78/0xe0 kernel/bpf/syscall.c:5081 do_syscall_32_irqs_on arch/x86/entry/common.c:112 [inline] __do_fast_syscall_32+0x65/0xf0 arch/x86/entry/common.c:178 do_fast_syscall_32+0x33/0x70 arch/x86/entry/common.c:203 entry_SYSENTER_compat_after_hwframe+0x70/0x82 The buggy address belongs to the object at ffff888078590100 which belongs to the cache kmalloc-16 of size 16 The buggy address is located 0 bytes inside of 16-byte region [ffff888078590100, ffff888078590110) The buggy address belongs to the physical page: page:ffffea0001e16400 refcount:1 mapcount:0 mapping:0000000000000000 index:0x0 pfn:0x78590 anon flags: 0xfff00000000200(slab|node=0|zone=1|lastcpupid=0x7ff) raw: 00fff00000000200 ffff8880124413c0 0000000000000000 dead000000000001 raw: 0000000000000000 0000000080800080 00000001ffffffff 0000000000000000 page dumped because: kasan: bad access detected page_owner tracks the page as allocated page last allocated via order 0, migratetype Unmovable, gfp_mask 0x112cc0(GFP_USER|__GFP_NOWARN|__GFP_NORETRY), pid 5122, tgid 5122 (syz-executor.4), ts 152876496960, free_ts 152876347475 prep_new_page mm/page_alloc.c:2531 [inline] get_page_from_freelist+0x119c/0x2ce0 mm/page_alloc.c:4283 __alloc_pages+0x1cb/0x5b0 mm/page_alloc.c:5549 alloc_pages+0x1aa/0x270 mm/mempolicy.c:2286 alloc_slab_page mm/slub.c:1851 [inline] allocate_slab+0x25f/0x350 mm/slub.c:1998 new_slab mm/slub.c:2051 [inline] ___slab_alloc+0xa91/0x1400 mm/slub.c:3193 __slab_alloc.constprop.0+0x56/0xa0 mm/slub.c:3292 __slab_alloc_node mm/slub.c:3345 [inline] slab_alloc_node mm/slub.c:3442 [inline] __kmem_cache_alloc_node+0x1a4/0x430 mm/slub.c:3491 __do_kmalloc_node mm/slab_common.c:967 [inline] __kmalloc+0x4a/0xd0 mm/slab_common.c:981 kmalloc include/linux/slab.h:584 [inline] kzalloc include/linux/slab.h:720 [inline] xt_jumpstack_alloc net/netfilter/x_tables.c:1334 [inline] xt_replace_table+0x584/0x8c0 net/netfilter/x_tables.c:1393 xt_register_table+0x37a/0x820 net/netfilter/x_tables.c:1479 ipt_register_table+0x13d/0x370 net/ipv4/netfilter/ip_tables.c:1743 iptable_mangle_table_init+0x41/0x60 net/ipv4/netfilter/iptable_mangle.c:91 xt_find_table_lock+0x3a2/0x680 net/netfilter/x_tables.c:1259 xt_request_find_table_lock+0x2b/0x100 net/netfilter/x_tables.c:1284 get_info+0x16a/0x730 net/ipv4/netfilter/ip_tables.c:965 do_ipt_get_ctl+0x156/0x9e0 net/ipv4/netfilter/ip_tables.c:1654 page last free stack trace: reset_page_owner include/linux/page_owner.h:24 [inline] free_pages_prepare mm/page_alloc.c:1446 [inline] free_pcp_prepare+0x65c/0xc00 mm/page_alloc.c:1496 free_unref_page_prepare mm/page_alloc.c:3369 [inline] free_unref_page+0x1d/0x490 mm/page_alloc.c:3464 __vunmap+0x85d/0xd30 mm/vmalloc.c:2727 __vfree+0x3c/0xd0 mm/vmalloc.c:2775 vfree+0x5e/0x90 mm/vmalloc.c:2806 xt_compat_flush_offsets+0x8f/0x160 net/netfilter/x_tables.c:691 compat_get_entries+0x1f6/0x770 net/ipv4/netfilter/ip_tables.c:1604 do_ipt_get_ctl+0x4f1/0x9e0 net/ipv4/netfilter/ip_tables.c:1660 nf_getsockopt+0x76/0xd0 net/netfilter/nf_sockopt.c:116 ip_getsockopt+0x189/0x1e0 net/ipv4/ip_sockglue.c:1797 tcp_getsockopt+0x99/0x100 net/ipv4/tcp.c:4406 __sys_getsockopt+0x21a/0x6a0 net/socket.c:2290 __do_compat_sys_socketcall+0x4c1/0x720 net/compat.c:493 do_syscall_32_irqs_on arch/x86/entry/common.c:112 [inline] __do_fast_syscall_32+0x65/0xf0 arch/x86/entry/common.c:178 do_fast_syscall_32+0x33/0x70 arch/x86/entry/common.c:203 entry_SYSENTER_compat_after_hwframe+0x70/0x82 Memory state around the buggy address: ffff888078590000: fa fb fc fc fa fb fc fc fa fb fc fc fb fb fc fc ffff888078590080: fa fb fc fc fb fb fc fc fa fb fc fc fa fb fc fc >ffff888078590100: 00 fc fc fc fa fb fc fc fb fb fc fc fb fb fc fc ^ ffff888078590180: fb fb fc fc fb fb fc fc fb fb fc fc fa fb fc fc ffff888078590200: fb fb fc fc fa fb fc fc fa fb fc fc fa fb fc fc ================================================================== ---------------- Code disassembly (best guess): 0: 03 74 c0 01 add 0x1(%rax,%rax,8),%esi 4: 10 05 03 74 b8 01 adc %al,0x1b87403(%rip) # 0x1b8740d a: 10 06 adc %al,(%rsi) c: 03 74 b4 01 add 0x1(%rsp,%rsi,4),%esi 10: 10 07 adc %al,(%rdi) 12: 03 74 b0 01 add 0x1(%rax,%rsi,4),%esi 16: 10 08 adc %cl,(%rax) 18: 03 74 d8 01 add 0x1(%rax,%rbx,8),%esi 1c: 00 00 add %al,(%rax) 1e: 00 00 add %al,(%rax) 20: 00 51 52 add %dl,0x52(%rcx) 23: 55 push %rbp 24: 89 e5 mov %esp,%ebp 26: 0f 34 sysenter 28: cd 80 int $0x80 * 2a: 5d pop %rbp <-- trapping instruction 2b: 5a pop %rdx 2c: 59 pop %rcx 2d: c3 retq 2e: 90 nop 2f: 90 nop 30: 90 nop 31: 90 nop 32: 8d b4 26 00 00 00 00 lea 0x0(%rsi,%riz,1),%esi 39: 8d b4 26 00 00 00 00 lea 0x0(%rsi,%riz,1),%esi