================================================================== BUG: KASAN: use-after-free in rxrpc_send_keepalive+0x8a2/0x940 net/rxrpc/output.c:634 Read of size 8 at addr ffff88809f15a058 by task kworker/0:4/8694 CPU: 0 PID: 8694 Comm: kworker/0:4 Not tainted 5.4.0-rc1+ #0 Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS Google 01/01/2011 Workqueue: krxrpcd rxrpc_peer_keepalive_worker Call Trace: __dump_stack lib/dump_stack.c:77 [inline] dump_stack+0x172/0x1f0 lib/dump_stack.c:113 print_address_description.constprop.0.cold+0xd4/0x30b mm/kasan/report.c:374 __kasan_report.cold+0x1b/0x41 mm/kasan/report.c:506 kasan_report+0x12/0x20 mm/kasan/common.c:634 __asan_report_load8_noabort+0x14/0x20 mm/kasan/generic_report.c:132 rxrpc_send_keepalive+0x8a2/0x940 net/rxrpc/output.c:634 rxrpc_peer_keepalive_dispatch net/rxrpc/peer_event.c:369 [inline] rxrpc_peer_keepalive_worker+0x7be/0xd02 net/rxrpc/peer_event.c:430 process_one_work+0x9af/0x1740 kernel/workqueue.c:2269 worker_thread+0x98/0xe40 kernel/workqueue.c:2415 kthread+0x361/0x430 kernel/kthread.c:255 ret_from_fork+0x24/0x30 arch/x86/entry/entry_64.S:352 Allocated by task 17817: save_stack+0x23/0x90 mm/kasan/common.c:69 set_track mm/kasan/common.c:77 [inline] __kasan_kmalloc mm/kasan/common.c:510 [inline] __kasan_kmalloc.constprop.0+0xcf/0xe0 mm/kasan/common.c:483 kasan_kmalloc+0x9/0x10 mm/kasan/common.c:524 __do_kmalloc_node mm/slab.c:3615 [inline] __kmalloc_node_track_caller+0x4e/0x70 mm/slab.c:3629 __kmalloc_reserve.isra.0+0x40/0xf0 net/core/skbuff.c:141 __alloc_skb+0x10b/0x5e0 net/core/skbuff.c:209 alloc_skb_fclone include/linux/skbuff.h:1099 [inline] sk_stream_alloc_skb net/ipv4/tcp.c:875 [inline] sk_stream_alloc_skb+0x113/0xc50 net/ipv4/tcp.c:852 tso_fragment net/ipv4/tcp_output.c:1886 [inline] tcp_write_xmit+0x813/0x5910 net/ipv4/tcp_output.c:2434 __tcp_push_pending_frames+0xb4/0x350 net/ipv4/tcp_output.c:2616 tcp_push_pending_frames include/net/tcp.h:1809 [inline] tcp_data_snd_check net/ipv4/tcp_input.c:5215 [inline] tcp_rcv_established+0x9bd/0x1e90 net/ipv4/tcp_input.c:5707 tcp_v4_do_rcv+0x610/0x8c0 net/ipv4/tcp_ipv4.c:1559 tcp_v4_rcv+0x2d80/0x3800 net/ipv4/tcp_ipv4.c:1940 ip_protocol_deliver_rcu+0x5a/0x880 net/ipv4/ip_input.c:204 ip_local_deliver_finish+0x23b/0x390 net/ipv4/ip_input.c:231 NF_HOOK include/linux/netfilter.h:305 [inline] NF_HOOK include/linux/netfilter.h:299 [inline] ip_local_deliver+0x1e9/0x520 net/ipv4/ip_input.c:252 dst_input include/net/dst.h:442 [inline] ip_rcv_finish+0x1d9/0x2f0 net/ipv4/ip_input.c:413 NF_HOOK include/linux/netfilter.h:305 [inline] NF_HOOK include/linux/netfilter.h:299 [inline] ip_rcv+0xe8/0x3f0 net/ipv4/ip_input.c:523 __netif_receive_skb_one_core+0x113/0x1a0 net/core/dev.c:5231 __netif_receive_skb+0x2c/0x1d0 net/core/dev.c:5345 process_backlog+0x206/0x750 net/core/dev.c:6176 napi_poll net/core/dev.c:6613 [inline] net_rx_action+0x508/0x1120 net/core/dev.c:6681 __do_softirq+0x262/0x98c kernel/softirq.c:292 Freed by task 17817: save_stack+0x23/0x90 mm/kasan/common.c:69 set_track mm/kasan/common.c:77 [inline] kasan_set_free_info mm/kasan/common.c:332 [inline] __kasan_slab_free+0x102/0x150 mm/kasan/common.c:471 kasan_slab_free+0xe/0x10 mm/kasan/common.c:480 __cache_free mm/slab.c:3425 [inline] kfree+0x10a/0x2c0 mm/slab.c:3756 skb_free_head+0x93/0xb0 net/core/skbuff.c:591 skb_release_data+0x42d/0x7c0 net/core/skbuff.c:611 skb_release_all+0x4d/0x60 net/core/skbuff.c:665 __kfree_skb+0x16/0x30 net/core/skbuff.c:679 sk_wmem_free_skb include/net/sock.h:1478 [inline] tcp_rtx_queue_unlink_and_free include/net/tcp.h:1801 [inline] tcp_clean_rtx_queue net/ipv4/tcp_input.c:3161 [inline] tcp_ack+0x1c20/0x58a0 net/ipv4/tcp_input.c:3688 tcp_rcv_established+0x6dd/0x1e90 net/ipv4/tcp_input.c:5696 tcp_v4_do_rcv+0x610/0x8c0 net/ipv4/tcp_ipv4.c:1559 tcp_v4_rcv+0x2d80/0x3800 net/ipv4/tcp_ipv4.c:1940 ip_protocol_deliver_rcu+0x5a/0x880 net/ipv4/ip_input.c:204 ip_local_deliver_finish+0x23b/0x390 net/ipv4/ip_input.c:231 NF_HOOK include/linux/netfilter.h:305 [inline] NF_HOOK include/linux/netfilter.h:299 [inline] ip_local_deliver+0x1e9/0x520 net/ipv4/ip_input.c:252 dst_input include/net/dst.h:442 [inline] ip_rcv_finish+0x1d9/0x2f0 net/ipv4/ip_input.c:413 NF_HOOK include/linux/netfilter.h:305 [inline] NF_HOOK include/linux/netfilter.h:299 [inline] ip_rcv+0xe8/0x3f0 net/ipv4/ip_input.c:523 __netif_receive_skb_one_core+0x113/0x1a0 net/core/dev.c:5231 __netif_receive_skb+0x2c/0x1d0 net/core/dev.c:5345 process_backlog+0x206/0x750 net/core/dev.c:6176 napi_poll net/core/dev.c:6613 [inline] net_rx_action+0x508/0x1120 net/core/dev.c:6681 __do_softirq+0x262/0x98c kernel/softirq.c:292 The buggy address belongs to the object at ffff88809f15a040 which belongs to the cache kmalloc-1k of size 1024 The buggy address is located 24 bytes inside of 1024-byte region [ffff88809f15a040, ffff88809f15a440) The buggy address belongs to the page: page:ffffea00027c5680 refcount:1 mapcount:0 mapping:ffff8880aa400c40 index:0xffff88809f15bb40 compound_mapcount: 0 flags: 0x1fffc0000010200(slab|head) raw: 01fffc0000010200 ffffea00022e2f88 ffffea00025cff88 ffff8880aa400c40 raw: ffff88809f15bb40 ffff88809f15a040 0000000100000006 0000000000000000 page dumped because: kasan: bad access detected Memory state around the buggy address: ffff88809f159f00: fc fc fc fc fc fc fc fc fc fc fc fc fc fc fc fc ffff88809f159f80: fc fc fc fc fc fc fc fc fc fc fc fc fc fc fc fc >ffff88809f15a000: fc fc fc fc fc fc fc fc fb fb fb fb fb fb fb fb ^ ffff88809f15a080: fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb ffff88809f15a100: fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb fb ==================================================================