Page MenuHomeFreeBSD

PCI hot-plug: use dedicated taskqueue for device attach / detach
ClosedPublic

Authored by avg on May 6 2021, 5:55 AM.
Tags
None
Referenced Files
Unknown Object (File)
Thu, Dec 26, 11:48 AM
Unknown Object (File)
Nov 25 2024, 3:10 PM
Unknown Object (File)
Nov 12 2024, 8:14 AM
Unknown Object (File)
Nov 12 2024, 7:22 AM
Unknown Object (File)
Nov 7 2024, 4:56 PM
Unknown Object (File)
Oct 18 2024, 5:35 PM
Unknown Object (File)
Sep 27 2024, 7:22 AM
Unknown Object (File)
Sep 24 2024, 7:22 PM
Subscribers

Details

Summary

Attaching and detaching devices can be heavy-weight and detaching can
sleep waiting for events. For that reason using the system-wide
single-threaded taskqueue_thread is not really appropriate.
There is even a possibility for a deadlock if taskqueue_thread is used
for detaching.

In fact, there is an easy to reproduce deadlock involving nvme, pass
and a sudden removal of an NVMe device.
A pass peripheral would not release a reference on an nvme sim until
pass_shutdown_kqueue() is executed via taskqueue_thread. But the
taskqueue's thread is blocked in nvme_detach() -> ... -> cam_sim_free()
because of the outstanding reference.

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 39051
Build 35940: arc lint + arc unit