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