2013-09-14 17:29:06 +02:00
|
|
|
/*-
|
2023-05-10 17:40:58 +02:00
|
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
2017-11-27 16:12:43 +01:00
|
|
|
*
|
2013-09-14 17:29:06 +02:00
|
|
|
* Copyright (c) 2012 The FreeBSD Foundation
|
|
|
|
*
|
|
|
|
* This software was developed by Edward Tomasz Napierala under sponsorship
|
|
|
|
* from the FreeBSD Foundation.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
* documentation and/or other materials provided with the distribution.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
|
|
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
|
|
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
|
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
|
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
|
* SUCH DAMAGE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef CTL_FRONTEND_ISCSI_H
|
|
|
|
#define CTL_FRONTEND_ISCSI_H
|
|
|
|
|
2014-07-05 20:15:00 +02:00
|
|
|
#define CFISCSI_TARGET_STATE_INVALID 0
|
|
|
|
#define CFISCSI_TARGET_STATE_ACTIVE 1
|
|
|
|
#define CFISCSI_TARGET_STATE_DYING 2
|
|
|
|
|
2013-09-14 17:29:06 +02:00
|
|
|
struct cfiscsi_target {
|
|
|
|
TAILQ_ENTRY(cfiscsi_target) ct_next;
|
|
|
|
struct cfiscsi_softc *ct_softc;
|
|
|
|
volatile u_int ct_refcount;
|
|
|
|
char ct_name[CTL_ISCSI_NAME_LEN];
|
|
|
|
char ct_alias[CTL_ISCSI_ALIAS_LEN];
|
2015-02-03 17:17:54 +01:00
|
|
|
uint16_t ct_tag;
|
2014-07-05 20:15:00 +02:00
|
|
|
int ct_state;
|
|
|
|
int ct_online;
|
2014-10-11 19:52:54 +02:00
|
|
|
int ct_target_id;
|
2014-07-05 20:15:00 +02:00
|
|
|
struct ctl_port ct_port;
|
2013-09-14 17:29:06 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
struct cfiscsi_data_wait {
|
|
|
|
TAILQ_ENTRY(cfiscsi_data_wait) cdw_next;
|
|
|
|
union ctl_io *cdw_ctl_io;
|
|
|
|
uint32_t cdw_target_transfer_tag;
|
|
|
|
uint32_t cdw_initiator_task_tag;
|
|
|
|
int cdw_sg_index;
|
|
|
|
char *cdw_sg_addr;
|
|
|
|
size_t cdw_sg_len;
|
2014-10-06 14:20:46 +02:00
|
|
|
uint32_t cdw_r2t_end;
|
2014-12-17 16:13:21 +01:00
|
|
|
uint32_t cdw_datasn;
|
2015-02-08 20:15:14 +01:00
|
|
|
void *cdw_icl_prv;
|
2013-09-14 17:29:06 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
#define CFISCSI_SESSION_STATE_INVALID 0
|
|
|
|
#define CFISCSI_SESSION_STATE_BHS 1
|
|
|
|
#define CFISCSI_SESSION_STATE_AHS 2
|
|
|
|
#define CFISCSI_SESSION_STATE_HEADER_DIGEST 3
|
|
|
|
#define CFISCSI_SESSION_STATE_DATA 4
|
|
|
|
#define CFISCSI_SESSION_STATE_DATA_DIGEST 5
|
|
|
|
|
|
|
|
struct cfiscsi_session {
|
|
|
|
TAILQ_ENTRY(cfiscsi_session) cs_next;
|
|
|
|
struct mtx cs_lock;
|
|
|
|
struct icl_conn *cs_conn;
|
|
|
|
uint32_t cs_cmdsn;
|
|
|
|
uint32_t cs_statsn;
|
|
|
|
uint32_t cs_target_transfer_tag;
|
|
|
|
volatile u_int cs_outstanding_ctl_pdus;
|
|
|
|
TAILQ_HEAD(, cfiscsi_data_wait) cs_waiting_for_data_out;
|
|
|
|
struct cfiscsi_target *cs_target;
|
|
|
|
struct callout cs_callout;
|
|
|
|
int cs_timeout;
|
|
|
|
struct cv cs_maintenance_cv;
|
2014-06-17 11:02:10 +02:00
|
|
|
bool cs_terminating;
|
2022-01-18 18:28:43 +01:00
|
|
|
bool cs_terminating_tasks;
|
2018-03-15 18:36:13 +01:00
|
|
|
bool cs_handoff_in_progress;
|
2014-07-07 07:48:11 +02:00
|
|
|
bool cs_tasks_aborted;
|
2016-08-25 07:22:53 +02:00
|
|
|
int cs_max_burst_length;
|
|
|
|
int cs_first_burst_length;
|
2013-09-14 17:29:06 +02:00
|
|
|
bool cs_immediate_data;
|
|
|
|
char cs_initiator_name[CTL_ISCSI_NAME_LEN];
|
|
|
|
char cs_initiator_addr[CTL_ISCSI_ADDR_LEN];
|
|
|
|
char cs_initiator_alias[CTL_ISCSI_ALIAS_LEN];
|
2014-07-05 23:18:33 +02:00
|
|
|
char cs_initiator_isid[6];
|
|
|
|
char cs_initiator_id[CTL_ISCSI_NAME_LEN + 5 + 6 + 1];
|
2013-09-14 17:29:06 +02:00
|
|
|
unsigned int cs_id;
|
|
|
|
int cs_ctl_initid;
|
|
|
|
#ifdef ICL_KERNEL_PROXY
|
2014-04-16 13:00:10 +02:00
|
|
|
struct sockaddr *cs_initiator_sa;
|
2014-04-16 12:29:34 +02:00
|
|
|
int cs_portal_id;
|
2013-09-14 17:29:06 +02:00
|
|
|
bool cs_login_phase;
|
|
|
|
bool cs_waiting_for_ctld;
|
|
|
|
struct cv cs_login_cv;
|
|
|
|
struct icl_pdu *cs_login_pdu;
|
|
|
|
#endif
|
|
|
|
};
|
|
|
|
|
|
|
|
#ifdef ICL_KERNEL_PROXY
|
|
|
|
struct icl_listen;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
struct cfiscsi_softc {
|
|
|
|
struct mtx lock;
|
|
|
|
char port_name[32];
|
|
|
|
int online;
|
2014-10-11 19:52:54 +02:00
|
|
|
int last_target_id;
|
2013-09-14 17:29:06 +02:00
|
|
|
unsigned int last_session_id;
|
|
|
|
TAILQ_HEAD(, cfiscsi_target) targets;
|
|
|
|
TAILQ_HEAD(, cfiscsi_session) sessions;
|
2014-11-21 19:05:02 +01:00
|
|
|
struct cv sessions_cv;
|
2013-09-14 17:29:06 +02:00
|
|
|
#ifdef ICL_KERNEL_PROXY
|
|
|
|
struct icl_listen *listener;
|
|
|
|
struct cv accept_cv;
|
|
|
|
#endif
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif /* !CTL_FRONTEND_ISCSI_H */
|