diff options
-rw-r--r-- | drivers/scsi/libiscsi.c | 164 | ||||
-rw-r--r-- | include/scsi/libiscsi.h | 7 |
2 files changed, 103 insertions, 68 deletions
diff --git a/drivers/scsi/libiscsi.c b/drivers/scsi/libiscsi.c index c33e28fd49bc..701457cca08a 100644 --- a/drivers/scsi/libiscsi.c +++ b/drivers/scsi/libiscsi.c | |||
@@ -38,6 +38,28 @@ | |||
38 | #include <scsi/scsi_transport_iscsi.h> | 38 | #include <scsi/scsi_transport_iscsi.h> |
39 | #include <scsi/libiscsi.h> | 39 | #include <scsi/libiscsi.h> |
40 | 40 | ||
41 | static int iscsi_dbg_lib; | ||
42 | module_param_named(debug_libiscsi, iscsi_dbg_lib, int, S_IRUGO | S_IWUSR); | ||
43 | MODULE_PARM_DESC(debug_libiscsi, "Turn on debugging for libiscsi module. " | ||
44 | "Set to 1 to turn on, and zero to turn off. Default " | ||
45 | "is off."); | ||
46 | |||
47 | #define ISCSI_DBG_CONN(_conn, dbg_fmt, arg...) \ | ||
48 | do { \ | ||
49 | if (iscsi_dbg_lib) \ | ||
50 | iscsi_conn_printk(KERN_INFO, _conn, \ | ||
51 | "%s " dbg_fmt, \ | ||
52 | __func__, ##arg); \ | ||
53 | } while (0); | ||
54 | |||
55 | #define ISCSI_DBG_SESSION(_session, dbg_fmt, arg...) \ | ||
56 | do { \ | ||
57 | if (iscsi_dbg_lib) \ | ||
58 | iscsi_session_printk(KERN_INFO, _session, \ | ||
59 | "%s " dbg_fmt, \ | ||
60 | __func__, ##arg); \ | ||
61 | } while (0); | ||
62 | |||
41 | /* Serial Number Arithmetic, 32 bits, less than, RFC1982 */ | 63 | /* Serial Number Arithmetic, 32 bits, less than, RFC1982 */ |
42 | #define SNA32_CHECK 2147483648UL | 64 | #define SNA32_CHECK 2147483648UL |
43 | 65 | ||
@@ -176,10 +198,11 @@ static int iscsi_prep_ecdb_ahs(struct iscsi_task *task) | |||
176 | ecdb_ahdr->reserved = 0; | 198 | ecdb_ahdr->reserved = 0; |
177 | memcpy(ecdb_ahdr->ecdb, cmd->cmnd + ISCSI_CDB_SIZE, rlen); | 199 | memcpy(ecdb_ahdr->ecdb, cmd->cmnd + ISCSI_CDB_SIZE, rlen); |
178 | 200 | ||
179 | debug_scsi("iscsi_prep_ecdb_ahs: varlen_cdb_len %d " | 201 | ISCSI_DBG_SESSION(task->conn->session, |
180 | "rlen %d pad_len %d ahs_length %d iscsi_headers_size %u\n", | 202 | "iscsi_prep_ecdb_ahs: varlen_cdb_len %d " |
181 | cmd->cmd_len, rlen, pad_len, ahslength, task->hdr_len); | 203 | "rlen %d pad_len %d ahs_length %d iscsi_headers_size " |
182 | 204 | "%u\n", cmd->cmd_len, rlen, pad_len, ahslength, | |
205 | task->hdr_len); | ||
183 | return 0; | 206 | return 0; |
184 | } | 207 | } |
185 | 208 | ||
@@ -201,10 +224,11 @@ static int iscsi_prep_bidi_ahs(struct iscsi_task *task) | |||
201 | rlen_ahdr->reserved = 0; | 224 | rlen_ahdr->reserved = 0; |
202 | rlen_ahdr->read_length = cpu_to_be32(scsi_in(sc)->length); | 225 | rlen_ahdr->read_length = cpu_to_be32(scsi_in(sc)->length); |
203 | 226 | ||
204 | debug_scsi("bidi-in rlen_ahdr->read_length(%d) " | 227 | ISCSI_DBG_SESSION(task->conn->session, |
205 | "rlen_ahdr->ahslength(%d)\n", | 228 | "bidi-in rlen_ahdr->read_length(%d) " |
206 | be32_to_cpu(rlen_ahdr->read_length), | 229 | "rlen_ahdr->ahslength(%d)\n", |
207 | be16_to_cpu(rlen_ahdr->ahslength)); | 230 | be32_to_cpu(rlen_ahdr->read_length), |
231 | be16_to_cpu(rlen_ahdr->ahslength)); | ||
208 | return 0; | 232 | return 0; |
209 | } | 233 | } |
210 | 234 | ||
@@ -335,13 +359,15 @@ static int iscsi_prep_scsi_cmd_pdu(struct iscsi_task *task) | |||
335 | list_move_tail(&task->running, &conn->run_list); | 359 | list_move_tail(&task->running, &conn->run_list); |
336 | 360 | ||
337 | conn->scsicmd_pdus_cnt++; | 361 | conn->scsicmd_pdus_cnt++; |
338 | debug_scsi("iscsi prep [%s cid %d sc %p cdb 0x%x itt 0x%x len %d " | 362 | ISCSI_DBG_SESSION(session, "iscsi prep [%s cid %d sc %p cdb 0x%x " |
339 | "bidi_len %d cmdsn %d win %d]\n", scsi_bidi_cmnd(sc) ? | 363 | "itt 0x%x len %d bidi_len %d cmdsn %d win %d]\n", |
340 | "bidirectional" : sc->sc_data_direction == DMA_TO_DEVICE ? | 364 | scsi_bidi_cmnd(sc) ? "bidirectional" : |
341 | "write" : "read", conn->id, sc, sc->cmnd[0], task->itt, | 365 | sc->sc_data_direction == DMA_TO_DEVICE ? |
342 | scsi_bufflen(sc), | 366 | "write" : "read", conn->id, sc, sc->cmnd[0], |
343 | scsi_bidi_cmnd(sc) ? scsi_in(sc)->length : 0, | 367 | task->itt, scsi_bufflen(sc), |
344 | session->cmdsn, session->max_cmdsn - session->exp_cmdsn + 1); | 368 | scsi_bidi_cmnd(sc) ? scsi_in(sc)->length : 0, |
369 | session->cmdsn, | ||
370 | session->max_cmdsn - session->exp_cmdsn + 1); | ||
345 | return 0; | 371 | return 0; |
346 | } | 372 | } |
347 | 373 | ||
@@ -483,9 +509,9 @@ static int iscsi_prep_mgmt_task(struct iscsi_conn *conn, | |||
483 | 509 | ||
484 | task->state = ISCSI_TASK_RUNNING; | 510 | task->state = ISCSI_TASK_RUNNING; |
485 | list_move_tail(&task->running, &conn->mgmt_run_list); | 511 | list_move_tail(&task->running, &conn->mgmt_run_list); |
486 | debug_scsi("mgmtpdu [op 0x%x hdr->itt 0x%x datalen %d]\n", | 512 | ISCSI_DBG_SESSION(session, "mgmtpdu [op 0x%x hdr->itt 0x%x " |
487 | hdr->opcode & ISCSI_OPCODE_MASK, hdr->itt, | 513 | "datalen %d]\n", hdr->opcode & ISCSI_OPCODE_MASK, |
488 | task->data_count); | 514 | hdr->itt, task->data_count); |
489 | return 0; | 515 | return 0; |
490 | } | 516 | } |
491 | 517 | ||
@@ -637,8 +663,9 @@ invalid_datalen: | |||
637 | 663 | ||
638 | memcpy(sc->sense_buffer, data + 2, | 664 | memcpy(sc->sense_buffer, data + 2, |
639 | min_t(uint16_t, senselen, SCSI_SENSE_BUFFERSIZE)); | 665 | min_t(uint16_t, senselen, SCSI_SENSE_BUFFERSIZE)); |
640 | debug_scsi("copied %d bytes of sense\n", | 666 | ISCSI_DBG_SESSION(session, "copied %d bytes of sense\n", |
641 | min_t(uint16_t, senselen, SCSI_SENSE_BUFFERSIZE)); | 667 | min_t(uint16_t, senselen, |
668 | SCSI_SENSE_BUFFERSIZE)); | ||
642 | } | 669 | } |
643 | 670 | ||
644 | if (rhdr->flags & (ISCSI_FLAG_CMD_BIDI_UNDERFLOW | | 671 | if (rhdr->flags & (ISCSI_FLAG_CMD_BIDI_UNDERFLOW | |
@@ -666,8 +693,8 @@ invalid_datalen: | |||
666 | sc->result = (DID_BAD_TARGET << 16) | rhdr->cmd_status; | 693 | sc->result = (DID_BAD_TARGET << 16) | rhdr->cmd_status; |
667 | } | 694 | } |
668 | out: | 695 | out: |
669 | debug_scsi("done [sc %lx res %d itt 0x%x]\n", | 696 | ISCSI_DBG_SESSION(session, "done [sc %p res %d itt 0x%x]\n", |
670 | (long)sc, sc->result, task->itt); | 697 | sc, sc->result, task->itt); |
671 | conn->scsirsp_pdus_cnt++; | 698 | conn->scsirsp_pdus_cnt++; |
672 | 699 | ||
673 | __iscsi_put_task(task); | 700 | __iscsi_put_task(task); |
@@ -835,8 +862,8 @@ int __iscsi_complete_pdu(struct iscsi_conn *conn, struct iscsi_hdr *hdr, | |||
835 | else | 862 | else |
836 | itt = ~0U; | 863 | itt = ~0U; |
837 | 864 | ||
838 | debug_scsi("[op 0x%x cid %d itt 0x%x len %d]\n", | 865 | ISCSI_DBG_SESSION(session, "[op 0x%x cid %d itt 0x%x len %d]\n", |
839 | opcode, conn->id, itt, datalen); | 866 | opcode, conn->id, itt, datalen); |
840 | 867 | ||
841 | if (itt == ~0U) { | 868 | if (itt == ~0U) { |
842 | iscsi_update_cmdsn(session, (struct iscsi_nopin*)hdr); | 869 | iscsi_update_cmdsn(session, (struct iscsi_nopin*)hdr); |
@@ -1095,10 +1122,10 @@ static int iscsi_check_cmdsn_window_closed(struct iscsi_conn *conn) | |||
1095 | * Check for iSCSI window and take care of CmdSN wrap-around | 1122 | * Check for iSCSI window and take care of CmdSN wrap-around |
1096 | */ | 1123 | */ |
1097 | if (!iscsi_sna_lte(session->queued_cmdsn, session->max_cmdsn)) { | 1124 | if (!iscsi_sna_lte(session->queued_cmdsn, session->max_cmdsn)) { |
1098 | debug_scsi("iSCSI CmdSN closed. ExpCmdSn %u MaxCmdSN %u " | 1125 | ISCSI_DBG_SESSION(session, "iSCSI CmdSN closed. ExpCmdSn " |
1099 | "CmdSN %u/%u\n", session->exp_cmdsn, | 1126 | "%u MaxCmdSN %u CmdSN %u/%u\n", |
1100 | session->max_cmdsn, session->cmdsn, | 1127 | session->exp_cmdsn, session->max_cmdsn, |
1101 | session->queued_cmdsn); | 1128 | session->cmdsn, session->queued_cmdsn); |
1102 | return -ENOSPC; | 1129 | return -ENOSPC; |
1103 | } | 1130 | } |
1104 | return 0; | 1131 | return 0; |
@@ -1152,7 +1179,7 @@ static int iscsi_data_xmit(struct iscsi_conn *conn) | |||
1152 | 1179 | ||
1153 | spin_lock_bh(&conn->session->lock); | 1180 | spin_lock_bh(&conn->session->lock); |
1154 | if (unlikely(conn->suspend_tx)) { | 1181 | if (unlikely(conn->suspend_tx)) { |
1155 | debug_scsi("conn %d Tx suspended!\n", conn->id); | 1182 | ISCSI_DBG_SESSION(conn->session, "Tx suspended!\n"); |
1156 | spin_unlock_bh(&conn->session->lock); | 1183 | spin_unlock_bh(&conn->session->lock); |
1157 | return -ENODATA; | 1184 | return -ENODATA; |
1158 | } | 1185 | } |
@@ -1398,7 +1425,8 @@ prepd_reject: | |||
1398 | iscsi_complete_command(task); | 1425 | iscsi_complete_command(task); |
1399 | reject: | 1426 | reject: |
1400 | spin_unlock(&session->lock); | 1427 | spin_unlock(&session->lock); |
1401 | debug_scsi("cmd 0x%x rejected (%d)\n", sc->cmnd[0], reason); | 1428 | ISCSI_DBG_SESSION(session, "cmd 0x%x rejected (%d)\n", |
1429 | sc->cmnd[0], reason); | ||
1402 | spin_lock(host->host_lock); | 1430 | spin_lock(host->host_lock); |
1403 | return SCSI_MLQUEUE_TARGET_BUSY; | 1431 | return SCSI_MLQUEUE_TARGET_BUSY; |
1404 | 1432 | ||
@@ -1407,7 +1435,8 @@ prepd_fault: | |||
1407 | iscsi_complete_command(task); | 1435 | iscsi_complete_command(task); |
1408 | fault: | 1436 | fault: |
1409 | spin_unlock(&session->lock); | 1437 | spin_unlock(&session->lock); |
1410 | debug_scsi("iscsi: cmd 0x%x is not queued (%d)\n", sc->cmnd[0], reason); | 1438 | ISCSI_DBG_SESSION(session, "iscsi: cmd 0x%x is not queued (%d)\n", |
1439 | sc->cmnd[0], reason); | ||
1411 | if (!scsi_bidi_cmnd(sc)) | 1440 | if (!scsi_bidi_cmnd(sc)) |
1412 | scsi_set_resid(sc, scsi_bufflen(sc)); | 1441 | scsi_set_resid(sc, scsi_bufflen(sc)); |
1413 | else { | 1442 | else { |
@@ -1457,8 +1486,10 @@ int iscsi_eh_target_reset(struct scsi_cmnd *sc) | |||
1457 | spin_lock_bh(&session->lock); | 1486 | spin_lock_bh(&session->lock); |
1458 | if (session->state == ISCSI_STATE_TERMINATE) { | 1487 | if (session->state == ISCSI_STATE_TERMINATE) { |
1459 | failed: | 1488 | failed: |
1460 | debug_scsi("failing target reset: session terminated " | 1489 | iscsi_session_printk(KERN_INFO, session, |
1461 | "[CID %d age %d]\n", conn->id, session->age); | 1490 | "failing target reset: Could not log " |
1491 | "back into target [age %d]\n", | ||
1492 | session->age); | ||
1462 | spin_unlock_bh(&session->lock); | 1493 | spin_unlock_bh(&session->lock); |
1463 | mutex_unlock(&session->eh_mutex); | 1494 | mutex_unlock(&session->eh_mutex); |
1464 | return FAILED; | 1495 | return FAILED; |
@@ -1472,7 +1503,7 @@ failed: | |||
1472 | */ | 1503 | */ |
1473 | iscsi_conn_failure(conn, ISCSI_ERR_CONN_FAILED); | 1504 | iscsi_conn_failure(conn, ISCSI_ERR_CONN_FAILED); |
1474 | 1505 | ||
1475 | debug_scsi("iscsi_eh_target_reset wait for relogin\n"); | 1506 | ISCSI_DBG_SESSION(session, "wait for relogin\n"); |
1476 | wait_event_interruptible(conn->ehwait, | 1507 | wait_event_interruptible(conn->ehwait, |
1477 | session->state == ISCSI_STATE_TERMINATE || | 1508 | session->state == ISCSI_STATE_TERMINATE || |
1478 | session->state == ISCSI_STATE_LOGGED_IN || | 1509 | session->state == ISCSI_STATE_LOGGED_IN || |
@@ -1501,7 +1532,7 @@ static void iscsi_tmf_timedout(unsigned long data) | |||
1501 | spin_lock(&session->lock); | 1532 | spin_lock(&session->lock); |
1502 | if (conn->tmf_state == TMF_QUEUED) { | 1533 | if (conn->tmf_state == TMF_QUEUED) { |
1503 | conn->tmf_state = TMF_TIMEDOUT; | 1534 | conn->tmf_state = TMF_TIMEDOUT; |
1504 | debug_scsi("tmf timedout\n"); | 1535 | ISCSI_DBG_SESSION(session, "tmf timedout\n"); |
1505 | /* unblock eh_abort() */ | 1536 | /* unblock eh_abort() */ |
1506 | wake_up(&conn->ehwait); | 1537 | wake_up(&conn->ehwait); |
1507 | } | 1538 | } |
@@ -1521,7 +1552,7 @@ static int iscsi_exec_task_mgmt_fn(struct iscsi_conn *conn, | |||
1521 | spin_unlock_bh(&session->lock); | 1552 | spin_unlock_bh(&session->lock); |
1522 | iscsi_conn_failure(conn, ISCSI_ERR_CONN_FAILED); | 1553 | iscsi_conn_failure(conn, ISCSI_ERR_CONN_FAILED); |
1523 | spin_lock_bh(&session->lock); | 1554 | spin_lock_bh(&session->lock); |
1524 | debug_scsi("tmf exec failure\n"); | 1555 | ISCSI_DBG_SESSION(session, "tmf exec failure\n"); |
1525 | return -EPERM; | 1556 | return -EPERM; |
1526 | } | 1557 | } |
1527 | conn->tmfcmd_pdus_cnt++; | 1558 | conn->tmfcmd_pdus_cnt++; |
@@ -1529,7 +1560,7 @@ static int iscsi_exec_task_mgmt_fn(struct iscsi_conn *conn, | |||
1529 | conn->tmf_timer.function = iscsi_tmf_timedout; | 1560 | conn->tmf_timer.function = iscsi_tmf_timedout; |
1530 | conn->tmf_timer.data = (unsigned long)conn; | 1561 | conn->tmf_timer.data = (unsigned long)conn; |
1531 | add_timer(&conn->tmf_timer); | 1562 | add_timer(&conn->tmf_timer); |
1532 | debug_scsi("tmf set timeout\n"); | 1563 | ISCSI_DBG_SESSION(session, "tmf set timeout\n"); |
1533 | 1564 | ||
1534 | spin_unlock_bh(&session->lock); | 1565 | spin_unlock_bh(&session->lock); |
1535 | mutex_unlock(&session->eh_mutex); | 1566 | mutex_unlock(&session->eh_mutex); |
@@ -1573,16 +1604,18 @@ static void fail_all_commands(struct iscsi_conn *conn, unsigned lun, | |||
1573 | /* flush pending */ | 1604 | /* flush pending */ |
1574 | list_for_each_entry_safe(task, tmp, &conn->xmitqueue, running) { | 1605 | list_for_each_entry_safe(task, tmp, &conn->xmitqueue, running) { |
1575 | if (lun == task->sc->device->lun || lun == -1) { | 1606 | if (lun == task->sc->device->lun || lun == -1) { |
1576 | debug_scsi("failing pending sc %p itt 0x%x\n", | 1607 | ISCSI_DBG_SESSION(conn->session, |
1577 | task->sc, task->itt); | 1608 | "failing pending sc %p itt 0x%x\n", |
1609 | task->sc, task->itt); | ||
1578 | fail_command(conn, task, error << 16); | 1610 | fail_command(conn, task, error << 16); |
1579 | } | 1611 | } |
1580 | } | 1612 | } |
1581 | 1613 | ||
1582 | list_for_each_entry_safe(task, tmp, &conn->requeue, running) { | 1614 | list_for_each_entry_safe(task, tmp, &conn->requeue, running) { |
1583 | if (lun == task->sc->device->lun || lun == -1) { | 1615 | if (lun == task->sc->device->lun || lun == -1) { |
1584 | debug_scsi("failing requeued sc %p itt 0x%x\n", | 1616 | ISCSI_DBG_SESSION(conn->session, |
1585 | task->sc, task->itt); | 1617 | "failing requeued sc %p itt 0x%x\n", |
1618 | task->sc, task->itt); | ||
1586 | fail_command(conn, task, error << 16); | 1619 | fail_command(conn, task, error << 16); |
1587 | } | 1620 | } |
1588 | } | 1621 | } |
@@ -1590,8 +1623,9 @@ static void fail_all_commands(struct iscsi_conn *conn, unsigned lun, | |||
1590 | /* fail all other running */ | 1623 | /* fail all other running */ |
1591 | list_for_each_entry_safe(task, tmp, &conn->run_list, running) { | 1624 | list_for_each_entry_safe(task, tmp, &conn->run_list, running) { |
1592 | if (lun == task->sc->device->lun || lun == -1) { | 1625 | if (lun == task->sc->device->lun || lun == -1) { |
1593 | debug_scsi("failing in progress sc %p itt 0x%x\n", | 1626 | ISCSI_DBG_SESSION(conn->session, |
1594 | task->sc, task->itt); | 1627 | "failing in progress sc %p itt 0x%x\n", |
1628 | task->sc, task->itt); | ||
1595 | fail_command(conn, task, error << 16); | 1629 | fail_command(conn, task, error << 16); |
1596 | } | 1630 | } |
1597 | } | 1631 | } |
@@ -1622,7 +1656,7 @@ static enum blk_eh_timer_return iscsi_eh_cmd_timed_out(struct scsi_cmnd *scmd) | |||
1622 | cls_session = starget_to_session(scsi_target(scmd->device)); | 1656 | cls_session = starget_to_session(scsi_target(scmd->device)); |
1623 | session = cls_session->dd_data; | 1657 | session = cls_session->dd_data; |
1624 | 1658 | ||
1625 | debug_scsi("scsi cmd %p timedout\n", scmd); | 1659 | ISCSI_DBG_SESSION(session, "scsi cmd %p timedout\n", scmd); |
1626 | 1660 | ||
1627 | spin_lock(&session->lock); | 1661 | spin_lock(&session->lock); |
1628 | if (session->state != ISCSI_STATE_LOGGED_IN) { | 1662 | if (session->state != ISCSI_STATE_LOGGED_IN) { |
@@ -1662,8 +1696,8 @@ static enum blk_eh_timer_return iscsi_eh_cmd_timed_out(struct scsi_cmnd *scmd) | |||
1662 | rc = BLK_EH_RESET_TIMER; | 1696 | rc = BLK_EH_RESET_TIMER; |
1663 | done: | 1697 | done: |
1664 | spin_unlock(&session->lock); | 1698 | spin_unlock(&session->lock); |
1665 | debug_scsi("return %s\n", rc == BLK_EH_RESET_TIMER ? | 1699 | ISCSI_DBG_SESSION(session, "return %s\n", rc == BLK_EH_RESET_TIMER ? |
1666 | "timer reset" : "nh"); | 1700 | "timer reset" : "nh"); |
1667 | return rc; | 1701 | return rc; |
1668 | } | 1702 | } |
1669 | 1703 | ||
@@ -1697,13 +1731,13 @@ static void iscsi_check_transport_timeouts(unsigned long data) | |||
1697 | 1731 | ||
1698 | if (time_before_eq(last_recv + recv_timeout, jiffies)) { | 1732 | if (time_before_eq(last_recv + recv_timeout, jiffies)) { |
1699 | /* send a ping to try to provoke some traffic */ | 1733 | /* send a ping to try to provoke some traffic */ |
1700 | debug_scsi("Sending nopout as ping on conn %p\n", conn); | 1734 | ISCSI_DBG_CONN(conn, "Sending nopout as ping\n"); |
1701 | iscsi_send_nopout(conn, NULL); | 1735 | iscsi_send_nopout(conn, NULL); |
1702 | next_timeout = conn->last_ping + (conn->ping_timeout * HZ); | 1736 | next_timeout = conn->last_ping + (conn->ping_timeout * HZ); |
1703 | } else | 1737 | } else |
1704 | next_timeout = last_recv + recv_timeout; | 1738 | next_timeout = last_recv + recv_timeout; |
1705 | 1739 | ||
1706 | debug_scsi("Setting next tmo %lu\n", next_timeout); | 1740 | ISCSI_DBG_CONN(conn, "Setting next tmo %lu\n", next_timeout); |
1707 | mod_timer(&conn->transport_timer, next_timeout); | 1741 | mod_timer(&conn->transport_timer, next_timeout); |
1708 | done: | 1742 | done: |
1709 | spin_unlock(&session->lock); | 1743 | spin_unlock(&session->lock); |
@@ -1740,7 +1774,8 @@ int iscsi_eh_abort(struct scsi_cmnd *sc) | |||
1740 | * got the command. | 1774 | * got the command. |
1741 | */ | 1775 | */ |
1742 | if (!sc->SCp.ptr) { | 1776 | if (!sc->SCp.ptr) { |
1743 | debug_scsi("sc never reached iscsi layer or it completed.\n"); | 1777 | ISCSI_DBG_SESSION(session, "sc never reached iscsi layer or " |
1778 | "it completed.\n"); | ||
1744 | spin_unlock_bh(&session->lock); | 1779 | spin_unlock_bh(&session->lock); |
1745 | mutex_unlock(&session->eh_mutex); | 1780 | mutex_unlock(&session->eh_mutex); |
1746 | return SUCCESS; | 1781 | return SUCCESS; |
@@ -1762,11 +1797,13 @@ int iscsi_eh_abort(struct scsi_cmnd *sc) | |||
1762 | age = session->age; | 1797 | age = session->age; |
1763 | 1798 | ||
1764 | task = (struct iscsi_task *)sc->SCp.ptr; | 1799 | task = (struct iscsi_task *)sc->SCp.ptr; |
1765 | debug_scsi("aborting [sc %p itt 0x%x]\n", sc, task->itt); | 1800 | ISCSI_DBG_SESSION(session, "aborting [sc %p itt 0x%x]\n", |
1801 | sc, task->itt); | ||
1766 | 1802 | ||
1767 | /* task completed before time out */ | 1803 | /* task completed before time out */ |
1768 | if (!task->sc) { | 1804 | if (!task->sc) { |
1769 | debug_scsi("sc completed while abort in progress\n"); | 1805 | ISCSI_DBG_SESSION(session, "sc completed while abort in " |
1806 | "progress\n"); | ||
1770 | goto success; | 1807 | goto success; |
1771 | } | 1808 | } |
1772 | 1809 | ||
@@ -1815,7 +1852,8 @@ int iscsi_eh_abort(struct scsi_cmnd *sc) | |||
1815 | if (!sc->SCp.ptr) { | 1852 | if (!sc->SCp.ptr) { |
1816 | conn->tmf_state = TMF_INITIAL; | 1853 | conn->tmf_state = TMF_INITIAL; |
1817 | /* task completed before tmf abort response */ | 1854 | /* task completed before tmf abort response */ |
1818 | debug_scsi("sc completed while abort in progress\n"); | 1855 | ISCSI_DBG_SESSION(session, "sc completed while abort " |
1856 | "in progress\n"); | ||
1819 | goto success; | 1857 | goto success; |
1820 | } | 1858 | } |
1821 | /* fall through */ | 1859 | /* fall through */ |
@@ -1827,15 +1865,16 @@ int iscsi_eh_abort(struct scsi_cmnd *sc) | |||
1827 | success: | 1865 | success: |
1828 | spin_unlock_bh(&session->lock); | 1866 | spin_unlock_bh(&session->lock); |
1829 | success_unlocked: | 1867 | success_unlocked: |
1830 | debug_scsi("abort success [sc %lx itt 0x%x]\n", (long)sc, task->itt); | 1868 | ISCSI_DBG_SESSION(session, "abort success [sc %p itt 0x%x]\n", |
1869 | sc, task->itt); | ||
1831 | mutex_unlock(&session->eh_mutex); | 1870 | mutex_unlock(&session->eh_mutex); |
1832 | return SUCCESS; | 1871 | return SUCCESS; |
1833 | 1872 | ||
1834 | failed: | 1873 | failed: |
1835 | spin_unlock_bh(&session->lock); | 1874 | spin_unlock_bh(&session->lock); |
1836 | failed_unlocked: | 1875 | failed_unlocked: |
1837 | debug_scsi("abort failed [sc %p itt 0x%x]\n", sc, | 1876 | ISCSI_DBG_SESSION(session, "abort failed [sc %p itt 0x%x]\n", sc, |
1838 | task ? task->itt : 0); | 1877 | task ? task->itt : 0); |
1839 | mutex_unlock(&session->eh_mutex); | 1878 | mutex_unlock(&session->eh_mutex); |
1840 | return FAILED; | 1879 | return FAILED; |
1841 | } | 1880 | } |
@@ -1862,7 +1901,8 @@ int iscsi_eh_device_reset(struct scsi_cmnd *sc) | |||
1862 | cls_session = starget_to_session(scsi_target(sc->device)); | 1901 | cls_session = starget_to_session(scsi_target(sc->device)); |
1863 | session = cls_session->dd_data; | 1902 | session = cls_session->dd_data; |
1864 | 1903 | ||
1865 | debug_scsi("LU Reset [sc %p lun %u]\n", sc, sc->device->lun); | 1904 | ISCSI_DBG_SESSION(session, "LU Reset [sc %p lun %u]\n", |
1905 | sc, sc->device->lun); | ||
1866 | 1906 | ||
1867 | mutex_lock(&session->eh_mutex); | 1907 | mutex_lock(&session->eh_mutex); |
1868 | spin_lock_bh(&session->lock); | 1908 | spin_lock_bh(&session->lock); |
@@ -1916,8 +1956,8 @@ int iscsi_eh_device_reset(struct scsi_cmnd *sc) | |||
1916 | unlock: | 1956 | unlock: |
1917 | spin_unlock_bh(&session->lock); | 1957 | spin_unlock_bh(&session->lock); |
1918 | done: | 1958 | done: |
1919 | debug_scsi("iscsi_eh_device_reset %s\n", | 1959 | ISCSI_DBG_SESSION(session, "dev reset result = %s\n", |
1920 | rc == SUCCESS ? "SUCCESS" : "FAILED"); | 1960 | rc == SUCCESS ? "SUCCESS" : "FAILED"); |
1921 | mutex_unlock(&session->eh_mutex); | 1961 | mutex_unlock(&session->eh_mutex); |
1922 | return rc; | 1962 | return rc; |
1923 | } | 1963 | } |
@@ -2466,14 +2506,16 @@ flush_control_queues(struct iscsi_session *session, struct iscsi_conn *conn) | |||
2466 | 2506 | ||
2467 | /* handle pending */ | 2507 | /* handle pending */ |
2468 | list_for_each_entry_safe(task, tmp, &conn->mgmtqueue, running) { | 2508 | list_for_each_entry_safe(task, tmp, &conn->mgmtqueue, running) { |
2469 | debug_scsi("flushing pending mgmt task itt 0x%x\n", task->itt); | 2509 | ISCSI_DBG_SESSION(session, "flushing pending mgmt task " |
2510 | "itt 0x%x\n", task->itt); | ||
2470 | /* release ref from prep task */ | 2511 | /* release ref from prep task */ |
2471 | __iscsi_put_task(task); | 2512 | __iscsi_put_task(task); |
2472 | } | 2513 | } |
2473 | 2514 | ||
2474 | /* handle running */ | 2515 | /* handle running */ |
2475 | list_for_each_entry_safe(task, tmp, &conn->mgmt_run_list, running) { | 2516 | list_for_each_entry_safe(task, tmp, &conn->mgmt_run_list, running) { |
2476 | debug_scsi("flushing running mgmt task itt 0x%x\n", task->itt); | 2517 | ISCSI_DBG_SESSION(session, "flushing running mgmt task " |
2518 | "itt 0x%x\n", task->itt); | ||
2477 | /* release ref from prep task */ | 2519 | /* release ref from prep task */ |
2478 | __iscsi_put_task(task); | 2520 | __iscsi_put_task(task); |
2479 | } | 2521 | } |
@@ -2523,7 +2565,7 @@ static void iscsi_start_session_recovery(struct iscsi_session *session, | |||
2523 | conn->datadgst_en = 0; | 2565 | conn->datadgst_en = 0; |
2524 | if (session->state == ISCSI_STATE_IN_RECOVERY && | 2566 | if (session->state == ISCSI_STATE_IN_RECOVERY && |
2525 | old_stop_stage != STOP_CONN_RECOVER) { | 2567 | old_stop_stage != STOP_CONN_RECOVER) { |
2526 | debug_scsi("blocking session\n"); | 2568 | ISCSI_DBG_SESSION(session, "blocking session\n"); |
2527 | iscsi_block_session(session->cls_session); | 2569 | iscsi_block_session(session->cls_session); |
2528 | } | 2570 | } |
2529 | } | 2571 | } |
diff --git a/include/scsi/libiscsi.h b/include/scsi/libiscsi.h index 7360e1916e75..67542aa3aedc 100644 --- a/include/scsi/libiscsi.h +++ b/include/scsi/libiscsi.h | |||
@@ -45,13 +45,6 @@ struct iscsi_session; | |||
45 | struct iscsi_nopin; | 45 | struct iscsi_nopin; |
46 | struct device; | 46 | struct device; |
47 | 47 | ||
48 | /* #define DEBUG_SCSI */ | ||
49 | #ifdef DEBUG_SCSI | ||
50 | #define debug_scsi(fmt...) printk(KERN_INFO "iscsi: " fmt) | ||
51 | #else | ||
52 | #define debug_scsi(fmt...) | ||
53 | #endif | ||
54 | |||
55 | #define ISCSI_DEF_XMIT_CMDS_MAX 128 /* must be power of 2 */ | 48 | #define ISCSI_DEF_XMIT_CMDS_MAX 128 /* must be power of 2 */ |
56 | #define ISCSI_MGMT_CMDS_MAX 15 | 49 | #define ISCSI_MGMT_CMDS_MAX 15 |
57 | 50 | ||