IB/srp: Add identifying information to log messages

When you have multiple targets, it gets really confusing when you try
to track down who did a reset when there is no identifying information
in the log message, especially when the same extension ID is mapped
through two different local IB ports.  So, add an identifier that can
be used to track back to which local IB port/remote target pair is the
one having problems.

Signed-off-by: David Dillow <dillowda@ornl.gov>
Acked-by: Pete Wyckoff <pw@osc.edu>
Signed-off-by: Roland Dreier <rolandd@cisco.com>
This commit is contained in:
David Dillow 2008-01-07 18:23:41 -05:00 committed by Roland Dreier
parent 586a693448
commit 7aa54bd730

View file

@ -272,7 +272,8 @@ static void srp_path_rec_completion(int status,
target->status = status; target->status = status;
if (status) if (status)
printk(KERN_ERR PFX "Got failed path rec status %d\n", status); shost_printk(KERN_ERR, target->scsi_host,
PFX "Got failed path rec status %d\n", status);
else else
target->path = *pathrec; target->path = *pathrec;
complete(&target->done); complete(&target->done);
@ -303,7 +304,8 @@ static int srp_lookup_path(struct srp_target_port *target)
wait_for_completion(&target->done); wait_for_completion(&target->done);
if (target->status < 0) if (target->status < 0)
printk(KERN_WARNING PFX "Path record query failed\n"); shost_printk(KERN_WARNING, target->scsi_host,
PFX "Path record query failed\n");
return target->status; return target->status;
} }
@ -379,9 +381,10 @@ static int srp_send_req(struct srp_target_port *target)
* the second 8 bytes to the local node GUID. * the second 8 bytes to the local node GUID.
*/ */
if (srp_target_is_topspin(target)) { if (srp_target_is_topspin(target)) {
printk(KERN_DEBUG PFX "Topspin/Cisco initiator port ID workaround " shost_printk(KERN_DEBUG, target->scsi_host,
"activated for target GUID %016llx\n", PFX "Topspin/Cisco initiator port ID workaround "
(unsigned long long) be64_to_cpu(target->ioc_guid)); "activated for target GUID %016llx\n",
(unsigned long long) be64_to_cpu(target->ioc_guid));
memset(req->priv.initiator_port_id, 0, 8); memset(req->priv.initiator_port_id, 0, 8);
memcpy(req->priv.initiator_port_id + 8, memcpy(req->priv.initiator_port_id + 8,
&target->srp_host->dev->dev->node_guid, 8); &target->srp_host->dev->dev->node_guid, 8);
@ -400,7 +403,8 @@ static void srp_disconnect_target(struct srp_target_port *target)
init_completion(&target->done); init_completion(&target->done);
if (ib_send_cm_dreq(target->cm_id, NULL, 0)) { if (ib_send_cm_dreq(target->cm_id, NULL, 0)) {
printk(KERN_DEBUG PFX "Sending CM DREQ failed\n"); shost_printk(KERN_DEBUG, target->scsi_host,
PFX "Sending CM DREQ failed\n");
return; return;
} }
wait_for_completion(&target->done); wait_for_completion(&target->done);
@ -568,7 +572,8 @@ static int srp_reconnect_target(struct srp_target_port *target)
return ret; return ret;
err: err:
printk(KERN_ERR PFX "reconnect failed (%d), removing target port.\n", ret); shost_printk(KERN_ERR, target->scsi_host,
PFX "reconnect failed (%d), removing target port.\n", ret);
/* /*
* We couldn't reconnect, so kill our target port off. * We couldn't reconnect, so kill our target port off.
@ -683,8 +688,9 @@ static int srp_map_data(struct scsi_cmnd *scmnd, struct srp_target_port *target,
if (scmnd->sc_data_direction != DMA_FROM_DEVICE && if (scmnd->sc_data_direction != DMA_FROM_DEVICE &&
scmnd->sc_data_direction != DMA_TO_DEVICE) { scmnd->sc_data_direction != DMA_TO_DEVICE) {
printk(KERN_WARNING PFX "Unhandled data direction %d\n", shost_printk(KERN_WARNING, target->scsi_host,
scmnd->sc_data_direction); PFX "Unhandled data direction %d\n",
scmnd->sc_data_direction);
return -EINVAL; return -EINVAL;
} }
@ -786,8 +792,9 @@ static void srp_process_rsp(struct srp_target_port *target, struct srp_rsp *rsp)
} else { } else {
scmnd = req->scmnd; scmnd = req->scmnd;
if (!scmnd) if (!scmnd)
printk(KERN_ERR "Null scmnd for RSP w/tag %016llx\n", shost_printk(KERN_ERR, target->scsi_host,
(unsigned long long) rsp->tag); "Null scmnd for RSP w/tag %016llx\n",
(unsigned long long) rsp->tag);
scmnd->result = rsp->status; scmnd->result = rsp->status;
if (rsp->flags & SRP_RSP_FLAG_SNSVALID) { if (rsp->flags & SRP_RSP_FLAG_SNSVALID) {
@ -831,7 +838,8 @@ static void srp_handle_recv(struct srp_target_port *target, struct ib_wc *wc)
if (0) { if (0) {
int i; int i;
printk(KERN_ERR PFX "recv completion, opcode 0x%02x\n", opcode); shost_printk(KERN_ERR, target->scsi_host,
PFX "recv completion, opcode 0x%02x\n", opcode);
for (i = 0; i < wc->byte_len; ++i) { for (i = 0; i < wc->byte_len; ++i) {
if (i % 8 == 0) if (i % 8 == 0)
@ -852,11 +860,13 @@ static void srp_handle_recv(struct srp_target_port *target, struct ib_wc *wc)
case SRP_T_LOGOUT: case SRP_T_LOGOUT:
/* XXX Handle target logout */ /* XXX Handle target logout */
printk(KERN_WARNING PFX "Got target logout request\n"); shost_printk(KERN_WARNING, target->scsi_host,
PFX "Got target logout request\n");
break; break;
default: default:
printk(KERN_WARNING PFX "Unhandled SRP opcode 0x%02x\n", opcode); shost_printk(KERN_WARNING, target->scsi_host,
PFX "Unhandled SRP opcode 0x%02x\n", opcode);
break; break;
} }
@ -872,9 +882,10 @@ static void srp_completion(struct ib_cq *cq, void *target_ptr)
ib_req_notify_cq(cq, IB_CQ_NEXT_COMP); ib_req_notify_cq(cq, IB_CQ_NEXT_COMP);
while (ib_poll_cq(cq, 1, &wc) > 0) { while (ib_poll_cq(cq, 1, &wc) > 0) {
if (wc.status) { if (wc.status) {
printk(KERN_ERR PFX "failed %s status %d\n", shost_printk(KERN_ERR, target->scsi_host,
wc.wr_id & SRP_OP_RECV ? "receive" : "send", PFX "failed %s status %d\n",
wc.status); wc.wr_id & SRP_OP_RECV ? "receive" : "send",
wc.status);
target->qp_in_error = 1; target->qp_in_error = 1;
break; break;
} }
@ -1027,12 +1038,13 @@ static int srp_queuecommand(struct scsi_cmnd *scmnd,
len = srp_map_data(scmnd, target, req); len = srp_map_data(scmnd, target, req);
if (len < 0) { if (len < 0) {
printk(KERN_ERR PFX "Failed to map data\n"); shost_printk(KERN_ERR, target->scsi_host,
PFX "Failed to map data\n");
goto err; goto err;
} }
if (__srp_post_recv(target)) { if (__srp_post_recv(target)) {
printk(KERN_ERR PFX "Recv failed\n"); shost_printk(KERN_ERR, target->scsi_host, PFX "Recv failed\n");
goto err_unmap; goto err_unmap;
} }
@ -1040,7 +1052,7 @@ static int srp_queuecommand(struct scsi_cmnd *scmnd,
DMA_TO_DEVICE); DMA_TO_DEVICE);
if (__srp_post_send(target, iu, len)) { if (__srp_post_send(target, iu, len)) {
printk(KERN_ERR PFX "Send failed\n"); shost_printk(KERN_ERR, target->scsi_host, PFX "Send failed\n");
goto err_unmap; goto err_unmap;
} }
@ -1095,6 +1107,7 @@ static void srp_cm_rej_handler(struct ib_cm_id *cm_id,
struct ib_cm_event *event, struct ib_cm_event *event,
struct srp_target_port *target) struct srp_target_port *target)
{ {
struct Scsi_Host *shost = target->scsi_host;
struct ib_class_port_info *cpi; struct ib_class_port_info *cpi;
int opcode; int opcode;
@ -1120,19 +1133,22 @@ static void srp_cm_rej_handler(struct ib_cm_id *cm_id,
memcpy(target->path.dgid.raw, memcpy(target->path.dgid.raw,
event->param.rej_rcvd.ari, 16); event->param.rej_rcvd.ari, 16);
printk(KERN_DEBUG PFX "Topspin/Cisco redirect to target port GID %016llx%016llx\n", shost_printk(KERN_DEBUG, shost,
(unsigned long long) be64_to_cpu(target->path.dgid.global.subnet_prefix), PFX "Topspin/Cisco redirect to target port GID %016llx%016llx\n",
(unsigned long long) be64_to_cpu(target->path.dgid.global.interface_id)); (unsigned long long) be64_to_cpu(target->path.dgid.global.subnet_prefix),
(unsigned long long) be64_to_cpu(target->path.dgid.global.interface_id));
target->status = SRP_PORT_REDIRECT; target->status = SRP_PORT_REDIRECT;
} else { } else {
printk(KERN_WARNING " REJ reason: IB_CM_REJ_PORT_REDIRECT\n"); shost_printk(KERN_WARNING, shost,
" REJ reason: IB_CM_REJ_PORT_REDIRECT\n");
target->status = -ECONNRESET; target->status = -ECONNRESET;
} }
break; break;
case IB_CM_REJ_DUPLICATE_LOCAL_COMM_ID: case IB_CM_REJ_DUPLICATE_LOCAL_COMM_ID:
printk(KERN_WARNING " REJ reason: IB_CM_REJ_DUPLICATE_LOCAL_COMM_ID\n"); shost_printk(KERN_WARNING, shost,
" REJ reason: IB_CM_REJ_DUPLICATE_LOCAL_COMM_ID\n");
target->status = -ECONNRESET; target->status = -ECONNRESET;
break; break;
@ -1143,20 +1159,21 @@ static void srp_cm_rej_handler(struct ib_cm_id *cm_id,
u32 reason = be32_to_cpu(rej->reason); u32 reason = be32_to_cpu(rej->reason);
if (reason == SRP_LOGIN_REJ_REQ_IT_IU_LENGTH_TOO_LARGE) if (reason == SRP_LOGIN_REJ_REQ_IT_IU_LENGTH_TOO_LARGE)
printk(KERN_WARNING PFX shost_printk(KERN_WARNING, shost,
"SRP_LOGIN_REJ: requested max_it_iu_len too large\n"); PFX "SRP_LOGIN_REJ: requested max_it_iu_len too large\n");
else else
printk(KERN_WARNING PFX shost_printk(KERN_WARNING, shost,
"SRP LOGIN REJECTED, reason 0x%08x\n", reason); PFX "SRP LOGIN REJECTED, reason 0x%08x\n", reason);
} else } else
printk(KERN_WARNING " REJ reason: IB_CM_REJ_CONSUMER_DEFINED," shost_printk(KERN_WARNING, shost,
" opcode 0x%02x\n", opcode); " REJ reason: IB_CM_REJ_CONSUMER_DEFINED,"
" opcode 0x%02x\n", opcode);
target->status = -ECONNRESET; target->status = -ECONNRESET;
break; break;
default: default:
printk(KERN_WARNING " REJ reason 0x%x\n", shost_printk(KERN_WARNING, shost, " REJ reason 0x%x\n",
event->param.rej_rcvd.reason); event->param.rej_rcvd.reason);
target->status = -ECONNRESET; target->status = -ECONNRESET;
} }
} }
@ -1171,7 +1188,8 @@ static int srp_cm_handler(struct ib_cm_id *cm_id, struct ib_cm_event *event)
switch (event->event) { switch (event->event) {
case IB_CM_REQ_ERROR: case IB_CM_REQ_ERROR:
printk(KERN_DEBUG PFX "Sending CM REQ failed\n"); shost_printk(KERN_DEBUG, target->scsi_host,
PFX "Sending CM REQ failed\n");
comp = 1; comp = 1;
target->status = -ECONNRESET; target->status = -ECONNRESET;
break; break;
@ -1189,7 +1207,8 @@ static int srp_cm_handler(struct ib_cm_id *cm_id, struct ib_cm_event *event)
target->scsi_host->can_queue = min(target->req_lim, target->scsi_host->can_queue = min(target->req_lim,
target->scsi_host->can_queue); target->scsi_host->can_queue);
} else { } else {
printk(KERN_WARNING PFX "Unhandled RSP opcode %#x\n", opcode); shost_printk(KERN_WARNING, target->scsi_host,
PFX "Unhandled RSP opcode %#x\n", opcode);
target->status = -ECONNRESET; target->status = -ECONNRESET;
break; break;
} }
@ -1235,20 +1254,23 @@ static int srp_cm_handler(struct ib_cm_id *cm_id, struct ib_cm_event *event)
break; break;
case IB_CM_REJ_RECEIVED: case IB_CM_REJ_RECEIVED:
printk(KERN_DEBUG PFX "REJ received\n"); shost_printk(KERN_DEBUG, target->scsi_host, PFX "REJ received\n");
comp = 1; comp = 1;
srp_cm_rej_handler(cm_id, event, target); srp_cm_rej_handler(cm_id, event, target);
break; break;
case IB_CM_DREQ_RECEIVED: case IB_CM_DREQ_RECEIVED:
printk(KERN_WARNING PFX "DREQ received - connection closed\n"); shost_printk(KERN_WARNING, target->scsi_host,
PFX "DREQ received - connection closed\n");
if (ib_send_cm_drep(cm_id, NULL, 0)) if (ib_send_cm_drep(cm_id, NULL, 0))
printk(KERN_ERR PFX "Sending CM DREP failed\n"); shost_printk(KERN_ERR, target->scsi_host,
PFX "Sending CM DREP failed\n");
break; break;
case IB_CM_TIMEWAIT_EXIT: case IB_CM_TIMEWAIT_EXIT:
printk(KERN_ERR PFX "connection closed\n"); shost_printk(KERN_ERR, target->scsi_host,
PFX "connection closed\n");
comp = 1; comp = 1;
target->status = 0; target->status = 0;
@ -1260,7 +1282,8 @@ static int srp_cm_handler(struct ib_cm_id *cm_id, struct ib_cm_event *event)
break; break;
default: default:
printk(KERN_WARNING PFX "Unhandled CM event %d\n", event->event); shost_printk(KERN_WARNING, target->scsi_host,
PFX "Unhandled CM event %d\n", event->event);
break; break;
} }
@ -1337,7 +1360,7 @@ static int srp_abort(struct scsi_cmnd *scmnd)
struct srp_request *req; struct srp_request *req;
int ret = SUCCESS; int ret = SUCCESS;
printk(KERN_ERR "SRP abort called\n"); shost_printk(KERN_ERR, target->scsi_host, "SRP abort called\n");
if (target->qp_in_error) if (target->qp_in_error)
return FAILED; return FAILED;
@ -1367,7 +1390,7 @@ static int srp_reset_device(struct scsi_cmnd *scmnd)
struct srp_target_port *target = host_to_target(scmnd->device->host); struct srp_target_port *target = host_to_target(scmnd->device->host);
struct srp_request *req, *tmp; struct srp_request *req, *tmp;
printk(KERN_ERR "SRP reset_device called\n"); shost_printk(KERN_ERR, target->scsi_host, "SRP reset_device called\n");
if (target->qp_in_error) if (target->qp_in_error)
return FAILED; return FAILED;
@ -1394,7 +1417,7 @@ static int srp_reset_host(struct scsi_cmnd *scmnd)
struct srp_target_port *target = host_to_target(scmnd->device->host); struct srp_target_port *target = host_to_target(scmnd->device->host);
int ret = FAILED; int ret = FAILED;
printk(KERN_ERR PFX "SRP reset_host called\n"); shost_printk(KERN_ERR, target->scsi_host, PFX "SRP reset_host called\n");
if (!srp_reconnect_target(target)) if (!srp_reconnect_target(target))
ret = SUCCESS; ret = SUCCESS;
@ -1820,8 +1843,9 @@ static ssize_t srp_create_target(struct class_device *class_dev,
ib_get_cached_gid(host->dev->dev, host->port, 0, &target->path.sgid); ib_get_cached_gid(host->dev->dev, host->port, 0, &target->path.sgid);
printk(KERN_DEBUG PFX "new target: id_ext %016llx ioc_guid %016llx pkey %04x " shost_printk(KERN_DEBUG, target->scsi_host, PFX
"service_id %016llx dgid %04x:%04x:%04x:%04x:%04x:%04x:%04x:%04x\n", "new target: id_ext %016llx ioc_guid %016llx pkey %04x "
"service_id %016llx dgid %04x:%04x:%04x:%04x:%04x:%04x:%04x:%04x\n",
(unsigned long long) be64_to_cpu(target->id_ext), (unsigned long long) be64_to_cpu(target->id_ext),
(unsigned long long) be64_to_cpu(target->ioc_guid), (unsigned long long) be64_to_cpu(target->ioc_guid),
be16_to_cpu(target->path.pkey), be16_to_cpu(target->path.pkey),
@ -1848,7 +1872,8 @@ static ssize_t srp_create_target(struct class_device *class_dev,
target->qp_in_error = 0; target->qp_in_error = 0;
ret = srp_connect_target(target); ret = srp_connect_target(target);
if (ret) { if (ret) {
printk(KERN_ERR PFX "Connection failed\n"); shost_printk(KERN_ERR, target->scsi_host,
PFX "Connection failed\n");
goto err_cm_id; goto err_cm_id;
} }