[<prev] [next>] [day] [month] [year] [list]
Message-Id: <DCGHG5UJT9G3.2K1GHFZ3H87T0@gmail.com>
Date: Sun, 31 Aug 2025 10:50:35 +0200
From: Hubert Wiśniewski <hubert.wisniewski.25632@...il.com>
To: "Andrew Lunn" <andrew+netdev@...n.ch>, "David S. Miller"
<davem@...emloft.net>, "Eric Dumazet" <edumazet@...gle.com>, "Jakub
Kicinski" <kuba@...nel.org>, "Paolo Abeni" <pabeni@...hat.com>, "Oleksij
Rempel" <linux@...pel-privat.de>
Cc: <linux-usb@...r.kernel.org>, <netdev@...r.kernel.org>,
<regressions@...ts.linux.dev>, <linux-kernel@...r.kernel.org>
Subject: [REGRESSION] net: usb: asix: deadlock on interface setup
Trying to bring an AX88772B-based USB-Ethernet adapter up results in a
deadlock if the adapter was suspended at the time. Most network-related
software hangs up indefinitely as a result. This can happen on systems
which configure USB power control to 'auto' by default, e.g. laptops
running `tlp`.
Steps to reproduce:
Try to bring the interface up while the adapter is suspended. For
example, assuming that the device is on bus 1, port 1:
root@...-eth-test:/sys/bus/usb/devices/1-1/power# echo auto > control
root@...-eth-test:/sys/bus/usb/devices/1-1/power# cat runtime_status
suspended
root@...-eth-test:/sys/bus/usb/devices/1-1/power# ip link set enp0s1u1 up
Expectations vs reality:
The interface should be brought up and be able to operate, but instead
the `ip` command hangs up and never returns, and lockdep emits the
following warning (decoded here):
============================================
WARNING: possible recursive locking detected
6.17.0-rc3 #1 Not tainted
--------------------------------------------
ip/273 is trying to acquire lock:
ffffffffb906e748 (rtnl_mutex){+.+.}-{4:4}, at: ax88772_resume (drivers/net/usb/asix_devices.c:650)
but task is already holding lock:
ffffffffb906e748 (rtnl_mutex){+.+.}-{4:4}, at: rtnl_newlink (net/core/rtnetlink.c:3893 net/core/rtnetlink.c:4057)
other info that might help us debug this:
Possible unsafe locking scenario:
CPU0
----
lock(rtnl_mutex);
lock(rtnl_mutex);
*** DEADLOCK ***
May be due to missing lock nesting notation
1 lock held by ip/273:
#0: ffffffffb906e748 (rtnl_mutex){+.+.}-{4:4}, at: rtnl_newlink (net/core/rtnetlink.c:3893 net/core/rtnetlink.c:4057)
stack backtrace:
CPU: 0 UID: 0 PID: 273 Comm: ip Not tainted 6.17.0-rc3 #1 PREEMPT(voluntary)
Hardware name: QEMU Standard PC (Q35 + ICH9, 2009), BIOS 1.16.3-debian-1.16.3-2 04/01/2014
Call Trace:
<TASK>
dump_stack_lvl (lib/dump_stack.c:122)
print_deadlock_bug.cold (kernel/locking/lockdep.c:3044)
__lock_acquire (kernel/locking/lockdep.c:3897 kernel/locking/lockdep.c:5237)
? usb_start_wait_urb (drivers/usb/core/message.c:83)
lock_acquire (kernel/locking/lockdep.c:470 (discriminator 4) kernel/locking/lockdep.c:5870 (discriminator 4) kernel/locking/lockdep.c:5825 (discriminator 4))
? ax88772_resume (drivers/net/usb/asix_devices.c:650)
__mutex_lock (arch/x86/include/asm/jump_label.h:36 include/trace/events/lock.h:95 kernel/locking/mutex.c:600 kernel/locking/mutex.c:760)
? ax88772_resume (drivers/net/usb/asix_devices.c:650)
? ax88772_resume (drivers/net/usb/asix_devices.c:650)
? __usbnet_read_cmd (drivers/net/usb/usbnet.c:2065)
? ax88772_resume (drivers/net/usb/asix_devices.c:650)
? srso_alias_return_thunk (arch/x86/lib/retpoline.S:183)
ax88772_resume (drivers/net/usb/asix_devices.c:650)
asix_resume (drivers/net/usb/asix_devices.c:663)
usb_resume_interface.isra.0 (drivers/usb/core/driver.c:1375)
usb_resume_both (drivers/usb/core/driver.c:1532 (discriminator 1))
? __pfx_usb_runtime_resume (drivers/usb/core/driver.c:1981)
__rpm_callback (drivers/base/power/runtime.c:406)
? srso_alias_return_thunk (arch/x86/lib/retpoline.S:183)
? srso_alias_return_thunk (arch/x86/lib/retpoline.S:183)
rpm_callback (include/linux/sched/mm.h:339 (discriminator 1) include/linux/sched/mm.h:369 (discriminator 1) drivers/base/power/runtime.c:458 (discriminator 1))
? __pfx_usb_runtime_resume (drivers/usb/core/driver.c:1981)
rpm_resume (drivers/base/power/runtime.c:934)
? srso_alias_return_thunk (arch/x86/lib/retpoline.S:183)
? lock_release (kernel/locking/lockdep.c:5536 kernel/locking/lockdep.c:5889 kernel/locking/lockdep.c:5875)
rpm_resume (drivers/base/power/runtime.c:913)
__pm_runtime_resume (include/linux/spinlock.h:406 drivers/base/power/runtime.c:1193)
usb_autopm_get_interface (include/linux/pm_runtime.h:532 drivers/usb/core/driver.c:1828)
usbnet_open (drivers/net/usb/usbnet.c:899)
__dev_open (net/core/dev.c:1684)
__dev_change_flags (net/core/dev.c:9549)
netif_change_flags (net/core/dev.c:9612)
do_setlink.isra.0 (net/core/rtnetlink.c:3143 (discriminator 1))
? lock_release (kernel/locking/lockdep.c:5536 kernel/locking/lockdep.c:5889 kernel/locking/lockdep.c:5875)
? rtnl_newlink (net/core/rtnetlink.c:3893 net/core/rtnetlink.c:4057)
? srso_alias_return_thunk (arch/x86/lib/retpoline.S:183)
? __mutex_lock (include/trace/events/lock.h:122 (discriminator 2) kernel/locking/mutex.c:607 (discriminator 2) kernel/locking/mutex.c:760 (discriminator 2))
? srso_alias_return_thunk (arch/x86/lib/retpoline.S:183)
? rtnl_newlink (net/core/rtnetlink.c:3893 net/core/rtnetlink.c:4057)
? lock_release (kernel/locking/lockdep.c:5536 kernel/locking/lockdep.c:5889 kernel/locking/lockdep.c:5875)
rtnl_newlink (net/core/rtnetlink.c:3761 (discriminator 1) net/core/rtnetlink.c:3920 (discriminator 1) net/core/rtnetlink.c:4057 (discriminator 1))
? lock_acquire (kernel/locking/lockdep.c:470 (discriminator 4) kernel/locking/lockdep.c:5870 (discriminator 4) kernel/locking/lockdep.c:5825 (discriminator 4))
? srso_alias_return_thunk (arch/x86/lib/retpoline.S:183)
? find_held_lock (kernel/locking/lockdep.c:5350 (discriminator 1))
? rtnetlink_rcv_msg (include/linux/rcupdate.h:341 (discriminator 1) include/linux/rcupdate.h:871 (discriminator 1) net/core/rtnetlink.c:6944 (discriminator 1))
? __pfx_rtnl_newlink (net/core/rtnetlink.c:3948)
? srso_alias_return_thunk (arch/x86/lib/retpoline.S:183)
? rtnetlink_rcv_msg (net/core/rtnetlink.c:6945)
? srso_alias_return_thunk (arch/x86/lib/retpoline.S:183)
? __pfx_rtnetlink_rcv_msg (net/core/rtnetlink.c:6849)
netlink_rcv_skb (net/netlink/af_netlink.c:2552)
netlink_unicast (net/netlink/af_netlink.c:1321 net/netlink/af_netlink.c:1346)
netlink_sendmsg (net/netlink/af_netlink.c:1896)
____sys_sendmsg (net/socket.c:714 (discriminator 1) net/socket.c:729 (discriminator 1) net/socket.c:2614 (discriminator 1))
___sys_sendmsg (net/socket.c:2670)
? lock_release (kernel/locking/lockdep.c:5536 kernel/locking/lockdep.c:5889 kernel/locking/lockdep.c:5875)
__sys_sendmsg (net/socket.c:2700 (discriminator 1))
? srso_alias_return_thunk (arch/x86/lib/retpoline.S:183)
do_syscall_64 (arch/x86/entry/syscall_64.c:63 (discriminator 1) arch/x86/entry/syscall_64.c:94 (discriminator 1))
entry_SYSCALL_64_after_hwframe (arch/x86/entry/entry_64.S:130)
RIP: 0033:0x7fddcbcb2687
Code: 48 89 fa 4c 89 df e8 58 b3 00 00 8b 93 08 03 00 00 59 5e 48 83 f8 fc 74 1a 5b c3 0f 1f 84 00 00 00 00 00 48 8b 44 24 10 0f 05 <5b> c3 0f 1f 80 00 00 00 00 83 e2 39 83 fa 08 75 de e8 23 ff ff ff
All code
========
0: 48 89 fa mov %rdi,%rdx
3: 4c 89 df mov %r11,%rdi
6: e8 58 b3 00 00 call 0xb363
b: 8b 93 08 03 00 00 mov 0x308(%rbx),%edx
11: 59 pop %rcx
12: 5e pop %rsi
13: 48 83 f8 fc cmp $0xfffffffffffffffc,%rax
17: 74 1a je 0x33
19: 5b pop %rbx
1a: c3 ret
1b: 0f 1f 84 00 00 00 00 nopl 0x0(%rax,%rax,1)
22: 00
23: 48 8b 44 24 10 mov 0x10(%rsp),%rax
28: 0f 05 syscall
2a:* 5b pop %rbx <-- trapping instruction
2b: c3 ret
2c: 0f 1f 80 00 00 00 00 nopl 0x0(%rax)
33: 83 e2 39 and $0x39,%edx
36: 83 fa 08 cmp $0x8,%edx
39: 75 de jne 0x19
3b: e8 23 ff ff ff call 0xffffffffffffff63
Code starting with the faulting instruction
===========================================
0: 5b pop %rbx
1: c3 ret
2: 0f 1f 80 00 00 00 00 nopl 0x0(%rax)
9: 83 e2 39 and $0x39,%edx
c: 83 fa 08 cmp $0x8,%edx
f: 75 de jne 0xffffffffffffffef
11: e8 23 ff ff ff call 0xffffffffffffff39
RSP: 002b:00007fffad1c7b60 EFLAGS: 00000202 ORIG_RAX: 000000000000002e
RAX: ffffffffffffffda RBX: 00007fddcba85840 RCX: 00007fddcbcb2687
RDX: 0000000000000000 RSI: 00007fffad1c7c10 RDI: 0000000000000003
RBP: 00007fffad1c7c10 R08: 0000000000000000 R09: 0000000000000000
R10: 0000000000000000 R11: 0000000000000202 R12: 00007fffad1c8300
R13: 0000000000000000 R14: 0000555b0fa13020 R15: 0000000000000000
</TASK>
Details:
I have used QEMU with USB passthrough to catch the issue, but this
happens on real hardware as well.
The bug has already been reported on bugzilla
(https://bugzilla.kernel.org/show_bug.cgi?id=215199), but this was
probably not the right place.
USB device: Edimax USB 2.0 Fast Ethernet Adapter, model no. EU-4208
USB device IDs: 0b95:772b ASIX Electronics Corp. AX88772B
Kernel version (/proc/version):
Linux version 6.17.0-rc3 (hubert25632@...0M-AE) (gcc (Debian 14.2.0-19)
14.2.0, GNU ld (GNU Binutils for Debian) 2.44) #1 SMP PREEMPT_DYNAMIC
Sat Aug 30 21:43:30 CEST 2025
iproute2 version: ip utility, iproute2-6.16.0, libbpf 1.6.2
OS: Debian GNU/Linux forky/sid
CPU architecture: x86_64
Kernel config: https://pastebin.com/MiBZnCgC
dmesg log: https://pastebin.com/JXiZTiAT
Last good kernel version: v5.13
First bad commit: 4a2c7217cd5a ("net: usb: asix: ax88772: manage PHY PM from MAC")
Possible workaroud:
Users of `tlp` can add the following statement to `/etc/tlp.conf` to
prevent the adapter from being suspended automatically:
USB_DENYLIST="0b95:772b"
#regzbot introduced: 4a2c7217cd5a
Powered by blists - more mailing lists