================================================================== BUG: KASAN: use-after-free in xas_next_entry include/linux/xarray.h:1630 [inline] BUG: KASAN: use-after-free in __io_uring_files_cancel+0x417/0x440 fs/io_uring.c:8681 Read of size 1 at addr ffff8880331af900 by task syz-executor.0/12672 CPU: 0 PID: 12672 Comm: syz-executor.0 Not tainted 5.9.0-rc8-next-20201008-syzkaller #0 Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS Google 01/01/2011 Call Trace: __dump_stack lib/dump_stack.c:77 [inline] dump_stack+0x198/0x1fb lib/dump_stack.c:118 print_address_description.constprop.0.cold+0xae/0x497 mm/kasan/report.c:385 __kasan_report mm/kasan/report.c:545 [inline] kasan_report.cold+0x1f/0x37 mm/kasan/report.c:562 xas_next_entry include/linux/xarray.h:1630 [inline] __io_uring_files_cancel+0x417/0x440 fs/io_uring.c:8681 io_uring_files_cancel include/linux/io_uring.h:35 [inline] exit_files+0xe4/0x170 fs/file.c:456 do_exit+0xae9/0x2930 kernel/exit.c:801 do_group_exit+0x125/0x310 kernel/exit.c:903 get_signal+0x428/0x1f00 kernel/signal.c:2757 arch_do_signal+0x82/0x2470 arch/x86/kernel/signal.c:811 exit_to_user_mode_loop kernel/entry/common.c:161 [inline] exit_to_user_mode_prepare+0x194/0x1f0 kernel/entry/common.c:192 syscall_exit_to_user_mode+0x7a/0x2c0 kernel/entry/common.c:267 entry_SYSCALL_64_after_hwframe+0x44/0xa9 RIP: 0033:0x45de29 Code: Unable to access opcode bytes at RIP 0x45ddff. RSP: 002b:00007faf94ea5cf8 EFLAGS: 00000246 ORIG_RAX: 00000000000000ca RAX: 0000000000000000 RBX: 000000000118bf28 RCX: 000000000045de29 RDX: 0000000000000000 RSI: 0000000000000080 RDI: 000000000118bf28 RBP: 000000000118bf20 R08: 0000000000000000 R09: 0000000000000000 R10: 0000000000000000 R11: 0000000000000246 R12: 000000000118bf2c R13: 00007ffe98d86b3f R14: 00007faf94ea69c0 R15: 000000000118bf2c Allocated by task 12672: kasan_save_stack+0x1b/0x40 mm/kasan/common.c:48 kasan_set_track mm/kasan/common.c:56 [inline] __kasan_kmalloc.constprop.0+0xbf/0xd0 mm/kasan/common.c:461 slab_post_alloc_hook mm/slab.h:514 [inline] slab_alloc mm/slab.c:3314 [inline] kmem_cache_alloc+0x162/0x550 mm/slab.c:3484 xas_alloc+0x330/0x440 lib/xarray.c:374 xas_create+0x2db/0x1020 lib/xarray.c:676 xas_store+0x8a/0x1bb0 lib/xarray.c:784 io_uring_add_task_file fs/io_uring.c:8608 [inline] io_uring_add_task_file+0x212/0x430 fs/io_uring.c:8590 io_uring_get_fd fs/io_uring.c:9116 [inline] io_uring_create fs/io_uring.c:9280 [inline] io_uring_setup+0x2727/0x3660 fs/io_uring.c:9314 do_syscall_64+0x2d/0x70 arch/x86/entry/common.c:46 entry_SYSCALL_64_after_hwframe+0x44/0xa9 Freed by task 9: kasan_save_stack+0x1b/0x40 mm/kasan/common.c:48 kasan_set_track+0x1c/0x30 mm/kasan/common.c:56 kasan_set_free_info+0x1b/0x30 mm/kasan/generic.c:355 __kasan_slab_free+0xd8/0x120 mm/kasan/common.c:422 __cache_free mm/slab.c:3420 [inline] kmem_cache_free.part.0+0x74/0x1d0 mm/slab.c:3695 rcu_do_batch kernel/rcu/tree.c:2484 [inline] rcu_core+0x645/0x1240 kernel/rcu/tree.c:2718 __do_softirq+0x203/0xab6 kernel/softirq.c:298 Last call_rcu(): kasan_save_stack+0x1b/0x40 mm/kasan/common.c:48 kasan_record_aux_stack+0x82/0xb0 mm/kasan/generic.c:346 __call_rcu kernel/rcu/tree.c:2960 [inline] call_rcu+0x15e/0x7d0 kernel/rcu/tree.c:3033 xa_node_free lib/xarray.c:258 [inline] xas_delete_node lib/xarray.c:494 [inline] update_node lib/xarray.c:756 [inline] xas_store+0xbcc/0x1bb0 lib/xarray.c:841 io_uring_del_task_file+0x105/0x1a0 fs/io_uring.c:8630 __io_uring_files_cancel+0x3dd/0x440 fs/io_uring.c:8691 io_uring_files_cancel include/linux/io_uring.h:35 [inline] exit_files+0xe4/0x170 fs/file.c:456 do_exit+0xae9/0x2930 kernel/exit.c:801 do_group_exit+0x125/0x310 kernel/exit.c:903 get_signal+0x428/0x1f00 kernel/signal.c:2757 arch_do_signal+0x82/0x2470 arch/x86/kernel/signal.c:811 exit_to_user_mode_loop kernel/entry/common.c:161 [inline] exit_to_user_mode_prepare+0x194/0x1f0 kernel/entry/common.c:192 syscall_exit_to_user_mode+0x7a/0x2c0 kernel/entry/common.c:267 entry_SYSCALL_64_after_hwframe+0x44/0xa9 Second to last call_rcu(): kasan_save_stack+0x1b/0x40 mm/kasan/common.c:48 kasan_record_aux_stack+0x82/0xb0 mm/kasan/generic.c:346 __call_rcu kernel/rcu/tree.c:2960 [inline] call_rcu+0x15e/0x7d0 kernel/rcu/tree.c:3033 radix_tree_node_free lib/radix-tree.c:308 [inline] delete_node+0xef/0x8c0 lib/radix-tree.c:571 __radix_tree_delete+0x190/0x370 lib/radix-tree.c:1377 radix_tree_delete_item+0xe7/0x230 lib/radix-tree.c:1428 kernfs_put.part.0+0x294/0x540 fs/kernfs/dir.c:535 kernfs_put+0x42/0x50 fs/kernfs/dir.c:511 __kernfs_remove+0x6ef/0xa30 fs/kernfs/dir.c:1344 kernfs_remove_by_name_ns+0x51/0xb0 fs/kernfs/dir.c:1516 kernfs_remove_by_name include/linux/kernfs.h:593 [inline] remove_files+0x96/0x1c0 fs/sysfs/group.c:28 sysfs_remove_group+0x87/0x170 fs/sysfs/group.c:289 sysfs_remove_groups fs/sysfs/group.c:313 [inline] sysfs_remove_groups+0x5c/0xa0 fs/sysfs/group.c:305 device_remove_groups drivers/base/core.c:2039 [inline] device_remove_attrs+0xba/0x160 drivers/base/core.c:2230 device_del+0x4fa/0xec0 drivers/base/core.c:3116 rollback_registered_many+0xd2d/0x1550 net/core/dev.c:9436 unregister_netdevice_many.part.0+0x1a/0x2f0 net/core/dev.c:10579 unregister_netdevice_many+0x36/0x50 net/core/dev.c:10578 ip_tunnel_delete_nets+0x3eb/0x5b0 net/ipv4/ip_tunnel.c:1119 ops_exit_list+0x10d/0x160 net/core/net_namespace.c:190 cleanup_net+0x4ea/0xb10 net/core/net_namespace.c:604 process_one_work+0x933/0x15a0 kernel/workqueue.c:2269 worker_thread+0x64c/0x1120 kernel/workqueue.c:2415 kthread+0x3af/0x4a0 kernel/kthread.c:292 ret_from_fork+0x1f/0x30 arch/x86/entry/entry_64.S:296 The buggy address belongs to the object at ffff8880331af900 which belongs to the cache radix_tree_node of size 576 The buggy address is located 0 bytes inside of 576-byte region [ffff8880331af900, ffff8880331afb40) The buggy address belongs to the page: page:0000000082a898a8 refcount:1 mapcount:0 mapping:0000000000000000 index:0xffff8880331afffb pfn:0x331af flags: 0xfffe0000000200(slab) raw: 00fffe0000000200 ffffea0000cc6208 ffffea0001d605c8 ffff88800ec6f000 raw: ffff8880331afffb ffff8880331af0c0 0000000100000005 0000000000000000 page dumped because: kasan: bad access detected Memory state around the buggy address: ffff8880331af800: fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb ffff8880331af880: fc fc fc fc fc fc fc fc fc fc fc fc fc fc fc fc >ffff8880331af900: fa fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb ^ ffff8880331af980: fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb ffff8880331afa00: fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb ==================================================================