xref: /openbmc/linux/drivers/scsi/bfa/bfi_ms.h (revision 75bf465f0bc33e9b776a46d6a1b9b990f5fb7c37)
1 /* SPDX-License-Identifier: GPL-2.0-only */
2 /*
3  * Copyright (c) 2005-2014 Brocade Communications Systems, Inc.
4  * Copyright (c) 2014- QLogic Corporation.
5  * All rights reserved
6  * www.qlogic.com
7  *
8  * Linux driver for QLogic BR-series Fibre Channel Host Bus Adapter.
9  */
10 
11 #ifndef __BFI_MS_H__
12 #define __BFI_MS_H__
13 
14 #include "bfi.h"
15 #include "bfa_fc.h"
16 #include "bfa_defs_svc.h"
17 
18 #pragma pack(1)
19 
20 enum bfi_iocfc_h2i_msgs {
21 	BFI_IOCFC_H2I_CFG_REQ		= 1,
22 	BFI_IOCFC_H2I_SET_INTR_REQ	= 2,
23 	BFI_IOCFC_H2I_UPDATEQ_REQ	= 3,
24 	BFI_IOCFC_H2I_FAA_QUERY_REQ	= 4,
25 	BFI_IOCFC_H2I_ADDR_REQ		= 5,
26 };
27 
28 enum bfi_iocfc_i2h_msgs {
29 	BFI_IOCFC_I2H_CFG_REPLY		= BFA_I2HM(1),
30 	BFI_IOCFC_I2H_UPDATEQ_RSP	= BFA_I2HM(3),
31 	BFI_IOCFC_I2H_FAA_QUERY_RSP	= BFA_I2HM(4),
32 	BFI_IOCFC_I2H_ADDR_MSG		= BFA_I2HM(5),
33 };
34 
35 struct bfi_iocfc_cfg_s {
36 	u8	num_cqs;	/*  Number of CQs to be used	*/
37 	u8	 sense_buf_len;	/*  SCSI sense length	    */
38 	u16	rsvd_1;
39 	u32	endian_sig;	/*  endian signature of host     */
40 	u8	rsvd_2;
41 	u8	single_msix_vec;
42 	u8	rsvd[2];
43 	__be16	num_ioim_reqs;
44 	__be16	num_fwtio_reqs;
45 
46 
47 	/*
48 	 * Request and response circular queue base addresses, size and
49 	 * shadow index pointers.
50 	 */
51 	union bfi_addr_u  req_cq_ba[BFI_IOC_MAX_CQS];
52 	union bfi_addr_u  req_shadow_ci[BFI_IOC_MAX_CQS];
53 	__be16    req_cq_elems[BFI_IOC_MAX_CQS];
54 	union bfi_addr_u  rsp_cq_ba[BFI_IOC_MAX_CQS];
55 	union bfi_addr_u  rsp_shadow_pi[BFI_IOC_MAX_CQS];
56 	__be16    rsp_cq_elems[BFI_IOC_MAX_CQS];
57 
58 	union bfi_addr_u  stats_addr;	/*  DMA-able address for stats	  */
59 	union bfi_addr_u  cfgrsp_addr;	/*  config response dma address  */
60 	union bfi_addr_u  ioim_snsbase[BFI_IOIM_SNSBUF_SEGS];
61 					/*  IO sense buf base addr segments */
62 	struct bfa_iocfc_intr_attr_s intr_attr; /*  IOC interrupt attributes */
63 };
64 
65 /*
66  * Boot target wwn information for this port. This contains either the stored
67  * or discovered boot target port wwns for the port.
68  */
69 struct bfi_iocfc_bootwwns {
70 	wwn_t		wwn[BFA_BOOT_BOOTLUN_MAX];
71 	u8		nwwns;
72 	u8		rsvd[7];
73 };
74 
75 /**
76  * Queue configuration response from firmware
77  */
78 struct bfi_iocfc_qreg_s {
79 	u32	cpe_q_ci_off[BFI_IOC_MAX_CQS];
80 	u32	cpe_q_pi_off[BFI_IOC_MAX_CQS];
81 	u32	cpe_qctl_off[BFI_IOC_MAX_CQS];
82 	u32	rme_q_ci_off[BFI_IOC_MAX_CQS];
83 	u32	rme_q_pi_off[BFI_IOC_MAX_CQS];
84 	u32	rme_qctl_off[BFI_IOC_MAX_CQS];
85 	u8	hw_qid[BFI_IOC_MAX_CQS];
86 };
87 
88 struct bfi_iocfc_cfgrsp_s {
89 	struct bfa_iocfc_fwcfg_s	fwcfg;
90 	struct bfa_iocfc_intr_attr_s	intr_attr;
91 	struct bfi_iocfc_bootwwns	bootwwns;
92 	struct bfi_pbc_s		pbc_cfg;
93 	struct bfi_iocfc_qreg_s		qreg;
94 };
95 
96 /*
97  * BFI_IOCFC_H2I_CFG_REQ message
98  */
99 struct bfi_iocfc_cfg_req_s {
100 	struct bfi_mhdr_s      mh;
101 	union bfi_addr_u      ioc_cfg_dma_addr;
102 };
103 
104 
105 /*
106  * BFI_IOCFC_I2H_CFG_REPLY message
107  */
108 struct bfi_iocfc_cfg_reply_s {
109 	struct bfi_mhdr_s  mh;		/*  Common msg header	  */
110 	u8	 cfg_success;	/*  cfg reply status	   */
111 	u8	 lpu_bm;		/*  LPUs assigned for this IOC */
112 	u8	 rsvd[2];
113 };
114 
115 
116 /*
117  * BFI_IOCFC_H2I_SET_INTR_REQ message
118  */
119 struct bfi_iocfc_set_intr_req_s {
120 	struct bfi_mhdr_s mh;		/*  common msg header		*/
121 	u8		coalesce;	/*  enable intr coalescing	*/
122 	u8		rsvd[3];
123 	__be16	delay;		/*  delay timer 0..1125us	*/
124 	__be16	latency;	/*  latency timer 0..225us	*/
125 };
126 
127 
128 /*
129  * BFI_IOCFC_H2I_UPDATEQ_REQ message
130  */
131 struct bfi_iocfc_updateq_req_s {
132 	struct bfi_mhdr_s mh;		/*  common msg header		*/
133 	u32 reqq_ba;		/*  reqq base addr		*/
134 	u32 rspq_ba;		/*  rspq base addr		*/
135 	u32 reqq_sci;		/*  reqq shadow ci		*/
136 	u32 rspq_spi;		/*  rspq shadow pi		*/
137 };
138 
139 
140 /*
141  * BFI_IOCFC_I2H_UPDATEQ_RSP message
142  */
143 struct bfi_iocfc_updateq_rsp_s {
144 	struct bfi_mhdr_s mh;		/*  common msg header	*/
145 	u8	status;			/*  updateq  status	*/
146 	u8	rsvd[3];
147 };
148 
149 
150 /*
151  * H2I Messages
152  */
153 union bfi_iocfc_h2i_msg_u {
154 	struct bfi_mhdr_s		mh;
155 	struct bfi_iocfc_cfg_req_s	cfg_req;
156 	struct bfi_iocfc_updateq_req_s updateq_req;
157 	u32 mboxmsg[BFI_IOC_MSGSZ];
158 };
159 
160 
161 /*
162  * I2H Messages
163  */
164 union bfi_iocfc_i2h_msg_u {
165 	struct bfi_mhdr_s		mh;
166 	struct bfi_iocfc_cfg_reply_s	cfg_reply;
167 	struct bfi_iocfc_updateq_rsp_s updateq_rsp;
168 	u32 mboxmsg[BFI_IOC_MSGSZ];
169 };
170 
171 /*
172  * BFI_IOCFC_H2I_FAA_ENABLE_REQ BFI_IOCFC_H2I_FAA_DISABLE_REQ message
173  */
174 struct bfi_faa_en_dis_s {
175 	struct bfi_mhdr_s mh;	/* common msg header    */
176 };
177 
178 struct bfi_faa_addr_msg_s {
179 	struct  bfi_mhdr_s mh;	/* common msg header	*/
180 	u8	rsvd[4];
181 	wwn_t	pwwn;		/* Fabric acquired PWWN	*/
182 	wwn_t	nwwn;		/* Fabric acquired PWWN	*/
183 };
184 
185 /*
186  * BFI_IOCFC_H2I_FAA_QUERY_REQ message
187  */
188 struct bfi_faa_query_s {
189 	struct bfi_mhdr_s mh;	/* common msg header    */
190 	u8	faa_status;	/* FAA status           */
191 	u8	addr_source;	/* PWWN source          */
192 	u8	rsvd[2];
193 	wwn_t	faa;		/* Fabric acquired PWWN	*/
194 };
195 
196 /*
197  * BFI_IOCFC_I2H_FAA_ENABLE_RSP, BFI_IOCFC_I2H_FAA_DISABLE_RSP message
198  */
199 struct bfi_faa_en_dis_rsp_s {
200 	struct bfi_mhdr_s mh;	/* common msg header    */
201 	u8	status;		/* updateq  status      */
202 	u8	rsvd[3];
203 };
204 
205 /*
206  * BFI_IOCFC_I2H_FAA_QUERY_RSP message
207  */
208 #define bfi_faa_query_rsp_t struct bfi_faa_query_s
209 
210 enum bfi_fcport_h2i {
211 	BFI_FCPORT_H2I_ENABLE_REQ		= (1),
212 	BFI_FCPORT_H2I_DISABLE_REQ		= (2),
213 	BFI_FCPORT_H2I_SET_SVC_PARAMS_REQ	= (3),
214 	BFI_FCPORT_H2I_STATS_GET_REQ		= (4),
215 	BFI_FCPORT_H2I_STATS_CLEAR_REQ		= (5),
216 };
217 
218 
219 enum bfi_fcport_i2h {
220 	BFI_FCPORT_I2H_ENABLE_RSP		= BFA_I2HM(1),
221 	BFI_FCPORT_I2H_DISABLE_RSP		= BFA_I2HM(2),
222 	BFI_FCPORT_I2H_SET_SVC_PARAMS_RSP	= BFA_I2HM(3),
223 	BFI_FCPORT_I2H_STATS_GET_RSP		= BFA_I2HM(4),
224 	BFI_FCPORT_I2H_STATS_CLEAR_RSP		= BFA_I2HM(5),
225 	BFI_FCPORT_I2H_EVENT			= BFA_I2HM(6),
226 	BFI_FCPORT_I2H_TRUNK_SCN		= BFA_I2HM(7),
227 	BFI_FCPORT_I2H_ENABLE_AEN		= BFA_I2HM(8),
228 	BFI_FCPORT_I2H_DISABLE_AEN		= BFA_I2HM(9),
229 };
230 
231 
232 /*
233  * Generic REQ type
234  */
235 struct bfi_fcport_req_s {
236 	struct bfi_mhdr_s  mh;		/*  msg header			    */
237 	u32	   msgtag;	/*  msgtag for reply		    */
238 };
239 
240 /*
241  * Generic RSP type
242  */
243 struct bfi_fcport_rsp_s {
244 	struct bfi_mhdr_s  mh;		/*  common msg header		    */
245 	u8		   status;	/*  port enable status		    */
246 	u8		   rsvd[3];
247 	struct	bfa_port_cfg_s port_cfg;/* port configuration	*/
248 	u32	msgtag;			/* msgtag for reply	*/
249 };
250 
251 /*
252  * BFI_FCPORT_H2I_ENABLE_REQ
253  */
254 struct bfi_fcport_enable_req_s {
255 	struct bfi_mhdr_s  mh;		/*  msg header			    */
256 	u32	   rsvd1;
257 	wwn_t		   nwwn;	/*  node wwn of physical port	    */
258 	wwn_t		   pwwn;	/*  port wwn of physical port	    */
259 	struct bfa_port_cfg_s port_cfg; /*  port configuration	    */
260 	union bfi_addr_u   stats_dma_addr; /*  DMA address for stats	    */
261 	u32	   msgtag;	/*  msgtag for reply		    */
262 	u8	use_flash_cfg;	/* get prot cfg from flash */
263 	u8	rsvd2[3];
264 };
265 
266 /*
267  * BFI_FCPORT_H2I_SET_SVC_PARAMS_REQ
268  */
269 struct bfi_fcport_set_svc_params_req_s {
270 	struct bfi_mhdr_s  mh;		/*  msg header */
271 	__be16	   tx_bbcredit;	/*  Tx credits */
272 	u8	rsvd[2];
273 };
274 
275 /*
276  * BFI_FCPORT_I2H_EVENT
277  */
278 struct bfi_fcport_event_s {
279 	struct bfi_mhdr_s	mh;	/*  common msg header */
280 	struct bfa_port_link_s	link_state;
281 };
282 
283 /*
284  * BFI_FCPORT_I2H_TRUNK_SCN
285  */
286 struct bfi_fcport_trunk_link_s {
287 	wwn_t			trunk_wwn;
288 	u8			fctl;		/* bfa_trunk_link_fctl_t */
289 	u8			state;		/* bfa_trunk_link_state_t */
290 	u8			speed;		/* bfa_port_speed_t */
291 	u8			rsvd;
292 	__be32		deskew;
293 };
294 
295 #define BFI_FCPORT_MAX_LINKS	2
296 struct bfi_fcport_trunk_scn_s {
297 	struct bfi_mhdr_s	mh;
298 	u8			trunk_state;	/* bfa_trunk_state_t */
299 	u8			trunk_speed;	/* bfa_port_speed_t */
300 	u8			rsvd_a[2];
301 	struct bfi_fcport_trunk_link_s tlink[BFI_FCPORT_MAX_LINKS];
302 };
303 
304 /*
305  * fcport H2I message
306  */
307 union bfi_fcport_h2i_msg_u {
308 	struct bfi_mhdr_s			*mhdr;
309 	struct bfi_fcport_enable_req_s		*penable;
310 	struct bfi_fcport_req_s			*pdisable;
311 	struct bfi_fcport_set_svc_params_req_s	*psetsvcparams;
312 	struct bfi_fcport_req_s			*pstatsget;
313 	struct bfi_fcport_req_s			*pstatsclear;
314 };
315 
316 /*
317  * fcport I2H message
318  */
319 union bfi_fcport_i2h_msg_u {
320 	struct bfi_msg_s			*msg;
321 	struct bfi_fcport_rsp_s			*penable_rsp;
322 	struct bfi_fcport_rsp_s			*pdisable_rsp;
323 	struct bfi_fcport_rsp_s			*psetsvcparams_rsp;
324 	struct bfi_fcport_rsp_s			*pstatsget_rsp;
325 	struct bfi_fcport_rsp_s			*pstatsclear_rsp;
326 	struct bfi_fcport_event_s		*event;
327 	struct bfi_fcport_trunk_scn_s		*trunk_scn;
328 };
329 
330 enum bfi_fcxp_h2i {
331 	BFI_FCXP_H2I_SEND_REQ = 1,
332 };
333 
334 enum bfi_fcxp_i2h {
335 	BFI_FCXP_I2H_SEND_RSP = BFA_I2HM(1),
336 };
337 
338 #define BFA_FCXP_MAX_SGES	2
339 
340 /*
341  * FCXP send request structure
342  */
343 struct bfi_fcxp_send_req_s {
344 	struct bfi_mhdr_s  mh;		/*  Common msg header		    */
345 	__be16	fcxp_tag;	/*  driver request tag		    */
346 	__be16	max_frmsz;	/*  max send frame size	    */
347 	__be16	vf_id;		/*  vsan tag if applicable	    */
348 	u16	rport_fw_hndl;	/*  FW Handle for the remote port  */
349 	u8	 class;		/*  FC class used for req/rsp	    */
350 	u8	 rsp_timeout;	/*  timeout in secs, 0-no response */
351 	u8	 cts;		/*  continue sequence		    */
352 	u8	 lp_fwtag;	/*  lport tag			    */
353 	struct fchs_s	fchs;	/*  request FC header structure    */
354 	__be32	req_len;	/*  request payload length	    */
355 	__be32	rsp_maxlen;	/*  max response length expected   */
356 	struct bfi_alen_s req_alen;	/* request buffer	*/
357 	struct bfi_alen_s rsp_alen;	/* response buffer	*/
358 };
359 
360 /*
361  * FCXP send response structure
362  */
363 struct bfi_fcxp_send_rsp_s {
364 	struct bfi_mhdr_s  mh;		/*  Common msg header		    */
365 	__be16	fcxp_tag;	/*  send request tag		    */
366 	u8	 req_status;	/*  request status		    */
367 	u8	 rsvd;
368 	__be32	rsp_len;	/*  actual response length	    */
369 	__be32	residue_len;	/*  residual response length	    */
370 	struct fchs_s	fchs;	/*  response FC header structure   */
371 };
372 
373 enum bfi_uf_h2i {
374 	BFI_UF_H2I_BUF_POST = 1,
375 };
376 
377 enum bfi_uf_i2h {
378 	BFI_UF_I2H_FRM_RCVD = BFA_I2HM(1),
379 };
380 
381 #define BFA_UF_MAX_SGES	2
382 
383 struct bfi_uf_buf_post_s {
384 	struct bfi_mhdr_s  mh;		/*  Common msg header		*/
385 	u16	buf_tag;	/*  buffer tag			*/
386 	__be16	buf_len;	/*  total buffer length	*/
387 	struct bfi_alen_s alen;	/* buffer address/len pair	*/
388 };
389 
390 struct bfi_uf_frm_rcvd_s {
391 	struct bfi_mhdr_s  mh;		/*  Common msg header		*/
392 	u16	buf_tag;	/*  buffer tag			*/
393 	u16	rsvd;
394 	u16	frm_len;	/*  received frame length	*/
395 	u16	xfr_len;	/*  tranferred length		*/
396 };
397 
398 enum bfi_lps_h2i_msgs {
399 	BFI_LPS_H2I_LOGIN_REQ	= 1,
400 	BFI_LPS_H2I_LOGOUT_REQ	= 2,
401 	BFI_LPS_H2I_N2N_PID_REQ = 3,
402 };
403 
404 enum bfi_lps_i2h_msgs {
405 	BFI_LPS_I2H_LOGIN_RSP	= BFA_I2HM(1),
406 	BFI_LPS_I2H_LOGOUT_RSP	= BFA_I2HM(2),
407 	BFI_LPS_I2H_CVL_EVENT	= BFA_I2HM(3),
408 };
409 
410 struct bfi_lps_login_req_s {
411 	struct bfi_mhdr_s  mh;		/*  common msg header		*/
412 	u8		bfa_tag;
413 	u8		alpa;
414 	__be16		pdu_size;
415 	wwn_t		pwwn;
416 	wwn_t		nwwn;
417 	u8		fdisc;
418 	u8		auth_en;
419 	u8		lps_role;
420 	u8		bb_scn;
421 	u32		vvl_flag;
422 };
423 
424 struct bfi_lps_login_rsp_s {
425 	struct bfi_mhdr_s  mh;		/*  common msg header		*/
426 	u8		fw_tag;
427 	u8		status;
428 	u8		lsrjt_rsn;
429 	u8		lsrjt_expl;
430 	wwn_t		port_name;
431 	wwn_t		node_name;
432 	__be16		bb_credit;
433 	u8		f_port;
434 	u8		npiv_en;
435 	u32	lp_pid:24;
436 	u32	auth_req:8;
437 	mac_t		lp_mac;
438 	mac_t		fcf_mac;
439 	u8		ext_status;
440 	u8		brcd_switch;	/*  attached peer is brcd switch */
441 	u8		bfa_tag;
442 	u8		rsvd;
443 };
444 
445 struct bfi_lps_logout_req_s {
446 	struct bfi_mhdr_s  mh;		/*  common msg header		*/
447 	u8		fw_tag;
448 	u8		rsvd[3];
449 	wwn_t		port_name;
450 };
451 
452 struct bfi_lps_logout_rsp_s {
453 	struct bfi_mhdr_s  mh;		/*  common msg header		*/
454 	u8		bfa_tag;
455 	u8		status;
456 	u8		rsvd[2];
457 };
458 
459 struct bfi_lps_cvl_event_s {
460 	struct bfi_mhdr_s  mh;		/*  common msg header		*/
461 	u8		bfa_tag;
462 	u8		rsvd[3];
463 };
464 
465 struct bfi_lps_n2n_pid_req_s {
466 	struct bfi_mhdr_s	mh;	/*  common msg header		*/
467 	u8	fw_tag;
468 	u32	lp_pid:24;
469 };
470 
471 union bfi_lps_h2i_msg_u {
472 	struct bfi_mhdr_s		*msg;
473 	struct bfi_lps_login_req_s	*login_req;
474 	struct bfi_lps_logout_req_s	*logout_req;
475 	struct bfi_lps_n2n_pid_req_s	*n2n_pid_req;
476 };
477 
478 union bfi_lps_i2h_msg_u {
479 	struct bfi_msg_s		*msg;
480 	struct bfi_lps_login_rsp_s	*login_rsp;
481 	struct bfi_lps_logout_rsp_s	*logout_rsp;
482 	struct bfi_lps_cvl_event_s	*cvl_event;
483 };
484 
485 enum bfi_rport_h2i_msgs {
486 	BFI_RPORT_H2I_CREATE_REQ = 1,
487 	BFI_RPORT_H2I_DELETE_REQ = 2,
488 	BFI_RPORT_H2I_SET_SPEED_REQ  = 3,
489 };
490 
491 enum bfi_rport_i2h_msgs {
492 	BFI_RPORT_I2H_CREATE_RSP = BFA_I2HM(1),
493 	BFI_RPORT_I2H_DELETE_RSP = BFA_I2HM(2),
494 	BFI_RPORT_I2H_QOS_SCN    = BFA_I2HM(3),
495 	BFI_RPORT_I2H_LIP_SCN_ONLINE =	BFA_I2HM(4),
496 	BFI_RPORT_I2H_LIP_SCN_OFFLINE = BFA_I2HM(5),
497 	BFI_RPORT_I2H_NO_DEV	= BFA_I2HM(6),
498 };
499 
500 struct bfi_rport_create_req_s {
501 	struct bfi_mhdr_s  mh;		/*  common msg header		*/
502 	u16	bfa_handle;	/*  host rport handle		*/
503 	__be16	max_frmsz;	/*  max rcv pdu size		*/
504 	u32	pid:24,	/*  remote port ID		*/
505 		lp_fwtag:8;	/*  local port tag		*/
506 	u32	local_pid:24,	/*  local port ID		*/
507 		cisc:8;
508 	u8	fc_class;	/*  supported FC classes	*/
509 	u8	vf_en;		/*  virtual fabric enable	*/
510 	u16	vf_id;		/*  virtual fabric ID		*/
511 };
512 
513 struct bfi_rport_create_rsp_s {
514 	struct bfi_mhdr_s  mh;		/*  common msg header		*/
515 	u8		status;		/*  rport creation status	*/
516 	u8		rsvd[3];
517 	u16	bfa_handle;	/*  host rport handle		*/
518 	u16	fw_handle;	/*  firmware rport handle	*/
519 	struct bfa_rport_qos_attr_s qos_attr;  /* QoS Attributes */
520 };
521 
522 struct bfa_rport_speed_req_s {
523 	struct bfi_mhdr_s  mh;		/*  common msg header		*/
524 	u16	fw_handle;	/*  firmware rport handle	*/
525 	u8		speed;		/*  rport's speed via RPSC	*/
526 	u8		rsvd;
527 };
528 
529 struct bfi_rport_delete_req_s {
530 	struct bfi_mhdr_s  mh;		/*  common msg header		*/
531 	u16	fw_handle;	/*  firmware rport handle	*/
532 	u16	rsvd;
533 };
534 
535 struct bfi_rport_delete_rsp_s {
536 	struct bfi_mhdr_s  mh;		/*  common msg header		*/
537 	u16	bfa_handle;	/*  host rport handle		*/
538 	u8		status;		/*  rport deletion status	*/
539 	u8		rsvd;
540 };
541 
542 struct bfi_rport_qos_scn_s {
543 	struct bfi_mhdr_s  mh;		/*  common msg header		*/
544 	u16	bfa_handle;	/*  host rport handle		*/
545 	u16	rsvd;
546 	struct bfa_rport_qos_attr_s old_qos_attr;  /* Old QoS Attributes */
547 	struct bfa_rport_qos_attr_s new_qos_attr;  /* New QoS Attributes */
548 };
549 
550 struct bfi_rport_lip_scn_s {
551 	struct bfi_mhdr_s  mh;		/*!< common msg header	*/
552 	u16	bfa_handle;	/*!< host rport handle	*/
553 	u8		status;		/*!< scn online status	*/
554 	u8		rsvd;
555 	struct bfa_fcport_loop_info_s	loop_info;
556 };
557 
558 union bfi_rport_h2i_msg_u {
559 	struct bfi_msg_s		*msg;
560 	struct bfi_rport_create_req_s	*create_req;
561 	struct bfi_rport_delete_req_s	*delete_req;
562 	struct bfi_rport_speed_req_s	*speed_req;
563 };
564 
565 union bfi_rport_i2h_msg_u {
566 	struct bfi_msg_s		*msg;
567 	struct bfi_rport_create_rsp_s	*create_rsp;
568 	struct bfi_rport_delete_rsp_s	*delete_rsp;
569 	struct bfi_rport_qos_scn_s	*qos_scn_evt;
570 	struct bfi_rport_lip_scn_s	*lip_scn;
571 };
572 
573 /*
574  * Initiator mode I-T nexus interface defines.
575  */
576 
577 enum bfi_itn_h2i {
578 	BFI_ITN_H2I_CREATE_REQ = 1,	/*  i-t nexus creation */
579 	BFI_ITN_H2I_DELETE_REQ = 2,	/*  i-t nexus deletion */
580 };
581 
582 enum bfi_itn_i2h {
583 	BFI_ITN_I2H_CREATE_RSP = BFA_I2HM(1),
584 	BFI_ITN_I2H_DELETE_RSP = BFA_I2HM(2),
585 	BFI_ITN_I2H_SLER_EVENT = BFA_I2HM(3),
586 };
587 
588 struct bfi_itn_create_req_s {
589 	struct bfi_mhdr_s  mh;		/*  common msg header		 */
590 	u16	fw_handle;	/*  f/w handle for itnim	 */
591 	u8	class;		/*  FC class for IO		 */
592 	u8	seq_rec;	/*  sequence recovery support	 */
593 	u8	msg_no;		/*  seq id of the msg		 */
594 	u8	role;
595 };
596 
597 struct bfi_itn_create_rsp_s {
598 	struct bfi_mhdr_s  mh;		/*  common msg header		 */
599 	u16	bfa_handle;	/*  bfa handle for itnim	 */
600 	u8	status;		/*  fcp request status		 */
601 	u8	seq_id;		/*  seq id of the msg		 */
602 };
603 
604 struct bfi_itn_delete_req_s {
605 	struct bfi_mhdr_s  mh;		/*  common msg header		 */
606 	u16	fw_handle;	/*  f/w itnim handle		 */
607 	u8	seq_id;		/*  seq id of the msg		 */
608 	u8	rsvd;
609 };
610 
611 struct bfi_itn_delete_rsp_s {
612 	struct bfi_mhdr_s  mh;		/*  common msg header		 */
613 	u16	bfa_handle;	/*  bfa handle for itnim	 */
614 	u8	status;		/*  fcp request status		 */
615 	u8	seq_id;		/*  seq id of the msg		 */
616 };
617 
618 struct bfi_itn_sler_event_s {
619 	struct bfi_mhdr_s  mh;		/*  common msg header		 */
620 	u16	bfa_handle;	/*  bfa handle for itnim	 */
621 	u16	rsvd;
622 };
623 
624 union bfi_itn_h2i_msg_u {
625 	struct bfi_itn_create_req_s *create_req;
626 	struct bfi_itn_delete_req_s *delete_req;
627 	struct bfi_msg_s	*msg;
628 };
629 
630 union bfi_itn_i2h_msg_u {
631 	struct bfi_itn_create_rsp_s *create_rsp;
632 	struct bfi_itn_delete_rsp_s *delete_rsp;
633 	struct bfi_itn_sler_event_s *sler_event;
634 	struct bfi_msg_s	*msg;
635 };
636 
637 /*
638  * Initiator mode IO interface defines.
639  */
640 
641 enum bfi_ioim_h2i {
642 	BFI_IOIM_H2I_IOABORT_REQ = 1,	/*  IO abort request	 */
643 	BFI_IOIM_H2I_IOCLEANUP_REQ = 2,	/*  IO cleanup request	 */
644 };
645 
646 enum bfi_ioim_i2h {
647 	BFI_IOIM_I2H_IO_RSP = BFA_I2HM(1),	/*  non-fp IO response	 */
648 	BFI_IOIM_I2H_IOABORT_RSP = BFA_I2HM(2),	/*  ABORT rsp	 */
649 };
650 
651 /*
652  * IO command DIF info
653  */
654 struct bfi_ioim_dif_s {
655 	u32	dif_info[4];
656 };
657 
658 /*
659  * FCP IO messages overview
660  *
661  * @note
662  * - Max CDB length supported is 64 bytes.
663  * - SCSI Linked commands and SCSI bi-directional Commands not
664  *	supported.
665  *
666  */
667 struct bfi_ioim_req_s {
668 	struct bfi_mhdr_s  mh;		/*  Common msg header		 */
669 	__be16	io_tag;		/*  I/O tag			 */
670 	u16	rport_hdl;	/*  itnim/rport firmware handle */
671 	struct fcp_cmnd_s	cmnd;	/*  IO request info	*/
672 
673 	/*
674 	 * SG elements array within the IO request must be double word
675 	 * aligned. This alignment is required to optimize SGM setup for the IO.
676 	 */
677 	struct bfi_sge_s	sges[BFI_SGE_INLINE_MAX];
678 	u8	io_timeout;
679 	u8	dif_en;
680 	u8	rsvd_a[2];
681 	struct bfi_ioim_dif_s  dif;
682 };
683 
684 /*
685  *	This table shows various IO status codes from firmware and their
686  *	meaning. Host driver can use these status codes to further process
687  *	IO completions.
688  *
689  *	BFI_IOIM_STS_OK		: IO completed with error free SCSI &
690  *					transport status.
691  *					 io-tag can be reused.
692  *
693  *	BFA_IOIM_STS_SCSI_ERR		: IO completed with scsi error.
694  *	- io-tag can be reused.
695  *
696  *	BFI_IOIM_STS_HOST_ABORTED	: IO was aborted successfully due to
697  *						host request.
698  *					- io-tag cannot be reused yet.
699  *
700  *	BFI_IOIM_STS_ABORTED		: IO was aborted successfully
701  *						internally by f/w.
702  *					- io-tag cannot be reused yet.
703  *
704  *	BFI_IOIM_STS_TIMEDOUT	: IO timedout and ABTS/RRQ is happening
705  *					in the firmware and
706  *					- io-tag cannot be reused yet.
707  *
708  *	BFI_IOIM_STS_SQER_NEEDED	: Firmware could not recover the IO
709  *					  with sequence level error
710  *	logic and hence host needs to retry
711  *					  this IO with a different IO tag
712  *					- io-tag cannot be used yet.
713  *
714  *	BFI_IOIM_STS_NEXUS_ABORT	: Second Level Error Recovery from host
715  *					  is required because 2 consecutive ABTS
716  *					  timedout and host needs logout and
717  *					  re-login with the target
718  *					- io-tag cannot be used yet.
719  *
720  *	BFI_IOIM_STS_UNDERRUN	: IO completed with SCSI status good,
721  *					  but the data tranferred is less than
722  *					  the fcp data length in the command.
723  *					  ex. SCSI INQUIRY where transferred
724  *					  data length and residue count in FCP
725  *					  response accounts for total fcp-dl
726  *					  - io-tag can be reused.
727  *
728  *	BFI_IOIM_STS_OVERRUN	: IO completed with SCSI status good,
729  *					  but the data transerred is more than
730  *					  fcp data length in the command. ex.
731  *					  TAPE IOs where blocks can of unequal
732  *					  lengths.
733  *					- io-tag can be reused.
734  *
735  *	BFI_IOIM_STS_RES_FREE	: Firmware has completed using io-tag
736  *					  during abort process
737  *					- io-tag can be reused.
738  *
739  *	BFI_IOIM_STS_PROTO_ERR	: Firmware detected a protocol error.
740  *					  ex target sent more data than
741  *					  requested, or there was data frame
742  *					  loss and other reasons
743  *					- io-tag cannot be used yet.
744  *
745  *	BFI_IOIM_STS_DIF_ERR	: Firwmare detected DIF error. ex: DIF
746  *					CRC err or Ref Tag err or App tag err.
747  *					- io-tag can be reused.
748  *
749  *	BFA_IOIM_STS_TSK_MGT_ABORT	: IO was aborted because of Task
750  *					  Management command from the host
751  *					  - io-tag can be reused.
752  *
753  *	BFI_IOIM_STS_UTAG		: Firmware does not know about this
754  *					  io_tag.
755  *					- io-tag can be reused.
756  */
757 enum bfi_ioim_status {
758 	BFI_IOIM_STS_OK = 0,
759 	BFI_IOIM_STS_HOST_ABORTED = 1,
760 	BFI_IOIM_STS_ABORTED = 2,
761 	BFI_IOIM_STS_TIMEDOUT = 3,
762 	BFI_IOIM_STS_RES_FREE = 4,
763 	BFI_IOIM_STS_SQER_NEEDED = 5,
764 	BFI_IOIM_STS_PROTO_ERR = 6,
765 	BFI_IOIM_STS_UTAG = 7,
766 	BFI_IOIM_STS_PATHTOV = 8,
767 };
768 
769 /*
770  * I/O response message
771  */
772 struct bfi_ioim_rsp_s {
773 	struct bfi_mhdr_s	mh;	/*  common msg header		*/
774 	__be16	io_tag;		/*  completed IO tag		 */
775 	u16	bfa_rport_hndl;	/*  releated rport handle	 */
776 	u8	io_status;	/*  IO completion status	 */
777 	u8	reuse_io_tag;	/*  IO tag can be reused	*/
778 	u16	abort_tag;	/*  host abort request tag	*/
779 	u8		scsi_status;	/*  scsi status from target	 */
780 	u8		sns_len;	/*  scsi sense length		 */
781 	u8		resid_flags;	/*  IO residue flags		 */
782 	u8		rsvd_a;
783 	__be32	residue;	/*  IO residual length in bytes */
784 	u32	rsvd_b[3];
785 };
786 
787 struct bfi_ioim_abort_req_s {
788 	struct bfi_mhdr_s  mh;	/*  Common msg header  */
789 	__be16	io_tag;	/*  I/O tag	*/
790 	u16	abort_tag;	/*  unique request tag */
791 };
792 
793 /*
794  * Initiator mode task management command interface defines.
795  */
796 
797 enum bfi_tskim_h2i {
798 	BFI_TSKIM_H2I_TM_REQ	= 1, /*  task-mgmt command	*/
799 	BFI_TSKIM_H2I_ABORT_REQ = 2, /*  task-mgmt command	*/
800 };
801 
802 enum bfi_tskim_i2h {
803 	BFI_TSKIM_I2H_TM_RSP = BFA_I2HM(1),
804 };
805 
806 struct bfi_tskim_req_s {
807 	struct bfi_mhdr_s  mh;	/*  Common msg header	*/
808 	__be16	tsk_tag;	/*  task management tag	*/
809 	u16	itn_fhdl;	/*  itn firmware handle	*/
810 	struct 	scsi_lun lun;	/*  LU number	*/
811 	u8	tm_flags;	/*  see enum fcp_tm_cmnd	*/
812 	u8	t_secs;	/*  Timeout value in seconds	*/
813 	u8	rsvd[2];
814 };
815 
816 struct bfi_tskim_abortreq_s {
817 	struct bfi_mhdr_s  mh;	/*  Common msg header	*/
818 	__be16	tsk_tag;	/*  task management tag	*/
819 	u16	rsvd;
820 };
821 
822 enum bfi_tskim_status {
823 	/*
824 	 * Following are FCP-4 spec defined status codes,
825 	 * **DO NOT CHANGE THEM **
826 	 */
827 	BFI_TSKIM_STS_OK	= 0,
828 	BFI_TSKIM_STS_NOT_SUPP = 4,
829 	BFI_TSKIM_STS_FAILED	= 5,
830 
831 	/*
832 	 * Defined by BFA
833 	 */
834 	BFI_TSKIM_STS_TIMEOUT  = 10,	/*  TM request timedout	*/
835 	BFI_TSKIM_STS_ABORTED  = 11,	/*  Aborted on host request */
836 	BFI_TSKIM_STS_UTAG     = 12,	/*  unknown tag for request */
837 };
838 
839 struct bfi_tskim_rsp_s {
840 	struct bfi_mhdr_s  mh;		/*  Common msg header		 */
841 	__be16	tsk_tag;	/*  task mgmt cmnd tag		 */
842 	u8	tsk_status;	/*  @ref bfi_tskim_status */
843 	u8	rsvd;
844 };
845 
846 #pragma pack()
847 
848 /*
849  * Crossbow PCI MSI-X vector defines
850  */
851 enum {
852 	BFI_MSIX_CPE_QMIN_CB = 0,
853 	BFI_MSIX_CPE_QMAX_CB = 7,
854 	BFI_MSIX_RME_QMIN_CB = 8,
855 	BFI_MSIX_RME_QMAX_CB = 15,
856 	BFI_MSIX_CB_MAX = 22,
857 };
858 
859 /*
860  * Catapult FC PCI MSI-X vector defines
861  */
862 enum {
863 	BFI_MSIX_LPU_ERR_CT = 0,
864 	BFI_MSIX_CPE_QMIN_CT = 1,
865 	BFI_MSIX_CPE_QMAX_CT = 4,
866 	BFI_MSIX_RME_QMIN_CT = 5,
867 	BFI_MSIX_RME_QMAX_CT = 8,
868 	BFI_MSIX_CT_MAX = 9,
869 };
870 
871 #endif /* __BFI_MS_H__ */
872