Re: Enable CONFIG_USB_SUSPEND by default or some mobile HD can't beunplugged safely
From: Alan Stern
Date:  Fri Jan 02 2009 - 11:04:55 EST
On Fri, 2 Jan 2009, Yan Li wrote:
> Now I know 3 methods supposed can be used to shut the device:
> 1. (Alan Stern said Windows use this) cut the USB port's power
I said no such thing!  In fact, I said exactly the opposite: Windows 
does _not_ cut the port's power.  Instead it disables the port.
> 2. send STOP SCSI command to stop it
Note that this is different.  The START-STOP command is used to spin-up 
or spin-down a disk.  It does not affect the state of the data link.
> 3. put it into suspend mode
As far as the device is concerned, there is essentially no difference 
between 1 and 3.  When the device's upstream port is disabled, the 
device must go into suspend mode.
The best approach is to send a SYNCHRONIZE CACHE command followed by 
START-STOP (if the device supports it), and then to disable or suspend 
the port.  In Linux, those two commands will be sent automatically if 
you unbind the device from usb-storage.  The suspend has to be done 
manually unless you have set up a udev rule (or something equivalent) 
to enable autosuspend for the device.  Of course, this requires 
CONFIG_USB_SUSPEND.
Alan Stern
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/