diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2018-01-31 11:23:28 -0800 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2018-01-31 11:23:28 -0800 | 
| commit | 28bc6fb9596fe1e577d09fc17ee6e1bb051c6ba3 (patch) | |
| tree | 6293b282a960720fc5008e3e5fa4d096d974b2f1 /drivers/scsi/scsi_devinfo.c | |
| parent | 0be600a5add76e8e8b9e1119f2a7426ff849aca8 (diff) | |
| parent | a2390348c19d0819d525d375414a7cfdacb51a68 (diff) | |
Merge tag 'scsi-misc' of git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi
Pull SCSI updates from James Bottomley:
 "This is mostly updates of the usual driver suspects: arcmsr,
  scsi_debug, mpt3sas, lpfc, cxlflash, qla2xxx, aacraid, megaraid_sas,
  hisi_sas.
  We also have a rework of the libsas hotplug handling to make it more
  robust, a slew of 32 bit time conversions and fixes, and a host of the
  usual minor updates and style changes. The biggest potential for
  regressions is the libsas hotplug changes, but so far they seem stable
  under testing"
* tag 'scsi-misc' of git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi: (313 commits)
  scsi: qla2xxx: Fix logo flag for qlt_free_session_done()
  scsi: arcmsr: avoid do_gettimeofday
  scsi: core: Add VENDOR_SPECIFIC sense code definitions
  scsi: qedi: Drop cqe response during connection recovery
  scsi: fas216: fix sense buffer initialization
  scsi: ibmvfc: Remove unneeded semicolons
  scsi: hisi_sas: fix a bug in hisi_sas_dev_gone()
  scsi: hisi_sas: directly attached disk LED feature for v2 hw
  scsi: hisi_sas: devicetree: bindings: add LED feature for v2 hw
  scsi: megaraid_sas: NVMe passthrough command support
  scsi: megaraid: use ktime_get_real for firmware time
  scsi: fnic: use 64-bit timestamps
  scsi: qedf: Fix error return code in __qedf_probe()
  scsi: devinfo: fix format of the device list
  scsi: qla2xxx: Update driver version to 10.00.00.05-k
  scsi: qla2xxx: Add XCB counters to debugfs
  scsi: qla2xxx: Fix queue ID for async abort with Multiqueue
  scsi: qla2xxx: Fix warning for code intentation in __qla24xx_handle_gpdb_event()
  scsi: qla2xxx: Fix warning during port_name debug print
  scsi: qla2xxx: Fix warning in qla2x00_async_iocb_timeout()
  ...
