aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/usb/storage
diff options
context:
space:
mode:
authorAlan Stern <stern@rowland.harvard.edu>2008-09-02 10:12:11 -0400
committerGreg Kroah-Hartman <gregkh@suse.de>2008-10-17 17:40:54 -0400
commit8bfa24727087d7252f9ecfb5fea2dfc92d797fbd (patch)
treef7155136c8a9353e4058b416ffff60512b266020 /drivers/usb/storage
parent3948f0e0c999a6201e9898bb8fbe3c6cc1199276 (diff)
usb-storage: report underflow with no sense data
This patch (as1118) addresses a problem with certain USB mass-storage devices. These devices sometimes return less data than asked for and then provide no sense data to explain the problem. Currently usb-storage leaves it up to the SCSI layer to decide how this should be handled, and the SCSI layer interprets the lack of sense data to mean that nothing went wrong. But if we got less data than required then something definitely _did_ go wrong, and we should say so. The patch tells the SCSI layer to retry the command when this sort of thing happens. Retrying may not solve the underlying problem, but it's better than believing that data was transferred when it wasn't. Signed-off-by: Alan Stern <stern@rowland.harvard.edu> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'drivers/usb/storage')
-rw-r--r--drivers/usb/storage/transport.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/usb/storage/transport.c b/drivers/usb/storage/transport.c
index 3523a0bfa0ff..79108d5d3171 100644
--- a/drivers/usb/storage/transport.c
+++ b/drivers/usb/storage/transport.c
@@ -663,7 +663,7 @@ void usb_stor_invoke_transport(struct scsi_cmnd *srb, struct us_data *us)
663 } 663 }
664 664
665 /* Did we transfer less than the minimum amount required? */ 665 /* Did we transfer less than the minimum amount required? */
666 if (srb->result == SAM_STAT_GOOD && 666 if ((srb->result == SAM_STAT_GOOD || srb->sense_buffer[2] == 0) &&
667 scsi_bufflen(srb) - scsi_get_resid(srb) < srb->underflow) 667 scsi_bufflen(srb) - scsi_get_resid(srb) < srb->underflow)
668 srb->result = (DID_ERROR << 16) | (SUGGEST_RETRY << 24); 668 srb->result = (DID_ERROR << 16) | (SUGGEST_RETRY << 24);
669 669