syzbot


KASAN: slab-use-after-free Read in sk_filter_trim_cap

Status: upstream: reported on 2024/09/04 12:35
Subsystems: net bpf
[Documentation on labels]
Reported-by: syzbot+b4bc25bfaad44df51f05@syzkaller.appspotmail.com
First crash: 250d, last: 10h27m
Discussions (2)
Title Replies (including bot) Last reply
[syzbot] Monthly bpf report (Apr 2025) 0 (1) 2025/04/24 07:48
[syzbot] [bpf?] [net?] KASAN: slab-use-after-free Read in sk_filter_trim_cap 0 (1) 2024/09/04 12:35
Similar bugs (2)
Kernel Title Repro Cause bisect Fix bisect Count Last Reported Patched Status
linux-4.19 KASAN: use-after-free Read in sk_filter_trim_cap 1 1159d 1159d 0/1 auto-closed as invalid on 2022/07/07 20:56
linux-6.1 KASAN: use-after-free Read in sk_filter_trim_cap 1 296d 296d 0/3 auto-obsoleted due to no activity on 2024/10/27 21:54

Sample crash report:
==================================================================
BUG: KASAN: slab-use-after-free in sk_filter_trim_cap+0x25a/0xa70 net/core/filter.c:156
Read of size 8 at addr ffff88805e69b178 by task syz.4.1564/12566

CPU: 1 UID: 0 PID: 12566 Comm: syz.4.1564 Not tainted 6.15.0-rc5-syzkaller-00136-g4d64321c4f6f #0 PREEMPT(full) 
Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS Google 05/07/2025
Call Trace:
 <TASK>
 dump_stack_lvl+0x189/0x250 lib/dump_stack.c:120
 print_address_description mm/kasan/report.c:408 [inline]
 print_report+0xb4/0x290 mm/kasan/report.c:521
 kasan_report+0x118/0x150 mm/kasan/report.c:634
 sk_filter_trim_cap+0x25a/0xa70 net/core/filter.c:156
 sk_filter include/linux/filter.h:1079 [inline]
 sock_queue_rcv_skb_reason+0x28/0xe0 net/core/sock.c:527
 sock_queue_rcv_skb include/net/sock.h:2433 [inline]
 mgmt_cmd_status+0x286/0x4c0 net/bluetooth/mgmt_util.c:156
 cmd_status_rsp net/bluetooth/mgmt.c:1464 [inline]
 cmd_complete_rsp+0x10d/0x1a0 net/bluetooth/mgmt.c:1484
 mgmt_pending_foreach+0xc9/0x120 net/bluetooth/mgmt_util.c:242
 __mgmt_power_off+0x15f/0x340 net/bluetooth/mgmt.c:9432
 hci_dev_close_sync+0x754/0x1330 net/bluetooth/hci_sync.c:5221
 hci_dev_do_close net/bluetooth/hci_core.c:483 [inline]
 hci_dev_close+0x106/0x200 net/bluetooth/hci_core.c:508
 sock_do_ioctl+0xd9/0x300 net/socket.c:1190
 sock_ioctl+0x576/0x790 net/socket.c:1311
 vfs_ioctl fs/ioctl.c:51 [inline]
 __do_sys_ioctl fs/ioctl.c:906 [inline]
 __se_sys_ioctl+0xf9/0x170 fs/ioctl.c:892
 do_syscall_x64 arch/x86/entry/syscall_64.c:63 [inline]
 do_syscall_64+0xf6/0x210 arch/x86/entry/syscall_64.c:94
 entry_SYSCALL_64_after_hwframe+0x77/0x7f
RIP: 0033:0x7ff4d818e969
Code: ff ff c3 66 2e 0f 1f 84 00 00 00 00 00 0f 1f 40 00 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 a8 ff ff ff f7 d8 64 89 01 48
RSP: 002b:00007ff4d902b038 EFLAGS: 00000246 ORIG_RAX: 0000000000000010
RAX: ffffffffffffffda RBX: 00007ff4d83b5fa0 RCX: 00007ff4d818e969
RDX: 0000000000000000 RSI: 00000000400448ca RDI: 0000000000000004
RBP: 00007ff4d8210ab1 R08: 0000000000000000 R09: 0000000000000000
R10: 0000000000000000 R11: 0000000000000246 R12: 0000000000000000
R13: 0000000000000000 R14: 00007ff4d83b5fa0 R15: 00007ffe61e69568
 </TASK>

