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