xref: /openbmc/linux/include/uapi/scsi/fc/fc_fs.h (revision 402b0e32)
1e2be04c7SGreg Kroah-Hartman /* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
2cf028200SDavid Howells /*
3cf028200SDavid Howells  * Copyright(c) 2007 Intel Corporation. All rights reserved.
4cf028200SDavid Howells  *
5cf028200SDavid Howells  * Maintained at www.Open-FCoE.org
6cf028200SDavid Howells  */
7cf028200SDavid Howells 
8cf028200SDavid Howells #ifndef _FC_FS_H_
9cf028200SDavid Howells #define _FC_FS_H_
10cf028200SDavid Howells 
11cf028200SDavid Howells #include <linux/types.h>
12cf028200SDavid Howells 
13cf028200SDavid Howells /*
14cf028200SDavid Howells  * Fibre Channel Framing and Signalling definitions.
15cf028200SDavid Howells  * From T11 FC-FS-2 Rev 0.90 - 9 August 2005.
16cf028200SDavid Howells  */
17cf028200SDavid Howells 
18cf028200SDavid Howells /*
19cf028200SDavid Howells  * Frame header
20cf028200SDavid Howells  */
21cf028200SDavid Howells struct fc_frame_header {
22cf028200SDavid Howells 	__u8          fh_r_ctl;	/* routing control */
23cf028200SDavid Howells 	__u8          fh_d_id[3];	/* Destination ID */
24cf028200SDavid Howells 
25cf028200SDavid Howells 	__u8          fh_cs_ctl;	/* class of service control / pri */
26cf028200SDavid Howells 	__u8          fh_s_id[3];	/* Source ID */
27cf028200SDavid Howells 
28cf028200SDavid Howells 	__u8          fh_type;		/* see enum fc_fh_type below */
29cf028200SDavid Howells 	__u8          fh_f_ctl[3];	/* frame control */
30cf028200SDavid Howells 
31cf028200SDavid Howells 	__u8          fh_seq_id;	/* sequence ID */
32cf028200SDavid Howells 	__u8          fh_df_ctl;	/* data field control */
33cf028200SDavid Howells 	__be16        fh_seq_cnt;	/* sequence count */
34cf028200SDavid Howells 
35cf028200SDavid Howells 	__be16        fh_ox_id;		/* originator exchange ID */
36cf028200SDavid Howells 	__be16        fh_rx_id;		/* responder exchange ID */
37cf028200SDavid Howells 	__be32        fh_parm_offset;	/* parameter or relative offset */
38cf028200SDavid Howells };
39cf028200SDavid Howells 
40cf028200SDavid Howells #define FC_FRAME_HEADER_LEN 24	/* expected length of structure */
41cf028200SDavid Howells 
42cf028200SDavid Howells #define FC_MAX_PAYLOAD  2112U		/* max payload length in bytes */
43cf028200SDavid Howells #define FC_MIN_MAX_PAYLOAD  256U 	/* lower limit on max payload */
44cf028200SDavid Howells 
45cf028200SDavid Howells #define FC_MAX_FRAME	(FC_MAX_PAYLOAD + FC_FRAME_HEADER_LEN)
46cf028200SDavid Howells #define FC_MIN_MAX_FRAME (FC_MIN_MAX_PAYLOAD + FC_FRAME_HEADER_LEN)
47cf028200SDavid Howells 
48cf028200SDavid Howells /*
49cf028200SDavid Howells  * fh_r_ctl - Routing control definitions.
50cf028200SDavid Howells  */
51cf028200SDavid Howells     /*
52cf028200SDavid Howells      * FC-4 device_data.
53cf028200SDavid Howells      */
54cf028200SDavid Howells enum fc_rctl {
55cf028200SDavid Howells 	FC_RCTL_DD_UNCAT = 0x00,	/* uncategorized information */
56cf028200SDavid Howells 	FC_RCTL_DD_SOL_DATA = 0x01,	/* solicited data */
57cf028200SDavid Howells 	FC_RCTL_DD_UNSOL_CTL = 0x02,	/* unsolicited control */
58cf028200SDavid Howells 	FC_RCTL_DD_SOL_CTL = 0x03,	/* solicited control or reply */
59cf028200SDavid Howells 	FC_RCTL_DD_UNSOL_DATA = 0x04,	/* unsolicited data */
60cf028200SDavid Howells 	FC_RCTL_DD_DATA_DESC = 0x05,	/* data descriptor */
61cf028200SDavid Howells 	FC_RCTL_DD_UNSOL_CMD = 0x06,	/* unsolicited command */
62cf028200SDavid Howells 	FC_RCTL_DD_CMD_STATUS = 0x07,	/* command status */
63cf028200SDavid Howells 
64cf028200SDavid Howells #define FC_RCTL_ILS_REQ FC_RCTL_DD_UNSOL_CTL	/* ILS request */
65cf028200SDavid Howells #define FC_RCTL_ILS_REP FC_RCTL_DD_SOL_CTL	/* ILS reply */
66cf028200SDavid Howells 
67cf028200SDavid Howells 	/*
68cf028200SDavid Howells 	 * Extended Link_Data
69cf028200SDavid Howells 	 */
70cf028200SDavid Howells 	FC_RCTL_ELS_REQ = 0x22,	/* extended link services request */
71cf028200SDavid Howells 	FC_RCTL_ELS_REP = 0x23,	/* extended link services reply */
72cf028200SDavid Howells 	FC_RCTL_ELS4_REQ = 0x32, /* FC-4 ELS request */
73cf028200SDavid Howells 	FC_RCTL_ELS4_REP = 0x33, /* FC-4 ELS reply */
74cf028200SDavid Howells 	/*
75cf028200SDavid Howells 	 * Optional Extended Headers
76cf028200SDavid Howells 	 */
77cf028200SDavid Howells 	FC_RCTL_VFTH = 0x50,	/* virtual fabric tagging header */
78cf028200SDavid Howells 	FC_RCTL_IFRH = 0x51,	/* inter-fabric routing header */
79cf028200SDavid Howells 	FC_RCTL_ENCH = 0x52,	/* encapsulation header */
80cf028200SDavid Howells 	/*
81cf028200SDavid Howells 	 * Basic Link Services fh_r_ctl values.
82cf028200SDavid Howells 	 */
83cf028200SDavid Howells 	FC_RCTL_BA_NOP = 0x80,	/* basic link service NOP */
84cf028200SDavid Howells 	FC_RCTL_BA_ABTS = 0x81,	/* basic link service abort */
85cf028200SDavid Howells 	FC_RCTL_BA_RMC = 0x82,	/* remove connection */
86cf028200SDavid Howells 	FC_RCTL_BA_ACC = 0x84,	/* basic accept */
87cf028200SDavid Howells 	FC_RCTL_BA_RJT = 0x85,	/* basic reject */
88cf028200SDavid Howells 	FC_RCTL_BA_PRMT = 0x86,	/* dedicated connection preempted */
89cf028200SDavid Howells 	/*
90cf028200SDavid Howells 	 * Link Control Information.
91cf028200SDavid Howells 	 */
92cf028200SDavid Howells 	FC_RCTL_ACK_1 = 0xc0,	/* acknowledge_1 */
93cf028200SDavid Howells 	FC_RCTL_ACK_0 = 0xc1,	/* acknowledge_0 */
94cf028200SDavid Howells 	FC_RCTL_P_RJT = 0xc2,	/* port reject */
95cf028200SDavid Howells 	FC_RCTL_F_RJT = 0xc3,	/* fabric reject */
96cf028200SDavid Howells 	FC_RCTL_P_BSY = 0xc4,	/* port busy */
97cf028200SDavid Howells 	FC_RCTL_F_BSY = 0xc5,	/* fabric busy to data frame */
98cf028200SDavid Howells 	FC_RCTL_F_BSYL = 0xc6,	/* fabric busy to link control frame */
99cf028200SDavid Howells 	FC_RCTL_LCR = 0xc7,	/* link credit reset */
100cf028200SDavid Howells 	FC_RCTL_END = 0xc9,	/* end */
101cf028200SDavid Howells };
102cf028200SDavid Howells 				    /* incomplete list of definitions */
103cf028200SDavid Howells 
104cf028200SDavid Howells /*
105cf028200SDavid Howells  * R_CTL names initializer.
106cf028200SDavid Howells  * Please keep this matching the above definitions.
107cf028200SDavid Howells  */
108cf028200SDavid Howells #define FC_RCTL_NAMES_INIT { \
109cf028200SDavid Howells 	[FC_RCTL_DD_UNCAT] =		"uncat",			\
110cf028200SDavid Howells 	[FC_RCTL_DD_SOL_DATA] =		"sol data",			\
111cf028200SDavid Howells 	[FC_RCTL_DD_UNSOL_CTL] =	"unsol ctl",			\
112cf028200SDavid Howells 	[FC_RCTL_DD_SOL_CTL] =		"sol ctl/reply",		\
113cf028200SDavid Howells 	[FC_RCTL_DD_UNSOL_DATA] =	"unsol data",			\
114cf028200SDavid Howells 	[FC_RCTL_DD_DATA_DESC] =	"data desc",			\
115cf028200SDavid Howells 	[FC_RCTL_DD_UNSOL_CMD] =	"unsol cmd",			\
116cf028200SDavid Howells 	[FC_RCTL_DD_CMD_STATUS] =	"cmd status",			\
117cf028200SDavid Howells 	[FC_RCTL_ELS_REQ] =		"ELS req",			\
118cf028200SDavid Howells 	[FC_RCTL_ELS_REP] =		"ELS rep",			\
119cf028200SDavid Howells 	[FC_RCTL_ELS4_REQ] =		"FC-4 ELS req",			\
120cf028200SDavid Howells 	[FC_RCTL_ELS4_REP] =		"FC-4 ELS rep",			\
121cf028200SDavid Howells 	[FC_RCTL_BA_NOP] =		"BLS NOP",			\
122cf028200SDavid Howells 	[FC_RCTL_BA_ABTS] =		"BLS abort",			\
123cf028200SDavid Howells 	[FC_RCTL_BA_RMC] =		"BLS remove connection",	\
124cf028200SDavid Howells 	[FC_RCTL_BA_ACC] =		"BLS accept",			\
125cf028200SDavid Howells 	[FC_RCTL_BA_RJT] =		"BLS reject",			\
126cf028200SDavid Howells 	[FC_RCTL_BA_PRMT] =		"BLS dedicated connection preempted", \
127cf028200SDavid Howells 	[FC_RCTL_ACK_1] =		"LC ACK_1",			\
128cf028200SDavid Howells 	[FC_RCTL_ACK_0] =		"LC ACK_0",			\
129cf028200SDavid Howells 	[FC_RCTL_P_RJT] =		"LC port reject",		\
130cf028200SDavid Howells 	[FC_RCTL_F_RJT] =		"LC fabric reject",		\
131cf028200SDavid Howells 	[FC_RCTL_P_BSY] =		"LC port busy",			\
132cf028200SDavid Howells 	[FC_RCTL_F_BSY] =		"LC fabric busy to data frame",	\
133cf028200SDavid Howells 	[FC_RCTL_F_BSYL] =		"LC fabric busy to link control frame",\
134cf028200SDavid Howells 	[FC_RCTL_LCR] =			"LC link credit reset",		\
135cf028200SDavid Howells 	[FC_RCTL_END] =			"LC end",			\
136cf028200SDavid Howells }
137cf028200SDavid Howells 
138cf028200SDavid Howells /*
139cf028200SDavid Howells  * Well-known fabric addresses.
140cf028200SDavid Howells  */
141cf028200SDavid Howells enum fc_well_known_fid {
142cf028200SDavid Howells 	FC_FID_NONE =           0x000000,       /* No destination */
143cf028200SDavid Howells 	FC_FID_BCAST =		0xffffff,	/* broadcast */
144cf028200SDavid Howells 	FC_FID_FLOGI =		0xfffffe,	/* fabric login */
145cf028200SDavid Howells 	FC_FID_FCTRL =		0xfffffd,	/* fabric controller */
146cf028200SDavid Howells 	FC_FID_DIR_SERV =	0xfffffc,	/* directory server */
147cf028200SDavid Howells 	FC_FID_TIME_SERV =	0xfffffb,	/* time server */
148cf028200SDavid Howells 	FC_FID_MGMT_SERV =	0xfffffa,	/* management server */
149cf028200SDavid Howells 	FC_FID_QOS =		0xfffff9,	/* QoS Facilitator */
150cf028200SDavid Howells 	FC_FID_ALIASES =	0xfffff8,	/* alias server (FC-PH2) */
151cf028200SDavid Howells 	FC_FID_SEC_KEY =	0xfffff7,	/* Security key dist. server */
152cf028200SDavid Howells 	FC_FID_CLOCK =		0xfffff6,	/* clock synch server */
153cf028200SDavid Howells 	FC_FID_MCAST_SERV =	0xfffff5,	/* multicast server */
154cf028200SDavid Howells };
155cf028200SDavid Howells 
156cf028200SDavid Howells #define	FC_FID_WELL_KNOWN_MAX	0xffffff /* highest well-known fabric ID */
157cf028200SDavid Howells #define	FC_FID_WELL_KNOWN_BASE	0xfffff5 /* start of well-known fabric ID */
158cf028200SDavid Howells 
159cf028200SDavid Howells /*
160cf028200SDavid Howells  * Other well-known addresses, outside the above contiguous range.
161cf028200SDavid Howells  */
162cf028200SDavid Howells #define	FC_FID_DOM_MGR		0xfffc00	/* domain manager base */
163cf028200SDavid Howells 
164cf028200SDavid Howells /*
165cf028200SDavid Howells  * Fabric ID bytes.
166cf028200SDavid Howells  */
167cf028200SDavid Howells #define	FC_FID_DOMAIN		0
168cf028200SDavid Howells #define	FC_FID_PORT		1
169cf028200SDavid Howells #define	FC_FID_LINK		2
170cf028200SDavid Howells 
171cf028200SDavid Howells /*
172cf028200SDavid Howells  * fh_type codes
173cf028200SDavid Howells  */
174cf028200SDavid Howells enum fc_fh_type {
175cf028200SDavid Howells 	FC_TYPE_BLS =	0x00,	/* basic link service */
176cf028200SDavid Howells 	FC_TYPE_ELS =	0x01,	/* extended link service */
177cf028200SDavid Howells 	FC_TYPE_IP =	0x05,	/* IP over FC, RFC 4338 */
178cf028200SDavid Howells 	FC_TYPE_FCP =	0x08,	/* SCSI FCP */
179cf028200SDavid Howells 	FC_TYPE_CT =	0x20,	/* Fibre Channel Services (FC-CT) */
180cf028200SDavid Howells 	FC_TYPE_ILS =	0x22,	/* internal link service */
1816ea76f33SJames Smart 	FC_TYPE_NVME =	0x28,	/* FC-NVME */
182cf028200SDavid Howells };
183cf028200SDavid Howells 
184cf028200SDavid Howells /*
185cf028200SDavid Howells  * FC_TYPE names initializer.
186cf028200SDavid Howells  * Please keep this matching the above definitions.
187cf028200SDavid Howells  */
188cf028200SDavid Howells #define FC_TYPE_NAMES_INIT {				\
189cf028200SDavid Howells 	[FC_TYPE_BLS] =		"BLS",			\
190cf028200SDavid Howells 	[FC_TYPE_ELS] =		"ELS",			\
191cf028200SDavid Howells 	[FC_TYPE_IP] =		"IP",			\
192cf028200SDavid Howells 	[FC_TYPE_FCP] =		"FCP",			\
193cf028200SDavid Howells 	[FC_TYPE_CT] =		"CT",			\
194cf028200SDavid Howells 	[FC_TYPE_ILS] =		"ILS",			\
1956ea76f33SJames Smart 	[FC_TYPE_NVME] =	"NVME",			\
196cf028200SDavid Howells }
197cf028200SDavid Howells 
198cf028200SDavid Howells /*
199cf028200SDavid Howells  * Exchange IDs.
200cf028200SDavid Howells  */
201cf028200SDavid Howells #define FC_XID_UNKNOWN  0xffff	/* unknown exchange ID */
202cf028200SDavid Howells #define FC_XID_MIN	0x0	/* supported min exchange ID */
203cf028200SDavid Howells #define FC_XID_MAX	0xfffe	/* supported max exchange ID */
204cf028200SDavid Howells 
205cf028200SDavid Howells /*
206cf028200SDavid Howells  * fh_f_ctl - Frame control flags.
207cf028200SDavid Howells  */
208cf028200SDavid Howells #define	FC_FC_EX_CTX	(1 << 23)	/* sent by responder to exchange */
209cf028200SDavid Howells #define	FC_FC_SEQ_CTX	(1 << 22)	/* sent by responder to sequence */
210cf028200SDavid Howells #define	FC_FC_FIRST_SEQ (1 << 21)	/* first sequence of this exchange */
211cf028200SDavid Howells #define	FC_FC_LAST_SEQ	(1 << 20)	/* last sequence of this exchange */
212cf028200SDavid Howells #define	FC_FC_END_SEQ	(1 << 19)	/* last frame of sequence */
213cf028200SDavid Howells #define	FC_FC_END_CONN	(1 << 18)	/* end of class 1 connection pending */
214cf028200SDavid Howells #define	FC_FC_RES_B17	(1 << 17)	/* reserved */
215cf028200SDavid Howells #define	FC_FC_SEQ_INIT	(1 << 16)	/* transfer of sequence initiative */
216cf028200SDavid Howells #define	FC_FC_X_ID_REASS (1 << 15)	/* exchange ID has been changed */
217cf028200SDavid Howells #define	FC_FC_X_ID_INVAL (1 << 14)	/* exchange ID invalidated */
218cf028200SDavid Howells 
219cf028200SDavid Howells #define	FC_FC_ACK_1	(1 << 12)	/* 13:12 = 1: ACK_1 expected */
220cf028200SDavid Howells #define	FC_FC_ACK_N	(2 << 12)	/* 13:12 = 2: ACK_N expected */
221cf028200SDavid Howells #define	FC_FC_ACK_0	(3 << 12)	/* 13:12 = 3: ACK_0 expected */
222cf028200SDavid Howells 
223cf028200SDavid Howells #define	FC_FC_RES_B11	(1 << 11)	/* reserved */
224cf028200SDavid Howells #define	FC_FC_RES_B10	(1 << 10)	/* reserved */
225cf028200SDavid Howells #define	FC_FC_RETX_SEQ	(1 << 9)	/* retransmitted sequence */
226cf028200SDavid Howells #define	FC_FC_UNI_TX	(1 << 8)	/* unidirectional transmit (class 1) */
227cf028200SDavid Howells #define	FC_FC_CONT_SEQ(i) ((i) << 6)
228cf028200SDavid Howells #define	FC_FC_ABT_SEQ(i) ((i) << 4)
229cf028200SDavid Howells #define	FC_FC_REL_OFF	(1 << 3)	/* parameter is relative offset */
230cf028200SDavid Howells #define	FC_FC_RES2	(1 << 2)	/* reserved */
231cf028200SDavid Howells #define	FC_FC_FILL(i)	((i) & 3)	/* 1:0: bytes of trailing fill */
232cf028200SDavid Howells 
233cf028200SDavid Howells /*
234cf028200SDavid Howells  * BA_ACC payload.
235cf028200SDavid Howells  */
236cf028200SDavid Howells struct fc_ba_acc {
237cf028200SDavid Howells 	__u8		ba_seq_id_val;	/* SEQ_ID validity */
238cf028200SDavid Howells #define FC_BA_SEQ_ID_VAL 0x80
239cf028200SDavid Howells 	__u8		ba_seq_id;	/* SEQ_ID of seq last deliverable */
240cf028200SDavid Howells 	__u8		ba_resvd[2];	/* reserved */
241cf028200SDavid Howells 	__be16		ba_ox_id;	/* OX_ID for aborted seq or exch */
242cf028200SDavid Howells 	__be16		ba_rx_id;	/* RX_ID for aborted seq or exch */
243cf028200SDavid Howells 	__be16		ba_low_seq_cnt;	/* low SEQ_CNT of aborted seq */
244cf028200SDavid Howells 	__be16		ba_high_seq_cnt; /* high SEQ_CNT of aborted seq */
245cf028200SDavid Howells };
246cf028200SDavid Howells 
247cf028200SDavid Howells /*
248cf028200SDavid Howells  * BA_RJT: Basic Reject payload.
249cf028200SDavid Howells  */
250cf028200SDavid Howells struct fc_ba_rjt {
251cf028200SDavid Howells 	__u8		br_resvd;	/* reserved */
252cf028200SDavid Howells 	__u8		br_reason;	/* reason code */
253cf028200SDavid Howells 	__u8		br_explan;	/* reason explanation */
254cf028200SDavid Howells 	__u8		br_vendor;	/* vendor unique code */
255cf028200SDavid Howells };
256cf028200SDavid Howells 
257cf028200SDavid Howells /*
258cf028200SDavid Howells  * BA_RJT reason codes.
259cf028200SDavid Howells  * From FS-2.
260cf028200SDavid Howells  */
261cf028200SDavid Howells enum fc_ba_rjt_reason {
262cf028200SDavid Howells 	FC_BA_RJT_NONE =	0,	/* in software this means no reject */
263cf028200SDavid Howells 	FC_BA_RJT_INVL_CMD =	0x01,	/* invalid command code */
264cf028200SDavid Howells 	FC_BA_RJT_LOG_ERR =	0x03,	/* logical error */
265cf028200SDavid Howells 	FC_BA_RJT_LOG_BUSY =	0x05,	/* logical busy */
266cf028200SDavid Howells 	FC_BA_RJT_PROTO_ERR =	0x07,	/* protocol error */
267cf028200SDavid Howells 	FC_BA_RJT_UNABLE =	0x09,	/* unable to perform request */
268cf028200SDavid Howells 	FC_BA_RJT_VENDOR =	0xff,	/* vendor-specific (see br_vendor) */
269cf028200SDavid Howells };
270cf028200SDavid Howells 
271cf028200SDavid Howells /*
272cf028200SDavid Howells  * BA_RJT reason code explanations.
273cf028200SDavid Howells  */
274cf028200SDavid Howells enum fc_ba_rjt_explan {
275cf028200SDavid Howells 	FC_BA_RJT_EXP_NONE =	0x00,	/* no additional expanation */
276cf028200SDavid Howells 	FC_BA_RJT_INV_XID =	0x03,	/* invalid OX_ID-RX_ID combination */
277cf028200SDavid Howells 	FC_BA_RJT_ABT =		0x05,	/* sequence aborted, no seq info */
278cf028200SDavid Howells };
279cf028200SDavid Howells 
280cf028200SDavid Howells /*
281cf028200SDavid Howells  * P_RJT or F_RJT: Port Reject or Fabric Reject parameter field.
282cf028200SDavid Howells  */
283cf028200SDavid Howells struct fc_pf_rjt {
284cf028200SDavid Howells 	__u8		rj_action;	/* reserved */
285cf028200SDavid Howells 	__u8		rj_reason;	/* reason code */
286cf028200SDavid Howells 	__u8		rj_resvd;	/* reserved */
287cf028200SDavid Howells 	__u8		rj_vendor;	/* vendor unique code */
288cf028200SDavid Howells };
289cf028200SDavid Howells 
290cf028200SDavid Howells /*
291cf028200SDavid Howells  * P_RJT and F_RJT reject reason codes.
292cf028200SDavid Howells  */
293cf028200SDavid Howells enum fc_pf_rjt_reason {
294cf028200SDavid Howells 	FC_RJT_NONE =		0,	/* non-reject (reserved by standard) */
295cf028200SDavid Howells 	FC_RJT_INVL_DID =	0x01,	/* invalid destination ID */
296cf028200SDavid Howells 	FC_RJT_INVL_SID =	0x02,	/* invalid source ID */
297cf028200SDavid Howells 	FC_RJT_P_UNAV_T =	0x03,	/* port unavailable, temporary */
298cf028200SDavid Howells 	FC_RJT_P_UNAV =		0x04,	/* port unavailable, permanent */
299cf028200SDavid Howells 	FC_RJT_CLS_UNSUP =	0x05,	/* class not supported */
300cf028200SDavid Howells 	FC_RJT_DEL_USAGE =	0x06,	/* delimiter usage error */
301cf028200SDavid Howells 	FC_RJT_TYPE_UNSUP =	0x07,	/* type not supported */
302cf028200SDavid Howells 	FC_RJT_LINK_CTL =	0x08,	/* invalid link control */
303cf028200SDavid Howells 	FC_RJT_R_CTL =		0x09,	/* invalid R_CTL field */
304cf028200SDavid Howells 	FC_RJT_F_CTL =		0x0a,	/* invalid F_CTL field */
305cf028200SDavid Howells 	FC_RJT_OX_ID =		0x0b,	/* invalid originator exchange ID */
306cf028200SDavid Howells 	FC_RJT_RX_ID =		0x0c,	/* invalid responder exchange ID */
307cf028200SDavid Howells 	FC_RJT_SEQ_ID =		0x0d,	/* invalid sequence ID */
308cf028200SDavid Howells 	FC_RJT_DF_CTL =		0x0e,	/* invalid DF_CTL field */
309cf028200SDavid Howells 	FC_RJT_SEQ_CNT =	0x0f,	/* invalid SEQ_CNT field */
310cf028200SDavid Howells 	FC_RJT_PARAM =		0x10,	/* invalid parameter field */
311cf028200SDavid Howells 	FC_RJT_EXCH_ERR =	0x11,	/* exchange error */
312cf028200SDavid Howells 	FC_RJT_PROTO =		0x12,	/* protocol error */
313cf028200SDavid Howells 	FC_RJT_LEN =		0x13,	/* incorrect length */
314cf028200SDavid Howells 	FC_RJT_UNEXP_ACK =	0x14,	/* unexpected ACK */
315cf028200SDavid Howells 	FC_RJT_FAB_CLASS =	0x15,	/* class unsupported by fabric entity */
316cf028200SDavid Howells 	FC_RJT_LOGI_REQ =	0x16,	/* login required */
317cf028200SDavid Howells 	FC_RJT_SEQ_XS =		0x17,	/* excessive sequences attempted */
318cf028200SDavid Howells 	FC_RJT_EXCH_EST =	0x18,	/* unable to establish exchange */
319cf028200SDavid Howells 	FC_RJT_FAB_UNAV =	0x1a,	/* fabric unavailable */
320cf028200SDavid Howells 	FC_RJT_VC_ID =		0x1b,	/* invalid VC_ID (class 4) */
321cf028200SDavid Howells 	FC_RJT_CS_CTL =		0x1c,	/* invalid CS_CTL field */
322cf028200SDavid Howells 	FC_RJT_INSUF_RES =	0x1d,	/* insuff. resources for VC (Class 4) */
323cf028200SDavid Howells 	FC_RJT_INVL_CLS =	0x1f,	/* invalid class of service */
324cf028200SDavid Howells 	FC_RJT_PREEMT_RJT =	0x20,	/* preemption request rejected */
325cf028200SDavid Howells 	FC_RJT_PREEMT_DIS =	0x21,	/* preemption not enabled */
326cf028200SDavid Howells 	FC_RJT_MCAST_ERR =	0x22,	/* multicast error */
327cf028200SDavid Howells 	FC_RJT_MCAST_ET =	0x23,	/* multicast error terminate */
328cf028200SDavid Howells 	FC_RJT_PRLI_REQ =	0x24,	/* process login required */
329cf028200SDavid Howells 	FC_RJT_INVL_ATT =	0x25,	/* invalid attachment */
330cf028200SDavid Howells 	FC_RJT_VENDOR =		0xff,	/* vendor specific reject */
331cf028200SDavid Howells };
332cf028200SDavid Howells 
333cf028200SDavid Howells /* default timeout values */
334cf028200SDavid Howells 
335cf028200SDavid Howells #define FC_DEF_E_D_TOV	2000UL
336cf028200SDavid Howells #define FC_DEF_R_A_TOV	10000UL
337cf028200SDavid Howells 
338cf028200SDavid Howells #endif /* _FC_FS_H_ */
339