Allocated by task 11260:
 kasan_save_stack mm/kasan/common.c:47 [inline]
 kasan_save_track+0x3e/0x80 mm/kasan/common.c:68
 poison_kmalloc_redzone mm/kasan/common.c:377 [inline]
 __kasan_kmalloc+0x93/0xb0 mm/kasan/common.c:394
 kasan_kmalloc include/linux/kasan.h:260 [inline]
 __do_kmalloc_node mm/slub.c:4327 [inline]
 __kmalloc_noprof+0x27a/0x4f0 mm/slub.c:4339
 kmalloc_noprof include/linux/slab.h:909 [inline]
 sk_prot_alloc+0xe7/0x220 net/core/sock.c:2198
 sk_alloc+0x3a/0x370 net/core/sock.c:2254
 bt_sock_alloc+0x3b/0x310 net/bluetooth/af_bluetooth.c:148
 hci_sock_create+0xa3/0x190 net/bluetooth/hci_sock.c:2202
 bt_sock_create+0x160/0x240 net/bluetooth/af_bluetooth.c:132
 __sock_create+0x4b0/0x9f0 net/socket.c:1541
 sock_create net/socket.c:1599 [inline]
 __sys_socket_create net/socket.c:1636 [inline]
 __sys_socket+0xd7/0x1b0 net/socket.c:1683
 __do_sys_socket net/socket.c:1697 [inline]
 __se_sys_socket net/socket.c:1695 [inline]
 __x64_sys_socket+0x7a/0x90 net/socket.c:1695
 do_syscall_x64 arch/x86/entry/syscall_64.c:63 [inline]
 do_syscall_64+0xf6/0x210 arch/x86/entry/syscall_64.c:94
 entry_SYSCALL_64_after_hwframe+0x77/0x7f

Freed by task 12567:
 kasan_save_stack mm/kasan/common.c:47 [inline]
 kasan_save_track+0x3e/0x80 mm/kasan/common.c:68
 kasan_save_free_info+0x46/0x50 mm/kasan/generic.c:576
 poison_slab_object mm/kasan/common.c:247 [inline]
 __kasan_slab_free+0x62/0x70 mm/kasan/common.c:264
 kasan_slab_free include/linux/kasan.h:233 [inline]
 slab_free_hook mm/slub.c:2380 [inline]
 slab_free mm/slub.c:4642 [inline]
 kfree+0x193/0x440 mm/slub.c:4841
 sk_prot_free net/core/sock.c:2237 [inline]
 __sk_destruct+0x4e1/0x660 net/core/sock.c:2332
 sock_put include/net/sock.h:1944 [inline]
 mgmt_pending_free net/bluetooth/mgmt_util.c:290 [inline]
 mgmt_pending_remove+0x141/0x1a0 net/bluetooth/mgmt_util.c:298
 mgmt_pending_foreach+0xc9/0x120 net/bluetooth/mgmt_util.c:242
 mgmt_index_removed+0x10d/0x2f0 net/bluetooth/mgmt.c:9365
 hci_sock_bind+0xbe9/0x1000 net/bluetooth/hci_sock.c:1307
 __sys_bind_socket net/socket.c:1810 [inline]
 __sys_bind+0x2c3/0x3e0 net/socket.c:1841
 __do_sys_bind net/socket.c:1846 [inline]
 __se_sys_bind net/socket.c:1844 [inline]
 __x64_sys_bind+0x7a/0x90 net/socket.c:1844
 do_syscall_x64 arch/x86/entry/syscall_64.c:63 [inline]
 do_syscall_64+0xf6/0x210 arch/x86/entry/syscall_64.c:94
 entry_SYSCALL_64_after_hwframe+0x77/0x7f