Diffstat (limited to 'drivers/scsi/scsi_devinfo.c')
| -rw-r--r-- | drivers/scsi/scsi_devinfo.c | 39 | 
1 files changed, 17 insertions, 22 deletions
| diff --git a/drivers/scsi/scsi_devinfo.c b/drivers/scsi/scsi_devinfo.c index dfb8da83fa50..f3b117246d47 100644 --- a/drivers/scsi/scsi_devinfo.c +++ b/drivers/scsi/scsi_devinfo.c @@ -108,8 +108,8 @@ static struct {  	 * seagate controller, which causes SCSI code to reset bus.  	 */  	{"HP", "C1750A", "3226", BLIST_NOLUN},		/* scanjet iic */ -	{"HP", "C1790A", "", BLIST_NOLUN},		/* scanjet iip */ -	{"HP", "C2500A", "", BLIST_NOLUN},		/* scanjet iicx */ +	{"HP", "C1790A", NULL, BLIST_NOLUN},		/* scanjet iip */ +	{"HP", "C2500A", NULL, BLIST_NOLUN},		/* scanjet iicx */  	{"MEDIAVIS", "CDR-H93MV", "1.31", BLIST_NOLUN},	/* locks up */  	{"MICROTEK", "ScanMaker II", "5.61", BLIST_NOLUN},	/* responds to all lun */  	{"MITSUMI", "CD-R CR-2201CS", "6119", BLIST_NOLUN},	/* locks up */ @@ -119,7 +119,7 @@ static struct {  	{"QUANTUM", "FIREBALL ST4.3S", "0F0C", BLIST_NOLUN},	/* locks up */  	{"RELISYS", "Scorpio", NULL, BLIST_NOLUN},	/* responds to all lun */  	{"SANKYO", "CP525", "6.64", BLIST_NOLUN},	/* causes failed REQ SENSE, extra reset */ -	{"TEXEL", "CD-ROM", "1.06", BLIST_NOLUN}, +	{"TEXEL", "CD-ROM", "1.06", BLIST_NOLUN | BLIST_BORKEN},  	{"transtec", "T5008", "0001", BLIST_NOREPORTLUN },  	{"YAMAHA", "CDR100", "1.00", BLIST_NOLUN},	/* locks up */  	{"YAMAHA", "CDR102", "1.00", BLIST_NOLUN},	/* locks up */ @@ -158,8 +158,8 @@ static struct {  	{"DELL", "PSEUDO DEVICE .", NULL, BLIST_SPARSELUN},	/* Dell PV 530F */  	{"DELL", "PV530F", NULL, BLIST_SPARSELUN},  	{"DELL", "PERCRAID", NULL, BLIST_FORCELUN}, -	{"DGC", "RAID", NULL, BLIST_SPARSELUN},	/* Dell PV 650F, storage on LUN 0 */ -	{"DGC", "DISK", NULL, BLIST_SPARSELUN},	/* Dell PV 650F, no storage on LUN 0 */ +	{"DGC", "RAID", NULL, BLIST_SPARSELUN},	/* EMC CLARiiON, storage on LUN 0 */ +	{"DGC", "DISK", NULL, BLIST_SPARSELUN},	/* EMC CLARiiON, no storage on LUN 0 */  	{"EMC",  "Invista", "*", BLIST_SPARSELUN | BLIST_LARGELUN},  	{"EMC", "SYMMETRIX", NULL, BLIST_SPARSELUN | BLIST_LARGELUN | BLIST_REPORTLUN2},  	{"EMULEX", "MD21/S2     ESDI", NULL, BLIST_SINGLELUN}, @@ -181,15 +181,14 @@ static struct {  	{"HITACHI", "6586-", "*", BLIST_SPARSELUN | BLIST_LARGELUN},  	{"HITACHI", "6588-", "*", BLIST_SPARSELUN | BLIST_LARGELUN},  	{"HP", "A6189A", NULL, BLIST_SPARSELUN | BLIST_LARGELUN},	/* HP VA7400 */ -	{"HP", "OPEN-", "*", BLIST_REPORTLUN2}, /* HP XP Arrays */ +	{"HP", "OPEN-", "*", BLIST_REPORTLUN2 | BLIST_TRY_VPD_PAGES}, /* HP XP Arrays */  	{"HP", "NetRAID-4M", NULL, BLIST_FORCELUN},  	{"HP", "HSV100", NULL, BLIST_REPORTLUN2 | BLIST_NOSTARTONADD},  	{"HP", "C1557A", NULL, BLIST_FORCELUN},  	{"HP", "C3323-300", "4269", BLIST_NOTQ},  	{"HP", "C5713A", NULL, BLIST_NOREPORTLUN}, -	{"HP", "DF400", "*", BLIST_SPARSELUN | BLIST_LARGELUN}, -	{"HP", "DF500", "*", BLIST_SPARSELUN | BLIST_LARGELUN}, -	{"HP", "DF600", "*", BLIST_SPARSELUN | BLIST_LARGELUN}, +	{"HP", "DF400", "*", BLIST_REPORTLUN2}, +	{"HP", "DF500", "*", BLIST_REPORTLUN2},  	{"HP", "OP-C-", "*", BLIST_SPARSELUN | BLIST_LARGELUN},  	{"HP", "3380-", "*", BLIST_SPARSELUN | BLIST_LARGELUN},  	{"HP", "3390-", "*", BLIST_SPARSELUN | BLIST_LARGELUN}, @@ -255,7 +254,6 @@ static struct {  	{"ST650211", "CF", NULL, BLIST_RETRY_HWERROR},  	{"SUN", "T300", "*", BLIST_SPARSELUN},  	{"SUN", "T4", "*", BLIST_SPARSELUN}, -	{"TEXEL", "CD-ROM", "1.06", BLIST_BORKEN},  	{"Tornado-", "F4", "*", BLIST_NOREPORTLUN},  	{"TOSHIBA", "CDROM", NULL, BLIST_ISROM},  	{"TOSHIBA", "CD-ROM", NULL, BLIST_ISROM}, @@ -353,7 +351,8 @@ static int scsi_dev_info_list_add(int compatible, char *vendor, char *model,   * Returns: 0 OK, -error on failure.   **/  int scsi_dev_info_list_add_keyed(int compatible, char *vendor, char *model, -				 char *strflags, blist_flags_t flags, int key) +				 char *strflags, blist_flags_t flags, +				 enum scsi_devinfo_key key)  {  	struct scsi_dev_info_list *devinfo;  	struct scsi_dev_info_list_table *devinfo_table = @@ -402,7 +401,7 @@ EXPORT_SYMBOL(scsi_dev_info_list_add_keyed);   * Returns: pointer to matching entry, or ERR_PTR on failure.   **/  static struct scsi_dev_info_list *scsi_dev_info_list_find(const char *vendor, -		const char *model, int key) +		const char *model, enum scsi_devinfo_key key)  {  	struct scsi_dev_info_list *devinfo;  	struct scsi_dev_info_list_table *devinfo_table = @@ -485,7 +484,8 @@ static struct scsi_dev_info_list *scsi_dev_info_list_find(const char *vendor,   *   * Returns: 0 OK, -error on failure.   **/ -int scsi_dev_info_list_del_keyed(char *vendor, char *model, int key) +int scsi_dev_info_list_del_keyed(char *vendor, char *model, +				 enum scsi_devinfo_key key)  {  	struct scsi_dev_info_list *found; @@ -587,20 +587,15 @@ blist_flags_t scsi_get_device_flags(struct scsi_device *sdev,  blist_flags_t scsi_get_device_flags_keyed(struct scsi_device *sdev,  				const unsigned char *vendor,  				const unsigned char *model, -				int key) +				enum scsi_devinfo_key key)  {  	struct scsi_dev_info_list *devinfo; -	int err;  	devinfo = scsi_dev_info_list_find(vendor, model, key);  	if (!IS_ERR(devinfo))  		return devinfo->flags; -	err = PTR_ERR(devinfo); -	if (err != -ENOENT) -		return err; - -	/* nothing found, return nothing */ +	/* key or device not found: return nothing */  	if (key != SCSI_DEVINFO_GLOBAL)  		return 0; @@ -774,7 +769,7 @@ void scsi_exit_devinfo(void)   * Adds the requested list, returns zero on success, -EEXIST if the   * key is already registered to a list, or other error on failure.   */ -int scsi_dev_info_add_list(int key, const char *name) +int scsi_dev_info_add_list(enum scsi_devinfo_key key, const char *name)  {  	struct scsi_dev_info_list_table *devinfo_table =  		scsi_devinfo_lookup_by_key(key); @@ -806,7 +801,7 @@ EXPORT_SYMBOL(scsi_dev_info_add_list);   * frees the list itself.  Returns 0 on success or -EINVAL if the key   * can't be found.   */ -int scsi_dev_info_remove_list(int key) +int scsi_dev_info_remove_list(enum scsi_devinfo_key key)  {  	struct list_head *lh, *lh_next;  	struct scsi_dev_info_list_table *devinfo_table = | 
