Deleted Added
full compact
isp_stds.h (197373) isp_stds.h (238869)
1/* $FreeBSD: head/sys/dev/isp/isp_stds.h 197373 2009-09-21 01:41:19Z mjacob $ */
1/* $FreeBSD: head/sys/dev/isp/isp_stds.h 238869 2012-07-28 20:06:29Z mjacob $ */
2/*-
3 * Copyright (c) 1997-2009 by Matthew Jacob
4 * All rights reserved.
5 *
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
8 * are met:
9 *
10 * 1. Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 * 2. Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in the
14 * documentation and/or other materials provided with the distribution.
15 *
16 * THIS SOFTWARE IS PROVIDED BY AUTHOR AND CONTRIBUTORS ``AS IS'' AND
17 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19 * ARE DISCLAIMED. IN NO EVENT SHALL AUTHOR OR CONTRIBUTORS BE LIABLE
20 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
22 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
23 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
24 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
25 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26 * SUCH DAMAGE.
27 *
28 */
29/*
30 * Structures that derive directly from public standards.
31 */
32#ifndef _ISP_STDS_H
33#define _ISP_STDS_H
34/*
35 * FC Frame Header
36 *
37 * Source: dpANS-X3.xxx-199x, section 18 (AKA FC-PH-2)
38 *
39 */
40typedef struct {
41 uint8_t r_ctl;
42 uint8_t d_id[3];
43 uint8_t cs_ctl;
44 uint8_t s_id[3];
45 uint8_t type;
46 uint8_t f_ctl[3];
47 uint8_t seq_id;
48 uint8_t df_ctl;
49 uint16_t seq_cnt;
50 uint16_t ox_id;
51 uint16_t rx_id;
52 uint32_t parameter;
53} fc_hdr_t;
54
55/*
56 * FCP_CMND_IU Payload
57 *
58 * Source: NICTS T10, Project 1144D, Revision 07a, Section 9 (AKA fcp2-r07a)
59 *
60 * Notes:
61 * When additional cdb length is defined in fcp_cmnd_alen_datadir,
62 * bits 2..7, the actual cdb length is 16 + ((fcp_cmnd_alen_datadir>>2)*4),
63 * with the datalength following in MSB format just after.
64 */
65typedef struct {
66 uint8_t fcp_cmnd_lun[8];
67 uint8_t fcp_cmnd_crn;
68 uint8_t fcp_cmnd_task_attribute;
69 uint8_t fcp_cmnd_task_management;
70 uint8_t fcp_cmnd_alen_datadir;
71 union {
72 struct {
73 uint8_t fcp_cmnd_cdb[16];
74 uint32_t fcp_cmnd_dl;
75 } sf;
76 struct {
77 uint8_t fcp_cmnd_cdb[1];
78 } lf;
79 } cdb_dl;
80} fcp_cmnd_iu_t;
81
82
83#define FCP_CMND_TASK_ATTR_SIMPLE 0x00
84#define FCP_CMND_TASK_ATTR_HEAD 0x01
85#define FCP_CMND_TASK_ATTR_ORDERED 0x02
86#define FCP_CMND_TASK_ATTR_ACA 0x04
87#define FCP_CMND_TASK_ATTR_UNTAGGED 0x05
88#define FCP_CMND_TASK_ATTR_MASK 0x07
89
90#define FCP_CMND_ADDTL_CDBLEN_SHIFT 2
91
92#define FCP_CMND_DATA_WRITE 0x01
93#define FCP_CMND_DATA_READ 0x02
94
95#define FCP_CMND_DATA_DIR_MASK 0x03
96
97#define FCP_CMND_TMF_CLEAR_ACA 0x40
98#define FCP_CMND_TMF_TGT_RESET 0x20
99#define FCP_CMND_TMF_LUN_RESET 0x10
100#define FCP_CMND_TMF_CLEAR_TASK_SET 0x04
101#define FCP_CMND_TMF_ABORT_TASK_SET 0x02
102
103/*
104 * Basic CT IU Header
105 *
106 * Source: X3.288-199x Generic Services 2 Rev 5.3 (FC-GS-2) Section 4.3.1
107 */
108
109typedef struct {
110 uint8_t ct_revision;
111 uint8_t ct_in_id[3];
112 uint8_t ct_fcs_type;
113 uint8_t ct_fcs_subtype;
114 uint8_t ct_options;
115 uint8_t ct_reserved0;
116 uint16_t ct_cmd_resp;
117 uint16_t ct_bcnt_resid;
118 uint8_t ct_reserved1;
119 uint8_t ct_reason;
120 uint8_t ct_explanation;
121 uint8_t ct_vunique;
122} ct_hdr_t;
123#define CT_REVISION 1
124#define CT_FC_TYPE_FC 0xFC
125#define CT_FC_SUBTYPE_NS 0x02
126
127/*
128 * RFT_ID Requet CT_IU
129 *
130 * Source: NCITS xxx-200x Generic Services- 5 Rev 8.5 Section 5.2.5.30
131 */
132typedef struct {
133 ct_hdr_t rftid_hdr;
134 uint8_t rftid_reserved;
135 uint8_t rftid_portid[3];
136 uint32_t rftid_fc4types[8];
137} rft_id_t;
138
139/*
2/*-
3 * Copyright (c) 1997-2009 by Matthew Jacob
4 * All rights reserved.
5 *
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
8 * are met:
9 *
10 * 1. Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 * 2. Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in the
14 * documentation and/or other materials provided with the distribution.
15 *
16 * THIS SOFTWARE IS PROVIDED BY AUTHOR AND CONTRIBUTORS ``AS IS'' AND
17 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19 * ARE DISCLAIMED. IN NO EVENT SHALL AUTHOR OR CONTRIBUTORS BE LIABLE
20 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
22 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
23 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
24 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
25 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26 * SUCH DAMAGE.
27 *
28 */
29/*
30 * Structures that derive directly from public standards.
31 */
32#ifndef _ISP_STDS_H
33#define _ISP_STDS_H
34/*
35 * FC Frame Header
36 *
37 * Source: dpANS-X3.xxx-199x, section 18 (AKA FC-PH-2)
38 *
39 */
40typedef struct {
41 uint8_t r_ctl;
42 uint8_t d_id[3];
43 uint8_t cs_ctl;
44 uint8_t s_id[3];
45 uint8_t type;
46 uint8_t f_ctl[3];
47 uint8_t seq_id;
48 uint8_t df_ctl;
49 uint16_t seq_cnt;
50 uint16_t ox_id;
51 uint16_t rx_id;
52 uint32_t parameter;
53} fc_hdr_t;
54
55/*
56 * FCP_CMND_IU Payload
57 *
58 * Source: NICTS T10, Project 1144D, Revision 07a, Section 9 (AKA fcp2-r07a)
59 *
60 * Notes:
61 * When additional cdb length is defined in fcp_cmnd_alen_datadir,
62 * bits 2..7, the actual cdb length is 16 + ((fcp_cmnd_alen_datadir>>2)*4),
63 * with the datalength following in MSB format just after.
64 */
65typedef struct {
66 uint8_t fcp_cmnd_lun[8];
67 uint8_t fcp_cmnd_crn;
68 uint8_t fcp_cmnd_task_attribute;
69 uint8_t fcp_cmnd_task_management;
70 uint8_t fcp_cmnd_alen_datadir;
71 union {
72 struct {
73 uint8_t fcp_cmnd_cdb[16];
74 uint32_t fcp_cmnd_dl;
75 } sf;
76 struct {
77 uint8_t fcp_cmnd_cdb[1];
78 } lf;
79 } cdb_dl;
80} fcp_cmnd_iu_t;
81
82
83#define FCP_CMND_TASK_ATTR_SIMPLE 0x00
84#define FCP_CMND_TASK_ATTR_HEAD 0x01
85#define FCP_CMND_TASK_ATTR_ORDERED 0x02
86#define FCP_CMND_TASK_ATTR_ACA 0x04
87#define FCP_CMND_TASK_ATTR_UNTAGGED 0x05
88#define FCP_CMND_TASK_ATTR_MASK 0x07
89
90#define FCP_CMND_ADDTL_CDBLEN_SHIFT 2
91
92#define FCP_CMND_DATA_WRITE 0x01
93#define FCP_CMND_DATA_READ 0x02
94
95#define FCP_CMND_DATA_DIR_MASK 0x03
96
97#define FCP_CMND_TMF_CLEAR_ACA 0x40
98#define FCP_CMND_TMF_TGT_RESET 0x20
99#define FCP_CMND_TMF_LUN_RESET 0x10
100#define FCP_CMND_TMF_CLEAR_TASK_SET 0x04
101#define FCP_CMND_TMF_ABORT_TASK_SET 0x02
102
103/*
104 * Basic CT IU Header
105 *
106 * Source: X3.288-199x Generic Services 2 Rev 5.3 (FC-GS-2) Section 4.3.1
107 */
108
109typedef struct {
110 uint8_t ct_revision;
111 uint8_t ct_in_id[3];
112 uint8_t ct_fcs_type;
113 uint8_t ct_fcs_subtype;
114 uint8_t ct_options;
115 uint8_t ct_reserved0;
116 uint16_t ct_cmd_resp;
117 uint16_t ct_bcnt_resid;
118 uint8_t ct_reserved1;
119 uint8_t ct_reason;
120 uint8_t ct_explanation;
121 uint8_t ct_vunique;
122} ct_hdr_t;
123#define CT_REVISION 1
124#define CT_FC_TYPE_FC 0xFC
125#define CT_FC_SUBTYPE_NS 0x02
126
127/*
128 * RFT_ID Requet CT_IU
129 *
130 * Source: NCITS xxx-200x Generic Services- 5 Rev 8.5 Section 5.2.5.30
131 */
132typedef struct {
133 ct_hdr_t rftid_hdr;
134 uint8_t rftid_reserved;
135 uint8_t rftid_portid[3];
136 uint32_t rftid_fc4types[8];
137} rft_id_t;
138
139/*
140 * FCP Response IU Bits of interest
141 * Source: NCITS T10, Project 1144D, Revision 08 (aka FCP2r08)
140 * FCP Response IU and bits of interest
141 * Source: NCITS T10, Project 1828D, Revision 02b (aka FCP4r02b)
142 */
142 */
143typedef struct {
144 uint8_t fcp_rsp_reserved[8];
145 uint16_t fcp_rsp_status_qualifier; /* SAM-5 Status Qualifier */
146 uint8_t fcp_rsp_bits;
147 uint8_t fcp_rsp_scsi_status; /* SAM-5 SCSI Status Byte */
148 uint32_t fcp_rsp_resid;
149 uint32_t fcp_rsp_snslen;
150 uint32_t fcp_rsp_rsplen;
151 /*
152 * In the bytes that follow, it's going to be
153 * FCP RESPONSE INFO (max 8 bytes, possibly 0)
154 * FCP SENSE INFO (if any)
155 * FCP BIDIRECTIONAL READ RESID (if any)
156 */
157 uint8_t fcp_rsp_extra[0];
158} fcp_rsp_iu_t;
159#define MIN_FCP_RESPONSE_SIZE 24
160
161#define FCP_BIDIR_RSP 0x80 /* Bi-Directional response */
162#define FCP_BIDIR_RESID_UNDERFLOW 0x40
163#define FCP_BIDIR_RESID_OVERFLOW 0x20
143#define FCP_CONF_REQ 0x10
144#define FCP_RESID_UNDERFLOW 0x08
145#define FCP_RESID_OVERFLOW 0x04
146#define FCP_SNSLEN_VALID 0x02
147#define FCP_RSPLEN_VALID 0x01
148
149#define FCP_MAX_RSPLEN 0x08
150/*
151 * FCP Response Code Definitions
152 * Source: NCITS T10, Project 1144D, Revision 08 (aka FCP2r08)
153 */
154#define FCP_RSPNS_CODE_OFFSET 3
155
156#define FCP_RSPNS_TMF_DONE 0
157#define FCP_RSPNS_DLBRSTX 1
158#define FCP_RSPNS_BADCMND 2
159#define FCP_RSPNS_EROFS 3
160#define FCP_RSPNS_TMF_REJECT 4
161#define FCP_RSPNS_TMF_FAILED 5
162#define FCP_RSPNS_TMF_SUCCEEDED 8
163#define FCP_RSPNS_TMF_INCORRECT_LUN 9
164
164#define FCP_CONF_REQ 0x10
165#define FCP_RESID_UNDERFLOW 0x08
166#define FCP_RESID_OVERFLOW 0x04
167#define FCP_SNSLEN_VALID 0x02
168#define FCP_RSPLEN_VALID 0x01
169
170#define FCP_MAX_RSPLEN 0x08
171/*
172 * FCP Response Code Definitions
173 * Source: NCITS T10, Project 1144D, Revision 08 (aka FCP2r08)
174 */
175#define FCP_RSPNS_CODE_OFFSET 3
176
177#define FCP_RSPNS_TMF_DONE 0
178#define FCP_RSPNS_DLBRSTX 1
179#define FCP_RSPNS_BADCMND 2
180#define FCP_RSPNS_EROFS 3
181#define FCP_RSPNS_TMF_REJECT 4
182#define FCP_RSPNS_TMF_FAILED 5
183#define FCP_RSPNS_TMF_SUCCEEDED 8
184#define FCP_RSPNS_TMF_INCORRECT_LUN 9
185
186/*
187 * R_CTL field definitions
188 *
189 * Bits 31-28 are ROUTING
190 * Bits 27-24 are INFORMATION
191 *
192 * These are nibble values, not bits
193 */
194#define R_CTL_ROUTE_DATA 0x00
195#define R_CTL_ROUTE_ELS 0x02
196#define R_CTL_ROUTE_FC4_LINK 0x03
197#define R_CTL_ROUTE_VDATA 0x04
198#define R_CTL_ROUTE_EXENDED 0x05
199#define R_CTL_ROUTE_BASIC 0x08
200#define R_CTL_ROUTE_LINK 0x0c
201#define R_CTL_ROUTE_EXT_ROUTING 0x0f
165
202
203#define R_CTL_INFO_UNCATEGORIZED 0x00
204#define R_CTL_INFO_SOLICITED_DATA 0x01
205#define R_CTL_INFO_UNSOLICITED_CONTROL 0x02
206#define R_CTL_INFO_SOLICITED_CONTROL 0x03
207#define R_CTL_INFO_UNSOLICITED_DATA 0x04
208#define R_CTL_INFO_DATA_DESCRIPTOR 0x05
209#define R_CTL_INFO_UNSOLICITED_COMMAND 0x06
210#define R_CTL_INFO_COMMAND_STATUS 0x07
211
212#define MAKE_RCTL(a, b) (((a) << 4) | (b))
213
166/* unconverted miscellany */
167/*
168 * Basic FC Link Service defines
169 */
214/* unconverted miscellany */
215/*
216 * Basic FC Link Service defines
217 */
170/*
171 * These are in the R_CTL field.
172 */
173#define ABTS 0x81
174#define BA_ACC 0x84 /* of ABORT SEQUENCE */
175#define BA_RJT 0x85 /* of ABORT SEQUENCE */
218/* #define ABTS MAKE_RCTL(R_CTL_ROUTE_BASIC, R_CTL_INFO_SOLICITED_DATA) */
219#define BA_ACC MAKE_RCTL(R_CTL_ROUTE_BASIC, R_CTL_INFO_UNSOLICITED_DATA) /* of ABORT */
220#define BA_RJT MAKE_RCTL(R_CTL_ROUTE_BASIC, R_CTL_INFO_DATA_DESCRIPTOR) /* of ABORT */
176
177/*
178 * Link Service Accept/Reject
179 */
180#define LS_ACC 0x8002
181#define LS_RJT 0x8001
182
183/*
184 * FC ELS Codes- bits 31-24 of the first payload word of an ELS frame.
185 */
186#define PLOGI 0x03
187#define FLOGI 0x04
188#define LOGO 0x05
189#define ABTX 0x06
190#define PRLI 0x20
191#define PRLO 0x21
192#define SCN 0x22
193#define TPRLO 0x24
194#define PDISC 0x50
195#define ADISC 0x52
196#define RNC 0x53
197
198/*
221
222/*
223 * Link Service Accept/Reject
224 */
225#define LS_ACC 0x8002
226#define LS_RJT 0x8001
227
228/*
229 * FC ELS Codes- bits 31-24 of the first payload word of an ELS frame.
230 */
231#define PLOGI 0x03
232#define FLOGI 0x04
233#define LOGO 0x05
234#define ABTX 0x06
235#define PRLI 0x20
236#define PRLO 0x21
237#define SCN 0x22
238#define TPRLO 0x24
239#define PDISC 0x50
240#define ADISC 0x52
241#define RNC 0x53
242
243/*
244 * PRLI Word 3 definitions
245 * FPC4-r02b January, 2011
246 */
247#define PRLI_WD3_ENHANCED_DISCOVERY (1 << 11)
248#define PRLI_WD3_REC_SUPPORT (1 << 10)
249#define PRLI_WD3_TASK_RETRY_IDENTIFICATION_REQUESTED (1 << 9)
250#define PRLI_WD3_RETRY (1 << 8)
251#define PRLI_WD3_CONFIRMED_COMPLETION_ALLOWED (1 << 7)
252#define PRLI_WD3_DATA_OVERLAY_ALLOWED (1 << 6)
253#define PRLI_WD3_INITIATOR_FUNCTION (1 << 5)
254#define PRLI_WD3_TARGET_FUNCTION (1 << 4)
255#define PRLI_WD3_READ_FCP_XFER_RDY_DISABLED (1 << 1) /* definitely supposed to be set */
256#define PRLI_WD3_WRITE_FCP_XFER_RDY_DISABLED (1 << 0)
257
258
259
260/*
199 * FC4 defines
200 */
201#define FC4_IP 5 /* ISO/EEC 8802-2 LLC/SNAP */
202#define FC4_SCSI 8 /* SCSI-3 via Fibre Channel Protocol (FCP) */
203#define FC4_FC_SVC 0x20 /* Fibre Channel Services */
204
205#ifndef MSG_ABORT
206#define MSG_ABORT 0x06
207#endif
208#ifndef MSG_BUS_DEV_RESET
209#define MSG_BUS_DEV_RESET 0x0c
210#endif
211#ifndef MSG_ABORT_TAG
212#define MSG_ABORT_TAG 0x0d
213#endif
214#ifndef MSG_CLEAR_QUEUE
215#define MSG_CLEAR_QUEUE 0x0e
216#endif
217#ifndef MSG_REL_RECOVERY
218#define MSG_REL_RECOVERY 0x10
219#endif
220#ifndef MSG_TERM_IO_PROC
221#define MSG_TERM_IO_PROC 0x11
222#endif
223#ifndef MSG_LUN_RESET
224#define MSG_LUN_RESET 0x17
225#endif
226
227#endif /* _ISP_STDS_H */
261 * FC4 defines
262 */
263#define FC4_IP 5 /* ISO/EEC 8802-2 LLC/SNAP */
264#define FC4_SCSI 8 /* SCSI-3 via Fibre Channel Protocol (FCP) */
265#define FC4_FC_SVC 0x20 /* Fibre Channel Services */
266
267#ifndef MSG_ABORT
268#define MSG_ABORT 0x06
269#endif
270#ifndef MSG_BUS_DEV_RESET
271#define MSG_BUS_DEV_RESET 0x0c
272#endif
273#ifndef MSG_ABORT_TAG
274#define MSG_ABORT_TAG 0x0d
275#endif
276#ifndef MSG_CLEAR_QUEUE
277#define MSG_CLEAR_QUEUE 0x0e
278#endif
279#ifndef MSG_REL_RECOVERY
280#define MSG_REL_RECOVERY 0x10
281#endif
282#ifndef MSG_TERM_IO_PROC
283#define MSG_TERM_IO_PROC 0x11
284#endif
285#ifndef MSG_LUN_RESET
286#define MSG_LUN_RESET 0x17
287#endif
288
289#endif /* _ISP_STDS_H */