Commit 4ff36718 authored by Matthew Wilcox's avatar Matthew Wilcox Committed by James Bottomley

[SCSI] Improve inquiry printing

 - Replace scsi_device_types array API with scsi_device_type function API.
   Gets rid of a lot of common code, as well as being easier to use.
 - Add the new device types in SPC4 r05a, and rename some of the older ones.
 - Reformat the printing of inquiry data; now fits on one line and
   includes PQ.

I think I've addressed all the feedback from the previous versions.  My
current test box prints:

scsi 2:0:1:0: Direct access     HP 18.2G ATLAS10K3_18_SCA HP05 PQ: 0 ANSI: 2
Signed-off-by: default avatarMatthew Wilcox <matthew@wil.cx>
Signed-off-by: default avatarJames Bottomley <James.Bottomley@SteelEye.com>
parent 008cd5bb
...@@ -251,10 +251,6 @@ scsi_cmd_stack_free(int ctlr) ...@@ -251,10 +251,6 @@ scsi_cmd_stack_free(int ctlr)
stk->pool = NULL; stk->pool = NULL;
} }
/* scsi_device_types comes from scsi.h */
#define DEVICETYPE(n) (n<0 || n>MAX_SCSI_DEVICE_CODE) ? \
"Unknown" : scsi_device_types[n]
#if 0 #if 0
static int xmargin=8; static int xmargin=8;
static int amargin=60; static int amargin=60;
...@@ -389,7 +385,7 @@ cciss_scsi_add_entry(int ctlr, int hostno, ...@@ -389,7 +385,7 @@ cciss_scsi_add_entry(int ctlr, int hostno,
time anyway (the scsi layer's inquiries will show that info) */ time anyway (the scsi layer's inquiries will show that info) */
if (hostno != -1) if (hostno != -1)
printk("cciss%d: %s device c%db%dt%dl%d added.\n", printk("cciss%d: %s device c%db%dt%dl%d added.\n",
ctlr, DEVICETYPE(sd->devtype), hostno, ctlr, scsi_device_type(sd->devtype), hostno,
sd->bus, sd->target, sd->lun); sd->bus, sd->target, sd->lun);
return 0; return 0;
} }
...@@ -407,7 +403,7 @@ cciss_scsi_remove_entry(int ctlr, int hostno, int entry) ...@@ -407,7 +403,7 @@ cciss_scsi_remove_entry(int ctlr, int hostno, int entry)
ccissscsi[ctlr].dev[i] = ccissscsi[ctlr].dev[i+1]; ccissscsi[ctlr].dev[i] = ccissscsi[ctlr].dev[i+1];
ccissscsi[ctlr].ndevices--; ccissscsi[ctlr].ndevices--;
printk("cciss%d: %s device c%db%dt%dl%d removed.\n", printk("cciss%d: %s device c%db%dt%dl%d removed.\n",
ctlr, DEVICETYPE(sd.devtype), hostno, ctlr, scsi_device_type(sd.devtype), hostno,
sd.bus, sd.target, sd.lun); sd.bus, sd.target, sd.lun);
} }
...@@ -458,7 +454,7 @@ adjust_cciss_scsi_table(int ctlr, int hostno, ...@@ -458,7 +454,7 @@ adjust_cciss_scsi_table(int ctlr, int hostno,
if (found == 0) { /* device no longer present. */ if (found == 0) { /* device no longer present. */
changes++; changes++;
/* printk("cciss%d: %s device c%db%dt%dl%d removed.\n", /* printk("cciss%d: %s device c%db%dt%dl%d removed.\n",
ctlr, DEVICETYPE(csd->devtype), hostno, ctlr, scsi_device_type(csd->devtype), hostno,
csd->bus, csd->target, csd->lun); */ csd->bus, csd->target, csd->lun); */
cciss_scsi_remove_entry(ctlr, hostno, i); cciss_scsi_remove_entry(ctlr, hostno, i);
/* note, i not incremented */ /* note, i not incremented */
...@@ -468,7 +464,7 @@ adjust_cciss_scsi_table(int ctlr, int hostno, ...@@ -468,7 +464,7 @@ adjust_cciss_scsi_table(int ctlr, int hostno,
printk("cciss%d: device c%db%dt%dl%d type changed " printk("cciss%d: device c%db%dt%dl%d type changed "
"(device type now %s).\n", "(device type now %s).\n",
ctlr, hostno, csd->bus, csd->target, csd->lun, ctlr, hostno, csd->bus, csd->target, csd->lun,
DEVICETYPE(csd->devtype)); scsi_device_type(csd->devtype));
csd->devtype = sd[j].devtype; csd->devtype = sd[j].devtype;
i++; /* so just move along. */ i++; /* so just move along. */
} else /* device is same as it ever was, */ } else /* device is same as it ever was, */
...@@ -1098,7 +1094,7 @@ cciss_update_non_disk_devices(int cntl_num, int hostno) ...@@ -1098,7 +1094,7 @@ cciss_update_non_disk_devices(int cntl_num, int hostno)
if (ncurrent >= CCISS_MAX_SCSI_DEVS_PER_HBA) { if (ncurrent >= CCISS_MAX_SCSI_DEVS_PER_HBA) {
printk(KERN_INFO "cciss%d: %s ignored, " printk(KERN_INFO "cciss%d: %s ignored, "
"too many devices.\n", cntl_num, "too many devices.\n", cntl_num,
DEVICETYPE(devtype)); scsi_device_type(devtype));
break; break;
} }
memcpy(&currentsd[ncurrent].scsi3addr[0], memcpy(&currentsd[ncurrent].scsi3addr[0],
......
...@@ -248,8 +248,7 @@ int fcal_proc_info (struct Scsi_Host *host, char *buffer, char **start, off_t of ...@@ -248,8 +248,7 @@ int fcal_proc_info (struct Scsi_Host *host, char *buffer, char **start, off_t of
if (scd->id == target) { if (scd->id == target) {
SPRINTF (" [AL-PA: %02x, Id: %02d, Port WWN: %08x%08x, Node WWN: %08x%08x] ", SPRINTF (" [AL-PA: %02x, Id: %02d, Port WWN: %08x%08x, Node WWN: %08x%08x] ",
alpa, target, u1[0], u1[1], u2[0], u2[1]); alpa, target, u1[0], u1[1], u2[0], u2[1]);
SPRINTF ("%s ", (scd->type < MAX_SCSI_DEVICE_CODE) ? SPRINTF ("%s ", scsi_device_type(scd->type));
scsi_device_types[(short) scd->type] : "Unknown device");
for (j = 0; (j < 8) && (scd->vendor[j] >= 0x20); j++) for (j = 0; (j < 8) && (scd->vendor[j] >= 0x20); j++)
SPRINTF ("%c", scd->vendor[j]); SPRINTF ("%c", scd->vendor[j]);
......
...@@ -811,7 +811,6 @@ static int generic_NCR5380_proc_info(struct Scsi_Host *scsi_ptr, char *buffer, c ...@@ -811,7 +811,6 @@ static int generic_NCR5380_proc_info(struct Scsi_Host *scsi_ptr, char *buffer, c
struct NCR5380_hostdata *hostdata; struct NCR5380_hostdata *hostdata;
#ifdef NCR5380_STATS #ifdef NCR5380_STATS
struct scsi_device *dev; struct scsi_device *dev;
extern const char *const scsi_device_types[MAX_SCSI_DEVICE_CODE];
#endif #endif
NCR5380_setup(scsi_ptr); NCR5380_setup(scsi_ptr);
...@@ -851,7 +850,7 @@ static int generic_NCR5380_proc_info(struct Scsi_Host *scsi_ptr, char *buffer, c ...@@ -851,7 +850,7 @@ static int generic_NCR5380_proc_info(struct Scsi_Host *scsi_ptr, char *buffer, c
long tr = hostdata->time_read[dev->id] / HZ; long tr = hostdata->time_read[dev->id] / HZ;
long tw = hostdata->time_write[dev->id] / HZ; long tw = hostdata->time_write[dev->id] / HZ;
PRINTP(" T:%d %s " ANDP dev->id ANDP(dev->type < MAX_SCSI_DEVICE_CODE) ? scsi_device_types[(int) dev->type] : "Unknown"); PRINTP(" T:%d %s " ANDP dev->id ANDP scsi_device_type(dev->type));
for (i = 0; i < 8; i++) for (i = 0; i < 8; i++)
if (dev->vendor[i] >= 0x20) if (dev->vendor[i] >= 0x20)
*(buffer + (len++)) = dev->vendor[i]; *(buffer + (len++)) = dev->vendor[i];
......
...@@ -2822,9 +2822,7 @@ mega_print_inquiry(char *page, char *scsi_inq) ...@@ -2822,9 +2822,7 @@ mega_print_inquiry(char *page, char *scsi_inq)
i = scsi_inq[0] & 0x1f; i = scsi_inq[0] & 0x1f;
len += sprintf(page+len, " Type: %s ", len += sprintf(page+len, " Type: %s ", scsi_device_type(i));
i < MAX_SCSI_DEVICE_CODE ? scsi_device_types[i] :
"Unknown ");
len += sprintf(page+len, len += sprintf(page+len,
" ANSI SCSI revision: %02x", scsi_inq[2] & 0x07); " ANSI SCSI revision: %02x", scsi_inq[2] & 0x07);
......
...@@ -96,24 +96,40 @@ unsigned int scsi_logging_level; ...@@ -96,24 +96,40 @@ unsigned int scsi_logging_level;
EXPORT_SYMBOL(scsi_logging_level); EXPORT_SYMBOL(scsi_logging_level);
#endif #endif
const char *const scsi_device_types[MAX_SCSI_DEVICE_CODE] = { static const char *const scsi_device_types[] = {
"Direct-Access ", "Direct access ",
"Sequential-Access", "Sequential access",
"Printer ", "Printer ",
"Processor ", "Processor ",
"WORM ", "WORM ",
"CD-ROM ", "CD/DVD ",
"Scanner ", "Scanner ",
"Optical Device ", "Optical memory ",
"Medium Changer ", "Media changer ",
"Communications ", "Communications ",
"Unknown ", "ASC IT8 ",
"Unknown ", "ASC IT8 ",
"RAID ", "RAID ",
"Enclosure ", "Enclosure ",
"Direct-Access-RBC", "Direct access RBC",
"Optical card ",
"Bridge controller",
"Object storage ",
"Automation/Drive ",
}; };
EXPORT_SYMBOL(scsi_device_types);
const char * scsi_device_type(unsigned type)
{
if (type == 0x1e)
return "Well-known LUN ";
if (type == 0x1f)
return "No Device ";
if (type > ARRAY_SIZE(scsi_device_types))
return "Unknown ";
return scsi_device_types[type];
}
EXPORT_SYMBOL(scsi_device_type);
struct scsi_host_cmd_pool { struct scsi_host_cmd_pool {
kmem_cache_t *slab; kmem_cache_t *slab;
......
...@@ -178,9 +178,7 @@ static int proc_print_scsidevice(struct device *dev, void *data) ...@@ -178,9 +178,7 @@ static int proc_print_scsidevice(struct device *dev, void *data)
seq_printf(s, "\n"); seq_printf(s, "\n");
seq_printf(s, " Type: %s ", seq_printf(s, " Type: %s ", scsi_device_type(sdev->type));
sdev->type < MAX_SCSI_DEVICE_CODE ?
scsi_device_types[(int) sdev->type] : "Unknown ");
seq_printf(s, " ANSI" seq_printf(s, " ANSI"
" SCSI revision: %02x", (sdev->scsi_level - 1) ? " SCSI revision: %02x", (sdev->scsi_level - 1) ?
sdev->scsi_level - 1 : 1); sdev->scsi_level - 1 : 1);
......
...@@ -133,59 +133,6 @@ static void scsi_unlock_floptical(struct scsi_device *sdev, ...@@ -133,59 +133,6 @@ static void scsi_unlock_floptical(struct scsi_device *sdev,
SCSI_TIMEOUT, 3); SCSI_TIMEOUT, 3);
} }
/**
* print_inquiry - printk the inquiry information
* @inq_result: printk this SCSI INQUIRY
*
* Description:
* printk the vendor, model, and other information found in the
* INQUIRY data in @inq_result.
*
* Notes:
* Remove this, and replace with a hotplug event that logs any
* relevant information.
**/
static void print_inquiry(unsigned char *inq_result)
{
int i;
printk(KERN_NOTICE " Vendor: ");
for (i = 8; i < 16; i++)
if (inq_result[i] >= 0x20 && i < inq_result[4] + 5)
printk("%c", inq_result[i]);
else
printk(" ");
printk(" Model: ");
for (i = 16; i < 32; i++)
if (inq_result[i] >= 0x20 && i < inq_result[4] + 5)
printk("%c", inq_result[i]);
else
printk(" ");
printk(" Rev: ");
for (i = 32; i < 36; i++)
if (inq_result[i] >= 0x20 && i < inq_result[4] + 5)
printk("%c", inq_result[i]);
else
printk(" ");
printk("\n");
i = inq_result[0] & 0x1f;
printk(KERN_NOTICE " Type: %s ",
i <
MAX_SCSI_DEVICE_CODE ? scsi_device_types[i] :
"Unknown ");
printk(" ANSI SCSI revision: %02x",
inq_result[2] & 0x07);
if ((inq_result[2] & 0x07) == 1 && (inq_result[3] & 0x0f) == 1)
printk(" CCS\n");
else
printk("\n");
}
/** /**
* scsi_alloc_sdev - allocate and setup a scsi_Device * scsi_alloc_sdev - allocate and setup a scsi_Device
* *
...@@ -653,9 +600,8 @@ static int scsi_add_lun(struct scsi_device *sdev, char *inq_result, int *bflags) ...@@ -653,9 +600,8 @@ static int scsi_add_lun(struct scsi_device *sdev, char *inq_result, int *bflags)
if (*bflags & BLIST_ISROM) { if (*bflags & BLIST_ISROM) {
/* /*
* It would be better to modify sdev->type, and set * It would be better to modify sdev->type, and set
* sdev->removable, but then the print_inquiry() output * sdev->removable; this can now be done since
* would not show TYPE_ROM; if print_inquiry() is removed * print_inquiry has gone away.
* the issue goes away.
*/ */
inq_result[0] = TYPE_ROM; inq_result[0] = TYPE_ROM;
inq_result[1] |= 0x80; /* removable */ inq_result[1] |= 0x80; /* removable */
...@@ -684,8 +630,6 @@ static int scsi_add_lun(struct scsi_device *sdev, char *inq_result, int *bflags) ...@@ -684,8 +630,6 @@ static int scsi_add_lun(struct scsi_device *sdev, char *inq_result, int *bflags)
printk(KERN_INFO "scsi: unknown device type %d\n", sdev->type); printk(KERN_INFO "scsi: unknown device type %d\n", sdev->type);
} }
print_inquiry(inq_result);
/* /*
* For a peripheral qualifier (PQ) value of 1 (001b), the SCSI * For a peripheral qualifier (PQ) value of 1 (001b), the SCSI
* spec says: The device server is capable of supporting the * spec says: The device server is capable of supporting the
...@@ -715,6 +659,12 @@ static int scsi_add_lun(struct scsi_device *sdev, char *inq_result, int *bflags) ...@@ -715,6 +659,12 @@ static int scsi_add_lun(struct scsi_device *sdev, char *inq_result, int *bflags)
if (inq_result[7] & 0x10) if (inq_result[7] & 0x10)
sdev->sdtr = 1; sdev->sdtr = 1;
sdev_printk(KERN_NOTICE "scsi", sdev, "%s %.8s %.16s %.4s PQ: %d "
"ANSI: %d%s\n", scsi_device_type(sdev->type),
sdev->vendor, sdev->model, sdev->rev,
sdev->inq_periph_qual, inq_result[2] & 0x07,
(inq_result[3] & 0x0f) == 1 ? " CCS" : "");
/* /*
* End sysfs code. * End sysfs code.
*/ */
......
...@@ -24,13 +24,6 @@ ...@@ -24,13 +24,6 @@
extern const unsigned char scsi_command_size[8]; extern const unsigned char scsi_command_size[8];
#define COMMAND_SIZE(opcode) scsi_command_size[((opcode) >> 5) & 7] #define COMMAND_SIZE(opcode) scsi_command_size[((opcode) >> 5) & 7]
/*
* SCSI device types
*/
#define MAX_SCSI_DEVICE_CODE 15
extern const char *const scsi_device_types[MAX_SCSI_DEVICE_CODE];
/* /*
* Special value for scanning to specify scanning or rescanning of all * Special value for scanning to specify scanning or rescanning of all
* possible channels, (target) ids, or luns on a given shost. * possible channels, (target) ids, or luns on a given shost.
...@@ -225,6 +218,9 @@ static inline int scsi_status_is_good(int status) ...@@ -225,6 +218,9 @@ static inline int scsi_status_is_good(int status)
#define TYPE_RBC 0x0e #define TYPE_RBC 0x0e
#define TYPE_NO_LUN 0x7f #define TYPE_NO_LUN 0x7f
/* Returns a human-readable name for the device */
extern const char * scsi_device_type(unsigned type);
/* /*
* standard mode-select header prepended to all mode-select commands * standard mode-select header prepended to all mode-select commands
*/ */
......
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