1163899Smjacob/* $FreeBSD: releng/11.0/sys/dev/isp/isp_stds.h 297751 2016-04-09 14:50:47Z mav $ */
2163899Smjacob/*-
3196008Smjacob *  Copyright (c) 1997-2009 by Matthew Jacob
4167403Smjacob *  All rights reserved.
5167403Smjacob *
6167403Smjacob *  Redistribution and use in source and binary forms, with or without
7167403Smjacob *  modification, are permitted provided that the following conditions
8167403Smjacob *  are met:
9167403Smjacob *
10167403Smjacob *  1. Redistributions of source code must retain the above copyright
11167403Smjacob *     notice, this list of conditions and the following disclaimer.
12167403Smjacob *  2. Redistributions in binary form must reproduce the above copyright
13167403Smjacob *     notice, this list of conditions and the following disclaimer in the
14167403Smjacob *     documentation and/or other materials provided with the distribution.
15167403Smjacob *
16167403Smjacob *  THIS SOFTWARE IS PROVIDED BY AUTHOR AND CONTRIBUTORS ``AS IS'' AND
17167403Smjacob *  ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18167403Smjacob *  IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19167403Smjacob *  ARE DISCLAIMED.  IN NO EVENT SHALL AUTHOR OR CONTRIBUTORS BE LIABLE
20167403Smjacob *  FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21167403Smjacob *  DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
22167403Smjacob *  OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
23167403Smjacob *  HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
24167403Smjacob *  LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
25167403Smjacob *  OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26167403Smjacob *  SUCH DAMAGE.
27196008Smjacob *
28163899Smjacob */
29163899Smjacob/*
30163899Smjacob * Structures that derive directly from public standards.
31163899Smjacob */
32163899Smjacob#ifndef	_ISP_STDS_H
33163899Smjacob#define	_ISP_STDS_H
34163899Smjacob/*
35163899Smjacob * FC Frame Header
36163899Smjacob *
37163899Smjacob * Source: dpANS-X3.xxx-199x, section 18 (AKA FC-PH-2)
38163899Smjacob *
39163899Smjacob */
40163899Smjacobtypedef struct {
41163899Smjacob	uint8_t		r_ctl;
42163899Smjacob	uint8_t		d_id[3];
43163899Smjacob	uint8_t		cs_ctl;
44163899Smjacob	uint8_t		s_id[3];
45163899Smjacob	uint8_t		type;
46196008Smjacob	uint8_t		f_ctl[3];
47163899Smjacob	uint8_t		seq_id;
48163899Smjacob	uint8_t		df_ctl;
49163899Smjacob	uint16_t	seq_cnt;
50163899Smjacob	uint16_t	ox_id;
51163899Smjacob	uint16_t	rx_id;
52163899Smjacob	uint32_t	parameter;
53163899Smjacob} fc_hdr_t;
54163899Smjacob
55163899Smjacob/*
56163899Smjacob * FCP_CMND_IU Payload
57163899Smjacob *
58163899Smjacob * Source: NICTS T10, Project 1144D, Revision 07a, Section 9 (AKA fcp2-r07a)
59163899Smjacob *
60163899Smjacob * Notes:
61163899Smjacob *	When additional cdb length is defined in fcp_cmnd_alen_datadir,
62163899Smjacob * 	bits 2..7, the actual cdb length is 16 + ((fcp_cmnd_alen_datadir>>2)*4),
63163899Smjacob *	with the datalength following in MSB format just after.
64163899Smjacob */
65163899Smjacobtypedef struct {
66163899Smjacob	uint8_t		fcp_cmnd_lun[8];
67163899Smjacob	uint8_t		fcp_cmnd_crn;
68163899Smjacob	uint8_t		fcp_cmnd_task_attribute;
69163899Smjacob	uint8_t		fcp_cmnd_task_management;
70163899Smjacob	uint8_t		fcp_cmnd_alen_datadir;
71163899Smjacob	union {
72163899Smjacob		struct {
73163899Smjacob			uint8_t		fcp_cmnd_cdb[16];
74163899Smjacob			uint32_t	fcp_cmnd_dl;
75163899Smjacob		} sf;
76163899Smjacob		struct {
77163899Smjacob			uint8_t		fcp_cmnd_cdb[1];
78163899Smjacob		} lf;
79163899Smjacob	} cdb_dl;
80163899Smjacob} fcp_cmnd_iu_t;
81163899Smjacob
82163899Smjacob
83163899Smjacob#define	FCP_CMND_TASK_ATTR_SIMPLE	0x00
84163899Smjacob#define	FCP_CMND_TASK_ATTR_HEAD		0x01
85163899Smjacob#define	FCP_CMND_TASK_ATTR_ORDERED	0x02
86163899Smjacob#define	FCP_CMND_TASK_ATTR_ACA		0x04
87163899Smjacob#define	FCP_CMND_TASK_ATTR_UNTAGGED	0x05
88163899Smjacob#define	FCP_CMND_TASK_ATTR_MASK		0x07
89163899Smjacob
90163899Smjacob#define	FCP_CMND_ADDTL_CDBLEN_SHIFT	2
91163899Smjacob
92163899Smjacob#define	FCP_CMND_DATA_WRITE		0x01
93163899Smjacob#define	FCP_CMND_DATA_READ		0x02
94163899Smjacob
95163899Smjacob#define	FCP_CMND_DATA_DIR_MASK		0x03
96163899Smjacob
97163899Smjacob#define	FCP_CMND_TMF_CLEAR_ACA		0x40
98163899Smjacob#define	FCP_CMND_TMF_TGT_RESET		0x20
99163899Smjacob#define	FCP_CMND_TMF_LUN_RESET		0x10
100289843Smav#define	FCP_CMND_TMF_QUERY_ASYNC_EVENT	0x08
101163899Smjacob#define	FCP_CMND_TMF_CLEAR_TASK_SET	0x04
102163899Smjacob#define	FCP_CMND_TMF_ABORT_TASK_SET	0x02
103289843Smav#define	FCP_CMND_TMF_QUERY_TASK_SET	0x01
104163899Smjacob
105163899Smjacob/*
106163899Smjacob * Basic CT IU Header
107163899Smjacob *
108163899Smjacob * Source: X3.288-199x Generic Services 2 Rev 5.3 (FC-GS-2) Section 4.3.1
109163899Smjacob */
110163899Smjacob
111163899Smjacobtypedef struct {
112163899Smjacob	uint8_t		ct_revision;
113163899Smjacob	uint8_t		ct_in_id[3];
114163899Smjacob	uint8_t		ct_fcs_type;
115163899Smjacob	uint8_t		ct_fcs_subtype;
116163899Smjacob	uint8_t		ct_options;
117163899Smjacob	uint8_t		ct_reserved0;
118163899Smjacob	uint16_t	ct_cmd_resp;
119163899Smjacob	uint16_t	ct_bcnt_resid;
120163899Smjacob	uint8_t		ct_reserved1;
121163899Smjacob	uint8_t		ct_reason;
122163899Smjacob	uint8_t		ct_explanation;
123163899Smjacob	uint8_t		ct_vunique;
124163899Smjacob} ct_hdr_t;
125163899Smjacob#define	CT_REVISION		1
126163899Smjacob#define	CT_FC_TYPE_FC		0xFC
127163899Smjacob#define CT_FC_SUBTYPE_NS	0x02
128163899Smjacob
129163899Smjacob/*
130163899Smjacob * RFT_ID Requet CT_IU
131163899Smjacob *
132164272Smjacob * Source: NCITS xxx-200x Generic Services- 5 Rev 8.5 Section 5.2.5.30
133163899Smjacob */
134163899Smjacobtypedef struct {
135163899Smjacob	ct_hdr_t	rftid_hdr;
136163899Smjacob	uint8_t		rftid_reserved;
137163899Smjacob	uint8_t		rftid_portid[3];
138163899Smjacob	uint32_t	rftid_fc4types[8];
139163899Smjacob} rft_id_t;
140163899Smjacob
141164272Smjacob/*
142297751Smav * RSPN_ID Requet CT_IU
143297751Smav *
144297751Smav * Source: INCITS 463-2010 Generic Services 6 Section 5.2.5.32
145297751Smav */
146297751Smavtypedef struct {
147297751Smav	ct_hdr_t	rspnid_hdr;
148297751Smav	uint8_t		rspnid_reserved;
149297751Smav	uint8_t		rspnid_portid[3];
150297751Smav	uint8_t		rspnid_length;
151297751Smav	uint8_t		rspnid_name[0];
152297751Smav} rspn_id_t;
153297751Smav
154297751Smav/*
155291000Smav * RFF_ID Requet CT_IU
156291000Smav *
157291000Smav * Source: INCITS 463-2010 Generic Services 6 Section 5.2.5.34
158291000Smav */
159291000Smavtypedef struct {
160291000Smav	ct_hdr_t	rffid_hdr;
161291000Smav	uint8_t		rffid_reserved;
162291000Smav	uint8_t		rffid_portid[3];
163291000Smav	uint16_t	rffid_reserved2;
164291000Smav	uint8_t		rffid_fc4features;
165291000Smav	uint8_t		rffid_fc4type;
166291000Smav} rff_id_t;
167291000Smav
168291000Smav/*
169297751Smav * RSNN_NN Requet CT_IU
170297751Smav *
171297751Smav * Source: INCITS 463-2010 Generic Services 6 Section 5.2.5.35
172297751Smav */
173297751Smavtypedef struct {
174297751Smav	ct_hdr_t	rsnnnn_hdr;
175297751Smav	uint8_t		rsnnnn_nodename[8];
176297751Smav	uint8_t		rsnnnn_length;
177297751Smav	uint8_t		rsnnnn_name[0];
178297751Smav} rsnn_nn_t;
179297751Smav
180297751Smav/*
181238869Smjacob * FCP Response IU and bits of interest
182238869Smjacob * Source: NCITS T10, Project 1828D, Revision 02b (aka FCP4r02b)
183196008Smjacob */
184238869Smjacobtypedef struct {
185238869Smjacob	uint8_t		fcp_rsp_reserved[8];
186238869Smjacob	uint16_t	fcp_rsp_status_qualifier;	/* SAM-5 Status Qualifier */
187238869Smjacob	uint8_t		fcp_rsp_bits;
188238869Smjacob	uint8_t		fcp_rsp_scsi_status;		/* SAM-5 SCSI Status Byte */
189238869Smjacob	uint32_t	fcp_rsp_resid;
190238869Smjacob	uint32_t	fcp_rsp_snslen;
191238869Smjacob	uint32_t	fcp_rsp_rsplen;
192238869Smjacob	/*
193238869Smjacob	 * In the bytes that follow, it's going to be
194238869Smjacob	 * FCP RESPONSE INFO (max 8 bytes, possibly 0)
195238869Smjacob	 * FCP SENSE INFO (if any)
196238869Smjacob	 * FCP BIDIRECTIONAL READ RESID (if any)
197238869Smjacob	 */
198238869Smjacob	uint8_t		fcp_rsp_extra[0];
199238869Smjacob} fcp_rsp_iu_t;
200238869Smjacob#define	MIN_FCP_RESPONSE_SIZE		24
201238869Smjacob
202238869Smjacob#define	FCP_BIDIR_RSP			0x80	/* Bi-Directional response */
203238869Smjacob#define	FCP_BIDIR_RESID_UNDERFLOW	0x40
204238869Smjacob#define	FCP_BIDIR_RESID_OVERFLOW	0x20
205196008Smjacob#define	FCP_CONF_REQ			0x10
206196008Smjacob#define	FCP_RESID_UNDERFLOW		0x08
207196008Smjacob#define	FCP_RESID_OVERFLOW		0x04
208196008Smjacob#define	FCP_SNSLEN_VALID		0x02
209196008Smjacob#define	FCP_RSPLEN_VALID		0x01
210196008Smjacob
211197372Smjacob#define FCP_MAX_RSPLEN			0x08
212196008Smjacob/*
213164272Smjacob * FCP Response Code Definitions
214196008Smjacob * Source: NCITS T10, Project 1144D, Revision 08 (aka FCP2r08)
215164272Smjacob */
216164272Smjacob#define	FCP_RSPNS_CODE_OFFSET		3
217163899Smjacob
218164272Smjacob#define	FCP_RSPNS_TMF_DONE		0
219164272Smjacob#define	FCP_RSPNS_DLBRSTX		1
220164272Smjacob#define	FCP_RSPNS_BADCMND		2
221164272Smjacob#define	FCP_RSPNS_EROFS			3
222164272Smjacob#define	FCP_RSPNS_TMF_REJECT		4
223164272Smjacob#define	FCP_RSPNS_TMF_FAILED		5
224197372Smjacob#define	FCP_RSPNS_TMF_SUCCEEDED		8
225197372Smjacob#define	FCP_RSPNS_TMF_INCORRECT_LUN	9
226164272Smjacob
227238869Smjacob/*
228238869Smjacob * R_CTL field definitions
229238869Smjacob *
230238869Smjacob * Bits 31-28 are ROUTING
231238869Smjacob * Bits 27-24 are INFORMATION
232238869Smjacob *
233238869Smjacob * These are nibble values, not bits
234238869Smjacob */
235238869Smjacob#define	R_CTL_ROUTE_DATA	0x00
236238869Smjacob#define	R_CTL_ROUTE_ELS		0x02
237238869Smjacob#define	R_CTL_ROUTE_FC4_LINK	0x03
238238869Smjacob#define	R_CTL_ROUTE_VDATA	0x04
239238869Smjacob#define	R_CTL_ROUTE_EXENDED	0x05
240238869Smjacob#define	R_CTL_ROUTE_BASIC	0x08
241238869Smjacob#define	R_CTL_ROUTE_LINK	0x0c
242238869Smjacob#define	R_CTL_ROUTE_EXT_ROUTING	0x0f
243164272Smjacob
244238869Smjacob#define	R_CTL_INFO_UNCATEGORIZED	0x00
245238869Smjacob#define	R_CTL_INFO_SOLICITED_DATA	0x01
246238869Smjacob#define	R_CTL_INFO_UNSOLICITED_CONTROL	0x02
247238869Smjacob#define	R_CTL_INFO_SOLICITED_CONTROL	0x03
248238869Smjacob#define	R_CTL_INFO_UNSOLICITED_DATA	0x04
249238869Smjacob#define	R_CTL_INFO_DATA_DESCRIPTOR	0x05
250238869Smjacob#define	R_CTL_INFO_UNSOLICITED_COMMAND	0x06
251238869Smjacob#define	R_CTL_INFO_COMMAND_STATUS	0x07
252238869Smjacob
253238869Smjacob#define	MAKE_RCTL(a, b)	(((a) << 4) | (b))
254238869Smjacob
255163899Smjacob/* unconverted miscellany */
256163899Smjacob/*
257163899Smjacob * Basic FC Link Service defines
258163899Smjacob */
259238869Smjacob/* #define	ABTS	MAKE_RCTL(R_CTL_ROUTE_BASIC, R_CTL_INFO_SOLICITED_DATA) */
260238869Smjacob#define	BA_ACC	MAKE_RCTL(R_CTL_ROUTE_BASIC, R_CTL_INFO_UNSOLICITED_DATA)	/* of ABORT */
261238869Smjacob#define	BA_RJT	MAKE_RCTL(R_CTL_ROUTE_BASIC, R_CTL_INFO_DATA_DESCRIPTOR)	/* of ABORT */
262163899Smjacob
263163899Smjacob/*
264163899Smjacob * Link Service Accept/Reject
265163899Smjacob */
266163899Smjacob#define	LS_ACC			0x8002
267163899Smjacob#define	LS_RJT			0x8001
268163899Smjacob
269163899Smjacob/*
270163899Smjacob * FC ELS Codes- bits 31-24 of the first payload word of an ELS frame.
271163899Smjacob */
272163899Smjacob#define	PLOGI			0x03
273163899Smjacob#define	FLOGI			0x04
274163899Smjacob#define	LOGO			0x05
275163899Smjacob#define	ABTX			0x06
276163899Smjacob#define	PRLI			0x20
277163899Smjacob#define	PRLO			0x21
278196008Smjacob#define	SCN			0x22
279163899Smjacob#define	TPRLO			0x24
280196008Smjacob#define	PDISC			0x50
281196008Smjacob#define	ADISC			0x52
282163899Smjacob#define	RNC			0x53
283163899Smjacob
284163899Smjacob/*
285238869Smjacob * PRLI Word 3 definitions
286238869Smjacob * FPC4-r02b January, 2011
287238869Smjacob */
288238869Smjacob#define	PRLI_WD3_ENHANCED_DISCOVERY			(1 << 11)
289238869Smjacob#define	PRLI_WD3_REC_SUPPORT				(1 << 10)
290238869Smjacob#define	PRLI_WD3_TASK_RETRY_IDENTIFICATION_REQUESTED	(1 << 9)
291238869Smjacob#define	PRLI_WD3_RETRY					(1 << 8)
292238869Smjacob#define	PRLI_WD3_CONFIRMED_COMPLETION_ALLOWED		(1 << 7)
293238869Smjacob#define	PRLI_WD3_DATA_OVERLAY_ALLOWED			(1 << 6)
294238869Smjacob#define	PRLI_WD3_INITIATOR_FUNCTION			(1 << 5)
295238869Smjacob#define	PRLI_WD3_TARGET_FUNCTION			(1 << 4)
296238869Smjacob#define	PRLI_WD3_READ_FCP_XFER_RDY_DISABLED		(1 << 1)	/* definitely supposed to be set */
297238869Smjacob#define	PRLI_WD3_WRITE_FCP_XFER_RDY_DISABLED		(1 << 0)
298238869Smjacob
299238869Smjacob
300238869Smjacob
301238869Smjacob/*
302163899Smjacob * FC4 defines
303163899Smjacob */
304163899Smjacob#define	FC4_IP		5	/* ISO/EEC 8802-2 LLC/SNAP */
305163899Smjacob#define	FC4_SCSI	8	/* SCSI-3 via Fibre Channel Protocol (FCP) */
306163899Smjacob#define	FC4_FC_SVC	0x20	/* Fibre Channel Services */
307163899Smjacob
308163899Smjacob#ifndef	MSG_ABORT
309163899Smjacob#define	MSG_ABORT		0x06
310163899Smjacob#endif
311163899Smjacob#ifndef	MSG_BUS_DEV_RESET
312163899Smjacob#define	MSG_BUS_DEV_RESET	0x0c
313163899Smjacob#endif
314163899Smjacob#ifndef	MSG_ABORT_TAG
315163899Smjacob#define	MSG_ABORT_TAG		0x0d
316163899Smjacob#endif
317163899Smjacob#ifndef	MSG_CLEAR_QUEUE
318163899Smjacob#define	MSG_CLEAR_QUEUE		0x0e
319163899Smjacob#endif
320163899Smjacob#ifndef	MSG_REL_RECOVERY
321163899Smjacob#define	MSG_REL_RECOVERY	0x10
322163899Smjacob#endif
323163899Smjacob#ifndef	MSG_TERM_IO_PROC
324163899Smjacob#define	MSG_TERM_IO_PROC	0x11
325163899Smjacob#endif
326163899Smjacob#ifndef	MSG_LUN_RESET
327163899Smjacob#define	MSG_LUN_RESET		0x17
328163899Smjacob#endif
329163899Smjacob
330163899Smjacob#endif	/* _ISP_STDS_H */
331