Commit 0d96ef5f authored by Webb Scales's avatar Webb Scales Committed by James Bottomley

hpsa: clean up host, channel, target, lun prints

We had a mix of formats used for specifying controller, bus, target,
and lun address of devices.

change to the format used by the scsi midlayer and upper layer (2:3:0:0)
so you can easily follow the information from hpsa to scsi midlayer
to sd upper layer.

Also add this information:
- product ID
- vendor ID
- RAID level
- SSD Smath Path capable and enabled
- exposure level (sg-only)

Example:
hpsa 0000:04:00.0: added scsi 2:0:0:0: Direct-Access     HP LOGICAL VOLUME   RAID-0 SSDSmartPathCap+ En+ Exp=4
scsi 2:0:0:0: Direct-Access     HP       LOGICAL VOLUME   10.0 PQ: 0 ANSI: 5
sd 2:0:0:0: [sdr] 12501713072 512-byte logical blocks: (6.40 TB/5.82 TiB)
sd 2:0:0:0: [sdr] 4096-byte physical blocks
sd 2:0:0:0: [sdr] Attached SCSI disk
sd 2:0:0:0: Attached scsi generic sg20 type 0
Reviewed-by: default avatarScott Teel <scott.teel@pmcs.com>
Reviewed-by: default avatarKevin Barnett <kevin.barnett@pmcs.com>
Reviewed-by: default avatarTomas Henzl <thenzl@redhat.com>
Reviewed-by: default avatarHannes Reinecke <hare@Suse.de>
Signed-off-by: default avatarRobert Elliott <elliott@hp.com>
Signed-off-by: default avatarDon Brace <don.brace@pmcs.com>
Reviewed-by: default avatarChristoph Hellwig <hch@lst.de>
Signed-off-by: default avatarJames Bottomley <JBottomley@Odin.com>
parent 41ce4c35
...@@ -886,6 +886,23 @@ static int hpsa_find_target_lun(struct ctlr_info *h, ...@@ -886,6 +886,23 @@ static int hpsa_find_target_lun(struct ctlr_info *h,
return !found; return !found;
} }
static inline void hpsa_show_dev_msg(const char *level, struct ctlr_info *h,
struct hpsa_scsi_dev_t *dev, char *description)
{
dev_printk(level, &h->pdev->dev,
"scsi %d:%d:%d:%d: %s %s %.8s %.16s RAID-%s SSDSmartPathCap%c En%c Exp=%d\n",
h->scsi_host->host_no, dev->bus, dev->target, dev->lun,
description,
scsi_device_type(dev->devtype),
dev->vendor,
dev->model,
dev->raid_level > RAID_UNKNOWN ?
"RAID-?" : raid_label[dev->raid_level],
dev->offload_config ? '+' : '-',
dev->offload_enabled ? '+' : '-',
dev->expose_state);
}
/* Add an entry into h->dev[] array. */ /* Add an entry into h->dev[] array. */
static int hpsa_scsi_add_entry(struct ctlr_info *h, int hostno, static int hpsa_scsi_add_entry(struct ctlr_info *h, int hostno,
struct hpsa_scsi_dev_t *device, struct hpsa_scsi_dev_t *device,
...@@ -955,15 +972,8 @@ static int hpsa_scsi_add_entry(struct ctlr_info *h, int hostno, ...@@ -955,15 +972,8 @@ static int hpsa_scsi_add_entry(struct ctlr_info *h, int hostno,
device->offload_enabled = 0; device->offload_enabled = 0;
added[*nadded] = device; added[*nadded] = device;
(*nadded)++; (*nadded)++;
hpsa_show_dev_msg(KERN_INFO, h, device,
/* initially, (before registering with scsi layer) we don't device->expose_state & HPSA_SCSI_ADD ? "added" : "masked");
* know our hostno and we don't want to print anything first
* time anyway (the scsi layer's inquiries will show that info)
*/
/* if (hostno != -1) */
dev_info(&h->pdev->dev, "%s device c%db%dt%dl%d added.\n",
scsi_device_type(device->devtype), hostno,
device->bus, device->target, device->lun);
return 0; return 0;
} }
...@@ -1003,6 +1013,7 @@ static void hpsa_scsi_update_entry(struct ctlr_info *h, int hostno, ...@@ -1003,6 +1013,7 @@ static void hpsa_scsi_update_entry(struct ctlr_info *h, int hostno,
if (!new_entry->offload_enabled) if (!new_entry->offload_enabled)
h->dev[entry]->offload_enabled = 0; h->dev[entry]->offload_enabled = 0;
hpsa_show_dev_msg(KERN_INFO, h, h->dev[entry], "updated");
} }
/* Replace an entry from h->dev[] array. */ /* Replace an entry from h->dev[] array. */
...@@ -1030,9 +1041,7 @@ static void hpsa_scsi_replace_entry(struct ctlr_info *h, int hostno, ...@@ -1030,9 +1041,7 @@ static void hpsa_scsi_replace_entry(struct ctlr_info *h, int hostno,
h->dev[entry] = new_entry; h->dev[entry] = new_entry;
added[*nadded] = new_entry; added[*nadded] = new_entry;
(*nadded)++; (*nadded)++;
dev_info(&h->pdev->dev, "%s device c%db%dt%dl%d changed.\n", hpsa_show_dev_msg(KERN_INFO, h, new_entry, "replaced");
scsi_device_type(new_entry->devtype), hostno, new_entry->bus,
new_entry->target, new_entry->lun);
} }
/* Remove an entry from h->dev[] array. */ /* Remove an entry from h->dev[] array. */
...@@ -1052,9 +1061,7 @@ static void hpsa_scsi_remove_entry(struct ctlr_info *h, int hostno, int entry, ...@@ -1052,9 +1061,7 @@ static void hpsa_scsi_remove_entry(struct ctlr_info *h, int hostno, int entry,
for (i = entry; i < h->ndevices-1; i++) for (i = entry; i < h->ndevices-1; i++)
h->dev[i] = h->dev[i+1]; h->dev[i] = h->dev[i+1];
h->ndevices--; h->ndevices--;
dev_info(&h->pdev->dev, "%s device c%db%dt%dl%d removed.\n", hpsa_show_dev_msg(KERN_INFO, h, sd, "removed");
scsi_device_type(sd->devtype), hostno, sd->bus, sd->target,
sd->lun);
} }
#define SCSI3ADDR_EQ(a, b) ( \ #define SCSI3ADDR_EQ(a, b) ( \
...@@ -1435,9 +1442,7 @@ static void adjust_hpsa_scsi_table(struct ctlr_info *h, int hostno, ...@@ -1435,9 +1442,7 @@ static void adjust_hpsa_scsi_table(struct ctlr_info *h, int hostno,
*/ */
if (sd[i]->volume_offline) { if (sd[i]->volume_offline) {
hpsa_show_volume_status(h, sd[i]); hpsa_show_volume_status(h, sd[i]);
dev_info(&h->pdev->dev, "c%db%dt%dl%d: temporarily offline\n", hpsa_show_dev_msg(KERN_INFO, h, sd[i], "offline");
h->scsi_host->host_no,
sd[i]->bus, sd[i]->target, sd[i]->lun);
continue; continue;
} }
...@@ -1501,10 +1506,8 @@ static void adjust_hpsa_scsi_table(struct ctlr_info *h, int hostno, ...@@ -1501,10 +1506,8 @@ static void adjust_hpsa_scsi_table(struct ctlr_info *h, int hostno,
* future cmds to this device will get selection * future cmds to this device will get selection
* timeout as if the device was gone. * timeout as if the device was gone.
*/ */
dev_warn(&h->pdev->dev, hpsa_show_dev_msg(KERN_WARNING, h, removed[i],
"didn't find c%db%dt%dl%d for removal.\n", "didn't find device for removal.");
hostno, removed[i]->bus,
removed[i]->target, removed[i]->lun);
} }
} }
kfree(removed[i]); kfree(removed[i]);
...@@ -1518,9 +1521,8 @@ static void adjust_hpsa_scsi_table(struct ctlr_info *h, int hostno, ...@@ -1518,9 +1521,8 @@ static void adjust_hpsa_scsi_table(struct ctlr_info *h, int hostno,
if (scsi_add_device(sh, added[i]->bus, if (scsi_add_device(sh, added[i]->bus,
added[i]->target, added[i]->lun) == 0) added[i]->target, added[i]->lun) == 0)
continue; continue;
dev_warn(&h->pdev->dev, "scsi_add_device c%db%dt%dl%d failed, " hpsa_show_dev_msg(KERN_WARNING, h, added[i],
"device not added.\n", hostno, added[i]->bus, "addition failed, device not added.");
added[i]->target, added[i]->lun);
/* now we have to remove it from h->dev, /* now we have to remove it from h->dev,
* since it didn't get added to scsi mid layer * since it didn't get added to scsi mid layer
*/ */
...@@ -4375,7 +4377,6 @@ static int hpsa_eh_device_reset_handler(struct scsi_cmnd *scsicmd) ...@@ -4375,7 +4377,6 @@ static int hpsa_eh_device_reset_handler(struct scsi_cmnd *scsicmd)
if (rc == 0 && wait_for_device_to_become_ready(h, dev->scsi3addr) == 0) if (rc == 0 && wait_for_device_to_become_ready(h, dev->scsi3addr) == 0)
return SUCCESS; return SUCCESS;
dev_warn(&h->pdev->dev, "resetting device failed.\n");
return FAILED; return FAILED;
} }
...@@ -4491,8 +4492,9 @@ static int hpsa_send_reset_as_abort_ioaccel2(struct ctlr_info *h, ...@@ -4491,8 +4492,9 @@ static int hpsa_send_reset_as_abort_ioaccel2(struct ctlr_info *h,
if (h->raid_offload_debug > 0) if (h->raid_offload_debug > 0)
dev_info(&h->pdev->dev, dev_info(&h->pdev->dev,
"Reset as abort: Abort requested on C%d:B%d:T%d:L%d scsi3addr 0x%02x%02x%02x%02x%02x%02x%02x%02x\n", "scsi %d:%d:%d:%d %s scsi3addr 0x%02x%02x%02x%02x%02x%02x%02x%02x\n",
h->scsi_host->host_no, dev->bus, dev->target, dev->lun, h->scsi_host->host_no, dev->bus, dev->target, dev->lun,
"Reset as abort",
scsi3addr[0], scsi3addr[1], scsi3addr[2], scsi3addr[3], scsi3addr[0], scsi3addr[1], scsi3addr[2], scsi3addr[3],
scsi3addr[4], scsi3addr[5], scsi3addr[6], scsi3addr[7]); scsi3addr[4], scsi3addr[5], scsi3addr[6], scsi3addr[7]);
...@@ -4594,9 +4596,10 @@ static int hpsa_eh_abort_handler(struct scsi_cmnd *sc) ...@@ -4594,9 +4596,10 @@ static int hpsa_eh_abort_handler(struct scsi_cmnd *sc)
return FAILED; return FAILED;
memset(msg, 0, sizeof(msg)); memset(msg, 0, sizeof(msg));
ml += sprintf(msg+ml, "ABORT REQUEST on C%d:B%d:T%d:L%llu ", ml += sprintf(msg+ml, "scsi %d:%d:%d:%llu %s",
h->scsi_host->host_no, sc->device->channel, h->scsi_host->host_no, sc->device->channel,
sc->device->id, sc->device->lun); sc->device->id, sc->device->lun,
"Aborting command");
/* Find the device of the command to be aborted */ /* Find the device of the command to be aborted */
dev = sc->device->hostdata; dev = sc->device->hostdata;
...@@ -4624,8 +4627,7 @@ static int hpsa_eh_abort_handler(struct scsi_cmnd *sc) ...@@ -4624,8 +4627,7 @@ static int hpsa_eh_abort_handler(struct scsi_cmnd *sc)
ml += sprintf(msg+ml, "Command:0x%x SN:0x%lx ", ml += sprintf(msg+ml, "Command:0x%x SN:0x%lx ",
as->cmnd[0], as->serial_number); as->cmnd[0], as->serial_number);
dev_dbg(&h->pdev->dev, "%s\n", msg); dev_dbg(&h->pdev->dev, "%s\n", msg);
dev_warn(&h->pdev->dev, "Abort request on C%d:B%d:T%d:L%d\n", hpsa_show_dev_msg(KERN_WARNING, h, dev, "Aborting command");
h->scsi_host->host_no, dev->bus, dev->target, dev->lun);
/* /*
* Command is in flight, or possibly already completed * Command is in flight, or possibly already completed
* by the firmware (but not to the scsi mid layer) but we can't * by the firmware (but not to the scsi mid layer) but we can't
...@@ -4633,10 +4635,8 @@ static int hpsa_eh_abort_handler(struct scsi_cmnd *sc) ...@@ -4633,10 +4635,8 @@ static int hpsa_eh_abort_handler(struct scsi_cmnd *sc)
*/ */
rc = hpsa_send_abort_both_ways(h, dev->scsi3addr, abort); rc = hpsa_send_abort_both_ways(h, dev->scsi3addr, abort);
if (rc != 0) { if (rc != 0) {
dev_dbg(&h->pdev->dev, "%s Request FAILED.\n", msg); hpsa_show_dev_msg(KERN_WARNING, h, dev,
dev_warn(&h->pdev->dev, "FAILED abort on device C%d:B%d:T%d:L%d\n", "FAILED to abort command");
h->scsi_host->host_no,
dev->bus, dev->target, dev->lun);
cmd_free(h, abort); cmd_free(h, abort);
return FAILED; return FAILED;
} }
......
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