1 /*- 2 * SPDX-License-Identifier: BSD-2-Clause-FreeBSD 3 * 4 * Copyright (c) 2012 The FreeBSD Foundation 5 * 6 * This software was developed by Edward Tomasz Napierala under sponsorship 7 * from the FreeBSD Foundation. 8 * 9 * Redistribution and use in source and binary forms, with or without 10 * modification, are permitted provided that the following conditions 11 * are met: 12 * 1. Redistributions of source code must retain the above copyright 13 * notice, this list of conditions and the following disclaimer. 14 * 2. Redistributions in binary form must reproduce the above copyright 15 * notice, this list of conditions and the following disclaimer in the 16 * documentation and/or other materials provided with the distribution. 17 * 18 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 19 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 20 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 21 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 22 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 23 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 24 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 25 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 26 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 27 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 28 * SUCH DAMAGE. 29 * 30 * $FreeBSD$ 31 */ 32 33 #ifndef ISCSI_H 34 #define ISCSI_H 35 36 struct iscsi_softc; 37 struct icl_conn; 38 39 #define ISCSI_NAME_LEN 224 /* 223 bytes, by RFC 3720, + '\0' */ 40 #define ISCSI_ADDR_LEN 47 /* INET6_ADDRSTRLEN + '\0' */ 41 #define ISCSI_SECRET_LEN 17 /* 16 + '\0' */ 42 43 struct iscsi_outstanding { 44 TAILQ_ENTRY(iscsi_outstanding) io_next; 45 union ccb *io_ccb; 46 size_t io_received; 47 uint32_t io_initiator_task_tag; 48 uint32_t io_referenced_task_tag; 49 void *io_icl_prv; 50 }; 51 52 struct iscsi_session { 53 TAILQ_ENTRY(iscsi_session) is_next; 54 55 struct icl_conn *is_conn; 56 struct mtx is_lock; 57 58 uint32_t is_statsn; 59 uint32_t is_cmdsn; 60 uint32_t is_expcmdsn; 61 uint32_t is_maxcmdsn; 62 uint32_t is_initiator_task_tag; 63 int is_protocol_level; 64 int is_initial_r2t; 65 int is_max_burst_length; 66 int is_first_burst_length; 67 uint8_t is_isid[6]; 68 uint16_t is_tsih; 69 bool is_immediate_data; 70 char is_target_alias[ISCSI_ALIAS_LEN]; 71 72 TAILQ_HEAD(, iscsi_outstanding) is_outstanding; 73 STAILQ_HEAD(, icl_pdu) is_postponed; 74 75 struct callout is_callout; 76 unsigned int is_timeout; 77 78 /* 79 * XXX: This could be rewritten using a single variable, 80 * but somehow it results in uglier code. 81 */ 82 /* 83 * We're waiting for iscsid(8); after iscsid_timeout 84 * expires, kernel will wake up an iscsid(8) to handle 85 * the session. 86 */ 87 bool is_waiting_for_iscsid; 88 89 /* 90 * Some iscsid(8) instance is handling the session; 91 * after login_timeout expires, kernel will wake up 92 * another iscsid(8) to handle the session. 93 */ 94 bool is_login_phase; 95 96 /* 97 * We're in the process of removing the iSCSI session. 98 */ 99 bool is_terminating; 100 101 /* 102 * We're waiting for the maintenance thread to do some 103 * reconnection tasks. 104 */ 105 bool is_reconnecting; 106 107 bool is_connected; 108 109 struct cam_devq *is_devq; 110 struct cam_sim *is_sim; 111 struct cam_path *is_path; 112 struct cv is_maintenance_cv; 113 struct iscsi_softc *is_softc; 114 unsigned int is_id; 115 struct iscsi_session_conf is_conf; 116 bool is_simq_frozen; 117 118 char is_reason[ISCSI_REASON_LEN]; 119 120 #ifdef ICL_KERNEL_PROXY 121 struct cv is_login_cv; 122 struct icl_pdu *is_login_pdu; 123 #endif 124 }; 125 126 struct iscsi_softc { 127 device_t sc_dev; 128 struct sx sc_lock; 129 struct cdev *sc_cdev; 130 TAILQ_HEAD(, iscsi_session) sc_sessions; 131 struct cv sc_cv; 132 unsigned int sc_last_session_id; 133 bool sc_unloading; 134 eventhandler_tag sc_shutdown_pre_eh; 135 eventhandler_tag sc_shutdown_post_eh; 136 }; 137 138 #endif /* !ISCSI_H */ 139