| 1 | /* $NetBSD: iscsi.h,v 1.4 2016/06/15 04:30:30 mlelstv Exp $ */ |
| 2 | |
| 3 | /*- |
| 4 | * Copyright (c) 2004,2006,2011 The NetBSD Foundation, Inc. |
| 5 | * All rights reserved. |
| 6 | * |
| 7 | * This code is derived from software contributed to The NetBSD Foundation |
| 8 | * by Wasabi Systems, Inc. |
| 9 | * |
| 10 | * Redistribution and use in source and binary forms, with or without |
| 11 | * modification, are permitted provided that the following conditions |
| 12 | * are met: |
| 13 | * 1. Redistributions of source code must retain the above copyright |
| 14 | * notice, this list of conditions and the following disclaimer. |
| 15 | * 2. Redistributions in binary form must reproduce the above copyright |
| 16 | * notice, this list of conditions and the following disclaimer in the |
| 17 | * documentation and/or other materials provided with the distribution. |
| 18 | * |
| 19 | * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS |
| 20 | * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED |
| 21 | * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR |
| 22 | * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS |
| 23 | * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR |
| 24 | * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF |
| 25 | * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS |
| 26 | * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN |
| 27 | * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) |
| 28 | * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE |
| 29 | * POSSIBILITY OF SUCH DAMAGE. |
| 30 | */ |
| 31 | #ifndef _ISCSI_H |
| 32 | #define _ISCSI_H |
| 33 | |
| 34 | #define ISCSI_DEV_MAJOR 203 |
| 35 | |
| 36 | #define ISCSI_STRING_LENGTH (223+1) |
| 37 | #define ISCSI_ADDRESS_LENGTH (255+1) |
| 38 | #define ISCSI_AUTH_OPTIONS 4 |
| 39 | |
| 40 | typedef enum { |
| 41 | ISCSI_AUTH_None = 0, |
| 42 | ISCSI_AUTH_CHAP = 1, |
| 43 | ISCSI_AUTH_KRB5 = 2, |
| 44 | ISCSI_AUTH_SRP = 3 |
| 45 | } iscsi_auth_types_t; |
| 46 | /* |
| 47 | ISCSI_AUTH_None |
| 48 | Indicates that no authentication is necessary. |
| 49 | ISCSI_AUTH_CHAP |
| 50 | Indicates CHAP authentication should be used. |
| 51 | ISCSI_AUTH_KRB5 |
| 52 | Indicates Kerberos 5 authentication (fur future use). |
| 53 | ISCSI_AUTH_SRP |
| 54 | Indicates SRP authentication (for future use). |
| 55 | */ |
| 56 | |
| 57 | typedef struct { |
| 58 | unsigned int mutual_auth:1; |
| 59 | unsigned int is_secure:1; |
| 60 | unsigned int auth_number:4; |
| 61 | iscsi_auth_types_t auth_type[ISCSI_AUTH_OPTIONS]; |
| 62 | } iscsi_auth_info_t; |
| 63 | |
| 64 | /* |
| 65 | mutual_auth |
| 66 | Indicates that authentication should be mutual, i.e. |
| 67 | the initiator should authenticate the target, and the target |
| 68 | should authenticate the initiator. If not specified, the target |
| 69 | will authenticate the initiator only. |
| 70 | is_secure |
| 71 | Indicates that the connection is secure. |
| 72 | auth_number |
| 73 | Indicates the number of elements in auth_type. |
| 74 | When 0, no authentication will be used. |
| 75 | auth_type |
| 76 | Contains up to ISCSI_AUTH_OPTIONS enumerator values of type |
| 77 | ISCSI_AUTH_TYPES that indicates the authentication method that |
| 78 | should be used to establish a login connection (none, CHAP, KRB5, |
| 79 | etc.), in order of priority. The first element is the most |
| 80 | preferred method, the last element the least preferred. |
| 81 | |
| 82 | */ |
| 83 | |
| 84 | typedef enum { |
| 85 | ISCSI_DIGEST_None = 0, |
| 86 | ISCSI_DIGEST_CRC32C = 1 |
| 87 | } iscsi_digest_t; |
| 88 | |
| 89 | /* |
| 90 | ISCSI_DIGEST_None |
| 91 | Indicates that no CRC is to be generated. |
| 92 | ISCSI_DIGEST_CRC32C |
| 93 | Indicates the CRC32C digest should be used. |
| 94 | */ |
| 95 | |
| 96 | typedef enum { |
| 97 | ISCSI_LOGINTYPE_DISCOVERY = 0, |
| 98 | ISCSI_LOGINTYPE_NOMAP = 1, |
| 99 | ISCSI_LOGINTYPE_MAP = 2 |
| 100 | } iscsi_login_session_type_t; |
| 101 | |
| 102 | /* |
| 103 | ISCSI_LOGINTYPE_DISCOVERY |
| 104 | Indicates that the login session is for discovery only. |
| 105 | Initiators use this type of session to send a SCSI SendTargets |
| 106 | command to an iSCSI target to request assistance in |
| 107 | discovering other targets accessible to the target that |
| 108 | receives the SendTargets command. |
| 109 | ISCSI_LOGINTYPE_NOMAP |
| 110 | This establishes a normal (full featured) session, but does |
| 111 | not report the target LUNs to the operating system as |
| 112 | available drives. Communication with the target is limited |
| 113 | to io-controls through the driver. |
| 114 | ISCSI_LOGINTYPE_MAP |
| 115 | Indicates that the login session is full featured, and reports |
| 116 | all target LUNs to the operating system to map as logical drives. |
| 117 | */ |
| 118 | |
| 119 | typedef struct { |
| 120 | uint8_t address[ISCSI_ADDRESS_LENGTH]; |
| 121 | uint16_t port; |
| 122 | uint16_t group_tag; |
| 123 | } iscsi_portal_address_t; |
| 124 | |
| 125 | /* |
| 126 | address |
| 127 | IP address of the target (V4 dotted quad or V6 hex). |
| 128 | port |
| 129 | IP port number. |
| 130 | group_tag |
| 131 | Target portal group tag (0 if unknown). |
| 132 | */ |
| 133 | |
| 134 | |
| 135 | /* ------------------------- Status Values -------------------------- */ |
| 136 | |
| 137 | #define ISCSI_STATUS_SUCCESS 0 /* Indicates success. */ |
| 138 | #define ISCSI_STATUS_LIST_EMPTY 1 /* The requested list is empty. */ |
| 139 | #define ISCSI_STATUS_DUPLICATE_NAME 2 /* The specified symbolic identifier is not unique. */ |
| 140 | #define ISCSI_STATUS_GENERAL_ERROR 3 /* A non-specific error occurred. */ |
| 141 | #define ISCSI_STATUS_LOGIN_FAILED 4 /* The login failed. */ |
| 142 | #define ISCSI_STATUS_CONNECTION_FAILED 5 /* The attempt to establish a connection failed. */ |
| 143 | #define ISCSI_STATUS_AUTHENTICATION_FAILED 6 /* Authentication negotiation failed. */ |
| 144 | #define ISCSI_STATUS_NO_RESOURCES 7 /* Could not allocate resources (e.g. memory). */ |
| 145 | #define ISCSI_STATUS_MAXED_CONNECTIONS 8 /* Maximum number of connections exceeded. */ |
| 146 | #define ISCSI_STATUS_INVALID_SESSION_ID 9 /* Session ID not found */ |
| 147 | #define ISCSI_STATUS_INVALID_CONNECTION_ID 10 /* Connection ID not found */ |
| 148 | #define ISCSI_STATUS_INVALID_SOCKET 11 /* Specified socket is invalid */ |
| 149 | #define ISCSI_STATUS_NOTIMPL 12 /* Feature not implemented */ |
| 150 | #define ISCSI_STATUS_CHECK_CONDITION 13 /* Target reported CHECK CONDITION */ |
| 151 | #define ISCSI_STATUS_TARGET_BUSY 14 /* Target reported BUSY */ |
| 152 | #define ISCSI_STATUS_TARGET_ERROR 15 /* Target reported other error */ |
| 153 | #define ISCSI_STATUS_TARGET_FAILURE 16 /* Command Response was Target Failure */ |
| 154 | #define ISCSI_STATUS_TARGET_DROP 17 /* Target dropped connection */ |
| 155 | #define ISCSI_STATUS_SOCKET_ERROR 18 /* Communication failure */ |
| 156 | #define ISCSI_STATUS_PARAMETER_MISSING 19 /* A required ioctl parameter is missing */ |
| 157 | #define ISCSI_STATUS_PARAMETER_INVALID 20 /* A parameter is malformed (string too long etc.) */ |
| 158 | #define ISCSI_STATUS_MAP_FAILED 21 /* Mapping the LUNs failed */ |
| 159 | #define ISCSI_STATUS_NO_INITIATOR_NAME 22 /* Initiator name was not set */ |
| 160 | #define ISCSI_STATUS_NEGOTIATION_ERROR 23 /* Negotiation failure (invalid key or value) */ |
| 161 | #define ISCSI_STATUS_TIMEOUT 24 /* Command timed out (at iSCSI level) */ |
| 162 | #define ISCSI_STATUS_PROTOCOL_ERROR 25 /* Internal Error (Protocol error reject) */ |
| 163 | #define ISCSI_STATUS_PDU_ERROR 26 /* Internal Error (Invalid PDU field reject) */ |
| 164 | #define ISCSI_STATUS_CMD_NOT_SUPPORTED 27 /* Target does not support iSCSI command */ |
| 165 | #define ISCSI_STATUS_DRIVER_UNLOAD 28 /* Driver is unloading */ |
| 166 | #define ISCSI_STATUS_LOGOUT 29 /* Session was logged out */ |
| 167 | #define ISCSI_STATUS_PDUS_LOST 30 /* Excessive PDU loss */ |
| 168 | #define ISCSI_STATUS_INVALID_EVENT_ID 31 /* Invalid Event ID */ |
| 169 | #define ISCSI_STATUS_EVENT_DEREGISTERED 32 /* Wait for event cancelled by deregistration */ |
| 170 | #define ISCSI_STATUS_EVENT_WAITING 33 /* Someone is already waiting for this event */ |
| 171 | #define ISCSI_STATUS_TASK_NOT_FOUND 34 /* Task Management: task not found */ |
| 172 | #define ISCSI_STATUS_LUN_NOT_FOUND 35 /* Task Management: LUN not found */ |
| 173 | #define ISCSI_STATUS_TASK_ALLEGIANT 36 /* Task Management: Task still allegiant */ |
| 174 | #define ISCSI_STATUS_CANT_REASSIGN 37 /* Task Management: Task reassignment not supported */ |
| 175 | #define ISCSI_STATUS_FUNCTION_UNSUPPORTED 38 /* Task Management: Function unsupported */ |
| 176 | #define ISCSI_STATUS_FUNCTION_NOT_AUTHORIZED 39 /* Task Management: Function not authorized */ |
| 177 | #define ISCSI_STATUS_FUNCTION_REJECTED 40 /* Task Management: Function rejected */ |
| 178 | #define ISCSI_STATUS_UNKNOWN_REASON 41 /* Task Management: Unknown reason code */ |
| 179 | #define ISCSI_STATUS_DUPLICATE_ID 42 /* Given ID is a duplicate */ |
| 180 | #define ISCSI_STATUS_INVALID_ID 43 /* Given ID was not found */ |
| 181 | #define ISCSI_STATUS_TARGET_LOGOUT 44 /* Target requested logout */ |
| 182 | #define ISCSI_STATUS_LOGOUT_CID_NOT_FOUND 45 /* Logout error: CID not found */ |
| 183 | #define ISCSI_STATUS_LOGOUT_RECOVERY_NS 46 /* Logout error: Recovery not supported */ |
| 184 | #define ISCSI_STATUS_LOGOUT_ERROR 47 /* Logout error: Unknown reason */ |
| 185 | #define ISCSI_STATUS_QUEUE_FULL 48 /* iSCSI send window exhausted */ |
| 186 | |
| 187 | #define ISCSID_STATUS_SUCCESS 0 /* Indicates success. */ |
| 188 | #define ISCSID_STATUS_LIST_EMPTY 1001 /* The requested list is empty. */ |
| 189 | #define ISCSID_STATUS_DUPLICATE_NAME 1002 /* The specified name is not unique. */ |
| 190 | #define ISCSID_STATUS_GENERAL_ERROR 1003 /* A non-specific error occurred. */ |
| 191 | #define ISCSID_STATUS_CONNECT_ERROR 1005 /* Failed to connect to target */ |
| 192 | #define ISCSID_STATUS_NO_RESOURCES 1007 /* Could not allocate resources (e.g. memory). */ |
| 193 | #define ISCSID_STATUS_INVALID_SESSION_ID 1009 /* Session ID not found */ |
| 194 | #define ISCSID_STATUS_INVALID_CONNECTION_ID 1010 /* Connection ID not found */ |
| 195 | #define ISCSID_STATUS_NOTIMPL 1012 /* Feature not implemented */ |
| 196 | #define ISCSID_STATUS_SOCKET_ERROR 1018 /* Failed to create socket */ |
| 197 | #define ISCSID_STATUS_PARAMETER_MISSING 1019 /* A required parameter is missing */ |
| 198 | #define ISCSID_STATUS_PARAMETER_INVALID 1020 /* A parameter is malformed (string too long etc.) */ |
| 199 | #define ISCSID_STATUS_INVALID_PARAMETER 1020 /* Alternate spelling of above */ |
| 200 | #define ISCSID_STATUS_NO_INITIATOR_NAME 1022 /* Initiator name was not set */ |
| 201 | #define ISCSID_STATUS_TIMEOUT 1024 /* Request timed out */ |
| 202 | #define ISCSID_STATUS_DRIVER_NOT_LOADED 1028 /* Driver not loaded */ |
| 203 | #define ISCSID_STATUS_INVALID_REQUEST 1101 /* Unknown request code */ |
| 204 | #define ISCSID_STATUS_INVALID_PORTAL_ID 1102 /* Portal ID not found */ |
| 205 | #define ISCSID_STATUS_INVALID_TARGET_ID 1103 /* Target ID not found */ |
| 206 | #define ISCSID_STATUS_NOT_FOUND 1104 /* Search failed */ |
| 207 | #define ISCSID_STATUS_HOST_NOT_FOUND 1105 /* Target address not found */ |
| 208 | #define ISCSID_STATUS_HOST_TRY_AGAIN 1106 /* Target address retreival failed, try again later */ |
| 209 | #define ISCSID_STATUS_HOST_ERROR 1107 /* Target address invalid */ |
| 210 | #define ISCSID_STATUS_NO_TARGETS_FOUND 1108 /* No targets found during refresh */ |
| 211 | #define ISCSID_STATUS_INVALID_ISNS_ID 1111 /* iSNS ID not found */ |
| 212 | #define ISCSID_STATUS_ISNS_ERROR 1112 /* Problem connecting to iSNS */ |
| 213 | #define ISCSID_STATUS_ISNS_SERVER_ERROR 1113 /* iSNS server returned garbage */ |
| 214 | #define ISCSID_STATUS_DUPLICATE_ENTRY 1114 /* The specified entry already exists */ |
| 215 | #define ISCSID_STATUS_INVALID_INITIATOR_ID 1115 /* Initiator ID not found */ |
| 216 | #define ISCSID_STATUS_INITIATOR_BIND_ERROR 1116 /* Bind to initiator portal failed */ |
| 217 | |
| 218 | #endif /* !_ISCSI_H */ |
| 219 | |