On Mon, Dec 19, 2011 at 02:50:50PM -0500, Matthew Wilcox wrote: > On Mon, Dec 19, 2011 at 08:39:55PM +0100, Sebastian Andrzej Siewior wrote: > > In "usb/uas: use unique tags for all LUNs" we make sure to create unique > > tags across all LUNs. This patch uses scsi_host_find_tag() to obtain the > > correct command which is associated with the tag. > > The following changes were required: > > - don't use sdev->current_cmnd anymore > > Since be can have devices which don't support command tagging we must > > ensure that we can tell the two commands apart. devinfo->cmnd is used > > for this. > > I don't understand. There's one devinfo per sdev. How does moving the > untagged command anchor from sdev to devinfo change anything? I thought there was only one devinfo per USB device. uas_probe() is only called once per USB device, and that's where devinfo is allocated and the scsi_host is created. > It's my understanding that the SCSI core will only send either a single > untagged command, or tagged commands. ie any outstanding tagged command > will cause an untagged command to be deferred, and an outstanding untagged > command will prevent any other command from being sent to the driver. Across all scsi_devices on a scsi_host? In the status command completion for USB 2.0 devices, we can't know which scsi_device we're completing the command for. Is it an untagged command completion for LUN 1 or LUN 2? We can't tell, because the device could reorder the commands across LUNs. So for untagged USB 2.0 devices, we need to be sure there is only one untagged command pending per scsi_host, and pull the command out of devinfo. Sarah Sharp -- To unsubscribe from this list: send the line "unsubscribe linux-scsi" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html