Lines Matching refs:session

90 	struct Scsi_Host *shost = conn->session->host;  in iscsi_conn_queue_xmit()
100 struct Scsi_Host *shost = conn->session->host; in iscsi_conn_queue_recv()
108 static void __iscsi_update_cmdsn(struct iscsi_session *session, in __iscsi_update_cmdsn() argument
118 if (exp_cmdsn != session->exp_cmdsn && in __iscsi_update_cmdsn()
119 !iscsi_sna_lt(exp_cmdsn, session->exp_cmdsn)) in __iscsi_update_cmdsn()
120 session->exp_cmdsn = exp_cmdsn; in __iscsi_update_cmdsn()
122 if (max_cmdsn != session->max_cmdsn && in __iscsi_update_cmdsn()
123 !iscsi_sna_lt(max_cmdsn, session->max_cmdsn)) in __iscsi_update_cmdsn()
124 session->max_cmdsn = max_cmdsn; in __iscsi_update_cmdsn()
127 void iscsi_update_cmdsn(struct iscsi_session *session, struct iscsi_nopin *hdr) in iscsi_update_cmdsn() argument
129 __iscsi_update_cmdsn(session, be32_to_cpu(hdr->exp_cmdsn), in iscsi_update_cmdsn()
222 ISCSI_DBG_SESSION(task->conn->session, in iscsi_prep_ecdb_ahs()
245 struct iscsi_session *session = task->conn->session; in iscsi_check_tmf_restrictions() local
246 struct iscsi_tm *tmf = &session->tmhdr; in iscsi_check_tmf_restrictions()
249 if (session->tmf_state == TMF_INITIAL) in iscsi_check_tmf_restrictions()
269 iscsi_session_printk(KERN_INFO, session, in iscsi_check_tmf_restrictions()
278 if (session->fast_abort) { in iscsi_check_tmf_restrictions()
279 iscsi_session_printk(KERN_INFO, session, in iscsi_check_tmf_restrictions()
294 ISCSI_DBG_SESSION(session, in iscsi_check_tmf_restrictions()
317 struct iscsi_session *session = conn->session; in iscsi_prep_scsi_cmd_pdu() local
328 if (conn->session->tt->alloc_pdu) { in iscsi_prep_scsi_cmd_pdu()
329 rc = conn->session->tt->alloc_pdu(task, ISCSI_OP_SCSI_CMD); in iscsi_prep_scsi_cmd_pdu()
337 if (session->tt->parse_pdu_itt) in iscsi_prep_scsi_cmd_pdu()
341 task->conn->session->age); in iscsi_prep_scsi_cmd_pdu()
388 if (session->imm_data_en) { in iscsi_prep_scsi_cmd_pdu()
389 if (transfer_length >= session->first_burst) in iscsi_prep_scsi_cmd_pdu()
390 task->imm_count = min(session->first_burst, in iscsi_prep_scsi_cmd_pdu()
399 if (!session->initial_r2t_en) { in iscsi_prep_scsi_cmd_pdu()
400 r2t->data_length = min(session->first_burst, in iscsi_prep_scsi_cmd_pdu()
427 hdr->cmdsn = task->cmdsn = cpu_to_be32(session->cmdsn); in iscsi_prep_scsi_cmd_pdu()
429 if (session->tt->init_task && session->tt->init_task(task)) in iscsi_prep_scsi_cmd_pdu()
433 session->cmdsn++; in iscsi_prep_scsi_cmd_pdu()
436 ISCSI_DBG_SESSION(session, "iscsi prep [%s cid %d sc %p cdb 0x%x " in iscsi_prep_scsi_cmd_pdu()
441 session->cmdsn, in iscsi_prep_scsi_cmd_pdu()
442 session->max_cmdsn - session->exp_cmdsn + 1); in iscsi_prep_scsi_cmd_pdu()
457 struct iscsi_session *session = conn->session; in iscsi_free_task() local
461 ISCSI_DBG_SESSION(session, "freeing task itt 0x%x state %d sc %p\n", in iscsi_free_task()
464 session->tt->cleanup_task(task); in iscsi_free_task()
473 kfifo_in(&session->cmdpool.queue, (void*)&task, sizeof(void*)); in iscsi_free_task()
508 struct iscsi_session *session = task->conn->session; in iscsi_put_task() local
511 spin_lock_bh(&session->back_lock); in iscsi_put_task()
513 spin_unlock_bh(&session->back_lock); in iscsi_put_task()
529 ISCSI_DBG_SESSION(conn->session, in iscsi_complete_task()
563 ISCSI_DBG_SESSION(conn->session, "[itt 0x%x]\n", task->itt); in iscsi_complete_scsi_task()
566 __iscsi_update_cmdsn(conn->session, exp_cmdsn, max_cmdsn); in iscsi_complete_scsi_task()
598 if (conn->session->running_aborted_task == task) { in cleanup_queued_task()
599 conn->session->running_aborted_task = NULL; in cleanup_queued_task()
629 conn->session->queued_cmdsn--; in __fail_scsi_task()
645 struct iscsi_session *session = task->conn->session; in fail_scsi_task() local
647 spin_lock_bh(&session->back_lock); in fail_scsi_task()
649 spin_unlock_bh(&session->back_lock); in fail_scsi_task()
655 struct iscsi_session *session = conn->session; in iscsi_prep_mgmt_task() local
660 if (conn->session->state == ISCSI_STATE_LOGGING_OUT) in iscsi_prep_mgmt_task()
668 nop->cmdsn = cpu_to_be32(session->cmdsn); in iscsi_prep_mgmt_task()
680 session->queued_cmdsn++; in iscsi_prep_mgmt_task()
681 session->cmdsn++; in iscsi_prep_mgmt_task()
685 if (session->tt->init_task && session->tt->init_task(task)) in iscsi_prep_mgmt_task()
689 session->state = ISCSI_STATE_LOGGING_OUT; in iscsi_prep_mgmt_task()
692 ISCSI_DBG_SESSION(session, "mgmtpdu [op 0x%x hdr->itt 0x%x " in iscsi_prep_mgmt_task()
709 struct iscsi_session *session = conn->session; in iscsi_alloc_mgmt_task() local
714 if (session->state == ISCSI_STATE_TERMINATE || in iscsi_alloc_mgmt_task()
738 if (session->state != ISCSI_STATE_LOGGED_IN) in iscsi_alloc_mgmt_task()
749 if (!kfifo_out(&session->cmdpool.queue, in iscsi_alloc_mgmt_task()
770 if (conn->session->tt->alloc_pdu) { in iscsi_alloc_mgmt_task()
771 if (conn->session->tt->alloc_pdu(task, hdr->opcode)) { in iscsi_alloc_mgmt_task()
783 if (session->tt->parse_pdu_itt) in iscsi_alloc_mgmt_task()
787 task->conn->session->age); in iscsi_alloc_mgmt_task()
807 struct iscsi_session *session = conn->session; in iscsi_send_mgmt_task() local
808 struct iscsi_host *ihost = shost_priv(conn->session->host); in iscsi_send_mgmt_task()
816 rc = session->tt->xmit_task(task); in iscsi_send_mgmt_task()
847 struct iscsi_session *session = conn->session; in iscsi_conn_send_pdu() local
850 spin_lock_bh(&session->frwd_lock); in iscsi_conn_send_pdu()
853 spin_unlock_bh(&session->frwd_lock); in iscsi_conn_send_pdu()
874 struct iscsi_session *session = conn->session; in iscsi_scsi_cmd_rsp() local
877 iscsi_update_cmdsn(session, (struct iscsi_nopin*)rhdr); in iscsi_scsi_cmd_rsp()
891 BUG_ON(!session->tt->check_protection); in iscsi_scsi_cmd_rsp()
893 ascq = session->tt->check_protection(task, &sector); in iscsi_scsi_cmd_rsp()
926 ISCSI_DBG_SESSION(session, "copied %d bytes of sense\n", in iscsi_scsi_cmd_rsp()
949 ISCSI_DBG_SESSION(session, "cmd rsp done [sc %p res %d itt 0x%x]\n", in iscsi_scsi_cmd_rsp()
974 iscsi_update_cmdsn(conn->session, (struct iscsi_nopin *)hdr); in iscsi_data_in_rsp()
989 ISCSI_DBG_SESSION(conn->session, "data in with status done " in iscsi_data_in_rsp()
999 struct iscsi_session *session = conn->session; in iscsi_tmf_rsp() local
1004 if (session->tmf_state != TMF_QUEUED) in iscsi_tmf_rsp()
1008 session->tmf_state = TMF_SUCCESS; in iscsi_tmf_rsp()
1010 session->tmf_state = TMF_NOT_FOUND; in iscsi_tmf_rsp()
1012 session->tmf_state = TMF_FAILED; in iscsi_tmf_rsp()
1013 wake_up(&session->ehwait); in iscsi_tmf_rsp()
1138 spin_unlock(&conn->session->back_lock); in iscsi_handle_reject()
1139 spin_lock(&conn->session->frwd_lock); in iscsi_handle_reject()
1142 spin_unlock(&conn->session->frwd_lock); in iscsi_handle_reject()
1143 spin_lock(&conn->session->back_lock); in iscsi_handle_reject()
1184 struct iscsi_session *session = conn->session; in iscsi_itt_to_task() local
1190 if (session->tt->parse_pdu_itt) in iscsi_itt_to_task()
1191 session->tt->parse_pdu_itt(conn, itt, &i, NULL); in iscsi_itt_to_task()
1194 if (i >= session->cmds_max) in iscsi_itt_to_task()
1197 return session->cmds[i]; in iscsi_itt_to_task()
1215 struct iscsi_session *session = conn->session; in __iscsi_complete_pdu() local
1230 ISCSI_DBG_SESSION(session, "[op 0x%x cid %d itt 0x%x len %d]\n", in __iscsi_complete_pdu()
1234 iscsi_update_cmdsn(session, (struct iscsi_nopin*)hdr); in __iscsi_complete_pdu()
1247 spin_unlock(&session->back_lock); in __iscsi_complete_pdu()
1248 spin_lock(&session->frwd_lock); in __iscsi_complete_pdu()
1250 spin_unlock(&session->frwd_lock); in __iscsi_complete_pdu()
1251 spin_lock(&session->back_lock); in __iscsi_complete_pdu()
1302 iscsi_update_cmdsn(session, (struct iscsi_nopin*)hdr); in __iscsi_complete_pdu()
1311 iscsi_update_cmdsn(session, (struct iscsi_nopin*)hdr); in __iscsi_complete_pdu()
1318 iscsi_update_cmdsn(session, (struct iscsi_nopin*)hdr); in __iscsi_complete_pdu()
1328 iscsi_update_cmdsn(session, (struct iscsi_nopin*)hdr); in __iscsi_complete_pdu()
1358 spin_lock(&conn->session->back_lock); in iscsi_complete_pdu()
1360 spin_unlock(&conn->session->back_lock); in iscsi_complete_pdu()
1367 struct iscsi_session *session = conn->session; in iscsi_verify_itt() local
1373 if (session->tt->parse_pdu_itt) in iscsi_verify_itt()
1374 session->tt->parse_pdu_itt(conn, itt, &i, &age); in iscsi_verify_itt()
1380 if (age != session->age) { in iscsi_verify_itt()
1383 (__force u32)itt, session->age); in iscsi_verify_itt()
1387 if (i >= session->cmds_max) { in iscsi_verify_itt()
1390 "%u.\n", i, session->cmds_max); in iscsi_verify_itt()
1417 if (iscsi_cmd(task->sc)->age != conn->session->age) { in iscsi_itt_to_ctask()
1418 iscsi_session_printk(KERN_ERR, conn->session, in iscsi_itt_to_ctask()
1420 iscsi_cmd(task->sc)->age, conn->session->age); in iscsi_itt_to_ctask()
1428 void iscsi_session_failure(struct iscsi_session *session, in iscsi_session_failure() argument
1433 spin_lock_bh(&session->frwd_lock); in iscsi_session_failure()
1434 conn = session->leadconn; in iscsi_session_failure()
1435 if (session->state == ISCSI_STATE_TERMINATE || !conn) { in iscsi_session_failure()
1436 spin_unlock_bh(&session->frwd_lock); in iscsi_session_failure()
1441 spin_unlock_bh(&session->frwd_lock); in iscsi_session_failure()
1457 struct iscsi_session *session = conn->session; in iscsi_set_conn_failed() local
1459 if (session->state == ISCSI_STATE_FAILED) in iscsi_set_conn_failed()
1463 session->state = ISCSI_STATE_FAILED; in iscsi_set_conn_failed()
1472 struct iscsi_session *session = conn->session; in iscsi_conn_failure() local
1475 spin_lock_bh(&session->frwd_lock); in iscsi_conn_failure()
1477 spin_unlock_bh(&session->frwd_lock); in iscsi_conn_failure()
1486 struct iscsi_session *session = conn->session; in iscsi_check_cmdsn_window_closed() local
1491 if (!iscsi_sna_lte(session->queued_cmdsn, session->max_cmdsn)) { in iscsi_check_cmdsn_window_closed()
1492 ISCSI_DBG_SESSION(session, "iSCSI CmdSN closed. ExpCmdSn " in iscsi_check_cmdsn_window_closed()
1494 session->exp_cmdsn, session->max_cmdsn, in iscsi_check_cmdsn_window_closed()
1495 session->cmdsn, session->queued_cmdsn); in iscsi_check_cmdsn_window_closed()
1542 spin_unlock_bh(&conn->session->frwd_lock); in iscsi_xmit_task()
1543 rc = conn->session->tt->xmit_task(task); in iscsi_xmit_task()
1544 spin_lock_bh(&conn->session->frwd_lock); in iscsi_xmit_task()
1575 spin_lock_bh(&conn->session->frwd_lock); in iscsi_requeue_task()
1586 spin_unlock_bh(&conn->session->frwd_lock); in iscsi_requeue_task()
1604 spin_lock_bh(&conn->session->frwd_lock); in iscsi_data_xmit()
1606 ISCSI_DBG_SESSION(conn->session, "Tx suspended!\n"); in iscsi_data_xmit()
1607 spin_unlock_bh(&conn->session->frwd_lock); in iscsi_data_xmit()
1629 spin_lock_bh(&conn->session->back_lock); in iscsi_data_xmit()
1631 spin_unlock_bh(&conn->session->back_lock); in iscsi_data_xmit()
1644 if (conn->session->state == ISCSI_STATE_LOGGING_OUT) in iscsi_data_xmit()
1666 if (conn->session->state == ISCSI_STATE_LOGGING_OUT) { in iscsi_data_xmit()
1692 spin_unlock_bh(&conn->session->frwd_lock); in iscsi_data_xmit()
1696 spin_unlock_bh(&conn->session->frwd_lock); in iscsi_data_xmit()
1718 if (!kfifo_out(&conn->session->cmdpool.queue, in iscsi_alloc_task()
1722 iscsi_cmd(sc)->age = conn->session->age; in iscsi_alloc_task()
1755 struct iscsi_session *session; in iscsi_queuecommand() local
1765 session = cls_session->dd_data; in iscsi_queuecommand()
1766 spin_lock_bh(&session->frwd_lock); in iscsi_queuecommand()
1774 if (session->state != ISCSI_STATE_LOGGED_IN) { in iscsi_queuecommand()
1781 switch (session->state) { in iscsi_queuecommand()
1816 conn = session->leadconn; in iscsi_queuecommand()
1851 if (session->tt->xmit_task(task)) { in iscsi_queuecommand()
1852 session->cmdsn--; in iscsi_queuecommand()
1861 session->queued_cmdsn++; in iscsi_queuecommand()
1862 spin_unlock_bh(&session->frwd_lock); in iscsi_queuecommand()
1866 spin_lock_bh(&session->back_lock); in iscsi_queuecommand()
1868 spin_unlock_bh(&session->back_lock); in iscsi_queuecommand()
1870 spin_unlock_bh(&session->frwd_lock); in iscsi_queuecommand()
1871 ISCSI_DBG_SESSION(session, "cmd 0x%x rejected (%d)\n", in iscsi_queuecommand()
1876 spin_lock_bh(&session->back_lock); in iscsi_queuecommand()
1878 spin_unlock_bh(&session->back_lock); in iscsi_queuecommand()
1880 spin_unlock_bh(&session->frwd_lock); in iscsi_queuecommand()
1881 ISCSI_DBG_SESSION(session, "iscsi: cmd 0x%x is not queued (%d)\n", in iscsi_queuecommand()
1892 struct iscsi_session *session = cls_session->dd_data; in iscsi_target_alloc() local
1894 starget->can_queue = session->scsi_cmds_max; in iscsi_target_alloc()
1901 struct iscsi_session *session = timer_container_of(session, t, in iscsi_tmf_timedout() local
1904 spin_lock(&session->frwd_lock); in iscsi_tmf_timedout()
1905 if (session->tmf_state == TMF_QUEUED) { in iscsi_tmf_timedout()
1906 session->tmf_state = TMF_TIMEDOUT; in iscsi_tmf_timedout()
1907 ISCSI_DBG_EH(session, "tmf timedout\n"); in iscsi_tmf_timedout()
1909 wake_up(&session->ehwait); in iscsi_tmf_timedout()
1911 spin_unlock(&session->frwd_lock); in iscsi_tmf_timedout()
1917 __must_hold(&session->frwd_lock) in iscsi_exec_task_mgmt_fn()
1919 struct iscsi_session *session = conn->session; in iscsi_exec_task_mgmt_fn() local
1922 spin_unlock_bh(&session->frwd_lock); in iscsi_exec_task_mgmt_fn()
1925 spin_lock_bh(&session->frwd_lock); in iscsi_exec_task_mgmt_fn()
1929 session->tmf_timer.expires = timeout * HZ + jiffies; in iscsi_exec_task_mgmt_fn()
1930 add_timer(&session->tmf_timer); in iscsi_exec_task_mgmt_fn()
1931 ISCSI_DBG_EH(session, "tmf set timeout\n"); in iscsi_exec_task_mgmt_fn()
1933 spin_unlock_bh(&session->frwd_lock); in iscsi_exec_task_mgmt_fn()
1934 mutex_unlock(&session->eh_mutex); in iscsi_exec_task_mgmt_fn()
1944 wait_event_interruptible(session->ehwait, age != session->age || in iscsi_exec_task_mgmt_fn()
1945 session->state != ISCSI_STATE_LOGGED_IN || in iscsi_exec_task_mgmt_fn()
1946 session->tmf_state != TMF_QUEUED); in iscsi_exec_task_mgmt_fn()
1949 timer_delete_sync(&session->tmf_timer); in iscsi_exec_task_mgmt_fn()
1951 mutex_lock(&session->eh_mutex); in iscsi_exec_task_mgmt_fn()
1952 spin_lock_bh(&session->frwd_lock); in iscsi_exec_task_mgmt_fn()
1954 if (age != session->age || in iscsi_exec_task_mgmt_fn()
1955 session->state != ISCSI_STATE_LOGGED_IN) in iscsi_exec_task_mgmt_fn()
1965 struct iscsi_session *session = conn->session; in fail_scsi_tasks() local
1970 spin_lock_bh(&session->back_lock); in fail_scsi_tasks()
1971 for (i = 0; i < session->cmds_max; i++) { in fail_scsi_tasks()
1972 task = session->cmds[i]; in fail_scsi_tasks()
1984 spin_unlock_bh(&session->back_lock); in fail_scsi_tasks()
1985 spin_unlock_bh(&session->frwd_lock); in fail_scsi_tasks()
1987 spin_lock_bh(&session->frwd_lock); in fail_scsi_tasks()
1991 ISCSI_DBG_SESSION(session, in fail_scsi_tasks()
1997 spin_unlock_bh(&session->back_lock); in fail_scsi_tasks()
2013 spin_lock_bh(&conn->session->frwd_lock); in iscsi_suspend_queue()
2015 spin_unlock_bh(&conn->session->frwd_lock); in iscsi_suspend_queue()
2029 struct Scsi_Host *shost = conn->session->host; in iscsi_suspend_tx()
2050 struct Scsi_Host *shost = conn->session->host; in iscsi_suspend_rx()
2080 struct iscsi_session *session; in iscsi_eh_cmd_timed_out() local
2085 session = cls_session->dd_data; in iscsi_eh_cmd_timed_out()
2087 ISCSI_DBG_EH(session, "scsi cmd %p timedout\n", sc); in iscsi_eh_cmd_timed_out()
2089 spin_lock_bh(&session->frwd_lock); in iscsi_eh_cmd_timed_out()
2090 spin_lock(&session->back_lock); in iscsi_eh_cmd_timed_out()
2098 spin_unlock(&session->back_lock); in iscsi_eh_cmd_timed_out()
2108 spin_unlock(&session->back_lock); in iscsi_eh_cmd_timed_out()
2111 spin_unlock(&session->back_lock); in iscsi_eh_cmd_timed_out()
2113 if (session->state != ISCSI_STATE_LOGGED_IN) { in iscsi_eh_cmd_timed_out()
2123 ISCSI_DBG_EH(session, "sc on shutdown, handled\n"); in iscsi_eh_cmd_timed_out()
2135 conn = session->leadconn; in iscsi_eh_cmd_timed_out()
2150 ISCSI_DBG_EH(session, "Command making progress. Asking " in iscsi_eh_cmd_timed_out()
2170 spin_lock(&session->back_lock); in iscsi_eh_cmd_timed_out()
2171 for (i = 0; i < conn->session->cmds_max; i++) { in iscsi_eh_cmd_timed_out()
2172 running_task = conn->session->cmds[i]; in iscsi_eh_cmd_timed_out()
2196 ISCSI_DBG_EH(session, "Command has not made progress " in iscsi_eh_cmd_timed_out()
2203 spin_unlock(&session->back_lock); in iscsi_eh_cmd_timed_out()
2208 spin_unlock(&session->back_lock); in iscsi_eh_cmd_timed_out()
2230 spin_unlock_bh(&session->frwd_lock); in iscsi_eh_cmd_timed_out()
2236 ISCSI_DBG_EH(session, "return %s\n", rc == SCSI_EH_RESET_TIMER ? in iscsi_eh_cmd_timed_out()
2245 struct iscsi_session *session = conn->session; in iscsi_check_transport_timeouts() local
2248 spin_lock(&session->frwd_lock); in iscsi_check_transport_timeouts()
2249 if (session->state != ISCSI_STATE_LOGGED_IN) in iscsi_check_transport_timeouts()
2265 spin_unlock(&session->frwd_lock); in iscsi_check_transport_timeouts()
2283 spin_unlock(&session->frwd_lock); in iscsi_check_transport_timeouts()
2297 struct iscsi_session *session; in iscsi_conn_unbind() local
2304 session = conn->session; in iscsi_conn_unbind()
2311 mutex_lock(&session->eh_mutex); in iscsi_conn_unbind()
2316 spin_lock_bh(&session->frwd_lock); in iscsi_conn_unbind()
2325 if (session->state == ISCSI_STATE_LOGGED_IN) in iscsi_conn_unbind()
2328 spin_unlock_bh(&session->frwd_lock); in iscsi_conn_unbind()
2329 mutex_unlock(&session->eh_mutex); in iscsi_conn_unbind()
2348 struct iscsi_session *session; in iscsi_eh_abort() local
2355 session = cls_session->dd_data; in iscsi_eh_abort()
2357 ISCSI_DBG_EH(session, "aborting sc %p\n", sc); in iscsi_eh_abort()
2360 mutex_lock(&session->eh_mutex); in iscsi_eh_abort()
2361 spin_lock_bh(&session->frwd_lock); in iscsi_eh_abort()
2367 ISCSI_DBG_EH(session, "sc never reached iscsi layer or " in iscsi_eh_abort()
2369 spin_unlock_bh(&session->frwd_lock); in iscsi_eh_abort()
2370 mutex_unlock(&session->eh_mutex); in iscsi_eh_abort()
2378 if (!session->leadconn || session->state != ISCSI_STATE_LOGGED_IN || in iscsi_eh_abort()
2379 iscsi_cmd(sc)->age != session->age) { in iscsi_eh_abort()
2380 spin_unlock_bh(&session->frwd_lock); in iscsi_eh_abort()
2381 mutex_unlock(&session->eh_mutex); in iscsi_eh_abort()
2382 ISCSI_DBG_EH(session, "failing abort due to dropped " in iscsi_eh_abort()
2387 spin_lock(&session->back_lock); in iscsi_eh_abort()
2391 ISCSI_DBG_EH(session, "sc completed while abort in progress\n"); in iscsi_eh_abort()
2393 spin_unlock(&session->back_lock); in iscsi_eh_abort()
2394 spin_unlock_bh(&session->frwd_lock); in iscsi_eh_abort()
2395 mutex_unlock(&session->eh_mutex); in iscsi_eh_abort()
2400 spin_unlock(&session->back_lock); in iscsi_eh_abort()
2401 spin_unlock_bh(&session->frwd_lock); in iscsi_eh_abort()
2402 mutex_unlock(&session->eh_mutex); in iscsi_eh_abort()
2408 ISCSI_DBG_EH(session, "aborting [sc %p itt 0x%x]\n", sc, task->itt); in iscsi_eh_abort()
2409 conn = session->leadconn; in iscsi_eh_abort()
2412 age = session->age; in iscsi_eh_abort()
2413 spin_unlock(&session->back_lock); in iscsi_eh_abort()
2421 if (session->tmf_state != TMF_INITIAL) in iscsi_eh_abort()
2423 session->tmf_state = TMF_QUEUED; in iscsi_eh_abort()
2425 hdr = &session->tmhdr; in iscsi_eh_abort()
2428 if (iscsi_exec_task_mgmt_fn(conn, hdr, age, session->abort_timeout)) in iscsi_eh_abort()
2431 switch (session->tmf_state) { in iscsi_eh_abort()
2433 spin_unlock_bh(&session->frwd_lock); in iscsi_eh_abort()
2444 spin_lock_bh(&session->frwd_lock); in iscsi_eh_abort()
2446 session->tmf_state = TMF_INITIAL; in iscsi_eh_abort()
2448 spin_unlock_bh(&session->frwd_lock); in iscsi_eh_abort()
2452 session->running_aborted_task = task; in iscsi_eh_abort()
2453 spin_unlock_bh(&session->frwd_lock); in iscsi_eh_abort()
2458 session->tmf_state = TMF_INITIAL; in iscsi_eh_abort()
2461 ISCSI_DBG_EH(session, "sc completed while abort in " in iscsi_eh_abort()
2467 session->tmf_state = TMF_INITIAL; in iscsi_eh_abort()
2472 spin_unlock_bh(&session->frwd_lock); in iscsi_eh_abort()
2474 ISCSI_DBG_EH(session, "abort success [sc %p itt 0x%x]\n", in iscsi_eh_abort()
2478 mutex_unlock(&session->eh_mutex); in iscsi_eh_abort()
2482 spin_unlock_bh(&session->frwd_lock); in iscsi_eh_abort()
2484 ISCSI_DBG_EH(session, "abort failed [sc %p itt 0x%x]\n", sc, in iscsi_eh_abort()
2491 if (!session->running_aborted_task) in iscsi_eh_abort()
2495 mutex_unlock(&session->eh_mutex); in iscsi_eh_abort()
2513 struct iscsi_session *session; in iscsi_eh_device_reset() local
2519 session = cls_session->dd_data; in iscsi_eh_device_reset()
2521 ISCSI_DBG_EH(session, "LU Reset [sc %p lun %llu]\n", sc, in iscsi_eh_device_reset()
2524 mutex_lock(&session->eh_mutex); in iscsi_eh_device_reset()
2525 spin_lock_bh(&session->frwd_lock); in iscsi_eh_device_reset()
2530 if (!session->leadconn || session->state != ISCSI_STATE_LOGGED_IN) in iscsi_eh_device_reset()
2532 conn = session->leadconn; in iscsi_eh_device_reset()
2535 if (session->tmf_state != TMF_INITIAL) in iscsi_eh_device_reset()
2537 session->tmf_state = TMF_QUEUED; in iscsi_eh_device_reset()
2539 hdr = &session->tmhdr; in iscsi_eh_device_reset()
2542 if (iscsi_exec_task_mgmt_fn(conn, hdr, session->age, in iscsi_eh_device_reset()
2543 session->lu_reset_timeout)) { in iscsi_eh_device_reset()
2548 switch (session->tmf_state) { in iscsi_eh_device_reset()
2552 spin_unlock_bh(&session->frwd_lock); in iscsi_eh_device_reset()
2556 session->tmf_state = TMF_INITIAL; in iscsi_eh_device_reset()
2561 spin_unlock_bh(&session->frwd_lock); in iscsi_eh_device_reset()
2565 spin_lock_bh(&session->frwd_lock); in iscsi_eh_device_reset()
2568 session->tmf_state = TMF_INITIAL; in iscsi_eh_device_reset()
2569 spin_unlock_bh(&session->frwd_lock); in iscsi_eh_device_reset()
2575 spin_unlock_bh(&session->frwd_lock); in iscsi_eh_device_reset()
2577 ISCSI_DBG_EH(session, "dev reset result = %s\n", in iscsi_eh_device_reset()
2579 mutex_unlock(&session->eh_mutex); in iscsi_eh_device_reset()
2586 struct iscsi_session *session = cls_session->dd_data; in iscsi_session_recovery_timedout() local
2588 spin_lock_bh(&session->frwd_lock); in iscsi_session_recovery_timedout()
2589 if (session->state != ISCSI_STATE_LOGGED_IN) { in iscsi_session_recovery_timedout()
2590 session->state = ISCSI_STATE_RECOVERY_FAILED; in iscsi_session_recovery_timedout()
2591 wake_up(&session->ehwait); in iscsi_session_recovery_timedout()
2593 spin_unlock_bh(&session->frwd_lock); in iscsi_session_recovery_timedout()
2607 struct iscsi_session *session; in iscsi_eh_session_reset() local
2611 session = cls_session->dd_data; in iscsi_eh_session_reset()
2613 mutex_lock(&session->eh_mutex); in iscsi_eh_session_reset()
2614 spin_lock_bh(&session->frwd_lock); in iscsi_eh_session_reset()
2615 if (session->state == ISCSI_STATE_TERMINATE) { in iscsi_eh_session_reset()
2617 ISCSI_DBG_EH(session, in iscsi_eh_session_reset()
2619 "%s [age %d]\n", session->targetname, in iscsi_eh_session_reset()
2620 session->age); in iscsi_eh_session_reset()
2621 spin_unlock_bh(&session->frwd_lock); in iscsi_eh_session_reset()
2622 mutex_unlock(&session->eh_mutex); in iscsi_eh_session_reset()
2626 conn = session->leadconn; in iscsi_eh_session_reset()
2629 spin_unlock_bh(&session->frwd_lock); in iscsi_eh_session_reset()
2630 mutex_unlock(&session->eh_mutex); in iscsi_eh_session_reset()
2635 ISCSI_DBG_EH(session, "wait for relogin\n"); in iscsi_eh_session_reset()
2636 wait_event_interruptible(session->ehwait, in iscsi_eh_session_reset()
2637 session->state == ISCSI_STATE_TERMINATE || in iscsi_eh_session_reset()
2638 session->state == ISCSI_STATE_LOGGED_IN || in iscsi_eh_session_reset()
2639 session->state == ISCSI_STATE_RECOVERY_FAILED); in iscsi_eh_session_reset()
2643 mutex_lock(&session->eh_mutex); in iscsi_eh_session_reset()
2644 spin_lock_bh(&session->frwd_lock); in iscsi_eh_session_reset()
2645 if (session->state == ISCSI_STATE_LOGGED_IN) { in iscsi_eh_session_reset()
2646 ISCSI_DBG_EH(session, in iscsi_eh_session_reset()
2648 session->targetname, conn->persistent_address); in iscsi_eh_session_reset()
2651 spin_unlock_bh(&session->frwd_lock); in iscsi_eh_session_reset()
2652 mutex_unlock(&session->eh_mutex); in iscsi_eh_session_reset()
2675 struct iscsi_session *session; in iscsi_eh_target_reset() local
2681 session = cls_session->dd_data; in iscsi_eh_target_reset()
2683 ISCSI_DBG_EH(session, "tgt Reset [sc %p tgt %s]\n", sc, in iscsi_eh_target_reset()
2684 session->targetname); in iscsi_eh_target_reset()
2686 mutex_lock(&session->eh_mutex); in iscsi_eh_target_reset()
2687 spin_lock_bh(&session->frwd_lock); in iscsi_eh_target_reset()
2692 if (!session->leadconn || session->state != ISCSI_STATE_LOGGED_IN) in iscsi_eh_target_reset()
2694 conn = session->leadconn; in iscsi_eh_target_reset()
2697 if (session->tmf_state != TMF_INITIAL) in iscsi_eh_target_reset()
2699 session->tmf_state = TMF_QUEUED; in iscsi_eh_target_reset()
2701 hdr = &session->tmhdr; in iscsi_eh_target_reset()
2704 if (iscsi_exec_task_mgmt_fn(conn, hdr, session->age, in iscsi_eh_target_reset()
2705 session->tgt_reset_timeout)) { in iscsi_eh_target_reset()
2710 switch (session->tmf_state) { in iscsi_eh_target_reset()
2714 spin_unlock_bh(&session->frwd_lock); in iscsi_eh_target_reset()
2718 session->tmf_state = TMF_INITIAL; in iscsi_eh_target_reset()
2723 spin_unlock_bh(&session->frwd_lock); in iscsi_eh_target_reset()
2727 spin_lock_bh(&session->frwd_lock); in iscsi_eh_target_reset()
2730 session->tmf_state = TMF_INITIAL; in iscsi_eh_target_reset()
2731 spin_unlock_bh(&session->frwd_lock); in iscsi_eh_target_reset()
2737 spin_unlock_bh(&session->frwd_lock); in iscsi_eh_target_reset()
2739 ISCSI_DBG_EH(session, "tgt %s reset result = %s\n", session->targetname, in iscsi_eh_target_reset()
2741 mutex_unlock(&session->eh_mutex); in iscsi_eh_target_reset()
3024 struct iscsi_session *session; in iscsi_session_setup() local
3046 session = cls_session->dd_data; in iscsi_session_setup()
3047 session->cls_session = cls_session; in iscsi_session_setup()
3048 session->host = shost; in iscsi_session_setup()
3049 session->state = ISCSI_STATE_FREE; in iscsi_session_setup()
3050 session->fast_abort = 1; in iscsi_session_setup()
3051 session->tgt_reset_timeout = 30; in iscsi_session_setup()
3052 session->lu_reset_timeout = 15; in iscsi_session_setup()
3053 session->abort_timeout = 10; in iscsi_session_setup()
3054 session->scsi_cmds_max = scsi_cmds; in iscsi_session_setup()
3055 session->cmds_max = scsi_cmds + ISCSI_MGMT_CMDS_MAX; in iscsi_session_setup()
3056 session->queued_cmdsn = session->cmdsn = initial_cmdsn; in iscsi_session_setup()
3057 session->exp_cmdsn = initial_cmdsn + 1; in iscsi_session_setup()
3058 session->max_cmdsn = initial_cmdsn + 1; in iscsi_session_setup()
3059 session->max_r2t = 1; in iscsi_session_setup()
3060 session->tt = iscsit; in iscsi_session_setup()
3061 session->dd_data = cls_session->dd_data + sizeof(*session); in iscsi_session_setup()
3063 session->tmf_state = TMF_INITIAL; in iscsi_session_setup()
3064 timer_setup(&session->tmf_timer, iscsi_tmf_timedout, 0); in iscsi_session_setup()
3065 mutex_init(&session->eh_mutex); in iscsi_session_setup()
3066 init_waitqueue_head(&session->ehwait); in iscsi_session_setup()
3068 spin_lock_init(&session->frwd_lock); in iscsi_session_setup()
3069 spin_lock_init(&session->back_lock); in iscsi_session_setup()
3072 if (iscsi_pool_init(&session->cmdpool, session->cmds_max, in iscsi_session_setup()
3073 (void***)&session->cmds, in iscsi_session_setup()
3078 for (cmd_i = 0; cmd_i < session->cmds_max; cmd_i++) { in iscsi_session_setup()
3079 struct iscsi_task *task = session->cmds[cmd_i]; in iscsi_session_setup()
3099 iscsi_pool_free(&session->cmdpool); in iscsi_session_setup()
3113 struct iscsi_session *session = cls_session->dd_data; in iscsi_session_remove() local
3114 struct Scsi_Host *shost = session->host; in iscsi_session_remove()
3132 struct iscsi_session *session = cls_session->dd_data; in iscsi_session_free() local
3135 iscsi_pool_free(&session->cmdpool); in iscsi_session_free()
3136 kfree(session->password); in iscsi_session_free()
3137 kfree(session->password_in); in iscsi_session_free()
3138 kfree(session->username); in iscsi_session_free()
3139 kfree(session->username_in); in iscsi_session_free()
3140 kfree(session->targetname); in iscsi_session_free()
3141 kfree(session->targetalias); in iscsi_session_free()
3142 kfree(session->initiatorname); in iscsi_session_free()
3143 kfree(session->boot_root); in iscsi_session_free()
3144 kfree(session->boot_nic); in iscsi_session_free()
3145 kfree(session->boot_target); in iscsi_session_free()
3146 kfree(session->ifacename); in iscsi_session_free()
3147 kfree(session->portal_type); in iscsi_session_free()
3148 kfree(session->discovery_parent_type); in iscsi_session_free()
3176 struct iscsi_session *session = cls_session->dd_data; in iscsi_conn_setup() local
3190 conn->session = session; in iscsi_conn_setup()
3204 spin_lock_bh(&session->frwd_lock); in iscsi_conn_setup()
3205 if (!kfifo_out(&session->cmdpool.queue, in iscsi_conn_setup()
3208 spin_unlock_bh(&session->frwd_lock); in iscsi_conn_setup()
3211 spin_unlock_bh(&session->frwd_lock); in iscsi_conn_setup()
3230 kfifo_in(&session->cmdpool.queue, (void*)&conn->login_task, in iscsi_conn_setup()
3248 struct iscsi_session *session = conn->session; in iscsi_conn_teardown() local
3254 mutex_lock(&session->eh_mutex); in iscsi_conn_teardown()
3255 spin_lock_bh(&session->frwd_lock); in iscsi_conn_teardown()
3257 if (session->leadconn == conn) { in iscsi_conn_teardown()
3261 session->state = ISCSI_STATE_TERMINATE; in iscsi_conn_teardown()
3262 wake_up(&session->ehwait); in iscsi_conn_teardown()
3264 spin_unlock_bh(&session->frwd_lock); in iscsi_conn_teardown()
3269 spin_lock_bh(&session->frwd_lock); in iscsi_conn_teardown()
3275 spin_lock_bh(&session->back_lock); in iscsi_conn_teardown()
3276 kfifo_in(&session->cmdpool.queue, (void*)&conn->login_task, in iscsi_conn_teardown()
3278 spin_unlock_bh(&session->back_lock); in iscsi_conn_teardown()
3279 if (session->leadconn == conn) in iscsi_conn_teardown()
3280 session->leadconn = NULL; in iscsi_conn_teardown()
3281 spin_unlock_bh(&session->frwd_lock); in iscsi_conn_teardown()
3282 mutex_unlock(&session->eh_mutex); in iscsi_conn_teardown()
3291 struct iscsi_session *session = conn->session; in iscsi_conn_start() local
3293 if (!session) { in iscsi_conn_start()
3299 if ((session->imm_data_en || !session->initial_r2t_en) && in iscsi_conn_start()
3300 session->first_burst > session->max_burst) { in iscsi_conn_start()
3303 session->first_burst, session->max_burst); in iscsi_conn_start()
3319 spin_lock_bh(&session->frwd_lock); in iscsi_conn_start()
3321 session->state = ISCSI_STATE_LOGGED_IN; in iscsi_conn_start()
3322 session->queued_cmdsn = session->cmdsn; in iscsi_conn_start()
3337 session->tmf_state = TMF_INITIAL; in iscsi_conn_start()
3338 session->age++; in iscsi_conn_start()
3339 if (session->age == 16) in iscsi_conn_start()
3340 session->age = 0; in iscsi_conn_start()
3348 spin_unlock_bh(&session->frwd_lock); in iscsi_conn_start()
3350 iscsi_unblock_session(session->cls_session); in iscsi_conn_start()
3351 wake_up(&session->ehwait); in iscsi_conn_start()
3357 fail_mgmt_tasks(struct iscsi_session *session, struct iscsi_conn *conn) in fail_mgmt_tasks() argument
3362 for (i = 0; i < conn->session->cmds_max; i++) { in fail_mgmt_tasks()
3363 task = conn->session->cmds[i]; in fail_mgmt_tasks()
3370 ISCSI_DBG_SESSION(conn->session, in fail_mgmt_tasks()
3374 spin_lock_bh(&session->back_lock); in fail_mgmt_tasks()
3376 spin_unlock_bh(&session->back_lock); in fail_mgmt_tasks()
3384 spin_unlock_bh(&session->back_lock); in fail_mgmt_tasks()
3391 struct iscsi_session *session = conn->session; in iscsi_conn_stop() local
3394 mutex_lock(&session->eh_mutex); in iscsi_conn_stop()
3395 spin_lock_bh(&session->frwd_lock); in iscsi_conn_stop()
3397 spin_unlock_bh(&session->frwd_lock); in iscsi_conn_stop()
3398 mutex_unlock(&session->eh_mutex); in iscsi_conn_stop()
3408 session->state = ISCSI_STATE_TERMINATE; in iscsi_conn_stop()
3410 session->state = ISCSI_STATE_IN_RECOVERY; in iscsi_conn_stop()
3414 spin_unlock_bh(&session->frwd_lock); in iscsi_conn_stop()
3419 spin_lock_bh(&session->frwd_lock); in iscsi_conn_stop()
3421 spin_unlock_bh(&session->frwd_lock); in iscsi_conn_stop()
3432 if (session->state == ISCSI_STATE_IN_RECOVERY && in iscsi_conn_stop()
3434 ISCSI_DBG_SESSION(session, "blocking session\n"); in iscsi_conn_stop()
3435 iscsi_block_session(session->cls_session); in iscsi_conn_stop()
3442 spin_lock_bh(&session->frwd_lock); in iscsi_conn_stop()
3444 fail_mgmt_tasks(session, conn); in iscsi_conn_stop()
3445 memset(&session->tmhdr, 0, sizeof(session->tmhdr)); in iscsi_conn_stop()
3446 spin_unlock_bh(&session->frwd_lock); in iscsi_conn_stop()
3447 mutex_unlock(&session->eh_mutex); in iscsi_conn_stop()
3454 struct iscsi_session *session = cls_session->dd_data; in iscsi_conn_bind() local
3457 spin_lock_bh(&session->frwd_lock); in iscsi_conn_bind()
3459 session->leadconn = conn; in iscsi_conn_bind()
3462 spin_unlock_bh(&session->frwd_lock); in iscsi_conn_bind()
3468 spin_lock_bh(&session->back_lock); in iscsi_conn_bind()
3469 session->max_cmdsn = session->exp_cmdsn = session->cmdsn + 1; in iscsi_conn_bind()
3470 spin_unlock_bh(&session->back_lock); in iscsi_conn_bind()
3503 struct iscsi_session *session = conn->session; in iscsi_set_param() local
3508 sscanf(buf, "%d", &session->fast_abort); in iscsi_set_param()
3511 sscanf(buf, "%d", &session->abort_timeout); in iscsi_set_param()
3514 sscanf(buf, "%d", &session->lu_reset_timeout); in iscsi_set_param()
3517 sscanf(buf, "%d", &session->tgt_reset_timeout); in iscsi_set_param()
3538 sscanf(buf, "%d", &session->initial_r2t_en); in iscsi_set_param()
3541 sscanf(buf, "%hu", &session->max_r2t); in iscsi_set_param()
3544 sscanf(buf, "%d", &session->imm_data_en); in iscsi_set_param()
3547 sscanf(buf, "%d", &session->first_burst); in iscsi_set_param()
3550 sscanf(buf, "%d", &session->max_burst); in iscsi_set_param()
3553 sscanf(buf, "%d", &session->pdu_inorder_en); in iscsi_set_param()
3556 sscanf(buf, "%d", &session->dataseq_inorder_en); in iscsi_set_param()
3559 sscanf(buf, "%d", &session->erl); in iscsi_set_param()
3565 return iscsi_switch_str_param(&session->username, buf); in iscsi_set_param()
3567 return iscsi_switch_str_param(&session->username_in, buf); in iscsi_set_param()
3569 return iscsi_switch_str_param(&session->password, buf); in iscsi_set_param()
3571 return iscsi_switch_str_param(&session->password_in, buf); in iscsi_set_param()
3573 return iscsi_switch_str_param(&session->targetname, buf); in iscsi_set_param()
3575 return iscsi_switch_str_param(&session->targetalias, buf); in iscsi_set_param()
3577 sscanf(buf, "%d", &session->tpgt); in iscsi_set_param()
3585 return iscsi_switch_str_param(&session->ifacename, buf); in iscsi_set_param()
3587 return iscsi_switch_str_param(&session->initiatorname, buf); in iscsi_set_param()
3589 return iscsi_switch_str_param(&session->boot_root, buf); in iscsi_set_param()
3591 return iscsi_switch_str_param(&session->boot_nic, buf); in iscsi_set_param()
3593 return iscsi_switch_str_param(&session->boot_target, buf); in iscsi_set_param()
3595 return iscsi_switch_str_param(&session->portal_type, buf); in iscsi_set_param()
3597 return iscsi_switch_str_param(&session->discovery_parent_type, in iscsi_set_param()
3601 session->discovery_sess = !!val; in iscsi_set_param()
3616 struct iscsi_session *session = cls_session->dd_data; in iscsi_session_get_param() local
3621 len = sysfs_emit(buf, "%d\n", session->fast_abort); in iscsi_session_get_param()
3624 len = sysfs_emit(buf, "%d\n", session->abort_timeout); in iscsi_session_get_param()
3627 len = sysfs_emit(buf, "%d\n", session->lu_reset_timeout); in iscsi_session_get_param()
3630 len = sysfs_emit(buf, "%d\n", session->tgt_reset_timeout); in iscsi_session_get_param()
3633 len = sysfs_emit(buf, "%d\n", session->initial_r2t_en); in iscsi_session_get_param()
3636 len = sysfs_emit(buf, "%hu\n", session->max_r2t); in iscsi_session_get_param()
3639 len = sysfs_emit(buf, "%d\n", session->imm_data_en); in iscsi_session_get_param()
3642 len = sysfs_emit(buf, "%u\n", session->first_burst); in iscsi_session_get_param()
3645 len = sysfs_emit(buf, "%u\n", session->max_burst); in iscsi_session_get_param()
3648 len = sysfs_emit(buf, "%d\n", session->pdu_inorder_en); in iscsi_session_get_param()
3651 len = sysfs_emit(buf, "%d\n", session->dataseq_inorder_en); in iscsi_session_get_param()
3654 len = sysfs_emit(buf, "%d\n", session->def_taskmgmt_tmo); in iscsi_session_get_param()
3657 len = sysfs_emit(buf, "%d\n", session->erl); in iscsi_session_get_param()
3660 len = sysfs_emit(buf, "%s\n", session->targetname); in iscsi_session_get_param()
3663 len = sysfs_emit(buf, "%s\n", session->targetalias); in iscsi_session_get_param()
3666 len = sysfs_emit(buf, "%d\n", session->tpgt); in iscsi_session_get_param()
3669 len = sysfs_emit(buf, "%s\n", session->username); in iscsi_session_get_param()
3672 len = sysfs_emit(buf, "%s\n", session->username_in); in iscsi_session_get_param()
3675 len = sysfs_emit(buf, "%s\n", session->password); in iscsi_session_get_param()
3678 len = sysfs_emit(buf, "%s\n", session->password_in); in iscsi_session_get_param()
3681 len = sysfs_emit(buf, "%s\n", session->ifacename); in iscsi_session_get_param()
3684 len = sysfs_emit(buf, "%s\n", session->initiatorname); in iscsi_session_get_param()
3687 len = sysfs_emit(buf, "%s\n", session->boot_root); in iscsi_session_get_param()
3690 len = sysfs_emit(buf, "%s\n", session->boot_nic); in iscsi_session_get_param()
3693 len = sysfs_emit(buf, "%s\n", session->boot_target); in iscsi_session_get_param()
3696 len = sysfs_emit(buf, "%u\n", session->auto_snd_tgt_disable); in iscsi_session_get_param()
3699 len = sysfs_emit(buf, "%u\n", session->discovery_sess); in iscsi_session_get_param()
3702 len = sysfs_emit(buf, "%s\n", session->portal_type); in iscsi_session_get_param()
3705 len = sysfs_emit(buf, "%u\n", session->chap_auth_en); in iscsi_session_get_param()
3708 len = sysfs_emit(buf, "%u\n", session->discovery_logout_en); in iscsi_session_get_param()
3711 len = sysfs_emit(buf, "%u\n", session->bidi_chap_en); in iscsi_session_get_param()
3714 len = sysfs_emit(buf, "%u\n", session->discovery_auth_optional); in iscsi_session_get_param()
3717 len = sysfs_emit(buf, "%d\n", session->time2wait); in iscsi_session_get_param()
3720 len = sysfs_emit(buf, "%d\n", session->time2retain); in iscsi_session_get_param()
3723 len = sysfs_emit(buf, "%u\n", session->tsid); in iscsi_session_get_param()
3727 session->isid[0], session->isid[1], in iscsi_session_get_param()
3728 session->isid[2], session->isid[3], in iscsi_session_get_param()
3729 session->isid[4], session->isid[5]); in iscsi_session_get_param()
3732 len = sysfs_emit(buf, "%u\n", session->discovery_parent_idx); in iscsi_session_get_param()
3735 if (session->discovery_parent_type) in iscsi_session_get_param()
3737 session->discovery_parent_type); in iscsi_session_get_param()