lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Date:   Mon, 22 Aug 2016 11:04:56 +0200
From:   Oliver Neukum <oneukum@...e.com>
To:     Alan Stern <stern@...land.harvard.edu>
Cc:     ludeng <ludeng@...ilicon.com>, Lipengcheng <lpc.li@...ilicon.com>,
        "Device ChipSet) Zhangzhenxing (Christian" 
        <zhangzhenxing@...ilicon.com>,
        "gregkh@...uxfoundation.org" <gregkh@...uxfoundation.org>,
        "linux-kernel@...r.kernel.org" <linux-kernel@...r.kernel.org>,
        "linux-usb@...r.kernel.org" <linux-usb@...r.kernel.org>
Subject: Re: How the EHCI HC driver make the decision to suspend some USB
 devices?

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





Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