Commit 9f2a3933 authored by Michal Pecio's avatar Michal Pecio Committed by Greg Kroah-Hartman

USB: document some API requirements on disconnection

A call to usb_set_interface() crashes if the device is deallocated
concurrently, such as due to physical removal or a serious IO error.
It could also interfere with other drivers using the device if the
current driver is unbound before the call is finished.

Document the need to delay driver unbinding until this call returns,
which solves both issues.

Document the same regarding usb_clear_halt(), which is equally known
to be routinely called by drivers.

Explicitly mention finishing pending operations in the documentation
of the driver disconnect callback.
Signed-off-by: default avatarMichal Pecio <michal.pecio@gmail.com>
Link: https://lore.kernel.org/r/20240218092515.7635ff8c@foxbookSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent be95cc6d
...@@ -99,8 +99,10 @@ The disconnect() callback ...@@ -99,8 +99,10 @@ The disconnect() callback
This callback is a signal to break any connection with an interface. This callback is a signal to break any connection with an interface.
You are not allowed any IO to a device after returning from this You are not allowed any IO to a device after returning from this
callback. You also may not do any other operation that may interfere callback. You also may not do any other operation that may interfere
with another driver bound the interface, eg. a power management with another driver bound to the interface, eg. a power management
operation. operation. Outstanding operations on the device must be completed or
aborted before this callback may return.
If you are called due to a physical disconnection, all your URBs will be If you are called due to a physical disconnection, all your URBs will be
killed by usbcore. Note that in this case disconnect will be called some killed by usbcore. Note that in this case disconnect will be called some
time after the physical disconnection. Thus your driver must be prepared time after the physical disconnection. Thus your driver must be prepared
......
...@@ -1198,6 +1198,8 @@ EXPORT_SYMBOL_GPL(usb_get_status); ...@@ -1198,6 +1198,8 @@ EXPORT_SYMBOL_GPL(usb_get_status);
* same status code used to report a true stall. * same status code used to report a true stall.
* *
* This call is synchronous, and may not be used in an interrupt context. * This call is synchronous, and may not be used in an interrupt context.
* If a thread in your driver uses this call, make sure your disconnect()
* method can wait for it to complete.
* *
* Return: Zero on success, or else the status code returned by the * Return: Zero on success, or else the status code returned by the
* underlying usb_control_msg() call. * underlying usb_control_msg() call.
...@@ -1516,7 +1518,8 @@ void usb_enable_interface(struct usb_device *dev, ...@@ -1516,7 +1518,8 @@ void usb_enable_interface(struct usb_device *dev,
* This call is synchronous, and may not be used in an interrupt context. * This call is synchronous, and may not be used in an interrupt context.
* Also, drivers must not change altsettings while urbs are scheduled for * Also, drivers must not change altsettings while urbs are scheduled for
* endpoints in that interface; all such urbs must first be completed * endpoints in that interface; all such urbs must first be completed
* (perhaps forced by unlinking). * (perhaps forced by unlinking). If a thread in your driver uses this call,
* make sure your disconnect() method can wait for it to complete.
* *
* Return: Zero on success, or else the status code returned by the * Return: Zero on success, or else the status code returned by the
* underlying usb_control_msg() call. * underlying usb_control_msg() call.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment