[PATCH v1 2/2] USB: set hub's default autosuspend delay as 0

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



This patch sets hub device's default autosuspend delay as 0 to
speedup bus suspend, see comments in code for details.

Signed-off-by: Ming Lei <ming.lei@xxxxxxxxxxxxx>
---
 drivers/usb/core/hub.c |   38 ++++++++++++++++++++++++++++++++++++++
 1 file changed, 38 insertions(+)

diff --git a/drivers/usb/core/hub.c b/drivers/usb/core/hub.c
index 97d6036..9bde1f5 100644
--- a/drivers/usb/core/hub.c
+++ b/drivers/usb/core/hub.c
@@ -1629,6 +1629,44 @@ static int hub_probe(struct usb_interface *intf, const struct usb_device_id *id)
 	desc = intf->cur_altsetting;
 	hdev = interface_to_usbdev(intf);
 
+	/*
+	 * Set default autosuspend delay as 0 to speedup bus suspend.
+	 * Based on the below considerations:
+	 *
+	 * - The remote wakeup from child device and new connected
+	 *   device doesn't mean that there might be another new device
+	 *   which is going to be connected or disconnected to the hub,
+	 *   or there might be another wakeup from other devices, in
+	 *   the following seconds.
+	 *
+	 * - If the hub device is accessed from user space context
+	 *   (sysfs or libusb), it will be woke up first, so utilities
+	 *   like 'lsusb' will work fine.
+	 *
+	 * - The wakeup event can be handled completely in hub_resume()
+	 *   and khubd, and the submitted status URB is just to check
+	 *   future changes on hub downstream ports.
+	 *
+	 * - the introduced hub resume delay during the autosuspend
+	 *   delay period doesn't matter for new device to be connected
+	 *   into the hub.
+	 *
+	 * - the child device should depend its own autosuspend delay
+	 *   to fit its use case and shoudn't depend on the delay of
+	 *   parent hub device.
+	 *
+	 * - suppose there is one device which will remote wakeup
+	 *   every 2 seconds periodically and does't care the resume
+	 *   delay, the bus can't be suspended with previous default
+	 *   autosuspend delay at all, not mention in case of several
+	 *   hubs connected in the path from the device to root hub.
+	 *
+	 * - it is safe to do so because the hub can't be auto-suspended
+	 *   until the remote wakeup is handled by khubd in the device
+	 *   remote wakeup path.
+	 */
+	pm_runtime_set_autosuspend_delay(&hdev->dev, 0);
+
 	/* Hubs have proper suspend/resume support. */
 	usb_enable_autosuspend(hdev);
 
-- 
1.7.9.5

--
To unsubscribe from this list: send the line "unsubscribe linux-usb" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Linux Media]     [Linux Input]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]     [Old Linux USB Devel Archive]

  Powered by Linux