1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20#ifndef _FC_FS_H_
21#define _FC_FS_H_
22
23
24
25
26
27
28
29
30
31struct fc_frame_header {
32 __u8 fh_r_ctl;
33 __u8 fh_d_id[3];
34
35 __u8 fh_cs_ctl;
36 __u8 fh_s_id[3];
37
38 __u8 fh_type;
39 __u8 fh_f_ctl[3];
40
41 __u8 fh_seq_id;
42 __u8 fh_df_ctl;
43 __be16 fh_seq_cnt;
44
45 __be16 fh_ox_id;
46 __be16 fh_rx_id;
47 __be32 fh_parm_offset;
48};
49
50#define FC_FRAME_HEADER_LEN 24
51
52#define FC_MAX_PAYLOAD 2112U
53#define FC_MIN_MAX_PAYLOAD 256U
54
55#define FC_MAX_FRAME (FC_MAX_PAYLOAD + FC_FRAME_HEADER_LEN)
56#define FC_MIN_MAX_FRAME (FC_MIN_MAX_PAYLOAD + FC_FRAME_HEADER_LEN)
57
58
59
60
61
62
63
64enum fc_rctl {
65 FC_RCTL_DD_UNCAT = 0x00,
66 FC_RCTL_DD_SOL_DATA = 0x01,
67 FC_RCTL_DD_UNSOL_CTL = 0x02,
68 FC_RCTL_DD_SOL_CTL = 0x03,
69 FC_RCTL_DD_UNSOL_DATA = 0x04,
70 FC_RCTL_DD_DATA_DESC = 0x05,
71 FC_RCTL_DD_UNSOL_CMD = 0x06,
72 FC_RCTL_DD_CMD_STATUS = 0x07,
73
74#define FC_RCTL_ILS_REQ FC_RCTL_DD_UNSOL_CTL
75#define FC_RCTL_ILS_REP FC_RCTL_DD_SOL_CTL
76
77
78
79
80 FC_RCTL_ELS_REQ = 0x22,
81 FC_RCTL_ELS_REP = 0x23,
82 FC_RCTL_ELS4_REQ = 0x32,
83 FC_RCTL_ELS4_REP = 0x33,
84
85
86
87 FC_RCTL_VFTH = 0x50,
88 FC_RCTL_IFRH = 0x51,
89 FC_RCTL_ENCH = 0x52,
90
91
92
93 FC_RCTL_BA_NOP = 0x80,
94 FC_RCTL_BA_ABTS = 0x81,
95 FC_RCTL_BA_RMC = 0x82,
96 FC_RCTL_BA_ACC = 0x84,
97 FC_RCTL_BA_RJT = 0x85,
98 FC_RCTL_BA_PRMT = 0x86,
99
100
101
102 FC_RCTL_ACK_1 = 0xc0,
103 FC_RCTL_ACK_0 = 0xc1,
104 FC_RCTL_P_RJT = 0xc2,
105 FC_RCTL_F_RJT = 0xc3,
106 FC_RCTL_P_BSY = 0xc4,
107 FC_RCTL_F_BSY = 0xc5,
108 FC_RCTL_F_BSYL = 0xc6,
109 FC_RCTL_LCR = 0xc7,
110 FC_RCTL_END = 0xc9,
111};
112
113
114
115
116
117
118#define FC_RCTL_NAMES_INIT { \
119 [FC_RCTL_DD_UNCAT] = "uncat", \
120 [FC_RCTL_DD_SOL_DATA] = "sol data", \
121 [FC_RCTL_DD_UNSOL_CTL] = "unsol ctl", \
122 [FC_RCTL_DD_SOL_CTL] = "sol ctl/reply", \
123 [FC_RCTL_DD_UNSOL_DATA] = "unsol data", \
124 [FC_RCTL_DD_DATA_DESC] = "data desc", \
125 [FC_RCTL_DD_UNSOL_CMD] = "unsol cmd", \
126 [FC_RCTL_DD_CMD_STATUS] = "cmd status", \
127 [FC_RCTL_ELS_REQ] = "ELS req", \
128 [FC_RCTL_ELS_REP] = "ELS rep", \
129 [FC_RCTL_ELS4_REQ] = "FC-4 ELS req", \
130 [FC_RCTL_ELS4_REP] = "FC-4 ELS rep", \
131 [FC_RCTL_BA_NOP] = "BLS NOP", \
132 [FC_RCTL_BA_ABTS] = "BLS abort", \
133 [FC_RCTL_BA_RMC] = "BLS remove connection", \
134 [FC_RCTL_BA_ACC] = "BLS accept", \
135 [FC_RCTL_BA_RJT] = "BLS reject", \
136 [FC_RCTL_BA_PRMT] = "BLS dedicated connection preempted", \
137 [FC_RCTL_ACK_1] = "LC ACK_1", \
138 [FC_RCTL_ACK_0] = "LC ACK_0", \
139 [FC_RCTL_P_RJT] = "LC port reject", \
140 [FC_RCTL_F_RJT] = "LC fabric reject", \
141 [FC_RCTL_P_BSY] = "LC port busy", \
142 [FC_RCTL_F_BSY] = "LC fabric busy to data frame", \
143 [FC_RCTL_F_BSYL] = "LC fabric busy to link control frame",\
144 [FC_RCTL_LCR] = "LC link credit reset", \
145 [FC_RCTL_END] = "LC end", \
146}
147
148
149
150
151enum fc_well_known_fid {
152 FC_FID_NONE = 0x000000,
153 FC_FID_BCAST = 0xffffff,
154 FC_FID_FLOGI = 0xfffffe,
155 FC_FID_FCTRL = 0xfffffd,
156 FC_FID_DIR_SERV = 0xfffffc,
157 FC_FID_TIME_SERV = 0xfffffb,
158 FC_FID_MGMT_SERV = 0xfffffa,
159 FC_FID_QOS = 0xfffff9,
160 FC_FID_ALIASES = 0xfffff8,
161 FC_FID_SEC_KEY = 0xfffff7,
162 FC_FID_CLOCK = 0xfffff6,
163 FC_FID_MCAST_SERV = 0xfffff5,
164};
165
166#define FC_FID_WELL_KNOWN_MAX 0xffffff
167#define FC_FID_WELL_KNOWN_BASE 0xfffff5
168
169
170
171
172#define FC_FID_DOM_MGR 0xfffc00
173
174
175
176
177#define FC_FID_DOMAIN 0
178#define FC_FID_PORT 1
179#define FC_FID_LINK 2
180
181
182
183
184enum fc_fh_type {
185 FC_TYPE_BLS = 0x00,
186 FC_TYPE_ELS = 0x01,
187 FC_TYPE_IP = 0x05,
188 FC_TYPE_FCP = 0x08,
189 FC_TYPE_CT = 0x20,
190 FC_TYPE_ILS = 0x22,
191};
192
193
194
195
196
197#define FC_TYPE_NAMES_INIT { \
198 [FC_TYPE_BLS] = "BLS", \
199 [FC_TYPE_ELS] = "ELS", \
200 [FC_TYPE_IP] = "IP", \
201 [FC_TYPE_FCP] = "FCP", \
202 [FC_TYPE_CT] = "CT", \
203 [FC_TYPE_ILS] = "ILS", \
204}
205
206
207
208
209#define FC_XID_UNKNOWN 0xffff
210#define FC_XID_MIN 0x0
211#define FC_XID_MAX 0xfffe
212
213
214
215
216#define FC_FC_EX_CTX (1 << 23)
217#define FC_FC_SEQ_CTX (1 << 22)
218#define FC_FC_FIRST_SEQ (1 << 21)
219#define FC_FC_LAST_SEQ (1 << 20)
220#define FC_FC_END_SEQ (1 << 19)
221#define FC_FC_END_CONN (1 << 18)
222#define FC_FC_RES_B17 (1 << 17)
223#define FC_FC_SEQ_INIT (1 << 16)
224#define FC_FC_X_ID_REASS (1 << 15)
225#define FC_FC_X_ID_INVAL (1 << 14)
226
227#define FC_FC_ACK_1 (1 << 12)
228#define FC_FC_ACK_N (2 << 12)
229#define FC_FC_ACK_0 (3 << 12)
230
231#define FC_FC_RES_B11 (1 << 11)
232#define FC_FC_RES_B10 (1 << 10)
233#define FC_FC_RETX_SEQ (1 << 9)
234#define FC_FC_UNI_TX (1 << 8)
235#define FC_FC_CONT_SEQ(i) ((i) << 6)
236#define FC_FC_ABT_SEQ(i) ((i) << 4)
237#define FC_FC_REL_OFF (1 << 3)
238#define FC_FC_RES2 (1 << 2)
239#define FC_FC_FILL(i) ((i) & 3)
240
241
242
243
244struct fc_ba_acc {
245 __u8 ba_seq_id_val;
246#define FC_BA_SEQ_ID_VAL 0x80
247 __u8 ba_seq_id;
248 __u8 ba_resvd[2];
249 __be16 ba_ox_id;
250 __be16 ba_rx_id;
251 __be16 ba_low_seq_cnt;
252 __be16 ba_high_seq_cnt;
253};
254
255
256
257
258struct fc_ba_rjt {
259 __u8 br_resvd;
260 __u8 br_reason;
261 __u8 br_explan;
262 __u8 br_vendor;
263};
264
265
266
267
268
269enum fc_ba_rjt_reason {
270 FC_BA_RJT_NONE = 0,
271 FC_BA_RJT_INVL_CMD = 0x01,
272 FC_BA_RJT_LOG_ERR = 0x03,
273 FC_BA_RJT_LOG_BUSY = 0x05,
274 FC_BA_RJT_PROTO_ERR = 0x07,
275 FC_BA_RJT_UNABLE = 0x09,
276 FC_BA_RJT_VENDOR = 0xff,
277};
278
279
280
281
282enum fc_ba_rjt_explan {
283 FC_BA_RJT_EXP_NONE = 0x00,
284 FC_BA_RJT_INV_XID = 0x03,
285 FC_BA_RJT_ABT = 0x05,
286};
287
288
289
290
291struct fc_pf_rjt {
292 __u8 rj_action;
293 __u8 rj_reason;
294 __u8 rj_resvd;
295 __u8 rj_vendor;
296};
297
298
299
300
301enum fc_pf_rjt_reason {
302 FC_RJT_NONE = 0,
303 FC_RJT_INVL_DID = 0x01,
304 FC_RJT_INVL_SID = 0x02,
305 FC_RJT_P_UNAV_T = 0x03,
306 FC_RJT_P_UNAV = 0x04,
307 FC_RJT_CLS_UNSUP = 0x05,
308 FC_RJT_DEL_USAGE = 0x06,
309 FC_RJT_TYPE_UNSUP = 0x07,
310 FC_RJT_LINK_CTL = 0x08,
311 FC_RJT_R_CTL = 0x09,
312 FC_RJT_F_CTL = 0x0a,
313 FC_RJT_OX_ID = 0x0b,
314 FC_RJT_RX_ID = 0x0c,
315 FC_RJT_SEQ_ID = 0x0d,
316 FC_RJT_DF_CTL = 0x0e,
317 FC_RJT_SEQ_CNT = 0x0f,
318 FC_RJT_PARAM = 0x10,
319 FC_RJT_EXCH_ERR = 0x11,
320 FC_RJT_PROTO = 0x12,
321 FC_RJT_LEN = 0x13,
322 FC_RJT_UNEXP_ACK = 0x14,
323 FC_RJT_FAB_CLASS = 0x15,
324 FC_RJT_LOGI_REQ = 0x16,
325 FC_RJT_SEQ_XS = 0x17,
326 FC_RJT_EXCH_EST = 0x18,
327 FC_RJT_FAB_UNAV = 0x1a,
328 FC_RJT_VC_ID = 0x1b,
329 FC_RJT_CS_CTL = 0x1c,
330 FC_RJT_INSUF_RES = 0x1d,
331 FC_RJT_INVL_CLS = 0x1f,
332 FC_RJT_PREEMT_RJT = 0x20,
333 FC_RJT_PREEMT_DIS = 0x21,
334 FC_RJT_MCAST_ERR = 0x22,
335 FC_RJT_MCAST_ET = 0x23,
336 FC_RJT_PRLI_REQ = 0x24,
337 FC_RJT_INVL_ATT = 0x25,
338 FC_RJT_VENDOR = 0xff,
339};
340
341
342
343#define FC_DEF_E_D_TOV 2000UL
344#define FC_DEF_R_A_TOV 10000UL
345
346#endif
347