================================================================== BUG: KASAN: use-after-free in skb_clear_hash include/linux/skbuff.h:1062 [inline] BUG: KASAN: use-after-free in ip_check_defrag net/ipv4/ip_fragment.c:738 [inline] BUG: KASAN: use-after-free in ip_check_defrag+0x571/0x5b0 net/ipv4/ip_fragment.c:703 Write of size 4 at addr ffff880191f7b95c by task syz-executor0/13408 CPU: 0 PID: 13408 Comm: syz-executor0 Not tainted 4.9.154+ #23 ffff880083fbece8 ffffffff81b47411 0000000000000001 ffffea000647dec0 ffff880191f7b95c 0000000000000004 ffffffff824a4c01 ffff880083fbed20 ffffffff81502615 0000000000000001 ffff880191f7b95c ffff880191f7b95c Call Trace: [] __dump_stack lib/dump_stack.c:15 [inline] [] dump_stack+0xc1/0x120 lib/dump_stack.c:51 [] print_address_description+0x6f/0x238 mm/kasan/report.c:256 [] kasan_report_error mm/kasan/report.c:355 [inline] [] kasan_report mm/kasan/report.c:412 [inline] [] kasan_report.cold+0x8c/0x2ba mm/kasan/report.c:397 [] __asan_report_store4_noabort+0x17/0x20 mm/kasan/report.c:437 [] skb_clear_hash include/linux/skbuff.h:1062 [inline] [] ip_check_defrag net/ipv4/ip_fragment.c:738 [inline] [] ip_check_defrag+0x571/0x5b0 net/ipv4/ip_fragment.c:703 [] packet_rcv_fanout+0x51e/0x5f0 net/packet/af_packet.c:1458 [] dev_queue_xmit_nit+0x5e0/0x800 net/core/dev.c:1950 [] xmit_one net/core/dev.c:2973 [inline] [] dev_hard_start_xmit+0xa7/0x8b0 net/core/dev.c:2993 [] sch_direct_xmit+0x2b1/0x5b0 net/sched/sch_generic.c:182 [] __dev_xmit_skb net/core/dev.c:3173 [inline] [] __dev_queue_xmit+0x154e/0x1bd0 net/core/dev.c:3441 [] dev_queue_xmit+0x18/0x20 net/core/dev.c:3506 [] neigh_hh_output include/net/neighbour.h:486 [inline] [] dst_neigh_output include/net/dst.h:468 [inline] [] ip_finish_output2+0xbf2/0x1280 net/ipv4/ip_output.c:225 [] ip_do_fragment+0x1859/0x1f30 net/ipv4/ip_output.c:671 [] ip_fragment.constprop.0+0x14b/0x200 net/ipv4/ip_output.c:544 [] ip_finish_output+0x7cb/0xce0 net/ipv4/ip_output.c:311 [] NF_HOOK_COND include/linux/netfilter.h:246 [inline] [] ip_mc_output+0x252/0xcb0 net/ipv4/ip_output.c:386 [] dst_output include/net/dst.h:507 [inline] [] ip_local_out+0x9c/0x180 net/ipv4/ip_output.c:124 [] ip_send_skb+0x3e/0xc0 net/ipv4/ip_output.c:1489 [] ip_push_pending_frames+0x64/0x80 net/ipv4/ip_output.c:1509 [] raw_sendmsg+0xbf3/0x23e0 net/ipv4/raw.c:658 [] inet_sendmsg+0x202/0x4d0 net/ipv4/af_inet.c:770 [] sock_sendmsg_nosec net/socket.c:648 [inline] [] sock_sendmsg+0xbe/0x110 net/socket.c:658 [] kernel_sendmsg+0x44/0x50 net/socket.c:666 [] sock_no_sendpage+0x116/0x150 net/core/sock.c:2335 [] inet_sendpage+0x3bc/0x520 net/ipv4/af_inet.c:788 [] kernel_sendpage+0x95/0xf0 net/socket.c:3334 [] sock_sendpage+0x8b/0xc0 net/socket.c:802 [] pipe_to_sendpage+0x28d/0x3d0 fs/splice.c:470 [] splice_from_pipe_feed fs/splice.c:521 [inline] [] __splice_from_pipe+0x351/0x790 fs/splice.c:645 [] splice_from_pipe+0x108/0x170 fs/splice.c:680 [] generic_splice_sendpage+0x3c/0x50 fs/splice.c:851 [] do_splice_from fs/splice.c:870 [inline] [] do_splice fs/splice.c:1166 [inline] [] SYSC_splice fs/splice.c:1416 [inline] [] SyS_splice+0xddd/0x1440 fs/splice.c:1399 [] do_syscall_64+0x1ad/0x570 arch/x86/entry/common.c:285 [] entry_SYSCALL_64_after_swapgs+0x5d/0xdb Allocated by task 13408: save_stack_trace+0x16/0x20 arch/x86/kernel/stacktrace.c:57 save_stack mm/kasan/kasan.c:505 [inline] set_track mm/kasan/kasan.c:517 [inline] kasan_kmalloc.part.0+0x62/0xf0 mm/kasan/kasan.c:609 kasan_kmalloc+0xb7/0xd0 mm/kasan/kasan.c:594 kasan_slab_alloc+0xf/0x20 mm/kasan/kasan.c:547 slab_post_alloc_hook mm/slab.h:417 [inline] slab_alloc_node mm/slub.c:2715 [inline] slab_alloc mm/slub.c:2723 [inline] kmem_cache_alloc+0xd5/0x2b0 mm/slub.c:2728 skb_clone+0x122/0x2a0 net/core/skbuff.c:1034 dev_queue_xmit_nit+0x2d2/0x800 net/core/dev.c:1919 xmit_one net/core/dev.c:2973 [inline] dev_hard_start_xmit+0xa7/0x8b0 net/core/dev.c:2993 sch_direct_xmit+0x2b1/0x5b0 net/sched/sch_generic.c:182 __dev_xmit_skb net/core/dev.c:3173 [inline] __dev_queue_xmit+0x154e/0x1bd0 net/core/dev.c:3441 dev_queue_xmit+0x18/0x20 net/core/dev.c:3506 neigh_hh_output include/net/neighbour.h:486 [inline] dst_neigh_output include/net/dst.h:468 [inline] ip_finish_output2+0xbf2/0x1280 net/ipv4/ip_output.c:225 ip_do_fragment+0x1859/0x1f30 net/ipv4/ip_output.c:671 ip_fragment.constprop.0+0x14b/0x200 net/ipv4/ip_output.c:544 ip_finish_output+0x7cb/0xce0 net/ipv4/ip_output.c:311 NF_HOOK_COND include/linux/netfilter.h:246 [inline] ip_mc_output+0x252/0xcb0 net/ipv4/ip_output.c:386 dst_output include/net/dst.h:507 [inline] ip_local_out+0x9c/0x180 net/ipv4/ip_output.c:124 ip_send_skb+0x3e/0xc0 net/ipv4/ip_output.c:1489 ip_push_pending_frames+0x64/0x80 net/ipv4/ip_output.c:1509 raw_sendmsg+0xbf3/0x23e0 net/ipv4/raw.c:658 inet_sendmsg+0x202/0x4d0 net/ipv4/af_inet.c:770 sock_sendmsg_nosec net/socket.c:648 [inline] sock_sendmsg+0xbe/0x110 net/socket.c:658 kernel_sendmsg+0x44/0x50 net/socket.c:666 sock_no_sendpage+0x116/0x150 net/core/sock.c:2335 inet_sendpage+0x3bc/0x520 net/ipv4/af_inet.c:788 kernel_sendpage+0x95/0xf0 net/socket.c:3334 sock_sendpage+0x8b/0xc0 net/socket.c:802 pipe_to_sendpage+0x28d/0x3d0 fs/splice.c:470 splice_from_pipe_feed fs/splice.c:521 [inline] __splice_from_pipe+0x351/0x790 fs/splice.c:645 splice_from_pipe+0x108/0x170 fs/splice.c:680 generic_splice_sendpage+0x3c/0x50 fs/splice.c:851 do_splice_from fs/splice.c:870 [inline] do_splice fs/splice.c:1166 [inline] SYSC_splice fs/splice.c:1416 [inline] SyS_splice+0xddd/0x1440 fs/splice.c:1399 do_syscall_64+0x1ad/0x570 arch/x86/entry/common.c:285 entry_SYSCALL_64_after_swapgs+0x5d/0xdb Freed by task 13408: save_stack_trace+0x16/0x20 arch/x86/kernel/stacktrace.c:57 save_stack mm/kasan/kasan.c:505 [inline] set_track mm/kasan/kasan.c:517 [inline] kasan_slab_free+0xb0/0x190 mm/kasan/kasan.c:582 slab_free_hook mm/slub.c:1355 [inline] slab_free_freelist_hook mm/slub.c:1377 [inline] slab_free mm/slub.c:2958 [inline] kmem_cache_free+0xbe/0x310 mm/slub.c:2980 kfree_skbmem+0x9f/0x100 net/core/skbuff.c:623 __kfree_skb net/core/skbuff.c:685 [inline] kfree_skb+0xd4/0x350 net/core/skbuff.c:705 ip_frag_queue net/ipv4/ip_fragment.c:505 [inline] ip_defrag+0x620/0x3bc0 net/ipv4/ip_fragment.c:690 ip_check_defrag net/ipv4/ip_fragment.c:736 [inline] ip_check_defrag+0x3d6/0x5b0 net/ipv4/ip_fragment.c:703 packet_rcv_fanout+0x51e/0x5f0 net/packet/af_packet.c:1458 dev_queue_xmit_nit+0x5e0/0x800 net/core/dev.c:1950 xmit_one net/core/dev.c:2973 [inline] dev_hard_start_xmit+0xa7/0x8b0 net/core/dev.c:2993 sch_direct_xmit+0x2b1/0x5b0 net/sched/sch_generic.c:182 __dev_xmit_skb net/core/dev.c:3173 [inline] __dev_queue_xmit+0x154e/0x1bd0 net/core/dev.c:3441 dev_queue_xmit+0x18/0x20 net/core/dev.c:3506 neigh_hh_output include/net/neighbour.h:486 [inline] dst_neigh_output include/net/dst.h:468 [inline] ip_finish_output2+0xbf2/0x1280 net/ipv4/ip_output.c:225 ip_do_fragment+0x1859/0x1f30 net/ipv4/ip_output.c:671 ip_fragment.constprop.0+0x14b/0x200 net/ipv4/ip_output.c:544 ip_finish_output+0x7cb/0xce0 net/ipv4/ip_output.c:311 NF_HOOK_COND include/linux/netfilter.h:246 [inline] ip_mc_output+0x252/0xcb0 net/ipv4/ip_output.c:386 dst_output include/net/dst.h:507 [inline] ip_local_out+0x9c/0x180 net/ipv4/ip_output.c:124 ip_send_skb+0x3e/0xc0 net/ipv4/ip_output.c:1489 ip_push_pending_frames+0x64/0x80 net/ipv4/ip_output.c:1509 raw_sendmsg+0xbf3/0x23e0 net/ipv4/raw.c:658 inet_sendmsg+0x202/0x4d0 net/ipv4/af_inet.c:770 sock_sendmsg_nosec net/socket.c:648 [inline] sock_sendmsg+0xbe/0x110 net/socket.c:658 kernel_sendmsg+0x44/0x50 net/socket.c:666 sock_no_sendpage+0x116/0x150 net/core/sock.c:2335 inet_sendpage+0x3bc/0x520 net/ipv4/af_inet.c:788 kernel_sendpage+0x95/0xf0 net/socket.c:3334 sock_sendpage+0x8b/0xc0 net/socket.c:802 pipe_to_sendpage+0x28d/0x3d0 fs/splice.c:470 splice_from_pipe_feed fs/splice.c:521 [inline] __splice_from_pipe+0x351/0x790 fs/splice.c:645 splice_from_pipe+0x108/0x170 fs/splice.c:680 generic_splice_sendpage+0x3c/0x50 fs/splice.c:851 do_splice_from fs/splice.c:870 [inline] do_splice fs/splice.c:1166 [inline] SYSC_splice fs/splice.c:1416 [inline] SyS_splice+0xddd/0x1440 fs/splice.c:1399 do_syscall_64+0x1ad/0x570 arch/x86/entry/common.c:285 entry_SYSCALL_64_after_swapgs+0x5d/0xdb The buggy address belongs to the object at ffff880191f7b8c0 which belongs to the cache skbuff_head_cache of size 224 The buggy address is located 156 bytes inside of 224-byte region [ffff880191f7b8c0, ffff880191f7b9a0) The buggy address belongs to the page: page:ffffea000647dec0 count:1 mapcount:0 mapping: (null) index:0x0 flags: 0x4000000000000080(slab) page dumped because: kasan: bad access detected Memory state around the buggy address: ffff880191f7b800: fb fb fb fb fb fb fb fb fb fb fb fb fc fc fc fc ffff880191f7b880: fc fc fc fc fc fc fc fc fb fb fb fb fb fb fb fb >ffff880191f7b900: fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb ^ ffff880191f7b980: fb fb fb fb fc fc fc fc fc fc fc fc fc fc fc fc ffff880191f7ba00: fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb ==================================================================