Linux Audio

Check our new training course

Real-Time Linux with PREEMPT_RT training

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