================================================================================ UBSAN: array-index-out-of-bounds in drivers/input/tablet/aiptek.c:741:31 index 3839 is out of range for type 'const int[34]' CPU: 1 PID: 847 Comm: syz.3.163 Not tainted syzkaller #0 Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS Google 04/18/2026 Call Trace: __dump_stack+0x21/0x24 lib/dump_stack.c:88 dump_stack_lvl+0x110/0x170 lib/dump_stack.c:106 dump_stack+0x15/0x24 lib/dump_stack.c:113 ubsan_epilogue+0xe/0x40 lib/ubsan.c:151 __ubsan_handle_out_of_bounds+0xdf/0xf0 lib/ubsan.c:282 aiptek_irq+0x208d/0x29b0 drivers/input/tablet/aiptek.c:741 __usb_hcd_giveback_urb+0x364/0x520 drivers/usb/core/hcd.c:1675 usb_hcd_giveback_urb+0x11c/0x410 drivers/usb/core/hcd.c:1758 dummy_timer+0x88c/0x3070 drivers/usb/gadget/udc/dummy_hcd.c:2004 __run_hrtimer kernel/time/hrtimer.c:1685 [inline] __hrtimer_run_queues+0x3bb/0x8e0 kernel/time/hrtimer.c:1749 hrtimer_run_softirq+0x19b/0x260 kernel/time/hrtimer.c:1766 handle_softirqs+0x1d7/0x600 kernel/softirq.c:642 __do_softirq kernel/softirq.c:680 [inline] invoke_softirq kernel/softirq.c:497 [inline] __irq_exit_rcu+0x52/0xf0 kernel/softirq.c:729 irq_exit_rcu+0x9/0x10 kernel/softirq.c:741 instr_sysvec_apic_timer_interrupt arch/x86/kernel/apic/apic.c:1118 [inline] sysvec_apic_timer_interrupt+0xa9/0xc0 arch/x86/kernel/apic/apic.c:1118 asm_sysvec_apic_timer_interrupt+0x1b/0x20 arch/x86/include/asm/idtentry.h:691 RIP: 0010:__raw_spin_unlock_irq include/linux/spinlock_api_smp.h:160 [inline] RIP: 0010:_raw_spin_unlock_irq+0x48/0x70 kernel/locking/spinlock.c:202 Code: 74 12 48 89 fb 48 c7 c7 00 d5 0d 87 e8 01 b8 b4 fc 48 89 df 48 83 3d 46 6a 0b 02 00 74 26 e8 13 0d 00 00 90 fb bf 01 00 00 00 83 3d 4a fc 65 8b 05 f4 02 00 7b 85 c0 74 03 5b 5d c3 e8 f4 11 RSP: 0018:ffffc90012ae7608 EFLAGS: 00000246 RAX: 0000000000000001 RBX: ffffea00050493c0 RCX: dffffc0000000000 RDX: ffffc9000265e000 RSI: 000000000007ffff RDI: 0000000000000001 RBP: ffffc90012ae7610 R08: ffff88813e68583f R09: 1ffff11027cd0b07 R10: dffffc0000000000 R11: ffffed1027cd0b08 R12: ffff8881308f5500 R13: 1ffff1102611ea9f R14: ffff8881308f54f8 R15: ffffc90012ae7660 spin_unlock_irq include/linux/spinlock.h:401 [inline] filemap_remove_folio+0x10f/0x490 mm/filemap.c:276 truncate_inode_folio+0x5d/0x70 mm/truncate.c:199 shmem_undo_range+0x456/0x1540 mm/shmem.c:947 shmem_truncate_range mm/shmem.c:1067 [inline] shmem_evict_inode+0x255/0xa50 mm/shmem.c:1176 evict+0x4d7/0x8f0 fs/inode.c:708 iput_final fs/inode.c:1844 [inline] iput+0x620/0x670 fs/inode.c:1870 dentry_unlink_inode+0x33d/0x3f0 fs/dcache.c:405 __dentry_kill+0x460/0x670 fs/dcache.c:611 dentry_kill+0xc0/0x2a0 fs/dcache.c:-1 dput+0x42/0x80 fs/dcache.c:918 __fput+0x5be/0x8f0 fs/file_table.c:328 ____fput+0x15/0x20 fs/file_table.c:348 task_work_run+0x1e1/0x250 kernel/task_work.c:203 resume_user_mode_work include/linux/resume_user_mode.h:49 [inline] exit_to_user_mode_loop+0x9b/0xb0 kernel/entry/common.c:177 exit_to_user_mode_prepare+0x87/0xd0 kernel/entry/common.c:210 __syscall_exit_to_user_mode_work kernel/entry/common.c:292 [inline] syscall_exit_to_user_mode+0x1a/0x30 kernel/entry/common.c:303 do_syscall_64+0x58/0xa0 arch/x86/entry/common.c:82 entry_SYSCALL_64_after_hwframe+0x68/0xd2 RIP: 0033:0x7f589c15d68e Code: 08 0f 85 a5 a8 ff ff 49 89 fb 48 89 f0 48 89 d7 48 89 ce 4c 89 c2 4d 89 ca 4c 8b 44 24 08 4c 8b 4c 24 10 4c 89 5c 24 08 0f 05 66 2e 0f 1f 84 00 00 00 00 00 0f 1f 80 00 00 00 00 48 83 ec 08 RSP: 002b:00007f589d125da8 EFLAGS: 00000246 ORIG_RAX: 0000000000000003 RAX: 0000000000000000 RBX: 00007f589d1266c0 RCX: 00007f589c15d68e RDX: 0000000000000000 RSI: 0000000000000000 RDI: 0000000000000003 RBP: 0000000000000002 R08: 0000000000000000 R09: 0000000000000000 R10: 0000000000000000 R11: 0000000000000246 R12: 0000000000000003 R13: 00007f589d125ee0 R14: 00007f589d125ea0 R15: 00007f58927f8000 ================================================================================ ================================================================== BUG: KASAN: global-out-of-bounds in aiptek_irq+0x20ab/0x29b0 drivers/input/tablet/aiptek.c:741 Read of size 4 at addr ffffffff85e6e1bc by task syz.3.163/847 CPU: 1 PID: 847 Comm: syz.3.163 Not tainted syzkaller #0 Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS Google 04/18/2026 Call Trace: __dump_stack+0x21/0x24 lib/dump_stack.c:88 dump_stack_lvl+0x110/0x170 lib/dump_stack.c:106 print_address_description+0x71/0x200 mm/kasan/report.c:316 print_report+0x4a/0x60 mm/kasan/report.c:420 kasan_report+0x122/0x150 mm/kasan/report.c:524 __asan_report_load4_noabort+0x14/0x20 mm/kasan/report_generic.c:350 aiptek_irq+0x20ab/0x29b0 drivers/input/tablet/aiptek.c:741 __usb_hcd_giveback_urb+0x364/0x520 drivers/usb/core/hcd.c:1675 usb_hcd_giveback_urb+0x11c/0x410 drivers/usb/core/hcd.c:1758 dummy_timer+0x88c/0x3070 drivers/usb/gadget/udc/dummy_hcd.c:2004 __run_hrtimer kernel/time/hrtimer.c:1685 [inline] __hrtimer_run_queues+0x3bb/0x8e0 kernel/time/hrtimer.c:1749 hrtimer_run_softirq+0x19b/0x260 kernel/time/hrtimer.c:1766 handle_softirqs+0x1d7/0x600 kernel/softirq.c:642 __do_softirq kernel/softirq.c:680 [inline] invoke_softirq kernel/softirq.c:497 [inline] __irq_exit_rcu+0x52/0xf0 kernel/softirq.c:729 irq_exit_rcu+0x9/0x10 kernel/softirq.c:741 instr_sysvec_apic_timer_interrupt arch/x86/kernel/apic/apic.c:1118 [inline] sysvec_apic_timer_interrupt+0xa9/0xc0 arch/x86/kernel/apic/apic.c:1118 asm_sysvec_apic_timer_interrupt+0x1b/0x20 arch/x86/include/asm/idtentry.h:691 RIP: 0010:__raw_spin_unlock_irq include/linux/spinlock_api_smp.h:160 [inline] RIP: 0010:_raw_spin_unlock_irq+0x48/0x70 kernel/locking/spinlock.c:202 Code: 74 12 48 89 fb 48 c7 c7 00 d5 0d 87 e8 01 b8 b4 fc 48 89 df 48 83 3d 46 6a 0b 02 00 74 26 e8 13 0d 00 00 90 fb bf 01 00 00 00 83 3d 4a fc 65 8b 05 f4 02 00 7b 85 c0 74 03 5b 5d c3 e8 f4 11 RSP: 0018:ffffc90012ae7608 EFLAGS: 00000246 RAX: 0000000000000001 RBX: ffffea00050493c0 RCX: dffffc0000000000 RDX: ffffc9000265e000 RSI: 000000000007ffff RDI: 0000000000000001 RBP: ffffc90012ae7610 R08: ffff88813e68583f R09: 1ffff11027cd0b07 R10: dffffc0000000000 R11: ffffed1027cd0b08 R12: ffff8881308f5500 R13: 1ffff1102611ea9f R14: ffff8881308f54f8 R15: ffffc90012ae7660 spin_unlock_irq include/linux/spinlock.h:401 [inline] filemap_remove_folio+0x10f/0x490 mm/filemap.c:276 truncate_inode_folio+0x5d/0x70 mm/truncate.c:199 shmem_undo_range+0x456/0x1540 mm/shmem.c:947 shmem_truncate_range mm/shmem.c:1067 [inline] shmem_evict_inode+0x255/0xa50 mm/shmem.c:1176 evict+0x4d7/0x8f0 fs/inode.c:708 iput_final fs/inode.c:1844 [inline] iput+0x620/0x670 fs/inode.c:1870 dentry_unlink_inode+0x33d/0x3f0 fs/dcache.c:405 __dentry_kill+0x460/0x670 fs/dcache.c:611 dentry_kill+0xc0/0x2a0 fs/dcache.c:-1 dput+0x42/0x80 fs/dcache.c:918 __fput+0x5be/0x8f0 fs/file_table.c:328 ____fput+0x15/0x20 fs/file_table.c:348 task_work_run+0x1e1/0x250 kernel/task_work.c:203 resume_user_mode_work include/linux/resume_user_mode.h:49 [inline] exit_to_user_mode_loop+0x9b/0xb0 kernel/entry/common.c:177 exit_to_user_mode_prepare+0x87/0xd0 kernel/entry/common.c:210 __syscall_exit_to_user_mode_work kernel/entry/common.c:292 [inline] syscall_exit_to_user_mode+0x1a/0x30 kernel/entry/common.c:303 do_syscall_64+0x58/0xa0 arch/x86/entry/common.c:82 entry_SYSCALL_64_after_hwframe+0x68/0xd2 RIP: 0033:0x7f589c15d68e Code: 08 0f 85 a5 a8 ff ff 49 89 fb 48 89 f0 48 89 d7 48 89 ce 4c 89 c2 4d 89 ca 4c 8b 44 24 08 4c 8b 4c 24 10 4c 89 5c 24 08 0f 05 66 2e 0f 1f 84 00 00 00 00 00 0f 1f 80 00 00 00 00 48 83 ec 08 RSP: 002b:00007f589d125da8 EFLAGS: 00000246 ORIG_RAX: 0000000000000003 RAX: 0000000000000000 RBX: 00007f589d1266c0 RCX: 00007f589c15d68e RDX: 0000000000000000 RSI: 0000000000000000 RDI: 0000000000000003 RBP: 0000000000000002 R08: 0000000000000000 R09: 0000000000000000 R10: 0000000000000000 R11: 0000000000000246 R12: 0000000000000003 R13: 00007f589d125ee0 R14: 00007f589d125ea0 R15: 00007f58927f8000 The buggy address belongs to the variable: .str.49+0x3c/0x60 The buggy address belongs to the physical page: page:ffffea0000179b80 refcount:1 mapcount:0 mapping:0000000000000000 index:0x0 pfn:0x5e6e flags: 0x1000(reserved|zone=0) raw: 0000000000001000 ffffea0000179b88 ffffea0000179b88 0000000000000000 raw: 0000000000000000 0000000000000000 00000001ffffffff 0000000000000000 page dumped because: kasan: bad access detected page_owner info is not present (never set?) Memory state around the buggy address: ffffffff85e6e080: 03 f9 f9 f9 f9 f9 f9 f9 00 00 00 00 06 f9 f9 f9 ffffffff85e6e100: f9 f9 f9 f9 00 00 00 00 02 f9 f9 f9 f9 f9 f9 f9 >ffffffff85e6e180: 00 00 00 00 03 f9 f9 f9 f9 f9 f9 f9 00 00 00 00 ^ ffffffff85e6e200: 00 00 03 f9 f9 f9 f9 f9 00 00 00 f9 f9 f9 f9 f9 ffffffff85e6e280: 00 00 00 01 f9 f9 f9 f9 00 00 00 00 01 f9 f9 f9 ================================================================== ================================================================================ UBSAN: array-index-out-of-bounds in drivers/input/tablet/aiptek.c:763:30 index 3840 is out of range for type 'const int[34]' CPU: 1 PID: 847 Comm: syz.3.163 Tainted: G B syzkaller #0 Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS Google 04/18/2026 Call Trace: __dump_stack+0x21/0x24 lib/dump_stack.c:88 dump_stack_lvl+0x110/0x170 lib/dump_stack.c:106 dump_stack+0x15/0x24 lib/dump_stack.c:113 ubsan_epilogue+0xe/0x40 lib/ubsan.c:151 __ubsan_handle_out_of_bounds+0xdf/0xf0 lib/ubsan.c:282 aiptek_irq+0x1f6d/0x29b0 drivers/input/tablet/aiptek.c:763 __usb_hcd_giveback_urb+0x364/0x520 drivers/usb/core/hcd.c:1675 usb_hcd_giveback_urb+0x11c/0x410 drivers/usb/core/hcd.c:1758 dummy_timer+0x88c/0x3070 drivers/usb/gadget/udc/dummy_hcd.c:2004 __run_hrtimer kernel/time/hrtimer.c:1685 [inline] __hrtimer_run_queues+0x3bb/0x8e0 kernel/time/hrtimer.c:1749 hrtimer_run_softirq+0x19b/0x260 kernel/time/hrtimer.c:1766 handle_softirqs+0x1d7/0x600 kernel/softirq.c:642 __do_softirq kernel/softirq.c:680 [inline] invoke_softirq kernel/softirq.c:497 [inline] __irq_exit_rcu+0x52/0xf0 kernel/softirq.c:729 irq_exit_rcu+0x9/0x10 kernel/softirq.c:741 instr_sysvec_apic_timer_interrupt arch/x86/kernel/apic/apic.c:1118 [inline] sysvec_apic_timer_interrupt+0xa9/0xc0 arch/x86/kernel/apic/apic.c:1118 asm_sysvec_apic_timer_interrupt+0x1b/0x20 arch/x86/include/asm/idtentry.h:691 RIP: 0010:__raw_spin_unlock_irq include/linux/spinlock_api_smp.h:160 [inline] RIP: 0010:_raw_spin_unlock_irq+0x48/0x70 kernel/locking/spinlock.c:202 Code: 74 12 48 89 fb 48 c7 c7 00 d5 0d 87 e8 01 b8 b4 fc 48 89 df 48 83 3d 46 6a 0b 02 00 74 26 e8 13 0d 00 00 90 fb bf 01 00 00 00 83 3d 4a fc 65 8b 05 f4 02 00 7b 85 c0 74 03 5b 5d c3 e8 f4 11 RSP: 0018:ffffc90012ae7608 EFLAGS: 00000246 RAX: 0000000000000001 RBX: ffffea00050493c0 RCX: dffffc0000000000 RDX: ffffc9000265e000 RSI: 000000000007ffff RDI: 0000000000000001 RBP: ffffc90012ae7610 R08: ffff88813e68583f R09: 1ffff11027cd0b07 R10: dffffc0000000000 R11: ffffed1027cd0b08 R12: ffff8881308f5500 R13: 1ffff1102611ea9f R14: ffff8881308f54f8 R15: ffffc90012ae7660 spin_unlock_irq include/linux/spinlock.h:401 [inline] filemap_remove_folio+0x10f/0x490 mm/filemap.c:276 truncate_inode_folio+0x5d/0x70 mm/truncate.c:199 shmem_undo_range+0x456/0x1540 mm/shmem.c:947 shmem_truncate_range mm/shmem.c:1067 [inline] shmem_evict_inode+0x255/0xa50 mm/shmem.c:1176 evict+0x4d7/0x8f0 fs/inode.c:708 iput_final fs/inode.c:1844 [inline] iput+0x620/0x670 fs/inode.c:1870 dentry_unlink_inode+0x33d/0x3f0 fs/dcache.c:405 __dentry_kill+0x460/0x670 fs/dcache.c:611 dentry_kill+0xc0/0x2a0 fs/dcache.c:-1 dput+0x42/0x80 fs/dcache.c:918 __fput+0x5be/0x8f0 fs/file_table.c:328 ____fput+0x15/0x20 fs/file_table.c:348 task_work_run+0x1e1/0x250 kernel/task_work.c:203 resume_user_mode_work include/linux/resume_user_mode.h:49 [inline] exit_to_user_mode_loop+0x9b/0xb0 kernel/entry/common.c:177 exit_to_user_mode_prepare+0x87/0xd0 kernel/entry/common.c:210 __syscall_exit_to_user_mode_work kernel/entry/common.c:292 [inline] syscall_exit_to_user_mode+0x1a/0x30 kernel/entry/common.c:303 do_syscall_64+0x58/0xa0 arch/x86/entry/common.c:82 entry_SYSCALL_64_after_hwframe+0x68/0xd2 RIP: 0033:0x7f589c15d68e Code: 08 0f 85 a5 a8 ff ff 49 89 fb 48 89 f0 48 89 d7 48 89 ce 4c 89 c2 4d 89 ca 4c 8b 44 24 08 4c 8b 4c 24 10 4c 89 5c 24 08 0f 05 66 2e 0f 1f 84 00 00 00 00 00 0f 1f 80 00 00 00 00 48 83 ec 08 RSP: 002b:00007f589d125da8 EFLAGS: 00000246 ORIG_RAX: 0000000000000003 RAX: 0000000000000000 RBX: 00007f589d1266c0 RCX: 00007f589c15d68e RDX: 0000000000000000 RSI: 0000000000000000 RDI: 0000000000000003 RBP: 0000000000000002 R08: 0000000000000000 R09: 0000000000000000 R10: 0000000000000000 R11: 0000000000000246 R12: 0000000000000003 R13: 00007f589d125ee0 R14: 00007f589d125ea0 R15: 00007f58927f8000 ================================================================================ aiptek 3-1:0.0: aiptek_irq - usb_submit_urb failed with result -19 ---------------- Code disassembly (best guess): 0: 74 12 je 0x14 2: 48 89 fb mov %rdi,%rbx 5: 48 c7 c7 00 d5 0d 87 mov $0xffffffff870dd500,%rdi c: e8 01 b8 b4 fc call 0xfcb4b812 11: 48 89 df mov %rbx,%rdi 14: 48 83 3d 46 6a 0b 02 cmpq $0x0,0x20b6a46(%rip) # 0x20b6a62 1b: 00 1c: 74 26 je 0x44 1e: e8 13 0d 00 00 call 0xd36 23: 90 nop 24: fb sti 25: bf 01 00 00 00 mov $0x1,%edi * 2a: e8 83 3d 4a fc call 0xfc4a3db2 <-- trapping instruction 2f: 65 8b 05 f4 02 00 7b mov %gs:0x7b0002f4(%rip),%eax # 0x7b00032a 36: 85 c0 test %eax,%eax 38: 74 03 je 0x3d 3a: 5b pop %rbx 3b: 5d pop %rbp 3c: c3 ret 3d: e8 .byte 0xe8 3e: f4 hlt 3f: 11 .byte 0x11