The buggy address belongs to the object at ffff88805e69b000
 which belongs to the cache kmalloc-2k of size 2048
The buggy address is located 376 bytes inside of
 freed 2048-byte region [ffff88805e69b000, ffff88805e69b800)

The buggy address belongs to the physical page:
page: refcount:0 mapcount:0 mapping:0000000000000000 index:0x0 pfn:0x5e698
head: order:3 mapcount:0 entire_mapcount:0 nr_pages_mapped:0 pincount:0
anon flags: 0xfff00000000040(head|node=0|zone=1|lastcpupid=0x7ff)
page_type: f5(slab)
raw: 00fff00000000040 ffff88801a042000 0000000000000000 dead000000000001
raw: 0000000000000000 0000000000080008 00000000f5000000 0000000000000000
head: 00fff00000000040 ffff88801a042000 0000000000000000 dead000000000001
head: 0000000000000000 0000000000080008 00000000f5000000 0000000000000000
head: 00fff00000000003 ffffea000179a601 00000000ffffffff 00000000ffffffff
head: ffffffffffffffff 0000000000000000 00000000ffffffff 0000000000000008
page dumped because: kasan: bad access detected
page_owner tracks the page as allocated
page last allocated via order 3, migratetype Unmovable, gfp_mask 0xd20c0(__GFP_IO|__GFP_FS|__GFP_NOWARN|__GFP_NORETRY|__GFP_COMP|__GFP_NOMEMALLOC), pid 5838, tgid 5838 (syz-executor), ts 88752123039, free_ts 29827126410
 set_page_owner include/linux/page_owner.h:32 [inline]
 post_alloc_hook+0x1d8/0x230 mm/page_alloc.c:1718
 prep_new_page mm/page_alloc.c:1726 [inline]
 get_page_from_freelist+0x21ce/0x22b0 mm/page_alloc.c:3688
 __alloc_frozen_pages_noprof+0x181/0x370 mm/page_alloc.c:4970
 alloc_pages_mpol+0x232/0x4a0 mm/mempolicy.c:2301
 alloc_slab_page mm/slub.c:2450 [inline]
 allocate_slab+0x8a/0x3b0 mm/slub.c:2618
 new_slab mm/slub.c:2672 [inline]
 ___slab_alloc+0xbfc/0x1480 mm/slub.c:3858
 __slab_alloc mm/slub.c:3948 [inline]
 __slab_alloc_node mm/slub.c:4023 [inline]
 slab_alloc_node mm/slub.c:4184 [inline]
 __do_kmalloc_node mm/slub.c:4326 [inline]
 __kmalloc_noprof+0x305/0x4f0 mm/slub.c:4339
 kmalloc_noprof include/linux/slab.h:909 [inline]
 sk_prot_alloc+0xe7/0x220 net/core/sock.c:2198
 sk_alloc+0x3a/0x370 net/core/sock.c:2254
 __netlink_create+0x65/0x260 net/netlink/af_netlink.c:629
 netlink_create+0x3ca/0x590 net/netlink/af_netlink.c:687
 __sock_create+0x4b0/0x9f0 net/socket.c:1541
 sock_create net/socket.c:1599 [inline]
 __sys_socket_create net/socket.c:1636 [inline]
 __sys_socket+0xd7/0x1b0 net/socket.c:1683
 __do_sys_socket net/socket.c:1697 [inline]
 __se_sys_socket net/socket.c:1695 [inline]
 __x64_sys_socket+0x7a/0x90 net/socket.c:1695
 do_syscall_x64 arch/x86/entry/syscall_64.c:63 [inline]
 do_syscall_64+0xf6/0x210 arch/x86/entry/syscall_64.c:94
 entry_SYSCALL_64_after_hwframe+0x77/0x7f
