================================================================== BUG: KASAN: use-after-free in ip6_dst_idev include/net/ip6_fib.h:192 [inline] BUG: KASAN: use-after-free in ip6_xmit+0x1f76/0x2260 net/ipv6/ip6_output.c:264 Read of size 8 at addr ffff8801cd68f518 by task syz-executor3/4689 CPU: 1 PID: 4689 Comm: syz-executor3 Not tainted 4.16.0-rc4+ #262 Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS Google 01/01/2011 Call Trace: __dump_stack lib/dump_stack.c:17 [inline] dump_stack+0x194/0x24d lib/dump_stack.c:53 print_address_description+0x73/0x250 mm/kasan/report.c:256 kasan_report_error mm/kasan/report.c:354 [inline] kasan_report+0x23c/0x360 mm/kasan/report.c:412 __asan_report_load8_noabort+0x14/0x20 mm/kasan/report.c:433 ip6_dst_idev include/net/ip6_fib.h:192 [inline] ip6_xmit+0x1f76/0x2260 net/ipv6/ip6_output.c:264 inet6_csk_xmit+0x2fc/0x580 net/ipv6/inet6_connection_sock.c:139 l2tp_xmit_core net/l2tp/l2tp_core.c:1053 [inline] l2tp_xmit_skb+0x105f/0x1410 net/l2tp/l2tp_core.c:1148 pppol2tp_sendmsg+0x470/0x670 net/l2tp/l2tp_ppp.c:341 sock_sendmsg_nosec net/socket.c:629 [inline] sock_sendmsg+0xca/0x110 net/socket.c:639 SYSC_sendto+0x361/0x5c0 net/socket.c:1748 SyS_sendto+0x40/0x50 net/socket.c:1716 do_syscall_64+0x281/0x940 arch/x86/entry/common.c:287 entry_SYSCALL_64_after_hwframe+0x42/0xb7 RIP: 0033:0x453e69 RSP: 002b:00007f1ca8a6dc68 EFLAGS: 00000246 ORIG_RAX: 000000000000002c RAX: ffffffffffffffda RBX: 00007f1ca8a6e6d4 RCX: 0000000000453e69 RDX: 000000000000100b RSI: 0000000020001180 RDI: 0000000000000014 RBP: 000000000072bea0 R08: 00000000200021c0 R09: 0000000000000080 R10: 0000000000040001 R11: 0000000000000246 R12: 00000000ffffffff R13: 00000000000004ca R14: 00000000006f7390 R15: 0000000000000000 Allocated by task 763: save_stack+0x43/0xd0 mm/kasan/kasan.c:447 set_track mm/kasan/kasan.c:459 [inline] kasan_kmalloc+0xad/0xe0 mm/kasan/kasan.c:552 kasan_slab_alloc+0x12/0x20 mm/kasan/kasan.c:489 kmem_cache_alloc+0x12e/0x760 mm/slab.c:3541 dst_alloc+0x11f/0x1a0 net/core/dst.c:104 rt_dst_alloc+0xe9/0x4e0 net/ipv4/route.c:1508 __mkroute_output net/ipv4/route.c:2245 [inline] ip_route_output_key_hash_rcu+0xa59/0x2fe0 net/ipv4/route.c:2471 ip_route_output_key_hash+0x20b/0x370 net/ipv4/route.c:2300 __ip_route_output_key include/net/route.h:123 [inline] ip_route_output_flow+0x26/0xa0 net/ipv4/route.c:2554 ip_route_output_key include/net/route.h:133 [inline] sctp_v4_get_dst+0x5f9/0x15b0 net/sctp/protocol.c:458 sctp_transport_route+0xa8/0x430 net/sctp/transport.c:293 sctp_assoc_add_peer+0x4fe/0x1190 net/sctp/associola.c:655 sctp_process_param net/sctp/sm_make_chunk.c:2546 [inline] sctp_process_init+0x1567/0x2440 net/sctp/sm_make_chunk.c:2362 sctp_sf_do_5_1B_init+0x8c9/0xe80 net/sctp/sm_statefuns.c:414 sctp_do_sm+0x192/0x6ed0 net/sctp/sm_sideeffect.c:1178 sctp_endpoint_bh_rcv+0x379/0x8f0 net/sctp/endpointola.c:456 sctp_inq_push+0x23b/0x300 net/sctp/inqueue.c:95 sctp_rcv+0x29f3/0x35c0 net/sctp/input.c:267 sctp6_rcv+0x15/0x30 net/sctp/ipv6.c:1011 ip6_input_finish+0x37e/0x17a0 net/ipv6/ip6_input.c:284 NF_HOOK include/linux/netfilter.h:288 [inline] ip6_input+0xdb/0x560 net/ipv6/ip6_input.c:327 dst_input include/net/dst.h:450 [inline] ip6_rcv_finish+0x297/0x8c0 net/ipv6/ip6_input.c:71 NF_HOOK include/linux/netfilter.h:288 [inline] ipv6_rcv+0xf38/0x1fb0 net/ipv6/ip6_input.c:208 __netif_receive_skb_core+0x1a41/0x3460 net/core/dev.c:4557 __netif_receive_skb+0x2c/0x1b0 net/core/dev.c:4622 process_backlog+0x203/0x740 net/core/dev.c:5302 napi_poll net/core/dev.c:5700 [inline] net_rx_action+0x792/0x1910 net/core/dev.c:5766 __do_softirq+0x2d7/0xb85 kernel/softirq.c:285 Freed by task 4238: save_stack+0x43/0xd0 mm/kasan/kasan.c:447 set_track mm/kasan/kasan.c:459 [inline] __kasan_slab_free+0x11a/0x170 mm/kasan/kasan.c:520 kasan_slab_free+0xe/0x10 mm/kasan/kasan.c:527 __cache_free mm/slab.c:3485 [inline] kmem_cache_free+0x83/0x2a0 mm/slab.c:3743 dst_destroy+0x257/0x370 net/core/dst.c:140 dst_destroy_rcu+0x16/0x20 net/core/dst.c:153 __rcu_reclaim kernel/rcu/rcu.h:172 [inline] rcu_do_batch kernel/rcu/tree.c:2674 [inline] invoke_rcu_callbacks kernel/rcu/tree.c:2933 [inline] __rcu_process_callbacks kernel/rcu/tree.c:2900 [inline] rcu_process_callbacks+0xd6c/0x17f0 kernel/rcu/tree.c:2917 __do_softirq+0x2d7/0xb85 kernel/softirq.c:285 The buggy address belongs to the object at ffff8801cd68f500 which belongs to the cache ip_dst_cache of size 160 The buggy address is located 24 bytes inside of 160-byte region [ffff8801cd68f500, ffff8801cd68f5a0) The buggy address belongs to the page: page:ffffea000735a3c0 count:1 mapcount:0 mapping:ffff8801cd68f000 index:0x0 flags: 0x2fffc0000000100(slab) raw: 02fffc0000000100 ffff8801cd68f000 0000000000000000 0000000100000010 raw: ffffea0007377e60 ffffea0006af7fe0 ffff8801d6bce1c0 0000000000000000 page dumped because: kasan: bad access detected Memory state around the buggy address: ffff8801cd68f400: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ffff8801cd68f480: 00 00 00 00 fc fc fc fc fc fc fc fc fc fc fc fc >ffff8801cd68f500: fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb ^ ffff8801cd68f580: fb fb fb fb fc fc fc fc fc fc fc fc fc fc fc fc ffff8801cd68f600: fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb ==================================================================