bisecting cause commit starting from 629f8205a6cc63d2e8e30956bad958a3507d018f building syzkaller on 7c7ded697e6322b0975f061b7e268fe44f585dab testing commit 629f8205a6cc63d2e8e30956bad958a3507d018f with gcc (GCC) 8.1.0 run #0: crashed: WARNING: refcount bug in nr_insert_socket run #1: crashed: WARNING: refcount bug in nr_insert_socket run #2: crashed: WARNING: refcount bug in nr_insert_socket run #3: crashed: WARNING: refcount bug in nr_insert_socket run #4: crashed: KASAN: use-after-free Read in nr_release run #5: crashed: KASAN: use-after-free Read in nr_release run #6: OK run #7: OK run #8: crashed: KASAN: use-after-free Read in nr_insert_socket run #9: OK testing release v5.2 testing commit 0ecfebd2b52404ae0c54a878c872bb93363ada36 with gcc (GCC) 8.1.0 all runs: OK # git bisect start 629f8205a6cc63d2e8e30956bad958a3507d018f v5.2 Bisecting: 6901 revisions left to test after this (roughly 13 steps) [17a20acaf171124017f43bc70bb4d7ca88070659] Merge tag 'usb-5.3-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/usb testing commit 17a20acaf171124017f43bc70bb4d7ca88070659 with gcc (GCC) 8.1.0 run #0: crashed: WARNING: refcount bug in nr_insert_socket run #1: crashed: WARNING: refcount bug in nr_insert_socket run #2: OK run #3: OK run #4: crashed: WARNING: refcount bug in nr_insert_socket run #5: crashed: WARNING: refcount bug in nr_insert_socket run #6: OK run #7: OK run #8: OK run #9: OK # git bisect bad 17a20acaf171124017f43bc70bb4d7ca88070659 Bisecting: 3621 revisions left to test after this (roughly 12 steps) [8f6ccf6159aed1f04c6d179f61f6fb2691261e84] Merge tag 'clone3-v5.3' of git://git.kernel.org/pub/scm/linux/kernel/git/brauner/linux testing commit 8f6ccf6159aed1f04c6d179f61f6fb2691261e84 with gcc (GCC) 8.1.0 all runs: OK # git bisect good 8f6ccf6159aed1f04c6d179f61f6fb2691261e84 Bisecting: 1810 revisions left to test after this (roughly 11 steps) [28261da8a26f4915aa257d12d506c6ba179d961f] Bluetooth: Check state in l2cap_disconnect_rsp testing commit 28261da8a26f4915aa257d12d506c6ba179d961f with gcc (GCC) 8.1.0 all runs: OK # git bisect good 28261da8a26f4915aa257d12d506c6ba179d961f Bisecting: 838 revisions left to test after this (roughly 10 steps) [97ff4ca46d3279134cec49752de8c5a62dc68460] Merge tag 'char-misc-5.3-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/char-misc testing commit 97ff4ca46d3279134cec49752de8c5a62dc68460 with gcc (GCC) 8.1.0 run #0: crashed: WARNING: refcount bug in nr_insert_socket run #1: crashed: WARNING: refcount bug in nr_insert_socket run #2: crashed: WARNING: refcount bug in nr_insert_socket run #3: crashed: WARNING: refcount bug in nr_insert_socket run #4: crashed: WARNING: refcount bug in nr_insert_socket run #5: crashed: KASAN: use-after-free Read in nr_insert_socket run #6: crashed: KASAN: use-after-free Read in nr_insert_socket run #7: crashed: general protection fault in send_hsr_supervision_frame run #8: OK run #9: OK # git bisect bad 97ff4ca46d3279134cec49752de8c5a62dc68460 Bisecting: 485 revisions left to test after this (roughly 9 steps) [a131c2bf165684315f606fdd88cf80be22ba32f3] Merge tag 'acpi-5.3-rc1-2' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm testing commit a131c2bf165684315f606fdd88cf80be22ba32f3 with gcc (GCC) 8.1.0 run #0: crashed: WARNING: refcount bug in nr_insert_socket run #1: crashed: WARNING: refcount bug in nr_insert_socket run #2: crashed: KASAN: use-after-free Read in nr_release run #3: crashed: KASAN: use-after-free Read in nr_release run #4: crashed: general protection fault in send_hsr_supervision_frame run #5: crashed: general protection fault in send_hsr_supervision_frame run #6: crashed: general protection fault in send_hsr_supervision_frame run #7: OK run #8: OK run #9: OK # git bisect bad a131c2bf165684315f606fdd88cf80be22ba32f3 Bisecting: 249 revisions left to test after this (roughly 8 steps) [7650b1a9bd693d133a3ec0548ba63e828f34e3ec] Merge branch 'mp-inner-L3' testing commit 7650b1a9bd693d133a3ec0548ba63e828f34e3ec with gcc (GCC) 8.1.0 all runs: OK # git bisect good 7650b1a9bd693d133a3ec0548ba63e828f34e3ec Bisecting: 129 revisions left to test after this (roughly 7 steps) [e858faf556d4e14c750ba1e8852783c6f9520a0e] tcp: Reset bytes_acked and bytes_received when disconnecting testing commit e858faf556d4e14c750ba1e8852783c6f9520a0e with gcc (GCC) 8.1.0 run #0: crashed: WARNING: refcount bug in nr_insert_socket run #1: crashed: WARNING: refcount bug in nr_insert_socket run #2: crashed: WARNING: refcount bug in nr_insert_socket run #3: crashed: WARNING: refcount bug in nr_insert_socket run #4: crashed: KASAN: use-after-free Read in nr_release run #5: crashed: WARNING: refcount bug in nr_insert_socket run #6: crashed: WARNING: refcount bug in nr_insert_socket run #7: crashed: WARNING: refcount bug in nr_insert_socket run #8: OK run #9: OK # git bisect bad e858faf556d4e14c750ba1e8852783c6f9520a0e Bisecting: 59 revisions left to test after this (roughly 6 steps) [3d26eb8ad1e9b906433903ce05f775cf038e747f] net: bridge: don't cache ether dest pointer on input testing commit 3d26eb8ad1e9b906433903ce05f775cf038e747f with gcc (GCC) 8.1.0 run #0: crashed: WARNING: refcount bug in nr_insert_socket run #1: crashed: WARNING: refcount bug in nr_insert_socket run #2: crashed: WARNING: refcount bug in nr_insert_socket run #3: crashed: WARNING: refcount bug in nr_insert_socket run #4: crashed: WARNING: refcount bug in nr_insert_socket run #5: crashed: WARNING: refcount bug in nr_insert_socket run #6: crashed: WARNING: refcount bug in nr_insert_socket run #7: crashed: WARNING: refcount bug in nr_insert_socket run #8: crashed: WARNING: refcount bug in nr_insert_socket run #9: OK # git bisect bad 3d26eb8ad1e9b906433903ce05f775cf038e747f Bisecting: 29 revisions left to test after this (roughly 5 steps) [e5b1c6c6277d5a283290a8c033c72544746f9b5b] igmp: fix memory leak in igmpv3_del_delrec() testing commit e5b1c6c6277d5a283290a8c033c72544746f9b5b with gcc (GCC) 8.1.0 all runs: OK # git bisect good e5b1c6c6277d5a283290a8c033c72544746f9b5b Bisecting: 14 revisions left to test after this (roughly 4 steps) [4d1415811e492d9a8238f8a92dd0d51612c788e9] sctp: fix error handling on stream scheduler initialization testing commit 4d1415811e492d9a8238f8a92dd0d51612c788e9 with gcc (GCC) 8.1.0 run #0: crashed: WARNING: refcount bug in nr_insert_socket run #1: crashed: WARNING: refcount bug in nr_insert_socket run #2: crashed: KASAN: use-after-free Read in nr_release run #3: crashed: WARNING: refcount bug in nr_insert_socket run #4: crashed: WARNING: refcount bug in nr_insert_socket run #5: crashed: WARNING: refcount bug in nr_insert_socket run #6: crashed: WARNING: refcount bug in nr_insert_socket run #7: crashed: WARNING: refcount bug in nr_insert_socket run #8: crashed: WARNING: refcount bug in nr_insert_socket run #9: OK # git bisect bad 4d1415811e492d9a8238f8a92dd0d51612c788e9 Bisecting: 6 revisions left to test after this (roughly 3 steps) [22506f488e6b7adf14b008ed241c69e3918886e6] Merge branch 'bnxt_en-Bug-fixes' testing commit 22506f488e6b7adf14b008ed241c69e3918886e6 with gcc (GCC) 8.1.0 all runs: OK # git bisect good 22506f488e6b7adf14b008ed241c69e3918886e6 Bisecting: 3 revisions left to test after this (roughly 2 steps) [40f6a2cb9cfc5da713f745b23bcc2c6761e5eb5e] net: dst.h: Fix shifting signed 32-bit value by 31 bits problem testing commit 40f6a2cb9cfc5da713f745b23bcc2c6761e5eb5e with gcc (GCC) 8.1.0 all runs: OK # git bisect good 40f6a2cb9cfc5da713f745b23bcc2c6761e5eb5e Bisecting: 1 revision left to test after this (roughly 1 step) [2e60546368165c2449564d71f6005dda9205b5fb] ipv4: don't set IPv6 only flags to IPv4 addresses testing commit 2e60546368165c2449564d71f6005dda9205b5fb with gcc (GCC) 8.1.0 run #0: basic kernel testing failed: failed to copy test binary to VM: failed to run ["scp" "-P" "22" "-F" "/dev/null" "-o" "UserKnownHostsFile=/dev/null" "-o" "BatchMode=yes" "-o" "IdentitiesOnly=yes" "-o" "StrictHostKeyChecking=no" "-o" "ConnectTimeout=10" "-i" "/syzkaller/jobs/linux/workdir/image/key" "/tmp/syz-executor023526472" "root@10.128.10.24:./syz-executor023526472"]: exit status 1 ssh: connect to host 10.128.10.24 port 22: Connection timed out lost connection run #1: OK run #2: OK run #3: OK run #4: OK run #5: OK run #6: OK run #7: OK run #8: OK run #9: OK # git bisect good 2e60546368165c2449564d71f6005dda9205b5fb Bisecting: 0 revisions left to test after this (roughly 0 steps) [c8c8218ec5af5d2598381883acbefbf604e56b5e] netrom: fix a memory leak in nr_rx_frame() testing commit c8c8218ec5af5d2598381883acbefbf604e56b5e with gcc (GCC) 8.1.0 run #0: crashed: KASAN: use-after-free Read in nr_release run #1: crashed: WARNING: refcount bug in nr_insert_socket run #2: crashed: WARNING: refcount bug in nr_insert_socket run #3: crashed: WARNING: refcount bug in nr_insert_socket run #4: crashed: WARNING: refcount bug in nr_insert_socket run #5: crashed: WARNING: refcount bug in nr_insert_socket run #6: crashed: WARNING: refcount bug in nr_insert_socket run #7: crashed: WARNING: refcount bug in nr_insert_socket run #8: crashed: WARNING: refcount bug in nr_insert_socket run #9: OK # git bisect bad c8c8218ec5af5d2598381883acbefbf604e56b5e c8c8218ec5af5d2598381883acbefbf604e56b5e is the first bad commit commit c8c8218ec5af5d2598381883acbefbf604e56b5e Author: Cong Wang Date: Thu Jun 27 14:30:58 2019 -0700 netrom: fix a memory leak in nr_rx_frame() When the skb is associated with a new sock, just assigning it to skb->sk is not sufficient, we have to set its destructor to free the sock properly too. Reported-by: syzbot+d6636a36d3c34bd88938@syzkaller.appspotmail.com Signed-off-by: Cong Wang Signed-off-by: David S. Miller :040000 040000 4c07dae2c063172c527c8acf843b916a275a70ce 1c43141d5e0b704990d869e2ed626126f1596f0b M net revisions tested: 16, total time: 4h41m51.161389866s (build: 1h33m55.560403506s, test: 3h2m53.791998496s) first bad commit: c8c8218ec5af5d2598381883acbefbf604e56b5e netrom: fix a memory leak in nr_rx_frame() cc: ["davem@davemloft.net" "linux-hams@vger.kernel.org" "linux-kernel@vger.kernel.org" "netdev@vger.kernel.org" "ralf@linux-mips.org" "xiyou.wangcong@gmail.com"] crash: WARNING: refcount bug in nr_insert_socket ------------[ cut here ]------------ refcount_t: increment on 0; use-after-free. WARNING: CPU: 0 PID: 0 at lib/refcount.c:156 refcount_inc_checked+0x2b/0x30 lib/refcount.c:156 Kernel panic - not syncing: panic_on_warn set ... CPU: 0 PID: 0 Comm: swapper/0 Not tainted 5.2.0-rc6+ #1 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+0x113/0x167 lib/dump_stack.c:113 panic+0x212/0x4cb kernel/panic.c:219 __warn.cold.8+0x1b/0x38 kernel/panic.c:576 report_bug+0x1a4/0x200 lib/bug.c:186 fixup_bug arch/x86/kernel/traps.c:179 [inline] do_error_trap+0x11b/0x200 arch/x86/kernel/traps.c:272 do_invalid_op+0x36/0x40 arch/x86/kernel/traps.c:291 invalid_op+0x14/0x20 arch/x86/entry/entry_64.S:986 RIP: 0010:refcount_inc_checked+0x2b/0x30 lib/refcount.c:156 Code: 48 89 e5 e8 97 fe ff ff 84 c0 74 02 5d c3 80 3d d3 82 f3 05 00 75 f5 48 c7 c7 00 52 41 87 c6 05 c3 82 f3 05 01 e8 a8 d2 3d fe <0f> 0b 5d c3 90 55 48 89 e5 41 56 41 55 49 89 fd 48 c7 c7 60 52 41 RSP: 0018:ffff8880aea09c10 EFLAGS: 00010286 RAX: 0000000000000000 RBX: ffff888089dca9c0 RCX: 0000000000000000 RDX: 0000000000000004 RSI: ffffffff8827a8e8 RDI: ffffffff89d63d40 RBP: ffff8880aea09c10 R08: 0000000000000002 R09: 0000000000000000 R10: 0000000000000000 R11: 0000000000000000 R12: ffff8880a9000c00 R13: ffff888089dcaa28 R14: 000000000000002f R15: ffff888089dcae5e sock_hold include/net/sock.h:649 [inline] sk_add_node include/net/sock.h:701 [inline] nr_insert_socket+0x28/0xd0 net/netrom/af_netrom.c:137 nr_rx_frame+0x160f/0x1f00 net/netrom/af_netrom.c:1023 nr_loopback_timer+0x64/0x120 net/netrom/nr_loopback.c:59 call_timer_fn+0x14d/0x510 kernel/time/timer.c:1322 expire_timers kernel/time/timer.c:1366 [inline] __run_timers kernel/time/timer.c:1685 [inline] run_timer_softirq+0xc6f/0x1330 kernel/time/timer.c:1698 __do_softirq+0x260/0x958 kernel/softirq.c:292 invoke_softirq kernel/softirq.c:373 [inline] irq_exit+0x17f/0x1c0 kernel/softirq.c:413 exiting_irq arch/x86/include/asm/apic.h:536 [inline] smp_apic_timer_interrupt+0x13e/0x540 arch/x86/kernel/apic/apic.c:1068 apic_timer_interrupt+0xf/0x20 arch/x86/entry/entry_64.S:806 RIP: 0010:native_safe_halt+0x12/0x20 arch/x86/include/asm/irqflags.h:61 Code: 11 ff ff ff 4c 89 e7 e8 6c 42 f4 fa eb 97 90 90 90 90 90 90 90 90 90 90 55 48 89 e5 e9 07 00 00 00 0f 00 2d f0 91 63 00 fb f4 <5d> c3 66 90 66 2e 0f 1f 84 00 00 00 00 00 55 48 89 e5 e9 07 00 00 RSP: 0018:ffffffff88207ce0 EFLAGS: 00000282 ORIG_RAX: ffffffffffffff13 RAX: dffffc0000000000 RBX: ffffffff8827a040 RCX: 0000000000000000 RDX: 1ffffffff10643e1 RSI: 0000000000000006 RDI: ffffffff88321f08 RBP: ffffffff88207ce0 R08: 0000000000000006 R09: 0000000000000000 R10: 0000000000000000 R11: 0000000000000000 R12: 0000000000000000 R13: ffffffff88321ef8 R14: 0000000000000000 R15: ffffffff88f69d78 arch_safe_halt arch/x86/include/asm/paravirt.h:156 [inline] default_idle+0x51/0x310 arch/x86/kernel/process.c:580 arch_cpu_idle+0xa/0x10 arch/x86/kernel/process.c:571 default_idle_call+0x6d/0x90 kernel/sched/idle.c:94 cpuidle_idle_call kernel/sched/idle.c:154 [inline] do_idle+0x3e4/0x590 kernel/sched/idle.c:263 cpu_startup_entry+0x18/0x20 kernel/sched/idle.c:354 rest_init+0x1a4/0x279 init/main.c:451 arch_call_rest_init+0x9/0xc start_kernel+0x6bd/0x6f8 init/main.c:761 x86_64_start_reservations+0x29/0x2b arch/x86/kernel/head64.c:470 x86_64_start_kernel+0x76/0x79 arch/x86/kernel/head64.c:451 secondary_startup_64+0xa4/0xb0 arch/x86/kernel/head_64.S:243 Kernel Offset: disabled Rebooting in 86400 seconds..