page last free pid 1 tgid 1 stack trace:
 reset_page_owner include/linux/page_owner.h:25 [inline]
 free_pages_prepare mm/page_alloc.c:1262 [inline]
 __free_frozen_pages+0xb0e/0xcd0 mm/page_alloc.c:2725
 __free_pages mm/page_alloc.c:5080 [inline]
 free_contig_range+0x159/0x440 mm/page_alloc.c:6936
 destroy_args+0x86/0x460 mm/debug_vm_pgtable.c:1017
 debug_vm_pgtable+0x3cf/0x410 mm/debug_vm_pgtable.c:1397
 do_one_initcall+0x233/0x820 init/main.c:1257
 do_initcall_level+0x137/0x1f0 init/main.c:1319
 do_initcalls+0x69/0xd0 init/main.c:1335
 kernel_init_freeable+0x3d9/0x570 init/main.c:1567
 kernel_init+0x1d/0x1d0 init/main.c:1457
 ret_from_fork+0x4b/0x80 arch/x86/kernel/process.c:153
 ret_from_fork_asm+0x1a/0x30 arch/x86/entry/entry_64.S:245

Memory state around the buggy address:
 ffff88805e69b000: fa fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb
 ffff88805e69b080: fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb
>ffff88805e69b100: fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb
                                                                ^
 ffff88805e69b180: fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb
 ffff88805e69b200: fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb
==================================================================

Crashes (12):
Time Kernel Commit Syzkaller Config Log Report Syz repro C repro VM info Assets (help?) Manager Title
2025/05/11 23:25 net 4d64321c4f6f 77908e5f .config console log report info [disk image] [vmlinux] [kernel image] ci-upstream-net-this-kasan-gce KASAN: slab-use-after-free Read in sk_filter_trim_cap
2025/03/30 11:37 net 2ea396448f26 d3999433 .config console log report info [disk image] [vmlinux] [kernel image] ci-upstream-net-this-kasan-gce KASAN: slab-use-after-free Read in sk_filter_trim_cap
2025/03/26 10:44 net 0032c99e83b9 89d30d73 .config console log report info [disk image] [vmlinux] [kernel image] ci-upstream-net-this-kasan-gce KASAN: slab-use-after-free Read in sk_filter_trim_cap
2025/03/24 08:35 net ed3ba9b6e280 875573af .config console log report info [disk image] [vmlinux] [kernel image] ci-upstream-net-this-kasan-gce KASAN: slab-use-after-free Read in sk_filter_trim_cap
2025/03/21 09:02 net 5fc319360819 62330552 .config console log report info [disk image] [vmlinux] [kernel image] ci-upstream-net-this-kasan-gce KASAN: slab-use-after-free Read in sk_filter_trim_cap
2025/02/09 01:27 net 011b03359038 ef44b750 .config console log report info [disk image] [vmlinux] [kernel image] ci-upstream-net-this-kasan-gce KASAN: slab-use-after-free Read in sk_filter_trim_cap
2025/02/07 06:41 net 2a64c96356c8 53657d1b .config console log report info [disk image] [vmlinux] [kernel image] ci-upstream-net-this-kasan-gce KASAN: slab-use-after-free Read in sk_filter_trim_cap
2025/01/21 06:58 net d640627663bf 6e87cfa2 .config console log report info [disk image] [vmlinux] [kernel image] ci-upstream-net-this-kasan-gce KASAN: slab-use-after-free Read in sk_filter_trim_cap
2024/12/04 06:44 net af8edaeddbc5 b50eb251 .config console log report info [disk image] [vmlinux] [kernel image] ci-upstream-net-this-kasan-gce KASAN: slab-use-after-free Read in sk_filter_trim_cap
2024/09/04 06:58 net 33f339a1ba54 9d47f20a .config console log report info [disk image] [vmlinux] [kernel image] ci-upstream-net-this-kasan-gce KASAN: slab-use-after-free Read in sk_filter_trim_cap
2025/04/20 05:01 net-next 8066e388be48 2a20f901 .config console log report info [disk image] [vmlinux] [kernel image] ci-upstream-net-kasan-gce KASAN: slab-use-after-free Read in sk_filter_trim_cap
2024/11/03 00:35 net-next dbb9a7ef3478 f00eed24 .config console log report info [disk image] [vmlinux] [kernel image] ci-upstream-net-kasan-gce KASAN: slab-use-after-free Read in sk_filter_trim_cap
* Struck through repros no longer work on HEAD.