Re: [PATCH v4 09/14] usb: synchronize port poweroff and khubd

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

 



On Thu, 6 Feb 2014, Alan Stern wrote:

> On Fri, 31 Jan 2014, Dan Williams wrote:
> 
> > If a port is powered-off, or in the process of being powered-off, prevent
> > khubd from operating on it.  Otherwise, the following sequence of events
> > leading to an unintended disconnect may occur:
> > 
> > Events:
> > (0) <set pm_qos_no_poweroff to '0' for port1>
> > (1) hub 2-2:1.0: hub_resume
> > (2) hub 2-2:1.0: port 1: status 0301 change 0000
> > (3) hub 2-2:1.0: state 7 ports 4 chg 0002 evt 0000
> > (4) hub 2-2:1.0: port 1, power off status 0000, change 0000, 12 Mb/s
> > (5) usb 2-2.1: USB disconnect, device number 5
> > 
> > Description:
> > (1) hub is resumed before sending a ClearPortFeature request
> > (2) hub_activate() notices the port is connected and sets
> >     hub->change_bits for the port
> > (3) hub_events() starts, but at the same time the port suspends
> > (4) hub_connect_change() sees the disabled port and triggers disconnect
> 
> > --- a/drivers/usb/core/hub.c
> > +++ b/drivers/usb/core/hub.c
> > @@ -4728,32 +4728,41 @@ static void port_event(struct usb_hub *hub, int port1)
> >  				       USB_PORT_FEAT_C_PORT_CONFIG_ERROR);
> >  	}
> >  
> > -	if (hub_handle_remote_wakeup(hub, port1, portstatus, portchange))
> > -		connect_change = 1;
> > -
> > -	/* Warm reset a USB3 protocol port if it's in
> > -	 * SS.Inactive state.
> > -	 */
> > -	if (hub_port_warm_reset_required(hub, portstatus)) {
> > -		int status;
> > +	/* take port actions that require the port to be powered on */
> > +	pm_runtime_get_noresume(&port_dev->dev);
> > +	pm_runtime_barrier(&port_dev->dev);
> > +	if (pm_runtime_active(&port_dev->dev)) {
> > +		if (hub_handle_remote_wakeup(hub, port1,
> > +					     portstatus, portchange))
> > +			connect_change = 1;
> 
> When there is a remote wakeup request pending, we want to handle it
> even if the port is powered off.

On second thought, this can't happen since we never power-down a port 
if the child device is enabled for remote wakeup.  Never mind...

Alan Stern

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