Commit 720c21a8 authored by Hans de Goede's avatar Hans de Goede Committed by Ben Hutchings

USB: uas: Add a new NO_REPORT_LUNS quirk

commit 13630746 upstream.

Add a new NO_REPORT_LUNS quirk and set it for Seagate drives with
an usb-id of: 0bc2:331a, as these will fail to respond to a
REPORT_LUNS command.
Reported-and-tested-by: default avatarDavid Webb <djw@noc.ac.uk>
Signed-off-by: default avatarHans de Goede <hdegoede@redhat.com>
Acked-by: default avatarAlan Stern <stern@rowland.harvard.edu>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
[bwh: Backported to 3.2:
 - Adjust context
 - Drop the UAS changes]
Signed-off-by: default avatarBen Hutchings <ben@decadent.org.uk>
parent 1972444b
...@@ -2699,6 +2699,8 @@ bytes respectively. Such letter suffixes can also be entirely omitted. ...@@ -2699,6 +2699,8 @@ bytes respectively. Such letter suffixes can also be entirely omitted.
sector if the number is odd); sector if the number is odd);
i = IGNORE_DEVICE (don't bind to this i = IGNORE_DEVICE (don't bind to this
device); device);
j = NO_REPORT_LUNS (don't use report luns
command, uas only);
l = NOT_LOCKABLE (don't try to lock and l = NOT_LOCKABLE (don't try to lock and
unlock ejectable media); unlock ejectable media);
m = MAX_SECTORS_64 (don't transfer more m = MAX_SECTORS_64 (don't transfer more
......
...@@ -453,7 +453,7 @@ static void adjust_quirks(struct us_data *us) ...@@ -453,7 +453,7 @@ static void adjust_quirks(struct us_data *us)
US_FL_CAPACITY_OK | US_FL_IGNORE_RESIDUE | US_FL_CAPACITY_OK | US_FL_IGNORE_RESIDUE |
US_FL_SINGLE_LUN | US_FL_NO_WP_DETECT | US_FL_SINGLE_LUN | US_FL_NO_WP_DETECT |
US_FL_NO_READ_DISC_INFO | US_FL_NO_READ_CAPACITY_16 | US_FL_NO_READ_DISC_INFO | US_FL_NO_READ_CAPACITY_16 |
US_FL_INITIAL_READ10); US_FL_INITIAL_READ10 | US_FL_NO_REPORT_LUNS);
p = quirks; p = quirks;
while (*p) { while (*p) {
...@@ -497,6 +497,9 @@ static void adjust_quirks(struct us_data *us) ...@@ -497,6 +497,9 @@ static void adjust_quirks(struct us_data *us)
case 'i': case 'i':
f |= US_FL_IGNORE_DEVICE; f |= US_FL_IGNORE_DEVICE;
break; break;
case 'j':
f |= US_FL_NO_REPORT_LUNS;
break;
case 'l': case 'l':
f |= US_FL_NOT_LOCKABLE; f |= US_FL_NOT_LOCKABLE;
break; break;
......
...@@ -67,6 +67,8 @@ ...@@ -67,6 +67,8 @@
/* Initial READ(10) (and others) must be retried */ \ /* Initial READ(10) (and others) must be retried */ \
US_FLAG(BROKEN_FUA, 0x01000000) \ US_FLAG(BROKEN_FUA, 0x01000000) \
/* Cannot handle FUA in WRITE or READ CDBs */ \ /* Cannot handle FUA in WRITE or READ CDBs */ \
US_FLAG(NO_REPORT_LUNS, 0x10000000) \
/* Cannot handle REPORT_LUNS */ \
#define US_FLAG(name, value) US_FL_##name = value , #define US_FLAG(name, value) US_FL_##name = value ,
enum { US_DO_ALL_FLAGS }; enum { US_DO_ALL_FLAGS };
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment