usercopy: Kernel memory overwrite attempt detected to SLUB object 'task_struct' (offset 80, size 116)! ------------[ cut here ]------------ kernel BUG at mm/usercopy.c:102! Internal error: Oops - BUG: 0 [#1] PREEMPT SMP ARM Modules linked in: CPU: 1 PID: 8374 Comm: syz-executor.0 Not tainted 6.9.0-rc5-syzkaller #0 Hardware name: ARM-Versatile Express PC is at usercopy_abort+0x98/0x9c mm/usercopy.c:102 LR is at __wake_up_klogd.part.0+0x7c/0xac kernel/printk/printk.c:3926 pc : [<818a8384>] lr : [<802ba768>] psr: 60000013 sp : dfa7dd98 ip : dfa7dce0 fp : dfa7ddbc r10: 81a00568 r9 : 00001000 r8 : 846a5450 r7 : dde97e80 r6 : 00000000 r5 : 00000074 r4 : 00000050 r3 : 83d66000 r2 : 00000000 r1 : 00000000 r0 : 00000066 Flags: nZCv IRQs on FIQs on Mode SVC_32 ISA ARM Segment none Control: 30c5387d Table: 85518640 DAC: 00000000 Register r0 information: non-paged memory Register r1 information: NULL pointer Register r2 information: NULL pointer Register r3 information: slab task_struct start 83d66000 pointer offset 0 size 3072 Register r4 information: non-paged memory Register r5 information: non-paged memory Register r6 information: NULL pointer Register r7 information: non-slab/vmalloc memory Register r8 information: slab task_struct start 846a5400 pointer offset 80 size 3072 Register r9 information: non-paged memory Register r10 information: non-slab/vmalloc memory Register r11 information: 2-page vmalloc region starting at 0xdfa7c000 allocated at kernel_clone+0xac/0x3cc kernel/fork.c:2797 Register r12 information: 2-page vmalloc region starting at 0xdfa7c000 allocated at kernel_clone+0xac/0x3cc kernel/fork.c:2797 Process syz-executor.0 (pid: 8374, stack limit = 0xdfa7c000) Stack: (0xdfa7dd98 to 0xdfa7e000) dd80: 81fec750 81fbf360 dda0: 81fd398c 00000050 00000074 00001000 dfa7ddec dfa7ddc0 804b82a4 818a82f8 ddc0: 00000074 dfa7ddd0 80216314 846a5450 00000074 00000000 846a54c4 dde97e80 dde0: dfa7de24 dfa7ddf0 804ef448 804b81d8 00000074 20000044 dfa7de14 846a5450 de00: 00000074 20000044 00000074 81a005a0 00001000 81a00568 dfa7de4c dfa7de28 de20: 8020a0e4 804ef268 00000064 dfa7de2c dfa7de2c dfa7de34 8020a054 846a5400 de40: dfa7def4 dfa7de50 80253b88 8020a060 00000000 20001d00 20001d00 81a0057c de60: 818cc6b8 00000000 dfa7deb4 dfa7de78 8020d1c0 8020c164 80000013 00000000 de80: 8027e644 00000000 00000000 00000000 00000000 00000000 00000000 00000000 dea0: 00000000 83d66000 dfa7dedc dfa7deb8 8027cafc 802ac884 00000000 00000000 dec0: dfa7deec a199e384 846a5400 20000040 00004202 00000002 00000000 20000040 dee0: 83d66000 0000001a dfa7df6c dfa7def8 8020a4e0 802538ac 846a5400 846a5c7c df00: dfa7df1c dfa7df10 818ccb64 8027b084 dfa7df6c dfa7df20 80280e88 818ccb40 df20: dfa7df54 00000000 8027cafc 60000013 8187a764 81891b04 dfa7df54 a199e384 df40: 846a5400 00004205 846a5400 a199e384 00004205 846a5400 00000002 00000000 df60: dfa7dfa4 dfa7df70 80253570 8020a43c 80203054 a199e384 dfa7dfac 00000000 df80: 00000000 0014c2cc 0000001a 80200288 83d66000 0000001a 00000000 dfa7dfa8 dfa0: 80200060 80253340 00000000 00000000 00004205 0000015a 00000002 20000040 dfc0: 00000000 00000000 0014c2cc 0000001a 7e99532e 7e99532f 003d0f00 76bda0fc dfe0: 76bd9f08 76bd9ef8 00016ab0 00050bf0 60000010 00004205 00000000 00000000 Call trace: [<818a82ec>] (usercopy_abort) from [<804b82a4>] (__check_heap_object+0xd8/0xf4 mm/slub.c:5370) [<804b81cc>] (__check_heap_object) from [<804ef448>] (check_heap_object mm/usercopy.c:196 [inline]) [<804b81cc>] (__check_heap_object) from [<804ef448>] (__check_object_size mm/usercopy.c:251 [inline]) [<804b81cc>] (__check_heap_object) from [<804ef448>] (__check_object_size+0x1ec/0x30c mm/usercopy.c:213) r8:dde97e80 r7:846a54c4 r6:00000000 r5:00000074 r4:846a5450 [<804ef25c>] (__check_object_size) from [<8020a0e4>] (check_object_size include/linux/thread_info.h:215 [inline]) [<804ef25c>] (__check_object_size) from [<8020a0e4>] (__copy_from_user include/linux/uaccess.h:101 [inline]) [<804ef25c>] (__check_object_size) from [<8020a0e4>] (user_regset_copyin include/linux/regset.h:268 [inline]) [<804ef25c>] (__check_object_size) from [<8020a0e4>] (fpa_set+0x90/0xfc arch/arm/kernel/ptrace.c:587) r10:81a00568 r9:00001000 r8:81a005a0 r7:00000074 r6:20000044 r5:00000074 r4:846a5450 [<8020a054>] (fpa_set) from [<80253b88>] (copy_regset_from_user include/linux/regset.h:337 [inline]) [<8020a054>] (fpa_set) from [<80253b88>] (ptrace_regset kernel/ptrace.c:906 [inline]) [<8020a054>] (fpa_set) from [<80253b88>] (ptrace_request+0x2e8/0x9a4 kernel/ptrace.c:1218) r5:846a5400 r4:8020a054 [<802538a0>] (ptrace_request) from [<8020a4e0>] (arch_ptrace+0xb0/0x3e4 arch/arm/kernel/ptrace.c:818) r10:0000001a r9:83d66000 r8:20000040 r7:00000000 r6:00000002 r5:00004202 r4:20000040 [<8020a430>] (arch_ptrace) from [<80253570>] (__do_sys_ptrace kernel/ptrace.c:1285 [inline]) [<8020a430>] (arch_ptrace) from [<80253570>] (sys_ptrace+0x23c/0x4e4 kernel/ptrace.c:1258) r7:00000000 r6:00000002 r5:846a5400 r4:00004205 [<80253334>] (sys_ptrace) from [<80200060>] (ret_fast_syscall+0x0/0x1c arch/arm/mm/proc-v7.S:66) Exception stack(0xdfa7dfa8 to 0xdfa7dff0) dfa0: 00000000 00000000 00004205 0000015a 00000002 20000040 dfc0: 00000000 00000000 0014c2cc 0000001a 7e99532e 7e99532f 003d0f00 76bda0fc dfe0: 76bd9f08 76bd9ef8 00016ab0 00050bf0 r10:0000001a r9:83d66000 r8:80200288 r7:0000001a r6:0014c2cc r5:00000000 r4:00000000 Code: e30c0754 e34801fe e58dc000 ebfff359 (e7f001f2) ---[ end trace 0000000000000000 ]--- ---------------- Code disassembly (best guess): 0: e30c0754 movw r0, #51028 @ 0xc754 4: e34801fe movt r0, #33278 @ 0x81fe 8: e58dc000 str ip, [sp] c: ebfff359 bl 0xffffcd78 * 10: e7f001f2 udf #18 <-- trapping instruction