4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License (the "License").
6 * You may not use this file except in compliance with the License.
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 * or http://www.opensolaris.org/os/licensing.
10 * See the License for the specific language governing permissions
11 * and limitations under the License.
13 * When distributing Covered Code, include this CDDL HEADER in each
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
23 * Copyright (c) 2008, 2010, Oracle and/or its affiliates. All rights reserved.
24 * Copyright 2014 Nexenta Systems, Inc. All rights reserved.
30 #include <sys/iscsit/iscsi_if.h>
31 #include <sys/iscsit/iscsit_common.h>
33 #include "iscsit_authclient.h"
36 * For some reason iscsi_protocol.h lists the max version as "0x02" and the
37 * min version as "0x00". RFC3720 clearly states that the current version
38 * number is 0x00 so that is what we will use.
40 #define ISCSIT_MIN_VERSION 0x00
41 #define ISCSIT_MAX_VERSION 0x00
42 #define ISCSIT_MAX_CONNECTIONS 32 /* MC/S support */
43 #define ISCSIT_MAX_RECV_DATA_SEGMENT_LENGTH (32*1024)
44 #define ISCSIT_MAX_BURST_LENGTH (1024*1024)
45 #define ISCSIT_MAX_FIRST_BURST_LENGTH ISCSI_DEFAULT_FIRST_BURST_LENGTH
46 #define ISCSIT_MAX_TIME2WAIT ISCSI_MAX_TIME2WAIT
47 #define ISCSIT_MAX_TIME2RETAIN ISCSI_DEFAULT_TIME_TO_RETAIN
48 #define ISCSIT_MAX_OUTSTANDING_R2T ISCSI_DEFAULT_MAX_OUT_R2T
49 #define ISCSIT_MAX_ERROR_RECOVERY_LEVEL 0
50 #define ISCSIT_MAX_OUTSTANDING_UNEXPECTED_PDUS 0
52 #define ISCSIT_DEFAULT_TPG "iscsit-default-tpg"
53 #define ISCSIT_DEFAULT_TPGT 1
55 #define ISCSI_MAX_TSIH 0xffff
56 #define ISCSI_UNSPEC_TSIH 0
58 /* Max targets per system */
59 #define ISCSIT_MAX_TARGETS 1024
61 #define ISCSIT_MAX_WINDOW 1024
62 #define ISCSIT_RXPDU_QUEUE_LEN 2048
64 #define ISCSIT_CMDSN_LT_EXPCMDSN -1
65 #define ISCSIT_CMDSN_EQ_EXPCMDSN 1
66 #define ISCSIT_CMDSN_GT_EXPCMDSN 0
68 * MC/S: A timeout is maintained to recover from lost CmdSN (holes in the
69 * CmdSN ordering). When the timeout is reached, the ExpCmdSN is advanced
70 * past the hole to continue processing the queued commands. This value is
71 * system-tunable (volatile rxpdu_queue_threshold) and should be in the
72 * range from 5 to 30 seconds.
74 #define ISCSIT_RXPDU_QUEUE_THRESHOLD 5 /* 5 seconds */
75 #define ISCSIT_RXPDU_QUEUE_MONITOR_INTERVAL 5 /* 5 seconds */
77 /* Time in seconds to wait between calls to stmf_deregister_local_port */
78 #define TGT_DEREG_RETRY_SECONDS 1
80 #define ISCSIT_GLOBAL_LOCK(rw) rw_enter(&iscsit_global.global_rwlock, (rw))
81 #define ISCSIT_GLOBAL_UNLOCK() rw_exit(&iscsit_global.global_rwlock)
83 /* Circular buffer to hold the out-of-order PDUs in MC/S */
85 idm_pdu_t
*cb_buffer
[ISCSIT_RXPDU_QUEUE_LEN
];
90 * Used for serial number arithmetic (RFC 1982)
92 #define ISCSIT_SNA32_CHECK 0x80000000
95 char tpg_name
[MAX_TPG_NAMELEN
];
97 idm_refcnt_t tpg_refcnt
;
99 avl_tree_t tpg_portal_list
;
100 avl_node_t tpg_global_ln
;
101 list_node_t tpg_delete_ln
;
104 #define IS_DEFAULT_TPGT(TPGT) \
105 (((TPGT) != NULL) && \
106 ((TPGT)->tpgt_tpg == iscsit_global.global_default_tpg))
109 iscsit_tpg_t
*tpgt_tpg
;
110 idm_refcnt_t tpgt_refcnt
;
111 avl_node_t tpgt_tgt_ln
;
112 list_node_t tpgt_delete_ln
;
114 boolean_t tpgt_needs_tpg_offline
;
118 struct sockaddr_storage portal_addr
;
120 idm_refcnt_t portal_refcnt
;
121 avl_node_t portal_tpg_ln
;
122 iscsit_tpg_t
*portal_tpg
;
123 idm_svc_t
*portal_svc
;
124 boolean_t portal_default
;
129 /* Target states and events, update iscsit_ts_name table whenever modified */
136 TS_DELETING_NEED_OFFLINE
,
140 TS_DELETING_STMF_DEREG
,
141 TS_DELETING_STMF_DEREG_FAIL
,
144 } iscsit_tgt_state_t
;
146 #ifdef ISCSIT_TGT_SM_STRINGS
147 static const char *iscsit_ts_name
[TS_MAX_STATE
+1] = {
153 "TS_DELETING_NEED_OFFLINE",
157 "TS_DELETING_STMF_DEREG",
158 "TS_DELETING_STMF_DEREG_FAIL",
169 TE_STMF_ONLINE_COMPLETE_ACK
,
172 TE_STMF_OFFLINE_COMPLETE_ACK
,
174 TE_STMF_DEREG_SUCCESS
,
177 TE_WAIT_REF_COMPLETE
,
179 } iscsit_tgt_event_t
;
181 #ifdef ISCSIT_TGT_SM_STRINGS
182 static const char *iscsit_te_name
[TE_MAX_EVENT
+1] = {
184 "TE_STMF_ONLINE_REQ",
187 "TE_STMF_ONLINE_COMPLETE_ACK",
188 "TE_STMF_OFFLINE_REQ",
189 "TE_OFFLINE_COMPLETE",
190 "TE_STMF_OFFLINE_COMPLETE_ACK",
192 "TE_STMF_DEREG_SUCCESS",
193 "TE_STMF_DEREG_FAIL",
194 "TE_STMF_DEREG_RETRY",
195 "TE_WAIT_REF_COMPLETE",
202 nvlist_t
*target_props
;
203 kmutex_t target_mutex
;
204 idm_refcnt_t target_refcnt
;
205 idm_refcnt_t target_sess_refcnt
;
206 avl_tree_t target_tpgt_list
;
207 avl_tree_t target_sess_list
;
208 avl_node_t target_global_ln
;
209 avl_node_t target_global_deleted_ln
;
210 /* STMF lport == iSCSI target */
211 scsi_devid_desc_t
*target_devid
;
212 stmf_local_port_t
*target_stmf_lport
;
213 uint8_t target_stmf_lport_registered
;
216 boolean_t target_sm_busy
;
217 boolean_t target_deleting
;
218 iscsit_tgt_state_t target_state
;
219 iscsit_tgt_state_t target_last_state
;
220 sm_audit_buf_t target_state_audit
;
221 list_t target_events
;
222 uint64_t target_generation
;
226 char ini_name
[MAX_ISCSI_NODENAMELEN
];
228 avl_node_t ini_global_ln
;
232 * iSCSI Auth Information
234 typedef struct conn_auth
{
235 char ca_tgt_chapuser
[iscsitAuthStringMaxLength
];
236 uint8_t ca_tgt_chapsecret
[iscsitAuthStringMaxLength
];
237 int ca_tgt_chapsecretlen
;
239 char ca_ini_chapuser
[iscsitAuthStringMaxLength
];
240 uint8_t ca_ini_chapsecret
[iscsitAuthStringMaxLength
];
241 int ca_ini_chapsecretlen
;
243 /* RADIUS authentication information */
244 boolean_t ca_use_radius
;
245 struct sockaddr_storage ca_radius_server
;
246 uint8_t ca_radius_secret
[iscsitAuthStringMaxLength
];
247 int ca_radius_secretlen
;
249 /* authentication method list */
250 iscsit_auth_method_t ca_method_valid_list
[iscsitAuthMethodMaxCount
];
253 char ca_tgt_alias
[MAX_ISCSI_NODENAMELEN
];
257 * We have three state machines (so far) between the IDM connection state
258 * machine, the session state machine, and the login state machine. All
259 * of these states have some concept of "full feature mode". It's going
260 * to be obnoxious if we use a mixture of these "ffp" representations
261 * since it will be difficult to ensure the three state machines
262 * transition at exactly the same time. We should drive decisions that
263 * depend on FFP from the IDM state machine which is actually snooping
264 * the iSCSI PDU's and will always transition at the correct time.
266 * A consequence of this approach is that there is a window just after
267 * login completes where we may get a SCSI request but the session
268 * or login state machine has not quite transitioned to "FFP". Whether
269 * this is a problem depends on how we use those state machines. This
270 * is what we should use them for:
272 * IDM Connection state machine - Decisions related to command processing
273 * including whether a connection is in FFP
275 * Session state machine - Summarize the state of all available connections
276 * for the purposes of ERL1, ERL2 and MC/S. A session in LOGGED_IN state
277 * should always have at least one FFP connection but there may be a brief
278 * window where a session in ACTIVE might have one or more FFP connections
279 * even though ACTIVE is not strictly an FFP state according to the RFC.
281 * Login state machine -- drive the login process, collect negotiated
282 * parameters. Another side effect of this approach is that we may get
283 * the "notify ffp" callback from the IDM connection state machine before
284 * the login state machine has actually transitioned to FFP state.
287 struct iscsit_conn_s
;
289 /* Update iscsit_ss_name table whenever session states are modified */
299 /* Add new session states above SS_MAX_STATE */
301 } iscsit_session_state_t
;
303 #ifdef ISCSIT_SESS_SM_STRINGS
304 /* An array of state text values, for use in logging state transitions */
305 static const char *iscsit_ss_name
[SS_MAX_STATE
+1] = {
318 /* Update iscsit_se_name table whenever session events are modified */
321 SE_CONN_IN_LOGIN
, /* From login state machine */
322 SE_CONN_LOGGED_IN
, /* FFP enabled client notification */
323 SE_CONN_FFP_FAIL
, /* FFP disabled client notification */
324 SE_CONN_FFP_DISABLE
, /* FFP disabled client notification */
325 SE_CONN_FAIL
, /* Conn destroy client notification */
326 SE_SESSION_CLOSE
, /* FFP disabled client notification */
327 SE_SESSION_REINSTATE
, /* From login state machine */
328 SE_SESSION_TIMEOUT
, /* Internal */
329 SE_SESSION_CONTINUE
, /* From login state machine */
330 SE_SESSION_CONTINUE_FAIL
, /* From login state machine? */
331 /* Add new events above SE_MAX_EVENT */
333 } iscsit_session_event_t
;
335 #ifdef ISCSIT_SESS_SM_STRINGS
336 /* An array of event text values, for use in logging events */
337 static const char *iscsit_se_name
[SE_MAX_EVENT
+1] = {
342 "SE_CONN_FFP_DISABLE",
345 "SE_SESSION_REINSTATE",
346 "SE_SESSION_TIMEOUT",
347 "SE_SESSION_CONTINUE",
348 "SE_SESSION_CONTINUE_FAIL",
354 * Set in ist_tgt after iscsit_tgt_unbind_sess to differentiate an unbound
355 * session from a discovery session.
357 #define SESS_UNBOUND_FROM_TGT -1
360 stmf_scsi_session_t
*ist_stmf_sess
;
361 stmf_local_port_t
*ist_lport
;
362 iscsit_tgt_t
*ist_tgt
;
363 idm_refcnt_t ist_refcnt
;
364 kmem_cache_t
*ist_task_cache
;
365 kmutex_t ist_sn_mutex
;
368 iscsit_session_state_t ist_state
;
369 iscsit_session_state_t ist_last_state
;
370 sm_audit_buf_t ist_state_audit
;
371 boolean_t ist_sm_busy
;
372 boolean_t ist_sm_complete
;
373 boolean_t ist_admin_close
;
376 int ist_ffp_conn_count
;
377 struct iscsit_conn_s
*ist_failed_conn
;
378 timeout_id_t ist_state_timeout
;
379 list_t ist_conn_list
;
380 avl_node_t ist_tgt_ln
;
381 char *ist_initiator_name
;
382 char *ist_initiator_alias
;
383 char *ist_target_name
;
384 char *ist_target_alias
;
385 uint8_t ist_isid
[ISCSI_ISID_LEN
];
387 uint16_t ist_tpgt_tag
;
388 uint32_t ist_expcmdsn
;
389 uint32_t ist_maxcmdsn
;
390 avl_tree_t ist_task_list
;
391 iscsit_cbuf_t
*ist_rxpdu_queue
;
394 /* Update iscsit_ils_name table whenever login states are modified */
398 ILS_LOGIN_WAITING
, /* Waiting for more login PDU's */
399 ILS_LOGIN_PROCESSING
, /* Processing login request */
400 ILS_LOGIN_RESPONDING
, /* Sending login response */
401 ILS_LOGIN_RESPONDED
, /* Sent login response (no trans. to FFP) */
402 ILS_LOGIN_FFP
, /* Sending last login PDU for final response */
403 ILS_LOGIN_DONE
, /* Last login PDU sent (so we can free it) */
404 ILS_LOGIN_ERROR
, /* Login error, login failed */
405 /* Add new login states above ILS_MAX_STATE */
407 } iscsit_login_state_t
;
409 #ifdef ISCSIT_LOGIN_SM_STRINGS
410 /* An array of login state text values, for use in logging login progress */
411 static const char *iscsit_ils_name
[ILS_MAX_STATE
+1] = {
415 "ILS_LOGIN_PROCESSING",
416 "ILS_LOGIN_RESPONDING",
417 "ILS_LOGIN_RESPONDED",
425 /* Update iscsit_ile_name table whenever login events are modified */
429 ILE_LOGIN_RESP_READY
,
431 ILE_LOGIN_RESP_COMPLETE
,
433 ILE_LOGIN_CONN_ERROR
,
434 /* Add new login events above ILE_MAX_EVENT */
436 } iscsit_login_event_t
;
438 #ifdef ISCSIT_LOGIN_SM_STRINGS
439 /* An array of login event text values, for use in logging login events */
440 static const char *iscsit_ile_name
[ILE_MAX_EVENT
+1] = {
443 "ILE_LOGIN_RESP_READY",
445 "ILE_LOGIN_RESP_COMPLETE",
447 "ILE_LOGIN_CONN_ERROR",
453 uint32_t op_initial_params_set
:1,
454 op_discovery_session
:1,
457 op_data_pdu_in_order
:1,
458 op_data_sequence_in_order
:1,
459 op_declarative_params_set
:1;
460 uint64_t op_max_connections
;
461 uint64_t op_max_recv_data_segment_length
;
462 uint64_t op_max_burst_length
;
463 uint64_t op_first_burst_length
;
464 uint64_t op_default_time_2_wait
;
465 uint64_t op_default_time_2_retain
;
466 uint64_t op_max_outstanding_r2t
;
467 uint64_t op_error_recovery_level
;
468 } iscsit_op_params_t
;
471 iscsit_login_state_t icl_login_state
;
472 iscsit_login_state_t icl_login_last_state
;
473 sm_audit_buf_t icl_state_audit
;
475 boolean_t icl_login_complete
;
477 uint32_t icl_login_itt
;
478 uint8_t icl_login_csg
;
479 uint8_t icl_login_nsg
;
480 boolean_t icl_login_transit
;
481 conn_auth_t icl_auth
;
482 iscsit_auth_client_t icl_auth_client
;
484 list_t icl_login_events
;
487 uint8_t icl_isid
[ISCSI_ISID_LEN
];
489 uint16_t icl_tpgt_tag
;
490 char *icl_target_name
;
491 char *icl_target_alias
;
492 char *icl_initiator_name
;
493 char *icl_login_resp_buf
;
494 void *icl_login_resp_itb
; /* mult-pdu idm buf */
495 int icl_login_resp_len
; /* For kmem_free */
496 int icl_login_resp_valid_len
;
497 uint8_t icl_login_resp_err_class
;
498 uint8_t icl_login_resp_err_detail
;
499 iscsi_login_rsp_hdr_t
*icl_login_resp_tmpl
;
500 nvlist_t
*icl_request_nvlist
;
501 nvlist_t
*icl_response_nvlist
;
502 nvlist_t
*icl_negotiated_values
;
503 } iscsit_conn_login_t
;
505 #define SET_LOGIN_ERROR(SLE_ICT, SLE_CLASS, SLE_DETAIL) \
506 (SLE_ICT)->ict_login_sm.icl_login_resp_err_class = (SLE_CLASS); \
507 (SLE_ICT)->ict_login_sm.icl_login_resp_err_detail = (SLE_DETAIL);
509 typedef struct iscsit_conn_s
{
511 iscsit_sess_t
*ict_sess
;
513 idm_refcnt_t ict_refcnt
;
514 idm_refcnt_t ict_dispatch_refcnt
;
515 list_node_t ict_sess_ln
;
516 iscsit_conn_login_t ict_login_sm
;
517 iscsit_op_params_t ict_op
;
520 kmutex_t ict_statsn_mutex
;
521 uint32_t ict_keepalive_ttt
;
522 struct iscsit_conn_s
*ict_reinstate_conn
;
523 uint32_t ict_reinstating
:1,
527 * Parameters for processing text commands
529 char *ict_text_rsp_buf
;
530 uint32_t ict_text_rsp_len
;
531 uint32_t ict_text_rsp_valid_len
;
532 uint32_t ict_text_rsp_off
;
533 uint32_t ict_text_req_itt
; /* from initiator */
534 uint32_t ict_text_rsp_ttt
;
537 #define ICT_FLAGS_DISCOVERY 0x00000001
540 idm_buf_t
*ibuf_idm_buf
;
541 stmf_data_buf_t
*ibuf_stmf_buf
;
542 idm_pdu_t
*ibuf_immed_data_pdu
;
543 boolean_t ibuf_is_immed
;
547 scsi_task_t
*it_stmf_task
;
548 idm_task_t
*it_idm_task
;
549 iscsit_buf_t
*it_immed_data
;
550 iscsit_conn_t
*it_ict
;
552 idm_pdu_t
*it_tm_pdu
;
553 uint32_t it_stmf_abort
:1,
561 avl_node_t it_sess_ln
;
564 typedef struct iscsit_isns_cfg
{
566 boolean_t isns_state
;
571 * State values for the iscsit service
581 } iscsit_service_enabled_t
;
585 iscsit_service_enabled_t global_svc_state
;
586 dev_info_t
*global_dip
;
587 ldi_ident_t global_li
;
588 nvlist_t
*global_props
;
589 stmf_port_provider_t
*global_pp
;
590 stmf_dbuf_store_t
*global_dbuf_store
;
591 taskq_t
*global_dispatch_taskq
;
592 idm_refcnt_t global_refcnt
;
593 avl_tree_t global_discovery_sessions
;
594 avl_tree_t global_target_list
;
595 list_t global_deleted_target_list
;
596 avl_tree_t global_tpg_list
;
597 avl_tree_t global_ini_list
;
598 iscsit_tpg_t
*global_default_tpg
;
599 vmem_t
*global_tsih_pool
;
600 iscsit_isns_cfg_t global_isns_cfg
;
601 iscsi_radius_props_t global_radius_server
;
602 krwlock_t global_rwlock
;
603 kmutex_t global_state_mutex
;
606 extern iscsit_global_t iscsit_global
;
609 iscsit_global_hold();
612 iscsit_global_rele();
615 iscsit_global_wait_ref();
618 iscsit_login_sm_init(iscsit_conn_t
*ict
);
621 iscsit_login_sm_fini(iscsit_conn_t
*ict
);
624 iscsit_login_sm_event(iscsit_conn_t
*ic
, iscsit_login_event_t event
,
628 iscsit_login_sm_event_locked(iscsit_conn_t
*ic
, iscsit_login_event_t event
,
632 iscsit_is_v4_mapped(struct sockaddr_storage
*sa
, struct sockaddr_storage
*v4sa
);
635 iscsit_send_async_event(iscsit_conn_t
*ict
, uint8_t async_event
);
638 iscsit_pdu_tx(idm_pdu_t
*pdu
);
641 iscsit_send_reject(iscsit_conn_t
*ict
, idm_pdu_t
*rejected_pdu
, uint8_t reason
);
644 iscsit_text_cmd_fini(iscsit_conn_t
*ict
);
650 idm_rx_pdu_cb_t iscsit_op_scsi_cmd
;
651 idm_rx_pdu_cb_t iscsit_rx_pdu
;
652 idm_rx_pdu_error_cb_t iscsit_rx_pdu_error
;
653 idm_rx_pdu_cb_t iscsit_rx_scsi_rsp
;
654 idm_task_cb_t iscsit_task_aborted
;
655 idm_client_notify_cb_t iscsit_client_notify
;
656 idm_build_hdr_cb_t iscsit_build_hdr
;
657 idm_update_statsn_cb_t iscsit_update_statsn
;
658 idm_keepalive_cb_t iscsit_keepalive
;
664 iscsit_xfer_scsi_data(scsi_task_t
*task
, stmf_data_buf_t
*dbuf
,
668 iscsit_send_scsi_status(scsi_task_t
*task
, uint32_t ioflags
);
671 iscsit_lport_task_free(scsi_task_t
*task
);
674 iscsit_abort(stmf_local_port_t
*lport
, int abort_cmd
, void *arg
,
678 iscsit_ctl(stmf_local_port_t
*lport
, int cmd
, void *arg
);
681 * Connection functions
684 iscsit_conn_reinstate(iscsit_conn_t
*existing_ict
, iscsit_conn_t
*ict
);
687 iscsit_conn_destroy_done(iscsit_conn_t
*ict
);
690 iscsit_conn_set_auth(iscsit_conn_t
*ict
);
693 iscsit_conn_hold(iscsit_conn_t
*ict
);
696 iscsit_conn_rele(iscsit_conn_t
*ict
);
699 iscsit_conn_logout(iscsit_conn_t
*ict
);
705 iscsit_sess_avl_compare(const void *void_sess1
, const void *void_sess2
);
708 iscsit_sess_create(iscsit_tgt_t
*tgt
, iscsit_conn_t
*ict
,
709 uint32_t cmdsn
, uint8_t *isid
, uint16_t tag
,
710 char *initiator_name
, char *target_name
,
711 uint8_t *error_class
, uint8_t *error_detail
);
714 iscsit_sess_destroy(iscsit_sess_t
*ist
);
717 iscsit_sess_hold(iscsit_sess_t
*ist
);
720 iscsit_sess_check_hold(iscsit_sess_t
*ist
);
723 iscsit_sess_rele(iscsit_sess_t
*ist
);
726 iscsit_sess_lookup_conn(iscsit_sess_t
*ist
, uint16_t cid
);
729 iscsit_sess_bind_conn(iscsit_sess_t
*ist
, iscsit_conn_t
*ict
);
732 iscsit_sess_unbind_conn(iscsit_sess_t
*ist
, iscsit_conn_t
*ict
);
735 iscsit_sess_close(iscsit_sess_t
*ist
);
738 iscsit_sess_reinstate(iscsit_tgt_t
*tgt
, iscsit_sess_t
*ist
, iscsit_conn_t
*ict
,
739 uint8_t *error_class
, uint8_t *error_detail
);
742 iscsit_sess_sm_event(iscsit_sess_t
*ist
, iscsit_session_event_t event
,
746 * Target, TPGT, TPGT and portal functions
750 iscsit_tgt_sm_event(iscsit_tgt_t
*tgt
, iscsit_tgt_event_t event
);
753 tgt_sm_event_locked(iscsit_tgt_t
*tgt
, iscsit_tgt_event_t event
);
756 iscsit_config_merge_tgt(it_config_t
*cfg
);
759 iscsit_config_destroy_tgts(list_t
*tgt_del_list
);
762 iscsit_config_destroy_tpgts(list_t
*tpgt_del_list
);
765 iscsit_tgt_lookup(char *target_name
);
768 iscsit_tgt_lookup_locked(char *target_name
);
771 iscsit_tgt_avl_compare(const void *void_tgt1
, const void *void_tgt2
);
774 iscsit_tpgt_avl_compare(const void *void_tpgt1
, const void *void_tpgt2
);
777 iscsit_tgt_hold(iscsit_tgt_t
*tgt
);
780 iscsit_tgt_rele(iscsit_tgt_t
*tgt
);
783 iscsit_tgt_lookup_tpgt(iscsit_tgt_t
*tgt
, uint16_t tag
);
786 iscsit_tpgt_hold(iscsit_tpgt_t
*tpgt
);
789 iscsit_tpgt_rele(iscsit_tpgt_t
*tpgt
);
792 iscsit_tgt_lookup_portal(iscsit_tgt_t
*tgt
, struct sockaddr_storage
*sa
,
793 iscsit_tpgt_t
**output_tpgt
);
796 iscsit_tgt_lookup_sess(iscsit_tgt_t
*tgt
, char *initiator_name
,
797 uint8_t *isid
, uint16_t tsih
, uint16_t tag
);
800 iscsit_tgt_bind_sess(iscsit_tgt_t
*tgt
, iscsit_sess_t
*sess
);
803 iscsit_tgt_unbind_sess(iscsit_tgt_t
*tgt
, iscsit_sess_t
*sess
);
806 iscsit_config_merge_tpg(it_config_t
*cfg
, list_t
*tpg_del_list
);
809 iscsit_config_destroy_tpgs(list_t
*tpg_del_list
);
812 iscsit_tpg_lookup(char *tpg_name
);
815 iscsit_tpg_avl_compare(const void *void_tpg1
, const void *void_tpg2
);
818 iscsit_tpg_hold(iscsit_tpg_t
*tpg
);
821 iscsit_tpg_rele(iscsit_tpg_t
*tpg
);
824 iscsit_tpg_createdefault();
827 iscsit_tpg_destroydefault(iscsit_tpg_t
*tpg
);
830 iscsit_tpg_online(iscsit_tpg_t
*tpg
);
833 iscsit_tpg_offline(iscsit_tpg_t
*tpg
);
836 iscsit_tpg_portal_lookup(iscsit_tpg_t
*tpg
, struct sockaddr_storage
*sa
);
839 iscsit_portal_hold(iscsit_portal_t
*portal
);
842 iscsit_portal_rele(iscsit_portal_t
*portal
);
845 iscsit_config_merge_ini(it_config_t
*cfg
);
848 iscsit_ini_avl_compare(const void *void_ini1
, const void *void_ini2
);
851 iscsit_ini_lookup_locked(char *ini_name
);
854 iscsit_portal_avl_compare(const void *void_portal1
, const void *void_portal2
);
857 iscsit_verify_chap_resp(iscsit_conn_login_t
*lsm
,
858 unsigned int chap_i
, uchar_t
*chap_c
, unsigned int challenge_len
,
859 uchar_t
*chap_r
, unsigned int resp_len
);
862 iscsit_rxpdu_queue_monitor_start(void);
865 iscsit_rxpdu_queue_monitor_stop(void);
867 #endif /* _ISCSIT_H_ */