Re: How the EHCI HC driver make the decision to suspend some USB devices?

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

 



On Fri, 2016-08-19 at 10:16 -0400, Alan Stern wrote:
> On Fri, 19 Aug 2016, ludeng wrote:
> 
> > Hi,
> > How the EHCI HC driver make the decision to suspend some USB devices,
> > but not to suspend some others? We notice that for some USB Video
> > Cameras, when they are enumerated and there is no data to transfer,
> > the EHCI HC driver will suspend them by setting the Suspend bit of
> > the PORTSC register. But for some other Cameras, the EHCI HC driver
> > will not suspend them. The drvier make the decision based on what
> > kind of information of the device ?
> 
> The EHCI driver does not make this decision.  The decision is made by 
> the video camera driver and by the user.

And the driver core in case of devices with multiple interfaces.

But I guess, the question is also about how, not where the decision
is made.

Runtime suspend will be used if

1) every interface's driver has declared
	a) it supports autosuspend
	b) its interface is idle

2) every bus connected to an interface [SCSI] has only suspended
devices

3) the requirements for remote wakeup are met on every interface.
That means, either
	a) remote wakeup is not requested
	b) remote wakeup is requested and
		I) the device supports it
		II) the RESET_RESUME quirk is not set for the device

4) it is enabled in sysfs

	HTH
		Oliver





--
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