============================================
WARNING: possible recursive locking detected
6.16.0-syzkaller-06620-gae633388cae3 #0 Not tainted
--------------------------------------------
swapper/0/0 is trying to acquire lock:
ffff88810e990958 (&qdisc_xmit_lock_key#4){+.-.}-{3:3}, at: sch_direct_xmit+0x153/0x4b0

but task is already holding lock:
ffff88802069a558 (&qdisc_xmit_lock_key#4){+.-.}-{3:3}, at: sch_direct_xmit+0x153/0x4b0

other info that might help us debug this:
 Possible unsafe locking scenario:

       CPU0
       ----
  lock(&qdisc_xmit_lock_key#4);
  lock(&qdisc_xmit_lock_key#4);

 *** DEADLOCK ***

 May be due to missing lock nesting notation

13 locks held by swapper/0/0:
 #0: ffffc90000007be0 ((&ndev->rs_timer)){+.-.}-{0:0}, at: call_timer_fn+0xbe/0x5f0
 #1: ffffffff8e13c4e0 (rcu_read_lock){....}-{1:3}, at: ndisc_send_skb+0x20c/0x1440
 #2: ffffffff8e13c4e0 (rcu_read_lock){....}-{1:3}, at: ip6_finish_output2+0x701/0x16a0
 #3: ffffffff8e13c540 (rcu_read_lock_bh){....}-{1:3}, at: __dev_queue_xmit+0x27b/0x3b50
 #4: ffffffff8e13c4e0 (rcu_read_lock){....}-{1:3}, at: bond_start_xmit+0xf8/0x1a10
 #5: ffffffff8e13c540 (rcu_read_lock_bh){....}-{1:3}, at: __dev_queue_xmit+0x27b/0x3b50
 #6: ffff888039b70258 (dev->qdisc_tx_busylock ?: &qdisc_tx_busylock#3){+...}-{3:3}, at: __dev_queue_xmit+0x138a/0x3b50
 #7: ffff88802069a558 (&qdisc_xmit_lock_key#4){+.-.}-{3:3}, at: sch_direct_xmit+0x153/0x4b0
 #8: ffffffff8e13c4e0 (rcu_read_lock){....}-{1:3}, at: ip_output+0x60/0x3c0
 #9: ffffffff8e13c4e0 (rcu_read_lock){....}-{1:3}, at: ip_finish_output2+0x452/0x1160
 #10: ffffffff8e13c4e0 (rcu_read_lock){....}-{1:3}, at: arp_xmit+0x23/0x270
 #11: ffffffff8e13c540 (rcu_read_lock_bh){....}-{1:3}, at: __dev_queue_xmit+0x27b/0x3b50
 #12: ffff888121e17258 (dev->qdisc_tx_busylock ?: &qdisc_tx_busylock#3){+...}-{3:3}, at: __dev_queue_xmit+0x138a/0x3b50

stack backtrace:
CPU: 0 UID: 0 PID: 0 Comm: swapper/0 Not tainted 6.16.0-syzkaller-06620-gae633388cae3 #0 PREEMPT(full) 
Hardware name: QEMU Standard PC (Q35 + ICH9, 2009), BIOS 1.16.2-debian-1.16.2-1 04/01/2014
Call Trace:
 <IRQ>
 dump_stack_lvl+0x189/0x250
 print_deadlock_bug+0x28b/0x2a0
 validate_chain+0x1a3f/0x2140
 __lock_acquire+0xab9/0xd20
 lock_acquire+0x120/0x360
 _raw_spin_lock+0x2e/0x40
 sch_direct_xmit+0x153/0x4b0
 __dev_queue_xmit+0x1857/0x3b50
 NF_HOOK+0x310/0x3a0
 arp_xmit+0x16c/0x270
 arp_solicit+0xc1d/0xe60
 __neigh_event_send+0xf70/0x1560
 neigh_resolve_output+0x198/0x750
 ip_finish_output2+0xd40/0x1160
 ip_output+0x2a1/0x3c0
 iptunnel_xmit+0x592/0xa40
 ip_tunnel_xmit+0x1c41/0x2390
 gre_tap_xmit+0x590/0x7a0
 dev_hard_start_xmit+0x2d7/0x830
 sch_direct_xmit+0x241/0x4b0
 __dev_queue_xmit+0x1857/0x3b50
 bond_dev_queue_xmit+0x10b/0x1e0
 bond_start_xmit+0x779/0x1a10
 dev_hard_start_xmit+0x2d7/0x830
 __dev_queue_xmit+0x1b8d/0x3b50
 ip6_finish_output2+0x11bc/0x16a0
 ndisc_send_skb+0xb54/0x1440
 addrconf_rs_timer+0x369/0x670
 call_timer_fn+0x17e/0x5f0
 __run_timer_base+0x61a/0x860
 run_timer_softirq+0xb7/0x180
 handle_softirqs+0x286/0x870
 __irq_exit_rcu+0xca/0x1f0
 irq_exit_rcu+0x9/0x30
 sysvec_apic_timer_interrupt+0xa6/0xc0
 </IRQ>
 <TASK>
 asm_sysvec_apic_timer_interrupt+0x1a/0x20
RIP: 0010:pv_native_safe_halt+0x13/0x20
Code: 53 e8 02 00 cc cc cc 90 90 90 90 90 90 90 90 90 90 90 90 90 90 90 90 f3 0f 1e fa eb 07 0f 00 2d 13 6f 18 00 f3 0f 1e fa fb f4 <c3> cc cc cc cc cc cc cc cc cc cc cc cc 90 90 90 90 90 90 90 90 90
RSP: 0018:ffffffff8de07d80 EFLAGS: 00000282
RAX: 754713027de96500 RBX: ffffffff81969b18 RCX: 754713027de96500
RDX: 0000000000000001 RSI: ffffffff8d9792a2 RDI: ffffffff8be30a00
RBP: ffffffff8de07eb8 R08: ffff88804b032f5b R09: 1ffff110096065eb
R10: dffffc0000000000 R11: ffffed10096065ec R12: ffffffff8fa07bf0
R13: 0000000000000000 R14: 0000000000000000 R15: 1ffffffff1bd2a18
 default_idle+0x13/0x20
 default_idle_call+0x74/0xb0
 do_idle+0x1e8/0x510
 cpu_startup_entry+0x44/0x60
 rest_init+0x2de/0x300
 start_kernel+0x3a9/0x410
 x86_64_start_reservations+0x24/0x30
 x86_64_start_kernel+0x143/0x1c0
 common_startup_64+0x13e/0x147
 </TASK>
