[SCSI] bfa: cleanup driver
authorKrishna Gudipati <kgudipat@brocade.com>
Wed, 15 Sep 2010 18:50:55 +0000 (11:50 -0700)
committerJames Bottomley <James.Bottomley@suse.de>
Fri, 17 Sep 2010 02:54:24 +0000 (22:54 -0400)
We have flattened the BFA hierarchy and also reduced the number of
source and header files we used to have earlier.

Signed-off-by: Krishna Gudipati <kgudipat@brocade.com>
Signed-off-by: James Bottomley <James.Bottomley@suse.de>
220 files changed:
drivers/scsi/bfa/Makefile
drivers/scsi/bfa/bfa.h [new file with mode: 0644]
drivers/scsi/bfa/bfa_callback_priv.h [deleted file]
drivers/scsi/bfa/bfa_cb_ioim.h [new file with mode: 0644]
drivers/scsi/bfa/bfa_cb_ioim_macros.h [deleted file]
drivers/scsi/bfa/bfa_cee.c [deleted file]
drivers/scsi/bfa/bfa_core.c
drivers/scsi/bfa/bfa_cs.h [new file with mode: 0644]
drivers/scsi/bfa/bfa_csdebug.c [deleted file]
drivers/scsi/bfa/bfa_defs.h [new file with mode: 0644]
drivers/scsi/bfa/bfa_defs_fcs.h [new file with mode: 0644]
drivers/scsi/bfa/bfa_defs_svc.h [new file with mode: 0644]
drivers/scsi/bfa/bfa_drv.c [new file with mode: 0644]
drivers/scsi/bfa/bfa_fc.h [new file with mode: 0644]
drivers/scsi/bfa/bfa_fcbuild.c [new file with mode: 0644]
drivers/scsi/bfa/bfa_fcbuild.h [new file with mode: 0644]
drivers/scsi/bfa/bfa_fcpim.c
drivers/scsi/bfa/bfa_fcpim.h [new file with mode: 0644]
drivers/scsi/bfa/bfa_fcpim_priv.h [deleted file]
drivers/scsi/bfa/bfa_fcport.c [deleted file]
drivers/scsi/bfa/bfa_fcs.c
drivers/scsi/bfa/bfa_fcs.h [new file with mode: 0644]
drivers/scsi/bfa/bfa_fcs_fcpim.c [new file with mode: 0644]
drivers/scsi/bfa/bfa_fcs_lport.c
drivers/scsi/bfa/bfa_fcs_port.c [deleted file]
drivers/scsi/bfa/bfa_fcs_rport.c [new file with mode: 0644]
drivers/scsi/bfa/bfa_fcs_uf.c [deleted file]
drivers/scsi/bfa/bfa_fcxp.c [deleted file]
drivers/scsi/bfa/bfa_fcxp_priv.h [deleted file]
drivers/scsi/bfa/bfa_fwimg_priv.h [deleted file]
drivers/scsi/bfa/bfa_hw_cb.c
drivers/scsi/bfa/bfa_hw_ct.c
drivers/scsi/bfa/bfa_intr.c [deleted file]
drivers/scsi/bfa/bfa_intr_priv.h [deleted file]
drivers/scsi/bfa/bfa_ioc.c
drivers/scsi/bfa/bfa_ioc.h
drivers/scsi/bfa/bfa_ioc_cb.c
drivers/scsi/bfa/bfa_ioc_ct.c
drivers/scsi/bfa/bfa_iocfc.c [deleted file]
drivers/scsi/bfa/bfa_iocfc.h [deleted file]
drivers/scsi/bfa/bfa_iocfc_q.c [deleted file]
drivers/scsi/bfa/bfa_ioim.c [deleted file]
drivers/scsi/bfa/bfa_itnim.c [deleted file]
drivers/scsi/bfa/bfa_log.c [deleted file]
drivers/scsi/bfa/bfa_log_module.c [deleted file]
drivers/scsi/bfa/bfa_lps.c [deleted file]
drivers/scsi/bfa/bfa_lps_priv.h [deleted file]
drivers/scsi/bfa/bfa_module.c [deleted file]
drivers/scsi/bfa/bfa_modules.h [new file with mode: 0644]
drivers/scsi/bfa/bfa_modules_priv.h [deleted file]
drivers/scsi/bfa/bfa_os_inc.h
drivers/scsi/bfa/bfa_plog.h [new file with mode: 0644]
drivers/scsi/bfa/bfa_port.c
drivers/scsi/bfa/bfa_port.h [new file with mode: 0644]
drivers/scsi/bfa/bfa_port_priv.h [deleted file]
drivers/scsi/bfa/bfa_priv.h [deleted file]
drivers/scsi/bfa/bfa_rport.c [deleted file]
drivers/scsi/bfa/bfa_rport_priv.h [deleted file]
drivers/scsi/bfa/bfa_sgpg.c [deleted file]
drivers/scsi/bfa/bfa_sgpg_priv.h [deleted file]
drivers/scsi/bfa/bfa_sm.c [deleted file]
drivers/scsi/bfa/bfa_svc.c [new file with mode: 0644]
drivers/scsi/bfa/bfa_svc.h [new file with mode: 0644]
drivers/scsi/bfa/bfa_timer.c [deleted file]
drivers/scsi/bfa/bfa_trcmod_priv.h [deleted file]
drivers/scsi/bfa/bfa_tskim.c [deleted file]
drivers/scsi/bfa/bfa_uf.c [deleted file]
drivers/scsi/bfa/bfa_uf_priv.h [deleted file]
drivers/scsi/bfa/bfad.c
drivers/scsi/bfa/bfad_attr.c
drivers/scsi/bfa/bfad_attr.h [deleted file]
drivers/scsi/bfa/bfad_debugfs.c
drivers/scsi/bfa/bfad_drv.h
drivers/scsi/bfa/bfad_fwimg.c [deleted file]
drivers/scsi/bfa/bfad_im.c
drivers/scsi/bfa/bfad_im.h
drivers/scsi/bfa/bfad_im_compat.h [deleted file]
drivers/scsi/bfa/bfad_intr.c [deleted file]
drivers/scsi/bfa/bfad_ipfc.h [deleted file]
drivers/scsi/bfa/bfad_os.c [deleted file]
drivers/scsi/bfa/bfad_tm.h [deleted file]
drivers/scsi/bfa/bfad_trcmod.h [deleted file]
drivers/scsi/bfa/bfi.h [new file with mode: 0644]
drivers/scsi/bfa/bfi_cbreg.h [new file with mode: 0644]
drivers/scsi/bfa/bfi_ctreg.h [new file with mode: 0644]
drivers/scsi/bfa/bfi_ms.h [new file with mode: 0644]
drivers/scsi/bfa/fab.c [deleted file]
drivers/scsi/bfa/fabric.c [deleted file]
drivers/scsi/bfa/fcbuild.c [deleted file]
drivers/scsi/bfa/fcbuild.h [deleted file]
drivers/scsi/bfa/fcpim.c [deleted file]
drivers/scsi/bfa/fcptm.c [deleted file]
drivers/scsi/bfa/fcs.h [deleted file]
drivers/scsi/bfa/fcs_auth.h [deleted file]
drivers/scsi/bfa/fcs_fabric.h [deleted file]
drivers/scsi/bfa/fcs_fcpim.h [deleted file]
drivers/scsi/bfa/fcs_fcptm.h [deleted file]
drivers/scsi/bfa/fcs_fcxp.h [deleted file]
drivers/scsi/bfa/fcs_lport.h [deleted file]
drivers/scsi/bfa/fcs_ms.h [deleted file]
drivers/scsi/bfa/fcs_port.h [deleted file]
drivers/scsi/bfa/fcs_rport.h [deleted file]
drivers/scsi/bfa/fcs_trcmod.h [deleted file]
drivers/scsi/bfa/fcs_uf.h [deleted file]
drivers/scsi/bfa/fcs_vport.h [deleted file]
drivers/scsi/bfa/fdmi.c [deleted file]
drivers/scsi/bfa/include/aen/bfa_aen.h [deleted file]
drivers/scsi/bfa/include/aen/bfa_aen_adapter.h [deleted file]
drivers/scsi/bfa/include/aen/bfa_aen_audit.h [deleted file]
drivers/scsi/bfa/include/aen/bfa_aen_ethport.h [deleted file]
drivers/scsi/bfa/include/aen/bfa_aen_ioc.h [deleted file]
drivers/scsi/bfa/include/aen/bfa_aen_itnim.h [deleted file]
drivers/scsi/bfa/include/aen/bfa_aen_lport.h [deleted file]
drivers/scsi/bfa/include/aen/bfa_aen_port.h [deleted file]
drivers/scsi/bfa/include/aen/bfa_aen_rport.h [deleted file]
drivers/scsi/bfa/include/bfa.h [deleted file]
drivers/scsi/bfa/include/bfa_fcpim.h [deleted file]
drivers/scsi/bfa/include/bfa_fcptm.h [deleted file]
drivers/scsi/bfa/include/bfa_svc.h [deleted file]
drivers/scsi/bfa/include/bfa_timer.h [deleted file]
drivers/scsi/bfa/include/bfi/bfi.h [deleted file]
drivers/scsi/bfa/include/bfi/bfi_boot.h [deleted file]
drivers/scsi/bfa/include/bfi/bfi_cbreg.h [deleted file]
drivers/scsi/bfa/include/bfi/bfi_cee.h [deleted file]
drivers/scsi/bfa/include/bfi/bfi_ctreg.h [deleted file]
drivers/scsi/bfa/include/bfi/bfi_fabric.h [deleted file]
drivers/scsi/bfa/include/bfi/bfi_fcpim.h [deleted file]
drivers/scsi/bfa/include/bfi/bfi_fcxp.h [deleted file]
drivers/scsi/bfa/include/bfi/bfi_ioc.h [deleted file]
drivers/scsi/bfa/include/bfi/bfi_iocfc.h [deleted file]
drivers/scsi/bfa/include/bfi/bfi_lport.h [deleted file]
drivers/scsi/bfa/include/bfi/bfi_lps.h [deleted file]
drivers/scsi/bfa/include/bfi/bfi_pbc.h [deleted file]
drivers/scsi/bfa/include/bfi/bfi_port.h [deleted file]
drivers/scsi/bfa/include/bfi/bfi_pport.h [deleted file]
drivers/scsi/bfa/include/bfi/bfi_rport.h [deleted file]
drivers/scsi/bfa/include/bfi/bfi_uf.h [deleted file]
drivers/scsi/bfa/include/cna/bfa_cna_trcmod.h [deleted file]
drivers/scsi/bfa/include/cna/cee/bfa_cee.h [deleted file]
drivers/scsi/bfa/include/cna/port/bfa_port.h [deleted file]
drivers/scsi/bfa/include/cna/pstats/ethport_defs.h [deleted file]
drivers/scsi/bfa/include/cna/pstats/phyport_defs.h [deleted file]
drivers/scsi/bfa/include/cs/bfa_checksum.h [deleted file]
drivers/scsi/bfa/include/cs/bfa_debug.h [deleted file]
drivers/scsi/bfa/include/cs/bfa_log.h [deleted file]
drivers/scsi/bfa/include/cs/bfa_perf.h [deleted file]
drivers/scsi/bfa/include/cs/bfa_plog.h [deleted file]
drivers/scsi/bfa/include/cs/bfa_q.h [deleted file]
drivers/scsi/bfa/include/cs/bfa_sm.h [deleted file]
drivers/scsi/bfa/include/cs/bfa_trc.h [deleted file]
drivers/scsi/bfa/include/cs/bfa_wc.h [deleted file]
drivers/scsi/bfa/include/defs/bfa_defs_adapter.h [deleted file]
drivers/scsi/bfa/include/defs/bfa_defs_aen.h [deleted file]
drivers/scsi/bfa/include/defs/bfa_defs_audit.h [deleted file]
drivers/scsi/bfa/include/defs/bfa_defs_auth.h [deleted file]
drivers/scsi/bfa/include/defs/bfa_defs_boot.h [deleted file]
drivers/scsi/bfa/include/defs/bfa_defs_cee.h [deleted file]
drivers/scsi/bfa/include/defs/bfa_defs_driver.h [deleted file]
drivers/scsi/bfa/include/defs/bfa_defs_ethport.h [deleted file]
drivers/scsi/bfa/include/defs/bfa_defs_fcpim.h [deleted file]
drivers/scsi/bfa/include/defs/bfa_defs_fcport.h [deleted file]
drivers/scsi/bfa/include/defs/bfa_defs_ioc.h [deleted file]
drivers/scsi/bfa/include/defs/bfa_defs_iocfc.h [deleted file]
drivers/scsi/bfa/include/defs/bfa_defs_ipfc.h [deleted file]
drivers/scsi/bfa/include/defs/bfa_defs_itnim.h [deleted file]
drivers/scsi/bfa/include/defs/bfa_defs_led.h [deleted file]
drivers/scsi/bfa/include/defs/bfa_defs_lport.h [deleted file]
drivers/scsi/bfa/include/defs/bfa_defs_mfg.h [deleted file]
drivers/scsi/bfa/include/defs/bfa_defs_pci.h [deleted file]
drivers/scsi/bfa/include/defs/bfa_defs_pm.h [deleted file]
drivers/scsi/bfa/include/defs/bfa_defs_pom.h [deleted file]
drivers/scsi/bfa/include/defs/bfa_defs_port.h [deleted file]
drivers/scsi/bfa/include/defs/bfa_defs_pport.h [deleted file]
drivers/scsi/bfa/include/defs/bfa_defs_qos.h [deleted file]
drivers/scsi/bfa/include/defs/bfa_defs_rport.h [deleted file]
drivers/scsi/bfa/include/defs/bfa_defs_status.h [deleted file]
drivers/scsi/bfa/include/defs/bfa_defs_tin.h [deleted file]
drivers/scsi/bfa/include/defs/bfa_defs_tsensor.h [deleted file]
drivers/scsi/bfa/include/defs/bfa_defs_types.h [deleted file]
drivers/scsi/bfa/include/defs/bfa_defs_version.h [deleted file]
drivers/scsi/bfa/include/defs/bfa_defs_vf.h [deleted file]
drivers/scsi/bfa/include/defs/bfa_defs_vport.h [deleted file]
drivers/scsi/bfa/include/fcb/bfa_fcb.h [deleted file]
drivers/scsi/bfa/include/fcb/bfa_fcb_fcpim.h [deleted file]
drivers/scsi/bfa/include/fcb/bfa_fcb_port.h [deleted file]
drivers/scsi/bfa/include/fcb/bfa_fcb_rport.h [deleted file]
drivers/scsi/bfa/include/fcb/bfa_fcb_vf.h [deleted file]
drivers/scsi/bfa/include/fcb/bfa_fcb_vport.h [deleted file]
drivers/scsi/bfa/include/fcs/bfa_fcs.h [deleted file]
drivers/scsi/bfa/include/fcs/bfa_fcs_auth.h [deleted file]
drivers/scsi/bfa/include/fcs/bfa_fcs_fabric.h [deleted file]
drivers/scsi/bfa/include/fcs/bfa_fcs_fcpim.h [deleted file]
drivers/scsi/bfa/include/fcs/bfa_fcs_fdmi.h [deleted file]
drivers/scsi/bfa/include/fcs/bfa_fcs_lport.h [deleted file]
drivers/scsi/bfa/include/fcs/bfa_fcs_rport.h [deleted file]
drivers/scsi/bfa/include/fcs/bfa_fcs_vport.h [deleted file]
drivers/scsi/bfa/include/log/bfa_log_fcs.h [deleted file]
drivers/scsi/bfa/include/log/bfa_log_hal.h [deleted file]
drivers/scsi/bfa/include/log/bfa_log_linux.h [deleted file]
drivers/scsi/bfa/include/log/bfa_log_wdrv.h [deleted file]
drivers/scsi/bfa/include/protocol/ct.h [deleted file]
drivers/scsi/bfa/include/protocol/fc.h [deleted file]
drivers/scsi/bfa/include/protocol/fc_sp.h [deleted file]
drivers/scsi/bfa/include/protocol/fcp.h [deleted file]
drivers/scsi/bfa/include/protocol/fdmi.h [deleted file]
drivers/scsi/bfa/include/protocol/scsi.h [deleted file]
drivers/scsi/bfa/include/protocol/types.h [deleted file]
drivers/scsi/bfa/loop.c [deleted file]
drivers/scsi/bfa/lport_api.c [deleted file]
drivers/scsi/bfa/lport_priv.h [deleted file]
drivers/scsi/bfa/ms.c [deleted file]
drivers/scsi/bfa/n2n.c [deleted file]
drivers/scsi/bfa/ns.c [deleted file]
drivers/scsi/bfa/plog.c [deleted file]
drivers/scsi/bfa/rport.c [deleted file]
drivers/scsi/bfa/rport_api.c [deleted file]
drivers/scsi/bfa/rport_ftrs.c [deleted file]
drivers/scsi/bfa/scn.c [deleted file]
drivers/scsi/bfa/vfapi.c [deleted file]
drivers/scsi/bfa/vport.c [deleted file]

index ac3fdf02d5f6fc9cc47d4c158ea45daac859c6db..d2eefd3e3bd5eb1f0ca69113bd336b9c33791fd1 100644 (file)
@@ -1,15 +1,8 @@
 obj-$(CONFIG_SCSI_BFA_FC) := bfa.o
 
-bfa-y := bfad.o bfad_intr.o bfad_os.o bfad_im.o bfad_attr.o bfad_fwimg.o
-bfa-y += bfad_debugfs.o
-bfa-y += bfa_core.o bfa_ioc.o bfa_ioc_ct.o bfa_ioc_cb.o bfa_iocfc.o bfa_fcxp.o
-bfa-y += bfa_lps.o bfa_hw_cb.o bfa_hw_ct.o bfa_intr.o bfa_timer.o bfa_rport.o
-bfa-y += bfa_fcport.o bfa_port.o bfa_uf.o bfa_sgpg.o bfa_module.o bfa_ioim.o
-bfa-y += bfa_itnim.o bfa_fcpim.o bfa_tskim.o bfa_log.o bfa_log_module.o
-bfa-y += bfa_csdebug.o bfa_sm.o plog.o
+bfa-y := bfad.o bfad_im.o bfad_attr.o bfad_debugfs.o
+bfa-y += bfa_ioc.o bfa_ioc_cb.o bfa_ioc_ct.o bfa_hw_cb.o bfa_hw_ct.o
+bfa-y += bfa_fcs.o bfa_fcs_lport.o bfa_fcs_rport.o bfa_fcs_fcpim.o bfa_fcbuild.o
+bfa-y += bfa_port.o bfa_fcpim.o bfa_core.o bfa_drv.o bfa_svc.o
 
-bfa-y += fcbuild.o fabric.o fcpim.o vfapi.o fcptm.o bfa_fcs.o bfa_fcs_port.o
-bfa-y += bfa_fcs_uf.o bfa_fcs_lport.o fab.o fdmi.o ms.o ns.o scn.o loop.o
-bfa-y += lport_api.o n2n.o rport.o rport_api.o rport_ftrs.o vport.o
-
-ccflags-y := -I$(obj) -I$(obj)/include -I$(obj)/include/cna -DBFA_PERF_BUILD
+ccflags-y := -DBFA_PERF_BUILD
diff --git a/drivers/scsi/bfa/bfa.h b/drivers/scsi/bfa/bfa.h
new file mode 100644 (file)
index 0000000..ceaac65
--- /dev/null
@@ -0,0 +1,438 @@
+/*
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
+ * All rights reserved
+ * www.brocade.com
+ *
+ * Linux driver for Brocade Fibre Channel Host Bus Adapter.
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License (GPL) Version 2 as
+ * published by the Free Software Foundation
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * General Public License for more details.
+ */
+#ifndef __BFA_H__
+#define __BFA_H__
+
+#include "bfa_os_inc.h"
+#include "bfa_cs.h"
+#include "bfa_plog.h"
+#include "bfa_defs_svc.h"
+#include "bfi.h"
+#include "bfa_ioc.h"
+
+struct bfa_s;
+
+typedef void (*bfa_isr_func_t) (struct bfa_s *bfa, struct bfi_msg_s *m);
+typedef void    (*bfa_cb_cbfn_t) (void *cbarg, bfa_boolean_t complete);
+
+/**
+ * Interrupt message handlers
+ */
+void bfa_isr_unhandled(struct bfa_s *bfa, struct bfi_msg_s *m);
+void bfa_isr_bind(enum bfi_mclass mc, bfa_isr_func_t isr_func);
+
+/**
+ * Request and response queue related defines
+ */
+#define BFA_REQQ_NELEMS_MIN    (4)
+#define BFA_RSPQ_NELEMS_MIN    (4)
+
+#define bfa_reqq_pi(__bfa, __reqq)     ((__bfa)->iocfc.req_cq_pi[__reqq])
+#define bfa_reqq_ci(__bfa, __reqq)                                     \
+       (*(u32 *)((__bfa)->iocfc.req_cq_shadow_ci[__reqq].kva))
+
+#define bfa_reqq_full(__bfa, __reqq)                           \
+       (((bfa_reqq_pi(__bfa, __reqq) + 1) &                    \
+         ((__bfa)->iocfc.cfg.drvcfg.num_reqq_elems - 1)) ==    \
+        bfa_reqq_ci(__bfa, __reqq))
+
+#define bfa_reqq_next(__bfa, __reqq)                                   \
+       (bfa_reqq_full(__bfa, __reqq) ? NULL :                          \
+        ((void *)((struct bfi_msg_s *)((__bfa)->iocfc.req_cq_ba[__reqq].kva) \
+                  + bfa_reqq_pi((__bfa), (__reqq)))))
+
+#define bfa_reqq_produce(__bfa, __reqq)        do {                            \
+               (__bfa)->iocfc.req_cq_pi[__reqq]++;                     \
+               (__bfa)->iocfc.req_cq_pi[__reqq] &=                     \
+                       ((__bfa)->iocfc.cfg.drvcfg.num_reqq_elems - 1);      \
+               bfa_reg_write((__bfa)->iocfc.bfa_regs.cpe_q_pi[__reqq], \
+                             (__bfa)->iocfc.req_cq_pi[__reqq]);      \
+               mmiowb();      \
+       } while (0)
+
+#define bfa_rspq_pi(__bfa, __rspq)                                     \
+       (*(u32 *)((__bfa)->iocfc.rsp_cq_shadow_pi[__rspq].kva))
+
+#define bfa_rspq_ci(__bfa, __rspq)     ((__bfa)->iocfc.rsp_cq_ci[__rspq])
+#define bfa_rspq_elem(__bfa, __rspq, __ci)                             \
+       (&((struct bfi_msg_s *)((__bfa)->iocfc.rsp_cq_ba[__rspq].kva))[__ci])
+
+#define CQ_INCR(__index, __size) do {                  \
+       (__index)++;                                    \
+       (__index) &= ((__size) - 1);                    \
+} while (0)
+
+/**
+ * Queue element to wait for room in request queue. FIFO order is
+ * maintained when fullfilling requests.
+ */
+struct bfa_reqq_wait_s {
+       struct list_head        qe;
+       void            (*qresume) (void *cbarg);
+       void            *cbarg;
+};
+
+/**
+ * Circular queue usage assignments
+ */
+enum {
+       BFA_REQQ_IOC    = 0,    /*  all low-priority IOC msgs   */
+       BFA_REQQ_FCXP   = 0,    /*  all FCXP messages           */
+       BFA_REQQ_LPS    = 0,    /*  all lport service msgs      */
+       BFA_REQQ_PORT   = 0,    /*  all port messages           */
+       BFA_REQQ_FLASH  = 0,    /*  for flash module            */
+       BFA_REQQ_DIAG   = 0,    /*  for diag module             */
+       BFA_REQQ_RPORT  = 0,    /*  all port messages           */
+       BFA_REQQ_SBOOT  = 0,    /*  all san boot messages       */
+       BFA_REQQ_QOS_LO = 1,    /*  all low priority IO */
+       BFA_REQQ_QOS_MD = 2,    /*  all medium priority IO      */
+       BFA_REQQ_QOS_HI = 3,    /*  all high priority IO        */
+};
+
+static inline void
+bfa_reqq_winit(struct bfa_reqq_wait_s *wqe, void (*qresume) (void *cbarg),
+              void *cbarg)
+{
+       wqe->qresume = qresume;
+       wqe->cbarg = cbarg;
+}
+
+#define bfa_reqq(__bfa, __reqq)        (&(__bfa)->reqq_waitq[__reqq])
+
+/**
+ * static inline void
+ * bfa_reqq_wait(struct bfa_s *bfa, int reqq, struct bfa_reqq_wait_s *wqe)
+ */
+#define bfa_reqq_wait(__bfa, __reqq, __wqe) do {                       \
+                                                                       \
+               struct list_head *waitq = bfa_reqq(__bfa, __reqq);      \
+                                                                       \
+               bfa_assert(((__reqq) < BFI_IOC_MAX_CQS));      \
+               bfa_assert((__wqe)->qresume && (__wqe)->cbarg);      \
+                                                                       \
+               list_add_tail(&(__wqe)->qe, waitq);      \
+       } while (0)
+
+#define bfa_reqq_wcancel(__wqe)        list_del(&(__wqe)->qe)
+
+
+/**
+ * Generic BFA callback element.
+ */
+struct bfa_cb_qe_s {
+       struct list_head         qe;
+       bfa_cb_cbfn_t  cbfn;
+       bfa_boolean_t   once;
+       u32             rsvd;
+       void           *cbarg;
+};
+
+#define bfa_cb_queue(__bfa, __hcb_qe, __cbfn, __cbarg) do {    \
+               (__hcb_qe)->cbfn  = (__cbfn);      \
+               (__hcb_qe)->cbarg = (__cbarg);      \
+               list_add_tail(&(__hcb_qe)->qe, &(__bfa)->comp_q);      \
+       } while (0)
+
+#define bfa_cb_dequeue(__hcb_qe)       list_del(&(__hcb_qe)->qe)
+
+#define bfa_cb_queue_once(__bfa, __hcb_qe, __cbfn, __cbarg) do {       \
+               (__hcb_qe)->cbfn  = (__cbfn);      \
+               (__hcb_qe)->cbarg = (__cbarg);      \
+               if (!(__hcb_qe)->once) {      \
+                       list_add_tail(&(__hcb_qe)->qe, &(__bfa)->comp_q);      \
+                       (__hcb_qe)->once = BFA_TRUE;                    \
+               }                                                       \
+       } while (0)
+
+#define bfa_cb_queue_done(__hcb_qe) do {       \
+               (__hcb_qe)->once = BFA_FALSE;   \
+       } while (0)
+
+
+/**
+ * PCI devices supported by the current BFA
+ */
+struct bfa_pciid_s {
+       u16     device_id;
+       u16     vendor_id;
+};
+
+extern char     bfa_version[];
+
+/**
+ * BFA memory resources
+ */
+enum bfa_mem_type {
+       BFA_MEM_TYPE_KVA = 1,   /*  Kernel Virtual Memory *(non-dma-able) */
+       BFA_MEM_TYPE_DMA = 2,   /*  DMA-able memory */
+       BFA_MEM_TYPE_MAX = BFA_MEM_TYPE_DMA,
+};
+
+struct bfa_mem_elem_s {
+       enum bfa_mem_type mem_type;     /* see enum bfa_mem_type */
+       u32     mem_len;        /*  Total Length in Bytes       */
+       u8              *kva;           /*  kernel virtual address      */
+       u64     dma;            /*  dma address if DMA memory   */
+       u8              *kva_curp;      /*  kva allocation cursor       */
+       u64     dma_curp;       /*  dma allocation cursor       */
+};
+
+struct bfa_meminfo_s {
+       struct bfa_mem_elem_s meminfo[BFA_MEM_TYPE_MAX];
+};
+#define bfa_meminfo_kva(_m)                            \
+       ((_m)->meminfo[BFA_MEM_TYPE_KVA - 1].kva_curp)
+#define bfa_meminfo_dma_virt(_m)                       \
+       ((_m)->meminfo[BFA_MEM_TYPE_DMA - 1].kva_curp)
+#define bfa_meminfo_dma_phys(_m)                       \
+       ((_m)->meminfo[BFA_MEM_TYPE_DMA - 1].dma_curp)
+
+struct bfa_iocfc_regs_s {
+       bfa_os_addr_t   intr_status;
+       bfa_os_addr_t   intr_mask;
+       bfa_os_addr_t   cpe_q_pi[BFI_IOC_MAX_CQS];
+       bfa_os_addr_t   cpe_q_ci[BFI_IOC_MAX_CQS];
+       bfa_os_addr_t   cpe_q_depth[BFI_IOC_MAX_CQS];
+       bfa_os_addr_t   cpe_q_ctrl[BFI_IOC_MAX_CQS];
+       bfa_os_addr_t   rme_q_ci[BFI_IOC_MAX_CQS];
+       bfa_os_addr_t   rme_q_pi[BFI_IOC_MAX_CQS];
+       bfa_os_addr_t   rme_q_depth[BFI_IOC_MAX_CQS];
+       bfa_os_addr_t   rme_q_ctrl[BFI_IOC_MAX_CQS];
+};
+
+/**
+ * MSIX vector handlers
+ */
+#define BFA_MSIX_MAX_VECTORS   22
+typedef void (*bfa_msix_handler_t)(struct bfa_s *bfa, int vec);
+struct bfa_msix_s {
+       int     nvecs;
+       bfa_msix_handler_t handler[BFA_MSIX_MAX_VECTORS];
+};
+
+/**
+ * Chip specific interfaces
+ */
+struct bfa_hwif_s {
+       void (*hw_reginit)(struct bfa_s *bfa);
+       void (*hw_reqq_ack)(struct bfa_s *bfa, int reqq);
+       void (*hw_rspq_ack)(struct bfa_s *bfa, int rspq);
+       void (*hw_msix_init)(struct bfa_s *bfa, int nvecs);
+       void (*hw_msix_install)(struct bfa_s *bfa);
+       void (*hw_msix_uninstall)(struct bfa_s *bfa);
+       void (*hw_isr_mode_set)(struct bfa_s *bfa, bfa_boolean_t msix);
+       void (*hw_msix_getvecs)(struct bfa_s *bfa, u32 *vecmap,
+                               u32 *nvecs, u32 *maxvec);
+       void (*hw_msix_get_rme_range) (struct bfa_s *bfa, u32 *start,
+                                      u32 *end);
+};
+typedef void (*bfa_cb_iocfc_t) (void *cbarg, enum bfa_status status);
+
+struct bfa_iocfc_s {
+       struct bfa_s            *bfa;
+       struct bfa_iocfc_cfg_s  cfg;
+       int                     action;
+       u32             req_cq_pi[BFI_IOC_MAX_CQS];
+       u32             rsp_cq_ci[BFI_IOC_MAX_CQS];
+       struct bfa_cb_qe_s      init_hcb_qe;
+       struct bfa_cb_qe_s      stop_hcb_qe;
+       struct bfa_cb_qe_s      dis_hcb_qe;
+       struct bfa_cb_qe_s      stats_hcb_qe;
+       bfa_boolean_t           cfgdone;
+
+       struct bfa_dma_s        cfg_info;
+       struct bfi_iocfc_cfg_s *cfginfo;
+       struct bfa_dma_s        cfgrsp_dma;
+       struct bfi_iocfc_cfgrsp_s *cfgrsp;
+       struct bfi_iocfc_cfg_reply_s *cfg_reply;
+       struct bfa_dma_s        req_cq_ba[BFI_IOC_MAX_CQS];
+       struct bfa_dma_s        req_cq_shadow_ci[BFI_IOC_MAX_CQS];
+       struct bfa_dma_s        rsp_cq_ba[BFI_IOC_MAX_CQS];
+       struct bfa_dma_s        rsp_cq_shadow_pi[BFI_IOC_MAX_CQS];
+       struct bfa_iocfc_regs_s bfa_regs;       /*  BFA device registers */
+       struct bfa_hwif_s       hwif;
+       bfa_cb_iocfc_t          updateq_cbfn; /*  bios callback function */
+       void                    *updateq_cbarg; /*  bios callback arg */
+       u32     intr_mask;
+};
+
+#define bfa_lpuid(__bfa)                                               \
+       bfa_ioc_portid(&(__bfa)->ioc)
+#define bfa_msix_init(__bfa, __nvecs)                                  \
+       ((__bfa)->iocfc.hwif.hw_msix_init(__bfa, __nvecs))
+#define bfa_msix_install(__bfa)                                                \
+       ((__bfa)->iocfc.hwif.hw_msix_install(__bfa))
+#define bfa_msix_uninstall(__bfa)                                      \
+       ((__bfa)->iocfc.hwif.hw_msix_uninstall(__bfa))
+#define bfa_isr_mode_set(__bfa, __msix)                                        \
+       ((__bfa)->iocfc.hwif.hw_isr_mode_set(__bfa, __msix))
+#define bfa_msix_getvecs(__bfa, __vecmap, __nvecs, __maxvec)           \
+       ((__bfa)->iocfc.hwif.hw_msix_getvecs(__bfa, __vecmap,           \
+                                       __nvecs, __maxvec))
+#define bfa_msix_get_rme_range(__bfa, __start, __end)                  \
+       ((__bfa)->iocfc.hwif.hw_msix_get_rme_range(__bfa, __start, __end))
+#define bfa_msix(__bfa, __vec)                                         \
+       ((__bfa)->msix.handler[__vec](__bfa, __vec))
+
+/*
+ * FC specific IOC functions.
+ */
+void bfa_iocfc_meminfo(struct bfa_iocfc_cfg_s *cfg, u32 *km_len,
+                      u32 *dm_len);
+void bfa_iocfc_attach(struct bfa_s *bfa, void *bfad,
+                     struct bfa_iocfc_cfg_s *cfg,
+                     struct bfa_meminfo_s *meminfo,
+                     struct bfa_pcidev_s *pcidev);
+void bfa_iocfc_detach(struct bfa_s *bfa);
+void bfa_iocfc_init(struct bfa_s *bfa);
+void bfa_iocfc_start(struct bfa_s *bfa);
+void bfa_iocfc_stop(struct bfa_s *bfa);
+void bfa_iocfc_isr(void *bfa, struct bfi_mbmsg_s *msg);
+void bfa_iocfc_set_snsbase(struct bfa_s *bfa, u64 snsbase_pa);
+bfa_boolean_t bfa_iocfc_is_operational(struct bfa_s *bfa);
+void bfa_iocfc_reset_queues(struct bfa_s *bfa);
+
+void bfa_msix_all(struct bfa_s *bfa, int vec);
+void bfa_msix_reqq(struct bfa_s *bfa, int vec);
+void bfa_msix_rspq(struct bfa_s *bfa, int vec);
+void bfa_msix_lpu_err(struct bfa_s *bfa, int vec);
+
+void bfa_hwcb_reginit(struct bfa_s *bfa);
+void bfa_hwcb_reqq_ack(struct bfa_s *bfa, int rspq);
+void bfa_hwcb_rspq_ack(struct bfa_s *bfa, int rspq);
+void bfa_hwcb_msix_init(struct bfa_s *bfa, int nvecs);
+void bfa_hwcb_msix_install(struct bfa_s *bfa);
+void bfa_hwcb_msix_uninstall(struct bfa_s *bfa);
+void bfa_hwcb_isr_mode_set(struct bfa_s *bfa, bfa_boolean_t msix);
+void bfa_hwcb_msix_getvecs(struct bfa_s *bfa, u32 *vecmap, u32 *nvecs,
+                          u32 *maxvec);
+void bfa_hwcb_msix_get_rme_range(struct bfa_s *bfa, u32 *start,
+                                u32 *end);
+void bfa_hwct_reginit(struct bfa_s *bfa);
+void bfa_hwct_reqq_ack(struct bfa_s *bfa, int rspq);
+void bfa_hwct_rspq_ack(struct bfa_s *bfa, int rspq);
+void bfa_hwct_msix_init(struct bfa_s *bfa, int nvecs);
+void bfa_hwct_msix_install(struct bfa_s *bfa);
+void bfa_hwct_msix_uninstall(struct bfa_s *bfa);
+void bfa_hwct_isr_mode_set(struct bfa_s *bfa, bfa_boolean_t msix);
+void bfa_hwct_msix_getvecs(struct bfa_s *bfa, u32 *vecmap, u32 *nvecs,
+                          u32 *maxvec);
+void bfa_hwct_msix_get_rme_range(struct bfa_s *bfa, u32 *start,
+                                u32 *end);
+void bfa_com_port_attach(struct bfa_s *bfa, struct bfa_meminfo_s *mi);
+void bfa_iocfc_get_bootwwns(struct bfa_s *bfa, u8 *nwwns, wwn_t *wwns);
+wwn_t bfa_iocfc_get_pwwn(struct bfa_s *bfa);
+wwn_t bfa_iocfc_get_nwwn(struct bfa_s *bfa);
+void bfa_iocfc_get_pbc_boot_cfg(struct bfa_s *bfa,
+                               struct bfa_boot_pbc_s *pbcfg);
+int bfa_iocfc_get_pbc_vports(struct bfa_s *bfa,
+                               struct bfi_pbc_vport_s *pbc_vport);
+
+
+/**
+ *----------------------------------------------------------------------
+ *             BFA public interfaces
+ *----------------------------------------------------------------------
+ */
+#define bfa_stats(_mod, _stats)        ((_mod)->stats._stats++)
+#define bfa_ioc_get_stats(__bfa, __ioc_stats)          \
+       bfa_ioc_fetch_stats(&(__bfa)->ioc, __ioc_stats)
+#define bfa_ioc_clear_stats(__bfa)             \
+       bfa_ioc_clr_stats(&(__bfa)->ioc)
+#define bfa_get_nports(__bfa)                  \
+       bfa_ioc_get_nports(&(__bfa)->ioc)
+#define bfa_get_adapter_manufacturer(__bfa, __manufacturer)            \
+       bfa_ioc_get_adapter_manufacturer(&(__bfa)->ioc, __manufacturer)
+#define bfa_get_adapter_model(__bfa, __model)                  \
+       bfa_ioc_get_adapter_model(&(__bfa)->ioc, __model)
+#define bfa_get_adapter_serial_num(__bfa, __serial_num)                        \
+       bfa_ioc_get_adapter_serial_num(&(__bfa)->ioc, __serial_num)
+#define bfa_get_adapter_fw_ver(__bfa, __fw_ver)                        \
+       bfa_ioc_get_adapter_fw_ver(&(__bfa)->ioc, __fw_ver)
+#define bfa_get_adapter_optrom_ver(__bfa, __optrom_ver)                        \
+       bfa_ioc_get_adapter_optrom_ver(&(__bfa)->ioc, __optrom_ver)
+#define bfa_get_pci_chip_rev(__bfa, __chip_rev)                        \
+       bfa_ioc_get_pci_chip_rev(&(__bfa)->ioc, __chip_rev)
+#define bfa_get_ioc_state(__bfa)               \
+       bfa_ioc_get_state(&(__bfa)->ioc)
+#define bfa_get_type(__bfa)                    \
+       bfa_ioc_get_type(&(__bfa)->ioc)
+#define bfa_get_mac(__bfa)                     \
+       bfa_ioc_get_mac(&(__bfa)->ioc)
+#define bfa_get_mfg_mac(__bfa)                 \
+       bfa_ioc_get_mfg_mac(&(__bfa)->ioc)
+#define bfa_get_fw_clock_res(__bfa)            \
+       ((__bfa)->iocfc.cfgrsp->fwcfg.fw_tick_res)
+
+void bfa_get_pciids(struct bfa_pciid_s **pciids, int *npciids);
+void bfa_cfg_get_default(struct bfa_iocfc_cfg_s *cfg);
+void bfa_cfg_get_min(struct bfa_iocfc_cfg_s *cfg);
+void bfa_cfg_get_meminfo(struct bfa_iocfc_cfg_s *cfg,
+                        struct bfa_meminfo_s *meminfo);
+void bfa_attach(struct bfa_s *bfa, void *bfad, struct bfa_iocfc_cfg_s *cfg,
+               struct bfa_meminfo_s *meminfo,
+               struct bfa_pcidev_s *pcidev);
+void bfa_init_trc(struct bfa_s *bfa, struct bfa_trc_mod_s *trcmod);
+void bfa_init_plog(struct bfa_s *bfa, struct bfa_plog_s *plog);
+void bfa_detach(struct bfa_s *bfa);
+void bfa_init(struct bfa_s *bfa);
+void bfa_start(struct bfa_s *bfa);
+void bfa_stop(struct bfa_s *bfa);
+void bfa_attach_fcs(struct bfa_s *bfa);
+void bfa_cb_init(void *bfad, bfa_status_t status);
+void bfa_cb_updateq(void *bfad, bfa_status_t status);
+
+bfa_boolean_t bfa_intx(struct bfa_s *bfa);
+void bfa_intx_disable(struct bfa_s *bfa);
+void bfa_intx_enable(struct bfa_s *bfa);
+void bfa_isr_enable(struct bfa_s *bfa);
+void bfa_isr_disable(struct bfa_s *bfa);
+
+void bfa_comp_deq(struct bfa_s *bfa, struct list_head *comp_q);
+void bfa_comp_process(struct bfa_s *bfa, struct list_head *comp_q);
+void bfa_comp_free(struct bfa_s *bfa, struct list_head *comp_q);
+
+typedef void (*bfa_cb_ioc_t) (void *cbarg, enum bfa_status status);
+void bfa_iocfc_get_attr(struct bfa_s *bfa, struct bfa_iocfc_attr_s *attr);
+void bfa_get_attr(struct bfa_s *bfa, struct bfa_ioc_attr_s *ioc_attr);
+
+void bfa_adapter_get_attr(struct bfa_s *bfa,
+                         struct bfa_adapter_attr_s *ad_attr);
+u64 bfa_adapter_get_id(struct bfa_s *bfa);
+
+bfa_status_t bfa_iocfc_israttr_set(struct bfa_s *bfa,
+                                  struct bfa_iocfc_intr_attr_s *attr);
+
+void bfa_iocfc_enable(struct bfa_s *bfa);
+void bfa_iocfc_disable(struct bfa_s *bfa);
+void bfa_chip_reset(struct bfa_s *bfa);
+void bfa_timer_tick(struct bfa_s *bfa);
+#define bfa_timer_start(_bfa, _timer, _timercb, _arg, _timeout)                \
+       bfa_timer_begin(&(_bfa)->timer_mod, _timer, _timercb, _arg, _timeout)
+
+/*
+ * BFA debug API functions
+ */
+bfa_status_t bfa_debug_fwtrc(struct bfa_s *bfa, void *trcdata, int *trclen);
+bfa_status_t bfa_debug_fwsave(struct bfa_s *bfa, void *trcdata, int *trclen);
+bfa_status_t bfa_debug_fwcore(struct bfa_s *bfa, void *buf,
+                             u32 *offset, int *buflen);
+void bfa_debug_fwsave_clear(struct bfa_s *bfa);
+bfa_status_t bfa_fw_stats_get(struct bfa_s *bfa, void *data);
+bfa_status_t bfa_fw_stats_clear(struct bfa_s *bfa);
+
+#endif /* __BFA_H__ */
diff --git a/drivers/scsi/bfa/bfa_callback_priv.h b/drivers/scsi/bfa/bfa_callback_priv.h
deleted file mode 100644 (file)
index 1e3265c..0000000
+++ /dev/null
@@ -1,57 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_CALLBACK_PRIV_H__
-#define __BFA_CALLBACK_PRIV_H__
-
-#include <cs/bfa_q.h>
-
-typedef void    (*bfa_cb_cbfn_t) (void *cbarg, bfa_boolean_t complete);
-
-/**
- * Generic BFA callback element.
- */
-struct bfa_cb_qe_s {
-       struct list_head         qe;
-       bfa_cb_cbfn_t  cbfn;
-       bfa_boolean_t   once;
-       u32             rsvd;
-       void           *cbarg;
-};
-
-#define bfa_cb_queue(__bfa, __hcb_qe, __cbfn, __cbarg) do {            \
-       (__hcb_qe)->cbfn  = (__cbfn);      \
-       (__hcb_qe)->cbarg = (__cbarg);      \
-       list_add_tail(&(__hcb_qe)->qe, &(__bfa)->comp_q);      \
-} while (0)
-
-#define bfa_cb_dequeue(__hcb_qe)       list_del(&(__hcb_qe)->qe)
-
-#define bfa_cb_queue_once(__bfa, __hcb_qe, __cbfn, __cbarg) do {       \
-       (__hcb_qe)->cbfn  = (__cbfn);      \
-       (__hcb_qe)->cbarg = (__cbarg);      \
-       if (!(__hcb_qe)->once) {      \
-               list_add_tail((__hcb_qe), &(__bfa)->comp_q);      \
-               (__hcb_qe)->once = BFA_TRUE;                            \
-       }                                                               \
-} while (0)
-
-#define bfa_cb_queue_done(__hcb_qe) do {                               \
-       (__hcb_qe)->once = BFA_FALSE;                                   \
-} while (0)
-
-#endif /* __BFA_CALLBACK_PRIV_H__ */
diff --git a/drivers/scsi/bfa/bfa_cb_ioim.h b/drivers/scsi/bfa/bfa_cb_ioim.h
new file mode 100644 (file)
index 0000000..a989a94
--- /dev/null
@@ -0,0 +1,169 @@
+/*
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
+ * All rights reserved
+ * www.brocade.com
+ *
+ * Linux driver for Brocade Fibre Channel Host Bus Adapter.
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License (GPL) Version 2 as
+ * published by the Free Software Foundation
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * General Public License for more details.
+ */
+
+#ifndef __BFA_HCB_IOIM_H__
+#define __BFA_HCB_IOIM_H__
+
+#include "bfa_os_inc.h"
+/*
+ * task attribute values in FCP-2 FCP_CMND IU
+ */
+#define SIMPLE_Q    0
+#define HEAD_OF_Q   1
+#define ORDERED_Q   2
+#define ACA_Q      4
+#define UNTAGGED    5
+
+static inline lun_t
+bfad_int_to_lun(u32 luno)
+{
+       union {
+               u16     scsi_lun[4];
+               lun_t           bfa_lun;
+       } lun;
+
+       lun.bfa_lun     = 0;
+       lun.scsi_lun[0] = bfa_os_htons(luno);
+
+       return lun.bfa_lun;
+}
+
+/**
+ * Get LUN for the I/O request
+ */
+#define bfa_cb_ioim_get_lun(__dio)     \
+       bfad_int_to_lun(((struct scsi_cmnd *)__dio)->device->lun)
+
+/**
+ * Get CDB for the I/O request
+ */
+static inline u8 *
+bfa_cb_ioim_get_cdb(struct bfad_ioim_s *dio)
+{
+       struct scsi_cmnd *cmnd = (struct scsi_cmnd *)dio;
+
+       return (u8 *) cmnd->cmnd;
+}
+
+/**
+ * Get I/O direction (read/write) for the I/O request
+ */
+static inline enum fcp_iodir
+bfa_cb_ioim_get_iodir(struct bfad_ioim_s *dio)
+{
+       struct scsi_cmnd *cmnd = (struct scsi_cmnd *)dio;
+       enum dma_data_direction dmadir;
+
+       dmadir = cmnd->sc_data_direction;
+       if (dmadir == DMA_TO_DEVICE)
+               return FCP_IODIR_WRITE;
+       else if (dmadir == DMA_FROM_DEVICE)
+               return FCP_IODIR_READ;
+       else
+               return FCP_IODIR_NONE;
+}
+
+/**
+ * Get IO size in bytes for the I/O request
+ */
+static inline u32
+bfa_cb_ioim_get_size(struct bfad_ioim_s *dio)
+{
+       struct scsi_cmnd *cmnd = (struct scsi_cmnd *)dio;
+
+       return scsi_bufflen(cmnd);
+}
+
+/**
+ * Get timeout for the I/O request
+ */
+static inline u8
+bfa_cb_ioim_get_timeout(struct bfad_ioim_s *dio)
+{
+       struct scsi_cmnd *cmnd = (struct scsi_cmnd *)dio;
+       /*
+        * TBD: need a timeout for scsi passthru
+        */
+       if (cmnd->device->host == NULL)
+               return 4;
+
+       return 0;
+}
+
+/**
+ * Get Command Reference Number for the I/O request. 0 if none.
+ */
+static inline u8
+bfa_cb_ioim_get_crn(struct bfad_ioim_s *dio)
+{
+       return 0;
+}
+
+/**
+ * Get SAM-3 priority for the I/O request. 0 is default.
+ */
+static inline u8
+bfa_cb_ioim_get_priority(struct bfad_ioim_s *dio)
+{
+       return 0;
+}
+
+/**
+ * Get task attributes for the I/O request. Default is FCP_TASK_ATTR_SIMPLE(0).
+ */
+static inline u8
+bfa_cb_ioim_get_taskattr(struct bfad_ioim_s *dio)
+{
+       struct scsi_cmnd *cmnd = (struct scsi_cmnd *)dio;
+       u8      task_attr = UNTAGGED;
+
+       if (cmnd->device->tagged_supported) {
+               switch (cmnd->tag) {
+               case HEAD_OF_QUEUE_TAG:
+                       task_attr = HEAD_OF_Q;
+                       break;
+               case ORDERED_QUEUE_TAG:
+                       task_attr = ORDERED_Q;
+                       break;
+               default:
+                       task_attr = SIMPLE_Q;
+                       break;
+               }
+       }
+
+       return task_attr;
+}
+
+/**
+ * Get CDB length in bytes for the I/O request. Default is FCP_CMND_CDB_LEN(16).
+ */
+static inline u8
+bfa_cb_ioim_get_cdblen(struct bfad_ioim_s *dio)
+{
+       struct scsi_cmnd *cmnd = (struct scsi_cmnd *)dio;
+
+       return cmnd->cmd_len;
+}
+
+/**
+ * Assign queue to be used for the I/O request. This value depends on whether
+ * the driver wants to use the queues via any specific algorithm. Currently,
+ * this is not supported.
+ */
+#define bfa_cb_ioim_get_reqq(__dio) BFA_FALSE
+
+#endif /* __BFA_HCB_IOIM_H__ */
diff --git a/drivers/scsi/bfa/bfa_cb_ioim_macros.h b/drivers/scsi/bfa/bfa_cb_ioim_macros.h
deleted file mode 100644 (file)
index 3906ed9..0000000
+++ /dev/null
@@ -1,181 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  bfa_cb_ioim_macros.h BFA IOIM driver interface macros.
- */
-
-#ifndef __BFA_HCB_IOIM_MACROS_H__
-#define __BFA_HCB_IOIM_MACROS_H__
-
-#include <bfa_os_inc.h>
-/*
- * #include <linux/dma-mapping.h>
- *
- * #include <scsi/scsi.h> #include <scsi/scsi_cmnd.h> #include
- * <scsi/scsi_device.h> #include <scsi/scsi_host.h>
- */
-#include "bfad_im_compat.h"
-
-/*
- * task attribute values in FCP-2 FCP_CMND IU
- */
-#define SIMPLE_Q    0
-#define HEAD_OF_Q   1
-#define ORDERED_Q   2
-#define ACA_Q       4
-#define UNTAGGED    5
-
-static inline lun_t
-bfad_int_to_lun(u32 luno)
-{
-       union {
-               u16        scsi_lun[4];
-               lun_t           bfa_lun;
-       } lun;
-
-       lun.bfa_lun     = 0;
-       lun.scsi_lun[0] = bfa_os_htons(luno);
-
-       return lun.bfa_lun;
-}
-
-/**
- * Get LUN for the I/O request
- */
-#define bfa_cb_ioim_get_lun(__dio)     \
-       bfad_int_to_lun(((struct scsi_cmnd *)__dio)->device->lun)
-
-/**
- * Get CDB for the I/O request
- */
-static inline u8 *
-bfa_cb_ioim_get_cdb(struct bfad_ioim_s *dio)
-{
-       struct scsi_cmnd *cmnd = (struct scsi_cmnd *)dio;
-
-       return (u8 *) cmnd->cmnd;
-}
-
-/**
- * Get I/O direction (read/write) for the I/O request
- */
-static inline enum fcp_iodir
-bfa_cb_ioim_get_iodir(struct bfad_ioim_s *dio)
-{
-       struct scsi_cmnd *cmnd = (struct scsi_cmnd *)dio;
-       enum dma_data_direction dmadir;
-
-       dmadir = cmnd->sc_data_direction;
-       if (dmadir == DMA_TO_DEVICE)
-               return FCP_IODIR_WRITE;
-       else if (dmadir == DMA_FROM_DEVICE)
-               return FCP_IODIR_READ;
-       else
-               return FCP_IODIR_NONE;
-}
-
-/**
- * Get IO size in bytes for the I/O request
- */
-static inline u32
-bfa_cb_ioim_get_size(struct bfad_ioim_s *dio)
-{
-       struct scsi_cmnd *cmnd = (struct scsi_cmnd *)dio;
-
-       return scsi_bufflen(cmnd);
-}
-
-/**
- * Get timeout for the I/O request
- */
-static inline u8
-bfa_cb_ioim_get_timeout(struct bfad_ioim_s *dio)
-{
-       struct scsi_cmnd *cmnd = (struct scsi_cmnd *)dio;
-       /*
-        * TBD: need a timeout for scsi passthru
-        */
-       if (cmnd->device->host == NULL)
-               return 4;
-
-       return 0;
-}
-
-/**
- * Get Command Reference Number for the I/O request. 0 if none.
- */
-static inline u8
-bfa_cb_ioim_get_crn(struct bfad_ioim_s *dio)
-{
-       return 0;
-}
-
-/**
- * Get SAM-3 priority for the I/O request. 0 is default.
- */
-static inline u8
-bfa_cb_ioim_get_priority(struct bfad_ioim_s *dio)
-{
-       return 0;
-}
-
-/**
- * Get task attributes for the I/O request. Default is FCP_TASK_ATTR_SIMPLE(0).
- */
-static inline u8
-bfa_cb_ioim_get_taskattr(struct bfad_ioim_s *dio)
-{
-       struct scsi_cmnd *cmnd = (struct scsi_cmnd *)dio;
-       u8         task_attr = UNTAGGED;
-
-       if (cmnd->device->tagged_supported) {
-               switch (cmnd->tag) {
-               case HEAD_OF_QUEUE_TAG:
-                       task_attr = HEAD_OF_Q;
-                       break;
-               case ORDERED_QUEUE_TAG:
-                       task_attr = ORDERED_Q;
-                       break;
-               default:
-                       task_attr = SIMPLE_Q;
-                       break;
-               }
-       }
-
-       return task_attr;
-}
-
-/**
- * Get CDB length in bytes for the I/O request. Default is FCP_CMND_CDB_LEN(16).
- */
-static inline u8
-bfa_cb_ioim_get_cdblen(struct bfad_ioim_s *dio)
-{
-       struct scsi_cmnd *cmnd = (struct scsi_cmnd *)dio;
-
-       return cmnd->cmd_len;
-}
-
-/**
- * Assign queue to be used for the I/O request. This value depends on whether
- * the driver wants to use the queues via any specific algorithm. Currently,
- * this is not supported.
- */
-#define bfa_cb_ioim_get_reqq(__dio) BFA_FALSE
-
-#endif /* __BFA_HCB_IOIM_MACROS_H__ */
diff --git a/drivers/scsi/bfa/bfa_cee.c b/drivers/scsi/bfa/bfa_cee.c
deleted file mode 100644 (file)
index 2b91779..0000000
+++ /dev/null
@@ -1,492 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#include <defs/bfa_defs_cee.h>
-#include <cs/bfa_trc.h>
-#include <cs/bfa_log.h>
-#include <cs/bfa_debug.h>
-#include <cee/bfa_cee.h>
-#include <bfi/bfi_cee.h>
-#include <bfi/bfi.h>
-#include <bfa_ioc.h>
-#include <cna/bfa_cna_trcmod.h>
-
-BFA_TRC_FILE(CNA, CEE);
-
-#define bfa_ioc_portid(__ioc) ((__ioc)->port_id)
-#define bfa_lpuid(__arg) bfa_ioc_portid(&(__arg)->ioc)
-
-static void     bfa_cee_format_lldp_cfg(struct bfa_cee_lldp_cfg_s *lldp_cfg);
-static void     bfa_cee_format_dcbcx_stats(struct bfa_cee_dcbx_stats_s
-                                          *dcbcx_stats);
-static void     bfa_cee_format_lldp_stats(struct bfa_cee_lldp_stats_s
-                                         *lldp_stats);
-static void     bfa_cee_format_cfg_stats(struct bfa_cee_cfg_stats_s *cfg_stats);
-static void     bfa_cee_format_cee_cfg(void *buffer);
-static void     bfa_cee_format_cee_stats(void *buffer);
-
-static void
-bfa_cee_format_cee_stats(void *buffer)
-{
-       struct bfa_cee_stats_s *cee_stats = buffer;
-       bfa_cee_format_dcbcx_stats(&cee_stats->dcbx_stats);
-       bfa_cee_format_lldp_stats(&cee_stats->lldp_stats);
-       bfa_cee_format_cfg_stats(&cee_stats->cfg_stats);
-}
-
-static void
-bfa_cee_format_cee_cfg(void *buffer)
-{
-       struct bfa_cee_attr_s *cee_cfg = buffer;
-       bfa_cee_format_lldp_cfg(&cee_cfg->lldp_remote);
-}
-
-static void
-bfa_cee_format_dcbcx_stats(struct bfa_cee_dcbx_stats_s *dcbcx_stats)
-{
-       dcbcx_stats->subtlvs_unrecognized =
-               bfa_os_ntohl(dcbcx_stats->subtlvs_unrecognized);
-       dcbcx_stats->negotiation_failed =
-               bfa_os_ntohl(dcbcx_stats->negotiation_failed);
-       dcbcx_stats->remote_cfg_changed =
-               bfa_os_ntohl(dcbcx_stats->remote_cfg_changed);
-       dcbcx_stats->tlvs_received = bfa_os_ntohl(dcbcx_stats->tlvs_received);
-       dcbcx_stats->tlvs_invalid = bfa_os_ntohl(dcbcx_stats->tlvs_invalid);
-       dcbcx_stats->seqno = bfa_os_ntohl(dcbcx_stats->seqno);
-       dcbcx_stats->ackno = bfa_os_ntohl(dcbcx_stats->ackno);
-       dcbcx_stats->recvd_seqno = bfa_os_ntohl(dcbcx_stats->recvd_seqno);
-       dcbcx_stats->recvd_ackno = bfa_os_ntohl(dcbcx_stats->recvd_ackno);
-}
-
-static void
-bfa_cee_format_lldp_stats(struct bfa_cee_lldp_stats_s *lldp_stats)
-{
-       lldp_stats->frames_transmitted =
-               bfa_os_ntohl(lldp_stats->frames_transmitted);
-       lldp_stats->frames_aged_out = bfa_os_ntohl(lldp_stats->frames_aged_out);
-       lldp_stats->frames_discarded =
-               bfa_os_ntohl(lldp_stats->frames_discarded);
-       lldp_stats->frames_in_error = bfa_os_ntohl(lldp_stats->frames_in_error);
-       lldp_stats->frames_rcvd = bfa_os_ntohl(lldp_stats->frames_rcvd);
-       lldp_stats->tlvs_discarded = bfa_os_ntohl(lldp_stats->tlvs_discarded);
-       lldp_stats->tlvs_unrecognized =
-               bfa_os_ntohl(lldp_stats->tlvs_unrecognized);
-}
-
-static void
-bfa_cee_format_cfg_stats(struct bfa_cee_cfg_stats_s *cfg_stats)
-{
-       cfg_stats->cee_status_down = bfa_os_ntohl(cfg_stats->cee_status_down);
-       cfg_stats->cee_status_up = bfa_os_ntohl(cfg_stats->cee_status_up);
-       cfg_stats->cee_hw_cfg_changed =
-               bfa_os_ntohl(cfg_stats->cee_hw_cfg_changed);
-       cfg_stats->recvd_invalid_cfg =
-               bfa_os_ntohl(cfg_stats->recvd_invalid_cfg);
-}
-
-static void
-bfa_cee_format_lldp_cfg(struct bfa_cee_lldp_cfg_s *lldp_cfg)
-{
-       lldp_cfg->time_to_interval = bfa_os_ntohs(lldp_cfg->time_to_interval);
-       lldp_cfg->enabled_system_cap =
-               bfa_os_ntohs(lldp_cfg->enabled_system_cap);
-}
-
-/**
- * bfa_cee_attr_meminfo()
- *
- *
- * @param[in] void
- *
- * @return Size of DMA region
- */
-static          u32
-bfa_cee_attr_meminfo(void)
-{
-       return BFA_ROUNDUP(sizeof(struct bfa_cee_attr_s), BFA_DMA_ALIGN_SZ);
-}
-
-/**
- * bfa_cee_stats_meminfo()
- *
- *
- * @param[in] void
- *
- * @return Size of DMA region
- */
-static          u32
-bfa_cee_stats_meminfo(void)
-{
-       return BFA_ROUNDUP(sizeof(struct bfa_cee_stats_s), BFA_DMA_ALIGN_SZ);
-}
-
-/**
- * bfa_cee_get_attr_isr()
- *
- *
- * @param[in] cee - Pointer to the CEE module
- *            status - Return status from the f/w
- *
- * @return void
- */
-static void
-bfa_cee_get_attr_isr(struct bfa_cee_s *cee, bfa_status_t status)
-{
-       cee->get_attr_status = status;
-       bfa_trc(cee, 0);
-       if (status == BFA_STATUS_OK) {
-               bfa_trc(cee, 0);
-               /*
-                * The requested data has been copied to the DMA area, *process
-                * it.
-                */
-               memcpy(cee->attr, cee->attr_dma.kva,
-                      sizeof(struct bfa_cee_attr_s));
-               bfa_cee_format_cee_cfg(cee->attr);
-       }
-       cee->get_attr_pending = BFA_FALSE;
-       if (cee->cbfn.get_attr_cbfn) {
-               bfa_trc(cee, 0);
-               cee->cbfn.get_attr_cbfn(cee->cbfn.get_attr_cbarg, status);
-       }
-       bfa_trc(cee, 0);
-}
-
-/**
- * bfa_cee_get_attr_isr()
- *
- *
- * @param[in] cee - Pointer to the CEE module
- *            status - Return status from the f/w
- *
- * @return void
- */
-static void
-bfa_cee_get_stats_isr(struct bfa_cee_s *cee, bfa_status_t status)
-{
-       cee->get_stats_status = status;
-       bfa_trc(cee, 0);
-       if (status == BFA_STATUS_OK) {
-               bfa_trc(cee, 0);
-               /*
-                * The requested data has been copied to the DMA area, process
-                * it.
-                */
-               memcpy(cee->stats, cee->stats_dma.kva,
-                      sizeof(struct bfa_cee_stats_s));
-               bfa_cee_format_cee_stats(cee->stats);
-       }
-       cee->get_stats_pending = BFA_FALSE;
-       bfa_trc(cee, 0);
-       if (cee->cbfn.get_stats_cbfn) {
-               bfa_trc(cee, 0);
-               cee->cbfn.get_stats_cbfn(cee->cbfn.get_stats_cbarg, status);
-       }
-       bfa_trc(cee, 0);
-}
-
-/**
- * bfa_cee_get_attr_isr()
- *
- *
- * @param[in] cee - Pointer to the CEE module
- *            status - Return status from the f/w
- *
- * @return void
- */
-static void
-bfa_cee_reset_stats_isr(struct bfa_cee_s *cee, bfa_status_t status)
-{
-       cee->reset_stats_status = status;
-       cee->reset_stats_pending = BFA_FALSE;
-       if (cee->cbfn.reset_stats_cbfn)
-               cee->cbfn.reset_stats_cbfn(cee->cbfn.reset_stats_cbarg, status);
-}
-
-/**
- * bfa_cee_meminfo()
- *
- *
- * @param[in] void
- *
- * @return Size of DMA region
- */
-u32
-bfa_cee_meminfo(void)
-{
-       return bfa_cee_attr_meminfo() + bfa_cee_stats_meminfo();
-}
-
-/**
- * bfa_cee_mem_claim()
- *
- *
- * @param[in] cee CEE module pointer
- *           dma_kva Kernel Virtual Address of CEE DMA Memory
- *           dma_pa  Physical Address of CEE DMA Memory
- *
- * @return void
- */
-void
-bfa_cee_mem_claim(struct bfa_cee_s *cee, u8 *dma_kva, u64 dma_pa)
-{
-       cee->attr_dma.kva = dma_kva;
-       cee->attr_dma.pa = dma_pa;
-       cee->stats_dma.kva = dma_kva + bfa_cee_attr_meminfo();
-       cee->stats_dma.pa = dma_pa + bfa_cee_attr_meminfo();
-       cee->attr = (struct bfa_cee_attr_s *)dma_kva;
-       cee->stats =
-               (struct bfa_cee_stats_s *)(dma_kva + bfa_cee_attr_meminfo());
-}
-
-/**
- * bfa_cee_get_attr()
- *
- *   Send the request to the f/w to fetch CEE attributes.
- *
- * @param[in] Pointer to the CEE module data structure.
- *
- * @return Status
- */
-
-bfa_status_t
-bfa_cee_get_attr(struct bfa_cee_s *cee, struct bfa_cee_attr_s *attr,
-                bfa_cee_get_attr_cbfn_t cbfn, void *cbarg)
-{
-       struct bfi_cee_get_req_s *cmd;
-
-       bfa_assert((cee != NULL) && (cee->ioc != NULL));
-       bfa_trc(cee, 0);
-       if (!bfa_ioc_is_operational(cee->ioc)) {
-               bfa_trc(cee, 0);
-               return BFA_STATUS_IOC_FAILURE;
-       }
-       if (cee->get_attr_pending == BFA_TRUE) {
-               bfa_trc(cee, 0);
-               return BFA_STATUS_DEVBUSY;
-       }
-       cee->get_attr_pending = BFA_TRUE;
-       cmd = (struct bfi_cee_get_req_s *)cee->get_cfg_mb.msg;
-       cee->attr = attr;
-       cee->cbfn.get_attr_cbfn = cbfn;
-       cee->cbfn.get_attr_cbarg = cbarg;
-       bfi_h2i_set(cmd->mh, BFI_MC_CEE, BFI_CEE_H2I_GET_CFG_REQ,
-                   bfa_ioc_portid(cee->ioc));
-       bfa_dma_be_addr_set(cmd->dma_addr, cee->attr_dma.pa);
-       bfa_ioc_mbox_queue(cee->ioc, &cee->get_cfg_mb);
-       bfa_trc(cee, 0);
-
-       return BFA_STATUS_OK;
-}
-
-/**
- * bfa_cee_get_stats()
- *
- *   Send the request to the f/w to fetch CEE statistics.
- *
- * @param[in] Pointer to the CEE module data structure.
- *
- * @return Status
- */
-
-bfa_status_t
-bfa_cee_get_stats(struct bfa_cee_s *cee, struct bfa_cee_stats_s *stats,
-                 bfa_cee_get_stats_cbfn_t cbfn, void *cbarg)
-{
-       struct bfi_cee_get_req_s *cmd;
-
-       bfa_assert((cee != NULL) && (cee->ioc != NULL));
-
-       if (!bfa_ioc_is_operational(cee->ioc)) {
-               bfa_trc(cee, 0);
-               return BFA_STATUS_IOC_FAILURE;
-       }
-       if (cee->get_stats_pending == BFA_TRUE) {
-               bfa_trc(cee, 0);
-               return BFA_STATUS_DEVBUSY;
-       }
-       cee->get_stats_pending = BFA_TRUE;
-       cmd = (struct bfi_cee_get_req_s *)cee->get_stats_mb.msg;
-       cee->stats = stats;
-       cee->cbfn.get_stats_cbfn = cbfn;
-       cee->cbfn.get_stats_cbarg = cbarg;
-       bfi_h2i_set(cmd->mh, BFI_MC_CEE, BFI_CEE_H2I_GET_STATS_REQ,
-                   bfa_ioc_portid(cee->ioc));
-       bfa_dma_be_addr_set(cmd->dma_addr, cee->stats_dma.pa);
-       bfa_ioc_mbox_queue(cee->ioc, &cee->get_stats_mb);
-       bfa_trc(cee, 0);
-
-       return BFA_STATUS_OK;
-}
-
-/**
- * bfa_cee_reset_stats()
- *
- *
- * @param[in] Pointer to the CEE module data structure.
- *
- * @return Status
- */
-
-bfa_status_t
-bfa_cee_reset_stats(struct bfa_cee_s *cee, bfa_cee_reset_stats_cbfn_t cbfn,
-                   void *cbarg)
-{
-       struct bfi_cee_reset_stats_s *cmd;
-
-       bfa_assert((cee != NULL) && (cee->ioc != NULL));
-       if (!bfa_ioc_is_operational(cee->ioc)) {
-               bfa_trc(cee, 0);
-               return BFA_STATUS_IOC_FAILURE;
-       }
-       if (cee->reset_stats_pending == BFA_TRUE) {
-               bfa_trc(cee, 0);
-               return BFA_STATUS_DEVBUSY;
-       }
-       cee->reset_stats_pending = BFA_TRUE;
-       cmd = (struct bfi_cee_reset_stats_s *)cee->reset_stats_mb.msg;
-       cee->cbfn.reset_stats_cbfn = cbfn;
-       cee->cbfn.reset_stats_cbarg = cbarg;
-       bfi_h2i_set(cmd->mh, BFI_MC_CEE, BFI_CEE_H2I_RESET_STATS,
-                   bfa_ioc_portid(cee->ioc));
-       bfa_ioc_mbox_queue(cee->ioc, &cee->reset_stats_mb);
-       bfa_trc(cee, 0);
-       return BFA_STATUS_OK;
-}
-
-/**
- * bfa_cee_isrs()
- *
- *
- * @param[in] Pointer to the CEE module data structure.
- *
- * @return void
- */
-
-void
-bfa_cee_isr(void *cbarg, struct bfi_mbmsg_s *m)
-{
-       union bfi_cee_i2h_msg_u *msg;
-       struct bfi_cee_get_rsp_s *get_rsp;
-       struct bfa_cee_s *cee = (struct bfa_cee_s *)cbarg;
-       msg = (union bfi_cee_i2h_msg_u *)m;
-       get_rsp = (struct bfi_cee_get_rsp_s *)m;
-       bfa_trc(cee, msg->mh.msg_id);
-       switch (msg->mh.msg_id) {
-       case BFI_CEE_I2H_GET_CFG_RSP:
-               bfa_trc(cee, get_rsp->cmd_status);
-               bfa_cee_get_attr_isr(cee, get_rsp->cmd_status);
-               break;
-       case BFI_CEE_I2H_GET_STATS_RSP:
-               bfa_cee_get_stats_isr(cee, get_rsp->cmd_status);
-               break;
-       case BFI_CEE_I2H_RESET_STATS_RSP:
-               bfa_cee_reset_stats_isr(cee, get_rsp->cmd_status);
-               break;
-       default:
-               bfa_assert(0);
-       }
-}
-
-/**
- * bfa_cee_hbfail()
- *
- *
- * @param[in] Pointer to the CEE module data structure.
- *
- * @return void
- */
-
-void
-bfa_cee_hbfail(void *arg)
-{
-       struct bfa_cee_s *cee;
-       cee = (struct bfa_cee_s *)arg;
-
-       if (cee->get_attr_pending == BFA_TRUE) {
-               cee->get_attr_status = BFA_STATUS_FAILED;
-               cee->get_attr_pending = BFA_FALSE;
-               if (cee->cbfn.get_attr_cbfn) {
-                       cee->cbfn.get_attr_cbfn(cee->cbfn.get_attr_cbarg,
-                                               BFA_STATUS_FAILED);
-               }
-       }
-       if (cee->get_stats_pending == BFA_TRUE) {
-               cee->get_stats_status = BFA_STATUS_FAILED;
-               cee->get_stats_pending = BFA_FALSE;
-               if (cee->cbfn.get_stats_cbfn) {
-                       cee->cbfn.get_stats_cbfn(cee->cbfn.get_stats_cbarg,
-                                                BFA_STATUS_FAILED);
-               }
-       }
-       if (cee->reset_stats_pending == BFA_TRUE) {
-               cee->reset_stats_status = BFA_STATUS_FAILED;
-               cee->reset_stats_pending = BFA_FALSE;
-               if (cee->cbfn.reset_stats_cbfn) {
-                       cee->cbfn.reset_stats_cbfn(cee->cbfn.reset_stats_cbarg,
-                                                  BFA_STATUS_FAILED);
-               }
-       }
-}
-
-/**
- * bfa_cee_attach()
- *
- *
- * @param[in] cee - Pointer to the CEE module data structure
- *            ioc - Pointer to the ioc module data structure
- *            dev - Pointer to the device driver module data structure
- *                  The device driver specific mbox ISR functions have
- *                  this pointer as one of the parameters.
- *            trcmod -
- *            logmod -
- *
- * @return void
- */
-void
-bfa_cee_attach(struct bfa_cee_s *cee, struct bfa_ioc_s *ioc, void *dev,
-              struct bfa_trc_mod_s *trcmod, struct bfa_log_mod_s *logmod)
-{
-       bfa_assert(cee != NULL);
-       cee->dev = dev;
-       cee->trcmod = trcmod;
-       cee->logmod = logmod;
-       cee->ioc = ioc;
-
-       bfa_ioc_mbox_regisr(cee->ioc, BFI_MC_CEE, bfa_cee_isr, cee);
-       bfa_ioc_hbfail_init(&cee->hbfail, bfa_cee_hbfail, cee);
-       bfa_ioc_hbfail_register(cee->ioc, &cee->hbfail);
-       bfa_trc(cee, 0);
-}
-
-/**
- * bfa_cee_detach()
- *
- *
- * @param[in] cee - Pointer to the CEE module data structure
- *
- * @return void
- */
-void
-bfa_cee_detach(struct bfa_cee_s *cee)
-{
-       /*
-        * For now, just check if there is some ioctl pending and mark that as
-        * failed?
-        */
-       /* bfa_cee_hbfail(cee); */
-}
index 76fa5c5b40dde33f6700e0a66b2d0cde846c8088..c2fa07f2485dc909bc7910efa925ee8c01bcb877 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
  * All rights reserved
  * www.brocade.com
  *
  * General Public License for more details.
  */
 
-#include <bfa.h>
-#include <defs/bfa_defs_pci.h>
-#include <cs/bfa_debug.h>
-#include <bfa_iocfc.h>
+#include "bfa_modules.h"
+#include "bfi_ctreg.h"
+#include "bfad_drv.h"
 
-#define DEF_CFG_NUM_FABRICS         1
-#define DEF_CFG_NUM_LPORTS          256
-#define DEF_CFG_NUM_CQS             4
-#define DEF_CFG_NUM_IOIM_REQS       (BFA_IOIM_MAX)
-#define DEF_CFG_NUM_TSKIM_REQS      128
-#define DEF_CFG_NUM_FCXP_REQS       64
-#define DEF_CFG_NUM_UF_BUFS         64
-#define DEF_CFG_NUM_RPORTS          1024
-#define DEF_CFG_NUM_ITNIMS          (DEF_CFG_NUM_RPORTS)
-#define DEF_CFG_NUM_TINS            256
+BFA_TRC_FILE(HAL, CORE);
 
-#define DEF_CFG_NUM_SGPGS           2048
-#define DEF_CFG_NUM_REQQ_ELEMS      256
-#define DEF_CFG_NUM_RSPQ_ELEMS      64
-#define DEF_CFG_NUM_SBOOT_TGTS      16
-#define DEF_CFG_NUM_SBOOT_LUNS      16
+/**
+ * BFA IOC FC related definitions
+ */
+
+/**
+ * IOC local definitions
+ */
+#define BFA_IOCFC_TOV          5000    /* msecs */
+
+enum {
+       BFA_IOCFC_ACT_NONE      = 0,
+       BFA_IOCFC_ACT_INIT      = 1,
+       BFA_IOCFC_ACT_STOP      = 2,
+       BFA_IOCFC_ACT_DISABLE   = 3,
+};
+
+#define DEF_CFG_NUM_FABRICS            1
+#define DEF_CFG_NUM_LPORTS             256
+#define DEF_CFG_NUM_CQS                        4
+#define DEF_CFG_NUM_IOIM_REQS          (BFA_IOIM_MAX)
+#define DEF_CFG_NUM_TSKIM_REQS         128
+#define DEF_CFG_NUM_FCXP_REQS          64
+#define DEF_CFG_NUM_UF_BUFS            64
+#define DEF_CFG_NUM_RPORTS             1024
+#define DEF_CFG_NUM_ITNIMS             (DEF_CFG_NUM_RPORTS)
+#define DEF_CFG_NUM_TINS               256
+
+#define DEF_CFG_NUM_SGPGS              2048
+#define DEF_CFG_NUM_REQQ_ELEMS         256
+#define DEF_CFG_NUM_RSPQ_ELEMS         64
+#define DEF_CFG_NUM_SBOOT_TGTS         16
+#define DEF_CFG_NUM_SBOOT_LUNS         16
+
+/**
+ * forward declaration for IOC FC functions
+ */
+static void bfa_iocfc_enable_cbfn(void *bfa_arg, enum bfa_status status);
+static void bfa_iocfc_disable_cbfn(void *bfa_arg);
+static void bfa_iocfc_hbfail_cbfn(void *bfa_arg);
+static void bfa_iocfc_reset_cbfn(void *bfa_arg);
+static struct bfa_ioc_cbfn_s bfa_iocfc_cbfn;
+
+/**
+ * BFA Interrupt handling functions
+ */
+static void
+bfa_msix_errint(struct bfa_s *bfa, u32 intr)
+{
+       bfa_ioc_error_isr(&bfa->ioc);
+}
+
+static void
+bfa_msix_lpu(struct bfa_s *bfa)
+{
+       bfa_ioc_mbox_isr(&bfa->ioc);
+}
+
+static void
+bfa_reqq_resume(struct bfa_s *bfa, int qid)
+{
+       struct list_head *waitq, *qe, *qen;
+       struct bfa_reqq_wait_s *wqe;
+
+       waitq = bfa_reqq(bfa, qid);
+       list_for_each_safe(qe, qen, waitq) {
+               /**
+                * Callback only as long as there is room in request queue
+                */
+               if (bfa_reqq_full(bfa, qid))
+                       break;
+
+               list_del(qe);
+               wqe = (struct bfa_reqq_wait_s *) qe;
+               wqe->qresume(wqe->cbarg);
+       }
+}
+
+void
+bfa_msix_all(struct bfa_s *bfa, int vec)
+{
+       bfa_intx(bfa);
+}
+
+/**
+ *  hal_intr_api
+ */
+bfa_boolean_t
+bfa_intx(struct bfa_s *bfa)
+{
+       u32 intr, qintr;
+       int queue;
+
+       intr = bfa_reg_read(bfa->iocfc.bfa_regs.intr_status);
+       if (!intr)
+               return BFA_FALSE;
+
+       /**
+        * RME completion queue interrupt
+        */
+       qintr = intr & __HFN_INT_RME_MASK;
+       bfa_reg_write(bfa->iocfc.bfa_regs.intr_status, qintr);
+
+       for (queue = 0; queue < BFI_IOC_MAX_CQS_ASIC; queue++) {
+               if (intr & (__HFN_INT_RME_Q0 << queue))
+                       bfa_msix_rspq(bfa, queue & (BFI_IOC_MAX_CQS - 1));
+       }
+       intr &= ~qintr;
+       if (!intr)
+               return BFA_TRUE;
+
+       /**
+        * CPE completion queue interrupt
+        */
+       qintr = intr & __HFN_INT_CPE_MASK;
+       bfa_reg_write(bfa->iocfc.bfa_regs.intr_status, qintr);
+
+       for (queue = 0; queue < BFI_IOC_MAX_CQS_ASIC; queue++) {
+               if (intr & (__HFN_INT_CPE_Q0 << queue))
+                       bfa_msix_reqq(bfa, queue & (BFI_IOC_MAX_CQS - 1));
+       }
+       intr &= ~qintr;
+       if (!intr)
+               return BFA_TRUE;
+
+       bfa_msix_lpu_err(bfa, intr);
+
+       return BFA_TRUE;
+}
+
+void
+bfa_intx_enable(struct bfa_s *bfa)
+{
+       bfa_reg_write(bfa->iocfc.bfa_regs.intr_mask, bfa->iocfc.intr_mask);
+}
+
+void
+bfa_intx_disable(struct bfa_s *bfa)
+{
+       bfa_reg_write(bfa->iocfc.bfa_regs.intr_mask, -1L);
+}
+
+void
+bfa_isr_enable(struct bfa_s *bfa)
+{
+       u32 intr_unmask;
+       int pci_func = bfa_ioc_pcifn(&bfa->ioc);
+
+       bfa_trc(bfa, pci_func);
+
+       bfa_msix_install(bfa);
+       intr_unmask = (__HFN_INT_ERR_EMC | __HFN_INT_ERR_LPU0 |
+                      __HFN_INT_ERR_LPU1 | __HFN_INT_ERR_PSS |
+                      __HFN_INT_LL_HALT);
+
+       if (pci_func == 0)
+               intr_unmask |= (__HFN_INT_CPE_Q0 | __HFN_INT_CPE_Q1 |
+                               __HFN_INT_CPE_Q2 | __HFN_INT_CPE_Q3 |
+                               __HFN_INT_RME_Q0 | __HFN_INT_RME_Q1 |
+                               __HFN_INT_RME_Q2 | __HFN_INT_RME_Q3 |
+                               __HFN_INT_MBOX_LPU0);
+       else
+               intr_unmask |= (__HFN_INT_CPE_Q4 | __HFN_INT_CPE_Q5 |
+                               __HFN_INT_CPE_Q6 | __HFN_INT_CPE_Q7 |
+                               __HFN_INT_RME_Q4 | __HFN_INT_RME_Q5 |
+                               __HFN_INT_RME_Q6 | __HFN_INT_RME_Q7 |
+                               __HFN_INT_MBOX_LPU1);
+
+       bfa_reg_write(bfa->iocfc.bfa_regs.intr_status, intr_unmask);
+       bfa_reg_write(bfa->iocfc.bfa_regs.intr_mask, ~intr_unmask);
+       bfa->iocfc.intr_mask = ~intr_unmask;
+       bfa_isr_mode_set(bfa, bfa->msix.nvecs != 0);
+}
+
+void
+bfa_isr_disable(struct bfa_s *bfa)
+{
+       bfa_isr_mode_set(bfa, BFA_FALSE);
+       bfa_reg_write(bfa->iocfc.bfa_regs.intr_mask, -1L);
+       bfa_msix_uninstall(bfa);
+}
+
+void
+bfa_msix_reqq(struct bfa_s *bfa, int qid)
+{
+       struct list_head *waitq;
+
+       qid &= (BFI_IOC_MAX_CQS - 1);
+
+       bfa->iocfc.hwif.hw_reqq_ack(bfa, qid);
+
+       /**
+        * Resume any pending requests in the corresponding reqq.
+        */
+       waitq = bfa_reqq(bfa, qid);
+       if (!list_empty(waitq))
+               bfa_reqq_resume(bfa, qid);
+}
+
+void
+bfa_isr_unhandled(struct bfa_s *bfa, struct bfi_msg_s *m)
+{
+       bfa_trc(bfa, m->mhdr.msg_class);
+       bfa_trc(bfa, m->mhdr.msg_id);
+       bfa_trc(bfa, m->mhdr.mtag.i2htok);
+       bfa_assert(0);
+       bfa_trc_stop(bfa->trcmod);
+}
+
+void
+bfa_msix_rspq(struct bfa_s *bfa, int qid)
+{
+       struct bfi_msg_s *m;
+       u32 pi, ci;
+       struct list_head *waitq;
+
+       bfa_trc_fp(bfa, qid);
+
+       qid &= (BFI_IOC_MAX_CQS - 1);
+
+       bfa->iocfc.hwif.hw_rspq_ack(bfa, qid);
+
+       ci = bfa_rspq_ci(bfa, qid);
+       pi = bfa_rspq_pi(bfa, qid);
+
+       bfa_trc_fp(bfa, ci);
+       bfa_trc_fp(bfa, pi);
+
+       if (bfa->rme_process) {
+               while (ci != pi) {
+                       m = bfa_rspq_elem(bfa, qid, ci);
+                       bfa_assert_fp(m->mhdr.msg_class < BFI_MC_MAX);
+
+                       bfa_isrs[m->mhdr.msg_class] (bfa, m);
+
+                       CQ_INCR(ci, bfa->iocfc.cfg.drvcfg.num_rspq_elems);
+               }
+       }
+
+       /**
+        * update CI
+        */
+       bfa_rspq_ci(bfa, qid) = pi;
+       bfa_reg_write(bfa->iocfc.bfa_regs.rme_q_ci[qid], pi);
+       mmiowb();
+
+       /**
+        * Resume any pending requests in the corresponding reqq.
+        */
+       waitq = bfa_reqq(bfa, qid);
+       if (!list_empty(waitq))
+               bfa_reqq_resume(bfa, qid);
+}
+
+void
+bfa_msix_lpu_err(struct bfa_s *bfa, int vec)
+{
+       u32 intr, curr_value;
+
+       intr = bfa_reg_read(bfa->iocfc.bfa_regs.intr_status);
+
+       if (intr & (__HFN_INT_MBOX_LPU0 | __HFN_INT_MBOX_LPU1))
+               bfa_msix_lpu(bfa);
+
+       intr &= (__HFN_INT_ERR_EMC | __HFN_INT_ERR_LPU0 |
+               __HFN_INT_ERR_LPU1 | __HFN_INT_ERR_PSS | __HFN_INT_LL_HALT);
+
+       if (intr) {
+               if (intr & __HFN_INT_LL_HALT) {
+                       /**
+                        * If LL_HALT bit is set then FW Init Halt LL Port
+                        * Register needs to be cleared as well so Interrupt
+                        * Status Register will be cleared.
+                        */
+                       curr_value = bfa_reg_read(bfa->ioc.ioc_regs.ll_halt);
+                       curr_value &= ~__FW_INIT_HALT_P;
+                       bfa_reg_write(bfa->ioc.ioc_regs.ll_halt, curr_value);
+               }
+
+               if (intr & __HFN_INT_ERR_PSS) {
+                       /**
+                        * ERR_PSS bit needs to be cleared as well in case
+                        * interrups are shared so driver's interrupt handler is
+                        * still called eventhough it is already masked out.
+                        */
+                       curr_value = bfa_reg_read(
+                                       bfa->ioc.ioc_regs.pss_err_status_reg);
+                       curr_value &= __PSS_ERR_STATUS_SET;
+                       bfa_reg_write(bfa->ioc.ioc_regs.pss_err_status_reg,
+                                       curr_value);
+               }
+
+               bfa_reg_write(bfa->iocfc.bfa_regs.intr_status, intr);
+               bfa_msix_errint(bfa, intr);
+       }
+}
+
+void
+bfa_isr_bind(enum bfi_mclass mc, bfa_isr_func_t isr_func)
+{
+       bfa_isrs[mc] = isr_func;
+}
+
+/**
+ * BFA IOC FC related functions
+ */
+
+/**
+ *  hal_ioc_pvt BFA IOC private functions
+ */
+
+static void
+bfa_iocfc_cqs_sz(struct bfa_iocfc_cfg_s *cfg, u32 *dm_len)
+{
+       int             i, per_reqq_sz, per_rspq_sz;
+
+       per_reqq_sz = BFA_ROUNDUP((cfg->drvcfg.num_reqq_elems * BFI_LMSG_SZ),
+                                 BFA_DMA_ALIGN_SZ);
+       per_rspq_sz = BFA_ROUNDUP((cfg->drvcfg.num_rspq_elems * BFI_LMSG_SZ),
+                                 BFA_DMA_ALIGN_SZ);
+
+       /*
+        * Calculate CQ size
+        */
+       for (i = 0; i < cfg->fwcfg.num_cqs; i++) {
+               *dm_len = *dm_len + per_reqq_sz;
+               *dm_len = *dm_len + per_rspq_sz;
+       }
+
+       /*
+        * Calculate Shadow CI/PI size
+        */
+       for (i = 0; i < cfg->fwcfg.num_cqs; i++)
+               *dm_len += (2 * BFA_CACHELINE_SZ);
+}
+
+static void
+bfa_iocfc_fw_cfg_sz(struct bfa_iocfc_cfg_s *cfg, u32 *dm_len)
+{
+       *dm_len +=
+               BFA_ROUNDUP(sizeof(struct bfi_iocfc_cfg_s), BFA_CACHELINE_SZ);
+       *dm_len +=
+               BFA_ROUNDUP(sizeof(struct bfi_iocfc_cfgrsp_s),
+                           BFA_CACHELINE_SZ);
+}
+
+/**
+ * Use the Mailbox interface to send BFI_IOCFC_H2I_CFG_REQ
+ */
+static void
+bfa_iocfc_send_cfg(void *bfa_arg)
+{
+       struct bfa_s *bfa = bfa_arg;
+       struct bfa_iocfc_s *iocfc = &bfa->iocfc;
+       struct bfi_iocfc_cfg_req_s cfg_req;
+       struct bfi_iocfc_cfg_s *cfg_info = iocfc->cfginfo;
+       struct bfa_iocfc_cfg_s  *cfg = &iocfc->cfg;
+       int             i;
+
+       bfa_assert(cfg->fwcfg.num_cqs <= BFI_IOC_MAX_CQS);
+       bfa_trc(bfa, cfg->fwcfg.num_cqs);
+
+       bfa_iocfc_reset_queues(bfa);
+
+       /**
+        * initialize IOC configuration info
+        */
+       cfg_info->endian_sig = BFI_IOC_ENDIAN_SIG;
+       cfg_info->num_cqs = cfg->fwcfg.num_cqs;
+
+       bfa_dma_be_addr_set(cfg_info->cfgrsp_addr, iocfc->cfgrsp_dma.pa);
+       /**
+        * dma map REQ and RSP circular queues and shadow pointers
+        */
+       for (i = 0; i < cfg->fwcfg.num_cqs; i++) {
+               bfa_dma_be_addr_set(cfg_info->req_cq_ba[i],
+                                   iocfc->req_cq_ba[i].pa);
+               bfa_dma_be_addr_set(cfg_info->req_shadow_ci[i],
+                                   iocfc->req_cq_shadow_ci[i].pa);
+               cfg_info->req_cq_elems[i] =
+                       bfa_os_htons(cfg->drvcfg.num_reqq_elems);
+
+               bfa_dma_be_addr_set(cfg_info->rsp_cq_ba[i],
+                                   iocfc->rsp_cq_ba[i].pa);
+               bfa_dma_be_addr_set(cfg_info->rsp_shadow_pi[i],
+                                   iocfc->rsp_cq_shadow_pi[i].pa);
+               cfg_info->rsp_cq_elems[i] =
+                       bfa_os_htons(cfg->drvcfg.num_rspq_elems);
+       }
+
+       /**
+        * Enable interrupt coalescing if it is driver init path
+        * and not ioc disable/enable path.
+        */
+       if (!iocfc->cfgdone)
+               cfg_info->intr_attr.coalesce = BFA_TRUE;
+
+       iocfc->cfgdone = BFA_FALSE;
+
+       /**
+        * dma map IOC configuration itself
+        */
+       bfi_h2i_set(cfg_req.mh, BFI_MC_IOCFC, BFI_IOCFC_H2I_CFG_REQ,
+                   bfa_lpuid(bfa));
+       bfa_dma_be_addr_set(cfg_req.ioc_cfg_dma_addr, iocfc->cfg_info.pa);
+
+       bfa_ioc_mbox_send(&bfa->ioc, &cfg_req,
+                         sizeof(struct bfi_iocfc_cfg_req_s));
+}
+
+static void
+bfa_iocfc_init_mem(struct bfa_s *bfa, void *bfad, struct bfa_iocfc_cfg_s *cfg,
+                  struct bfa_pcidev_s *pcidev)
+{
+       struct bfa_iocfc_s      *iocfc = &bfa->iocfc;
+
+       bfa->bfad = bfad;
+       iocfc->bfa = bfa;
+       iocfc->action = BFA_IOCFC_ACT_NONE;
+
+       bfa_os_assign(iocfc->cfg, *cfg);
+
+       /**
+        * Initialize chip specific handlers.
+        */
+       if (bfa_asic_id_ct(bfa_ioc_devid(&bfa->ioc))) {
+               iocfc->hwif.hw_reginit = bfa_hwct_reginit;
+               iocfc->hwif.hw_reqq_ack = bfa_hwct_reqq_ack;
+               iocfc->hwif.hw_rspq_ack = bfa_hwct_rspq_ack;
+               iocfc->hwif.hw_msix_init = bfa_hwct_msix_init;
+               iocfc->hwif.hw_msix_install = bfa_hwct_msix_install;
+               iocfc->hwif.hw_msix_uninstall = bfa_hwct_msix_uninstall;
+               iocfc->hwif.hw_isr_mode_set = bfa_hwct_isr_mode_set;
+               iocfc->hwif.hw_msix_getvecs = bfa_hwct_msix_getvecs;
+               iocfc->hwif.hw_msix_get_rme_range = bfa_hwct_msix_get_rme_range;
+       } else {
+               iocfc->hwif.hw_reginit = bfa_hwcb_reginit;
+               iocfc->hwif.hw_reqq_ack = bfa_hwcb_reqq_ack;
+               iocfc->hwif.hw_rspq_ack = bfa_hwcb_rspq_ack;
+               iocfc->hwif.hw_msix_init = bfa_hwcb_msix_init;
+               iocfc->hwif.hw_msix_install = bfa_hwcb_msix_install;
+               iocfc->hwif.hw_msix_uninstall = bfa_hwcb_msix_uninstall;
+               iocfc->hwif.hw_isr_mode_set = bfa_hwcb_isr_mode_set;
+               iocfc->hwif.hw_msix_getvecs = bfa_hwcb_msix_getvecs;
+               iocfc->hwif.hw_msix_get_rme_range = bfa_hwcb_msix_get_rme_range;
+       }
+
+       iocfc->hwif.hw_reginit(bfa);
+       bfa->msix.nvecs = 0;
+}
+
+static void
+bfa_iocfc_mem_claim(struct bfa_s *bfa, struct bfa_iocfc_cfg_s *cfg,
+                   struct bfa_meminfo_s *meminfo)
+{
+       u8             *dm_kva;
+       u64     dm_pa;
+       int             i, per_reqq_sz, per_rspq_sz;
+       struct bfa_iocfc_s  *iocfc = &bfa->iocfc;
+       int             dbgsz;
+
+       dm_kva = bfa_meminfo_dma_virt(meminfo);
+       dm_pa = bfa_meminfo_dma_phys(meminfo);
+
+       /*
+        * First allocate dma memory for IOC.
+        */
+       bfa_ioc_mem_claim(&bfa->ioc, dm_kva, dm_pa);
+       dm_kva += bfa_ioc_meminfo();
+       dm_pa  += bfa_ioc_meminfo();
+
+       /*
+        * Claim DMA-able memory for the request/response queues and for shadow
+        * ci/pi registers
+        */
+       per_reqq_sz = BFA_ROUNDUP((cfg->drvcfg.num_reqq_elems * BFI_LMSG_SZ),
+                                 BFA_DMA_ALIGN_SZ);
+       per_rspq_sz = BFA_ROUNDUP((cfg->drvcfg.num_rspq_elems * BFI_LMSG_SZ),
+                                 BFA_DMA_ALIGN_SZ);
+
+       for (i = 0; i < cfg->fwcfg.num_cqs; i++) {
+               iocfc->req_cq_ba[i].kva = dm_kva;
+               iocfc->req_cq_ba[i].pa = dm_pa;
+               bfa_os_memset(dm_kva, 0, per_reqq_sz);
+               dm_kva += per_reqq_sz;
+               dm_pa += per_reqq_sz;
+
+               iocfc->rsp_cq_ba[i].kva = dm_kva;
+               iocfc->rsp_cq_ba[i].pa = dm_pa;
+               bfa_os_memset(dm_kva, 0, per_rspq_sz);
+               dm_kva += per_rspq_sz;
+               dm_pa += per_rspq_sz;
+       }
+
+       for (i = 0; i < cfg->fwcfg.num_cqs; i++) {
+               iocfc->req_cq_shadow_ci[i].kva = dm_kva;
+               iocfc->req_cq_shadow_ci[i].pa = dm_pa;
+               dm_kva += BFA_CACHELINE_SZ;
+               dm_pa += BFA_CACHELINE_SZ;
+
+               iocfc->rsp_cq_shadow_pi[i].kva = dm_kva;
+               iocfc->rsp_cq_shadow_pi[i].pa = dm_pa;
+               dm_kva += BFA_CACHELINE_SZ;
+               dm_pa += BFA_CACHELINE_SZ;
+       }
+
+       /*
+        * Claim DMA-able memory for the config info page
+        */
+       bfa->iocfc.cfg_info.kva = dm_kva;
+       bfa->iocfc.cfg_info.pa = dm_pa;
+       bfa->iocfc.cfginfo = (struct bfi_iocfc_cfg_s *) dm_kva;
+       dm_kva += BFA_ROUNDUP(sizeof(struct bfi_iocfc_cfg_s), BFA_CACHELINE_SZ);
+       dm_pa += BFA_ROUNDUP(sizeof(struct bfi_iocfc_cfg_s), BFA_CACHELINE_SZ);
+
+       /*
+        * Claim DMA-able memory for the config response
+        */
+       bfa->iocfc.cfgrsp_dma.kva = dm_kva;
+       bfa->iocfc.cfgrsp_dma.pa = dm_pa;
+       bfa->iocfc.cfgrsp = (struct bfi_iocfc_cfgrsp_s *) dm_kva;
+
+       dm_kva +=
+               BFA_ROUNDUP(sizeof(struct bfi_iocfc_cfgrsp_s),
+                           BFA_CACHELINE_SZ);
+       dm_pa += BFA_ROUNDUP(sizeof(struct bfi_iocfc_cfgrsp_s),
+                            BFA_CACHELINE_SZ);
+
+
+       bfa_meminfo_dma_virt(meminfo) = dm_kva;
+       bfa_meminfo_dma_phys(meminfo) = dm_pa;
+
+       dbgsz = bfa_ioc_debug_trcsz(bfa_auto_recover);
+       if (dbgsz > 0) {
+               bfa_ioc_debug_memclaim(&bfa->ioc, bfa_meminfo_kva(meminfo));
+               bfa_meminfo_kva(meminfo) += dbgsz;
+       }
+}
+
+/**
+ * Start BFA submodules.
+ */
+static void
+bfa_iocfc_start_submod(struct bfa_s *bfa)
+{
+       int             i;
+
+       bfa->rme_process = BFA_TRUE;
+
+       for (i = 0; hal_mods[i]; i++)
+               hal_mods[i]->start(bfa);
+}
+
+/**
+ * Disable BFA submodules.
+ */
+static void
+bfa_iocfc_disable_submod(struct bfa_s *bfa)
+{
+       int             i;
+
+       for (i = 0; hal_mods[i]; i++)
+               hal_mods[i]->iocdisable(bfa);
+}
+
+static void
+bfa_iocfc_init_cb(void *bfa_arg, bfa_boolean_t complete)
+{
+       struct bfa_s    *bfa = bfa_arg;
+
+       if (complete) {
+               if (bfa->iocfc.cfgdone)
+                       bfa_cb_init(bfa->bfad, BFA_STATUS_OK);
+               else
+                       bfa_cb_init(bfa->bfad, BFA_STATUS_FAILED);
+       } else {
+               if (bfa->iocfc.cfgdone)
+                       bfa->iocfc.action = BFA_IOCFC_ACT_NONE;
+       }
+}
+
+static void
+bfa_iocfc_stop_cb(void *bfa_arg, bfa_boolean_t compl)
+{
+       struct bfa_s  *bfa = bfa_arg;
+       struct bfad_s *bfad = bfa->bfad;
+
+       if (compl)
+               complete(&bfad->comp);
+       else
+               bfa->iocfc.action = BFA_IOCFC_ACT_NONE;
+}
+
+static void
+bfa_iocfc_disable_cb(void *bfa_arg, bfa_boolean_t compl)
+{
+       struct bfa_s  *bfa = bfa_arg;
+       struct bfad_s *bfad = bfa->bfad;
+
+       if (compl)
+               complete(&bfad->disable_comp);
+}
+
+/**
+ * Update BFA configuration from firmware configuration.
+ */
+static void
+bfa_iocfc_cfgrsp(struct bfa_s *bfa)
+{
+       struct bfa_iocfc_s              *iocfc   = &bfa->iocfc;
+       struct bfi_iocfc_cfgrsp_s       *cfgrsp  = iocfc->cfgrsp;
+       struct bfa_iocfc_fwcfg_s        *fwcfg   = &cfgrsp->fwcfg;
+
+       fwcfg->num_cqs        = fwcfg->num_cqs;
+       fwcfg->num_ioim_reqs  = bfa_os_ntohs(fwcfg->num_ioim_reqs);
+       fwcfg->num_tskim_reqs = bfa_os_ntohs(fwcfg->num_tskim_reqs);
+       fwcfg->num_fcxp_reqs  = bfa_os_ntohs(fwcfg->num_fcxp_reqs);
+       fwcfg->num_uf_bufs    = bfa_os_ntohs(fwcfg->num_uf_bufs);
+       fwcfg->num_rports     = bfa_os_ntohs(fwcfg->num_rports);
+
+       iocfc->cfgdone = BFA_TRUE;
+
+       /**
+        * Configuration is complete - initialize/start submodules
+        */
+       bfa_fcport_init(bfa);
+
+       if (iocfc->action == BFA_IOCFC_ACT_INIT)
+               bfa_cb_queue(bfa, &iocfc->init_hcb_qe, bfa_iocfc_init_cb, bfa);
+       else
+               bfa_iocfc_start_submod(bfa);
+}
+void
+bfa_iocfc_reset_queues(struct bfa_s *bfa)
+{
+       int             q;
+
+       for (q = 0; q < BFI_IOC_MAX_CQS; q++) {
+               bfa_reqq_ci(bfa, q) = 0;
+               bfa_reqq_pi(bfa, q) = 0;
+               bfa_rspq_ci(bfa, q) = 0;
+               bfa_rspq_pi(bfa, q) = 0;
+       }
+}
+
+/**
+ * IOC enable request is complete
+ */
+static void
+bfa_iocfc_enable_cbfn(void *bfa_arg, enum bfa_status status)
+{
+       struct bfa_s    *bfa = bfa_arg;
+
+       if (status != BFA_STATUS_OK) {
+               bfa_isr_disable(bfa);
+               if (bfa->iocfc.action == BFA_IOCFC_ACT_INIT)
+                       bfa_cb_queue(bfa, &bfa->iocfc.init_hcb_qe,
+                                    bfa_iocfc_init_cb, bfa);
+               return;
+       }
+
+       bfa_iocfc_send_cfg(bfa);
+}
+
+/**
+ * IOC disable request is complete
+ */
+static void
+bfa_iocfc_disable_cbfn(void *bfa_arg)
+{
+       struct bfa_s    *bfa = bfa_arg;
+
+       bfa_isr_disable(bfa);
+       bfa_iocfc_disable_submod(bfa);
+
+       if (bfa->iocfc.action == BFA_IOCFC_ACT_STOP)
+               bfa_cb_queue(bfa, &bfa->iocfc.stop_hcb_qe, bfa_iocfc_stop_cb,
+                            bfa);
+       else {
+               bfa_assert(bfa->iocfc.action == BFA_IOCFC_ACT_DISABLE);
+               bfa_cb_queue(bfa, &bfa->iocfc.dis_hcb_qe, bfa_iocfc_disable_cb,
+                            bfa);
+       }
+}
+
+/**
+ * Notify sub-modules of hardware failure.
+ */
+static void
+bfa_iocfc_hbfail_cbfn(void *bfa_arg)
+{
+       struct bfa_s    *bfa = bfa_arg;
+
+       bfa->rme_process = BFA_FALSE;
+
+       bfa_isr_disable(bfa);
+       bfa_iocfc_disable_submod(bfa);
+
+       if (bfa->iocfc.action == BFA_IOCFC_ACT_INIT)
+               bfa_cb_queue(bfa, &bfa->iocfc.init_hcb_qe, bfa_iocfc_init_cb,
+                            bfa);
+}
+
+/**
+ * Actions on chip-reset completion.
+ */
+static void
+bfa_iocfc_reset_cbfn(void *bfa_arg)
+{
+       struct bfa_s    *bfa = bfa_arg;
+
+       bfa_iocfc_reset_queues(bfa);
+       bfa_isr_enable(bfa);
+}
+
+/**
+ *  hal_ioc_public
+ */
+
+/**
+ * Query IOC memory requirement information.
+ */
+void
+bfa_iocfc_meminfo(struct bfa_iocfc_cfg_s *cfg, u32 *km_len,
+                 u32 *dm_len)
+{
+       /* dma memory for IOC */
+       *dm_len += bfa_ioc_meminfo();
+
+       bfa_iocfc_fw_cfg_sz(cfg, dm_len);
+       bfa_iocfc_cqs_sz(cfg, dm_len);
+       *km_len += bfa_ioc_debug_trcsz(bfa_auto_recover);
+}
+
+/**
+ * Query IOC memory requirement information.
+ */
+void
+bfa_iocfc_attach(struct bfa_s *bfa, void *bfad, struct bfa_iocfc_cfg_s *cfg,
+                struct bfa_meminfo_s *meminfo, struct bfa_pcidev_s *pcidev)
+{
+       int             i;
+       struct bfa_ioc_s *ioc = &bfa->ioc;
+
+       bfa_iocfc_cbfn.enable_cbfn = bfa_iocfc_enable_cbfn;
+       bfa_iocfc_cbfn.disable_cbfn = bfa_iocfc_disable_cbfn;
+       bfa_iocfc_cbfn.hbfail_cbfn = bfa_iocfc_hbfail_cbfn;
+       bfa_iocfc_cbfn.reset_cbfn = bfa_iocfc_reset_cbfn;
+
+       ioc->trcmod = bfa->trcmod;
+       bfa_ioc_attach(&bfa->ioc, bfa, &bfa_iocfc_cbfn, &bfa->timer_mod);
+
+       /**
+        * Set FC mode for BFA_PCI_DEVICE_ID_CT_FC.
+        */
+       if (pcidev->device_id == BFA_PCI_DEVICE_ID_CT_FC)
+               bfa_ioc_set_fcmode(&bfa->ioc);
+
+       bfa_ioc_pci_init(&bfa->ioc, pcidev, BFI_MC_IOCFC);
+       bfa_ioc_mbox_register(&bfa->ioc, bfa_mbox_isrs);
+
+       bfa_iocfc_init_mem(bfa, bfad, cfg, pcidev);
+       bfa_iocfc_mem_claim(bfa, cfg, meminfo);
+       bfa_timer_init(&bfa->timer_mod);
+
+       INIT_LIST_HEAD(&bfa->comp_q);
+       for (i = 0; i < BFI_IOC_MAX_CQS; i++)
+               INIT_LIST_HEAD(&bfa->reqq_waitq[i]);
+}
+
+/**
+ * Query IOC memory requirement information.
+ */
+void
+bfa_iocfc_detach(struct bfa_s *bfa)
+{
+       bfa_ioc_detach(&bfa->ioc);
+}
+
+/**
+ * Query IOC memory requirement information.
+ */
+void
+bfa_iocfc_init(struct bfa_s *bfa)
+{
+       bfa->iocfc.action = BFA_IOCFC_ACT_INIT;
+       bfa_ioc_enable(&bfa->ioc);
+}
+
+/**
+ * IOC start called from bfa_start(). Called to start IOC operations
+ * at driver instantiation for this instance.
+ */
+void
+bfa_iocfc_start(struct bfa_s *bfa)
+{
+       if (bfa->iocfc.cfgdone)
+               bfa_iocfc_start_submod(bfa);
+}
+
+/**
+ * IOC stop called from bfa_stop(). Called only when driver is unloaded
+ * for this instance.
+ */
+void
+bfa_iocfc_stop(struct bfa_s *bfa)
+{
+       bfa->iocfc.action = BFA_IOCFC_ACT_STOP;
+
+       bfa->rme_process = BFA_FALSE;
+       bfa_ioc_disable(&bfa->ioc);
+}
+
+void
+bfa_iocfc_isr(void *bfaarg, struct bfi_mbmsg_s *m)
+{
+       struct bfa_s            *bfa = bfaarg;
+       struct bfa_iocfc_s      *iocfc = &bfa->iocfc;
+       union bfi_iocfc_i2h_msg_u       *msg;
+
+       msg = (union bfi_iocfc_i2h_msg_u *) m;
+       bfa_trc(bfa, msg->mh.msg_id);
+
+       switch (msg->mh.msg_id) {
+       case BFI_IOCFC_I2H_CFG_REPLY:
+               iocfc->cfg_reply = &msg->cfg_reply;
+               bfa_iocfc_cfgrsp(bfa);
+               break;
+       case BFI_IOCFC_I2H_UPDATEQ_RSP:
+               iocfc->updateq_cbfn(iocfc->updateq_cbarg, BFA_STATUS_OK);
+               break;
+       default:
+               bfa_assert(0);
+       }
+}
+
+void
+bfa_adapter_get_attr(struct bfa_s *bfa, struct bfa_adapter_attr_s *ad_attr)
+{
+       bfa_ioc_get_adapter_attr(&bfa->ioc, ad_attr);
+}
+
+u64
+bfa_adapter_get_id(struct bfa_s *bfa)
+{
+       return bfa_ioc_get_adid(&bfa->ioc);
+}
+
+void
+bfa_iocfc_get_attr(struct bfa_s *bfa, struct bfa_iocfc_attr_s *attr)
+{
+       struct bfa_iocfc_s      *iocfc = &bfa->iocfc;
+
+       attr->intr_attr.coalesce = iocfc->cfginfo->intr_attr.coalesce;
+
+       attr->intr_attr.delay = iocfc->cfginfo->intr_attr.delay ?
+                               bfa_os_ntohs(iocfc->cfginfo->intr_attr.delay) :
+                               bfa_os_ntohs(iocfc->cfgrsp->intr_attr.delay);
+
+       attr->intr_attr.latency = iocfc->cfginfo->intr_attr.latency ?
+                       bfa_os_ntohs(iocfc->cfginfo->intr_attr.latency) :
+                       bfa_os_ntohs(iocfc->cfgrsp->intr_attr.latency);
+
+       attr->config    = iocfc->cfg;
+}
+
+bfa_status_t
+bfa_iocfc_israttr_set(struct bfa_s *bfa, struct bfa_iocfc_intr_attr_s *attr)
+{
+       struct bfa_iocfc_s              *iocfc = &bfa->iocfc;
+       struct bfi_iocfc_set_intr_req_s *m;
+
+       iocfc->cfginfo->intr_attr.coalesce = attr->coalesce;
+       iocfc->cfginfo->intr_attr.delay = bfa_os_htons(attr->delay);
+       iocfc->cfginfo->intr_attr.latency = bfa_os_htons(attr->latency);
+
+       if (!bfa_iocfc_is_operational(bfa))
+               return BFA_STATUS_OK;
+
+       m = bfa_reqq_next(bfa, BFA_REQQ_IOC);
+       if (!m)
+               return BFA_STATUS_DEVBUSY;
+
+       bfi_h2i_set(m->mh, BFI_MC_IOCFC, BFI_IOCFC_H2I_SET_INTR_REQ,
+                   bfa_lpuid(bfa));
+       m->coalesce = iocfc->cfginfo->intr_attr.coalesce;
+       m->delay    = iocfc->cfginfo->intr_attr.delay;
+       m->latency  = iocfc->cfginfo->intr_attr.latency;
+
+       bfa_trc(bfa, attr->delay);
+       bfa_trc(bfa, attr->latency);
+
+       bfa_reqq_produce(bfa, BFA_REQQ_IOC);
+       return BFA_STATUS_OK;
+}
+
+void
+bfa_iocfc_set_snsbase(struct bfa_s *bfa, u64 snsbase_pa)
+{
+       struct bfa_iocfc_s      *iocfc = &bfa->iocfc;
+
+       iocfc->cfginfo->sense_buf_len = (BFI_IOIM_SNSLEN - 1);
+       bfa_dma_be_addr_set(iocfc->cfginfo->ioim_snsbase, snsbase_pa);
+}
+/**
+ * Enable IOC after it is disabled.
+ */
+void
+bfa_iocfc_enable(struct bfa_s *bfa)
+{
+       bfa_plog_str(bfa->plog, BFA_PL_MID_HAL, BFA_PL_EID_MISC, 0,
+                    "IOC Enable");
+       bfa_ioc_enable(&bfa->ioc);
+}
+
+void
+bfa_iocfc_disable(struct bfa_s *bfa)
+{
+       bfa_plog_str(bfa->plog, BFA_PL_MID_HAL, BFA_PL_EID_MISC, 0,
+                    "IOC Disable");
+       bfa->iocfc.action = BFA_IOCFC_ACT_DISABLE;
+
+       bfa->rme_process = BFA_FALSE;
+       bfa_ioc_disable(&bfa->ioc);
+}
+
+
+bfa_boolean_t
+bfa_iocfc_is_operational(struct bfa_s *bfa)
+{
+       return bfa_ioc_is_operational(&bfa->ioc) && bfa->iocfc.cfgdone;
+}
+
+/**
+ * Return boot target port wwns -- read from boot information in flash.
+ */
+void
+bfa_iocfc_get_bootwwns(struct bfa_s *bfa, u8 *nwwns, wwn_t *wwns)
+{
+       struct bfa_iocfc_s *iocfc = &bfa->iocfc;
+       struct bfi_iocfc_cfgrsp_s *cfgrsp = iocfc->cfgrsp;
+       int i;
+
+       if (cfgrsp->pbc_cfg.boot_enabled && cfgrsp->pbc_cfg.nbluns) {
+               bfa_trc(bfa, cfgrsp->pbc_cfg.nbluns);
+               *nwwns = cfgrsp->pbc_cfg.nbluns;
+               for (i = 0; i < cfgrsp->pbc_cfg.nbluns; i++)
+                       wwns[i] = cfgrsp->pbc_cfg.blun[i].tgt_pwwn;
+
+               return;
+       }
+
+       *nwwns = cfgrsp->bootwwns.nwwns;
+       memcpy(wwns, cfgrsp->bootwwns.wwn, sizeof(cfgrsp->bootwwns.wwn));
+}
+
+void
+bfa_iocfc_get_pbc_boot_cfg(struct bfa_s *bfa, struct bfa_boot_pbc_s *pbcfg)
+{
+       struct bfa_iocfc_s *iocfc = &bfa->iocfc;
+       struct bfi_iocfc_cfgrsp_s *cfgrsp = iocfc->cfgrsp;
+
+       pbcfg->enable = cfgrsp->pbc_cfg.boot_enabled;
+       pbcfg->nbluns = cfgrsp->pbc_cfg.nbluns;
+       pbcfg->speed = cfgrsp->pbc_cfg.port_speed;
+       memcpy(pbcfg->pblun, cfgrsp->pbc_cfg.blun, sizeof(pbcfg->pblun));
+}
+
+int
+bfa_iocfc_get_pbc_vports(struct bfa_s *bfa, struct bfi_pbc_vport_s *pbc_vport)
+{
+       struct bfa_iocfc_s *iocfc = &bfa->iocfc;
+       struct bfi_iocfc_cfgrsp_s *cfgrsp = iocfc->cfgrsp;
+
+       memcpy(pbc_vport, cfgrsp->pbc_cfg.vport, sizeof(cfgrsp->pbc_cfg.vport));
+       return cfgrsp->pbc_cfg.nvports;
+}
+
+/**
+ *  hal_api
+ */
 
 /**
  * Use this function query the memory requirement of the BFA library.
  * This call will fail, if the cap is out of range compared to pre-defined
  * values within the BFA library
  *
- * @param[in] cfg -    pointer to bfa_ioc_cfg_t. Driver layer should indicate
- *                     its configuration in this structure.
+ * @param[in] cfg -    pointer to bfa_ioc_cfg_t. Driver layer should indicate
+ *                     its configuration in this structure.
  *                     The default values for struct bfa_iocfc_cfg_s can be
  *                     fetched using bfa_cfg_get_default() API.
  *
- *                     If cap's boundary check fails, the library will use
+ *                     If cap's boundary check fails, the library will use
  *                     the default bfa_cap_t values (and log a warning msg).
  *
  * @param[out] meminfo - pointer to bfa_meminfo_t. This content
- *                     indicates the memory type (see bfa_mem_type_t) and
+ *                     indicates the memory type (see bfa_mem_type_t) and
  *                     amount of memory required.
  *
  *                     Driver should allocate the memory, populate the
 void
 bfa_cfg_get_meminfo(struct bfa_iocfc_cfg_s *cfg, struct bfa_meminfo_s *meminfo)
 {
-       int             i;
-       u32        km_len = 0, dm_len = 0;
+       int             i;
+       u32     km_len = 0, dm_len = 0;
 
        bfa_assert((cfg != NULL) && (meminfo != NULL));
 
@@ -90,26 +1055,6 @@ bfa_cfg_get_meminfo(struct bfa_iocfc_cfg_s *cfg, struct bfa_meminfo_s *meminfo)
        meminfo->meminfo[BFA_MEM_TYPE_DMA - 1].mem_len = dm_len;
 }
 
-static void
-bfa_com_port_attach(struct bfa_s *bfa, struct bfa_meminfo_s *mi)
-{
-       struct bfa_port_s       *port = &bfa->modules.port;
-       uint32_t                dm_len;
-       uint8_t                 *dm_kva;
-       uint64_t                dm_pa;
-
-       dm_len = bfa_port_meminfo();
-       dm_kva = bfa_meminfo_dma_virt(mi);
-       dm_pa  = bfa_meminfo_dma_phys(mi);
-
-       memset(port, 0, sizeof(struct bfa_port_s));
-       bfa_port_attach(port, &bfa->ioc, bfa, bfa->trcmod, bfa->logm);
-       bfa_port_mem_claim(port, dm_kva, dm_pa);
-
-       bfa_meminfo_dma_virt(mi) = dm_kva + dm_len;
-       bfa_meminfo_dma_phys(mi) = dm_pa + dm_len;
-}
-
 /**
  * Use this function to do attach the driver instance with the BFA
  * library. This function will not trigger any HW initialization
@@ -119,14 +1064,14 @@ bfa_com_port_attach(struct bfa_s *bfa, struct bfa_meminfo_s *mi)
  * pre-defined values within the BFA library
  *
  * @param[out] bfa     Pointer to bfa_t.
- * @param[in]  bfad    Opaque handle back to the driver's IOC structure
+ * @param[in]  bfad    Opaque handle back to the driver's IOC structure
  * @param[in]  cfg     Pointer to bfa_ioc_cfg_t. Should be same structure
- *                     that was used in bfa_cfg_get_meminfo().
- * @param[in]  meminfo Pointer to bfa_meminfo_t. The driver should
- *                     use the bfa_cfg_get_meminfo() call to
- *                     find the memory blocks required, allocate the
- *                     required memory and provide the starting addresses.
- * @param[in]  pcidev  pointer to struct bfa_pcidev_s
+ *                     that was used in bfa_cfg_get_meminfo().
+ * @param[in]  meminfo Pointer to bfa_meminfo_t. The driver should
+ *                     use the bfa_cfg_get_meminfo() call to
+ *                     find the memory blocks required, allocate the
+ *                     required memory and provide the starting addresses.
+ * @param[in]  pcidev  pointer to struct bfa_pcidev_s
  *
  * @return
  * void
@@ -140,8 +1085,8 @@ void
 bfa_attach(struct bfa_s *bfa, void *bfad, struct bfa_iocfc_cfg_s *cfg,
               struct bfa_meminfo_s *meminfo, struct bfa_pcidev_s *pcidev)
 {
-       int             i;
-       struct bfa_mem_elem_s *melem;
+       int                     i;
+       struct bfa_mem_elem_s   *melem;
 
        bfa->fcs = BFA_FALSE;
 
@@ -195,20 +1140,6 @@ bfa_init_trc(struct bfa_s *bfa, struct bfa_trc_mod_s *trcmod)
        bfa->trcmod = trcmod;
 }
 
-
-void
-bfa_init_log(struct bfa_s *bfa, struct bfa_log_mod_s *logmod)
-{
-       bfa->logm = logmod;
-}
-
-
-void
-bfa_init_aen(struct bfa_s *bfa, struct bfa_aen_s *aen)
-{
-       bfa->aen = aen;
-}
-
 void
 bfa_init_plog(struct bfa_s *bfa, struct bfa_plog_s *plog)
 {
@@ -254,14 +1185,14 @@ bfa_start(struct bfa_s *bfa)
 
 /**
  * Use this function quiese the IOC. This function will return immediately,
- * when the IOC is actually stopped, the bfa_cb_stop() will be called.
+ * when the IOC is actually stopped, the bfad->comp will be set.
  *
- * @param[in]  bfa - pointer to bfa_t.
+ * @param[in]bfa - pointer to bfa_t.
  *
  * @return None
  *
  * Special Considerations:
- * bfa_cb_stop() could be called before or after bfa_stop() returns.
+ * bfad->comp can be set before or after bfa_stop() returns.
  *
  * @note
  * In case of any failure, we could handle it automatically by doing a
@@ -283,9 +1214,9 @@ bfa_comp_deq(struct bfa_s *bfa, struct list_head *comp_q)
 void
 bfa_comp_process(struct bfa_s *bfa, struct list_head *comp_q)
 {
-       struct list_head        *qe;
-       struct list_head        *qen;
-       struct bfa_cb_qe_s   *hcb_qe;
+       struct list_head                *qe;
+       struct list_head                *qen;
+       struct bfa_cb_qe_s      *hcb_qe;
 
        list_for_each_safe(qe, qen, comp_q) {
                hcb_qe = (struct bfa_cb_qe_s *) qe;
@@ -296,8 +1227,8 @@ bfa_comp_process(struct bfa_s *bfa, struct list_head *comp_q)
 void
 bfa_comp_free(struct bfa_s *bfa, struct list_head *comp_q)
 {
-       struct list_head        *qe;
-       struct bfa_cb_qe_s   *hcb_qe;
+       struct list_head                *qe;
+       struct bfa_cb_qe_s      *hcb_qe;
 
        while (!list_empty(comp_q)) {
                bfa_q_deq(comp_q, &qe);
@@ -321,7 +1252,6 @@ bfa_timer_tick(struct bfa_s *bfa)
        bfa_timer_beat(&bfa->timer_mod);
 }
 
-#ifndef BFA_BIOS_BUILD
 /**
  * Return the list of PCI vendor/device id lists supported by this
  * BFA instance.
@@ -336,7 +1266,7 @@ bfa_get_pciids(struct bfa_pciid_s **pciids, int *npciids)
                {BFA_PCI_VENDOR_ID_BROCADE, BFA_PCI_DEVICE_ID_CT_FC},
        };
 
-       *npciids = ARRAY_SIZE(__pciids);
+       *npciids = sizeof(__pciids) / sizeof(__pciids[0]);
        *pciids = __pciids;
 }
 
@@ -351,7 +1281,7 @@ bfa_get_pciids(struct bfa_pciid_s **pciids, int *npciids)
  *     void
  *
  * Special Considerations:
- *     note
+ * note
  */
 void
 bfa_cfg_get_default(struct bfa_iocfc_cfg_s *cfg)
@@ -389,7 +1319,7 @@ bfa_cfg_get_min(struct bfa_iocfc_cfg_s *cfg)
        cfg->drvcfg.num_sgpgs      = BFA_SGPG_MIN;
        cfg->drvcfg.num_reqq_elems = BFA_REQQ_NELEMS_MIN;
        cfg->drvcfg.num_rspq_elems = BFA_RSPQ_NELEMS_MIN;
-       cfg->drvcfg.min_cfg        = BFA_TRUE;
+       cfg->drvcfg.min_cfg        = BFA_TRUE;
 }
 
 void
@@ -417,7 +1347,7 @@ bfa_debug_fwsave_clear(struct bfa_s *bfa)
 }
 
 /**
- *             Fetch firmware trace data.
+ * Fetch firmware trace data.
  *
  * @param[in]          bfa                     BFA instance
  * @param[out]         trcdata         Firmware trace buffer
@@ -432,6 +1362,22 @@ bfa_debug_fwtrc(struct bfa_s *bfa, void *trcdata, int *trclen)
        return bfa_ioc_debug_fwtrc(&bfa->ioc, trcdata, trclen);
 }
 
+/**
+ * Dump firmware memory.
+ *
+ * @param[in]          bfa             BFA instance
+ * @param[out]         buf             buffer for dump
+ * @param[in,out]      offset          smem offset to start read
+ * @param[in,out]      buflen          length of buffer
+ *
+ * @retval BFA_STATUS_OK               Firmware memory is dumped.
+ * @retval BFA_STATUS_INPROGRESS       Firmware memory dump is in progress.
+ */
+bfa_status_t
+bfa_debug_fwcore(struct bfa_s *bfa, void *buf, u32 *offset, int *buflen)
+{
+       return bfa_ioc_debug_fwcore(&bfa->ioc, buf, offset, buflen);
+}
 /**
  * Reset hw semaphore & usage cnt regs and initialize.
  */
@@ -441,4 +1387,23 @@ bfa_chip_reset(struct bfa_s *bfa)
        bfa_ioc_ownership_reset(&bfa->ioc);
        bfa_ioc_pll_init(&bfa->ioc);
 }
-#endif
+
+/**
+ * Fetch firmware statistics data.
+ *
+ * @param[in]          bfa             BFA instance
+ * @param[out]         data            Firmware stats buffer
+ *
+ * @retval BFA_STATUS_OK               Firmware trace is fetched.
+ */
+bfa_status_t
+bfa_fw_stats_get(struct bfa_s *bfa, void *data)
+{
+       return bfa_ioc_fw_stats_get(&bfa->ioc, data);
+}
+
+bfa_status_t
+bfa_fw_stats_clear(struct bfa_s *bfa)
+{
+       return bfa_ioc_fw_stats_clear(&bfa->ioc);
+}
diff --git a/drivers/scsi/bfa/bfa_cs.h b/drivers/scsi/bfa/bfa_cs.h
new file mode 100644 (file)
index 0000000..7260c74
--- /dev/null
@@ -0,0 +1,364 @@
+/*
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
+ * All rights reserved
+ * www.brocade.com
+ *
+ * Linux driver for Brocade Fibre Channel Host Bus Adapter.
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License (GPL) Version 2 as
+ * published by the Free Software Foundation
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * General Public License for more details.
+ */
+
+/**
+ *  bfa_cs.h BFA common services
+ */
+
+#ifndef __BFA_CS_H__
+#define __BFA_CS_H__
+
+#include "bfa_os_inc.h"
+
+/**
+ * BFA TRC
+ */
+
+#ifndef BFA_TRC_MAX
+#define BFA_TRC_MAX    (4 * 1024)
+#endif
+
+#ifndef BFA_TRC_TS
+#define BFA_TRC_TS(_trcm)      ((_trcm)->ticks++)
+#endif
+
+struct bfa_trc_s {
+#ifdef __BIGENDIAN
+       u16     fileno;
+       u16     line;
+#else
+       u16     line;
+       u16     fileno;
+#endif
+       u32     timestamp;
+       union {
+               struct {
+                       u32     rsvd;
+                       u32     u32;
+               } u32;
+               u64     u64;
+       } data;
+};
+
+struct bfa_trc_mod_s {
+       u32     head;
+       u32     tail;
+       u32     ntrc;
+       u32     stopped;
+       u32     ticks;
+       u32     rsvd[3];
+       struct bfa_trc_s trc[BFA_TRC_MAX];
+};
+
+enum {
+       BFA_TRC_HAL  = 1,       /*  BFA modules */
+       BFA_TRC_FCS  = 2,       /*  BFA FCS modules */
+       BFA_TRC_LDRV = 3,       /*  Linux driver modules */
+       BFA_TRC_CNA  = 4,       /*  Common modules */
+};
+#define BFA_TRC_MOD_SH 10
+#define BFA_TRC_MOD(__mod)     ((BFA_TRC_ ## __mod) << BFA_TRC_MOD_SH)
+
+/**
+ * Define a new tracing file (module). Module should match one defined above.
+ */
+#define BFA_TRC_FILE(__mod, __submod)                                  \
+       static int __trc_fileno = ((BFA_TRC_ ## __mod ## _ ## __submod) | \
+                                                BFA_TRC_MOD(__mod))
+
+
+#define bfa_trc32(_trcp, _data)        \
+       __bfa_trc((_trcp)->trcmod, __trc_fileno, __LINE__, (u32)_data)
+#define bfa_trc(_trcp, _data)  \
+       __bfa_trc((_trcp)->trcmod, __trc_fileno, __LINE__, (u64)_data)
+
+static inline void
+bfa_trc_init(struct bfa_trc_mod_s *trcm)
+{
+       trcm->head = trcm->tail = trcm->stopped = 0;
+       trcm->ntrc = BFA_TRC_MAX;
+}
+
+static inline void
+bfa_trc_stop(struct bfa_trc_mod_s *trcm)
+{
+       trcm->stopped = 1;
+}
+
+#ifdef FWTRC
+extern void dc_flush(void *data);
+#else
+#define dc_flush(data)
+#endif
+
+
+static inline void
+__bfa_trc(struct bfa_trc_mod_s *trcm, int fileno, int line, u64 data)
+{
+       int             tail = trcm->tail;
+       struct bfa_trc_s        *trc = &trcm->trc[tail];
+
+       if (trcm->stopped)
+               return;
+
+       trc->fileno = (u16) fileno;
+       trc->line = (u16) line;
+       trc->data.u64 = data;
+       trc->timestamp = BFA_TRC_TS(trcm);
+       dc_flush(trc);
+
+       trcm->tail = (trcm->tail + 1) & (BFA_TRC_MAX - 1);
+       if (trcm->tail == trcm->head)
+               trcm->head = (trcm->head + 1) & (BFA_TRC_MAX - 1);
+       dc_flush(trcm);
+}
+
+
+static inline void
+__bfa_trc32(struct bfa_trc_mod_s *trcm, int fileno, int line, u32 data)
+{
+       int             tail = trcm->tail;
+       struct bfa_trc_s *trc = &trcm->trc[tail];
+
+       if (trcm->stopped)
+               return;
+
+       trc->fileno = (u16) fileno;
+       trc->line = (u16) line;
+       trc->data.u32.u32 = data;
+       trc->timestamp = BFA_TRC_TS(trcm);
+       dc_flush(trc);
+
+       trcm->tail = (trcm->tail + 1) & (BFA_TRC_MAX - 1);
+       if (trcm->tail == trcm->head)
+               trcm->head = (trcm->head + 1) & (BFA_TRC_MAX - 1);
+       dc_flush(trcm);
+}
+
+#ifndef BFA_PERF_BUILD
+#define bfa_trc_fp(_trcp, _data)       bfa_trc(_trcp, _data)
+#else
+#define bfa_trc_fp(_trcp, _data)
+#endif
+
+/**
+ * @ BFA LOG interfaces
+ */
+#define bfa_assert(__cond)     do {                                    \
+       if (!(__cond)) {                                                \
+               printk(KERN_ERR "assert(%s) failed at %s:%d\\n",         \
+               #__cond, __FILE__, __LINE__);                           \
+       }                                                               \
+} while (0)
+
+#define bfa_sm_fault(__mod, __event)   do {                            \
+       bfa_trc(__mod, (((u32)0xDEAD << 16) | __event));                \
+       printk(KERN_ERR "Assertion failure: %s:%d: %d",                 \
+               __FILE__, __LINE__, (__event));                         \
+} while (0)
+
+#ifndef BFA_PERF_BUILD
+#define bfa_assert_fp(__cond)  bfa_assert(__cond)
+#else
+#define bfa_assert_fp(__cond)
+#endif
+
+/* BFA queue definitions */
+#define bfa_q_first(_q) ((void *)(((struct list_head *) (_q))->next))
+#define bfa_q_next(_qe) (((struct list_head *) (_qe))->next)
+#define bfa_q_prev(_qe) (((struct list_head *) (_qe))->prev)
+
+/*
+ * bfa_q_qe_init - to initialize a queue element
+ */
+#define bfa_q_qe_init(_qe) {                           \
+       bfa_q_next(_qe) = (struct list_head *) NULL;    \
+       bfa_q_prev(_qe) = (struct list_head *) NULL;    \
+}
+
+/*
+ * bfa_q_deq - dequeue an element from head of the queue
+ */
+#define bfa_q_deq(_q, _qe) {                                           \
+       if (!list_empty(_q)) {                                          \
+               (*((struct list_head **) (_qe))) = bfa_q_next(_q);      \
+               bfa_q_prev(bfa_q_next(*((struct list_head **) _qe))) =  \
+                               (struct list_head *) (_q);              \
+               bfa_q_next(_q) = bfa_q_next(*((struct list_head **) _qe));\
+               BFA_Q_DBG_INIT(*((struct list_head **) _qe));           \
+       } else {                                                        \
+               *((struct list_head **) (_qe)) = (struct list_head *) NULL;\
+       }                                                               \
+}
+
+/*
+ * bfa_q_deq_tail - dequeue an element from tail of the queue
+ */
+#define bfa_q_deq_tail(_q, _qe) {                                      \
+       if (!list_empty(_q)) {                                          \
+               *((struct list_head **) (_qe)) = bfa_q_prev(_q);        \
+               bfa_q_next(bfa_q_prev(*((struct list_head **) _qe))) =  \
+                       (struct list_head *) (_q);                      \
+               bfa_q_prev(_q) = bfa_q_prev(*(struct list_head **) _qe);\
+               BFA_Q_DBG_INIT(*((struct list_head **) _qe));           \
+       } else {                                                        \
+               *((struct list_head **) (_qe)) = (struct list_head *) NULL;\
+       }                                                               \
+}
+
+static inline int
+bfa_q_is_on_q_func(struct list_head *q, struct list_head *qe)
+{
+       struct list_head        *tqe;
+
+       tqe = bfa_q_next(q);
+       while (tqe != q) {
+               if (tqe == qe)
+                       return 1;
+               tqe = bfa_q_next(tqe);
+               if (tqe == NULL)
+                       break;
+       }
+       return 0;
+}
+
+/*
+ * #ifdef BFA_DEBUG (Using bfa_assert to check for debug_build is not
+ * consistent across modules)
+ */
+#ifndef BFA_PERF_BUILD
+#define BFA_Q_DBG_INIT(_qe) bfa_q_qe_init(_qe)
+#else
+#define BFA_Q_DBG_INIT(_qe)
+#endif
+
+#define bfa_q_is_on_q(_q, _qe)      \
+       bfa_q_is_on_q_func(_q, (struct list_head *)(_qe))
+
+/**
+ * @ BFA state machine interfaces
+ */
+
+typedef void (*bfa_sm_t)(void *sm, int event);
+
+/**
+ * oc - object class eg. bfa_ioc
+ * st - state, eg. reset
+ * otype - object type, eg. struct bfa_ioc_s
+ * etype - object type, eg. enum ioc_event
+ */
+#define bfa_sm_state_decl(oc, st, otype, etype)                \
+       static void oc ## _sm_ ## st(otype * fsm, etype event)
+
+#define bfa_sm_set_state(_sm, _state)  ((_sm)->sm = (bfa_sm_t)(_state))
+#define bfa_sm_send_event(_sm, _event) ((_sm)->sm((_sm), (_event)))
+#define bfa_sm_get_state(_sm)          ((_sm)->sm)
+#define bfa_sm_cmp_state(_sm, _state)  ((_sm)->sm == (bfa_sm_t)(_state))
+
+/**
+ * For converting from state machine function to state encoding.
+ */
+struct bfa_sm_table_s {
+       bfa_sm_t        sm;     /*  state machine function      */
+       int             state;  /*  state machine encoding      */
+       char            *name;  /*  state name for display      */
+};
+#define BFA_SM(_sm)    ((bfa_sm_t)(_sm))
+
+/**
+ * State machine with entry actions.
+ */
+typedef void (*bfa_fsm_t)(void *fsm, int event);
+
+/**
+ * oc - object class eg. bfa_ioc
+ * st - state, eg. reset
+ * otype - object type, eg. struct bfa_ioc_s
+ * etype - object type, eg. enum ioc_event
+ */
+#define bfa_fsm_state_decl(oc, st, otype, etype)               \
+       static void oc ## _sm_ ## st(otype * fsm, etype event);      \
+       static void oc ## _sm_ ## st ## _entry(otype * fsm)
+
+#define bfa_fsm_set_state(_fsm, _state) do {   \
+       (_fsm)->fsm = (bfa_fsm_t)(_state);      \
+       _state ## _entry(_fsm);      \
+} while (0)
+
+#define bfa_fsm_send_event(_fsm, _event)       ((_fsm)->fsm((_fsm), (_event)))
+#define bfa_fsm_get_state(_fsm)                        ((_fsm)->fsm)
+#define bfa_fsm_cmp_state(_fsm, _state)                \
+       ((_fsm)->fsm == (bfa_fsm_t)(_state))
+
+static inline int
+bfa_sm_to_state(struct bfa_sm_table_s *smt, bfa_sm_t sm)
+{
+       int     i = 0;
+
+       while (smt[i].sm && smt[i].sm != sm)
+               i++;
+       return smt[i].state;
+}
+
+/**
+ * @ Generic wait counter.
+ */
+
+typedef void (*bfa_wc_resume_t) (void *cbarg);
+
+struct bfa_wc_s {
+       bfa_wc_resume_t wc_resume;
+       void            *wc_cbarg;
+       int             wc_count;
+};
+
+static inline void
+bfa_wc_up(struct bfa_wc_s *wc)
+{
+       wc->wc_count++;
+}
+
+static inline void
+bfa_wc_down(struct bfa_wc_s *wc)
+{
+       wc->wc_count--;
+       if (wc->wc_count == 0)
+               wc->wc_resume(wc->wc_cbarg);
+}
+
+/**
+ * Initialize a waiting counter.
+ */
+static inline void
+bfa_wc_init(struct bfa_wc_s *wc, bfa_wc_resume_t wc_resume, void *wc_cbarg)
+{
+       wc->wc_resume = wc_resume;
+       wc->wc_cbarg = wc_cbarg;
+       wc->wc_count = 0;
+       bfa_wc_up(wc);
+}
+
+/**
+ * Wait for counter to reach zero
+ */
+static inline void
+bfa_wc_wait(struct bfa_wc_s *wc)
+{
+       bfa_wc_down(wc);
+}
+
+#endif /* __BFA_CS_H__ */
diff --git a/drivers/scsi/bfa/bfa_csdebug.c b/drivers/scsi/bfa/bfa_csdebug.c
deleted file mode 100644 (file)
index caeb114..0000000
+++ /dev/null
@@ -1,58 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#include <cs/bfa_debug.h>
-#include <bfa_os_inc.h>
-#include <cs/bfa_q.h>
-#include <log/bfa_log_hal.h>
-
-/**
- *  cs_debug_api
- */
-
-
-void
-bfa_panic(int line, char *file, char *panicstr)
-{
-       bfa_log(NULL, BFA_LOG_HAL_ASSERT, file, line, panicstr);
-       bfa_os_panic();
-}
-
-void
-bfa_sm_panic(struct bfa_log_mod_s *logm, int line, char *file, int event)
-{
-       bfa_log(logm, BFA_LOG_HAL_SM_ASSERT, file, line, event);
-       bfa_os_panic();
-}
-
-int
-bfa_q_is_on_q_func(struct list_head *q, struct list_head *qe)
-{
-       struct list_head        *tqe;
-
-       tqe = bfa_q_next(q);
-       while (tqe != q) {
-               if (tqe == qe)
-                       return 1;
-               tqe = bfa_q_next(tqe);
-               if (tqe == NULL)
-                       break;
-       }
-       return 0;
-}
-
-
diff --git a/drivers/scsi/bfa/bfa_defs.h b/drivers/scsi/bfa/bfa_defs.h
new file mode 100644 (file)
index 0000000..d49877f
--- /dev/null
@@ -0,0 +1,466 @@
+/*
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
+ * All rights reserved
+ * www.brocade.com
+ *
+ * Linux driver for Brocade Fibre Channel Host Bus Adapter.
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License (GPL) Version 2 as
+ * published by the Free Software Foundation
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * General Public License for more details.
+ */
+
+#ifndef __BFA_DEFS_H__
+#define __BFA_DEFS_H__
+
+#include "bfa_fc.h"
+#include "bfa_os_inc.h"
+
+#define BFA_MFG_SERIALNUM_SIZE                  11
+#define STRSZ(_n)                               (((_n) + 4) & ~3)
+
+/**
+ * Manufacturing card type
+ */
+enum {
+       BFA_MFG_TYPE_CB_MAX  = 825,      /*  Crossbow card type max     */
+       BFA_MFG_TYPE_FC8P2   = 825,      /*  8G 2port FC card           */
+       BFA_MFG_TYPE_FC8P1   = 815,      /*  8G 1port FC card           */
+       BFA_MFG_TYPE_FC4P2   = 425,      /*  4G 2port FC card           */
+       BFA_MFG_TYPE_FC4P1   = 415,      /*  4G 1port FC card           */
+       BFA_MFG_TYPE_CNA10P2 = 1020,     /*  10G 2port CNA card */
+       BFA_MFG_TYPE_CNA10P1 = 1010,     /*  10G 1port CNA card */
+       BFA_MFG_TYPE_JAYHAWK = 804,      /*  Jayhawk mezz card          */
+       BFA_MFG_TYPE_WANCHESE = 1007,    /*  Wanchese mezz card */
+       BFA_MFG_TYPE_ASTRA    = 807,     /*  Astra mezz card            */
+       BFA_MFG_TYPE_LIGHTNING_P0 = 902, /*  Lightning mezz card - old  */
+       BFA_MFG_TYPE_LIGHTNING = 1741,   /*  Lightning mezz card        */
+       BFA_MFG_TYPE_INVALID = 0,        /*  Invalid card type          */
+};
+
+#pragma pack(1)
+
+/**
+ * Check if Mezz card
+ */
+#define bfa_mfg_is_mezz(type) (( \
+       (type) == BFA_MFG_TYPE_JAYHAWK || \
+       (type) == BFA_MFG_TYPE_WANCHESE || \
+       (type) == BFA_MFG_TYPE_ASTRA || \
+       (type) == BFA_MFG_TYPE_LIGHTNING_P0 || \
+       (type) == BFA_MFG_TYPE_LIGHTNING))
+
+/**
+ * Check if the card having old wwn/mac handling
+ */
+#define bfa_mfg_is_old_wwn_mac_model(type) (( \
+       (type) == BFA_MFG_TYPE_FC8P2 || \
+       (type) == BFA_MFG_TYPE_FC8P1 || \
+       (type) == BFA_MFG_TYPE_FC4P2 || \
+       (type) == BFA_MFG_TYPE_FC4P1 || \
+       (type) == BFA_MFG_TYPE_CNA10P2 || \
+       (type) == BFA_MFG_TYPE_CNA10P1 || \
+       (type) == BFA_MFG_TYPE_JAYHAWK || \
+       (type) == BFA_MFG_TYPE_WANCHESE))
+
+#define bfa_mfg_increment_wwn_mac(m, i)                         \
+do {                                                            \
+       u32 t = ((u32)(m)[0] << 16) | ((u32)(m)[1] << 8) | \
+               (u32)(m)[2];  \
+       t += (i);      \
+       (m)[0] = (t >> 16) & 0xFF;                              \
+       (m)[1] = (t >> 8) & 0xFF;                               \
+       (m)[2] = t & 0xFF;                                      \
+} while (0)
+
+/**
+ * VPD data length
+ */
+#define BFA_MFG_VPD_LEN                 512
+
+/**
+ * VPD vendor tag
+ */
+enum {
+       BFA_MFG_VPD_UNKNOWN     = 0,     /*  vendor unknown             */
+       BFA_MFG_VPD_IBM         = 1,     /*  vendor IBM                 */
+       BFA_MFG_VPD_HP          = 2,     /*  vendor HP                  */
+       BFA_MFG_VPD_DELL        = 3,     /*  vendor DELL                */
+       BFA_MFG_VPD_PCI_IBM     = 0x08,  /*  PCI VPD IBM                */
+       BFA_MFG_VPD_PCI_HP      = 0x10,  /*  PCI VPD HP         */
+       BFA_MFG_VPD_PCI_DELL    = 0x20,  /*  PCI VPD DELL               */
+       BFA_MFG_VPD_PCI_BRCD    = 0xf8,  /*  PCI VPD Brocade            */
+};
+
+/**
+ * All numerical fields are in big-endian format.
+ */
+struct bfa_mfg_vpd_s {
+       u8              version;        /*  vpd data version */
+       u8              vpd_sig[3];     /*  characters 'V', 'P', 'D' */
+       u8              chksum;         /*  u8 checksum */
+       u8              vendor;         /*  vendor */
+       u8      len;            /*  vpd data length excluding header */
+       u8      rsv;
+       u8              data[BFA_MFG_VPD_LEN];  /*  vpd data */
+};
+
+#pragma pack()
+
+/**
+ * Status return values
+ */
+enum bfa_status {
+       BFA_STATUS_OK           = 0,    /*  Success */
+       BFA_STATUS_FAILED       = 1,    /*  Operation failed */
+       BFA_STATUS_EINVAL       = 2,    /*  Invalid params Check input
+                                        *  parameters */
+       BFA_STATUS_ENOMEM       = 3,    /*  Out of resources */
+       BFA_STATUS_ETIMER       = 5,    /*  Timer expired - Retry, if persists,
+                                        *  contact support */
+       BFA_STATUS_EPROTOCOL    = 6,    /*  Protocol error */
+       BFA_STATUS_DEVBUSY      = 13,   /*  Device busy - Retry operation */
+       BFA_STATUS_UNKNOWN_LWWN = 18,   /*  LPORT PWWN not found */
+       BFA_STATUS_UNKNOWN_RWWN = 19,   /*  RPORT PWWN not found */
+       BFA_STATUS_VPORT_EXISTS = 21,   /*  VPORT already exists */
+       BFA_STATUS_VPORT_MAX    = 22,   /*  Reached max VPORT supported limit */
+       BFA_STATUS_UNSUPP_SPEED = 23,   /*  Invalid Speed Check speed setting */
+       BFA_STATUS_INVLD_DFSZ   = 24,   /*  Invalid Max data field size */
+       BFA_STATUS_FABRIC_RJT   = 29,   /*  Reject from attached fabric */
+       BFA_STATUS_VPORT_WWN_BP = 46,   /*  WWN is same as base port's WWN */
+       BFA_STATUS_NO_FCPIM_NEXUS = 52, /* No FCP Nexus exists with the rport */
+       BFA_STATUS_IOC_FAILURE  = 56,   /* IOC failure - Retry, if persists
+                                        * contact support */
+       BFA_STATUS_INVALID_WWN  = 57,   /*  Invalid WWN */
+       BFA_STATUS_DIAG_BUSY    = 71,   /*  diag busy */
+       BFA_STATUS_ENOFSAVE     = 78,   /*  No saved firmware trace */
+       BFA_STATUS_IOC_DISABLED = 82,   /* IOC is already disabled */
+       BFA_STATUS_INVALID_MAC  = 134, /*  Invalid MAC address */
+       BFA_STATUS_PBC          = 154, /*  Operation not allowed for pre-boot
+                                       *  configuration */
+       BFA_STATUS_TRUNK_ENABLED = 164, /* Trunk is already enabled on
+                                        * this adapter */
+       BFA_STATUS_TRUNK_DISABLED  = 165, /* Trunking is disabled on
+                                          * the adapter */
+       BFA_STATUS_IOPROFILE_OFF = 175, /* IO profile OFF */
+       BFA_STATUS_MAX_VAL              /* Unknown error code */
+};
+#define bfa_status_t enum bfa_status
+
+enum bfa_eproto_status {
+       BFA_EPROTO_BAD_ACCEPT = 0,
+       BFA_EPROTO_UNKNOWN_RSP = 1
+};
+#define bfa_eproto_status_t enum bfa_eproto_status
+
+enum bfa_boolean {
+       BFA_FALSE = 0,
+       BFA_TRUE  = 1
+};
+#define bfa_boolean_t enum bfa_boolean
+
+#define BFA_STRING_32  32
+#define BFA_VERSION_LEN 64
+
+/**
+ * ---------------------- adapter definitions ------------
+ */
+
+/**
+ * BFA adapter level attributes.
+ */
+enum {
+       BFA_ADAPTER_SERIAL_NUM_LEN = STRSZ(BFA_MFG_SERIALNUM_SIZE),
+                                       /*
+                                        *!< adapter serial num length
+                                        */
+       BFA_ADAPTER_MODEL_NAME_LEN  = 16,  /*  model name length */
+       BFA_ADAPTER_MODEL_DESCR_LEN = 128, /*  model description length */
+       BFA_ADAPTER_MFG_NAME_LEN    = 8,   /*  manufacturer name length */
+       BFA_ADAPTER_SYM_NAME_LEN    = 64,  /*  adapter symbolic name length */
+       BFA_ADAPTER_OS_TYPE_LEN     = 64,  /*  adapter os type length */
+};
+
+struct bfa_adapter_attr_s {
+       char            manufacturer[BFA_ADAPTER_MFG_NAME_LEN];
+       char            serial_num[BFA_ADAPTER_SERIAL_NUM_LEN];
+       u32     card_type;
+       char            model[BFA_ADAPTER_MODEL_NAME_LEN];
+       char            model_descr[BFA_ADAPTER_MODEL_DESCR_LEN];
+       wwn_t           pwwn;
+       char            node_symname[FC_SYMNAME_MAX];
+       char            hw_ver[BFA_VERSION_LEN];
+       char            fw_ver[BFA_VERSION_LEN];
+       char            optrom_ver[BFA_VERSION_LEN];
+       char            os_type[BFA_ADAPTER_OS_TYPE_LEN];
+       struct bfa_mfg_vpd_s    vpd;
+       struct mac_s    mac;
+
+       u8              nports;
+       u8              max_speed;
+       u8              prototype;
+       char            asic_rev;
+
+       u8              pcie_gen;
+       u8              pcie_lanes_orig;
+       u8              pcie_lanes;
+       u8              cna_capable;
+
+       u8              is_mezz;
+       u8              trunk_capable;
+};
+
+/**
+ * ---------------------- IOC definitions ------------
+ */
+
+enum {
+       BFA_IOC_DRIVER_LEN      = 16,
+       BFA_IOC_CHIP_REV_LEN    = 8,
+};
+
+/**
+ * Driver and firmware versions.
+ */
+struct bfa_ioc_driver_attr_s {
+       char            driver[BFA_IOC_DRIVER_LEN];     /*  driver name */
+       char            driver_ver[BFA_VERSION_LEN];    /*  driver version */
+       char            fw_ver[BFA_VERSION_LEN];        /*  firmware version */
+       char            bios_ver[BFA_VERSION_LEN];      /*  bios version */
+       char            efi_ver[BFA_VERSION_LEN];       /*  EFI version */
+       char            ob_ver[BFA_VERSION_LEN];        /*  openboot version */
+};
+
+/**
+ * IOC PCI device attributes
+ */
+struct bfa_ioc_pci_attr_s {
+       u16     vendor_id;      /*  PCI vendor ID */
+       u16     device_id;      /*  PCI device ID */
+       u16     ssid;           /*  subsystem ID */
+       u16     ssvid;          /*  subsystem vendor ID */
+       u32     pcifn;          /*  PCI device function */
+       u32     rsvd;           /* padding */
+       char            chip_rev[BFA_IOC_CHIP_REV_LEN];  /*  chip revision */
+};
+
+/**
+ * IOC states
+ */
+enum bfa_ioc_state {
+       BFA_IOC_UNINIT          = 1,    /*  IOC is in uninit state */
+       BFA_IOC_RESET           = 2,    /*  IOC is in reset state */
+       BFA_IOC_SEMWAIT         = 3,    /*  Waiting for IOC h/w semaphore */
+       BFA_IOC_HWINIT          = 4,    /*  IOC h/w is being initialized */
+       BFA_IOC_GETATTR         = 5,    /*  IOC is being configured */
+       BFA_IOC_OPERATIONAL     = 6,    /*  IOC is operational */
+       BFA_IOC_INITFAIL        = 7,    /*  IOC hardware failure */
+       BFA_IOC_FAIL            = 8,    /*  IOC heart-beat failure */
+       BFA_IOC_DISABLING       = 9,    /*  IOC is being disabled */
+       BFA_IOC_DISABLED        = 10,   /*  IOC is disabled */
+       BFA_IOC_FWMISMATCH      = 11,   /*  IOC f/w different from drivers */
+       BFA_IOC_ENABLING        = 12,   /*  IOC is being enabled */
+};
+
+/**
+ * IOC firmware stats
+ */
+struct bfa_fw_ioc_stats_s {
+       u32     enable_reqs;
+       u32     disable_reqs;
+       u32     get_attr_reqs;
+       u32     dbg_sync;
+       u32     dbg_dump;
+       u32     unknown_reqs;
+};
+
+/**
+ * IOC driver stats
+ */
+struct bfa_ioc_drv_stats_s {
+       u32     ioc_isrs;
+       u32     ioc_enables;
+       u32     ioc_disables;
+       u32     ioc_hbfails;
+       u32     ioc_boots;
+       u32     stats_tmos;
+       u32     hb_count;
+       u32     disable_reqs;
+       u32     enable_reqs;
+       u32     disable_replies;
+       u32     enable_replies;
+};
+
+/**
+ * IOC statistics
+ */
+struct bfa_ioc_stats_s {
+       struct bfa_ioc_drv_stats_s      drv_stats; /*  driver IOC stats */
+       struct bfa_fw_ioc_stats_s       fw_stats;  /*  firmware IOC stats */
+};
+
+enum bfa_ioc_type_e {
+       BFA_IOC_TYPE_FC         = 1,
+       BFA_IOC_TYPE_FCoE       = 2,
+       BFA_IOC_TYPE_LL         = 3,
+};
+
+/**
+ * IOC attributes returned in queries
+ */
+struct bfa_ioc_attr_s {
+       enum bfa_ioc_type_e             ioc_type;
+       enum bfa_ioc_state              state;          /*  IOC state      */
+       struct bfa_adapter_attr_s       adapter_attr;   /*  HBA attributes */
+       struct bfa_ioc_driver_attr_s    driver_attr;    /*  driver attr    */
+       struct bfa_ioc_pci_attr_s       pci_attr;
+       u8                              port_id;        /*  port number    */
+       u8                              rsvd[7];        /*  64bit align    */
+};
+
+/**
+ * ---------------------- mfg definitions ------------
+ */
+
+/**
+ * Checksum size
+ */
+#define BFA_MFG_CHKSUM_SIZE                    16
+
+#define BFA_MFG_PARTNUM_SIZE                   14
+#define BFA_MFG_SUPPLIER_ID_SIZE               10
+#define BFA_MFG_SUPPLIER_PARTNUM_SIZE          20
+#define BFA_MFG_SUPPLIER_SERIALNUM_SIZE                20
+#define BFA_MFG_SUPPLIER_REVISION_SIZE         4
+
+#pragma pack(1)
+
+/**
+ * All numerical fields are in big-endian format.
+ */
+struct bfa_mfg_block_s {
+       u8              version;        /*  manufacturing block version */
+       u8              mfg_sig[3];     /*  characters 'M', 'F', 'G' */
+       u16     mfgsize;        /*  mfg block size */
+       u16     u16_chksum;     /*  old u16 checksum */
+       char            brcd_serialnum[STRSZ(BFA_MFG_SERIALNUM_SIZE)];
+       char            brcd_partnum[STRSZ(BFA_MFG_PARTNUM_SIZE)];
+       u8              mfg_day;        /*  manufacturing day */
+       u8              mfg_month;      /*  manufacturing month */
+       u16     mfg_year;       /*  manufacturing year */
+       wwn_t           mfg_wwn;        /*  wwn base for this adapter */
+       u8              num_wwn;        /*  number of wwns assigned */
+       u8              mfg_speeds;     /*  speeds allowed for this adapter */
+       u8              rsv[2];
+       char            supplier_id[STRSZ(BFA_MFG_SUPPLIER_ID_SIZE)];
+       char            supplier_partnum[STRSZ(BFA_MFG_SUPPLIER_PARTNUM_SIZE)];
+       char
+               supplier_serialnum[STRSZ(BFA_MFG_SUPPLIER_SERIALNUM_SIZE)];
+       char
+               supplier_revision[STRSZ(BFA_MFG_SUPPLIER_REVISION_SIZE)];
+       mac_t           mfg_mac;        /*  mac address */
+       u8              num_mac;        /*  number of mac addresses */
+       u8              rsv2;
+       u32     mfg_type;       /*  card type */
+       u8              rsv3[108];
+       u8              md5_chksum[BFA_MFG_CHKSUM_SIZE]; /*  md5 checksum */
+};
+
+#pragma pack()
+
+/**
+ * ---------------------- pci definitions ------------
+ */
+
+/**
+ * PCI device and vendor ID information
+ */
+enum {
+       BFA_PCI_VENDOR_ID_BROCADE       = 0x1657,
+       BFA_PCI_DEVICE_ID_FC_8G2P       = 0x13,
+       BFA_PCI_DEVICE_ID_FC_8G1P       = 0x17,
+       BFA_PCI_DEVICE_ID_CT            = 0x14,
+       BFA_PCI_DEVICE_ID_CT_FC         = 0x21,
+};
+
+#define bfa_asic_id_ct(devid)                  \
+       ((devid) == BFA_PCI_DEVICE_ID_CT ||     \
+        (devid) == BFA_PCI_DEVICE_ID_CT_FC)
+
+/**
+ * PCI sub-system device and vendor ID information
+ */
+enum {
+       BFA_PCI_FCOE_SSDEVICE_ID        = 0x14,
+};
+
+/**
+ * Maximum number of device address ranges mapped through different BAR(s)
+ */
+#define BFA_PCI_ACCESS_RANGES 1
+
+/*
+ *     Port speed settings. Each specific speed is a bit field. Use multiple
+ *     bits to specify speeds to be selected for auto-negotiation.
+ */
+enum bfa_port_speed {
+       BFA_PORT_SPEED_UNKNOWN = 0,
+       BFA_PORT_SPEED_1GBPS    = 1,
+       BFA_PORT_SPEED_2GBPS    = 2,
+       BFA_PORT_SPEED_4GBPS    = 4,
+       BFA_PORT_SPEED_8GBPS    = 8,
+       BFA_PORT_SPEED_10GBPS   = 10,
+       BFA_PORT_SPEED_16GBPS   = 16,
+       BFA_PORT_SPEED_AUTO =
+               (BFA_PORT_SPEED_1GBPS | BFA_PORT_SPEED_2GBPS |
+                BFA_PORT_SPEED_4GBPS | BFA_PORT_SPEED_8GBPS),
+};
+#define bfa_port_speed_t enum bfa_port_speed
+
+enum {
+       BFA_BOOT_BOOTLUN_MAX = 4,       /*  maximum boot lun per IOC */
+       BFA_PREBOOT_BOOTLUN_MAX = 8,    /*  maximum preboot lun per IOC */
+};
+
+#define BOOT_CFG_REV1   1
+#define BOOT_CFG_VLAN   1
+
+/**
+ *      Boot options setting. Boot options setting determines from where
+ *      to get the boot lun information
+ */
+enum bfa_boot_bootopt {
+       BFA_BOOT_AUTO_DISCOVER  = 0, /*  Boot from blun provided by fabric */
+       BFA_BOOT_STORED_BLUN = 1, /*  Boot from bluns stored in flash */
+       BFA_BOOT_FIRST_LUN      = 2, /*  Boot from first discovered blun */
+       BFA_BOOT_PBC    = 3, /*  Boot from pbc configured blun  */
+};
+
+#pragma pack(1)
+/**
+ * Boot lun information.
+ */
+struct bfa_boot_bootlun_s {
+       wwn_t   pwwn;   /*  port wwn of target */
+       lun_t   lun;    /*  64-bit lun */
+};
+#pragma pack()
+
+/**
+ * BOOT boot configuraton
+ */
+struct bfa_boot_pbc_s {
+       u8              enable;         /*  enable/disable SAN boot */
+       u8              speed;          /*  boot speed settings */
+       u8              topology;       /*  boot topology setting */
+       u8              rsvd1;
+       u32     nbluns;         /*  number of boot luns */
+       struct bfa_boot_bootlun_s pblun[BFA_PREBOOT_BOOTLUN_MAX];
+};
+
+#endif /* __BFA_DEFS_H__ */
diff --git a/drivers/scsi/bfa/bfa_defs_fcs.h b/drivers/scsi/bfa/bfa_defs_fcs.h
new file mode 100644 (file)
index 0000000..96905d3
--- /dev/null
@@ -0,0 +1,457 @@
+/*
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
+ * All rights reserved
+ * www.brocade.com
+ *
+ * Linux driver for Brocade Fibre Channel Host Bus Adapter.
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License (GPL) Version 2 as
+ * published by the Free Software Foundation
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * General Public License for more details.
+ */
+
+#ifndef __BFA_DEFS_FCS_H__
+#define __BFA_DEFS_FCS_H__
+
+#include "bfa_fc.h"
+#include "bfa_defs_svc.h"
+
+/**
+ * VF states
+ */
+enum bfa_vf_state {
+       BFA_VF_UNINIT    = 0,   /*  fabric is not yet initialized */
+       BFA_VF_LINK_DOWN = 1,   /*  link is down */
+       BFA_VF_FLOGI     = 2,   /*  flogi is in progress */
+       BFA_VF_AUTH      = 3,   /*  authentication in progress */
+       BFA_VF_NOFABRIC  = 4,   /*  fabric is not present */
+       BFA_VF_ONLINE    = 5,   /*  login to fabric is complete */
+       BFA_VF_EVFP      = 6,   /*  EVFP is in progress */
+       BFA_VF_ISOLATED  = 7,   /*  port isolated due to vf_id mismatch */
+};
+
+/**
+ * VF statistics
+ */
+struct bfa_vf_stats_s {
+       u32     flogi_sent;     /*  Num FLOGIs sent */
+       u32     flogi_rsp_err;  /*  FLOGI response errors */
+       u32     flogi_acc_err;  /*  FLOGI accept errors */
+       u32     flogi_accepts;  /*  FLOGI accepts received */
+       u32     flogi_rejects;  /*  FLOGI rejects received */
+       u32     flogi_unknown_rsp; /*  Unknown responses for FLOGI */
+       u32     flogi_alloc_wait; /*  Allocation waits prior to sending FLOGI */
+       u32     flogi_rcvd;     /*  FLOGIs received */
+       u32     flogi_rejected; /*  Incoming FLOGIs rejected */
+       u32     fabric_onlines; /*  Internal fabric online notification sent
+                                *  to other modules */
+       u32     fabric_offlines; /* Internal fabric offline notification sent
+                                 * to other modules */
+       u32     resvd; /*  padding for 64 bit alignment */
+};
+
+/**
+ * VF attributes returned in queries
+ */
+struct bfa_vf_attr_s {
+       enum bfa_vf_state  state;               /*  VF state */
+       u32        rsvd;
+       wwn_t           fabric_name;    /*  fabric name */
+};
+
+#define BFA_FCS_MAX_LPORTS 256
+#define BFA_FCS_FABRIC_IPADDR_SZ  16
+
+/**
+ * symbolic names for base port/virtual port
+ */
+#define BFA_SYMNAME_MAXLEN     128     /* 128 bytes */
+struct bfa_lport_symname_s {
+       char        symname[BFA_SYMNAME_MAXLEN];
+};
+
+/**
+* Roles of FCS port:
+ *     - FCP IM and FCP TM roles cannot be enabled together for a FCS port
+ *     - Create multiple ports if both IM and TM functions required.
+ *     - Atleast one role must be specified.
+ */
+enum bfa_lport_role {
+       BFA_LPORT_ROLE_FCP_IM   = 0x01, /*  FCP initiator role */
+       BFA_LPORT_ROLE_FCP_MAX  = BFA_LPORT_ROLE_FCP_IM,
+};
+
+/**
+ * FCS port configuration.
+ */
+struct bfa_lport_cfg_s {
+    wwn_t             pwwn;       /*  port wwn */
+    wwn_t             nwwn;       /*  node wwn */
+    struct bfa_lport_symname_s  sym_name;   /*  vm port symbolic name */
+       bfa_boolean_t       preboot_vp;  /*  vport created from PBC */
+    enum bfa_lport_role     roles;      /*  FCS port roles */
+    u8      tag[16];   /*  opaque tag from application */
+};
+
+/**
+ * FCS port states
+ */
+enum bfa_lport_state {
+       BFA_LPORT_UNINIT  = 0,  /*  PORT is not yet initialized */
+       BFA_LPORT_FDISC   = 1,  /*  FDISC is in progress */
+       BFA_LPORT_ONLINE  = 2,  /*  login to fabric is complete */
+       BFA_LPORT_OFFLINE = 3,  /*  No login to fabric */
+};
+
+/**
+ * FCS port type.
+ */
+enum bfa_lport_type {
+       BFA_LPORT_TYPE_PHYSICAL = 0,
+       BFA_LPORT_TYPE_VIRTUAL,
+};
+
+/**
+ * FCS port offline reason.
+ */
+enum bfa_lport_offline_reason {
+       BFA_LPORT_OFFLINE_UNKNOWN = 0,
+       BFA_LPORT_OFFLINE_LINKDOWN,
+       BFA_LPORT_OFFLINE_FAB_UNSUPPORTED,      /*  NPIV not supported by the
+        *    fabric */
+       BFA_LPORT_OFFLINE_FAB_NORESOURCES,
+       BFA_LPORT_OFFLINE_FAB_LOGOUT,
+};
+
+/**
+ * FCS lport info.
+ */
+struct bfa_lport_info_s {
+       u8       port_type;     /* bfa_lport_type_t : physical or
+        * virtual */
+       u8       port_state;    /* one of bfa_lport_state values */
+       u8       offline_reason;        /* one of bfa_lport_offline_reason_t
+        * values */
+       wwn_t      port_wwn;
+       wwn_t      node_wwn;
+
+       /*
+        * following 4 feilds are valid for Physical Ports only
+        */
+       u32     max_vports_supp;        /* Max supported vports */
+       u32     num_vports_inuse;       /* Num of in use vports */
+       u32     max_rports_supp;        /* Max supported rports */
+       u32     num_rports_inuse;       /* Num of doscovered rports */
+
+};
+
+/**
+ * FCS port statistics
+ */
+struct bfa_lport_stats_s {
+       u32     ns_plogi_sent;
+       u32     ns_plogi_rsp_err;
+       u32     ns_plogi_acc_err;
+       u32     ns_plogi_accepts;
+       u32     ns_rejects;     /* NS command rejects */
+       u32     ns_plogi_unknown_rsp;
+       u32     ns_plogi_alloc_wait;
+
+       u32     ns_retries;     /* NS command retries */
+       u32     ns_timeouts;    /* NS command timeouts */
+
+       u32     ns_rspnid_sent;
+       u32     ns_rspnid_accepts;
+       u32     ns_rspnid_rsp_err;
+       u32     ns_rspnid_rejects;
+       u32     ns_rspnid_alloc_wait;
+
+       u32     ns_rftid_sent;
+       u32     ns_rftid_accepts;
+       u32     ns_rftid_rsp_err;
+       u32     ns_rftid_rejects;
+       u32     ns_rftid_alloc_wait;
+
+       u32     ns_rffid_sent;
+       u32     ns_rffid_accepts;
+       u32     ns_rffid_rsp_err;
+       u32     ns_rffid_rejects;
+       u32     ns_rffid_alloc_wait;
+
+       u32     ns_gidft_sent;
+       u32     ns_gidft_accepts;
+       u32     ns_gidft_rsp_err;
+       u32     ns_gidft_rejects;
+       u32     ns_gidft_unknown_rsp;
+       u32     ns_gidft_alloc_wait;
+
+       /*
+        * Mgmt Server stats
+        */
+       u32     ms_retries;     /* MS command retries */
+       u32     ms_timeouts;    /* MS command timeouts */
+       u32     ms_plogi_sent;
+       u32     ms_plogi_rsp_err;
+       u32     ms_plogi_acc_err;
+       u32     ms_plogi_accepts;
+       u32     ms_rejects;     /* MS command rejects */
+       u32     ms_plogi_unknown_rsp;
+       u32     ms_plogi_alloc_wait;
+
+       u32     num_rscn;       /* Num of RSCN received */
+       u32     num_portid_rscn;/* Num portid format RSCN
+       * received */
+
+       u32     uf_recvs;       /* Unsolicited recv frames      */
+       u32     uf_recv_drops;  /* Dropped received frames      */
+
+       u32     plogi_rcvd;     /* Received plogi       */
+       u32     prli_rcvd;      /* Received prli        */
+       u32     adisc_rcvd;     /* Received adisc       */
+       u32     prlo_rcvd;      /* Received prlo        */
+       u32     logo_rcvd;      /* Received logo        */
+       u32     rpsc_rcvd;      /* Received rpsc        */
+       u32     un_handled_els_rcvd;    /* Received unhandled ELS       */
+       u32     rport_plogi_timeouts; /* Rport plogi retry timeout count */
+       u32     rport_del_max_plogi_retry; /* Deleted rport
+                                           * (max retry of plogi) */
+};
+
+/**
+ * BFA port attribute returned in queries
+ */
+struct bfa_lport_attr_s {
+       enum bfa_lport_state state;     /*  port state */
+       u32      pid;   /*  port ID */
+       struct bfa_lport_cfg_s   port_cfg;      /*  port configuration */
+       enum bfa_port_type port_type;   /*  current topology */
+       u32      loopback;      /*  cable is externally looped back */
+       wwn_t   fabric_name; /*  attached switch's nwwn */
+       u8      fabric_ip_addr[BFA_FCS_FABRIC_IPADDR_SZ]; /*  attached
+       * fabric's ip addr */
+       mac_t      fpma_mac;    /*  Lport's FPMA Mac address */
+       u16     authfail;       /*  auth failed state */
+};
+
+
+/**
+ * VPORT states
+ */
+enum bfa_vport_state {
+       BFA_FCS_VPORT_UNINIT            = 0,
+       BFA_FCS_VPORT_CREATED           = 1,
+       BFA_FCS_VPORT_OFFLINE           = 1,
+       BFA_FCS_VPORT_FDISC_SEND        = 2,
+       BFA_FCS_VPORT_FDISC             = 3,
+       BFA_FCS_VPORT_FDISC_RETRY       = 4,
+       BFA_FCS_VPORT_ONLINE            = 5,
+       BFA_FCS_VPORT_DELETING          = 6,
+       BFA_FCS_VPORT_CLEANUP           = 6,
+       BFA_FCS_VPORT_LOGO_SEND         = 7,
+       BFA_FCS_VPORT_LOGO              = 8,
+       BFA_FCS_VPORT_ERROR             = 9,
+       BFA_FCS_VPORT_MAX_STATE,
+};
+
+/**
+ * vport statistics
+ */
+struct bfa_vport_stats_s {
+       struct bfa_lport_stats_s port_stats;    /*  base class (port) stats */
+       /*
+        * TODO - remove
+        */
+
+       u32        fdisc_sent;  /*  num fdisc sent */
+       u32        fdisc_accepts;       /*  fdisc accepts */
+       u32        fdisc_retries;       /*  fdisc retries */
+       u32        fdisc_timeouts;      /*  fdisc timeouts */
+       u32        fdisc_rsp_err;       /*  fdisc response error */
+       u32        fdisc_acc_bad;       /*  bad fdisc accepts */
+       u32        fdisc_rejects;       /*  fdisc rejects */
+       u32        fdisc_unknown_rsp;
+       /*
+        *!< fdisc rsp unknown error
+        */
+       u32        fdisc_alloc_wait;/*  fdisc req (fcxp)alloc wait */
+
+       u32        logo_alloc_wait;/*  logo req (fcxp) alloc wait */
+       u32        logo_sent;   /*  logo sent */
+       u32        logo_accepts;        /*  logo accepts */
+       u32        logo_rejects;        /*  logo rejects */
+       u32        logo_rsp_err;        /*  logo rsp errors */
+       u32        logo_unknown_rsp;
+                       /*  logo rsp unknown errors */
+
+       u32        fab_no_npiv; /*  fabric does not support npiv */
+
+       u32        fab_offline; /*  offline events from fab SM */
+       u32        fab_online;  /*  online events from fab SM */
+       u32        fab_cleanup; /*  cleanup request from fab SM */
+       u32        rsvd;
+};
+
+/**
+ * BFA vport attribute returned in queries
+ */
+struct bfa_vport_attr_s {
+       struct bfa_lport_attr_s   port_attr; /*  base class (port) attributes */
+       enum bfa_vport_state vport_state; /*  vport state */
+       u32          rsvd;
+};
+
+/**
+ * FCS remote port states
+ */
+enum bfa_rport_state {
+       BFA_RPORT_UNINIT        = 0,    /*  PORT is not yet initialized */
+       BFA_RPORT_OFFLINE       = 1,    /*  rport is offline */
+       BFA_RPORT_PLOGI         = 2,    /*  PLOGI to rport is in progress */
+       BFA_RPORT_ONLINE        = 3,    /*  login to rport is complete */
+       BFA_RPORT_PLOGI_RETRY   = 4,    /*  retrying login to rport */
+       BFA_RPORT_NSQUERY       = 5,    /*  nameserver query */
+       BFA_RPORT_ADISC         = 6,    /*  ADISC authentication */
+       BFA_RPORT_LOGO          = 7,    /*  logging out with rport */
+       BFA_RPORT_LOGORCV       = 8,    /*  handling LOGO from rport */
+       BFA_RPORT_NSDISC        = 9,    /*  re-discover rport */
+};
+
+/**
+ *  Rport Scsi Function : Initiator/Target.
+ */
+enum bfa_rport_function {
+       BFA_RPORT_INITIATOR     = 0x01, /*  SCSI Initiator      */
+       BFA_RPORT_TARGET        = 0x02, /*  SCSI Target */
+};
+
+/**
+ * port/node symbolic names for rport
+ */
+#define BFA_RPORT_SYMNAME_MAXLEN       255
+struct bfa_rport_symname_s {
+       char            symname[BFA_RPORT_SYMNAME_MAXLEN];
+};
+
+/**
+ * FCS remote port statistics
+ */
+struct bfa_rport_stats_s {
+       u32        offlines;           /*  remote port offline count  */
+       u32        onlines;            /*  remote port online count   */
+       u32        rscns;              /*  RSCN affecting rport       */
+       u32        plogis;                  /*  plogis sent                */
+       u32        plogi_accs;      /*  plogi accepts              */
+       u32        plogi_timeouts;          /*  plogi timeouts             */
+       u32        plogi_rejects;           /*  rcvd plogi rejects         */
+       u32        plogi_failed;            /*  local failure              */
+       u32        plogi_rcvd;      /*  plogis rcvd                */
+       u32        prli_rcvd;          /*  inbound PRLIs              */
+       u32        adisc_rcvd;         /*  ADISCs received            */
+       u32        adisc_rejects;      /*  recvd  ADISC rejects       */
+       u32        adisc_sent;         /*  ADISC requests sent        */
+       u32        adisc_accs;         /*  ADISC accepted by rport    */
+       u32        adisc_failed;       /*  ADISC failed (no response) */
+       u32        adisc_rejected;     /*  ADISC rejected by us    */
+       u32        logos;              /*  logos sent                 */
+       u32        logo_accs;          /*  LOGO accepts from rport    */
+       u32        logo_failed;        /*  LOGO failures              */
+       u32        logo_rejected;      /*  LOGO rejects from rport    */
+       u32        logo_rcvd;          /*  LOGO from remote port      */
+
+       u32        rpsc_rcvd;         /*  RPSC received            */
+       u32        rpsc_rejects;      /*  recvd  RPSC rejects       */
+       u32        rpsc_sent;         /*  RPSC requests sent        */
+       u32        rpsc_accs;         /*  RPSC accepted by rport    */
+       u32        rpsc_failed;       /*  RPSC failed (no response) */
+       u32        rpsc_rejected;     /*  RPSC rejected by us    */
+
+       u32     rjt_insuff_res; /*  LS RJT with insuff resources */
+       struct bfa_rport_hal_stats_s    hal_stats;  /*  BFA rport stats    */
+};
+
+/**
+ * FCS remote port attributes returned in queries
+ */
+struct bfa_rport_attr_s {
+       wwn_t           nwwn;   /*  node wwn */
+       wwn_t           pwwn;   /*  port wwn */
+       enum fc_cos cos_supported;      /*  supported class of services */
+       u32             pid;    /*  port ID */
+       u32             df_sz;  /*  Max payload size */
+       enum bfa_rport_state    state;  /*  Rport State machine state */
+       enum fc_cos     fc_cos; /*  FC classes of services */
+       bfa_boolean_t   cisc;   /*  CISC capable device */
+       struct bfa_rport_symname_s symname; /*  Symbolic Name */
+       enum bfa_rport_function scsi_function; /*  Initiator/Target */
+       struct bfa_rport_qos_attr_s qos_attr; /*  qos attributes  */
+       enum bfa_port_speed curr_speed;   /*  operating speed got from
+                                           * RPSC ELS. UNKNOWN, if RPSC
+                                           * is not supported */
+       bfa_boolean_t   trl_enforced;   /*  TRL enforced ? TRUE/FALSE */
+       enum bfa_port_speed     assigned_speed; /* Speed assigned by the user.
+                                                * will be used if RPSC is not
+                                                * supported by the rport */
+};
+
+struct bfa_rport_remote_link_stats_s {
+       u32 lfc; /*  Link Failure Count */
+       u32 lsyc; /*  Loss of Synchronization Count */
+       u32 lsic; /*  Loss of Signal Count */
+       u32 pspec; /*  Primitive Sequence Protocol Error Count */
+       u32 itwc; /*  Invalid Transmission Word Count */
+       u32 icc; /*  Invalid CRC Count */
+};
+
+
+#define BFA_MAX_IO_INDEX 7
+#define BFA_NO_IO_INDEX 9
+
+/**
+ * FCS itnim states
+ */
+enum bfa_itnim_state {
+       BFA_ITNIM_OFFLINE       = 0,    /*  offline */
+       BFA_ITNIM_PRLI_SEND     = 1,    /*  prli send */
+       BFA_ITNIM_PRLI_SENT     = 2,    /*  prli sent */
+       BFA_ITNIM_PRLI_RETRY    = 3,    /*  prli retry */
+       BFA_ITNIM_HCB_ONLINE    = 4,    /*  online callback */
+       BFA_ITNIM_ONLINE        = 5,    /*  online */
+       BFA_ITNIM_HCB_OFFLINE   = 6,    /*  offline callback */
+       BFA_ITNIM_INITIATIOR    = 7,    /*  initiator */
+};
+
+/**
+ * FCS remote port statistics
+ */
+struct bfa_itnim_stats_s {
+       u32        onlines;     /*  num rport online */
+       u32        offlines;    /*  num rport offline */
+       u32        prli_sent;   /*  num prli sent out */
+       u32        fcxp_alloc_wait;/*  num fcxp alloc waits */
+       u32        prli_rsp_err;        /*  num prli rsp errors */
+       u32        prli_rsp_acc;        /*  num prli rsp accepts */
+       u32        initiator;   /*  rport is an initiator */
+       u32        prli_rsp_parse_err;  /*  prli rsp parsing errors */
+       u32        prli_rsp_rjt;        /*  num prli rsp rejects */
+       u32        timeout;     /*  num timeouts detected */
+       u32        sler;                /*  num sler notification from BFA */
+       u32     rsvd;           /* padding for 64 bit alignment */
+};
+
+/**
+ * FCS itnim attributes returned in queries
+ */
+struct bfa_itnim_attr_s {
+       enum bfa_itnim_state state; /*  FCS itnim state        */
+       u8 retry;               /*  data retransmision support */
+       u8      task_retry_id;  /*  task retry ident support   */
+       u8 rec_support;    /*  REC supported              */
+       u8 conf_comp;      /*  confirmed completion supp  */
+};
+
+#endif /* __BFA_DEFS_FCS_H__ */
diff --git a/drivers/scsi/bfa/bfa_defs_svc.h b/drivers/scsi/bfa/bfa_defs_svc.h
new file mode 100644 (file)
index 0000000..56226fc
--- /dev/null
@@ -0,0 +1,1081 @@
+/*
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
+ * All rights reserved
+ * www.brocade.com
+ *
+ * Linux driver for Brocade Fibre Channel Host Bus Adapter.
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License (GPL) Version 2 as
+ * published by the Free Software Foundation
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * General Public License for more details.
+ */
+
+#ifndef __BFA_DEFS_SVC_H__
+#define __BFA_DEFS_SVC_H__
+
+#include "bfa_defs.h"
+#include "bfa_fc.h"
+#include "bfi.h"
+
+#define BFA_IOCFC_INTR_DELAY   1125
+#define BFA_IOCFC_INTR_LATENCY 225
+#define BFA_IOCFCOE_INTR_DELAY 25
+#define BFA_IOCFCOE_INTR_LATENCY 5
+
+/**
+ * Interrupt coalescing configuration.
+ */
+#pragma pack(1)
+struct bfa_iocfc_intr_attr_s {
+       u8              coalesce;       /*  enable/disable coalescing */
+       u8              rsvd[3];
+       u16     latency;        /*  latency in microseconds   */
+       u16     delay;          /*  delay in microseconds     */
+};
+
+/**
+ * IOC firmware configuraton
+ */
+struct bfa_iocfc_fwcfg_s {
+       u16        num_fabrics; /*  number of fabrics           */
+       u16        num_lports;  /*  number of local lports      */
+       u16        num_rports;  /*  number of remote ports      */
+       u16        num_ioim_reqs;       /*  number of IO reqs           */
+       u16        num_tskim_reqs;      /*  task management requests    */
+       u16        num_iotm_reqs;       /*  number of TM IO reqs        */
+       u16        num_tsktm_reqs;      /*  TM task management requests*/
+       u16        num_fcxp_reqs;       /*  unassisted FC exchanges     */
+       u16        num_uf_bufs; /*  unsolicited recv buffers    */
+       u8              num_cqs;
+       u8              fw_tick_res;    /*  FW clock resolution in ms */
+       u8              rsvd[4];
+};
+#pragma pack()
+
+struct bfa_iocfc_drvcfg_s {
+       u16        num_reqq_elems;      /*  number of req queue elements */
+       u16        num_rspq_elems;      /*  number of rsp queue elements */
+       u16        num_sgpgs;   /*  number of total SG pages      */
+       u16        num_sboot_tgts;      /*  number of SAN boot targets    */
+       u16        num_sboot_luns;      /*  number of SAN boot luns       */
+       u16         ioc_recover;        /*  IOC recovery mode             */
+       u16         min_cfg;    /*  minimum configuration         */
+       u16        path_tov;    /*  device path timeout   */
+       bfa_boolean_t   delay_comp; /*  delay completion of
+                                                       failed inflight IOs */
+       u32             rsvd;
+};
+
+/**
+ * IOC configuration
+ */
+struct bfa_iocfc_cfg_s {
+       struct bfa_iocfc_fwcfg_s        fwcfg;  /*  firmware side config */
+       struct bfa_iocfc_drvcfg_s       drvcfg; /*  driver side config    */
+};
+
+/**
+ * IOC firmware IO stats
+ */
+struct bfa_fw_io_stats_s {
+       u32     host_abort;             /*  IO aborted by host driver*/
+       u32     host_cleanup;           /*  IO clean up by host driver */
+
+       u32     fw_io_timeout;          /*  IOs timedout */
+       u32     fw_frm_parse;           /*  frame parsed by f/w */
+       u32     fw_frm_data;            /*  fcp_data frame parsed by f/w */
+       u32     fw_frm_rsp;             /*  fcp_rsp frame parsed by f/w */
+       u32     fw_frm_xfer_rdy;        /*  xfer_rdy frame parsed by f/w */
+       u32     fw_frm_bls_acc;         /*  BLS ACC  frame parsed by f/w */
+       u32     fw_frm_tgt_abort;       /*  target ABTS parsed by f/w */
+       u32     fw_frm_unknown;         /*  unknown parsed by f/w */
+       u32     fw_data_dma;            /*  f/w DMA'ed the data frame */
+       u32     fw_frm_drop;            /*  f/w drop the frame */
+
+       u32     rec_timeout;            /*  FW rec timed out */
+       u32     error_rec;                      /*  FW sending rec on
+                                                       * an error condition*/
+       u32     wait_for_si;            /*  FW wait for SI */
+       u32     rec_rsp_inval;          /*  REC rsp invalid */
+       u32     seqr_io_abort;          /*  target does not know cmd so abort */
+       u32     seqr_io_retry;          /*  SEQR failed so retry IO */
+
+       u32     itn_cisc_upd_rsp;       /*  ITN cisc updated on fcp_rsp */
+       u32     itn_cisc_upd_data;      /*  ITN cisc updated on fcp_data */
+       u32     itn_cisc_upd_xfer_rdy;  /*  ITN cisc updated on fcp_data */
+
+       u32     fcp_data_lost;          /*  fcp data lost */
+
+       u32     ro_set_in_xfer_rdy;     /*  Target set RO in Xfer_rdy frame */
+       u32     xfer_rdy_ooo_err;       /*  Out of order Xfer_rdy received */
+       u32     xfer_rdy_unknown_err;   /*  unknown error in xfer_rdy frame */
+
+       u32     io_abort_timeout;       /*  ABTS timedout  */
+       u32     sler_initiated;         /*  SLER initiated */
+
+       u32     unexp_fcp_rsp;          /*  fcp response in wrong state */
+
+       u32     fcp_rsp_under_run;      /*  fcp rsp IO underrun */
+       u32        fcp_rsp_under_run_wr;   /*  fcp rsp IO underrun for write */
+       u32     fcp_rsp_under_run_err;  /*  fcp rsp IO underrun error */
+       u32        fcp_rsp_resid_inval;    /*  invalid residue */
+       u32     fcp_rsp_over_run;       /*  fcp rsp IO overrun */
+       u32     fcp_rsp_over_run_err;   /*  fcp rsp IO overrun error */
+       u32     fcp_rsp_proto_err;      /*  protocol error in fcp rsp */
+       u32     fcp_rsp_sense_err;      /*  error in sense info in fcp rsp */
+       u32     fcp_conf_req;           /*  FCP conf requested */
+
+       u32     tgt_aborted_io;         /*  target initiated abort */
+
+       u32     ioh_edtov_timeout_event;/*  IOH edtov timer popped */
+       u32     ioh_fcp_rsp_excp_event; /*  IOH FCP_RSP exception */
+       u32     ioh_fcp_conf_event;     /*  IOH FCP_CONF */
+       u32     ioh_mult_frm_rsp_event; /*  IOH multi_frame FCP_RSP */
+       u32     ioh_hit_class2_event;   /*  IOH hit class2 */
+       u32     ioh_miss_other_event;   /*  IOH miss other */
+       u32     ioh_seq_cnt_err_event;  /*  IOH seq cnt error */
+       u32     ioh_len_err_event;              /*  IOH len error - fcp_dl !=
+                                                       * bytes xfered */
+       u32     ioh_seq_len_err_event;  /*  IOH seq len error */
+       u32     ioh_data_oor_event;     /*  Data out of range */
+       u32     ioh_ro_ooo_event;       /*  Relative offset out of range */
+       u32     ioh_cpu_owned_event;    /*  IOH hit -iost owned by f/w */
+       u32     ioh_unexp_frame_event;  /*  unexpected frame recieved
+                                                *   count */
+       u32     ioh_err_int;            /*  IOH error int during data-phase
+                                                *   for scsi write
+                                                */
+};
+
+/**
+ * IOC port firmware stats
+ */
+
+struct bfa_fw_port_fpg_stats_s {
+    u32    intr_evt;
+    u32    intr;
+    u32    intr_excess;
+    u32    intr_cause0;
+    u32    intr_other;
+    u32    intr_other_ign;
+    u32    sig_lost;
+    u32    sig_regained;
+    u32    sync_lost;
+    u32    sync_to;
+    u32    sync_regained;
+    u32    div2_overflow;
+    u32    div2_underflow;
+    u32    efifo_overflow;
+    u32    efifo_underflow;
+    u32    idle_rx;
+    u32    lrr_rx;
+    u32    lr_rx;
+    u32    ols_rx;
+    u32    nos_rx;
+    u32    lip_rx;
+    u32    arbf0_rx;
+    u32    arb_rx;
+    u32    mrk_rx;
+    u32    const_mrk_rx;
+    u32    prim_unknown;
+};
+
+
+struct bfa_fw_port_lksm_stats_s {
+    u32    hwsm_success;       /*  hwsm state machine success          */
+    u32    hwsm_fails;         /*  hwsm fails                          */
+    u32    hwsm_wdtov;         /*  hwsm timed out                      */
+    u32    swsm_success;       /*  swsm success                        */
+    u32    swsm_fails;         /*  swsm fails                          */
+    u32    swsm_wdtov;         /*  swsm timed out                      */
+    u32    busybufs;           /*  link init failed due to busybuf     */
+    u32    buf_waits;          /*  bufwait state entries               */
+    u32    link_fails;         /*  link failures                       */
+    u32    psp_errors;         /*  primitive sequence protocol errors  */
+    u32    lr_unexp;           /*  No. of times LR rx-ed unexpectedly  */
+    u32    lrr_unexp;          /*  No. of times LRR rx-ed unexpectedly */
+    u32    lr_tx;              /*  No. of times LR tx started          */
+    u32    lrr_tx;             /*  No. of times LRR tx started         */
+    u32    ols_tx;             /*  No. of times OLS tx started         */
+    u32    nos_tx;             /*  No. of times NOS tx started         */
+    u32    hwsm_lrr_rx;        /*  No. of times LRR rx-ed by HWSM      */
+    u32    hwsm_lr_rx;         /*  No. of times LR rx-ed by HWSM      */
+};
+
+struct bfa_fw_port_snsm_stats_s {
+    u32    hwsm_success;       /*  Successful hwsm terminations        */
+    u32    hwsm_fails;         /*  hwsm fail count                     */
+    u32    hwsm_wdtov;         /*  hwsm timed out                      */
+    u32    swsm_success;       /*  swsm success                        */
+    u32    swsm_wdtov;         /*  swsm timed out                      */
+    u32    error_resets;       /*  error resets initiated by upsm      */
+    u32    sync_lost;          /*  Sync loss count                     */
+    u32    sig_lost;           /*  Signal loss count                   */
+};
+
+struct bfa_fw_port_physm_stats_s {
+    u32    module_inserts;     /*  Module insert count                 */
+    u32    module_xtracts;     /*  Module extracts count               */
+    u32    module_invalids;    /*  Invalid module inserted count       */
+    u32    module_read_ign;    /*  Module validation status ignored    */
+    u32    laser_faults;       /*  Laser fault count                   */
+    u32    rsvd;
+};
+
+struct bfa_fw_fip_stats_s {
+    u32    vlan_req;           /*  vlan discovery requests             */
+    u32    vlan_notify;        /*  vlan notifications                  */
+    u32    vlan_err;           /*  vlan response error                 */
+    u32    vlan_timeouts;      /*  vlan disvoery timeouts              */
+    u32    vlan_invalids;      /*  invalid vlan in discovery advert.   */
+    u32    disc_req;           /*  Discovery solicit requests          */
+    u32    disc_rsp;           /*  Discovery solicit response          */
+    u32    disc_err;           /*  Discovery advt. parse errors        */
+    u32    disc_unsol;         /*  Discovery unsolicited               */
+    u32    disc_timeouts;      /*  Discovery timeouts                  */
+    u32    disc_fcf_unavail;   /*  Discovery FCF Not Avail.            */
+    u32    linksvc_unsupp;     /*  Unsupported link service req        */
+    u32    linksvc_err;        /*  Parse error in link service req     */
+    u32    logo_req;           /*  FIP logos received                  */
+    u32    clrvlink_req;       /*  Clear virtual link req              */
+    u32    op_unsupp;          /*  Unsupported FIP operation           */
+    u32    untagged;           /*  Untagged frames (ignored)           */
+    u32    invalid_version;    /*  Invalid FIP version                 */
+};
+
+struct bfa_fw_lps_stats_s {
+    u32    mac_invalids;       /*  Invalid mac assigned                */
+    u32    rsvd;
+};
+
+struct bfa_fw_fcoe_stats_s {
+    u32    cee_linkups;        /*  CEE link up count                   */
+    u32    cee_linkdns;        /*  CEE link down count                 */
+    u32    fip_linkups;        /*  FIP link up count                   */
+    u32    fip_linkdns;        /*  FIP link up count                   */
+    u32    fip_fails;          /*  FIP fail count                      */
+    u32    mac_invalids;       /*  Invalid mac assigned                */
+};
+
+/**
+ * IOC firmware FCoE port stats
+ */
+struct bfa_fw_fcoe_port_stats_s {
+    struct bfa_fw_fcoe_stats_s  fcoe_stats;
+    struct bfa_fw_fip_stats_s   fip_stats;
+};
+
+/**
+ * IOC firmware FC uport stats
+ */
+struct bfa_fw_fc_uport_stats_s {
+       struct bfa_fw_port_snsm_stats_s         snsm_stats;
+       struct bfa_fw_port_lksm_stats_s         lksm_stats;
+};
+
+/**
+ * IOC firmware FC port stats
+ */
+union bfa_fw_fc_port_stats_s {
+       struct bfa_fw_fc_uport_stats_s  fc_stats;
+       struct bfa_fw_fcoe_port_stats_s fcoe_stats;
+};
+
+/**
+ * IOC firmware port stats
+ */
+struct bfa_fw_port_stats_s {
+       struct bfa_fw_port_fpg_stats_s          fpg_stats;
+       struct bfa_fw_port_physm_stats_s        physm_stats;
+       union  bfa_fw_fc_port_stats_s           fc_port;
+};
+
+/**
+ * fcxchg module statistics
+ */
+struct bfa_fw_fcxchg_stats_s {
+       u32     ua_tag_inv;
+       u32     ua_state_inv;
+};
+
+struct bfa_fw_lpsm_stats_s {
+       u32     cls_rx;
+       u32     cls_tx;
+};
+
+/**
+ *  Trunk statistics
+ */
+struct bfa_fw_trunk_stats_s {
+       u32 emt_recvd;          /*  Trunk EMT received          */
+       u32 emt_accepted;               /*  Trunk EMT Accepted          */
+       u32 emt_rejected;               /*  Trunk EMT rejected          */
+       u32 etp_recvd;          /*  Trunk ETP received          */
+       u32 etp_accepted;               /*  Trunk ETP Accepted          */
+       u32 etp_rejected;               /*  Trunk ETP rejected          */
+       u32 lr_recvd;           /*  Trunk LR received           */
+       u32 rsvd;                       /*  padding for 64 bit alignment */
+};
+
+struct bfa_fw_advsm_stats_s {
+       u32 flogi_sent;         /*  Flogi sent                  */
+       u32 flogi_acc_recvd;    /*  Flogi Acc received          */
+       u32 flogi_rjt_recvd;    /*  Flogi rejects received      */
+       u32 flogi_retries;              /*  Flogi retries               */
+
+       u32 elp_recvd;          /*  ELP received                */
+       u32 elp_accepted;               /*  ELP Accepted                */
+       u32 elp_rejected;               /*  ELP rejected                */
+       u32 elp_dropped;                /*  ELP dropped         */
+};
+
+/**
+ * IOCFC firmware stats
+ */
+struct bfa_fw_iocfc_stats_s {
+       u32     cfg_reqs;       /*  cfg request */
+       u32     updq_reqs;      /*  update queue request */
+       u32     ic_reqs;        /*  interrupt coalesce reqs */
+       u32     unknown_reqs;
+       u32     set_intr_reqs;  /*  set interrupt reqs */
+};
+
+/**
+ * IOC attributes returned in queries
+ */
+struct bfa_iocfc_attr_s {
+       struct bfa_iocfc_cfg_s          config;         /*  IOCFC config   */
+       struct bfa_iocfc_intr_attr_s    intr_attr;      /*  interrupt attr */
+};
+
+/**
+ * Eth_sndrcv mod stats
+ */
+struct bfa_fw_eth_sndrcv_stats_s {
+       u32     crc_err;
+       u32     rsvd;           /*  64bit align    */
+};
+
+/**
+ * CT MAC mod stats
+ */
+struct bfa_fw_mac_mod_stats_s {
+       u32     mac_on;         /*  MAC got turned-on */
+       u32     link_up;        /*  link-up */
+       u32     signal_off;     /*  lost signal */
+       u32     dfe_on;         /*  DFE on */
+       u32     mac_reset;      /*  # of MAC reset to bring lnk up */
+       u32     pcs_reset;      /*  # of PCS reset to bring lnk up */
+       u32     loopback;       /*  MAC got into serdes loopback */
+       u32     lb_mac_reset;
+                       /*  # of MAC reset to bring link up in loopback */
+       u32     lb_pcs_reset;
+                       /*  # of PCS reset to bring link up in loopback */
+       u32     rsvd;           /*  64bit align    */
+};
+
+/**
+ * CT MOD stats
+ */
+struct bfa_fw_ct_mod_stats_s {
+       u32     rxa_rds_undrun; /*  RxA RDS underrun */
+       u32     rad_bpc_ovfl;   /*  RAD BPC overflow */
+       u32     rad_rlb_bpc_ovfl; /*  RAD RLB BPC overflow */
+       u32     bpc_fcs_err;    /*  BPC FCS_ERR */
+       u32     txa_tso_hdr;    /*  TxA TSO header too long */
+       u32     rsvd;           /*  64bit align    */
+};
+
+/**
+ * IOC firmware stats
+ */
+struct bfa_fw_stats_s {
+       struct bfa_fw_ioc_stats_s       ioc_stats;
+       struct bfa_fw_iocfc_stats_s     iocfc_stats;
+       struct bfa_fw_io_stats_s        io_stats;
+       struct bfa_fw_port_stats_s      port_stats;
+       struct bfa_fw_fcxchg_stats_s    fcxchg_stats;
+       struct bfa_fw_lpsm_stats_s      lpsm_stats;
+       struct bfa_fw_lps_stats_s       lps_stats;
+       struct bfa_fw_trunk_stats_s     trunk_stats;
+       struct bfa_fw_advsm_stats_s     advsm_stats;
+       struct bfa_fw_mac_mod_stats_s   macmod_stats;
+       struct bfa_fw_ct_mod_stats_s    ctmod_stats;
+       struct bfa_fw_eth_sndrcv_stats_s        ethsndrcv_stats;
+};
+
+#define BFA_IOCFC_PATHTOV_MAX  60
+#define BFA_IOCFC_QDEPTH_MAX   2000
+
+/**
+ * QoS states
+ */
+enum bfa_qos_state {
+       BFA_QOS_ONLINE = 1,             /*  QoS is online */
+       BFA_QOS_OFFLINE = 2,            /*  QoS is offline */
+};
+
+/**
+ * QoS  Priority levels.
+ */
+enum bfa_qos_priority {
+       BFA_QOS_UNKNOWN = 0,
+       BFA_QOS_HIGH  = 1,      /*  QoS Priority Level High */
+       BFA_QOS_MED  =  2,      /*  QoS Priority Level Medium */
+       BFA_QOS_LOW  =  3,      /*  QoS Priority Level Low */
+};
+
+/**
+ * QoS  bandwidth allocation for each priority level
+ */
+enum bfa_qos_bw_alloc {
+       BFA_QOS_BW_HIGH  = 60,  /*  bandwidth allocation for High */
+       BFA_QOS_BW_MED  =  30,  /*  bandwidth allocation for Medium */
+       BFA_QOS_BW_LOW  =  10,  /*  bandwidth allocation for Low */
+};
+#pragma pack(1)
+/**
+ * QoS attribute returned in QoS Query
+ */
+struct bfa_qos_attr_s {
+       u8              state;          /*  QoS current state */
+       u8              rsvd[3];
+       u32  total_bb_cr;               /*  Total BB Credits */
+};
+
+/**
+ * These fields should be displayed only from the CLI.
+ * There will be a separate BFAL API (get_qos_vc_attr ?)
+ * to retrieve this.
+ *
+ */
+#define  BFA_QOS_MAX_VC  16
+
+struct bfa_qos_vc_info_s {
+       u8 vc_credit;
+       u8 borrow_credit;
+       u8 priority;
+       u8 resvd;
+};
+
+struct bfa_qos_vc_attr_s {
+       u16  total_vc_count;                    /*  Total VC Count */
+       u16  shared_credit;
+       u32  elp_opmode_flags;
+       struct bfa_qos_vc_info_s vc_info[BFA_QOS_MAX_VC];  /*   as many as
+                                                           * total_vc_count */
+};
+
+/**
+ * QoS statistics
+ */
+struct bfa_qos_stats_s {
+       u32     flogi_sent;             /*  QoS Flogi sent */
+       u32     flogi_acc_recvd;        /*  QoS Flogi Acc received */
+       u32     flogi_rjt_recvd; /*  QoS Flogi rejects received */
+       u32     flogi_retries;          /*  QoS Flogi retries */
+
+       u32     elp_recvd;              /*  QoS ELP received */
+       u32     elp_accepted;           /*  QoS ELP Accepted */
+       u32     elp_rejected;       /*  QoS ELP rejected */
+       u32     elp_dropped;        /*  QoS ELP dropped  */
+
+       u32     qos_rscn_recvd;     /*  QoS RSCN received */
+       u32     rsvd;               /* padding for 64 bit alignment */
+};
+
+/**
+ * FCoE statistics
+ */
+struct bfa_fcoe_stats_s {
+       u64     secs_reset;     /*  Seconds since stats reset        */
+       u64     cee_linkups;    /*  CEE link up              */
+       u64     cee_linkdns;    /*  CEE link down                    */
+       u64     fip_linkups;    /*  FIP link up              */
+       u64     fip_linkdns;    /*  FIP link down                    */
+       u64     fip_fails;      /*  FIP failures                     */
+       u64     mac_invalids;   /*  Invalid mac assignments          */
+       u64     vlan_req;       /*  Vlan requests                    */
+       u64     vlan_notify;    /*  Vlan notifications               */
+       u64     vlan_err;       /*  Vlan notification errors         */
+       u64     vlan_timeouts;  /*  Vlan request timeouts            */
+       u64     vlan_invalids;  /*  Vlan invalids                    */
+       u64     disc_req;       /*  Discovery requests               */
+       u64     disc_rsp;       /*  Discovery responses      */
+       u64     disc_err;       /*  Discovery error frames           */
+       u64     disc_unsol;     /*  Discovery unsolicited            */
+       u64     disc_timeouts;  /*  Discovery timeouts               */
+       u64     disc_fcf_unavail; /*  Discovery FCF not avail        */
+       u64     linksvc_unsupp; /*  FIP link service req unsupp.    */
+       u64     linksvc_err;    /*  FIP link service req errors     */
+       u64     logo_req;       /*  FIP logos received               */
+       u64     clrvlink_req;   /*  Clear virtual link requests     */
+       u64     op_unsupp;      /*  FIP operation unsupp.            */
+       u64     untagged;       /*  FIP untagged frames      */
+       u64     txf_ucast;      /*  Tx FCoE unicast frames           */
+       u64     txf_ucast_vlan; /*  Tx FCoE unicast vlan frames     */
+       u64     txf_ucast_octets; /*  Tx FCoE unicast octets         */
+       u64     txf_mcast;      /*  Tx FCoE multicast frames         */
+       u64     txf_mcast_vlan; /*  Tx FCoE multicast vlan frames   */
+       u64     txf_mcast_octets; /*  Tx FCoE multicast octets       */
+       u64     txf_bcast;      /*  Tx FCoE broadcast frames         */
+       u64     txf_bcast_vlan; /*  Tx FCoE broadcast vlan frames   */
+       u64     txf_bcast_octets; /*  Tx FCoE broadcast octets       */
+       u64     txf_timeout;    /*  Tx timeouts              */
+       u64     txf_parity_errors; /*  Transmit parity err           */
+       u64     txf_fid_parity_errors; /*  Transmit FID parity err  */
+       u64     rxf_ucast_octets; /*  Rx FCoE unicast octets         */
+       u64     rxf_ucast;      /*  Rx FCoE unicast frames           */
+       u64     rxf_ucast_vlan; /*  Rx FCoE unicast vlan frames     */
+       u64     rxf_mcast_octets; /*  Rx FCoE multicast octets       */
+       u64     rxf_mcast;      /*  Rx FCoE multicast frames         */
+       u64     rxf_mcast_vlan; /*  Rx FCoE multicast vlan frames   */
+       u64     rxf_bcast_octets; /*  Rx FCoE broadcast octets       */
+       u64     rxf_bcast;      /*  Rx FCoE broadcast frames         */
+       u64     rxf_bcast_vlan; /*  Rx FCoE broadcast vlan frames   */
+};
+
+/**
+ * QoS or FCoE stats (fcport stats excluding physical FC port stats)
+ */
+union bfa_fcport_stats_u {
+       struct bfa_qos_stats_s  fcqos;
+       struct bfa_fcoe_stats_s fcoe;
+};
+#pragma pack()
+
+struct bfa_fcpim_del_itn_stats_s {
+       u32     del_itn_iocomp_aborted;    /* Aborted IO requests             */
+       u32     del_itn_iocomp_timedout;   /* IO timeouts                     */
+       u32     del_itn_iocom_sqer_needed; /* IO retry for SQ error recovery  */
+       u32     del_itn_iocom_res_free;    /* Delayed freeing of IO resources */
+       u32     del_itn_iocom_hostabrts;   /* Host IO abort requests          */
+       u32     del_itn_total_ios;         /* Total IO count                  */
+       u32     del_io_iocdowns;           /* IO cleaned-up due to IOC down   */
+       u32     del_tm_iocdowns;           /* TM cleaned-up due to IOC down   */
+};
+
+struct bfa_itnim_iostats_s {
+
+       u32     total_ios;              /*  Total IO Requests           */
+       u32     input_reqs;             /*  Data in-bound requests      */
+       u32     output_reqs;            /*  Data out-bound requests     */
+       u32     io_comps;               /*  Total IO Completions        */
+       u32     wr_throughput;          /*  Write data transfered in bytes */
+       u32     rd_throughput;          /*  Read data transfered in bytes  */
+
+       u32     iocomp_ok;              /*  Slowpath IO completions     */
+       u32     iocomp_underrun;        /*  IO underrun         */
+       u32     iocomp_overrun;         /*  IO overrun                  */
+       u32     qwait;                  /*  IO Request-Q wait           */
+       u32     qresumes;               /*  IO Request-Q wait done      */
+       u32     no_iotags;              /*  No free IO tag              */
+       u32     iocomp_timedout;        /*  IO timeouts         */
+       u32     iocom_nexus_abort;      /*  IO failure due to target offline */
+       u32     iocom_proto_err;        /*  IO protocol errors          */
+       u32     iocom_dif_err;          /*  IO SBC-3 protection errors  */
+
+       u32     iocom_sqer_needed;      /*  fcp-2 error recovery failed */
+       u32     iocom_res_free;         /*  Delayed freeing of IO tag   */
+
+
+       u32     io_aborts;              /*  Host IO abort requests      */
+       u32     iocom_hostabrts;        /*  Host IO abort completions   */
+       u32     io_cleanups;            /*  IO clean-up requests        */
+       u32     path_tov_expired;       /*  IO path tov expired */
+       u32     iocomp_aborted;         /*  IO abort completions        */
+       u32     io_iocdowns;            /*  IO cleaned-up due to IOC down */
+       u32     iocom_utags;            /*  IO comp with unknown tags   */
+
+       u32     io_tmaborts;            /*  Abort request due to TM command */
+       u32     tm_io_comps;            /* Abort completion due to TM command */
+
+       u32     creates;                /*  IT Nexus create requests    */
+       u32     fw_create;              /*  IT Nexus FW create requests */
+       u32     create_comps;           /*  IT Nexus FW create completions */
+       u32     onlines;                /*  IT Nexus onlines            */
+       u32     offlines;               /*  IT Nexus offlines           */
+       u32     fw_delete;              /*  IT Nexus FW delete requests */
+       u32     delete_comps;           /*  IT Nexus FW delete completions */
+       u32     deletes;                /*  IT Nexus delete requests       */
+       u32     sler_events;            /*  SLER events         */
+       u32     ioc_disabled;           /*  Num IOC disables            */
+       u32     cleanup_comps;          /*  IT Nexus cleanup completions    */
+
+       u32     tm_cmnds;               /*  TM Requests         */
+       u32     tm_fw_rsps;             /*  TM Completions              */
+       u32     tm_success;             /*  TM initiated IO cleanup success */
+       u32     tm_failures;            /*  TM initiated IO cleanup failure */
+       u32     no_tskims;              /*  No free TM tag              */
+       u32     tm_qwait;               /*  TM Request-Q wait           */
+       u32     tm_qresumes;            /*  TM Request-Q wait done      */
+
+       u32     tm_iocdowns;            /*  TM cleaned-up due to IOC down   */
+       u32     tm_cleanups;            /*  TM cleanup requests */
+       u32     tm_cleanup_comps;       /*  TM cleanup completions      */
+};
+
+/* Modify char* port_stt[] in bfal_port.c if a new state was added */
+enum bfa_port_states {
+       BFA_PORT_ST_UNINIT              = 1,
+       BFA_PORT_ST_ENABLING_QWAIT      = 2,
+       BFA_PORT_ST_ENABLING            = 3,
+       BFA_PORT_ST_LINKDOWN            = 4,
+       BFA_PORT_ST_LINKUP              = 5,
+       BFA_PORT_ST_DISABLING_QWAIT     = 6,
+       BFA_PORT_ST_DISABLING           = 7,
+       BFA_PORT_ST_DISABLED            = 8,
+       BFA_PORT_ST_STOPPED             = 9,
+       BFA_PORT_ST_IOCDOWN             = 10,
+       BFA_PORT_ST_IOCDIS              = 11,
+       BFA_PORT_ST_FWMISMATCH          = 12,
+       BFA_PORT_ST_PREBOOT_DISABLED    = 13,
+       BFA_PORT_ST_TOGGLING_QWAIT      = 14,
+       BFA_PORT_ST_MAX_STATE,
+};
+
+/**
+ *     Port operational type (in sync with SNIA port type).
+ */
+enum bfa_port_type {
+       BFA_PORT_TYPE_UNKNOWN   = 1,    /*  port type is unknown */
+       BFA_PORT_TYPE_NPORT     = 5,    /*  P2P with switched fabric */
+       BFA_PORT_TYPE_NLPORT    = 6,    /*  public loop */
+       BFA_PORT_TYPE_LPORT     = 20,   /*  private loop */
+       BFA_PORT_TYPE_P2P       = 21,   /*  P2P with no switched fabric */
+       BFA_PORT_TYPE_VPORT     = 22,   /*  NPIV - virtual port */
+};
+
+/**
+ *     Port topology setting. A port's topology and fabric login status
+ *     determine its operational type.
+ */
+enum bfa_port_topology {
+       BFA_PORT_TOPOLOGY_NONE = 0,     /*  No valid topology */
+       BFA_PORT_TOPOLOGY_P2P  = 1,     /*  P2P only */
+       BFA_PORT_TOPOLOGY_LOOP = 2,     /*  LOOP topology */
+       BFA_PORT_TOPOLOGY_AUTO = 3,     /*  auto topology selection */
+};
+
+/**
+ *     Physical port loopback types.
+ */
+enum bfa_port_opmode {
+       BFA_PORT_OPMODE_NORMAL   = 0x00, /*  normal non-loopback mode */
+       BFA_PORT_OPMODE_LB_INT   = 0x01, /*  internal loop back */
+       BFA_PORT_OPMODE_LB_SLW   = 0x02, /*  serial link wrapback (serdes) */
+       BFA_PORT_OPMODE_LB_EXT   = 0x04, /*  external loop back (serdes) */
+       BFA_PORT_OPMODE_LB_CBL   = 0x08, /*  cabled loop back */
+       BFA_PORT_OPMODE_LB_NLINT = 0x20, /*  NL_Port internal loopback */
+};
+
+#define BFA_PORT_OPMODE_LB_HARD(_mode)                 \
+       ((_mode == BFA_PORT_OPMODE_LB_INT) ||           \
+       (_mode == BFA_PORT_OPMODE_LB_SLW) ||            \
+       (_mode == BFA_PORT_OPMODE_LB_EXT))
+
+/**
+ *     Port link state
+ */
+enum bfa_port_linkstate {
+       BFA_PORT_LINKUP         = 1,    /*  Physical port/Trunk link up */
+       BFA_PORT_LINKDOWN       = 2,    /*  Physical port/Trunk link down */
+};
+
+/**
+ *     Port link state reason code
+ */
+enum bfa_port_linkstate_rsn {
+       BFA_PORT_LINKSTATE_RSN_NONE             = 0,
+       BFA_PORT_LINKSTATE_RSN_DISABLED         = 1,
+       BFA_PORT_LINKSTATE_RSN_RX_NOS           = 2,
+       BFA_PORT_LINKSTATE_RSN_RX_OLS           = 3,
+       BFA_PORT_LINKSTATE_RSN_RX_LIP           = 4,
+       BFA_PORT_LINKSTATE_RSN_RX_LIPF7         = 5,
+       BFA_PORT_LINKSTATE_RSN_SFP_REMOVED      = 6,
+       BFA_PORT_LINKSTATE_RSN_PORT_FAULT       = 7,
+       BFA_PORT_LINKSTATE_RSN_RX_LOS           = 8,
+       BFA_PORT_LINKSTATE_RSN_LOCAL_FAULT      = 9,
+       BFA_PORT_LINKSTATE_RSN_REMOTE_FAULT     = 10,
+       BFA_PORT_LINKSTATE_RSN_TIMEOUT          = 11,
+
+
+
+       /* CEE related reason codes/errors */
+       CEE_LLDP_INFO_AGED_OUT                  = 20,
+       CEE_LLDP_SHUTDOWN_TLV_RCVD              = 21,
+       CEE_PEER_NOT_ADVERTISE_DCBX             = 22,
+       CEE_PEER_NOT_ADVERTISE_PG               = 23,
+       CEE_PEER_NOT_ADVERTISE_PFC              = 24,
+       CEE_PEER_NOT_ADVERTISE_FCOE             = 25,
+       CEE_PG_NOT_COMPATIBLE                   = 26,
+       CEE_PFC_NOT_COMPATIBLE                  = 27,
+       CEE_FCOE_NOT_COMPATIBLE                 = 28,
+       CEE_BAD_PG_RCVD                         = 29,
+       CEE_BAD_BW_RCVD                         = 30,
+       CEE_BAD_PFC_RCVD                        = 31,
+       CEE_BAD_APP_PRI_RCVD                    = 32,
+       CEE_FCOE_PRI_PFC_OFF                    = 33,
+       CEE_DUP_CONTROL_TLV_RCVD                = 34,
+       CEE_DUP_FEAT_TLV_RCVD                   = 35,
+       CEE_APPLY_NEW_CFG                       = 36, /* reason, not error */
+       CEE_PROTOCOL_INIT                       = 37, /* reason, not error */
+       CEE_PHY_LINK_DOWN                       = 38,
+       CEE_LLS_FCOE_ABSENT                     = 39,
+       CEE_LLS_FCOE_DOWN                       = 40,
+       CEE_ISCSI_NOT_COMPATIBLE                = 41,
+       CEE_ISCSI_PRI_PFC_OFF                   = 42,
+       CEE_ISCSI_PRI_OVERLAP_FCOE_PRI          = 43
+};
+#pragma pack(1)
+/**
+ *      Physical port configuration
+ */
+struct bfa_port_cfg_s {
+       u8       topology;      /*  bfa_port_topology           */
+       u8       speed;         /*  enum bfa_port_speed */
+       u8       trunked;       /*  trunked or not              */
+       u8       qos_enabled;   /*  qos enabled or not          */
+       u8       cfg_hardalpa;  /*  is hard alpa configured     */
+       u8       hardalpa;      /*  configured hard alpa        */
+       u16 maxfrsize;  /*  maximum frame size          */
+       u8       rx_bbcredit;   /*  receive buffer credits      */
+       u8       tx_bbcredit;   /*  transmit buffer credits     */
+       u8       ratelimit;     /*  ratelimit enabled or not    */
+       u8       trl_def_speed; /*  ratelimit default speed     */
+       u16 path_tov;   /*  device path timeout */
+       u16 q_depth;    /*  SCSI Queue depth            */
+};
+#pragma pack()
+
+/**
+ *     Port attribute values.
+ */
+struct bfa_port_attr_s {
+       /*
+        * Static fields
+        */
+       wwn_t      nwwn;                /*  node wwn */
+       wwn_t      pwwn;                /*  port wwn */
+       wwn_t      factorynwwn; /*  factory node wwn */
+       wwn_t      factorypwwn; /*  factory port wwn */
+       enum fc_cos     cos_supported;  /*  supported class of services */
+       u32     rsvd;
+       struct fc_symname_s     port_symname;   /*  port symbolic name */
+       enum bfa_port_speed speed_supported; /*  supported speeds */
+       bfa_boolean_t   pbind_enabled;
+
+       /*
+        * Configured values
+        */
+       struct bfa_port_cfg_s pport_cfg;        /*  pport cfg */
+
+       /*
+        * Dynamic field - info from BFA
+        */
+       enum bfa_port_states    port_state;     /*  current port state */
+       enum bfa_port_speed     speed;          /*  current speed */
+       enum bfa_port_topology  topology;       /*  current topology */
+       bfa_boolean_t           beacon;         /*  current beacon status */
+       bfa_boolean_t           link_e2e_beacon; /*  link beacon is on */
+       bfa_boolean_t           plog_enabled;   /*  portlog is enabled */
+
+       /*
+        * Dynamic field - info from FCS
+        */
+       u32             pid;            /*  port ID */
+       enum bfa_port_type      port_type;      /*  current topology */
+       u32             loopback;       /*  external loopback */
+       u32             authfail;       /*  auth fail state */
+       bfa_boolean_t           io_profile;     /*  get it from fcpim mod */
+       u8                      pad[4];         /*  for 64-bit alignement */
+
+       /* FCoE specific  */
+       u16             fcoe_vlan;
+       u8                      rsvd1[6];
+};
+
+/**
+ *           Port FCP mappings.
+ */
+struct bfa_port_fcpmap_s {
+       char            osdevname[256];
+       u32     bus;
+       u32     target;
+       u32     oslun;
+       u32     fcid;
+       wwn_t      nwwn;
+       wwn_t      pwwn;
+       u64     fcplun;
+       char            luid[256];
+};
+
+/**
+ *           Port RNID info.
+ */
+struct bfa_port_rnid_s {
+       wwn_t        wwn;
+       u32       unittype;
+       u32       portid;
+       u32       attached_nodes_num;
+       u16       ip_version;
+       u16       udp_port;
+       u8         ipaddr[16];
+       u16       rsvd;
+       u16       topologydiscoveryflags;
+};
+
+#pragma pack(1)
+struct bfa_fcport_fcf_s {
+       wwn_t      name;           /*  FCF name          */
+       wwn_t      fabric_name;    /*  Fabric Name            */
+       u8              fipenabled;     /*  FIP enabled or not */
+       u8              fipfailed;      /*  FIP failed or not   */
+       u8              resv[2];
+       u8       pri;       /*  FCF priority         */
+       u8       version;       /*  FIP version used     */
+       u8       available;      /*  Available  for  login    */
+       u8       fka_disabled;   /*  FKA is disabled      */
+       u8       maxsz_verified; /*  FCoE max size verified   */
+       u8       fc_map[3];      /*  FC map                */
+       u16     vlan;      /*  FCoE vlan tag/priority   */
+       u32     fka_adv_per;    /*  FIP  ka advert. period   */
+       mac_t      mac;     /*  FCF mac           */
+};
+
+/**
+ *     Trunk states for BCU/BFAL
+ */
+enum bfa_trunk_state {
+       BFA_TRUNK_DISABLED      = 0,    /*  Trunk is not configured     */
+       BFA_TRUNK_ONLINE        = 1,    /*  Trunk is online             */
+       BFA_TRUNK_OFFLINE       = 2,    /*  Trunk is offline            */
+};
+
+/**
+ *     VC attributes for trunked link
+ */
+struct bfa_trunk_vc_attr_s {
+       u32 bb_credit;
+       u32 elp_opmode_flags;
+       u32 req_credit;
+       u16 vc_credits[8];
+};
+
+/**
+ *     Link state information
+ */
+struct bfa_port_link_s {
+       u8       linkstate;     /*  Link state bfa_port_linkstate */
+       u8       linkstate_rsn; /*  bfa_port_linkstate_rsn_t */
+       u8       topology;      /*  P2P/LOOP bfa_port_topology */
+       u8       speed;         /*  Link speed (1/2/4/8 G) */
+       u32     linkstate_opt;  /*  Linkstate optional data (debug) */
+       u8       trunked;       /*  Trunked or not (1 or 0) */
+       u8       resvd[3];
+       struct bfa_qos_attr_s  qos_attr;   /* QoS Attributes */
+       union {
+               struct bfa_qos_vc_attr_s qos_vc_attr;  /*  VC info from ELP */
+               struct bfa_trunk_vc_attr_s trunk_vc_attr;
+               struct bfa_fcport_fcf_s fcf; /*  FCF information (for FCoE) */
+       } vc_fcf;
+};
+#pragma pack()
+
+enum bfa_trunk_link_fctl {
+       BFA_TRUNK_LINK_FCTL_NORMAL,
+       BFA_TRUNK_LINK_FCTL_VC,
+       BFA_TRUNK_LINK_FCTL_VC_QOS,
+};
+
+enum bfa_trunk_link_state {
+       BFA_TRUNK_LINK_STATE_UP = 1,            /* link part of trunk */
+       BFA_TRUNK_LINK_STATE_DN_LINKDN = 2,     /* physical link down */
+       BFA_TRUNK_LINK_STATE_DN_GRP_MIS = 3,    /* trunk group different */
+       BFA_TRUNK_LINK_STATE_DN_SPD_MIS = 4,    /* speed mismatch */
+       BFA_TRUNK_LINK_STATE_DN_MODE_MIS = 5,   /* remote port not trunked */
+};
+
+#define BFA_TRUNK_MAX_PORTS    2
+struct bfa_trunk_link_attr_s {
+       wwn_t    trunk_wwn;
+       enum bfa_trunk_link_fctl fctl;
+       enum bfa_trunk_link_state link_state;
+       enum bfa_port_speed     speed;
+       u32 deskew;
+};
+
+struct bfa_trunk_attr_s {
+       enum bfa_trunk_state    state;
+       enum bfa_port_speed     speed;
+       u32             port_id;
+       u32             rsvd;
+       struct bfa_trunk_link_attr_s link_attr[BFA_TRUNK_MAX_PORTS];
+};
+
+struct bfa_rport_hal_stats_s {
+       u32        sm_un_cr;        /*  uninit: create events      */
+       u32        sm_un_unexp;     /*  uninit: exception events   */
+       u32        sm_cr_on;        /*  created: online events     */
+       u32        sm_cr_del;       /*  created: delete events     */
+       u32        sm_cr_hwf;       /*  created: IOC down          */
+       u32        sm_cr_unexp;     /*  created: exception events  */
+       u32        sm_fwc_rsp;      /*  fw create: f/w responses   */
+       u32        sm_fwc_del;      /*  fw create: delete events   */
+       u32        sm_fwc_off;      /*  fw create: offline events  */
+       u32        sm_fwc_hwf;      /*  fw create: IOC down        */
+       u32        sm_fwc_unexp;            /*  fw create: exception events*/
+       u32        sm_on_off;       /*  online: offline events     */
+       u32        sm_on_del;       /*  online: delete events      */
+       u32        sm_on_hwf;       /*  online: IOC down events    */
+       u32        sm_on_unexp;     /*  online: exception events   */
+       u32        sm_fwd_rsp;      /*  fw delete: fw responses    */
+       u32        sm_fwd_del;      /*  fw delete: delete events   */
+       u32        sm_fwd_hwf;      /*  fw delete: IOC down events */
+       u32        sm_fwd_unexp;            /*  fw delete: exception events*/
+       u32        sm_off_del;      /*  offline: delete events     */
+       u32        sm_off_on;       /*  offline: online events     */
+       u32        sm_off_hwf;      /*  offline: IOC down events   */
+       u32        sm_off_unexp;            /*  offline: exception events  */
+       u32        sm_del_fwrsp;            /*  delete: fw responses       */
+       u32        sm_del_hwf;      /*  delete: IOC down events    */
+       u32        sm_del_unexp;            /*  delete: exception events   */
+       u32        sm_delp_fwrsp;           /*  delete pend: fw responses  */
+       u32        sm_delp_hwf;     /*  delete pend: IOC downs     */
+       u32        sm_delp_unexp;           /*  delete pend: exceptions    */
+       u32        sm_offp_fwrsp;           /*  off-pending: fw responses  */
+       u32        sm_offp_del;     /*  off-pending: deletes       */
+       u32        sm_offp_hwf;     /*  off-pending: IOC downs     */
+       u32        sm_offp_unexp;           /*  off-pending: exceptions    */
+       u32        sm_iocd_off;     /*  IOC down: offline events   */
+       u32        sm_iocd_del;     /*  IOC down: delete events    */
+       u32        sm_iocd_on;      /*  IOC down: online events    */
+       u32        sm_iocd_unexp;           /*  IOC down: exceptions       */
+       u32        rsvd;
+};
+#pragma pack(1)
+/**
+ *  Rport's QoS attributes
+ */
+struct bfa_rport_qos_attr_s {
+       u8                      qos_priority;  /*  rport's QoS priority   */
+       u8                      rsvd[3];
+       u32            qos_flow_id;       /*  QoS flow Id        */
+};
+#pragma pack()
+
+#define BFA_IOBUCKET_MAX 14
+
+struct bfa_itnim_latency_s {
+       u32 min[BFA_IOBUCKET_MAX];
+       u32 max[BFA_IOBUCKET_MAX];
+       u32 count[BFA_IOBUCKET_MAX];
+       u32 avg[BFA_IOBUCKET_MAX];
+};
+
+struct bfa_itnim_ioprofile_s {
+       u32 clock_res_mul;
+       u32 clock_res_div;
+       u32 index;
+       u32 io_profile_start_time;      /*  IO profile start time       */
+       u32 iocomps[BFA_IOBUCKET_MAX];  /*  IO completed        */
+       struct bfa_itnim_latency_s io_latency;
+};
+
+/**
+ * FC physical port statistics.
+ */
+struct bfa_port_fc_stats_s {
+       u64     secs_reset;     /*  Seconds since stats is reset */
+       u64     tx_frames;      /*  Tx frames                   */
+       u64     tx_words;       /*  Tx words                    */
+       u64     tx_lip;         /*  Tx LIP                      */
+       u64     tx_nos;         /*  Tx NOS                      */
+       u64     tx_ols;         /*  Tx OLS                      */
+       u64     tx_lr;          /*  Tx LR                       */
+       u64     tx_lrr;         /*  Tx LRR                      */
+       u64     rx_frames;      /*  Rx frames                   */
+       u64     rx_words;       /*  Rx words                    */
+       u64     lip_count;      /*  Rx LIP                      */
+       u64     nos_count;      /*  Rx NOS                      */
+       u64     ols_count;      /*  Rx OLS                      */
+       u64     lr_count;       /*  Rx LR                       */
+       u64     lrr_count;      /*  Rx LRR                      */
+       u64     invalid_crcs;   /*  Rx CRC err frames           */
+       u64     invalid_crc_gd_eof; /*  Rx CRC err good EOF frames */
+       u64     undersized_frm; /*  Rx undersized frames        */
+       u64     oversized_frm;  /*  Rx oversized frames */
+       u64     bad_eof_frm;    /*  Rx frames with bad EOF      */
+       u64     error_frames;   /*  Errored frames              */
+       u64     dropped_frames; /*  Dropped frames              */
+       u64     link_failures;  /*  Link Failure (LF) count     */
+       u64     loss_of_syncs;  /*  Loss of sync count          */
+       u64     loss_of_signals; /*  Loss of signal count       */
+       u64     primseq_errs;   /*  Primitive sequence protocol err. */
+       u64     bad_os_count;   /*  Invalid ordered sets        */
+       u64     err_enc_out;    /*  Encoding err nonframe_8b10b */
+       u64     err_enc;        /*  Encoding err frame_8b10b    */
+};
+
+/**
+ * Eth Physical Port statistics.
+ */
+struct bfa_port_eth_stats_s {
+       u64     secs_reset;     /*  Seconds since stats is reset */
+       u64     frame_64;       /*  Frames 64 bytes             */
+       u64     frame_65_127;   /*  Frames 65-127 bytes */
+       u64     frame_128_255;  /*  Frames 128-255 bytes        */
+       u64     frame_256_511;  /*  Frames 256-511 bytes        */
+       u64     frame_512_1023; /*  Frames 512-1023 bytes       */
+       u64     frame_1024_1518; /*  Frames 1024-1518 bytes     */
+       u64     frame_1519_1522; /*  Frames 1519-1522 bytes     */
+       u64     tx_bytes;       /*  Tx bytes                    */
+       u64     tx_packets;      /*  Tx packets         */
+       u64     tx_mcast_packets; /*  Tx multicast packets      */
+       u64     tx_bcast_packets; /*  Tx broadcast packets      */
+       u64     tx_control_frame; /*  Tx control frame          */
+       u64     tx_drop;        /*  Tx drops                    */
+       u64     tx_jabber;      /*  Tx jabber                   */
+       u64     tx_fcs_error;   /*  Tx FCS errors               */
+       u64     tx_fragments;   /*  Tx fragments                */
+       u64     rx_bytes;       /*  Rx bytes                    */
+       u64     rx_packets;     /*  Rx packets                  */
+       u64     rx_mcast_packets; /*  Rx multicast packets      */
+       u64     rx_bcast_packets; /*  Rx broadcast packets      */
+       u64     rx_control_frames; /*  Rx control frames        */
+       u64     rx_unknown_opcode; /*  Rx unknown opcode        */
+       u64     rx_drop;        /*  Rx drops                    */
+       u64     rx_jabber;      /*  Rx jabber                   */
+       u64     rx_fcs_error;   /*  Rx FCS errors               */
+       u64     rx_alignment_error; /*  Rx alignment errors     */
+       u64     rx_frame_length_error; /*  Rx frame len errors  */
+       u64     rx_code_error;  /*  Rx code errors              */
+       u64     rx_fragments;   /*  Rx fragments                */
+       u64     rx_pause;       /*  Rx pause                    */
+       u64     rx_zero_pause;  /*  Rx zero pause               */
+       u64     tx_pause;       /*  Tx pause                    */
+       u64     tx_zero_pause;  /*  Tx zero pause               */
+       u64     rx_fcoe_pause;  /*  Rx FCoE pause               */
+       u64     rx_fcoe_zero_pause; /*  Rx FCoE zero pause      */
+       u64     tx_fcoe_pause;  /*  Tx FCoE pause               */
+       u64     tx_fcoe_zero_pause; /*  Tx FCoE zero pause      */
+       u64     rx_iscsi_pause; /*  Rx iSCSI pause              */
+       u64     rx_iscsi_zero_pause; /*  Rx iSCSI zero pause    */
+       u64     tx_iscsi_pause; /*  Tx iSCSI pause              */
+       u64     tx_iscsi_zero_pause; /*  Tx iSCSI zero pause    */
+};
+
+/**
+ *              Port statistics.
+ */
+union bfa_port_stats_u {
+       struct bfa_port_fc_stats_s      fc;
+       struct bfa_port_eth_stats_s     eth;
+};
+
+#endif /* __BFA_DEFS_SVC_H__ */
diff --git a/drivers/scsi/bfa/bfa_drv.c b/drivers/scsi/bfa/bfa_drv.c
new file mode 100644 (file)
index 0000000..1412764
--- /dev/null
@@ -0,0 +1,107 @@
+/*
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
+ * All rights reserved
+ * www.brocade.com
+ *
+ * Linux driver for Brocade Fibre Channel Host Bus Adapter.
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License (GPL) Version 2 as
+ * published by the Free Software Foundation
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * General Public License for more details.
+ */
+
+#include "bfa_modules.h"
+
+/**
+ * BFA module list terminated by NULL
+ */
+struct bfa_module_s *hal_mods[] = {
+       &hal_mod_sgpg,
+       &hal_mod_fcport,
+       &hal_mod_fcxp,
+       &hal_mod_lps,
+       &hal_mod_uf,
+       &hal_mod_rport,
+       &hal_mod_fcpim,
+       NULL
+};
+
+/**
+ * Message handlers for various modules.
+ */
+bfa_isr_func_t  bfa_isrs[BFI_MC_MAX] = {
+       bfa_isr_unhandled,      /* NONE */
+       bfa_isr_unhandled,      /* BFI_MC_IOC */
+       bfa_isr_unhandled,      /* BFI_MC_DIAG */
+       bfa_isr_unhandled,      /* BFI_MC_FLASH */
+       bfa_isr_unhandled,      /* BFI_MC_CEE */
+       bfa_fcport_isr,         /* BFI_MC_FCPORT */
+       bfa_isr_unhandled,      /* BFI_MC_IOCFC */
+       bfa_isr_unhandled,      /* BFI_MC_LL */
+       bfa_uf_isr,             /* BFI_MC_UF */
+       bfa_fcxp_isr,           /* BFI_MC_FCXP */
+       bfa_lps_isr,            /* BFI_MC_LPS */
+       bfa_rport_isr,          /* BFI_MC_RPORT */
+       bfa_itnim_isr,          /* BFI_MC_ITNIM */
+       bfa_isr_unhandled,      /* BFI_MC_IOIM_READ */
+       bfa_isr_unhandled,      /* BFI_MC_IOIM_WRITE */
+       bfa_isr_unhandled,      /* BFI_MC_IOIM_IO */
+       bfa_ioim_isr,           /* BFI_MC_IOIM */
+       bfa_ioim_good_comp_isr, /* BFI_MC_IOIM_IOCOM */
+       bfa_tskim_isr,          /* BFI_MC_TSKIM */
+       bfa_isr_unhandled,      /* BFI_MC_SBOOT */
+       bfa_isr_unhandled,      /* BFI_MC_IPFC */
+       bfa_isr_unhandled,      /* BFI_MC_PORT */
+       bfa_isr_unhandled,      /* --------- */
+       bfa_isr_unhandled,      /* --------- */
+       bfa_isr_unhandled,      /* --------- */
+       bfa_isr_unhandled,      /* --------- */
+       bfa_isr_unhandled,      /* --------- */
+       bfa_isr_unhandled,      /* --------- */
+       bfa_isr_unhandled,      /* --------- */
+       bfa_isr_unhandled,      /* --------- */
+       bfa_isr_unhandled,      /* --------- */
+       bfa_isr_unhandled,      /* --------- */
+};
+
+
+/**
+ * Message handlers for mailbox command classes
+ */
+bfa_ioc_mbox_mcfunc_t  bfa_mbox_isrs[BFI_MC_MAX] = {
+       NULL,
+       NULL,                   /* BFI_MC_IOC   */
+       NULL,                   /* BFI_MC_DIAG  */
+       NULL,           /* BFI_MC_FLASH */
+       NULL,                   /* BFI_MC_CEE   */
+       NULL,                   /* BFI_MC_PORT  */
+       bfa_iocfc_isr,          /* BFI_MC_IOCFC */
+       NULL,
+};
+
+
+
+void
+bfa_com_port_attach(struct bfa_s *bfa, struct bfa_meminfo_s *mi)
+{
+       struct bfa_port_s       *port = &bfa->modules.port;
+       u32             dm_len;
+       u8                      *dm_kva;
+       u64             dm_pa;
+
+       dm_len = bfa_port_meminfo();
+       dm_kva = bfa_meminfo_dma_virt(mi);
+       dm_pa  = bfa_meminfo_dma_phys(mi);
+
+       memset(port, 0, sizeof(struct bfa_port_s));
+       bfa_port_attach(port, &bfa->ioc, bfa, bfa->trcmod);
+       bfa_port_mem_claim(port, dm_kva, dm_pa);
+
+       bfa_meminfo_dma_virt(mi) = dm_kva + dm_len;
+       bfa_meminfo_dma_phys(mi) = dm_pa + dm_len;
+}
diff --git a/drivers/scsi/bfa/bfa_fc.h b/drivers/scsi/bfa/bfa_fc.h
new file mode 100644 (file)
index 0000000..6eff705
--- /dev/null
@@ -0,0 +1,1916 @@
+/*
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
+ * All rights reserved
+ * www.brocade.com
+ *
+ * Linux driver for Brocade Fibre Channel Host Bus Adapter.
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License (GPL) Version 2 as
+ * published by the Free Software Foundation
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * General Public License for more details.
+ */
+
+#ifndef __BFA_FC_H__
+#define __BFA_FC_H__
+
+#include "bfa_os_inc.h"
+
+typedef u64 wwn_t;
+typedef u64 lun_t;
+
+#define WWN_NULL       (0)
+#define FC_SYMNAME_MAX 256     /*  max name server symbolic name size */
+#define FC_ALPA_MAX    128
+
+#pragma pack(1)
+
+#define MAC_ADDRLEN    (6)
+struct mac_s { u8 mac[MAC_ADDRLEN]; };
+#define mac_t struct mac_s
+
+/*
+ * generic SCSI cdb definition
+ */
+#define SCSI_MAX_CDBLEN     16
+struct scsi_cdb_s {
+       u8         scsi_cdb[SCSI_MAX_CDBLEN];
+};
+#define scsi_cdb_t struct scsi_cdb_s
+
+/* ------------------------------------------------------------
+ * SCSI status byte values
+ * ------------------------------------------------------------
+ */
+#define SCSI_STATUS_GOOD                   0x00
+#define SCSI_STATUS_CHECK_CONDITION        0x02
+#define SCSI_STATUS_CONDITION_MET          0x04
+#define SCSI_STATUS_BUSY                   0x08
+#define SCSI_STATUS_INTERMEDIATE           0x10
+#define SCSI_STATUS_ICM                    0x14 /* intermediate condition met */
+#define SCSI_STATUS_RESERVATION_CONFLICT   0x18
+#define SCSI_STATUS_COMMAND_TERMINATED     0x22
+#define SCSI_STATUS_QUEUE_FULL             0x28
+#define SCSI_STATUS_ACA_ACTIVE             0x30
+
+#define SCSI_MAX_ALLOC_LEN      0xFF    /* maximum allocarion length */
+
+/*
+ * Fibre Channel Header Structure (FCHS) definition
+ */
+struct fchs_s {
+#ifdef __BIGENDIAN
+       u32        routing:4;   /* routing bits */
+       u32        cat_info:4;  /* category info */
+#else
+       u32        cat_info:4;  /* category info */
+       u32        routing:4;   /* routing bits */
+#endif
+       u32        d_id:24;     /* destination identifier */
+
+       u32        cs_ctl:8;    /* class specific control */
+       u32        s_id:24;     /* source identifier */
+
+       u32        type:8;              /* data structure type */
+       u32        f_ctl:24;    /* initial frame control */
+
+       u8         seq_id;              /* sequence identifier */
+       u8         df_ctl;              /* data field control */
+       u16        seq_cnt;     /* sequence count */
+
+       u16        ox_id;               /* originator exchange ID */
+       u16        rx_id;               /* responder exchange ID */
+
+       u32        ro;          /* relative offset */
+};
+
+#define FC_SOF_LEN             4
+#define FC_EOF_LEN             4
+#define FC_CRC_LEN             4
+
+/*
+ * Fibre Channel BB_E Header Structure
+ */
+struct fcbbehs_s {
+       u16     ver_rsvd;
+       u32     rsvd[2];
+       u32     rsvd__sof;
+};
+
+#define FC_SEQ_ID_MAX          256
+
+/*
+ * routing bit definitions
+ */
+enum {
+       FC_RTG_FC4_DEV_DATA     = 0x0,  /* FC-4 Device Data */
+       FC_RTG_EXT_LINK         = 0x2,  /* Extended Link Data */
+       FC_RTG_FC4_LINK_DATA    = 0x3,  /* FC-4 Link Data */
+       FC_RTG_VIDEO_DATA       = 0x4,  /* Video Data */
+       FC_RTG_EXT_HDR          = 0x5,  /* VFT, IFR or Encapsuled */
+       FC_RTG_BASIC_LINK       = 0x8,  /* Basic Link data */
+       FC_RTG_LINK_CTRL        = 0xC,  /* Link Control */
+};
+
+/*
+ * information category for extended link data and FC-4 Link Data
+ */
+enum {
+       FC_CAT_LD_REQUEST       = 0x2,  /* Request */
+       FC_CAT_LD_REPLY         = 0x3,  /* Reply */
+       FC_CAT_LD_DIAG          = 0xF,  /* for DIAG use only */
+};
+
+/*
+ * information category for extended headers (VFT, IFR or encapsulation)
+ */
+enum {
+       FC_CAT_VFT_HDR = 0x0,   /* Virtual fabric tagging header */
+       FC_CAT_IFR_HDR = 0x1,   /* Inter-Fabric routing header */
+       FC_CAT_ENC_HDR = 0x2,   /* Encapsulation header */
+};
+
+/*
+ * information category for FC-4 device data
+ */
+enum {
+       FC_CAT_UNCATEG_INFO     = 0x0,  /* Uncategorized information */
+       FC_CAT_SOLICIT_DATA     = 0x1,  /* Solicited Data */
+       FC_CAT_UNSOLICIT_CTRL   = 0x2,  /* Unsolicited Control */
+       FC_CAT_SOLICIT_CTRL     = 0x3,  /* Solicited Control */
+       FC_CAT_UNSOLICIT_DATA   = 0x4,  /* Unsolicited Data */
+       FC_CAT_DATA_DESC        = 0x5,  /* Data Descriptor */
+       FC_CAT_UNSOLICIT_CMD    = 0x6,  /* Unsolicited Command */
+       FC_CAT_CMD_STATUS       = 0x7,  /* Command Status */
+};
+
+/*
+ * information category for Link Control
+ */
+enum {
+       FC_CAT_ACK_1            = 0x00,
+       FC_CAT_ACK_0_N          = 0x01,
+       FC_CAT_P_RJT            = 0x02,
+       FC_CAT_F_RJT            = 0x03,
+       FC_CAT_P_BSY            = 0x04,
+       FC_CAT_F_BSY_DATA       = 0x05,
+       FC_CAT_F_BSY_LINK_CTL   = 0x06,
+       FC_CAT_F_LCR            = 0x07,
+       FC_CAT_NTY              = 0x08,
+       FC_CAT_END              = 0x09,
+};
+
+/*
+ * Type Field Definitions. FC-PH Section 18.5 pg. 165
+ */
+enum {
+       FC_TYPE_BLS             = 0x0,  /* Basic Link Service */
+       FC_TYPE_ELS             = 0x1,  /* Extended Link Service */
+       FC_TYPE_IP              = 0x5,  /* IP */
+       FC_TYPE_FCP             = 0x8,  /* SCSI-FCP */
+       FC_TYPE_GPP             = 0x9,  /* SCSI_GPP */
+       FC_TYPE_SERVICES        = 0x20, /* Fibre Channel Services */
+       FC_TYPE_FC_FSS          = 0x22, /* Fabric Switch Services */
+       FC_TYPE_FC_AL           = 0x23, /* FC-AL */
+       FC_TYPE_FC_SNMP         = 0x24, /* FC-SNMP */
+       FC_TYPE_FC_SPINFAB      = 0xEE, /* SPINFAB */
+       FC_TYPE_FC_DIAG         = 0xEF, /* DIAG */
+       FC_TYPE_MAX             = 256,  /* 256 FC-4 types */
+};
+
+struct fc_fc4types_s {
+       u8         bits[FC_TYPE_MAX / 8];
+};
+
+/*
+ * Frame Control Definitions. FC-PH Table-45. pg. 168
+ */
+enum {
+       FCTL_EC_ORIG = 0x000000,        /* exchange originator */
+       FCTL_EC_RESP = 0x800000,        /* exchange responder */
+       FCTL_SEQ_INI = 0x000000,        /* sequence initiator */
+       FCTL_SEQ_REC = 0x400000,        /* sequence recipient */
+       FCTL_FS_EXCH = 0x200000,        /* first sequence of xchg */
+       FCTL_LS_EXCH = 0x100000,        /* last sequence of xchg */
+       FCTL_END_SEQ = 0x080000,        /* last frame of sequence */
+       FCTL_SI_XFER = 0x010000,        /* seq initiative transfer */
+       FCTL_RO_PRESENT = 0x000008,     /* relative offset present */
+       FCTL_FILLBYTE_MASK = 0x000003   /* , fill byte mask */
+};
+
+/*
+ * Fabric Well Known Addresses
+ */
+enum {
+       FC_MIN_WELL_KNOWN_ADDR          = 0xFFFFF0,
+       FC_DOMAIN_CONTROLLER_MASK       = 0xFFFC00,
+       FC_ALIAS_SERVER                 = 0xFFFFF8,
+       FC_MGMT_SERVER                  = 0xFFFFFA,
+       FC_TIME_SERVER                  = 0xFFFFFB,
+       FC_NAME_SERVER                  = 0xFFFFFC,
+       FC_FABRIC_CONTROLLER            = 0xFFFFFD,
+       FC_FABRIC_PORT                  = 0xFFFFFE,
+       FC_BROADCAST_SERVER             = 0xFFFFFF
+};
+
+/*
+ * domain/area/port defines
+ */
+#define FC_DOMAIN_MASK  0xFF0000
+#define FC_DOMAIN_SHIFT 16
+#define FC_AREA_MASK    0x00FF00
+#define FC_AREA_SHIFT   8
+#define FC_PORT_MASK    0x0000FF
+#define FC_PORT_SHIFT   0
+
+#define FC_GET_DOMAIN(p)       (((p) & FC_DOMAIN_MASK) >> FC_DOMAIN_SHIFT)
+#define FC_GET_AREA(p)         (((p) & FC_AREA_MASK) >> FC_AREA_SHIFT)
+#define FC_GET_PORT(p)         (((p) & FC_PORT_MASK) >> FC_PORT_SHIFT)
+
+#define FC_DOMAIN_CTRLR(p)     (FC_DOMAIN_CONTROLLER_MASK | (FC_GET_DOMAIN(p)))
+
+enum {
+       FC_RXID_ANY = 0xFFFFU,
+};
+
+/*
+ * generic ELS command
+ */
+struct fc_els_cmd_s {
+       u32        els_code:8;  /* ELS Command Code */
+       u32        reserved:24;
+};
+
+/*
+ * ELS Command Codes. FC-PH Table-75. pg. 223
+ */
+enum {
+       FC_ELS_LS_RJT = 0x1,    /* Link Service Reject. */
+       FC_ELS_ACC = 0x02,      /* Accept */
+       FC_ELS_PLOGI = 0x03,    /* N_Port Login. */
+       FC_ELS_FLOGI = 0x04,    /* F_Port Login. */
+       FC_ELS_LOGO = 0x05,     /* Logout. */
+       FC_ELS_ABTX = 0x06,     /* Abort Exchange */
+       FC_ELS_RES = 0x08,      /* Read Exchange status */
+       FC_ELS_RSS = 0x09,      /* Read sequence status block */
+       FC_ELS_RSI = 0x0A,      /* Request Sequence Initiative */
+       FC_ELS_ESTC = 0x0C,     /* Estimate Credit. */
+       FC_ELS_RTV = 0x0E,      /* Read Timeout Value. */
+       FC_ELS_RLS = 0x0F,      /* Read Link Status. */
+       FC_ELS_ECHO = 0x10,     /* Echo */
+       FC_ELS_TEST = 0x11,     /* Test */
+       FC_ELS_RRQ = 0x12,      /* Reinstate Recovery Qualifier. */
+       FC_ELS_REC = 0x13,      /* Add this for TAPE support in FCR */
+       FC_ELS_PRLI = 0x20,     /* Process Login */
+       FC_ELS_PRLO = 0x21,     /* Process Logout. */
+       FC_ELS_SCN = 0x22,      /* State Change Notification. */
+       FC_ELS_TPRLO = 0x24,    /* Third Party Process Logout. */
+       FC_ELS_PDISC = 0x50,    /* Discover N_Port Parameters. */
+       FC_ELS_FDISC = 0x51,    /* Discover F_Port Parameters. */
+       FC_ELS_ADISC = 0x52,    /* Discover Address. */
+       FC_ELS_FARP_REQ = 0x54, /* FARP Request. */
+       FC_ELS_FARP_REP = 0x55, /* FARP Reply. */
+       FC_ELS_FAN = 0x60,      /* Fabric Address Notification */
+       FC_ELS_RSCN = 0x61,     /* Reg State Change Notification */
+       FC_ELS_SCR = 0x62,      /* State Change Registration. */
+       FC_ELS_RTIN = 0x77,     /* Mangement server request */
+       FC_ELS_RNID = 0x78,     /* Mangement server request */
+       FC_ELS_RLIR = 0x79,     /* Registered Link Incident Record */
+
+       FC_ELS_RPSC = 0x7D,     /* Report Port Speed Capabilities */
+       FC_ELS_QSA = 0x7E,      /* Query Security Attributes. Ref FC-SP */
+       FC_ELS_E2E_LBEACON = 0x81,
+                               /* End-to-End Link Beacon */
+       FC_ELS_AUTH = 0x90,     /* Authentication. Ref FC-SP */
+       FC_ELS_RFCN = 0x97,     /* Request Fabric Change Notification. Ref
+                                *FC-SP */
+
+};
+
+/*
+ *  Version numbers for FC-PH standards,
+ *  used in login to indicate what port
+ *  supports. See FC-PH-X table 158.
+ */
+enum {
+       FC_PH_VER_4_3 = 0x09,
+       FC_PH_VER_PH_3 = 0x20,
+};
+
+/*
+ * PDU size defines
+ */
+enum {
+       FC_MIN_PDUSZ = 512,
+       FC_MAX_PDUSZ = 2112,
+};
+
+/*
+ * N_Port PLOGI Common Service Parameters.
+ * FC-PH-x. Figure-76. pg. 308.
+ */
+struct fc_plogi_csp_s {
+       u8         verhi;       /* FC-PH high version */
+       u8         verlo;       /* FC-PH low version */
+       u16        bbcred;      /* BB_Credit */
+
+#ifdef __BIGENDIAN
+       u8         ciro:1,              /* continuously increasing RO */
+                       rro:1,          /* random relative offset */
+                       npiv_supp:1,    /* NPIV supported */
+                       port_type:1,    /* N_Port/F_port */
+                       altbbcred:1,    /* alternate BB_Credit */
+                       resolution:1,   /* ms/ns ED_TOV resolution */
+                       vvl_info:1,     /* VVL Info included */
+                       reserved1:1;
+
+       u8         hg_supp:1,
+                       query_dbc:1,
+                       security:1,
+                       sync_cap:1,
+                       r_t_tov:1,
+                       dh_dup_supp:1,
+                       cisc:1,         /* continuously increasing seq count */
+                       payload:1;
+#else
+       u8         reserved2:2,
+                       resolution:1,   /* ms/ns ED_TOV resolution */
+                       altbbcred:1,    /* alternate BB_Credit */
+                       port_type:1,    /* N_Port/F_port */
+                       npiv_supp:1,    /* NPIV supported */
+                       rro:1,          /* random relative offset */
+                       ciro:1;         /* continuously increasing RO */
+
+       u8         payload:1,
+                       cisc:1,         /* continuously increasing seq count */
+                       dh_dup_supp:1,
+                       r_t_tov:1,
+                       sync_cap:1,
+                       security:1,
+                       query_dbc:1,
+                       hg_supp:1;
+#endif
+
+       u16        rxsz;                /* recieve data_field size */
+
+       u16        conseq;
+       u16        ro_bitmap;
+
+       u32        e_d_tov;
+};
+
+/*
+ * N_Port PLOGI Class Specific Parameters.
+ * FC-PH-x. Figure 78. pg. 318.
+ */
+struct fc_plogi_clp_s {
+#ifdef __BIGENDIAN
+       u32        class_valid:1;
+       u32        intermix:1;  /* class intermix supported if set =1.
+                                        * valid only for class1. Reserved for
+                                        * class2 & class3
+                                        */
+       u32        reserved1:2;
+       u32        sequential:1;
+       u32        reserved2:3;
+#else
+       u32        reserved2:3;
+       u32        sequential:1;
+       u32        reserved1:2;
+       u32        intermix:1;  /* class intermix supported if set =1.
+                                        * valid only for class1. Reserved for
+                                        * class2 & class3
+                                        */
+       u32        class_valid:1;
+#endif
+
+       u32        reserved3:24;
+
+       u32        reserved4:16;
+       u32        rxsz:16;     /* Receive data_field size */
+
+       u32        reserved5:8;
+       u32        conseq:8;
+       u32        e2e_credit:16;       /* end to end credit */
+
+       u32        reserved7:8;
+       u32        ospx:8;
+       u32        reserved8:16;
+};
+
+/* ASCII value for each character in string "BRCD" */
+#define FLOGI_VVL_BRCD    0x42524344
+
+/*
+ * PLOGI els command and reply payload
+ */
+struct fc_logi_s {
+       struct fc_els_cmd_s els_cmd;    /* ELS command code */
+       struct fc_plogi_csp_s csp;              /* common service params */
+       wwn_t           port_name;
+       wwn_t           node_name;
+       struct fc_plogi_clp_s class1;           /* class 1 service parameters */
+       struct fc_plogi_clp_s class2;           /* class 2 service parameters */
+       struct fc_plogi_clp_s class3;           /* class 3 service parameters */
+       struct fc_plogi_clp_s class4;           /* class 4 service parameters */
+       u8         vvl[16];     /* vendor version level */
+};
+
+/*
+ * LOGO els command payload
+ */
+struct fc_logo_s {
+       struct fc_els_cmd_s els_cmd;    /* ELS command code */
+       u32        res1:8;
+       u32        nport_id:24; /* N_Port identifier of source */
+       wwn_t           orig_port_name; /* Port name of the LOGO originator */
+};
+
+/*
+ * ADISC els command payload
+ */
+struct fc_adisc_s {
+       struct fc_els_cmd_s els_cmd;    /* ELS command code */
+       u32        res1:8;
+       u32        orig_HA:24;  /* originator hard address */
+       wwn_t           orig_port_name; /* originator port name */
+       wwn_t           orig_node_name; /* originator node name */
+       u32        res2:8;
+       u32        nport_id:24; /* originator NPortID */
+};
+
+/*
+ * Exchange status block
+ */
+struct fc_exch_status_blk_s {
+       u32        oxid:16;
+       u32        rxid:16;
+       u32        res1:8;
+       u32        orig_np:24;  /* originator NPortID */
+       u32        res2:8;
+       u32        resp_np:24;  /* responder NPortID */
+       u32        es_bits;
+       u32        res3;
+       /*
+        * un modified section of the fields
+        */
+};
+
+/*
+ * RES els command payload
+ */
+struct fc_res_s {
+       struct fc_els_cmd_s els_cmd;    /* ELS command code */
+       u32        res1:8;
+       u32        nport_id:24; /* N_Port identifier of source */
+       u32        oxid:16;
+       u32        rxid:16;
+       u8         assoc_hdr[32];
+};
+
+/*
+ * RES els accept payload
+ */
+struct fc_res_acc_s {
+       struct fc_els_cmd_s             els_cmd;        /* ELS command code */
+       struct fc_exch_status_blk_s     fc_exch_blk; /* Exchange status block */
+};
+
+/*
+ * REC els command payload
+ */
+struct fc_rec_s {
+       struct fc_els_cmd_s els_cmd;    /* ELS command code */
+       u32        res1:8;
+       u32        nport_id:24; /* N_Port identifier of source */
+       u32        oxid:16;
+       u32        rxid:16;
+};
+
+#define FC_REC_ESB_OWN_RSP     0x80000000      /* responder owns */
+#define FC_REC_ESB_SI          0x40000000      /* SI is owned  */
+#define FC_REC_ESB_COMP                0x20000000      /* exchange is complete */
+#define FC_REC_ESB_ENDCOND_ABN 0x10000000      /* abnormal ending      */
+#define FC_REC_ESB_RQACT       0x04000000      /* recovery qual active */
+#define FC_REC_ESB_ERRP_MSK    0x03000000
+#define FC_REC_ESB_OXID_INV    0x00800000      /* invalid OXID         */
+#define FC_REC_ESB_RXID_INV    0x00400000      /* invalid RXID         */
+#define FC_REC_ESB_PRIO_INUSE  0x00200000
+
+/*
+ * REC els accept payload
+ */
+struct fc_rec_acc_s {
+       struct fc_els_cmd_s els_cmd;    /* ELS command code */
+       u32        oxid:16;
+       u32        rxid:16;
+       u32        res1:8;
+       u32        orig_id:24;  /* N_Port id of exchange originator */
+       u32        res2:8;
+       u32        resp_id:24;  /* N_Port id of exchange responder */
+       u32        count;               /* data transfer count */
+       u32        e_stat;              /* exchange status */
+};
+
+/*
+ * RSI els payload
+ */
+struct fc_rsi_s {
+       struct fc_els_cmd_s els_cmd;
+       u32        res1:8;
+       u32        orig_sid:24;
+       u32        oxid:16;
+       u32        rxid:16;
+};
+
+/*
+ * structure for PRLI paramater pages, both request & response
+ * see FC-PH-X table 113 & 115 for explanation also FCP table 8
+ */
+struct fc_prli_params_s {
+       u32        reserved:16;
+#ifdef __BIGENDIAN
+       u32        reserved1:5;
+       u32        rec_support:1;
+       u32        task_retry_id:1;
+       u32        retry:1;
+
+       u32        confirm:1;
+       u32        doverlay:1;
+       u32        initiator:1;
+       u32        target:1;
+       u32        cdmix:1;
+       u32        drmix:1;
+       u32        rxrdisab:1;
+       u32        wxrdisab:1;
+#else
+       u32        retry:1;
+       u32        task_retry_id:1;
+       u32        rec_support:1;
+       u32        reserved1:5;
+
+       u32        wxrdisab:1;
+       u32        rxrdisab:1;
+       u32        drmix:1;
+       u32        cdmix:1;
+       u32        target:1;
+       u32        initiator:1;
+       u32        doverlay:1;
+       u32        confirm:1;
+#endif
+};
+
+/*
+ * valid values for rspcode in PRLI ACC payload
+ */
+enum {
+       FC_PRLI_ACC_XQTD = 0x1,         /* request executed */
+       FC_PRLI_ACC_PREDEF_IMG = 0x5,   /* predefined image - no prli needed */
+};
+
+struct fc_prli_params_page_s {
+       u32        type:8;
+       u32        codext:8;
+#ifdef __BIGENDIAN
+       u32        origprocasv:1;
+       u32        rsppav:1;
+       u32        imagepair:1;
+       u32        reserved1:1;
+       u32        rspcode:4;
+#else
+       u32        rspcode:4;
+       u32        reserved1:1;
+       u32        imagepair:1;
+       u32        rsppav:1;
+       u32        origprocasv:1;
+#endif
+       u32        reserved2:8;
+
+       u32        origprocas;
+       u32        rspprocas;
+       struct fc_prli_params_s servparams;
+};
+
+/*
+ * PRLI request and accept payload, FC-PH-X tables 112 & 114
+ */
+struct fc_prli_s {
+       u32        command:8;
+       u32        pglen:8;
+       u32        pagebytes:16;
+       struct fc_prli_params_page_s parampage;
+};
+
+/*
+ * PRLO logout params page
+ */
+struct fc_prlo_params_page_s {
+       u32        type:8;
+       u32        type_ext:8;
+#ifdef __BIGENDIAN
+       u32        opa_valid:1; /* originator process associator
+                                        * valid
+                                        */
+       u32        rpa_valid:1; /* responder process associator valid */
+       u32        res1:14;
+#else
+       u32        res1:14;
+       u32        rpa_valid:1; /* responder process associator valid */
+       u32        opa_valid:1; /* originator process associator
+                                        * valid
+                                        */
+#endif
+       u32        orig_process_assc;
+       u32        resp_process_assc;
+
+       u32        res2;
+};
+
+/*
+ * PRLO els command payload
+ */
+struct fc_prlo_s {
+       u32     command:8;
+       u32     page_len:8;
+       u32     payload_len:16;
+       struct fc_prlo_params_page_s    prlo_params[1];
+};
+
+/*
+ * PRLO Logout response parameter page
+ */
+struct fc_prlo_acc_params_page_s {
+       u32        type:8;
+       u32        type_ext:8;
+
+#ifdef __BIGENDIAN
+       u32        opa_valid:1; /* originator process associator
+                                        * valid
+                                        */
+       u32        rpa_valid:1; /* responder process associator valid */
+       u32        res1:14;
+#else
+       u32        res1:14;
+       u32        rpa_valid:1; /* responder process associator valid */
+       u32        opa_valid:1; /* originator process associator
+                                        * valid
+                                        */
+#endif
+       u32        orig_process_assc;
+       u32        resp_process_assc;
+
+       u32        fc4type_csp;
+};
+
+/*
+ * PRLO els command ACC payload
+ */
+struct fc_prlo_acc_s {
+       u32        command:8;
+       u32        page_len:8;
+       u32        payload_len:16;
+       struct fc_prlo_acc_params_page_s prlo_acc_params[1];
+};
+
+/*
+ * SCR els command payload
+ */
+enum {
+       FC_SCR_REG_FUNC_FABRIC_DETECTED = 0x01,
+       FC_SCR_REG_FUNC_N_PORT_DETECTED = 0x02,
+       FC_SCR_REG_FUNC_FULL = 0x03,
+       FC_SCR_REG_FUNC_CLEAR_REG = 0xFF,
+};
+
+/* SCR VU registrations */
+enum {
+       FC_VU_SCR_REG_FUNC_FABRIC_NAME_CHANGE = 0x01
+};
+
+struct fc_scr_s {
+       u32 command:8;
+       u32 res:24;
+       u32 vu_reg_func:8; /* Vendor Unique Registrations */
+       u32 res1:16;
+       u32 reg_func:8;
+};
+
+/*
+ * Information category for Basic link data
+ */
+enum {
+       FC_CAT_NOP      = 0x0,
+       FC_CAT_ABTS     = 0x1,
+       FC_CAT_RMC      = 0x2,
+       FC_CAT_BA_ACC   = 0x4,
+       FC_CAT_BA_RJT   = 0x5,
+       FC_CAT_PRMT     = 0x6,
+};
+
+/*
+ * LS_RJT els reply payload
+ */
+struct fc_ls_rjt_s {
+       struct fc_els_cmd_s els_cmd;            /* ELS command code */
+       u32        res1:8;
+       u32        reason_code:8;               /* Reason code for reject */
+       u32        reason_code_expl:8;  /* Reason code explanation */
+       u32        vendor_unique:8;     /* Vendor specific */
+};
+
+/*
+ * LS_RJT reason codes
+ */
+enum {
+       FC_LS_RJT_RSN_INV_CMD_CODE      = 0x01,
+       FC_LS_RJT_RSN_LOGICAL_ERROR     = 0x03,
+       FC_LS_RJT_RSN_LOGICAL_BUSY      = 0x05,
+       FC_LS_RJT_RSN_PROTOCOL_ERROR    = 0x07,
+       FC_LS_RJT_RSN_UNABLE_TO_PERF_CMD = 0x09,
+       FC_LS_RJT_RSN_CMD_NOT_SUPP      = 0x0B,
+};
+
+/*
+ * LS_RJT reason code explanation
+ */
+enum {
+       FC_LS_RJT_EXP_NO_ADDL_INFO              = 0x00,
+       FC_LS_RJT_EXP_SPARMS_ERR_OPTIONS        = 0x01,
+       FC_LS_RJT_EXP_SPARMS_ERR_INI_CTL        = 0x03,
+       FC_LS_RJT_EXP_SPARMS_ERR_REC_CTL        = 0x05,
+       FC_LS_RJT_EXP_SPARMS_ERR_RXSZ           = 0x07,
+       FC_LS_RJT_EXP_SPARMS_ERR_CONSEQ         = 0x09,
+       FC_LS_RJT_EXP_SPARMS_ERR_CREDIT         = 0x0B,
+       FC_LS_RJT_EXP_INV_PORT_NAME             = 0x0D,
+       FC_LS_RJT_EXP_INV_NODE_FABRIC_NAME      = 0x0E,
+       FC_LS_RJT_EXP_INV_CSP                   = 0x0F,
+       FC_LS_RJT_EXP_INV_ASSOC_HDR             = 0x11,
+       FC_LS_RJT_EXP_ASSOC_HDR_REQD            = 0x13,
+       FC_LS_RJT_EXP_INV_ORIG_S_ID             = 0x15,
+       FC_LS_RJT_EXP_INV_OXID_RXID_COMB        = 0x17,
+       FC_LS_RJT_EXP_CMD_ALREADY_IN_PROG       = 0x19,
+       FC_LS_RJT_EXP_LOGIN_REQUIRED            = 0x1E,
+       FC_LS_RJT_EXP_INVALID_NPORT_ID          = 0x1F,
+       FC_LS_RJT_EXP_INSUFF_RES                = 0x29,
+       FC_LS_RJT_EXP_CMD_NOT_SUPP              = 0x2C,
+       FC_LS_RJT_EXP_INV_PAYLOAD_LEN           = 0x2D,
+};
+
+/*
+ * RRQ els command payload
+ */
+struct fc_rrq_s {
+       struct fc_els_cmd_s els_cmd;    /* ELS command code */
+       u32        res1:8;
+       u32        s_id:24;     /* exchange originator S_ID */
+
+       u32        ox_id:16;    /* originator exchange ID */
+       u32        rx_id:16;    /* responder exchange ID */
+
+       u32        res2[8];     /* optional association header */
+};
+
+/*
+ * ABTS BA_ACC reply payload
+ */
+struct fc_ba_acc_s {
+       u32        seq_id_valid:8;      /* set to 0x00 for Abort Exchange */
+       u32        seq_id:8;    /* invalid for Abort Exchange */
+       u32        res2:16;
+       u32        ox_id:16;    /* OX_ID from ABTS frame */
+       u32        rx_id:16;    /* RX_ID from ABTS frame */
+       u32        low_seq_cnt:16;      /* set to 0x0000 for Abort Exchange */
+       u32        high_seq_cnt:16;/* set to 0xFFFF for Abort Exchange */
+};
+
+/*
+ * ABTS BA_RJT reject payload
+ */
+struct fc_ba_rjt_s {
+       u32        res1:8;              /* Reserved */
+       u32        reason_code:8;       /* reason code for reject */
+       u32        reason_expl:8;       /* reason code explanation */
+       u32        vendor_unique:8;/* vendor unique reason code,set to 0 */
+};
+
+/*
+ * TPRLO logout parameter page
+ */
+struct fc_tprlo_params_page_s {
+u32        type:8;
+u32        type_ext:8;
+
+#ifdef __BIGENDIAN
+       u32        opa_valid:1;
+       u32        rpa_valid:1;
+       u32        tpo_nport_valid:1;
+       u32        global_process_logout:1;
+       u32        res1:12;
+#else
+       u32        res1:12;
+       u32        global_process_logout:1;
+       u32        tpo_nport_valid:1;
+       u32        rpa_valid:1;
+       u32        opa_valid:1;
+#endif
+
+       u32        orig_process_assc;
+       u32        resp_process_assc;
+
+       u32        res2:8;
+       u32        tpo_nport_id;
+};
+
+/*
+ * TPRLO ELS command payload
+ */
+struct fc_tprlo_s {
+       u32        command:8;
+       u32        page_len:8;
+       u32        payload_len:16;
+
+       struct fc_tprlo_params_page_s tprlo_params[1];
+};
+
+enum fc_tprlo_type {
+       FC_GLOBAL_LOGO = 1,
+       FC_TPR_LOGO
+};
+
+/*
+ * TPRLO els command ACC payload
+ */
+struct fc_tprlo_acc_s {
+       u32     command:8;
+       u32     page_len:8;
+       u32     payload_len:16;
+       struct fc_prlo_acc_params_page_s tprlo_acc_params[1];
+};
+
+/*
+ * RSCN els command req payload
+ */
+#define FC_RSCN_PGLEN  0x4
+
+enum fc_rscn_format {
+       FC_RSCN_FORMAT_PORTID   = 0x0,
+       FC_RSCN_FORMAT_AREA     = 0x1,
+       FC_RSCN_FORMAT_DOMAIN   = 0x2,
+       FC_RSCN_FORMAT_FABRIC   = 0x3,
+};
+
+struct fc_rscn_event_s {
+       u32        format:2;
+       u32        qualifier:4;
+       u32        resvd:2;
+       u32        portid:24;
+};
+
+struct fc_rscn_pl_s {
+       u8         command;
+       u8         pagelen;
+       u16        payldlen;
+       struct fc_rscn_event_s event[1];
+};
+
+/*
+ * ECHO els command req payload
+ */
+struct fc_echo_s {
+       struct fc_els_cmd_s els_cmd;
+};
+
+/*
+ * RNID els command
+ */
+
+#define RNID_NODEID_DATA_FORMAT_COMMON                 0x00
+#define RNID_NODEID_DATA_FORMAT_FCP3                   0x08
+#define RNID_NODEID_DATA_FORMAT_DISCOVERY              0xDF
+
+#define RNID_ASSOCIATED_TYPE_UNKNOWN                   0x00000001
+#define RNID_ASSOCIATED_TYPE_OTHER                      0x00000002
+#define RNID_ASSOCIATED_TYPE_HUB                        0x00000003
+#define RNID_ASSOCIATED_TYPE_SWITCH                     0x00000004
+#define RNID_ASSOCIATED_TYPE_GATEWAY                    0x00000005
+#define RNID_ASSOCIATED_TYPE_STORAGE_DEVICE             0x00000009
+#define RNID_ASSOCIATED_TYPE_HOST                       0x0000000A
+#define RNID_ASSOCIATED_TYPE_STORAGE_SUBSYSTEM          0x0000000B
+#define RNID_ASSOCIATED_TYPE_STORAGE_ACCESS_DEVICE      0x0000000E
+#define RNID_ASSOCIATED_TYPE_NAS_SERVER                 0x00000011
+#define RNID_ASSOCIATED_TYPE_BRIDGE                     0x00000002
+#define RNID_ASSOCIATED_TYPE_VIRTUALIZATION_DEVICE      0x00000003
+#define RNID_ASSOCIATED_TYPE_MULTI_FUNCTION_DEVICE      0x000000FF
+
+/*
+ * RNID els command payload
+ */
+struct fc_rnid_cmd_s {
+       struct fc_els_cmd_s els_cmd;
+       u32        node_id_data_format:8;
+       u32        reserved:24;
+};
+
+/*
+ * RNID els response payload
+ */
+
+struct fc_rnid_common_id_data_s {
+       wwn_t           port_name;
+       wwn_t           node_name;
+};
+
+struct fc_rnid_general_topology_data_s {
+       u32        vendor_unique[4];
+       u32        asso_type;
+       u32        phy_port_num;
+       u32        num_attached_nodes;
+       u32        node_mgmt:8;
+       u32        ip_version:8;
+       u32        udp_tcp_port_num:16;
+       u32        ip_address[4];
+       u32        reserved:16;
+       u32        vendor_specific:16;
+};
+
+struct fc_rnid_acc_s {
+       struct fc_els_cmd_s els_cmd;
+       u32        node_id_data_format:8;
+       u32        common_id_data_length:8;
+       u32        reserved:8;
+       u32        specific_id_data_length:8;
+       struct fc_rnid_common_id_data_s common_id_data;
+       struct fc_rnid_general_topology_data_s gen_topology_data;
+};
+
+#define RNID_ASSOCIATED_TYPE_UNKNOWN                    0x00000001
+#define RNID_ASSOCIATED_TYPE_OTHER                      0x00000002
+#define RNID_ASSOCIATED_TYPE_HUB                        0x00000003
+#define RNID_ASSOCIATED_TYPE_SWITCH                     0x00000004
+#define RNID_ASSOCIATED_TYPE_GATEWAY                    0x00000005
+#define RNID_ASSOCIATED_TYPE_STORAGE_DEVICE             0x00000009
+#define RNID_ASSOCIATED_TYPE_HOST                       0x0000000A
+#define RNID_ASSOCIATED_TYPE_STORAGE_SUBSYSTEM          0x0000000B
+#define RNID_ASSOCIATED_TYPE_STORAGE_ACCESS_DEVICE      0x0000000E
+#define RNID_ASSOCIATED_TYPE_NAS_SERVER                 0x00000011
+#define RNID_ASSOCIATED_TYPE_BRIDGE                     0x00000002
+#define RNID_ASSOCIATED_TYPE_VIRTUALIZATION_DEVICE      0x00000003
+#define RNID_ASSOCIATED_TYPE_MULTI_FUNCTION_DEVICE      0x000000FF
+
+enum fc_rpsc_speed_cap {
+       RPSC_SPEED_CAP_1G = 0x8000,
+       RPSC_SPEED_CAP_2G = 0x4000,
+       RPSC_SPEED_CAP_4G = 0x2000,
+       RPSC_SPEED_CAP_10G = 0x1000,
+       RPSC_SPEED_CAP_8G = 0x0800,
+       RPSC_SPEED_CAP_16G = 0x0400,
+
+       RPSC_SPEED_CAP_UNKNOWN = 0x0001,
+};
+
+enum fc_rpsc_op_speed {
+       RPSC_OP_SPEED_1G = 0x8000,
+       RPSC_OP_SPEED_2G = 0x4000,
+       RPSC_OP_SPEED_4G = 0x2000,
+       RPSC_OP_SPEED_10G = 0x1000,
+       RPSC_OP_SPEED_8G = 0x0800,
+       RPSC_OP_SPEED_16G = 0x0400,
+
+       RPSC_OP_SPEED_NOT_EST = 0x0001, /*! speed not established */
+};
+
+struct fc_rpsc_speed_info_s {
+       u16        port_speed_cap;      /*! see enum fc_rpsc_speed_cap */
+       u16        port_op_speed;       /*! see enum fc_rpsc_op_speed */
+};
+
+enum link_e2e_beacon_subcmd {
+       LINK_E2E_BEACON_ON = 1,
+       LINK_E2E_BEACON_OFF = 2
+};
+
+enum beacon_type {
+       BEACON_TYPE_NORMAL      = 1,    /*! Normal Beaconing. Green */
+       BEACON_TYPE_WARN        = 2,    /*! Warning Beaconing. Yellow/Amber */
+       BEACON_TYPE_CRITICAL    = 3     /*! Critical Beaconing. Red */
+};
+
+struct link_e2e_beacon_param_s {
+       u8         beacon_type; /* Beacon Type. See enum beacon_type */
+       u8         beacon_frequency;
+                                       /* Beacon frequency. Number of blinks
+                                        * per 10 seconds
+                                        */
+       u16        beacon_duration;/* Beacon duration (in Seconds). The
+                                        * command operation should be
+                                        * terminated at the end of this
+                                        * timeout value.
+                                        *
+                                        * Ignored if diag_sub_cmd is
+                                        * LINK_E2E_BEACON_OFF.
+                                        *
+                                        * If 0, beaconing will continue till a
+                                        * BEACON OFF request is received
+                                        */
+};
+
+/*
+ * Link E2E beacon request/good response format.
+ * For LS_RJTs use struct fc_ls_rjt_s
+ */
+struct link_e2e_beacon_req_s {
+       u32        ls_code;     /*! FC_ELS_E2E_LBEACON in requests *
+                                        *or FC_ELS_ACC in good replies */
+       u32        ls_sub_cmd;  /*! See enum link_e2e_beacon_subcmd */
+       struct link_e2e_beacon_param_s beacon_parm;
+};
+
+/**
+ * If RPSC request is sent to the Domain Controller, the request is for
+ * all the ports within that domain (TODO - I don't think FOS implements
+ * this...).
+ */
+struct fc_rpsc_cmd_s {
+       struct fc_els_cmd_s els_cmd;
+};
+
+/*
+ * RPSC Acc
+ */
+struct fc_rpsc_acc_s {
+       u32        command:8;
+       u32        rsvd:8;
+       u32        num_entries:16;
+
+       struct fc_rpsc_speed_info_s speed_info[1];
+};
+
+/**
+ * If RPSC2 request is sent to the Domain Controller,
+ */
+#define FC_BRCD_TOKEN    0x42524344
+
+struct fc_rpsc2_cmd_s {
+       struct fc_els_cmd_s els_cmd;
+       u32     token;
+       u16     resvd;
+       u16     num_pids;       /* Number of pids in the request */
+       struct  {
+               u32     rsvd1:8;
+               u32     pid:24;         /* port identifier */
+       } pid_list[1];
+};
+
+enum fc_rpsc2_port_type {
+       RPSC2_PORT_TYPE_UNKNOWN = 0,
+       RPSC2_PORT_TYPE_NPORT   = 1,
+       RPSC2_PORT_TYPE_NLPORT  = 2,
+       RPSC2_PORT_TYPE_NPIV_PORT  = 0x5f,
+       RPSC2_PORT_TYPE_NPORT_TRUNK  = 0x6f,
+};
+/*
+ * RPSC2 portInfo entry structure
+ */
+struct fc_rpsc2_port_info_s {
+    u32    pid;        /* PID */
+    u16    resvd1;
+    u16    index;      /* port number / index */
+    u8     resvd2;
+    u8    type;        /* port type N/NL/... */
+    u16    speed;      /* port Operating Speed */
+};
+
+/*
+ * RPSC2 Accept payload
+ */
+struct fc_rpsc2_acc_s {
+       u8        els_cmd;
+       u8        resvd;
+    u16       num_pids;  /* Number of pids in the request */
+    struct fc_rpsc2_port_info_s port_info[1];    /* port information */
+};
+
+/**
+ * bit fields so that multiple classes can be specified
+ */
+enum fc_cos {
+       FC_CLASS_2      = 0x04,
+       FC_CLASS_3      = 0x08,
+       FC_CLASS_2_3    = 0x0C,
+};
+
+/*
+ * symbolic name
+ */
+struct fc_symname_s {
+       u8         symname[FC_SYMNAME_MAX];
+};
+
+struct fc_alpabm_s {
+       u8         alpa_bm[FC_ALPA_MAX / 8];
+};
+
+/*
+ * protocol default timeout values
+ */
+#define FC_ED_TOV              2
+#define FC_REC_TOV             (FC_ED_TOV + 1)
+#define FC_RA_TOV              10
+#define FC_ELS_TOV             (2 * FC_RA_TOV)
+#define FC_FCCT_TOV            (3 * FC_RA_TOV)
+
+/*
+ * virtual fabric related defines
+ */
+#define FC_VF_ID_NULL    0     /*  must not be used as VF_ID */
+#define FC_VF_ID_MIN     1
+#define FC_VF_ID_MAX     0xEFF
+#define FC_VF_ID_CTL     0xFEF /*  control VF_ID */
+
+/**
+ * Virtual Fabric Tagging header format
+ * @caution This is defined only in BIG ENDIAN format.
+ */
+struct fc_vft_s {
+       u32        r_ctl:8;
+       u32        ver:2;
+       u32        type:4;
+       u32        res_a:2;
+       u32        priority:3;
+       u32        vf_id:12;
+       u32        res_b:1;
+       u32        hopct:8;
+       u32        res_c:24;
+};
+
+/*
+ * FCP
+ */
+enum {
+       FCP_RJT         = 0x01000000,   /* SRR reject */
+       FCP_SRR_ACCEPT  = 0x02000000,   /* SRR accept */
+       FCP_SRR         = 0x14000000,   /* Sequence Retransmission Request */
+};
+
+/*
+ * SRR FC-4 LS payload
+ */
+struct fc_srr_s {
+       u32     ls_cmd;
+       u32        ox_id:16;    /* ox-id */
+       u32        rx_id:16;    /* rx-id */
+       u32        ro;          /* relative offset */
+       u32        r_ctl:8;             /* R_CTL for I.U. */
+       u32        res:24;
+};
+
+
+/*
+ * FCP_CMND definitions
+ */
+#define FCP_CMND_CDB_LEN    16
+#define FCP_CMND_LUN_LEN    8
+
+struct fcp_cmnd_s {
+       lun_t           lun;            /* 64-bit LU number */
+       u8         crn;         /* command reference number */
+#ifdef __BIGENDIAN
+       u8         resvd:1,
+                       priority:4,     /* FCP-3: SAM-3 priority */
+                       taskattr:3;     /* scsi task attribute */
+#else
+       u8         taskattr:3,  /* scsi task attribute */
+                       priority:4,     /* FCP-3: SAM-3 priority */
+                       resvd:1;
+#endif
+       u8         tm_flags;    /* task management flags */
+#ifdef __BIGENDIAN
+       u8         addl_cdb_len:6,      /* additional CDB length words */
+                       iodir:2;        /* read/write FCP_DATA IUs */
+#else
+       u8         iodir:2,     /* read/write FCP_DATA IUs */
+                       addl_cdb_len:6; /* additional CDB length */
+#endif
+       scsi_cdb_t      cdb;
+
+       /*
+        * !!! additional cdb bytes follows here!!!
+        */
+       u32        fcp_dl;      /* bytes to be transferred */
+};
+
+#define fcp_cmnd_cdb_len(_cmnd) ((_cmnd)->addl_cdb_len * 4 + FCP_CMND_CDB_LEN)
+#define fcp_cmnd_fcpdl(_cmnd)  ((&(_cmnd)->fcp_dl)[(_cmnd)->addl_cdb_len])
+
+/*
+ * struct fcp_cmnd_s .iodir field values
+ */
+enum fcp_iodir {
+       FCP_IODIR_NONE  = 0,
+       FCP_IODIR_WRITE = 1,
+       FCP_IODIR_READ  = 2,
+       FCP_IODIR_RW    = 3,
+};
+
+/*
+ * Task attribute field
+ */
+enum {
+       FCP_TASK_ATTR_SIMPLE    = 0,
+       FCP_TASK_ATTR_HOQ       = 1,
+       FCP_TASK_ATTR_ORDERED   = 2,
+       FCP_TASK_ATTR_ACA       = 4,
+       FCP_TASK_ATTR_UNTAGGED  = 5,    /* obsolete in FCP-3 */
+};
+
+/*
+ * Task management flags field - only one bit shall be set
+ */
+enum fcp_tm_cmnd {
+       FCP_TM_ABORT_TASK_SET   = BIT(1),
+       FCP_TM_CLEAR_TASK_SET   = BIT(2),
+       FCP_TM_LUN_RESET        = BIT(4),
+       FCP_TM_TARGET_RESET     = BIT(5),       /* obsolete in FCP-3 */
+       FCP_TM_CLEAR_ACA        = BIT(6),
+};
+
+/*
+ * FCP_XFER_RDY IU defines
+ */
+struct fcp_xfer_rdy_s {
+       u32        data_ro;
+       u32        burst_len;
+       u32        reserved;
+};
+
+/*
+ * FCP_RSP residue flags
+ */
+enum fcp_residue {
+       FCP_NO_RESIDUE = 0,     /* no residue */
+       FCP_RESID_OVER = 1,     /* more data left that was not sent */
+       FCP_RESID_UNDER = 2,    /* less data than requested */
+};
+
+enum {
+       FCP_RSPINFO_GOOD = 0,
+       FCP_RSPINFO_DATALEN_MISMATCH = 1,
+       FCP_RSPINFO_CMND_INVALID = 2,
+       FCP_RSPINFO_ROLEN_MISMATCH = 3,
+       FCP_RSPINFO_TM_NOT_SUPP = 4,
+       FCP_RSPINFO_TM_FAILED = 5,
+};
+
+struct fcp_rspinfo_s {
+       u32        res0:24;
+       u32        rsp_code:8;  /* response code (as above) */
+       u32        res1;
+};
+
+struct fcp_resp_s {
+       u32        reserved[2]; /* 2 words reserved */
+       u16        reserved2;
+#ifdef __BIGENDIAN
+       u8         reserved3:3;
+       u8         fcp_conf_req:1;      /* FCP_CONF is requested */
+       u8         resid_flags:2;       /* underflow/overflow */
+       u8         sns_len_valid:1;/* sense len is valid */
+       u8         rsp_len_valid:1;/* response len is valid */
+#else
+       u8         rsp_len_valid:1;/* response len is valid */
+       u8         sns_len_valid:1;/* sense len is valid */
+       u8         resid_flags:2;       /* underflow/overflow */
+       u8         fcp_conf_req:1;      /* FCP_CONF is requested */
+       u8         reserved3:3;
+#endif
+       u8         scsi_status; /* one byte SCSI status */
+       u32        residue;     /* residual data bytes */
+       u32        sns_len;     /* length od sense info */
+       u32        rsp_len;     /* length of response info */
+};
+
+#define fcp_snslen(__fcprsp)   ((__fcprsp)->sns_len_valid ?            \
+                                       (__fcprsp)->sns_len : 0)
+#define fcp_rsplen(__fcprsp)   ((__fcprsp)->rsp_len_valid ?            \
+                                       (__fcprsp)->rsp_len : 0)
+#define fcp_rspinfo(__fcprsp)  ((struct fcp_rspinfo_s *)((__fcprsp) + 1))
+#define fcp_snsinfo(__fcprsp)  (((u8 *)fcp_rspinfo(__fcprsp)) +        \
+                                               fcp_rsplen(__fcprsp))
+
+struct fcp_cmnd_fr_s {
+       struct fchs_s fchs;
+       struct fcp_cmnd_s fcp;
+};
+
+/*
+ * CT
+ */
+struct ct_hdr_s {
+       u32     rev_id:8;       /* Revision of the CT */
+       u32     in_id:24;       /* Initiator Id */
+       u32     gs_type:8;      /* Generic service Type */
+       u32     gs_sub_type:8;  /* Generic service sub type */
+       u32     options:8;      /* options */
+       u32     rsvrd:8;        /* reserved */
+       u32     cmd_rsp_code:16;/* ct command/response code */
+       u32     max_res_size:16;/* maximum/residual size */
+       u32     frag_id:8;      /* fragment ID */
+       u32     reason_code:8;  /* reason code */
+       u32     exp_code:8;     /* explanation code */
+       u32     vendor_unq:8;   /* vendor unique */
+};
+
+/*
+ * defines for the Revision
+ */
+enum {
+       CT_GS3_REVISION = 0x01,
+};
+
+/*
+ * defines for gs_type
+ */
+enum {
+       CT_GSTYPE_KEYSERVICE    = 0xF7,
+       CT_GSTYPE_ALIASSERVICE  = 0xF8,
+       CT_GSTYPE_MGMTSERVICE   = 0xFA,
+       CT_GSTYPE_TIMESERVICE   = 0xFB,
+       CT_GSTYPE_DIRSERVICE    = 0xFC,
+};
+
+/*
+ * defines for gs_sub_type for gs type directory service
+ */
+enum {
+       CT_GSSUBTYPE_NAMESERVER = 0x02,
+};
+
+/*
+ * defines for gs_sub_type for gs type management service
+ */
+enum {
+       CT_GSSUBTYPE_CFGSERVER  = 0x01,
+       CT_GSSUBTYPE_UNZONED_NS = 0x02,
+       CT_GSSUBTYPE_ZONESERVER = 0x03,
+       CT_GSSUBTYPE_LOCKSERVER = 0x04,
+       CT_GSSUBTYPE_HBA_MGMTSERVER = 0x10,     /* for FDMI */
+};
+
+/*
+ * defines for CT response code field
+ */
+enum {
+       CT_RSP_REJECT = 0x8001,
+       CT_RSP_ACCEPT = 0x8002,
+};
+
+/*
+ * defintions for CT reason code
+ */
+enum {
+       CT_RSN_INV_CMD          = 0x01,
+       CT_RSN_INV_VER          = 0x02,
+       CT_RSN_LOGIC_ERR        = 0x03,
+       CT_RSN_INV_SIZE         = 0x04,
+       CT_RSN_LOGICAL_BUSY     = 0x05,
+       CT_RSN_PROTO_ERR        = 0x07,
+       CT_RSN_UNABLE_TO_PERF   = 0x09,
+       CT_RSN_NOT_SUPP                 = 0x0B,
+       CT_RSN_SERVER_NOT_AVBL  = 0x0D,
+       CT_RSN_SESSION_COULD_NOT_BE_ESTBD = 0x0E,
+       CT_RSN_VENDOR_SPECIFIC  = 0xFF,
+
+};
+
+/*
+ * definitions for explanations code for Name server
+ */
+enum {
+       CT_NS_EXP_NOADDITIONAL  = 0x00,
+       CT_NS_EXP_ID_NOT_REG    = 0x01,
+       CT_NS_EXP_PN_NOT_REG    = 0x02,
+       CT_NS_EXP_NN_NOT_REG    = 0x03,
+       CT_NS_EXP_CS_NOT_REG    = 0x04,
+       CT_NS_EXP_IPN_NOT_REG   = 0x05,
+       CT_NS_EXP_IPA_NOT_REG   = 0x06,
+       CT_NS_EXP_FT_NOT_REG    = 0x07,
+       CT_NS_EXP_SPN_NOT_REG   = 0x08,
+       CT_NS_EXP_SNN_NOT_REG   = 0x09,
+       CT_NS_EXP_PT_NOT_REG    = 0x0A,
+       CT_NS_EXP_IPP_NOT_REG   = 0x0B,
+       CT_NS_EXP_FPN_NOT_REG   = 0x0C,
+       CT_NS_EXP_HA_NOT_REG    = 0x0D,
+       CT_NS_EXP_FD_NOT_REG    = 0x0E,
+       CT_NS_EXP_FF_NOT_REG    = 0x0F,
+       CT_NS_EXP_ACCESSDENIED  = 0x10,
+       CT_NS_EXP_UNACCEPTABLE_ID = 0x11,
+       CT_NS_EXP_DATABASEEMPTY         = 0x12,
+       CT_NS_EXP_NOT_REG_IN_SCOPE      = 0x13,
+       CT_NS_EXP_DOM_ID_NOT_PRESENT    = 0x14,
+       CT_NS_EXP_PORT_NUM_NOT_PRESENT  = 0x15,
+       CT_NS_EXP_NO_DEVICE_ATTACHED    = 0x16
+};
+
+/*
+ * defintions for the explanation code for all servers
+ */
+enum {
+       CT_EXP_AUTH_EXCEPTION                   = 0xF1,
+       CT_EXP_DB_FULL                                  = 0xF2,
+       CT_EXP_DB_EMPTY                                 = 0xF3,
+       CT_EXP_PROCESSING_REQ                   = 0xF4,
+       CT_EXP_UNABLE_TO_VERIFY_CONN    = 0xF5,
+       CT_EXP_DEVICES_NOT_IN_CMN_ZONE  = 0xF6
+};
+
+/*
+ * Command codes for Name server
+ */
+enum {
+       GS_GID_PN       = 0x0121,       /* Get Id on port name */
+       GS_GPN_ID       = 0x0112,       /* Get port name on ID */
+       GS_GNN_ID       = 0x0113,       /* Get node name on ID */
+       GS_GID_FT       = 0x0171,       /* Get Id on FC4 type */
+       GS_GSPN_ID      = 0x0118,       /* Get symbolic PN on ID */
+       GS_RFT_ID       = 0x0217,       /* Register fc4type on ID */
+       GS_RSPN_ID      = 0x0218,       /* Register symbolic PN on ID */
+       GS_RPN_ID       = 0x0212,       /* Register port name */
+       GS_RNN_ID       = 0x0213,       /* Register node name */
+       GS_RCS_ID       = 0x0214,       /* Register class of service */
+       GS_RPT_ID       = 0x021A,       /* Register port type */
+       GS_GA_NXT       = 0x0100,       /* Get all next */
+       GS_RFF_ID       = 0x021F,       /* Register FC4 Feature         */
+};
+
+struct fcgs_id_req_s{
+       u32 rsvd:8;
+       u32 dap:24; /* port identifier */
+};
+#define fcgs_gpnid_req_t struct fcgs_id_req_s
+#define fcgs_gnnid_req_t struct fcgs_id_req_s
+#define fcgs_gspnid_req_t struct fcgs_id_req_s
+
+struct fcgs_gidpn_req_s {
+       wwn_t   port_name;      /* port wwn */
+};
+
+struct fcgs_gidpn_resp_s {
+       u32     rsvd:8;
+       u32     dap:24; /* port identifier */
+};
+
+/**
+ * RFT_ID
+ */
+struct fcgs_rftid_req_s {
+       u32     rsvd:8;
+       u32     dap:24;         /* port identifier */
+       u32     fc4_type[8];    /* fc4 types */
+};
+
+/**
+ * RFF_ID : Register FC4 features.
+ */
+
+#define FC_GS_FCP_FC4_FEATURE_INITIATOR  0x02
+#define FC_GS_FCP_FC4_FEATURE_TARGET    0x01
+
+struct fcgs_rffid_req_s {
+    u32    rsvd:8;
+    u32    dap:24;             /* port identifier      */
+    u32    rsvd1:16;
+    u32    fc4ftr_bits:8;              /* fc4 feature bits     */
+    u32    fc4_type:8;         /* corresponding FC4 Type */
+};
+
+/**
+ * GID_FT Request
+ */
+struct fcgs_gidft_req_s {
+       u8      reserved;
+       u8      domain_id;      /* domain, 0 - all fabric */
+       u8      area_id;        /* area, 0 - whole domain */
+       u8      fc4_type;       /* FC_TYPE_FCP for SCSI devices */
+};             /* GID_FT Request */
+
+/**
+ * GID_FT Response
+ */
+struct fcgs_gidft_resp_s {
+       u8              last:1; /* last port identifier flag */
+       u8              reserved:7;
+       u32     pid:24; /* port identifier */
+};             /* GID_FT Response */
+
+/**
+ * RSPN_ID
+ */
+struct fcgs_rspnid_req_s {
+       u32     rsvd:8;
+       u32     dap:24;         /* port identifier */
+       u8              spn_len;        /* symbolic port name length */
+       u8              spn[256];       /* symbolic port name */
+};
+
+/**
+ * RPN_ID
+ */
+struct fcgs_rpnid_req_s {
+       u32     rsvd:8;
+       u32     port_id:24;
+       wwn_t           port_name;
+};
+
+/**
+ * RNN_ID
+ */
+struct fcgs_rnnid_req_s {
+       u32     rsvd:8;
+       u32     port_id:24;
+       wwn_t           node_name;
+};
+
+/**
+ * RCS_ID
+ */
+struct fcgs_rcsid_req_s {
+       u32     rsvd:8;
+       u32     port_id:24;
+       u32     cos;
+};
+
+/**
+ * RPT_ID
+ */
+struct fcgs_rptid_req_s {
+       u32     rsvd:8;
+       u32     port_id:24;
+       u32     port_type:8;
+       u32     rsvd1:24;
+};
+
+/**
+ * GA_NXT Request
+ */
+struct fcgs_ganxt_req_s {
+       u32     rsvd:8;
+       u32     port_id:24;
+};
+
+/**
+ * GA_NXT Response
+ */
+struct fcgs_ganxt_rsp_s {
+       u32     port_type:8;    /* Port Type */
+       u32     port_id:24;     /* Port Identifier */
+       wwn_t           port_name;      /* Port Name */
+       u8              spn_len;        /* Length of Symbolic Port Name */
+       char            spn[255];       /* Symbolic Port Name */
+       wwn_t           node_name;      /* Node Name */
+       u8              snn_len;        /* Length of Symbolic Node Name */
+       char            snn[255];       /* Symbolic Node Name */
+       u8              ipa[8];         /* Initial Process Associator */
+       u8              ip[16];         /* IP Address */
+       u32     cos;            /* Class of Service */
+       u32     fc4types[8];    /* FC-4 TYPEs */
+       wwn_t           fabric_port_name;
+                                       /* Fabric Port Name */
+       u32     rsvd:8;         /* Reserved */
+       u32     hard_addr:24;   /* Hard Address */
+};
+
+/*
+ * Fabric Config Server
+ */
+
+/*
+ * Command codes for Fabric Configuration Server
+ */
+enum {
+       GS_FC_GFN_CMD   = 0x0114,       /* GS FC Get Fabric Name  */
+       GS_FC_GMAL_CMD  = 0x0116,       /* GS FC GMAL  */
+       GS_FC_TRACE_CMD = 0x0400,       /* GS FC Trace Route */
+       GS_FC_PING_CMD  = 0x0401,       /* GS FC Ping */
+};
+
+/*
+ * Source or Destination Port Tags.
+ */
+enum {
+       GS_FTRACE_TAG_NPORT_ID          = 1,
+       GS_FTRACE_TAG_NPORT_NAME        = 2,
+};
+
+/*
+* Port Value : Could be a Port id or wwn
+ */
+union fcgs_port_val_u {
+       u32     nport_id;
+       wwn_t           nport_wwn;
+};
+
+#define GS_FTRACE_MAX_HOP_COUNT        20
+#define GS_FTRACE_REVISION     1
+
+/*
+ * Ftrace Related Structures.
+ */
+
+/*
+ * STR (Switch Trace) Reject Reason Codes. From FC-SW.
+ */
+enum {
+       GS_FTRACE_STR_CMD_COMPLETED_SUCC        = 0,
+       GS_FTRACE_STR_CMD_NOT_SUPP_IN_NEXT_SWITCH,
+       GS_FTRACE_STR_NO_RESP_FROM_NEXT_SWITCH,
+       GS_FTRACE_STR_MAX_HOP_CNT_REACHED,
+       GS_FTRACE_STR_SRC_PORT_NOT_FOUND,
+       GS_FTRACE_STR_DST_PORT_NOT_FOUND,
+       GS_FTRACE_STR_DEVICES_NOT_IN_COMMON_ZONE,
+       GS_FTRACE_STR_NO_ROUTE_BW_PORTS,
+       GS_FTRACE_STR_NO_ADDL_EXPLN,
+       GS_FTRACE_STR_FABRIC_BUSY,
+       GS_FTRACE_STR_FABRIC_BUILD_IN_PROGRESS,
+       GS_FTRACE_STR_VENDOR_SPECIFIC_ERR_START = 0xf0,
+       GS_FTRACE_STR_VENDOR_SPECIFIC_ERR_END = 0xff,
+};
+
+/*
+ * Ftrace Request
+ */
+struct fcgs_ftrace_req_s {
+       u32     revision;
+       u16     src_port_tag;   /* Source Port tag */
+       u16     src_port_len;   /* Source Port len */
+       union fcgs_port_val_u src_port_val;     /* Source Port value */
+       u16     dst_port_tag;   /* Destination Port tag */
+       u16     dst_port_len;   /* Destination Port len */
+       union fcgs_port_val_u dst_port_val;     /* Destination Port value */
+       u32     token;
+       u8              vendor_id[8];   /* T10 Vendor Identifier */
+       u8              vendor_info[8]; /* Vendor specific Info */
+       u32     max_hop_cnt;    /* Max Hop Count */
+};
+
+/*
+ * Path info structure
+ */
+struct fcgs_ftrace_path_info_s {
+       wwn_t           switch_name;            /* Switch WWN */
+       u32     domain_id;
+       wwn_t           ingress_port_name;      /* Ingress ports wwn */
+       u32     ingress_phys_port_num;  /* Ingress ports physical port
+                                                * number
+                                                */
+       wwn_t           egress_port_name;       /* Ingress ports wwn */
+       u32     egress_phys_port_num;   /* Ingress ports physical port
+                                                * number
+                                                */
+};
+
+/*
+ * Ftrace Acc Response
+ */
+struct fcgs_ftrace_resp_s {
+       u32     revision;
+       u32     token;
+       u8              vendor_id[8];           /* T10 Vendor Identifier */
+       u8              vendor_info[8];         /* Vendor specific Info */
+       u32     str_rej_reason_code;    /* STR Reject Reason Code */
+       u32     num_path_info_entries;  /* No. of path info entries */
+       /*
+        * path info entry/entries.
+        */
+       struct fcgs_ftrace_path_info_s path_info[1];
+
+};
+
+/*
+* Fabric Config Server : FCPing
+ */
+
+/*
+ * FC Ping Request
+ */
+struct fcgs_fcping_req_s {
+       u32     revision;
+       u16     port_tag;
+       u16     port_len;       /* Port len */
+       union fcgs_port_val_u port_val; /* Port value */
+       u32     token;
+};
+
+/*
+ * FC Ping Response
+ */
+struct fcgs_fcping_resp_s {
+       u32     token;
+};
+
+/*
+ * Command codes for zone server query.
+ */
+enum {
+       ZS_GZME = 0x0124,       /* Get zone member extended */
+};
+
+/*
+ * ZS GZME request
+ */
+#define ZS_GZME_ZNAMELEN       32
+struct zs_gzme_req_s {
+       u8      znamelen;
+       u8      rsvd[3];
+       u8      zname[ZS_GZME_ZNAMELEN];
+};
+
+enum zs_mbr_type {
+       ZS_MBR_TYPE_PWWN        = 1,
+       ZS_MBR_TYPE_DOMPORT     = 2,
+       ZS_MBR_TYPE_PORTID      = 3,
+       ZS_MBR_TYPE_NWWN        = 4,
+};
+
+struct zs_mbr_wwn_s {
+       u8      mbr_type;
+       u8      rsvd[3];
+       wwn_t   wwn;
+};
+
+struct zs_query_resp_s {
+       u32     nmbrs;  /*  number of zone members */
+       struct zs_mbr_wwn_s     mbr[1];
+};
+
+/*
+ * GMAL Command ( Get ( interconnect Element) Management Address List)
+ * To retrieve the IP Address of a Switch.
+ */
+
+#define CT_GMAL_RESP_PREFIX_TELNET      "telnet://"
+#define CT_GMAL_RESP_PREFIX_HTTP        "http://"
+
+/*  GMAL/GFN request */
+struct fcgs_req_s {
+       wwn_t    wwn;   /* PWWN/NWWN */
+};
+
+#define fcgs_gmal_req_t struct fcgs_req_s
+#define fcgs_gfn_req_t struct fcgs_req_s
+
+/* Accept Response to GMAL */
+struct fcgs_gmal_resp_s {
+       u32     ms_len;   /* Num of entries */
+       u8      ms_ma[256];
+};
+
+struct fcgs_gmal_entry_s {
+       u8  len;
+       u8  prefix[7]; /* like "http://" */
+       u8  ip_addr[248];
+};
+
+/*
+ * FDMI
+ */
+/*
+ * FDMI Command Codes
+ */
+#define        FDMI_GRHL               0x0100
+#define        FDMI_GHAT               0x0101
+#define        FDMI_GRPL               0x0102
+#define        FDMI_GPAT               0x0110
+#define        FDMI_RHBA               0x0200
+#define        FDMI_RHAT               0x0201
+#define        FDMI_RPRT               0x0210
+#define        FDMI_RPA                0x0211
+#define        FDMI_DHBA               0x0300
+#define        FDMI_DPRT               0x0310
+
+/*
+ * FDMI reason codes
+ */
+#define        FDMI_NO_ADDITIONAL_EXP          0x00
+#define        FDMI_HBA_ALREADY_REG            0x10
+#define        FDMI_HBA_ATTRIB_NOT_REG         0x11
+#define        FDMI_HBA_ATTRIB_MULTIPLE        0x12
+#define        FDMI_HBA_ATTRIB_LENGTH_INVALID  0x13
+#define        FDMI_HBA_ATTRIB_NOT_PRESENT     0x14
+#define        FDMI_PORT_ORIG_NOT_IN_LIST      0x15
+#define        FDMI_PORT_HBA_NOT_IN_LIST       0x16
+#define        FDMI_PORT_ATTRIB_NOT_REG        0x20
+#define        FDMI_PORT_NOT_REG               0x21
+#define        FDMI_PORT_ATTRIB_MULTIPLE       0x22
+#define        FDMI_PORT_ATTRIB_LENGTH_INVALID 0x23
+#define        FDMI_PORT_ALREADY_REGISTEREED   0x24
+
+/*
+ * FDMI Transmission Speed Mask values
+ */
+#define        FDMI_TRANS_SPEED_1G             0x00000001
+#define        FDMI_TRANS_SPEED_2G             0x00000002
+#define        FDMI_TRANS_SPEED_10G            0x00000004
+#define        FDMI_TRANS_SPEED_4G             0x00000008
+#define        FDMI_TRANS_SPEED_8G             0x00000010
+#define        FDMI_TRANS_SPEED_16G            0x00000020
+#define        FDMI_TRANS_SPEED_UNKNOWN        0x00008000
+
+/*
+ * FDMI HBA attribute types
+ */
+enum fdmi_hba_attribute_type {
+       FDMI_HBA_ATTRIB_NODENAME = 1,   /* 0x0001 */
+       FDMI_HBA_ATTRIB_MANUFACTURER,   /* 0x0002 */
+       FDMI_HBA_ATTRIB_SERIALNUM,      /* 0x0003 */
+       FDMI_HBA_ATTRIB_MODEL,          /* 0x0004 */
+       FDMI_HBA_ATTRIB_MODEL_DESC,     /* 0x0005 */
+       FDMI_HBA_ATTRIB_HW_VERSION,     /* 0x0006 */
+       FDMI_HBA_ATTRIB_DRIVER_VERSION, /* 0x0007 */
+       FDMI_HBA_ATTRIB_ROM_VERSION,    /* 0x0008 */
+       FDMI_HBA_ATTRIB_FW_VERSION,     /* 0x0009 */
+       FDMI_HBA_ATTRIB_OS_NAME,        /* 0x000A */
+       FDMI_HBA_ATTRIB_MAX_CT,         /* 0x000B */
+
+       FDMI_HBA_ATTRIB_MAX_TYPE
+};
+
+/*
+ * FDMI Port attribute types
+ */
+enum fdmi_port_attribute_type {
+       FDMI_PORT_ATTRIB_FC4_TYPES = 1, /* 0x0001 */
+       FDMI_PORT_ATTRIB_SUPP_SPEED,    /* 0x0002 */
+       FDMI_PORT_ATTRIB_PORT_SPEED,    /* 0x0003 */
+       FDMI_PORT_ATTRIB_FRAME_SIZE,    /* 0x0004 */
+       FDMI_PORT_ATTRIB_DEV_NAME,      /* 0x0005 */
+       FDMI_PORT_ATTRIB_HOST_NAME,     /* 0x0006 */
+
+       FDMI_PORT_ATTR_MAX_TYPE
+};
+
+/*
+ * FDMI attribute
+ */
+struct fdmi_attr_s {
+       u16        type;
+       u16        len;
+       u8         value[1];
+};
+
+/*
+ * HBA Attribute Block
+ */
+struct fdmi_hba_attr_s {
+       u32        attr_count;  /* # of attributes */
+       struct fdmi_attr_s hba_attr;    /* n attributes */
+};
+
+/*
+ * Registered Port List
+ */
+struct fdmi_port_list_s {
+       u32        num_ports;   /* number Of Port Entries */
+       wwn_t           port_entry;     /* one or more */
+};
+
+/*
+ * Port Attribute Block
+ */
+struct fdmi_port_attr_s {
+       u32        attr_count;  /* # of attributes */
+       struct fdmi_attr_s port_attr;   /* n attributes */
+};
+
+/*
+ * FDMI Register HBA Attributes
+ */
+struct fdmi_rhba_s {
+       wwn_t           hba_id;         /* HBA Identifier */
+       struct fdmi_port_list_s port_list;      /* Registered Port List */
+       struct fdmi_hba_attr_s hba_attr_blk;    /* HBA attribute block */
+};
+
+/*
+ * FDMI Register Port
+ */
+struct fdmi_rprt_s {
+       wwn_t           hba_id;         /* HBA Identifier */
+       wwn_t           port_name;      /* Port wwn */
+       struct fdmi_port_attr_s port_attr_blk;  /* Port Attr Block */
+};
+
+/*
+ * FDMI Register Port Attributes
+ */
+struct fdmi_rpa_s {
+       wwn_t           port_name;      /* port wwn */
+       struct fdmi_port_attr_s port_attr_blk;  /* Port Attr Block */
+};
+
+#pragma pack()
+
+#endif /* __BFA_FC_H__ */
diff --git a/drivers/scsi/bfa/bfa_fcbuild.c b/drivers/scsi/bfa/bfa_fcbuild.c
new file mode 100644 (file)
index 0000000..b7d2657
--- /dev/null
@@ -0,0 +1,1410 @@
+/*
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
+ * All rights reserved
+ * www.brocade.com
+ *
+ * Linux driver for Brocade Fibre Channel Host Bus Adapter.
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License (GPL) Version 2 as
+ * published by the Free Software Foundation
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * General Public License for more details.
+ */
+/*
+ * fcbuild.c - FC link service frame building and parsing routines
+ */
+
+#include "bfa_os_inc.h"
+#include "bfa_fcbuild.h"
+
+/*
+ * static build functions
+ */
+static void     fc_els_rsp_build(struct fchs_s *fchs, u32 d_id, u32 s_id,
+                                u16 ox_id);
+static void     fc_bls_rsp_build(struct fchs_s *fchs, u32 d_id, u32 s_id,
+                                u16 ox_id);
+static struct fchs_s fc_els_req_tmpl;
+static struct fchs_s fc_els_rsp_tmpl;
+static struct fchs_s fc_bls_req_tmpl;
+static struct fchs_s fc_bls_rsp_tmpl;
+static struct fc_ba_acc_s ba_acc_tmpl;
+static struct fc_logi_s plogi_tmpl;
+static struct fc_prli_s prli_tmpl;
+static struct fc_rrq_s rrq_tmpl;
+static struct fchs_s fcp_fchs_tmpl;
+
+void
+fcbuild_init(void)
+{
+       /*
+        * fc_els_req_tmpl
+        */
+       fc_els_req_tmpl.routing = FC_RTG_EXT_LINK;
+       fc_els_req_tmpl.cat_info = FC_CAT_LD_REQUEST;
+       fc_els_req_tmpl.type = FC_TYPE_ELS;
+       fc_els_req_tmpl.f_ctl =
+               bfa_os_hton3b(FCTL_SEQ_INI | FCTL_FS_EXCH | FCTL_END_SEQ |
+                             FCTL_SI_XFER);
+       fc_els_req_tmpl.rx_id = FC_RXID_ANY;
+
+       /*
+        * fc_els_rsp_tmpl
+        */
+       fc_els_rsp_tmpl.routing = FC_RTG_EXT_LINK;
+       fc_els_rsp_tmpl.cat_info = FC_CAT_LD_REPLY;
+       fc_els_rsp_tmpl.type = FC_TYPE_ELS;
+       fc_els_rsp_tmpl.f_ctl =
+               bfa_os_hton3b(FCTL_EC_RESP | FCTL_SEQ_INI | FCTL_LS_EXCH |
+                             FCTL_END_SEQ | FCTL_SI_XFER);
+       fc_els_rsp_tmpl.rx_id = FC_RXID_ANY;
+
+       /*
+        * fc_bls_req_tmpl
+        */
+       fc_bls_req_tmpl.routing = FC_RTG_BASIC_LINK;
+       fc_bls_req_tmpl.type = FC_TYPE_BLS;
+       fc_bls_req_tmpl.f_ctl = bfa_os_hton3b(FCTL_END_SEQ | FCTL_SI_XFER);
+       fc_bls_req_tmpl.rx_id = FC_RXID_ANY;
+
+       /*
+        * fc_bls_rsp_tmpl
+        */
+       fc_bls_rsp_tmpl.routing = FC_RTG_BASIC_LINK;
+       fc_bls_rsp_tmpl.cat_info = FC_CAT_BA_ACC;
+       fc_bls_rsp_tmpl.type = FC_TYPE_BLS;
+       fc_bls_rsp_tmpl.f_ctl =
+               bfa_os_hton3b(FCTL_EC_RESP | FCTL_SEQ_INI | FCTL_LS_EXCH |
+                             FCTL_END_SEQ | FCTL_SI_XFER);
+       fc_bls_rsp_tmpl.rx_id = FC_RXID_ANY;
+
+       /*
+        * ba_acc_tmpl
+        */
+       ba_acc_tmpl.seq_id_valid = 0;
+       ba_acc_tmpl.low_seq_cnt = 0;
+       ba_acc_tmpl.high_seq_cnt = 0xFFFF;
+
+       /*
+        * plogi_tmpl
+        */
+       plogi_tmpl.csp.verhi = FC_PH_VER_PH_3;
+       plogi_tmpl.csp.verlo = FC_PH_VER_4_3;
+       plogi_tmpl.csp.bbcred = bfa_os_htons(0x0004);
+       plogi_tmpl.csp.ciro = 0x1;
+       plogi_tmpl.csp.cisc = 0x0;
+       plogi_tmpl.csp.altbbcred = 0x0;
+       plogi_tmpl.csp.conseq = bfa_os_htons(0x00FF);
+       plogi_tmpl.csp.ro_bitmap = bfa_os_htons(0x0002);
+       plogi_tmpl.csp.e_d_tov = bfa_os_htonl(2000);
+
+       plogi_tmpl.class3.class_valid = 1;
+       plogi_tmpl.class3.sequential = 1;
+       plogi_tmpl.class3.conseq = 0xFF;
+       plogi_tmpl.class3.ospx = 1;
+
+       /*
+        * prli_tmpl
+        */
+       prli_tmpl.command = FC_ELS_PRLI;
+       prli_tmpl.pglen = 0x10;
+       prli_tmpl.pagebytes = bfa_os_htons(0x0014);
+       prli_tmpl.parampage.type = FC_TYPE_FCP;
+       prli_tmpl.parampage.imagepair = 1;
+       prli_tmpl.parampage.servparams.rxrdisab = 1;
+
+       /*
+        * rrq_tmpl
+        */
+       rrq_tmpl.els_cmd.els_code = FC_ELS_RRQ;
+
+       /*
+        * fcp_struct fchs_s mpl
+        */
+       fcp_fchs_tmpl.routing = FC_RTG_FC4_DEV_DATA;
+       fcp_fchs_tmpl.cat_info = FC_CAT_UNSOLICIT_CMD;
+       fcp_fchs_tmpl.type = FC_TYPE_FCP;
+       fcp_fchs_tmpl.f_ctl =
+               bfa_os_hton3b(FCTL_FS_EXCH | FCTL_END_SEQ | FCTL_SI_XFER);
+       fcp_fchs_tmpl.seq_id = 1;
+       fcp_fchs_tmpl.rx_id = FC_RXID_ANY;
+}
+
+static void
+fc_gs_fchdr_build(struct fchs_s *fchs, u32 d_id, u32 s_id, u32 ox_id)
+{
+       bfa_os_memset(fchs, 0, sizeof(struct fchs_s));
+
+       fchs->routing = FC_RTG_FC4_DEV_DATA;
+       fchs->cat_info = FC_CAT_UNSOLICIT_CTRL;
+       fchs->type = FC_TYPE_SERVICES;
+       fchs->f_ctl =
+               bfa_os_hton3b(FCTL_SEQ_INI | FCTL_FS_EXCH | FCTL_END_SEQ |
+                             FCTL_SI_XFER);
+       fchs->rx_id = FC_RXID_ANY;
+       fchs->d_id = (d_id);
+       fchs->s_id = (s_id);
+       fchs->ox_id = bfa_os_htons(ox_id);
+
+       /**
+        * @todo no need to set ox_id for request
+        *       no need to set rx_id for response
+        */
+}
+
+void
+fc_els_req_build(struct fchs_s *fchs, u32 d_id, u32 s_id, u16 ox_id)
+{
+       bfa_os_memcpy(fchs, &fc_els_req_tmpl, sizeof(struct fchs_s));
+       fchs->d_id = (d_id);
+       fchs->s_id = (s_id);
+       fchs->ox_id = bfa_os_htons(ox_id);
+}
+
+static void
+fc_els_rsp_build(struct fchs_s *fchs, u32 d_id, u32 s_id, u16 ox_id)
+{
+       bfa_os_memcpy(fchs, &fc_els_rsp_tmpl, sizeof(struct fchs_s));
+       fchs->d_id = d_id;
+       fchs->s_id = s_id;
+       fchs->ox_id = ox_id;
+}
+
+enum fc_parse_status
+fc_els_rsp_parse(struct fchs_s *fchs, int len)
+{
+       struct fc_els_cmd_s *els_cmd = (struct fc_els_cmd_s *) (fchs + 1);
+       struct fc_ls_rjt_s *ls_rjt = (struct fc_ls_rjt_s *) els_cmd;
+
+       len = len;
+
+       switch (els_cmd->els_code) {
+       case FC_ELS_LS_RJT:
+               if (ls_rjt->reason_code == FC_LS_RJT_RSN_LOGICAL_BUSY)
+                       return FC_PARSE_BUSY;
+               else
+                       return FC_PARSE_FAILURE;
+
+       case FC_ELS_ACC:
+               return FC_PARSE_OK;
+       }
+       return FC_PARSE_OK;
+}
+
+static void
+fc_bls_rsp_build(struct fchs_s *fchs, u32 d_id, u32 s_id, u16 ox_id)
+{
+       bfa_os_memcpy(fchs, &fc_bls_rsp_tmpl, sizeof(struct fchs_s));
+       fchs->d_id = d_id;
+       fchs->s_id = s_id;
+       fchs->ox_id = ox_id;
+}
+
+static          u16
+fc_plogi_x_build(struct fchs_s *fchs, void *pld, u32 d_id, u32 s_id,
+                u16 ox_id, wwn_t port_name, wwn_t node_name,
+                u16 pdu_size, u8 els_code)
+{
+       struct fc_logi_s *plogi = (struct fc_logi_s *) (pld);
+
+       bfa_os_memcpy(plogi, &plogi_tmpl, sizeof(struct fc_logi_s));
+
+       plogi->els_cmd.els_code = els_code;
+       if (els_code == FC_ELS_PLOGI)
+               fc_els_req_build(fchs, d_id, s_id, ox_id);
+       else
+               fc_els_rsp_build(fchs, d_id, s_id, ox_id);
+
+       plogi->csp.rxsz = plogi->class3.rxsz = bfa_os_htons(pdu_size);
+
+       bfa_os_memcpy(&plogi->port_name, &port_name, sizeof(wwn_t));
+       bfa_os_memcpy(&plogi->node_name, &node_name, sizeof(wwn_t));
+
+       return sizeof(struct fc_logi_s);
+}
+
+u16
+fc_flogi_build(struct fchs_s *fchs, struct fc_logi_s *flogi, u32 s_id,
+               u16 ox_id, wwn_t port_name, wwn_t node_name, u16 pdu_size,
+              u8 set_npiv, u8 set_auth, u16 local_bb_credits)
+{
+       u32        d_id = bfa_os_hton3b(FC_FABRIC_PORT);
+       u32     *vvl_info;
+
+       bfa_os_memcpy(flogi, &plogi_tmpl, sizeof(struct fc_logi_s));
+
+       flogi->els_cmd.els_code = FC_ELS_FLOGI;
+       fc_els_req_build(fchs, d_id, s_id, ox_id);
+
+       flogi->csp.rxsz = flogi->class3.rxsz = bfa_os_htons(pdu_size);
+       flogi->port_name = port_name;
+       flogi->node_name = node_name;
+
+       /*
+        * Set the NPIV Capability Bit ( word 1, bit 31) of Common
+        * Service Parameters.
+        */
+       flogi->csp.ciro = set_npiv;
+
+       /* set AUTH capability */
+       flogi->csp.security = set_auth;
+
+       flogi->csp.bbcred = bfa_os_htons(local_bb_credits);
+
+       /* Set brcd token in VVL */
+       vvl_info = (u32 *)&flogi->vvl[0];
+
+       /* set the flag to indicate the presence of VVL */
+       flogi->csp.npiv_supp    = 1; /* @todo. field name is not correct */
+       vvl_info[0]     = bfa_os_htonl(FLOGI_VVL_BRCD);
+
+       return sizeof(struct fc_logi_s);
+}
+
+u16
+fc_flogi_acc_build(struct fchs_s *fchs, struct fc_logi_s *flogi, u32 s_id,
+                  u16 ox_id, wwn_t port_name, wwn_t node_name,
+                  u16 pdu_size, u16 local_bb_credits)
+{
+       u32        d_id = 0;
+
+       bfa_os_memcpy(flogi, &plogi_tmpl, sizeof(struct fc_logi_s));
+       fc_els_rsp_build(fchs, d_id, s_id, ox_id);
+
+       flogi->els_cmd.els_code = FC_ELS_ACC;
+       flogi->csp.rxsz = flogi->class3.rxsz = bfa_os_htons(pdu_size);
+       flogi->port_name = port_name;
+       flogi->node_name = node_name;
+
+       flogi->csp.bbcred = bfa_os_htons(local_bb_credits);
+
+       return sizeof(struct fc_logi_s);
+}
+
+u16
+fc_fdisc_build(struct fchs_s *fchs, struct fc_logi_s *flogi, u32 s_id,
+               u16 ox_id, wwn_t port_name, wwn_t node_name, u16 pdu_size)
+{
+       u32        d_id = bfa_os_hton3b(FC_FABRIC_PORT);
+
+       bfa_os_memcpy(flogi, &plogi_tmpl, sizeof(struct fc_logi_s));
+
+       flogi->els_cmd.els_code = FC_ELS_FDISC;
+       fc_els_req_build(fchs, d_id, s_id, ox_id);
+
+       flogi->csp.rxsz = flogi->class3.rxsz = bfa_os_htons(pdu_size);
+       flogi->port_name = port_name;
+       flogi->node_name = node_name;
+
+       return sizeof(struct fc_logi_s);
+}
+
+u16
+fc_plogi_build(struct fchs_s *fchs, void *pld, u32 d_id, u32 s_id,
+              u16 ox_id, wwn_t port_name, wwn_t node_name,
+              u16 pdu_size)
+{
+       return fc_plogi_x_build(fchs, pld, d_id, s_id, ox_id, port_name,
+                               node_name, pdu_size, FC_ELS_PLOGI);
+}
+
+u16
+fc_plogi_acc_build(struct fchs_s *fchs, void *pld, u32 d_id, u32 s_id,
+                  u16 ox_id, wwn_t port_name, wwn_t node_name,
+                  u16 pdu_size)
+{
+       return fc_plogi_x_build(fchs, pld, d_id, s_id, ox_id, port_name,
+                               node_name, pdu_size, FC_ELS_ACC);
+}
+
+enum fc_parse_status
+fc_plogi_rsp_parse(struct fchs_s *fchs, int len, wwn_t port_name)
+{
+       struct fc_els_cmd_s *els_cmd = (struct fc_els_cmd_s *) (fchs + 1);
+       struct fc_logi_s *plogi;
+       struct fc_ls_rjt_s *ls_rjt;
+
+       switch (els_cmd->els_code) {
+       case FC_ELS_LS_RJT:
+               ls_rjt = (struct fc_ls_rjt_s *) (fchs + 1);
+               if (ls_rjt->reason_code == FC_LS_RJT_RSN_LOGICAL_BUSY)
+                       return FC_PARSE_BUSY;
+               else
+                       return FC_PARSE_FAILURE;
+       case FC_ELS_ACC:
+               plogi = (struct fc_logi_s *) (fchs + 1);
+               if (len < sizeof(struct fc_logi_s))
+                       return FC_PARSE_FAILURE;
+
+               if (!wwn_is_equal(plogi->port_name, port_name))
+                       return FC_PARSE_FAILURE;
+
+               if (!plogi->class3.class_valid)
+                       return FC_PARSE_FAILURE;
+
+               if (bfa_os_ntohs(plogi->class3.rxsz) < (FC_MIN_PDUSZ))
+                       return FC_PARSE_FAILURE;
+
+               return FC_PARSE_OK;
+       default:
+               return FC_PARSE_FAILURE;
+       }
+}
+
+enum fc_parse_status
+fc_plogi_parse(struct fchs_s *fchs)
+{
+       struct fc_logi_s *plogi = (struct fc_logi_s *) (fchs + 1);
+
+       if (plogi->class3.class_valid != 1)
+               return FC_PARSE_FAILURE;
+
+       if ((bfa_os_ntohs(plogi->class3.rxsz) < FC_MIN_PDUSZ)
+           || (bfa_os_ntohs(plogi->class3.rxsz) > FC_MAX_PDUSZ)
+           || (plogi->class3.rxsz == 0))
+               return FC_PARSE_FAILURE;
+
+       return FC_PARSE_OK;
+}
+
+u16
+fc_prli_build(struct fchs_s *fchs, void *pld, u32 d_id, u32 s_id,
+             u16 ox_id)
+{
+       struct fc_prli_s *prli = (struct fc_prli_s *) (pld);
+
+       fc_els_req_build(fchs, d_id, s_id, ox_id);
+       bfa_os_memcpy(prli, &prli_tmpl, sizeof(struct fc_prli_s));
+
+       prli->command = FC_ELS_PRLI;
+       prli->parampage.servparams.initiator     = 1;
+       prli->parampage.servparams.retry         = 1;
+       prli->parampage.servparams.rec_support   = 1;
+       prli->parampage.servparams.task_retry_id = 0;
+       prli->parampage.servparams.confirm       = 1;
+
+       return sizeof(struct fc_prli_s);
+}
+
+u16
+fc_prli_acc_build(struct fchs_s *fchs, void *pld, u32 d_id, u32 s_id,
+                 u16 ox_id, enum bfa_lport_role role)
+{
+       struct fc_prli_s *prli = (struct fc_prli_s *) (pld);
+
+       fc_els_rsp_build(fchs, d_id, s_id, ox_id);
+       bfa_os_memcpy(prli, &prli_tmpl, sizeof(struct fc_prli_s));
+
+       prli->command = FC_ELS_ACC;
+
+       prli->parampage.servparams.initiator = 1;
+
+       prli->parampage.rspcode = FC_PRLI_ACC_XQTD;
+
+       return sizeof(struct fc_prli_s);
+}
+
+enum fc_parse_status
+fc_prli_rsp_parse(struct fc_prli_s *prli, int len)
+{
+       if (len < sizeof(struct fc_prli_s))
+               return FC_PARSE_FAILURE;
+
+       if (prli->command != FC_ELS_ACC)
+               return FC_PARSE_FAILURE;
+
+       if ((prli->parampage.rspcode != FC_PRLI_ACC_XQTD)
+           && (prli->parampage.rspcode != FC_PRLI_ACC_PREDEF_IMG))
+               return FC_PARSE_FAILURE;
+
+       if (prli->parampage.servparams.target != 1)
+               return FC_PARSE_FAILURE;
+
+       return FC_PARSE_OK;
+}
+
+enum fc_parse_status
+fc_prli_parse(struct fc_prli_s *prli)
+{
+       if (prli->parampage.type != FC_TYPE_FCP)
+               return FC_PARSE_FAILURE;
+
+       if (!prli->parampage.imagepair)
+               return FC_PARSE_FAILURE;
+
+       if (!prli->parampage.servparams.initiator)
+               return FC_PARSE_FAILURE;
+
+       return FC_PARSE_OK;
+}
+
+u16
+fc_logo_build(struct fchs_s *fchs, struct fc_logo_s *logo, u32 d_id, u32 s_id,
+             u16 ox_id, wwn_t port_name)
+{
+       fc_els_req_build(fchs, d_id, s_id, ox_id);
+
+       bfa_os_memset(logo, '\0', sizeof(struct fc_logo_s));
+       logo->els_cmd.els_code = FC_ELS_LOGO;
+       logo->nport_id = (s_id);
+       logo->orig_port_name = port_name;
+
+       return sizeof(struct fc_logo_s);
+}
+
+static          u16
+fc_adisc_x_build(struct fchs_s *fchs, struct fc_adisc_s *adisc, u32 d_id,
+                u32 s_id, u16 ox_id, wwn_t port_name,
+                wwn_t node_name, u8 els_code)
+{
+       bfa_os_memset(adisc, '\0', sizeof(struct fc_adisc_s));
+
+       adisc->els_cmd.els_code = els_code;
+
+       if (els_code == FC_ELS_ADISC)
+               fc_els_req_build(fchs, d_id, s_id, ox_id);
+       else
+               fc_els_rsp_build(fchs, d_id, s_id, ox_id);
+
+       adisc->orig_HA = 0;
+       adisc->orig_port_name = port_name;
+       adisc->orig_node_name = node_name;
+       adisc->nport_id = (s_id);
+
+       return sizeof(struct fc_adisc_s);
+}
+
+u16
+fc_adisc_build(struct fchs_s *fchs, struct fc_adisc_s *adisc, u32 d_id,
+               u32 s_id, u16 ox_id, wwn_t port_name, wwn_t node_name)
+{
+       return fc_adisc_x_build(fchs, adisc, d_id, s_id, ox_id, port_name,
+                               node_name, FC_ELS_ADISC);
+}
+
+u16
+fc_adisc_acc_build(struct fchs_s *fchs, struct fc_adisc_s *adisc, u32 d_id,
+                  u32 s_id, u16 ox_id, wwn_t port_name,
+                  wwn_t node_name)
+{
+       return fc_adisc_x_build(fchs, adisc, d_id, s_id, ox_id, port_name,
+                               node_name, FC_ELS_ACC);
+}
+
+enum fc_parse_status
+fc_adisc_rsp_parse(struct fc_adisc_s *adisc, int len, wwn_t port_name,
+                                wwn_t node_name)
+{
+
+       if (len < sizeof(struct fc_adisc_s))
+               return FC_PARSE_FAILURE;
+
+       if (adisc->els_cmd.els_code != FC_ELS_ACC)
+               return FC_PARSE_FAILURE;
+
+       if (!wwn_is_equal(adisc->orig_port_name, port_name))
+               return FC_PARSE_FAILURE;
+
+       return FC_PARSE_OK;
+}
+
+enum fc_parse_status
+fc_adisc_parse(struct fchs_s *fchs, void *pld, u32 host_dap, wwn_t node_name,
+              wwn_t port_name)
+{
+       struct fc_adisc_s *adisc = (struct fc_adisc_s *) pld;
+
+       if (adisc->els_cmd.els_code != FC_ELS_ACC)
+               return FC_PARSE_FAILURE;
+
+       if ((adisc->nport_id == (host_dap))
+           && wwn_is_equal(adisc->orig_port_name, port_name)
+           && wwn_is_equal(adisc->orig_node_name, node_name))
+               return FC_PARSE_OK;
+
+       return FC_PARSE_FAILURE;
+}
+
+enum fc_parse_status
+fc_pdisc_parse(struct fchs_s *fchs, wwn_t node_name, wwn_t port_name)
+{
+       struct fc_logi_s *pdisc = (struct fc_logi_s *) (fchs + 1);
+
+       if (pdisc->class3.class_valid != 1)
+               return FC_PARSE_FAILURE;
+
+       if ((bfa_os_ntohs(pdisc->class3.rxsz) <
+               (FC_MIN_PDUSZ - sizeof(struct fchs_s)))
+           || (pdisc->class3.rxsz == 0))
+               return FC_PARSE_FAILURE;
+
+       if (!wwn_is_equal(pdisc->port_name, port_name))
+               return FC_PARSE_FAILURE;
+
+       if (!wwn_is_equal(pdisc->node_name, node_name))
+               return FC_PARSE_FAILURE;
+
+       return FC_PARSE_OK;
+}
+
+u16
+fc_abts_build(struct fchs_s *fchs, u32 d_id, u32 s_id, u16 ox_id)
+{
+       bfa_os_memcpy(fchs, &fc_bls_req_tmpl, sizeof(struct fchs_s));
+       fchs->cat_info = FC_CAT_ABTS;
+       fchs->d_id = (d_id);
+       fchs->s_id = (s_id);
+       fchs->ox_id = bfa_os_htons(ox_id);
+
+       return sizeof(struct fchs_s);
+}
+
+enum fc_parse_status
+fc_abts_rsp_parse(struct fchs_s *fchs, int len)
+{
+       if ((fchs->cat_info == FC_CAT_BA_ACC)
+           || (fchs->cat_info == FC_CAT_BA_RJT))
+               return FC_PARSE_OK;
+
+       return FC_PARSE_FAILURE;
+}
+
+u16
+fc_rrq_build(struct fchs_s *fchs, struct fc_rrq_s *rrq, u32 d_id, u32 s_id,
+            u16 ox_id, u16 rrq_oxid)
+{
+       fc_els_req_build(fchs, d_id, s_id, ox_id);
+
+       /*
+        * build rrq payload
+        */
+       bfa_os_memcpy(rrq, &rrq_tmpl, sizeof(struct fc_rrq_s));
+       rrq->s_id = (s_id);
+       rrq->ox_id = bfa_os_htons(rrq_oxid);
+       rrq->rx_id = FC_RXID_ANY;
+
+       return sizeof(struct fc_rrq_s);
+}
+
+u16
+fc_logo_acc_build(struct fchs_s *fchs, void *pld, u32 d_id, u32 s_id,
+                 u16 ox_id)
+{
+       struct fc_els_cmd_s *acc = pld;
+
+       fc_els_rsp_build(fchs, d_id, s_id, ox_id);
+
+       bfa_os_memset(acc, 0, sizeof(struct fc_els_cmd_s));
+       acc->els_code = FC_ELS_ACC;
+
+       return sizeof(struct fc_els_cmd_s);
+}
+
+u16
+fc_ls_rjt_build(struct fchs_s *fchs, struct fc_ls_rjt_s *ls_rjt, u32 d_id,
+               u32 s_id, u16 ox_id, u8 reason_code,
+               u8 reason_code_expl)
+{
+       fc_els_rsp_build(fchs, d_id, s_id, ox_id);
+       bfa_os_memset(ls_rjt, 0, sizeof(struct fc_ls_rjt_s));
+
+       ls_rjt->els_cmd.els_code = FC_ELS_LS_RJT;
+       ls_rjt->reason_code = reason_code;
+       ls_rjt->reason_code_expl = reason_code_expl;
+       ls_rjt->vendor_unique = 0x00;
+
+       return sizeof(struct fc_ls_rjt_s);
+}
+
+u16
+fc_ba_acc_build(struct fchs_s *fchs, struct fc_ba_acc_s *ba_acc, u32 d_id,
+               u32 s_id, u16 ox_id, u16 rx_id)
+{
+       fc_bls_rsp_build(fchs, d_id, s_id, ox_id);
+
+       bfa_os_memcpy(ba_acc, &ba_acc_tmpl, sizeof(struct fc_ba_acc_s));
+
+       fchs->rx_id = rx_id;
+
+       ba_acc->ox_id = fchs->ox_id;
+       ba_acc->rx_id = fchs->rx_id;
+
+       return sizeof(struct fc_ba_acc_s);
+}
+
+u16
+fc_ls_acc_build(struct fchs_s *fchs, struct fc_els_cmd_s *els_cmd, u32 d_id,
+               u32 s_id, u16 ox_id)
+{
+       fc_els_rsp_build(fchs, d_id, s_id, ox_id);
+       bfa_os_memset(els_cmd, 0, sizeof(struct fc_els_cmd_s));
+       els_cmd->els_code = FC_ELS_ACC;
+
+       return sizeof(struct fc_els_cmd_s);
+}
+
+int
+fc_logout_params_pages(struct fchs_s *fc_frame, u8 els_code)
+{
+       int             num_pages = 0;
+       struct fc_prlo_s *prlo;
+       struct fc_tprlo_s *tprlo;
+
+       if (els_code == FC_ELS_PRLO) {
+               prlo = (struct fc_prlo_s *) (fc_frame + 1);
+               num_pages = (bfa_os_ntohs(prlo->payload_len) - 4) / 16;
+       } else {
+               tprlo = (struct fc_tprlo_s *) (fc_frame + 1);
+               num_pages = (bfa_os_ntohs(tprlo->payload_len) - 4) / 16;
+       }
+       return num_pages;
+}
+
+u16
+fc_tprlo_acc_build(struct fchs_s *fchs, struct fc_tprlo_acc_s *tprlo_acc,
+               u32 d_id, u32 s_id, u16 ox_id, int num_pages)
+{
+       int             page;
+
+       fc_els_rsp_build(fchs, d_id, s_id, ox_id);
+
+       bfa_os_memset(tprlo_acc, 0, (num_pages * 16) + 4);
+       tprlo_acc->command = FC_ELS_ACC;
+
+       tprlo_acc->page_len = 0x10;
+       tprlo_acc->payload_len = bfa_os_htons((num_pages * 16) + 4);
+
+       for (page = 0; page < num_pages; page++) {
+               tprlo_acc->tprlo_acc_params[page].opa_valid = 0;
+               tprlo_acc->tprlo_acc_params[page].rpa_valid = 0;
+               tprlo_acc->tprlo_acc_params[page].fc4type_csp = FC_TYPE_FCP;
+               tprlo_acc->tprlo_acc_params[page].orig_process_assc = 0;
+               tprlo_acc->tprlo_acc_params[page].resp_process_assc = 0;
+       }
+       return bfa_os_ntohs(tprlo_acc->payload_len);
+}
+
+u16
+fc_prlo_acc_build(struct fchs_s *fchs, struct fc_prlo_acc_s *prlo_acc, u32 d_id,
+                 u32 s_id, u16 ox_id, int num_pages)
+{
+       int             page;
+
+       fc_els_rsp_build(fchs, d_id, s_id, ox_id);
+
+       bfa_os_memset(prlo_acc, 0, (num_pages * 16) + 4);
+       prlo_acc->command = FC_ELS_ACC;
+       prlo_acc->page_len = 0x10;
+       prlo_acc->payload_len = bfa_os_htons((num_pages * 16) + 4);
+
+       for (page = 0; page < num_pages; page++) {
+               prlo_acc->prlo_acc_params[page].opa_valid = 0;
+               prlo_acc->prlo_acc_params[page].rpa_valid = 0;
+               prlo_acc->prlo_acc_params[page].fc4type_csp = FC_TYPE_FCP;
+               prlo_acc->prlo_acc_params[page].orig_process_assc = 0;
+               prlo_acc->prlo_acc_params[page].resp_process_assc = 0;
+       }
+
+       return bfa_os_ntohs(prlo_acc->payload_len);
+}
+
+u16
+fc_rnid_build(struct fchs_s *fchs, struct fc_rnid_cmd_s *rnid, u32 d_id,
+               u32 s_id, u16 ox_id, u32 data_format)
+{
+       fc_els_req_build(fchs, d_id, s_id, ox_id);
+
+       bfa_os_memset(rnid, 0, sizeof(struct fc_rnid_cmd_s));
+
+       rnid->els_cmd.els_code = FC_ELS_RNID;
+       rnid->node_id_data_format = data_format;
+
+       return sizeof(struct fc_rnid_cmd_s);
+}
+
+u16
+fc_rnid_acc_build(struct fchs_s *fchs, struct fc_rnid_acc_s *rnid_acc, u32 d_id,
+                 u32 s_id, u16 ox_id, u32 data_format,
+                 struct fc_rnid_common_id_data_s *common_id_data,
+                 struct fc_rnid_general_topology_data_s *gen_topo_data)
+{
+       bfa_os_memset(rnid_acc, 0, sizeof(struct fc_rnid_acc_s));
+
+       fc_els_rsp_build(fchs, d_id, s_id, ox_id);
+
+       rnid_acc->els_cmd.els_code = FC_ELS_ACC;
+       rnid_acc->node_id_data_format = data_format;
+       rnid_acc->common_id_data_length =
+                       sizeof(struct fc_rnid_common_id_data_s);
+       rnid_acc->common_id_data = *common_id_data;
+
+       if (data_format == RNID_NODEID_DATA_FORMAT_DISCOVERY) {
+               rnid_acc->specific_id_data_length =
+                       sizeof(struct fc_rnid_general_topology_data_s);
+               bfa_os_assign(rnid_acc->gen_topology_data, *gen_topo_data);
+               return sizeof(struct fc_rnid_acc_s);
+       } else {
+               return sizeof(struct fc_rnid_acc_s) -
+                       sizeof(struct fc_rnid_general_topology_data_s);
+       }
+
+}
+
+u16
+fc_rpsc_build(struct fchs_s *fchs, struct fc_rpsc_cmd_s *rpsc, u32 d_id,
+               u32 s_id, u16 ox_id)
+{
+       fc_els_req_build(fchs, d_id, s_id, ox_id);
+
+       bfa_os_memset(rpsc, 0, sizeof(struct fc_rpsc_cmd_s));
+
+       rpsc->els_cmd.els_code = FC_ELS_RPSC;
+       return sizeof(struct fc_rpsc_cmd_s);
+}
+
+u16
+fc_rpsc2_build(struct fchs_s *fchs, struct fc_rpsc2_cmd_s *rpsc2, u32 d_id,
+               u32 s_id, u32 *pid_list, u16 npids)
+{
+       u32 dctlr_id = FC_DOMAIN_CTRLR(bfa_os_hton3b(d_id));
+       int i = 0;
+
+       fc_els_req_build(fchs, bfa_os_hton3b(dctlr_id), s_id, 0);
+
+       bfa_os_memset(rpsc2, 0, sizeof(struct fc_rpsc2_cmd_s));
+
+       rpsc2->els_cmd.els_code = FC_ELS_RPSC;
+       rpsc2->token = bfa_os_htonl(FC_BRCD_TOKEN);
+       rpsc2->num_pids  = bfa_os_htons(npids);
+       for (i = 0; i < npids; i++)
+               rpsc2->pid_list[i].pid = pid_list[i];
+
+       return sizeof(struct fc_rpsc2_cmd_s) + ((npids - 1) * (sizeof(u32)));
+}
+
+u16
+fc_rpsc_acc_build(struct fchs_s *fchs, struct fc_rpsc_acc_s *rpsc_acc,
+               u32 d_id, u32 s_id, u16 ox_id,
+                 struct fc_rpsc_speed_info_s *oper_speed)
+{
+       bfa_os_memset(rpsc_acc, 0, sizeof(struct fc_rpsc_acc_s));
+
+       fc_els_rsp_build(fchs, d_id, s_id, ox_id);
+
+       rpsc_acc->command = FC_ELS_ACC;
+       rpsc_acc->num_entries = bfa_os_htons(1);
+
+       rpsc_acc->speed_info[0].port_speed_cap =
+               bfa_os_htons(oper_speed->port_speed_cap);
+
+       rpsc_acc->speed_info[0].port_op_speed =
+               bfa_os_htons(oper_speed->port_op_speed);
+
+       return sizeof(struct fc_rpsc_acc_s);
+}
+
+/*
+ * TBD -
+ * . get rid of unnecessary memsets
+ */
+
+u16
+fc_logo_rsp_parse(struct fchs_s *fchs, int len)
+{
+       struct fc_els_cmd_s *els_cmd = (struct fc_els_cmd_s *) (fchs + 1);
+
+       len = len;
+       if (els_cmd->els_code != FC_ELS_ACC)
+               return FC_PARSE_FAILURE;
+
+       return FC_PARSE_OK;
+}
+
+u16
+fc_pdisc_build(struct fchs_s *fchs, u32 d_id, u32 s_id, u16 ox_id,
+              wwn_t port_name, wwn_t node_name, u16 pdu_size)
+{
+       struct fc_logi_s *pdisc = (struct fc_logi_s *) (fchs + 1);
+
+       bfa_os_memcpy(pdisc, &plogi_tmpl, sizeof(struct fc_logi_s));
+
+       pdisc->els_cmd.els_code = FC_ELS_PDISC;
+       fc_els_req_build(fchs, d_id, s_id, ox_id);
+
+       pdisc->csp.rxsz = pdisc->class3.rxsz = bfa_os_htons(pdu_size);
+       pdisc->port_name = port_name;
+       pdisc->node_name = node_name;
+
+       return sizeof(struct fc_logi_s);
+}
+
+u16
+fc_pdisc_rsp_parse(struct fchs_s *fchs, int len, wwn_t port_name)
+{
+       struct fc_logi_s *pdisc = (struct fc_logi_s *) (fchs + 1);
+
+       if (len < sizeof(struct fc_logi_s))
+               return FC_PARSE_LEN_INVAL;
+
+       if (pdisc->els_cmd.els_code != FC_ELS_ACC)
+               return FC_PARSE_ACC_INVAL;
+
+       if (!wwn_is_equal(pdisc->port_name, port_name))
+               return FC_PARSE_PWWN_NOT_EQUAL;
+
+       if (!pdisc->class3.class_valid)
+               return FC_PARSE_NWWN_NOT_EQUAL;
+
+       if (bfa_os_ntohs(pdisc->class3.rxsz) < (FC_MIN_PDUSZ))
+               return FC_PARSE_RXSZ_INVAL;
+
+       return FC_PARSE_OK;
+}
+
+u16
+fc_prlo_build(struct fchs_s *fchs, u32 d_id, u32 s_id, u16 ox_id,
+             int num_pages)
+{
+       struct fc_prlo_s *prlo = (struct fc_prlo_s *) (fchs + 1);
+       int             page;
+
+       fc_els_req_build(fchs, d_id, s_id, ox_id);
+       bfa_os_memset(prlo, 0, (num_pages * 16) + 4);
+       prlo->command = FC_ELS_PRLO;
+       prlo->page_len = 0x10;
+       prlo->payload_len = bfa_os_htons((num_pages * 16) + 4);
+
+       for (page = 0; page < num_pages; page++) {
+               prlo->prlo_params[page].type = FC_TYPE_FCP;
+               prlo->prlo_params[page].opa_valid = 0;
+               prlo->prlo_params[page].rpa_valid = 0;
+               prlo->prlo_params[page].orig_process_assc = 0;
+               prlo->prlo_params[page].resp_process_assc = 0;
+       }
+
+       return bfa_os_ntohs(prlo->payload_len);
+}
+
+u16
+fc_prlo_rsp_parse(struct fchs_s *fchs, int len)
+{
+       struct fc_prlo_acc_s *prlo = (struct fc_prlo_acc_s *) (fchs + 1);
+       int             num_pages = 0;
+       int             page = 0;
+
+       len = len;
+
+       if (prlo->command != FC_ELS_ACC)
+               return FC_PARSE_FAILURE;
+
+       num_pages = ((bfa_os_ntohs(prlo->payload_len)) - 4) / 16;
+
+       for (page = 0; page < num_pages; page++) {
+               if (prlo->prlo_acc_params[page].type != FC_TYPE_FCP)
+                       return FC_PARSE_FAILURE;
+
+               if (prlo->prlo_acc_params[page].opa_valid != 0)
+                       return FC_PARSE_FAILURE;
+
+               if (prlo->prlo_acc_params[page].rpa_valid != 0)
+                       return FC_PARSE_FAILURE;
+
+               if (prlo->prlo_acc_params[page].orig_process_assc != 0)
+                       return FC_PARSE_FAILURE;
+
+               if (prlo->prlo_acc_params[page].resp_process_assc != 0)
+                       return FC_PARSE_FAILURE;
+       }
+       return FC_PARSE_OK;
+
+}
+
+u16
+fc_tprlo_build(struct fchs_s *fchs, u32 d_id, u32 s_id, u16 ox_id,
+              int num_pages, enum fc_tprlo_type tprlo_type, u32 tpr_id)
+{
+       struct fc_tprlo_s *tprlo = (struct fc_tprlo_s *) (fchs + 1);
+       int             page;
+
+       fc_els_req_build(fchs, d_id, s_id, ox_id);
+       bfa_os_memset(tprlo, 0, (num_pages * 16) + 4);
+       tprlo->command = FC_ELS_TPRLO;
+       tprlo->page_len = 0x10;
+       tprlo->payload_len = bfa_os_htons((num_pages * 16) + 4);
+
+       for (page = 0; page < num_pages; page++) {
+               tprlo->tprlo_params[page].type = FC_TYPE_FCP;
+               tprlo->tprlo_params[page].opa_valid = 0;
+               tprlo->tprlo_params[page].rpa_valid = 0;
+               tprlo->tprlo_params[page].orig_process_assc = 0;
+               tprlo->tprlo_params[page].resp_process_assc = 0;
+               if (tprlo_type == FC_GLOBAL_LOGO) {
+                       tprlo->tprlo_params[page].global_process_logout = 1;
+               } else if (tprlo_type == FC_TPR_LOGO) {
+                       tprlo->tprlo_params[page].tpo_nport_valid = 1;
+                       tprlo->tprlo_params[page].tpo_nport_id = (tpr_id);
+               }
+       }
+
+       return bfa_os_ntohs(tprlo->payload_len);
+}
+
+u16
+fc_tprlo_rsp_parse(struct fchs_s *fchs, int len)
+{
+       struct fc_tprlo_acc_s *tprlo = (struct fc_tprlo_acc_s *) (fchs + 1);
+       int             num_pages = 0;
+       int             page = 0;
+
+       len = len;
+
+       if (tprlo->command != FC_ELS_ACC)
+               return FC_PARSE_ACC_INVAL;
+
+       num_pages = (bfa_os_ntohs(tprlo->payload_len) - 4) / 16;
+
+       for (page = 0; page < num_pages; page++) {
+               if (tprlo->tprlo_acc_params[page].type != FC_TYPE_FCP)
+                       return FC_PARSE_NOT_FCP;
+               if (tprlo->tprlo_acc_params[page].opa_valid != 0)
+                       return FC_PARSE_OPAFLAG_INVAL;
+               if (tprlo->tprlo_acc_params[page].rpa_valid != 0)
+                       return FC_PARSE_RPAFLAG_INVAL;
+               if (tprlo->tprlo_acc_params[page].orig_process_assc != 0)
+                       return FC_PARSE_OPA_INVAL;
+               if (tprlo->tprlo_acc_params[page].resp_process_assc != 0)
+                       return FC_PARSE_RPA_INVAL;
+       }
+       return FC_PARSE_OK;
+}
+
+enum fc_parse_status
+fc_rrq_rsp_parse(struct fchs_s *fchs, int len)
+{
+       struct fc_els_cmd_s *els_cmd = (struct fc_els_cmd_s *) (fchs + 1);
+
+       len = len;
+       if (els_cmd->els_code != FC_ELS_ACC)
+               return FC_PARSE_FAILURE;
+
+       return FC_PARSE_OK;
+}
+
+u16
+fc_ba_rjt_build(struct fchs_s *fchs, u32 d_id, u32 s_id, u16 ox_id,
+               u32 reason_code, u32 reason_expl)
+{
+       struct fc_ba_rjt_s *ba_rjt = (struct fc_ba_rjt_s *) (fchs + 1);
+
+       fc_bls_rsp_build(fchs, d_id, s_id, ox_id);
+
+       fchs->cat_info = FC_CAT_BA_RJT;
+       ba_rjt->reason_code = reason_code;
+       ba_rjt->reason_expl = reason_expl;
+       return sizeof(struct fc_ba_rjt_s);
+}
+
+static void
+fc_gs_cthdr_build(struct ct_hdr_s *cthdr, u32 s_id, u16 cmd_code)
+{
+       bfa_os_memset(cthdr, 0, sizeof(struct ct_hdr_s));
+       cthdr->rev_id = CT_GS3_REVISION;
+       cthdr->gs_type = CT_GSTYPE_DIRSERVICE;
+       cthdr->gs_sub_type = CT_GSSUBTYPE_NAMESERVER;
+       cthdr->cmd_rsp_code = bfa_os_htons(cmd_code);
+}
+
+static void
+fc_gs_fdmi_cthdr_build(struct ct_hdr_s *cthdr, u32 s_id, u16 cmd_code)
+{
+       bfa_os_memset(cthdr, 0, sizeof(struct ct_hdr_s));
+       cthdr->rev_id = CT_GS3_REVISION;
+       cthdr->gs_type = CT_GSTYPE_MGMTSERVICE;
+       cthdr->gs_sub_type = CT_GSSUBTYPE_HBA_MGMTSERVER;
+       cthdr->cmd_rsp_code = bfa_os_htons(cmd_code);
+}
+
+static void
+fc_gs_ms_cthdr_build(struct ct_hdr_s *cthdr, u32 s_id, u16 cmd_code,
+                                        u8 sub_type)
+{
+       bfa_os_memset(cthdr, 0, sizeof(struct ct_hdr_s));
+       cthdr->rev_id = CT_GS3_REVISION;
+       cthdr->gs_type = CT_GSTYPE_MGMTSERVICE;
+       cthdr->gs_sub_type = sub_type;
+       cthdr->cmd_rsp_code = bfa_os_htons(cmd_code);
+}
+
+u16
+fc_gidpn_build(struct fchs_s *fchs, void *pyld, u32 s_id, u16 ox_id,
+              wwn_t port_name)
+{
+       struct ct_hdr_s *cthdr = (struct ct_hdr_s *) pyld;
+       struct fcgs_gidpn_req_s *gidpn = (struct fcgs_gidpn_req_s *)(cthdr + 1);
+       u32        d_id = bfa_os_hton3b(FC_NAME_SERVER);
+
+       fc_gs_fchdr_build(fchs, d_id, s_id, ox_id);
+       fc_gs_cthdr_build(cthdr, s_id, GS_GID_PN);
+
+       bfa_os_memset(gidpn, 0, sizeof(struct fcgs_gidpn_req_s));
+       gidpn->port_name = port_name;
+       return sizeof(struct fcgs_gidpn_req_s) + sizeof(struct ct_hdr_s);
+}
+
+u16
+fc_gpnid_build(struct fchs_s *fchs, void *pyld, u32 s_id, u16 ox_id,
+              u32 port_id)
+{
+       struct ct_hdr_s *cthdr = (struct ct_hdr_s *) pyld;
+       fcgs_gpnid_req_t *gpnid = (fcgs_gpnid_req_t *) (cthdr + 1);
+       u32        d_id = bfa_os_hton3b(FC_NAME_SERVER);
+
+       fc_gs_fchdr_build(fchs, d_id, s_id, ox_id);
+       fc_gs_cthdr_build(cthdr, s_id, GS_GPN_ID);
+
+       bfa_os_memset(gpnid, 0, sizeof(fcgs_gpnid_req_t));
+       gpnid->dap = port_id;
+       return sizeof(fcgs_gpnid_req_t) + sizeof(struct ct_hdr_s);
+}
+
+u16
+fc_gnnid_build(struct fchs_s *fchs, void *pyld, u32 s_id, u16 ox_id,
+              u32 port_id)
+{
+       struct ct_hdr_s *cthdr = (struct ct_hdr_s *) pyld;
+       fcgs_gnnid_req_t *gnnid = (fcgs_gnnid_req_t *) (cthdr + 1);
+       u32        d_id = bfa_os_hton3b(FC_NAME_SERVER);
+
+       fc_gs_fchdr_build(fchs, d_id, s_id, ox_id);
+       fc_gs_cthdr_build(cthdr, s_id, GS_GNN_ID);
+
+       bfa_os_memset(gnnid, 0, sizeof(fcgs_gnnid_req_t));
+       gnnid->dap = port_id;
+       return sizeof(fcgs_gnnid_req_t) + sizeof(struct ct_hdr_s);
+}
+
+u16
+fc_ct_rsp_parse(struct ct_hdr_s *cthdr)
+{
+       if (bfa_os_ntohs(cthdr->cmd_rsp_code) != CT_RSP_ACCEPT) {
+               if (cthdr->reason_code == CT_RSN_LOGICAL_BUSY)
+                       return FC_PARSE_BUSY;
+               else
+                       return FC_PARSE_FAILURE;
+       }
+
+       return FC_PARSE_OK;
+}
+
+u16
+fc_scr_build(struct fchs_s *fchs, struct fc_scr_s *scr,
+               u8 set_br_reg, u32 s_id, u16 ox_id)
+{
+       u32        d_id = bfa_os_hton3b(FC_FABRIC_CONTROLLER);
+
+       fc_els_req_build(fchs, d_id, s_id, ox_id);
+
+       bfa_os_memset(scr, 0, sizeof(struct fc_scr_s));
+       scr->command = FC_ELS_SCR;
+       scr->reg_func = FC_SCR_REG_FUNC_FULL;
+       if (set_br_reg)
+               scr->vu_reg_func = FC_VU_SCR_REG_FUNC_FABRIC_NAME_CHANGE;
+
+       return sizeof(struct fc_scr_s);
+}
+
+u16
+fc_rscn_build(struct fchs_s *fchs, struct fc_rscn_pl_s *rscn,
+               u32 s_id, u16 ox_id)
+{
+       u32        d_id = bfa_os_hton3b(FC_FABRIC_CONTROLLER);
+       u16        payldlen;
+
+       fc_els_req_build(fchs, d_id, s_id, ox_id);
+       rscn->command = FC_ELS_RSCN;
+       rscn->pagelen = sizeof(rscn->event[0]);
+
+       payldlen = sizeof(u32) + rscn->pagelen;
+       rscn->payldlen = bfa_os_htons(payldlen);
+
+       rscn->event[0].format = FC_RSCN_FORMAT_PORTID;
+       rscn->event[0].portid = s_id;
+
+       return sizeof(struct fc_rscn_pl_s);
+}
+
+u16
+fc_rftid_build(struct fchs_s *fchs, void *pyld, u32 s_id, u16 ox_id,
+              enum bfa_lport_role roles)
+{
+       struct ct_hdr_s *cthdr = (struct ct_hdr_s *) pyld;
+       struct fcgs_rftid_req_s *rftid = (struct fcgs_rftid_req_s *)(cthdr + 1);
+       u32        type_value, d_id = bfa_os_hton3b(FC_NAME_SERVER);
+       u8         index;
+
+       fc_gs_fchdr_build(fchs, d_id, s_id, ox_id);
+       fc_gs_cthdr_build(cthdr, s_id, GS_RFT_ID);
+
+       bfa_os_memset(rftid, 0, sizeof(struct fcgs_rftid_req_s));
+
+       rftid->dap = s_id;
+
+       /* By default, FCP FC4 Type is registered */
+       index = FC_TYPE_FCP >> 5;
+       type_value = 1 << (FC_TYPE_FCP % 32);
+       rftid->fc4_type[index] = bfa_os_htonl(type_value);
+
+       return sizeof(struct fcgs_rftid_req_s) + sizeof(struct ct_hdr_s);
+}
+
+u16
+fc_rftid_build_sol(struct fchs_s *fchs, void *pyld, u32 s_id, u16 ox_id,
+                  u8 *fc4_bitmap, u32 bitmap_size)
+{
+       struct ct_hdr_s *cthdr = (struct ct_hdr_s *) pyld;
+       struct fcgs_rftid_req_s *rftid = (struct fcgs_rftid_req_s *)(cthdr + 1);
+       u32        d_id = bfa_os_hton3b(FC_NAME_SERVER);
+
+       fc_gs_fchdr_build(fchs, d_id, s_id, ox_id);
+       fc_gs_cthdr_build(cthdr, s_id, GS_RFT_ID);
+
+       bfa_os_memset(rftid, 0, sizeof(struct fcgs_rftid_req_s));
+
+       rftid->dap = s_id;
+       bfa_os_memcpy((void *)rftid->fc4_type, (void *)fc4_bitmap,
+               (bitmap_size < 32 ? bitmap_size : 32));
+
+       return sizeof(struct fcgs_rftid_req_s) + sizeof(struct ct_hdr_s);
+}
+
+u16
+fc_rffid_build(struct fchs_s *fchs, void *pyld, u32 s_id, u16 ox_id,
+              u8 fc4_type, u8 fc4_ftrs)
+{
+       struct ct_hdr_s *cthdr = (struct ct_hdr_s *) pyld;
+       struct fcgs_rffid_req_s *rffid = (struct fcgs_rffid_req_s *)(cthdr + 1);
+       u32         d_id = bfa_os_hton3b(FC_NAME_SERVER);
+
+       fc_gs_fchdr_build(fchs, d_id, s_id, ox_id);
+       fc_gs_cthdr_build(cthdr, s_id, GS_RFF_ID);
+
+       bfa_os_memset(rffid, 0, sizeof(struct fcgs_rffid_req_s));
+
+       rffid->dap          = s_id;
+       rffid->fc4ftr_bits  = fc4_ftrs;
+       rffid->fc4_type     = fc4_type;
+
+       return sizeof(struct fcgs_rffid_req_s) + sizeof(struct ct_hdr_s);
+}
+
+u16
+fc_rspnid_build(struct fchs_s *fchs, void *pyld, u32 s_id, u16 ox_id,
+               u8 *name)
+{
+
+       struct ct_hdr_s *cthdr = (struct ct_hdr_s *) pyld;
+       struct fcgs_rspnid_req_s *rspnid =
+                       (struct fcgs_rspnid_req_s *)(cthdr + 1);
+       u32        d_id = bfa_os_hton3b(FC_NAME_SERVER);
+
+       fc_gs_fchdr_build(fchs, d_id, s_id, ox_id);
+       fc_gs_cthdr_build(cthdr, s_id, GS_RSPN_ID);
+
+       bfa_os_memset(rspnid, 0, sizeof(struct fcgs_rspnid_req_s));
+
+       rspnid->dap = s_id;
+       rspnid->spn_len = (u8) strlen((char *)name);
+       strncpy((char *)rspnid->spn, (char *)name, rspnid->spn_len);
+
+       return sizeof(struct fcgs_rspnid_req_s) + sizeof(struct ct_hdr_s);
+}
+
+u16
+fc_gid_ft_build(struct fchs_s *fchs, void *pyld, u32 s_id, u8 fc4_type)
+{
+
+       struct ct_hdr_s *cthdr = (struct ct_hdr_s *) pyld;
+       struct fcgs_gidft_req_s *gidft = (struct fcgs_gidft_req_s *)(cthdr + 1);
+       u32        d_id = bfa_os_hton3b(FC_NAME_SERVER);
+
+       fc_gs_fchdr_build(fchs, d_id, s_id, 0);
+
+       fc_gs_cthdr_build(cthdr, s_id, GS_GID_FT);
+
+       bfa_os_memset(gidft, 0, sizeof(struct fcgs_gidft_req_s));
+       gidft->fc4_type = fc4_type;
+       gidft->domain_id = 0;
+       gidft->area_id = 0;
+
+       return sizeof(struct fcgs_gidft_req_s) + sizeof(struct ct_hdr_s);
+}
+
+u16
+fc_rpnid_build(struct fchs_s *fchs, void *pyld, u32 s_id, u32 port_id,
+              wwn_t port_name)
+{
+       struct ct_hdr_s *cthdr = (struct ct_hdr_s *) pyld;
+       struct fcgs_rpnid_req_s *rpnid = (struct fcgs_rpnid_req_s *)(cthdr + 1);
+       u32        d_id = bfa_os_hton3b(FC_NAME_SERVER);
+
+       fc_gs_fchdr_build(fchs, d_id, s_id, 0);
+       fc_gs_cthdr_build(cthdr, s_id, GS_RPN_ID);
+
+       bfa_os_memset(rpnid, 0, sizeof(struct fcgs_rpnid_req_s));
+       rpnid->port_id = port_id;
+       rpnid->port_name = port_name;
+
+       return sizeof(struct fcgs_rpnid_req_s) + sizeof(struct ct_hdr_s);
+}
+
+u16
+fc_rnnid_build(struct fchs_s *fchs, void *pyld, u32 s_id, u32 port_id,
+              wwn_t node_name)
+{
+       struct ct_hdr_s *cthdr = (struct ct_hdr_s *) pyld;
+       struct fcgs_rnnid_req_s *rnnid = (struct fcgs_rnnid_req_s *)(cthdr + 1);
+       u32        d_id = bfa_os_hton3b(FC_NAME_SERVER);
+
+       fc_gs_fchdr_build(fchs, d_id, s_id, 0);
+       fc_gs_cthdr_build(cthdr, s_id, GS_RNN_ID);
+
+       bfa_os_memset(rnnid, 0, sizeof(struct fcgs_rnnid_req_s));
+       rnnid->port_id = port_id;
+       rnnid->node_name = node_name;
+
+       return sizeof(struct fcgs_rnnid_req_s) + sizeof(struct ct_hdr_s);
+}
+
+u16
+fc_rcsid_build(struct fchs_s *fchs, void *pyld, u32 s_id, u32 port_id,
+              u32 cos)
+{
+       struct ct_hdr_s *cthdr = (struct ct_hdr_s *) pyld;
+       struct fcgs_rcsid_req_s *rcsid =
+                       (struct fcgs_rcsid_req_s *) (cthdr + 1);
+       u32        d_id = bfa_os_hton3b(FC_NAME_SERVER);
+
+       fc_gs_fchdr_build(fchs, d_id, s_id, 0);
+       fc_gs_cthdr_build(cthdr, s_id, GS_RCS_ID);
+
+       bfa_os_memset(rcsid, 0, sizeof(struct fcgs_rcsid_req_s));
+       rcsid->port_id = port_id;
+       rcsid->cos = cos;
+
+       return sizeof(struct fcgs_rcsid_req_s) + sizeof(struct ct_hdr_s);
+}
+
+u16
+fc_rptid_build(struct fchs_s *fchs, void *pyld, u32 s_id, u32 port_id,
+              u8 port_type)
+{
+       struct ct_hdr_s *cthdr = (struct ct_hdr_s *) pyld;
+       struct fcgs_rptid_req_s *rptid = (struct fcgs_rptid_req_s *)(cthdr + 1);
+       u32        d_id = bfa_os_hton3b(FC_NAME_SERVER);
+
+       fc_gs_fchdr_build(fchs, d_id, s_id, 0);
+       fc_gs_cthdr_build(cthdr, s_id, GS_RPT_ID);
+
+       bfa_os_memset(rptid, 0, sizeof(struct fcgs_rptid_req_s));
+       rptid->port_id = port_id;
+       rptid->port_type = port_type;
+
+       return sizeof(struct fcgs_rptid_req_s) + sizeof(struct ct_hdr_s);
+}
+
+u16
+fc_ganxt_build(struct fchs_s *fchs, void *pyld, u32 s_id, u32 port_id)
+{
+       struct ct_hdr_s *cthdr = (struct ct_hdr_s *) pyld;
+       struct fcgs_ganxt_req_s *ganxt = (struct fcgs_ganxt_req_s *)(cthdr + 1);
+       u32        d_id = bfa_os_hton3b(FC_NAME_SERVER);
+
+       fc_gs_fchdr_build(fchs, d_id, s_id, 0);
+       fc_gs_cthdr_build(cthdr, s_id, GS_GA_NXT);
+
+       bfa_os_memset(ganxt, 0, sizeof(struct fcgs_ganxt_req_s));
+       ganxt->port_id = port_id;
+
+       return sizeof(struct ct_hdr_s) + sizeof(struct fcgs_ganxt_req_s);
+}
+
+/*
+ * Builds fc hdr and ct hdr for FDMI requests.
+ */
+u16
+fc_fdmi_reqhdr_build(struct fchs_s *fchs, void *pyld, u32 s_id,
+                    u16 cmd_code)
+{
+
+       struct ct_hdr_s *cthdr = (struct ct_hdr_s *) pyld;
+       u32        d_id = bfa_os_hton3b(FC_MGMT_SERVER);
+
+       fc_gs_fchdr_build(fchs, d_id, s_id, 0);
+       fc_gs_fdmi_cthdr_build(cthdr, s_id, cmd_code);
+
+       return sizeof(struct ct_hdr_s);
+}
+
+/*
+ * Given a FC4 Type, this function returns a fc4 type bitmask
+ */
+void
+fc_get_fc4type_bitmask(u8 fc4_type, u8 *bit_mask)
+{
+       u8         index;
+       u32       *ptr = (u32 *) bit_mask;
+       u32        type_value;
+
+       /*
+        * @todo : Check for bitmask size
+        */
+
+       index = fc4_type >> 5;
+       type_value = 1 << (fc4_type % 32);
+       ptr[index] = bfa_os_htonl(type_value);
+
+}
+
+/*
+ *     GMAL Request
+ */
+u16
+fc_gmal_req_build(struct fchs_s *fchs, void *pyld, u32 s_id, wwn_t wwn)
+{
+       struct ct_hdr_s *cthdr = (struct ct_hdr_s *) pyld;
+       fcgs_gmal_req_t *gmal = (fcgs_gmal_req_t *) (cthdr + 1);
+       u32        d_id = bfa_os_hton3b(FC_MGMT_SERVER);
+
+       fc_gs_fchdr_build(fchs, d_id, s_id, 0);
+       fc_gs_ms_cthdr_build(cthdr, s_id, GS_FC_GMAL_CMD,
+                       CT_GSSUBTYPE_CFGSERVER);
+
+       bfa_os_memset(gmal, 0, sizeof(fcgs_gmal_req_t));
+       gmal->wwn = wwn;
+
+       return sizeof(struct ct_hdr_s) + sizeof(fcgs_gmal_req_t);
+}
+
+/*
+ * GFN (Get Fabric Name) Request
+ */
+u16
+fc_gfn_req_build(struct fchs_s *fchs, void *pyld, u32 s_id, wwn_t wwn)
+{
+       struct ct_hdr_s *cthdr = (struct ct_hdr_s *) pyld;
+       fcgs_gfn_req_t *gfn = (fcgs_gfn_req_t *) (cthdr + 1);
+       u32        d_id = bfa_os_hton3b(FC_MGMT_SERVER);
+
+       fc_gs_fchdr_build(fchs, d_id, s_id, 0);
+       fc_gs_ms_cthdr_build(cthdr, s_id, GS_FC_GFN_CMD,
+                       CT_GSSUBTYPE_CFGSERVER);
+
+       bfa_os_memset(gfn, 0, sizeof(fcgs_gfn_req_t));
+       gfn->wwn = wwn;
+
+       return sizeof(struct ct_hdr_s) + sizeof(fcgs_gfn_req_t);
+}
diff --git a/drivers/scsi/bfa/bfa_fcbuild.h b/drivers/scsi/bfa/bfa_fcbuild.h
new file mode 100644 (file)
index 0000000..73abd02
--- /dev/null
@@ -0,0 +1,316 @@
+/*
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
+ * All rights reserved
+ * www.brocade.com
+ *
+ * Linux driver for Brocade Fibre Channel Host Bus Adapter.
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License (GPL) Version 2 as
+ * published by the Free Software Foundation
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * General Public License for more details.
+ */
+/*
+ * fcbuild.h - FC link service frame building and parsing routines
+ */
+
+#ifndef __FCBUILD_H__
+#define __FCBUILD_H__
+
+#include "bfa_os_inc.h"
+#include "bfa_fc.h"
+#include "bfa_defs_fcs.h"
+
+/*
+ * Utility Macros/functions
+ */
+
+#define wwn_is_equal(_wwn1, _wwn2)             \
+       (memcmp(&(_wwn1), &(_wwn2), sizeof(wwn_t)) == 0)
+
+#define fc_roundup(_l, _s) (((_l) + ((_s) - 1)) & ~((_s) - 1))
+
+/*
+ * Given the fc response length, this routine will return
+ * the length of the actual payload bytes following the CT header.
+ *
+ * Assumes the input response length does not include the crc, eof, etc.
+ */
+static inline   u32
+fc_get_ctresp_pyld_len(u32 resp_len)
+{
+       return resp_len - sizeof(struct ct_hdr_s);
+}
+
+/*
+ * Convert bfa speed to rpsc speed value.
+ */
+static inline  enum bfa_port_speed
+fc_rpsc_operspeed_to_bfa_speed(enum fc_rpsc_op_speed speed)
+{
+       switch (speed) {
+
+       case RPSC_OP_SPEED_1G:
+               return BFA_PORT_SPEED_1GBPS;
+
+       case RPSC_OP_SPEED_2G:
+               return BFA_PORT_SPEED_2GBPS;
+
+       case RPSC_OP_SPEED_4G:
+               return BFA_PORT_SPEED_4GBPS;
+
+       case RPSC_OP_SPEED_8G:
+               return BFA_PORT_SPEED_8GBPS;
+
+       case RPSC_OP_SPEED_10G:
+               return BFA_PORT_SPEED_10GBPS;
+
+       default:
+               return BFA_PORT_SPEED_UNKNOWN;
+       }
+}
+
+/*
+ * Convert RPSC speed to bfa speed value.
+ */
+static inline   enum fc_rpsc_op_speed
+fc_bfa_speed_to_rpsc_operspeed(enum bfa_port_speed op_speed)
+{
+       switch (op_speed) {
+
+       case BFA_PORT_SPEED_1GBPS:
+               return RPSC_OP_SPEED_1G;
+
+       case BFA_PORT_SPEED_2GBPS:
+               return RPSC_OP_SPEED_2G;
+
+       case BFA_PORT_SPEED_4GBPS:
+               return RPSC_OP_SPEED_4G;
+
+       case BFA_PORT_SPEED_8GBPS:
+               return RPSC_OP_SPEED_8G;
+
+       case BFA_PORT_SPEED_10GBPS:
+               return RPSC_OP_SPEED_10G;
+
+       default:
+               return RPSC_OP_SPEED_NOT_EST;
+       }
+}
+
+enum fc_parse_status {
+       FC_PARSE_OK = 0,
+       FC_PARSE_FAILURE = 1,
+       FC_PARSE_BUSY = 2,
+       FC_PARSE_LEN_INVAL,
+       FC_PARSE_ACC_INVAL,
+       FC_PARSE_PWWN_NOT_EQUAL,
+       FC_PARSE_NWWN_NOT_EQUAL,
+       FC_PARSE_RXSZ_INVAL,
+       FC_PARSE_NOT_FCP,
+       FC_PARSE_OPAFLAG_INVAL,
+       FC_PARSE_RPAFLAG_INVAL,
+       FC_PARSE_OPA_INVAL,
+       FC_PARSE_RPA_INVAL,
+
+};
+
+struct fc_templates_s {
+       struct fchs_s fc_els_req;
+       struct fchs_s fc_bls_req;
+       struct fc_logi_s plogi;
+       struct fc_rrq_s rrq;
+};
+
+void            fcbuild_init(void);
+
+u16        fc_flogi_build(struct fchs_s *fchs, struct fc_logi_s *flogi,
+                       u32 s_id, u16 ox_id, wwn_t port_name, wwn_t node_name,
+                              u16 pdu_size, u8 set_npiv, u8 set_auth,
+                              u16 local_bb_credits);
+
+u16        fc_fdisc_build(struct fchs_s *buf, struct fc_logi_s *flogi, u32 s_id,
+                              u16 ox_id, wwn_t port_name, wwn_t node_name,
+                              u16 pdu_size);
+
+u16        fc_flogi_acc_build(struct fchs_s *fchs, struct fc_logi_s *flogi,
+                                  u32 s_id, u16 ox_id,
+                                  wwn_t port_name, wwn_t node_name,
+                                  u16 pdu_size,
+                                  u16 local_bb_credits);
+
+u16        fc_plogi_build(struct fchs_s *fchs, void *pld, u32 d_id,
+                              u32 s_id, u16 ox_id, wwn_t port_name,
+                              wwn_t node_name, u16 pdu_size);
+
+enum fc_parse_status fc_plogi_parse(struct fchs_s *fchs);
+
+u16        fc_abts_build(struct fchs_s *buf, u32 d_id, u32 s_id,
+                             u16 ox_id);
+
+enum fc_parse_status fc_abts_rsp_parse(struct fchs_s *buf, int len);
+
+u16        fc_rrq_build(struct fchs_s *buf, struct fc_rrq_s *rrq, u32 d_id,
+                            u32 s_id, u16 ox_id, u16 rrq_oxid);
+enum fc_parse_status fc_rrq_rsp_parse(struct fchs_s *buf, int len);
+
+u16        fc_rspnid_build(struct fchs_s *fchs, void *pld, u32 s_id,
+                               u16 ox_id, u8 *name);
+
+u16        fc_rftid_build(struct fchs_s *fchs, void *pld, u32 s_id,
+                              u16 ox_id, enum bfa_lport_role role);
+
+u16       fc_rftid_build_sol(struct fchs_s *fchs, void *pyld, u32 s_id,
+                                  u16 ox_id, u8 *fc4_bitmap,
+                                  u32 bitmap_size);
+
+u16    fc_rffid_build(struct fchs_s *fchs, void *pyld, u32 s_id,
+                       u16 ox_id, u8 fc4_type, u8 fc4_ftrs);
+
+u16        fc_gidpn_build(struct fchs_s *fchs, void *pyld, u32 s_id,
+                              u16 ox_id, wwn_t port_name);
+
+u16        fc_gpnid_build(struct fchs_s *fchs, void *pld, u32 s_id,
+                              u16 ox_id, u32 port_id);
+
+u16        fc_scr_build(struct fchs_s *fchs, struct fc_scr_s *scr,
+                       u8 set_br_reg, u32 s_id, u16 ox_id);
+
+u16        fc_plogi_acc_build(struct fchs_s *fchs, void *pld, u32 d_id,
+                                  u32 s_id, u16 ox_id,
+                                  wwn_t port_name, wwn_t node_name,
+                                  u16 pdu_size);
+
+u16        fc_adisc_build(struct fchs_s *fchs, struct fc_adisc_s *adisc,
+                       u32 d_id, u32 s_id, u16 ox_id, wwn_t port_name,
+                              wwn_t node_name);
+
+enum fc_parse_status fc_adisc_parse(struct fchs_s *fchs, void *pld,
+                       u32 host_dap, wwn_t node_name, wwn_t port_name);
+
+enum fc_parse_status fc_adisc_rsp_parse(struct fc_adisc_s *adisc, int len,
+                                wwn_t port_name, wwn_t node_name);
+
+u16        fc_adisc_acc_build(struct fchs_s *fchs, struct fc_adisc_s *adisc,
+                                  u32 d_id, u32 s_id, u16 ox_id,
+                                  wwn_t port_name, wwn_t node_name);
+u16        fc_ls_rjt_build(struct fchs_s *fchs, struct fc_ls_rjt_s *ls_rjt,
+                               u32 d_id, u32 s_id, u16 ox_id,
+                               u8 reason_code, u8 reason_code_expl);
+u16        fc_ls_acc_build(struct fchs_s *fchs, struct fc_els_cmd_s *els_cmd,
+                               u32 d_id, u32 s_id, u16 ox_id);
+u16        fc_prli_build(struct fchs_s *fchs, void *pld, u32 d_id,
+                             u32 s_id, u16 ox_id);
+
+enum fc_parse_status fc_prli_rsp_parse(struct fc_prli_s *prli, int len);
+
+u16        fc_prli_acc_build(struct fchs_s *fchs, void *pld, u32 d_id,
+                                 u32 s_id, u16 ox_id,
+                                 enum bfa_lport_role role);
+
+u16        fc_rnid_build(struct fchs_s *fchs, struct fc_rnid_cmd_s *rnid,
+                             u32 d_id, u32 s_id, u16 ox_id,
+                             u32 data_format);
+
+u16        fc_rnid_acc_build(struct fchs_s *fchs,
+                       struct fc_rnid_acc_s *rnid_acc, u32 d_id, u32 s_id,
+                       u16 ox_id, u32 data_format,
+                       struct fc_rnid_common_id_data_s *common_id_data,
+                       struct fc_rnid_general_topology_data_s *gen_topo_data);
+
+u16    fc_rpsc2_build(struct fchs_s *fchs, struct fc_rpsc2_cmd_s *rps2c,
+                       u32 d_id, u32 s_id, u32 *pid_list, u16 npids);
+u16        fc_rpsc_build(struct fchs_s *fchs, struct fc_rpsc_cmd_s *rpsc,
+                             u32 d_id, u32 s_id, u16 ox_id);
+u16        fc_rpsc_acc_build(struct fchs_s *fchs,
+                       struct fc_rpsc_acc_s *rpsc_acc, u32 d_id, u32 s_id,
+                       u16 ox_id, struct fc_rpsc_speed_info_s *oper_speed);
+u16        fc_gid_ft_build(struct fchs_s *fchs, void *pld, u32 s_id,
+                               u8 fc4_type);
+
+u16        fc_rpnid_build(struct fchs_s *fchs, void *pyld, u32 s_id,
+                              u32 port_id, wwn_t port_name);
+
+u16        fc_rnnid_build(struct fchs_s *fchs, void *pyld, u32 s_id,
+                              u32 port_id, wwn_t node_name);
+
+u16        fc_rcsid_build(struct fchs_s *fchs, void *pyld, u32 s_id,
+                              u32 port_id, u32 cos);
+
+u16        fc_rptid_build(struct fchs_s *fchs, void *pyld, u32 s_id,
+                              u32 port_id, u8 port_type);
+
+u16        fc_ganxt_build(struct fchs_s *fchs, void *pyld, u32 s_id,
+                              u32 port_id);
+
+u16        fc_logo_build(struct fchs_s *fchs, struct fc_logo_s *logo, u32 d_id,
+                             u32 s_id, u16 ox_id, wwn_t port_name);
+
+u16        fc_logo_acc_build(struct fchs_s *fchs, void *pld, u32 d_id,
+                                 u32 s_id, u16 ox_id);
+
+u16        fc_fdmi_reqhdr_build(struct fchs_s *fchs, void *pyld, u32 s_id,
+                                    u16 cmd_code);
+u16    fc_gmal_req_build(struct fchs_s *fchs, void *pyld, u32 s_id, wwn_t wwn);
+u16    fc_gfn_req_build(struct fchs_s *fchs, void *pyld, u32 s_id, wwn_t wwn);
+
+void           fc_get_fc4type_bitmask(u8 fc4_type, u8 *bit_mask);
+
+void           fc_els_req_build(struct fchs_s *fchs, u32 d_id, u32 s_id,
+                                        u16 ox_id);
+
+enum fc_parse_status   fc_els_rsp_parse(struct fchs_s *fchs, int len);
+
+enum fc_parse_status   fc_plogi_rsp_parse(struct fchs_s *fchs, int len,
+                                       wwn_t port_name);
+
+enum fc_parse_status   fc_prli_parse(struct fc_prli_s *prli);
+
+enum fc_parse_status   fc_pdisc_parse(struct fchs_s *fchs, wwn_t node_name,
+                                       wwn_t port_name);
+
+u16 fc_ba_acc_build(struct fchs_s *fchs, struct fc_ba_acc_s *ba_acc, u32 d_id,
+               u32 s_id, u16 ox_id, u16 rx_id);
+
+int fc_logout_params_pages(struct fchs_s *fc_frame, u8 els_code);
+
+u16 fc_tprlo_acc_build(struct fchs_s *fchs, struct fc_tprlo_acc_s *tprlo_acc,
+               u32 d_id, u32 s_id, u16 ox_id, int num_pages);
+
+u16 fc_prlo_acc_build(struct fchs_s *fchs, struct fc_prlo_acc_s *prlo_acc,
+               u32 d_id, u32 s_id, u16 ox_id, int num_pages);
+
+u16 fc_logo_rsp_parse(struct fchs_s *fchs, int len);
+
+u16 fc_pdisc_build(struct fchs_s *fchs, u32 d_id, u32 s_id,
+               u16 ox_id, wwn_t port_name, wwn_t node_name,
+               u16 pdu_size);
+
+u16 fc_pdisc_rsp_parse(struct fchs_s *fchs, int len, wwn_t port_name);
+
+u16 fc_prlo_build(struct fchs_s *fchs, u32 d_id, u32 s_id,
+               u16 ox_id, int num_pages);
+
+u16 fc_prlo_rsp_parse(struct fchs_s *fchs, int len);
+
+u16 fc_tprlo_build(struct fchs_s *fchs, u32 d_id, u32 s_id,
+               u16 ox_id, int num_pages, enum fc_tprlo_type tprlo_type,
+               u32 tpr_id);
+
+u16 fc_tprlo_rsp_parse(struct fchs_s *fchs, int len);
+
+u16 fc_ba_rjt_build(struct fchs_s *fchs, u32 d_id, u32 s_id,
+               u16 ox_id, u32 reason_code, u32 reason_expl);
+
+u16 fc_gnnid_build(struct fchs_s *fchs, void *pyld, u32 s_id, u16 ox_id,
+               u32 port_id);
+
+u16 fc_ct_rsp_parse(struct ct_hdr_s *cthdr);
+
+u16 fc_rscn_build(struct fchs_s *fchs, struct fc_rscn_pl_s *rscn, u32 s_id,
+               u16 ox_id);
+#endif
index 8c703d8dc94bb4701c661e9a43b0d44291d55f6e..33c8dd51f4748677fadc78b518fc51964a318859 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
  * All rights reserved
  * www.brocade.com
  *
  * General Public License for more details.
  */
 
-#include <bfa.h>
-#include <log/bfa_log_hal.h>
+#include "bfa_modules.h"
+#include "bfa_cb_ioim.h"
 
 BFA_TRC_FILE(HAL, FCPIM);
 BFA_MODULE(fcpim);
 
+
+#define bfa_fcpim_add_iostats(__l, __r, __stats)       \
+       (__l->__stats += __r->__stats)
+
+
+/**
+ *  BFA ITNIM Related definitions
+ */
+static void bfa_itnim_update_del_itn_stats(struct bfa_itnim_s *itnim);
+
+#define BFA_ITNIM_FROM_TAG(_fcpim, _tag)                                \
+       (((_fcpim)->itnim_arr + ((_tag) & ((_fcpim)->num_itnims - 1))))
+
+#define bfa_fcpim_additn(__itnim)                                      \
+       list_add_tail(&(__itnim)->qe, &(__itnim)->fcpim->itnim_q)
+#define bfa_fcpim_delitn(__itnim)      do {                            \
+       bfa_assert(bfa_q_is_on_q(&(__itnim)->fcpim->itnim_q, __itnim));      \
+       bfa_itnim_update_del_itn_stats(__itnim);      \
+       list_del(&(__itnim)->qe);      \
+       bfa_assert(list_empty(&(__itnim)->io_q));      \
+       bfa_assert(list_empty(&(__itnim)->io_cleanup_q));      \
+       bfa_assert(list_empty(&(__itnim)->pending_q));      \
+} while (0)
+
+#define bfa_itnim_online_cb(__itnim) do {                              \
+       if ((__itnim)->bfa->fcs)                                        \
+               bfa_cb_itnim_online((__itnim)->ditn);      \
+       else {                                                          \
+               bfa_cb_queue((__itnim)->bfa, &(__itnim)->hcb_qe,        \
+               __bfa_cb_itnim_online, (__itnim));      \
+       }                                                               \
+} while (0)
+
+#define bfa_itnim_offline_cb(__itnim) do {                             \
+       if ((__itnim)->bfa->fcs)                                        \
+               bfa_cb_itnim_offline((__itnim)->ditn);      \
+       else {                                                          \
+               bfa_cb_queue((__itnim)->bfa, &(__itnim)->hcb_qe,        \
+               __bfa_cb_itnim_offline, (__itnim));      \
+       }                                                               \
+} while (0)
+
+#define bfa_itnim_sler_cb(__itnim) do {                                        \
+       if ((__itnim)->bfa->fcs)                                        \
+               bfa_cb_itnim_sler((__itnim)->ditn);      \
+       else {                                                          \
+               bfa_cb_queue((__itnim)->bfa, &(__itnim)->hcb_qe,        \
+               __bfa_cb_itnim_sler, (__itnim));      \
+       }                                                               \
+} while (0)
+
+/**
+ *  bfa_itnim_sm BFA itnim state machine
+ */
+
+
+enum bfa_itnim_event {
+       BFA_ITNIM_SM_CREATE = 1,        /*  itnim is created */
+       BFA_ITNIM_SM_ONLINE = 2,        /*  itnim is online */
+       BFA_ITNIM_SM_OFFLINE = 3,       /*  itnim is offline */
+       BFA_ITNIM_SM_FWRSP = 4,         /*  firmware response */
+       BFA_ITNIM_SM_DELETE = 5,        /*  deleting an existing itnim */
+       BFA_ITNIM_SM_CLEANUP = 6,       /*  IO cleanup completion */
+       BFA_ITNIM_SM_SLER = 7,          /*  second level error recovery */
+       BFA_ITNIM_SM_HWFAIL = 8,        /*  IOC h/w failure event */
+       BFA_ITNIM_SM_QRESUME = 9,       /*  queue space available */
+};
+
+/**
+ *  BFA IOIM related definitions
+ */
+#define bfa_ioim_move_to_comp_q(__ioim) do {                           \
+       list_del(&(__ioim)->qe);                                        \
+       list_add_tail(&(__ioim)->qe, &(__ioim)->fcpim->ioim_comp_q);    \
+} while (0)
+
+
+#define bfa_ioim_cb_profile_comp(__fcpim, __ioim) do {                 \
+       if ((__fcpim)->profile_comp)                                    \
+               (__fcpim)->profile_comp(__ioim);                        \
+} while (0)
+
+#define bfa_ioim_cb_profile_start(__fcpim, __ioim) do {                        \
+       if ((__fcpim)->profile_start)                                   \
+               (__fcpim)->profile_start(__ioim);                       \
+} while (0)
+/**
+ *  hal_ioim_sm
+ */
+
+/**
+ * IO state machine events
+ */
+enum bfa_ioim_event {
+       BFA_IOIM_SM_START       = 1,    /*  io start request from host */
+       BFA_IOIM_SM_COMP_GOOD   = 2,    /*  io good comp, resource free */
+       BFA_IOIM_SM_COMP        = 3,    /*  io comp, resource is free */
+       BFA_IOIM_SM_COMP_UTAG   = 4,    /*  io comp, resource is free */
+       BFA_IOIM_SM_DONE        = 5,    /*  io comp, resource not free */
+       BFA_IOIM_SM_FREE        = 6,    /*  io resource is freed */
+       BFA_IOIM_SM_ABORT       = 7,    /*  abort request from scsi stack */
+       BFA_IOIM_SM_ABORT_COMP  = 8,    /*  abort from f/w */
+       BFA_IOIM_SM_ABORT_DONE  = 9,    /*  abort completion from f/w */
+       BFA_IOIM_SM_QRESUME     = 10,   /*  CQ space available to queue IO */
+       BFA_IOIM_SM_SGALLOCED   = 11,   /*  SG page allocation successful */
+       BFA_IOIM_SM_SQRETRY     = 12,   /*  sequence recovery retry */
+       BFA_IOIM_SM_HCB         = 13,   /*  bfa callback complete */
+       BFA_IOIM_SM_CLEANUP     = 14,   /*  IO cleanup from itnim */
+       BFA_IOIM_SM_TMSTART     = 15,   /*  IO cleanup from tskim */
+       BFA_IOIM_SM_TMDONE      = 16,   /*  IO cleanup from tskim */
+       BFA_IOIM_SM_HWFAIL      = 17,   /*  IOC h/w failure event */
+       BFA_IOIM_SM_IOTOV       = 18,   /*  ITN offline TOV */
+};
+
+
+/**
+ *  BFA TSKIM related definitions
+ */
+
+/**
+ * task management completion handling
+ */
+#define bfa_tskim_qcomp(__tskim, __cbfn) do {                          \
+       bfa_cb_queue((__tskim)->bfa, &(__tskim)->hcb_qe, __cbfn, (__tskim));\
+       bfa_tskim_notify_comp(__tskim);      \
+} while (0)
+
+#define bfa_tskim_notify_comp(__tskim) do {                            \
+       if ((__tskim)->notify)                                          \
+               bfa_itnim_tskdone((__tskim)->itnim);      \
+} while (0)
+
+
+enum bfa_tskim_event {
+       BFA_TSKIM_SM_START      = 1,    /*  TM command start            */
+       BFA_TSKIM_SM_DONE       = 2,    /*  TM completion               */
+       BFA_TSKIM_SM_QRESUME    = 3,    /*  resume after qfull          */
+       BFA_TSKIM_SM_HWFAIL     = 5,    /*  IOC h/w failure event       */
+       BFA_TSKIM_SM_HCB        = 6,    /*  BFA callback completion     */
+       BFA_TSKIM_SM_IOS_DONE   = 7,    /*  IO and sub TM completions   */
+       BFA_TSKIM_SM_CLEANUP    = 8,    /*  TM cleanup on ITN offline   */
+       BFA_TSKIM_SM_CLEANUP_DONE = 9,  /*  TM abort completion */
+};
+
+/**
+ * forward declaration for BFA ITNIM functions
+ */
+static void     bfa_itnim_iocdisable_cleanup(struct bfa_itnim_s *itnim);
+static bfa_boolean_t bfa_itnim_send_fwcreate(struct bfa_itnim_s *itnim);
+static bfa_boolean_t bfa_itnim_send_fwdelete(struct bfa_itnim_s *itnim);
+static void     bfa_itnim_cleanp_comp(void *itnim_cbarg);
+static void     bfa_itnim_cleanup(struct bfa_itnim_s *itnim);
+static void     __bfa_cb_itnim_online(void *cbarg, bfa_boolean_t complete);
+static void     __bfa_cb_itnim_offline(void *cbarg, bfa_boolean_t complete);
+static void     __bfa_cb_itnim_sler(void *cbarg, bfa_boolean_t complete);
+static void     bfa_itnim_iotov_online(struct bfa_itnim_s *itnim);
+static void     bfa_itnim_iotov_cleanup(struct bfa_itnim_s *itnim);
+static void     bfa_itnim_iotov(void *itnim_arg);
+static void     bfa_itnim_iotov_start(struct bfa_itnim_s *itnim);
+static void     bfa_itnim_iotov_stop(struct bfa_itnim_s *itnim);
+static void     bfa_itnim_iotov_delete(struct bfa_itnim_s *itnim);
+
+/**
+ * forward declaration of ITNIM state machine
+ */
+static void     bfa_itnim_sm_uninit(struct bfa_itnim_s *itnim,
+                                       enum bfa_itnim_event event);
+static void     bfa_itnim_sm_created(struct bfa_itnim_s *itnim,
+                                       enum bfa_itnim_event event);
+static void     bfa_itnim_sm_fwcreate(struct bfa_itnim_s *itnim,
+                                       enum bfa_itnim_event event);
+static void     bfa_itnim_sm_delete_pending(struct bfa_itnim_s *itnim,
+                                       enum bfa_itnim_event event);
+static void     bfa_itnim_sm_online(struct bfa_itnim_s *itnim,
+                                       enum bfa_itnim_event event);
+static void     bfa_itnim_sm_sler(struct bfa_itnim_s *itnim,
+                                       enum bfa_itnim_event event);
+static void     bfa_itnim_sm_cleanup_offline(struct bfa_itnim_s *itnim,
+                                       enum bfa_itnim_event event);
+static void     bfa_itnim_sm_cleanup_delete(struct bfa_itnim_s *itnim,
+                                       enum bfa_itnim_event event);
+static void     bfa_itnim_sm_fwdelete(struct bfa_itnim_s *itnim,
+                                       enum bfa_itnim_event event);
+static void     bfa_itnim_sm_offline(struct bfa_itnim_s *itnim,
+                                       enum bfa_itnim_event event);
+static void     bfa_itnim_sm_iocdisable(struct bfa_itnim_s *itnim,
+                                       enum bfa_itnim_event event);
+static void     bfa_itnim_sm_deleting(struct bfa_itnim_s *itnim,
+                                       enum bfa_itnim_event event);
+static void     bfa_itnim_sm_fwcreate_qfull(struct bfa_itnim_s *itnim,
+                                       enum bfa_itnim_event event);
+static void     bfa_itnim_sm_fwdelete_qfull(struct bfa_itnim_s *itnim,
+                                       enum bfa_itnim_event event);
+static void     bfa_itnim_sm_deleting_qfull(struct bfa_itnim_s *itnim,
+                                       enum bfa_itnim_event event);
+
+/**
+ * forward declaration for BFA IOIM functions
+ */
+static bfa_boolean_t   bfa_ioim_send_ioreq(struct bfa_ioim_s *ioim);
+static bfa_boolean_t   bfa_ioim_sge_setup(struct bfa_ioim_s *ioim);
+static void            bfa_ioim_sgpg_setup(struct bfa_ioim_s *ioim);
+static bfa_boolean_t   bfa_ioim_send_abort(struct bfa_ioim_s *ioim);
+static void            bfa_ioim_notify_cleanup(struct bfa_ioim_s *ioim);
+static void __bfa_cb_ioim_good_comp(void *cbarg, bfa_boolean_t complete);
+static void __bfa_cb_ioim_comp(void *cbarg, bfa_boolean_t complete);
+static void __bfa_cb_ioim_abort(void *cbarg, bfa_boolean_t complete);
+static void __bfa_cb_ioim_failed(void *cbarg, bfa_boolean_t complete);
+static void __bfa_cb_ioim_pathtov(void *cbarg, bfa_boolean_t complete);
+static bfa_boolean_t    bfa_ioim_is_abortable(struct bfa_ioim_s *ioim);
+
+
+/**
+ * forward declaration of BFA IO state machine
+ */
+static void     bfa_ioim_sm_uninit(struct bfa_ioim_s *ioim,
+                                       enum bfa_ioim_event event);
+static void     bfa_ioim_sm_sgalloc(struct bfa_ioim_s *ioim,
+                                       enum bfa_ioim_event event);
+static void     bfa_ioim_sm_active(struct bfa_ioim_s *ioim,
+                                       enum bfa_ioim_event event);
+static void     bfa_ioim_sm_abort(struct bfa_ioim_s *ioim,
+                                       enum bfa_ioim_event event);
+static void     bfa_ioim_sm_cleanup(struct bfa_ioim_s *ioim,
+                                       enum bfa_ioim_event event);
+static void     bfa_ioim_sm_qfull(struct bfa_ioim_s *ioim,
+                                       enum bfa_ioim_event event);
+static void     bfa_ioim_sm_abort_qfull(struct bfa_ioim_s *ioim,
+                                       enum bfa_ioim_event event);
+static void     bfa_ioim_sm_cleanup_qfull(struct bfa_ioim_s *ioim,
+                                       enum bfa_ioim_event event);
+static void     bfa_ioim_sm_hcb(struct bfa_ioim_s *ioim,
+                                       enum bfa_ioim_event event);
+static void     bfa_ioim_sm_hcb_free(struct bfa_ioim_s *ioim,
+                                       enum bfa_ioim_event event);
+static void     bfa_ioim_sm_resfree(struct bfa_ioim_s *ioim,
+                                       enum bfa_ioim_event event);
+static void    bfa_ioim_sm_cmnd_retry(struct bfa_ioim_s *ioim,
+                                       enum bfa_ioim_event event);
+
+/**
+ * forward declaration for BFA TSKIM functions
+ */
+static void     __bfa_cb_tskim_done(void *cbarg, bfa_boolean_t complete);
+static void     __bfa_cb_tskim_failed(void *cbarg, bfa_boolean_t complete);
+static bfa_boolean_t bfa_tskim_match_scope(struct bfa_tskim_s *tskim,
+                                       lun_t lun);
+static void     bfa_tskim_gather_ios(struct bfa_tskim_s *tskim);
+static void     bfa_tskim_cleanp_comp(void *tskim_cbarg);
+static void     bfa_tskim_cleanup_ios(struct bfa_tskim_s *tskim);
+static bfa_boolean_t bfa_tskim_send(struct bfa_tskim_s *tskim);
+static bfa_boolean_t bfa_tskim_send_abort(struct bfa_tskim_s *tskim);
+static void     bfa_tskim_iocdisable_ios(struct bfa_tskim_s *tskim);
+
+
+/**
+ * forward declaration of BFA TSKIM state machine
+ */
+static void     bfa_tskim_sm_uninit(struct bfa_tskim_s *tskim,
+                                       enum bfa_tskim_event event);
+static void     bfa_tskim_sm_active(struct bfa_tskim_s *tskim,
+                                       enum bfa_tskim_event event);
+static void     bfa_tskim_sm_cleanup(struct bfa_tskim_s *tskim,
+                                       enum bfa_tskim_event event);
+static void     bfa_tskim_sm_iocleanup(struct bfa_tskim_s *tskim,
+                                       enum bfa_tskim_event event);
+static void     bfa_tskim_sm_qfull(struct bfa_tskim_s *tskim,
+                                       enum bfa_tskim_event event);
+static void     bfa_tskim_sm_cleanup_qfull(struct bfa_tskim_s *tskim,
+                                       enum bfa_tskim_event event);
+static void     bfa_tskim_sm_hcb(struct bfa_tskim_s *tskim,
+                                       enum bfa_tskim_event event);
+
 /**
  *  hal_fcpim_mod BFA FCP Initiator Mode module
  */
 
 /**
- *             Compute and return memory needed by FCP(im) module.
+ *     Compute and return memory needed by FCP(im) module.
  */
 static void
 bfa_fcpim_meminfo(struct bfa_iocfc_cfg_s *cfg, u32 *km_len,
@@ -58,7 +331,7 @@ bfa_fcpim_meminfo(struct bfa_iocfc_cfg_s *cfg, u32 *km_len,
 
 static void
 bfa_fcpim_attach(struct bfa_s *bfa, void *bfad, struct bfa_iocfc_cfg_s *cfg,
-                    struct bfa_meminfo_s *meminfo, struct bfa_pcidev_s *pcidev)
+               struct bfa_meminfo_s *meminfo, struct bfa_pcidev_s *pcidev)
 {
        struct bfa_fcpim_mod_s *fcpim = BFA_FCPIM_MOD(bfa);
 
@@ -67,12 +340,14 @@ bfa_fcpim_attach(struct bfa_s *bfa, void *bfad, struct bfa_iocfc_cfg_s *cfg,
        bfa_trc(bfa, cfg->fwcfg.num_ioim_reqs);
        bfa_trc(bfa, cfg->fwcfg.num_tskim_reqs);
 
-       fcpim->bfa            = bfa;
-       fcpim->num_itnims     = cfg->fwcfg.num_rports;
+       fcpim->bfa              = bfa;
+       fcpim->num_itnims       = cfg->fwcfg.num_rports;
        fcpim->num_ioim_reqs  = cfg->fwcfg.num_ioim_reqs;
        fcpim->num_tskim_reqs = cfg->fwcfg.num_tskim_reqs;
-       fcpim->path_tov       = cfg->drvcfg.path_tov;
-       fcpim->delay_comp         = cfg->drvcfg.delay_comp;
+       fcpim->path_tov         = cfg->drvcfg.path_tov;
+       fcpim->delay_comp       = cfg->drvcfg.delay_comp;
+       fcpim->profile_comp = NULL;
+       fcpim->profile_start = NULL;
 
        bfa_itnim_attach(fcpim, meminfo);
        bfa_tskim_attach(fcpim, meminfo);
@@ -103,7 +378,7 @@ bfa_fcpim_iocdisable(struct bfa_s *bfa)
 {
        struct bfa_fcpim_mod_s *fcpim = BFA_FCPIM_MOD(bfa);
        struct bfa_itnim_s *itnim;
-       struct list_head        *qe, *qen;
+       struct list_head *qe, *qen;
 
        list_for_each_safe(qe, qen, &fcpim->itnim_q) {
                itnim = (struct bfa_itnim_s *) qe;
@@ -111,6 +386,56 @@ bfa_fcpim_iocdisable(struct bfa_s *bfa)
        }
 }
 
+void
+bfa_fcpim_add_stats(struct bfa_itnim_iostats_s *lstats,
+               struct bfa_itnim_iostats_s *rstats)
+{
+       bfa_fcpim_add_iostats(lstats, rstats, total_ios);
+       bfa_fcpim_add_iostats(lstats, rstats, qresumes);
+       bfa_fcpim_add_iostats(lstats, rstats, no_iotags);
+       bfa_fcpim_add_iostats(lstats, rstats, io_aborts);
+       bfa_fcpim_add_iostats(lstats, rstats, no_tskims);
+       bfa_fcpim_add_iostats(lstats, rstats, iocomp_ok);
+       bfa_fcpim_add_iostats(lstats, rstats, iocomp_underrun);
+       bfa_fcpim_add_iostats(lstats, rstats, iocomp_overrun);
+       bfa_fcpim_add_iostats(lstats, rstats, iocomp_aborted);
+       bfa_fcpim_add_iostats(lstats, rstats, iocomp_timedout);
+       bfa_fcpim_add_iostats(lstats, rstats, iocom_nexus_abort);
+       bfa_fcpim_add_iostats(lstats, rstats, iocom_proto_err);
+       bfa_fcpim_add_iostats(lstats, rstats, iocom_dif_err);
+       bfa_fcpim_add_iostats(lstats, rstats, iocom_sqer_needed);
+       bfa_fcpim_add_iostats(lstats, rstats, iocom_res_free);
+       bfa_fcpim_add_iostats(lstats, rstats, iocom_hostabrts);
+       bfa_fcpim_add_iostats(lstats, rstats, iocom_utags);
+       bfa_fcpim_add_iostats(lstats, rstats, io_cleanups);
+       bfa_fcpim_add_iostats(lstats, rstats, io_tmaborts);
+       bfa_fcpim_add_iostats(lstats, rstats, onlines);
+       bfa_fcpim_add_iostats(lstats, rstats, offlines);
+       bfa_fcpim_add_iostats(lstats, rstats, creates);
+       bfa_fcpim_add_iostats(lstats, rstats, deletes);
+       bfa_fcpim_add_iostats(lstats, rstats, create_comps);
+       bfa_fcpim_add_iostats(lstats, rstats, delete_comps);
+       bfa_fcpim_add_iostats(lstats, rstats, sler_events);
+       bfa_fcpim_add_iostats(lstats, rstats, fw_create);
+       bfa_fcpim_add_iostats(lstats, rstats, fw_delete);
+       bfa_fcpim_add_iostats(lstats, rstats, ioc_disabled);
+       bfa_fcpim_add_iostats(lstats, rstats, cleanup_comps);
+       bfa_fcpim_add_iostats(lstats, rstats, tm_cmnds);
+       bfa_fcpim_add_iostats(lstats, rstats, tm_fw_rsps);
+       bfa_fcpim_add_iostats(lstats, rstats, tm_success);
+       bfa_fcpim_add_iostats(lstats, rstats, tm_failures);
+       bfa_fcpim_add_iostats(lstats, rstats, tm_io_comps);
+       bfa_fcpim_add_iostats(lstats, rstats, tm_qresumes);
+       bfa_fcpim_add_iostats(lstats, rstats, tm_iocdowns);
+       bfa_fcpim_add_iostats(lstats, rstats, tm_cleanups);
+       bfa_fcpim_add_iostats(lstats, rstats, tm_cleanup_comps);
+       bfa_fcpim_add_iostats(lstats, rstats, io_comps);
+       bfa_fcpim_add_iostats(lstats, rstats, input_reqs);
+       bfa_fcpim_add_iostats(lstats, rstats, output_reqs);
+       bfa_fcpim_add_iostats(lstats, rstats, rd_throughput);
+       bfa_fcpim_add_iostats(lstats, rstats, wr_throughput);
+}
+
 void
 bfa_fcpim_path_tov_set(struct bfa_s *bfa, u16 path_tov)
 {
@@ -130,21 +455,113 @@ bfa_fcpim_path_tov_get(struct bfa_s *bfa)
 }
 
 bfa_status_t
-bfa_fcpim_get_modstats(struct bfa_s *bfa, struct bfa_fcpim_stats_s *modstats)
+bfa_fcpim_port_iostats(struct bfa_s *bfa, struct bfa_itnim_iostats_s *stats,
+       u8 lp_tag)
+{
+       struct bfa_fcpim_mod_s *fcpim = BFA_FCPIM_MOD(bfa);
+       struct list_head *qe, *qen;
+       struct bfa_itnim_s *itnim;
+
+       /* accumulate IO stats from itnim */
+       bfa_os_memset(stats, 0, sizeof(struct bfa_itnim_iostats_s));
+       list_for_each_safe(qe, qen, &fcpim->itnim_q) {
+               itnim = (struct bfa_itnim_s *) qe;
+               if (itnim->rport->rport_info.lp_tag != lp_tag)
+                       continue;
+               bfa_fcpim_add_stats(stats, &(itnim->stats));
+       }
+       return BFA_STATUS_OK;
+}
+bfa_status_t
+bfa_fcpim_get_modstats(struct bfa_s *bfa, struct bfa_itnim_iostats_s *modstats)
+{
+       struct bfa_fcpim_mod_s *fcpim = BFA_FCPIM_MOD(bfa);
+       struct list_head *qe, *qen;
+       struct bfa_itnim_s *itnim;
+
+       /* accumulate IO stats from itnim */
+       bfa_os_memset(modstats, 0, sizeof(struct bfa_itnim_iostats_s));
+       list_for_each_safe(qe, qen, &fcpim->itnim_q) {
+               itnim = (struct bfa_itnim_s *) qe;
+               bfa_fcpim_add_stats(modstats, &(itnim->stats));
+       }
+       return BFA_STATUS_OK;
+}
+
+bfa_status_t
+bfa_fcpim_get_del_itn_stats(struct bfa_s *bfa,
+        struct bfa_fcpim_del_itn_stats_s *modstats)
+{
+       struct bfa_fcpim_mod_s *fcpim = BFA_FCPIM_MOD(bfa);
+
+       *modstats = fcpim->del_itn_stats;
+
+       return BFA_STATUS_OK;
+}
+
+
+bfa_status_t
+bfa_fcpim_profile_on(struct bfa_s *bfa, u32 time)
+{
+       struct bfa_itnim_s *itnim;
+       struct bfa_fcpim_mod_s *fcpim = BFA_FCPIM_MOD(bfa);
+       struct list_head *qe, *qen;
+
+       /* accumulate IO stats from itnim */
+       list_for_each_safe(qe, qen, &fcpim->itnim_q) {
+               itnim = (struct bfa_itnim_s *) qe;
+               bfa_itnim_clear_stats(itnim);
+       }
+       fcpim->io_profile = BFA_TRUE;
+       fcpim->io_profile_start_time = time;
+       fcpim->profile_comp = bfa_ioim_profile_comp;
+       fcpim->profile_start = bfa_ioim_profile_start;
+
+       return BFA_STATUS_OK;
+}
+bfa_status_t
+bfa_fcpim_profile_off(struct bfa_s *bfa)
 {
        struct bfa_fcpim_mod_s *fcpim = BFA_FCPIM_MOD(bfa);
+       fcpim->io_profile = BFA_FALSE;
+       fcpim->io_profile_start_time = 0;
+       fcpim->profile_comp = NULL;
+       fcpim->profile_start = NULL;
+       return BFA_STATUS_OK;
+}
 
-       *modstats = fcpim->stats;
+bfa_status_t
+bfa_fcpim_port_clear_iostats(struct bfa_s *bfa, u8 lp_tag)
+{
+       struct bfa_fcpim_mod_s *fcpim = BFA_FCPIM_MOD(bfa);
+       struct list_head *qe, *qen;
+       struct bfa_itnim_s *itnim;
 
+       /* clear IO stats from all active itnims */
+       list_for_each_safe(qe, qen, &fcpim->itnim_q) {
+               itnim = (struct bfa_itnim_s *) qe;
+               if (itnim->rport->rport_info.lp_tag != lp_tag)
+                       continue;
+               bfa_itnim_clear_stats(itnim);
+       }
        return BFA_STATUS_OK;
+
 }
 
 bfa_status_t
 bfa_fcpim_clr_modstats(struct bfa_s *bfa)
 {
        struct bfa_fcpim_mod_s *fcpim = BFA_FCPIM_MOD(bfa);
+       struct list_head *qe, *qen;
+       struct bfa_itnim_s *itnim;
 
-       memset(&fcpim->stats, 0, sizeof(struct bfa_fcpim_stats_s));
+       /* clear IO stats from all active itnims */
+       list_for_each_safe(qe, qen, &fcpim->itnim_q) {
+               itnim = (struct bfa_itnim_s *) qe;
+               bfa_itnim_clear_stats(itnim);
+       }
+       bfa_os_memset(&fcpim->del_itn_stats, 0,
+               sizeof(struct bfa_fcpim_del_itn_stats_s));
 
        return BFA_STATUS_OK;
 }
@@ -176,14 +593,6 @@ bfa_fcpim_update_ioredirect(struct bfa_s *bfa)
         * IO redirection is turned off when QoS is enabled and vice versa
         */
        ioredirect = bfa_fcport_is_qos_enabled(bfa) ? BFA_FALSE : BFA_TRUE;
-
-       /*
-        * Notify the bfad module of a possible state change in
-        * IO redirection capability, due to a QoS state change. bfad will
-        * check on the support for io redirection and update the
-        * fcpim's ioredirect state accordingly.
-        */
-       bfa_cb_ioredirect_state_change((void *)(bfa->bfad), ioredirect);
 }
 
 void
@@ -192,3 +601,3012 @@ bfa_fcpim_set_ioredirect(struct bfa_s *bfa, bfa_boolean_t state)
        struct bfa_fcpim_mod_s *fcpim = BFA_FCPIM_MOD(bfa);
        fcpim->ioredirect = state;
 }
+
+
+
+/**
+ *  BFA ITNIM module state machine functions
+ */
+
+/**
+ *     Beginning/unallocated state - no events expected.
+ */
+static void
+bfa_itnim_sm_uninit(struct bfa_itnim_s *itnim, enum bfa_itnim_event event)
+{
+       bfa_trc(itnim->bfa, itnim->rport->rport_tag);
+       bfa_trc(itnim->bfa, event);
+
+       switch (event) {
+       case BFA_ITNIM_SM_CREATE:
+               bfa_sm_set_state(itnim, bfa_itnim_sm_created);
+               itnim->is_online = BFA_FALSE;
+               bfa_fcpim_additn(itnim);
+               break;
+
+       default:
+               bfa_sm_fault(itnim->bfa, event);
+       }
+}
+
+/**
+ *     Beginning state, only online event expected.
+ */
+static void
+bfa_itnim_sm_created(struct bfa_itnim_s *itnim, enum bfa_itnim_event event)
+{
+       bfa_trc(itnim->bfa, itnim->rport->rport_tag);
+       bfa_trc(itnim->bfa, event);
+
+       switch (event) {
+       case BFA_ITNIM_SM_ONLINE:
+               if (bfa_itnim_send_fwcreate(itnim))
+                       bfa_sm_set_state(itnim, bfa_itnim_sm_fwcreate);
+               else
+                       bfa_sm_set_state(itnim, bfa_itnim_sm_fwcreate_qfull);
+               break;
+
+       case BFA_ITNIM_SM_DELETE:
+               bfa_sm_set_state(itnim, bfa_itnim_sm_uninit);
+               bfa_fcpim_delitn(itnim);
+               break;
+
+       case BFA_ITNIM_SM_HWFAIL:
+               bfa_sm_set_state(itnim, bfa_itnim_sm_iocdisable);
+               break;
+
+       default:
+               bfa_sm_fault(itnim->bfa, event);
+       }
+}
+
+/**
+ *     Waiting for itnim create response from firmware.
+ */
+static void
+bfa_itnim_sm_fwcreate(struct bfa_itnim_s *itnim, enum bfa_itnim_event event)
+{
+       bfa_trc(itnim->bfa, itnim->rport->rport_tag);
+       bfa_trc(itnim->bfa, event);
+
+       switch (event) {
+       case BFA_ITNIM_SM_FWRSP:
+               bfa_sm_set_state(itnim, bfa_itnim_sm_online);
+               itnim->is_online = BFA_TRUE;
+               bfa_itnim_iotov_online(itnim);
+               bfa_itnim_online_cb(itnim);
+               break;
+
+       case BFA_ITNIM_SM_DELETE:
+               bfa_sm_set_state(itnim, bfa_itnim_sm_delete_pending);
+               break;
+
+       case BFA_ITNIM_SM_OFFLINE:
+               if (bfa_itnim_send_fwdelete(itnim))
+                       bfa_sm_set_state(itnim, bfa_itnim_sm_fwdelete);
+               else
+                       bfa_sm_set_state(itnim, bfa_itnim_sm_fwdelete_qfull);
+               break;
+
+       case BFA_ITNIM_SM_HWFAIL:
+               bfa_sm_set_state(itnim, bfa_itnim_sm_iocdisable);
+               break;
+
+       default:
+               bfa_sm_fault(itnim->bfa, event);
+       }
+}
+
+static void
+bfa_itnim_sm_fwcreate_qfull(struct bfa_itnim_s *itnim,
+                       enum bfa_itnim_event event)
+{
+       bfa_trc(itnim->bfa, itnim->rport->rport_tag);
+       bfa_trc(itnim->bfa, event);
+
+       switch (event) {
+       case BFA_ITNIM_SM_QRESUME:
+               bfa_sm_set_state(itnim, bfa_itnim_sm_fwcreate);
+               bfa_itnim_send_fwcreate(itnim);
+               break;
+
+       case BFA_ITNIM_SM_DELETE:
+               bfa_sm_set_state(itnim, bfa_itnim_sm_uninit);
+               bfa_reqq_wcancel(&itnim->reqq_wait);
+               bfa_fcpim_delitn(itnim);
+               break;
+
+       case BFA_ITNIM_SM_OFFLINE:
+               bfa_sm_set_state(itnim, bfa_itnim_sm_offline);
+               bfa_reqq_wcancel(&itnim->reqq_wait);
+               bfa_itnim_offline_cb(itnim);
+               break;
+
+       case BFA_ITNIM_SM_HWFAIL:
+               bfa_sm_set_state(itnim, bfa_itnim_sm_iocdisable);
+               bfa_reqq_wcancel(&itnim->reqq_wait);
+               break;
+
+       default:
+               bfa_sm_fault(itnim->bfa, event);
+       }
+}
+
+/**
+ *     Waiting for itnim create response from firmware, a delete is pending.
+ */
+static void
+bfa_itnim_sm_delete_pending(struct bfa_itnim_s *itnim,
+                               enum bfa_itnim_event event)
+{
+       bfa_trc(itnim->bfa, itnim->rport->rport_tag);
+       bfa_trc(itnim->bfa, event);
+
+       switch (event) {
+       case BFA_ITNIM_SM_FWRSP:
+               if (bfa_itnim_send_fwdelete(itnim))
+                       bfa_sm_set_state(itnim, bfa_itnim_sm_deleting);
+               else
+                       bfa_sm_set_state(itnim, bfa_itnim_sm_deleting_qfull);
+               break;
+
+       case BFA_ITNIM_SM_HWFAIL:
+               bfa_sm_set_state(itnim, bfa_itnim_sm_uninit);
+               bfa_fcpim_delitn(itnim);
+               break;
+
+       default:
+               bfa_sm_fault(itnim->bfa, event);
+       }
+}
+
+/**
+ *     Online state - normal parking state.
+ */
+static void
+bfa_itnim_sm_online(struct bfa_itnim_s *itnim, enum bfa_itnim_event event)
+{
+       bfa_trc(itnim->bfa, itnim->rport->rport_tag);
+       bfa_trc(itnim->bfa, event);
+
+       switch (event) {
+       case BFA_ITNIM_SM_OFFLINE:
+               bfa_sm_set_state(itnim, bfa_itnim_sm_cleanup_offline);
+               itnim->is_online = BFA_FALSE;
+               bfa_itnim_iotov_start(itnim);
+               bfa_itnim_cleanup(itnim);
+               break;
+
+       case BFA_ITNIM_SM_DELETE:
+               bfa_sm_set_state(itnim, bfa_itnim_sm_cleanup_delete);
+               itnim->is_online = BFA_FALSE;
+               bfa_itnim_cleanup(itnim);
+               break;
+
+       case BFA_ITNIM_SM_SLER:
+               bfa_sm_set_state(itnim, bfa_itnim_sm_sler);
+               itnim->is_online = BFA_FALSE;
+               bfa_itnim_iotov_start(itnim);
+               bfa_itnim_sler_cb(itnim);
+               break;
+
+       case BFA_ITNIM_SM_HWFAIL:
+               bfa_sm_set_state(itnim, bfa_itnim_sm_iocdisable);
+               itnim->is_online = BFA_FALSE;
+               bfa_itnim_iotov_start(itnim);
+               bfa_itnim_iocdisable_cleanup(itnim);
+               break;
+
+       default:
+               bfa_sm_fault(itnim->bfa, event);
+       }
+}
+
+/**
+ *     Second level error recovery need.
+ */
+static void
+bfa_itnim_sm_sler(struct bfa_itnim_s *itnim, enum bfa_itnim_event event)
+{
+       bfa_trc(itnim->bfa, itnim->rport->rport_tag);
+       bfa_trc(itnim->bfa, event);
+
+       switch (event) {
+       case BFA_ITNIM_SM_OFFLINE:
+               bfa_sm_set_state(itnim, bfa_itnim_sm_cleanup_offline);
+               bfa_itnim_cleanup(itnim);
+               break;
+
+       case BFA_ITNIM_SM_DELETE:
+               bfa_sm_set_state(itnim, bfa_itnim_sm_cleanup_delete);
+               bfa_itnim_cleanup(itnim);
+               bfa_itnim_iotov_delete(itnim);
+               break;
+
+       case BFA_ITNIM_SM_HWFAIL:
+               bfa_sm_set_state(itnim, bfa_itnim_sm_iocdisable);
+               bfa_itnim_iocdisable_cleanup(itnim);
+               break;
+
+       default:
+               bfa_sm_fault(itnim->bfa, event);
+       }
+}
+
+/**
+ *     Going offline. Waiting for active IO cleanup.
+ */
+static void
+bfa_itnim_sm_cleanup_offline(struct bfa_itnim_s *itnim,
+                                enum bfa_itnim_event event)
+{
+       bfa_trc(itnim->bfa, itnim->rport->rport_tag);
+       bfa_trc(itnim->bfa, event);
+
+       switch (event) {
+       case BFA_ITNIM_SM_CLEANUP:
+               if (bfa_itnim_send_fwdelete(itnim))
+                       bfa_sm_set_state(itnim, bfa_itnim_sm_fwdelete);
+               else
+                       bfa_sm_set_state(itnim, bfa_itnim_sm_fwdelete_qfull);
+               break;
+
+       case BFA_ITNIM_SM_DELETE:
+               bfa_sm_set_state(itnim, bfa_itnim_sm_cleanup_delete);
+               bfa_itnim_iotov_delete(itnim);
+               break;
+
+       case BFA_ITNIM_SM_HWFAIL:
+               bfa_sm_set_state(itnim, bfa_itnim_sm_iocdisable);
+               bfa_itnim_iocdisable_cleanup(itnim);
+               bfa_itnim_offline_cb(itnim);
+               break;
+
+       case BFA_ITNIM_SM_SLER:
+               break;
+
+       default:
+               bfa_sm_fault(itnim->bfa, event);
+       }
+}
+
+/**
+ *     Deleting itnim. Waiting for active IO cleanup.
+ */
+static void
+bfa_itnim_sm_cleanup_delete(struct bfa_itnim_s *itnim,
+                               enum bfa_itnim_event event)
+{
+       bfa_trc(itnim->bfa, itnim->rport->rport_tag);
+       bfa_trc(itnim->bfa, event);
+
+       switch (event) {
+       case BFA_ITNIM_SM_CLEANUP:
+               if (bfa_itnim_send_fwdelete(itnim))
+                       bfa_sm_set_state(itnim, bfa_itnim_sm_deleting);
+               else
+                       bfa_sm_set_state(itnim, bfa_itnim_sm_deleting_qfull);
+               break;
+
+       case BFA_ITNIM_SM_HWFAIL:
+               bfa_sm_set_state(itnim, bfa_itnim_sm_iocdisable);
+               bfa_itnim_iocdisable_cleanup(itnim);
+               break;
+
+       default:
+               bfa_sm_fault(itnim->bfa, event);
+       }
+}
+
+/**
+ * Rport offline. Fimrware itnim is being deleted - awaiting f/w response.
+ */
+static void
+bfa_itnim_sm_fwdelete(struct bfa_itnim_s *itnim, enum bfa_itnim_event event)
+{
+       bfa_trc(itnim->bfa, itnim->rport->rport_tag);
+       bfa_trc(itnim->bfa, event);
+
+       switch (event) {
+       case BFA_ITNIM_SM_FWRSP:
+               bfa_sm_set_state(itnim, bfa_itnim_sm_offline);
+               bfa_itnim_offline_cb(itnim);
+               break;
+
+       case BFA_ITNIM_SM_DELETE:
+               bfa_sm_set_state(itnim, bfa_itnim_sm_deleting);
+               break;
+
+       case BFA_ITNIM_SM_HWFAIL:
+               bfa_sm_set_state(itnim, bfa_itnim_sm_iocdisable);
+               bfa_itnim_offline_cb(itnim);
+               break;
+
+       default:
+               bfa_sm_fault(itnim->bfa, event);
+       }
+}
+
+static void
+bfa_itnim_sm_fwdelete_qfull(struct bfa_itnim_s *itnim,
+                       enum bfa_itnim_event event)
+{
+       bfa_trc(itnim->bfa, itnim->rport->rport_tag);
+       bfa_trc(itnim->bfa, event);
+
+       switch (event) {
+       case BFA_ITNIM_SM_QRESUME:
+               bfa_sm_set_state(itnim, bfa_itnim_sm_fwdelete);
+               bfa_itnim_send_fwdelete(itnim);
+               break;
+
+       case BFA_ITNIM_SM_DELETE:
+               bfa_sm_set_state(itnim, bfa_itnim_sm_deleting_qfull);
+               break;
+
+       case BFA_ITNIM_SM_HWFAIL:
+               bfa_sm_set_state(itnim, bfa_itnim_sm_iocdisable);
+               bfa_reqq_wcancel(&itnim->reqq_wait);
+               bfa_itnim_offline_cb(itnim);
+               break;
+
+       default:
+               bfa_sm_fault(itnim->bfa, event);
+       }
+}
+
+/**
+ *     Offline state.
+ */
+static void
+bfa_itnim_sm_offline(struct bfa_itnim_s *itnim, enum bfa_itnim_event event)
+{
+       bfa_trc(itnim->bfa, itnim->rport->rport_tag);
+       bfa_trc(itnim->bfa, event);
+
+       switch (event) {
+       case BFA_ITNIM_SM_DELETE:
+               bfa_sm_set_state(itnim, bfa_itnim_sm_uninit);
+               bfa_itnim_iotov_delete(itnim);
+               bfa_fcpim_delitn(itnim);
+               break;
+
+       case BFA_ITNIM_SM_ONLINE:
+               if (bfa_itnim_send_fwcreate(itnim))
+                       bfa_sm_set_state(itnim, bfa_itnim_sm_fwcreate);
+               else
+                       bfa_sm_set_state(itnim, bfa_itnim_sm_fwcreate_qfull);
+               break;
+
+       case BFA_ITNIM_SM_HWFAIL:
+               bfa_sm_set_state(itnim, bfa_itnim_sm_iocdisable);
+               break;
+
+       default:
+               bfa_sm_fault(itnim->bfa, event);
+       }
+}
+
+/**
+ *     IOC h/w failed state.
+ */
+static void
+bfa_itnim_sm_iocdisable(struct bfa_itnim_s *itnim,
+                               enum bfa_itnim_event event)
+{
+       bfa_trc(itnim->bfa, itnim->rport->rport_tag);
+       bfa_trc(itnim->bfa, event);
+
+       switch (event) {
+       case BFA_ITNIM_SM_DELETE:
+               bfa_sm_set_state(itnim, bfa_itnim_sm_uninit);
+               bfa_itnim_iotov_delete(itnim);
+               bfa_fcpim_delitn(itnim);
+               break;
+
+       case BFA_ITNIM_SM_OFFLINE:
+               bfa_itnim_offline_cb(itnim);
+               break;
+
+       case BFA_ITNIM_SM_ONLINE:
+               if (bfa_itnim_send_fwcreate(itnim))
+                       bfa_sm_set_state(itnim, bfa_itnim_sm_fwcreate);
+               else
+                       bfa_sm_set_state(itnim, bfa_itnim_sm_fwcreate_qfull);
+               break;
+
+       case BFA_ITNIM_SM_HWFAIL:
+               break;
+
+       default:
+               bfa_sm_fault(itnim->bfa, event);
+       }
+}
+
+/**
+ *     Itnim is deleted, waiting for firmware response to delete.
+ */
+static void
+bfa_itnim_sm_deleting(struct bfa_itnim_s *itnim, enum bfa_itnim_event event)
+{
+       bfa_trc(itnim->bfa, itnim->rport->rport_tag);
+       bfa_trc(itnim->bfa, event);
+
+       switch (event) {
+       case BFA_ITNIM_SM_FWRSP:
+       case BFA_ITNIM_SM_HWFAIL:
+               bfa_sm_set_state(itnim, bfa_itnim_sm_uninit);
+               bfa_fcpim_delitn(itnim);
+               break;
+
+       default:
+               bfa_sm_fault(itnim->bfa, event);
+       }
+}
+
+static void
+bfa_itnim_sm_deleting_qfull(struct bfa_itnim_s *itnim,
+               enum bfa_itnim_event event)
+{
+       bfa_trc(itnim->bfa, itnim->rport->rport_tag);
+       bfa_trc(itnim->bfa, event);
+
+       switch (event) {
+       case BFA_ITNIM_SM_QRESUME:
+               bfa_sm_set_state(itnim, bfa_itnim_sm_deleting);
+               bfa_itnim_send_fwdelete(itnim);
+               break;
+
+       case BFA_ITNIM_SM_HWFAIL:
+               bfa_sm_set_state(itnim, bfa_itnim_sm_uninit);
+               bfa_reqq_wcancel(&itnim->reqq_wait);
+               bfa_fcpim_delitn(itnim);
+               break;
+
+       default:
+               bfa_sm_fault(itnim->bfa, event);
+       }
+}
+
+/**
+ *     Initiate cleanup of all IOs on an IOC failure.
+ */
+static void
+bfa_itnim_iocdisable_cleanup(struct bfa_itnim_s *itnim)
+{
+       struct bfa_tskim_s *tskim;
+       struct bfa_ioim_s *ioim;
+       struct list_head        *qe, *qen;
+
+       list_for_each_safe(qe, qen, &itnim->tsk_q) {
+               tskim = (struct bfa_tskim_s *) qe;
+               bfa_tskim_iocdisable(tskim);
+       }
+
+       list_for_each_safe(qe, qen, &itnim->io_q) {
+               ioim = (struct bfa_ioim_s *) qe;
+               bfa_ioim_iocdisable(ioim);
+       }
+
+       /**
+        * For IO request in pending queue, we pretend an early timeout.
+        */
+       list_for_each_safe(qe, qen, &itnim->pending_q) {
+               ioim = (struct bfa_ioim_s *) qe;
+               bfa_ioim_tov(ioim);
+       }
+
+       list_for_each_safe(qe, qen, &itnim->io_cleanup_q) {
+               ioim = (struct bfa_ioim_s *) qe;
+               bfa_ioim_iocdisable(ioim);
+       }
+}
+
+/**
+ *     IO cleanup completion
+ */
+static void
+bfa_itnim_cleanp_comp(void *itnim_cbarg)
+{
+       struct bfa_itnim_s *itnim = itnim_cbarg;
+
+       bfa_stats(itnim, cleanup_comps);
+       bfa_sm_send_event(itnim, BFA_ITNIM_SM_CLEANUP);
+}
+
+/**
+ *     Initiate cleanup of all IOs.
+ */
+static void
+bfa_itnim_cleanup(struct bfa_itnim_s *itnim)
+{
+       struct bfa_ioim_s  *ioim;
+       struct bfa_tskim_s *tskim;
+       struct list_head        *qe, *qen;
+
+       bfa_wc_init(&itnim->wc, bfa_itnim_cleanp_comp, itnim);
+
+       list_for_each_safe(qe, qen, &itnim->io_q) {
+               ioim = (struct bfa_ioim_s *) qe;
+
+               /**
+                * Move IO to a cleanup queue from active queue so that a later
+                * TM will not pickup this IO.
+                */
+               list_del(&ioim->qe);
+               list_add_tail(&ioim->qe, &itnim->io_cleanup_q);
+
+               bfa_wc_up(&itnim->wc);
+               bfa_ioim_cleanup(ioim);
+       }
+
+       list_for_each_safe(qe, qen, &itnim->tsk_q) {
+               tskim = (struct bfa_tskim_s *) qe;
+               bfa_wc_up(&itnim->wc);
+               bfa_tskim_cleanup(tskim);
+       }
+
+       bfa_wc_wait(&itnim->wc);
+}
+
+static void
+__bfa_cb_itnim_online(void *cbarg, bfa_boolean_t complete)
+{
+       struct bfa_itnim_s *itnim = cbarg;
+
+       if (complete)
+               bfa_cb_itnim_online(itnim->ditn);
+}
+
+static void
+__bfa_cb_itnim_offline(void *cbarg, bfa_boolean_t complete)
+{
+       struct bfa_itnim_s *itnim = cbarg;
+
+       if (complete)
+               bfa_cb_itnim_offline(itnim->ditn);
+}
+
+static void
+__bfa_cb_itnim_sler(void *cbarg, bfa_boolean_t complete)
+{
+       struct bfa_itnim_s *itnim = cbarg;
+
+       if (complete)
+               bfa_cb_itnim_sler(itnim->ditn);
+}
+
+/**
+ * Call to resume any I/O requests waiting for room in request queue.
+ */
+static void
+bfa_itnim_qresume(void *cbarg)
+{
+       struct bfa_itnim_s *itnim = cbarg;
+
+       bfa_sm_send_event(itnim, BFA_ITNIM_SM_QRESUME);
+}
+
+
+
+
+/**
+ *  bfa_itnim_public
+ */
+
+void
+bfa_itnim_iodone(struct bfa_itnim_s *itnim)
+{
+       bfa_wc_down(&itnim->wc);
+}
+
+void
+bfa_itnim_tskdone(struct bfa_itnim_s *itnim)
+{
+       bfa_wc_down(&itnim->wc);
+}
+
+void
+bfa_itnim_meminfo(struct bfa_iocfc_cfg_s *cfg, u32 *km_len,
+               u32 *dm_len)
+{
+       /**
+        * ITN memory
+        */
+       *km_len += cfg->fwcfg.num_rports * sizeof(struct bfa_itnim_s);
+}
+
+void
+bfa_itnim_attach(struct bfa_fcpim_mod_s *fcpim, struct bfa_meminfo_s *minfo)
+{
+       struct bfa_s    *bfa = fcpim->bfa;
+       struct bfa_itnim_s *itnim;
+       int     i, j;
+
+       INIT_LIST_HEAD(&fcpim->itnim_q);
+
+       itnim = (struct bfa_itnim_s *) bfa_meminfo_kva(minfo);
+       fcpim->itnim_arr = itnim;
+
+       for (i = 0; i < fcpim->num_itnims; i++, itnim++) {
+               bfa_os_memset(itnim, 0, sizeof(struct bfa_itnim_s));
+               itnim->bfa = bfa;
+               itnim->fcpim = fcpim;
+               itnim->reqq = BFA_REQQ_QOS_LO;
+               itnim->rport = BFA_RPORT_FROM_TAG(bfa, i);
+               itnim->iotov_active = BFA_FALSE;
+               bfa_reqq_winit(&itnim->reqq_wait, bfa_itnim_qresume, itnim);
+
+               INIT_LIST_HEAD(&itnim->io_q);
+               INIT_LIST_HEAD(&itnim->io_cleanup_q);
+               INIT_LIST_HEAD(&itnim->pending_q);
+               INIT_LIST_HEAD(&itnim->tsk_q);
+               INIT_LIST_HEAD(&itnim->delay_comp_q);
+               for (j = 0; j < BFA_IOBUCKET_MAX; j++)
+                       itnim->ioprofile.io_latency.min[j] = ~0;
+               bfa_sm_set_state(itnim, bfa_itnim_sm_uninit);
+       }
+
+       bfa_meminfo_kva(minfo) = (u8 *) itnim;
+}
+
+void
+bfa_itnim_iocdisable(struct bfa_itnim_s *itnim)
+{
+       bfa_stats(itnim, ioc_disabled);
+       bfa_sm_send_event(itnim, BFA_ITNIM_SM_HWFAIL);
+}
+
+static bfa_boolean_t
+bfa_itnim_send_fwcreate(struct bfa_itnim_s *itnim)
+{
+       struct bfi_itnim_create_req_s *m;
+
+       itnim->msg_no++;
+
+       /**
+        * check for room in queue to send request now
+        */
+       m = bfa_reqq_next(itnim->bfa, itnim->reqq);
+       if (!m) {
+               bfa_reqq_wait(itnim->bfa, itnim->reqq, &itnim->reqq_wait);
+               return BFA_FALSE;
+       }
+
+       bfi_h2i_set(m->mh, BFI_MC_ITNIM, BFI_ITNIM_H2I_CREATE_REQ,
+                       bfa_lpuid(itnim->bfa));
+       m->fw_handle = itnim->rport->fw_handle;
+       m->class = FC_CLASS_3;
+       m->seq_rec = itnim->seq_rec;
+       m->msg_no = itnim->msg_no;
+       bfa_stats(itnim, fw_create);
+
+       /**
+        * queue I/O message to firmware
+        */
+       bfa_reqq_produce(itnim->bfa, itnim->reqq);
+       return BFA_TRUE;
+}
+
+static bfa_boolean_t
+bfa_itnim_send_fwdelete(struct bfa_itnim_s *itnim)
+{
+       struct bfi_itnim_delete_req_s *m;
+
+       /**
+        * check for room in queue to send request now
+        */
+       m = bfa_reqq_next(itnim->bfa, itnim->reqq);
+       if (!m) {
+               bfa_reqq_wait(itnim->bfa, itnim->reqq, &itnim->reqq_wait);
+               return BFA_FALSE;
+       }
+
+       bfi_h2i_set(m->mh, BFI_MC_ITNIM, BFI_ITNIM_H2I_DELETE_REQ,
+                       bfa_lpuid(itnim->bfa));
+       m->fw_handle = itnim->rport->fw_handle;
+       bfa_stats(itnim, fw_delete);
+
+       /**
+        * queue I/O message to firmware
+        */
+       bfa_reqq_produce(itnim->bfa, itnim->reqq);
+       return BFA_TRUE;
+}
+
+/**
+ * Cleanup all pending failed inflight requests.
+ */
+static void
+bfa_itnim_delayed_comp(struct bfa_itnim_s *itnim, bfa_boolean_t iotov)
+{
+       struct bfa_ioim_s *ioim;
+       struct list_head *qe, *qen;
+
+       list_for_each_safe(qe, qen, &itnim->delay_comp_q) {
+               ioim = (struct bfa_ioim_s *)qe;
+               bfa_ioim_delayed_comp(ioim, iotov);
+       }
+}
+
+/**
+ * Start all pending IO requests.
+ */
+static void
+bfa_itnim_iotov_online(struct bfa_itnim_s *itnim)
+{
+       struct bfa_ioim_s *ioim;
+
+       bfa_itnim_iotov_stop(itnim);
+
+       /**
+        * Abort all inflight IO requests in the queue
+        */
+       bfa_itnim_delayed_comp(itnim, BFA_FALSE);
+
+       /**
+        * Start all pending IO requests.
+        */
+       while (!list_empty(&itnim->pending_q)) {
+               bfa_q_deq(&itnim->pending_q, &ioim);
+               list_add_tail(&ioim->qe, &itnim->io_q);
+               bfa_ioim_start(ioim);
+       }
+}
+
+/**
+ * Fail all pending IO requests
+ */
+static void
+bfa_itnim_iotov_cleanup(struct bfa_itnim_s *itnim)
+{
+       struct bfa_ioim_s *ioim;
+
+       /**
+        * Fail all inflight IO requests in the queue
+        */
+       bfa_itnim_delayed_comp(itnim, BFA_TRUE);
+
+       /**
+        * Fail any pending IO requests.
+        */
+       while (!list_empty(&itnim->pending_q)) {
+               bfa_q_deq(&itnim->pending_q, &ioim);
+               list_add_tail(&ioim->qe, &ioim->fcpim->ioim_comp_q);
+               bfa_ioim_tov(ioim);
+       }
+}
+
+/**
+ * IO TOV timer callback. Fail any pending IO requests.
+ */
+static void
+bfa_itnim_iotov(void *itnim_arg)
+{
+       struct bfa_itnim_s *itnim = itnim_arg;
+
+       itnim->iotov_active = BFA_FALSE;
+
+       bfa_cb_itnim_tov_begin(itnim->ditn);
+       bfa_itnim_iotov_cleanup(itnim);
+       bfa_cb_itnim_tov(itnim->ditn);
+}
+
+/**
+ * Start IO TOV timer for failing back pending IO requests in offline state.
+ */
+static void
+bfa_itnim_iotov_start(struct bfa_itnim_s *itnim)
+{
+       if (itnim->fcpim->path_tov > 0) {
+
+               itnim->iotov_active = BFA_TRUE;
+               bfa_assert(bfa_itnim_hold_io(itnim));
+               bfa_timer_start(itnim->bfa, &itnim->timer,
+                       bfa_itnim_iotov, itnim, itnim->fcpim->path_tov);
+       }
+}
+
+/**
+ * Stop IO TOV timer.
+ */
+static void
+bfa_itnim_iotov_stop(struct bfa_itnim_s *itnim)
+{
+       if (itnim->iotov_active) {
+               itnim->iotov_active = BFA_FALSE;
+               bfa_timer_stop(&itnim->timer);
+       }
+}
+
+/**
+ * Stop IO TOV timer.
+ */
+static void
+bfa_itnim_iotov_delete(struct bfa_itnim_s *itnim)
+{
+       bfa_boolean_t pathtov_active = BFA_FALSE;
+
+       if (itnim->iotov_active)
+               pathtov_active = BFA_TRUE;
+
+       bfa_itnim_iotov_stop(itnim);
+       if (pathtov_active)
+               bfa_cb_itnim_tov_begin(itnim->ditn);
+       bfa_itnim_iotov_cleanup(itnim);
+       if (pathtov_active)
+               bfa_cb_itnim_tov(itnim->ditn);
+}
+
+static void
+bfa_itnim_update_del_itn_stats(struct bfa_itnim_s *itnim)
+{
+       struct bfa_fcpim_mod_s *fcpim = BFA_FCPIM_MOD(itnim->bfa);
+       fcpim->del_itn_stats.del_itn_iocomp_aborted +=
+               itnim->stats.iocomp_aborted;
+       fcpim->del_itn_stats.del_itn_iocomp_timedout +=
+               itnim->stats.iocomp_timedout;
+       fcpim->del_itn_stats.del_itn_iocom_sqer_needed +=
+               itnim->stats.iocom_sqer_needed;
+       fcpim->del_itn_stats.del_itn_iocom_res_free +=
+               itnim->stats.iocom_res_free;
+       fcpim->del_itn_stats.del_itn_iocom_hostabrts +=
+               itnim->stats.iocom_hostabrts;
+       fcpim->del_itn_stats.del_itn_total_ios += itnim->stats.total_ios;
+       fcpim->del_itn_stats.del_io_iocdowns += itnim->stats.io_iocdowns;
+       fcpim->del_itn_stats.del_tm_iocdowns += itnim->stats.tm_iocdowns;
+}
+
+
+
+/**
+ *  bfa_itnim_public
+ */
+
+/**
+ *     Itnim interrupt processing.
+ */
+void
+bfa_itnim_isr(struct bfa_s *bfa, struct bfi_msg_s *m)
+{
+       struct bfa_fcpim_mod_s *fcpim = BFA_FCPIM_MOD(bfa);
+       union bfi_itnim_i2h_msg_u msg;
+       struct bfa_itnim_s *itnim;
+
+       bfa_trc(bfa, m->mhdr.msg_id);
+
+       msg.msg = m;
+
+       switch (m->mhdr.msg_id) {
+       case BFI_ITNIM_I2H_CREATE_RSP:
+               itnim = BFA_ITNIM_FROM_TAG(fcpim,
+                                               msg.create_rsp->bfa_handle);
+               bfa_assert(msg.create_rsp->status == BFA_STATUS_OK);
+               bfa_stats(itnim, create_comps);
+               bfa_sm_send_event(itnim, BFA_ITNIM_SM_FWRSP);
+               break;
+
+       case BFI_ITNIM_I2H_DELETE_RSP:
+               itnim = BFA_ITNIM_FROM_TAG(fcpim,
+                                               msg.delete_rsp->bfa_handle);
+               bfa_assert(msg.delete_rsp->status == BFA_STATUS_OK);
+               bfa_stats(itnim, delete_comps);
+               bfa_sm_send_event(itnim, BFA_ITNIM_SM_FWRSP);
+               break;
+
+       case BFI_ITNIM_I2H_SLER_EVENT:
+               itnim = BFA_ITNIM_FROM_TAG(fcpim,
+                                               msg.sler_event->bfa_handle);
+               bfa_stats(itnim, sler_events);
+               bfa_sm_send_event(itnim, BFA_ITNIM_SM_SLER);
+               break;
+
+       default:
+               bfa_trc(bfa, m->mhdr.msg_id);
+               bfa_assert(0);
+       }
+}
+
+
+
+/**
+ *  bfa_itnim_api
+ */
+
+struct bfa_itnim_s *
+bfa_itnim_create(struct bfa_s *bfa, struct bfa_rport_s *rport, void *ditn)
+{
+       struct bfa_fcpim_mod_s *fcpim = BFA_FCPIM_MOD(bfa);
+       struct bfa_itnim_s *itnim;
+
+       itnim = BFA_ITNIM_FROM_TAG(fcpim, rport->rport_tag);
+       bfa_assert(itnim->rport == rport);
+
+       itnim->ditn = ditn;
+
+       bfa_stats(itnim, creates);
+       bfa_sm_send_event(itnim, BFA_ITNIM_SM_CREATE);
+
+       return itnim;
+}
+
+void
+bfa_itnim_delete(struct bfa_itnim_s *itnim)
+{
+       bfa_stats(itnim, deletes);
+       bfa_sm_send_event(itnim, BFA_ITNIM_SM_DELETE);
+}
+
+void
+bfa_itnim_online(struct bfa_itnim_s *itnim, bfa_boolean_t seq_rec)
+{
+       itnim->seq_rec = seq_rec;
+       bfa_stats(itnim, onlines);
+       bfa_sm_send_event(itnim, BFA_ITNIM_SM_ONLINE);
+}
+
+void
+bfa_itnim_offline(struct bfa_itnim_s *itnim)
+{
+       bfa_stats(itnim, offlines);
+       bfa_sm_send_event(itnim, BFA_ITNIM_SM_OFFLINE);
+}
+
+/**
+ * Return true if itnim is considered offline for holding off IO request.
+ * IO is not held if itnim is being deleted.
+ */
+bfa_boolean_t
+bfa_itnim_hold_io(struct bfa_itnim_s *itnim)
+{
+       return itnim->fcpim->path_tov && itnim->iotov_active &&
+               (bfa_sm_cmp_state(itnim, bfa_itnim_sm_fwcreate) ||
+                bfa_sm_cmp_state(itnim, bfa_itnim_sm_sler) ||
+                bfa_sm_cmp_state(itnim, bfa_itnim_sm_cleanup_offline) ||
+                bfa_sm_cmp_state(itnim, bfa_itnim_sm_fwdelete) ||
+                bfa_sm_cmp_state(itnim, bfa_itnim_sm_offline) ||
+                bfa_sm_cmp_state(itnim, bfa_itnim_sm_iocdisable));
+}
+
+bfa_status_t
+bfa_itnim_get_ioprofile(struct bfa_itnim_s *itnim,
+               struct bfa_itnim_ioprofile_s *ioprofile)
+{
+       struct bfa_fcpim_mod_s *fcpim = BFA_FCPIM_MOD(itnim->bfa);
+       if (!fcpim->io_profile)
+               return BFA_STATUS_IOPROFILE_OFF;
+
+       itnim->ioprofile.index = BFA_IOBUCKET_MAX;
+       itnim->ioprofile.io_profile_start_time =
+               bfa_io_profile_start_time(itnim->bfa);
+       itnim->ioprofile.clock_res_mul = bfa_io_lat_clock_res_mul;
+       itnim->ioprofile.clock_res_div = bfa_io_lat_clock_res_div;
+       *ioprofile = itnim->ioprofile;
+
+       return BFA_STATUS_OK;
+}
+
+void
+bfa_itnim_get_stats(struct bfa_itnim_s *itnim,
+       struct bfa_itnim_iostats_s *stats)
+{
+       *stats = itnim->stats;
+}
+
+void
+bfa_itnim_clear_stats(struct bfa_itnim_s *itnim)
+{
+       int j;
+       bfa_os_memset(&itnim->stats, 0, sizeof(itnim->stats));
+       bfa_os_memset(&itnim->ioprofile, 0, sizeof(itnim->ioprofile));
+       for (j = 0; j < BFA_IOBUCKET_MAX; j++)
+               itnim->ioprofile.io_latency.min[j] = ~0;
+}
+
+/**
+ *  BFA IO module state machine functions
+ */
+
+/**
+ *     IO is not started (unallocated).
+ */
+static void
+bfa_ioim_sm_uninit(struct bfa_ioim_s *ioim, enum bfa_ioim_event event)
+{
+       bfa_trc_fp(ioim->bfa, ioim->iotag);
+       bfa_trc_fp(ioim->bfa, event);
+
+       switch (event) {
+       case BFA_IOIM_SM_START:
+               if (!bfa_itnim_is_online(ioim->itnim)) {
+                       if (!bfa_itnim_hold_io(ioim->itnim)) {
+                               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
+                               list_del(&ioim->qe);
+                               list_add_tail(&ioim->qe,
+                                       &ioim->fcpim->ioim_comp_q);
+                               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe,
+                                               __bfa_cb_ioim_pathtov, ioim);
+                       } else {
+                               list_del(&ioim->qe);
+                               list_add_tail(&ioim->qe,
+                                       &ioim->itnim->pending_q);
+                       }
+                       break;
+               }
+
+               if (ioim->nsges > BFI_SGE_INLINE) {
+                       if (!bfa_ioim_sge_setup(ioim)) {
+                               bfa_sm_set_state(ioim, bfa_ioim_sm_sgalloc);
+                               return;
+                       }
+               }
+
+               if (!bfa_ioim_send_ioreq(ioim)) {
+                       bfa_sm_set_state(ioim, bfa_ioim_sm_qfull);
+                       break;
+               }
+
+               bfa_sm_set_state(ioim, bfa_ioim_sm_active);
+               break;
+
+       case BFA_IOIM_SM_IOTOV:
+               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
+               bfa_ioim_move_to_comp_q(ioim);
+               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe,
+                               __bfa_cb_ioim_pathtov, ioim);
+               break;
+
+       case BFA_IOIM_SM_ABORT:
+               /**
+                * IO in pending queue can get abort requests. Complete abort
+                * requests immediately.
+                */
+               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
+               bfa_assert(bfa_q_is_on_q(&ioim->itnim->pending_q, ioim));
+               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe,
+                               __bfa_cb_ioim_abort, ioim);
+               break;
+
+       default:
+               bfa_sm_fault(ioim->bfa, event);
+       }
+}
+
+/**
+ *     IO is waiting for SG pages.
+ */
+static void
+bfa_ioim_sm_sgalloc(struct bfa_ioim_s *ioim, enum bfa_ioim_event event)
+{
+       bfa_trc(ioim->bfa, ioim->iotag);
+       bfa_trc(ioim->bfa, event);
+
+       switch (event) {
+       case BFA_IOIM_SM_SGALLOCED:
+               if (!bfa_ioim_send_ioreq(ioim)) {
+                       bfa_sm_set_state(ioim, bfa_ioim_sm_qfull);
+                       break;
+               }
+               bfa_sm_set_state(ioim, bfa_ioim_sm_active);
+               break;
+
+       case BFA_IOIM_SM_CLEANUP:
+               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
+               bfa_sgpg_wcancel(ioim->bfa, &ioim->iosp->sgpg_wqe);
+               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_failed,
+                             ioim);
+               bfa_ioim_notify_cleanup(ioim);
+               break;
+
+       case BFA_IOIM_SM_ABORT:
+               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
+               bfa_sgpg_wcancel(ioim->bfa, &ioim->iosp->sgpg_wqe);
+               bfa_ioim_move_to_comp_q(ioim);
+               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_abort,
+                             ioim);
+               break;
+
+       case BFA_IOIM_SM_HWFAIL:
+               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
+               bfa_sgpg_wcancel(ioim->bfa, &ioim->iosp->sgpg_wqe);
+               bfa_ioim_move_to_comp_q(ioim);
+               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_failed,
+                             ioim);
+               break;
+
+       default:
+               bfa_sm_fault(ioim->bfa, event);
+       }
+}
+
+/**
+ *     IO is active.
+ */
+static void
+bfa_ioim_sm_active(struct bfa_ioim_s *ioim, enum bfa_ioim_event event)
+{
+       bfa_trc_fp(ioim->bfa, ioim->iotag);
+       bfa_trc_fp(ioim->bfa, event);
+
+       switch (event) {
+       case BFA_IOIM_SM_COMP_GOOD:
+               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
+               bfa_ioim_move_to_comp_q(ioim);
+               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe,
+                             __bfa_cb_ioim_good_comp, ioim);
+               break;
+
+       case BFA_IOIM_SM_COMP:
+               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
+               bfa_ioim_move_to_comp_q(ioim);
+               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_comp,
+                             ioim);
+               break;
+
+       case BFA_IOIM_SM_DONE:
+               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb_free);
+               bfa_ioim_move_to_comp_q(ioim);
+               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_comp,
+                             ioim);
+               break;
+
+       case BFA_IOIM_SM_ABORT:
+               ioim->iosp->abort_explicit = BFA_TRUE;
+               ioim->io_cbfn = __bfa_cb_ioim_abort;
+
+               if (bfa_ioim_send_abort(ioim))
+                       bfa_sm_set_state(ioim, bfa_ioim_sm_abort);
+               else {
+                       bfa_sm_set_state(ioim, bfa_ioim_sm_abort_qfull);
+                       bfa_stats(ioim->itnim, qwait);
+                       bfa_reqq_wait(ioim->bfa, ioim->reqq,
+                                         &ioim->iosp->reqq_wait);
+               }
+               break;
+
+       case BFA_IOIM_SM_CLEANUP:
+               ioim->iosp->abort_explicit = BFA_FALSE;
+               ioim->io_cbfn = __bfa_cb_ioim_failed;
+
+               if (bfa_ioim_send_abort(ioim))
+                       bfa_sm_set_state(ioim, bfa_ioim_sm_cleanup);
+               else {
+                       bfa_sm_set_state(ioim, bfa_ioim_sm_cleanup_qfull);
+                       bfa_stats(ioim->itnim, qwait);
+                       bfa_reqq_wait(ioim->bfa, ioim->reqq,
+                                         &ioim->iosp->reqq_wait);
+               }
+               break;
+
+       case BFA_IOIM_SM_HWFAIL:
+               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
+               bfa_ioim_move_to_comp_q(ioim);
+               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_failed,
+                             ioim);
+               break;
+
+       case BFA_IOIM_SM_SQRETRY:
+               if (bfa_ioim_get_iotag(ioim) != BFA_TRUE) {
+                       /* max retry completed free IO */
+                       bfa_sm_set_state(ioim, bfa_ioim_sm_hcb_free);
+                       bfa_ioim_move_to_comp_q(ioim);
+                       bfa_cb_queue(ioim->bfa, &ioim->hcb_qe,
+                                       __bfa_cb_ioim_failed, ioim);
+                       break;
+               }
+               /* waiting for IO tag resource free */
+               bfa_sm_set_state(ioim, bfa_ioim_sm_cmnd_retry);
+               break;
+
+       default:
+               bfa_sm_fault(ioim->bfa, event);
+       }
+}
+
+/**
+*      IO is retried with new tag.
+*/
+static void
+bfa_ioim_sm_cmnd_retry(struct bfa_ioim_s *ioim, enum bfa_ioim_event event)
+{
+       bfa_trc_fp(ioim->bfa, ioim->iotag);
+       bfa_trc_fp(ioim->bfa, event);
+
+       switch (event) {
+       case BFA_IOIM_SM_FREE:
+               /* abts and rrq done. Now retry the IO with new tag */
+               if (!bfa_ioim_send_ioreq(ioim)) {
+                       bfa_sm_set_state(ioim, bfa_ioim_sm_qfull);
+                       break;
+               }
+               bfa_sm_set_state(ioim, bfa_ioim_sm_active);
+       break;
+
+       case BFA_IOIM_SM_CLEANUP:
+               ioim->iosp->abort_explicit = BFA_FALSE;
+               ioim->io_cbfn = __bfa_cb_ioim_failed;
+
+               if (bfa_ioim_send_abort(ioim))
+                       bfa_sm_set_state(ioim, bfa_ioim_sm_cleanup);
+               else {
+                       bfa_sm_set_state(ioim, bfa_ioim_sm_cleanup_qfull);
+                       bfa_stats(ioim->itnim, qwait);
+                       bfa_reqq_wait(ioim->bfa, ioim->reqq,
+                                         &ioim->iosp->reqq_wait);
+               }
+       break;
+
+       case BFA_IOIM_SM_HWFAIL:
+               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
+               bfa_ioim_move_to_comp_q(ioim);
+               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe,
+                        __bfa_cb_ioim_failed, ioim);
+               break;
+
+       case BFA_IOIM_SM_ABORT:
+               /** in this state IO abort is done.
+                * Waiting for IO tag resource free.
+                */
+               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb_free);
+               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_abort,
+                             ioim);
+               break;
+
+       default:
+               bfa_sm_fault(ioim->bfa, event);
+       }
+}
+
+/**
+ *     IO is being aborted, waiting for completion from firmware.
+ */
+static void
+bfa_ioim_sm_abort(struct bfa_ioim_s *ioim, enum bfa_ioim_event event)
+{
+       bfa_trc(ioim->bfa, ioim->iotag);
+       bfa_trc(ioim->bfa, event);
+
+       switch (event) {
+       case BFA_IOIM_SM_COMP_GOOD:
+       case BFA_IOIM_SM_COMP:
+       case BFA_IOIM_SM_DONE:
+       case BFA_IOIM_SM_FREE:
+               break;
+
+       case BFA_IOIM_SM_ABORT_DONE:
+               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb_free);
+               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_abort,
+                             ioim);
+               break;
+
+       case BFA_IOIM_SM_ABORT_COMP:
+               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
+               bfa_ioim_move_to_comp_q(ioim);
+               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_abort,
+                             ioim);
+               break;
+
+       case BFA_IOIM_SM_COMP_UTAG:
+               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
+               bfa_ioim_move_to_comp_q(ioim);
+               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_abort,
+                             ioim);
+               break;
+
+       case BFA_IOIM_SM_CLEANUP:
+               bfa_assert(ioim->iosp->abort_explicit == BFA_TRUE);
+               ioim->iosp->abort_explicit = BFA_FALSE;
+
+               if (bfa_ioim_send_abort(ioim))
+                       bfa_sm_set_state(ioim, bfa_ioim_sm_cleanup);
+               else {
+                       bfa_sm_set_state(ioim, bfa_ioim_sm_cleanup_qfull);
+                       bfa_stats(ioim->itnim, qwait);
+                       bfa_reqq_wait(ioim->bfa, ioim->reqq,
+                                         &ioim->iosp->reqq_wait);
+               }
+               break;
+
+       case BFA_IOIM_SM_HWFAIL:
+               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
+               bfa_ioim_move_to_comp_q(ioim);
+               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_failed,
+                             ioim);
+               break;
+
+       default:
+               bfa_sm_fault(ioim->bfa, event);
+       }
+}
+
+/**
+ * IO is being cleaned up (implicit abort), waiting for completion from
+ * firmware.
+ */
+static void
+bfa_ioim_sm_cleanup(struct bfa_ioim_s *ioim, enum bfa_ioim_event event)
+{
+       bfa_trc(ioim->bfa, ioim->iotag);
+       bfa_trc(ioim->bfa, event);
+
+       switch (event) {
+       case BFA_IOIM_SM_COMP_GOOD:
+       case BFA_IOIM_SM_COMP:
+       case BFA_IOIM_SM_DONE:
+       case BFA_IOIM_SM_FREE:
+               break;
+
+       case BFA_IOIM_SM_ABORT:
+               /**
+                * IO is already being aborted implicitly
+                */
+               ioim->io_cbfn = __bfa_cb_ioim_abort;
+               break;
+
+       case BFA_IOIM_SM_ABORT_DONE:
+               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb_free);
+               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, ioim->io_cbfn, ioim);
+               bfa_ioim_notify_cleanup(ioim);
+               break;
+
+       case BFA_IOIM_SM_ABORT_COMP:
+               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
+               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, ioim->io_cbfn, ioim);
+               bfa_ioim_notify_cleanup(ioim);
+               break;
+
+       case BFA_IOIM_SM_COMP_UTAG:
+               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
+               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, ioim->io_cbfn, ioim);
+               bfa_ioim_notify_cleanup(ioim);
+               break;
+
+       case BFA_IOIM_SM_HWFAIL:
+               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
+               bfa_ioim_move_to_comp_q(ioim);
+               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_failed,
+                             ioim);
+               break;
+
+       case BFA_IOIM_SM_CLEANUP:
+               /**
+                * IO can be in cleanup state already due to TM command.
+                * 2nd cleanup request comes from ITN offline event.
+                */
+               break;
+
+       default:
+               bfa_sm_fault(ioim->bfa, event);
+       }
+}
+
+/**
+ *     IO is waiting for room in request CQ
+ */
+static void
+bfa_ioim_sm_qfull(struct bfa_ioim_s *ioim, enum bfa_ioim_event event)
+{
+       bfa_trc(ioim->bfa, ioim->iotag);
+       bfa_trc(ioim->bfa, event);
+
+       switch (event) {
+       case BFA_IOIM_SM_QRESUME:
+               bfa_sm_set_state(ioim, bfa_ioim_sm_active);
+               bfa_ioim_send_ioreq(ioim);
+               break;
+
+       case BFA_IOIM_SM_ABORT:
+               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
+               bfa_reqq_wcancel(&ioim->iosp->reqq_wait);
+               bfa_ioim_move_to_comp_q(ioim);
+               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_abort,
+                             ioim);
+               break;
+
+       case BFA_IOIM_SM_CLEANUP:
+               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
+               bfa_reqq_wcancel(&ioim->iosp->reqq_wait);
+               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_failed,
+                             ioim);
+               bfa_ioim_notify_cleanup(ioim);
+               break;
+
+       case BFA_IOIM_SM_HWFAIL:
+               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
+               bfa_reqq_wcancel(&ioim->iosp->reqq_wait);
+               bfa_ioim_move_to_comp_q(ioim);
+               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_failed,
+                             ioim);
+               break;
+
+       default:
+               bfa_sm_fault(ioim->bfa, event);
+       }
+}
+
+/**
+ *     Active IO is being aborted, waiting for room in request CQ.
+ */
+static void
+bfa_ioim_sm_abort_qfull(struct bfa_ioim_s *ioim, enum bfa_ioim_event event)
+{
+       bfa_trc(ioim->bfa, ioim->iotag);
+       bfa_trc(ioim->bfa, event);
+
+       switch (event) {
+       case BFA_IOIM_SM_QRESUME:
+               bfa_sm_set_state(ioim, bfa_ioim_sm_abort);
+               bfa_ioim_send_abort(ioim);
+               break;
+
+       case BFA_IOIM_SM_CLEANUP:
+               bfa_assert(ioim->iosp->abort_explicit == BFA_TRUE);
+               ioim->iosp->abort_explicit = BFA_FALSE;
+               bfa_sm_set_state(ioim, bfa_ioim_sm_cleanup_qfull);
+               break;
+
+       case BFA_IOIM_SM_COMP_GOOD:
+       case BFA_IOIM_SM_COMP:
+               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
+               bfa_reqq_wcancel(&ioim->iosp->reqq_wait);
+               bfa_ioim_move_to_comp_q(ioim);
+               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_abort,
+                             ioim);
+               break;
+
+       case BFA_IOIM_SM_DONE:
+               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb_free);
+               bfa_reqq_wcancel(&ioim->iosp->reqq_wait);
+               bfa_ioim_move_to_comp_q(ioim);
+               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_abort,
+                             ioim);
+               break;
+
+       case BFA_IOIM_SM_HWFAIL:
+               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
+               bfa_reqq_wcancel(&ioim->iosp->reqq_wait);
+               bfa_ioim_move_to_comp_q(ioim);
+               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_failed,
+                             ioim);
+               break;
+
+       default:
+               bfa_sm_fault(ioim->bfa, event);
+       }
+}
+
+/**
+ *     Active IO is being cleaned up, waiting for room in request CQ.
+ */
+static void
+bfa_ioim_sm_cleanup_qfull(struct bfa_ioim_s *ioim, enum bfa_ioim_event event)
+{
+       bfa_trc(ioim->bfa, ioim->iotag);
+       bfa_trc(ioim->bfa, event);
+
+       switch (event) {
+       case BFA_IOIM_SM_QRESUME:
+               bfa_sm_set_state(ioim, bfa_ioim_sm_cleanup);
+               bfa_ioim_send_abort(ioim);
+               break;
+
+       case BFA_IOIM_SM_ABORT:
+               /**
+                * IO is alraedy being cleaned up implicitly
+                */
+               ioim->io_cbfn = __bfa_cb_ioim_abort;
+               break;
+
+       case BFA_IOIM_SM_COMP_GOOD:
+       case BFA_IOIM_SM_COMP:
+               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
+               bfa_reqq_wcancel(&ioim->iosp->reqq_wait);
+               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, ioim->io_cbfn, ioim);
+               bfa_ioim_notify_cleanup(ioim);
+               break;
+
+       case BFA_IOIM_SM_DONE:
+               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb_free);
+               bfa_reqq_wcancel(&ioim->iosp->reqq_wait);
+               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, ioim->io_cbfn, ioim);
+               bfa_ioim_notify_cleanup(ioim);
+               break;
+
+       case BFA_IOIM_SM_HWFAIL:
+               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
+               bfa_reqq_wcancel(&ioim->iosp->reqq_wait);
+               bfa_ioim_move_to_comp_q(ioim);
+               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_failed,
+                             ioim);
+               break;
+
+       default:
+               bfa_sm_fault(ioim->bfa, event);
+       }
+}
+
+/**
+ * IO bfa callback is pending.
+ */
+static void
+bfa_ioim_sm_hcb(struct bfa_ioim_s *ioim, enum bfa_ioim_event event)
+{
+       bfa_trc_fp(ioim->bfa, ioim->iotag);
+       bfa_trc_fp(ioim->bfa, event);
+
+       switch (event) {
+       case BFA_IOIM_SM_HCB:
+               bfa_sm_set_state(ioim, bfa_ioim_sm_uninit);
+               bfa_ioim_free(ioim);
+               break;
+
+       case BFA_IOIM_SM_CLEANUP:
+               bfa_ioim_notify_cleanup(ioim);
+               break;
+
+       case BFA_IOIM_SM_HWFAIL:
+               break;
+
+       default:
+               bfa_sm_fault(ioim->bfa, event);
+       }
+}
+
+/**
+ * IO bfa callback is pending. IO resource cannot be freed.
+ */
+static void
+bfa_ioim_sm_hcb_free(struct bfa_ioim_s *ioim, enum bfa_ioim_event event)
+{
+       bfa_trc(ioim->bfa, ioim->iotag);
+       bfa_trc(ioim->bfa, event);
+
+       switch (event) {
+       case BFA_IOIM_SM_HCB:
+               bfa_sm_set_state(ioim, bfa_ioim_sm_resfree);
+               list_del(&ioim->qe);
+               list_add_tail(&ioim->qe, &ioim->fcpim->ioim_resfree_q);
+               break;
+
+       case BFA_IOIM_SM_FREE:
+               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
+               break;
+
+       case BFA_IOIM_SM_CLEANUP:
+               bfa_ioim_notify_cleanup(ioim);
+               break;
+
+       case BFA_IOIM_SM_HWFAIL:
+               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
+               break;
+
+       default:
+               bfa_sm_fault(ioim->bfa, event);
+       }
+}
+
+/**
+ * IO is completed, waiting resource free from firmware.
+ */
+static void
+bfa_ioim_sm_resfree(struct bfa_ioim_s *ioim, enum bfa_ioim_event event)
+{
+       bfa_trc(ioim->bfa, ioim->iotag);
+       bfa_trc(ioim->bfa, event);
+
+       switch (event) {
+       case BFA_IOIM_SM_FREE:
+               bfa_sm_set_state(ioim, bfa_ioim_sm_uninit);
+               bfa_ioim_free(ioim);
+               break;
+
+       case BFA_IOIM_SM_CLEANUP:
+               bfa_ioim_notify_cleanup(ioim);
+               break;
+
+       case BFA_IOIM_SM_HWFAIL:
+               break;
+
+       default:
+               bfa_sm_fault(ioim->bfa, event);
+       }
+}
+
+
+
+/**
+ *  hal_ioim_private
+ */
+
+static void
+__bfa_cb_ioim_good_comp(void *cbarg, bfa_boolean_t complete)
+{
+       struct bfa_ioim_s *ioim = cbarg;
+
+       if (!complete) {
+               bfa_sm_send_event(ioim, BFA_IOIM_SM_HCB);
+               return;
+       }
+
+       bfa_cb_ioim_good_comp(ioim->bfa->bfad, ioim->dio);
+}
+
+static void
+__bfa_cb_ioim_comp(void *cbarg, bfa_boolean_t complete)
+{
+       struct bfa_ioim_s       *ioim = cbarg;
+       struct bfi_ioim_rsp_s *m;
+       u8      *snsinfo = NULL;
+       u8      sns_len = 0;
+       s32     residue = 0;
+
+       if (!complete) {
+               bfa_sm_send_event(ioim, BFA_IOIM_SM_HCB);
+               return;
+       }
+
+       m = (struct bfi_ioim_rsp_s *) &ioim->iosp->comp_rspmsg;
+       if (m->io_status == BFI_IOIM_STS_OK) {
+               /**
+                * setup sense information, if present
+                */
+               if ((m->scsi_status == SCSI_STATUS_CHECK_CONDITION) &&
+                                       m->sns_len) {
+                       sns_len = m->sns_len;
+                       snsinfo = ioim->iosp->snsinfo;
+               }
+
+               /**
+                * setup residue value correctly for normal completions
+                */
+               if (m->resid_flags == FCP_RESID_UNDER) {
+                       residue = bfa_os_ntohl(m->residue);
+                       bfa_stats(ioim->itnim, iocomp_underrun);
+               }
+               if (m->resid_flags == FCP_RESID_OVER) {
+                       residue = bfa_os_ntohl(m->residue);
+                       residue = -residue;
+                       bfa_stats(ioim->itnim, iocomp_overrun);
+               }
+       }
+
+       bfa_cb_ioim_done(ioim->bfa->bfad, ioim->dio, m->io_status,
+                         m->scsi_status, sns_len, snsinfo, residue);
+}
+
+static void
+__bfa_cb_ioim_failed(void *cbarg, bfa_boolean_t complete)
+{
+       struct bfa_ioim_s *ioim = cbarg;
+
+       if (!complete) {
+               bfa_sm_send_event(ioim, BFA_IOIM_SM_HCB);
+               return;
+       }
+
+       bfa_cb_ioim_done(ioim->bfa->bfad, ioim->dio, BFI_IOIM_STS_ABORTED,
+                         0, 0, NULL, 0);
+}
+
+static void
+__bfa_cb_ioim_pathtov(void *cbarg, bfa_boolean_t complete)
+{
+       struct bfa_ioim_s *ioim = cbarg;
+
+       bfa_stats(ioim->itnim, path_tov_expired);
+       if (!complete) {
+               bfa_sm_send_event(ioim, BFA_IOIM_SM_HCB);
+               return;
+       }
+
+       bfa_cb_ioim_done(ioim->bfa->bfad, ioim->dio, BFI_IOIM_STS_PATHTOV,
+                         0, 0, NULL, 0);
+}
+
+static void
+__bfa_cb_ioim_abort(void *cbarg, bfa_boolean_t complete)
+{
+       struct bfa_ioim_s *ioim = cbarg;
+
+       if (!complete) {
+               bfa_sm_send_event(ioim, BFA_IOIM_SM_HCB);
+               return;
+       }
+
+       bfa_cb_ioim_abort(ioim->bfa->bfad, ioim->dio);
+}
+
+static void
+bfa_ioim_sgpg_alloced(void *cbarg)
+{
+       struct bfa_ioim_s *ioim = cbarg;
+
+       ioim->nsgpgs = BFA_SGPG_NPAGE(ioim->nsges);
+       list_splice_tail_init(&ioim->iosp->sgpg_wqe.sgpg_q, &ioim->sgpg_q);
+       bfa_ioim_sgpg_setup(ioim);
+       bfa_sm_send_event(ioim, BFA_IOIM_SM_SGALLOCED);
+}
+
+/**
+ * Send I/O request to firmware.
+ */
+static bfa_boolean_t
+bfa_ioim_send_ioreq(struct bfa_ioim_s *ioim)
+{
+       struct bfa_itnim_s *itnim = ioim->itnim;
+       struct bfi_ioim_req_s *m;
+       static struct fcp_cmnd_s cmnd_z0 = { 0 };
+       struct bfi_sge_s      *sge;
+       u32     pgdlen = 0;
+       u32     fcp_dl;
+       u64 addr;
+       struct scatterlist *sg;
+       struct scsi_cmnd *cmnd = (struct scsi_cmnd *) ioim->dio;
+
+       /**
+        * check for room in queue to send request now
+        */
+       m = bfa_reqq_next(ioim->bfa, ioim->reqq);
+       if (!m) {
+               bfa_stats(ioim->itnim, qwait);
+               bfa_reqq_wait(ioim->bfa, ioim->reqq,
+                                 &ioim->iosp->reqq_wait);
+               return BFA_FALSE;
+       }
+
+       /**
+        * build i/o request message next
+        */
+       m->io_tag = bfa_os_htons(ioim->iotag);
+       m->rport_hdl = ioim->itnim->rport->fw_handle;
+       m->io_timeout = bfa_cb_ioim_get_timeout(ioim->dio);
+
+       /**
+        * build inline IO SG element here
+        */
+       sge = &m->sges[0];
+       if (ioim->nsges) {
+               sg = (struct scatterlist *)scsi_sglist(cmnd);
+               addr = bfa_os_sgaddr(sg_dma_address(sg));
+               sge->sga = *(union bfi_addr_u *) &addr;
+               pgdlen = sg_dma_len(sg);
+               sge->sg_len = pgdlen;
+               sge->flags = (ioim->nsges > BFI_SGE_INLINE) ?
+                                       BFI_SGE_DATA_CPL : BFI_SGE_DATA_LAST;
+               bfa_sge_to_be(sge);
+               sge++;
+       }
+
+       if (ioim->nsges > BFI_SGE_INLINE) {
+               sge->sga = ioim->sgpg->sgpg_pa;
+       } else {
+               sge->sga.a32.addr_lo = 0;
+               sge->sga.a32.addr_hi = 0;
+       }
+       sge->sg_len = pgdlen;
+       sge->flags = BFI_SGE_PGDLEN;
+       bfa_sge_to_be(sge);
+
+       /**
+        * set up I/O command parameters
+        */
+       bfa_os_assign(m->cmnd, cmnd_z0);
+       m->cmnd.lun = bfa_cb_ioim_get_lun(ioim->dio);
+       m->cmnd.iodir = bfa_cb_ioim_get_iodir(ioim->dio);
+       bfa_os_assign(m->cmnd.cdb,
+                       *(scsi_cdb_t *)bfa_cb_ioim_get_cdb(ioim->dio));
+       fcp_dl = bfa_cb_ioim_get_size(ioim->dio);
+       m->cmnd.fcp_dl = bfa_os_htonl(fcp_dl);
+
+       /**
+        * set up I/O message header
+        */
+       switch (m->cmnd.iodir) {
+       case FCP_IODIR_READ:
+               bfi_h2i_set(m->mh, BFI_MC_IOIM_READ, 0, bfa_lpuid(ioim->bfa));
+               bfa_stats(itnim, input_reqs);
+               ioim->itnim->stats.rd_throughput += fcp_dl;
+               break;
+       case FCP_IODIR_WRITE:
+               bfi_h2i_set(m->mh, BFI_MC_IOIM_WRITE, 0, bfa_lpuid(ioim->bfa));
+               bfa_stats(itnim, output_reqs);
+               ioim->itnim->stats.wr_throughput += fcp_dl;
+               break;
+       case FCP_IODIR_RW:
+               bfa_stats(itnim, input_reqs);
+               bfa_stats(itnim, output_reqs);
+       default:
+               bfi_h2i_set(m->mh, BFI_MC_IOIM_IO, 0, bfa_lpuid(ioim->bfa));
+       }
+       if (itnim->seq_rec ||
+           (bfa_cb_ioim_get_size(ioim->dio) & (sizeof(u32) - 1)))
+               bfi_h2i_set(m->mh, BFI_MC_IOIM_IO, 0, bfa_lpuid(ioim->bfa));
+
+#ifdef IOIM_ADVANCED
+       m->cmnd.crn = bfa_cb_ioim_get_crn(ioim->dio);
+       m->cmnd.priority = bfa_cb_ioim_get_priority(ioim->dio);
+       m->cmnd.taskattr = bfa_cb_ioim_get_taskattr(ioim->dio);
+
+       /**
+        * Handle large CDB (>16 bytes).
+        */
+       m->cmnd.addl_cdb_len = (bfa_cb_ioim_get_cdblen(ioim->dio) -
+                                       FCP_CMND_CDB_LEN) / sizeof(u32);
+       if (m->cmnd.addl_cdb_len) {
+               bfa_os_memcpy(&m->cmnd.cdb + 1, (scsi_cdb_t *)
+                               bfa_cb_ioim_get_cdb(ioim->dio) + 1,
+                               m->cmnd.addl_cdb_len * sizeof(u32));
+               fcp_cmnd_fcpdl(&m->cmnd) =
+                               bfa_os_htonl(bfa_cb_ioim_get_size(ioim->dio));
+       }
+#endif
+
+       /**
+        * queue I/O message to firmware
+        */
+       bfa_reqq_produce(ioim->bfa, ioim->reqq);
+       return BFA_TRUE;
+}
+
+/**
+ * Setup any additional SG pages needed.Inline SG element is setup
+ * at queuing time.
+ */
+static bfa_boolean_t
+bfa_ioim_sge_setup(struct bfa_ioim_s *ioim)
+{
+       u16     nsgpgs;
+
+       bfa_assert(ioim->nsges > BFI_SGE_INLINE);
+
+       /**
+        * allocate SG pages needed
+        */
+       nsgpgs = BFA_SGPG_NPAGE(ioim->nsges);
+       if (!nsgpgs)
+               return BFA_TRUE;
+
+       if (bfa_sgpg_malloc(ioim->bfa, &ioim->sgpg_q, nsgpgs)
+           != BFA_STATUS_OK) {
+               bfa_sgpg_wait(ioim->bfa, &ioim->iosp->sgpg_wqe, nsgpgs);
+               return BFA_FALSE;
+       }
+
+       ioim->nsgpgs = nsgpgs;
+       bfa_ioim_sgpg_setup(ioim);
+
+       return BFA_TRUE;
+}
+
+static void
+bfa_ioim_sgpg_setup(struct bfa_ioim_s *ioim)
+{
+       int             sgeid, nsges, i;
+       struct bfi_sge_s      *sge;
+       struct bfa_sgpg_s *sgpg;
+       u32     pgcumsz;
+       u64        addr;
+       struct scatterlist *sg;
+       struct scsi_cmnd *cmnd = (struct scsi_cmnd *) ioim->dio;
+
+       sgeid = BFI_SGE_INLINE;
+       ioim->sgpg = sgpg = bfa_q_first(&ioim->sgpg_q);
+
+       sg = scsi_sglist(cmnd);
+       sg = sg_next(sg);
+
+       do {
+               sge = sgpg->sgpg->sges;
+               nsges = ioim->nsges - sgeid;
+               if (nsges > BFI_SGPG_DATA_SGES)
+                       nsges = BFI_SGPG_DATA_SGES;
+
+               pgcumsz = 0;
+               for (i = 0; i < nsges; i++, sge++, sgeid++, sg = sg_next(sg)) {
+                       addr = bfa_os_sgaddr(sg_dma_address(sg));
+                       sge->sga = *(union bfi_addr_u *) &addr;
+                       sge->sg_len = sg_dma_len(sg);
+                       pgcumsz += sge->sg_len;
+
+                       /**
+                        * set flags
+                        */
+                       if (i < (nsges - 1))
+                               sge->flags = BFI_SGE_DATA;
+                       else if (sgeid < (ioim->nsges - 1))
+                               sge->flags = BFI_SGE_DATA_CPL;
+                       else
+                               sge->flags = BFI_SGE_DATA_LAST;
+
+                       bfa_sge_to_le(sge);
+               }
+
+               sgpg = (struct bfa_sgpg_s *) bfa_q_next(sgpg);
+
+               /**
+                * set the link element of each page
+                */
+               if (sgeid == ioim->nsges) {
+                       sge->flags = BFI_SGE_PGDLEN;
+                       sge->sga.a32.addr_lo = 0;
+                       sge->sga.a32.addr_hi = 0;
+               } else {
+                       sge->flags = BFI_SGE_LINK;
+                       sge->sga = sgpg->sgpg_pa;
+               }
+               sge->sg_len = pgcumsz;
+
+               bfa_sge_to_le(sge);
+       } while (sgeid < ioim->nsges);
+}
+
+/**
+ * Send I/O abort request to firmware.
+ */
+static bfa_boolean_t
+bfa_ioim_send_abort(struct bfa_ioim_s *ioim)
+{
+       struct bfi_ioim_abort_req_s *m;
+       enum bfi_ioim_h2i       msgop;
+
+       /**
+        * check for room in queue to send request now
+        */
+       m = bfa_reqq_next(ioim->bfa, ioim->reqq);
+       if (!m)
+               return BFA_FALSE;
+
+       /**
+        * build i/o request message next
+        */
+       if (ioim->iosp->abort_explicit)
+               msgop = BFI_IOIM_H2I_IOABORT_REQ;
+       else
+               msgop = BFI_IOIM_H2I_IOCLEANUP_REQ;
+
+       bfi_h2i_set(m->mh, BFI_MC_IOIM, msgop, bfa_lpuid(ioim->bfa));
+       m->io_tag    = bfa_os_htons(ioim->iotag);
+       m->abort_tag = ++ioim->abort_tag;
+
+       /**
+        * queue I/O message to firmware
+        */
+       bfa_reqq_produce(ioim->bfa, ioim->reqq);
+       return BFA_TRUE;
+}
+
+/**
+ * Call to resume any I/O requests waiting for room in request queue.
+ */
+static void
+bfa_ioim_qresume(void *cbarg)
+{
+       struct bfa_ioim_s *ioim = cbarg;
+
+       bfa_stats(ioim->itnim, qresumes);
+       bfa_sm_send_event(ioim, BFA_IOIM_SM_QRESUME);
+}
+
+
+static void
+bfa_ioim_notify_cleanup(struct bfa_ioim_s *ioim)
+{
+       /**
+        * Move IO from itnim queue to fcpim global queue since itnim will be
+        * freed.
+        */
+       list_del(&ioim->qe);
+       list_add_tail(&ioim->qe, &ioim->fcpim->ioim_comp_q);
+
+       if (!ioim->iosp->tskim) {
+               if (ioim->fcpim->delay_comp && ioim->itnim->iotov_active) {
+                       bfa_cb_dequeue(&ioim->hcb_qe);
+                       list_del(&ioim->qe);
+                       list_add_tail(&ioim->qe, &ioim->itnim->delay_comp_q);
+               }
+               bfa_itnim_iodone(ioim->itnim);
+       } else
+               bfa_tskim_iodone(ioim->iosp->tskim);
+}
+
+static bfa_boolean_t
+bfa_ioim_is_abortable(struct bfa_ioim_s *ioim)
+{
+       if ((bfa_sm_cmp_state(ioim, bfa_ioim_sm_uninit) &&
+           (!bfa_q_is_on_q(&ioim->itnim->pending_q, ioim)))    ||
+           (bfa_sm_cmp_state(ioim, bfa_ioim_sm_abort))         ||
+           (bfa_sm_cmp_state(ioim, bfa_ioim_sm_abort_qfull))   ||
+           (bfa_sm_cmp_state(ioim, bfa_ioim_sm_hcb))           ||
+           (bfa_sm_cmp_state(ioim, bfa_ioim_sm_hcb_free))      ||
+           (bfa_sm_cmp_state(ioim, bfa_ioim_sm_resfree)))
+               return BFA_FALSE;
+
+       return BFA_TRUE;
+}
+
+/**
+ *     or after the link comes back.
+ */
+void
+bfa_ioim_delayed_comp(struct bfa_ioim_s *ioim, bfa_boolean_t iotov)
+{
+       /**
+        * If path tov timer expired, failback with PATHTOV status - these
+        * IO requests are not normally retried by IO stack.
+        *
+        * Otherwise device cameback online and fail it with normal failed
+        * status so that IO stack retries these failed IO requests.
+        */
+       if (iotov)
+               ioim->io_cbfn = __bfa_cb_ioim_pathtov;
+       else {
+               ioim->io_cbfn = __bfa_cb_ioim_failed;
+               bfa_stats(ioim->itnim, iocom_nexus_abort);
+       }
+       bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, ioim->io_cbfn, ioim);
+
+       /**
+        * Move IO to fcpim global queue since itnim will be
+        * freed.
+        */
+       list_del(&ioim->qe);
+       list_add_tail(&ioim->qe, &ioim->fcpim->ioim_comp_q);
+}
+
+
+
+/**
+ *  hal_ioim_friend
+ */
+
+/**
+ * Memory allocation and initialization.
+ */
+void
+bfa_ioim_attach(struct bfa_fcpim_mod_s *fcpim, struct bfa_meminfo_s *minfo)
+{
+       struct bfa_ioim_s               *ioim;
+       struct bfa_ioim_sp_s    *iosp;
+       u16             i;
+       u8                      *snsinfo;
+       u32             snsbufsz;
+
+       /**
+        * claim memory first
+        */
+       ioim = (struct bfa_ioim_s *) bfa_meminfo_kva(minfo);
+       fcpim->ioim_arr = ioim;
+       bfa_meminfo_kva(minfo) = (u8 *) (ioim + fcpim->num_ioim_reqs);
+
+       iosp = (struct bfa_ioim_sp_s *) bfa_meminfo_kva(minfo);
+       fcpim->ioim_sp_arr = iosp;
+       bfa_meminfo_kva(minfo) = (u8 *) (iosp + fcpim->num_ioim_reqs);
+
+       /**
+        * Claim DMA memory for per IO sense data.
+        */
+       snsbufsz = fcpim->num_ioim_reqs * BFI_IOIM_SNSLEN;
+       fcpim->snsbase.pa  = bfa_meminfo_dma_phys(minfo);
+       bfa_meminfo_dma_phys(minfo) += snsbufsz;
+
+       fcpim->snsbase.kva = bfa_meminfo_dma_virt(minfo);
+       bfa_meminfo_dma_virt(minfo) += snsbufsz;
+       snsinfo = fcpim->snsbase.kva;
+       bfa_iocfc_set_snsbase(fcpim->bfa, fcpim->snsbase.pa);
+
+       /**
+        * Initialize ioim free queues
+        */
+       INIT_LIST_HEAD(&fcpim->ioim_free_q);
+       INIT_LIST_HEAD(&fcpim->ioim_resfree_q);
+       INIT_LIST_HEAD(&fcpim->ioim_comp_q);
+
+       for (i = 0; i < fcpim->num_ioim_reqs;
+            i++, ioim++, iosp++, snsinfo += BFI_IOIM_SNSLEN) {
+               /*
+                * initialize IOIM
+                */
+               bfa_os_memset(ioim, 0, sizeof(struct bfa_ioim_s));
+               ioim->iotag   = i;
+               ioim->bfa     = fcpim->bfa;
+               ioim->fcpim   = fcpim;
+               ioim->iosp    = iosp;
+               iosp->snsinfo = snsinfo;
+               INIT_LIST_HEAD(&ioim->sgpg_q);
+               bfa_reqq_winit(&ioim->iosp->reqq_wait,
+                                  bfa_ioim_qresume, ioim);
+               bfa_sgpg_winit(&ioim->iosp->sgpg_wqe,
+                                  bfa_ioim_sgpg_alloced, ioim);
+               bfa_sm_set_state(ioim, bfa_ioim_sm_uninit);
+
+               list_add_tail(&ioim->qe, &fcpim->ioim_free_q);
+       }
+}
+
+/**
+ * Driver detach time call.
+ */
+void
+bfa_ioim_detach(struct bfa_fcpim_mod_s *fcpim)
+{
+}
+
+void
+bfa_ioim_isr(struct bfa_s *bfa, struct bfi_msg_s *m)
+{
+       struct bfa_fcpim_mod_s *fcpim = BFA_FCPIM_MOD(bfa);
+       struct bfi_ioim_rsp_s *rsp = (struct bfi_ioim_rsp_s *) m;
+       struct bfa_ioim_s *ioim;
+       u16     iotag;
+       enum bfa_ioim_event evt = BFA_IOIM_SM_COMP;
+
+       iotag = bfa_os_ntohs(rsp->io_tag);
+
+       ioim = BFA_IOIM_FROM_TAG(fcpim, iotag);
+       bfa_assert(ioim->iotag == iotag);
+
+       bfa_trc(ioim->bfa, ioim->iotag);
+       bfa_trc(ioim->bfa, rsp->io_status);
+       bfa_trc(ioim->bfa, rsp->reuse_io_tag);
+
+       if (bfa_sm_cmp_state(ioim, bfa_ioim_sm_active))
+               bfa_os_assign(ioim->iosp->comp_rspmsg, *m);
+
+       switch (rsp->io_status) {
+       case BFI_IOIM_STS_OK:
+               bfa_stats(ioim->itnim, iocomp_ok);
+               if (rsp->reuse_io_tag == 0)
+                       evt = BFA_IOIM_SM_DONE;
+               else
+                       evt = BFA_IOIM_SM_COMP;
+               break;
+
+       case BFI_IOIM_STS_TIMEDOUT:
+               bfa_stats(ioim->itnim, iocomp_timedout);
+       case BFI_IOIM_STS_ABORTED:
+               rsp->io_status = BFI_IOIM_STS_ABORTED;
+               bfa_stats(ioim->itnim, iocomp_aborted);
+               if (rsp->reuse_io_tag == 0)
+                       evt = BFA_IOIM_SM_DONE;
+               else
+                       evt = BFA_IOIM_SM_COMP;
+               break;
+
+       case BFI_IOIM_STS_PROTO_ERR:
+               bfa_stats(ioim->itnim, iocom_proto_err);
+               bfa_assert(rsp->reuse_io_tag);
+               evt = BFA_IOIM_SM_COMP;
+               break;
+
+       case BFI_IOIM_STS_SQER_NEEDED:
+               bfa_stats(ioim->itnim, iocom_sqer_needed);
+               bfa_assert(rsp->reuse_io_tag == 0);
+               evt = BFA_IOIM_SM_SQRETRY;
+               break;
+
+       case BFI_IOIM_STS_RES_FREE:
+               bfa_stats(ioim->itnim, iocom_res_free);
+               evt = BFA_IOIM_SM_FREE;
+               break;
+
+       case BFI_IOIM_STS_HOST_ABORTED:
+               bfa_stats(ioim->itnim, iocom_hostabrts);
+               if (rsp->abort_tag != ioim->abort_tag) {
+                       bfa_trc(ioim->bfa, rsp->abort_tag);
+                       bfa_trc(ioim->bfa, ioim->abort_tag);
+                       return;
+               }
+
+               if (rsp->reuse_io_tag)
+                       evt = BFA_IOIM_SM_ABORT_COMP;
+               else
+                       evt = BFA_IOIM_SM_ABORT_DONE;
+               break;
+
+       case BFI_IOIM_STS_UTAG:
+               bfa_stats(ioim->itnim, iocom_utags);
+               evt = BFA_IOIM_SM_COMP_UTAG;
+               break;
+
+       default:
+               bfa_assert(0);
+       }
+
+       bfa_sm_send_event(ioim, evt);
+}
+
+void
+bfa_ioim_good_comp_isr(struct bfa_s *bfa, struct bfi_msg_s *m)
+{
+       struct bfa_fcpim_mod_s *fcpim = BFA_FCPIM_MOD(bfa);
+       struct bfi_ioim_rsp_s *rsp = (struct bfi_ioim_rsp_s *) m;
+       struct bfa_ioim_s *ioim;
+       u16     iotag;
+
+       iotag = bfa_os_ntohs(rsp->io_tag);
+
+       ioim = BFA_IOIM_FROM_TAG(fcpim, iotag);
+       bfa_assert(ioim->iotag == iotag);
+
+       bfa_trc_fp(ioim->bfa, ioim->iotag);
+       bfa_ioim_cb_profile_comp(fcpim, ioim);
+
+       bfa_sm_send_event(ioim, BFA_IOIM_SM_COMP_GOOD);
+}
+
+void
+bfa_ioim_profile_start(struct bfa_ioim_s *ioim)
+{
+       ioim->start_time = bfa_os_get_clock();
+}
+
+void
+bfa_ioim_profile_comp(struct bfa_ioim_s *ioim)
+{
+       u32 fcp_dl = bfa_cb_ioim_get_size(ioim->dio);
+       u32 index = bfa_ioim_get_index(fcp_dl);
+       u64 end_time = bfa_os_get_clock();
+       struct bfa_itnim_latency_s *io_lat =
+                       &(ioim->itnim->ioprofile.io_latency);
+       u32 val = (u32)(end_time - ioim->start_time);
+
+       bfa_itnim_ioprofile_update(ioim->itnim, index);
+
+       io_lat->count[index]++;
+       io_lat->min[index] = (io_lat->min[index] < val) ?
+               io_lat->min[index] : val;
+       io_lat->max[index] = (io_lat->max[index] > val) ?
+               io_lat->max[index] : val;
+       io_lat->avg[index] += val;
+}
+/**
+ * Called by itnim to clean up IO while going offline.
+ */
+void
+bfa_ioim_cleanup(struct bfa_ioim_s *ioim)
+{
+       bfa_trc(ioim->bfa, ioim->iotag);
+       bfa_stats(ioim->itnim, io_cleanups);
+
+       ioim->iosp->tskim = NULL;
+       bfa_sm_send_event(ioim, BFA_IOIM_SM_CLEANUP);
+}
+
+void
+bfa_ioim_cleanup_tm(struct bfa_ioim_s *ioim, struct bfa_tskim_s *tskim)
+{
+       bfa_trc(ioim->bfa, ioim->iotag);
+       bfa_stats(ioim->itnim, io_tmaborts);
+
+       ioim->iosp->tskim = tskim;
+       bfa_sm_send_event(ioim, BFA_IOIM_SM_CLEANUP);
+}
+
+/**
+ * IOC failure handling.
+ */
+void
+bfa_ioim_iocdisable(struct bfa_ioim_s *ioim)
+{
+       bfa_trc(ioim->bfa, ioim->iotag);
+       bfa_stats(ioim->itnim, io_iocdowns);
+       bfa_sm_send_event(ioim, BFA_IOIM_SM_HWFAIL);
+}
+
+/**
+ * IO offline TOV popped. Fail the pending IO.
+ */
+void
+bfa_ioim_tov(struct bfa_ioim_s *ioim)
+{
+       bfa_trc(ioim->bfa, ioim->iotag);
+       bfa_sm_send_event(ioim, BFA_IOIM_SM_IOTOV);
+}
+
+
+
+/**
+ *  hal_ioim_api
+ */
+
+/**
+ * Allocate IOIM resource for initiator mode I/O request.
+ */
+struct bfa_ioim_s *
+bfa_ioim_alloc(struct bfa_s *bfa, struct bfad_ioim_s *dio,
+               struct bfa_itnim_s *itnim, u16 nsges)
+{
+       struct bfa_fcpim_mod_s *fcpim = BFA_FCPIM_MOD(bfa);
+       struct bfa_ioim_s *ioim;
+
+       /**
+        * alocate IOIM resource
+        */
+       bfa_q_deq(&fcpim->ioim_free_q, &ioim);
+       if (!ioim) {
+               bfa_stats(itnim, no_iotags);
+               return NULL;
+       }
+
+       ioim->dio = dio;
+       ioim->itnim = itnim;
+       ioim->nsges = nsges;
+       ioim->nsgpgs = 0;
+
+       bfa_stats(itnim, total_ios);
+       fcpim->ios_active++;
+
+       list_add_tail(&ioim->qe, &itnim->io_q);
+       bfa_trc_fp(ioim->bfa, ioim->iotag);
+
+       return ioim;
+}
+
+void
+bfa_ioim_free(struct bfa_ioim_s *ioim)
+{
+       struct bfa_fcpim_mod_s *fcpim = ioim->fcpim;
+
+       bfa_trc_fp(ioim->bfa, ioim->iotag);
+       bfa_assert_fp(bfa_sm_cmp_state(ioim, bfa_ioim_sm_uninit));
+
+       bfa_assert_fp(list_empty(&ioim->sgpg_q) ||
+                       (ioim->nsges > BFI_SGE_INLINE));
+
+       if (ioim->nsgpgs > 0)
+               bfa_sgpg_mfree(ioim->bfa, &ioim->sgpg_q, ioim->nsgpgs);
+
+       bfa_stats(ioim->itnim, io_comps);
+       fcpim->ios_active--;
+
+       list_del(&ioim->qe);
+       list_add_tail(&ioim->qe, &fcpim->ioim_free_q);
+}
+
+void
+bfa_ioim_start(struct bfa_ioim_s *ioim)
+{
+       bfa_trc_fp(ioim->bfa, ioim->iotag);
+
+       bfa_ioim_cb_profile_start(ioim->fcpim, ioim);
+
+       /**
+        * Obtain the queue over which this request has to be issued
+        */
+       ioim->reqq = bfa_fcpim_ioredirect_enabled(ioim->bfa) ?
+                       bfa_cb_ioim_get_reqq(ioim->dio) :
+                       bfa_itnim_get_reqq(ioim);
+
+       bfa_sm_send_event(ioim, BFA_IOIM_SM_START);
+}
+
+/**
+ * Driver I/O abort request.
+ */
+bfa_status_t
+bfa_ioim_abort(struct bfa_ioim_s *ioim)
+{
+
+       bfa_trc(ioim->bfa, ioim->iotag);
+
+       if (!bfa_ioim_is_abortable(ioim))
+               return BFA_STATUS_FAILED;
+
+       bfa_stats(ioim->itnim, io_aborts);
+       bfa_sm_send_event(ioim, BFA_IOIM_SM_ABORT);
+
+       return BFA_STATUS_OK;
+}
+
+
+/**
+ *  BFA TSKIM state machine functions
+ */
+
+/**
+ *     Task management command beginning state.
+ */
+static void
+bfa_tskim_sm_uninit(struct bfa_tskim_s *tskim, enum bfa_tskim_event event)
+{
+       bfa_trc(tskim->bfa, event);
+
+       switch (event) {
+       case BFA_TSKIM_SM_START:
+               bfa_sm_set_state(tskim, bfa_tskim_sm_active);
+               bfa_tskim_gather_ios(tskim);
+
+               /**
+                * If device is offline, do not send TM on wire. Just cleanup
+                * any pending IO requests and complete TM request.
+                */
+               if (!bfa_itnim_is_online(tskim->itnim)) {
+                       bfa_sm_set_state(tskim, bfa_tskim_sm_iocleanup);
+                       tskim->tsk_status = BFI_TSKIM_STS_OK;
+                       bfa_tskim_cleanup_ios(tskim);
+                       return;
+               }
+
+               if (!bfa_tskim_send(tskim)) {
+                       bfa_sm_set_state(tskim, bfa_tskim_sm_qfull);
+                       bfa_stats(tskim->itnim, tm_qwait);
+                       bfa_reqq_wait(tskim->bfa, tskim->itnim->reqq,
+                                         &tskim->reqq_wait);
+               }
+               break;
+
+       default:
+               bfa_sm_fault(tskim->bfa, event);
+       }
+}
+
+/**
+ * brief
+ *     TM command is active, awaiting completion from firmware to
+ *     cleanup IO requests in TM scope.
+ */
+static void
+bfa_tskim_sm_active(struct bfa_tskim_s *tskim, enum bfa_tskim_event event)
+{
+       bfa_trc(tskim->bfa, event);
+
+       switch (event) {
+       case BFA_TSKIM_SM_DONE:
+               bfa_sm_set_state(tskim, bfa_tskim_sm_iocleanup);
+               bfa_tskim_cleanup_ios(tskim);
+               break;
+
+       case BFA_TSKIM_SM_CLEANUP:
+               bfa_sm_set_state(tskim, bfa_tskim_sm_cleanup);
+               if (!bfa_tskim_send_abort(tskim)) {
+                       bfa_sm_set_state(tskim, bfa_tskim_sm_cleanup_qfull);
+                       bfa_stats(tskim->itnim, tm_qwait);
+                       bfa_reqq_wait(tskim->bfa, tskim->itnim->reqq,
+                               &tskim->reqq_wait);
+               }
+               break;
+
+       case BFA_TSKIM_SM_HWFAIL:
+               bfa_sm_set_state(tskim, bfa_tskim_sm_hcb);
+               bfa_tskim_iocdisable_ios(tskim);
+               bfa_tskim_qcomp(tskim, __bfa_cb_tskim_failed);
+               break;
+
+       default:
+               bfa_sm_fault(tskim->bfa, event);
+       }
+}
+
+/**
+ *     An active TM is being cleaned up since ITN is offline. Awaiting cleanup
+ *     completion event from firmware.
+ */
+static void
+bfa_tskim_sm_cleanup(struct bfa_tskim_s *tskim, enum bfa_tskim_event event)
+{
+       bfa_trc(tskim->bfa, event);
+
+       switch (event) {
+       case BFA_TSKIM_SM_DONE:
+               /**
+                * Ignore and wait for ABORT completion from firmware.
+                */
+               break;
+
+       case BFA_TSKIM_SM_CLEANUP_DONE:
+               bfa_sm_set_state(tskim, bfa_tskim_sm_iocleanup);
+               bfa_tskim_cleanup_ios(tskim);
+               break;
+
+       case BFA_TSKIM_SM_HWFAIL:
+               bfa_sm_set_state(tskim, bfa_tskim_sm_hcb);
+               bfa_tskim_iocdisable_ios(tskim);
+               bfa_tskim_qcomp(tskim, __bfa_cb_tskim_failed);
+               break;
+
+       default:
+               bfa_sm_fault(tskim->bfa, event);
+       }
+}
+
+static void
+bfa_tskim_sm_iocleanup(struct bfa_tskim_s *tskim, enum bfa_tskim_event event)
+{
+       bfa_trc(tskim->bfa, event);
+
+       switch (event) {
+       case BFA_TSKIM_SM_IOS_DONE:
+               bfa_sm_set_state(tskim, bfa_tskim_sm_hcb);
+               bfa_tskim_qcomp(tskim, __bfa_cb_tskim_done);
+               break;
+
+       case BFA_TSKIM_SM_CLEANUP:
+               /**
+                * Ignore, TM command completed on wire.
+                * Notify TM conmpletion on IO cleanup completion.
+                */
+               break;
+
+       case BFA_TSKIM_SM_HWFAIL:
+               bfa_sm_set_state(tskim, bfa_tskim_sm_hcb);
+               bfa_tskim_iocdisable_ios(tskim);
+               bfa_tskim_qcomp(tskim, __bfa_cb_tskim_failed);
+               break;
+
+       default:
+               bfa_sm_fault(tskim->bfa, event);
+       }
+}
+
+/**
+ *     Task management command is waiting for room in request CQ
+ */
+static void
+bfa_tskim_sm_qfull(struct bfa_tskim_s *tskim, enum bfa_tskim_event event)
+{
+       bfa_trc(tskim->bfa, event);
+
+       switch (event) {
+       case BFA_TSKIM_SM_QRESUME:
+               bfa_sm_set_state(tskim, bfa_tskim_sm_active);
+               bfa_tskim_send(tskim);
+               break;
+
+       case BFA_TSKIM_SM_CLEANUP:
+               /**
+                * No need to send TM on wire since ITN is offline.
+                */
+               bfa_sm_set_state(tskim, bfa_tskim_sm_iocleanup);
+               bfa_reqq_wcancel(&tskim->reqq_wait);
+               bfa_tskim_cleanup_ios(tskim);
+               break;
+
+       case BFA_TSKIM_SM_HWFAIL:
+               bfa_sm_set_state(tskim, bfa_tskim_sm_hcb);
+               bfa_reqq_wcancel(&tskim->reqq_wait);
+               bfa_tskim_iocdisable_ios(tskim);
+               bfa_tskim_qcomp(tskim, __bfa_cb_tskim_failed);
+               break;
+
+       default:
+               bfa_sm_fault(tskim->bfa, event);
+       }
+}
+
+/**
+ *     Task management command is active, awaiting for room in request CQ
+ *     to send clean up request.
+ */
+static void
+bfa_tskim_sm_cleanup_qfull(struct bfa_tskim_s *tskim,
+               enum bfa_tskim_event event)
+{
+       bfa_trc(tskim->bfa, event);
+
+       switch (event) {
+       case BFA_TSKIM_SM_DONE:
+               bfa_reqq_wcancel(&tskim->reqq_wait);
+               /**
+                *
+                * Fall through !!!
+                */
+
+       case BFA_TSKIM_SM_QRESUME:
+               bfa_sm_set_state(tskim, bfa_tskim_sm_cleanup);
+               bfa_tskim_send_abort(tskim);
+               break;
+
+       case BFA_TSKIM_SM_HWFAIL:
+               bfa_sm_set_state(tskim, bfa_tskim_sm_hcb);
+               bfa_reqq_wcancel(&tskim->reqq_wait);
+               bfa_tskim_iocdisable_ios(tskim);
+               bfa_tskim_qcomp(tskim, __bfa_cb_tskim_failed);
+               break;
+
+       default:
+               bfa_sm_fault(tskim->bfa, event);
+       }
+}
+
+/**
+ *     BFA callback is pending
+ */
+static void
+bfa_tskim_sm_hcb(struct bfa_tskim_s *tskim, enum bfa_tskim_event event)
+{
+       bfa_trc(tskim->bfa, event);
+
+       switch (event) {
+       case BFA_TSKIM_SM_HCB:
+               bfa_sm_set_state(tskim, bfa_tskim_sm_uninit);
+               bfa_tskim_free(tskim);
+               break;
+
+       case BFA_TSKIM_SM_CLEANUP:
+               bfa_tskim_notify_comp(tskim);
+               break;
+
+       case BFA_TSKIM_SM_HWFAIL:
+               break;
+
+       default:
+               bfa_sm_fault(tskim->bfa, event);
+       }
+}
+
+
+
+/**
+ *  hal_tskim_private
+ */
+
+static void
+__bfa_cb_tskim_done(void *cbarg, bfa_boolean_t complete)
+{
+       struct bfa_tskim_s *tskim = cbarg;
+
+       if (!complete) {
+               bfa_sm_send_event(tskim, BFA_TSKIM_SM_HCB);
+               return;
+       }
+
+       bfa_stats(tskim->itnim, tm_success);
+       bfa_cb_tskim_done(tskim->bfa->bfad, tskim->dtsk, tskim->tsk_status);
+}
+
+static void
+__bfa_cb_tskim_failed(void *cbarg, bfa_boolean_t complete)
+{
+       struct bfa_tskim_s *tskim = cbarg;
+
+       if (!complete) {
+               bfa_sm_send_event(tskim, BFA_TSKIM_SM_HCB);
+               return;
+       }
+
+       bfa_stats(tskim->itnim, tm_failures);
+       bfa_cb_tskim_done(tskim->bfa->bfad, tskim->dtsk,
+                               BFI_TSKIM_STS_FAILED);
+}
+
+static bfa_boolean_t
+bfa_tskim_match_scope(struct bfa_tskim_s *tskim, lun_t lun)
+{
+       switch (tskim->tm_cmnd) {
+       case FCP_TM_TARGET_RESET:
+               return BFA_TRUE;
+
+       case FCP_TM_ABORT_TASK_SET:
+       case FCP_TM_CLEAR_TASK_SET:
+       case FCP_TM_LUN_RESET:
+       case FCP_TM_CLEAR_ACA:
+               return (tskim->lun == lun);
+
+       default:
+               bfa_assert(0);
+       }
+
+       return BFA_FALSE;
+}
+
+/**
+ *     Gather affected IO requests and task management commands.
+ */
+static void
+bfa_tskim_gather_ios(struct bfa_tskim_s *tskim)
+{
+       struct bfa_itnim_s *itnim = tskim->itnim;
+       struct bfa_ioim_s *ioim;
+       struct list_head        *qe, *qen;
+
+       INIT_LIST_HEAD(&tskim->io_q);
+
+       /**
+        * Gather any active IO requests first.
+        */
+       list_for_each_safe(qe, qen, &itnim->io_q) {
+               ioim = (struct bfa_ioim_s *) qe;
+               if (bfa_tskim_match_scope
+                       (tskim, bfa_cb_ioim_get_lun(ioim->dio))) {
+                       list_del(&ioim->qe);
+                       list_add_tail(&ioim->qe, &tskim->io_q);
+               }
+       }
+
+       /**
+        * Failback any pending IO requests immediately.
+        */
+       list_for_each_safe(qe, qen, &itnim->pending_q) {
+               ioim = (struct bfa_ioim_s *) qe;
+               if (bfa_tskim_match_scope
+                       (tskim, bfa_cb_ioim_get_lun(ioim->dio))) {
+                       list_del(&ioim->qe);
+                       list_add_tail(&ioim->qe, &ioim->fcpim->ioim_comp_q);
+                       bfa_ioim_tov(ioim);
+               }
+       }
+}
+
+/**
+ *     IO cleanup completion
+ */
+static void
+bfa_tskim_cleanp_comp(void *tskim_cbarg)
+{
+       struct bfa_tskim_s *tskim = tskim_cbarg;
+
+       bfa_stats(tskim->itnim, tm_io_comps);
+       bfa_sm_send_event(tskim, BFA_TSKIM_SM_IOS_DONE);
+}
+
+/**
+ *     Gather affected IO requests and task management commands.
+ */
+static void
+bfa_tskim_cleanup_ios(struct bfa_tskim_s *tskim)
+{
+       struct bfa_ioim_s *ioim;
+       struct list_head        *qe, *qen;
+
+       bfa_wc_init(&tskim->wc, bfa_tskim_cleanp_comp, tskim);
+
+       list_for_each_safe(qe, qen, &tskim->io_q) {
+               ioim = (struct bfa_ioim_s *) qe;
+               bfa_wc_up(&tskim->wc);
+               bfa_ioim_cleanup_tm(ioim, tskim);
+       }
+
+       bfa_wc_wait(&tskim->wc);
+}
+
+/**
+ *     Send task management request to firmware.
+ */
+static bfa_boolean_t
+bfa_tskim_send(struct bfa_tskim_s *tskim)
+{
+       struct bfa_itnim_s *itnim = tskim->itnim;
+       struct bfi_tskim_req_s *m;
+
+       /**
+        * check for room in queue to send request now
+        */
+       m = bfa_reqq_next(tskim->bfa, itnim->reqq);
+       if (!m)
+               return BFA_FALSE;
+
+       /**
+        * build i/o request message next
+        */
+       bfi_h2i_set(m->mh, BFI_MC_TSKIM, BFI_TSKIM_H2I_TM_REQ,
+                       bfa_lpuid(tskim->bfa));
+
+       m->tsk_tag = bfa_os_htons(tskim->tsk_tag);
+       m->itn_fhdl = tskim->itnim->rport->fw_handle;
+       m->t_secs = tskim->tsecs;
+       m->lun = tskim->lun;
+       m->tm_flags = tskim->tm_cmnd;
+
+       /**
+        * queue I/O message to firmware
+        */
+       bfa_reqq_produce(tskim->bfa, itnim->reqq);
+       return BFA_TRUE;
+}
+
+/**
+ *     Send abort request to cleanup an active TM to firmware.
+ */
+static bfa_boolean_t
+bfa_tskim_send_abort(struct bfa_tskim_s *tskim)
+{
+       struct bfa_itnim_s      *itnim = tskim->itnim;
+       struct bfi_tskim_abortreq_s     *m;
+
+       /**
+        * check for room in queue to send request now
+        */
+       m = bfa_reqq_next(tskim->bfa, itnim->reqq);
+       if (!m)
+               return BFA_FALSE;
+
+       /**
+        * build i/o request message next
+        */
+       bfi_h2i_set(m->mh, BFI_MC_TSKIM, BFI_TSKIM_H2I_ABORT_REQ,
+                       bfa_lpuid(tskim->bfa));
+
+       m->tsk_tag  = bfa_os_htons(tskim->tsk_tag);
+
+       /**
+        * queue I/O message to firmware
+        */
+       bfa_reqq_produce(tskim->bfa, itnim->reqq);
+       return BFA_TRUE;
+}
+
+/**
+ *     Call to resume task management cmnd waiting for room in request queue.
+ */
+static void
+bfa_tskim_qresume(void *cbarg)
+{
+       struct bfa_tskim_s *tskim = cbarg;
+
+       bfa_stats(tskim->itnim, tm_qresumes);
+       bfa_sm_send_event(tskim, BFA_TSKIM_SM_QRESUME);
+}
+
+/**
+ * Cleanup IOs associated with a task mangement command on IOC failures.
+ */
+static void
+bfa_tskim_iocdisable_ios(struct bfa_tskim_s *tskim)
+{
+       struct bfa_ioim_s *ioim;
+       struct list_head        *qe, *qen;
+
+       list_for_each_safe(qe, qen, &tskim->io_q) {
+               ioim = (struct bfa_ioim_s *) qe;
+               bfa_ioim_iocdisable(ioim);
+       }
+}
+
+
+
+/**
+ *  hal_tskim_friend
+ */
+
+/**
+ * Notification on completions from related ioim.
+ */
+void
+bfa_tskim_iodone(struct bfa_tskim_s *tskim)
+{
+       bfa_wc_down(&tskim->wc);
+}
+
+/**
+ * Handle IOC h/w failure notification from itnim.
+ */
+void
+bfa_tskim_iocdisable(struct bfa_tskim_s *tskim)
+{
+       tskim->notify = BFA_FALSE;
+       bfa_stats(tskim->itnim, tm_iocdowns);
+       bfa_sm_send_event(tskim, BFA_TSKIM_SM_HWFAIL);
+}
+
+/**
+ * Cleanup TM command and associated IOs as part of ITNIM offline.
+ */
+void
+bfa_tskim_cleanup(struct bfa_tskim_s *tskim)
+{
+       tskim->notify = BFA_TRUE;
+       bfa_stats(tskim->itnim, tm_cleanups);
+       bfa_sm_send_event(tskim, BFA_TSKIM_SM_CLEANUP);
+}
+
+/**
+ *     Memory allocation and initialization.
+ */
+void
+bfa_tskim_attach(struct bfa_fcpim_mod_s *fcpim, struct bfa_meminfo_s *minfo)
+{
+       struct bfa_tskim_s *tskim;
+       u16     i;
+
+       INIT_LIST_HEAD(&fcpim->tskim_free_q);
+
+       tskim = (struct bfa_tskim_s *) bfa_meminfo_kva(minfo);
+       fcpim->tskim_arr = tskim;
+
+       for (i = 0; i < fcpim->num_tskim_reqs; i++, tskim++) {
+               /*
+                * initialize TSKIM
+                */
+               bfa_os_memset(tskim, 0, sizeof(struct bfa_tskim_s));
+               tskim->tsk_tag = i;
+               tskim->bfa      = fcpim->bfa;
+               tskim->fcpim    = fcpim;
+               tskim->notify  = BFA_FALSE;
+               bfa_reqq_winit(&tskim->reqq_wait, bfa_tskim_qresume,
+                                       tskim);
+               bfa_sm_set_state(tskim, bfa_tskim_sm_uninit);
+
+               list_add_tail(&tskim->qe, &fcpim->tskim_free_q);
+       }
+
+       bfa_meminfo_kva(minfo) = (u8 *) tskim;
+}
+
+void
+bfa_tskim_detach(struct bfa_fcpim_mod_s *fcpim)
+{
+       /**
+       * @todo
+       */
+}
+
+void
+bfa_tskim_isr(struct bfa_s *bfa, struct bfi_msg_s *m)
+{
+       struct bfa_fcpim_mod_s *fcpim = BFA_FCPIM_MOD(bfa);
+       struct bfi_tskim_rsp_s *rsp = (struct bfi_tskim_rsp_s *) m;
+       struct bfa_tskim_s *tskim;
+       u16     tsk_tag = bfa_os_ntohs(rsp->tsk_tag);
+
+       tskim = BFA_TSKIM_FROM_TAG(fcpim, tsk_tag);
+       bfa_assert(tskim->tsk_tag == tsk_tag);
+
+       tskim->tsk_status = rsp->tsk_status;
+
+       /**
+        * Firmware sends BFI_TSKIM_STS_ABORTED status for abort
+        * requests. All other statuses are for normal completions.
+        */
+       if (rsp->tsk_status == BFI_TSKIM_STS_ABORTED) {
+               bfa_stats(tskim->itnim, tm_cleanup_comps);
+               bfa_sm_send_event(tskim, BFA_TSKIM_SM_CLEANUP_DONE);
+       } else {
+               bfa_stats(tskim->itnim, tm_fw_rsps);
+               bfa_sm_send_event(tskim, BFA_TSKIM_SM_DONE);
+       }
+}
+
+
+
+/**
+ *  hal_tskim_api
+ */
+
+
+struct bfa_tskim_s *
+bfa_tskim_alloc(struct bfa_s *bfa, struct bfad_tskim_s *dtsk)
+{
+       struct bfa_fcpim_mod_s *fcpim = BFA_FCPIM_MOD(bfa);
+       struct bfa_tskim_s *tskim;
+
+       bfa_q_deq(&fcpim->tskim_free_q, &tskim);
+
+       if (tskim)
+               tskim->dtsk = dtsk;
+
+       return tskim;
+}
+
+void
+bfa_tskim_free(struct bfa_tskim_s *tskim)
+{
+       bfa_assert(bfa_q_is_on_q_func(&tskim->itnim->tsk_q, &tskim->qe));
+       list_del(&tskim->qe);
+       list_add_tail(&tskim->qe, &tskim->fcpim->tskim_free_q);
+}
+
+/**
+ *     Start a task management command.
+ *
+ * @param[in]  tskim   BFA task management command instance
+ * @param[in]  itnim   i-t nexus for the task management command
+ * @param[in]  lun     lun, if applicable
+ * @param[in]  tm_cmnd Task management command code.
+ * @param[in]  t_secs  Timeout in seconds
+ *
+ * @return None.
+ */
+void
+bfa_tskim_start(struct bfa_tskim_s *tskim, struct bfa_itnim_s *itnim, lun_t lun,
+                       enum fcp_tm_cmnd tm_cmnd, u8 tsecs)
+{
+       tskim->itnim    = itnim;
+       tskim->lun      = lun;
+       tskim->tm_cmnd = tm_cmnd;
+       tskim->tsecs    = tsecs;
+       tskim->notify  = BFA_FALSE;
+       bfa_stats(itnim, tm_cmnds);
+
+       list_add_tail(&tskim->qe, &itnim->tsk_q);
+       bfa_sm_send_event(tskim, BFA_TSKIM_SM_START);
+}
diff --git a/drivers/scsi/bfa/bfa_fcpim.h b/drivers/scsi/bfa/bfa_fcpim.h
new file mode 100644 (file)
index 0000000..3bf3431
--- /dev/null
@@ -0,0 +1,401 @@
+/*
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
+ * All rights reserved
+ * www.brocade.com
+ *
+ * Linux driver for Brocade Fibre Channel Host Bus Adapter.
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License (GPL) Version 2 as
+ * published by the Free Software Foundation
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * General Public License for more details.
+ */
+
+#ifndef __BFA_FCPIM_H__
+#define __BFA_FCPIM_H__
+
+#include "bfa.h"
+#include "bfa_svc.h"
+#include "bfi_ms.h"
+#include "bfa_defs_svc.h"
+#include "bfa_cs.h"
+
+
+#define BFA_ITNIM_MIN   32
+#define BFA_ITNIM_MAX   1024
+
+#define BFA_IOIM_MIN   8
+#define BFA_IOIM_MAX   2000
+
+#define BFA_TSKIM_MIN   4
+#define BFA_TSKIM_MAX   512
+#define BFA_FCPIM_PATHTOV_DEF  (30 * 1000)     /* in millisecs */
+#define BFA_FCPIM_PATHTOV_MAX  (90 * 1000)     /* in millisecs */
+
+
+#define bfa_itnim_ioprofile_update(__itnim, __index)                   \
+       (__itnim->ioprofile.iocomps[__index]++)
+
+#define BFA_IOIM_RETRY_TAG_OFFSET 11
+#define BFA_IOIM_RETRY_TAG_MASK 0x07ff /* 2K IOs */
+#define BFA_IOIM_RETRY_MAX 7
+
+/* Buckets are are 512 bytes to 2MB */
+static inline u32
+bfa_ioim_get_index(u32 n) {
+       int pos = 0;
+       if (n >= (1UL)<<22)
+               return BFA_IOBUCKET_MAX - 1;
+       n >>= 8;
+       if (n >= (1UL)<<16)
+               n >>= 16; pos += 16;
+       if (n >= 1 << 8)
+               n >>= 8; pos += 8;
+       if (n >= 1 << 4)
+               n >>= 4; pos += 4;
+       if (n >= 1 << 2)
+               n >>= 2; pos += 2;
+       if (n >= 1 << 1)
+               pos += 1;
+
+       return (n == 0) ? (0) : pos;
+}
+
+/*
+ * forward declarations
+ */
+struct bfa_ioim_s;
+struct bfa_tskim_s;
+struct bfad_ioim_s;
+struct bfad_tskim_s;
+
+typedef void    (*bfa_fcpim_profile_t) (struct bfa_ioim_s *ioim);
+
+struct bfa_fcpim_mod_s {
+       struct bfa_s            *bfa;
+       struct bfa_itnim_s      *itnim_arr;
+       struct bfa_ioim_s       *ioim_arr;
+       struct bfa_ioim_sp_s    *ioim_sp_arr;
+       struct bfa_tskim_s      *tskim_arr;
+       struct bfa_dma_s        snsbase;
+       int                     num_itnims;
+       int                     num_ioim_reqs;
+       int                     num_tskim_reqs;
+       u32                     path_tov;
+       u16                     q_depth;
+       u8                      reqq;           /*  Request queue to be used */
+       u8                      rsvd;
+       struct list_head        itnim_q;        /*  queue of active itnim */
+       struct list_head        ioim_free_q;    /*  free IO resources   */
+       struct list_head        ioim_resfree_q; /*  IOs waiting for f/w */
+       struct list_head        ioim_comp_q;    /*  IO global comp Q    */
+       struct list_head        tskim_free_q;
+       u32             ios_active;     /*  current active IOs  */
+       u32             delay_comp;
+       struct bfa_fcpim_del_itn_stats_s del_itn_stats;
+       bfa_boolean_t           ioredirect;
+       bfa_boolean_t           io_profile;
+       u32             io_profile_start_time;
+       bfa_fcpim_profile_t     profile_comp;
+       bfa_fcpim_profile_t     profile_start;
+};
+
+/**
+ * BFA IO (initiator mode)
+ */
+struct bfa_ioim_s {
+       struct list_head        qe;             /*  queue elememt       */
+       bfa_sm_t                sm;             /*  BFA ioim state machine */
+       struct bfa_s            *bfa;           /*  BFA module  */
+       struct bfa_fcpim_mod_s  *fcpim;         /*  parent fcpim module */
+       struct bfa_itnim_s      *itnim;         /*  i-t-n nexus for this IO  */
+       struct bfad_ioim_s      *dio;           /*  driver IO handle    */
+       u16             iotag;          /*  FWI IO tag  */
+       u16             abort_tag;      /*  unqiue abort request tag */
+       u16             nsges;          /*  number of SG elements */
+       u16             nsgpgs;         /*  number of SG pages  */
+       struct bfa_sgpg_s       *sgpg;          /*  first SG page       */
+       struct list_head        sgpg_q;         /*  allocated SG pages  */
+       struct bfa_cb_qe_s      hcb_qe;         /*  bfa callback qelem  */
+       bfa_cb_cbfn_t           io_cbfn;        /*  IO completion handler */
+       struct bfa_ioim_sp_s *iosp;             /*  slow-path IO handling */
+       u8              reqq;           /*  Request queue for I/O */
+       u64 start_time;                 /*  IO's Profile start val */
+};
+
+
+struct bfa_ioim_sp_s {
+       struct bfi_msg_s        comp_rspmsg;    /*  IO comp f/w response */
+       u8                      *snsinfo;       /*  sense info for this IO   */
+       struct bfa_sgpg_wqe_s sgpg_wqe; /*  waitq elem for sgpg */
+       struct bfa_reqq_wait_s reqq_wait;       /*  to wait for room in reqq */
+       bfa_boolean_t           abort_explicit; /*  aborted by OS       */
+       struct bfa_tskim_s      *tskim;         /*  Relevant TM cmd     */
+};
+
+/**
+ * BFA Task management command (initiator mode)
+ */
+struct bfa_tskim_s {
+       struct list_head        qe;
+       bfa_sm_t                sm;
+       struct bfa_s    *bfa;   /*  BFA module  */
+       struct bfa_fcpim_mod_s  *fcpim; /*  parent fcpim module */
+       struct bfa_itnim_s      *itnim; /*  i-t-n nexus for this IO  */
+       struct bfad_tskim_s     *dtsk;   /*  driver task mgmt cmnd      */
+       bfa_boolean_t   notify; /*  notify itnim on TM comp  */
+       lun_t   lun;    /*  lun if applicable   */
+       enum fcp_tm_cmnd        tm_cmnd;        /*  task management command  */
+       u16     tsk_tag;        /*  FWI IO tag  */
+       u8      tsecs;  /*  timeout in seconds  */
+       struct bfa_reqq_wait_s  reqq_wait;   /*  to wait for room in reqq */
+       struct list_head        io_q;   /*  queue of affected IOs       */
+       struct bfa_wc_s wc;     /*  waiting counter     */
+       struct bfa_cb_qe_s      hcb_qe; /*  bfa callback qelem  */
+       enum bfi_tskim_status   tsk_status;  /*  TM status      */
+};
+
+
+/**
+ * BFA i-t-n (initiator mode)
+ */
+struct bfa_itnim_s {
+       struct list_head        qe;             /*  queue element       */
+       bfa_sm_t          sm;           /*  i-t-n im BFA state machine  */
+       struct bfa_s    *bfa;           /*  bfa instance        */
+       struct bfa_rport_s *rport;      /*  bfa rport   */
+       void    *ditn;          /*  driver i-t-n structure      */
+       struct bfi_mhdr_s       mhdr;   /*  pre-built mhdr      */
+       u8      msg_no;         /*  itnim/rport firmware handle */
+       u8      reqq;           /*  CQ for requests     */
+       struct bfa_cb_qe_s      hcb_qe; /*  bfa callback qelem  */
+       struct list_head pending_q;     /*  queue of pending IO requests */
+       struct list_head io_q;          /*  queue of active IO requests */
+       struct list_head io_cleanup_q;  /*  IO being cleaned up */
+       struct list_head tsk_q;         /*  queue of active TM commands */
+       struct list_head  delay_comp_q; /*  queue of failed inflight cmds */
+       bfa_boolean_t   seq_rec;        /*  SQER supported      */
+       bfa_boolean_t   is_online;      /*  itnim is ONLINE for IO      */
+       bfa_boolean_t   iotov_active;   /*  IO TOV timer is active       */
+       struct bfa_wc_s wc;     /*  waiting counter     */
+       struct bfa_timer_s timer;       /*  pending IO TOV               */
+       struct bfa_reqq_wait_s reqq_wait; /*  to wait for room in reqq */
+       struct bfa_fcpim_mod_s *fcpim;  /*  fcpim module        */
+       struct bfa_itnim_iostats_s      stats;
+       struct bfa_itnim_ioprofile_s  ioprofile;
+};
+
+
+#define bfa_itnim_is_online(_itnim) ((_itnim)->is_online)
+#define BFA_FCPIM_MOD(_hal) (&(_hal)->modules.fcpim_mod)
+#define BFA_IOIM_FROM_TAG(_fcpim, _iotag)      \
+       (&fcpim->ioim_arr[(_iotag & BFA_IOIM_RETRY_TAG_MASK)])
+#define BFA_TSKIM_FROM_TAG(_fcpim, _tmtag)     \
+       (&fcpim->tskim_arr[_tmtag & (fcpim->num_tskim_reqs - 1)])
+
+#define bfa_io_profile_start_time(_bfa)        \
+       (_bfa->modules.fcpim_mod.io_profile_start_time)
+#define bfa_fcpim_get_io_profile(_bfa) \
+       (_bfa->modules.fcpim_mod.io_profile)
+
+static inline bfa_boolean_t
+bfa_ioim_get_iotag(struct bfa_ioim_s *ioim)
+{
+       u16 k = ioim->iotag;
+
+       k >>= BFA_IOIM_RETRY_TAG_OFFSET; k++;
+
+       if (k > BFA_IOIM_RETRY_MAX)
+               return BFA_FALSE;
+       ioim->iotag &= BFA_IOIM_RETRY_TAG_MASK;
+       ioim->iotag |= k<<BFA_IOIM_RETRY_TAG_OFFSET;
+       return BFA_TRUE;
+}
+/*
+ * function prototypes
+ */
+void   bfa_ioim_attach(struct bfa_fcpim_mod_s *fcpim,
+                                       struct bfa_meminfo_s *minfo);
+void   bfa_ioim_detach(struct bfa_fcpim_mod_s *fcpim);
+void   bfa_ioim_isr(struct bfa_s *bfa, struct bfi_msg_s *msg);
+void   bfa_ioim_good_comp_isr(struct bfa_s *bfa,
+                                       struct bfi_msg_s *msg);
+void   bfa_ioim_cleanup(struct bfa_ioim_s *ioim);
+void   bfa_ioim_cleanup_tm(struct bfa_ioim_s *ioim,
+                                       struct bfa_tskim_s *tskim);
+void   bfa_ioim_iocdisable(struct bfa_ioim_s *ioim);
+void   bfa_ioim_tov(struct bfa_ioim_s *ioim);
+
+void   bfa_tskim_attach(struct bfa_fcpim_mod_s *fcpim,
+                                       struct bfa_meminfo_s *minfo);
+void   bfa_tskim_detach(struct bfa_fcpim_mod_s *fcpim);
+void   bfa_tskim_isr(struct bfa_s *bfa, struct bfi_msg_s *msg);
+void   bfa_tskim_iodone(struct bfa_tskim_s *tskim);
+void   bfa_tskim_iocdisable(struct bfa_tskim_s *tskim);
+void   bfa_tskim_cleanup(struct bfa_tskim_s *tskim);
+
+void   bfa_itnim_meminfo(struct bfa_iocfc_cfg_s *cfg, u32 *km_len,
+                                       u32 *dm_len);
+void   bfa_itnim_attach(struct bfa_fcpim_mod_s *fcpim,
+                                       struct bfa_meminfo_s *minfo);
+void   bfa_itnim_detach(struct bfa_fcpim_mod_s *fcpim);
+void   bfa_itnim_iocdisable(struct bfa_itnim_s *itnim);
+void   bfa_itnim_isr(struct bfa_s *bfa, struct bfi_msg_s *msg);
+void   bfa_itnim_iodone(struct bfa_itnim_s *itnim);
+void   bfa_itnim_tskdone(struct bfa_itnim_s *itnim);
+bfa_boolean_t   bfa_itnim_hold_io(struct bfa_itnim_s *itnim);
+void bfa_ioim_profile_comp(struct bfa_ioim_s *ioim);
+void bfa_ioim_profile_start(struct bfa_ioim_s *ioim);
+
+
+/*
+ * bfa fcpim module API functions
+ */
+void           bfa_fcpim_path_tov_set(struct bfa_s *bfa, u16 path_tov);
+u16    bfa_fcpim_path_tov_get(struct bfa_s *bfa);
+void           bfa_fcpim_qdepth_set(struct bfa_s *bfa, u16 q_depth);
+u16    bfa_fcpim_qdepth_get(struct bfa_s *bfa);
+bfa_status_t bfa_fcpim_get_modstats(struct bfa_s *bfa,
+        struct bfa_itnim_iostats_s *modstats);
+bfa_status_t bfa_fcpim_port_iostats(struct bfa_s *bfa,
+               struct bfa_itnim_iostats_s *stats, u8 lp_tag);
+bfa_status_t bfa_fcpim_get_del_itn_stats(struct bfa_s *bfa,
+        struct bfa_fcpim_del_itn_stats_s *modstats);
+bfa_status_t bfa_fcpim_port_clear_iostats(struct bfa_s *bfa, u8 lp_tag);
+void bfa_fcpim_add_stats(struct bfa_itnim_iostats_s *fcpim_stats,
+               struct bfa_itnim_iostats_s *itnim_stats);
+bfa_status_t bfa_fcpim_clr_modstats(struct bfa_s *bfa);
+void           bfa_fcpim_set_ioredirect(struct bfa_s *bfa,
+                               bfa_boolean_t state);
+void           bfa_fcpim_update_ioredirect(struct bfa_s *bfa);
+bfa_status_t bfa_fcpim_profile_on(struct bfa_s *bfa, u32 time);
+bfa_status_t bfa_fcpim_profile_off(struct bfa_s *bfa);
+#define bfa_fcpim_ioredirect_enabled(__bfa)                            \
+       (((struct bfa_fcpim_mod_s *)(BFA_FCPIM_MOD(__bfa)))->ioredirect)
+
+#define bfa_fcpim_get_next_reqq(__bfa, __qid)                          \
+{                                                                      \
+       struct bfa_fcpim_mod_s *__fcpim = BFA_FCPIM_MOD(__bfa);      \
+       __fcpim->reqq++;                                                \
+       __fcpim->reqq &= (BFI_IOC_MAX_CQS - 1);      \
+       *(__qid) = __fcpim->reqq;                                       \
+}
+
+#define bfa_iocfc_map_msg_to_qid(__msg, __qid)                         \
+       *(__qid) = (u8)((__msg) & (BFI_IOC_MAX_CQS - 1));
+/*
+ * bfa itnim API functions
+ */
+struct bfa_itnim_s *bfa_itnim_create(struct bfa_s *bfa,
+                                       struct bfa_rport_s *rport, void *itnim);
+void           bfa_itnim_delete(struct bfa_itnim_s *itnim);
+void           bfa_itnim_online(struct bfa_itnim_s *itnim,
+                                bfa_boolean_t seq_rec);
+void           bfa_itnim_offline(struct bfa_itnim_s *itnim);
+void           bfa_itnim_get_stats(struct bfa_itnim_s *itnim,
+                       struct bfa_itnim_iostats_s *stats);
+void           bfa_itnim_clear_stats(struct bfa_itnim_s *itnim);
+bfa_status_t   bfa_itnim_get_ioprofile(struct bfa_itnim_s *itnim,
+               struct bfa_itnim_ioprofile_s *ioprofile);
+#define bfa_itnim_get_reqq(__ioim) (((struct bfa_ioim_s *)__ioim)->itnim->reqq)
+
+/**
+ *     BFA completion callback for bfa_itnim_online().
+ *
+ * @param[in]          itnim           FCS or driver itnim instance
+ *
+ * return None
+ */
+void   bfa_cb_itnim_online(void *itnim);
+
+/**
+ *     BFA completion callback for bfa_itnim_offline().
+ *
+ * @param[in]          itnim           FCS or driver itnim instance
+ *
+ * return None
+ */
+void   bfa_cb_itnim_offline(void *itnim);
+void   bfa_cb_itnim_tov_begin(void *itnim);
+void   bfa_cb_itnim_tov(void *itnim);
+
+/**
+ *     BFA notification to FCS/driver for second level error recovery.
+ *
+ * Atleast one I/O request has timedout and target is unresponsive to
+ * repeated abort requests. Second level error recovery should be initiated
+ * by starting implicit logout and recovery procedures.
+ *
+ * @param[in]          itnim           FCS or driver itnim instance
+ *
+ * return None
+ */
+void   bfa_cb_itnim_sler(void *itnim);
+
+/*
+ * bfa ioim API functions
+ */
+struct bfa_ioim_s      *bfa_ioim_alloc(struct bfa_s *bfa,
+                                       struct bfad_ioim_s *dio,
+                                       struct bfa_itnim_s *itnim,
+                                       u16 nsgles);
+
+void           bfa_ioim_free(struct bfa_ioim_s *ioim);
+void           bfa_ioim_start(struct bfa_ioim_s *ioim);
+bfa_status_t   bfa_ioim_abort(struct bfa_ioim_s *ioim);
+void           bfa_ioim_delayed_comp(struct bfa_ioim_s *ioim,
+                                     bfa_boolean_t iotov);
+
+
+/**
+ *     I/O completion notification.
+ *
+ * @param[in]          dio                     driver IO structure
+ * @param[in]          io_status               IO completion status
+ * @param[in]          scsi_status             SCSI status returned by target
+ * @param[in]          sns_len                 SCSI sense length, 0 if none
+ * @param[in]          sns_info                SCSI sense data, if any
+ * @param[in]          residue                 Residual length
+ *
+ * @return None
+ */
+void   bfa_cb_ioim_done(void *bfad, struct bfad_ioim_s *dio,
+                                 enum bfi_ioim_status io_status,
+                                 u8 scsi_status, int sns_len,
+                                 u8 *sns_info, s32 residue);
+
+/**
+ *     I/O good completion notification.
+ *
+ * @param[in]          dio                     driver IO structure
+ *
+ * @return None
+ */
+void   bfa_cb_ioim_good_comp(void *bfad, struct bfad_ioim_s *dio);
+
+/**
+ *     I/O abort completion notification
+ *
+ * @param[in]          dio                     driver IO that was aborted
+ *
+ * @return None
+ */
+void   bfa_cb_ioim_abort(void *bfad, struct bfad_ioim_s *dio);
+
+/*
+ * bfa tskim API functions
+ */
+struct bfa_tskim_s     *bfa_tskim_alloc(struct bfa_s *bfa,
+                                       struct bfad_tskim_s *dtsk);
+void           bfa_tskim_free(struct bfa_tskim_s *tskim);
+void           bfa_tskim_start(struct bfa_tskim_s *tskim,
+                               struct bfa_itnim_s *itnim, lun_t lun,
+                               enum fcp_tm_cmnd tm, u8 t_secs);
+void           bfa_cb_tskim_done(void *bfad, struct bfad_tskim_s *dtsk,
+                                 enum bfi_tskim_status tsk_status);
+
+#endif /* __BFA_FCPIM_H__ */
diff --git a/drivers/scsi/bfa/bfa_fcpim_priv.h b/drivers/scsi/bfa/bfa_fcpim_priv.h
deleted file mode 100644 (file)
index 762516c..0000000
+++ /dev/null
@@ -1,192 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_FCPIM_PRIV_H__
-#define __BFA_FCPIM_PRIV_H__
-
-#include <bfa_fcpim.h>
-#include <defs/bfa_defs_fcpim.h>
-#include <cs/bfa_wc.h>
-#include "bfa_sgpg_priv.h"
-
-#define BFA_ITNIM_MIN   32
-#define BFA_ITNIM_MAX   1024
-
-#define BFA_IOIM_MIN    8
-#define BFA_IOIM_MAX    2000
-
-#define BFA_TSKIM_MIN   4
-#define BFA_TSKIM_MAX   512
-#define BFA_FCPIM_PATHTOV_DEF  (30 * 1000)     /* in millisecs */
-#define BFA_FCPIM_PATHTOV_MAX  (90 * 1000)     /* in millisecs */
-
-#define bfa_fcpim_stats(__fcpim, __stats)   \
-    ((__fcpim)->stats.__stats++)
-
-struct bfa_fcpim_mod_s {
-       struct bfa_s    *bfa;
-       struct bfa_itnim_s      *itnim_arr;
-       struct bfa_ioim_s       *ioim_arr;
-       struct bfa_ioim_sp_s *ioim_sp_arr;
-       struct bfa_tskim_s      *tskim_arr;
-       struct bfa_dma_s        snsbase;
-       int                     num_itnims;
-       int                     num_ioim_reqs;
-       int                     num_tskim_reqs;
-       u32             path_tov;
-       u16             q_depth;
-       u8              reqq;           /* Request queue to be used */
-       u8              rsvd;
-       struct list_head        itnim_q;        /*  queue of active itnim    */
-       struct list_head        ioim_free_q;    /*  free IO resources        */
-       struct list_head        ioim_resfree_q; /*  IOs waiting for f/w      */
-       struct list_head        ioim_comp_q;    /*  IO global comp Q         */
-       struct list_head        tskim_free_q;
-       u32     ios_active;     /*  current active IOs        */
-       u32     delay_comp;
-       struct bfa_fcpim_stats_s stats;
-       bfa_boolean_t           ioredirect;
-};
-
-struct bfa_ioim_s;
-struct bfa_tskim_s;
-
-/**
- * BFA IO (initiator mode)
- */
-struct bfa_ioim_s {
-       struct list_head qe;            /*  queue elememt            */
-       bfa_sm_t                sm;     /*  BFA ioim state machine   */
-       struct bfa_s            *bfa;   /*  BFA module               */
-       struct bfa_fcpim_mod_s  *fcpim; /*  parent fcpim module      */
-       struct bfa_itnim_s      *itnim; /*  i-t-n nexus for this IO  */
-       struct bfad_ioim_s      *dio;   /*  driver IO handle         */
-       u16     iotag;          /*  FWI IO tag               */
-       u16     abort_tag;      /*  unqiue abort request tag */
-       u16     nsges;          /*  number of SG elements    */
-       u16     nsgpgs;         /*  number of SG pages       */
-       struct bfa_sgpg_s *sgpg;        /*  first SG page            */
-       struct list_head sgpg_q;                /*  allocated SG pages       */
-       struct bfa_cb_qe_s hcb_qe;      /*  bfa callback qelem       */
-       bfa_cb_cbfn_t io_cbfn;          /*  IO completion handler    */
-       struct bfa_ioim_sp_s *iosp;     /*  slow-path IO handling    */
-       u8 reqq;                        /* Request queue for I/O    */
-};
-
-struct bfa_ioim_sp_s {
-       struct bfi_msg_s        comp_rspmsg;    /*  IO comp f/w response     */
-       u8                      *snsinfo;       /*  sense info for this IO   */
-       struct bfa_sgpg_wqe_s sgpg_wqe; /*  waitq elem for sgpg      */
-       struct bfa_reqq_wait_s reqq_wait;       /*  to wait for room in reqq */
-       bfa_boolean_t           abort_explicit; /*  aborted by OS            */
-       struct bfa_tskim_s      *tskim;         /*  Relevant TM cmd          */
-};
-
-/**
- * BFA Task management command (initiator mode)
- */
-struct bfa_tskim_s {
-       struct list_head          qe;
-       bfa_sm_t                sm;
-       struct bfa_s            *bfa;        /*  BFA module  */
-       struct bfa_fcpim_mod_s  *fcpim;      /*  parent fcpim module      */
-       struct bfa_itnim_s      *itnim;      /*  i-t-n nexus for this IO  */
-       struct bfad_tskim_s         *dtsk;   /*  driver task mgmt cmnd    */
-       bfa_boolean_t        notify;         /*  notify itnim on TM comp  */
-       lun_t                lun;            /*  lun if applicable        */
-       enum fcp_tm_cmnd        tm_cmnd;     /*  task management command  */
-       u16             tsk_tag;        /*  FWI IO tag               */
-       u8              tsecs;          /*  timeout in seconds       */
-       struct bfa_reqq_wait_s  reqq_wait;   /*  to wait for room in reqq */
-       struct list_head              io_q;    /*  queue of affected IOs    */
-       struct bfa_wc_s             wc;      /*  waiting counter          */
-       struct bfa_cb_qe_s      hcb_qe;      /*  bfa callback qelem       */
-       enum bfi_tskim_status   tsk_status;  /*  TM status                */
-};
-
-/**
- * BFA i-t-n (initiator mode)
- */
-struct bfa_itnim_s {
-       struct list_head    qe;         /*  queue element               */
-       bfa_sm_t          sm;           /*  i-t-n im BFA state machine  */
-       struct bfa_s      *bfa;         /*  bfa instance                */
-       struct bfa_rport_s *rport;      /*  bfa rport                   */
-       void           *ditn;           /*  driver i-t-n structure      */
-       struct bfi_mhdr_s      mhdr;    /*  pre-built mhdr              */
-       u8         msg_no;              /*  itnim/rport firmware handle */
-       u8         reqq;                /*  CQ for requests             */
-       struct bfa_cb_qe_s    hcb_qe;   /*  bfa callback qelem          */
-       struct list_head pending_q;     /*  queue of pending IO requests*/
-       struct list_head io_q;          /*  queue of active IO requests */
-       struct list_head io_cleanup_q;  /*  IO being cleaned up         */
-       struct list_head tsk_q;         /*  queue of active TM commands */
-       struct list_head  delay_comp_q;/*  queue of failed inflight cmds */
-       bfa_boolean_t   seq_rec;        /*  SQER supported              */
-       bfa_boolean_t   is_online;      /*  itnim is ONLINE for IO      */
-       bfa_boolean_t   iotov_active;   /*  IO TOV timer is active       */
-       struct bfa_wc_s        wc;      /*  waiting counter             */
-       struct bfa_timer_s timer;       /*  pending IO TOV               */
-       struct bfa_reqq_wait_s reqq_wait; /*  to wait for room in reqq */
-       struct bfa_fcpim_mod_s *fcpim;  /*  fcpim module                */
-       struct bfa_itnim_hal_stats_s    stats;
-       struct bfa_itnim_latency_s  io_latency;
-};
-
-#define bfa_itnim_is_online(_itnim) ((_itnim)->is_online)
-#define BFA_FCPIM_MOD(_hal) (&(_hal)->modules.fcpim_mod)
-#define BFA_IOIM_FROM_TAG(_fcpim, _iotag)      \
-       (&fcpim->ioim_arr[_iotag])
-#define BFA_TSKIM_FROM_TAG(_fcpim, _tmtag)                  \
-    (&fcpim->tskim_arr[_tmtag & (fcpim->num_tskim_reqs - 1)])
-
-/*
- * function prototypes
- */
-void            bfa_ioim_attach(struct bfa_fcpim_mod_s *fcpim,
-                                   struct bfa_meminfo_s *minfo);
-void            bfa_ioim_detach(struct bfa_fcpim_mod_s *fcpim);
-void            bfa_ioim_isr(struct bfa_s *bfa, struct bfi_msg_s *msg);
-void            bfa_ioim_good_comp_isr(struct bfa_s *bfa,
-                                       struct bfi_msg_s *msg);
-void            bfa_ioim_cleanup(struct bfa_ioim_s *ioim);
-void            bfa_ioim_cleanup_tm(struct bfa_ioim_s *ioim,
-                                       struct bfa_tskim_s *tskim);
-void            bfa_ioim_iocdisable(struct bfa_ioim_s *ioim);
-void            bfa_ioim_tov(struct bfa_ioim_s *ioim);
-
-void            bfa_tskim_attach(struct bfa_fcpim_mod_s *fcpim,
-                                    struct bfa_meminfo_s *minfo);
-void            bfa_tskim_detach(struct bfa_fcpim_mod_s *fcpim);
-void            bfa_tskim_isr(struct bfa_s *bfa, struct bfi_msg_s *msg);
-void            bfa_tskim_iodone(struct bfa_tskim_s *tskim);
-void            bfa_tskim_iocdisable(struct bfa_tskim_s *tskim);
-void            bfa_tskim_cleanup(struct bfa_tskim_s *tskim);
-
-void            bfa_itnim_meminfo(struct bfa_iocfc_cfg_s *cfg, u32 *km_len,
-                                     u32 *dm_len);
-void            bfa_itnim_attach(struct bfa_fcpim_mod_s *fcpim,
-                                    struct bfa_meminfo_s *minfo);
-void            bfa_itnim_detach(struct bfa_fcpim_mod_s *fcpim);
-void            bfa_itnim_iocdisable(struct bfa_itnim_s *itnim);
-void            bfa_itnim_isr(struct bfa_s *bfa, struct bfi_msg_s *msg);
-void            bfa_itnim_iodone(struct bfa_itnim_s *itnim);
-void            bfa_itnim_tskdone(struct bfa_itnim_s *itnim);
-bfa_boolean_t   bfa_itnim_hold_io(struct bfa_itnim_s *itnim);
-
-#endif /* __BFA_FCPIM_PRIV_H__ */
-
diff --git a/drivers/scsi/bfa/bfa_fcport.c b/drivers/scsi/bfa/bfa_fcport.c
deleted file mode 100644 (file)
index 76867b5..0000000
+++ /dev/null
@@ -1,1962 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#include <bfa.h>
-#include <bfa_svc.h>
-#include <bfi/bfi_pport.h>
-#include <bfi/bfi_pbc.h>
-#include <cs/bfa_debug.h>
-#include <aen/bfa_aen.h>
-#include <cs/bfa_plog.h>
-#include <aen/bfa_aen_port.h>
-
-BFA_TRC_FILE(HAL, FCPORT);
-BFA_MODULE(fcport);
-
-/*
- * The port is considered disabled if corresponding physical port or IOC are
- * disabled explicitly
- */
-#define BFA_PORT_IS_DISABLED(bfa) \
-       ((bfa_fcport_is_disabled(bfa) == BFA_TRUE) || \
-       (bfa_ioc_is_disabled(&bfa->ioc) == BFA_TRUE))
-
-/*
- * forward declarations
- */
-static bfa_boolean_t bfa_fcport_send_enable(struct bfa_fcport_s *fcport);
-static bfa_boolean_t bfa_fcport_send_disable(struct bfa_fcport_s *fcport);
-static void     bfa_fcport_update_linkinfo(struct bfa_fcport_s *fcport);
-static void     bfa_fcport_reset_linkinfo(struct bfa_fcport_s *fcport);
-static void     bfa_fcport_set_wwns(struct bfa_fcport_s *fcport);
-static void     __bfa_cb_fcport_event(void *cbarg, bfa_boolean_t complete);
-static void     bfa_fcport_callback(struct bfa_fcport_s *fcport,
-                               enum bfa_pport_linkstate event);
-static void     bfa_fcport_queue_cb(struct bfa_fcport_ln_s *ln,
-                               enum bfa_pport_linkstate event);
-static void     __bfa_cb_fcport_stats_clr(void *cbarg, bfa_boolean_t complete);
-static void     bfa_fcport_stats_get_timeout(void *cbarg);
-static void     bfa_fcport_stats_clr_timeout(void *cbarg);
-
-/**
- *  bfa_pport_private
- */
-
-/**
- * BFA port state machine events
- */
-enum bfa_fcport_sm_event {
-       BFA_FCPORT_SM_START = 1,        /*  start port state machine */
-       BFA_FCPORT_SM_STOP = 2, /*  stop port state machine */
-       BFA_FCPORT_SM_ENABLE = 3,       /*  enable port */
-       BFA_FCPORT_SM_DISABLE = 4,      /*  disable port state machine */
-       BFA_FCPORT_SM_FWRSP = 5,        /*  firmware enable/disable rsp */
-       BFA_FCPORT_SM_LINKUP = 6,       /*  firmware linkup event */
-       BFA_FCPORT_SM_LINKDOWN = 7,     /*  firmware linkup down */
-       BFA_FCPORT_SM_QRESUME = 8,      /*  CQ space available */
-       BFA_FCPORT_SM_HWFAIL = 9,       /*  IOC h/w failure */
-};
-
-/**
- * BFA port link notification state machine events
- */
-
-enum bfa_fcport_ln_sm_event {
-       BFA_FCPORT_LN_SM_LINKUP         = 1,    /*  linkup event */
-       BFA_FCPORT_LN_SM_LINKDOWN       = 2,    /*  linkdown event */
-       BFA_FCPORT_LN_SM_NOTIFICATION   = 3     /*  done notification */
-};
-
-static void     bfa_fcport_sm_uninit(struct bfa_fcport_s *fcport,
-                                       enum bfa_fcport_sm_event event);
-static void     bfa_fcport_sm_enabling_qwait(struct bfa_fcport_s *fcport,
-                                               enum bfa_fcport_sm_event event);
-static void     bfa_fcport_sm_enabling(struct bfa_fcport_s *fcport,
-                                               enum bfa_fcport_sm_event event);
-static void     bfa_fcport_sm_linkdown(struct bfa_fcport_s *fcport,
-                                               enum bfa_fcport_sm_event event);
-static void     bfa_fcport_sm_linkup(struct bfa_fcport_s *fcport,
-                                               enum bfa_fcport_sm_event event);
-static void     bfa_fcport_sm_disabling(struct bfa_fcport_s *fcport,
-                                               enum bfa_fcport_sm_event event);
-static void     bfa_fcport_sm_disabling_qwait(struct bfa_fcport_s *fcport,
-                                               enum bfa_fcport_sm_event event);
-static void     bfa_fcport_sm_disabled(struct bfa_fcport_s *fcport,
-                                               enum bfa_fcport_sm_event event);
-static void     bfa_fcport_sm_stopped(struct bfa_fcport_s *fcport,
-                                        enum bfa_fcport_sm_event event);
-static void     bfa_fcport_sm_iocdown(struct bfa_fcport_s *fcport,
-                                        enum bfa_fcport_sm_event event);
-static void     bfa_fcport_sm_iocfail(struct bfa_fcport_s *fcport,
-                                        enum bfa_fcport_sm_event event);
-
-static void     bfa_fcport_ln_sm_dn(struct bfa_fcport_ln_s *ln,
-                                        enum bfa_fcport_ln_sm_event event);
-static void     bfa_fcport_ln_sm_dn_nf(struct bfa_fcport_ln_s *ln,
-                                        enum bfa_fcport_ln_sm_event event);
-static void     bfa_fcport_ln_sm_dn_up_nf(struct bfa_fcport_ln_s *ln,
-                                        enum bfa_fcport_ln_sm_event event);
-static void     bfa_fcport_ln_sm_up(struct bfa_fcport_ln_s *ln,
-                                        enum bfa_fcport_ln_sm_event event);
-static void     bfa_fcport_ln_sm_up_nf(struct bfa_fcport_ln_s *ln,
-                                        enum bfa_fcport_ln_sm_event event);
-static void     bfa_fcport_ln_sm_up_dn_nf(struct bfa_fcport_ln_s *ln,
-                                        enum bfa_fcport_ln_sm_event event);
-static void     bfa_fcport_ln_sm_up_dn_up_nf(struct bfa_fcport_ln_s *ln,
-                                        enum bfa_fcport_ln_sm_event event);
-
-static struct bfa_sm_table_s hal_pport_sm_table[] = {
-       {BFA_SM(bfa_fcport_sm_uninit), BFA_PPORT_ST_UNINIT},
-       {BFA_SM(bfa_fcport_sm_enabling_qwait), BFA_PPORT_ST_ENABLING_QWAIT},
-       {BFA_SM(bfa_fcport_sm_enabling), BFA_PPORT_ST_ENABLING},
-       {BFA_SM(bfa_fcport_sm_linkdown), BFA_PPORT_ST_LINKDOWN},
-       {BFA_SM(bfa_fcport_sm_linkup), BFA_PPORT_ST_LINKUP},
-       {BFA_SM(bfa_fcport_sm_disabling_qwait), BFA_PPORT_ST_DISABLING_QWAIT},
-       {BFA_SM(bfa_fcport_sm_disabling), BFA_PPORT_ST_DISABLING},
-       {BFA_SM(bfa_fcport_sm_disabled), BFA_PPORT_ST_DISABLED},
-       {BFA_SM(bfa_fcport_sm_stopped), BFA_PPORT_ST_STOPPED},
-       {BFA_SM(bfa_fcport_sm_iocdown), BFA_PPORT_ST_IOCDOWN},
-       {BFA_SM(bfa_fcport_sm_iocfail), BFA_PPORT_ST_IOCDOWN},
-};
-
-static void
-bfa_fcport_aen_post(struct bfa_fcport_s *fcport, enum bfa_port_aen_event event)
-{
-       union bfa_aen_data_u aen_data;
-       struct bfa_log_mod_s *logmod = fcport->bfa->logm;
-       wwn_t           pwwn = fcport->pwwn;
-       char            pwwn_ptr[BFA_STRING_32];
-
-       memset(&aen_data, 0, sizeof(aen_data));
-       wwn2str(pwwn_ptr, pwwn);
-       bfa_log(logmod, BFA_LOG_CREATE_ID(BFA_AEN_CAT_PORT, event), pwwn_ptr);
-
-       aen_data.port.ioc_type = bfa_get_type(fcport->bfa);
-       aen_data.port.pwwn = pwwn;
-}
-
-static void
-bfa_fcport_sm_uninit(struct bfa_fcport_s *fcport,
-                       enum bfa_fcport_sm_event event)
-{
-       bfa_trc(fcport->bfa, event);
-
-       switch (event) {
-       case BFA_FCPORT_SM_START:
-               /**
-                * Start event after IOC is configured and BFA is started.
-                */
-               if (bfa_fcport_send_enable(fcport))
-                       bfa_sm_set_state(fcport, bfa_fcport_sm_enabling);
-               else
-                       bfa_sm_set_state(fcport, bfa_fcport_sm_enabling_qwait);
-               break;
-
-       case BFA_FCPORT_SM_ENABLE:
-               /**
-                * Port is persistently configured to be in enabled state. Do
-                * not change state. Port enabling is done when START event is
-                * received.
-                */
-               break;
-
-       case BFA_FCPORT_SM_DISABLE:
-               /**
-                * If a port is persistently configured to be disabled, the
-                * first event will a port disable request.
-                */
-               bfa_sm_set_state(fcport, bfa_fcport_sm_disabled);
-               break;
-
-       case BFA_FCPORT_SM_HWFAIL:
-               bfa_sm_set_state(fcport, bfa_fcport_sm_iocdown);
-               break;
-
-       default:
-               bfa_sm_fault(fcport->bfa, event);
-       }
-}
-
-static void
-bfa_fcport_sm_enabling_qwait(struct bfa_fcport_s *fcport,
-                           enum bfa_fcport_sm_event event)
-{
-       bfa_trc(fcport->bfa, event);
-
-       switch (event) {
-       case BFA_FCPORT_SM_QRESUME:
-               bfa_sm_set_state(fcport, bfa_fcport_sm_enabling);
-               bfa_fcport_send_enable(fcport);
-               break;
-
-       case BFA_FCPORT_SM_STOP:
-               bfa_reqq_wcancel(&fcport->reqq_wait);
-               bfa_sm_set_state(fcport, bfa_fcport_sm_stopped);
-               break;
-
-       case BFA_FCPORT_SM_ENABLE:
-               /**
-                * Already enable is in progress.
-                */
-               break;
-
-       case BFA_FCPORT_SM_DISABLE:
-               /**
-                * Just send disable request to firmware when room becomes
-                * available in request queue.
-                */
-               bfa_sm_set_state(fcport, bfa_fcport_sm_disabled);
-               bfa_reqq_wcancel(&fcport->reqq_wait);
-               bfa_plog_str(fcport->bfa->plog, BFA_PL_MID_HAL,
-                            BFA_PL_EID_PORT_DISABLE, 0, "Port Disable");
-               bfa_fcport_aen_post(fcport, BFA_PORT_AEN_DISABLE);
-               break;
-
-       case BFA_FCPORT_SM_LINKUP:
-       case BFA_FCPORT_SM_LINKDOWN:
-               /**
-                * Possible to get link events when doing back-to-back
-                * enable/disables.
-                */
-               break;
-
-       case BFA_FCPORT_SM_HWFAIL:
-               bfa_reqq_wcancel(&fcport->reqq_wait);
-               bfa_sm_set_state(fcport, bfa_fcport_sm_iocdown);
-               break;
-
-       default:
-               bfa_sm_fault(fcport->bfa, event);
-       }
-}
-
-static void
-bfa_fcport_sm_enabling(struct bfa_fcport_s *fcport,
-               enum bfa_fcport_sm_event event)
-{
-       bfa_trc(fcport->bfa, event);
-
-       switch (event) {
-       case BFA_FCPORT_SM_FWRSP:
-       case BFA_FCPORT_SM_LINKDOWN:
-               bfa_sm_set_state(fcport, bfa_fcport_sm_linkdown);
-               break;
-
-       case BFA_FCPORT_SM_LINKUP:
-               bfa_fcport_update_linkinfo(fcport);
-               bfa_sm_set_state(fcport, bfa_fcport_sm_linkup);
-
-               bfa_assert(fcport->event_cbfn);
-               bfa_fcport_callback(fcport, BFA_PPORT_LINKUP);
-               break;
-
-       case BFA_FCPORT_SM_ENABLE:
-               /**
-                * Already being enabled.
-                */
-               break;
-
-       case BFA_FCPORT_SM_DISABLE:
-               if (bfa_fcport_send_disable(fcport))
-                       bfa_sm_set_state(fcport, bfa_fcport_sm_disabling);
-               else
-                       bfa_sm_set_state(fcport, bfa_fcport_sm_disabling_qwait);
-
-               bfa_plog_str(fcport->bfa->plog, BFA_PL_MID_HAL,
-                            BFA_PL_EID_PORT_DISABLE, 0, "Port Disable");
-               bfa_fcport_aen_post(fcport, BFA_PORT_AEN_DISABLE);
-               break;
-
-       case BFA_FCPORT_SM_STOP:
-               bfa_sm_set_state(fcport, bfa_fcport_sm_stopped);
-               break;
-
-       case BFA_FCPORT_SM_HWFAIL:
-               bfa_sm_set_state(fcport, bfa_fcport_sm_iocdown);
-               break;
-
-       default:
-               bfa_sm_fault(fcport->bfa, event);
-       }
-}
-
-static void
-bfa_fcport_sm_linkdown(struct bfa_fcport_s *fcport,
-                       enum bfa_fcport_sm_event event)
-{
-       struct bfi_fcport_event_s *pevent = fcport->event_arg.i2hmsg.event;
-       bfa_trc(fcport->bfa, event);
-
-       switch (event) {
-       case BFA_FCPORT_SM_LINKUP:
-               bfa_fcport_update_linkinfo(fcport);
-               bfa_sm_set_state(fcport, bfa_fcport_sm_linkup);
-               bfa_assert(fcport->event_cbfn);
-               bfa_plog_str(fcport->bfa->plog, BFA_PL_MID_HAL,
-                            BFA_PL_EID_PORT_ST_CHANGE, 0, "Port Linkup");
-
-               if (!bfa_ioc_get_fcmode(&fcport->bfa->ioc)) {
-
-                       bfa_trc(fcport->bfa,
-                               pevent->link_state.vc_fcf.fcf.fipenabled);
-                       bfa_trc(fcport->bfa,
-                               pevent->link_state.vc_fcf.fcf.fipfailed);
-
-                       if (pevent->link_state.vc_fcf.fcf.fipfailed)
-                               bfa_plog_str(fcport->bfa->plog, BFA_PL_MID_HAL,
-                                       BFA_PL_EID_FIP_FCF_DISC, 0,
-                                       "FIP FCF Discovery Failed");
-                       else
-                               bfa_plog_str(fcport->bfa->plog, BFA_PL_MID_HAL,
-                                       BFA_PL_EID_FIP_FCF_DISC, 0,
-                                       "FIP FCF Discovered");
-               }
-
-               bfa_fcport_callback(fcport, BFA_PPORT_LINKUP);
-               bfa_fcport_aen_post(fcport, BFA_PORT_AEN_ONLINE);
-               /**
-                * If QoS is enabled and it is not online,
-                * Send a separate event.
-                */
-               if ((fcport->cfg.qos_enabled)
-                   && (bfa_os_ntohl(fcport->qos_attr.state) != BFA_QOS_ONLINE))
-                       bfa_fcport_aen_post(fcport, BFA_PORT_AEN_QOS_NEG);
-
-               break;
-
-       case BFA_FCPORT_SM_LINKDOWN:
-               /**
-                * Possible to get link down event.
-                */
-               break;
-
-       case BFA_FCPORT_SM_ENABLE:
-               /**
-                * Already enabled.
-                */
-               break;
-
-       case BFA_FCPORT_SM_DISABLE:
-               if (bfa_fcport_send_disable(fcport))
-                       bfa_sm_set_state(fcport, bfa_fcport_sm_disabling);
-               else
-                       bfa_sm_set_state(fcport, bfa_fcport_sm_disabling_qwait);
-
-               bfa_plog_str(fcport->bfa->plog, BFA_PL_MID_HAL,
-                            BFA_PL_EID_PORT_DISABLE, 0, "Port Disable");
-               bfa_fcport_aen_post(fcport, BFA_PORT_AEN_DISABLE);
-               break;
-
-       case BFA_FCPORT_SM_STOP:
-               bfa_sm_set_state(fcport, bfa_fcport_sm_stopped);
-               break;
-
-       case BFA_FCPORT_SM_HWFAIL:
-               bfa_sm_set_state(fcport, bfa_fcport_sm_iocdown);
-               break;
-
-       default:
-               bfa_sm_fault(fcport->bfa, event);
-       }
-}
-
-static void
-bfa_fcport_sm_linkup(struct bfa_fcport_s *fcport,
-                       enum bfa_fcport_sm_event event)
-{
-       bfa_trc(fcport->bfa, event);
-
-       switch (event) {
-       case BFA_FCPORT_SM_ENABLE:
-               /**
-                * Already enabled.
-                */
-               break;
-
-       case BFA_FCPORT_SM_DISABLE:
-               if (bfa_fcport_send_disable(fcport))
-                       bfa_sm_set_state(fcport, bfa_fcport_sm_disabling);
-               else
-                       bfa_sm_set_state(fcport, bfa_fcport_sm_disabling_qwait);
-
-               bfa_fcport_reset_linkinfo(fcport);
-               bfa_fcport_callback(fcport, BFA_PPORT_LINKDOWN);
-               bfa_plog_str(fcport->bfa->plog, BFA_PL_MID_HAL,
-                            BFA_PL_EID_PORT_DISABLE, 0, "Port Disable");
-               bfa_fcport_aen_post(fcport, BFA_PORT_AEN_OFFLINE);
-               bfa_fcport_aen_post(fcport, BFA_PORT_AEN_DISABLE);
-               break;
-
-       case BFA_FCPORT_SM_LINKDOWN:
-               bfa_sm_set_state(fcport, bfa_fcport_sm_linkdown);
-               bfa_fcport_reset_linkinfo(fcport);
-               bfa_fcport_callback(fcport, BFA_PPORT_LINKDOWN);
-               bfa_plog_str(fcport->bfa->plog, BFA_PL_MID_HAL,
-                            BFA_PL_EID_PORT_ST_CHANGE, 0, "Port Linkdown");
-               if (BFA_PORT_IS_DISABLED(fcport->bfa))
-                       bfa_fcport_aen_post(fcport, BFA_PORT_AEN_OFFLINE);
-               else
-                       bfa_fcport_aen_post(fcport, BFA_PORT_AEN_DISCONNECT);
-               break;
-
-       case BFA_FCPORT_SM_STOP:
-               bfa_sm_set_state(fcport, bfa_fcport_sm_stopped);
-               bfa_fcport_reset_linkinfo(fcport);
-               if (BFA_PORT_IS_DISABLED(fcport->bfa))
-                       bfa_fcport_aen_post(fcport, BFA_PORT_AEN_OFFLINE);
-               else
-                       bfa_fcport_aen_post(fcport, BFA_PORT_AEN_DISCONNECT);
-               break;
-
-       case BFA_FCPORT_SM_HWFAIL:
-               bfa_sm_set_state(fcport, bfa_fcport_sm_iocdown);
-               bfa_fcport_reset_linkinfo(fcport);
-               bfa_fcport_callback(fcport, BFA_PPORT_LINKDOWN);
-               if (BFA_PORT_IS_DISABLED(fcport->bfa))
-                       bfa_fcport_aen_post(fcport, BFA_PORT_AEN_OFFLINE);
-               else
-                       bfa_fcport_aen_post(fcport, BFA_PORT_AEN_DISCONNECT);
-               break;
-
-       default:
-               bfa_sm_fault(fcport->bfa, event);
-       }
-}
-
-static void
-bfa_fcport_sm_disabling_qwait(struct bfa_fcport_s *fcport,
-                            enum bfa_fcport_sm_event event)
-{
-       bfa_trc(fcport->bfa, event);
-
-       switch (event) {
-       case BFA_FCPORT_SM_QRESUME:
-               bfa_sm_set_state(fcport, bfa_fcport_sm_disabling);
-               bfa_fcport_send_disable(fcport);
-               break;
-
-       case BFA_FCPORT_SM_STOP:
-               bfa_sm_set_state(fcport, bfa_fcport_sm_stopped);
-               bfa_reqq_wcancel(&fcport->reqq_wait);
-               break;
-
-       case BFA_FCPORT_SM_DISABLE:
-               /**
-                * Already being disabled.
-                */
-               break;
-
-       case BFA_FCPORT_SM_LINKUP:
-       case BFA_FCPORT_SM_LINKDOWN:
-               /**
-                * Possible to get link events when doing back-to-back
-                * enable/disables.
-                */
-               break;
-
-       case BFA_FCPORT_SM_HWFAIL:
-               bfa_sm_set_state(fcport, bfa_fcport_sm_iocfail);
-               bfa_reqq_wcancel(&fcport->reqq_wait);
-               break;
-
-       default:
-               bfa_sm_fault(fcport->bfa, event);
-       }
-}
-
-static void
-bfa_fcport_sm_disabling(struct bfa_fcport_s *fcport,
-                       enum bfa_fcport_sm_event event)
-{
-       bfa_trc(fcport->bfa, event);
-
-       switch (event) {
-       case BFA_FCPORT_SM_FWRSP:
-               bfa_sm_set_state(fcport, bfa_fcport_sm_disabled);
-               break;
-
-       case BFA_FCPORT_SM_DISABLE:
-               /**
-                * Already being disabled.
-                */
-               break;
-
-       case BFA_FCPORT_SM_ENABLE:
-               if (bfa_fcport_send_enable(fcport))
-                       bfa_sm_set_state(fcport, bfa_fcport_sm_enabling);
-               else
-                       bfa_sm_set_state(fcport, bfa_fcport_sm_enabling_qwait);
-
-               bfa_plog_str(fcport->bfa->plog, BFA_PL_MID_HAL,
-                            BFA_PL_EID_PORT_ENABLE, 0, "Port Enable");
-               bfa_fcport_aen_post(fcport, BFA_PORT_AEN_ENABLE);
-               break;
-
-       case BFA_FCPORT_SM_STOP:
-               bfa_sm_set_state(fcport, bfa_fcport_sm_stopped);
-               break;
-
-       case BFA_FCPORT_SM_LINKUP:
-       case BFA_FCPORT_SM_LINKDOWN:
-               /**
-                * Possible to get link events when doing back-to-back
-                * enable/disables.
-                */
-               break;
-
-       case BFA_FCPORT_SM_HWFAIL:
-               bfa_sm_set_state(fcport, bfa_fcport_sm_iocfail);
-               break;
-
-       default:
-               bfa_sm_fault(fcport->bfa, event);
-       }
-}
-
-static void
-bfa_fcport_sm_disabled(struct bfa_fcport_s *fcport,
-                       enum bfa_fcport_sm_event event)
-{
-       bfa_trc(fcport->bfa, event);
-
-       switch (event) {
-       case BFA_FCPORT_SM_START:
-               /**
-                * Ignore start event for a port that is disabled.
-                */
-               break;
-
-       case BFA_FCPORT_SM_STOP:
-               bfa_sm_set_state(fcport, bfa_fcport_sm_stopped);
-               break;
-
-       case BFA_FCPORT_SM_ENABLE:
-               if (bfa_fcport_send_enable(fcport))
-                       bfa_sm_set_state(fcport, bfa_fcport_sm_enabling);
-               else
-                       bfa_sm_set_state(fcport, bfa_fcport_sm_enabling_qwait);
-
-               bfa_plog_str(fcport->bfa->plog, BFA_PL_MID_HAL,
-                            BFA_PL_EID_PORT_ENABLE, 0, "Port Enable");
-               bfa_fcport_aen_post(fcport, BFA_PORT_AEN_ENABLE);
-               break;
-
-       case BFA_FCPORT_SM_DISABLE:
-               /**
-                * Already disabled.
-                */
-               break;
-
-       case BFA_FCPORT_SM_HWFAIL:
-               bfa_sm_set_state(fcport, bfa_fcport_sm_iocfail);
-               break;
-
-       default:
-               bfa_sm_fault(fcport->bfa, event);
-       }
-}
-
-static void
-bfa_fcport_sm_stopped(struct bfa_fcport_s *fcport,
-                       enum bfa_fcport_sm_event event)
-{
-       bfa_trc(fcport->bfa, event);
-
-       switch (event) {
-       case BFA_FCPORT_SM_START:
-               if (bfa_fcport_send_enable(fcport))
-                       bfa_sm_set_state(fcport, bfa_fcport_sm_enabling);
-               else
-                       bfa_sm_set_state(fcport, bfa_fcport_sm_enabling_qwait);
-               break;
-
-       default:
-               /**
-                * Ignore all other events.
-                */
-               ;
-       }
-}
-
-/**
- * Port is enabled. IOC is down/failed.
- */
-static void
-bfa_fcport_sm_iocdown(struct bfa_fcport_s *fcport,
-                       enum bfa_fcport_sm_event event)
-{
-       bfa_trc(fcport->bfa, event);
-
-       switch (event) {
-       case BFA_FCPORT_SM_START:
-               if (bfa_fcport_send_enable(fcport))
-                       bfa_sm_set_state(fcport, bfa_fcport_sm_enabling);
-               else
-                       bfa_sm_set_state(fcport, bfa_fcport_sm_enabling_qwait);
-               break;
-
-       default:
-               /**
-                * Ignore all events.
-                */
-               ;
-       }
-}
-
-/**
- * Port is disabled. IOC is down/failed.
- */
-static void
-bfa_fcport_sm_iocfail(struct bfa_fcport_s *fcport,
-                       enum bfa_fcport_sm_event event)
-{
-       bfa_trc(fcport->bfa, event);
-
-       switch (event) {
-       case BFA_FCPORT_SM_START:
-               bfa_sm_set_state(fcport, bfa_fcport_sm_disabled);
-               break;
-
-       case BFA_FCPORT_SM_ENABLE:
-               bfa_sm_set_state(fcport, bfa_fcport_sm_iocdown);
-               break;
-
-       default:
-               /**
-                * Ignore all events.
-                */
-               ;
-       }
-}
-
-/**
- * Link state is down
- */
-static void
-bfa_fcport_ln_sm_dn(struct bfa_fcport_ln_s *ln,
-               enum bfa_fcport_ln_sm_event event)
-{
-       bfa_trc(ln->fcport->bfa, event);
-
-       switch (event) {
-       case BFA_FCPORT_LN_SM_LINKUP:
-               bfa_sm_set_state(ln, bfa_fcport_ln_sm_up_nf);
-               bfa_fcport_queue_cb(ln, BFA_PPORT_LINKUP);
-               break;
-
-       default:
-               bfa_sm_fault(ln->fcport->bfa, event);
-       }
-}
-
-/**
- * Link state is waiting for down notification
- */
-static void
-bfa_fcport_ln_sm_dn_nf(struct bfa_fcport_ln_s *ln,
-               enum bfa_fcport_ln_sm_event event)
-{
-       bfa_trc(ln->fcport->bfa, event);
-
-       switch (event) {
-       case BFA_FCPORT_LN_SM_LINKUP:
-               bfa_sm_set_state(ln, bfa_fcport_ln_sm_dn_up_nf);
-               break;
-
-       case BFA_FCPORT_LN_SM_NOTIFICATION:
-               bfa_sm_set_state(ln, bfa_fcport_ln_sm_dn);
-               break;
-
-       default:
-               bfa_sm_fault(ln->fcport->bfa, event);
-       }
-}
-
-/**
- * Link state is waiting for down notification and there is a pending up
- */
-static void
-bfa_fcport_ln_sm_dn_up_nf(struct bfa_fcport_ln_s *ln,
-               enum bfa_fcport_ln_sm_event event)
-{
-       bfa_trc(ln->fcport->bfa, event);
-
-       switch (event) {
-       case BFA_FCPORT_LN_SM_LINKDOWN:
-               bfa_sm_set_state(ln, bfa_fcport_ln_sm_dn_nf);
-               break;
-
-       case BFA_FCPORT_LN_SM_NOTIFICATION:
-               bfa_sm_set_state(ln, bfa_fcport_ln_sm_up_nf);
-               bfa_fcport_queue_cb(ln, BFA_PPORT_LINKUP);
-               break;
-
-       default:
-               bfa_sm_fault(ln->fcport->bfa, event);
-       }
-}
-
-/**
- * Link state is up
- */
-static void
-bfa_fcport_ln_sm_up(struct bfa_fcport_ln_s *ln,
-               enum bfa_fcport_ln_sm_event event)
-{
-       bfa_trc(ln->fcport->bfa, event);
-
-       switch (event) {
-       case BFA_FCPORT_LN_SM_LINKDOWN:
-               bfa_sm_set_state(ln, bfa_fcport_ln_sm_dn_nf);
-               bfa_fcport_queue_cb(ln, BFA_PPORT_LINKDOWN);
-               break;
-
-       default:
-               bfa_sm_fault(ln->fcport->bfa, event);
-       }
-}
-
-/**
- * Link state is waiting for up notification
- */
-static void
-bfa_fcport_ln_sm_up_nf(struct bfa_fcport_ln_s *ln,
-               enum bfa_fcport_ln_sm_event event)
-{
-       bfa_trc(ln->fcport->bfa, event);
-
-       switch (event) {
-       case BFA_FCPORT_LN_SM_LINKDOWN:
-               bfa_sm_set_state(ln, bfa_fcport_ln_sm_up_dn_nf);
-               break;
-
-       case BFA_FCPORT_LN_SM_NOTIFICATION:
-               bfa_sm_set_state(ln, bfa_fcport_ln_sm_up);
-               break;
-
-       default:
-               bfa_sm_fault(ln->fcport->bfa, event);
-       }
-}
-
-/**
- * Link state is waiting for up notification and there is a pending down
- */
-static void
-bfa_fcport_ln_sm_up_dn_nf(struct bfa_fcport_ln_s *ln,
-               enum bfa_fcport_ln_sm_event event)
-{
-       bfa_trc(ln->fcport->bfa, event);
-
-       switch (event) {
-       case BFA_FCPORT_LN_SM_LINKUP:
-               bfa_sm_set_state(ln, bfa_fcport_ln_sm_up_dn_up_nf);
-               break;
-
-       case BFA_FCPORT_LN_SM_NOTIFICATION:
-               bfa_sm_set_state(ln, bfa_fcport_ln_sm_dn_nf);
-               bfa_fcport_queue_cb(ln, BFA_PPORT_LINKDOWN);
-               break;
-
-       default:
-               bfa_sm_fault(ln->fcport->bfa, event);
-       }
-}
-
-/**
- * Link state is waiting for up notification and there are pending down and up
- */
-static void
-bfa_fcport_ln_sm_up_dn_up_nf(struct bfa_fcport_ln_s *ln,
-                       enum bfa_fcport_ln_sm_event event)
-{
-       bfa_trc(ln->fcport->bfa, event);
-
-       switch (event) {
-       case BFA_FCPORT_LN_SM_LINKDOWN:
-               bfa_sm_set_state(ln, bfa_fcport_ln_sm_up_dn_nf);
-               break;
-
-       case BFA_FCPORT_LN_SM_NOTIFICATION:
-               bfa_sm_set_state(ln, bfa_fcport_ln_sm_dn_up_nf);
-               bfa_fcport_queue_cb(ln, BFA_PPORT_LINKDOWN);
-               break;
-
-       default:
-               bfa_sm_fault(ln->fcport->bfa, event);
-       }
-}
-
-/**
- *  bfa_pport_private
- */
-
-static void
-__bfa_cb_fcport_event(void *cbarg, bfa_boolean_t complete)
-{
-       struct bfa_fcport_ln_s *ln = cbarg;
-
-       if (complete)
-               ln->fcport->event_cbfn(ln->fcport->event_cbarg, ln->ln_event);
-       else
-               bfa_sm_send_event(ln, BFA_FCPORT_LN_SM_NOTIFICATION);
-}
-
-static void
-bfa_fcport_callback(struct bfa_fcport_s *fcport, enum bfa_pport_linkstate event)
-{
-       if (fcport->bfa->fcs) {
-               fcport->event_cbfn(fcport->event_cbarg, event);
-               return;
-       }
-
-       switch (event) {
-       case BFA_PPORT_LINKUP:
-               bfa_sm_send_event(&fcport->ln, BFA_FCPORT_LN_SM_LINKUP);
-               break;
-       case BFA_PPORT_LINKDOWN:
-               bfa_sm_send_event(&fcport->ln, BFA_FCPORT_LN_SM_LINKDOWN);
-               break;
-       default:
-               bfa_assert(0);
-       }
-}
-
-static void
-bfa_fcport_queue_cb(struct bfa_fcport_ln_s *ln, enum bfa_pport_linkstate event)
-{
-       ln->ln_event = event;
-       bfa_cb_queue(ln->fcport->bfa, &ln->ln_qe, __bfa_cb_fcport_event, ln);
-}
-
-#define FCPORT_STATS_DMA_SZ (BFA_ROUNDUP(sizeof(union bfa_fcport_stats_u), \
-                                                       BFA_CACHELINE_SZ))
-
-static void
-bfa_fcport_meminfo(struct bfa_iocfc_cfg_s *cfg, u32 *ndm_len,
-                 u32 *dm_len)
-{
-       *dm_len += FCPORT_STATS_DMA_SZ;
-}
-
-static void
-bfa_fcport_qresume(void *cbarg)
-{
-       struct bfa_fcport_s *fcport = cbarg;
-
-       bfa_sm_send_event(fcport, BFA_FCPORT_SM_QRESUME);
-}
-
-static void
-bfa_fcport_mem_claim(struct bfa_fcport_s *fcport, struct bfa_meminfo_s *meminfo)
-{
-       u8        *dm_kva;
-       u64        dm_pa;
-
-       dm_kva = bfa_meminfo_dma_virt(meminfo);
-       dm_pa = bfa_meminfo_dma_phys(meminfo);
-
-       fcport->stats_kva = dm_kva;
-       fcport->stats_pa = dm_pa;
-       fcport->stats = (union bfa_fcport_stats_u *)dm_kva;
-
-       dm_kva += FCPORT_STATS_DMA_SZ;
-       dm_pa += FCPORT_STATS_DMA_SZ;
-
-       bfa_meminfo_dma_virt(meminfo) = dm_kva;
-       bfa_meminfo_dma_phys(meminfo) = dm_pa;
-}
-
-/**
- * Memory initialization.
- */
-static void
-bfa_fcport_attach(struct bfa_s *bfa, void *bfad, struct bfa_iocfc_cfg_s *cfg,
-                struct bfa_meminfo_s *meminfo, struct bfa_pcidev_s *pcidev)
-{
-       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
-       struct bfa_pport_cfg_s *port_cfg = &fcport->cfg;
-       struct bfa_fcport_ln_s *ln = &fcport->ln;
-       struct bfa_timeval_s tv;
-
-       bfa_os_memset(fcport, 0, sizeof(struct bfa_fcport_s));
-       fcport->bfa = bfa;
-       ln->fcport = fcport;
-
-       bfa_fcport_mem_claim(fcport, meminfo);
-
-       bfa_sm_set_state(fcport, bfa_fcport_sm_uninit);
-       bfa_sm_set_state(ln, bfa_fcport_ln_sm_dn);
-
-       /**
-        * initialize time stamp for stats reset
-        */
-       bfa_os_gettimeofday(&tv);
-       fcport->stats_reset_time = tv.tv_sec;
-
-       /**
-        * initialize and set default configuration
-        */
-       port_cfg->topology = BFA_PPORT_TOPOLOGY_P2P;
-       port_cfg->speed = BFA_PPORT_SPEED_AUTO;
-       port_cfg->trunked = BFA_FALSE;
-       port_cfg->maxfrsize = 0;
-
-       port_cfg->trl_def_speed = BFA_PPORT_SPEED_1GBPS;
-
-       bfa_reqq_winit(&fcport->reqq_wait, bfa_fcport_qresume, fcport);
-}
-
-static void
-bfa_fcport_detach(struct bfa_s *bfa)
-{
-}
-
-/**
- * Called when IOC is ready.
- */
-static void
-bfa_fcport_start(struct bfa_s *bfa)
-{
-       bfa_sm_send_event(BFA_FCPORT_MOD(bfa), BFA_FCPORT_SM_START);
-}
-
-/**
- * Called before IOC is stopped.
- */
-static void
-bfa_fcport_stop(struct bfa_s *bfa)
-{
-       bfa_sm_send_event(BFA_FCPORT_MOD(bfa), BFA_FCPORT_SM_STOP);
-}
-
-/**
- * Called when IOC failure is detected.
- */
-static void
-bfa_fcport_iocdisable(struct bfa_s *bfa)
-{
-       bfa_sm_send_event(BFA_FCPORT_MOD(bfa), BFA_FCPORT_SM_HWFAIL);
-}
-
-static void
-bfa_fcport_update_linkinfo(struct bfa_fcport_s *fcport)
-{
-       struct bfi_fcport_event_s *pevent = fcport->event_arg.i2hmsg.event;
-
-       fcport->speed = pevent->link_state.speed;
-       fcport->topology = pevent->link_state.topology;
-
-       if (fcport->topology == BFA_PPORT_TOPOLOGY_LOOP)
-               fcport->myalpa = 0;
-
-       /*
-        * QoS Details
-        */
-       bfa_os_assign(fcport->qos_attr, pevent->link_state.qos_attr);
-       bfa_os_assign(fcport->qos_vc_attr,
-               pevent->link_state.vc_fcf.qos_vc_attr);
-
-
-       bfa_trc(fcport->bfa, fcport->speed);
-       bfa_trc(fcport->bfa, fcport->topology);
-}
-
-static void
-bfa_fcport_reset_linkinfo(struct bfa_fcport_s *fcport)
-{
-       fcport->speed = BFA_PPORT_SPEED_UNKNOWN;
-       fcport->topology = BFA_PPORT_TOPOLOGY_NONE;
-}
-
-/**
- * Send port enable message to firmware.
- */
-static          bfa_boolean_t
-bfa_fcport_send_enable(struct bfa_fcport_s *fcport)
-{
-       struct bfi_fcport_enable_req_s *m;
-
-       /**
-        * Increment message tag before queue check, so that responses to old
-        * requests are discarded.
-        */
-       fcport->msgtag++;
-
-       /**
-        * check for room in queue to send request now
-        */
-       m = bfa_reqq_next(fcport->bfa, BFA_REQQ_PORT);
-       if (!m) {
-               bfa_reqq_wait(fcport->bfa, BFA_REQQ_PORT,
-                                                       &fcport->reqq_wait);
-               return BFA_FALSE;
-       }
-
-       bfi_h2i_set(m->mh, BFI_MC_FCPORT, BFI_FCPORT_H2I_ENABLE_REQ,
-                               bfa_lpuid(fcport->bfa));
-       m->nwwn = fcport->nwwn;
-       m->pwwn = fcport->pwwn;
-       m->port_cfg = fcport->cfg;
-       m->msgtag = fcport->msgtag;
-       m->port_cfg.maxfrsize = bfa_os_htons(fcport->cfg.maxfrsize);
-       bfa_dma_be_addr_set(m->stats_dma_addr, fcport->stats_pa);
-       bfa_trc(fcport->bfa, m->stats_dma_addr.a32.addr_lo);
-       bfa_trc(fcport->bfa, m->stats_dma_addr.a32.addr_hi);
-
-       /**
-        * queue I/O message to firmware
-        */
-       bfa_reqq_produce(fcport->bfa, BFA_REQQ_PORT);
-       return BFA_TRUE;
-}
-
-/**
- * Send port disable message to firmware.
- */
-static          bfa_boolean_t
-bfa_fcport_send_disable(struct bfa_fcport_s *fcport)
-{
-       struct bfi_fcport_req_s *m;
-
-       /**
-        * Increment message tag before queue check, so that responses to old
-        * requests are discarded.
-        */
-       fcport->msgtag++;
-
-       /**
-        * check for room in queue to send request now
-        */
-       m = bfa_reqq_next(fcport->bfa, BFA_REQQ_PORT);
-       if (!m) {
-               bfa_reqq_wait(fcport->bfa, BFA_REQQ_PORT,
-                                                       &fcport->reqq_wait);
-               return BFA_FALSE;
-       }
-
-       bfi_h2i_set(m->mh, BFI_MC_FCPORT, BFI_FCPORT_H2I_DISABLE_REQ,
-                       bfa_lpuid(fcport->bfa));
-       m->msgtag = fcport->msgtag;
-
-       /**
-        * queue I/O message to firmware
-        */
-       bfa_reqq_produce(fcport->bfa, BFA_REQQ_PORT);
-
-       return BFA_TRUE;
-}
-
-static void
-bfa_fcport_set_wwns(struct bfa_fcport_s *fcport)
-{
-       fcport->pwwn = bfa_ioc_get_pwwn(&fcport->bfa->ioc);
-       fcport->nwwn = bfa_ioc_get_nwwn(&fcport->bfa->ioc);
-
-       bfa_trc(fcport->bfa, fcport->pwwn);
-       bfa_trc(fcport->bfa, fcport->nwwn);
-}
-
-static void
-bfa_fcport_send_txcredit(void *port_cbarg)
-{
-
-       struct bfa_fcport_s *fcport = port_cbarg;
-       struct bfi_fcport_set_svc_params_req_s *m;
-
-       /**
-        * check for room in queue to send request now
-        */
-       m = bfa_reqq_next(fcport->bfa, BFA_REQQ_PORT);
-       if (!m) {
-               bfa_trc(fcport->bfa, fcport->cfg.tx_bbcredit);
-               return;
-       }
-
-       bfi_h2i_set(m->mh, BFI_MC_FCPORT, BFI_FCPORT_H2I_SET_SVC_PARAMS_REQ,
-                       bfa_lpuid(fcport->bfa));
-       m->tx_bbcredit = bfa_os_htons((u16) fcport->cfg.tx_bbcredit);
-
-       /**
-        * queue I/O message to firmware
-        */
-       bfa_reqq_produce(fcport->bfa, BFA_REQQ_PORT);
-}
-
-static void
-bfa_fcport_qos_stats_swap(struct bfa_qos_stats_s *d,
-       struct bfa_qos_stats_s *s)
-{
-       u32     *dip = (u32 *) d;
-       u32     *sip = (u32 *) s;
-       int             i;
-
-       /* Now swap the 32 bit fields */
-       for (i = 0; i < (sizeof(struct bfa_qos_stats_s)/sizeof(u32)); ++i)
-               dip[i] = bfa_os_ntohl(sip[i]);
-}
-
-static void
-bfa_fcport_fcoe_stats_swap(struct bfa_fcoe_stats_s *d,
-       struct bfa_fcoe_stats_s *s)
-{
-       u32     *dip = (u32 *) d;
-       u32     *sip = (u32 *) s;
-       int             i;
-
-       for (i = 0; i < ((sizeof(struct bfa_fcoe_stats_s))/sizeof(u32));
-               i = i + 2) {
-#ifdef __BIGENDIAN
-               dip[i] = bfa_os_ntohl(sip[i]);
-               dip[i + 1] = bfa_os_ntohl(sip[i + 1]);
-#else
-               dip[i] = bfa_os_ntohl(sip[i + 1]);
-               dip[i + 1] = bfa_os_ntohl(sip[i]);
-#endif
-       }
-}
-
-static void
-__bfa_cb_fcport_stats_get(void *cbarg, bfa_boolean_t complete)
-{
-       struct bfa_fcport_s *fcport = cbarg;
-
-       if (complete) {
-               if (fcport->stats_status == BFA_STATUS_OK) {
-                       struct bfa_timeval_s tv;
-
-                       /* Swap FC QoS or FCoE stats */
-                       if (bfa_ioc_get_fcmode(&fcport->bfa->ioc)) {
-                               bfa_fcport_qos_stats_swap(
-                                       &fcport->stats_ret->fcqos,
-                                       &fcport->stats->fcqos);
-                       } else {
-                               bfa_fcport_fcoe_stats_swap(
-                                       &fcport->stats_ret->fcoe,
-                                       &fcport->stats->fcoe);
-
-                               bfa_os_gettimeofday(&tv);
-                               fcport->stats_ret->fcoe.secs_reset =
-                                       tv.tv_sec - fcport->stats_reset_time;
-                       }
-               }
-               fcport->stats_cbfn(fcport->stats_cbarg, fcport->stats_status);
-       } else {
-               fcport->stats_busy = BFA_FALSE;
-               fcport->stats_status = BFA_STATUS_OK;
-       }
-}
-
-static void
-bfa_fcport_stats_get_timeout(void *cbarg)
-{
-       struct bfa_fcport_s *fcport = (struct bfa_fcport_s *) cbarg;
-
-       bfa_trc(fcport->bfa, fcport->stats_qfull);
-
-       if (fcport->stats_qfull) {
-               bfa_reqq_wcancel(&fcport->stats_reqq_wait);
-               fcport->stats_qfull = BFA_FALSE;
-       }
-
-       fcport->stats_status = BFA_STATUS_ETIMER;
-       bfa_cb_queue(fcport->bfa, &fcport->hcb_qe, __bfa_cb_fcport_stats_get,
-               fcport);
-}
-
-static void
-bfa_fcport_send_stats_get(void *cbarg)
-{
-       struct bfa_fcport_s *fcport = (struct bfa_fcport_s *) cbarg;
-       struct bfi_fcport_req_s *msg;
-
-       msg = bfa_reqq_next(fcport->bfa, BFA_REQQ_PORT);
-
-       if (!msg) {
-               fcport->stats_qfull = BFA_TRUE;
-               bfa_reqq_winit(&fcport->stats_reqq_wait,
-                               bfa_fcport_send_stats_get, fcport);
-               bfa_reqq_wait(fcport->bfa, BFA_REQQ_PORT,
-                               &fcport->stats_reqq_wait);
-               return;
-       }
-       fcport->stats_qfull = BFA_FALSE;
-
-       bfa_os_memset(msg, 0, sizeof(struct bfi_fcport_req_s));
-       bfi_h2i_set(msg->mh, BFI_MC_FCPORT, BFI_FCPORT_H2I_STATS_GET_REQ,
-               bfa_lpuid(fcport->bfa));
-       bfa_reqq_produce(fcport->bfa, BFA_REQQ_PORT);
-}
-
-static void
-__bfa_cb_fcport_stats_clr(void *cbarg, bfa_boolean_t complete)
-{
-       struct bfa_fcport_s *fcport = cbarg;
-
-       if (complete) {
-               struct bfa_timeval_s tv;
-
-               /**
-                * re-initialize time stamp for stats reset
-                */
-               bfa_os_gettimeofday(&tv);
-               fcport->stats_reset_time = tv.tv_sec;
-
-               fcport->stats_cbfn(fcport->stats_cbarg, fcport->stats_status);
-       } else {
-               fcport->stats_busy = BFA_FALSE;
-               fcport->stats_status = BFA_STATUS_OK;
-       }
-}
-
-static void
-bfa_fcport_stats_clr_timeout(void *cbarg)
-{
-       struct bfa_fcport_s *fcport = (struct bfa_fcport_s *) cbarg;
-
-       bfa_trc(fcport->bfa, fcport->stats_qfull);
-
-       if (fcport->stats_qfull) {
-               bfa_reqq_wcancel(&fcport->stats_reqq_wait);
-               fcport->stats_qfull = BFA_FALSE;
-       }
-
-       fcport->stats_status = BFA_STATUS_ETIMER;
-       bfa_cb_queue(fcport->bfa, &fcport->hcb_qe,
-                       __bfa_cb_fcport_stats_clr, fcport);
-}
-
-static void
-bfa_fcport_send_stats_clear(void *cbarg)
-{
-       struct bfa_fcport_s *fcport = (struct bfa_fcport_s *) cbarg;
-       struct bfi_fcport_req_s *msg;
-
-       msg = bfa_reqq_next(fcport->bfa, BFA_REQQ_PORT);
-
-       if (!msg) {
-               fcport->stats_qfull = BFA_TRUE;
-               bfa_reqq_winit(&fcport->stats_reqq_wait,
-                               bfa_fcport_send_stats_clear, fcport);
-               bfa_reqq_wait(fcport->bfa, BFA_REQQ_PORT,
-                               &fcport->stats_reqq_wait);
-               return;
-       }
-       fcport->stats_qfull = BFA_FALSE;
-
-       bfa_os_memset(msg, 0, sizeof(struct bfi_fcport_req_s));
-       bfi_h2i_set(msg->mh, BFI_MC_FCPORT, BFI_FCPORT_H2I_STATS_CLEAR_REQ,
-                       bfa_lpuid(fcport->bfa));
-       bfa_reqq_produce(fcport->bfa, BFA_REQQ_PORT);
-}
-
-/**
- *  bfa_pport_public
- */
-
-/**
- * Called to initialize port attributes
- */
-void
-bfa_fcport_init(struct bfa_s *bfa)
-{
-       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
-
-       /**
-        * Initialize port attributes from IOC hardware data.
-        */
-       bfa_fcport_set_wwns(fcport);
-       if (fcport->cfg.maxfrsize == 0)
-               fcport->cfg.maxfrsize = bfa_ioc_maxfrsize(&bfa->ioc);
-       fcport->cfg.rx_bbcredit = bfa_ioc_rx_bbcredit(&bfa->ioc);
-       fcport->speed_sup = bfa_ioc_speed_sup(&bfa->ioc);
-
-       bfa_assert(fcport->cfg.maxfrsize);
-       bfa_assert(fcport->cfg.rx_bbcredit);
-       bfa_assert(fcport->speed_sup);
-}
-
-
-/**
- * Firmware message handler.
- */
-void
-bfa_fcport_isr(struct bfa_s *bfa, struct bfi_msg_s *msg)
-{
-       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
-       union bfi_fcport_i2h_msg_u i2hmsg;
-
-       i2hmsg.msg = msg;
-       fcport->event_arg.i2hmsg = i2hmsg;
-
-       switch (msg->mhdr.msg_id) {
-       case BFI_FCPORT_I2H_ENABLE_RSP:
-               if (fcport->msgtag == i2hmsg.penable_rsp->msgtag)
-                       bfa_sm_send_event(fcport, BFA_FCPORT_SM_FWRSP);
-               break;
-
-       case BFI_FCPORT_I2H_DISABLE_RSP:
-               if (fcport->msgtag == i2hmsg.pdisable_rsp->msgtag)
-                       bfa_sm_send_event(fcport, BFA_FCPORT_SM_FWRSP);
-               break;
-
-       case BFI_FCPORT_I2H_EVENT:
-               switch (i2hmsg.event->link_state.linkstate) {
-               case BFA_PPORT_LINKUP:
-                       bfa_sm_send_event(fcport, BFA_FCPORT_SM_LINKUP);
-                       break;
-               case BFA_PPORT_LINKDOWN:
-                       bfa_sm_send_event(fcport, BFA_FCPORT_SM_LINKDOWN);
-                       break;
-               case BFA_PPORT_TRUNK_LINKDOWN:
-                       /** todo: event notification */
-                       break;
-               }
-               break;
-
-       case BFI_FCPORT_I2H_STATS_GET_RSP:
-               /*
-                * check for timer pop before processing the rsp
-                */
-               if (fcport->stats_busy == BFA_FALSE ||
-                       fcport->stats_status == BFA_STATUS_ETIMER)
-                       break;
-
-               bfa_timer_stop(&fcport->timer);
-               fcport->stats_status = i2hmsg.pstatsget_rsp->status;
-               bfa_cb_queue(fcport->bfa, &fcport->hcb_qe,
-                               __bfa_cb_fcport_stats_get, fcport);
-               break;
-
-       case BFI_FCPORT_I2H_STATS_CLEAR_RSP:
-               /*
-                * check for timer pop before processing the rsp
-                */
-               if (fcport->stats_busy == BFA_FALSE ||
-                       fcport->stats_status == BFA_STATUS_ETIMER)
-                       break;
-
-               bfa_timer_stop(&fcport->timer);
-               fcport->stats_status = BFA_STATUS_OK;
-               bfa_cb_queue(fcport->bfa, &fcport->hcb_qe,
-                               __bfa_cb_fcport_stats_clr, fcport);
-               break;
-
-       default:
-               bfa_assert(0);
-       break;
-       }
-}
-
-/**
- *  bfa_pport_api
- */
-
-/**
- * Registered callback for port events.
- */
-void
-bfa_fcport_event_register(struct bfa_s *bfa,
-                        void (*cbfn) (void *cbarg, bfa_pport_event_t event),
-                        void *cbarg)
-{
-       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
-
-       fcport->event_cbfn = cbfn;
-       fcport->event_cbarg = cbarg;
-}
-
-bfa_status_t
-bfa_fcport_enable(struct bfa_s *bfa)
-{
-       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
-       struct bfa_iocfc_s *iocfc = &bfa->iocfc;
-       struct bfi_iocfc_cfgrsp_s *cfgrsp = iocfc->cfgrsp;
-
-       /* if port is PBC disabled, return error */
-       if (cfgrsp->pbc_cfg.port_enabled == BFI_PBC_PORT_DISABLED) {
-               bfa_trc(bfa, fcport->pwwn);
-               return BFA_STATUS_PBC;
-       }
-
-       if (bfa_ioc_is_disabled(&bfa->ioc))
-               return BFA_STATUS_IOC_DISABLED;
-
-       if (fcport->diag_busy)
-               return BFA_STATUS_DIAG_BUSY;
-       else if (bfa_sm_cmp_state
-                (BFA_FCPORT_MOD(bfa), bfa_fcport_sm_disabling_qwait))
-               return BFA_STATUS_DEVBUSY;
-
-       bfa_sm_send_event(BFA_FCPORT_MOD(bfa), BFA_FCPORT_SM_ENABLE);
-       return BFA_STATUS_OK;
-}
-
-bfa_status_t
-bfa_fcport_disable(struct bfa_s *bfa)
-{
-       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
-       struct bfa_iocfc_s *iocfc = &bfa->iocfc;
-       struct bfi_iocfc_cfgrsp_s *cfgrsp = iocfc->cfgrsp;
-
-       /* if port is PBC disabled, return error */
-       if (cfgrsp->pbc_cfg.port_enabled == BFI_PBC_PORT_DISABLED) {
-               bfa_trc(bfa, fcport->pwwn);
-               return BFA_STATUS_PBC;
-       }
-
-       bfa_sm_send_event(BFA_FCPORT_MOD(bfa), BFA_FCPORT_SM_DISABLE);
-       return BFA_STATUS_OK;
-}
-
-/**
- * Configure port speed.
- */
-bfa_status_t
-bfa_fcport_cfg_speed(struct bfa_s *bfa, enum bfa_pport_speed speed)
-{
-       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
-
-       bfa_trc(bfa, speed);
-
-       if ((speed != BFA_PPORT_SPEED_AUTO) && (speed > fcport->speed_sup)) {
-               bfa_trc(bfa, fcport->speed_sup);
-               return BFA_STATUS_UNSUPP_SPEED;
-       }
-
-       fcport->cfg.speed = speed;
-
-       return BFA_STATUS_OK;
-}
-
-/**
- * Get current speed.
- */
-enum bfa_pport_speed
-bfa_fcport_get_speed(struct bfa_s *bfa)
-{
-       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
-
-       return fcport->speed;
-}
-
-/**
- * Configure port topology.
- */
-bfa_status_t
-bfa_fcport_cfg_topology(struct bfa_s *bfa, enum bfa_pport_topology topology)
-{
-       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
-
-       bfa_trc(bfa, topology);
-       bfa_trc(bfa, fcport->cfg.topology);
-
-       switch (topology) {
-       case BFA_PPORT_TOPOLOGY_P2P:
-       case BFA_PPORT_TOPOLOGY_LOOP:
-       case BFA_PPORT_TOPOLOGY_AUTO:
-               break;
-
-       default:
-               return BFA_STATUS_EINVAL;
-       }
-
-       fcport->cfg.topology = topology;
-       return BFA_STATUS_OK;
-}
-
-/**
- * Get current topology.
- */
-enum bfa_pport_topology
-bfa_fcport_get_topology(struct bfa_s *bfa)
-{
-       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
-
-       return fcport->topology;
-}
-
-bfa_status_t
-bfa_fcport_cfg_hardalpa(struct bfa_s *bfa, u8 alpa)
-{
-       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
-
-       bfa_trc(bfa, alpa);
-       bfa_trc(bfa, fcport->cfg.cfg_hardalpa);
-       bfa_trc(bfa, fcport->cfg.hardalpa);
-
-       fcport->cfg.cfg_hardalpa = BFA_TRUE;
-       fcport->cfg.hardalpa = alpa;
-
-       return BFA_STATUS_OK;
-}
-
-bfa_status_t
-bfa_fcport_clr_hardalpa(struct bfa_s *bfa)
-{
-       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
-
-       bfa_trc(bfa, fcport->cfg.cfg_hardalpa);
-       bfa_trc(bfa, fcport->cfg.hardalpa);
-
-       fcport->cfg.cfg_hardalpa = BFA_FALSE;
-       return BFA_STATUS_OK;
-}
-
-bfa_boolean_t
-bfa_fcport_get_hardalpa(struct bfa_s *bfa, u8 *alpa)
-{
-       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
-
-       *alpa = fcport->cfg.hardalpa;
-       return fcport->cfg.cfg_hardalpa;
-}
-
-u8
-bfa_fcport_get_myalpa(struct bfa_s *bfa)
-{
-       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
-
-       return fcport->myalpa;
-}
-
-bfa_status_t
-bfa_fcport_cfg_maxfrsize(struct bfa_s *bfa, u16 maxfrsize)
-{
-       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
-
-       bfa_trc(bfa, maxfrsize);
-       bfa_trc(bfa, fcport->cfg.maxfrsize);
-
-       /*
-        * with in range
-        */
-       if ((maxfrsize > FC_MAX_PDUSZ) || (maxfrsize < FC_MIN_PDUSZ))
-               return BFA_STATUS_INVLD_DFSZ;
-
-       /*
-        * power of 2, if not the max frame size of 2112
-        */
-       if ((maxfrsize != FC_MAX_PDUSZ) && (maxfrsize & (maxfrsize - 1)))
-               return BFA_STATUS_INVLD_DFSZ;
-
-       fcport->cfg.maxfrsize = maxfrsize;
-       return BFA_STATUS_OK;
-}
-
-u16
-bfa_fcport_get_maxfrsize(struct bfa_s *bfa)
-{
-       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
-
-       return fcport->cfg.maxfrsize;
-}
-
-u32
-bfa_fcport_mypid(struct bfa_s *bfa)
-{
-       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
-
-       return fcport->mypid;
-}
-
-u8
-bfa_fcport_get_rx_bbcredit(struct bfa_s *bfa)
-{
-       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
-
-       return fcport->cfg.rx_bbcredit;
-}
-
-void
-bfa_fcport_set_tx_bbcredit(struct bfa_s *bfa, u16 tx_bbcredit)
-{
-       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
-
-       fcport->cfg.tx_bbcredit = (u8) tx_bbcredit;
-       bfa_fcport_send_txcredit(fcport);
-}
-
-/**
- * Get port attributes.
- */
-
-wwn_t
-bfa_fcport_get_wwn(struct bfa_s *bfa, bfa_boolean_t node)
-{
-       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
-       if (node)
-               return fcport->nwwn;
-       else
-               return fcport->pwwn;
-}
-
-void
-bfa_fcport_get_attr(struct bfa_s *bfa, struct bfa_pport_attr_s *attr)
-{
-       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
-       struct bfa_iocfc_s *iocfc = &bfa->iocfc;
-       struct bfi_iocfc_cfgrsp_s *cfgrsp = iocfc->cfgrsp;
-
-       bfa_os_memset(attr, 0, sizeof(struct bfa_pport_attr_s));
-
-       attr->nwwn = fcport->nwwn;
-       attr->pwwn = fcport->pwwn;
-
-       attr->factorypwwn =  bfa_ioc_get_mfg_pwwn(&bfa->ioc);
-       attr->factorynwwn =  bfa_ioc_get_mfg_nwwn(&bfa->ioc);
-
-       bfa_os_memcpy(&attr->pport_cfg, &fcport->cfg,
-                     sizeof(struct bfa_pport_cfg_s));
-       /*
-        * speed attributes
-        */
-       attr->pport_cfg.speed = fcport->cfg.speed;
-       attr->speed_supported = fcport->speed_sup;
-       attr->speed = fcport->speed;
-       attr->cos_supported = FC_CLASS_3;
-
-       /*
-        * topology attributes
-        */
-       attr->pport_cfg.topology = fcport->cfg.topology;
-       attr->topology = fcport->topology;
-
-       /*
-        * beacon attributes
-        */
-       attr->beacon = fcport->beacon;
-       attr->link_e2e_beacon = fcport->link_e2e_beacon;
-       attr->plog_enabled = bfa_plog_get_setting(fcport->bfa->plog);
-
-       attr->pport_cfg.path_tov = bfa_fcpim_path_tov_get(bfa);
-       attr->pport_cfg.q_depth = bfa_fcpim_qdepth_get(bfa);
-
-       /* PBC Disabled State */
-       if (cfgrsp->pbc_cfg.port_enabled == BFI_PBC_PORT_DISABLED)
-               attr->port_state = BFA_PPORT_ST_PREBOOT_DISABLED;
-       else {
-               attr->port_state = bfa_sm_to_state(
-                               hal_pport_sm_table, fcport->sm);
-               if (bfa_ioc_is_disabled(&fcport->bfa->ioc))
-                       attr->port_state = BFA_PPORT_ST_IOCDIS;
-               else if (bfa_ioc_fw_mismatch(&fcport->bfa->ioc))
-                       attr->port_state = BFA_PPORT_ST_FWMISMATCH;
-       }
-}
-
-#define BFA_FCPORT_STATS_TOV   1000
-
-/**
- * Fetch port attributes (FCQoS or FCoE).
- */
-bfa_status_t
-bfa_fcport_get_stats(struct bfa_s *bfa, union bfa_fcport_stats_u *stats,
-                   bfa_cb_pport_t cbfn, void *cbarg)
-{
-       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
-
-       if (fcport->stats_busy) {
-               bfa_trc(bfa, fcport->stats_busy);
-               return BFA_STATUS_DEVBUSY;
-       }
-
-       fcport->stats_busy  = BFA_TRUE;
-       fcport->stats_ret   = stats;
-       fcport->stats_cbfn  = cbfn;
-       fcport->stats_cbarg = cbarg;
-
-       bfa_fcport_send_stats_get(fcport);
-
-       bfa_timer_start(bfa, &fcport->timer, bfa_fcport_stats_get_timeout,
-               fcport, BFA_FCPORT_STATS_TOV);
-       return BFA_STATUS_OK;
-}
-
-/**
- * Reset port statistics (FCQoS or FCoE).
- */
-bfa_status_t
-bfa_fcport_clear_stats(struct bfa_s *bfa, bfa_cb_pport_t cbfn, void *cbarg)
-{
-       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
-
-       if (fcport->stats_busy) {
-               bfa_trc(bfa, fcport->stats_busy);
-               return BFA_STATUS_DEVBUSY;
-       }
-
-       fcport->stats_busy = BFA_TRUE;
-       fcport->stats_cbfn = cbfn;
-       fcport->stats_cbarg = cbarg;
-
-       bfa_fcport_send_stats_clear(fcport);
-
-       bfa_timer_start(bfa, &fcport->timer, bfa_fcport_stats_clr_timeout,
-                       fcport, BFA_FCPORT_STATS_TOV);
-       return BFA_STATUS_OK;
-}
-
-/**
- * Fetch FCQoS port statistics
- */
-bfa_status_t
-bfa_fcport_get_qos_stats(struct bfa_s *bfa, union bfa_fcport_stats_u *stats,
-       bfa_cb_pport_t cbfn, void *cbarg)
-{
-       /* Meaningful only for FC mode */
-       bfa_assert(bfa_ioc_get_fcmode(&bfa->ioc));
-
-       return bfa_fcport_get_stats(bfa, stats, cbfn, cbarg);
-}
-
-/**
- * Reset FCoE port statistics
- */
-bfa_status_t
-bfa_fcport_clear_qos_stats(struct bfa_s *bfa, bfa_cb_pport_t cbfn, void *cbarg)
-{
-       /* Meaningful only for FC mode */
-       bfa_assert(bfa_ioc_get_fcmode(&bfa->ioc));
-
-       return bfa_fcport_clear_stats(bfa, cbfn, cbarg);
-}
-
-/**
- * Fetch FCQoS port statistics
- */
-bfa_status_t
-bfa_fcport_get_fcoe_stats(struct bfa_s *bfa, union bfa_fcport_stats_u *stats,
-       bfa_cb_pport_t cbfn, void *cbarg)
-{
-       /* Meaningful only for FCoE mode */
-       bfa_assert(!bfa_ioc_get_fcmode(&bfa->ioc));
-
-       return bfa_fcport_get_stats(bfa, stats, cbfn, cbarg);
-}
-
-/**
- * Reset FCoE port statistics
- */
-bfa_status_t
-bfa_fcport_clear_fcoe_stats(struct bfa_s *bfa, bfa_cb_pport_t cbfn, void *cbarg)
-{
-       /* Meaningful only for FCoE mode */
-       bfa_assert(!bfa_ioc_get_fcmode(&bfa->ioc));
-
-       return bfa_fcport_clear_stats(bfa, cbfn, cbarg);
-}
-
-bfa_status_t
-bfa_fcport_trunk_enable(struct bfa_s *bfa, u8 bitmap)
-{
-       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
-
-       bfa_trc(bfa, bitmap);
-       bfa_trc(bfa, fcport->cfg.trunked);
-       bfa_trc(bfa, fcport->cfg.trunk_ports);
-
-       if (!bitmap || (bitmap & (bitmap - 1)))
-               return BFA_STATUS_EINVAL;
-
-       fcport->cfg.trunked = BFA_TRUE;
-       fcport->cfg.trunk_ports = bitmap;
-
-       return BFA_STATUS_OK;
-}
-
-void
-bfa_fcport_qos_get_attr(struct bfa_s *bfa, struct bfa_qos_attr_s *qos_attr)
-{
-       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
-
-       qos_attr->state = bfa_os_ntohl(fcport->qos_attr.state);
-       qos_attr->total_bb_cr = bfa_os_ntohl(fcport->qos_attr.total_bb_cr);
-}
-
-void
-bfa_fcport_qos_get_vc_attr(struct bfa_s *bfa,
-                         struct bfa_qos_vc_attr_s *qos_vc_attr)
-{
-       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
-       struct bfa_qos_vc_attr_s *bfa_vc_attr = &fcport->qos_vc_attr;
-       u32        i = 0;
-
-       qos_vc_attr->total_vc_count = bfa_os_ntohs(bfa_vc_attr->total_vc_count);
-       qos_vc_attr->shared_credit = bfa_os_ntohs(bfa_vc_attr->shared_credit);
-       qos_vc_attr->elp_opmode_flags =
-               bfa_os_ntohl(bfa_vc_attr->elp_opmode_flags);
-
-       /*
-        * Individual VC info
-        */
-       while (i < qos_vc_attr->total_vc_count) {
-               qos_vc_attr->vc_info[i].vc_credit =
-                       bfa_vc_attr->vc_info[i].vc_credit;
-               qos_vc_attr->vc_info[i].borrow_credit =
-                       bfa_vc_attr->vc_info[i].borrow_credit;
-               qos_vc_attr->vc_info[i].priority =
-                       bfa_vc_attr->vc_info[i].priority;
-               ++i;
-       }
-}
-
-/**
- * Fetch port attributes.
- */
-bfa_status_t
-bfa_fcport_trunk_disable(struct bfa_s *bfa)
-{
-       return BFA_STATUS_OK;
-}
-
-bfa_boolean_t
-bfa_fcport_trunk_query(struct bfa_s *bfa, u32 *bitmap)
-{
-       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
-
-       *bitmap = fcport->cfg.trunk_ports;
-       return fcport->cfg.trunked;
-}
-
-bfa_boolean_t
-bfa_fcport_is_disabled(struct bfa_s *bfa)
-{
-       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
-
-       return bfa_sm_to_state(hal_pport_sm_table, fcport->sm) ==
-               BFA_PPORT_ST_DISABLED;
-
-}
-
-bfa_boolean_t
-bfa_fcport_is_ratelim(struct bfa_s *bfa)
-{
-       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
-
-       return fcport->cfg.ratelimit ? BFA_TRUE : BFA_FALSE;
-
-}
-
-void
-bfa_fcport_cfg_qos(struct bfa_s *bfa, bfa_boolean_t on_off)
-{
-       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
-       enum bfa_ioc_type_e ioc_type = bfa_get_type(bfa);
-
-       bfa_trc(bfa, on_off);
-       bfa_trc(bfa, fcport->cfg.qos_enabled);
-
-       bfa_trc(bfa, ioc_type);
-
-       if (ioc_type == BFA_IOC_TYPE_FC) {
-               fcport->cfg.qos_enabled = on_off;
-               /**
-                * Notify fcpim of the change in QoS state
-                */
-               bfa_fcpim_update_ioredirect(bfa);
-       }
-}
-
-void
-bfa_fcport_cfg_ratelim(struct bfa_s *bfa, bfa_boolean_t on_off)
-{
-       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
-
-       bfa_trc(bfa, on_off);
-       bfa_trc(bfa, fcport->cfg.ratelimit);
-
-       fcport->cfg.ratelimit = on_off;
-       if (fcport->cfg.trl_def_speed == BFA_PPORT_SPEED_UNKNOWN)
-               fcport->cfg.trl_def_speed = BFA_PPORT_SPEED_1GBPS;
-}
-
-/**
- * Configure default minimum ratelim speed
- */
-bfa_status_t
-bfa_fcport_cfg_ratelim_speed(struct bfa_s *bfa, enum bfa_pport_speed speed)
-{
-       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
-
-       bfa_trc(bfa, speed);
-
-       /*
-        * Auto and speeds greater than the supported speed, are invalid
-        */
-       if ((speed == BFA_PPORT_SPEED_AUTO) || (speed > fcport->speed_sup)) {
-               bfa_trc(bfa, fcport->speed_sup);
-               return BFA_STATUS_UNSUPP_SPEED;
-       }
-
-       fcport->cfg.trl_def_speed = speed;
-
-       return BFA_STATUS_OK;
-}
-
-/**
- * Get default minimum ratelim speed
- */
-enum bfa_pport_speed
-bfa_fcport_get_ratelim_speed(struct bfa_s *bfa)
-{
-       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
-
-       bfa_trc(bfa, fcport->cfg.trl_def_speed);
-       return fcport->cfg.trl_def_speed;
-
-}
-
-void
-bfa_fcport_busy(struct bfa_s *bfa, bfa_boolean_t status)
-{
-       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
-
-       bfa_trc(bfa, status);
-       bfa_trc(bfa, fcport->diag_busy);
-
-       fcport->diag_busy = status;
-}
-
-void
-bfa_fcport_beacon(struct bfa_s *bfa, bfa_boolean_t beacon,
-                bfa_boolean_t link_e2e_beacon)
-{
-       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
-
-       bfa_trc(bfa, beacon);
-       bfa_trc(bfa, link_e2e_beacon);
-       bfa_trc(bfa, fcport->beacon);
-       bfa_trc(bfa, fcport->link_e2e_beacon);
-
-       fcport->beacon = beacon;
-       fcport->link_e2e_beacon = link_e2e_beacon;
-}
-
-bfa_boolean_t
-bfa_fcport_is_linkup(struct bfa_s *bfa)
-{
-       return bfa_sm_cmp_state(BFA_FCPORT_MOD(bfa), bfa_fcport_sm_linkup);
-}
-
-bfa_boolean_t
-bfa_fcport_is_qos_enabled(struct bfa_s *bfa)
-{
-       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
-
-       return fcport->cfg.qos_enabled;
-}
index d1a99209bf5f9fbd7260b470ececa3a25b733829..9cebbe30a6782dbf8e8d9fedea033d7f19531d68 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
  * All rights reserved
  * www.brocade.com
  *
  *  bfa_fcs.c BFA FCS main
  */
 
-#include <fcs/bfa_fcs.h>
-#include "fcs_port.h"
-#include "fcs_uf.h"
-#include "fcs_vport.h"
-#include "fcs_rport.h"
-#include "fcs_fabric.h"
-#include "fcs_fcpim.h"
-#include "fcs_fcptm.h"
-#include "fcbuild.h"
-#include "fcs.h"
+#include "bfa_fcs.h"
+#include "bfa_fcbuild.h"
 #include "bfad_drv.h"
-#include <fcb/bfa_fcb.h>
+
+BFA_TRC_FILE(FCS, FCS);
 
 /**
  * FCS sub-modules
  */
 struct bfa_fcs_mod_s {
        void            (*attach) (struct bfa_fcs_s *fcs);
-       void            (*modinit) (struct bfa_fcs_s *fcs);
-       void            (*modexit) (struct bfa_fcs_s *fcs);
+       void            (*modinit) (struct bfa_fcs_s *fcs);
+       void            (*modexit) (struct bfa_fcs_s *fcs);
 };
 
 #define BFA_FCS_MODULE(_mod) { _mod ## _modinit, _mod ## _modexit }
 
 static struct bfa_fcs_mod_s fcs_modules[] = {
-       { bfa_fcs_pport_attach, NULL, NULL },
+       { bfa_fcs_port_attach, NULL, NULL },
        { bfa_fcs_uf_attach, NULL, NULL },
        { bfa_fcs_fabric_attach, bfa_fcs_fabric_modinit,
-        bfa_fcs_fabric_modexit },
+         bfa_fcs_fabric_modexit },
 };
 
 /**
@@ -57,8 +50,8 @@ static struct bfa_fcs_mod_s fcs_modules[] = {
 static void
 bfa_fcs_exit_comp(void *fcs_cbarg)
 {
-       struct bfa_fcs_s *fcs = fcs_cbarg;
-       struct bfad_s *bfad = fcs->bfad;
+       struct bfa_fcs_s      *fcs = fcs_cbarg;
+       struct bfad_s         *bfad = fcs->bfad;
 
        complete(&bfad->comp);
 }
@@ -74,9 +67,9 @@ bfa_fcs_exit_comp(void *fcs_cbarg)
  */
 void
 bfa_fcs_attach(struct bfa_fcs_s *fcs, struct bfa_s *bfa, struct bfad_s *bfad,
-                       bfa_boolean_t min_cfg)
+              bfa_boolean_t min_cfg)
 {
-       int             i;
+       int             i;
        struct bfa_fcs_mod_s  *mod;
 
        fcs->bfa = bfa;
@@ -86,7 +79,7 @@ bfa_fcs_attach(struct bfa_fcs_s *fcs, struct bfa_s *bfa, struct bfad_s *bfad,
        bfa_attach_fcs(bfa);
        fcbuild_init();
 
-       for (i = 0; i < ARRAY_SIZE(fcs_modules); i++) {
+       for (i = 0; i < sizeof(fcs_modules) / sizeof(fcs_modules[0]); i++) {
                mod = &fcs_modules[i];
                if (mod->attach)
                        mod->attach(fcs);
@@ -99,11 +92,11 @@ bfa_fcs_attach(struct bfa_fcs_s *fcs, struct bfa_s *bfa, struct bfad_s *bfad,
 void
 bfa_fcs_init(struct bfa_fcs_s *fcs)
 {
-       int i, npbc_vports;
+       int             i, npbc_vports;
        struct bfa_fcs_mod_s  *mod;
        struct bfi_pbc_vport_s pbc_vports[BFI_PBC_MAX_VPORTS];
 
-       for (i = 0; i < ARRAY_SIZE(fcs_modules); i++) {
+       for (i = 0; i < sizeof(fcs_modules) / sizeof(fcs_modules[0]); i++) {
                mod = &fcs_modules[i];
                if (mod->modinit)
                        mod->modinit(fcs);
@@ -111,7 +104,7 @@ bfa_fcs_init(struct bfa_fcs_s *fcs)
        /* Initialize pbc vports */
        if (!fcs->min_cfg) {
                npbc_vports =
-                       bfa_iocfc_get_pbc_vports(fcs->bfa, pbc_vports);
+                   bfa_iocfc_get_pbc_vports(fcs->bfa, pbc_vports);
                for (i = 0; i < npbc_vports; i++)
                        bfa_fcb_pbc_vport_create(fcs->bfa->bfad, pbc_vports[i]);
        }
@@ -127,12 +120,13 @@ bfa_fcs_start(struct bfa_fcs_s *fcs)
 }
 
 /**
- *             FCS driver details initialization.
+ *     brief
+ *             FCS driver details initialization.
  *
- *     param[in]               fcs             FCS instance
- *     param[in]               driver_info     Driver Details
+ *     param[in]               fcs             FCS instance
+ *     param[in]               driver_info     Driver Details
  *
- *     return None
+ *     return None
  */
 void
 bfa_fcs_driver_info_init(struct bfa_fcs_s *fcs,
@@ -145,13 +139,13 @@ bfa_fcs_driver_info_init(struct bfa_fcs_s *fcs,
 }
 
 /**
- *      @brief
- *              FCS FDMI Driver Parameter Initialization
+ *     brief
+ *             FCS FDMI Driver Parameter Initialization
  *
- *      @param[in]              fcs             FCS instance
- *      @param[in]              fdmi_enable     TRUE/FALSE
+ *     param[in]               fcs             FCS instance
+ *     param[in]               fdmi_enable     TRUE/FALSE
  *
- *      @return None
+ *     return None
  */
 void
 bfa_fcs_set_fdmi_param(struct bfa_fcs_s *fcs, bfa_boolean_t fdmi_enable)
@@ -160,22 +154,24 @@ bfa_fcs_set_fdmi_param(struct bfa_fcs_s *fcs, bfa_boolean_t fdmi_enable)
        fcs->fdmi_enabled = fdmi_enable;
 
 }
-
 /**
- *             FCS instance cleanup and exit.
+ *     brief
+ *             FCS instance cleanup and exit.
  *
- *     param[in]               fcs                     FCS instance
- *     return None
+ *     param[in]               fcs                     FCS instance
+ *     return None
  */
 void
 bfa_fcs_exit(struct bfa_fcs_s *fcs)
 {
        struct bfa_fcs_mod_s  *mod;
-       int i;
+       int             nmods, i;
 
        bfa_wc_init(&fcs->wc, bfa_fcs_exit_comp, fcs);
 
-       for (i = 0; i < ARRAY_SIZE(fcs_modules); i++) {
+       nmods = sizeof(fcs_modules) / sizeof(fcs_modules[0]);
+
+       for (i = 0; i < nmods; i++) {
 
                mod = &fcs_modules[i];
                if (mod->modexit) {
@@ -194,24 +190,1547 @@ bfa_fcs_trc_init(struct bfa_fcs_s *fcs, struct bfa_trc_mod_s *trcmod)
        fcs->trcmod = trcmod;
 }
 
-
 void
-bfa_fcs_log_init(struct bfa_fcs_s *fcs, struct bfa_log_mod_s *logmod)
+bfa_fcs_modexit_comp(struct bfa_fcs_s *fcs)
+{
+       bfa_wc_down(&fcs->wc);
+}
+
+/**
+ * Fabric module implementation.
+ */
+
+#define BFA_FCS_FABRIC_RETRY_DELAY     (2000)  /* Milliseconds */
+#define BFA_FCS_FABRIC_CLEANUP_DELAY   (10000) /* Milliseconds */
+
+#define bfa_fcs_fabric_set_opertype(__fabric) do {                     \
+               if (bfa_fcport_get_topology((__fabric)->fcs->bfa)       \
+                   == BFA_PORT_TOPOLOGY_P2P)                           \
+                       (__fabric)->oper_type = BFA_PORT_TYPE_NPORT;    \
+               else                                                    \
+                       (__fabric)->oper_type = BFA_PORT_TYPE_NLPORT;   \
+} while (0)
+
+/*
+ * forward declarations
+ */
+static void bfa_fcs_fabric_init(struct bfa_fcs_fabric_s *fabric);
+static void bfa_fcs_fabric_login(struct bfa_fcs_fabric_s *fabric);
+static void bfa_fcs_fabric_notify_online(struct bfa_fcs_fabric_s *fabric);
+static void bfa_fcs_fabric_notify_offline(struct bfa_fcs_fabric_s *fabric);
+static void bfa_fcs_fabric_delay(void *cbarg);
+static void bfa_fcs_fabric_delete(struct bfa_fcs_fabric_s *fabric);
+static void bfa_fcs_fabric_delete_comp(void *cbarg);
+static void bfa_fcs_fabric_process_uf(struct bfa_fcs_fabric_s *fabric,
+                                     struct fchs_s *fchs, u16 len);
+static void bfa_fcs_fabric_process_flogi(struct bfa_fcs_fabric_s *fabric,
+                                        struct fchs_s *fchs, u16 len);
+static void bfa_fcs_fabric_send_flogi_acc(struct bfa_fcs_fabric_s *fabric);
+static void bfa_fcs_fabric_flogiacc_comp(void *fcsarg,
+                                        struct bfa_fcxp_s *fcxp, void *cbarg,
+                                        bfa_status_t status,
+                                        u32 rsp_len,
+                                        u32 resid_len,
+                                        struct fchs_s *rspfchs);
+/**
+ *  fcs_fabric_sm fabric state machine functions
+ */
+
+/**
+ * Fabric state machine events
+ */
+enum bfa_fcs_fabric_event {
+       BFA_FCS_FABRIC_SM_CREATE        = 1,    /*  create from driver        */
+       BFA_FCS_FABRIC_SM_DELETE        = 2,    /*  delete from driver        */
+       BFA_FCS_FABRIC_SM_LINK_DOWN     = 3,    /*  link down from port      */
+       BFA_FCS_FABRIC_SM_LINK_UP       = 4,    /*  link up from port         */
+       BFA_FCS_FABRIC_SM_CONT_OP       = 5,    /*  flogi/auth continue op   */
+       BFA_FCS_FABRIC_SM_RETRY_OP      = 6,    /*  flogi/auth retry op      */
+       BFA_FCS_FABRIC_SM_NO_FABRIC     = 7,    /*  from flogi/auth           */
+       BFA_FCS_FABRIC_SM_PERF_EVFP     = 8,    /*  from flogi/auth           */
+       BFA_FCS_FABRIC_SM_ISOLATE       = 9,    /*  from EVFP processing     */
+       BFA_FCS_FABRIC_SM_NO_TAGGING    = 10,   /*  no VFT tagging from EVFP */
+       BFA_FCS_FABRIC_SM_DELAYED       = 11,   /*  timeout delay event      */
+       BFA_FCS_FABRIC_SM_AUTH_FAILED   = 12,   /*  auth failed       */
+       BFA_FCS_FABRIC_SM_AUTH_SUCCESS  = 13,   /*  auth successful           */
+       BFA_FCS_FABRIC_SM_DELCOMP       = 14,   /*  all vports deleted event */
+       BFA_FCS_FABRIC_SM_LOOPBACK      = 15,   /*  Received our own FLOGI   */
+       BFA_FCS_FABRIC_SM_START         = 16,   /*  from driver       */
+};
+
+static void    bfa_fcs_fabric_sm_uninit(struct bfa_fcs_fabric_s *fabric,
+                                        enum bfa_fcs_fabric_event event);
+static void    bfa_fcs_fabric_sm_created(struct bfa_fcs_fabric_s *fabric,
+                                         enum bfa_fcs_fabric_event event);
+static void    bfa_fcs_fabric_sm_linkdown(struct bfa_fcs_fabric_s *fabric,
+                                          enum bfa_fcs_fabric_event event);
+static void    bfa_fcs_fabric_sm_flogi(struct bfa_fcs_fabric_s *fabric,
+                                       enum bfa_fcs_fabric_event event);
+static void    bfa_fcs_fabric_sm_flogi_retry(struct bfa_fcs_fabric_s *fabric,
+                                             enum bfa_fcs_fabric_event event);
+static void    bfa_fcs_fabric_sm_auth(struct bfa_fcs_fabric_s *fabric,
+                                      enum bfa_fcs_fabric_event event);
+static void    bfa_fcs_fabric_sm_auth_failed(struct bfa_fcs_fabric_s *fabric,
+                                             enum bfa_fcs_fabric_event event);
+static void    bfa_fcs_fabric_sm_loopback(struct bfa_fcs_fabric_s *fabric,
+                                          enum bfa_fcs_fabric_event event);
+static void    bfa_fcs_fabric_sm_nofabric(struct bfa_fcs_fabric_s *fabric,
+                                          enum bfa_fcs_fabric_event event);
+static void    bfa_fcs_fabric_sm_online(struct bfa_fcs_fabric_s *fabric,
+                                        enum bfa_fcs_fabric_event event);
+static void    bfa_fcs_fabric_sm_evfp(struct bfa_fcs_fabric_s *fabric,
+                                      enum bfa_fcs_fabric_event event);
+static void    bfa_fcs_fabric_sm_evfp_done(struct bfa_fcs_fabric_s *fabric,
+                                           enum bfa_fcs_fabric_event event);
+static void    bfa_fcs_fabric_sm_isolated(struct bfa_fcs_fabric_s *fabric,
+                                          enum bfa_fcs_fabric_event event);
+static void    bfa_fcs_fabric_sm_deleting(struct bfa_fcs_fabric_s *fabric,
+                                          enum bfa_fcs_fabric_event event);
+/**
+ *   Beginning state before fabric creation.
+ */
+static void
+bfa_fcs_fabric_sm_uninit(struct bfa_fcs_fabric_s *fabric,
+                        enum bfa_fcs_fabric_event event)
+{
+       bfa_trc(fabric->fcs, fabric->bport.port_cfg.pwwn);
+       bfa_trc(fabric->fcs, event);
+
+       switch (event) {
+       case BFA_FCS_FABRIC_SM_CREATE:
+               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_created);
+               bfa_fcs_fabric_init(fabric);
+               bfa_fcs_lport_init(&fabric->bport, &fabric->bport.port_cfg);
+               break;
+
+       case BFA_FCS_FABRIC_SM_LINK_UP:
+       case BFA_FCS_FABRIC_SM_LINK_DOWN:
+               break;
+
+       default:
+               bfa_sm_fault(fabric->fcs, event);
+       }
+}
+
+/**
+ *   Beginning state before fabric creation.
+ */
+static void
+bfa_fcs_fabric_sm_created(struct bfa_fcs_fabric_s *fabric,
+                         enum bfa_fcs_fabric_event event)
+{
+       bfa_trc(fabric->fcs, fabric->bport.port_cfg.pwwn);
+       bfa_trc(fabric->fcs, event);
+
+       switch (event) {
+       case BFA_FCS_FABRIC_SM_START:
+               if (bfa_fcport_is_linkup(fabric->fcs->bfa)) {
+                       bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_flogi);
+                       bfa_fcs_fabric_login(fabric);
+               } else
+                       bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_linkdown);
+               break;
+
+       case BFA_FCS_FABRIC_SM_LINK_UP:
+       case BFA_FCS_FABRIC_SM_LINK_DOWN:
+               break;
+
+       case BFA_FCS_FABRIC_SM_DELETE:
+               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_uninit);
+               bfa_fcs_modexit_comp(fabric->fcs);
+               break;
+
+       default:
+               bfa_sm_fault(fabric->fcs, event);
+       }
+}
+
+/**
+ *   Link is down, awaiting LINK UP event from port. This is also the
+ *   first state at fabric creation.
+ */
+static void
+bfa_fcs_fabric_sm_linkdown(struct bfa_fcs_fabric_s *fabric,
+                          enum bfa_fcs_fabric_event event)
+{
+       bfa_trc(fabric->fcs, fabric->bport.port_cfg.pwwn);
+       bfa_trc(fabric->fcs, event);
+
+       switch (event) {
+       case BFA_FCS_FABRIC_SM_LINK_UP:
+               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_flogi);
+               bfa_fcs_fabric_login(fabric);
+               break;
+
+       case BFA_FCS_FABRIC_SM_RETRY_OP:
+               break;
+
+       case BFA_FCS_FABRIC_SM_DELETE:
+               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_deleting);
+               bfa_fcs_fabric_delete(fabric);
+               break;
+
+       default:
+               bfa_sm_fault(fabric->fcs, event);
+       }
+}
+
+/**
+ *   FLOGI is in progress, awaiting FLOGI reply.
+ */
+static void
+bfa_fcs_fabric_sm_flogi(struct bfa_fcs_fabric_s *fabric,
+                       enum bfa_fcs_fabric_event event)
+{
+       bfa_trc(fabric->fcs, fabric->bport.port_cfg.pwwn);
+       bfa_trc(fabric->fcs, event);
+
+       switch (event) {
+       case BFA_FCS_FABRIC_SM_CONT_OP:
+
+               bfa_fcport_set_tx_bbcredit(fabric->fcs->bfa,
+                                          fabric->bb_credit);
+               fabric->fab_type = BFA_FCS_FABRIC_SWITCHED;
+
+               if (fabric->auth_reqd && fabric->is_auth) {
+                       bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_auth);
+                       bfa_trc(fabric->fcs, event);
+               } else {
+                       bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_online);
+                       bfa_fcs_fabric_notify_online(fabric);
+               }
+               break;
+
+       case BFA_FCS_FABRIC_SM_RETRY_OP:
+               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_flogi_retry);
+               bfa_timer_start(fabric->fcs->bfa, &fabric->delay_timer,
+                               bfa_fcs_fabric_delay, fabric,
+                               BFA_FCS_FABRIC_RETRY_DELAY);
+               break;
+
+       case BFA_FCS_FABRIC_SM_LOOPBACK:
+               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_loopback);
+               bfa_lps_discard(fabric->lps);
+               bfa_fcs_fabric_set_opertype(fabric);
+               break;
+
+       case BFA_FCS_FABRIC_SM_NO_FABRIC:
+               fabric->fab_type = BFA_FCS_FABRIC_N2N;
+               bfa_fcport_set_tx_bbcredit(fabric->fcs->bfa,
+                                          fabric->bb_credit);
+               bfa_fcs_fabric_notify_online(fabric);
+               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_nofabric);
+               break;
+
+       case BFA_FCS_FABRIC_SM_LINK_DOWN:
+               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_linkdown);
+               bfa_lps_discard(fabric->lps);
+               break;
+
+       case BFA_FCS_FABRIC_SM_DELETE:
+               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_deleting);
+               bfa_lps_discard(fabric->lps);
+               bfa_fcs_fabric_delete(fabric);
+               break;
+
+       default:
+               bfa_sm_fault(fabric->fcs, event);
+       }
+}
+
+
+static void
+bfa_fcs_fabric_sm_flogi_retry(struct bfa_fcs_fabric_s *fabric,
+                             enum bfa_fcs_fabric_event event)
+{
+       bfa_trc(fabric->fcs, fabric->bport.port_cfg.pwwn);
+       bfa_trc(fabric->fcs, event);
+
+       switch (event) {
+       case BFA_FCS_FABRIC_SM_DELAYED:
+               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_flogi);
+               bfa_fcs_fabric_login(fabric);
+               break;
+
+       case BFA_FCS_FABRIC_SM_LINK_DOWN:
+               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_linkdown);
+               bfa_timer_stop(&fabric->delay_timer);
+               break;
+
+       case BFA_FCS_FABRIC_SM_DELETE:
+               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_deleting);
+               bfa_timer_stop(&fabric->delay_timer);
+               bfa_fcs_fabric_delete(fabric);
+               break;
+
+       default:
+               bfa_sm_fault(fabric->fcs, event);
+       }
+}
+
+/**
+ *   Authentication is in progress, awaiting authentication results.
+ */
+static void
+bfa_fcs_fabric_sm_auth(struct bfa_fcs_fabric_s *fabric,
+                      enum bfa_fcs_fabric_event event)
+{
+       bfa_trc(fabric->fcs, fabric->bport.port_cfg.pwwn);
+       bfa_trc(fabric->fcs, event);
+
+       switch (event) {
+       case BFA_FCS_FABRIC_SM_AUTH_FAILED:
+               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_auth_failed);
+               bfa_lps_discard(fabric->lps);
+               break;
+
+       case BFA_FCS_FABRIC_SM_AUTH_SUCCESS:
+               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_online);
+               bfa_fcs_fabric_notify_online(fabric);
+               break;
+
+       case BFA_FCS_FABRIC_SM_PERF_EVFP:
+               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_evfp);
+               break;
+
+       case BFA_FCS_FABRIC_SM_LINK_DOWN:
+               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_linkdown);
+               bfa_lps_discard(fabric->lps);
+               break;
+
+       case BFA_FCS_FABRIC_SM_DELETE:
+               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_deleting);
+               bfa_fcs_fabric_delete(fabric);
+               break;
+
+       default:
+               bfa_sm_fault(fabric->fcs, event);
+       }
+}
+
+/**
+ *   Authentication failed
+ */
+static void
+bfa_fcs_fabric_sm_auth_failed(struct bfa_fcs_fabric_s *fabric,
+                             enum bfa_fcs_fabric_event event)
+{
+       bfa_trc(fabric->fcs, fabric->bport.port_cfg.pwwn);
+       bfa_trc(fabric->fcs, event);
+
+       switch (event) {
+       case BFA_FCS_FABRIC_SM_LINK_DOWN:
+               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_linkdown);
+               bfa_fcs_fabric_notify_offline(fabric);
+               break;
+
+       case BFA_FCS_FABRIC_SM_DELETE:
+               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_deleting);
+               bfa_fcs_fabric_delete(fabric);
+               break;
+
+       default:
+               bfa_sm_fault(fabric->fcs, event);
+       }
+}
+
+/**
+ *   Port is in loopback mode.
+ */
+static void
+bfa_fcs_fabric_sm_loopback(struct bfa_fcs_fabric_s *fabric,
+                          enum bfa_fcs_fabric_event event)
+{
+       bfa_trc(fabric->fcs, fabric->bport.port_cfg.pwwn);
+       bfa_trc(fabric->fcs, event);
+
+       switch (event) {
+       case BFA_FCS_FABRIC_SM_LINK_DOWN:
+               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_linkdown);
+               bfa_fcs_fabric_notify_offline(fabric);
+               break;
+
+       case BFA_FCS_FABRIC_SM_DELETE:
+               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_deleting);
+               bfa_fcs_fabric_delete(fabric);
+               break;
+
+       default:
+               bfa_sm_fault(fabric->fcs, event);
+       }
+}
+
+/**
+ *   There is no attached fabric - private loop or NPort-to-NPort topology.
+ */
+static void
+bfa_fcs_fabric_sm_nofabric(struct bfa_fcs_fabric_s *fabric,
+                          enum bfa_fcs_fabric_event event)
+{
+       bfa_trc(fabric->fcs, fabric->bport.port_cfg.pwwn);
+       bfa_trc(fabric->fcs, event);
+
+       switch (event) {
+       case BFA_FCS_FABRIC_SM_LINK_DOWN:
+               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_linkdown);
+               bfa_lps_discard(fabric->lps);
+               bfa_fcs_fabric_notify_offline(fabric);
+               break;
+
+       case BFA_FCS_FABRIC_SM_DELETE:
+               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_deleting);
+               bfa_fcs_fabric_delete(fabric);
+               break;
+
+       case BFA_FCS_FABRIC_SM_NO_FABRIC:
+               bfa_trc(fabric->fcs, fabric->bb_credit);
+               bfa_fcport_set_tx_bbcredit(fabric->fcs->bfa,
+                                          fabric->bb_credit);
+               break;
+
+       default:
+               bfa_sm_fault(fabric->fcs, event);
+       }
+}
+
+/**
+ *   Fabric is online - normal operating state.
+ */
+static void
+bfa_fcs_fabric_sm_online(struct bfa_fcs_fabric_s *fabric,
+                        enum bfa_fcs_fabric_event event)
+{
+       bfa_trc(fabric->fcs, fabric->bport.port_cfg.pwwn);
+       bfa_trc(fabric->fcs, event);
+
+       switch (event) {
+       case BFA_FCS_FABRIC_SM_LINK_DOWN:
+               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_linkdown);
+               bfa_lps_discard(fabric->lps);
+               bfa_fcs_fabric_notify_offline(fabric);
+               break;
+
+       case BFA_FCS_FABRIC_SM_DELETE:
+               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_deleting);
+               bfa_fcs_fabric_delete(fabric);
+               break;
+
+       case BFA_FCS_FABRIC_SM_AUTH_FAILED:
+               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_auth_failed);
+               bfa_lps_discard(fabric->lps);
+               break;
+
+       case BFA_FCS_FABRIC_SM_AUTH_SUCCESS:
+               break;
+
+       default:
+               bfa_sm_fault(fabric->fcs, event);
+       }
+}
+
+/**
+ *   Exchanging virtual fabric parameters.
+ */
+static void
+bfa_fcs_fabric_sm_evfp(struct bfa_fcs_fabric_s *fabric,
+                      enum bfa_fcs_fabric_event event)
+{
+       bfa_trc(fabric->fcs, fabric->bport.port_cfg.pwwn);
+       bfa_trc(fabric->fcs, event);
+
+       switch (event) {
+       case BFA_FCS_FABRIC_SM_CONT_OP:
+               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_evfp_done);
+               break;
+
+       case BFA_FCS_FABRIC_SM_ISOLATE:
+               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_isolated);
+               break;
+
+       default:
+               bfa_sm_fault(fabric->fcs, event);
+       }
+}
+
+/**
+ *   EVFP exchange complete and VFT tagging is enabled.
+ */
+static void
+bfa_fcs_fabric_sm_evfp_done(struct bfa_fcs_fabric_s *fabric,
+                           enum bfa_fcs_fabric_event event)
+{
+       bfa_trc(fabric->fcs, fabric->bport.port_cfg.pwwn);
+       bfa_trc(fabric->fcs, event);
+}
+
+/**
+ *   Port is isolated after EVFP exchange due to VF_ID mismatch (N and F).
+ */
+static void
+bfa_fcs_fabric_sm_isolated(struct bfa_fcs_fabric_s *fabric,
+                          enum bfa_fcs_fabric_event event)
+{
+       struct bfad_s *bfad = (struct bfad_s *)fabric->fcs->bfad;
+       char    pwwn_ptr[BFA_STRING_32];
+
+       bfa_trc(fabric->fcs, fabric->bport.port_cfg.pwwn);
+       bfa_trc(fabric->fcs, event);
+       wwn2str(pwwn_ptr, fabric->bport.port_cfg.pwwn);
+
+       BFA_LOG(KERN_INFO, bfad, log_level,
+               "Port is isolated due to VF_ID mismatch. "
+               "PWWN: %s Port VF_ID: %04x switch port VF_ID: %04x.",
+               pwwn_ptr, fabric->fcs->port_vfid,
+               fabric->event_arg.swp_vfid);
+}
+
+/**
+ *   Fabric is being deleted, awaiting vport delete completions.
+ */
+static void
+bfa_fcs_fabric_sm_deleting(struct bfa_fcs_fabric_s *fabric,
+                          enum bfa_fcs_fabric_event event)
 {
-       fcs->logm = logmod;
+       bfa_trc(fabric->fcs, fabric->bport.port_cfg.pwwn);
+       bfa_trc(fabric->fcs, event);
+
+       switch (event) {
+       case BFA_FCS_FABRIC_SM_DELCOMP:
+               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_uninit);
+               bfa_fcs_modexit_comp(fabric->fcs);
+               break;
+
+       case BFA_FCS_FABRIC_SM_LINK_UP:
+               break;
+
+       case BFA_FCS_FABRIC_SM_LINK_DOWN:
+               bfa_fcs_fabric_notify_offline(fabric);
+               break;
+
+       default:
+               bfa_sm_fault(fabric->fcs, event);
+       }
 }
 
 
+
+/**
+ *  fcs_fabric_private fabric private functions
+ */
+
+static void
+bfa_fcs_fabric_init(struct bfa_fcs_fabric_s *fabric)
+{
+       struct bfa_lport_cfg_s *port_cfg = &fabric->bport.port_cfg;
+
+       port_cfg->roles = BFA_LPORT_ROLE_FCP_IM;
+       port_cfg->nwwn = bfa_ioc_get_nwwn(&fabric->fcs->bfa->ioc);
+       port_cfg->pwwn = bfa_ioc_get_pwwn(&fabric->fcs->bfa->ioc);
+}
+
+/**
+ * Port Symbolic Name Creation for base port.
+ */
 void
-bfa_fcs_aen_init(struct bfa_fcs_s *fcs, struct bfa_aen_s *aen)
+bfa_fcs_fabric_psymb_init(struct bfa_fcs_fabric_s *fabric)
 {
-       fcs->aen = aen;
+       struct bfa_lport_cfg_s *port_cfg = &fabric->bport.port_cfg;
+       char model[BFA_ADAPTER_MODEL_NAME_LEN] = {0};
+       struct bfa_fcs_driver_info_s *driver_info = &fabric->fcs->driver_info;
+
+       bfa_ioc_get_adapter_model(&fabric->fcs->bfa->ioc, model);
+
+       /* Model name/number */
+       strncpy((char *)&port_cfg->sym_name, model,
+               BFA_FCS_PORT_SYMBNAME_MODEL_SZ);
+       strncat((char *)&port_cfg->sym_name, BFA_FCS_PORT_SYMBNAME_SEPARATOR,
+               sizeof(BFA_FCS_PORT_SYMBNAME_SEPARATOR));
+
+       /* Driver Version */
+       strncat((char *)&port_cfg->sym_name, (char *)driver_info->version,
+               BFA_FCS_PORT_SYMBNAME_VERSION_SZ);
+       strncat((char *)&port_cfg->sym_name, BFA_FCS_PORT_SYMBNAME_SEPARATOR,
+               sizeof(BFA_FCS_PORT_SYMBNAME_SEPARATOR));
+
+       /* Host machine name */
+       strncat((char *)&port_cfg->sym_name,
+               (char *)driver_info->host_machine_name,
+               BFA_FCS_PORT_SYMBNAME_MACHINENAME_SZ);
+       strncat((char *)&port_cfg->sym_name, BFA_FCS_PORT_SYMBNAME_SEPARATOR,
+               sizeof(BFA_FCS_PORT_SYMBNAME_SEPARATOR));
+
+       /*
+        * Host OS Info :
+        * If OS Patch Info is not there, do not truncate any bytes from the
+        * OS name string and instead copy the entire OS info string (64 bytes).
+        */
+       if (driver_info->host_os_patch[0] == '\0') {
+               strncat((char *)&port_cfg->sym_name,
+                       (char *)driver_info->host_os_name,
+                       BFA_FCS_OS_STR_LEN);
+               strncat((char *)&port_cfg->sym_name,
+                       BFA_FCS_PORT_SYMBNAME_SEPARATOR,
+                       sizeof(BFA_FCS_PORT_SYMBNAME_SEPARATOR));
+       } else {
+               strncat((char *)&port_cfg->sym_name,
+                       (char *)driver_info->host_os_name,
+                       BFA_FCS_PORT_SYMBNAME_OSINFO_SZ);
+               strncat((char *)&port_cfg->sym_name,
+                       BFA_FCS_PORT_SYMBNAME_SEPARATOR,
+                       sizeof(BFA_FCS_PORT_SYMBNAME_SEPARATOR));
+
+               /* Append host OS Patch Info */
+               strncat((char *)&port_cfg->sym_name,
+                       (char *)driver_info->host_os_patch,
+                       BFA_FCS_PORT_SYMBNAME_OSPATCH_SZ);
+       }
+
+       /* null terminate */
+       port_cfg->sym_name.symname[BFA_SYMNAME_MAXLEN - 1] = 0;
 }
 
+/**
+ * bfa lps login completion callback
+ */
 void
-bfa_fcs_modexit_comp(struct bfa_fcs_s *fcs)
+bfa_cb_lps_flogi_comp(void *bfad, void *uarg, bfa_status_t status)
 {
-       bfa_wc_down(&fcs->wc);
+       struct bfa_fcs_fabric_s *fabric = uarg;
+
+       bfa_trc(fabric->fcs, fabric->bport.port_cfg.pwwn);
+       bfa_trc(fabric->fcs, status);
+
+       switch (status) {
+       case BFA_STATUS_OK:
+               fabric->stats.flogi_accepts++;
+               break;
+
+       case BFA_STATUS_INVALID_MAC:
+               /* Only for CNA */
+               fabric->stats.flogi_acc_err++;
+               bfa_sm_send_event(fabric, BFA_FCS_FABRIC_SM_RETRY_OP);
+
+               return;
+
+       case BFA_STATUS_EPROTOCOL:
+               switch (bfa_lps_get_extstatus(fabric->lps)) {
+               case BFA_EPROTO_BAD_ACCEPT:
+                       fabric->stats.flogi_acc_err++;
+                       break;
+
+               case BFA_EPROTO_UNKNOWN_RSP:
+                       fabric->stats.flogi_unknown_rsp++;
+                       break;
+
+               default:
+                       break;
+               }
+               bfa_sm_send_event(fabric, BFA_FCS_FABRIC_SM_RETRY_OP);
+
+               return;
+
+       case BFA_STATUS_FABRIC_RJT:
+               fabric->stats.flogi_rejects++;
+               bfa_sm_send_event(fabric, BFA_FCS_FABRIC_SM_RETRY_OP);
+               return;
+
+       default:
+               fabric->stats.flogi_rsp_err++;
+               bfa_sm_send_event(fabric, BFA_FCS_FABRIC_SM_RETRY_OP);
+               return;
+       }
+
+       fabric->bb_credit = bfa_lps_get_peer_bbcredit(fabric->lps);
+       bfa_trc(fabric->fcs, fabric->bb_credit);
+
+       if (!bfa_lps_is_brcd_fabric(fabric->lps))
+               fabric->fabric_name =  bfa_lps_get_peer_nwwn(fabric->lps);
+
+       /*
+        * Check port type. It should be 1 = F-port.
+        */
+       if (bfa_lps_is_fport(fabric->lps)) {
+               fabric->bport.pid = bfa_lps_get_pid(fabric->lps);
+               fabric->is_npiv = bfa_lps_is_npiv_en(fabric->lps);
+               fabric->is_auth = bfa_lps_is_authreq(fabric->lps);
+               bfa_sm_send_event(fabric, BFA_FCS_FABRIC_SM_CONT_OP);
+       } else {
+               /*
+                * Nport-2-Nport direct attached
+                */
+               fabric->bport.port_topo.pn2n.rem_port_wwn =
+                       bfa_lps_get_peer_pwwn(fabric->lps);
+               bfa_sm_send_event(fabric, BFA_FCS_FABRIC_SM_NO_FABRIC);
+       }
+
+       bfa_trc(fabric->fcs, fabric->bport.pid);
+       bfa_trc(fabric->fcs, fabric->is_npiv);
+       bfa_trc(fabric->fcs, fabric->is_auth);
+}
+/**
+ *             Allocate and send FLOGI.
+ */
+static void
+bfa_fcs_fabric_login(struct bfa_fcs_fabric_s *fabric)
+{
+       struct bfa_s            *bfa = fabric->fcs->bfa;
+       struct bfa_lport_cfg_s  *pcfg = &fabric->bport.port_cfg;
+       u8                      alpa = 0;
+
+       if (bfa_fcport_get_topology(bfa) == BFA_PORT_TOPOLOGY_LOOP)
+               alpa = bfa_fcport_get_myalpa(bfa);
+
+       bfa_lps_flogi(fabric->lps, fabric, alpa, bfa_fcport_get_maxfrsize(bfa),
+                     pcfg->pwwn, pcfg->nwwn, fabric->auth_reqd);
+
+       fabric->stats.flogi_sent++;
+}
+
+static void
+bfa_fcs_fabric_notify_online(struct bfa_fcs_fabric_s *fabric)
+{
+       struct bfa_fcs_vport_s *vport;
+       struct list_head              *qe, *qen;
+
+       bfa_trc(fabric->fcs, fabric->fabric_name);
+
+       bfa_fcs_fabric_set_opertype(fabric);
+       fabric->stats.fabric_onlines++;
+
+       /**
+        * notify online event to base and then virtual ports
+        */
+       bfa_fcs_lport_online(&fabric->bport);
+
+       list_for_each_safe(qe, qen, &fabric->vport_q) {
+               vport = (struct bfa_fcs_vport_s *) qe;
+               bfa_fcs_vport_online(vport);
+       }
+}
+
+static void
+bfa_fcs_fabric_notify_offline(struct bfa_fcs_fabric_s *fabric)
+{
+       struct bfa_fcs_vport_s *vport;
+       struct list_head              *qe, *qen;
+
+       bfa_trc(fabric->fcs, fabric->fabric_name);
+       fabric->stats.fabric_offlines++;
+
+       /**
+        * notify offline event first to vports and then base port.
+        */
+       list_for_each_safe(qe, qen, &fabric->vport_q) {
+               vport = (struct bfa_fcs_vport_s *) qe;
+               bfa_fcs_vport_offline(vport);
+       }
+
+       bfa_fcs_lport_offline(&fabric->bport);
+
+       fabric->fabric_name = 0;
+       fabric->fabric_ip_addr[0] = 0;
+}
+
+static void
+bfa_fcs_fabric_delay(void *cbarg)
+{
+       struct bfa_fcs_fabric_s *fabric = cbarg;
+
+       bfa_sm_send_event(fabric, BFA_FCS_FABRIC_SM_DELAYED);
+}
+
+/**
+ * Delete all vports and wait for vport delete completions.
+ */
+static void
+bfa_fcs_fabric_delete(struct bfa_fcs_fabric_s *fabric)
+{
+       struct bfa_fcs_vport_s *vport;
+       struct list_head              *qe, *qen;
+
+       list_for_each_safe(qe, qen, &fabric->vport_q) {
+               vport = (struct bfa_fcs_vport_s *) qe;
+               bfa_fcs_vport_fcs_delete(vport);
+       }
+
+       bfa_fcs_lport_delete(&fabric->bport);
+       bfa_wc_wait(&fabric->wc);
 }
 
+static void
+bfa_fcs_fabric_delete_comp(void *cbarg)
+{
+       struct bfa_fcs_fabric_s *fabric = cbarg;
+
+       bfa_sm_send_event(fabric, BFA_FCS_FABRIC_SM_DELCOMP);
+}
 
+/**
+ *  fcs_fabric_public fabric public functions
+ */
+
+/**
+ * Attach time initialization.
+ */
+void
+bfa_fcs_fabric_attach(struct bfa_fcs_s *fcs)
+{
+       struct bfa_fcs_fabric_s *fabric;
+
+       fabric = &fcs->fabric;
+       bfa_os_memset(fabric, 0, sizeof(struct bfa_fcs_fabric_s));
+
+       /**
+        * Initialize base fabric.
+        */
+       fabric->fcs = fcs;
+       INIT_LIST_HEAD(&fabric->vport_q);
+       INIT_LIST_HEAD(&fabric->vf_q);
+       fabric->lps = bfa_lps_alloc(fcs->bfa);
+       bfa_assert(fabric->lps);
+
+       /**
+        * Initialize fabric delete completion handler. Fabric deletion is
+        * complete when the last vport delete is complete.
+        */
+       bfa_wc_init(&fabric->wc, bfa_fcs_fabric_delete_comp, fabric);
+       bfa_wc_up(&fabric->wc); /* For the base port */
+
+       bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_uninit);
+       bfa_fcs_lport_attach(&fabric->bport, fabric->fcs, FC_VF_ID_NULL, NULL);
+}
+
+void
+bfa_fcs_fabric_modinit(struct bfa_fcs_s *fcs)
+{
+       bfa_sm_send_event(&fcs->fabric, BFA_FCS_FABRIC_SM_CREATE);
+       bfa_trc(fcs, 0);
+}
+
+/**
+ *   Module cleanup
+ */
+void
+bfa_fcs_fabric_modexit(struct bfa_fcs_s *fcs)
+{
+       struct bfa_fcs_fabric_s *fabric;
+
+       bfa_trc(fcs, 0);
+
+       /**
+        * Cleanup base fabric.
+        */
+       fabric = &fcs->fabric;
+       bfa_lps_delete(fabric->lps);
+       bfa_sm_send_event(fabric, BFA_FCS_FABRIC_SM_DELETE);
+}
+
+/**
+ * Fabric module start -- kick starts FCS actions
+ */
+void
+bfa_fcs_fabric_modstart(struct bfa_fcs_s *fcs)
+{
+       struct bfa_fcs_fabric_s *fabric;
+
+       bfa_trc(fcs, 0);
+       fabric = &fcs->fabric;
+       bfa_sm_send_event(fabric, BFA_FCS_FABRIC_SM_START);
+}
+
+/**
+ *   Suspend fabric activity as part of driver suspend.
+ */
+void
+bfa_fcs_fabric_modsusp(struct bfa_fcs_s *fcs)
+{
+}
+
+bfa_boolean_t
+bfa_fcs_fabric_is_loopback(struct bfa_fcs_fabric_s *fabric)
+{
+       return bfa_sm_cmp_state(fabric, bfa_fcs_fabric_sm_loopback);
+}
+
+bfa_boolean_t
+bfa_fcs_fabric_is_auth_failed(struct bfa_fcs_fabric_s *fabric)
+{
+       return bfa_sm_cmp_state(fabric, bfa_fcs_fabric_sm_auth_failed);
+}
+
+enum bfa_port_type
+bfa_fcs_fabric_port_type(struct bfa_fcs_fabric_s *fabric)
+{
+       return fabric->oper_type;
+}
+
+/**
+ *   Link up notification from BFA physical port module.
+ */
+void
+bfa_fcs_fabric_link_up(struct bfa_fcs_fabric_s *fabric)
+{
+       bfa_trc(fabric->fcs, fabric->bport.port_cfg.pwwn);
+       bfa_sm_send_event(fabric, BFA_FCS_FABRIC_SM_LINK_UP);
+}
+
+/**
+ *   Link down notification from BFA physical port module.
+ */
+void
+bfa_fcs_fabric_link_down(struct bfa_fcs_fabric_s *fabric)
+{
+       bfa_trc(fabric->fcs, fabric->bport.port_cfg.pwwn);
+       bfa_sm_send_event(fabric, BFA_FCS_FABRIC_SM_LINK_DOWN);
+}
+
+/**
+ *   A child vport is being created in the fabric.
+ *
+ *   Call from vport module at vport creation. A list of base port and vports
+ *   belonging to a fabric is maintained to propagate link events.
+ *
+ *   param[in] fabric - Fabric instance. This can be a base fabric or vf.
+ *   param[in] vport  - Vport being created.
+ *
+ *   @return None (always succeeds)
+ */
+void
+bfa_fcs_fabric_addvport(struct bfa_fcs_fabric_s *fabric,
+                       struct bfa_fcs_vport_s *vport)
+{
+       /**
+        * - add vport to fabric's vport_q
+        */
+       bfa_trc(fabric->fcs, fabric->vf_id);
+
+       list_add_tail(&vport->qe, &fabric->vport_q);
+       fabric->num_vports++;
+       bfa_wc_up(&fabric->wc);
+}
+
+/**
+ *   A child vport is being deleted from fabric.
+ *
+ *   Vport is being deleted.
+ */
+void
+bfa_fcs_fabric_delvport(struct bfa_fcs_fabric_s *fabric,
+                       struct bfa_fcs_vport_s *vport)
+{
+       list_del(&vport->qe);
+       fabric->num_vports--;
+       bfa_wc_down(&fabric->wc);
+}
+
+/**
+ *   Base port is deleted.
+ */
+void
+bfa_fcs_fabric_port_delete_comp(struct bfa_fcs_fabric_s *fabric)
+{
+       bfa_wc_down(&fabric->wc);
+}
+
+
+/**
+ *    Check if fabric is online.
+ *
+ *   param[in] fabric - Fabric instance. This can be a base fabric or vf.
+ *
+ *   @return  TRUE/FALSE
+ */
+int
+bfa_fcs_fabric_is_online(struct bfa_fcs_fabric_s *fabric)
+{
+       return bfa_sm_cmp_state(fabric, bfa_fcs_fabric_sm_online);
+}
+
+/**
+ *     brief
+ *
+ */
+bfa_status_t
+bfa_fcs_fabric_addvf(struct bfa_fcs_fabric_s *vf, struct bfa_fcs_s *fcs,
+                    struct bfa_lport_cfg_s *port_cfg, struct bfad_vf_s *vf_drv)
+{
+       bfa_sm_set_state(vf, bfa_fcs_fabric_sm_uninit);
+       return BFA_STATUS_OK;
+}
+
+/**
+ * Lookup for a vport withing a fabric given its pwwn
+ */
+struct bfa_fcs_vport_s *
+bfa_fcs_fabric_vport_lookup(struct bfa_fcs_fabric_s *fabric, wwn_t pwwn)
+{
+       struct bfa_fcs_vport_s *vport;
+       struct list_head              *qe;
+
+       list_for_each(qe, &fabric->vport_q) {
+               vport = (struct bfa_fcs_vport_s *) qe;
+               if (bfa_fcs_lport_get_pwwn(&vport->lport) == pwwn)
+                       return vport;
+       }
+
+       return NULL;
+}
+
+/**
+ *    In a given fabric, return the number of lports.
+ *
+ *   param[in] fabric - Fabric instance. This can be a base fabric or vf.
+ *
+ *   @return : 1 or more.
+ */
+u16
+bfa_fcs_fabric_vport_count(struct bfa_fcs_fabric_s *fabric)
+{
+       return fabric->num_vports;
+}
+
+/*
+ *  Get OUI of the attached switch.
+ *
+ *  Note : Use of this function should be avoided as much as possible.
+ *         This function should be used only if there is any requirement
+*          to check for FOS version below 6.3.
+ *         To check if the attached fabric is a brocade fabric, use
+ *         bfa_lps_is_brcd_fabric() which works for FOS versions 6.3
+ *         or above only.
+ */
+
+u16
+bfa_fcs_fabric_get_switch_oui(struct bfa_fcs_fabric_s *fabric)
+{
+       wwn_t fab_nwwn;
+       u8 *tmp;
+       u16 oui;
+
+       fab_nwwn = bfa_lps_get_peer_nwwn(fabric->lps);
+
+       tmp = (u8 *)&fab_nwwn;
+       oui = (tmp[3] << 8) | tmp[4];
+
+       return oui;
+}
+/**
+ *             Unsolicited frame receive handling.
+ */
+void
+bfa_fcs_fabric_uf_recv(struct bfa_fcs_fabric_s *fabric, struct fchs_s *fchs,
+                      u16 len)
+{
+       u32     pid = fchs->d_id;
+       struct bfa_fcs_vport_s *vport;
+       struct list_head              *qe;
+       struct fc_els_cmd_s *els_cmd = (struct fc_els_cmd_s *) (fchs + 1);
+       struct fc_logi_s *flogi = (struct fc_logi_s *) els_cmd;
+
+       bfa_trc(fabric->fcs, len);
+       bfa_trc(fabric->fcs, pid);
+
+       /**
+        * Look for our own FLOGI frames being looped back. This means an
+        * external loopback cable is in place. Our own FLOGI frames are
+        * sometimes looped back when switch port gets temporarily bypassed.
+        */
+       if ((pid == bfa_os_ntoh3b(FC_FABRIC_PORT)) &&
+           (els_cmd->els_code == FC_ELS_FLOGI) &&
+           (flogi->port_name == bfa_fcs_lport_get_pwwn(&fabric->bport))) {
+               bfa_sm_send_event(fabric, BFA_FCS_FABRIC_SM_LOOPBACK);
+               return;
+       }
+
+       /**
+        * FLOGI/EVFP exchanges should be consumed by base fabric.
+        */
+       if (fchs->d_id == bfa_os_hton3b(FC_FABRIC_PORT)) {
+               bfa_trc(fabric->fcs, pid);
+               bfa_fcs_fabric_process_uf(fabric, fchs, len);
+               return;
+       }
+
+       if (fabric->bport.pid == pid) {
+               /**
+                * All authentication frames should be routed to auth
+                */
+               bfa_trc(fabric->fcs, els_cmd->els_code);
+               if (els_cmd->els_code == FC_ELS_AUTH) {
+                       bfa_trc(fabric->fcs, els_cmd->els_code);
+                       return;
+               }
+
+               bfa_trc(fabric->fcs, *(u8 *) ((u8 *) fchs));
+               bfa_fcs_lport_uf_recv(&fabric->bport, fchs, len);
+               return;
+       }
+
+       /**
+        * look for a matching local port ID
+        */
+       list_for_each(qe, &fabric->vport_q) {
+               vport = (struct bfa_fcs_vport_s *) qe;
+               if (vport->lport.pid == pid) {
+                       bfa_fcs_lport_uf_recv(&vport->lport, fchs, len);
+                       return;
+               }
+       }
+       bfa_trc(fabric->fcs, els_cmd->els_code);
+       bfa_fcs_lport_uf_recv(&fabric->bport, fchs, len);
+}
+
+/**
+ *             Unsolicited frames to be processed by fabric.
+ */
+static void
+bfa_fcs_fabric_process_uf(struct bfa_fcs_fabric_s *fabric, struct fchs_s *fchs,
+                         u16 len)
+{
+       struct fc_els_cmd_s *els_cmd = (struct fc_els_cmd_s *) (fchs + 1);
+
+       bfa_trc(fabric->fcs, els_cmd->els_code);
+
+       switch (els_cmd->els_code) {
+       case FC_ELS_FLOGI:
+               bfa_fcs_fabric_process_flogi(fabric, fchs, len);
+               break;
+
+       default:
+               /*
+                * need to generate a LS_RJT
+                */
+               break;
+       }
+}
+
+/**
+ *     Process incoming FLOGI
+ */
+static void
+bfa_fcs_fabric_process_flogi(struct bfa_fcs_fabric_s *fabric,
+                       struct fchs_s *fchs, u16 len)
+{
+       struct fc_logi_s *flogi = (struct fc_logi_s *) (fchs + 1);
+       struct bfa_fcs_lport_s *bport = &fabric->bport;
+
+       bfa_trc(fabric->fcs, fchs->s_id);
+
+       fabric->stats.flogi_rcvd++;
+       /*
+        * Check port type. It should be 0 = n-port.
+        */
+       if (flogi->csp.port_type) {
+               /*
+                * @todo: may need to send a LS_RJT
+                */
+               bfa_trc(fabric->fcs, flogi->port_name);
+               fabric->stats.flogi_rejected++;
+               return;
+       }
+
+       fabric->bb_credit = bfa_os_ntohs(flogi->csp.bbcred);
+       bport->port_topo.pn2n.rem_port_wwn = flogi->port_name;
+       bport->port_topo.pn2n.reply_oxid = fchs->ox_id;
+
+       /*
+        * Send a Flogi Acc
+        */
+       bfa_fcs_fabric_send_flogi_acc(fabric);
+       bfa_sm_send_event(fabric, BFA_FCS_FABRIC_SM_NO_FABRIC);
+}
+
+static void
+bfa_fcs_fabric_send_flogi_acc(struct bfa_fcs_fabric_s *fabric)
+{
+       struct bfa_lport_cfg_s *pcfg = &fabric->bport.port_cfg;
+       struct bfa_fcs_lport_n2n_s *n2n_port = &fabric->bport.port_topo.pn2n;
+       struct bfa_s      *bfa = fabric->fcs->bfa;
+       struct bfa_fcxp_s *fcxp;
+       u16     reqlen;
+       struct fchs_s   fchs;
+
+       fcxp = bfa_fcs_fcxp_alloc(fabric->fcs);
+       /**
+        * Do not expect this failure -- expect remote node to retry
+        */
+       if (!fcxp)
+               return;
+
+       reqlen = fc_flogi_acc_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
+                                   bfa_os_hton3b(FC_FABRIC_PORT),
+                                   n2n_port->reply_oxid, pcfg->pwwn,
+                                   pcfg->nwwn,
+                                   bfa_fcport_get_maxfrsize(bfa),
+                                   bfa_fcport_get_rx_bbcredit(bfa));
+
+       bfa_fcxp_send(fcxp, NULL, fabric->vf_id, bfa_lps_get_tag(fabric->lps),
+                     BFA_FALSE, FC_CLASS_3,
+                     reqlen, &fchs, bfa_fcs_fabric_flogiacc_comp, fabric,
+                     FC_MAX_PDUSZ, 0);
+}
+
+/**
+ *   Flogi Acc completion callback.
+ */
+static void
+bfa_fcs_fabric_flogiacc_comp(void *fcsarg, struct bfa_fcxp_s *fcxp, void *cbarg,
+                            bfa_status_t status, u32 rsp_len,
+                            u32 resid_len, struct fchs_s *rspfchs)
+{
+       struct bfa_fcs_fabric_s *fabric = cbarg;
+
+       bfa_trc(fabric->fcs, status);
+}
+
+/*
+ *
+ * @param[in] fabric - fabric
+ * @param[in] wwn_t - new fabric name
+ *
+ * @return - none
+ */
+void
+bfa_fcs_fabric_set_fabric_name(struct bfa_fcs_fabric_s *fabric,
+                              wwn_t fabric_name)
+{
+       struct bfad_s *bfad = (struct bfad_s *)fabric->fcs->bfad;
+       char    pwwn_ptr[BFA_STRING_32];
+       char    fwwn_ptr[BFA_STRING_32];
+
+       bfa_trc(fabric->fcs, fabric_name);
+
+       if (fabric->fabric_name == 0) {
+               /*
+                * With BRCD switches, we don't get Fabric Name in FLOGI.
+                * Don't generate a fabric name change event in this case.
+                */
+               fabric->fabric_name = fabric_name;
+       } else {
+               fabric->fabric_name = fabric_name;
+               wwn2str(pwwn_ptr, bfa_fcs_lport_get_pwwn(&fabric->bport));
+               wwn2str(fwwn_ptr,
+                       bfa_fcs_lport_get_fabric_name(&fabric->bport));
+               BFA_LOG(KERN_WARNING, bfad, log_level,
+                       "Base port WWN = %s Fabric WWN = %s\n",
+                       pwwn_ptr, fwwn_ptr);
+       }
+}
+
+/**
+ *  fcs_vf_api virtual fabrics API
+ */
+
+/**
+ * Enable VF mode.
+ *
+ * @param[in]          fcs             fcs module instance
+ * @param[in]          vf_id           default vf_id of port, FC_VF_ID_NULL
+ *                                     to use standard default vf_id of 1.
+ *
+ * @retval     BFA_STATUS_OK           vf mode is enabled
+ * @retval     BFA_STATUS_BUSY         Port is active. Port must be disabled
+ *                                     before VF mode can be enabled.
+ */
+bfa_status_t
+bfa_fcs_vf_mode_enable(struct bfa_fcs_s *fcs, u16 vf_id)
+{
+       return BFA_STATUS_OK;
+}
+
+/**
+ * Disable VF mode.
+ *
+ * @param[in]          fcs             fcs module instance
+ *
+ * @retval     BFA_STATUS_OK           vf mode is disabled
+ * @retval     BFA_STATUS_BUSY         VFs are present and being used. All
+ *                                     VFs must be deleted before disabling
+ *                                     VF mode.
+ */
+bfa_status_t
+bfa_fcs_vf_mode_disable(struct bfa_fcs_s *fcs)
+{
+       return BFA_STATUS_OK;
+}
+
+/**
+ *  Create a new VF instance.
+ *
+ *  A new VF is created using the given VF configuration. A VF is identified
+ *  by VF id. No duplicate VF creation is allowed with the same VF id. Once
+ *  a VF is created, VF is automatically started after link initialization
+ *  and EVFP exchange is completed.
+ *
+ *     param[in] vf     -      FCS vf data structure. Memory is
+ *                             allocated by caller (driver)
+ *     param[in] fcs    -      FCS module
+ *     param[in] vf_cfg -      VF configuration
+ *     param[in] vf_drv -      Opaque handle back to the driver's
+ *                             virtual vf structure
+ *
+ *     retval BFA_STATUS_OK VF creation is successful
+ *     retval BFA_STATUS_FAILED VF creation failed
+ *     retval BFA_STATUS_EEXIST A VF exists with the given vf_id
+ */
+bfa_status_t
+bfa_fcs_vf_create(bfa_fcs_vf_t *vf, struct bfa_fcs_s *fcs, u16 vf_id,
+                 struct bfa_lport_cfg_s *port_cfg, struct bfad_vf_s *vf_drv)
+{
+       bfa_trc(fcs, vf_id);
+       return BFA_STATUS_OK;
+}
+
+/**
+ *     Use this function to delete a BFA VF object. VF object should
+ *     be stopped before this function call.
+ *
+ *     param[in] vf - pointer to bfa_vf_t.
+ *
+ *     retval BFA_STATUS_OK    On vf deletion success
+ *     retval BFA_STATUS_BUSY VF is not in a stopped state
+ *     retval BFA_STATUS_INPROGRESS VF deletion in in progress
+ */
+bfa_status_t
+bfa_fcs_vf_delete(bfa_fcs_vf_t *vf)
+{
+       bfa_trc(vf->fcs, vf->vf_id);
+       return BFA_STATUS_OK;
+}
+
+
+/**
+ *     Returns attributes of the given VF.
+ *
+ *     param[in]       vf      pointer to bfa_vf_t.
+ *     param[out] vf_attr      vf attributes returned
+ *
+ *     return None
+ */
+void
+bfa_fcs_vf_get_attr(bfa_fcs_vf_t *vf, struct bfa_vf_attr_s *vf_attr)
+{
+       bfa_trc(vf->fcs, vf->vf_id);
+}
+
+/**
+ *     Return statistics associated with the given vf.
+ *
+ *     param[in] vf            pointer to bfa_vf_t.
+ *     param[out] vf_stats     vf statistics returned
+ *
+ *     @return None
+ */
+void
+bfa_fcs_vf_get_stats(bfa_fcs_vf_t *vf, struct bfa_vf_stats_s *vf_stats)
+{
+       bfa_os_memcpy(vf_stats, &vf->stats, sizeof(struct bfa_vf_stats_s));
+}
+
+/**
+ *     clear statistics associated with the given vf.
+ *
+ *     param[in]       vf      pointer to bfa_vf_t.
+ *
+ *     @return None
+ */
+void
+bfa_fcs_vf_clear_stats(bfa_fcs_vf_t *vf)
+{
+       bfa_os_memset(&vf->stats, 0, sizeof(struct bfa_vf_stats_s));
+}
+
+/**
+ *     Returns FCS vf structure for a given vf_id.
+ *
+ *     param[in]       vf_id - VF_ID
+ *
+ *     return
+ *     If lookup succeeds, retuns fcs vf object, otherwise returns NULL
+ */
+bfa_fcs_vf_t   *
+bfa_fcs_vf_lookup(struct bfa_fcs_s *fcs, u16 vf_id)
+{
+       bfa_trc(fcs, vf_id);
+       if (vf_id == FC_VF_ID_NULL)
+               return &fcs->fabric;
+
+       return NULL;
+}
+
+/**
+ *     Return the list of VFs configured.
+ *
+ *     param[in]       fcs     fcs module instance
+ *     param[out]      vf_ids  returned list of vf_ids
+ *     param[in,out]   nvfs    in:size of vf_ids array,
+ *                             out:total elements present,
+ *                             actual elements returned is limited by the size
+ *
+ *     return Driver VF structure
+ */
+void
+bfa_fcs_vf_list(struct bfa_fcs_s *fcs, u16 *vf_ids, int *nvfs)
+{
+       bfa_trc(fcs, *nvfs);
+}
+
+/**
+ *     Return the list of all VFs visible from fabric.
+ *
+ *     param[in]       fcs     fcs module instance
+ *     param[out]      vf_ids  returned list of vf_ids
+ *     param[in,out]   nvfs    in:size of vf_ids array,
+ *                             out:total elements present,
+ *                             actual elements returned is limited by the size
+ *
+ *     return Driver VF structure
+ */
+void
+bfa_fcs_vf_list_all(struct bfa_fcs_s *fcs, u16 *vf_ids, int *nvfs)
+{
+       bfa_trc(fcs, *nvfs);
+}
+
+/**
+ *     Return the list of local logical ports present in the given VF.
+ *
+ *     param[in]       vf      vf for which logical ports are returned
+ *     param[out]      lpwwn   returned logical port wwn list
+ *     param[in,out]   nlports in:size of lpwwn list;
+ *                             out:total elements present,
+ *                             actual elements returned is limited by the size
+ */
+void
+bfa_fcs_vf_get_ports(bfa_fcs_vf_t *vf, wwn_t lpwwn[], int *nlports)
+{
+       struct list_head        *qe;
+       struct bfa_fcs_vport_s *vport;
+       int     i;
+       struct bfa_fcs_s      *fcs;
+
+       if (vf == NULL || lpwwn == NULL || *nlports == 0)
+               return;
+
+       fcs = vf->fcs;
+
+       bfa_trc(fcs, vf->vf_id);
+       bfa_trc(fcs, (u32) *nlports);
+
+       i = 0;
+       lpwwn[i++] = vf->bport.port_cfg.pwwn;
+
+       list_for_each(qe, &vf->vport_q) {
+               if (i >= *nlports)
+                       break;
+
+               vport = (struct bfa_fcs_vport_s *) qe;
+               lpwwn[i++] = vport->lport.port_cfg.pwwn;
+       }
+
+       bfa_trc(fcs, i);
+       *nlports = i;
+}
+
+/**
+ * BFA FCS PPORT ( physical port)
+ */
+static void
+bfa_fcs_port_event_handler(void *cbarg, enum bfa_port_linkstate event)
+{
+       struct bfa_fcs_s      *fcs = cbarg;
+
+       bfa_trc(fcs, event);
+
+       switch (event) {
+       case BFA_PORT_LINKUP:
+               bfa_fcs_fabric_link_up(&fcs->fabric);
+               break;
+
+       case BFA_PORT_LINKDOWN:
+               bfa_fcs_fabric_link_down(&fcs->fabric);
+               break;
+
+       default:
+               bfa_assert(0);
+       }
+}
+
+void
+bfa_fcs_port_attach(struct bfa_fcs_s *fcs)
+{
+       bfa_fcport_event_register(fcs->bfa, bfa_fcs_port_event_handler, fcs);
+}
+
+/**
+ * BFA FCS UF ( Unsolicited Frames)
+ */
+
+/**
+ *             BFA callback for unsolicited frame receive handler.
+ *
+ * @param[in]          cbarg           callback arg for receive handler
+ * @param[in]          uf              unsolicited frame descriptor
+ *
+ * @return None
+ */
+static void
+bfa_fcs_uf_recv(void *cbarg, struct bfa_uf_s *uf)
+{
+       struct bfa_fcs_s        *fcs = (struct bfa_fcs_s *) cbarg;
+       struct fchs_s   *fchs = bfa_uf_get_frmbuf(uf);
+       u16     len = bfa_uf_get_frmlen(uf);
+       struct fc_vft_s *vft;
+       struct bfa_fcs_fabric_s *fabric;
+
+       /**
+        * check for VFT header
+        */
+       if (fchs->routing == FC_RTG_EXT_HDR &&
+           fchs->cat_info == FC_CAT_VFT_HDR) {
+               bfa_stats(fcs, uf.tagged);
+               vft = bfa_uf_get_frmbuf(uf);
+               if (fcs->port_vfid == vft->vf_id)
+                       fabric = &fcs->fabric;
+               else
+                       fabric = bfa_fcs_vf_lookup(fcs, (u16) vft->vf_id);
+
+               /**
+                * drop frame if vfid is unknown
+                */
+               if (!fabric) {
+                       bfa_assert(0);
+                       bfa_stats(fcs, uf.vfid_unknown);
+                       bfa_uf_free(uf);
+                       return;
+               }
+
+               /**
+                * skip vft header
+                */
+               fchs = (struct fchs_s *) (vft + 1);
+               len -= sizeof(struct fc_vft_s);
+
+               bfa_trc(fcs, vft->vf_id);
+       } else {
+               bfa_stats(fcs, uf.untagged);
+               fabric = &fcs->fabric;
+       }
+
+       bfa_trc(fcs, ((u32 *) fchs)[0]);
+       bfa_trc(fcs, ((u32 *) fchs)[1]);
+       bfa_trc(fcs, ((u32 *) fchs)[2]);
+       bfa_trc(fcs, ((u32 *) fchs)[3]);
+       bfa_trc(fcs, ((u32 *) fchs)[4]);
+       bfa_trc(fcs, ((u32 *) fchs)[5]);
+       bfa_trc(fcs, len);
+
+       bfa_fcs_fabric_uf_recv(fabric, fchs, len);
+       bfa_uf_free(uf);
+}
+
+void
+bfa_fcs_uf_attach(struct bfa_fcs_s *fcs)
+{
+       bfa_uf_recv_register(fcs->bfa, bfa_fcs_uf_recv, fcs);
+}
diff --git a/drivers/scsi/bfa/bfa_fcs.h b/drivers/scsi/bfa/bfa_fcs.h
new file mode 100644 (file)
index 0000000..d75045d
--- /dev/null
@@ -0,0 +1,779 @@
+/*
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
+ * All rights reserved
+ * www.brocade.com
+ *
+ * Linux driver for Brocade Fibre Channel Host Bus Adapter.
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License (GPL) Version 2 as
+ * published by the Free Software Foundation
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * General Public License for more details.
+ */
+
+#ifndef __BFA_FCS_H__
+#define __BFA_FCS_H__
+
+#include "bfa_cs.h"
+#include "bfa_defs.h"
+#include "bfa_defs_fcs.h"
+#include "bfa_modules.h"
+#include "bfa_fc.h"
+
+#define BFA_FCS_OS_STR_LEN             64
+
+/*
+ * !!! Only append to the enums defined here to avoid any versioning
+ * !!! needed between trace utility and driver version
+ */
+enum {
+       BFA_TRC_FCS_FCS         = 1,
+       BFA_TRC_FCS_PORT        = 2,
+       BFA_TRC_FCS_RPORT       = 3,
+       BFA_TRC_FCS_FCPIM       = 4,
+};
+
+
+struct bfa_fcs_s;
+
+#define __fcs_min_cfg(__fcs)       ((__fcs)->min_cfg)
+void bfa_fcs_modexit_comp(struct bfa_fcs_s *fcs);
+
+#define BFA_FCS_BRCD_SWITCH_OUI  0x051e
+#define N2N_LOCAL_PID      0x010000
+#define N2N_REMOTE_PID         0x020000
+#define        BFA_FCS_RETRY_TIMEOUT 2000
+#define BFA_FCS_PID_IS_WKA(pid)  ((bfa_os_ntoh3b(pid) > 0xFFF000) ?  1 : 0)
+
+
+
+struct bfa_fcs_lport_ns_s {
+       bfa_sm_t        sm;             /*  state machine */
+       struct bfa_timer_s timer;
+       struct bfa_fcs_lport_s *port;   /*  parent port */
+       struct bfa_fcxp_s *fcxp;
+       struct bfa_fcxp_wqe_s fcxp_wqe;
+};
+
+
+struct bfa_fcs_lport_scn_s {
+       bfa_sm_t        sm;             /*  state machine */
+       struct bfa_timer_s timer;
+       struct bfa_fcs_lport_s *port;   /*  parent port */
+       struct bfa_fcxp_s *fcxp;
+       struct bfa_fcxp_wqe_s fcxp_wqe;
+};
+
+
+struct bfa_fcs_lport_fdmi_s {
+       bfa_sm_t        sm;             /*  state machine */
+       struct bfa_timer_s timer;
+       struct bfa_fcs_lport_ms_s *ms;  /*  parent ms */
+       struct bfa_fcxp_s *fcxp;
+       struct bfa_fcxp_wqe_s fcxp_wqe;
+       u8      retry_cnt;      /*  retry count */
+       u8      rsvd[3];
+};
+
+
+struct bfa_fcs_lport_ms_s {
+       bfa_sm_t        sm;             /*  state machine */
+       struct bfa_timer_s timer;
+       struct bfa_fcs_lport_s *port;   /*  parent port */
+       struct bfa_fcxp_s *fcxp;
+       struct bfa_fcxp_wqe_s fcxp_wqe;
+       struct bfa_fcs_lport_fdmi_s fdmi;       /*  FDMI component of MS */
+       u8         retry_cnt;   /*  retry count */
+       u8      rsvd[3];
+};
+
+
+struct bfa_fcs_lport_fab_s {
+       struct bfa_fcs_lport_ns_s ns;   /*  NS component of port */
+       struct bfa_fcs_lport_scn_s scn; /*  scn component of port */
+       struct bfa_fcs_lport_ms_s ms;   /*  MS component of port */
+};
+
+#define        MAX_ALPA_COUNT  127
+
+struct bfa_fcs_lport_loop_s {
+       u8         num_alpa;    /*  Num of ALPA entries in the map */
+       u8         alpa_pos_map[MAX_ALPA_COUNT];        /*  ALPA Positional
+                                                        *Map */
+       struct bfa_fcs_lport_s *port;   /*  parent port */
+};
+
+struct bfa_fcs_lport_n2n_s {
+       u32        rsvd;
+       u16        reply_oxid;  /*  ox_id from the req flogi to be
+                                        *used in flogi acc */
+       wwn_t           rem_port_wwn;   /*  Attached port's wwn */
+};
+
+
+union bfa_fcs_lport_topo_u {
+       struct bfa_fcs_lport_fab_s pfab;
+       struct bfa_fcs_lport_loop_s ploop;
+       struct bfa_fcs_lport_n2n_s pn2n;
+};
+
+
+struct bfa_fcs_lport_s {
+       struct list_head         qe;    /*  used by port/vport */
+       bfa_sm_t               sm;      /*  state machine */
+       struct bfa_fcs_fabric_s *fabric;        /*  parent fabric */
+       struct bfa_lport_cfg_s  port_cfg;       /*  port configuration */
+       struct bfa_timer_s link_timer;  /*  timer for link offline */
+       u32        pid:24;      /*  FC address */
+       u8         lp_tag;              /*  lport tag */
+       u16        num_rports;  /*  Num of r-ports */
+       struct list_head         rport_q; /*  queue of discovered r-ports */
+       struct bfa_fcs_s *fcs;  /*  FCS instance */
+       union bfa_fcs_lport_topo_u port_topo;   /*  fabric/loop/n2n details */
+       struct bfad_port_s *bfad_port;  /*  driver peer instance */
+       struct bfa_fcs_vport_s *vport;  /*  NULL for base ports */
+       struct bfa_fcxp_s *fcxp;
+       struct bfa_fcxp_wqe_s fcxp_wqe;
+       struct bfa_lport_stats_s stats;
+       struct bfa_wc_s        wc;      /*  waiting counter for events */
+};
+#define BFA_FCS_GET_HAL_FROM_PORT(port)  (port->fcs->bfa)
+#define BFA_FCS_GET_NS_FROM_PORT(port)  (&port->port_topo.pfab.ns)
+#define BFA_FCS_GET_SCN_FROM_PORT(port)  (&port->port_topo.pfab.scn)
+#define BFA_FCS_GET_MS_FROM_PORT(port)  (&port->port_topo.pfab.ms)
+#define BFA_FCS_GET_FDMI_FROM_PORT(port)  (&port->port_topo.pfab.ms.fdmi)
+#define        BFA_FCS_VPORT_IS_INITIATOR_MODE(port) \
+               (port->port_cfg.roles & BFA_LPORT_ROLE_FCP_IM)
+
+/*
+ * forward declaration
+ */
+struct bfad_vf_s;
+
+enum bfa_fcs_fabric_type {
+       BFA_FCS_FABRIC_UNKNOWN = 0,
+       BFA_FCS_FABRIC_SWITCHED = 1,
+       BFA_FCS_FABRIC_N2N = 2,
+};
+
+
+struct bfa_fcs_fabric_s {
+       struct list_head   qe;          /*  queue element */
+       bfa_sm_t         sm;            /*  state machine */
+       struct bfa_fcs_s *fcs;          /*  FCS instance */
+       struct bfa_fcs_lport_s  bport;  /*  base logical port */
+       enum bfa_fcs_fabric_type fab_type; /*  fabric type */
+       enum bfa_port_type oper_type;   /*  current link topology */
+       u8         is_vf;               /*  is virtual fabric? */
+       u8         is_npiv;     /*  is NPIV supported ? */
+       u8         is_auth;     /*  is Security/Auth supported ? */
+       u16        bb_credit;   /*  BB credit from fabric */
+       u16        vf_id;               /*  virtual fabric ID */
+       u16        num_vports;  /*  num vports */
+       u16        rsvd;
+       struct list_head         vport_q;       /*  queue of virtual ports */
+       struct list_head         vf_q;  /*  queue of virtual fabrics */
+       struct bfad_vf_s      *vf_drv;  /*  driver vf structure */
+       struct bfa_timer_s link_timer;  /*  Link Failure timer. Vport */
+       wwn_t           fabric_name;    /*  attached fabric name */
+       bfa_boolean_t   auth_reqd;      /*  authentication required     */
+       struct bfa_timer_s delay_timer; /*  delay timer         */
+       union {
+               u16        swp_vfid;/*  switch port VF id               */
+       } event_arg;
+       struct bfa_wc_s        wc;      /*  wait counter for delete     */
+       struct bfa_vf_stats_s   stats;  /*  fabric/vf stats             */
+       struct bfa_lps_s        *lps;   /*  lport login services        */
+       u8      fabric_ip_addr[BFA_FCS_FABRIC_IPADDR_SZ];
+                                       /*  attached fabric's ip addr  */
+};
+
+#define bfa_fcs_fabric_npiv_capable(__f)    ((__f)->is_npiv)
+#define bfa_fcs_fabric_is_switched(__f)                        \
+       ((__f)->fab_type == BFA_FCS_FABRIC_SWITCHED)
+
+/**
+ *   The design calls for a single implementation of base fabric and vf.
+ */
+#define bfa_fcs_vf_t struct bfa_fcs_fabric_s
+
+struct bfa_vf_event_s {
+       u32        undefined;
+};
+
+struct bfa_fcs_s;
+struct bfa_fcs_fabric_s;
+
+/*
+ * @todo : need to move to a global config file.
+ * Maximum Rports supported per port (physical/logical).
+ */
+#define BFA_FCS_MAX_RPORTS_SUPP  256   /* @todo : tentative value */
+
+#define bfa_fcs_lport_t struct bfa_fcs_lport_s
+
+/**
+ * Symbolic Name related defines
+ *  Total bytes 255.
+ *  Physical Port's symbolic name 128 bytes.
+ *  For Vports, Vport's symbolic name is appended to the Physical port's
+ *  Symbolic Name.
+ *
+ *  Physical Port's symbolic name Format : (Total 128 bytes)
+ *  Adapter Model number/name : 12 bytes
+ *  Driver Version     : 10 bytes
+ *  Host Machine Name  : 30 bytes
+ *  Host OS Info          : 48 bytes
+ *  Host OS PATCH Info : 16 bytes
+ *  ( remaining 12 bytes reserved to be used for separator)
+ */
+#define BFA_FCS_PORT_SYMBNAME_SEPARATOR                        " | "
+
+#define BFA_FCS_PORT_SYMBNAME_MODEL_SZ                 12
+#define BFA_FCS_PORT_SYMBNAME_VERSION_SZ               10
+#define BFA_FCS_PORT_SYMBNAME_MACHINENAME_SZ           30
+#define BFA_FCS_PORT_SYMBNAME_OSINFO_SZ                        48
+#define BFA_FCS_PORT_SYMBNAME_OSPATCH_SZ               16
+
+/**
+ * Get FC port ID for a logical port.
+ */
+#define bfa_fcs_lport_get_fcid(_lport) ((_lport)->pid)
+#define bfa_fcs_lport_get_pwwn(_lport) ((_lport)->port_cfg.pwwn)
+#define bfa_fcs_lport_get_nwwn(_lport) ((_lport)->port_cfg.nwwn)
+#define bfa_fcs_lport_get_psym_name(_lport)    ((_lport)->port_cfg.sym_name)
+#define bfa_fcs_lport_is_initiator(_lport)                     \
+       ((_lport)->port_cfg.roles & BFA_LPORT_ROLE_FCP_IM)
+#define bfa_fcs_lport_get_nrports(_lport)      \
+       ((_lport) ? (_lport)->num_rports : 0)
+
+static inline struct bfad_port_s *
+bfa_fcs_lport_get_drvport(struct bfa_fcs_lport_s *port)
+{
+       return port->bfad_port;
+}
+
+#define bfa_fcs_lport_get_opertype(_lport)     ((_lport)->fabric->oper_type)
+#define bfa_fcs_lport_get_fabric_name(_lport)  ((_lport)->fabric->fabric_name)
+#define bfa_fcs_lport_get_fabric_ipaddr(_lport)                \
+               ((_lport)->fabric->fabric_ip_addr)
+
+/**
+ * bfa fcs port public functions
+ */
+
+bfa_boolean_t   bfa_fcs_lport_is_online(struct bfa_fcs_lport_s *port);
+struct bfa_fcs_lport_s *bfa_fcs_get_base_port(struct bfa_fcs_s *fcs);
+void bfa_fcs_lport_get_rports(struct bfa_fcs_lport_s *port,
+                             wwn_t rport_wwns[], int *nrports);
+
+wwn_t bfa_fcs_lport_get_rport(struct bfa_fcs_lport_s *port, wwn_t wwn,
+                             int index, int nrports, bfa_boolean_t bwwn);
+
+struct bfa_fcs_lport_s *bfa_fcs_lookup_port(struct bfa_fcs_s *fcs,
+                                           u16 vf_id, wwn_t lpwwn);
+
+void bfa_fcs_lport_get_info(struct bfa_fcs_lport_s *port,
+                           struct bfa_lport_info_s *port_info);
+void bfa_fcs_lport_get_attr(struct bfa_fcs_lport_s *port,
+                           struct bfa_lport_attr_s *port_attr);
+void bfa_fcs_lport_get_stats(struct bfa_fcs_lport_s *fcs_port,
+                            struct bfa_lport_stats_s *port_stats);
+void bfa_fcs_lport_clear_stats(struct bfa_fcs_lport_s *fcs_port);
+enum bfa_port_speed bfa_fcs_lport_get_rport_max_speed(
+                       struct bfa_fcs_lport_s *port);
+
+/* MS FCS routines */
+void bfa_fcs_lport_ms_init(struct bfa_fcs_lport_s *port);
+void bfa_fcs_lport_ms_offline(struct bfa_fcs_lport_s *port);
+void bfa_fcs_lport_ms_online(struct bfa_fcs_lport_s *port);
+void bfa_fcs_lport_ms_fabric_rscn(struct bfa_fcs_lport_s *port);
+
+/* FDMI FCS routines */
+void bfa_fcs_lport_fdmi_init(struct bfa_fcs_lport_ms_s *ms);
+void bfa_fcs_lport_fdmi_offline(struct bfa_fcs_lport_ms_s *ms);
+void bfa_fcs_lport_fdmi_online(struct bfa_fcs_lport_ms_s *ms);
+void bfa_fcs_lport_uf_recv(struct bfa_fcs_lport_s *lport, struct fchs_s *fchs,
+                                    u16 len);
+void bfa_fcs_lport_attach(struct bfa_fcs_lport_s *lport, struct bfa_fcs_s *fcs,
+                       u16 vf_id, struct bfa_fcs_vport_s *vport);
+void bfa_fcs_lport_init(struct bfa_fcs_lport_s *lport,
+                               struct bfa_lport_cfg_s *port_cfg);
+void            bfa_fcs_lport_online(struct bfa_fcs_lport_s *port);
+void            bfa_fcs_lport_offline(struct bfa_fcs_lport_s *port);
+void            bfa_fcs_lport_delete(struct bfa_fcs_lport_s *port);
+struct bfa_fcs_rport_s *bfa_fcs_lport_get_rport_by_pid(
+               struct bfa_fcs_lport_s *port, u32 pid);
+struct bfa_fcs_rport_s *bfa_fcs_lport_get_rport_by_pwwn(
+               struct bfa_fcs_lport_s *port, wwn_t pwwn);
+struct bfa_fcs_rport_s *bfa_fcs_lport_get_rport_by_nwwn(
+               struct bfa_fcs_lport_s *port, wwn_t nwwn);
+void            bfa_fcs_lport_add_rport(struct bfa_fcs_lport_s *port,
+                                      struct bfa_fcs_rport_s *rport);
+void            bfa_fcs_lport_del_rport(struct bfa_fcs_lport_s *port,
+                                      struct bfa_fcs_rport_s *rport);
+void bfa_fcs_lport_modinit(struct bfa_fcs_s *fcs);
+void bfa_fcs_lport_modexit(struct bfa_fcs_s *fcs);
+void            bfa_fcs_lport_ns_init(struct bfa_fcs_lport_s *vport);
+void            bfa_fcs_lport_ns_offline(struct bfa_fcs_lport_s *vport);
+void            bfa_fcs_lport_ns_online(struct bfa_fcs_lport_s *vport);
+void            bfa_fcs_lport_ns_query(struct bfa_fcs_lport_s *port);
+void            bfa_fcs_lport_scn_init(struct bfa_fcs_lport_s *vport);
+void            bfa_fcs_lport_scn_offline(struct bfa_fcs_lport_s *vport);
+void            bfa_fcs_lport_scn_online(struct bfa_fcs_lport_s *vport);
+void            bfa_fcs_lport_scn_process_rscn(struct bfa_fcs_lport_s *port,
+                                             struct fchs_s *rx_frame, u32 len);
+
+struct bfa_fcs_vport_s {
+       struct list_head                qe;             /*  queue elem  */
+       bfa_sm_t                sm;             /*  state machine       */
+       bfa_fcs_lport_t         lport;          /*  logical port        */
+       struct bfa_timer_s      timer;
+       struct bfad_vport_s     *vport_drv;     /*  Driver private      */
+       struct bfa_vport_stats_s vport_stats;   /*  vport statistics    */
+       struct bfa_lps_s        *lps;           /*  Lport login service*/
+       int                     fdisc_retries;
+};
+
+#define bfa_fcs_vport_get_port(vport)                  \
+       ((struct bfa_fcs_lport_s  *)(&vport->port))
+
+/**
+ * bfa fcs vport public functions
+ */
+bfa_status_t bfa_fcs_vport_create(struct bfa_fcs_vport_s *vport,
+                                 struct bfa_fcs_s *fcs, u16 vf_id,
+                                 struct bfa_lport_cfg_s *port_cfg,
+                                 struct bfad_vport_s *vport_drv);
+bfa_status_t bfa_fcs_pbc_vport_create(struct bfa_fcs_vport_s *vport,
+                                     struct bfa_fcs_s *fcs, u16 vf_id,
+                                     struct bfa_lport_cfg_s *port_cfg,
+                                     struct bfad_vport_s *vport_drv);
+bfa_boolean_t bfa_fcs_is_pbc_vport(struct bfa_fcs_vport_s *vport);
+bfa_status_t bfa_fcs_vport_delete(struct bfa_fcs_vport_s *vport);
+bfa_status_t bfa_fcs_vport_start(struct bfa_fcs_vport_s *vport);
+bfa_status_t bfa_fcs_vport_stop(struct bfa_fcs_vport_s *vport);
+void bfa_fcs_vport_get_attr(struct bfa_fcs_vport_s *vport,
+                           struct bfa_vport_attr_s *vport_attr);
+void bfa_fcs_vport_get_stats(struct bfa_fcs_vport_s *vport,
+                            struct bfa_vport_stats_s *vport_stats);
+void bfa_fcs_vport_clr_stats(struct bfa_fcs_vport_s *vport);
+struct bfa_fcs_vport_s *bfa_fcs_vport_lookup(struct bfa_fcs_s *fcs,
+                                            u16 vf_id, wwn_t vpwwn);
+void bfa_fcs_vport_cleanup(struct bfa_fcs_vport_s *vport);
+void bfa_fcs_vport_online(struct bfa_fcs_vport_s *vport);
+void bfa_fcs_vport_offline(struct bfa_fcs_vport_s *vport);
+void bfa_fcs_vport_delete_comp(struct bfa_fcs_vport_s *vport);
+void bfa_fcs_vport_fcs_delete(struct bfa_fcs_vport_s *vport);
+
+#define BFA_FCS_RPORT_DEF_DEL_TIMEOUT  90      /* in secs */
+#define BFA_FCS_RPORT_MAX_RETRIES      (5)
+
+/*
+ * forward declarations
+ */
+struct bfad_rport_s;
+
+struct bfa_fcs_itnim_s;
+struct bfa_fcs_tin_s;
+struct bfa_fcs_iprp_s;
+
+/* Rport Features (RPF) */
+struct bfa_fcs_rpf_s {
+       bfa_sm_t        sm;     /*  state machine */
+       struct bfa_fcs_rport_s *rport;  /*  parent rport */
+       struct bfa_timer_s      timer;  /*  general purpose timer */
+       struct bfa_fcxp_s       *fcxp;  /*  FCXP needed for discarding */
+       struct bfa_fcxp_wqe_s   fcxp_wqe; /*  fcxp wait queue element */
+       int     rpsc_retries;   /*  max RPSC retry attempts */
+       enum bfa_port_speed     rpsc_speed;
+       /*  Current Speed from RPSC. O if RPSC fails */
+       enum bfa_port_speed     assigned_speed;
+       /**
+        * Speed assigned by the user.  will be used if RPSC is
+        * not supported by the rport.
+        */
+};
+
+struct bfa_fcs_rport_s {
+       struct list_head        qe;     /*  used by port/vport */
+       struct bfa_fcs_lport_s *port;   /*  parent FCS port */
+       struct bfa_fcs_s        *fcs;   /*  fcs instance */
+       struct bfad_rport_s     *rp_drv;        /*  driver peer instance */
+       u32     pid;    /*  port ID of rport */
+       u16     maxfrsize;      /*  maximum frame size */
+       u16     reply_oxid;     /*  OX_ID of inbound requests */
+       enum fc_cos     fc_cos; /*  FC classes of service supp */
+       bfa_boolean_t   cisc;   /*  CISC capable device */
+       bfa_boolean_t   prlo;   /*  processing prlo or LOGO */
+       wwn_t   pwwn;   /*  port wwn of rport */
+       wwn_t   nwwn;   /*  node wwn of rport */
+       struct bfa_rport_symname_s psym_name; /*  port symbolic name  */
+       bfa_sm_t        sm;             /*  state machine */
+       struct bfa_timer_s timer;       /*  general purpose timer */
+       struct bfa_fcs_itnim_s *itnim;  /*  ITN initiator mode role */
+       struct bfa_fcs_tin_s *tin;      /*  ITN initiator mode role */
+       struct bfa_fcs_iprp_s *iprp;    /*  IP/FC role */
+       struct bfa_rport_s *bfa_rport;  /*  BFA Rport */
+       struct bfa_fcxp_s *fcxp;        /*  FCXP needed for discarding */
+       int     plogi_retries;  /*  max plogi retry attempts */
+       int     ns_retries;     /*  max NS query retry attempts */
+       struct bfa_fcxp_wqe_s   fcxp_wqe; /*  fcxp wait queue element */
+       struct bfa_rport_stats_s stats; /*  rport stats */
+       enum bfa_rport_function scsi_function;  /*  Initiator/Target */
+       struct bfa_fcs_rpf_s rpf;       /* Rport features module */
+};
+
+static inline struct bfa_rport_s *
+bfa_fcs_rport_get_halrport(struct bfa_fcs_rport_s *rport)
+{
+       return rport->bfa_rport;
+}
+
+/**
+ * bfa fcs rport API functions
+ */
+bfa_status_t bfa_fcs_rport_add(struct bfa_fcs_lport_s *port, wwn_t *pwwn,
+                              struct bfa_fcs_rport_s *rport,
+                              struct bfad_rport_s *rport_drv);
+bfa_status_t bfa_fcs_rport_remove(struct bfa_fcs_rport_s *rport);
+void bfa_fcs_rport_get_attr(struct bfa_fcs_rport_s *rport,
+                           struct bfa_rport_attr_s *attr);
+void bfa_fcs_rport_get_stats(struct bfa_fcs_rport_s *rport,
+                            struct bfa_rport_stats_s *stats);
+void bfa_fcs_rport_clear_stats(struct bfa_fcs_rport_s *rport);
+struct bfa_fcs_rport_s *bfa_fcs_rport_lookup(struct bfa_fcs_lport_s *port,
+                                            wwn_t rpwwn);
+struct bfa_fcs_rport_s *bfa_fcs_rport_lookup_by_nwwn(
+       struct bfa_fcs_lport_s *port, wwn_t rnwwn);
+void bfa_fcs_rport_set_del_timeout(u8 rport_tmo);
+
+void bfa_fcs_rport_set_speed(struct bfa_fcs_rport_s *rport,
+                            enum bfa_port_speed speed);
+void bfa_fcs_rport_uf_recv(struct bfa_fcs_rport_s *rport,
+        struct fchs_s *fchs, u16 len);
+void bfa_fcs_rport_scn(struct bfa_fcs_rport_s *rport);
+
+struct bfa_fcs_rport_s *bfa_fcs_rport_create(struct bfa_fcs_lport_s *port,
+        u32 pid);
+void bfa_fcs_rport_delete(struct bfa_fcs_rport_s *rport);
+void bfa_fcs_rport_online(struct bfa_fcs_rport_s *rport);
+void bfa_fcs_rport_offline(struct bfa_fcs_rport_s *rport);
+void bfa_fcs_rport_start(struct bfa_fcs_lport_s *port, struct fchs_s *rx_fchs,
+                        struct fc_logi_s *plogi_rsp);
+void bfa_fcs_rport_plogi_create(struct bfa_fcs_lport_s *port,
+                               struct fchs_s *rx_fchs,
+                               struct fc_logi_s *plogi);
+void bfa_fcs_rport_plogi(struct bfa_fcs_rport_s *rport, struct fchs_s *fchs,
+                        struct fc_logi_s *plogi);
+void bfa_fcs_rport_logo_imp(struct bfa_fcs_rport_s *rport);
+void bfa_fcs_rport_prlo(struct bfa_fcs_rport_s *rport, u16 ox_id);
+
+void bfa_fcs_rport_itnim_ack(struct bfa_fcs_rport_s *rport);
+void bfa_fcs_rport_itntm_ack(struct bfa_fcs_rport_s *rport);
+void bfa_fcs_rport_fcptm_offline_done(struct bfa_fcs_rport_s *rport);
+int  bfa_fcs_rport_get_state(struct bfa_fcs_rport_s *rport);
+struct bfa_fcs_rport_s *bfa_fcs_rport_create_by_wwn(
+                       struct bfa_fcs_lport_s *port, wwn_t wwn);
+void  bfa_fcs_rpf_init(struct bfa_fcs_rport_s *rport);
+void  bfa_fcs_rpf_rport_online(struct bfa_fcs_rport_s *rport);
+void  bfa_fcs_rpf_rport_offline(struct bfa_fcs_rport_s *rport);
+
+/*
+ * forward declarations
+ */
+struct bfad_itnim_s;
+
+struct bfa_fcs_itnim_s {
+       bfa_sm_t                sm;             /*  state machine */
+       struct bfa_fcs_rport_s  *rport;         /*  parent remote rport  */
+       struct bfad_itnim_s     *itnim_drv;     /*  driver peer instance */
+       struct bfa_fcs_s        *fcs;           /*  fcs instance        */
+       struct bfa_timer_s      timer;          /*  timer functions     */
+       struct bfa_itnim_s      *bfa_itnim;     /*  BFA itnim struct    */
+       u32             prli_retries;   /*  max prli retry attempts */
+       bfa_boolean_t           seq_rec;        /*  seq recovery support */
+       bfa_boolean_t           rec_support;    /*  REC supported       */
+       bfa_boolean_t           conf_comp;      /*  FCP_CONF    support */
+       bfa_boolean_t           task_retry_id;  /*  task retry id supp  */
+       struct bfa_fcxp_wqe_s   fcxp_wqe;       /*  wait qelem for fcxp  */
+       struct bfa_fcxp_s       *fcxp;          /*  FCXP in use */
+       struct bfa_itnim_stats_s        stats;  /*  itn statistics      */
+};
+#define bfa_fcs_fcxp_alloc(__fcs)      \
+       bfa_fcxp_alloc(NULL, (__fcs)->bfa, 0, 0, NULL, NULL, NULL, NULL)
+
+#define bfa_fcs_fcxp_alloc_wait(__bfa, __wqe, __alloc_cbfn, __alloc_cbarg) \
+       bfa_fcxp_alloc_wait(__bfa, __wqe, __alloc_cbfn, __alloc_cbarg, \
+                                       NULL, 0, 0, NULL, NULL, NULL, NULL)
+
+static inline struct bfad_port_s *
+bfa_fcs_itnim_get_drvport(struct bfa_fcs_itnim_s *itnim)
+{
+       return itnim->rport->port->bfad_port;
+}
+
+
+static inline struct bfa_fcs_lport_s *
+bfa_fcs_itnim_get_port(struct bfa_fcs_itnim_s *itnim)
+{
+       return itnim->rport->port;
+}
+
+
+static inline wwn_t
+bfa_fcs_itnim_get_nwwn(struct bfa_fcs_itnim_s *itnim)
+{
+       return itnim->rport->nwwn;
+}
+
+
+static inline wwn_t
+bfa_fcs_itnim_get_pwwn(struct bfa_fcs_itnim_s *itnim)
+{
+       return itnim->rport->pwwn;
+}
+
+
+static inline u32
+bfa_fcs_itnim_get_fcid(struct bfa_fcs_itnim_s *itnim)
+{
+       return itnim->rport->pid;
+}
+
+
+static inline  u32
+bfa_fcs_itnim_get_maxfrsize(struct bfa_fcs_itnim_s *itnim)
+{
+       return itnim->rport->maxfrsize;
+}
+
+
+static inline  enum fc_cos
+bfa_fcs_itnim_get_cos(struct bfa_fcs_itnim_s *itnim)
+{
+       return itnim->rport->fc_cos;
+}
+
+
+static inline struct bfad_itnim_s *
+bfa_fcs_itnim_get_drvitn(struct bfa_fcs_itnim_s *itnim)
+{
+       return itnim->itnim_drv;
+}
+
+
+static inline struct bfa_itnim_s *
+bfa_fcs_itnim_get_halitn(struct bfa_fcs_itnim_s *itnim)
+{
+       return itnim->bfa_itnim;
+}
+
+/**
+ * bfa fcs FCP Initiator mode API functions
+ */
+void bfa_fcs_itnim_get_attr(struct bfa_fcs_itnim_s *itnim,
+                           struct bfa_itnim_attr_s *attr);
+void bfa_fcs_itnim_get_stats(struct bfa_fcs_itnim_s *itnim,
+                            struct bfa_itnim_stats_s *stats);
+struct bfa_fcs_itnim_s *bfa_fcs_itnim_lookup(struct bfa_fcs_lport_s *port,
+                                            wwn_t rpwwn);
+bfa_status_t bfa_fcs_itnim_attr_get(struct bfa_fcs_lport_s *port, wwn_t rpwwn,
+                                   struct bfa_itnim_attr_s *attr);
+bfa_status_t bfa_fcs_itnim_stats_get(struct bfa_fcs_lport_s *port, wwn_t rpwwn,
+                                    struct bfa_itnim_stats_s *stats);
+bfa_status_t bfa_fcs_itnim_stats_clear(struct bfa_fcs_lport_s *port,
+                                      wwn_t rpwwn);
+struct bfa_fcs_itnim_s *bfa_fcs_itnim_create(struct bfa_fcs_rport_s *rport);
+void bfa_fcs_itnim_delete(struct bfa_fcs_itnim_s *itnim);
+void bfa_fcs_itnim_rport_offline(struct bfa_fcs_itnim_s *itnim);
+void bfa_fcs_itnim_rport_online(struct bfa_fcs_itnim_s *itnim);
+bfa_status_t bfa_fcs_itnim_get_online_state(struct bfa_fcs_itnim_s *itnim);
+void bfa_fcs_itnim_is_initiator(struct bfa_fcs_itnim_s *itnim);
+void bfa_fcs_fcpim_uf_recv(struct bfa_fcs_itnim_s *itnim,
+                       struct fchs_s *fchs, u16 len);
+
+#define        BFA_FCS_FDMI_SUPORTED_SPEEDS  (FDMI_TRANS_SPEED_1G  |   \
+                                      FDMI_TRANS_SPEED_2G |    \
+                                      FDMI_TRANS_SPEED_4G |    \
+                                      FDMI_TRANS_SPEED_8G)
+
+/*
+ * HBA Attribute Block : BFA internal representation. Note : Some variable
+ * sizes have been trimmed to suit BFA For Ex : Model will be "Brocade". Based
+ * on this the size has been reduced to 16 bytes from the standard's 64 bytes.
+ */
+struct bfa_fcs_fdmi_hba_attr_s {
+       wwn_t           node_name;
+       u8         manufacturer[64];
+       u8         serial_num[64];
+       u8         model[16];
+       u8         model_desc[256];
+       u8         hw_version[8];
+       u8         driver_version[8];
+       u8         option_rom_ver[BFA_VERSION_LEN];
+       u8         fw_version[8];
+       u8         os_name[256];
+       u32        max_ct_pyld;
+};
+
+/*
+ * Port Attribute Block
+ */
+struct bfa_fcs_fdmi_port_attr_s {
+       u8         supp_fc4_types[32];  /* supported FC4 types */
+       u32        supp_speed;  /* supported speed */
+       u32        curr_speed;  /* current Speed */
+       u32        max_frm_size;        /* max frame size */
+       u8         os_device_name[256]; /* OS device Name */
+       u8         host_name[256];      /* host name */
+};
+
+struct bfa_fcs_stats_s {
+       struct {
+               u32     untagged; /*  untagged receive frames */
+               u32     tagged; /*  tagged receive frames */
+               u32     vfid_unknown;   /*  VF id is unknown */
+       } uf;
+};
+
+struct bfa_fcs_driver_info_s {
+       u8       version[BFA_VERSION_LEN];              /* Driver Version */
+       u8       host_machine_name[BFA_FCS_OS_STR_LEN];
+       u8       host_os_name[BFA_FCS_OS_STR_LEN]; /* OS name and version */
+       u8       host_os_patch[BFA_FCS_OS_STR_LEN]; /* patch or service pack */
+       u8       os_device_name[BFA_FCS_OS_STR_LEN]; /* Driver Device Name */
+};
+
+struct bfa_fcs_s {
+       struct bfa_s      *bfa; /*  corresponding BFA bfa instance */
+       struct bfad_s         *bfad; /*  corresponding BDA driver instance */
+       struct bfa_trc_mod_s  *trcmod;  /*  tracing module */
+       bfa_boolean_t   vf_enabled;     /*  VF mode is enabled */
+       bfa_boolean_t   fdmi_enabled;   /*  FDMI is enabled */
+       bfa_boolean_t min_cfg;          /* min cfg enabled/disabled */
+       u16     port_vfid;      /*  port default VF ID */
+       struct bfa_fcs_driver_info_s driver_info;
+       struct bfa_fcs_fabric_s fabric; /*  base fabric state machine */
+       struct bfa_fcs_stats_s  stats;  /*  FCS statistics */
+       struct bfa_wc_s         wc;     /*  waiting counter */
+};
+
+/*
+ * bfa fcs API functions
+ */
+void bfa_fcs_attach(struct bfa_fcs_s *fcs, struct bfa_s *bfa,
+                   struct bfad_s *bfad,
+                   bfa_boolean_t min_cfg);
+void bfa_fcs_init(struct bfa_fcs_s *fcs);
+void bfa_fcs_driver_info_init(struct bfa_fcs_s *fcs,
+                             struct bfa_fcs_driver_info_s *driver_info);
+void bfa_fcs_set_fdmi_param(struct bfa_fcs_s *fcs, bfa_boolean_t fdmi_enable);
+void bfa_fcs_exit(struct bfa_fcs_s *fcs);
+void bfa_fcs_trc_init(struct bfa_fcs_s *fcs, struct bfa_trc_mod_s *trcmod);
+void           bfa_fcs_start(struct bfa_fcs_s *fcs);
+
+/**
+ * bfa fcs vf public functions
+ */
+bfa_status_t bfa_fcs_vf_mode_enable(struct bfa_fcs_s *fcs, u16 vf_id);
+bfa_status_t bfa_fcs_vf_mode_disable(struct bfa_fcs_s *fcs);
+bfa_status_t bfa_fcs_vf_create(bfa_fcs_vf_t *vf, struct bfa_fcs_s *fcs,
+                              u16 vf_id, struct bfa_lport_cfg_s *port_cfg,
+                              struct bfad_vf_s *vf_drv);
+bfa_status_t bfa_fcs_vf_delete(bfa_fcs_vf_t *vf);
+void bfa_fcs_vf_list(struct bfa_fcs_s *fcs, u16 *vf_ids, int *nvfs);
+void bfa_fcs_vf_list_all(struct bfa_fcs_s *fcs, u16 *vf_ids, int *nvfs);
+void bfa_fcs_vf_get_attr(bfa_fcs_vf_t *vf, struct bfa_vf_attr_s *vf_attr);
+void bfa_fcs_vf_get_stats(bfa_fcs_vf_t *vf,
+                         struct bfa_vf_stats_s *vf_stats);
+void bfa_fcs_vf_clear_stats(bfa_fcs_vf_t *vf);
+void bfa_fcs_vf_get_ports(bfa_fcs_vf_t *vf, wwn_t vpwwn[], int *nports);
+bfa_fcs_vf_t *bfa_fcs_vf_lookup(struct bfa_fcs_s *fcs, u16 vf_id);
+u16 bfa_fcs_fabric_vport_count(struct bfa_fcs_fabric_s *fabric);
+
+/*
+ * fabric protected interface functions
+ */
+void bfa_fcs_fabric_attach(struct bfa_fcs_s *fcs);
+void bfa_fcs_fabric_modinit(struct bfa_fcs_s *fcs);
+void bfa_fcs_fabric_modexit(struct bfa_fcs_s *fcs);
+void bfa_fcs_fabric_modsusp(struct bfa_fcs_s *fcs);
+void bfa_fcs_fabric_link_up(struct bfa_fcs_fabric_s *fabric);
+void bfa_fcs_fabric_link_down(struct bfa_fcs_fabric_s *fabric);
+void bfa_fcs_fabric_addvport(struct bfa_fcs_fabric_s *fabric,
+       struct bfa_fcs_vport_s *vport);
+void bfa_fcs_fabric_delvport(struct bfa_fcs_fabric_s *fabric,
+       struct bfa_fcs_vport_s *vport);
+int bfa_fcs_fabric_is_online(struct bfa_fcs_fabric_s *fabric);
+struct bfa_fcs_vport_s *bfa_fcs_fabric_vport_lookup(
+               struct bfa_fcs_fabric_s *fabric, wwn_t pwwn);
+void bfa_fcs_fabric_modstart(struct bfa_fcs_s *fcs);
+void bfa_fcs_fabric_uf_recv(struct bfa_fcs_fabric_s *fabric,
+               struct fchs_s *fchs, u16 len);
+bfa_boolean_t  bfa_fcs_fabric_is_loopback(struct bfa_fcs_fabric_s *fabric);
+bfa_boolean_t  bfa_fcs_fabric_is_auth_failed(struct bfa_fcs_fabric_s *fabric);
+enum bfa_port_type bfa_fcs_fabric_port_type(struct bfa_fcs_fabric_s *fabric);
+void   bfa_fcs_fabric_psymb_init(struct bfa_fcs_fabric_s *fabric);
+void   bfa_fcs_fabric_port_delete_comp(struct bfa_fcs_fabric_s *fabric);
+bfa_status_t   bfa_fcs_fabric_addvf(struct bfa_fcs_fabric_s *vf,
+                       struct bfa_fcs_s *fcs, struct bfa_lport_cfg_s *port_cfg,
+                       struct bfad_vf_s *vf_drv);
+void bfa_fcs_fabric_set_fabric_name(struct bfa_fcs_fabric_s *fabric,
+              wwn_t fabric_name);
+u16 bfa_fcs_fabric_get_switch_oui(struct bfa_fcs_fabric_s *fabric);
+void bfa_fcs_uf_attach(struct bfa_fcs_s *fcs);
+void bfa_fcs_port_attach(struct bfa_fcs_s *fcs);
+
+/**
+ * BFA FCS callback interfaces
+ */
+
+/**
+ * fcb Main fcs callbacks
+ */
+
+struct bfad_port_s;
+struct bfad_vf_s;
+struct bfad_vport_s;
+struct bfad_rport_s;
+
+/**
+ * lport callbacks
+ */
+struct bfad_port_s *bfa_fcb_lport_new(struct bfad_s *bfad,
+                                     struct bfa_fcs_lport_s *port,
+                                     enum bfa_lport_role roles,
+                                     struct bfad_vf_s *vf_drv,
+                                     struct bfad_vport_s *vp_drv);
+void bfa_fcb_lport_delete(struct bfad_s *bfad, enum bfa_lport_role roles,
+                         struct bfad_vf_s *vf_drv,
+                         struct bfad_vport_s *vp_drv);
+
+/**
+ * vport callbacks
+ */
+void bfa_fcb_pbc_vport_create(struct bfad_s *bfad, struct bfi_pbc_vport_s);
+
+/**
+ * rport callbacks
+ */
+bfa_status_t bfa_fcb_rport_alloc(struct bfad_s *bfad,
+                                struct bfa_fcs_rport_s **rport,
+                                struct bfad_rport_s **rport_drv);
+
+/**
+ * itnim callbacks
+ */
+void bfa_fcb_itnim_alloc(struct bfad_s *bfad, struct bfa_fcs_itnim_s **itnim,
+                        struct bfad_itnim_s **itnim_drv);
+void bfa_fcb_itnim_free(struct bfad_s *bfad,
+                       struct bfad_itnim_s *itnim_drv);
+void bfa_fcb_itnim_online(struct bfad_itnim_s *itnim_drv);
+void bfa_fcb_itnim_offline(struct bfad_itnim_s *itnim_drv);
+
+#endif /* __BFA_FCS_H__ */
diff --git a/drivers/scsi/bfa/bfa_fcs_fcpim.c b/drivers/scsi/bfa/bfa_fcs_fcpim.c
new file mode 100644 (file)
index 0000000..569dfef
--- /dev/null
@@ -0,0 +1,783 @@
+/*
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
+ * All rights reserved
+ * www.brocade.com
+ *
+ * Linux driver for Brocade Fibre Channel Host Bus Adapter.
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License (GPL) Version 2 as
+ * published by the Free Software Foundation
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * General Public License for more details.
+ */
+
+/**
+ *  fcpim.c - FCP initiator mode i-t nexus state machine
+ */
+
+#include "bfa_fcs.h"
+#include "bfa_fcbuild.h"
+#include "bfad_drv.h"
+#include "bfad_im.h"
+
+BFA_TRC_FILE(FCS, FCPIM);
+
+/*
+ * forward declarations
+ */
+static void    bfa_fcs_itnim_timeout(void *arg);
+static void    bfa_fcs_itnim_free(struct bfa_fcs_itnim_s *itnim);
+static void    bfa_fcs_itnim_send_prli(void *itnim_cbarg,
+                                       struct bfa_fcxp_s *fcxp_alloced);
+static void    bfa_fcs_itnim_prli_response(void *fcsarg,
+                        struct bfa_fcxp_s *fcxp, void *cbarg,
+                           bfa_status_t req_status, u32 rsp_len,
+                           u32 resid_len, struct fchs_s *rsp_fchs);
+
+/**
+ *  fcs_itnim_sm FCS itnim state machine events
+ */
+
+enum bfa_fcs_itnim_event {
+       BFA_FCS_ITNIM_SM_ONLINE = 1,    /*  rport online event */
+       BFA_FCS_ITNIM_SM_OFFLINE = 2,   /*  rport offline */
+       BFA_FCS_ITNIM_SM_FRMSENT = 3,   /*  prli frame is sent */
+       BFA_FCS_ITNIM_SM_RSP_OK = 4,    /*  good response */
+       BFA_FCS_ITNIM_SM_RSP_ERROR = 5, /*  error response */
+       BFA_FCS_ITNIM_SM_TIMEOUT = 6,   /*  delay timeout */
+       BFA_FCS_ITNIM_SM_HCB_OFFLINE = 7, /*  BFA online callback */
+       BFA_FCS_ITNIM_SM_HCB_ONLINE = 8, /*  BFA offline callback */
+       BFA_FCS_ITNIM_SM_INITIATOR = 9, /*  rport is initiator */
+       BFA_FCS_ITNIM_SM_DELETE = 10,   /*  delete event from rport */
+       BFA_FCS_ITNIM_SM_PRLO = 11,     /*  delete event from rport */
+};
+
+static void    bfa_fcs_itnim_sm_offline(struct bfa_fcs_itnim_s *itnim,
+                                        enum bfa_fcs_itnim_event event);
+static void    bfa_fcs_itnim_sm_prli_send(struct bfa_fcs_itnim_s *itnim,
+                                          enum bfa_fcs_itnim_event event);
+static void    bfa_fcs_itnim_sm_prli(struct bfa_fcs_itnim_s *itnim,
+                                     enum bfa_fcs_itnim_event event);
+static void    bfa_fcs_itnim_sm_prli_retry(struct bfa_fcs_itnim_s *itnim,
+                                           enum bfa_fcs_itnim_event event);
+static void    bfa_fcs_itnim_sm_hcb_online(struct bfa_fcs_itnim_s *itnim,
+                                           enum bfa_fcs_itnim_event event);
+static void    bfa_fcs_itnim_sm_online(struct bfa_fcs_itnim_s *itnim,
+                                       enum bfa_fcs_itnim_event event);
+static void    bfa_fcs_itnim_sm_hcb_offline(struct bfa_fcs_itnim_s *itnim,
+                                            enum bfa_fcs_itnim_event event);
+static void    bfa_fcs_itnim_sm_initiator(struct bfa_fcs_itnim_s *itnim,
+                                          enum bfa_fcs_itnim_event event);
+
+static struct bfa_sm_table_s itnim_sm_table[] = {
+       {BFA_SM(bfa_fcs_itnim_sm_offline), BFA_ITNIM_OFFLINE},
+       {BFA_SM(bfa_fcs_itnim_sm_prli_send), BFA_ITNIM_PRLI_SEND},
+       {BFA_SM(bfa_fcs_itnim_sm_prli), BFA_ITNIM_PRLI_SENT},
+       {BFA_SM(bfa_fcs_itnim_sm_prli_retry), BFA_ITNIM_PRLI_RETRY},
+       {BFA_SM(bfa_fcs_itnim_sm_hcb_online), BFA_ITNIM_HCB_ONLINE},
+       {BFA_SM(bfa_fcs_itnim_sm_online), BFA_ITNIM_ONLINE},
+       {BFA_SM(bfa_fcs_itnim_sm_hcb_offline), BFA_ITNIM_HCB_OFFLINE},
+       {BFA_SM(bfa_fcs_itnim_sm_initiator), BFA_ITNIM_INITIATIOR},
+};
+
+/**
+ *  fcs_itnim_sm FCS itnim state machine
+ */
+
+static void
+bfa_fcs_itnim_sm_offline(struct bfa_fcs_itnim_s *itnim,
+                enum bfa_fcs_itnim_event event)
+{
+       bfa_trc(itnim->fcs, itnim->rport->pwwn);
+       bfa_trc(itnim->fcs, event);
+
+       switch (event) {
+       case BFA_FCS_ITNIM_SM_ONLINE:
+               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_prli_send);
+               itnim->prli_retries = 0;
+               bfa_fcs_itnim_send_prli(itnim, NULL);
+               break;
+
+       case BFA_FCS_ITNIM_SM_OFFLINE:
+               bfa_fcs_rport_itnim_ack(itnim->rport);
+               break;
+
+       case BFA_FCS_ITNIM_SM_INITIATOR:
+               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_initiator);
+               break;
+
+       case BFA_FCS_ITNIM_SM_DELETE:
+               bfa_fcs_itnim_free(itnim);
+               break;
+
+       default:
+               bfa_sm_fault(itnim->fcs, event);
+       }
+
+}
+
+static void
+bfa_fcs_itnim_sm_prli_send(struct bfa_fcs_itnim_s *itnim,
+                enum bfa_fcs_itnim_event event)
+{
+       bfa_trc(itnim->fcs, itnim->rport->pwwn);
+       bfa_trc(itnim->fcs, event);
+
+       switch (event) {
+       case BFA_FCS_ITNIM_SM_FRMSENT:
+               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_prli);
+               break;
+
+       case BFA_FCS_ITNIM_SM_INITIATOR:
+               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_initiator);
+               bfa_fcxp_walloc_cancel(itnim->fcs->bfa, &itnim->fcxp_wqe);
+               break;
+
+       case BFA_FCS_ITNIM_SM_OFFLINE:
+               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_offline);
+               bfa_fcxp_walloc_cancel(itnim->fcs->bfa, &itnim->fcxp_wqe);
+               bfa_fcs_rport_itnim_ack(itnim->rport);
+               break;
+
+       case BFA_FCS_ITNIM_SM_DELETE:
+               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_offline);
+               bfa_fcxp_walloc_cancel(itnim->fcs->bfa, &itnim->fcxp_wqe);
+               bfa_fcs_itnim_free(itnim);
+               break;
+
+       default:
+               bfa_sm_fault(itnim->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_itnim_sm_prli(struct bfa_fcs_itnim_s *itnim,
+                enum bfa_fcs_itnim_event event)
+{
+       bfa_trc(itnim->fcs, itnim->rport->pwwn);
+       bfa_trc(itnim->fcs, event);
+
+       switch (event) {
+       case BFA_FCS_ITNIM_SM_RSP_OK:
+               if (itnim->rport->scsi_function == BFA_RPORT_INITIATOR) {
+                       bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_initiator);
+               } else {
+                       bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_hcb_online);
+                       bfa_itnim_online(itnim->bfa_itnim, itnim->seq_rec);
+               }
+               break;
+
+       case BFA_FCS_ITNIM_SM_RSP_ERROR:
+               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_prli_retry);
+               bfa_timer_start(itnim->fcs->bfa, &itnim->timer,
+                               bfa_fcs_itnim_timeout, itnim,
+                               BFA_FCS_RETRY_TIMEOUT);
+               break;
+
+       case BFA_FCS_ITNIM_SM_OFFLINE:
+               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_offline);
+               bfa_fcxp_discard(itnim->fcxp);
+               bfa_fcs_rport_itnim_ack(itnim->rport);
+               break;
+
+       case BFA_FCS_ITNIM_SM_INITIATOR:
+               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_initiator);
+               bfa_fcxp_discard(itnim->fcxp);
+               break;
+
+       case BFA_FCS_ITNIM_SM_DELETE:
+               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_offline);
+               bfa_fcxp_discard(itnim->fcxp);
+               bfa_fcs_itnim_free(itnim);
+               break;
+
+       default:
+               bfa_sm_fault(itnim->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_itnim_sm_prli_retry(struct bfa_fcs_itnim_s *itnim,
+                           enum bfa_fcs_itnim_event event)
+{
+       bfa_trc(itnim->fcs, itnim->rport->pwwn);
+       bfa_trc(itnim->fcs, event);
+
+       switch (event) {
+       case BFA_FCS_ITNIM_SM_TIMEOUT:
+               if (itnim->prli_retries < BFA_FCS_RPORT_MAX_RETRIES) {
+                       itnim->prli_retries++;
+                       bfa_trc(itnim->fcs, itnim->prli_retries);
+                       bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_prli_send);
+                       bfa_fcs_itnim_send_prli(itnim, NULL);
+               } else {
+                       /* invoke target offline */
+                       bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_offline);
+                       bfa_fcs_rport_logo_imp(itnim->rport);
+               }
+               break;
+
+
+       case BFA_FCS_ITNIM_SM_OFFLINE:
+               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_offline);
+               bfa_timer_stop(&itnim->timer);
+               bfa_fcs_rport_itnim_ack(itnim->rport);
+               break;
+
+       case BFA_FCS_ITNIM_SM_INITIATOR:
+               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_initiator);
+               bfa_timer_stop(&itnim->timer);
+               break;
+
+       case BFA_FCS_ITNIM_SM_DELETE:
+               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_offline);
+               bfa_timer_stop(&itnim->timer);
+               bfa_fcs_itnim_free(itnim);
+               break;
+
+       default:
+               bfa_sm_fault(itnim->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_itnim_sm_hcb_online(struct bfa_fcs_itnim_s *itnim,
+                           enum bfa_fcs_itnim_event event)
+{
+       struct bfad_s *bfad = (struct bfad_s *)itnim->fcs->bfad;
+       char    lpwwn_buf[BFA_STRING_32];
+       char    rpwwn_buf[BFA_STRING_32];
+
+       bfa_trc(itnim->fcs, itnim->rport->pwwn);
+       bfa_trc(itnim->fcs, event);
+
+       switch (event) {
+       case BFA_FCS_ITNIM_SM_HCB_ONLINE:
+               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_online);
+               bfa_fcb_itnim_online(itnim->itnim_drv);
+               wwn2str(lpwwn_buf, bfa_fcs_lport_get_pwwn(itnim->rport->port));
+               wwn2str(rpwwn_buf, itnim->rport->pwwn);
+               BFA_LOG(KERN_INFO, bfad, log_level,
+               "Target (WWN = %s) is online for initiator (WWN = %s)\n",
+               rpwwn_buf, lpwwn_buf);
+               break;
+
+       case BFA_FCS_ITNIM_SM_OFFLINE:
+               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_offline);
+               bfa_itnim_offline(itnim->bfa_itnim);
+               bfa_fcs_rport_itnim_ack(itnim->rport);
+               break;
+
+       case BFA_FCS_ITNIM_SM_DELETE:
+               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_offline);
+               bfa_fcs_itnim_free(itnim);
+               break;
+
+       default:
+               bfa_sm_fault(itnim->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_itnim_sm_online(struct bfa_fcs_itnim_s *itnim,
+                enum bfa_fcs_itnim_event event)
+{
+       struct bfad_s *bfad = (struct bfad_s *)itnim->fcs->bfad;
+       char    lpwwn_buf[BFA_STRING_32];
+       char    rpwwn_buf[BFA_STRING_32];
+
+       bfa_trc(itnim->fcs, itnim->rport->pwwn);
+       bfa_trc(itnim->fcs, event);
+
+       switch (event) {
+       case BFA_FCS_ITNIM_SM_OFFLINE:
+               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_hcb_offline);
+               bfa_fcb_itnim_offline(itnim->itnim_drv);
+               bfa_itnim_offline(itnim->bfa_itnim);
+               wwn2str(lpwwn_buf, bfa_fcs_lport_get_pwwn(itnim->rport->port));
+               wwn2str(rpwwn_buf, itnim->rport->pwwn);
+               if (bfa_fcs_lport_is_online(itnim->rport->port) == BFA_TRUE)
+                       BFA_LOG(KERN_ERR, bfad, log_level,
+                       "Target (WWN = %s) connectivity lost for "
+                       "initiator (WWN = %s)\n", rpwwn_buf, lpwwn_buf);
+               else
+                       BFA_LOG(KERN_INFO, bfad, log_level,
+                       "Target (WWN = %s) offlined by initiator (WWN = %s)\n",
+                       rpwwn_buf, lpwwn_buf);
+               break;
+
+       case BFA_FCS_ITNIM_SM_DELETE:
+               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_offline);
+               bfa_fcs_itnim_free(itnim);
+               break;
+
+       default:
+               bfa_sm_fault(itnim->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_itnim_sm_hcb_offline(struct bfa_fcs_itnim_s *itnim,
+                            enum bfa_fcs_itnim_event event)
+{
+       bfa_trc(itnim->fcs, itnim->rport->pwwn);
+       bfa_trc(itnim->fcs, event);
+
+       switch (event) {
+       case BFA_FCS_ITNIM_SM_HCB_OFFLINE:
+               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_offline);
+               bfa_fcs_rport_itnim_ack(itnim->rport);
+               break;
+
+       case BFA_FCS_ITNIM_SM_DELETE:
+               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_offline);
+               bfa_fcs_itnim_free(itnim);
+               break;
+
+       default:
+               bfa_sm_fault(itnim->fcs, event);
+       }
+}
+
+/*
+ * This state is set when a discovered rport is also in intiator mode.
+ * This ITN is marked as no_op and is not active and will not be truned into
+ * online state.
+ */
+static void
+bfa_fcs_itnim_sm_initiator(struct bfa_fcs_itnim_s *itnim,
+                enum bfa_fcs_itnim_event event)
+{
+       bfa_trc(itnim->fcs, itnim->rport->pwwn);
+       bfa_trc(itnim->fcs, event);
+
+       switch (event) {
+       case BFA_FCS_ITNIM_SM_OFFLINE:
+               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_offline);
+               bfa_fcs_rport_itnim_ack(itnim->rport);
+               break;
+
+       case BFA_FCS_ITNIM_SM_RSP_ERROR:
+       case BFA_FCS_ITNIM_SM_ONLINE:
+       case BFA_FCS_ITNIM_SM_INITIATOR:
+               break;
+
+       case BFA_FCS_ITNIM_SM_DELETE:
+               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_offline);
+               bfa_fcs_itnim_free(itnim);
+               break;
+
+       default:
+               bfa_sm_fault(itnim->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_itnim_send_prli(void *itnim_cbarg, struct bfa_fcxp_s *fcxp_alloced)
+{
+       struct bfa_fcs_itnim_s *itnim = itnim_cbarg;
+       struct bfa_fcs_rport_s *rport = itnim->rport;
+       struct bfa_fcs_lport_s *port = rport->port;
+       struct fchs_s   fchs;
+       struct bfa_fcxp_s *fcxp;
+       int             len;
+
+       bfa_trc(itnim->fcs, itnim->rport->pwwn);
+
+       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
+       if (!fcxp) {
+               itnim->stats.fcxp_alloc_wait++;
+               bfa_fcs_fcxp_alloc_wait(port->fcs->bfa, &itnim->fcxp_wqe,
+                                   bfa_fcs_itnim_send_prli, itnim);
+               return;
+       }
+       itnim->fcxp = fcxp;
+
+       len = fc_prli_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
+                           itnim->rport->pid, bfa_fcs_lport_get_fcid(port), 0);
+
+       bfa_fcxp_send(fcxp, rport->bfa_rport, port->fabric->vf_id, port->lp_tag,
+                     BFA_FALSE, FC_CLASS_3, len, &fchs,
+                     bfa_fcs_itnim_prli_response, (void *)itnim,
+                     FC_MAX_PDUSZ, FC_ELS_TOV);
+
+       itnim->stats.prli_sent++;
+       bfa_sm_send_event(itnim, BFA_FCS_ITNIM_SM_FRMSENT);
+}
+
+static void
+bfa_fcs_itnim_prli_response(void *fcsarg, struct bfa_fcxp_s *fcxp, void *cbarg,
+                           bfa_status_t req_status, u32 rsp_len,
+                           u32 resid_len, struct fchs_s *rsp_fchs)
+{
+       struct bfa_fcs_itnim_s *itnim = (struct bfa_fcs_itnim_s *) cbarg;
+       struct fc_els_cmd_s *els_cmd;
+       struct fc_prli_s *prli_resp;
+       struct fc_ls_rjt_s *ls_rjt;
+       struct fc_prli_params_s *sparams;
+
+       bfa_trc(itnim->fcs, req_status);
+
+       /*
+        * Sanity Checks
+        */
+       if (req_status != BFA_STATUS_OK) {
+               itnim->stats.prli_rsp_err++;
+               bfa_sm_send_event(itnim, BFA_FCS_ITNIM_SM_RSP_ERROR);
+               return;
+       }
+
+       els_cmd = (struct fc_els_cmd_s *) BFA_FCXP_RSP_PLD(fcxp);
+
+       if (els_cmd->els_code == FC_ELS_ACC) {
+               prli_resp = (struct fc_prli_s *) els_cmd;
+
+               if (fc_prli_rsp_parse(prli_resp, rsp_len) != FC_PARSE_OK) {
+                       bfa_trc(itnim->fcs, rsp_len);
+                       /*
+                        * Check if this  r-port is also in Initiator mode.
+                        * If so, we need to set this ITN as a no-op.
+                        */
+                       if (prli_resp->parampage.servparams.initiator) {
+                               bfa_trc(itnim->fcs, prli_resp->parampage.type);
+                               itnim->rport->scsi_function =
+                                        BFA_RPORT_INITIATOR;
+                               itnim->stats.prli_rsp_acc++;
+                               bfa_sm_send_event(itnim,
+                                                 BFA_FCS_ITNIM_SM_RSP_OK);
+                               return;
+                       }
+
+                       itnim->stats.prli_rsp_parse_err++;
+                       return;
+               }
+               itnim->rport->scsi_function = BFA_RPORT_TARGET;
+
+               sparams = &prli_resp->parampage.servparams;
+               itnim->seq_rec       = sparams->retry;
+               itnim->rec_support   = sparams->rec_support;
+               itnim->task_retry_id = sparams->task_retry_id;
+               itnim->conf_comp     = sparams->confirm;
+
+               itnim->stats.prli_rsp_acc++;
+               bfa_sm_send_event(itnim, BFA_FCS_ITNIM_SM_RSP_OK);
+       } else {
+               ls_rjt = (struct fc_ls_rjt_s *) BFA_FCXP_RSP_PLD(fcxp);
+
+               bfa_trc(itnim->fcs, ls_rjt->reason_code);
+               bfa_trc(itnim->fcs, ls_rjt->reason_code_expl);
+
+               itnim->stats.prli_rsp_rjt++;
+               bfa_sm_send_event(itnim, BFA_FCS_ITNIM_SM_RSP_ERROR);
+       }
+}
+
+static void
+bfa_fcs_itnim_timeout(void *arg)
+{
+       struct bfa_fcs_itnim_s *itnim = (struct bfa_fcs_itnim_s *) arg;
+
+       itnim->stats.timeout++;
+       bfa_sm_send_event(itnim, BFA_FCS_ITNIM_SM_TIMEOUT);
+}
+
+static void
+bfa_fcs_itnim_free(struct bfa_fcs_itnim_s *itnim)
+{
+       bfa_itnim_delete(itnim->bfa_itnim);
+       bfa_fcb_itnim_free(itnim->fcs->bfad, itnim->itnim_drv);
+}
+
+
+
+/**
+ *  itnim_public FCS ITNIM public interfaces
+ */
+
+/**
+ *     Called by rport when a new rport is created.
+ *
+ * @param[in] rport    -  remote port.
+ */
+struct bfa_fcs_itnim_s *
+bfa_fcs_itnim_create(struct bfa_fcs_rport_s *rport)
+{
+       struct bfa_fcs_lport_s *port = rport->port;
+       struct bfa_fcs_itnim_s *itnim;
+       struct bfad_itnim_s   *itnim_drv;
+       struct bfa_itnim_s *bfa_itnim;
+
+       /*
+        * call bfad to allocate the itnim
+        */
+       bfa_fcb_itnim_alloc(port->fcs->bfad, &itnim, &itnim_drv);
+       if (itnim == NULL) {
+               bfa_trc(port->fcs, rport->pwwn);
+               return NULL;
+       }
+
+       /*
+        * Initialize itnim
+        */
+       itnim->rport = rport;
+       itnim->fcs = rport->fcs;
+       itnim->itnim_drv = itnim_drv;
+
+       /*
+        * call BFA to create the itnim
+        */
+       bfa_itnim =
+               bfa_itnim_create(port->fcs->bfa, rport->bfa_rport, itnim);
+
+       if (bfa_itnim == NULL) {
+               bfa_trc(port->fcs, rport->pwwn);
+               bfa_fcb_itnim_free(port->fcs->bfad, itnim_drv);
+               bfa_assert(0);
+               return NULL;
+       }
+
+       itnim->bfa_itnim     = bfa_itnim;
+       itnim->seq_rec       = BFA_FALSE;
+       itnim->rec_support   = BFA_FALSE;
+       itnim->conf_comp     = BFA_FALSE;
+       itnim->task_retry_id = BFA_FALSE;
+
+       /*
+        * Set State machine
+        */
+       bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_offline);
+
+       return itnim;
+}
+
+/**
+ *     Called by rport to delete  the instance of FCPIM.
+ *
+ * @param[in] rport    -  remote port.
+ */
+void
+bfa_fcs_itnim_delete(struct bfa_fcs_itnim_s *itnim)
+{
+       bfa_trc(itnim->fcs, itnim->rport->pid);
+       bfa_sm_send_event(itnim, BFA_FCS_ITNIM_SM_DELETE);
+}
+
+/**
+ * Notification from rport that PLOGI is complete to initiate FC-4 session.
+ */
+void
+bfa_fcs_itnim_rport_online(struct bfa_fcs_itnim_s *itnim)
+{
+       itnim->stats.onlines++;
+
+       if (!BFA_FCS_PID_IS_WKA(itnim->rport->pid)) {
+               bfa_sm_send_event(itnim, BFA_FCS_ITNIM_SM_ONLINE);
+       } else {
+               /*
+                *  For well known addresses, we set the itnim to initiator
+                *  state
+                */
+               itnim->stats.initiator++;
+               bfa_sm_send_event(itnim, BFA_FCS_ITNIM_SM_INITIATOR);
+       }
+}
+
+/**
+ * Called by rport to handle a remote device offline.
+ */
+void
+bfa_fcs_itnim_rport_offline(struct bfa_fcs_itnim_s *itnim)
+{
+       itnim->stats.offlines++;
+       bfa_sm_send_event(itnim, BFA_FCS_ITNIM_SM_OFFLINE);
+}
+
+/**
+ * Called by rport when remote port is known to be an initiator from
+ * PRLI received.
+ */
+void
+bfa_fcs_itnim_is_initiator(struct bfa_fcs_itnim_s *itnim)
+{
+       bfa_trc(itnim->fcs, itnim->rport->pid);
+       itnim->stats.initiator++;
+       bfa_sm_send_event(itnim, BFA_FCS_ITNIM_SM_INITIATOR);
+}
+
+/**
+ * Called by rport to check if the itnim is online.
+ */
+bfa_status_t
+bfa_fcs_itnim_get_online_state(struct bfa_fcs_itnim_s *itnim)
+{
+       bfa_trc(itnim->fcs, itnim->rport->pid);
+       switch (bfa_sm_to_state(itnim_sm_table, itnim->sm)) {
+       case BFA_ITNIM_ONLINE:
+       case BFA_ITNIM_INITIATIOR:
+               return BFA_STATUS_OK;
+
+       default:
+               return BFA_STATUS_NO_FCPIM_NEXUS;
+       }
+}
+
+/**
+ * BFA completion callback for bfa_itnim_online().
+ */
+void
+bfa_cb_itnim_online(void *cbarg)
+{
+       struct bfa_fcs_itnim_s *itnim = (struct bfa_fcs_itnim_s *) cbarg;
+
+       bfa_trc(itnim->fcs, itnim->rport->pwwn);
+       bfa_sm_send_event(itnim, BFA_FCS_ITNIM_SM_HCB_ONLINE);
+}
+
+/**
+ * BFA completion callback for bfa_itnim_offline().
+ */
+void
+bfa_cb_itnim_offline(void *cb_arg)
+{
+       struct bfa_fcs_itnim_s *itnim = (struct bfa_fcs_itnim_s *) cb_arg;
+
+       bfa_trc(itnim->fcs, itnim->rport->pwwn);
+       bfa_sm_send_event(itnim, BFA_FCS_ITNIM_SM_HCB_OFFLINE);
+}
+
+/**
+ * Mark the beginning of PATH TOV handling. IO completion callbacks
+ * are still pending.
+ */
+void
+bfa_cb_itnim_tov_begin(void *cb_arg)
+{
+       struct bfa_fcs_itnim_s *itnim = (struct bfa_fcs_itnim_s *) cb_arg;
+
+       bfa_trc(itnim->fcs, itnim->rport->pwwn);
+}
+
+/**
+ * Mark the end of PATH TOV handling. All pending IOs are already cleaned up.
+ */
+void
+bfa_cb_itnim_tov(void *cb_arg)
+{
+       struct bfa_fcs_itnim_s *itnim = (struct bfa_fcs_itnim_s *) cb_arg;
+       struct bfad_itnim_s *itnim_drv = itnim->itnim_drv;
+
+       bfa_trc(itnim->fcs, itnim->rport->pwwn);
+       itnim_drv->state = ITNIM_STATE_TIMEOUT;
+}
+
+/**
+ *             BFA notification to FCS/driver for second level error recovery.
+ *
+ * Atleast one I/O request has timedout and target is unresponsive to
+ * repeated abort requests. Second level error recovery should be initiated
+ * by starting implicit logout and recovery procedures.
+ */
+void
+bfa_cb_itnim_sler(void *cb_arg)
+{
+       struct bfa_fcs_itnim_s *itnim = (struct bfa_fcs_itnim_s *) cb_arg;
+
+       itnim->stats.sler++;
+       bfa_trc(itnim->fcs, itnim->rport->pwwn);
+       bfa_fcs_rport_logo_imp(itnim->rport);
+}
+
+struct bfa_fcs_itnim_s *
+bfa_fcs_itnim_lookup(struct bfa_fcs_lport_s *port, wwn_t rpwwn)
+{
+       struct bfa_fcs_rport_s *rport;
+       rport = bfa_fcs_rport_lookup(port, rpwwn);
+
+       if (!rport)
+               return NULL;
+
+       bfa_assert(rport->itnim != NULL);
+       return rport->itnim;
+}
+
+bfa_status_t
+bfa_fcs_itnim_attr_get(struct bfa_fcs_lport_s *port, wwn_t rpwwn,
+                      struct bfa_itnim_attr_s *attr)
+{
+       struct bfa_fcs_itnim_s *itnim = NULL;
+
+       itnim = bfa_fcs_itnim_lookup(port, rpwwn);
+
+       if (itnim == NULL)
+               return BFA_STATUS_NO_FCPIM_NEXUS;
+
+       attr->state         = bfa_sm_to_state(itnim_sm_table, itnim->sm);
+       attr->retry         = itnim->seq_rec;
+       attr->rec_support   = itnim->rec_support;
+       attr->conf_comp     = itnim->conf_comp;
+       attr->task_retry_id = itnim->task_retry_id;
+       return BFA_STATUS_OK;
+}
+
+bfa_status_t
+bfa_fcs_itnim_stats_get(struct bfa_fcs_lport_s *port, wwn_t rpwwn,
+                       struct bfa_itnim_stats_s *stats)
+{
+       struct bfa_fcs_itnim_s *itnim = NULL;
+
+       bfa_assert(port != NULL);
+
+       itnim = bfa_fcs_itnim_lookup(port, rpwwn);
+
+       if (itnim == NULL)
+               return BFA_STATUS_NO_FCPIM_NEXUS;
+
+       bfa_os_memcpy(stats, &itnim->stats, sizeof(struct bfa_itnim_stats_s));
+
+       return BFA_STATUS_OK;
+}
+
+bfa_status_t
+bfa_fcs_itnim_stats_clear(struct bfa_fcs_lport_s *port, wwn_t rpwwn)
+{
+       struct bfa_fcs_itnim_s *itnim = NULL;
+
+       bfa_assert(port != NULL);
+
+       itnim = bfa_fcs_itnim_lookup(port, rpwwn);
+
+       if (itnim == NULL)
+               return BFA_STATUS_NO_FCPIM_NEXUS;
+
+       bfa_os_memset(&itnim->stats, 0, sizeof(struct bfa_itnim_stats_s));
+       return BFA_STATUS_OK;
+}
+
+void
+bfa_fcs_fcpim_uf_recv(struct bfa_fcs_itnim_s *itnim,
+                       struct fchs_s *fchs, u16 len)
+{
+       struct fc_els_cmd_s *els_cmd;
+
+       bfa_trc(itnim->fcs, fchs->type);
+
+       if (fchs->type != FC_TYPE_ELS)
+               return;
+
+       els_cmd = (struct fc_els_cmd_s *) (fchs + 1);
+
+       bfa_trc(itnim->fcs, els_cmd->els_code);
+
+       switch (els_cmd->els_code) {
+       case FC_ELS_PRLO:
+               bfa_fcs_rport_prlo(itnim->rport, fchs->ox_id);
+               break;
+
+       default:
+               bfa_assert(0);
+       }
+}
index 35df20e68a52199cba9c861345c248718537c3a5..b522bf30247a62d2f63be931b2c46dc73df4a583 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
  * All rights reserved
  * www.brocade.com
  *
  */
 
 /**
- *  bfa_fcs_port.c BFA FCS port
+ *  bfa_fcs_lport.c BFA FCS port
  */
 
-#include <fcs/bfa_fcs.h>
-#include <fcs/bfa_fcs_lport.h>
-#include <fcs/bfa_fcs_rport.h>
-#include <fcb/bfa_fcb_port.h>
-#include <bfa_svc.h>
-#include <log/bfa_log_fcs.h>
-#include "fcs.h"
-#include "fcs_lport.h"
-#include "fcs_vport.h"
-#include "fcs_rport.h"
-#include "fcs_fcxp.h"
-#include "fcs_trcmod.h"
-#include "lport_priv.h"
-#include <aen/bfa_aen_lport.h>
+#include "bfa_fcs.h"
+#include "bfa_fcbuild.h"
+#include "bfa_fc.h"
+#include "bfad_drv.h"
 
 BFA_TRC_FILE(FCS, PORT);
 
@@ -40,49 +30,53 @@ BFA_TRC_FILE(FCS, PORT);
  * Forward declarations
  */
 
-static void     bfa_fcs_port_aen_post(struct bfa_fcs_port_s *port,
-                                     enum bfa_lport_aen_event event);
-static void     bfa_fcs_port_send_ls_rjt(struct bfa_fcs_port_s *port,
-                       struct fchs_s *rx_fchs, u8 reason_code,
-                       u8 reason_code_expl);
-static void     bfa_fcs_port_plogi(struct bfa_fcs_port_s *port,
-                       struct fchs_s *rx_fchs,
-                       struct fc_logi_s *plogi);
-static void     bfa_fcs_port_online_actions(struct bfa_fcs_port_s *port);
-static void     bfa_fcs_port_offline_actions(struct bfa_fcs_port_s *port);
-static void     bfa_fcs_port_unknown_init(struct bfa_fcs_port_s *port);
-static void     bfa_fcs_port_unknown_online(struct bfa_fcs_port_s *port);
-static void     bfa_fcs_port_unknown_offline(struct bfa_fcs_port_s *port);
-static void     bfa_fcs_port_deleted(struct bfa_fcs_port_s *port);
-static void     bfa_fcs_port_echo(struct bfa_fcs_port_s *port,
+static void     bfa_fcs_lport_send_ls_rjt(struct bfa_fcs_lport_s *port,
+                                        struct fchs_s *rx_fchs, u8 reason_code,
+                                        u8 reason_code_expl);
+static void     bfa_fcs_lport_plogi(struct bfa_fcs_lport_s *port,
+                       struct fchs_s *rx_fchs, struct fc_logi_s *plogi);
+static void     bfa_fcs_lport_online_actions(struct bfa_fcs_lport_s *port);
+static void     bfa_fcs_lport_offline_actions(struct bfa_fcs_lport_s *port);
+static void     bfa_fcs_lport_unknown_init(struct bfa_fcs_lport_s *port);
+static void     bfa_fcs_lport_unknown_online(struct bfa_fcs_lport_s *port);
+static void     bfa_fcs_lport_unknown_offline(struct bfa_fcs_lport_s *port);
+static void     bfa_fcs_lport_deleted(struct bfa_fcs_lport_s *port);
+static void     bfa_fcs_lport_echo(struct bfa_fcs_lport_s *port,
                        struct fchs_s *rx_fchs,
                        struct fc_echo_s *echo, u16 len);
-static void     bfa_fcs_port_rnid(struct bfa_fcs_port_s *port,
+static void     bfa_fcs_lport_rnid(struct bfa_fcs_lport_s *port,
                        struct fchs_s *rx_fchs,
                        struct fc_rnid_cmd_s *rnid, u16 len);
-static void     bfa_fs_port_get_gen_topo_data(struct bfa_fcs_port_s *port,
+static void     bfa_fs_port_get_gen_topo_data(struct bfa_fcs_lport_s *port,
                        struct fc_rnid_general_topology_data_s *gen_topo_data);
 
+static void    bfa_fcs_lport_fab_init(struct bfa_fcs_lport_s *port);
+static void    bfa_fcs_lport_fab_online(struct bfa_fcs_lport_s *port);
+static void    bfa_fcs_lport_fab_offline(struct bfa_fcs_lport_s *port);
+
+static void    bfa_fcs_lport_n2n_init(struct bfa_fcs_lport_s *port);
+static void    bfa_fcs_lport_n2n_online(struct bfa_fcs_lport_s *port);
+static void    bfa_fcs_lport_n2n_offline(struct bfa_fcs_lport_s *port);
+
 static struct {
-       void            (*init) (struct bfa_fcs_port_s *port);
-       void            (*online) (struct bfa_fcs_port_s *port);
-       void            (*offline) (struct bfa_fcs_port_s *port);
+       void            (*init) (struct bfa_fcs_lport_s *port);
+       void            (*online) (struct bfa_fcs_lport_s *port);
+       void            (*offline) (struct bfa_fcs_lport_s *port);
 } __port_action[] = {
        {
-       bfa_fcs_port_unknown_init, bfa_fcs_port_unknown_online,
-                       bfa_fcs_port_unknown_offline}, {
-       bfa_fcs_port_fab_init, bfa_fcs_port_fab_online,
-                       bfa_fcs_port_fab_offline}, {
-       bfa_fcs_port_loop_init, bfa_fcs_port_loop_online,
-                       bfa_fcs_port_loop_offline}, {
-bfa_fcs_port_n2n_init, bfa_fcs_port_n2n_online,
-                       bfa_fcs_port_n2n_offline},};
+       bfa_fcs_lport_unknown_init, bfa_fcs_lport_unknown_online,
+                       bfa_fcs_lport_unknown_offline}, {
+       bfa_fcs_lport_fab_init, bfa_fcs_lport_fab_online,
+                       bfa_fcs_lport_fab_offline}, {
+       bfa_fcs_lport_n2n_init, bfa_fcs_lport_n2n_online,
+                       bfa_fcs_lport_n2n_offline},
+       };
 
 /**
  *  fcs_port_sm FCS logical port state machine
  */
 
-enum bfa_fcs_port_event {
+enum bfa_fcs_lport_event {
        BFA_FCS_PORT_SM_CREATE = 1,
        BFA_FCS_PORT_SM_ONLINE = 2,
        BFA_FCS_PORT_SM_OFFLINE = 3,
@@ -90,27 +84,28 @@ enum bfa_fcs_port_event {
        BFA_FCS_PORT_SM_DELRPORT = 5,
 };
 
-static void     bfa_fcs_port_sm_uninit(struct bfa_fcs_port_s *port,
-                                      enum bfa_fcs_port_event event);
-static void     bfa_fcs_port_sm_init(struct bfa_fcs_port_s *port,
-                                    enum bfa_fcs_port_event event);
-static void     bfa_fcs_port_sm_online(struct bfa_fcs_port_s *port,
-                                      enum bfa_fcs_port_event event);
-static void     bfa_fcs_port_sm_offline(struct bfa_fcs_port_s *port,
-                                       enum bfa_fcs_port_event event);
-static void     bfa_fcs_port_sm_deleting(struct bfa_fcs_port_s *port,
-                                        enum bfa_fcs_port_event event);
+static void     bfa_fcs_lport_sm_uninit(struct bfa_fcs_lport_s *port,
+                                       enum bfa_fcs_lport_event event);
+static void     bfa_fcs_lport_sm_init(struct bfa_fcs_lport_s *port,
+                                       enum bfa_fcs_lport_event event);
+static void     bfa_fcs_lport_sm_online(struct bfa_fcs_lport_s *port,
+                                       enum bfa_fcs_lport_event event);
+static void     bfa_fcs_lport_sm_offline(struct bfa_fcs_lport_s *port,
+                                       enum bfa_fcs_lport_event event);
+static void     bfa_fcs_lport_sm_deleting(struct bfa_fcs_lport_s *port,
+                                       enum bfa_fcs_lport_event event);
 
 static void
-bfa_fcs_port_sm_uninit(struct bfa_fcs_port_s *port,
-                       enum bfa_fcs_port_event event)
+bfa_fcs_lport_sm_uninit(
+       struct bfa_fcs_lport_s *port,
+       enum bfa_fcs_lport_event event)
 {
        bfa_trc(port->fcs, port->port_cfg.pwwn);
        bfa_trc(port->fcs, event);
 
        switch (event) {
        case BFA_FCS_PORT_SM_CREATE:
-               bfa_sm_set_state(port, bfa_fcs_port_sm_init);
+               bfa_sm_set_state(port, bfa_fcs_lport_sm_init);
                break;
 
        default:
@@ -119,20 +114,21 @@ bfa_fcs_port_sm_uninit(struct bfa_fcs_port_s *port,
 }
 
 static void
-bfa_fcs_port_sm_init(struct bfa_fcs_port_s *port, enum bfa_fcs_port_event event)
+bfa_fcs_lport_sm_init(struct bfa_fcs_lport_s *port,
+                       enum bfa_fcs_lport_event event)
 {
        bfa_trc(port->fcs, port->port_cfg.pwwn);
        bfa_trc(port->fcs, event);
 
        switch (event) {
        case BFA_FCS_PORT_SM_ONLINE:
-               bfa_sm_set_state(port, bfa_fcs_port_sm_online);
-               bfa_fcs_port_online_actions(port);
+               bfa_sm_set_state(port, bfa_fcs_lport_sm_online);
+               bfa_fcs_lport_online_actions(port);
                break;
 
        case BFA_FCS_PORT_SM_DELETE:
-               bfa_sm_set_state(port, bfa_fcs_port_sm_uninit);
-               bfa_fcs_port_deleted(port);
+               bfa_sm_set_state(port, bfa_fcs_lport_sm_uninit);
+               bfa_fcs_lport_deleted(port);
                break;
 
        case BFA_FCS_PORT_SM_OFFLINE:
@@ -144,19 +140,20 @@ bfa_fcs_port_sm_init(struct bfa_fcs_port_s *port, enum bfa_fcs_port_event event)
 }
 
 static void
-bfa_fcs_port_sm_online(struct bfa_fcs_port_s *port,
-                       enum bfa_fcs_port_event event)
+bfa_fcs_lport_sm_online(
+       struct bfa_fcs_lport_s *port,
+       enum bfa_fcs_lport_event event)
 {
        struct bfa_fcs_rport_s *rport;
-       struct list_head *qe, *qen;
+       struct list_head                *qe, *qen;
 
        bfa_trc(port->fcs, port->port_cfg.pwwn);
        bfa_trc(port->fcs, event);
 
        switch (event) {
        case BFA_FCS_PORT_SM_OFFLINE:
-               bfa_sm_set_state(port, bfa_fcs_port_sm_offline);
-               bfa_fcs_port_offline_actions(port);
+               bfa_sm_set_state(port, bfa_fcs_lport_sm_offline);
+               bfa_fcs_lport_offline_actions(port);
                break;
 
        case BFA_FCS_PORT_SM_DELETE:
@@ -164,12 +161,12 @@ bfa_fcs_port_sm_online(struct bfa_fcs_port_s *port,
                __port_action[port->fabric->fab_type].offline(port);
 
                if (port->num_rports == 0) {
-                       bfa_sm_set_state(port, bfa_fcs_port_sm_uninit);
-                       bfa_fcs_port_deleted(port);
+                       bfa_sm_set_state(port, bfa_fcs_lport_sm_uninit);
+                       bfa_fcs_lport_deleted(port);
                } else {
-                       bfa_sm_set_state(port, bfa_fcs_port_sm_deleting);
+                       bfa_sm_set_state(port, bfa_fcs_lport_sm_deleting);
                        list_for_each_safe(qe, qen, &port->rport_q) {
-                               rport = (struct bfa_fcs_rport_s *)qe;
+                               rport = (struct bfa_fcs_rport_s *) qe;
                                bfa_fcs_rport_delete(rport);
                        }
                }
@@ -184,29 +181,30 @@ bfa_fcs_port_sm_online(struct bfa_fcs_port_s *port,
 }
 
 static void
-bfa_fcs_port_sm_offline(struct bfa_fcs_port_s *port,
-                       enum bfa_fcs_port_event event)
+bfa_fcs_lport_sm_offline(
+       struct bfa_fcs_lport_s *port,
+       enum bfa_fcs_lport_event event)
 {
        struct bfa_fcs_rport_s *rport;
-       struct list_head *qe, *qen;
+       struct list_head                *qe, *qen;
 
        bfa_trc(port->fcs, port->port_cfg.pwwn);
        bfa_trc(port->fcs, event);
 
        switch (event) {
        case BFA_FCS_PORT_SM_ONLINE:
-               bfa_sm_set_state(port, bfa_fcs_port_sm_online);
-               bfa_fcs_port_online_actions(port);
+               bfa_sm_set_state(port, bfa_fcs_lport_sm_online);
+               bfa_fcs_lport_online_actions(port);
                break;
 
        case BFA_FCS_PORT_SM_DELETE:
                if (port->num_rports == 0) {
-                       bfa_sm_set_state(port, bfa_fcs_port_sm_uninit);
-                       bfa_fcs_port_deleted(port);
+                       bfa_sm_set_state(port, bfa_fcs_lport_sm_uninit);
+                       bfa_fcs_lport_deleted(port);
                } else {
-                       bfa_sm_set_state(port, bfa_fcs_port_sm_deleting);
+                       bfa_sm_set_state(port, bfa_fcs_lport_sm_deleting);
                        list_for_each_safe(qe, qen, &port->rport_q) {
-                               rport = (struct bfa_fcs_rport_s *)qe;
+                               rport = (struct bfa_fcs_rport_s *) qe;
                                bfa_fcs_rport_delete(rport);
                        }
                }
@@ -222,8 +220,9 @@ bfa_fcs_port_sm_offline(struct bfa_fcs_port_s *port,
 }
 
 static void
-bfa_fcs_port_sm_deleting(struct bfa_fcs_port_s *port,
-                        enum bfa_fcs_port_event event)
+bfa_fcs_lport_sm_deleting(
+       struct bfa_fcs_lport_s *port,
+       enum bfa_fcs_lport_event event)
 {
        bfa_trc(port->fcs, port->port_cfg.pwwn);
        bfa_trc(port->fcs, event);
@@ -231,8 +230,8 @@ bfa_fcs_port_sm_deleting(struct bfa_fcs_port_s *port,
        switch (event) {
        case BFA_FCS_PORT_SM_DELRPORT:
                if (port->num_rports == 0) {
-                       bfa_sm_set_state(port, bfa_fcs_port_sm_uninit);
-                       bfa_fcs_port_deleted(port);
+                       bfa_sm_set_state(port, bfa_fcs_lport_sm_uninit);
+                       bfa_fcs_lport_deleted(port);
                }
                break;
 
@@ -241,74 +240,44 @@ bfa_fcs_port_sm_deleting(struct bfa_fcs_port_s *port,
        }
 }
 
-
-
 /**
  *  fcs_port_pvt
  */
 
-/**
- * Send AEN notification
- */
-static void
-bfa_fcs_port_aen_post(struct bfa_fcs_port_s *port,
-                     enum bfa_lport_aen_event event)
-{
-       union bfa_aen_data_u aen_data;
-       struct bfa_log_mod_s *logmod = port->fcs->logm;
-       enum bfa_port_role role = port->port_cfg.roles;
-       wwn_t           lpwwn = bfa_fcs_port_get_pwwn(port);
-       char            lpwwn_ptr[BFA_STRING_32];
-       char           *role_str[BFA_PORT_ROLE_FCP_MAX / 2 + 1] =
-               { "Initiator", "Target", "IPFC" };
-
-       wwn2str(lpwwn_ptr, lpwwn);
-
-       bfa_assert(role <= BFA_PORT_ROLE_FCP_MAX);
-
-       bfa_log(logmod, BFA_LOG_CREATE_ID(BFA_AEN_CAT_LPORT, event), lpwwn_ptr,
-               role_str[role/2]);
-
-       aen_data.lport.vf_id = port->fabric->vf_id;
-       aen_data.lport.roles = role;
-       aen_data.lport.ppwwn =
-               bfa_fcs_port_get_pwwn(bfa_fcs_get_base_port(port->fcs));
-       aen_data.lport.lpwwn = lpwwn;
-}
-
 /*
  * Send a LS reject
  */
 static void
-bfa_fcs_port_send_ls_rjt(struct bfa_fcs_port_s *port, struct fchs_s *rx_fchs,
+bfa_fcs_lport_send_ls_rjt(struct bfa_fcs_lport_s *port, struct fchs_s *rx_fchs,
                         u8 reason_code, u8 reason_code_expl)
 {
-       struct fchs_s          fchs;
+       struct fchs_s   fchs;
        struct bfa_fcxp_s *fcxp;
        struct bfa_rport_s *bfa_rport = NULL;
-       int             len;
+       int             len;
 
+       bfa_trc(port->fcs, rx_fchs->d_id);
        bfa_trc(port->fcs, rx_fchs->s_id);
 
        fcxp = bfa_fcs_fcxp_alloc(port->fcs);
        if (!fcxp)
                return;
 
-       len = fc_ls_rjt_build(&fchs, bfa_fcxp_get_reqbuf(fcxp), rx_fchs->s_id,
-                             bfa_fcs_port_get_fcid(port), rx_fchs->ox_id,
-                             reason_code, reason_code_expl);
+       len = fc_ls_rjt_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
+                             rx_fchs->s_id, bfa_fcs_lport_get_fcid(port),
+                             rx_fchs->ox_id, reason_code, reason_code_expl);
 
        bfa_fcxp_send(fcxp, bfa_rport, port->fabric->vf_id, port->lp_tag,
-                     BFA_FALSE, FC_CLASS_3, len, &fchs, NULL, NULL,
-                     FC_MAX_PDUSZ, 0);
+                         BFA_FALSE, FC_CLASS_3, len, &fchs, NULL, NULL,
+                         FC_MAX_PDUSZ, 0);
 }
 
 /**
  * Process incoming plogi from a remote port.
  */
 static void
-bfa_fcs_port_plogi(struct bfa_fcs_port_s *port, struct fchs_s *rx_fchs,
-                       struct fc_logi_s *plogi)
+bfa_fcs_lport_plogi(struct bfa_fcs_lport_s *port,
+               struct fchs_s *rx_fchs, struct fc_logi_s *plogi)
 {
        struct bfa_fcs_rport_s *rport;
 
@@ -328,46 +297,40 @@ bfa_fcs_port_plogi(struct bfa_fcs_port_s *port, struct fchs_s *rx_fchs,
                /*
                 * send a LS reject
                 */
-               bfa_fcs_port_send_ls_rjt(port, rx_fchs,
-                                        FC_LS_RJT_RSN_PROTOCOL_ERROR,
-                                        FC_LS_RJT_EXP_SPARMS_ERR_OPTIONS);
+               bfa_fcs_lport_send_ls_rjt(port, rx_fchs,
+                                       FC_LS_RJT_RSN_PROTOCOL_ERROR,
+                                       FC_LS_RJT_EXP_SPARMS_ERR_OPTIONS);
                return;
        }
 
        /**
-* Direct Attach P2P mode : verify address assigned by the r-port.
+        * Direct Attach P2P mode : verify address assigned by the r-port.
         */
-       if ((!bfa_fcs_fabric_is_switched(port->fabric))
-           &&
-           (memcmp
-            ((void *)&bfa_fcs_port_get_pwwn(port), (void *)&plogi->port_name,
-             sizeof(wwn_t)) < 0)) {
+       if ((!bfa_fcs_fabric_is_switched(port->fabric)) &&
+               (memcmp((void *)&bfa_fcs_lport_get_pwwn(port),
+                          (void *)&plogi->port_name, sizeof(wwn_t)) < 0)) {
                if (BFA_FCS_PID_IS_WKA(rx_fchs->d_id)) {
-                       /*
-                        * Address assigned to us cannot be a WKA
-                        */
-                       bfa_fcs_port_send_ls_rjt(port, rx_fchs,
+                       /* Address assigned to us cannot be a WKA */
+                       bfa_fcs_lport_send_ls_rjt(port, rx_fchs,
                                        FC_LS_RJT_RSN_PROTOCOL_ERROR,
                                        FC_LS_RJT_EXP_INVALID_NPORT_ID);
                        return;
                }
-               port->pid = rx_fchs->d_id;
+               port->pid  = rx_fchs->d_id;
        }
 
        /**
         * First, check if we know the device by pwwn.
         */
-       rport = bfa_fcs_port_get_rport_by_pwwn(port, plogi->port_name);
+       rport = bfa_fcs_lport_get_rport_by_pwwn(port, plogi->port_name);
        if (rport) {
                /**
-                * Direct Attach P2P mode: handle address assigned by the rport.
-                */
-               if ((!bfa_fcs_fabric_is_switched(port->fabric))
-                   &&
-                   (memcmp
-                    ((void *)&bfa_fcs_port_get_pwwn(port),
-                     (void *)&plogi->port_name, sizeof(wwn_t)) < 0)) {
-                       port->pid = rx_fchs->d_id;
+                * Direct Attach P2P mode : handle address assigned by r-port.
+                */
+               if ((!bfa_fcs_fabric_is_switched(port->fabric)) &&
+                       (memcmp((void *)&bfa_fcs_lport_get_pwwn(port),
+                       (void *)&plogi->port_name, sizeof(wwn_t)) < 0)) {
+                       port->pid  = rx_fchs->d_id;
                        rport->pid = rx_fchs->s_id;
                }
                bfa_fcs_rport_plogi(rport, rx_fchs, plogi);
@@ -377,7 +340,7 @@ bfa_fcs_port_plogi(struct bfa_fcs_port_s *port, struct fchs_s *rx_fchs,
        /**
         * Next, lookup rport by PID.
         */
-       rport = bfa_fcs_port_get_rport_by_pid(port, rx_fchs->s_id);
+       rport = bfa_fcs_lport_get_rport_by_pid(port, rx_fchs->s_id);
        if (!rport) {
                /**
                 * Inbound PLOGI from a new device.
@@ -416,39 +379,40 @@ bfa_fcs_port_plogi(struct bfa_fcs_port_s *port, struct fchs_s *rx_fchs,
  * Since it does not require a login, it is processed here.
  */
 static void
-bfa_fcs_port_echo(struct bfa_fcs_port_s *port, struct fchs_s *rx_fchs,
-                       struct fc_echo_s *echo, u16 rx_len)
+bfa_fcs_lport_echo(struct bfa_fcs_lport_s *port, struct fchs_s *rx_fchs,
+               struct fc_echo_s *echo, u16 rx_len)
 {
-       struct fchs_s          fchs;
-       struct bfa_fcxp_s *fcxp;
-       struct bfa_rport_s *bfa_rport = NULL;
-       int             len, pyld_len;
+       struct fchs_s           fchs;
+       struct bfa_fcxp_s       *fcxp;
+       struct bfa_rport_s      *bfa_rport = NULL;
+       int                     len, pyld_len;
 
        bfa_trc(port->fcs, rx_fchs->s_id);
        bfa_trc(port->fcs, rx_fchs->d_id);
-       bfa_trc(port->fcs, rx_len);
 
        fcxp = bfa_fcs_fcxp_alloc(port->fcs);
        if (!fcxp)
                return;
 
-       len = fc_ls_acc_build(&fchs, bfa_fcxp_get_reqbuf(fcxp), rx_fchs->s_id,
-                             bfa_fcs_port_get_fcid(port), rx_fchs->ox_id);
+       len = fc_ls_acc_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
+                               rx_fchs->s_id, bfa_fcs_lport_get_fcid(port),
+                               rx_fchs->ox_id);
 
        /*
         * Copy the payload (if any) from the echo frame
         */
        pyld_len = rx_len - sizeof(struct fchs_s);
+       bfa_trc(port->fcs, rx_len);
        bfa_trc(port->fcs, pyld_len);
 
        if (pyld_len > len)
                memcpy(((u8 *) bfa_fcxp_get_reqbuf(fcxp)) +
-                      sizeof(struct fc_echo_s), (echo + 1),
-                      (pyld_len - sizeof(struct fc_echo_s)));
+                       sizeof(struct fc_echo_s), (echo + 1),
+                       (pyld_len - sizeof(struct fc_echo_s)));
 
        bfa_fcxp_send(fcxp, bfa_rport, port->fabric->vf_id, port->lp_tag,
-                     BFA_FALSE, FC_CLASS_3, pyld_len, &fchs, NULL, NULL,
-                     FC_MAX_PDUSZ, 0);
+                       BFA_FALSE, FC_CLASS_3, pyld_len, &fchs, NULL, NULL,
+                       FC_MAX_PDUSZ, 0);
 }
 
 /*
@@ -456,16 +420,16 @@ bfa_fcs_port_echo(struct bfa_fcs_port_s *port, struct fchs_s *rx_fchs,
  * Since it does not require a login, it is processed here.
  */
 static void
-bfa_fcs_port_rnid(struct bfa_fcs_port_s *port, struct fchs_s *rx_fchs,
-                       struct fc_rnid_cmd_s *rnid, u16 rx_len)
+bfa_fcs_lport_rnid(struct bfa_fcs_lport_s *port, struct fchs_s *rx_fchs,
+               struct fc_rnid_cmd_s *rnid, u16 rx_len)
 {
        struct fc_rnid_common_id_data_s common_id_data;
        struct fc_rnid_general_topology_data_s gen_topo_data;
-       struct fchs_s          fchs;
+       struct fchs_s   fchs;
        struct bfa_fcxp_s *fcxp;
        struct bfa_rport_s *bfa_rport = NULL;
-       u16        len;
-       u32        data_format;
+       u16     len;
+       u32     data_format;
 
        bfa_trc(port->fcs, rx_fchs->s_id);
        bfa_trc(port->fcs, rx_fchs->d_id);
@@ -495,28 +459,26 @@ bfa_fcs_port_rnid(struct bfa_fcs_port_s *port, struct fchs_s *rx_fchs,
        /*
         * Copy the Node Id Info
         */
-       common_id_data.port_name = bfa_fcs_port_get_pwwn(port);
-       common_id_data.node_name = bfa_fcs_port_get_nwwn(port);
+       common_id_data.port_name = bfa_fcs_lport_get_pwwn(port);
+       common_id_data.node_name = bfa_fcs_lport_get_nwwn(port);
 
-       len = fc_rnid_acc_build(&fchs, bfa_fcxp_get_reqbuf(fcxp), rx_fchs->s_id,
-                               bfa_fcs_port_get_fcid(port), rx_fchs->ox_id,
-                               data_format, &common_id_data, &gen_topo_data);
+       len = fc_rnid_acc_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
+                               rx_fchs->s_id, bfa_fcs_lport_get_fcid(port),
+                               rx_fchs->ox_id, data_format, &common_id_data,
+                               &gen_topo_data);
 
        bfa_fcxp_send(fcxp, bfa_rport, port->fabric->vf_id, port->lp_tag,
-                     BFA_FALSE, FC_CLASS_3, len, &fchs, NULL, NULL,
-                     FC_MAX_PDUSZ, 0);
-
-       return;
+                       BFA_FALSE, FC_CLASS_3, len, &fchs, NULL, NULL,
+                       FC_MAX_PDUSZ, 0);
 }
 
 /*
  *  Fill out General Topolpgy Discovery Data for RNID ELS.
  */
 static void
-bfa_fs_port_get_gen_topo_data(struct bfa_fcs_port_s *port,
+bfa_fs_port_get_gen_topo_data(struct bfa_fcs_lport_s *port,
                        struct fc_rnid_general_topology_data_s *gen_topo_data)
 {
-
        bfa_os_memset(gen_topo_data, 0,
                      sizeof(struct fc_rnid_general_topology_data_s));
 
@@ -526,76 +488,111 @@ bfa_fs_port_get_gen_topo_data(struct bfa_fcs_port_s *port,
 }
 
 static void
-bfa_fcs_port_online_actions(struct bfa_fcs_port_s *port)
+bfa_fcs_lport_online_actions(struct bfa_fcs_lport_s *port)
 {
+       struct bfad_s *bfad = (struct bfad_s *)port->fcs->bfad;
+       char    lpwwn_buf[BFA_STRING_32];
+
        bfa_trc(port->fcs, port->fabric->oper_type);
 
        __port_action[port->fabric->fab_type].init(port);
        __port_action[port->fabric->fab_type].online(port);
 
-       bfa_fcs_port_aen_post(port, BFA_LPORT_AEN_ONLINE);
-       bfa_fcb_port_online(port->fcs->bfad, port->port_cfg.roles,
-                       port->fabric->vf_drv, (port->vport == NULL) ?
-                       NULL : port->vport->vport_drv);
+       wwn2str(lpwwn_buf, bfa_fcs_lport_get_pwwn(port));
+       BFA_LOG(KERN_INFO, bfad, log_level,
+               "Logical port online: WWN = %s Role = %s\n",
+               lpwwn_buf, "Initiator");
+
+       bfad->bfad_flags |= BFAD_PORT_ONLINE;
 }
 
 static void
-bfa_fcs_port_offline_actions(struct bfa_fcs_port_s *port)
+bfa_fcs_lport_offline_actions(struct bfa_fcs_lport_s *port)
 {
-       struct list_head *qe, *qen;
+       struct list_head        *qe, *qen;
        struct bfa_fcs_rport_s *rport;
+       struct bfad_s *bfad = (struct bfad_s *)port->fcs->bfad;
+       char    lpwwn_buf[BFA_STRING_32];
 
        bfa_trc(port->fcs, port->fabric->oper_type);
 
        __port_action[port->fabric->fab_type].offline(port);
 
+       wwn2str(lpwwn_buf, bfa_fcs_lport_get_pwwn(port));
        if (bfa_fcs_fabric_is_online(port->fabric) == BFA_TRUE)
-               bfa_fcs_port_aen_post(port, BFA_LPORT_AEN_DISCONNECT);
+               BFA_LOG(KERN_ERR, bfad, log_level,
+               "Logical port lost fabric connectivity: WWN = %s Role = %s\n",
+               lpwwn_buf, "Initiator");
        else
-               bfa_fcs_port_aen_post(port, BFA_LPORT_AEN_OFFLINE);
-       bfa_fcb_port_offline(port->fcs->bfad, port->port_cfg.roles,
-                       port->fabric->vf_drv,
-                       (port->vport == NULL) ? NULL : port->vport->vport_drv);
+               BFA_LOG(KERN_INFO, bfad, log_level,
+               "Logical port taken offline: WWN = %s Role = %s\n",
+               lpwwn_buf, "Initiator");
 
        list_for_each_safe(qe, qen, &port->rport_q) {
-               rport = (struct bfa_fcs_rport_s *)qe;
+               rport = (struct bfa_fcs_rport_s *) qe;
                bfa_fcs_rport_offline(rport);
        }
 }
 
 static void
-bfa_fcs_port_unknown_init(struct bfa_fcs_port_s *port)
+bfa_fcs_lport_unknown_init(struct bfa_fcs_lport_s *port)
 {
        bfa_assert(0);
 }
 
 static void
-bfa_fcs_port_unknown_online(struct bfa_fcs_port_s *port)
+bfa_fcs_lport_unknown_online(struct bfa_fcs_lport_s *port)
 {
        bfa_assert(0);
 }
 
 static void
-bfa_fcs_port_unknown_offline(struct bfa_fcs_port_s *port)
+bfa_fcs_lport_unknown_offline(struct bfa_fcs_lport_s *port)
 {
        bfa_assert(0);
 }
 
 static void
-bfa_fcs_port_deleted(struct bfa_fcs_port_s *port)
+bfa_fcs_lport_abts_acc(struct bfa_fcs_lport_s *port, struct fchs_s *rx_fchs)
 {
-       bfa_fcs_port_aen_post(port, BFA_LPORT_AEN_DELETE);
+       struct fchs_s fchs;
+       struct bfa_fcxp_s *fcxp;
+       int             len;
 
-       /*
-        * Base port will be deleted by the OS driver
-        */
+       bfa_trc(port->fcs, rx_fchs->d_id);
+       bfa_trc(port->fcs, rx_fchs->s_id);
+
+       fcxp = bfa_fcs_fcxp_alloc(port->fcs);
+       if (!fcxp)
+               return;
+
+       len = fc_ba_acc_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
+                       rx_fchs->s_id, bfa_fcs_lport_get_fcid(port),
+                       rx_fchs->ox_id, 0);
+
+       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag,
+                         BFA_FALSE, FC_CLASS_3, len, &fchs, NULL, NULL,
+                         FC_MAX_PDUSZ, 0);
+}
+static void
+bfa_fcs_lport_deleted(struct bfa_fcs_lport_s *port)
+{
+       struct bfad_s *bfad = (struct bfad_s *)port->fcs->bfad;
+       char    lpwwn_buf[BFA_STRING_32];
+
+       wwn2str(lpwwn_buf, bfa_fcs_lport_get_pwwn(port));
+       BFA_LOG(KERN_INFO, bfad, log_level,
+               "Logical port deleted: WWN = %s Role = %s\n",
+               lpwwn_buf, "Initiator");
+
+       /* Base port will be deleted by the OS driver */
        if (port->vport) {
-               bfa_fcb_port_delete(port->fcs->bfad, port->port_cfg.roles,
-                       port->fabric->vf_drv,
-                       port->vport ? port->vport->vport_drv : NULL);
+               bfa_fcb_lport_delete(port->fcs->bfad, port->port_cfg.roles,
+                               port->fabric->vf_drv,
+                               port->vport ? port->vport->vport_drv : NULL);
                bfa_fcs_vport_delete_comp(port->vport);
        } else {
-               bfa_fcs_fabric_port_delete_comp(port->fabric);
+                bfa_fcs_fabric_port_delete_comp(port->fabric);
        }
 }
 
@@ -608,7 +605,7 @@ bfa_fcs_port_deleted(struct bfa_fcs_port_s *port)
  *   Module initialization
  */
 void
-bfa_fcs_port_modinit(struct bfa_fcs_s *fcs)
+bfa_fcs_lport_modinit(struct bfa_fcs_s *fcs)
 {
 
 }
@@ -617,25 +614,25 @@ bfa_fcs_port_modinit(struct bfa_fcs_s *fcs)
  *   Module cleanup
  */
 void
-bfa_fcs_port_modexit(struct bfa_fcs_s *fcs)
+bfa_fcs_lport_modexit(struct bfa_fcs_s *fcs)
 {
        bfa_fcs_modexit_comp(fcs);
 }
 
 /**
- *             Unsolicited frame receive handling.
+ * Unsolicited frame receive handling.
  */
 void
-bfa_fcs_port_uf_recv(struct bfa_fcs_port_s *lport, struct fchs_s *fchs,
-                       u16 len)
+bfa_fcs_lport_uf_recv(struct bfa_fcs_lport_s *lport,
+                       struct fchs_s *fchs, u16 len)
 {
-       u32        pid = fchs->s_id;
+       u32     pid = fchs->s_id;
        struct bfa_fcs_rport_s *rport = NULL;
-       struct fc_els_cmd_s   *els_cmd = (struct fc_els_cmd_s *) (fchs + 1);
+       struct fc_els_cmd_s *els_cmd = (struct fc_els_cmd_s *) (fchs + 1);
 
        bfa_stats(lport, uf_recvs);
 
-       if (!bfa_fcs_port_is_online(lport)) {
+       if (!bfa_fcs_lport_is_online(lport)) {
                bfa_stats(lport, uf_recv_drops);
                return;
        }
@@ -648,7 +645,7 @@ bfa_fcs_port_uf_recv(struct bfa_fcs_port_s *lport, struct fchs_s *fchs,
         */
        if ((fchs->type == FC_TYPE_ELS) &&
                (els_cmd->els_code == FC_ELS_PLOGI)) {
-               bfa_fcs_port_plogi(lport, fchs, (struct fc_logi_s *) els_cmd);
+               bfa_fcs_lport_plogi(lport, fchs, (struct fc_logi_s *) els_cmd);
                return;
        }
 
@@ -656,8 +653,8 @@ bfa_fcs_port_uf_recv(struct bfa_fcs_port_s *lport, struct fchs_s *fchs,
         * Handle ECHO separately.
         */
        if ((fchs->type == FC_TYPE_ELS) && (els_cmd->els_code == FC_ELS_ECHO)) {
-               bfa_fcs_port_echo(lport, fchs,
-                       (struct fc_echo_s *) els_cmd, len);
+               bfa_fcs_lport_echo(lport, fchs,
+                               (struct fc_echo_s *)els_cmd, len);
                return;
        }
 
@@ -665,15 +662,21 @@ bfa_fcs_port_uf_recv(struct bfa_fcs_port_s *lport, struct fchs_s *fchs,
         * Handle RNID separately.
         */
        if ((fchs->type == FC_TYPE_ELS) && (els_cmd->els_code == FC_ELS_RNID)) {
-               bfa_fcs_port_rnid(lport, fchs,
+               bfa_fcs_lport_rnid(lport, fchs,
                        (struct fc_rnid_cmd_s *) els_cmd, len);
                return;
        }
 
+       if (fchs->type == FC_TYPE_BLS) {
+               if ((fchs->routing == FC_RTG_BASIC_LINK) &&
+                               (fchs->cat_info == FC_CAT_ABTS))
+                       bfa_fcs_lport_abts_acc(lport, fchs);
+               return;
+       }
        /**
         * look for a matching remote port ID
         */
-       rport = bfa_fcs_port_get_rport_by_pid(lport, pid);
+       rport = bfa_fcs_lport_get_rport_by_pid(lport, pid);
        if (rport) {
                bfa_trc(rport->fcs, fchs->s_id);
                bfa_trc(rport->fcs, fchs->d_id);
@@ -694,7 +697,7 @@ bfa_fcs_port_uf_recv(struct bfa_fcs_port_s *lport, struct fchs_s *fchs,
 
        bfa_trc(lport->fcs, els_cmd->els_code);
        if (els_cmd->els_code == FC_ELS_RSCN) {
-               bfa_fcs_port_scn_process_rscn(lport, fchs, len);
+               bfa_fcs_lport_scn_process_rscn(lport, fchs, len);
                return;
        }
 
@@ -702,7 +705,6 @@ bfa_fcs_port_uf_recv(struct bfa_fcs_port_s *lport, struct fchs_s *fchs,
                /**
                 * @todo Handle LOGO frames received.
                 */
-               bfa_trc(lport->fcs, els_cmd->els_code);
                return;
        }
 
@@ -710,14 +712,13 @@ bfa_fcs_port_uf_recv(struct bfa_fcs_port_s *lport, struct fchs_s *fchs,
                /**
                 * @todo Handle PRLI frames received.
                 */
-               bfa_trc(lport->fcs, els_cmd->els_code);
                return;
        }
 
        /**
         * Unhandled ELS frames. Send a LS_RJT.
         */
-       bfa_fcs_port_send_ls_rjt(lport, fchs, FC_LS_RJT_RSN_CMD_NOT_SUPP,
+       bfa_fcs_lport_send_ls_rjt(lport, fchs, FC_LS_RJT_RSN_CMD_NOT_SUPP,
                                 FC_LS_RJT_EXP_NO_ADDL_INFO);
 
 }
@@ -726,13 +727,13 @@ bfa_fcs_port_uf_recv(struct bfa_fcs_port_s *lport, struct fchs_s *fchs,
  *   PID based Lookup for a R-Port in the Port R-Port Queue
  */
 struct bfa_fcs_rport_s *
-bfa_fcs_port_get_rport_by_pid(struct bfa_fcs_port_s *port, u32 pid)
+bfa_fcs_lport_get_rport_by_pid(struct bfa_fcs_lport_s *port, u32 pid)
 {
        struct bfa_fcs_rport_s *rport;
-       struct list_head *qe;
+       struct list_head        *qe;
 
        list_for_each(qe, &port->rport_q) {
-               rport = (struct bfa_fcs_rport_s *)qe;
+               rport = (struct bfa_fcs_rport_s *) qe;
                if (rport->pid == pid)
                        return rport;
        }
@@ -745,13 +746,13 @@ bfa_fcs_port_get_rport_by_pid(struct bfa_fcs_port_s *port, u32 pid)
  *   PWWN based Lookup for a R-Port in the Port R-Port Queue
  */
 struct bfa_fcs_rport_s *
-bfa_fcs_port_get_rport_by_pwwn(struct bfa_fcs_port_s *port, wwn_t pwwn)
+bfa_fcs_lport_get_rport_by_pwwn(struct bfa_fcs_lport_s *port, wwn_t pwwn)
 {
        struct bfa_fcs_rport_s *rport;
-       struct list_head *qe;
+       struct list_head        *qe;
 
        list_for_each(qe, &port->rport_q) {
-               rport = (struct bfa_fcs_rport_s *)qe;
+               rport = (struct bfa_fcs_rport_s *) qe;
                if (wwn_is_equal(rport->pwwn, pwwn))
                        return rport;
        }
@@ -764,13 +765,13 @@ bfa_fcs_port_get_rport_by_pwwn(struct bfa_fcs_port_s *port, wwn_t pwwn)
  *   NWWN based Lookup for a R-Port in the Port R-Port Queue
  */
 struct bfa_fcs_rport_s *
-bfa_fcs_port_get_rport_by_nwwn(struct bfa_fcs_port_s *port, wwn_t nwwn)
+bfa_fcs_lport_get_rport_by_nwwn(struct bfa_fcs_lport_s *port, wwn_t nwwn)
 {
        struct bfa_fcs_rport_s *rport;
-       struct list_head *qe;
+       struct list_head        *qe;
 
        list_for_each(qe, &port->rport_q) {
-               rport = (struct bfa_fcs_rport_s *)qe;
+               rport = (struct bfa_fcs_rport_s *) qe;
                if (wwn_is_equal(rport->nwwn, nwwn))
                        return rport;
        }
@@ -783,8 +784,9 @@ bfa_fcs_port_get_rport_by_nwwn(struct bfa_fcs_port_s *port, wwn_t nwwn)
  * Called by rport module when new rports are discovered.
  */
 void
-bfa_fcs_port_add_rport(struct bfa_fcs_port_s *port,
-                      struct bfa_fcs_rport_s *rport)
+bfa_fcs_lport_add_rport(
+       struct bfa_fcs_lport_s *port,
+       struct bfa_fcs_rport_s *rport)
 {
        list_add_tail(&rport->qe, &port->rport_q);
        port->num_rports++;
@@ -794,8 +796,9 @@ bfa_fcs_port_add_rport(struct bfa_fcs_port_s *port,
  * Called by rport module to when rports are deleted.
  */
 void
-bfa_fcs_port_del_rport(struct bfa_fcs_port_s *port,
-                      struct bfa_fcs_rport_s *rport)
+bfa_fcs_lport_del_rport(
+       struct bfa_fcs_lport_s *port,
+       struct bfa_fcs_rport_s *rport)
 {
        bfa_assert(bfa_q_is_on_q(&port->rport_q, rport));
        list_del(&rport->qe);
@@ -809,7 +812,7 @@ bfa_fcs_port_del_rport(struct bfa_fcs_port_s *port,
  * Called by vport for virtual ports when FDISC is complete.
  */
 void
-bfa_fcs_port_online(struct bfa_fcs_port_s *port)
+bfa_fcs_lport_online(struct bfa_fcs_lport_s *port)
 {
        bfa_sm_send_event(port, BFA_FCS_PORT_SM_ONLINE);
 }
@@ -819,7 +822,7 @@ bfa_fcs_port_online(struct bfa_fcs_port_s *port)
  * Called by vport for virtual ports when virtual port becomes offline.
  */
 void
-bfa_fcs_port_offline(struct bfa_fcs_port_s *port)
+bfa_fcs_lport_offline(struct bfa_fcs_lport_s *port)
 {
        bfa_sm_send_event(port, BFA_FCS_PORT_SM_OFFLINE);
 }
@@ -831,40 +834,32 @@ bfa_fcs_port_offline(struct bfa_fcs_port_s *port)
  * bfa_fcs_vport_delete_comp() for vports on completion.
  */
 void
-bfa_fcs_port_delete(struct bfa_fcs_port_s *port)
+bfa_fcs_lport_delete(struct bfa_fcs_lport_s *port)
 {
        bfa_sm_send_event(port, BFA_FCS_PORT_SM_DELETE);
 }
 
-/**
- * Called by fabric in private loop topology to process LIP event.
- */
-void
-bfa_fcs_port_lip(struct bfa_fcs_port_s *port)
-{
-}
-
 /**
  * Return TRUE if port is online, else return FALSE
  */
 bfa_boolean_t
-bfa_fcs_port_is_online(struct bfa_fcs_port_s *port)
+bfa_fcs_lport_is_online(struct bfa_fcs_lport_s *port)
 {
-       return bfa_sm_cmp_state(port, bfa_fcs_port_sm_online);
+       return bfa_sm_cmp_state(port, bfa_fcs_lport_sm_online);
 }
 
 /**
- * Attach time initialization of logical ports.
 * Attach time initialization of logical ports.
  */
 void
-bfa_fcs_lport_attach(struct bfa_fcs_port_s *lport, struct bfa_fcs_s *fcs,
-               uint16_t vf_id, struct bfa_fcs_vport_s *vport)
+bfa_fcs_lport_attach(struct bfa_fcs_lport_s *lport, struct bfa_fcs_s *fcs,
+                  u16 vf_id, struct bfa_fcs_vport_s *vport)
 {
        lport->fcs = fcs;
        lport->fabric = bfa_fcs_vf_lookup(fcs, vf_id);
        lport->vport = vport;
        lport->lp_tag = (vport) ? bfa_lps_get_tag(vport->lps) :
-                        bfa_lps_get_tag(lport->fabric->lps);
+                                 bfa_lps_get_tag(lport->fabric->lps);
 
        INIT_LIST_HEAD(&lport->rport_q);
        lport->num_rports = 0;
@@ -876,21 +871,26 @@ bfa_fcs_lport_attach(struct bfa_fcs_port_s *lport, struct bfa_fcs_s *fcs,
  */
 
 void
-bfa_fcs_lport_init(struct bfa_fcs_port_s *lport,
-               struct bfa_port_cfg_s *port_cfg)
+bfa_fcs_lport_init(struct bfa_fcs_lport_s *lport,
+       struct bfa_lport_cfg_s *port_cfg)
 {
        struct bfa_fcs_vport_s *vport = lport->vport;
+       struct bfad_s *bfad = (struct bfad_s *)lport->fcs->bfad;
+       char    lpwwn_buf[BFA_STRING_32];
 
        bfa_os_assign(lport->port_cfg, *port_cfg);
 
-       lport->bfad_port = bfa_fcb_port_new(lport->fcs->bfad, lport,
-                               lport->port_cfg.roles,
-                               lport->fabric->vf_drv,
-                               vport ? vport->vport_drv : NULL);
+       lport->bfad_port = bfa_fcb_lport_new(lport->fcs->bfad, lport,
+                                       lport->port_cfg.roles,
+                                       lport->fabric->vf_drv,
+                                       vport ? vport->vport_drv : NULL);
 
-       bfa_fcs_port_aen_post(lport, BFA_LPORT_AEN_NEW);
+       wwn2str(lpwwn_buf, bfa_fcs_lport_get_pwwn(lport));
+       BFA_LOG(KERN_INFO, bfad, log_level,
+               "New logical port created: WWN = %s Role = %s\n",
+               lpwwn_buf, "Initiator");
 
-       bfa_sm_set_state(lport, bfa_fcs_port_sm_uninit);
+       bfa_sm_set_state(lport, bfa_fcs_lport_sm_uninit);
        bfa_sm_send_event(lport, BFA_FCS_PORT_SM_CREATE);
 }
 
@@ -899,10 +899,11 @@ bfa_fcs_lport_init(struct bfa_fcs_port_s *lport,
  */
 
 void
-bfa_fcs_port_get_attr(struct bfa_fcs_port_s *port,
-                     struct bfa_port_attr_s *port_attr)
+bfa_fcs_lport_get_attr(
+       struct bfa_fcs_lport_s *port,
+       struct bfa_lport_attr_s *port_attr)
 {
-       if (bfa_sm_cmp_state(port, bfa_fcs_port_sm_online))
+       if (bfa_sm_cmp_state(port, bfa_fcs_lport_sm_online))
                port_attr->pid = port->pid;
        else
                port_attr->pid = 0;
@@ -913,25 +914,4895 @@ bfa_fcs_port_get_attr(struct bfa_fcs_port_s *port,
                port_attr->port_type = bfa_fcs_fabric_port_type(port->fabric);
                port_attr->loopback = bfa_fcs_fabric_is_loopback(port->fabric);
                port_attr->authfail =
-                               bfa_fcs_fabric_is_auth_failed(port->fabric);
-               port_attr->fabric_name = bfa_fcs_port_get_fabric_name(port);
+                       bfa_fcs_fabric_is_auth_failed(port->fabric);
+               port_attr->fabric_name  = bfa_fcs_lport_get_fabric_name(port);
                memcpy(port_attr->fabric_ip_addr,
-                      bfa_fcs_port_get_fabric_ipaddr(port),
-                      BFA_FCS_FABRIC_IPADDR_SZ);
+                       bfa_fcs_lport_get_fabric_ipaddr(port),
+                       BFA_FCS_FABRIC_IPADDR_SZ);
 
                if (port->vport != NULL) {
-                       port_attr->port_type = BFA_PPORT_TYPE_VPORT;
+                       port_attr->port_type = BFA_PORT_TYPE_VPORT;
                        port_attr->fpma_mac =
                                bfa_lps_get_lp_mac(port->vport->lps);
-               } else
+               } else {
                        port_attr->fpma_mac =
                                bfa_lps_get_lp_mac(port->fabric->lps);
-
+               }
        } else {
-               port_attr->port_type = BFA_PPORT_TYPE_UNKNOWN;
-               port_attr->state = BFA_PORT_UNINIT;
+               port_attr->port_type = BFA_PORT_TYPE_UNKNOWN;
+               port_attr->state = BFA_LPORT_UNINIT;
+       }
+}
+
+/**
+ *  bfa_fcs_lport_fab port fab functions
+ */
+
+/**
+ *   Called by port to initialize fabric services of the base port.
+ */
+static void
+bfa_fcs_lport_fab_init(struct bfa_fcs_lport_s *port)
+{
+       bfa_fcs_lport_ns_init(port);
+       bfa_fcs_lport_scn_init(port);
+       bfa_fcs_lport_ms_init(port);
+}
+
+/**
+ *   Called by port to notify transition to online state.
+ */
+static void
+bfa_fcs_lport_fab_online(struct bfa_fcs_lport_s *port)
+{
+       bfa_fcs_lport_ns_online(port);
+       bfa_fcs_lport_scn_online(port);
+}
+
+/**
+ *   Called by port to notify transition to offline state.
+ */
+static void
+bfa_fcs_lport_fab_offline(struct bfa_fcs_lport_s *port)
+{
+       bfa_fcs_lport_ns_offline(port);
+       bfa_fcs_lport_scn_offline(port);
+       bfa_fcs_lport_ms_offline(port);
+}
+
+/**
+ *  bfa_fcs_lport_n2n  functions
+ */
+
+/**
+ *   Called by fcs/port to initialize N2N topology.
+ */
+static void
+bfa_fcs_lport_n2n_init(struct bfa_fcs_lport_s *port)
+{
+}
+
+/**
+ *   Called by fcs/port to notify transition to online state.
+ */
+static void
+bfa_fcs_lport_n2n_online(struct bfa_fcs_lport_s *port)
+{
+       struct bfa_fcs_lport_n2n_s *n2n_port = &port->port_topo.pn2n;
+       struct bfa_lport_cfg_s *pcfg = &port->port_cfg;
+       struct bfa_fcs_rport_s *rport;
+
+       bfa_trc(port->fcs, pcfg->pwwn);
+
+       /*
+        * If our PWWN is > than that of the r-port, we have to initiate PLOGI
+        * and assign an Address. if not, we need to wait for its PLOGI.
+        *
+        * If our PWWN is < than that of the remote port, it will send a PLOGI
+        * with the PIDs assigned. The rport state machine take care of this
+        * incoming PLOGI.
+        */
+       if (memcmp
+           ((void *)&pcfg->pwwn, (void *)&n2n_port->rem_port_wwn,
+            sizeof(wwn_t)) > 0) {
+               port->pid = N2N_LOCAL_PID;
+               /**
+                * First, check if we know the device by pwwn.
+                */
+               rport = bfa_fcs_lport_get_rport_by_pwwn(port,
+                                                       n2n_port->rem_port_wwn);
+               if (rport) {
+                       bfa_trc(port->fcs, rport->pid);
+                       bfa_trc(port->fcs, rport->pwwn);
+                       rport->pid = N2N_REMOTE_PID;
+                       bfa_fcs_rport_online(rport);
+                       return;
+               }
+
+               /*
+                * In n2n there can be only one rport. Delete the old one
+                * whose pid should be zero, because it is offline.
+                */
+               if (port->num_rports > 0) {
+                       rport = bfa_fcs_lport_get_rport_by_pid(port, 0);
+                       bfa_assert(rport != NULL);
+                       if (rport) {
+                               bfa_trc(port->fcs, rport->pwwn);
+                               bfa_fcs_rport_delete(rport);
+                       }
+               }
+               bfa_fcs_rport_create(port, N2N_REMOTE_PID);
+       }
+}
+
+/**
+ *   Called by fcs/port to notify transition to offline state.
+ */
+static void
+bfa_fcs_lport_n2n_offline(struct bfa_fcs_lport_s *port)
+{
+       struct bfa_fcs_lport_n2n_s *n2n_port = &port->port_topo.pn2n;
+
+       bfa_trc(port->fcs, port->pid);
+       port->pid = 0;
+       n2n_port->rem_port_wwn = 0;
+       n2n_port->reply_oxid = 0;
+}
+
+#define BFA_FCS_FDMI_CMD_MAX_RETRIES 2
+
+/*
+ * forward declarations
+ */
+static void     bfa_fcs_lport_fdmi_send_rhba(void *fdmi_cbarg,
+                                           struct bfa_fcxp_s *fcxp_alloced);
+static void     bfa_fcs_lport_fdmi_send_rprt(void *fdmi_cbarg,
+                                           struct bfa_fcxp_s *fcxp_alloced);
+static void     bfa_fcs_lport_fdmi_send_rpa(void *fdmi_cbarg,
+                                          struct bfa_fcxp_s *fcxp_alloced);
+static void     bfa_fcs_lport_fdmi_rhba_response(void *fcsarg,
+                                               struct bfa_fcxp_s *fcxp,
+                                               void *cbarg,
+                                               bfa_status_t req_status,
+                                               u32 rsp_len,
+                                               u32 resid_len,
+                                               struct fchs_s *rsp_fchs);
+static void     bfa_fcs_lport_fdmi_rprt_response(void *fcsarg,
+                                               struct bfa_fcxp_s *fcxp,
+                                               void *cbarg,
+                                               bfa_status_t req_status,
+                                               u32 rsp_len,
+                                               u32 resid_len,
+                                               struct fchs_s *rsp_fchs);
+static void     bfa_fcs_lport_fdmi_rpa_response(void *fcsarg,
+                                              struct bfa_fcxp_s *fcxp,
+                                              void *cbarg,
+                                              bfa_status_t req_status,
+                                              u32 rsp_len,
+                                              u32 resid_len,
+                                              struct fchs_s *rsp_fchs);
+static void     bfa_fcs_lport_fdmi_timeout(void *arg);
+static u16 bfa_fcs_lport_fdmi_build_rhba_pyld(struct bfa_fcs_lport_fdmi_s *fdmi,
+                                                 u8 *pyld);
+static u16 bfa_fcs_lport_fdmi_build_rprt_pyld(struct bfa_fcs_lport_fdmi_s *fdmi,
+                                                 u8 *pyld);
+static u16 bfa_fcs_lport_fdmi_build_rpa_pyld(struct bfa_fcs_lport_fdmi_s *fdmi,
+                                                u8 *pyld);
+static u16 bfa_fcs_lport_fdmi_build_portattr_block(struct bfa_fcs_lport_fdmi_s *
+                                                      fdmi, u8 *pyld);
+static void    bfa_fcs_fdmi_get_hbaattr(struct bfa_fcs_lport_fdmi_s *fdmi,
+                                struct bfa_fcs_fdmi_hba_attr_s *hba_attr);
+static void    bfa_fcs_fdmi_get_portattr(struct bfa_fcs_lport_fdmi_s *fdmi,
+                                 struct bfa_fcs_fdmi_port_attr_s *port_attr);
+/**
+ *  fcs_fdmi_sm FCS FDMI state machine
+ */
+
+/**
+ *  FDMI State Machine events
+ */
+enum port_fdmi_event {
+       FDMISM_EVENT_PORT_ONLINE = 1,
+       FDMISM_EVENT_PORT_OFFLINE = 2,
+       FDMISM_EVENT_RSP_OK = 4,
+       FDMISM_EVENT_RSP_ERROR = 5,
+       FDMISM_EVENT_TIMEOUT = 6,
+       FDMISM_EVENT_RHBA_SENT = 7,
+       FDMISM_EVENT_RPRT_SENT = 8,
+       FDMISM_EVENT_RPA_SENT = 9,
+};
+
+static void     bfa_fcs_lport_fdmi_sm_offline(struct bfa_fcs_lport_fdmi_s *fdmi,
+                                            enum port_fdmi_event event);
+static void     bfa_fcs_lport_fdmi_sm_sending_rhba(
+                               struct bfa_fcs_lport_fdmi_s *fdmi,
+                               enum port_fdmi_event event);
+static void     bfa_fcs_lport_fdmi_sm_rhba(struct bfa_fcs_lport_fdmi_s *fdmi,
+                                         enum port_fdmi_event event);
+static void     bfa_fcs_lport_fdmi_sm_rhba_retry(
+                               struct bfa_fcs_lport_fdmi_s *fdmi,
+                               enum port_fdmi_event event);
+static void     bfa_fcs_lport_fdmi_sm_sending_rprt(
+                               struct bfa_fcs_lport_fdmi_s *fdmi,
+                               enum port_fdmi_event event);
+static void     bfa_fcs_lport_fdmi_sm_rprt(struct bfa_fcs_lport_fdmi_s *fdmi,
+                                         enum port_fdmi_event event);
+static void     bfa_fcs_lport_fdmi_sm_rprt_retry(
+                               struct bfa_fcs_lport_fdmi_s *fdmi,
+                               enum port_fdmi_event event);
+static void     bfa_fcs_lport_fdmi_sm_sending_rpa(
+                               struct bfa_fcs_lport_fdmi_s *fdmi,
+                               enum port_fdmi_event event);
+static void     bfa_fcs_lport_fdmi_sm_rpa(struct bfa_fcs_lport_fdmi_s *fdmi,
+                                        enum port_fdmi_event event);
+static void     bfa_fcs_lport_fdmi_sm_rpa_retry(
+                               struct bfa_fcs_lport_fdmi_s *fdmi,
+                               enum port_fdmi_event event);
+static void     bfa_fcs_lport_fdmi_sm_online(struct bfa_fcs_lport_fdmi_s *fdmi,
+                                           enum port_fdmi_event event);
+static void     bfa_fcs_lport_fdmi_sm_disabled(
+                               struct bfa_fcs_lport_fdmi_s *fdmi,
+                               enum port_fdmi_event event);
+/**
+ *     Start in offline state - awaiting MS to send start.
+ */
+static void
+bfa_fcs_lport_fdmi_sm_offline(struct bfa_fcs_lport_fdmi_s *fdmi,
+                            enum port_fdmi_event event)
+{
+       struct bfa_fcs_lport_s *port = fdmi->ms->port;
+
+       bfa_trc(port->fcs, port->port_cfg.pwwn);
+       bfa_trc(port->fcs, event);
+
+       fdmi->retry_cnt = 0;
+
+       switch (event) {
+       case FDMISM_EVENT_PORT_ONLINE:
+               if (port->vport) {
+                       /*
+                        * For Vports, register a new port.
+                        */
+                       bfa_sm_set_state(fdmi,
+                                        bfa_fcs_lport_fdmi_sm_sending_rprt);
+                       bfa_fcs_lport_fdmi_send_rprt(fdmi, NULL);
+               } else {
+                       /*
+                        * For a base port, we should first register the HBA
+                        * atribute. The HBA attribute also contains the base
+                        *  port registration.
+                        */
+                       bfa_sm_set_state(fdmi,
+                                        bfa_fcs_lport_fdmi_sm_sending_rhba);
+                       bfa_fcs_lport_fdmi_send_rhba(fdmi, NULL);
+               }
+               break;
+
+       case FDMISM_EVENT_PORT_OFFLINE:
+               break;
+
+       default:
+               bfa_sm_fault(port->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_lport_fdmi_sm_sending_rhba(struct bfa_fcs_lport_fdmi_s *fdmi,
+                                 enum port_fdmi_event event)
+{
+       struct bfa_fcs_lport_s *port = fdmi->ms->port;
+
+       bfa_trc(port->fcs, port->port_cfg.pwwn);
+       bfa_trc(port->fcs, event);
+
+       switch (event) {
+       case FDMISM_EVENT_RHBA_SENT:
+               bfa_sm_set_state(fdmi, bfa_fcs_lport_fdmi_sm_rhba);
+               break;
+
+       case FDMISM_EVENT_PORT_OFFLINE:
+               bfa_sm_set_state(fdmi, bfa_fcs_lport_fdmi_sm_offline);
+               bfa_fcxp_walloc_cancel(BFA_FCS_GET_HAL_FROM_PORT(port),
+                                          &fdmi->fcxp_wqe);
+               break;
+
+       default:
+               bfa_sm_fault(port->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_lport_fdmi_sm_rhba(struct bfa_fcs_lport_fdmi_s *fdmi,
+                       enum port_fdmi_event event)
+{
+       struct bfa_fcs_lport_s *port = fdmi->ms->port;
+
+       bfa_trc(port->fcs, port->port_cfg.pwwn);
+       bfa_trc(port->fcs, event);
+
+       switch (event) {
+       case FDMISM_EVENT_RSP_ERROR:
+               /*
+                * if max retries have not been reached, start timer for a
+                * delayed retry
+                */
+               if (fdmi->retry_cnt++ < BFA_FCS_FDMI_CMD_MAX_RETRIES) {
+                       bfa_sm_set_state(fdmi,
+                                       bfa_fcs_lport_fdmi_sm_rhba_retry);
+                       bfa_timer_start(BFA_FCS_GET_HAL_FROM_PORT(port),
+                                           &fdmi->timer,
+                                           bfa_fcs_lport_fdmi_timeout, fdmi,
+                                           BFA_FCS_RETRY_TIMEOUT);
+               } else {
+                       /*
+                        * set state to offline
+                        */
+                       bfa_sm_set_state(fdmi, bfa_fcs_lport_fdmi_sm_offline);
+               }
+               break;
+
+       case FDMISM_EVENT_RSP_OK:
+               /*
+                * Initiate Register Port Attributes
+                */
+               bfa_sm_set_state(fdmi, bfa_fcs_lport_fdmi_sm_sending_rpa);
+               fdmi->retry_cnt = 0;
+               bfa_fcs_lport_fdmi_send_rpa(fdmi, NULL);
+               break;
+
+       case FDMISM_EVENT_PORT_OFFLINE:
+               bfa_fcxp_discard(fdmi->fcxp);
+               bfa_sm_set_state(fdmi, bfa_fcs_lport_fdmi_sm_offline);
+               break;
+
+       default:
+               bfa_sm_fault(port->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_lport_fdmi_sm_rhba_retry(struct bfa_fcs_lport_fdmi_s *fdmi,
+                               enum port_fdmi_event event)
+{
+       struct bfa_fcs_lport_s *port = fdmi->ms->port;
+
+       bfa_trc(port->fcs, port->port_cfg.pwwn);
+       bfa_trc(port->fcs, event);
+
+       switch (event) {
+       case FDMISM_EVENT_TIMEOUT:
+               /*
+                * Retry Timer Expired. Re-send
+                */
+               bfa_sm_set_state(fdmi, bfa_fcs_lport_fdmi_sm_sending_rhba);
+               bfa_fcs_lport_fdmi_send_rhba(fdmi, NULL);
+               break;
+
+       case FDMISM_EVENT_PORT_OFFLINE:
+               bfa_sm_set_state(fdmi, bfa_fcs_lport_fdmi_sm_offline);
+               bfa_timer_stop(&fdmi->timer);
+               break;
+
+       default:
+               bfa_sm_fault(port->fcs, event);
+       }
+}
+
+/*
+* RPRT : Register Port
+ */
+static void
+bfa_fcs_lport_fdmi_sm_sending_rprt(struct bfa_fcs_lport_fdmi_s *fdmi,
+                                 enum port_fdmi_event event)
+{
+       struct bfa_fcs_lport_s *port = fdmi->ms->port;
+
+       bfa_trc(port->fcs, port->port_cfg.pwwn);
+       bfa_trc(port->fcs, event);
+
+       switch (event) {
+       case FDMISM_EVENT_RPRT_SENT:
+               bfa_sm_set_state(fdmi, bfa_fcs_lport_fdmi_sm_rprt);
+               break;
+
+       case FDMISM_EVENT_PORT_OFFLINE:
+               bfa_sm_set_state(fdmi, bfa_fcs_lport_fdmi_sm_offline);
+               bfa_fcxp_walloc_cancel(BFA_FCS_GET_HAL_FROM_PORT(port),
+                                          &fdmi->fcxp_wqe);
+               break;
+
+       default:
+               bfa_sm_fault(port->fcs, event);
        }
+}
+
+static void
+bfa_fcs_lport_fdmi_sm_rprt(struct bfa_fcs_lport_fdmi_s *fdmi,
+                       enum port_fdmi_event event)
+{
+       struct bfa_fcs_lport_s *port = fdmi->ms->port;
+
+       bfa_trc(port->fcs, port->port_cfg.pwwn);
+       bfa_trc(port->fcs, event);
+
+       switch (event) {
+       case FDMISM_EVENT_RSP_ERROR:
+               /*
+                * if max retries have not been reached, start timer for a
+                * delayed retry
+                */
+               if (fdmi->retry_cnt++ < BFA_FCS_FDMI_CMD_MAX_RETRIES) {
+                       bfa_sm_set_state(fdmi,
+                                       bfa_fcs_lport_fdmi_sm_rprt_retry);
+                       bfa_timer_start(BFA_FCS_GET_HAL_FROM_PORT(port),
+                                           &fdmi->timer,
+                                           bfa_fcs_lport_fdmi_timeout, fdmi,
+                                           BFA_FCS_RETRY_TIMEOUT);
 
+               } else {
+                       /*
+                        * set state to offline
+                        */
+                       bfa_sm_set_state(fdmi, bfa_fcs_lport_fdmi_sm_offline);
+                       fdmi->retry_cnt = 0;
+               }
+               break;
+
+       case FDMISM_EVENT_RSP_OK:
+               fdmi->retry_cnt = 0;
+               bfa_sm_set_state(fdmi, bfa_fcs_lport_fdmi_sm_online);
+               break;
+
+       case FDMISM_EVENT_PORT_OFFLINE:
+               bfa_fcxp_discard(fdmi->fcxp);
+               bfa_sm_set_state(fdmi, bfa_fcs_lport_fdmi_sm_offline);
+               break;
+
+       default:
+               bfa_sm_fault(port->fcs, event);
+       }
 }
 
+static void
+bfa_fcs_lport_fdmi_sm_rprt_retry(struct bfa_fcs_lport_fdmi_s *fdmi,
+                               enum port_fdmi_event event)
+{
+       struct bfa_fcs_lport_s *port = fdmi->ms->port;
 
+       bfa_trc(port->fcs, port->port_cfg.pwwn);
+       bfa_trc(port->fcs, event);
+
+       switch (event) {
+       case FDMISM_EVENT_TIMEOUT:
+               /*
+                * Retry Timer Expired. Re-send
+                */
+               bfa_sm_set_state(fdmi, bfa_fcs_lport_fdmi_sm_sending_rprt);
+               bfa_fcs_lport_fdmi_send_rprt(fdmi, NULL);
+               break;
+
+       case FDMISM_EVENT_PORT_OFFLINE:
+               bfa_sm_set_state(fdmi, bfa_fcs_lport_fdmi_sm_offline);
+               bfa_timer_stop(&fdmi->timer);
+               break;
+
+       default:
+               bfa_sm_fault(port->fcs, event);
+       }
+}
+
+/*
+ * Register Port Attributes
+ */
+static void
+bfa_fcs_lport_fdmi_sm_sending_rpa(struct bfa_fcs_lport_fdmi_s *fdmi,
+                                enum port_fdmi_event event)
+{
+       struct bfa_fcs_lport_s *port = fdmi->ms->port;
+
+       bfa_trc(port->fcs, port->port_cfg.pwwn);
+       bfa_trc(port->fcs, event);
+
+       switch (event) {
+       case FDMISM_EVENT_RPA_SENT:
+               bfa_sm_set_state(fdmi, bfa_fcs_lport_fdmi_sm_rpa);
+               break;
+
+       case FDMISM_EVENT_PORT_OFFLINE:
+               bfa_sm_set_state(fdmi, bfa_fcs_lport_fdmi_sm_offline);
+               bfa_fcxp_walloc_cancel(BFA_FCS_GET_HAL_FROM_PORT(port),
+                                          &fdmi->fcxp_wqe);
+               break;
+
+       default:
+               bfa_sm_fault(port->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_lport_fdmi_sm_rpa(struct bfa_fcs_lport_fdmi_s *fdmi,
+                       enum port_fdmi_event event)
+{
+       struct bfa_fcs_lport_s *port = fdmi->ms->port;
+
+       bfa_trc(port->fcs, port->port_cfg.pwwn);
+       bfa_trc(port->fcs, event);
+
+       switch (event) {
+       case FDMISM_EVENT_RSP_ERROR:
+               /*
+                * if max retries have not been reached, start timer for a
+                * delayed retry
+                */
+               if (fdmi->retry_cnt++ < BFA_FCS_FDMI_CMD_MAX_RETRIES) {
+                       bfa_sm_set_state(fdmi, bfa_fcs_lport_fdmi_sm_rpa_retry);
+                       bfa_timer_start(BFA_FCS_GET_HAL_FROM_PORT(port),
+                                           &fdmi->timer,
+                                           bfa_fcs_lport_fdmi_timeout, fdmi,
+                                           BFA_FCS_RETRY_TIMEOUT);
+               } else {
+                       /*
+                        * set state to offline
+                        */
+                       bfa_sm_set_state(fdmi, bfa_fcs_lport_fdmi_sm_offline);
+                       fdmi->retry_cnt = 0;
+               }
+               break;
+
+       case FDMISM_EVENT_RSP_OK:
+               bfa_sm_set_state(fdmi, bfa_fcs_lport_fdmi_sm_online);
+               fdmi->retry_cnt = 0;
+               break;
+
+       case FDMISM_EVENT_PORT_OFFLINE:
+               bfa_fcxp_discard(fdmi->fcxp);
+               bfa_sm_set_state(fdmi, bfa_fcs_lport_fdmi_sm_offline);
+               break;
+
+       default:
+               bfa_sm_fault(port->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_lport_fdmi_sm_rpa_retry(struct bfa_fcs_lport_fdmi_s *fdmi,
+                              enum port_fdmi_event event)
+{
+       struct bfa_fcs_lport_s *port = fdmi->ms->port;
+
+       bfa_trc(port->fcs, port->port_cfg.pwwn);
+       bfa_trc(port->fcs, event);
+
+       switch (event) {
+       case FDMISM_EVENT_TIMEOUT:
+               /*
+                * Retry Timer Expired. Re-send
+                */
+               bfa_sm_set_state(fdmi, bfa_fcs_lport_fdmi_sm_sending_rpa);
+               bfa_fcs_lport_fdmi_send_rpa(fdmi, NULL);
+               break;
+
+       case FDMISM_EVENT_PORT_OFFLINE:
+               bfa_sm_set_state(fdmi, bfa_fcs_lport_fdmi_sm_offline);
+               bfa_timer_stop(&fdmi->timer);
+               break;
+
+       default:
+               bfa_sm_fault(port->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_lport_fdmi_sm_online(struct bfa_fcs_lport_fdmi_s *fdmi,
+                               enum port_fdmi_event event)
+{
+       struct bfa_fcs_lport_s *port = fdmi->ms->port;
+
+       bfa_trc(port->fcs, port->port_cfg.pwwn);
+       bfa_trc(port->fcs, event);
+
+       switch (event) {
+       case FDMISM_EVENT_PORT_OFFLINE:
+               bfa_sm_set_state(fdmi, bfa_fcs_lport_fdmi_sm_offline);
+               break;
+
+       default:
+               bfa_sm_fault(port->fcs, event);
+       }
+}
+/**
+ *  FDMI is disabled state.
+ */
+static void
+bfa_fcs_lport_fdmi_sm_disabled(struct bfa_fcs_lport_fdmi_s *fdmi,
+                            enum port_fdmi_event event)
+{
+       struct bfa_fcs_lport_s *port = fdmi->ms->port;
+
+       bfa_trc(port->fcs, port->port_cfg.pwwn);
+       bfa_trc(port->fcs, event);
+
+       /* No op State. It can only be enabled at Driver Init. */
+}
+
+/**
+*  RHBA : Register HBA Attributes.
+ */
+static void
+bfa_fcs_lport_fdmi_send_rhba(void *fdmi_cbarg, struct bfa_fcxp_s *fcxp_alloced)
+{
+       struct bfa_fcs_lport_fdmi_s *fdmi = fdmi_cbarg;
+       struct bfa_fcs_lport_s *port = fdmi->ms->port;
+       struct fchs_s fchs;
+       int             len, attr_len;
+       struct bfa_fcxp_s *fcxp;
+       u8        *pyld;
+
+       bfa_trc(port->fcs, port->port_cfg.pwwn);
+
+       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
+       if (!fcxp) {
+               bfa_fcs_fcxp_alloc_wait(port->fcs->bfa, &fdmi->fcxp_wqe,
+                                       bfa_fcs_lport_fdmi_send_rhba, fdmi);
+               return;
+       }
+       fdmi->fcxp = fcxp;
+
+       pyld = bfa_fcxp_get_reqbuf(fcxp);
+       bfa_os_memset(pyld, 0, FC_MAX_PDUSZ);
+
+       len = fc_fdmi_reqhdr_build(&fchs, pyld, bfa_fcs_lport_get_fcid(port),
+                                  FDMI_RHBA);
+
+       attr_len =
+               bfa_fcs_lport_fdmi_build_rhba_pyld(fdmi,
+                                         (u8 *) ((struct ct_hdr_s *) pyld
+                                                      + 1));
+
+       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
+                         FC_CLASS_3, (len + attr_len), &fchs,
+                         bfa_fcs_lport_fdmi_rhba_response, (void *)fdmi,
+                         FC_MAX_PDUSZ, FC_FCCT_TOV);
+
+       bfa_sm_send_event(fdmi, FDMISM_EVENT_RHBA_SENT);
+}
+
+static          u16
+bfa_fcs_lport_fdmi_build_rhba_pyld(struct bfa_fcs_lport_fdmi_s *fdmi, u8 *pyld)
+{
+       struct bfa_fcs_lport_s *port = fdmi->ms->port;
+       struct bfa_fcs_fdmi_hba_attr_s hba_attr;
+       struct bfa_fcs_fdmi_hba_attr_s *fcs_hba_attr = &hba_attr;
+       struct fdmi_rhba_s *rhba = (struct fdmi_rhba_s *) pyld;
+       struct fdmi_attr_s *attr;
+       u8        *curr_ptr;
+       u16        len, count;
+
+       /*
+        * get hba attributes
+        */
+       bfa_fcs_fdmi_get_hbaattr(fdmi, fcs_hba_attr);
+
+       rhba->hba_id = bfa_fcs_lport_get_pwwn(port);
+       rhba->port_list.num_ports = bfa_os_htonl(1);
+       rhba->port_list.port_entry = bfa_fcs_lport_get_pwwn(port);
+
+       len = sizeof(rhba->hba_id) + sizeof(rhba->port_list);
+
+       count = 0;
+       len += sizeof(rhba->hba_attr_blk.attr_count);
+
+       /*
+        * fill out the invididual entries of the HBA attrib Block
+        */
+       curr_ptr = (u8 *) &rhba->hba_attr_blk.hba_attr;
+
+       /*
+        * Node Name
+        */
+       attr = (struct fdmi_attr_s *) curr_ptr;
+       attr->type = bfa_os_htons(FDMI_HBA_ATTRIB_NODENAME);
+       attr->len = sizeof(wwn_t);
+       memcpy(attr->value, &bfa_fcs_lport_get_nwwn(port), attr->len);
+       curr_ptr += sizeof(attr->type) + sizeof(attr->len) + attr->len;
+       len += attr->len;
+       count++;
+       attr->len =
+               bfa_os_htons(attr->len + sizeof(attr->type) +
+                            sizeof(attr->len));
+
+       /*
+        * Manufacturer
+        */
+       attr = (struct fdmi_attr_s *) curr_ptr;
+       attr->type = bfa_os_htons(FDMI_HBA_ATTRIB_MANUFACTURER);
+       attr->len = (u16) strlen(fcs_hba_attr->manufacturer);
+       memcpy(attr->value, fcs_hba_attr->manufacturer, attr->len);
+       attr->len = fc_roundup(attr->len, sizeof(u32)); /* variable
+                                                                *fields need
+                                                                *to be 4 byte
+                                                                *aligned */
+       curr_ptr += sizeof(attr->type) + sizeof(attr->len) + attr->len;
+       len += attr->len;
+       count++;
+       attr->len =
+               bfa_os_htons(attr->len + sizeof(attr->type) +
+                            sizeof(attr->len));
+
+       /*
+        * Serial Number
+        */
+       attr = (struct fdmi_attr_s *) curr_ptr;
+       attr->type = bfa_os_htons(FDMI_HBA_ATTRIB_SERIALNUM);
+       attr->len = (u16) strlen(fcs_hba_attr->serial_num);
+       memcpy(attr->value, fcs_hba_attr->serial_num, attr->len);
+       attr->len = fc_roundup(attr->len, sizeof(u32)); /* variable
+                                                                *fields need
+                                                                *to be 4 byte
+                                                                *aligned */
+       curr_ptr += sizeof(attr->type) + sizeof(attr->len) + attr->len;
+       len += attr->len;
+       count++;
+       attr->len =
+               bfa_os_htons(attr->len + sizeof(attr->type) +
+                            sizeof(attr->len));
+
+       /*
+        * Model
+        */
+       attr = (struct fdmi_attr_s *) curr_ptr;
+       attr->type = bfa_os_htons(FDMI_HBA_ATTRIB_MODEL);
+       attr->len = (u16) strlen(fcs_hba_attr->model);
+       memcpy(attr->value, fcs_hba_attr->model, attr->len);
+       attr->len = fc_roundup(attr->len, sizeof(u32)); /* variable
+                                                                *fields need
+                                                                *to be 4 byte
+                                                                *aligned */
+       curr_ptr += sizeof(attr->type) + sizeof(attr->len) + attr->len;
+       len += attr->len;
+       count++;
+       attr->len =
+               bfa_os_htons(attr->len + sizeof(attr->type) +
+                            sizeof(attr->len));
+
+       /*
+        * Model Desc
+        */
+       attr = (struct fdmi_attr_s *) curr_ptr;
+       attr->type = bfa_os_htons(FDMI_HBA_ATTRIB_MODEL_DESC);
+       attr->len = (u16) strlen(fcs_hba_attr->model_desc);
+       memcpy(attr->value, fcs_hba_attr->model_desc, attr->len);
+       attr->len = fc_roundup(attr->len, sizeof(u32)); /* variable
+                                                        *fields need
+                                                        *to be 4 byte
+                                                        *aligned */
+       curr_ptr += sizeof(attr->type) + sizeof(attr->len) + attr->len;
+       len += attr->len;
+       count++;
+       attr->len =
+               bfa_os_htons(attr->len + sizeof(attr->type) +
+                            sizeof(attr->len));
+
+       /*
+        * H/W Version
+        */
+       if (fcs_hba_attr->hw_version[0] != '\0') {
+               attr = (struct fdmi_attr_s *) curr_ptr;
+               attr->type = bfa_os_htons(FDMI_HBA_ATTRIB_HW_VERSION);
+               attr->len = (u16) strlen(fcs_hba_attr->hw_version);
+               memcpy(attr->value, fcs_hba_attr->hw_version, attr->len);
+               attr->len = fc_roundup(attr->len, sizeof(u32)); /* variable
+                                                                *fields need
+                                                                *to be 4 byte
+                                                                *aligned */
+               curr_ptr += sizeof(attr->type) + sizeof(attr->len) + attr->len;
+               len += attr->len;
+               count++;
+               attr->len =
+                       bfa_os_htons(attr->len + sizeof(attr->type) +
+                                        sizeof(attr->len));
+       }
+
+       /*
+        * Driver Version
+        */
+       attr = (struct fdmi_attr_s *) curr_ptr;
+       attr->type = bfa_os_htons(FDMI_HBA_ATTRIB_DRIVER_VERSION);
+       attr->len = (u16) strlen(fcs_hba_attr->driver_version);
+       memcpy(attr->value, fcs_hba_attr->driver_version, attr->len);
+       attr->len = fc_roundup(attr->len, sizeof(u32)); /* variable
+                                                        *fields need
+                                                        *to be 4 byte
+                                                        *aligned */
+       curr_ptr += sizeof(attr->type) + sizeof(attr->len) + attr->len;
+       len += attr->len;;
+       count++;
+       attr->len =
+               bfa_os_htons(attr->len + sizeof(attr->type) +
+                            sizeof(attr->len));
+
+       /*
+        * Option Rom Version
+        */
+       if (fcs_hba_attr->option_rom_ver[0] != '\0') {
+               attr = (struct fdmi_attr_s *) curr_ptr;
+               attr->type = bfa_os_htons(FDMI_HBA_ATTRIB_ROM_VERSION);
+               attr->len = (u16) strlen(fcs_hba_attr->option_rom_ver);
+               memcpy(attr->value, fcs_hba_attr->option_rom_ver, attr->len);
+               attr->len = fc_roundup(attr->len, sizeof(u32)); /* variable
+                                                                *fields need
+                                                                *to be 4 byte
+                                                                *aligned */
+               curr_ptr += sizeof(attr->type) + sizeof(attr->len) + attr->len;
+               len += attr->len;
+               count++;
+               attr->len =
+                       bfa_os_htons(attr->len + sizeof(attr->type) +
+                                        sizeof(attr->len));
+       }
+
+       /*
+        * f/w Version = driver version
+        */
+       attr = (struct fdmi_attr_s *) curr_ptr;
+       attr->type = bfa_os_htons(FDMI_HBA_ATTRIB_FW_VERSION);
+       attr->len = (u16) strlen(fcs_hba_attr->driver_version);
+       memcpy(attr->value, fcs_hba_attr->driver_version, attr->len);
+       attr->len = fc_roundup(attr->len, sizeof(u32)); /* variable
+                                                        *fields need
+                                                        *to be 4 byte
+                                                        *aligned */
+       curr_ptr += sizeof(attr->type) + sizeof(attr->len) + attr->len;
+       len += attr->len;
+       count++;
+       attr->len =
+               bfa_os_htons(attr->len + sizeof(attr->type) +
+                            sizeof(attr->len));
+
+       /*
+        * OS Name
+        */
+       if (fcs_hba_attr->os_name[0] != '\0') {
+               attr = (struct fdmi_attr_s *) curr_ptr;
+               attr->type = bfa_os_htons(FDMI_HBA_ATTRIB_OS_NAME);
+               attr->len = (u16) strlen(fcs_hba_attr->os_name);
+               memcpy(attr->value, fcs_hba_attr->os_name, attr->len);
+               attr->len = fc_roundup(attr->len, sizeof(u32)); /* variable
+                                                            *fields need
+                                                            *to be 4 byte
+                                                            *aligned */
+               curr_ptr += sizeof(attr->type) + sizeof(attr->len) + attr->len;
+               len += attr->len;
+               count++;
+               attr->len =
+                       bfa_os_htons(attr->len + sizeof(attr->type) +
+                                       sizeof(attr->len));
+       }
+
+       /*
+        * MAX_CT_PAYLOAD
+        */
+       attr = (struct fdmi_attr_s *) curr_ptr;
+       attr->type = bfa_os_htons(FDMI_HBA_ATTRIB_MAX_CT);
+       attr->len = sizeof(fcs_hba_attr->max_ct_pyld);
+       memcpy(attr->value, &fcs_hba_attr->max_ct_pyld, attr->len);
+       len += attr->len;
+       count++;
+       attr->len =
+               bfa_os_htons(attr->len + sizeof(attr->type) +
+                            sizeof(attr->len));
+
+       /*
+        * Update size of payload
+        */
+       len += ((sizeof(attr->type) +
+                sizeof(attr->len)) * count);
+
+       rhba->hba_attr_blk.attr_count = bfa_os_htonl(count);
+       return len;
+}
+
+static void
+bfa_fcs_lport_fdmi_rhba_response(void *fcsarg, struct bfa_fcxp_s *fcxp,
+                               void *cbarg, bfa_status_t req_status,
+                               u32 rsp_len, u32 resid_len,
+                               struct fchs_s *rsp_fchs)
+{
+       struct bfa_fcs_lport_fdmi_s *fdmi =
+                               (struct bfa_fcs_lport_fdmi_s *) cbarg;
+       struct bfa_fcs_lport_s *port = fdmi->ms->port;
+       struct ct_hdr_s *cthdr = NULL;
+
+       bfa_trc(port->fcs, port->port_cfg.pwwn);
+
+       /*
+        * Sanity Checks
+        */
+       if (req_status != BFA_STATUS_OK) {
+               bfa_trc(port->fcs, req_status);
+               bfa_sm_send_event(fdmi, FDMISM_EVENT_RSP_ERROR);
+               return;
+       }
+
+       cthdr = (struct ct_hdr_s *) BFA_FCXP_RSP_PLD(fcxp);
+       cthdr->cmd_rsp_code = bfa_os_ntohs(cthdr->cmd_rsp_code);
+
+       if (cthdr->cmd_rsp_code == CT_RSP_ACCEPT) {
+               bfa_sm_send_event(fdmi, FDMISM_EVENT_RSP_OK);
+               return;
+       }
+
+       bfa_trc(port->fcs, cthdr->reason_code);
+       bfa_trc(port->fcs, cthdr->exp_code);
+       bfa_sm_send_event(fdmi, FDMISM_EVENT_RSP_ERROR);
+}
+
+/**
+*  RPRT : Register Port
+ */
+static void
+bfa_fcs_lport_fdmi_send_rprt(void *fdmi_cbarg, struct bfa_fcxp_s *fcxp_alloced)
+{
+       struct bfa_fcs_lport_fdmi_s *fdmi = fdmi_cbarg;
+       struct bfa_fcs_lport_s *port = fdmi->ms->port;
+       struct fchs_s fchs;
+       u16        len, attr_len;
+       struct bfa_fcxp_s *fcxp;
+       u8        *pyld;
+
+       bfa_trc(port->fcs, port->port_cfg.pwwn);
+
+       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
+       if (!fcxp) {
+               bfa_fcs_fcxp_alloc_wait(port->fcs->bfa, &fdmi->fcxp_wqe,
+                                       bfa_fcs_lport_fdmi_send_rprt, fdmi);
+               return;
+       }
+       fdmi->fcxp = fcxp;
+
+       pyld = bfa_fcxp_get_reqbuf(fcxp);
+       bfa_os_memset(pyld, 0, FC_MAX_PDUSZ);
+
+       len = fc_fdmi_reqhdr_build(&fchs, pyld, bfa_fcs_lport_get_fcid(port),
+                                  FDMI_RPRT);
+
+       attr_len =
+               bfa_fcs_lport_fdmi_build_rprt_pyld(fdmi,
+                                         (u8 *) ((struct ct_hdr_s *) pyld
+                                                      + 1));
+
+       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
+                         FC_CLASS_3, len + attr_len, &fchs,
+                         bfa_fcs_lport_fdmi_rprt_response, (void *)fdmi,
+                         FC_MAX_PDUSZ, FC_FCCT_TOV);
+
+       bfa_sm_send_event(fdmi, FDMISM_EVENT_RPRT_SENT);
+}
+
+/**
+ * This routine builds Port Attribute Block that used in RPA, RPRT commands.
+ */
+static          u16
+bfa_fcs_lport_fdmi_build_portattr_block(struct bfa_fcs_lport_fdmi_s *fdmi,
+                                      u8 *pyld)
+{
+       struct bfa_fcs_fdmi_port_attr_s fcs_port_attr;
+       struct fdmi_port_attr_s *port_attrib = (struct fdmi_port_attr_s *) pyld;
+       struct fdmi_attr_s *attr;
+       u8        *curr_ptr;
+       u16        len;
+       u8      count = 0;
+
+       /*
+        * get port attributes
+        */
+       bfa_fcs_fdmi_get_portattr(fdmi, &fcs_port_attr);
+
+       len = sizeof(port_attrib->attr_count);
+
+       /*
+        * fill out the invididual entries
+        */
+       curr_ptr = (u8 *) &port_attrib->port_attr;
+
+       /*
+        * FC4 Types
+        */
+       attr = (struct fdmi_attr_s *) curr_ptr;
+       attr->type = bfa_os_htons(FDMI_PORT_ATTRIB_FC4_TYPES);
+       attr->len = sizeof(fcs_port_attr.supp_fc4_types);
+       memcpy(attr->value, fcs_port_attr.supp_fc4_types, attr->len);
+       curr_ptr += sizeof(attr->type) + sizeof(attr->len) + attr->len;
+       len += attr->len;
+       ++count;
+       attr->len =
+               bfa_os_htons(attr->len + sizeof(attr->type) +
+                            sizeof(attr->len));
+
+       /*
+        * Supported Speed
+        */
+       attr = (struct fdmi_attr_s *) curr_ptr;
+       attr->type = bfa_os_htons(FDMI_PORT_ATTRIB_SUPP_SPEED);
+       attr->len = sizeof(fcs_port_attr.supp_speed);
+       memcpy(attr->value, &fcs_port_attr.supp_speed, attr->len);
+       curr_ptr += sizeof(attr->type) + sizeof(attr->len) + attr->len;
+       len += attr->len;
+       ++count;
+       attr->len =
+               bfa_os_htons(attr->len + sizeof(attr->type) +
+                            sizeof(attr->len));
+
+       /*
+        * current Port Speed
+        */
+       attr = (struct fdmi_attr_s *) curr_ptr;
+       attr->type = bfa_os_htons(FDMI_PORT_ATTRIB_PORT_SPEED);
+       attr->len = sizeof(fcs_port_attr.curr_speed);
+       memcpy(attr->value, &fcs_port_attr.curr_speed, attr->len);
+       curr_ptr += sizeof(attr->type) + sizeof(attr->len) + attr->len;
+       len += attr->len;
+       ++count;
+       attr->len =
+               bfa_os_htons(attr->len + sizeof(attr->type) +
+                            sizeof(attr->len));
+
+       /*
+        * max frame size
+        */
+       attr = (struct fdmi_attr_s *) curr_ptr;
+       attr->type = bfa_os_htons(FDMI_PORT_ATTRIB_FRAME_SIZE);
+       attr->len = sizeof(fcs_port_attr.max_frm_size);
+       memcpy(attr->value, &fcs_port_attr.max_frm_size, attr->len);
+       curr_ptr += sizeof(attr->type) + sizeof(attr->len) + attr->len;
+       len += attr->len;
+       ++count;
+       attr->len =
+               bfa_os_htons(attr->len + sizeof(attr->type) +
+                            sizeof(attr->len));
+
+       /*
+        * OS Device Name
+        */
+       if (fcs_port_attr.os_device_name[0] != '\0') {
+               attr = (struct fdmi_attr_s *) curr_ptr;
+               attr->type = bfa_os_htons(FDMI_PORT_ATTRIB_DEV_NAME);
+               attr->len = (u16) strlen(fcs_port_attr.os_device_name);
+               memcpy(attr->value, fcs_port_attr.os_device_name, attr->len);
+               attr->len = fc_roundup(attr->len, sizeof(u32)); /* variable
+                                                            *fields need
+                                                            *to be 4 byte
+                                                            *aligned */
+               curr_ptr += sizeof(attr->type) + sizeof(attr->len) + attr->len;
+               len += attr->len;
+               ++count;
+               attr->len =
+                       bfa_os_htons(attr->len + sizeof(attr->type) +
+                                       sizeof(attr->len));
+       }
+       /*
+        * Host Name
+        */
+       if (fcs_port_attr.host_name[0] != '\0') {
+               attr = (struct fdmi_attr_s *) curr_ptr;
+               attr->type = bfa_os_htons(FDMI_PORT_ATTRIB_HOST_NAME);
+               attr->len = (u16) strlen(fcs_port_attr.host_name);
+               memcpy(attr->value, fcs_port_attr.host_name, attr->len);
+               attr->len = fc_roundup(attr->len, sizeof(u32)); /* variable
+                                                            *fields need
+                                                            *to be 4 byte
+                                                            *aligned */
+               curr_ptr += sizeof(attr->type) + sizeof(attr->len) + attr->len;
+               len += attr->len;
+               ++count;
+               attr->len =
+                       bfa_os_htons(attr->len + sizeof(attr->type) +
+                               sizeof(attr->len));
+       }
+
+       /*
+        * Update size of payload
+        */
+       port_attrib->attr_count = bfa_os_htonl(count);
+       len += ((sizeof(attr->type) +
+                sizeof(attr->len)) * count);
+       return len;
+}
+
+static          u16
+bfa_fcs_lport_fdmi_build_rprt_pyld(struct bfa_fcs_lport_fdmi_s *fdmi, u8 *pyld)
+{
+       struct bfa_fcs_lport_s *port = fdmi->ms->port;
+       struct fdmi_rprt_s *rprt = (struct fdmi_rprt_s *) pyld;
+       u16        len;
+
+       rprt->hba_id = bfa_fcs_lport_get_pwwn(bfa_fcs_get_base_port(port->fcs));
+       rprt->port_name = bfa_fcs_lport_get_pwwn(port);
+
+       len = bfa_fcs_lport_fdmi_build_portattr_block(fdmi,
+                               (u8 *) &rprt->port_attr_blk);
+
+       len += sizeof(rprt->hba_id) + sizeof(rprt->port_name);
+
+       return len;
+}
+
+static void
+bfa_fcs_lport_fdmi_rprt_response(void *fcsarg, struct bfa_fcxp_s *fcxp,
+                               void *cbarg, bfa_status_t req_status,
+                               u32 rsp_len, u32 resid_len,
+                               struct fchs_s *rsp_fchs)
+{
+       struct bfa_fcs_lport_fdmi_s *fdmi =
+                       (struct bfa_fcs_lport_fdmi_s *) cbarg;
+       struct bfa_fcs_lport_s *port = fdmi->ms->port;
+       struct ct_hdr_s *cthdr = NULL;
+
+       bfa_trc(port->fcs, port->port_cfg.pwwn);
+
+       /*
+        * Sanity Checks
+        */
+       if (req_status != BFA_STATUS_OK) {
+               bfa_trc(port->fcs, req_status);
+               bfa_sm_send_event(fdmi, FDMISM_EVENT_RSP_ERROR);
+               return;
+       }
+
+       cthdr = (struct ct_hdr_s *) BFA_FCXP_RSP_PLD(fcxp);
+       cthdr->cmd_rsp_code = bfa_os_ntohs(cthdr->cmd_rsp_code);
+
+       if (cthdr->cmd_rsp_code == CT_RSP_ACCEPT) {
+               bfa_sm_send_event(fdmi, FDMISM_EVENT_RSP_OK);
+               return;
+       }
+
+       bfa_trc(port->fcs, cthdr->reason_code);
+       bfa_trc(port->fcs, cthdr->exp_code);
+       bfa_sm_send_event(fdmi, FDMISM_EVENT_RSP_ERROR);
+}
+
+/**
+*  RPA : Register Port Attributes.
+ */
+static void
+bfa_fcs_lport_fdmi_send_rpa(void *fdmi_cbarg, struct bfa_fcxp_s *fcxp_alloced)
+{
+       struct bfa_fcs_lport_fdmi_s *fdmi = fdmi_cbarg;
+       struct bfa_fcs_lport_s *port = fdmi->ms->port;
+       struct fchs_s fchs;
+       u16        len, attr_len;
+       struct bfa_fcxp_s *fcxp;
+       u8        *pyld;
+
+       bfa_trc(port->fcs, port->port_cfg.pwwn);
+
+       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
+       if (!fcxp) {
+               bfa_fcs_fcxp_alloc_wait(port->fcs->bfa, &fdmi->fcxp_wqe,
+                                       bfa_fcs_lport_fdmi_send_rpa, fdmi);
+               return;
+       }
+       fdmi->fcxp = fcxp;
+
+       pyld = bfa_fcxp_get_reqbuf(fcxp);
+       bfa_os_memset(pyld, 0, FC_MAX_PDUSZ);
+
+       len = fc_fdmi_reqhdr_build(&fchs, pyld, bfa_fcs_lport_get_fcid(port),
+                                  FDMI_RPA);
+
+       attr_len =
+               bfa_fcs_lport_fdmi_build_rpa_pyld(fdmi,
+                                        (u8 *) ((struct ct_hdr_s *) pyld
+                                                     + 1));
+
+       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
+                         FC_CLASS_3, len + attr_len, &fchs,
+                         bfa_fcs_lport_fdmi_rpa_response, (void *)fdmi,
+                         FC_MAX_PDUSZ, FC_FCCT_TOV);
+
+       bfa_sm_send_event(fdmi, FDMISM_EVENT_RPA_SENT);
+}
+
+static          u16
+bfa_fcs_lport_fdmi_build_rpa_pyld(struct bfa_fcs_lport_fdmi_s *fdmi, u8 *pyld)
+{
+       struct bfa_fcs_lport_s *port = fdmi->ms->port;
+       struct fdmi_rpa_s *rpa = (struct fdmi_rpa_s *) pyld;
+       u16        len;
+
+       rpa->port_name = bfa_fcs_lport_get_pwwn(port);
+
+       len = bfa_fcs_lport_fdmi_build_portattr_block(fdmi,
+                               (u8 *) &rpa->port_attr_blk);
+
+       len += sizeof(rpa->port_name);
+
+       return len;
+}
+
+static void
+bfa_fcs_lport_fdmi_rpa_response(void *fcsarg, struct bfa_fcxp_s *fcxp,
+                       void *cbarg, bfa_status_t req_status, u32 rsp_len,
+                       u32 resid_len, struct fchs_s *rsp_fchs)
+{
+       struct bfa_fcs_lport_fdmi_s *fdmi =
+                               (struct bfa_fcs_lport_fdmi_s *) cbarg;
+       struct bfa_fcs_lport_s *port = fdmi->ms->port;
+       struct ct_hdr_s *cthdr = NULL;
+
+       bfa_trc(port->fcs, port->port_cfg.pwwn);
+
+       /*
+        * Sanity Checks
+        */
+       if (req_status != BFA_STATUS_OK) {
+               bfa_trc(port->fcs, req_status);
+               bfa_sm_send_event(fdmi, FDMISM_EVENT_RSP_ERROR);
+               return;
+       }
+
+       cthdr = (struct ct_hdr_s *) BFA_FCXP_RSP_PLD(fcxp);
+       cthdr->cmd_rsp_code = bfa_os_ntohs(cthdr->cmd_rsp_code);
+
+       if (cthdr->cmd_rsp_code == CT_RSP_ACCEPT) {
+               bfa_sm_send_event(fdmi, FDMISM_EVENT_RSP_OK);
+               return;
+       }
+
+       bfa_trc(port->fcs, cthdr->reason_code);
+       bfa_trc(port->fcs, cthdr->exp_code);
+       bfa_sm_send_event(fdmi, FDMISM_EVENT_RSP_ERROR);
+}
+
+static void
+bfa_fcs_lport_fdmi_timeout(void *arg)
+{
+       struct bfa_fcs_lport_fdmi_s *fdmi = (struct bfa_fcs_lport_fdmi_s *) arg;
+
+       bfa_sm_send_event(fdmi, FDMISM_EVENT_TIMEOUT);
+}
+
+void
+bfa_fcs_fdmi_get_hbaattr(struct bfa_fcs_lport_fdmi_s *fdmi,
+                        struct bfa_fcs_fdmi_hba_attr_s *hba_attr)
+{
+       struct bfa_fcs_lport_s *port = fdmi->ms->port;
+       struct bfa_fcs_driver_info_s  *driver_info = &port->fcs->driver_info;
+
+       bfa_os_memset(hba_attr, 0, sizeof(struct bfa_fcs_fdmi_hba_attr_s));
+
+       bfa_ioc_get_adapter_manufacturer(&port->fcs->bfa->ioc,
+                                       hba_attr->manufacturer);
+       bfa_ioc_get_adapter_serial_num(&port->fcs->bfa->ioc,
+                                       hba_attr->serial_num);
+       bfa_ioc_get_adapter_model(&port->fcs->bfa->ioc,
+                                       hba_attr->model);
+       bfa_ioc_get_adapter_model(&port->fcs->bfa->ioc,
+                                       hba_attr->model_desc);
+       bfa_ioc_get_pci_chip_rev(&port->fcs->bfa->ioc,
+                                       hba_attr->hw_version);
+       bfa_ioc_get_adapter_optrom_ver(&port->fcs->bfa->ioc,
+                                       hba_attr->option_rom_ver);
+       bfa_ioc_get_adapter_fw_ver(&port->fcs->bfa->ioc,
+                                       hba_attr->fw_version);
+
+       strncpy(hba_attr->driver_version, (char *)driver_info->version,
+               sizeof(hba_attr->driver_version));
+
+       strncpy(hba_attr->os_name, driver_info->host_os_name,
+               sizeof(hba_attr->os_name));
+
+       /*
+        * If there is a patch level, append it
+        * to the os name along with a separator
+        */
+       if (driver_info->host_os_patch[0] != '\0') {
+               strncat(hba_attr->os_name, BFA_FCS_PORT_SYMBNAME_SEPARATOR,
+                       sizeof(BFA_FCS_PORT_SYMBNAME_SEPARATOR));
+               strncat(hba_attr->os_name, driver_info->host_os_patch,
+                               sizeof(driver_info->host_os_patch));
+       }
+
+       hba_attr->max_ct_pyld = bfa_os_htonl(FC_MAX_PDUSZ);
+}
+
+void
+bfa_fcs_fdmi_get_portattr(struct bfa_fcs_lport_fdmi_s *fdmi,
+                         struct bfa_fcs_fdmi_port_attr_s *port_attr)
+{
+       struct bfa_fcs_lport_s *port = fdmi->ms->port;
+       struct bfa_fcs_driver_info_s  *driver_info = &port->fcs->driver_info;
+       struct bfa_port_attr_s pport_attr;
+
+       bfa_os_memset(port_attr, 0, sizeof(struct bfa_fcs_fdmi_port_attr_s));
+
+       /*
+        * get pport attributes from hal
+        */
+       bfa_fcport_get_attr(port->fcs->bfa, &pport_attr);
+
+       /*
+        * get FC4 type Bitmask
+        */
+       fc_get_fc4type_bitmask(FC_TYPE_FCP, port_attr->supp_fc4_types);
+
+       /*
+        * Supported Speeds
+        */
+       port_attr->supp_speed = bfa_os_htonl(BFA_FCS_FDMI_SUPORTED_SPEEDS);
+
+       /*
+        * Current Speed
+        */
+       port_attr->curr_speed = bfa_os_htonl(pport_attr.speed);
+
+       /*
+        * Max PDU Size.
+        */
+       port_attr->max_frm_size = bfa_os_htonl(FC_MAX_PDUSZ);
+
+       /*
+        * OS device Name
+        */
+       strncpy(port_attr->os_device_name, (char *)driver_info->os_device_name,
+               sizeof(port_attr->os_device_name));
+
+       /*
+        * Host name
+        */
+       strncpy(port_attr->host_name, (char *)driver_info->host_machine_name,
+               sizeof(port_attr->host_name));
+
+}
+
+
+void
+bfa_fcs_lport_fdmi_init(struct bfa_fcs_lport_ms_s *ms)
+{
+       struct bfa_fcs_lport_fdmi_s *fdmi = &ms->fdmi;
+
+       fdmi->ms = ms;
+       if (ms->port->fcs->fdmi_enabled)
+               bfa_sm_set_state(fdmi, bfa_fcs_lport_fdmi_sm_offline);
+       else
+               bfa_sm_set_state(fdmi, bfa_fcs_lport_fdmi_sm_disabled);
+}
+
+void
+bfa_fcs_lport_fdmi_offline(struct bfa_fcs_lport_ms_s *ms)
+{
+       struct bfa_fcs_lport_fdmi_s *fdmi = &ms->fdmi;
+
+       fdmi->ms = ms;
+       bfa_sm_send_event(fdmi, FDMISM_EVENT_PORT_OFFLINE);
+}
+
+void
+bfa_fcs_lport_fdmi_online(struct bfa_fcs_lport_ms_s *ms)
+{
+       struct bfa_fcs_lport_fdmi_s *fdmi = &ms->fdmi;
+
+       fdmi->ms = ms;
+       bfa_sm_send_event(fdmi, FDMISM_EVENT_PORT_ONLINE);
+}
+
+#define BFA_FCS_MS_CMD_MAX_RETRIES  2
+
+/*
+ * forward declarations
+ */
+static void     bfa_fcs_lport_ms_send_plogi(void *ms_cbarg,
+                                          struct bfa_fcxp_s *fcxp_alloced);
+static void     bfa_fcs_lport_ms_timeout(void *arg);
+static void     bfa_fcs_lport_ms_plogi_response(void *fcsarg,
+                                              struct bfa_fcxp_s *fcxp,
+                                              void *cbarg,
+                                              bfa_status_t req_status,
+                                              u32 rsp_len,
+                                              u32 resid_len,
+                                              struct fchs_s *rsp_fchs);
+
+static void    bfa_fcs_lport_ms_send_gmal(void *ms_cbarg,
+                                       struct bfa_fcxp_s *fcxp_alloced);
+static void     bfa_fcs_lport_ms_gmal_response(void *fcsarg,
+                                              struct bfa_fcxp_s *fcxp,
+                                              void *cbarg,
+                                              bfa_status_t req_status,
+                                              u32 rsp_len,
+                                              u32 resid_len,
+                                              struct fchs_s *rsp_fchs);
+static void    bfa_fcs_lport_ms_send_gfn(void *ms_cbarg,
+                                       struct bfa_fcxp_s *fcxp_alloced);
+static void     bfa_fcs_lport_ms_gfn_response(void *fcsarg,
+                                              struct bfa_fcxp_s *fcxp,
+                                              void *cbarg,
+                                              bfa_status_t req_status,
+                                              u32 rsp_len,
+                                              u32 resid_len,
+                                              struct fchs_s *rsp_fchs);
+/**
+ *  fcs_ms_sm FCS MS state machine
+ */
+
+/**
+ *  MS State Machine events
+ */
+enum port_ms_event {
+       MSSM_EVENT_PORT_ONLINE = 1,
+       MSSM_EVENT_PORT_OFFLINE = 2,
+       MSSM_EVENT_RSP_OK = 3,
+       MSSM_EVENT_RSP_ERROR = 4,
+       MSSM_EVENT_TIMEOUT = 5,
+       MSSM_EVENT_FCXP_SENT = 6,
+       MSSM_EVENT_PORT_FABRIC_RSCN = 7
+};
+
+static void     bfa_fcs_lport_ms_sm_offline(struct bfa_fcs_lport_ms_s *ms,
+                                          enum port_ms_event event);
+static void     bfa_fcs_lport_ms_sm_plogi_sending(struct bfa_fcs_lport_ms_s *ms,
+                                                enum port_ms_event event);
+static void     bfa_fcs_lport_ms_sm_plogi(struct bfa_fcs_lport_ms_s *ms,
+                                        enum port_ms_event event);
+static void     bfa_fcs_lport_ms_sm_plogi_retry(struct bfa_fcs_lport_ms_s *ms,
+                                              enum port_ms_event event);
+static void     bfa_fcs_lport_ms_sm_gmal_sending(struct bfa_fcs_lport_ms_s *ms,
+                                                enum port_ms_event event);
+static void     bfa_fcs_lport_ms_sm_gmal(struct bfa_fcs_lport_ms_s *ms,
+                                        enum port_ms_event event);
+static void     bfa_fcs_lport_ms_sm_gmal_retry(struct bfa_fcs_lport_ms_s *ms,
+                                              enum port_ms_event event);
+static void     bfa_fcs_lport_ms_sm_gfn_sending(struct bfa_fcs_lport_ms_s *ms,
+                                                enum port_ms_event event);
+static void     bfa_fcs_lport_ms_sm_gfn(struct bfa_fcs_lport_ms_s *ms,
+                                        enum port_ms_event event);
+static void     bfa_fcs_lport_ms_sm_gfn_retry(struct bfa_fcs_lport_ms_s *ms,
+                                              enum port_ms_event event);
+static void     bfa_fcs_lport_ms_sm_online(struct bfa_fcs_lport_ms_s *ms,
+                                         enum port_ms_event event);
+/**
+ *     Start in offline state - awaiting NS to send start.
+ */
+static void
+bfa_fcs_lport_ms_sm_offline(struct bfa_fcs_lport_ms_s *ms,
+                               enum port_ms_event event)
+{
+       bfa_trc(ms->port->fcs, ms->port->port_cfg.pwwn);
+       bfa_trc(ms->port->fcs, event);
+
+       switch (event) {
+       case MSSM_EVENT_PORT_ONLINE:
+               bfa_sm_set_state(ms, bfa_fcs_lport_ms_sm_plogi_sending);
+               bfa_fcs_lport_ms_send_plogi(ms, NULL);
+               break;
+
+       case MSSM_EVENT_PORT_OFFLINE:
+               break;
+
+       default:
+               bfa_sm_fault(ms->port->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_lport_ms_sm_plogi_sending(struct bfa_fcs_lport_ms_s *ms,
+                               enum port_ms_event event)
+{
+       bfa_trc(ms->port->fcs, ms->port->port_cfg.pwwn);
+       bfa_trc(ms->port->fcs, event);
+
+       switch (event) {
+       case MSSM_EVENT_FCXP_SENT:
+               bfa_sm_set_state(ms, bfa_fcs_lport_ms_sm_plogi);
+               break;
+
+       case MSSM_EVENT_PORT_OFFLINE:
+               bfa_sm_set_state(ms, bfa_fcs_lport_ms_sm_offline);
+               bfa_fcxp_walloc_cancel(BFA_FCS_GET_HAL_FROM_PORT(ms->port),
+                                          &ms->fcxp_wqe);
+               break;
+
+       default:
+               bfa_sm_fault(ms->port->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_lport_ms_sm_plogi(struct bfa_fcs_lport_ms_s *ms,
+                       enum port_ms_event event)
+{
+       bfa_trc(ms->port->fcs, ms->port->port_cfg.pwwn);
+       bfa_trc(ms->port->fcs, event);
+
+       switch (event) {
+       case MSSM_EVENT_RSP_ERROR:
+               /*
+                * Start timer for a delayed retry
+                */
+               bfa_sm_set_state(ms, bfa_fcs_lport_ms_sm_plogi_retry);
+               ms->port->stats.ms_retries++;
+               bfa_timer_start(BFA_FCS_GET_HAL_FROM_PORT(ms->port),
+                                   &ms->timer, bfa_fcs_lport_ms_timeout, ms,
+                                   BFA_FCS_RETRY_TIMEOUT);
+               break;
+
+       case MSSM_EVENT_RSP_OK:
+               /*
+                * since plogi is done, now invoke MS related sub-modules
+                */
+               bfa_fcs_lport_fdmi_online(ms);
+
+               /**
+                * if this is a Vport, go to online state.
+                */
+               if (ms->port->vport) {
+                       bfa_sm_set_state(ms, bfa_fcs_lport_ms_sm_online);
+                       break;
+               }
+
+               /*
+                * For a base port we need to get the
+                * switch's IP address.
+                */
+               bfa_sm_set_state(ms, bfa_fcs_lport_ms_sm_gmal_sending);
+               bfa_fcs_lport_ms_send_gmal(ms, NULL);
+               break;
+
+       case MSSM_EVENT_PORT_OFFLINE:
+               bfa_sm_set_state(ms, bfa_fcs_lport_ms_sm_offline);
+               bfa_fcxp_discard(ms->fcxp);
+               break;
+
+       default:
+               bfa_sm_fault(ms->port->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_lport_ms_sm_plogi_retry(struct bfa_fcs_lport_ms_s *ms,
+                       enum port_ms_event event)
+{
+       bfa_trc(ms->port->fcs, ms->port->port_cfg.pwwn);
+       bfa_trc(ms->port->fcs, event);
+
+       switch (event) {
+       case MSSM_EVENT_TIMEOUT:
+               /*
+                * Retry Timer Expired. Re-send
+                */
+               bfa_sm_set_state(ms, bfa_fcs_lport_ms_sm_plogi_sending);
+               bfa_fcs_lport_ms_send_plogi(ms, NULL);
+               break;
+
+       case MSSM_EVENT_PORT_OFFLINE:
+               bfa_sm_set_state(ms, bfa_fcs_lport_ms_sm_offline);
+               bfa_timer_stop(&ms->timer);
+               break;
+
+       default:
+               bfa_sm_fault(ms->port->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_lport_ms_sm_online(struct bfa_fcs_lport_ms_s *ms,
+                       enum port_ms_event event)
+{
+       bfa_trc(ms->port->fcs, ms->port->port_cfg.pwwn);
+       bfa_trc(ms->port->fcs, event);
+
+       switch (event) {
+       case MSSM_EVENT_PORT_OFFLINE:
+               bfa_sm_set_state(ms, bfa_fcs_lport_ms_sm_offline);
+               break;
+
+       case MSSM_EVENT_PORT_FABRIC_RSCN:
+               bfa_sm_set_state(ms, bfa_fcs_lport_ms_sm_gfn_sending);
+               ms->retry_cnt = 0;
+               bfa_fcs_lport_ms_send_gfn(ms, NULL);
+               break;
+
+       default:
+               bfa_sm_fault(ms->port->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_lport_ms_sm_gmal_sending(struct bfa_fcs_lport_ms_s *ms,
+                               enum port_ms_event event)
+{
+       bfa_trc(ms->port->fcs, ms->port->port_cfg.pwwn);
+       bfa_trc(ms->port->fcs, event);
+
+       switch (event) {
+       case MSSM_EVENT_FCXP_SENT:
+               bfa_sm_set_state(ms, bfa_fcs_lport_ms_sm_gmal);
+               break;
+
+       case MSSM_EVENT_PORT_OFFLINE:
+               bfa_sm_set_state(ms, bfa_fcs_lport_ms_sm_offline);
+               bfa_fcxp_walloc_cancel(BFA_FCS_GET_HAL_FROM_PORT(ms->port),
+                                          &ms->fcxp_wqe);
+               break;
+
+       default:
+               bfa_sm_fault(ms->port->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_lport_ms_sm_gmal(struct bfa_fcs_lport_ms_s *ms,
+                               enum port_ms_event event)
+{
+       bfa_trc(ms->port->fcs, ms->port->port_cfg.pwwn);
+       bfa_trc(ms->port->fcs, event);
+
+       switch (event) {
+       case MSSM_EVENT_RSP_ERROR:
+               /*
+                * Start timer for a delayed retry
+                */
+               if (ms->retry_cnt++ < BFA_FCS_MS_CMD_MAX_RETRIES) {
+                       bfa_sm_set_state(ms, bfa_fcs_lport_ms_sm_gmal_retry);
+                       ms->port->stats.ms_retries++;
+                       bfa_timer_start(BFA_FCS_GET_HAL_FROM_PORT(ms->port),
+                               &ms->timer, bfa_fcs_lport_ms_timeout, ms,
+                               BFA_FCS_RETRY_TIMEOUT);
+               } else {
+                       bfa_sm_set_state(ms, bfa_fcs_lport_ms_sm_gfn_sending);
+                       bfa_fcs_lport_ms_send_gfn(ms, NULL);
+                       ms->retry_cnt = 0;
+               }
+               break;
+
+       case MSSM_EVENT_RSP_OK:
+               bfa_sm_set_state(ms, bfa_fcs_lport_ms_sm_gfn_sending);
+               bfa_fcs_lport_ms_send_gfn(ms, NULL);
+               break;
+
+       case MSSM_EVENT_PORT_OFFLINE:
+               bfa_sm_set_state(ms, bfa_fcs_lport_ms_sm_offline);
+               bfa_fcxp_discard(ms->fcxp);
+               break;
+
+       default:
+               bfa_sm_fault(ms->port->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_lport_ms_sm_gmal_retry(struct bfa_fcs_lport_ms_s *ms,
+                               enum port_ms_event event)
+{
+       bfa_trc(ms->port->fcs, ms->port->port_cfg.pwwn);
+       bfa_trc(ms->port->fcs, event);
+
+       switch (event) {
+       case MSSM_EVENT_TIMEOUT:
+               /*
+                * Retry Timer Expired. Re-send
+                */
+               bfa_sm_set_state(ms, bfa_fcs_lport_ms_sm_gmal_sending);
+               bfa_fcs_lport_ms_send_gmal(ms, NULL);
+               break;
+
+       case MSSM_EVENT_PORT_OFFLINE:
+               bfa_sm_set_state(ms, bfa_fcs_lport_ms_sm_offline);
+               bfa_timer_stop(&ms->timer);
+               break;
+
+       default:
+               bfa_sm_fault(ms->port->fcs, event);
+       }
+}
+/**
+ *  ms_pvt MS local functions
+ */
+
+static void
+bfa_fcs_lport_ms_send_gmal(void *ms_cbarg, struct bfa_fcxp_s *fcxp_alloced)
+{
+       struct bfa_fcs_lport_ms_s *ms = ms_cbarg;
+       bfa_fcs_lport_t *port = ms->port;
+       struct fchs_s   fchs;
+       int             len;
+       struct bfa_fcxp_s *fcxp;
+
+       bfa_trc(port->fcs, port->pid);
+
+       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
+       if (!fcxp) {
+               bfa_fcs_fcxp_alloc_wait(port->fcs->bfa, &ms->fcxp_wqe,
+                                       bfa_fcs_lport_ms_send_gmal, ms);
+               return;
+       }
+       ms->fcxp = fcxp;
+
+       len = fc_gmal_req_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
+                            bfa_fcs_lport_get_fcid(port),
+                                bfa_lps_get_peer_nwwn(port->fabric->lps));
+
+       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
+                         FC_CLASS_3, len, &fchs,
+                         bfa_fcs_lport_ms_gmal_response, (void *)ms,
+                         FC_MAX_PDUSZ, FC_FCCT_TOV);
+
+       bfa_sm_send_event(ms, MSSM_EVENT_FCXP_SENT);
+}
+
+static void
+bfa_fcs_lport_ms_gmal_response(void *fcsarg, struct bfa_fcxp_s *fcxp,
+                               void *cbarg, bfa_status_t req_status,
+                               u32 rsp_len, u32 resid_len,
+                               struct fchs_s *rsp_fchs)
+{
+       struct bfa_fcs_lport_ms_s *ms = (struct bfa_fcs_lport_ms_s *) cbarg;
+       bfa_fcs_lport_t *port = ms->port;
+       struct ct_hdr_s         *cthdr = NULL;
+       struct fcgs_gmal_resp_s *gmal_resp;
+       struct fcgs_gmal_entry_s *gmal_entry;
+       u32             num_entries;
+       u8                      *rsp_str;
+
+       bfa_trc(port->fcs, req_status);
+       bfa_trc(port->fcs, port->port_cfg.pwwn);
+
+       /*
+        * Sanity Checks
+        */
+       if (req_status != BFA_STATUS_OK) {
+               bfa_trc(port->fcs, req_status);
+               bfa_sm_send_event(ms, MSSM_EVENT_RSP_ERROR);
+               return;
+       }
+
+       cthdr = (struct ct_hdr_s *) BFA_FCXP_RSP_PLD(fcxp);
+       cthdr->cmd_rsp_code = bfa_os_ntohs(cthdr->cmd_rsp_code);
+
+       if (cthdr->cmd_rsp_code == CT_RSP_ACCEPT) {
+               gmal_resp = (struct fcgs_gmal_resp_s *)(cthdr + 1);
+
+               num_entries = bfa_os_ntohl(gmal_resp->ms_len);
+               if (num_entries == 0) {
+                       bfa_sm_send_event(ms, MSSM_EVENT_RSP_ERROR);
+                       return;
+               }
+               /*
+               * The response could contain multiple Entries.
+               * Entries for SNMP interface, etc.
+               * We look for the entry with a telnet prefix.
+               * First "http://" entry refers to IP addr
+               */
+
+               gmal_entry = (struct fcgs_gmal_entry_s *)gmal_resp->ms_ma;
+               while (num_entries > 0) {
+                       if (strncmp(gmal_entry->prefix,
+                               CT_GMAL_RESP_PREFIX_HTTP,
+                               sizeof(gmal_entry->prefix)) == 0) {
+
+                               /*
+                               * if the IP address is terminating with a '/',
+                               * remove it.
+                               * Byte 0 consists of the length of the string.
+                               */
+                               rsp_str = &(gmal_entry->prefix[0]);
+                               if (rsp_str[gmal_entry->len-1] == '/')
+                                       rsp_str[gmal_entry->len-1] = 0;
+
+                               /* copy IP Address to fabric */
+                               strncpy(bfa_fcs_lport_get_fabric_ipaddr(port),
+                                       gmal_entry->ip_addr,
+                                       BFA_FCS_FABRIC_IPADDR_SZ);
+                               break;
+                       } else {
+                               --num_entries;
+                               ++gmal_entry;
+                       }
+               }
+
+               bfa_sm_send_event(ms, MSSM_EVENT_RSP_OK);
+               return;
+       }
+
+       bfa_trc(port->fcs, cthdr->reason_code);
+       bfa_trc(port->fcs, cthdr->exp_code);
+       bfa_sm_send_event(ms, MSSM_EVENT_RSP_ERROR);
+}
+
+static void
+bfa_fcs_lport_ms_sm_gfn_sending(struct bfa_fcs_lport_ms_s *ms,
+                       enum port_ms_event event)
+{
+       bfa_trc(ms->port->fcs, ms->port->port_cfg.pwwn);
+       bfa_trc(ms->port->fcs, event);
+
+       switch (event) {
+       case MSSM_EVENT_FCXP_SENT:
+               bfa_sm_set_state(ms, bfa_fcs_lport_ms_sm_gfn);
+               break;
+
+       case MSSM_EVENT_PORT_OFFLINE:
+               bfa_sm_set_state(ms, bfa_fcs_lport_ms_sm_offline);
+               bfa_fcxp_walloc_cancel(BFA_FCS_GET_HAL_FROM_PORT(ms->port),
+                                          &ms->fcxp_wqe);
+               break;
+
+       default:
+               bfa_sm_fault(ms->port->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_lport_ms_sm_gfn(struct bfa_fcs_lport_ms_s *ms,
+                       enum port_ms_event event)
+{
+       bfa_trc(ms->port->fcs, ms->port->port_cfg.pwwn);
+       bfa_trc(ms->port->fcs, event);
+
+       switch (event) {
+       case MSSM_EVENT_RSP_ERROR:
+               /*
+                * Start timer for a delayed retry
+                */
+               if (ms->retry_cnt++ < BFA_FCS_MS_CMD_MAX_RETRIES) {
+                       bfa_sm_set_state(ms, bfa_fcs_lport_ms_sm_gfn_retry);
+                       ms->port->stats.ms_retries++;
+                       bfa_timer_start(BFA_FCS_GET_HAL_FROM_PORT(ms->port),
+                               &ms->timer, bfa_fcs_lport_ms_timeout, ms,
+                               BFA_FCS_RETRY_TIMEOUT);
+               } else {
+                       bfa_sm_set_state(ms, bfa_fcs_lport_ms_sm_online);
+                       ms->retry_cnt = 0;
+               }
+               break;
+
+       case MSSM_EVENT_RSP_OK:
+               bfa_sm_set_state(ms, bfa_fcs_lport_ms_sm_online);
+               break;
+
+       case MSSM_EVENT_PORT_OFFLINE:
+               bfa_sm_set_state(ms, bfa_fcs_lport_ms_sm_offline);
+               bfa_fcxp_discard(ms->fcxp);
+               break;
+
+       default:
+               bfa_sm_fault(ms->port->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_lport_ms_sm_gfn_retry(struct bfa_fcs_lport_ms_s *ms,
+                               enum port_ms_event event)
+{
+       bfa_trc(ms->port->fcs, ms->port->port_cfg.pwwn);
+       bfa_trc(ms->port->fcs, event);
+
+       switch (event) {
+       case MSSM_EVENT_TIMEOUT:
+               /*
+                * Retry Timer Expired. Re-send
+                */
+               bfa_sm_set_state(ms, bfa_fcs_lport_ms_sm_gfn_sending);
+               bfa_fcs_lport_ms_send_gfn(ms, NULL);
+               break;
+
+       case MSSM_EVENT_PORT_OFFLINE:
+               bfa_sm_set_state(ms, bfa_fcs_lport_ms_sm_offline);
+               bfa_timer_stop(&ms->timer);
+               break;
+
+       default:
+               bfa_sm_fault(ms->port->fcs, event);
+       }
+}
+/**
+ *  ms_pvt MS local functions
+ */
+
+static void
+bfa_fcs_lport_ms_send_gfn(void *ms_cbarg, struct bfa_fcxp_s *fcxp_alloced)
+{
+       struct bfa_fcs_lport_ms_s *ms = ms_cbarg;
+       bfa_fcs_lport_t *port = ms->port;
+       struct fchs_s           fchs;
+       int                     len;
+       struct bfa_fcxp_s *fcxp;
+
+       bfa_trc(port->fcs, port->pid);
+
+       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
+       if (!fcxp) {
+               bfa_fcs_fcxp_alloc_wait(port->fcs->bfa, &ms->fcxp_wqe,
+                                       bfa_fcs_lport_ms_send_gfn, ms);
+               return;
+       }
+       ms->fcxp = fcxp;
+
+       len = fc_gfn_req_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
+                            bfa_fcs_lport_get_fcid(port),
+                                bfa_lps_get_peer_nwwn(port->fabric->lps));
+
+       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
+                         FC_CLASS_3, len, &fchs,
+                         bfa_fcs_lport_ms_gfn_response, (void *)ms,
+                         FC_MAX_PDUSZ, FC_FCCT_TOV);
+
+       bfa_sm_send_event(ms, MSSM_EVENT_FCXP_SENT);
+}
+
+static void
+bfa_fcs_lport_ms_gfn_response(void *fcsarg, struct bfa_fcxp_s *fcxp,
+                       void *cbarg, bfa_status_t req_status, u32 rsp_len,
+                       u32 resid_len, struct fchs_s *rsp_fchs)
+{
+       struct bfa_fcs_lport_ms_s *ms = (struct bfa_fcs_lport_ms_s *) cbarg;
+       bfa_fcs_lport_t *port = ms->port;
+       struct ct_hdr_s *cthdr = NULL;
+       wwn_t          *gfn_resp;
+
+       bfa_trc(port->fcs, req_status);
+       bfa_trc(port->fcs, port->port_cfg.pwwn);
+
+       /*
+        * Sanity Checks
+        */
+       if (req_status != BFA_STATUS_OK) {
+               bfa_trc(port->fcs, req_status);
+               bfa_sm_send_event(ms, MSSM_EVENT_RSP_ERROR);
+               return;
+       }
+
+       cthdr = (struct ct_hdr_s *) BFA_FCXP_RSP_PLD(fcxp);
+       cthdr->cmd_rsp_code = bfa_os_ntohs(cthdr->cmd_rsp_code);
+
+       if (cthdr->cmd_rsp_code == CT_RSP_ACCEPT) {
+               gfn_resp = (wwn_t *)(cthdr + 1);
+               /* check if it has actually changed */
+               if ((memcmp((void *)&bfa_fcs_lport_get_fabric_name(port),
+                               gfn_resp, sizeof(wwn_t)) != 0)) {
+                       bfa_fcs_fabric_set_fabric_name(port->fabric, *gfn_resp);
+               }
+               bfa_sm_send_event(ms, MSSM_EVENT_RSP_OK);
+               return;
+       }
+
+       bfa_trc(port->fcs, cthdr->reason_code);
+       bfa_trc(port->fcs, cthdr->exp_code);
+       bfa_sm_send_event(ms, MSSM_EVENT_RSP_ERROR);
+}
+
+/**
+ *  ms_pvt MS local functions
+ */
+
+static void
+bfa_fcs_lport_ms_send_plogi(void *ms_cbarg, struct bfa_fcxp_s *fcxp_alloced)
+{
+       struct bfa_fcs_lport_ms_s *ms = ms_cbarg;
+       struct bfa_fcs_lport_s *port = ms->port;
+       struct fchs_s   fchs;
+       int     len;
+       struct bfa_fcxp_s *fcxp;
+
+       bfa_trc(port->fcs, port->pid);
+
+       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
+       if (!fcxp) {
+               port->stats.ms_plogi_alloc_wait++;
+               bfa_fcs_fcxp_alloc_wait(port->fcs->bfa, &ms->fcxp_wqe,
+                                       bfa_fcs_lport_ms_send_plogi, ms);
+               return;
+       }
+       ms->fcxp = fcxp;
+
+       len = fc_plogi_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
+                            bfa_os_hton3b(FC_MGMT_SERVER),
+                            bfa_fcs_lport_get_fcid(port), 0,
+                            port->port_cfg.pwwn, port->port_cfg.nwwn,
+                                bfa_fcport_get_maxfrsize(port->fcs->bfa));
+
+       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
+                         FC_CLASS_3, len, &fchs,
+                         bfa_fcs_lport_ms_plogi_response, (void *)ms,
+                         FC_MAX_PDUSZ, FC_ELS_TOV);
+
+       port->stats.ms_plogi_sent++;
+       bfa_sm_send_event(ms, MSSM_EVENT_FCXP_SENT);
+}
+
+static void
+bfa_fcs_lport_ms_plogi_response(void *fcsarg, struct bfa_fcxp_s *fcxp,
+                       void *cbarg, bfa_status_t req_status,
+                       u32 rsp_len, u32 resid_len, struct fchs_s *rsp_fchs)
+{
+       struct bfa_fcs_lport_ms_s *ms = (struct bfa_fcs_lport_ms_s *) cbarg;
+       struct bfa_fcs_lport_s *port = ms->port;
+       struct fc_els_cmd_s *els_cmd;
+       struct fc_ls_rjt_s *ls_rjt;
+
+       bfa_trc(port->fcs, req_status);
+       bfa_trc(port->fcs, port->port_cfg.pwwn);
+
+       /*
+        * Sanity Checks
+        */
+       if (req_status != BFA_STATUS_OK) {
+               port->stats.ms_plogi_rsp_err++;
+               bfa_trc(port->fcs, req_status);
+               bfa_sm_send_event(ms, MSSM_EVENT_RSP_ERROR);
+               return;
+       }
+
+       els_cmd = (struct fc_els_cmd_s *) BFA_FCXP_RSP_PLD(fcxp);
+
+       switch (els_cmd->els_code) {
+
+       case FC_ELS_ACC:
+               if (rsp_len < sizeof(struct fc_logi_s)) {
+                       bfa_trc(port->fcs, rsp_len);
+                       port->stats.ms_plogi_acc_err++;
+                       bfa_sm_send_event(ms, MSSM_EVENT_RSP_ERROR);
+                       break;
+               }
+               port->stats.ms_plogi_accepts++;
+               bfa_sm_send_event(ms, MSSM_EVENT_RSP_OK);
+               break;
+
+       case FC_ELS_LS_RJT:
+               ls_rjt = (struct fc_ls_rjt_s *) BFA_FCXP_RSP_PLD(fcxp);
+
+               bfa_trc(port->fcs, ls_rjt->reason_code);
+               bfa_trc(port->fcs, ls_rjt->reason_code_expl);
+
+               port->stats.ms_rejects++;
+               bfa_sm_send_event(ms, MSSM_EVENT_RSP_ERROR);
+               break;
+
+       default:
+               port->stats.ms_plogi_unknown_rsp++;
+               bfa_trc(port->fcs, els_cmd->els_code);
+               bfa_sm_send_event(ms, MSSM_EVENT_RSP_ERROR);
+       }
+}
+
+static void
+bfa_fcs_lport_ms_timeout(void *arg)
+{
+       struct bfa_fcs_lport_ms_s *ms = (struct bfa_fcs_lport_ms_s *) arg;
+
+       ms->port->stats.ms_timeouts++;
+       bfa_sm_send_event(ms, MSSM_EVENT_TIMEOUT);
+}
+
+
+void
+bfa_fcs_lport_ms_init(struct bfa_fcs_lport_s *port)
+{
+       struct bfa_fcs_lport_ms_s *ms = BFA_FCS_GET_MS_FROM_PORT(port);
+
+       ms->port = port;
+       bfa_sm_set_state(ms, bfa_fcs_lport_ms_sm_offline);
+
+       /*
+        * Invoke init routines of sub modules.
+        */
+       bfa_fcs_lport_fdmi_init(ms);
+}
+
+void
+bfa_fcs_lport_ms_offline(struct bfa_fcs_lport_s *port)
+{
+       struct bfa_fcs_lport_ms_s *ms = BFA_FCS_GET_MS_FROM_PORT(port);
+
+       ms->port = port;
+       bfa_sm_send_event(ms, MSSM_EVENT_PORT_OFFLINE);
+       bfa_fcs_lport_fdmi_offline(ms);
+}
+
+void
+bfa_fcs_lport_ms_online(struct bfa_fcs_lport_s *port)
+{
+       struct bfa_fcs_lport_ms_s *ms = BFA_FCS_GET_MS_FROM_PORT(port);
+
+       ms->port = port;
+       bfa_sm_send_event(ms, MSSM_EVENT_PORT_ONLINE);
+}
+void
+bfa_fcs_lport_ms_fabric_rscn(struct bfa_fcs_lport_s *port)
+{
+       struct bfa_fcs_lport_ms_s *ms = BFA_FCS_GET_MS_FROM_PORT(port);
+
+       /* todo.  Handle this only  when in Online state */
+       if (bfa_sm_cmp_state(ms, bfa_fcs_lport_ms_sm_online))
+               bfa_sm_send_event(ms, MSSM_EVENT_PORT_FABRIC_RSCN);
+}
+
+/**
+ * @page ns_sm_info VPORT NS State Machine
+ *
+ * @section ns_sm_interactions VPORT NS State Machine Interactions
+ *
+ * @section ns_sm VPORT NS State Machine
+ * img ns_sm.jpg
+ */
+
+/*
+ * forward declarations
+ */
+static void     bfa_fcs_lport_ns_send_plogi(void *ns_cbarg,
+                                          struct bfa_fcxp_s *fcxp_alloced);
+static void     bfa_fcs_lport_ns_send_rspn_id(void *ns_cbarg,
+                                            struct bfa_fcxp_s *fcxp_alloced);
+static void     bfa_fcs_lport_ns_send_rft_id(void *ns_cbarg,
+                                           struct bfa_fcxp_s *fcxp_alloced);
+static void     bfa_fcs_lport_ns_send_rff_id(void *ns_cbarg,
+                                           struct bfa_fcxp_s *fcxp_alloced);
+static void     bfa_fcs_lport_ns_send_gid_ft(void *ns_cbarg,
+                                           struct bfa_fcxp_s *fcxp_alloced);
+static void     bfa_fcs_lport_ns_timeout(void *arg);
+static void     bfa_fcs_lport_ns_plogi_response(void *fcsarg,
+                                              struct bfa_fcxp_s *fcxp,
+                                              void *cbarg,
+                                              bfa_status_t req_status,
+                                              u32 rsp_len,
+                                              u32 resid_len,
+                                              struct fchs_s *rsp_fchs);
+static void     bfa_fcs_lport_ns_rspn_id_response(void *fcsarg,
+                                                struct bfa_fcxp_s *fcxp,
+                                                void *cbarg,
+                                                bfa_status_t req_status,
+                                                u32 rsp_len,
+                                                u32 resid_len,
+                                                struct fchs_s *rsp_fchs);
+static void     bfa_fcs_lport_ns_rft_id_response(void *fcsarg,
+                                               struct bfa_fcxp_s *fcxp,
+                                               void *cbarg,
+                                               bfa_status_t req_status,
+                                               u32 rsp_len,
+                                               u32 resid_len,
+                                               struct fchs_s *rsp_fchs);
+static void     bfa_fcs_lport_ns_rff_id_response(void *fcsarg,
+                                               struct bfa_fcxp_s *fcxp,
+                                               void *cbarg,
+                                               bfa_status_t req_status,
+                                               u32 rsp_len,
+                                               u32 resid_len,
+                                               struct fchs_s *rsp_fchs);
+static void     bfa_fcs_lport_ns_gid_ft_response(void *fcsarg,
+                                               struct bfa_fcxp_s *fcxp,
+                                               void *cbarg,
+                                               bfa_status_t req_status,
+                                               u32 rsp_len,
+                                               u32 resid_len,
+                                               struct fchs_s *rsp_fchs);
+static void     bfa_fcs_lport_ns_process_gidft_pids(
+                               struct bfa_fcs_lport_s *port,
+                               u32 *pid_buf, u32 n_pids);
+
+static void bfa_fcs_lport_ns_boot_target_disc(bfa_fcs_lport_t *port);
+/**
+ *  fcs_ns_sm FCS nameserver interface state machine
+ */
+
+/**
+ * VPort NS State Machine events
+ */
+enum vport_ns_event {
+       NSSM_EVENT_PORT_ONLINE = 1,
+       NSSM_EVENT_PORT_OFFLINE = 2,
+       NSSM_EVENT_PLOGI_SENT = 3,
+       NSSM_EVENT_RSP_OK = 4,
+       NSSM_EVENT_RSP_ERROR = 5,
+       NSSM_EVENT_TIMEOUT = 6,
+       NSSM_EVENT_NS_QUERY = 7,
+       NSSM_EVENT_RSPNID_SENT = 8,
+       NSSM_EVENT_RFTID_SENT = 9,
+       NSSM_EVENT_RFFID_SENT = 10,
+       NSSM_EVENT_GIDFT_SENT = 11,
+};
+
+static void     bfa_fcs_lport_ns_sm_offline(struct bfa_fcs_lport_ns_s *ns,
+                                          enum vport_ns_event event);
+static void     bfa_fcs_lport_ns_sm_plogi_sending(struct bfa_fcs_lport_ns_s *ns,
+                                                enum vport_ns_event event);
+static void     bfa_fcs_lport_ns_sm_plogi(struct bfa_fcs_lport_ns_s *ns,
+                                        enum vport_ns_event event);
+static void     bfa_fcs_lport_ns_sm_plogi_retry(struct bfa_fcs_lport_ns_s *ns,
+                                              enum vport_ns_event event);
+static void     bfa_fcs_lport_ns_sm_sending_rspn_id(
+                                       struct bfa_fcs_lport_ns_s *ns,
+                                       enum vport_ns_event event);
+static void     bfa_fcs_lport_ns_sm_rspn_id(struct bfa_fcs_lport_ns_s *ns,
+                                          enum vport_ns_event event);
+static void     bfa_fcs_lport_ns_sm_rspn_id_retry(struct bfa_fcs_lport_ns_s *ns,
+                                                enum vport_ns_event event);
+static void     bfa_fcs_lport_ns_sm_sending_rft_id(
+                                       struct bfa_fcs_lport_ns_s *ns,
+                                       enum vport_ns_event event);
+static void     bfa_fcs_lport_ns_sm_rft_id_retry(struct bfa_fcs_lport_ns_s *ns,
+                                               enum vport_ns_event event);
+static void     bfa_fcs_lport_ns_sm_rft_id(struct bfa_fcs_lport_ns_s *ns,
+                                         enum vport_ns_event event);
+static void     bfa_fcs_lport_ns_sm_sending_rff_id(
+                                       struct bfa_fcs_lport_ns_s *ns,
+                                       enum vport_ns_event event);
+static void     bfa_fcs_lport_ns_sm_rff_id_retry(struct bfa_fcs_lport_ns_s *ns,
+                                               enum vport_ns_event event);
+static void     bfa_fcs_lport_ns_sm_rff_id(struct bfa_fcs_lport_ns_s *ns,
+                                         enum vport_ns_event event);
+static void     bfa_fcs_lport_ns_sm_sending_gid_ft(
+                                       struct bfa_fcs_lport_ns_s *ns,
+                                       enum vport_ns_event event);
+static void     bfa_fcs_lport_ns_sm_gid_ft(struct bfa_fcs_lport_ns_s *ns,
+                                         enum vport_ns_event event);
+static void     bfa_fcs_lport_ns_sm_gid_ft_retry(struct bfa_fcs_lport_ns_s *ns,
+                                               enum vport_ns_event event);
+static void     bfa_fcs_lport_ns_sm_online(struct bfa_fcs_lport_ns_s *ns,
+                                         enum vport_ns_event event);
+/**
+ *     Start in offline state - awaiting linkup
+ */
+static void
+bfa_fcs_lport_ns_sm_offline(struct bfa_fcs_lport_ns_s *ns,
+                       enum vport_ns_event event)
+{
+       bfa_trc(ns->port->fcs, ns->port->port_cfg.pwwn);
+       bfa_trc(ns->port->fcs, event);
+
+       switch (event) {
+       case NSSM_EVENT_PORT_ONLINE:
+               bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_plogi_sending);
+               bfa_fcs_lport_ns_send_plogi(ns, NULL);
+               break;
+
+       case NSSM_EVENT_PORT_OFFLINE:
+               break;
+
+       default:
+               bfa_sm_fault(ns->port->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_lport_ns_sm_plogi_sending(struct bfa_fcs_lport_ns_s *ns,
+                       enum vport_ns_event event)
+{
+       bfa_trc(ns->port->fcs, ns->port->port_cfg.pwwn);
+       bfa_trc(ns->port->fcs, event);
+
+       switch (event) {
+       case NSSM_EVENT_PLOGI_SENT:
+               bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_plogi);
+               break;
+
+       case NSSM_EVENT_PORT_OFFLINE:
+               bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_offline);
+               bfa_fcxp_walloc_cancel(BFA_FCS_GET_HAL_FROM_PORT(ns->port),
+                                          &ns->fcxp_wqe);
+               break;
+
+       default:
+               bfa_sm_fault(ns->port->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_lport_ns_sm_plogi(struct bfa_fcs_lport_ns_s *ns,
+                       enum vport_ns_event event)
+{
+       bfa_trc(ns->port->fcs, ns->port->port_cfg.pwwn);
+       bfa_trc(ns->port->fcs, event);
+
+       switch (event) {
+       case NSSM_EVENT_RSP_ERROR:
+               /*
+                * Start timer for a delayed retry
+                */
+               bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_plogi_retry);
+               ns->port->stats.ns_retries++;
+               bfa_timer_start(BFA_FCS_GET_HAL_FROM_PORT(ns->port),
+                                   &ns->timer, bfa_fcs_lport_ns_timeout, ns,
+                                   BFA_FCS_RETRY_TIMEOUT);
+               break;
+
+       case NSSM_EVENT_RSP_OK:
+               bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_sending_rspn_id);
+               bfa_fcs_lport_ns_send_rspn_id(ns, NULL);
+               break;
+
+       case NSSM_EVENT_PORT_OFFLINE:
+               bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_offline);
+               bfa_fcxp_discard(ns->fcxp);
+               break;
+
+       default:
+               bfa_sm_fault(ns->port->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_lport_ns_sm_plogi_retry(struct bfa_fcs_lport_ns_s *ns,
+                               enum vport_ns_event event)
+{
+       bfa_trc(ns->port->fcs, ns->port->port_cfg.pwwn);
+       bfa_trc(ns->port->fcs, event);
+
+       switch (event) {
+       case NSSM_EVENT_TIMEOUT:
+               /*
+                * Retry Timer Expired. Re-send
+                */
+               bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_plogi_sending);
+               bfa_fcs_lport_ns_send_plogi(ns, NULL);
+               break;
+
+       case NSSM_EVENT_PORT_OFFLINE:
+               bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_offline);
+               bfa_timer_stop(&ns->timer);
+               break;
+
+       default:
+               bfa_sm_fault(ns->port->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_lport_ns_sm_sending_rspn_id(struct bfa_fcs_lport_ns_s *ns,
+                                  enum vport_ns_event event)
+{
+       bfa_trc(ns->port->fcs, ns->port->port_cfg.pwwn);
+       bfa_trc(ns->port->fcs, event);
+
+       switch (event) {
+       case NSSM_EVENT_RSPNID_SENT:
+               bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_rspn_id);
+               break;
+
+       case NSSM_EVENT_PORT_OFFLINE:
+               bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_offline);
+               bfa_fcxp_walloc_cancel(BFA_FCS_GET_HAL_FROM_PORT(ns->port),
+                                          &ns->fcxp_wqe);
+               break;
+
+       default:
+               bfa_sm_fault(ns->port->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_lport_ns_sm_rspn_id(struct bfa_fcs_lport_ns_s *ns,
+                       enum vport_ns_event event)
+{
+       bfa_trc(ns->port->fcs, ns->port->port_cfg.pwwn);
+       bfa_trc(ns->port->fcs, event);
+
+       switch (event) {
+       case NSSM_EVENT_RSP_ERROR:
+               /*
+                * Start timer for a delayed retry
+                */
+               bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_rspn_id_retry);
+               ns->port->stats.ns_retries++;
+               bfa_timer_start(BFA_FCS_GET_HAL_FROM_PORT(ns->port),
+                                   &ns->timer, bfa_fcs_lport_ns_timeout, ns,
+                                   BFA_FCS_RETRY_TIMEOUT);
+               break;
+
+       case NSSM_EVENT_RSP_OK:
+               bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_sending_rft_id);
+               bfa_fcs_lport_ns_send_rft_id(ns, NULL);
+               break;
+
+       case NSSM_EVENT_PORT_OFFLINE:
+               bfa_fcxp_discard(ns->fcxp);
+               bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_offline);
+               break;
+
+       default:
+               bfa_sm_fault(ns->port->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_lport_ns_sm_rspn_id_retry(struct bfa_fcs_lport_ns_s *ns,
+                               enum vport_ns_event event)
+{
+       bfa_trc(ns->port->fcs, ns->port->port_cfg.pwwn);
+       bfa_trc(ns->port->fcs, event);
+
+       switch (event) {
+       case NSSM_EVENT_TIMEOUT:
+               /*
+                * Retry Timer Expired. Re-send
+                */
+               bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_sending_rspn_id);
+               bfa_fcs_lport_ns_send_rspn_id(ns, NULL);
+               break;
+
+       case NSSM_EVENT_PORT_OFFLINE:
+               bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_offline);
+               bfa_timer_stop(&ns->timer);
+               break;
+
+       default:
+               bfa_sm_fault(ns->port->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_lport_ns_sm_sending_rft_id(struct bfa_fcs_lport_ns_s *ns,
+                                 enum vport_ns_event event)
+{
+       bfa_trc(ns->port->fcs, ns->port->port_cfg.pwwn);
+       bfa_trc(ns->port->fcs, event);
+
+       switch (event) {
+       case NSSM_EVENT_RFTID_SENT:
+               bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_rft_id);
+               break;
+
+       case NSSM_EVENT_PORT_OFFLINE:
+               bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_offline);
+               bfa_fcxp_walloc_cancel(BFA_FCS_GET_HAL_FROM_PORT(ns->port),
+                                          &ns->fcxp_wqe);
+               break;
+
+       default:
+               bfa_sm_fault(ns->port->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_lport_ns_sm_rft_id(struct bfa_fcs_lport_ns_s *ns,
+                       enum vport_ns_event event)
+{
+       bfa_trc(ns->port->fcs, ns->port->port_cfg.pwwn);
+       bfa_trc(ns->port->fcs, event);
+
+       switch (event) {
+       case NSSM_EVENT_RSP_OK:
+               /* Now move to register FC4 Features */
+               bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_sending_rff_id);
+               bfa_fcs_lport_ns_send_rff_id(ns, NULL);
+               break;
+
+       case NSSM_EVENT_RSP_ERROR:
+               /*
+                * Start timer for a delayed retry
+                */
+               bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_rft_id_retry);
+               ns->port->stats.ns_retries++;
+               bfa_timer_start(BFA_FCS_GET_HAL_FROM_PORT(ns->port),
+                                   &ns->timer, bfa_fcs_lport_ns_timeout, ns,
+                                   BFA_FCS_RETRY_TIMEOUT);
+               break;
+
+       case NSSM_EVENT_PORT_OFFLINE:
+               bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_offline);
+               bfa_fcxp_discard(ns->fcxp);
+               break;
+
+       default:
+               bfa_sm_fault(ns->port->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_lport_ns_sm_rft_id_retry(struct bfa_fcs_lport_ns_s *ns,
+                               enum vport_ns_event event)
+{
+       bfa_trc(ns->port->fcs, ns->port->port_cfg.pwwn);
+       bfa_trc(ns->port->fcs, event);
+
+       switch (event) {
+       case NSSM_EVENT_TIMEOUT:
+               bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_sending_rft_id);
+               bfa_fcs_lport_ns_send_rft_id(ns, NULL);
+               break;
+
+       case NSSM_EVENT_PORT_OFFLINE:
+               bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_offline);
+               bfa_timer_stop(&ns->timer);
+               break;
+
+       default:
+               bfa_sm_fault(ns->port->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_lport_ns_sm_sending_rff_id(struct bfa_fcs_lport_ns_s *ns,
+                                 enum vport_ns_event event)
+{
+       bfa_trc(ns->port->fcs, ns->port->port_cfg.pwwn);
+       bfa_trc(ns->port->fcs, event);
+
+       switch (event) {
+       case NSSM_EVENT_RFFID_SENT:
+               bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_rff_id);
+               break;
+
+       case NSSM_EVENT_PORT_OFFLINE:
+               bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_offline);
+               bfa_fcxp_walloc_cancel(BFA_FCS_GET_HAL_FROM_PORT(ns->port),
+                                          &ns->fcxp_wqe);
+               break;
+
+       default:
+               bfa_sm_fault(ns->port->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_lport_ns_sm_rff_id(struct bfa_fcs_lport_ns_s *ns,
+                       enum vport_ns_event event)
+{
+       bfa_trc(ns->port->fcs, ns->port->port_cfg.pwwn);
+       bfa_trc(ns->port->fcs, event);
+
+       switch (event) {
+       case NSSM_EVENT_RSP_OK:
+
+               /*
+                * If min cfg mode is enabled, we donot initiate rport
+                * discovery with the fabric. Instead, we will retrieve the
+                * boot targets from HAL/FW.
+                */
+               if (__fcs_min_cfg(ns->port->fcs)) {
+                       bfa_fcs_lport_ns_boot_target_disc(ns->port);
+                       bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_online);
+                       return;
+               }
+
+               /*
+                * If the port role is Initiator Mode issue NS query.
+                * If it is Target Mode, skip this and go to online.
+                */
+               if (BFA_FCS_VPORT_IS_INITIATOR_MODE(ns->port)) {
+                       bfa_sm_set_state(ns,
+                               bfa_fcs_lport_ns_sm_sending_gid_ft);
+                       bfa_fcs_lport_ns_send_gid_ft(ns, NULL);
+               }
+               /*
+                * kick off mgmt srvr state machine
+                */
+               bfa_fcs_lport_ms_online(ns->port);
+               break;
+
+       case NSSM_EVENT_RSP_ERROR:
+               /*
+                * Start timer for a delayed retry
+                */
+               bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_rff_id_retry);
+               ns->port->stats.ns_retries++;
+               bfa_timer_start(BFA_FCS_GET_HAL_FROM_PORT(ns->port),
+                                   &ns->timer, bfa_fcs_lport_ns_timeout, ns,
+                                   BFA_FCS_RETRY_TIMEOUT);
+               break;
+
+       case NSSM_EVENT_PORT_OFFLINE:
+               bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_offline);
+               bfa_fcxp_discard(ns->fcxp);
+               break;
+
+       default:
+               bfa_sm_fault(ns->port->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_lport_ns_sm_rff_id_retry(struct bfa_fcs_lport_ns_s *ns,
+                               enum vport_ns_event event)
+{
+       bfa_trc(ns->port->fcs, ns->port->port_cfg.pwwn);
+       bfa_trc(ns->port->fcs, event);
+
+       switch (event) {
+       case NSSM_EVENT_TIMEOUT:
+               bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_sending_rff_id);
+               bfa_fcs_lport_ns_send_rff_id(ns, NULL);
+               break;
+
+       case NSSM_EVENT_PORT_OFFLINE:
+               bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_offline);
+               bfa_timer_stop(&ns->timer);
+               break;
+
+       default:
+               bfa_sm_fault(ns->port->fcs, event);
+       }
+}
+static void
+bfa_fcs_lport_ns_sm_sending_gid_ft(struct bfa_fcs_lport_ns_s *ns,
+                                 enum vport_ns_event event)
+{
+       bfa_trc(ns->port->fcs, ns->port->port_cfg.pwwn);
+       bfa_trc(ns->port->fcs, event);
+
+       switch (event) {
+       case NSSM_EVENT_GIDFT_SENT:
+               bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_gid_ft);
+               break;
+
+       case NSSM_EVENT_PORT_OFFLINE:
+               bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_offline);
+               bfa_fcxp_walloc_cancel(BFA_FCS_GET_HAL_FROM_PORT(ns->port),
+                                          &ns->fcxp_wqe);
+               break;
+
+       default:
+               bfa_sm_fault(ns->port->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_lport_ns_sm_gid_ft(struct bfa_fcs_lport_ns_s *ns,
+                       enum vport_ns_event event)
+{
+       bfa_trc(ns->port->fcs, ns->port->port_cfg.pwwn);
+       bfa_trc(ns->port->fcs, event);
+
+       switch (event) {
+       case NSSM_EVENT_RSP_OK:
+               bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_online);
+               break;
+
+       case NSSM_EVENT_RSP_ERROR:
+               /*
+                * TBD: for certain reject codes, we don't need to retry
+                */
+               /*
+                * Start timer for a delayed retry
+                */
+               bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_gid_ft_retry);
+               ns->port->stats.ns_retries++;
+               bfa_timer_start(BFA_FCS_GET_HAL_FROM_PORT(ns->port),
+                                   &ns->timer, bfa_fcs_lport_ns_timeout, ns,
+                                   BFA_FCS_RETRY_TIMEOUT);
+               break;
+
+       case NSSM_EVENT_PORT_OFFLINE:
+               bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_offline);
+               bfa_fcxp_discard(ns->fcxp);
+               break;
+
+       case  NSSM_EVENT_NS_QUERY:
+               break;
+
+       default:
+               bfa_sm_fault(ns->port->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_lport_ns_sm_gid_ft_retry(struct bfa_fcs_lport_ns_s *ns,
+                               enum vport_ns_event event)
+{
+       bfa_trc(ns->port->fcs, ns->port->port_cfg.pwwn);
+       bfa_trc(ns->port->fcs, event);
+
+       switch (event) {
+       case NSSM_EVENT_TIMEOUT:
+               bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_sending_gid_ft);
+               bfa_fcs_lport_ns_send_gid_ft(ns, NULL);
+               break;
+
+       case NSSM_EVENT_PORT_OFFLINE:
+               bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_offline);
+               bfa_timer_stop(&ns->timer);
+               break;
+
+       default:
+               bfa_sm_fault(ns->port->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_lport_ns_sm_online(struct bfa_fcs_lport_ns_s *ns,
+                       enum vport_ns_event event)
+{
+       bfa_trc(ns->port->fcs, ns->port->port_cfg.pwwn);
+       bfa_trc(ns->port->fcs, event);
+
+       switch (event) {
+       case NSSM_EVENT_PORT_OFFLINE:
+               bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_offline);
+               break;
+
+       case NSSM_EVENT_NS_QUERY:
+               /*
+                * If the port role is Initiator Mode issue NS query.
+                * If it is Target Mode, skip this and go to online.
+                */
+               if (BFA_FCS_VPORT_IS_INITIATOR_MODE(ns->port)) {
+                       bfa_sm_set_state(ns,
+                               bfa_fcs_lport_ns_sm_sending_gid_ft);
+                       bfa_fcs_lport_ns_send_gid_ft(ns, NULL);
+               };
+               break;
+
+       default:
+               bfa_sm_fault(ns->port->fcs, event);
+       }
+}
+
+
+
+/**
+ *  ns_pvt Nameserver local functions
+ */
+
+static void
+bfa_fcs_lport_ns_send_plogi(void *ns_cbarg, struct bfa_fcxp_s *fcxp_alloced)
+{
+       struct bfa_fcs_lport_ns_s *ns = ns_cbarg;
+       struct bfa_fcs_lport_s *port = ns->port;
+       struct fchs_s fchs;
+       int             len;
+       struct bfa_fcxp_s *fcxp;
+
+       bfa_trc(port->fcs, port->pid);
+
+fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
+       if (!fcxp) {
+               port->stats.ns_plogi_alloc_wait++;
+               bfa_fcs_fcxp_alloc_wait(port->fcs->bfa, &ns->fcxp_wqe,
+                                       bfa_fcs_lport_ns_send_plogi, ns);
+               return;
+       }
+       ns->fcxp = fcxp;
+
+       len = fc_plogi_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
+                            bfa_os_hton3b(FC_NAME_SERVER),
+                            bfa_fcs_lport_get_fcid(port), 0,
+                            port->port_cfg.pwwn, port->port_cfg.nwwn,
+                                bfa_fcport_get_maxfrsize(port->fcs->bfa));
+
+       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
+                         FC_CLASS_3, len, &fchs,
+                         bfa_fcs_lport_ns_plogi_response, (void *)ns,
+                         FC_MAX_PDUSZ, FC_ELS_TOV);
+       port->stats.ns_plogi_sent++;
+
+       bfa_sm_send_event(ns, NSSM_EVENT_PLOGI_SENT);
+}
+
+static void
+bfa_fcs_lport_ns_plogi_response(void *fcsarg, struct bfa_fcxp_s *fcxp,
+                       void *cbarg, bfa_status_t req_status, u32 rsp_len,
+                      u32 resid_len, struct fchs_s *rsp_fchs)
+{
+       struct bfa_fcs_lport_ns_s *ns = (struct bfa_fcs_lport_ns_s *) cbarg;
+       struct bfa_fcs_lport_s *port = ns->port;
+       /* struct fc_logi_s *plogi_resp; */
+       struct fc_els_cmd_s *els_cmd;
+       struct fc_ls_rjt_s *ls_rjt;
+
+       bfa_trc(port->fcs, req_status);
+       bfa_trc(port->fcs, port->port_cfg.pwwn);
+
+       /*
+        * Sanity Checks
+        */
+       if (req_status != BFA_STATUS_OK) {
+               bfa_trc(port->fcs, req_status);
+               port->stats.ns_plogi_rsp_err++;
+               bfa_sm_send_event(ns, NSSM_EVENT_RSP_ERROR);
+               return;
+       }
+
+       els_cmd = (struct fc_els_cmd_s *) BFA_FCXP_RSP_PLD(fcxp);
+
+       switch (els_cmd->els_code) {
+
+       case FC_ELS_ACC:
+               if (rsp_len < sizeof(struct fc_logi_s)) {
+                       bfa_trc(port->fcs, rsp_len);
+                       port->stats.ns_plogi_acc_err++;
+                       bfa_sm_send_event(ns, NSSM_EVENT_RSP_ERROR);
+                       break;
+               }
+               port->stats.ns_plogi_accepts++;
+               bfa_sm_send_event(ns, NSSM_EVENT_RSP_OK);
+               break;
+
+       case FC_ELS_LS_RJT:
+               ls_rjt = (struct fc_ls_rjt_s *) BFA_FCXP_RSP_PLD(fcxp);
+
+               bfa_trc(port->fcs, ls_rjt->reason_code);
+               bfa_trc(port->fcs, ls_rjt->reason_code_expl);
+
+               port->stats.ns_rejects++;
+
+               bfa_sm_send_event(ns, NSSM_EVENT_RSP_ERROR);
+               break;
+
+       default:
+               port->stats.ns_plogi_unknown_rsp++;
+               bfa_trc(port->fcs, els_cmd->els_code);
+               bfa_sm_send_event(ns, NSSM_EVENT_RSP_ERROR);
+       }
+}
+
+/**
+ * Register the symbolic port name.
+ */
+static void
+bfa_fcs_lport_ns_send_rspn_id(void *ns_cbarg, struct bfa_fcxp_s *fcxp_alloced)
+{
+       struct bfa_fcs_lport_ns_s *ns = ns_cbarg;
+       struct bfa_fcs_lport_s *port = ns->port;
+       struct fchs_s fchs;
+       int             len;
+       struct bfa_fcxp_s *fcxp;
+       u8         symbl[256];
+       u8         *psymbl = &symbl[0];
+
+       bfa_os_memset(symbl, 0, sizeof(symbl));
+
+       bfa_trc(port->fcs, port->port_cfg.pwwn);
+
+       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
+       if (!fcxp) {
+               port->stats.ns_rspnid_alloc_wait++;
+               bfa_fcs_fcxp_alloc_wait(port->fcs->bfa, &ns->fcxp_wqe,
+                                       bfa_fcs_lport_ns_send_rspn_id, ns);
+               return;
+       }
+       ns->fcxp = fcxp;
+
+       /*
+        * for V-Port, form a Port Symbolic Name
+        */
+       if (port->vport) {
+               /**
+                * For Vports, we append the vport's port symbolic name
+                * to that of the base port.
+                */
+
+               strncpy((char *)psymbl,
+                       (char *) &
+                       (bfa_fcs_lport_get_psym_name
+                        (bfa_fcs_get_base_port(port->fcs))),
+                       strlen((char *) &
+                              bfa_fcs_lport_get_psym_name(bfa_fcs_get_base_port
+                                                         (port->fcs))));
+
+               /* Ensure we have a null terminating string. */
+               ((char *)psymbl)[strlen((char *) &
+                       bfa_fcs_lport_get_psym_name(bfa_fcs_get_base_port
+                                               (port->fcs)))] = 0;
+               strncat((char *)psymbl,
+                       (char *) &(bfa_fcs_lport_get_psym_name(port)),
+               strlen((char *) &bfa_fcs_lport_get_psym_name(port)));
+       } else {
+               psymbl = (u8 *) &(bfa_fcs_lport_get_psym_name(port));
+       }
+
+       len = fc_rspnid_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
+                             bfa_fcs_lport_get_fcid(port), 0, psymbl);
+
+       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
+                         FC_CLASS_3, len, &fchs,
+                         bfa_fcs_lport_ns_rspn_id_response, (void *)ns,
+                         FC_MAX_PDUSZ, FC_FCCT_TOV);
+
+       port->stats.ns_rspnid_sent++;
+
+       bfa_sm_send_event(ns, NSSM_EVENT_RSPNID_SENT);
+}
+
+static void
+bfa_fcs_lport_ns_rspn_id_response(void *fcsarg, struct bfa_fcxp_s *fcxp,
+                                void *cbarg, bfa_status_t req_status,
+                                u32 rsp_len, u32 resid_len,
+                                struct fchs_s *rsp_fchs)
+{
+       struct bfa_fcs_lport_ns_s *ns = (struct bfa_fcs_lport_ns_s *) cbarg;
+       struct bfa_fcs_lport_s *port = ns->port;
+       struct ct_hdr_s *cthdr = NULL;
+
+       bfa_trc(port->fcs, port->port_cfg.pwwn);
+
+       /*
+        * Sanity Checks
+        */
+       if (req_status != BFA_STATUS_OK) {
+               bfa_trc(port->fcs, req_status);
+               port->stats.ns_rspnid_rsp_err++;
+               bfa_sm_send_event(ns, NSSM_EVENT_RSP_ERROR);
+               return;
+       }
+
+       cthdr = (struct ct_hdr_s *) BFA_FCXP_RSP_PLD(fcxp);
+       cthdr->cmd_rsp_code = bfa_os_ntohs(cthdr->cmd_rsp_code);
+
+       if (cthdr->cmd_rsp_code == CT_RSP_ACCEPT) {
+               port->stats.ns_rspnid_accepts++;
+               bfa_sm_send_event(ns, NSSM_EVENT_RSP_OK);
+               return;
+       }
+
+       port->stats.ns_rspnid_rejects++;
+       bfa_trc(port->fcs, cthdr->reason_code);
+       bfa_trc(port->fcs, cthdr->exp_code);
+       bfa_sm_send_event(ns, NSSM_EVENT_RSP_ERROR);
+}
+
+/**
+ * Register FC4-Types
+ */
+static void
+bfa_fcs_lport_ns_send_rft_id(void *ns_cbarg, struct bfa_fcxp_s *fcxp_alloced)
+{
+       struct bfa_fcs_lport_ns_s *ns = ns_cbarg;
+       struct bfa_fcs_lport_s *port = ns->port;
+       struct fchs_s fchs;
+       int             len;
+       struct bfa_fcxp_s *fcxp;
+
+       bfa_trc(port->fcs, port->port_cfg.pwwn);
+
+       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
+       if (!fcxp) {
+               port->stats.ns_rftid_alloc_wait++;
+               bfa_fcs_fcxp_alloc_wait(port->fcs->bfa, &ns->fcxp_wqe,
+                                       bfa_fcs_lport_ns_send_rft_id, ns);
+               return;
+       }
+       ns->fcxp = fcxp;
+
+       len = fc_rftid_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
+                    bfa_fcs_lport_get_fcid(port), 0, port->port_cfg.roles);
+
+       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
+                         FC_CLASS_3, len, &fchs,
+                         bfa_fcs_lport_ns_rft_id_response, (void *)ns,
+                         FC_MAX_PDUSZ, FC_FCCT_TOV);
+
+       port->stats.ns_rftid_sent++;
+       bfa_sm_send_event(ns, NSSM_EVENT_RFTID_SENT);
+}
+
+static void
+bfa_fcs_lport_ns_rft_id_response(void *fcsarg, struct bfa_fcxp_s *fcxp,
+                               void *cbarg, bfa_status_t req_status,
+                               u32 rsp_len, u32 resid_len,
+                               struct fchs_s *rsp_fchs)
+{
+       struct bfa_fcs_lport_ns_s *ns = (struct bfa_fcs_lport_ns_s *) cbarg;
+       struct bfa_fcs_lport_s *port = ns->port;
+       struct ct_hdr_s *cthdr = NULL;
+
+       bfa_trc(port->fcs, port->port_cfg.pwwn);
+
+       /*
+        * Sanity Checks
+        */
+       if (req_status != BFA_STATUS_OK) {
+               bfa_trc(port->fcs, req_status);
+               port->stats.ns_rftid_rsp_err++;
+               bfa_sm_send_event(ns, NSSM_EVENT_RSP_ERROR);
+               return;
+       }
+
+       cthdr = (struct ct_hdr_s *) BFA_FCXP_RSP_PLD(fcxp);
+       cthdr->cmd_rsp_code = bfa_os_ntohs(cthdr->cmd_rsp_code);
+
+       if (cthdr->cmd_rsp_code == CT_RSP_ACCEPT) {
+               port->stats.ns_rftid_accepts++;
+               bfa_sm_send_event(ns, NSSM_EVENT_RSP_OK);
+               return;
+       }
+
+       port->stats.ns_rftid_rejects++;
+       bfa_trc(port->fcs, cthdr->reason_code);
+       bfa_trc(port->fcs, cthdr->exp_code);
+       bfa_sm_send_event(ns, NSSM_EVENT_RSP_ERROR);
+}
+
+/**
+ * Register FC4-Features : Should be done after RFT_ID
+ */
+static void
+bfa_fcs_lport_ns_send_rff_id(void *ns_cbarg, struct bfa_fcxp_s *fcxp_alloced)
+{
+       struct bfa_fcs_lport_ns_s *ns = ns_cbarg;
+       struct bfa_fcs_lport_s *port = ns->port;
+       struct fchs_s fchs;
+       int             len;
+       struct bfa_fcxp_s *fcxp;
+       u8                      fc4_ftrs = 0;
+
+       bfa_trc(port->fcs, port->port_cfg.pwwn);
+
+       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
+       if (!fcxp) {
+               port->stats.ns_rffid_alloc_wait++;
+               bfa_fcs_fcxp_alloc_wait(port->fcs->bfa, &ns->fcxp_wqe,
+                                       bfa_fcs_lport_ns_send_rff_id, ns);
+               return;
+       }
+       ns->fcxp = fcxp;
+
+       if (BFA_FCS_VPORT_IS_INITIATOR_MODE(ns->port))
+               fc4_ftrs = FC_GS_FCP_FC4_FEATURE_INITIATOR;
+
+       len = fc_rffid_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
+                            bfa_fcs_lport_get_fcid(port), 0,
+                                FC_TYPE_FCP, fc4_ftrs);
+
+       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
+                         FC_CLASS_3, len, &fchs,
+                         bfa_fcs_lport_ns_rff_id_response, (void *)ns,
+                         FC_MAX_PDUSZ, FC_FCCT_TOV);
+
+       port->stats.ns_rffid_sent++;
+       bfa_sm_send_event(ns, NSSM_EVENT_RFFID_SENT);
+}
+
+static void
+bfa_fcs_lport_ns_rff_id_response(void *fcsarg, struct bfa_fcxp_s *fcxp,
+                               void *cbarg, bfa_status_t req_status,
+                               u32 rsp_len, u32 resid_len,
+                               struct fchs_s *rsp_fchs)
+{
+       struct bfa_fcs_lport_ns_s *ns = (struct bfa_fcs_lport_ns_s *) cbarg;
+       struct bfa_fcs_lport_s *port = ns->port;
+       struct ct_hdr_s *cthdr = NULL;
+
+       bfa_trc(port->fcs, port->port_cfg.pwwn);
+
+       /*
+        * Sanity Checks
+        */
+       if (req_status != BFA_STATUS_OK) {
+               bfa_trc(port->fcs, req_status);
+               port->stats.ns_rffid_rsp_err++;
+               bfa_sm_send_event(ns, NSSM_EVENT_RSP_ERROR);
+               return;
+       }
+
+       cthdr = (struct ct_hdr_s *) BFA_FCXP_RSP_PLD(fcxp);
+       cthdr->cmd_rsp_code = bfa_os_ntohs(cthdr->cmd_rsp_code);
+
+       if (cthdr->cmd_rsp_code == CT_RSP_ACCEPT) {
+               port->stats.ns_rffid_accepts++;
+               bfa_sm_send_event(ns, NSSM_EVENT_RSP_OK);
+               return;
+       }
+
+       port->stats.ns_rffid_rejects++;
+       bfa_trc(port->fcs, cthdr->reason_code);
+       bfa_trc(port->fcs, cthdr->exp_code);
+
+       if (cthdr->reason_code == CT_RSN_NOT_SUPP) {
+               /* if this command is not supported, we don't retry */
+               bfa_sm_send_event(ns, NSSM_EVENT_RSP_OK);
+       } else
+               bfa_sm_send_event(ns, NSSM_EVENT_RSP_ERROR);
+}
+/**
+ * Query Fabric for FC4-Types Devices.
+ *
+* TBD : Need to use a local (FCS private) response buffer, since the response
+ * can be larger than 2K.
+ */
+static void
+bfa_fcs_lport_ns_send_gid_ft(void *ns_cbarg, struct bfa_fcxp_s *fcxp_alloced)
+{
+       struct bfa_fcs_lport_ns_s *ns = ns_cbarg;
+       struct bfa_fcs_lport_s *port = ns->port;
+       struct fchs_s fchs;
+       int             len;
+       struct bfa_fcxp_s *fcxp;
+
+       bfa_trc(port->fcs, port->pid);
+
+       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
+       if (!fcxp) {
+               port->stats.ns_gidft_alloc_wait++;
+               bfa_fcs_fcxp_alloc_wait(port->fcs->bfa, &ns->fcxp_wqe,
+                                       bfa_fcs_lport_ns_send_gid_ft, ns);
+               return;
+       }
+       ns->fcxp = fcxp;
+
+       /*
+        * This query is only initiated for FCP initiator mode.
+        */
+       len = fc_gid_ft_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
+                             ns->port->pid, FC_TYPE_FCP);
+
+       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
+                         FC_CLASS_3, len, &fchs,
+                         bfa_fcs_lport_ns_gid_ft_response, (void *)ns,
+                         bfa_fcxp_get_maxrsp(port->fcs->bfa), FC_FCCT_TOV);
+
+       port->stats.ns_gidft_sent++;
+
+       bfa_sm_send_event(ns, NSSM_EVENT_GIDFT_SENT);
+}
+
+static void
+bfa_fcs_lport_ns_gid_ft_response(void *fcsarg, struct bfa_fcxp_s *fcxp,
+                               void *cbarg, bfa_status_t req_status,
+                               u32 rsp_len, u32 resid_len,
+                               struct fchs_s *rsp_fchs)
+{
+       struct bfa_fcs_lport_ns_s *ns = (struct bfa_fcs_lport_ns_s *) cbarg;
+       struct bfa_fcs_lport_s *port = ns->port;
+       struct ct_hdr_s *cthdr = NULL;
+       u32        n_pids;
+
+       bfa_trc(port->fcs, port->port_cfg.pwwn);
+
+       /*
+        * Sanity Checks
+        */
+       if (req_status != BFA_STATUS_OK) {
+               bfa_trc(port->fcs, req_status);
+               port->stats.ns_gidft_rsp_err++;
+               bfa_sm_send_event(ns, NSSM_EVENT_RSP_ERROR);
+               return;
+       }
+
+       if (resid_len != 0) {
+               /*
+                * TBD : we will need to allocate a larger buffer & retry the
+                * command
+                */
+               bfa_trc(port->fcs, rsp_len);
+               bfa_trc(port->fcs, resid_len);
+               return;
+       }
+
+       cthdr = (struct ct_hdr_s *) BFA_FCXP_RSP_PLD(fcxp);
+       cthdr->cmd_rsp_code = bfa_os_ntohs(cthdr->cmd_rsp_code);
+
+       switch (cthdr->cmd_rsp_code) {
+
+       case CT_RSP_ACCEPT:
+
+               port->stats.ns_gidft_accepts++;
+               n_pids = (fc_get_ctresp_pyld_len(rsp_len) / sizeof(u32));
+               bfa_trc(port->fcs, n_pids);
+               bfa_fcs_lport_ns_process_gidft_pids(port,
+                                                  (u32 *) (cthdr + 1),
+                                                  n_pids);
+               bfa_sm_send_event(ns, NSSM_EVENT_RSP_OK);
+               break;
+
+       case CT_RSP_REJECT:
+
+               /*
+                * Check the reason code  & explanation.
+                * There may not have been any FC4 devices in the fabric
+                */
+               port->stats.ns_gidft_rejects++;
+               bfa_trc(port->fcs, cthdr->reason_code);
+               bfa_trc(port->fcs, cthdr->exp_code);
+
+               if ((cthdr->reason_code == CT_RSN_UNABLE_TO_PERF)
+                   && (cthdr->exp_code == CT_NS_EXP_FT_NOT_REG)) {
+
+                       bfa_sm_send_event(ns, NSSM_EVENT_RSP_OK);
+               } else {
+                       /*
+                        * for all other errors, retry
+                        */
+                       bfa_sm_send_event(ns, NSSM_EVENT_RSP_ERROR);
+               }
+               break;
+
+       default:
+               port->stats.ns_gidft_unknown_rsp++;
+               bfa_trc(port->fcs, cthdr->cmd_rsp_code);
+               bfa_sm_send_event(ns, NSSM_EVENT_RSP_ERROR);
+       }
+}
+
+/**
+ *     This routine will be called by bfa_timer on timer timeouts.
+ *
+ *     param[in]       port - pointer to bfa_fcs_lport_t.
+ *
+ *     return
+ *             void
+ *
+ *     Special Considerations:
+ *
+ *     note
+ */
+static void
+bfa_fcs_lport_ns_timeout(void *arg)
+{
+       struct bfa_fcs_lport_ns_s *ns = (struct bfa_fcs_lport_ns_s *) arg;
+
+       ns->port->stats.ns_timeouts++;
+       bfa_sm_send_event(ns, NSSM_EVENT_TIMEOUT);
+}
+
+/*
+ * Process the PID list in GID_FT response
+ */
+static void
+bfa_fcs_lport_ns_process_gidft_pids(struct bfa_fcs_lport_s *port, u32 *pid_buf,
+                                  u32 n_pids)
+{
+       struct fcgs_gidft_resp_s *gidft_entry;
+       struct bfa_fcs_rport_s *rport;
+       u32        ii;
+
+       for (ii = 0; ii < n_pids; ii++) {
+               gidft_entry = (struct fcgs_gidft_resp_s *) &pid_buf[ii];
+
+               if (gidft_entry->pid == port->pid)
+                       continue;
+
+               /*
+                * Check if this rport already exists
+                */
+               rport = bfa_fcs_lport_get_rport_by_pid(port, gidft_entry->pid);
+               if (rport == NULL) {
+                       /*
+                        * this is a new device. create rport
+                        */
+                       rport = bfa_fcs_rport_create(port, gidft_entry->pid);
+               } else {
+                       /*
+                        * this rport already exists
+                        */
+                       bfa_fcs_rport_scn(rport);
+               }
+
+               bfa_trc(port->fcs, gidft_entry->pid);
+
+               /*
+                * if the last entry bit is set, bail out.
+                */
+               if (gidft_entry->last)
+                       return;
+       }
+}
+
+/**
+ *  fcs_ns_public FCS nameserver public interfaces
+ */
+
+/*
+ * Functions called by port/fab.
+ * These will send relevant Events to the ns state machine.
+ */
+void
+bfa_fcs_lport_ns_init(struct bfa_fcs_lport_s *port)
+{
+       struct bfa_fcs_lport_ns_s *ns = BFA_FCS_GET_NS_FROM_PORT(port);
+
+       ns->port = port;
+       bfa_sm_set_state(ns, bfa_fcs_lport_ns_sm_offline);
+}
+
+void
+bfa_fcs_lport_ns_offline(struct bfa_fcs_lport_s *port)
+{
+       struct bfa_fcs_lport_ns_s *ns = BFA_FCS_GET_NS_FROM_PORT(port);
+
+       ns->port = port;
+       bfa_sm_send_event(ns, NSSM_EVENT_PORT_OFFLINE);
+}
+
+void
+bfa_fcs_lport_ns_online(struct bfa_fcs_lport_s *port)
+{
+       struct bfa_fcs_lport_ns_s *ns = BFA_FCS_GET_NS_FROM_PORT(port);
+
+       ns->port = port;
+       bfa_sm_send_event(ns, NSSM_EVENT_PORT_ONLINE);
+}
+
+void
+bfa_fcs_lport_ns_query(struct bfa_fcs_lport_s *port)
+{
+       struct bfa_fcs_lport_ns_s *ns = BFA_FCS_GET_NS_FROM_PORT(port);
+
+       bfa_trc(port->fcs, port->pid);
+       bfa_sm_send_event(ns, NSSM_EVENT_NS_QUERY);
+}
+
+void
+bfa_fcs_lport_ns_boot_target_disc(bfa_fcs_lport_t *port)
+{
+
+       struct bfa_fcs_rport_s *rport;
+       u8 nwwns;
+       wwn_t  wwns[BFA_PREBOOT_BOOTLUN_MAX];
+       int ii;
+
+       bfa_iocfc_get_bootwwns(port->fcs->bfa, &nwwns, wwns);
+
+       for (ii = 0 ; ii < nwwns; ++ii) {
+               rport = bfa_fcs_rport_create_by_wwn(port, wwns[ii]);
+               bfa_assert(rport);
+       }
+}
+
+/**
+ * FCS SCN
+ */
+
+#define FC_QOS_RSCN_EVENT              0x0c
+#define FC_FABRIC_NAME_RSCN_EVENT      0x0d
+
+/*
+ * forward declarations
+ */
+static void     bfa_fcs_lport_scn_send_scr(void *scn_cbarg,
+                                         struct bfa_fcxp_s *fcxp_alloced);
+static void     bfa_fcs_lport_scn_scr_response(void *fcsarg,
+                                             struct bfa_fcxp_s *fcxp,
+                                             void *cbarg,
+                                             bfa_status_t req_status,
+                                             u32 rsp_len,
+                                             u32 resid_len,
+                                             struct fchs_s *rsp_fchs);
+static void     bfa_fcs_lport_scn_send_ls_acc(struct bfa_fcs_lport_s *port,
+                                            struct fchs_s *rx_fchs);
+static void     bfa_fcs_lport_scn_timeout(void *arg);
+
+/**
+ *  fcs_scm_sm FCS SCN state machine
+ */
+
+/**
+ * VPort SCN State Machine events
+ */
+enum port_scn_event {
+       SCNSM_EVENT_PORT_ONLINE = 1,
+       SCNSM_EVENT_PORT_OFFLINE = 2,
+       SCNSM_EVENT_RSP_OK = 3,
+       SCNSM_EVENT_RSP_ERROR = 4,
+       SCNSM_EVENT_TIMEOUT = 5,
+       SCNSM_EVENT_SCR_SENT = 6,
+};
+
+static void     bfa_fcs_lport_scn_sm_offline(struct bfa_fcs_lport_scn_s *scn,
+                                           enum port_scn_event event);
+static void     bfa_fcs_lport_scn_sm_sending_scr(
+                                       struct bfa_fcs_lport_scn_s *scn,
+                                       enum port_scn_event event);
+static void     bfa_fcs_lport_scn_sm_scr(struct bfa_fcs_lport_scn_s *scn,
+                                       enum port_scn_event event);
+static void     bfa_fcs_lport_scn_sm_scr_retry(struct bfa_fcs_lport_scn_s *scn,
+                                             enum port_scn_event event);
+static void     bfa_fcs_lport_scn_sm_online(struct bfa_fcs_lport_scn_s *scn,
+                                          enum port_scn_event event);
+
+/**
+ *     Starting state - awaiting link up.
+ */
+static void
+bfa_fcs_lport_scn_sm_offline(struct bfa_fcs_lport_scn_s *scn,
+                       enum port_scn_event event)
+{
+       switch (event) {
+       case SCNSM_EVENT_PORT_ONLINE:
+               bfa_sm_set_state(scn, bfa_fcs_lport_scn_sm_sending_scr);
+               bfa_fcs_lport_scn_send_scr(scn, NULL);
+               break;
+
+       case SCNSM_EVENT_PORT_OFFLINE:
+               break;
+
+       default:
+               bfa_sm_fault(scn->port->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_lport_scn_sm_sending_scr(struct bfa_fcs_lport_scn_s *scn,
+                               enum port_scn_event event)
+{
+       switch (event) {
+       case SCNSM_EVENT_SCR_SENT:
+               bfa_sm_set_state(scn, bfa_fcs_lport_scn_sm_scr);
+               break;
+
+       case SCNSM_EVENT_PORT_OFFLINE:
+               bfa_sm_set_state(scn, bfa_fcs_lport_scn_sm_offline);
+               bfa_fcxp_walloc_cancel(scn->port->fcs->bfa, &scn->fcxp_wqe);
+               break;
+
+       default:
+               bfa_sm_fault(scn->port->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_lport_scn_sm_scr(struct bfa_fcs_lport_scn_s *scn,
+                       enum port_scn_event event)
+{
+       struct bfa_fcs_lport_s *port = scn->port;
+
+       switch (event) {
+       case SCNSM_EVENT_RSP_OK:
+               bfa_sm_set_state(scn, bfa_fcs_lport_scn_sm_online);
+               break;
+
+       case SCNSM_EVENT_RSP_ERROR:
+               bfa_sm_set_state(scn, bfa_fcs_lport_scn_sm_scr_retry);
+               bfa_timer_start(port->fcs->bfa, &scn->timer,
+                                   bfa_fcs_lport_scn_timeout, scn,
+                                   BFA_FCS_RETRY_TIMEOUT);
+               break;
+
+       case SCNSM_EVENT_PORT_OFFLINE:
+               bfa_sm_set_state(scn, bfa_fcs_lport_scn_sm_offline);
+               bfa_fcxp_discard(scn->fcxp);
+               break;
+
+       default:
+               bfa_sm_fault(port->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_lport_scn_sm_scr_retry(struct bfa_fcs_lport_scn_s *scn,
+                               enum port_scn_event event)
+{
+       switch (event) {
+       case SCNSM_EVENT_TIMEOUT:
+               bfa_sm_set_state(scn, bfa_fcs_lport_scn_sm_sending_scr);
+               bfa_fcs_lport_scn_send_scr(scn, NULL);
+               break;
+
+       case SCNSM_EVENT_PORT_OFFLINE:
+               bfa_sm_set_state(scn, bfa_fcs_lport_scn_sm_offline);
+               bfa_timer_stop(&scn->timer);
+               break;
+
+       default:
+               bfa_sm_fault(scn->port->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_lport_scn_sm_online(struct bfa_fcs_lport_scn_s *scn,
+                       enum port_scn_event event)
+{
+       switch (event) {
+       case SCNSM_EVENT_PORT_OFFLINE:
+               bfa_sm_set_state(scn, bfa_fcs_lport_scn_sm_offline);
+               break;
+
+       default:
+               bfa_sm_fault(scn->port->fcs, event);
+       }
+}
+
+
+
+/**
+ *  fcs_scn_private FCS SCN private functions
+ */
+
+/**
+ * This routine will be called to send a SCR command.
+ */
+static void
+bfa_fcs_lport_scn_send_scr(void *scn_cbarg, struct bfa_fcxp_s *fcxp_alloced)
+{
+       struct bfa_fcs_lport_scn_s *scn = scn_cbarg;
+       struct bfa_fcs_lport_s *port = scn->port;
+       struct fchs_s fchs;
+       int             len;
+       struct bfa_fcxp_s *fcxp;
+
+       bfa_trc(port->fcs, port->pid);
+       bfa_trc(port->fcs, port->port_cfg.pwwn);
+
+       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
+       if (!fcxp) {
+               bfa_fcs_fcxp_alloc_wait(port->fcs->bfa, &scn->fcxp_wqe,
+                                       bfa_fcs_lport_scn_send_scr, scn);
+               return;
+       }
+       scn->fcxp = fcxp;
+
+       /* Handle VU registrations for Base port only */
+       if ((!port->vport) && bfa_ioc_get_fcmode(&port->fcs->bfa->ioc)) {
+               len = fc_scr_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
+                               bfa_lps_is_brcd_fabric(port->fabric->lps),
+                                                       port->pid, 0);
+       } else {
+           len = fc_scr_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
+                                   BFA_FALSE,
+                                   port->pid, 0);
+       }
+
+       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
+                         FC_CLASS_3, len, &fchs,
+                         bfa_fcs_lport_scn_scr_response,
+                         (void *)scn, FC_MAX_PDUSZ, FC_ELS_TOV);
+
+       bfa_sm_send_event(scn, SCNSM_EVENT_SCR_SENT);
+}
+
+static void
+bfa_fcs_lport_scn_scr_response(void *fcsarg, struct bfa_fcxp_s *fcxp,
+                       void *cbarg, bfa_status_t req_status, u32 rsp_len,
+                             u32 resid_len, struct fchs_s *rsp_fchs)
+{
+       struct bfa_fcs_lport_scn_s *scn = (struct bfa_fcs_lport_scn_s *) cbarg;
+       struct bfa_fcs_lport_s *port = scn->port;
+       struct fc_els_cmd_s *els_cmd;
+       struct fc_ls_rjt_s *ls_rjt;
+
+       bfa_trc(port->fcs, port->port_cfg.pwwn);
+
+       /*
+        * Sanity Checks
+        */
+       if (req_status != BFA_STATUS_OK) {
+               bfa_trc(port->fcs, req_status);
+               bfa_sm_send_event(scn, SCNSM_EVENT_RSP_ERROR);
+               return;
+       }
+
+       els_cmd = (struct fc_els_cmd_s *) BFA_FCXP_RSP_PLD(fcxp);
+
+       switch (els_cmd->els_code) {
+
+       case FC_ELS_ACC:
+               bfa_sm_send_event(scn, SCNSM_EVENT_RSP_OK);
+               break;
+
+       case FC_ELS_LS_RJT:
+
+               ls_rjt = (struct fc_ls_rjt_s *) BFA_FCXP_RSP_PLD(fcxp);
+
+               bfa_trc(port->fcs, ls_rjt->reason_code);
+               bfa_trc(port->fcs, ls_rjt->reason_code_expl);
+
+               bfa_sm_send_event(scn, SCNSM_EVENT_RSP_ERROR);
+               break;
+
+       default:
+               bfa_sm_send_event(scn, SCNSM_EVENT_RSP_ERROR);
+       }
+}
+
+/*
+ * Send a LS Accept
+ */
+static void
+bfa_fcs_lport_scn_send_ls_acc(struct bfa_fcs_lport_s *port,
+                               struct fchs_s *rx_fchs)
+{
+       struct fchs_s fchs;
+       struct bfa_fcxp_s *fcxp;
+       struct bfa_rport_s *bfa_rport = NULL;
+       int             len;
+
+       bfa_trc(port->fcs, rx_fchs->s_id);
+
+       fcxp = bfa_fcs_fcxp_alloc(port->fcs);
+       if (!fcxp)
+               return;
+
+       len = fc_ls_acc_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
+                             rx_fchs->s_id, bfa_fcs_lport_get_fcid(port),
+                             rx_fchs->ox_id);
+
+       bfa_fcxp_send(fcxp, bfa_rport, port->fabric->vf_id, port->lp_tag,
+                         BFA_FALSE, FC_CLASS_3, len, &fchs, NULL, NULL,
+                         FC_MAX_PDUSZ, 0);
+}
+
+/**
+ *     This routine will be called by bfa_timer on timer timeouts.
+ *
+ *     param[in]       vport           - pointer to bfa_fcs_lport_t.
+ *     param[out]      vport_status    - pointer to return vport status in
+ *
+ *     return
+ *             void
+ *
+ *     Special Considerations:
+ *
+ *     note
+ */
+static void
+bfa_fcs_lport_scn_timeout(void *arg)
+{
+       struct bfa_fcs_lport_scn_s *scn = (struct bfa_fcs_lport_scn_s *) arg;
+
+       bfa_sm_send_event(scn, SCNSM_EVENT_TIMEOUT);
+}
+
+
+
+/**
+ *  fcs_scn_public FCS state change notification public interfaces
+ */
+
+/*
+ * Functions called by port/fab
+ */
+void
+bfa_fcs_lport_scn_init(struct bfa_fcs_lport_s *port)
+{
+       struct bfa_fcs_lport_scn_s *scn = BFA_FCS_GET_SCN_FROM_PORT(port);
+
+       scn->port = port;
+       bfa_sm_set_state(scn, bfa_fcs_lport_scn_sm_offline);
+}
+
+void
+bfa_fcs_lport_scn_offline(struct bfa_fcs_lport_s *port)
+{
+       struct bfa_fcs_lport_scn_s *scn = BFA_FCS_GET_SCN_FROM_PORT(port);
+
+       scn->port = port;
+       bfa_sm_send_event(scn, SCNSM_EVENT_PORT_OFFLINE);
+}
+
+void
+bfa_fcs_lport_scn_online(struct bfa_fcs_lport_s *port)
+{
+       struct bfa_fcs_lport_scn_s *scn = BFA_FCS_GET_SCN_FROM_PORT(port);
+
+       scn->port = port;
+       bfa_sm_send_event(scn, SCNSM_EVENT_PORT_ONLINE);
+}
+
+static void
+bfa_fcs_lport_scn_portid_rscn(struct bfa_fcs_lport_s *port, u32 rpid)
+{
+       struct bfa_fcs_rport_s *rport;
+
+       bfa_trc(port->fcs, rpid);
+
+       /**
+        * If this is an unknown device, then it just came online.
+        * Otherwise let rport handle the RSCN event.
+        */
+       rport = bfa_fcs_lport_get_rport_by_pid(port, rpid);
+       if (rport == NULL) {
+               /*
+                * If min cfg mode is enabled, we donot need to
+                * discover any new rports.
+                */
+               if (!__fcs_min_cfg(port->fcs))
+                       rport = bfa_fcs_rport_create(port, rpid);
+       } else
+               bfa_fcs_rport_scn(rport);
+}
+
+/**
+ * rscn format based PID comparison
+ */
+#define __fc_pid_match(__c0, __c1, __fmt)              \
+       (((__fmt) == FC_RSCN_FORMAT_FABRIC) ||          \
+        (((__fmt) == FC_RSCN_FORMAT_DOMAIN) &&         \
+         ((__c0)[0] == (__c1)[0])) ||                          \
+        (((__fmt) == FC_RSCN_FORMAT_AREA) &&           \
+         ((__c0)[0] == (__c1)[0]) &&                           \
+         ((__c0)[1] == (__c1)[1])))
+
+static void
+bfa_fcs_lport_scn_multiport_rscn(struct bfa_fcs_lport_s *port,
+                               enum fc_rscn_format format,
+                               u32 rscn_pid)
+{
+       struct bfa_fcs_rport_s *rport;
+       struct list_head        *qe, *qe_next;
+       u8        *c0, *c1;
+
+       bfa_trc(port->fcs, format);
+       bfa_trc(port->fcs, rscn_pid);
+
+       c0 = (u8 *) &rscn_pid;
+
+       list_for_each_safe(qe, qe_next, &port->rport_q) {
+               rport = (struct bfa_fcs_rport_s *) qe;
+               c1 = (u8 *) &rport->pid;
+               if (__fc_pid_match(c0, c1, format))
+                       bfa_fcs_rport_scn(rport);
+       }
+}
+
+
+void
+bfa_fcs_lport_scn_process_rscn(struct bfa_fcs_lport_s *port,
+                       struct fchs_s *fchs, u32 len)
+{
+       struct fc_rscn_pl_s *rscn = (struct fc_rscn_pl_s *) (fchs + 1);
+       int             num_entries;
+       u32        rscn_pid;
+       bfa_boolean_t   nsquery = BFA_FALSE, found;
+       int             i = 0, j;
+
+       num_entries =
+               (bfa_os_ntohs(rscn->payldlen) -
+                sizeof(u32)) / sizeof(rscn->event[0]);
+
+       bfa_trc(port->fcs, num_entries);
+
+       port->stats.num_rscn++;
+
+       bfa_fcs_lport_scn_send_ls_acc(port, fchs);
+
+       for (i = 0; i < num_entries; i++) {
+               rscn_pid = rscn->event[i].portid;
+
+               bfa_trc(port->fcs, rscn->event[i].format);
+               bfa_trc(port->fcs, rscn_pid);
+
+               /* check for duplicate entries in the list */
+               found = BFA_FALSE;
+               for (j = 0; j < i; j++) {
+                       if (rscn->event[j].portid == rscn_pid) {
+                               found = BFA_TRUE;
+                               break;
+                       }
+               }
+
+               /* if found in down the list, pid has been already processed */
+               if (found) {
+                       bfa_trc(port->fcs, rscn_pid);
+                       continue;
+               }
+
+               switch (rscn->event[i].format) {
+               case FC_RSCN_FORMAT_PORTID:
+                       if (rscn->event[i].qualifier == FC_QOS_RSCN_EVENT) {
+                               /*
+                                * Ignore this event.
+                                * f/w would have processed it
+                                */
+                               bfa_trc(port->fcs, rscn_pid);
+                       } else {
+                               port->stats.num_portid_rscn++;
+                               bfa_fcs_lport_scn_portid_rscn(port, rscn_pid);
+                       }
+               break;
+
+               case FC_RSCN_FORMAT_FABRIC:
+                       if (rscn->event[i].qualifier ==
+                                       FC_FABRIC_NAME_RSCN_EVENT) {
+                               bfa_fcs_lport_ms_fabric_rscn(port);
+                               break;
+                       }
+                       /* !!!!!!!!! Fall Through !!!!!!!!!!!!! */
+
+               case FC_RSCN_FORMAT_AREA:
+               case FC_RSCN_FORMAT_DOMAIN:
+                       nsquery = BFA_TRUE;
+                       bfa_fcs_lport_scn_multiport_rscn(port,
+                                                       rscn->event[i].format,
+                                                       rscn_pid);
+                       break;
+
+
+               default:
+                       bfa_assert(0);
+                       nsquery = BFA_TRUE;
+               }
+       }
+
+       /**
+        * If any of area, domain or fabric RSCN is received, do a fresh discovery
+        * to find new devices.
+        */
+       if (nsquery)
+               bfa_fcs_lport_ns_query(port);
+}
+
+/**
+ * BFA FCS port
+ */
+/**
+ *  fcs_port_api BFA FCS port API
+ */
+struct bfa_fcs_lport_s *
+bfa_fcs_get_base_port(struct bfa_fcs_s *fcs)
+{
+       return &fcs->fabric.bport;
+}
+
+wwn_t
+bfa_fcs_lport_get_rport(struct bfa_fcs_lport_s *port, wwn_t wwn, int index,
+               int nrports, bfa_boolean_t bwwn)
+{
+       struct list_head        *qh, *qe;
+       struct bfa_fcs_rport_s *rport = NULL;
+       int     i;
+       struct bfa_fcs_s        *fcs;
+
+       if (port == NULL || nrports == 0)
+               return (wwn_t) 0;
+
+       fcs = port->fcs;
+       bfa_trc(fcs, (u32) nrports);
+
+       i = 0;
+       qh = &port->rport_q;
+       qe = bfa_q_first(qh);
+
+       while ((qe != qh) && (i < nrports)) {
+               rport = (struct bfa_fcs_rport_s *) qe;
+               if (bfa_os_ntoh3b(rport->pid) > 0xFFF000) {
+                       qe = bfa_q_next(qe);
+                       bfa_trc(fcs, (u32) rport->pwwn);
+                       bfa_trc(fcs, rport->pid);
+                       bfa_trc(fcs, i);
+                       continue;
+               }
+
+               if (bwwn) {
+                       if (!memcmp(&wwn, &rport->pwwn, 8))
+                               break;
+               } else {
+                       if (i == index)
+                               break;
+               }
+
+               i++;
+               qe = bfa_q_next(qe);
+       }
+
+       bfa_trc(fcs, i);
+       if (rport)
+               return rport->pwwn;
+       else
+               return (wwn_t) 0;
+}
+
+void
+bfa_fcs_lport_get_rports(struct bfa_fcs_lport_s *port,
+        wwn_t rport_wwns[], int *nrports)
+{
+       struct list_head        *qh, *qe;
+       struct bfa_fcs_rport_s *rport = NULL;
+       int     i;
+       struct bfa_fcs_s        *fcs;
+
+       if (port == NULL || rport_wwns == NULL || *nrports == 0)
+               return;
+
+       fcs = port->fcs;
+       bfa_trc(fcs, (u32) *nrports);
+
+       i = 0;
+       qh = &port->rport_q;
+       qe = bfa_q_first(qh);
+
+       while ((qe != qh) && (i < *nrports)) {
+               rport = (struct bfa_fcs_rport_s *) qe;
+               if (bfa_os_ntoh3b(rport->pid) > 0xFFF000) {
+                       qe = bfa_q_next(qe);
+                       bfa_trc(fcs, (u32) rport->pwwn);
+                       bfa_trc(fcs, rport->pid);
+                       bfa_trc(fcs, i);
+                       continue;
+               }
+
+               rport_wwns[i] = rport->pwwn;
+
+               i++;
+               qe = bfa_q_next(qe);
+       }
+
+       bfa_trc(fcs, i);
+       *nrports = i;
+}
+
+/*
+ * Iterate's through all the rport's in the given port to
+ * determine the maximum operating speed.
+ *
+ * !!!! To be used in TRL Functionality only !!!!
+ */
+bfa_port_speed_t
+bfa_fcs_lport_get_rport_max_speed(bfa_fcs_lport_t *port)
+{
+       struct list_head *qh, *qe;
+       struct bfa_fcs_rport_s *rport = NULL;
+       struct bfa_fcs_s        *fcs;
+       bfa_port_speed_t max_speed = 0;
+       struct bfa_port_attr_s port_attr;
+       bfa_port_speed_t port_speed, rport_speed;
+       bfa_boolean_t trl_enabled = bfa_fcport_is_ratelim(port->fcs->bfa);
+
+
+       if (port == NULL)
+               return 0;
+
+       fcs = port->fcs;
+
+       /* Get Physical port's current speed */
+       bfa_fcport_get_attr(port->fcs->bfa, &port_attr);
+       port_speed = port_attr.speed;
+       bfa_trc(fcs, port_speed);
+
+       qh = &port->rport_q;
+       qe = bfa_q_first(qh);
+
+       while (qe != qh) {
+               rport = (struct bfa_fcs_rport_s *) qe;
+               if ((bfa_os_ntoh3b(rport->pid) > 0xFFF000) ||
+                       (bfa_fcs_rport_get_state(rport) ==
+                         BFA_RPORT_OFFLINE)) {
+                       qe = bfa_q_next(qe);
+                       continue;
+               }
+
+               rport_speed = rport->rpf.rpsc_speed;
+               if ((trl_enabled) && (rport_speed ==
+                       BFA_PORT_SPEED_UNKNOWN)) {
+                       /* Use default ratelim speed setting */
+                       rport_speed =
+                               bfa_fcport_get_ratelim_speed(port->fcs->bfa);
+               }
+
+               if      ((rport_speed  == BFA_PORT_SPEED_8GBPS) ||
+                       (rport_speed > port_speed)) {
+                       max_speed = rport_speed;
+                       break;
+               } else if (rport_speed > max_speed) {
+                       max_speed = rport_speed;
+               }
+
+               qe = bfa_q_next(qe);
+       }
+
+       bfa_trc(fcs, max_speed);
+       return max_speed;
+}
+
+struct bfa_fcs_lport_s *
+bfa_fcs_lookup_port(struct bfa_fcs_s *fcs, u16 vf_id, wwn_t lpwwn)
+{
+       struct bfa_fcs_vport_s *vport;
+       bfa_fcs_vf_t   *vf;
+
+       bfa_assert(fcs != NULL);
+
+       vf = bfa_fcs_vf_lookup(fcs, vf_id);
+       if (vf == NULL) {
+               bfa_trc(fcs, vf_id);
+               return NULL;
+       }
+
+       if (!lpwwn || (vf->bport.port_cfg.pwwn == lpwwn))
+               return &vf->bport;
+
+       vport = bfa_fcs_fabric_vport_lookup(vf, lpwwn);
+       if (vport)
+               return &vport->lport;
+
+       return NULL;
+}
+
+/*
+ *  API corresponding to NPIV_VPORT_GETINFO.
+ */
+void
+bfa_fcs_lport_get_info(struct bfa_fcs_lport_s *port,
+        struct bfa_lport_info_s *port_info)
+{
+
+       bfa_trc(port->fcs, port->fabric->fabric_name);
+
+       if (port->vport == NULL) {
+               /*
+                * This is a Physical port
+                */
+               port_info->port_type = BFA_LPORT_TYPE_PHYSICAL;
+
+               /*
+                * @todo : need to fix the state & reason
+                */
+               port_info->port_state = 0;
+               port_info->offline_reason = 0;
+
+               port_info->port_wwn = bfa_fcs_lport_get_pwwn(port);
+               port_info->node_wwn = bfa_fcs_lport_get_nwwn(port);
+
+               port_info->max_vports_supp =
+                       bfa_lps_get_max_vport(port->fcs->bfa);
+               port_info->num_vports_inuse =
+                       bfa_fcs_fabric_vport_count(port->fabric);
+               port_info->max_rports_supp = BFA_FCS_MAX_RPORTS_SUPP;
+               port_info->num_rports_inuse = port->num_rports;
+       } else {
+               /*
+                * This is a virtual port
+                */
+               port_info->port_type = BFA_LPORT_TYPE_VIRTUAL;
+
+               /*
+                * @todo : need to fix the state & reason
+                */
+               port_info->port_state = 0;
+               port_info->offline_reason = 0;
+
+               port_info->port_wwn = bfa_fcs_lport_get_pwwn(port);
+               port_info->node_wwn = bfa_fcs_lport_get_nwwn(port);
+       }
+}
+
+void
+bfa_fcs_lport_get_stats(struct bfa_fcs_lport_s *fcs_port,
+        struct bfa_lport_stats_s *port_stats)
+{
+       *port_stats = fcs_port->stats;
+}
+
+void
+bfa_fcs_lport_clear_stats(struct bfa_fcs_lport_s *fcs_port)
+{
+       bfa_os_memset(&fcs_port->stats, 0, sizeof(struct bfa_lport_stats_s));
+}
+
+/**
+ * FCS virtual port state machine
+ */
+
+#define __vport_fcs(__vp)       ((__vp)->lport.fcs)
+#define __vport_pwwn(__vp)      ((__vp)->lport.port_cfg.pwwn)
+#define __vport_nwwn(__vp)      ((__vp)->lport.port_cfg.nwwn)
+#define __vport_bfa(__vp)       ((__vp)->lport.fcs->bfa)
+#define __vport_fcid(__vp)      ((__vp)->lport.pid)
+#define __vport_fabric(__vp)    ((__vp)->lport.fabric)
+#define __vport_vfid(__vp)      ((__vp)->lport.fabric->vf_id)
+
+#define BFA_FCS_VPORT_MAX_RETRIES  5
+/*
+ * Forward declarations
+ */
+static void     bfa_fcs_vport_do_fdisc(struct bfa_fcs_vport_s *vport);
+static void     bfa_fcs_vport_timeout(void *vport_arg);
+static void     bfa_fcs_vport_do_logo(struct bfa_fcs_vport_s *vport);
+static void     bfa_fcs_vport_free(struct bfa_fcs_vport_s *vport);
+
+/**
+ *  fcs_vport_sm FCS virtual port state machine
+ */
+
+/**
+ * VPort State Machine events
+ */
+enum bfa_fcs_vport_event {
+       BFA_FCS_VPORT_SM_CREATE = 1,    /*  vport create event */
+       BFA_FCS_VPORT_SM_DELETE = 2,    /*  vport delete event */
+       BFA_FCS_VPORT_SM_START = 3,     /*  vport start request */
+       BFA_FCS_VPORT_SM_STOP = 4,      /*  stop: unsupported */
+       BFA_FCS_VPORT_SM_ONLINE = 5,    /*  fabric online */
+       BFA_FCS_VPORT_SM_OFFLINE = 6,   /*  fabric offline event */
+       BFA_FCS_VPORT_SM_FRMSENT = 7,   /*  fdisc/logo sent events */
+       BFA_FCS_VPORT_SM_RSP_OK = 8,    /*  good response */
+       BFA_FCS_VPORT_SM_RSP_ERROR = 9, /*  error/bad response */
+       BFA_FCS_VPORT_SM_TIMEOUT = 10,  /*  delay timer event */
+       BFA_FCS_VPORT_SM_DELCOMP = 11,  /*  lport delete completion */
+       BFA_FCS_VPORT_SM_RSP_DUP_WWN = 12,      /*  Dup wnn error*/
+       BFA_FCS_VPORT_SM_RSP_FAILED = 13,       /*  non-retryable failure */
+};
+
+static void     bfa_fcs_vport_sm_uninit(struct bfa_fcs_vport_s *vport,
+                                       enum bfa_fcs_vport_event event);
+static void     bfa_fcs_vport_sm_created(struct bfa_fcs_vport_s *vport,
+                                        enum bfa_fcs_vport_event event);
+static void     bfa_fcs_vport_sm_offline(struct bfa_fcs_vport_s *vport,
+                                        enum bfa_fcs_vport_event event);
+static void     bfa_fcs_vport_sm_fdisc(struct bfa_fcs_vport_s *vport,
+                                      enum bfa_fcs_vport_event event);
+static void     bfa_fcs_vport_sm_fdisc_retry(struct bfa_fcs_vport_s *vport,
+                                            enum bfa_fcs_vport_event event);
+static void     bfa_fcs_vport_sm_online(struct bfa_fcs_vport_s *vport,
+                                       enum bfa_fcs_vport_event event);
+static void     bfa_fcs_vport_sm_deleting(struct bfa_fcs_vport_s *vport,
+                                         enum bfa_fcs_vport_event event);
+static void     bfa_fcs_vport_sm_cleanup(struct bfa_fcs_vport_s *vport,
+                                        enum bfa_fcs_vport_event event);
+static void     bfa_fcs_vport_sm_logo(struct bfa_fcs_vport_s *vport,
+                                     enum bfa_fcs_vport_event event);
+static void     bfa_fcs_vport_sm_error(struct bfa_fcs_vport_s *vport,
+                                     enum bfa_fcs_vport_event event);
+
+static struct bfa_sm_table_s  vport_sm_table[] = {
+       {BFA_SM(bfa_fcs_vport_sm_uninit), BFA_FCS_VPORT_UNINIT},
+       {BFA_SM(bfa_fcs_vport_sm_created), BFA_FCS_VPORT_CREATED},
+       {BFA_SM(bfa_fcs_vport_sm_offline), BFA_FCS_VPORT_OFFLINE},
+       {BFA_SM(bfa_fcs_vport_sm_fdisc), BFA_FCS_VPORT_FDISC},
+       {BFA_SM(bfa_fcs_vport_sm_fdisc_retry), BFA_FCS_VPORT_FDISC_RETRY},
+       {BFA_SM(bfa_fcs_vport_sm_online), BFA_FCS_VPORT_ONLINE},
+       {BFA_SM(bfa_fcs_vport_sm_deleting), BFA_FCS_VPORT_DELETING},
+       {BFA_SM(bfa_fcs_vport_sm_cleanup), BFA_FCS_VPORT_CLEANUP},
+       {BFA_SM(bfa_fcs_vport_sm_logo), BFA_FCS_VPORT_LOGO},
+       {BFA_SM(bfa_fcs_vport_sm_error), BFA_FCS_VPORT_ERROR}
+};
+
+/**
+ * Beginning state.
+ */
+static void
+bfa_fcs_vport_sm_uninit(struct bfa_fcs_vport_s *vport,
+                       enum bfa_fcs_vport_event event)
+{
+       bfa_trc(__vport_fcs(vport), __vport_pwwn(vport));
+       bfa_trc(__vport_fcs(vport), event);
+
+       switch (event) {
+       case BFA_FCS_VPORT_SM_CREATE:
+               bfa_sm_set_state(vport, bfa_fcs_vport_sm_created);
+               bfa_fcs_fabric_addvport(__vport_fabric(vport), vport);
+               break;
+
+       default:
+               bfa_sm_fault(__vport_fcs(vport), event);
+       }
+}
+
+/**
+ * Created state - a start event is required to start up the state machine.
+ */
+static void
+bfa_fcs_vport_sm_created(struct bfa_fcs_vport_s *vport,
+                       enum bfa_fcs_vport_event event)
+{
+       bfa_trc(__vport_fcs(vport), __vport_pwwn(vport));
+       bfa_trc(__vport_fcs(vport), event);
+
+       switch (event) {
+       case BFA_FCS_VPORT_SM_START:
+               if (bfa_fcs_fabric_is_online(__vport_fabric(vport))
+                   && bfa_fcs_fabric_npiv_capable(__vport_fabric(vport))) {
+                       bfa_sm_set_state(vport, bfa_fcs_vport_sm_fdisc);
+                       bfa_fcs_vport_do_fdisc(vport);
+               } else {
+                       /**
+                        * Fabric is offline or not NPIV capable, stay in
+                        * offline state.
+                        */
+                       vport->vport_stats.fab_no_npiv++;
+                       bfa_sm_set_state(vport, bfa_fcs_vport_sm_offline);
+               }
+               break;
+
+       case BFA_FCS_VPORT_SM_DELETE:
+               bfa_sm_set_state(vport, bfa_fcs_vport_sm_cleanup);
+               bfa_fcs_lport_delete(&vport->lport);
+               break;
+
+       case BFA_FCS_VPORT_SM_ONLINE:
+       case BFA_FCS_VPORT_SM_OFFLINE:
+               /**
+                * Ignore ONLINE/OFFLINE events from fabric
+                * till vport is started.
+                */
+               break;
+
+       default:
+               bfa_sm_fault(__vport_fcs(vport), event);
+       }
+}
+
+/**
+ * Offline state - awaiting ONLINE event from fabric SM.
+ */
+static void
+bfa_fcs_vport_sm_offline(struct bfa_fcs_vport_s *vport,
+                       enum bfa_fcs_vport_event event)
+{
+       bfa_trc(__vport_fcs(vport), __vport_pwwn(vport));
+       bfa_trc(__vport_fcs(vport), event);
+
+       switch (event) {
+       case BFA_FCS_VPORT_SM_DELETE:
+               bfa_sm_set_state(vport, bfa_fcs_vport_sm_cleanup);
+               bfa_fcs_lport_delete(&vport->lport);
+               break;
+
+       case BFA_FCS_VPORT_SM_ONLINE:
+               bfa_sm_set_state(vport, bfa_fcs_vport_sm_fdisc);
+               vport->fdisc_retries = 0;
+               bfa_fcs_vport_do_fdisc(vport);
+               break;
+
+       case BFA_FCS_VPORT_SM_OFFLINE:
+               /*
+                * This can happen if the vport couldn't be initialzied
+                * due the fact that the npiv was not enabled on the switch.
+                * In that case we will put the vport in offline state.
+                * However, the link can go down and cause the this event to
+                * be sent when we are already offline. Ignore it.
+                */
+               break;
+
+       default:
+               bfa_sm_fault(__vport_fcs(vport), event);
+       }
+}
+
+
+/**
+ * FDISC is sent and awaiting reply from fabric.
+ */
+static void
+bfa_fcs_vport_sm_fdisc(struct bfa_fcs_vport_s *vport,
+                       enum bfa_fcs_vport_event event)
+{
+       bfa_trc(__vport_fcs(vport), __vport_pwwn(vport));
+       bfa_trc(__vport_fcs(vport), event);
+
+       switch (event) {
+       case BFA_FCS_VPORT_SM_DELETE:
+               bfa_sm_set_state(vport, bfa_fcs_vport_sm_cleanup);
+               bfa_lps_discard(vport->lps);
+               bfa_fcs_lport_delete(&vport->lport);
+               break;
+
+       case BFA_FCS_VPORT_SM_OFFLINE:
+               bfa_sm_set_state(vport, bfa_fcs_vport_sm_offline);
+               bfa_lps_discard(vport->lps);
+               break;
+
+       case BFA_FCS_VPORT_SM_RSP_OK:
+               bfa_sm_set_state(vport, bfa_fcs_vport_sm_online);
+               bfa_fcs_lport_online(&vport->lport);
+               break;
+
+       case BFA_FCS_VPORT_SM_RSP_ERROR:
+               bfa_sm_set_state(vport, bfa_fcs_vport_sm_fdisc_retry);
+               bfa_timer_start(__vport_bfa(vport), &vport->timer,
+                                   bfa_fcs_vport_timeout, vport,
+                                   BFA_FCS_RETRY_TIMEOUT);
+               break;
+
+       case BFA_FCS_VPORT_SM_RSP_FAILED:
+               bfa_sm_set_state(vport, bfa_fcs_vport_sm_offline);
+               break;
+
+       case BFA_FCS_VPORT_SM_RSP_DUP_WWN:
+               bfa_sm_set_state(vport, bfa_fcs_vport_sm_error);
+               break;
+
+       default:
+               bfa_sm_fault(__vport_fcs(vport), event);
+       }
+}
+
+/**
+ * FDISC attempt failed - a timer is active to retry FDISC.
+ */
+static void
+bfa_fcs_vport_sm_fdisc_retry(struct bfa_fcs_vport_s *vport,
+                            enum bfa_fcs_vport_event event)
+{
+       bfa_trc(__vport_fcs(vport), __vport_pwwn(vport));
+       bfa_trc(__vport_fcs(vport), event);
+
+       switch (event) {
+       case BFA_FCS_VPORT_SM_DELETE:
+               bfa_sm_set_state(vport, bfa_fcs_vport_sm_cleanup);
+               bfa_timer_stop(&vport->timer);
+               bfa_fcs_lport_delete(&vport->lport);
+               break;
+
+       case BFA_FCS_VPORT_SM_OFFLINE:
+               bfa_sm_set_state(vport, bfa_fcs_vport_sm_offline);
+               bfa_timer_stop(&vport->timer);
+               break;
+
+       case BFA_FCS_VPORT_SM_TIMEOUT:
+               bfa_sm_set_state(vport, bfa_fcs_vport_sm_fdisc);
+               vport->vport_stats.fdisc_retries++;
+               vport->fdisc_retries++;
+               bfa_fcs_vport_do_fdisc(vport);
+               break;
+
+       default:
+               bfa_sm_fault(__vport_fcs(vport), event);
+       }
+}
+
+/**
+ * Vport is online (FDISC is complete).
+ */
+static void
+bfa_fcs_vport_sm_online(struct bfa_fcs_vport_s *vport,
+                       enum bfa_fcs_vport_event event)
+{
+       bfa_trc(__vport_fcs(vport), __vport_pwwn(vport));
+       bfa_trc(__vport_fcs(vport), event);
+
+       switch (event) {
+       case BFA_FCS_VPORT_SM_DELETE:
+               bfa_sm_set_state(vport, bfa_fcs_vport_sm_deleting);
+               bfa_fcs_lport_delete(&vport->lport);
+               break;
+
+       case BFA_FCS_VPORT_SM_OFFLINE:
+               bfa_sm_set_state(vport, bfa_fcs_vport_sm_offline);
+               bfa_lps_discard(vport->lps);
+               bfa_fcs_lport_offline(&vport->lport);
+               break;
+
+       default:
+               bfa_sm_fault(__vport_fcs(vport), event);
+       }
+}
+
+/**
+ * Vport is being deleted - awaiting lport delete completion to send
+ * LOGO to fabric.
+ */
+static void
+bfa_fcs_vport_sm_deleting(struct bfa_fcs_vport_s *vport,
+                       enum bfa_fcs_vport_event event)
+{
+       bfa_trc(__vport_fcs(vport), __vport_pwwn(vport));
+       bfa_trc(__vport_fcs(vport), event);
+
+       switch (event) {
+       case BFA_FCS_VPORT_SM_DELETE:
+               break;
+
+       case BFA_FCS_VPORT_SM_DELCOMP:
+               bfa_sm_set_state(vport, bfa_fcs_vport_sm_logo);
+               bfa_fcs_vport_do_logo(vport);
+               break;
+
+       case BFA_FCS_VPORT_SM_OFFLINE:
+               bfa_sm_set_state(vport, bfa_fcs_vport_sm_cleanup);
+               break;
+
+       default:
+               bfa_sm_fault(__vport_fcs(vport), event);
+       }
+}
+
+/**
+ * Error State.
+ * This state will be set when the Vport Creation fails due
+ * to errors like Dup WWN. In this state only operation allowed
+ * is a Vport Delete.
+ */
+static void
+bfa_fcs_vport_sm_error(struct bfa_fcs_vport_s *vport,
+                       enum bfa_fcs_vport_event event)
+{
+       bfa_trc(__vport_fcs(vport), __vport_pwwn(vport));
+       bfa_trc(__vport_fcs(vport), event);
+
+       switch (event) {
+       case BFA_FCS_VPORT_SM_DELETE:
+               bfa_sm_set_state(vport, bfa_fcs_vport_sm_cleanup);
+               bfa_fcs_lport_delete(&vport->lport);
+               break;
+
+       default:
+               bfa_trc(__vport_fcs(vport), event);
+       }
+}
+
+/**
+ * Lport cleanup is in progress since vport is being deleted. Fabric is
+ * offline, so no LOGO is needed to complete vport deletion.
+ */
+static void
+bfa_fcs_vport_sm_cleanup(struct bfa_fcs_vport_s *vport,
+                       enum bfa_fcs_vport_event event)
+{
+       bfa_trc(__vport_fcs(vport), __vport_pwwn(vport));
+       bfa_trc(__vport_fcs(vport), event);
+
+       switch (event) {
+       case BFA_FCS_VPORT_SM_DELCOMP:
+               bfa_sm_set_state(vport, bfa_fcs_vport_sm_uninit);
+               bfa_fcs_vport_free(vport);
+               break;
+
+       case BFA_FCS_VPORT_SM_DELETE:
+               break;
+
+       default:
+               bfa_sm_fault(__vport_fcs(vport), event);
+       }
+}
+
+/**
+ * LOGO is sent to fabric. Vport delete is in progress. Lport delete cleanup
+ * is done.
+ */
+static void
+bfa_fcs_vport_sm_logo(struct bfa_fcs_vport_s *vport,
+                       enum bfa_fcs_vport_event event)
+{
+       bfa_trc(__vport_fcs(vport), __vport_pwwn(vport));
+       bfa_trc(__vport_fcs(vport), event);
+
+       switch (event) {
+       case BFA_FCS_VPORT_SM_OFFLINE:
+               bfa_lps_discard(vport->lps);
+               /*
+                * !!! fall through !!!
+                */
+
+       case BFA_FCS_VPORT_SM_RSP_OK:
+       case BFA_FCS_VPORT_SM_RSP_ERROR:
+               bfa_sm_set_state(vport, bfa_fcs_vport_sm_uninit);
+               bfa_fcs_vport_free(vport);
+               break;
+
+       case BFA_FCS_VPORT_SM_DELETE:
+               break;
+
+       default:
+               bfa_sm_fault(__vport_fcs(vport), event);
+       }
+}
+
+
+
+/**
+ *  fcs_vport_private FCS virtual port private functions
+ */
+/**
+ * This routine will be called to send a FDISC command.
+ */
+static void
+bfa_fcs_vport_do_fdisc(struct bfa_fcs_vport_s *vport)
+{
+       bfa_lps_fdisc(vport->lps, vport,
+               bfa_fcport_get_maxfrsize(__vport_bfa(vport)),
+               __vport_pwwn(vport), __vport_nwwn(vport));
+       vport->vport_stats.fdisc_sent++;
+}
+
+static void
+bfa_fcs_vport_fdisc_rejected(struct bfa_fcs_vport_s *vport)
+{
+       u8              lsrjt_rsn = bfa_lps_get_lsrjt_rsn(vport->lps);
+       u8              lsrjt_expl = bfa_lps_get_lsrjt_expl(vport->lps);
+
+       bfa_trc(__vport_fcs(vport), lsrjt_rsn);
+       bfa_trc(__vport_fcs(vport), lsrjt_expl);
+
+       /* For certain reason codes, we don't want to retry. */
+       switch (bfa_lps_get_lsrjt_expl(vport->lps)) {
+       case FC_LS_RJT_EXP_INV_PORT_NAME: /* by brocade */
+       case FC_LS_RJT_EXP_INVALID_NPORT_ID: /* by Cisco */
+               if (vport->fdisc_retries < BFA_FCS_VPORT_MAX_RETRIES)
+                       bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_RSP_ERROR);
+               else
+                       bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_RSP_DUP_WWN);
+               break;
+
+       case FC_LS_RJT_EXP_INSUFF_RES:
+               /*
+                * This means max logins per port/switch setting on the
+                * switch was exceeded.
+                */
+               if (vport->fdisc_retries < BFA_FCS_VPORT_MAX_RETRIES)
+                       bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_RSP_ERROR);
+               else
+                       bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_RSP_FAILED);
+               break;
+
+       default:
+               bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_RSP_ERROR);
+       }
+}
+
+/**
+ *     Called to send a logout to the fabric. Used when a V-Port is
+ *     deleted/stopped.
+ */
+static void
+bfa_fcs_vport_do_logo(struct bfa_fcs_vport_s *vport)
+{
+       bfa_trc(__vport_fcs(vport), __vport_pwwn(vport));
+
+       vport->vport_stats.logo_sent++;
+       bfa_lps_fdisclogo(vport->lps);
+}
+
+
+/**
+ *     This routine will be called by bfa_timer on timer timeouts.
+ *
+ *     param[in]       vport           - pointer to bfa_fcs_vport_t.
+ *     param[out]      vport_status    - pointer to return vport status in
+ *
+ *     return
+ *             void
+ *
+ *     Special Considerations:
+ *
+ *     note
+ */
+static void
+bfa_fcs_vport_timeout(void *vport_arg)
+{
+       struct bfa_fcs_vport_s *vport = (struct bfa_fcs_vport_s *) vport_arg;
+
+       vport->vport_stats.fdisc_timeouts++;
+       bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_TIMEOUT);
+}
+
+static void
+bfa_fcs_vport_free(struct bfa_fcs_vport_s *vport)
+{
+       struct bfad_vport_s *vport_drv =
+                       (struct bfad_vport_s *)vport->vport_drv;
+
+       bfa_fcs_fabric_delvport(__vport_fabric(vport), vport);
+
+       if (vport_drv->comp_del)
+               complete(vport_drv->comp_del);
+
+       bfa_lps_delete(vport->lps);
+}
+
+
+
+/**
+ *  fcs_vport_public FCS virtual port public interfaces
+ */
+
+/**
+ * Online notification from fabric SM.
+ */
+void
+bfa_fcs_vport_online(struct bfa_fcs_vport_s *vport)
+{
+       vport->vport_stats.fab_online++;
+       bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_ONLINE);
+}
+
+/**
+ * Offline notification from fabric SM.
+ */
+void
+bfa_fcs_vport_offline(struct bfa_fcs_vport_s *vport)
+{
+       vport->vport_stats.fab_offline++;
+       bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_OFFLINE);
+}
+
+/**
+ * Cleanup notification from fabric SM on link timer expiry.
+ */
+void
+bfa_fcs_vport_cleanup(struct bfa_fcs_vport_s *vport)
+{
+       vport->vport_stats.fab_cleanup++;
+}
+/**
+ * delete notification from fabric SM. To be invoked from within FCS.
+ */
+void
+bfa_fcs_vport_fcs_delete(struct bfa_fcs_vport_s *vport)
+{
+       bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_DELETE);
+}
+
+/**
+ * Delete completion callback from associated lport
+ */
+void
+bfa_fcs_vport_delete_comp(struct bfa_fcs_vport_s *vport)
+{
+       bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_DELCOMP);
+}
+
+
+
+/**
+ *  fcs_vport_api Virtual port API
+ */
+
+/**
+ *     Use this function to instantiate a new FCS vport object. This
+ *     function will not trigger any HW initialization process (which will be
+ *     done in vport_start() call)
+ *
+ *     param[in] vport -               pointer to bfa_fcs_vport_t. This space
+ *                                     needs to be allocated by the driver.
+ *     param[in] fcs           -       FCS instance
+ *     param[in] vport_cfg     -       vport configuration
+ *     param[in] vf_id         -       VF_ID if vport is created within a VF.
+ *                                     FC_VF_ID_NULL to specify base fabric.
+ *     param[in] vport_drv     -       Opaque handle back to the driver's vport
+ *                                     structure
+ *
+ *     retval BFA_STATUS_OK - on success.
+ *     retval BFA_STATUS_FAILED - on failure.
+ */
+bfa_status_t
+bfa_fcs_vport_create(struct bfa_fcs_vport_s *vport, struct bfa_fcs_s *fcs,
+               u16 vf_id, struct bfa_lport_cfg_s *vport_cfg,
+               struct bfad_vport_s *vport_drv)
+{
+       if (vport_cfg->pwwn == 0)
+               return BFA_STATUS_INVALID_WWN;
+
+       if (bfa_fcs_lport_get_pwwn(&fcs->fabric.bport) == vport_cfg->pwwn)
+               return BFA_STATUS_VPORT_WWN_BP;
+
+       if (bfa_fcs_vport_lookup(fcs, vf_id, vport_cfg->pwwn) != NULL)
+               return BFA_STATUS_VPORT_EXISTS;
+
+       if (bfa_fcs_fabric_vport_count(&fcs->fabric) ==
+                       bfa_lps_get_max_vport(fcs->bfa))
+               return BFA_STATUS_VPORT_MAX;
+
+       vport->lps = bfa_lps_alloc(fcs->bfa);
+       if (!vport->lps)
+               return BFA_STATUS_VPORT_MAX;
+
+       vport->vport_drv = vport_drv;
+       vport_cfg->preboot_vp = BFA_FALSE;
+
+       bfa_sm_set_state(vport, bfa_fcs_vport_sm_uninit);
+       bfa_fcs_lport_attach(&vport->lport, fcs, vf_id, vport);
+       bfa_fcs_lport_init(&vport->lport, vport_cfg);
+       bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_CREATE);
+
+       return BFA_STATUS_OK;
+}
+
+/**
+ *     Use this function to instantiate a new FCS PBC vport object. This
+ *     function will not trigger any HW initialization process (which will be
+ *     done in vport_start() call)
+ *
+ *     param[in] vport -       pointer to bfa_fcs_vport_t. This space
+ *                             needs to be allocated by the driver.
+ *     param[in] fcs   -       FCS instance
+ *     param[in] vport_cfg     -       vport configuration
+ *     param[in] vf_id         -       VF_ID if vport is created within a VF.
+ *                                     FC_VF_ID_NULL to specify base fabric.
+ *     param[in] vport_drv     -       Opaque handle back to the driver's vport
+ *                                     structure
+ *
+ *     retval BFA_STATUS_OK - on success.
+ *     retval BFA_STATUS_FAILED - on failure.
+ */
+bfa_status_t
+bfa_fcs_pbc_vport_create(struct bfa_fcs_vport_s *vport, struct bfa_fcs_s *fcs,
+                       u16 vf_id, struct bfa_lport_cfg_s *vport_cfg,
+                       struct bfad_vport_s *vport_drv)
+{
+       bfa_status_t rc;
+
+       rc = bfa_fcs_vport_create(vport, fcs, vf_id, vport_cfg, vport_drv);
+       vport->lport.port_cfg.preboot_vp = BFA_TRUE;
+
+       return rc;
+}
+
+/**
+ *     Use this function to findout if this is a pbc vport or not.
+ *
+ * @param[in] vport - pointer to bfa_fcs_vport_t.
+ *
+ * @returns None
+ */
+bfa_boolean_t
+bfa_fcs_is_pbc_vport(struct bfa_fcs_vport_s *vport)
+{
+
+       if (vport && (vport->lport.port_cfg.preboot_vp == BFA_TRUE))
+               return BFA_TRUE;
+       else
+               return BFA_FALSE;
+
+}
+
+/**
+ * Use this function initialize the vport.
+ *
+ * @param[in] vport - pointer to bfa_fcs_vport_t.
+ *
+ * @returns None
+ */
+bfa_status_t
+bfa_fcs_vport_start(struct bfa_fcs_vport_s *vport)
+{
+       bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_START);
+
+       return BFA_STATUS_OK;
+}
+
+/**
+ *     Use this function quiese the vport object. This function will return
+ *     immediately, when the vport is actually stopped, the
+ *     bfa_drv_vport_stop_cb() will be called.
+ *
+ *     param[in] vport - pointer to bfa_fcs_vport_t.
+ *
+ *     return None
+ */
+bfa_status_t
+bfa_fcs_vport_stop(struct bfa_fcs_vport_s *vport)
+{
+       bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_STOP);
+
+       return BFA_STATUS_OK;
+}
+
+/**
+ *     Use this function to delete a vport object. Fabric object should
+ *     be stopped before this function call.
+ *
+ *     !!!!!!! Donot invoke this from within FCS  !!!!!!!
+ *
+ *     param[in] vport - pointer to bfa_fcs_vport_t.
+ *
+ *     return     None
+ */
+bfa_status_t
+bfa_fcs_vport_delete(struct bfa_fcs_vport_s *vport)
+{
+
+       if (vport->lport.port_cfg.preboot_vp)
+               return BFA_STATUS_PBC;
+
+       bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_DELETE);
+
+       return BFA_STATUS_OK;
+}
+
+/**
+ *     Use this function to get vport's current status info.
+ *
+ *     param[in] vport         pointer to bfa_fcs_vport_t.
+ *     param[out] attr         pointer to return vport attributes
+ *
+ *     return None
+ */
+void
+bfa_fcs_vport_get_attr(struct bfa_fcs_vport_s *vport,
+                       struct bfa_vport_attr_s *attr)
+{
+       if (vport == NULL || attr == NULL)
+               return;
+
+       bfa_os_memset(attr, 0, sizeof(struct bfa_vport_attr_s));
+
+       bfa_fcs_lport_get_attr(&vport->lport, &attr->port_attr);
+       attr->vport_state = bfa_sm_to_state(vport_sm_table, vport->sm);
+}
+
+/**
+ *     Use this function to get vport's statistics.
+ *
+ *     param[in]       vport   pointer to bfa_fcs_vport_t.
+ *     param[out]      stats   pointer to return vport statistics in
+ *
+ *     return None
+ */
+void
+bfa_fcs_vport_get_stats(struct bfa_fcs_vport_s *vport,
+                       struct bfa_vport_stats_s *stats)
+{
+       *stats = vport->vport_stats;
+}
+
+/**
+ *     Use this function to clear vport's statistics.
+ *
+ *     param[in]       vport   pointer to bfa_fcs_vport_t.
+ *
+ *     return None
+ */
+void
+bfa_fcs_vport_clr_stats(struct bfa_fcs_vport_s *vport)
+{
+       bfa_os_memset(&vport->vport_stats, 0, sizeof(struct bfa_vport_stats_s));
+}
+
+/**
+ *     Lookup a virtual port. Excludes base port from lookup.
+ */
+struct bfa_fcs_vport_s *
+bfa_fcs_vport_lookup(struct bfa_fcs_s *fcs, u16 vf_id, wwn_t vpwwn)
+{
+       struct bfa_fcs_vport_s *vport;
+       struct bfa_fcs_fabric_s *fabric;
+
+       bfa_trc(fcs, vf_id);
+       bfa_trc(fcs, vpwwn);
+
+       fabric = bfa_fcs_vf_lookup(fcs, vf_id);
+       if (!fabric) {
+               bfa_trc(fcs, vf_id);
+               return NULL;
+       }
+
+       vport = bfa_fcs_fabric_vport_lookup(fabric, vpwwn);
+       return vport;
+}
+
+/**
+ * FDISC Response
+ */
+void
+bfa_cb_lps_fdisc_comp(void *bfad, void *uarg, bfa_status_t status)
+{
+       struct bfa_fcs_vport_s *vport = uarg;
+
+       bfa_trc(__vport_fcs(vport), __vport_pwwn(vport));
+       bfa_trc(__vport_fcs(vport), status);
+
+       switch (status) {
+       case BFA_STATUS_OK:
+               /*
+                * Initialiaze the V-Port fields
+                */
+               __vport_fcid(vport) = bfa_lps_get_pid(vport->lps);
+               vport->vport_stats.fdisc_accepts++;
+               bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_RSP_OK);
+               break;
+
+       case BFA_STATUS_INVALID_MAC:
+               /* Only for CNA */
+               vport->vport_stats.fdisc_acc_bad++;
+               bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_RSP_ERROR);
+
+               break;
+
+       case BFA_STATUS_EPROTOCOL:
+               switch (bfa_lps_get_extstatus(vport->lps)) {
+               case BFA_EPROTO_BAD_ACCEPT:
+                       vport->vport_stats.fdisc_acc_bad++;
+                       break;
+
+               case BFA_EPROTO_UNKNOWN_RSP:
+                       vport->vport_stats.fdisc_unknown_rsp++;
+                       break;
+
+               default:
+                       break;
+               }
+
+               bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_RSP_ERROR);
+               break;
+
+       case BFA_STATUS_FABRIC_RJT:
+               vport->vport_stats.fdisc_rejects++;
+               bfa_fcs_vport_fdisc_rejected(vport);
+               break;
+
+       default:
+               vport->vport_stats.fdisc_rsp_err++;
+               bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_RSP_ERROR);
+       }
+}
+
+/**
+ * LOGO response
+ */
+void
+bfa_cb_lps_fdisclogo_comp(void *bfad, void *uarg)
+{
+       struct bfa_fcs_vport_s *vport = uarg;
+       bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_RSP_OK);
+}
+
+/**
+ * Received clear virtual link
+ */
+void
+bfa_cb_lps_cvl_event(void *bfad, void *uarg)
+{
+       struct bfa_fcs_vport_s *vport = uarg;
+
+       /* Send an Offline followed by an ONLINE */
+       bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_OFFLINE);
+       bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_ONLINE);
+}
diff --git a/drivers/scsi/bfa/bfa_fcs_port.c b/drivers/scsi/bfa/bfa_fcs_port.c
deleted file mode 100644 (file)
index 3c27788..0000000
+++ /dev/null
@@ -1,61 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  bfa_fcs_pport.c BFA FCS PPORT ( physical port)
- */
-
-#include <fcs/bfa_fcs.h>
-#include <bfa_svc.h>
-#include <fcs/bfa_fcs_fabric.h>
-#include "fcs_trcmod.h"
-#include "fcs.h"
-#include "fcs_fabric.h"
-#include "fcs_port.h"
-
-BFA_TRC_FILE(FCS, PPORT);
-
-static void
-bfa_fcs_pport_event_handler(void *cbarg, bfa_pport_event_t event)
-{
-       struct bfa_fcs_s      *fcs = cbarg;
-
-       bfa_trc(fcs, event);
-
-       switch (event) {
-       case BFA_PPORT_LINKUP:
-               bfa_fcs_fabric_link_up(&fcs->fabric);
-               break;
-
-       case BFA_PPORT_LINKDOWN:
-               bfa_fcs_fabric_link_down(&fcs->fabric);
-               break;
-
-       case BFA_PPORT_TRUNK_LINKDOWN:
-               bfa_assert(0);
-               break;
-
-       default:
-               bfa_assert(0);
-       }
-}
-
-void
-bfa_fcs_pport_attach(struct bfa_fcs_s *fcs)
-{
-       bfa_fcport_event_register(fcs->bfa, bfa_fcs_pport_event_handler, fcs);
-}
diff --git a/drivers/scsi/bfa/bfa_fcs_rport.c b/drivers/scsi/bfa/bfa_fcs_rport.c
new file mode 100644 (file)
index 0000000..635f0cd
--- /dev/null
@@ -0,0 +1,3126 @@
+/*
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
+ * All rights reserved
+ * www.brocade.com
+ *
+ * Linux driver for Brocade Fibre Channel Host Bus Adapter.
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License (GPL) Version 2 as
+ * published by the Free Software Foundation
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * General Public License for more details.
+ */
+
+/**
+ *  rport.c Remote port implementation.
+ */
+
+#include "bfa_fcs.h"
+#include "bfa_fcbuild.h"
+#include "bfad_drv.h"
+
+BFA_TRC_FILE(FCS, RPORT);
+
+static u32
+bfa_fcs_rport_del_timeout = BFA_FCS_RPORT_DEF_DEL_TIMEOUT * 1000;
+        /* In millisecs */
+/*
+ * forward declarations
+ */
+static struct bfa_fcs_rport_s *bfa_fcs_rport_alloc(
+               struct bfa_fcs_lport_s *port, wwn_t pwwn, u32 rpid);
+static void    bfa_fcs_rport_free(struct bfa_fcs_rport_s *rport);
+static void    bfa_fcs_rport_hal_online(struct bfa_fcs_rport_s *rport);
+static void    bfa_fcs_rport_online_action(struct bfa_fcs_rport_s *rport);
+static void    bfa_fcs_rport_offline_action(struct bfa_fcs_rport_s *rport);
+static void    bfa_fcs_rport_update(struct bfa_fcs_rport_s *rport,
+                                       struct fc_logi_s *plogi);
+static void    bfa_fcs_rport_timeout(void *arg);
+static void    bfa_fcs_rport_send_plogi(void *rport_cbarg,
+                                        struct bfa_fcxp_s *fcxp_alloced);
+static void    bfa_fcs_rport_send_plogiacc(void *rport_cbarg,
+                                       struct bfa_fcxp_s *fcxp_alloced);
+static void    bfa_fcs_rport_plogi_response(void *fcsarg,
+                               struct bfa_fcxp_s *fcxp, void *cbarg,
+                               bfa_status_t req_status, u32 rsp_len,
+                               u32 resid_len, struct fchs_s *rsp_fchs);
+static void    bfa_fcs_rport_send_adisc(void *rport_cbarg,
+                                        struct bfa_fcxp_s *fcxp_alloced);
+static void    bfa_fcs_rport_adisc_response(void *fcsarg,
+                               struct bfa_fcxp_s *fcxp, void *cbarg,
+                               bfa_status_t req_status, u32 rsp_len,
+                               u32 resid_len, struct fchs_s *rsp_fchs);
+static void    bfa_fcs_rport_send_nsdisc(void *rport_cbarg,
+                                        struct bfa_fcxp_s *fcxp_alloced);
+static void    bfa_fcs_rport_gidpn_response(void *fcsarg,
+                               struct bfa_fcxp_s *fcxp, void *cbarg,
+                               bfa_status_t req_status, u32 rsp_len,
+                               u32 resid_len, struct fchs_s *rsp_fchs);
+static void    bfa_fcs_rport_gpnid_response(void *fcsarg,
+                               struct bfa_fcxp_s *fcxp, void *cbarg,
+                               bfa_status_t req_status, u32 rsp_len,
+                               u32 resid_len, struct fchs_s *rsp_fchs);
+static void    bfa_fcs_rport_send_logo(void *rport_cbarg,
+                                       struct bfa_fcxp_s *fcxp_alloced);
+static void    bfa_fcs_rport_send_logo_acc(void *rport_cbarg);
+static void    bfa_fcs_rport_process_prli(struct bfa_fcs_rport_s *rport,
+                                       struct fchs_s *rx_fchs, u16 len);
+static void    bfa_fcs_rport_send_ls_rjt(struct bfa_fcs_rport_s *rport,
+                               struct fchs_s *rx_fchs, u8 reason_code,
+                                         u8 reason_code_expl);
+static void    bfa_fcs_rport_process_adisc(struct bfa_fcs_rport_s *rport,
+                               struct fchs_s *rx_fchs, u16 len);
+static void bfa_fcs_rport_send_prlo_acc(struct bfa_fcs_rport_s *rport);
+/**
+ *  fcs_rport_sm FCS rport state machine events
+ */
+
+enum rport_event {
+       RPSM_EVENT_PLOGI_SEND   = 1,    /*  new rport; start with PLOGI */
+       RPSM_EVENT_PLOGI_RCVD   = 2,    /*  Inbound PLOGI from remote port */
+       RPSM_EVENT_PLOGI_COMP   = 3,    /*  PLOGI completed to rport    */
+       RPSM_EVENT_LOGO_RCVD    = 4,    /*  LOGO from remote device     */
+       RPSM_EVENT_LOGO_IMP     = 5,    /*  implicit logo for SLER      */
+       RPSM_EVENT_FCXP_SENT    = 6,    /*  Frame from has been sent    */
+       RPSM_EVENT_DELETE       = 7,    /*  RPORT delete request        */
+       RPSM_EVENT_SCN          = 8,    /*  state change notification   */
+       RPSM_EVENT_ACCEPTED     = 9,    /*  Good response from remote device */
+       RPSM_EVENT_FAILED       = 10,   /*  Request to rport failed.    */
+       RPSM_EVENT_TIMEOUT      = 11,   /*  Rport SM timeout event      */
+       RPSM_EVENT_HCB_ONLINE  = 12,    /*  BFA rport online callback   */
+       RPSM_EVENT_HCB_OFFLINE = 13,    /*  BFA rport offline callback  */
+       RPSM_EVENT_FC4_OFFLINE = 14,    /*  FC-4 offline complete       */
+       RPSM_EVENT_ADDRESS_CHANGE = 15, /*  Rport's PID has changed     */
+       RPSM_EVENT_ADDRESS_DISC = 16,   /*  Need to Discover rport's PID */
+       RPSM_EVENT_PRLO_RCVD   = 17,    /*  PRLO from remote device     */
+       RPSM_EVENT_PLOGI_RETRY = 18,    /*  Retry PLOGI continously */
+};
+
+static void    bfa_fcs_rport_sm_uninit(struct bfa_fcs_rport_s *rport,
+                                       enum rport_event event);
+static void    bfa_fcs_rport_sm_plogi_sending(struct bfa_fcs_rport_s *rport,
+                                               enum rport_event event);
+static void    bfa_fcs_rport_sm_plogiacc_sending(struct bfa_fcs_rport_s *rport,
+                                                 enum rport_event event);
+static void    bfa_fcs_rport_sm_plogi_retry(struct bfa_fcs_rport_s *rport,
+                                               enum rport_event event);
+static void    bfa_fcs_rport_sm_plogi(struct bfa_fcs_rport_s *rport,
+                                       enum rport_event event);
+static void    bfa_fcs_rport_sm_hal_online(struct bfa_fcs_rport_s *rport,
+                                               enum rport_event event);
+static void    bfa_fcs_rport_sm_online(struct bfa_fcs_rport_s *rport,
+                                       enum rport_event event);
+static void    bfa_fcs_rport_sm_nsquery_sending(struct bfa_fcs_rport_s *rport,
+                                                enum rport_event event);
+static void    bfa_fcs_rport_sm_nsquery(struct bfa_fcs_rport_s *rport,
+                                        enum rport_event event);
+static void    bfa_fcs_rport_sm_adisc_sending(struct bfa_fcs_rport_s *rport,
+                                               enum rport_event event);
+static void    bfa_fcs_rport_sm_adisc(struct bfa_fcs_rport_s *rport,
+                                       enum rport_event event);
+static void    bfa_fcs_rport_sm_fc4_logorcv(struct bfa_fcs_rport_s *rport,
+                                               enum rport_event event);
+static void    bfa_fcs_rport_sm_fc4_logosend(struct bfa_fcs_rport_s *rport,
+                                               enum rport_event event);
+static void    bfa_fcs_rport_sm_fc4_offline(struct bfa_fcs_rport_s *rport,
+                                               enum rport_event event);
+static void    bfa_fcs_rport_sm_hcb_offline(struct bfa_fcs_rport_s *rport,
+                                               enum rport_event event);
+static void    bfa_fcs_rport_sm_hcb_logorcv(struct bfa_fcs_rport_s *rport,
+                                               enum rport_event event);
+static void    bfa_fcs_rport_sm_hcb_logosend(struct bfa_fcs_rport_s *rport,
+                                               enum rport_event event);
+static void    bfa_fcs_rport_sm_logo_sending(struct bfa_fcs_rport_s *rport,
+                                               enum rport_event event);
+static void    bfa_fcs_rport_sm_offline(struct bfa_fcs_rport_s *rport,
+                                        enum rport_event event);
+static void    bfa_fcs_rport_sm_nsdisc_sending(struct bfa_fcs_rport_s *rport,
+                                               enum rport_event event);
+static void    bfa_fcs_rport_sm_nsdisc_retry(struct bfa_fcs_rport_s *rport,
+                                               enum rport_event event);
+static void    bfa_fcs_rport_sm_nsdisc_sent(struct bfa_fcs_rport_s *rport,
+                                               enum rport_event event);
+static void    bfa_fcs_rport_sm_nsdisc_sent(struct bfa_fcs_rport_s *rport,
+                                               enum rport_event event);
+
+static struct bfa_sm_table_s rport_sm_table[] = {
+       {BFA_SM(bfa_fcs_rport_sm_uninit), BFA_RPORT_UNINIT},
+       {BFA_SM(bfa_fcs_rport_sm_plogi_sending), BFA_RPORT_PLOGI},
+       {BFA_SM(bfa_fcs_rport_sm_plogiacc_sending), BFA_RPORT_ONLINE},
+       {BFA_SM(bfa_fcs_rport_sm_plogi_retry), BFA_RPORT_PLOGI_RETRY},
+       {BFA_SM(bfa_fcs_rport_sm_plogi), BFA_RPORT_PLOGI},
+       {BFA_SM(bfa_fcs_rport_sm_hal_online), BFA_RPORT_ONLINE},
+       {BFA_SM(bfa_fcs_rport_sm_online), BFA_RPORT_ONLINE},
+       {BFA_SM(bfa_fcs_rport_sm_nsquery_sending), BFA_RPORT_NSQUERY},
+       {BFA_SM(bfa_fcs_rport_sm_nsquery), BFA_RPORT_NSQUERY},
+       {BFA_SM(bfa_fcs_rport_sm_adisc_sending), BFA_RPORT_ADISC},
+       {BFA_SM(bfa_fcs_rport_sm_adisc), BFA_RPORT_ADISC},
+       {BFA_SM(bfa_fcs_rport_sm_fc4_logorcv), BFA_RPORT_LOGORCV},
+       {BFA_SM(bfa_fcs_rport_sm_fc4_logosend), BFA_RPORT_LOGO},
+       {BFA_SM(bfa_fcs_rport_sm_fc4_offline), BFA_RPORT_OFFLINE},
+       {BFA_SM(bfa_fcs_rport_sm_hcb_offline), BFA_RPORT_OFFLINE},
+       {BFA_SM(bfa_fcs_rport_sm_hcb_logorcv), BFA_RPORT_LOGORCV},
+       {BFA_SM(bfa_fcs_rport_sm_hcb_logosend), BFA_RPORT_LOGO},
+       {BFA_SM(bfa_fcs_rport_sm_logo_sending), BFA_RPORT_LOGO},
+       {BFA_SM(bfa_fcs_rport_sm_offline), BFA_RPORT_OFFLINE},
+       {BFA_SM(bfa_fcs_rport_sm_nsdisc_sending), BFA_RPORT_NSDISC},
+       {BFA_SM(bfa_fcs_rport_sm_nsdisc_retry), BFA_RPORT_NSDISC},
+       {BFA_SM(bfa_fcs_rport_sm_nsdisc_sent), BFA_RPORT_NSDISC},
+};
+
+/**
+ *             Beginning state.
+ */
+static void
+bfa_fcs_rport_sm_uninit(struct bfa_fcs_rport_s *rport, enum rport_event event)
+{
+       bfa_trc(rport->fcs, rport->pwwn);
+       bfa_trc(rport->fcs, rport->pid);
+       bfa_trc(rport->fcs, event);
+
+       switch (event) {
+       case RPSM_EVENT_PLOGI_SEND:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_plogi_sending);
+               rport->plogi_retries = 0;
+               bfa_fcs_rport_send_plogi(rport, NULL);
+               break;
+
+       case RPSM_EVENT_PLOGI_RCVD:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_plogiacc_sending);
+               bfa_fcs_rport_send_plogiacc(rport, NULL);
+               break;
+
+       case RPSM_EVENT_PLOGI_COMP:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_hal_online);
+               bfa_fcs_rport_hal_online(rport);
+               break;
+
+       case RPSM_EVENT_ADDRESS_CHANGE:
+       case RPSM_EVENT_ADDRESS_DISC:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_nsdisc_sending);
+               rport->ns_retries = 0;
+               bfa_fcs_rport_send_nsdisc(rport, NULL);
+               break;
+       default:
+               bfa_sm_fault(rport->fcs, event);
+       }
+}
+
+/**
+ *             PLOGI is being sent.
+ */
+static void
+bfa_fcs_rport_sm_plogi_sending(struct bfa_fcs_rport_s *rport,
+        enum rport_event event)
+{
+       bfa_trc(rport->fcs, rport->pwwn);
+       bfa_trc(rport->fcs, rport->pid);
+       bfa_trc(rport->fcs, event);
+
+       switch (event) {
+       case RPSM_EVENT_FCXP_SENT:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_plogi);
+               break;
+
+       case RPSM_EVENT_DELETE:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_uninit);
+               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
+               bfa_fcs_rport_free(rport);
+               break;
+
+       case RPSM_EVENT_PLOGI_RCVD:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_plogiacc_sending);
+               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
+               bfa_fcs_rport_send_plogiacc(rport, NULL);
+               break;
+
+       case RPSM_EVENT_ADDRESS_CHANGE:
+       case RPSM_EVENT_SCN:
+               /* query the NS */
+               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_nsdisc_sending);
+               rport->ns_retries = 0;
+               bfa_fcs_rport_send_nsdisc(rport, NULL);
+               break;
+
+       case RPSM_EVENT_LOGO_IMP:
+               rport->pid = 0;
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_offline);
+               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
+               bfa_timer_start(rport->fcs->bfa, &rport->timer,
+                               bfa_fcs_rport_timeout, rport,
+                               bfa_fcs_rport_del_timeout);
+               break;
+
+
+       default:
+               bfa_sm_fault(rport->fcs, event);
+       }
+}
+
+/**
+ *             PLOGI is being sent.
+ */
+static void
+bfa_fcs_rport_sm_plogiacc_sending(struct bfa_fcs_rport_s *rport,
+        enum rport_event event)
+{
+       bfa_trc(rport->fcs, rport->pwwn);
+       bfa_trc(rport->fcs, rport->pid);
+       bfa_trc(rport->fcs, event);
+
+       switch (event) {
+       case RPSM_EVENT_FCXP_SENT:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_hal_online);
+               bfa_fcs_rport_hal_online(rport);
+               break;
+
+       case RPSM_EVENT_DELETE:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_uninit);
+               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
+               bfa_fcs_rport_free(rport);
+               break;
+
+       case RPSM_EVENT_PLOGI_RCVD:
+       case RPSM_EVENT_SCN:
+               /**
+                * Ignore, SCN is possibly online notification.
+                */
+               break;
+
+       case RPSM_EVENT_ADDRESS_CHANGE:
+               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_nsdisc_sending);
+               rport->ns_retries = 0;
+               bfa_fcs_rport_send_nsdisc(rport, NULL);
+               break;
+
+       case RPSM_EVENT_LOGO_IMP:
+               rport->pid = 0;
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_offline);
+               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
+               bfa_timer_start(rport->fcs->bfa, &rport->timer,
+                               bfa_fcs_rport_timeout, rport,
+                               bfa_fcs_rport_del_timeout);
+               break;
+
+       case RPSM_EVENT_HCB_OFFLINE:
+               /**
+                * Ignore BFA callback, on a PLOGI receive we call bfa offline.
+                */
+               break;
+
+       default:
+               bfa_sm_fault(rport->fcs, event);
+       }
+}
+
+/**
+ *             PLOGI is sent.
+ */
+static void
+bfa_fcs_rport_sm_plogi_retry(struct bfa_fcs_rport_s *rport,
+                       enum rport_event event)
+{
+       bfa_trc(rport->fcs, rport->pwwn);
+       bfa_trc(rport->fcs, rport->pid);
+       bfa_trc(rport->fcs, event);
+
+       switch (event) {
+       case RPSM_EVENT_TIMEOUT:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_plogi_sending);
+               bfa_fcs_rport_send_plogi(rport, NULL);
+               break;
+
+       case RPSM_EVENT_DELETE:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_uninit);
+               bfa_timer_stop(&rport->timer);
+               bfa_fcs_rport_free(rport);
+               break;
+
+       case RPSM_EVENT_PRLO_RCVD:
+       case RPSM_EVENT_LOGO_RCVD:
+               break;
+
+       case RPSM_EVENT_PLOGI_RCVD:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_plogiacc_sending);
+               bfa_timer_stop(&rport->timer);
+               bfa_fcs_rport_send_plogiacc(rport, NULL);
+               break;
+
+       case RPSM_EVENT_ADDRESS_CHANGE:
+       case RPSM_EVENT_SCN:
+               bfa_timer_stop(&rport->timer);
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_nsdisc_sending);
+               rport->ns_retries = 0;
+               bfa_fcs_rport_send_nsdisc(rport, NULL);
+               break;
+
+       case RPSM_EVENT_LOGO_IMP:
+               rport->pid = 0;
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_offline);
+               bfa_timer_stop(&rport->timer);
+               bfa_timer_start(rport->fcs->bfa, &rport->timer,
+                               bfa_fcs_rport_timeout, rport,
+                               bfa_fcs_rport_del_timeout);
+               break;
+
+       case RPSM_EVENT_PLOGI_COMP:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_hal_online);
+               bfa_timer_stop(&rport->timer);
+               bfa_fcs_rport_hal_online(rport);
+               break;
+
+       default:
+               bfa_sm_fault(rport->fcs, event);
+       }
+}
+
+/**
+ *             PLOGI is sent.
+ */
+static void
+bfa_fcs_rport_sm_plogi(struct bfa_fcs_rport_s *rport, enum rport_event event)
+{
+       bfa_trc(rport->fcs, rport->pwwn);
+       bfa_trc(rport->fcs, rport->pid);
+       bfa_trc(rport->fcs, event);
+
+       switch (event) {
+       case RPSM_EVENT_ACCEPTED:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_hal_online);
+               rport->plogi_retries = 0;
+               bfa_fcs_rport_hal_online(rport);
+               break;
+
+       case RPSM_EVENT_LOGO_RCVD:
+               bfa_fcs_rport_send_logo_acc(rport);
+               /*
+                * !! fall through !!
+                */
+       case RPSM_EVENT_PRLO_RCVD:
+               if (rport->prlo == BFA_TRUE)
+                       bfa_fcs_rport_send_prlo_acc(rport);
+
+               bfa_fcxp_discard(rport->fcxp);
+               /*
+                * !! fall through !!
+                */
+       case RPSM_EVENT_FAILED:
+               if (rport->plogi_retries < BFA_FCS_RPORT_MAX_RETRIES) {
+                       rport->plogi_retries++;
+                       bfa_sm_set_state(rport, bfa_fcs_rport_sm_plogi_retry);
+                       bfa_timer_start(rport->fcs->bfa, &rport->timer,
+                                       bfa_fcs_rport_timeout, rport,
+                                       BFA_FCS_RETRY_TIMEOUT);
+               } else {
+                       bfa_stats(rport->port, rport_del_max_plogi_retry);
+                       rport->pid = 0;
+                       bfa_sm_set_state(rport, bfa_fcs_rport_sm_offline);
+                       bfa_timer_start(rport->fcs->bfa, &rport->timer,
+                                       bfa_fcs_rport_timeout, rport,
+                                       bfa_fcs_rport_del_timeout);
+               }
+               break;
+
+       case    RPSM_EVENT_PLOGI_RETRY:
+               rport->plogi_retries = 0;
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_plogi_retry);
+               bfa_timer_start(rport->fcs->bfa, &rport->timer,
+                               bfa_fcs_rport_timeout, rport,
+                               (FC_RA_TOV * 1000));
+               break;
+
+       case RPSM_EVENT_LOGO_IMP:
+               rport->pid = 0;
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_offline);
+               bfa_fcxp_discard(rport->fcxp);
+               bfa_timer_start(rport->fcs->bfa, &rport->timer,
+                               bfa_fcs_rport_timeout, rport,
+                               bfa_fcs_rport_del_timeout);
+               break;
+
+       case RPSM_EVENT_ADDRESS_CHANGE:
+       case RPSM_EVENT_SCN:
+               bfa_fcxp_discard(rport->fcxp);
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_nsdisc_sending);
+               rport->ns_retries = 0;
+               bfa_fcs_rport_send_nsdisc(rport, NULL);
+               break;
+
+       case RPSM_EVENT_PLOGI_RCVD:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_plogiacc_sending);
+               bfa_fcxp_discard(rport->fcxp);
+               bfa_fcs_rport_send_plogiacc(rport, NULL);
+               break;
+
+       case RPSM_EVENT_DELETE:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_uninit);
+               bfa_fcxp_discard(rport->fcxp);
+               bfa_fcs_rport_free(rport);
+               break;
+
+       case RPSM_EVENT_PLOGI_COMP:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_hal_online);
+               bfa_fcxp_discard(rport->fcxp);
+               bfa_fcs_rport_hal_online(rport);
+               break;
+
+       default:
+               bfa_sm_fault(rport->fcs, event);
+       }
+}
+
+/**
+ *             PLOGI is complete. Awaiting BFA rport online callback. FC-4s
+ *             are offline.
+ */
+static void
+bfa_fcs_rport_sm_hal_online(struct bfa_fcs_rport_s *rport,
+                       enum rport_event event)
+{
+       bfa_trc(rport->fcs, rport->pwwn);
+       bfa_trc(rport->fcs, rport->pid);
+       bfa_trc(rport->fcs, event);
+
+       switch (event) {
+       case RPSM_EVENT_HCB_ONLINE:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_online);
+               bfa_fcs_rport_online_action(rport);
+               break;
+
+       case RPSM_EVENT_PRLO_RCVD:
+               break;
+
+       case RPSM_EVENT_LOGO_RCVD:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_hcb_logorcv);
+               bfa_rport_offline(rport->bfa_rport);
+               break;
+
+       case RPSM_EVENT_LOGO_IMP:
+       case RPSM_EVENT_ADDRESS_CHANGE:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_hcb_offline);
+               bfa_rport_offline(rport->bfa_rport);
+               break;
+
+       case RPSM_EVENT_PLOGI_RCVD:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_plogiacc_sending);
+               bfa_rport_offline(rport->bfa_rport);
+               bfa_fcs_rport_send_plogiacc(rport, NULL);
+               break;
+
+       case RPSM_EVENT_DELETE:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_hcb_logosend);
+               bfa_rport_offline(rport->bfa_rport);
+               break;
+
+       case RPSM_EVENT_SCN:
+               /**
+                * @todo
+                * Ignore SCN - PLOGI just completed, FC-4 login should detect
+                * device failures.
+                */
+               break;
+
+       default:
+               bfa_sm_fault(rport->fcs, event);
+       }
+}
+
+/**
+ *             Rport is ONLINE. FC-4s active.
+ */
+static void
+bfa_fcs_rport_sm_online(struct bfa_fcs_rport_s *rport, enum rport_event event)
+{
+       bfa_trc(rport->fcs, rport->pwwn);
+       bfa_trc(rport->fcs, rport->pid);
+       bfa_trc(rport->fcs, event);
+
+       switch (event) {
+       case RPSM_EVENT_SCN:
+               if (bfa_fcs_fabric_is_switched(rport->port->fabric)) {
+                       bfa_sm_set_state(rport,
+                                        bfa_fcs_rport_sm_nsquery_sending);
+                       rport->ns_retries = 0;
+                       bfa_fcs_rport_send_nsdisc(rport, NULL);
+               } else {
+                       bfa_sm_set_state(rport, bfa_fcs_rport_sm_adisc_sending);
+                       bfa_fcs_rport_send_adisc(rport, NULL);
+               }
+               break;
+
+       case RPSM_EVENT_PLOGI_RCVD:
+       case RPSM_EVENT_LOGO_IMP:
+       case RPSM_EVENT_ADDRESS_CHANGE:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_offline);
+               bfa_fcs_rport_offline_action(rport);
+               break;
+
+       case RPSM_EVENT_DELETE:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_logosend);
+               bfa_fcs_rport_offline_action(rport);
+               break;
+
+       case RPSM_EVENT_LOGO_RCVD:
+       case RPSM_EVENT_PRLO_RCVD:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_logorcv);
+               bfa_fcs_rport_offline_action(rport);
+               break;
+
+       case RPSM_EVENT_PLOGI_COMP:
+               break;
+
+       default:
+               bfa_sm_fault(rport->fcs, event);
+       }
+}
+
+/**
+ *             An SCN event is received in ONLINE state. NS query is being sent
+ *             prior to ADISC authentication with rport. FC-4s are paused.
+ */
+static void
+bfa_fcs_rport_sm_nsquery_sending(struct bfa_fcs_rport_s *rport,
+        enum rport_event event)
+{
+       bfa_trc(rport->fcs, rport->pwwn);
+       bfa_trc(rport->fcs, rport->pid);
+       bfa_trc(rport->fcs, event);
+
+       switch (event) {
+       case RPSM_EVENT_FCXP_SENT:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_nsquery);
+               break;
+
+       case RPSM_EVENT_DELETE:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_logosend);
+               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
+               bfa_fcs_rport_offline_action(rport);
+               break;
+
+       case RPSM_EVENT_SCN:
+               /**
+                * ignore SCN, wait for response to query itself
+                */
+               break;
+
+       case RPSM_EVENT_LOGO_RCVD:
+       case RPSM_EVENT_PRLO_RCVD:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_logorcv);
+               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
+               bfa_fcs_rport_offline_action(rport);
+               break;
+
+       case RPSM_EVENT_LOGO_IMP:
+               rport->pid = 0;
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_offline);
+               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
+               bfa_timer_start(rport->fcs->bfa, &rport->timer,
+                               bfa_fcs_rport_timeout, rport,
+                               bfa_fcs_rport_del_timeout);
+               break;
+
+       case RPSM_EVENT_PLOGI_RCVD:
+       case RPSM_EVENT_ADDRESS_CHANGE:
+       case RPSM_EVENT_PLOGI_COMP:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_offline);
+               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
+               bfa_fcs_rport_offline_action(rport);
+               break;
+
+       default:
+               bfa_sm_fault(rport->fcs, event);
+       }
+}
+
+/**
+ *     An SCN event is received in ONLINE state. NS query is sent to rport.
+ *     FC-4s are paused.
+ */
+static void
+bfa_fcs_rport_sm_nsquery(struct bfa_fcs_rport_s *rport, enum rport_event event)
+{
+       bfa_trc(rport->fcs, rport->pwwn);
+       bfa_trc(rport->fcs, rport->pid);
+       bfa_trc(rport->fcs, event);
+
+       switch (event) {
+       case RPSM_EVENT_ACCEPTED:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_adisc_sending);
+               bfa_fcs_rport_send_adisc(rport, NULL);
+               break;
+
+       case RPSM_EVENT_FAILED:
+               rport->ns_retries++;
+               if (rport->ns_retries < BFA_FCS_RPORT_MAX_RETRIES) {
+                       bfa_sm_set_state(rport,
+                                        bfa_fcs_rport_sm_nsquery_sending);
+                       bfa_fcs_rport_send_nsdisc(rport, NULL);
+               } else {
+                       bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_offline);
+                       bfa_fcs_rport_offline_action(rport);
+               }
+               break;
+
+       case RPSM_EVENT_DELETE:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_logosend);
+               bfa_fcxp_discard(rport->fcxp);
+               bfa_fcs_rport_offline_action(rport);
+               break;
+
+       case RPSM_EVENT_SCN:
+               break;
+
+       case RPSM_EVENT_LOGO_RCVD:
+       case RPSM_EVENT_PRLO_RCVD:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_logorcv);
+               bfa_fcxp_discard(rport->fcxp);
+               bfa_fcs_rport_offline_action(rport);
+               break;
+
+       case RPSM_EVENT_PLOGI_COMP:
+       case RPSM_EVENT_ADDRESS_CHANGE:
+       case RPSM_EVENT_PLOGI_RCVD:
+       case RPSM_EVENT_LOGO_IMP:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_offline);
+               bfa_fcxp_discard(rport->fcxp);
+               bfa_fcs_rport_offline_action(rport);
+               break;
+
+       default:
+               bfa_sm_fault(rport->fcs, event);
+       }
+}
+
+/**
+ *     An SCN event is received in ONLINE state. ADISC is being sent for
+ *     authenticating with rport. FC-4s are paused.
+ */
+static void
+bfa_fcs_rport_sm_adisc_sending(struct bfa_fcs_rport_s *rport,
+        enum rport_event event)
+{
+       bfa_trc(rport->fcs, rport->pwwn);
+       bfa_trc(rport->fcs, rport->pid);
+       bfa_trc(rport->fcs, event);
+
+       switch (event) {
+       case RPSM_EVENT_FCXP_SENT:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_adisc);
+               break;
+
+       case RPSM_EVENT_DELETE:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_logosend);
+               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
+               bfa_fcs_rport_offline_action(rport);
+               break;
+
+       case RPSM_EVENT_LOGO_IMP:
+       case RPSM_EVENT_ADDRESS_CHANGE:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_offline);
+               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
+               bfa_fcs_rport_offline_action(rport);
+               break;
+
+       case RPSM_EVENT_LOGO_RCVD:
+       case RPSM_EVENT_PRLO_RCVD:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_logorcv);
+               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
+               bfa_fcs_rport_offline_action(rport);
+               break;
+
+       case RPSM_EVENT_SCN:
+               break;
+
+       case RPSM_EVENT_PLOGI_RCVD:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_offline);
+               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
+               bfa_fcs_rport_offline_action(rport);
+               break;
+
+       default:
+               bfa_sm_fault(rport->fcs, event);
+       }
+}
+
+/**
+ *             An SCN event is received in ONLINE state. ADISC is to rport.
+ *             FC-4s are paused.
+ */
+static void
+bfa_fcs_rport_sm_adisc(struct bfa_fcs_rport_s *rport, enum rport_event event)
+{
+       bfa_trc(rport->fcs, rport->pwwn);
+       bfa_trc(rport->fcs, rport->pid);
+       bfa_trc(rport->fcs, event);
+
+       switch (event) {
+       case RPSM_EVENT_ACCEPTED:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_online);
+               break;
+
+       case RPSM_EVENT_PLOGI_RCVD:
+               /**
+                * Too complex to cleanup FC-4 & rport and then acc to PLOGI.
+                * At least go offline when a PLOGI is received.
+                */
+               bfa_fcxp_discard(rport->fcxp);
+               /*
+                * !!! fall through !!!
+                */
+
+       case RPSM_EVENT_FAILED:
+       case RPSM_EVENT_ADDRESS_CHANGE:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_offline);
+               bfa_fcs_rport_offline_action(rport);
+               break;
+
+       case RPSM_EVENT_DELETE:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_logosend);
+               bfa_fcxp_discard(rport->fcxp);
+               bfa_fcs_rport_offline_action(rport);
+               break;
+
+       case RPSM_EVENT_SCN:
+               /**
+                * already processing RSCN
+                */
+               break;
+
+       case RPSM_EVENT_LOGO_IMP:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_offline);
+               bfa_fcxp_discard(rport->fcxp);
+               bfa_fcs_rport_offline_action(rport);
+               break;
+
+       case RPSM_EVENT_LOGO_RCVD:
+       case RPSM_EVENT_PRLO_RCVD:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_logorcv);
+               bfa_fcxp_discard(rport->fcxp);
+               bfa_fcs_rport_offline_action(rport);
+               break;
+
+       default:
+               bfa_sm_fault(rport->fcs, event);
+       }
+}
+
+/**
+ *             Rport has sent LOGO. Awaiting FC-4 offline completion callback.
+ */
+static void
+bfa_fcs_rport_sm_fc4_logorcv(struct bfa_fcs_rport_s *rport,
+                       enum rport_event event)
+{
+       bfa_trc(rport->fcs, rport->pwwn);
+       bfa_trc(rport->fcs, rport->pid);
+       bfa_trc(rport->fcs, event);
+
+       switch (event) {
+       case RPSM_EVENT_FC4_OFFLINE:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_hcb_logorcv);
+               bfa_rport_offline(rport->bfa_rport);
+               break;
+
+       case RPSM_EVENT_DELETE:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_logosend);
+               break;
+
+       case RPSM_EVENT_LOGO_RCVD:
+       case RPSM_EVENT_PRLO_RCVD:
+       case RPSM_EVENT_ADDRESS_CHANGE:
+               break;
+
+       default:
+               bfa_sm_fault(rport->fcs, event);
+       }
+}
+
+/**
+ *             LOGO needs to be sent to rport. Awaiting FC-4 offline completion
+ *             callback.
+ */
+static void
+bfa_fcs_rport_sm_fc4_logosend(struct bfa_fcs_rport_s *rport,
+        enum rport_event event)
+{
+       bfa_trc(rport->fcs, rport->pwwn);
+       bfa_trc(rport->fcs, rport->pid);
+       bfa_trc(rport->fcs, event);
+
+       switch (event) {
+       case RPSM_EVENT_FC4_OFFLINE:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_hcb_logosend);
+               bfa_rport_offline(rport->bfa_rport);
+               break;
+
+       default:
+               bfa_sm_fault(rport->fcs, event);
+       }
+}
+
+/**
+ *     Rport is going offline. Awaiting FC-4 offline completion callback.
+ */
+static void
+bfa_fcs_rport_sm_fc4_offline(struct bfa_fcs_rport_s *rport,
+                       enum rport_event event)
+{
+       bfa_trc(rport->fcs, rport->pwwn);
+       bfa_trc(rport->fcs, rport->pid);
+       bfa_trc(rport->fcs, event);
+
+       switch (event) {
+       case RPSM_EVENT_FC4_OFFLINE:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_hcb_offline);
+               bfa_rport_offline(rport->bfa_rport);
+               break;
+
+       case RPSM_EVENT_SCN:
+       case RPSM_EVENT_LOGO_IMP:
+       case RPSM_EVENT_LOGO_RCVD:
+       case RPSM_EVENT_PRLO_RCVD:
+       case RPSM_EVENT_ADDRESS_CHANGE:
+               /**
+                * rport is already going offline.
+                * SCN - ignore and wait till transitioning to offline state
+                */
+               break;
+
+       case RPSM_EVENT_DELETE:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_logosend);
+               break;
+
+       default:
+               bfa_sm_fault(rport->fcs, event);
+       }
+}
+
+/**
+ *             Rport is offline. FC-4s are offline. Awaiting BFA rport offline
+ *             callback.
+ */
+static void
+bfa_fcs_rport_sm_hcb_offline(struct bfa_fcs_rport_s *rport,
+                               enum rport_event event)
+{
+       bfa_trc(rport->fcs, rport->pwwn);
+       bfa_trc(rport->fcs, rport->pid);
+       bfa_trc(rport->fcs, event);
+
+       switch (event) {
+       case RPSM_EVENT_HCB_OFFLINE:
+       case RPSM_EVENT_ADDRESS_CHANGE:
+               if (bfa_fcs_lport_is_online(rport->port)) {
+                       if (bfa_fcs_fabric_is_switched(rport->port->fabric)) {
+                               bfa_sm_set_state(rport,
+                                       bfa_fcs_rport_sm_nsdisc_sending);
+                               rport->ns_retries = 0;
+                               bfa_fcs_rport_send_nsdisc(rport, NULL);
+                       } else {
+                               bfa_sm_set_state(rport,
+                                       bfa_fcs_rport_sm_plogi_sending);
+                               rport->plogi_retries = 0;
+                               bfa_fcs_rport_send_plogi(rport, NULL);
+                       }
+               } else {
+                       rport->pid = 0;
+                       bfa_sm_set_state(rport, bfa_fcs_rport_sm_offline);
+                       bfa_timer_start(rport->fcs->bfa, &rport->timer,
+                                       bfa_fcs_rport_timeout, rport,
+                                       bfa_fcs_rport_del_timeout);
+               }
+               break;
+
+       case RPSM_EVENT_DELETE:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_uninit);
+               bfa_fcs_rport_free(rport);
+               break;
+
+       case RPSM_EVENT_SCN:
+       case RPSM_EVENT_LOGO_RCVD:
+       case RPSM_EVENT_PRLO_RCVD:
+               /**
+                * Ignore, already offline.
+                */
+               break;
+
+       default:
+               bfa_sm_fault(rport->fcs, event);
+       }
+}
+
+/**
+ *             Rport is offline. FC-4s are offline. Awaiting BFA rport offline
+ *             callback to send LOGO accept.
+ */
+static void
+bfa_fcs_rport_sm_hcb_logorcv(struct bfa_fcs_rport_s *rport,
+                       enum rport_event event)
+{
+       bfa_trc(rport->fcs, rport->pwwn);
+       bfa_trc(rport->fcs, rport->pid);
+       bfa_trc(rport->fcs, event);
+
+       switch (event) {
+       case RPSM_EVENT_HCB_OFFLINE:
+       case RPSM_EVENT_ADDRESS_CHANGE:
+               if (rport->pid && (rport->prlo == BFA_TRUE))
+                       bfa_fcs_rport_send_prlo_acc(rport);
+               if (rport->pid && (rport->prlo == BFA_FALSE))
+                       bfa_fcs_rport_send_logo_acc(rport);
+               /*
+                * If the lport is online and if the rport is not a well
+                * known address port,
+                * we try to re-discover the r-port.
+                */
+               if (bfa_fcs_lport_is_online(rport->port) &&
+                       (!BFA_FCS_PID_IS_WKA(rport->pid))) {
+                       bfa_sm_set_state(rport,
+                               bfa_fcs_rport_sm_nsdisc_sending);
+                       rport->ns_retries = 0;
+                       bfa_fcs_rport_send_nsdisc(rport, NULL);
+               } else {
+                       /*
+                        * if it is not a well known address, reset the
+                        * pid to 0.
+                        */
+                       if (!BFA_FCS_PID_IS_WKA(rport->pid))
+                               rport->pid = 0;
+                       bfa_sm_set_state(rport, bfa_fcs_rport_sm_offline);
+                       bfa_timer_start(rport->fcs->bfa, &rport->timer,
+                                       bfa_fcs_rport_timeout, rport,
+                                       bfa_fcs_rport_del_timeout);
+               }
+               break;
+
+       case RPSM_EVENT_DELETE:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_hcb_logosend);
+               break;
+
+       case RPSM_EVENT_LOGO_IMP:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_hcb_offline);
+               break;
+
+       case RPSM_EVENT_LOGO_RCVD:
+       case RPSM_EVENT_PRLO_RCVD:
+               /**
+                * Ignore - already processing a LOGO.
+                */
+               break;
+
+       default:
+               bfa_sm_fault(rport->fcs, event);
+       }
+}
+
+/**
+ *             Rport is being deleted. FC-4s are offline.
+ *  Awaiting BFA rport offline
+ *             callback to send LOGO.
+ */
+static void
+bfa_fcs_rport_sm_hcb_logosend(struct bfa_fcs_rport_s *rport,
+                enum rport_event event)
+{
+       bfa_trc(rport->fcs, rport->pwwn);
+       bfa_trc(rport->fcs, rport->pid);
+       bfa_trc(rport->fcs, event);
+
+       switch (event) {
+       case RPSM_EVENT_HCB_OFFLINE:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_logo_sending);
+               bfa_fcs_rport_send_logo(rport, NULL);
+               break;
+
+       case RPSM_EVENT_LOGO_RCVD:
+       case RPSM_EVENT_PRLO_RCVD:
+       case RPSM_EVENT_ADDRESS_CHANGE:
+               break;
+
+       default:
+               bfa_sm_fault(rport->fcs, event);
+       }
+}
+
+/**
+ *             Rport is being deleted. FC-4s are offline. LOGO is being sent.
+ */
+static void
+bfa_fcs_rport_sm_logo_sending(struct bfa_fcs_rport_s *rport,
+        enum rport_event event)
+{
+       bfa_trc(rport->fcs, rport->pwwn);
+       bfa_trc(rport->fcs, rport->pid);
+       bfa_trc(rport->fcs, event);
+
+       switch (event) {
+       case RPSM_EVENT_FCXP_SENT:
+               /* Once LOGO is sent, we donot wait for the response */
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_uninit);
+               bfa_fcs_rport_free(rport);
+               break;
+
+       case RPSM_EVENT_SCN:
+       case RPSM_EVENT_ADDRESS_CHANGE:
+               break;
+
+       case RPSM_EVENT_LOGO_RCVD:
+       case RPSM_EVENT_PRLO_RCVD:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_uninit);
+               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
+               bfa_fcs_rport_free(rport);
+               break;
+
+       default:
+               bfa_sm_fault(rport->fcs, event);
+       }
+}
+
+/**
+ *             Rport is offline. FC-4s are offline. BFA rport is offline.
+ *             Timer active to delete stale rport.
+ */
+static void
+bfa_fcs_rport_sm_offline(struct bfa_fcs_rport_s *rport, enum rport_event event)
+{
+       bfa_trc(rport->fcs, rport->pwwn);
+       bfa_trc(rport->fcs, rport->pid);
+       bfa_trc(rport->fcs, event);
+
+       switch (event) {
+       case RPSM_EVENT_TIMEOUT:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_uninit);
+               bfa_fcs_rport_free(rport);
+               break;
+
+       case RPSM_EVENT_SCN:
+       case RPSM_EVENT_ADDRESS_CHANGE:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_nsdisc_sending);
+               bfa_timer_stop(&rport->timer);
+               rport->ns_retries = 0;
+               bfa_fcs_rport_send_nsdisc(rport, NULL);
+               break;
+
+       case RPSM_EVENT_DELETE:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_uninit);
+               bfa_timer_stop(&rport->timer);
+               bfa_fcs_rport_free(rport);
+               break;
+
+       case RPSM_EVENT_PLOGI_RCVD:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_plogiacc_sending);
+               bfa_timer_stop(&rport->timer);
+               bfa_fcs_rport_send_plogiacc(rport, NULL);
+               break;
+
+       case RPSM_EVENT_LOGO_RCVD:
+       case RPSM_EVENT_PRLO_RCVD:
+       case RPSM_EVENT_LOGO_IMP:
+               break;
+
+       case RPSM_EVENT_PLOGI_COMP:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_hal_online);
+               bfa_timer_stop(&rport->timer);
+               bfa_fcs_rport_hal_online(rport);
+               break;
+
+       case RPSM_EVENT_PLOGI_SEND:
+               bfa_timer_stop(&rport->timer);
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_plogi_sending);
+               rport->plogi_retries = 0;
+               bfa_fcs_rport_send_plogi(rport, NULL);
+               break;
+
+       default:
+               bfa_sm_fault(rport->fcs, event);
+       }
+}
+
+/**
+ *     Rport address has changed. Nameserver discovery request is being sent.
+ */
+static void
+bfa_fcs_rport_sm_nsdisc_sending(struct bfa_fcs_rport_s *rport,
+        enum rport_event event)
+{
+       bfa_trc(rport->fcs, rport->pwwn);
+       bfa_trc(rport->fcs, rport->pid);
+       bfa_trc(rport->fcs, event);
+
+       switch (event) {
+       case RPSM_EVENT_FCXP_SENT:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_nsdisc_sent);
+               break;
+
+       case RPSM_EVENT_DELETE:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_uninit);
+               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
+               bfa_fcs_rport_free(rport);
+               break;
+
+       case RPSM_EVENT_PLOGI_RCVD:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_plogiacc_sending);
+               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
+               bfa_fcs_rport_send_plogiacc(rport, NULL);
+               break;
+
+       case RPSM_EVENT_SCN:
+       case RPSM_EVENT_LOGO_RCVD:
+       case RPSM_EVENT_PRLO_RCVD:
+       case RPSM_EVENT_PLOGI_SEND:
+               break;
+
+       case RPSM_EVENT_ADDRESS_CHANGE:
+               rport->ns_retries = 0; /* reset the retry count */
+               break;
+
+       case RPSM_EVENT_LOGO_IMP:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_offline);
+               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
+               bfa_timer_start(rport->fcs->bfa, &rport->timer,
+                               bfa_fcs_rport_timeout, rport,
+                               bfa_fcs_rport_del_timeout);
+               break;
+
+       case RPSM_EVENT_PLOGI_COMP:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_hal_online);
+               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
+               bfa_fcs_rport_hal_online(rport);
+               break;
+
+       default:
+               bfa_sm_fault(rport->fcs, event);
+       }
+}
+
+/**
+ *             Nameserver discovery failed. Waiting for timeout to retry.
+ */
+static void
+bfa_fcs_rport_sm_nsdisc_retry(struct bfa_fcs_rport_s *rport,
+        enum rport_event event)
+{
+       bfa_trc(rport->fcs, rport->pwwn);
+       bfa_trc(rport->fcs, rport->pid);
+       bfa_trc(rport->fcs, event);
+
+       switch (event) {
+       case RPSM_EVENT_TIMEOUT:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_nsdisc_sending);
+               bfa_fcs_rport_send_nsdisc(rport, NULL);
+               break;
+
+       case RPSM_EVENT_SCN:
+       case RPSM_EVENT_ADDRESS_CHANGE:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_nsdisc_sending);
+               bfa_timer_stop(&rport->timer);
+               rport->ns_retries = 0;
+               bfa_fcs_rport_send_nsdisc(rport, NULL);
+               break;
+
+       case RPSM_EVENT_DELETE:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_uninit);
+               bfa_timer_stop(&rport->timer);
+               bfa_fcs_rport_free(rport);
+               break;
+
+       case RPSM_EVENT_PLOGI_RCVD:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_plogiacc_sending);
+               bfa_timer_stop(&rport->timer);
+               bfa_fcs_rport_send_plogiacc(rport, NULL);
+               break;
+
+       case RPSM_EVENT_LOGO_IMP:
+               rport->pid = 0;
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_offline);
+               bfa_timer_stop(&rport->timer);
+               bfa_timer_start(rport->fcs->bfa, &rport->timer,
+                               bfa_fcs_rport_timeout, rport,
+                               bfa_fcs_rport_del_timeout);
+               break;
+
+       case RPSM_EVENT_LOGO_RCVD:
+               bfa_fcs_rport_send_logo_acc(rport);
+               break;
+       case RPSM_EVENT_PRLO_RCVD:
+               bfa_fcs_rport_send_prlo_acc(rport);
+               break;
+
+       case RPSM_EVENT_PLOGI_COMP:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_hal_online);
+               bfa_timer_stop(&rport->timer);
+               bfa_fcs_rport_hal_online(rport);
+               break;
+
+       default:
+               bfa_sm_fault(rport->fcs, event);
+       }
+}
+
+/**
+ *             Rport address has changed. Nameserver discovery request is sent.
+ */
+static void
+bfa_fcs_rport_sm_nsdisc_sent(struct bfa_fcs_rport_s *rport,
+                       enum rport_event event)
+{
+       bfa_trc(rport->fcs, rport->pwwn);
+       bfa_trc(rport->fcs, rport->pid);
+       bfa_trc(rport->fcs, event);
+
+       switch (event) {
+       case RPSM_EVENT_ACCEPTED:
+       case RPSM_EVENT_ADDRESS_CHANGE:
+               if (rport->pid) {
+                       bfa_sm_set_state(rport, bfa_fcs_rport_sm_plogi_sending);
+                       bfa_fcs_rport_send_plogi(rport, NULL);
+               } else {
+                       bfa_sm_set_state(rport,
+                                bfa_fcs_rport_sm_nsdisc_sending);
+                       rport->ns_retries = 0;
+                       bfa_fcs_rport_send_nsdisc(rport, NULL);
+               }
+               break;
+
+       case RPSM_EVENT_FAILED:
+               rport->ns_retries++;
+               if (rport->ns_retries < BFA_FCS_RPORT_MAX_RETRIES) {
+                       bfa_sm_set_state(rport,
+                                bfa_fcs_rport_sm_nsdisc_sending);
+                       bfa_fcs_rport_send_nsdisc(rport, NULL);
+               } else {
+                       rport->pid = 0;
+                       bfa_sm_set_state(rport, bfa_fcs_rport_sm_offline);
+                       bfa_timer_start(rport->fcs->bfa, &rport->timer,
+                                       bfa_fcs_rport_timeout, rport,
+                                       bfa_fcs_rport_del_timeout);
+               };
+               break;
+
+       case RPSM_EVENT_DELETE:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_uninit);
+               bfa_fcxp_discard(rport->fcxp);
+               bfa_fcs_rport_free(rport);
+               break;
+
+       case RPSM_EVENT_PLOGI_RCVD:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_plogiacc_sending);
+               bfa_fcxp_discard(rport->fcxp);
+               bfa_fcs_rport_send_plogiacc(rport, NULL);
+               break;
+
+       case RPSM_EVENT_LOGO_IMP:
+               rport->pid = 0;
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_offline);
+               bfa_fcxp_discard(rport->fcxp);
+               bfa_timer_start(rport->fcs->bfa, &rport->timer,
+                               bfa_fcs_rport_timeout, rport,
+                               bfa_fcs_rport_del_timeout);
+               break;
+
+
+       case RPSM_EVENT_PRLO_RCVD:
+               bfa_fcs_rport_send_prlo_acc(rport);
+               break;
+       case RPSM_EVENT_SCN:
+               /**
+                * ignore, wait for NS query response
+                */
+               break;
+
+       case RPSM_EVENT_LOGO_RCVD:
+               /**
+                * Not logged-in yet. Accept LOGO.
+                */
+               bfa_fcs_rport_send_logo_acc(rport);
+               break;
+
+       case RPSM_EVENT_PLOGI_COMP:
+               bfa_sm_set_state(rport, bfa_fcs_rport_sm_hal_online);
+               bfa_fcxp_discard(rport->fcxp);
+               bfa_fcs_rport_hal_online(rport);
+               break;
+
+       default:
+               bfa_sm_fault(rport->fcs, event);
+       }
+}
+
+
+
+/**
+ *  fcs_rport_private FCS RPORT provate functions
+ */
+
+static void
+bfa_fcs_rport_send_plogi(void *rport_cbarg, struct bfa_fcxp_s *fcxp_alloced)
+{
+       struct bfa_fcs_rport_s *rport = rport_cbarg;
+       struct bfa_fcs_lport_s *port = rport->port;
+       struct fchs_s   fchs;
+       int             len;
+       struct bfa_fcxp_s *fcxp;
+
+       bfa_trc(rport->fcs, rport->pwwn);
+
+       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
+       if (!fcxp) {
+               bfa_fcs_fcxp_alloc_wait(port->fcs->bfa, &rport->fcxp_wqe,
+                                       bfa_fcs_rport_send_plogi, rport);
+               return;
+       }
+       rport->fcxp = fcxp;
+
+       len = fc_plogi_build(&fchs, bfa_fcxp_get_reqbuf(fcxp), rport->pid,
+                               bfa_fcs_lport_get_fcid(port), 0,
+                               port->port_cfg.pwwn, port->port_cfg.nwwn,
+                               bfa_fcport_get_maxfrsize(port->fcs->bfa));
+
+       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
+                       FC_CLASS_3, len, &fchs, bfa_fcs_rport_plogi_response,
+                       (void *)rport, FC_MAX_PDUSZ, FC_ELS_TOV);
+
+       rport->stats.plogis++;
+       bfa_sm_send_event(rport, RPSM_EVENT_FCXP_SENT);
+}
+
+static void
+bfa_fcs_rport_plogi_response(void *fcsarg, struct bfa_fcxp_s *fcxp, void *cbarg,
+                               bfa_status_t req_status, u32 rsp_len,
+                               u32 resid_len, struct fchs_s *rsp_fchs)
+{
+       struct bfa_fcs_rport_s *rport = (struct bfa_fcs_rport_s *) cbarg;
+       struct fc_logi_s        *plogi_rsp;
+       struct fc_ls_rjt_s      *ls_rjt;
+       struct bfa_fcs_rport_s *twin;
+       struct list_head        *qe;
+
+       bfa_trc(rport->fcs, rport->pwwn);
+
+       /*
+        * Sanity Checks
+        */
+       if (req_status != BFA_STATUS_OK) {
+               bfa_trc(rport->fcs, req_status);
+               rport->stats.plogi_failed++;
+               bfa_sm_send_event(rport, RPSM_EVENT_FAILED);
+               return;
+       }
+
+       plogi_rsp = (struct fc_logi_s *) BFA_FCXP_RSP_PLD(fcxp);
+
+       /**
+        * Check for failure first.
+        */
+       if (plogi_rsp->els_cmd.els_code != FC_ELS_ACC) {
+               ls_rjt = (struct fc_ls_rjt_s *) BFA_FCXP_RSP_PLD(fcxp);
+
+               bfa_trc(rport->fcs, ls_rjt->reason_code);
+               bfa_trc(rport->fcs, ls_rjt->reason_code_expl);
+
+               if ((ls_rjt->reason_code == FC_LS_RJT_RSN_UNABLE_TO_PERF_CMD) &&
+                (ls_rjt->reason_code_expl == FC_LS_RJT_EXP_INSUFF_RES)) {
+                       rport->stats.rjt_insuff_res++;
+                       bfa_sm_send_event(rport, RPSM_EVENT_PLOGI_RETRY);
+                       return;
+               }
+
+               rport->stats.plogi_rejects++;
+               bfa_sm_send_event(rport, RPSM_EVENT_FAILED);
+               return;
+       }
+
+       /**
+        * PLOGI is complete. Make sure this device is not one of the known
+        * device with a new FC port address.
+        */
+       list_for_each(qe, &rport->port->rport_q) {
+               twin = (struct bfa_fcs_rport_s *) qe;
+               if (twin == rport)
+                       continue;
+               if (!rport->pwwn && (plogi_rsp->port_name == twin->pwwn)) {
+                       bfa_trc(rport->fcs, twin->pid);
+                       bfa_trc(rport->fcs, rport->pid);
+
+                       /* Update plogi stats in twin */
+                       twin->stats.plogis  += rport->stats.plogis;
+                       twin->stats.plogi_rejects  +=
+                                rport->stats.plogi_rejects;
+                       twin->stats.plogi_timeouts  +=
+                                rport->stats.plogi_timeouts;
+                       twin->stats.plogi_failed +=
+                                rport->stats.plogi_failed;
+                       twin->stats.plogi_rcvd    += rport->stats.plogi_rcvd;
+                       twin->stats.plogi_accs++;
+
+                       bfa_fcs_rport_delete(rport);
+
+                       bfa_fcs_rport_update(twin, plogi_rsp);
+                       twin->pid = rsp_fchs->s_id;
+                       bfa_sm_send_event(twin, RPSM_EVENT_PLOGI_COMP);
+                       return;
+               }
+       }
+
+       /**
+        * Normal login path -- no evil twins.
+        */
+       rport->stats.plogi_accs++;
+       bfa_fcs_rport_update(rport, plogi_rsp);
+       bfa_sm_send_event(rport, RPSM_EVENT_ACCEPTED);
+}
+
+static void
+bfa_fcs_rport_send_plogiacc(void *rport_cbarg, struct bfa_fcxp_s *fcxp_alloced)
+{
+       struct bfa_fcs_rport_s *rport = rport_cbarg;
+       struct bfa_fcs_lport_s *port = rport->port;
+       struct fchs_s           fchs;
+       int             len;
+       struct bfa_fcxp_s *fcxp;
+
+       bfa_trc(rport->fcs, rport->pwwn);
+       bfa_trc(rport->fcs, rport->reply_oxid);
+
+       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
+       if (!fcxp) {
+               bfa_fcs_fcxp_alloc_wait(port->fcs->bfa, &rport->fcxp_wqe,
+                                       bfa_fcs_rport_send_plogiacc, rport);
+               return;
+       }
+       rport->fcxp = fcxp;
+
+       len = fc_plogi_acc_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
+                                rport->pid, bfa_fcs_lport_get_fcid(port),
+                                rport->reply_oxid, port->port_cfg.pwwn,
+                                port->port_cfg.nwwn,
+                                bfa_fcport_get_maxfrsize(port->fcs->bfa));
+
+       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
+                       FC_CLASS_3, len, &fchs, NULL, NULL, FC_MAX_PDUSZ, 0);
+
+       bfa_sm_send_event(rport, RPSM_EVENT_FCXP_SENT);
+}
+
+static void
+bfa_fcs_rport_send_adisc(void *rport_cbarg, struct bfa_fcxp_s *fcxp_alloced)
+{
+       struct bfa_fcs_rport_s *rport = rport_cbarg;
+       struct bfa_fcs_lport_s *port = rport->port;
+       struct fchs_s           fchs;
+       int             len;
+       struct bfa_fcxp_s *fcxp;
+
+       bfa_trc(rport->fcs, rport->pwwn);
+
+       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
+       if (!fcxp) {
+               bfa_fcs_fcxp_alloc_wait(port->fcs->bfa, &rport->fcxp_wqe,
+                                       bfa_fcs_rport_send_adisc, rport);
+               return;
+       }
+       rport->fcxp = fcxp;
+
+       len = fc_adisc_build(&fchs, bfa_fcxp_get_reqbuf(fcxp), rport->pid,
+                               bfa_fcs_lport_get_fcid(port), 0,
+                               port->port_cfg.pwwn, port->port_cfg.nwwn);
+
+       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
+                       FC_CLASS_3, len, &fchs, bfa_fcs_rport_adisc_response,
+                       rport, FC_MAX_PDUSZ, FC_ELS_TOV);
+
+       rport->stats.adisc_sent++;
+       bfa_sm_send_event(rport, RPSM_EVENT_FCXP_SENT);
+}
+
+static void
+bfa_fcs_rport_adisc_response(void *fcsarg, struct bfa_fcxp_s *fcxp, void *cbarg,
+                               bfa_status_t req_status, u32 rsp_len,
+                               u32 resid_len, struct fchs_s *rsp_fchs)
+{
+       struct bfa_fcs_rport_s *rport = (struct bfa_fcs_rport_s *) cbarg;
+       void            *pld = bfa_fcxp_get_rspbuf(fcxp);
+       struct fc_ls_rjt_s      *ls_rjt;
+
+       if (req_status != BFA_STATUS_OK) {
+               bfa_trc(rport->fcs, req_status);
+               rport->stats.adisc_failed++;
+               bfa_sm_send_event(rport, RPSM_EVENT_FAILED);
+               return;
+       }
+
+       if (fc_adisc_rsp_parse((struct fc_adisc_s *)pld, rsp_len, rport->pwwn,
+                               rport->nwwn)  == FC_PARSE_OK) {
+               rport->stats.adisc_accs++;
+               bfa_sm_send_event(rport, RPSM_EVENT_ACCEPTED);
+               return;
+       }
+
+       rport->stats.adisc_rejects++;
+       ls_rjt = pld;
+       bfa_trc(rport->fcs, ls_rjt->els_cmd.els_code);
+       bfa_trc(rport->fcs, ls_rjt->reason_code);
+       bfa_trc(rport->fcs, ls_rjt->reason_code_expl);
+       bfa_sm_send_event(rport, RPSM_EVENT_FAILED);
+}
+
+static void
+bfa_fcs_rport_send_nsdisc(void *rport_cbarg, struct bfa_fcxp_s *fcxp_alloced)
+{
+       struct bfa_fcs_rport_s *rport = rport_cbarg;
+       struct bfa_fcs_lport_s *port = rport->port;
+       struct fchs_s   fchs;
+       struct bfa_fcxp_s *fcxp;
+       int             len;
+       bfa_cb_fcxp_send_t cbfn;
+
+       bfa_trc(rport->fcs, rport->pid);
+
+       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
+       if (!fcxp) {
+               bfa_fcs_fcxp_alloc_wait(port->fcs->bfa, &rport->fcxp_wqe,
+                                       bfa_fcs_rport_send_nsdisc, rport);
+               return;
+       }
+       rport->fcxp = fcxp;
+
+       if (rport->pwwn) {
+               len = fc_gidpn_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
+                               bfa_fcs_lport_get_fcid(port), 0, rport->pwwn);
+               cbfn = bfa_fcs_rport_gidpn_response;
+       } else {
+               len = fc_gpnid_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
+                               bfa_fcs_lport_get_fcid(port), 0, rport->pid);
+               cbfn = bfa_fcs_rport_gpnid_response;
+       }
+
+       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
+                       FC_CLASS_3, len, &fchs, cbfn,
+                       (void *)rport, FC_MAX_PDUSZ, FC_FCCT_TOV);
+
+       bfa_sm_send_event(rport, RPSM_EVENT_FCXP_SENT);
+}
+
+static void
+bfa_fcs_rport_gidpn_response(void *fcsarg, struct bfa_fcxp_s *fcxp, void *cbarg,
+                               bfa_status_t req_status, u32 rsp_len,
+                               u32 resid_len, struct fchs_s *rsp_fchs)
+{
+       struct bfa_fcs_rport_s *rport = (struct bfa_fcs_rport_s *) cbarg;
+       struct ct_hdr_s *cthdr;
+       struct fcgs_gidpn_resp_s        *gidpn_rsp;
+       struct bfa_fcs_rport_s  *twin;
+       struct list_head        *qe;
+
+       bfa_trc(rport->fcs, rport->pwwn);
+
+       cthdr = (struct ct_hdr_s *) BFA_FCXP_RSP_PLD(fcxp);
+       cthdr->cmd_rsp_code = bfa_os_ntohs(cthdr->cmd_rsp_code);
+
+       if (cthdr->cmd_rsp_code == CT_RSP_ACCEPT) {
+               /* Check if the pid is the same as before. */
+               gidpn_rsp = (struct fcgs_gidpn_resp_s *) (cthdr + 1);
+
+               if (gidpn_rsp->dap == rport->pid) {
+                       /* Device is online  */
+                       bfa_sm_send_event(rport, RPSM_EVENT_ACCEPTED);
+               } else {
+                       /*
+                        * Device's PID has changed. We need to cleanup
+                        * and re-login. If there is another device with
+                        * the the newly discovered pid, send an scn notice
+                        * so that its new pid can be discovered.
+                        */
+                       list_for_each(qe, &rport->port->rport_q) {
+                               twin = (struct bfa_fcs_rport_s *) qe;
+                               if (twin == rport)
+                                       continue;
+                               if (gidpn_rsp->dap == twin->pid) {
+                                       bfa_trc(rport->fcs, twin->pid);
+                                       bfa_trc(rport->fcs, rport->pid);
+
+                                       twin->pid = 0;
+                                       bfa_sm_send_event(twin,
+                                        RPSM_EVENT_ADDRESS_CHANGE);
+                               }
+                       }
+                       rport->pid = gidpn_rsp->dap;
+                       bfa_sm_send_event(rport, RPSM_EVENT_ADDRESS_CHANGE);
+               }
+               return;
+       }
+
+       /*
+        * Reject Response
+        */
+       switch (cthdr->reason_code) {
+       case CT_RSN_LOGICAL_BUSY:
+               /*
+                * Need to retry
+                */
+               bfa_sm_send_event(rport, RPSM_EVENT_TIMEOUT);
+               break;
+
+       case CT_RSN_UNABLE_TO_PERF:
+               /*
+                * device doesn't exist : Start timer to cleanup this later.
+                */
+               bfa_sm_send_event(rport, RPSM_EVENT_FAILED);
+               break;
+
+       default:
+               bfa_sm_send_event(rport, RPSM_EVENT_FAILED);
+               break;
+       }
+}
+
+static void
+bfa_fcs_rport_gpnid_response(void *fcsarg, struct bfa_fcxp_s *fcxp, void *cbarg,
+                               bfa_status_t req_status, u32 rsp_len,
+                               u32 resid_len, struct fchs_s *rsp_fchs)
+{
+       struct bfa_fcs_rport_s *rport = (struct bfa_fcs_rport_s *) cbarg;
+       struct ct_hdr_s *cthdr;
+
+       bfa_trc(rport->fcs, rport->pwwn);
+
+       cthdr = (struct ct_hdr_s *) BFA_FCXP_RSP_PLD(fcxp);
+       cthdr->cmd_rsp_code = bfa_os_ntohs(cthdr->cmd_rsp_code);
+
+       if (cthdr->cmd_rsp_code == CT_RSP_ACCEPT) {
+               bfa_sm_send_event(rport, RPSM_EVENT_ACCEPTED);
+               return;
+       }
+
+       /*
+        * Reject Response
+        */
+       switch (cthdr->reason_code) {
+       case CT_RSN_LOGICAL_BUSY:
+               /*
+                * Need to retry
+                */
+               bfa_sm_send_event(rport, RPSM_EVENT_TIMEOUT);
+               break;
+
+       case CT_RSN_UNABLE_TO_PERF:
+               /*
+                * device doesn't exist : Start timer to cleanup this later.
+                */
+               bfa_sm_send_event(rport, RPSM_EVENT_FAILED);
+               break;
+
+       default:
+               bfa_sm_send_event(rport, RPSM_EVENT_FAILED);
+               break;
+       }
+}
+
+/**
+ *     Called to send a logout to the rport.
+ */
+static void
+bfa_fcs_rport_send_logo(void *rport_cbarg, struct bfa_fcxp_s *fcxp_alloced)
+{
+       struct bfa_fcs_rport_s *rport = rport_cbarg;
+       struct bfa_fcs_lport_s *port;
+       struct fchs_s   fchs;
+       struct bfa_fcxp_s *fcxp;
+       u16     len;
+
+       bfa_trc(rport->fcs, rport->pid);
+
+       port = rport->port;
+
+       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
+       if (!fcxp) {
+               bfa_fcs_fcxp_alloc_wait(port->fcs->bfa, &rport->fcxp_wqe,
+                                       bfa_fcs_rport_send_logo, rport);
+               return;
+       }
+       rport->fcxp = fcxp;
+
+       len = fc_logo_build(&fchs, bfa_fcxp_get_reqbuf(fcxp), rport->pid,
+                               bfa_fcs_lport_get_fcid(port), 0,
+                               bfa_fcs_lport_get_pwwn(port));
+
+       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
+                       FC_CLASS_3, len, &fchs, NULL,
+                       rport, FC_MAX_PDUSZ, FC_ELS_TOV);
+
+       rport->stats.logos++;
+       bfa_fcxp_discard(rport->fcxp);
+       bfa_sm_send_event(rport, RPSM_EVENT_FCXP_SENT);
+}
+
+/**
+ *     Send ACC for a LOGO received.
+ */
+static void
+bfa_fcs_rport_send_logo_acc(void *rport_cbarg)
+{
+       struct bfa_fcs_rport_s *rport = rport_cbarg;
+       struct bfa_fcs_lport_s *port;
+       struct fchs_s   fchs;
+       struct bfa_fcxp_s *fcxp;
+       u16     len;
+
+       bfa_trc(rport->fcs, rport->pid);
+
+       port = rport->port;
+
+       fcxp = bfa_fcs_fcxp_alloc(port->fcs);
+       if (!fcxp)
+               return;
+
+       rport->stats.logo_rcvd++;
+       len = fc_logo_acc_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
+                               rport->pid, bfa_fcs_lport_get_fcid(port),
+                               rport->reply_oxid);
+
+       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
+                       FC_CLASS_3, len, &fchs, NULL, NULL, FC_MAX_PDUSZ, 0);
+}
+
+/**
+ *     brief
+ *     This routine will be called by bfa_timer on timer timeouts.
+ *
+ *     param[in]       rport                   - pointer to bfa_fcs_lport_ns_t.
+ *     param[out]      rport_status    - pointer to return vport status in
+ *
+ *     return
+ *             void
+ *
+ *     Special Considerations:
+ *
+ *     note
+ */
+static void
+bfa_fcs_rport_timeout(void *arg)
+{
+       struct bfa_fcs_rport_s *rport = (struct bfa_fcs_rport_s *) arg;
+
+       rport->stats.plogi_timeouts++;
+       bfa_stats(rport->port, rport_plogi_timeouts);
+       bfa_sm_send_event(rport, RPSM_EVENT_TIMEOUT);
+}
+
+static void
+bfa_fcs_rport_process_prli(struct bfa_fcs_rport_s *rport,
+                       struct fchs_s *rx_fchs, u16 len)
+{
+       struct bfa_fcxp_s *fcxp;
+       struct fchs_s   fchs;
+       struct bfa_fcs_lport_s *port = rport->port;
+       struct fc_prli_s        *prli;
+
+       bfa_trc(port->fcs, rx_fchs->s_id);
+       bfa_trc(port->fcs, rx_fchs->d_id);
+
+       rport->stats.prli_rcvd++;
+
+       /*
+        * We are in Initiator Mode
+        */
+       prli = (struct fc_prli_s *) (rx_fchs + 1);
+
+       if (prli->parampage.servparams.target) {
+               /*
+                * PRLI from a target ?
+                * Send the Acc.
+                * PRLI sent by us will be used to transition the IT nexus,
+                * once the response is received from the target.
+                */
+               bfa_trc(port->fcs, rx_fchs->s_id);
+               rport->scsi_function = BFA_RPORT_TARGET;
+       } else {
+               bfa_trc(rport->fcs, prli->parampage.type);
+               rport->scsi_function = BFA_RPORT_INITIATOR;
+               bfa_fcs_itnim_is_initiator(rport->itnim);
+       }
+
+       fcxp = bfa_fcs_fcxp_alloc(port->fcs);
+       if (!fcxp)
+               return;
+
+       len = fc_prli_acc_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
+                               rx_fchs->s_id, bfa_fcs_lport_get_fcid(port),
+                               rx_fchs->ox_id, port->port_cfg.roles);
+
+       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
+                       FC_CLASS_3, len, &fchs, NULL, NULL, FC_MAX_PDUSZ, 0);
+}
+
+static void
+bfa_fcs_rport_process_rpsc(struct bfa_fcs_rport_s *rport,
+                       struct fchs_s *rx_fchs, u16 len)
+{
+       struct bfa_fcxp_s *fcxp;
+       struct fchs_s   fchs;
+       struct bfa_fcs_lport_s *port = rport->port;
+       struct fc_rpsc_speed_info_s speeds;
+       struct bfa_port_attr_s pport_attr;
+
+       bfa_trc(port->fcs, rx_fchs->s_id);
+       bfa_trc(port->fcs, rx_fchs->d_id);
+
+       rport->stats.rpsc_rcvd++;
+       speeds.port_speed_cap =
+               RPSC_SPEED_CAP_1G | RPSC_SPEED_CAP_2G | RPSC_SPEED_CAP_4G |
+               RPSC_SPEED_CAP_8G;
+
+       /*
+        * get curent speed from pport attributes from BFA
+        */
+       bfa_fcport_get_attr(port->fcs->bfa, &pport_attr);
+
+       speeds.port_op_speed = fc_bfa_speed_to_rpsc_operspeed(pport_attr.speed);
+
+       fcxp = bfa_fcs_fcxp_alloc(port->fcs);
+       if (!fcxp)
+               return;
+
+       len = fc_rpsc_acc_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
+                               rx_fchs->s_id, bfa_fcs_lport_get_fcid(port),
+                               rx_fchs->ox_id, &speeds);
+
+       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
+                       FC_CLASS_3, len, &fchs, NULL, NULL, FC_MAX_PDUSZ, 0);
+}
+
+static void
+bfa_fcs_rport_process_adisc(struct bfa_fcs_rport_s *rport,
+                       struct fchs_s *rx_fchs, u16 len)
+{
+       struct bfa_fcxp_s *fcxp;
+       struct fchs_s   fchs;
+       struct bfa_fcs_lport_s *port = rport->port;
+       struct fc_adisc_s       *adisc;
+
+       bfa_trc(port->fcs, rx_fchs->s_id);
+       bfa_trc(port->fcs, rx_fchs->d_id);
+
+       rport->stats.adisc_rcvd++;
+
+       adisc = (struct fc_adisc_s *) (rx_fchs + 1);
+
+       /*
+        * Accept if the itnim for this rport is online.
+        * Else reject the ADISC.
+        */
+       if (bfa_fcs_itnim_get_online_state(rport->itnim) == BFA_STATUS_OK) {
+
+               fcxp = bfa_fcs_fcxp_alloc(port->fcs);
+               if (!fcxp)
+                       return;
+
+               len = fc_adisc_acc_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
+                        rx_fchs->s_id, bfa_fcs_lport_get_fcid(port),
+                        rx_fchs->ox_id, port->port_cfg.pwwn,
+                        port->port_cfg.nwwn);
+
+               bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag,
+                               BFA_FALSE, FC_CLASS_3, len, &fchs, NULL, NULL,
+                               FC_MAX_PDUSZ, 0);
+       } else {
+               rport->stats.adisc_rejected++;
+               bfa_fcs_rport_send_ls_rjt(rport, rx_fchs,
+                                         FC_LS_RJT_RSN_UNABLE_TO_PERF_CMD,
+                                         FC_LS_RJT_EXP_LOGIN_REQUIRED);
+       }
+}
+
+static void
+bfa_fcs_rport_hal_online(struct bfa_fcs_rport_s *rport)
+{
+       struct bfa_fcs_lport_s *port = rport->port;
+       struct bfa_rport_info_s rport_info;
+
+       rport_info.pid = rport->pid;
+       rport_info.local_pid = port->pid;
+       rport_info.lp_tag = port->lp_tag;
+       rport_info.vf_id = port->fabric->vf_id;
+       rport_info.vf_en = port->fabric->is_vf;
+       rport_info.fc_class = rport->fc_cos;
+       rport_info.cisc = rport->cisc;
+       rport_info.max_frmsz = rport->maxfrsize;
+       bfa_rport_online(rport->bfa_rport, &rport_info);
+}
+
+static struct bfa_fcs_rport_s *
+bfa_fcs_rport_alloc(struct bfa_fcs_lport_s *port, wwn_t pwwn, u32 rpid)
+{
+       struct bfa_fcs_s        *fcs = port->fcs;
+       struct bfa_fcs_rport_s *rport;
+       struct bfad_rport_s     *rport_drv;
+
+       /**
+        * allocate rport
+        */
+       if (bfa_fcb_rport_alloc(fcs->bfad, &rport, &rport_drv)
+               != BFA_STATUS_OK) {
+               bfa_trc(fcs, rpid);
+               return NULL;
+       }
+
+       /*
+        * Initialize r-port
+        */
+       rport->port = port;
+       rport->fcs = fcs;
+       rport->rp_drv = rport_drv;
+       rport->pid = rpid;
+       rport->pwwn = pwwn;
+
+       /**
+        * allocate BFA rport
+        */
+       rport->bfa_rport = bfa_rport_create(port->fcs->bfa, rport);
+       if (!rport->bfa_rport) {
+               bfa_trc(fcs, rpid);
+               kfree(rport_drv);
+               return NULL;
+       }
+
+       /**
+        * allocate FC-4s
+        */
+       bfa_assert(bfa_fcs_lport_is_initiator(port));
+
+       if (bfa_fcs_lport_is_initiator(port)) {
+               rport->itnim = bfa_fcs_itnim_create(rport);
+               if (!rport->itnim) {
+                       bfa_trc(fcs, rpid);
+                       bfa_rport_delete(rport->bfa_rport);
+                       kfree(rport_drv);
+                       return NULL;
+               }
+       }
+
+       bfa_fcs_lport_add_rport(port, rport);
+
+       bfa_sm_set_state(rport, bfa_fcs_rport_sm_uninit);
+
+       /* Initialize the Rport Features(RPF) Sub Module  */
+       if (!BFA_FCS_PID_IS_WKA(rport->pid))
+               bfa_fcs_rpf_init(rport);
+
+       return rport;
+}
+
+
+static void
+bfa_fcs_rport_free(struct bfa_fcs_rport_s *rport)
+{
+       struct bfa_fcs_lport_s *port = rport->port;
+
+       /**
+        * - delete FC-4s
+        * - delete BFA rport
+        * - remove from queue of rports
+        */
+       if (bfa_fcs_lport_is_initiator(port)) {
+               bfa_fcs_itnim_delete(rport->itnim);
+               if (rport->pid != 0 && !BFA_FCS_PID_IS_WKA(rport->pid))
+                       bfa_fcs_rpf_rport_offline(rport);
+       }
+
+       bfa_rport_delete(rport->bfa_rport);
+       bfa_fcs_lport_del_rport(port, rport);
+       kfree(rport->rp_drv);
+}
+
+static void
+bfa_fcs_rport_online_action(struct bfa_fcs_rport_s *rport)
+{
+       struct bfa_fcs_lport_s *port = rport->port;
+       struct bfad_s *bfad = (struct bfad_s *)port->fcs->bfad;
+       char    lpwwn_buf[BFA_STRING_32];
+       char    rpwwn_buf[BFA_STRING_32];
+
+       rport->stats.onlines++;
+
+       if (bfa_fcs_lport_is_initiator(port)) {
+               bfa_fcs_itnim_rport_online(rport->itnim);
+               if (!BFA_FCS_PID_IS_WKA(rport->pid))
+                       bfa_fcs_rpf_rport_online(rport);
+       };
+
+       wwn2str(lpwwn_buf, bfa_fcs_lport_get_pwwn(port));
+       wwn2str(rpwwn_buf, rport->pwwn);
+       if (!BFA_FCS_PID_IS_WKA(rport->pid))
+               BFA_LOG(KERN_INFO, bfad, log_level,
+               "Remote port (WWN = %s) online for logical port (WWN = %s)\n",
+               rpwwn_buf, lpwwn_buf);
+}
+
+static void
+bfa_fcs_rport_offline_action(struct bfa_fcs_rport_s *rport)
+{
+       struct bfa_fcs_lport_s *port = rport->port;
+       struct bfad_s *bfad = (struct bfad_s *)port->fcs->bfad;
+       char    lpwwn_buf[BFA_STRING_32];
+       char    rpwwn_buf[BFA_STRING_32];
+
+       rport->stats.offlines++;
+
+       wwn2str(lpwwn_buf, bfa_fcs_lport_get_pwwn(port));
+       wwn2str(rpwwn_buf, rport->pwwn);
+       if (!BFA_FCS_PID_IS_WKA(rport->pid)) {
+               if (bfa_fcs_lport_is_online(rport->port) == BFA_TRUE)
+                       BFA_LOG(KERN_ERR, bfad, log_level,
+                               "Remote port (WWN = %s) connectivity lost for "
+                               "logical port (WWN = %s)\n",
+                               rpwwn_buf, lpwwn_buf);
+               else
+                       BFA_LOG(KERN_INFO, bfad, log_level,
+                               "Remote port (WWN = %s) offlined by "
+                               "logical port (WWN = %s)\n",
+                               rpwwn_buf, lpwwn_buf);
+       }
+
+       if (bfa_fcs_lport_is_initiator(port)) {
+               bfa_fcs_itnim_rport_offline(rport->itnim);
+               if (!BFA_FCS_PID_IS_WKA(rport->pid))
+                       bfa_fcs_rpf_rport_offline(rport);
+       }
+}
+
+/**
+ * Update rport parameters from PLOGI or PLOGI accept.
+ */
+static void
+bfa_fcs_rport_update(struct bfa_fcs_rport_s *rport, struct fc_logi_s *plogi)
+{
+       bfa_fcs_lport_t *port = rport->port;
+
+       /**
+        * - port name
+        * - node name
+        */
+       rport->pwwn = plogi->port_name;
+       rport->nwwn = plogi->node_name;
+
+       /**
+        * - class of service
+        */
+       rport->fc_cos = 0;
+       if (plogi->class3.class_valid)
+               rport->fc_cos = FC_CLASS_3;
+
+       if (plogi->class2.class_valid)
+               rport->fc_cos |= FC_CLASS_2;
+
+       /**
+        * - CISC
+        * - MAX receive frame size
+        */
+       rport->cisc = plogi->csp.cisc;
+       rport->maxfrsize = bfa_os_ntohs(plogi->class3.rxsz);
+
+       bfa_trc(port->fcs, bfa_os_ntohs(plogi->csp.bbcred));
+       bfa_trc(port->fcs, port->fabric->bb_credit);
+       /**
+        * Direct Attach P2P mode :
+        * This is to handle a bug (233476) in IBM targets in Direct Attach
+        *  Mode. Basically, in FLOGI Accept the target would have
+        * erroneously set the BB Credit to the value used in the FLOGI
+        * sent by the HBA. It uses the correct value (its own BB credit)
+        * in PLOGI.
+        */
+       if ((!bfa_fcs_fabric_is_switched(port->fabric))  &&
+               (bfa_os_ntohs(plogi->csp.bbcred) < port->fabric->bb_credit)) {
+
+               bfa_trc(port->fcs, bfa_os_ntohs(plogi->csp.bbcred));
+               bfa_trc(port->fcs, port->fabric->bb_credit);
+
+               port->fabric->bb_credit = bfa_os_ntohs(plogi->csp.bbcred);
+               bfa_fcport_set_tx_bbcredit(port->fcs->bfa,
+                                         port->fabric->bb_credit);
+       }
+
+}
+
+/**
+ *     Called to handle LOGO received from an existing remote port.
+ */
+static void
+bfa_fcs_rport_process_logo(struct bfa_fcs_rport_s *rport, struct fchs_s *fchs)
+{
+       rport->reply_oxid = fchs->ox_id;
+       bfa_trc(rport->fcs, rport->reply_oxid);
+
+       rport->prlo = BFA_FALSE;
+       rport->stats.logo_rcvd++;
+       bfa_sm_send_event(rport, RPSM_EVENT_LOGO_RCVD);
+}
+
+
+
+/**
+ *  fcs_rport_public FCS rport public interfaces
+ */
+
+/**
+ *     Called by bport/vport to create a remote port instance for a discovered
+ *     remote device.
+ *
+ * @param[in] port     - base port or vport
+ * @param[in] rpid     - remote port ID
+ *
+ * @return None
+ */
+struct bfa_fcs_rport_s *
+bfa_fcs_rport_create(struct bfa_fcs_lport_s *port, u32 rpid)
+{
+       struct bfa_fcs_rport_s *rport;
+
+       bfa_trc(port->fcs, rpid);
+       rport = bfa_fcs_rport_alloc(port, WWN_NULL, rpid);
+       if (!rport)
+               return NULL;
+
+       bfa_sm_send_event(rport, RPSM_EVENT_PLOGI_SEND);
+       return rport;
+}
+
+/**
+ * Called to create a rport for which only the wwn is known.
+ *
+ * @param[in] port     - base port
+ * @param[in] rpwwn    - remote port wwn
+ *
+ * @return None
+ */
+struct bfa_fcs_rport_s *
+bfa_fcs_rport_create_by_wwn(struct bfa_fcs_lport_s *port, wwn_t rpwwn)
+{
+       struct bfa_fcs_rport_s *rport;
+       bfa_trc(port->fcs, rpwwn);
+       rport = bfa_fcs_rport_alloc(port, rpwwn, 0);
+       if (!rport)
+               return NULL;
+
+       bfa_sm_send_event(rport, RPSM_EVENT_ADDRESS_DISC);
+       return rport;
+}
+/**
+ * Called by bport in private loop topology to indicate that a
+ * rport has been discovered and plogi has been completed.
+ *
+ * @param[in] port     - base port or vport
+ * @param[in] rpid     - remote port ID
+ */
+void
+bfa_fcs_rport_start(struct bfa_fcs_lport_s *port, struct fchs_s *fchs,
+        struct fc_logi_s *plogi)
+{
+       struct bfa_fcs_rport_s *rport;
+
+       rport = bfa_fcs_rport_alloc(port, WWN_NULL, fchs->s_id);
+       if (!rport)
+               return;
+
+       bfa_fcs_rport_update(rport, plogi);
+
+       bfa_sm_send_event(rport, RPSM_EVENT_PLOGI_COMP);
+}
+
+/**
+ *     Called by bport/vport to handle PLOGI received from a new remote port.
+ *     If an existing rport does a plogi, it will be handled separately.
+ */
+void
+bfa_fcs_rport_plogi_create(struct bfa_fcs_lport_s *port, struct fchs_s *fchs,
+                               struct fc_logi_s *plogi)
+{
+       struct bfa_fcs_rport_s *rport;
+
+       rport = bfa_fcs_rport_alloc(port, plogi->port_name, fchs->s_id);
+       if (!rport)
+               return;
+
+       bfa_fcs_rport_update(rport, plogi);
+
+       rport->reply_oxid = fchs->ox_id;
+       bfa_trc(rport->fcs, rport->reply_oxid);
+
+       rport->stats.plogi_rcvd++;
+       bfa_sm_send_event(rport, RPSM_EVENT_PLOGI_RCVD);
+}
+
+static int
+wwn_compare(wwn_t wwn1, wwn_t wwn2)
+{
+       u8              *b1 = (u8 *) &wwn1;
+       u8              *b2 = (u8 *) &wwn2;
+       int             i;
+
+       for (i = 0; i < sizeof(wwn_t); i++) {
+               if (b1[i] < b2[i])
+                       return -1;
+               if (b1[i] > b2[i])
+                       return 1;
+       }
+       return 0;
+}
+
+/**
+ *     Called by bport/vport to handle PLOGI received from an existing
+ *      remote port.
+ */
+void
+bfa_fcs_rport_plogi(struct bfa_fcs_rport_s *rport, struct fchs_s *rx_fchs,
+                       struct fc_logi_s *plogi)
+{
+       /**
+        * @todo Handle P2P and initiator-initiator.
+        */
+
+       bfa_fcs_rport_update(rport, plogi);
+
+       rport->reply_oxid = rx_fchs->ox_id;
+       bfa_trc(rport->fcs, rport->reply_oxid);
+
+       /**
+        * In Switched fabric topology,
+        * PLOGI to each other. If our pwwn is smaller, ignore it,
+        * if it is not a well known address.
+        * If the link topology is N2N,
+        * this Plogi should be accepted.
+        */
+       if ((wwn_compare(rport->port->port_cfg.pwwn, rport->pwwn) == -1) &&
+               (bfa_fcs_fabric_is_switched(rport->port->fabric)) &&
+               (!BFA_FCS_PID_IS_WKA(rport->pid))) {
+               bfa_trc(rport->fcs, rport->pid);
+               return;
+       }
+
+       rport->stats.plogi_rcvd++;
+       bfa_sm_send_event(rport, RPSM_EVENT_PLOGI_RCVD);
+}
+
+/**
+ * Called by bport/vport to delete a remote port instance.
+ *
+ * Rport delete is called under the following conditions:
+ *             - vport is deleted
+ *             - vf is deleted
+ *             - explicit request from OS to delete rport
+ */
+void
+bfa_fcs_rport_delete(struct bfa_fcs_rport_s *rport)
+{
+       bfa_sm_send_event(rport, RPSM_EVENT_DELETE);
+}
+
+/**
+ * Called by bport/vport to  when a target goes offline.
+ *
+ */
+void
+bfa_fcs_rport_offline(struct bfa_fcs_rport_s *rport)
+{
+       bfa_sm_send_event(rport, RPSM_EVENT_LOGO_IMP);
+}
+
+/**
+ * Called by bport in n2n when a target (attached port) becomes online.
+ *
+ */
+void
+bfa_fcs_rport_online(struct bfa_fcs_rport_s *rport)
+{
+       bfa_sm_send_event(rport, RPSM_EVENT_PLOGI_SEND);
+}
+/**
+ *     Called by bport/vport to notify SCN for the remote port
+ */
+void
+bfa_fcs_rport_scn(struct bfa_fcs_rport_s *rport)
+{
+       rport->stats.rscns++;
+       bfa_sm_send_event(rport, RPSM_EVENT_SCN);
+}
+
+/**
+ *     Called by       fcpim to notify that the ITN cleanup is done.
+ */
+void
+bfa_fcs_rport_itnim_ack(struct bfa_fcs_rport_s *rport)
+{
+       bfa_sm_send_event(rport, RPSM_EVENT_FC4_OFFLINE);
+}
+
+/**
+ *     Called by fcptm to notify that the ITN cleanup is done.
+ */
+void
+bfa_fcs_rport_tin_ack(struct bfa_fcs_rport_s *rport)
+{
+       bfa_sm_send_event(rport, RPSM_EVENT_FC4_OFFLINE);
+}
+
+/**
+ *     brief
+ *     This routine BFA callback for bfa_rport_online() call.
+ *
+ *     param[in]       cb_arg  -  rport struct.
+ *
+ *     return
+ *             void
+ *
+ *     Special Considerations:
+ *
+ *     note
+ */
+void
+bfa_cb_rport_online(void *cbarg)
+{
+
+       struct bfa_fcs_rport_s *rport = (struct bfa_fcs_rport_s *) cbarg;
+
+       bfa_trc(rport->fcs, rport->pwwn);
+       bfa_sm_send_event(rport, RPSM_EVENT_HCB_ONLINE);
+}
+
+/**
+ *     brief
+ *     This routine BFA callback for bfa_rport_offline() call.
+ *
+ *     param[in]       rport   -
+ *
+ *     return
+ *             void
+ *
+ *     Special Considerations:
+ *
+ *     note
+ */
+void
+bfa_cb_rport_offline(void *cbarg)
+{
+       struct bfa_fcs_rport_s *rport = (struct bfa_fcs_rport_s *) cbarg;
+
+       bfa_trc(rport->fcs, rport->pwwn);
+       bfa_sm_send_event(rport, RPSM_EVENT_HCB_OFFLINE);
+}
+
+/**
+ *     brief
+ *     This routine is a static BFA callback when there is a QoS flow_id
+ *     change notification
+ *
+ *     param[in]       rport   -
+ *
+ *     return
+ *             void
+ *
+ *     Special Considerations:
+ *
+ *     note
+ */
+void
+bfa_cb_rport_qos_scn_flowid(void *cbarg,
+               struct bfa_rport_qos_attr_s old_qos_attr,
+               struct bfa_rport_qos_attr_s new_qos_attr)
+{
+       struct bfa_fcs_rport_s *rport = (struct bfa_fcs_rport_s *) cbarg;
+
+       bfa_trc(rport->fcs, rport->pwwn);
+}
+
+/**
+ *     brief
+ *     This routine is a static BFA callback when there is a QoS priority
+ *     change notification
+ *
+ *     param[in]       rport   -
+ *
+ *     return
+ *             void
+ *
+ *     Special Considerations:
+ *
+ *     note
+ */
+void
+bfa_cb_rport_qos_scn_prio(void *cbarg,
+               struct bfa_rport_qos_attr_s old_qos_attr,
+               struct bfa_rport_qos_attr_s new_qos_attr)
+{
+       struct bfa_fcs_rport_s *rport = (struct bfa_fcs_rport_s *) cbarg;
+
+       bfa_trc(rport->fcs, rport->pwwn);
+}
+
+/**
+ *             Called to process any unsolicted frames from this remote port
+ */
+void
+bfa_fcs_rport_logo_imp(struct bfa_fcs_rport_s *rport)
+{
+       bfa_sm_send_event(rport, RPSM_EVENT_LOGO_IMP);
+}
+
+/**
+ *             Called to process any unsolicted frames from this remote port
+ */
+void
+bfa_fcs_rport_uf_recv(struct bfa_fcs_rport_s *rport,
+                       struct fchs_s *fchs, u16 len)
+{
+       struct bfa_fcs_lport_s *port = rport->port;
+       struct fc_els_cmd_s     *els_cmd;
+
+       bfa_trc(rport->fcs, fchs->s_id);
+       bfa_trc(rport->fcs, fchs->d_id);
+       bfa_trc(rport->fcs, fchs->type);
+
+       if (fchs->type != FC_TYPE_ELS)
+               return;
+
+       els_cmd = (struct fc_els_cmd_s *) (fchs + 1);
+
+       bfa_trc(rport->fcs, els_cmd->els_code);
+
+       switch (els_cmd->els_code) {
+       case FC_ELS_LOGO:
+               bfa_stats(port, plogi_rcvd);
+               bfa_fcs_rport_process_logo(rport, fchs);
+               break;
+
+       case FC_ELS_ADISC:
+               bfa_stats(port, adisc_rcvd);
+               bfa_fcs_rport_process_adisc(rport, fchs, len);
+               break;
+
+       case FC_ELS_PRLO:
+               bfa_stats(port, prlo_rcvd);
+               if (bfa_fcs_lport_is_initiator(port))
+                       bfa_fcs_fcpim_uf_recv(rport->itnim, fchs, len);
+               break;
+
+       case FC_ELS_PRLI:
+               bfa_stats(port, prli_rcvd);
+               bfa_fcs_rport_process_prli(rport, fchs, len);
+               break;
+
+       case FC_ELS_RPSC:
+               bfa_stats(port, rpsc_rcvd);
+               bfa_fcs_rport_process_rpsc(rport, fchs, len);
+               break;
+
+       default:
+               bfa_stats(port, un_handled_els_rcvd);
+               bfa_fcs_rport_send_ls_rjt(rport, fchs,
+                                         FC_LS_RJT_RSN_CMD_NOT_SUPP,
+                                         FC_LS_RJT_EXP_NO_ADDL_INFO);
+               break;
+       }
+}
+
+/* send best case  acc to prlo */
+static void
+bfa_fcs_rport_send_prlo_acc(struct bfa_fcs_rport_s *rport)
+{
+       struct bfa_fcs_lport_s *port = rport->port;
+       struct fchs_s   fchs;
+       struct bfa_fcxp_s *fcxp;
+       int             len;
+
+       bfa_trc(rport->fcs, rport->pid);
+
+       fcxp = bfa_fcs_fcxp_alloc(port->fcs);
+       if (!fcxp)
+               return;
+       len = fc_prlo_acc_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
+                       rport->pid, bfa_fcs_lport_get_fcid(port),
+                       rport->reply_oxid, 0);
+
+       bfa_fcxp_send(fcxp, rport->bfa_rport, port->fabric->vf_id,
+               port->lp_tag, BFA_FALSE, FC_CLASS_3, len, &fchs,
+               NULL, NULL, FC_MAX_PDUSZ, 0);
+}
+
+/*
+ * Send a LS reject
+ */
+static void
+bfa_fcs_rport_send_ls_rjt(struct bfa_fcs_rport_s *rport, struct fchs_s *rx_fchs,
+                         u8 reason_code, u8 reason_code_expl)
+{
+       struct bfa_fcs_lport_s *port = rport->port;
+       struct fchs_s   fchs;
+       struct bfa_fcxp_s *fcxp;
+       int             len;
+
+       bfa_trc(rport->fcs, rx_fchs->s_id);
+
+       fcxp = bfa_fcs_fcxp_alloc(rport->fcs);
+       if (!fcxp)
+               return;
+
+       len = fc_ls_rjt_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
+                               rx_fchs->s_id, bfa_fcs_lport_get_fcid(port),
+                               rx_fchs->ox_id, reason_code, reason_code_expl);
+
+       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag,
+                       BFA_FALSE, FC_CLASS_3, len, &fchs, NULL, NULL,
+                       FC_MAX_PDUSZ, 0);
+}
+
+/**
+ * Return state of rport.
+ */
+int
+bfa_fcs_rport_get_state(struct bfa_fcs_rport_s *rport)
+{
+       return bfa_sm_to_state(rport_sm_table, rport->sm);
+}
+
+/**
+ *     brief
+ *              Called by the Driver to set rport delete/ageout timeout
+ *
+ *     param[in]               rport timeout value in seconds.
+ *
+ *     return None
+ */
+void
+bfa_fcs_rport_set_del_timeout(u8 rport_tmo)
+{
+       /* convert to Millisecs */
+       if (rport_tmo > 0)
+               bfa_fcs_rport_del_timeout = rport_tmo * 1000;
+}
+void
+bfa_fcs_rport_prlo(struct bfa_fcs_rport_s *rport, u16 ox_id)
+{
+       bfa_trc(rport->fcs, rport->pid);
+
+       rport->prlo = BFA_TRUE;
+       rport->reply_oxid = ox_id;
+       bfa_sm_send_event(rport, RPSM_EVENT_PRLO_RCVD);
+}
+
+
+
+/**
+ * Remote port implementation.
+ */
+
+/**
+ *  fcs_rport_api FCS rport API.
+ */
+
+/**
+ *     Direct API to add a target by port wwn. This interface is used, for
+ *     example, by bios when target pwwn is known from boot lun configuration.
+ */
+bfa_status_t
+bfa_fcs_rport_add(struct bfa_fcs_lport_s *port, wwn_t *pwwn,
+               struct bfa_fcs_rport_s *rport, struct bfad_rport_s *rport_drv)
+{
+       bfa_trc(port->fcs, *pwwn);
+
+       return BFA_STATUS_OK;
+}
+
+/**
+ *     Direct API to remove a target and its associated resources. This
+ *     interface is used, for example, by driver to remove target
+ *     ports from the target list for a VM.
+ */
+bfa_status_t
+bfa_fcs_rport_remove(struct bfa_fcs_rport_s *rport_in)
+{
+
+       struct bfa_fcs_rport_s *rport;
+
+       bfa_trc(rport_in->fcs, rport_in->pwwn);
+
+       rport = bfa_fcs_lport_get_rport_by_pwwn(rport_in->port, rport_in->pwwn);
+       if (rport == NULL) {
+               /*
+                * TBD Error handling
+                */
+               bfa_trc(rport_in->fcs, rport_in->pid);
+               return BFA_STATUS_UNKNOWN_RWWN;
+       }
+
+       /*
+        * TBD if this remote port is online, send a logo
+        */
+       return BFA_STATUS_OK;
+
+}
+
+/**
+ *     Remote device status for display/debug.
+ */
+void
+bfa_fcs_rport_get_attr(struct bfa_fcs_rport_s *rport,
+                       struct bfa_rport_attr_s *rport_attr)
+{
+       struct bfa_rport_qos_attr_s qos_attr;
+       bfa_fcs_lport_t *port = rport->port;
+       bfa_port_speed_t rport_speed = rport->rpf.rpsc_speed;
+
+       bfa_os_memset(rport_attr, 0, sizeof(struct bfa_rport_attr_s));
+
+       rport_attr->pid = rport->pid;
+       rport_attr->pwwn = rport->pwwn;
+       rport_attr->nwwn = rport->nwwn;
+       rport_attr->cos_supported = rport->fc_cos;
+       rport_attr->df_sz = rport->maxfrsize;
+       rport_attr->state = bfa_fcs_rport_get_state(rport);
+       rport_attr->fc_cos = rport->fc_cos;
+       rport_attr->cisc = rport->cisc;
+       rport_attr->scsi_function = rport->scsi_function;
+       rport_attr->curr_speed  = rport->rpf.rpsc_speed;
+       rport_attr->assigned_speed  = rport->rpf.assigned_speed;
+
+       bfa_rport_get_qos_attr(rport->bfa_rport, &qos_attr);
+       rport_attr->qos_attr = qos_attr;
+
+       rport_attr->trl_enforced = BFA_FALSE;
+       if (bfa_fcport_is_ratelim(port->fcs->bfa)) {
+               if (rport_speed == BFA_PORT_SPEED_UNKNOWN) {
+                       /* Use default ratelim speed setting */
+                       rport_speed =
+                               bfa_fcport_get_ratelim_speed(rport->fcs->bfa);
+               }
+
+               if (rport_speed < bfa_fcs_lport_get_rport_max_speed(port))
+                       rport_attr->trl_enforced = BFA_TRUE;
+       }
+}
+
+/**
+ *     Per remote device statistics.
+ */
+void
+bfa_fcs_rport_get_stats(struct bfa_fcs_rport_s *rport,
+                       struct bfa_rport_stats_s *stats)
+{
+       *stats = rport->stats;
+}
+
+void
+bfa_fcs_rport_clear_stats(struct bfa_fcs_rport_s *rport)
+{
+       bfa_os_memset((char *)&rport->stats, 0,
+                       sizeof(struct bfa_rport_stats_s));
+}
+
+struct bfa_fcs_rport_s *
+bfa_fcs_rport_lookup(struct bfa_fcs_lport_s *port, wwn_t rpwwn)
+{
+       struct bfa_fcs_rport_s *rport;
+
+       rport = bfa_fcs_lport_get_rport_by_pwwn(port, rpwwn);
+       if (rport == NULL) {
+               /*
+                * TBD Error handling
+                */
+       }
+
+       return rport;
+}
+
+struct bfa_fcs_rport_s *
+bfa_fcs_rport_lookup_by_nwwn(struct bfa_fcs_lport_s *port, wwn_t rnwwn)
+{
+       struct bfa_fcs_rport_s *rport;
+
+       rport = bfa_fcs_lport_get_rport_by_nwwn(port, rnwwn);
+       if (rport == NULL) {
+               /*
+                * TBD Error handling
+                */
+       }
+
+       return rport;
+}
+
+/*
+ * This API is to set the Rport's speed. Should be used when RPSC is not
+ * supported by the rport.
+ */
+void
+bfa_fcs_rport_set_speed(struct bfa_fcs_rport_s *rport, bfa_port_speed_t speed)
+{
+       rport->rpf.assigned_speed  = speed;
+
+       /* Set this speed in f/w only if the RPSC speed is not available */
+       if (rport->rpf.rpsc_speed == BFA_PORT_SPEED_UNKNOWN)
+               bfa_rport_speed(rport->bfa_rport, speed);
+}
+
+
+
+/**
+ * Remote port features (RPF) implementation.
+ */
+
+#define BFA_FCS_RPF_RETRIES    (3)
+#define BFA_FCS_RPF_RETRY_TIMEOUT  (1000) /* 1 sec (In millisecs) */
+
+static void     bfa_fcs_rpf_send_rpsc2(void *rport_cbarg,
+                               struct bfa_fcxp_s *fcxp_alloced);
+static void     bfa_fcs_rpf_rpsc2_response(void *fcsarg,
+                       struct bfa_fcxp_s *fcxp,
+                       void *cbarg,
+                       bfa_status_t req_status,
+                       u32 rsp_len,
+                       u32 resid_len,
+                       struct fchs_s *rsp_fchs);
+
+static void     bfa_fcs_rpf_timeout(void *arg);
+
+/**
+ *  fcs_rport_ftrs_sm FCS rport state machine events
+ */
+
+enum rpf_event {
+       RPFSM_EVENT_RPORT_OFFLINE  = 1, /* Rport offline                */
+       RPFSM_EVENT_RPORT_ONLINE   = 2, /* Rport online                 */
+       RPFSM_EVENT_FCXP_SENT      = 3, /* Frame from has been sent     */
+       RPFSM_EVENT_TIMEOUT        = 4, /* Rport SM timeout event       */
+       RPFSM_EVENT_RPSC_COMP      = 5,
+       RPFSM_EVENT_RPSC_FAIL      = 6,
+       RPFSM_EVENT_RPSC_ERROR     = 7,
+};
+
+static void    bfa_fcs_rpf_sm_uninit(struct bfa_fcs_rpf_s *rpf,
+                                       enum rpf_event event);
+static void     bfa_fcs_rpf_sm_rpsc_sending(struct bfa_fcs_rpf_s *rpf,
+                                      enum rpf_event event);
+static void     bfa_fcs_rpf_sm_rpsc(struct bfa_fcs_rpf_s *rpf,
+                                      enum rpf_event event);
+static void    bfa_fcs_rpf_sm_rpsc_retry(struct bfa_fcs_rpf_s *rpf,
+                                       enum rpf_event event);
+static void     bfa_fcs_rpf_sm_offline(struct bfa_fcs_rpf_s *rpf,
+                                       enum rpf_event event);
+static void     bfa_fcs_rpf_sm_online(struct bfa_fcs_rpf_s *rpf,
+                                       enum rpf_event event);
+
+static void
+bfa_fcs_rpf_sm_uninit(struct bfa_fcs_rpf_s *rpf, enum rpf_event event)
+{
+       struct bfa_fcs_rport_s *rport = rpf->rport;
+       struct bfa_fcs_fabric_s *fabric = &rport->fcs->fabric;
+
+       bfa_trc(rport->fcs, rport->pwwn);
+       bfa_trc(rport->fcs, rport->pid);
+       bfa_trc(rport->fcs, event);
+
+       switch (event) {
+       case RPFSM_EVENT_RPORT_ONLINE:
+               /* Send RPSC2 to a Brocade fabric only. */
+               if ((!BFA_FCS_PID_IS_WKA(rport->pid)) &&
+                       ((bfa_lps_is_brcd_fabric(rport->port->fabric->lps)) ||
+                       (bfa_fcs_fabric_get_switch_oui(fabric) ==
+                                               BFA_FCS_BRCD_SWITCH_OUI))) {
+                       bfa_sm_set_state(rpf, bfa_fcs_rpf_sm_rpsc_sending);
+                       rpf->rpsc_retries = 0;
+                       bfa_fcs_rpf_send_rpsc2(rpf, NULL);
+               }
+               break;
+
+       case RPFSM_EVENT_RPORT_OFFLINE:
+               break;
+
+       default:
+               bfa_sm_fault(rport->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_rpf_sm_rpsc_sending(struct bfa_fcs_rpf_s *rpf, enum rpf_event event)
+{
+       struct bfa_fcs_rport_s *rport = rpf->rport;
+
+       bfa_trc(rport->fcs, event);
+
+       switch (event) {
+       case RPFSM_EVENT_FCXP_SENT:
+               bfa_sm_set_state(rpf, bfa_fcs_rpf_sm_rpsc);
+               break;
+
+       case RPFSM_EVENT_RPORT_OFFLINE:
+               bfa_sm_set_state(rpf, bfa_fcs_rpf_sm_offline);
+               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rpf->fcxp_wqe);
+               rpf->rpsc_retries = 0;
+               break;
+
+       default:
+               bfa_sm_fault(rport->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_rpf_sm_rpsc(struct bfa_fcs_rpf_s *rpf, enum rpf_event event)
+{
+       struct bfa_fcs_rport_s *rport = rpf->rport;
+
+       bfa_trc(rport->fcs, rport->pid);
+       bfa_trc(rport->fcs, event);
+
+       switch (event) {
+       case RPFSM_EVENT_RPSC_COMP:
+               bfa_sm_set_state(rpf, bfa_fcs_rpf_sm_online);
+               /* Update speed info in f/w via BFA */
+               if (rpf->rpsc_speed != BFA_PORT_SPEED_UNKNOWN)
+                       bfa_rport_speed(rport->bfa_rport, rpf->rpsc_speed);
+               else if (rpf->assigned_speed != BFA_PORT_SPEED_UNKNOWN)
+                       bfa_rport_speed(rport->bfa_rport, rpf->assigned_speed);
+               break;
+
+       case RPFSM_EVENT_RPSC_FAIL:
+               /* RPSC not supported by rport */
+               bfa_sm_set_state(rpf, bfa_fcs_rpf_sm_online);
+               break;
+
+       case RPFSM_EVENT_RPSC_ERROR:
+               /* need to retry...delayed a bit. */
+               if (rpf->rpsc_retries++ < BFA_FCS_RPF_RETRIES) {
+                       bfa_timer_start(rport->fcs->bfa, &rpf->timer,
+                                   bfa_fcs_rpf_timeout, rpf,
+                                   BFA_FCS_RPF_RETRY_TIMEOUT);
+                       bfa_sm_set_state(rpf, bfa_fcs_rpf_sm_rpsc_retry);
+               } else {
+                       bfa_sm_set_state(rpf, bfa_fcs_rpf_sm_online);
+               }
+               break;
+
+       case RPFSM_EVENT_RPORT_OFFLINE:
+               bfa_sm_set_state(rpf, bfa_fcs_rpf_sm_offline);
+               bfa_fcxp_discard(rpf->fcxp);
+               rpf->rpsc_retries = 0;
+               break;
+
+       default:
+               bfa_sm_fault(rport->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_rpf_sm_rpsc_retry(struct bfa_fcs_rpf_s *rpf, enum rpf_event event)
+{
+       struct bfa_fcs_rport_s *rport = rpf->rport;
+
+       bfa_trc(rport->fcs, rport->pid);
+       bfa_trc(rport->fcs, event);
+
+       switch (event) {
+       case RPFSM_EVENT_TIMEOUT:
+               /* re-send the RPSC */
+               bfa_sm_set_state(rpf, bfa_fcs_rpf_sm_rpsc_sending);
+               bfa_fcs_rpf_send_rpsc2(rpf, NULL);
+               break;
+
+       case RPFSM_EVENT_RPORT_OFFLINE:
+               bfa_timer_stop(&rpf->timer);
+               bfa_sm_set_state(rpf, bfa_fcs_rpf_sm_offline);
+               rpf->rpsc_retries = 0;
+               break;
+
+       default:
+               bfa_sm_fault(rport->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_rpf_sm_online(struct bfa_fcs_rpf_s *rpf, enum rpf_event event)
+{
+       struct bfa_fcs_rport_s *rport = rpf->rport;
+
+       bfa_trc(rport->fcs, rport->pwwn);
+       bfa_trc(rport->fcs, rport->pid);
+       bfa_trc(rport->fcs, event);
+
+       switch (event) {
+       case RPFSM_EVENT_RPORT_OFFLINE:
+               bfa_sm_set_state(rpf, bfa_fcs_rpf_sm_offline);
+               rpf->rpsc_retries = 0;
+               break;
+
+       default:
+               bfa_sm_fault(rport->fcs, event);
+       }
+}
+
+static void
+bfa_fcs_rpf_sm_offline(struct bfa_fcs_rpf_s *rpf, enum rpf_event event)
+{
+       struct bfa_fcs_rport_s *rport = rpf->rport;
+
+       bfa_trc(rport->fcs, rport->pwwn);
+       bfa_trc(rport->fcs, rport->pid);
+       bfa_trc(rport->fcs, event);
+
+       switch (event) {
+       case RPFSM_EVENT_RPORT_ONLINE:
+               bfa_sm_set_state(rpf, bfa_fcs_rpf_sm_rpsc_sending);
+               bfa_fcs_rpf_send_rpsc2(rpf, NULL);
+               break;
+
+       case RPFSM_EVENT_RPORT_OFFLINE:
+               break;
+
+       default:
+               bfa_sm_fault(rport->fcs, event);
+       }
+}
+/**
+ * Called when Rport is created.
+ */
+void
+bfa_fcs_rpf_init(struct bfa_fcs_rport_s *rport)
+{
+       struct bfa_fcs_rpf_s *rpf = &rport->rpf;
+
+       bfa_trc(rport->fcs, rport->pid);
+       rpf->rport = rport;
+
+       bfa_sm_set_state(rpf, bfa_fcs_rpf_sm_uninit);
+}
+
+/**
+ * Called when Rport becomes online
+ */
+void
+bfa_fcs_rpf_rport_online(struct bfa_fcs_rport_s *rport)
+{
+       bfa_trc(rport->fcs, rport->pid);
+
+       if (__fcs_min_cfg(rport->port->fcs))
+               return;
+
+       if (bfa_fcs_fabric_is_switched(rport->port->fabric))
+               bfa_sm_send_event(&rport->rpf, RPFSM_EVENT_RPORT_ONLINE);
+}
+
+/**
+ * Called when Rport becomes offline
+ */
+void
+bfa_fcs_rpf_rport_offline(struct bfa_fcs_rport_s *rport)
+{
+       bfa_trc(rport->fcs, rport->pid);
+
+       if (__fcs_min_cfg(rport->port->fcs))
+               return;
+
+       rport->rpf.rpsc_speed = 0;
+       bfa_sm_send_event(&rport->rpf, RPFSM_EVENT_RPORT_OFFLINE);
+}
+
+static void
+bfa_fcs_rpf_timeout(void *arg)
+{
+       struct bfa_fcs_rpf_s *rpf = (struct bfa_fcs_rpf_s *) arg;
+       struct bfa_fcs_rport_s *rport = rpf->rport;
+
+       bfa_trc(rport->fcs, rport->pid);
+       bfa_sm_send_event(rpf, RPFSM_EVENT_TIMEOUT);
+}
+
+static void
+bfa_fcs_rpf_send_rpsc2(void *rpf_cbarg, struct bfa_fcxp_s *fcxp_alloced)
+{
+       struct bfa_fcs_rpf_s *rpf = (struct bfa_fcs_rpf_s *)rpf_cbarg;
+       struct bfa_fcs_rport_s *rport = rpf->rport;
+       struct bfa_fcs_lport_s *port = rport->port;
+       struct fchs_s   fchs;
+       int             len;
+       struct bfa_fcxp_s *fcxp;
+
+       bfa_trc(rport->fcs, rport->pwwn);
+
+       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
+       if (!fcxp) {
+               bfa_fcs_fcxp_alloc_wait(port->fcs->bfa, &rpf->fcxp_wqe,
+                                       bfa_fcs_rpf_send_rpsc2, rpf);
+               return;
+       }
+       rpf->fcxp = fcxp;
+
+       len = fc_rpsc2_build(&fchs, bfa_fcxp_get_reqbuf(fcxp), rport->pid,
+                           bfa_fcs_lport_get_fcid(port), &rport->pid, 1);
+
+       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
+                         FC_CLASS_3, len, &fchs, bfa_fcs_rpf_rpsc2_response,
+                         rpf, FC_MAX_PDUSZ, FC_ELS_TOV);
+       rport->stats.rpsc_sent++;
+       bfa_sm_send_event(rpf, RPFSM_EVENT_FCXP_SENT);
+
+}
+
+static void
+bfa_fcs_rpf_rpsc2_response(void *fcsarg, struct bfa_fcxp_s *fcxp, void *cbarg,
+                           bfa_status_t req_status, u32 rsp_len,
+                           u32 resid_len, struct fchs_s *rsp_fchs)
+{
+       struct bfa_fcs_rpf_s *rpf = (struct bfa_fcs_rpf_s *) cbarg;
+       struct bfa_fcs_rport_s *rport = rpf->rport;
+       struct fc_ls_rjt_s *ls_rjt;
+       struct fc_rpsc2_acc_s *rpsc2_acc;
+       u16     num_ents;
+
+       bfa_trc(rport->fcs, req_status);
+
+       if (req_status != BFA_STATUS_OK) {
+               bfa_trc(rport->fcs, req_status);
+               if (req_status == BFA_STATUS_ETIMER)
+                       rport->stats.rpsc_failed++;
+               bfa_sm_send_event(rpf, RPFSM_EVENT_RPSC_ERROR);
+               return;
+       }
+
+       rpsc2_acc = (struct fc_rpsc2_acc_s *) BFA_FCXP_RSP_PLD(fcxp);
+       if (rpsc2_acc->els_cmd == FC_ELS_ACC) {
+               rport->stats.rpsc_accs++;
+               num_ents = bfa_os_ntohs(rpsc2_acc->num_pids);
+               bfa_trc(rport->fcs, num_ents);
+               if (num_ents > 0) {
+                       bfa_assert(rpsc2_acc->port_info[0].pid != rport->pid);
+                       bfa_trc(rport->fcs,
+                               bfa_os_ntohs(rpsc2_acc->port_info[0].pid));
+                       bfa_trc(rport->fcs,
+                               bfa_os_ntohs(rpsc2_acc->port_info[0].speed));
+                       bfa_trc(rport->fcs,
+                               bfa_os_ntohs(rpsc2_acc->port_info[0].index));
+                       bfa_trc(rport->fcs,
+                               rpsc2_acc->port_info[0].type);
+
+                       if (rpsc2_acc->port_info[0].speed == 0) {
+                               bfa_sm_send_event(rpf, RPFSM_EVENT_RPSC_ERROR);
+                               return;
+                       }
+
+                       rpf->rpsc_speed = fc_rpsc_operspeed_to_bfa_speed(
+                               bfa_os_ntohs(rpsc2_acc->port_info[0].speed));
+
+                       bfa_sm_send_event(rpf, RPFSM_EVENT_RPSC_COMP);
+               }
+       } else {
+               ls_rjt = (struct fc_ls_rjt_s *) BFA_FCXP_RSP_PLD(fcxp);
+               bfa_trc(rport->fcs, ls_rjt->reason_code);
+               bfa_trc(rport->fcs, ls_rjt->reason_code_expl);
+               rport->stats.rpsc_rejects++;
+               if (ls_rjt->reason_code == FC_LS_RJT_RSN_CMD_NOT_SUPP)
+                       bfa_sm_send_event(rpf, RPFSM_EVENT_RPSC_FAIL);
+               else
+                       bfa_sm_send_event(rpf, RPFSM_EVENT_RPSC_ERROR);
+       }
+}
diff --git a/drivers/scsi/bfa/bfa_fcs_uf.c b/drivers/scsi/bfa/bfa_fcs_uf.c
deleted file mode 100644 (file)
index 3d57d48..0000000
+++ /dev/null
@@ -1,99 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  bfa_fcs_uf.c BFA FCS UF ( Unsolicited Frames)
- */
-
-#include <fcs/bfa_fcs.h>
-#include <bfa_svc.h>
-#include <fcs/bfa_fcs_fabric.h>
-#include "fcs.h"
-#include "fcs_trcmod.h"
-#include "fcs_fabric.h"
-#include "fcs_uf.h"
-
-BFA_TRC_FILE(FCS, UF);
-
-/**
- *             BFA callback for unsolicited frame receive handler.
- *
- * @param[in]          cbarg           callback arg for receive handler
- * @param[in]          uf              unsolicited frame descriptor
- *
- * @return None
- */
-static void
-bfa_fcs_uf_recv(void *cbarg, struct bfa_uf_s *uf)
-{
-       struct bfa_fcs_s      *fcs = (struct bfa_fcs_s *) cbarg;
-       struct fchs_s         *fchs = bfa_uf_get_frmbuf(uf);
-       u16        len = bfa_uf_get_frmlen(uf);
-       struct fc_vft_s       *vft;
-       struct bfa_fcs_fabric_s *fabric;
-
-       /**
-        * check for VFT header
-        */
-       if (fchs->routing == FC_RTG_EXT_HDR &&
-               fchs->cat_info == FC_CAT_VFT_HDR) {
-               bfa_stats(fcs, uf.tagged);
-               vft = bfa_uf_get_frmbuf(uf);
-               if (fcs->port_vfid == vft->vf_id)
-                       fabric = &fcs->fabric;
-               else
-                       fabric = bfa_fcs_vf_lookup(fcs, (u16) vft->vf_id);
-
-               /**
-                * drop frame if vfid is unknown
-                */
-               if (!fabric) {
-                       bfa_assert(0);
-                       bfa_stats(fcs, uf.vfid_unknown);
-                       bfa_uf_free(uf);
-                       return;
-               }
-
-               /**
-                * skip vft header
-                */
-               fchs = (struct fchs_s *) (vft + 1);
-               len -= sizeof(struct fc_vft_s);
-
-               bfa_trc(fcs, vft->vf_id);
-       } else {
-               bfa_stats(fcs, uf.untagged);
-               fabric = &fcs->fabric;
-       }
-
-       bfa_trc(fcs, ((u32 *) fchs)[0]);
-       bfa_trc(fcs, ((u32 *) fchs)[1]);
-       bfa_trc(fcs, ((u32 *) fchs)[2]);
-       bfa_trc(fcs, ((u32 *) fchs)[3]);
-       bfa_trc(fcs, ((u32 *) fchs)[4]);
-       bfa_trc(fcs, ((u32 *) fchs)[5]);
-       bfa_trc(fcs, len);
-
-       bfa_fcs_fabric_uf_recv(fabric, fchs, len);
-       bfa_uf_free(uf);
-}
-
-void
-bfa_fcs_uf_attach(struct bfa_fcs_s *fcs)
-{
-       bfa_uf_recv_register(fcs->bfa, bfa_fcs_uf_recv, fcs);
-}
diff --git a/drivers/scsi/bfa/bfa_fcxp.c b/drivers/scsi/bfa/bfa_fcxp.c
deleted file mode 100644 (file)
index 8258f88..0000000
+++ /dev/null
@@ -1,774 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#include <bfa.h>
-#include <bfi/bfi_uf.h>
-#include <cs/bfa_debug.h>
-
-BFA_TRC_FILE(HAL, FCXP);
-BFA_MODULE(fcxp);
-
-/**
- * forward declarations
- */
-static void     __bfa_fcxp_send_cbfn(void *cbarg, bfa_boolean_t complete);
-static void     hal_fcxp_rx_plog(struct bfa_s *bfa, struct bfa_fcxp_s *fcxp,
-                                struct bfi_fcxp_send_rsp_s *fcxp_rsp);
-static void     hal_fcxp_tx_plog(struct bfa_s *bfa, u32 reqlen,
-                                struct bfa_fcxp_s *fcxp, struct fchs_s *fchs);
-static void    bfa_fcxp_qresume(void *cbarg);
-static void    bfa_fcxp_queue(struct bfa_fcxp_s *fcxp,
-                              struct bfi_fcxp_send_req_s *send_req);
-
-/**
- *  fcxp_pvt BFA FCXP private functions
- */
-
-static void
-claim_fcxp_req_rsp_mem(struct bfa_fcxp_mod_s *mod, struct bfa_meminfo_s *mi)
-{
-       u8        *dm_kva = NULL;
-       u64        dm_pa;
-       u32        buf_pool_sz;
-
-       dm_kva = bfa_meminfo_dma_virt(mi);
-       dm_pa = bfa_meminfo_dma_phys(mi);
-
-       buf_pool_sz = mod->req_pld_sz * mod->num_fcxps;
-
-       /*
-        * Initialize the fcxp req payload list
-        */
-       mod->req_pld_list_kva = dm_kva;
-       mod->req_pld_list_pa = dm_pa;
-       dm_kva += buf_pool_sz;
-       dm_pa += buf_pool_sz;
-       bfa_os_memset(mod->req_pld_list_kva, 0, buf_pool_sz);
-
-       /*
-        * Initialize the fcxp rsp payload list
-        */
-       buf_pool_sz = mod->rsp_pld_sz * mod->num_fcxps;
-       mod->rsp_pld_list_kva = dm_kva;
-       mod->rsp_pld_list_pa = dm_pa;
-       dm_kva += buf_pool_sz;
-       dm_pa += buf_pool_sz;
-       bfa_os_memset(mod->rsp_pld_list_kva, 0, buf_pool_sz);
-
-       bfa_meminfo_dma_virt(mi) = dm_kva;
-       bfa_meminfo_dma_phys(mi) = dm_pa;
-}
-
-static void
-claim_fcxps_mem(struct bfa_fcxp_mod_s *mod, struct bfa_meminfo_s *mi)
-{
-       u16        i;
-       struct bfa_fcxp_s *fcxp;
-
-       fcxp = (struct bfa_fcxp_s *) bfa_meminfo_kva(mi);
-       bfa_os_memset(fcxp, 0, sizeof(struct bfa_fcxp_s) * mod->num_fcxps);
-
-       INIT_LIST_HEAD(&mod->fcxp_free_q);
-       INIT_LIST_HEAD(&mod->fcxp_active_q);
-
-       mod->fcxp_list = fcxp;
-
-       for (i = 0; i < mod->num_fcxps; i++) {
-               fcxp->fcxp_mod = mod;
-               fcxp->fcxp_tag = i;
-
-               list_add_tail(&fcxp->qe, &mod->fcxp_free_q);
-               bfa_reqq_winit(&fcxp->reqq_wqe, bfa_fcxp_qresume, fcxp);
-               fcxp->reqq_waiting = BFA_FALSE;
-
-               fcxp = fcxp + 1;
-       }
-
-       bfa_meminfo_kva(mi) = (void *)fcxp;
-}
-
-static void
-bfa_fcxp_meminfo(struct bfa_iocfc_cfg_s *cfg, u32 *ndm_len,
-               u32 *dm_len)
-{
-       u16        num_fcxp_reqs = cfg->fwcfg.num_fcxp_reqs;
-
-       if (num_fcxp_reqs == 0)
-               return;
-
-       /*
-        * Account for req/rsp payload
-        */
-       *dm_len += BFA_FCXP_MAX_IBUF_SZ * num_fcxp_reqs;
-       if (cfg->drvcfg.min_cfg)
-               *dm_len += BFA_FCXP_MAX_IBUF_SZ * num_fcxp_reqs;
-       else
-               *dm_len += BFA_FCXP_MAX_LBUF_SZ * num_fcxp_reqs;
-
-       /*
-        * Account for fcxp structs
-        */
-       *ndm_len += sizeof(struct bfa_fcxp_s) * num_fcxp_reqs;
-}
-
-static void
-bfa_fcxp_attach(struct bfa_s *bfa, void *bfad, struct bfa_iocfc_cfg_s *cfg,
-                   struct bfa_meminfo_s *meminfo, struct bfa_pcidev_s *pcidev)
-{
-       struct bfa_fcxp_mod_s *mod = BFA_FCXP_MOD(bfa);
-
-       bfa_os_memset(mod, 0, sizeof(struct bfa_fcxp_mod_s));
-       mod->bfa = bfa;
-       mod->num_fcxps = cfg->fwcfg.num_fcxp_reqs;
-
-       /**
-        * Initialize FCXP request and response payload sizes.
-        */
-       mod->req_pld_sz = mod->rsp_pld_sz = BFA_FCXP_MAX_IBUF_SZ;
-       if (!cfg->drvcfg.min_cfg)
-               mod->rsp_pld_sz = BFA_FCXP_MAX_LBUF_SZ;
-
-       INIT_LIST_HEAD(&mod->wait_q);
-
-       claim_fcxp_req_rsp_mem(mod, meminfo);
-       claim_fcxps_mem(mod, meminfo);
-}
-
-static void
-bfa_fcxp_detach(struct bfa_s *bfa)
-{
-}
-
-static void
-bfa_fcxp_start(struct bfa_s *bfa)
-{
-}
-
-static void
-bfa_fcxp_stop(struct bfa_s *bfa)
-{
-}
-
-static void
-bfa_fcxp_iocdisable(struct bfa_s *bfa)
-{
-       struct bfa_fcxp_mod_s *mod = BFA_FCXP_MOD(bfa);
-       struct bfa_fcxp_s *fcxp;
-       struct list_head        *qe, *qen;
-
-       list_for_each_safe(qe, qen, &mod->fcxp_active_q) {
-               fcxp = (struct bfa_fcxp_s *) qe;
-               if (fcxp->caller == NULL) {
-                       fcxp->send_cbfn(fcxp->caller, fcxp, fcxp->send_cbarg,
-                                       BFA_STATUS_IOC_FAILURE, 0, 0, NULL);
-                       bfa_fcxp_free(fcxp);
-               } else {
-                       fcxp->rsp_status = BFA_STATUS_IOC_FAILURE;
-                       bfa_cb_queue(bfa, &fcxp->hcb_qe,
-                                     __bfa_fcxp_send_cbfn, fcxp);
-               }
-       }
-}
-
-static struct bfa_fcxp_s *
-bfa_fcxp_get(struct bfa_fcxp_mod_s *fm)
-{
-       struct bfa_fcxp_s *fcxp;
-
-       bfa_q_deq(&fm->fcxp_free_q, &fcxp);
-
-       if (fcxp)
-               list_add_tail(&fcxp->qe, &fm->fcxp_active_q);
-
-       return fcxp;
-}
-
-static void
-bfa_fcxp_put(struct bfa_fcxp_s *fcxp)
-{
-       struct bfa_fcxp_mod_s *mod = fcxp->fcxp_mod;
-       struct bfa_fcxp_wqe_s *wqe;
-
-       bfa_q_deq(&mod->wait_q, &wqe);
-       if (wqe) {
-               bfa_trc(mod->bfa, fcxp->fcxp_tag);
-               wqe->alloc_cbfn(wqe->alloc_cbarg, fcxp);
-               return;
-       }
-
-       bfa_assert(bfa_q_is_on_q(&mod->fcxp_active_q, fcxp));
-       list_del(&fcxp->qe);
-       list_add_tail(&fcxp->qe, &mod->fcxp_free_q);
-}
-
-static void
-bfa_fcxp_null_comp(void *bfad_fcxp, struct bfa_fcxp_s *fcxp, void *cbarg,
-                      bfa_status_t req_status, u32 rsp_len,
-                      u32 resid_len, struct fchs_s *rsp_fchs)
-{
-       /* discarded fcxp completion */
-}
-
-static void
-__bfa_fcxp_send_cbfn(void *cbarg, bfa_boolean_t complete)
-{
-       struct bfa_fcxp_s *fcxp = cbarg;
-
-       if (complete) {
-               fcxp->send_cbfn(fcxp->caller, fcxp, fcxp->send_cbarg,
-                               fcxp->rsp_status, fcxp->rsp_len,
-                               fcxp->residue_len, &fcxp->rsp_fchs);
-       } else {
-               bfa_fcxp_free(fcxp);
-       }
-}
-
-static void
-hal_fcxp_send_comp(struct bfa_s *bfa, struct bfi_fcxp_send_rsp_s *fcxp_rsp)
-{
-       struct bfa_fcxp_mod_s   *mod = BFA_FCXP_MOD(bfa);
-       struct bfa_fcxp_s       *fcxp;
-       u16             fcxp_tag = bfa_os_ntohs(fcxp_rsp->fcxp_tag);
-
-       bfa_trc(bfa, fcxp_tag);
-
-       fcxp_rsp->rsp_len = bfa_os_ntohl(fcxp_rsp->rsp_len);
-
-       /**
-        * @todo f/w should not set residue to non-0 when everything
-        *       is received.
-        */
-       if (fcxp_rsp->req_status == BFA_STATUS_OK)
-               fcxp_rsp->residue_len = 0;
-       else
-               fcxp_rsp->residue_len = bfa_os_ntohl(fcxp_rsp->residue_len);
-
-       fcxp = BFA_FCXP_FROM_TAG(mod, fcxp_tag);
-
-       bfa_assert(fcxp->send_cbfn != NULL);
-
-       hal_fcxp_rx_plog(mod->bfa, fcxp, fcxp_rsp);
-
-       if (fcxp->send_cbfn != NULL) {
-               if (fcxp->caller == NULL) {
-                       bfa_trc(mod->bfa, fcxp->fcxp_tag);
-
-                       fcxp->send_cbfn(fcxp->caller, fcxp, fcxp->send_cbarg,
-                                       fcxp_rsp->req_status, fcxp_rsp->rsp_len,
-                                       fcxp_rsp->residue_len, &fcxp_rsp->fchs);
-                       /*
-                        * fcxp automatically freed on return from the callback
-                        */
-                       bfa_fcxp_free(fcxp);
-               } else {
-                       bfa_trc(mod->bfa, fcxp->fcxp_tag);
-                       fcxp->rsp_status = fcxp_rsp->req_status;
-                       fcxp->rsp_len = fcxp_rsp->rsp_len;
-                       fcxp->residue_len = fcxp_rsp->residue_len;
-                       fcxp->rsp_fchs = fcxp_rsp->fchs;
-
-                       bfa_cb_queue(bfa, &fcxp->hcb_qe,
-                                     __bfa_fcxp_send_cbfn, fcxp);
-               }
-       } else {
-               bfa_trc(bfa, fcxp_tag);
-       }
-}
-
-static void
-hal_fcxp_set_local_sges(struct bfi_sge_s *sge, u32 reqlen, u64 req_pa)
-{
-       union bfi_addr_u      sga_zero = { {0} };
-
-       sge->sg_len = reqlen;
-       sge->flags = BFI_SGE_DATA_LAST;
-       bfa_dma_addr_set(sge[0].sga, req_pa);
-       bfa_sge_to_be(sge);
-       sge++;
-
-       sge->sga = sga_zero;
-       sge->sg_len = reqlen;
-       sge->flags = BFI_SGE_PGDLEN;
-       bfa_sge_to_be(sge);
-}
-
-static void
-hal_fcxp_tx_plog(struct bfa_s *bfa, u32 reqlen, struct bfa_fcxp_s *fcxp,
-                struct fchs_s *fchs)
-{
-       /*
-        * TODO: TX ox_id
-        */
-       if (reqlen > 0) {
-               if (fcxp->use_ireqbuf) {
-                       u32        pld_w0 =
-                               *((u32 *) BFA_FCXP_REQ_PLD(fcxp));
-
-                       bfa_plog_fchdr_and_pl(bfa->plog, BFA_PL_MID_HAL_FCXP,
-                               BFA_PL_EID_TX,
-                               reqlen + sizeof(struct fchs_s), fchs, pld_w0);
-               } else {
-                       bfa_plog_fchdr(bfa->plog, BFA_PL_MID_HAL_FCXP,
-                               BFA_PL_EID_TX, reqlen + sizeof(struct fchs_s),
-                               fchs);
-               }
-       } else {
-               bfa_plog_fchdr(bfa->plog, BFA_PL_MID_HAL_FCXP, BFA_PL_EID_TX,
-                              reqlen + sizeof(struct fchs_s), fchs);
-       }
-}
-
-static void
-hal_fcxp_rx_plog(struct bfa_s *bfa, struct bfa_fcxp_s *fcxp,
-                struct bfi_fcxp_send_rsp_s *fcxp_rsp)
-{
-       if (fcxp_rsp->rsp_len > 0) {
-               if (fcxp->use_irspbuf) {
-                       u32        pld_w0 =
-                               *((u32 *) BFA_FCXP_RSP_PLD(fcxp));
-
-                       bfa_plog_fchdr_and_pl(bfa->plog, BFA_PL_MID_HAL_FCXP,
-                                             BFA_PL_EID_RX,
-                                             (u16) fcxp_rsp->rsp_len,
-                                             &fcxp_rsp->fchs, pld_w0);
-               } else {
-                       bfa_plog_fchdr(bfa->plog, BFA_PL_MID_HAL_FCXP,
-                                      BFA_PL_EID_RX,
-                                      (u16) fcxp_rsp->rsp_len,
-                                      &fcxp_rsp->fchs);
-               }
-       } else {
-               bfa_plog_fchdr(bfa->plog, BFA_PL_MID_HAL_FCXP, BFA_PL_EID_RX,
-                              (u16) fcxp_rsp->rsp_len, &fcxp_rsp->fchs);
-       }
-}
-
-/**
- * Handler to resume sending fcxp when space in available in cpe queue.
- */
-static void
-bfa_fcxp_qresume(void *cbarg)
-{
-       struct bfa_fcxp_s               *fcxp = cbarg;
-       struct bfa_s                    *bfa = fcxp->fcxp_mod->bfa;
-       struct bfi_fcxp_send_req_s      *send_req;
-
-       fcxp->reqq_waiting = BFA_FALSE;
-       send_req = bfa_reqq_next(bfa, BFA_REQQ_FCXP);
-       bfa_fcxp_queue(fcxp, send_req);
-}
-
-/**
- * Queue fcxp send request to foimrware.
- */
-static void
-bfa_fcxp_queue(struct bfa_fcxp_s *fcxp, struct bfi_fcxp_send_req_s *send_req)
-{
-       struct bfa_s                    *bfa = fcxp->fcxp_mod->bfa;
-       struct bfa_fcxp_req_info_s      *reqi = &fcxp->req_info;
-       struct bfa_fcxp_rsp_info_s      *rspi = &fcxp->rsp_info;
-       struct bfa_rport_s              *rport = reqi->bfa_rport;
-
-       bfi_h2i_set(send_req->mh, BFI_MC_FCXP, BFI_FCXP_H2I_SEND_REQ,
-                       bfa_lpuid(bfa));
-
-       send_req->fcxp_tag = bfa_os_htons(fcxp->fcxp_tag);
-       if (rport) {
-               send_req->rport_fw_hndl = rport->fw_handle;
-               send_req->max_frmsz = bfa_os_htons(rport->rport_info.max_frmsz);
-               if (send_req->max_frmsz == 0)
-                       send_req->max_frmsz = bfa_os_htons(FC_MAX_PDUSZ);
-       } else {
-               send_req->rport_fw_hndl = 0;
-               send_req->max_frmsz = bfa_os_htons(FC_MAX_PDUSZ);
-       }
-
-       send_req->vf_id = bfa_os_htons(reqi->vf_id);
-       send_req->lp_tag = reqi->lp_tag;
-       send_req->class = reqi->class;
-       send_req->rsp_timeout = rspi->rsp_timeout;
-       send_req->cts = reqi->cts;
-       send_req->fchs = reqi->fchs;
-
-       send_req->req_len = bfa_os_htonl(reqi->req_tot_len);
-       send_req->rsp_maxlen = bfa_os_htonl(rspi->rsp_maxlen);
-
-       /*
-        * setup req sgles
-        */
-       if (fcxp->use_ireqbuf == 1) {
-               hal_fcxp_set_local_sges(send_req->req_sge, reqi->req_tot_len,
-                                       BFA_FCXP_REQ_PLD_PA(fcxp));
-       } else {
-               if (fcxp->nreq_sgles > 0) {
-                       bfa_assert(fcxp->nreq_sgles == 1);
-                       hal_fcxp_set_local_sges(send_req->req_sge,
-                                               reqi->req_tot_len,
-                                               fcxp->req_sga_cbfn(fcxp->caller,
-                                                                  0));
-               } else {
-                       bfa_assert(reqi->req_tot_len == 0);
-                       hal_fcxp_set_local_sges(send_req->rsp_sge, 0, 0);
-               }
-       }
-
-       /*
-        * setup rsp sgles
-        */
-       if (fcxp->use_irspbuf == 1) {
-               bfa_assert(rspi->rsp_maxlen <= BFA_FCXP_MAX_LBUF_SZ);
-
-               hal_fcxp_set_local_sges(send_req->rsp_sge, rspi->rsp_maxlen,
-                                       BFA_FCXP_RSP_PLD_PA(fcxp));
-
-       } else {
-               if (fcxp->nrsp_sgles > 0) {
-                       bfa_assert(fcxp->nrsp_sgles == 1);
-                       hal_fcxp_set_local_sges(send_req->rsp_sge,
-                                               rspi->rsp_maxlen,
-                                               fcxp->rsp_sga_cbfn(fcxp->caller,
-                                                                  0));
-               } else {
-                       bfa_assert(rspi->rsp_maxlen == 0);
-                       hal_fcxp_set_local_sges(send_req->rsp_sge, 0, 0);
-               }
-       }
-
-       hal_fcxp_tx_plog(bfa, reqi->req_tot_len, fcxp, &reqi->fchs);
-
-       bfa_reqq_produce(bfa, BFA_REQQ_FCXP);
-
-       bfa_trc(bfa, bfa_reqq_pi(bfa, BFA_REQQ_FCXP));
-       bfa_trc(bfa, bfa_reqq_ci(bfa, BFA_REQQ_FCXP));
-}
-
-
-/**
- *  hal_fcxp_api BFA FCXP API
- */
-
-/**
- * Allocate an FCXP instance to send a response or to send a request
- * that has a response. Request/response buffers are allocated by caller.
- *
- * @param[in]  bfa             BFA bfa instance
- * @param[in]  nreq_sgles      Number of SG elements required for request
- *                             buffer. 0, if fcxp internal buffers are used.
- *                             Use bfa_fcxp_get_reqbuf() to get the
- *                             internal req buffer.
- * @param[in]  req_sgles       SG elements describing request buffer. Will be
- *                             copied in by BFA and hence can be freed on
- *                             return from this function.
- * @param[in]  get_req_sga     function ptr to be called to get a request SG
- *                             Address (given the sge index).
- * @param[in]  get_req_sglen   function ptr to be called to get a request SG
- *                             len (given the sge index).
- * @param[in]  get_rsp_sga     function ptr to be called to get a response SG
- *                             Address (given the sge index).
- * @param[in]  get_rsp_sglen   function ptr to be called to get a response SG
- *                             len (given the sge index).
- *
- * @return FCXP instance. NULL on failure.
- */
-struct bfa_fcxp_s *
-bfa_fcxp_alloc(void *caller, struct bfa_s *bfa, int nreq_sgles,
-                       int nrsp_sgles, bfa_fcxp_get_sgaddr_t req_sga_cbfn,
-                       bfa_fcxp_get_sglen_t req_sglen_cbfn,
-                       bfa_fcxp_get_sgaddr_t rsp_sga_cbfn,
-                       bfa_fcxp_get_sglen_t rsp_sglen_cbfn)
-{
-       struct bfa_fcxp_s *fcxp = NULL;
-       u32        nreq_sgpg, nrsp_sgpg;
-
-       bfa_assert(bfa != NULL);
-
-       fcxp = bfa_fcxp_get(BFA_FCXP_MOD(bfa));
-       if (fcxp == NULL)
-               return NULL;
-
-       bfa_trc(bfa, fcxp->fcxp_tag);
-
-       fcxp->caller = caller;
-
-       if (nreq_sgles == 0) {
-               fcxp->use_ireqbuf = 1;
-       } else {
-               bfa_assert(req_sga_cbfn != NULL);
-               bfa_assert(req_sglen_cbfn != NULL);
-
-               fcxp->use_ireqbuf = 0;
-               fcxp->req_sga_cbfn = req_sga_cbfn;
-               fcxp->req_sglen_cbfn = req_sglen_cbfn;
-
-               fcxp->nreq_sgles = nreq_sgles;
-
-               /*
-                * alloc required sgpgs
-                */
-               if (nreq_sgles > BFI_SGE_INLINE) {
-                       nreq_sgpg = BFA_SGPG_NPAGE(nreq_sgles);
-
-                       if (bfa_sgpg_malloc(bfa, &fcxp->req_sgpg_q, nreq_sgpg)
-                           != BFA_STATUS_OK) {
-                               /*
-                                * TODO
-                                */
-                       }
-               }
-       }
-
-       if (nrsp_sgles == 0) {
-               fcxp->use_irspbuf = 1;
-       } else {
-               bfa_assert(rsp_sga_cbfn != NULL);
-               bfa_assert(rsp_sglen_cbfn != NULL);
-
-               fcxp->use_irspbuf = 0;
-               fcxp->rsp_sga_cbfn = rsp_sga_cbfn;
-               fcxp->rsp_sglen_cbfn = rsp_sglen_cbfn;
-
-               fcxp->nrsp_sgles = nrsp_sgles;
-               /*
-                * alloc required sgpgs
-                */
-               if (nrsp_sgles > BFI_SGE_INLINE) {
-                       nrsp_sgpg = BFA_SGPG_NPAGE(nreq_sgles);
-
-                       if (bfa_sgpg_malloc
-                           (bfa, &fcxp->rsp_sgpg_q, nrsp_sgpg)
-                           != BFA_STATUS_OK) {
-                               /* bfa_sgpg_wait(bfa, &fcxp->rsp_sgpg_wqe,
-                               nrsp_sgpg); */
-                               /*
-                                * TODO
-                                */
-                       }
-               }
-       }
-
-       return fcxp;
-}
-
-/**
- * Get the internal request buffer pointer
- *
- * @param[in]  fcxp    BFA fcxp pointer
- *
- * @return             pointer to the internal request buffer
- */
-void *
-bfa_fcxp_get_reqbuf(struct bfa_fcxp_s *fcxp)
-{
-       struct bfa_fcxp_mod_s *mod = fcxp->fcxp_mod;
-       void    *reqbuf;
-
-       bfa_assert(fcxp->use_ireqbuf == 1);
-       reqbuf = ((u8 *)mod->req_pld_list_kva) +
-                       fcxp->fcxp_tag * mod->req_pld_sz;
-       return reqbuf;
-}
-
-u32
-bfa_fcxp_get_reqbufsz(struct bfa_fcxp_s *fcxp)
-{
-       struct bfa_fcxp_mod_s *mod = fcxp->fcxp_mod;
-
-       return mod->req_pld_sz;
-}
-
-/**
- * Get the internal response buffer pointer
- *
- * @param[in]  fcxp    BFA fcxp pointer
- *
- * @return             pointer to the internal request buffer
- */
-void *
-bfa_fcxp_get_rspbuf(struct bfa_fcxp_s *fcxp)
-{
-       struct bfa_fcxp_mod_s *mod = fcxp->fcxp_mod;
-       void    *rspbuf;
-
-       bfa_assert(fcxp->use_irspbuf == 1);
-
-       rspbuf = ((u8 *)mod->rsp_pld_list_kva) +
-                       fcxp->fcxp_tag * mod->rsp_pld_sz;
-       return rspbuf;
-}
-
-/**
- *             Free the BFA FCXP
- *
- * @param[in]  fcxp                    BFA fcxp pointer
- *
- * @return             void
- */
-void
-bfa_fcxp_free(struct bfa_fcxp_s *fcxp)
-{
-       struct bfa_fcxp_mod_s *mod = fcxp->fcxp_mod;
-
-       bfa_assert(fcxp != NULL);
-       bfa_trc(mod->bfa, fcxp->fcxp_tag);
-       bfa_fcxp_put(fcxp);
-}
-
-/**
- * Send a FCXP request
- *
- * @param[in]  fcxp    BFA fcxp pointer
- * @param[in]  rport   BFA rport pointer. Could be left NULL for WKA rports
- * @param[in]  vf_id   virtual Fabric ID
- * @param[in]  lp_tag  lport tag
- * @param[in]  cts     use Continous sequence
- * @param[in]  cos     fc Class of Service
- * @param[in]  reqlen  request length, does not include FCHS length
- * @param[in]  fchs    fc Header Pointer. The header content will be copied
- *                     in by BFA.
- *
- * @param[in]  cbfn    call back function to be called on receiving
- *                                                             the response
- * @param[in]  cbarg   arg for cbfn
- * @param[in]  rsp_timeout
- *                     response timeout
- *
- * @return             bfa_status_t
- */
-void
-bfa_fcxp_send(struct bfa_fcxp_s *fcxp, struct bfa_rport_s *rport,
-               u16 vf_id, u8 lp_tag, bfa_boolean_t cts, enum fc_cos cos,
-               u32 reqlen, struct fchs_s *fchs, bfa_cb_fcxp_send_t cbfn,
-               void *cbarg, u32 rsp_maxlen, u8 rsp_timeout)
-{
-       struct bfa_s                    *bfa  = fcxp->fcxp_mod->bfa;
-       struct bfa_fcxp_req_info_s      *reqi = &fcxp->req_info;
-       struct bfa_fcxp_rsp_info_s      *rspi = &fcxp->rsp_info;
-       struct bfi_fcxp_send_req_s      *send_req;
-
-       bfa_trc(bfa, fcxp->fcxp_tag);
-
-       /**
-        * setup request/response info
-        */
-       reqi->bfa_rport = rport;
-       reqi->vf_id = vf_id;
-       reqi->lp_tag = lp_tag;
-       reqi->class = cos;
-       rspi->rsp_timeout = rsp_timeout;
-       reqi->cts = cts;
-       reqi->fchs = *fchs;
-       reqi->req_tot_len = reqlen;
-       rspi->rsp_maxlen = rsp_maxlen;
-       fcxp->send_cbfn = cbfn ? cbfn : bfa_fcxp_null_comp;
-       fcxp->send_cbarg = cbarg;
-
-       /**
-        * If no room in CPE queue, wait for space in request queue
-        */
-       send_req = bfa_reqq_next(bfa, BFA_REQQ_FCXP);
-       if (!send_req) {
-               bfa_trc(bfa, fcxp->fcxp_tag);
-               fcxp->reqq_waiting = BFA_TRUE;
-               bfa_reqq_wait(bfa, BFA_REQQ_FCXP, &fcxp->reqq_wqe);
-               return;
-       }
-
-       bfa_fcxp_queue(fcxp, send_req);
-}
-
-/**
- * Abort a BFA FCXP
- *
- * @param[in]  fcxp    BFA fcxp pointer
- *
- * @return             void
- */
-bfa_status_t
-bfa_fcxp_abort(struct bfa_fcxp_s *fcxp)
-{
-       bfa_assert(0);
-       return BFA_STATUS_OK;
-}
-
-void
-bfa_fcxp_alloc_wait(struct bfa_s *bfa, struct bfa_fcxp_wqe_s *wqe,
-                       bfa_fcxp_alloc_cbfn_t alloc_cbfn, void *alloc_cbarg)
-{
-       struct bfa_fcxp_mod_s *mod = BFA_FCXP_MOD(bfa);
-
-       bfa_assert(list_empty(&mod->fcxp_free_q));
-
-       wqe->alloc_cbfn = alloc_cbfn;
-       wqe->alloc_cbarg = alloc_cbarg;
-       list_add_tail(&wqe->qe, &mod->wait_q);
-}
-
-void
-bfa_fcxp_walloc_cancel(struct bfa_s *bfa, struct bfa_fcxp_wqe_s *wqe)
-{
-       struct bfa_fcxp_mod_s *mod = BFA_FCXP_MOD(bfa);
-
-       bfa_assert(bfa_q_is_on_q(&mod->wait_q, wqe));
-       list_del(&wqe->qe);
-}
-
-void
-bfa_fcxp_discard(struct bfa_fcxp_s *fcxp)
-{
-       /**
-        * If waiting for room in request queue, cancel reqq wait
-        * and free fcxp.
-        */
-       if (fcxp->reqq_waiting) {
-               fcxp->reqq_waiting = BFA_FALSE;
-               bfa_reqq_wcancel(&fcxp->reqq_wqe);
-               bfa_fcxp_free(fcxp);
-               return;
-       }
-
-       fcxp->send_cbfn = bfa_fcxp_null_comp;
-}
-
-
-
-/**
- *  hal_fcxp_public BFA FCXP public functions
- */
-
-void
-bfa_fcxp_isr(struct bfa_s *bfa, struct bfi_msg_s *msg)
-{
-       switch (msg->mhdr.msg_id) {
-       case BFI_FCXP_I2H_SEND_RSP:
-               hal_fcxp_send_comp(bfa, (struct bfi_fcxp_send_rsp_s *) msg);
-               break;
-
-       default:
-               bfa_trc(bfa, msg->mhdr.msg_id);
-               bfa_assert(0);
-       }
-}
-
-u32
-bfa_fcxp_get_maxrsp(struct bfa_s *bfa)
-{
-       struct bfa_fcxp_mod_s *mod = BFA_FCXP_MOD(bfa);
-
-       return mod->rsp_pld_sz;
-}
-
-
diff --git a/drivers/scsi/bfa/bfa_fcxp_priv.h b/drivers/scsi/bfa/bfa_fcxp_priv.h
deleted file mode 100644 (file)
index 4cda493..0000000
+++ /dev/null
@@ -1,138 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_FCXP_PRIV_H__
-#define __BFA_FCXP_PRIV_H__
-
-#include <cs/bfa_sm.h>
-#include <protocol/fc.h>
-#include <bfa_svc.h>
-#include <bfi/bfi_fcxp.h>
-
-#define BFA_FCXP_MIN           (1)
-#define BFA_FCXP_MAX_IBUF_SZ   (2 * 1024 + 256)
-#define BFA_FCXP_MAX_LBUF_SZ   (4 * 1024 + 256)
-
-struct bfa_fcxp_mod_s {
-       struct bfa_s      *bfa;         /*  backpointer to BFA */
-       struct bfa_fcxp_s *fcxp_list;   /*  array of FCXPs */
-       u16        num_fcxps;   /*  max num FCXP requests */
-       struct list_head fcxp_free_q;   /*  free FCXPs */
-       struct list_head fcxp_active_q; /*  active FCXPs */
-       void    *req_pld_list_kva;      /*  list of FCXP req pld */
-       u64 req_pld_list_pa;    /*  list of FCXP req pld */
-       void *rsp_pld_list_kva;         /*  list of FCXP resp pld */
-       u64 rsp_pld_list_pa;    /*  list of FCXP resp pld */
-       struct list_head  wait_q;               /*  wait queue for free fcxp */
-       u32     req_pld_sz;
-       u32     rsp_pld_sz;
-};
-
-#define BFA_FCXP_MOD(__bfa)            (&(__bfa)->modules.fcxp_mod)
-#define BFA_FCXP_FROM_TAG(__mod, __tag)        (&(__mod)->fcxp_list[__tag])
-
-typedef void    (*fcxp_send_cb_t) (struct bfa_s *ioc, struct bfa_fcxp_s *fcxp,
-                                  void *cb_arg, bfa_status_t req_status,
-                                  u32 rsp_len, u32 resid_len,
-                                  struct fchs_s *rsp_fchs);
-
-/**
- * Information needed for a FCXP request
- */
-struct bfa_fcxp_req_info_s {
-       struct bfa_rport_s *bfa_rport;  /*  Pointer to the bfa rport that was
-                                        *returned from bfa_rport_create().
-                                        *This could be left NULL for WKA or for
-                                        *FCXP interactions before the rport
-                                        *nexus is established
-                                        */
-       struct fchs_s   fchs;   /*  request FC header structure */
-       u8 cts;         /*  continous sequence */
-       u8 class;               /*  FC class for the request/response */
-       u16 max_frmsz;  /*  max send frame size */
-       u16 vf_id;              /*  vsan tag if applicable */
-       u8      lp_tag;         /*  lport tag */
-       u32 req_tot_len;        /*  request payload total length */
-};
-
-struct bfa_fcxp_rsp_info_s {
-       struct fchs_s rsp_fchs;         /*  Response frame's FC header will
-                                        * be *sent back in this field */
-       u8         rsp_timeout; /*  timeout in seconds, 0-no response
-                                        */
-       u8         rsvd2[3];
-       u32        rsp_maxlen;  /*  max response length expected */
-};
-
-struct bfa_fcxp_s {
-       struct list_head        qe;             /*  fcxp queue element */
-       bfa_sm_t        sm;             /*  state machine */
-       void            *caller;        /*  driver or fcs */
-       struct bfa_fcxp_mod_s *fcxp_mod;
-                                       /*  back pointer to fcxp mod */
-       u16        fcxp_tag;    /*  internal tag */
-       struct bfa_fcxp_req_info_s req_info;
-                                       /*  request info */
-       struct bfa_fcxp_rsp_info_s rsp_info;
-                                       /*  response info */
-       u8      use_ireqbuf;    /*  use internal req buf */
-       u8         use_irspbuf; /*  use internal rsp buf */
-       u32        nreq_sgles;  /*  num request SGLEs */
-       u32        nrsp_sgles;  /*  num response SGLEs */
-       struct list_head req_sgpg_q;    /*  SG pages for request buf */
-       struct list_head req_sgpg_wqe;  /*  wait queue for req SG page */
-       struct list_head rsp_sgpg_q;    /*  SG pages for response buf */
-       struct list_head rsp_sgpg_wqe;  /*  wait queue for rsp SG page */
-
-       bfa_fcxp_get_sgaddr_t req_sga_cbfn;
-                                       /*  SG elem addr user function */
-       bfa_fcxp_get_sglen_t req_sglen_cbfn;
-                                       /*  SG elem len user function */
-       bfa_fcxp_get_sgaddr_t rsp_sga_cbfn;
-                                       /*  SG elem addr user function */
-       bfa_fcxp_get_sglen_t rsp_sglen_cbfn;
-                                       /*  SG elem len user function */
-       bfa_cb_fcxp_send_t send_cbfn;   /*  send completion callback */
-       void            *send_cbarg;    /*  callback arg */
-       struct bfa_sge_s   req_sge[BFA_FCXP_MAX_SGES];
-                                       /*  req SG elems */
-       struct bfa_sge_s   rsp_sge[BFA_FCXP_MAX_SGES];
-                                       /*  rsp SG elems */
-       u8         rsp_status;  /*  comp: rsp status */
-       u32        rsp_len;     /*  comp: actual response len */
-       u32        residue_len; /*  comp: residual rsp length */
-       struct fchs_s          rsp_fchs;        /*  comp: response fchs */
-       struct bfa_cb_qe_s    hcb_qe;   /*  comp: callback qelem */
-       struct bfa_reqq_wait_s  reqq_wqe;
-       bfa_boolean_t   reqq_waiting;
-};
-
-#define BFA_FCXP_REQ_PLD(_fcxp)        (bfa_fcxp_get_reqbuf(_fcxp))
-
-#define BFA_FCXP_RSP_FCHS(_fcxp)       (&((_fcxp)->rsp_info.fchs))
-#define BFA_FCXP_RSP_PLD(_fcxp)        (bfa_fcxp_get_rspbuf(_fcxp))
-
-#define BFA_FCXP_REQ_PLD_PA(_fcxp)                                     \
-       ((_fcxp)->fcxp_mod->req_pld_list_pa +                           \
-               ((_fcxp)->fcxp_mod->req_pld_sz  * (_fcxp)->fcxp_tag))
-
-#define BFA_FCXP_RSP_PLD_PA(_fcxp)                                     \
-       ((_fcxp)->fcxp_mod->rsp_pld_list_pa +                           \
-               ((_fcxp)->fcxp_mod->rsp_pld_sz * (_fcxp)->fcxp_tag))
-
-void   bfa_fcxp_isr(struct bfa_s *bfa, struct bfi_msg_s *msg);
-#endif /* __BFA_FCXP_PRIV_H__ */
diff --git a/drivers/scsi/bfa/bfa_fwimg_priv.h b/drivers/scsi/bfa/bfa_fwimg_priv.h
deleted file mode 100644 (file)
index d33e19e..0000000
+++ /dev/null
@@ -1,44 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_FWIMG_PRIV_H__
-#define __BFA_FWIMG_PRIV_H__
-
-#define        BFI_FLASH_CHUNK_SZ              256     /*  Flash chunk size */
-#define        BFI_FLASH_CHUNK_SZ_WORDS        (BFI_FLASH_CHUNK_SZ/sizeof(u32))
-
-/**
- * BFI FW image type
- */
-enum {
-       BFI_IMAGE_CB_FC,
-       BFI_IMAGE_CT_FC,
-       BFI_IMAGE_CT_CNA,
-       BFI_IMAGE_MAX,
-};
-
-extern u32 *bfi_image_get_chunk(int type, uint32_t off);
-extern u32 bfi_image_get_size(int type);
-extern u32 bfi_image_ct_fc_size;
-extern u32 bfi_image_ct_cna_size;
-extern u32 bfi_image_cb_fc_size;
-extern u32 *bfi_image_ct_fc;
-extern u32 *bfi_image_ct_cna;
-extern u32 *bfi_image_cb_fc;
-
-
-#endif /* __BFA_FWIMG_PRIV_H__ */
index edfd729445cfe23d880c31e87039f57999e38ca1..c787d3af0886e2172d6180d792c5202c695b9a30 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
  * All rights reserved
  * www.brocade.com
  *
  * General Public License for more details.
  */
 
-#include <bfa_priv.h>
-#include <bfi/bfi_cbreg.h>
+#include "bfa_modules.h"
+#include "bfi_cbreg.h"
 
 void
 bfa_hwcb_reginit(struct bfa_s *bfa)
 {
        struct bfa_iocfc_regs_s *bfa_regs = &bfa->iocfc.bfa_regs;
        bfa_os_addr_t           kva = bfa_ioc_bar0(&bfa->ioc);
-       int                     i, q, fn = bfa_ioc_pcifn(&bfa->ioc);
+       int                     i, q, fn = bfa_ioc_pcifn(&bfa->ioc);
 
        if (fn == 0) {
                bfa_regs->intr_status = (kva + HOSTFN0_INT_STATUS);
index a357fb3066fd27577eba4cbf9d028f1b5e67d0d4..c97ebafec5ea980ec0a4597aa9ac4719001184fd 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
  * All rights reserved
  * www.brocade.com
  *
@@ -15,9 +15,8 @@
  * General Public License for more details.
  */
 
-#include <bfa_priv.h>
-#include <bfi/bfi_ctreg.h>
-#include <bfa_ioc.h>
+#include "bfa_modules.h"
+#include "bfi_ctreg.h"
 
 BFA_TRC_FILE(HAL, IOCFC_CT);
 
@@ -53,7 +52,7 @@ bfa_hwct_reginit(struct bfa_s *bfa)
 {
        struct bfa_iocfc_regs_s *bfa_regs = &bfa->iocfc.bfa_regs;
        bfa_os_addr_t           kva = bfa_ioc_bar0(&bfa->ioc);
-       int                     i, q, fn = bfa_ioc_pcifn(&bfa->ioc);
+       int                     i, q, fn = bfa_ioc_pcifn(&bfa->ioc);
 
        if (fn == 0) {
                bfa_regs->intr_status = (kva + HOSTFN0_INT_STATUS);
@@ -87,7 +86,7 @@ bfa_hwct_reginit(struct bfa_s *bfa)
 void
 bfa_hwct_reqq_ack(struct bfa_s *bfa, int reqq)
 {
-       u32 r32;
+       u32     r32;
 
        r32 = bfa_reg_read(bfa->iocfc.bfa_regs.cpe_q_ctrl[reqq]);
        bfa_reg_write(bfa->iocfc.bfa_regs.cpe_q_ctrl[reqq], r32);
diff --git a/drivers/scsi/bfa/bfa_intr.c b/drivers/scsi/bfa/bfa_intr.c
deleted file mode 100644 (file)
index 4936788..0000000
+++ /dev/null
@@ -1,270 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-#include <bfa.h>
-#include <bfi/bfi_ctreg.h>
-#include <bfa_port_priv.h>
-#include <bfa_intr_priv.h>
-#include <cs/bfa_debug.h>
-
-BFA_TRC_FILE(HAL, INTR);
-
-static void
-bfa_msix_errint(struct bfa_s *bfa, u32 intr)
-{
-       bfa_ioc_error_isr(&bfa->ioc);
-}
-
-static void
-bfa_msix_lpu(struct bfa_s *bfa)
-{
-       bfa_ioc_mbox_isr(&bfa->ioc);
-}
-
-static void
-bfa_reqq_resume(struct bfa_s *bfa, int qid)
-{
-       struct list_head *waitq, *qe, *qen;
-       struct bfa_reqq_wait_s *wqe;
-
-       waitq = bfa_reqq(bfa, qid);
-       list_for_each_safe(qe, qen, waitq) {
-               /**
-                * Callback only as long as there is room in request queue
-                */
-               if (bfa_reqq_full(bfa, qid))
-                       break;
-
-               list_del(qe);
-               wqe = (struct bfa_reqq_wait_s *) qe;
-               wqe->qresume(wqe->cbarg);
-       }
-}
-
-void
-bfa_msix_all(struct bfa_s *bfa, int vec)
-{
-       bfa_intx(bfa);
-}
-
-/**
- *  hal_intr_api
- */
-bfa_boolean_t
-bfa_intx(struct bfa_s *bfa)
-{
-       u32        intr, qintr;
-       int             queue;
-
-       intr = bfa_reg_read(bfa->iocfc.bfa_regs.intr_status);
-       if (!intr)
-               return BFA_FALSE;
-
-       /**
-        * RME completion queue interrupt
-        */
-       qintr = intr & __HFN_INT_RME_MASK;
-       bfa_reg_write(bfa->iocfc.bfa_regs.intr_status, qintr);
-
-       for (queue = 0; queue < BFI_IOC_MAX_CQS_ASIC; queue++) {
-               if (intr & (__HFN_INT_RME_Q0 << queue))
-                       bfa_msix_rspq(bfa, queue & (BFI_IOC_MAX_CQS - 1));
-       }
-       intr &= ~qintr;
-       if (!intr)
-               return BFA_TRUE;
-
-       /**
-        * CPE completion queue interrupt
-        */
-       qintr = intr & __HFN_INT_CPE_MASK;
-       bfa_reg_write(bfa->iocfc.bfa_regs.intr_status, qintr);
-
-       for (queue = 0; queue < BFI_IOC_MAX_CQS_ASIC; queue++) {
-               if (intr & (__HFN_INT_CPE_Q0 << queue))
-                       bfa_msix_reqq(bfa, queue & (BFI_IOC_MAX_CQS - 1));
-       }
-       intr &= ~qintr;
-       if (!intr)
-               return BFA_TRUE;
-
-       bfa_msix_lpu_err(bfa, intr);
-
-       return BFA_TRUE;
-}
-
-void
-bfa_isr_enable(struct bfa_s *bfa)
-{
-       u32        intr_unmask;
-       int             pci_func = bfa_ioc_pcifn(&bfa->ioc);
-
-       bfa_trc(bfa, pci_func);
-
-       bfa_msix_install(bfa);
-       intr_unmask = (__HFN_INT_ERR_EMC | __HFN_INT_ERR_LPU0 |
-                      __HFN_INT_ERR_LPU1 | __HFN_INT_ERR_PSS |
-                      __HFN_INT_LL_HALT);
-
-       if (pci_func == 0)
-               intr_unmask |= (__HFN_INT_CPE_Q0 | __HFN_INT_CPE_Q1 |
-                               __HFN_INT_CPE_Q2 | __HFN_INT_CPE_Q3 |
-                               __HFN_INT_RME_Q0 | __HFN_INT_RME_Q1 |
-                               __HFN_INT_RME_Q2 | __HFN_INT_RME_Q3 |
-                               __HFN_INT_MBOX_LPU0);
-       else
-               intr_unmask |= (__HFN_INT_CPE_Q4 | __HFN_INT_CPE_Q5 |
-                               __HFN_INT_CPE_Q6 | __HFN_INT_CPE_Q7 |
-                               __HFN_INT_RME_Q4 | __HFN_INT_RME_Q5 |
-                               __HFN_INT_RME_Q6 | __HFN_INT_RME_Q7 |
-                               __HFN_INT_MBOX_LPU1);
-
-       bfa_reg_write(bfa->iocfc.bfa_regs.intr_status, intr_unmask);
-       bfa_reg_write(bfa->iocfc.bfa_regs.intr_mask, ~intr_unmask);
-       bfa->iocfc.intr_mask = ~intr_unmask;
-       bfa_isr_mode_set(bfa, bfa->msix.nvecs != 0);
-}
-
-void
-bfa_isr_disable(struct bfa_s *bfa)
-{
-       bfa_isr_mode_set(bfa, BFA_FALSE);
-       bfa_reg_write(bfa->iocfc.bfa_regs.intr_mask, -1L);
-       bfa_msix_uninstall(bfa);
-}
-
-void
-bfa_msix_reqq(struct bfa_s *bfa, int qid)
-{
-       struct list_head *waitq;
-
-       qid &= (BFI_IOC_MAX_CQS - 1);
-
-       bfa->iocfc.hwif.hw_reqq_ack(bfa, qid);
-
-       /**
-        * Resume any pending requests in the corresponding reqq.
-        */
-       waitq = bfa_reqq(bfa, qid);
-       if (!list_empty(waitq))
-               bfa_reqq_resume(bfa, qid);
-}
-
-void
-bfa_isr_unhandled(struct bfa_s *bfa, struct bfi_msg_s *m)
-{
-       bfa_trc(bfa, m->mhdr.msg_class);
-       bfa_trc(bfa, m->mhdr.msg_id);
-       bfa_trc(bfa, m->mhdr.mtag.i2htok);
-       bfa_assert(0);
-       bfa_trc_stop(bfa->trcmod);
-}
-
-void
-bfa_msix_rspq(struct bfa_s *bfa, int qid)
-{
-       struct bfi_msg_s *m;
-       u32 pi, ci;
-       struct list_head *waitq;
-
-       bfa_trc_fp(bfa, qid);
-
-       qid &= (BFI_IOC_MAX_CQS - 1);
-
-       bfa->iocfc.hwif.hw_rspq_ack(bfa, qid);
-
-       ci = bfa_rspq_ci(bfa, qid);
-       pi = bfa_rspq_pi(bfa, qid);
-
-       bfa_trc_fp(bfa, ci);
-       bfa_trc_fp(bfa, pi);
-
-       if (bfa->rme_process) {
-               while (ci != pi) {
-                       m = bfa_rspq_elem(bfa, qid, ci);
-                       bfa_assert_fp(m->mhdr.msg_class < BFI_MC_MAX);
-
-                       bfa_isrs[m->mhdr.msg_class] (bfa, m);
-
-                       CQ_INCR(ci, bfa->iocfc.cfg.drvcfg.num_rspq_elems);
-               }
-       }
-
-       /**
-        * update CI
-        */
-       bfa_rspq_ci(bfa, qid) = pi;
-       bfa_reg_write(bfa->iocfc.bfa_regs.rme_q_ci[qid], pi);
-       bfa_os_mmiowb();
-
-       /**
-        * Resume any pending requests in the corresponding reqq.
-        */
-       waitq = bfa_reqq(bfa, qid);
-       if (!list_empty(waitq))
-               bfa_reqq_resume(bfa, qid);
-}
-
-void
-bfa_msix_lpu_err(struct bfa_s *bfa, int vec)
-{
-       u32 intr, curr_value;
-
-       intr = bfa_reg_read(bfa->iocfc.bfa_regs.intr_status);
-
-       if (intr & (__HFN_INT_MBOX_LPU0 | __HFN_INT_MBOX_LPU1))
-               bfa_msix_lpu(bfa);
-
-       intr &= (__HFN_INT_ERR_EMC | __HFN_INT_ERR_LPU0 |
-               __HFN_INT_ERR_LPU1 | __HFN_INT_ERR_PSS | __HFN_INT_LL_HALT);
-
-       if (intr) {
-               if (intr & __HFN_INT_LL_HALT) {
-                       /**
-                        * If LL_HALT bit is set then FW Init Halt LL Port
-                        * Register needs to be cleared as well so Interrupt
-                        * Status Register will be cleared.
-                        */
-                       curr_value = bfa_reg_read(bfa->ioc.ioc_regs.ll_halt);
-                       curr_value &= ~__FW_INIT_HALT_P;
-                       bfa_reg_write(bfa->ioc.ioc_regs.ll_halt, curr_value);
-               }
-
-               if (intr & __HFN_INT_ERR_PSS) {
-                       /**
-                        * ERR_PSS bit needs to be cleared as well in case
-                        * interrups are shared so driver's interrupt handler is
-                        * still called eventhough it is already masked out.
-                        */
-                       curr_value = bfa_reg_read(
-                               bfa->ioc.ioc_regs.pss_err_status_reg);
-                       curr_value &= __PSS_ERR_STATUS_SET;
-                       bfa_reg_write(bfa->ioc.ioc_regs.pss_err_status_reg,
-                               curr_value);
-               }
-
-               bfa_reg_write(bfa->iocfc.bfa_regs.intr_status, intr);
-               bfa_msix_errint(bfa, intr);
-       }
-}
-
-void
-bfa_isr_bind(enum bfi_mclass mc, bfa_isr_func_t isr_func)
-{
-       bfa_isrs[mc] = isr_func;
-}
-
-
diff --git a/drivers/scsi/bfa/bfa_intr_priv.h b/drivers/scsi/bfa/bfa_intr_priv.h
deleted file mode 100644 (file)
index 5fc301c..0000000
+++ /dev/null
@@ -1,117 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_INTR_PRIV_H__
-#define __BFA_INTR_PRIV_H__
-
-/**
- * Message handler
- */
-typedef void (*bfa_isr_func_t) (struct bfa_s *bfa, struct bfi_msg_s *m);
-void bfa_isr_unhandled(struct bfa_s *bfa, struct bfi_msg_s *m);
-void bfa_isr_bind(enum bfi_mclass mc, bfa_isr_func_t isr_func);
-
-
-#define bfa_reqq_pi(__bfa, __reqq)     ((__bfa)->iocfc.req_cq_pi[__reqq])
-#define bfa_reqq_ci(__bfa, __reqq)                                     \
-       (*(u32 *)((__bfa)->iocfc.req_cq_shadow_ci[__reqq].kva))
-
-#define bfa_reqq_full(__bfa, __reqq)                           \
-       (((bfa_reqq_pi(__bfa, __reqq) + 1) &                    \
-         ((__bfa)->iocfc.cfg.drvcfg.num_reqq_elems - 1)) ==    \
-        bfa_reqq_ci(__bfa, __reqq))
-
-#define bfa_reqq_next(__bfa, __reqq)                           \
-       (bfa_reqq_full(__bfa, __reqq) ? NULL :                  \
-        ((void *)((struct bfi_msg_s *)((__bfa)->iocfc.req_cq_ba[__reqq].kva) \
-                         + bfa_reqq_pi((__bfa), (__reqq)))))
-
-#define bfa_reqq_produce(__bfa, __reqq)        do {                            \
-       (__bfa)->iocfc.req_cq_pi[__reqq]++;                             \
-       (__bfa)->iocfc.req_cq_pi[__reqq] &=                             \
-               ((__bfa)->iocfc.cfg.drvcfg.num_reqq_elems - 1);      \
-       bfa_reg_write((__bfa)->iocfc.bfa_regs.cpe_q_pi[__reqq],         \
-                               (__bfa)->iocfc.req_cq_pi[__reqq]);      \
-       bfa_os_mmiowb();      \
-} while (0)
-
-#define bfa_rspq_pi(__bfa, __rspq)                                     \
-       (*(u32 *)((__bfa)->iocfc.rsp_cq_shadow_pi[__rspq].kva))
-
-#define bfa_rspq_ci(__bfa, __rspq)     ((__bfa)->iocfc.rsp_cq_ci[__rspq])
-#define bfa_rspq_elem(__bfa, __rspq, __ci)                             \
-       (&((struct bfi_msg_s *)((__bfa)->iocfc.rsp_cq_ba[__rspq].kva))[__ci])
-
-#define CQ_INCR(__index, __size) do {                                  \
-                       (__index)++;                                    \
-                       (__index) &= ((__size) - 1);      \
-} while (0)
-
-/**
- * Queue element to wait for room in request queue. FIFO order is
- * maintained when fullfilling requests.
- */
-struct bfa_reqq_wait_s {
-       struct list_head        qe;
-       void            (*qresume) (void *cbarg);
-       void            *cbarg;
-};
-
-/**
- * Circular queue usage assignments
- */
-enum {
-       BFA_REQQ_IOC    = 0,    /*  all low-priority IOC msgs   */
-       BFA_REQQ_FCXP   = 0,    /*  all FCXP messages           */
-       BFA_REQQ_LPS    = 0,    /*  all lport service msgs      */
-       BFA_REQQ_PORT   = 0,    /*  all port messages           */
-       BFA_REQQ_FLASH  = 0,    /*  for flash module            */
-       BFA_REQQ_DIAG   = 0,    /*  for diag module             */
-       BFA_REQQ_RPORT  = 0,    /*  all port messages           */
-       BFA_REQQ_SBOOT  = 0,    /*  all san boot messages       */
-       BFA_REQQ_QOS_LO = 1,    /*  all low priority IO */
-       BFA_REQQ_QOS_MD = 2,    /*  all medium priority IO      */
-       BFA_REQQ_QOS_HI = 3,    /*  all high priority IO        */
-};
-
-static inline void
-bfa_reqq_winit(struct bfa_reqq_wait_s *wqe, void (*qresume) (void *cbarg),
-                       void *cbarg)
-{
-       wqe->qresume = qresume;
-       wqe->cbarg = cbarg;
-}
-
-#define bfa_reqq(__bfa, __reqq)        (&(__bfa)->reqq_waitq[__reqq])
-
-/**
- * static inline void
- * bfa_reqq_wait(struct bfa_s *bfa, int reqq, struct bfa_reqq_wait_s *wqe)
- */
-#define bfa_reqq_wait(__bfa, __reqq, __wqe) do {                       \
-                                                                       \
-               struct list_head *waitq = bfa_reqq(__bfa, __reqq);      \
-                                                                       \
-               bfa_assert(((__reqq) < BFI_IOC_MAX_CQS));      \
-               bfa_assert((__wqe)->qresume && (__wqe)->cbarg);      \
-                                                                       \
-               list_add_tail(&(__wqe)->qe, waitq);      \
-} while (0)
-
-#define bfa_reqq_wcancel(__wqe)        list_del(&(__wqe)->qe)
-
-#endif /* __BFA_INTR_PRIV_H__ */
index 8e78f20110a5be237a4c4d64a0fddd2496a816fd..6795b247791a5d48f8b4572997f5f68afbd7ec95 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
  * All rights reserved
  * www.brocade.com
  *
  * General Public License for more details.
  */
 
-#include <bfa.h>
-#include <bfa_ioc.h>
-#include <bfa_fwimg_priv.h>
-#include <cna/bfa_cna_trcmod.h>
-#include <cs/bfa_debug.h>
-#include <bfi/bfi_ioc.h>
-#include <bfi/bfi_ctreg.h>
-#include <aen/bfa_aen_ioc.h>
-#include <aen/bfa_aen.h>
-#include <log/bfa_log_hal.h>
-#include <defs/bfa_defs_pci.h>
+#include "bfa_ioc.h"
+#include "bfi_ctreg.h"
+#include "bfa_defs.h"
+#include "bfa_defs_svc.h"
+#include "bfad_drv.h"
 
 BFA_TRC_FILE(CNA, IOC);
 
 /**
  * IOC local definitions
  */
-#define BFA_IOC_TOV            2000    /* msecs */
-#define BFA_IOC_HWSEM_TOV       500     /* msecs */
-#define BFA_IOC_HB_TOV          500     /* msecs */
-#define BFA_IOC_HWINIT_MAX      2
-#define BFA_IOC_FWIMG_MINSZ     (16 * 1024)
-#define BFA_IOC_TOV_RECOVER      BFA_IOC_HB_TOV
+#define BFA_IOC_TOV            3000    /* msecs */
+#define BFA_IOC_HWSEM_TOV      500     /* msecs */
+#define BFA_IOC_HB_TOV         500     /* msecs */
+#define BFA_IOC_HWINIT_MAX     2
+#define BFA_IOC_TOV_RECOVER     BFA_IOC_HB_TOV
 
 #define bfa_ioc_timer_start(__ioc)                                     \
        bfa_timer_begin((__ioc)->timer_mod, &(__ioc)->ioc_timer,        \
                        bfa_ioc_timeout, (__ioc), BFA_IOC_TOV)
 #define bfa_ioc_timer_stop(__ioc)   bfa_timer_stop(&(__ioc)->ioc_timer)
 
+#define bfa_hb_timer_start(__ioc)                                      \
+       bfa_timer_begin((__ioc)->timer_mod, &(__ioc)->hb_timer,         \
+                       bfa_ioc_hb_check, (__ioc), BFA_IOC_HB_TOV)
+#define bfa_hb_timer_stop(__ioc)       bfa_timer_stop(&(__ioc)->hb_timer)
+
 #define BFA_DBG_FWTRC_ENTS     (BFI_IOC_TRC_ENTS)
 #define BFA_DBG_FWTRC_LEN                                      \
        (BFA_DBG_FWTRC_ENTS * sizeof(struct bfa_trc_s) +        \
@@ -55,100 +53,226 @@ BFA_TRC_FILE(CNA, IOC);
  * Asic specific macros : see bfa_hw_cb.c and bfa_hw_ct.c for details.
  */
 
-#define bfa_ioc_firmware_lock(__ioc)                    \
+#define bfa_ioc_firmware_lock(__ioc)                   \
                        ((__ioc)->ioc_hwif->ioc_firmware_lock(__ioc))
-#define bfa_ioc_firmware_unlock(__ioc)                  \
+#define bfa_ioc_firmware_unlock(__ioc)                 \
                        ((__ioc)->ioc_hwif->ioc_firmware_unlock(__ioc))
 #define bfa_ioc_reg_init(__ioc) ((__ioc)->ioc_hwif->ioc_reg_init(__ioc))
 #define bfa_ioc_map_port(__ioc) ((__ioc)->ioc_hwif->ioc_map_port(__ioc))
-#define bfa_ioc_notify_hbfail(__ioc)                    \
+#define bfa_ioc_notify_hbfail(__ioc)                   \
                        ((__ioc)->ioc_hwif->ioc_notify_hbfail(__ioc))
-#define bfa_ioc_is_optrom(__ioc)        \
-       (bfi_image_get_size(BFA_IOC_FWIMG_TYPE(__ioc)) < BFA_IOC_FWIMG_MINSZ)
 
-bfa_boolean_t   bfa_auto_recover = BFA_TRUE;
+#ifdef BFA_IOC_IS_UEFI
+#define bfa_ioc_is_bios_optrom(__ioc) (0)
+#define bfa_ioc_is_uefi(__ioc) BFA_IOC_IS_UEFI
+#else
+#define bfa_ioc_is_bios_optrom(__ioc)  \
+       (bfa_cb_image_get_size(BFA_IOC_FWIMG_TYPE(__ioc)) < BFA_IOC_FWIMG_MINSZ)
+#define bfa_ioc_is_uefi(__ioc) (0)
+#endif
+
+#define bfa_ioc_mbox_cmd_pending(__ioc)                \
+                       (!list_empty(&((__ioc)->mbox_mod.cmd_q)) || \
+                       bfa_reg_read((__ioc)->ioc_regs.hfn_mbox_cmd))
+
+bfa_boolean_t bfa_auto_recover = BFA_TRUE;
 
 /*
  * forward declarations
  */
-static void     bfa_ioc_hw_sem_get(struct bfa_ioc_s *ioc);
-static void     bfa_ioc_hw_sem_get_cancel(struct bfa_ioc_s *ioc);
-static void     bfa_ioc_hwinit(struct bfa_ioc_s *ioc, bfa_boolean_t force);
-static void     bfa_ioc_timeout(void *ioc);
-static void     bfa_ioc_send_enable(struct bfa_ioc_s *ioc);
-static void     bfa_ioc_send_disable(struct bfa_ioc_s *ioc);
-static void     bfa_ioc_send_getattr(struct bfa_ioc_s *ioc);
-static void     bfa_ioc_hb_monitor(struct bfa_ioc_s *ioc);
-static void     bfa_ioc_hb_stop(struct bfa_ioc_s *ioc);
-static void     bfa_ioc_reset(struct bfa_ioc_s *ioc, bfa_boolean_t force);
-static void     bfa_ioc_mbox_poll(struct bfa_ioc_s *ioc);
-static void     bfa_ioc_mbox_hbfail(struct bfa_ioc_s *ioc);
-static void     bfa_ioc_recover(struct bfa_ioc_s *ioc);
-static void    bfa_ioc_check_attr_wwns(struct bfa_ioc_s *ioc);
-static void     bfa_ioc_disable_comp(struct bfa_ioc_s *ioc);
-static void     bfa_ioc_lpu_stop(struct bfa_ioc_s *ioc);
+static void bfa_ioc_hw_sem_get(struct bfa_ioc_s *ioc);
+static void bfa_ioc_hw_sem_get_cancel(struct bfa_ioc_s *ioc);
+static void bfa_ioc_hwinit(struct bfa_ioc_s *ioc, bfa_boolean_t force);
+static void bfa_ioc_timeout(void *ioc);
+static void bfa_ioc_send_enable(struct bfa_ioc_s *ioc);
+static void bfa_ioc_send_disable(struct bfa_ioc_s *ioc);
+static void bfa_ioc_send_getattr(struct bfa_ioc_s *ioc);
+static void bfa_ioc_hb_monitor(struct bfa_ioc_s *ioc);
+static void bfa_ioc_hb_stop(struct bfa_ioc_s *ioc);
+static void bfa_ioc_reset(struct bfa_ioc_s *ioc, bfa_boolean_t force);
+static void bfa_ioc_mbox_poll(struct bfa_ioc_s *ioc);
+static void bfa_ioc_mbox_hbfail(struct bfa_ioc_s *ioc);
+static void bfa_ioc_recover(struct bfa_ioc_s *ioc);
+static void bfa_ioc_check_attr_wwns(struct bfa_ioc_s *ioc);
+static void bfa_ioc_disable_comp(struct bfa_ioc_s *ioc);
+static void bfa_ioc_lpu_stop(struct bfa_ioc_s *ioc);
+static void bfa_ioc_pf_enabled(struct bfa_ioc_s *ioc);
+static void bfa_ioc_pf_disabled(struct bfa_ioc_s *ioc);
+static void bfa_ioc_pf_failed(struct bfa_ioc_s *ioc);
+static void bfa_ioc_pf_fwmismatch(struct bfa_ioc_s *ioc);
 
 /**
- *  bfa_ioc_sm
+ *  hal_ioc_sm
  */
 
 /**
- * IOC state machine events
+ * IOC state machine definitions/declarations
  */
 enum ioc_event {
-       IOC_E_ENABLE = 1,       /*  IOC enable request */
-       IOC_E_DISABLE = 2,      /*  IOC disable request */
-       IOC_E_TIMEOUT = 3,      /*  f/w response timeout */
-       IOC_E_FWREADY = 4,      /*  f/w initialization done */
-       IOC_E_FWRSP_GETATTR = 5,        /*  IOC get attribute response */
-       IOC_E_FWRSP_ENABLE = 6, /*  enable f/w response */
-       IOC_E_FWRSP_DISABLE = 7,        /*  disable f/w response */
-       IOC_E_HBFAIL = 8,       /*  heartbeat failure */
-       IOC_E_HWERROR = 9,      /*  hardware error interrupt */
-       IOC_E_SEMLOCKED = 10,   /*  h/w semaphore is locked */
-       IOC_E_DETACH = 11,      /*  driver detach cleanup */
+       IOC_E_RESET             = 1,    /*  IOC reset request           */
+       IOC_E_ENABLE            = 2,    /*  IOC enable request          */
+       IOC_E_DISABLE           = 3,    /*  IOC disable request */
+       IOC_E_DETACH            = 4,    /*  driver detach cleanup       */
+       IOC_E_ENABLED           = 5,    /*  f/w enabled         */
+       IOC_E_FWRSP_GETATTR     = 6,    /*  IOC get attribute response  */
+       IOC_E_DISABLED          = 7,    /*  f/w disabled                */
+       IOC_E_FAILED            = 8,    /*  failure notice by iocpf sm  */
+       IOC_E_HBFAIL            = 9,    /*  heartbeat failure           */
+       IOC_E_HWERROR           = 10,   /*  hardware error interrupt    */
+       IOC_E_TIMEOUT           = 11,   /*  timeout                     */
 };
 
+bfa_fsm_state_decl(bfa_ioc, uninit, struct bfa_ioc_s, enum ioc_event);
 bfa_fsm_state_decl(bfa_ioc, reset, struct bfa_ioc_s, enum ioc_event);
-bfa_fsm_state_decl(bfa_ioc, fwcheck, struct bfa_ioc_s, enum ioc_event);
-bfa_fsm_state_decl(bfa_ioc, mismatch, struct bfa_ioc_s, enum ioc_event);
-bfa_fsm_state_decl(bfa_ioc, semwait, struct bfa_ioc_s, enum ioc_event);
-bfa_fsm_state_decl(bfa_ioc, hwinit, struct bfa_ioc_s, enum ioc_event);
 bfa_fsm_state_decl(bfa_ioc, enabling, struct bfa_ioc_s, enum ioc_event);
 bfa_fsm_state_decl(bfa_ioc, getattr, struct bfa_ioc_s, enum ioc_event);
 bfa_fsm_state_decl(bfa_ioc, op, struct bfa_ioc_s, enum ioc_event);
 bfa_fsm_state_decl(bfa_ioc, initfail, struct bfa_ioc_s, enum ioc_event);
-bfa_fsm_state_decl(bfa_ioc, hbfail, struct bfa_ioc_s, enum ioc_event);
+bfa_fsm_state_decl(bfa_ioc, fail, struct bfa_ioc_s, enum ioc_event);
 bfa_fsm_state_decl(bfa_ioc, disabling, struct bfa_ioc_s, enum ioc_event);
 bfa_fsm_state_decl(bfa_ioc, disabled, struct bfa_ioc_s, enum ioc_event);
 
 static struct bfa_sm_table_s ioc_sm_table[] = {
+       {BFA_SM(bfa_ioc_sm_uninit), BFA_IOC_UNINIT},
        {BFA_SM(bfa_ioc_sm_reset), BFA_IOC_RESET},
-       {BFA_SM(bfa_ioc_sm_fwcheck), BFA_IOC_FWMISMATCH},
-       {BFA_SM(bfa_ioc_sm_mismatch), BFA_IOC_FWMISMATCH},
-       {BFA_SM(bfa_ioc_sm_semwait), BFA_IOC_SEMWAIT},
-       {BFA_SM(bfa_ioc_sm_hwinit), BFA_IOC_HWINIT},
-       {BFA_SM(bfa_ioc_sm_enabling), BFA_IOC_HWINIT},
+       {BFA_SM(bfa_ioc_sm_enabling), BFA_IOC_ENABLING},
        {BFA_SM(bfa_ioc_sm_getattr), BFA_IOC_GETATTR},
        {BFA_SM(bfa_ioc_sm_op), BFA_IOC_OPERATIONAL},
        {BFA_SM(bfa_ioc_sm_initfail), BFA_IOC_INITFAIL},
-       {BFA_SM(bfa_ioc_sm_hbfail), BFA_IOC_HBFAIL},
+       {BFA_SM(bfa_ioc_sm_fail), BFA_IOC_FAIL},
        {BFA_SM(bfa_ioc_sm_disabling), BFA_IOC_DISABLING},
        {BFA_SM(bfa_ioc_sm_disabled), BFA_IOC_DISABLED},
 };
 
+/**
+ * IOCPF state machine definitions/declarations
+ */
+
+#define bfa_iocpf_timer_start(__ioc)                                   \
+       bfa_timer_begin((__ioc)->timer_mod, &(__ioc)->ioc_timer,        \
+                       bfa_iocpf_timeout, (__ioc), BFA_IOC_TOV)
+#define bfa_iocpf_timer_stop(__ioc)    bfa_timer_stop(&(__ioc)->ioc_timer)
+
+#define bfa_iocpf_recovery_timer_start(__ioc)                          \
+       bfa_timer_begin((__ioc)->timer_mod, &(__ioc)->ioc_timer,        \
+                       bfa_iocpf_timeout, (__ioc), BFA_IOC_TOV_RECOVER)
+
+#define bfa_sem_timer_start(__ioc)                                     \
+       bfa_timer_begin((__ioc)->timer_mod, &(__ioc)->sem_timer,        \
+                       bfa_iocpf_sem_timeout, (__ioc), BFA_IOC_HWSEM_TOV)
+#define bfa_sem_timer_stop(__ioc)      bfa_timer_stop(&(__ioc)->sem_timer)
+
+/*
+ * Forward declareations for iocpf state machine
+ */
+static void bfa_iocpf_enable(struct bfa_ioc_s *ioc);
+static void bfa_iocpf_disable(struct bfa_ioc_s *ioc);
+static void bfa_iocpf_fail(struct bfa_ioc_s *ioc);
+static void bfa_iocpf_initfail(struct bfa_ioc_s *ioc);
+static void bfa_iocpf_getattrfail(struct bfa_ioc_s *ioc);
+static void bfa_iocpf_stop(struct bfa_ioc_s *ioc);
+static void bfa_iocpf_timeout(void *ioc_arg);
+static void bfa_iocpf_sem_timeout(void *ioc_arg);
+
+/**
+ * IOCPF state machine events
+ */
+enum iocpf_event {
+       IOCPF_E_ENABLE          = 1,    /*  IOCPF enable request        */
+       IOCPF_E_DISABLE         = 2,    /*  IOCPF disable request       */
+       IOCPF_E_STOP            = 3,    /*  stop on driver detach       */
+       IOCPF_E_FWREADY         = 4,    /*  f/w initialization done     */
+       IOCPF_E_FWRSP_ENABLE    = 5,    /*  enable f/w response */
+       IOCPF_E_FWRSP_DISABLE   = 6,    /*  disable f/w response        */
+       IOCPF_E_FAIL            = 7,    /*  failure notice by ioc sm    */
+       IOCPF_E_INITFAIL        = 8,    /*  init fail notice by ioc sm  */
+       IOCPF_E_GETATTRFAIL     = 9,    /*  init fail notice by ioc sm  */
+       IOCPF_E_SEMLOCKED       = 10,   /*  h/w semaphore is locked     */
+       IOCPF_E_TIMEOUT         = 11,   /*  f/w response timeout        */
+};
+
+/**
+ * IOCPF states
+ */
+enum bfa_iocpf_state {
+       BFA_IOCPF_RESET         = 1,    /*  IOC is in reset state */
+       BFA_IOCPF_SEMWAIT       = 2,    /*  Waiting for IOC h/w semaphore */
+       BFA_IOCPF_HWINIT        = 3,    /*  IOC h/w is being initialized */
+       BFA_IOCPF_READY         = 4,    /*  IOCPF is initialized */
+       BFA_IOCPF_INITFAIL      = 5,    /*  IOCPF failed */
+       BFA_IOCPF_FAIL          = 6,    /*  IOCPF failed */
+       BFA_IOCPF_DISABLING     = 7,    /*  IOCPF is being disabled */
+       BFA_IOCPF_DISABLED      = 8,    /*  IOCPF is disabled */
+       BFA_IOCPF_FWMISMATCH    = 9,    /*  IOC f/w different from drivers */
+};
+
+bfa_fsm_state_decl(bfa_iocpf, reset, struct bfa_iocpf_s, enum iocpf_event);
+bfa_fsm_state_decl(bfa_iocpf, fwcheck, struct bfa_iocpf_s, enum iocpf_event);
+bfa_fsm_state_decl(bfa_iocpf, mismatch, struct bfa_iocpf_s, enum iocpf_event);
+bfa_fsm_state_decl(bfa_iocpf, semwait, struct bfa_iocpf_s, enum iocpf_event);
+bfa_fsm_state_decl(bfa_iocpf, hwinit, struct bfa_iocpf_s, enum iocpf_event);
+bfa_fsm_state_decl(bfa_iocpf, enabling, struct bfa_iocpf_s, enum iocpf_event);
+bfa_fsm_state_decl(bfa_iocpf, ready, struct bfa_iocpf_s, enum iocpf_event);
+bfa_fsm_state_decl(bfa_iocpf, initfail, struct bfa_iocpf_s, enum iocpf_event);
+bfa_fsm_state_decl(bfa_iocpf, fail, struct bfa_iocpf_s, enum iocpf_event);
+bfa_fsm_state_decl(bfa_iocpf, disabling, struct bfa_iocpf_s, enum iocpf_event);
+bfa_fsm_state_decl(bfa_iocpf, disabled, struct bfa_iocpf_s, enum iocpf_event);
+
+static struct bfa_sm_table_s iocpf_sm_table[] = {
+       {BFA_SM(bfa_iocpf_sm_reset), BFA_IOCPF_RESET},
+       {BFA_SM(bfa_iocpf_sm_fwcheck), BFA_IOCPF_FWMISMATCH},
+       {BFA_SM(bfa_iocpf_sm_mismatch), BFA_IOCPF_FWMISMATCH},
+       {BFA_SM(bfa_iocpf_sm_semwait), BFA_IOCPF_SEMWAIT},
+       {BFA_SM(bfa_iocpf_sm_hwinit), BFA_IOCPF_HWINIT},
+       {BFA_SM(bfa_iocpf_sm_enabling), BFA_IOCPF_HWINIT},
+       {BFA_SM(bfa_iocpf_sm_ready), BFA_IOCPF_READY},
+       {BFA_SM(bfa_iocpf_sm_initfail), BFA_IOCPF_INITFAIL},
+       {BFA_SM(bfa_iocpf_sm_fail), BFA_IOCPF_FAIL},
+       {BFA_SM(bfa_iocpf_sm_disabling), BFA_IOCPF_DISABLING},
+       {BFA_SM(bfa_iocpf_sm_disabled), BFA_IOCPF_DISABLED},
+};
+
+/**
+ * IOC State Machine
+ */
+
+/**
+ * Beginning state. IOC uninit state.
+ */
+
+static void
+bfa_ioc_sm_uninit_entry(struct bfa_ioc_s *ioc)
+{
+}
+
+/**
+ * IOC is in uninit state.
+ */
+static void
+bfa_ioc_sm_uninit(struct bfa_ioc_s *ioc, enum ioc_event event)
+{
+       bfa_trc(ioc, event);
+
+       switch (event) {
+       case IOC_E_RESET:
+               bfa_fsm_set_state(ioc, bfa_ioc_sm_reset);
+               break;
+
+       default:
+               bfa_sm_fault(ioc, event);
+       }
+}
 /**
  * Reset entry actions -- initialize state machine
  */
 static void
 bfa_ioc_sm_reset_entry(struct bfa_ioc_s *ioc)
 {
-       ioc->retry_count = 0;
-       ioc->auto_recover = bfa_auto_recover;
+       bfa_fsm_set_state(&ioc->iocpf, bfa_iocpf_sm_reset);
 }
 
 /**
- * Beginning state. IOC is in reset state.
+ * IOC is in reset state.
  */
 static void
 bfa_ioc_sm_reset(struct bfa_ioc_s *ioc, enum ioc_event event)
@@ -157,7 +281,7 @@ bfa_ioc_sm_reset(struct bfa_ioc_s *ioc, enum ioc_event event)
 
        switch (event) {
        case IOC_E_ENABLE:
-               bfa_fsm_set_state(ioc, bfa_ioc_sm_fwcheck);
+               bfa_fsm_set_state(ioc, bfa_ioc_sm_enabling);
                break;
 
        case IOC_E_DISABLE:
@@ -165,6 +289,7 @@ bfa_ioc_sm_reset(struct bfa_ioc_s *ioc, enum ioc_event event)
                break;
 
        case IOC_E_DETACH:
+               bfa_fsm_set_state(ioc, bfa_ioc_sm_uninit);
                break;
 
        default:
@@ -172,46 +297,209 @@ bfa_ioc_sm_reset(struct bfa_ioc_s *ioc, enum ioc_event event)
        }
 }
 
+
+static void
+bfa_ioc_sm_enabling_entry(struct bfa_ioc_s *ioc)
+{
+       bfa_iocpf_enable(ioc);
+}
+
 /**
- * Semaphore should be acquired for version check.
+ * Host IOC function is being enabled, awaiting response from firmware.
+ * Semaphore is acquired.
  */
 static void
-bfa_ioc_sm_fwcheck_entry(struct bfa_ioc_s *ioc)
+bfa_ioc_sm_enabling(struct bfa_ioc_s *ioc, enum ioc_event event)
 {
-       bfa_ioc_hw_sem_get(ioc);
+       bfa_trc(ioc, event);
+
+       switch (event) {
+       case IOC_E_ENABLED:
+               bfa_fsm_set_state(ioc, bfa_ioc_sm_getattr);
+               break;
+
+       case IOC_E_FAILED:
+               bfa_fsm_set_state(ioc, bfa_ioc_sm_initfail);
+               break;
+
+       case IOC_E_HWERROR:
+               bfa_fsm_set_state(ioc, bfa_ioc_sm_initfail);
+               bfa_iocpf_initfail(ioc);
+               break;
+
+       case IOC_E_DISABLE:
+               bfa_fsm_set_state(ioc, bfa_ioc_sm_disabling);
+               break;
+
+       case IOC_E_DETACH:
+               bfa_fsm_set_state(ioc, bfa_ioc_sm_uninit);
+               bfa_iocpf_stop(ioc);
+               break;
+
+       case IOC_E_ENABLE:
+               break;
+
+       default:
+               bfa_sm_fault(ioc, event);
+       }
+}
+
+
+static void
+bfa_ioc_sm_getattr_entry(struct bfa_ioc_s *ioc)
+{
+       bfa_ioc_timer_start(ioc);
+       bfa_ioc_send_getattr(ioc);
 }
 
 /**
- * Awaiting h/w semaphore to continue with version check.
+ * IOC configuration in progress. Timer is active.
  */
 static void
-bfa_ioc_sm_fwcheck(struct bfa_ioc_s *ioc, enum ioc_event event)
+bfa_ioc_sm_getattr(struct bfa_ioc_s *ioc, enum ioc_event event)
 {
        bfa_trc(ioc, event);
 
        switch (event) {
-       case IOC_E_SEMLOCKED:
-               if (bfa_ioc_firmware_lock(ioc)) {
-                       ioc->retry_count = 0;
-                       bfa_fsm_set_state(ioc, bfa_ioc_sm_hwinit);
-               } else {
-                       bfa_ioc_hw_sem_release(ioc);
-                       bfa_fsm_set_state(ioc, bfa_ioc_sm_mismatch);
-               }
+       case IOC_E_FWRSP_GETATTR:
+               bfa_ioc_timer_stop(ioc);
+               bfa_ioc_check_attr_wwns(ioc);
+               bfa_fsm_set_state(ioc, bfa_ioc_sm_op);
+               break;
+
+       case IOC_E_FAILED:
+               bfa_ioc_timer_stop(ioc);
+               bfa_fsm_set_state(ioc, bfa_ioc_sm_initfail);
+               break;
+
+       case IOC_E_HWERROR:
+               bfa_ioc_timer_stop(ioc);
+               /* fall through */
+
+       case IOC_E_TIMEOUT:
+               bfa_fsm_set_state(ioc, bfa_ioc_sm_initfail);
+               bfa_iocpf_getattrfail(ioc);
                break;
 
        case IOC_E_DISABLE:
-               bfa_ioc_disable_comp(ioc);
+               bfa_ioc_timer_stop(ioc);
+               bfa_fsm_set_state(ioc, bfa_ioc_sm_disabling);
+               break;
+
+       case IOC_E_ENABLE:
+               break;
+
+       default:
+               bfa_sm_fault(ioc, event);
+       }
+}
+
+
+static void
+bfa_ioc_sm_op_entry(struct bfa_ioc_s *ioc)
+{
+       struct bfad_s *bfad = (struct bfad_s *)ioc->bfa->bfad;
+
+       ioc->cbfn->enable_cbfn(ioc->bfa, BFA_STATUS_OK);
+       bfa_ioc_hb_monitor(ioc);
+       BFA_LOG(KERN_INFO, bfad, log_level, "IOC enabled\n");
+}
+
+static void
+bfa_ioc_sm_op(struct bfa_ioc_s *ioc, enum ioc_event event)
+{
+       bfa_trc(ioc, event);
+
+       switch (event) {
+       case IOC_E_ENABLE:
+               break;
+
+       case IOC_E_DISABLE:
+               bfa_ioc_hb_stop(ioc);
+               bfa_fsm_set_state(ioc, bfa_ioc_sm_disabling);
+               break;
+
+       case IOC_E_FAILED:
+               bfa_ioc_hb_stop(ioc);
+               bfa_fsm_set_state(ioc, bfa_ioc_sm_fail);
+               break;
+
+       case IOC_E_HWERROR:
+               bfa_ioc_hb_stop(ioc);
+               /* !!! fall through !!! */
+
+       case IOC_E_HBFAIL:
+               bfa_fsm_set_state(ioc, bfa_ioc_sm_fail);
+               bfa_iocpf_fail(ioc);
+               break;
+
+       default:
+               bfa_sm_fault(ioc, event);
+       }
+}
+
+
+static void
+bfa_ioc_sm_disabling_entry(struct bfa_ioc_s *ioc)
+{
+       struct bfad_s *bfad = (struct bfad_s *)ioc->bfa->bfad;
+       bfa_iocpf_disable(ioc);
+       BFA_LOG(KERN_INFO, bfad, log_level, "IOC disabled\n");
+}
+
+/**
+ * IOC is being disabled
+ */
+static void
+bfa_ioc_sm_disabling(struct bfa_ioc_s *ioc, enum ioc_event event)
+{
+       bfa_trc(ioc, event);
+
+       switch (event) {
+       case IOC_E_DISABLED:
+               bfa_fsm_set_state(ioc, bfa_ioc_sm_disabled);
+               break;
+
+       case IOC_E_HWERROR:
                /*
-                * fall through
+                * No state change.  Will move to disabled state
+                * after iocpf sm completes failure processing and
+                * moves to disabled state.
                 */
+               bfa_iocpf_fail(ioc);
+               break;
 
-       case IOC_E_DETACH:
-               bfa_ioc_hw_sem_get_cancel(ioc);
-               bfa_fsm_set_state(ioc, bfa_ioc_sm_reset);
+       default:
+               bfa_sm_fault(ioc, event);
+       }
+}
+
+/**
+ * IOC disable completion entry.
+ */
+static void
+bfa_ioc_sm_disabled_entry(struct bfa_ioc_s *ioc)
+{
+       bfa_ioc_disable_comp(ioc);
+}
+
+static void
+bfa_ioc_sm_disabled(struct bfa_ioc_s *ioc, enum ioc_event event)
+{
+       bfa_trc(ioc, event);
+
+       switch (event) {
+       case IOC_E_ENABLE:
+               bfa_fsm_set_state(ioc, bfa_ioc_sm_enabling);
                break;
 
-       case IOC_E_FWREADY:
+       case IOC_E_DISABLE:
+               ioc->cbfn->disable_cbfn(ioc->bfa);
+               break;
+
+       case IOC_E_DETACH:
+               bfa_fsm_set_state(ioc, bfa_ioc_sm_uninit);
+               bfa_iocpf_stop(ioc);
                break;
 
        default:
@@ -219,48 +507,138 @@ bfa_ioc_sm_fwcheck(struct bfa_ioc_s *ioc, enum ioc_event event)
        }
 }
 
+
+static void
+bfa_ioc_sm_initfail_entry(struct bfa_ioc_s *ioc)
+{
+       ioc->cbfn->enable_cbfn(ioc->bfa, BFA_STATUS_IOC_FAILURE);
+}
+
 /**
- * Notify enable completion callback and generate mismatch AEN.
+ * Hardware initialization failed.
  */
 static void
-bfa_ioc_sm_mismatch_entry(struct bfa_ioc_s *ioc)
+bfa_ioc_sm_initfail(struct bfa_ioc_s *ioc, enum ioc_event event)
 {
+       bfa_trc(ioc, event);
+
+       switch (event) {
+       case IOC_E_ENABLED:
+               bfa_fsm_set_state(ioc, bfa_ioc_sm_getattr);
+               break;
+
+       case IOC_E_FAILED:
+               /**
+                * Initialization failure during iocpf init retry.
+                */
+               ioc->cbfn->enable_cbfn(ioc->bfa, BFA_STATUS_IOC_FAILURE);
+               break;
+
+       case IOC_E_DISABLE:
+               bfa_fsm_set_state(ioc, bfa_ioc_sm_disabling);
+               break;
+
+       case IOC_E_DETACH:
+               bfa_fsm_set_state(ioc, bfa_ioc_sm_uninit);
+               bfa_iocpf_stop(ioc);
+               break;
+
+       default:
+               bfa_sm_fault(ioc, event);
+       }
+}
+
+
+static void
+bfa_ioc_sm_fail_entry(struct bfa_ioc_s *ioc)
+{
+       struct list_head                        *qe;
+       struct bfa_ioc_hbfail_notify_s  *notify;
+       struct bfad_s *bfad = (struct bfad_s *)ioc->bfa->bfad;
+
        /**
-        * Provide enable completion callback and AEN notification only once.
+        * Notify driver and common modules registered for notification.
         */
-       if (ioc->retry_count == 0) {
-               ioc->cbfn->enable_cbfn(ioc->bfa, BFA_STATUS_IOC_FAILURE);
-               bfa_ioc_aen_post(ioc, BFA_IOC_AEN_FWMISMATCH);
+       ioc->cbfn->hbfail_cbfn(ioc->bfa);
+       list_for_each(qe, &ioc->hb_notify_q) {
+               notify = (struct bfa_ioc_hbfail_notify_s *) qe;
+               notify->cbfn(notify->cbarg);
        }
-       ioc->retry_count++;
-       bfa_ioc_timer_start(ioc);
+
+       BFA_LOG(KERN_CRIT, bfad, log_level,
+               "Heart Beat of IOC has failed\n");
 }
 
 /**
- * Awaiting firmware version match.
+ * IOC failure.
  */
 static void
-bfa_ioc_sm_mismatch(struct bfa_ioc_s *ioc, enum ioc_event event)
+bfa_ioc_sm_fail(struct bfa_ioc_s *ioc, enum ioc_event event)
 {
        bfa_trc(ioc, event);
 
        switch (event) {
-       case IOC_E_TIMEOUT:
-               bfa_fsm_set_state(ioc, bfa_ioc_sm_fwcheck);
+
+       case IOC_E_FAILED:
+               /**
+                * Initialization failure during iocpf recovery.
+                * !!! Fall through !!!
+                */
+       case IOC_E_ENABLE:
+               ioc->cbfn->enable_cbfn(ioc->bfa, BFA_STATUS_IOC_FAILURE);
+               break;
+
+       case IOC_E_ENABLED:
+               bfa_fsm_set_state(ioc, bfa_ioc_sm_getattr);
                break;
 
        case IOC_E_DISABLE:
-               bfa_ioc_disable_comp(ioc);
+               bfa_fsm_set_state(ioc, bfa_ioc_sm_disabling);
+               break;
+
+       case IOC_E_HWERROR:
                /*
-                * fall through
+                * HB failure notification, ignore.
                 */
+               break;
+       default:
+               bfa_sm_fault(ioc, event);
+       }
+}
 
-       case IOC_E_DETACH:
-               bfa_ioc_timer_stop(ioc);
-               bfa_fsm_set_state(ioc, bfa_ioc_sm_reset);
+
+
+/**
+ * IOCPF State Machine
+ */
+
+
+/**
+ * Reset entry actions -- initialize state machine
+ */
+static void
+bfa_iocpf_sm_reset_entry(struct bfa_iocpf_s *iocpf)
+{
+       iocpf->retry_count = 0;
+       iocpf->auto_recover = bfa_auto_recover;
+}
+
+/**
+ * Beginning state. IOC is in reset state.
+ */
+static void
+bfa_iocpf_sm_reset(struct bfa_iocpf_s *iocpf, enum iocpf_event event)
+{
+       struct bfa_ioc_s *ioc = iocpf->ioc;
+
+       bfa_trc(ioc, event);
+
+       switch (event) {
+       case IOCPF_E_ENABLE:
+               bfa_fsm_set_state(iocpf, bfa_iocpf_sm_fwcheck);
                break;
 
-       case IOC_E_FWREADY:
+       case IOCPF_E_STOP:
                break;
 
        default:
@@ -269,31 +647,44 @@ bfa_ioc_sm_mismatch(struct bfa_ioc_s *ioc, enum ioc_event event)
 }
 
 /**
- * Request for semaphore.
+ * Semaphore should be acquired for version check.
  */
 static void
-bfa_ioc_sm_semwait_entry(struct bfa_ioc_s *ioc)
+bfa_iocpf_sm_fwcheck_entry(struct bfa_iocpf_s *iocpf)
 {
-       bfa_ioc_hw_sem_get(ioc);
+       bfa_ioc_hw_sem_get(iocpf->ioc);
 }
 
 /**
- * Awaiting semaphore for h/w initialzation.
+ * Awaiting h/w semaphore to continue with version check.
  */
 static void
-bfa_ioc_sm_semwait(struct bfa_ioc_s *ioc, enum ioc_event event)
+bfa_iocpf_sm_fwcheck(struct bfa_iocpf_s *iocpf, enum iocpf_event event)
 {
+       struct bfa_ioc_s *ioc = iocpf->ioc;
+
        bfa_trc(ioc, event);
 
        switch (event) {
-       case IOC_E_SEMLOCKED:
-               ioc->retry_count = 0;
-               bfa_fsm_set_state(ioc, bfa_ioc_sm_hwinit);
+       case IOCPF_E_SEMLOCKED:
+               if (bfa_ioc_firmware_lock(ioc)) {
+                       iocpf->retry_count = 0;
+                       bfa_fsm_set_state(iocpf, bfa_iocpf_sm_hwinit);
+               } else {
+                       bfa_ioc_hw_sem_release(ioc);
+                       bfa_fsm_set_state(iocpf, bfa_iocpf_sm_mismatch);
+               }
                break;
 
-       case IOC_E_DISABLE:
+       case IOCPF_E_DISABLE:
                bfa_ioc_hw_sem_get_cancel(ioc);
-               bfa_fsm_set_state(ioc, bfa_ioc_sm_disabled);
+               bfa_fsm_set_state(iocpf, bfa_iocpf_sm_reset);
+               bfa_ioc_pf_disabled(ioc);
+               break;
+
+       case IOCPF_E_STOP:
+               bfa_ioc_hw_sem_get_cancel(ioc);
+               bfa_fsm_set_state(iocpf, bfa_iocpf_sm_reset);
                break;
 
        default:
@@ -301,51 +692,81 @@ bfa_ioc_sm_semwait(struct bfa_ioc_s *ioc, enum ioc_event event)
        }
 }
 
-
+/**
+ * Notify enable completion callback.
+ */
 static void
-bfa_ioc_sm_hwinit_entry(struct bfa_ioc_s *ioc)
+bfa_iocpf_sm_mismatch_entry(struct bfa_iocpf_s *iocpf)
 {
-       bfa_ioc_timer_start(ioc);
-       bfa_ioc_reset(ioc, BFA_FALSE);
+       /*
+        * Call only the first time sm enters fwmismatch state.
+        */
+       if (iocpf->retry_count == 0)
+               bfa_ioc_pf_fwmismatch(iocpf->ioc);
+
+       iocpf->retry_count++;
+       bfa_iocpf_timer_start(iocpf->ioc);
 }
 
 /**
- * Hardware is being initialized. Interrupts are enabled.
- * Holding hardware semaphore lock.
+ * Awaiting firmware version match.
  */
 static void
-bfa_ioc_sm_hwinit(struct bfa_ioc_s *ioc, enum ioc_event event)
+bfa_iocpf_sm_mismatch(struct bfa_iocpf_s *iocpf, enum iocpf_event event)
 {
+       struct bfa_ioc_s *ioc = iocpf->ioc;
+
        bfa_trc(ioc, event);
 
        switch (event) {
-       case IOC_E_FWREADY:
-               bfa_ioc_timer_stop(ioc);
-               bfa_fsm_set_state(ioc, bfa_ioc_sm_enabling);
+       case IOCPF_E_TIMEOUT:
+               bfa_fsm_set_state(iocpf, bfa_iocpf_sm_fwcheck);
                break;
 
-       case IOC_E_HWERROR:
-               bfa_ioc_timer_stop(ioc);
-               /*
-                * fall through
-                */
+       case IOCPF_E_DISABLE:
+               bfa_iocpf_timer_stop(ioc);
+               bfa_fsm_set_state(iocpf, bfa_iocpf_sm_reset);
+               bfa_ioc_pf_disabled(ioc);
+               break;
 
-       case IOC_E_TIMEOUT:
-               ioc->retry_count++;
-               if (ioc->retry_count < BFA_IOC_HWINIT_MAX) {
-                       bfa_ioc_timer_start(ioc);
-                       bfa_ioc_reset(ioc, BFA_TRUE);
-                       break;
-               }
+       case IOCPF_E_STOP:
+               bfa_iocpf_timer_stop(ioc);
+               bfa_fsm_set_state(iocpf, bfa_iocpf_sm_reset);
+               break;
 
-               bfa_ioc_hw_sem_release(ioc);
-               bfa_fsm_set_state(ioc, bfa_ioc_sm_initfail);
+       default:
+               bfa_sm_fault(ioc, event);
+       }
+}
+
+/**
+ * Request for semaphore.
+ */
+static void
+bfa_iocpf_sm_semwait_entry(struct bfa_iocpf_s *iocpf)
+{
+       bfa_ioc_hw_sem_get(iocpf->ioc);
+}
+
+/**
+ * Awaiting semaphore for h/w initialzation.
+ */
+static void
+bfa_iocpf_sm_semwait(struct bfa_iocpf_s *iocpf, enum iocpf_event event)
+{
+       struct bfa_ioc_s *ioc = iocpf->ioc;
+
+       bfa_trc(ioc, event);
+
+       switch (event) {
+       case IOCPF_E_SEMLOCKED:
+               iocpf->retry_count = 0;
+               bfa_fsm_set_state(iocpf, bfa_iocpf_sm_hwinit);
                break;
 
-       case IOC_E_DISABLE:
-               bfa_ioc_hw_sem_release(ioc);
-               bfa_ioc_timer_stop(ioc);
-               bfa_fsm_set_state(ioc, bfa_ioc_sm_disabled);
+       case IOCPF_E_DISABLE:
+               bfa_ioc_hw_sem_get_cancel(ioc);
+               bfa_fsm_set_state(iocpf, bfa_iocpf_sm_disabled);
                break;
 
        default:
@@ -355,55 +776,54 @@ bfa_ioc_sm_hwinit(struct bfa_ioc_s *ioc, enum ioc_event event)
 
 
 static void
-bfa_ioc_sm_enabling_entry(struct bfa_ioc_s *ioc)
+bfa_iocpf_sm_hwinit_entry(struct bfa_iocpf_s *iocpf)
 {
-       bfa_ioc_timer_start(ioc);
-       bfa_ioc_send_enable(ioc);
+       bfa_iocpf_timer_start(iocpf->ioc);
+       bfa_ioc_reset(iocpf->ioc, BFA_FALSE);
 }
 
 /**
- * Host IOC function is being enabled, awaiting response from firmware.
- * Semaphore is acquired.
+ * Hardware is being initialized. Interrupts are enabled.
+ * Holding hardware semaphore lock.
  */
 static void
-bfa_ioc_sm_enabling(struct bfa_ioc_s *ioc, enum ioc_event event)
+bfa_iocpf_sm_hwinit(struct bfa_iocpf_s *iocpf, enum iocpf_event event)
 {
+       struct bfa_ioc_s *ioc = iocpf->ioc;
+
        bfa_trc(ioc, event);
 
        switch (event) {
-       case IOC_E_FWRSP_ENABLE:
-               bfa_ioc_timer_stop(ioc);
-               bfa_ioc_hw_sem_release(ioc);
-               bfa_fsm_set_state(ioc, bfa_ioc_sm_getattr);
+       case IOCPF_E_FWREADY:
+               bfa_iocpf_timer_stop(ioc);
+               bfa_fsm_set_state(iocpf, bfa_iocpf_sm_enabling);
                break;
 
-       case IOC_E_HWERROR:
-               bfa_ioc_timer_stop(ioc);
+       case IOCPF_E_INITFAIL:
+               bfa_iocpf_timer_stop(ioc);
                /*
-                * fall through
+                * !!! fall through !!!
                 */
 
-       case IOC_E_TIMEOUT:
-               ioc->retry_count++;
-               if (ioc->retry_count < BFA_IOC_HWINIT_MAX) {
-                       bfa_reg_write(ioc->ioc_regs.ioc_fwstate,
-                                     BFI_IOC_UNINIT);
-                       bfa_fsm_set_state(ioc, bfa_ioc_sm_hwinit);
+       case IOCPF_E_TIMEOUT:
+               iocpf->retry_count++;
+               if (iocpf->retry_count < BFA_IOC_HWINIT_MAX) {
+                       bfa_iocpf_timer_start(ioc);
+                       bfa_ioc_reset(ioc, BFA_TRUE);
                        break;
                }
 
                bfa_ioc_hw_sem_release(ioc);
-               bfa_fsm_set_state(ioc, bfa_ioc_sm_initfail);
-               break;
+               bfa_fsm_set_state(iocpf, bfa_iocpf_sm_initfail);
 
-       case IOC_E_DISABLE:
-               bfa_ioc_timer_stop(ioc);
-               bfa_ioc_hw_sem_release(ioc);
-               bfa_fsm_set_state(ioc, bfa_ioc_sm_disabled);
+               if (event == IOCPF_E_TIMEOUT)
+                       bfa_ioc_pf_failed(ioc);
                break;
 
-       case IOC_E_FWREADY:
-               bfa_ioc_send_enable(ioc);
+       case IOCPF_E_DISABLE:
+               bfa_ioc_hw_sem_release(ioc);
+               bfa_iocpf_timer_stop(ioc);
+               bfa_fsm_set_state(iocpf, bfa_iocpf_sm_disabled);
                break;
 
        default:
@@ -413,40 +833,60 @@ bfa_ioc_sm_enabling(struct bfa_ioc_s *ioc, enum ioc_event event)
 
 
 static void
-bfa_ioc_sm_getattr_entry(struct bfa_ioc_s *ioc)
+bfa_iocpf_sm_enabling_entry(struct bfa_iocpf_s *iocpf)
 {
-       bfa_ioc_timer_start(ioc);
-       bfa_ioc_send_getattr(ioc);
+       bfa_iocpf_timer_start(iocpf->ioc);
+       bfa_ioc_send_enable(iocpf->ioc);
 }
 
 /**
- * IOC configuration in progress. Timer is active.
+ * Host IOC function is being enabled, awaiting response from firmware.
+ * Semaphore is acquired.
  */
 static void
-bfa_ioc_sm_getattr(struct bfa_ioc_s *ioc, enum ioc_event event)
+bfa_iocpf_sm_enabling(struct bfa_iocpf_s *iocpf, enum iocpf_event event)
 {
+       struct bfa_ioc_s *ioc = iocpf->ioc;
+
        bfa_trc(ioc, event);
 
        switch (event) {
-       case IOC_E_FWRSP_GETATTR:
-               bfa_ioc_timer_stop(ioc);
-               bfa_ioc_check_attr_wwns(ioc);
-               bfa_fsm_set_state(ioc, bfa_ioc_sm_op);
+       case IOCPF_E_FWRSP_ENABLE:
+               bfa_iocpf_timer_stop(ioc);
+               bfa_ioc_hw_sem_release(ioc);
+               bfa_fsm_set_state(iocpf, bfa_iocpf_sm_ready);
                break;
 
-       case IOC_E_HWERROR:
-               bfa_ioc_timer_stop(ioc);
+       case IOCPF_E_INITFAIL:
+               bfa_iocpf_timer_stop(ioc);
                /*
-                * fall through
+                * !!! fall through !!!
                 */
 
-       case IOC_E_TIMEOUT:
-               bfa_fsm_set_state(ioc, bfa_ioc_sm_initfail);
+       case IOCPF_E_TIMEOUT:
+               iocpf->retry_count++;
+               if (iocpf->retry_count < BFA_IOC_HWINIT_MAX) {
+                       bfa_reg_write(ioc->ioc_regs.ioc_fwstate,
+                                     BFI_IOC_UNINIT);
+                       bfa_fsm_set_state(iocpf, bfa_iocpf_sm_hwinit);
+                       break;
+               }
+
+               bfa_ioc_hw_sem_release(ioc);
+               bfa_fsm_set_state(iocpf, bfa_iocpf_sm_initfail);
+
+               if (event == IOCPF_E_TIMEOUT)
+                       bfa_ioc_pf_failed(ioc);
                break;
 
-       case IOC_E_DISABLE:
-               bfa_ioc_timer_stop(ioc);
-               bfa_fsm_set_state(ioc, bfa_ioc_sm_disabled);
+       case IOCPF_E_DISABLE:
+               bfa_iocpf_timer_stop(ioc);
+               bfa_ioc_hw_sem_release(ioc);
+               bfa_fsm_set_state(iocpf, bfa_iocpf_sm_disabling);
+               break;
+
+       case IOCPF_E_FWREADY:
+               bfa_ioc_send_enable(ioc);
                break;
 
        default:
@@ -455,41 +895,40 @@ bfa_ioc_sm_getattr(struct bfa_ioc_s *ioc, enum ioc_event event)
 }
 
 
+
 static void
-bfa_ioc_sm_op_entry(struct bfa_ioc_s *ioc)
+bfa_iocpf_sm_ready_entry(struct bfa_iocpf_s *iocpf)
 {
-       ioc->cbfn->enable_cbfn(ioc->bfa, BFA_STATUS_OK);
-       bfa_ioc_hb_monitor(ioc);
-       bfa_ioc_aen_post(ioc, BFA_IOC_AEN_ENABLE);
+       bfa_ioc_pf_enabled(iocpf->ioc);
 }
 
 static void
-bfa_ioc_sm_op(struct bfa_ioc_s *ioc, enum ioc_event event)
+bfa_iocpf_sm_ready(struct bfa_iocpf_s *iocpf, enum iocpf_event event)
 {
+       struct bfa_ioc_s *ioc = iocpf->ioc;
+
        bfa_trc(ioc, event);
 
        switch (event) {
-       case IOC_E_ENABLE:
+       case IOCPF_E_DISABLE:
+               bfa_fsm_set_state(iocpf, bfa_iocpf_sm_disabling);
+               break;
+
+       case IOCPF_E_GETATTRFAIL:
+               bfa_fsm_set_state(iocpf, bfa_iocpf_sm_initfail);
                break;
 
-       case IOC_E_DISABLE:
-               bfa_ioc_hb_stop(ioc);
-               bfa_fsm_set_state(ioc, bfa_ioc_sm_disabling);
+       case IOCPF_E_FAIL:
+               bfa_fsm_set_state(iocpf, bfa_iocpf_sm_fail);
                break;
 
-       case IOC_E_HWERROR:
-       case IOC_E_FWREADY:
-               /**
-                * Hard error or IOC recovery by other function.
-                * Treat it same as heartbeat failure.
-                */
-               bfa_ioc_hb_stop(ioc);
-               /*
-                * !!! fall through !!!
-                */
+       case IOCPF_E_FWREADY:
+               if (bfa_ioc_is_operational(ioc))
+                       bfa_fsm_set_state(iocpf, bfa_iocpf_sm_fail);
+               else
+                       bfa_fsm_set_state(iocpf, bfa_iocpf_sm_initfail);
 
-       case IOC_E_HBFAIL:
-               bfa_fsm_set_state(ioc, bfa_ioc_sm_hbfail);
+               bfa_ioc_pf_failed(ioc);
                break;
 
        default:
@@ -499,36 +938,41 @@ bfa_ioc_sm_op(struct bfa_ioc_s *ioc, enum ioc_event event)
 
 
 static void
-bfa_ioc_sm_disabling_entry(struct bfa_ioc_s *ioc)
+bfa_iocpf_sm_disabling_entry(struct bfa_iocpf_s *iocpf)
 {
-       bfa_ioc_aen_post(ioc, BFA_IOC_AEN_DISABLE);
-       bfa_ioc_timer_start(ioc);
-       bfa_ioc_send_disable(ioc);
+       bfa_iocpf_timer_start(iocpf->ioc);
+       bfa_ioc_send_disable(iocpf->ioc);
 }
 
 /**
  * IOC is being disabled
  */
 static void
-bfa_ioc_sm_disabling(struct bfa_ioc_s *ioc, enum ioc_event event)
+bfa_iocpf_sm_disabling(struct bfa_iocpf_s *iocpf, enum iocpf_event event)
 {
+       struct bfa_ioc_s *ioc = iocpf->ioc;
+
        bfa_trc(ioc, event);
 
        switch (event) {
-       case IOC_E_FWRSP_DISABLE:
-               bfa_ioc_timer_stop(ioc);
-               bfa_fsm_set_state(ioc, bfa_ioc_sm_disabled);
+       case IOCPF_E_FWRSP_DISABLE:
+       case IOCPF_E_FWREADY:
+               bfa_iocpf_timer_stop(ioc);
+               bfa_fsm_set_state(iocpf, bfa_iocpf_sm_disabled);
                break;
 
-       case IOC_E_HWERROR:
-               bfa_ioc_timer_stop(ioc);
+       case IOCPF_E_FAIL:
+               bfa_iocpf_timer_stop(ioc);
                /*
                 * !!! fall through !!!
                 */
 
-       case IOC_E_TIMEOUT:
+       case IOCPF_E_TIMEOUT:
                bfa_reg_write(ioc->ioc_regs.ioc_fwstate, BFI_IOC_FAIL);
-               bfa_fsm_set_state(ioc, bfa_ioc_sm_disabled);
+               bfa_fsm_set_state(iocpf, bfa_iocpf_sm_disabled);
+               break;
+
+       case IOCPF_E_FWRSP_ENABLE:
                break;
 
        default:
@@ -540,31 +984,26 @@ bfa_ioc_sm_disabling(struct bfa_ioc_s *ioc, enum ioc_event event)
  * IOC disable completion entry.
  */
 static void
-bfa_ioc_sm_disabled_entry(struct bfa_ioc_s *ioc)
+bfa_iocpf_sm_disabled_entry(struct bfa_iocpf_s *iocpf)
 {
-       bfa_ioc_disable_comp(ioc);
+       bfa_ioc_pf_disabled(iocpf->ioc);
 }
 
 static void
-bfa_ioc_sm_disabled(struct bfa_ioc_s *ioc, enum ioc_event event)
+bfa_iocpf_sm_disabled(struct bfa_iocpf_s *iocpf, enum iocpf_event event)
 {
+       struct bfa_ioc_s *ioc = iocpf->ioc;
+
        bfa_trc(ioc, event);
 
        switch (event) {
-       case IOC_E_ENABLE:
-               bfa_fsm_set_state(ioc, bfa_ioc_sm_semwait);
-               break;
-
-       case IOC_E_DISABLE:
-               ioc->cbfn->disable_cbfn(ioc->bfa);
+       case IOCPF_E_ENABLE:
+               bfa_fsm_set_state(iocpf, bfa_iocpf_sm_semwait);
                break;
 
-       case IOC_E_FWREADY:
-               break;
-
-       case IOC_E_DETACH:
+       case IOCPF_E_STOP:
                bfa_ioc_firmware_unlock(ioc);
-               bfa_fsm_set_state(ioc, bfa_ioc_sm_reset);
+               bfa_fsm_set_state(iocpf, bfa_iocpf_sm_reset);
                break;
 
        default:
@@ -574,34 +1013,35 @@ bfa_ioc_sm_disabled(struct bfa_ioc_s *ioc, enum ioc_event event)
 
 
 static void
-bfa_ioc_sm_initfail_entry(struct bfa_ioc_s *ioc)
+bfa_iocpf_sm_initfail_entry(struct bfa_iocpf_s *iocpf)
 {
-       ioc->cbfn->enable_cbfn(ioc->bfa, BFA_STATUS_IOC_FAILURE);
-       bfa_ioc_timer_start(ioc);
+       bfa_iocpf_timer_start(iocpf->ioc);
 }
 
 /**
  * Hardware initialization failed.
  */
 static void
-bfa_ioc_sm_initfail(struct bfa_ioc_s *ioc, enum ioc_event event)
+bfa_iocpf_sm_initfail(struct bfa_iocpf_s *iocpf, enum iocpf_event event)
 {
+       struct bfa_ioc_s *ioc = iocpf->ioc;
+
        bfa_trc(ioc, event);
 
        switch (event) {
-       case IOC_E_DISABLE:
-               bfa_ioc_timer_stop(ioc);
-               bfa_fsm_set_state(ioc, bfa_ioc_sm_disabled);
+       case IOCPF_E_DISABLE:
+               bfa_iocpf_timer_stop(ioc);
+               bfa_fsm_set_state(iocpf, bfa_iocpf_sm_disabled);
                break;
 
-       case IOC_E_DETACH:
-               bfa_ioc_timer_stop(ioc);
+       case IOCPF_E_STOP:
+               bfa_iocpf_timer_stop(ioc);
                bfa_ioc_firmware_unlock(ioc);
-               bfa_fsm_set_state(ioc, bfa_ioc_sm_reset);
+               bfa_fsm_set_state(iocpf, bfa_iocpf_sm_reset);
                break;
 
-       case IOC_E_TIMEOUT:
-               bfa_fsm_set_state(ioc, bfa_ioc_sm_semwait);
+       case IOCPF_E_TIMEOUT:
+               bfa_fsm_set_state(iocpf, bfa_iocpf_sm_semwait);
                break;
 
        default:
@@ -611,80 +1051,47 @@ bfa_ioc_sm_initfail(struct bfa_ioc_s *ioc, enum ioc_event event)
 
 
 static void
-bfa_ioc_sm_hbfail_entry(struct bfa_ioc_s *ioc)
+bfa_iocpf_sm_fail_entry(struct bfa_iocpf_s *iocpf)
 {
-       struct list_head *qe;
-       struct bfa_ioc_hbfail_notify_s *notify;
-
        /**
         * Mark IOC as failed in hardware and stop firmware.
         */
-       bfa_ioc_lpu_stop(ioc);
-       bfa_reg_write(ioc->ioc_regs.ioc_fwstate, BFI_IOC_FAIL);
+       bfa_ioc_lpu_stop(iocpf->ioc);
+       bfa_reg_write(iocpf->ioc->ioc_regs.ioc_fwstate, BFI_IOC_FAIL);
 
        /**
         * Notify other functions on HB failure.
         */
-       bfa_ioc_notify_hbfail(ioc);
-
-       /**
-        * Notify driver and common modules registered for notification.
-        */
-       ioc->cbfn->hbfail_cbfn(ioc->bfa);
-       list_for_each(qe, &ioc->hb_notify_q) {
-               notify = (struct bfa_ioc_hbfail_notify_s *)qe;
-               notify->cbfn(notify->cbarg);
-       }
+       bfa_ioc_notify_hbfail(iocpf->ioc);
 
        /**
         * Flush any queued up mailbox requests.
         */
-       bfa_ioc_mbox_hbfail(ioc);
-       bfa_ioc_aen_post(ioc, BFA_IOC_AEN_HBFAIL);
+       bfa_ioc_mbox_hbfail(iocpf->ioc);
 
-       /**
-        * Trigger auto-recovery after a delay.
-        */
-       if (ioc->auto_recover) {
-               bfa_timer_begin(ioc->timer_mod, &ioc->ioc_timer,
-                               bfa_ioc_timeout, ioc, BFA_IOC_TOV_RECOVER);
-       }
+       if (iocpf->auto_recover)
+               bfa_iocpf_recovery_timer_start(iocpf->ioc);
 }
 
 /**
- * IOC heartbeat failure.
+ * IOC is in failed state.
  */
 static void
-bfa_ioc_sm_hbfail(struct bfa_ioc_s *ioc, enum ioc_event event)
+bfa_iocpf_sm_fail(struct bfa_iocpf_s *iocpf, enum iocpf_event event)
 {
+       struct bfa_ioc_s *ioc = iocpf->ioc;
+
        bfa_trc(ioc, event);
 
        switch (event) {
-
-       case IOC_E_ENABLE:
-               ioc->cbfn->enable_cbfn(ioc->bfa, BFA_STATUS_IOC_FAILURE);
+       case IOCPF_E_DISABLE:
+               if (iocpf->auto_recover)
+                       bfa_iocpf_timer_stop(ioc);
+               bfa_fsm_set_state(iocpf, bfa_iocpf_sm_disabled);
                break;
 
-       case IOC_E_DISABLE:
-               if (ioc->auto_recover)
-                       bfa_ioc_timer_stop(ioc);
-               bfa_fsm_set_state(ioc, bfa_ioc_sm_disabled);
-               break;
-
-       case IOC_E_TIMEOUT:
-               bfa_fsm_set_state(ioc, bfa_ioc_sm_semwait);
-               break;
-
-       case IOC_E_FWREADY:
-               /**
-                * Recovery is already initiated by other function.
-                */
-               break;
-
-       case IOC_E_HWERROR:
-               /*
-                * HB failure notification, ignore.
-                */
+       case IOCPF_E_TIMEOUT:
+               bfa_fsm_set_state(iocpf, bfa_iocpf_sm_semwait);
                break;
 
        default:
@@ -695,14 +1102,14 @@ bfa_ioc_sm_hbfail(struct bfa_ioc_s *ioc, enum ioc_event event)
 
 
 /**
- *  bfa_ioc_pvt BFA IOC private functions
+ *  hal_ioc_pvt BFA IOC private functions
  */
 
 static void
 bfa_ioc_disable_comp(struct bfa_ioc_s *ioc)
 {
-       struct list_head *qe;
-       struct bfa_ioc_hbfail_notify_s *notify;
+       struct list_head                        *qe;
+       struct bfa_ioc_hbfail_notify_s  *notify;
 
        ioc->cbfn->disable_cbfn(ioc->bfa);
 
@@ -710,25 +1117,17 @@ bfa_ioc_disable_comp(struct bfa_ioc_s *ioc)
         * Notify common modules registered for notification.
         */
        list_for_each(qe, &ioc->hb_notify_q) {
-               notify = (struct bfa_ioc_hbfail_notify_s *)qe;
+               notify = (struct bfa_ioc_hbfail_notify_s *) qe;
                notify->cbfn(notify->cbarg);
        }
 }
 
-void
-bfa_ioc_sem_timeout(void *ioc_arg)
-{
-       struct bfa_ioc_s *ioc = (struct bfa_ioc_s *)ioc_arg;
-
-       bfa_ioc_hw_sem_get(ioc);
-}
-
 bfa_boolean_t
 bfa_ioc_sem_get(bfa_os_addr_t sem_reg)
 {
        u32 r32;
        int cnt = 0;
-#define BFA_SEM_SPINCNT 3000
+#define BFA_SEM_SPINCNT        3000
 
        r32 = bfa_reg_read(sem_reg);
 
@@ -754,7 +1153,7 @@ bfa_ioc_sem_release(bfa_os_addr_t sem_reg)
 static void
 bfa_ioc_hw_sem_get(struct bfa_ioc_s *ioc)
 {
-       u32        r32;
+       u32     r32;
 
        /**
         * First read to the semaphore register will return 0, subsequent reads
@@ -762,12 +1161,11 @@ bfa_ioc_hw_sem_get(struct bfa_ioc_s *ioc)
         */
        r32 = bfa_reg_read(ioc->ioc_regs.ioc_sem_reg);
        if (r32 == 0) {
-               bfa_fsm_send_event(ioc, IOC_E_SEMLOCKED);
+               bfa_fsm_send_event(&ioc->iocpf, IOCPF_E_SEMLOCKED);
                return;
        }
 
-       bfa_timer_begin(ioc->timer_mod, &ioc->sem_timer, bfa_ioc_sem_timeout,
-                       ioc, BFA_IOC_HWSEM_TOV);
+       bfa_sem_timer_start(ioc);
 }
 
 void
@@ -779,7 +1177,7 @@ bfa_ioc_hw_sem_release(struct bfa_ioc_s *ioc)
 static void
 bfa_ioc_hw_sem_get_cancel(struct bfa_ioc_s *ioc)
 {
-       bfa_timer_stop(&ioc->sem_timer);
+       bfa_sem_timer_stop(ioc);
 }
 
 /**
@@ -788,14 +1186,18 @@ bfa_ioc_hw_sem_get_cancel(struct bfa_ioc_s *ioc)
 static void
 bfa_ioc_lmem_init(struct bfa_ioc_s *ioc)
 {
-       u32        pss_ctl;
-       int             i;
+       u32     pss_ctl;
+       int             i;
 #define PSS_LMEM_INIT_TIME  10000
 
        pss_ctl = bfa_reg_read(ioc->ioc_regs.pss_ctl_reg);
        pss_ctl &= ~__PSS_LMEM_RESET;
        pss_ctl |= __PSS_LMEM_INIT_EN;
-       pss_ctl |= __PSS_I2C_CLK_DIV(3UL); /* i2c workaround 12.5khz clock */
+
+       /*
+        * i2c workaround 12.5khz clock
+        */
+       pss_ctl |= __PSS_I2C_CLK_DIV(3UL);
        bfa_reg_write(ioc->ioc_regs.pss_ctl_reg, pss_ctl);
 
        /**
@@ -821,7 +1223,7 @@ bfa_ioc_lmem_init(struct bfa_ioc_s *ioc)
 static void
 bfa_ioc_lpu_start(struct bfa_ioc_s *ioc)
 {
-       u32        pss_ctl;
+       u32     pss_ctl;
 
        /**
         * Take processor out of reset.
@@ -835,7 +1237,7 @@ bfa_ioc_lpu_start(struct bfa_ioc_s *ioc)
 static void
 bfa_ioc_lpu_stop(struct bfa_ioc_s *ioc)
 {
-       u32        pss_ctl;
+       u32     pss_ctl;
 
        /**
         * Put processors in reset.
@@ -852,10 +1254,10 @@ bfa_ioc_lpu_stop(struct bfa_ioc_s *ioc)
 void
 bfa_ioc_fwver_get(struct bfa_ioc_s *ioc, struct bfi_ioc_image_hdr_s *fwhdr)
 {
-       u32        pgnum, pgoff;
-       u32        loff = 0;
-       int             i;
-       u32       *fwsig = (u32 *) fwhdr;
+       u32     pgnum, pgoff;
+       u32     loff = 0;
+       int             i;
+       u32     *fwsig = (u32 *) fwhdr;
 
        pgnum = bfa_ioc_smem_pgnum(ioc, loff);
        pgoff = bfa_ioc_smem_pgoff(ioc, loff);
@@ -863,7 +1265,8 @@ bfa_ioc_fwver_get(struct bfa_ioc_s *ioc, struct bfi_ioc_image_hdr_s *fwhdr)
 
        for (i = 0; i < (sizeof(struct bfi_ioc_image_hdr_s) / sizeof(u32));
             i++) {
-               fwsig[i] = bfa_mem_read(ioc->ioc_regs.smem_page_start, loff);
+               fwsig[i] =
+                       bfa_mem_read(ioc->ioc_regs.smem_page_start, loff);
                loff += sizeof(u32);
        }
 }
@@ -875,10 +1278,10 @@ bfa_boolean_t
 bfa_ioc_fwver_cmp(struct bfa_ioc_s *ioc, struct bfi_ioc_image_hdr_s *fwhdr)
 {
        struct bfi_ioc_image_hdr_s *drv_fwhdr;
-       int             i;
+       int i;
 
        drv_fwhdr = (struct bfi_ioc_image_hdr_s *)
-                       bfi_image_get_chunk(BFA_IOC_FWIMG_TYPE(ioc), 0);
+               bfa_cb_image_get_chunk(BFA_IOC_FWIMG_TYPE(ioc), 0);
 
        for (i = 0; i < BFI_IOC_MD5SUM_SZ; i++) {
                if (fwhdr->md5sum[i] != drv_fwhdr->md5sum[i]) {
@@ -897,21 +1300,20 @@ bfa_ioc_fwver_cmp(struct bfa_ioc_s *ioc, struct bfi_ioc_image_hdr_s *fwhdr)
  * Return true if current running version is valid. Firmware signature and
  * execution context (driver/bios) must match.
  */
-static          bfa_boolean_t
-bfa_ioc_fwver_valid(struct bfa_ioc_s *ioc)
+static bfa_boolean_t
+bfa_ioc_fwver_valid(struct bfa_ioc_s *ioc, u32 boot_env)
 {
        struct bfi_ioc_image_hdr_s fwhdr, *drv_fwhdr;
 
        /**
         * If bios/efi boot (flash based) -- return true
         */
-       if (bfa_ioc_is_optrom(ioc))
+       if (bfa_ioc_is_bios_optrom(ioc))
                return BFA_TRUE;
 
        bfa_ioc_fwver_get(ioc, &fwhdr);
        drv_fwhdr = (struct bfi_ioc_image_hdr_s *)
-                       bfi_image_get_chunk(BFA_IOC_FWIMG_TYPE(ioc), 0);
-
+               bfa_cb_image_get_chunk(BFA_IOC_FWIMG_TYPE(ioc), 0);
 
        if (fwhdr.signature != drv_fwhdr->signature) {
                bfa_trc(ioc, fwhdr.signature);
@@ -919,9 +1321,9 @@ bfa_ioc_fwver_valid(struct bfa_ioc_s *ioc)
                return BFA_FALSE;
        }
 
-       if (fwhdr.exec != drv_fwhdr->exec) {
-               bfa_trc(ioc, fwhdr.exec);
-               bfa_trc(ioc, drv_fwhdr->exec);
+       if (bfa_os_swap32(fwhdr.param) != boot_env) {
+               bfa_trc(ioc, fwhdr.param);
+               bfa_trc(ioc, boot_env);
                return BFA_FALSE;
        }
 
@@ -934,7 +1336,7 @@ bfa_ioc_fwver_valid(struct bfa_ioc_s *ioc)
 static void
 bfa_ioc_msgflush(struct bfa_ioc_s *ioc)
 {
-       u32        r32;
+       u32     r32;
 
        r32 = bfa_reg_read(ioc->ioc_regs.lpu_mbox_cmd);
        if (r32)
@@ -946,7 +1348,9 @@ static void
 bfa_ioc_hwinit(struct bfa_ioc_s *ioc, bfa_boolean_t force)
 {
        enum bfi_ioc_state ioc_fwstate;
-       bfa_boolean_t   fwvalid;
+       bfa_boolean_t fwvalid;
+       u32 boot_type;
+       u32 boot_env;
 
        ioc_fwstate = bfa_reg_read(ioc->ioc_regs.ioc_fwstate);
 
@@ -955,14 +1359,33 @@ bfa_ioc_hwinit(struct bfa_ioc_s *ioc, bfa_boolean_t force)
 
        bfa_trc(ioc, ioc_fwstate);
 
+       boot_type = BFI_BOOT_TYPE_NORMAL;
+       boot_env = BFI_BOOT_LOADER_OS;
+
+       /**
+        * Flash based firmware boot BIOS env.
+        */
+       if (bfa_ioc_is_bios_optrom(ioc)) {
+               boot_type = BFI_BOOT_TYPE_FLASH;
+               boot_env = BFI_BOOT_LOADER_BIOS;
+       }
+
+       /**
+        * Flash based firmware boot UEFI env.
+        */
+       if (bfa_ioc_is_uefi(ioc)) {
+               boot_type = BFI_BOOT_TYPE_FLASH;
+               boot_env = BFI_BOOT_LOADER_UEFI;
+       }
+
        /**
         * check if firmware is valid
         */
        fwvalid = (ioc_fwstate == BFI_IOC_UNINIT) ?
-                       BFA_FALSE : bfa_ioc_fwver_valid(ioc);
+               BFA_FALSE : bfa_ioc_fwver_valid(ioc, boot_env);
 
        if (!fwvalid) {
-               bfa_ioc_boot(ioc, BFI_BOOT_TYPE_NORMAL, ioc->pcidev.device_id);
+               bfa_ioc_boot(ioc, boot_type, boot_env);
                return;
        }
 
@@ -971,7 +1394,6 @@ bfa_ioc_hwinit(struct bfa_ioc_s *ioc, bfa_boolean_t force)
         * just wait for an initialization completion interrupt.
         */
        if (ioc_fwstate == BFI_IOC_INITING) {
-               bfa_trc(ioc, ioc_fwstate);
                ioc->cbfn->reset_cbfn(ioc->bfa);
                return;
        }
@@ -985,8 +1407,7 @@ bfa_ioc_hwinit(struct bfa_ioc_s *ioc, bfa_boolean_t force)
         * is loaded.
         */
        if (ioc_fwstate == BFI_IOC_DISABLED ||
-               (!bfa_ioc_is_optrom(ioc) && ioc_fwstate == BFI_IOC_OP)) {
-               bfa_trc(ioc, ioc_fwstate);
+           (!bfa_ioc_is_bios_optrom(ioc) && ioc_fwstate == BFI_IOC_OP)) {
 
                /**
                 * When using MSI-X any pending firmware ready event should
@@ -994,20 +1415,20 @@ bfa_ioc_hwinit(struct bfa_ioc_s *ioc, bfa_boolean_t force)
                 */
                bfa_ioc_msgflush(ioc);
                ioc->cbfn->reset_cbfn(ioc->bfa);
-               bfa_fsm_send_event(ioc, IOC_E_FWREADY);
+               bfa_fsm_send_event(&ioc->iocpf, IOCPF_E_FWREADY);
                return;
        }
 
        /**
         * Initialize the h/w for any other states.
         */
-       bfa_ioc_boot(ioc, BFI_BOOT_TYPE_NORMAL, ioc->pcidev.device_id);
+       bfa_ioc_boot(ioc, boot_type, boot_env);
 }
 
 static void
 bfa_ioc_timeout(void *ioc_arg)
 {
-       struct bfa_ioc_s *ioc = (struct bfa_ioc_s *)ioc_arg;
+       struct bfa_ioc_s  *ioc = (struct bfa_ioc_s *) ioc_arg;
 
        bfa_trc(ioc, 0);
        bfa_fsm_send_event(ioc, IOC_E_TIMEOUT);
@@ -1016,8 +1437,8 @@ bfa_ioc_timeout(void *ioc_arg)
 void
 bfa_ioc_mbox_send(struct bfa_ioc_s *ioc, void *ioc_msg, int len)
 {
-       u32       *msgp = (u32 *) ioc_msg;
-       u32        i;
+       u32 *msgp = (u32 *) ioc_msg;
+       u32 i;
 
        bfa_trc(ioc, msgp[0]);
        bfa_trc(ioc, len);
@@ -1038,17 +1459,20 @@ bfa_ioc_mbox_send(struct bfa_ioc_s *ioc, void *ioc_msg, int len)
         * write 1 to mailbox CMD to trigger LPU event
         */
        bfa_reg_write(ioc->ioc_regs.hfn_mbox_cmd, 1);
-       (void)bfa_reg_read(ioc->ioc_regs.hfn_mbox_cmd);
+       (void) bfa_reg_read(ioc->ioc_regs.hfn_mbox_cmd);
 }
 
 static void
 bfa_ioc_send_enable(struct bfa_ioc_s *ioc)
 {
        struct bfi_ioc_ctrl_req_s enable_req;
+       struct bfa_timeval_s tv;
 
        bfi_h2i_set(enable_req.mh, BFI_MC_IOC, BFI_IOC_H2I_ENABLE_REQ,
                    bfa_ioc_portid(ioc));
        enable_req.ioc_class = ioc->ioc_mc;
+       bfa_os_gettimeofday(&tv);
+       enable_req.tv_sec = bfa_os_ntohl(tv.tv_sec);
        bfa_ioc_mbox_send(ioc, &enable_req, sizeof(struct bfi_ioc_ctrl_req_s));
 }
 
@@ -1065,7 +1489,7 @@ bfa_ioc_send_disable(struct bfa_ioc_s *ioc)
 static void
 bfa_ioc_send_getattr(struct bfa_ioc_s *ioc)
 {
-       struct bfi_ioc_getattr_req_s attr_req;
+       struct bfi_ioc_getattr_req_s    attr_req;
 
        bfi_h2i_set(attr_req.mh, BFI_MC_IOC, BFI_IOC_H2I_GETATTR_REQ,
                    bfa_ioc_portid(ioc));
@@ -1077,12 +1501,11 @@ static void
 bfa_ioc_hb_check(void *cbarg)
 {
        struct bfa_ioc_s  *ioc = cbarg;
-       u32     hb_count;
+       u32     hb_count;
 
        hb_count = bfa_reg_read(ioc->ioc_regs.heartbeat);
        if (ioc->hb_count == hb_count) {
-               bfa_log(ioc->logm, BFA_LOG_HAL_HEARTBEAT_FAILURE,
-                       hb_count);
+               printk(KERN_CRIT "Firmware heartbeat failure at %d", hb_count);
                bfa_ioc_recover(ioc);
                return;
        } else {
@@ -1090,61 +1513,54 @@ bfa_ioc_hb_check(void *cbarg)
        }
 
        bfa_ioc_mbox_poll(ioc);
-       bfa_timer_begin(ioc->timer_mod, &ioc->ioc_timer, bfa_ioc_hb_check,
-                       ioc, BFA_IOC_HB_TOV);
+       bfa_hb_timer_start(ioc);
 }
 
 static void
 bfa_ioc_hb_monitor(struct bfa_ioc_s *ioc)
 {
        ioc->hb_count = bfa_reg_read(ioc->ioc_regs.heartbeat);
-       bfa_timer_begin(ioc->timer_mod, &ioc->ioc_timer, bfa_ioc_hb_check, ioc,
-                       BFA_IOC_HB_TOV);
+       bfa_hb_timer_start(ioc);
 }
 
 static void
 bfa_ioc_hb_stop(struct bfa_ioc_s *ioc)
 {
-       bfa_timer_stop(&ioc->ioc_timer);
+       bfa_hb_timer_stop(ioc);
 }
 
+
 /**
- *      Initiate a full firmware download.
+ *     Initiate a full firmware download.
  */
 static void
 bfa_ioc_download_fw(struct bfa_ioc_s *ioc, u32 boot_type,
-                   u32 boot_param)
+                   u32 boot_env)
 {
-       u32       *fwimg;
-       u32        pgnum, pgoff;
-       u32        loff = 0;
-       u32        chunkno = 0;
-       u32        i;
+       u32 *fwimg;
+       u32 pgnum, pgoff;
+       u32 loff = 0;
+       u32 chunkno = 0;
+       u32 i;
 
        /**
         * Initialize LMEM first before code download
         */
        bfa_ioc_lmem_init(ioc);
 
-       /**
-        * Flash based firmware boot
-        */
-       bfa_trc(ioc, bfi_image_get_size(BFA_IOC_FWIMG_TYPE(ioc)));
-       if (bfa_ioc_is_optrom(ioc))
-               boot_type = BFI_BOOT_TYPE_FLASH;
-       fwimg = bfi_image_get_chunk(BFA_IOC_FWIMG_TYPE(ioc), chunkno);
-
+       bfa_trc(ioc, bfa_cb_image_get_size(BFA_IOC_FWIMG_TYPE(ioc)));
+       fwimg = bfa_cb_image_get_chunk(BFA_IOC_FWIMG_TYPE(ioc), chunkno);
 
        pgnum = bfa_ioc_smem_pgnum(ioc, loff);
        pgoff = bfa_ioc_smem_pgoff(ioc, loff);
 
        bfa_reg_write(ioc->ioc_regs.host_page_num_fn, pgnum);
 
-       for (i = 0; i < bfi_image_get_size(BFA_IOC_FWIMG_TYPE(ioc)); i++) {
+       for (i = 0; i < bfa_cb_image_get_size(BFA_IOC_FWIMG_TYPE(ioc)); i++) {
 
                if (BFA_IOC_FLASH_CHUNK_NO(i) != chunkno) {
                        chunkno = BFA_IOC_FLASH_CHUNK_NO(i);
-                       fwimg = bfi_image_get_chunk(BFA_IOC_FWIMG_TYPE(ioc),
+                       fwimg = bfa_cb_image_get_chunk(BFA_IOC_FWIMG_TYPE(ioc),
                                        BFA_IOC_FLASH_CHUNK_ADDR(chunkno));
                }
 
@@ -1162,7 +1578,8 @@ bfa_ioc_download_fw(struct bfa_ioc_s *ioc, u32 boot_type,
                loff = PSS_SMEM_PGOFF(loff);
                if (loff == 0) {
                        pgnum++;
-                       bfa_reg_write(ioc->ioc_regs.host_page_num_fn, pgnum);
+                       bfa_reg_write(ioc->ioc_regs.host_page_num_fn,
+                                     pgnum);
                }
        }
 
@@ -1171,105 +1588,274 @@ bfa_ioc_download_fw(struct bfa_ioc_s *ioc, u32 boot_type,
 
        /*
         * Set boot type and boot param at the end.
-        */
+       */
        bfa_mem_write(ioc->ioc_regs.smem_page_start, BFI_BOOT_TYPE_OFF,
                        bfa_os_swap32(boot_type));
-       bfa_mem_write(ioc->ioc_regs.smem_page_start, BFI_BOOT_PARAM_OFF,
-                       bfa_os_swap32(boot_param));
+       bfa_mem_write(ioc->ioc_regs.smem_page_start, BFI_BOOT_LOADER_OFF,
+                       bfa_os_swap32(boot_env));
+}
+
+static void
+bfa_ioc_reset(struct bfa_ioc_s *ioc, bfa_boolean_t force)
+{
+       bfa_ioc_hwinit(ioc, force);
+}
+
+/**
+ * Update BFA configuration from firmware configuration.
+ */
+static void
+bfa_ioc_getattr_reply(struct bfa_ioc_s *ioc)
+{
+       struct bfi_ioc_attr_s   *attr = ioc->attr;
+
+       attr->adapter_prop  = bfa_os_ntohl(attr->adapter_prop);
+       attr->card_type     = bfa_os_ntohl(attr->card_type);
+       attr->maxfrsize     = bfa_os_ntohs(attr->maxfrsize);
+
+       bfa_fsm_send_event(ioc, IOC_E_FWRSP_GETATTR);
+}
+
+/**
+ * Attach time initialization of mbox logic.
+ */
+static void
+bfa_ioc_mbox_attach(struct bfa_ioc_s *ioc)
+{
+       struct bfa_ioc_mbox_mod_s       *mod = &ioc->mbox_mod;
+       int     mc;
+
+       INIT_LIST_HEAD(&mod->cmd_q);
+       for (mc = 0; mc < BFI_MC_MAX; mc++) {
+               mod->mbhdlr[mc].cbfn = NULL;
+               mod->mbhdlr[mc].cbarg = ioc->bfa;
+       }
+}
+
+/**
+ * Mbox poll timer -- restarts any pending mailbox requests.
+ */
+static void
+bfa_ioc_mbox_poll(struct bfa_ioc_s *ioc)
+{
+       struct bfa_ioc_mbox_mod_s       *mod = &ioc->mbox_mod;
+       struct bfa_mbox_cmd_s           *cmd;
+       u32                     stat;
+
+       /**
+        * If no command pending, do nothing
+        */
+       if (list_empty(&mod->cmd_q))
+               return;
+
+       /**
+        * If previous command is not yet fetched by firmware, do nothing
+        */
+       stat = bfa_reg_read(ioc->ioc_regs.hfn_mbox_cmd);
+       if (stat)
+               return;
+
+       /**
+        * Enqueue command to firmware.
+        */
+       bfa_q_deq(&mod->cmd_q, &cmd);
+       bfa_ioc_mbox_send(ioc, cmd->msg, sizeof(cmd->msg));
+}
+
+/**
+ * Cleanup any pending requests.
+ */
+static void
+bfa_ioc_mbox_hbfail(struct bfa_ioc_s *ioc)
+{
+       struct bfa_ioc_mbox_mod_s       *mod = &ioc->mbox_mod;
+       struct bfa_mbox_cmd_s           *cmd;
+
+       while (!list_empty(&mod->cmd_q))
+               bfa_q_deq(&mod->cmd_q, &cmd);
+}
+
+/**
+ * Read data from SMEM to host through PCI memmap
+ *
+ * @param[in]  ioc     memory for IOC
+ * @param[in]  tbuf    app memory to store data from smem
+ * @param[in]  soff    smem offset
+ * @param[in]  sz      size of smem in bytes
+ */
+static bfa_status_t
+bfa_ioc_smem_read(struct bfa_ioc_s *ioc, void *tbuf, u32 soff, u32 sz)
+{
+       u32 pgnum, loff, r32;
+       int i, len;
+       u32 *buf = tbuf;
+
+       pgnum = bfa_ioc_smem_pgnum(ioc, soff);
+       loff = bfa_ioc_smem_pgoff(ioc, soff);
+       bfa_trc(ioc, pgnum);
+       bfa_trc(ioc, loff);
+       bfa_trc(ioc, sz);
+
+       /*
+        *  Hold semaphore to serialize pll init and fwtrc.
+        */
+       if (BFA_FALSE == bfa_ioc_sem_get(ioc->ioc_regs.ioc_init_sem_reg)) {
+               bfa_trc(ioc, 0);
+               return BFA_STATUS_FAILED;
+       }
+
+       bfa_reg_write(ioc->ioc_regs.host_page_num_fn, pgnum);
+
+       len = sz/sizeof(u32);
+       bfa_trc(ioc, len);
+       for (i = 0; i < len; i++) {
+               r32 = bfa_mem_read(ioc->ioc_regs.smem_page_start, loff);
+               buf[i] = bfa_os_ntohl(r32);
+               loff += sizeof(u32);
+
+               /**
+                * handle page offset wrap around
+                */
+               loff = PSS_SMEM_PGOFF(loff);
+               if (loff == 0) {
+                       pgnum++;
+                       bfa_reg_write(ioc->ioc_regs.host_page_num_fn, pgnum);
+               }
+       }
+       bfa_reg_write(ioc->ioc_regs.host_page_num_fn,
+                     bfa_ioc_smem_pgnum(ioc, 0));
+       /*
+        *  release semaphore.
+        */
+       bfa_ioc_sem_release(ioc->ioc_regs.ioc_init_sem_reg);
+
+       bfa_trc(ioc, pgnum);
+       return BFA_STATUS_OK;
+}
+
+/**
+ * Clear SMEM data from host through PCI memmap
+ *
+ * @param[in]  ioc     memory for IOC
+ * @param[in]  soff    smem offset
+ * @param[in]  sz      size of smem in bytes
+ */
+static bfa_status_t
+bfa_ioc_smem_clr(struct bfa_ioc_s *ioc, u32 soff, u32 sz)
+{
+       int i, len;
+       u32 pgnum, loff;
+
+       pgnum = bfa_ioc_smem_pgnum(ioc, soff);
+       loff = bfa_ioc_smem_pgoff(ioc, soff);
+       bfa_trc(ioc, pgnum);
+       bfa_trc(ioc, loff);
+       bfa_trc(ioc, sz);
+
+       /*
+        *  Hold semaphore to serialize pll init and fwtrc.
+        */
+       if (BFA_FALSE == bfa_ioc_sem_get(ioc->ioc_regs.ioc_init_sem_reg)) {
+               bfa_trc(ioc, 0);
+               return BFA_STATUS_FAILED;
+       }
+
+       bfa_reg_write(ioc->ioc_regs.host_page_num_fn, pgnum);
+
+       len = sz/sizeof(u32); /* len in words */
+       bfa_trc(ioc, len);
+       for (i = 0; i < len; i++) {
+               bfa_mem_write(ioc->ioc_regs.smem_page_start, loff, 0);
+               loff += sizeof(u32);
+
+               /**
+                * handle page offset wrap around
+                */
+               loff = PSS_SMEM_PGOFF(loff);
+               if (loff == 0) {
+                       pgnum++;
+                       bfa_reg_write(ioc->ioc_regs.host_page_num_fn, pgnum);
+               }
+       }
+       bfa_reg_write(ioc->ioc_regs.host_page_num_fn,
+                     bfa_ioc_smem_pgnum(ioc, 0));
+
+       /*
+        *  release semaphore.
+        */
+       bfa_ioc_sem_release(ioc->ioc_regs.ioc_init_sem_reg);
+       bfa_trc(ioc, pgnum);
+       return BFA_STATUS_OK;
 }
 
+/**
+ * hal iocpf to ioc interface
+ */
 static void
-bfa_ioc_reset(struct bfa_ioc_s *ioc, bfa_boolean_t force)
+bfa_ioc_pf_enabled(struct bfa_ioc_s *ioc)
 {
-       bfa_ioc_hwinit(ioc, force);
+       bfa_fsm_send_event(ioc, IOC_E_ENABLED);
 }
 
-/**
- * Update BFA configuration from firmware configuration.
- */
 static void
-bfa_ioc_getattr_reply(struct bfa_ioc_s *ioc)
+bfa_ioc_pf_disabled(struct bfa_ioc_s *ioc)
 {
-       struct bfi_ioc_attr_s *attr = ioc->attr;
-
-       attr->adapter_prop = bfa_os_ntohl(attr->adapter_prop);
-       attr->card_type     = bfa_os_ntohl(attr->card_type);
-       attr->maxfrsize = bfa_os_ntohs(attr->maxfrsize);
-
-       bfa_fsm_send_event(ioc, IOC_E_FWRSP_GETATTR);
+       bfa_fsm_send_event(ioc, IOC_E_DISABLED);
 }
 
-/**
- * Attach time initialization of mbox logic.
- */
 static void
-bfa_ioc_mbox_attach(struct bfa_ioc_s *ioc)
+bfa_ioc_pf_failed(struct bfa_ioc_s *ioc)
 {
-       struct bfa_ioc_mbox_mod_s *mod = &ioc->mbox_mod;
-       int             mc;
-
-       INIT_LIST_HEAD(&mod->cmd_q);
-       for (mc = 0; mc < BFI_MC_MAX; mc++) {
-               mod->mbhdlr[mc].cbfn = NULL;
-               mod->mbhdlr[mc].cbarg = ioc->bfa;
-       }
+       bfa_fsm_send_event(ioc, IOC_E_FAILED);
 }
 
-/**
- * Mbox poll timer -- restarts any pending mailbox requests.
- */
 static void
-bfa_ioc_mbox_poll(struct bfa_ioc_s *ioc)
+bfa_ioc_pf_fwmismatch(struct bfa_ioc_s *ioc)
 {
-       struct bfa_ioc_mbox_mod_s *mod = &ioc->mbox_mod;
-       struct bfa_mbox_cmd_s *cmd;
-       u32        stat;
-
+       struct bfad_s *bfad = (struct bfad_s *)ioc->bfa->bfad;
        /**
-        * If no command pending, do nothing
+        * Provide enable completion callback.
         */
-       if (list_empty(&mod->cmd_q))
-               return;
+       ioc->cbfn->enable_cbfn(ioc->bfa, BFA_STATUS_IOC_FAILURE);
+       BFA_LOG(KERN_WARNING, bfad, log_level,
+               "Running firmware version is incompatible "
+               "with the driver version\n");
+}
 
-       /**
-        * If previous command is not yet fetched by firmware, do nothing
-        */
-       stat = bfa_reg_read(ioc->ioc_regs.hfn_mbox_cmd);
-       if (stat)
-               return;
 
-       /**
-        * Enqueue command to firmware.
-        */
-       bfa_q_deq(&mod->cmd_q, &cmd);
-       bfa_ioc_mbox_send(ioc, cmd->msg, sizeof(cmd->msg));
-}
 
 /**
- * Cleanup any pending requests.
+ *  hal_ioc_public
  */
-static void
-bfa_ioc_mbox_hbfail(struct bfa_ioc_s *ioc)
+
+bfa_status_t
+bfa_ioc_pll_init(struct bfa_ioc_s *ioc)
 {
-       struct bfa_ioc_mbox_mod_s *mod = &ioc->mbox_mod;
-       struct bfa_mbox_cmd_s *cmd;
 
-       while (!list_empty(&mod->cmd_q))
-               bfa_q_deq(&mod->cmd_q, &cmd);
-}
+       /*
+        *  Hold semaphore so that nobody can access the chip during init.
+        */
+       bfa_ioc_sem_get(ioc->ioc_regs.ioc_init_sem_reg);
 
-/**
- *  bfa_ioc_public
- */
+       bfa_ioc_pll_init_asic(ioc);
+
+       ioc->pllinit = BFA_TRUE;
+       /*
+        *  release semaphore.
+        */
+       bfa_ioc_sem_release(ioc->ioc_regs.ioc_init_sem_reg);
+
+       return BFA_STATUS_OK;
+}
 
 /**
  * Interface used by diag module to do firmware boot with memory test
  * as the entry vector.
  */
 void
-bfa_ioc_boot(struct bfa_ioc_s *ioc, u32 boot_type, u32 boot_param)
+bfa_ioc_boot(struct bfa_ioc_s *ioc, u32 boot_type, u32 boot_env)
 {
-       bfa_os_addr_t   rb;
+       bfa_os_addr_t   rb;
 
        bfa_ioc_stats(ioc, ioc_boots);
 
@@ -1280,7 +1866,7 @@ bfa_ioc_boot(struct bfa_ioc_s *ioc, u32 boot_type, u32 boot_param)
         * Initialize IOC state of all functions on a chip reset.
         */
        rb = ioc->pcidev.pci_bar_kva;
-       if (boot_param == BFI_BOOT_TYPE_MEMTEST) {
+       if (boot_type == BFI_BOOT_TYPE_MEMTEST) {
                bfa_reg_write((rb + BFA_IOC0_STATE_REG), BFI_IOC_MEMTEST);
                bfa_reg_write((rb + BFA_IOC1_STATE_REG), BFI_IOC_MEMTEST);
        } else {
@@ -1289,7 +1875,7 @@ bfa_ioc_boot(struct bfa_ioc_s *ioc, u32 boot_type, u32 boot_param)
        }
 
        bfa_ioc_msgflush(ioc);
-       bfa_ioc_download_fw(ioc, boot_type, boot_param);
+       bfa_ioc_download_fw(ioc, boot_type, boot_env);
 
        /**
         * Enable interrupts just before starting LPU
@@ -1308,18 +1894,29 @@ bfa_ioc_auto_recover(bfa_boolean_t auto_recover)
 }
 
 
+
 bfa_boolean_t
 bfa_ioc_is_operational(struct bfa_ioc_s *ioc)
 {
        return bfa_fsm_cmp_state(ioc, bfa_ioc_sm_op);
 }
 
+bfa_boolean_t
+bfa_ioc_is_initialized(struct bfa_ioc_s *ioc)
+{
+       u32 r32 = bfa_reg_read(ioc->ioc_regs.ioc_fwstate);
+
+       return ((r32 != BFI_IOC_UNINIT) &&
+               (r32 != BFI_IOC_INITING) &&
+               (r32 != BFI_IOC_MEMTEST));
+}
+
 void
 bfa_ioc_msgget(struct bfa_ioc_s *ioc, void *mbmsg)
 {
-       u32       *msgp = mbmsg;
-       u32        r32;
-       int             i;
+       u32     *msgp = mbmsg;
+       u32     r32;
+       int             i;
 
        /**
         * read the MBOX msg
@@ -1341,9 +1938,10 @@ bfa_ioc_msgget(struct bfa_ioc_s *ioc, void *mbmsg)
 void
 bfa_ioc_isr(struct bfa_ioc_s *ioc, struct bfi_mbmsg_s *m)
 {
-       union bfi_ioc_i2h_msg_u *msg;
+       union bfi_ioc_i2h_msg_u *msg;
+       struct bfa_iocpf_s *iocpf = &ioc->iocpf;
 
-       msg = (union bfi_ioc_i2h_msg_u *)m;
+       msg = (union bfi_ioc_i2h_msg_u *) m;
 
        bfa_ioc_stats(ioc, ioc_isrs);
 
@@ -1352,15 +1950,15 @@ bfa_ioc_isr(struct bfa_ioc_s *ioc, struct bfi_mbmsg_s *m)
                break;
 
        case BFI_IOC_I2H_READY_EVENT:
-               bfa_fsm_send_event(ioc, IOC_E_FWREADY);
+               bfa_fsm_send_event(iocpf, IOCPF_E_FWREADY);
                break;
 
        case BFI_IOC_I2H_ENABLE_REPLY:
-               bfa_fsm_send_event(ioc, IOC_E_FWRSP_ENABLE);
+               bfa_fsm_send_event(iocpf, IOCPF_E_FWRSP_ENABLE);
                break;
 
        case BFI_IOC_I2H_DISABLE_REPLY:
-               bfa_fsm_send_event(ioc, IOC_E_FWRSP_DISABLE);
+               bfa_fsm_send_event(iocpf, IOCPF_E_FWRSP_DISABLE);
                break;
 
        case BFI_IOC_I2H_GETATTR_REPLY:
@@ -1378,29 +1976,24 @@ bfa_ioc_isr(struct bfa_ioc_s *ioc, struct bfi_mbmsg_s *m)
  *
  * @param[in]  ioc     memory for IOC
  * @param[in]  bfa     driver instance structure
- * @param[in]  trcmod  kernel trace module
- * @param[in]  aen     kernel aen event module
- * @param[in]  logm    kernel logging module
  */
 void
 bfa_ioc_attach(struct bfa_ioc_s *ioc, void *bfa, struct bfa_ioc_cbfn_s *cbfn,
-              struct bfa_timer_mod_s *timer_mod, struct bfa_trc_mod_s *trcmod,
-              struct bfa_aen_s *aen, struct bfa_log_mod_s *logm)
-{
-       ioc->bfa = bfa;
-       ioc->cbfn = cbfn;
-       ioc->timer_mod = timer_mod;
-       ioc->trcmod = trcmod;
-       ioc->aen = aen;
-       ioc->logm = logm;
-       ioc->fcmode = BFA_FALSE;
-       ioc->pllinit = BFA_FALSE;
+              struct bfa_timer_mod_s *timer_mod)
+{
+       ioc->bfa        = bfa;
+       ioc->cbfn       = cbfn;
+       ioc->timer_mod  = timer_mod;
+       ioc->fcmode     = BFA_FALSE;
+       ioc->pllinit    = BFA_FALSE;
        ioc->dbg_fwsave_once = BFA_TRUE;
+       ioc->iocpf.ioc  = ioc;
 
        bfa_ioc_mbox_attach(ioc);
        INIT_LIST_HEAD(&ioc->hb_notify_q);
 
-       bfa_fsm_set_state(ioc, bfa_ioc_sm_reset);
+       bfa_fsm_set_state(ioc, bfa_ioc_sm_uninit);
+       bfa_fsm_send_event(ioc, IOC_E_RESET);
 }
 
 /**
@@ -1421,10 +2014,10 @@ void
 bfa_ioc_pci_init(struct bfa_ioc_s *ioc, struct bfa_pcidev_s *pcidev,
                 enum bfi_mclass mc)
 {
-       ioc->ioc_mc = mc;
-       ioc->pcidev = *pcidev;
-       ioc->ctdev  = bfa_asic_id_ct(ioc->pcidev.device_id);
-       ioc->cna = ioc->ctdev && !ioc->fcmode;
+       ioc->ioc_mc     = mc;
+       ioc->pcidev     = *pcidev;
+       ioc->ctdev      = bfa_asic_id_ct(ioc->pcidev.device_id);
+       ioc->cna        = ioc->ctdev && !ioc->fcmode;
 
        /**
         * Set asic specific interfaces. See bfa_ioc_cb.c and bfa_ioc_ct.c
@@ -1445,14 +2038,14 @@ bfa_ioc_pci_init(struct bfa_ioc_s *ioc, struct bfa_pcidev_s *pcidev,
  * @param[in]  dm_pa   physical address of IOC dma memory
  */
 void
-bfa_ioc_mem_claim(struct bfa_ioc_s *ioc, u8 *dm_kva, u64 dm_pa)
+bfa_ioc_mem_claim(struct bfa_ioc_s *ioc,  u8 *dm_kva, u64 dm_pa)
 {
        /**
         * dma memory for firmware attribute
         */
        ioc->attr_dma.kva = dm_kva;
        ioc->attr_dma.pa = dm_pa;
-       ioc->attr = (struct bfi_ioc_attr_s *)dm_kva;
+       ioc->attr = (struct bfi_ioc_attr_s *) dm_kva;
 }
 
 /**
@@ -1490,7 +2083,7 @@ bfa_ioc_disable(struct bfa_ioc_s *ioc)
 int
 bfa_ioc_debug_trcsz(bfa_boolean_t auto_recover)
 {
-return (auto_recover) ? BFA_DBG_FWTRC_LEN : 0;
+       return (auto_recover) ? BFA_DBG_FWTRC_LEN : 0;
 }
 
 /**
@@ -1500,8 +2093,8 @@ return (auto_recover) ? BFA_DBG_FWTRC_LEN : 0;
 void
 bfa_ioc_debug_memclaim(struct bfa_ioc_s *ioc, void *dbg_fwsave)
 {
-       ioc->dbg_fwsave = dbg_fwsave;
-       ioc->dbg_fwsave_len = bfa_ioc_debug_trcsz(ioc->auto_recover);
+       ioc->dbg_fwsave     = dbg_fwsave;
+       ioc->dbg_fwsave_len = bfa_ioc_debug_trcsz(ioc->iocpf.auto_recover);
 }
 
 u32
@@ -1525,8 +2118,8 @@ bfa_ioc_smem_pgoff(struct bfa_ioc_s *ioc, u32 fmaddr)
 void
 bfa_ioc_mbox_register(struct bfa_ioc_s *ioc, bfa_ioc_mbox_mcfunc_t *mcfuncs)
 {
-       struct bfa_ioc_mbox_mod_s *mod = &ioc->mbox_mod;
-       int             mc;
+       struct bfa_ioc_mbox_mod_s       *mod = &ioc->mbox_mod;
+       int                             mc;
 
        for (mc = 0; mc < BFI_MC_MAX; mc++)
                mod->mbhdlr[mc].cbfn = mcfuncs[mc];
@@ -1539,10 +2132,10 @@ void
 bfa_ioc_mbox_regisr(struct bfa_ioc_s *ioc, enum bfi_mclass mc,
                    bfa_ioc_mbox_mcfunc_t cbfn, void *cbarg)
 {
-       struct bfa_ioc_mbox_mod_s *mod = &ioc->mbox_mod;
+       struct bfa_ioc_mbox_mod_s       *mod = &ioc->mbox_mod;
 
-       mod->mbhdlr[mc].cbfn = cbfn;
-       mod->mbhdlr[mc].cbarg = cbarg;
+       mod->mbhdlr[mc].cbfn    = cbfn;
+       mod->mbhdlr[mc].cbarg   = cbarg;
 }
 
 /**
@@ -1555,8 +2148,8 @@ bfa_ioc_mbox_regisr(struct bfa_ioc_s *ioc, enum bfi_mclass mc,
 void
 bfa_ioc_mbox_queue(struct bfa_ioc_s *ioc, struct bfa_mbox_cmd_s *cmd)
 {
-       struct bfa_ioc_mbox_mod_s *mod = &ioc->mbox_mod;
-       u32        stat;
+       struct bfa_ioc_mbox_mod_s       *mod = &ioc->mbox_mod;
+       u32                     stat;
 
        /**
         * If a previous command is pending, queue new command
@@ -1587,9 +2180,9 @@ bfa_ioc_mbox_queue(struct bfa_ioc_s *ioc, struct bfa_mbox_cmd_s *cmd)
 void
 bfa_ioc_mbox_isr(struct bfa_ioc_s *ioc)
 {
-       struct bfa_ioc_mbox_mod_s *mod = &ioc->mbox_mod;
-       struct bfi_mbmsg_s m;
-       int             mc;
+       struct bfa_ioc_mbox_mod_s       *mod = &ioc->mbox_mod;
+       struct bfi_mbmsg_s              m;
+       int                             mc;
 
        bfa_ioc_msgget(ioc, &m);
 
@@ -1621,16 +2214,14 @@ bfa_ioc_set_fcmode(struct bfa_ioc_s *ioc)
        ioc->port_id = bfa_ioc_pcifn(ioc);
 }
 
-#ifndef BFA_BIOS_BUILD
-
 /**
  * return true if IOC is disabled
  */
 bfa_boolean_t
 bfa_ioc_is_disabled(struct bfa_ioc_s *ioc)
 {
-       return bfa_fsm_cmp_state(ioc, bfa_ioc_sm_disabling)
-               || bfa_fsm_cmp_state(ioc, bfa_ioc_sm_disabled);
+       return bfa_fsm_cmp_state(ioc, bfa_ioc_sm_disabling) ||
+               bfa_fsm_cmp_state(ioc, bfa_ioc_sm_disabled);
 }
 
 /**
@@ -1639,9 +2230,9 @@ bfa_ioc_is_disabled(struct bfa_ioc_s *ioc)
 bfa_boolean_t
 bfa_ioc_fw_mismatch(struct bfa_ioc_s *ioc)
 {
-       return bfa_fsm_cmp_state(ioc, bfa_ioc_sm_reset)
-               || bfa_fsm_cmp_state(ioc, bfa_ioc_sm_fwcheck)
-               || bfa_fsm_cmp_state(ioc, bfa_ioc_sm_mismatch);
+       return bfa_fsm_cmp_state(ioc, bfa_ioc_sm_reset) ||
+               bfa_fsm_cmp_state(&ioc->iocpf, bfa_iocpf_sm_fwcheck) ||
+               bfa_fsm_cmp_state(&ioc->iocpf, bfa_iocpf_sm_mismatch);
 }
 
 #define bfa_ioc_state_disabled(__sm)           \
@@ -1659,8 +2250,8 @@ bfa_ioc_fw_mismatch(struct bfa_ioc_s *ioc)
 bfa_boolean_t
 bfa_ioc_adapter_is_disabled(struct bfa_ioc_s *ioc)
 {
-       u32        ioc_state;
-       bfa_os_addr_t   rb = ioc->pcidev.pci_bar_kva;
+       u32     ioc_state;
+       bfa_os_addr_t   rb = ioc->pcidev.pci_bar_kva;
 
        if (!bfa_fsm_cmp_state(ioc, bfa_ioc_sm_disabled))
                return BFA_FALSE;
@@ -1669,16 +2260,18 @@ bfa_ioc_adapter_is_disabled(struct bfa_ioc_s *ioc)
        if (!bfa_ioc_state_disabled(ioc_state))
                return BFA_FALSE;
 
-       ioc_state = bfa_reg_read(rb + BFA_IOC1_STATE_REG);
-       if (!bfa_ioc_state_disabled(ioc_state))
-               return BFA_FALSE;
+       if (ioc->pcidev.device_id != BFA_PCI_DEVICE_ID_FC_8G1P) {
+               ioc_state = bfa_reg_read(rb + BFA_IOC1_STATE_REG);
+               if (!bfa_ioc_state_disabled(ioc_state))
+                       return BFA_FALSE;
+       }
 
        return BFA_TRUE;
 }
 
 /**
  * Add to IOC heartbeat failure notification queue. To be used by common
- * modules such as
+ * modules such as cee, port, diag.
  */
 void
 bfa_ioc_hbfail_register(struct bfa_ioc_s *ioc,
@@ -1692,7 +2285,7 @@ void
 bfa_ioc_get_adapter_attr(struct bfa_ioc_s *ioc,
                         struct bfa_adapter_attr_s *ad_attr)
 {
-       struct bfi_ioc_attr_s *ioc_attr;
+       struct bfi_ioc_attr_s   *ioc_attr;
 
        ioc_attr = ioc->attr;
 
@@ -1719,7 +2312,7 @@ bfa_ioc_get_adapter_attr(struct bfa_ioc_s *ioc,
                ad_attr->prototype = 0;
 
        ad_attr->pwwn = bfa_ioc_get_pwwn(ioc);
-       ad_attr->mac = bfa_ioc_get_mac(ioc);
+       ad_attr->mac  = bfa_ioc_get_mac(ioc);
 
        ad_attr->pcie_gen = ioc_attr->pcie_gen;
        ad_attr->pcie_lanes = ioc_attr->pcie_lanes;
@@ -1729,6 +2322,7 @@ bfa_ioc_get_adapter_attr(struct bfa_ioc_s *ioc,
        bfa_ioc_get_pci_chip_rev(ioc, ad_attr->hw_ver);
 
        ad_attr->cna_capable = ioc->cna;
+       ad_attr->trunk_capable = (ad_attr->nports > 1) && !ioc->cna;
 }
 
 enum bfa_ioc_type_e
@@ -1782,7 +2376,7 @@ bfa_ioc_get_adapter_optrom_ver(struct bfa_ioc_s *ioc, char *optrom_ver)
 {
        bfa_os_memset((void *)optrom_ver, 0, BFA_VERSION_LEN);
        bfa_os_memcpy(optrom_ver, ioc->attr->optrom_version,
-               BFA_VERSION_LEN);
+                     BFA_VERSION_LEN);
 }
 
 void
@@ -1795,7 +2389,7 @@ bfa_ioc_get_adapter_manufacturer(struct bfa_ioc_s *ioc, char *manufacturer)
 void
 bfa_ioc_get_adapter_model(struct bfa_ioc_s *ioc, char *model)
 {
-       struct bfi_ioc_attr_s   *ioc_attr;
+       struct bfi_ioc_attr_s   *ioc_attr;
 
        bfa_assert(model);
        bfa_os_memset((void *)model, 0, BFA_ADAPTER_MODEL_NAME_LEN);
@@ -1805,14 +2399,48 @@ bfa_ioc_get_adapter_model(struct bfa_ioc_s *ioc, char *model)
        /**
         * model name
         */
-       snprintf(model, BFA_ADAPTER_MODEL_NAME_LEN, "%s-%u",
-                       BFA_MFG_NAME, ioc_attr->card_type);
+       bfa_os_snprintf(model, BFA_ADAPTER_MODEL_NAME_LEN, "%s-%u",
+               BFA_MFG_NAME, ioc_attr->card_type);
 }
 
 enum bfa_ioc_state
 bfa_ioc_get_state(struct bfa_ioc_s *ioc)
 {
-       return bfa_sm_to_state(ioc_sm_table, ioc->fsm);
+       enum bfa_iocpf_state iocpf_st;
+       enum bfa_ioc_state ioc_st = bfa_sm_to_state(ioc_sm_table, ioc->fsm);
+
+       if (ioc_st == BFA_IOC_ENABLING ||
+               ioc_st == BFA_IOC_FAIL || ioc_st == BFA_IOC_INITFAIL) {
+
+               iocpf_st = bfa_sm_to_state(iocpf_sm_table, ioc->iocpf.fsm);
+
+               switch (iocpf_st) {
+               case BFA_IOCPF_SEMWAIT:
+                       ioc_st = BFA_IOC_SEMWAIT;
+                       break;
+
+               case BFA_IOCPF_HWINIT:
+                       ioc_st = BFA_IOC_HWINIT;
+                       break;
+
+               case BFA_IOCPF_FWMISMATCH:
+                       ioc_st = BFA_IOC_FWMISMATCH;
+                       break;
+
+               case BFA_IOCPF_FAIL:
+                       ioc_st = BFA_IOC_FAIL;
+                       break;
+
+               case BFA_IOCPF_INITFAIL:
+                       ioc_st = BFA_IOC_INITFAIL;
+                       break;
+
+               default:
+                       break;
+               }
+       }
+
+       return ioc_st;
 }
 
 void
@@ -1833,7 +2461,7 @@ bfa_ioc_get_attr(struct bfa_ioc_s *ioc, struct bfa_ioc_attr_s *ioc_attr)
 }
 
 /**
- *  bfa_wwn_public
+ *  hal_wwn_public
  */
 wwn_t
 bfa_ioc_get_pwwn(struct bfa_ioc_s *ioc)
@@ -1857,10 +2485,10 @@ mac_t
 bfa_ioc_get_mac(struct bfa_ioc_s *ioc)
 {
        /*
-        * Currently mfg mac is used as FCoE enode mac (not configured by PBC)
+        * Check the IOC type and return the appropriate MAC
         */
        if (bfa_ioc_get_type(ioc) == BFA_IOC_TYPE_FCoE)
-               return bfa_ioc_get_mfg_mac(ioc);
+               return ioc->attr->fcoe_mac;
        else
                return ioc->attr->mac;
 }
@@ -1880,12 +2508,16 @@ bfa_ioc_get_mfg_nwwn(struct bfa_ioc_s *ioc)
 mac_t
 bfa_ioc_get_mfg_mac(struct bfa_ioc_s *ioc)
 {
-       mac_t   mac;
+       mac_t   m;
 
-       mac = ioc->attr->mfg_mac;
-       mac.mac[MAC_ADDRLEN - 1] += bfa_ioc_pcifn(ioc);
+       m = ioc->attr->mfg_mac;
+       if (bfa_mfg_is_old_wwn_mac_model(ioc->attr->card_type))
+               m.mac[MAC_ADDRLEN - 1] += bfa_ioc_pcifn(ioc);
+       else
+               bfa_mfg_increment_wwn_mac(&(m.mac[MAC_ADDRLEN-3]),
+                       bfa_ioc_pcifn(ioc));
 
-       return mac;
+       return m;
 }
 
 bfa_boolean_t
@@ -1894,47 +2526,13 @@ bfa_ioc_get_fcmode(struct bfa_ioc_s *ioc)
        return ioc->fcmode || !bfa_asic_id_ct(ioc->pcidev.device_id);
 }
 
-/**
- * Send AEN notification
- */
-void
-bfa_ioc_aen_post(struct bfa_ioc_s *ioc, enum bfa_ioc_aen_event event)
-{
-       union bfa_aen_data_u aen_data;
-       struct bfa_log_mod_s *logmod = ioc->logm;
-       s32         inst_num = 0;
-       enum bfa_ioc_type_e ioc_type;
-
-       bfa_log(logmod, BFA_LOG_CREATE_ID(BFA_AEN_CAT_IOC, event), inst_num);
-
-       memset(&aen_data.ioc.pwwn, 0, sizeof(aen_data.ioc.pwwn));
-       memset(&aen_data.ioc.mac, 0, sizeof(aen_data.ioc.mac));
-       ioc_type = bfa_ioc_get_type(ioc);
-       switch (ioc_type) {
-       case BFA_IOC_TYPE_FC:
-               aen_data.ioc.pwwn = bfa_ioc_get_pwwn(ioc);
-               break;
-       case BFA_IOC_TYPE_FCoE:
-               aen_data.ioc.pwwn = bfa_ioc_get_pwwn(ioc);
-               aen_data.ioc.mac = bfa_ioc_get_mac(ioc);
-               break;
-       case BFA_IOC_TYPE_LL:
-               aen_data.ioc.mac = bfa_ioc_get_mac(ioc);
-               break;
-       default:
-               bfa_assert(ioc_type == BFA_IOC_TYPE_FC);
-               break;
-       }
-       aen_data.ioc.ioc_type = ioc_type;
-}
-
 /**
  * Retrieve saved firmware trace from a prior IOC failure.
  */
 bfa_status_t
 bfa_ioc_debug_fwsave(struct bfa_ioc_s *ioc, void *trcdata, int *trclen)
 {
-       int             tlen;
+       int     tlen;
 
        if (ioc->dbg_fwsave_len == 0)
                return BFA_STATUS_ENOFSAVE;
@@ -1963,57 +2561,145 @@ bfa_ioc_debug_fwsave_clear(struct bfa_ioc_s *ioc)
 bfa_status_t
 bfa_ioc_debug_fwtrc(struct bfa_ioc_s *ioc, void *trcdata, int *trclen)
 {
-       u32        pgnum;
-       u32        loff = BFA_DBG_FWTRC_OFF(bfa_ioc_portid(ioc));
-       int             i, tlen;
-       u32       *tbuf = trcdata, r32;
+       u32 loff = BFA_DBG_FWTRC_OFF(bfa_ioc_portid(ioc));
+       int tlen;
+       bfa_status_t status;
 
        bfa_trc(ioc, *trclen);
 
-       pgnum = bfa_ioc_smem_pgnum(ioc, loff);
-       loff = bfa_ioc_smem_pgoff(ioc, loff);
-
-       /*
-        *  Hold semaphore to serialize pll init and fwtrc.
-        */
-       if (BFA_FALSE == bfa_ioc_sem_get(ioc->ioc_regs.ioc_init_sem_reg))
-               return BFA_STATUS_FAILED;
-
-       bfa_reg_write(ioc->ioc_regs.host_page_num_fn, pgnum);
-
        tlen = *trclen;
        if (tlen > BFA_DBG_FWTRC_LEN)
                tlen = BFA_DBG_FWTRC_LEN;
-       tlen /= sizeof(u32);
 
-       bfa_trc(ioc, tlen);
+       status = bfa_ioc_smem_read(ioc, trcdata, loff, tlen);
+       *trclen = tlen;
+       return status;
+}
 
-       for (i = 0; i < tlen; i++) {
-               r32 = bfa_mem_read(ioc->ioc_regs.smem_page_start, loff);
-               tbuf[i] = bfa_os_ntohl(r32);
-               loff += sizeof(u32);
+static void
+bfa_ioc_send_fwsync(struct bfa_ioc_s *ioc)
+{
+       struct bfa_mbox_cmd_s cmd;
+       struct bfi_ioc_ctrl_req_s *req = (struct bfi_ioc_ctrl_req_s *) cmd.msg;
 
-               /**
-                * handle page offset wrap around
-                */
-               loff = PSS_SMEM_PGOFF(loff);
-               if (loff == 0) {
-                       pgnum++;
-                       bfa_reg_write(ioc->ioc_regs.host_page_num_fn, pgnum);
-               }
+       bfi_h2i_set(req->mh, BFI_MC_IOC, BFI_IOC_H2I_DBG_SYNC,
+                   bfa_ioc_portid(ioc));
+       req->ioc_class = ioc->ioc_mc;
+       bfa_ioc_mbox_queue(ioc, &cmd);
+}
+
+static void
+bfa_ioc_fwsync(struct bfa_ioc_s *ioc)
+{
+       u32 fwsync_iter = 1000;
+
+       bfa_ioc_send_fwsync(ioc);
+
+       /**
+        * After sending a fw sync mbox command wait for it to
+        * take effect.  We will not wait for a response because
+        *    1. fw_sync mbox cmd doesn't have a response.
+        *    2. Even if we implement that,  interrupts might not
+        *       be enabled when we call this function.
+        * So, just keep checking if any mbox cmd is pending, and
+        * after waiting for a reasonable amount of time, go ahead.
+        * It is possible that fw has crashed and the mbox command
+        * is never acknowledged.
+        */
+       while (bfa_ioc_mbox_cmd_pending(ioc) && fwsync_iter > 0)
+               fwsync_iter--;
+}
+
+/**
+ * Dump firmware smem
+ */
+bfa_status_t
+bfa_ioc_debug_fwcore(struct bfa_ioc_s *ioc, void *buf,
+                               u32 *offset, int *buflen)
+{
+       u32 loff;
+       int dlen;
+       bfa_status_t status;
+       u32 smem_len = BFA_IOC_FW_SMEM_SIZE(ioc);
+
+       if (*offset >= smem_len) {
+               *offset = *buflen = 0;
+               return BFA_STATUS_EINVAL;
        }
-       bfa_reg_write(ioc->ioc_regs.host_page_num_fn,
-                     bfa_ioc_smem_pgnum(ioc, 0));
 
-       /*
-        *  release semaphore.
+       loff = *offset;
+       dlen = *buflen;
+
+       /**
+        * First smem read, sync smem before proceeding
+        * No need to sync before reading every chunk.
         */
-       bfa_ioc_sem_release(ioc->ioc_regs.ioc_init_sem_reg);
+       if (loff == 0)
+               bfa_ioc_fwsync(ioc);
 
-       bfa_trc(ioc, pgnum);
+       if ((loff + dlen) >= smem_len)
+               dlen = smem_len - loff;
 
-       *trclen = tlen * sizeof(u32);
-       return BFA_STATUS_OK;
+       status = bfa_ioc_smem_read(ioc, buf, loff, dlen);
+
+       if (status != BFA_STATUS_OK) {
+               *offset = *buflen = 0;
+               return status;
+       }
+
+       *offset += dlen;
+
+       if (*offset >= smem_len)
+               *offset = 0;
+
+       *buflen = dlen;
+
+       return status;
+}
+
+/**
+ * Firmware statistics
+ */
+bfa_status_t
+bfa_ioc_fw_stats_get(struct bfa_ioc_s *ioc, void *stats)
+{
+       u32 loff = BFI_IOC_FWSTATS_OFF + \
+               BFI_IOC_FWSTATS_SZ * (bfa_ioc_portid(ioc));
+       int tlen;
+       bfa_status_t status;
+
+       if (ioc->stats_busy) {
+               bfa_trc(ioc, ioc->stats_busy);
+               return BFA_STATUS_DEVBUSY;
+       }
+       ioc->stats_busy = BFA_TRUE;
+
+       tlen = sizeof(struct bfa_fw_stats_s);
+       status = bfa_ioc_smem_read(ioc, stats, loff, tlen);
+
+       ioc->stats_busy = BFA_FALSE;
+       return status;
+}
+
+bfa_status_t
+bfa_ioc_fw_stats_clear(struct bfa_ioc_s *ioc)
+{
+       u32 loff = BFI_IOC_FWSTATS_OFF + \
+               BFI_IOC_FWSTATS_SZ * (bfa_ioc_portid(ioc));
+       int tlen;
+       bfa_status_t status;
+
+       if (ioc->stats_busy) {
+               bfa_trc(ioc, ioc->stats_busy);
+               return BFA_STATUS_DEVBUSY;
+       }
+       ioc->stats_busy = BFA_TRUE;
+
+       tlen = sizeof(struct bfa_fw_stats_s);
+       status = bfa_ioc_smem_clr(ioc, loff, tlen);
+
+       ioc->stats_busy = BFA_FALSE;
+       return status;
 }
 
 /**
@@ -2022,7 +2708,7 @@ bfa_ioc_debug_fwtrc(struct bfa_ioc_s *ioc, void *trcdata, int *trclen)
 static void
 bfa_ioc_debug_save(struct bfa_ioc_s *ioc)
 {
-       int             tlen;
+       int             tlen;
 
        if (ioc->dbg_fwsave_len) {
                tlen = ioc->dbg_fwsave_len;
@@ -2050,11 +2736,135 @@ bfa_ioc_check_attr_wwns(struct bfa_ioc_s *ioc)
 {
        if (bfa_ioc_get_type(ioc) == BFA_IOC_TYPE_LL)
                return;
+}
+
+/**
+ *  hal_iocpf_pvt BFA IOC PF private functions
+ */
 
-       if (ioc->attr->nwwn == 0)
-               bfa_ioc_aen_post(ioc, BFA_IOC_AEN_INVALID_NWWN);
-       if (ioc->attr->pwwn == 0)
-               bfa_ioc_aen_post(ioc, BFA_IOC_AEN_INVALID_PWWN);
+static void
+bfa_iocpf_enable(struct bfa_ioc_s *ioc)
+{
+       bfa_fsm_send_event(&ioc->iocpf, IOCPF_E_ENABLE);
 }
 
-#endif
+static void
+bfa_iocpf_disable(struct bfa_ioc_s *ioc)
+{
+       bfa_fsm_send_event(&ioc->iocpf, IOCPF_E_DISABLE);
+}
+
+static void
+bfa_iocpf_fail(struct bfa_ioc_s *ioc)
+{
+       bfa_fsm_send_event(&ioc->iocpf, IOCPF_E_FAIL);
+}
+
+static void
+bfa_iocpf_initfail(struct bfa_ioc_s *ioc)
+{
+       bfa_fsm_send_event(&ioc->iocpf, IOCPF_E_INITFAIL);
+}
+
+static void
+bfa_iocpf_getattrfail(struct bfa_ioc_s *ioc)
+{
+       bfa_fsm_send_event(&ioc->iocpf, IOCPF_E_GETATTRFAIL);
+}
+
+static void
+bfa_iocpf_stop(struct bfa_ioc_s *ioc)
+{
+       bfa_fsm_send_event(&ioc->iocpf, IOCPF_E_STOP);
+}
+
+static void
+bfa_iocpf_timeout(void *ioc_arg)
+{
+       struct bfa_ioc_s  *ioc = (struct bfa_ioc_s *) ioc_arg;
+
+       bfa_trc(ioc, 0);
+       bfa_fsm_send_event(&ioc->iocpf, IOCPF_E_TIMEOUT);
+}
+
+static void
+bfa_iocpf_sem_timeout(void *ioc_arg)
+{
+       struct bfa_ioc_s  *ioc = (struct bfa_ioc_s *) ioc_arg;
+
+       bfa_ioc_hw_sem_get(ioc);
+}
+
+/**
+ *  bfa timer function
+ */
+void
+bfa_timer_init(struct bfa_timer_mod_s *mod)
+{
+       INIT_LIST_HEAD(&mod->timer_q);
+}
+
+void
+bfa_timer_beat(struct bfa_timer_mod_s *mod)
+{
+       struct list_head *qh = &mod->timer_q;
+       struct list_head *qe, *qe_next;
+       struct bfa_timer_s *elem;
+       struct list_head timedout_q;
+
+       INIT_LIST_HEAD(&timedout_q);
+
+       qe = bfa_q_next(qh);
+
+       while (qe != qh) {
+               qe_next = bfa_q_next(qe);
+
+               elem = (struct bfa_timer_s *) qe;
+               if (elem->timeout <= BFA_TIMER_FREQ) {
+                       elem->timeout = 0;
+                       list_del(&elem->qe);
+                       list_add_tail(&elem->qe, &timedout_q);
+               } else {
+                       elem->timeout -= BFA_TIMER_FREQ;
+               }
+
+               qe = qe_next;   /* go to next elem */
+       }
+
+       /*
+        * Pop all the timeout entries
+        */
+       while (!list_empty(&timedout_q)) {
+               bfa_q_deq(&timedout_q, &elem);
+               elem->timercb(elem->arg);
+       }
+}
+
+/**
+ * Should be called with lock protection
+ */
+void
+bfa_timer_begin(struct bfa_timer_mod_s *mod, struct bfa_timer_s *timer,
+                   void (*timercb) (void *), void *arg, unsigned int timeout)
+{
+
+       bfa_assert(timercb != NULL);
+       bfa_assert(!bfa_q_is_on_q(&mod->timer_q, timer));
+
+       timer->timeout = timeout;
+       timer->timercb = timercb;
+       timer->arg = arg;
+
+       list_add_tail(&timer->qe, &mod->timer_q);
+}
+
+/**
+ * Should be called with lock protection
+ */
+void
+bfa_timer_stop(struct bfa_timer_s *timer)
+{
+       bfa_assert(!list_empty(&timer->qe));
+
+       list_del(&timer->qe);
+}
index cae05b251c9990b076be68c9aeeb78a04707db92..288c5801aace553021d68472824f342ce9aac0e0 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
  * All rights reserved
  * www.brocade.com
  *
 #ifndef __BFA_IOC_H__
 #define __BFA_IOC_H__
 
-#include <cs/bfa_sm.h>
-#include <bfi/bfi.h>
-#include <bfi/bfi_ioc.h>
-#include <bfi/bfi_boot.h>
-#include <bfa_timer.h>
+#include "bfa_os_inc.h"
+#include "bfa_cs.h"
+#include "bfi.h"
+
+/**
+ * BFA timer declarations
+ */
+typedef void (*bfa_timer_cbfn_t)(void *);
+
+/**
+ * BFA timer data structure
+ */
+struct bfa_timer_s {
+       struct list_head        qe;
+       bfa_timer_cbfn_t timercb;
+       void            *arg;
+       int             timeout;        /**< in millisecs. */
+};
+
+/**
+ * Timer module structure
+ */
+struct bfa_timer_mod_s {
+       struct list_head timer_q;
+};
+
+#define BFA_TIMER_FREQ 200 /**< specified in millisecs */
+
+void bfa_timer_beat(struct bfa_timer_mod_s *mod);
+void bfa_timer_init(struct bfa_timer_mod_s *mod);
+void bfa_timer_begin(struct bfa_timer_mod_s *mod, struct bfa_timer_s *timer,
+                       bfa_timer_cbfn_t timercb, void *arg,
+                       unsigned int timeout);
+void bfa_timer_stop(struct bfa_timer_s *timer);
+
+/**
+ * Generic Scatter Gather Element used by driver
+ */
+struct bfa_sge_s {
+       u32     sg_len;
+       void            *sg_addr;
+};
+
+#define bfa_sge_word_swap(__sge) do {                                       \
+       ((u32 *)(__sge))[0] = bfa_os_swap32(((u32 *)(__sge))[0]);      \
+       ((u32 *)(__sge))[1] = bfa_os_swap32(((u32 *)(__sge))[1]);      \
+       ((u32 *)(__sge))[2] = bfa_os_swap32(((u32 *)(__sge))[2]);      \
+} while (0)
+
+#define bfa_swap_words(_x)  (  \
+       ((_x) << 32) | ((_x) >> 32))
+
+#ifdef __BIGENDIAN
+#define bfa_sge_to_be(_x)
+#define bfa_sge_to_le(_x)      bfa_sge_word_swap(_x)
+#define bfa_sgaddr_le(_x)      bfa_swap_words(_x)
+#else
+#define        bfa_sge_to_be(_x)       bfa_sge_word_swap(_x)
+#define bfa_sge_to_le(_x)
+#define bfa_sgaddr_le(_x)      (_x)
+#endif
 
 /**
  * PCI device information required by IOC
  */
 struct bfa_pcidev_s {
-       int             pci_slot;
-       u8         pci_func;
+       int             pci_slot;
+       u8              pci_func;
        u16     device_id;
        bfa_os_addr_t   pci_bar_kva;
 };
@@ -39,13 +95,18 @@ struct bfa_pcidev_s {
  * Address
  */
 struct bfa_dma_s {
-       void            *kva;   /*! Kernel virtual address      */
-       u64     pa;     /*! Physical address            */
+       void            *kva;   /* ! Kernel virtual address     */
+       u64     pa;     /* ! Physical address           */
 };
 
 #define BFA_DMA_ALIGN_SZ       256
 #define BFA_ROUNDUP(_l, _s)    (((_l) + ((_s) - 1)) & ~((_s) - 1))
 
+/**
+ * smem size for Crossbow and Catapult
+ */
+#define BFI_SMEM_CB_SIZE       0x200000U       /* ! 2MB for crossbow   */
+#define BFI_SMEM_CT_SIZE       0x280000U       /* ! 2.5MB for catapult */
 
 
 #define bfa_dma_addr_set(dma_addr, pa) \
@@ -101,7 +162,7 @@ struct bfa_ioc_regs_s {
  * IOC Mailbox structures
  */
 struct bfa_mbox_cmd_s {
-       struct list_head                qe;
+       struct list_head        qe;
        u32     msg[BFI_IOC_MSGSZ];
 };
 
@@ -110,8 +171,8 @@ struct bfa_mbox_cmd_s {
  */
 typedef void (*bfa_ioc_mbox_mcfunc_t)(void *cbarg, struct bfi_mbmsg_s *m);
 struct bfa_ioc_mbox_mod_s {
-       struct list_head        cmd_q;          /*  pending mbox queue  */
-       int             nmclass;        /*  number of handlers */
+       struct list_head                cmd_q;  /*  pending mbox queue  */
+       int                     nmclass;        /*  number of handlers */
        struct {
                bfa_ioc_mbox_mcfunc_t   cbfn;   /*  message handlers    */
                void                    *cbarg;
@@ -149,49 +210,54 @@ struct bfa_ioc_hbfail_notify_s {
        (__notify)->cbarg = (__cbarg);      \
 } while (0)
 
+struct bfa_iocpf_s {
+       bfa_fsm_t               fsm;
+       struct bfa_ioc_s        *ioc;
+       u32             retry_count;
+       bfa_boolean_t           auto_recover;
+};
+
 struct bfa_ioc_s {
        bfa_fsm_t               fsm;
        struct bfa_s            *bfa;
        struct bfa_pcidev_s     pcidev;
-       struct bfa_timer_mod_s  *timer_mod;
-       struct bfa_timer_s      ioc_timer;
-       struct bfa_timer_s      sem_timer;
+       struct bfa_timer_mod_s  *timer_mod;
+       struct bfa_timer_s      ioc_timer;
+       struct bfa_timer_s      sem_timer;
+       struct bfa_timer_s      hb_timer;
        u32             hb_count;
-       u32             retry_count;
        struct list_head                hb_notify_q;
        void                    *dbg_fwsave;
        int                     dbg_fwsave_len;
        bfa_boolean_t           dbg_fwsave_once;
        enum bfi_mclass         ioc_mc;
-       struct bfa_ioc_regs_s   ioc_regs;
+       struct bfa_ioc_regs_s   ioc_regs;
        struct bfa_trc_mod_s    *trcmod;
-       struct bfa_aen_s        *aen;
-       struct bfa_log_mod_s    *logm;
        struct bfa_ioc_drv_stats_s      stats;
-       bfa_boolean_t           auto_recover;
        bfa_boolean_t           fcmode;
        bfa_boolean_t           ctdev;
        bfa_boolean_t           cna;
        bfa_boolean_t           pllinit;
+       bfa_boolean_t           stats_busy;     /*  outstanding stats */
        u8                      port_id;
-
        struct bfa_dma_s        attr_dma;
        struct bfi_ioc_attr_s   *attr;
        struct bfa_ioc_cbfn_s   *cbfn;
        struct bfa_ioc_mbox_mod_s mbox_mod;
-       struct bfa_ioc_hwif_s   *ioc_hwif;
+       struct bfa_ioc_hwif_s   *ioc_hwif;
+       struct bfa_iocpf_s      iocpf;
 };
 
 struct bfa_ioc_hwif_s {
-       bfa_status_t    (*ioc_pll_init) (struct bfa_ioc_s *ioc);
-       bfa_boolean_t   (*ioc_firmware_lock)    (struct bfa_ioc_s *ioc);
-       void            (*ioc_firmware_unlock)  (struct bfa_ioc_s *ioc);
-       void            (*ioc_reg_init) (struct bfa_ioc_s *ioc);
-       void            (*ioc_map_port) (struct bfa_ioc_s *ioc);
-       void            (*ioc_isr_mode_set)     (struct bfa_ioc_s *ioc,
-                                               bfa_boolean_t msix);
-       void            (*ioc_notify_hbfail)    (struct bfa_ioc_s *ioc);
-       void            (*ioc_ownership_reset)  (struct bfa_ioc_s *ioc);
+       bfa_status_t (*ioc_pll_init) (bfa_os_addr_t rb, bfa_boolean_t fcmode);
+       bfa_boolean_t   (*ioc_firmware_lock)    (struct bfa_ioc_s *ioc);
+       void            (*ioc_firmware_unlock)  (struct bfa_ioc_s *ioc);
+       void            (*ioc_reg_init) (struct bfa_ioc_s *ioc);
+       void            (*ioc_map_port) (struct bfa_ioc_s *ioc);
+       void            (*ioc_isr_mode_set)     (struct bfa_ioc_s *ioc,
+                                       bfa_boolean_t msix);
+       void            (*ioc_notify_hbfail)    (struct bfa_ioc_s *ioc);
+       void            (*ioc_ownership_reset)  (struct bfa_ioc_s *ioc);
 };
 
 #define bfa_ioc_pcifn(__ioc)           ((__ioc)->pcidev.pci_func)
@@ -206,18 +272,19 @@ struct bfa_ioc_hwif_s {
 #define bfa_ioc_rx_bbcredit(__ioc)     ((__ioc)->attr->rx_bbcredit)
 #define bfa_ioc_speed_sup(__ioc)       \
        BFI_ADAPTER_GETP(SPEED, (__ioc)->attr->adapter_prop)
-#define bfa_ioc_get_nports(__ioc)       \
+#define bfa_ioc_get_nports(__ioc)      \
        BFI_ADAPTER_GETP(NPORTS, (__ioc)->attr->adapter_prop)
 
-#define bfa_ioc_stats(_ioc, _stats)     ((_ioc)->stats._stats++)
-#define BFA_IOC_FWIMG_MINSZ     (16 * 1024)
-#define BFA_IOC_FWIMG_TYPE(__ioc)                                       \
-       (((__ioc)->ctdev) ?                                             \
-        (((__ioc)->fcmode) ? BFI_IMAGE_CT_FC : BFI_IMAGE_CT_CNA) :     \
+#define bfa_ioc_stats(_ioc, _stats)    ((_ioc)->stats._stats++)
+#define BFA_IOC_FWIMG_MINSZ    (16 * 1024)
+#define BFA_IOC_FWIMG_TYPE(__ioc)                                      \
+       (((__ioc)->ctdev) ?                                             \
+        (((__ioc)->fcmode) ? BFI_IMAGE_CT_FC : BFI_IMAGE_CT_CNA) :     \
         BFI_IMAGE_CB_FC)
-
-#define BFA_IOC_FLASH_CHUNK_NO(off)             (off / BFI_FLASH_CHUNK_SZ_WORDS)
-#define BFA_IOC_FLASH_OFFSET_IN_CHUNK(off)      (off % BFI_FLASH_CHUNK_SZ_WORDS)
+#define BFA_IOC_FW_SMEM_SIZE(__ioc)                                    \
+       (((__ioc)->ctdev) ? BFI_SMEM_CT_SIZE : BFI_SMEM_CB_SIZE)
+#define BFA_IOC_FLASH_CHUNK_NO(off)            (off / BFI_FLASH_CHUNK_SZ_WORDS)
+#define BFA_IOC_FLASH_OFFSET_IN_CHUNK(off)     (off % BFI_FLASH_CHUNK_SZ_WORDS)
 #define BFA_IOC_FLASH_CHUNK_ADDR(chunkno)  (chunkno * BFI_FLASH_CHUNK_SZ_WORDS)
 
 /**
@@ -235,18 +302,28 @@ void bfa_ioc_mbox_regisr(struct bfa_ioc_s *ioc, enum bfi_mclass mc,
 /**
  * IOC interfaces
  */
-#define bfa_ioc_pll_init(__ioc) ((__ioc)->ioc_hwif->ioc_pll_init(__ioc))
-#define bfa_ioc_isr_mode_set(__ioc, __msix)                     \
+
+#define bfa_ioc_pll_init_asic(__ioc) \
+       ((__ioc)->ioc_hwif->ioc_pll_init((__ioc)->pcidev.pci_bar_kva, \
+                          (__ioc)->fcmode))
+
+bfa_status_t bfa_ioc_pll_init(struct bfa_ioc_s *ioc);
+bfa_status_t bfa_ioc_cb_pll_init(bfa_os_addr_t rb, bfa_boolean_t fcmode);
+bfa_boolean_t bfa_ioc_ct_pll_init_complete(bfa_os_addr_t rb);
+bfa_status_t bfa_ioc_ct_pll_init(bfa_os_addr_t rb, bfa_boolean_t fcmode);
+
+#define        bfa_ioc_isr_mode_set(__ioc, __msix)                     \
                        ((__ioc)->ioc_hwif->ioc_isr_mode_set(__ioc, __msix))
-#define bfa_ioc_ownership_reset(__ioc)                          \
+#define        bfa_ioc_ownership_reset(__ioc)                          \
                        ((__ioc)->ioc_hwif->ioc_ownership_reset(__ioc))
 
+
 void bfa_ioc_set_ct_hwif(struct bfa_ioc_s *ioc);
 void bfa_ioc_set_cb_hwif(struct bfa_ioc_s *ioc);
+
 void bfa_ioc_attach(struct bfa_ioc_s *ioc, void *bfa,
-               struct bfa_ioc_cbfn_s *cbfn, struct bfa_timer_mod_s *timer_mod,
-               struct bfa_trc_mod_s *trcmod,
-               struct bfa_aen_s *aen, struct bfa_log_mod_s *logm);
+               struct bfa_ioc_cbfn_s *cbfn, struct bfa_timer_mod_s *timer_mod);
+void bfa_ioc_auto_recover(bfa_boolean_t auto_recover);
 void bfa_ioc_detach(struct bfa_ioc_s *ioc);
 void bfa_ioc_pci_init(struct bfa_ioc_s *ioc, struct bfa_pcidev_s *pcidev,
                enum bfi_mclass mc);
@@ -256,21 +333,22 @@ void bfa_ioc_enable(struct bfa_ioc_s *ioc);
 void bfa_ioc_disable(struct bfa_ioc_s *ioc);
 bfa_boolean_t bfa_ioc_intx_claim(struct bfa_ioc_s *ioc);
 
-void bfa_ioc_boot(struct bfa_ioc_s *ioc, u32 boot_type, u32 boot_param);
+void bfa_ioc_boot(struct bfa_ioc_s *ioc, u32 boot_type,
+               u32 boot_param);
 void bfa_ioc_isr(struct bfa_ioc_s *ioc, struct bfi_mbmsg_s *msg);
 void bfa_ioc_error_isr(struct bfa_ioc_s *ioc);
 bfa_boolean_t bfa_ioc_is_operational(struct bfa_ioc_s *ioc);
+bfa_boolean_t bfa_ioc_is_initialized(struct bfa_ioc_s *ioc);
 bfa_boolean_t bfa_ioc_is_disabled(struct bfa_ioc_s *ioc);
 bfa_boolean_t bfa_ioc_fw_mismatch(struct bfa_ioc_s *ioc);
 bfa_boolean_t bfa_ioc_adapter_is_disabled(struct bfa_ioc_s *ioc);
-void bfa_ioc_cfg_complete(struct bfa_ioc_s *ioc);
 enum bfa_ioc_type_e bfa_ioc_get_type(struct bfa_ioc_s *ioc);
 void bfa_ioc_get_adapter_serial_num(struct bfa_ioc_s *ioc, char *serial_num);
 void bfa_ioc_get_adapter_fw_ver(struct bfa_ioc_s *ioc, char *fw_ver);
 void bfa_ioc_get_adapter_optrom_ver(struct bfa_ioc_s *ioc, char *optrom_ver);
 void bfa_ioc_get_adapter_model(struct bfa_ioc_s *ioc, char *model);
 void bfa_ioc_get_adapter_manufacturer(struct bfa_ioc_s *ioc,
-       char *manufacturer);
+               char *manufacturer);
 void bfa_ioc_get_pci_chip_rev(struct bfa_ioc_s *ioc, char *chip_rev);
 enum bfa_ioc_state bfa_ioc_get_state(struct bfa_ioc_s *ioc);
 
@@ -284,6 +362,8 @@ bfa_status_t bfa_ioc_debug_fwsave(struct bfa_ioc_s *ioc, void *trcdata,
 void bfa_ioc_debug_fwsave_clear(struct bfa_ioc_s *ioc);
 bfa_status_t bfa_ioc_debug_fwtrc(struct bfa_ioc_s *ioc, void *trcdata,
                                 int *trclen);
+bfa_status_t bfa_ioc_debug_fwcore(struct bfa_ioc_s *ioc, void *buf,
+       u32 *offset, int *buflen);
 u32 bfa_ioc_smem_pgnum(struct bfa_ioc_s *ioc, u32 fmaddr);
 u32 bfa_ioc_smem_pgoff(struct bfa_ioc_s *ioc, u32 fmaddr);
 void bfa_ioc_set_fcmode(struct bfa_ioc_s *ioc);
@@ -297,7 +377,8 @@ void bfa_ioc_fwver_get(struct bfa_ioc_s *ioc,
                        struct bfi_ioc_image_hdr_s *fwhdr);
 bfa_boolean_t bfa_ioc_fwver_cmp(struct bfa_ioc_s *ioc,
                        struct bfi_ioc_image_hdr_s *fwhdr);
-void bfa_ioc_aen_post(struct bfa_ioc_s *ioc, enum bfa_ioc_aen_event event);
+bfa_status_t bfa_ioc_fw_stats_get(struct bfa_ioc_s *ioc, void *stats);
+bfa_status_t bfa_ioc_fw_stats_clear(struct bfa_ioc_s *ioc);
 
 /*
  * bfa mfg wwn API functions
@@ -310,5 +391,68 @@ wwn_t bfa_ioc_get_mfg_nwwn(struct bfa_ioc_s *ioc);
 mac_t bfa_ioc_get_mfg_mac(struct bfa_ioc_s *ioc);
 u64 bfa_ioc_get_adid(struct bfa_ioc_s *ioc);
 
-#endif /* __BFA_IOC_H__ */
+/*
+ * F/W Image Size & Chunk
+ */
+extern u32 bfi_image_ct_fc_size;
+extern u32 bfi_image_ct_cna_size;
+extern u32 bfi_image_cb_fc_size;
+extern u32 *bfi_image_ct_fc;
+extern u32 *bfi_image_ct_cna;
+extern u32 *bfi_image_cb_fc;
+
+static inline u32 *
+bfi_image_ct_fc_get_chunk(u32 off)
+{      return (u32 *)(bfi_image_ct_fc + off); }
+
+static inline u32 *
+bfi_image_ct_cna_get_chunk(u32 off)
+{      return (u32 *)(bfi_image_ct_cna + off); }
 
+static inline u32 *
+bfi_image_cb_fc_get_chunk(u32 off)
+{      return (u32 *)(bfi_image_cb_fc + off); }
+
+static inline u32*
+bfa_cb_image_get_chunk(int type, u32 off)
+{
+       switch (type) {
+       case BFI_IMAGE_CT_FC:
+               return bfi_image_ct_fc_get_chunk(off);  break;
+       case BFI_IMAGE_CT_CNA:
+               return bfi_image_ct_cna_get_chunk(off); break;
+       case BFI_IMAGE_CB_FC:
+               return bfi_image_cb_fc_get_chunk(off);  break;
+       default: return 0;
+       }
+}
+
+static inline u32
+bfa_cb_image_get_size(int type)
+{
+       switch (type) {
+       case BFI_IMAGE_CT_FC:
+               return bfi_image_ct_fc_size;    break;
+       case BFI_IMAGE_CT_CNA:
+               return bfi_image_ct_cna_size;   break;
+       case BFI_IMAGE_CB_FC:
+               return bfi_image_cb_fc_size;    break;
+       default: return 0;
+       }
+}
+
+/**
+ * CNA TRCMOD declaration
+ */
+/*
+ * !!! Only append to the enums defined here to avoid any versioning
+ * !!! needed between trace utility and driver version
+ */
+enum {
+       BFA_TRC_CNA_PORT        = 1,
+       BFA_TRC_CNA_IOC         = 2,
+       BFA_TRC_CNA_IOC_CB      = 3,
+       BFA_TRC_CNA_IOC_CT      = 4,
+};
+
+#endif /* __BFA_IOC_H__ */
index 324bdde7ea2eacb158b792015c5d09bcfe36d44f..d7ac864d8539de35a1fc56c28c33091be71534a9 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
  * All rights reserved
  * www.brocade.com
  *
  * General Public License for more details.
  */
 
-#include <bfa.h>
-#include <bfa_ioc.h>
-#include <bfa_fwimg_priv.h>
-#include <cna/bfa_cna_trcmod.h>
-#include <cs/bfa_debug.h>
-#include <bfi/bfi_ioc.h>
-#include <bfi/bfi_cbreg.h>
-#include <log/bfa_log_hal.h>
-#include <defs/bfa_defs_pci.h>
+#include "bfa_ioc.h"
+#include "bfi_cbreg.h"
+#include "bfa_defs.h"
 
 BFA_TRC_FILE(CNA, IOC_CB);
 
 /*
  * forward declarations
  */
-static bfa_status_t bfa_ioc_cb_pll_init(struct bfa_ioc_s *ioc);
 static bfa_boolean_t bfa_ioc_cb_firmware_lock(struct bfa_ioc_s *ioc);
 static void bfa_ioc_cb_firmware_unlock(struct bfa_ioc_s *ioc);
 static void bfa_ioc_cb_reg_init(struct bfa_ioc_s *ioc);
@@ -95,6 +88,7 @@ static struct { u32 hfn_mbox, lpu_mbox, hfn_pgn; } iocreg_fnreg[] = {
  * Host <-> LPU mailbox command/status registers
  */
 static struct { u32 hfn, lpu; } iocreg_mbcmd[] = {
+
        { HOSTFN0_LPU0_CMD_STAT, LPU0_HOSTFN0_CMD_STAT },
        { HOSTFN1_LPU1_CMD_STAT, LPU1_HOSTFN1_CMD_STAT }
 };
@@ -154,6 +148,7 @@ bfa_ioc_cb_reg_init(struct bfa_ioc_s *ioc)
 /**
  * Initialize IOC to port mapping.
  */
+
 static void
 bfa_ioc_cb_map_port(struct bfa_ioc_s *ioc)
 {
@@ -161,6 +156,7 @@ bfa_ioc_cb_map_port(struct bfa_ioc_s *ioc)
         * For crossbow, port id is same as pci function.
         */
        ioc->port_id = bfa_ioc_pcifn(ioc);
+
        bfa_trc(ioc, ioc->port_id);
 }
 
@@ -172,87 +168,69 @@ bfa_ioc_cb_isr_mode_set(struct bfa_ioc_s *ioc, bfa_boolean_t msix)
 {
 }
 
-static bfa_status_t
-bfa_ioc_cb_pll_init(struct bfa_ioc_s *ioc)
+/**
+ * Cleanup hw semaphore and usecnt registers
+ */
+static void
+bfa_ioc_cb_ownership_reset(struct bfa_ioc_s *ioc)
 {
-       bfa_os_addr_t   rb = ioc->pcidev.pci_bar_kva;
-       u32     pll_sclk, pll_fclk;
 
        /*
-        *  Hold semaphore so that nobody can access the chip during init.
+        * Read the hw sem reg to make sure that it is locked
+        * before we clear it. If it is not locked, writing 1
+        * will lock it instead of clearing it.
         */
-       bfa_ioc_sem_get(ioc->ioc_regs.ioc_init_sem_reg);
+       bfa_reg_read(ioc->ioc_regs.ioc_sem_reg);
+       bfa_ioc_hw_sem_release(ioc);
+}
+
+
+
+bfa_status_t
+bfa_ioc_cb_pll_init(bfa_os_addr_t rb, bfa_boolean_t fcmode)
+{
+       u32     pll_sclk, pll_fclk;
 
        pll_sclk = __APP_PLL_212_ENABLE | __APP_PLL_212_LRESETN |
-                       __APP_PLL_212_P0_1(3U) |
-                       __APP_PLL_212_JITLMT0_1(3U) |
-                       __APP_PLL_212_CNTLMT0_1(3U);
+               __APP_PLL_212_P0_1(3U) |
+               __APP_PLL_212_JITLMT0_1(3U) |
+               __APP_PLL_212_CNTLMT0_1(3U);
        pll_fclk = __APP_PLL_400_ENABLE | __APP_PLL_400_LRESETN |
-                       __APP_PLL_400_RSEL200500 | __APP_PLL_400_P0_1(3U) |
-                       __APP_PLL_400_JITLMT0_1(3U) |
-                       __APP_PLL_400_CNTLMT0_1(3U);
-
+               __APP_PLL_400_RSEL200500 | __APP_PLL_400_P0_1(3U) |
+               __APP_PLL_400_JITLMT0_1(3U) |
+               __APP_PLL_400_CNTLMT0_1(3U);
        bfa_reg_write((rb + BFA_IOC0_STATE_REG), BFI_IOC_UNINIT);
        bfa_reg_write((rb + BFA_IOC1_STATE_REG), BFI_IOC_UNINIT);
-
        bfa_reg_write((rb + HOSTFN0_INT_MSK), 0xffffffffU);
        bfa_reg_write((rb + HOSTFN1_INT_MSK), 0xffffffffU);
        bfa_reg_write((rb + HOSTFN0_INT_STATUS), 0xffffffffU);
        bfa_reg_write((rb + HOSTFN1_INT_STATUS), 0xffffffffU);
        bfa_reg_write((rb + HOSTFN0_INT_MSK), 0xffffffffU);
        bfa_reg_write((rb + HOSTFN1_INT_MSK), 0xffffffffU);
-
-       bfa_reg_write(ioc->ioc_regs.app_pll_slow_ctl_reg,
-                       __APP_PLL_212_LOGIC_SOFT_RESET);
-       bfa_reg_write(ioc->ioc_regs.app_pll_slow_ctl_reg,
-                       __APP_PLL_212_BYPASS |
-                       __APP_PLL_212_LOGIC_SOFT_RESET);
-       bfa_reg_write(ioc->ioc_regs.app_pll_fast_ctl_reg,
-                       __APP_PLL_400_LOGIC_SOFT_RESET);
-       bfa_reg_write(ioc->ioc_regs.app_pll_fast_ctl_reg,
-                       __APP_PLL_400_BYPASS |
-                       __APP_PLL_400_LOGIC_SOFT_RESET);
+       bfa_reg_write(rb + APP_PLL_212_CTL_REG,
+                         __APP_PLL_212_LOGIC_SOFT_RESET);
+       bfa_reg_write(rb + APP_PLL_212_CTL_REG,
+                         __APP_PLL_212_BYPASS |
+                         __APP_PLL_212_LOGIC_SOFT_RESET);
+       bfa_reg_write(rb + APP_PLL_400_CTL_REG,
+                         __APP_PLL_400_LOGIC_SOFT_RESET);
+       bfa_reg_write(rb + APP_PLL_400_CTL_REG,
+                         __APP_PLL_400_BYPASS |
+                         __APP_PLL_400_LOGIC_SOFT_RESET);
        bfa_os_udelay(2);
-       bfa_reg_write(ioc->ioc_regs.app_pll_slow_ctl_reg,
-                       __APP_PLL_212_LOGIC_SOFT_RESET);
-       bfa_reg_write(ioc->ioc_regs.app_pll_fast_ctl_reg,
-                       __APP_PLL_400_LOGIC_SOFT_RESET);
-
-       bfa_reg_write(ioc->ioc_regs.app_pll_slow_ctl_reg,
-                       pll_sclk | __APP_PLL_212_LOGIC_SOFT_RESET);
-       bfa_reg_write(ioc->ioc_regs.app_pll_fast_ctl_reg,
-                       pll_fclk | __APP_PLL_400_LOGIC_SOFT_RESET);
-
-       /**
-        * Wait for PLLs to lock.
-        */
+       bfa_reg_write(rb + APP_PLL_212_CTL_REG,
+                         __APP_PLL_212_LOGIC_SOFT_RESET);
+       bfa_reg_write(rb + APP_PLL_400_CTL_REG,
+                         __APP_PLL_400_LOGIC_SOFT_RESET);
+       bfa_reg_write(rb + APP_PLL_212_CTL_REG,
+                         pll_sclk | __APP_PLL_212_LOGIC_SOFT_RESET);
+       bfa_reg_write(rb + APP_PLL_400_CTL_REG,
+                         pll_fclk | __APP_PLL_400_LOGIC_SOFT_RESET);
        bfa_os_udelay(2000);
        bfa_reg_write((rb + HOSTFN0_INT_STATUS), 0xffffffffU);
        bfa_reg_write((rb + HOSTFN1_INT_STATUS), 0xffffffffU);
-
-       bfa_reg_write(ioc->ioc_regs.app_pll_slow_ctl_reg, pll_sclk);
-       bfa_reg_write(ioc->ioc_regs.app_pll_fast_ctl_reg, pll_fclk);
-
-       /*
-        *  release semaphore.
-        */
-       bfa_ioc_sem_release(ioc->ioc_regs.ioc_init_sem_reg);
+       bfa_reg_write((rb + APP_PLL_212_CTL_REG), pll_sclk);
+       bfa_reg_write((rb + APP_PLL_400_CTL_REG), pll_fclk);
 
        return BFA_STATUS_OK;
 }
-
-/**
- * Cleanup hw semaphore and usecnt registers
- */
-static void
-bfa_ioc_cb_ownership_reset(struct bfa_ioc_s *ioc)
-{
-
-       /*
-        * Read the hw sem reg to make sure that it is locked
-        * before we clear it. If it is not locked, writing 1
-        * will lock it instead of clearing it.
-        */
-       bfa_reg_read(ioc->ioc_regs.ioc_sem_reg);
-       bfa_ioc_hw_sem_release(ioc);
-}
index 68f027da001e42b5c7e34c6af4d507d6b3fbc663..f21b82c5f64c64cf271b378099d38484dbf2611c 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
  * All rights reserved
  * www.brocade.com
  *
  * General Public License for more details.
  */
 
-#include <bfa.h>
-#include <bfa_ioc.h>
-#include <bfa_fwimg_priv.h>
-#include <cna/bfa_cna_trcmod.h>
-#include <cs/bfa_debug.h>
-#include <bfi/bfi_ioc.h>
-#include <bfi/bfi_ctreg.h>
-#include <log/bfa_log_hal.h>
-#include <defs/bfa_defs_pci.h>
+#include "bfa_ioc.h"
+#include "bfi_ctreg.h"
+#include "bfa_defs.h"
 
 BFA_TRC_FILE(CNA, IOC_CT);
 
 /*
  * forward declarations
  */
-static bfa_status_t bfa_ioc_ct_pll_init(struct bfa_ioc_s *ioc);
 static bfa_boolean_t bfa_ioc_ct_firmware_lock(struct bfa_ioc_s *ioc);
 static void bfa_ioc_ct_firmware_unlock(struct bfa_ioc_s *ioc);
 static void bfa_ioc_ct_reg_init(struct bfa_ioc_s *ioc);
@@ -78,7 +71,8 @@ bfa_ioc_ct_firmware_lock(struct bfa_ioc_s *ioc)
        /**
         * If bios boot (flash based) -- do not increment usage count
         */
-       if (bfi_image_get_size(BFA_IOC_FWIMG_TYPE(ioc)) < BFA_IOC_FWIMG_MINSZ)
+       if (bfa_cb_image_get_size(BFA_IOC_FWIMG_TYPE(ioc)) <
+                                               BFA_IOC_FWIMG_MINSZ)
                return BFA_TRUE;
 
        bfa_ioc_sem_get(ioc->ioc_regs.ioc_usage_sem_reg);
@@ -136,7 +130,8 @@ bfa_ioc_ct_firmware_unlock(struct bfa_ioc_s *ioc)
        /**
         * If bios boot (flash based) -- do not decrement usage count
         */
-       if (bfi_image_get_size(BFA_IOC_FWIMG_TYPE(ioc)) < BFA_IOC_FWIMG_MINSZ)
+       if (bfa_cb_image_get_size(BFA_IOC_FWIMG_TYPE(ioc)) <
+                                               BFA_IOC_FWIMG_MINSZ)
                return;
 
        /**
@@ -308,16 +303,47 @@ bfa_ioc_ct_isr_mode_set(struct bfa_ioc_s *ioc, bfa_boolean_t msix)
        bfa_reg_write(rb + FNC_PERS_REG, r32);
 }
 
-static bfa_status_t
-bfa_ioc_ct_pll_init(struct bfa_ioc_s *ioc)
+/**
+ * Cleanup hw semaphore and usecnt registers
+ */
+static void
+bfa_ioc_ct_ownership_reset(struct bfa_ioc_s *ioc)
 {
-       bfa_os_addr_t   rb = ioc->pcidev.pci_bar_kva;
-       u32     pll_sclk, pll_fclk, r32;
+
+       if (ioc->cna) {
+               bfa_ioc_sem_get(ioc->ioc_regs.ioc_usage_sem_reg);
+               bfa_reg_write(ioc->ioc_regs.ioc_usage_reg, 0);
+               bfa_ioc_sem_release(ioc->ioc_regs.ioc_usage_sem_reg);
+       }
 
        /*
-        *  Hold semaphore so that nobody can access the chip during init.
+        * Read the hw sem reg to make sure that it is locked
+        * before we clear it. If it is not locked, writing 1
+        * will lock it instead of clearing it.
         */
-       bfa_ioc_sem_get(ioc->ioc_regs.ioc_init_sem_reg);
+       bfa_reg_read(ioc->ioc_regs.ioc_sem_reg);
+       bfa_ioc_hw_sem_release(ioc);
+}
+
+
+
+/*
+ * Check the firmware state to know if pll_init has been completed already
+ */
+bfa_boolean_t
+bfa_ioc_ct_pll_init_complete(bfa_os_addr_t rb)
+{
+       if ((bfa_reg_read(rb + BFA_IOC0_STATE_REG) == BFI_IOC_OP) ||
+         (bfa_reg_read(rb + BFA_IOC1_STATE_REG) == BFI_IOC_OP))
+               return BFA_TRUE;
+
+       return BFA_FALSE;
+}
+
+bfa_status_t
+bfa_ioc_ct_pll_init(bfa_os_addr_t rb, bfa_boolean_t fcmode)
+{
+       u32     pll_sclk, pll_fclk, r32;
 
        pll_sclk = __APP_PLL_312_LRESETN | __APP_PLL_312_ENARST |
                __APP_PLL_312_RSEL200500 | __APP_PLL_312_P0_1(3U) |
@@ -327,70 +353,50 @@ bfa_ioc_ct_pll_init(struct bfa_ioc_s *ioc)
                __APP_PLL_425_RSEL200500 | __APP_PLL_425_P0_1(3U) |
                __APP_PLL_425_JITLMT0_1(3U) |
                __APP_PLL_425_CNTLMT0_1(1U);
-
-       /**
-        *      For catapult, choose operational mode FC/FCoE
-        */
-       if (ioc->fcmode) {
+       if (fcmode) {
                bfa_reg_write((rb + OP_MODE), 0);
                bfa_reg_write((rb + ETH_MAC_SER_REG),
                                __APP_EMS_CMLCKSEL |
                                __APP_EMS_REFCKBUFEN2 |
                                __APP_EMS_CHANNEL_SEL);
        } else {
-               ioc->pllinit = BFA_TRUE;
                bfa_reg_write((rb + OP_MODE), __GLOBAL_FCOE_MODE);
                bfa_reg_write((rb + ETH_MAC_SER_REG),
-                                __APP_EMS_REFCKBUFEN1);
+                               __APP_EMS_REFCKBUFEN1);
        }
-
        bfa_reg_write((rb + BFA_IOC0_STATE_REG), BFI_IOC_UNINIT);
        bfa_reg_write((rb + BFA_IOC1_STATE_REG), BFI_IOC_UNINIT);
-
        bfa_reg_write((rb + HOSTFN0_INT_MSK), 0xffffffffU);
        bfa_reg_write((rb + HOSTFN1_INT_MSK), 0xffffffffU);
        bfa_reg_write((rb + HOSTFN0_INT_STATUS), 0xffffffffU);
        bfa_reg_write((rb + HOSTFN1_INT_STATUS), 0xffffffffU);
        bfa_reg_write((rb + HOSTFN0_INT_MSK), 0xffffffffU);
        bfa_reg_write((rb + HOSTFN1_INT_MSK), 0xffffffffU);
-
-       bfa_reg_write(ioc->ioc_regs.app_pll_slow_ctl_reg, pll_sclk |
+       bfa_reg_write(rb + APP_PLL_312_CTL_REG, pll_sclk |
                __APP_PLL_312_LOGIC_SOFT_RESET);
-       bfa_reg_write(ioc->ioc_regs.app_pll_fast_ctl_reg, pll_fclk |
+       bfa_reg_write(rb + APP_PLL_425_CTL_REG, pll_fclk |
                __APP_PLL_425_LOGIC_SOFT_RESET);
-       bfa_reg_write(ioc->ioc_regs.app_pll_slow_ctl_reg, pll_sclk |
+       bfa_reg_write(rb + APP_PLL_312_CTL_REG, pll_sclk |
                __APP_PLL_312_LOGIC_SOFT_RESET | __APP_PLL_312_ENABLE);
-       bfa_reg_write(ioc->ioc_regs.app_pll_fast_ctl_reg, pll_fclk |
+       bfa_reg_write(rb + APP_PLL_425_CTL_REG, pll_fclk |
                __APP_PLL_425_LOGIC_SOFT_RESET | __APP_PLL_425_ENABLE);
-
-       /**
-        * Wait for PLLs to lock.
-        */
        bfa_reg_read(rb + HOSTFN0_INT_MSK);
        bfa_os_udelay(2000);
        bfa_reg_write((rb + HOSTFN0_INT_STATUS), 0xffffffffU);
        bfa_reg_write((rb + HOSTFN1_INT_STATUS), 0xffffffffU);
-
-       bfa_reg_write(ioc->ioc_regs.app_pll_slow_ctl_reg, pll_sclk |
+       bfa_reg_write(rb + APP_PLL_312_CTL_REG, pll_sclk |
                __APP_PLL_312_ENABLE);
-       bfa_reg_write(ioc->ioc_regs.app_pll_fast_ctl_reg, pll_fclk |
+       bfa_reg_write(rb + APP_PLL_425_CTL_REG, pll_fclk |
                __APP_PLL_425_ENABLE);
-
-       /**
-        * PSS memory reset is asserted at power-on-reset. Need to clear
-        * this before running EDRAM BISTR
-        */
-       if (ioc->cna) {
+       if (!fcmode) {
                bfa_reg_write((rb + PMM_1T_RESET_REG_P0), __PMM_1T_RESET_P);
                bfa_reg_write((rb + PMM_1T_RESET_REG_P1), __PMM_1T_RESET_P);
        }
-
        r32 = bfa_reg_read((rb + PSS_CTL_REG));
        r32 &= ~__PSS_LMEM_RESET;
        bfa_reg_write((rb + PSS_CTL_REG), r32);
        bfa_os_udelay(1000);
-
-       if (ioc->cna) {
+       if (!fcmode) {
                bfa_reg_write((rb + PMM_1T_RESET_REG_P0), 0);
                bfa_reg_write((rb + PMM_1T_RESET_REG_P1), 0);
        }
@@ -398,39 +404,6 @@ bfa_ioc_ct_pll_init(struct bfa_ioc_s *ioc)
        bfa_reg_write((rb + MBIST_CTL_REG), __EDRAM_BISTR_START);
        bfa_os_udelay(1000);
        r32 = bfa_reg_read((rb + MBIST_STAT_REG));
-       bfa_trc(ioc, r32);
-
-       /**
-        * Clear BISTR
-        */
        bfa_reg_write((rb + MBIST_CTL_REG), 0);
-
-       /*
-        *  release semaphore.
-        */
-       bfa_ioc_sem_release(ioc->ioc_regs.ioc_init_sem_reg);
-
        return BFA_STATUS_OK;
 }
-
-/**
- * Cleanup hw semaphore and usecnt registers
- */
-static void
-bfa_ioc_ct_ownership_reset(struct bfa_ioc_s *ioc)
-{
-
-       if (ioc->cna) {
-               bfa_ioc_sem_get(ioc->ioc_regs.ioc_usage_sem_reg);
-               bfa_reg_write(ioc->ioc_regs.ioc_usage_reg, 0);
-               bfa_ioc_sem_release(ioc->ioc_regs.ioc_usage_sem_reg);
-       }
-
-       /*
-        * Read the hw sem reg to make sure that it is locked
-        * before we clear it. If it is not locked, writing 1
-        * will lock it instead of clearing it.
-        */
-       bfa_reg_read(ioc->ioc_regs.ioc_sem_reg);
-       bfa_ioc_hw_sem_release(ioc);
-}
diff --git a/drivers/scsi/bfa/bfa_iocfc.c b/drivers/scsi/bfa/bfa_iocfc.c
deleted file mode 100644 (file)
index 90820be..0000000
+++ /dev/null
@@ -1,927 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#include <cs/bfa_debug.h>
-#include <bfa_priv.h>
-#include <log/bfa_log_hal.h>
-#include <bfi/bfi_boot.h>
-#include <bfi/bfi_cbreg.h>
-#include <aen/bfa_aen_ioc.h>
-#include <defs/bfa_defs_iocfc.h>
-#include <defs/bfa_defs_pci.h>
-#include "bfa_callback_priv.h"
-#include "bfad_drv.h"
-
-BFA_TRC_FILE(HAL, IOCFC);
-
-/**
- * IOC local definitions
- */
-#define BFA_IOCFC_TOV          5000    /* msecs */
-
-enum {
-       BFA_IOCFC_ACT_NONE      = 0,
-       BFA_IOCFC_ACT_INIT      = 1,
-       BFA_IOCFC_ACT_STOP      = 2,
-       BFA_IOCFC_ACT_DISABLE   = 3,
-};
-
-/*
- * forward declarations
- */
-static void bfa_iocfc_enable_cbfn(void *bfa_arg, enum bfa_status status);
-static void bfa_iocfc_disable_cbfn(void *bfa_arg);
-static void bfa_iocfc_hbfail_cbfn(void *bfa_arg);
-static void bfa_iocfc_reset_cbfn(void *bfa_arg);
-static void bfa_iocfc_stats_clear(void *bfa_arg);
-static void bfa_iocfc_stats_swap(struct bfa_fw_stats_s *d,
-                       struct bfa_fw_stats_s *s);
-static void bfa_iocfc_stats_clr_cb(void *bfa_arg, bfa_boolean_t complete);
-static void bfa_iocfc_stats_clr_timeout(void *bfa_arg);
-static void bfa_iocfc_stats_cb(void *bfa_arg, bfa_boolean_t complete);
-static void bfa_iocfc_stats_timeout(void *bfa_arg);
-
-static struct bfa_ioc_cbfn_s bfa_iocfc_cbfn;
-
-/**
- *  bfa_ioc_pvt BFA IOC private functions
- */
-
-static void
-bfa_iocfc_cqs_sz(struct bfa_iocfc_cfg_s *cfg, u32 *dm_len)
-{
-       int             i, per_reqq_sz, per_rspq_sz;
-
-       per_reqq_sz = BFA_ROUNDUP((cfg->drvcfg.num_reqq_elems * BFI_LMSG_SZ),
-                                                       BFA_DMA_ALIGN_SZ);
-       per_rspq_sz = BFA_ROUNDUP((cfg->drvcfg.num_rspq_elems * BFI_LMSG_SZ),
-                                                       BFA_DMA_ALIGN_SZ);
-
-       /*
-        * Calculate CQ size
-        */
-       for (i = 0; i < cfg->fwcfg.num_cqs; i++) {
-               *dm_len = *dm_len + per_reqq_sz;
-               *dm_len = *dm_len + per_rspq_sz;
-       }
-
-       /*
-        * Calculate Shadow CI/PI size
-        */
-       for (i = 0; i < cfg->fwcfg.num_cqs; i++)
-               *dm_len += (2 * BFA_CACHELINE_SZ);
-}
-
-static void
-bfa_iocfc_fw_cfg_sz(struct bfa_iocfc_cfg_s *cfg, u32 *dm_len)
-{
-       *dm_len +=
-               BFA_ROUNDUP(sizeof(struct bfi_iocfc_cfg_s), BFA_CACHELINE_SZ);
-       *dm_len +=
-               BFA_ROUNDUP(sizeof(struct bfi_iocfc_cfgrsp_s),
-                           BFA_CACHELINE_SZ);
-       *dm_len += BFA_ROUNDUP(sizeof(struct bfa_fw_stats_s), BFA_CACHELINE_SZ);
-}
-
-/**
- * Use the Mailbox interface to send BFI_IOCFC_H2I_CFG_REQ
- */
-static void
-bfa_iocfc_send_cfg(void *bfa_arg)
-{
-       struct bfa_s *bfa = bfa_arg;
-       struct bfa_iocfc_s *iocfc = &bfa->iocfc;
-       struct bfi_iocfc_cfg_req_s cfg_req;
-       struct bfi_iocfc_cfg_s *cfg_info = iocfc->cfginfo;
-       struct bfa_iocfc_cfg_s  *cfg = &iocfc->cfg;
-       int             i;
-
-       bfa_assert(cfg->fwcfg.num_cqs <= BFI_IOC_MAX_CQS);
-       bfa_trc(bfa, cfg->fwcfg.num_cqs);
-
-       bfa_iocfc_reset_queues(bfa);
-
-       /**
-        * initialize IOC configuration info
-        */
-       cfg_info->endian_sig = BFI_IOC_ENDIAN_SIG;
-       cfg_info->num_cqs = cfg->fwcfg.num_cqs;
-
-       bfa_dma_be_addr_set(cfg_info->cfgrsp_addr, iocfc->cfgrsp_dma.pa);
-       bfa_dma_be_addr_set(cfg_info->stats_addr, iocfc->stats_pa);
-
-       /**
-        * dma map REQ and RSP circular queues and shadow pointers
-        */
-       for (i = 0; i < cfg->fwcfg.num_cqs; i++) {
-               bfa_dma_be_addr_set(cfg_info->req_cq_ba[i],
-                                      iocfc->req_cq_ba[i].pa);
-               bfa_dma_be_addr_set(cfg_info->req_shadow_ci[i],
-                                      iocfc->req_cq_shadow_ci[i].pa);
-               cfg_info->req_cq_elems[i] =
-                       bfa_os_htons(cfg->drvcfg.num_reqq_elems);
-
-               bfa_dma_be_addr_set(cfg_info->rsp_cq_ba[i],
-                                      iocfc->rsp_cq_ba[i].pa);
-               bfa_dma_be_addr_set(cfg_info->rsp_shadow_pi[i],
-                                      iocfc->rsp_cq_shadow_pi[i].pa);
-               cfg_info->rsp_cq_elems[i] =
-                       bfa_os_htons(cfg->drvcfg.num_rspq_elems);
-       }
-
-       /**
-        * Enable interrupt coalescing if it is driver init path
-        * and not ioc disable/enable path.
-        */
-       if (!iocfc->cfgdone)
-               cfg_info->intr_attr.coalesce = BFA_TRUE;
-
-       iocfc->cfgdone = BFA_FALSE;
-
-       /**
-        * dma map IOC configuration itself
-        */
-       bfi_h2i_set(cfg_req.mh, BFI_MC_IOCFC, BFI_IOCFC_H2I_CFG_REQ,
-                       bfa_lpuid(bfa));
-       bfa_dma_be_addr_set(cfg_req.ioc_cfg_dma_addr, iocfc->cfg_info.pa);
-
-       bfa_ioc_mbox_send(&bfa->ioc, &cfg_req,
-                       sizeof(struct bfi_iocfc_cfg_req_s));
-}
-
-static void
-bfa_iocfc_init_mem(struct bfa_s *bfa, void *bfad, struct bfa_iocfc_cfg_s *cfg,
-                   struct bfa_pcidev_s *pcidev)
-{
-       struct bfa_iocfc_s      *iocfc = &bfa->iocfc;
-
-       bfa->bfad = bfad;
-       iocfc->bfa = bfa;
-       iocfc->action = BFA_IOCFC_ACT_NONE;
-
-       bfa_os_assign(iocfc->cfg, *cfg);
-
-       /**
-        * Initialize chip specific handlers.
-        */
-       if (bfa_asic_id_ct(bfa_ioc_devid(&bfa->ioc))) {
-               iocfc->hwif.hw_reginit = bfa_hwct_reginit;
-               iocfc->hwif.hw_reqq_ack = bfa_hwct_reqq_ack;
-               iocfc->hwif.hw_rspq_ack = bfa_hwct_rspq_ack;
-               iocfc->hwif.hw_msix_init = bfa_hwct_msix_init;
-               iocfc->hwif.hw_msix_install = bfa_hwct_msix_install;
-               iocfc->hwif.hw_msix_uninstall = bfa_hwct_msix_uninstall;
-               iocfc->hwif.hw_isr_mode_set = bfa_hwct_isr_mode_set;
-               iocfc->hwif.hw_msix_getvecs = bfa_hwct_msix_getvecs;
-               iocfc->hwif.hw_msix_get_rme_range = bfa_hwct_msix_get_rme_range;
-       } else {
-               iocfc->hwif.hw_reginit = bfa_hwcb_reginit;
-               iocfc->hwif.hw_reqq_ack = bfa_hwcb_reqq_ack;
-               iocfc->hwif.hw_rspq_ack = bfa_hwcb_rspq_ack;
-               iocfc->hwif.hw_msix_init = bfa_hwcb_msix_init;
-               iocfc->hwif.hw_msix_install = bfa_hwcb_msix_install;
-               iocfc->hwif.hw_msix_uninstall = bfa_hwcb_msix_uninstall;
-               iocfc->hwif.hw_isr_mode_set = bfa_hwcb_isr_mode_set;
-               iocfc->hwif.hw_msix_getvecs = bfa_hwcb_msix_getvecs;
-               iocfc->hwif.hw_msix_get_rme_range = bfa_hwcb_msix_get_rme_range;
-       }
-
-       iocfc->hwif.hw_reginit(bfa);
-       bfa->msix.nvecs = 0;
-}
-
-static void
-bfa_iocfc_mem_claim(struct bfa_s *bfa, struct bfa_iocfc_cfg_s *cfg,
-                     struct bfa_meminfo_s *meminfo)
-{
-       u8        *dm_kva;
-       u64        dm_pa;
-       int             i, per_reqq_sz, per_rspq_sz;
-       struct bfa_iocfc_s  *iocfc = &bfa->iocfc;
-       int             dbgsz;
-
-       dm_kva = bfa_meminfo_dma_virt(meminfo);
-       dm_pa = bfa_meminfo_dma_phys(meminfo);
-
-       /*
-        * First allocate dma memory for IOC.
-        */
-       bfa_ioc_mem_claim(&bfa->ioc, dm_kva, dm_pa);
-       dm_kva += bfa_ioc_meminfo();
-       dm_pa  += bfa_ioc_meminfo();
-
-       /*
-        * Claim DMA-able memory for the request/response queues and for shadow
-        * ci/pi registers
-        */
-       per_reqq_sz = BFA_ROUNDUP((cfg->drvcfg.num_reqq_elems * BFI_LMSG_SZ),
-                                                       BFA_DMA_ALIGN_SZ);
-       per_rspq_sz = BFA_ROUNDUP((cfg->drvcfg.num_rspq_elems * BFI_LMSG_SZ),
-                                                       BFA_DMA_ALIGN_SZ);
-
-       for (i = 0; i < cfg->fwcfg.num_cqs; i++) {
-               iocfc->req_cq_ba[i].kva = dm_kva;
-               iocfc->req_cq_ba[i].pa = dm_pa;
-               bfa_os_memset(dm_kva, 0, per_reqq_sz);
-               dm_kva += per_reqq_sz;
-               dm_pa += per_reqq_sz;
-
-               iocfc->rsp_cq_ba[i].kva = dm_kva;
-               iocfc->rsp_cq_ba[i].pa = dm_pa;
-               bfa_os_memset(dm_kva, 0, per_rspq_sz);
-               dm_kva += per_rspq_sz;
-               dm_pa += per_rspq_sz;
-       }
-
-       for (i = 0; i < cfg->fwcfg.num_cqs; i++) {
-               iocfc->req_cq_shadow_ci[i].kva = dm_kva;
-               iocfc->req_cq_shadow_ci[i].pa = dm_pa;
-               dm_kva += BFA_CACHELINE_SZ;
-               dm_pa += BFA_CACHELINE_SZ;
-
-               iocfc->rsp_cq_shadow_pi[i].kva = dm_kva;
-               iocfc->rsp_cq_shadow_pi[i].pa = dm_pa;
-               dm_kva += BFA_CACHELINE_SZ;
-               dm_pa += BFA_CACHELINE_SZ;
-       }
-
-       /*
-        * Claim DMA-able memory for the config info page
-        */
-       bfa->iocfc.cfg_info.kva = dm_kva;
-       bfa->iocfc.cfg_info.pa = dm_pa;
-       bfa->iocfc.cfginfo = (struct bfi_iocfc_cfg_s *) dm_kva;
-       dm_kva += BFA_ROUNDUP(sizeof(struct bfi_iocfc_cfg_s), BFA_CACHELINE_SZ);
-       dm_pa += BFA_ROUNDUP(sizeof(struct bfi_iocfc_cfg_s), BFA_CACHELINE_SZ);
-
-       /*
-        * Claim DMA-able memory for the config response
-        */
-       bfa->iocfc.cfgrsp_dma.kva = dm_kva;
-       bfa->iocfc.cfgrsp_dma.pa = dm_pa;
-       bfa->iocfc.cfgrsp = (struct bfi_iocfc_cfgrsp_s *) dm_kva;
-
-       dm_kva +=
-               BFA_ROUNDUP(sizeof(struct bfi_iocfc_cfgrsp_s),
-                           BFA_CACHELINE_SZ);
-       dm_pa += BFA_ROUNDUP(sizeof(struct bfi_iocfc_cfgrsp_s),
-                            BFA_CACHELINE_SZ);
-
-       /*
-        * Claim DMA-able memory for iocfc stats
-        */
-       bfa->iocfc.stats_kva = dm_kva;
-       bfa->iocfc.stats_pa = dm_pa;
-       bfa->iocfc.fw_stats = (struct bfa_fw_stats_s *) dm_kva;
-       dm_kva += BFA_ROUNDUP(sizeof(struct bfa_fw_stats_s), BFA_CACHELINE_SZ);
-       dm_pa += BFA_ROUNDUP(sizeof(struct bfa_fw_stats_s), BFA_CACHELINE_SZ);
-
-       bfa_meminfo_dma_virt(meminfo) = dm_kva;
-       bfa_meminfo_dma_phys(meminfo) = dm_pa;
-
-       dbgsz = bfa_ioc_debug_trcsz(bfa_auto_recover);
-       if (dbgsz > 0) {
-               bfa_ioc_debug_memclaim(&bfa->ioc, bfa_meminfo_kva(meminfo));
-               bfa_meminfo_kva(meminfo) += dbgsz;
-       }
-}
-
-/**
- * Start BFA submodules.
- */
-static void
-bfa_iocfc_start_submod(struct bfa_s *bfa)
-{
-       int             i;
-
-       bfa->rme_process = BFA_TRUE;
-
-       for (i = 0; hal_mods[i]; i++)
-               hal_mods[i]->start(bfa);
-}
-
-/**
- * Disable BFA submodules.
- */
-static void
-bfa_iocfc_disable_submod(struct bfa_s *bfa)
-{
-       int             i;
-
-       for (i = 0; hal_mods[i]; i++)
-               hal_mods[i]->iocdisable(bfa);
-}
-
-static void
-bfa_iocfc_init_cb(void *bfa_arg, bfa_boolean_t complete)
-{
-       struct bfa_s    *bfa = bfa_arg;
-
-       if (complete) {
-               if (bfa->iocfc.cfgdone)
-                       bfa_cb_init(bfa->bfad, BFA_STATUS_OK);
-               else
-                       bfa_cb_init(bfa->bfad, BFA_STATUS_FAILED);
-       } else {
-               if (bfa->iocfc.cfgdone)
-                       bfa->iocfc.action = BFA_IOCFC_ACT_NONE;
-       }
-}
-
-static void
-bfa_iocfc_stop_cb(void *bfa_arg, bfa_boolean_t compl)
-{
-       struct bfa_s  *bfa = bfa_arg;
-       struct bfad_s *bfad = bfa->bfad;
-
-       if (compl)
-               complete(&bfad->comp);
-
-       else
-               bfa->iocfc.action = BFA_IOCFC_ACT_NONE;
-}
-
-static void
-bfa_iocfc_disable_cb(void *bfa_arg, bfa_boolean_t compl)
-{
-       struct bfa_s  *bfa = bfa_arg;
-       struct bfad_s *bfad = bfa->bfad;
-
-       if (compl)
-               complete(&bfad->disable_comp);
-}
-
-/**
- * Update BFA configuration from firmware configuration.
- */
-static void
-bfa_iocfc_cfgrsp(struct bfa_s *bfa)
-{
-       struct bfa_iocfc_s              *iocfc   = &bfa->iocfc;
-       struct bfi_iocfc_cfgrsp_s       *cfgrsp  = iocfc->cfgrsp;
-       struct bfa_iocfc_fwcfg_s        *fwcfg   = &cfgrsp->fwcfg;
-
-       fwcfg->num_cqs        = fwcfg->num_cqs;
-       fwcfg->num_ioim_reqs  = bfa_os_ntohs(fwcfg->num_ioim_reqs);
-       fwcfg->num_tskim_reqs = bfa_os_ntohs(fwcfg->num_tskim_reqs);
-       fwcfg->num_fcxp_reqs  = bfa_os_ntohs(fwcfg->num_fcxp_reqs);
-       fwcfg->num_uf_bufs    = bfa_os_ntohs(fwcfg->num_uf_bufs);
-       fwcfg->num_rports     = bfa_os_ntohs(fwcfg->num_rports);
-
-       iocfc->cfgdone = BFA_TRUE;
-
-       /**
-        * Configuration is complete - initialize/start submodules
-        */
-       bfa_fcport_init(bfa);
-
-       if (iocfc->action == BFA_IOCFC_ACT_INIT)
-               bfa_cb_queue(bfa, &iocfc->init_hcb_qe, bfa_iocfc_init_cb, bfa);
-       else
-               bfa_iocfc_start_submod(bfa);
-}
-
-static void
-bfa_iocfc_stats_clear(void *bfa_arg)
-{
-       struct bfa_s            *bfa = bfa_arg;
-       struct bfa_iocfc_s      *iocfc = &bfa->iocfc;
-       struct bfi_iocfc_stats_req_s stats_req;
-
-       bfa_timer_start(bfa, &iocfc->stats_timer,
-                           bfa_iocfc_stats_clr_timeout, bfa,
-                           BFA_IOCFC_TOV);
-
-       bfi_h2i_set(stats_req.mh, BFI_MC_IOCFC, BFI_IOCFC_H2I_CLEAR_STATS_REQ,
-               bfa_lpuid(bfa));
-       bfa_ioc_mbox_send(&bfa->ioc, &stats_req,
-               sizeof(struct bfi_iocfc_stats_req_s));
-}
-
-static void
-bfa_iocfc_stats_swap(struct bfa_fw_stats_s *d, struct bfa_fw_stats_s *s)
-{
-       u32       *dip = (u32 *) d;
-       u32       *sip = (u32 *) s;
-       int             i;
-
-       for (i = 0; i < (sizeof(struct bfa_fw_stats_s) / sizeof(u32)); i++)
-               dip[i] = bfa_os_ntohl(sip[i]);
-}
-
-static void
-bfa_iocfc_stats_clr_cb(void *bfa_arg, bfa_boolean_t complete)
-{
-       struct bfa_s *bfa = bfa_arg;
-       struct bfa_iocfc_s *iocfc = &bfa->iocfc;
-
-       if (complete) {
-               bfa_ioc_clr_stats(&bfa->ioc);
-               iocfc->stats_cbfn(iocfc->stats_cbarg, iocfc->stats_status);
-       } else {
-               iocfc->stats_busy = BFA_FALSE;
-               iocfc->stats_status = BFA_STATUS_OK;
-       }
-}
-
-static void
-bfa_iocfc_stats_clr_timeout(void *bfa_arg)
-{
-       struct bfa_s            *bfa = bfa_arg;
-       struct bfa_iocfc_s      *iocfc = &bfa->iocfc;
-
-       bfa_trc(bfa, 0);
-
-       iocfc->stats_status = BFA_STATUS_ETIMER;
-       bfa_cb_queue(bfa, &iocfc->stats_hcb_qe, bfa_iocfc_stats_clr_cb, bfa);
-}
-
-static void
-bfa_iocfc_stats_cb(void *bfa_arg, bfa_boolean_t complete)
-{
-       struct bfa_s            *bfa = bfa_arg;
-       struct bfa_iocfc_s      *iocfc = &bfa->iocfc;
-
-       if (complete) {
-               if (iocfc->stats_status == BFA_STATUS_OK) {
-                       bfa_os_memset(iocfc->stats_ret, 0,
-                               sizeof(*iocfc->stats_ret));
-                       bfa_iocfc_stats_swap(&iocfc->stats_ret->fw_stats,
-                               iocfc->fw_stats);
-               }
-               iocfc->stats_cbfn(iocfc->stats_cbarg, iocfc->stats_status);
-       } else {
-               iocfc->stats_busy = BFA_FALSE;
-               iocfc->stats_status = BFA_STATUS_OK;
-       }
-}
-
-static void
-bfa_iocfc_stats_timeout(void *bfa_arg)
-{
-       struct bfa_s            *bfa = bfa_arg;
-       struct bfa_iocfc_s      *iocfc = &bfa->iocfc;
-
-       bfa_trc(bfa, 0);
-
-       iocfc->stats_status = BFA_STATUS_ETIMER;
-       bfa_cb_queue(bfa, &iocfc->stats_hcb_qe, bfa_iocfc_stats_cb, bfa);
-}
-
-static void
-bfa_iocfc_stats_query(struct bfa_s *bfa)
-{
-       struct bfa_iocfc_s      *iocfc = &bfa->iocfc;
-       struct bfi_iocfc_stats_req_s stats_req;
-
-       bfa_timer_start(bfa, &iocfc->stats_timer,
-                           bfa_iocfc_stats_timeout, bfa, BFA_IOCFC_TOV);
-
-       bfi_h2i_set(stats_req.mh, BFI_MC_IOCFC, BFI_IOCFC_H2I_GET_STATS_REQ,
-                       bfa_lpuid(bfa));
-       bfa_ioc_mbox_send(&bfa->ioc, &stats_req,
-               sizeof(struct bfi_iocfc_stats_req_s));
-}
-
-void
-bfa_iocfc_reset_queues(struct bfa_s *bfa)
-{
-       int             q;
-
-       for (q = 0; q < BFI_IOC_MAX_CQS; q++) {
-               bfa_reqq_ci(bfa, q) = 0;
-               bfa_reqq_pi(bfa, q) = 0;
-               bfa_rspq_ci(bfa, q) = 0;
-               bfa_rspq_pi(bfa, q) = 0;
-       }
-}
-
-/**
- * IOC enable request is complete
- */
-static void
-bfa_iocfc_enable_cbfn(void *bfa_arg, enum bfa_status status)
-{
-       struct bfa_s    *bfa = bfa_arg;
-
-       if (status != BFA_STATUS_OK) {
-               bfa_isr_disable(bfa);
-               if (bfa->iocfc.action == BFA_IOCFC_ACT_INIT)
-                       bfa_cb_queue(bfa, &bfa->iocfc.init_hcb_qe,
-                                    bfa_iocfc_init_cb, bfa);
-               return;
-       }
-
-       bfa_iocfc_send_cfg(bfa);
-}
-
-/**
- * IOC disable request is complete
- */
-static void
-bfa_iocfc_disable_cbfn(void *bfa_arg)
-{
-       struct bfa_s    *bfa = bfa_arg;
-
-       bfa_isr_disable(bfa);
-       bfa_iocfc_disable_submod(bfa);
-
-       if (bfa->iocfc.action == BFA_IOCFC_ACT_STOP)
-               bfa_cb_queue(bfa, &bfa->iocfc.stop_hcb_qe, bfa_iocfc_stop_cb,
-                            bfa);
-       else {
-               bfa_assert(bfa->iocfc.action == BFA_IOCFC_ACT_DISABLE);
-               bfa_cb_queue(bfa, &bfa->iocfc.dis_hcb_qe, bfa_iocfc_disable_cb,
-                            bfa);
-       }
-}
-
-/**
- * Notify sub-modules of hardware failure.
- */
-static void
-bfa_iocfc_hbfail_cbfn(void *bfa_arg)
-{
-       struct bfa_s    *bfa = bfa_arg;
-
-       bfa->rme_process = BFA_FALSE;
-
-       bfa_isr_disable(bfa);
-       bfa_iocfc_disable_submod(bfa);
-
-       if (bfa->iocfc.action == BFA_IOCFC_ACT_INIT)
-               bfa_cb_queue(bfa, &bfa->iocfc.init_hcb_qe, bfa_iocfc_init_cb,
-                            bfa);
-}
-
-/**
- * Actions on chip-reset completion.
- */
-static void
-bfa_iocfc_reset_cbfn(void *bfa_arg)
-{
-       struct bfa_s    *bfa = bfa_arg;
-
-       bfa_iocfc_reset_queues(bfa);
-       bfa_isr_enable(bfa);
-}
-
-
-
-/**
- *  bfa_ioc_public
- */
-
-/**
- * Query IOC memory requirement information.
- */
-void
-bfa_iocfc_meminfo(struct bfa_iocfc_cfg_s *cfg, u32 *km_len,
-               u32 *dm_len)
-{
-       /* dma memory for IOC */
-       *dm_len += bfa_ioc_meminfo();
-
-       bfa_iocfc_fw_cfg_sz(cfg, dm_len);
-       bfa_iocfc_cqs_sz(cfg, dm_len);
-       *km_len += bfa_ioc_debug_trcsz(bfa_auto_recover);
-}
-
-/**
- * Query IOC memory requirement information.
- */
-void
-bfa_iocfc_attach(struct bfa_s *bfa, void *bfad, struct bfa_iocfc_cfg_s *cfg,
-                  struct bfa_meminfo_s *meminfo, struct bfa_pcidev_s *pcidev)
-{
-       int             i;
-
-       bfa_iocfc_cbfn.enable_cbfn = bfa_iocfc_enable_cbfn;
-       bfa_iocfc_cbfn.disable_cbfn = bfa_iocfc_disable_cbfn;
-       bfa_iocfc_cbfn.hbfail_cbfn = bfa_iocfc_hbfail_cbfn;
-       bfa_iocfc_cbfn.reset_cbfn = bfa_iocfc_reset_cbfn;
-
-       bfa_ioc_attach(&bfa->ioc, bfa, &bfa_iocfc_cbfn, &bfa->timer_mod,
-               bfa->trcmod, bfa->aen, bfa->logm);
-
-       /**
-        * Set FC mode for BFA_PCI_DEVICE_ID_CT_FC.
-        */
-       if (pcidev->device_id == BFA_PCI_DEVICE_ID_CT_FC)
-               bfa_ioc_set_fcmode(&bfa->ioc);
-
-       bfa_ioc_pci_init(&bfa->ioc, pcidev, BFI_MC_IOCFC);
-       bfa_ioc_mbox_register(&bfa->ioc, bfa_mbox_isrs);
-
-       bfa_iocfc_init_mem(bfa, bfad, cfg, pcidev);
-       bfa_iocfc_mem_claim(bfa, cfg, meminfo);
-       bfa_timer_init(&bfa->timer_mod);
-
-       INIT_LIST_HEAD(&bfa->comp_q);
-       for (i = 0; i < BFI_IOC_MAX_CQS; i++)
-               INIT_LIST_HEAD(&bfa->reqq_waitq[i]);
-}
-
-/**
- * Query IOC memory requirement information.
- */
-void
-bfa_iocfc_detach(struct bfa_s *bfa)
-{
-       bfa_ioc_detach(&bfa->ioc);
-}
-
-/**
- * Query IOC memory requirement information.
- */
-void
-bfa_iocfc_init(struct bfa_s *bfa)
-{
-       bfa->iocfc.action = BFA_IOCFC_ACT_INIT;
-       bfa_ioc_enable(&bfa->ioc);
-}
-
-/**
- * IOC start called from bfa_start(). Called to start IOC operations
- * at driver instantiation for this instance.
- */
-void
-bfa_iocfc_start(struct bfa_s *bfa)
-{
-       if (bfa->iocfc.cfgdone)
-               bfa_iocfc_start_submod(bfa);
-}
-
-/**
- * IOC stop called from bfa_stop(). Called only when driver is unloaded
- * for this instance.
- */
-void
-bfa_iocfc_stop(struct bfa_s *bfa)
-{
-       bfa->iocfc.action = BFA_IOCFC_ACT_STOP;
-
-       bfa->rme_process = BFA_FALSE;
-       bfa_ioc_disable(&bfa->ioc);
-}
-
-void
-bfa_iocfc_isr(void *bfaarg, struct bfi_mbmsg_s *m)
-{
-       struct bfa_s            *bfa = bfaarg;
-       struct bfa_iocfc_s      *iocfc = &bfa->iocfc;
-       union bfi_iocfc_i2h_msg_u       *msg;
-
-       msg = (union bfi_iocfc_i2h_msg_u *) m;
-       bfa_trc(bfa, msg->mh.msg_id);
-
-       switch (msg->mh.msg_id) {
-       case BFI_IOCFC_I2H_CFG_REPLY:
-               iocfc->cfg_reply = &msg->cfg_reply;
-               bfa_iocfc_cfgrsp(bfa);
-               break;
-
-       case BFI_IOCFC_I2H_GET_STATS_RSP:
-               if (iocfc->stats_busy == BFA_FALSE
-                   || iocfc->stats_status == BFA_STATUS_ETIMER)
-                       break;
-
-               bfa_timer_stop(&iocfc->stats_timer);
-               iocfc->stats_status = BFA_STATUS_OK;
-               bfa_cb_queue(bfa, &iocfc->stats_hcb_qe, bfa_iocfc_stats_cb,
-                             bfa);
-               break;
-       case BFI_IOCFC_I2H_CLEAR_STATS_RSP:
-               /*
-                * check for timer pop before processing the rsp
-                */
-               if (iocfc->stats_busy == BFA_FALSE
-                   || iocfc->stats_status == BFA_STATUS_ETIMER)
-                       break;
-
-               bfa_timer_stop(&iocfc->stats_timer);
-               iocfc->stats_status = BFA_STATUS_OK;
-               bfa_cb_queue(bfa, &iocfc->stats_hcb_qe,
-                             bfa_iocfc_stats_clr_cb, bfa);
-               break;
-       case BFI_IOCFC_I2H_UPDATEQ_RSP:
-               iocfc->updateq_cbfn(iocfc->updateq_cbarg, BFA_STATUS_OK);
-               break;
-       default:
-               bfa_assert(0);
-       }
-}
-
-#ifndef BFA_BIOS_BUILD
-void
-bfa_adapter_get_attr(struct bfa_s *bfa, struct bfa_adapter_attr_s *ad_attr)
-{
-       bfa_ioc_get_adapter_attr(&bfa->ioc, ad_attr);
-}
-
-u64
-bfa_adapter_get_id(struct bfa_s *bfa)
-{
-       return bfa_ioc_get_adid(&bfa->ioc);
-}
-
-void
-bfa_iocfc_get_attr(struct bfa_s *bfa, struct bfa_iocfc_attr_s *attr)
-{
-       struct bfa_iocfc_s      *iocfc = &bfa->iocfc;
-
-       attr->intr_attr.coalesce = iocfc->cfginfo->intr_attr.coalesce;
-
-       attr->intr_attr.delay = iocfc->cfginfo->intr_attr.delay ?
-                       bfa_os_ntohs(iocfc->cfginfo->intr_attr.delay) :
-                       bfa_os_ntohs(iocfc->cfgrsp->intr_attr.delay);
-
-       attr->intr_attr.latency = iocfc->cfginfo->intr_attr.latency ?
-                       bfa_os_ntohs(iocfc->cfginfo->intr_attr.latency) :
-                       bfa_os_ntohs(iocfc->cfgrsp->intr_attr.latency);
-
-       attr->config    = iocfc->cfg;
-
-}
-
-bfa_status_t
-bfa_iocfc_israttr_set(struct bfa_s *bfa, struct bfa_iocfc_intr_attr_s *attr)
-{
-       struct bfa_iocfc_s              *iocfc = &bfa->iocfc;
-       struct bfi_iocfc_set_intr_req_s *m;
-
-       iocfc->cfginfo->intr_attr.coalesce = attr->coalesce;
-       iocfc->cfginfo->intr_attr.delay = bfa_os_htons(attr->delay);
-       iocfc->cfginfo->intr_attr.latency = bfa_os_htons(attr->latency);
-
-       if (!bfa_iocfc_is_operational(bfa))
-               return BFA_STATUS_OK;
-
-       m = bfa_reqq_next(bfa, BFA_REQQ_IOC);
-       if (!m)
-               return BFA_STATUS_DEVBUSY;
-
-       bfi_h2i_set(m->mh, BFI_MC_IOCFC, BFI_IOCFC_H2I_SET_INTR_REQ,
-                       bfa_lpuid(bfa));
-       m->coalesce = iocfc->cfginfo->intr_attr.coalesce;
-       m->delay    = iocfc->cfginfo->intr_attr.delay;
-       m->latency  = iocfc->cfginfo->intr_attr.latency;
-
-
-       bfa_trc(bfa, attr->delay);
-       bfa_trc(bfa, attr->latency);
-
-       bfa_reqq_produce(bfa, BFA_REQQ_IOC);
-       return BFA_STATUS_OK;
-}
-
-void
-bfa_iocfc_set_snsbase(struct bfa_s *bfa, u64 snsbase_pa)
-{
-       struct bfa_iocfc_s      *iocfc = &bfa->iocfc;
-
-       iocfc->cfginfo->sense_buf_len = (BFI_IOIM_SNSLEN - 1);
-       bfa_dma_be_addr_set(iocfc->cfginfo->ioim_snsbase, snsbase_pa);
-}
-
-bfa_status_t
-bfa_iocfc_get_stats(struct bfa_s *bfa, struct bfa_iocfc_stats_s *stats,
-                     bfa_cb_ioc_t cbfn, void *cbarg)
-{
-       struct bfa_iocfc_s      *iocfc = &bfa->iocfc;
-
-       if (iocfc->stats_busy) {
-               bfa_trc(bfa, iocfc->stats_busy);
-               return BFA_STATUS_DEVBUSY;
-       }
-
-       if (!bfa_iocfc_is_operational(bfa)) {
-               bfa_trc(bfa, 0);
-               return BFA_STATUS_IOC_NON_OP;
-       }
-
-       iocfc->stats_busy = BFA_TRUE;
-       iocfc->stats_ret = stats;
-       iocfc->stats_cbfn = cbfn;
-       iocfc->stats_cbarg = cbarg;
-
-       bfa_iocfc_stats_query(bfa);
-
-       return BFA_STATUS_OK;
-}
-
-bfa_status_t
-bfa_iocfc_clear_stats(struct bfa_s *bfa, bfa_cb_ioc_t cbfn, void *cbarg)
-{
-       struct bfa_iocfc_s      *iocfc = &bfa->iocfc;
-
-       if (iocfc->stats_busy) {
-               bfa_trc(bfa, iocfc->stats_busy);
-               return BFA_STATUS_DEVBUSY;
-       }
-
-       if (!bfa_iocfc_is_operational(bfa)) {
-               bfa_trc(bfa, 0);
-               return BFA_STATUS_IOC_NON_OP;
-       }
-
-       iocfc->stats_busy = BFA_TRUE;
-       iocfc->stats_cbfn = cbfn;
-       iocfc->stats_cbarg = cbarg;
-
-       bfa_iocfc_stats_clear(bfa);
-       return BFA_STATUS_OK;
-}
-
-/**
- * Enable IOC after it is disabled.
- */
-void
-bfa_iocfc_enable(struct bfa_s *bfa)
-{
-       bfa_plog_str(bfa->plog, BFA_PL_MID_HAL, BFA_PL_EID_MISC, 0,
-                    "IOC Enable");
-       bfa_ioc_enable(&bfa->ioc);
-}
-
-void
-bfa_iocfc_disable(struct bfa_s *bfa)
-{
-       bfa_plog_str(bfa->plog, BFA_PL_MID_HAL, BFA_PL_EID_MISC, 0,
-                    "IOC Disable");
-       bfa->iocfc.action = BFA_IOCFC_ACT_DISABLE;
-
-       bfa->rme_process = BFA_FALSE;
-       bfa_ioc_disable(&bfa->ioc);
-}
-
-
-bfa_boolean_t
-bfa_iocfc_is_operational(struct bfa_s *bfa)
-{
-       return bfa_ioc_is_operational(&bfa->ioc) && bfa->iocfc.cfgdone;
-}
-
-/**
- * Return boot target port wwns -- read from boot information in flash.
- */
-void
-bfa_iocfc_get_bootwwns(struct bfa_s *bfa, u8 *nwwns, wwn_t *wwns)
-{
-       struct bfa_iocfc_s *iocfc = &bfa->iocfc;
-       struct bfi_iocfc_cfgrsp_s *cfgrsp = iocfc->cfgrsp;
-       int i;
-
-       if (cfgrsp->pbc_cfg.boot_enabled && cfgrsp->pbc_cfg.nbluns) {
-               bfa_trc(bfa, cfgrsp->pbc_cfg.nbluns);
-               *nwwns = cfgrsp->pbc_cfg.nbluns;
-               for (i = 0; i < cfgrsp->pbc_cfg.nbluns; i++)
-                       wwns[i] = cfgrsp->pbc_cfg.blun[i].tgt_pwwn;
-
-               return;
-       }
-
-       *nwwns = cfgrsp->bootwwns.nwwns;
-       memcpy(wwns, cfgrsp->bootwwns.wwn, sizeof(cfgrsp->bootwwns.wwn));
-}
-
-void
-bfa_iocfc_get_pbc_boot_cfg(struct bfa_s *bfa, struct bfa_boot_pbc_s *pbcfg)
-{
-       struct bfa_iocfc_s *iocfc = &bfa->iocfc;
-       struct bfi_iocfc_cfgrsp_s *cfgrsp = iocfc->cfgrsp;
-
-       pbcfg->enable = cfgrsp->pbc_cfg.boot_enabled;
-       pbcfg->nbluns = cfgrsp->pbc_cfg.nbluns;
-       pbcfg->speed = cfgrsp->pbc_cfg.port_speed;
-       memcpy(pbcfg->pblun, cfgrsp->pbc_cfg.blun, sizeof(pbcfg->pblun));
-}
-
-int
-bfa_iocfc_get_pbc_vports(struct bfa_s *bfa, struct bfi_pbc_vport_s *pbc_vport)
-{
-       struct bfa_iocfc_s *iocfc = &bfa->iocfc;
-       struct bfi_iocfc_cfgrsp_s *cfgrsp = iocfc->cfgrsp;
-
-       memcpy(pbc_vport, cfgrsp->pbc_cfg.vport, sizeof(cfgrsp->pbc_cfg.vport));
-       return cfgrsp->pbc_cfg.nvports;
-}
-
-
-#endif
-
-
diff --git a/drivers/scsi/bfa/bfa_iocfc.h b/drivers/scsi/bfa/bfa_iocfc.h
deleted file mode 100644 (file)
index 74a6a04..0000000
+++ /dev/null
@@ -1,184 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_IOCFC_H__
-#define __BFA_IOCFC_H__
-
-#include <bfa_ioc.h>
-#include <bfa.h>
-#include <bfi/bfi_iocfc.h>
-#include <bfi/bfi_pbc.h>
-#include <bfa_callback_priv.h>
-
-#define BFA_REQQ_NELEMS_MIN    (4)
-#define BFA_RSPQ_NELEMS_MIN    (4)
-
-struct bfa_iocfc_regs_s {
-       bfa_os_addr_t   intr_status;
-       bfa_os_addr_t   intr_mask;
-       bfa_os_addr_t   cpe_q_pi[BFI_IOC_MAX_CQS];
-       bfa_os_addr_t   cpe_q_ci[BFI_IOC_MAX_CQS];
-       bfa_os_addr_t   cpe_q_depth[BFI_IOC_MAX_CQS];
-       bfa_os_addr_t   cpe_q_ctrl[BFI_IOC_MAX_CQS];
-       bfa_os_addr_t   rme_q_ci[BFI_IOC_MAX_CQS];
-       bfa_os_addr_t   rme_q_pi[BFI_IOC_MAX_CQS];
-       bfa_os_addr_t   rme_q_depth[BFI_IOC_MAX_CQS];
-       bfa_os_addr_t   rme_q_ctrl[BFI_IOC_MAX_CQS];
-};
-
-/**
- * MSIX vector handlers
- */
-#define BFA_MSIX_MAX_VECTORS   22
-typedef void (*bfa_msix_handler_t)(struct bfa_s *bfa, int vec);
-struct bfa_msix_s {
-       int     nvecs;
-       bfa_msix_handler_t handler[BFA_MSIX_MAX_VECTORS];
-};
-
-/**
- * Chip specific interfaces
- */
-struct bfa_hwif_s {
-       void (*hw_reginit)(struct bfa_s *bfa);
-       void (*hw_reqq_ack)(struct bfa_s *bfa, int reqq);
-       void (*hw_rspq_ack)(struct bfa_s *bfa, int rspq);
-       void (*hw_msix_init)(struct bfa_s *bfa, int nvecs);
-       void (*hw_msix_install)(struct bfa_s *bfa);
-       void (*hw_msix_uninstall)(struct bfa_s *bfa);
-       void (*hw_isr_mode_set)(struct bfa_s *bfa, bfa_boolean_t msix);
-       void (*hw_msix_getvecs)(struct bfa_s *bfa, u32 *vecmap,
-                       u32 *nvecs, u32 *maxvec);
-       void (*hw_msix_get_rme_range) (struct bfa_s *bfa, u32 *start,
-                       u32 *end);
-};
-typedef void (*bfa_cb_iocfc_t) (void *cbarg, enum bfa_status status);
-
-struct bfa_iocfc_s {
-       struct bfa_s            *bfa;
-       struct bfa_iocfc_cfg_s  cfg;
-       int                     action;
-
-       u32             req_cq_pi[BFI_IOC_MAX_CQS];
-       u32             rsp_cq_ci[BFI_IOC_MAX_CQS];
-
-       struct bfa_cb_qe_s      init_hcb_qe;
-       struct bfa_cb_qe_s      stop_hcb_qe;
-       struct bfa_cb_qe_s      dis_hcb_qe;
-       struct bfa_cb_qe_s      stats_hcb_qe;
-       bfa_boolean_t           cfgdone;
-
-       struct bfa_dma_s        cfg_info;
-       struct bfi_iocfc_cfg_s *cfginfo;
-       struct bfa_dma_s        cfgrsp_dma;
-       struct bfi_iocfc_cfgrsp_s *cfgrsp;
-       struct bfi_iocfc_cfg_reply_s *cfg_reply;
-
-       u8                      *stats_kva;
-       u64             stats_pa;
-       struct bfa_fw_stats_s   *fw_stats;
-       struct bfa_timer_s      stats_timer;    /*  timer */
-       struct bfa_iocfc_stats_s *stats_ret;    /*  driver stats location */
-       bfa_status_t            stats_status;   /*  stats/statsclr status */
-       bfa_boolean_t           stats_busy;     /*  outstanding stats */
-       bfa_cb_ioc_t            stats_cbfn;     /*  driver callback function */
-       void                    *stats_cbarg;   /*  user callback arg */
-
-       struct bfa_dma_s        req_cq_ba[BFI_IOC_MAX_CQS];
-       struct bfa_dma_s        req_cq_shadow_ci[BFI_IOC_MAX_CQS];
-       struct bfa_dma_s        rsp_cq_ba[BFI_IOC_MAX_CQS];
-       struct bfa_dma_s        rsp_cq_shadow_pi[BFI_IOC_MAX_CQS];
-       struct bfa_iocfc_regs_s bfa_regs;       /*  BFA device registers */
-       struct bfa_hwif_s       hwif;
-
-       bfa_cb_iocfc_t          updateq_cbfn; /*  bios callback function */
-       void                    *updateq_cbarg; /*  bios callback arg */
-       u32                     intr_mask;
-};
-
-#define bfa_lpuid(__bfa)               bfa_ioc_portid(&(__bfa)->ioc)
-#define bfa_msix_init(__bfa, __nvecs)  \
-       ((__bfa)->iocfc.hwif.hw_msix_init(__bfa, __nvecs))
-#define bfa_msix_install(__bfa)        \
-       ((__bfa)->iocfc.hwif.hw_msix_install(__bfa))
-#define bfa_msix_uninstall(__bfa)      \
-       ((__bfa)->iocfc.hwif.hw_msix_uninstall(__bfa))
-#define bfa_isr_mode_set(__bfa, __msix)        \
-       ((__bfa)->iocfc.hwif.hw_isr_mode_set(__bfa, __msix))
-#define bfa_msix_getvecs(__bfa, __vecmap, __nvecs, __maxvec)   \
-       ((__bfa)->iocfc.hwif.hw_msix_getvecs(__bfa, __vecmap,   \
-                __nvecs, __maxvec))
-#define bfa_msix_get_rme_range(__bfa, __start, __end)   \
-       ((__bfa)->iocfc.hwif.hw_msix_get_rme_range(__bfa, __start, __end))
-
-/*
- * FC specific IOC functions.
- */
-void bfa_iocfc_meminfo(struct bfa_iocfc_cfg_s *cfg, u32 *km_len,
-               u32 *dm_len);
-void bfa_iocfc_attach(struct bfa_s *bfa, void *bfad,
-               struct bfa_iocfc_cfg_s *cfg, struct bfa_meminfo_s *meminfo,
-               struct bfa_pcidev_s *pcidev);
-void bfa_iocfc_detach(struct bfa_s *bfa);
-void bfa_iocfc_init(struct bfa_s *bfa);
-void bfa_iocfc_start(struct bfa_s *bfa);
-void bfa_iocfc_stop(struct bfa_s *bfa);
-void bfa_iocfc_isr(void *bfa, struct bfi_mbmsg_s *msg);
-void bfa_iocfc_set_snsbase(struct bfa_s *bfa, u64 snsbase_pa);
-bfa_boolean_t bfa_iocfc_is_operational(struct bfa_s *bfa);
-void bfa_iocfc_reset_queues(struct bfa_s *bfa);
-void bfa_iocfc_updateq(struct bfa_s *bfa, u32 reqq_ba, u32 rspq_ba,
-                       u32 reqq_sci, u32 rspq_spi,
-                       bfa_cb_iocfc_t cbfn, void *cbarg);
-
-void bfa_msix_all(struct bfa_s *bfa, int vec);
-void bfa_msix_reqq(struct bfa_s *bfa, int vec);
-void bfa_msix_rspq(struct bfa_s *bfa, int vec);
-void bfa_msix_lpu_err(struct bfa_s *bfa, int vec);
-
-void bfa_hwcb_reginit(struct bfa_s *bfa);
-void bfa_hwcb_reqq_ack(struct bfa_s *bfa, int rspq);
-void bfa_hwcb_rspq_ack(struct bfa_s *bfa, int rspq);
-void bfa_hwcb_msix_init(struct bfa_s *bfa, int nvecs);
-void bfa_hwcb_msix_install(struct bfa_s *bfa);
-void bfa_hwcb_msix_uninstall(struct bfa_s *bfa);
-void bfa_hwcb_isr_mode_set(struct bfa_s *bfa, bfa_boolean_t msix);
-void bfa_hwcb_msix_getvecs(struct bfa_s *bfa, u32 *vecmap,
-                       u32 *nvecs, u32 *maxvec);
-void bfa_hwcb_msix_get_rme_range(struct bfa_s *bfa, u32 *start, u32 *end);
-void bfa_hwct_reginit(struct bfa_s *bfa);
-void bfa_hwct_reqq_ack(struct bfa_s *bfa, int rspq);
-void bfa_hwct_rspq_ack(struct bfa_s *bfa, int rspq);
-void bfa_hwct_msix_init(struct bfa_s *bfa, int nvecs);
-void bfa_hwct_msix_install(struct bfa_s *bfa);
-void bfa_hwct_msix_uninstall(struct bfa_s *bfa);
-void bfa_hwct_isr_mode_set(struct bfa_s *bfa, bfa_boolean_t msix);
-void bfa_hwct_msix_getvecs(struct bfa_s *bfa, u32 *vecmap,
-                       u32 *nvecs, u32 *maxvec);
-void bfa_hwct_msix_get_rme_range(struct bfa_s *bfa, u32 *start, u32 *end);
-
-void bfa_com_meminfo(bfa_boolean_t mincfg, u32 *dm_len);
-void bfa_com_attach(struct bfa_s *bfa, struct bfa_meminfo_s *mi,
-               bfa_boolean_t mincfg);
-void bfa_iocfc_get_bootwwns(struct bfa_s *bfa, u8 *nwwns, wwn_t *wwns);
-void bfa_iocfc_get_pbc_boot_cfg(struct bfa_s *bfa,
-               struct bfa_boot_pbc_s *pbcfg);
-int bfa_iocfc_get_pbc_vports(struct bfa_s *bfa,
-               struct bfi_pbc_vport_s *pbc_vport);
-
-#endif /* __BFA_IOCFC_H__ */
-
diff --git a/drivers/scsi/bfa/bfa_iocfc_q.c b/drivers/scsi/bfa/bfa_iocfc_q.c
deleted file mode 100644 (file)
index 500a17d..0000000
+++ /dev/null
@@ -1,44 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#include <bfa.h>
-#include "bfa_intr_priv.h"
-
-BFA_TRC_FILE(HAL, IOCFC_Q);
-
-void
-bfa_iocfc_updateq(struct bfa_s *bfa, u32 reqq_ba, u32 rspq_ba,
-                               u32 reqq_sci, u32 rspq_spi, bfa_cb_iocfc_t cbfn,
-                               void *cbarg)
-{
-       struct bfa_iocfc_s *iocfc = &bfa->iocfc;
-       struct bfi_iocfc_updateq_req_s updateq_req;
-
-       iocfc->updateq_cbfn = cbfn;
-       iocfc->updateq_cbarg = cbarg;
-
-       bfi_h2i_set(updateq_req.mh, BFI_MC_IOCFC, BFI_IOCFC_H2I_UPDATEQ_REQ,
-                       bfa_lpuid(bfa));
-
-       updateq_req.reqq_ba = bfa_os_htonl(reqq_ba);
-       updateq_req.rspq_ba = bfa_os_htonl(rspq_ba);
-       updateq_req.reqq_sci = bfa_os_htonl(reqq_sci);
-       updateq_req.rspq_spi = bfa_os_htonl(rspq_spi);
-
-       bfa_ioc_mbox_send(&bfa->ioc, &updateq_req,
-                       sizeof(struct bfi_iocfc_updateq_req_s));
-}
diff --git a/drivers/scsi/bfa/bfa_ioim.c b/drivers/scsi/bfa/bfa_ioim.c
deleted file mode 100644 (file)
index bdfdc19..0000000
+++ /dev/null
@@ -1,1364 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#include <bfa.h>
-#include <cs/bfa_debug.h>
-#include <bfa_cb_ioim_macros.h>
-
-BFA_TRC_FILE(HAL, IOIM);
-
-/*
- * forward declarations.
- */
-static bfa_boolean_t   bfa_ioim_send_ioreq(struct bfa_ioim_s *ioim);
-static bfa_boolean_t   bfa_ioim_sge_setup(struct bfa_ioim_s *ioim);
-static void            bfa_ioim_sgpg_setup(struct bfa_ioim_s *ioim);
-static bfa_boolean_t   bfa_ioim_send_abort(struct bfa_ioim_s *ioim);
-static void            bfa_ioim_notify_cleanup(struct bfa_ioim_s *ioim);
-static void __bfa_cb_ioim_good_comp(void *cbarg, bfa_boolean_t complete);
-static void __bfa_cb_ioim_comp(void *cbarg, bfa_boolean_t complete);
-static void __bfa_cb_ioim_abort(void *cbarg, bfa_boolean_t complete);
-static void __bfa_cb_ioim_failed(void *cbarg, bfa_boolean_t complete);
-static void __bfa_cb_ioim_pathtov(void *cbarg, bfa_boolean_t complete);
-
-/**
- *  bfa_ioim_sm
- */
-
-/**
- * IO state machine events
- */
-enum bfa_ioim_event {
-       BFA_IOIM_SM_START = 1,          /*  io start request from host */
-       BFA_IOIM_SM_COMP_GOOD = 2,      /*  io good comp, resource free */
-       BFA_IOIM_SM_COMP = 3,           /*  io comp, resource is free */
-       BFA_IOIM_SM_COMP_UTAG = 4,      /*  io comp, resource is free */
-       BFA_IOIM_SM_DONE = 5,           /*  io comp, resource not free */
-       BFA_IOIM_SM_FREE = 6,           /*  io resource is freed */
-       BFA_IOIM_SM_ABORT = 7,          /*  abort request from scsi stack */
-       BFA_IOIM_SM_ABORT_COMP = 8,     /*  abort from f/w */
-       BFA_IOIM_SM_ABORT_DONE = 9,     /*  abort completion from f/w */
-       BFA_IOIM_SM_QRESUME = 10,       /*  CQ space available to queue IO */
-       BFA_IOIM_SM_SGALLOCED = 11,     /*  SG page allocation successful */
-       BFA_IOIM_SM_SQRETRY = 12,       /*  sequence recovery retry */
-       BFA_IOIM_SM_HCB = 13,           /*  bfa callback complete */
-       BFA_IOIM_SM_CLEANUP = 14,       /*  IO cleanup from itnim */
-       BFA_IOIM_SM_TMSTART = 15,       /*  IO cleanup from tskim */
-       BFA_IOIM_SM_TMDONE = 16,        /*  IO cleanup from tskim */
-       BFA_IOIM_SM_HWFAIL = 17,        /*  IOC h/w failure event */
-       BFA_IOIM_SM_IOTOV = 18,         /*  ITN offline TOV       */
-};
-
-/*
- * forward declaration of IO state machine
- */
-static void     bfa_ioim_sm_uninit(struct bfa_ioim_s *ioim,
-                                      enum bfa_ioim_event event);
-static void     bfa_ioim_sm_sgalloc(struct bfa_ioim_s *ioim,
-                                       enum bfa_ioim_event event);
-static void     bfa_ioim_sm_active(struct bfa_ioim_s *ioim,
-                                      enum bfa_ioim_event event);
-static void     bfa_ioim_sm_abort(struct bfa_ioim_s *ioim,
-                                     enum bfa_ioim_event event);
-static void     bfa_ioim_sm_cleanup(struct bfa_ioim_s *ioim,
-                                       enum bfa_ioim_event event);
-static void     bfa_ioim_sm_qfull(struct bfa_ioim_s *ioim,
-                                     enum bfa_ioim_event event);
-static void     bfa_ioim_sm_abort_qfull(struct bfa_ioim_s *ioim,
-                                           enum bfa_ioim_event event);
-static void     bfa_ioim_sm_cleanup_qfull(struct bfa_ioim_s *ioim,
-                                             enum bfa_ioim_event event);
-static void     bfa_ioim_sm_hcb(struct bfa_ioim_s *ioim,
-                                   enum bfa_ioim_event event);
-static void     bfa_ioim_sm_hcb_free(struct bfa_ioim_s *ioim,
-                                        enum bfa_ioim_event event);
-static void     bfa_ioim_sm_resfree(struct bfa_ioim_s *ioim,
-                                       enum bfa_ioim_event event);
-
-/**
- *             IO is not started (unallocated).
- */
-static void
-bfa_ioim_sm_uninit(struct bfa_ioim_s *ioim, enum bfa_ioim_event event)
-{
-       bfa_trc_fp(ioim->bfa, ioim->iotag);
-       bfa_trc_fp(ioim->bfa, event);
-
-       switch (event) {
-       case BFA_IOIM_SM_START:
-               if (!bfa_itnim_is_online(ioim->itnim)) {
-                       if (!bfa_itnim_hold_io(ioim->itnim)) {
-                               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
-                               list_del(&ioim->qe);
-                               list_add_tail(&ioim->qe,
-                                               &ioim->fcpim->ioim_comp_q);
-                               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe,
-                                               __bfa_cb_ioim_pathtov, ioim);
-                       } else {
-                               list_del(&ioim->qe);
-                               list_add_tail(&ioim->qe,
-                                               &ioim->itnim->pending_q);
-                       }
-                       break;
-               }
-
-               if (ioim->nsges > BFI_SGE_INLINE) {
-                       if (!bfa_ioim_sge_setup(ioim)) {
-                               bfa_sm_set_state(ioim, bfa_ioim_sm_sgalloc);
-                               return;
-                       }
-               }
-
-               if (!bfa_ioim_send_ioreq(ioim)) {
-                       bfa_sm_set_state(ioim, bfa_ioim_sm_qfull);
-                       break;
-               }
-
-               bfa_sm_set_state(ioim, bfa_ioim_sm_active);
-               break;
-
-       case BFA_IOIM_SM_IOTOV:
-               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
-               list_del(&ioim->qe);
-               list_add_tail(&ioim->qe, &ioim->fcpim->ioim_comp_q);
-               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe,
-                               __bfa_cb_ioim_pathtov, ioim);
-               break;
-
-       case BFA_IOIM_SM_ABORT:
-               /**
-                * IO in pending queue can get abort requests. Complete abort
-                * requests immediately.
-                */
-               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
-               bfa_assert(bfa_q_is_on_q(&ioim->itnim->pending_q, ioim));
-               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_abort,
-                               ioim);
-               break;
-
-       default:
-               bfa_sm_fault(ioim->bfa, event);
-       }
-}
-
-/**
- *             IO is waiting for SG pages.
- */
-static void
-bfa_ioim_sm_sgalloc(struct bfa_ioim_s *ioim, enum bfa_ioim_event event)
-{
-       bfa_trc(ioim->bfa, ioim->iotag);
-       bfa_trc(ioim->bfa, event);
-
-       switch (event) {
-       case BFA_IOIM_SM_SGALLOCED:
-               if (!bfa_ioim_send_ioreq(ioim)) {
-                       bfa_sm_set_state(ioim, bfa_ioim_sm_qfull);
-                       break;
-               }
-               bfa_sm_set_state(ioim, bfa_ioim_sm_active);
-               break;
-
-       case BFA_IOIM_SM_CLEANUP:
-               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
-               bfa_sgpg_wcancel(ioim->bfa, &ioim->iosp->sgpg_wqe);
-               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_failed,
-                             ioim);
-               bfa_ioim_notify_cleanup(ioim);
-               break;
-
-       case BFA_IOIM_SM_ABORT:
-               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
-               bfa_sgpg_wcancel(ioim->bfa, &ioim->iosp->sgpg_wqe);
-               list_del(&ioim->qe);
-               list_add_tail(&ioim->qe, &ioim->fcpim->ioim_comp_q);
-               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_abort,
-                             ioim);
-               break;
-
-       case BFA_IOIM_SM_HWFAIL:
-               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
-               bfa_sgpg_wcancel(ioim->bfa, &ioim->iosp->sgpg_wqe);
-               list_del(&ioim->qe);
-               list_add_tail(&ioim->qe, &ioim->fcpim->ioim_comp_q);
-               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_failed,
-                             ioim);
-               break;
-
-       default:
-               bfa_sm_fault(ioim->bfa, event);
-       }
-}
-
-/**
- *             IO is active.
- */
-static void
-bfa_ioim_sm_active(struct bfa_ioim_s *ioim, enum bfa_ioim_event event)
-{
-       bfa_trc_fp(ioim->bfa, ioim->iotag);
-       bfa_trc_fp(ioim->bfa, event);
-
-       switch (event) {
-       case BFA_IOIM_SM_COMP_GOOD:
-               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
-               list_del(&ioim->qe);
-               list_add_tail(&ioim->qe, &ioim->fcpim->ioim_comp_q);
-               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe,
-                             __bfa_cb_ioim_good_comp, ioim);
-               break;
-
-       case BFA_IOIM_SM_COMP:
-               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
-               list_del(&ioim->qe);
-               list_add_tail(&ioim->qe, &ioim->fcpim->ioim_comp_q);
-               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_comp,
-                             ioim);
-               break;
-
-       case BFA_IOIM_SM_DONE:
-               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb_free);
-               list_del(&ioim->qe);
-               list_add_tail(&ioim->qe, &ioim->fcpim->ioim_comp_q);
-               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_comp,
-                             ioim);
-               break;
-
-       case BFA_IOIM_SM_ABORT:
-               ioim->iosp->abort_explicit = BFA_TRUE;
-               ioim->io_cbfn = __bfa_cb_ioim_abort;
-
-               if (bfa_ioim_send_abort(ioim))
-                       bfa_sm_set_state(ioim, bfa_ioim_sm_abort);
-               else {
-                       bfa_sm_set_state(ioim, bfa_ioim_sm_abort_qfull);
-                       bfa_reqq_wait(ioim->bfa, ioim->reqq,
-                                       &ioim->iosp->reqq_wait);
-               }
-               break;
-
-       case BFA_IOIM_SM_CLEANUP:
-               ioim->iosp->abort_explicit = BFA_FALSE;
-               ioim->io_cbfn = __bfa_cb_ioim_failed;
-
-               if (bfa_ioim_send_abort(ioim))
-                       bfa_sm_set_state(ioim, bfa_ioim_sm_cleanup);
-               else {
-                       bfa_sm_set_state(ioim, bfa_ioim_sm_cleanup_qfull);
-                       bfa_reqq_wait(ioim->bfa, ioim->reqq,
-                                       &ioim->iosp->reqq_wait);
-               }
-               break;
-
-       case BFA_IOIM_SM_HWFAIL:
-               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
-               list_del(&ioim->qe);
-               list_add_tail(&ioim->qe, &ioim->fcpim->ioim_comp_q);
-               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_failed,
-                             ioim);
-               break;
-
-       default:
-               bfa_sm_fault(ioim->bfa, event);
-       }
-}
-
-/**
- *             IO is being aborted, waiting for completion from firmware.
- */
-static void
-bfa_ioim_sm_abort(struct bfa_ioim_s *ioim, enum bfa_ioim_event event)
-{
-       bfa_trc(ioim->bfa, ioim->iotag);
-       bfa_trc(ioim->bfa, event);
-
-       switch (event) {
-       case BFA_IOIM_SM_COMP_GOOD:
-       case BFA_IOIM_SM_COMP:
-       case BFA_IOIM_SM_DONE:
-       case BFA_IOIM_SM_FREE:
-               break;
-
-       case BFA_IOIM_SM_ABORT_DONE:
-               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb_free);
-               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_abort,
-                             ioim);
-               break;
-
-       case BFA_IOIM_SM_ABORT_COMP:
-               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
-               list_del(&ioim->qe);
-               list_add_tail(&ioim->qe, &ioim->fcpim->ioim_comp_q);
-               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_abort,
-                             ioim);
-               break;
-
-       case BFA_IOIM_SM_COMP_UTAG:
-               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
-               list_del(&ioim->qe);
-               list_add_tail(&ioim->qe, &ioim->fcpim->ioim_comp_q);
-               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_abort,
-                             ioim);
-               break;
-
-       case BFA_IOIM_SM_CLEANUP:
-               bfa_assert(ioim->iosp->abort_explicit == BFA_TRUE);
-               ioim->iosp->abort_explicit = BFA_FALSE;
-
-               if (bfa_ioim_send_abort(ioim))
-                       bfa_sm_set_state(ioim, bfa_ioim_sm_cleanup);
-               else {
-                       bfa_sm_set_state(ioim, bfa_ioim_sm_cleanup_qfull);
-                       bfa_reqq_wait(ioim->bfa, ioim->reqq,
-                                         &ioim->iosp->reqq_wait);
-               }
-               break;
-
-       case BFA_IOIM_SM_HWFAIL:
-               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
-               list_del(&ioim->qe);
-               list_add_tail(&ioim->qe, &ioim->fcpim->ioim_comp_q);
-               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_failed,
-                             ioim);
-               break;
-
-       default:
-               bfa_sm_fault(ioim->bfa, event);
-       }
-}
-
-/**
- * IO is being cleaned up (implicit abort), waiting for completion from
- * firmware.
- */
-static void
-bfa_ioim_sm_cleanup(struct bfa_ioim_s *ioim, enum bfa_ioim_event event)
-{
-       bfa_trc(ioim->bfa, ioim->iotag);
-       bfa_trc(ioim->bfa, event);
-
-       switch (event) {
-       case BFA_IOIM_SM_COMP_GOOD:
-       case BFA_IOIM_SM_COMP:
-       case BFA_IOIM_SM_DONE:
-       case BFA_IOIM_SM_FREE:
-               break;
-
-       case BFA_IOIM_SM_ABORT:
-               /**
-                * IO is already being aborted implicitly
-                */
-               ioim->io_cbfn = __bfa_cb_ioim_abort;
-               break;
-
-       case BFA_IOIM_SM_ABORT_DONE:
-               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb_free);
-               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, ioim->io_cbfn, ioim);
-               bfa_ioim_notify_cleanup(ioim);
-               break;
-
-       case BFA_IOIM_SM_ABORT_COMP:
-               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
-               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, ioim->io_cbfn, ioim);
-               bfa_ioim_notify_cleanup(ioim);
-               break;
-
-       case BFA_IOIM_SM_COMP_UTAG:
-               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
-               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, ioim->io_cbfn, ioim);
-               bfa_ioim_notify_cleanup(ioim);
-               break;
-
-       case BFA_IOIM_SM_HWFAIL:
-               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
-               list_del(&ioim->qe);
-               list_add_tail(&ioim->qe, &ioim->fcpim->ioim_comp_q);
-               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_failed,
-                             ioim);
-               break;
-
-       case BFA_IOIM_SM_CLEANUP:
-               /**
-                * IO can be in cleanup state already due to TM command. 2nd cleanup
-                * request comes from ITN offline event.
-                */
-               break;
-
-       default:
-               bfa_sm_fault(ioim->bfa, event);
-       }
-}
-
-/**
- *             IO is waiting for room in request CQ
- */
-static void
-bfa_ioim_sm_qfull(struct bfa_ioim_s *ioim, enum bfa_ioim_event event)
-{
-       bfa_trc(ioim->bfa, ioim->iotag);
-       bfa_trc(ioim->bfa, event);
-
-       switch (event) {
-       case BFA_IOIM_SM_QRESUME:
-               bfa_sm_set_state(ioim, bfa_ioim_sm_active);
-               bfa_ioim_send_ioreq(ioim);
-               break;
-
-       case BFA_IOIM_SM_ABORT:
-               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
-               bfa_reqq_wcancel(&ioim->iosp->reqq_wait);
-               list_del(&ioim->qe);
-               list_add_tail(&ioim->qe, &ioim->fcpim->ioim_comp_q);
-               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_abort,
-                             ioim);
-               break;
-
-       case BFA_IOIM_SM_CLEANUP:
-               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
-               bfa_reqq_wcancel(&ioim->iosp->reqq_wait);
-               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_failed,
-                             ioim);
-               bfa_ioim_notify_cleanup(ioim);
-               break;
-
-       case BFA_IOIM_SM_HWFAIL:
-               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
-               bfa_reqq_wcancel(&ioim->iosp->reqq_wait);
-               list_del(&ioim->qe);
-               list_add_tail(&ioim->qe, &ioim->fcpim->ioim_comp_q);
-               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_failed,
-                             ioim);
-               break;
-
-       default:
-               bfa_sm_fault(ioim->bfa, event);
-       }
-}
-
-/**
- *             Active IO is being aborted, waiting for room in request CQ.
- */
-static void
-bfa_ioim_sm_abort_qfull(struct bfa_ioim_s *ioim, enum bfa_ioim_event event)
-{
-       bfa_trc(ioim->bfa, ioim->iotag);
-       bfa_trc(ioim->bfa, event);
-
-       switch (event) {
-       case BFA_IOIM_SM_QRESUME:
-               bfa_sm_set_state(ioim, bfa_ioim_sm_abort);
-               bfa_ioim_send_abort(ioim);
-               break;
-
-       case BFA_IOIM_SM_CLEANUP:
-               bfa_assert(ioim->iosp->abort_explicit == BFA_TRUE);
-               ioim->iosp->abort_explicit = BFA_FALSE;
-               bfa_sm_set_state(ioim, bfa_ioim_sm_cleanup_qfull);
-               break;
-
-       case BFA_IOIM_SM_COMP_GOOD:
-       case BFA_IOIM_SM_COMP:
-               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
-               bfa_reqq_wcancel(&ioim->iosp->reqq_wait);
-               list_del(&ioim->qe);
-               list_add_tail(&ioim->qe, &ioim->fcpim->ioim_comp_q);
-               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_abort,
-                             ioim);
-               break;
-
-       case BFA_IOIM_SM_DONE:
-               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb_free);
-               bfa_reqq_wcancel(&ioim->iosp->reqq_wait);
-               list_del(&ioim->qe);
-               list_add_tail(&ioim->qe, &ioim->fcpim->ioim_comp_q);
-               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_abort,
-                             ioim);
-               break;
-
-       case BFA_IOIM_SM_HWFAIL:
-               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
-               bfa_reqq_wcancel(&ioim->iosp->reqq_wait);
-               list_del(&ioim->qe);
-               list_add_tail(&ioim->qe, &ioim->fcpim->ioim_comp_q);
-               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_failed,
-                             ioim);
-               break;
-
-       default:
-               bfa_sm_fault(ioim->bfa, event);
-       }
-}
-
-/**
- *             Active IO is being cleaned up, waiting for room in request CQ.
- */
-static void
-bfa_ioim_sm_cleanup_qfull(struct bfa_ioim_s *ioim, enum bfa_ioim_event event)
-{
-       bfa_trc(ioim->bfa, ioim->iotag);
-       bfa_trc(ioim->bfa, event);
-
-       switch (event) {
-       case BFA_IOIM_SM_QRESUME:
-               bfa_sm_set_state(ioim, bfa_ioim_sm_cleanup);
-               bfa_ioim_send_abort(ioim);
-               break;
-
-       case BFA_IOIM_SM_ABORT:
-               /**
-                * IO is already being cleaned up implicitly
-                */
-               ioim->io_cbfn = __bfa_cb_ioim_abort;
-               break;
-
-       case BFA_IOIM_SM_COMP_GOOD:
-       case BFA_IOIM_SM_COMP:
-               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
-               bfa_reqq_wcancel(&ioim->iosp->reqq_wait);
-               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, ioim->io_cbfn, ioim);
-               bfa_ioim_notify_cleanup(ioim);
-               break;
-
-       case BFA_IOIM_SM_DONE:
-               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb_free);
-               bfa_reqq_wcancel(&ioim->iosp->reqq_wait);
-               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, ioim->io_cbfn, ioim);
-               bfa_ioim_notify_cleanup(ioim);
-               break;
-
-       case BFA_IOIM_SM_HWFAIL:
-               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
-               bfa_reqq_wcancel(&ioim->iosp->reqq_wait);
-               list_del(&ioim->qe);
-               list_add_tail(&ioim->qe, &ioim->fcpim->ioim_comp_q);
-               bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, __bfa_cb_ioim_failed,
-                             ioim);
-               break;
-
-       default:
-               bfa_sm_fault(ioim->bfa, event);
-       }
-}
-
-/**
- * IO bfa callback is pending.
- */
-static void
-bfa_ioim_sm_hcb(struct bfa_ioim_s *ioim, enum bfa_ioim_event event)
-{
-       bfa_trc_fp(ioim->bfa, ioim->iotag);
-       bfa_trc_fp(ioim->bfa, event);
-
-       switch (event) {
-       case BFA_IOIM_SM_HCB:
-               bfa_sm_set_state(ioim, bfa_ioim_sm_uninit);
-               bfa_ioim_free(ioim);
-               bfa_cb_ioim_resfree(ioim->bfa->bfad);
-               break;
-
-       case BFA_IOIM_SM_CLEANUP:
-               bfa_ioim_notify_cleanup(ioim);
-               break;
-
-       case BFA_IOIM_SM_HWFAIL:
-               break;
-
-       default:
-               bfa_sm_fault(ioim->bfa, event);
-       }
-}
-
-/**
- * IO bfa callback is pending. IO resource cannot be freed.
- */
-static void
-bfa_ioim_sm_hcb_free(struct bfa_ioim_s *ioim, enum bfa_ioim_event event)
-{
-       bfa_trc(ioim->bfa, ioim->iotag);
-       bfa_trc(ioim->bfa, event);
-
-       switch (event) {
-       case BFA_IOIM_SM_HCB:
-               bfa_sm_set_state(ioim, bfa_ioim_sm_resfree);
-               list_del(&ioim->qe);
-               list_add_tail(&ioim->qe, &ioim->fcpim->ioim_resfree_q);
-               break;
-
-       case BFA_IOIM_SM_FREE:
-               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
-               break;
-
-       case BFA_IOIM_SM_CLEANUP:
-               bfa_ioim_notify_cleanup(ioim);
-               break;
-
-       case BFA_IOIM_SM_HWFAIL:
-               bfa_sm_set_state(ioim, bfa_ioim_sm_hcb);
-               break;
-
-       default:
-               bfa_sm_fault(ioim->bfa, event);
-       }
-}
-
-/**
- * IO is completed, waiting resource free from firmware.
- */
-static void
-bfa_ioim_sm_resfree(struct bfa_ioim_s *ioim, enum bfa_ioim_event event)
-{
-       bfa_trc(ioim->bfa, ioim->iotag);
-       bfa_trc(ioim->bfa, event);
-
-       switch (event) {
-       case BFA_IOIM_SM_FREE:
-               bfa_sm_set_state(ioim, bfa_ioim_sm_uninit);
-               bfa_ioim_free(ioim);
-               bfa_cb_ioim_resfree(ioim->bfa->bfad);
-               break;
-
-       case BFA_IOIM_SM_CLEANUP:
-               bfa_ioim_notify_cleanup(ioim);
-               break;
-
-       case BFA_IOIM_SM_HWFAIL:
-               break;
-
-       default:
-               bfa_sm_fault(ioim->bfa, event);
-       }
-}
-
-
-
-/**
- *  bfa_ioim_private
- */
-
-static void
-__bfa_cb_ioim_good_comp(void *cbarg, bfa_boolean_t complete)
-{
-       struct bfa_ioim_s *ioim = cbarg;
-
-       if (!complete) {
-               bfa_sm_send_event(ioim, BFA_IOIM_SM_HCB);
-               return;
-       }
-
-       bfa_cb_ioim_good_comp(ioim->bfa->bfad, ioim->dio);
-}
-
-static void
-__bfa_cb_ioim_comp(void *cbarg, bfa_boolean_t complete)
-{
-       struct bfa_ioim_s       *ioim = cbarg;
-       struct bfi_ioim_rsp_s *m;
-       u8              *snsinfo = NULL;
-       u8         sns_len = 0;
-       s32         residue = 0;
-
-       if (!complete) {
-               bfa_sm_send_event(ioim, BFA_IOIM_SM_HCB);
-               return;
-       }
-
-       m = (struct bfi_ioim_rsp_s *) &ioim->iosp->comp_rspmsg;
-       if (m->io_status == BFI_IOIM_STS_OK) {
-               /**
-                * setup sense information, if present
-                */
-               if (m->scsi_status == SCSI_STATUS_CHECK_CONDITION
-                                       && m->sns_len) {
-                       sns_len = m->sns_len;
-                       snsinfo = ioim->iosp->snsinfo;
-               }
-
-               /**
-                * setup residue value correctly for normal completions
-                */
-               if (m->resid_flags == FCP_RESID_UNDER)
-                       residue = bfa_os_ntohl(m->residue);
-               if (m->resid_flags == FCP_RESID_OVER) {
-                       residue = bfa_os_ntohl(m->residue);
-                       residue = -residue;
-               }
-       }
-
-       bfa_cb_ioim_done(ioim->bfa->bfad, ioim->dio, m->io_status,
-                         m->scsi_status, sns_len, snsinfo, residue);
-}
-
-static void
-__bfa_cb_ioim_failed(void *cbarg, bfa_boolean_t complete)
-{
-       struct bfa_ioim_s *ioim = cbarg;
-
-       if (!complete) {
-               bfa_sm_send_event(ioim, BFA_IOIM_SM_HCB);
-               return;
-       }
-
-       bfa_cb_ioim_done(ioim->bfa->bfad, ioim->dio, BFI_IOIM_STS_ABORTED,
-                         0, 0, NULL, 0);
-}
-
-static void
-__bfa_cb_ioim_pathtov(void *cbarg, bfa_boolean_t complete)
-{
-       struct bfa_ioim_s *ioim = cbarg;
-
-       if (!complete) {
-               bfa_sm_send_event(ioim, BFA_IOIM_SM_HCB);
-               return;
-       }
-
-       bfa_cb_ioim_done(ioim->bfa->bfad, ioim->dio, BFI_IOIM_STS_PATHTOV,
-                         0, 0, NULL, 0);
-}
-
-static void
-__bfa_cb_ioim_abort(void *cbarg, bfa_boolean_t complete)
-{
-       struct bfa_ioim_s *ioim = cbarg;
-
-       if (!complete) {
-               bfa_sm_send_event(ioim, BFA_IOIM_SM_HCB);
-               return;
-       }
-
-       bfa_cb_ioim_abort(ioim->bfa->bfad, ioim->dio);
-}
-
-static void
-bfa_ioim_sgpg_alloced(void *cbarg)
-{
-       struct bfa_ioim_s *ioim = cbarg;
-
-       ioim->nsgpgs = BFA_SGPG_NPAGE(ioim->nsges);
-       list_splice_tail_init(&ioim->iosp->sgpg_wqe.sgpg_q, &ioim->sgpg_q);
-       bfa_ioim_sgpg_setup(ioim);
-       bfa_sm_send_event(ioim, BFA_IOIM_SM_SGALLOCED);
-}
-
-/**
- * Send I/O request to firmware.
- */
-static          bfa_boolean_t
-bfa_ioim_send_ioreq(struct bfa_ioim_s *ioim)
-{
-       struct bfa_itnim_s *itnim = ioim->itnim;
-       struct bfi_ioim_req_s *m;
-       static struct fcp_cmnd_s cmnd_z0 = { 0 };
-       struct bfi_sge_s      *sge;
-       u32        pgdlen = 0;
-       u64 addr;
-       struct scatterlist *sg;
-       struct scsi_cmnd *cmnd = (struct scsi_cmnd *) ioim->dio;
-
-       /**
-        * check for room in queue to send request now
-        */
-       m = bfa_reqq_next(ioim->bfa, ioim->reqq);
-       if (!m) {
-               bfa_reqq_wait(ioim->bfa, ioim->reqq,
-                                 &ioim->iosp->reqq_wait);
-               return BFA_FALSE;
-       }
-
-       /**
-        * build i/o request message next
-        */
-       m->io_tag = bfa_os_htons(ioim->iotag);
-       m->rport_hdl = ioim->itnim->rport->fw_handle;
-       m->io_timeout = bfa_cb_ioim_get_timeout(ioim->dio);
-
-       /**
-        * build inline IO SG element here
-        */
-       sge = &m->sges[0];
-       if (ioim->nsges) {
-               sg = (struct scatterlist *)scsi_sglist(cmnd);
-               addr = bfa_os_sgaddr(sg_dma_address(sg));
-               sge->sga = *(union bfi_addr_u *) &addr;
-               pgdlen = sg_dma_len(sg);
-               sge->sg_len = pgdlen;
-               sge->flags = (ioim->nsges > BFI_SGE_INLINE) ?
-                                       BFI_SGE_DATA_CPL : BFI_SGE_DATA_LAST;
-               bfa_sge_to_be(sge);
-               sge++;
-       }
-
-       if (ioim->nsges > BFI_SGE_INLINE) {
-               sge->sga = ioim->sgpg->sgpg_pa;
-       } else {
-               sge->sga.a32.addr_lo = 0;
-               sge->sga.a32.addr_hi = 0;
-       }
-       sge->sg_len = pgdlen;
-       sge->flags = BFI_SGE_PGDLEN;
-       bfa_sge_to_be(sge);
-
-       /**
-        * set up I/O command parameters
-        */
-       bfa_os_assign(m->cmnd, cmnd_z0);
-       m->cmnd.lun = bfa_cb_ioim_get_lun(ioim->dio);
-       m->cmnd.iodir = bfa_cb_ioim_get_iodir(ioim->dio);
-       bfa_os_assign(m->cmnd.cdb,
-                       *(struct scsi_cdb_s *)bfa_cb_ioim_get_cdb(ioim->dio));
-       m->cmnd.fcp_dl = bfa_os_htonl(bfa_cb_ioim_get_size(ioim->dio));
-
-       /**
-        * set up I/O message header
-        */
-       switch (m->cmnd.iodir) {
-       case FCP_IODIR_READ:
-               bfi_h2i_set(m->mh, BFI_MC_IOIM_READ, 0, bfa_lpuid(ioim->bfa));
-               bfa_stats(itnim, input_reqs);
-               break;
-       case FCP_IODIR_WRITE:
-               bfi_h2i_set(m->mh, BFI_MC_IOIM_WRITE, 0, bfa_lpuid(ioim->bfa));
-               bfa_stats(itnim, output_reqs);
-               break;
-       case FCP_IODIR_RW:
-               bfa_stats(itnim, input_reqs);
-               bfa_stats(itnim, output_reqs);
-       default:
-               bfi_h2i_set(m->mh, BFI_MC_IOIM_IO, 0, bfa_lpuid(ioim->bfa));
-       }
-       if (itnim->seq_rec ||
-           (bfa_cb_ioim_get_size(ioim->dio) & (sizeof(u32) - 1)))
-               bfi_h2i_set(m->mh, BFI_MC_IOIM_IO, 0, bfa_lpuid(ioim->bfa));
-
-#ifdef IOIM_ADVANCED
-       m->cmnd.crn = bfa_cb_ioim_get_crn(ioim->dio);
-       m->cmnd.priority = bfa_cb_ioim_get_priority(ioim->dio);
-       m->cmnd.taskattr = bfa_cb_ioim_get_taskattr(ioim->dio);
-
-       /**
-        * Handle large CDB (>16 bytes).
-        */
-       m->cmnd.addl_cdb_len = (bfa_cb_ioim_get_cdblen(ioim->dio) -
-                                       FCP_CMND_CDB_LEN) / sizeof(u32);
-       if (m->cmnd.addl_cdb_len) {
-               bfa_os_memcpy(&m->cmnd.cdb + 1, (struct scsi_cdb_s *)
-                               bfa_cb_ioim_get_cdb(ioim->dio) + 1,
-                               m->cmnd.addl_cdb_len * sizeof(u32));
-               fcp_cmnd_fcpdl(&m->cmnd) =
-                               bfa_os_htonl(bfa_cb_ioim_get_size(ioim->dio));
-       }
-#endif
-
-       /**
-        * queue I/O message to firmware
-        */
-       bfa_reqq_produce(ioim->bfa, ioim->reqq);
-       return BFA_TRUE;
-}
-
-/**
- * Setup any additional SG pages needed.Inline SG element is setup
- * at queuing time.
- */
-static bfa_boolean_t
-bfa_ioim_sge_setup(struct bfa_ioim_s *ioim)
-{
-       u16        nsgpgs;
-
-       bfa_assert(ioim->nsges > BFI_SGE_INLINE);
-
-       /**
-        * allocate SG pages needed
-        */
-       nsgpgs = BFA_SGPG_NPAGE(ioim->nsges);
-       if (!nsgpgs)
-               return BFA_TRUE;
-
-       if (bfa_sgpg_malloc(ioim->bfa, &ioim->sgpg_q, nsgpgs)
-           != BFA_STATUS_OK) {
-               bfa_sgpg_wait(ioim->bfa, &ioim->iosp->sgpg_wqe, nsgpgs);
-               return BFA_FALSE;
-       }
-
-       ioim->nsgpgs = nsgpgs;
-       bfa_ioim_sgpg_setup(ioim);
-
-       return BFA_TRUE;
-}
-
-static void
-bfa_ioim_sgpg_setup(struct bfa_ioim_s *ioim)
-{
-       int             sgeid, nsges, i;
-       struct bfi_sge_s      *sge;
-       struct bfa_sgpg_s *sgpg;
-       u32        pgcumsz;
-       u64        addr;
-       struct scatterlist *sg;
-       struct scsi_cmnd *cmnd = (struct scsi_cmnd *) ioim->dio;
-
-       sgeid = BFI_SGE_INLINE;
-       ioim->sgpg = sgpg = bfa_q_first(&ioim->sgpg_q);
-
-       sg = scsi_sglist(cmnd);
-       sg = sg_next(sg);
-
-       do {
-               sge = sgpg->sgpg->sges;
-               nsges = ioim->nsges - sgeid;
-               if (nsges > BFI_SGPG_DATA_SGES)
-                       nsges = BFI_SGPG_DATA_SGES;
-
-               pgcumsz = 0;
-               for (i = 0; i < nsges; i++, sge++, sgeid++, sg = sg_next(sg)) {
-                       addr = bfa_os_sgaddr(sg_dma_address(sg));
-                       sge->sga = *(union bfi_addr_u *) &addr;
-                       sge->sg_len = sg_dma_len(sg);
-                       pgcumsz += sge->sg_len;
-
-                       /**
-                        * set flags
-                        */
-                       if (i < (nsges - 1))
-                               sge->flags = BFI_SGE_DATA;
-                       else if (sgeid < (ioim->nsges - 1))
-                               sge->flags = BFI_SGE_DATA_CPL;
-                       else
-                               sge->flags = BFI_SGE_DATA_LAST;
-               }
-
-               sgpg = (struct bfa_sgpg_s *) bfa_q_next(sgpg);
-
-               /**
-                * set the link element of each page
-                */
-               if (sgeid == ioim->nsges) {
-                       sge->flags = BFI_SGE_PGDLEN;
-                       sge->sga.a32.addr_lo = 0;
-                       sge->sga.a32.addr_hi = 0;
-               } else {
-                       sge->flags = BFI_SGE_LINK;
-                       sge->sga = sgpg->sgpg_pa;
-               }
-               sge->sg_len = pgcumsz;
-       } while (sgeid < ioim->nsges);
-}
-
-/**
- * Send I/O abort request to firmware.
- */
-static          bfa_boolean_t
-bfa_ioim_send_abort(struct bfa_ioim_s *ioim)
-{
-       struct bfi_ioim_abort_req_s *m;
-       enum bfi_ioim_h2i       msgop;
-
-       /**
-        * check for room in queue to send request now
-        */
-       m = bfa_reqq_next(ioim->bfa, ioim->reqq);
-       if (!m)
-               return BFA_FALSE;
-
-       /**
-        * build i/o request message next
-        */
-       if (ioim->iosp->abort_explicit)
-               msgop = BFI_IOIM_H2I_IOABORT_REQ;
-       else
-               msgop = BFI_IOIM_H2I_IOCLEANUP_REQ;
-
-       bfi_h2i_set(m->mh, BFI_MC_IOIM, msgop, bfa_lpuid(ioim->bfa));
-       m->io_tag    = bfa_os_htons(ioim->iotag);
-       m->abort_tag = ++ioim->abort_tag;
-
-       /**
-        * queue I/O message to firmware
-        */
-       bfa_reqq_produce(ioim->bfa, ioim->reqq);
-       return BFA_TRUE;
-}
-
-/**
- * Call to resume any I/O requests waiting for room in request queue.
- */
-static void
-bfa_ioim_qresume(void *cbarg)
-{
-       struct bfa_ioim_s *ioim = cbarg;
-
-       bfa_fcpim_stats(ioim->fcpim, qresumes);
-       bfa_sm_send_event(ioim, BFA_IOIM_SM_QRESUME);
-}
-
-
-static void
-bfa_ioim_notify_cleanup(struct bfa_ioim_s *ioim)
-{
-       /**
-        * Move IO from itnim queue to fcpim global queue since itnim will be
-        * freed.
-        */
-       list_del(&ioim->qe);
-       list_add_tail(&ioim->qe, &ioim->fcpim->ioim_comp_q);
-
-       if (!ioim->iosp->tskim) {
-               if (ioim->fcpim->delay_comp && ioim->itnim->iotov_active) {
-                       bfa_cb_dequeue(&ioim->hcb_qe);
-                       list_del(&ioim->qe);
-                       list_add_tail(&ioim->qe, &ioim->itnim->delay_comp_q);
-               }
-               bfa_itnim_iodone(ioim->itnim);
-       } else
-               bfa_tskim_iodone(ioim->iosp->tskim);
-}
-
-/**
- *               or after the link comes back.
- */
-void
-bfa_ioim_delayed_comp(struct bfa_ioim_s *ioim, bfa_boolean_t iotov)
-{
-       /**
-        * If path tov timer expired, failback with PATHTOV status - these
-        * IO requests are not normally retried by IO stack.
-        *
-        * Otherwise device cameback online and fail it with normal failed
-        * status so that IO stack retries these failed IO requests.
-        */
-       if (iotov)
-               ioim->io_cbfn = __bfa_cb_ioim_pathtov;
-       else
-               ioim->io_cbfn = __bfa_cb_ioim_failed;
-
-       bfa_cb_queue(ioim->bfa, &ioim->hcb_qe, ioim->io_cbfn, ioim);
-
-    /**
-     * Move IO to fcpim global queue since itnim will be
-     * freed.
-     */
-    list_del(&ioim->qe);
-    list_add_tail(&ioim->qe, &ioim->fcpim->ioim_comp_q);
-}
-
-
-
-/**
- *  bfa_ioim_friend
- */
-
-/**
- * Memory allocation and initialization.
- */
-void
-bfa_ioim_attach(struct bfa_fcpim_mod_s *fcpim, struct bfa_meminfo_s *minfo)
-{
-       struct bfa_ioim_s               *ioim;
-       struct bfa_ioim_sp_s    *iosp;
-       u16             i;
-       u8                      *snsinfo;
-       u32             snsbufsz;
-
-       /**
-        * claim memory first
-        */
-       ioim = (struct bfa_ioim_s *) bfa_meminfo_kva(minfo);
-       fcpim->ioim_arr = ioim;
-       bfa_meminfo_kva(minfo) = (u8 *) (ioim + fcpim->num_ioim_reqs);
-
-       iosp = (struct bfa_ioim_sp_s *) bfa_meminfo_kva(minfo);
-       fcpim->ioim_sp_arr = iosp;
-       bfa_meminfo_kva(minfo) = (u8 *) (iosp + fcpim->num_ioim_reqs);
-
-       /**
-        * Claim DMA memory for per IO sense data.
-        */
-       snsbufsz = fcpim->num_ioim_reqs * BFI_IOIM_SNSLEN;
-       fcpim->snsbase.pa  = bfa_meminfo_dma_phys(minfo);
-       bfa_meminfo_dma_phys(minfo) += snsbufsz;
-
-       fcpim->snsbase.kva = bfa_meminfo_dma_virt(minfo);
-       bfa_meminfo_dma_virt(minfo) += snsbufsz;
-       snsinfo = fcpim->snsbase.kva;
-       bfa_iocfc_set_snsbase(fcpim->bfa, fcpim->snsbase.pa);
-
-       /**
-        * Initialize ioim free queues
-        */
-       INIT_LIST_HEAD(&fcpim->ioim_free_q);
-       INIT_LIST_HEAD(&fcpim->ioim_resfree_q);
-       INIT_LIST_HEAD(&fcpim->ioim_comp_q);
-
-       for (i = 0; i < fcpim->num_ioim_reqs;
-            i++, ioim++, iosp++, snsinfo += BFI_IOIM_SNSLEN) {
-               /*
-                * initialize IOIM
-                */
-               bfa_os_memset(ioim, 0, sizeof(struct bfa_ioim_s));
-               ioim->iotag   = i;
-               ioim->bfa     = fcpim->bfa;
-               ioim->fcpim   = fcpim;
-               ioim->iosp    = iosp;
-               iosp->snsinfo = snsinfo;
-               INIT_LIST_HEAD(&ioim->sgpg_q);
-               bfa_reqq_winit(&ioim->iosp->reqq_wait,
-                                  bfa_ioim_qresume, ioim);
-               bfa_sgpg_winit(&ioim->iosp->sgpg_wqe,
-                                  bfa_ioim_sgpg_alloced, ioim);
-               bfa_sm_set_state(ioim, bfa_ioim_sm_uninit);
-
-               list_add_tail(&ioim->qe, &fcpim->ioim_free_q);
-       }
-}
-
-/**
- * Driver detach time call.
- */
-void
-bfa_ioim_detach(struct bfa_fcpim_mod_s *fcpim)
-{
-}
-
-void
-bfa_ioim_isr(struct bfa_s *bfa, struct bfi_msg_s *m)
-{
-       struct bfa_fcpim_mod_s *fcpim = BFA_FCPIM_MOD(bfa);
-       struct bfi_ioim_rsp_s *rsp = (struct bfi_ioim_rsp_s *) m;
-       struct bfa_ioim_s *ioim;
-       u16        iotag;
-       enum bfa_ioim_event evt = BFA_IOIM_SM_COMP;
-
-       iotag = bfa_os_ntohs(rsp->io_tag);
-
-       ioim = BFA_IOIM_FROM_TAG(fcpim, iotag);
-       bfa_assert(ioim->iotag == iotag);
-
-       bfa_trc(ioim->bfa, ioim->iotag);
-       bfa_trc(ioim->bfa, rsp->io_status);
-       bfa_trc(ioim->bfa, rsp->reuse_io_tag);
-
-       if (bfa_sm_cmp_state(ioim, bfa_ioim_sm_active))
-               bfa_os_assign(ioim->iosp->comp_rspmsg, *m);
-
-       switch (rsp->io_status) {
-       case BFI_IOIM_STS_OK:
-               bfa_fcpim_stats(fcpim, iocomp_ok);
-               if (rsp->reuse_io_tag == 0)
-                       evt = BFA_IOIM_SM_DONE;
-               else
-                       evt = BFA_IOIM_SM_COMP;
-               break;
-
-       case BFI_IOIM_STS_TIMEDOUT:
-       case BFI_IOIM_STS_ABORTED:
-               rsp->io_status = BFI_IOIM_STS_ABORTED;
-               bfa_fcpim_stats(fcpim, iocomp_aborted);
-               if (rsp->reuse_io_tag == 0)
-                       evt = BFA_IOIM_SM_DONE;
-               else
-                       evt = BFA_IOIM_SM_COMP;
-               break;
-
-       case BFI_IOIM_STS_PROTO_ERR:
-               bfa_fcpim_stats(fcpim, iocom_proto_err);
-               bfa_assert(rsp->reuse_io_tag);
-               evt = BFA_IOIM_SM_COMP;
-               break;
-
-       case BFI_IOIM_STS_SQER_NEEDED:
-               bfa_fcpim_stats(fcpim, iocom_sqer_needed);
-               bfa_assert(rsp->reuse_io_tag == 0);
-               evt = BFA_IOIM_SM_SQRETRY;
-               break;
-
-       case BFI_IOIM_STS_RES_FREE:
-               bfa_fcpim_stats(fcpim, iocom_res_free);
-               evt = BFA_IOIM_SM_FREE;
-               break;
-
-       case BFI_IOIM_STS_HOST_ABORTED:
-               bfa_fcpim_stats(fcpim, iocom_hostabrts);
-               if (rsp->abort_tag != ioim->abort_tag) {
-                       bfa_trc(ioim->bfa, rsp->abort_tag);
-                       bfa_trc(ioim->bfa, ioim->abort_tag);
-                       return;
-               }
-
-               if (rsp->reuse_io_tag)
-                       evt = BFA_IOIM_SM_ABORT_COMP;
-               else
-                       evt = BFA_IOIM_SM_ABORT_DONE;
-               break;
-
-       case BFI_IOIM_STS_UTAG:
-               bfa_fcpim_stats(fcpim, iocom_utags);
-               evt = BFA_IOIM_SM_COMP_UTAG;
-               break;
-
-       default:
-               bfa_assert(0);
-       }
-
-       bfa_sm_send_event(ioim, evt);
-}
-
-void
-bfa_ioim_good_comp_isr(struct bfa_s *bfa, struct bfi_msg_s *m)
-{
-       struct bfa_fcpim_mod_s *fcpim = BFA_FCPIM_MOD(bfa);
-       struct bfi_ioim_rsp_s *rsp = (struct bfi_ioim_rsp_s *) m;
-       struct bfa_ioim_s *ioim;
-       u16        iotag;
-
-       iotag = bfa_os_ntohs(rsp->io_tag);
-
-       ioim = BFA_IOIM_FROM_TAG(fcpim, iotag);
-       bfa_assert(ioim->iotag == iotag);
-
-       bfa_trc_fp(ioim->bfa, ioim->iotag);
-       bfa_sm_send_event(ioim, BFA_IOIM_SM_COMP_GOOD);
-}
-
-/**
- * Called by itnim to clean up IO while going offline.
- */
-void
-bfa_ioim_cleanup(struct bfa_ioim_s *ioim)
-{
-       bfa_trc(ioim->bfa, ioim->iotag);
-       bfa_fcpim_stats(ioim->fcpim, io_cleanups);
-
-       ioim->iosp->tskim = NULL;
-       bfa_sm_send_event(ioim, BFA_IOIM_SM_CLEANUP);
-}
-
-void
-bfa_ioim_cleanup_tm(struct bfa_ioim_s *ioim, struct bfa_tskim_s *tskim)
-{
-       bfa_trc(ioim->bfa, ioim->iotag);
-       bfa_fcpim_stats(ioim->fcpim, io_tmaborts);
-
-       ioim->iosp->tskim = tskim;
-       bfa_sm_send_event(ioim, BFA_IOIM_SM_CLEANUP);
-}
-
-/**
- * IOC failure handling.
- */
-void
-bfa_ioim_iocdisable(struct bfa_ioim_s *ioim)
-{
-       bfa_sm_send_event(ioim, BFA_IOIM_SM_HWFAIL);
-}
-
-/**
- * IO offline TOV popped. Fail the pending IO.
- */
-void
-bfa_ioim_tov(struct bfa_ioim_s *ioim)
-{
-       bfa_sm_send_event(ioim, BFA_IOIM_SM_IOTOV);
-}
-
-
-
-/**
- *  bfa_ioim_api
- */
-
-/**
- * Allocate IOIM resource for initiator mode I/O request.
- */
-struct bfa_ioim_s *
-bfa_ioim_alloc(struct bfa_s *bfa, struct bfad_ioim_s *dio,
-               struct bfa_itnim_s *itnim, u16 nsges)
-{
-       struct bfa_fcpim_mod_s *fcpim = BFA_FCPIM_MOD(bfa);
-       struct bfa_ioim_s *ioim;
-
-       /**
-        * alocate IOIM resource
-        */
-       bfa_q_deq(&fcpim->ioim_free_q, &ioim);
-       if (!ioim) {
-               bfa_fcpim_stats(fcpim, no_iotags);
-               return NULL;
-       }
-
-       ioim->dio = dio;
-       ioim->itnim = itnim;
-       ioim->nsges = nsges;
-       ioim->nsgpgs = 0;
-
-       bfa_stats(fcpim, total_ios);
-       bfa_stats(itnim, ios);
-       fcpim->ios_active++;
-
-       list_add_tail(&ioim->qe, &itnim->io_q);
-       bfa_trc_fp(ioim->bfa, ioim->iotag);
-
-       return ioim;
-}
-
-void
-bfa_ioim_free(struct bfa_ioim_s *ioim)
-{
-       struct bfa_fcpim_mod_s *fcpim = ioim->fcpim;
-
-       bfa_trc_fp(ioim->bfa, ioim->iotag);
-       bfa_assert_fp(bfa_sm_cmp_state(ioim, bfa_ioim_sm_uninit));
-
-       bfa_assert_fp(list_empty(&ioim->sgpg_q)
-                  || (ioim->nsges > BFI_SGE_INLINE));
-
-       if (ioim->nsgpgs > 0)
-               bfa_sgpg_mfree(ioim->bfa, &ioim->sgpg_q, ioim->nsgpgs);
-
-       bfa_stats(ioim->itnim, io_comps);
-       fcpim->ios_active--;
-
-       list_del(&ioim->qe);
-       list_add_tail(&ioim->qe, &fcpim->ioim_free_q);
-}
-
-void
-bfa_ioim_start(struct bfa_ioim_s *ioim)
-{
-       bfa_trc_fp(ioim->bfa, ioim->iotag);
-
-       /**
-        * Obtain the queue over which this request has to be issued
-        */
-       ioim->reqq = bfa_fcpim_ioredirect_enabled(ioim->bfa) ?
-                       bfa_cb_ioim_get_reqq(ioim->dio) :
-                       bfa_itnim_get_reqq(ioim);
-
-       bfa_sm_send_event(ioim, BFA_IOIM_SM_START);
-}
-
-/**
- * Driver I/O abort request.
- */
-void
-bfa_ioim_abort(struct bfa_ioim_s *ioim)
-{
-       bfa_trc(ioim->bfa, ioim->iotag);
-       bfa_fcpim_stats(ioim->fcpim, io_aborts);
-       bfa_sm_send_event(ioim, BFA_IOIM_SM_ABORT);
-}
-
-
diff --git a/drivers/scsi/bfa/bfa_itnim.c b/drivers/scsi/bfa/bfa_itnim.c
deleted file mode 100644 (file)
index a914ff2..0000000
+++ /dev/null
@@ -1,1088 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#include <bfa.h>
-#include <bfa_fcpim.h>
-#include "bfa_fcpim_priv.h"
-
-BFA_TRC_FILE(HAL, ITNIM);
-
-#define BFA_ITNIM_FROM_TAG(_fcpim, _tag)                               \
-       ((_fcpim)->itnim_arr + ((_tag) & ((_fcpim)->num_itnims - 1)))
-
-#define bfa_fcpim_additn(__itnim)                                      \
-       list_add_tail(&(__itnim)->qe, &(__itnim)->fcpim->itnim_q)
-#define bfa_fcpim_delitn(__itnim)      do {                            \
-       bfa_assert(bfa_q_is_on_q(&(__itnim)->fcpim->itnim_q, __itnim));      \
-       list_del(&(__itnim)->qe);      \
-       bfa_assert(list_empty(&(__itnim)->io_q));      \
-       bfa_assert(list_empty(&(__itnim)->io_cleanup_q));      \
-       bfa_assert(list_empty(&(__itnim)->pending_q));      \
-} while (0)
-
-#define bfa_itnim_online_cb(__itnim) do {                              \
-       if ((__itnim)->bfa->fcs)                                        \
-               bfa_cb_itnim_online((__itnim)->ditn);      \
-       else {                                                          \
-               bfa_cb_queue((__itnim)->bfa, &(__itnim)->hcb_qe,        \
-               __bfa_cb_itnim_online, (__itnim));      \
-       }                                                               \
-} while (0)
-
-#define bfa_itnim_offline_cb(__itnim) do {                             \
-       if ((__itnim)->bfa->fcs)                                        \
-               bfa_cb_itnim_offline((__itnim)->ditn);      \
-       else {                                                          \
-               bfa_cb_queue((__itnim)->bfa, &(__itnim)->hcb_qe,        \
-               __bfa_cb_itnim_offline, (__itnim));      \
-       }                                                               \
-} while (0)
-
-#define bfa_itnim_sler_cb(__itnim) do {                                        \
-       if ((__itnim)->bfa->fcs)                                        \
-               bfa_cb_itnim_sler((__itnim)->ditn);      \
-       else {                                                          \
-               bfa_cb_queue((__itnim)->bfa, &(__itnim)->hcb_qe,        \
-               __bfa_cb_itnim_sler, (__itnim));      \
-       }                                                               \
-} while (0)
-
-/*
- * forward declarations
- */
-static void     bfa_itnim_iocdisable_cleanup(struct bfa_itnim_s *itnim);
-static bfa_boolean_t bfa_itnim_send_fwcreate(struct bfa_itnim_s *itnim);
-static bfa_boolean_t bfa_itnim_send_fwdelete(struct bfa_itnim_s *itnim);
-static void     bfa_itnim_cleanp_comp(void *itnim_cbarg);
-static void     bfa_itnim_cleanup(struct bfa_itnim_s *itnim);
-static void     __bfa_cb_itnim_online(void *cbarg, bfa_boolean_t complete);
-static void     __bfa_cb_itnim_offline(void *cbarg, bfa_boolean_t complete);
-static void     __bfa_cb_itnim_sler(void *cbarg, bfa_boolean_t complete);
-static void     bfa_itnim_iotov_online(struct bfa_itnim_s *itnim);
-static void     bfa_itnim_iotov_cleanup(struct bfa_itnim_s *itnim);
-static void     bfa_itnim_iotov(void *itnim_arg);
-static void     bfa_itnim_iotov_start(struct bfa_itnim_s *itnim);
-static void     bfa_itnim_iotov_stop(struct bfa_itnim_s *itnim);
-static void     bfa_itnim_iotov_delete(struct bfa_itnim_s *itnim);
-
-/**
- *  bfa_itnim_sm BFA itnim state machine
- */
-
-
-enum bfa_itnim_event {
-       BFA_ITNIM_SM_CREATE = 1,        /*  itnim is created */
-       BFA_ITNIM_SM_ONLINE = 2,        /*  itnim is online */
-       BFA_ITNIM_SM_OFFLINE = 3,       /*  itnim is offline */
-       BFA_ITNIM_SM_FWRSP = 4,         /*  firmware response */
-       BFA_ITNIM_SM_DELETE = 5,        /*  deleting an existing itnim */
-       BFA_ITNIM_SM_CLEANUP = 6,       /*  IO cleanup completion */
-       BFA_ITNIM_SM_SLER = 7,          /*  second level error recovery */
-       BFA_ITNIM_SM_HWFAIL = 8,        /*  IOC h/w failure event */
-       BFA_ITNIM_SM_QRESUME = 9,       /*  queue space available */
-};
-
-static void     bfa_itnim_sm_uninit(struct bfa_itnim_s *itnim,
-                                       enum bfa_itnim_event event);
-static void     bfa_itnim_sm_created(struct bfa_itnim_s *itnim,
-                                        enum bfa_itnim_event event);
-static void     bfa_itnim_sm_fwcreate(struct bfa_itnim_s *itnim,
-                                         enum bfa_itnim_event event);
-static void    bfa_itnim_sm_delete_pending(struct bfa_itnim_s *itnim,
-                               enum bfa_itnim_event event);
-static void     bfa_itnim_sm_online(struct bfa_itnim_s *itnim,
-                                       enum bfa_itnim_event event);
-static void     bfa_itnim_sm_sler(struct bfa_itnim_s *itnim,
-                                     enum bfa_itnim_event event);
-static void     bfa_itnim_sm_cleanup_offline(struct bfa_itnim_s *itnim,
-                                                enum bfa_itnim_event event);
-static void     bfa_itnim_sm_cleanup_delete(struct bfa_itnim_s *itnim,
-                                               enum bfa_itnim_event event);
-static void     bfa_itnim_sm_fwdelete(struct bfa_itnim_s *itnim,
-                                         enum bfa_itnim_event event);
-static void     bfa_itnim_sm_offline(struct bfa_itnim_s *itnim,
-                                        enum bfa_itnim_event event);
-static void     bfa_itnim_sm_iocdisable(struct bfa_itnim_s *itnim,
-                                           enum bfa_itnim_event event);
-static void     bfa_itnim_sm_deleting(struct bfa_itnim_s *itnim,
-                                         enum bfa_itnim_event event);
-static void     bfa_itnim_sm_fwcreate_qfull(struct bfa_itnim_s *itnim,
-                                         enum bfa_itnim_event event);
-static void     bfa_itnim_sm_fwdelete_qfull(struct bfa_itnim_s *itnim,
-                                         enum bfa_itnim_event event);
-static void     bfa_itnim_sm_deleting_qfull(struct bfa_itnim_s *itnim,
-                                         enum bfa_itnim_event event);
-
-/**
- *             Beginning/unallocated state - no events expected.
- */
-static void
-bfa_itnim_sm_uninit(struct bfa_itnim_s *itnim, enum bfa_itnim_event event)
-{
-       bfa_trc(itnim->bfa, itnim->rport->rport_tag);
-       bfa_trc(itnim->bfa, event);
-
-       switch (event) {
-       case BFA_ITNIM_SM_CREATE:
-               bfa_sm_set_state(itnim, bfa_itnim_sm_created);
-               itnim->is_online = BFA_FALSE;
-               bfa_fcpim_additn(itnim);
-               break;
-
-       default:
-               bfa_sm_fault(itnim->bfa, event);
-       }
-}
-
-/**
- *             Beginning state, only online event expected.
- */
-static void
-bfa_itnim_sm_created(struct bfa_itnim_s *itnim, enum bfa_itnim_event event)
-{
-       bfa_trc(itnim->bfa, itnim->rport->rport_tag);
-       bfa_trc(itnim->bfa, event);
-
-       switch (event) {
-       case BFA_ITNIM_SM_ONLINE:
-               if (bfa_itnim_send_fwcreate(itnim))
-                       bfa_sm_set_state(itnim, bfa_itnim_sm_fwcreate);
-               else
-                       bfa_sm_set_state(itnim, bfa_itnim_sm_fwcreate_qfull);
-               break;
-
-       case BFA_ITNIM_SM_DELETE:
-               bfa_sm_set_state(itnim, bfa_itnim_sm_uninit);
-               bfa_fcpim_delitn(itnim);
-               break;
-
-       case BFA_ITNIM_SM_HWFAIL:
-               bfa_sm_set_state(itnim, bfa_itnim_sm_iocdisable);
-               break;
-
-       default:
-               bfa_sm_fault(itnim->bfa, event);
-       }
-}
-
-/**
- *             Waiting for itnim create response from firmware.
- */
-static void
-bfa_itnim_sm_fwcreate(struct bfa_itnim_s *itnim, enum bfa_itnim_event event)
-{
-       bfa_trc(itnim->bfa, itnim->rport->rport_tag);
-       bfa_trc(itnim->bfa, event);
-
-       switch (event) {
-       case BFA_ITNIM_SM_FWRSP:
-               bfa_sm_set_state(itnim, bfa_itnim_sm_online);
-               itnim->is_online = BFA_TRUE;
-               bfa_itnim_iotov_online(itnim);
-               bfa_itnim_online_cb(itnim);
-               break;
-
-       case BFA_ITNIM_SM_DELETE:
-               bfa_sm_set_state(itnim, bfa_itnim_sm_delete_pending);
-               break;
-
-       case BFA_ITNIM_SM_OFFLINE:
-               if (bfa_itnim_send_fwdelete(itnim))
-                       bfa_sm_set_state(itnim, bfa_itnim_sm_fwdelete);
-               else
-                       bfa_sm_set_state(itnim, bfa_itnim_sm_fwdelete_qfull);
-               break;
-
-       case BFA_ITNIM_SM_HWFAIL:
-               bfa_sm_set_state(itnim, bfa_itnim_sm_iocdisable);
-               break;
-
-       default:
-               bfa_sm_fault(itnim->bfa, event);
-       }
-}
-
-static void
-bfa_itnim_sm_fwcreate_qfull(struct bfa_itnim_s *itnim,
-                       enum bfa_itnim_event event)
-{
-       bfa_trc(itnim->bfa, itnim->rport->rport_tag);
-       bfa_trc(itnim->bfa, event);
-
-       switch (event) {
-       case BFA_ITNIM_SM_QRESUME:
-               bfa_sm_set_state(itnim, bfa_itnim_sm_fwcreate);
-               bfa_itnim_send_fwcreate(itnim);
-               break;
-
-       case BFA_ITNIM_SM_DELETE:
-               bfa_sm_set_state(itnim, bfa_itnim_sm_uninit);
-               bfa_reqq_wcancel(&itnim->reqq_wait);
-               bfa_fcpim_delitn(itnim);
-               break;
-
-       case BFA_ITNIM_SM_OFFLINE:
-               bfa_sm_set_state(itnim, bfa_itnim_sm_offline);
-               bfa_reqq_wcancel(&itnim->reqq_wait);
-               bfa_itnim_offline_cb(itnim);
-               break;
-
-       case BFA_ITNIM_SM_HWFAIL:
-               bfa_sm_set_state(itnim, bfa_itnim_sm_iocdisable);
-               bfa_reqq_wcancel(&itnim->reqq_wait);
-               break;
-
-       default:
-               bfa_sm_fault(itnim->bfa, event);
-       }
-}
-
-/**
- *     Waiting for itnim create response from firmware, a delete is pending.
- */
-static void
-bfa_itnim_sm_delete_pending(struct bfa_itnim_s *itnim,
-                               enum bfa_itnim_event event)
-{
-       bfa_trc(itnim->bfa, itnim->rport->rport_tag);
-       bfa_trc(itnim->bfa, event);
-
-       switch (event) {
-       case BFA_ITNIM_SM_FWRSP:
-               if (bfa_itnim_send_fwdelete(itnim))
-                       bfa_sm_set_state(itnim, bfa_itnim_sm_deleting);
-               else
-                       bfa_sm_set_state(itnim, bfa_itnim_sm_deleting_qfull);
-               break;
-
-       case BFA_ITNIM_SM_HWFAIL:
-               bfa_sm_set_state(itnim, bfa_itnim_sm_uninit);
-               bfa_fcpim_delitn(itnim);
-               break;
-
-       default:
-               bfa_sm_fault(itnim->bfa, event);
-       }
-}
-
-/**
- *             Online state - normal parking state.
- */
-static void
-bfa_itnim_sm_online(struct bfa_itnim_s *itnim, enum bfa_itnim_event event)
-{
-       bfa_trc(itnim->bfa, itnim->rport->rport_tag);
-       bfa_trc(itnim->bfa, event);
-
-       switch (event) {
-       case BFA_ITNIM_SM_OFFLINE:
-               bfa_sm_set_state(itnim, bfa_itnim_sm_cleanup_offline);
-               itnim->is_online = BFA_FALSE;
-               bfa_itnim_iotov_start(itnim);
-               bfa_itnim_cleanup(itnim);
-               break;
-
-       case BFA_ITNIM_SM_DELETE:
-               bfa_sm_set_state(itnim, bfa_itnim_sm_cleanup_delete);
-               itnim->is_online = BFA_FALSE;
-               bfa_itnim_cleanup(itnim);
-               break;
-
-       case BFA_ITNIM_SM_SLER:
-               bfa_sm_set_state(itnim, bfa_itnim_sm_sler);
-               itnim->is_online = BFA_FALSE;
-               bfa_itnim_iotov_start(itnim);
-               bfa_itnim_sler_cb(itnim);
-               break;
-
-       case BFA_ITNIM_SM_HWFAIL:
-               bfa_sm_set_state(itnim, bfa_itnim_sm_iocdisable);
-               itnim->is_online = BFA_FALSE;
-               bfa_itnim_iotov_start(itnim);
-               bfa_itnim_iocdisable_cleanup(itnim);
-               break;
-
-       default:
-               bfa_sm_fault(itnim->bfa, event);
-       }
-}
-
-/**
- *             Second level error recovery need.
- */
-static void
-bfa_itnim_sm_sler(struct bfa_itnim_s *itnim, enum bfa_itnim_event event)
-{
-       bfa_trc(itnim->bfa, itnim->rport->rport_tag);
-       bfa_trc(itnim->bfa, event);
-
-       switch (event) {
-       case BFA_ITNIM_SM_OFFLINE:
-               bfa_sm_set_state(itnim, bfa_itnim_sm_cleanup_offline);
-               bfa_itnim_cleanup(itnim);
-               break;
-
-       case BFA_ITNIM_SM_DELETE:
-               bfa_sm_set_state(itnim, bfa_itnim_sm_cleanup_delete);
-               bfa_itnim_cleanup(itnim);
-               bfa_itnim_iotov_delete(itnim);
-               break;
-
-       case BFA_ITNIM_SM_HWFAIL:
-               bfa_sm_set_state(itnim, bfa_itnim_sm_iocdisable);
-               bfa_itnim_iocdisable_cleanup(itnim);
-               break;
-
-       default:
-               bfa_sm_fault(itnim->bfa, event);
-       }
-}
-
-/**
- *             Going offline. Waiting for active IO cleanup.
- */
-static void
-bfa_itnim_sm_cleanup_offline(struct bfa_itnim_s *itnim,
-                                enum bfa_itnim_event event)
-{
-       bfa_trc(itnim->bfa, itnim->rport->rport_tag);
-       bfa_trc(itnim->bfa, event);
-
-       switch (event) {
-       case BFA_ITNIM_SM_CLEANUP:
-               if (bfa_itnim_send_fwdelete(itnim))
-                       bfa_sm_set_state(itnim, bfa_itnim_sm_fwdelete);
-               else
-                       bfa_sm_set_state(itnim, bfa_itnim_sm_fwdelete_qfull);
-               break;
-
-       case BFA_ITNIM_SM_DELETE:
-               bfa_sm_set_state(itnim, bfa_itnim_sm_cleanup_delete);
-               bfa_itnim_iotov_delete(itnim);
-               break;
-
-       case BFA_ITNIM_SM_HWFAIL:
-               bfa_sm_set_state(itnim, bfa_itnim_sm_iocdisable);
-               bfa_itnim_iocdisable_cleanup(itnim);
-               bfa_itnim_offline_cb(itnim);
-               break;
-
-       case BFA_ITNIM_SM_SLER:
-               break;
-
-       default:
-               bfa_sm_fault(itnim->bfa, event);
-       }
-}
-
-/**
- *             Deleting itnim. Waiting for active IO cleanup.
- */
-static void
-bfa_itnim_sm_cleanup_delete(struct bfa_itnim_s *itnim,
-                               enum bfa_itnim_event event)
-{
-       bfa_trc(itnim->bfa, itnim->rport->rport_tag);
-       bfa_trc(itnim->bfa, event);
-
-       switch (event) {
-       case BFA_ITNIM_SM_CLEANUP:
-               if (bfa_itnim_send_fwdelete(itnim))
-                       bfa_sm_set_state(itnim, bfa_itnim_sm_deleting);
-               else
-                       bfa_sm_set_state(itnim, bfa_itnim_sm_deleting_qfull);
-               break;
-
-       case BFA_ITNIM_SM_HWFAIL:
-               bfa_sm_set_state(itnim, bfa_itnim_sm_iocdisable);
-               bfa_itnim_iocdisable_cleanup(itnim);
-               break;
-
-       default:
-               bfa_sm_fault(itnim->bfa, event);
-       }
-}
-
-/**
- * Rport offline. Fimrware itnim is being deleted - awaiting f/w response.
- */
-static void
-bfa_itnim_sm_fwdelete(struct bfa_itnim_s *itnim, enum bfa_itnim_event event)
-{
-       bfa_trc(itnim->bfa, itnim->rport->rport_tag);
-       bfa_trc(itnim->bfa, event);
-
-       switch (event) {
-       case BFA_ITNIM_SM_FWRSP:
-               bfa_sm_set_state(itnim, bfa_itnim_sm_offline);
-               bfa_itnim_offline_cb(itnim);
-               break;
-
-       case BFA_ITNIM_SM_DELETE:
-               bfa_sm_set_state(itnim, bfa_itnim_sm_deleting);
-               break;
-
-       case BFA_ITNIM_SM_HWFAIL:
-               bfa_sm_set_state(itnim, bfa_itnim_sm_iocdisable);
-               bfa_itnim_offline_cb(itnim);
-               break;
-
-       default:
-               bfa_sm_fault(itnim->bfa, event);
-       }
-}
-
-static void
-bfa_itnim_sm_fwdelete_qfull(struct bfa_itnim_s *itnim,
-                       enum bfa_itnim_event event)
-{
-       bfa_trc(itnim->bfa, itnim->rport->rport_tag);
-       bfa_trc(itnim->bfa, event);
-
-       switch (event) {
-       case BFA_ITNIM_SM_QRESUME:
-               bfa_sm_set_state(itnim, bfa_itnim_sm_fwdelete);
-               bfa_itnim_send_fwdelete(itnim);
-               break;
-
-       case BFA_ITNIM_SM_DELETE:
-               bfa_sm_set_state(itnim, bfa_itnim_sm_deleting_qfull);
-               break;
-
-       case BFA_ITNIM_SM_HWFAIL:
-               bfa_sm_set_state(itnim, bfa_itnim_sm_iocdisable);
-               bfa_reqq_wcancel(&itnim->reqq_wait);
-               bfa_itnim_offline_cb(itnim);
-               break;
-
-       default:
-               bfa_sm_fault(itnim->bfa, event);
-       }
-}
-
-/**
- *             Offline state.
- */
-static void
-bfa_itnim_sm_offline(struct bfa_itnim_s *itnim, enum bfa_itnim_event event)
-{
-       bfa_trc(itnim->bfa, itnim->rport->rport_tag);
-       bfa_trc(itnim->bfa, event);
-
-       switch (event) {
-       case BFA_ITNIM_SM_DELETE:
-               bfa_sm_set_state(itnim, bfa_itnim_sm_uninit);
-               bfa_itnim_iotov_delete(itnim);
-               bfa_fcpim_delitn(itnim);
-               break;
-
-       case BFA_ITNIM_SM_ONLINE:
-               if (bfa_itnim_send_fwcreate(itnim))
-                       bfa_sm_set_state(itnim, bfa_itnim_sm_fwcreate);
-               else
-                       bfa_sm_set_state(itnim, bfa_itnim_sm_fwcreate_qfull);
-               break;
-
-       case BFA_ITNIM_SM_HWFAIL:
-               bfa_sm_set_state(itnim, bfa_itnim_sm_iocdisable);
-               break;
-
-       default:
-               bfa_sm_fault(itnim->bfa, event);
-       }
-}
-
-/**
- *             IOC h/w failed state.
- */
-static void
-bfa_itnim_sm_iocdisable(struct bfa_itnim_s *itnim,
-                           enum bfa_itnim_event event)
-{
-       bfa_trc(itnim->bfa, itnim->rport->rport_tag);
-       bfa_trc(itnim->bfa, event);
-
-       switch (event) {
-       case BFA_ITNIM_SM_DELETE:
-               bfa_sm_set_state(itnim, bfa_itnim_sm_uninit);
-               bfa_itnim_iotov_delete(itnim);
-               bfa_fcpim_delitn(itnim);
-               break;
-
-       case BFA_ITNIM_SM_OFFLINE:
-               bfa_itnim_offline_cb(itnim);
-               break;
-
-       case BFA_ITNIM_SM_ONLINE:
-               if (bfa_itnim_send_fwcreate(itnim))
-                       bfa_sm_set_state(itnim, bfa_itnim_sm_fwcreate);
-               else
-                       bfa_sm_set_state(itnim, bfa_itnim_sm_fwcreate_qfull);
-               break;
-
-       case BFA_ITNIM_SM_HWFAIL:
-               break;
-
-       default:
-               bfa_sm_fault(itnim->bfa, event);
-       }
-}
-
-/**
- *             Itnim is deleted, waiting for firmware response to delete.
- */
-static void
-bfa_itnim_sm_deleting(struct bfa_itnim_s *itnim, enum bfa_itnim_event event)
-{
-       bfa_trc(itnim->bfa, itnim->rport->rport_tag);
-       bfa_trc(itnim->bfa, event);
-
-       switch (event) {
-       case BFA_ITNIM_SM_FWRSP:
-       case BFA_ITNIM_SM_HWFAIL:
-               bfa_sm_set_state(itnim, bfa_itnim_sm_uninit);
-               bfa_fcpim_delitn(itnim);
-               break;
-
-       default:
-               bfa_sm_fault(itnim->bfa, event);
-       }
-}
-
-static void
-bfa_itnim_sm_deleting_qfull(struct bfa_itnim_s *itnim,
-                       enum bfa_itnim_event event)
-{
-       bfa_trc(itnim->bfa, itnim->rport->rport_tag);
-       bfa_trc(itnim->bfa, event);
-
-       switch (event) {
-       case BFA_ITNIM_SM_QRESUME:
-               bfa_sm_set_state(itnim, bfa_itnim_sm_deleting);
-               bfa_itnim_send_fwdelete(itnim);
-               break;
-
-       case BFA_ITNIM_SM_HWFAIL:
-               bfa_sm_set_state(itnim, bfa_itnim_sm_uninit);
-               bfa_reqq_wcancel(&itnim->reqq_wait);
-               bfa_fcpim_delitn(itnim);
-               break;
-
-       default:
-               bfa_sm_fault(itnim->bfa, event);
-       }
-}
-
-
-
-/**
- *  bfa_itnim_private
- */
-
-/**
- *             Initiate cleanup of all IOs on an IOC failure.
- */
-static void
-bfa_itnim_iocdisable_cleanup(struct bfa_itnim_s *itnim)
-{
-       struct bfa_tskim_s *tskim;
-       struct bfa_ioim_s *ioim;
-       struct list_head        *qe, *qen;
-
-       list_for_each_safe(qe, qen, &itnim->tsk_q) {
-               tskim = (struct bfa_tskim_s *) qe;
-               bfa_tskim_iocdisable(tskim);
-       }
-
-       list_for_each_safe(qe, qen, &itnim->io_q) {
-               ioim = (struct bfa_ioim_s *) qe;
-               bfa_ioim_iocdisable(ioim);
-       }
-
-       /**
-        * For IO request in pending queue, we pretend an early timeout.
-        */
-       list_for_each_safe(qe, qen, &itnim->pending_q) {
-               ioim = (struct bfa_ioim_s *) qe;
-               bfa_ioim_tov(ioim);
-       }
-
-       list_for_each_safe(qe, qen, &itnim->io_cleanup_q) {
-               ioim = (struct bfa_ioim_s *) qe;
-               bfa_ioim_iocdisable(ioim);
-       }
-}
-
-/**
- *             IO cleanup completion
- */
-static void
-bfa_itnim_cleanp_comp(void *itnim_cbarg)
-{
-       struct bfa_itnim_s *itnim = itnim_cbarg;
-
-       bfa_stats(itnim, cleanup_comps);
-       bfa_sm_send_event(itnim, BFA_ITNIM_SM_CLEANUP);
-}
-
-/**
- *             Initiate cleanup of all IOs.
- */
-static void
-bfa_itnim_cleanup(struct bfa_itnim_s *itnim)
-{
-       struct bfa_ioim_s  *ioim;
-       struct bfa_tskim_s *tskim;
-       struct list_head         *qe, *qen;
-
-       bfa_wc_init(&itnim->wc, bfa_itnim_cleanp_comp, itnim);
-
-       list_for_each_safe(qe, qen, &itnim->io_q) {
-               ioim = (struct bfa_ioim_s *) qe;
-
-               /**
-                * Move IO to a cleanup queue from active queue so that a later
-                * TM will not pickup this IO.
-                */
-               list_del(&ioim->qe);
-               list_add_tail(&ioim->qe, &itnim->io_cleanup_q);
-
-               bfa_wc_up(&itnim->wc);
-               bfa_ioim_cleanup(ioim);
-       }
-
-       list_for_each_safe(qe, qen, &itnim->tsk_q) {
-               tskim = (struct bfa_tskim_s *) qe;
-               bfa_wc_up(&itnim->wc);
-               bfa_tskim_cleanup(tskim);
-       }
-
-       bfa_wc_wait(&itnim->wc);
-}
-
-static void
-__bfa_cb_itnim_online(void *cbarg, bfa_boolean_t complete)
-{
-       struct bfa_itnim_s *itnim = cbarg;
-
-       if (complete)
-               bfa_cb_itnim_online(itnim->ditn);
-}
-
-static void
-__bfa_cb_itnim_offline(void *cbarg, bfa_boolean_t complete)
-{
-       struct bfa_itnim_s *itnim = cbarg;
-
-       if (complete)
-               bfa_cb_itnim_offline(itnim->ditn);
-}
-
-static void
-__bfa_cb_itnim_sler(void *cbarg, bfa_boolean_t complete)
-{
-       struct bfa_itnim_s *itnim = cbarg;
-
-       if (complete)
-               bfa_cb_itnim_sler(itnim->ditn);
-}
-
-/**
- * Call to resume any I/O requests waiting for room in request queue.
- */
-static void
-bfa_itnim_qresume(void *cbarg)
-{
-       struct bfa_itnim_s *itnim = cbarg;
-
-       bfa_sm_send_event(itnim, BFA_ITNIM_SM_QRESUME);
-}
-
-
-
-
-/**
- *  bfa_itnim_public
- */
-
-void
-bfa_itnim_iodone(struct bfa_itnim_s *itnim)
-{
-       bfa_wc_down(&itnim->wc);
-}
-
-void
-bfa_itnim_tskdone(struct bfa_itnim_s *itnim)
-{
-       bfa_wc_down(&itnim->wc);
-}
-
-void
-bfa_itnim_meminfo(struct bfa_iocfc_cfg_s *cfg, u32 *km_len,
-               u32 *dm_len)
-{
-       /**
-        * ITN memory
-        */
-       *km_len += cfg->fwcfg.num_rports * sizeof(struct bfa_itnim_s);
-}
-
-void
-bfa_itnim_attach(struct bfa_fcpim_mod_s *fcpim, struct bfa_meminfo_s *minfo)
-{
-       struct bfa_s      *bfa = fcpim->bfa;
-       struct bfa_itnim_s *itnim;
-       int             i;
-
-       INIT_LIST_HEAD(&fcpim->itnim_q);
-
-       itnim = (struct bfa_itnim_s *) bfa_meminfo_kva(minfo);
-       fcpim->itnim_arr = itnim;
-
-       for (i = 0; i < fcpim->num_itnims; i++, itnim++) {
-               bfa_os_memset(itnim, 0, sizeof(struct bfa_itnim_s));
-               itnim->bfa = bfa;
-               itnim->fcpim = fcpim;
-               itnim->reqq = BFA_REQQ_QOS_LO;
-               itnim->rport = BFA_RPORT_FROM_TAG(bfa, i);
-               itnim->iotov_active = BFA_FALSE;
-               bfa_reqq_winit(&itnim->reqq_wait, bfa_itnim_qresume, itnim);
-
-               INIT_LIST_HEAD(&itnim->io_q);
-               INIT_LIST_HEAD(&itnim->io_cleanup_q);
-               INIT_LIST_HEAD(&itnim->pending_q);
-               INIT_LIST_HEAD(&itnim->tsk_q);
-               INIT_LIST_HEAD(&itnim->delay_comp_q);
-               bfa_sm_set_state(itnim, bfa_itnim_sm_uninit);
-       }
-
-       bfa_meminfo_kva(minfo) = (u8 *) itnim;
-}
-
-void
-bfa_itnim_iocdisable(struct bfa_itnim_s *itnim)
-{
-       bfa_stats(itnim, ioc_disabled);
-       bfa_sm_send_event(itnim, BFA_ITNIM_SM_HWFAIL);
-}
-
-static bfa_boolean_t
-bfa_itnim_send_fwcreate(struct bfa_itnim_s *itnim)
-{
-       struct bfi_itnim_create_req_s *m;
-
-       itnim->msg_no++;
-
-       /**
-        * check for room in queue to send request now
-        */
-       m = bfa_reqq_next(itnim->bfa, itnim->reqq);
-       if (!m) {
-               bfa_reqq_wait(itnim->bfa, itnim->reqq, &itnim->reqq_wait);
-               return BFA_FALSE;
-       }
-
-       bfi_h2i_set(m->mh, BFI_MC_ITNIM, BFI_ITNIM_H2I_CREATE_REQ,
-                       bfa_lpuid(itnim->bfa));
-       m->fw_handle = itnim->rport->fw_handle;
-       m->class = FC_CLASS_3;
-       m->seq_rec = itnim->seq_rec;
-       m->msg_no = itnim->msg_no;
-
-       /**
-        * queue I/O message to firmware
-        */
-       bfa_reqq_produce(itnim->bfa, itnim->reqq);
-       return BFA_TRUE;
-}
-
-static bfa_boolean_t
-bfa_itnim_send_fwdelete(struct bfa_itnim_s *itnim)
-{
-       struct bfi_itnim_delete_req_s *m;
-
-       /**
-        * check for room in queue to send request now
-        */
-       m = bfa_reqq_next(itnim->bfa, itnim->reqq);
-       if (!m) {
-               bfa_reqq_wait(itnim->bfa, itnim->reqq, &itnim->reqq_wait);
-               return BFA_FALSE;
-       }
-
-       bfi_h2i_set(m->mh, BFI_MC_ITNIM, BFI_ITNIM_H2I_DELETE_REQ,
-                       bfa_lpuid(itnim->bfa));
-       m->fw_handle = itnim->rport->fw_handle;
-
-       /**
-        * queue I/O message to firmware
-        */
-       bfa_reqq_produce(itnim->bfa, itnim->reqq);
-       return BFA_TRUE;
-}
-
-/**
- * Cleanup all pending failed inflight requests.
- */
-static void
-bfa_itnim_delayed_comp(struct bfa_itnim_s *itnim, bfa_boolean_t iotov)
-{
-       struct bfa_ioim_s *ioim;
-       struct list_head *qe, *qen;
-
-       list_for_each_safe(qe, qen, &itnim->delay_comp_q) {
-               ioim = (struct bfa_ioim_s *)qe;
-               bfa_ioim_delayed_comp(ioim, iotov);
-       }
-}
-
-/**
- * Start all pending IO requests.
- */
-static void
-bfa_itnim_iotov_online(struct bfa_itnim_s *itnim)
-{
-       struct bfa_ioim_s *ioim;
-
-       bfa_itnim_iotov_stop(itnim);
-
-       /**
-        * Abort all inflight IO requests in the queue
-        */
-       bfa_itnim_delayed_comp(itnim, BFA_FALSE);
-
-       /**
-        * Start all pending IO requests.
-        */
-       while (!list_empty(&itnim->pending_q)) {
-               bfa_q_deq(&itnim->pending_q, &ioim);
-               list_add_tail(&ioim->qe, &itnim->io_q);
-               bfa_ioim_start(ioim);
-       }
-}
-
-/**
- * Fail all pending IO requests
- */
-static void
-bfa_itnim_iotov_cleanup(struct bfa_itnim_s *itnim)
-{
-       struct bfa_ioim_s *ioim;
-
-       /**
-        * Fail all inflight IO requests in the queue
-        */
-       bfa_itnim_delayed_comp(itnim, BFA_TRUE);
-
-       /**
-        * Fail any pending IO requests.
-        */
-       while (!list_empty(&itnim->pending_q)) {
-               bfa_q_deq(&itnim->pending_q, &ioim);
-               list_add_tail(&ioim->qe, &ioim->fcpim->ioim_comp_q);
-               bfa_ioim_tov(ioim);
-       }
-}
-
-/**
- * IO TOV timer callback. Fail any pending IO requests.
- */
-static void
-bfa_itnim_iotov(void *itnim_arg)
-{
-       struct bfa_itnim_s *itnim = itnim_arg;
-
-       itnim->iotov_active = BFA_FALSE;
-
-       bfa_cb_itnim_tov_begin(itnim->ditn);
-       bfa_itnim_iotov_cleanup(itnim);
-       bfa_cb_itnim_tov(itnim->ditn);
-}
-
-/**
- * Start IO TOV timer for failing back pending IO requests in offline state.
- */
-static void
-bfa_itnim_iotov_start(struct bfa_itnim_s *itnim)
-{
-       if (itnim->fcpim->path_tov > 0) {
-
-               itnim->iotov_active = BFA_TRUE;
-               bfa_assert(bfa_itnim_hold_io(itnim));
-               bfa_timer_start(itnim->bfa, &itnim->timer,
-                       bfa_itnim_iotov, itnim, itnim->fcpim->path_tov);
-       }
-}
-
-/**
- * Stop IO TOV timer.
- */
-static void
-bfa_itnim_iotov_stop(struct bfa_itnim_s *itnim)
-{
-       if (itnim->iotov_active) {
-               itnim->iotov_active = BFA_FALSE;
-               bfa_timer_stop(&itnim->timer);
-       }
-}
-
-/**
- * Stop IO TOV timer.
- */
-static void
-bfa_itnim_iotov_delete(struct bfa_itnim_s *itnim)
-{
-    bfa_boolean_t pathtov_active = BFA_FALSE;
-
-    if (itnim->iotov_active)
-               pathtov_active = BFA_TRUE;
-
-       bfa_itnim_iotov_stop(itnim);
-       if (pathtov_active)
-               bfa_cb_itnim_tov_begin(itnim->ditn);
-       bfa_itnim_iotov_cleanup(itnim);
-       if (pathtov_active)
-               bfa_cb_itnim_tov(itnim->ditn);
-}
-
-
-
-/**
- *  bfa_itnim_public
- */
-
-/**
- *             Itnim interrupt processing.
- */
-void
-bfa_itnim_isr(struct bfa_s *bfa, struct bfi_msg_s *m)
-{
-       struct bfa_fcpim_mod_s *fcpim = BFA_FCPIM_MOD(bfa);
-       union bfi_itnim_i2h_msg_u msg;
-       struct bfa_itnim_s *itnim;
-
-       bfa_trc(bfa, m->mhdr.msg_id);
-
-       msg.msg = m;
-
-       switch (m->mhdr.msg_id) {
-       case BFI_ITNIM_I2H_CREATE_RSP:
-               itnim = BFA_ITNIM_FROM_TAG(fcpim,
-                                              msg.create_rsp->bfa_handle);
-               bfa_assert(msg.create_rsp->status == BFA_STATUS_OK);
-               bfa_stats(itnim, create_comps);
-               bfa_sm_send_event(itnim, BFA_ITNIM_SM_FWRSP);
-               break;
-
-       case BFI_ITNIM_I2H_DELETE_RSP:
-               itnim = BFA_ITNIM_FROM_TAG(fcpim,
-                                              msg.delete_rsp->bfa_handle);
-               bfa_assert(msg.delete_rsp->status == BFA_STATUS_OK);
-               bfa_stats(itnim, delete_comps);
-               bfa_sm_send_event(itnim, BFA_ITNIM_SM_FWRSP);
-               break;
-
-       case BFI_ITNIM_I2H_SLER_EVENT:
-               itnim = BFA_ITNIM_FROM_TAG(fcpim,
-                                              msg.sler_event->bfa_handle);
-               bfa_stats(itnim, sler_events);
-               bfa_sm_send_event(itnim, BFA_ITNIM_SM_SLER);
-               break;
-
-       default:
-               bfa_trc(bfa, m->mhdr.msg_id);
-               bfa_assert(0);
-       }
-}
-
-
-
-/**
- *  bfa_itnim_api
- */
-
-struct bfa_itnim_s *
-bfa_itnim_create(struct bfa_s *bfa, struct bfa_rport_s *rport, void *ditn)
-{
-       struct bfa_fcpim_mod_s *fcpim = BFA_FCPIM_MOD(bfa);
-       struct bfa_itnim_s *itnim;
-
-       itnim = BFA_ITNIM_FROM_TAG(fcpim, rport->rport_tag);
-       bfa_assert(itnim->rport == rport);
-
-       itnim->ditn = ditn;
-
-       bfa_stats(itnim, creates);
-       bfa_sm_send_event(itnim, BFA_ITNIM_SM_CREATE);
-
-       return itnim;
-}
-
-void
-bfa_itnim_delete(struct bfa_itnim_s *itnim)
-{
-       bfa_stats(itnim, deletes);
-       bfa_sm_send_event(itnim, BFA_ITNIM_SM_DELETE);
-}
-
-void
-bfa_itnim_online(struct bfa_itnim_s *itnim, bfa_boolean_t seq_rec)
-{
-       itnim->seq_rec = seq_rec;
-       bfa_stats(itnim, onlines);
-       bfa_sm_send_event(itnim, BFA_ITNIM_SM_ONLINE);
-}
-
-void
-bfa_itnim_offline(struct bfa_itnim_s *itnim)
-{
-       bfa_stats(itnim, offlines);
-       bfa_sm_send_event(itnim, BFA_ITNIM_SM_OFFLINE);
-}
-
-/**
- * Return true if itnim is considered offline for holding off IO request.
- * IO is not held if itnim is being deleted.
- */
-bfa_boolean_t
-bfa_itnim_hold_io(struct bfa_itnim_s *itnim)
-{
-       return
-               itnim->fcpim->path_tov && itnim->iotov_active &&
-               (bfa_sm_cmp_state(itnim, bfa_itnim_sm_fwcreate) ||
-                bfa_sm_cmp_state(itnim, bfa_itnim_sm_sler) ||
-                bfa_sm_cmp_state(itnim, bfa_itnim_sm_cleanup_offline) ||
-                bfa_sm_cmp_state(itnim, bfa_itnim_sm_fwdelete) ||
-                bfa_sm_cmp_state(itnim, bfa_itnim_sm_offline) ||
-                bfa_sm_cmp_state(itnim, bfa_itnim_sm_iocdisable))
-       ;
-}
-
-void
-bfa_itnim_get_stats(struct bfa_itnim_s *itnim,
-       struct bfa_itnim_hal_stats_s *stats)
-{
-       *stats = itnim->stats;
-}
-
-void
-bfa_itnim_clear_stats(struct bfa_itnim_s *itnim)
-{
-       bfa_os_memset(&itnim->stats, 0, sizeof(itnim->stats));
-}
-
-
diff --git a/drivers/scsi/bfa/bfa_log.c b/drivers/scsi/bfa/bfa_log.c
deleted file mode 100644 (file)
index e751401..0000000
+++ /dev/null
@@ -1,346 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  bfa_log.c BFA log library
- */
-
-#include <bfa_os_inc.h>
-#include <cs/bfa_log.h>
-
-/*
- * global log info structure
- */
-struct bfa_log_info_s {
-       u32        start_idx;   /*  start index for a module */
-       u32        total_count; /*  total count for a module */
-       enum bfa_log_severity level;    /*  global log level */
-       bfa_log_cb_t    cbfn;           /*  callback function */
-};
-
-static struct bfa_log_info_s bfa_log_info[BFA_LOG_MODULE_ID_MAX + 1];
-static u32 bfa_log_msg_total_count;
-static int      bfa_log_initialized;
-
-static char    *bfa_log_severity[] =
-       { "[none]", "[critical]", "[error]", "[warn]", "[info]", "" };
-
-/**
- * BFA log library initialization
- *
- * The log library initialization includes the following,
- *    - set log instance name and callback function
- *    - read the message array generated from xml files
- *    - calculate start index for each module
- *    - calculate message count for each module
- *    - perform error checking
- *
- * @param[in] log_mod - log module info
- * @param[in] instance_name - instance name
- * @param[in] cbfn - callback function
- *
- * It return 0 on success, or -1 on failure
- */
-int
-bfa_log_init(struct bfa_log_mod_s *log_mod, char *instance_name,
-                       bfa_log_cb_t cbfn)
-{
-       struct bfa_log_msgdef_s *msg;
-       u32        pre_mod_id = 0;
-       u32        cur_mod_id = 0;
-       u32        i, pre_idx, idx, msg_id;
-
-       /*
-        * set instance name
-        */
-       if (log_mod) {
-               strncpy(log_mod->instance_info, instance_name,
-                       sizeof(log_mod->instance_info));
-               log_mod->cbfn = cbfn;
-               for (i = 0; i <= BFA_LOG_MODULE_ID_MAX; i++)
-                       log_mod->log_level[i] = BFA_LOG_WARNING;
-       }
-
-       if (bfa_log_initialized)
-               return 0;
-
-       for (i = 0; i <= BFA_LOG_MODULE_ID_MAX; i++) {
-               bfa_log_info[i].start_idx = 0;
-               bfa_log_info[i].total_count = 0;
-               bfa_log_info[i].level = BFA_LOG_WARNING;
-               bfa_log_info[i].cbfn = cbfn;
-       }
-
-       pre_idx = 0;
-       idx = 0;
-       msg = bfa_log_msg_array;
-       msg_id = BFA_LOG_GET_MSG_ID(msg);
-       pre_mod_id = BFA_LOG_GET_MOD_ID(msg_id);
-       while (msg_id != 0) {
-               cur_mod_id = BFA_LOG_GET_MOD_ID(msg_id);
-
-               if (cur_mod_id > BFA_LOG_MODULE_ID_MAX) {
-                       cbfn(log_mod, msg_id,
-                               "%s%s log: module id %u out of range\n",
-                               BFA_LOG_CAT_NAME,
-                               bfa_log_severity[BFA_LOG_ERROR],
-                               cur_mod_id);
-                       return -1;
-               }
-
-               if (pre_mod_id > BFA_LOG_MODULE_ID_MAX) {
-                       cbfn(log_mod, msg_id,
-                               "%s%s log: module id %u out of range\n",
-                               BFA_LOG_CAT_NAME,
-                               bfa_log_severity[BFA_LOG_ERROR],
-                               pre_mod_id);
-                       return -1;
-               }
-
-               if (cur_mod_id != pre_mod_id) {
-                       bfa_log_info[pre_mod_id].start_idx = pre_idx;
-                       bfa_log_info[pre_mod_id].total_count = idx - pre_idx;
-                       pre_mod_id = cur_mod_id;
-                       pre_idx = idx;
-               }
-
-               idx++;
-               msg++;
-               msg_id = BFA_LOG_GET_MSG_ID(msg);
-       }
-
-       bfa_log_info[cur_mod_id].start_idx = pre_idx;
-       bfa_log_info[cur_mod_id].total_count = idx - pre_idx;
-       bfa_log_msg_total_count = idx;
-
-       cbfn(log_mod, msg_id, "%s%s log: init OK, msg total count %u\n",
-               BFA_LOG_CAT_NAME,
-               bfa_log_severity[BFA_LOG_INFO], bfa_log_msg_total_count);
-
-       bfa_log_initialized = 1;
-
-       return 0;
-}
-
-/**
- * BFA log set log level for a module
- *
- * @param[in] log_mod - log module info
- * @param[in] mod_id - module id
- * @param[in] log_level - log severity level
- *
- * It return BFA_STATUS_OK on success, or > 0 on failure
- */
-bfa_status_t
-bfa_log_set_level(struct bfa_log_mod_s *log_mod, int mod_id,
-                 enum bfa_log_severity log_level)
-{
-       if (mod_id <= BFA_LOG_UNUSED_ID || mod_id > BFA_LOG_MODULE_ID_MAX)
-               return BFA_STATUS_EINVAL;
-
-       if (log_level <= BFA_LOG_INVALID || log_level > BFA_LOG_LEVEL_MAX)
-               return BFA_STATUS_EINVAL;
-
-       if (log_mod)
-               log_mod->log_level[mod_id] = log_level;
-       else
-               bfa_log_info[mod_id].level = log_level;
-
-       return BFA_STATUS_OK;
-}
-
-/**
- * BFA log set log level for all modules
- *
- * @param[in] log_mod - log module info
- * @param[in] log_level - log severity level
- *
- * It return BFA_STATUS_OK on success, or > 0 on failure
- */
-bfa_status_t
-bfa_log_set_level_all(struct bfa_log_mod_s *log_mod,
-                 enum bfa_log_severity log_level)
-{
-       int mod_id = BFA_LOG_UNUSED_ID + 1;
-
-       if (log_level <= BFA_LOG_INVALID || log_level > BFA_LOG_LEVEL_MAX)
-               return BFA_STATUS_EINVAL;
-
-       if (log_mod) {
-               for (; mod_id <= BFA_LOG_MODULE_ID_MAX; mod_id++)
-                       log_mod->log_level[mod_id] = log_level;
-       } else {
-               for (; mod_id <= BFA_LOG_MODULE_ID_MAX; mod_id++)
-                       bfa_log_info[mod_id].level = log_level;
-       }
-
-       return BFA_STATUS_OK;
-}
-
-/**
- * BFA log set log level for all aen sub-modules
- *
- * @param[in] log_mod - log module info
- * @param[in] log_level - log severity level
- *
- * It return BFA_STATUS_OK on success, or > 0 on failure
- */
-bfa_status_t
-bfa_log_set_level_aen(struct bfa_log_mod_s *log_mod,
-                 enum bfa_log_severity log_level)
-{
-       int mod_id = BFA_LOG_AEN_MIN + 1;
-
-       if (log_mod) {
-               for (; mod_id <= BFA_LOG_AEN_MAX; mod_id++)
-                       log_mod->log_level[mod_id] = log_level;
-       } else {
-               for (; mod_id <= BFA_LOG_AEN_MAX; mod_id++)
-                       bfa_log_info[mod_id].level = log_level;
-       }
-
-       return BFA_STATUS_OK;
-}
-
-/**
- * BFA log get log level for a module
- *
- * @param[in] log_mod - log module info
- * @param[in] mod_id - module id
- *
- * It returns log level or -1 on error
- */
-enum bfa_log_severity
-bfa_log_get_level(struct bfa_log_mod_s *log_mod, int mod_id)
-{
-       if (mod_id <= BFA_LOG_UNUSED_ID || mod_id > BFA_LOG_MODULE_ID_MAX)
-               return BFA_LOG_INVALID;
-
-       if (log_mod)
-               return log_mod->log_level[mod_id];
-       else
-               return bfa_log_info[mod_id].level;
-}
-
-enum bfa_log_severity
-bfa_log_get_msg_level(struct bfa_log_mod_s *log_mod, u32 msg_id)
-{
-       struct bfa_log_msgdef_s *msg;
-       u32        mod = BFA_LOG_GET_MOD_ID(msg_id);
-       u32        idx = BFA_LOG_GET_MSG_IDX(msg_id) - 1;
-
-       if (!bfa_log_initialized)
-               return BFA_LOG_INVALID;
-
-       if (mod > BFA_LOG_MODULE_ID_MAX)
-               return BFA_LOG_INVALID;
-
-       if (idx >= bfa_log_info[mod].total_count) {
-               bfa_log_info[mod].cbfn(log_mod, msg_id,
-                       "%s%s log: inconsistent idx %u vs. total count %u\n",
-                       BFA_LOG_CAT_NAME, bfa_log_severity[BFA_LOG_ERROR], idx,
-                       bfa_log_info[mod].total_count);
-               return BFA_LOG_INVALID;
-       }
-
-       msg = bfa_log_msg_array + bfa_log_info[mod].start_idx + idx;
-       if (msg_id != BFA_LOG_GET_MSG_ID(msg)) {
-               bfa_log_info[mod].cbfn(log_mod, msg_id,
-                       "%s%s log: inconsistent msg id %u array msg id %u\n",
-                       BFA_LOG_CAT_NAME, bfa_log_severity[BFA_LOG_ERROR],
-                       msg_id, BFA_LOG_GET_MSG_ID(msg));
-               return BFA_LOG_INVALID;
-       }
-
-       return BFA_LOG_GET_SEVERITY(msg);
-}
-
-/**
- * BFA log message handling
- *
- * BFA log message handling finds the message based on message id and prints
- * out the message based on its format and arguments. It also does prefix
- * the severity etc.
- *
- * @param[in] log_mod - log module info
- * @param[in] msg_id - message id
- * @param[in] ... - message arguments
- *
- * It return 0 on success, or -1 on errors
- */
-int
-bfa_log(struct bfa_log_mod_s *log_mod, u32 msg_id, ...)
-{
-       va_list         ap;
-       char            buf[256];
-       struct bfa_log_msgdef_s *msg;
-       int             log_level;
-       u32        mod = BFA_LOG_GET_MOD_ID(msg_id);
-       u32        idx = BFA_LOG_GET_MSG_IDX(msg_id) - 1;
-
-       if (!bfa_log_initialized)
-               return -1;
-
-       if (mod > BFA_LOG_MODULE_ID_MAX)
-               return -1;
-
-       if (idx >= bfa_log_info[mod].total_count) {
-               bfa_log_info[mod].
-                       cbfn
-                       (log_mod, msg_id,
-                       "%s%s log: inconsistent idx %u vs. total count %u\n",
-                       BFA_LOG_CAT_NAME, bfa_log_severity[BFA_LOG_ERROR], idx,
-                       bfa_log_info[mod].total_count);
-               return -1;
-       }
-
-       msg = bfa_log_msg_array + bfa_log_info[mod].start_idx + idx;
-       if (msg_id != BFA_LOG_GET_MSG_ID(msg)) {
-               bfa_log_info[mod].
-                       cbfn
-                       (log_mod, msg_id,
-                       "%s%s log: inconsistent msg id %u array msg id %u\n",
-                       BFA_LOG_CAT_NAME, bfa_log_severity[BFA_LOG_ERROR],
-                       msg_id, BFA_LOG_GET_MSG_ID(msg));
-               return -1;
-       }
-
-       log_level = log_mod ? log_mod->log_level[mod] : bfa_log_info[mod].level;
-       if ((BFA_LOG_GET_SEVERITY(msg) > log_level) &&
-                       (msg->attributes != BFA_LOG_ATTR_NONE))
-               return 0;
-
-       va_start(ap, msg_id);
-       bfa_os_vsprintf(buf, BFA_LOG_GET_MSG_FMT_STRING(msg), ap);
-       va_end(ap);
-
-       if (log_mod)
-               log_mod->cbfn(log_mod, msg_id, "%s[%s]%s%s %s: %s\n",
-                               BFA_LOG_CAT_NAME, log_mod->instance_info,
-                               bfa_log_severity[BFA_LOG_GET_SEVERITY(msg)],
-                               (msg->attributes & BFA_LOG_ATTR_AUDIT)
-                               ? " (audit) " : "", msg->msg_value, buf);
-       else
-               bfa_log_info[mod].cbfn(log_mod, msg_id, "%s%s%s %s: %s\n",
-                               BFA_LOG_CAT_NAME,
-                               bfa_log_severity[BFA_LOG_GET_SEVERITY(msg)],
-                               (msg->attributes & BFA_LOG_ATTR_AUDIT) ?
-                               " (audit) " : "", msg->msg_value, buf);
-
-       return 0;
-}
-
diff --git a/drivers/scsi/bfa/bfa_log_module.c b/drivers/scsi/bfa/bfa_log_module.c
deleted file mode 100644 (file)
index cf577ef..0000000
+++ /dev/null
@@ -1,537 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#include <cs/bfa_log.h>
-#include <aen/bfa_aen_adapter.h>
-#include <aen/bfa_aen_audit.h>
-#include <aen/bfa_aen_ethport.h>
-#include <aen/bfa_aen_ioc.h>
-#include <aen/bfa_aen_itnim.h>
-#include <aen/bfa_aen_lport.h>
-#include <aen/bfa_aen_port.h>
-#include <aen/bfa_aen_rport.h>
-#include <log/bfa_log_fcs.h>
-#include <log/bfa_log_hal.h>
-#include <log/bfa_log_linux.h>
-#include <log/bfa_log_wdrv.h>
-
-struct bfa_log_msgdef_s bfa_log_msg_array[] = {
-
-
-/* messages define for BFA_AEN_CAT_ADAPTER Module */
-{BFA_AEN_ADAPTER_ADD, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_INFO,
- "BFA_AEN_ADAPTER_ADD",
- "New adapter found: SN = %s, base port WWN = %s.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | (BFA_LOG_S << BFA_LOG_ARG1) | 0), 2},
-
-{BFA_AEN_ADAPTER_REMOVE, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_WARNING, "BFA_AEN_ADAPTER_REMOVE",
- "Adapter removed: SN = %s.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-
-
-
-/* messages define for BFA_AEN_CAT_AUDIT Module */
-{BFA_AEN_AUDIT_AUTH_ENABLE, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_INFO, "BFA_AEN_AUDIT_AUTH_ENABLE",
- "Authentication enabled for base port: WWN = %s.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_AEN_AUDIT_AUTH_DISABLE, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_INFO, "BFA_AEN_AUDIT_AUTH_DISABLE",
- "Authentication disabled for base port: WWN = %s.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-
-
-
-/* messages define for BFA_AEN_CAT_ETHPORT Module */
-{BFA_AEN_ETHPORT_LINKUP, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_INFO,
- "BFA_AEN_ETHPORT_LINKUP",
- "Base port ethernet linkup: mac = %s.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_AEN_ETHPORT_LINKDOWN, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_INFO,
- "BFA_AEN_ETHPORT_LINKDOWN",
- "Base port ethernet linkdown: mac = %s.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_AEN_ETHPORT_ENABLE, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_INFO,
- "BFA_AEN_ETHPORT_ENABLE",
- "Base port ethernet interface enabled: mac = %s.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_AEN_ETHPORT_DISABLE, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_INFO,
- "BFA_AEN_ETHPORT_DISABLE",
- "Base port ethernet interface disabled: mac = %s.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-
-
-
-/* messages define for BFA_AEN_CAT_IOC Module */
-{BFA_AEN_IOC_HBGOOD, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_INFO,
- "BFA_AEN_IOC_HBGOOD",
- "Heart Beat of IOC %d is good.",
- ((BFA_LOG_D << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_AEN_IOC_HBFAIL, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_CRITICAL,
- "BFA_AEN_IOC_HBFAIL",
- "Heart Beat of IOC %d has failed.",
- ((BFA_LOG_D << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_AEN_IOC_ENABLE, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_INFO,
- "BFA_AEN_IOC_ENABLE",
- "IOC %d is enabled.",
- ((BFA_LOG_D << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_AEN_IOC_DISABLE, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_INFO,
- "BFA_AEN_IOC_DISABLE",
- "IOC %d is disabled.",
- ((BFA_LOG_D << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_AEN_IOC_FWMISMATCH, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_CRITICAL, "BFA_AEN_IOC_FWMISMATCH",
- "Running firmware version is incompatible with the driver version.",
- (0), 0},
-
-{BFA_AEN_IOC_FWCFG_ERROR, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_CRITICAL, "BFA_AEN_IOC_FWCFG_ERROR",
- "Link initialization failed due to firmware configuration read error:"
- " WWN = %s.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_AEN_IOC_INVALID_VENDOR, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_ERROR, "BFA_AEN_IOC_INVALID_VENDOR",
- "Unsupported switch vendor. Link initialization failed: WWN = %s.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_AEN_IOC_INVALID_NWWN, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_ERROR, "BFA_AEN_IOC_INVALID_NWWN",
- "Invalid NWWN. Link initialization failed: NWWN = 00:00:00:00:00:00:00:00.",
- (0), 0},
-
-{BFA_AEN_IOC_INVALID_PWWN, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_ERROR, "BFA_AEN_IOC_INVALID_PWWN",
- "Invalid PWWN. Link initialization failed: PWWN = 00:00:00:00:00:00:00:00.",
- (0), 0},
-
-
-
-
-/* messages define for BFA_AEN_CAT_ITNIM Module */
-{BFA_AEN_ITNIM_ONLINE, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_INFO,
- "BFA_AEN_ITNIM_ONLINE",
- "Target (WWN = %s) is online for initiator (WWN = %s).",
- ((BFA_LOG_S << BFA_LOG_ARG0) | (BFA_LOG_S << BFA_LOG_ARG1) | 0), 2},
-
-{BFA_AEN_ITNIM_OFFLINE, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_INFO,
- "BFA_AEN_ITNIM_OFFLINE",
- "Target (WWN = %s) offlined by initiator (WWN = %s).",
- ((BFA_LOG_S << BFA_LOG_ARG0) | (BFA_LOG_S << BFA_LOG_ARG1) | 0), 2},
-
-{BFA_AEN_ITNIM_DISCONNECT, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_ERROR, "BFA_AEN_ITNIM_DISCONNECT",
- "Target (WWN = %s) connectivity lost for initiator (WWN = %s).",
- ((BFA_LOG_S << BFA_LOG_ARG0) | (BFA_LOG_S << BFA_LOG_ARG1) | 0), 2},
-
-
-
-
-/* messages define for BFA_AEN_CAT_LPORT Module */
-{BFA_AEN_LPORT_NEW, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_INFO,
- "BFA_AEN_LPORT_NEW",
- "New logical port created: WWN = %s, Role = %s.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | (BFA_LOG_S << BFA_LOG_ARG1) | 0), 2},
-
-{BFA_AEN_LPORT_DELETE, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_INFO,
- "BFA_AEN_LPORT_DELETE",
- "Logical port deleted: WWN = %s, Role = %s.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | (BFA_LOG_S << BFA_LOG_ARG1) | 0), 2},
-
-{BFA_AEN_LPORT_ONLINE, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_INFO,
- "BFA_AEN_LPORT_ONLINE",
- "Logical port online: WWN = %s, Role = %s.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | (BFA_LOG_S << BFA_LOG_ARG1) | 0), 2},
-
-{BFA_AEN_LPORT_OFFLINE, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_INFO,
- "BFA_AEN_LPORT_OFFLINE",
- "Logical port taken offline: WWN = %s, Role = %s.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | (BFA_LOG_S << BFA_LOG_ARG1) | 0), 2},
-
-{BFA_AEN_LPORT_DISCONNECT, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_ERROR, "BFA_AEN_LPORT_DISCONNECT",
- "Logical port lost fabric connectivity: WWN = %s, Role = %s.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | (BFA_LOG_S << BFA_LOG_ARG1) | 0), 2},
-
-{BFA_AEN_LPORT_NEW_PROP, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_INFO,
- "BFA_AEN_LPORT_NEW_PROP",
- "New virtual port created using proprietary interface: WWN = %s, Role = %s.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | (BFA_LOG_S << BFA_LOG_ARG1) | 0), 2},
-
-{BFA_AEN_LPORT_DELETE_PROP, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_INFO, "BFA_AEN_LPORT_DELETE_PROP",
- "Virtual port deleted using proprietary interface: WWN = %s, Role = %s.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | (BFA_LOG_S << BFA_LOG_ARG1) | 0), 2},
-
-{BFA_AEN_LPORT_NEW_STANDARD, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_INFO, "BFA_AEN_LPORT_NEW_STANDARD",
- "New virtual port created using standard interface: WWN = %s, Role = %s.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | (BFA_LOG_S << BFA_LOG_ARG1) | 0), 2},
-
-{BFA_AEN_LPORT_DELETE_STANDARD, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_INFO, "BFA_AEN_LPORT_DELETE_STANDARD",
- "Virtual port deleted using standard interface: WWN = %s, Role = %s.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | (BFA_LOG_S << BFA_LOG_ARG1) | 0), 2},
-
-{BFA_AEN_LPORT_NPIV_DUP_WWN, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_WARNING, "BFA_AEN_LPORT_NPIV_DUP_WWN",
- "Virtual port login failed. Duplicate WWN = %s reported by fabric.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_AEN_LPORT_NPIV_FABRIC_MAX, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_WARNING, "BFA_AEN_LPORT_NPIV_FABRIC_MAX",
- "Virtual port (WWN = %s) login failed. Max NPIV ports already exist in"
- " fabric/fport.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_AEN_LPORT_NPIV_UNKNOWN, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_WARNING, "BFA_AEN_LPORT_NPIV_UNKNOWN",
- "Virtual port (WWN = %s) login failed.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-
-
-
-/* messages define for BFA_AEN_CAT_PORT Module */
-{BFA_AEN_PORT_ONLINE, BFA_LOG_ATTR_NONE, BFA_LOG_INFO, "BFA_AEN_PORT_ONLINE",
- "Base port online: WWN = %s.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_AEN_PORT_OFFLINE, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_WARNING,
- "BFA_AEN_PORT_OFFLINE",
- "Base port offline: WWN = %s.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_AEN_PORT_RLIR, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_INFO,
- "BFA_AEN_PORT_RLIR",
- "RLIR event not supported.",
- (0), 0},
-
-{BFA_AEN_PORT_SFP_INSERT, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_INFO,
- "BFA_AEN_PORT_SFP_INSERT",
- "New SFP found: WWN/MAC = %s.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_AEN_PORT_SFP_REMOVE, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_WARNING, "BFA_AEN_PORT_SFP_REMOVE",
- "SFP removed: WWN/MAC = %s.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_AEN_PORT_SFP_POM, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_WARNING,
- "BFA_AEN_PORT_SFP_POM",
- "SFP POM level to %s: WWN/MAC = %s.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | (BFA_LOG_S << BFA_LOG_ARG1) | 0), 2},
-
-{BFA_AEN_PORT_ENABLE, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_INFO,
- "BFA_AEN_PORT_ENABLE",
- "Base port enabled: WWN = %s.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_AEN_PORT_DISABLE, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_INFO,
- "BFA_AEN_PORT_DISABLE",
- "Base port disabled: WWN = %s.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_AEN_PORT_AUTH_ON, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_INFO,
- "BFA_AEN_PORT_AUTH_ON",
- "Authentication successful for base port: WWN = %s.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_AEN_PORT_AUTH_OFF, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_ERROR,
- "BFA_AEN_PORT_AUTH_OFF",
- "Authentication unsuccessful for base port: WWN = %s.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_AEN_PORT_DISCONNECT, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_ERROR,
- "BFA_AEN_PORT_DISCONNECT",
- "Base port (WWN = %s) lost fabric connectivity.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_AEN_PORT_QOS_NEG, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_WARNING,
- "BFA_AEN_PORT_QOS_NEG",
- "QOS negotiation failed for base port: WWN = %s.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_AEN_PORT_FABRIC_NAME_CHANGE, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_WARNING, "BFA_AEN_PORT_FABRIC_NAME_CHANGE",
- "Base port WWN = %s, Fabric WWN = %s.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | (BFA_LOG_S << BFA_LOG_ARG1) | 0), 2},
-
-{BFA_AEN_PORT_SFP_ACCESS_ERROR, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_WARNING, "BFA_AEN_PORT_SFP_ACCESS_ERROR",
- "SFP access error: WWN/MAC = %s.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_AEN_PORT_SFP_UNSUPPORT, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_WARNING, "BFA_AEN_PORT_SFP_UNSUPPORT",
- "Unsupported SFP found: WWN/MAC = %s.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-
-
-
-/* messages define for BFA_AEN_CAT_RPORT Module */
-{BFA_AEN_RPORT_ONLINE, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_INFO,
- "BFA_AEN_RPORT_ONLINE",
- "Remote port (WWN = %s) online for logical port (WWN = %s).",
- ((BFA_LOG_S << BFA_LOG_ARG0) | (BFA_LOG_S << BFA_LOG_ARG1) | 0), 2},
-
-{BFA_AEN_RPORT_OFFLINE, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_INFO,
- "BFA_AEN_RPORT_OFFLINE",
- "Remote port (WWN = %s) offlined by logical port (WWN = %s).",
- ((BFA_LOG_S << BFA_LOG_ARG0) | (BFA_LOG_S << BFA_LOG_ARG1) | 0), 2},
-
-{BFA_AEN_RPORT_DISCONNECT, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_ERROR, "BFA_AEN_RPORT_DISCONNECT",
- "Remote port (WWN = %s) connectivity lost for logical port (WWN = %s).",
- ((BFA_LOG_S << BFA_LOG_ARG0) | (BFA_LOG_S << BFA_LOG_ARG1) | 0), 2},
-
-{BFA_AEN_RPORT_QOS_PRIO, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_INFO,
- "BFA_AEN_RPORT_QOS_PRIO",
- "QOS priority changed to %s: RPWWN = %s and LPWWN = %s.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | (BFA_LOG_S << BFA_LOG_ARG1) |
-  (BFA_LOG_S << BFA_LOG_ARG2) | 0), 3},
-
-{BFA_AEN_RPORT_QOS_FLOWID, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_INFO,
- "BFA_AEN_RPORT_QOS_FLOWID",
- "QOS flow ID changed to %d: RPWWN = %s and LPWWN = %s.",
- ((BFA_LOG_D << BFA_LOG_ARG0) | (BFA_LOG_S << BFA_LOG_ARG1) |
-  (BFA_LOG_S << BFA_LOG_ARG2) | 0), 3},
-
-
-
-
-/* messages define for FCS Module */
-{BFA_LOG_FCS_FABRIC_NOSWITCH, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_INFO, "FCS_FABRIC_NOSWITCH",
- "No switched fabric presence is detected.",
- (0), 0},
-
-{BFA_LOG_FCS_FABRIC_ISOLATED, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_INFO, "FCS_FABRIC_ISOLATED",
- "Port is isolated due to VF_ID mismatch. PWWN: %s, Port VF_ID: %04x and"
- " switch port VF_ID: %04x.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | (BFA_LOG_X << BFA_LOG_ARG1) |
-  (BFA_LOG_X << BFA_LOG_ARG2) | 0), 3},
-
-
-
-
-/* messages define for HAL Module */
-{BFA_LOG_HAL_ASSERT, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_ERROR,
- "HAL_ASSERT",
- "Assertion failure: %s:%d: %s",
- ((BFA_LOG_S << BFA_LOG_ARG0) | (BFA_LOG_D << BFA_LOG_ARG1) |
-  (BFA_LOG_S << BFA_LOG_ARG2) | 0), 3},
-
-{BFA_LOG_HAL_HEARTBEAT_FAILURE, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_CRITICAL, "HAL_HEARTBEAT_FAILURE",
- "Firmware heartbeat failure at %d",
- ((BFA_LOG_D << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_LOG_HAL_FCPIM_PARM_INVALID, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_INFO, "HAL_FCPIM_PARM_INVALID",
- "Driver configuration %s value %d is invalid. Value should be within"
- " %d and %d.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | (BFA_LOG_D << BFA_LOG_ARG1) |
-  (BFA_LOG_D << BFA_LOG_ARG2) | (BFA_LOG_D << BFA_LOG_ARG3) | 0), 4},
-
-{BFA_LOG_HAL_SM_ASSERT, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_ERROR,
- "HAL_SM_ASSERT",
- "SM Assertion failure: %s:%d: event = %d",
- ((BFA_LOG_S << BFA_LOG_ARG0) | (BFA_LOG_D << BFA_LOG_ARG1) |
-  (BFA_LOG_D << BFA_LOG_ARG2) | 0), 3},
-
-{BFA_LOG_HAL_DRIVER_ERROR, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_INFO, "HAL_DRIVER_ERROR",
- "%s",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_LOG_HAL_DRIVER_CONFIG_ERROR,
- BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_INFO,
- "HAL_DRIVER_CONFIG_ERROR",
- "%s",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_LOG_HAL_MBOX_ERROR, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_INFO, "HAL_MBOX_ERROR",
- "%s",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-
-
-
-/* messages define for LINUX Module */
-{BFA_LOG_LINUX_DEVICE_CLAIMED, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_INFO, "LINUX_DEVICE_CLAIMED",
- "bfa device at %s claimed.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_LOG_LINUX_HASH_INIT_FAILED, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_INFO, "LINUX_HASH_INIT_FAILED",
- "Hash table initialization failure for the port %s.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_LOG_LINUX_SYSFS_FAILED, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_INFO, "LINUX_SYSFS_FAILED",
- "sysfs file creation failure for the port %s.",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_LOG_LINUX_MEM_ALLOC_FAILED, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_INFO, "LINUX_MEM_ALLOC_FAILED",
- "Memory allocation failed: %s.  ",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_LOG_LINUX_DRIVER_REGISTRATION_FAILED,
- BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_INFO,
- "LINUX_DRIVER_REGISTRATION_FAILED",
- "%s.  ",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_LOG_LINUX_ITNIM_FREE, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_INFO,
- "LINUX_ITNIM_FREE",
- "scsi%d: FCID: %s WWPN: %s",
- ((BFA_LOG_D << BFA_LOG_ARG0) | (BFA_LOG_S << BFA_LOG_ARG1) |
-  (BFA_LOG_S << BFA_LOG_ARG2) | 0), 3},
-
-{BFA_LOG_LINUX_ITNIM_ONLINE, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_INFO, "LINUX_ITNIM_ONLINE",
- "Target: %d:0:%d FCID: %s WWPN: %s",
- ((BFA_LOG_D << BFA_LOG_ARG0) | (BFA_LOG_D << BFA_LOG_ARG1) |
-  (BFA_LOG_S << BFA_LOG_ARG2) | (BFA_LOG_S << BFA_LOG_ARG3) | 0), 4},
-
-{BFA_LOG_LINUX_ITNIM_OFFLINE, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_INFO, "LINUX_ITNIM_OFFLINE",
- "Target: %d:0:%d FCID: %s WWPN: %s",
- ((BFA_LOG_D << BFA_LOG_ARG0) | (BFA_LOG_D << BFA_LOG_ARG1) |
-  (BFA_LOG_S << BFA_LOG_ARG2) | (BFA_LOG_S << BFA_LOG_ARG3) | 0), 4},
-
-{BFA_LOG_LINUX_SCSI_HOST_FREE, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_INFO, "LINUX_SCSI_HOST_FREE",
- "Free scsi%d",
- ((BFA_LOG_D << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_LOG_LINUX_SCSI_ABORT, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_INFO,
- "LINUX_SCSI_ABORT",
- "scsi%d: abort cmnd %p, iotag %x",
- ((BFA_LOG_D << BFA_LOG_ARG0) | (BFA_LOG_P << BFA_LOG_ARG1) |
-  (BFA_LOG_X << BFA_LOG_ARG2) | 0), 3},
-
-{BFA_LOG_LINUX_SCSI_ABORT_COMP, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_INFO, "LINUX_SCSI_ABORT_COMP",
- "scsi%d: complete abort 0x%p, iotag 0x%x",
- ((BFA_LOG_D << BFA_LOG_ARG0) | (BFA_LOG_P << BFA_LOG_ARG1) |
-  (BFA_LOG_X << BFA_LOG_ARG2) | 0), 3},
-
-{BFA_LOG_LINUX_DRIVER_CONFIG_ERROR,
- BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_INFO,
- "LINUX_DRIVER_CONFIG_ERROR",
- "%s",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_LOG_LINUX_BNA_STATE_MACHINE,
- BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_INFO,
- "LINUX_BNA_STATE_MACHINE",
- "%s",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_LOG_LINUX_IOC_ERROR, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_INFO, "LINUX_IOC_ERROR",
- "%s",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_LOG_LINUX_RESOURCE_ALLOC_ERROR,
- BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_INFO,
- "LINUX_RESOURCE_ALLOC_ERROR",
- "%s",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_LOG_LINUX_RING_BUFFER_ERROR,
- BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG, BFA_LOG_INFO,
- "LINUX_RING_BUFFER_ERROR",
- "%s",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_LOG_LINUX_DRIVER_ERROR, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_ERROR, "LINUX_DRIVER_ERROR",
- "%s",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_LOG_LINUX_DRIVER_INFO, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_INFO, "LINUX_DRIVER_INFO",
- "%s",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_LOG_LINUX_DRIVER_DIAG, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_INFO, "LINUX_DRIVER_DIAG",
- "%s",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-{BFA_LOG_LINUX_DRIVER_AEN, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_INFO, "LINUX_DRIVER_AEN",
- "%s",
- ((BFA_LOG_S << BFA_LOG_ARG0) | 0), 1},
-
-
-
-
-/* messages define for WDRV Module */
-{BFA_LOG_WDRV_IOC_INIT_ERROR, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_INFO, "WDRV_IOC_INIT_ERROR",
- "IOC initialization has failed.",
- (0), 0},
-
-{BFA_LOG_WDRV_IOC_INTERNAL_ERROR, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_INFO, "WDRV_IOC_INTERNAL_ERROR",
- "IOC internal error.  ",
- (0), 0},
-
-{BFA_LOG_WDRV_IOC_START_ERROR, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_INFO, "WDRV_IOC_START_ERROR",
- "IOC could not be started.  ",
- (0), 0},
-
-{BFA_LOG_WDRV_IOC_STOP_ERROR, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_INFO, "WDRV_IOC_STOP_ERROR",
- "IOC could not be stopped.  ",
- (0), 0},
-
-{BFA_LOG_WDRV_INSUFFICIENT_RESOURCES, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_INFO, "WDRV_INSUFFICIENT_RESOURCES",
- "Insufficient memory.  ",
- (0), 0},
-
-{BFA_LOG_WDRV_BASE_ADDRESS_MAP_ERROR, BFA_LOG_ATTR_NONE | BFA_LOG_ATTR_LOG,
- BFA_LOG_INFO, "WDRV_BASE_ADDRESS_MAP_ERROR",
- "Unable to map the IOC onto the system address space.  ",
- (0), 0},
-
-
-{0, 0, 0, "", "", 0, 0},
-};
diff --git a/drivers/scsi/bfa/bfa_lps.c b/drivers/scsi/bfa/bfa_lps.c
deleted file mode 100644 (file)
index acabb44..0000000
+++ /dev/null
@@ -1,892 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#include <bfa.h>
-#include <bfi/bfi_lps.h>
-#include <cs/bfa_debug.h>
-#include <defs/bfa_defs_pci.h>
-
-BFA_TRC_FILE(HAL, LPS);
-BFA_MODULE(lps);
-
-#define BFA_LPS_MIN_LPORTS     (1)
-#define BFA_LPS_MAX_LPORTS     (256)
-
-/*
- * Maximum Vports supported per physical port or vf.
- */
-#define BFA_LPS_MAX_VPORTS_SUPP_CB  255
-#define BFA_LPS_MAX_VPORTS_SUPP_CT  190
-
-/**
- * forward declarations
- */
-static void bfa_lps_meminfo(struct bfa_iocfc_cfg_s *cfg, u32 *ndm_len,
-                           u32 *dm_len);
-static void bfa_lps_attach(struct bfa_s *bfa, void *bfad,
-                          struct bfa_iocfc_cfg_s *cfg,
-                          struct bfa_meminfo_s *meminfo,
-                          struct bfa_pcidev_s *pcidev);
-static void bfa_lps_detach(struct bfa_s *bfa);
-static void bfa_lps_start(struct bfa_s *bfa);
-static void bfa_lps_stop(struct bfa_s *bfa);
-static void bfa_lps_iocdisable(struct bfa_s *bfa);
-static void bfa_lps_login_rsp(struct bfa_s *bfa,
-                             struct bfi_lps_login_rsp_s *rsp);
-static void bfa_lps_logout_rsp(struct bfa_s *bfa,
-                              struct bfi_lps_logout_rsp_s *rsp);
-static void bfa_lps_reqq_resume(void *lps_arg);
-static void bfa_lps_free(struct bfa_lps_s *lps);
-static void bfa_lps_send_login(struct bfa_lps_s *lps);
-static void bfa_lps_send_logout(struct bfa_lps_s *lps);
-static void bfa_lps_login_comp(struct bfa_lps_s *lps);
-static void bfa_lps_logout_comp(struct bfa_lps_s *lps);
-static void bfa_lps_cvl_event(struct bfa_lps_s *lps);
-
-/**
- *  lps_pvt BFA LPS private functions
- */
-
-enum bfa_lps_event {
-       BFA_LPS_SM_LOGIN        = 1,    /* login request from user      */
-       BFA_LPS_SM_LOGOUT       = 2,    /* logout request from user     */
-       BFA_LPS_SM_FWRSP        = 3,    /* f/w response to login/logout */
-       BFA_LPS_SM_RESUME       = 4,    /* space present in reqq queue  */
-       BFA_LPS_SM_DELETE       = 5,    /* lps delete from user         */
-       BFA_LPS_SM_OFFLINE      = 6,    /* Link is offline              */
-       BFA_LPS_SM_RX_CVL       = 7,    /* Rx clear virtual link        */
-};
-
-static void bfa_lps_sm_init(struct bfa_lps_s *lps, enum bfa_lps_event event);
-static void bfa_lps_sm_login(struct bfa_lps_s *lps, enum bfa_lps_event event);
-static void bfa_lps_sm_loginwait(struct bfa_lps_s *lps,
-                       enum bfa_lps_event event);
-static void bfa_lps_sm_online(struct bfa_lps_s *lps, enum bfa_lps_event event);
-static void bfa_lps_sm_logout(struct bfa_lps_s *lps, enum bfa_lps_event event);
-static void bfa_lps_sm_logowait(struct bfa_lps_s *lps,
-                       enum bfa_lps_event event);
-
-/**
- * Init state -- no login
- */
-static void
-bfa_lps_sm_init(struct bfa_lps_s *lps, enum bfa_lps_event event)
-{
-       bfa_trc(lps->bfa, lps->lp_tag);
-       bfa_trc(lps->bfa, event);
-
-       switch (event) {
-       case BFA_LPS_SM_LOGIN:
-               if (bfa_reqq_full(lps->bfa, lps->reqq)) {
-                       bfa_sm_set_state(lps, bfa_lps_sm_loginwait);
-                       bfa_reqq_wait(lps->bfa, lps->reqq, &lps->wqe);
-               } else {
-                       bfa_sm_set_state(lps, bfa_lps_sm_login);
-                       bfa_lps_send_login(lps);
-               }
-               if (lps->fdisc)
-                       bfa_plog_str(lps->bfa->plog, BFA_PL_MID_LPS,
-                       BFA_PL_EID_LOGIN, 0, "FDISC Request");
-               else
-                       bfa_plog_str(lps->bfa->plog, BFA_PL_MID_LPS,
-                       BFA_PL_EID_LOGIN, 0, "FLOGI Request");
-               break;
-
-       case BFA_LPS_SM_LOGOUT:
-               bfa_lps_logout_comp(lps);
-               break;
-
-       case BFA_LPS_SM_DELETE:
-               bfa_lps_free(lps);
-               break;
-
-       case BFA_LPS_SM_RX_CVL:
-       case BFA_LPS_SM_OFFLINE:
-               break;
-
-       case BFA_LPS_SM_FWRSP:
-               /* Could happen when fabric detects loopback and discards
-                * the lps request. Fw will eventually sent out the timeout
-                * Just ignore
-                */
-               break;
-
-       default:
-               bfa_sm_fault(lps->bfa, event);
-       }
-}
-
-/**
- * login is in progress -- awaiting response from firmware
- */
-static void
-bfa_lps_sm_login(struct bfa_lps_s *lps, enum bfa_lps_event event)
-{
-       bfa_trc(lps->bfa, lps->lp_tag);
-       bfa_trc(lps->bfa, event);
-
-       switch (event) {
-       case BFA_LPS_SM_FWRSP:
-               if (lps->status == BFA_STATUS_OK) {
-                       bfa_sm_set_state(lps, bfa_lps_sm_online);
-                       if (lps->fdisc)
-                               bfa_plog_str(lps->bfa->plog, BFA_PL_MID_LPS,
-                               BFA_PL_EID_LOGIN, 0, "FDISC Accept");
-                       else
-                               bfa_plog_str(lps->bfa->plog, BFA_PL_MID_LPS,
-                               BFA_PL_EID_LOGIN, 0, "FLOGI Accept");
-               } else {
-                       bfa_sm_set_state(lps, bfa_lps_sm_init);
-                       if (lps->fdisc)
-                               bfa_plog_str(lps->bfa->plog, BFA_PL_MID_LPS,
-                               BFA_PL_EID_LOGIN, 0,
-                               "FDISC Fail (RJT or timeout)");
-                       else
-                               bfa_plog_str(lps->bfa->plog, BFA_PL_MID_LPS,
-                               BFA_PL_EID_LOGIN, 0,
-                               "FLOGI Fail (RJT or timeout)");
-               }
-               bfa_lps_login_comp(lps);
-               break;
-
-       case BFA_LPS_SM_OFFLINE:
-               bfa_sm_set_state(lps, bfa_lps_sm_init);
-               break;
-
-       default:
-               bfa_sm_fault(lps->bfa, event);
-       }
-}
-
-/**
- * login pending - awaiting space in request queue
- */
-static void
-bfa_lps_sm_loginwait(struct bfa_lps_s *lps, enum bfa_lps_event event)
-{
-       bfa_trc(lps->bfa, lps->lp_tag);
-       bfa_trc(lps->bfa, event);
-
-       switch (event) {
-       case BFA_LPS_SM_RESUME:
-               bfa_sm_set_state(lps, bfa_lps_sm_login);
-               break;
-
-       case BFA_LPS_SM_OFFLINE:
-               bfa_sm_set_state(lps, bfa_lps_sm_init);
-               bfa_reqq_wcancel(&lps->wqe);
-               break;
-
-       case BFA_LPS_SM_RX_CVL:
-               /*
-                * Login was not even sent out; so when getting out
-                * of this state, it will appear like a login retry
-                * after Clear virtual link
-                */
-               break;
-
-       default:
-               bfa_sm_fault(lps->bfa, event);
-       }
-}
-
-/**
- * login complete
- */
-static void
-bfa_lps_sm_online(struct bfa_lps_s *lps, enum bfa_lps_event event)
-{
-       bfa_trc(lps->bfa, lps->lp_tag);
-       bfa_trc(lps->bfa, event);
-
-       switch (event) {
-       case BFA_LPS_SM_LOGOUT:
-               if (bfa_reqq_full(lps->bfa, lps->reqq)) {
-                       bfa_sm_set_state(lps, bfa_lps_sm_logowait);
-                       bfa_reqq_wait(lps->bfa, lps->reqq, &lps->wqe);
-               } else {
-                       bfa_sm_set_state(lps, bfa_lps_sm_logout);
-                       bfa_lps_send_logout(lps);
-               }
-               bfa_plog_str(lps->bfa->plog, BFA_PL_MID_LPS,
-                       BFA_PL_EID_LOGO, 0, "Logout");
-               break;
-
-       case BFA_LPS_SM_RX_CVL:
-               bfa_sm_set_state(lps, bfa_lps_sm_init);
-
-               /* Let the vport module know about this event */
-               bfa_lps_cvl_event(lps);
-               bfa_plog_str(lps->bfa->plog, BFA_PL_MID_LPS,
-                       BFA_PL_EID_FIP_FCF_CVL, 0, "FCF Clear Virt. Link Rx");
-               break;
-
-       case BFA_LPS_SM_OFFLINE:
-       case BFA_LPS_SM_DELETE:
-               bfa_sm_set_state(lps, bfa_lps_sm_init);
-               break;
-
-       default:
-               bfa_sm_fault(lps->bfa, event);
-       }
-}
-
-/**
- * logout in progress - awaiting firmware response
- */
-static void
-bfa_lps_sm_logout(struct bfa_lps_s *lps, enum bfa_lps_event event)
-{
-       bfa_trc(lps->bfa, lps->lp_tag);
-       bfa_trc(lps->bfa, event);
-
-       switch (event) {
-       case BFA_LPS_SM_FWRSP:
-               bfa_sm_set_state(lps, bfa_lps_sm_init);
-               bfa_lps_logout_comp(lps);
-               break;
-
-       case BFA_LPS_SM_OFFLINE:
-               bfa_sm_set_state(lps, bfa_lps_sm_init);
-               break;
-
-       default:
-               bfa_sm_fault(lps->bfa, event);
-       }
-}
-
-/**
- * logout pending -- awaiting space in request queue
- */
-static void
-bfa_lps_sm_logowait(struct bfa_lps_s *lps, enum bfa_lps_event event)
-{
-       bfa_trc(lps->bfa, lps->lp_tag);
-       bfa_trc(lps->bfa, event);
-
-       switch (event) {
-       case BFA_LPS_SM_RESUME:
-               bfa_sm_set_state(lps, bfa_lps_sm_logout);
-               bfa_lps_send_logout(lps);
-               break;
-
-       case BFA_LPS_SM_OFFLINE:
-               bfa_sm_set_state(lps, bfa_lps_sm_init);
-               bfa_reqq_wcancel(&lps->wqe);
-               break;
-
-       default:
-               bfa_sm_fault(lps->bfa, event);
-       }
-}
-
-
-
-/**
- *  lps_pvt BFA LPS private functions
- */
-
-/**
- * return memory requirement
- */
-static void
-bfa_lps_meminfo(struct bfa_iocfc_cfg_s *cfg, u32 *ndm_len, u32 *dm_len)
-{
-       if (cfg->drvcfg.min_cfg)
-               *ndm_len += sizeof(struct bfa_lps_s) * BFA_LPS_MIN_LPORTS;
-       else
-               *ndm_len += sizeof(struct bfa_lps_s) * BFA_LPS_MAX_LPORTS;
-}
-
-/**
- * bfa module attach at initialization time
- */
-static void
-bfa_lps_attach(struct bfa_s *bfa, void *bfad, struct bfa_iocfc_cfg_s *cfg,
-               struct bfa_meminfo_s *meminfo, struct bfa_pcidev_s *pcidev)
-{
-       struct bfa_lps_mod_s    *mod = BFA_LPS_MOD(bfa);
-       struct bfa_lps_s        *lps;
-       int                     i;
-
-       bfa_os_memset(mod, 0, sizeof(struct bfa_lps_mod_s));
-       mod->num_lps = BFA_LPS_MAX_LPORTS;
-       if (cfg->drvcfg.min_cfg)
-               mod->num_lps = BFA_LPS_MIN_LPORTS;
-       else
-               mod->num_lps = BFA_LPS_MAX_LPORTS;
-       mod->lps_arr = lps = (struct bfa_lps_s *) bfa_meminfo_kva(meminfo);
-
-       bfa_meminfo_kva(meminfo) += mod->num_lps * sizeof(struct bfa_lps_s);
-
-       INIT_LIST_HEAD(&mod->lps_free_q);
-       INIT_LIST_HEAD(&mod->lps_active_q);
-
-       for (i = 0; i < mod->num_lps; i++, lps++) {
-               lps->bfa        = bfa;
-               lps->lp_tag     = (u8) i;
-               lps->reqq       = BFA_REQQ_LPS;
-               bfa_reqq_winit(&lps->wqe, bfa_lps_reqq_resume, lps);
-               list_add_tail(&lps->qe, &mod->lps_free_q);
-       }
-}
-
-static void
-bfa_lps_detach(struct bfa_s *bfa)
-{
-}
-
-static void
-bfa_lps_start(struct bfa_s *bfa)
-{
-}
-
-static void
-bfa_lps_stop(struct bfa_s *bfa)
-{
-}
-
-/**
- * IOC in disabled state -- consider all lps offline
- */
-static void
-bfa_lps_iocdisable(struct bfa_s *bfa)
-{
-       struct bfa_lps_mod_s    *mod = BFA_LPS_MOD(bfa);
-       struct bfa_lps_s        *lps;
-       struct list_head                *qe, *qen;
-
-       list_for_each_safe(qe, qen, &mod->lps_active_q) {
-               lps = (struct bfa_lps_s *) qe;
-               bfa_sm_send_event(lps, BFA_LPS_SM_OFFLINE);
-       }
-}
-
-/**
- * Firmware login response
- */
-static void
-bfa_lps_login_rsp(struct bfa_s *bfa, struct bfi_lps_login_rsp_s *rsp)
-{
-       struct bfa_lps_mod_s    *mod = BFA_LPS_MOD(bfa);
-       struct bfa_lps_s        *lps;
-
-       bfa_assert(rsp->lp_tag < mod->num_lps);
-       lps = BFA_LPS_FROM_TAG(mod, rsp->lp_tag);
-
-       lps->status = rsp->status;
-       switch (rsp->status) {
-       case BFA_STATUS_OK:
-               lps->fport      = rsp->f_port;
-               lps->npiv_en    = rsp->npiv_en;
-               lps->lp_pid     = rsp->lp_pid;
-               lps->pr_bbcred  = bfa_os_ntohs(rsp->bb_credit);
-               lps->pr_pwwn    = rsp->port_name;
-               lps->pr_nwwn    = rsp->node_name;
-               lps->auth_req   = rsp->auth_req;
-               lps->lp_mac     = rsp->lp_mac;
-               lps->brcd_switch = rsp->brcd_switch;
-               lps->fcf_mac    = rsp->fcf_mac;
-
-               break;
-
-       case BFA_STATUS_FABRIC_RJT:
-               lps->lsrjt_rsn = rsp->lsrjt_rsn;
-               lps->lsrjt_expl = rsp->lsrjt_expl;
-
-               break;
-
-       case BFA_STATUS_EPROTOCOL:
-               lps->ext_status = rsp->ext_status;
-
-               break;
-
-       default:
-               /* Nothing to do with other status */
-               break;
-       }
-
-       bfa_sm_send_event(lps, BFA_LPS_SM_FWRSP);
-}
-
-/**
- * Firmware logout response
- */
-static void
-bfa_lps_logout_rsp(struct bfa_s *bfa, struct bfi_lps_logout_rsp_s *rsp)
-{
-       struct bfa_lps_mod_s    *mod = BFA_LPS_MOD(bfa);
-       struct bfa_lps_s        *lps;
-
-       bfa_assert(rsp->lp_tag < mod->num_lps);
-       lps = BFA_LPS_FROM_TAG(mod, rsp->lp_tag);
-
-       bfa_sm_send_event(lps, BFA_LPS_SM_FWRSP);
-}
-
-/**
- * Firmware received a Clear virtual link request (for FCoE)
- */
-static void
-bfa_lps_rx_cvl_event(struct bfa_s *bfa, struct bfi_lps_cvl_event_s *cvl)
-{
-       struct bfa_lps_mod_s    *mod = BFA_LPS_MOD(bfa);
-       struct bfa_lps_s        *lps;
-
-       lps = BFA_LPS_FROM_TAG(mod, cvl->lp_tag);
-
-       bfa_sm_send_event(lps, BFA_LPS_SM_RX_CVL);
-}
-
-/**
- * Space is available in request queue, resume queueing request to firmware.
- */
-static void
-bfa_lps_reqq_resume(void *lps_arg)
-{
-       struct bfa_lps_s        *lps = lps_arg;
-
-       bfa_sm_send_event(lps, BFA_LPS_SM_RESUME);
-}
-
-/**
- * lps is freed -- triggered by vport delete
- */
-static void
-bfa_lps_free(struct bfa_lps_s *lps)
-{
-       struct bfa_lps_mod_s    *mod = BFA_LPS_MOD(lps->bfa);
-
-       list_del(&lps->qe);
-       list_add_tail(&lps->qe, &mod->lps_free_q);
-}
-
-/**
- * send login request to firmware
- */
-static void
-bfa_lps_send_login(struct bfa_lps_s *lps)
-{
-       struct bfi_lps_login_req_s      *m;
-
-       m = bfa_reqq_next(lps->bfa, lps->reqq);
-       bfa_assert(m);
-
-       bfi_h2i_set(m->mh, BFI_MC_LPS, BFI_LPS_H2I_LOGIN_REQ,
-                       bfa_lpuid(lps->bfa));
-
-       m->lp_tag       = lps->lp_tag;
-       m->alpa         = lps->alpa;
-       m->pdu_size     = bfa_os_htons(lps->pdusz);
-       m->pwwn         = lps->pwwn;
-       m->nwwn         = lps->nwwn;
-       m->fdisc        = lps->fdisc;
-       m->auth_en      = lps->auth_en;
-
-       bfa_reqq_produce(lps->bfa, lps->reqq);
-}
-
-/**
- * send logout request to firmware
- */
-static void
-bfa_lps_send_logout(struct bfa_lps_s *lps)
-{
-       struct bfi_lps_logout_req_s *m;
-
-       m = bfa_reqq_next(lps->bfa, lps->reqq);
-       bfa_assert(m);
-
-       bfi_h2i_set(m->mh, BFI_MC_LPS, BFI_LPS_H2I_LOGOUT_REQ,
-                       bfa_lpuid(lps->bfa));
-
-       m->lp_tag    = lps->lp_tag;
-       m->port_name = lps->pwwn;
-       bfa_reqq_produce(lps->bfa, lps->reqq);
-}
-
-/**
- * Indirect login completion handler for non-fcs
- */
-static void
-bfa_lps_login_comp_cb(void *arg, bfa_boolean_t complete)
-{
-       struct bfa_lps_s *lps   = arg;
-
-       if (!complete)
-               return;
-
-       if (lps->fdisc)
-               bfa_cb_lps_fdisc_comp(lps->bfa->bfad, lps->uarg, lps->status);
-       else
-               bfa_cb_lps_flogi_comp(lps->bfa->bfad, lps->uarg, lps->status);
-}
-
-/**
- * Login completion handler -- direct call for fcs, queue for others
- */
-static void
-bfa_lps_login_comp(struct bfa_lps_s *lps)
-{
-       if (!lps->bfa->fcs) {
-               bfa_cb_queue(lps->bfa, &lps->hcb_qe,
-                               bfa_lps_login_comp_cb, lps);
-               return;
-       }
-
-       if (lps->fdisc)
-               bfa_cb_lps_fdisc_comp(lps->bfa->bfad, lps->uarg, lps->status);
-       else
-               bfa_cb_lps_flogi_comp(lps->bfa->bfad, lps->uarg, lps->status);
-}
-
-/**
- * Indirect logout completion handler for non-fcs
- */
-static void
-bfa_lps_logout_comp_cb(void *arg, bfa_boolean_t complete)
-{
-       struct bfa_lps_s *lps   = arg;
-
-       if (!complete)
-               return;
-
-       if (lps->fdisc)
-               bfa_cb_lps_fdisclogo_comp(lps->bfa->bfad, lps->uarg);
-       else
-               bfa_cb_lps_flogo_comp(lps->bfa->bfad, lps->uarg);
-}
-
-/**
- * Logout completion handler -- direct call for fcs, queue for others
- */
-static void
-bfa_lps_logout_comp(struct bfa_lps_s *lps)
-{
-       if (!lps->bfa->fcs) {
-               bfa_cb_queue(lps->bfa, &lps->hcb_qe,
-                               bfa_lps_logout_comp_cb, lps);
-               return;
-       }
-       if (lps->fdisc)
-               bfa_cb_lps_fdisclogo_comp(lps->bfa->bfad, lps->uarg);
-       else
-               bfa_cb_lps_flogo_comp(lps->bfa->bfad, lps->uarg);
-}
-
-/**
- * Clear virtual link completion handler for non-fcs
- */
-static void
-bfa_lps_cvl_event_cb(void *arg, bfa_boolean_t complete)
-{
-       struct bfa_lps_s *lps   = arg;
-
-       if (!complete)
-               return;
-
-       /* Clear virtual link to base port will result in link down */
-       if (lps->fdisc)
-               bfa_cb_lps_cvl_event(lps->bfa->bfad, lps->uarg);
-}
-
-/**
- * Received Clear virtual link event --direct call for fcs,
- * queue for others
- */
-static void
-bfa_lps_cvl_event(struct bfa_lps_s *lps)
-{
-       if (!lps->bfa->fcs) {
-               bfa_cb_queue(lps->bfa, &lps->hcb_qe, bfa_lps_cvl_event_cb,
-                               lps);
-               return;
-       }
-
-       /* Clear virtual link to base port will result in link down */
-       if (lps->fdisc)
-               bfa_cb_lps_cvl_event(lps->bfa->bfad, lps->uarg);
-}
-
-u32
-bfa_lps_get_max_vport(struct bfa_s *bfa)
-{
-       if (bfa_ioc_devid(&bfa->ioc) == BFA_PCI_DEVICE_ID_CT)
-               return BFA_LPS_MAX_VPORTS_SUPP_CT;
-       else
-               return BFA_LPS_MAX_VPORTS_SUPP_CB;
-}
-
-/**
- *  lps_public BFA LPS public functions
- */
-
-/**
- * Allocate a lport srvice tag.
- */
-struct bfa_lps_s  *
-bfa_lps_alloc(struct bfa_s *bfa)
-{
-       struct bfa_lps_mod_s    *mod = BFA_LPS_MOD(bfa);
-       struct bfa_lps_s        *lps = NULL;
-
-       bfa_q_deq(&mod->lps_free_q, &lps);
-
-       if (lps == NULL)
-               return NULL;
-
-       list_add_tail(&lps->qe, &mod->lps_active_q);
-
-       bfa_sm_set_state(lps, bfa_lps_sm_init);
-       return lps;
-}
-
-/**
- * Free lport service tag. This can be called anytime after an alloc.
- * No need to wait for any pending login/logout completions.
- */
-void
-bfa_lps_delete(struct bfa_lps_s *lps)
-{
-       bfa_sm_send_event(lps, BFA_LPS_SM_DELETE);
-}
-
-/**
- * Initiate a lport login.
- */
-void
-bfa_lps_flogi(struct bfa_lps_s *lps, void *uarg, u8 alpa, u16 pdusz,
-       wwn_t pwwn, wwn_t nwwn, bfa_boolean_t auth_en)
-{
-       lps->uarg       = uarg;
-       lps->alpa       = alpa;
-       lps->pdusz      = pdusz;
-       lps->pwwn       = pwwn;
-       lps->nwwn       = nwwn;
-       lps->fdisc      = BFA_FALSE;
-       lps->auth_en    = auth_en;
-       bfa_sm_send_event(lps, BFA_LPS_SM_LOGIN);
-}
-
-/**
- * Initiate a lport fdisc login.
- */
-void
-bfa_lps_fdisc(struct bfa_lps_s *lps, void *uarg, u16 pdusz, wwn_t pwwn,
-       wwn_t nwwn)
-{
-       lps->uarg       = uarg;
-       lps->alpa       = 0;
-       lps->pdusz      = pdusz;
-       lps->pwwn       = pwwn;
-       lps->nwwn       = nwwn;
-       lps->fdisc      = BFA_TRUE;
-       lps->auth_en    = BFA_FALSE;
-       bfa_sm_send_event(lps, BFA_LPS_SM_LOGIN);
-}
-
-/**
- * Initiate a lport logout (flogi).
- */
-void
-bfa_lps_flogo(struct bfa_lps_s *lps)
-{
-       bfa_sm_send_event(lps, BFA_LPS_SM_LOGOUT);
-}
-
-/**
- * Initiate a lport FDSIC logout.
- */
-void
-bfa_lps_fdisclogo(struct bfa_lps_s *lps)
-{
-       bfa_sm_send_event(lps, BFA_LPS_SM_LOGOUT);
-}
-
-/**
- * Discard a pending login request -- should be called only for
- * link down handling.
- */
-void
-bfa_lps_discard(struct bfa_lps_s *lps)
-{
-       bfa_sm_send_event(lps, BFA_LPS_SM_OFFLINE);
-}
-
-/**
- * Return lport services tag
- */
-u8
-bfa_lps_get_tag(struct bfa_lps_s *lps)
-{
-       return lps->lp_tag;
-}
-
-/**
- * Return lport services tag given the pid
- */
-u8
-bfa_lps_get_tag_from_pid(struct bfa_s *bfa, u32 pid)
-{
-       struct bfa_lps_mod_s    *mod = BFA_LPS_MOD(bfa);
-       struct bfa_lps_s        *lps;
-       int                     i;
-
-       for (i = 0, lps = mod->lps_arr; i < mod->num_lps; i++, lps++) {
-               if (lps->lp_pid == pid)
-                       return lps->lp_tag;
-       }
-
-       /* Return base port tag anyway */
-       return 0;
-}
-
-/**
- * return if fabric login indicates support for NPIV
- */
-bfa_boolean_t
-bfa_lps_is_npiv_en(struct bfa_lps_s *lps)
-{
-       return lps->npiv_en;
-}
-
-/**
- * Return TRUE if attached to F-Port, else return FALSE
- */
-bfa_boolean_t
-bfa_lps_is_fport(struct bfa_lps_s *lps)
-{
-       return lps->fport;
-}
-
-/**
- * Return TRUE if attached to a Brocade Fabric
- */
-bfa_boolean_t
-bfa_lps_is_brcd_fabric(struct bfa_lps_s *lps)
-{
-       return lps->brcd_switch;
-}
-/**
- * return TRUE if authentication is required
- */
-bfa_boolean_t
-bfa_lps_is_authreq(struct bfa_lps_s *lps)
-{
-       return lps->auth_req;
-}
-
-bfa_eproto_status_t
-bfa_lps_get_extstatus(struct bfa_lps_s *lps)
-{
-       return lps->ext_status;
-}
-
-/**
- * return port id assigned to the lport
- */
-u32
-bfa_lps_get_pid(struct bfa_lps_s *lps)
-{
-       return lps->lp_pid;
-}
-
-/**
- * Return bb_credit assigned in FLOGI response
- */
-u16
-bfa_lps_get_peer_bbcredit(struct bfa_lps_s *lps)
-{
-       return lps->pr_bbcred;
-}
-
-/**
- * Return peer port name
- */
-wwn_t
-bfa_lps_get_peer_pwwn(struct bfa_lps_s *lps)
-{
-       return lps->pr_pwwn;
-}
-
-/**
- * Return peer node name
- */
-wwn_t
-bfa_lps_get_peer_nwwn(struct bfa_lps_s *lps)
-{
-       return lps->pr_nwwn;
-}
-
-/**
- * return reason code if login request is rejected
- */
-u8
-bfa_lps_get_lsrjt_rsn(struct bfa_lps_s *lps)
-{
-       return lps->lsrjt_rsn;
-}
-
-/**
- * return explanation code if login request is rejected
- */
-u8
-bfa_lps_get_lsrjt_expl(struct bfa_lps_s *lps)
-{
-       return lps->lsrjt_expl;
-}
-
-/**
- * Return fpma/spma MAC for lport
- */
-struct mac_s
-bfa_lps_get_lp_mac(struct bfa_lps_s *lps)
-{
-       return lps->lp_mac;
-}
-
-/**
- * LPS firmware message class handler.
- */
-void
-bfa_lps_isr(struct bfa_s *bfa, struct bfi_msg_s *m)
-{
-       union bfi_lps_i2h_msg_u msg;
-
-       bfa_trc(bfa, m->mhdr.msg_id);
-       msg.msg = m;
-
-       switch (m->mhdr.msg_id) {
-       case BFI_LPS_H2I_LOGIN_RSP:
-               bfa_lps_login_rsp(bfa, msg.login_rsp);
-               break;
-
-       case BFI_LPS_H2I_LOGOUT_RSP:
-               bfa_lps_logout_rsp(bfa, msg.logout_rsp);
-               break;
-
-       case BFI_LPS_H2I_CVL_EVENT:
-               bfa_lps_rx_cvl_event(bfa, msg.cvl_event);
-               break;
-
-       default:
-               bfa_trc(bfa, m->mhdr.msg_id);
-               bfa_assert(0);
-       }
-}
-
-
diff --git a/drivers/scsi/bfa/bfa_lps_priv.h b/drivers/scsi/bfa/bfa_lps_priv.h
deleted file mode 100644 (file)
index d16c6ce..0000000
+++ /dev/null
@@ -1,38 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_LPS_PRIV_H__
-#define __BFA_LPS_PRIV_H__
-
-#include <bfa_svc.h>
-
-struct bfa_lps_mod_s {
-       struct list_head                lps_free_q;
-       struct list_head                lps_active_q;
-       struct bfa_lps_s        *lps_arr;
-       int                     num_lps;
-};
-
-#define BFA_LPS_MOD(__bfa)             (&(__bfa)->modules.lps_mod)
-#define BFA_LPS_FROM_TAG(__mod, __tag) (&(__mod)->lps_arr[__tag])
-
-/*
- * external functions
- */
-void   bfa_lps_isr(struct bfa_s *bfa, struct bfi_msg_s *msg);
-
-#endif /* __BFA_LPS_PRIV_H__ */
diff --git a/drivers/scsi/bfa/bfa_module.c b/drivers/scsi/bfa/bfa_module.c
deleted file mode 100644 (file)
index a7fcc80..0000000
+++ /dev/null
@@ -1,90 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-#include <bfa.h>
-#include <defs/bfa_defs_pci.h>
-#include <cs/bfa_debug.h>
-#include <bfa_iocfc.h>
-
-/**
- * BFA module list terminated by NULL
- */
-struct bfa_module_s *hal_mods[] = {
-       &hal_mod_sgpg,
-       &hal_mod_fcport,
-       &hal_mod_fcxp,
-       &hal_mod_lps,
-       &hal_mod_uf,
-       &hal_mod_rport,
-       &hal_mod_fcpim,
-#ifdef BFA_CFG_PBIND
-       &hal_mod_pbind,
-#endif
-       NULL
-};
-
-/**
- * Message handlers for various modules.
- */
-bfa_isr_func_t  bfa_isrs[BFI_MC_MAX] = {
-       bfa_isr_unhandled,      /* NONE */
-       bfa_isr_unhandled,      /* BFI_MC_IOC */
-       bfa_isr_unhandled,      /* BFI_MC_DIAG */
-       bfa_isr_unhandled,      /* BFI_MC_FLASH */
-       bfa_isr_unhandled,      /* BFI_MC_CEE */
-       bfa_fcport_isr,         /* BFI_MC_FCPORT */
-       bfa_isr_unhandled,      /* BFI_MC_IOCFC */
-       bfa_isr_unhandled,      /* BFI_MC_LL */
-       bfa_uf_isr,             /* BFI_MC_UF */
-       bfa_fcxp_isr,           /* BFI_MC_FCXP */
-       bfa_lps_isr,            /* BFI_MC_LPS */
-       bfa_rport_isr,          /* BFI_MC_RPORT */
-       bfa_itnim_isr,          /* BFI_MC_ITNIM */
-       bfa_isr_unhandled,      /* BFI_MC_IOIM_READ */
-       bfa_isr_unhandled,      /* BFI_MC_IOIM_WRITE */
-       bfa_isr_unhandled,      /* BFI_MC_IOIM_IO */
-       bfa_ioim_isr,           /* BFI_MC_IOIM */
-       bfa_ioim_good_comp_isr, /* BFI_MC_IOIM_IOCOM */
-       bfa_tskim_isr,          /* BFI_MC_TSKIM */
-       bfa_isr_unhandled,      /* BFI_MC_SBOOT */
-       bfa_isr_unhandled,      /* BFI_MC_IPFC */
-       bfa_isr_unhandled,      /* BFI_MC_PORT */
-       bfa_isr_unhandled,      /* --------- */
-       bfa_isr_unhandled,      /* --------- */
-       bfa_isr_unhandled,      /* --------- */
-       bfa_isr_unhandled,      /* --------- */
-       bfa_isr_unhandled,      /* --------- */
-       bfa_isr_unhandled,      /* --------- */
-       bfa_isr_unhandled,      /* --------- */
-       bfa_isr_unhandled,      /* --------- */
-       bfa_isr_unhandled,      /* --------- */
-       bfa_isr_unhandled,      /* --------- */
-};
-
-/**
- * Message handlers for mailbox command classes
- */
-bfa_ioc_mbox_mcfunc_t  bfa_mbox_isrs[BFI_MC_MAX] = {
-       NULL,
-       NULL,                   /* BFI_MC_IOC   */
-       NULL,                   /* BFI_MC_DIAG  */
-       NULL,           /* BFI_MC_FLASH */
-       NULL,                   /* BFI_MC_CEE   */
-       NULL,                   /* BFI_MC_PORT  */
-       bfa_iocfc_isr,          /* BFI_MC_IOCFC */
-       NULL,
-};
-
diff --git a/drivers/scsi/bfa/bfa_modules.h b/drivers/scsi/bfa/bfa_modules.h
new file mode 100644 (file)
index 0000000..2cd5273
--- /dev/null
@@ -0,0 +1,130 @@
+/*
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
+ * All rights reserved
+ * www.brocade.com
+ *
+ * Linux driver for Brocade Fibre Channel Host Bus Adapter.
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License (GPL) Version 2 as
+ * published by the Free Software Foundation
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * General Public License for more details.
+ */
+
+/**
+ *  bfa_modules.h BFA modules
+ */
+
+#ifndef __BFA_MODULES_H__
+#define __BFA_MODULES_H__
+
+#include "bfa_cs.h"
+#include "bfa.h"
+#include "bfa_svc.h"
+#include "bfa_fcpim.h"
+#include "bfa_port.h"
+
+struct bfa_modules_s {
+       struct bfa_fcport_s     fcport;         /*  fc port module            */
+       struct bfa_fcxp_mod_s   fcxp_mod;       /*  fcxp module       */
+       struct bfa_lps_mod_s    lps_mod;        /*  fcxp module       */
+       struct bfa_uf_mod_s     uf_mod;         /*  unsolicited frame module */
+       struct bfa_rport_mod_s  rport_mod;      /*  remote port module        */
+       struct bfa_fcpim_mod_s  fcpim_mod;      /*  FCP initiator module     */
+       struct bfa_sgpg_mod_s   sgpg_mod;       /*  SG page module            */
+       struct bfa_port_s       port;           /*  Physical port module     */
+};
+
+/*
+ * !!! Only append to the enums defined here to avoid any versioning
+ * !!! needed between trace utility and driver version
+ */
+enum {
+       BFA_TRC_HAL_CORE        = 1,
+       BFA_TRC_HAL_FCXP        = 2,
+       BFA_TRC_HAL_FCPIM       = 3,
+       BFA_TRC_HAL_IOCFC_CT    = 4,
+       BFA_TRC_HAL_IOCFC_CB    = 5,
+};
+
+
+/**
+ * Macro to define a new BFA module
+ */
+#define BFA_MODULE(__mod)                                              \
+       static void bfa_ ## __mod ## _meminfo(                          \
+                       struct bfa_iocfc_cfg_s *cfg, u32 *ndm_len,      \
+                       u32 *dm_len);      \
+       static void bfa_ ## __mod ## _attach(struct bfa_s *bfa,         \
+                       void *bfad, struct bfa_iocfc_cfg_s *cfg,        \
+                       struct bfa_meminfo_s *meminfo,                  \
+                       struct bfa_pcidev_s *pcidev);      \
+       static void bfa_ ## __mod ## _detach(struct bfa_s *bfa);      \
+       static void bfa_ ## __mod ## _start(struct bfa_s *bfa);      \
+       static void bfa_ ## __mod ## _stop(struct bfa_s *bfa);      \
+       static void bfa_ ## __mod ## _iocdisable(struct bfa_s *bfa);      \
+                                                                       \
+       extern struct bfa_module_s hal_mod_ ## __mod;                   \
+       struct bfa_module_s hal_mod_ ## __mod = {                       \
+               bfa_ ## __mod ## _meminfo,                              \
+               bfa_ ## __mod ## _attach,                               \
+               bfa_ ## __mod ## _detach,                               \
+               bfa_ ## __mod ## _start,                                \
+               bfa_ ## __mod ## _stop,                                 \
+               bfa_ ## __mod ## _iocdisable,                           \
+       }
+
+#define BFA_CACHELINE_SZ       (256)
+
+/**
+ * Structure used to interact between different BFA sub modules
+ *
+ * Each sub module needs to implement only the entry points relevant to it (and
+ * can leave entry points as NULL)
+ */
+struct bfa_module_s {
+       void (*meminfo) (struct bfa_iocfc_cfg_s *cfg, u32 *km_len,
+                       u32 *dm_len);
+       void (*attach) (struct bfa_s *bfa, void *bfad,
+                       struct bfa_iocfc_cfg_s *cfg,
+                       struct bfa_meminfo_s *meminfo,
+                       struct bfa_pcidev_s *pcidev);
+       void (*detach) (struct bfa_s *bfa);
+       void (*start) (struct bfa_s *bfa);
+       void (*stop) (struct bfa_s *bfa);
+       void (*iocdisable) (struct bfa_s *bfa);
+};
+
+extern struct bfa_module_s *hal_mods[];
+
+struct bfa_s {
+       void                    *bfad;          /*  BFA driver instance    */
+       struct bfa_plog_s       *plog;          /*  portlog buffer          */
+       struct bfa_trc_mod_s    *trcmod;        /*  driver tracing          */
+       struct bfa_ioc_s        ioc;            /*  IOC module              */
+       struct bfa_iocfc_s      iocfc;          /*  IOCFC module            */
+       struct bfa_timer_mod_s  timer_mod;      /*  timer module            */
+       struct bfa_modules_s    modules;        /*  BFA modules     */
+       struct list_head        comp_q;         /*  pending completions     */
+       bfa_boolean_t           rme_process;    /*  RME processing enabled  */
+       struct list_head        reqq_waitq[BFI_IOC_MAX_CQS];
+       bfa_boolean_t           fcs;            /*  FCS is attached to BFA */
+       struct bfa_msix_s       msix;
+};
+
+extern bfa_isr_func_t bfa_isrs[BFI_MC_MAX];
+extern bfa_ioc_mbox_mcfunc_t  bfa_mbox_isrs[];
+extern bfa_boolean_t bfa_auto_recover;
+extern struct bfa_module_s hal_mod_sgpg;
+extern struct bfa_module_s hal_mod_fcport;
+extern struct bfa_module_s hal_mod_fcxp;
+extern struct bfa_module_s hal_mod_lps;
+extern struct bfa_module_s hal_mod_uf;
+extern struct bfa_module_s hal_mod_rport;
+extern struct bfa_module_s hal_mod_fcpim;
+
+#endif /* __BFA_MODULES_H__ */
diff --git a/drivers/scsi/bfa/bfa_modules_priv.h b/drivers/scsi/bfa/bfa_modules_priv.h
deleted file mode 100644 (file)
index f554c2f..0000000
+++ /dev/null
@@ -1,43 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_MODULES_PRIV_H__
-#define __BFA_MODULES_PRIV_H__
-
-#include "bfa_uf_priv.h"
-#include "bfa_port_priv.h"
-#include "bfa_rport_priv.h"
-#include "bfa_fcxp_priv.h"
-#include "bfa_lps_priv.h"
-#include "bfa_fcpim_priv.h"
-#include <cee/bfa_cee.h>
-#include <port/bfa_port.h>
-
-
-struct bfa_modules_s {
-       struct bfa_fcport_s     fcport; /*  fc port module      */
-       struct bfa_fcxp_mod_s fcxp_mod; /*  fcxp module         */
-       struct bfa_lps_mod_s lps_mod;   /*  fcxp module         */
-       struct bfa_uf_mod_s uf_mod;     /*  unsolicited frame module    */
-       struct bfa_rport_mod_s rport_mod; /*  remote port module        */
-       struct bfa_fcpim_mod_s fcpim_mod; /*  FCP initiator module      */
-       struct bfa_sgpg_mod_s sgpg_mod; /*  SG page module              */
-       struct bfa_cee_s cee;           /*  CEE Module                 */
-       struct bfa_port_s port;         /*  Physical port module        */
-};
-
-#endif /* __BFA_MODULES_PRIV_H__ */
index bd1cd3ee3022ad2a9b5f0ccb32bf7b82b1530941..788a250ffb8a01b05a6701cab2ecd1e3308016f7 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
  * All rights reserved
  * www.brocade.com
  *
 #ifndef __BFA_OS_INC_H__
 #define __BFA_OS_INC_H__
 
-#ifndef __KERNEL__
-#include <stdint.h>
-#else
 #include <linux/types.h>
-
 #include <linux/version.h>
 #include <linux/pci.h>
-
 #include <linux/dma-mapping.h>
-#define SET_MODULE_VERSION(VER)
-
 #include <linux/idr.h>
-
 #include <linux/interrupt.h>
 #include <linux/cdev.h>
 #include <linux/fs.h>
 #include <linux/delay.h>
 #include <linux/vmalloc.h>
-
 #include <linux/workqueue.h>
-
+#include <linux/bitops.h>
 #include <scsi/scsi.h>
 #include <scsi/scsi_host.h>
-
 #include <scsi/scsi_tcq.h>
 #include <scsi/scsi_transport_fc.h>
 #include <scsi/scsi_transport.h>
 #define __BIGENDIAN
 #endif
 
-#define BFA_ERR                        KERN_ERR
-#define BFA_WARNING            KERN_WARNING
-#define BFA_NOTICE             KERN_NOTICE
-#define BFA_INFO               KERN_INFO
-#define BFA_DEBUG              KERN_DEBUG
-
-#define LOG_BFAD_INIT          0x00000001
-#define LOG_FCP_IO             0x00000002
-
-#ifdef DEBUG
-#define BFA_LOG_TRACE(bfad, level, mask, fmt, arg...)                  \
-               BFA_LOG(bfad, level, mask, fmt, ## arg)
-#define BFA_DEV_TRACE(bfad, level, fmt, arg...)                                \
-               BFA_DEV_PRINTF(bfad, level, fmt, ## arg)
-#define BFA_TRACE(level, fmt, arg...)                                  \
-               BFA_PRINTF(level, fmt, ## arg)
-#else
-#define BFA_LOG_TRACE(bfad, level, mask, fmt, arg...)
-#define BFA_DEV_TRACE(bfad, level, fmt, arg...)
-#define BFA_TRACE(level, fmt, arg...)
-#endif
+static inline u64 bfa_os_get_clock(void)
+{
+       return jiffies;
+}
+
+static inline u64 bfa_os_get_log_time(void)
+{
+       u64 system_time = 0;
+       struct timeval tv;
+       do_gettimeofday(&tv);
+
+       /* We are interested in seconds only. */
+       system_time = tv.tv_sec;
+       return system_time;
+}
+
+#define bfa_io_lat_clock_res_div HZ
+#define bfa_io_lat_clock_res_mul 1000
 
 #define BFA_ASSERT(p) do {                                             \
        if (!(p)) {      \
                printk(KERN_ERR "assert(%s) failed at %s:%d\n",         \
                #p, __FILE__, __LINE__);      \
-               BUG();      \
        }                                                               \
 } while (0)
 
-
-#define BFA_LOG(bfad, level, mask, fmt, arg...)                                \
-do {                                                                   \
-       if (((mask) & (((struct bfad_s *)(bfad))->                      \
-               cfg_data[cfg_log_mask])) || (level[1] <= '3'))          \
-               dev_printk(level, &(((struct bfad_s *)                  \
-                       (bfad))->pcidev->dev), fmt, ##arg);      \
+#define BFA_LOG(level, bfad, mask, fmt, arg...)                                \
+do {                                                                   \
+       if (((mask) == 4) || (level[1] <= '4'))                         \
+               dev_printk(level, &((bfad)->pcidev)->dev, fmt, ##arg);  \
 } while (0)
 
-#ifndef BFA_DEV_PRINTF
-#define BFA_DEV_PRINTF(bfad, level, fmt, arg...)                       \
-               dev_printk(level, &(((struct bfad_s *)                  \
-                       (bfad))->pcidev->dev), fmt, ##arg);
-#endif
-
-#define BFA_PRINTF(level, fmt, arg...)                                 \
-               printk(level fmt, ##arg);
-
-int bfa_os_MWB(void *);
-
-#define bfa_os_mmiowb()                mmiowb()
-
 #define bfa_swap_3b(_x)                                \
        ((((_x) & 0xff) << 16) |                \
        ((_x) & 0x00ff00) |                     \
        (((_x) & 0xff0000) >> 16))
 
-#define bfa_swap_8b(_x)                                \
-     ((((_x) & 0xff00000000000000ull) >> 56)           \
-      | (((_x) & 0x00ff000000000000ull) >> 40)         \
-      | (((_x) & 0x0000ff0000000000ull) >> 24)         \
-      | (((_x) & 0x000000ff00000000ull) >> 8)          \
-      | (((_x) & 0x00000000ff000000ull) << 8)          \
-      | (((_x) & 0x0000000000ff0000ull) << 24)         \
-      | (((_x) & 0x000000000000ff00ull) << 40)         \
-      | (((_x) & 0x00000000000000ffull) << 56))
-
-#define bfa_os_swap32(_x)                      \
-       ((((_x) & 0xff) << 24)          |       \
+#define bfa_swap_8b(_x)                                        \
+       ((((_x) & 0xff00000000000000ull) >> 56)         \
+        | (((_x) & 0x00ff000000000000ull) >> 40)       \
+        | (((_x) & 0x0000ff0000000000ull) >> 24)       \
+        | (((_x) & 0x000000ff00000000ull) >> 8)        \
+        | (((_x) & 0x00000000ff000000ull) << 8)        \
+        | (((_x) & 0x0000000000ff0000ull) << 24)       \
+        | (((_x) & 0x000000000000ff00ull) << 40)       \
+        | (((_x) & 0x00000000000000ffull) << 56))
+
+#define bfa_os_swap32(_x)                      \
+       ((((_x) & 0xff) << 24)          |       \
        (((_x) & 0x0000ff00) << 8)      |       \
        (((_x) & 0x00ff0000) >> 8)      |       \
        (((_x) & 0xff000000) >> 24))
 
-#define bfa_os_swap_sgaddr(_x) ((u64)(                                 \
-       (((u64)(_x) & (u64)0x00000000000000ffull) << 32)        |       \
-       (((u64)(_x) & (u64)0x000000000000ff00ull) << 32)        |       \
-       (((u64)(_x) & (u64)0x0000000000ff0000ull) << 32)        |       \
-       (((u64)(_x) & (u64)0x00000000ff000000ull) << 32)        |       \
-       (((u64)(_x) & (u64)0x000000ff00000000ull) >> 32)        |       \
-       (((u64)(_x) & (u64)0x0000ff0000000000ull) >> 32)        |       \
-       (((u64)(_x) & (u64)0x00ff000000000000ull) >> 32)        |       \
+#define bfa_os_swap_sgaddr(_x)  ((u64)(                                 \
+       (((u64)(_x) & (u64)0x00000000000000ffull) << 32)        |       \
+       (((u64)(_x) & (u64)0x000000000000ff00ull) << 32)        |       \
+       (((u64)(_x) & (u64)0x0000000000ff0000ull) << 32)        |       \
+       (((u64)(_x) & (u64)0x00000000ff000000ull) << 32)        |       \
+       (((u64)(_x) & (u64)0x000000ff00000000ull) >> 32)        |       \
+       (((u64)(_x) & (u64)0x0000ff0000000000ull) >> 32)        |       \
+       (((u64)(_x) & (u64)0x00ff000000000000ull) >> 32)        |       \
        (((u64)(_x) & (u64)0xff00000000000000ull) >> 32)))
 
 #ifndef __BIGENDIAN
 #define bfa_os_htons(_x) ((u16)((((_x) & 0xff00) >> 8) | \
                                 (((_x) & 0x00ff) << 8)))
-
 #define bfa_os_htonl(_x)       bfa_os_swap32(_x)
 #define bfa_os_htonll(_x)      bfa_swap_8b(_x)
 #define bfa_os_hton3b(_x)      bfa_swap_3b(_x)
-
 #define bfa_os_wtole(_x)   (_x)
 #define bfa_os_sgaddr(_x)  (_x)
 
@@ -170,17 +138,16 @@ int bfa_os_MWB(void *);
 #define bfa_os_memcpy  memcpy
 #define bfa_os_udelay  udelay
 #define bfa_os_vsprintf vsprintf
+#define bfa_os_snprintf snprintf
 
 #define bfa_os_assign(__t, __s) __t = __s
-
-#define bfa_os_addr_t char __iomem *
-#define bfa_os_panic()
+#define bfa_os_addr_t void __iomem *
 
 #define bfa_os_reg_read(_raddr) readl(_raddr)
 #define bfa_os_reg_write(_raddr, _val) writel((_val), (_raddr))
-#define bfa_os_mem_read(_raddr, _off)                                   \
+#define bfa_os_mem_read(_raddr, _off)                                  \
        bfa_os_swap32(readl(((_raddr) + (_off))))
-#define bfa_os_mem_write(_raddr, _off, _val)                            \
+#define bfa_os_mem_write(_raddr, _off, _val)                           \
        writel(bfa_os_swap32((_val)), ((_raddr) + (_off)))
 
 #define BFA_TRC_TS(_trcm)                                              \
@@ -191,11 +158,6 @@ int bfa_os_MWB(void *);
                                (tv.tv_sec*1000000+tv.tv_usec);      \
                         })
 
-struct bfa_log_mod_s;
-void bfa_os_printf(struct bfa_log_mod_s *log_mod, u32 msg_id,
-                       const char *fmt, ...);
-#endif
-
 #define boolean_t int
 
 /**
@@ -206,7 +168,15 @@ struct bfa_timeval_s {
        u32     tv_usec;        /*  microseconds   */
 };
 
-void bfa_os_gettimeofday(struct bfa_timeval_s *tv);
+static inline void
+bfa_os_gettimeofday(struct bfa_timeval_s *tv)
+{
+       struct timeval  tmp_tv;
+
+       do_gettimeofday(&tmp_tv);
+       tv->tv_sec = (u32) tmp_tv.tv_sec;
+       tv->tv_usec = (u32) tmp_tv.tv_usec;
+}
 
 static inline void
 wwn2str(char *wwn_str, u64 wwn)
diff --git a/drivers/scsi/bfa/bfa_plog.h b/drivers/scsi/bfa/bfa_plog.h
new file mode 100644 (file)
index 0000000..501f0ed
--- /dev/null
@@ -0,0 +1,159 @@
+/*
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
+ * All rights reserved
+ * www.brocade.com
+ *
+ * Linux driver for Brocade Fibre Channel Host Bus Adapter.
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License (GPL) Version 2 as
+ * published by the Free Software Foundation
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * General Public License for more details.
+ */
+#ifndef __BFA_PORTLOG_H__
+#define __BFA_PORTLOG_H__
+
+#include "bfa_fc.h"
+#include "bfa_defs.h"
+
+#define BFA_PL_NLOG_ENTS 256
+#define BFA_PL_LOG_REC_INCR(_x) ((_x)++, (_x) %= BFA_PL_NLOG_ENTS)
+
+#define BFA_PL_STRING_LOG_SZ   32   /* number of chars in string log */
+#define BFA_PL_INT_LOG_SZ      8    /* number of integers in the integer log */
+
+enum bfa_plog_log_type {
+       BFA_PL_LOG_TYPE_INVALID = 0,
+       BFA_PL_LOG_TYPE_INT     = 1,
+       BFA_PL_LOG_TYPE_STRING  = 2,
+};
+
+/*
+ * the (fixed size) record format for each entry in the portlog
+ */
+struct bfa_plog_rec_s {
+       u64     tv;     /* timestamp */
+       u8       port;  /* Source port that logged this entry */
+       u8       mid;   /* module id */
+       u8       eid;   /* indicates Rx, Tx, IOCTL, etc.  bfa_plog_eid */
+       u8       log_type; /* string/integer log, bfa_plog_log_type_t */
+       u8       log_num_ints;
+       /*
+        * interpreted only if log_type is INT_LOG. indicates number of
+        * integers in the int_log[] (0-PL_INT_LOG_SZ).
+        */
+       u8       rsvd;
+       u16     misc;   /* can be used to indicate fc frame length */
+       union {
+               char        string_log[BFA_PL_STRING_LOG_SZ];
+               u32     int_log[BFA_PL_INT_LOG_SZ];
+       } log_entry;
+
+};
+
+/*
+ * the following #defines will be used by the logging entities to indicate
+ * their module id. BFAL will convert the integer value to string format
+ *
+* process to be used while changing the following #defines:
+ *  - Always add new entries at the end
+ *  - define corresponding string in BFAL
+ *  - Do not remove any entry or rearrange the order.
+ */
+enum bfa_plog_mid {
+       BFA_PL_MID_INVALID      = 0,
+       BFA_PL_MID_DEBUG        = 1,
+       BFA_PL_MID_DRVR         = 2,
+       BFA_PL_MID_HAL          = 3,
+       BFA_PL_MID_HAL_FCXP     = 4,
+       BFA_PL_MID_HAL_UF       = 5,
+       BFA_PL_MID_FCS          = 6,
+       BFA_PL_MID_LPS          = 7,
+       BFA_PL_MID_MAX          = 8
+};
+
+#define BFA_PL_MID_STRLEN    8
+struct bfa_plog_mid_strings_s {
+       char        m_str[BFA_PL_MID_STRLEN];
+};
+
+/*
+ * the following #defines will be used by the logging entities to indicate
+ * their event type. BFAL will convert the integer value to string format
+ *
+* process to be used while changing the following #defines:
+ *  - Always add new entries at the end
+ *  - define corresponding string in BFAL
+ *  - Do not remove any entry or rearrange the order.
+ */
+enum bfa_plog_eid {
+       BFA_PL_EID_INVALID              = 0,
+       BFA_PL_EID_IOC_DISABLE          = 1,
+       BFA_PL_EID_IOC_ENABLE           = 2,
+       BFA_PL_EID_PORT_DISABLE         = 3,
+       BFA_PL_EID_PORT_ENABLE          = 4,
+       BFA_PL_EID_PORT_ST_CHANGE       = 5,
+       BFA_PL_EID_TX                   = 6,
+       BFA_PL_EID_TX_ACK1              = 7,
+       BFA_PL_EID_TX_RJT               = 8,
+       BFA_PL_EID_TX_BSY               = 9,
+       BFA_PL_EID_RX                   = 10,
+       BFA_PL_EID_RX_ACK1              = 11,
+       BFA_PL_EID_RX_RJT               = 12,
+       BFA_PL_EID_RX_BSY               = 13,
+       BFA_PL_EID_CT_IN                = 14,
+       BFA_PL_EID_CT_OUT               = 15,
+       BFA_PL_EID_DRIVER_START         = 16,
+       BFA_PL_EID_RSCN                 = 17,
+       BFA_PL_EID_DEBUG                = 18,
+       BFA_PL_EID_MISC                 = 19,
+       BFA_PL_EID_FIP_FCF_DISC         = 20,
+       BFA_PL_EID_FIP_FCF_CVL          = 21,
+       BFA_PL_EID_LOGIN                = 22,
+       BFA_PL_EID_LOGO                 = 23,
+       BFA_PL_EID_TRUNK_SCN            = 24,
+       BFA_PL_EID_MAX
+};
+
+#define BFA_PL_ENAME_STRLEN    8
+struct bfa_plog_eid_strings_s {
+       char        e_str[BFA_PL_ENAME_STRLEN];
+};
+
+#define BFA_PL_SIG_LEN 8
+#define BFA_PL_SIG_STR  "12pl123"
+
+/*
+ * per port circular log buffer
+ */
+struct bfa_plog_s {
+       char        plog_sig[BFA_PL_SIG_LEN];   /* Start signature */
+       u8       plog_enabled;
+       u8       rsvd[7];
+       u32     ticks;
+       u16     head;
+       u16     tail;
+       struct bfa_plog_rec_s  plog_recs[BFA_PL_NLOG_ENTS];
+};
+
+void bfa_plog_init(struct bfa_plog_s *plog);
+void bfa_plog_str(struct bfa_plog_s *plog, enum bfa_plog_mid mid,
+                       enum bfa_plog_eid event, u16 misc, char *log_str);
+void bfa_plog_intarr(struct bfa_plog_s *plog, enum bfa_plog_mid mid,
+                       enum bfa_plog_eid event, u16 misc,
+                       u32 *intarr, u32 num_ints);
+void bfa_plog_fchdr(struct bfa_plog_s *plog, enum bfa_plog_mid mid,
+               enum bfa_plog_eid event, u16 misc, struct fchs_s *fchdr);
+void bfa_plog_fchdr_and_pl(struct bfa_plog_s *plog, enum bfa_plog_mid mid,
+                       enum bfa_plog_eid event, u16 misc,
+                       struct fchs_s *fchdr, u32 pld_w0);
+void bfa_plog_clear(struct bfa_plog_s *plog);
+void bfa_plog_enable(struct bfa_plog_s *plog);
+void bfa_plog_disable(struct bfa_plog_s *plog);
+bfa_boolean_t  bfa_plog_get_setting(struct bfa_plog_s *plog);
+
+#endif /* __BFA_PORTLOG_H__ */
index c7e69f1e56e3e11649a310fb50ef39e4411a057c..b6d170a13bea4f88c8ebbc78d4c63a523b4781b8 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
  * All rights reserved
  * www.brocade.com
  *
  * General Public License for more details.
  */
 
-#include <defs/bfa_defs_port.h>
-#include <cs/bfa_trc.h>
-#include <cs/bfa_log.h>
-#include <cs/bfa_debug.h>
-#include <port/bfa_port.h>
-#include <bfi/bfi.h>
-#include <bfi/bfi_port.h>
-#include <bfa_ioc.h>
-#include <cna/bfa_cna_trcmod.h>
+#include "bfa_defs_svc.h"
+#include "bfa_port.h"
+#include "bfi.h"
+#include "bfa_ioc.h"
+
 
 BFA_TRC_FILE(CNA, PORT);
 
 #define bfa_ioc_portid(__ioc) ((__ioc)->port_id)
-#define bfa_lpuid(__arg) bfa_ioc_portid(&(__arg)->ioc)
 
 static void
-bfa_port_stats_swap(struct bfa_port_s *port, union bfa_pport_stats_u *stats)
+bfa_port_stats_swap(struct bfa_port_s *port, union bfa_port_stats_u *stats)
 {
-       u32       *dip = (u32 *) stats;
-       u32        t0, t1;
-       int             i;
+       u32    *dip = (u32 *) stats;
+       u32    t0, t1;
+       int         i;
 
-       for (i = 0; i < sizeof(union bfa_pport_stats_u) / sizeof(u32);
-            i += 2) {
+       for (i = 0; i < sizeof(union bfa_port_stats_u)/sizeof(u32);
+               i += 2) {
                t0 = dip[i];
                t1 = dip[i + 1];
 #ifdef __BIGENDIAN
@@ -49,11 +44,6 @@ bfa_port_stats_swap(struct bfa_port_s *port, union bfa_pport_stats_u *stats)
                dip[i + 1] = bfa_os_ntohl(t0);
 #endif
        }
-
-    /** todo
-     * QoS stats r also swapped as 64bit; that structure also
-     * has to use 64 bit counters
-     */
 }
 
 /**
@@ -68,7 +58,9 @@ bfa_port_stats_swap(struct bfa_port_s *port, union bfa_pport_stats_u *stats)
 static void
 bfa_port_enable_isr(struct bfa_port_s *port, bfa_status_t status)
 {
-       bfa_assert(0);
+       bfa_trc(port, status);
+       port->endis_pending = BFA_FALSE;
+       port->endis_cbfn(port->endis_cbarg, status);
 }
 
 /**
@@ -83,7 +75,9 @@ bfa_port_enable_isr(struct bfa_port_s *port, bfa_status_t status)
 static void
 bfa_port_disable_isr(struct bfa_port_s *port, bfa_status_t status)
 {
-       bfa_assert(0);
+       bfa_trc(port, status);
+       port->endis_pending = BFA_FALSE;
+       port->endis_cbfn(port->endis_cbarg, status);
 }
 
 /**
@@ -105,7 +99,7 @@ bfa_port_get_stats_isr(struct bfa_port_s *port, bfa_status_t status)
                struct bfa_timeval_s tv;
 
                memcpy(port->stats, port->stats_dma.kva,
-                      sizeof(union bfa_pport_stats_u));
+                      sizeof(union bfa_port_stats_u));
                bfa_port_stats_swap(port, port->stats);
 
                bfa_os_gettimeofday(&tv);
@@ -133,11 +127,11 @@ bfa_port_clear_stats_isr(struct bfa_port_s *port, bfa_status_t status)
        struct bfa_timeval_s tv;
 
        port->stats_status = status;
-       port->stats_busy = BFA_FALSE;
+       port->stats_busy   = BFA_FALSE;
 
        /**
-        * re-initialize time stamp for stats reset
-        */
+       * re-initialize time stamp for stats reset
+       */
        bfa_os_gettimeofday(&tv);
        port->stats_reset_time = tv.tv_sec;
 
@@ -158,10 +152,10 @@ bfa_port_clear_stats_isr(struct bfa_port_s *port, bfa_status_t status)
 static void
 bfa_port_isr(void *cbarg, struct bfi_mbmsg_s *m)
 {
-       struct bfa_port_s *port = (struct bfa_port_s *)cbarg;
+       struct bfa_port_s *port = (struct bfa_port_s *) cbarg;
        union bfi_port_i2h_msg_u *i2hmsg;
 
-       i2hmsg = (union bfi_port_i2h_msg_u *)m;
+       i2hmsg = (union bfi_port_i2h_msg_u *) m;
        bfa_trc(port, m->mh.msg_id);
 
        switch (m->mh.msg_id) {
@@ -178,9 +172,7 @@ bfa_port_isr(void *cbarg, struct bfi_mbmsg_s *m)
                break;
 
        case BFI_PORT_I2H_GET_STATS_RSP:
-               /*
-                * Stats busy flag is still set? (may be cmd timed out)
-                */
+               /* Stats busy flag is still set? (may be cmd timed out) */
                if (port->stats_busy == BFA_FALSE)
                        break;
                bfa_port_get_stats_isr(port, i2hmsg->getstats_rsp.status);
@@ -208,7 +200,7 @@ bfa_port_isr(void *cbarg, struct bfi_mbmsg_s *m)
 u32
 bfa_port_meminfo(void)
 {
-       return BFA_ROUNDUP(sizeof(union bfa_pport_stats_u), BFA_DMA_ALIGN_SZ);
+       return BFA_ROUNDUP(sizeof(union bfa_port_stats_u), BFA_DMA_ALIGN_SZ);
 }
 
 /**
@@ -216,8 +208,8 @@ bfa_port_meminfo(void)
  *
  *
  * @param[in] port Port module pointer
- *           dma_kva Kernel Virtual Address of Port DMA Memory
- *           dma_pa  Physical Address of Port DMA Memory
+ *           dma_kva Kernel Virtual Address of Port DMA Memory
+ *           dma_pa  Physical Address of Port DMA Memory
  *
  * @return void
  */
@@ -225,7 +217,7 @@ void
 bfa_port_mem_claim(struct bfa_port_s *port, u8 *dma_kva, u64 dma_pa)
 {
        port->stats_dma.kva = dma_kva;
-       port->stats_dma.pa = dma_pa;
+       port->stats_dma.pa  = dma_pa;
 }
 
 /**
@@ -239,12 +231,14 @@ bfa_port_mem_claim(struct bfa_port_s *port, u8 *dma_kva, u64 dma_pa)
  */
 bfa_status_t
 bfa_port_enable(struct bfa_port_s *port, bfa_port_endis_cbfn_t cbfn,
-               void *cbarg)
+                void *cbarg)
 {
        struct bfi_port_generic_req_s *m;
 
-       /** todo Not implemented */
-       bfa_assert(0);
+       if (bfa_ioc_is_disabled(port->ioc)) {
+               bfa_trc(port, BFA_STATUS_IOC_DISABLED);
+               return BFA_STATUS_IOC_DISABLED;
+       }
 
        if (!bfa_ioc_is_operational(port->ioc)) {
                bfa_trc(port, BFA_STATUS_IOC_FAILURE);
@@ -256,11 +250,11 @@ bfa_port_enable(struct bfa_port_s *port, bfa_port_endis_cbfn_t cbfn,
                return BFA_STATUS_DEVBUSY;
        }
 
-       m = (struct bfi_port_generic_req_s *)port->endis_mb.msg;
+       m = (struct bfi_port_generic_req_s *) port->endis_mb.msg;
 
        port->msgtag++;
-       port->endis_cbfn = cbfn;
-       port->endis_cbarg = cbarg;
+       port->endis_cbfn    = cbfn;
+       port->endis_cbarg   = cbarg;
        port->endis_pending = BFA_TRUE;
 
        bfi_h2i_set(m->mh, BFI_MC_PORT, BFI_PORT_H2I_ENABLE_REQ,
@@ -281,12 +275,14 @@ bfa_port_enable(struct bfa_port_s *port, bfa_port_endis_cbfn_t cbfn,
  */
 bfa_status_t
 bfa_port_disable(struct bfa_port_s *port, bfa_port_endis_cbfn_t cbfn,
-                void *cbarg)
+                 void *cbarg)
 {
        struct bfi_port_generic_req_s *m;
 
-       /** todo Not implemented */
-       bfa_assert(0);
+       if (bfa_ioc_is_disabled(port->ioc)) {
+               bfa_trc(port, BFA_STATUS_IOC_DISABLED);
+               return BFA_STATUS_IOC_DISABLED;
+       }
 
        if (!bfa_ioc_is_operational(port->ioc)) {
                bfa_trc(port, BFA_STATUS_IOC_FAILURE);
@@ -298,11 +294,11 @@ bfa_port_disable(struct bfa_port_s *port, bfa_port_endis_cbfn_t cbfn,
                return BFA_STATUS_DEVBUSY;
        }
 
-       m = (struct bfi_port_generic_req_s *)port->endis_mb.msg;
+       m = (struct bfi_port_generic_req_s *) port->endis_mb.msg;
 
        port->msgtag++;
-       port->endis_cbfn = cbfn;
-       port->endis_cbarg = cbarg;
+       port->endis_cbfn    = cbfn;
+       port->endis_cbarg   = cbarg;
        port->endis_pending = BFA_TRUE;
 
        bfi_h2i_set(m->mh, BFI_MC_PORT, BFI_PORT_H2I_DISABLE_REQ,
@@ -322,8 +318,8 @@ bfa_port_disable(struct bfa_port_s *port, bfa_port_endis_cbfn_t cbfn,
  * @return Status
  */
 bfa_status_t
-bfa_port_get_stats(struct bfa_port_s *port, union bfa_pport_stats_u *stats,
-                  bfa_port_stats_cbfn_t cbfn, void *cbarg)
+bfa_port_get_stats(struct bfa_port_s *port, union bfa_port_stats_u *stats,
+                   bfa_port_stats_cbfn_t cbfn, void *cbarg)
 {
        struct bfi_port_get_stats_req_s *m;
 
@@ -337,12 +333,12 @@ bfa_port_get_stats(struct bfa_port_s *port, union bfa_pport_stats_u *stats,
                return BFA_STATUS_DEVBUSY;
        }
 
-       m = (struct bfi_port_get_stats_req_s *)port->stats_mb.msg;
+       m = (struct bfi_port_get_stats_req_s *) port->stats_mb.msg;
 
-       port->stats = stats;
-       port->stats_cbfn = cbfn;
+       port->stats       = stats;
+       port->stats_cbfn  = cbfn;
        port->stats_cbarg = cbarg;
-       port->stats_busy = BFA_TRUE;
+       port->stats_busy  = BFA_TRUE;
        bfa_dma_be_addr_set(m->dma_addr, port->stats_dma.pa);
 
        bfi_h2i_set(m->mh, BFI_MC_PORT, BFI_PORT_H2I_GET_STATS_REQ,
@@ -362,7 +358,7 @@ bfa_port_get_stats(struct bfa_port_s *port, union bfa_pport_stats_u *stats,
  */
 bfa_status_t
 bfa_port_clear_stats(struct bfa_port_s *port, bfa_port_stats_cbfn_t cbfn,
-                    void *cbarg)
+                     void *cbarg)
 {
        struct bfi_port_generic_req_s *m;
 
@@ -376,11 +372,11 @@ bfa_port_clear_stats(struct bfa_port_s *port, bfa_port_stats_cbfn_t cbfn,
                return BFA_STATUS_DEVBUSY;
        }
 
-       m = (struct bfi_port_generic_req_s *)port->stats_mb.msg;
+       m = (struct bfi_port_generic_req_s *) port->stats_mb.msg;
 
-       port->stats_cbfn = cbfn;
+       port->stats_cbfn  = cbfn;
        port->stats_cbarg = cbarg;
-       port->stats_busy = BFA_TRUE;
+       port->stats_busy  = BFA_TRUE;
 
        bfi_h2i_set(m->mh, BFI_MC_PORT, BFI_PORT_H2I_CLEAR_STATS_REQ,
                    bfa_ioc_portid(port->ioc));
@@ -400,11 +396,9 @@ bfa_port_clear_stats(struct bfa_port_s *port, bfa_port_stats_cbfn_t cbfn,
 void
 bfa_port_hbfail(void *arg)
 {
-       struct bfa_port_s *port = (struct bfa_port_s *)arg;
+       struct bfa_port_s *port = (struct bfa_port_s *) arg;
 
-       /*
-        * Fail any pending get_stats/clear_stats requests
-        */
+       /* Fail any pending get_stats/clear_stats requests */
        if (port->stats_busy) {
                if (port->stats_cbfn)
                        port->stats_cbfn(port->stats_cbarg, BFA_STATUS_FAILED);
@@ -412,9 +406,7 @@ bfa_port_hbfail(void *arg)
                port->stats_busy = BFA_FALSE;
        }
 
-       /*
-        * Clear any enable/disable is pending
-        */
+       /* Clear any enable/disable is pending */
        if (port->endis_pending) {
                if (port->endis_cbfn)
                        port->endis_cbfn(port->endis_cbarg, BFA_STATUS_FAILED);
@@ -433,22 +425,20 @@ bfa_port_hbfail(void *arg)
  *                   The device driver specific mbox ISR functions have
  *                   this pointer as one of the parameters.
  *            trcmod -
- *            logmod -
  *
  * @return void
  */
 void
-bfa_port_attach(struct bfa_port_s *port, struct bfa_ioc_s *ioc, void *dev,
-               struct bfa_trc_mod_s *trcmod, struct bfa_log_mod_s *logmod)
+bfa_port_attach(struct bfa_port_s *port, struct bfa_ioc_s *ioc,
+                void *dev, struct bfa_trc_mod_s *trcmod)
 {
        struct bfa_timeval_s tv;
 
        bfa_assert(port);
 
-       port->dev = dev;
-       port->ioc = ioc;
+       port->dev    = dev;
+       port->ioc    = ioc;
        port->trcmod = trcmod;
-       port->logmod = logmod;
 
        port->stats_busy = BFA_FALSE;
        port->endis_pending = BFA_FALSE;
diff --git a/drivers/scsi/bfa/bfa_port.h b/drivers/scsi/bfa/bfa_port.h
new file mode 100644 (file)
index 0000000..dbce9df
--- /dev/null
@@ -0,0 +1,66 @@
+/*
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
+ * All rights reserved
+ * www.brocade.com
+ *
+ * Linux driver for Brocade Fibre Channel Host Bus Adapter.
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License (GPL) Version 2 as
+ * published by the Free Software Foundation
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * General Public License for more details.
+ */
+
+#ifndef __BFA_PORT_H__
+#define __BFA_PORT_H__
+
+#include "bfa_defs_svc.h"
+#include "bfa_ioc.h"
+#include "bfa_cs.h"
+
+typedef void (*bfa_port_stats_cbfn_t) (void *dev, bfa_status_t status);
+typedef void (*bfa_port_endis_cbfn_t) (void *dev, bfa_status_t status);
+
+struct bfa_port_s {
+       void                            *dev;
+       struct bfa_ioc_s                *ioc;
+       struct bfa_trc_mod_s            *trcmod;
+       u32                     msgtag;
+       bfa_boolean_t                   stats_busy;
+       struct bfa_mbox_cmd_s           stats_mb;
+       bfa_port_stats_cbfn_t           stats_cbfn;
+       void                            *stats_cbarg;
+       bfa_status_t                    stats_status;
+       u32                     stats_reset_time;
+       union bfa_port_stats_u          *stats;
+       struct bfa_dma_s                stats_dma;
+       bfa_boolean_t                   endis_pending;
+       struct bfa_mbox_cmd_s           endis_mb;
+       bfa_port_endis_cbfn_t           endis_cbfn;
+       void                            *endis_cbarg;
+       bfa_status_t                    endis_status;
+       struct bfa_ioc_hbfail_notify_s  hbfail;
+};
+
+void        bfa_port_attach(struct bfa_port_s *port, struct bfa_ioc_s *ioc,
+                               void *dev, struct bfa_trc_mod_s *trcmod);
+void        bfa_port_detach(struct bfa_port_s *port);
+void        bfa_port_hbfail(void *arg);
+
+bfa_status_t bfa_port_get_stats(struct bfa_port_s *port,
+                                union bfa_port_stats_u *stats,
+                                bfa_port_stats_cbfn_t cbfn, void *cbarg);
+bfa_status_t bfa_port_clear_stats(struct bfa_port_s *port,
+                                  bfa_port_stats_cbfn_t cbfn, void *cbarg);
+bfa_status_t bfa_port_enable(struct bfa_port_s *port,
+                             bfa_port_endis_cbfn_t cbfn, void *cbarg);
+bfa_status_t bfa_port_disable(struct bfa_port_s *port,
+                              bfa_port_endis_cbfn_t cbfn, void *cbarg);
+u32     bfa_port_meminfo(void);
+void        bfa_port_mem_claim(struct bfa_port_s *port,
+                                u8 *dma_kva, u64 dma_pa);
+#endif /* __BFA_PORT_H__ */
diff --git a/drivers/scsi/bfa/bfa_port_priv.h b/drivers/scsi/bfa/bfa_port_priv.h
deleted file mode 100644 (file)
index c9ebe04..0000000
+++ /dev/null
@@ -1,94 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_PORT_PRIV_H__
-#define __BFA_PORT_PRIV_H__
-
-#include <defs/bfa_defs_pport.h>
-#include <bfi/bfi_pport.h>
-#include "bfa_intr_priv.h"
-
-/**
- * Link notification data structure
- */
-struct bfa_fcport_ln_s {
-       struct bfa_fcport_s     *fcport;
-       bfa_sm_t                sm;
-       struct bfa_cb_qe_s      ln_qe;  /*  BFA callback queue elem for ln */
-       enum bfa_pport_linkstate ln_event; /*  ln event for callback */
-};
-
-/**
- * BFA FC port data structure
- */
-struct bfa_fcport_s {
-       struct bfa_s            *bfa;   /*  parent BFA instance */
-       bfa_sm_t                sm;     /*  port state machine */
-       wwn_t                   nwwn;   /*  node wwn of physical port */
-       wwn_t                   pwwn;   /*  port wwn of physical oprt */
-       enum bfa_pport_speed speed_sup;
-                                       /*  supported speeds */
-       enum bfa_pport_speed speed;     /*  current speed */
-       enum bfa_pport_topology topology;       /*  current topology */
-       u8                      myalpa; /*  my ALPA in LOOP topology */
-       u8                      rsvd[3];
-       u32             mypid:24;
-       u32             rsvd_b:8;
-       struct bfa_pport_cfg_s  cfg;    /*  current port configuration */
-       struct bfa_qos_attr_s  qos_attr;   /* QoS Attributes */
-       struct bfa_qos_vc_attr_s qos_vc_attr;  /*  VC info from ELP */
-       struct bfa_reqq_wait_s  reqq_wait;
-                                       /*  to wait for room in reqq */
-       struct bfa_reqq_wait_s  svcreq_wait;
-                                       /*  to wait for room in reqq */
-       struct bfa_reqq_wait_s  stats_reqq_wait;
-                                       /*  to wait for room in reqq (stats) */
-       void                    *event_cbarg;
-       void                    (*event_cbfn) (void *cbarg,
-                                               bfa_pport_event_t event);
-       union {
-               union bfi_fcport_i2h_msg_u i2hmsg;
-       } event_arg;
-       void                    *bfad;  /*  BFA driver handle */
-       struct bfa_fcport_ln_s   ln; /* Link Notification */
-       struct bfa_cb_qe_s              hcb_qe; /*  BFA callback queue elem */
-       struct bfa_timer_s      timer;  /*  timer */
-       u32             msgtag; /*  fimrware msg tag for reply */
-       u8                      *stats_kva;
-       u64             stats_pa;
-       union bfa_fcport_stats_u *stats;
-       union bfa_fcport_stats_u *stats_ret; /*  driver stats location */
-       bfa_status_t            stats_status; /*  stats/statsclr status */
-       bfa_boolean_t           stats_busy; /*  outstanding stats/statsclr */
-       bfa_boolean_t           stats_qfull;
-       u32                     stats_reset_time; /* stats reset time stamp */
-       bfa_cb_pport_t          stats_cbfn; /*  driver callback function */
-       void                    *stats_cbarg; /* user callback arg */
-       bfa_boolean_t           diag_busy; /*  diag busy status */
-       bfa_boolean_t           beacon; /*  port beacon status */
-       bfa_boolean_t           link_e2e_beacon; /*  link beacon status */
-};
-
-#define BFA_FCPORT_MOD(__bfa)  (&(__bfa)->modules.fcport)
-
-/*
- * public functions
- */
-void bfa_fcport_init(struct bfa_s *bfa);
-void bfa_fcport_isr(struct bfa_s *bfa, struct bfi_msg_s *msg);
-
-#endif /* __BFA_PORT_PRIV_H__ */
diff --git a/drivers/scsi/bfa/bfa_priv.h b/drivers/scsi/bfa/bfa_priv.h
deleted file mode 100644 (file)
index bf4939b..0000000
+++ /dev/null
@@ -1,110 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_PRIV_H__
-#define __BFA_PRIV_H__
-
-#include "bfa_iocfc.h"
-#include "bfa_intr_priv.h"
-#include "bfa_trcmod_priv.h"
-#include "bfa_modules_priv.h"
-#include "bfa_fwimg_priv.h"
-#include <cs/bfa_log.h>
-#include <bfa_timer.h>
-
-/**
- * Macro to define a new BFA module
- */
-#define BFA_MODULE(__mod)                                              \
-       static void bfa_ ## __mod ## _meminfo(                          \
-                       struct bfa_iocfc_cfg_s *cfg, u32 *ndm_len,      \
-                       u32 *dm_len);      \
-       static void bfa_ ## __mod ## _attach(struct bfa_s *bfa,         \
-                       void *bfad, struct bfa_iocfc_cfg_s *cfg,        \
-                       struct bfa_meminfo_s *meminfo,                  \
-                       struct bfa_pcidev_s *pcidev);      \
-       static void bfa_ ## __mod ## _detach(struct bfa_s *bfa);      \
-       static void bfa_ ## __mod ## _start(struct bfa_s *bfa);      \
-       static void bfa_ ## __mod ## _stop(struct bfa_s *bfa);      \
-       static void bfa_ ## __mod ## _iocdisable(struct bfa_s *bfa);      \
-                                                                       \
-       extern struct bfa_module_s hal_mod_ ## __mod;                   \
-       struct bfa_module_s hal_mod_ ## __mod = {                       \
-               bfa_ ## __mod ## _meminfo,                              \
-               bfa_ ## __mod ## _attach,                               \
-               bfa_ ## __mod ## _detach,                               \
-               bfa_ ## __mod ## _start,                                \
-               bfa_ ## __mod ## _stop,                                 \
-               bfa_ ## __mod ## _iocdisable,                           \
-       }
-
-#define BFA_CACHELINE_SZ       (256)
-
-/**
- * Structure used to interact between different BFA sub modules
- *
- * Each sub module needs to implement only the entry points relevant to it (and
- * can leave entry points as NULL)
- */
-struct bfa_module_s {
-       void (*meminfo) (struct bfa_iocfc_cfg_s *cfg, u32 *km_len,
-                       u32 *dm_len);
-       void (*attach) (struct bfa_s *bfa, void *bfad,
-                       struct bfa_iocfc_cfg_s *cfg,
-                       struct bfa_meminfo_s *meminfo,
-                       struct bfa_pcidev_s *pcidev);
-       void (*detach) (struct bfa_s *bfa);
-       void (*start) (struct bfa_s *bfa);
-       void (*stop) (struct bfa_s *bfa);
-       void (*iocdisable) (struct bfa_s *bfa);
-};
-
-extern struct bfa_module_s *hal_mods[];
-
-struct bfa_s {
-       void                    *bfad;          /*  BFA driver instance    */
-       struct bfa_aen_s        *aen;           /*  AEN module              */
-       struct bfa_plog_s       *plog;          /*  portlog buffer          */
-       struct bfa_log_mod_s    *logm;          /*  driver logging modulen */
-       struct bfa_trc_mod_s    *trcmod;        /*  driver tracing          */
-       struct bfa_ioc_s        ioc;            /*  IOC module              */
-       struct bfa_iocfc_s      iocfc;          /*  IOCFC module            */
-       struct bfa_timer_mod_s  timer_mod;      /*  timer module            */
-       struct bfa_modules_s    modules;        /*  BFA modules     */
-       struct list_head        comp_q;         /*  pending completions    */
-       bfa_boolean_t           rme_process;    /*  RME processing enabled */
-       struct list_head                reqq_waitq[BFI_IOC_MAX_CQS];
-       bfa_boolean_t           fcs;            /*  FCS is attached to BFA */
-       struct bfa_msix_s       msix;
-};
-
-extern bfa_isr_func_t bfa_isrs[BFI_MC_MAX];
-extern bfa_ioc_mbox_mcfunc_t  bfa_mbox_isrs[];
-extern bfa_boolean_t bfa_auto_recover;
-extern struct bfa_module_s hal_mod_flash;
-extern struct bfa_module_s hal_mod_fcdiag;
-extern struct bfa_module_s hal_mod_sgpg;
-extern struct bfa_module_s hal_mod_fcport;
-extern struct bfa_module_s hal_mod_fcxp;
-extern struct bfa_module_s hal_mod_lps;
-extern struct bfa_module_s hal_mod_uf;
-extern struct bfa_module_s hal_mod_rport;
-extern struct bfa_module_s hal_mod_fcpim;
-extern struct bfa_module_s hal_mod_pbind;
-
-#endif /* __BFA_PRIV_H__ */
-
diff --git a/drivers/scsi/bfa/bfa_rport.c b/drivers/scsi/bfa/bfa_rport.c
deleted file mode 100644 (file)
index ccd0680..0000000
+++ /dev/null
@@ -1,906 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#include <bfa.h>
-#include <bfa_svc.h>
-#include <cs/bfa_debug.h>
-#include <bfi/bfi_rport.h>
-#include "bfa_intr_priv.h"
-
-BFA_TRC_FILE(HAL, RPORT);
-BFA_MODULE(rport);
-
-#define bfa_rport_offline_cb(__rp) do {                                \
-       if ((__rp)->bfa->fcs)                                           \
-               bfa_cb_rport_offline((__rp)->rport_drv);      \
-       else {                                                          \
-               bfa_cb_queue((__rp)->bfa, &(__rp)->hcb_qe,              \
-                               __bfa_cb_rport_offline, (__rp));      \
-       }                                                               \
-} while (0)
-
-#define bfa_rport_online_cb(__rp) do {                         \
-       if ((__rp)->bfa->fcs)                                           \
-               bfa_cb_rport_online((__rp)->rport_drv);      \
-       else {                                                          \
-               bfa_cb_queue((__rp)->bfa, &(__rp)->hcb_qe,              \
-                                 __bfa_cb_rport_online, (__rp));      \
-               }                                                       \
-} while (0)
-
-/*
- * forward declarations
- */
-static struct bfa_rport_s *bfa_rport_alloc(struct bfa_rport_mod_s *rp_mod);
-static void bfa_rport_free(struct bfa_rport_s *rport);
-static bfa_boolean_t bfa_rport_send_fwcreate(struct bfa_rport_s *rp);
-static bfa_boolean_t bfa_rport_send_fwdelete(struct bfa_rport_s *rp);
-static bfa_boolean_t bfa_rport_send_fwspeed(struct bfa_rport_s *rp);
-static void __bfa_cb_rport_online(void *cbarg, bfa_boolean_t complete);
-static void __bfa_cb_rport_offline(void *cbarg, bfa_boolean_t complete);
-
-/**
- *  bfa_rport_sm BFA rport state machine
- */
-
-
-enum bfa_rport_event {
-       BFA_RPORT_SM_CREATE     = 1,    /*  rport create event          */
-       BFA_RPORT_SM_DELETE     = 2,    /*  deleting an existing rport */
-       BFA_RPORT_SM_ONLINE     = 3,    /*  rport is online             */
-       BFA_RPORT_SM_OFFLINE    = 4,    /*  rport is offline            */
-       BFA_RPORT_SM_FWRSP      = 5,    /*  firmware response           */
-       BFA_RPORT_SM_HWFAIL     = 6,    /*  IOC h/w failure             */
-       BFA_RPORT_SM_QOS_SCN    = 7,    /*  QoS SCN from firmware       */
-       BFA_RPORT_SM_SET_SPEED  = 8,    /*  Set Rport Speed             */
-       BFA_RPORT_SM_QRESUME    = 9,    /*  space in requeue queue      */
-};
-
-static void    bfa_rport_sm_uninit(struct bfa_rport_s *rp,
-                                       enum bfa_rport_event event);
-static void    bfa_rport_sm_created(struct bfa_rport_s *rp,
-                                        enum bfa_rport_event event);
-static void    bfa_rport_sm_fwcreate(struct bfa_rport_s *rp,
-                                         enum bfa_rport_event event);
-static void    bfa_rport_sm_online(struct bfa_rport_s *rp,
-                                       enum bfa_rport_event event);
-static void    bfa_rport_sm_fwdelete(struct bfa_rport_s *rp,
-                                         enum bfa_rport_event event);
-static void    bfa_rport_sm_offline(struct bfa_rport_s *rp,
-                                        enum bfa_rport_event event);
-static void    bfa_rport_sm_deleting(struct bfa_rport_s *rp,
-                                         enum bfa_rport_event event);
-static void    bfa_rport_sm_offline_pending(struct bfa_rport_s *rp,
-                                         enum bfa_rport_event event);
-static void    bfa_rport_sm_delete_pending(struct bfa_rport_s *rp,
-                                         enum bfa_rport_event event);
-static void    bfa_rport_sm_iocdisable(struct bfa_rport_s *rp,
-                                           enum bfa_rport_event event);
-static void    bfa_rport_sm_fwcreate_qfull(struct bfa_rport_s *rp,
-                                         enum bfa_rport_event event);
-static void    bfa_rport_sm_fwdelete_qfull(struct bfa_rport_s *rp,
-                                         enum bfa_rport_event event);
-static void    bfa_rport_sm_deleting_qfull(struct bfa_rport_s *rp,
-                                         enum bfa_rport_event event);
-
-/**
- * Beginning state, only online event expected.
- */
-static void
-bfa_rport_sm_uninit(struct bfa_rport_s *rp, enum bfa_rport_event event)
-{
-       bfa_trc(rp->bfa, rp->rport_tag);
-       bfa_trc(rp->bfa, event);
-
-       switch (event) {
-       case BFA_RPORT_SM_CREATE:
-               bfa_stats(rp, sm_un_cr);
-               bfa_sm_set_state(rp, bfa_rport_sm_created);
-               break;
-
-       default:
-               bfa_stats(rp, sm_un_unexp);
-               bfa_sm_fault(rp->bfa, event);
-       }
-}
-
-static void
-bfa_rport_sm_created(struct bfa_rport_s *rp, enum bfa_rport_event event)
-{
-       bfa_trc(rp->bfa, rp->rport_tag);
-       bfa_trc(rp->bfa, event);
-
-       switch (event) {
-       case BFA_RPORT_SM_ONLINE:
-               bfa_stats(rp, sm_cr_on);
-               if (bfa_rport_send_fwcreate(rp))
-                       bfa_sm_set_state(rp, bfa_rport_sm_fwcreate);
-               else
-                       bfa_sm_set_state(rp, bfa_rport_sm_fwcreate_qfull);
-               break;
-
-       case BFA_RPORT_SM_DELETE:
-               bfa_stats(rp, sm_cr_del);
-               bfa_sm_set_state(rp, bfa_rport_sm_uninit);
-               bfa_rport_free(rp);
-               break;
-
-       case BFA_RPORT_SM_HWFAIL:
-               bfa_stats(rp, sm_cr_hwf);
-               bfa_sm_set_state(rp, bfa_rport_sm_iocdisable);
-               break;
-
-       default:
-               bfa_stats(rp, sm_cr_unexp);
-               bfa_sm_fault(rp->bfa, event);
-       }
-}
-
-/**
- * Waiting for rport create response from firmware.
- */
-static void
-bfa_rport_sm_fwcreate(struct bfa_rport_s *rp, enum bfa_rport_event event)
-{
-       bfa_trc(rp->bfa, rp->rport_tag);
-       bfa_trc(rp->bfa, event);
-
-       switch (event) {
-       case BFA_RPORT_SM_FWRSP:
-               bfa_stats(rp, sm_fwc_rsp);
-               bfa_sm_set_state(rp, bfa_rport_sm_online);
-               bfa_rport_online_cb(rp);
-               break;
-
-       case BFA_RPORT_SM_DELETE:
-               bfa_stats(rp, sm_fwc_del);
-               bfa_sm_set_state(rp, bfa_rport_sm_delete_pending);
-               break;
-
-       case BFA_RPORT_SM_OFFLINE:
-               bfa_stats(rp, sm_fwc_off);
-               bfa_sm_set_state(rp, bfa_rport_sm_offline_pending);
-               break;
-
-       case BFA_RPORT_SM_HWFAIL:
-               bfa_stats(rp, sm_fwc_hwf);
-               bfa_sm_set_state(rp, bfa_rport_sm_iocdisable);
-               break;
-
-       default:
-               bfa_stats(rp, sm_fwc_unexp);
-               bfa_sm_fault(rp->bfa, event);
-       }
-}
-
-/**
- * Request queue is full, awaiting queue resume to send create request.
- */
-static void
-bfa_rport_sm_fwcreate_qfull(struct bfa_rport_s *rp, enum bfa_rport_event event)
-{
-       bfa_trc(rp->bfa, rp->rport_tag);
-       bfa_trc(rp->bfa, event);
-
-       switch (event) {
-       case BFA_RPORT_SM_QRESUME:
-               bfa_sm_set_state(rp, bfa_rport_sm_fwcreate);
-               bfa_rport_send_fwcreate(rp);
-               break;
-
-       case BFA_RPORT_SM_DELETE:
-               bfa_stats(rp, sm_fwc_del);
-               bfa_sm_set_state(rp, bfa_rport_sm_uninit);
-               bfa_reqq_wcancel(&rp->reqq_wait);
-               bfa_rport_free(rp);
-               break;
-
-       case BFA_RPORT_SM_OFFLINE:
-               bfa_stats(rp, sm_fwc_off);
-               bfa_sm_set_state(rp, bfa_rport_sm_offline);
-               bfa_reqq_wcancel(&rp->reqq_wait);
-               bfa_rport_offline_cb(rp);
-               break;
-
-       case BFA_RPORT_SM_HWFAIL:
-               bfa_stats(rp, sm_fwc_hwf);
-               bfa_sm_set_state(rp, bfa_rport_sm_iocdisable);
-               bfa_reqq_wcancel(&rp->reqq_wait);
-               break;
-
-       default:
-               bfa_stats(rp, sm_fwc_unexp);
-               bfa_sm_fault(rp->bfa, event);
-       }
-}
-
-/**
- * Online state - normal parking state.
- */
-static void
-bfa_rport_sm_online(struct bfa_rport_s *rp, enum bfa_rport_event event)
-{
-       struct bfi_rport_qos_scn_s *qos_scn;
-
-       bfa_trc(rp->bfa, rp->rport_tag);
-       bfa_trc(rp->bfa, event);
-
-       switch (event) {
-       case BFA_RPORT_SM_OFFLINE:
-               bfa_stats(rp, sm_on_off);
-               if (bfa_rport_send_fwdelete(rp))
-                       bfa_sm_set_state(rp, bfa_rport_sm_fwdelete);
-               else
-                       bfa_sm_set_state(rp, bfa_rport_sm_fwdelete_qfull);
-               break;
-
-       case BFA_RPORT_SM_DELETE:
-               bfa_stats(rp, sm_on_del);
-               if (bfa_rport_send_fwdelete(rp))
-                       bfa_sm_set_state(rp, bfa_rport_sm_deleting);
-               else
-                       bfa_sm_set_state(rp, bfa_rport_sm_deleting_qfull);
-               break;
-
-       case BFA_RPORT_SM_HWFAIL:
-               bfa_stats(rp, sm_on_hwf);
-               bfa_sm_set_state(rp, bfa_rport_sm_iocdisable);
-               break;
-
-       case BFA_RPORT_SM_SET_SPEED:
-               bfa_rport_send_fwspeed(rp);
-               break;
-
-       case BFA_RPORT_SM_QOS_SCN:
-               qos_scn = (struct bfi_rport_qos_scn_s *) rp->event_arg.fw_msg;
-               rp->qos_attr = qos_scn->new_qos_attr;
-               bfa_trc(rp->bfa, qos_scn->old_qos_attr.qos_flow_id);
-               bfa_trc(rp->bfa, qos_scn->new_qos_attr.qos_flow_id);
-               bfa_trc(rp->bfa, qos_scn->old_qos_attr.qos_priority);
-               bfa_trc(rp->bfa, qos_scn->new_qos_attr.qos_priority);
-
-               qos_scn->old_qos_attr.qos_flow_id  =
-                       bfa_os_ntohl(qos_scn->old_qos_attr.qos_flow_id);
-               qos_scn->new_qos_attr.qos_flow_id  =
-                       bfa_os_ntohl(qos_scn->new_qos_attr.qos_flow_id);
-               qos_scn->old_qos_attr.qos_priority =
-                       bfa_os_ntohl(qos_scn->old_qos_attr.qos_priority);
-               qos_scn->new_qos_attr.qos_priority =
-                       bfa_os_ntohl(qos_scn->new_qos_attr.qos_priority);
-
-               if (qos_scn->old_qos_attr.qos_flow_id !=
-                       qos_scn->new_qos_attr.qos_flow_id)
-                       bfa_cb_rport_qos_scn_flowid(rp->rport_drv,
-                                                   qos_scn->old_qos_attr,
-                                                   qos_scn->new_qos_attr);
-               if (qos_scn->old_qos_attr.qos_priority !=
-                       qos_scn->new_qos_attr.qos_priority)
-                       bfa_cb_rport_qos_scn_prio(rp->rport_drv,
-                                                 qos_scn->old_qos_attr,
-                                                 qos_scn->new_qos_attr);
-               break;
-
-       default:
-               bfa_stats(rp, sm_on_unexp);
-               bfa_sm_fault(rp->bfa, event);
-       }
-}
-
-/**
- * Firmware rport is being deleted - awaiting f/w response.
- */
-static void
-bfa_rport_sm_fwdelete(struct bfa_rport_s *rp, enum bfa_rport_event event)
-{
-       bfa_trc(rp->bfa, rp->rport_tag);
-       bfa_trc(rp->bfa, event);
-
-       switch (event) {
-       case BFA_RPORT_SM_FWRSP:
-               bfa_stats(rp, sm_fwd_rsp);
-               bfa_sm_set_state(rp, bfa_rport_sm_offline);
-               bfa_rport_offline_cb(rp);
-               break;
-
-       case BFA_RPORT_SM_DELETE:
-               bfa_stats(rp, sm_fwd_del);
-               bfa_sm_set_state(rp, bfa_rport_sm_deleting);
-               break;
-
-       case BFA_RPORT_SM_HWFAIL:
-               bfa_stats(rp, sm_fwd_hwf);
-               bfa_sm_set_state(rp, bfa_rport_sm_iocdisable);
-               bfa_rport_offline_cb(rp);
-               break;
-
-       default:
-               bfa_stats(rp, sm_fwd_unexp);
-               bfa_sm_fault(rp->bfa, event);
-       }
-}
-
-static void
-bfa_rport_sm_fwdelete_qfull(struct bfa_rport_s *rp, enum bfa_rport_event event)
-{
-       bfa_trc(rp->bfa, rp->rport_tag);
-       bfa_trc(rp->bfa, event);
-
-       switch (event) {
-       case BFA_RPORT_SM_QRESUME:
-               bfa_sm_set_state(rp, bfa_rport_sm_fwdelete);
-               bfa_rport_send_fwdelete(rp);
-               break;
-
-       case BFA_RPORT_SM_DELETE:
-               bfa_stats(rp, sm_fwd_del);
-               bfa_sm_set_state(rp, bfa_rport_sm_deleting_qfull);
-               break;
-
-       case BFA_RPORT_SM_HWFAIL:
-               bfa_stats(rp, sm_fwd_hwf);
-               bfa_sm_set_state(rp, bfa_rport_sm_iocdisable);
-               bfa_reqq_wcancel(&rp->reqq_wait);
-               bfa_rport_offline_cb(rp);
-               break;
-
-       default:
-               bfa_stats(rp, sm_fwd_unexp);
-               bfa_sm_fault(rp->bfa, event);
-       }
-}
-
-/**
- * Offline state.
- */
-static void
-bfa_rport_sm_offline(struct bfa_rport_s *rp, enum bfa_rport_event event)
-{
-       bfa_trc(rp->bfa, rp->rport_tag);
-       bfa_trc(rp->bfa, event);
-
-       switch (event) {
-       case BFA_RPORT_SM_DELETE:
-               bfa_stats(rp, sm_off_del);
-               bfa_sm_set_state(rp, bfa_rport_sm_uninit);
-               bfa_rport_free(rp);
-               break;
-
-       case BFA_RPORT_SM_ONLINE:
-               bfa_stats(rp, sm_off_on);
-               if (bfa_rport_send_fwcreate(rp))
-                       bfa_sm_set_state(rp, bfa_rport_sm_fwcreate);
-               else
-                       bfa_sm_set_state(rp, bfa_rport_sm_fwcreate_qfull);
-               break;
-
-       case BFA_RPORT_SM_HWFAIL:
-               bfa_stats(rp, sm_off_hwf);
-               bfa_sm_set_state(rp, bfa_rport_sm_iocdisable);
-               break;
-
-       default:
-               bfa_stats(rp, sm_off_unexp);
-               bfa_sm_fault(rp->bfa, event);
-       }
-}
-
-/**
- * Rport is deleted, waiting for firmware response to delete.
- */
-static void
-bfa_rport_sm_deleting(struct bfa_rport_s *rp, enum bfa_rport_event event)
-{
-       bfa_trc(rp->bfa, rp->rport_tag);
-       bfa_trc(rp->bfa, event);
-
-       switch (event) {
-       case BFA_RPORT_SM_FWRSP:
-               bfa_stats(rp, sm_del_fwrsp);
-               bfa_sm_set_state(rp, bfa_rport_sm_uninit);
-               bfa_rport_free(rp);
-               break;
-
-       case BFA_RPORT_SM_HWFAIL:
-               bfa_stats(rp, sm_del_hwf);
-               bfa_sm_set_state(rp, bfa_rport_sm_uninit);
-               bfa_rport_free(rp);
-               break;
-
-       default:
-               bfa_sm_fault(rp->bfa, event);
-       }
-}
-
-static void
-bfa_rport_sm_deleting_qfull(struct bfa_rport_s *rp, enum bfa_rport_event event)
-{
-       bfa_trc(rp->bfa, rp->rport_tag);
-       bfa_trc(rp->bfa, event);
-
-       switch (event) {
-       case BFA_RPORT_SM_QRESUME:
-               bfa_stats(rp, sm_del_fwrsp);
-               bfa_sm_set_state(rp, bfa_rport_sm_deleting);
-               bfa_rport_send_fwdelete(rp);
-               break;
-
-       case BFA_RPORT_SM_HWFAIL:
-               bfa_stats(rp, sm_del_hwf);
-               bfa_sm_set_state(rp, bfa_rport_sm_uninit);
-               bfa_reqq_wcancel(&rp->reqq_wait);
-               bfa_rport_free(rp);
-               break;
-
-       default:
-               bfa_sm_fault(rp->bfa, event);
-       }
-}
-
-/**
- * Waiting for rport create response from firmware. A delete is pending.
- */
-static void
-bfa_rport_sm_delete_pending(struct bfa_rport_s *rp,
-                               enum bfa_rport_event event)
-{
-       bfa_trc(rp->bfa, rp->rport_tag);
-       bfa_trc(rp->bfa, event);
-
-       switch (event) {
-       case BFA_RPORT_SM_FWRSP:
-               bfa_stats(rp, sm_delp_fwrsp);
-               if (bfa_rport_send_fwdelete(rp))
-                       bfa_sm_set_state(rp, bfa_rport_sm_deleting);
-               else
-                       bfa_sm_set_state(rp, bfa_rport_sm_deleting_qfull);
-               break;
-
-       case BFA_RPORT_SM_HWFAIL:
-               bfa_stats(rp, sm_delp_hwf);
-               bfa_sm_set_state(rp, bfa_rport_sm_uninit);
-               bfa_rport_free(rp);
-               break;
-
-       default:
-               bfa_stats(rp, sm_delp_unexp);
-               bfa_sm_fault(rp->bfa, event);
-       }
-}
-
-/**
- * Waiting for rport create response from firmware. Rport offline is pending.
- */
-static void
-bfa_rport_sm_offline_pending(struct bfa_rport_s *rp,
-                                enum bfa_rport_event event)
-{
-       bfa_trc(rp->bfa, rp->rport_tag);
-       bfa_trc(rp->bfa, event);
-
-       switch (event) {
-       case BFA_RPORT_SM_FWRSP:
-               bfa_stats(rp, sm_offp_fwrsp);
-               if (bfa_rport_send_fwdelete(rp))
-                       bfa_sm_set_state(rp, bfa_rport_sm_fwdelete);
-               else
-                       bfa_sm_set_state(rp, bfa_rport_sm_fwdelete_qfull);
-               break;
-
-       case BFA_RPORT_SM_DELETE:
-               bfa_stats(rp, sm_offp_del);
-               bfa_sm_set_state(rp, bfa_rport_sm_delete_pending);
-               break;
-
-       case BFA_RPORT_SM_HWFAIL:
-               bfa_stats(rp, sm_offp_hwf);
-               bfa_sm_set_state(rp, bfa_rport_sm_iocdisable);
-               break;
-
-       default:
-               bfa_stats(rp, sm_offp_unexp);
-               bfa_sm_fault(rp->bfa, event);
-       }
-}
-
-/**
- * IOC h/w failed.
- */
-static void
-bfa_rport_sm_iocdisable(struct bfa_rport_s *rp, enum bfa_rport_event event)
-{
-       bfa_trc(rp->bfa, rp->rport_tag);
-       bfa_trc(rp->bfa, event);
-
-       switch (event) {
-       case BFA_RPORT_SM_OFFLINE:
-               bfa_stats(rp, sm_iocd_off);
-               bfa_rport_offline_cb(rp);
-               break;
-
-       case BFA_RPORT_SM_DELETE:
-               bfa_stats(rp, sm_iocd_del);
-               bfa_sm_set_state(rp, bfa_rport_sm_uninit);
-               bfa_rport_free(rp);
-               break;
-
-       case BFA_RPORT_SM_ONLINE:
-               bfa_stats(rp, sm_iocd_on);
-               if (bfa_rport_send_fwcreate(rp))
-                       bfa_sm_set_state(rp, bfa_rport_sm_fwcreate);
-               else
-                       bfa_sm_set_state(rp, bfa_rport_sm_fwcreate_qfull);
-               break;
-
-       case BFA_RPORT_SM_HWFAIL:
-               break;
-
-       default:
-               bfa_stats(rp, sm_iocd_unexp);
-               bfa_sm_fault(rp->bfa, event);
-       }
-}
-
-
-
-/**
- *  bfa_rport_private BFA rport private functions
- */
-
-static void
-__bfa_cb_rport_online(void *cbarg, bfa_boolean_t complete)
-{
-       struct bfa_rport_s *rp = cbarg;
-
-       if (complete)
-               bfa_cb_rport_online(rp->rport_drv);
-}
-
-static void
-__bfa_cb_rport_offline(void *cbarg, bfa_boolean_t complete)
-{
-       struct bfa_rport_s *rp = cbarg;
-
-       if (complete)
-               bfa_cb_rport_offline(rp->rport_drv);
-}
-
-static void
-bfa_rport_qresume(void *cbarg)
-{
-       struct bfa_rport_s      *rp = cbarg;
-
-       bfa_sm_send_event(rp, BFA_RPORT_SM_QRESUME);
-}
-
-static void
-bfa_rport_meminfo(struct bfa_iocfc_cfg_s *cfg, u32 *km_len,
-               u32 *dm_len)
-{
-       if (cfg->fwcfg.num_rports < BFA_RPORT_MIN)
-               cfg->fwcfg.num_rports = BFA_RPORT_MIN;
-
-       *km_len += cfg->fwcfg.num_rports * sizeof(struct bfa_rport_s);
-}
-
-static void
-bfa_rport_attach(struct bfa_s *bfa, void *bfad, struct bfa_iocfc_cfg_s *cfg,
-                    struct bfa_meminfo_s *meminfo, struct bfa_pcidev_s *pcidev)
-{
-       struct bfa_rport_mod_s *mod = BFA_RPORT_MOD(bfa);
-       struct bfa_rport_s *rp;
-       u16        i;
-
-       INIT_LIST_HEAD(&mod->rp_free_q);
-       INIT_LIST_HEAD(&mod->rp_active_q);
-
-       rp = (struct bfa_rport_s *) bfa_meminfo_kva(meminfo);
-       mod->rps_list = rp;
-       mod->num_rports = cfg->fwcfg.num_rports;
-
-       bfa_assert(mod->num_rports
-                  && !(mod->num_rports & (mod->num_rports - 1)));
-
-       for (i = 0; i < mod->num_rports; i++, rp++) {
-               bfa_os_memset(rp, 0, sizeof(struct bfa_rport_s));
-               rp->bfa = bfa;
-               rp->rport_tag = i;
-               bfa_sm_set_state(rp, bfa_rport_sm_uninit);
-
-               /**
-                *  - is unused
-                */
-               if (i)
-                       list_add_tail(&rp->qe, &mod->rp_free_q);
-
-               bfa_reqq_winit(&rp->reqq_wait, bfa_rport_qresume, rp);
-       }
-
-       /**
-        * consume memory
-        */
-       bfa_meminfo_kva(meminfo) = (u8 *) rp;
-}
-
-static void
-bfa_rport_detach(struct bfa_s *bfa)
-{
-}
-
-static void
-bfa_rport_start(struct bfa_s *bfa)
-{
-}
-
-static void
-bfa_rport_stop(struct bfa_s *bfa)
-{
-}
-
-static void
-bfa_rport_iocdisable(struct bfa_s *bfa)
-{
-       struct bfa_rport_mod_s *mod = BFA_RPORT_MOD(bfa);
-       struct bfa_rport_s *rport;
-       struct list_head        *qe, *qen;
-
-       list_for_each_safe(qe, qen, &mod->rp_active_q) {
-               rport = (struct bfa_rport_s *) qe;
-               bfa_sm_send_event(rport, BFA_RPORT_SM_HWFAIL);
-       }
-}
-
-static struct bfa_rport_s *
-bfa_rport_alloc(struct bfa_rport_mod_s *mod)
-{
-       struct bfa_rport_s *rport;
-
-       bfa_q_deq(&mod->rp_free_q, &rport);
-       if (rport)
-               list_add_tail(&rport->qe, &mod->rp_active_q);
-
-       return rport;
-}
-
-static void
-bfa_rport_free(struct bfa_rport_s *rport)
-{
-       struct bfa_rport_mod_s *mod = BFA_RPORT_MOD(rport->bfa);
-
-       bfa_assert(bfa_q_is_on_q(&mod->rp_active_q, rport));
-       list_del(&rport->qe);
-       list_add_tail(&rport->qe, &mod->rp_free_q);
-}
-
-static bfa_boolean_t
-bfa_rport_send_fwcreate(struct bfa_rport_s *rp)
-{
-       struct bfi_rport_create_req_s *m;
-
-       /**
-        * check for room in queue to send request now
-        */
-       m = bfa_reqq_next(rp->bfa, BFA_REQQ_RPORT);
-       if (!m) {
-               bfa_reqq_wait(rp->bfa, BFA_REQQ_RPORT, &rp->reqq_wait);
-               return BFA_FALSE;
-       }
-
-       bfi_h2i_set(m->mh, BFI_MC_RPORT, BFI_RPORT_H2I_CREATE_REQ,
-                       bfa_lpuid(rp->bfa));
-       m->bfa_handle = rp->rport_tag;
-       m->max_frmsz = bfa_os_htons(rp->rport_info.max_frmsz);
-       m->pid = rp->rport_info.pid;
-       m->lp_tag = rp->rport_info.lp_tag;
-       m->local_pid = rp->rport_info.local_pid;
-       m->fc_class = rp->rport_info.fc_class;
-       m->vf_en = rp->rport_info.vf_en;
-       m->vf_id = rp->rport_info.vf_id;
-       m->cisc = rp->rport_info.cisc;
-
-       /**
-        * queue I/O message to firmware
-        */
-       bfa_reqq_produce(rp->bfa, BFA_REQQ_RPORT);
-       return BFA_TRUE;
-}
-
-static bfa_boolean_t
-bfa_rport_send_fwdelete(struct bfa_rport_s *rp)
-{
-       struct bfi_rport_delete_req_s *m;
-
-       /**
-        * check for room in queue to send request now
-        */
-       m = bfa_reqq_next(rp->bfa, BFA_REQQ_RPORT);
-       if (!m) {
-               bfa_reqq_wait(rp->bfa, BFA_REQQ_RPORT, &rp->reqq_wait);
-               return BFA_FALSE;
-       }
-
-       bfi_h2i_set(m->mh, BFI_MC_RPORT, BFI_RPORT_H2I_DELETE_REQ,
-                       bfa_lpuid(rp->bfa));
-       m->fw_handle = rp->fw_handle;
-
-       /**
-        * queue I/O message to firmware
-        */
-       bfa_reqq_produce(rp->bfa, BFA_REQQ_RPORT);
-       return BFA_TRUE;
-}
-
-static bfa_boolean_t
-bfa_rport_send_fwspeed(struct bfa_rport_s *rp)
-{
-       struct bfa_rport_speed_req_s *m;
-
-       /**
-        * check for room in queue to send request now
-        */
-       m = bfa_reqq_next(rp->bfa, BFA_REQQ_RPORT);
-       if (!m) {
-               bfa_trc(rp->bfa, rp->rport_info.speed);
-               return BFA_FALSE;
-       }
-
-       bfi_h2i_set(m->mh, BFI_MC_RPORT, BFI_RPORT_H2I_SET_SPEED_REQ,
-                       bfa_lpuid(rp->bfa));
-       m->fw_handle = rp->fw_handle;
-       m->speed = (u8)rp->rport_info.speed;
-
-       /**
-        * queue I/O message to firmware
-        */
-       bfa_reqq_produce(rp->bfa, BFA_REQQ_RPORT);
-       return BFA_TRUE;
-}
-
-
-
-/**
- *  bfa_rport_public
- */
-
-/**
- *             Rport interrupt processing.
- */
-void
-bfa_rport_isr(struct bfa_s *bfa, struct bfi_msg_s *m)
-{
-       union bfi_rport_i2h_msg_u msg;
-       struct bfa_rport_s *rp;
-
-       bfa_trc(bfa, m->mhdr.msg_id);
-
-       msg.msg = m;
-
-       switch (m->mhdr.msg_id) {
-       case BFI_RPORT_I2H_CREATE_RSP:
-               rp = BFA_RPORT_FROM_TAG(bfa, msg.create_rsp->bfa_handle);
-               rp->fw_handle = msg.create_rsp->fw_handle;
-               rp->qos_attr = msg.create_rsp->qos_attr;
-               bfa_assert(msg.create_rsp->status == BFA_STATUS_OK);
-               bfa_sm_send_event(rp, BFA_RPORT_SM_FWRSP);
-               break;
-
-       case BFI_RPORT_I2H_DELETE_RSP:
-               rp = BFA_RPORT_FROM_TAG(bfa, msg.delete_rsp->bfa_handle);
-               bfa_assert(msg.delete_rsp->status == BFA_STATUS_OK);
-               bfa_sm_send_event(rp, BFA_RPORT_SM_FWRSP);
-               break;
-
-       case BFI_RPORT_I2H_QOS_SCN:
-               rp = BFA_RPORT_FROM_TAG(bfa, msg.qos_scn_evt->bfa_handle);
-               rp->event_arg.fw_msg = msg.qos_scn_evt;
-               bfa_sm_send_event(rp, BFA_RPORT_SM_QOS_SCN);
-               break;
-
-       default:
-               bfa_trc(bfa, m->mhdr.msg_id);
-               bfa_assert(0);
-       }
-}
-
-
-
-/**
- *  bfa_rport_api
- */
-
-struct bfa_rport_s *
-bfa_rport_create(struct bfa_s *bfa, void *rport_drv)
-{
-       struct bfa_rport_s *rp;
-
-       rp = bfa_rport_alloc(BFA_RPORT_MOD(bfa));
-
-       if (rp == NULL)
-               return NULL;
-
-       rp->bfa = bfa;
-       rp->rport_drv = rport_drv;
-       bfa_rport_clear_stats(rp);
-
-       bfa_assert(bfa_sm_cmp_state(rp, bfa_rport_sm_uninit));
-       bfa_sm_send_event(rp, BFA_RPORT_SM_CREATE);
-
-       return rp;
-}
-
-void
-bfa_rport_delete(struct bfa_rport_s *rport)
-{
-       bfa_sm_send_event(rport, BFA_RPORT_SM_DELETE);
-}
-
-void
-bfa_rport_online(struct bfa_rport_s *rport, struct bfa_rport_info_s *rport_info)
-{
-       bfa_assert(rport_info->max_frmsz != 0);
-
-       /**
-        * Some JBODs are seen to be not setting PDU size correctly in PLOGI
-        * responses. Default to minimum size.
-        */
-       if (rport_info->max_frmsz == 0) {
-               bfa_trc(rport->bfa, rport->rport_tag);
-               rport_info->max_frmsz = FC_MIN_PDUSZ;
-       }
-
-       bfa_os_assign(rport->rport_info, *rport_info);
-       bfa_sm_send_event(rport, BFA_RPORT_SM_ONLINE);
-}
-
-void
-bfa_rport_offline(struct bfa_rport_s *rport)
-{
-       bfa_sm_send_event(rport, BFA_RPORT_SM_OFFLINE);
-}
-
-void
-bfa_rport_speed(struct bfa_rport_s *rport, enum bfa_pport_speed speed)
-{
-       bfa_assert(speed != 0);
-       bfa_assert(speed != BFA_PPORT_SPEED_AUTO);
-
-       rport->rport_info.speed = speed;
-       bfa_sm_send_event(rport, BFA_RPORT_SM_SET_SPEED);
-}
-
-void
-bfa_rport_get_stats(struct bfa_rport_s *rport,
-       struct bfa_rport_hal_stats_s *stats)
-{
-       *stats = rport->stats;
-}
-
-void
-bfa_rport_get_qos_attr(struct bfa_rport_s *rport,
-                                       struct bfa_rport_qos_attr_s *qos_attr)
-{
-       qos_attr->qos_priority  = bfa_os_ntohl(rport->qos_attr.qos_priority);
-       qos_attr->qos_flow_id  = bfa_os_ntohl(rport->qos_attr.qos_flow_id);
-
-}
-
-void
-bfa_rport_clear_stats(struct bfa_rport_s *rport)
-{
-       bfa_os_memset(&rport->stats, 0, sizeof(rport->stats));
-}
-
-
diff --git a/drivers/scsi/bfa/bfa_rport_priv.h b/drivers/scsi/bfa/bfa_rport_priv.h
deleted file mode 100644 (file)
index 6490ce2..0000000
+++ /dev/null
@@ -1,45 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_RPORT_PRIV_H__
-#define __BFA_RPORT_PRIV_H__
-
-#include <bfa_svc.h>
-
-#define BFA_RPORT_MIN  4
-
-struct bfa_rport_mod_s {
-       struct bfa_rport_s *rps_list;   /*  list of rports      */
-       struct list_head        rp_free_q;      /*  free bfa_rports     */
-       struct list_head        rp_active_q;    /*  free bfa_rports     */
-       u16     num_rports;     /*  number of rports    */
-};
-
-#define BFA_RPORT_MOD(__bfa)   (&(__bfa)->modules.rport_mod)
-
-/**
- * Convert rport tag to RPORT
- */
-#define BFA_RPORT_FROM_TAG(__bfa, _tag)                                \
-       (BFA_RPORT_MOD(__bfa)->rps_list +                               \
-        ((_tag) & (BFA_RPORT_MOD(__bfa)->num_rports - 1)))
-
-/*
- * external functions
- */
-void   bfa_rport_isr(struct bfa_s *bfa, struct bfi_msg_s *msg);
-#endif /* __BFA_RPORT_PRIV_H__ */
diff --git a/drivers/scsi/bfa/bfa_sgpg.c b/drivers/scsi/bfa/bfa_sgpg.c
deleted file mode 100644 (file)
index ae452c4..0000000
+++ /dev/null
@@ -1,226 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#include <bfa.h>
-
-BFA_TRC_FILE(HAL, SGPG);
-BFA_MODULE(sgpg);
-
-/**
- *  bfa_sgpg_mod BFA SGPG Mode module
- */
-
-/**
- * Compute and return memory needed by FCP(im) module.
- */
-static void
-bfa_sgpg_meminfo(struct bfa_iocfc_cfg_s *cfg, u32 *km_len,
-               u32 *dm_len)
-{
-       if (cfg->drvcfg.num_sgpgs < BFA_SGPG_MIN)
-               cfg->drvcfg.num_sgpgs = BFA_SGPG_MIN;
-
-       *km_len += (cfg->drvcfg.num_sgpgs + 1) * sizeof(struct bfa_sgpg_s);
-       *dm_len += (cfg->drvcfg.num_sgpgs + 1) * sizeof(struct bfi_sgpg_s);
-}
-
-
-static void
-bfa_sgpg_attach(struct bfa_s *bfa, void *bfad, struct bfa_iocfc_cfg_s *cfg,
-                   struct bfa_meminfo_s *minfo, struct bfa_pcidev_s *pcidev)
-{
-       struct bfa_sgpg_mod_s   *mod = BFA_SGPG_MOD(bfa);
-       int                             i;
-       struct bfa_sgpg_s               *hsgpg;
-       struct bfi_sgpg_s       *sgpg;
-       u64             align_len;
-
-       union {
-               u64        pa;
-               union bfi_addr_u      addr;
-       } sgpg_pa;
-
-       INIT_LIST_HEAD(&mod->sgpg_q);
-       INIT_LIST_HEAD(&mod->sgpg_wait_q);
-
-       bfa_trc(bfa, cfg->drvcfg.num_sgpgs);
-
-       mod->num_sgpgs = cfg->drvcfg.num_sgpgs;
-       mod->sgpg_arr_pa = bfa_meminfo_dma_phys(minfo);
-       align_len = (BFA_SGPG_ROUNDUP(mod->sgpg_arr_pa) - mod->sgpg_arr_pa);
-       mod->sgpg_arr_pa += align_len;
-       mod->hsgpg_arr = (struct bfa_sgpg_s *) (bfa_meminfo_kva(minfo) +
-                                               align_len);
-       mod->sgpg_arr = (struct bfi_sgpg_s *) (bfa_meminfo_dma_virt(minfo) +
-                                               align_len);
-
-       hsgpg = mod->hsgpg_arr;
-       sgpg = mod->sgpg_arr;
-       sgpg_pa.pa = mod->sgpg_arr_pa;
-       mod->free_sgpgs = mod->num_sgpgs;
-
-       bfa_assert(!(sgpg_pa.pa & (sizeof(struct bfi_sgpg_s) - 1)));
-
-       for (i = 0; i < mod->num_sgpgs; i++) {
-               bfa_os_memset(hsgpg, 0, sizeof(*hsgpg));
-               bfa_os_memset(sgpg, 0, sizeof(*sgpg));
-
-               hsgpg->sgpg = sgpg;
-               hsgpg->sgpg_pa = sgpg_pa.addr;
-               list_add_tail(&hsgpg->qe, &mod->sgpg_q);
-
-               hsgpg++;
-               sgpg++;
-               sgpg_pa.pa += sizeof(struct bfi_sgpg_s);
-       }
-
-       bfa_meminfo_kva(minfo) = (u8 *) hsgpg;
-       bfa_meminfo_dma_virt(minfo) = (u8 *) sgpg;
-       bfa_meminfo_dma_phys(minfo) = sgpg_pa.pa;
-}
-
-static void
-bfa_sgpg_detach(struct bfa_s *bfa)
-{
-}
-
-static void
-bfa_sgpg_start(struct bfa_s *bfa)
-{
-}
-
-static void
-bfa_sgpg_stop(struct bfa_s *bfa)
-{
-}
-
-static void
-bfa_sgpg_iocdisable(struct bfa_s *bfa)
-{
-}
-
-
-
-/**
- *  bfa_sgpg_public BFA SGPG public functions
- */
-
-bfa_status_t
-bfa_sgpg_malloc(struct bfa_s *bfa, struct list_head *sgpg_q, int nsgpgs)
-{
-       struct bfa_sgpg_mod_s *mod = BFA_SGPG_MOD(bfa);
-       struct bfa_sgpg_s *hsgpg;
-       int             i;
-
-       bfa_trc_fp(bfa, nsgpgs);
-
-       if (mod->free_sgpgs < nsgpgs)
-               return BFA_STATUS_ENOMEM;
-
-       for (i = 0; i < nsgpgs; i++) {
-               bfa_q_deq(&mod->sgpg_q, &hsgpg);
-               bfa_assert(hsgpg);
-               list_add_tail(&hsgpg->qe, sgpg_q);
-       }
-
-       mod->free_sgpgs -= nsgpgs;
-       return BFA_STATUS_OK;
-}
-
-void
-bfa_sgpg_mfree(struct bfa_s *bfa, struct list_head *sgpg_q, int nsgpg)
-{
-       struct bfa_sgpg_mod_s *mod = BFA_SGPG_MOD(bfa);
-       struct bfa_sgpg_wqe_s *wqe;
-
-       bfa_trc_fp(bfa, nsgpg);
-
-       mod->free_sgpgs += nsgpg;
-       bfa_assert(mod->free_sgpgs <= mod->num_sgpgs);
-
-       list_splice_tail_init(sgpg_q, &mod->sgpg_q);
-
-       if (list_empty(&mod->sgpg_wait_q))
-               return;
-
-       /**
-        * satisfy as many waiting requests as possible
-        */
-       do {
-               wqe = bfa_q_first(&mod->sgpg_wait_q);
-               if (mod->free_sgpgs < wqe->nsgpg)
-                       nsgpg = mod->free_sgpgs;
-               else
-                       nsgpg = wqe->nsgpg;
-               bfa_sgpg_malloc(bfa, &wqe->sgpg_q, nsgpg);
-               wqe->nsgpg -= nsgpg;
-               if (wqe->nsgpg == 0) {
-                       list_del(&wqe->qe);
-                       wqe->cbfn(wqe->cbarg);
-               }
-       } while (mod->free_sgpgs && !list_empty(&mod->sgpg_wait_q));
-}
-
-void
-bfa_sgpg_wait(struct bfa_s *bfa, struct bfa_sgpg_wqe_s *wqe, int nsgpg)
-{
-       struct bfa_sgpg_mod_s *mod = BFA_SGPG_MOD(bfa);
-
-       bfa_assert(nsgpg > 0);
-       bfa_assert(nsgpg > mod->free_sgpgs);
-
-       wqe->nsgpg_total = wqe->nsgpg = nsgpg;
-
-       /**
-        * allocate any left to this one first
-        */
-       if (mod->free_sgpgs) {
-               /**
-                * no one else is waiting for SGPG
-                */
-               bfa_assert(list_empty(&mod->sgpg_wait_q));
-               list_splice_tail_init(&mod->sgpg_q, &wqe->sgpg_q);
-               wqe->nsgpg -= mod->free_sgpgs;
-               mod->free_sgpgs = 0;
-       }
-
-       list_add_tail(&wqe->qe, &mod->sgpg_wait_q);
-}
-
-void
-bfa_sgpg_wcancel(struct bfa_s *bfa, struct bfa_sgpg_wqe_s *wqe)
-{
-       struct bfa_sgpg_mod_s *mod = BFA_SGPG_MOD(bfa);
-
-       bfa_assert(bfa_q_is_on_q(&mod->sgpg_wait_q, wqe));
-       list_del(&wqe->qe);
-
-       if (wqe->nsgpg_total != wqe->nsgpg)
-               bfa_sgpg_mfree(bfa, &wqe->sgpg_q,
-                                  wqe->nsgpg_total - wqe->nsgpg);
-}
-
-void
-bfa_sgpg_winit(struct bfa_sgpg_wqe_s *wqe, void (*cbfn) (void *cbarg),
-                  void *cbarg)
-{
-       INIT_LIST_HEAD(&wqe->sgpg_q);
-       wqe->cbfn = cbfn;
-       wqe->cbarg = cbarg;
-}
-
-
diff --git a/drivers/scsi/bfa/bfa_sgpg_priv.h b/drivers/scsi/bfa/bfa_sgpg_priv.h
deleted file mode 100644 (file)
index 9c2a8cb..0000000
+++ /dev/null
@@ -1,79 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  hal_sgpg.h BFA SG page module
- */
-
-#ifndef __BFA_SGPG_PRIV_H__
-#define __BFA_SGPG_PRIV_H__
-
-#include <cs/bfa_q.h>
-
-#define BFA_SGPG_MIN   (16)
-
-/**
- * Alignment macro for SG page allocation
- */
-#define BFA_SGPG_ROUNDUP(_l) (((_l) + (sizeof(struct bfi_sgpg_s) - 1)) \
-                       & ~(sizeof(struct bfi_sgpg_s) - 1))
-
-struct bfa_sgpg_wqe_s {
-       struct list_head qe;    /*  queue sg page element       */
-       int     nsgpg;          /*  pages to be allocated       */
-       int     nsgpg_total;    /*  total pages required        */
-       void    (*cbfn) (void *cbarg);
-                               /*  callback function           */
-       void    *cbarg;         /*  callback arg                */
-       struct list_head sgpg_q;        /*  queue of alloced sgpgs      */
-};
-
-struct bfa_sgpg_s {
-       struct list_head        qe;     /*  queue sg page element       */
-       struct bfi_sgpg_s *sgpg; /*  va of SG page              */
-       union bfi_addr_u sgpg_pa;/*  pa of SG page              */
-};
-
-/**
- * Given number of SG elements, BFA_SGPG_NPAGE() returns the number of
- * SG pages required.
- */
-#define BFA_SGPG_NPAGE(_nsges)  (((_nsges) / BFI_SGPG_DATA_SGES) + 1)
-
-struct bfa_sgpg_mod_s {
-       struct bfa_s *bfa;
-       int             num_sgpgs;      /*  number of SG pages          */
-       int             free_sgpgs;     /*  number of free SG pages     */
-       struct bfa_sgpg_s *hsgpg_arr;   /*  BFA SG page array   */
-       struct bfi_sgpg_s *sgpg_arr;    /*  actual SG page array        */
-       u64     sgpg_arr_pa;    /*  SG page array DMA addr      */
-       struct list_head sgpg_q;        /*  queue of free SG pages      */
-       struct list_head sgpg_wait_q; /*  wait queue for SG pages       */
-};
-#define BFA_SGPG_MOD(__bfa)    (&(__bfa)->modules.sgpg_mod)
-
-bfa_status_t   bfa_sgpg_malloc(struct bfa_s *bfa, struct list_head *sgpg_q,
-                                                               int nsgpgs);
-void           bfa_sgpg_mfree(struct bfa_s *bfa, struct list_head *sgpg_q,
-                                                               int nsgpgs);
-void           bfa_sgpg_winit(struct bfa_sgpg_wqe_s *wqe,
-                                  void (*cbfn) (void *cbarg), void *cbarg);
-void           bfa_sgpg_wait(struct bfa_s *bfa, struct bfa_sgpg_wqe_s *wqe,
-                                                               int nsgpgs);
-void           bfa_sgpg_wcancel(struct bfa_s *bfa, struct bfa_sgpg_wqe_s *wqe);
-
-#endif /* __BFA_SGPG_PRIV_H__ */
diff --git a/drivers/scsi/bfa/bfa_sm.c b/drivers/scsi/bfa/bfa_sm.c
deleted file mode 100644 (file)
index 5420f4f..0000000
+++ /dev/null
@@ -1,38 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  bfasm.c BFA State machine utility functions
- */
-
-#include <cs/bfa_sm.h>
-
-/**
- *  cs_sm_api
- */
-
-int
-bfa_sm_to_state(struct bfa_sm_table_s *smt, bfa_sm_t sm)
-{
-       int             i = 0;
-
-       while (smt[i].sm && smt[i].sm != sm)
-               i++;
-       return smt[i].state;
-}
-
-
diff --git a/drivers/scsi/bfa/bfa_svc.c b/drivers/scsi/bfa/bfa_svc.c
new file mode 100644 (file)
index 0000000..aa1dc74
--- /dev/null
@@ -0,0 +1,5423 @@
+/*
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
+ * All rights reserved
+ * www.brocade.com
+ *
+ * Linux driver for Brocade Fibre Channel Host Bus Adapter.
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License (GPL) Version 2 as
+ * published by the Free Software Foundation
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * General Public License for more details.
+ */
+
+#include "bfa_os_inc.h"
+#include "bfa_plog.h"
+#include "bfa_cs.h"
+#include "bfa_modules.h"
+#include "bfad_drv.h"
+
+BFA_TRC_FILE(HAL, FCXP);
+BFA_MODULE(fcxp);
+BFA_MODULE(sgpg);
+BFA_MODULE(lps);
+BFA_MODULE(fcport);
+BFA_MODULE(rport);
+BFA_MODULE(uf);
+
+/**
+ * LPS related definitions
+ */
+#define BFA_LPS_MIN_LPORTS      (1)
+#define BFA_LPS_MAX_LPORTS      (256)
+
+/*
+ * Maximum Vports supported per physical port or vf.
+ */
+#define BFA_LPS_MAX_VPORTS_SUPP_CB  255
+#define BFA_LPS_MAX_VPORTS_SUPP_CT  190
+
+/**
+ *  lps_pvt BFA LPS private functions
+ */
+
+enum bfa_lps_event {
+       BFA_LPS_SM_LOGIN        = 1,    /* login request from user      */
+       BFA_LPS_SM_LOGOUT       = 2,    /* logout request from user     */
+       BFA_LPS_SM_FWRSP        = 3,    /* f/w response to login/logout */
+       BFA_LPS_SM_RESUME       = 4,    /* space present in reqq queue  */
+       BFA_LPS_SM_DELETE       = 5,    /* lps delete from user         */
+       BFA_LPS_SM_OFFLINE      = 6,    /* Link is offline              */
+       BFA_LPS_SM_RX_CVL       = 7,    /* Rx clear virtual link        */
+};
+
+/**
+ * FC PORT related definitions
+ */
+/*
+ * The port is considered disabled if corresponding physical port or IOC are
+ * disabled explicitly
+ */
+#define BFA_PORT_IS_DISABLED(bfa) \
+       ((bfa_fcport_is_disabled(bfa) == BFA_TRUE) || \
+       (bfa_ioc_is_disabled(&bfa->ioc) == BFA_TRUE))
+
+
+/**
+ * BFA port state machine events
+ */
+enum bfa_fcport_sm_event {
+       BFA_FCPORT_SM_START     = 1,    /*  start port state machine    */
+       BFA_FCPORT_SM_STOP      = 2,    /*  stop port state machine     */
+       BFA_FCPORT_SM_ENABLE    = 3,    /*  enable port         */
+       BFA_FCPORT_SM_DISABLE   = 4,    /*  disable port state machine */
+       BFA_FCPORT_SM_FWRSP     = 5,    /*  firmware enable/disable rsp */
+       BFA_FCPORT_SM_LINKUP    = 6,    /*  firmware linkup event       */
+       BFA_FCPORT_SM_LINKDOWN  = 7,    /*  firmware linkup down        */
+       BFA_FCPORT_SM_QRESUME   = 8,    /*  CQ space available  */
+       BFA_FCPORT_SM_HWFAIL    = 9,    /*  IOC h/w failure             */
+};
+
+/**
+ * BFA port link notification state machine events
+ */
+
+enum bfa_fcport_ln_sm_event {
+       BFA_FCPORT_LN_SM_LINKUP         = 1,    /*  linkup event        */
+       BFA_FCPORT_LN_SM_LINKDOWN       = 2,    /*  linkdown event      */
+       BFA_FCPORT_LN_SM_NOTIFICATION   = 3     /*  done notification   */
+};
+
+/**
+ * RPORT related definitions
+ */
+#define bfa_rport_offline_cb(__rp) do {                                        \
+       if ((__rp)->bfa->fcs)                                           \
+               bfa_cb_rport_offline((__rp)->rport_drv);      \
+       else {                                                          \
+               bfa_cb_queue((__rp)->bfa, &(__rp)->hcb_qe,              \
+                               __bfa_cb_rport_offline, (__rp));      \
+       }                                                               \
+} while (0)
+
+#define bfa_rport_online_cb(__rp) do {                                 \
+       if ((__rp)->bfa->fcs)                                           \
+               bfa_cb_rport_online((__rp)->rport_drv);      \
+       else {                                                          \
+               bfa_cb_queue((__rp)->bfa, &(__rp)->hcb_qe,              \
+                                 __bfa_cb_rport_online, (__rp));      \
+               }                                                       \
+} while (0)
+
+
+enum bfa_rport_event {
+       BFA_RPORT_SM_CREATE     = 1,    /*  rport create event          */
+       BFA_RPORT_SM_DELETE     = 2,    /*  deleting an existing rport  */
+       BFA_RPORT_SM_ONLINE     = 3,    /*  rport is online             */
+       BFA_RPORT_SM_OFFLINE    = 4,    /*  rport is offline            */
+       BFA_RPORT_SM_FWRSP      = 5,    /*  firmware response           */
+       BFA_RPORT_SM_HWFAIL     = 6,    /*  IOC h/w failure             */
+       BFA_RPORT_SM_QOS_SCN    = 7,    /*  QoS SCN from firmware       */
+       BFA_RPORT_SM_SET_SPEED  = 8,    /*  Set Rport Speed             */
+       BFA_RPORT_SM_QRESUME    = 9,    /*  space in requeue queue      */
+};
+
+/**
+ * forward declarations FCXP related functions
+ */
+static void    __bfa_fcxp_send_cbfn(void *cbarg, bfa_boolean_t complete);
+static void    hal_fcxp_rx_plog(struct bfa_s *bfa, struct bfa_fcxp_s *fcxp,
+                               struct bfi_fcxp_send_rsp_s *fcxp_rsp);
+static void    hal_fcxp_tx_plog(struct bfa_s *bfa, u32 reqlen,
+                               struct bfa_fcxp_s *fcxp, struct fchs_s *fchs);
+static void    bfa_fcxp_qresume(void *cbarg);
+static void    bfa_fcxp_queue(struct bfa_fcxp_s *fcxp,
+                               struct bfi_fcxp_send_req_s *send_req);
+
+/**
+ * forward declarations for LPS functions
+ */
+static void bfa_lps_meminfo(struct bfa_iocfc_cfg_s *cfg, u32 *ndm_len,
+                               u32 *dm_len);
+static void bfa_lps_attach(struct bfa_s *bfa, void *bfad,
+                               struct bfa_iocfc_cfg_s *cfg,
+                               struct bfa_meminfo_s *meminfo,
+                               struct bfa_pcidev_s *pcidev);
+static void bfa_lps_detach(struct bfa_s *bfa);
+static void bfa_lps_start(struct bfa_s *bfa);
+static void bfa_lps_stop(struct bfa_s *bfa);
+static void bfa_lps_iocdisable(struct bfa_s *bfa);
+static void bfa_lps_login_rsp(struct bfa_s *bfa,
+                               struct bfi_lps_login_rsp_s *rsp);
+static void bfa_lps_logout_rsp(struct bfa_s *bfa,
+                               struct bfi_lps_logout_rsp_s *rsp);
+static void bfa_lps_reqq_resume(void *lps_arg);
+static void bfa_lps_free(struct bfa_lps_s *lps);
+static void bfa_lps_send_login(struct bfa_lps_s *lps);
+static void bfa_lps_send_logout(struct bfa_lps_s *lps);
+static void bfa_lps_login_comp(struct bfa_lps_s *lps);
+static void bfa_lps_logout_comp(struct bfa_lps_s *lps);
+static void bfa_lps_cvl_event(struct bfa_lps_s *lps);
+
+/**
+ * forward declaration for LPS state machine
+ */
+static void bfa_lps_sm_init(struct bfa_lps_s *lps, enum bfa_lps_event event);
+static void bfa_lps_sm_login(struct bfa_lps_s *lps, enum bfa_lps_event event);
+static void bfa_lps_sm_loginwait(struct bfa_lps_s *lps, enum bfa_lps_event
+                                       event);
+static void bfa_lps_sm_online(struct bfa_lps_s *lps, enum bfa_lps_event event);
+static void bfa_lps_sm_logout(struct bfa_lps_s *lps, enum bfa_lps_event event);
+static void bfa_lps_sm_logowait(struct bfa_lps_s *lps, enum bfa_lps_event
+                                       event);
+
+/**
+ * forward declaration for FC Port functions
+ */
+static bfa_boolean_t bfa_fcport_send_enable(struct bfa_fcport_s *fcport);
+static bfa_boolean_t bfa_fcport_send_disable(struct bfa_fcport_s *fcport);
+static void bfa_fcport_update_linkinfo(struct bfa_fcport_s *fcport);
+static void bfa_fcport_reset_linkinfo(struct bfa_fcport_s *fcport);
+static void bfa_fcport_set_wwns(struct bfa_fcport_s *fcport);
+static void __bfa_cb_fcport_event(void *cbarg, bfa_boolean_t complete);
+static void bfa_fcport_scn(struct bfa_fcport_s *fcport,
+                       enum bfa_port_linkstate event, bfa_boolean_t trunk);
+static void bfa_fcport_queue_cb(struct bfa_fcport_ln_s *ln,
+                               enum bfa_port_linkstate event);
+static void __bfa_cb_fcport_stats_clr(void *cbarg, bfa_boolean_t complete);
+static void bfa_fcport_stats_get_timeout(void *cbarg);
+static void bfa_fcport_stats_clr_timeout(void *cbarg);
+static void bfa_trunk_iocdisable(struct bfa_s *bfa);
+
+/**
+ * forward declaration for FC PORT state machine
+ */
+static void     bfa_fcport_sm_uninit(struct bfa_fcport_s *fcport,
+                                       enum bfa_fcport_sm_event event);
+static void     bfa_fcport_sm_enabling_qwait(struct bfa_fcport_s *fcport,
+                                       enum bfa_fcport_sm_event event);
+static void     bfa_fcport_sm_enabling(struct bfa_fcport_s *fcport,
+                                       enum bfa_fcport_sm_event event);
+static void     bfa_fcport_sm_linkdown(struct bfa_fcport_s *fcport,
+                                       enum bfa_fcport_sm_event event);
+static void     bfa_fcport_sm_linkup(struct bfa_fcport_s *fcport,
+                                       enum bfa_fcport_sm_event event);
+static void     bfa_fcport_sm_disabling(struct bfa_fcport_s *fcport,
+                                       enum bfa_fcport_sm_event event);
+static void     bfa_fcport_sm_disabling_qwait(struct bfa_fcport_s *fcport,
+                                       enum bfa_fcport_sm_event event);
+static void     bfa_fcport_sm_toggling_qwait(struct bfa_fcport_s *fcport,
+                                       enum bfa_fcport_sm_event event);
+static void     bfa_fcport_sm_disabled(struct bfa_fcport_s *fcport,
+                                       enum bfa_fcport_sm_event event);
+static void     bfa_fcport_sm_stopped(struct bfa_fcport_s *fcport,
+                                       enum bfa_fcport_sm_event event);
+static void     bfa_fcport_sm_iocdown(struct bfa_fcport_s *fcport,
+                                       enum bfa_fcport_sm_event event);
+static void     bfa_fcport_sm_iocfail(struct bfa_fcport_s *fcport,
+                                       enum bfa_fcport_sm_event event);
+
+static void     bfa_fcport_ln_sm_dn(struct bfa_fcport_ln_s *ln,
+                                       enum bfa_fcport_ln_sm_event event);
+static void     bfa_fcport_ln_sm_dn_nf(struct bfa_fcport_ln_s *ln,
+                                       enum bfa_fcport_ln_sm_event event);
+static void     bfa_fcport_ln_sm_dn_up_nf(struct bfa_fcport_ln_s *ln,
+                                       enum bfa_fcport_ln_sm_event event);
+static void     bfa_fcport_ln_sm_up(struct bfa_fcport_ln_s *ln,
+                                       enum bfa_fcport_ln_sm_event event);
+static void     bfa_fcport_ln_sm_up_nf(struct bfa_fcport_ln_s *ln,
+                                       enum bfa_fcport_ln_sm_event event);
+static void     bfa_fcport_ln_sm_up_dn_nf(struct bfa_fcport_ln_s *ln,
+                                       enum bfa_fcport_ln_sm_event event);
+static void     bfa_fcport_ln_sm_up_dn_up_nf(struct bfa_fcport_ln_s *ln,
+                                       enum bfa_fcport_ln_sm_event event);
+
+static struct bfa_sm_table_s hal_port_sm_table[] = {
+       {BFA_SM(bfa_fcport_sm_uninit), BFA_PORT_ST_UNINIT},
+       {BFA_SM(bfa_fcport_sm_enabling_qwait), BFA_PORT_ST_ENABLING_QWAIT},
+       {BFA_SM(bfa_fcport_sm_enabling), BFA_PORT_ST_ENABLING},
+       {BFA_SM(bfa_fcport_sm_linkdown), BFA_PORT_ST_LINKDOWN},
+       {BFA_SM(bfa_fcport_sm_linkup), BFA_PORT_ST_LINKUP},
+       {BFA_SM(bfa_fcport_sm_disabling_qwait), BFA_PORT_ST_DISABLING_QWAIT},
+       {BFA_SM(bfa_fcport_sm_toggling_qwait), BFA_PORT_ST_TOGGLING_QWAIT},
+       {BFA_SM(bfa_fcport_sm_disabling), BFA_PORT_ST_DISABLING},
+       {BFA_SM(bfa_fcport_sm_disabled), BFA_PORT_ST_DISABLED},
+       {BFA_SM(bfa_fcport_sm_stopped), BFA_PORT_ST_STOPPED},
+       {BFA_SM(bfa_fcport_sm_iocdown), BFA_PORT_ST_IOCDOWN},
+       {BFA_SM(bfa_fcport_sm_iocfail), BFA_PORT_ST_IOCDOWN},
+};
+
+
+/**
+ * forward declaration for RPORT related functions
+ */
+static struct bfa_rport_s *bfa_rport_alloc(struct bfa_rport_mod_s *rp_mod);
+static void            bfa_rport_free(struct bfa_rport_s *rport);
+static bfa_boolean_t   bfa_rport_send_fwcreate(struct bfa_rport_s *rp);
+static bfa_boolean_t   bfa_rport_send_fwdelete(struct bfa_rport_s *rp);
+static bfa_boolean_t   bfa_rport_send_fwspeed(struct bfa_rport_s *rp);
+static void            __bfa_cb_rport_online(void *cbarg,
+                                               bfa_boolean_t complete);
+static void            __bfa_cb_rport_offline(void *cbarg,
+                                               bfa_boolean_t complete);
+
+/**
+ * forward declaration for RPORT state machine
+ */
+static void     bfa_rport_sm_uninit(struct bfa_rport_s *rp,
+                                       enum bfa_rport_event event);
+static void     bfa_rport_sm_created(struct bfa_rport_s *rp,
+                                       enum bfa_rport_event event);
+static void     bfa_rport_sm_fwcreate(struct bfa_rport_s *rp,
+                                       enum bfa_rport_event event);
+static void     bfa_rport_sm_online(struct bfa_rport_s *rp,
+                                       enum bfa_rport_event event);
+static void     bfa_rport_sm_fwdelete(struct bfa_rport_s *rp,
+                                       enum bfa_rport_event event);
+static void     bfa_rport_sm_offline(struct bfa_rport_s *rp,
+                                       enum bfa_rport_event event);
+static void     bfa_rport_sm_deleting(struct bfa_rport_s *rp,
+                                       enum bfa_rport_event event);
+static void     bfa_rport_sm_offline_pending(struct bfa_rport_s *rp,
+                                       enum bfa_rport_event event);
+static void     bfa_rport_sm_delete_pending(struct bfa_rport_s *rp,
+                                       enum bfa_rport_event event);
+static void     bfa_rport_sm_iocdisable(struct bfa_rport_s *rp,
+                                       enum bfa_rport_event event);
+static void     bfa_rport_sm_fwcreate_qfull(struct bfa_rport_s *rp,
+                                       enum bfa_rport_event event);
+static void     bfa_rport_sm_fwdelete_qfull(struct bfa_rport_s *rp,
+                                       enum bfa_rport_event event);
+static void     bfa_rport_sm_deleting_qfull(struct bfa_rport_s *rp,
+                                       enum bfa_rport_event event);
+
+/**
+ * PLOG related definitions
+ */
+static int
+plkd_validate_logrec(struct bfa_plog_rec_s *pl_rec)
+{
+       if ((pl_rec->log_type != BFA_PL_LOG_TYPE_INT) &&
+               (pl_rec->log_type != BFA_PL_LOG_TYPE_STRING))
+               return 1;
+
+       if ((pl_rec->log_type != BFA_PL_LOG_TYPE_INT) &&
+               (pl_rec->log_num_ints > BFA_PL_INT_LOG_SZ))
+               return 1;
+
+       return 0;
+}
+
+static void
+bfa_plog_add(struct bfa_plog_s *plog, struct bfa_plog_rec_s *pl_rec)
+{
+       u16 tail;
+       struct bfa_plog_rec_s *pl_recp;
+
+       if (plog->plog_enabled == 0)
+               return;
+
+       if (plkd_validate_logrec(pl_rec)) {
+               bfa_assert(0);
+               return;
+       }
+
+       tail = plog->tail;
+
+       pl_recp = &(plog->plog_recs[tail]);
+
+       bfa_os_memcpy(pl_recp, pl_rec, sizeof(struct bfa_plog_rec_s));
+
+       pl_recp->tv = bfa_os_get_log_time();
+       BFA_PL_LOG_REC_INCR(plog->tail);
+
+       if (plog->head == plog->tail)
+               BFA_PL_LOG_REC_INCR(plog->head);
+}
+
+void
+bfa_plog_init(struct bfa_plog_s *plog)
+{
+       bfa_os_memset((char *)plog, 0, sizeof(struct bfa_plog_s));
+
+       bfa_os_memcpy(plog->plog_sig, BFA_PL_SIG_STR, BFA_PL_SIG_LEN);
+       plog->head = plog->tail = 0;
+       plog->plog_enabled = 1;
+}
+
+void
+bfa_plog_str(struct bfa_plog_s *plog, enum bfa_plog_mid mid,
+               enum bfa_plog_eid event,
+               u16 misc, char *log_str)
+{
+       struct bfa_plog_rec_s  lp;
+
+       if (plog->plog_enabled) {
+               bfa_os_memset(&lp, 0, sizeof(struct bfa_plog_rec_s));
+               lp.mid = mid;
+               lp.eid = event;
+               lp.log_type = BFA_PL_LOG_TYPE_STRING;
+               lp.misc = misc;
+               strncpy(lp.log_entry.string_log, log_str,
+                       BFA_PL_STRING_LOG_SZ - 1);
+               lp.log_entry.string_log[BFA_PL_STRING_LOG_SZ - 1] = '\0';
+               bfa_plog_add(plog, &lp);
+       }
+}
+
+void
+bfa_plog_intarr(struct bfa_plog_s *plog, enum bfa_plog_mid mid,
+               enum bfa_plog_eid event,
+               u16 misc, u32 *intarr, u32 num_ints)
+{
+       struct bfa_plog_rec_s  lp;
+       u32 i;
+
+       if (num_ints > BFA_PL_INT_LOG_SZ)
+               num_ints = BFA_PL_INT_LOG_SZ;
+
+       if (plog->plog_enabled) {
+               bfa_os_memset(&lp, 0, sizeof(struct bfa_plog_rec_s));
+               lp.mid = mid;
+               lp.eid = event;
+               lp.log_type = BFA_PL_LOG_TYPE_INT;
+               lp.misc = misc;
+
+               for (i = 0; i < num_ints; i++)
+                       bfa_os_assign(lp.log_entry.int_log[i],
+                                       intarr[i]);
+
+               lp.log_num_ints = (u8) num_ints;
+
+               bfa_plog_add(plog, &lp);
+       }
+}
+
+void
+bfa_plog_fchdr(struct bfa_plog_s *plog, enum bfa_plog_mid mid,
+                       enum bfa_plog_eid event,
+                       u16 misc, struct fchs_s *fchdr)
+{
+       struct bfa_plog_rec_s  lp;
+       u32     *tmp_int = (u32 *) fchdr;
+       u32     ints[BFA_PL_INT_LOG_SZ];
+
+       if (plog->plog_enabled) {
+               bfa_os_memset(&lp, 0, sizeof(struct bfa_plog_rec_s));
+
+               ints[0] = tmp_int[0];
+               ints[1] = tmp_int[1];
+               ints[2] = tmp_int[4];
+
+               bfa_plog_intarr(plog, mid, event, misc, ints, 3);
+       }
+}
+
+void
+bfa_plog_fchdr_and_pl(struct bfa_plog_s *plog, enum bfa_plog_mid mid,
+                     enum bfa_plog_eid event, u16 misc, struct fchs_s *fchdr,
+                     u32 pld_w0)
+{
+       struct bfa_plog_rec_s  lp;
+       u32     *tmp_int = (u32 *) fchdr;
+       u32     ints[BFA_PL_INT_LOG_SZ];
+
+       if (plog->plog_enabled) {
+               bfa_os_memset(&lp, 0, sizeof(struct bfa_plog_rec_s));
+
+               ints[0] = tmp_int[0];
+               ints[1] = tmp_int[1];
+               ints[2] = tmp_int[4];
+               ints[3] = pld_w0;
+
+               bfa_plog_intarr(plog, mid, event, misc, ints, 4);
+       }
+}
+
+void
+bfa_plog_clear(struct bfa_plog_s *plog)
+{
+       plog->head = plog->tail = 0;
+}
+
+void
+bfa_plog_enable(struct bfa_plog_s *plog)
+{
+       plog->plog_enabled = 1;
+}
+
+void
+bfa_plog_disable(struct bfa_plog_s *plog)
+{
+       plog->plog_enabled = 0;
+}
+
+bfa_boolean_t
+bfa_plog_get_setting(struct bfa_plog_s *plog)
+{
+       return (bfa_boolean_t)plog->plog_enabled;
+}
+
+/**
+ *  fcxp_pvt BFA FCXP private functions
+ */
+
+static void
+claim_fcxp_req_rsp_mem(struct bfa_fcxp_mod_s *mod, struct bfa_meminfo_s *mi)
+{
+       u8             *dm_kva = NULL;
+       u64     dm_pa;
+       u32     buf_pool_sz;
+
+       dm_kva = bfa_meminfo_dma_virt(mi);
+       dm_pa = bfa_meminfo_dma_phys(mi);
+
+       buf_pool_sz = mod->req_pld_sz * mod->num_fcxps;
+
+       /*
+        * Initialize the fcxp req payload list
+        */
+       mod->req_pld_list_kva = dm_kva;
+       mod->req_pld_list_pa = dm_pa;
+       dm_kva += buf_pool_sz;
+       dm_pa += buf_pool_sz;
+       bfa_os_memset(mod->req_pld_list_kva, 0, buf_pool_sz);
+
+       /*
+        * Initialize the fcxp rsp payload list
+        */
+       buf_pool_sz = mod->rsp_pld_sz * mod->num_fcxps;
+       mod->rsp_pld_list_kva = dm_kva;
+       mod->rsp_pld_list_pa = dm_pa;
+       dm_kva += buf_pool_sz;
+       dm_pa += buf_pool_sz;
+       bfa_os_memset(mod->rsp_pld_list_kva, 0, buf_pool_sz);
+
+       bfa_meminfo_dma_virt(mi) = dm_kva;
+       bfa_meminfo_dma_phys(mi) = dm_pa;
+}
+
+static void
+claim_fcxps_mem(struct bfa_fcxp_mod_s *mod, struct bfa_meminfo_s *mi)
+{
+       u16     i;
+       struct bfa_fcxp_s *fcxp;
+
+       fcxp = (struct bfa_fcxp_s *) bfa_meminfo_kva(mi);
+       bfa_os_memset(fcxp, 0, sizeof(struct bfa_fcxp_s) * mod->num_fcxps);
+
+       INIT_LIST_HEAD(&mod->fcxp_free_q);
+       INIT_LIST_HEAD(&mod->fcxp_active_q);
+
+       mod->fcxp_list = fcxp;
+
+       for (i = 0; i < mod->num_fcxps; i++) {
+               fcxp->fcxp_mod = mod;
+               fcxp->fcxp_tag = i;
+
+               list_add_tail(&fcxp->qe, &mod->fcxp_free_q);
+               bfa_reqq_winit(&fcxp->reqq_wqe, bfa_fcxp_qresume, fcxp);
+               fcxp->reqq_waiting = BFA_FALSE;
+
+               fcxp = fcxp + 1;
+       }
+
+       bfa_meminfo_kva(mi) = (void *)fcxp;
+}
+
+static void
+bfa_fcxp_meminfo(struct bfa_iocfc_cfg_s *cfg, u32 *ndm_len,
+                u32 *dm_len)
+{
+       u16     num_fcxp_reqs = cfg->fwcfg.num_fcxp_reqs;
+
+       if (num_fcxp_reqs == 0)
+               return;
+
+       /*
+        * Account for req/rsp payload
+        */
+       *dm_len += BFA_FCXP_MAX_IBUF_SZ * num_fcxp_reqs;
+       if (cfg->drvcfg.min_cfg)
+               *dm_len += BFA_FCXP_MAX_IBUF_SZ * num_fcxp_reqs;
+       else
+               *dm_len += BFA_FCXP_MAX_LBUF_SZ * num_fcxp_reqs;
+
+       /*
+        * Account for fcxp structs
+        */
+       *ndm_len += sizeof(struct bfa_fcxp_s) * num_fcxp_reqs;
+}
+
+static void
+bfa_fcxp_attach(struct bfa_s *bfa, void *bfad, struct bfa_iocfc_cfg_s *cfg,
+               struct bfa_meminfo_s *meminfo, struct bfa_pcidev_s *pcidev)
+{
+       struct bfa_fcxp_mod_s *mod = BFA_FCXP_MOD(bfa);
+
+       bfa_os_memset(mod, 0, sizeof(struct bfa_fcxp_mod_s));
+       mod->bfa = bfa;
+       mod->num_fcxps = cfg->fwcfg.num_fcxp_reqs;
+
+       /**
+        * Initialize FCXP request and response payload sizes.
+        */
+       mod->req_pld_sz = mod->rsp_pld_sz = BFA_FCXP_MAX_IBUF_SZ;
+       if (!cfg->drvcfg.min_cfg)
+               mod->rsp_pld_sz = BFA_FCXP_MAX_LBUF_SZ;
+
+       INIT_LIST_HEAD(&mod->wait_q);
+
+       claim_fcxp_req_rsp_mem(mod, meminfo);
+       claim_fcxps_mem(mod, meminfo);
+}
+
+static void
+bfa_fcxp_detach(struct bfa_s *bfa)
+{
+}
+
+static void
+bfa_fcxp_start(struct bfa_s *bfa)
+{
+}
+
+static void
+bfa_fcxp_stop(struct bfa_s *bfa)
+{
+}
+
+static void
+bfa_fcxp_iocdisable(struct bfa_s *bfa)
+{
+       struct bfa_fcxp_mod_s *mod = BFA_FCXP_MOD(bfa);
+       struct bfa_fcxp_s *fcxp;
+       struct list_head              *qe, *qen;
+
+       list_for_each_safe(qe, qen, &mod->fcxp_active_q) {
+               fcxp = (struct bfa_fcxp_s *) qe;
+               if (fcxp->caller == NULL) {
+                       fcxp->send_cbfn(fcxp->caller, fcxp, fcxp->send_cbarg,
+                                       BFA_STATUS_IOC_FAILURE, 0, 0, NULL);
+                       bfa_fcxp_free(fcxp);
+               } else {
+                       fcxp->rsp_status = BFA_STATUS_IOC_FAILURE;
+                       bfa_cb_queue(bfa, &fcxp->hcb_qe,
+                                    __bfa_fcxp_send_cbfn, fcxp);
+               }
+       }
+}
+
+static struct bfa_fcxp_s *
+bfa_fcxp_get(struct bfa_fcxp_mod_s *fm)
+{
+       struct bfa_fcxp_s *fcxp;
+
+       bfa_q_deq(&fm->fcxp_free_q, &fcxp);
+
+       if (fcxp)
+               list_add_tail(&fcxp->qe, &fm->fcxp_active_q);
+
+       return fcxp;
+}
+
+static void
+bfa_fcxp_init_reqrsp(struct bfa_fcxp_s *fcxp,
+              struct bfa_s *bfa,
+              u8 *use_ibuf,
+              u32 *nr_sgles,
+              bfa_fcxp_get_sgaddr_t *r_sga_cbfn,
+              bfa_fcxp_get_sglen_t *r_sglen_cbfn,
+              struct list_head *r_sgpg_q,
+              int n_sgles,
+              bfa_fcxp_get_sgaddr_t sga_cbfn,
+              bfa_fcxp_get_sglen_t sglen_cbfn)
+{
+
+       bfa_assert(bfa != NULL);
+
+       bfa_trc(bfa, fcxp->fcxp_tag);
+
+       if (n_sgles == 0) {
+               *use_ibuf = 1;
+       } else {
+               bfa_assert(*sga_cbfn != NULL);
+               bfa_assert(*sglen_cbfn != NULL);
+
+               *use_ibuf = 0;
+               *r_sga_cbfn = sga_cbfn;
+               *r_sglen_cbfn = sglen_cbfn;
+
+               *nr_sgles = n_sgles;
+
+               /*
+                * alloc required sgpgs
+                */
+               if (n_sgles > BFI_SGE_INLINE)
+                       bfa_assert(0);
+       }
+
+}
+
+static void
+bfa_fcxp_init(struct bfa_fcxp_s *fcxp,
+              void *caller, struct bfa_s *bfa, int nreq_sgles,
+              int nrsp_sgles, bfa_fcxp_get_sgaddr_t req_sga_cbfn,
+              bfa_fcxp_get_sglen_t req_sglen_cbfn,
+              bfa_fcxp_get_sgaddr_t rsp_sga_cbfn,
+              bfa_fcxp_get_sglen_t rsp_sglen_cbfn)
+{
+
+       bfa_assert(bfa != NULL);
+
+       bfa_trc(bfa, fcxp->fcxp_tag);
+
+       fcxp->caller = caller;
+
+       bfa_fcxp_init_reqrsp(fcxp, bfa,
+               &fcxp->use_ireqbuf, &fcxp->nreq_sgles, &fcxp->req_sga_cbfn,
+               &fcxp->req_sglen_cbfn, &fcxp->req_sgpg_q,
+               nreq_sgles, req_sga_cbfn, req_sglen_cbfn);
+
+       bfa_fcxp_init_reqrsp(fcxp, bfa,
+               &fcxp->use_irspbuf, &fcxp->nrsp_sgles, &fcxp->rsp_sga_cbfn,
+               &fcxp->rsp_sglen_cbfn, &fcxp->rsp_sgpg_q,
+               nrsp_sgles, rsp_sga_cbfn, rsp_sglen_cbfn);
+
+}
+
+static void
+bfa_fcxp_put(struct bfa_fcxp_s *fcxp)
+{
+       struct bfa_fcxp_mod_s *mod = fcxp->fcxp_mod;
+       struct bfa_fcxp_wqe_s *wqe;
+
+       bfa_q_deq(&mod->wait_q, &wqe);
+       if (wqe) {
+               bfa_trc(mod->bfa, fcxp->fcxp_tag);
+
+               bfa_fcxp_init(fcxp, wqe->caller, wqe->bfa, wqe->nreq_sgles,
+                       wqe->nrsp_sgles, wqe->req_sga_cbfn,
+                       wqe->req_sglen_cbfn, wqe->rsp_sga_cbfn,
+                       wqe->rsp_sglen_cbfn);
+
+               wqe->alloc_cbfn(wqe->alloc_cbarg, fcxp);
+               return;
+       }
+
+       bfa_assert(bfa_q_is_on_q(&mod->fcxp_active_q, fcxp));
+       list_del(&fcxp->qe);
+       list_add_tail(&fcxp->qe, &mod->fcxp_free_q);
+}
+
+static void
+bfa_fcxp_null_comp(void *bfad_fcxp, struct bfa_fcxp_s *fcxp, void *cbarg,
+                  bfa_status_t req_status, u32 rsp_len,
+                  u32 resid_len, struct fchs_s *rsp_fchs)
+{
+       /* discarded fcxp completion */
+}
+
+static void
+__bfa_fcxp_send_cbfn(void *cbarg, bfa_boolean_t complete)
+{
+       struct bfa_fcxp_s *fcxp = cbarg;
+
+       if (complete) {
+               fcxp->send_cbfn(fcxp->caller, fcxp, fcxp->send_cbarg,
+                               fcxp->rsp_status, fcxp->rsp_len,
+                               fcxp->residue_len, &fcxp->rsp_fchs);
+       } else {
+               bfa_fcxp_free(fcxp);
+       }
+}
+
+static void
+hal_fcxp_send_comp(struct bfa_s *bfa, struct bfi_fcxp_send_rsp_s *fcxp_rsp)
+{
+       struct bfa_fcxp_mod_s   *mod = BFA_FCXP_MOD(bfa);
+       struct bfa_fcxp_s       *fcxp;
+       u16             fcxp_tag = bfa_os_ntohs(fcxp_rsp->fcxp_tag);
+
+       bfa_trc(bfa, fcxp_tag);
+
+       fcxp_rsp->rsp_len = bfa_os_ntohl(fcxp_rsp->rsp_len);
+
+       /**
+        * @todo f/w should not set residue to non-0 when everything
+        *       is received.
+        */
+       if (fcxp_rsp->req_status == BFA_STATUS_OK)
+               fcxp_rsp->residue_len = 0;
+       else
+               fcxp_rsp->residue_len = bfa_os_ntohl(fcxp_rsp->residue_len);
+
+       fcxp = BFA_FCXP_FROM_TAG(mod, fcxp_tag);
+
+       bfa_assert(fcxp->send_cbfn != NULL);
+
+       hal_fcxp_rx_plog(mod->bfa, fcxp, fcxp_rsp);
+
+       if (fcxp->send_cbfn != NULL) {
+               bfa_trc(mod->bfa, (NULL == fcxp->caller));
+               if (fcxp->caller == NULL) {
+                       fcxp->send_cbfn(fcxp->caller, fcxp, fcxp->send_cbarg,
+                                       fcxp_rsp->req_status, fcxp_rsp->rsp_len,
+                                       fcxp_rsp->residue_len, &fcxp_rsp->fchs);
+                       /*
+                        * fcxp automatically freed on return from the callback
+                        */
+                       bfa_fcxp_free(fcxp);
+               } else {
+                       fcxp->rsp_status = fcxp_rsp->req_status;
+                       fcxp->rsp_len = fcxp_rsp->rsp_len;
+                       fcxp->residue_len = fcxp_rsp->residue_len;
+                       fcxp->rsp_fchs = fcxp_rsp->fchs;
+
+                       bfa_cb_queue(bfa, &fcxp->hcb_qe,
+                                       __bfa_fcxp_send_cbfn, fcxp);
+               }
+       } else {
+               bfa_trc(bfa, (NULL == fcxp->send_cbfn));
+       }
+}
+
+static void
+hal_fcxp_set_local_sges(struct bfi_sge_s *sge, u32 reqlen, u64 req_pa)
+{
+       union bfi_addr_u      sga_zero = { {0} };
+
+       sge->sg_len = reqlen;
+       sge->flags = BFI_SGE_DATA_LAST;
+       bfa_dma_addr_set(sge[0].sga, req_pa);
+       bfa_sge_to_be(sge);
+       sge++;
+
+       sge->sga = sga_zero;
+       sge->sg_len = reqlen;
+       sge->flags = BFI_SGE_PGDLEN;
+       bfa_sge_to_be(sge);
+}
+
+static void
+hal_fcxp_tx_plog(struct bfa_s *bfa, u32 reqlen, struct bfa_fcxp_s *fcxp,
+                struct fchs_s *fchs)
+{
+       /*
+        * TODO: TX ox_id
+        */
+       if (reqlen > 0) {
+               if (fcxp->use_ireqbuf) {
+                       u32     pld_w0 =
+                               *((u32 *) BFA_FCXP_REQ_PLD(fcxp));
+
+                       bfa_plog_fchdr_and_pl(bfa->plog, BFA_PL_MID_HAL_FCXP,
+                                       BFA_PL_EID_TX,
+                                       reqlen + sizeof(struct fchs_s), fchs,
+                                       pld_w0);
+               } else {
+                       bfa_plog_fchdr(bfa->plog, BFA_PL_MID_HAL_FCXP,
+                                       BFA_PL_EID_TX,
+                                       reqlen + sizeof(struct fchs_s),
+                                       fchs);
+               }
+       } else {
+               bfa_plog_fchdr(bfa->plog, BFA_PL_MID_HAL_FCXP, BFA_PL_EID_TX,
+                              reqlen + sizeof(struct fchs_s), fchs);
+       }
+}
+
+static void
+hal_fcxp_rx_plog(struct bfa_s *bfa, struct bfa_fcxp_s *fcxp,
+                struct bfi_fcxp_send_rsp_s *fcxp_rsp)
+{
+       if (fcxp_rsp->rsp_len > 0) {
+               if (fcxp->use_irspbuf) {
+                       u32     pld_w0 =
+                               *((u32 *) BFA_FCXP_RSP_PLD(fcxp));
+
+                       bfa_plog_fchdr_and_pl(bfa->plog, BFA_PL_MID_HAL_FCXP,
+                                             BFA_PL_EID_RX,
+                                             (u16) fcxp_rsp->rsp_len,
+                                             &fcxp_rsp->fchs, pld_w0);
+               } else {
+                       bfa_plog_fchdr(bfa->plog, BFA_PL_MID_HAL_FCXP,
+                                      BFA_PL_EID_RX,
+                                      (u16) fcxp_rsp->rsp_len,
+                                      &fcxp_rsp->fchs);
+               }
+       } else {
+               bfa_plog_fchdr(bfa->plog, BFA_PL_MID_HAL_FCXP, BFA_PL_EID_RX,
+                              (u16) fcxp_rsp->rsp_len, &fcxp_rsp->fchs);
+       }
+}
+
+/**
+ * Handler to resume sending fcxp when space in available in cpe queue.
+ */
+static void
+bfa_fcxp_qresume(void *cbarg)
+{
+       struct bfa_fcxp_s               *fcxp = cbarg;
+       struct bfa_s                    *bfa = fcxp->fcxp_mod->bfa;
+       struct bfi_fcxp_send_req_s      *send_req;
+
+       fcxp->reqq_waiting = BFA_FALSE;
+       send_req = bfa_reqq_next(bfa, BFA_REQQ_FCXP);
+       bfa_fcxp_queue(fcxp, send_req);
+}
+
+/**
+ * Queue fcxp send request to foimrware.
+ */
+static void
+bfa_fcxp_queue(struct bfa_fcxp_s *fcxp, struct bfi_fcxp_send_req_s *send_req)
+{
+       struct bfa_s                    *bfa = fcxp->fcxp_mod->bfa;
+       struct bfa_fcxp_req_info_s      *reqi = &fcxp->req_info;
+       struct bfa_fcxp_rsp_info_s      *rspi = &fcxp->rsp_info;
+       struct bfa_rport_s              *rport = reqi->bfa_rport;
+
+       bfi_h2i_set(send_req->mh, BFI_MC_FCXP, BFI_FCXP_H2I_SEND_REQ,
+                   bfa_lpuid(bfa));
+
+       send_req->fcxp_tag = bfa_os_htons(fcxp->fcxp_tag);
+       if (rport) {
+               send_req->rport_fw_hndl = rport->fw_handle;
+               send_req->max_frmsz = bfa_os_htons(rport->rport_info.max_frmsz);
+               if (send_req->max_frmsz == 0)
+                       send_req->max_frmsz = bfa_os_htons(FC_MAX_PDUSZ);
+       } else {
+               send_req->rport_fw_hndl = 0;
+               send_req->max_frmsz = bfa_os_htons(FC_MAX_PDUSZ);
+       }
+
+       send_req->vf_id = bfa_os_htons(reqi->vf_id);
+       send_req->lp_tag = reqi->lp_tag;
+       send_req->class = reqi->class;
+       send_req->rsp_timeout = rspi->rsp_timeout;
+       send_req->cts = reqi->cts;
+       send_req->fchs = reqi->fchs;
+
+       send_req->req_len = bfa_os_htonl(reqi->req_tot_len);
+       send_req->rsp_maxlen = bfa_os_htonl(rspi->rsp_maxlen);
+
+       /*
+        * setup req sgles
+        */
+       if (fcxp->use_ireqbuf == 1) {
+               hal_fcxp_set_local_sges(send_req->req_sge, reqi->req_tot_len,
+                                       BFA_FCXP_REQ_PLD_PA(fcxp));
+       } else {
+               if (fcxp->nreq_sgles > 0) {
+                       bfa_assert(fcxp->nreq_sgles == 1);
+                       hal_fcxp_set_local_sges(send_req->req_sge,
+                                               reqi->req_tot_len,
+                                               fcxp->req_sga_cbfn(fcxp->caller,
+                                                                  0));
+               } else {
+                       bfa_assert(reqi->req_tot_len == 0);
+                       hal_fcxp_set_local_sges(send_req->rsp_sge, 0, 0);
+               }
+       }
+
+       /*
+        * setup rsp sgles
+        */
+       if (fcxp->use_irspbuf == 1) {
+               bfa_assert(rspi->rsp_maxlen <= BFA_FCXP_MAX_LBUF_SZ);
+
+               hal_fcxp_set_local_sges(send_req->rsp_sge, rspi->rsp_maxlen,
+                                       BFA_FCXP_RSP_PLD_PA(fcxp));
+
+       } else {
+               if (fcxp->nrsp_sgles > 0) {
+                       bfa_assert(fcxp->nrsp_sgles == 1);
+                       hal_fcxp_set_local_sges(send_req->rsp_sge,
+                                               rspi->rsp_maxlen,
+                                               fcxp->rsp_sga_cbfn(fcxp->caller,
+                                                                  0));
+               } else {
+                       bfa_assert(rspi->rsp_maxlen == 0);
+                       hal_fcxp_set_local_sges(send_req->rsp_sge, 0, 0);
+               }
+       }
+
+       hal_fcxp_tx_plog(bfa, reqi->req_tot_len, fcxp, &reqi->fchs);
+
+       bfa_reqq_produce(bfa, BFA_REQQ_FCXP);
+
+       bfa_trc(bfa, bfa_reqq_pi(bfa, BFA_REQQ_FCXP));
+       bfa_trc(bfa, bfa_reqq_ci(bfa, BFA_REQQ_FCXP));
+}
+
+/**
+ *  hal_fcxp_api BFA FCXP API
+ */
+
+/**
+ * Allocate an FCXP instance to send a response or to send a request
+ * that has a response. Request/response buffers are allocated by caller.
+ *
+ * @param[in]  bfa             BFA bfa instance
+ * @param[in]  nreq_sgles      Number of SG elements required for request
+ *                             buffer. 0, if fcxp internal buffers are used.
+ *                             Use bfa_fcxp_get_reqbuf() to get the
+ *                             internal req buffer.
+ * @param[in]  req_sgles       SG elements describing request buffer. Will be
+ *                             copied in by BFA and hence can be freed on
+ *                             return from this function.
+ * @param[in]  get_req_sga     function ptr to be called to get a request SG
+ *                             Address (given the sge index).
+ * @param[in]  get_req_sglen   function ptr to be called to get a request SG
+ *                             len (given the sge index).
+ * @param[in]  get_rsp_sga     function ptr to be called to get a response SG
+ *                             Address (given the sge index).
+ * @param[in]  get_rsp_sglen   function ptr to be called to get a response SG
+ *                             len (given the sge index).
+ *
+ * @return FCXP instance. NULL on failure.
+ */
+struct bfa_fcxp_s *
+bfa_fcxp_alloc(void *caller, struct bfa_s *bfa, int nreq_sgles,
+              int nrsp_sgles, bfa_fcxp_get_sgaddr_t req_sga_cbfn,
+              bfa_fcxp_get_sglen_t req_sglen_cbfn,
+              bfa_fcxp_get_sgaddr_t rsp_sga_cbfn,
+              bfa_fcxp_get_sglen_t rsp_sglen_cbfn)
+{
+       struct bfa_fcxp_s *fcxp = NULL;
+
+       bfa_assert(bfa != NULL);
+
+       fcxp = bfa_fcxp_get(BFA_FCXP_MOD(bfa));
+       if (fcxp == NULL)
+               return NULL;
+
+       bfa_trc(bfa, fcxp->fcxp_tag);
+
+       bfa_fcxp_init(fcxp, caller, bfa, nreq_sgles, nrsp_sgles, req_sga_cbfn,
+                       req_sglen_cbfn, rsp_sga_cbfn, rsp_sglen_cbfn);
+
+       return fcxp;
+}
+
+/**
+ * Get the internal request buffer pointer
+ *
+ * @param[in]  fcxp    BFA fcxp pointer
+ *
+ * @return             pointer to the internal request buffer
+ */
+void *
+bfa_fcxp_get_reqbuf(struct bfa_fcxp_s *fcxp)
+{
+       struct bfa_fcxp_mod_s *mod = fcxp->fcxp_mod;
+       void    *reqbuf;
+
+       bfa_assert(fcxp->use_ireqbuf == 1);
+       reqbuf = ((u8 *)mod->req_pld_list_kva) +
+               fcxp->fcxp_tag * mod->req_pld_sz;
+       return reqbuf;
+}
+
+u32
+bfa_fcxp_get_reqbufsz(struct bfa_fcxp_s *fcxp)
+{
+       struct bfa_fcxp_mod_s *mod = fcxp->fcxp_mod;
+
+       return mod->req_pld_sz;
+}
+
+/**
+ * Get the internal response buffer pointer
+ *
+ * @param[in]  fcxp    BFA fcxp pointer
+ *
+ * @return             pointer to the internal request buffer
+ */
+void *
+bfa_fcxp_get_rspbuf(struct bfa_fcxp_s *fcxp)
+{
+       struct bfa_fcxp_mod_s *mod = fcxp->fcxp_mod;
+       void    *rspbuf;
+
+       bfa_assert(fcxp->use_irspbuf == 1);
+
+       rspbuf = ((u8 *)mod->rsp_pld_list_kva) +
+               fcxp->fcxp_tag * mod->rsp_pld_sz;
+       return rspbuf;
+}
+
+/**
+ *             Free the BFA FCXP
+ *
+ * @param[in]  fcxp                    BFA fcxp pointer
+ *
+ * @return             void
+ */
+void
+bfa_fcxp_free(struct bfa_fcxp_s *fcxp)
+{
+       struct bfa_fcxp_mod_s *mod = fcxp->fcxp_mod;
+
+       bfa_assert(fcxp != NULL);
+       bfa_trc(mod->bfa, fcxp->fcxp_tag);
+       bfa_fcxp_put(fcxp);
+}
+
+/**
+ * Send a FCXP request
+ *
+ * @param[in]  fcxp    BFA fcxp pointer
+ * @param[in]  rport   BFA rport pointer. Could be left NULL for WKA rports
+ * @param[in]  vf_id   virtual Fabric ID
+ * @param[in]  lp_tag  lport tag
+ * @param[in]  cts     use Continous sequence
+ * @param[in]  cos     fc Class of Service
+ * @param[in]  reqlen  request length, does not include FCHS length
+ * @param[in]  fchs    fc Header Pointer. The header content will be copied
+ *                     in by BFA.
+ *
+ * @param[in]  cbfn    call back function to be called on receiving
+ *                                                             the response
+ * @param[in]  cbarg   arg for cbfn
+ * @param[in]  rsp_timeout
+ *                     response timeout
+ *
+ * @return             bfa_status_t
+ */
+void
+bfa_fcxp_send(struct bfa_fcxp_s *fcxp, struct bfa_rport_s *rport,
+             u16 vf_id, u8 lp_tag, bfa_boolean_t cts, enum fc_cos cos,
+             u32 reqlen, struct fchs_s *fchs, bfa_cb_fcxp_send_t cbfn,
+             void *cbarg, u32 rsp_maxlen, u8 rsp_timeout)
+{
+       struct bfa_s                    *bfa  = fcxp->fcxp_mod->bfa;
+       struct bfa_fcxp_req_info_s      *reqi = &fcxp->req_info;
+       struct bfa_fcxp_rsp_info_s      *rspi = &fcxp->rsp_info;
+       struct bfi_fcxp_send_req_s      *send_req;
+
+       bfa_trc(bfa, fcxp->fcxp_tag);
+
+       /**
+        * setup request/response info
+        */
+       reqi->bfa_rport = rport;
+       reqi->vf_id = vf_id;
+       reqi->lp_tag = lp_tag;
+       reqi->class = cos;
+       rspi->rsp_timeout = rsp_timeout;
+       reqi->cts = cts;
+       reqi->fchs = *fchs;
+       reqi->req_tot_len = reqlen;
+       rspi->rsp_maxlen = rsp_maxlen;
+       fcxp->send_cbfn = cbfn ? cbfn : bfa_fcxp_null_comp;
+       fcxp->send_cbarg = cbarg;
+
+       /**
+        * If no room in CPE queue, wait for space in request queue
+        */
+       send_req = bfa_reqq_next(bfa, BFA_REQQ_FCXP);
+       if (!send_req) {
+               bfa_trc(bfa, fcxp->fcxp_tag);
+               fcxp->reqq_waiting = BFA_TRUE;
+               bfa_reqq_wait(bfa, BFA_REQQ_FCXP, &fcxp->reqq_wqe);
+               return;
+       }
+
+       bfa_fcxp_queue(fcxp, send_req);
+}
+
+/**
+ * Abort a BFA FCXP
+ *
+ * @param[in]  fcxp    BFA fcxp pointer
+ *
+ * @return             void
+ */
+bfa_status_t
+bfa_fcxp_abort(struct bfa_fcxp_s *fcxp)
+{
+       bfa_trc(fcxp->fcxp_mod->bfa, fcxp->fcxp_tag);
+       bfa_assert(0);
+       return BFA_STATUS_OK;
+}
+
+void
+bfa_fcxp_alloc_wait(struct bfa_s *bfa, struct bfa_fcxp_wqe_s *wqe,
+              bfa_fcxp_alloc_cbfn_t alloc_cbfn, void *alloc_cbarg,
+              void *caller, int nreq_sgles,
+              int nrsp_sgles, bfa_fcxp_get_sgaddr_t req_sga_cbfn,
+              bfa_fcxp_get_sglen_t req_sglen_cbfn,
+              bfa_fcxp_get_sgaddr_t rsp_sga_cbfn,
+              bfa_fcxp_get_sglen_t rsp_sglen_cbfn)
+{
+       struct bfa_fcxp_mod_s *mod = BFA_FCXP_MOD(bfa);
+
+       bfa_assert(list_empty(&mod->fcxp_free_q));
+
+       wqe->alloc_cbfn = alloc_cbfn;
+       wqe->alloc_cbarg = alloc_cbarg;
+       wqe->caller = caller;
+       wqe->bfa = bfa;
+       wqe->nreq_sgles = nreq_sgles;
+       wqe->nrsp_sgles = nrsp_sgles;
+       wqe->req_sga_cbfn = req_sga_cbfn;
+       wqe->req_sglen_cbfn = req_sglen_cbfn;
+       wqe->rsp_sga_cbfn = rsp_sga_cbfn;
+       wqe->rsp_sglen_cbfn = rsp_sglen_cbfn;
+
+       list_add_tail(&wqe->qe, &mod->wait_q);
+}
+
+void
+bfa_fcxp_walloc_cancel(struct bfa_s *bfa, struct bfa_fcxp_wqe_s *wqe)
+{
+       struct bfa_fcxp_mod_s *mod = BFA_FCXP_MOD(bfa);
+
+       bfa_assert(bfa_q_is_on_q(&mod->wait_q, wqe));
+       list_del(&wqe->qe);
+}
+
+void
+bfa_fcxp_discard(struct bfa_fcxp_s *fcxp)
+{
+       /**
+        * If waiting for room in request queue, cancel reqq wait
+        * and free fcxp.
+        */
+       if (fcxp->reqq_waiting) {
+               fcxp->reqq_waiting = BFA_FALSE;
+               bfa_reqq_wcancel(&fcxp->reqq_wqe);
+               bfa_fcxp_free(fcxp);
+               return;
+       }
+
+       fcxp->send_cbfn = bfa_fcxp_null_comp;
+}
+
+
+
+/**
+ *  hal_fcxp_public BFA FCXP public functions
+ */
+
+void
+bfa_fcxp_isr(struct bfa_s *bfa, struct bfi_msg_s *msg)
+{
+       switch (msg->mhdr.msg_id) {
+       case BFI_FCXP_I2H_SEND_RSP:
+               hal_fcxp_send_comp(bfa, (struct bfi_fcxp_send_rsp_s *) msg);
+               break;
+
+       default:
+               bfa_trc(bfa, msg->mhdr.msg_id);
+               bfa_assert(0);
+       }
+}
+
+u32
+bfa_fcxp_get_maxrsp(struct bfa_s *bfa)
+{
+       struct bfa_fcxp_mod_s *mod = BFA_FCXP_MOD(bfa);
+
+       return mod->rsp_pld_sz;
+}
+
+
+/**
+ *  BFA LPS state machine functions
+ */
+
+/**
+ * Init state -- no login
+ */
+static void
+bfa_lps_sm_init(struct bfa_lps_s *lps, enum bfa_lps_event event)
+{
+       bfa_trc(lps->bfa, lps->lp_tag);
+       bfa_trc(lps->bfa, event);
+
+       switch (event) {
+       case BFA_LPS_SM_LOGIN:
+               if (bfa_reqq_full(lps->bfa, lps->reqq)) {
+                       bfa_sm_set_state(lps, bfa_lps_sm_loginwait);
+                       bfa_reqq_wait(lps->bfa, lps->reqq, &lps->wqe);
+               } else {
+                       bfa_sm_set_state(lps, bfa_lps_sm_login);
+                       bfa_lps_send_login(lps);
+               }
+
+               if (lps->fdisc)
+                       bfa_plog_str(lps->bfa->plog, BFA_PL_MID_LPS,
+                               BFA_PL_EID_LOGIN, 0, "FDISC Request");
+               else
+                       bfa_plog_str(lps->bfa->plog, BFA_PL_MID_LPS,
+                               BFA_PL_EID_LOGIN, 0, "FLOGI Request");
+               break;
+
+       case BFA_LPS_SM_LOGOUT:
+               bfa_lps_logout_comp(lps);
+               break;
+
+       case BFA_LPS_SM_DELETE:
+               bfa_lps_free(lps);
+               break;
+
+       case BFA_LPS_SM_RX_CVL:
+       case BFA_LPS_SM_OFFLINE:
+               break;
+
+       case BFA_LPS_SM_FWRSP:
+               /*
+                * Could happen when fabric detects loopback and discards
+                * the lps request. Fw will eventually sent out the timeout
+                * Just ignore
+                */
+               break;
+
+       default:
+               bfa_sm_fault(lps->bfa, event);
+       }
+}
+
+/**
+ * login is in progress -- awaiting response from firmware
+ */
+static void
+bfa_lps_sm_login(struct bfa_lps_s *lps, enum bfa_lps_event event)
+{
+       bfa_trc(lps->bfa, lps->lp_tag);
+       bfa_trc(lps->bfa, event);
+
+       switch (event) {
+       case BFA_LPS_SM_FWRSP:
+               if (lps->status == BFA_STATUS_OK) {
+                       bfa_sm_set_state(lps, bfa_lps_sm_online);
+                       if (lps->fdisc)
+                               bfa_plog_str(lps->bfa->plog, BFA_PL_MID_LPS,
+                                       BFA_PL_EID_LOGIN, 0, "FDISC Accept");
+                       else
+                               bfa_plog_str(lps->bfa->plog, BFA_PL_MID_LPS,
+                                       BFA_PL_EID_LOGIN, 0, "FLOGI Accept");
+               } else {
+                       bfa_sm_set_state(lps, bfa_lps_sm_init);
+                       if (lps->fdisc)
+                               bfa_plog_str(lps->bfa->plog, BFA_PL_MID_LPS,
+                                       BFA_PL_EID_LOGIN, 0,
+                                       "FDISC Fail (RJT or timeout)");
+                       else
+                               bfa_plog_str(lps->bfa->plog, BFA_PL_MID_LPS,
+                                       BFA_PL_EID_LOGIN, 0,
+                                       "FLOGI Fail (RJT or timeout)");
+               }
+               bfa_lps_login_comp(lps);
+               break;
+
+       case BFA_LPS_SM_OFFLINE:
+               bfa_sm_set_state(lps, bfa_lps_sm_init);
+               break;
+
+       default:
+               bfa_sm_fault(lps->bfa, event);
+       }
+}
+
+/**
+ * login pending - awaiting space in request queue
+ */
+static void
+bfa_lps_sm_loginwait(struct bfa_lps_s *lps, enum bfa_lps_event event)
+{
+       bfa_trc(lps->bfa, lps->lp_tag);
+       bfa_trc(lps->bfa, event);
+
+       switch (event) {
+       case BFA_LPS_SM_RESUME:
+               bfa_sm_set_state(lps, bfa_lps_sm_login);
+               break;
+
+       case BFA_LPS_SM_OFFLINE:
+               bfa_sm_set_state(lps, bfa_lps_sm_init);
+               bfa_reqq_wcancel(&lps->wqe);
+               break;
+
+       case BFA_LPS_SM_RX_CVL:
+               /*
+                * Login was not even sent out; so when getting out
+                * of this state, it will appear like a login retry
+                * after Clear virtual link
+                */
+               break;
+
+       default:
+               bfa_sm_fault(lps->bfa, event);
+       }
+}
+
+/**
+ * login complete
+ */
+static void
+bfa_lps_sm_online(struct bfa_lps_s *lps, enum bfa_lps_event event)
+{
+       bfa_trc(lps->bfa, lps->lp_tag);
+       bfa_trc(lps->bfa, event);
+
+       switch (event) {
+       case BFA_LPS_SM_LOGOUT:
+               if (bfa_reqq_full(lps->bfa, lps->reqq)) {
+                       bfa_sm_set_state(lps, bfa_lps_sm_logowait);
+                       bfa_reqq_wait(lps->bfa, lps->reqq, &lps->wqe);
+               } else {
+                       bfa_sm_set_state(lps, bfa_lps_sm_logout);
+                       bfa_lps_send_logout(lps);
+               }
+               bfa_plog_str(lps->bfa->plog, BFA_PL_MID_LPS,
+                       BFA_PL_EID_LOGO, 0, "Logout");
+               break;
+
+       case BFA_LPS_SM_RX_CVL:
+               bfa_sm_set_state(lps, bfa_lps_sm_init);
+
+               /* Let the vport module know about this event */
+               bfa_lps_cvl_event(lps);
+               bfa_plog_str(lps->bfa->plog, BFA_PL_MID_LPS,
+                       BFA_PL_EID_FIP_FCF_CVL, 0, "FCF Clear Virt. Link Rx");
+               break;
+
+       case BFA_LPS_SM_OFFLINE:
+       case BFA_LPS_SM_DELETE:
+               bfa_sm_set_state(lps, bfa_lps_sm_init);
+               break;
+
+       default:
+               bfa_sm_fault(lps->bfa, event);
+       }
+}
+
+/**
+ * logout in progress - awaiting firmware response
+ */
+static void
+bfa_lps_sm_logout(struct bfa_lps_s *lps, enum bfa_lps_event event)
+{
+       bfa_trc(lps->bfa, lps->lp_tag);
+       bfa_trc(lps->bfa, event);
+
+       switch (event) {
+       case BFA_LPS_SM_FWRSP:
+               bfa_sm_set_state(lps, bfa_lps_sm_init);
+               bfa_lps_logout_comp(lps);
+               break;
+
+       case BFA_LPS_SM_OFFLINE:
+               bfa_sm_set_state(lps, bfa_lps_sm_init);
+               break;
+
+       default:
+               bfa_sm_fault(lps->bfa, event);
+       }
+}
+
+/**
+ * logout pending -- awaiting space in request queue
+ */
+static void
+bfa_lps_sm_logowait(struct bfa_lps_s *lps, enum bfa_lps_event event)
+{
+       bfa_trc(lps->bfa, lps->lp_tag);
+       bfa_trc(lps->bfa, event);
+
+       switch (event) {
+       case BFA_LPS_SM_RESUME:
+               bfa_sm_set_state(lps, bfa_lps_sm_logout);
+               bfa_lps_send_logout(lps);
+               break;
+
+       case BFA_LPS_SM_OFFLINE:
+               bfa_sm_set_state(lps, bfa_lps_sm_init);
+               bfa_reqq_wcancel(&lps->wqe);
+               break;
+
+       default:
+               bfa_sm_fault(lps->bfa, event);
+       }
+}
+
+
+
+/**
+ *  lps_pvt BFA LPS private functions
+ */
+
+/**
+ * return memory requirement
+ */
+static void
+bfa_lps_meminfo(struct bfa_iocfc_cfg_s *cfg, u32 *ndm_len,
+       u32 *dm_len)
+{
+       if (cfg->drvcfg.min_cfg)
+               *ndm_len += sizeof(struct bfa_lps_s) * BFA_LPS_MIN_LPORTS;
+       else
+               *ndm_len += sizeof(struct bfa_lps_s) * BFA_LPS_MAX_LPORTS;
+}
+
+/**
+ * bfa module attach at initialization time
+ */
+static void
+bfa_lps_attach(struct bfa_s *bfa, void *bfad, struct bfa_iocfc_cfg_s *cfg,
+       struct bfa_meminfo_s *meminfo, struct bfa_pcidev_s *pcidev)
+{
+       struct bfa_lps_mod_s    *mod = BFA_LPS_MOD(bfa);
+       struct bfa_lps_s        *lps;
+       int                     i;
+
+       bfa_os_memset(mod, 0, sizeof(struct bfa_lps_mod_s));
+       mod->num_lps = BFA_LPS_MAX_LPORTS;
+       if (cfg->drvcfg.min_cfg)
+               mod->num_lps = BFA_LPS_MIN_LPORTS;
+       else
+               mod->num_lps = BFA_LPS_MAX_LPORTS;
+       mod->lps_arr = lps = (struct bfa_lps_s *) bfa_meminfo_kva(meminfo);
+
+       bfa_meminfo_kva(meminfo) += mod->num_lps * sizeof(struct bfa_lps_s);
+
+       INIT_LIST_HEAD(&mod->lps_free_q);
+       INIT_LIST_HEAD(&mod->lps_active_q);
+
+       for (i = 0; i < mod->num_lps; i++, lps++) {
+               lps->bfa        = bfa;
+               lps->lp_tag     = (u8) i;
+               lps->reqq       = BFA_REQQ_LPS;
+               bfa_reqq_winit(&lps->wqe, bfa_lps_reqq_resume, lps);
+               list_add_tail(&lps->qe, &mod->lps_free_q);
+       }
+}
+
+static void
+bfa_lps_detach(struct bfa_s *bfa)
+{
+}
+
+static void
+bfa_lps_start(struct bfa_s *bfa)
+{
+}
+
+static void
+bfa_lps_stop(struct bfa_s *bfa)
+{
+}
+
+/**
+ * IOC in disabled state -- consider all lps offline
+ */
+static void
+bfa_lps_iocdisable(struct bfa_s *bfa)
+{
+       struct bfa_lps_mod_s    *mod = BFA_LPS_MOD(bfa);
+       struct bfa_lps_s        *lps;
+       struct list_head                *qe, *qen;
+
+       list_for_each_safe(qe, qen, &mod->lps_active_q) {
+               lps = (struct bfa_lps_s *) qe;
+               bfa_sm_send_event(lps, BFA_LPS_SM_OFFLINE);
+       }
+}
+
+/**
+ * Firmware login response
+ */
+static void
+bfa_lps_login_rsp(struct bfa_s *bfa, struct bfi_lps_login_rsp_s *rsp)
+{
+       struct bfa_lps_mod_s    *mod = BFA_LPS_MOD(bfa);
+       struct bfa_lps_s        *lps;
+
+       bfa_assert(rsp->lp_tag < mod->num_lps);
+       lps = BFA_LPS_FROM_TAG(mod, rsp->lp_tag);
+
+       lps->status = rsp->status;
+       switch (rsp->status) {
+       case BFA_STATUS_OK:
+               lps->fport      = rsp->f_port;
+               lps->npiv_en    = rsp->npiv_en;
+               lps->lp_pid     = rsp->lp_pid;
+               lps->pr_bbcred  = bfa_os_ntohs(rsp->bb_credit);
+               lps->pr_pwwn    = rsp->port_name;
+               lps->pr_nwwn    = rsp->node_name;
+               lps->auth_req   = rsp->auth_req;
+               lps->lp_mac     = rsp->lp_mac;
+               lps->brcd_switch = rsp->brcd_switch;
+               lps->fcf_mac    = rsp->fcf_mac;
+
+               break;
+
+       case BFA_STATUS_FABRIC_RJT:
+               lps->lsrjt_rsn = rsp->lsrjt_rsn;
+               lps->lsrjt_expl = rsp->lsrjt_expl;
+
+               break;
+
+       case BFA_STATUS_EPROTOCOL:
+               lps->ext_status = rsp->ext_status;
+
+               break;
+
+       default:
+               /* Nothing to do with other status */
+               break;
+       }
+
+       bfa_sm_send_event(lps, BFA_LPS_SM_FWRSP);
+}
+
+/**
+ * Firmware logout response
+ */
+static void
+bfa_lps_logout_rsp(struct bfa_s *bfa, struct bfi_lps_logout_rsp_s *rsp)
+{
+       struct bfa_lps_mod_s    *mod = BFA_LPS_MOD(bfa);
+       struct bfa_lps_s        *lps;
+
+       bfa_assert(rsp->lp_tag < mod->num_lps);
+       lps = BFA_LPS_FROM_TAG(mod, rsp->lp_tag);
+
+       bfa_sm_send_event(lps, BFA_LPS_SM_FWRSP);
+}
+
+/**
+ * Firmware received a Clear virtual link request (for FCoE)
+ */
+static void
+bfa_lps_rx_cvl_event(struct bfa_s *bfa, struct bfi_lps_cvl_event_s *cvl)
+{
+       struct bfa_lps_mod_s    *mod = BFA_LPS_MOD(bfa);
+       struct bfa_lps_s        *lps;
+
+       lps = BFA_LPS_FROM_TAG(mod, cvl->lp_tag);
+
+       bfa_sm_send_event(lps, BFA_LPS_SM_RX_CVL);
+}
+
+/**
+ * Space is available in request queue, resume queueing request to firmware.
+ */
+static void
+bfa_lps_reqq_resume(void *lps_arg)
+{
+       struct bfa_lps_s        *lps = lps_arg;
+
+       bfa_sm_send_event(lps, BFA_LPS_SM_RESUME);
+}
+
+/**
+ * lps is freed -- triggered by vport delete
+ */
+static void
+bfa_lps_free(struct bfa_lps_s *lps)
+{
+       struct bfa_lps_mod_s    *mod = BFA_LPS_MOD(lps->bfa);
+
+       lps->lp_pid = 0;
+       list_del(&lps->qe);
+       list_add_tail(&lps->qe, &mod->lps_free_q);
+}
+
+/**
+ * send login request to firmware
+ */
+static void
+bfa_lps_send_login(struct bfa_lps_s *lps)
+{
+       struct bfi_lps_login_req_s      *m;
+
+       m = bfa_reqq_next(lps->bfa, lps->reqq);
+       bfa_assert(m);
+
+       bfi_h2i_set(m->mh, BFI_MC_LPS, BFI_LPS_H2I_LOGIN_REQ,
+               bfa_lpuid(lps->bfa));
+
+       m->lp_tag       = lps->lp_tag;
+       m->alpa         = lps->alpa;
+       m->pdu_size     = bfa_os_htons(lps->pdusz);
+       m->pwwn         = lps->pwwn;
+       m->nwwn         = lps->nwwn;
+       m->fdisc        = lps->fdisc;
+       m->auth_en      = lps->auth_en;
+
+       bfa_reqq_produce(lps->bfa, lps->reqq);
+}
+
+/**
+ * send logout request to firmware
+ */
+static void
+bfa_lps_send_logout(struct bfa_lps_s *lps)
+{
+       struct bfi_lps_logout_req_s *m;
+
+       m = bfa_reqq_next(lps->bfa, lps->reqq);
+       bfa_assert(m);
+
+       bfi_h2i_set(m->mh, BFI_MC_LPS, BFI_LPS_H2I_LOGOUT_REQ,
+               bfa_lpuid(lps->bfa));
+
+       m->lp_tag    = lps->lp_tag;
+       m->port_name = lps->pwwn;
+       bfa_reqq_produce(lps->bfa, lps->reqq);
+}
+
+/**
+ * Indirect login completion handler for non-fcs
+ */
+static void
+bfa_lps_login_comp_cb(void *arg, bfa_boolean_t complete)
+{
+       struct bfa_lps_s *lps   = arg;
+
+       if (!complete)
+               return;
+
+       if (lps->fdisc)
+               bfa_cb_lps_fdisc_comp(lps->bfa->bfad, lps->uarg, lps->status);
+       else
+               bfa_cb_lps_flogi_comp(lps->bfa->bfad, lps->uarg, lps->status);
+}
+
+/**
+ * Login completion handler -- direct call for fcs, queue for others
+ */
+static void
+bfa_lps_login_comp(struct bfa_lps_s *lps)
+{
+       if (!lps->bfa->fcs) {
+               bfa_cb_queue(lps->bfa, &lps->hcb_qe, bfa_lps_login_comp_cb,
+                       lps);
+               return;
+       }
+
+       if (lps->fdisc)
+               bfa_cb_lps_fdisc_comp(lps->bfa->bfad, lps->uarg, lps->status);
+       else
+               bfa_cb_lps_flogi_comp(lps->bfa->bfad, lps->uarg, lps->status);
+}
+
+/**
+ * Indirect logout completion handler for non-fcs
+ */
+static void
+bfa_lps_logout_comp_cb(void *arg, bfa_boolean_t complete)
+{
+       struct bfa_lps_s *lps   = arg;
+
+       if (!complete)
+               return;
+
+       if (lps->fdisc)
+               bfa_cb_lps_fdisclogo_comp(lps->bfa->bfad, lps->uarg);
+}
+
+/**
+ * Logout completion handler -- direct call for fcs, queue for others
+ */
+static void
+bfa_lps_logout_comp(struct bfa_lps_s *lps)
+{
+       if (!lps->bfa->fcs) {
+               bfa_cb_queue(lps->bfa, &lps->hcb_qe, bfa_lps_logout_comp_cb,
+                       lps);
+               return;
+       }
+       if (lps->fdisc)
+               bfa_cb_lps_fdisclogo_comp(lps->bfa->bfad, lps->uarg);
+}
+
+/**
+ * Clear virtual link completion handler for non-fcs
+ */
+static void
+bfa_lps_cvl_event_cb(void *arg, bfa_boolean_t complete)
+{
+       struct bfa_lps_s *lps   = arg;
+
+       if (!complete)
+               return;
+
+       /* Clear virtual link to base port will result in link down */
+       if (lps->fdisc)
+               bfa_cb_lps_cvl_event(lps->bfa->bfad, lps->uarg);
+}
+
+/**
+ * Received Clear virtual link event --direct call for fcs,
+ * queue for others
+ */
+static void
+bfa_lps_cvl_event(struct bfa_lps_s *lps)
+{
+       if (!lps->bfa->fcs) {
+               bfa_cb_queue(lps->bfa, &lps->hcb_qe, bfa_lps_cvl_event_cb,
+                       lps);
+               return;
+       }
+
+       /* Clear virtual link to base port will result in link down */
+       if (lps->fdisc)
+               bfa_cb_lps_cvl_event(lps->bfa->bfad, lps->uarg);
+}
+
+
+
+/**
+ *  lps_public BFA LPS public functions
+ */
+
+u32
+bfa_lps_get_max_vport(struct bfa_s *bfa)
+{
+       if (bfa_ioc_devid(&bfa->ioc) == BFA_PCI_DEVICE_ID_CT)
+               return BFA_LPS_MAX_VPORTS_SUPP_CT;
+       else
+               return BFA_LPS_MAX_VPORTS_SUPP_CB;
+}
+
+/**
+ * Allocate a lport srvice tag.
+ */
+struct bfa_lps_s  *
+bfa_lps_alloc(struct bfa_s *bfa)
+{
+       struct bfa_lps_mod_s    *mod = BFA_LPS_MOD(bfa);
+       struct bfa_lps_s        *lps = NULL;
+
+       bfa_q_deq(&mod->lps_free_q, &lps);
+
+       if (lps == NULL)
+               return NULL;
+
+       list_add_tail(&lps->qe, &mod->lps_active_q);
+
+       bfa_sm_set_state(lps, bfa_lps_sm_init);
+       return lps;
+}
+
+/**
+ * Free lport service tag. This can be called anytime after an alloc.
+ * No need to wait for any pending login/logout completions.
+ */
+void
+bfa_lps_delete(struct bfa_lps_s *lps)
+{
+       bfa_sm_send_event(lps, BFA_LPS_SM_DELETE);
+}
+
+/**
+ * Initiate a lport login.
+ */
+void
+bfa_lps_flogi(struct bfa_lps_s *lps, void *uarg, u8 alpa, u16 pdusz,
+       wwn_t pwwn, wwn_t nwwn, bfa_boolean_t auth_en)
+{
+       lps->uarg       = uarg;
+       lps->alpa       = alpa;
+       lps->pdusz      = pdusz;
+       lps->pwwn       = pwwn;
+       lps->nwwn       = nwwn;
+       lps->fdisc      = BFA_FALSE;
+       lps->auth_en    = auth_en;
+       bfa_sm_send_event(lps, BFA_LPS_SM_LOGIN);
+}
+
+/**
+ * Initiate a lport fdisc login.
+ */
+void
+bfa_lps_fdisc(struct bfa_lps_s *lps, void *uarg, u16 pdusz, wwn_t pwwn,
+       wwn_t nwwn)
+{
+       lps->uarg       = uarg;
+       lps->alpa       = 0;
+       lps->pdusz      = pdusz;
+       lps->pwwn       = pwwn;
+       lps->nwwn       = nwwn;
+       lps->fdisc      = BFA_TRUE;
+       lps->auth_en    = BFA_FALSE;
+       bfa_sm_send_event(lps, BFA_LPS_SM_LOGIN);
+}
+
+/**
+ * Initiate a lport logout (flogi).
+ */
+void
+bfa_lps_flogo(struct bfa_lps_s *lps)
+{
+       bfa_sm_send_event(lps, BFA_LPS_SM_LOGOUT);
+}
+
+/**
+ * Initiate a lport FDSIC logout.
+ */
+void
+bfa_lps_fdisclogo(struct bfa_lps_s *lps)
+{
+       bfa_sm_send_event(lps, BFA_LPS_SM_LOGOUT);
+}
+
+/**
+ * Discard a pending login request -- should be called only for
+ * link down handling.
+ */
+void
+bfa_lps_discard(struct bfa_lps_s *lps)
+{
+       bfa_sm_send_event(lps, BFA_LPS_SM_OFFLINE);
+}
+
+/**
+ * Return lport services tag
+ */
+u8
+bfa_lps_get_tag(struct bfa_lps_s *lps)
+{
+       return lps->lp_tag;
+}
+
+/**
+ * Return lport services tag given the pid
+ */
+u8
+bfa_lps_get_tag_from_pid(struct bfa_s *bfa, u32 pid)
+{
+       struct bfa_lps_mod_s    *mod = BFA_LPS_MOD(bfa);
+       struct bfa_lps_s        *lps;
+       int                     i;
+
+       for (i = 0, lps = mod->lps_arr; i < mod->num_lps; i++, lps++) {
+               if (lps->lp_pid == pid)
+                       return lps->lp_tag;
+       }
+
+       /* Return base port tag anyway */
+       return 0;
+}
+
+/**
+ * return if fabric login indicates support for NPIV
+ */
+bfa_boolean_t
+bfa_lps_is_npiv_en(struct bfa_lps_s *lps)
+{
+       return lps->npiv_en;
+}
+
+/**
+ * Return TRUE if attached to F-Port, else return FALSE
+ */
+bfa_boolean_t
+bfa_lps_is_fport(struct bfa_lps_s *lps)
+{
+       return lps->fport;
+}
+
+/**
+ * Return TRUE if attached to a Brocade Fabric
+ */
+bfa_boolean_t
+bfa_lps_is_brcd_fabric(struct bfa_lps_s *lps)
+{
+       return lps->brcd_switch;
+}
+/**
+ * return TRUE if authentication is required
+ */
+bfa_boolean_t
+bfa_lps_is_authreq(struct bfa_lps_s *lps)
+{
+       return lps->auth_req;
+}
+
+bfa_eproto_status_t
+bfa_lps_get_extstatus(struct bfa_lps_s *lps)
+{
+       return lps->ext_status;
+}
+
+/**
+ * return port id assigned to the lport
+ */
+u32
+bfa_lps_get_pid(struct bfa_lps_s *lps)
+{
+       return lps->lp_pid;
+}
+
+/**
+ * return port id assigned to the base lport
+ */
+u32
+bfa_lps_get_base_pid(struct bfa_s *bfa)
+{
+       struct bfa_lps_mod_s    *mod = BFA_LPS_MOD(bfa);
+
+       return BFA_LPS_FROM_TAG(mod, 0)->lp_pid;
+}
+
+/**
+ * Return bb_credit assigned in FLOGI response
+ */
+u16
+bfa_lps_get_peer_bbcredit(struct bfa_lps_s *lps)
+{
+       return lps->pr_bbcred;
+}
+
+/**
+ * Return peer port name
+ */
+wwn_t
+bfa_lps_get_peer_pwwn(struct bfa_lps_s *lps)
+{
+       return lps->pr_pwwn;
+}
+
+/**
+ * Return peer node name
+ */
+wwn_t
+bfa_lps_get_peer_nwwn(struct bfa_lps_s *lps)
+{
+       return lps->pr_nwwn;
+}
+
+/**
+ * return reason code if login request is rejected
+ */
+u8
+bfa_lps_get_lsrjt_rsn(struct bfa_lps_s *lps)
+{
+       return lps->lsrjt_rsn;
+}
+
+/**
+ * return explanation code if login request is rejected
+ */
+u8
+bfa_lps_get_lsrjt_expl(struct bfa_lps_s *lps)
+{
+       return lps->lsrjt_expl;
+}
+
+/**
+ * Return fpma/spma MAC for lport
+ */
+mac_t
+bfa_lps_get_lp_mac(struct bfa_lps_s *lps)
+{
+       return lps->lp_mac;
+}
+
+/**
+ * LPS firmware message class handler.
+ */
+void
+bfa_lps_isr(struct bfa_s *bfa, struct bfi_msg_s *m)
+{
+       union bfi_lps_i2h_msg_u msg;
+
+       bfa_trc(bfa, m->mhdr.msg_id);
+       msg.msg = m;
+
+       switch (m->mhdr.msg_id) {
+       case BFI_LPS_H2I_LOGIN_RSP:
+               bfa_lps_login_rsp(bfa, msg.login_rsp);
+               break;
+
+       case BFI_LPS_H2I_LOGOUT_RSP:
+               bfa_lps_logout_rsp(bfa, msg.logout_rsp);
+               break;
+
+       case BFI_LPS_H2I_CVL_EVENT:
+               bfa_lps_rx_cvl_event(bfa, msg.cvl_event);
+               break;
+
+       default:
+               bfa_trc(bfa, m->mhdr.msg_id);
+               bfa_assert(0);
+       }
+}
+
+/**
+ * FC PORT state machine functions
+ */
+static void
+bfa_fcport_sm_uninit(struct bfa_fcport_s *fcport,
+                       enum bfa_fcport_sm_event event)
+{
+       bfa_trc(fcport->bfa, event);
+
+       switch (event) {
+       case BFA_FCPORT_SM_START:
+               /**
+                * Start event after IOC is configured and BFA is started.
+                */
+               if (bfa_fcport_send_enable(fcport)) {
+                       bfa_trc(fcport->bfa, BFA_TRUE);
+                       bfa_sm_set_state(fcport, bfa_fcport_sm_enabling);
+               } else {
+                       bfa_trc(fcport->bfa, BFA_FALSE);
+                       bfa_sm_set_state(fcport,
+                                       bfa_fcport_sm_enabling_qwait);
+               }
+               break;
+
+       case BFA_FCPORT_SM_ENABLE:
+               /**
+                * Port is persistently configured to be in enabled state. Do
+                * not change state. Port enabling is done when START event is
+                * received.
+                */
+               break;
+
+       case BFA_FCPORT_SM_DISABLE:
+               /**
+                * If a port is persistently configured to be disabled, the
+                * first event will a port disable request.
+                */
+               bfa_sm_set_state(fcport, bfa_fcport_sm_disabled);
+               break;
+
+       case BFA_FCPORT_SM_HWFAIL:
+               bfa_sm_set_state(fcport, bfa_fcport_sm_iocdown);
+               break;
+
+       default:
+               bfa_sm_fault(fcport->bfa, event);
+       }
+}
+
+static void
+bfa_fcport_sm_enabling_qwait(struct bfa_fcport_s *fcport,
+                               enum bfa_fcport_sm_event event)
+{
+       char pwwn_buf[BFA_STRING_32];
+       struct bfad_s *bfad = (struct bfad_s *)fcport->bfa->bfad;
+       bfa_trc(fcport->bfa, event);
+
+       switch (event) {
+       case BFA_FCPORT_SM_QRESUME:
+               bfa_sm_set_state(fcport, bfa_fcport_sm_enabling);
+               bfa_fcport_send_enable(fcport);
+               break;
+
+       case BFA_FCPORT_SM_STOP:
+               bfa_reqq_wcancel(&fcport->reqq_wait);
+               bfa_sm_set_state(fcport, bfa_fcport_sm_stopped);
+               break;
+
+       case BFA_FCPORT_SM_ENABLE:
+               /**
+                * Already enable is in progress.
+                */
+               break;
+
+       case BFA_FCPORT_SM_DISABLE:
+               /**
+                * Just send disable request to firmware when room becomes
+                * available in request queue.
+                */
+               bfa_sm_set_state(fcport, bfa_fcport_sm_disabled);
+               bfa_reqq_wcancel(&fcport->reqq_wait);
+               bfa_plog_str(fcport->bfa->plog, BFA_PL_MID_HAL,
+                               BFA_PL_EID_PORT_DISABLE, 0, "Port Disable");
+               wwn2str(pwwn_buf, fcport->pwwn);
+               BFA_LOG(KERN_INFO, bfad, log_level,
+                       "Base port disabled: WWN = %s\n", pwwn_buf);
+               break;
+
+       case BFA_FCPORT_SM_LINKUP:
+       case BFA_FCPORT_SM_LINKDOWN:
+               /**
+                * Possible to get link events when doing back-to-back
+                * enable/disables.
+                */
+               break;
+
+       case BFA_FCPORT_SM_HWFAIL:
+               bfa_reqq_wcancel(&fcport->reqq_wait);
+               bfa_sm_set_state(fcport, bfa_fcport_sm_iocdown);
+               break;
+
+       default:
+               bfa_sm_fault(fcport->bfa, event);
+       }
+}
+
+static void
+bfa_fcport_sm_enabling(struct bfa_fcport_s *fcport,
+                                               enum bfa_fcport_sm_event event)
+{
+       char pwwn_buf[BFA_STRING_32];
+       struct bfad_s *bfad = (struct bfad_s *)fcport->bfa->bfad;
+       bfa_trc(fcport->bfa, event);
+
+       switch (event) {
+       case BFA_FCPORT_SM_FWRSP:
+       case BFA_FCPORT_SM_LINKDOWN:
+               bfa_sm_set_state(fcport, bfa_fcport_sm_linkdown);
+               break;
+
+       case BFA_FCPORT_SM_LINKUP:
+               bfa_fcport_update_linkinfo(fcport);
+               bfa_sm_set_state(fcport, bfa_fcport_sm_linkup);
+
+               bfa_assert(fcport->event_cbfn);
+               bfa_fcport_scn(fcport, BFA_PORT_LINKUP, BFA_FALSE);
+               break;
+
+       case BFA_FCPORT_SM_ENABLE:
+               /**
+                * Already being enabled.
+                */
+               break;
+
+       case BFA_FCPORT_SM_DISABLE:
+               if (bfa_fcport_send_disable(fcport))
+                       bfa_sm_set_state(fcport, bfa_fcport_sm_disabling);
+               else
+                       bfa_sm_set_state(fcport,
+                                        bfa_fcport_sm_disabling_qwait);
+
+               bfa_plog_str(fcport->bfa->plog, BFA_PL_MID_HAL,
+                               BFA_PL_EID_PORT_DISABLE, 0, "Port Disable");
+               wwn2str(pwwn_buf, fcport->pwwn);
+               BFA_LOG(KERN_INFO, bfad, log_level,
+                       "Base port disabled: WWN = %s\n", pwwn_buf);
+               break;
+
+       case BFA_FCPORT_SM_STOP:
+               bfa_sm_set_state(fcport, bfa_fcport_sm_stopped);
+               break;
+
+       case BFA_FCPORT_SM_HWFAIL:
+               bfa_sm_set_state(fcport, bfa_fcport_sm_iocdown);
+               break;
+
+       default:
+               bfa_sm_fault(fcport->bfa, event);
+       }
+}
+
+static void
+bfa_fcport_sm_linkdown(struct bfa_fcport_s *fcport,
+                                               enum bfa_fcport_sm_event event)
+{
+       struct bfi_fcport_event_s *pevent = fcport->event_arg.i2hmsg.event;
+       char pwwn_buf[BFA_STRING_32];
+       struct bfad_s *bfad = (struct bfad_s *)fcport->bfa->bfad;
+
+       bfa_trc(fcport->bfa, event);
+
+       switch (event) {
+       case BFA_FCPORT_SM_LINKUP:
+               bfa_fcport_update_linkinfo(fcport);
+               bfa_sm_set_state(fcport, bfa_fcport_sm_linkup);
+               bfa_assert(fcport->event_cbfn);
+               bfa_plog_str(fcport->bfa->plog, BFA_PL_MID_HAL,
+                               BFA_PL_EID_PORT_ST_CHANGE, 0, "Port Linkup");
+               if (!bfa_ioc_get_fcmode(&fcport->bfa->ioc)) {
+
+                       bfa_trc(fcport->bfa,
+                               pevent->link_state.vc_fcf.fcf.fipenabled);
+                       bfa_trc(fcport->bfa,
+                               pevent->link_state.vc_fcf.fcf.fipfailed);
+
+                       if (pevent->link_state.vc_fcf.fcf.fipfailed)
+                               bfa_plog_str(fcport->bfa->plog, BFA_PL_MID_HAL,
+                                       BFA_PL_EID_FIP_FCF_DISC, 0,
+                                       "FIP FCF Discovery Failed");
+                       else
+                               bfa_plog_str(fcport->bfa->plog, BFA_PL_MID_HAL,
+                                       BFA_PL_EID_FIP_FCF_DISC, 0,
+                                       "FIP FCF Discovered");
+               }
+
+               bfa_fcport_scn(fcport, BFA_PORT_LINKUP, BFA_FALSE);
+               wwn2str(pwwn_buf, fcport->pwwn);
+               BFA_LOG(KERN_INFO, bfad, log_level,
+                       "Base port online: WWN = %s\n", pwwn_buf);
+               break;
+
+       case BFA_FCPORT_SM_LINKDOWN:
+               /**
+                * Possible to get link down event.
+                */
+               break;
+
+       case BFA_FCPORT_SM_ENABLE:
+               /**
+                * Already enabled.
+                */
+               break;
+
+       case BFA_FCPORT_SM_DISABLE:
+               if (bfa_fcport_send_disable(fcport))
+                       bfa_sm_set_state(fcport, bfa_fcport_sm_disabling);
+               else
+                       bfa_sm_set_state(fcport,
+                                        bfa_fcport_sm_disabling_qwait);
+
+               bfa_plog_str(fcport->bfa->plog, BFA_PL_MID_HAL,
+                               BFA_PL_EID_PORT_DISABLE, 0, "Port Disable");
+               wwn2str(pwwn_buf, fcport->pwwn);
+               BFA_LOG(KERN_INFO, bfad, log_level,
+                       "Base port disabled: WWN = %s\n", pwwn_buf);
+               break;
+
+       case BFA_FCPORT_SM_STOP:
+               bfa_sm_set_state(fcport, bfa_fcport_sm_stopped);
+               break;
+
+       case BFA_FCPORT_SM_HWFAIL:
+               bfa_sm_set_state(fcport, bfa_fcport_sm_iocdown);
+               break;
+
+       default:
+               bfa_sm_fault(fcport->bfa, event);
+       }
+}
+
+static void
+bfa_fcport_sm_linkup(struct bfa_fcport_s *fcport,
+       enum bfa_fcport_sm_event event)
+{
+       char pwwn_buf[BFA_STRING_32];
+       struct bfad_s *bfad = (struct bfad_s *)fcport->bfa->bfad;
+
+       bfa_trc(fcport->bfa, event);
+
+       switch (event) {
+       case BFA_FCPORT_SM_ENABLE:
+               /**
+                * Already enabled.
+                */
+               break;
+
+       case BFA_FCPORT_SM_DISABLE:
+               if (bfa_fcport_send_disable(fcport))
+                       bfa_sm_set_state(fcport, bfa_fcport_sm_disabling);
+               else
+                       bfa_sm_set_state(fcport,
+                                        bfa_fcport_sm_disabling_qwait);
+
+               bfa_fcport_reset_linkinfo(fcport);
+               bfa_fcport_scn(fcport, BFA_PORT_LINKDOWN, BFA_FALSE);
+               bfa_plog_str(fcport->bfa->plog, BFA_PL_MID_HAL,
+                               BFA_PL_EID_PORT_DISABLE, 0, "Port Disable");
+               wwn2str(pwwn_buf, fcport->pwwn);
+               BFA_LOG(KERN_INFO, bfad, log_level,
+                       "Base port offline: WWN = %s\n", pwwn_buf);
+               BFA_LOG(KERN_INFO, bfad, log_level,
+                       "Base port disabled: WWN = %s\n", pwwn_buf);
+               break;
+
+       case BFA_FCPORT_SM_LINKDOWN:
+               bfa_sm_set_state(fcport, bfa_fcport_sm_linkdown);
+               bfa_fcport_reset_linkinfo(fcport);
+               bfa_fcport_scn(fcport, BFA_PORT_LINKDOWN, BFA_FALSE);
+               bfa_plog_str(fcport->bfa->plog, BFA_PL_MID_HAL,
+                               BFA_PL_EID_PORT_ST_CHANGE, 0, "Port Linkdown");
+               wwn2str(pwwn_buf, fcport->pwwn);
+               if (BFA_PORT_IS_DISABLED(fcport->bfa))
+                       BFA_LOG(KERN_INFO, bfad, log_level,
+                               "Base port offline: WWN = %s\n", pwwn_buf);
+               else
+                       BFA_LOG(KERN_ERR, bfad, log_level,
+                               "Base port (WWN = %s) "
+                               "lost fabric connectivity\n", pwwn_buf);
+               break;
+
+       case BFA_FCPORT_SM_STOP:
+               bfa_sm_set_state(fcport, bfa_fcport_sm_stopped);
+               bfa_fcport_reset_linkinfo(fcport);
+               wwn2str(pwwn_buf, fcport->pwwn);
+               if (BFA_PORT_IS_DISABLED(fcport->bfa))
+                       BFA_LOG(KERN_INFO, bfad, log_level,
+                               "Base port offline: WWN = %s\n", pwwn_buf);
+               else
+                       BFA_LOG(KERN_ERR, bfad, log_level,
+                               "Base port (WWN = %s) "
+                               "lost fabric connectivity\n", pwwn_buf);
+               break;
+
+       case BFA_FCPORT_SM_HWFAIL:
+               bfa_sm_set_state(fcport, bfa_fcport_sm_iocdown);
+               bfa_fcport_reset_linkinfo(fcport);
+               bfa_fcport_scn(fcport, BFA_PORT_LINKDOWN, BFA_FALSE);
+               wwn2str(pwwn_buf, fcport->pwwn);
+               if (BFA_PORT_IS_DISABLED(fcport->bfa))
+                       BFA_LOG(KERN_INFO, bfad, log_level,
+                               "Base port offline: WWN = %s\n", pwwn_buf);
+               else
+                       BFA_LOG(KERN_ERR, bfad, log_level,
+                               "Base port (WWN = %s) "
+                               "lost fabric connectivity\n", pwwn_buf);
+               break;
+
+       default:
+               bfa_sm_fault(fcport->bfa, event);
+       }
+}
+
+static void
+bfa_fcport_sm_disabling_qwait(struct bfa_fcport_s *fcport,
+                                enum bfa_fcport_sm_event event)
+{
+       bfa_trc(fcport->bfa, event);
+
+       switch (event) {
+       case BFA_FCPORT_SM_QRESUME:
+               bfa_sm_set_state(fcport, bfa_fcport_sm_disabling);
+               bfa_fcport_send_disable(fcport);
+               break;
+
+       case BFA_FCPORT_SM_STOP:
+               bfa_sm_set_state(fcport, bfa_fcport_sm_stopped);
+               bfa_reqq_wcancel(&fcport->reqq_wait);
+               break;
+
+       case BFA_FCPORT_SM_ENABLE:
+               bfa_sm_set_state(fcport, bfa_fcport_sm_toggling_qwait);
+               break;
+
+       case BFA_FCPORT_SM_DISABLE:
+               /**
+                * Already being disabled.
+                */
+               break;
+
+       case BFA_FCPORT_SM_LINKUP:
+       case BFA_FCPORT_SM_LINKDOWN:
+               /**
+                * Possible to get link events when doing back-to-back
+                * enable/disables.
+                */
+               break;
+
+       case BFA_FCPORT_SM_HWFAIL:
+               bfa_sm_set_state(fcport, bfa_fcport_sm_iocfail);
+               bfa_reqq_wcancel(&fcport->reqq_wait);
+               break;
+
+       default:
+               bfa_sm_fault(fcport->bfa, event);
+       }
+}
+
+static void
+bfa_fcport_sm_toggling_qwait(struct bfa_fcport_s *fcport,
+                                enum bfa_fcport_sm_event event)
+{
+       bfa_trc(fcport->bfa, event);
+
+       switch (event) {
+       case BFA_FCPORT_SM_QRESUME:
+               bfa_sm_set_state(fcport, bfa_fcport_sm_disabling);
+               bfa_fcport_send_disable(fcport);
+               if (bfa_fcport_send_enable(fcport))
+                       bfa_sm_set_state(fcport, bfa_fcport_sm_enabling);
+               else
+                       bfa_sm_set_state(fcport,
+                                        bfa_fcport_sm_enabling_qwait);
+               break;
+
+       case BFA_FCPORT_SM_STOP:
+               bfa_sm_set_state(fcport, bfa_fcport_sm_stopped);
+               bfa_reqq_wcancel(&fcport->reqq_wait);
+               break;
+
+       case BFA_FCPORT_SM_ENABLE:
+               break;
+
+       case BFA_FCPORT_SM_DISABLE:
+               bfa_sm_set_state(fcport, bfa_fcport_sm_disabling_qwait);
+               break;
+
+       case BFA_FCPORT_SM_LINKUP:
+       case BFA_FCPORT_SM_LINKDOWN:
+               /**
+                * Possible to get link events when doing back-to-back
+                * enable/disables.
+                */
+               break;
+
+       case BFA_FCPORT_SM_HWFAIL:
+               bfa_sm_set_state(fcport, bfa_fcport_sm_iocfail);
+               bfa_reqq_wcancel(&fcport->reqq_wait);
+               break;
+
+       default:
+               bfa_sm_fault(fcport->bfa, event);
+       }
+}
+
+static void
+bfa_fcport_sm_disabling(struct bfa_fcport_s *fcport,
+                                               enum bfa_fcport_sm_event event)
+{
+       char pwwn_buf[BFA_STRING_32];
+       struct bfad_s *bfad = (struct bfad_s *)fcport->bfa->bfad;
+       bfa_trc(fcport->bfa, event);
+
+       switch (event) {
+       case BFA_FCPORT_SM_FWRSP:
+               bfa_sm_set_state(fcport, bfa_fcport_sm_disabled);
+               break;
+
+       case BFA_FCPORT_SM_DISABLE:
+               /**
+                * Already being disabled.
+                */
+               break;
+
+       case BFA_FCPORT_SM_ENABLE:
+               if (bfa_fcport_send_enable(fcport))
+                       bfa_sm_set_state(fcport, bfa_fcport_sm_enabling);
+               else
+                       bfa_sm_set_state(fcport,
+                                        bfa_fcport_sm_enabling_qwait);
+
+               bfa_plog_str(fcport->bfa->plog, BFA_PL_MID_HAL,
+                               BFA_PL_EID_PORT_ENABLE, 0, "Port Enable");
+               wwn2str(pwwn_buf, fcport->pwwn);
+               BFA_LOG(KERN_INFO, bfad, log_level,
+                       "Base port enabled: WWN = %s\n", pwwn_buf);
+               break;
+
+       case BFA_FCPORT_SM_STOP:
+               bfa_sm_set_state(fcport, bfa_fcport_sm_stopped);
+               break;
+
+       case BFA_FCPORT_SM_LINKUP:
+       case BFA_FCPORT_SM_LINKDOWN:
+               /**
+                * Possible to get link events when doing back-to-back
+                * enable/disables.
+                */
+               break;
+
+       case BFA_FCPORT_SM_HWFAIL:
+               bfa_sm_set_state(fcport, bfa_fcport_sm_iocfail);
+               break;
+
+       default:
+               bfa_sm_fault(fcport->bfa, event);
+       }
+}
+
+static void
+bfa_fcport_sm_disabled(struct bfa_fcport_s *fcport,
+                                               enum bfa_fcport_sm_event event)
+{
+       char pwwn_buf[BFA_STRING_32];
+       struct bfad_s *bfad = (struct bfad_s *)fcport->bfa->bfad;
+       bfa_trc(fcport->bfa, event);
+
+       switch (event) {
+       case BFA_FCPORT_SM_START:
+               /**
+                * Ignore start event for a port that is disabled.
+                */
+               break;
+
+       case BFA_FCPORT_SM_STOP:
+               bfa_sm_set_state(fcport, bfa_fcport_sm_stopped);
+               break;
+
+       case BFA_FCPORT_SM_ENABLE:
+               if (bfa_fcport_send_enable(fcport))
+                       bfa_sm_set_state(fcport, bfa_fcport_sm_enabling);
+               else
+                       bfa_sm_set_state(fcport,
+                                        bfa_fcport_sm_enabling_qwait);
+
+               bfa_plog_str(fcport->bfa->plog, BFA_PL_MID_HAL,
+                               BFA_PL_EID_PORT_ENABLE, 0, "Port Enable");
+               wwn2str(pwwn_buf, fcport->pwwn);
+               BFA_LOG(KERN_INFO, bfad, log_level,
+                       "Base port enabled: WWN = %s\n", pwwn_buf);
+               break;
+
+       case BFA_FCPORT_SM_DISABLE:
+               /**
+                * Already disabled.
+                */
+               break;
+
+       case BFA_FCPORT_SM_HWFAIL:
+               bfa_sm_set_state(fcport, bfa_fcport_sm_iocfail);
+               break;
+
+       default:
+               bfa_sm_fault(fcport->bfa, event);
+       }
+}
+
+static void
+bfa_fcport_sm_stopped(struct bfa_fcport_s *fcport,
+                        enum bfa_fcport_sm_event event)
+{
+       bfa_trc(fcport->bfa, event);
+
+       switch (event) {
+       case BFA_FCPORT_SM_START:
+               if (bfa_fcport_send_enable(fcport))
+                       bfa_sm_set_state(fcport, bfa_fcport_sm_enabling);
+               else
+                       bfa_sm_set_state(fcport,
+                                        bfa_fcport_sm_enabling_qwait);
+               break;
+
+       default:
+               /**
+                * Ignore all other events.
+                */
+               ;
+       }
+}
+
+/**
+ * Port is enabled. IOC is down/failed.
+ */
+static void
+bfa_fcport_sm_iocdown(struct bfa_fcport_s *fcport,
+                        enum bfa_fcport_sm_event event)
+{
+       bfa_trc(fcport->bfa, event);
+
+       switch (event) {
+       case BFA_FCPORT_SM_START:
+               if (bfa_fcport_send_enable(fcport))
+                       bfa_sm_set_state(fcport, bfa_fcport_sm_enabling);
+               else
+                       bfa_sm_set_state(fcport,
+                                        bfa_fcport_sm_enabling_qwait);
+               break;
+
+       default:
+               /**
+                * Ignore all events.
+                */
+               ;
+       }
+}
+
+/**
+ * Port is disabled. IOC is down/failed.
+ */
+static void
+bfa_fcport_sm_iocfail(struct bfa_fcport_s *fcport,
+                        enum bfa_fcport_sm_event event)
+{
+       bfa_trc(fcport->bfa, event);
+
+       switch (event) {
+       case BFA_FCPORT_SM_START:
+               bfa_sm_set_state(fcport, bfa_fcport_sm_disabled);
+               break;
+
+       case BFA_FCPORT_SM_ENABLE:
+               bfa_sm_set_state(fcport, bfa_fcport_sm_iocdown);
+               break;
+
+       default:
+               /**
+                * Ignore all events.
+                */
+               ;
+       }
+}
+
+/**
+ * Link state is down
+ */
+static void
+bfa_fcport_ln_sm_dn(struct bfa_fcport_ln_s *ln,
+               enum bfa_fcport_ln_sm_event event)
+{
+       bfa_trc(ln->fcport->bfa, event);
+
+       switch (event) {
+       case BFA_FCPORT_LN_SM_LINKUP:
+               bfa_sm_set_state(ln, bfa_fcport_ln_sm_up_nf);
+               bfa_fcport_queue_cb(ln, BFA_PORT_LINKUP);
+               break;
+
+       default:
+               bfa_sm_fault(ln->fcport->bfa, event);
+       }
+}
+
+/**
+ * Link state is waiting for down notification
+ */
+static void
+bfa_fcport_ln_sm_dn_nf(struct bfa_fcport_ln_s *ln,
+               enum bfa_fcport_ln_sm_event event)
+{
+       bfa_trc(ln->fcport->bfa, event);
+
+       switch (event) {
+       case BFA_FCPORT_LN_SM_LINKUP:
+               bfa_sm_set_state(ln, bfa_fcport_ln_sm_dn_up_nf);
+               break;
+
+       case BFA_FCPORT_LN_SM_NOTIFICATION:
+               bfa_sm_set_state(ln, bfa_fcport_ln_sm_dn);
+               break;
+
+       default:
+               bfa_sm_fault(ln->fcport->bfa, event);
+       }
+}
+
+/**
+ * Link state is waiting for down notification and there is a pending up
+ */
+static void
+bfa_fcport_ln_sm_dn_up_nf(struct bfa_fcport_ln_s *ln,
+               enum bfa_fcport_ln_sm_event event)
+{
+       bfa_trc(ln->fcport->bfa, event);
+
+       switch (event) {
+       case BFA_FCPORT_LN_SM_LINKDOWN:
+               bfa_sm_set_state(ln, bfa_fcport_ln_sm_dn_nf);
+               break;
+
+       case BFA_FCPORT_LN_SM_NOTIFICATION:
+               bfa_sm_set_state(ln, bfa_fcport_ln_sm_up_nf);
+               bfa_fcport_queue_cb(ln, BFA_PORT_LINKUP);
+               break;
+
+       default:
+               bfa_sm_fault(ln->fcport->bfa, event);
+       }
+}
+
+/**
+ * Link state is up
+ */
+static void
+bfa_fcport_ln_sm_up(struct bfa_fcport_ln_s *ln,
+               enum bfa_fcport_ln_sm_event event)
+{
+       bfa_trc(ln->fcport->bfa, event);
+
+       switch (event) {
+       case BFA_FCPORT_LN_SM_LINKDOWN:
+               bfa_sm_set_state(ln, bfa_fcport_ln_sm_dn_nf);
+               bfa_fcport_queue_cb(ln, BFA_PORT_LINKDOWN);
+               break;
+
+       default:
+               bfa_sm_fault(ln->fcport->bfa, event);
+       }
+}
+
+/**
+ * Link state is waiting for up notification
+ */
+static void
+bfa_fcport_ln_sm_up_nf(struct bfa_fcport_ln_s *ln,
+               enum bfa_fcport_ln_sm_event event)
+{
+       bfa_trc(ln->fcport->bfa, event);
+
+       switch (event) {
+       case BFA_FCPORT_LN_SM_LINKDOWN:
+               bfa_sm_set_state(ln, bfa_fcport_ln_sm_up_dn_nf);
+               break;
+
+       case BFA_FCPORT_LN_SM_NOTIFICATION:
+               bfa_sm_set_state(ln, bfa_fcport_ln_sm_up);
+               break;
+
+       default:
+               bfa_sm_fault(ln->fcport->bfa, event);
+       }
+}
+
+/**
+ * Link state is waiting for up notification and there is a pending down
+ */
+static void
+bfa_fcport_ln_sm_up_dn_nf(struct bfa_fcport_ln_s *ln,
+               enum bfa_fcport_ln_sm_event event)
+{
+       bfa_trc(ln->fcport->bfa, event);
+
+       switch (event) {
+       case BFA_FCPORT_LN_SM_LINKUP:
+               bfa_sm_set_state(ln, bfa_fcport_ln_sm_up_dn_up_nf);
+               break;
+
+       case BFA_FCPORT_LN_SM_NOTIFICATION:
+               bfa_sm_set_state(ln, bfa_fcport_ln_sm_dn_nf);
+               bfa_fcport_queue_cb(ln, BFA_PORT_LINKDOWN);
+               break;
+
+       default:
+               bfa_sm_fault(ln->fcport->bfa, event);
+       }
+}
+
+/**
+ * Link state is waiting for up notification and there are pending down and up
+ */
+static void
+bfa_fcport_ln_sm_up_dn_up_nf(struct bfa_fcport_ln_s *ln,
+                       enum bfa_fcport_ln_sm_event event)
+{
+       bfa_trc(ln->fcport->bfa, event);
+
+       switch (event) {
+       case BFA_FCPORT_LN_SM_LINKDOWN:
+               bfa_sm_set_state(ln, bfa_fcport_ln_sm_up_dn_nf);
+               break;
+
+       case BFA_FCPORT_LN_SM_NOTIFICATION:
+               bfa_sm_set_state(ln, bfa_fcport_ln_sm_dn_up_nf);
+               bfa_fcport_queue_cb(ln, BFA_PORT_LINKDOWN);
+               break;
+
+       default:
+               bfa_sm_fault(ln->fcport->bfa, event);
+       }
+}
+
+
+
+/**
+ *  hal_port_private
+ */
+
+static void
+__bfa_cb_fcport_event(void *cbarg, bfa_boolean_t complete)
+{
+       struct bfa_fcport_ln_s *ln = cbarg;
+
+       if (complete)
+               ln->fcport->event_cbfn(ln->fcport->event_cbarg, ln->ln_event);
+       else
+               bfa_sm_send_event(ln, BFA_FCPORT_LN_SM_NOTIFICATION);
+}
+
+/**
+ * Send SCN notification to upper layers.
+ * trunk - false if caller is fcport to ignore fcport event in trunked mode
+ */
+static void
+bfa_fcport_scn(struct bfa_fcport_s *fcport, enum bfa_port_linkstate event,
+       bfa_boolean_t trunk)
+{
+       if (fcport->cfg.trunked && !trunk)
+               return;
+
+       switch (event) {
+       case BFA_PORT_LINKUP:
+               bfa_sm_send_event(&fcport->ln, BFA_FCPORT_LN_SM_LINKUP);
+               break;
+       case BFA_PORT_LINKDOWN:
+               bfa_sm_send_event(&fcport->ln, BFA_FCPORT_LN_SM_LINKDOWN);
+               break;
+       default:
+               bfa_assert(0);
+       }
+}
+
+static void
+bfa_fcport_queue_cb(struct bfa_fcport_ln_s *ln, enum bfa_port_linkstate event)
+{
+       struct bfa_fcport_s *fcport = ln->fcport;
+
+       if (fcport->bfa->fcs) {
+               fcport->event_cbfn(fcport->event_cbarg, event);
+               bfa_sm_send_event(ln, BFA_FCPORT_LN_SM_NOTIFICATION);
+       } else {
+               ln->ln_event = event;
+               bfa_cb_queue(fcport->bfa, &ln->ln_qe,
+                       __bfa_cb_fcport_event, ln);
+       }
+}
+
+#define FCPORT_STATS_DMA_SZ (BFA_ROUNDUP(sizeof(union bfa_fcport_stats_u), \
+                                                       BFA_CACHELINE_SZ))
+
+static void
+bfa_fcport_meminfo(struct bfa_iocfc_cfg_s *cfg, u32 *ndm_len,
+               u32 *dm_len)
+{
+       *dm_len += FCPORT_STATS_DMA_SZ;
+}
+
+static void
+bfa_fcport_qresume(void *cbarg)
+{
+       struct bfa_fcport_s *fcport = cbarg;
+
+       bfa_sm_send_event(fcport, BFA_FCPORT_SM_QRESUME);
+}
+
+static void
+bfa_fcport_mem_claim(struct bfa_fcport_s *fcport, struct bfa_meminfo_s *meminfo)
+{
+       u8              *dm_kva;
+       u64     dm_pa;
+
+       dm_kva = bfa_meminfo_dma_virt(meminfo);
+       dm_pa  = bfa_meminfo_dma_phys(meminfo);
+
+       fcport->stats_kva = dm_kva;
+       fcport->stats_pa  = dm_pa;
+       fcport->stats     = (union bfa_fcport_stats_u *) dm_kva;
+
+       dm_kva += FCPORT_STATS_DMA_SZ;
+       dm_pa  += FCPORT_STATS_DMA_SZ;
+
+       bfa_meminfo_dma_virt(meminfo) = dm_kva;
+       bfa_meminfo_dma_phys(meminfo) = dm_pa;
+}
+
+/**
+ * Memory initialization.
+ */
+static void
+bfa_fcport_attach(struct bfa_s *bfa, void *bfad, struct bfa_iocfc_cfg_s *cfg,
+               struct bfa_meminfo_s *meminfo, struct bfa_pcidev_s *pcidev)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+       struct bfa_port_cfg_s *port_cfg = &fcport->cfg;
+       struct bfa_fcport_ln_s *ln = &fcport->ln;
+       struct bfa_timeval_s tv;
+
+       bfa_os_memset(fcport, 0, sizeof(struct bfa_fcport_s));
+       fcport->bfa = bfa;
+       ln->fcport = fcport;
+
+       bfa_fcport_mem_claim(fcport, meminfo);
+
+       bfa_sm_set_state(fcport, bfa_fcport_sm_uninit);
+       bfa_sm_set_state(ln, bfa_fcport_ln_sm_dn);
+
+       /**
+        * initialize time stamp for stats reset
+        */
+       bfa_os_gettimeofday(&tv);
+       fcport->stats_reset_time = tv.tv_sec;
+
+       /**
+        * initialize and set default configuration
+        */
+       port_cfg->topology = BFA_PORT_TOPOLOGY_P2P;
+       port_cfg->speed = BFA_PORT_SPEED_AUTO;
+       port_cfg->trunked = BFA_FALSE;
+       port_cfg->maxfrsize = 0;
+
+       port_cfg->trl_def_speed = BFA_PORT_SPEED_1GBPS;
+
+       bfa_reqq_winit(&fcport->reqq_wait, bfa_fcport_qresume, fcport);
+}
+
+static void
+bfa_fcport_detach(struct bfa_s *bfa)
+{
+}
+
+/**
+ * Called when IOC is ready.
+ */
+static void
+bfa_fcport_start(struct bfa_s *bfa)
+{
+       bfa_sm_send_event(BFA_FCPORT_MOD(bfa), BFA_FCPORT_SM_START);
+}
+
+/**
+ * Called before IOC is stopped.
+ */
+static void
+bfa_fcport_stop(struct bfa_s *bfa)
+{
+       bfa_sm_send_event(BFA_FCPORT_MOD(bfa), BFA_FCPORT_SM_STOP);
+       bfa_trunk_iocdisable(bfa);
+}
+
+/**
+ * Called when IOC failure is detected.
+ */
+static void
+bfa_fcport_iocdisable(struct bfa_s *bfa)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+
+       bfa_sm_send_event(fcport, BFA_FCPORT_SM_HWFAIL);
+       bfa_trunk_iocdisable(bfa);
+}
+
+static void
+bfa_fcport_update_linkinfo(struct bfa_fcport_s *fcport)
+{
+       struct bfi_fcport_event_s *pevent = fcport->event_arg.i2hmsg.event;
+       struct bfa_fcport_trunk_s *trunk = &fcport->trunk;
+
+       fcport->speed = pevent->link_state.speed;
+       fcport->topology = pevent->link_state.topology;
+
+       if (fcport->topology == BFA_PORT_TOPOLOGY_LOOP)
+               fcport->myalpa = 0;
+
+       /* QoS Details */
+       bfa_os_assign(fcport->qos_attr, pevent->link_state.qos_attr);
+       bfa_os_assign(fcport->qos_vc_attr,
+               pevent->link_state.vc_fcf.qos_vc_attr);
+
+       /**
+        * update trunk state if applicable
+        */
+       if (!fcport->cfg.trunked)
+               trunk->attr.state = BFA_TRUNK_DISABLED;
+
+       /* update FCoE specific */
+       fcport->fcoe_vlan = bfa_os_ntohs(pevent->link_state.vc_fcf.fcf.vlan);
+
+       bfa_trc(fcport->bfa, fcport->speed);
+       bfa_trc(fcport->bfa, fcport->topology);
+}
+
+static void
+bfa_fcport_reset_linkinfo(struct bfa_fcport_s *fcport)
+{
+       fcport->speed = BFA_PORT_SPEED_UNKNOWN;
+       fcport->topology = BFA_PORT_TOPOLOGY_NONE;
+}
+
+/**
+ * Send port enable message to firmware.
+ */
+static bfa_boolean_t
+bfa_fcport_send_enable(struct bfa_fcport_s *fcport)
+{
+       struct bfi_fcport_enable_req_s *m;
+
+       /**
+        * Increment message tag before queue check, so that responses to old
+        * requests are discarded.
+        */
+       fcport->msgtag++;
+
+       /**
+        * check for room in queue to send request now
+        */
+       m = bfa_reqq_next(fcport->bfa, BFA_REQQ_PORT);
+       if (!m) {
+               bfa_reqq_wait(fcport->bfa, BFA_REQQ_PORT,
+                                                       &fcport->reqq_wait);
+               return BFA_FALSE;
+       }
+
+       bfi_h2i_set(m->mh, BFI_MC_FCPORT, BFI_FCPORT_H2I_ENABLE_REQ,
+                       bfa_lpuid(fcport->bfa));
+       m->nwwn = fcport->nwwn;
+       m->pwwn = fcport->pwwn;
+       m->port_cfg = fcport->cfg;
+       m->msgtag = fcport->msgtag;
+       m->port_cfg.maxfrsize = bfa_os_htons(fcport->cfg.maxfrsize);
+       bfa_dma_be_addr_set(m->stats_dma_addr, fcport->stats_pa);
+       bfa_trc(fcport->bfa, m->stats_dma_addr.a32.addr_lo);
+       bfa_trc(fcport->bfa, m->stats_dma_addr.a32.addr_hi);
+
+       /**
+        * queue I/O message to firmware
+        */
+       bfa_reqq_produce(fcport->bfa, BFA_REQQ_PORT);
+       return BFA_TRUE;
+}
+
+/**
+ * Send port disable message to firmware.
+ */
+static bfa_boolean_t
+bfa_fcport_send_disable(struct bfa_fcport_s *fcport)
+{
+       struct bfi_fcport_req_s *m;
+
+       /**
+        * Increment message tag before queue check, so that responses to old
+        * requests are discarded.
+        */
+       fcport->msgtag++;
+
+       /**
+        * check for room in queue to send request now
+        */
+       m = bfa_reqq_next(fcport->bfa, BFA_REQQ_PORT);
+       if (!m) {
+               bfa_reqq_wait(fcport->bfa, BFA_REQQ_PORT,
+                                                       &fcport->reqq_wait);
+               return BFA_FALSE;
+       }
+
+       bfi_h2i_set(m->mh, BFI_MC_FCPORT, BFI_FCPORT_H2I_DISABLE_REQ,
+                       bfa_lpuid(fcport->bfa));
+       m->msgtag = fcport->msgtag;
+
+       /**
+        * queue I/O message to firmware
+        */
+       bfa_reqq_produce(fcport->bfa, BFA_REQQ_PORT);
+
+       return BFA_TRUE;
+}
+
+static void
+bfa_fcport_set_wwns(struct bfa_fcport_s *fcport)
+{
+       fcport->pwwn = bfa_ioc_get_pwwn(&fcport->bfa->ioc);
+       fcport->nwwn = bfa_ioc_get_nwwn(&fcport->bfa->ioc);
+
+       bfa_trc(fcport->bfa, fcport->pwwn);
+       bfa_trc(fcport->bfa, fcport->nwwn);
+}
+
+static void
+bfa_fcport_send_txcredit(void *port_cbarg)
+{
+
+       struct bfa_fcport_s *fcport = port_cbarg;
+       struct bfi_fcport_set_svc_params_req_s *m;
+
+       /**
+        * check for room in queue to send request now
+        */
+       m = bfa_reqq_next(fcport->bfa, BFA_REQQ_PORT);
+       if (!m) {
+               bfa_trc(fcport->bfa, fcport->cfg.tx_bbcredit);
+               return;
+       }
+
+       bfi_h2i_set(m->mh, BFI_MC_FCPORT, BFI_FCPORT_H2I_SET_SVC_PARAMS_REQ,
+                       bfa_lpuid(fcport->bfa));
+       m->tx_bbcredit = bfa_os_htons((u16)fcport->cfg.tx_bbcredit);
+
+       /**
+        * queue I/O message to firmware
+        */
+       bfa_reqq_produce(fcport->bfa, BFA_REQQ_PORT);
+}
+
+static void
+bfa_fcport_qos_stats_swap(struct bfa_qos_stats_s *d,
+       struct bfa_qos_stats_s *s)
+{
+       u32     *dip = (u32 *) d;
+       u32     *sip = (u32 *) s;
+       int             i;
+
+       /* Now swap the 32 bit fields */
+       for (i = 0; i < (sizeof(struct bfa_qos_stats_s)/sizeof(u32)); ++i)
+               dip[i] = bfa_os_ntohl(sip[i]);
+}
+
+static void
+bfa_fcport_fcoe_stats_swap(struct bfa_fcoe_stats_s *d,
+       struct bfa_fcoe_stats_s *s)
+{
+       u32     *dip = (u32 *) d;
+       u32     *sip = (u32 *) s;
+       int             i;
+
+       for (i = 0; i < ((sizeof(struct bfa_fcoe_stats_s))/sizeof(u32));
+            i = i + 2) {
+#ifdef __BIGENDIAN
+               dip[i] = bfa_os_ntohl(sip[i]);
+               dip[i + 1] = bfa_os_ntohl(sip[i + 1]);
+#else
+               dip[i] = bfa_os_ntohl(sip[i + 1]);
+               dip[i + 1] = bfa_os_ntohl(sip[i]);
+#endif
+       }
+}
+
+static void
+__bfa_cb_fcport_stats_get(void *cbarg, bfa_boolean_t complete)
+{
+       struct bfa_fcport_s *fcport = cbarg;
+
+       if (complete) {
+               if (fcport->stats_status == BFA_STATUS_OK) {
+                       struct bfa_timeval_s tv;
+
+                       /* Swap FC QoS or FCoE stats */
+                       if (bfa_ioc_get_fcmode(&fcport->bfa->ioc)) {
+                               bfa_fcport_qos_stats_swap(
+                                       &fcport->stats_ret->fcqos,
+                                       &fcport->stats->fcqos);
+                       } else {
+                               bfa_fcport_fcoe_stats_swap(
+                                       &fcport->stats_ret->fcoe,
+                                       &fcport->stats->fcoe);
+
+                               bfa_os_gettimeofday(&tv);
+                               fcport->stats_ret->fcoe.secs_reset =
+                                       tv.tv_sec - fcport->stats_reset_time;
+                       }
+               }
+               fcport->stats_cbfn(fcport->stats_cbarg, fcport->stats_status);
+       } else {
+               fcport->stats_busy = BFA_FALSE;
+               fcport->stats_status = BFA_STATUS_OK;
+       }
+}
+
+static void
+bfa_fcport_stats_get_timeout(void *cbarg)
+{
+       struct bfa_fcport_s *fcport = (struct bfa_fcport_s *) cbarg;
+
+       bfa_trc(fcport->bfa, fcport->stats_qfull);
+
+       if (fcport->stats_qfull) {
+               bfa_reqq_wcancel(&fcport->stats_reqq_wait);
+               fcport->stats_qfull = BFA_FALSE;
+       }
+
+       fcport->stats_status = BFA_STATUS_ETIMER;
+       bfa_cb_queue(fcport->bfa, &fcport->hcb_qe, __bfa_cb_fcport_stats_get,
+               fcport);
+}
+
+static void
+bfa_fcport_send_stats_get(void *cbarg)
+{
+       struct bfa_fcport_s *fcport = (struct bfa_fcport_s *) cbarg;
+       struct bfi_fcport_req_s *msg;
+
+       msg = bfa_reqq_next(fcport->bfa, BFA_REQQ_PORT);
+
+       if (!msg) {
+               fcport->stats_qfull = BFA_TRUE;
+               bfa_reqq_winit(&fcport->stats_reqq_wait,
+                               bfa_fcport_send_stats_get, fcport);
+               bfa_reqq_wait(fcport->bfa, BFA_REQQ_PORT,
+                               &fcport->stats_reqq_wait);
+               return;
+       }
+       fcport->stats_qfull = BFA_FALSE;
+
+       bfa_os_memset(msg, 0, sizeof(struct bfi_fcport_req_s));
+       bfi_h2i_set(msg->mh, BFI_MC_FCPORT, BFI_FCPORT_H2I_STATS_GET_REQ,
+                       bfa_lpuid(fcport->bfa));
+       bfa_reqq_produce(fcport->bfa, BFA_REQQ_PORT);
+}
+
+static void
+__bfa_cb_fcport_stats_clr(void *cbarg, bfa_boolean_t complete)
+{
+       struct bfa_fcport_s *fcport = cbarg;
+
+       if (complete) {
+               struct bfa_timeval_s tv;
+
+               /**
+                * re-initialize time stamp for stats reset
+                */
+               bfa_os_gettimeofday(&tv);
+               fcport->stats_reset_time = tv.tv_sec;
+
+               fcport->stats_cbfn(fcport->stats_cbarg, fcport->stats_status);
+       } else {
+               fcport->stats_busy = BFA_FALSE;
+               fcport->stats_status = BFA_STATUS_OK;
+       }
+}
+
+static void
+bfa_fcport_stats_clr_timeout(void *cbarg)
+{
+       struct bfa_fcport_s *fcport = (struct bfa_fcport_s *) cbarg;
+
+       bfa_trc(fcport->bfa, fcport->stats_qfull);
+
+       if (fcport->stats_qfull) {
+               bfa_reqq_wcancel(&fcport->stats_reqq_wait);
+               fcport->stats_qfull = BFA_FALSE;
+       }
+
+       fcport->stats_status = BFA_STATUS_ETIMER;
+       bfa_cb_queue(fcport->bfa, &fcport->hcb_qe,
+                       __bfa_cb_fcport_stats_clr, fcport);
+}
+
+static void
+bfa_fcport_send_stats_clear(void *cbarg)
+{
+       struct bfa_fcport_s *fcport = (struct bfa_fcport_s *) cbarg;
+       struct bfi_fcport_req_s *msg;
+
+       msg = bfa_reqq_next(fcport->bfa, BFA_REQQ_PORT);
+
+       if (!msg) {
+               fcport->stats_qfull = BFA_TRUE;
+               bfa_reqq_winit(&fcport->stats_reqq_wait,
+                               bfa_fcport_send_stats_clear, fcport);
+               bfa_reqq_wait(fcport->bfa, BFA_REQQ_PORT,
+                                               &fcport->stats_reqq_wait);
+               return;
+       }
+       fcport->stats_qfull = BFA_FALSE;
+
+       bfa_os_memset(msg, 0, sizeof(struct bfi_fcport_req_s));
+       bfi_h2i_set(msg->mh, BFI_MC_FCPORT, BFI_FCPORT_H2I_STATS_CLEAR_REQ,
+                       bfa_lpuid(fcport->bfa));
+       bfa_reqq_produce(fcport->bfa, BFA_REQQ_PORT);
+}
+
+/**
+ * Handle trunk SCN event from firmware.
+ */
+static void
+bfa_trunk_scn(struct bfa_fcport_s *fcport, struct bfi_fcport_trunk_scn_s *scn)
+{
+       struct bfa_fcport_trunk_s *trunk = &fcport->trunk;
+       struct bfi_fcport_trunk_link_s *tlink;
+       struct bfa_trunk_link_attr_s *lattr;
+       enum bfa_trunk_state state_prev;
+       int i;
+       int link_bm = 0;
+
+       bfa_trc(fcport->bfa, fcport->cfg.trunked);
+       bfa_assert(scn->trunk_state == BFA_TRUNK_ONLINE ||
+                  scn->trunk_state == BFA_TRUNK_OFFLINE);
+
+       bfa_trc(fcport->bfa, trunk->attr.state);
+       bfa_trc(fcport->bfa, scn->trunk_state);
+       bfa_trc(fcport->bfa, scn->trunk_speed);
+
+       /**
+        * Save off new state for trunk attribute query
+        */
+       state_prev = trunk->attr.state;
+       if (fcport->cfg.trunked && (trunk->attr.state != BFA_TRUNK_DISABLED))
+               trunk->attr.state = scn->trunk_state;
+       trunk->attr.speed = scn->trunk_speed;
+       for (i = 0; i < BFA_TRUNK_MAX_PORTS; i++) {
+               lattr = &trunk->attr.link_attr[i];
+               tlink = &scn->tlink[i];
+
+               lattr->link_state = tlink->state;
+               lattr->trunk_wwn  = tlink->trunk_wwn;
+               lattr->fctl       = tlink->fctl;
+               lattr->speed      = tlink->speed;
+               lattr->deskew     = bfa_os_ntohl(tlink->deskew);
+
+               if (tlink->state == BFA_TRUNK_LINK_STATE_UP) {
+                       fcport->speed    = tlink->speed;
+                       fcport->topology = BFA_PORT_TOPOLOGY_P2P;
+                       link_bm |= 1 << i;
+               }
+
+               bfa_trc(fcport->bfa, lattr->link_state);
+               bfa_trc(fcport->bfa, lattr->trunk_wwn);
+               bfa_trc(fcport->bfa, lattr->fctl);
+               bfa_trc(fcport->bfa, lattr->speed);
+               bfa_trc(fcport->bfa, lattr->deskew);
+       }
+
+       switch (link_bm) {
+       case 3:
+               bfa_plog_str(fcport->bfa->plog, BFA_PL_MID_HAL,
+                       BFA_PL_EID_TRUNK_SCN, 0, "Trunk up(0,1)");
+               break;
+       case 2:
+               bfa_plog_str(fcport->bfa->plog, BFA_PL_MID_HAL,
+                       BFA_PL_EID_TRUNK_SCN, 0, "Trunk up(-,1)");
+               break;
+       case 1:
+               bfa_plog_str(fcport->bfa->plog, BFA_PL_MID_HAL,
+                       BFA_PL_EID_TRUNK_SCN, 0, "Trunk up(0,-)");
+               break;
+       default:
+               bfa_plog_str(fcport->bfa->plog, BFA_PL_MID_HAL,
+                       BFA_PL_EID_TRUNK_SCN, 0, "Trunk down");
+       }
+
+       /**
+        * Notify upper layers if trunk state changed.
+        */
+       if ((state_prev != trunk->attr.state) ||
+               (scn->trunk_state == BFA_TRUNK_OFFLINE)) {
+               bfa_fcport_scn(fcport, (scn->trunk_state == BFA_TRUNK_ONLINE) ?
+                       BFA_PORT_LINKUP : BFA_PORT_LINKDOWN, BFA_TRUE);
+       }
+}
+
+static void
+bfa_trunk_iocdisable(struct bfa_s *bfa)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+       int i = 0;
+
+       /**
+        * In trunked mode, notify upper layers that link is down
+        */
+       if (fcport->cfg.trunked) {
+               if (fcport->trunk.attr.state == BFA_TRUNK_ONLINE)
+                       bfa_fcport_scn(fcport, BFA_PORT_LINKDOWN, BFA_TRUE);
+
+               fcport->trunk.attr.state = BFA_TRUNK_OFFLINE;
+               fcport->trunk.attr.speed = BFA_PORT_SPEED_UNKNOWN;
+               for (i = 0; i < BFA_TRUNK_MAX_PORTS; i++) {
+                       fcport->trunk.attr.link_attr[i].trunk_wwn = 0;
+                       fcport->trunk.attr.link_attr[i].fctl =
+                                               BFA_TRUNK_LINK_FCTL_NORMAL;
+                       fcport->trunk.attr.link_attr[i].link_state =
+                                               BFA_TRUNK_LINK_STATE_DN_LINKDN;
+                       fcport->trunk.attr.link_attr[i].speed =
+                                               BFA_PORT_SPEED_UNKNOWN;
+                       fcport->trunk.attr.link_attr[i].deskew = 0;
+               }
+       }
+}
+
+
+
+/**
+ *  hal_port_public
+ */
+
+/**
+ * Called to initialize port attributes
+ */
+void
+bfa_fcport_init(struct bfa_s *bfa)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+
+       /**
+        * Initialize port attributes from IOC hardware data.
+        */
+       bfa_fcport_set_wwns(fcport);
+       if (fcport->cfg.maxfrsize == 0)
+               fcport->cfg.maxfrsize = bfa_ioc_maxfrsize(&bfa->ioc);
+       fcport->cfg.rx_bbcredit = bfa_ioc_rx_bbcredit(&bfa->ioc);
+       fcport->speed_sup = bfa_ioc_speed_sup(&bfa->ioc);
+
+       bfa_assert(fcport->cfg.maxfrsize);
+       bfa_assert(fcport->cfg.rx_bbcredit);
+       bfa_assert(fcport->speed_sup);
+}
+
+/**
+ * Firmware message handler.
+ */
+void
+bfa_fcport_isr(struct bfa_s *bfa, struct bfi_msg_s *msg)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+       union bfi_fcport_i2h_msg_u i2hmsg;
+
+       i2hmsg.msg = msg;
+       fcport->event_arg.i2hmsg = i2hmsg;
+
+       bfa_trc(bfa, msg->mhdr.msg_id);
+       bfa_trc(bfa, bfa_sm_to_state(hal_port_sm_table, fcport->sm));
+
+       switch (msg->mhdr.msg_id) {
+       case BFI_FCPORT_I2H_ENABLE_RSP:
+               if (fcport->msgtag == i2hmsg.penable_rsp->msgtag)
+                       bfa_sm_send_event(fcport, BFA_FCPORT_SM_FWRSP);
+               break;
+
+       case BFI_FCPORT_I2H_DISABLE_RSP:
+               if (fcport->msgtag == i2hmsg.penable_rsp->msgtag)
+                       bfa_sm_send_event(fcport, BFA_FCPORT_SM_FWRSP);
+               break;
+
+       case BFI_FCPORT_I2H_EVENT:
+               if (i2hmsg.event->link_state.linkstate == BFA_PORT_LINKUP)
+                       bfa_sm_send_event(fcport, BFA_FCPORT_SM_LINKUP);
+               else
+                       bfa_sm_send_event(fcport, BFA_FCPORT_SM_LINKDOWN);
+               break;
+
+       case BFI_FCPORT_I2H_TRUNK_SCN:
+               bfa_trunk_scn(fcport, i2hmsg.trunk_scn);
+               break;
+
+       case BFI_FCPORT_I2H_STATS_GET_RSP:
+               /*
+                * check for timer pop before processing the rsp
+                */
+               if (fcport->stats_busy == BFA_FALSE ||
+                   fcport->stats_status == BFA_STATUS_ETIMER)
+                       break;
+
+               bfa_timer_stop(&fcport->timer);
+               fcport->stats_status = i2hmsg.pstatsget_rsp->status;
+               bfa_cb_queue(fcport->bfa, &fcport->hcb_qe,
+                               __bfa_cb_fcport_stats_get, fcport);
+               break;
+
+       case BFI_FCPORT_I2H_STATS_CLEAR_RSP:
+               /*
+                * check for timer pop before processing the rsp
+                */
+               if (fcport->stats_busy == BFA_FALSE ||
+                   fcport->stats_status == BFA_STATUS_ETIMER)
+                       break;
+
+               bfa_timer_stop(&fcport->timer);
+               fcport->stats_status = BFA_STATUS_OK;
+               bfa_cb_queue(fcport->bfa, &fcport->hcb_qe,
+                               __bfa_cb_fcport_stats_clr, fcport);
+               break;
+
+       case BFI_FCPORT_I2H_ENABLE_AEN:
+               bfa_sm_send_event(fcport, BFA_FCPORT_SM_ENABLE);
+               break;
+
+       case BFI_FCPORT_I2H_DISABLE_AEN:
+               bfa_sm_send_event(fcport, BFA_FCPORT_SM_DISABLE);
+               break;
+
+       default:
+               bfa_assert(0);
+       break;
+       }
+}
+
+
+
+/**
+ *  hal_port_api
+ */
+
+/**
+ * Registered callback for port events.
+ */
+void
+bfa_fcport_event_register(struct bfa_s *bfa,
+                               void (*cbfn) (void *cbarg,
+                               enum bfa_port_linkstate event),
+                               void *cbarg)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+
+       fcport->event_cbfn = cbfn;
+       fcport->event_cbarg = cbarg;
+}
+
+bfa_status_t
+bfa_fcport_enable(struct bfa_s *bfa)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+
+       if (bfa_ioc_is_disabled(&bfa->ioc))
+               return BFA_STATUS_IOC_DISABLED;
+
+       if (fcport->diag_busy)
+               return BFA_STATUS_DIAG_BUSY;
+
+       bfa_sm_send_event(BFA_FCPORT_MOD(bfa), BFA_FCPORT_SM_ENABLE);
+       return BFA_STATUS_OK;
+}
+
+bfa_status_t
+bfa_fcport_disable(struct bfa_s *bfa)
+{
+
+       if (bfa_ioc_is_disabled(&bfa->ioc))
+               return BFA_STATUS_IOC_DISABLED;
+
+       bfa_sm_send_event(BFA_FCPORT_MOD(bfa), BFA_FCPORT_SM_DISABLE);
+       return BFA_STATUS_OK;
+}
+
+/**
+ * Configure port speed.
+ */
+bfa_status_t
+bfa_fcport_cfg_speed(struct bfa_s *bfa, enum bfa_port_speed speed)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+
+       bfa_trc(bfa, speed);
+
+       if (fcport->cfg.trunked == BFA_TRUE)
+               return BFA_STATUS_TRUNK_ENABLED;
+       if ((speed != BFA_PORT_SPEED_AUTO) && (speed > fcport->speed_sup)) {
+               bfa_trc(bfa, fcport->speed_sup);
+               return BFA_STATUS_UNSUPP_SPEED;
+       }
+
+       fcport->cfg.speed = speed;
+
+       return BFA_STATUS_OK;
+}
+
+/**
+ * Get current speed.
+ */
+enum bfa_port_speed
+bfa_fcport_get_speed(struct bfa_s *bfa)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+
+       return fcport->speed;
+}
+
+/**
+ * Configure port topology.
+ */
+bfa_status_t
+bfa_fcport_cfg_topology(struct bfa_s *bfa, enum bfa_port_topology topology)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+
+       bfa_trc(bfa, topology);
+       bfa_trc(bfa, fcport->cfg.topology);
+
+       switch (topology) {
+       case BFA_PORT_TOPOLOGY_P2P:
+       case BFA_PORT_TOPOLOGY_LOOP:
+       case BFA_PORT_TOPOLOGY_AUTO:
+               break;
+
+       default:
+               return BFA_STATUS_EINVAL;
+       }
+
+       fcport->cfg.topology = topology;
+       return BFA_STATUS_OK;
+}
+
+/**
+ * Get current topology.
+ */
+enum bfa_port_topology
+bfa_fcport_get_topology(struct bfa_s *bfa)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+
+       return fcport->topology;
+}
+
+bfa_status_t
+bfa_fcport_cfg_hardalpa(struct bfa_s *bfa, u8 alpa)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+
+       bfa_trc(bfa, alpa);
+       bfa_trc(bfa, fcport->cfg.cfg_hardalpa);
+       bfa_trc(bfa, fcport->cfg.hardalpa);
+
+       fcport->cfg.cfg_hardalpa = BFA_TRUE;
+       fcport->cfg.hardalpa = alpa;
+
+       return BFA_STATUS_OK;
+}
+
+bfa_status_t
+bfa_fcport_clr_hardalpa(struct bfa_s *bfa)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+
+       bfa_trc(bfa, fcport->cfg.cfg_hardalpa);
+       bfa_trc(bfa, fcport->cfg.hardalpa);
+
+       fcport->cfg.cfg_hardalpa = BFA_FALSE;
+       return BFA_STATUS_OK;
+}
+
+bfa_boolean_t
+bfa_fcport_get_hardalpa(struct bfa_s *bfa, u8 *alpa)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+
+       *alpa = fcport->cfg.hardalpa;
+       return fcport->cfg.cfg_hardalpa;
+}
+
+u8
+bfa_fcport_get_myalpa(struct bfa_s *bfa)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+
+       return fcport->myalpa;
+}
+
+bfa_status_t
+bfa_fcport_cfg_maxfrsize(struct bfa_s *bfa, u16 maxfrsize)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+
+       bfa_trc(bfa, maxfrsize);
+       bfa_trc(bfa, fcport->cfg.maxfrsize);
+
+       /* with in range */
+       if ((maxfrsize > FC_MAX_PDUSZ) || (maxfrsize < FC_MIN_PDUSZ))
+               return BFA_STATUS_INVLD_DFSZ;
+
+       /* power of 2, if not the max frame size of 2112 */
+       if ((maxfrsize != FC_MAX_PDUSZ) && (maxfrsize & (maxfrsize - 1)))
+               return BFA_STATUS_INVLD_DFSZ;
+
+       fcport->cfg.maxfrsize = maxfrsize;
+       return BFA_STATUS_OK;
+}
+
+u16
+bfa_fcport_get_maxfrsize(struct bfa_s *bfa)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+
+       return fcport->cfg.maxfrsize;
+}
+
+u8
+bfa_fcport_get_rx_bbcredit(struct bfa_s *bfa)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+
+       return fcport->cfg.rx_bbcredit;
+}
+
+void
+bfa_fcport_set_tx_bbcredit(struct bfa_s *bfa, u16 tx_bbcredit)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+
+       fcport->cfg.tx_bbcredit = (u8)tx_bbcredit;
+       bfa_fcport_send_txcredit(fcport);
+}
+
+/**
+ * Get port attributes.
+ */
+
+wwn_t
+bfa_fcport_get_wwn(struct bfa_s *bfa, bfa_boolean_t node)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+       if (node)
+               return fcport->nwwn;
+       else
+               return fcport->pwwn;
+}
+
+void
+bfa_fcport_get_attr(struct bfa_s *bfa, struct bfa_port_attr_s *attr)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+
+       bfa_os_memset(attr, 0, sizeof(struct bfa_port_attr_s));
+
+       attr->nwwn = fcport->nwwn;
+       attr->pwwn = fcport->pwwn;
+
+       attr->factorypwwn =  bfa_ioc_get_mfg_pwwn(&bfa->ioc);
+       attr->factorynwwn =  bfa_ioc_get_mfg_nwwn(&bfa->ioc);
+
+       bfa_os_memcpy(&attr->pport_cfg, &fcport->cfg,
+               sizeof(struct bfa_port_cfg_s));
+       /* speed attributes */
+       attr->pport_cfg.speed = fcport->cfg.speed;
+       attr->speed_supported = fcport->speed_sup;
+       attr->speed = fcport->speed;
+       attr->cos_supported = FC_CLASS_3;
+
+       /* topology attributes */
+       attr->pport_cfg.topology = fcport->cfg.topology;
+       attr->topology = fcport->topology;
+       attr->pport_cfg.trunked = fcport->cfg.trunked;
+
+       /* beacon attributes */
+       attr->beacon = fcport->beacon;
+       attr->link_e2e_beacon = fcport->link_e2e_beacon;
+       attr->plog_enabled = bfa_plog_get_setting(fcport->bfa->plog);
+       attr->io_profile = bfa_fcpim_get_io_profile(fcport->bfa);
+
+       attr->pport_cfg.path_tov  = bfa_fcpim_path_tov_get(bfa);
+       attr->pport_cfg.q_depth  = bfa_fcpim_qdepth_get(bfa);
+       attr->port_state = bfa_sm_to_state(hal_port_sm_table, fcport->sm);
+       if (bfa_ioc_is_disabled(&fcport->bfa->ioc))
+               attr->port_state = BFA_PORT_ST_IOCDIS;
+       else if (bfa_ioc_fw_mismatch(&fcport->bfa->ioc))
+               attr->port_state = BFA_PORT_ST_FWMISMATCH;
+
+       /* FCoE vlan */
+       attr->fcoe_vlan = fcport->fcoe_vlan;
+}
+
+#define BFA_FCPORT_STATS_TOV   1000
+
+/**
+ * Fetch port statistics (FCQoS or FCoE).
+ */
+bfa_status_t
+bfa_fcport_get_stats(struct bfa_s *bfa, union bfa_fcport_stats_u *stats,
+       bfa_cb_port_t cbfn, void *cbarg)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+
+       if (fcport->stats_busy) {
+               bfa_trc(bfa, fcport->stats_busy);
+               return BFA_STATUS_DEVBUSY;
+       }
+
+       fcport->stats_busy  = BFA_TRUE;
+       fcport->stats_ret   = stats;
+       fcport->stats_cbfn  = cbfn;
+       fcport->stats_cbarg = cbarg;
+
+       bfa_fcport_send_stats_get(fcport);
+
+       bfa_timer_start(bfa, &fcport->timer, bfa_fcport_stats_get_timeout,
+                       fcport, BFA_FCPORT_STATS_TOV);
+       return BFA_STATUS_OK;
+}
+
+/**
+ * Reset port statistics (FCQoS or FCoE).
+ */
+bfa_status_t
+bfa_fcport_clear_stats(struct bfa_s *bfa, bfa_cb_port_t cbfn, void *cbarg)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+
+       if (fcport->stats_busy) {
+               bfa_trc(bfa, fcport->stats_busy);
+               return BFA_STATUS_DEVBUSY;
+       }
+
+       fcport->stats_busy  = BFA_TRUE;
+       fcport->stats_cbfn  = cbfn;
+       fcport->stats_cbarg = cbarg;
+
+       bfa_fcport_send_stats_clear(fcport);
+
+       bfa_timer_start(bfa, &fcport->timer, bfa_fcport_stats_clr_timeout,
+                       fcport, BFA_FCPORT_STATS_TOV);
+       return BFA_STATUS_OK;
+}
+
+/**
+ * Fetch FCQoS port statistics
+ */
+bfa_status_t
+bfa_fcport_get_qos_stats(struct bfa_s *bfa, union bfa_fcport_stats_u *stats,
+       bfa_cb_port_t cbfn, void *cbarg)
+{
+       /* Meaningful only for FC mode */
+       bfa_assert(bfa_ioc_get_fcmode(&bfa->ioc));
+
+       return bfa_fcport_get_stats(bfa, stats, cbfn, cbarg);
+}
+
+/**
+ * Reset FCoE port statistics
+ */
+bfa_status_t
+bfa_fcport_clear_qos_stats(struct bfa_s *bfa, bfa_cb_port_t cbfn, void *cbarg)
+{
+       /* Meaningful only for FC mode */
+       bfa_assert(bfa_ioc_get_fcmode(&bfa->ioc));
+
+       return bfa_fcport_clear_stats(bfa, cbfn, cbarg);
+}
+
+/**
+ * Fetch FCQoS port statistics
+ */
+bfa_status_t
+bfa_fcport_get_fcoe_stats(struct bfa_s *bfa, union bfa_fcport_stats_u *stats,
+       bfa_cb_port_t cbfn, void *cbarg)
+{
+       /* Meaningful only for FCoE mode */
+       bfa_assert(!bfa_ioc_get_fcmode(&bfa->ioc));
+
+       return bfa_fcport_get_stats(bfa, stats, cbfn, cbarg);
+}
+
+/**
+ * Reset FCoE port statistics
+ */
+bfa_status_t
+bfa_fcport_clear_fcoe_stats(struct bfa_s *bfa, bfa_cb_port_t cbfn, void *cbarg)
+{
+       /* Meaningful only for FCoE mode */
+       bfa_assert(!bfa_ioc_get_fcmode(&bfa->ioc));
+
+       return bfa_fcport_clear_stats(bfa, cbfn, cbarg);
+}
+
+void
+bfa_fcport_qos_get_attr(struct bfa_s *bfa, struct bfa_qos_attr_s *qos_attr)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+
+       qos_attr->state = fcport->qos_attr.state;
+       qos_attr->total_bb_cr = bfa_os_ntohl(fcport->qos_attr.total_bb_cr);
+}
+
+void
+bfa_fcport_qos_get_vc_attr(struct bfa_s *bfa,
+       struct bfa_qos_vc_attr_s *qos_vc_attr)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+       struct bfa_qos_vc_attr_s *bfa_vc_attr = &fcport->qos_vc_attr;
+       u32 i = 0;
+
+       qos_vc_attr->total_vc_count = bfa_os_ntohs(bfa_vc_attr->total_vc_count);
+       qos_vc_attr->shared_credit  = bfa_os_ntohs(bfa_vc_attr->shared_credit);
+       qos_vc_attr->elp_opmode_flags  =
+                       bfa_os_ntohl(bfa_vc_attr->elp_opmode_flags);
+
+       /* Individual VC info */
+       while (i < qos_vc_attr->total_vc_count) {
+               qos_vc_attr->vc_info[i].vc_credit       =
+                               bfa_vc_attr->vc_info[i].vc_credit;
+               qos_vc_attr->vc_info[i].borrow_credit   =
+                               bfa_vc_attr->vc_info[i].borrow_credit;
+               qos_vc_attr->vc_info[i].priority        =
+                               bfa_vc_attr->vc_info[i].priority;
+               ++i;
+       }
+}
+
+/**
+ * Fetch port attributes.
+ */
+bfa_boolean_t
+bfa_fcport_is_disabled(struct bfa_s *bfa)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+
+       return bfa_sm_to_state(hal_port_sm_table, fcport->sm) ==
+               BFA_PORT_ST_DISABLED;
+
+}
+
+bfa_boolean_t
+bfa_fcport_is_ratelim(struct bfa_s *bfa)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+
+       return fcport->cfg.ratelimit ? BFA_TRUE : BFA_FALSE;
+
+}
+
+void
+bfa_fcport_cfg_qos(struct bfa_s *bfa, bfa_boolean_t on_off)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+       enum bfa_ioc_type_e ioc_type = bfa_get_type(bfa);
+
+       bfa_trc(bfa, on_off);
+       bfa_trc(bfa, fcport->cfg.qos_enabled);
+
+       bfa_trc(bfa, ioc_type);
+
+       if (ioc_type == BFA_IOC_TYPE_FC) {
+               fcport->cfg.qos_enabled = on_off;
+               /**
+                * Notify fcpim of the change in QoS state
+                */
+               bfa_fcpim_update_ioredirect(bfa);
+       }
+}
+
+void
+bfa_fcport_cfg_ratelim(struct bfa_s *bfa, bfa_boolean_t on_off)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+
+       bfa_trc(bfa, on_off);
+       bfa_trc(bfa, fcport->cfg.ratelimit);
+
+       fcport->cfg.ratelimit = on_off;
+       if (fcport->cfg.trl_def_speed == BFA_PORT_SPEED_UNKNOWN)
+               fcport->cfg.trl_def_speed = BFA_PORT_SPEED_1GBPS;
+}
+
+/**
+ * Configure default minimum ratelim speed
+ */
+bfa_status_t
+bfa_fcport_cfg_ratelim_speed(struct bfa_s *bfa, enum bfa_port_speed speed)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+
+       bfa_trc(bfa, speed);
+
+       /* Auto and speeds greater than the supported speed, are invalid */
+       if ((speed == BFA_PORT_SPEED_AUTO) || (speed > fcport->speed_sup)) {
+               bfa_trc(bfa, fcport->speed_sup);
+               return BFA_STATUS_UNSUPP_SPEED;
+       }
+
+       fcport->cfg.trl_def_speed = speed;
+
+       return BFA_STATUS_OK;
+}
+
+/**
+ * Get default minimum ratelim speed
+ */
+enum bfa_port_speed
+bfa_fcport_get_ratelim_speed(struct bfa_s *bfa)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+
+       bfa_trc(bfa, fcport->cfg.trl_def_speed);
+       return fcport->cfg.trl_def_speed;
+
+}
+void
+bfa_fcport_busy(struct bfa_s *bfa, bfa_boolean_t status)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+
+       bfa_trc(bfa, status);
+       bfa_trc(bfa, fcport->diag_busy);
+
+       fcport->diag_busy = status;
+}
+
+void
+bfa_fcport_beacon(void *dev, bfa_boolean_t beacon,
+       bfa_boolean_t link_e2e_beacon)
+{
+       struct bfa_s *bfa = dev;
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+
+       bfa_trc(bfa, beacon);
+       bfa_trc(bfa, link_e2e_beacon);
+       bfa_trc(bfa, fcport->beacon);
+       bfa_trc(bfa, fcport->link_e2e_beacon);
+
+       fcport->beacon = beacon;
+       fcport->link_e2e_beacon = link_e2e_beacon;
+}
+
+bfa_boolean_t
+bfa_fcport_is_linkup(struct bfa_s *bfa)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+
+       return  (!fcport->cfg.trunked &&
+                bfa_sm_cmp_state(fcport, bfa_fcport_sm_linkup)) ||
+               (fcport->cfg.trunked &&
+                fcport->trunk.attr.state == BFA_TRUNK_ONLINE);
+}
+
+bfa_boolean_t
+bfa_fcport_is_qos_enabled(struct bfa_s *bfa)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+
+       return fcport->cfg.qos_enabled;
+}
+
+bfa_status_t
+bfa_trunk_get_attr(struct bfa_s *bfa, struct bfa_trunk_attr_s *attr)
+
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+       struct bfa_fcport_trunk_s *trunk = &fcport->trunk;
+
+       bfa_trc(bfa, fcport->cfg.trunked);
+       bfa_trc(bfa, trunk->attr.state);
+       *attr = trunk->attr;
+       attr->port_id = bfa_lps_get_base_pid(bfa);
+
+       return BFA_STATUS_OK;
+}
+
+void
+bfa_trunk_enable_cfg(struct bfa_s *bfa)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+       struct bfa_fcport_trunk_s *trunk = &fcport->trunk;
+
+       bfa_trc(bfa, 1);
+       trunk->attr.state = BFA_TRUNK_OFFLINE;
+       fcport->cfg.trunked = BFA_TRUE;
+}
+
+bfa_status_t
+bfa_trunk_enable(struct bfa_s *bfa)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+       struct bfa_fcport_trunk_s *trunk = &fcport->trunk;
+
+       bfa_trc(bfa, 1);
+
+       trunk->attr.state   = BFA_TRUNK_OFFLINE;
+       bfa_fcport_disable(bfa);
+       fcport->cfg.trunked = BFA_TRUE;
+       bfa_fcport_enable(bfa);
+
+       return BFA_STATUS_OK;
+}
+
+bfa_status_t
+bfa_trunk_disable(struct bfa_s *bfa)
+{
+       struct bfa_fcport_s *fcport = BFA_FCPORT_MOD(bfa);
+       struct bfa_fcport_trunk_s *trunk = &fcport->trunk;
+
+       bfa_trc(bfa, 0);
+       trunk->attr.state   = BFA_TRUNK_DISABLED;
+       bfa_fcport_disable(bfa);
+       fcport->cfg.trunked = BFA_FALSE;
+       bfa_fcport_enable(bfa);
+       return BFA_STATUS_OK;
+}
+
+
+/**
+ * Rport State machine functions
+ */
+/**
+ * Beginning state, only online event expected.
+ */
+static void
+bfa_rport_sm_uninit(struct bfa_rport_s *rp, enum bfa_rport_event event)
+{
+       bfa_trc(rp->bfa, rp->rport_tag);
+       bfa_trc(rp->bfa, event);
+
+       switch (event) {
+       case BFA_RPORT_SM_CREATE:
+               bfa_stats(rp, sm_un_cr);
+               bfa_sm_set_state(rp, bfa_rport_sm_created);
+               break;
+
+       default:
+               bfa_stats(rp, sm_un_unexp);
+               bfa_sm_fault(rp->bfa, event);
+       }
+}
+
+static void
+bfa_rport_sm_created(struct bfa_rport_s *rp, enum bfa_rport_event event)
+{
+       bfa_trc(rp->bfa, rp->rport_tag);
+       bfa_trc(rp->bfa, event);
+
+       switch (event) {
+       case BFA_RPORT_SM_ONLINE:
+               bfa_stats(rp, sm_cr_on);
+               if (bfa_rport_send_fwcreate(rp))
+                       bfa_sm_set_state(rp, bfa_rport_sm_fwcreate);
+               else
+                       bfa_sm_set_state(rp, bfa_rport_sm_fwcreate_qfull);
+               break;
+
+       case BFA_RPORT_SM_DELETE:
+               bfa_stats(rp, sm_cr_del);
+               bfa_sm_set_state(rp, bfa_rport_sm_uninit);
+               bfa_rport_free(rp);
+               break;
+
+       case BFA_RPORT_SM_HWFAIL:
+               bfa_stats(rp, sm_cr_hwf);
+               bfa_sm_set_state(rp, bfa_rport_sm_iocdisable);
+               break;
+
+       default:
+               bfa_stats(rp, sm_cr_unexp);
+               bfa_sm_fault(rp->bfa, event);
+       }
+}
+
+/**
+ * Waiting for rport create response from firmware.
+ */
+static void
+bfa_rport_sm_fwcreate(struct bfa_rport_s *rp, enum bfa_rport_event event)
+{
+       bfa_trc(rp->bfa, rp->rport_tag);
+       bfa_trc(rp->bfa, event);
+
+       switch (event) {
+       case BFA_RPORT_SM_FWRSP:
+               bfa_stats(rp, sm_fwc_rsp);
+               bfa_sm_set_state(rp, bfa_rport_sm_online);
+               bfa_rport_online_cb(rp);
+               break;
+
+       case BFA_RPORT_SM_DELETE:
+               bfa_stats(rp, sm_fwc_del);
+               bfa_sm_set_state(rp, bfa_rport_sm_delete_pending);
+               break;
+
+       case BFA_RPORT_SM_OFFLINE:
+               bfa_stats(rp, sm_fwc_off);
+               bfa_sm_set_state(rp, bfa_rport_sm_offline_pending);
+               break;
+
+       case BFA_RPORT_SM_HWFAIL:
+               bfa_stats(rp, sm_fwc_hwf);
+               bfa_sm_set_state(rp, bfa_rport_sm_iocdisable);
+               break;
+
+       default:
+               bfa_stats(rp, sm_fwc_unexp);
+               bfa_sm_fault(rp->bfa, event);
+       }
+}
+
+/**
+ * Request queue is full, awaiting queue resume to send create request.
+ */
+static void
+bfa_rport_sm_fwcreate_qfull(struct bfa_rport_s *rp, enum bfa_rport_event event)
+{
+       bfa_trc(rp->bfa, rp->rport_tag);
+       bfa_trc(rp->bfa, event);
+
+       switch (event) {
+       case BFA_RPORT_SM_QRESUME:
+               bfa_sm_set_state(rp, bfa_rport_sm_fwcreate);
+               bfa_rport_send_fwcreate(rp);
+               break;
+
+       case BFA_RPORT_SM_DELETE:
+               bfa_stats(rp, sm_fwc_del);
+               bfa_sm_set_state(rp, bfa_rport_sm_uninit);
+               bfa_reqq_wcancel(&rp->reqq_wait);
+               bfa_rport_free(rp);
+               break;
+
+       case BFA_RPORT_SM_OFFLINE:
+               bfa_stats(rp, sm_fwc_off);
+               bfa_sm_set_state(rp, bfa_rport_sm_offline);
+               bfa_reqq_wcancel(&rp->reqq_wait);
+               bfa_rport_offline_cb(rp);
+               break;
+
+       case BFA_RPORT_SM_HWFAIL:
+               bfa_stats(rp, sm_fwc_hwf);
+               bfa_sm_set_state(rp, bfa_rport_sm_iocdisable);
+               bfa_reqq_wcancel(&rp->reqq_wait);
+               break;
+
+       default:
+               bfa_stats(rp, sm_fwc_unexp);
+               bfa_sm_fault(rp->bfa, event);
+       }
+}
+
+/**
+ * Online state - normal parking state.
+ */
+static void
+bfa_rport_sm_online(struct bfa_rport_s *rp, enum bfa_rport_event event)
+{
+       struct bfi_rport_qos_scn_s *qos_scn;
+
+       bfa_trc(rp->bfa, rp->rport_tag);
+       bfa_trc(rp->bfa, event);
+
+       switch (event) {
+       case BFA_RPORT_SM_OFFLINE:
+               bfa_stats(rp, sm_on_off);
+               if (bfa_rport_send_fwdelete(rp))
+                       bfa_sm_set_state(rp, bfa_rport_sm_fwdelete);
+               else
+                       bfa_sm_set_state(rp, bfa_rport_sm_fwdelete_qfull);
+               break;
+
+       case BFA_RPORT_SM_DELETE:
+               bfa_stats(rp, sm_on_del);
+               if (bfa_rport_send_fwdelete(rp))
+                       bfa_sm_set_state(rp, bfa_rport_sm_deleting);
+               else
+                       bfa_sm_set_state(rp, bfa_rport_sm_deleting_qfull);
+               break;
+
+       case BFA_RPORT_SM_HWFAIL:
+               bfa_stats(rp, sm_on_hwf);
+               bfa_sm_set_state(rp, bfa_rport_sm_iocdisable);
+               break;
+
+       case BFA_RPORT_SM_SET_SPEED:
+               bfa_rport_send_fwspeed(rp);
+               break;
+
+       case BFA_RPORT_SM_QOS_SCN:
+               qos_scn = (struct bfi_rport_qos_scn_s *) rp->event_arg.fw_msg;
+               rp->qos_attr = qos_scn->new_qos_attr;
+               bfa_trc(rp->bfa, qos_scn->old_qos_attr.qos_flow_id);
+               bfa_trc(rp->bfa, qos_scn->new_qos_attr.qos_flow_id);
+               bfa_trc(rp->bfa, qos_scn->old_qos_attr.qos_priority);
+               bfa_trc(rp->bfa, qos_scn->new_qos_attr.qos_priority);
+
+               qos_scn->old_qos_attr.qos_flow_id  =
+                       bfa_os_ntohl(qos_scn->old_qos_attr.qos_flow_id);
+               qos_scn->new_qos_attr.qos_flow_id  =
+                       bfa_os_ntohl(qos_scn->new_qos_attr.qos_flow_id);
+
+               if (qos_scn->old_qos_attr.qos_flow_id !=
+                       qos_scn->new_qos_attr.qos_flow_id)
+                       bfa_cb_rport_qos_scn_flowid(rp->rport_drv,
+                                                   qos_scn->old_qos_attr,
+                                                   qos_scn->new_qos_attr);
+               if (qos_scn->old_qos_attr.qos_priority !=
+                       qos_scn->new_qos_attr.qos_priority)
+                       bfa_cb_rport_qos_scn_prio(rp->rport_drv,
+                                                 qos_scn->old_qos_attr,
+                                                 qos_scn->new_qos_attr);
+               break;
+
+       default:
+               bfa_stats(rp, sm_on_unexp);
+               bfa_sm_fault(rp->bfa, event);
+       }
+}
+
+/**
+ * Firmware rport is being deleted - awaiting f/w response.
+ */
+static void
+bfa_rport_sm_fwdelete(struct bfa_rport_s *rp, enum bfa_rport_event event)
+{
+       bfa_trc(rp->bfa, rp->rport_tag);
+       bfa_trc(rp->bfa, event);
+
+       switch (event) {
+       case BFA_RPORT_SM_FWRSP:
+               bfa_stats(rp, sm_fwd_rsp);
+               bfa_sm_set_state(rp, bfa_rport_sm_offline);
+               bfa_rport_offline_cb(rp);
+               break;
+
+       case BFA_RPORT_SM_DELETE:
+               bfa_stats(rp, sm_fwd_del);
+               bfa_sm_set_state(rp, bfa_rport_sm_deleting);
+               break;
+
+       case BFA_RPORT_SM_HWFAIL:
+               bfa_stats(rp, sm_fwd_hwf);
+               bfa_sm_set_state(rp, bfa_rport_sm_iocdisable);
+               bfa_rport_offline_cb(rp);
+               break;
+
+       default:
+               bfa_stats(rp, sm_fwd_unexp);
+               bfa_sm_fault(rp->bfa, event);
+       }
+}
+
+static void
+bfa_rport_sm_fwdelete_qfull(struct bfa_rport_s *rp, enum bfa_rport_event event)
+{
+       bfa_trc(rp->bfa, rp->rport_tag);
+       bfa_trc(rp->bfa, event);
+
+       switch (event) {
+       case BFA_RPORT_SM_QRESUME:
+               bfa_sm_set_state(rp, bfa_rport_sm_fwdelete);
+               bfa_rport_send_fwdelete(rp);
+               break;
+
+       case BFA_RPORT_SM_DELETE:
+               bfa_stats(rp, sm_fwd_del);
+               bfa_sm_set_state(rp, bfa_rport_sm_deleting_qfull);
+               break;
+
+       case BFA_RPORT_SM_HWFAIL:
+               bfa_stats(rp, sm_fwd_hwf);
+               bfa_sm_set_state(rp, bfa_rport_sm_iocdisable);
+               bfa_reqq_wcancel(&rp->reqq_wait);
+               bfa_rport_offline_cb(rp);
+               break;
+
+       default:
+               bfa_stats(rp, sm_fwd_unexp);
+               bfa_sm_fault(rp->bfa, event);
+       }
+}
+
+/**
+ * Offline state.
+ */
+static void
+bfa_rport_sm_offline(struct bfa_rport_s *rp, enum bfa_rport_event event)
+{
+       bfa_trc(rp->bfa, rp->rport_tag);
+       bfa_trc(rp->bfa, event);
+
+       switch (event) {
+       case BFA_RPORT_SM_DELETE:
+               bfa_stats(rp, sm_off_del);
+               bfa_sm_set_state(rp, bfa_rport_sm_uninit);
+               bfa_rport_free(rp);
+               break;
+
+       case BFA_RPORT_SM_ONLINE:
+               bfa_stats(rp, sm_off_on);
+               if (bfa_rport_send_fwcreate(rp))
+                       bfa_sm_set_state(rp, bfa_rport_sm_fwcreate);
+               else
+                       bfa_sm_set_state(rp, bfa_rport_sm_fwcreate_qfull);
+               break;
+
+       case BFA_RPORT_SM_HWFAIL:
+               bfa_stats(rp, sm_off_hwf);
+               bfa_sm_set_state(rp, bfa_rport_sm_iocdisable);
+               break;
+
+       default:
+               bfa_stats(rp, sm_off_unexp);
+               bfa_sm_fault(rp->bfa, event);
+       }
+}
+
+/**
+ * Rport is deleted, waiting for firmware response to delete.
+ */
+static void
+bfa_rport_sm_deleting(struct bfa_rport_s *rp, enum bfa_rport_event event)
+{
+       bfa_trc(rp->bfa, rp->rport_tag);
+       bfa_trc(rp->bfa, event);
+
+       switch (event) {
+       case BFA_RPORT_SM_FWRSP:
+               bfa_stats(rp, sm_del_fwrsp);
+               bfa_sm_set_state(rp, bfa_rport_sm_uninit);
+               bfa_rport_free(rp);
+               break;
+
+       case BFA_RPORT_SM_HWFAIL:
+               bfa_stats(rp, sm_del_hwf);
+               bfa_sm_set_state(rp, bfa_rport_sm_uninit);
+               bfa_rport_free(rp);
+               break;
+
+       default:
+               bfa_sm_fault(rp->bfa, event);
+       }
+}
+
+static void
+bfa_rport_sm_deleting_qfull(struct bfa_rport_s *rp, enum bfa_rport_event event)
+{
+       bfa_trc(rp->bfa, rp->rport_tag);
+       bfa_trc(rp->bfa, event);
+
+       switch (event) {
+       case BFA_RPORT_SM_QRESUME:
+               bfa_stats(rp, sm_del_fwrsp);
+               bfa_sm_set_state(rp, bfa_rport_sm_deleting);
+               bfa_rport_send_fwdelete(rp);
+               break;
+
+       case BFA_RPORT_SM_HWFAIL:
+               bfa_stats(rp, sm_del_hwf);
+               bfa_sm_set_state(rp, bfa_rport_sm_uninit);
+               bfa_reqq_wcancel(&rp->reqq_wait);
+               bfa_rport_free(rp);
+               break;
+
+       default:
+               bfa_sm_fault(rp->bfa, event);
+       }
+}
+
+/**
+ * Waiting for rport create response from firmware. A delete is pending.
+ */
+static void
+bfa_rport_sm_delete_pending(struct bfa_rport_s *rp,
+                               enum bfa_rport_event event)
+{
+       bfa_trc(rp->bfa, rp->rport_tag);
+       bfa_trc(rp->bfa, event);
+
+       switch (event) {
+       case BFA_RPORT_SM_FWRSP:
+               bfa_stats(rp, sm_delp_fwrsp);
+               if (bfa_rport_send_fwdelete(rp))
+                       bfa_sm_set_state(rp, bfa_rport_sm_deleting);
+               else
+                       bfa_sm_set_state(rp, bfa_rport_sm_deleting_qfull);
+               break;
+
+       case BFA_RPORT_SM_HWFAIL:
+               bfa_stats(rp, sm_delp_hwf);
+               bfa_sm_set_state(rp, bfa_rport_sm_uninit);
+               bfa_rport_free(rp);
+               break;
+
+       default:
+               bfa_stats(rp, sm_delp_unexp);
+               bfa_sm_fault(rp->bfa, event);
+       }
+}
+
+/**
+ * Waiting for rport create response from firmware. Rport offline is pending.
+ */
+static void
+bfa_rport_sm_offline_pending(struct bfa_rport_s *rp,
+                                enum bfa_rport_event event)
+{
+       bfa_trc(rp->bfa, rp->rport_tag);
+       bfa_trc(rp->bfa, event);
+
+       switch (event) {
+       case BFA_RPORT_SM_FWRSP:
+               bfa_stats(rp, sm_offp_fwrsp);
+               if (bfa_rport_send_fwdelete(rp))
+                       bfa_sm_set_state(rp, bfa_rport_sm_fwdelete);
+               else
+                       bfa_sm_set_state(rp, bfa_rport_sm_fwdelete_qfull);
+               break;
+
+       case BFA_RPORT_SM_DELETE:
+               bfa_stats(rp, sm_offp_del);
+               bfa_sm_set_state(rp, bfa_rport_sm_delete_pending);
+               break;
+
+       case BFA_RPORT_SM_HWFAIL:
+               bfa_stats(rp, sm_offp_hwf);
+               bfa_sm_set_state(rp, bfa_rport_sm_iocdisable);
+               break;
+
+       default:
+               bfa_stats(rp, sm_offp_unexp);
+               bfa_sm_fault(rp->bfa, event);
+       }
+}
+
+/**
+ * IOC h/w failed.
+ */
+static void
+bfa_rport_sm_iocdisable(struct bfa_rport_s *rp, enum bfa_rport_event event)
+{
+       bfa_trc(rp->bfa, rp->rport_tag);
+       bfa_trc(rp->bfa, event);
+
+       switch (event) {
+       case BFA_RPORT_SM_OFFLINE:
+               bfa_stats(rp, sm_iocd_off);
+               bfa_rport_offline_cb(rp);
+               break;
+
+       case BFA_RPORT_SM_DELETE:
+               bfa_stats(rp, sm_iocd_del);
+               bfa_sm_set_state(rp, bfa_rport_sm_uninit);
+               bfa_rport_free(rp);
+               break;
+
+       case BFA_RPORT_SM_ONLINE:
+               bfa_stats(rp, sm_iocd_on);
+               if (bfa_rport_send_fwcreate(rp))
+                       bfa_sm_set_state(rp, bfa_rport_sm_fwcreate);
+               else
+                       bfa_sm_set_state(rp, bfa_rport_sm_fwcreate_qfull);
+               break;
+
+       case BFA_RPORT_SM_HWFAIL:
+               break;
+
+       default:
+               bfa_stats(rp, sm_iocd_unexp);
+               bfa_sm_fault(rp->bfa, event);
+       }
+}
+
+
+
+/**
+ *  bfa_rport_private BFA rport private functions
+ */
+
+static void
+__bfa_cb_rport_online(void *cbarg, bfa_boolean_t complete)
+{
+       struct bfa_rport_s *rp = cbarg;
+
+       if (complete)
+               bfa_cb_rport_online(rp->rport_drv);
+}
+
+static void
+__bfa_cb_rport_offline(void *cbarg, bfa_boolean_t complete)
+{
+       struct bfa_rport_s *rp = cbarg;
+
+       if (complete)
+               bfa_cb_rport_offline(rp->rport_drv);
+}
+
+static void
+bfa_rport_qresume(void *cbarg)
+{
+       struct bfa_rport_s      *rp = cbarg;
+
+       bfa_sm_send_event(rp, BFA_RPORT_SM_QRESUME);
+}
+
+static void
+bfa_rport_meminfo(struct bfa_iocfc_cfg_s *cfg, u32 *km_len,
+               u32 *dm_len)
+{
+       if (cfg->fwcfg.num_rports < BFA_RPORT_MIN)
+               cfg->fwcfg.num_rports = BFA_RPORT_MIN;
+
+       *km_len += cfg->fwcfg.num_rports * sizeof(struct bfa_rport_s);
+}
+
+static void
+bfa_rport_attach(struct bfa_s *bfa, void *bfad, struct bfa_iocfc_cfg_s *cfg,
+                    struct bfa_meminfo_s *meminfo, struct bfa_pcidev_s *pcidev)
+{
+       struct bfa_rport_mod_s *mod = BFA_RPORT_MOD(bfa);
+       struct bfa_rport_s *rp;
+       u16 i;
+
+       INIT_LIST_HEAD(&mod->rp_free_q);
+       INIT_LIST_HEAD(&mod->rp_active_q);
+
+       rp = (struct bfa_rport_s *) bfa_meminfo_kva(meminfo);
+       mod->rps_list = rp;
+       mod->num_rports = cfg->fwcfg.num_rports;
+
+       bfa_assert(mod->num_rports &&
+                  !(mod->num_rports & (mod->num_rports - 1)));
+
+       for (i = 0; i < mod->num_rports; i++, rp++) {
+               bfa_os_memset(rp, 0, sizeof(struct bfa_rport_s));
+               rp->bfa = bfa;
+               rp->rport_tag = i;
+               bfa_sm_set_state(rp, bfa_rport_sm_uninit);
+
+               /**
+                *  - is unused
+                */
+               if (i)
+                       list_add_tail(&rp->qe, &mod->rp_free_q);
+
+               bfa_reqq_winit(&rp->reqq_wait, bfa_rport_qresume, rp);
+       }
+
+       /**
+        * consume memory
+        */
+       bfa_meminfo_kva(meminfo) = (u8 *) rp;
+}
+
+static void
+bfa_rport_detach(struct bfa_s *bfa)
+{
+}
+
+static void
+bfa_rport_start(struct bfa_s *bfa)
+{
+}
+
+static void
+bfa_rport_stop(struct bfa_s *bfa)
+{
+}
+
+static void
+bfa_rport_iocdisable(struct bfa_s *bfa)
+{
+       struct bfa_rport_mod_s *mod = BFA_RPORT_MOD(bfa);
+       struct bfa_rport_s *rport;
+       struct list_head *qe, *qen;
+
+       list_for_each_safe(qe, qen, &mod->rp_active_q) {
+               rport = (struct bfa_rport_s *) qe;
+               bfa_sm_send_event(rport, BFA_RPORT_SM_HWFAIL);
+       }
+}
+
+static struct bfa_rport_s *
+bfa_rport_alloc(struct bfa_rport_mod_s *mod)
+{
+       struct bfa_rport_s *rport;
+
+       bfa_q_deq(&mod->rp_free_q, &rport);
+       if (rport)
+               list_add_tail(&rport->qe, &mod->rp_active_q);
+
+       return rport;
+}
+
+static void
+bfa_rport_free(struct bfa_rport_s *rport)
+{
+       struct bfa_rport_mod_s *mod = BFA_RPORT_MOD(rport->bfa);
+
+       bfa_assert(bfa_q_is_on_q(&mod->rp_active_q, rport));
+       list_del(&rport->qe);
+       list_add_tail(&rport->qe, &mod->rp_free_q);
+}
+
+static bfa_boolean_t
+bfa_rport_send_fwcreate(struct bfa_rport_s *rp)
+{
+       struct bfi_rport_create_req_s *m;
+
+       /**
+        * check for room in queue to send request now
+        */
+       m = bfa_reqq_next(rp->bfa, BFA_REQQ_RPORT);
+       if (!m) {
+               bfa_reqq_wait(rp->bfa, BFA_REQQ_RPORT, &rp->reqq_wait);
+               return BFA_FALSE;
+       }
+
+       bfi_h2i_set(m->mh, BFI_MC_RPORT, BFI_RPORT_H2I_CREATE_REQ,
+                       bfa_lpuid(rp->bfa));
+       m->bfa_handle = rp->rport_tag;
+       m->max_frmsz = bfa_os_htons(rp->rport_info.max_frmsz);
+       m->pid = rp->rport_info.pid;
+       m->lp_tag = rp->rport_info.lp_tag;
+       m->local_pid = rp->rport_info.local_pid;
+       m->fc_class = rp->rport_info.fc_class;
+       m->vf_en = rp->rport_info.vf_en;
+       m->vf_id = rp->rport_info.vf_id;
+       m->cisc = rp->rport_info.cisc;
+
+       /**
+        * queue I/O message to firmware
+        */
+       bfa_reqq_produce(rp->bfa, BFA_REQQ_RPORT);
+       return BFA_TRUE;
+}
+
+static bfa_boolean_t
+bfa_rport_send_fwdelete(struct bfa_rport_s *rp)
+{
+       struct bfi_rport_delete_req_s *m;
+
+       /**
+        * check for room in queue to send request now
+        */
+       m = bfa_reqq_next(rp->bfa, BFA_REQQ_RPORT);
+       if (!m) {
+               bfa_reqq_wait(rp->bfa, BFA_REQQ_RPORT, &rp->reqq_wait);
+               return BFA_FALSE;
+       }
+
+       bfi_h2i_set(m->mh, BFI_MC_RPORT, BFI_RPORT_H2I_DELETE_REQ,
+                       bfa_lpuid(rp->bfa));
+       m->fw_handle = rp->fw_handle;
+
+       /**
+        * queue I/O message to firmware
+        */
+       bfa_reqq_produce(rp->bfa, BFA_REQQ_RPORT);
+       return BFA_TRUE;
+}
+
+static bfa_boolean_t
+bfa_rport_send_fwspeed(struct bfa_rport_s *rp)
+{
+       struct bfa_rport_speed_req_s *m;
+
+       /**
+        * check for room in queue to send request now
+        */
+       m = bfa_reqq_next(rp->bfa, BFA_REQQ_RPORT);
+       if (!m) {
+               bfa_trc(rp->bfa, rp->rport_info.speed);
+               return BFA_FALSE;
+       }
+
+       bfi_h2i_set(m->mh, BFI_MC_RPORT, BFI_RPORT_H2I_SET_SPEED_REQ,
+                       bfa_lpuid(rp->bfa));
+       m->fw_handle = rp->fw_handle;
+       m->speed = (u8)rp->rport_info.speed;
+
+       /**
+        * queue I/O message to firmware
+        */
+       bfa_reqq_produce(rp->bfa, BFA_REQQ_RPORT);
+       return BFA_TRUE;
+}
+
+
+
+/**
+ *  bfa_rport_public
+ */
+
+/**
+ * Rport interrupt processing.
+ */
+void
+bfa_rport_isr(struct bfa_s *bfa, struct bfi_msg_s *m)
+{
+       union bfi_rport_i2h_msg_u msg;
+       struct bfa_rport_s *rp;
+
+       bfa_trc(bfa, m->mhdr.msg_id);
+
+       msg.msg = m;
+
+       switch (m->mhdr.msg_id) {
+       case BFI_RPORT_I2H_CREATE_RSP:
+               rp = BFA_RPORT_FROM_TAG(bfa, msg.create_rsp->bfa_handle);
+               rp->fw_handle = msg.create_rsp->fw_handle;
+               rp->qos_attr = msg.create_rsp->qos_attr;
+               bfa_assert(msg.create_rsp->status == BFA_STATUS_OK);
+               bfa_sm_send_event(rp, BFA_RPORT_SM_FWRSP);
+               break;
+
+       case BFI_RPORT_I2H_DELETE_RSP:
+               rp = BFA_RPORT_FROM_TAG(bfa, msg.delete_rsp->bfa_handle);
+               bfa_assert(msg.delete_rsp->status == BFA_STATUS_OK);
+               bfa_sm_send_event(rp, BFA_RPORT_SM_FWRSP);
+               break;
+
+       case BFI_RPORT_I2H_QOS_SCN:
+               rp = BFA_RPORT_FROM_TAG(bfa, msg.qos_scn_evt->bfa_handle);
+               rp->event_arg.fw_msg = msg.qos_scn_evt;
+               bfa_sm_send_event(rp, BFA_RPORT_SM_QOS_SCN);
+               break;
+
+       default:
+               bfa_trc(bfa, m->mhdr.msg_id);
+               bfa_assert(0);
+       }
+}
+
+
+
+/**
+ *  bfa_rport_api
+ */
+
+struct bfa_rport_s *
+bfa_rport_create(struct bfa_s *bfa, void *rport_drv)
+{
+       struct bfa_rport_s *rp;
+
+       rp = bfa_rport_alloc(BFA_RPORT_MOD(bfa));
+
+       if (rp == NULL)
+               return NULL;
+
+       rp->bfa = bfa;
+       rp->rport_drv = rport_drv;
+       bfa_rport_clear_stats(rp);
+
+       bfa_assert(bfa_sm_cmp_state(rp, bfa_rport_sm_uninit));
+       bfa_sm_send_event(rp, BFA_RPORT_SM_CREATE);
+
+       return rp;
+}
+
+void
+bfa_rport_delete(struct bfa_rport_s *rport)
+{
+       bfa_sm_send_event(rport, BFA_RPORT_SM_DELETE);
+}
+
+void
+bfa_rport_online(struct bfa_rport_s *rport, struct bfa_rport_info_s *rport_info)
+{
+       bfa_assert(rport_info->max_frmsz != 0);
+
+       /**
+        * Some JBODs are seen to be not setting PDU size correctly in PLOGI
+        * responses. Default to minimum size.
+        */
+       if (rport_info->max_frmsz == 0) {
+               bfa_trc(rport->bfa, rport->rport_tag);
+               rport_info->max_frmsz = FC_MIN_PDUSZ;
+       }
+
+       bfa_os_assign(rport->rport_info, *rport_info);
+       bfa_sm_send_event(rport, BFA_RPORT_SM_ONLINE);
+}
+
+void
+bfa_rport_offline(struct bfa_rport_s *rport)
+{
+       bfa_sm_send_event(rport, BFA_RPORT_SM_OFFLINE);
+}
+
+void
+bfa_rport_speed(struct bfa_rport_s *rport, enum bfa_port_speed speed)
+{
+       bfa_assert(speed != 0);
+       bfa_assert(speed != BFA_PORT_SPEED_AUTO);
+
+       rport->rport_info.speed = speed;
+       bfa_sm_send_event(rport, BFA_RPORT_SM_SET_SPEED);
+}
+
+void
+bfa_rport_get_stats(struct bfa_rport_s *rport,
+       struct bfa_rport_hal_stats_s *stats)
+{
+       *stats = rport->stats;
+}
+
+void
+bfa_rport_get_qos_attr(struct bfa_rport_s *rport,
+                                       struct bfa_rport_qos_attr_s *qos_attr)
+{
+       qos_attr->qos_priority  = rport->qos_attr.qos_priority;
+       qos_attr->qos_flow_id  = bfa_os_ntohl(rport->qos_attr.qos_flow_id);
+
+}
+
+void
+bfa_rport_clear_stats(struct bfa_rport_s *rport)
+{
+       bfa_os_memset(&rport->stats, 0, sizeof(rport->stats));
+}
+
+
+/**
+ * SGPG related functions
+ */
+
+/**
+ * Compute and return memory needed by FCP(im) module.
+ */
+static void
+bfa_sgpg_meminfo(struct bfa_iocfc_cfg_s *cfg, u32 *km_len,
+               u32 *dm_len)
+{
+       if (cfg->drvcfg.num_sgpgs < BFA_SGPG_MIN)
+               cfg->drvcfg.num_sgpgs = BFA_SGPG_MIN;
+
+       *km_len += (cfg->drvcfg.num_sgpgs + 1) * sizeof(struct bfa_sgpg_s);
+       *dm_len += (cfg->drvcfg.num_sgpgs + 1) * sizeof(struct bfi_sgpg_s);
+}
+
+
+static void
+bfa_sgpg_attach(struct bfa_s *bfa, void *bfad, struct bfa_iocfc_cfg_s *cfg,
+                   struct bfa_meminfo_s *minfo, struct bfa_pcidev_s *pcidev)
+{
+       struct bfa_sgpg_mod_s *mod = BFA_SGPG_MOD(bfa);
+       int i;
+       struct bfa_sgpg_s *hsgpg;
+       struct bfi_sgpg_s *sgpg;
+       u64 align_len;
+
+       union {
+               u64 pa;
+               union bfi_addr_u addr;
+       } sgpg_pa, sgpg_pa_tmp;
+
+       INIT_LIST_HEAD(&mod->sgpg_q);
+       INIT_LIST_HEAD(&mod->sgpg_wait_q);
+
+       bfa_trc(bfa, cfg->drvcfg.num_sgpgs);
+
+       mod->num_sgpgs = cfg->drvcfg.num_sgpgs;
+       mod->sgpg_arr_pa = bfa_meminfo_dma_phys(minfo);
+       align_len = (BFA_SGPG_ROUNDUP(mod->sgpg_arr_pa) - mod->sgpg_arr_pa);
+       mod->sgpg_arr_pa += align_len;
+       mod->hsgpg_arr = (struct bfa_sgpg_s *) (bfa_meminfo_kva(minfo) +
+                                               align_len);
+       mod->sgpg_arr = (struct bfi_sgpg_s *) (bfa_meminfo_dma_virt(minfo) +
+                                               align_len);
+
+       hsgpg = mod->hsgpg_arr;
+       sgpg = mod->sgpg_arr;
+       sgpg_pa.pa = mod->sgpg_arr_pa;
+       mod->free_sgpgs = mod->num_sgpgs;
+
+       bfa_assert(!(sgpg_pa.pa & (sizeof(struct bfi_sgpg_s) - 1)));
+
+       for (i = 0; i < mod->num_sgpgs; i++) {
+               bfa_os_memset(hsgpg, 0, sizeof(*hsgpg));
+               bfa_os_memset(sgpg, 0, sizeof(*sgpg));
+
+               hsgpg->sgpg = sgpg;
+               sgpg_pa_tmp.pa = bfa_sgaddr_le(sgpg_pa.pa);
+               hsgpg->sgpg_pa = sgpg_pa_tmp.addr;
+               list_add_tail(&hsgpg->qe, &mod->sgpg_q);
+
+               hsgpg++;
+               sgpg++;
+               sgpg_pa.pa += sizeof(struct bfi_sgpg_s);
+       }
+
+       bfa_meminfo_kva(minfo) = (u8 *) hsgpg;
+       bfa_meminfo_dma_virt(minfo) = (u8 *) sgpg;
+       bfa_meminfo_dma_phys(minfo) = sgpg_pa.pa;
+}
+
+static void
+bfa_sgpg_detach(struct bfa_s *bfa)
+{
+}
+
+static void
+bfa_sgpg_start(struct bfa_s *bfa)
+{
+}
+
+static void
+bfa_sgpg_stop(struct bfa_s *bfa)
+{
+}
+
+static void
+bfa_sgpg_iocdisable(struct bfa_s *bfa)
+{
+}
+
+
+
+/**
+ *  hal_sgpg_public BFA SGPG public functions
+ */
+
+bfa_status_t
+bfa_sgpg_malloc(struct bfa_s *bfa, struct list_head *sgpg_q, int nsgpgs)
+{
+       struct bfa_sgpg_mod_s *mod = BFA_SGPG_MOD(bfa);
+       struct bfa_sgpg_s *hsgpg;
+       int i;
+
+       bfa_trc_fp(bfa, nsgpgs);
+
+       if (mod->free_sgpgs < nsgpgs)
+               return BFA_STATUS_ENOMEM;
+
+       for (i = 0; i < nsgpgs; i++) {
+               bfa_q_deq(&mod->sgpg_q, &hsgpg);
+               bfa_assert(hsgpg);
+               list_add_tail(&hsgpg->qe, sgpg_q);
+       }
+
+       mod->free_sgpgs -= nsgpgs;
+       return BFA_STATUS_OK;
+}
+
+void
+bfa_sgpg_mfree(struct bfa_s *bfa, struct list_head *sgpg_q, int nsgpg)
+{
+       struct bfa_sgpg_mod_s *mod = BFA_SGPG_MOD(bfa);
+       struct bfa_sgpg_wqe_s *wqe;
+
+       bfa_trc_fp(bfa, nsgpg);
+
+       mod->free_sgpgs += nsgpg;
+       bfa_assert(mod->free_sgpgs <= mod->num_sgpgs);
+
+       list_splice_tail_init(sgpg_q, &mod->sgpg_q);
+
+       if (list_empty(&mod->sgpg_wait_q))
+               return;
+
+       /**
+        * satisfy as many waiting requests as possible
+        */
+       do {
+               wqe = bfa_q_first(&mod->sgpg_wait_q);
+               if (mod->free_sgpgs < wqe->nsgpg)
+                       nsgpg = mod->free_sgpgs;
+               else
+                       nsgpg = wqe->nsgpg;
+               bfa_sgpg_malloc(bfa, &wqe->sgpg_q, nsgpg);
+               wqe->nsgpg -= nsgpg;
+               if (wqe->nsgpg == 0) {
+                       list_del(&wqe->qe);
+                       wqe->cbfn(wqe->cbarg);
+               }
+       } while (mod->free_sgpgs && !list_empty(&mod->sgpg_wait_q));
+}
+
+void
+bfa_sgpg_wait(struct bfa_s *bfa, struct bfa_sgpg_wqe_s *wqe, int nsgpg)
+{
+       struct bfa_sgpg_mod_s *mod = BFA_SGPG_MOD(bfa);
+
+       bfa_assert(nsgpg > 0);
+       bfa_assert(nsgpg > mod->free_sgpgs);
+
+       wqe->nsgpg_total = wqe->nsgpg = nsgpg;
+
+       /**
+        * allocate any left to this one first
+        */
+       if (mod->free_sgpgs) {
+               /**
+                * no one else is waiting for SGPG
+                */
+               bfa_assert(list_empty(&mod->sgpg_wait_q));
+               list_splice_tail_init(&mod->sgpg_q, &wqe->sgpg_q);
+               wqe->nsgpg -= mod->free_sgpgs;
+               mod->free_sgpgs = 0;
+       }
+
+       list_add_tail(&wqe->qe, &mod->sgpg_wait_q);
+}
+
+void
+bfa_sgpg_wcancel(struct bfa_s *bfa, struct bfa_sgpg_wqe_s *wqe)
+{
+       struct bfa_sgpg_mod_s *mod = BFA_SGPG_MOD(bfa);
+
+       bfa_assert(bfa_q_is_on_q(&mod->sgpg_wait_q, wqe));
+       list_del(&wqe->qe);
+
+       if (wqe->nsgpg_total != wqe->nsgpg)
+               bfa_sgpg_mfree(bfa, &wqe->sgpg_q,
+                                  wqe->nsgpg_total - wqe->nsgpg);
+}
+
+void
+bfa_sgpg_winit(struct bfa_sgpg_wqe_s *wqe, void (*cbfn) (void *cbarg),
+                  void *cbarg)
+{
+       INIT_LIST_HEAD(&wqe->sgpg_q);
+       wqe->cbfn = cbfn;
+       wqe->cbarg = cbarg;
+}
+
+/**
+ *  UF related functions
+ */
+/*
+ *****************************************************************************
+ * Internal functions
+ *****************************************************************************
+ */
+static void
+__bfa_cb_uf_recv(void *cbarg, bfa_boolean_t complete)
+{
+       struct bfa_uf_s   *uf = cbarg;
+       struct bfa_uf_mod_s *ufm = BFA_UF_MOD(uf->bfa);
+
+       if (complete)
+               ufm->ufrecv(ufm->cbarg, uf);
+}
+
+static void
+claim_uf_pbs(struct bfa_uf_mod_s *ufm, struct bfa_meminfo_s *mi)
+{
+       u32 uf_pb_tot_sz;
+
+       ufm->uf_pbs_kva = (struct bfa_uf_buf_s *) bfa_meminfo_dma_virt(mi);
+       ufm->uf_pbs_pa = bfa_meminfo_dma_phys(mi);
+       uf_pb_tot_sz = BFA_ROUNDUP((sizeof(struct bfa_uf_buf_s) * ufm->num_ufs),
+                                                       BFA_DMA_ALIGN_SZ);
+
+       bfa_meminfo_dma_virt(mi) += uf_pb_tot_sz;
+       bfa_meminfo_dma_phys(mi) += uf_pb_tot_sz;
+
+       bfa_os_memset((void *)ufm->uf_pbs_kva, 0, uf_pb_tot_sz);
+}
+
+static void
+claim_uf_post_msgs(struct bfa_uf_mod_s *ufm, struct bfa_meminfo_s *mi)
+{
+       struct bfi_uf_buf_post_s *uf_bp_msg;
+       struct bfi_sge_s      *sge;
+       union bfi_addr_u      sga_zero = { {0} };
+       u16 i;
+       u16 buf_len;
+
+       ufm->uf_buf_posts = (struct bfi_uf_buf_post_s *) bfa_meminfo_kva(mi);
+       uf_bp_msg = ufm->uf_buf_posts;
+
+       for (i = 0, uf_bp_msg = ufm->uf_buf_posts; i < ufm->num_ufs;
+            i++, uf_bp_msg++) {
+               bfa_os_memset(uf_bp_msg, 0, sizeof(struct bfi_uf_buf_post_s));
+
+               uf_bp_msg->buf_tag = i;
+               buf_len = sizeof(struct bfa_uf_buf_s);
+               uf_bp_msg->buf_len = bfa_os_htons(buf_len);
+               bfi_h2i_set(uf_bp_msg->mh, BFI_MC_UF, BFI_UF_H2I_BUF_POST,
+                           bfa_lpuid(ufm->bfa));
+
+               sge = uf_bp_msg->sge;
+               sge[0].sg_len = buf_len;
+               sge[0].flags = BFI_SGE_DATA_LAST;
+               bfa_dma_addr_set(sge[0].sga, ufm_pbs_pa(ufm, i));
+               bfa_sge_to_be(sge);
+
+               sge[1].sg_len = buf_len;
+               sge[1].flags = BFI_SGE_PGDLEN;
+               sge[1].sga = sga_zero;
+               bfa_sge_to_be(&sge[1]);
+       }
+
+       /**
+        * advance pointer beyond consumed memory
+        */
+       bfa_meminfo_kva(mi) = (u8 *) uf_bp_msg;
+}
+
+static void
+claim_ufs(struct bfa_uf_mod_s *ufm, struct bfa_meminfo_s *mi)
+{
+       u16 i;
+       struct bfa_uf_s   *uf;
+
+       /*
+        * Claim block of memory for UF list
+        */
+       ufm->uf_list = (struct bfa_uf_s *) bfa_meminfo_kva(mi);
+
+       /*
+        * Initialize UFs and queue it in UF free queue
+        */
+       for (i = 0, uf = ufm->uf_list; i < ufm->num_ufs; i++, uf++) {
+               bfa_os_memset(uf, 0, sizeof(struct bfa_uf_s));
+               uf->bfa = ufm->bfa;
+               uf->uf_tag = i;
+               uf->pb_len = sizeof(struct bfa_uf_buf_s);
+               uf->buf_kva = (void *)&ufm->uf_pbs_kva[i];
+               uf->buf_pa = ufm_pbs_pa(ufm, i);
+               list_add_tail(&uf->qe, &ufm->uf_free_q);
+       }
+
+       /**
+        * advance memory pointer
+        */
+       bfa_meminfo_kva(mi) = (u8 *) uf;
+}
+
+static void
+uf_mem_claim(struct bfa_uf_mod_s *ufm, struct bfa_meminfo_s *mi)
+{
+       claim_uf_pbs(ufm, mi);
+       claim_ufs(ufm, mi);
+       claim_uf_post_msgs(ufm, mi);
+}
+
+static void
+bfa_uf_meminfo(struct bfa_iocfc_cfg_s *cfg, u32 *ndm_len, u32 *dm_len)
+{
+       u32 num_ufs = cfg->fwcfg.num_uf_bufs;
+
+       /*
+        * dma-able memory for UF posted bufs
+        */
+       *dm_len += BFA_ROUNDUP((sizeof(struct bfa_uf_buf_s) * num_ufs),
+                                                       BFA_DMA_ALIGN_SZ);
+
+       /*
+        * kernel Virtual memory for UFs and UF buf post msg copies
+        */
+       *ndm_len += sizeof(struct bfa_uf_s) * num_ufs;
+       *ndm_len += sizeof(struct bfi_uf_buf_post_s) * num_ufs;
+}
+
+static void
+bfa_uf_attach(struct bfa_s *bfa, void *bfad, struct bfa_iocfc_cfg_s *cfg,
+                 struct bfa_meminfo_s *meminfo, struct bfa_pcidev_s *pcidev)
+{
+       struct bfa_uf_mod_s *ufm = BFA_UF_MOD(bfa);
+
+       bfa_os_memset(ufm, 0, sizeof(struct bfa_uf_mod_s));
+       ufm->bfa = bfa;
+       ufm->num_ufs = cfg->fwcfg.num_uf_bufs;
+       INIT_LIST_HEAD(&ufm->uf_free_q);
+       INIT_LIST_HEAD(&ufm->uf_posted_q);
+
+       uf_mem_claim(ufm, meminfo);
+}
+
+static void
+bfa_uf_detach(struct bfa_s *bfa)
+{
+}
+
+static struct bfa_uf_s *
+bfa_uf_get(struct bfa_uf_mod_s *uf_mod)
+{
+       struct bfa_uf_s   *uf;
+
+       bfa_q_deq(&uf_mod->uf_free_q, &uf);
+       return uf;
+}
+
+static void
+bfa_uf_put(struct bfa_uf_mod_s *uf_mod, struct bfa_uf_s *uf)
+{
+       list_add_tail(&uf->qe, &uf_mod->uf_free_q);
+}
+
+static bfa_status_t
+bfa_uf_post(struct bfa_uf_mod_s *ufm, struct bfa_uf_s *uf)
+{
+       struct bfi_uf_buf_post_s *uf_post_msg;
+
+       uf_post_msg = bfa_reqq_next(ufm->bfa, BFA_REQQ_FCXP);
+       if (!uf_post_msg)
+               return BFA_STATUS_FAILED;
+
+       bfa_os_memcpy(uf_post_msg, &ufm->uf_buf_posts[uf->uf_tag],
+                     sizeof(struct bfi_uf_buf_post_s));
+       bfa_reqq_produce(ufm->bfa, BFA_REQQ_FCXP);
+
+       bfa_trc(ufm->bfa, uf->uf_tag);
+
+       list_add_tail(&uf->qe, &ufm->uf_posted_q);
+       return BFA_STATUS_OK;
+}
+
+static void
+bfa_uf_post_all(struct bfa_uf_mod_s *uf_mod)
+{
+       struct bfa_uf_s   *uf;
+
+       while ((uf = bfa_uf_get(uf_mod)) != NULL) {
+               if (bfa_uf_post(uf_mod, uf) != BFA_STATUS_OK)
+                       break;
+       }
+}
+
+static void
+uf_recv(struct bfa_s *bfa, struct bfi_uf_frm_rcvd_s *m)
+{
+       struct bfa_uf_mod_s *ufm = BFA_UF_MOD(bfa);
+       u16 uf_tag = m->buf_tag;
+       struct bfa_uf_buf_s *uf_buf = &ufm->uf_pbs_kva[uf_tag];
+       struct bfa_uf_s *uf = &ufm->uf_list[uf_tag];
+       u8 *buf = &uf_buf->d[0];
+       struct fchs_s *fchs;
+
+       m->frm_len = bfa_os_ntohs(m->frm_len);
+       m->xfr_len = bfa_os_ntohs(m->xfr_len);
+
+       fchs = (struct fchs_s *)uf_buf;
+
+       list_del(&uf->qe);      /* dequeue from posted queue */
+
+       uf->data_ptr = buf;
+       uf->data_len = m->xfr_len;
+
+       bfa_assert(uf->data_len >= sizeof(struct fchs_s));
+
+       if (uf->data_len == sizeof(struct fchs_s)) {
+               bfa_plog_fchdr(bfa->plog, BFA_PL_MID_HAL_UF, BFA_PL_EID_RX,
+                              uf->data_len, (struct fchs_s *)buf);
+       } else {
+               u32 pld_w0 = *((u32 *) (buf + sizeof(struct fchs_s)));
+               bfa_plog_fchdr_and_pl(bfa->plog, BFA_PL_MID_HAL_UF,
+                                     BFA_PL_EID_RX, uf->data_len,
+                                     (struct fchs_s *)buf, pld_w0);
+       }
+
+       if (bfa->fcs)
+               __bfa_cb_uf_recv(uf, BFA_TRUE);
+       else
+               bfa_cb_queue(bfa, &uf->hcb_qe, __bfa_cb_uf_recv, uf);
+}
+
+static void
+bfa_uf_stop(struct bfa_s *bfa)
+{
+}
+
+static void
+bfa_uf_iocdisable(struct bfa_s *bfa)
+{
+       struct bfa_uf_mod_s *ufm = BFA_UF_MOD(bfa);
+       struct bfa_uf_s *uf;
+       struct list_head *qe, *qen;
+
+       list_for_each_safe(qe, qen, &ufm->uf_posted_q) {
+               uf = (struct bfa_uf_s *) qe;
+               list_del(&uf->qe);
+               bfa_uf_put(ufm, uf);
+       }
+}
+
+static void
+bfa_uf_start(struct bfa_s *bfa)
+{
+       bfa_uf_post_all(BFA_UF_MOD(bfa));
+}
+
+
+
+/**
+ *  hal_uf_api
+ */
+
+/**
+ * Register handler for all unsolicted recieve frames.
+ *
+ * @param[in]  bfa             BFA instance
+ * @param[in]  ufrecv  receive handler function
+ * @param[in]  cbarg   receive handler arg
+ */
+void
+bfa_uf_recv_register(struct bfa_s *bfa, bfa_cb_uf_recv_t ufrecv, void *cbarg)
+{
+       struct bfa_uf_mod_s *ufm = BFA_UF_MOD(bfa);
+
+       ufm->ufrecv = ufrecv;
+       ufm->cbarg = cbarg;
+}
+
+/**
+ *     Free an unsolicited frame back to BFA.
+ *
+ * @param[in]          uf              unsolicited frame to be freed
+ *
+ * @return None
+ */
+void
+bfa_uf_free(struct bfa_uf_s *uf)
+{
+       bfa_uf_put(BFA_UF_MOD(uf->bfa), uf);
+       bfa_uf_post_all(BFA_UF_MOD(uf->bfa));
+}
+
+
+
+/**
+ *  uf_pub BFA uf module public functions
+ */
+void
+bfa_uf_isr(struct bfa_s *bfa, struct bfi_msg_s *msg)
+{
+       bfa_trc(bfa, msg->mhdr.msg_id);
+
+       switch (msg->mhdr.msg_id) {
+       case BFI_UF_I2H_FRM_RCVD:
+               uf_recv(bfa, (struct bfi_uf_frm_rcvd_s *) msg);
+               break;
+
+       default:
+               bfa_trc(bfa, msg->mhdr.msg_id);
+               bfa_assert(0);
+       }
+}
+
+
diff --git a/drivers/scsi/bfa/bfa_svc.h b/drivers/scsi/bfa/bfa_svc.h
new file mode 100644 (file)
index 0000000..9921dad
--- /dev/null
@@ -0,0 +1,657 @@
+/*
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
+ * All rights reserved
+ * www.brocade.com
+ *
+ * Linux driver for Brocade Fibre Channel Host Bus Adapter.
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License (GPL) Version 2 as
+ * published by the Free Software Foundation
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * General Public License for more details.
+ */
+
+#ifndef __BFA_SVC_H__
+#define __BFA_SVC_H__
+
+#include "bfa_cs.h"
+#include "bfi_ms.h"
+
+
+/**
+ * Scatter-gather DMA related defines
+ */
+#define BFA_SGPG_MIN   (16)
+
+/**
+ * Alignment macro for SG page allocation
+ */
+#define BFA_SGPG_ROUNDUP(_l) (((_l) + (sizeof(struct bfi_sgpg_s) - 1)) \
+                             & ~(sizeof(struct bfi_sgpg_s) - 1))
+
+struct bfa_sgpg_wqe_s {
+       struct list_head qe;    /*  queue sg page element       */
+       int     nsgpg;          /*  pages to be allocated       */
+       int     nsgpg_total;    /*  total pages required        */
+       void    (*cbfn) (void *cbarg);  /*  callback function   */
+       void    *cbarg;         /*  callback arg                */
+       struct list_head sgpg_q;        /*  queue of alloced sgpgs      */
+};
+
+struct bfa_sgpg_s {
+       struct list_head  qe;   /*  queue sg page element       */
+       struct bfi_sgpg_s *sgpg;        /*  va of SG page               */
+       union bfi_addr_u sgpg_pa;       /*  pa of SG page               */
+};
+
+/**
+ * Given number of SG elements, BFA_SGPG_NPAGE() returns the number of
+ * SG pages required.
+ */
+#define BFA_SGPG_NPAGE(_nsges)  (((_nsges) / BFI_SGPG_DATA_SGES) + 1)
+
+struct bfa_sgpg_mod_s {
+       struct bfa_s *bfa;
+       int             num_sgpgs;      /*  number of SG pages          */
+       int             free_sgpgs;     /*  number of free SG pages     */
+       struct bfa_sgpg_s       *hsgpg_arr;     /*  BFA SG page array   */
+       struct bfi_sgpg_s *sgpg_arr;    /*  actual SG page array        */
+       u64     sgpg_arr_pa;    /*  SG page array DMA addr      */
+       struct list_head        sgpg_q;         /*  queue of free SG pages */
+       struct list_head        sgpg_wait_q;    /*  wait queue for SG pages */
+};
+#define BFA_SGPG_MOD(__bfa)    (&(__bfa)->modules.sgpg_mod)
+
+bfa_status_t bfa_sgpg_malloc(struct bfa_s *bfa, struct list_head *sgpg_q,
+                            int nsgpgs);
+void bfa_sgpg_mfree(struct bfa_s *bfa, struct list_head *sgpg_q, int nsgpgs);
+void bfa_sgpg_winit(struct bfa_sgpg_wqe_s *wqe,
+                   void (*cbfn) (void *cbarg), void *cbarg);
+void bfa_sgpg_wait(struct bfa_s *bfa, struct bfa_sgpg_wqe_s *wqe, int nsgpgs);
+void bfa_sgpg_wcancel(struct bfa_s *bfa, struct bfa_sgpg_wqe_s *wqe);
+
+
+/**
+ * FCXP related defines
+ */
+#define BFA_FCXP_MIN           (1)
+#define BFA_FCXP_MAX_IBUF_SZ   (2 * 1024 + 256)
+#define BFA_FCXP_MAX_LBUF_SZ   (4 * 1024 + 256)
+
+struct bfa_fcxp_mod_s {
+       struct bfa_s      *bfa;         /* backpointer to BFA */
+       struct bfa_fcxp_s *fcxp_list;   /* array of FCXPs */
+       u16     num_fcxps;      /* max num FCXP requests */
+       struct list_head  fcxp_free_q;  /* free FCXPs */
+       struct list_head  fcxp_active_q;        /* active FCXPs */
+       void            *req_pld_list_kva;      /* list of FCXP req pld */
+       u64     req_pld_list_pa;        /* list of FCXP req pld */
+       void            *rsp_pld_list_kva;      /* list of FCXP resp pld */
+       u64     rsp_pld_list_pa;        /* list of FCXP resp pld */
+       struct list_head  wait_q;               /* wait queue for free fcxp */
+       u32     req_pld_sz;
+       u32     rsp_pld_sz;
+};
+
+#define BFA_FCXP_MOD(__bfa)            (&(__bfa)->modules.fcxp_mod)
+#define BFA_FCXP_FROM_TAG(__mod, __tag)        (&(__mod)->fcxp_list[__tag])
+
+typedef void    (*fcxp_send_cb_t) (struct bfa_s *ioc, struct bfa_fcxp_s *fcxp,
+                                  void *cb_arg, bfa_status_t req_status,
+                                  u32 rsp_len, u32 resid_len,
+                                  struct fchs_s *rsp_fchs);
+
+typedef u64 (*bfa_fcxp_get_sgaddr_t) (void *bfad_fcxp, int sgeid);
+typedef u32 (*bfa_fcxp_get_sglen_t) (void *bfad_fcxp, int sgeid);
+typedef void (*bfa_cb_fcxp_send_t) (void *bfad_fcxp, struct bfa_fcxp_s *fcxp,
+                                   void *cbarg, enum bfa_status req_status,
+                                   u32 rsp_len, u32 resid_len,
+                                   struct fchs_s *rsp_fchs);
+typedef void (*bfa_fcxp_alloc_cbfn_t) (void *cbarg, struct bfa_fcxp_s *fcxp);
+
+
+
+/**
+ * Information needed for a FCXP request
+ */
+struct bfa_fcxp_req_info_s {
+       struct bfa_rport_s *bfa_rport;
+                                       /** Pointer to the bfa rport that was
+                                        * returned from bfa_rport_create().
+                                        * This could be left NULL for WKA or
+                                        * for FCXP interactions before the
+                                        * rport nexus is established
+                                        */
+       struct fchs_s   fchs;   /*  request FC header structure */
+       u8              cts;    /*  continous sequence */
+       u8              class;  /*  FC class for the request/response */
+       u16     max_frmsz;      /*  max send frame size */
+       u16     vf_id;  /*  vsan tag if applicable */
+       u8              lp_tag; /*  lport tag */
+       u32     req_tot_len;    /*  request payload total length */
+};
+
+struct bfa_fcxp_rsp_info_s {
+       struct fchs_s   rsp_fchs;
+                               /** !< Response frame's FC header will
+                                * be sent back in this field */
+       u8              rsp_timeout;
+                               /** !< timeout in seconds, 0-no response
+                                */
+       u8              rsvd2[3];
+       u32     rsp_maxlen;     /*  max response length expected */
+};
+
+struct bfa_fcxp_s {
+       struct list_head        qe;             /*  fcxp queue element */
+       bfa_sm_t        sm;             /*  state machine */
+       void            *caller;        /*  driver or fcs */
+       struct bfa_fcxp_mod_s *fcxp_mod;
+       /*  back pointer to fcxp mod */
+       u16     fcxp_tag;       /*  internal tag */
+       struct bfa_fcxp_req_info_s req_info;
+       /*  request info */
+       struct bfa_fcxp_rsp_info_s rsp_info;
+       /*  response info */
+       u8      use_ireqbuf;    /*  use internal req buf */
+       u8              use_irspbuf;    /*  use internal rsp buf */
+       u32     nreq_sgles;     /*  num request SGLEs */
+       u32     nrsp_sgles;     /*  num response SGLEs */
+       struct list_head req_sgpg_q;    /*  SG pages for request buf */
+       struct list_head req_sgpg_wqe;  /*  wait queue for req SG page */
+       struct list_head rsp_sgpg_q;    /*  SG pages for response buf */
+       struct list_head rsp_sgpg_wqe;  /*  wait queue for rsp SG page */
+
+       bfa_fcxp_get_sgaddr_t req_sga_cbfn;
+       /*  SG elem addr user function */
+       bfa_fcxp_get_sglen_t req_sglen_cbfn;
+       /*  SG elem len user function */
+       bfa_fcxp_get_sgaddr_t rsp_sga_cbfn;
+       /*  SG elem addr user function */
+       bfa_fcxp_get_sglen_t rsp_sglen_cbfn;
+       /*  SG elem len user function */
+       bfa_cb_fcxp_send_t send_cbfn;   /*  send completion callback */
+       void            *send_cbarg;    /*  callback arg */
+       struct bfa_sge_s   req_sge[BFA_FCXP_MAX_SGES];
+       /*  req SG elems */
+       struct bfa_sge_s   rsp_sge[BFA_FCXP_MAX_SGES];
+       /*  rsp SG elems */
+       u8              rsp_status;     /*  comp: rsp status */
+       u32     rsp_len;        /*  comp: actual response len */
+       u32     residue_len;    /*  comp: residual rsp length */
+       struct fchs_s   rsp_fchs;       /*  comp: response fchs */
+       struct bfa_cb_qe_s    hcb_qe;   /*  comp: callback qelem */
+       struct bfa_reqq_wait_s  reqq_wqe;
+       bfa_boolean_t   reqq_waiting;
+};
+
+struct bfa_fcxp_wqe_s {
+       struct list_head                qe;
+       bfa_fcxp_alloc_cbfn_t   alloc_cbfn;
+       void            *alloc_cbarg;
+       void            *caller;
+       struct bfa_s    *bfa;
+       int             nreq_sgles;
+       int             nrsp_sgles;
+       bfa_fcxp_get_sgaddr_t   req_sga_cbfn;
+       bfa_fcxp_get_sglen_t    req_sglen_cbfn;
+       bfa_fcxp_get_sgaddr_t   rsp_sga_cbfn;
+       bfa_fcxp_get_sglen_t    rsp_sglen_cbfn;
+};
+
+#define BFA_FCXP_REQ_PLD(_fcxp)                (bfa_fcxp_get_reqbuf(_fcxp))
+#define BFA_FCXP_RSP_FCHS(_fcxp)       (&((_fcxp)->rsp_info.fchs))
+#define BFA_FCXP_RSP_PLD(_fcxp)                (bfa_fcxp_get_rspbuf(_fcxp))
+
+#define BFA_FCXP_REQ_PLD_PA(_fcxp)                             \
+       ((_fcxp)->fcxp_mod->req_pld_list_pa +                   \
+        ((_fcxp)->fcxp_mod->req_pld_sz  * (_fcxp)->fcxp_tag))
+
+#define BFA_FCXP_RSP_PLD_PA(_fcxp)                             \
+       ((_fcxp)->fcxp_mod->rsp_pld_list_pa +                   \
+        ((_fcxp)->fcxp_mod->rsp_pld_sz * (_fcxp)->fcxp_tag))
+
+void   bfa_fcxp_isr(struct bfa_s *bfa, struct bfi_msg_s *msg);
+
+
+/**
+ * RPORT related defines
+ */
+#define BFA_RPORT_MIN  4
+
+struct bfa_rport_mod_s {
+       struct bfa_rport_s *rps_list;   /*  list of rports      */
+       struct list_head        rp_free_q;      /*  free bfa_rports     */
+       struct list_head        rp_active_q;    /*  free bfa_rports     */
+       u16     num_rports;     /*  number of rports    */
+};
+
+#define BFA_RPORT_MOD(__bfa)   (&(__bfa)->modules.rport_mod)
+
+/**
+ * Convert rport tag to RPORT
+ */
+#define BFA_RPORT_FROM_TAG(__bfa, _tag)                                \
+       (BFA_RPORT_MOD(__bfa)->rps_list +                       \
+        ((_tag) & (BFA_RPORT_MOD(__bfa)->num_rports - 1)))
+
+/*
+ * protected functions
+ */
+void   bfa_rport_isr(struct bfa_s *bfa, struct bfi_msg_s *msg);
+
+/**
+ *     BFA rport information.
+ */
+struct bfa_rport_info_s {
+       u16     max_frmsz;      /*  max rcv pdu size                */
+       u32     pid:24, /*  remote port ID                  */
+               lp_tag:8;       /*  tag                     */
+       u32     local_pid:24,   /*  local port ID                   */
+               cisc:8; /*  CIRO supported                  */
+       u8      fc_class;       /*  supported FC classes. enum fc_cos */
+       u8      vf_en;          /*  virtual fabric enable           */
+       u16     vf_id;          /*  virtual fabric ID               */
+       enum bfa_port_speed speed;      /*  Rport's current speed           */
+};
+
+/**
+ * BFA rport data structure
+ */
+struct bfa_rport_s {
+       struct list_head        qe;     /*  queue element                   */
+       bfa_sm_t        sm;             /*  state machine                   */
+       struct bfa_s    *bfa;           /*  backpointer to BFA              */
+       void            *rport_drv;     /*  fcs/driver rport object         */
+       u16     fw_handle;      /*  firmware rport handle           */
+       u16     rport_tag;      /*  BFA rport tag                   */
+       struct bfa_rport_info_s rport_info; /*  rport info from fcs/driver */
+       struct bfa_reqq_wait_s reqq_wait; /*  to wait for room in reqq     */
+       struct bfa_cb_qe_s hcb_qe;      /*  BFA callback qelem              */
+       struct bfa_rport_hal_stats_s stats; /*  BFA rport statistics        */
+       struct bfa_rport_qos_attr_s qos_attr;
+       union a {
+               bfa_status_t    status; /*  f/w status */
+               void            *fw_msg; /*  QoS scn event                  */
+       } event_arg;
+};
+#define BFA_RPORT_FC_COS(_rport)       ((_rport)->rport_info.fc_class)
+
+
+/**
+ * UF - unsolicited receive related defines
+ */
+
+#define BFA_UF_MIN     (4)
+
+
+struct bfa_uf_s {
+       struct list_head        qe;     /*  queue element               */
+       struct bfa_s            *bfa;   /*  bfa instance                */
+       u16     uf_tag;         /*  identifying tag fw msgs     */
+       u16     vf_id;
+       u16     src_rport_handle;
+       u16     rsvd;
+       u8              *data_ptr;
+       u16     data_len;       /*  actual receive length       */
+       u16     pb_len;         /*  posted buffer length        */
+       void            *buf_kva;       /*  buffer virtual address      */
+       u64     buf_pa;         /*  buffer physical address     */
+       struct bfa_cb_qe_s hcb_qe;      /*  comp: BFA comp qelem        */
+       struct bfa_sge_s sges[BFI_SGE_INLINE_MAX];
+};
+
+/**
+ *      Callback prototype for unsolicited frame receive handler.
+ *
+ * @param[in]           cbarg           callback arg for receive handler
+ * @param[in]           uf              unsolicited frame descriptor
+ *
+ * @return None
+ */
+typedef void (*bfa_cb_uf_recv_t) (void *cbarg, struct bfa_uf_s *uf);
+
+struct bfa_uf_mod_s {
+       struct bfa_s *bfa;              /*  back pointer to BFA */
+       struct bfa_uf_s *uf_list;       /*  array of UFs */
+       u16     num_ufs;        /*  num unsolicited rx frames */
+       struct list_head        uf_free_q;      /*  free UFs */
+       struct list_head        uf_posted_q;    /*  UFs posted to IOC */
+       struct bfa_uf_buf_s *uf_pbs_kva;        /*  list UF bufs request pld */
+       u64     uf_pbs_pa;      /*  phy addr for UF bufs */
+       struct bfi_uf_buf_post_s *uf_buf_posts;
+       /*  pre-built UF post msgs */
+       bfa_cb_uf_recv_t ufrecv;        /*  uf recv handler function */
+       void            *cbarg;         /*  uf receive handler arg */
+};
+
+#define BFA_UF_MOD(__bfa)      (&(__bfa)->modules.uf_mod)
+
+#define ufm_pbs_pa(_ufmod, _uftag)                                     \
+       ((_ufmod)->uf_pbs_pa + sizeof(struct bfa_uf_buf_s) * (_uftag))
+
+void   bfa_uf_isr(struct bfa_s *bfa, struct bfi_msg_s *msg);
+
+#define BFA_UF_BUFSZ   (2 * 1024 + 256)
+
+/**
+ * @todo private
+ */
+struct bfa_uf_buf_s {
+       u8              d[BFA_UF_BUFSZ];
+};
+
+
+/**
+ * LPS - bfa lport login/logout service interface
+ */
+struct bfa_lps_s {
+       struct list_head        qe;     /*  queue element               */
+       struct bfa_s    *bfa;           /*  parent bfa instance */
+       bfa_sm_t        sm;             /*  finite state machine        */
+       u8              lp_tag;         /*  lport tag                   */
+       u8              reqq;           /*  lport request queue */
+       u8              alpa;           /*  ALPA for loop topologies    */
+       u32     lp_pid;         /*  lport port ID               */
+       bfa_boolean_t   fdisc;          /*  snd FDISC instead of FLOGI  */
+       bfa_boolean_t   auth_en;        /*  enable authentication       */
+       bfa_boolean_t   auth_req;       /*  authentication required     */
+       bfa_boolean_t   npiv_en;        /*  NPIV is allowed by peer     */
+       bfa_boolean_t   fport;          /*  attached peer is F_PORT     */
+       bfa_boolean_t   brcd_switch;    /*  attached peer is brcd sw    */
+       bfa_status_t    status;         /*  login status                */
+       u16             pdusz;          /*  max receive PDU size        */
+       u16             pr_bbcred;      /*  BB_CREDIT from peer         */
+       u8              lsrjt_rsn;      /*  LSRJT reason                */
+       u8              lsrjt_expl;     /*  LSRJT explanation           */
+       wwn_t           pwwn;           /*  port wwn of lport           */
+       wwn_t           nwwn;           /*  node wwn of lport           */
+       wwn_t           pr_pwwn;        /*  port wwn of lport peer      */
+       wwn_t           pr_nwwn;        /*  node wwn of lport peer      */
+       mac_t           lp_mac;         /*  fpma/spma MAC for lport     */
+       mac_t           fcf_mac;        /*  FCF MAC of lport            */
+       struct bfa_reqq_wait_s  wqe;    /*  request wait queue element  */
+       void            *uarg;          /*  user callback arg           */
+       struct bfa_cb_qe_s hcb_qe;      /*  comp: callback qelem        */
+       struct bfi_lps_login_rsp_s *loginrsp;
+       bfa_eproto_status_t ext_status;
+};
+
+struct bfa_lps_mod_s {
+       struct list_head                lps_free_q;
+       struct list_head                lps_active_q;
+       struct bfa_lps_s        *lps_arr;
+       int                     num_lps;
+};
+
+#define BFA_LPS_MOD(__bfa)             (&(__bfa)->modules.lps_mod)
+#define BFA_LPS_FROM_TAG(__mod, __tag) (&(__mod)->lps_arr[__tag])
+
+/*
+ * external functions
+ */
+void   bfa_lps_isr(struct bfa_s *bfa, struct bfi_msg_s *msg);
+
+
+/**
+ * FCPORT related defines
+ */
+
+#define BFA_FCPORT(_bfa)       (&((_bfa)->modules.port))
+typedef void (*bfa_cb_port_t) (void *cbarg, enum bfa_status status);
+
+/**
+ * Link notification data structure
+ */
+struct bfa_fcport_ln_s {
+       struct bfa_fcport_s     *fcport;
+       bfa_sm_t                sm;
+       struct bfa_cb_qe_s      ln_qe;  /*  BFA callback queue elem for ln */
+       enum bfa_port_linkstate ln_event; /*  ln event for callback */
+};
+
+struct bfa_fcport_trunk_s {
+       struct bfa_trunk_attr_s attr;
+};
+
+/**
+ * BFA FC port data structure
+ */
+struct bfa_fcport_s {
+       struct bfa_s            *bfa;   /*  parent BFA instance */
+       bfa_sm_t                sm;     /*  port state machine */
+       wwn_t                   nwwn;   /*  node wwn of physical port */
+       wwn_t                   pwwn;   /*  port wwn of physical oprt */
+       enum bfa_port_speed speed_sup;
+       /*  supported speeds */
+       enum bfa_port_speed speed;      /*  current speed */
+       enum bfa_port_topology topology;        /*  current topology */
+       u8                      myalpa; /*  my ALPA in LOOP topology */
+       u8                      rsvd[3];
+       struct bfa_port_cfg_s   cfg;    /*  current port configuration */
+       struct bfa_qos_attr_s  qos_attr;   /* QoS Attributes */
+       struct bfa_qos_vc_attr_s qos_vc_attr;  /*  VC info from ELP */
+       struct bfa_reqq_wait_s  reqq_wait;
+       /*  to wait for room in reqq */
+       struct bfa_reqq_wait_s  svcreq_wait;
+       /*  to wait for room in reqq */
+       struct bfa_reqq_wait_s  stats_reqq_wait;
+       /*  to wait for room in reqq (stats) */
+       void                    *event_cbarg;
+       void                    (*event_cbfn) (void *cbarg,
+                                              enum bfa_port_linkstate event);
+       union {
+               union bfi_fcport_i2h_msg_u i2hmsg;
+       } event_arg;
+       void                    *bfad;  /*  BFA driver handle */
+       struct bfa_fcport_ln_s  ln; /*  Link Notification */
+       struct bfa_cb_qe_s      hcb_qe; /*  BFA callback queue elem */
+       struct bfa_timer_s      timer;  /*  timer */
+       u32             msgtag; /*  fimrware msg tag for reply */
+       u8                      *stats_kva;
+       u64             stats_pa;
+       union bfa_fcport_stats_u *stats;
+       union bfa_fcport_stats_u *stats_ret; /*  driver stats location */
+       bfa_status_t            stats_status; /*  stats/statsclr status */
+       bfa_boolean_t           stats_busy; /*  outstanding stats/statsclr */
+       bfa_boolean_t           stats_qfull;
+       u32             stats_reset_time; /*  stats reset time stamp */
+       bfa_cb_port_t           stats_cbfn; /*  driver callback function */
+       void                    *stats_cbarg; /* *!< user callback arg */
+       bfa_boolean_t           diag_busy; /*  diag busy status */
+       bfa_boolean_t           beacon; /*  port beacon status */
+       bfa_boolean_t           link_e2e_beacon; /*  link beacon status */
+       struct bfa_fcport_trunk_s trunk;
+       u16             fcoe_vlan;
+};
+
+#define BFA_FCPORT_MOD(__bfa)  (&(__bfa)->modules.fcport)
+
+/*
+ * protected functions
+ */
+void bfa_fcport_init(struct bfa_s *bfa);
+void bfa_fcport_isr(struct bfa_s *bfa, struct bfi_msg_s *msg);
+
+/*
+ * bfa fcport API functions
+ */
+bfa_status_t bfa_fcport_enable(struct bfa_s *bfa);
+bfa_status_t bfa_fcport_disable(struct bfa_s *bfa);
+bfa_status_t bfa_fcport_cfg_speed(struct bfa_s *bfa,
+                                 enum bfa_port_speed speed);
+enum bfa_port_speed bfa_fcport_get_speed(struct bfa_s *bfa);
+bfa_status_t bfa_fcport_cfg_topology(struct bfa_s *bfa,
+                                    enum bfa_port_topology topo);
+enum bfa_port_topology bfa_fcport_get_topology(struct bfa_s *bfa);
+bfa_status_t bfa_fcport_cfg_hardalpa(struct bfa_s *bfa, u8 alpa);
+bfa_boolean_t bfa_fcport_get_hardalpa(struct bfa_s *bfa, u8 *alpa);
+u8 bfa_fcport_get_myalpa(struct bfa_s *bfa);
+bfa_status_t bfa_fcport_clr_hardalpa(struct bfa_s *bfa);
+bfa_status_t bfa_fcport_cfg_maxfrsize(struct bfa_s *bfa, u16 maxsize);
+u16 bfa_fcport_get_maxfrsize(struct bfa_s *bfa);
+u8 bfa_fcport_get_rx_bbcredit(struct bfa_s *bfa);
+void bfa_fcport_get_attr(struct bfa_s *bfa, struct bfa_port_attr_s *attr);
+wwn_t bfa_fcport_get_wwn(struct bfa_s *bfa, bfa_boolean_t node);
+void bfa_fcport_event_register(struct bfa_s *bfa,
+                       void (*event_cbfn) (void *cbarg,
+                       enum bfa_port_linkstate event), void *event_cbarg);
+bfa_boolean_t bfa_fcport_is_disabled(struct bfa_s *bfa);
+void bfa_fcport_cfg_qos(struct bfa_s *bfa, bfa_boolean_t on_off);
+void bfa_fcport_cfg_ratelim(struct bfa_s *bfa, bfa_boolean_t on_off);
+bfa_status_t bfa_fcport_cfg_ratelim_speed(struct bfa_s *bfa,
+                                         enum bfa_port_speed speed);
+enum bfa_port_speed bfa_fcport_get_ratelim_speed(struct bfa_s *bfa);
+
+void bfa_fcport_set_tx_bbcredit(struct bfa_s *bfa, u16 tx_bbcredit);
+void bfa_fcport_busy(struct bfa_s *bfa, bfa_boolean_t status);
+void bfa_fcport_beacon(void *dev, bfa_boolean_t beacon,
+                      bfa_boolean_t link_e2e_beacon);
+void bfa_fcport_qos_get_attr(struct bfa_s *bfa,
+                            struct bfa_qos_attr_s *qos_attr);
+void bfa_fcport_qos_get_vc_attr(struct bfa_s *bfa,
+                               struct bfa_qos_vc_attr_s *qos_vc_attr);
+bfa_status_t bfa_fcport_get_qos_stats(struct bfa_s *bfa,
+                                     union bfa_fcport_stats_u *stats,
+                                     bfa_cb_port_t cbfn, void *cbarg);
+bfa_status_t bfa_fcport_clear_qos_stats(struct bfa_s *bfa, bfa_cb_port_t cbfn,
+                                       void *cbarg);
+bfa_status_t bfa_fcport_get_fcoe_stats(struct bfa_s *bfa,
+                                      union bfa_fcport_stats_u *stats,
+                                      bfa_cb_port_t cbfn, void *cbarg);
+bfa_status_t bfa_fcport_clear_fcoe_stats(struct bfa_s *bfa, bfa_cb_port_t cbfn,
+                                        void *cbarg);
+bfa_boolean_t     bfa_fcport_is_ratelim(struct bfa_s *bfa);
+bfa_boolean_t  bfa_fcport_is_linkup(struct bfa_s *bfa);
+bfa_status_t bfa_fcport_get_stats(struct bfa_s *bfa,
+                                 union bfa_fcport_stats_u *stats,
+                                 bfa_cb_port_t cbfn, void *cbarg);
+bfa_status_t bfa_fcport_clear_stats(struct bfa_s *bfa, bfa_cb_port_t cbfn,
+                                   void *cbarg);
+bfa_boolean_t bfa_fcport_is_qos_enabled(struct bfa_s *bfa);
+
+/*
+ * bfa rport API functions
+ */
+struct bfa_rport_s *bfa_rport_create(struct bfa_s *bfa, void *rport_drv);
+void bfa_rport_delete(struct bfa_rport_s *rport);
+void bfa_rport_online(struct bfa_rport_s *rport,
+                     struct bfa_rport_info_s *rport_info);
+void bfa_rport_offline(struct bfa_rport_s *rport);
+void bfa_rport_speed(struct bfa_rport_s *rport, enum bfa_port_speed speed);
+void bfa_rport_get_stats(struct bfa_rport_s *rport,
+                        struct bfa_rport_hal_stats_s *stats);
+void bfa_rport_clear_stats(struct bfa_rport_s *rport);
+void bfa_cb_rport_online(void *rport);
+void bfa_cb_rport_offline(void *rport);
+void bfa_cb_rport_qos_scn_flowid(void *rport,
+                                struct bfa_rport_qos_attr_s old_qos_attr,
+                                struct bfa_rport_qos_attr_s new_qos_attr);
+void bfa_cb_rport_qos_scn_prio(void *rport,
+                              struct bfa_rport_qos_attr_s old_qos_attr,
+                              struct bfa_rport_qos_attr_s new_qos_attr);
+void bfa_rport_get_qos_attr(struct bfa_rport_s *rport,
+                           struct bfa_rport_qos_attr_s *qos_attr);
+
+/*
+ * bfa fcxp API functions
+ */
+struct bfa_fcxp_s *bfa_fcxp_alloc(void *bfad_fcxp, struct bfa_s *bfa,
+                                 int nreq_sgles, int nrsp_sgles,
+                                 bfa_fcxp_get_sgaddr_t get_req_sga,
+                                 bfa_fcxp_get_sglen_t get_req_sglen,
+                                 bfa_fcxp_get_sgaddr_t get_rsp_sga,
+                                 bfa_fcxp_get_sglen_t get_rsp_sglen);
+void bfa_fcxp_alloc_wait(struct bfa_s *bfa, struct bfa_fcxp_wqe_s *wqe,
+                               bfa_fcxp_alloc_cbfn_t alloc_cbfn,
+                               void *cbarg, void *bfad_fcxp,
+                               int nreq_sgles, int nrsp_sgles,
+                               bfa_fcxp_get_sgaddr_t get_req_sga,
+                               bfa_fcxp_get_sglen_t get_req_sglen,
+                               bfa_fcxp_get_sgaddr_t get_rsp_sga,
+                               bfa_fcxp_get_sglen_t get_rsp_sglen);
+void bfa_fcxp_walloc_cancel(struct bfa_s *bfa,
+                           struct bfa_fcxp_wqe_s *wqe);
+void bfa_fcxp_discard(struct bfa_fcxp_s *fcxp);
+
+void *bfa_fcxp_get_reqbuf(struct bfa_fcxp_s *fcxp);
+void *bfa_fcxp_get_rspbuf(struct bfa_fcxp_s *fcxp);
+
+void bfa_fcxp_free(struct bfa_fcxp_s *fcxp);
+
+void bfa_fcxp_send(struct bfa_fcxp_s *fcxp, struct bfa_rport_s *rport,
+                  u16 vf_id, u8 lp_tag,
+                  bfa_boolean_t cts, enum fc_cos cos,
+                  u32 reqlen, struct fchs_s *fchs,
+                  bfa_cb_fcxp_send_t cbfn,
+                  void *cbarg,
+                  u32 rsp_maxlen, u8 rsp_timeout);
+bfa_status_t bfa_fcxp_abort(struct bfa_fcxp_s *fcxp);
+u32 bfa_fcxp_get_reqbufsz(struct bfa_fcxp_s *fcxp);
+u32 bfa_fcxp_get_maxrsp(struct bfa_s *bfa);
+
+static inline void *
+bfa_uf_get_frmbuf(struct bfa_uf_s *uf)
+{
+       return uf->data_ptr;
+}
+
+static inline   u16
+bfa_uf_get_frmlen(struct bfa_uf_s *uf)
+{
+       return uf->data_len;
+}
+
+/*
+ * bfa uf API functions
+ */
+void bfa_uf_recv_register(struct bfa_s *bfa, bfa_cb_uf_recv_t ufrecv,
+                         void *cbarg);
+void bfa_uf_free(struct bfa_uf_s *uf);
+
+/**
+ * bfa lport service api
+ */
+
+u32 bfa_lps_get_max_vport(struct bfa_s *bfa);
+struct bfa_lps_s *bfa_lps_alloc(struct bfa_s *bfa);
+void bfa_lps_delete(struct bfa_lps_s *lps);
+void bfa_lps_discard(struct bfa_lps_s *lps);
+void bfa_lps_flogi(struct bfa_lps_s *lps, void *uarg, u8 alpa,
+                  u16 pdusz, wwn_t pwwn, wwn_t nwwn,
+                  bfa_boolean_t auth_en);
+void bfa_lps_fdisc(struct bfa_lps_s *lps, void *uarg, u16 pdusz,
+                  wwn_t pwwn, wwn_t nwwn);
+void bfa_lps_flogo(struct bfa_lps_s *lps);
+void bfa_lps_fdisclogo(struct bfa_lps_s *lps);
+u8 bfa_lps_get_tag(struct bfa_lps_s *lps);
+bfa_boolean_t bfa_lps_is_npiv_en(struct bfa_lps_s *lps);
+bfa_boolean_t bfa_lps_is_fport(struct bfa_lps_s *lps);
+bfa_boolean_t bfa_lps_is_brcd_fabric(struct bfa_lps_s *lps);
+bfa_boolean_t bfa_lps_is_authreq(struct bfa_lps_s *lps);
+bfa_eproto_status_t bfa_lps_get_extstatus(struct bfa_lps_s *lps);
+u32 bfa_lps_get_pid(struct bfa_lps_s *lps);
+u32 bfa_lps_get_base_pid(struct bfa_s *bfa);
+u8 bfa_lps_get_tag_from_pid(struct bfa_s *bfa, u32 pid);
+u16 bfa_lps_get_peer_bbcredit(struct bfa_lps_s *lps);
+wwn_t bfa_lps_get_peer_pwwn(struct bfa_lps_s *lps);
+wwn_t bfa_lps_get_peer_nwwn(struct bfa_lps_s *lps);
+u8 bfa_lps_get_lsrjt_rsn(struct bfa_lps_s *lps);
+u8 bfa_lps_get_lsrjt_expl(struct bfa_lps_s *lps);
+mac_t bfa_lps_get_lp_mac(struct bfa_lps_s *lps);
+void bfa_cb_lps_flogi_comp(void *bfad, void *uarg, bfa_status_t status);
+void bfa_cb_lps_fdisc_comp(void *bfad, void *uarg, bfa_status_t status);
+void bfa_cb_lps_fdisclogo_comp(void *bfad, void *uarg);
+void bfa_cb_lps_cvl_event(void *bfad, void *uarg);
+
+void bfa_trunk_enable_cfg(struct bfa_s *bfa);
+bfa_status_t bfa_trunk_enable(struct bfa_s *bfa);
+bfa_status_t bfa_trunk_disable(struct bfa_s *bfa);
+bfa_status_t bfa_trunk_get_attr(struct bfa_s *bfa,
+               struct bfa_trunk_attr_s *attr);
+
+#endif /* __BFA_SVC_H__ */
diff --git a/drivers/scsi/bfa/bfa_timer.c b/drivers/scsi/bfa/bfa_timer.c
deleted file mode 100644 (file)
index cb76481..0000000
+++ /dev/null
@@ -1,90 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#include <bfa_timer.h>
-#include <cs/bfa_debug.h>
-
-void
-bfa_timer_init(struct bfa_timer_mod_s *mod)
-{
-       INIT_LIST_HEAD(&mod->timer_q);
-}
-
-void
-bfa_timer_beat(struct bfa_timer_mod_s *mod)
-{
-       struct list_head        *qh = &mod->timer_q;
-       struct list_head        *qe, *qe_next;
-       struct bfa_timer_s *elem;
-       struct list_head         timedout_q;
-
-       INIT_LIST_HEAD(&timedout_q);
-
-       qe = bfa_q_next(qh);
-
-       while (qe != qh) {
-               qe_next = bfa_q_next(qe);
-
-               elem = (struct bfa_timer_s *) qe;
-               if (elem->timeout <= BFA_TIMER_FREQ) {
-                       elem->timeout = 0;
-                       list_del(&elem->qe);
-                       list_add_tail(&elem->qe, &timedout_q);
-               } else {
-                       elem->timeout -= BFA_TIMER_FREQ;
-               }
-
-               qe = qe_next;   /* go to next elem */
-       }
-
-       /*
-        * Pop all the timeout entries
-        */
-       while (!list_empty(&timedout_q)) {
-               bfa_q_deq(&timedout_q, &elem);
-               elem->timercb(elem->arg);
-       }
-}
-
-/**
- * Should be called with lock protection
- */
-void
-bfa_timer_begin(struct bfa_timer_mod_s *mod, struct bfa_timer_s *timer,
-                   void (*timercb) (void *), void *arg, unsigned int timeout)
-{
-
-       bfa_assert(timercb != NULL);
-       bfa_assert(!bfa_q_is_on_q(&mod->timer_q, timer));
-
-       timer->timeout = timeout;
-       timer->timercb = timercb;
-       timer->arg = arg;
-
-       list_add_tail(&timer->qe, &mod->timer_q);
-}
-
-/**
- * Should be called with lock protection
- */
-void
-bfa_timer_stop(struct bfa_timer_s *timer)
-{
-       bfa_assert(!list_empty(&timer->qe));
-
-       list_del(&timer->qe);
-}
diff --git a/drivers/scsi/bfa/bfa_trcmod_priv.h b/drivers/scsi/bfa/bfa_trcmod_priv.h
deleted file mode 100644 (file)
index a7a8261..0000000
+++ /dev/null
@@ -1,64 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  hal_trcmod.h BFA trace modules
- */
-
-#ifndef __BFA_TRCMOD_PRIV_H__
-#define __BFA_TRCMOD_PRIV_H__
-
-#include <cs/bfa_trc.h>
-
-/*
- * !!! Only append to the enums defined here to avoid any versioning
- * !!! needed between trace utility and driver version
- */
-enum {
-       BFA_TRC_HAL_INTR        = 1,
-       BFA_TRC_HAL_FCXP        = 2,
-       BFA_TRC_HAL_UF          = 3,
-       BFA_TRC_HAL_RPORT       = 4,
-       BFA_TRC_HAL_FCPIM       = 5,
-       BFA_TRC_HAL_IOIM        = 6,
-       BFA_TRC_HAL_TSKIM       = 7,
-       BFA_TRC_HAL_ITNIM       = 8,
-       BFA_TRC_HAL_FCPORT      = 9,
-       BFA_TRC_HAL_SGPG        = 10,
-       BFA_TRC_HAL_FLASH       = 11,
-       BFA_TRC_HAL_DEBUG       = 12,
-       BFA_TRC_HAL_WWN         = 13,
-       BFA_TRC_HAL_FLASH_RAW   = 14,
-       BFA_TRC_HAL_SBOOT       = 15,
-       BFA_TRC_HAL_SBOOT_IO    = 16,
-       BFA_TRC_HAL_SBOOT_INTR  = 17,
-       BFA_TRC_HAL_SBTEST      = 18,
-       BFA_TRC_HAL_IPFC        = 19,
-       BFA_TRC_HAL_IOCFC       = 20,
-       BFA_TRC_HAL_FCPTM       = 21,
-       BFA_TRC_HAL_IOTM        = 22,
-       BFA_TRC_HAL_TSKTM       = 23,
-       BFA_TRC_HAL_TIN         = 24,
-       BFA_TRC_HAL_LPS         = 25,
-       BFA_TRC_HAL_FCDIAG      = 26,
-       BFA_TRC_HAL_PBIND       = 27,
-       BFA_TRC_HAL_IOCFC_CT    = 28,
-       BFA_TRC_HAL_IOCFC_CB    = 29,
-       BFA_TRC_HAL_IOCFC_Q     = 30,
-};
-
-#endif /* __BFA_TRCMOD_PRIV_H__ */
diff --git a/drivers/scsi/bfa/bfa_tskim.c b/drivers/scsi/bfa/bfa_tskim.c
deleted file mode 100644 (file)
index ad9aaae..0000000
+++ /dev/null
@@ -1,690 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#include <bfa.h>
-#include <bfa_cb_ioim_macros.h>
-
-BFA_TRC_FILE(HAL, TSKIM);
-
-/**
- * task management completion handling
- */
-#define bfa_tskim_qcomp(__tskim, __cbfn) do {                  \
-       bfa_cb_queue((__tskim)->bfa, &(__tskim)->hcb_qe,        \
-                        __cbfn, (__tskim));      \
-       bfa_tskim_notify_comp(__tskim);      \
-} while (0)
-
-#define bfa_tskim_notify_comp(__tskim) do {                     \
-       if ((__tskim)->notify)                                   \
-               bfa_itnim_tskdone((__tskim)->itnim);      \
-} while (0)
-
-/*
- * forward declarations
- */
-static void     __bfa_cb_tskim_done(void *cbarg, bfa_boolean_t complete);
-static void     __bfa_cb_tskim_failed(void *cbarg, bfa_boolean_t complete);
-static bfa_boolean_t bfa_tskim_match_scope(struct bfa_tskim_s *tskim,
-                                              lun_t lun);
-static void     bfa_tskim_gather_ios(struct bfa_tskim_s *tskim);
-static void     bfa_tskim_cleanp_comp(void *tskim_cbarg);
-static void     bfa_tskim_cleanup_ios(struct bfa_tskim_s *tskim);
-static bfa_boolean_t bfa_tskim_send(struct bfa_tskim_s *tskim);
-static bfa_boolean_t bfa_tskim_send_abort(struct bfa_tskim_s *tskim);
-static void     bfa_tskim_iocdisable_ios(struct bfa_tskim_s *tskim);
-
-/**
- *  bfa_tskim_sm
- */
-
-enum bfa_tskim_event {
-       BFA_TSKIM_SM_START        = 1,  /*  TM command start            */
-       BFA_TSKIM_SM_DONE         = 2,  /*  TM completion               */
-       BFA_TSKIM_SM_QRESUME      = 3,  /*  resume after qfull          */
-       BFA_TSKIM_SM_HWFAIL       = 5,  /*  IOC h/w failure event       */
-       BFA_TSKIM_SM_HCB          = 6,  /*  BFA callback completion     */
-       BFA_TSKIM_SM_IOS_DONE     = 7,  /*  IO and sub TM completions   */
-       BFA_TSKIM_SM_CLEANUP      = 8,  /*  TM cleanup on ITN offline   */
-       BFA_TSKIM_SM_CLEANUP_DONE = 9,  /*  TM abort completion         */
-};
-
-static void     bfa_tskim_sm_uninit(struct bfa_tskim_s *tskim,
-                                       enum bfa_tskim_event event);
-static void     bfa_tskim_sm_active(struct bfa_tskim_s *tskim,
-                                       enum bfa_tskim_event event);
-static void     bfa_tskim_sm_cleanup(struct bfa_tskim_s *tskim,
-                                        enum bfa_tskim_event event);
-static void     bfa_tskim_sm_iocleanup(struct bfa_tskim_s *tskim,
-                                        enum bfa_tskim_event event);
-static void     bfa_tskim_sm_qfull(struct bfa_tskim_s *tskim,
-                                      enum bfa_tskim_event event);
-static void     bfa_tskim_sm_cleanup_qfull(struct bfa_tskim_s *tskim,
-                                      enum bfa_tskim_event event);
-static void     bfa_tskim_sm_hcb(struct bfa_tskim_s *tskim,
-                                    enum bfa_tskim_event event);
-
-/**
- *      Task management command beginning state.
- */
-static void
-bfa_tskim_sm_uninit(struct bfa_tskim_s *tskim, enum bfa_tskim_event event)
-{
-       bfa_trc(tskim->bfa, event);
-
-       switch (event) {
-       case BFA_TSKIM_SM_START:
-               bfa_sm_set_state(tskim, bfa_tskim_sm_active);
-               bfa_tskim_gather_ios(tskim);
-
-               /**
-                * If device is offline, do not send TM on wire. Just cleanup
-                * any pending IO requests and complete TM request.
-                */
-               if (!bfa_itnim_is_online(tskim->itnim)) {
-                       bfa_sm_set_state(tskim, bfa_tskim_sm_iocleanup);
-                       tskim->tsk_status = BFI_TSKIM_STS_OK;
-                       bfa_tskim_cleanup_ios(tskim);
-                       return;
-               }
-
-               if (!bfa_tskim_send(tskim)) {
-                       bfa_sm_set_state(tskim, bfa_tskim_sm_qfull);
-                       bfa_reqq_wait(tskim->bfa, tskim->itnim->reqq,
-                                         &tskim->reqq_wait);
-               }
-               break;
-
-       default:
-               bfa_sm_fault(tskim->bfa, event);
-       }
-}
-
-/**
- * brief
- *     TM command is active, awaiting completion from firmware to
- *     cleanup IO requests in TM scope.
- */
-static void
-bfa_tskim_sm_active(struct bfa_tskim_s *tskim, enum bfa_tskim_event event)
-{
-       bfa_trc(tskim->bfa, event);
-
-       switch (event) {
-       case BFA_TSKIM_SM_DONE:
-               bfa_sm_set_state(tskim, bfa_tskim_sm_iocleanup);
-               bfa_tskim_cleanup_ios(tskim);
-               break;
-
-       case BFA_TSKIM_SM_CLEANUP:
-               bfa_sm_set_state(tskim, bfa_tskim_sm_cleanup);
-               if (!bfa_tskim_send_abort(tskim)) {
-                       bfa_sm_set_state(tskim, bfa_tskim_sm_cleanup_qfull);
-                       bfa_reqq_wait(tskim->bfa, tskim->itnim->reqq,
-                               &tskim->reqq_wait);
-               }
-               break;
-
-       case BFA_TSKIM_SM_HWFAIL:
-               bfa_sm_set_state(tskim, bfa_tskim_sm_hcb);
-               bfa_tskim_iocdisable_ios(tskim);
-               bfa_tskim_qcomp(tskim, __bfa_cb_tskim_failed);
-               break;
-
-       default:
-               bfa_sm_fault(tskim->bfa, event);
-       }
-}
-
-/**
- *     An active TM is being cleaned up since ITN is offline. Awaiting cleanup
- *     completion event from firmware.
- */
-static void
-bfa_tskim_sm_cleanup(struct bfa_tskim_s *tskim, enum bfa_tskim_event event)
-{
-       bfa_trc(tskim->bfa, event);
-
-       switch (event) {
-       case BFA_TSKIM_SM_DONE:
-               /**
-                * Ignore and wait for ABORT completion from firmware.
-                */
-               break;
-
-       case BFA_TSKIM_SM_CLEANUP_DONE:
-               bfa_sm_set_state(tskim, bfa_tskim_sm_iocleanup);
-               bfa_tskim_cleanup_ios(tskim);
-               break;
-
-       case BFA_TSKIM_SM_HWFAIL:
-               bfa_sm_set_state(tskim, bfa_tskim_sm_hcb);
-               bfa_tskim_iocdisable_ios(tskim);
-               bfa_tskim_qcomp(tskim, __bfa_cb_tskim_failed);
-               break;
-
-       default:
-               bfa_sm_fault(tskim->bfa, event);
-       }
-}
-
-static void
-bfa_tskim_sm_iocleanup(struct bfa_tskim_s *tskim, enum bfa_tskim_event event)
-{
-       bfa_trc(tskim->bfa, event);
-
-       switch (event) {
-       case BFA_TSKIM_SM_IOS_DONE:
-               bfa_sm_set_state(tskim, bfa_tskim_sm_hcb);
-               bfa_tskim_qcomp(tskim, __bfa_cb_tskim_done);
-               break;
-
-       case BFA_TSKIM_SM_CLEANUP:
-               /**
-                * Ignore, TM command completed on wire.
-                * Notify TM conmpletion on IO cleanup completion.
-                */
-               break;
-
-       case BFA_TSKIM_SM_HWFAIL:
-               bfa_sm_set_state(tskim, bfa_tskim_sm_hcb);
-               bfa_tskim_iocdisable_ios(tskim);
-               bfa_tskim_qcomp(tskim, __bfa_cb_tskim_failed);
-               break;
-
-       default:
-               bfa_sm_fault(tskim->bfa, event);
-       }
-}
-
-/**
- *      Task management command is waiting for room in request CQ
- */
-static void
-bfa_tskim_sm_qfull(struct bfa_tskim_s *tskim, enum bfa_tskim_event event)
-{
-       bfa_trc(tskim->bfa, event);
-
-       switch (event) {
-       case BFA_TSKIM_SM_QRESUME:
-               bfa_sm_set_state(tskim, bfa_tskim_sm_active);
-               bfa_tskim_send(tskim);
-               break;
-
-       case BFA_TSKIM_SM_CLEANUP:
-               /**
-                * No need to send TM on wire since ITN is offline.
-                */
-               bfa_sm_set_state(tskim, bfa_tskim_sm_iocleanup);
-               bfa_reqq_wcancel(&tskim->reqq_wait);
-               bfa_tskim_cleanup_ios(tskim);
-               break;
-
-       case BFA_TSKIM_SM_HWFAIL:
-               bfa_sm_set_state(tskim, bfa_tskim_sm_hcb);
-               bfa_reqq_wcancel(&tskim->reqq_wait);
-               bfa_tskim_iocdisable_ios(tskim);
-               bfa_tskim_qcomp(tskim, __bfa_cb_tskim_failed);
-               break;
-
-       default:
-               bfa_sm_fault(tskim->bfa, event);
-       }
-}
-
-/**
- *      Task management command is active, awaiting for room in request CQ
- *     to send clean up request.
- */
-static void
-bfa_tskim_sm_cleanup_qfull(struct bfa_tskim_s *tskim,
-               enum bfa_tskim_event event)
-{
-       bfa_trc(tskim->bfa, event);
-
-       switch (event) {
-       case BFA_TSKIM_SM_DONE:
-               bfa_reqq_wcancel(&tskim->reqq_wait);
-               /**
-                *
-                * Fall through !!!
-                */
-
-       case BFA_TSKIM_SM_QRESUME:
-               bfa_sm_set_state(tskim, bfa_tskim_sm_cleanup);
-               bfa_tskim_send_abort(tskim);
-               break;
-
-       case BFA_TSKIM_SM_HWFAIL:
-               bfa_sm_set_state(tskim, bfa_tskim_sm_hcb);
-               bfa_reqq_wcancel(&tskim->reqq_wait);
-               bfa_tskim_iocdisable_ios(tskim);
-               bfa_tskim_qcomp(tskim, __bfa_cb_tskim_failed);
-               break;
-
-       default:
-               bfa_sm_fault(tskim->bfa, event);
-       }
-}
-
-/**
- *      BFA callback is pending
- */
-static void
-bfa_tskim_sm_hcb(struct bfa_tskim_s *tskim, enum bfa_tskim_event event)
-{
-       bfa_trc(tskim->bfa, event);
-
-       switch (event) {
-       case BFA_TSKIM_SM_HCB:
-               bfa_sm_set_state(tskim, bfa_tskim_sm_uninit);
-               bfa_tskim_free(tskim);
-               break;
-
-       case BFA_TSKIM_SM_CLEANUP:
-               bfa_tskim_notify_comp(tskim);
-               break;
-
-       case BFA_TSKIM_SM_HWFAIL:
-               break;
-
-       default:
-               bfa_sm_fault(tskim->bfa, event);
-       }
-}
-
-
-
-/**
- *  bfa_tskim_private
- */
-
-static void
-__bfa_cb_tskim_done(void *cbarg, bfa_boolean_t complete)
-{
-       struct bfa_tskim_s *tskim = cbarg;
-
-       if (!complete) {
-               bfa_sm_send_event(tskim, BFA_TSKIM_SM_HCB);
-               return;
-       }
-
-       bfa_stats(tskim->itnim, tm_success);
-       bfa_cb_tskim_done(tskim->bfa->bfad, tskim->dtsk, tskim->tsk_status);
-}
-
-static void
-__bfa_cb_tskim_failed(void *cbarg, bfa_boolean_t complete)
-{
-       struct bfa_tskim_s *tskim = cbarg;
-
-       if (!complete) {
-               bfa_sm_send_event(tskim, BFA_TSKIM_SM_HCB);
-               return;
-       }
-
-       bfa_stats(tskim->itnim, tm_failures);
-       bfa_cb_tskim_done(tskim->bfa->bfad, tskim->dtsk,
-                          BFI_TSKIM_STS_FAILED);
-}
-
-static          bfa_boolean_t
-bfa_tskim_match_scope(struct bfa_tskim_s *tskim, lun_t lun)
-{
-       switch (tskim->tm_cmnd) {
-       case FCP_TM_TARGET_RESET:
-               return BFA_TRUE;
-
-       case FCP_TM_ABORT_TASK_SET:
-       case FCP_TM_CLEAR_TASK_SET:
-       case FCP_TM_LUN_RESET:
-       case FCP_TM_CLEAR_ACA:
-               return (tskim->lun == lun);
-
-       default:
-               bfa_assert(0);
-       }
-
-       return BFA_FALSE;
-}
-
-/**
- *      Gather affected IO requests and task management commands.
- */
-static void
-bfa_tskim_gather_ios(struct bfa_tskim_s *tskim)
-{
-       struct bfa_itnim_s *itnim = tskim->itnim;
-       struct bfa_ioim_s *ioim;
-       struct list_head        *qe, *qen;
-
-       INIT_LIST_HEAD(&tskim->io_q);
-
-       /**
-        * Gather any active IO requests first.
-        */
-       list_for_each_safe(qe, qen, &itnim->io_q) {
-               ioim = (struct bfa_ioim_s *) qe;
-               if (bfa_tskim_match_scope
-                   (tskim, bfa_cb_ioim_get_lun(ioim->dio))) {
-                       list_del(&ioim->qe);
-                       list_add_tail(&ioim->qe, &tskim->io_q);
-               }
-       }
-
-       /**
-        * Failback any pending IO requests immediately.
-        */
-       list_for_each_safe(qe, qen, &itnim->pending_q) {
-               ioim = (struct bfa_ioim_s *) qe;
-               if (bfa_tskim_match_scope
-                   (tskim, bfa_cb_ioim_get_lun(ioim->dio))) {
-                       list_del(&ioim->qe);
-                       list_add_tail(&ioim->qe, &ioim->fcpim->ioim_comp_q);
-                       bfa_ioim_tov(ioim);
-               }
-       }
-}
-
-/**
- *             IO cleanup completion
- */
-static void
-bfa_tskim_cleanp_comp(void *tskim_cbarg)
-{
-       struct bfa_tskim_s *tskim = tskim_cbarg;
-
-       bfa_stats(tskim->itnim, tm_io_comps);
-       bfa_sm_send_event(tskim, BFA_TSKIM_SM_IOS_DONE);
-}
-
-/**
- *      Gather affected IO requests and task management commands.
- */
-static void
-bfa_tskim_cleanup_ios(struct bfa_tskim_s *tskim)
-{
-       struct bfa_ioim_s *ioim;
-       struct list_head        *qe, *qen;
-
-       bfa_wc_init(&tskim->wc, bfa_tskim_cleanp_comp, tskim);
-
-       list_for_each_safe(qe, qen, &tskim->io_q) {
-               ioim = (struct bfa_ioim_s *) qe;
-               bfa_wc_up(&tskim->wc);
-               bfa_ioim_cleanup_tm(ioim, tskim);
-       }
-
-       bfa_wc_wait(&tskim->wc);
-}
-
-/**
- *      Send task management request to firmware.
- */
-static bfa_boolean_t
-bfa_tskim_send(struct bfa_tskim_s *tskim)
-{
-       struct bfa_itnim_s *itnim = tskim->itnim;
-       struct bfi_tskim_req_s *m;
-
-       /**
-        * check for room in queue to send request now
-        */
-       m = bfa_reqq_next(tskim->bfa, itnim->reqq);
-       if (!m)
-               return BFA_FALSE;
-
-       /**
-        * build i/o request message next
-        */
-       bfi_h2i_set(m->mh, BFI_MC_TSKIM, BFI_TSKIM_H2I_TM_REQ,
-                       bfa_lpuid(tskim->bfa));
-
-       m->tsk_tag = bfa_os_htons(tskim->tsk_tag);
-       m->itn_fhdl = tskim->itnim->rport->fw_handle;
-       m->t_secs = tskim->tsecs;
-       m->lun = tskim->lun;
-       m->tm_flags = tskim->tm_cmnd;
-
-       /**
-        * queue I/O message to firmware
-        */
-       bfa_reqq_produce(tskim->bfa, itnim->reqq);
-       return BFA_TRUE;
-}
-
-/**
- *      Send abort request to cleanup an active TM to firmware.
- */
-static bfa_boolean_t
-bfa_tskim_send_abort(struct bfa_tskim_s *tskim)
-{
-       struct bfa_itnim_s             *itnim = tskim->itnim;
-       struct bfi_tskim_abortreq_s    *m;
-
-       /**
-        * check for room in queue to send request now
-        */
-       m = bfa_reqq_next(tskim->bfa, itnim->reqq);
-       if (!m)
-               return BFA_FALSE;
-
-       /**
-        * build i/o request message next
-        */
-       bfi_h2i_set(m->mh, BFI_MC_TSKIM, BFI_TSKIM_H2I_ABORT_REQ,
-                       bfa_lpuid(tskim->bfa));
-
-       m->tsk_tag  = bfa_os_htons(tskim->tsk_tag);
-
-       /**
-        * queue I/O message to firmware
-        */
-       bfa_reqq_produce(tskim->bfa, itnim->reqq);
-       return BFA_TRUE;
-}
-
-/**
- *      Call to resume task management cmnd waiting for room in request queue.
- */
-static void
-bfa_tskim_qresume(void *cbarg)
-{
-       struct bfa_tskim_s *tskim = cbarg;
-
-       bfa_fcpim_stats(tskim->fcpim, qresumes);
-       bfa_stats(tskim->itnim, tm_qresumes);
-       bfa_sm_send_event(tskim, BFA_TSKIM_SM_QRESUME);
-}
-
-/**
- * Cleanup IOs associated with a task mangement command on IOC failures.
- */
-static void
-bfa_tskim_iocdisable_ios(struct bfa_tskim_s *tskim)
-{
-       struct bfa_ioim_s *ioim;
-       struct list_head        *qe, *qen;
-
-       list_for_each_safe(qe, qen, &tskim->io_q) {
-               ioim = (struct bfa_ioim_s *) qe;
-               bfa_ioim_iocdisable(ioim);
-       }
-}
-
-
-
-/**
- *  bfa_tskim_friend
- */
-
-/**
- * Notification on completions from related ioim.
- */
-void
-bfa_tskim_iodone(struct bfa_tskim_s *tskim)
-{
-       bfa_wc_down(&tskim->wc);
-}
-
-/**
- * Handle IOC h/w failure notification from itnim.
- */
-void
-bfa_tskim_iocdisable(struct bfa_tskim_s *tskim)
-{
-       tskim->notify = BFA_FALSE;
-       bfa_stats(tskim->itnim, tm_iocdowns);
-       bfa_sm_send_event(tskim, BFA_TSKIM_SM_HWFAIL);
-}
-
-/**
- * Cleanup TM command and associated IOs as part of ITNIM offline.
- */
-void
-bfa_tskim_cleanup(struct bfa_tskim_s *tskim)
-{
-       tskim->notify = BFA_TRUE;
-       bfa_stats(tskim->itnim, tm_cleanups);
-       bfa_sm_send_event(tskim, BFA_TSKIM_SM_CLEANUP);
-}
-
-/**
- *      Memory allocation and initialization.
- */
-void
-bfa_tskim_attach(struct bfa_fcpim_mod_s *fcpim, struct bfa_meminfo_s *minfo)
-{
-       struct bfa_tskim_s *tskim;
-       u16        i;
-
-       INIT_LIST_HEAD(&fcpim->tskim_free_q);
-
-       tskim = (struct bfa_tskim_s *) bfa_meminfo_kva(minfo);
-       fcpim->tskim_arr = tskim;
-
-       for (i = 0; i < fcpim->num_tskim_reqs; i++, tskim++) {
-               /*
-                * initialize TSKIM
-                */
-               bfa_os_memset(tskim, 0, sizeof(struct bfa_tskim_s));
-               tskim->tsk_tag = i;
-               tskim->bfa     = fcpim->bfa;
-               tskim->fcpim   = fcpim;
-               tskim->notify  = BFA_FALSE;
-               bfa_reqq_winit(&tskim->reqq_wait, bfa_tskim_qresume,
-                                  tskim);
-               bfa_sm_set_state(tskim, bfa_tskim_sm_uninit);
-
-               list_add_tail(&tskim->qe, &fcpim->tskim_free_q);
-       }
-
-       bfa_meminfo_kva(minfo) = (u8 *) tskim;
-}
-
-void
-bfa_tskim_detach(struct bfa_fcpim_mod_s *fcpim)
-{
-    /**
-     * @todo
-     */
-}
-
-void
-bfa_tskim_isr(struct bfa_s *bfa, struct bfi_msg_s *m)
-{
-       struct bfa_fcpim_mod_s *fcpim = BFA_FCPIM_MOD(bfa);
-       struct bfi_tskim_rsp_s *rsp = (struct bfi_tskim_rsp_s *) m;
-       struct bfa_tskim_s *tskim;
-       u16        tsk_tag = bfa_os_ntohs(rsp->tsk_tag);
-
-       tskim = BFA_TSKIM_FROM_TAG(fcpim, tsk_tag);
-       bfa_assert(tskim->tsk_tag == tsk_tag);
-
-       tskim->tsk_status = rsp->tsk_status;
-
-       /**
-        * Firmware sends BFI_TSKIM_STS_ABORTED status for abort
-        * requests. All other statuses are for normal completions.
-        */
-       if (rsp->tsk_status == BFI_TSKIM_STS_ABORTED) {
-               bfa_stats(tskim->itnim, tm_cleanup_comps);
-               bfa_sm_send_event(tskim, BFA_TSKIM_SM_CLEANUP_DONE);
-       } else {
-               bfa_stats(tskim->itnim, tm_fw_rsps);
-               bfa_sm_send_event(tskim, BFA_TSKIM_SM_DONE);
-       }
-}
-
-
-
-/**
- *  bfa_tskim_api
- */
-
-
-struct bfa_tskim_s *
-bfa_tskim_alloc(struct bfa_s *bfa, struct bfad_tskim_s *dtsk)
-{
-       struct bfa_fcpim_mod_s *fcpim = BFA_FCPIM_MOD(bfa);
-       struct bfa_tskim_s *tskim;
-
-       bfa_q_deq(&fcpim->tskim_free_q, &tskim);
-
-       if (!tskim)
-               bfa_fcpim_stats(fcpim, no_tskims);
-       else
-               tskim->dtsk = dtsk;
-
-       return tskim;
-}
-
-void
-bfa_tskim_free(struct bfa_tskim_s *tskim)
-{
-       bfa_assert(bfa_q_is_on_q_func(&tskim->itnim->tsk_q, &tskim->qe));
-       list_del(&tskim->qe);
-       list_add_tail(&tskim->qe, &tskim->fcpim->tskim_free_q);
-}
-
-/**
- *      Start a task management command.
- *
- * @param[in]       tskim       BFA task management command instance
- * @param[in]       itnim       i-t nexus for the task management command
- * @param[in]       lun         lun, if applicable
- * @param[in]       tm_cmnd     Task management command code.
- * @param[in]       t_secs      Timeout in seconds
- *
- * @return None.
- */
-void
-bfa_tskim_start(struct bfa_tskim_s *tskim, struct bfa_itnim_s *itnim, lun_t lun,
-                   enum fcp_tm_cmnd tm_cmnd, u8 tsecs)
-{
-       tskim->itnim   = itnim;
-       tskim->lun     = lun;
-       tskim->tm_cmnd = tm_cmnd;
-       tskim->tsecs   = tsecs;
-       tskim->notify  = BFA_FALSE;
-       bfa_stats(itnim, tm_cmnds);
-
-       list_add_tail(&tskim->qe, &itnim->tsk_q);
-       bfa_sm_send_event(tskim, BFA_TSKIM_SM_START);
-}
-
-
diff --git a/drivers/scsi/bfa/bfa_uf.c b/drivers/scsi/bfa/bfa_uf.c
deleted file mode 100644 (file)
index b9a9a68..0000000
+++ /dev/null
@@ -1,343 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  bfa_uf.c BFA unsolicited frame receive implementation
- */
-
-#include <bfa.h>
-#include <bfa_svc.h>
-#include <bfi/bfi_uf.h>
-#include <cs/bfa_debug.h>
-
-BFA_TRC_FILE(HAL, UF);
-BFA_MODULE(uf);
-
-/*
- *****************************************************************************
- * Internal functions
- *****************************************************************************
- */
-static void
-__bfa_cb_uf_recv(void *cbarg, bfa_boolean_t complete)
-{
-       struct bfa_uf_s   *uf = cbarg;
-       struct bfa_uf_mod_s *ufm = BFA_UF_MOD(uf->bfa);
-
-       if (complete)
-               ufm->ufrecv(ufm->cbarg, uf);
-}
-
-static void
-claim_uf_pbs(struct bfa_uf_mod_s *ufm, struct bfa_meminfo_s *mi)
-{
-       u32        uf_pb_tot_sz;
-
-       ufm->uf_pbs_kva = (struct bfa_uf_buf_s *) bfa_meminfo_dma_virt(mi);
-       ufm->uf_pbs_pa = bfa_meminfo_dma_phys(mi);
-       uf_pb_tot_sz = BFA_ROUNDUP((sizeof(struct bfa_uf_buf_s) * ufm->num_ufs),
-                                                       BFA_DMA_ALIGN_SZ);
-
-       bfa_meminfo_dma_virt(mi) += uf_pb_tot_sz;
-       bfa_meminfo_dma_phys(mi) += uf_pb_tot_sz;
-
-       bfa_os_memset((void *)ufm->uf_pbs_kva, 0, uf_pb_tot_sz);
-}
-
-static void
-claim_uf_post_msgs(struct bfa_uf_mod_s *ufm, struct bfa_meminfo_s *mi)
-{
-       struct bfi_uf_buf_post_s *uf_bp_msg;
-       struct bfi_sge_s      *sge;
-       union bfi_addr_u      sga_zero = { {0} };
-       u16        i;
-       u16        buf_len;
-
-       ufm->uf_buf_posts = (struct bfi_uf_buf_post_s *) bfa_meminfo_kva(mi);
-       uf_bp_msg = ufm->uf_buf_posts;
-
-       for (i = 0, uf_bp_msg = ufm->uf_buf_posts; i < ufm->num_ufs;
-            i++, uf_bp_msg++) {
-               bfa_os_memset(uf_bp_msg, 0, sizeof(struct bfi_uf_buf_post_s));
-
-               uf_bp_msg->buf_tag = i;
-               buf_len = sizeof(struct bfa_uf_buf_s);
-               uf_bp_msg->buf_len = bfa_os_htons(buf_len);
-               bfi_h2i_set(uf_bp_msg->mh, BFI_MC_UF, BFI_UF_H2I_BUF_POST,
-                           bfa_lpuid(ufm->bfa));
-
-               sge = uf_bp_msg->sge;
-               sge[0].sg_len = buf_len;
-               sge[0].flags = BFI_SGE_DATA_LAST;
-               bfa_dma_addr_set(sge[0].sga, ufm_pbs_pa(ufm, i));
-               bfa_sge_to_be(sge);
-
-               sge[1].sg_len = buf_len;
-               sge[1].flags = BFI_SGE_PGDLEN;
-               sge[1].sga = sga_zero;
-               bfa_sge_to_be(&sge[1]);
-       }
-
-       /**
-        * advance pointer beyond consumed memory
-        */
-       bfa_meminfo_kva(mi) = (u8 *) uf_bp_msg;
-}
-
-static void
-claim_ufs(struct bfa_uf_mod_s *ufm, struct bfa_meminfo_s *mi)
-{
-       u16        i;
-       struct bfa_uf_s   *uf;
-
-       /*
-        * Claim block of memory for UF list
-        */
-       ufm->uf_list = (struct bfa_uf_s *) bfa_meminfo_kva(mi);
-
-       /*
-        * Initialize UFs and queue it in UF free queue
-        */
-       for (i = 0, uf = ufm->uf_list; i < ufm->num_ufs; i++, uf++) {
-               bfa_os_memset(uf, 0, sizeof(struct bfa_uf_s));
-               uf->bfa = ufm->bfa;
-               uf->uf_tag = i;
-               uf->pb_len = sizeof(struct bfa_uf_buf_s);
-               uf->buf_kva = (void *)&ufm->uf_pbs_kva[i];
-               uf->buf_pa = ufm_pbs_pa(ufm, i);
-               list_add_tail(&uf->qe, &ufm->uf_free_q);
-       }
-
-       /**
-        * advance memory pointer
-        */
-       bfa_meminfo_kva(mi) = (u8 *) uf;
-}
-
-static void
-uf_mem_claim(struct bfa_uf_mod_s *ufm, struct bfa_meminfo_s *mi)
-{
-       claim_uf_pbs(ufm, mi);
-       claim_ufs(ufm, mi);
-       claim_uf_post_msgs(ufm, mi);
-}
-
-static void
-bfa_uf_meminfo(struct bfa_iocfc_cfg_s *cfg, u32 *ndm_len, u32 *dm_len)
-{
-       u32        num_ufs = cfg->fwcfg.num_uf_bufs;
-
-       /*
-        * dma-able memory for UF posted bufs
-        */
-       *dm_len += BFA_ROUNDUP((sizeof(struct bfa_uf_buf_s) * num_ufs),
-                                                       BFA_DMA_ALIGN_SZ);
-
-       /*
-        * kernel Virtual memory for UFs and UF buf post msg copies
-        */
-       *ndm_len += sizeof(struct bfa_uf_s) * num_ufs;
-       *ndm_len += sizeof(struct bfi_uf_buf_post_s) * num_ufs;
-}
-
-static void
-bfa_uf_attach(struct bfa_s *bfa, void *bfad, struct bfa_iocfc_cfg_s *cfg,
-                 struct bfa_meminfo_s *meminfo, struct bfa_pcidev_s *pcidev)
-{
-       struct bfa_uf_mod_s *ufm = BFA_UF_MOD(bfa);
-
-       bfa_os_memset(ufm, 0, sizeof(struct bfa_uf_mod_s));
-       ufm->bfa = bfa;
-       ufm->num_ufs = cfg->fwcfg.num_uf_bufs;
-       INIT_LIST_HEAD(&ufm->uf_free_q);
-       INIT_LIST_HEAD(&ufm->uf_posted_q);
-
-       uf_mem_claim(ufm, meminfo);
-}
-
-static void
-bfa_uf_detach(struct bfa_s *bfa)
-{
-}
-
-static struct bfa_uf_s *
-bfa_uf_get(struct bfa_uf_mod_s *uf_mod)
-{
-       struct bfa_uf_s   *uf;
-
-       bfa_q_deq(&uf_mod->uf_free_q, &uf);
-       return uf;
-}
-
-static void
-bfa_uf_put(struct bfa_uf_mod_s *uf_mod, struct bfa_uf_s *uf)
-{
-       list_add_tail(&uf->qe, &uf_mod->uf_free_q);
-}
-
-static bfa_status_t
-bfa_uf_post(struct bfa_uf_mod_s *ufm, struct bfa_uf_s *uf)
-{
-       struct bfi_uf_buf_post_s *uf_post_msg;
-
-       uf_post_msg = bfa_reqq_next(ufm->bfa, BFA_REQQ_FCXP);
-       if (!uf_post_msg)
-               return BFA_STATUS_FAILED;
-
-       bfa_os_memcpy(uf_post_msg, &ufm->uf_buf_posts[uf->uf_tag],
-                     sizeof(struct bfi_uf_buf_post_s));
-       bfa_reqq_produce(ufm->bfa, BFA_REQQ_FCXP);
-
-       bfa_trc(ufm->bfa, uf->uf_tag);
-
-       list_add_tail(&uf->qe, &ufm->uf_posted_q);
-       return BFA_STATUS_OK;
-}
-
-static void
-bfa_uf_post_all(struct bfa_uf_mod_s *uf_mod)
-{
-       struct bfa_uf_s   *uf;
-
-       while ((uf = bfa_uf_get(uf_mod)) != NULL) {
-               if (bfa_uf_post(uf_mod, uf) != BFA_STATUS_OK)
-                       break;
-       }
-}
-
-static void
-uf_recv(struct bfa_s *bfa, struct bfi_uf_frm_rcvd_s *m)
-{
-       struct bfa_uf_mod_s *ufm = BFA_UF_MOD(bfa);
-       u16        uf_tag = m->buf_tag;
-       struct bfa_uf_buf_s *uf_buf = &ufm->uf_pbs_kva[uf_tag];
-       struct bfa_uf_s   *uf = &ufm->uf_list[uf_tag];
-       u8        *buf = &uf_buf->d[0];
-       struct fchs_s         *fchs;
-
-       m->frm_len = bfa_os_ntohs(m->frm_len);
-       m->xfr_len = bfa_os_ntohs(m->xfr_len);
-
-       fchs = (struct fchs_s *) uf_buf;
-
-       list_del(&uf->qe);      /* dequeue from posted queue */
-
-       uf->data_ptr = buf;
-       uf->data_len = m->xfr_len;
-
-       bfa_assert(uf->data_len >= sizeof(struct fchs_s));
-
-       if (uf->data_len == sizeof(struct fchs_s)) {
-               bfa_plog_fchdr(bfa->plog, BFA_PL_MID_HAL_UF, BFA_PL_EID_RX,
-                              uf->data_len, (struct fchs_s *) buf);
-       } else {
-               u32        pld_w0 = *((u32 *) (buf + sizeof(struct fchs_s)));
-               bfa_plog_fchdr_and_pl(bfa->plog, BFA_PL_MID_HAL_UF,
-                                     BFA_PL_EID_RX, uf->data_len,
-                                     (struct fchs_s *) buf, pld_w0);
-       }
-
-       if (bfa->fcs)
-               __bfa_cb_uf_recv(uf, BFA_TRUE);
-       else
-               bfa_cb_queue(bfa, &uf->hcb_qe, __bfa_cb_uf_recv, uf);
-}
-
-static void
-bfa_uf_stop(struct bfa_s *bfa)
-{
-}
-
-static void
-bfa_uf_iocdisable(struct bfa_s *bfa)
-{
-       struct bfa_uf_mod_s *ufm = BFA_UF_MOD(bfa);
-       struct bfa_uf_s   *uf;
-       struct list_head        *qe, *qen;
-
-       list_for_each_safe(qe, qen, &ufm->uf_posted_q) {
-               uf = (struct bfa_uf_s *) qe;
-               list_del(&uf->qe);
-               bfa_uf_put(ufm, uf);
-       }
-}
-
-static void
-bfa_uf_start(struct bfa_s *bfa)
-{
-       bfa_uf_post_all(BFA_UF_MOD(bfa));
-}
-
-
-
-/**
- *  bfa_uf_api
- */
-
-/**
- *             Register handler for all unsolicted recieve frames.
- *
- * @param[in]  bfa             BFA instance
- * @param[in]  ufrecv  receive handler function
- * @param[in]  cbarg   receive handler arg
- */
-void
-bfa_uf_recv_register(struct bfa_s *bfa, bfa_cb_uf_recv_t ufrecv, void *cbarg)
-{
-       struct bfa_uf_mod_s *ufm = BFA_UF_MOD(bfa);
-
-       ufm->ufrecv = ufrecv;
-       ufm->cbarg = cbarg;
-}
-
-/**
- *             Free an unsolicited frame back to BFA.
- *
- * @param[in]          uf              unsolicited frame to be freed
- *
- * @return None
- */
-void
-bfa_uf_free(struct bfa_uf_s *uf)
-{
-       bfa_uf_put(BFA_UF_MOD(uf->bfa), uf);
-       bfa_uf_post_all(BFA_UF_MOD(uf->bfa));
-}
-
-
-
-/**
- *  uf_pub BFA uf module public functions
- */
-
-void
-bfa_uf_isr(struct bfa_s *bfa, struct bfi_msg_s *msg)
-{
-       bfa_trc(bfa, msg->mhdr.msg_id);
-
-       switch (msg->mhdr.msg_id) {
-       case BFI_UF_I2H_FRM_RCVD:
-               uf_recv(bfa, (struct bfi_uf_frm_rcvd_s *) msg);
-               break;
-
-       default:
-               bfa_trc(bfa, msg->mhdr.msg_id);
-               bfa_assert(0);
-       }
-}
-
-
diff --git a/drivers/scsi/bfa/bfa_uf_priv.h b/drivers/scsi/bfa/bfa_uf_priv.h
deleted file mode 100644 (file)
index bcb490f..0000000
+++ /dev/null
@@ -1,47 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-#ifndef __BFA_UF_PRIV_H__
-#define __BFA_UF_PRIV_H__
-
-#include <cs/bfa_sm.h>
-#include <bfa_svc.h>
-#include <bfi/bfi_uf.h>
-
-#define BFA_UF_MIN     (4)
-
-struct bfa_uf_mod_s {
-       struct bfa_s *bfa;              /*  back pointer to BFA */
-       struct bfa_uf_s *uf_list;       /*  array of UFs */
-       u16     num_ufs;        /*  num unsolicited rx frames */
-       struct list_head        uf_free_q;      /*  free UFs */
-       struct list_head        uf_posted_q;    /*  UFs posted to IOC */
-       struct bfa_uf_buf_s *uf_pbs_kva;        /*  list UF bufs request pld */
-       u64     uf_pbs_pa;      /*  phy addr for UF bufs */
-       struct bfi_uf_buf_post_s *uf_buf_posts;
-                                       /*  pre-built UF post msgs */
-       bfa_cb_uf_recv_t ufrecv;        /*  uf recv handler function */
-       void            *cbarg;         /*  uf receive handler arg */
-};
-
-#define BFA_UF_MOD(__bfa)      (&(__bfa)->modules.uf_mod)
-
-#define ufm_pbs_pa(_ufmod, _uftag)     \
-       ((_ufmod)->uf_pbs_pa + sizeof(struct bfa_uf_buf_s) * (_uftag))
-
-void   bfa_uf_isr(struct bfa_s *bfa, struct bfi_msg_s *msg);
-
-#endif /* __BFA_UF_PRIV_H__ */
index ca04cc9d332f07e4a8e41244d1af26cfa8f2263e..4d8784e06e142a8d0dd4d178cd947dbca6c17ff9 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
  * All rights reserved
  * www.brocade.com
  *
 /**
  *  bfad.c Linux driver PCI interface module.
  */
-
-#include <linux/slab.h>
 #include <linux/module.h>
 #include <linux/kthread.h>
+#include <linux/errno.h>
+#include <linux/sched.h>
+#include <linux/init.h>
+#include <linux/fs.h>
+#include <linux/pci.h>
+#include <linux/firmware.h>
+#include <asm/uaccess.h>
+#include <asm/fcntl.h>
+
 #include "bfad_drv.h"
 #include "bfad_im.h"
-#include "bfad_tm.h"
-#include "bfad_ipfc.h"
-#include "bfad_trcmod.h"
-#include <fcb/bfa_fcb_vf.h>
-#include <fcb/bfa_fcb_rport.h>
-#include <fcb/bfa_fcb_port.h>
-#include <fcb/bfa_fcb.h>
+#include "bfa_fcs.h"
+#include "bfa_os_inc.h"
+#include "bfa_defs.h"
+#include "bfa.h"
 
 BFA_TRC_FILE(LDRV, BFAD);
 DEFINE_MUTEX(bfad_mutex);
 LIST_HEAD(bfad_list);
-static int      bfad_inst;
-int bfad_supported_fc4s;
-
-static char     *host_name;
-static char     *os_name;
-static char     *os_patch;
-static int      num_rports;
-static int      num_ios;
-static int      num_tms;
-static int      num_fcxps;
-static int      num_ufbufs;
-static int      reqq_size;
-static int      rspq_size;
-static int      num_sgpgs;
-static int      rport_del_timeout = BFA_FCS_RPORT_DEF_DEL_TIMEOUT;
-static int      bfa_io_max_sge = BFAD_IO_MAX_SGE;
-static int      log_level = BFA_LOG_WARNING;
-static int      ioc_auto_recover = BFA_TRUE;
-static int      ipfc_enable = BFA_FALSE;
-static int     fdmi_enable = BFA_TRUE;
-int            bfa_lun_queue_depth = BFAD_LUN_QUEUE_DEPTH;
-int            bfa_linkup_delay = -1;
+
+static int     bfad_inst;
+static int      num_sgpgs_parm;
+int            supported_fc4s;
+char           *host_name, *os_name, *os_patch;
+int            num_rports, num_ios, num_tms;
+int            num_fcxps, num_ufbufs;
+int            reqq_size, rspq_size, num_sgpgs;
+int            rport_del_timeout = BFA_FCS_RPORT_DEF_DEL_TIMEOUT;
+int            bfa_lun_queue_depth = BFAD_LUN_QUEUE_DEPTH;
+int            bfa_io_max_sge = BFAD_IO_MAX_SGE;
+int            log_level = 3; /* WARNING log level */
+int            ioc_auto_recover = BFA_TRUE;
+int            bfa_linkup_delay = -1;
+int            fdmi_enable = BFA_TRUE;
+int            pcie_max_read_reqsz;
 int            bfa_debugfs_enable = 1;
+int            msix_disable_cb = 0, msix_disable_ct = 0;
+
+u32    bfi_image_ct_fc_size, bfi_image_ct_cna_size, bfi_image_cb_fc_size;
+u32     *bfi_image_ct_fc, *bfi_image_ct_cna, *bfi_image_cb_fc;
+
+const char *msix_name_ct[] = {
+       "cpe0", "cpe1", "cpe2", "cpe3",
+       "rme0", "rme1", "rme2", "rme3",
+       "ctrl" };
+
+const char *msix_name_cb[] = {
+       "cpe0", "cpe1", "cpe2", "cpe3",
+       "rme0", "rme1", "rme2", "rme3",
+       "eemc", "elpu0", "elpu1", "epss", "mlpu" };
+
+MODULE_FIRMWARE(BFAD_FW_FILE_CT_FC);
+MODULE_FIRMWARE(BFAD_FW_FILE_CT_CNA);
+MODULE_FIRMWARE(BFAD_FW_FILE_CB_FC);
 
 module_param(os_name, charp, S_IRUGO | S_IWUSR);
 MODULE_PARM_DESC(os_name, "OS name of the hba host machine");
@@ -66,8 +82,8 @@ MODULE_PARM_DESC(os_patch, "OS patch level of the hba host machine");
 module_param(host_name, charp, S_IRUGO | S_IWUSR);
 MODULE_PARM_DESC(host_name, "Hostname of the hba host machine");
 module_param(num_rports, int, S_IRUGO | S_IWUSR);
-MODULE_PARM_DESC(num_rports, "Max number of rports supported per port"
-               (physical/logical), default=1024");
+MODULE_PARM_DESC(num_rports, "Max number of rports supported per port "
+                               "(physical/logical), default=1024");
 module_param(num_ios, int, S_IRUGO | S_IWUSR);
 MODULE_PARM_DESC(num_ios, "Max number of ioim requests, default=2000");
 module_param(num_tms, int, S_IRUGO | S_IWUSR);
@@ -75,120 +91,277 @@ MODULE_PARM_DESC(num_tms, "Max number of task im requests, default=128");
 module_param(num_fcxps, int, S_IRUGO | S_IWUSR);
 MODULE_PARM_DESC(num_fcxps, "Max number of fcxp requests, default=64");
 module_param(num_ufbufs, int, S_IRUGO | S_IWUSR);
-MODULE_PARM_DESC(num_ufbufs, "Max number of unsolicited frame buffers,"
-               " default=64");
+MODULE_PARM_DESC(num_ufbufs, "Max number of unsolicited frame "
+                               "buffers, default=64");
 module_param(reqq_size, int, S_IRUGO | S_IWUSR);
-MODULE_PARM_DESC(reqq_size, "Max number of request queue elements,"
-               default=256");
+MODULE_PARM_DESC(reqq_size, "Max number of request queue elements, "
+                               "default=256");
 module_param(rspq_size, int, S_IRUGO | S_IWUSR);
-MODULE_PARM_DESC(rspq_size, "Max number of response queue elements,"
-               default=64");
+MODULE_PARM_DESC(rspq_size, "Max number of response queue elements, "
+                               "default=64");
 module_param(num_sgpgs, int, S_IRUGO | S_IWUSR);
 MODULE_PARM_DESC(num_sgpgs, "Number of scatter/gather pages, default=2048");
 module_param(rport_del_timeout, int, S_IRUGO | S_IWUSR);
-MODULE_PARM_DESC(rport_del_timeout, "Rport delete timeout, default=90 secs,"
-               Range[>0]");
+MODULE_PARM_DESC(rport_del_timeout, "Rport delete timeout, default=90 secs, "
+                                       "Range[>0]");
 module_param(bfa_lun_queue_depth, int, S_IRUGO | S_IWUSR);
-MODULE_PARM_DESC(bfa_lun_queue_depth, "Lun queue depth, default=32,"
-               " Range[>0]");
+MODULE_PARM_DESC(bfa_lun_queue_depth, "Lun queue depth, default=32, Range[>0]");
 module_param(bfa_io_max_sge, int, S_IRUGO | S_IWUSR);
 MODULE_PARM_DESC(bfa_io_max_sge, "Max io scatter/gather elements, default=255");
 module_param(log_level, int, S_IRUGO | S_IWUSR);
-MODULE_PARM_DESC(log_level, "Driver log level, default=3,"
-               Range[Critical:1|Error:2|Warning:3|Info:4]");
+MODULE_PARM_DESC(log_level, "Driver log level, default=3, "
+                               "Range[Critical:1|Error:2|Warning:3|Info:4]");
 module_param(ioc_auto_recover, int, S_IRUGO | S_IWUSR);
-MODULE_PARM_DESC(ioc_auto_recover, "IOC auto recovery, default=1,"
-               " Range[off:0|on:1]");
-module_param(ipfc_enable, int, S_IRUGO | S_IWUSR);
-MODULE_PARM_DESC(ipfc_enable, "Enable IPoFC, default=0, Range[off:0|on:1]");
+MODULE_PARM_DESC(ioc_auto_recover, "IOC auto recovery, default=1, "
+                               "Range[off:0|on:1]");
 module_param(bfa_linkup_delay, int, S_IRUGO | S_IWUSR);
-MODULE_PARM_DESC(bfa_linkup_delay, "Link up delay, default=30 secs for boot"
-               " port. Otherwise Range[>0]");
+MODULE_PARM_DESC(bfa_linkup_delay, "Link up delay, default=30 secs for "
+                       "boot port. Otherwise 10 secs in RHEL4 & 0 for "
+                       "[RHEL5, SLES10, ESX40] Range[>0]");
+module_param(msix_disable_cb, int, S_IRUGO | S_IWUSR);
+MODULE_PARM_DESC(msix_disable_cb, "Disable Message Signaled Interrupts "
+                       "for Brocade-415/425/815/825 cards, default=0, "
+                       " Range[false:0|true:1]");
+module_param(msix_disable_ct, int, S_IRUGO | S_IWUSR);
+MODULE_PARM_DESC(msix_disable_ct, "Disable Message Signaled Interrupts "
+                       "if possible for Brocade-1010/1020/804/1007/902/1741 "
+                       "cards, default=0, Range[false:0|true:1]");
 module_param(fdmi_enable, int, S_IRUGO | S_IWUSR);
-MODULE_PARM_DESC(fdmi_enable, "Enables fdmi registration, default=1,"
-               " Range[false:0|true:1]");
+MODULE_PARM_DESC(fdmi_enable, "Enables fdmi registration, default=1, "
+                               "Range[false:0|true:1]");
+module_param(pcie_max_read_reqsz, int, S_IRUGO | S_IWUSR);
+MODULE_PARM_DESC(pcie_max_read_reqsz, "PCIe max read request size, default=0 "
+               "(use system setting), Range[128|256|512|1024|2048|4096]");
 module_param(bfa_debugfs_enable, int, S_IRUGO | S_IWUSR);
 MODULE_PARM_DESC(bfa_debugfs_enable, "Enables debugfs feature, default=1,"
                " Range[false:0|true:1]");
 
-/*
- * Stores the module parm num_sgpgs value;
- * used to reset for bfad next instance.
+static void
+bfad_sm_uninit(struct bfad_s *bfad, enum bfad_sm_event event);
+static void
+bfad_sm_created(struct bfad_s *bfad, enum bfad_sm_event event);
+static void
+bfad_sm_initializing(struct bfad_s *bfad, enum bfad_sm_event event);
+static void
+bfad_sm_operational(struct bfad_s *bfad, enum bfad_sm_event event);
+static void
+bfad_sm_stopping(struct bfad_s *bfad, enum bfad_sm_event event);
+static void
+bfad_sm_failed(struct bfad_s *bfad, enum bfad_sm_event event);
+static void
+bfad_sm_fcs_exit(struct bfad_s *bfad, enum bfad_sm_event event);
+
+/**
+ * Beginning state for the driver instance, awaiting the pci_probe event
  */
-static int num_sgpgs_parm;
+static void
+bfad_sm_uninit(struct bfad_s *bfad, enum bfad_sm_event event)
+{
+       bfa_trc(bfad, event);
+
+       switch (event) {
+       case BFAD_E_CREATE:
+               bfa_sm_set_state(bfad, bfad_sm_created);
+               bfad->bfad_tsk = kthread_create(bfad_worker, (void *) bfad,
+                                               "%s", "bfad_worker");
+               if (IS_ERR(bfad->bfad_tsk)) {
+                       printk(KERN_INFO "bfad[%d]: Kernel thread "
+                               "creation failed!\n", bfad->inst_no);
+                       bfa_sm_send_event(bfad, BFAD_E_KTHREAD_CREATE_FAILED);
+               }
+               bfa_sm_send_event(bfad, BFAD_E_INIT);
+               break;
+
+       case BFAD_E_STOP:
+               /* Ignore stop; already in uninit */
+               break;
+
+       default:
+               bfa_sm_fault(bfad, event);
+       }
+}
 
-static bfa_status_t
-bfad_fc4_probe(struct bfad_s *bfad)
+/**
+ * Driver Instance is created, awaiting event INIT to initialize the bfad
+ */
+static void
+bfad_sm_created(struct bfad_s *bfad, enum bfad_sm_event event)
 {
-       int             rc;
+       unsigned long flags;
 
-       rc = bfad_im_probe(bfad);
-       if (rc != BFA_STATUS_OK)
-               goto ext;
+       bfa_trc(bfad, event);
 
-       bfad_tm_probe(bfad);
+       switch (event) {
+       case BFAD_E_INIT:
+               bfa_sm_set_state(bfad, bfad_sm_initializing);
 
-       if (ipfc_enable)
-               bfad_ipfc_probe(bfad);
+               init_completion(&bfad->comp);
 
-       bfad->bfad_flags |= BFAD_FC4_PROBE_DONE;
-ext:
-       return rc;
+               /* Enable Interrupt and wait bfa_init completion */
+               if (bfad_setup_intr(bfad)) {
+                       printk(KERN_WARNING "bfad%d: bfad_setup_intr failed\n",
+                                       bfad->inst_no);
+                       bfa_sm_send_event(bfad, BFAD_E_INTR_INIT_FAILED);
+                       break;
+               }
+
+               spin_lock_irqsave(&bfad->bfad_lock, flags);
+               bfa_init(&bfad->bfa);
+               spin_unlock_irqrestore(&bfad->bfad_lock, flags);
+
+               /* Set up interrupt handler for each vectors */
+               if ((bfad->bfad_flags & BFAD_MSIX_ON) &&
+                       bfad_install_msix_handler(bfad)) {
+                       printk(KERN_WARNING "%s: install_msix failed, bfad%d\n",
+                               __func__, bfad->inst_no);
+               }
+
+               bfad_init_timer(bfad);
+
+               wait_for_completion(&bfad->comp);
+
+               if ((bfad->bfad_flags & BFAD_HAL_INIT_DONE)) {
+                       bfa_sm_send_event(bfad, BFAD_E_INIT_SUCCESS);
+               } else {
+                       bfad->bfad_flags |= BFAD_HAL_INIT_FAIL;
+                       bfa_sm_send_event(bfad, BFAD_E_INIT_FAILED);
+               }
+
+               break;
+
+       case BFAD_E_KTHREAD_CREATE_FAILED:
+               bfa_sm_set_state(bfad, bfad_sm_uninit);
+               break;
+
+       default:
+               bfa_sm_fault(bfad, event);
+       }
 }
 
 static void
-bfad_fc4_probe_undo(struct bfad_s *bfad)
+bfad_sm_initializing(struct bfad_s *bfad, enum bfad_sm_event event)
 {
-       bfad_im_probe_undo(bfad);
-       bfad_tm_probe_undo(bfad);
-       if (ipfc_enable)
-               bfad_ipfc_probe_undo(bfad);
-       bfad->bfad_flags &= ~BFAD_FC4_PROBE_DONE;
+       int     retval;
+       unsigned long   flags;
+
+       bfa_trc(bfad, event);
+
+       switch (event) {
+       case BFAD_E_INIT_SUCCESS:
+               kthread_stop(bfad->bfad_tsk);
+               spin_lock_irqsave(&bfad->bfad_lock, flags);
+               bfad->bfad_tsk = NULL;
+               spin_unlock_irqrestore(&bfad->bfad_lock, flags);
+
+               retval = bfad_start_ops(bfad);
+               if (retval != BFA_STATUS_OK)
+                       break;
+               bfa_sm_set_state(bfad, bfad_sm_operational);
+               break;
+
+       case BFAD_E_INTR_INIT_FAILED:
+               bfa_sm_set_state(bfad, bfad_sm_uninit);
+               kthread_stop(bfad->bfad_tsk);
+               spin_lock_irqsave(&bfad->bfad_lock, flags);
+               bfad->bfad_tsk = NULL;
+               spin_unlock_irqrestore(&bfad->bfad_lock, flags);
+               break;
+
+       case BFAD_E_INIT_FAILED:
+               bfa_sm_set_state(bfad, bfad_sm_failed);
+               break;
+       default:
+               bfa_sm_fault(bfad, event);
+       }
 }
 
 static void
-bfad_fc4_probe_post(struct bfad_s *bfad)
+bfad_sm_failed(struct bfad_s *bfad, enum bfad_sm_event event)
 {
-       if (bfad->im)
-               bfad_im_probe_post(bfad->im);
+       int     retval;
 
-       bfad_tm_probe_post(bfad);
-       if (ipfc_enable)
-               bfad_ipfc_probe_post(bfad);
+       bfa_trc(bfad, event);
+
+       switch (event) {
+       case BFAD_E_INIT_SUCCESS:
+               retval = bfad_start_ops(bfad);
+               if (retval != BFA_STATUS_OK)
+                       break;
+               bfa_sm_set_state(bfad, bfad_sm_operational);
+               break;
+
+       case BFAD_E_STOP:
+               if (bfad->bfad_flags & BFAD_CFG_PPORT_DONE)
+                       bfad_uncfg_pport(bfad);
+               if (bfad->bfad_flags & BFAD_FC4_PROBE_DONE) {
+                       bfad_im_probe_undo(bfad);
+                       bfad->bfad_flags &= ~BFAD_FC4_PROBE_DONE;
+               }
+               bfad_stop(bfad);
+               break;
+
+       case BFAD_E_EXIT_COMP:
+               bfa_sm_set_state(bfad, bfad_sm_uninit);
+               bfad_remove_intr(bfad);
+               del_timer_sync(&bfad->hal_tmo);
+               break;
+
+       default:
+               bfa_sm_fault(bfad, event);
+       }
 }
 
-static bfa_status_t
-bfad_fc4_port_new(struct bfad_s *bfad, struct bfad_port_s *port, int roles)
+static void
+bfad_sm_operational(struct bfad_s *bfad, enum bfad_sm_event event)
 {
-       int             rc = BFA_STATUS_FAILED;
+       bfa_trc(bfad, event);
 
-       if (roles & BFA_PORT_ROLE_FCP_IM)
-               rc = bfad_im_port_new(bfad, port);
-       if (rc != BFA_STATUS_OK)
-               goto ext;
+       switch (event) {
+       case BFAD_E_STOP:
+               bfa_sm_set_state(bfad, bfad_sm_fcs_exit);
+               bfad_fcs_stop(bfad);
+               break;
 
-       if (roles & BFA_PORT_ROLE_FCP_TM)
-               rc = bfad_tm_port_new(bfad, port);
-       if (rc != BFA_STATUS_OK)
-               goto ext;
+       default:
+               bfa_sm_fault(bfad, event);
+       }
+}
 
-       if ((roles & BFA_PORT_ROLE_FCP_IPFC) && ipfc_enable)
-               rc = bfad_ipfc_port_new(bfad, port, port->pvb_type);
-ext:
-       return rc;
+static void
+bfad_sm_fcs_exit(struct bfad_s *bfad, enum bfad_sm_event event)
+{
+       bfa_trc(bfad, event);
+
+       switch (event) {
+       case BFAD_E_FCS_EXIT_COMP:
+               bfa_sm_set_state(bfad, bfad_sm_stopping);
+               bfad_stop(bfad);
+               break;
+
+       default:
+               bfa_sm_fault(bfad, event);
+       }
 }
 
 static void
-bfad_fc4_port_delete(struct bfad_s *bfad, struct bfad_port_s *port, int roles)
+bfad_sm_stopping(struct bfad_s *bfad, enum bfad_sm_event event)
 {
-       if (roles & BFA_PORT_ROLE_FCP_IM)
-               bfad_im_port_delete(bfad, port);
+       bfa_trc(bfad, event);
 
-       if (roles & BFA_PORT_ROLE_FCP_TM)
-               bfad_tm_port_delete(bfad, port);
+       switch (event) {
+       case BFAD_E_EXIT_COMP:
+               bfa_sm_set_state(bfad, bfad_sm_uninit);
+               bfad_remove_intr(bfad);
+               del_timer_sync(&bfad->hal_tmo);
+               bfad_im_probe_undo(bfad);
+               bfad->bfad_flags &= ~BFAD_FC4_PROBE_DONE;
+               bfad_uncfg_pport(bfad);
+               break;
 
-       if ((roles & BFA_PORT_ROLE_FCP_IPFC) && ipfc_enable)
-               bfad_ipfc_port_delete(bfad, port);
+       default:
+               bfa_sm_fault(bfad, event);
+               break;
+       }
 }
 
 /**
@@ -209,12 +382,13 @@ bfad_hcb_comp(void *arg, bfa_status_t status)
 void
 bfa_cb_init(void *drv, bfa_status_t init_status)
 {
-       struct bfad_s  *bfad = drv;
+       struct bfad_s         *bfad = drv;
 
        if (init_status == BFA_STATUS_OK) {
                bfad->bfad_flags |= BFAD_HAL_INIT_DONE;
 
-               /* If BFAD_HAL_INIT_FAIL flag is set:
+               /*
+                * If BFAD_HAL_INIT_FAIL flag is set:
                 * Wake up the kernel thread to start
                 * the bfad operations after HAL init done
                 */
@@ -227,26 +401,16 @@ bfa_cb_init(void *drv, bfa_status_t init_status)
        complete(&bfad->comp);
 }
 
-
-
 /**
  *  BFA_FCS callbacks
  */
-static struct bfad_port_s *
-bfad_get_drv_port(struct bfad_s *bfad, struct bfad_vf_s *vf_drv,
-                 struct bfad_vport_s *vp_drv)
-{
-       return (vp_drv) ? (&(vp_drv)->drv_port)
-               : ((vf_drv) ? (&(vf_drv)->base_port) : (&(bfad)->pport));
-}
-
 struct bfad_port_s *
-bfa_fcb_port_new(struct bfad_s *bfad, struct bfa_fcs_port_s *port,
-                enum bfa_port_role roles, struct bfad_vf_s *vf_drv,
+bfa_fcb_lport_new(struct bfad_s *bfad, struct bfa_fcs_lport_s *port,
+                enum bfa_lport_role roles, struct bfad_vf_s *vf_drv,
                 struct bfad_vport_s *vp_drv)
 {
-       bfa_status_t    rc;
-       struct bfad_port_s *port_drv;
+       bfa_status_t    rc;
+       struct bfad_port_s    *port_drv;
 
        if (!vp_drv && !vf_drv) {
                port_drv = &bfad->pport;
@@ -264,71 +428,32 @@ bfa_fcb_port_new(struct bfad_s *bfad, struct bfa_fcs_port_s *port,
 
        port_drv->fcs_port = port;
        port_drv->roles = roles;
-       rc = bfad_fc4_port_new(bfad, port_drv, roles);
-       if (rc != BFA_STATUS_OK) {
-               bfad_fc4_port_delete(bfad, port_drv, roles);
-               port_drv = NULL;
+
+       if (roles & BFA_LPORT_ROLE_FCP_IM) {
+               rc = bfad_im_port_new(bfad, port_drv);
+               if (rc != BFA_STATUS_OK) {
+                       bfad_im_port_delete(bfad, port_drv);
+                       port_drv = NULL;
+               }
        }
 
        return port_drv;
 }
 
 void
-bfa_fcb_port_delete(struct bfad_s *bfad, enum bfa_port_role roles,
+bfa_fcb_lport_delete(struct bfad_s *bfad, enum bfa_lport_role roles,
                    struct bfad_vf_s *vf_drv, struct bfad_vport_s *vp_drv)
 {
-       struct bfad_port_s *port_drv;
+       struct bfad_port_s    *port_drv;
 
-       /*
-        * this will be only called from rmmod context
-        */
+       /* this will be only called from rmmod context */
        if (vp_drv && !vp_drv->comp_del) {
-               port_drv = bfad_get_drv_port(bfad, vf_drv, vp_drv);
+               port_drv = (vp_drv) ? (&(vp_drv)->drv_port) :
+                               ((vf_drv) ? (&(vf_drv)->base_port) :
+                               (&(bfad)->pport));
                bfa_trc(bfad, roles);
-               bfad_fc4_port_delete(bfad, port_drv, roles);
-       }
-}
-
-void
-bfa_fcb_port_online(struct bfad_s *bfad, enum bfa_port_role roles,
-                   struct bfad_vf_s *vf_drv, struct bfad_vport_s *vp_drv)
-{
-       struct bfad_port_s *port_drv = bfad_get_drv_port(bfad, vf_drv, vp_drv);
-
-       if (roles & BFA_PORT_ROLE_FCP_IM)
-               bfad_im_port_online(bfad, port_drv);
-
-       if (roles & BFA_PORT_ROLE_FCP_TM)
-               bfad_tm_port_online(bfad, port_drv);
-
-       if ((roles & BFA_PORT_ROLE_FCP_IPFC) && ipfc_enable)
-               bfad_ipfc_port_online(bfad, port_drv);
-
-       bfad->bfad_flags |= BFAD_PORT_ONLINE;
-}
-
-void
-bfa_fcb_port_offline(struct bfad_s *bfad, enum bfa_port_role roles,
-                    struct bfad_vf_s *vf_drv, struct bfad_vport_s *vp_drv)
-{
-       struct bfad_port_s *port_drv = bfad_get_drv_port(bfad, vf_drv, vp_drv);
-
-       if (roles & BFA_PORT_ROLE_FCP_IM)
-               bfad_im_port_offline(bfad, port_drv);
-
-       if (roles & BFA_PORT_ROLE_FCP_TM)
-               bfad_tm_port_offline(bfad, port_drv);
-
-       if ((roles & BFA_PORT_ROLE_FCP_IPFC) && ipfc_enable)
-               bfad_ipfc_port_offline(bfad, port_drv);
-}
-
-void
-bfa_fcb_vport_delete(struct bfad_vport_s *vport_drv)
-{
-       if (vport_drv->comp_del) {
-               complete(vport_drv->comp_del);
-               return;
+               if (roles & BFA_LPORT_ROLE_FCP_IM)
+                       bfad_im_port_delete(bfad, port_drv);
        }
 }
 
@@ -339,7 +464,7 @@ bfa_status_t
 bfa_fcb_rport_alloc(struct bfad_s *bfad, struct bfa_fcs_rport_s **rport,
                    struct bfad_rport_s **rport_drv)
 {
-       bfa_status_t    rc = BFA_STATUS_OK;
+       bfa_status_t    rc = BFA_STATUS_OK;
 
        *rport_drv = kzalloc(sizeof(struct bfad_rport_s), GFP_ATOMIC);
        if (*rport_drv == NULL) {
@@ -354,35 +479,43 @@ ext:
 }
 
 /**
- * @brief
  * FCS PBC VPORT Create
  */
 void
 bfa_fcb_pbc_vport_create(struct bfad_s *bfad, struct bfi_pbc_vport_s pbc_vport)
 {
 
-       struct bfad_pcfg_s *pcfg;
+       struct bfa_lport_cfg_s port_cfg = {0};
+       struct bfad_vport_s   *vport;
+       int rc;
 
-       pcfg = kzalloc(sizeof(struct bfad_pcfg_s), GFP_ATOMIC);
-       if (!pcfg) {
+       vport = kzalloc(sizeof(struct bfad_vport_s), GFP_KERNEL);
+       if (!vport) {
                bfa_trc(bfad, 0);
                return;
        }
 
-       pcfg->port_cfg.roles = BFA_PORT_ROLE_FCP_IM;
-       pcfg->port_cfg.pwwn = pbc_vport.vp_pwwn;
-       pcfg->port_cfg.nwwn = pbc_vport.vp_nwwn;
-       pcfg->port_cfg.preboot_vp  = BFA_TRUE;
+       vport->drv_port.bfad = bfad;
+       port_cfg.roles = BFA_LPORT_ROLE_FCP_IM;
+       port_cfg.pwwn = pbc_vport.vp_pwwn;
+       port_cfg.nwwn = pbc_vport.vp_nwwn;
+       port_cfg.preboot_vp  = BFA_TRUE;
+
+       rc = bfa_fcs_pbc_vport_create(&vport->fcs_vport, &bfad->bfa_fcs, 0,
+                                 &port_cfg, vport);
 
-       list_add_tail(&pcfg->list_entry, &bfad->pbc_pcfg_list);
+       if (rc != BFA_STATUS_OK) {
+               bfa_trc(bfad, 0);
+               return;
+       }
 
-       return;
+       list_add_tail(&vport->list_entry, &bfad->pbc_vport_list);
 }
 
 void
 bfad_hal_mem_release(struct bfad_s *bfad)
 {
-       int             i;
+       int             i;
        struct bfa_meminfo_s *hal_meminfo = &bfad->meminfo;
        struct bfa_mem_elem_s *meminfo_elem;
 
@@ -395,9 +528,9 @@ bfad_hal_mem_release(struct bfad_s *bfad)
                                break;
                        case BFA_MEM_TYPE_DMA:
                                dma_free_coherent(&bfad->pcidev->dev,
-                                               meminfo_elem->mem_len,
-                                               meminfo_elem->kva,
-                                               (dma_addr_t) meminfo_elem->dma);
+                                       meminfo_elem->mem_len,
+                                       meminfo_elem->kva,
+                                       (dma_addr_t) meminfo_elem->dma);
                                break;
                        default:
                                bfa_assert(0);
@@ -434,27 +567,27 @@ bfad_update_hal_cfg(struct bfa_iocfc_cfg_s *bfa_cfg)
         * otherwise, the default values will be shown as 0 in sysfs
         */
        num_rports = bfa_cfg->fwcfg.num_rports;
-       num_ios    = bfa_cfg->fwcfg.num_ioim_reqs;
-       num_tms    = bfa_cfg->fwcfg.num_tskim_reqs;
-       num_fcxps  = bfa_cfg->fwcfg.num_fcxp_reqs;
+       num_ios = bfa_cfg->fwcfg.num_ioim_reqs;
+       num_tms = bfa_cfg->fwcfg.num_tskim_reqs;
+       num_fcxps = bfa_cfg->fwcfg.num_fcxp_reqs;
        num_ufbufs = bfa_cfg->fwcfg.num_uf_bufs;
-       reqq_size  = bfa_cfg->drvcfg.num_reqq_elems;
-       rspq_size  = bfa_cfg->drvcfg.num_rspq_elems;
-       num_sgpgs  = bfa_cfg->drvcfg.num_sgpgs;
+       reqq_size = bfa_cfg->drvcfg.num_reqq_elems;
+       rspq_size = bfa_cfg->drvcfg.num_rspq_elems;
+       num_sgpgs = bfa_cfg->drvcfg.num_sgpgs;
 }
 
 bfa_status_t
 bfad_hal_mem_alloc(struct bfad_s *bfad)
 {
+       int             i;
        struct bfa_meminfo_s *hal_meminfo = &bfad->meminfo;
        struct bfa_mem_elem_s *meminfo_elem;
-       bfa_status_t    rc = BFA_STATUS_OK;
-       dma_addr_t      phys_addr;
-       int             retry_count = 0;
-       int             reset_value = 1;
-       int             min_num_sgpgs = 512;
-       void           *kva;
-       int             i;
+       dma_addr_t      phys_addr;
+       void           *kva;
+       bfa_status_t    rc = BFA_STATUS_OK;
+       int retry_count = 0;
+       int reset_value = 1;
+       int min_num_sgpgs = 512;
 
        bfa_cfg_get_default(&bfad->ioc_cfg);
 
@@ -478,8 +611,7 @@ retry:
                        break;
                case BFA_MEM_TYPE_DMA:
                        kva = dma_alloc_coherent(&bfad->pcidev->dev,
-                                       meminfo_elem->mem_len,
-                                       &phys_addr, GFP_KERNEL);
+                               meminfo_elem->mem_len, &phys_addr, GFP_KERNEL);
                        if (kva == NULL) {
                                bfad_hal_mem_release(bfad);
                                /*
@@ -487,14 +619,14 @@ retry:
                                 * num_sgpages try with half the value.
                                 */
                                if (num_sgpgs > min_num_sgpgs) {
-                                       printk(KERN_INFO "bfad[%d]: memory"
-                                               " allocation failed with"
-                                               " num_sgpgs: %d\n",
+                                       printk(KERN_INFO
+                                       "bfad[%d]: memory allocation failed"
+                                       " with num_sgpgs: %d\n",
                                                bfad->inst_no, num_sgpgs);
                                        nextLowerInt(&num_sgpgs);
-                                       printk(KERN_INFO "bfad[%d]: trying to"
-                                               " allocate memory with"
-                                               " num_sgpgs: %d\n",
+                                       printk(KERN_INFO
+                                       "bfad[%d]: trying to allocate memory"
+                                       " with num_sgpgs: %d\n",
                                                bfad->inst_no, num_sgpgs);
                                        retry_count++;
                                        goto retry;
@@ -536,11 +668,11 @@ ext:
  */
 bfa_status_t
 bfad_vport_create(struct bfad_s *bfad, u16 vf_id,
-                       struct bfa_port_cfg_s *port_cfg, struct device *dev)
+                 struct bfa_lport_cfg_s *port_cfg, struct device *dev)
 {
-       struct bfad_vport_s *vport;
-       int rc = BFA_STATUS_OK;
-       unsigned long   flags;
+       struct bfad_vport_s   *vport;
+       int             rc = BFA_STATUS_OK;
+       unsigned long   flags;
        struct completion fcomp;
 
        vport = kzalloc(sizeof(struct bfad_vport_s), GFP_KERNEL);
@@ -551,18 +683,14 @@ bfad_vport_create(struct bfad_s *bfad, u16 vf_id,
 
        vport->drv_port.bfad = bfad;
        spin_lock_irqsave(&bfad->bfad_lock, flags);
-       if (port_cfg->preboot_vp == BFA_TRUE)
-               rc = bfa_fcs_pbc_vport_create(&vport->fcs_vport,
-                               &bfad->bfa_fcs, vf_id, port_cfg, vport);
-       else
-               rc = bfa_fcs_vport_create(&vport->fcs_vport,
-                               &bfad->bfa_fcs, vf_id, port_cfg, vport);
+       rc = bfa_fcs_vport_create(&vport->fcs_vport, &bfad->bfa_fcs, vf_id,
+                                 port_cfg, vport);
        spin_unlock_irqrestore(&bfad->bfad_lock, flags);
 
        if (rc != BFA_STATUS_OK)
                goto ext_free_vport;
 
-       if (port_cfg->roles & BFA_PORT_ROLE_FCP_IM) {
+       if (port_cfg->roles & BFA_LPORT_ROLE_FCP_IM) {
                rc = bfad_im_scsi_host_alloc(bfad, vport->drv_port.im_port,
                                                        dev);
                if (rc != BFA_STATUS_OK)
@@ -593,10 +721,10 @@ ext:
  */
 bfa_status_t
 bfad_vf_create(struct bfad_s *bfad, u16 vf_id,
-              struct bfa_port_cfg_s *port_cfg)
+              struct bfa_lport_cfg_s *port_cfg)
 {
-       struct bfad_vf_s *vf;
-       int             rc = BFA_STATUS_OK;
+       struct bfad_vf_s      *vf;
+       int             rc = BFA_STATUS_OK;
 
        vf = kzalloc(sizeof(struct bfad_vf_s), GFP_KERNEL);
        if (!vf) {
@@ -615,9 +743,9 @@ ext:
 void
 bfad_bfa_tmo(unsigned long data)
 {
-       struct bfad_s  *bfad = (struct bfad_s *)data;
-       unsigned long   flags;
-       struct list_head  doneq;
+       struct bfad_s         *bfad = (struct bfad_s *) data;
+       unsigned long   flags;
+       struct list_head               doneq;
 
        spin_lock_irqsave(&bfad->bfad_lock, flags);
 
@@ -633,7 +761,8 @@ bfad_bfa_tmo(unsigned long data)
                spin_unlock_irqrestore(&bfad->bfad_lock, flags);
        }
 
-       mod_timer(&bfad->hal_tmo, jiffies + msecs_to_jiffies(BFA_TIMER_FREQ));
+       mod_timer(&bfad->hal_tmo,
+                 jiffies + msecs_to_jiffies(BFA_TIMER_FREQ));
 }
 
 void
@@ -643,16 +772,17 @@ bfad_init_timer(struct bfad_s *bfad)
        bfad->hal_tmo.function = bfad_bfa_tmo;
        bfad->hal_tmo.data = (unsigned long)bfad;
 
-       mod_timer(&bfad->hal_tmo, jiffies + msecs_to_jiffies(BFA_TIMER_FREQ));
+       mod_timer(&bfad->hal_tmo,
+                 jiffies + msecs_to_jiffies(BFA_TIMER_FREQ));
 }
 
 int
 bfad_pci_init(struct pci_dev *pdev, struct bfad_s *bfad)
 {
-       int             rc = -ENODEV;
+       int             rc = -ENODEV;
 
        if (pci_enable_device(pdev)) {
-               BFA_PRINTF(BFA_ERR, "pci_enable_device fail %p\n", pdev);
+               printk(KERN_ERR "pci_enable_device fail %p\n", pdev);
                goto out;
        }
 
@@ -664,14 +794,14 @@ bfad_pci_init(struct pci_dev *pdev, struct bfad_s *bfad)
 
        if (pci_set_dma_mask(pdev, DMA_BIT_MASK(64)) != 0)
                if (pci_set_dma_mask(pdev, DMA_BIT_MASK(32)) != 0) {
-                       BFA_PRINTF(BFA_ERR, "pci_set_dma_mask fail %p\n", pdev);
+                       printk(KERN_ERR "pci_set_dma_mask fail %p\n", pdev);
                        goto out_release_region;
                }
 
        bfad->pci_bar0_kva = pci_iomap(pdev, 0, pci_resource_len(pdev, 0));
 
        if (bfad->pci_bar0_kva == NULL) {
-               BFA_PRINTF(BFA_ERR, "Fail to map bar0\n");
+               printk(KERN_ERR "Fail to map bar0\n");
                goto out_release_region;
        }
 
@@ -688,6 +818,54 @@ bfad_pci_init(struct pci_dev *pdev, struct bfad_s *bfad)
        bfad->pci_attr.pcifn = PCI_FUNC(pdev->devfn);
 
        bfad->pcidev = pdev;
+
+       /* Adjust PCIe Maximum Read Request Size */
+       if (pcie_max_read_reqsz > 0) {
+               int pcie_cap_reg;
+               u16 pcie_dev_ctl;
+               u16 mask = 0xffff;
+
+               switch (pcie_max_read_reqsz) {
+               case 128:
+                       mask = 0x0;
+                       break;
+               case 256:
+                       mask = 0x1000;
+                       break;
+               case 512:
+                       mask = 0x2000;
+                       break;
+               case 1024:
+                       mask = 0x3000;
+                       break;
+               case 2048:
+                       mask = 0x4000;
+                       break;
+               case 4096:
+                       mask = 0x5000;
+                       break;
+               default:
+                       break;
+               }
+
+               pcie_cap_reg = pci_find_capability(pdev, PCI_CAP_ID_EXP);
+               if (mask != 0xffff && pcie_cap_reg) {
+                       pcie_cap_reg += 0x08;
+                       pci_read_config_word(pdev, pcie_cap_reg, &pcie_dev_ctl);
+                       if ((pcie_dev_ctl & 0x7000) != mask) {
+                               printk(KERN_WARNING "BFA[%s]: "
+                               "pcie_max_read_request_size is %d, "
+                               "reset to %d\n", bfad->pci_name,
+                               (1 << ((pcie_dev_ctl & 0x7000) >> 12)) << 7,
+                               pcie_max_read_reqsz);
+
+                               pcie_dev_ctl &= ~0x7000;
+                               pci_write_config_word(pdev, pcie_cap_reg,
+                                               pcie_dev_ctl | mask);
+                       }
+               }
+       }
+
        return 0;
 
 out_release_region:
@@ -710,25 +888,22 @@ bfad_pci_uninit(struct pci_dev *pdev, struct bfad_s *bfad)
 void
 bfad_fcs_port_cfg(struct bfad_s *bfad)
 {
-       struct bfa_port_cfg_s port_cfg;
-       struct bfa_pport_attr_s attr;
-       char            symname[BFA_SYMNAME_MAXLEN];
+       struct bfa_lport_cfg_s  port_cfg;
+       struct bfa_port_attr_s attr;
+       char            symname[BFA_SYMNAME_MAXLEN];
 
        sprintf(symname, "%s-%d", BFAD_DRIVER_NAME, bfad->inst_no);
        memcpy(port_cfg.sym_name.symname, symname, strlen(symname));
        bfa_fcport_get_attr(&bfad->bfa, &attr);
        port_cfg.nwwn = attr.nwwn;
        port_cfg.pwwn = attr.pwwn;
-
-       bfa_fcs_cfg_base_port(&bfad->bfa_fcs, &port_cfg);
 }
 
 bfa_status_t
 bfad_drv_init(struct bfad_s *bfad)
 {
-       bfa_status_t    rc;
-       unsigned long   flags;
-       struct bfa_fcs_driver_info_s driver_info;
+       bfa_status_t    rc;
+       unsigned long   flags;
 
        bfad->cfg_data.rport_del_timeout = rport_del_timeout;
        bfad->cfg_data.lun_queue_depth = bfa_lun_queue_depth;
@@ -740,15 +915,12 @@ bfad_drv_init(struct bfad_s *bfad)
                printk(KERN_WARNING "bfad%d bfad_hal_mem_alloc failure\n",
                       bfad->inst_no);
                printk(KERN_WARNING
-                       "Not enough memory to attach all Brocade HBA ports,"
-                       " System may need more memory.\n");
+                       "Not enough memory to attach all Brocade HBA ports, %s",
+                       "System may need more memory.\n");
                goto out_hal_mem_alloc_failure;
        }
 
-       bfa_init_log(&bfad->bfa, bfad->logmod);
        bfa_init_trc(&bfad->bfa, bfad->trcmod);
-       bfa_init_aen(&bfad->bfa, bfad->aen);
-       memset(bfad->file_map, 0, sizeof(bfad->file_map));
        bfa_init_plog(&bfad->bfa, &bfad->plog_buf);
        bfa_plog_init(&bfad->plog_buf);
        bfa_plog_str(&bfad->plog_buf, BFA_PL_MID_DRVR, BFA_PL_EID_DRIVER_START,
@@ -757,77 +929,17 @@ bfad_drv_init(struct bfad_s *bfad)
        bfa_attach(&bfad->bfa, bfad, &bfad->ioc_cfg, &bfad->meminfo,
                   &bfad->hal_pcidev);
 
-       init_completion(&bfad->comp);
-
-       /*
-        * Enable Interrupt and wait bfa_init completion
-        */
-       if (bfad_setup_intr(bfad)) {
-               printk(KERN_WARNING "bfad%d: bfad_setup_intr failed\n",
-                      bfad->inst_no);
-               goto out_setup_intr_failure;
-       }
-
+       /* FCS INIT */
        spin_lock_irqsave(&bfad->bfad_lock, flags);
-       bfa_init(&bfad->bfa);
-       spin_unlock_irqrestore(&bfad->bfad_lock, flags);
-
-       /*
-        * Set up interrupt handler for each vectors
-        */
-       if ((bfad->bfad_flags & BFAD_MSIX_ON)
-           && bfad_install_msix_handler(bfad)) {
-               printk(KERN_WARNING "%s: install_msix failed, bfad%d\n",
-                      __func__, bfad->inst_no);
-       }
-
-       bfad_init_timer(bfad);
-
-       wait_for_completion(&bfad->comp);
-
-       memset(&driver_info, 0, sizeof(driver_info));
-       strncpy(driver_info.version, BFAD_DRIVER_VERSION,
-               sizeof(driver_info.version) - 1);
-       __kernel_param_lock();
-       if (host_name)
-               strncpy(driver_info.host_machine_name, host_name,
-                       sizeof(driver_info.host_machine_name) - 1);
-       if (os_name)
-               strncpy(driver_info.host_os_name, os_name,
-                       sizeof(driver_info.host_os_name) - 1);
-       if (os_patch)
-               strncpy(driver_info.host_os_patch, os_patch,
-                       sizeof(driver_info.host_os_patch) - 1);
-       __kernel_param_unlock();
-
-       strncpy(driver_info.os_device_name, bfad->pci_name,
-               sizeof(driver_info.os_device_name - 1));
-
-       /*
-        * FCS INIT
-        */
-       spin_lock_irqsave(&bfad->bfad_lock, flags);
-       bfa_fcs_log_init(&bfad->bfa_fcs, bfad->logmod);
        bfa_fcs_trc_init(&bfad->bfa_fcs, bfad->trcmod);
-       bfa_fcs_aen_init(&bfad->bfa_fcs, bfad->aen);
        bfa_fcs_attach(&bfad->bfa_fcs, &bfad->bfa, bfad, BFA_FALSE);
-
-       /* Do FCS init only when HAL init is done */
-       if ((bfad->bfad_flags & BFAD_HAL_INIT_DONE)) {
-               bfa_fcs_init(&bfad->bfa_fcs);
-               bfad->bfad_flags |= BFAD_FCS_INIT_DONE;
-       }
-
-       bfa_fcs_driver_info_init(&bfad->bfa_fcs, &driver_info);
        bfa_fcs_set_fdmi_param(&bfad->bfa_fcs, fdmi_enable);
        spin_unlock_irqrestore(&bfad->bfad_lock, flags);
 
        bfad->bfad_flags |= BFAD_DRV_INIT_DONE;
+
        return BFA_STATUS_OK;
 
-out_setup_intr_failure:
-       bfa_detach(&bfad->bfa);
-       bfad_hal_mem_release(bfad);
 out_hal_mem_alloc_failure:
        return BFA_STATUS_FAILED;
 }
@@ -855,7 +967,7 @@ bfad_drv_uninit(struct bfad_s *bfad)
 void
 bfad_drv_start(struct bfad_s *bfad)
 {
-       unsigned long   flags;
+       unsigned long   flags;
 
        spin_lock_irqsave(&bfad->bfad_lock, flags);
        bfa_start(&bfad->bfa);
@@ -863,13 +975,14 @@ bfad_drv_start(struct bfad_s *bfad)
        bfad->bfad_flags |= BFAD_HAL_START_DONE;
        spin_unlock_irqrestore(&bfad->bfad_lock, flags);
 
-       bfad_fc4_probe_post(bfad);
+       if (bfad->im)
+               flush_workqueue(bfad->im->drv_workq);
 }
 
 void
-bfad_drv_stop(struct bfad_s *bfad)
+bfad_fcs_stop(struct bfad_s *bfad)
 {
-       unsigned long   flags;
+       unsigned long   flags;
 
        spin_lock_irqsave(&bfad->bfad_lock, flags);
        init_completion(&bfad->comp);
@@ -878,24 +991,32 @@ bfad_drv_stop(struct bfad_s *bfad)
        spin_unlock_irqrestore(&bfad->bfad_lock, flags);
        wait_for_completion(&bfad->comp);
 
+       bfa_sm_send_event(bfad, BFAD_E_FCS_EXIT_COMP);
+}
+
+void
+bfad_stop(struct bfad_s *bfad)
+{
+       unsigned long   flags;
+
        spin_lock_irqsave(&bfad->bfad_lock, flags);
        init_completion(&bfad->comp);
        bfa_stop(&bfad->bfa);
        bfad->bfad_flags &= ~BFAD_HAL_START_DONE;
        spin_unlock_irqrestore(&bfad->bfad_lock, flags);
        wait_for_completion(&bfad->comp);
+
+       bfa_sm_send_event(bfad, BFAD_E_EXIT_COMP);
 }
 
 bfa_status_t
-bfad_cfg_pport(struct bfad_s *bfad, enum bfa_port_role role)
+bfad_cfg_pport(struct bfad_s *bfad, enum bfa_lport_role role)
 {
-       int             rc = BFA_STATUS_OK;
+       int             rc = BFA_STATUS_OK;
 
-       /*
-        * Allocate scsi_host for the physical port
-        */
-       if ((bfad_supported_fc4s & BFA_PORT_ROLE_FCP_IM)
-           && (role & BFA_PORT_ROLE_FCP_IM)) {
+       /* Allocate scsi_host for the physical port */
+       if ((supported_fc4s & BFA_LPORT_ROLE_FCP_IM) &&
+           (role & BFA_LPORT_ROLE_FCP_IM)) {
                if (bfad->pport.im_port == NULL) {
                        rc = BFA_STATUS_FAILED;
                        goto out;
@@ -906,7 +1027,7 @@ bfad_cfg_pport(struct bfad_s *bfad, enum bfa_port_role role)
                if (rc != BFA_STATUS_OK)
                        goto out;
 
-               bfad->pport.roles |= BFA_PORT_ROLE_FCP_IM;
+               bfad->pport.roles |= BFA_LPORT_ROLE_FCP_IM;
        }
 
        /* Setup the debugfs node for this scsi_host */
@@ -922,74 +1043,102 @@ out:
 void
 bfad_uncfg_pport(struct bfad_s *bfad)
 {
-        /* Remove the debugfs node for this scsi_host */
+       /* Remove the debugfs node for this scsi_host */
        kfree(bfad->regdata);
        bfad_debugfs_exit(&bfad->pport);
 
-       if ((bfad->pport.roles & BFA_PORT_ROLE_FCP_IPFC) && ipfc_enable) {
-               bfad_ipfc_port_delete(bfad, &bfad->pport);
-               bfad->pport.roles &= ~BFA_PORT_ROLE_FCP_IPFC;
-       }
-
-       if ((bfad_supported_fc4s & BFA_PORT_ROLE_FCP_IM)
-           && (bfad->pport.roles & BFA_PORT_ROLE_FCP_IM)) {
+       if ((supported_fc4s & BFA_LPORT_ROLE_FCP_IM) &&
+           (bfad->pport.roles & BFA_LPORT_ROLE_FCP_IM)) {
                bfad_im_scsi_host_free(bfad, bfad->pport.im_port);
                bfad_im_port_clean(bfad->pport.im_port);
                kfree(bfad->pport.im_port);
-               bfad->pport.roles &= ~BFA_PORT_ROLE_FCP_IM;
+               bfad->pport.roles &= ~BFA_LPORT_ROLE_FCP_IM;
        }
 
        bfad->bfad_flags &= ~BFAD_CFG_PPORT_DONE;
 }
 
-void
-bfad_drv_log_level_set(struct bfad_s *bfad)
-{
-       if (log_level > BFA_LOG_INVALID && log_level <= BFA_LOG_LEVEL_MAX)
-               bfa_log_set_level_all(&bfad->log_data, log_level);
-}
-
 bfa_status_t
-bfad_start_ops(struct bfad_s *bfad)
-{
-       int retval;
-       struct bfad_pcfg_s *pcfg, *pcfg_new;
+bfad_start_ops(struct bfad_s *bfad) {
+
+       int     retval;
+       unsigned long   flags;
+       struct bfad_vport_s *vport, *vport_new;
+       struct bfa_fcs_driver_info_s driver_info;
+
+       /* Fill the driver_info info to fcs*/
+       memset(&driver_info, 0, sizeof(driver_info));
+       strncpy(driver_info.version, BFAD_DRIVER_VERSION,
+               sizeof(driver_info.version) - 1);
+       if (host_name)
+               strncpy(driver_info.host_machine_name, host_name,
+                       sizeof(driver_info.host_machine_name) - 1);
+       if (os_name)
+               strncpy(driver_info.host_os_name, os_name,
+                       sizeof(driver_info.host_os_name) - 1);
+       if (os_patch)
+               strncpy(driver_info.host_os_patch, os_patch,
+                       sizeof(driver_info.host_os_patch) - 1);
+
+       strncpy(driver_info.os_device_name, bfad->pci_name,
+               sizeof(driver_info.os_device_name - 1));
+
+       /* FCS INIT */
+       spin_lock_irqsave(&bfad->bfad_lock, flags);
+       bfa_fcs_driver_info_init(&bfad->bfa_fcs, &driver_info);
+       bfa_fcs_init(&bfad->bfa_fcs);
+       spin_unlock_irqrestore(&bfad->bfad_lock, flags);
 
        /* PPORT FCS config */
        bfad_fcs_port_cfg(bfad);
 
-       retval = bfad_cfg_pport(bfad, BFA_PORT_ROLE_FCP_IM);
-       if (retval != BFA_STATUS_OK)
-               goto out_cfg_pport_failure;
-
-       /* BFAD level FC4 (IM/TM/IPFC) specific resource allocation */
-       retval = bfad_fc4_probe(bfad);
+       retval = bfad_cfg_pport(bfad, BFA_LPORT_ROLE_FCP_IM);
        if (retval != BFA_STATUS_OK) {
-               printk(KERN_WARNING "bfad_fc4_probe failed\n");
-               goto out_fc4_probe_failure;
+               if (bfa_sm_cmp_state(bfad, bfad_sm_initializing))
+                       bfa_sm_set_state(bfad, bfad_sm_failed);
+               bfad_stop(bfad);
+               return BFA_STATUS_FAILED;
        }
 
+       /* BFAD level FC4 IM specific resource allocation */
+       retval = bfad_im_probe(bfad);
+       if (retval != BFA_STATUS_OK) {
+               printk(KERN_WARNING "bfad_im_probe failed\n");
+               if (bfa_sm_cmp_state(bfad, bfad_sm_initializing))
+                       bfa_sm_set_state(bfad, bfad_sm_failed);
+               bfad_im_probe_undo(bfad);
+               bfad->bfad_flags &= ~BFAD_FC4_PROBE_DONE;
+               bfad_uncfg_pport(bfad);
+               bfad_stop(bfad);
+               return BFA_STATUS_FAILED;
+       } else
+               bfad->bfad_flags |= BFAD_FC4_PROBE_DONE;
+
        bfad_drv_start(bfad);
 
-       /* pbc vport creation */
-       list_for_each_entry_safe(pcfg, pcfg_new,  &bfad->pbc_pcfg_list,
-                                       list_entry) {
+       /* Complete pbc vport create */
+       list_for_each_entry_safe(vport, vport_new, &bfad->pbc_vport_list,
+                               list_entry) {
                struct fc_vport_identifiers vid;
                struct fc_vport *fc_vport;
+               char pwwn_buf[BFA_STRING_32];
 
                memset(&vid, 0, sizeof(vid));
                vid.roles = FC_PORT_ROLE_FCP_INITIATOR;
                vid.vport_type = FC_PORTTYPE_NPIV;
                vid.disable = false;
-               vid.node_name = wwn_to_u64((u8 *)&pcfg->port_cfg.nwwn);
-               vid.port_name = wwn_to_u64((u8 *)&pcfg->port_cfg.pwwn);
+               vid.node_name = wwn_to_u64((u8 *)
+                               (&((vport->fcs_vport).lport.port_cfg.nwwn)));
+               vid.port_name = wwn_to_u64((u8 *)
+                               (&((vport->fcs_vport).lport.port_cfg.pwwn)));
                fc_vport = fc_vport_create(bfad->pport.im_port->shost, 0, &vid);
-               if (!fc_vport)
+               if (!fc_vport) {
+                       wwn2str(pwwn_buf, vid.port_name);
                        printk(KERN_WARNING "bfad%d: failed to create pbc vport"
-                               " %llx\n", bfad->inst_no, vid.port_name);
-               list_del(&pcfg->list_entry);
-               kfree(pcfg);
-
+                               " %s\n", bfad->inst_no, pwwn_buf);
+               }
+               list_del(&vport->list_entry);
+               kfree(vport);
        }
 
        /*
@@ -998,24 +1147,15 @@ bfad_start_ops(struct bfad_s *bfad)
         * passed in module param value as the bfa_linkup_delay.
         */
        if (bfa_linkup_delay < 0) {
-
                bfa_linkup_delay = bfad_os_get_linkup_delay(bfad);
                bfad_os_rport_online_wait(bfad);
                bfa_linkup_delay = -1;
-
-       } else {
+       } else
                bfad_os_rport_online_wait(bfad);
-       }
 
-       bfa_log(bfad->logmod, BFA_LOG_LINUX_DEVICE_CLAIMED, bfad->pci_name);
+       BFA_LOG(KERN_INFO, bfad, log_level, "bfa device claimed\n");
 
        return BFA_STATUS_OK;
-
-out_fc4_probe_failure:
-       bfad_fc4_probe_undo(bfad);
-       bfad_uncfg_pport(bfad);
-out_cfg_pport_failure:
-       return BFA_STATUS_FAILED;
 }
 
 int
@@ -1028,18 +1168,8 @@ bfad_worker(void *ptr)
 
        while (!kthread_should_stop()) {
 
-               /* Check if the FCS init is done from bfad_drv_init;
-                * if not done do FCS init and set the flag.
-                */
-               if (!(bfad->bfad_flags & BFAD_FCS_INIT_DONE)) {
-                       spin_lock_irqsave(&bfad->bfad_lock, flags);
-                       bfa_fcs_init(&bfad->bfa_fcs);
-                       bfad->bfad_flags |= BFAD_FCS_INIT_DONE;
-                       spin_unlock_irqrestore(&bfad->bfad_lock, flags);
-               }
-
-               /* Start the bfad operations after HAL init done */
-               bfad_start_ops(bfad);
+               /* Send event BFAD_E_INIT_SUCCESS */
+               bfa_sm_send_event(bfad, BFAD_E_INIT_SUCCESS);
 
                spin_lock_irqsave(&bfad->bfad_lock, flags);
                bfad->bfad_tsk = NULL;
@@ -1051,9 +1181,198 @@ bfad_worker(void *ptr)
        return 0;
 }
 
- /*
-  *  PCI_entry PCI driver entries * {
-  */
+/**
+ *  BFA driver interrupt functions
+ */
+irqreturn_t
+bfad_intx(int irq, void *dev_id)
+{
+       struct bfad_s   *bfad = dev_id;
+       struct list_head        doneq;
+       unsigned long   flags;
+       bfa_boolean_t rc;
+
+       spin_lock_irqsave(&bfad->bfad_lock, flags);
+       rc = bfa_intx(&bfad->bfa);
+       if (!rc) {
+               spin_unlock_irqrestore(&bfad->bfad_lock, flags);
+               return IRQ_NONE;
+       }
+
+       bfa_comp_deq(&bfad->bfa, &doneq);
+       spin_unlock_irqrestore(&bfad->bfad_lock, flags);
+
+       if (!list_empty(&doneq)) {
+               bfa_comp_process(&bfad->bfa, &doneq);
+
+               spin_lock_irqsave(&bfad->bfad_lock, flags);
+               bfa_comp_free(&bfad->bfa, &doneq);
+               spin_unlock_irqrestore(&bfad->bfad_lock, flags);
+               bfa_trc_fp(bfad, irq);
+       }
+
+       return IRQ_HANDLED;
+
+}
+
+static irqreturn_t
+bfad_msix(int irq, void *dev_id)
+{
+       struct bfad_msix_s *vec = dev_id;
+       struct bfad_s *bfad = vec->bfad;
+       struct list_head doneq;
+       unsigned long   flags;
+
+       spin_lock_irqsave(&bfad->bfad_lock, flags);
+
+       bfa_msix(&bfad->bfa, vec->msix.entry);
+       bfa_comp_deq(&bfad->bfa, &doneq);
+       spin_unlock_irqrestore(&bfad->bfad_lock, flags);
+
+       if (!list_empty(&doneq)) {
+               bfa_comp_process(&bfad->bfa, &doneq);
+
+               spin_lock_irqsave(&bfad->bfad_lock, flags);
+               bfa_comp_free(&bfad->bfa, &doneq);
+               spin_unlock_irqrestore(&bfad->bfad_lock, flags);
+       }
+
+       return IRQ_HANDLED;
+}
+
+/**
+ * Initialize the MSIX entry table.
+ */
+static void
+bfad_init_msix_entry(struct bfad_s *bfad, struct msix_entry *msix_entries,
+                        int mask, int max_bit)
+{
+       int     i;
+       int     match = 0x00000001;
+
+       for (i = 0, bfad->nvec = 0; i < MAX_MSIX_ENTRY; i++) {
+               if (mask & match) {
+                       bfad->msix_tab[bfad->nvec].msix.entry = i;
+                       bfad->msix_tab[bfad->nvec].bfad = bfad;
+                       msix_entries[bfad->nvec].entry = i;
+                       bfad->nvec++;
+               }
+
+               match <<= 1;
+       }
+
+}
+
+int
+bfad_install_msix_handler(struct bfad_s *bfad)
+{
+       int i, error = 0;
+
+       for (i = 0; i < bfad->nvec; i++) {
+               sprintf(bfad->msix_tab[i].name, "bfa-%s-%s",
+                               bfad->pci_name,
+                               ((bfa_asic_id_ct(bfad->hal_pcidev.device_id)) ?
+                               msix_name_ct[i] : msix_name_cb[i]));
+
+               error = request_irq(bfad->msix_tab[i].msix.vector,
+                                   (irq_handler_t) bfad_msix, 0,
+                                   bfad->msix_tab[i].name, &bfad->msix_tab[i]);
+               bfa_trc(bfad, i);
+               bfa_trc(bfad, bfad->msix_tab[i].msix.vector);
+               if (error) {
+                       int     j;
+
+                       for (j = 0; j < i; j++)
+                               free_irq(bfad->msix_tab[j].msix.vector,
+                                               &bfad->msix_tab[j]);
+
+                       return 1;
+               }
+       }
+
+       return 0;
+}
+
+/**
+ * Setup MSIX based interrupt.
+ */
+int
+bfad_setup_intr(struct bfad_s *bfad)
+{
+       int error = 0;
+       u32 mask = 0, i, num_bit = 0, max_bit = 0;
+       struct msix_entry msix_entries[MAX_MSIX_ENTRY];
+       struct pci_dev *pdev = bfad->pcidev;
+
+       /* Call BFA to get the msix map for this PCI function.  */
+       bfa_msix_getvecs(&bfad->bfa, &mask, &num_bit, &max_bit);
+
+       /* Set up the msix entry table */
+       bfad_init_msix_entry(bfad, msix_entries, mask, max_bit);
+
+       if ((bfa_asic_id_ct(pdev->device) && !msix_disable_ct) ||
+           (!bfa_asic_id_ct(pdev->device) && !msix_disable_cb)) {
+
+               error = pci_enable_msix(bfad->pcidev, msix_entries, bfad->nvec);
+               if (error) {
+                       /*
+                        * Only error number of vector is available.
+                        * We don't have a mechanism to map multiple
+                        * interrupts into one vector, so even if we
+                        * can try to request less vectors, we don't
+                        * know how to associate interrupt events to
+                        *  vectors. Linux doesn't dupicate vectors
+                        * in the MSIX table for this case.
+                        */
+
+                       printk(KERN_WARNING "bfad%d: "
+                               "pci_enable_msix failed (%d),"
+                               " use line based.\n", bfad->inst_no, error);
+
+                       goto line_based;
+               }
+
+               /* Save the vectors */
+               for (i = 0; i < bfad->nvec; i++) {
+                       bfa_trc(bfad, msix_entries[i].vector);
+                       bfad->msix_tab[i].msix.vector = msix_entries[i].vector;
+               }
+
+               bfa_msix_init(&bfad->bfa, bfad->nvec);
+
+               bfad->bfad_flags |= BFAD_MSIX_ON;
+
+               return error;
+       }
+
+line_based:
+       error = 0;
+       if (request_irq
+           (bfad->pcidev->irq, (irq_handler_t) bfad_intx, BFAD_IRQ_FLAGS,
+            BFAD_DRIVER_NAME, bfad) != 0) {
+               /* Enable interrupt handler failed */
+               return 1;
+       }
+
+       return error;
+}
+
+void
+bfad_remove_intr(struct bfad_s *bfad)
+{
+       int     i;
+
+       if (bfad->bfad_flags & BFAD_MSIX_ON) {
+               for (i = 0; i < bfad->nvec; i++)
+                       free_irq(bfad->msix_tab[i].msix.vector,
+                                       &bfad->msix_tab[i]);
+
+               pci_disable_msix(bfad->pcidev);
+               bfad->bfad_flags &= ~BFAD_MSIX_ON;
+       } else {
+               free_irq(bfad->pcidev->irq, bfad);
+       }
+}
 
 /**
  * PCI probe entry.
@@ -1061,18 +1380,14 @@ bfad_worker(void *ptr)
 int
 bfad_pci_probe(struct pci_dev *pdev, const struct pci_device_id *pid)
 {
-       struct bfad_s  *bfad;
-       int             error = -ENODEV, retval;
+       struct bfad_s   *bfad;
+       int             error = -ENODEV, retval;
 
-       /*
-        * For single port cards - only claim function 0
-        */
-       if ((pdev->device == BFA_PCI_DEVICE_ID_FC_8G1P)
-           && (PCI_FUNC(pdev->devfn) != 0))
+       /* For single port cards - only claim function 0 */
+       if ((pdev->device == BFA_PCI_DEVICE_ID_FC_8G1P) &&
+               (PCI_FUNC(pdev->devfn) != 0))
                return -ENODEV;
 
-       BFA_TRACE(BFA_INFO, "bfad_pci_probe entry");
-
        bfad = kzalloc(sizeof(struct bfad_s), GFP_KERNEL);
        if (!bfad) {
                error = -ENOMEM;
@@ -1086,21 +1401,11 @@ bfad_pci_probe(struct pci_dev *pdev, const struct pci_device_id *pid)
                goto out_alloc_trace_failure;
        }
 
-       /*
-        * LOG/TRACE INIT
-        */
+       /* TRACE INIT */
        bfa_trc_init(bfad->trcmod);
        bfa_trc(bfad, bfad_inst);
 
-       bfad->logmod = &bfad->log_data;
-       bfa_log_init(bfad->logmod, (char *)pci_name(pdev), bfa_os_printf);
-
-       bfad_drv_log_level_set(bfad);
-
-       bfad->aen = &bfad->aen_buf;
-
        if (!(bfad_load_fwimg(pdev))) {
-               printk(KERN_WARNING "bfad_load_fwimg failure!\n");
                kfree(bfad->trcmod);
                goto out_alloc_trace_failure;
        }
@@ -1117,46 +1422,31 @@ bfad_pci_probe(struct pci_dev *pdev, const struct pci_device_id *pid)
        list_add_tail(&bfad->list_entry, &bfad_list);
        mutex_unlock(&bfad_mutex);
 
+       /* Initializing the state machine: State set to uninit */
+       bfa_sm_set_state(bfad, bfad_sm_uninit);
+
        spin_lock_init(&bfad->bfad_lock);
        pci_set_drvdata(pdev, bfad);
 
        bfad->ref_count = 0;
        bfad->pport.bfad = bfad;
-       INIT_LIST_HEAD(&bfad->pbc_pcfg_list);
-
-       bfad->bfad_tsk = kthread_create(bfad_worker, (void *) bfad, "%s",
-                                       "bfad_worker");
-       if (IS_ERR(bfad->bfad_tsk)) {
-               printk(KERN_INFO "bfad[%d]: Kernel thread"
-                       " creation failed!\n",
-                       bfad->inst_no);
-               goto out_kthread_create_failure;
-       }
+       INIT_LIST_HEAD(&bfad->pbc_vport_list);
 
        retval = bfad_drv_init(bfad);
        if (retval != BFA_STATUS_OK)
                goto out_drv_init_failure;
-       if (!(bfad->bfad_flags & BFAD_HAL_INIT_DONE)) {
-               bfad->bfad_flags |= BFAD_HAL_INIT_FAIL;
-               printk(KERN_WARNING "bfad%d: hal init failed\n", bfad->inst_no);
-               goto ok;
-       }
 
-       retval = bfad_start_ops(bfad);
-       if (retval != BFA_STATUS_OK)
-               goto out_start_ops_failure;
+       bfa_sm_send_event(bfad, BFAD_E_CREATE);
 
-       kthread_stop(bfad->bfad_tsk);
-       bfad->bfad_tsk = NULL;
+       if (bfa_sm_cmp_state(bfad, bfad_sm_uninit))
+               goto out_bfad_sm_failure;
 
-ok:
        return 0;
 
-out_start_ops_failure:
-       bfad_drv_uninit(bfad);
+out_bfad_sm_failure:
+       bfa_detach(&bfad->bfa);
+       bfad_hal_mem_release(bfad);
 out_drv_init_failure:
-       kthread_stop(bfad->bfad_tsk);
-out_kthread_create_failure:
        mutex_lock(&bfad_mutex);
        bfad_inst--;
        list_del(&bfad->list_entry);
@@ -1176,62 +1466,29 @@ out:
 void
 bfad_pci_remove(struct pci_dev *pdev)
 {
-       struct bfad_s  *bfad = pci_get_drvdata(pdev);
-       unsigned long   flags;
+       struct bfad_s         *bfad = pci_get_drvdata(pdev);
+       unsigned long   flags;
 
        bfa_trc(bfad, bfad->inst_no);
 
        spin_lock_irqsave(&bfad->bfad_lock, flags);
-       if (bfad->bfad_tsk != NULL)
-               kthread_stop(bfad->bfad_tsk);
-       spin_unlock_irqrestore(&bfad->bfad_lock, flags);
-
-       if ((bfad->bfad_flags & BFAD_DRV_INIT_DONE)
-           && !(bfad->bfad_flags & BFAD_HAL_INIT_DONE)) {
-
-               spin_lock_irqsave(&bfad->bfad_lock, flags);
-               init_completion(&bfad->comp);
-               bfa_stop(&bfad->bfa);
+       if (bfad->bfad_tsk != NULL) {
                spin_unlock_irqrestore(&bfad->bfad_lock, flags);
-               wait_for_completion(&bfad->comp);
-
-               bfad_remove_intr(bfad);
-               del_timer_sync(&bfad->hal_tmo);
-               goto hal_detach;
-       } else if (!(bfad->bfad_flags & BFAD_DRV_INIT_DONE)) {
-               goto remove_sysfs;
-       }
-
-       if (bfad->bfad_flags & BFAD_HAL_START_DONE) {
-               bfad_drv_stop(bfad);
-       } else if (bfad->bfad_flags & BFAD_DRV_INIT_DONE) {
-               /* Invoking bfa_stop() before bfa_detach
-                * when HAL and DRV init are success
-                * but HAL start did not occur.
-                */
-               spin_lock_irqsave(&bfad->bfad_lock, flags);
-               init_completion(&bfad->comp);
-               bfa_stop(&bfad->bfa);
+               kthread_stop(bfad->bfad_tsk);
+       } else {
                spin_unlock_irqrestore(&bfad->bfad_lock, flags);
-               wait_for_completion(&bfad->comp);
        }
 
-       bfad_remove_intr(bfad);
-       del_timer_sync(&bfad->hal_tmo);
+       /* Send Event BFAD_E_STOP */
+       bfa_sm_send_event(bfad, BFAD_E_STOP);
 
-       if (bfad->bfad_flags & BFAD_FC4_PROBE_DONE)
-               bfad_fc4_probe_undo(bfad);
-
-       if (bfad->bfad_flags & BFAD_CFG_PPORT_DONE)
-               bfad_uncfg_pport(bfad);
-
-hal_detach:
+       /* Driver detach and dealloc mem */
        spin_lock_irqsave(&bfad->bfad_lock, flags);
        bfa_detach(&bfad->bfa);
        spin_unlock_irqrestore(&bfad->bfad_lock, flags);
        bfad_hal_mem_release(bfad);
-remove_sysfs:
 
+       /* Cleaning the BFAD instance */
        mutex_lock(&bfad_mutex);
        bfad_inst--;
        list_del(&bfad->list_entry);
@@ -1242,35 +1499,34 @@ remove_sysfs:
        kfree(bfad);
 }
 
-
-static struct pci_device_id bfad_id_table[] = {
+struct pci_device_id bfad_id_table[] = {
        {
-        .vendor = BFA_PCI_VENDOR_ID_BROCADE,
-        .device = BFA_PCI_DEVICE_ID_FC_8G2P,
-        .subvendor = PCI_ANY_ID,
-        .subdevice = PCI_ANY_ID,
-        },
+               .vendor = BFA_PCI_VENDOR_ID_BROCADE,
+               .device = BFA_PCI_DEVICE_ID_FC_8G2P,
+               .subvendor = PCI_ANY_ID,
+               .subdevice = PCI_ANY_ID,
+       },
        {
-        .vendor = BFA_PCI_VENDOR_ID_BROCADE,
-        .device = BFA_PCI_DEVICE_ID_FC_8G1P,
-        .subvendor = PCI_ANY_ID,
-        .subdevice = PCI_ANY_ID,
-        },
+               .vendor = BFA_PCI_VENDOR_ID_BROCADE,
+               .device = BFA_PCI_DEVICE_ID_FC_8G1P,
+               .subvendor = PCI_ANY_ID,
+               .subdevice = PCI_ANY_ID,
+       },
        {
-        .vendor = BFA_PCI_VENDOR_ID_BROCADE,
-        .device = BFA_PCI_DEVICE_ID_CT,
-        .subvendor = PCI_ANY_ID,
-        .subdevice = PCI_ANY_ID,
-        .class = (PCI_CLASS_SERIAL_FIBER << 8),
-        .class_mask = ~0,
-        },
+               .vendor = BFA_PCI_VENDOR_ID_BROCADE,
+               .device = BFA_PCI_DEVICE_ID_CT,
+               .subvendor = PCI_ANY_ID,
+               .subdevice = PCI_ANY_ID,
+               .class = (PCI_CLASS_SERIAL_FIBER << 8),
+               .class_mask = ~0,
+       },
        {
-        .vendor = BFA_PCI_VENDOR_ID_BROCADE,
-        .device = BFA_PCI_DEVICE_ID_CT_FC,
-        .subvendor = PCI_ANY_ID,
-        .subdevice = PCI_ANY_ID,
-        .class = (PCI_CLASS_SERIAL_FIBER << 8),
-        .class_mask = ~0,
+               .vendor = BFA_PCI_VENDOR_ID_BROCADE,
+               .device = BFA_PCI_DEVICE_ID_CT_FC,
+               .subvendor = PCI_ANY_ID,
+               .subdevice = PCI_ANY_ID,
+               .class = (PCI_CLASS_SERIAL_FIBER << 8),
+               .class_mask = ~0,
        },
 
        {0, 0},
@@ -1285,90 +1541,105 @@ static struct pci_driver bfad_pci_driver = {
        .remove = __devexit_p(bfad_pci_remove),
 };
 
-/**
- *  Linux driver module functions
- */
-bfa_status_t
-bfad_fc4_module_init(void)
-{
-       int             rc;
-
-       rc = bfad_im_module_init();
-       if (rc != BFA_STATUS_OK)
-               goto ext;
-
-       bfad_tm_module_init();
-       if (ipfc_enable)
-               bfad_ipfc_module_init();
-ext:
-       return rc;
-}
-
-void
-bfad_fc4_module_exit(void)
-{
-       if (ipfc_enable)
-               bfad_ipfc_module_exit();
-       bfad_tm_module_exit();
-       bfad_im_module_exit();
-}
-
 /**
  * Driver module init.
  */
-static int      __init
+static int __init
 bfad_init(void)
 {
-       int             error = 0;
+       int             error = 0;
 
        printk(KERN_INFO "Brocade BFA FC/FCOE SCSI driver - version: %s\n",
-              BFAD_DRIVER_VERSION);
+                       BFAD_DRIVER_VERSION);
 
        if (num_sgpgs > 0)
                num_sgpgs_parm = num_sgpgs;
 
-       error = bfad_fc4_module_init();
+       error = bfad_im_module_init();
        if (error) {
                error = -ENOMEM;
-               printk(KERN_WARNING "bfad_fc4_module_init failure\n");
+               printk(KERN_WARNING "bfad_im_module_init failure\n");
                goto ext;
        }
 
-       if (!strcmp(FCPI_NAME, " fcpim"))
-               bfad_supported_fc4s |= BFA_PORT_ROLE_FCP_IM;
-       if (!strcmp(FCPT_NAME, " fcptm"))
-               bfad_supported_fc4s |= BFA_PORT_ROLE_FCP_TM;
-       if (!strcmp(IPFC_NAME, " ipfc"))
-               bfad_supported_fc4s |= BFA_PORT_ROLE_FCP_IPFC;
+       if (strcmp(FCPI_NAME, " fcpim") == 0)
+               supported_fc4s |= BFA_LPORT_ROLE_FCP_IM;
 
        bfa_ioc_auto_recover(ioc_auto_recover);
        bfa_fcs_rport_set_del_timeout(rport_del_timeout);
-       error = pci_register_driver(&bfad_pci_driver);
 
+       error = pci_register_driver(&bfad_pci_driver);
        if (error) {
-               printk(KERN_WARNING "bfad pci_register_driver failure\n");
+               printk(KERN_WARNING "pci_register_driver failure\n");
                goto ext;
        }
 
        return 0;
 
 ext:
-       bfad_fc4_module_exit();
+       bfad_im_module_exit();
        return error;
 }
 
 /**
  * Driver module exit.
  */
-static void     __exit
+static void __exit
 bfad_exit(void)
 {
        pci_unregister_driver(&bfad_pci_driver);
-       bfad_fc4_module_exit();
+       bfad_im_module_exit();
        bfad_free_fwimg();
 }
 
-#define BFAD_PROTO_NAME FCPI_NAME FCPT_NAME IPFC_NAME
+/* Firmware handling */
+u32 *
+bfad_read_firmware(struct pci_dev *pdev, u32 **bfi_image,
+               u32 *bfi_image_size, char *fw_name)
+{
+       const struct firmware *fw;
+
+       if (request_firmware(&fw, fw_name, &pdev->dev)) {
+               printk(KERN_ALERT "Can't locate firmware %s\n", fw_name);
+               goto error;
+       }
+
+       *bfi_image = vmalloc(fw->size);
+       if (NULL == *bfi_image) {
+               printk(KERN_ALERT "Fail to allocate buffer for fw image "
+                       "size=%x!\n", (u32) fw->size);
+               goto error;
+       }
+
+       memcpy(*bfi_image, fw->data, fw->size);
+       *bfi_image_size = fw->size/sizeof(u32);
+
+       return *bfi_image;
+
+error:
+       return NULL;
+}
+
+u32 *
+bfad_get_firmware_buf(struct pci_dev *pdev)
+{
+       if (pdev->device == BFA_PCI_DEVICE_ID_CT_FC) {
+               if (bfi_image_ct_fc_size == 0)
+                       bfad_read_firmware(pdev, &bfi_image_ct_fc,
+                               &bfi_image_ct_fc_size, BFAD_FW_FILE_CT_FC);
+               return bfi_image_ct_fc;
+       } else if (pdev->device == BFA_PCI_DEVICE_ID_CT) {
+               if (bfi_image_ct_cna_size == 0)
+                       bfad_read_firmware(pdev, &bfi_image_ct_cna,
+                               &bfi_image_ct_cna_size, BFAD_FW_FILE_CT_CNA);
+               return bfi_image_ct_cna;
+       } else {
+               if (bfi_image_cb_fc_size == 0)
+                       bfad_read_firmware(pdev, &bfi_image_cb_fc,
+                               &bfi_image_cb_fc_size, BFAD_FW_FILE_CB_FC);
+               return bfi_image_cb_fc;
+       }
+}
 
 module_init(bfad_init);
 module_exit(bfad_exit);
@@ -1376,5 +1647,3 @@ MODULE_LICENSE("GPL");
 MODULE_DESCRIPTION("Brocade Fibre Channel HBA Driver" BFAD_PROTO_NAME);
 MODULE_AUTHOR("Brocade Communications Systems, Inc.");
 MODULE_VERSION(BFAD_DRIVER_VERSION);
-
-
index 0818eb07ef884cffabc7f14e93965d4a2a796cd3..d8843720eac1b42b39606c6af93f1cde39653b5c 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
  * All rights reserved
  * www.brocade.com
  *
  *  bfa_attr.c Linux driver configuration interface module.
  */
 
-#include <linux/slab.h>
 #include "bfad_drv.h"
 #include "bfad_im.h"
-#include "bfad_trcmod.h"
-#include "bfad_attr.h"
-
-/**
- *  FC_transport_template FC transport template
- */
 
 /**
  * FC transport template entry, get SCSI target port ID.
@@ -42,7 +35,7 @@ bfad_im_get_starget_port_id(struct scsi_target *starget)
        u32        fc_id = -1;
        unsigned long   flags;
 
-       shost = bfad_os_starget_to_shost(starget);
+       shost = dev_to_shost(starget->dev.parent);
        im_port = (struct bfad_im_port_s *) shost->hostdata[0];
        bfad = im_port->bfad;
        spin_lock_irqsave(&bfad->bfad_lock, flags);
@@ -68,7 +61,7 @@ bfad_im_get_starget_node_name(struct scsi_target *starget)
        u64             node_name = 0;
        unsigned long   flags;
 
-       shost = bfad_os_starget_to_shost(starget);
+       shost = dev_to_shost(starget->dev.parent);
        im_port = (struct bfad_im_port_s *) shost->hostdata[0];
        bfad = im_port->bfad;
        spin_lock_irqsave(&bfad->bfad_lock, flags);
@@ -94,7 +87,7 @@ bfad_im_get_starget_port_name(struct scsi_target *starget)
        u64             port_name = 0;
        unsigned long   flags;
 
-       shost = bfad_os_starget_to_shost(starget);
+       shost = dev_to_shost(starget->dev.parent);
        im_port = (struct bfad_im_port_s *) shost->hostdata[0];
        bfad = im_port->bfad;
        spin_lock_irqsave(&bfad->bfad_lock, flags);
@@ -118,17 +111,7 @@ bfad_im_get_host_port_id(struct Scsi_Host *shost)
        struct bfad_port_s    *port = im_port->port;
 
        fc_host_port_id(shost) =
-                       bfa_os_hton3b(bfa_fcs_port_get_fcid(port->fcs_port));
-}
-
-
-
-
-
-struct Scsi_Host *
-bfad_os_starget_to_shost(struct scsi_target *starget)
-{
-       return dev_to_shost(starget->dev.parent);
+                       bfa_os_hton3b(bfa_fcs_lport_get_fcid(port->fcs_port));
 }
 
 /**
@@ -140,21 +123,21 @@ bfad_im_get_host_port_type(struct Scsi_Host *shost)
        struct bfad_im_port_s *im_port =
                        (struct bfad_im_port_s *) shost->hostdata[0];
        struct bfad_s         *bfad = im_port->bfad;
-       struct bfa_pport_attr_s attr;
+       struct bfa_lport_attr_s port_attr;
 
-       bfa_fcport_get_attr(&bfad->bfa, &attr);
+       bfa_fcs_lport_get_attr(&bfad->bfa_fcs.fabric.bport, &port_attr);
 
-       switch (attr.port_type) {
-       case BFA_PPORT_TYPE_NPORT:
+       switch (port_attr.port_type) {
+       case BFA_PORT_TYPE_NPORT:
                fc_host_port_type(shost) = FC_PORTTYPE_NPORT;
                break;
-       case BFA_PPORT_TYPE_NLPORT:
+       case BFA_PORT_TYPE_NLPORT:
                fc_host_port_type(shost) = FC_PORTTYPE_NLPORT;
                break;
-       case BFA_PPORT_TYPE_P2P:
+       case BFA_PORT_TYPE_P2P:
                fc_host_port_type(shost) = FC_PORTTYPE_PTP;
                break;
-       case BFA_PPORT_TYPE_LPORT:
+       case BFA_PORT_TYPE_LPORT:
                fc_host_port_type(shost) = FC_PORTTYPE_LPORT;
                break;
        default:
@@ -172,25 +155,28 @@ bfad_im_get_host_port_state(struct Scsi_Host *shost)
        struct bfad_im_port_s *im_port =
                        (struct bfad_im_port_s *) shost->hostdata[0];
        struct bfad_s         *bfad = im_port->bfad;
-       struct bfa_pport_attr_s attr;
+       struct bfa_port_attr_s attr;
 
        bfa_fcport_get_attr(&bfad->bfa, &attr);
 
        switch (attr.port_state) {
-       case BFA_PPORT_ST_LINKDOWN:
+       case BFA_PORT_ST_LINKDOWN:
                fc_host_port_state(shost) = FC_PORTSTATE_LINKDOWN;
                break;
-       case BFA_PPORT_ST_LINKUP:
+       case BFA_PORT_ST_LINKUP:
                fc_host_port_state(shost) = FC_PORTSTATE_ONLINE;
                break;
-       case BFA_PPORT_ST_UNINIT:
-       case BFA_PPORT_ST_ENABLING_QWAIT:
-       case BFA_PPORT_ST_ENABLING:
-       case BFA_PPORT_ST_DISABLING_QWAIT:
-       case BFA_PPORT_ST_DISABLING:
-       case BFA_PPORT_ST_DISABLED:
-       case BFA_PPORT_ST_STOPPED:
-       case BFA_PPORT_ST_IOCDOWN:
+       case BFA_PORT_ST_DISABLED:
+       case BFA_PORT_ST_STOPPED:
+       case BFA_PORT_ST_IOCDOWN:
+       case BFA_PORT_ST_IOCDIS:
+               fc_host_port_state(shost) = FC_PORTSTATE_OFFLINE;
+               break;
+       case BFA_PORT_ST_UNINIT:
+       case BFA_PORT_ST_ENABLING_QWAIT:
+       case BFA_PORT_ST_ENABLING:
+       case BFA_PORT_ST_DISABLING_QWAIT:
+       case BFA_PORT_ST_DISABLING:
        default:
                fc_host_port_state(shost) = FC_PORTSTATE_UNKNOWN;
                break;
@@ -210,13 +196,9 @@ bfad_im_get_host_active_fc4s(struct Scsi_Host *shost)
        memset(fc_host_active_fc4s(shost), 0,
               sizeof(fc_host_active_fc4s(shost)));
 
-       if (port->supported_fc4s &
-               (BFA_PORT_ROLE_FCP_IM | BFA_PORT_ROLE_FCP_TM))
+       if (port->supported_fc4s & BFA_LPORT_ROLE_FCP_IM)
                fc_host_active_fc4s(shost)[2] = 1;
 
-       if (port->supported_fc4s & BFA_PORT_ROLE_FCP_IPFC)
-               fc_host_active_fc4s(shost)[3] = 0x20;
-
        fc_host_active_fc4s(shost)[7] = 1;
 }
 
@@ -229,29 +211,29 @@ bfad_im_get_host_speed(struct Scsi_Host *shost)
        struct bfad_im_port_s *im_port =
                        (struct bfad_im_port_s *) shost->hostdata[0];
        struct bfad_s         *bfad = im_port->bfad;
-       struct bfa_pport_attr_s attr;
-       unsigned long   flags;
+       struct bfa_port_attr_s attr;
 
-       spin_lock_irqsave(shost->host_lock, flags);
        bfa_fcport_get_attr(&bfad->bfa, &attr);
        switch (attr.speed) {
-       case BFA_PPORT_SPEED_8GBPS:
+       case BFA_PORT_SPEED_10GBPS:
+               fc_host_speed(shost) = FC_PORTSPEED_10GBIT;
+               break;
+       case BFA_PORT_SPEED_8GBPS:
                fc_host_speed(shost) = FC_PORTSPEED_8GBIT;
                break;
-       case BFA_PPORT_SPEED_4GBPS:
+       case BFA_PORT_SPEED_4GBPS:
                fc_host_speed(shost) = FC_PORTSPEED_4GBIT;
                break;
-       case BFA_PPORT_SPEED_2GBPS:
+       case BFA_PORT_SPEED_2GBPS:
                fc_host_speed(shost) = FC_PORTSPEED_2GBIT;
                break;
-       case BFA_PPORT_SPEED_1GBPS:
+       case BFA_PORT_SPEED_1GBPS:
                fc_host_speed(shost) = FC_PORTSPEED_1GBIT;
                break;
        default:
                fc_host_speed(shost) = FC_PORTSPEED_UNKNOWN;
                break;
        }
-       spin_unlock_irqrestore(shost->host_lock, flags);
 }
 
 /**
@@ -265,7 +247,7 @@ bfad_im_get_host_fabric_name(struct Scsi_Host *shost)
        struct bfad_port_s    *port = im_port->port;
        wwn_t           fabric_nwwn = 0;
 
-       fabric_nwwn = bfa_fcs_port_get_fabric_name(port->fcs_port);
+       fabric_nwwn = bfa_fcs_lport_get_fabric_name(port->fcs_port);
 
        fc_host_fabric_name(shost) = bfa_os_htonll(fabric_nwwn);
 
@@ -281,23 +263,44 @@ bfad_im_get_stats(struct Scsi_Host *shost)
                        (struct bfad_im_port_s *) shost->hostdata[0];
        struct bfad_s         *bfad = im_port->bfad;
        struct bfad_hal_comp fcomp;
+       union bfa_port_stats_u *fcstats;
        struct fc_host_statistics *hstats;
        bfa_status_t    rc;
        unsigned long   flags;
 
+       fcstats = kzalloc(sizeof(union bfa_port_stats_u), GFP_KERNEL);
+       if (fcstats == NULL)
+               return NULL;
+
        hstats = &bfad->link_stats;
        init_completion(&fcomp.comp);
        spin_lock_irqsave(&bfad->bfad_lock, flags);
        memset(hstats, 0, sizeof(struct fc_host_statistics));
-       rc =  bfa_port_get_stats(BFA_FCPORT(&bfad->bfa),
-                                    (union bfa_pport_stats_u *) hstats,
-                                    bfad_hcb_comp, &fcomp);
+       rc = bfa_port_get_stats(BFA_FCPORT(&bfad->bfa),
+                               fcstats, bfad_hcb_comp, &fcomp);
        spin_unlock_irqrestore(&bfad->bfad_lock, flags);
        if (rc != BFA_STATUS_OK)
                return NULL;
 
        wait_for_completion(&fcomp.comp);
 
+       /* Fill the fc_host_statistics structure */
+       hstats->seconds_since_last_reset = fcstats->fc.secs_reset;
+       hstats->tx_frames = fcstats->fc.tx_frames;
+       hstats->tx_words  = fcstats->fc.tx_words;
+       hstats->rx_frames = fcstats->fc.rx_frames;
+       hstats->rx_words  = fcstats->fc.rx_words;
+       hstats->lip_count = fcstats->fc.lip_count;
+       hstats->nos_count = fcstats->fc.nos_count;
+       hstats->error_frames = fcstats->fc.error_frames;
+       hstats->dumped_frames = fcstats->fc.dropped_frames;
+       hstats->link_failure_count = fcstats->fc.link_failures;
+       hstats->loss_of_sync_count = fcstats->fc.loss_of_syncs;
+       hstats->loss_of_signal_count = fcstats->fc.loss_of_signals;
+       hstats->prim_seq_protocol_err_count = fcstats->fc.primseq_errs;
+       hstats->invalid_crc_count = fcstats->fc.invalid_crcs;
+
+       kfree(fcstats);
        return hstats;
 }
 
@@ -317,7 +320,7 @@ bfad_im_reset_stats(struct Scsi_Host *shost)
        init_completion(&fcomp.comp);
        spin_lock_irqsave(&bfad->bfad_lock, flags);
        rc = bfa_port_clear_stats(BFA_FCPORT(&bfad->bfa), bfad_hcb_comp,
-               &fcomp);
+                                       &fcomp);
        spin_unlock_irqrestore(&bfad->bfad_lock, flags);
 
        if (rc != BFA_STATUS_OK)
@@ -372,8 +375,8 @@ bfad_im_vport_create(struct fc_vport *fc_vport, bool disable)
        struct bfad_im_port_s *im_port =
                (struct bfad_im_port_s *) shost->hostdata[0];
        struct bfad_s *bfad = im_port->bfad;
-       struct bfa_port_cfg_s port_cfg;
-       struct bfad_pcfg_s *pcfg;
+       struct bfa_lport_cfg_s port_cfg;
+       struct bfad_vport_s *vp;
        int status = 0, rc;
        unsigned long flags;
 
@@ -382,12 +385,14 @@ bfad_im_vport_create(struct fc_vport *fc_vport, bool disable)
        u64_to_wwn(fc_vport->port_name, (u8 *)&port_cfg.pwwn);
        if (strlen(vname) > 0)
                strcpy((char *)&port_cfg.sym_name, vname);
-       port_cfg.roles = BFA_PORT_ROLE_FCP_IM;
+       port_cfg.roles = BFA_LPORT_ROLE_FCP_IM;
 
        spin_lock_irqsave(&bfad->bfad_lock, flags);
-       list_for_each_entry(pcfg, &bfad->pbc_pcfg_list, list_entry) {
-               if (port_cfg.pwwn == pcfg->port_cfg.pwwn) {
-                       port_cfg.preboot_vp = pcfg->port_cfg.preboot_vp;
+       list_for_each_entry(vp, &bfad->pbc_vport_list, list_entry) {
+               if (port_cfg.pwwn ==
+                               vp->fcs_vport.lport.port_cfg.pwwn) {
+                       port_cfg.preboot_vp =
+                               vp->fcs_vport.lport.port_cfg.preboot_vp;
                        break;
                }
        }
@@ -638,7 +643,7 @@ bfad_im_serial_num_show(struct device *dev, struct device_attribute *attr,
        struct Scsi_Host *shost = class_to_shost(dev);
        struct bfad_im_port_s *im_port =
                        (struct bfad_im_port_s *) shost->hostdata[0];
-       struct bfad_s         *bfad = im_port->bfad;
+       struct bfad_s *bfad = im_port->bfad;
        char serial_num[BFA_ADAPTER_SERIAL_NUM_LEN];
 
        bfa_get_adapter_serial_num(&bfad->bfa, serial_num);
@@ -652,7 +657,7 @@ bfad_im_model_show(struct device *dev, struct device_attribute *attr,
        struct Scsi_Host *shost = class_to_shost(dev);
        struct bfad_im_port_s *im_port =
                        (struct bfad_im_port_s *) shost->hostdata[0];
-       struct bfad_s         *bfad = im_port->bfad;
+       struct bfad_s *bfad = im_port->bfad;
        char model[BFA_ADAPTER_MODEL_NAME_LEN];
 
        bfa_get_adapter_model(&bfad->bfa, model);
@@ -666,10 +671,54 @@ bfad_im_model_desc_show(struct device *dev, struct device_attribute *attr,
        struct Scsi_Host *shost = class_to_shost(dev);
        struct bfad_im_port_s *im_port =
                        (struct bfad_im_port_s *) shost->hostdata[0];
-       struct bfad_s         *bfad = im_port->bfad;
+       struct bfad_s *bfad = im_port->bfad;
+       char model[BFA_ADAPTER_MODEL_NAME_LEN];
        char model_descr[BFA_ADAPTER_MODEL_DESCR_LEN];
 
-       bfa_get_adapter_model(&bfad->bfa, model_descr);
+       bfa_get_adapter_model(&bfad->bfa, model);
+       if (!strcmp(model, "Brocade-425"))
+               snprintf(model_descr, BFA_ADAPTER_MODEL_DESCR_LEN,
+                       "Brocade 4Gbps PCIe dual port FC HBA");
+       else if (!strcmp(model, "Brocade-825"))
+               snprintf(model_descr, BFA_ADAPTER_MODEL_DESCR_LEN,
+                       "Brocade 8Gbps PCIe dual port FC HBA");
+       else if (!strcmp(model, "Brocade-42B"))
+               snprintf(model_descr, BFA_ADAPTER_MODEL_DESCR_LEN,
+                       "HP 4Gbps PCIe dual port FC HBA");
+       else if (!strcmp(model, "Brocade-82B"))
+               snprintf(model_descr, BFA_ADAPTER_MODEL_DESCR_LEN,
+                       "HP 8Gbps PCIe dual port FC HBA");
+       else if (!strcmp(model, "Brocade-1010"))
+               snprintf(model_descr, BFA_ADAPTER_MODEL_DESCR_LEN,
+                       "Brocade 10Gbps single port CNA");
+       else if (!strcmp(model, "Brocade-1020"))
+               snprintf(model_descr, BFA_ADAPTER_MODEL_DESCR_LEN,
+                       "Brocade 10Gbps dual port CNA");
+       else if (!strcmp(model, "Brocade-1007"))
+               snprintf(model_descr, BFA_ADAPTER_MODEL_DESCR_LEN,
+                       "Brocade 10Gbps CNA");
+       else if (!strcmp(model, "Brocade-415"))
+               snprintf(model_descr, BFA_ADAPTER_MODEL_DESCR_LEN,
+                       "Brocade 4Gbps PCIe single port FC HBA");
+       else if (!strcmp(model, "Brocade-815"))
+               snprintf(model_descr, BFA_ADAPTER_MODEL_DESCR_LEN,
+                       "Brocade 8Gbps PCIe single port FC HBA");
+       else if (!strcmp(model, "Brocade-41B"))
+               snprintf(model_descr, BFA_ADAPTER_MODEL_DESCR_LEN,
+                       "HP 4Gbps PCIe single port FC HBA");
+       else if (!strcmp(model, "Brocade-81B"))
+               snprintf(model_descr, BFA_ADAPTER_MODEL_DESCR_LEN,
+                       "HP 8Gbps PCIe single port FC HBA");
+       else if (!strcmp(model, "Brocade-804"))
+               snprintf(model_descr, BFA_ADAPTER_MODEL_DESCR_LEN,
+                       "HP Bladesystem C-class 8Gbps FC HBA");
+       else if (!strcmp(model, "Brocade-902"))
+               snprintf(model_descr, BFA_ADAPTER_MODEL_DESCR_LEN,
+                       "Brocade 10Gbps CNA");
+       else
+               snprintf(model_descr, BFA_ADAPTER_MODEL_DESCR_LEN,
+                       "Invalid Model");
+
        return snprintf(buf, PAGE_SIZE, "%s\n", model_descr);
 }
 
@@ -683,7 +732,7 @@ bfad_im_node_name_show(struct device *dev, struct device_attribute *attr,
        struct bfad_port_s    *port = im_port->port;
        u64        nwwn;
 
-       nwwn = bfa_fcs_port_get_nwwn(port->fcs_port);
+       nwwn = bfa_fcs_lport_get_nwwn(port->fcs_port);
        return snprintf(buf, PAGE_SIZE, "0x%llx\n", bfa_os_htonll(nwwn));
 }
 
@@ -694,14 +743,14 @@ bfad_im_symbolic_name_show(struct device *dev, struct device_attribute *attr,
        struct Scsi_Host *shost = class_to_shost(dev);
        struct bfad_im_port_s *im_port =
                        (struct bfad_im_port_s *) shost->hostdata[0];
-       struct bfad_s         *bfad = im_port->bfad;
-       char model[BFA_ADAPTER_MODEL_NAME_LEN];
-       char fw_ver[BFA_VERSION_LEN];
+       struct bfad_s *bfad = im_port->bfad;
+       struct bfa_lport_attr_s port_attr;
+       char symname[BFA_SYMNAME_MAXLEN];
 
-       bfa_get_adapter_model(&bfad->bfa, model);
-       bfa_get_adapter_fw_ver(&bfad->bfa, fw_ver);
-       return snprintf(buf, PAGE_SIZE, "Brocade %s FV%s DV%s\n",
-               model, fw_ver, BFAD_DRIVER_VERSION);
+       bfa_fcs_lport_get_attr(&bfad->bfa_fcs.fabric.bport, &port_attr);
+       strncpy(symname, port_attr.port_cfg.sym_name.symname,
+                       BFA_SYMNAME_MAXLEN);
+       return snprintf(buf, PAGE_SIZE, "%s\n", symname);
 }
 
 static ssize_t
@@ -711,7 +760,7 @@ bfad_im_hw_version_show(struct device *dev, struct device_attribute *attr,
        struct Scsi_Host *shost = class_to_shost(dev);
        struct bfad_im_port_s *im_port =
                        (struct bfad_im_port_s *) shost->hostdata[0];
-       struct bfad_s         *bfad = im_port->bfad;
+       struct bfad_s *bfad = im_port->bfad;
        char hw_ver[BFA_VERSION_LEN];
 
        bfa_get_pci_chip_rev(&bfad->bfa, hw_ver);
@@ -732,7 +781,7 @@ bfad_im_optionrom_version_show(struct device *dev,
        struct Scsi_Host *shost = class_to_shost(dev);
        struct bfad_im_port_s *im_port =
                        (struct bfad_im_port_s *) shost->hostdata[0];
-       struct bfad_s         *bfad = im_port->bfad;
+       struct bfad_s *bfad = im_port->bfad;
        char optrom_ver[BFA_VERSION_LEN];
 
        bfa_get_adapter_optrom_ver(&bfad->bfa, optrom_ver);
@@ -746,7 +795,7 @@ bfad_im_fw_version_show(struct device *dev, struct device_attribute *attr,
        struct Scsi_Host *shost = class_to_shost(dev);
        struct bfad_im_port_s *im_port =
                        (struct bfad_im_port_s *) shost->hostdata[0];
-       struct bfad_s         *bfad = im_port->bfad;
+       struct bfad_s *bfad = im_port->bfad;
        char fw_ver[BFA_VERSION_LEN];
 
        bfa_get_adapter_fw_ver(&bfad->bfa, fw_ver);
@@ -760,10 +809,10 @@ bfad_im_num_of_ports_show(struct device *dev, struct device_attribute *attr,
        struct Scsi_Host *shost = class_to_shost(dev);
        struct bfad_im_port_s *im_port =
                        (struct bfad_im_port_s *) shost->hostdata[0];
-       struct bfad_s         *bfad = im_port->bfad;
+       struct bfad_s *bfad = im_port->bfad;
 
        return snprintf(buf, PAGE_SIZE, "%d\n",
-               bfa_get_nports(&bfad->bfa));
+                       bfa_get_nports(&bfad->bfa));
 }
 
 static ssize_t
@@ -788,10 +837,10 @@ bfad_im_num_of_discovered_ports_show(struct device *dev,
 
        rports = kzalloc(sizeof(wwn_t) * nrports , GFP_ATOMIC);
        if (rports == NULL)
-               return -ENOMEM;
+               return snprintf(buf, PAGE_SIZE, "Failed\n");
 
        spin_lock_irqsave(&bfad->bfad_lock, flags);
-       bfa_fcs_port_get_rports(port->fcs_port, rports, &nrports);
+       bfa_fcs_lport_get_rports(port->fcs_port, rports, &nrports);
        spin_unlock_irqrestore(&bfad->bfad_lock, flags);
        kfree(rports);
 
@@ -837,19 +886,19 @@ struct device_attribute *bfad_im_host_attrs[] = {
 };
 
 struct device_attribute *bfad_im_vport_attrs[] = {
-    &dev_attr_serial_number,
-    &dev_attr_model,
-    &dev_attr_model_description,
-    &dev_attr_node_name,
-    &dev_attr_symbolic_name,
-    &dev_attr_hardware_version,
-    &dev_attr_driver_version,
-    &dev_attr_option_rom_version,
-    &dev_attr_firmware_version,
-    &dev_attr_number_of_ports,
-    &dev_attr_driver_name,
-    &dev_attr_number_of_discovered_ports,
-    NULL,
+       &dev_attr_serial_number,
+       &dev_attr_model,
+       &dev_attr_model_description,
+       &dev_attr_node_name,
+       &dev_attr_symbolic_name,
+       &dev_attr_hardware_version,
+       &dev_attr_driver_version,
+       &dev_attr_option_rom_version,
+       &dev_attr_firmware_version,
+       &dev_attr_number_of_ports,
+       &dev_attr_driver_name,
+       &dev_attr_number_of_discovered_ports,
+       NULL,
 };
 
 
diff --git a/drivers/scsi/bfa/bfad_attr.h b/drivers/scsi/bfa/bfad_attr.h
deleted file mode 100644 (file)
index bf01020..0000000
+++ /dev/null
@@ -1,56 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFAD_ATTR_H__
-#define __BFAD_ATTR_H__
-
-/**
- *  FC_transport_template FC transport template
- */
-
-struct Scsi_Host*
-bfad_os_dev_to_shost(struct scsi_target *starget);
-
-/**
- * FC transport template entry, get SCSI target port ID.
- */
-void
-bfad_im_get_starget_port_id(struct scsi_target *starget);
-
-/**
- * FC transport template entry, get SCSI target nwwn.
- */
-void
-bfad_im_get_starget_node_name(struct scsi_target *starget);
-
-/**
- * FC transport template entry, get SCSI target pwwn.
- */
-void
-bfad_im_get_starget_port_name(struct scsi_target *starget);
-
-/**
- * FC transport template entry, get SCSI host port ID.
- */
-void
-bfad_im_get_host_port_id(struct Scsi_Host *shost);
-
-struct Scsi_Host*
-bfad_os_starget_to_shost(struct scsi_target *starget);
-
-
-#endif /*  __BFAD_ATTR_H__ */
index 4b82f12aad62fd67b85834ce8bdf2c028358325a..69ed1c4a903eac810fc40a70d86b20e7f440f6c1 100644 (file)
@@ -17,8 +17,8 @@
 
 #include <linux/debugfs.h>
 
-#include <bfad_drv.h>
-#include <bfad_im.h>
+#include "bfad_drv.h"
+#include "bfad_im.h"
 
 /*
  * BFA debufs interface
@@ -28,7 +28,7 @@
  * mount -t debugfs none /sys/kernel/debug
  *
  * BFA Hierarchy:
- *     - bfa/host#
+ *     - bfa/host#
  * where the host number corresponds to the one under /sys/class/scsi_host/host#
  *
  * Debugging service available per host:
@@ -217,7 +217,7 @@ bfad_debugfs_read(struct file *file, char __user *buf,
 #define BFA_REG_ADDRSZ(__bfa)  \
        ((bfa_ioc_devid(&(__bfa)->ioc) == BFA_PCI_DEVICE_ID_CT) ?       \
                BFA_REG_CT_ADDRSZ : BFA_REG_CB_ADDRSZ)
-#define BFA_REG_ADDRMSK(__bfa)  ((uint32_t)(BFA_REG_ADDRSZ(__bfa) - 1))
+#define BFA_REG_ADDRMSK(__bfa)  ((u32)(BFA_REG_ADDRSZ(__bfa) - 1))
 
 static bfa_status_t
 bfad_reg_offset_check(struct bfa_s *bfa, u32 offset, u32 len)
@@ -359,7 +359,7 @@ bfad_debugfs_write_regwr(struct file *file, const char __user *buf,
                return -EINVAL;
        }
 
-       reg_addr = (uint32_t *) ((uint8_t *) bfa_ioc_bar0(ioc) + addr);
+       reg_addr = (u32 *) ((u8 *) bfa_ioc_bar0(ioc) + addr);
        spin_lock_irqsave(&bfad->bfad_lock, flags);
        bfa_reg_write(reg_addr, val);
        spin_unlock_irqrestore(&bfad->bfad_lock, flags);
index 465b8b86ec9ce7b7dfb3ec1245fe87599d08f55e..98420bbb4f3f1d01f6c9035472d42f69a258ab88 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
  * All rights reserved
  * www.brocade.com
  *
 
 #include "bfa_os_inc.h"
 
-#include <bfa.h>
-#include <bfa_svc.h>
-#include <fcs/bfa_fcs.h>
-#include <defs/bfa_defs_pci.h>
-#include <defs/bfa_defs_port.h>
-#include <defs/bfa_defs_rport.h>
-#include <fcs/bfa_fcs_rport.h>
-#include <defs/bfa_defs_vport.h>
-#include <fcs/bfa_fcs_vport.h>
-
-#include <cs/bfa_plog.h>
-#include "aen/bfa_aen.h"
-#include <log/bfa_log_linux.h>
-
-#define BFAD_DRIVER_NAME        "bfa"
+#include "bfa_modules.h"
+#include "bfa_fcs.h"
+#include "bfa_defs_fcs.h"
+
+#include "bfa_plog.h"
+#include "bfa_cs.h"
+
+#define BFAD_DRIVER_NAME       "bfa"
 #ifdef BFA_DRIVER_VERSION
 #define BFAD_DRIVER_VERSION    BFA_DRIVER_VERSION
 #else
-#define BFAD_DRIVER_VERSION    "2.2.2.1"
+#define BFAD_DRIVER_VERSION    "2.3.2.0"
 #endif
 
-
+#define BFAD_PROTO_NAME FCPI_NAME
 #define BFAD_IRQ_FLAGS IRQF_SHARED
 
+#ifndef FC_PORTSPEED_8GBIT
+#define FC_PORTSPEED_8GBIT 0x10
+#endif
+
 /*
  * BFAD flags
  */
@@ -62,9 +59,9 @@
 #define BFAD_HAL_START_DONE                    0x00000010
 #define BFAD_PORT_ONLINE                       0x00000020
 #define BFAD_RPORT_ONLINE                      0x00000040
-#define BFAD_FCS_INIT_DONE                      0x00000080
-#define BFAD_HAL_INIT_FAIL                      0x00000100
-#define BFAD_FC4_PROBE_DONE                     0x00000200
+#define BFAD_FCS_INIT_DONE                     0x00000080
+#define BFAD_HAL_INIT_FAIL                     0x00000100
+#define BFAD_FC4_PROBE_DONE                    0x00000200
 #define BFAD_PORT_DELETE                       0x00000001
 
 /*
@@ -77,8 +74,8 @@
 /*
  * BFAD configuration parameter default values
  */
-#define BFAD_LUN_QUEUE_DEPTH           32
-#define BFAD_IO_MAX_SGE                SG_ALL
+#define BFAD_LUN_QUEUE_DEPTH   32
+#define BFAD_IO_MAX_SGE                SG_ALL
 
 #define bfad_isr_t irq_handler_t
 
 struct bfad_msix_s {
        struct bfad_s *bfad;
        struct msix_entry msix;
+       char name[32];
+};
+
+/*
+ * Only append to the enums defined here to avoid any versioning
+ * needed between trace utility and driver version
+ */
+enum {
+       BFA_TRC_LDRV_BFAD               = 1,
+       BFA_TRC_LDRV_IM                 = 2,
 };
 
 enum bfad_port_pvb_type {
@@ -101,17 +108,13 @@ enum bfad_port_pvb_type {
  */
 struct bfad_port_s {
        struct list_head list_entry;
-       struct bfad_s         *bfad;
-       struct bfa_fcs_port_s *fcs_port;
-       u32        roles;
-       s32         flags;
-       u32        supported_fc4s;
-       u8              ipfc_flags;
+       struct bfad_s   *bfad;
+       struct bfa_fcs_lport_s *fcs_port;
+       u32     roles;
+       s32             flags;
+       u32     supported_fc4s;
        enum bfad_port_pvb_type pvb_type;
        struct bfad_im_port_s *im_port; /* IM specific data */
-       struct bfad_tm_port_s *tm_port; /* TM specific data */
-       struct bfad_ipfc_port_s *ipfc_port;     /* IPFC specific data */
-
        /* port debugfs specific data */
        struct dentry *port_debugfs_root;
 };
@@ -124,7 +127,6 @@ struct bfad_vport_s {
        struct bfa_fcs_vport_s fcs_vport;
        struct completion *comp_del;
        struct list_head list_entry;
-       struct bfa_port_cfg_s port_cfg;
 };
 
 /*
@@ -137,20 +139,35 @@ struct bfad_vf_s {
 };
 
 struct bfad_cfg_param_s {
-       u32        rport_del_timeout;
-       u32        ioc_queue_depth;
-       u32        lun_queue_depth;
-       u32        io_max_sge;
-       u32        binding_method;
+       u32     rport_del_timeout;
+       u32     ioc_queue_depth;
+       u32     lun_queue_depth;
+       u32     io_max_sge;
+       u32     binding_method;
+};
+
+union bfad_tmp_buf {
+       /* From struct bfa_adapter_attr_s */
+       char            manufacturer[BFA_ADAPTER_MFG_NAME_LEN];
+       char            serial_num[BFA_ADAPTER_SERIAL_NUM_LEN];
+       char            model[BFA_ADAPTER_MODEL_NAME_LEN];
+       char            fw_ver[BFA_VERSION_LEN];
+       char            optrom_ver[BFA_VERSION_LEN];
+
+       /* From struct bfa_ioc_pci_attr_s */
+       u8              chip_rev[BFA_IOC_CHIP_REV_LEN];  /*  chip revision */
+
+       wwn_t           wwn[BFA_FCS_MAX_LPORTS];
 };
 
 /*
  * BFAD (PCI function) data structure
  */
 struct bfad_s {
+       bfa_sm_t        sm;     /* state machine */
        struct list_head list_entry;
-       struct bfa_s       bfa;
-       struct bfa_fcs_s       bfa_fcs;
+       struct bfa_s    bfa;
+       struct bfa_fcs_s bfa_fcs;
        struct pci_dev *pcidev;
        const char *pci_name;
        struct bfa_pcidev_s hal_pcidev;
@@ -163,41 +180,41 @@ struct bfad_s {
        struct bfad_port_s     pport;   /* physical port of the BFAD */
        struct bfa_meminfo_s meminfo;
        struct bfa_iocfc_cfg_s   ioc_cfg;
-       u32        inst_no;     /* BFAD instance number */
-       u32        bfad_flags;
+       u32     inst_no;        /* BFAD instance number */
+       u32     bfad_flags;
        spinlock_t      bfad_lock;
        struct task_struct *bfad_tsk;
        struct bfad_cfg_param_s cfg_data;
        struct bfad_msix_s msix_tab[MAX_MSIX_ENTRY];
-       int             nvec;
-       char            adapter_name[BFA_ADAPTER_SYM_NAME_LEN];
-       char            port_name[BFA_ADAPTER_SYM_NAME_LEN];
+       int             nvec;
+       char    adapter_name[BFA_ADAPTER_SYM_NAME_LEN];
+       char    port_name[BFA_ADAPTER_SYM_NAME_LEN];
        struct timer_list hal_tmo;
        unsigned long   hs_start;
        struct bfad_im_s *im;           /* IM specific data */
-       struct bfad_tm_s *tm;           /* TM specific data */
-       struct bfad_ipfc_s *ipfc;       /* IPFC specific data */
-       struct bfa_log_mod_s   log_data;
        struct bfa_trc_mod_s  *trcmod;
-       struct bfa_log_mod_s  *logmod;
-       struct bfa_aen_s      *aen;
-       struct bfa_aen_s       aen_buf;
-       void            *file_map[BFA_AEN_MAX_APP];
        struct bfa_plog_s      plog_buf;
-       int             ref_count;
-       bfa_boolean_t   ipfc_enabled;
+       int             ref_count;
+       union bfad_tmp_buf tmp_buf;
        struct fc_host_statistics link_stats;
-       struct list_head pbc_pcfg_list;
-       atomic_t wq_reqcnt;
+       struct list_head pbc_vport_list;
        /* debugfs specific data */
        char *regdata;
        u32 reglen;
        struct dentry *bfad_dentry_files[5];
 };
 
-struct bfad_pcfg_s {
-       struct list_head list_entry;
-       struct bfa_port_cfg_s port_cfg;
+/* BFAD state machine events */
+enum bfad_sm_event {
+       BFAD_E_CREATE                   = 1,
+       BFAD_E_KTHREAD_CREATE_FAILED    = 2,
+       BFAD_E_INIT                     = 3,
+       BFAD_E_INIT_SUCCESS             = 4,
+       BFAD_E_INIT_FAILED              = 5,
+       BFAD_E_INTR_INIT_FAILED         = 6,
+       BFAD_E_FCS_EXIT_COMP            = 7,
+       BFAD_E_EXIT_COMP                = 8,
+       BFAD_E_STOP                     = 9
 };
 
 /*
@@ -208,30 +225,30 @@ struct bfad_rport_s {
 };
 
 struct bfad_buf_info {
-       void           *virt;
+       void            *virt;
        dma_addr_t      phys;
-       u32        size;
+       u32     size;
 };
 
 struct bfad_fcxp {
        struct bfad_port_s    *port;
        struct bfa_rport_s *bfa_rport;
        bfa_status_t    req_status;
-       u16        tag;
-       u16        rsp_len;
-       u16        rsp_maxlen;
-       u8         use_ireqbuf;
-       u8         use_irspbuf;
-       u32        num_req_sgles;
-       u32        num_rsp_sgles;
-       struct fchs_s          fchs;
-       void           *reqbuf_info;
-       void           *rspbuf_info;
+       u16     tag;
+       u16     rsp_len;
+       u16     rsp_maxlen;
+       u8              use_ireqbuf;
+       u8              use_irspbuf;
+       u32     num_req_sgles;
+       u32     num_rsp_sgles;
+       struct fchs_s   fchs;
+       void            *reqbuf_info;
+       void            *rspbuf_info;
        struct bfa_sge_s  *req_sge;
        struct bfa_sge_s  *rsp_sge;
        fcxp_send_cb_t  send_cbfn;
-       void           *send_cbarg;
-       void           *bfa_fcxp;
+       void            *send_cbarg;
+       void            *bfa_fcxp;
        struct completion comp;
 };
 
@@ -244,34 +261,48 @@ struct bfad_hal_comp {
  * Macro to obtain the immediate lower power
  * of two for the integer.
  */
-#define nextLowerInt(x)                                \
-do {                                                   \
-       int j;                                          \
-       (*x)--;                                         \
-       for (j = 1; j < (sizeof(int) * 8); j <<= 1)     \
-               (*x) = (*x) | (*x) >> j;                \
-       (*x)++;                                         \
-       (*x) = (*x) >> 1;                               \
+#define nextLowerInt(x)                         \
+do {                                            \
+       int i;                                  \
+       (*x)--;                                 \
+       for (i = 1; i < (sizeof(int)*8); i <<= 1) \
+               (*x) = (*x) | (*x) >> i;        \
+       (*x)++;                                 \
+       (*x) = (*x) >> 1;                       \
 } while (0)
 
 
-bfa_status_t    bfad_vport_create(struct bfad_s *bfad, u16 vf_id,
-                         struct bfa_port_cfg_s *port_cfg, struct device *dev);
-bfa_status_t    bfad_vf_create(struct bfad_s *bfad, u16 vf_id,
-                              struct bfa_port_cfg_s *port_cfg);
-bfa_status_t    bfad_cfg_pport(struct bfad_s *bfad, enum bfa_port_role role);
-bfa_status_t    bfad_drv_init(struct bfad_s *bfad);
-bfa_status_t   bfad_start_ops(struct bfad_s *bfad);
-void            bfad_drv_start(struct bfad_s *bfad);
-void            bfad_uncfg_pport(struct bfad_s *bfad);
-void            bfad_drv_stop(struct bfad_s *bfad);
-void            bfad_remove_intr(struct bfad_s *bfad);
-void            bfad_hal_mem_release(struct bfad_s *bfad);
-void            bfad_hcb_comp(void *arg, bfa_status_t status);
-
-int             bfad_setup_intr(struct bfad_s *bfad);
-void            bfad_remove_intr(struct bfad_s *bfad);
+#define list_remove_head(list, entry, type, member)            \
+do {                                                           \
+       entry = NULL;                                           \
+       if (!list_empty(list)) {                                \
+               entry = list_entry((list)->next, type, member); \
+               list_del_init(&entry->member);                  \
+       }                                                       \
+} while (0)
 
+#define list_get_first(list, type, member)                             \
+((list_empty(list)) ? NULL :                                           \
+       list_entry((list)->next, type, member))
+
+bfa_status_t   bfad_vport_create(struct bfad_s *bfad, u16 vf_id,
+                                 struct bfa_lport_cfg_s *port_cfg,
+                                 struct device *dev);
+bfa_status_t   bfad_vf_create(struct bfad_s *bfad, u16 vf_id,
+                              struct bfa_lport_cfg_s *port_cfg);
+bfa_status_t   bfad_cfg_pport(struct bfad_s *bfad, enum bfa_lport_role role);
+bfa_status_t   bfad_drv_init(struct bfad_s *bfad);
+bfa_status_t   bfad_start_ops(struct bfad_s *bfad);
+void           bfad_drv_start(struct bfad_s *bfad);
+void           bfad_uncfg_pport(struct bfad_s *bfad);
+void           bfad_stop(struct bfad_s *bfad);
+void           bfad_fcs_stop(struct bfad_s *bfad);
+void           bfad_remove_intr(struct bfad_s *bfad);
+void           bfad_hal_mem_release(struct bfad_s *bfad);
+void           bfad_hcb_comp(void *arg, bfa_status_t status);
+
+int            bfad_setup_intr(struct bfad_s *bfad);
+void           bfad_remove_intr(struct bfad_s *bfad);
 void           bfad_update_hal_cfg(struct bfa_iocfc_cfg_s *bfa_cfg);
 bfa_status_t   bfad_hal_mem_alloc(struct bfad_s *bfad);
 void           bfad_bfa_tmo(unsigned long data);
@@ -280,9 +311,6 @@ int         bfad_pci_init(struct pci_dev *pdev, struct bfad_s *bfad);
 void           bfad_pci_uninit(struct pci_dev *pdev, struct bfad_s *bfad);
 void           bfad_fcs_port_cfg(struct bfad_s *bfad);
 void           bfad_drv_uninit(struct bfad_s *bfad);
-void           bfad_drv_log_level_set(struct bfad_s *bfad);
-bfa_status_t   bfad_fc4_module_init(void);
-void           bfad_fc4_module_exit(void);
 int            bfad_worker(void *ptr);
 void           bfad_debugfs_init(struct bfad_port_s *port);
 void           bfad_debugfs_exit(struct bfad_port_s *port);
@@ -294,10 +322,30 @@ int bfad_os_get_linkup_delay(struct bfad_s *bfad);
 int bfad_install_msix_handler(struct bfad_s *bfad);
 
 extern struct idr bfad_im_port_index;
+extern struct pci_device_id bfad_id_table[];
 extern struct list_head bfad_list;
-extern int bfa_lun_queue_depth;
-extern int bfad_supported_fc4s;
-extern int bfa_linkup_delay;
+extern char    *os_name;
+extern char    *os_patch;
+extern char    *host_name;
+extern int     num_rports;
+extern int     num_ios;
+extern int     num_tms;
+extern int     num_fcxps;
+extern int     num_ufbufs;
+extern int     reqq_size;
+extern int     rspq_size;
+extern int     num_sgpgs;
+extern int      rport_del_timeout;
+extern int      bfa_lun_queue_depth;
+extern int      bfa_io_max_sge;
+extern int      log_level;
+extern int      ioc_auto_recover;
+extern int      bfa_linkup_delay;
+extern int      msix_disable_cb;
+extern int      msix_disable_ct;
+extern int      fdmi_enable;
+extern int      supported_fc4s;
+extern int     pcie_max_read_reqsz;
 extern int bfa_debugfs_enable;
 extern struct mutex bfad_mutex;
 
diff --git a/drivers/scsi/bfa/bfad_fwimg.c b/drivers/scsi/bfa/bfad_fwimg.c
deleted file mode 100644 (file)
index 1baca1a..0000000
+++ /dev/null
@@ -1,131 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  bfad_fwimg.c Linux driver PCI interface module.
- */
-#include <bfa_os_inc.h>
-#include <bfad_drv.h>
-#include <bfad_im_compat.h>
-#include <defs/bfa_defs_version.h>
-#include <linux/errno.h>
-#include <linux/sched.h>
-#include <linux/init.h>
-#include <linux/fs.h>
-#include <asm/uaccess.h>
-#include <asm/fcntl.h>
-#include <linux/pci.h>
-#include <linux/firmware.h>
-#include <bfa_fwimg_priv.h>
-#include <bfa.h>
-
-u32 bfi_image_ct_fc_size;
-u32 bfi_image_ct_cna_size;
-u32 bfi_image_cb_fc_size;
-u32 *bfi_image_ct_fc;
-u32 *bfi_image_ct_cna;
-u32 *bfi_image_cb_fc;
-
-
-#define        BFAD_FW_FILE_CT_FC      "ctfw_fc.bin"
-#define        BFAD_FW_FILE_CT_CNA     "ctfw_cna.bin"
-#define        BFAD_FW_FILE_CB_FC      "cbfw_fc.bin"
-MODULE_FIRMWARE(BFAD_FW_FILE_CT_FC);
-MODULE_FIRMWARE(BFAD_FW_FILE_CT_CNA);
-MODULE_FIRMWARE(BFAD_FW_FILE_CB_FC);
-
-u32 *
-bfad_read_firmware(struct pci_dev *pdev, u32 **bfi_image,
-                       u32 *bfi_image_size, char *fw_name)
-{
-       const struct firmware *fw;
-
-       if (request_firmware(&fw, fw_name, &pdev->dev)) {
-               printk(KERN_ALERT "Can't locate firmware %s\n", fw_name);
-               goto error;
-       }
-
-       *bfi_image = vmalloc(fw->size);
-       if (NULL == *bfi_image) {
-               printk(KERN_ALERT "Fail to allocate buffer for fw image "
-                       "size=%x!\n", (u32) fw->size);
-               goto error;
-       }
-
-       memcpy(*bfi_image, fw->data, fw->size);
-       *bfi_image_size = fw->size/sizeof(u32);
-
-       return *bfi_image;
-
-error:
-       return NULL;
-}
-
-u32 *
-bfad_get_firmware_buf(struct pci_dev *pdev)
-{
-       if (pdev->device == BFA_PCI_DEVICE_ID_CT_FC) {
-               if (bfi_image_ct_fc_size == 0)
-                       bfad_read_firmware(pdev, &bfi_image_ct_fc,
-                               &bfi_image_ct_fc_size, BFAD_FW_FILE_CT_FC);
-               return bfi_image_ct_fc;
-       } else if (pdev->device == BFA_PCI_DEVICE_ID_CT) {
-               if (bfi_image_ct_cna_size == 0)
-                       bfad_read_firmware(pdev, &bfi_image_ct_cna,
-                               &bfi_image_ct_cna_size, BFAD_FW_FILE_CT_CNA);
-               return bfi_image_ct_cna;
-       } else {
-               if (bfi_image_cb_fc_size == 0)
-                       bfad_read_firmware(pdev, &bfi_image_cb_fc,
-                               &bfi_image_cb_fc_size, BFAD_FW_FILE_CB_FC);
-               return bfi_image_cb_fc;
-       }
-}
-
-u32 *
-bfi_image_ct_fc_get_chunk(u32 off)
-{ return (u32 *)(bfi_image_ct_fc + off); }
-
-u32 *
-bfi_image_ct_cna_get_chunk(u32 off)
-{ return (u32 *)(bfi_image_ct_cna + off); }
-
-u32 *
-bfi_image_cb_fc_get_chunk(u32 off)
-{ return (u32 *)(bfi_image_cb_fc + off); }
-
-uint32_t *
-bfi_image_get_chunk(int type, uint32_t off)
-{
-       switch (type) {
-       case BFI_IMAGE_CT_FC: return bfi_image_ct_fc_get_chunk(off); break;
-       case BFI_IMAGE_CT_CNA: return bfi_image_ct_cna_get_chunk(off); break;
-       case BFI_IMAGE_CB_FC: return bfi_image_cb_fc_get_chunk(off); break;
-       default: return 0; break;
-       }
-}
-
-uint32_t
-bfi_image_get_size(int type)
-{
-       switch (type) {
-       case BFI_IMAGE_CT_FC: return bfi_image_ct_fc_size; break;
-       case BFI_IMAGE_CT_CNA: return bfi_image_ct_cna_size; break;
-       case BFI_IMAGE_CB_FC: return bfi_image_cb_fc_size; break;
-       default: return 0; break;
-       }
-}
index 6ef87f6fcdbb533e4773bc380d49f0c77826d768..d950ee44016eeefcf3e8870483f9322f667551ce 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
  * All rights reserved
  * www.brocade.com
  *
  *  bfad_im.c Linux driver IM module.
  */
 
-#include <linux/slab.h>
 #include "bfad_drv.h"
 #include "bfad_im.h"
-#include "bfad_trcmod.h"
-#include "bfa_cb_ioim_macros.h"
-#include <fcb/bfa_fcb_fcpim.h>
+#include "bfa_cb_ioim.h"
+#include "bfa_fcs.h"
 
 BFA_TRC_FILE(LDRV, IM);
 
@@ -33,8 +31,10 @@ struct scsi_transport_template *bfad_im_scsi_transport_template;
 struct scsi_transport_template *bfad_im_scsi_vport_transport_template;
 static void bfad_im_itnim_work_handler(struct work_struct *work);
 static int bfad_im_queuecommand(struct scsi_cmnd *cmnd,
-               void (*done)(struct scsi_cmnd *));
+                               void (*done)(struct scsi_cmnd *));
 static int bfad_im_slave_alloc(struct scsi_device *sdev);
+static void bfad_im_fc_rport_add(struct bfad_im_port_s  *im_port,
+                               struct bfad_itnim_s *itnim);
 
 void
 bfa_cb_ioim_done(void *drv, struct bfad_ioim_s *dio,
@@ -58,6 +58,7 @@ bfa_cb_ioim_done(void *drv, struct bfad_ioim_s *dio,
                                sns_len = SCSI_SENSE_BUFFERSIZE;
                        memcpy(cmnd->sense_buffer, sns_info, sns_len);
                }
+
                if (residue > 0) {
                        bfa_trc(bfad, residue);
                        scsi_set_resid(cmnd, residue);
@@ -76,7 +77,8 @@ bfa_cb_ioim_done(void *drv, struct bfad_ioim_s *dio,
        case BFI_IOIM_STS_TIMEDOUT:
        case BFI_IOIM_STS_PATHTOV:
        default:
-               cmnd->result = ScsiResult(DID_ERROR, 0);
+               host_status = DID_ERROR;
+               cmnd->result = ScsiResult(host_status, 0);
        }
 
        /* Unmap DMA, if host is NULL, it means a scsi passthru cmd */
@@ -162,11 +164,6 @@ bfa_cb_tskim_done(void *bfad, struct bfad_tskim_s *dtsk,
                wake_up(wq);
 }
 
-void
-bfa_cb_ioim_resfree(void *drv)
-{
-}
-
 /**
  *  Scsi_Host_template SCSI host template
  */
@@ -179,15 +176,23 @@ bfad_im_info(struct Scsi_Host *shost)
        static char     bfa_buf[256];
        struct bfad_im_port_s *im_port =
                        (struct bfad_im_port_s *) shost->hostdata[0];
-       struct bfad_s         *bfad = im_port->bfad;
+       struct bfad_s *bfad = im_port->bfad;
+       struct bfa_s *bfa = &bfad->bfa;
+       struct bfa_ioc_s *ioc = &bfa->ioc;
        char model[BFA_ADAPTER_MODEL_NAME_LEN];
 
-       bfa_get_adapter_model(&bfad->bfa, model);
+       bfa_get_adapter_model(bfa, model);
 
        memset(bfa_buf, 0, sizeof(bfa_buf));
-       snprintf(bfa_buf, sizeof(bfa_buf),
-               "Brocade FC/FCOE Adapter, " "model: %s hwpath: %s driver: %s",
+       if (ioc->ctdev)
+               snprintf(bfa_buf, sizeof(bfa_buf),
+               "Brocade FCOE Adapter, " "model: %s hwpath: %s driver: %s",
+                model, bfad->pci_name, BFAD_DRIVER_VERSION);
+       else
+               snprintf(bfa_buf, sizeof(bfa_buf),
+               "Brocade FC Adapter, " "model: %s hwpath: %s driver: %s",
                model, bfad->pci_name, BFAD_DRIVER_VERSION);
+
        return bfa_buf;
 }
 
@@ -221,9 +226,9 @@ bfad_im_abort_handler(struct scsi_cmnd *cmnd)
        }
 
        bfa_trc(bfad, hal_io->iotag);
-       bfa_log(bfad->logmod, BFA_LOG_LINUX_SCSI_ABORT,
+       BFA_LOG(KERN_INFO, bfad, log_level, "scsi%d: abort cmnd %p iotag %x\n",
                im_port->shost->host_no, cmnd, hal_io->iotag);
-       bfa_ioim_abort(hal_io);
+       (void) bfa_ioim_abort(hal_io);
        spin_unlock_irqrestore(&bfad->bfad_lock, flags);
 
        /* Need to wait until the command get aborted */
@@ -237,7 +242,8 @@ bfad_im_abort_handler(struct scsi_cmnd *cmnd)
 
        cmnd->scsi_done(cmnd);
        bfa_trc(bfad, hal_io->iotag);
-       bfa_log(bfad->logmod, BFA_LOG_LINUX_SCSI_ABORT_COMP,
+       BFA_LOG(KERN_INFO, bfad, log_level,
+               "scsi%d: complete abort 0x%p iotag 0x%x\n",
                im_port->shost->host_no, cmnd, hal_io->iotag);
        return SUCCESS;
 out:
@@ -255,8 +261,8 @@ bfad_im_target_reset_send(struct bfad_s *bfad, struct scsi_cmnd *cmnd,
 
        tskim = bfa_tskim_alloc(&bfad->bfa, (struct bfad_tskim_s *) cmnd);
        if (!tskim) {
-               BFA_DEV_PRINTF(bfad, BFA_ERR,
-                              "target reset, fail to allocate tskim\n");
+               BFA_LOG(KERN_ERR, bfad, log_level,
+                       "target reset, fail to allocate tskim\n");
                rc = BFA_STATUS_FAILED;
                goto out;
        }
@@ -306,7 +312,7 @@ bfad_im_reset_lun_handler(struct scsi_cmnd *cmnd)
 
        tskim = bfa_tskim_alloc(&bfad->bfa, (struct bfad_tskim_s *) cmnd);
        if (!tskim) {
-               BFA_DEV_PRINTF(bfad, BFA_ERR,
+               BFA_LOG(KERN_ERR, bfad, log_level,
                                "LUN reset, fail to allocate tskim");
                spin_unlock_irqrestore(&bfad->bfad_lock, flags);
                rc = FAILED;
@@ -331,8 +337,8 @@ bfad_im_reset_lun_handler(struct scsi_cmnd *cmnd)
 
        task_status = cmnd->SCp.Status >> 1;
        if (task_status != BFI_TSKIM_STS_OK) {
-               BFA_DEV_PRINTF(bfad, BFA_ERR, "LUN reset failure, status: %d\n",
-                              task_status);
+               BFA_LOG(KERN_ERR, bfad, log_level,
+                       "LUN reset failure, status: %d\n", task_status);
                rc = FAILED;
        }
 
@@ -375,7 +381,7 @@ bfad_im_reset_bus_handler(struct scsi_cmnd *cmnd)
 
                        task_status = cmnd->SCp.Status >> 1;
                        if (task_status != BFI_TSKIM_STS_OK) {
-                               BFA_DEV_PRINTF(bfad, BFA_ERR,
+                               BFA_LOG(KERN_ERR, bfad, log_level,
                                        "target reset failure,"
                                        " status: %d\n", task_status);
                                err_cnt++;
@@ -438,6 +444,7 @@ bfa_fcb_itnim_free(struct bfad_s *bfad, struct bfad_itnim_s *itnim_drv)
        wwn_t wwpn;
        u32 fcid;
        char wwpn_str[32], fcid_str[16];
+       struct bfad_im_s        *im = itnim_drv->im;
 
        /* online to free state transtion should not happen */
        bfa_assert(itnim_drv->state != ITNIM_STATE_ONLINE);
@@ -454,10 +461,14 @@ bfa_fcb_itnim_free(struct bfad_s *bfad, struct bfad_itnim_s *itnim_drv)
        fcid = bfa_fcs_itnim_get_fcid(&itnim_drv->fcs_itnim);
        wwn2str(wwpn_str, wwpn);
        fcid2str(fcid_str, fcid);
-       bfa_log(bfad->logmod, BFA_LOG_LINUX_ITNIM_FREE,
+       BFA_LOG(KERN_INFO, bfad, log_level,
+               "ITNIM FREE scsi%d: FCID: %s WWPN: %s\n",
                port->im_port->shost->host_no,
                fcid_str, wwpn_str);
-       bfad_os_itnim_process(itnim_drv);
+
+       /* ITNIM processing */
+       if (itnim_drv->queue_work)
+               queue_work(im->drv_workq, &itnim_drv->itnim_work);
 }
 
 /**
@@ -468,13 +479,17 @@ void
 bfa_fcb_itnim_online(struct bfad_itnim_s *itnim_drv)
 {
        struct bfad_port_s    *port;
+       struct bfad_im_s        *im = itnim_drv->im;
 
        itnim_drv->bfa_itnim = bfa_fcs_itnim_get_halitn(&itnim_drv->fcs_itnim);
        port = bfa_fcs_itnim_get_drvport(&itnim_drv->fcs_itnim);
        itnim_drv->state = ITNIM_STATE_ONLINE;
        itnim_drv->queue_work = 1;
        itnim_drv->im_port = port->im_port;
-       bfad_os_itnim_process(itnim_drv);
+
+       /* ITNIM processing */
+       if (itnim_drv->queue_work)
+               queue_work(im->drv_workq, &itnim_drv->itnim_work);
 }
 
 /**
@@ -486,6 +501,7 @@ bfa_fcb_itnim_offline(struct bfad_itnim_s *itnim_drv)
 {
        struct bfad_port_s    *port;
        struct bfad_s *bfad;
+       struct bfad_im_s        *im = itnim_drv->im;
 
        port = bfa_fcs_itnim_get_drvport(&itnim_drv->fcs_itnim);
        bfad = port->bfad;
@@ -497,16 +513,10 @@ bfa_fcb_itnim_offline(struct bfad_itnim_s *itnim_drv)
        itnim_drv->im_port = port->im_port;
        itnim_drv->state = ITNIM_STATE_OFFLINE_PENDING;
        itnim_drv->queue_work = 1;
-       bfad_os_itnim_process(itnim_drv);
-}
 
-/**
- * BFA FCS itnim timeout callback.
- * Context: Interrupt. bfad_lock is held
- */
-void bfa_fcb_itnim_tov(struct bfad_itnim_s *itnim)
-{
-       itnim->state = ITNIM_STATE_TIMEOUT;
+       /* ITNIM processing */
+       if (itnim_drv->queue_work)
+               queue_work(im->drv_workq, &itnim_drv->itnim_work);
 }
 
 /**
@@ -514,7 +524,7 @@ void bfa_fcb_itnim_tov(struct bfad_itnim_s *itnim)
  */
 int
 bfad_im_scsi_host_alloc(struct bfad_s *bfad, struct bfad_im_port_s *im_port,
-                               struct device *dev)
+                       struct device *dev)
 {
        int error = 1;
 
@@ -580,7 +590,7 @@ void
 bfad_im_scsi_host_free(struct bfad_s *bfad, struct bfad_im_port_s *im_port)
 {
        bfa_trc(bfad, bfad->inst_no);
-       bfa_log(bfad->logmod, BFA_LOG_LINUX_SCSI_HOST_FREE,
+       BFA_LOG(KERN_INFO, bfad, log_level, "Free scsi%d\n",
                        im_port->shost->host_no);
 
        fc_remove_host(im_port->shost);
@@ -598,14 +608,11 @@ bfad_im_port_delete_handler(struct work_struct *work)
 {
        struct bfad_im_port_s *im_port =
                container_of(work, struct bfad_im_port_s, port_delete_work);
-       struct bfad_s *bfad = im_port->bfad;
 
        if (im_port->port->pvb_type != BFAD_PORT_PHYS_BASE) {
                im_port->flags |= BFAD_PORT_DELETE;
                fc_vport_terminate(im_port->fc_vport);
-               atomic_dec(&bfad->wq_reqcnt);
        }
-
 }
 
 bfa_status_t
@@ -636,11 +643,8 @@ bfad_im_port_delete(struct bfad_s *bfad, struct bfad_port_s *port)
 {
        struct bfad_im_port_s *im_port = port->im_port;
 
-       if (im_port->port->pvb_type != BFAD_PORT_PHYS_BASE) {
-               atomic_inc(&bfad->wq_reqcnt);
-               queue_work(bfad->im->drv_workq,
+       queue_work(bfad->im->drv_workq,
                                &im_port->port_delete_work);
-       }
 }
 
 void
@@ -663,16 +667,6 @@ bfad_im_port_clean(struct bfad_im_port_s *im_port)
        spin_unlock_irqrestore(&bfad->bfad_lock, flags);
 }
 
-void
-bfad_im_port_online(struct bfad_s *bfad, struct bfad_port_s *port)
-{
-}
-
-void
-bfad_im_port_offline(struct bfad_s *bfad, struct bfad_port_s *port)
-{
-}
-
 bfa_status_t
 bfad_im_probe(struct bfad_s *bfad)
 {
@@ -701,27 +695,12 @@ void
 bfad_im_probe_undo(struct bfad_s *bfad)
 {
        if (bfad->im) {
-               while (atomic_read(&bfad->wq_reqcnt)) {
-                       printk(KERN_INFO "bfa %s: waiting workq processing,"
-                               " wq_reqcnt:%x\n", bfad->pci_name,
-                               atomic_read(&bfad->wq_reqcnt));
-                       schedule_timeout_uninterruptible(HZ);
-               }
                bfad_os_destroy_workq(bfad->im);
                kfree(bfad->im);
                bfad->im = NULL;
        }
 }
 
-/**
- * Call back function to handle IO redirection state change
- */
-void
-bfa_cb_ioredirect_state_change(void *hcb_bfad, bfa_boolean_t ioredirect)
-{
-       /* Do nothing */
-}
-
 struct Scsi_Host *
 bfad_os_scsi_host_alloc(struct bfad_im_port_s *im_port, struct bfad_s *bfad)
 {
@@ -751,6 +730,7 @@ void
 bfad_os_destroy_workq(struct bfad_im_s *im)
 {
        if (im && im->drv_workq) {
+               flush_workqueue(im->drv_workq);
                destroy_workqueue(im->drv_workq);
                im->drv_workq = NULL;
        }
@@ -762,7 +742,7 @@ bfad_os_thread_workq(struct bfad_s *bfad)
        struct bfad_im_s      *im = bfad->im;
 
        bfa_trc(bfad, 0);
-       snprintf(im->drv_workq_name, BFAD_KOBJ_NAME_LEN, "bfad_wq_%d",
+       snprintf(im->drv_workq_name, KOBJ_NAME_LEN, "bfad_wq_%d",
                 bfad->inst_no);
        im->drv_workq = create_singlethread_workqueue(im->drv_workq_name);
        if (!im->drv_workq)
@@ -832,12 +812,6 @@ struct scsi_host_template bfad_im_vport_template = {
        .max_sectors = 0xFFFF,
 };
 
-void
-bfad_im_probe_post(struct bfad_im_s *im)
-{
-       flush_workqueue(im->drv_workq);
-}
-
 bfa_status_t
 bfad_im_module_init(void)
 {
@@ -861,19 +835,11 @@ bfad_im_module_exit(void)
 {
        if (bfad_im_scsi_transport_template)
                fc_release_transport(bfad_im_scsi_transport_template);
+
        if (bfad_im_scsi_vport_transport_template)
                fc_release_transport(bfad_im_scsi_vport_transport_template);
 }
 
-void
-bfad_os_itnim_process(struct bfad_itnim_s *itnim_drv)
-{
-       struct bfad_im_s      *im = itnim_drv->im;
-
-       if (itnim_drv->queue_work)
-               queue_work(im->drv_workq, &itnim_drv->itnim_work);
-}
-
 void
 bfad_os_ramp_up_qdepth(struct bfad_itnim_s *itnim, struct scsi_device *sdev)
 {
@@ -916,9 +882,6 @@ bfad_os_handle_qfull(struct bfad_itnim_s *itnim, struct scsi_device *sdev)
        }
 }
 
-
-
-
 struct bfad_itnim_s *
 bfad_os_get_itnim(struct bfad_im_port_s *im_port, int id)
 {
@@ -949,44 +912,64 @@ bfad_im_slave_alloc(struct scsi_device *sdev)
        return 0;
 }
 
+static u32
+bfad_im_supported_speeds(struct bfa_s *bfa)
+{
+       struct bfa_ioc_attr_s ioc_attr;
+       u32 supported_speed = 0;
+
+       bfa_get_attr(bfa, &ioc_attr);
+       if (ioc_attr.adapter_attr.max_speed == BFA_PORT_SPEED_8GBPS) {
+               if (ioc_attr.adapter_attr.is_mezz) {
+                       supported_speed |= FC_PORTSPEED_8GBIT |
+                               FC_PORTSPEED_4GBIT |
+                               FC_PORTSPEED_2GBIT | FC_PORTSPEED_1GBIT;
+               } else {
+                       supported_speed |= FC_PORTSPEED_8GBIT |
+                               FC_PORTSPEED_4GBIT |
+                               FC_PORTSPEED_2GBIT;
+               }
+       } else if (ioc_attr.adapter_attr.max_speed == BFA_PORT_SPEED_4GBPS) {
+               supported_speed |=  FC_PORTSPEED_4GBIT | FC_PORTSPEED_2GBIT |
+                               FC_PORTSPEED_1GBIT;
+       } else if (ioc_attr.adapter_attr.max_speed == BFA_PORT_SPEED_10GBPS) {
+               supported_speed |= FC_PORTSPEED_10GBIT;
+       }
+       return supported_speed;
+}
+
 void
 bfad_os_fc_host_init(struct bfad_im_port_s *im_port)
 {
        struct Scsi_Host *host = im_port->shost;
        struct bfad_s         *bfad = im_port->bfad;
        struct bfad_port_s    *port = im_port->port;
-       struct bfa_pport_attr_s pattr;
-       char model[BFA_ADAPTER_MODEL_NAME_LEN];
-       char fw_ver[BFA_VERSION_LEN];
+       struct bfa_port_attr_s pattr;
+       struct bfa_lport_attr_s port_attr;
+       char symname[BFA_SYMNAME_MAXLEN];
 
        fc_host_node_name(host) =
-               bfa_os_htonll((bfa_fcs_port_get_nwwn(port->fcs_port)));
+               bfa_os_htonll((bfa_fcs_lport_get_nwwn(port->fcs_port)));
        fc_host_port_name(host) =
-               bfa_os_htonll((bfa_fcs_port_get_pwwn(port->fcs_port)));
+               bfa_os_htonll((bfa_fcs_lport_get_pwwn(port->fcs_port)));
        fc_host_max_npiv_vports(host) = bfa_lps_get_max_vport(&bfad->bfa);
 
        fc_host_supported_classes(host) = FC_COS_CLASS3;
 
        memset(fc_host_supported_fc4s(host), 0,
               sizeof(fc_host_supported_fc4s(host)));
-       if (bfad_supported_fc4s & (BFA_PORT_ROLE_FCP_IM | BFA_PORT_ROLE_FCP_TM))
+       if (supported_fc4s & BFA_LPORT_ROLE_FCP_IM)
                /* For FCP type 0x08 */
                fc_host_supported_fc4s(host)[2] = 1;
-       if (bfad_supported_fc4s & BFA_PORT_ROLE_FCP_IPFC)
-               /* For LLC/SNAP type 0x05 */
-               fc_host_supported_fc4s(host)[3] = 0x20;
        /* For fibre channel services type 0x20 */
        fc_host_supported_fc4s(host)[7] = 1;
 
-       bfa_get_adapter_model(&bfad->bfa, model);
-       bfa_get_adapter_fw_ver(&bfad->bfa, fw_ver);
-       sprintf(fc_host_symbolic_name(host), "Brocade %s FV%s DV%s",
-               model, fw_ver, BFAD_DRIVER_VERSION);
+       bfa_fcs_lport_get_attr(&bfad->bfa_fcs.fabric.bport, &port_attr);
+       strncpy(symname, port_attr.port_cfg.sym_name.symname,
+               BFA_SYMNAME_MAXLEN);
+       sprintf(fc_host_symbolic_name(host), "%s", symname);
 
-       fc_host_supported_speeds(host) = 0;
-       fc_host_supported_speeds(host) |=
-               FC_PORTSPEED_8GBIT | FC_PORTSPEED_4GBIT | FC_PORTSPEED_2GBIT |
-               FC_PORTSPEED_1GBIT;
+       fc_host_supported_speeds(host) = bfad_im_supported_speeds(&bfad->bfa);
 
        bfa_fcport_get_attr(&bfad->bfa, &pattr);
        fc_host_maxframe_size(host) = pattr.pport_cfg.maxfrsize;
@@ -1065,7 +1048,9 @@ bfad_im_itnim_work_handler(struct work_struct *work)
                        fcid2str(fcid_str, fcid);
                        list_add_tail(&itnim->list_entry,
                                &im_port->itnim_mapped_list);
-                       bfa_log(bfad->logmod, BFA_LOG_LINUX_ITNIM_ONLINE,
+                       BFA_LOG(KERN_INFO, bfad, log_level,
+                               "ITNIM ONLINE Target: %d:0:%d "
+                               "FCID: %s WWPN: %s\n",
                                im_port->shost->host_no,
                                itnim->scsi_tgt_id,
                                fcid_str, wwpn_str);
@@ -1096,7 +1081,9 @@ bfad_im_itnim_work_handler(struct work_struct *work)
                        wwn2str(wwpn_str, wwpn);
                        fcid2str(fcid_str, fcid);
                        list_del(&itnim->list_entry);
-                       bfa_log(bfad->logmod, BFA_LOG_LINUX_ITNIM_OFFLINE,
+                       BFA_LOG(KERN_INFO, bfad, log_level,
+                               "ITNIM OFFLINE Target: %d:0:%d "
+                               "FCID: %s WWPN: %s\n",
                                im_port->shost->host_no,
                                itnim->scsi_tgt_id,
                                fcid_str, wwpn_str);
@@ -1142,7 +1129,7 @@ bfad_im_queuecommand(struct scsi_cmnd *cmnd, void (*done) (struct scsi_cmnd *))
        struct bfa_ioim_s *hal_io;
        unsigned long   flags;
        int             rc;
-       s16        sg_cnt = 0;
+       int       sg_cnt = 0;
        struct fc_rport *rport = starget_to_rport(scsi_target(cmnd->device));
 
        rc = fc_remote_port_chkready(rport);
@@ -1153,7 +1140,6 @@ bfad_im_queuecommand(struct scsi_cmnd *cmnd, void (*done) (struct scsi_cmnd *))
        }
 
        sg_cnt = scsi_dma_map(cmnd);
-
        if (sg_cnt < 0)
                return SCSI_MLQUEUE_HOST_BUSY;
 
@@ -1168,6 +1154,7 @@ bfad_im_queuecommand(struct scsi_cmnd *cmnd, void (*done) (struct scsi_cmnd *))
                goto out_fail_cmd;
        }
 
+
        itnim = itnim_data->itnim;
        if (!itnim) {
                cmnd->result = ScsiResult(DID_IMM_RETRY, 0);
@@ -1206,47 +1193,49 @@ bfad_os_rport_online_wait(struct bfad_s *bfad)
        int rport_delay = 10;
 
        for (i = 0; !(bfad->bfad_flags & BFAD_PORT_ONLINE)
-                && i < bfa_linkup_delay; i++)
-               schedule_timeout_uninterruptible(HZ);
+               && i < bfa_linkup_delay; i++) {
+               set_current_state(TASK_UNINTERRUPTIBLE);
+               schedule_timeout(HZ);
+       }
 
        if (bfad->bfad_flags & BFAD_PORT_ONLINE) {
                rport_delay = rport_delay < bfa_linkup_delay ?
-                                rport_delay : bfa_linkup_delay;
+                       rport_delay : bfa_linkup_delay;
                for (i = 0; !(bfad->bfad_flags & BFAD_RPORT_ONLINE)
-                        && i < rport_delay; i++)
-                       schedule_timeout_uninterruptible(HZ);
+                       && i < rport_delay; i++) {
+                       set_current_state(TASK_UNINTERRUPTIBLE);
+                       schedule_timeout(HZ);
+               }
 
-               if (rport_delay > 0 && (bfad->bfad_flags & BFAD_RPORT_ONLINE))
-                       schedule_timeout_uninterruptible(rport_delay * HZ);
+               if (rport_delay > 0 && (bfad->bfad_flags & BFAD_RPORT_ONLINE)) {
+                       set_current_state(TASK_UNINTERRUPTIBLE);
+                       schedule_timeout(rport_delay * HZ);
+               }
        }
 }
 
 int
 bfad_os_get_linkup_delay(struct bfad_s *bfad)
 {
-
-       u8      nwwns = 0;
-       wwn_t   wwns[BFA_PREBOOT_BOOTLUN_MAX];
-       int     ldelay;
+       u8              nwwns = 0;
+       wwn_t           wwns[BFA_PREBOOT_BOOTLUN_MAX];
+       int             linkup_delay;
 
        /*
         * Querying for the boot target port wwns
         * -- read from boot information in flash.
-        * If nwwns > 0 => boot over SAN and set bfa_linkup_delay = 30
-        * else => local boot machine set bfa_linkup_delay = 10
+        * If nwwns > 0 => boot over SAN and set linkup_delay = 30
+        * else => local boot machine set linkup_delay = 0
         */
 
        bfa_iocfc_get_bootwwns(&bfad->bfa, &nwwns, wwns);
 
-       if (nwwns > 0) {
-               /* If boot over SAN; linkup_delay = 30sec */
-               ldelay = 30;
-       } else {
-               /* If local boot; linkup_delay = 10sec */
-               ldelay = 0;
-       }
+       if (nwwns > 0)
+               /* If Boot over SAN set linkup_delay = 30sec */
+               linkup_delay = 30;
+       else
+               /* If local boot; no linkup_delay */
+               linkup_delay = 0;
 
-       return ldelay;
+       return linkup_delay;
 }
-
-
index 973cab4d09c7b4ec030e7556d3e3511d5595b632..b038c0e089214d4017b8f235b5b6d8889aedcc5f 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
  * All rights reserved
  * www.brocade.com
  *
 #ifndef __BFAD_IM_H__
 #define __BFAD_IM_H__
 
-#include "fcs/bfa_fcs_fcpim.h"
-#include "bfad_im_compat.h"
+#include "bfa_fcs.h"
 
 #define FCPI_NAME " fcpim"
 
+#ifndef KOBJ_NAME_LEN
+#define KOBJ_NAME_LEN           20
+#endif
+
 bfa_status_t bfad_im_module_init(void);
 void bfad_im_module_exit(void);
 bfa_status_t bfad_im_probe(struct bfad_s *bfad);
 void bfad_im_probe_undo(struct bfad_s *bfad);
-void bfad_im_probe_post(struct bfad_im_s *im);
 bfa_status_t bfad_im_port_new(struct bfad_s *bfad, struct bfad_port_s *port);
 void bfad_im_port_delete(struct bfad_s *bfad, struct bfad_port_s *port);
-void bfad_im_port_online(struct bfad_s *bfad, struct bfad_port_s *port);
-void bfad_im_port_offline(struct bfad_s *bfad, struct bfad_port_s *port);
 void bfad_im_port_clean(struct bfad_im_port_s *im_port);
 int  bfad_im_scsi_host_alloc(struct bfad_s *bfad,
                struct bfad_im_port_s *im_port, struct device *dev);
@@ -44,14 +44,10 @@ void bfad_im_scsi_host_free(struct bfad_s *bfad,
 #define BFAD_LUN_RESET_TMO 60
 #define ScsiResult(host_code, scsi_code) (((host_code) << 16) | scsi_code)
 #define BFA_QUEUE_FULL_RAMP_UP_TIME 120
-#define BFAD_KOBJ_NAME_LEN 20
 
 /*
  * itnim flags
  */
-#define ITNIM_MAPPED           0x00000001
-
-#define SCSI_TASK_MGMT         0x00000001
 #define IO_DONE_BIT                    0
 
 struct bfad_itnim_data_s {
@@ -64,7 +60,7 @@ struct bfad_im_port_s {
        struct work_struct port_delete_work;
        int             idr_id;
        u16        cur_scsi_id;
-       u16        flags;
+       u16     flags;
        struct list_head binding_list;
        struct Scsi_Host *shost;
        struct list_head itnim_mapped_list;
@@ -118,14 +114,13 @@ struct bfad_fcp_binding {
 struct bfad_im_s {
        struct bfad_s         *bfad;
        struct workqueue_struct *drv_workq;
-       char   drv_workq_name[BFAD_KOBJ_NAME_LEN];
+       char            drv_workq_name[KOBJ_NAME_LEN];
 };
 
 struct Scsi_Host *bfad_os_scsi_host_alloc(struct bfad_im_port_s *im_port,
                                struct bfad_s *);
 bfa_status_t bfad_os_thread_workq(struct bfad_s *bfad);
 void bfad_os_destroy_workq(struct bfad_im_s *im);
-void bfad_os_itnim_process(struct bfad_itnim_s *itnim_drv);
 void bfad_os_fc_host_init(struct bfad_im_port_s *im_port);
 void bfad_os_scsi_host_free(struct bfad_s *bfad,
                                 struct bfad_im_port_s *im_port);
@@ -133,11 +128,6 @@ void bfad_os_ramp_up_qdepth(struct bfad_itnim_s *itnim,
                                 struct scsi_device *sdev);
 void bfad_os_handle_qfull(struct bfad_itnim_s *itnim, struct scsi_device *sdev);
 struct bfad_itnim_s *bfad_os_get_itnim(struct bfad_im_port_s *im_port, int id);
-int bfad_os_scsi_add_host(struct Scsi_Host *shost,
-               struct bfad_im_port_s *im_port, struct bfad_s *bfad);
-
-void bfad_im_itnim_unmap(struct bfad_im_port_s  *im_port,
-                        struct bfad_itnim_s *itnim);
 
 extern struct scsi_host_template bfad_im_scsi_host_template;
 extern struct scsi_host_template bfad_im_vport_template;
@@ -146,4 +136,34 @@ extern struct fc_function_template bfad_im_vport_fc_function_template;
 extern struct scsi_transport_template *bfad_im_scsi_transport_template;
 extern struct scsi_transport_template *bfad_im_scsi_vport_transport_template;
 
+extern struct device_attribute *bfad_im_host_attrs[];
+extern struct device_attribute *bfad_im_vport_attrs[];
+
+irqreturn_t bfad_intx(int irq, void *dev_id);
+
+/* Firmware releated */
+#define BFAD_FW_FILE_CT_FC      "ctfw_fc.bin"
+#define BFAD_FW_FILE_CT_CNA     "ctfw_cna.bin"
+#define BFAD_FW_FILE_CB_FC      "cbfw_fc.bin"
+
+u32 *bfad_get_firmware_buf(struct pci_dev *pdev);
+u32 *bfad_read_firmware(struct pci_dev *pdev, u32 **bfi_image,
+               u32 *bfi_image_size, char *fw_name);
+
+static inline u32 *
+bfad_load_fwimg(struct pci_dev *pdev)
+{
+       return bfad_get_firmware_buf(pdev);
+}
+
+static inline void
+bfad_free_fwimg(void)
+{
+       if (bfi_image_ct_fc_size && bfi_image_ct_fc)
+               vfree(bfi_image_ct_fc);
+       if (bfi_image_ct_cna_size && bfi_image_ct_cna)
+               vfree(bfi_image_ct_cna);
+       if (bfi_image_cb_fc_size && bfi_image_cb_fc)
+               vfree(bfi_image_cb_fc);
+}
 #endif
diff --git a/drivers/scsi/bfa/bfad_im_compat.h b/drivers/scsi/bfa/bfad_im_compat.h
deleted file mode 100644 (file)
index 0a122ab..0000000
+++ /dev/null
@@ -1,45 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFAD_IM_COMPAT_H__
-#define __BFAD_IM_COMPAT_H__
-
-extern struct device_attribute *bfad_im_host_attrs[];
-extern struct device_attribute *bfad_im_vport_attrs[];
-
-u32 *bfad_get_firmware_buf(struct pci_dev *pdev);
-u32 *bfad_read_firmware(struct pci_dev *pdev, u32 **bfi_image,
-                       u32 *bfi_image_size, char *fw_name);
-
-static inline u32 *
-bfad_load_fwimg(struct pci_dev *pdev)
-{
-       return bfad_get_firmware_buf(pdev);
-}
-
-static inline void
-bfad_free_fwimg(void)
-{
-       if (bfi_image_ct_fc_size && bfi_image_ct_fc)
-               vfree(bfi_image_ct_fc);
-       if (bfi_image_ct_cna_size && bfi_image_ct_cna)
-               vfree(bfi_image_ct_cna);
-       if (bfi_image_cb_fc_size && bfi_image_cb_fc)
-               vfree(bfi_image_cb_fc);
-}
-
-#endif
diff --git a/drivers/scsi/bfa/bfad_intr.c b/drivers/scsi/bfa/bfad_intr.c
deleted file mode 100644 (file)
index 56a3515..0000000
+++ /dev/null
@@ -1,222 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#include "bfad_drv.h"
-#include "bfad_trcmod.h"
-
-BFA_TRC_FILE(LDRV, INTR);
-
-/**
- *  bfa_isr BFA driver interrupt functions
- */
-static int msix_disable_cb;
-static int msix_disable_ct;
-module_param(msix_disable_cb, int, S_IRUGO | S_IWUSR);
-MODULE_PARM_DESC(msix_disable_cb, "Disable MSIX for Brocade-415/425/815/825"
-               " cards, default=0, Range[false:0|true:1]");
-module_param(msix_disable_ct, int, S_IRUGO | S_IWUSR);
-MODULE_PARM_DESC(msix_disable_ct, "Disable MSIX for Brocade-1010/1020/804"
-               " cards, default=0, Range[false:0|true:1]");
-/**
- * Line based interrupt handler.
- */
-static irqreturn_t
-bfad_intx(int irq, void *dev_id)
-{
-       struct bfad_s         *bfad = dev_id;
-       struct list_head         doneq;
-       unsigned long   flags;
-       bfa_boolean_t rc;
-
-       spin_lock_irqsave(&bfad->bfad_lock, flags);
-       rc = bfa_intx(&bfad->bfa);
-       if (!rc) {
-               spin_unlock_irqrestore(&bfad->bfad_lock, flags);
-               return IRQ_NONE;
-       }
-
-       bfa_comp_deq(&bfad->bfa, &doneq);
-       spin_unlock_irqrestore(&bfad->bfad_lock, flags);
-
-       if (!list_empty(&doneq)) {
-               bfa_comp_process(&bfad->bfa, &doneq);
-
-               spin_lock_irqsave(&bfad->bfad_lock, flags);
-               bfa_comp_free(&bfad->bfa, &doneq);
-               spin_unlock_irqrestore(&bfad->bfad_lock, flags);
-               bfa_trc_fp(bfad, irq);
-       }
-
-       return IRQ_HANDLED;
-
-}
-
-static irqreturn_t
-bfad_msix(int irq, void *dev_id)
-{
-       struct bfad_msix_s *vec = dev_id;
-       struct bfad_s *bfad = vec->bfad;
-       struct list_head doneq;
-       unsigned long   flags;
-
-       spin_lock_irqsave(&bfad->bfad_lock, flags);
-
-       bfa_msix(&bfad->bfa, vec->msix.entry);
-       bfa_comp_deq(&bfad->bfa, &doneq);
-       spin_unlock_irqrestore(&bfad->bfad_lock, flags);
-
-       if (!list_empty(&doneq)) {
-               bfa_comp_process(&bfad->bfa, &doneq);
-
-               spin_lock_irqsave(&bfad->bfad_lock, flags);
-               bfa_comp_free(&bfad->bfa, &doneq);
-               spin_unlock_irqrestore(&bfad->bfad_lock, flags);
-       }
-
-       return IRQ_HANDLED;
-}
-
-/**
- * Initialize the MSIX entry table.
- */
-static void
-bfad_init_msix_entry(struct bfad_s *bfad, struct msix_entry *msix_entries,
-                        int mask, int max_bit)
-{
-       int             i;
-       int             match = 0x00000001;
-
-       for (i = 0, bfad->nvec = 0; i < MAX_MSIX_ENTRY; i++) {
-               if (mask & match) {
-                       bfad->msix_tab[bfad->nvec].msix.entry = i;
-                       bfad->msix_tab[bfad->nvec].bfad = bfad;
-                       msix_entries[bfad->nvec].entry = i;
-                       bfad->nvec++;
-               }
-
-               match <<= 1;
-       }
-
-}
-
-int
-bfad_install_msix_handler(struct bfad_s *bfad)
-{
-       int             i, error = 0;
-
-       for (i = 0; i < bfad->nvec; i++) {
-               error = request_irq(bfad->msix_tab[i].msix.vector,
-                                   (irq_handler_t) bfad_msix, 0,
-                                   BFAD_DRIVER_NAME, &bfad->msix_tab[i]);
-               bfa_trc(bfad, i);
-               bfa_trc(bfad, bfad->msix_tab[i].msix.vector);
-               if (error) {
-                       int             j;
-
-                       for (j = 0; j < i; j++)
-                               free_irq(bfad->msix_tab[j].msix.vector,
-                                               &bfad->msix_tab[j]);
-
-                       return 1;
-               }
-       }
-
-       return 0;
-}
-
-/**
- * Setup MSIX based interrupt.
- */
-int
-bfad_setup_intr(struct bfad_s *bfad)
-{
-       int error = 0;
-       u32 mask = 0, i, num_bit = 0, max_bit = 0;
-       struct msix_entry msix_entries[MAX_MSIX_ENTRY];
-       struct pci_dev *pdev = bfad->pcidev;
-
-       /* Call BFA to get the msix map for this PCI function.  */
-       bfa_msix_getvecs(&bfad->bfa, &mask, &num_bit, &max_bit);
-
-       /* Set up the msix entry table */
-       bfad_init_msix_entry(bfad, msix_entries, mask, max_bit);
-
-       if ((bfa_asic_id_ct(pdev->device) && !msix_disable_ct) ||
-               (!bfa_asic_id_ct(pdev->device) && !msix_disable_cb)) {
-
-               error = pci_enable_msix(bfad->pcidev, msix_entries, bfad->nvec);
-               if (error) {
-                       /*
-                        * Only error number of vector is available.
-                        * We don't have a mechanism to map multiple
-                        * interrupts into one vector, so even if we
-                        * can try to request less vectors, we don't
-                        * know how to associate interrupt events to
-                        *  vectors. Linux doesn't dupicate vectors
-                        * in the MSIX table for this case.
-                        */
-
-                       printk(KERN_WARNING "bfad%d: "
-                               "pci_enable_msix failed (%d),"
-                               " use line based.\n", bfad->inst_no, error);
-
-                       goto line_based;
-               }
-
-               /* Save the vectors */
-               for (i = 0; i < bfad->nvec; i++) {
-                       bfa_trc(bfad, msix_entries[i].vector);
-                       bfad->msix_tab[i].msix.vector = msix_entries[i].vector;
-               }
-
-               bfa_msix_init(&bfad->bfa, bfad->nvec);
-
-               bfad->bfad_flags |= BFAD_MSIX_ON;
-
-               return error;
-       }
-
-line_based:
-       error = 0;
-       if (request_irq
-           (bfad->pcidev->irq, (irq_handler_t) bfad_intx, BFAD_IRQ_FLAGS,
-            BFAD_DRIVER_NAME, bfad) != 0) {
-               /* Enable interrupt handler failed */
-               return 1;
-       }
-
-       return error;
-}
-
-void
-bfad_remove_intr(struct bfad_s *bfad)
-{
-       int             i;
-
-       if (bfad->bfad_flags & BFAD_MSIX_ON) {
-               for (i = 0; i < bfad->nvec; i++)
-                       free_irq(bfad->msix_tab[i].msix.vector,
-                                       &bfad->msix_tab[i]);
-
-               pci_disable_msix(bfad->pcidev);
-               bfad->bfad_flags &= ~BFAD_MSIX_ON;
-       } else {
-               free_irq(bfad->pcidev->irq, bfad);
-       }
-}
-
-
diff --git a/drivers/scsi/bfa/bfad_ipfc.h b/drivers/scsi/bfa/bfad_ipfc.h
deleted file mode 100644 (file)
index 718bc52..0000000
+++ /dev/null
@@ -1,42 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-#ifndef __BFA_DRV_IPFC_H__
-#define __BFA_DRV_IPFC_H__
-
-
-#define IPFC_NAME ""
-
-#define bfad_ipfc_module_init(x) do {} while (0)
-#define bfad_ipfc_module_exit(x) do {} while (0)
-#define bfad_ipfc_probe(x) do {} while (0)
-#define bfad_ipfc_probe_undo(x) do {} while (0)
-#define bfad_ipfc_port_config(x, y) BFA_STATUS_OK
-#define bfad_ipfc_port_unconfig(x, y) do {} while (0)
-
-#define bfad_ipfc_probe_post(x) do {} while (0)
-#define bfad_ipfc_port_new(x, y, z) BFA_STATUS_OK
-#define bfad_ipfc_port_delete(x, y) do {} while (0)
-#define bfad_ipfc_port_online(x, y) do {} while (0)
-#define bfad_ipfc_port_offline(x, y) do {} while (0)
-
-#define bfad_ip_get_attr(x) BFA_STATUS_FAILED
-#define bfad_ip_reset_drv_stats(x) BFA_STATUS_FAILED
-#define bfad_ip_get_drv_stats(x, y) BFA_STATUS_FAILED
-#define bfad_ip_enable_ipfc(x, y, z) BFA_STATUS_FAILED
-
-
-#endif
diff --git a/drivers/scsi/bfa/bfad_os.c b/drivers/scsi/bfa/bfad_os.c
deleted file mode 100644 (file)
index faf47b4..0000000
+++ /dev/null
@@ -1,50 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  bfad_os.c Linux driver OS specific calls.
- */
-
-#include "bfa_os_inc.h"
-#include "bfad_drv.h"
-
-void
-bfa_os_gettimeofday(struct bfa_timeval_s *tv)
-{
-       struct timeval  tmp_tv;
-
-       do_gettimeofday(&tmp_tv);
-       tv->tv_sec = (u32) tmp_tv.tv_sec;
-       tv->tv_usec = (u32) tmp_tv.tv_usec;
-}
-
-void
-bfa_os_printf(struct bfa_log_mod_s *log_mod, u32 msg_id,
-                       const char *fmt, ...)
-{
-       va_list ap;
-       #define BFA_STRING_256  256
-       char tmp[BFA_STRING_256];
-
-       va_start(ap, fmt);
-       vsprintf(tmp, fmt, ap);
-       va_end(ap);
-
-       printk(tmp);
-}
-
-
diff --git a/drivers/scsi/bfa/bfad_tm.h b/drivers/scsi/bfa/bfad_tm.h
deleted file mode 100644 (file)
index 4901b1b..0000000
+++ /dev/null
@@ -1,59 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/*
- * Brocade Fibre Channel HBA Linux Target Mode Driver
- */
-
-/**
- *  tm/dummy/bfad_tm.h BFA callback dummy header file for BFA Linux target mode PCI interface module.
- */
-
-#ifndef __BFAD_TM_H__
-#define __BFAD_TM_H__
-
-#include <defs/bfa_defs_status.h>
-
-#define FCPT_NAME              ""
-
-/*
- * Called from base Linux driver on (De)Init events
- */
-
-/* attach tgt template with scst */
-#define bfad_tm_module_init()  do {} while (0)
-
-/* detach/release tgt template */
-#define bfad_tm_module_exit()  do {} while (0)
-
-#define bfad_tm_probe(x)       do {} while (0)
-#define bfad_tm_probe_undo(x)  do {} while (0)
-#define bfad_tm_probe_post(x)  do {} while (0)
-
-/*
- * Called by base Linux driver but triggered by BFA FCS on config events
- */
-#define bfad_tm_port_new(x, y)         BFA_STATUS_OK
-#define bfad_tm_port_delete(x, y)      do {} while (0)
-
-/*
- * Called by base Linux driver but triggered by BFA FCS on PLOGI/O events
- */
-#define bfad_tm_port_online(x, y)      do {} while (0)
-#define bfad_tm_port_offline(x, y)     do {} while (0)
-
-#endif
diff --git a/drivers/scsi/bfa/bfad_trcmod.h b/drivers/scsi/bfa/bfad_trcmod.h
deleted file mode 100644 (file)
index 2827b2a..0000000
+++ /dev/null
@@ -1,52 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  bfad_trcmod.h Linux driver trace modules
- */
-
-
-#ifndef __BFAD_TRCMOD_H__
-#define __BFAD_TRCMOD_H__
-
-#include <cs/bfa_trc.h>
-
-/*
- * !!! Only append to the enums defined here to avoid any versioning
- * !!! needed between trace utility and driver version
- */
-enum {
-       /* 2.6 Driver */
-       BFA_TRC_LDRV_BFAD               = 1,
-       BFA_TRC_LDRV_BFAD_2_6           = 2,
-       BFA_TRC_LDRV_BFAD_2_6_9         = 3,
-       BFA_TRC_LDRV_BFAD_2_6_10        = 4,
-       BFA_TRC_LDRV_INTR               = 5,
-       BFA_TRC_LDRV_IOCTL              = 6,
-       BFA_TRC_LDRV_OS                 = 7,
-       BFA_TRC_LDRV_IM                 = 8,
-       BFA_TRC_LDRV_IM_2_6             = 9,
-       BFA_TRC_LDRV_IM_2_6_9           = 10,
-       BFA_TRC_LDRV_IM_2_6_10          = 11,
-       BFA_TRC_LDRV_TM                 = 12,
-       BFA_TRC_LDRV_IPFC               = 13,
-       BFA_TRC_LDRV_IM_2_4             = 14,
-       BFA_TRC_LDRV_IM_VMW             = 15,
-       BFA_TRC_LDRV_IM_LT_2_6_10       = 16,
-};
-
-#endif /* __BFAD_TRCMOD_H__ */
diff --git a/drivers/scsi/bfa/bfi.h b/drivers/scsi/bfa/bfi.h
new file mode 100644 (file)
index 0000000..85f2224
--- /dev/null
@@ -0,0 +1,579 @@
+/*
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
+ * All rights reserved
+ * www.brocade.com
+ *
+ * Linux driver for Brocade Fibre Channel Host Bus Adapter.
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License (GPL) Version 2 as
+ * published by the Free Software Foundation
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * General Public License for more details.
+ */
+
+#ifndef __BFI_H__
+#define __BFI_H__
+
+#include "bfa_defs.h"
+#include "bfa_defs_svc.h"
+
+#pragma pack(1)
+
+/**
+ * BFI FW image type
+ */
+#define        BFI_FLASH_CHUNK_SZ                      256     /*  Flash chunk size */
+#define        BFI_FLASH_CHUNK_SZ_WORDS        (BFI_FLASH_CHUNK_SZ/sizeof(u32))
+enum {
+       BFI_IMAGE_CB_FC,
+       BFI_IMAGE_CT_FC,
+       BFI_IMAGE_CT_CNA,
+       BFI_IMAGE_MAX,
+};
+
+/**
+ * Msg header common to all msgs
+ */
+struct bfi_mhdr_s {
+       u8              msg_class;      /*  @ref bfi_mclass_t               */
+       u8              msg_id;         /*  msg opcode with in the class   */
+       union {
+               struct {
+                       u8      rsvd;
+                       u8      lpu_id; /*  msg destination                 */
+               } h2i;
+               u16     i2htok; /*  token in msgs to host           */
+       } mtag;
+};
+
+#define bfi_h2i_set(_mh, _mc, _op, _lpuid) do {                \
+       (_mh).msg_class         = (_mc);      \
+       (_mh).msg_id            = (_op);      \
+       (_mh).mtag.h2i.lpu_id   = (_lpuid);      \
+} while (0)
+
+#define bfi_i2h_set(_mh, _mc, _op, _i2htok) do {               \
+       (_mh).msg_class         = (_mc);      \
+       (_mh).msg_id            = (_op);      \
+       (_mh).mtag.i2htok       = (_i2htok);      \
+} while (0)
+
+/*
+ * Message opcodes: 0-127 to firmware, 128-255 to host
+ */
+#define BFI_I2H_OPCODE_BASE    128
+#define BFA_I2HM(_x)           ((_x) + BFI_I2H_OPCODE_BASE)
+
+/**
+ ****************************************************************************
+ *
+ * Scatter Gather Element and Page definition
+ *
+ ****************************************************************************
+ */
+
+#define BFI_SGE_INLINE 1
+#define BFI_SGE_INLINE_MAX     (BFI_SGE_INLINE + 1)
+
+/**
+ * SG Flags
+ */
+enum {
+       BFI_SGE_DATA            = 0,    /*  data address, not last           */
+       BFI_SGE_DATA_CPL        = 1,    /*  data addr, last in current page */
+       BFI_SGE_DATA_LAST       = 3,    /*  data address, last               */
+       BFI_SGE_LINK            = 2,    /*  link address                     */
+       BFI_SGE_PGDLEN          = 2,    /*  cumulative data length for page */
+};
+
+/**
+ * DMA addresses
+ */
+union bfi_addr_u {
+       struct {
+               u32     addr_lo;
+               u32     addr_hi;
+       } a32;
+};
+
+/**
+ * Scatter Gather Element
+ */
+struct bfi_sge_s {
+#ifdef __BIGENDIAN
+       u32     flags:2,
+                       rsvd:2,
+                       sg_len:28;
+#else
+       u32     sg_len:28,
+                       rsvd:2,
+                       flags:2;
+#endif
+       union bfi_addr_u sga;
+};
+
+/**
+ * Scatter Gather Page
+ */
+#define BFI_SGPG_DATA_SGES             7
+#define BFI_SGPG_SGES_MAX              (BFI_SGPG_DATA_SGES + 1)
+#define BFI_SGPG_RSVD_WD_LEN   8
+struct bfi_sgpg_s {
+       struct bfi_sge_s sges[BFI_SGPG_SGES_MAX];
+       u32     rsvd[BFI_SGPG_RSVD_WD_LEN];
+};
+
+/*
+ * Large Message structure - 128 Bytes size Msgs
+ */
+#define BFI_LMSG_SZ            128
+#define BFI_LMSG_PL_WSZ        \
+                       ((BFI_LMSG_SZ - sizeof(struct bfi_mhdr_s)) / 4)
+
+struct bfi_msg_s {
+       struct bfi_mhdr_s mhdr;
+       u32     pl[BFI_LMSG_PL_WSZ];
+};
+
+/**
+ * Mailbox message structure
+ */
+#define BFI_MBMSG_SZ           7
+struct bfi_mbmsg_s {
+       struct bfi_mhdr_s       mh;
+       u32             pl[BFI_MBMSG_SZ];
+};
+
+/**
+ * Message Classes
+ */
+enum bfi_mclass {
+       BFI_MC_IOC              = 1,    /*  IO Controller (IOC)     */
+       BFI_MC_FCPORT           = 5,    /*  FC port                         */
+       BFI_MC_IOCFC            = 6,    /*  FC - IO Controller (IOC)        */
+       BFI_MC_LL               = 7,    /*  Link Layer                      */
+       BFI_MC_UF               = 8,    /*  Unsolicited frame receive       */
+       BFI_MC_FCXP             = 9,    /*  FC Transport                    */
+       BFI_MC_LPS              = 10,   /*  lport fc login services         */
+       BFI_MC_RPORT            = 11,   /*  Remote port             */
+       BFI_MC_ITNIM            = 12,   /*  I-T nexus (Initiator mode)      */
+       BFI_MC_IOIM_READ        = 13,   /*  read IO (Initiator mode)        */
+       BFI_MC_IOIM_WRITE       = 14,   /*  write IO (Initiator mode)       */
+       BFI_MC_IOIM_IO          = 15,   /*  IO (Initiator mode)     */
+       BFI_MC_IOIM             = 16,   /*  IO (Initiator mode)     */
+       BFI_MC_IOIM_IOCOM       = 17,   /*  good IO completion              */
+       BFI_MC_TSKIM            = 18,   /*  Initiator Task management       */
+       BFI_MC_PORT             = 21,   /*  Physical port                   */
+       BFI_MC_MAX              = 32
+};
+
+#define BFI_IOC_MAX_CQS                4
+#define BFI_IOC_MAX_CQS_ASIC   8
+#define BFI_IOC_MSGLEN_MAX     32      /* 32 bytes */
+
+#define BFI_BOOT_TYPE_OFF              8
+#define BFI_BOOT_LOADER_OFF            12
+
+#define BFI_BOOT_TYPE_NORMAL           0
+#define        BFI_BOOT_TYPE_FLASH             1
+#define        BFI_BOOT_TYPE_MEMTEST           2
+
+#define BFI_BOOT_LOADER_OS             0
+#define BFI_BOOT_LOADER_BIOS           1
+#define BFI_BOOT_LOADER_UEFI           2
+
+/**
+ *----------------------------------------------------------------------
+ *                             IOC
+ *----------------------------------------------------------------------
+ */
+
+enum bfi_ioc_h2i_msgs {
+       BFI_IOC_H2I_ENABLE_REQ          = 1,
+       BFI_IOC_H2I_DISABLE_REQ         = 2,
+       BFI_IOC_H2I_GETATTR_REQ         = 3,
+       BFI_IOC_H2I_DBG_SYNC            = 4,
+       BFI_IOC_H2I_DBG_DUMP            = 5,
+};
+
+enum bfi_ioc_i2h_msgs {
+       BFI_IOC_I2H_ENABLE_REPLY        = BFA_I2HM(1),
+       BFI_IOC_I2H_DISABLE_REPLY       = BFA_I2HM(2),
+       BFI_IOC_I2H_GETATTR_REPLY       = BFA_I2HM(3),
+       BFI_IOC_I2H_READY_EVENT         = BFA_I2HM(4),
+       BFI_IOC_I2H_HBEAT               = BFA_I2HM(5),
+};
+
+/**
+ * BFI_IOC_H2I_GETATTR_REQ message
+ */
+struct bfi_ioc_getattr_req_s {
+       struct bfi_mhdr_s       mh;
+       union bfi_addr_u        attr_addr;
+};
+
+struct bfi_ioc_attr_s {
+       wwn_t           mfg_pwwn;       /*  Mfg port wwn           */
+       wwn_t           mfg_nwwn;       /*  Mfg node wwn           */
+       mac_t           mfg_mac;        /*  Mfg mac                */
+       u16     rsvd_a;
+       wwn_t           pwwn;
+       wwn_t           nwwn;
+       mac_t           mac;            /*  PBC or Mfg mac         */
+       u16     rsvd_b;
+       mac_t           fcoe_mac;
+       u16     rsvd_c;
+       char            brcd_serialnum[STRSZ(BFA_MFG_SERIALNUM_SIZE)];
+       u8              pcie_gen;
+       u8              pcie_lanes_orig;
+       u8              pcie_lanes;
+       u8              rx_bbcredit;    /*  receive buffer credits */
+       u32     adapter_prop;   /*  adapter properties     */
+       u16     maxfrsize;      /*  max receive frame size */
+       char            asic_rev;
+       u8              rsvd_d;
+       char            fw_version[BFA_VERSION_LEN];
+       char            optrom_version[BFA_VERSION_LEN];
+       struct          bfa_mfg_vpd_s   vpd;
+       u32     card_type;      /*  card type                   */
+};
+
+/**
+ * BFI_IOC_I2H_GETATTR_REPLY message
+ */
+struct bfi_ioc_getattr_reply_s {
+       struct  bfi_mhdr_s      mh;     /*  Common msg header           */
+       u8                      status; /*  cfg reply status            */
+       u8                      rsvd[3];
+};
+
+/**
+ * Firmware memory page offsets
+ */
+#define BFI_IOC_SMEM_PG0_CB    (0x40)
+#define BFI_IOC_SMEM_PG0_CT    (0x180)
+
+/**
+ * Firmware statistic offset
+ */
+#define BFI_IOC_FWSTATS_OFF    (0x6B40)
+#define BFI_IOC_FWSTATS_SZ     (4096)
+
+/**
+ * Firmware trace offset
+ */
+#define BFI_IOC_TRC_OFF                (0x4b00)
+#define BFI_IOC_TRC_ENTS       256
+
+#define BFI_IOC_FW_SIGNATURE   (0xbfadbfad)
+#define BFI_IOC_MD5SUM_SZ      4
+struct bfi_ioc_image_hdr_s {
+       u32     signature;      /*  constant signature */
+       u32     rsvd_a;
+       u32     exec;           /*  exec vector */
+       u32     param;          /*  parameters          */
+       u32     rsvd_b[4];
+       u32     md5sum[BFI_IOC_MD5SUM_SZ];
+};
+
+/**
+ *  BFI_IOC_I2H_READY_EVENT message
+ */
+struct bfi_ioc_rdy_event_s {
+       struct bfi_mhdr_s       mh;             /*  common msg header */
+       u8                      init_status;    /*  init event status */
+       u8                      rsvd[3];
+};
+
+struct bfi_ioc_hbeat_s {
+       struct bfi_mhdr_s  mh;          /*  common msg header           */
+       u32        hb_count;    /*  current heart beat count    */
+};
+
+/**
+ * IOC hardware/firmware state
+ */
+enum bfi_ioc_state {
+       BFI_IOC_UNINIT          = 0,    /*  not initialized                  */
+       BFI_IOC_INITING         = 1,    /*  h/w is being initialized         */
+       BFI_IOC_HWINIT          = 2,    /*  h/w is initialized               */
+       BFI_IOC_CFG             = 3,    /*  IOC configuration in progress   */
+       BFI_IOC_OP              = 4,    /*  IOC is operational               */
+       BFI_IOC_DISABLING       = 5,    /*  IOC is being disabled            */
+       BFI_IOC_DISABLED        = 6,    /*  IOC is disabled                  */
+       BFI_IOC_CFG_DISABLED    = 7,    /*  IOC is being disabled;transient */
+       BFI_IOC_FAIL            = 8,    /*  IOC heart-beat failure           */
+       BFI_IOC_MEMTEST         = 9,    /*  IOC is doing memtest             */
+};
+
+#define BFI_IOC_ENDIAN_SIG  0x12345678
+
+enum {
+       BFI_ADAPTER_TYPE_FC     = 0x01,         /*  FC adapters    */
+       BFI_ADAPTER_TYPE_MK     = 0x0f0000,     /*  adapter type mask     */
+       BFI_ADAPTER_TYPE_SH     = 16,           /*  adapter type shift    */
+       BFI_ADAPTER_NPORTS_MK   = 0xff00,       /*  number of ports mask  */
+       BFI_ADAPTER_NPORTS_SH   = 8,            /*  number of ports shift */
+       BFI_ADAPTER_SPEED_MK    = 0xff,         /*  adapter speed mask    */
+       BFI_ADAPTER_SPEED_SH    = 0,            /*  adapter speed shift   */
+       BFI_ADAPTER_PROTO       = 0x100000,     /*  prototype adapaters   */
+       BFI_ADAPTER_TTV         = 0x200000,     /*  TTV debug capable     */
+       BFI_ADAPTER_UNSUPP      = 0x400000,     /*  unknown adapter type  */
+};
+
+#define BFI_ADAPTER_GETP(__prop, __adap_prop)                  \
+       (((__adap_prop) & BFI_ADAPTER_ ## __prop ## _MK) >>     \
+               BFI_ADAPTER_ ## __prop ## _SH)
+#define BFI_ADAPTER_SETP(__prop, __val)                                \
+       ((__val) << BFI_ADAPTER_ ## __prop ## _SH)
+#define BFI_ADAPTER_IS_PROTO(__adap_type)                      \
+       ((__adap_type) & BFI_ADAPTER_PROTO)
+#define BFI_ADAPTER_IS_TTV(__adap_type)                                \
+       ((__adap_type) & BFI_ADAPTER_TTV)
+#define BFI_ADAPTER_IS_UNSUPP(__adap_type)                     \
+       ((__adap_type) & BFI_ADAPTER_UNSUPP)
+#define BFI_ADAPTER_IS_SPECIAL(__adap_type)                    \
+       ((__adap_type) & (BFI_ADAPTER_TTV | BFI_ADAPTER_PROTO | \
+                       BFI_ADAPTER_UNSUPP))
+
+/**
+ * BFI_IOC_H2I_ENABLE_REQ & BFI_IOC_H2I_DISABLE_REQ messages
+ */
+struct bfi_ioc_ctrl_req_s {
+       struct bfi_mhdr_s       mh;
+       u8                      ioc_class;
+       u8                      rsvd[3];
+       u32             tv_sec;
+};
+#define bfi_ioc_enable_req_t struct bfi_ioc_ctrl_req_s;
+#define bfi_ioc_disable_req_t struct bfi_ioc_ctrl_req_s;
+
+/**
+ * BFI_IOC_I2H_ENABLE_REPLY & BFI_IOC_I2H_DISABLE_REPLY messages
+ */
+struct bfi_ioc_ctrl_reply_s {
+       struct bfi_mhdr_s       mh;             /*  Common msg header     */
+       u8                      status;         /*  enable/disable status */
+       u8                      rsvd[3];
+};
+#define bfi_ioc_enable_reply_t struct bfi_ioc_ctrl_reply_s;
+#define bfi_ioc_disable_reply_t struct bfi_ioc_ctrl_reply_s;
+
+#define BFI_IOC_MSGSZ   8
+/**
+ * H2I Messages
+ */
+union bfi_ioc_h2i_msg_u {
+       struct bfi_mhdr_s               mh;
+       struct bfi_ioc_ctrl_req_s       enable_req;
+       struct bfi_ioc_ctrl_req_s       disable_req;
+       struct bfi_ioc_getattr_req_s    getattr_req;
+       u32                     mboxmsg[BFI_IOC_MSGSZ];
+};
+
+/**
+ * I2H Messages
+ */
+union bfi_ioc_i2h_msg_u {
+       struct bfi_mhdr_s               mh;
+       struct bfi_ioc_rdy_event_s      rdy_event;
+       u32                     mboxmsg[BFI_IOC_MSGSZ];
+};
+
+
+/**
+ *----------------------------------------------------------------------
+ *                             PBC
+ *----------------------------------------------------------------------
+ */
+
+#define BFI_PBC_MAX_BLUNS      8
+#define BFI_PBC_MAX_VPORTS     16
+
+/**
+ * PBC boot lun configuration
+ */
+struct bfi_pbc_blun_s {
+       wwn_t           tgt_pwwn;
+       lun_t           tgt_lun;
+};
+
+/**
+ * PBC virtual port configuration
+ */
+struct bfi_pbc_vport_s {
+       wwn_t           vp_pwwn;
+       wwn_t           vp_nwwn;
+};
+
+/**
+ * BFI pre-boot configuration information
+ */
+struct bfi_pbc_s {
+       u8              port_enabled;
+       u8              boot_enabled;
+       u8              nbluns;
+       u8              nvports;
+       u8              port_speed;
+       u8              rsvd_a;
+       u16     hss;
+       wwn_t           pbc_pwwn;
+       wwn_t           pbc_nwwn;
+       struct bfi_pbc_blun_s blun[BFI_PBC_MAX_BLUNS];
+       struct bfi_pbc_vport_s vport[BFI_PBC_MAX_VPORTS];
+};
+
+/**
+ *----------------------------------------------------------------------
+ *                             MSGQ
+ *----------------------------------------------------------------------
+ */
+#define BFI_MSGQ_FULL(_q)      (((_q->pi + 1) % _q->q_depth) == _q->ci)
+#define BFI_MSGQ_EMPTY(_q)     (_q->pi == _q->ci)
+#define BFI_MSGQ_UPDATE_CI(_q) (_q->ci = (_q->ci + 1) % _q->q_depth)
+#define BFI_MSGQ_UPDATE_PI(_q) (_q->pi = (_q->pi + 1) % _q->q_depth)
+
+/* q_depth must be power of 2 */
+#define BFI_MSGQ_FREE_CNT(_q)  ((_q->ci - _q->pi - 1) & (_q->q_depth - 1))
+
+enum bfi_msgq_h2i_msgs_e {
+       BFI_MSGQ_H2I_INIT_REQ   = 1,
+       BFI_MSGQ_H2I_DOORBELL   = 2,
+       BFI_MSGQ_H2I_SHUTDOWN   = 3,
+};
+
+enum bfi_msgq_i2h_msgs_e {
+       BFI_MSGQ_I2H_INIT_RSP   = 1,
+       BFI_MSGQ_I2H_DOORBELL   = 2,
+};
+
+
+/* Messages(commands/responsed/AENS will have the following header */
+struct bfi_msgq_mhdr_s {
+       u8              msg_class;
+       u8              msg_id;
+       u16     msg_token;
+       u16     num_entries;
+       u8              enet_id;
+       u8              rsvd[1];
+};
+
+#define bfi_msgq_mhdr_set(_mh, _mc, _mid, _tok, _enet_id) do {        \
+       (_mh).msg_class         = (_mc);      \
+       (_mh).msg_id            = (_mid);      \
+       (_mh).msg_token         = (_tok);      \
+       (_mh).enet_id           = (_enet_id);      \
+} while (0)
+
+/*
+ * Mailbox  for messaging interface
+ *
+*/
+#define BFI_MSGQ_CMD_ENTRY_SIZE                (64)    /* TBD */
+#define BFI_MSGQ_RSP_ENTRY_SIZE                (64)    /* TBD */
+#define BFI_MSGQ_MSG_SIZE_MAX          (2048)  /* TBD */
+
+struct bfi_msgq_s {
+       union bfi_addr_u addr;
+       u16 q_depth;     /* Total num of entries in the queue */
+       u8 rsvd[2];
+};
+
+/* BFI_ENET_MSGQ_CFG_REQ TBD init or cfg? */
+struct bfi_msgq_cfg_req_s {
+       struct bfi_mhdr_s mh;
+       struct bfi_msgq_s cmdq;
+       struct bfi_msgq_s rspq;
+};
+
+/* BFI_ENET_MSGQ_CFG_RSP */
+struct bfi_msgq_cfg_rsp_s {
+       struct bfi_mhdr_s mh;
+       u8 cmd_status;
+       u8 rsvd[3];
+};
+
+
+/* BFI_MSGQ_H2I_DOORBELL */
+struct bfi_msgq_h2i_db_s {
+       struct bfi_mhdr_s mh;
+       u16 cmdq_pi;
+       u16 rspq_ci;
+};
+
+/* BFI_MSGQ_I2H_DOORBELL */
+struct bfi_msgq_i2h_db_s {
+       struct bfi_mhdr_s mh;
+       u16 rspq_pi;
+       u16 cmdq_ci;
+};
+
+#pragma pack()
+
+/* BFI port specific */
+#pragma pack(1)
+
+enum bfi_port_h2i {
+       BFI_PORT_H2I_ENABLE_REQ         = (1),
+       BFI_PORT_H2I_DISABLE_REQ        = (2),
+       BFI_PORT_H2I_GET_STATS_REQ      = (3),
+       BFI_PORT_H2I_CLEAR_STATS_REQ    = (4),
+};
+
+enum bfi_port_i2h {
+       BFI_PORT_I2H_ENABLE_RSP         = BFA_I2HM(1),
+       BFI_PORT_I2H_DISABLE_RSP        = BFA_I2HM(2),
+       BFI_PORT_I2H_GET_STATS_RSP      = BFA_I2HM(3),
+       BFI_PORT_I2H_CLEAR_STATS_RSP    = BFA_I2HM(4),
+};
+
+/**
+ * Generic REQ type
+ */
+struct bfi_port_generic_req_s {
+       struct bfi_mhdr_s  mh;          /*  msg header          */
+       u32     msgtag;         /*  msgtag for reply                */
+       u32     rsvd;
+};
+
+/**
+ * Generic RSP type
+ */
+struct bfi_port_generic_rsp_s {
+       struct bfi_mhdr_s  mh;          /*  common msg header               */
+       u8              status;         /*  port enable status              */
+       u8              rsvd[3];
+       u32     msgtag;         /*  msgtag for reply                */
+};
+
+/**
+ * BFI_PORT_H2I_GET_STATS_REQ
+ */
+struct bfi_port_get_stats_req_s {
+       struct bfi_mhdr_s  mh;          /*  common msg header               */
+       union bfi_addr_u   dma_addr;
+};
+
+union bfi_port_h2i_msg_u {
+       struct bfi_mhdr_s               mh;
+       struct bfi_port_generic_req_s   enable_req;
+       struct bfi_port_generic_req_s   disable_req;
+       struct bfi_port_get_stats_req_s getstats_req;
+       struct bfi_port_generic_req_s   clearstats_req;
+};
+
+union bfi_port_i2h_msg_u {
+       struct bfi_mhdr_s               mh;
+       struct bfi_port_generic_rsp_s   enable_rsp;
+       struct bfi_port_generic_rsp_s   disable_rsp;
+       struct bfi_port_generic_rsp_s   getstats_rsp;
+       struct bfi_port_generic_rsp_s   clearstats_rsp;
+};
+
+#pragma pack()
+
+#endif /* __BFI_H__ */
diff --git a/drivers/scsi/bfa/bfi_cbreg.h b/drivers/scsi/bfa/bfi_cbreg.h
new file mode 100644 (file)
index 0000000..6f03ed3
--- /dev/null
@@ -0,0 +1,304 @@
+
+/*
+ * bfi_cbreg.h crossbow host block register definitions
+ *
+ * !!! Do not edit. Auto generated. !!!
+ */
+
+#ifndef __BFI_CBREG_H__
+#define __BFI_CBREG_H__
+
+
+#define HOSTFN0_INT_STATUS               0x00014000
+#define __HOSTFN0_INT_STATUS_LVL_MK      0x00f00000
+#define __HOSTFN0_INT_STATUS_LVL_SH      20
+#define __HOSTFN0_INT_STATUS_LVL(_v)     ((_v) << __HOSTFN0_INT_STATUS_LVL_SH)
+#define __HOSTFN0_INT_STATUS_P           0x000fffff
+#define HOSTFN0_INT_MSK                  0x00014004
+#define HOST_PAGE_NUM_FN0                0x00014008
+#define __HOST_PAGE_NUM_FN               0x000001ff
+#define HOSTFN1_INT_STATUS               0x00014100
+#define __HOSTFN1_INT_STAT_LVL_MK        0x00f00000
+#define __HOSTFN1_INT_STAT_LVL_SH        20
+#define __HOSTFN1_INT_STAT_LVL(_v)       ((_v) << __HOSTFN1_INT_STAT_LVL_SH)
+#define __HOSTFN1_INT_STAT_P             0x000fffff
+#define HOSTFN1_INT_MSK                  0x00014104
+#define HOST_PAGE_NUM_FN1                0x00014108
+#define APP_PLL_400_CTL_REG              0x00014204
+#define __P_400_PLL_LOCK                 0x80000000
+#define __APP_PLL_400_SRAM_USE_100MHZ    0x00100000
+#define __APP_PLL_400_RESET_TIMER_MK     0x000e0000
+#define __APP_PLL_400_RESET_TIMER_SH     17
+#define __APP_PLL_400_RESET_TIMER(_v)    ((_v) << __APP_PLL_400_RESET_TIMER_SH)
+#define __APP_PLL_400_LOGIC_SOFT_RESET   0x00010000
+#define __APP_PLL_400_CNTLMT0_1_MK       0x0000c000
+#define __APP_PLL_400_CNTLMT0_1_SH       14
+#define __APP_PLL_400_CNTLMT0_1(_v)      ((_v) << __APP_PLL_400_CNTLMT0_1_SH)
+#define __APP_PLL_400_JITLMT0_1_MK       0x00003000
+#define __APP_PLL_400_JITLMT0_1_SH       12
+#define __APP_PLL_400_JITLMT0_1(_v)      ((_v) << __APP_PLL_400_JITLMT0_1_SH)
+#define __APP_PLL_400_HREF               0x00000800
+#define __APP_PLL_400_HDIV               0x00000400
+#define __APP_PLL_400_P0_1_MK            0x00000300
+#define __APP_PLL_400_P0_1_SH            8
+#define __APP_PLL_400_P0_1(_v)           ((_v) << __APP_PLL_400_P0_1_SH)
+#define __APP_PLL_400_Z0_2_MK            0x000000e0
+#define __APP_PLL_400_Z0_2_SH            5
+#define __APP_PLL_400_Z0_2(_v)           ((_v) << __APP_PLL_400_Z0_2_SH)
+#define __APP_PLL_400_RSEL200500         0x00000010
+#define __APP_PLL_400_ENARST             0x00000008
+#define __APP_PLL_400_BYPASS             0x00000004
+#define __APP_PLL_400_LRESETN            0x00000002
+#define __APP_PLL_400_ENABLE             0x00000001
+#define APP_PLL_212_CTL_REG              0x00014208
+#define __P_212_PLL_LOCK                 0x80000000
+#define __APP_PLL_212_RESET_TIMER_MK     0x000e0000
+#define __APP_PLL_212_RESET_TIMER_SH     17
+#define __APP_PLL_212_RESET_TIMER(_v)    ((_v) << __APP_PLL_212_RESET_TIMER_SH)
+#define __APP_PLL_212_LOGIC_SOFT_RESET   0x00010000
+#define __APP_PLL_212_CNTLMT0_1_MK       0x0000c000
+#define __APP_PLL_212_CNTLMT0_1_SH       14
+#define __APP_PLL_212_CNTLMT0_1(_v)      ((_v) << __APP_PLL_212_CNTLMT0_1_SH)
+#define __APP_PLL_212_JITLMT0_1_MK       0x00003000
+#define __APP_PLL_212_JITLMT0_1_SH       12
+#define __APP_PLL_212_JITLMT0_1(_v)      ((_v) << __APP_PLL_212_JITLMT0_1_SH)
+#define __APP_PLL_212_HREF               0x00000800
+#define __APP_PLL_212_HDIV               0x00000400
+#define __APP_PLL_212_P0_1_MK            0x00000300
+#define __APP_PLL_212_P0_1_SH            8
+#define __APP_PLL_212_P0_1(_v)           ((_v) << __APP_PLL_212_P0_1_SH)
+#define __APP_PLL_212_Z0_2_MK            0x000000e0
+#define __APP_PLL_212_Z0_2_SH            5
+#define __APP_PLL_212_Z0_2(_v)           ((_v) << __APP_PLL_212_Z0_2_SH)
+#define __APP_PLL_212_RSEL200500         0x00000010
+#define __APP_PLL_212_ENARST             0x00000008
+#define __APP_PLL_212_BYPASS             0x00000004
+#define __APP_PLL_212_LRESETN            0x00000002
+#define __APP_PLL_212_ENABLE             0x00000001
+#define HOST_SEM0_REG                    0x00014230
+#define __HOST_SEMAPHORE                 0x00000001
+#define HOST_SEM1_REG                    0x00014234
+#define HOST_SEM2_REG                    0x00014238
+#define HOST_SEM3_REG                    0x0001423c
+#define HOST_SEM0_INFO_REG               0x00014240
+#define HOST_SEM1_INFO_REG               0x00014244
+#define HOST_SEM2_INFO_REG               0x00014248
+#define HOST_SEM3_INFO_REG               0x0001424c
+#define HOSTFN0_LPU0_CMD_STAT            0x00019000
+#define __HOSTFN0_LPU0_MBOX_INFO_MK      0xfffffffe
+#define __HOSTFN0_LPU0_MBOX_INFO_SH      1
+#define __HOSTFN0_LPU0_MBOX_INFO(_v)     ((_v) << __HOSTFN0_LPU0_MBOX_INFO_SH)
+#define __HOSTFN0_LPU0_MBOX_CMD_STATUS   0x00000001
+#define LPU0_HOSTFN0_CMD_STAT            0x00019008
+#define __LPU0_HOSTFN0_MBOX_INFO_MK      0xfffffffe
+#define __LPU0_HOSTFN0_MBOX_INFO_SH      1
+#define __LPU0_HOSTFN0_MBOX_INFO(_v)     ((_v) << __LPU0_HOSTFN0_MBOX_INFO_SH)
+#define __LPU0_HOSTFN0_MBOX_CMD_STATUS   0x00000001
+#define HOSTFN1_LPU1_CMD_STAT            0x00019014
+#define __HOSTFN1_LPU1_MBOX_INFO_MK      0xfffffffe
+#define __HOSTFN1_LPU1_MBOX_INFO_SH      1
+#define __HOSTFN1_LPU1_MBOX_INFO(_v)     ((_v) << __HOSTFN1_LPU1_MBOX_INFO_SH)
+#define __HOSTFN1_LPU1_MBOX_CMD_STATUS   0x00000001
+#define LPU1_HOSTFN1_CMD_STAT            0x0001901c
+#define __LPU1_HOSTFN1_MBOX_INFO_MK      0xfffffffe
+#define __LPU1_HOSTFN1_MBOX_INFO_SH      1
+#define __LPU1_HOSTFN1_MBOX_INFO(_v)     ((_v) << __LPU1_HOSTFN1_MBOX_INFO_SH)
+#define __LPU1_HOSTFN1_MBOX_CMD_STATUS   0x00000001
+#define CPE_Q0_DEPTH                     0x00010014
+#define CPE_Q0_PI                        0x0001001c
+#define CPE_Q0_CI                        0x00010020
+#define CPE_Q1_DEPTH                     0x00010034
+#define CPE_Q1_PI                        0x0001003c
+#define CPE_Q1_CI                        0x00010040
+#define CPE_Q2_DEPTH                     0x00010054
+#define CPE_Q2_PI                        0x0001005c
+#define CPE_Q2_CI                        0x00010060
+#define CPE_Q3_DEPTH                     0x00010074
+#define CPE_Q3_PI                        0x0001007c
+#define CPE_Q3_CI                        0x00010080
+#define CPE_Q4_DEPTH                     0x00010094
+#define CPE_Q4_PI                        0x0001009c
+#define CPE_Q4_CI                        0x000100a0
+#define CPE_Q5_DEPTH                     0x000100b4
+#define CPE_Q5_PI                        0x000100bc
+#define CPE_Q5_CI                        0x000100c0
+#define CPE_Q6_DEPTH                     0x000100d4
+#define CPE_Q6_PI                        0x000100dc
+#define CPE_Q6_CI                        0x000100e0
+#define CPE_Q7_DEPTH                     0x000100f4
+#define CPE_Q7_PI                        0x000100fc
+#define CPE_Q7_CI                        0x00010100
+#define RME_Q0_DEPTH                     0x00011014
+#define RME_Q0_PI                        0x0001101c
+#define RME_Q0_CI                        0x00011020
+#define RME_Q1_DEPTH                     0x00011034
+#define RME_Q1_PI                        0x0001103c
+#define RME_Q1_CI                        0x00011040
+#define RME_Q2_DEPTH                     0x00011054
+#define RME_Q2_PI                        0x0001105c
+#define RME_Q2_CI                        0x00011060
+#define RME_Q3_DEPTH                     0x00011074
+#define RME_Q3_PI                        0x0001107c
+#define RME_Q3_CI                        0x00011080
+#define RME_Q4_DEPTH                     0x00011094
+#define RME_Q4_PI                        0x0001109c
+#define RME_Q4_CI                        0x000110a0
+#define RME_Q5_DEPTH                     0x000110b4
+#define RME_Q5_PI                        0x000110bc
+#define RME_Q5_CI                        0x000110c0
+#define RME_Q6_DEPTH                     0x000110d4
+#define RME_Q6_PI                        0x000110dc
+#define RME_Q6_CI                        0x000110e0
+#define RME_Q7_DEPTH                     0x000110f4
+#define RME_Q7_PI                        0x000110fc
+#define RME_Q7_CI                        0x00011100
+#define PSS_CTL_REG                      0x00018800
+#define __PSS_I2C_CLK_DIV_MK             0x00030000
+#define __PSS_I2C_CLK_DIV_SH             16
+#define __PSS_I2C_CLK_DIV(_v)            ((_v) << __PSS_I2C_CLK_DIV_SH)
+#define __PSS_LMEM_INIT_DONE             0x00001000
+#define __PSS_LMEM_RESET                 0x00000200
+#define __PSS_LMEM_INIT_EN               0x00000100
+#define __PSS_LPU1_RESET                 0x00000002
+#define __PSS_LPU0_RESET                 0x00000001
+#define PSS_ERR_STATUS_REG               0x00018810
+#define __PSS_LMEM1_CORR_ERR             0x00000800
+#define __PSS_LMEM0_CORR_ERR             0x00000400
+#define __PSS_LMEM1_UNCORR_ERR           0x00000200
+#define __PSS_LMEM0_UNCORR_ERR           0x00000100
+#define __PSS_BAL_PERR                   0x00000080
+#define __PSS_DIP_IF_ERR                 0x00000040
+#define __PSS_IOH_IF_ERR                 0x00000020
+#define __PSS_TDS_IF_ERR                 0x00000010
+#define __PSS_RDS_IF_ERR                 0x00000008
+#define __PSS_SGM_IF_ERR                 0x00000004
+#define __PSS_LPU1_RAM_ERR               0x00000002
+#define __PSS_LPU0_RAM_ERR               0x00000001
+#define ERR_SET_REG                      0x00018818
+#define __PSS_ERR_STATUS_SET             0x00000fff
+
+
+/*
+ * These definitions are either in error/missing in spec. Its auto-generated
+ * from hard coded values in regparse.pl.
+ */
+#define __EMPHPOST_AT_4G_MK_FIX          0x0000001c
+#define __EMPHPOST_AT_4G_SH_FIX          0x00000002
+#define __EMPHPRE_AT_4G_FIX              0x00000003
+#define __SFP_TXRATE_EN_FIX              0x00000100
+#define __SFP_RXRATE_EN_FIX              0x00000080
+
+
+/*
+ * These register definitions are auto-generated from hard coded values
+ * in regparse.pl.
+ */
+#define HOSTFN0_LPU_MBOX0_0              0x00019200
+#define HOSTFN1_LPU_MBOX0_8              0x00019260
+#define LPU_HOSTFN0_MBOX0_0              0x00019280
+#define LPU_HOSTFN1_MBOX0_8              0x000192e0
+
+
+/*
+ * These register mapping definitions are auto-generated from mapping tables
+ * in regparse.pl.
+ */
+#define BFA_IOC0_HBEAT_REG               HOST_SEM0_INFO_REG
+#define BFA_IOC0_STATE_REG               HOST_SEM1_INFO_REG
+#define BFA_IOC1_HBEAT_REG               HOST_SEM2_INFO_REG
+#define BFA_IOC1_STATE_REG               HOST_SEM3_INFO_REG
+#define BFA_FW_USE_COUNT                 HOST_SEM4_INFO_REG
+
+#define CPE_Q_DEPTH(__n) \
+       (CPE_Q0_DEPTH + (__n) * (CPE_Q1_DEPTH - CPE_Q0_DEPTH))
+#define CPE_Q_PI(__n) \
+       (CPE_Q0_PI + (__n) * (CPE_Q1_PI - CPE_Q0_PI))
+#define CPE_Q_CI(__n) \
+       (CPE_Q0_CI + (__n) * (CPE_Q1_CI - CPE_Q0_CI))
+#define RME_Q_DEPTH(__n) \
+       (RME_Q0_DEPTH + (__n) * (RME_Q1_DEPTH - RME_Q0_DEPTH))
+#define RME_Q_PI(__n) \
+       (RME_Q0_PI + (__n) * (RME_Q1_PI - RME_Q0_PI))
+#define RME_Q_CI(__n) \
+       (RME_Q0_CI + (__n) * (RME_Q1_CI - RME_Q0_CI))
+
+#define CPE_Q_NUM(__fn, __q)  (((__fn) << 2) + (__q))
+#define RME_Q_NUM(__fn, __q)  (((__fn) << 2) + (__q))
+#define CPE_Q_MASK(__q)  ((__q) & 0x3)
+#define RME_Q_MASK(__q)  ((__q) & 0x3)
+
+
+/*
+ * PCI MSI-X vector defines
+ */
+enum {
+    BFA_MSIX_CPE_Q0 = 0,
+    BFA_MSIX_CPE_Q1 = 1,
+    BFA_MSIX_CPE_Q2 = 2,
+    BFA_MSIX_CPE_Q3 = 3,
+    BFA_MSIX_CPE_Q4 = 4,
+    BFA_MSIX_CPE_Q5 = 5,
+    BFA_MSIX_CPE_Q6 = 6,
+    BFA_MSIX_CPE_Q7 = 7,
+    BFA_MSIX_RME_Q0 = 8,
+    BFA_MSIX_RME_Q1 = 9,
+    BFA_MSIX_RME_Q2 = 10,
+    BFA_MSIX_RME_Q3 = 11,
+    BFA_MSIX_RME_Q4 = 12,
+    BFA_MSIX_RME_Q5 = 13,
+    BFA_MSIX_RME_Q6 = 14,
+    BFA_MSIX_RME_Q7 = 15,
+    BFA_MSIX_ERR_EMC = 16,
+    BFA_MSIX_ERR_LPU0 = 17,
+    BFA_MSIX_ERR_LPU1 = 18,
+    BFA_MSIX_ERR_PSS = 19,
+    BFA_MSIX_MBOX_LPU0 = 20,
+    BFA_MSIX_MBOX_LPU1 = 21,
+    BFA_MSIX_CB_MAX = 22,
+};
+
+/*
+ * And corresponding host interrupt status bit field defines
+ */
+#define __HFN_INT_CPE_Q0                   0x00000001U
+#define __HFN_INT_CPE_Q1                   0x00000002U
+#define __HFN_INT_CPE_Q2                   0x00000004U
+#define __HFN_INT_CPE_Q3                   0x00000008U
+#define __HFN_INT_CPE_Q4                   0x00000010U
+#define __HFN_INT_CPE_Q5                   0x00000020U
+#define __HFN_INT_CPE_Q6                   0x00000040U
+#define __HFN_INT_CPE_Q7                   0x00000080U
+#define __HFN_INT_RME_Q0                   0x00000100U
+#define __HFN_INT_RME_Q1                   0x00000200U
+#define __HFN_INT_RME_Q2                   0x00000400U
+#define __HFN_INT_RME_Q3                   0x00000800U
+#define __HFN_INT_RME_Q4                   0x00001000U
+#define __HFN_INT_RME_Q5                   0x00002000U
+#define __HFN_INT_RME_Q6                   0x00004000U
+#define __HFN_INT_RME_Q7                   0x00008000U
+#define __HFN_INT_ERR_EMC                  0x00010000U
+#define __HFN_INT_ERR_LPU0                 0x00020000U
+#define __HFN_INT_ERR_LPU1                 0x00040000U
+#define __HFN_INT_ERR_PSS                  0x00080000U
+#define __HFN_INT_MBOX_LPU0                0x00100000U
+#define __HFN_INT_MBOX_LPU1                0x00200000U
+#define __HFN_INT_MBOX1_LPU0               0x00400000U
+#define __HFN_INT_MBOX1_LPU1               0x00800000U
+#define __HFN_INT_CPE_MASK                 0x000000ffU
+#define __HFN_INT_RME_MASK                 0x0000ff00U
+
+
+/*
+ * crossbow memory map.
+ */
+#define PSS_SMEM_PAGE_START    0x8000
+#define PSS_SMEM_PGNUM(_pg0, _ma)      ((_pg0) + ((_ma) >> 15))
+#define PSS_SMEM_PGOFF(_ma)    ((_ma) & 0x7fff)
+
+/*
+ * End of crossbow memory map
+ */
+
+
+#endif /* __BFI_CBREG_H__ */
+
diff --git a/drivers/scsi/bfa/bfi_ctreg.h b/drivers/scsi/bfa/bfi_ctreg.h
new file mode 100644 (file)
index 0000000..62b86a4
--- /dev/null
@@ -0,0 +1,627 @@
+
+/*
+ * bfi_ctreg.h catapult host block register definitions
+ *
+ * !!! Do not edit. Auto generated. !!!
+ */
+
+#ifndef __BFI_CTREG_H__
+#define __BFI_CTREG_H__
+
+
+#define HOSTFN0_LPU_MBOX0_0            0x00019200
+#define HOSTFN1_LPU_MBOX0_8            0x00019260
+#define LPU_HOSTFN0_MBOX0_0            0x00019280
+#define LPU_HOSTFN1_MBOX0_8            0x000192e0
+#define HOSTFN2_LPU_MBOX0_0            0x00019400
+#define HOSTFN3_LPU_MBOX0_8            0x00019460
+#define LPU_HOSTFN2_MBOX0_0            0x00019480
+#define LPU_HOSTFN3_MBOX0_8            0x000194e0
+#define HOSTFN0_INT_STATUS             0x00014000
+#define __HOSTFN0_HALT_OCCURRED                0x01000000
+#define __HOSTFN0_INT_STATUS_LVL_MK    0x00f00000
+#define __HOSTFN0_INT_STATUS_LVL_SH    20
+#define __HOSTFN0_INT_STATUS_LVL(_v)   ((_v) << __HOSTFN0_INT_STATUS_LVL_SH)
+#define __HOSTFN0_INT_STATUS_P_MK      0x000f0000
+#define __HOSTFN0_INT_STATUS_P_SH      16
+#define __HOSTFN0_INT_STATUS_P(_v)     ((_v) << __HOSTFN0_INT_STATUS_P_SH)
+#define __HOSTFN0_INT_STATUS_F         0x0000ffff
+#define HOSTFN0_INT_MSK                        0x00014004
+#define HOST_PAGE_NUM_FN0              0x00014008
+#define __HOST_PAGE_NUM_FN             0x000001ff
+#define HOST_MSIX_ERR_INDEX_FN0                0x0001400c
+#define __MSIX_ERR_INDEX_FN            0x000001ff
+#define HOSTFN1_INT_STATUS             0x00014100
+#define __HOSTFN1_HALT_OCCURRED                0x01000000
+#define __HOSTFN1_INT_STATUS_LVL_MK    0x00f00000
+#define __HOSTFN1_INT_STATUS_LVL_SH    20
+#define __HOSTFN1_INT_STATUS_LVL(_v)   ((_v) << __HOSTFN1_INT_STATUS_LVL_SH)
+#define __HOSTFN1_INT_STATUS_P_MK      0x000f0000
+#define __HOSTFN1_INT_STATUS_P_SH      16
+#define __HOSTFN1_INT_STATUS_P(_v)     ((_v) << __HOSTFN1_INT_STATUS_P_SH)
+#define __HOSTFN1_INT_STATUS_F         0x0000ffff
+#define HOSTFN1_INT_MSK                        0x00014104
+#define HOST_PAGE_NUM_FN1              0x00014108
+#define HOST_MSIX_ERR_INDEX_FN1                0x0001410c
+#define APP_PLL_425_CTL_REG            0x00014204
+#define __P_425_PLL_LOCK               0x80000000
+#define __APP_PLL_425_SRAM_USE_100MHZ  0x00100000
+#define __APP_PLL_425_RESET_TIMER_MK   0x000e0000
+#define __APP_PLL_425_RESET_TIMER_SH   17
+#define __APP_PLL_425_RESET_TIMER(_v)  ((_v) << __APP_PLL_425_RESET_TIMER_SH)
+#define __APP_PLL_425_LOGIC_SOFT_RESET 0x00010000
+#define __APP_PLL_425_CNTLMT0_1_MK     0x0000c000
+#define __APP_PLL_425_CNTLMT0_1_SH     14
+#define __APP_PLL_425_CNTLMT0_1(_v)    ((_v) << __APP_PLL_425_CNTLMT0_1_SH)
+#define __APP_PLL_425_JITLMT0_1_MK     0x00003000
+#define __APP_PLL_425_JITLMT0_1_SH     12
+#define __APP_PLL_425_JITLMT0_1(_v)    ((_v) << __APP_PLL_425_JITLMT0_1_SH)
+#define __APP_PLL_425_HREF             0x00000800
+#define __APP_PLL_425_HDIV             0x00000400
+#define __APP_PLL_425_P0_1_MK          0x00000300
+#define __APP_PLL_425_P0_1_SH          8
+#define __APP_PLL_425_P0_1(_v)         ((_v) << __APP_PLL_425_P0_1_SH)
+#define __APP_PLL_425_Z0_2_MK          0x000000e0
+#define __APP_PLL_425_Z0_2_SH          5
+#define __APP_PLL_425_Z0_2(_v)         ((_v) << __APP_PLL_425_Z0_2_SH)
+#define __APP_PLL_425_RSEL200500       0x00000010
+#define __APP_PLL_425_ENARST           0x00000008
+#define __APP_PLL_425_BYPASS           0x00000004
+#define __APP_PLL_425_LRESETN          0x00000002
+#define __APP_PLL_425_ENABLE           0x00000001
+#define APP_PLL_312_CTL_REG            0x00014208
+#define __P_312_PLL_LOCK               0x80000000
+#define __ENABLE_MAC_AHB_1             0x00800000
+#define __ENABLE_MAC_AHB_0             0x00400000
+#define __ENABLE_MAC_1                 0x00200000
+#define __ENABLE_MAC_0                 0x00100000
+#define __APP_PLL_312_RESET_TIMER_MK   0x000e0000
+#define __APP_PLL_312_RESET_TIMER_SH   17
+#define __APP_PLL_312_RESET_TIMER(_v)  ((_v) << __APP_PLL_312_RESET_TIMER_SH)
+#define __APP_PLL_312_LOGIC_SOFT_RESET 0x00010000
+#define __APP_PLL_312_CNTLMT0_1_MK     0x0000c000
+#define __APP_PLL_312_CNTLMT0_1_SH     14
+#define __APP_PLL_312_CNTLMT0_1(_v)    ((_v) << __APP_PLL_312_CNTLMT0_1_SH)
+#define __APP_PLL_312_JITLMT0_1_MK     0x00003000
+#define __APP_PLL_312_JITLMT0_1_SH     12
+#define __APP_PLL_312_JITLMT0_1(_v)    ((_v) << __APP_PLL_312_JITLMT0_1_SH)
+#define __APP_PLL_312_HREF             0x00000800
+#define __APP_PLL_312_HDIV             0x00000400
+#define __APP_PLL_312_P0_1_MK          0x00000300
+#define __APP_PLL_312_P0_1_SH          8
+#define __APP_PLL_312_P0_1(_v)         ((_v) << __APP_PLL_312_P0_1_SH)
+#define __APP_PLL_312_Z0_2_MK          0x000000e0
+#define __APP_PLL_312_Z0_2_SH          5
+#define __APP_PLL_312_Z0_2(_v)         ((_v) << __APP_PLL_312_Z0_2_SH)
+#define __APP_PLL_312_RSEL200500       0x00000010
+#define __APP_PLL_312_ENARST           0x00000008
+#define __APP_PLL_312_BYPASS           0x00000004
+#define __APP_PLL_312_LRESETN          0x00000002
+#define __APP_PLL_312_ENABLE           0x00000001
+#define MBIST_CTL_REG                  0x00014220
+#define __EDRAM_BISTR_START            0x00000004
+#define __MBIST_RESET                  0x00000002
+#define __MBIST_START                  0x00000001
+#define MBIST_STAT_REG                 0x00014224
+#define __EDRAM_BISTR_STATUS           0x00000008
+#define __EDRAM_BISTR_DONE             0x00000004
+#define __MEM_BIT_STATUS               0x00000002
+#define __MBIST_DONE                   0x00000001
+#define HOST_SEM0_REG                  0x00014230
+#define __HOST_SEMAPHORE               0x00000001
+#define HOST_SEM1_REG                  0x00014234
+#define HOST_SEM2_REG                  0x00014238
+#define HOST_SEM3_REG                  0x0001423c
+#define HOST_SEM0_INFO_REG             0x00014240
+#define HOST_SEM1_INFO_REG             0x00014244
+#define HOST_SEM2_INFO_REG             0x00014248
+#define HOST_SEM3_INFO_REG             0x0001424c
+#define ETH_MAC_SER_REG                        0x00014288
+#define __APP_EMS_CKBUFAMPIN           0x00000020
+#define __APP_EMS_REFCLKSEL            0x00000010
+#define __APP_EMS_CMLCKSEL             0x00000008
+#define __APP_EMS_REFCKBUFEN2          0x00000004
+#define __APP_EMS_REFCKBUFEN1          0x00000002
+#define __APP_EMS_CHANNEL_SEL          0x00000001
+#define HOSTFN2_INT_STATUS             0x00014300
+#define __HOSTFN2_HALT_OCCURRED                0x01000000
+#define __HOSTFN2_INT_STATUS_LVL_MK    0x00f00000
+#define __HOSTFN2_INT_STATUS_LVL_SH    20
+#define __HOSTFN2_INT_STATUS_LVL(_v)   ((_v) << __HOSTFN2_INT_STATUS_LVL_SH)
+#define __HOSTFN2_INT_STATUS_P_MK      0x000f0000
+#define __HOSTFN2_INT_STATUS_P_SH      16
+#define __HOSTFN2_INT_STATUS_P(_v)     ((_v) << __HOSTFN2_INT_STATUS_P_SH)
+#define __HOSTFN2_INT_STATUS_F         0x0000ffff
+#define HOSTFN2_INT_MSK                        0x00014304
+#define HOST_PAGE_NUM_FN2              0x00014308
+#define HOST_MSIX_ERR_INDEX_FN2                0x0001430c
+#define HOSTFN3_INT_STATUS             0x00014400
+#define __HALT_OCCURRED                        0x01000000
+#define __HOSTFN3_INT_STATUS_LVL_MK    0x00f00000
+#define __HOSTFN3_INT_STATUS_LVL_SH    20
+#define __HOSTFN3_INT_STATUS_LVL(_v)   ((_v) << __HOSTFN3_INT_STATUS_LVL_SH)
+#define __HOSTFN3_INT_STATUS_P_MK      0x000f0000
+#define __HOSTFN3_INT_STATUS_P_SH      16
+#define __HOSTFN3_INT_STATUS_P(_v)     ((_v) << __HOSTFN3_INT_STATUS_P_SH)
+#define __HOSTFN3_INT_STATUS_F         0x0000ffff
+#define HOSTFN3_INT_MSK                        0x00014404
+#define HOST_PAGE_NUM_FN3              0x00014408
+#define HOST_MSIX_ERR_INDEX_FN3                0x0001440c
+#define FNC_ID_REG                     0x00014600
+#define __FUNCTION_NUMBER              0x00000007
+#define FNC_PERS_REG                   0x00014604
+#define __F3_FUNCTION_ACTIVE           0x80000000
+#define __F3_FUNCTION_MODE             0x40000000
+#define __F3_PORT_MAP_MK               0x30000000
+#define __F3_PORT_MAP_SH               28
+#define __F3_PORT_MAP(_v)              ((_v) << __F3_PORT_MAP_SH)
+#define __F3_VM_MODE                   0x08000000
+#define __F3_INTX_STATUS_MK            0x07000000
+#define __F3_INTX_STATUS_SH            24
+#define __F3_INTX_STATUS(_v)           ((_v) << __F3_INTX_STATUS_SH)
+#define __F2_FUNCTION_ACTIVE           0x00800000
+#define __F2_FUNCTION_MODE             0x00400000
+#define __F2_PORT_MAP_MK               0x00300000
+#define __F2_PORT_MAP_SH               20
+#define __F2_PORT_MAP(_v)              ((_v) << __F2_PORT_MAP_SH)
+#define __F2_VM_MODE                   0x00080000
+#define __F2_INTX_STATUS_MK            0x00070000
+#define __F2_INTX_STATUS_SH            16
+#define __F2_INTX_STATUS(_v)           ((_v) << __F2_INTX_STATUS_SH)
+#define __F1_FUNCTION_ACTIVE           0x00008000
+#define __F1_FUNCTION_MODE             0x00004000
+#define __F1_PORT_MAP_MK               0x00003000
+#define __F1_PORT_MAP_SH               12
+#define __F1_PORT_MAP(_v)              ((_v) << __F1_PORT_MAP_SH)
+#define __F1_VM_MODE                   0x00000800
+#define __F1_INTX_STATUS_MK            0x00000700
+#define __F1_INTX_STATUS_SH            8
+#define __F1_INTX_STATUS(_v)           ((_v) << __F1_INTX_STATUS_SH)
+#define __F0_FUNCTION_ACTIVE           0x00000080
+#define __F0_FUNCTION_MODE             0x00000040
+#define __F0_PORT_MAP_MK               0x00000030
+#define __F0_PORT_MAP_SH               4
+#define __F0_PORT_MAP(_v)              ((_v) << __F0_PORT_MAP_SH)
+#define __F0_VM_MODE           0x00000008
+#define __F0_INTX_STATUS               0x00000007
+enum {
+       __F0_INTX_STATUS_MSIX           = 0x0,
+       __F0_INTX_STATUS_INTA           = 0x1,
+       __F0_INTX_STATUS_INTB           = 0x2,
+       __F0_INTX_STATUS_INTC           = 0x3,
+       __F0_INTX_STATUS_INTD           = 0x4,
+};
+#define OP_MODE                                0x0001460c
+#define __APP_ETH_CLK_LOWSPEED         0x00000004
+#define __GLOBAL_CORECLK_HALFSPEED     0x00000002
+#define __GLOBAL_FCOE_MODE             0x00000001
+#define HOST_SEM4_REG                  0x00014610
+#define HOST_SEM5_REG                  0x00014614
+#define HOST_SEM6_REG                  0x00014618
+#define HOST_SEM7_REG                  0x0001461c
+#define HOST_SEM4_INFO_REG             0x00014620
+#define HOST_SEM5_INFO_REG             0x00014624
+#define HOST_SEM6_INFO_REG             0x00014628
+#define HOST_SEM7_INFO_REG             0x0001462c
+#define HOSTFN0_LPU0_MBOX0_CMD_STAT    0x00019000
+#define __HOSTFN0_LPU0_MBOX0_INFO_MK   0xfffffffe
+#define __HOSTFN0_LPU0_MBOX0_INFO_SH   1
+#define __HOSTFN0_LPU0_MBOX0_INFO(_v)  ((_v) << __HOSTFN0_LPU0_MBOX0_INFO_SH)
+#define __HOSTFN0_LPU0_MBOX0_CMD_STATUS 0x00000001
+#define HOSTFN0_LPU1_MBOX0_CMD_STAT    0x00019004
+#define __HOSTFN0_LPU1_MBOX0_INFO_MK   0xfffffffe
+#define __HOSTFN0_LPU1_MBOX0_INFO_SH   1
+#define __HOSTFN0_LPU1_MBOX0_INFO(_v)  ((_v) << __HOSTFN0_LPU1_MBOX0_INFO_SH)
+#define __HOSTFN0_LPU1_MBOX0_CMD_STATUS 0x00000001
+#define LPU0_HOSTFN0_MBOX0_CMD_STAT    0x00019008
+#define __LPU0_HOSTFN0_MBOX0_INFO_MK   0xfffffffe
+#define __LPU0_HOSTFN0_MBOX0_INFO_SH   1
+#define __LPU0_HOSTFN0_MBOX0_INFO(_v)  ((_v) << __LPU0_HOSTFN0_MBOX0_INFO_SH)
+#define __LPU0_HOSTFN0_MBOX0_CMD_STATUS 0x00000001
+#define LPU1_HOSTFN0_MBOX0_CMD_STAT    0x0001900c
+#define __LPU1_HOSTFN0_MBOX0_INFO_MK   0xfffffffe
+#define __LPU1_HOSTFN0_MBOX0_INFO_SH   1
+#define __LPU1_HOSTFN0_MBOX0_INFO(_v)  ((_v) << __LPU1_HOSTFN0_MBOX0_INFO_SH)
+#define __LPU1_HOSTFN0_MBOX0_CMD_STATUS 0x00000001
+#define HOSTFN1_LPU0_MBOX0_CMD_STAT    0x00019010
+#define __HOSTFN1_LPU0_MBOX0_INFO_MK   0xfffffffe
+#define __HOSTFN1_LPU0_MBOX0_INFO_SH   1
+#define __HOSTFN1_LPU0_MBOX0_INFO(_v)  ((_v) << __HOSTFN1_LPU0_MBOX0_INFO_SH)
+#define __HOSTFN1_LPU0_MBOX0_CMD_STATUS 0x00000001
+#define HOSTFN1_LPU1_MBOX0_CMD_STAT    0x00019014
+#define __HOSTFN1_LPU1_MBOX0_INFO_MK   0xfffffffe
+#define __HOSTFN1_LPU1_MBOX0_INFO_SH   1
+#define __HOSTFN1_LPU1_MBOX0_INFO(_v)  ((_v) << __HOSTFN1_LPU1_MBOX0_INFO_SH)
+#define __HOSTFN1_LPU1_MBOX0_CMD_STATUS 0x00000001
+#define LPU0_HOSTFN1_MBOX0_CMD_STAT    0x00019018
+#define __LPU0_HOSTFN1_MBOX0_INFO_MK   0xfffffffe
+#define __LPU0_HOSTFN1_MBOX0_INFO_SH   1
+#define __LPU0_HOSTFN1_MBOX0_INFO(_v)  ((_v) << __LPU0_HOSTFN1_MBOX0_INFO_SH)
+#define __LPU0_HOSTFN1_MBOX0_CMD_STATUS 0x00000001
+#define LPU1_HOSTFN1_MBOX0_CMD_STAT    0x0001901c
+#define __LPU1_HOSTFN1_MBOX0_INFO_MK   0xfffffffe
+#define __LPU1_HOSTFN1_MBOX0_INFO_SH   1
+#define __LPU1_HOSTFN1_MBOX0_INFO(_v)  ((_v) << __LPU1_HOSTFN1_MBOX0_INFO_SH)
+#define __LPU1_HOSTFN1_MBOX0_CMD_STATUS 0x00000001
+#define HOSTFN2_LPU0_MBOX0_CMD_STAT    0x00019150
+#define __HOSTFN2_LPU0_MBOX0_INFO_MK   0xfffffffe
+#define __HOSTFN2_LPU0_MBOX0_INFO_SH   1
+#define __HOSTFN2_LPU0_MBOX0_INFO(_v)  ((_v) << __HOSTFN2_LPU0_MBOX0_INFO_SH)
+#define __HOSTFN2_LPU0_MBOX0_CMD_STATUS 0x00000001
+#define HOSTFN2_LPU1_MBOX0_CMD_STAT    0x00019154
+#define __HOSTFN2_LPU1_MBOX0_INFO_MK   0xfffffffe
+#define __HOSTFN2_LPU1_MBOX0_INFO_SH   1
+#define __HOSTFN2_LPU1_MBOX0_INFO(_v)  ((_v) << __HOSTFN2_LPU1_MBOX0_INFO_SH)
+#define __HOSTFN2_LPU1_MBOX0BOX0_CMD_STATUS 0x00000001
+#define LPU0_HOSTFN2_MBOX0_CMD_STAT    0x00019158
+#define __LPU0_HOSTFN2_MBOX0_INFO_MK   0xfffffffe
+#define __LPU0_HOSTFN2_MBOX0_INFO_SH   1
+#define __LPU0_HOSTFN2_MBOX0_INFO(_v)  ((_v) << __LPU0_HOSTFN2_MBOX0_INFO_SH)
+#define __LPU0_HOSTFN2_MBOX0_CMD_STATUS 0x00000001
+#define LPU1_HOSTFN2_MBOX0_CMD_STAT    0x0001915c
+#define __LPU1_HOSTFN2_MBOX0_INFO_MK   0xfffffffe
+#define __LPU1_HOSTFN2_MBOX0_INFO_SH   1
+#define __LPU1_HOSTFN2_MBOX0_INFO(_v)  ((_v) << __LPU1_HOSTFN2_MBOX0_INFO_SH)
+#define __LPU1_HOSTFN2_MBOX0_CMD_STATUS 0x00000001
+#define HOSTFN3_LPU0_MBOX0_CMD_STAT    0x00019160
+#define __HOSTFN3_LPU0_MBOX0_INFO_MK   0xfffffffe
+#define __HOSTFN3_LPU0_MBOX0_INFO_SH   1
+#define __HOSTFN3_LPU0_MBOX0_INFO(_v)  ((_v) << __HOSTFN3_LPU0_MBOX0_INFO_SH)
+#define __HOSTFN3_LPU0_MBOX0_CMD_STATUS 0x00000001
+#define HOSTFN3_LPU1_MBOX0_CMD_STAT    0x00019164
+#define __HOSTFN3_LPU1_MBOX0_INFO_MK   0xfffffffe
+#define __HOSTFN3_LPU1_MBOX0_INFO_SH   1
+#define __HOSTFN3_LPU1_MBOX0_INFO(_v)  ((_v) << __HOSTFN3_LPU1_MBOX0_INFO_SH)
+#define __HOSTFN3_LPU1_MBOX0_CMD_STATUS 0x00000001
+#define LPU0_HOSTFN3_MBOX0_CMD_STAT    0x00019168
+#define __LPU0_HOSTFN3_MBOX0_INFO_MK   0xfffffffe
+#define __LPU0_HOSTFN3_MBOX0_INFO_SH   1
+#define __LPU0_HOSTFN3_MBOX0_INFO(_v)  ((_v) << __LPU0_HOSTFN3_MBOX0_INFO_SH)
+#define __LPU0_HOSTFN3_MBOX0_CMD_STATUS 0x00000001
+#define LPU1_HOSTFN3_MBOX0_CMD_STAT    0x0001916c
+#define __LPU1_HOSTFN3_MBOX0_INFO_MK   0xfffffffe
+#define __LPU1_HOSTFN3_MBOX0_INFO_SH   1
+#define __LPU1_HOSTFN3_MBOX0_INFO(_v)  ((_v) << __LPU1_HOSTFN3_MBOX0_INFO_SH)
+#define __LPU1_HOSTFN3_MBOX0_CMD_STATUS        0x00000001
+#define FW_INIT_HALT_P0                        0x000191ac
+#define __FW_INIT_HALT_P               0x00000001
+#define FW_INIT_HALT_P1                        0x000191bc
+#define CPE_PI_PTR_Q0                  0x00038000
+#define __CPE_PI_UNUSED_MK             0xffff0000
+#define __CPE_PI_UNUSED_SH             16
+#define __CPE_PI_UNUSED(_v)            ((_v) << __CPE_PI_UNUSED_SH)
+#define __CPE_PI_PTR                   0x0000ffff
+#define CPE_PI_PTR_Q1                  0x00038040
+#define CPE_CI_PTR_Q0                  0x00038004
+#define __CPE_CI_UNUSED_MK             0xffff0000
+#define __CPE_CI_UNUSED_SH             16
+#define __CPE_CI_UNUSED(_v)            ((_v) << __CPE_CI_UNUSED_SH)
+#define __CPE_CI_PTR                   0x0000ffff
+#define CPE_CI_PTR_Q1                  0x00038044
+#define CPE_DEPTH_Q0                   0x00038008
+#define __CPE_DEPTH_UNUSED_MK          0xf8000000
+#define __CPE_DEPTH_UNUSED_SH          27
+#define __CPE_DEPTH_UNUSED(_v)         ((_v) << __CPE_DEPTH_UNUSED_SH)
+#define __CPE_MSIX_VEC_INDEX_MK                0x07ff0000
+#define __CPE_MSIX_VEC_INDEX_SH                16
+#define __CPE_MSIX_VEC_INDEX(_v)       ((_v) << __CPE_MSIX_VEC_INDEX_SH)
+#define __CPE_DEPTH                    0x0000ffff
+#define CPE_DEPTH_Q1                   0x00038048
+#define CPE_QCTRL_Q0                   0x0003800c
+#define __CPE_CTRL_UNUSED30_MK         0xfc000000
+#define __CPE_CTRL_UNUSED30_SH         26
+#define __CPE_CTRL_UNUSED30(_v)                ((_v) << __CPE_CTRL_UNUSED30_SH)
+#define __CPE_FUNC_INT_CTRL_MK         0x03000000
+#define __CPE_FUNC_INT_CTRL_SH         24
+#define __CPE_FUNC_INT_CTRL(_v)                ((_v) << __CPE_FUNC_INT_CTRL_SH)
+enum {
+       __CPE_FUNC_INT_CTRL_DISABLE             = 0x0,
+       __CPE_FUNC_INT_CTRL_F2NF                = 0x1,
+       __CPE_FUNC_INT_CTRL_3QUART              = 0x2,
+       __CPE_FUNC_INT_CTRL_HALF                = 0x3,
+};
+#define __CPE_CTRL_UNUSED20_MK         0x00f00000
+#define __CPE_CTRL_UNUSED20_SH         20
+#define __CPE_CTRL_UNUSED20(_v)                ((_v) << __CPE_CTRL_UNUSED20_SH)
+#define __CPE_SCI_TH_MK                        0x000f0000
+#define __CPE_SCI_TH_SH                        16
+#define __CPE_SCI_TH(_v)               ((_v) << __CPE_SCI_TH_SH)
+#define __CPE_CTRL_UNUSED10_MK         0x0000c000
+#define __CPE_CTRL_UNUSED10_SH         14
+#define __CPE_CTRL_UNUSED10(_v)                ((_v) << __CPE_CTRL_UNUSED10_SH)
+#define __CPE_ACK_PENDING              0x00002000
+#define __CPE_CTRL_UNUSED40_MK         0x00001c00
+#define __CPE_CTRL_UNUSED40_SH         10
+#define __CPE_CTRL_UNUSED40(_v)                ((_v) << __CPE_CTRL_UNUSED40_SH)
+#define __CPE_PCIEID_MK                        0x00000300
+#define __CPE_PCIEID_SH                        8
+#define __CPE_PCIEID(_v)               ((_v) << __CPE_PCIEID_SH)
+#define __CPE_CTRL_UNUSED00_MK         0x000000fe
+#define __CPE_CTRL_UNUSED00_SH         1
+#define __CPE_CTRL_UNUSED00(_v)                ((_v) << __CPE_CTRL_UNUSED00_SH)
+#define __CPE_ESIZE                    0x00000001
+#define CPE_QCTRL_Q1                   0x0003804c
+#define __CPE_CTRL_UNUSED31_MK         0xfc000000
+#define __CPE_CTRL_UNUSED31_SH         26
+#define __CPE_CTRL_UNUSED31(_v)                ((_v) << __CPE_CTRL_UNUSED31_SH)
+#define __CPE_CTRL_UNUSED21_MK         0x00f00000
+#define __CPE_CTRL_UNUSED21_SH         20
+#define __CPE_CTRL_UNUSED21(_v)                ((_v) << __CPE_CTRL_UNUSED21_SH)
+#define __CPE_CTRL_UNUSED11_MK         0x0000c000
+#define __CPE_CTRL_UNUSED11_SH         14
+#define __CPE_CTRL_UNUSED11(_v)                ((_v) << __CPE_CTRL_UNUSED11_SH)
+#define __CPE_CTRL_UNUSED41_MK         0x00001c00
+#define __CPE_CTRL_UNUSED41_SH         10
+#define __CPE_CTRL_UNUSED41(_v)                ((_v) << __CPE_CTRL_UNUSED41_SH)
+#define __CPE_CTRL_UNUSED01_MK         0x000000fe
+#define __CPE_CTRL_UNUSED01_SH         1
+#define __CPE_CTRL_UNUSED01(_v)                ((_v) << __CPE_CTRL_UNUSED01_SH)
+#define RME_PI_PTR_Q0                  0x00038020
+#define __LATENCY_TIME_STAMP_MK                0xffff0000
+#define __LATENCY_TIME_STAMP_SH                16
+#define __LATENCY_TIME_STAMP(_v)       ((_v) << __LATENCY_TIME_STAMP_SH)
+#define __RME_PI_PTR                   0x0000ffff
+#define RME_PI_PTR_Q1                  0x00038060
+#define RME_CI_PTR_Q0                  0x00038024
+#define __DELAY_TIME_STAMP_MK          0xffff0000
+#define __DELAY_TIME_STAMP_SH          16
+#define __DELAY_TIME_STAMP(_v)         ((_v) << __DELAY_TIME_STAMP_SH)
+#define __RME_CI_PTR                   0x0000ffff
+#define RME_CI_PTR_Q1                  0x00038064
+#define RME_DEPTH_Q0                   0x00038028
+#define __RME_DEPTH_UNUSED_MK          0xf8000000
+#define __RME_DEPTH_UNUSED_SH          27
+#define __RME_DEPTH_UNUSED(_v)         ((_v) << __RME_DEPTH_UNUSED_SH)
+#define __RME_MSIX_VEC_INDEX_MK                0x07ff0000
+#define __RME_MSIX_VEC_INDEX_SH                16
+#define __RME_MSIX_VEC_INDEX(_v)       ((_v) << __RME_MSIX_VEC_INDEX_SH)
+#define __RME_DEPTH                    0x0000ffff
+#define RME_DEPTH_Q1                   0x00038068
+#define RME_QCTRL_Q0                   0x0003802c
+#define __RME_INT_LATENCY_TIMER_MK     0xff000000
+#define __RME_INT_LATENCY_TIMER_SH     24
+#define __RME_INT_LATENCY_TIMER(_v)    ((_v) << __RME_INT_LATENCY_TIMER_SH)
+#define __RME_INT_DELAY_TIMER_MK       0x00ff0000
+#define __RME_INT_DELAY_TIMER_SH       16
+#define __RME_INT_DELAY_TIMER(_v)      ((_v) << __RME_INT_DELAY_TIMER_SH)
+#define __RME_INT_DELAY_DISABLE                0x00008000
+#define __RME_DLY_DELAY_DISABLE                0x00004000
+#define __RME_ACK_PENDING              0x00002000
+#define __RME_FULL_INTERRUPT_DISABLE   0x00001000
+#define __RME_CTRL_UNUSED10_MK         0x00000c00
+#define __RME_CTRL_UNUSED10_SH         10
+#define __RME_CTRL_UNUSED10(_v)                ((_v) << __RME_CTRL_UNUSED10_SH)
+#define __RME_PCIEID_MK                        0x00000300
+#define __RME_PCIEID_SH                        8
+#define __RME_PCIEID(_v)               ((_v) << __RME_PCIEID_SH)
+#define __RME_CTRL_UNUSED00_MK         0x000000fe
+#define __RME_CTRL_UNUSED00_SH         1
+#define __RME_CTRL_UNUSED00(_v)                ((_v) << __RME_CTRL_UNUSED00_SH)
+#define __RME_ESIZE                    0x00000001
+#define RME_QCTRL_Q1                   0x0003806c
+#define __RME_CTRL_UNUSED11_MK         0x00000c00
+#define __RME_CTRL_UNUSED11_SH         10
+#define __RME_CTRL_UNUSED11(_v)                ((_v) << __RME_CTRL_UNUSED11_SH)
+#define __RME_CTRL_UNUSED01_MK         0x000000fe
+#define __RME_CTRL_UNUSED01_SH         1
+#define __RME_CTRL_UNUSED01(_v)                ((_v) << __RME_CTRL_UNUSED01_SH)
+#define PSS_CTL_REG                    0x00018800
+#define __PSS_I2C_CLK_DIV_MK           0x007f0000
+#define __PSS_I2C_CLK_DIV_SH           16
+#define __PSS_I2C_CLK_DIV(_v)          ((_v) << __PSS_I2C_CLK_DIV_SH)
+#define __PSS_LMEM_INIT_DONE           0x00001000
+#define __PSS_LMEM_RESET               0x00000200
+#define __PSS_LMEM_INIT_EN             0x00000100
+#define __PSS_LPU1_RESET               0x00000002
+#define __PSS_LPU0_RESET               0x00000001
+#define PSS_ERR_STATUS_REG             0x00018810
+#define __PSS_LPU1_TCM_READ_ERR                0x00200000
+#define __PSS_LPU0_TCM_READ_ERR                0x00100000
+#define __PSS_LMEM5_CORR_ERR           0x00080000
+#define __PSS_LMEM4_CORR_ERR           0x00040000
+#define __PSS_LMEM3_CORR_ERR           0x00020000
+#define __PSS_LMEM2_CORR_ERR           0x00010000
+#define __PSS_LMEM1_CORR_ERR           0x00008000
+#define __PSS_LMEM0_CORR_ERR           0x00004000
+#define __PSS_LMEM5_UNCORR_ERR         0x00002000
+#define __PSS_LMEM4_UNCORR_ERR         0x00001000
+#define __PSS_LMEM3_UNCORR_ERR         0x00000800
+#define __PSS_LMEM2_UNCORR_ERR         0x00000400
+#define __PSS_LMEM1_UNCORR_ERR         0x00000200
+#define __PSS_LMEM0_UNCORR_ERR         0x00000100
+#define __PSS_BAL_PERR                 0x00000080
+#define __PSS_DIP_IF_ERR               0x00000040
+#define __PSS_IOH_IF_ERR               0x00000020
+#define __PSS_TDS_IF_ERR               0x00000010
+#define __PSS_RDS_IF_ERR               0x00000008
+#define __PSS_SGM_IF_ERR               0x00000004
+#define __PSS_LPU1_RAM_ERR             0x00000002
+#define __PSS_LPU0_RAM_ERR             0x00000001
+#define ERR_SET_REG                    0x00018818
+#define __PSS_ERR_STATUS_SET           0x003fffff
+#define PMM_1T_RESET_REG_P0            0x0002381c
+#define __PMM_1T_RESET_P               0x00000001
+#define PMM_1T_RESET_REG_P1            0x00023c1c
+#define HQM_QSET0_RXQ_DRBL_P0          0x00038000
+#define __RXQ0_ADD_VECTORS_P           0x80000000
+#define __RXQ0_STOP_P                  0x40000000
+#define __RXQ0_PRD_PTR_P               0x0000ffff
+#define HQM_QSET1_RXQ_DRBL_P0          0x00038080
+#define __RXQ1_ADD_VECTORS_P           0x80000000
+#define __RXQ1_STOP_P                  0x40000000
+#define __RXQ1_PRD_PTR_P               0x0000ffff
+#define HQM_QSET0_RXQ_DRBL_P1          0x0003c000
+#define HQM_QSET1_RXQ_DRBL_P1          0x0003c080
+#define HQM_QSET0_TXQ_DRBL_P0          0x00038020
+#define __TXQ0_ADD_VECTORS_P           0x80000000
+#define __TXQ0_STOP_P                  0x40000000
+#define __TXQ0_PRD_PTR_P               0x0000ffff
+#define HQM_QSET1_TXQ_DRBL_P0          0x000380a0
+#define __TXQ1_ADD_VECTORS_P           0x80000000
+#define __TXQ1_STOP_P                  0x40000000
+#define __TXQ1_PRD_PTR_P               0x0000ffff
+#define HQM_QSET0_TXQ_DRBL_P1          0x0003c020
+#define HQM_QSET1_TXQ_DRBL_P1          0x0003c0a0
+#define HQM_QSET0_IB_DRBL_1_P0         0x00038040
+#define __IB1_0_ACK_P                  0x80000000
+#define __IB1_0_DISABLE_P              0x40000000
+#define __IB1_0_COALESCING_CFG_P_MK    0x00ff0000
+#define __IB1_0_COALESCING_CFG_P_SH    16
+#define __IB1_0_COALESCING_CFG_P(_v)   ((_v) << __IB1_0_COALESCING_CFG_P_SH)
+#define __IB1_0_NUM_OF_ACKED_EVENTS_P  0x0000ffff
+#define HQM_QSET1_IB_DRBL_1_P0         0x000380c0
+#define __IB1_1_ACK_P                  0x80000000
+#define __IB1_1_DISABLE_P              0x40000000
+#define __IB1_1_COALESCING_CFG_P_MK    0x00ff0000
+#define __IB1_1_COALESCING_CFG_P_SH    16
+#define __IB1_1_COALESCING_CFG_P(_v)   ((_v) << __IB1_1_COALESCING_CFG_P_SH)
+#define __IB1_1_NUM_OF_ACKED_EVENTS_P  0x0000ffff
+#define HQM_QSET0_IB_DRBL_1_P1         0x0003c040
+#define HQM_QSET1_IB_DRBL_1_P1         0x0003c0c0
+#define HQM_QSET0_IB_DRBL_2_P0         0x00038060
+#define __IB2_0_ACK_P                  0x80000000
+#define __IB2_0_DISABLE_P              0x40000000
+#define __IB2_0_COALESCING_CFG_P_MK    0x00ff0000
+#define __IB2_0_COALESCING_CFG_P_SH    16
+#define __IB2_0_COALESCING_CFG_P(_v)   ((_v) << __IB2_0_COALESCING_CFG_P_SH)
+#define __IB2_0_NUM_OF_ACKED_EVENTS_P  0x0000ffff
+#define HQM_QSET1_IB_DRBL_2_P0         0x000380e0
+#define __IB2_1_ACK_P                  0x80000000
+#define __IB2_1_DISABLE_P              0x40000000
+#define __IB2_1_COALESCING_CFG_P_MK    0x00ff0000
+#define __IB2_1_COALESCING_CFG_P_SH    16
+#define __IB2_1_COALESCING_CFG_P(_v)   ((_v) << __IB2_1_COALESCING_CFG_P_SH)
+#define __IB2_1_NUM_OF_ACKED_EVENTS_P  0x0000ffff
+#define HQM_QSET0_IB_DRBL_2_P1         0x0003c060
+#define HQM_QSET1_IB_DRBL_2_P1         0x0003c0e0
+
+
+/*
+ * These definitions are either in error/missing in spec. Its auto-generated
+ * from hard coded values in regparse.pl.
+ */
+#define __EMPHPOST_AT_4G_MK_FIX                0x0000001c
+#define __EMPHPOST_AT_4G_SH_FIX                0x00000002
+#define __EMPHPRE_AT_4G_FIX            0x00000003
+#define __SFP_TXRATE_EN_FIX            0x00000100
+#define __SFP_RXRATE_EN_FIX            0x00000080
+
+
+/*
+ * These register definitions are auto-generated from hard coded values
+ * in regparse.pl.
+ */
+
+
+/*
+ * These register mapping definitions are auto-generated from mapping tables
+ * in regparse.pl.
+ */
+#define BFA_IOC0_HBEAT_REG             HOST_SEM0_INFO_REG
+#define BFA_IOC0_STATE_REG             HOST_SEM1_INFO_REG
+#define BFA_IOC1_HBEAT_REG             HOST_SEM2_INFO_REG
+#define BFA_IOC1_STATE_REG             HOST_SEM3_INFO_REG
+#define BFA_FW_USE_COUNT                HOST_SEM4_INFO_REG
+
+#define CPE_DEPTH_Q(__n) \
+       (CPE_DEPTH_Q0 + (__n) * (CPE_DEPTH_Q1 - CPE_DEPTH_Q0))
+#define CPE_QCTRL_Q(__n) \
+       (CPE_QCTRL_Q0 + (__n) * (CPE_QCTRL_Q1 - CPE_QCTRL_Q0))
+#define CPE_PI_PTR_Q(__n) \
+       (CPE_PI_PTR_Q0 + (__n) * (CPE_PI_PTR_Q1 - CPE_PI_PTR_Q0))
+#define CPE_CI_PTR_Q(__n) \
+       (CPE_CI_PTR_Q0 + (__n) * (CPE_CI_PTR_Q1 - CPE_CI_PTR_Q0))
+#define RME_DEPTH_Q(__n) \
+       (RME_DEPTH_Q0 + (__n) * (RME_DEPTH_Q1 - RME_DEPTH_Q0))
+#define RME_QCTRL_Q(__n) \
+       (RME_QCTRL_Q0 + (__n) * (RME_QCTRL_Q1 - RME_QCTRL_Q0))
+#define RME_PI_PTR_Q(__n) \
+       (RME_PI_PTR_Q0 + (__n) * (RME_PI_PTR_Q1 - RME_PI_PTR_Q0))
+#define RME_CI_PTR_Q(__n) \
+       (RME_CI_PTR_Q0 + (__n) * (RME_CI_PTR_Q1 - RME_CI_PTR_Q0))
+#define HQM_QSET_RXQ_DRBL_P0(__n) (HQM_QSET0_RXQ_DRBL_P0 + (__n) \
+       * (HQM_QSET1_RXQ_DRBL_P0 - HQM_QSET0_RXQ_DRBL_P0))
+#define HQM_QSET_TXQ_DRBL_P0(__n) (HQM_QSET0_TXQ_DRBL_P0 + (__n) \
+       * (HQM_QSET1_TXQ_DRBL_P0 - HQM_QSET0_TXQ_DRBL_P0))
+#define HQM_QSET_IB_DRBL_1_P0(__n) (HQM_QSET0_IB_DRBL_1_P0 + (__n) \
+       * (HQM_QSET1_IB_DRBL_1_P0 - HQM_QSET0_IB_DRBL_1_P0))
+#define HQM_QSET_IB_DRBL_2_P0(__n) (HQM_QSET0_IB_DRBL_2_P0 + (__n) \
+       * (HQM_QSET1_IB_DRBL_2_P0 - HQM_QSET0_IB_DRBL_2_P0))
+#define HQM_QSET_RXQ_DRBL_P1(__n) (HQM_QSET0_RXQ_DRBL_P1 + (__n) \
+       * (HQM_QSET1_RXQ_DRBL_P1 - HQM_QSET0_RXQ_DRBL_P1))
+#define HQM_QSET_TXQ_DRBL_P1(__n) (HQM_QSET0_TXQ_DRBL_P1 + (__n) \
+       * (HQM_QSET1_TXQ_DRBL_P1 - HQM_QSET0_TXQ_DRBL_P1))
+#define HQM_QSET_IB_DRBL_1_P1(__n) (HQM_QSET0_IB_DRBL_1_P1 + (__n) \
+       * (HQM_QSET1_IB_DRBL_1_P1 - HQM_QSET0_IB_DRBL_1_P1))
+#define HQM_QSET_IB_DRBL_2_P1(__n) (HQM_QSET0_IB_DRBL_2_P1 + (__n) \
+       * (HQM_QSET1_IB_DRBL_2_P1 - HQM_QSET0_IB_DRBL_2_P1))
+
+#define CPE_Q_NUM(__fn, __q) (((__fn) << 2) + (__q))
+#define RME_Q_NUM(__fn, __q) (((__fn) << 2) + (__q))
+#define CPE_Q_MASK(__q) ((__q) & 0x3)
+#define RME_Q_MASK(__q) ((__q) & 0x3)
+
+
+/*
+ * PCI MSI-X vector defines
+ */
+enum {
+       BFA_MSIX_CPE_Q0 = 0,
+       BFA_MSIX_CPE_Q1 = 1,
+       BFA_MSIX_CPE_Q2 = 2,
+       BFA_MSIX_CPE_Q3 = 3,
+       BFA_MSIX_RME_Q0 = 4,
+       BFA_MSIX_RME_Q1 = 5,
+       BFA_MSIX_RME_Q2 = 6,
+       BFA_MSIX_RME_Q3 = 7,
+       BFA_MSIX_LPU_ERR = 8,
+       BFA_MSIX_CT_MAX = 9,
+};
+
+/*
+ * And corresponding host interrupt status bit field defines
+ */
+#define __HFN_INT_CPE_Q0               0x00000001U
+#define __HFN_INT_CPE_Q1               0x00000002U
+#define __HFN_INT_CPE_Q2               0x00000004U
+#define __HFN_INT_CPE_Q3               0x00000008U
+#define __HFN_INT_CPE_Q4               0x00000010U
+#define __HFN_INT_CPE_Q5               0x00000020U
+#define __HFN_INT_CPE_Q6               0x00000040U
+#define __HFN_INT_CPE_Q7               0x00000080U
+#define __HFN_INT_RME_Q0               0x00000100U
+#define __HFN_INT_RME_Q1               0x00000200U
+#define __HFN_INT_RME_Q2               0x00000400U
+#define __HFN_INT_RME_Q3               0x00000800U
+#define __HFN_INT_RME_Q4               0x00001000U
+#define __HFN_INT_RME_Q5               0x00002000U
+#define __HFN_INT_RME_Q6               0x00004000U
+#define __HFN_INT_RME_Q7               0x00008000U
+#define __HFN_INT_ERR_EMC              0x00010000U
+#define __HFN_INT_ERR_LPU0             0x00020000U
+#define __HFN_INT_ERR_LPU1             0x00040000U
+#define __HFN_INT_ERR_PSS              0x00080000U
+#define __HFN_INT_MBOX_LPU0            0x00100000U
+#define __HFN_INT_MBOX_LPU1            0x00200000U
+#define __HFN_INT_MBOX1_LPU0           0x00400000U
+#define __HFN_INT_MBOX1_LPU1           0x00800000U
+#define __HFN_INT_LL_HALT              0x01000000U
+#define __HFN_INT_CPE_MASK             0x000000ffU
+#define __HFN_INT_RME_MASK             0x0000ff00U
+
+
+/*
+ * catapult memory map.
+ */
+#define LL_PGN_HQM0            0x0096
+#define LL_PGN_HQM1            0x0097
+#define PSS_SMEM_PAGE_START    0x8000
+#define PSS_SMEM_PGNUM(_pg0, _ma)      ((_pg0) + ((_ma) >> 15))
+#define PSS_SMEM_PGOFF(_ma)    ((_ma) & 0x7fff)
+
+/*
+ * End of catapult memory map
+ */
+
+
+#endif /* __BFI_CTREG_H__ */
diff --git a/drivers/scsi/bfa/bfi_ms.h b/drivers/scsi/bfa/bfi_ms.h
new file mode 100644 (file)
index 0000000..69ac85f
--- /dev/null
@@ -0,0 +1,765 @@
+/*
+ * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
+ * All rights reserved
+ * www.brocade.com
+ *
+ * Linux driver for Brocade Fibre Channel Host Bus Adapter.
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License (GPL) Version 2 as
+ * published by the Free Software Foundation
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * General Public License for more details.
+ */
+
+#ifndef __BFI_MS_H__
+#define __BFI_MS_H__
+
+#include "bfi.h"
+#include "bfa_fc.h"
+#include "bfa_defs_svc.h"
+
+#pragma pack(1)
+
+enum bfi_iocfc_h2i_msgs {
+       BFI_IOCFC_H2I_CFG_REQ           = 1,
+       BFI_IOCFC_H2I_SET_INTR_REQ      = 2,
+       BFI_IOCFC_H2I_UPDATEQ_REQ       = 3,
+};
+
+enum bfi_iocfc_i2h_msgs {
+       BFI_IOCFC_I2H_CFG_REPLY         = BFA_I2HM(1),
+       BFI_IOCFC_I2H_UPDATEQ_RSP       = BFA_I2HM(3),
+};
+
+struct bfi_iocfc_cfg_s {
+       u8      num_cqs;        /*  Number of CQs to be used    */
+       u8       sense_buf_len; /*  SCSI sense length       */
+       u16     rsvd_1;
+       u32     endian_sig;     /*  endian signature of host     */
+
+       /**
+        * Request and response circular queue base addresses, size and
+        * shadow index pointers.
+        */
+       union bfi_addr_u  req_cq_ba[BFI_IOC_MAX_CQS];
+       union bfi_addr_u  req_shadow_ci[BFI_IOC_MAX_CQS];
+       u16    req_cq_elems[BFI_IOC_MAX_CQS];
+       union bfi_addr_u  rsp_cq_ba[BFI_IOC_MAX_CQS];
+       union bfi_addr_u  rsp_shadow_pi[BFI_IOC_MAX_CQS];
+       u16    rsp_cq_elems[BFI_IOC_MAX_CQS];
+
+       union bfi_addr_u  stats_addr;   /*  DMA-able address for stats    */
+       union bfi_addr_u  cfgrsp_addr;  /*  config response dma address  */
+       union bfi_addr_u  ioim_snsbase;  /*  IO sense buffer base address */
+       struct bfa_iocfc_intr_attr_s intr_attr; /*  IOC interrupt attributes */
+};
+
+/**
+ * Boot target wwn information for this port. This contains either the stored
+ * or discovered boot target port wwns for the port.
+ */
+struct bfi_iocfc_bootwwns {
+       wwn_t           wwn[BFA_BOOT_BOOTLUN_MAX];
+       u8              nwwns;
+       u8              rsvd[7];
+};
+
+struct bfi_iocfc_cfgrsp_s {
+       struct bfa_iocfc_fwcfg_s        fwcfg;
+       struct bfa_iocfc_intr_attr_s    intr_attr;
+       struct bfi_iocfc_bootwwns       bootwwns;
+       struct bfi_pbc_s                pbc_cfg;
+};
+
+/**
+ * BFI_IOCFC_H2I_CFG_REQ message
+ */
+struct bfi_iocfc_cfg_req_s {
+       struct bfi_mhdr_s      mh;
+       union bfi_addr_u      ioc_cfg_dma_addr;
+};
+
+
+/**
+ * BFI_IOCFC_I2H_CFG_REPLY message
+ */
+struct bfi_iocfc_cfg_reply_s {
+       struct bfi_mhdr_s  mh;          /*  Common msg header     */
+       u8       cfg_success;   /*  cfg reply status       */
+       u8       lpu_bm;                /*  LPUs assigned for this IOC */
+       u8       rsvd[2];
+};
+
+
+/**
+ * BFI_IOCFC_H2I_SET_INTR_REQ message
+ */
+struct bfi_iocfc_set_intr_req_s {
+       struct bfi_mhdr_s mh;           /*  common msg header           */
+       u8              coalesce;       /*  enable intr coalescing      */
+       u8              rsvd[3];
+       u16     delay;          /*  delay timer 0..1125us       */
+       u16     latency;        /*  latency timer 0..225us      */
+};
+
+
+/**
+ * BFI_IOCFC_H2I_UPDATEQ_REQ message
+ */
+struct bfi_iocfc_updateq_req_s {
+       struct bfi_mhdr_s mh;           /*  common msg header           */
+       u32 reqq_ba;            /*  reqq base addr              */
+       u32 rspq_ba;            /*  rspq base addr              */
+       u32 reqq_sci;           /*  reqq shadow ci              */
+       u32 rspq_spi;           /*  rspq shadow pi              */
+};
+
+
+/**
+ * BFI_IOCFC_I2H_UPDATEQ_RSP message
+ */
+struct bfi_iocfc_updateq_rsp_s {
+       struct bfi_mhdr_s mh;           /*  common msg header   */
+       u8      status;                 /*  updateq  status     */
+       u8      rsvd[3];
+};
+
+
+/**
+ * H2I Messages
+ */
+union bfi_iocfc_h2i_msg_u {
+       struct bfi_mhdr_s               mh;
+       struct bfi_iocfc_cfg_req_s      cfg_req;
+       struct bfi_iocfc_updateq_req_s updateq_req;
+       u32 mboxmsg[BFI_IOC_MSGSZ];
+};
+
+
+/**
+ * I2H Messages
+ */
+union bfi_iocfc_i2h_msg_u {
+       struct bfi_mhdr_s               mh;
+       struct bfi_iocfc_cfg_reply_s    cfg_reply;
+       struct bfi_iocfc_updateq_rsp_s updateq_rsp;
+       u32 mboxmsg[BFI_IOC_MSGSZ];
+};
+
+
+enum bfi_fcport_h2i {
+       BFI_FCPORT_H2I_ENABLE_REQ               = (1),
+       BFI_FCPORT_H2I_DISABLE_REQ              = (2),
+       BFI_FCPORT_H2I_SET_SVC_PARAMS_REQ       = (3),
+       BFI_FCPORT_H2I_STATS_GET_REQ            = (4),
+       BFI_FCPORT_H2I_STATS_CLEAR_REQ          = (5),
+};
+
+
+enum bfi_fcport_i2h {
+       BFI_FCPORT_I2H_ENABLE_RSP               = BFA_I2HM(1),
+       BFI_FCPORT_I2H_DISABLE_RSP              = BFA_I2HM(2),
+       BFI_FCPORT_I2H_SET_SVC_PARAMS_RSP       = BFA_I2HM(3),
+       BFI_FCPORT_I2H_STATS_GET_RSP            = BFA_I2HM(4),
+       BFI_FCPORT_I2H_STATS_CLEAR_RSP          = BFA_I2HM(5),
+       BFI_FCPORT_I2H_EVENT                    = BFA_I2HM(6),
+       BFI_FCPORT_I2H_TRUNK_SCN                = BFA_I2HM(7),
+       BFI_FCPORT_I2H_ENABLE_AEN               = BFA_I2HM(8),
+       BFI_FCPORT_I2H_DISABLE_AEN              = BFA_I2HM(9),
+};
+
+
+/**
+ * Generic REQ type
+ */
+struct bfi_fcport_req_s {
+       struct bfi_mhdr_s  mh;          /*  msg header                      */
+       u32        msgtag;      /*  msgtag for reply                */
+};
+
+/**
+ * Generic RSP type
+ */
+struct bfi_fcport_rsp_s {
+       struct bfi_mhdr_s  mh;          /*  common msg header               */
+       u8                 status;      /*  port enable status              */
+       u8                 rsvd[3];
+       u32        msgtag;      /*  msgtag for reply                */
+};
+
+/**
+ * BFI_FCPORT_H2I_ENABLE_REQ
+ */
+struct bfi_fcport_enable_req_s {
+       struct bfi_mhdr_s  mh;          /*  msg header                      */
+       u32        rsvd1;
+       wwn_t              nwwn;        /*  node wwn of physical port       */
+       wwn_t              pwwn;        /*  port wwn of physical port       */
+       struct bfa_port_cfg_s port_cfg; /*  port configuration      */
+       union bfi_addr_u   stats_dma_addr; /*  DMA address for stats        */
+       u32        msgtag;      /*  msgtag for reply                */
+       u32        rsvd2;
+};
+
+/**
+ * BFI_FCPORT_H2I_SET_SVC_PARAMS_REQ
+ */
+struct bfi_fcport_set_svc_params_req_s {
+       struct bfi_mhdr_s  mh;          /*  msg header */
+       u16        tx_bbcredit; /*  Tx credits */
+       u16        rsvd;
+};
+
+/**
+ * BFI_FCPORT_I2H_EVENT
+ */
+struct bfi_fcport_event_s {
+       struct bfi_mhdr_s       mh;     /*  common msg header */
+       struct bfa_port_link_s  link_state;
+};
+
+/**
+ * BFI_FCPORT_I2H_TRUNK_SCN
+ */
+struct bfi_fcport_trunk_link_s {
+       wwn_t                   trunk_wwn;
+       u8                      fctl;           /* bfa_trunk_link_fctl_t */
+       u8                      state;          /* bfa_trunk_link_state_t */
+       u8                      speed;          /* bfa_port_speed_t */
+       u8                      rsvd;
+       u32             deskew;
+};
+
+#define BFI_FCPORT_MAX_LINKS   2
+struct bfi_fcport_trunk_scn_s {
+       struct bfi_mhdr_s       mh;
+       u8                      trunk_state;    /* bfa_trunk_state_t */
+       u8                      trunk_speed;    /* bfa_port_speed_t */
+       u8                      rsvd_a[2];
+       struct bfi_fcport_trunk_link_s tlink[BFI_FCPORT_MAX_LINKS];
+};
+
+/**
+ * fcport H2I message
+ */
+union bfi_fcport_h2i_msg_u {
+       struct bfi_mhdr_s                       *mhdr;
+       struct bfi_fcport_enable_req_s          *penable;
+       struct bfi_fcport_req_s                 *pdisable;
+       struct bfi_fcport_set_svc_params_req_s  *psetsvcparams;
+       struct bfi_fcport_req_s                 *pstatsget;
+       struct bfi_fcport_req_s                 *pstatsclear;
+};
+
+/**
+ * fcport I2H message
+ */
+union bfi_fcport_i2h_msg_u {
+       struct bfi_msg_s                        *msg;
+       struct bfi_fcport_rsp_s                 *penable_rsp;
+       struct bfi_fcport_rsp_s                 *pdisable_rsp;
+       struct bfi_fcport_rsp_s                 *psetsvcparams_rsp;
+       struct bfi_fcport_rsp_s                 *pstatsget_rsp;
+       struct bfi_fcport_rsp_s                 *pstatsclear_rsp;
+       struct bfi_fcport_event_s               *event;
+       struct bfi_fcport_trunk_scn_s           *trunk_scn;
+};
+
+enum bfi_fcxp_h2i {
+       BFI_FCXP_H2I_SEND_REQ = 1,
+};
+
+enum bfi_fcxp_i2h {
+       BFI_FCXP_I2H_SEND_RSP = BFA_I2HM(1),
+};
+
+#define BFA_FCXP_MAX_SGES      2
+
+/**
+ * FCXP send request structure
+ */
+struct bfi_fcxp_send_req_s {
+       struct bfi_mhdr_s  mh;          /*  Common msg header               */
+       u16     fcxp_tag;       /*  driver request tag              */
+       u16     max_frmsz;      /*  max send frame size     */
+       u16     vf_id;          /*  vsan tag if applicable          */
+       u16     rport_fw_hndl;  /*  FW Handle for the remote port  */
+       u8       class;         /*  FC class used for req/rsp       */
+       u8       rsp_timeout;   /*  timeout in secs, 0-no response */
+       u8       cts;           /*  continue sequence               */
+       u8       lp_tag;        /*  lport tag                       */
+       struct fchs_s   fchs;   /*  request FC header structure    */
+       u32     req_len;        /*  request payload length          */
+       u32     rsp_maxlen;     /*  max response length expected   */
+       struct bfi_sge_s   req_sge[BFA_FCXP_MAX_SGES];  /*  request buf    */
+       struct bfi_sge_s   rsp_sge[BFA_FCXP_MAX_SGES];  /*  response buf   */
+};
+
+/**
+ * FCXP send response structure
+ */
+struct bfi_fcxp_send_rsp_s {
+       struct bfi_mhdr_s  mh;          /*  Common msg header               */
+       u16     fcxp_tag;       /*  send request tag                */
+       u8       req_status;    /*  request status                  */
+       u8       rsvd;
+       u32     rsp_len;        /*  actual response length          */
+       u32     residue_len;    /*  residual response length        */
+       struct fchs_s   fchs;   /*  response FC header structure   */
+};
+
+enum bfi_uf_h2i {
+       BFI_UF_H2I_BUF_POST = 1,
+};
+
+enum bfi_uf_i2h {
+       BFI_UF_I2H_FRM_RCVD = BFA_I2HM(1),
+};
+
+#define BFA_UF_MAX_SGES        2
+
+struct bfi_uf_buf_post_s {
+       struct bfi_mhdr_s  mh;          /*  Common msg header           */
+       u16     buf_tag;        /*  buffer tag                  */
+       u16     buf_len;        /*  total buffer length */
+       struct bfi_sge_s   sge[BFA_UF_MAX_SGES]; /*  buffer DMA SGEs    */
+};
+
+struct bfi_uf_frm_rcvd_s {
+       struct bfi_mhdr_s  mh;          /*  Common msg header           */
+       u16     buf_tag;        /*  buffer tag                  */
+       u16     rsvd;
+       u16     frm_len;        /*  received frame length       */
+       u16     xfr_len;        /*  tranferred length           */
+};
+
+enum bfi_lps_h2i_msgs {
+       BFI_LPS_H2I_LOGIN_REQ   = 1,
+       BFI_LPS_H2I_LOGOUT_REQ  = 2,
+};
+
+enum bfi_lps_i2h_msgs {
+       BFI_LPS_H2I_LOGIN_RSP   = BFA_I2HM(1),
+       BFI_LPS_H2I_LOGOUT_RSP  = BFA_I2HM(2),
+       BFI_LPS_H2I_CVL_EVENT   = BFA_I2HM(3),
+};
+
+struct bfi_lps_login_req_s {
+       struct bfi_mhdr_s  mh;          /*  common msg header           */
+       u8              lp_tag;
+       u8              alpa;
+       u16     pdu_size;
+       wwn_t           pwwn;
+       wwn_t           nwwn;
+       u8              fdisc;
+       u8              auth_en;
+       u8              rsvd[2];
+};
+
+struct bfi_lps_login_rsp_s {
+       struct bfi_mhdr_s  mh;          /*  common msg header           */
+       u8              lp_tag;
+       u8              status;
+       u8              lsrjt_rsn;
+       u8              lsrjt_expl;
+       wwn_t           port_name;
+       wwn_t           node_name;
+       u16     bb_credit;
+       u8              f_port;
+       u8              npiv_en;
+       u32     lp_pid:24;
+       u32     auth_req:8;
+       mac_t           lp_mac;
+       mac_t           fcf_mac;
+       u8              ext_status;
+       u8              brcd_switch;    /*  attached peer is brcd switch */
+};
+
+struct bfi_lps_logout_req_s {
+       struct bfi_mhdr_s  mh;          /*  common msg header           */
+       u8              lp_tag;
+       u8              rsvd[3];
+       wwn_t           port_name;
+};
+
+struct bfi_lps_logout_rsp_s {
+       struct bfi_mhdr_s  mh;          /*  common msg header           */
+       u8              lp_tag;
+       u8              status;
+       u8              rsvd[2];
+};
+
+struct bfi_lps_cvl_event_s {
+       struct bfi_mhdr_s  mh;          /*  common msg header           */
+       u8              lp_tag;
+       u8              rsvd[3];
+};
+
+union bfi_lps_h2i_msg_u {
+       struct bfi_mhdr_s               *msg;
+       struct bfi_lps_login_req_s      *login_req;
+       struct bfi_lps_logout_req_s     *logout_req;
+};
+
+union bfi_lps_i2h_msg_u {
+       struct bfi_msg_s                *msg;
+       struct bfi_lps_login_rsp_s      *login_rsp;
+       struct bfi_lps_logout_rsp_s     *logout_rsp;
+       struct bfi_lps_cvl_event_s      *cvl_event;
+};
+
+enum bfi_rport_h2i_msgs {
+       BFI_RPORT_H2I_CREATE_REQ = 1,
+       BFI_RPORT_H2I_DELETE_REQ = 2,
+       BFI_RPORT_H2I_SET_SPEED_REQ  = 3,
+};
+
+enum bfi_rport_i2h_msgs {
+       BFI_RPORT_I2H_CREATE_RSP = BFA_I2HM(1),
+       BFI_RPORT_I2H_DELETE_RSP = BFA_I2HM(2),
+       BFI_RPORT_I2H_QOS_SCN    = BFA_I2HM(3),
+};
+
+struct bfi_rport_create_req_s {
+       struct bfi_mhdr_s  mh;          /*  common msg header           */
+       u16     bfa_handle;     /*  host rport handle           */
+       u16     max_frmsz;      /*  max rcv pdu size            */
+       u32     pid:24, /*  remote port ID              */
+               lp_tag:8;       /*  local port tag              */
+       u32     local_pid:24,   /*  local port ID               */
+               cisc:8;
+       u8      fc_class;       /*  supported FC classes        */
+       u8      vf_en;          /*  virtual fabric enable       */
+       u16     vf_id;          /*  virtual fabric ID           */
+};
+
+struct bfi_rport_create_rsp_s {
+       struct bfi_mhdr_s  mh;          /*  common msg header           */
+       u8              status;         /*  rport creation status       */
+       u8              rsvd[3];
+       u16     bfa_handle;     /*  host rport handle           */
+       u16     fw_handle;      /*  firmware rport handle       */
+       struct bfa_rport_qos_attr_s qos_attr;  /* QoS Attributes */
+};
+
+struct bfa_rport_speed_req_s {
+       struct bfi_mhdr_s  mh;          /*  common msg header           */
+       u16     fw_handle;      /*  firmware rport handle       */
+       u8              speed;          /*  rport's speed via RPSC      */
+       u8              rsvd;
+};
+
+struct bfi_rport_delete_req_s {
+       struct bfi_mhdr_s  mh;          /*  common msg header           */
+       u16     fw_handle;      /*  firmware rport handle       */
+       u16     rsvd;
+};
+
+struct bfi_rport_delete_rsp_s {
+       struct bfi_mhdr_s  mh;          /*  common msg header           */
+       u16     bfa_handle;     /*  host rport handle           */
+       u8              status;         /*  rport deletion status       */
+       u8              rsvd;
+};
+
+struct bfi_rport_qos_scn_s {
+       struct bfi_mhdr_s  mh;          /*  common msg header           */
+       u16     bfa_handle;     /*  host rport handle           */
+       u16     rsvd;
+       struct bfa_rport_qos_attr_s old_qos_attr;  /* Old QoS Attributes */
+       struct bfa_rport_qos_attr_s new_qos_attr;  /* New QoS Attributes */
+};
+
+union bfi_rport_h2i_msg_u {
+       struct bfi_msg_s                *msg;
+       struct bfi_rport_create_req_s   *create_req;
+       struct bfi_rport_delete_req_s   *delete_req;
+       struct bfi_rport_speed_req_s    *speed_req;
+};
+
+union bfi_rport_i2h_msg_u {
+       struct bfi_msg_s                *msg;
+       struct bfi_rport_create_rsp_s   *create_rsp;
+       struct bfi_rport_delete_rsp_s   *delete_rsp;
+       struct bfi_rport_qos_scn_s      *qos_scn_evt;
+};
+
+/*
+ * Initiator mode I-T nexus interface defines.
+ */
+
+enum bfi_itnim_h2i {
+       BFI_ITNIM_H2I_CREATE_REQ = 1,   /*  i-t nexus creation */
+       BFI_ITNIM_H2I_DELETE_REQ = 2,   /*  i-t nexus deletion */
+};
+
+enum bfi_itnim_i2h {
+       BFI_ITNIM_I2H_CREATE_RSP = BFA_I2HM(1),
+       BFI_ITNIM_I2H_DELETE_RSP = BFA_I2HM(2),
+       BFI_ITNIM_I2H_SLER_EVENT = BFA_I2HM(3),
+};
+
+struct bfi_itnim_create_req_s {
+       struct bfi_mhdr_s  mh;          /*  common msg header            */
+       u16     fw_handle;      /*  f/w handle for itnim         */
+       u8      class;          /*  FC class for IO              */
+       u8      seq_rec;        /*  sequence recovery support    */
+       u8      msg_no;         /*  seq id of the msg            */
+};
+
+struct bfi_itnim_create_rsp_s {
+       struct bfi_mhdr_s  mh;          /*  common msg header            */
+       u16     bfa_handle;     /*  bfa handle for itnim         */
+       u8      status;         /*  fcp request status           */
+       u8      seq_id;         /*  seq id of the msg            */
+};
+
+struct bfi_itnim_delete_req_s {
+       struct bfi_mhdr_s  mh;          /*  common msg header            */
+       u16     fw_handle;      /*  f/w itnim handle             */
+       u8      seq_id;         /*  seq id of the msg            */
+       u8      rsvd;
+};
+
+struct bfi_itnim_delete_rsp_s {
+       struct bfi_mhdr_s  mh;          /*  common msg header            */
+       u16     bfa_handle;     /*  bfa handle for itnim         */
+       u8      status;         /*  fcp request status           */
+       u8      seq_id;         /*  seq id of the msg            */
+};
+
+struct bfi_itnim_sler_event_s {
+       struct bfi_mhdr_s  mh;          /*  common msg header            */
+       u16     bfa_handle;     /*  bfa handle for itnim         */
+       u16     rsvd;
+};
+
+union bfi_itnim_h2i_msg_u {
+       struct bfi_itnim_create_req_s *create_req;
+       struct bfi_itnim_delete_req_s *delete_req;
+       struct bfi_msg_s        *msg;
+};
+
+union bfi_itnim_i2h_msg_u {
+       struct bfi_itnim_create_rsp_s *create_rsp;
+       struct bfi_itnim_delete_rsp_s *delete_rsp;
+       struct bfi_itnim_sler_event_s *sler_event;
+       struct bfi_msg_s        *msg;
+};
+
+/*
+ * Initiator mode IO interface defines.
+ */
+
+enum bfi_ioim_h2i {
+       BFI_IOIM_H2I_IOABORT_REQ = 1,   /*  IO abort request     */
+       BFI_IOIM_H2I_IOCLEANUP_REQ = 2, /*  IO cleanup request   */
+};
+
+enum bfi_ioim_i2h {
+       BFI_IOIM_I2H_IO_RSP = BFA_I2HM(1),      /*  non-fp IO response   */
+       BFI_IOIM_I2H_IOABORT_RSP = BFA_I2HM(2), /*  ABORT rsp    */
+};
+
+/**
+ * IO command DIF info
+ */
+struct bfi_ioim_dif_s {
+       u32     dif_info[4];
+};
+
+/**
+ * FCP IO messages overview
+ *
+ * @note
+ * - Max CDB length supported is 64 bytes.
+ * - SCSI Linked commands and SCSI bi-directional Commands not
+ *     supported.
+ *
+ */
+struct bfi_ioim_req_s {
+       struct bfi_mhdr_s  mh;          /*  Common msg header            */
+       u16     io_tag;         /*  I/O tag                      */
+       u16     rport_hdl;      /*  itnim/rport firmware handle */
+       struct fcp_cmnd_s       cmnd;   /*  IO request info     */
+
+       /**
+        * SG elements array within the IO request must be double word
+        * aligned. This aligment is required to optimize SGM setup for the IO.
+        */
+       struct bfi_sge_s        sges[BFI_SGE_INLINE_MAX];
+       u8      io_timeout;
+       u8      dif_en;
+       u8      rsvd_a[2];
+       struct bfi_ioim_dif_s  dif;
+};
+
+/**
+ *     This table shows various IO status codes from firmware and their
+ *     meaning. Host driver can use these status codes to further process
+ *     IO completions.
+ *
+ *     BFI_IOIM_STS_OK         : IO completed with error free SCSI &
+ *                                     transport status.
+ *                                      io-tag can be reused.
+ *
+ *     BFA_IOIM_STS_SCSI_ERR           : IO completed with scsi error.
+ *     - io-tag can be reused.
+ *
+ *     BFI_IOIM_STS_HOST_ABORTED       : IO was aborted successfully due to
+ *                                             host request.
+ *                                     - io-tag cannot be reused yet.
+ *
+ *     BFI_IOIM_STS_ABORTED            : IO was aborted successfully
+ *                                             internally by f/w.
+ *                                     - io-tag cannot be reused yet.
+ *
+ *     BFI_IOIM_STS_TIMEDOUT   : IO timedout and ABTS/RRQ is happening
+ *                                     in the firmware and
+ *                                     - io-tag cannot be reused yet.
+ *
+ *     BFI_IOIM_STS_SQER_NEEDED        : Firmware could not recover the IO
+ *                                       with sequence level error
+ *     logic and hence host needs to retry
+ *                                       this IO with a different IO tag
+ *                                     - io-tag cannot be used yet.
+ *
+ *     BFI_IOIM_STS_NEXUS_ABORT        : Second Level Error Recovery from host
+ *                                       is required because 2 consecutive ABTS
+ *                                       timedout and host needs logout and
+ *                                       re-login with the target
+ *                                     - io-tag cannot be used yet.
+ *
+ *     BFI_IOIM_STS_UNDERRUN   : IO completed with SCSI status good,
+ *                                       but the data tranferred is less than
+ *                                       the fcp data length in the command.
+ *                                       ex. SCSI INQUIRY where transferred
+ *                                       data length and residue count in FCP
+ *                                       response accounts for total fcp-dl
+ *                                       - io-tag can be reused.
+ *
+ *     BFI_IOIM_STS_OVERRUN    : IO completed with SCSI status good,
+ *                                       but the data transerred is more than
+ *                                       fcp data length in the command. ex.
+ *                                       TAPE IOs where blocks can of unequal
+ *                                       lengths.
+ *                                     - io-tag can be reused.
+ *
+ *     BFI_IOIM_STS_RES_FREE   : Firmware has completed using io-tag
+ *                                       during abort process
+ *                                     - io-tag can be reused.
+ *
+ *     BFI_IOIM_STS_PROTO_ERR  : Firmware detected a protocol error.
+ *                                       ex target sent more data than
+ *                                       requested, or there was data frame
+ *                                       loss and other reasons
+ *                                     - io-tag cannot be used yet.
+ *
+ *     BFI_IOIM_STS_DIF_ERR    : Firwmare detected DIF error. ex: DIF
+ *                                     CRC err or Ref Tag err or App tag err.
+ *                                     - io-tag can be reused.
+ *
+ *     BFA_IOIM_STS_TSK_MGT_ABORT      : IO was aborted because of Task
+ *                                       Management command from the host
+ *                                       - io-tag can be reused.
+ *
+ *     BFI_IOIM_STS_UTAG               : Firmware does not know about this
+ *                                       io_tag.
+ *                                     - io-tag can be reused.
+ */
+enum bfi_ioim_status {
+       BFI_IOIM_STS_OK = 0,
+       BFI_IOIM_STS_HOST_ABORTED = 1,
+       BFI_IOIM_STS_ABORTED = 2,
+       BFI_IOIM_STS_TIMEDOUT = 3,
+       BFI_IOIM_STS_RES_FREE = 4,
+       BFI_IOIM_STS_SQER_NEEDED = 5,
+       BFI_IOIM_STS_PROTO_ERR = 6,
+       BFI_IOIM_STS_UTAG = 7,
+       BFI_IOIM_STS_PATHTOV = 8,
+};
+
+#define BFI_IOIM_SNSLEN        (256)
+/**
+ * I/O response message
+ */
+struct bfi_ioim_rsp_s {
+       struct bfi_mhdr_s       mh;     /*  common msg header           */
+       u16     io_tag;         /*  completed IO tag             */
+       u16     bfa_rport_hndl; /*  releated rport handle        */
+       u8      io_status;      /*  IO completion status         */
+       u8      reuse_io_tag;   /*  IO tag can be reused        */
+       u16     abort_tag;      /*  host abort request tag      */
+       u8              scsi_status;    /*  scsi status from target      */
+       u8              sns_len;        /*  scsi sense length            */
+       u8              resid_flags;    /*  IO residue flags             */
+       u8              rsvd_a;
+       u32     residue;        /*  IO residual length in bytes */
+       u32     rsvd_b[3];
+};
+
+struct bfi_ioim_abort_req_s {
+       struct bfi_mhdr_s  mh;  /*  Common msg header  */
+       u16     io_tag; /*  I/O tag     */
+       u16     abort_tag;      /*  unique request tag */
+};
+
+/*
+ * Initiator mode task management command interface defines.
+ */
+
+enum bfi_tskim_h2i {
+       BFI_TSKIM_H2I_TM_REQ    = 1, /*  task-mgmt command      */
+       BFI_TSKIM_H2I_ABORT_REQ = 2, /*  task-mgmt command      */
+};
+
+enum bfi_tskim_i2h {
+       BFI_TSKIM_I2H_TM_RSP = BFA_I2HM(1),
+};
+
+struct bfi_tskim_req_s {
+       struct bfi_mhdr_s  mh;  /*  Common msg header   */
+       u16     tsk_tag;        /*  task management tag */
+       u16     itn_fhdl;       /*  itn firmware handle */
+       lun_t   lun;    /*  LU number   */
+       u8      tm_flags;       /*  see enum fcp_tm_cmnd        */
+       u8      t_secs; /*  Timeout value in seconds    */
+       u8      rsvd[2];
+};
+
+struct bfi_tskim_abortreq_s {
+       struct bfi_mhdr_s  mh;  /*  Common msg header   */
+       u16     tsk_tag;        /*  task management tag */
+       u16     rsvd;
+};
+
+enum bfi_tskim_status {
+       /*
+        * Following are FCP-4 spec defined status codes,
+        * **DO NOT CHANGE THEM **
+        */
+       BFI_TSKIM_STS_OK        = 0,
+       BFI_TSKIM_STS_NOT_SUPP = 4,
+       BFI_TSKIM_STS_FAILED    = 5,
+
+       /**
+        * Defined by BFA
+        */
+       BFI_TSKIM_STS_TIMEOUT  = 10,    /*  TM request timedout */
+       BFI_TSKIM_STS_ABORTED  = 11,    /*  Aborted on host request */
+};
+
+struct bfi_tskim_rsp_s {
+       struct bfi_mhdr_s  mh;          /*  Common msg header            */
+       u16     tsk_tag;        /*  task mgmt cmnd tag           */
+       u8      tsk_status;     /*  @ref bfi_tskim_status */
+       u8      rsvd;
+};
+
+#pragma pack()
+
+#endif /* __BFI_MS_H__ */
diff --git a/drivers/scsi/bfa/fab.c b/drivers/scsi/bfa/fab.c
deleted file mode 100644 (file)
index 7e3a4d5..0000000
+++ /dev/null
@@ -1,62 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#include <bfa.h>
-#include <bfa_svc.h>
-#include "fcs_lport.h"
-#include "fcs_rport.h"
-#include "lport_priv.h"
-
-/**
- *  fab.c port fab implementation.
- */
-
-/**
- *  bfa_fcs_port_fab_public port fab public functions
- */
-
-/**
- *   Called by port to initialize fabric services of the base port.
- */
-void
-bfa_fcs_port_fab_init(struct bfa_fcs_port_s *port)
-{
-       bfa_fcs_port_ns_init(port);
-       bfa_fcs_port_scn_init(port);
-       bfa_fcs_port_ms_init(port);
-}
-
-/**
- *   Called by port to notify transition to online state.
- */
-void
-bfa_fcs_port_fab_online(struct bfa_fcs_port_s *port)
-{
-       bfa_fcs_port_ns_online(port);
-       bfa_fcs_port_scn_online(port);
-}
-
-/**
- *   Called by port to notify transition to offline state.
- */
-void
-bfa_fcs_port_fab_offline(struct bfa_fcs_port_s *port)
-{
-       bfa_fcs_port_ns_offline(port);
-       bfa_fcs_port_scn_offline(port);
-       bfa_fcs_port_ms_offline(port);
-}
diff --git a/drivers/scsi/bfa/fabric.c b/drivers/scsi/bfa/fabric.c
deleted file mode 100644 (file)
index ddd4ba9..0000000
+++ /dev/null
@@ -1,1323 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  fabric.c Fabric module implementation.
- */
-
-#include "fcs_fabric.h"
-#include "fcs_lport.h"
-#include "fcs_vport.h"
-#include "fcs_trcmod.h"
-#include "fcs_fcxp.h"
-#include "fcs_auth.h"
-#include "fcs.h"
-#include "fcbuild.h"
-#include <log/bfa_log_fcs.h>
-#include <aen/bfa_aen_port.h>
-#include <bfa_svc.h>
-
-BFA_TRC_FILE(FCS, FABRIC);
-
-#define BFA_FCS_FABRIC_RETRY_DELAY     (2000)  /* Milliseconds */
-#define BFA_FCS_FABRIC_CLEANUP_DELAY   (10000) /* Milliseconds */
-
-#define bfa_fcs_fabric_set_opertype(__fabric) do {             \
-       if (bfa_fcport_get_topology((__fabric)->fcs->bfa)       \
-                               == BFA_PPORT_TOPOLOGY_P2P)     \
-               (__fabric)->oper_type = BFA_PPORT_TYPE_NPORT;  \
-       else                                                   \
-               (__fabric)->oper_type = BFA_PPORT_TYPE_NLPORT; \
-} while (0)
-
-/*
- * forward declarations
- */
-static void     bfa_fcs_fabric_init(struct bfa_fcs_fabric_s *fabric);
-static void     bfa_fcs_fabric_login(struct bfa_fcs_fabric_s *fabric);
-static void     bfa_fcs_fabric_notify_online(struct bfa_fcs_fabric_s *fabric);
-static void     bfa_fcs_fabric_notify_offline(struct bfa_fcs_fabric_s *fabric);
-static void     bfa_fcs_fabric_delay(void *cbarg);
-static void     bfa_fcs_fabric_delete(struct bfa_fcs_fabric_s *fabric);
-static void     bfa_fcs_fabric_delete_comp(void *cbarg);
-static void     bfa_fcs_fabric_process_uf(struct bfa_fcs_fabric_s *fabric,
-                                         struct fchs_s *fchs, u16 len);
-static void     bfa_fcs_fabric_process_flogi(struct bfa_fcs_fabric_s *fabric,
-                                            struct fchs_s *fchs, u16 len);
-static void     bfa_fcs_fabric_send_flogi_acc(struct bfa_fcs_fabric_s *fabric);
-static void     bfa_fcs_fabric_flogiacc_comp(void *fcsarg,
-                                            struct bfa_fcxp_s *fcxp,
-                                            void *cbarg, bfa_status_t status,
-                                            u32 rsp_len,
-                                            u32 resid_len,
-                                            struct fchs_s *rspfchs);
-/**
- *  fcs_fabric_sm fabric state machine functions
- */
-
-/**
- * Fabric state machine events
- */
-enum bfa_fcs_fabric_event {
-       BFA_FCS_FABRIC_SM_CREATE = 1,   /*  fabric create from driver */
-       BFA_FCS_FABRIC_SM_DELETE = 2,   /*  fabric delete from driver */
-       BFA_FCS_FABRIC_SM_LINK_DOWN = 3,        /*  link down from port */
-       BFA_FCS_FABRIC_SM_LINK_UP = 4,  /*  link up from port */
-       BFA_FCS_FABRIC_SM_CONT_OP = 5,  /*  continue op from flogi/auth */
-       BFA_FCS_FABRIC_SM_RETRY_OP = 6, /*  continue op from flogi/auth */
-       BFA_FCS_FABRIC_SM_NO_FABRIC = 7,        /*  no fabric from flogi/auth
-                                                */
-       BFA_FCS_FABRIC_SM_PERF_EVFP = 8,        /*  perform EVFP from
-                                                *flogi/auth */
-       BFA_FCS_FABRIC_SM_ISOLATE = 9,  /*  isolate from EVFP processing */
-       BFA_FCS_FABRIC_SM_NO_TAGGING = 10,/*  no VFT tagging from EVFP */
-       BFA_FCS_FABRIC_SM_DELAYED = 11, /*  timeout delay event */
-       BFA_FCS_FABRIC_SM_AUTH_FAILED = 12,     /*  authentication failed */
-       BFA_FCS_FABRIC_SM_AUTH_SUCCESS = 13,    /*  authentication successful
-                                                */
-       BFA_FCS_FABRIC_SM_DELCOMP = 14, /*  all vports deleted event */
-       BFA_FCS_FABRIC_SM_LOOPBACK = 15,        /*  Received our own FLOGI */
-       BFA_FCS_FABRIC_SM_START = 16,   /*  fabric delete from driver */
-};
-
-static void     bfa_fcs_fabric_sm_uninit(struct bfa_fcs_fabric_s *fabric,
-                                        enum bfa_fcs_fabric_event event);
-static void     bfa_fcs_fabric_sm_created(struct bfa_fcs_fabric_s *fabric,
-                                         enum bfa_fcs_fabric_event event);
-static void     bfa_fcs_fabric_sm_linkdown(struct bfa_fcs_fabric_s *fabric,
-                                          enum bfa_fcs_fabric_event event);
-static void     bfa_fcs_fabric_sm_flogi(struct bfa_fcs_fabric_s *fabric,
-                                       enum bfa_fcs_fabric_event event);
-static void     bfa_fcs_fabric_sm_flogi_retry(struct bfa_fcs_fabric_s *fabric,
-                                             enum bfa_fcs_fabric_event event);
-static void     bfa_fcs_fabric_sm_auth(struct bfa_fcs_fabric_s *fabric,
-                                      enum bfa_fcs_fabric_event event);
-static void     bfa_fcs_fabric_sm_auth_failed(struct bfa_fcs_fabric_s *fabric,
-                                             enum bfa_fcs_fabric_event event);
-static void     bfa_fcs_fabric_sm_loopback(struct bfa_fcs_fabric_s *fabric,
-                                          enum bfa_fcs_fabric_event event);
-static void     bfa_fcs_fabric_sm_nofabric(struct bfa_fcs_fabric_s *fabric,
-                                          enum bfa_fcs_fabric_event event);
-static void     bfa_fcs_fabric_sm_online(struct bfa_fcs_fabric_s *fabric,
-                                        enum bfa_fcs_fabric_event event);
-static void     bfa_fcs_fabric_sm_evfp(struct bfa_fcs_fabric_s *fabric,
-                                      enum bfa_fcs_fabric_event event);
-static void     bfa_fcs_fabric_sm_evfp_done(struct bfa_fcs_fabric_s *fabric,
-                                           enum bfa_fcs_fabric_event event);
-static void     bfa_fcs_fabric_sm_isolated(struct bfa_fcs_fabric_s *fabric,
-                                          enum bfa_fcs_fabric_event event);
-static void     bfa_fcs_fabric_sm_deleting(struct bfa_fcs_fabric_s *fabric,
-                                          enum bfa_fcs_fabric_event event);
-/**
- *   Beginning state before fabric creation.
- */
-static void
-bfa_fcs_fabric_sm_uninit(struct bfa_fcs_fabric_s *fabric,
-                        enum bfa_fcs_fabric_event event)
-{
-       bfa_trc(fabric->fcs, fabric->bport.port_cfg.pwwn);
-       bfa_trc(fabric->fcs, event);
-
-       switch (event) {
-       case BFA_FCS_FABRIC_SM_CREATE:
-               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_created);
-               bfa_fcs_fabric_init(fabric);
-               bfa_fcs_lport_init(&fabric->bport, &fabric->bport.port_cfg);
-               break;
-
-       case BFA_FCS_FABRIC_SM_LINK_UP:
-       case BFA_FCS_FABRIC_SM_LINK_DOWN:
-               break;
-
-       default:
-               bfa_sm_fault(fabric->fcs, event);
-       }
-}
-
-/**
- *   Beginning state before fabric creation.
- */
-static void
-bfa_fcs_fabric_sm_created(struct bfa_fcs_fabric_s *fabric,
-                         enum bfa_fcs_fabric_event event)
-{
-       bfa_trc(fabric->fcs, fabric->bport.port_cfg.pwwn);
-       bfa_trc(fabric->fcs, event);
-
-       switch (event) {
-       case BFA_FCS_FABRIC_SM_START:
-               if (bfa_fcport_is_linkup(fabric->fcs->bfa)) {
-                       bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_flogi);
-                       bfa_fcs_fabric_login(fabric);
-               } else
-                       bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_linkdown);
-               break;
-
-       case BFA_FCS_FABRIC_SM_LINK_UP:
-       case BFA_FCS_FABRIC_SM_LINK_DOWN:
-               break;
-
-       case BFA_FCS_FABRIC_SM_DELETE:
-               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_uninit);
-               bfa_fcs_modexit_comp(fabric->fcs);
-               break;
-
-       default:
-               bfa_sm_fault(fabric->fcs, event);
-       }
-}
-
-/**
- *   Link is down, awaiting LINK UP event from port. This is also the
- *   first state at fabric creation.
- */
-static void
-bfa_fcs_fabric_sm_linkdown(struct bfa_fcs_fabric_s *fabric,
-                          enum bfa_fcs_fabric_event event)
-{
-       bfa_trc(fabric->fcs, fabric->bport.port_cfg.pwwn);
-       bfa_trc(fabric->fcs, event);
-
-       switch (event) {
-       case BFA_FCS_FABRIC_SM_LINK_UP:
-               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_flogi);
-               bfa_fcs_fabric_login(fabric);
-               break;
-
-       case BFA_FCS_FABRIC_SM_RETRY_OP:
-               break;
-
-       case BFA_FCS_FABRIC_SM_DELETE:
-               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_deleting);
-               bfa_fcs_fabric_delete(fabric);
-               break;
-
-       default:
-               bfa_sm_fault(fabric->fcs, event);
-       }
-}
-
-/**
- *   FLOGI is in progress, awaiting FLOGI reply.
- */
-static void
-bfa_fcs_fabric_sm_flogi(struct bfa_fcs_fabric_s *fabric,
-                       enum bfa_fcs_fabric_event event)
-{
-       bfa_trc(fabric->fcs, fabric->bport.port_cfg.pwwn);
-       bfa_trc(fabric->fcs, event);
-
-       switch (event) {
-       case BFA_FCS_FABRIC_SM_CONT_OP:
-
-               bfa_fcport_set_tx_bbcredit(fabric->fcs->bfa, fabric->bb_credit);
-               fabric->fab_type = BFA_FCS_FABRIC_SWITCHED;
-
-               if (fabric->auth_reqd && fabric->is_auth) {
-                       bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_auth);
-                       bfa_trc(fabric->fcs, event);
-               } else {
-                       bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_online);
-                       bfa_fcs_fabric_notify_online(fabric);
-               }
-               break;
-
-       case BFA_FCS_FABRIC_SM_RETRY_OP:
-               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_flogi_retry);
-               bfa_timer_start(fabric->fcs->bfa, &fabric->delay_timer,
-                               bfa_fcs_fabric_delay, fabric,
-                               BFA_FCS_FABRIC_RETRY_DELAY);
-               break;
-
-       case BFA_FCS_FABRIC_SM_LOOPBACK:
-               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_loopback);
-               bfa_lps_discard(fabric->lps);
-               bfa_fcs_fabric_set_opertype(fabric);
-               break;
-
-       case BFA_FCS_FABRIC_SM_NO_FABRIC:
-               fabric->fab_type = BFA_FCS_FABRIC_N2N;
-               bfa_fcport_set_tx_bbcredit(fabric->fcs->bfa, fabric->bb_credit);
-               bfa_fcs_fabric_notify_online(fabric);
-               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_nofabric);
-               break;
-
-       case BFA_FCS_FABRIC_SM_LINK_DOWN:
-               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_linkdown);
-               bfa_lps_discard(fabric->lps);
-               break;
-
-       case BFA_FCS_FABRIC_SM_DELETE:
-               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_deleting);
-               bfa_lps_discard(fabric->lps);
-               bfa_fcs_fabric_delete(fabric);
-               break;
-
-       default:
-               bfa_sm_fault(fabric->fcs, event);
-       }
-}
-
-
-static void
-bfa_fcs_fabric_sm_flogi_retry(struct bfa_fcs_fabric_s *fabric,
-                             enum bfa_fcs_fabric_event event)
-{
-       bfa_trc(fabric->fcs, fabric->bport.port_cfg.pwwn);
-       bfa_trc(fabric->fcs, event);
-
-       switch (event) {
-       case BFA_FCS_FABRIC_SM_DELAYED:
-               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_flogi);
-               bfa_fcs_fabric_login(fabric);
-               break;
-
-       case BFA_FCS_FABRIC_SM_LINK_DOWN:
-               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_linkdown);
-               bfa_timer_stop(&fabric->delay_timer);
-               break;
-
-       case BFA_FCS_FABRIC_SM_DELETE:
-               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_deleting);
-               bfa_timer_stop(&fabric->delay_timer);
-               bfa_fcs_fabric_delete(fabric);
-               break;
-
-       default:
-               bfa_sm_fault(fabric->fcs, event);
-       }
-}
-
-/**
- *   Authentication is in progress, awaiting authentication results.
- */
-static void
-bfa_fcs_fabric_sm_auth(struct bfa_fcs_fabric_s *fabric,
-                      enum bfa_fcs_fabric_event event)
-{
-       bfa_trc(fabric->fcs, fabric->bport.port_cfg.pwwn);
-       bfa_trc(fabric->fcs, event);
-
-       switch (event) {
-       case BFA_FCS_FABRIC_SM_AUTH_FAILED:
-               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_auth_failed);
-               bfa_lps_discard(fabric->lps);
-               break;
-
-       case BFA_FCS_FABRIC_SM_AUTH_SUCCESS:
-               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_online);
-               bfa_fcs_fabric_notify_online(fabric);
-               break;
-
-       case BFA_FCS_FABRIC_SM_PERF_EVFP:
-               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_evfp);
-               break;
-
-       case BFA_FCS_FABRIC_SM_LINK_DOWN:
-               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_linkdown);
-               bfa_lps_discard(fabric->lps);
-               break;
-
-       case BFA_FCS_FABRIC_SM_DELETE:
-               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_deleting);
-               bfa_fcs_fabric_delete(fabric);
-               break;
-
-       default:
-               bfa_sm_fault(fabric->fcs, event);
-       }
-}
-
-/**
- *   Authentication failed
- */
-static void
-bfa_fcs_fabric_sm_auth_failed(struct bfa_fcs_fabric_s *fabric,
-                             enum bfa_fcs_fabric_event event)
-{
-       bfa_trc(fabric->fcs, fabric->bport.port_cfg.pwwn);
-       bfa_trc(fabric->fcs, event);
-
-       switch (event) {
-       case BFA_FCS_FABRIC_SM_LINK_DOWN:
-               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_linkdown);
-               bfa_fcs_fabric_notify_offline(fabric);
-               break;
-
-       case BFA_FCS_FABRIC_SM_DELETE:
-               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_deleting);
-               bfa_fcs_fabric_delete(fabric);
-               break;
-
-       default:
-               bfa_sm_fault(fabric->fcs, event);
-       }
-}
-
-/**
- *   Port is in loopback mode.
- */
-static void
-bfa_fcs_fabric_sm_loopback(struct bfa_fcs_fabric_s *fabric,
-                          enum bfa_fcs_fabric_event event)
-{
-       bfa_trc(fabric->fcs, fabric->bport.port_cfg.pwwn);
-       bfa_trc(fabric->fcs, event);
-
-       switch (event) {
-       case BFA_FCS_FABRIC_SM_LINK_DOWN:
-               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_linkdown);
-               bfa_fcs_fabric_notify_offline(fabric);
-               break;
-
-       case BFA_FCS_FABRIC_SM_DELETE:
-               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_deleting);
-               bfa_fcs_fabric_delete(fabric);
-               break;
-
-       default:
-               bfa_sm_fault(fabric->fcs, event);
-       }
-}
-
-/**
- *   There is no attached fabric - private loop or NPort-to-NPort topology.
- */
-static void
-bfa_fcs_fabric_sm_nofabric(struct bfa_fcs_fabric_s *fabric,
-                          enum bfa_fcs_fabric_event event)
-{
-       bfa_trc(fabric->fcs, fabric->bport.port_cfg.pwwn);
-       bfa_trc(fabric->fcs, event);
-
-       switch (event) {
-       case BFA_FCS_FABRIC_SM_LINK_DOWN:
-               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_linkdown);
-               bfa_lps_discard(fabric->lps);
-               bfa_fcs_fabric_notify_offline(fabric);
-               break;
-
-       case BFA_FCS_FABRIC_SM_DELETE:
-               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_deleting);
-               bfa_fcs_fabric_delete(fabric);
-               break;
-
-       case BFA_FCS_FABRIC_SM_NO_FABRIC:
-               bfa_trc(fabric->fcs, fabric->bb_credit);
-               bfa_fcport_set_tx_bbcredit(fabric->fcs->bfa, fabric->bb_credit);
-               break;
-
-       default:
-               bfa_sm_fault(fabric->fcs, event);
-       }
-}
-
-/**
- *   Fabric is online - normal operating state.
- */
-static void
-bfa_fcs_fabric_sm_online(struct bfa_fcs_fabric_s *fabric,
-                        enum bfa_fcs_fabric_event event)
-{
-       bfa_trc(fabric->fcs, fabric->bport.port_cfg.pwwn);
-       bfa_trc(fabric->fcs, event);
-
-       switch (event) {
-       case BFA_FCS_FABRIC_SM_LINK_DOWN:
-               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_linkdown);
-               bfa_lps_discard(fabric->lps);
-               bfa_fcs_fabric_notify_offline(fabric);
-               break;
-
-       case BFA_FCS_FABRIC_SM_DELETE:
-               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_deleting);
-               bfa_fcs_fabric_delete(fabric);
-               break;
-
-       case BFA_FCS_FABRIC_SM_AUTH_FAILED:
-               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_auth_failed);
-               bfa_lps_discard(fabric->lps);
-               break;
-
-       case BFA_FCS_FABRIC_SM_AUTH_SUCCESS:
-               break;
-
-       default:
-               bfa_sm_fault(fabric->fcs, event);
-       }
-}
-
-/**
- *   Exchanging virtual fabric parameters.
- */
-static void
-bfa_fcs_fabric_sm_evfp(struct bfa_fcs_fabric_s *fabric,
-                      enum bfa_fcs_fabric_event event)
-{
-       bfa_trc(fabric->fcs, fabric->bport.port_cfg.pwwn);
-       bfa_trc(fabric->fcs, event);
-
-       switch (event) {
-       case BFA_FCS_FABRIC_SM_CONT_OP:
-               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_evfp_done);
-               break;
-
-       case BFA_FCS_FABRIC_SM_ISOLATE:
-               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_isolated);
-               break;
-
-       default:
-               bfa_sm_fault(fabric->fcs, event);
-       }
-}
-
-/**
- *   EVFP exchange complete and VFT tagging is enabled.
- */
-static void
-bfa_fcs_fabric_sm_evfp_done(struct bfa_fcs_fabric_s *fabric,
-                           enum bfa_fcs_fabric_event event)
-{
-       bfa_trc(fabric->fcs, fabric->bport.port_cfg.pwwn);
-       bfa_trc(fabric->fcs, event);
-}
-
-/**
- *   Port is isolated after EVFP exchange due to VF_ID mismatch (N and F).
- */
-static void
-bfa_fcs_fabric_sm_isolated(struct bfa_fcs_fabric_s *fabric,
-                          enum bfa_fcs_fabric_event event)
-{
-       bfa_trc(fabric->fcs, fabric->bport.port_cfg.pwwn);
-       bfa_trc(fabric->fcs, event);
-
-       bfa_log(fabric->fcs->logm, BFA_LOG_FCS_FABRIC_ISOLATED,
-               fabric->bport.port_cfg.pwwn, fabric->fcs->port_vfid,
-               fabric->event_arg.swp_vfid);
-}
-
-/**
- *   Fabric is being deleted, awaiting vport delete completions.
- */
-static void
-bfa_fcs_fabric_sm_deleting(struct bfa_fcs_fabric_s *fabric,
-                          enum bfa_fcs_fabric_event event)
-{
-       bfa_trc(fabric->fcs, fabric->bport.port_cfg.pwwn);
-       bfa_trc(fabric->fcs, event);
-
-       switch (event) {
-       case BFA_FCS_FABRIC_SM_DELCOMP:
-               bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_uninit);
-               bfa_fcs_modexit_comp(fabric->fcs);
-               break;
-
-       case BFA_FCS_FABRIC_SM_LINK_UP:
-               break;
-
-       case BFA_FCS_FABRIC_SM_LINK_DOWN:
-               bfa_fcs_fabric_notify_offline(fabric);
-               break;
-
-       default:
-               bfa_sm_fault(fabric->fcs, event);
-       }
-}
-
-
-
-/**
- *  fcs_fabric_private fabric private functions
- */
-
-static void
-bfa_fcs_fabric_init(struct bfa_fcs_fabric_s *fabric)
-{
-       struct bfa_port_cfg_s *port_cfg = &fabric->bport.port_cfg;
-
-       port_cfg->roles = BFA_PORT_ROLE_FCP_IM;
-       port_cfg->nwwn = bfa_ioc_get_nwwn(&fabric->fcs->bfa->ioc);
-       port_cfg->pwwn = bfa_ioc_get_pwwn(&fabric->fcs->bfa->ioc);
-}
-
-/**
- * Port Symbolic Name Creation for base port.
- */
-void
-bfa_fcs_fabric_psymb_init(struct bfa_fcs_fabric_s *fabric)
-{
-       struct bfa_port_cfg_s *port_cfg = &fabric->bport.port_cfg;
-       char            model[BFA_ADAPTER_MODEL_NAME_LEN] = {0};
-       struct bfa_fcs_driver_info_s *driver_info = &fabric->fcs->driver_info;
-
-       bfa_ioc_get_adapter_model(&fabric->fcs->bfa->ioc, model);
-
-       /*
-        * Model name/number
-        */
-       strncpy((char *)&port_cfg->sym_name, model,
-               BFA_FCS_PORT_SYMBNAME_MODEL_SZ);
-       strncat((char *)&port_cfg->sym_name, BFA_FCS_PORT_SYMBNAME_SEPARATOR,
-               sizeof(BFA_FCS_PORT_SYMBNAME_SEPARATOR));
-
-       /*
-        * Driver Version
-        */
-       strncat((char *)&port_cfg->sym_name, (char *)driver_info->version,
-               BFA_FCS_PORT_SYMBNAME_VERSION_SZ);
-       strncat((char *)&port_cfg->sym_name, BFA_FCS_PORT_SYMBNAME_SEPARATOR,
-               sizeof(BFA_FCS_PORT_SYMBNAME_SEPARATOR));
-
-       /*
-        * Host machine name
-        */
-       strncat((char *)&port_cfg->sym_name,
-               (char *)driver_info->host_machine_name,
-               BFA_FCS_PORT_SYMBNAME_MACHINENAME_SZ);
-       strncat((char *)&port_cfg->sym_name, BFA_FCS_PORT_SYMBNAME_SEPARATOR,
-               sizeof(BFA_FCS_PORT_SYMBNAME_SEPARATOR));
-
-       /*
-        * Host OS Info :
-        * If OS Patch Info is not there, do not truncate any bytes from the
-        * OS name string and instead copy the entire OS info string (64 bytes).
-        */
-       if (driver_info->host_os_patch[0] == '\0') {
-               strncat((char *)&port_cfg->sym_name,
-                       (char *)driver_info->host_os_name, BFA_FCS_OS_STR_LEN);
-               strncat((char *)&port_cfg->sym_name,
-                       BFA_FCS_PORT_SYMBNAME_SEPARATOR,
-                       sizeof(BFA_FCS_PORT_SYMBNAME_SEPARATOR));
-       } else {
-               strncat((char *)&port_cfg->sym_name,
-                       (char *)driver_info->host_os_name,
-                       BFA_FCS_PORT_SYMBNAME_OSINFO_SZ);
-               strncat((char *)&port_cfg->sym_name,
-                       BFA_FCS_PORT_SYMBNAME_SEPARATOR,
-                       sizeof(BFA_FCS_PORT_SYMBNAME_SEPARATOR));
-
-               /*
-                * Append host OS Patch Info
-                */
-               strncat((char *)&port_cfg->sym_name,
-                       (char *)driver_info->host_os_patch,
-                       BFA_FCS_PORT_SYMBNAME_OSPATCH_SZ);
-       }
-
-       /*
-        * null terminate
-        */
-       port_cfg->sym_name.symname[BFA_SYMNAME_MAXLEN - 1] = 0;
-}
-
-/**
- * bfa lps login completion callback
- */
-void
-bfa_cb_lps_flogi_comp(void *bfad, void *uarg, bfa_status_t status)
-{
-       struct bfa_fcs_fabric_s *fabric = uarg;
-
-       bfa_trc(fabric->fcs, fabric->bport.port_cfg.pwwn);
-       bfa_trc(fabric->fcs, status);
-
-       switch (status) {
-       case BFA_STATUS_OK:
-               fabric->stats.flogi_accepts++;
-               break;
-
-       case BFA_STATUS_INVALID_MAC:
-               /*
-                * Only for CNA
-                */
-               fabric->stats.flogi_acc_err++;
-               bfa_sm_send_event(fabric, BFA_FCS_FABRIC_SM_RETRY_OP);
-
-               return;
-
-       case BFA_STATUS_EPROTOCOL:
-               switch (bfa_lps_get_extstatus(fabric->lps)) {
-               case BFA_EPROTO_BAD_ACCEPT:
-                       fabric->stats.flogi_acc_err++;
-                       break;
-
-               case BFA_EPROTO_UNKNOWN_RSP:
-                       fabric->stats.flogi_unknown_rsp++;
-                       break;
-
-               default:
-                       break;
-               }
-               bfa_sm_send_event(fabric, BFA_FCS_FABRIC_SM_RETRY_OP);
-
-               return;
-
-       case BFA_STATUS_FABRIC_RJT:
-               fabric->stats.flogi_rejects++;
-               bfa_sm_send_event(fabric, BFA_FCS_FABRIC_SM_RETRY_OP);
-               return;
-
-       default:
-               fabric->stats.flogi_rsp_err++;
-               bfa_sm_send_event(fabric, BFA_FCS_FABRIC_SM_RETRY_OP);
-               return;
-       }
-
-       fabric->bb_credit = bfa_lps_get_peer_bbcredit(fabric->lps);
-       bfa_trc(fabric->fcs, fabric->bb_credit);
-
-       if (!bfa_lps_is_brcd_fabric(fabric->lps))
-               fabric->fabric_name = bfa_lps_get_peer_nwwn(fabric->lps);
-
-       /*
-        * Check port type. It should be 1 = F-port.
-        */
-       if (bfa_lps_is_fport(fabric->lps)) {
-               fabric->bport.pid = bfa_lps_get_pid(fabric->lps);
-               fabric->is_npiv = bfa_lps_is_npiv_en(fabric->lps);
-               fabric->is_auth = bfa_lps_is_authreq(fabric->lps);
-               bfa_sm_send_event(fabric, BFA_FCS_FABRIC_SM_CONT_OP);
-       } else {
-               /*
-                * Nport-2-Nport direct attached
-                */
-               fabric->bport.port_topo.pn2n.rem_port_wwn =
-                       bfa_lps_get_peer_pwwn(fabric->lps);
-               bfa_sm_send_event(fabric, BFA_FCS_FABRIC_SM_NO_FABRIC);
-       }
-
-       bfa_trc(fabric->fcs, fabric->bport.pid);
-       bfa_trc(fabric->fcs, fabric->is_npiv);
-       bfa_trc(fabric->fcs, fabric->is_auth);
-}
-
-/**
- *             Allocate and send FLOGI.
- */
-static void
-bfa_fcs_fabric_login(struct bfa_fcs_fabric_s *fabric)
-{
-       struct bfa_s   *bfa = fabric->fcs->bfa;
-       struct bfa_port_cfg_s *pcfg = &fabric->bport.port_cfg;
-       u8         alpa = 0;
-
-       if (bfa_fcport_get_topology(bfa) == BFA_PPORT_TOPOLOGY_LOOP)
-               alpa = bfa_fcport_get_myalpa(bfa);
-
-       bfa_lps_flogi(fabric->lps, fabric, alpa, bfa_fcport_get_maxfrsize(bfa),
-                     pcfg->pwwn, pcfg->nwwn, fabric->auth_reqd);
-
-       fabric->stats.flogi_sent++;
-}
-
-static void
-bfa_fcs_fabric_notify_online(struct bfa_fcs_fabric_s *fabric)
-{
-       struct bfa_fcs_vport_s *vport;
-       struct list_head *qe, *qen;
-
-       bfa_trc(fabric->fcs, fabric->fabric_name);
-
-       bfa_fcs_fabric_set_opertype(fabric);
-       fabric->stats.fabric_onlines++;
-
-       /**
-        * notify online event to base and then virtual ports
-        */
-       bfa_fcs_port_online(&fabric->bport);
-
-       list_for_each_safe(qe, qen, &fabric->vport_q) {
-               vport = (struct bfa_fcs_vport_s *)qe;
-               bfa_fcs_vport_online(vport);
-       }
-}
-
-static void
-bfa_fcs_fabric_notify_offline(struct bfa_fcs_fabric_s *fabric)
-{
-       struct bfa_fcs_vport_s *vport;
-       struct list_head *qe, *qen;
-
-       bfa_trc(fabric->fcs, fabric->fabric_name);
-       fabric->stats.fabric_offlines++;
-
-       /**
-        * notify offline event first to vports and then base port.
-        */
-       list_for_each_safe(qe, qen, &fabric->vport_q) {
-               vport = (struct bfa_fcs_vport_s *)qe;
-               bfa_fcs_vport_offline(vport);
-       }
-
-       bfa_fcs_port_offline(&fabric->bport);
-
-       fabric->fabric_name = 0;
-       fabric->fabric_ip_addr[0] = 0;
-}
-
-static void
-bfa_fcs_fabric_delay(void *cbarg)
-{
-       struct bfa_fcs_fabric_s *fabric = cbarg;
-
-       bfa_sm_send_event(fabric, BFA_FCS_FABRIC_SM_DELAYED);
-}
-
-/**
- * Delete all vports and wait for vport delete completions.
- */
-static void
-bfa_fcs_fabric_delete(struct bfa_fcs_fabric_s *fabric)
-{
-       struct bfa_fcs_vport_s *vport;
-       struct list_head *qe, *qen;
-
-       list_for_each_safe(qe, qen, &fabric->vport_q) {
-               vport = (struct bfa_fcs_vport_s *)qe;
-               bfa_fcs_vport_fcs_delete(vport);
-       }
-
-       bfa_fcs_port_delete(&fabric->bport);
-       bfa_wc_wait(&fabric->wc);
-}
-
-static void
-bfa_fcs_fabric_delete_comp(void *cbarg)
-{
-       struct bfa_fcs_fabric_s *fabric = cbarg;
-
-       bfa_sm_send_event(fabric, BFA_FCS_FABRIC_SM_DELCOMP);
-}
-
-
-
-/**
- *  fcs_fabric_public fabric public functions
- */
-
-/**
- *   Attach time initialization
- */
-void
-bfa_fcs_fabric_attach(struct bfa_fcs_s *fcs)
-{
-       struct bfa_fcs_fabric_s *fabric;
-
-       fabric = &fcs->fabric;
-       bfa_os_memset(fabric, 0, sizeof(struct bfa_fcs_fabric_s));
-
-       /**
-        * Initialize base fabric.
-        */
-       fabric->fcs = fcs;
-       INIT_LIST_HEAD(&fabric->vport_q);
-       INIT_LIST_HEAD(&fabric->vf_q);
-       fabric->lps = bfa_lps_alloc(fcs->bfa);
-       bfa_assert(fabric->lps);
-
-       /**
-        * Initialize fabric delete completion handler. Fabric deletion is complete
-        * when the last vport delete is complete.
-        */
-       bfa_wc_init(&fabric->wc, bfa_fcs_fabric_delete_comp, fabric);
-       bfa_wc_up(&fabric->wc); /* For the base port */
-
-       bfa_sm_set_state(fabric, bfa_fcs_fabric_sm_uninit);
-       bfa_fcs_lport_attach(&fabric->bport, fabric->fcs, FC_VF_ID_NULL, NULL);
-}
-
-void
-bfa_fcs_fabric_modinit(struct bfa_fcs_s *fcs)
-{
-       bfa_sm_send_event(&fcs->fabric, BFA_FCS_FABRIC_SM_CREATE);
-       bfa_trc(fcs, 0);
-}
-
-/**
- *   Module cleanup
- */
-void
-bfa_fcs_fabric_modexit(struct bfa_fcs_s *fcs)
-{
-       struct bfa_fcs_fabric_s *fabric;
-
-       bfa_trc(fcs, 0);
-
-       /**
-        * Cleanup base fabric.
-        */
-       fabric = &fcs->fabric;
-       bfa_lps_delete(fabric->lps);
-       bfa_sm_send_event(fabric, BFA_FCS_FABRIC_SM_DELETE);
-}
-
-/**
- * Fabric module start -- kick starts FCS actions
- */
-void
-bfa_fcs_fabric_modstart(struct bfa_fcs_s *fcs)
-{
-       struct bfa_fcs_fabric_s *fabric;
-
-       bfa_trc(fcs, 0);
-       fabric = &fcs->fabric;
-       bfa_sm_send_event(fabric, BFA_FCS_FABRIC_SM_START);
-}
-
-/**
- *   Suspend fabric activity as part of driver suspend.
- */
-void
-bfa_fcs_fabric_modsusp(struct bfa_fcs_s *fcs)
-{
-}
-
-bfa_boolean_t
-bfa_fcs_fabric_is_loopback(struct bfa_fcs_fabric_s *fabric)
-{
-       return bfa_sm_cmp_state(fabric, bfa_fcs_fabric_sm_loopback);
-}
-
-bfa_boolean_t
-bfa_fcs_fabric_is_auth_failed(struct bfa_fcs_fabric_s *fabric)
-{
-       return bfa_sm_cmp_state(fabric, bfa_fcs_fabric_sm_auth_failed);
-}
-
-enum bfa_pport_type
-bfa_fcs_fabric_port_type(struct bfa_fcs_fabric_s *fabric)
-{
-       return fabric->oper_type;
-}
-
-/**
- *   Link up notification from BFA physical port module.
- */
-void
-bfa_fcs_fabric_link_up(struct bfa_fcs_fabric_s *fabric)
-{
-       bfa_trc(fabric->fcs, fabric->bport.port_cfg.pwwn);
-       bfa_sm_send_event(fabric, BFA_FCS_FABRIC_SM_LINK_UP);
-}
-
-/**
- *   Link down notification from BFA physical port module.
- */
-void
-bfa_fcs_fabric_link_down(struct bfa_fcs_fabric_s *fabric)
-{
-       bfa_trc(fabric->fcs, fabric->bport.port_cfg.pwwn);
-       bfa_sm_send_event(fabric, BFA_FCS_FABRIC_SM_LINK_DOWN);
-}
-
-/**
- *   A child vport is being created in the fabric.
- *
- *   Call from vport module at vport creation. A list of base port and vports
- *   belonging to a fabric is maintained to propagate link events.
- *
- *   param[in] fabric - Fabric instance. This can be a base fabric or vf.
- *   param[in] vport  - Vport being created.
- *
- *   @return None (always succeeds)
- */
-void
-bfa_fcs_fabric_addvport(struct bfa_fcs_fabric_s *fabric,
-                       struct bfa_fcs_vport_s *vport)
-{
-       /**
-        * - add vport to fabric's vport_q
-        */
-       bfa_trc(fabric->fcs, fabric->vf_id);
-
-       list_add_tail(&vport->qe, &fabric->vport_q);
-       fabric->num_vports++;
-       bfa_wc_up(&fabric->wc);
-}
-
-/**
- *   A child vport is being deleted from fabric.
- *
- *   Vport is being deleted.
- */
-void
-bfa_fcs_fabric_delvport(struct bfa_fcs_fabric_s *fabric,
-                       struct bfa_fcs_vport_s *vport)
-{
-       list_del(&vport->qe);
-       fabric->num_vports--;
-       bfa_wc_down(&fabric->wc);
-}
-
-/**
- *   Base port is deleted.
- */
-void
-bfa_fcs_fabric_port_delete_comp(struct bfa_fcs_fabric_s *fabric)
-{
-       bfa_wc_down(&fabric->wc);
-}
-
-/**
- *    Check if fabric is online.
- *
- *   param[in] fabric - Fabric instance. This can be a base fabric or vf.
- *
- *   @return  TRUE/FALSE
- */
-int
-bfa_fcs_fabric_is_online(struct bfa_fcs_fabric_s *fabric)
-{
-       return bfa_sm_cmp_state(fabric, bfa_fcs_fabric_sm_online);
-}
-
-
-bfa_status_t
-bfa_fcs_fabric_addvf(struct bfa_fcs_fabric_s *vf, struct bfa_fcs_s *fcs,
-                    struct bfa_port_cfg_s *port_cfg,
-                    struct bfad_vf_s *vf_drv)
-{
-       bfa_sm_set_state(vf, bfa_fcs_fabric_sm_uninit);
-       return BFA_STATUS_OK;
-}
-
-/**
- * Lookup for a vport withing a fabric given its pwwn
- */
-struct bfa_fcs_vport_s *
-bfa_fcs_fabric_vport_lookup(struct bfa_fcs_fabric_s *fabric, wwn_t pwwn)
-{
-       struct bfa_fcs_vport_s *vport;
-       struct list_head *qe;
-
-       list_for_each(qe, &fabric->vport_q) {
-               vport = (struct bfa_fcs_vport_s *)qe;
-               if (bfa_fcs_port_get_pwwn(&vport->lport) == pwwn)
-                       return vport;
-       }
-
-       return NULL;
-}
-
-/**
- *    In a given fabric, return the number of lports.
- *
- *   param[in] fabric - Fabric instance. This can be a base fabric or vf.
- *
-*    @return : 1 or more.
- */
-u16
-bfa_fcs_fabric_vport_count(struct bfa_fcs_fabric_s *fabric)
-{
-       return fabric->num_vports;
-}
-
-/*
- *  Get OUI of the attached switch.
- *
- *  Note : Use of this function should be avoided as much as possible.
- *         This function should be used only if there is any requirement
- *         to check for FOS version below 6.3.
- *         To check if the attached fabric is a brocade fabric, use
- *         bfa_lps_is_brcd_fabric() which works for FOS versions 6.3
- *         or above only.
- */
-
-u16
-bfa_fcs_fabric_get_switch_oui(struct bfa_fcs_fabric_s *fabric)
-{
-       wwn_t fab_nwwn;
-       u8 *tmp;
-       u16 oui;
-
-       fab_nwwn = bfa_lps_get_peer_nwwn(fabric->lps);
-
-       tmp = (uint8_t *)&fab_nwwn;
-       oui = (tmp[3] << 8) | tmp[4];
-
-       return oui;
-}
-
-/**
- *             Unsolicited frame receive handling.
- */
-void
-bfa_fcs_fabric_uf_recv(struct bfa_fcs_fabric_s *fabric, struct fchs_s *fchs,
-                      u16 len)
-{
-       u32        pid = fchs->d_id;
-       struct bfa_fcs_vport_s *vport;
-       struct list_head *qe;
-       struct fc_els_cmd_s   *els_cmd = (struct fc_els_cmd_s *) (fchs + 1);
-       struct fc_logi_s     *flogi = (struct fc_logi_s *) els_cmd;
-
-       bfa_trc(fabric->fcs, len);
-       bfa_trc(fabric->fcs, pid);
-
-       /**
-        * Look for our own FLOGI frames being looped back. This means an
-        * external loopback cable is in place. Our own FLOGI frames are
-        * sometimes looped back when switch port gets temporarily bypassed.
-        */
-       if ((pid == bfa_os_ntoh3b(FC_FABRIC_PORT))
-           && (els_cmd->els_code == FC_ELS_FLOGI)
-           && (flogi->port_name == bfa_fcs_port_get_pwwn(&fabric->bport))) {
-               bfa_sm_send_event(fabric, BFA_FCS_FABRIC_SM_LOOPBACK);
-               return;
-       }
-
-       /**
-        * FLOGI/EVFP exchanges should be consumed by base fabric.
-        */
-       if (fchs->d_id == bfa_os_hton3b(FC_FABRIC_PORT)) {
-               bfa_trc(fabric->fcs, pid);
-               bfa_fcs_fabric_process_uf(fabric, fchs, len);
-               return;
-       }
-
-       if (fabric->bport.pid == pid) {
-               /**
-                * All authentication frames should be routed to auth
-                */
-               bfa_trc(fabric->fcs, els_cmd->els_code);
-               if (els_cmd->els_code == FC_ELS_AUTH) {
-                       bfa_trc(fabric->fcs, els_cmd->els_code);
-                       fabric->auth.response = (u8 *) els_cmd;
-                       return;
-               }
-
-               bfa_trc(fabric->fcs, *(u8 *) ((u8 *) fchs));
-               bfa_fcs_port_uf_recv(&fabric->bport, fchs, len);
-               return;
-       }
-
-       /**
-        * look for a matching local port ID
-        */
-       list_for_each(qe, &fabric->vport_q) {
-               vport = (struct bfa_fcs_vport_s *)qe;
-               if (vport->lport.pid == pid) {
-                       bfa_fcs_port_uf_recv(&vport->lport, fchs, len);
-                       return;
-               }
-       }
-       bfa_trc(fabric->fcs, els_cmd->els_code);
-       bfa_fcs_port_uf_recv(&fabric->bport, fchs, len);
-}
-
-/**
- *             Unsolicited frames to be processed by fabric.
- */
-static void
-bfa_fcs_fabric_process_uf(struct bfa_fcs_fabric_s *fabric, struct fchs_s *fchs,
-                         u16 len)
-{
-       struct fc_els_cmd_s   *els_cmd = (struct fc_els_cmd_s *) (fchs + 1);
-
-       bfa_trc(fabric->fcs, els_cmd->els_code);
-
-       switch (els_cmd->els_code) {
-       case FC_ELS_FLOGI:
-               bfa_fcs_fabric_process_flogi(fabric, fchs, len);
-               break;
-
-       default:
-               /*
-                * need to generate a LS_RJT
-                */
-               break;
-       }
-}
-
-/**
- *     Process incoming FLOGI
- */
-static void
-bfa_fcs_fabric_process_flogi(struct bfa_fcs_fabric_s *fabric,
-                       struct fchs_s *fchs, u16 len)
-{
-       struct fc_logi_s     *flogi = (struct fc_logi_s *) (fchs + 1);
-       struct bfa_fcs_port_s *bport = &fabric->bport;
-
-       bfa_trc(fabric->fcs, fchs->s_id);
-
-       fabric->stats.flogi_rcvd++;
-       /*
-        * Check port type. It should be 0 = n-port.
-        */
-       if (flogi->csp.port_type) {
-               /*
-                * @todo: may need to send a LS_RJT
-                */
-               bfa_trc(fabric->fcs, flogi->port_name);
-               fabric->stats.flogi_rejected++;
-               return;
-       }
-
-       fabric->bb_credit = bfa_os_ntohs(flogi->csp.bbcred);
-       bport->port_topo.pn2n.rem_port_wwn = flogi->port_name;
-       bport->port_topo.pn2n.reply_oxid = fchs->ox_id;
-
-       /*
-        * Send a Flogi Acc
-        */
-       bfa_fcs_fabric_send_flogi_acc(fabric);
-       bfa_sm_send_event(fabric, BFA_FCS_FABRIC_SM_NO_FABRIC);
-}
-
-static void
-bfa_fcs_fabric_send_flogi_acc(struct bfa_fcs_fabric_s *fabric)
-{
-       struct bfa_port_cfg_s *pcfg = &fabric->bport.port_cfg;
-       struct bfa_fcs_port_n2n_s *n2n_port = &fabric->bport.port_topo.pn2n;
-       struct bfa_s   *bfa = fabric->fcs->bfa;
-       struct bfa_fcxp_s *fcxp;
-       u16        reqlen;
-       struct fchs_s          fchs;
-
-       fcxp = bfa_fcs_fcxp_alloc(fabric->fcs);
-       /**
-        * Do not expect this failure -- expect remote node to retry
-        */
-       if (!fcxp)
-               return;
-
-       reqlen = fc_flogi_acc_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
-                                   bfa_os_hton3b(FC_FABRIC_PORT),
-                                   n2n_port->reply_oxid, pcfg->pwwn,
-                                   pcfg->nwwn, bfa_fcport_get_maxfrsize(bfa),
-                                   bfa_fcport_get_rx_bbcredit(bfa));
-
-       bfa_fcxp_send(fcxp, NULL, fabric->vf_id, bfa_lps_get_tag(fabric->lps),
-                       BFA_FALSE, FC_CLASS_3, reqlen, &fchs,
-                       bfa_fcs_fabric_flogiacc_comp, fabric,
-                       FC_MAX_PDUSZ, 0); /* Timeout 0 indicates no
-                                          * response expected
-                                          */
-}
-
-/**
- *   Flogi Acc completion callback.
- */
-static void
-bfa_fcs_fabric_flogiacc_comp(void *fcsarg, struct bfa_fcxp_s *fcxp, void *cbarg,
-                            bfa_status_t status, u32 rsp_len,
-                            u32 resid_len, struct fchs_s *rspfchs)
-{
-       struct bfa_fcs_fabric_s *fabric = cbarg;
-
-       bfa_trc(fabric->fcs, status);
-}
-
-/*
- *
- * @param[in] fabric - fabric
- * @param[in] result - 1
- *
- * @return - none
- */
-void
-bfa_fcs_auth_finished(struct bfa_fcs_fabric_s *fabric, enum auth_status status)
-{
-       bfa_trc(fabric->fcs, status);
-
-       if (status == FC_AUTH_STATE_SUCCESS)
-               bfa_sm_send_event(fabric, BFA_FCS_FABRIC_SM_AUTH_SUCCESS);
-       else
-               bfa_sm_send_event(fabric, BFA_FCS_FABRIC_SM_AUTH_FAILED);
-}
-
-/**
- * Send AEN notification
- */
-static void
-bfa_fcs_fabric_aen_post(struct bfa_fcs_port_s *port,
-                       enum bfa_port_aen_event event)
-{
-       union bfa_aen_data_u aen_data;
-       struct bfa_log_mod_s *logmod = port->fcs->logm;
-       wwn_t           pwwn = bfa_fcs_port_get_pwwn(port);
-       wwn_t           fwwn = bfa_fcs_port_get_fabric_name(port);
-       char            pwwn_ptr[BFA_STRING_32];
-       char            fwwn_ptr[BFA_STRING_32];
-
-       wwn2str(pwwn_ptr, pwwn);
-       wwn2str(fwwn_ptr, fwwn);
-
-       bfa_log(logmod, BFA_LOG_CREATE_ID(BFA_AEN_CAT_PORT, event),
-               pwwn_ptr, fwwn_ptr);
-
-       aen_data.port.pwwn = pwwn;
-       aen_data.port.fwwn = fwwn;
-}
-
-/*
- *
- * @param[in] fabric - fabric
- * @param[in] wwn_t - new fabric name
- *
- * @return - none
- */
-void
-bfa_fcs_fabric_set_fabric_name(struct bfa_fcs_fabric_s *fabric,
-                              wwn_t fabric_name)
-{
-       bfa_trc(fabric->fcs, fabric_name);
-
-       if (fabric->fabric_name == 0) {
-               /*
-                * With BRCD switches, we don't get Fabric Name in FLOGI.
-                * Don't generate a fabric name change event in this case.
-                */
-               fabric->fabric_name = fabric_name;
-       } else {
-               fabric->fabric_name = fabric_name;
-               /*
-                * Generate a Event
-                */
-               bfa_fcs_fabric_aen_post(&fabric->bport,
-                                       BFA_PORT_AEN_FABRIC_NAME_CHANGE);
-       }
-
-}
-
-/**
- *
- * @param[in] fabric - fabric
- * @param[in] node_symname -
- *              Caller allocated buffer to receive the symbolic name
- *
- * @return - none
- */
-void
-bfa_fcs_get_sym_name(const struct bfa_fcs_s *fcs, char *node_symname)
-{
-       bfa_os_memcpy(node_symname,
-                       fcs->fabric.bport.port_cfg.sym_name.symname,
-                       BFA_SYMNAME_MAXLEN);
-}
-
-/**
- * Not used by FCS.
- */
-void
-bfa_cb_lps_flogo_comp(void *bfad, void *uarg)
-{
-}
-
-
diff --git a/drivers/scsi/bfa/fcbuild.c b/drivers/scsi/bfa/fcbuild.c
deleted file mode 100644 (file)
index fee5456..0000000
+++ /dev/null
@@ -1,1449 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-/*
- * fcbuild.c - FC link service frame building and parsing routines
- */
-
-#include <bfa_os_inc.h>
-#include "fcbuild.h"
-
-/*
- * static build functions
- */
-static void fc_els_rsp_build(struct fchs_s *fchs, u32 d_id, u32 s_id,
-                       u16 ox_id);
-static void fc_bls_rsp_build(struct fchs_s *fchs, u32 d_id, u32 s_id,
-                       u16 ox_id);
-static struct fchs_s   fc_els_req_tmpl;
-static struct fchs_s   fc_els_rsp_tmpl;
-static struct fchs_s   fc_bls_req_tmpl;
-static struct fchs_s   fc_bls_rsp_tmpl;
-static struct fc_ba_acc_s ba_acc_tmpl;
-static struct fc_logi_s plogi_tmpl;
-static struct fc_prli_s prli_tmpl;
-static struct fc_rrq_s rrq_tmpl;
-static struct fchs_s   fcp_fchs_tmpl;
-
-void
-fcbuild_init(void)
-{
-       /*
-        * fc_els_req_tmpl
-        */
-       fc_els_req_tmpl.routing = FC_RTG_EXT_LINK;
-       fc_els_req_tmpl.cat_info = FC_CAT_LD_REQUEST;
-       fc_els_req_tmpl.type = FC_TYPE_ELS;
-       fc_els_req_tmpl.f_ctl =
-               bfa_os_hton3b(FCTL_SEQ_INI | FCTL_FS_EXCH | FCTL_END_SEQ |
-                             FCTL_SI_XFER);
-       fc_els_req_tmpl.rx_id = FC_RXID_ANY;
-
-       /*
-        * fc_els_rsp_tmpl
-        */
-       fc_els_rsp_tmpl.routing = FC_RTG_EXT_LINK;
-       fc_els_rsp_tmpl.cat_info = FC_CAT_LD_REPLY;
-       fc_els_rsp_tmpl.type = FC_TYPE_ELS;
-       fc_els_rsp_tmpl.f_ctl =
-               bfa_os_hton3b(FCTL_EC_RESP | FCTL_SEQ_INI | FCTL_LS_EXCH |
-                             FCTL_END_SEQ | FCTL_SI_XFER);
-       fc_els_rsp_tmpl.rx_id = FC_RXID_ANY;
-
-       /*
-        * fc_bls_req_tmpl
-        */
-       fc_bls_req_tmpl.routing = FC_RTG_BASIC_LINK;
-       fc_bls_req_tmpl.type = FC_TYPE_BLS;
-       fc_bls_req_tmpl.f_ctl = bfa_os_hton3b(FCTL_END_SEQ | FCTL_SI_XFER);
-       fc_bls_req_tmpl.rx_id = FC_RXID_ANY;
-
-       /*
-        * fc_bls_rsp_tmpl
-        */
-       fc_bls_rsp_tmpl.routing = FC_RTG_BASIC_LINK;
-       fc_bls_rsp_tmpl.cat_info = FC_CAT_BA_ACC;
-       fc_bls_rsp_tmpl.type = FC_TYPE_BLS;
-       fc_bls_rsp_tmpl.f_ctl =
-               bfa_os_hton3b(FCTL_EC_RESP | FCTL_SEQ_INI | FCTL_LS_EXCH |
-                             FCTL_END_SEQ | FCTL_SI_XFER);
-       fc_bls_rsp_tmpl.rx_id = FC_RXID_ANY;
-
-       /*
-        * ba_acc_tmpl
-        */
-       ba_acc_tmpl.seq_id_valid = 0;
-       ba_acc_tmpl.low_seq_cnt = 0;
-       ba_acc_tmpl.high_seq_cnt = 0xFFFF;
-
-       /*
-        * plogi_tmpl
-        */
-       plogi_tmpl.csp.verhi = FC_PH_VER_PH_3;
-       plogi_tmpl.csp.verlo = FC_PH_VER_4_3;
-       plogi_tmpl.csp.bbcred = bfa_os_htons(0x0004);
-       plogi_tmpl.csp.ciro = 0x1;
-       plogi_tmpl.csp.cisc = 0x0;
-       plogi_tmpl.csp.altbbcred = 0x0;
-       plogi_tmpl.csp.conseq = bfa_os_htons(0x00FF);
-       plogi_tmpl.csp.ro_bitmap = bfa_os_htons(0x0002);
-       plogi_tmpl.csp.e_d_tov = bfa_os_htonl(2000);
-
-       plogi_tmpl.class3.class_valid = 1;
-       plogi_tmpl.class3.sequential = 1;
-       plogi_tmpl.class3.conseq = 0xFF;
-       plogi_tmpl.class3.ospx = 1;
-
-       /*
-        * prli_tmpl
-        */
-       prli_tmpl.command = FC_ELS_PRLI;
-       prli_tmpl.pglen = 0x10;
-       prli_tmpl.pagebytes = bfa_os_htons(0x0014);
-       prli_tmpl.parampage.type = FC_TYPE_FCP;
-       prli_tmpl.parampage.imagepair = 1;
-       prli_tmpl.parampage.servparams.rxrdisab = 1;
-
-       /*
-        * rrq_tmpl
-        */
-       rrq_tmpl.els_cmd.els_code = FC_ELS_RRQ;
-
-       /*
-        * fcp_fchs_tmpl
-        */
-       fcp_fchs_tmpl.routing = FC_RTG_FC4_DEV_DATA;
-       fcp_fchs_tmpl.cat_info = FC_CAT_UNSOLICIT_CMD;
-       fcp_fchs_tmpl.type = FC_TYPE_FCP;
-       fcp_fchs_tmpl.f_ctl =
-               bfa_os_hton3b(FCTL_FS_EXCH | FCTL_END_SEQ | FCTL_SI_XFER);
-       fcp_fchs_tmpl.seq_id = 1;
-       fcp_fchs_tmpl.rx_id = FC_RXID_ANY;
-}
-
-static void
-fc_gs_fchdr_build(struct fchs_s *fchs, u32 d_id, u32 s_id,
-                       u32 ox_id)
-{
-       bfa_os_memset(fchs, 0, sizeof(struct fchs_s));
-
-       fchs->routing = FC_RTG_FC4_DEV_DATA;
-       fchs->cat_info = FC_CAT_UNSOLICIT_CTRL;
-       fchs->type = FC_TYPE_SERVICES;
-       fchs->f_ctl =
-               bfa_os_hton3b(FCTL_SEQ_INI | FCTL_FS_EXCH | FCTL_END_SEQ |
-                             FCTL_SI_XFER);
-       fchs->rx_id = FC_RXID_ANY;
-       fchs->d_id = (d_id);
-       fchs->s_id = (s_id);
-       fchs->ox_id = bfa_os_htons(ox_id);
-
-       /**
-        * @todo no need to set ox_id for request
-        *       no need to set rx_id for response
-        */
-}
-
-void
-fc_els_req_build(struct fchs_s *fchs, u32 d_id, u32 s_id,
-                       u16 ox_id)
-{
-       bfa_os_memcpy(fchs, &fc_els_req_tmpl, sizeof(struct fchs_s));
-       fchs->d_id = (d_id);
-       fchs->s_id = (s_id);
-       fchs->ox_id = bfa_os_htons(ox_id);
-}
-
-static void
-fc_els_rsp_build(struct fchs_s *fchs, u32 d_id, u32 s_id,
-                       u16 ox_id)
-{
-       bfa_os_memcpy(fchs, &fc_els_rsp_tmpl, sizeof(struct fchs_s));
-       fchs->d_id = d_id;
-       fchs->s_id = s_id;
-       fchs->ox_id = ox_id;
-}
-
-enum fc_parse_status
-fc_els_rsp_parse(struct fchs_s *fchs, int len)
-{
-       struct fc_els_cmd_s   *els_cmd = (struct fc_els_cmd_s *) (fchs + 1);
-       struct fc_ls_rjt_s    *ls_rjt = (struct fc_ls_rjt_s *) els_cmd;
-
-       len = len;
-
-       switch (els_cmd->els_code) {
-       case FC_ELS_LS_RJT:
-               if (ls_rjt->reason_code == FC_LS_RJT_RSN_LOGICAL_BUSY)
-                       return FC_PARSE_BUSY;
-               else
-                       return FC_PARSE_FAILURE;
-
-       case FC_ELS_ACC:
-               return FC_PARSE_OK;
-       }
-       return FC_PARSE_OK;
-}
-
-static void
-fc_bls_rsp_build(struct fchs_s *fchs, u32 d_id, u32 s_id,
-                       u16 ox_id)
-{
-       bfa_os_memcpy(fchs, &fc_bls_rsp_tmpl, sizeof(struct fchs_s));
-       fchs->d_id = d_id;
-       fchs->s_id = s_id;
-       fchs->ox_id = ox_id;
-}
-
-static          u16
-fc_plogi_x_build(struct fchs_s *fchs, void *pld, u32 d_id, u32 s_id,
-                u16 ox_id, wwn_t port_name, wwn_t node_name,
-                u16 pdu_size, u8 els_code)
-{
-       struct fc_logi_s     *plogi = (struct fc_logi_s *) (pld);
-
-       bfa_os_memcpy(plogi, &plogi_tmpl, sizeof(struct fc_logi_s));
-
-       plogi->els_cmd.els_code = els_code;
-       if (els_code == FC_ELS_PLOGI)
-               fc_els_req_build(fchs, d_id, s_id, ox_id);
-       else
-               fc_els_rsp_build(fchs, d_id, s_id, ox_id);
-
-       plogi->csp.rxsz = plogi->class3.rxsz = bfa_os_htons(pdu_size);
-
-       bfa_os_memcpy(&plogi->port_name, &port_name, sizeof(wwn_t));
-       bfa_os_memcpy(&plogi->node_name, &node_name, sizeof(wwn_t));
-
-       return sizeof(struct fc_logi_s);
-}
-
-u16
-fc_flogi_build(struct fchs_s *fchs, struct fc_logi_s *flogi, u32 s_id,
-               u16 ox_id, wwn_t port_name, wwn_t node_name,
-               u16 pdu_size, u8 set_npiv, u8 set_auth,
-               u16 local_bb_credits)
-{
-       u32        d_id = bfa_os_hton3b(FC_FABRIC_PORT);
-       u32     *vvl_info;
-
-       bfa_os_memcpy(flogi, &plogi_tmpl, sizeof(struct fc_logi_s));
-
-       flogi->els_cmd.els_code = FC_ELS_FLOGI;
-       fc_els_req_build(fchs, d_id, s_id, ox_id);
-
-       flogi->csp.rxsz = flogi->class3.rxsz = bfa_os_htons(pdu_size);
-       flogi->port_name = port_name;
-       flogi->node_name = node_name;
-
-       /*
-        * Set the NPIV Capability Bit ( word 1, bit 31) of Common
-        * Service Parameters.
-        */
-       flogi->csp.ciro = set_npiv;
-
-       /* set AUTH capability */
-       flogi->csp.security = set_auth;
-
-       flogi->csp.bbcred = bfa_os_htons(local_bb_credits);
-
-       /* Set brcd token in VVL */
-       vvl_info = (u32 *)&flogi->vvl[0];
-
-       /* set the flag to indicate the presence of VVL */
-       flogi->csp.npiv_supp    = 1; /* @todo. field name is not correct */
-       vvl_info[0]     = bfa_os_htonl(FLOGI_VVL_BRCD);
-
-       return sizeof(struct fc_logi_s);
-}
-
-u16
-fc_flogi_acc_build(struct fchs_s *fchs, struct fc_logi_s *flogi, u32 s_id,
-                  u16 ox_id, wwn_t port_name, wwn_t node_name,
-                  u16 pdu_size, u16 local_bb_credits)
-{
-       u32        d_id = 0;
-
-       bfa_os_memcpy(flogi, &plogi_tmpl, sizeof(struct fc_logi_s));
-       fc_els_rsp_build(fchs, d_id, s_id, ox_id);
-
-       flogi->els_cmd.els_code = FC_ELS_ACC;
-       flogi->csp.rxsz = flogi->class3.rxsz = bfa_os_htons(pdu_size);
-       flogi->port_name = port_name;
-       flogi->node_name = node_name;
-
-       flogi->csp.bbcred = bfa_os_htons(local_bb_credits);
-
-       return sizeof(struct fc_logi_s);
-}
-
-u16
-fc_fdisc_build(struct fchs_s *fchs, struct fc_logi_s *flogi, u32 s_id,
-               u16 ox_id, wwn_t port_name, wwn_t node_name,
-               u16 pdu_size)
-{
-       u32        d_id = bfa_os_hton3b(FC_FABRIC_PORT);
-
-       bfa_os_memcpy(flogi, &plogi_tmpl, sizeof(struct fc_logi_s));
-
-       flogi->els_cmd.els_code = FC_ELS_FDISC;
-       fc_els_req_build(fchs, d_id, s_id, ox_id);
-
-       flogi->csp.rxsz = flogi->class3.rxsz = bfa_os_htons(pdu_size);
-       flogi->port_name = port_name;
-       flogi->node_name = node_name;
-
-       return sizeof(struct fc_logi_s);
-}
-
-u16
-fc_plogi_build(struct fchs_s *fchs, void *pld, u32 d_id, u32 s_id,
-              u16 ox_id, wwn_t port_name, wwn_t node_name,
-              u16 pdu_size)
-{
-       return fc_plogi_x_build(fchs, pld, d_id, s_id, ox_id, port_name,
-                               node_name, pdu_size, FC_ELS_PLOGI);
-}
-
-u16
-fc_plogi_acc_build(struct fchs_s *fchs, void *pld, u32 d_id, u32 s_id,
-                  u16 ox_id, wwn_t port_name, wwn_t node_name,
-                  u16 pdu_size)
-{
-       return fc_plogi_x_build(fchs, pld, d_id, s_id, ox_id, port_name,
-                               node_name, pdu_size, FC_ELS_ACC);
-}
-
-enum fc_parse_status
-fc_plogi_rsp_parse(struct fchs_s *fchs, int len, wwn_t port_name)
-{
-       struct fc_els_cmd_s   *els_cmd = (struct fc_els_cmd_s *) (fchs + 1);
-       struct fc_logi_s     *plogi;
-       struct fc_ls_rjt_s    *ls_rjt;
-
-       switch (els_cmd->els_code) {
-       case FC_ELS_LS_RJT:
-               ls_rjt = (struct fc_ls_rjt_s *) (fchs + 1);
-               if (ls_rjt->reason_code == FC_LS_RJT_RSN_LOGICAL_BUSY)
-                       return FC_PARSE_BUSY;
-               else
-                       return FC_PARSE_FAILURE;
-       case FC_ELS_ACC:
-               plogi = (struct fc_logi_s *) (fchs + 1);
-               if (len < sizeof(struct fc_logi_s))
-                       return FC_PARSE_FAILURE;
-
-               if (!wwn_is_equal(plogi->port_name, port_name))
-                       return FC_PARSE_FAILURE;
-
-               if (!plogi->class3.class_valid)
-                       return FC_PARSE_FAILURE;
-
-               if (bfa_os_ntohs(plogi->class3.rxsz) < (FC_MIN_PDUSZ))
-                       return FC_PARSE_FAILURE;
-
-               return FC_PARSE_OK;
-       default:
-               return FC_PARSE_FAILURE;
-       }
-}
-
-enum fc_parse_status
-fc_plogi_parse(struct fchs_s *fchs)
-{
-       struct fc_logi_s     *plogi = (struct fc_logi_s *) (fchs + 1);
-
-       if (plogi->class3.class_valid != 1)
-               return FC_PARSE_FAILURE;
-
-       if ((bfa_os_ntohs(plogi->class3.rxsz) < FC_MIN_PDUSZ)
-           || (bfa_os_ntohs(plogi->class3.rxsz) > FC_MAX_PDUSZ)
-           || (plogi->class3.rxsz == 0))
-               return FC_PARSE_FAILURE;
-
-       return FC_PARSE_OK;
-}
-
-u16
-fc_prli_build(struct fchs_s *fchs, void *pld, u32 d_id, u32 s_id,
-             u16 ox_id)
-{
-       struct fc_prli_s      *prli = (struct fc_prli_s *) (pld);
-
-       fc_els_req_build(fchs, d_id, s_id, ox_id);
-       bfa_os_memcpy(prli, &prli_tmpl, sizeof(struct fc_prli_s));
-
-       prli->command = FC_ELS_PRLI;
-       prli->parampage.servparams.initiator     = 1;
-       prli->parampage.servparams.retry         = 1;
-       prli->parampage.servparams.rec_support   = 1;
-       prli->parampage.servparams.task_retry_id = 0;
-       prli->parampage.servparams.confirm       = 1;
-
-       return sizeof(struct fc_prli_s);
-}
-
-u16
-fc_prli_acc_build(struct fchs_s *fchs, void *pld, u32 d_id, u32 s_id,
-                 u16 ox_id, enum bfa_port_role role)
-{
-       struct fc_prli_s      *prli = (struct fc_prli_s *) (pld);
-
-       fc_els_rsp_build(fchs, d_id, s_id, ox_id);
-       bfa_os_memcpy(prli, &prli_tmpl, sizeof(struct fc_prli_s));
-
-       prli->command = FC_ELS_ACC;
-
-       if ((role & BFA_PORT_ROLE_FCP_TM) == BFA_PORT_ROLE_FCP_TM)
-               prli->parampage.servparams.target = 1;
-       else
-               prli->parampage.servparams.initiator = 1;
-
-       prli->parampage.rspcode = FC_PRLI_ACC_XQTD;
-
-       return sizeof(struct fc_prli_s);
-}
-
-enum fc_parse_status
-fc_prli_rsp_parse(struct fc_prli_s *prli, int len)
-{
-       if (len < sizeof(struct fc_prli_s))
-               return FC_PARSE_FAILURE;
-
-       if (prli->command != FC_ELS_ACC)
-               return FC_PARSE_FAILURE;
-
-       if ((prli->parampage.rspcode != FC_PRLI_ACC_XQTD)
-           && (prli->parampage.rspcode != FC_PRLI_ACC_PREDEF_IMG))
-               return FC_PARSE_FAILURE;
-
-       if (prli->parampage.servparams.target != 1)
-               return FC_PARSE_FAILURE;
-
-       return FC_PARSE_OK;
-}
-
-enum fc_parse_status
-fc_prli_parse(struct fc_prli_s *prli)
-{
-       if (prli->parampage.type != FC_TYPE_FCP)
-               return FC_PARSE_FAILURE;
-
-       if (!prli->parampage.imagepair)
-               return FC_PARSE_FAILURE;
-
-       if (!prli->parampage.servparams.initiator)
-               return FC_PARSE_FAILURE;
-
-       return FC_PARSE_OK;
-}
-
-u16
-fc_logo_build(struct fchs_s *fchs, struct fc_logo_s *logo, u32 d_id,
-                       u32 s_id, u16 ox_id, wwn_t port_name)
-{
-       fc_els_req_build(fchs, d_id, s_id, ox_id);
-
-       memset(logo, '\0', sizeof(struct fc_logo_s));
-       logo->els_cmd.els_code = FC_ELS_LOGO;
-       logo->nport_id = (s_id);
-       logo->orig_port_name = port_name;
-
-       return sizeof(struct fc_logo_s);
-}
-
-static          u16
-fc_adisc_x_build(struct fchs_s *fchs, struct fc_adisc_s *adisc, u32 d_id,
-                u32 s_id, u16 ox_id, wwn_t port_name,
-                wwn_t node_name, u8 els_code)
-{
-       memset(adisc, '\0', sizeof(struct fc_adisc_s));
-
-       adisc->els_cmd.els_code = els_code;
-
-       if (els_code == FC_ELS_ADISC)
-               fc_els_req_build(fchs, d_id, s_id, ox_id);
-       else
-               fc_els_rsp_build(fchs, d_id, s_id, ox_id);
-
-       adisc->orig_HA = 0;
-       adisc->orig_port_name = port_name;
-       adisc->orig_node_name = node_name;
-       adisc->nport_id = (s_id);
-
-       return sizeof(struct fc_adisc_s);
-}
-
-u16
-fc_adisc_build(struct fchs_s *fchs, struct fc_adisc_s *adisc, u32 d_id,
-               u32 s_id, u16 ox_id, wwn_t port_name,
-               wwn_t node_name)
-{
-       return fc_adisc_x_build(fchs, adisc, d_id, s_id, ox_id, port_name,
-                               node_name, FC_ELS_ADISC);
-}
-
-u16
-fc_adisc_acc_build(struct fchs_s *fchs, struct fc_adisc_s *adisc, u32 d_id,
-                  u32 s_id, u16 ox_id, wwn_t port_name,
-                  wwn_t node_name)
-{
-       return fc_adisc_x_build(fchs, adisc, d_id, s_id, ox_id, port_name,
-                               node_name, FC_ELS_ACC);
-}
-
-enum fc_parse_status
-fc_adisc_rsp_parse(struct fc_adisc_s *adisc, int len, wwn_t port_name,
-                                wwn_t node_name)
-{
-
-       if (len < sizeof(struct fc_adisc_s))
-               return FC_PARSE_FAILURE;
-
-       if (adisc->els_cmd.els_code != FC_ELS_ACC)
-               return FC_PARSE_FAILURE;
-
-       if (!wwn_is_equal(adisc->orig_port_name, port_name))
-               return FC_PARSE_FAILURE;
-
-       return FC_PARSE_OK;
-}
-
-enum fc_parse_status
-fc_adisc_parse(struct fchs_s *fchs, void *pld, u32 host_dap,
-                wwn_t node_name, wwn_t port_name)
-{
-       struct fc_adisc_s     *adisc = (struct fc_adisc_s *) pld;
-
-       if (adisc->els_cmd.els_code != FC_ELS_ACC)
-               return FC_PARSE_FAILURE;
-
-       if ((adisc->nport_id == (host_dap))
-           && wwn_is_equal(adisc->orig_port_name, port_name)
-           && wwn_is_equal(adisc->orig_node_name, node_name))
-               return FC_PARSE_OK;
-
-       return FC_PARSE_FAILURE;
-}
-
-enum fc_parse_status
-fc_pdisc_parse(struct fchs_s *fchs, wwn_t node_name, wwn_t port_name)
-{
-       struct fc_logi_s     *pdisc = (struct fc_logi_s *) (fchs + 1);
-
-       if (pdisc->class3.class_valid != 1)
-               return FC_PARSE_FAILURE;
-
-       if ((bfa_os_ntohs(pdisc->class3.rxsz) <
-                (FC_MIN_PDUSZ - sizeof(struct fchs_s)))
-           || (pdisc->class3.rxsz == 0))
-               return FC_PARSE_FAILURE;
-
-       if (!wwn_is_equal(pdisc->port_name, port_name))
-               return FC_PARSE_FAILURE;
-
-       if (!wwn_is_equal(pdisc->node_name, node_name))
-               return FC_PARSE_FAILURE;
-
-       return FC_PARSE_OK;
-}
-
-u16
-fc_abts_build(struct fchs_s *fchs, u32 d_id, u32 s_id, u16 ox_id)
-{
-       bfa_os_memcpy(fchs, &fc_bls_req_tmpl, sizeof(struct fchs_s));
-       fchs->cat_info = FC_CAT_ABTS;
-       fchs->d_id = (d_id);
-       fchs->s_id = (s_id);
-       fchs->ox_id = bfa_os_htons(ox_id);
-
-       return sizeof(struct fchs_s);
-}
-
-enum fc_parse_status
-fc_abts_rsp_parse(struct fchs_s *fchs, int len)
-{
-       if ((fchs->cat_info == FC_CAT_BA_ACC)
-           || (fchs->cat_info == FC_CAT_BA_RJT))
-               return FC_PARSE_OK;
-
-       return FC_PARSE_FAILURE;
-}
-
-u16
-fc_rrq_build(struct fchs_s *fchs, struct fc_rrq_s *rrq, u32 d_id,
-                        u32 s_id, u16 ox_id, u16 rrq_oxid)
-{
-       fc_els_req_build(fchs, d_id, s_id, ox_id);
-
-       /*
-        * build rrq payload
-        */
-       bfa_os_memcpy(rrq, &rrq_tmpl, sizeof(struct fc_rrq_s));
-       rrq->s_id = (s_id);
-       rrq->ox_id = bfa_os_htons(rrq_oxid);
-       rrq->rx_id = FC_RXID_ANY;
-
-       return sizeof(struct fc_rrq_s);
-}
-
-u16
-fc_logo_acc_build(struct fchs_s *fchs, void *pld, u32 d_id, u32 s_id,
-                 u16 ox_id)
-{
-       struct fc_els_cmd_s   *acc = pld;
-
-       fc_els_rsp_build(fchs, d_id, s_id, ox_id);
-
-       memset(acc, 0, sizeof(struct fc_els_cmd_s));
-       acc->els_code = FC_ELS_ACC;
-
-       return sizeof(struct fc_els_cmd_s);
-}
-
-u16
-fc_ls_rjt_build(struct fchs_s *fchs, struct fc_ls_rjt_s *ls_rjt, u32 d_id,
-               u32 s_id, u16 ox_id, u8 reason_code,
-               u8 reason_code_expl)
-{
-       fc_els_rsp_build(fchs, d_id, s_id, ox_id);
-       memset(ls_rjt, 0, sizeof(struct fc_ls_rjt_s));
-
-       ls_rjt->els_cmd.els_code = FC_ELS_LS_RJT;
-       ls_rjt->reason_code = reason_code;
-       ls_rjt->reason_code_expl = reason_code_expl;
-       ls_rjt->vendor_unique = 0x00;
-
-       return sizeof(struct fc_ls_rjt_s);
-}
-
-u16
-fc_ba_acc_build(struct fchs_s *fchs, struct fc_ba_acc_s *ba_acc, u32 d_id,
-               u32 s_id, u16 ox_id, u16 rx_id)
-{
-       fc_bls_rsp_build(fchs, d_id, s_id, ox_id);
-
-       bfa_os_memcpy(ba_acc, &ba_acc_tmpl, sizeof(struct fc_ba_acc_s));
-
-       fchs->rx_id = rx_id;
-
-       ba_acc->ox_id = fchs->ox_id;
-       ba_acc->rx_id = fchs->rx_id;
-
-       return sizeof(struct fc_ba_acc_s);
-}
-
-u16
-fc_ls_acc_build(struct fchs_s *fchs, struct fc_els_cmd_s *els_cmd,
-                       u32 d_id, u32 s_id, u16 ox_id)
-{
-       fc_els_rsp_build(fchs, d_id, s_id, ox_id);
-       memset(els_cmd, 0, sizeof(struct fc_els_cmd_s));
-       els_cmd->els_code = FC_ELS_ACC;
-
-       return sizeof(struct fc_els_cmd_s);
-}
-
-int
-fc_logout_params_pages(struct fchs_s *fc_frame, u8 els_code)
-{
-       int             num_pages = 0;
-       struct fc_prlo_s      *prlo;
-       struct fc_tprlo_s     *tprlo;
-
-       if (els_code == FC_ELS_PRLO) {
-               prlo = (struct fc_prlo_s *) (fc_frame + 1);
-               num_pages = (bfa_os_ntohs(prlo->payload_len) - 4) / 16;
-       } else {
-               tprlo = (struct fc_tprlo_s *) (fc_frame + 1);
-               num_pages = (bfa_os_ntohs(tprlo->payload_len) - 4) / 16;
-       }
-       return num_pages;
-}
-
-u16
-fc_tprlo_acc_build(struct fchs_s *fchs, struct fc_tprlo_acc_s *tprlo_acc,
-                       u32 d_id, u32 s_id, u16 ox_id,
-                       int num_pages)
-{
-       int             page;
-
-       fc_els_rsp_build(fchs, d_id, s_id, ox_id);
-
-       memset(tprlo_acc, 0, (num_pages * 16) + 4);
-       tprlo_acc->command = FC_ELS_ACC;
-
-       tprlo_acc->page_len = 0x10;
-       tprlo_acc->payload_len = bfa_os_htons((num_pages * 16) + 4);
-
-       for (page = 0; page < num_pages; page++) {
-               tprlo_acc->tprlo_acc_params[page].opa_valid = 0;
-               tprlo_acc->tprlo_acc_params[page].rpa_valid = 0;
-               tprlo_acc->tprlo_acc_params[page].fc4type_csp = FC_TYPE_FCP;
-               tprlo_acc->tprlo_acc_params[page].orig_process_assc = 0;
-               tprlo_acc->tprlo_acc_params[page].resp_process_assc = 0;
-       }
-       return bfa_os_ntohs(tprlo_acc->payload_len);
-}
-
-u16
-fc_prlo_acc_build(struct fchs_s *fchs, struct fc_prlo_acc_s *prlo_acc,
-                       u32 d_id, u32 s_id, u16 ox_id,
-                       int num_pages)
-{
-       int             page;
-
-       fc_els_rsp_build(fchs, d_id, s_id, ox_id);
-
-       memset(prlo_acc, 0, (num_pages * 16) + 4);
-       prlo_acc->command = FC_ELS_ACC;
-       prlo_acc->page_len = 0x10;
-       prlo_acc->payload_len = bfa_os_htons((num_pages * 16) + 4);
-
-       for (page = 0; page < num_pages; page++) {
-               prlo_acc->prlo_acc_params[page].opa_valid = 0;
-               prlo_acc->prlo_acc_params[page].rpa_valid = 0;
-               prlo_acc->prlo_acc_params[page].fc4type_csp = FC_TYPE_FCP;
-               prlo_acc->prlo_acc_params[page].orig_process_assc = 0;
-               prlo_acc->prlo_acc_params[page].resp_process_assc = 0;
-       }
-
-       return bfa_os_ntohs(prlo_acc->payload_len);
-}
-
-u16
-fc_rnid_build(struct fchs_s *fchs, struct fc_rnid_cmd_s *rnid, u32 d_id,
-                       u32 s_id, u16 ox_id, u32 data_format)
-{
-       fc_els_req_build(fchs, d_id, s_id, ox_id);
-
-       memset(rnid, 0, sizeof(struct fc_rnid_cmd_s));
-
-       rnid->els_cmd.els_code = FC_ELS_RNID;
-       rnid->node_id_data_format = data_format;
-
-       return sizeof(struct fc_rnid_cmd_s);
-}
-
-u16
-fc_rnid_acc_build(struct fchs_s *fchs, struct fc_rnid_acc_s *rnid_acc,
-                       u32 d_id, u32 s_id, u16 ox_id,
-                       u32 data_format,
-                       struct fc_rnid_common_id_data_s *common_id_data,
-                       struct fc_rnid_general_topology_data_s *gen_topo_data)
-{
-       memset(rnid_acc, 0, sizeof(struct fc_rnid_acc_s));
-
-       fc_els_rsp_build(fchs, d_id, s_id, ox_id);
-
-       rnid_acc->els_cmd.els_code = FC_ELS_ACC;
-       rnid_acc->node_id_data_format = data_format;
-       rnid_acc->common_id_data_length =
-                       sizeof(struct fc_rnid_common_id_data_s);
-       rnid_acc->common_id_data = *common_id_data;
-
-       if (data_format == RNID_NODEID_DATA_FORMAT_DISCOVERY) {
-               rnid_acc->specific_id_data_length =
-                       sizeof(struct fc_rnid_general_topology_data_s);
-               bfa_os_assign(rnid_acc->gen_topology_data, *gen_topo_data);
-               return sizeof(struct fc_rnid_acc_s);
-       } else {
-               return sizeof(struct fc_rnid_acc_s) -
-                       sizeof(struct fc_rnid_general_topology_data_s);
-       }
-
-}
-
-u16
-fc_rpsc_build(struct fchs_s *fchs, struct fc_rpsc_cmd_s *rpsc, u32 d_id,
-                       u32 s_id, u16 ox_id)
-{
-       fc_els_req_build(fchs, d_id, s_id, ox_id);
-
-       memset(rpsc, 0, sizeof(struct fc_rpsc_cmd_s));
-
-       rpsc->els_cmd.els_code = FC_ELS_RPSC;
-       return sizeof(struct fc_rpsc_cmd_s);
-}
-
-u16
-fc_rpsc2_build(struct fchs_s *fchs, struct fc_rpsc2_cmd_s *rpsc2,
-                       u32 d_id, u32 s_id, u32 *pid_list,
-                       u16 npids)
-{
-       u32 dctlr_id = FC_DOMAIN_CTRLR(bfa_os_hton3b(d_id));
-       int i = 0;
-
-       fc_els_req_build(fchs, bfa_os_hton3b(dctlr_id), s_id, 0);
-
-       memset(rpsc2, 0, sizeof(struct fc_rpsc2_cmd_s));
-
-       rpsc2->els_cmd.els_code = FC_ELS_RPSC;
-       rpsc2->token = bfa_os_htonl(FC_BRCD_TOKEN);
-       rpsc2->num_pids  = bfa_os_htons(npids);
-       for (i = 0; i < npids; i++)
-               rpsc2->pid_list[i].pid = pid_list[i];
-
-       return sizeof(struct fc_rpsc2_cmd_s) + ((npids - 1) *
-                       (sizeof(u32)));
-}
-
-u16
-fc_rpsc_acc_build(struct fchs_s *fchs, struct fc_rpsc_acc_s *rpsc_acc,
-                       u32 d_id, u32 s_id, u16 ox_id,
-                       struct fc_rpsc_speed_info_s *oper_speed)
-{
-       memset(rpsc_acc, 0, sizeof(struct fc_rpsc_acc_s));
-
-       fc_els_rsp_build(fchs, d_id, s_id, ox_id);
-
-       rpsc_acc->command = FC_ELS_ACC;
-       rpsc_acc->num_entries = bfa_os_htons(1);
-
-       rpsc_acc->speed_info[0].port_speed_cap =
-               bfa_os_htons(oper_speed->port_speed_cap);
-
-       rpsc_acc->speed_info[0].port_op_speed =
-               bfa_os_htons(oper_speed->port_op_speed);
-
-       return sizeof(struct fc_rpsc_acc_s);
-
-}
-
-/*
- * TBD -
- * . get rid of unnecessary memsets
- */
-
-u16
-fc_logo_rsp_parse(struct fchs_s *fchs, int len)
-{
-       struct fc_els_cmd_s   *els_cmd = (struct fc_els_cmd_s *) (fchs + 1);
-
-       len = len;
-       if (els_cmd->els_code != FC_ELS_ACC)
-               return FC_PARSE_FAILURE;
-
-       return FC_PARSE_OK;
-}
-
-u16
-fc_pdisc_build(struct fchs_s *fchs, u32 d_id, u32 s_id,
-                       u16 ox_id, wwn_t port_name, wwn_t node_name,
-                       u16 pdu_size)
-{
-       struct fc_logi_s     *pdisc = (struct fc_logi_s *) (fchs + 1);
-
-       bfa_os_memcpy(pdisc, &plogi_tmpl, sizeof(struct fc_logi_s));
-
-       pdisc->els_cmd.els_code = FC_ELS_PDISC;
-       fc_els_req_build(fchs, d_id, s_id, ox_id);
-
-       pdisc->csp.rxsz = pdisc->class3.rxsz = bfa_os_htons(pdu_size);
-       pdisc->port_name = port_name;
-       pdisc->node_name = node_name;
-
-       return sizeof(struct fc_logi_s);
-}
-
-u16
-fc_pdisc_rsp_parse(struct fchs_s *fchs, int len, wwn_t port_name)
-{
-       struct fc_logi_s     *pdisc = (struct fc_logi_s *) (fchs + 1);
-
-       if (len < sizeof(struct fc_logi_s))
-               return FC_PARSE_LEN_INVAL;
-
-       if (pdisc->els_cmd.els_code != FC_ELS_ACC)
-               return FC_PARSE_ACC_INVAL;
-
-       if (!wwn_is_equal(pdisc->port_name, port_name))
-               return FC_PARSE_PWWN_NOT_EQUAL;
-
-       if (!pdisc->class3.class_valid)
-               return FC_PARSE_NWWN_NOT_EQUAL;
-
-       if (bfa_os_ntohs(pdisc->class3.rxsz) < (FC_MIN_PDUSZ))
-               return FC_PARSE_RXSZ_INVAL;
-
-       return FC_PARSE_OK;
-}
-
-u16
-fc_prlo_build(struct fchs_s *fchs, u32 d_id, u32 s_id, u16 ox_id,
-             int num_pages)
-{
-       struct fc_prlo_s      *prlo = (struct fc_prlo_s *) (fchs + 1);
-       int             page;
-
-       fc_els_req_build(fchs, d_id, s_id, ox_id);
-       memset(prlo, 0, (num_pages * 16) + 4);
-       prlo->command = FC_ELS_PRLO;
-       prlo->page_len = 0x10;
-       prlo->payload_len = bfa_os_htons((num_pages * 16) + 4);
-
-       for (page = 0; page < num_pages; page++) {
-               prlo->prlo_params[page].type = FC_TYPE_FCP;
-               prlo->prlo_params[page].opa_valid = 0;
-               prlo->prlo_params[page].rpa_valid = 0;
-               prlo->prlo_params[page].orig_process_assc = 0;
-               prlo->prlo_params[page].resp_process_assc = 0;
-       }
-
-       return bfa_os_ntohs(prlo->payload_len);
-}
-
-u16
-fc_prlo_rsp_parse(struct fchs_s *fchs, int len)
-{
-       struct fc_prlo_acc_s  *prlo = (struct fc_prlo_acc_s *) (fchs + 1);
-       int             num_pages = 0;
-       int             page = 0;
-
-       len = len;
-
-       if (prlo->command != FC_ELS_ACC)
-               return FC_PARSE_FAILURE;
-
-       num_pages = ((bfa_os_ntohs(prlo->payload_len)) - 4) / 16;
-
-       for (page = 0; page < num_pages; page++) {
-               if (prlo->prlo_acc_params[page].type != FC_TYPE_FCP)
-                       return FC_PARSE_FAILURE;
-
-               if (prlo->prlo_acc_params[page].opa_valid != 0)
-                       return FC_PARSE_FAILURE;
-
-               if (prlo->prlo_acc_params[page].rpa_valid != 0)
-                       return FC_PARSE_FAILURE;
-
-               if (prlo->prlo_acc_params[page].orig_process_assc != 0)
-                       return FC_PARSE_FAILURE;
-
-               if (prlo->prlo_acc_params[page].resp_process_assc != 0)
-                       return FC_PARSE_FAILURE;
-       }
-       return FC_PARSE_OK;
-
-}
-
-u16
-fc_tprlo_build(struct fchs_s *fchs, u32 d_id, u32 s_id,
-                       u16 ox_id, int num_pages,
-                       enum fc_tprlo_type tprlo_type, u32 tpr_id)
-{
-       struct fc_tprlo_s     *tprlo = (struct fc_tprlo_s *) (fchs + 1);
-       int             page;
-
-       fc_els_req_build(fchs, d_id, s_id, ox_id);
-       memset(tprlo, 0, (num_pages * 16) + 4);
-       tprlo->command = FC_ELS_TPRLO;
-       tprlo->page_len = 0x10;
-       tprlo->payload_len = bfa_os_htons((num_pages * 16) + 4);
-
-       for (page = 0; page < num_pages; page++) {
-               tprlo->tprlo_params[page].type = FC_TYPE_FCP;
-               tprlo->tprlo_params[page].opa_valid = 0;
-               tprlo->tprlo_params[page].rpa_valid = 0;
-               tprlo->tprlo_params[page].orig_process_assc = 0;
-               tprlo->tprlo_params[page].resp_process_assc = 0;
-               if (tprlo_type == FC_GLOBAL_LOGO) {
-                       tprlo->tprlo_params[page].global_process_logout = 1;
-               } else if (tprlo_type == FC_TPR_LOGO) {
-                       tprlo->tprlo_params[page].tpo_nport_valid = 1;
-                       tprlo->tprlo_params[page].tpo_nport_id = (tpr_id);
-               }
-       }
-
-       return bfa_os_ntohs(tprlo->payload_len);
-}
-
-u16
-fc_tprlo_rsp_parse(struct fchs_s *fchs, int len)
-{
-       struct fc_tprlo_acc_s *tprlo = (struct fc_tprlo_acc_s *) (fchs + 1);
-       int             num_pages = 0;
-       int             page = 0;
-
-       len = len;
-
-       if (tprlo->command != FC_ELS_ACC)
-               return FC_PARSE_ACC_INVAL;
-
-       num_pages = (bfa_os_ntohs(tprlo->payload_len) - 4) / 16;
-
-       for (page = 0; page < num_pages; page++) {
-               if (tprlo->tprlo_acc_params[page].type != FC_TYPE_FCP)
-                       return FC_PARSE_NOT_FCP;
-               if (tprlo->tprlo_acc_params[page].opa_valid != 0)
-                       return FC_PARSE_OPAFLAG_INVAL;
-               if (tprlo->tprlo_acc_params[page].rpa_valid != 0)
-                       return FC_PARSE_RPAFLAG_INVAL;
-               if (tprlo->tprlo_acc_params[page].orig_process_assc != 0)
-                       return FC_PARSE_OPA_INVAL;
-               if (tprlo->tprlo_acc_params[page].resp_process_assc != 0)
-                       return FC_PARSE_RPA_INVAL;
-       }
-       return FC_PARSE_OK;
-}
-
-enum fc_parse_status
-fc_rrq_rsp_parse(struct fchs_s *fchs, int len)
-{
-       struct fc_els_cmd_s   *els_cmd = (struct fc_els_cmd_s *) (fchs + 1);
-
-       len = len;
-       if (els_cmd->els_code != FC_ELS_ACC)
-               return FC_PARSE_FAILURE;
-
-       return FC_PARSE_OK;
-}
-
-u16
-fc_ba_rjt_build(struct fchs_s *fchs, u32 d_id, u32 s_id,
-                       u16 ox_id, u32 reason_code,
-                       u32 reason_expl)
-{
-       struct fc_ba_rjt_s    *ba_rjt = (struct fc_ba_rjt_s *) (fchs + 1);
-
-       fc_bls_rsp_build(fchs, d_id, s_id, ox_id);
-
-       fchs->cat_info = FC_CAT_BA_RJT;
-       ba_rjt->reason_code = reason_code;
-       ba_rjt->reason_expl = reason_expl;
-       return sizeof(struct fc_ba_rjt_s);
-}
-
-static void
-fc_gs_cthdr_build(struct ct_hdr_s *cthdr, u32 s_id, u16 cmd_code)
-{
-       bfa_os_memset(cthdr, 0, sizeof(struct ct_hdr_s));
-       cthdr->rev_id = CT_GS3_REVISION;
-       cthdr->gs_type = CT_GSTYPE_DIRSERVICE;
-       cthdr->gs_sub_type = CT_GSSUBTYPE_NAMESERVER;
-       cthdr->cmd_rsp_code = bfa_os_htons(cmd_code);
-}
-
-static void
-fc_gs_fdmi_cthdr_build(struct ct_hdr_s *cthdr, u32 s_id, u16 cmd_code)
-{
-       bfa_os_memset(cthdr, 0, sizeof(struct ct_hdr_s));
-       cthdr->rev_id = CT_GS3_REVISION;
-       cthdr->gs_type = CT_GSTYPE_MGMTSERVICE;
-       cthdr->gs_sub_type = CT_GSSUBTYPE_HBA_MGMTSERVER;
-       cthdr->cmd_rsp_code = bfa_os_htons(cmd_code);
-}
-
-static void
-fc_gs_ms_cthdr_build(struct ct_hdr_s *cthdr, u32 s_id, u16 cmd_code,
-                                        u8 sub_type)
-{
-       bfa_os_memset(cthdr, 0, sizeof(struct ct_hdr_s));
-       cthdr->rev_id = CT_GS3_REVISION;
-       cthdr->gs_type = CT_GSTYPE_MGMTSERVICE;
-       cthdr->gs_sub_type = sub_type;
-       cthdr->cmd_rsp_code = bfa_os_htons(cmd_code);
-}
-
-u16
-fc_gidpn_build(struct fchs_s *fchs, void *pyld, u32 s_id, u16 ox_id,
-              wwn_t port_name)
-{
-
-       struct ct_hdr_s       *cthdr = (struct ct_hdr_s *) pyld;
-       struct fcgs_gidpn_req_s *gidpn =
-                       (struct fcgs_gidpn_req_s *) (cthdr + 1);
-       u32        d_id = bfa_os_hton3b(FC_NAME_SERVER);
-
-       fc_gs_fchdr_build(fchs, d_id, s_id, ox_id);
-       fc_gs_cthdr_build(cthdr, s_id, GS_GID_PN);
-
-       bfa_os_memset(gidpn, 0, sizeof(struct fcgs_gidpn_req_s));
-       gidpn->port_name = port_name;
-       return sizeof(struct fcgs_gidpn_req_s) + sizeof(struct ct_hdr_s);
-}
-
-u16
-fc_gpnid_build(struct fchs_s *fchs, void *pyld, u32 s_id, u16 ox_id,
-              u32 port_id)
-{
-
-       struct ct_hdr_s       *cthdr = (struct ct_hdr_s *) pyld;
-       fcgs_gpnid_req_t *gpnid = (fcgs_gpnid_req_t *) (cthdr + 1);
-       u32        d_id = bfa_os_hton3b(FC_NAME_SERVER);
-
-       fc_gs_fchdr_build(fchs, d_id, s_id, ox_id);
-       fc_gs_cthdr_build(cthdr, s_id, GS_GPN_ID);
-
-       bfa_os_memset(gpnid, 0, sizeof(fcgs_gpnid_req_t));
-       gpnid->dap = port_id;
-       return sizeof(fcgs_gpnid_req_t) + sizeof(struct ct_hdr_s);
-}
-
-u16
-fc_gnnid_build(struct fchs_s *fchs, void *pyld, u32 s_id, u16 ox_id,
-              u32 port_id)
-{
-
-       struct ct_hdr_s       *cthdr = (struct ct_hdr_s *) pyld;
-       fcgs_gnnid_req_t *gnnid = (fcgs_gnnid_req_t *) (cthdr + 1);
-       u32        d_id = bfa_os_hton3b(FC_NAME_SERVER);
-
-       fc_gs_fchdr_build(fchs, d_id, s_id, ox_id);
-       fc_gs_cthdr_build(cthdr, s_id, GS_GNN_ID);
-
-       bfa_os_memset(gnnid, 0, sizeof(fcgs_gnnid_req_t));
-       gnnid->dap = port_id;
-       return sizeof(fcgs_gnnid_req_t) + sizeof(struct ct_hdr_s);
-}
-
-u16
-fc_ct_rsp_parse(struct ct_hdr_s *cthdr)
-{
-       if (bfa_os_ntohs(cthdr->cmd_rsp_code) != CT_RSP_ACCEPT) {
-               if (cthdr->reason_code == CT_RSN_LOGICAL_BUSY)
-                       return FC_PARSE_BUSY;
-               else
-                       return FC_PARSE_FAILURE;
-       }
-
-       return FC_PARSE_OK;
-}
-
-u16
-fc_scr_build(struct fchs_s *fchs, struct fc_scr_s *scr, u8 set_br_reg,
-                       u32 s_id, u16 ox_id)
-{
-       u32        d_id = bfa_os_hton3b(FC_FABRIC_CONTROLLER);
-
-       fc_els_req_build(fchs, d_id, s_id, ox_id);
-
-       bfa_os_memset(scr, 0, sizeof(struct fc_scr_s));
-       scr->command = FC_ELS_SCR;
-       scr->reg_func = FC_SCR_REG_FUNC_FULL;
-       if (set_br_reg)
-               scr->vu_reg_func = FC_VU_SCR_REG_FUNC_FABRIC_NAME_CHANGE;
-
-       return sizeof(struct fc_scr_s);
-}
-
-u16
-fc_rscn_build(struct fchs_s *fchs, struct fc_rscn_pl_s *rscn, u32 s_id,
-                       u16 ox_id)
-{
-       u32        d_id = bfa_os_hton3b(FC_FABRIC_CONTROLLER);
-       u16        payldlen;
-
-       fc_els_req_build(fchs, d_id, s_id, ox_id);
-       rscn->command = FC_ELS_RSCN;
-       rscn->pagelen = sizeof(rscn->event[0]);
-
-       payldlen = sizeof(u32) + rscn->pagelen;
-       rscn->payldlen = bfa_os_htons(payldlen);
-
-       rscn->event[0].format = FC_RSCN_FORMAT_PORTID;
-       rscn->event[0].portid = s_id;
-
-       return sizeof(struct fc_rscn_pl_s);
-}
-
-u16
-fc_rftid_build(struct fchs_s *fchs, void *pyld, u32 s_id, u16 ox_id,
-              enum bfa_port_role roles)
-{
-       struct ct_hdr_s       *cthdr = (struct ct_hdr_s *) pyld;
-       struct fcgs_rftid_req_s *rftid =
-                       (struct fcgs_rftid_req_s *) (cthdr + 1);
-       u32        type_value, d_id = bfa_os_hton3b(FC_NAME_SERVER);
-       u8         index;
-
-       fc_gs_fchdr_build(fchs, d_id, s_id, ox_id);
-       fc_gs_cthdr_build(cthdr, s_id, GS_RFT_ID);
-
-       bfa_os_memset(rftid, 0, sizeof(struct fcgs_rftid_req_s));
-
-       rftid->dap = s_id;
-
-       /* By default, FCP FC4 Type is registered */
-       index = FC_TYPE_FCP >> 5;
-       type_value = 1 << (FC_TYPE_FCP % 32);
-       rftid->fc4_type[index] = bfa_os_htonl(type_value);
-
-       if (roles & BFA_PORT_ROLE_FCP_IPFC) {
-               index = FC_TYPE_IP >> 5;
-               type_value = 1 << (FC_TYPE_IP % 32);
-               rftid->fc4_type[index] |= bfa_os_htonl(type_value);
-       }
-
-       return sizeof(struct fcgs_rftid_req_s) + sizeof(struct ct_hdr_s);
-}
-
-u16
-fc_rftid_build_sol(struct fchs_s *fchs, void *pyld, u32 s_id,
-                       u16 ox_id, u8 *fc4_bitmap,
-                       u32 bitmap_size)
-{
-       struct ct_hdr_s       *cthdr = (struct ct_hdr_s *) pyld;
-       struct fcgs_rftid_req_s *rftid =
-                       (struct fcgs_rftid_req_s *) (cthdr + 1);
-       u32        d_id = bfa_os_hton3b(FC_NAME_SERVER);
-
-       fc_gs_fchdr_build(fchs, d_id, s_id, ox_id);
-       fc_gs_cthdr_build(cthdr, s_id, GS_RFT_ID);
-
-       bfa_os_memset(rftid, 0, sizeof(struct fcgs_rftid_req_s));
-
-       rftid->dap = s_id;
-       bfa_os_memcpy((void *)rftid->fc4_type, (void *)fc4_bitmap,
-                       (bitmap_size < 32 ? bitmap_size : 32));
-
-       return sizeof(struct fcgs_rftid_req_s) + sizeof(struct ct_hdr_s);
-}
-
-u16
-fc_rffid_build(struct fchs_s *fchs, void *pyld, u32 s_id, u16 ox_id,
-              u8 fc4_type, u8 fc4_ftrs)
-{
-       struct ct_hdr_s         *cthdr = (struct ct_hdr_s *) pyld;
-       struct fcgs_rffid_req_s *rffid =
-                       (struct fcgs_rffid_req_s *) (cthdr + 1);
-       u32         d_id = bfa_os_hton3b(FC_NAME_SERVER);
-
-       fc_gs_fchdr_build(fchs, d_id, s_id, ox_id);
-       fc_gs_cthdr_build(cthdr, s_id, GS_RFF_ID);
-
-       bfa_os_memset(rffid, 0, sizeof(struct fcgs_rffid_req_s));
-
-       rffid->dap                      = s_id;
-       rffid->fc4ftr_bits  = fc4_ftrs;
-       rffid->fc4_type         = fc4_type;
-
-       return sizeof(struct fcgs_rffid_req_s) + sizeof(struct ct_hdr_s);
-}
-
-u16
-fc_rspnid_build(struct fchs_s *fchs, void *pyld, u32 s_id, u16 ox_id,
-               u8 *name)
-{
-
-       struct ct_hdr_s       *cthdr = (struct ct_hdr_s *) pyld;
-       struct fcgs_rspnid_req_s *rspnid =
-                       (struct fcgs_rspnid_req_s *) (cthdr + 1);
-       u32        d_id = bfa_os_hton3b(FC_NAME_SERVER);
-
-       fc_gs_fchdr_build(fchs, d_id, s_id, ox_id);
-       fc_gs_cthdr_build(cthdr, s_id, GS_RSPN_ID);
-
-       bfa_os_memset(rspnid, 0, sizeof(struct fcgs_rspnid_req_s));
-
-       rspnid->dap = s_id;
-       rspnid->spn_len = (u8) strlen((char *)name);
-       strncpy((char *)rspnid->spn, (char *)name, rspnid->spn_len);
-
-       return sizeof(struct fcgs_rspnid_req_s) + sizeof(struct ct_hdr_s);
-}
-
-u16
-fc_gid_ft_build(struct fchs_s *fchs, void *pyld, u32 s_id,
-                       u8 fc4_type)
-{
-
-       struct ct_hdr_s       *cthdr = (struct ct_hdr_s *) pyld;
-       struct fcgs_gidft_req_s *gidft =
-                       (struct fcgs_gidft_req_s *) (cthdr + 1);
-       u32        d_id = bfa_os_hton3b(FC_NAME_SERVER);
-
-       fc_gs_fchdr_build(fchs, d_id, s_id, 0);
-
-       fc_gs_cthdr_build(cthdr, s_id, GS_GID_FT);
-
-       bfa_os_memset(gidft, 0, sizeof(struct fcgs_gidft_req_s));
-       gidft->fc4_type = fc4_type;
-       gidft->domain_id = 0;
-       gidft->area_id = 0;
-
-       return sizeof(struct fcgs_gidft_req_s) + sizeof(struct ct_hdr_s);
-}
-
-u16
-fc_rpnid_build(struct fchs_s *fchs, void *pyld, u32 s_id, u32 port_id,
-              wwn_t port_name)
-{
-       struct ct_hdr_s       *cthdr = (struct ct_hdr_s *) pyld;
-       struct fcgs_rpnid_req_s *rpnid =
-                       (struct fcgs_rpnid_req_s *) (cthdr + 1);
-       u32        d_id = bfa_os_hton3b(FC_NAME_SERVER);
-
-       fc_gs_fchdr_build(fchs, d_id, s_id, 0);
-       fc_gs_cthdr_build(cthdr, s_id, GS_RPN_ID);
-
-       bfa_os_memset(rpnid, 0, sizeof(struct fcgs_rpnid_req_s));
-       rpnid->port_id = port_id;
-       rpnid->port_name = port_name;
-
-       return sizeof(struct fcgs_rpnid_req_s) + sizeof(struct ct_hdr_s);
-}
-
-u16
-fc_rnnid_build(struct fchs_s *fchs, void *pyld, u32 s_id, u32 port_id,
-              wwn_t node_name)
-{
-       struct ct_hdr_s       *cthdr = (struct ct_hdr_s *) pyld;
-       struct fcgs_rnnid_req_s *rnnid =
-                       (struct fcgs_rnnid_req_s *) (cthdr + 1);
-       u32        d_id = bfa_os_hton3b(FC_NAME_SERVER);
-
-       fc_gs_fchdr_build(fchs, d_id, s_id, 0);
-       fc_gs_cthdr_build(cthdr, s_id, GS_RNN_ID);
-
-       bfa_os_memset(rnnid, 0, sizeof(struct fcgs_rnnid_req_s));
-       rnnid->port_id = port_id;
-       rnnid->node_name = node_name;
-
-       return sizeof(struct fcgs_rnnid_req_s) + sizeof(struct ct_hdr_s);
-}
-
-u16
-fc_rcsid_build(struct fchs_s *fchs, void *pyld, u32 s_id, u32 port_id,
-              u32 cos)
-{
-       struct ct_hdr_s       *cthdr = (struct ct_hdr_s *) pyld;
-       struct fcgs_rcsid_req_s *rcsid =
-                       (struct fcgs_rcsid_req_s *) (cthdr + 1);
-       u32        d_id = bfa_os_hton3b(FC_NAME_SERVER);
-
-       fc_gs_fchdr_build(fchs, d_id, s_id, 0);
-       fc_gs_cthdr_build(cthdr, s_id, GS_RCS_ID);
-
-       bfa_os_memset(rcsid, 0, sizeof(struct fcgs_rcsid_req_s));
-       rcsid->port_id = port_id;
-       rcsid->cos = cos;
-
-       return sizeof(struct fcgs_rcsid_req_s) + sizeof(struct ct_hdr_s);
-}
-
-u16
-fc_rptid_build(struct fchs_s *fchs, void *pyld, u32 s_id, u32 port_id,
-              u8 port_type)
-{
-       struct ct_hdr_s       *cthdr = (struct ct_hdr_s *) pyld;
-       struct fcgs_rptid_req_s *rptid =
-                       (struct fcgs_rptid_req_s *) (cthdr + 1);
-       u32        d_id = bfa_os_hton3b(FC_NAME_SERVER);
-
-       fc_gs_fchdr_build(fchs, d_id, s_id, 0);
-       fc_gs_cthdr_build(cthdr, s_id, GS_RPT_ID);
-
-       bfa_os_memset(rptid, 0, sizeof(struct fcgs_rptid_req_s));
-       rptid->port_id = port_id;
-       rptid->port_type = port_type;
-
-       return sizeof(struct fcgs_rptid_req_s) + sizeof(struct ct_hdr_s);
-}
-
-u16
-fc_ganxt_build(struct fchs_s *fchs, void *pyld, u32 s_id, u32 port_id)
-{
-       struct ct_hdr_s       *cthdr = (struct ct_hdr_s *) pyld;
-       struct fcgs_ganxt_req_s *ganxt =
-                       (struct fcgs_ganxt_req_s *) (cthdr + 1);
-       u32        d_id = bfa_os_hton3b(FC_NAME_SERVER);
-
-       fc_gs_fchdr_build(fchs, d_id, s_id, 0);
-       fc_gs_cthdr_build(cthdr, s_id, GS_GA_NXT);
-
-       bfa_os_memset(ganxt, 0, sizeof(struct fcgs_ganxt_req_s));
-       ganxt->port_id = port_id;
-
-       return sizeof(struct ct_hdr_s) + sizeof(struct fcgs_ganxt_req_s);
-}
-
-/*
- * Builds fc hdr and ct hdr for FDMI requests.
- */
-u16
-fc_fdmi_reqhdr_build(struct fchs_s *fchs, void *pyld, u32 s_id,
-                    u16 cmd_code)
-{
-
-       struct ct_hdr_s       *cthdr = (struct ct_hdr_s *) pyld;
-       u32        d_id = bfa_os_hton3b(FC_MGMT_SERVER);
-
-       fc_gs_fchdr_build(fchs, d_id, s_id, 0);
-       fc_gs_fdmi_cthdr_build(cthdr, s_id, cmd_code);
-
-       return sizeof(struct ct_hdr_s);
-}
-
-/*
- * Given a FC4 Type, this function returns a fc4 type bitmask
- */
-void
-fc_get_fc4type_bitmask(u8 fc4_type, u8 *bit_mask)
-{
-       u8         index;
-       u32       *ptr = (u32 *) bit_mask;
-       u32        type_value;
-
-       /*
-        * @todo : Check for bitmask size
-        */
-
-       index = fc4_type >> 5;
-       type_value = 1 << (fc4_type % 32);
-       ptr[index] = bfa_os_htonl(type_value);
-
-}
-
-/*
- * GMAL Request
- */
-u16
-fc_gmal_req_build(struct fchs_s *fchs, void *pyld, u32 s_id, wwn_t wwn)
-{
-       struct ct_hdr_s       *cthdr = (struct ct_hdr_s *) pyld;
-       fcgs_gmal_req_t *gmal = (fcgs_gmal_req_t *) (cthdr + 1);
-       u32        d_id = bfa_os_hton3b(FC_MGMT_SERVER);
-
-       fc_gs_fchdr_build(fchs, d_id, s_id, 0);
-       fc_gs_ms_cthdr_build(cthdr, s_id, GS_FC_GMAL_CMD,
-                       CT_GSSUBTYPE_CFGSERVER);
-
-       bfa_os_memset(gmal, 0, sizeof(fcgs_gmal_req_t));
-       gmal->wwn = wwn;
-
-       return sizeof(struct ct_hdr_s) + sizeof(fcgs_gmal_req_t);
-}
-
-/*
- * GFN (Get Fabric Name) Request
- */
-u16
-fc_gfn_req_build(struct fchs_s *fchs, void *pyld, u32 s_id, wwn_t wwn)
-{
-       struct ct_hdr_s       *cthdr = (struct ct_hdr_s *) pyld;
-       fcgs_gfn_req_t *gfn = (fcgs_gfn_req_t *) (cthdr + 1);
-       u32        d_id = bfa_os_hton3b(FC_MGMT_SERVER);
-
-       fc_gs_fchdr_build(fchs, d_id, s_id, 0);
-       fc_gs_ms_cthdr_build(cthdr, s_id, GS_FC_GFN_CMD,
-                       CT_GSSUBTYPE_CFGSERVER);
-
-       bfa_os_memset(gfn, 0, sizeof(fcgs_gfn_req_t));
-       gfn->wwn = wwn;
-
-       return sizeof(struct ct_hdr_s) + sizeof(fcgs_gfn_req_t);
-}
diff --git a/drivers/scsi/bfa/fcbuild.h b/drivers/scsi/bfa/fcbuild.h
deleted file mode 100644 (file)
index 981d98d..0000000
+++ /dev/null
@@ -1,279 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-/*
- * fcbuild.h - FC link service frame building and parsing routines
- */
-
-#ifndef __FCBUILD_H__
-#define __FCBUILD_H__
-
-#include <bfa_os_inc.h>
-#include <protocol/fc.h>
-#include <protocol/fcp.h>
-#include <protocol/ct.h>
-#include <defs/bfa_defs_port.h>
-#include <defs/bfa_defs_pport.h>
-
-/*
- * Utility Macros/functions
- */
-
-#define fcif_sof_set(_ifhdr, _sof)     ((_ifhdr)->sof = FC_ ## _sof)
-#define fcif_eof_set(_ifhdr, _eof)     ((_ifhdr)->eof = FC_ ## _eof)
-
-#define wwn_is_equal(_wwn1, _wwn2)             \
-       (memcmp(&(_wwn1), &(_wwn2), sizeof(wwn_t)) == 0)
-
-#define fc_roundup(_l, _s) (((_l) + ((_s) - 1)) & ~((_s) - 1))
-
-/*
- * Given the fc response length, this routine will return
- * the length of the actual payload bytes following the CT header.
- *
- * Assumes the input response length does not include the crc, eof, etc.
- */
-static inline   u32
-fc_get_ctresp_pyld_len(u32 resp_len)
-{
-       return resp_len - sizeof(struct ct_hdr_s);
-}
-
-/*
- * Convert bfa speed to rpsc speed value.
- */
-static inline enum bfa_pport_speed
-fc_rpsc_operspeed_to_bfa_speed(enum fc_rpsc_op_speed_s speed)
-{
-       switch (speed) {
-
-       case RPSC_OP_SPEED_1G:
-               return BFA_PPORT_SPEED_1GBPS;
-
-       case RPSC_OP_SPEED_2G:
-               return BFA_PPORT_SPEED_2GBPS;
-
-       case RPSC_OP_SPEED_4G:
-               return BFA_PPORT_SPEED_4GBPS;
-
-       case RPSC_OP_SPEED_8G:
-               return BFA_PPORT_SPEED_8GBPS;
-
-       case RPSC_OP_SPEED_10G:
-               return BFA_PPORT_SPEED_10GBPS;
-
-       default:
-               return BFA_PPORT_SPEED_UNKNOWN;
-       }
-}
-
-/*
- * Convert RPSC speed to bfa speed value.
- */
-static inline   enum fc_rpsc_op_speed_s
-fc_bfa_speed_to_rpsc_operspeed(enum bfa_pport_speed op_speed)
-{
-       switch (op_speed) {
-
-       case BFA_PPORT_SPEED_1GBPS:
-               return RPSC_OP_SPEED_1G;
-
-       case BFA_PPORT_SPEED_2GBPS:
-               return RPSC_OP_SPEED_2G;
-
-       case BFA_PPORT_SPEED_4GBPS:
-               return RPSC_OP_SPEED_4G;
-
-       case BFA_PPORT_SPEED_8GBPS:
-               return RPSC_OP_SPEED_8G;
-
-       case BFA_PPORT_SPEED_10GBPS:
-               return RPSC_OP_SPEED_10G;
-
-       default:
-               return RPSC_OP_SPEED_NOT_EST;
-       }
-}
-enum fc_parse_status {
-       FC_PARSE_OK = 0,
-       FC_PARSE_FAILURE = 1,
-       FC_PARSE_BUSY = 2,
-       FC_PARSE_LEN_INVAL,
-       FC_PARSE_ACC_INVAL,
-       FC_PARSE_PWWN_NOT_EQUAL,
-       FC_PARSE_NWWN_NOT_EQUAL,
-       FC_PARSE_RXSZ_INVAL,
-       FC_PARSE_NOT_FCP,
-       FC_PARSE_OPAFLAG_INVAL,
-       FC_PARSE_RPAFLAG_INVAL,
-       FC_PARSE_OPA_INVAL,
-       FC_PARSE_RPA_INVAL,
-
-};
-
-struct fc_templates_s {
-       struct fchs_s          fc_els_req;
-       struct fchs_s          fc_bls_req;
-       struct fc_logi_s      plogi;
-       struct fc_rrq_s        rrq;
-};
-
-void fcbuild_init(void);
-
-u16 fc_flogi_build(struct fchs_s *fchs, struct fc_logi_s *flogi,
-                       u32 s_id, u16 ox_id, wwn_t port_name,
-                       wwn_t node_name, u16 pdu_size, u8 set_npiv,
-                       u8 set_auth, u16 local_bb_credits);
-u16 fc_fdisc_build(struct fchs_s *buf, struct fc_logi_s *flogi,
-                       u32 s_id, u16 ox_id, wwn_t port_name,
-                       wwn_t node_name, u16 pdu_size);
-u16 fc_flogi_acc_build(struct fchs_s *fchs, struct fc_logi_s *flogi,
-                       u32 s_id, u16 ox_id, wwn_t port_name,
-                       wwn_t node_name, u16 pdu_size,
-                       u16 local_bb_credits);
-u16 fc_plogi_build(struct fchs_s *fchs, void *pld, u32 d_id,
-                       u32 s_id, u16 ox_id, wwn_t port_name,
-                       wwn_t node_name, u16 pdu_size);
-enum fc_parse_status fc_plogi_parse(struct fchs_s *fchs);
-u16 fc_abts_build(struct fchs_s *buf, u32 d_id, u32 s_id,
-                       u16 ox_id);
-enum fc_parse_status fc_abts_rsp_parse(struct fchs_s *buf, int len);
-u16 fc_rrq_build(struct fchs_s *buf, struct fc_rrq_s *rrq, u32 d_id,
-                       u32 s_id, u16 ox_id, u16 rrq_oxid);
-enum fc_parse_status fc_rrq_rsp_parse(struct fchs_s *buf, int len);
-u16 fc_rspnid_build(struct fchs_s *fchs, void *pld, u32 s_id,
-                       u16 ox_id, u8 *name);
-u16 fc_rftid_build(struct fchs_s *fchs, void *pld, u32 s_id,
-                       u16 ox_id, enum bfa_port_role role);
-u16 fc_rftid_build_sol(struct fchs_s *fchs, void *pyld, u32 s_id,
-                       u16 ox_id, u8 *fc4_bitmap,
-                       u32 bitmap_size);
-u16 fc_rffid_build(struct fchs_s *fchs, void *pyld, u32 s_id,
-                       u16 ox_id, u8 fc4_type, u8 fc4_ftrs);
-u16 fc_gidpn_build(struct fchs_s *fchs, void *pyld, u32 s_id,
-                       u16 ox_id, wwn_t port_name);
-u16 fc_gpnid_build(struct fchs_s *fchs, void *pld, u32 s_id,
-                       u16 ox_id, u32 port_id);
-u16 fc_scr_build(struct fchs_s *fchs, struct fc_scr_s *scr,
-                       u8 set_br_reg, u32 s_id, u16 ox_id);
-u16 fc_plogi_acc_build(struct fchs_s *fchs, void *pld, u32 d_id,
-                       u32 s_id, u16 ox_id,
-                       wwn_t port_name, wwn_t node_name, u16 pdu_size);
-
-u16 fc_adisc_build(struct fchs_s *fchs, struct fc_adisc_s *adisc,
-                       u32 d_id, u32 s_id, u16 ox_id,
-                       wwn_t port_name, wwn_t node_name);
-enum fc_parse_status fc_adisc_parse(struct fchs_s *fchs, void *pld,
-                       u32 host_dap,
-                       wwn_t node_name, wwn_t port_name);
-enum fc_parse_status fc_adisc_rsp_parse(struct fc_adisc_s *adisc, int len,
-                       wwn_t port_name, wwn_t node_name);
-u16 fc_adisc_acc_build(struct fchs_s *fchs, struct fc_adisc_s *adisc,
-                       u32 d_id, u32 s_id, u16 ox_id,
-                       wwn_t port_name, wwn_t node_name);
-u16 fc_ls_rjt_build(struct fchs_s *fchs, struct fc_ls_rjt_s *ls_rjt,
-                       u32 d_id, u32 s_id, u16 ox_id,
-                       u8 reason_code, u8 reason_code_expl);
-u16 fc_ls_acc_build(struct fchs_s *fchs, struct fc_els_cmd_s *els_cmd,
-                       u32 d_id, u32 s_id, u16 ox_id);
-u16 fc_prli_build(struct fchs_s *fchs, void *pld, u32 d_id,
-                       u32 s_id, u16 ox_id);
-enum fc_parse_status fc_prli_rsp_parse(struct fc_prli_s *prli, int len);
-
-u16 fc_prli_acc_build(struct fchs_s *fchs, void *pld, u32 d_id,
-                       u32 s_id, u16 ox_id,
-                       enum bfa_port_role role);
-u16 fc_rnid_build(struct fchs_s *fchs, struct fc_rnid_cmd_s *rnid,
-                       u32 d_id, u32 s_id, u16 ox_id,
-                       u32 data_format);
-u16 fc_rnid_acc_build(struct fchs_s *fchs, struct fc_rnid_acc_s *rnid_acc,
-                       u32 d_id, u32 s_id, u16 ox_id,
-                       u32 data_format,
-                       struct fc_rnid_common_id_data_s *common_id_data,
-                       struct fc_rnid_general_topology_data_s *
-                       gen_topo_data);
-u16 fc_rpsc2_build(struct fchs_s *fchs, struct fc_rpsc2_cmd_s *rps2c,
-                       u32 d_id, u32 s_id,
-                       u32 *pid_list, u16 npids);
-u16 fc_rpsc_build(struct fchs_s *fchs, struct fc_rpsc_cmd_s *rpsc,
-                       u32 d_id, u32 s_id, u16 ox_id);
-u16 fc_rpsc_acc_build(struct fchs_s *fchs, struct fc_rpsc_acc_s *rpsc_acc,
-                       u32 d_id, u32 s_id, u16 ox_id,
-                       struct fc_rpsc_speed_info_s *oper_speed);
-u16 fc_gid_ft_build(struct fchs_s *fchs, void *pld, u32 s_id,
-                       u8 fc4_type);
-u16 fc_rpnid_build(struct fchs_s *fchs, void *pyld, u32 s_id,
-                       u32 port_id, wwn_t port_name);
-u16 fc_rnnid_build(struct fchs_s *fchs, void *pyld, u32 s_id,
-                       u32 port_id, wwn_t node_name);
-u16 fc_rcsid_build(struct fchs_s *fchs, void *pyld, u32 s_id,
-                       u32 port_id, u32 cos);
-u16 fc_rptid_build(struct fchs_s *fchs, void *pyld, u32 s_id,
-                       u32 port_id, u8 port_type);
-u16 fc_ganxt_build(struct fchs_s *fchs, void *pyld, u32 s_id,
-                       u32 port_id);
-u16 fc_logo_build(struct fchs_s *fchs, struct fc_logo_s *logo,
-                       u32 d_id, u32 s_id, u16 ox_id,
-                       wwn_t port_name);
-u16 fc_logo_acc_build(struct fchs_s *fchs, void *pld, u32 d_id,
-                       u32 s_id, u16 ox_id);
-u16 fc_fdmi_reqhdr_build(struct fchs_s *fchs, void *pyld, u32 s_id,
-                       u16 cmd_code);
-u16 fc_gmal_req_build(struct fchs_s *fchs, void *pyld, u32 s_id,
-                       wwn_t wwn);
-u16 fc_gfn_req_build(struct fchs_s *fchs, void *pyld, u32 s_id,
-                       wwn_t wwn);
-void fc_get_fc4type_bitmask(u8 fc4_type, u8 *bit_mask);
-void fc_els_req_build(struct fchs_s *fchs, u32 d_id, u32 s_id,
-                       u16 ox_id);
-enum fc_parse_status fc_els_rsp_parse(struct fchs_s *fchs, int len);
-enum fc_parse_status fc_plogi_rsp_parse(struct fchs_s *fchs, int len,
-                        wwn_t port_name);
-enum fc_parse_status fc_prli_parse(struct fc_prli_s *prli);
-enum fc_parse_status fc_pdisc_parse(struct fchs_s *fchs, wwn_t node_name,
-                       wwn_t port_name);
-u16 fc_ba_acc_build(struct fchs_s *fchs, struct fc_ba_acc_s *ba_acc,
-                       u32 d_id, u32 s_id, u16 ox_id,
-                       u16 rx_id);
-int fc_logout_params_pages(struct fchs_s *fc_frame, u8 els_code);
-u16 fc_tprlo_acc_build(struct fchs_s *fchs,
-                       struct fc_tprlo_acc_s *tprlo_acc,
-                       u32 d_id, u32 s_id, u16 ox_id,
-                       int num_pages);
-u16 fc_prlo_acc_build(struct fchs_s *fchs, struct fc_prlo_acc_s *prlo_acc,
-                       u32 d_id, u32 s_id, u16 ox_id,
-                       int num_pages);
-u16 fc_logo_rsp_parse(struct fchs_s *fchs, int len);
-u16 fc_pdisc_build(struct fchs_s *fchs, u32 d_id, u32 s_id,
-                       u16 ox_id, wwn_t port_name, wwn_t node_name,
-                       u16 pdu_size);
-u16 fc_pdisc_rsp_parse(struct fchs_s *fchs, int len, wwn_t port_name);
-u16 fc_prlo_build(struct fchs_s *fchs, u32 d_id, u32 s_id,
-                       u16 ox_id, int num_pages);
-u16 fc_prlo_rsp_parse(struct fchs_s *fchs, int len);
-u16 fc_tprlo_build(struct fchs_s *fchs, u32 d_id, u32 s_id,
-                       u16 ox_id, int num_pages,
-                       enum fc_tprlo_type tprlo_type, u32 tpr_id);
-u16 fc_tprlo_rsp_parse(struct fchs_s *fchs, int len);
-u16 fc_ba_rjt_build(struct fchs_s *fchs, u32 d_id, u32 s_id,
-                       u16 ox_id, u32 reason_code,
-                       u32 reason_expl);
-u16 fc_gnnid_build(struct fchs_s *fchs, void *pyld, u32 s_id,
-                       u16 ox_id, u32 port_id);
-u16 fc_ct_rsp_parse(struct ct_hdr_s *cthdr);
-u16 fc_rscn_build(struct fchs_s *fchs, struct fc_rscn_pl_s *rscn,
-                       u32 s_id, u16 ox_id);
-#endif
diff --git a/drivers/scsi/bfa/fcpim.c b/drivers/scsi/bfa/fcpim.c
deleted file mode 100644 (file)
index 6b8976a..0000000
+++ /dev/null
@@ -1,824 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  fcpim.c - FCP initiator mode i-t nexus state machine
- */
-
-#include <bfa.h>
-#include <bfa_svc.h>
-#include "fcs_fcpim.h"
-#include "fcs_rport.h"
-#include "fcs_lport.h"
-#include "fcs_trcmod.h"
-#include "fcs_fcxp.h"
-#include "fcs.h"
-#include <fcs/bfa_fcs_fcpim.h>
-#include <fcb/bfa_fcb_fcpim.h>
-#include <aen/bfa_aen_itnim.h>
-
-BFA_TRC_FILE(FCS, FCPIM);
-
-/*
- * forward declarations
- */
-static void     bfa_fcs_itnim_timeout(void *arg);
-static void     bfa_fcs_itnim_free(struct bfa_fcs_itnim_s *itnim);
-static void     bfa_fcs_itnim_send_prli(void *itnim_cbarg,
-                                       struct bfa_fcxp_s *fcxp_alloced);
-static void     bfa_fcs_itnim_prli_response(void *fcsarg,
-                                           struct bfa_fcxp_s *fcxp,
-                                           void *cbarg,
-                                           bfa_status_t req_status,
-                                           u32 rsp_len,
-                                           u32 resid_len,
-                                           struct fchs_s *rsp_fchs);
-static void     bfa_fcs_itnim_aen_post(struct bfa_fcs_itnim_s *itnim,
-                                      enum bfa_itnim_aen_event event);
-
-/**
- *  fcs_itnim_sm FCS itnim state machine events
- */
-
-enum bfa_fcs_itnim_event {
-       BFA_FCS_ITNIM_SM_ONLINE = 1,    /*  rport online event */
-       BFA_FCS_ITNIM_SM_OFFLINE = 2,   /*  rport offline */
-       BFA_FCS_ITNIM_SM_FRMSENT = 3,   /*  prli frame is sent */
-       BFA_FCS_ITNIM_SM_RSP_OK = 4,    /*  good response */
-       BFA_FCS_ITNIM_SM_RSP_ERROR = 5, /*  error response */
-       BFA_FCS_ITNIM_SM_TIMEOUT = 6,   /*  delay timeout */
-       BFA_FCS_ITNIM_SM_HCB_OFFLINE = 7,       /*  BFA online callback */
-       BFA_FCS_ITNIM_SM_HCB_ONLINE = 8,        /*  BFA offline callback */
-       BFA_FCS_ITNIM_SM_INITIATOR = 9, /*  rport is initiator */
-       BFA_FCS_ITNIM_SM_DELETE = 10,   /*  delete event from rport */
-       BFA_FCS_ITNIM_SM_PRLO = 11,     /*  delete event from rport */
-};
-
-static void     bfa_fcs_itnim_sm_offline(struct bfa_fcs_itnim_s *itnim,
-                                        enum bfa_fcs_itnim_event event);
-static void     bfa_fcs_itnim_sm_prli_send(struct bfa_fcs_itnim_s *itnim,
-                                          enum bfa_fcs_itnim_event event);
-static void     bfa_fcs_itnim_sm_prli(struct bfa_fcs_itnim_s *itnim,
-                                     enum bfa_fcs_itnim_event event);
-static void     bfa_fcs_itnim_sm_prli_retry(struct bfa_fcs_itnim_s *itnim,
-                                           enum bfa_fcs_itnim_event event);
-static void     bfa_fcs_itnim_sm_hcb_online(struct bfa_fcs_itnim_s *itnim,
-                                           enum bfa_fcs_itnim_event event);
-static void     bfa_fcs_itnim_sm_online(struct bfa_fcs_itnim_s *itnim,
-                                       enum bfa_fcs_itnim_event event);
-static void     bfa_fcs_itnim_sm_hcb_offline(struct bfa_fcs_itnim_s *itnim,
-                                            enum bfa_fcs_itnim_event event);
-static void     bfa_fcs_itnim_sm_initiator(struct bfa_fcs_itnim_s *itnim,
-                                          enum bfa_fcs_itnim_event event);
-
-static struct bfa_sm_table_s itnim_sm_table[] = {
-       {BFA_SM(bfa_fcs_itnim_sm_offline), BFA_ITNIM_OFFLINE},
-       {BFA_SM(bfa_fcs_itnim_sm_prli_send), BFA_ITNIM_PRLI_SEND},
-       {BFA_SM(bfa_fcs_itnim_sm_prli), BFA_ITNIM_PRLI_SENT},
-       {BFA_SM(bfa_fcs_itnim_sm_prli_retry), BFA_ITNIM_PRLI_RETRY},
-       {BFA_SM(bfa_fcs_itnim_sm_hcb_online), BFA_ITNIM_HCB_ONLINE},
-       {BFA_SM(bfa_fcs_itnim_sm_online), BFA_ITNIM_ONLINE},
-       {BFA_SM(bfa_fcs_itnim_sm_hcb_offline), BFA_ITNIM_HCB_OFFLINE},
-       {BFA_SM(bfa_fcs_itnim_sm_initiator), BFA_ITNIM_INITIATIOR},
-};
-
-/**
- *  fcs_itnim_sm FCS itnim state machine
- */
-
-static void
-bfa_fcs_itnim_sm_offline(struct bfa_fcs_itnim_s *itnim,
-                        enum bfa_fcs_itnim_event event)
-{
-       bfa_trc(itnim->fcs, itnim->rport->pwwn);
-       bfa_trc(itnim->fcs, event);
-
-       switch (event) {
-       case BFA_FCS_ITNIM_SM_ONLINE:
-               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_prli_send);
-               itnim->prli_retries = 0;
-               bfa_fcs_itnim_send_prli(itnim, NULL);
-               break;
-
-       case BFA_FCS_ITNIM_SM_OFFLINE:
-               bfa_fcs_rport_itnim_ack(itnim->rport);
-               break;
-
-       case BFA_FCS_ITNIM_SM_INITIATOR:
-               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_initiator);
-               break;
-
-       case BFA_FCS_ITNIM_SM_DELETE:
-               bfa_fcs_itnim_free(itnim);
-               break;
-
-       default:
-               bfa_sm_fault(itnim->fcs, event);
-       }
-
-}
-
-static void
-bfa_fcs_itnim_sm_prli_send(struct bfa_fcs_itnim_s *itnim,
-                          enum bfa_fcs_itnim_event event)
-{
-       bfa_trc(itnim->fcs, itnim->rport->pwwn);
-       bfa_trc(itnim->fcs, event);
-
-       switch (event) {
-       case BFA_FCS_ITNIM_SM_FRMSENT:
-               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_prli);
-               break;
-
-       case BFA_FCS_ITNIM_SM_INITIATOR:
-               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_initiator);
-               bfa_fcxp_walloc_cancel(itnim->fcs->bfa, &itnim->fcxp_wqe);
-               break;
-
-       case BFA_FCS_ITNIM_SM_OFFLINE:
-               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_offline);
-               bfa_fcxp_walloc_cancel(itnim->fcs->bfa, &itnim->fcxp_wqe);
-               bfa_fcs_rport_itnim_ack(itnim->rport);
-               break;
-
-       case BFA_FCS_ITNIM_SM_DELETE:
-               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_offline);
-               bfa_fcxp_walloc_cancel(itnim->fcs->bfa, &itnim->fcxp_wqe);
-               bfa_fcs_itnim_free(itnim);
-               break;
-
-       default:
-               bfa_sm_fault(itnim->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_itnim_sm_prli(struct bfa_fcs_itnim_s *itnim,
-                     enum bfa_fcs_itnim_event event)
-{
-       bfa_trc(itnim->fcs, itnim->rport->pwwn);
-       bfa_trc(itnim->fcs, event);
-
-       switch (event) {
-       case BFA_FCS_ITNIM_SM_RSP_OK:
-               if (itnim->rport->scsi_function == BFA_RPORT_INITIATOR) {
-                       bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_initiator);
-               } else {
-                       bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_hcb_online);
-                       bfa_itnim_online(itnim->bfa_itnim, itnim->seq_rec);
-               }
-               break;
-
-       case BFA_FCS_ITNIM_SM_RSP_ERROR:
-               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_prli_retry);
-               bfa_timer_start(itnim->fcs->bfa, &itnim->timer,
-                               bfa_fcs_itnim_timeout, itnim,
-                               BFA_FCS_RETRY_TIMEOUT);
-               break;
-
-       case BFA_FCS_ITNIM_SM_OFFLINE:
-               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_offline);
-               bfa_fcxp_discard(itnim->fcxp);
-               bfa_fcs_rport_itnim_ack(itnim->rport);
-               break;
-
-       case BFA_FCS_ITNIM_SM_INITIATOR:
-               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_initiator);
-               bfa_fcxp_discard(itnim->fcxp);
-               break;
-
-       case BFA_FCS_ITNIM_SM_DELETE:
-               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_offline);
-               bfa_fcxp_discard(itnim->fcxp);
-               bfa_fcs_itnim_free(itnim);
-               break;
-
-       default:
-               bfa_sm_fault(itnim->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_itnim_sm_prli_retry(struct bfa_fcs_itnim_s *itnim,
-                           enum bfa_fcs_itnim_event event)
-{
-       bfa_trc(itnim->fcs, itnim->rport->pwwn);
-       bfa_trc(itnim->fcs, event);
-
-       switch (event) {
-       case BFA_FCS_ITNIM_SM_TIMEOUT:
-               if (itnim->prli_retries < BFA_FCS_RPORT_MAX_RETRIES) {
-                       itnim->prli_retries++;
-                       bfa_trc(itnim->fcs, itnim->prli_retries);
-                       bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_prli_send);
-                       bfa_fcs_itnim_send_prli(itnim, NULL);
-               } else {
-                       /* invoke target offline */
-                       bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_offline);
-                       bfa_fcs_rport_logo_imp(itnim->rport);
-               }
-               break;
-
-       case BFA_FCS_ITNIM_SM_OFFLINE:
-               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_offline);
-               bfa_timer_stop(&itnim->timer);
-               bfa_fcs_rport_itnim_ack(itnim->rport);
-               break;
-
-       case BFA_FCS_ITNIM_SM_INITIATOR:
-               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_initiator);
-               bfa_timer_stop(&itnim->timer);
-               break;
-
-       case BFA_FCS_ITNIM_SM_DELETE:
-               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_offline);
-               bfa_timer_stop(&itnim->timer);
-               bfa_fcs_itnim_free(itnim);
-               break;
-
-       default:
-               bfa_sm_fault(itnim->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_itnim_sm_hcb_online(struct bfa_fcs_itnim_s *itnim,
-                           enum bfa_fcs_itnim_event event)
-{
-       bfa_trc(itnim->fcs, itnim->rport->pwwn);
-       bfa_trc(itnim->fcs, event);
-
-       switch (event) {
-       case BFA_FCS_ITNIM_SM_HCB_ONLINE:
-               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_online);
-               bfa_fcb_itnim_online(itnim->itnim_drv);
-               bfa_fcs_itnim_aen_post(itnim, BFA_ITNIM_AEN_ONLINE);
-               break;
-
-       case BFA_FCS_ITNIM_SM_OFFLINE:
-               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_offline);
-               bfa_itnim_offline(itnim->bfa_itnim);
-               bfa_fcs_rport_itnim_ack(itnim->rport);
-               break;
-
-       case BFA_FCS_ITNIM_SM_DELETE:
-               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_offline);
-               bfa_fcs_itnim_free(itnim);
-               break;
-
-       default:
-               bfa_sm_fault(itnim->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_itnim_sm_online(struct bfa_fcs_itnim_s *itnim,
-                       enum bfa_fcs_itnim_event event)
-{
-       bfa_trc(itnim->fcs, itnim->rport->pwwn);
-       bfa_trc(itnim->fcs, event);
-
-       switch (event) {
-       case BFA_FCS_ITNIM_SM_OFFLINE:
-               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_hcb_offline);
-               bfa_fcb_itnim_offline(itnim->itnim_drv);
-               bfa_itnim_offline(itnim->bfa_itnim);
-               if (bfa_fcs_port_is_online(itnim->rport->port) == BFA_TRUE)
-                       bfa_fcs_itnim_aen_post(itnim, BFA_ITNIM_AEN_DISCONNECT);
-               else
-                       bfa_fcs_itnim_aen_post(itnim, BFA_ITNIM_AEN_OFFLINE);
-               break;
-
-       case BFA_FCS_ITNIM_SM_DELETE:
-               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_offline);
-               bfa_fcs_itnim_free(itnim);
-               break;
-
-       default:
-               bfa_sm_fault(itnim->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_itnim_sm_hcb_offline(struct bfa_fcs_itnim_s *itnim,
-                            enum bfa_fcs_itnim_event event)
-{
-       bfa_trc(itnim->fcs, itnim->rport->pwwn);
-       bfa_trc(itnim->fcs, event);
-
-       switch (event) {
-       case BFA_FCS_ITNIM_SM_HCB_OFFLINE:
-               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_offline);
-               bfa_fcs_rport_itnim_ack(itnim->rport);
-               break;
-
-       case BFA_FCS_ITNIM_SM_DELETE:
-               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_offline);
-               bfa_fcs_itnim_free(itnim);
-               break;
-
-       default:
-               bfa_sm_fault(itnim->fcs, event);
-       }
-}
-
-/*
- * This state is set when a discovered rport is also in intiator mode.
- * This ITN is marked as no_op and is not active and will not be truned into
- * online state.
- */
-static void
-bfa_fcs_itnim_sm_initiator(struct bfa_fcs_itnim_s *itnim,
-                          enum bfa_fcs_itnim_event event)
-{
-       bfa_trc(itnim->fcs, itnim->rport->pwwn);
-       bfa_trc(itnim->fcs, event);
-
-       switch (event) {
-       case BFA_FCS_ITNIM_SM_OFFLINE:
-               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_offline);
-               bfa_fcs_rport_itnim_ack(itnim->rport);
-               break;
-
-       case BFA_FCS_ITNIM_SM_RSP_ERROR:
-       case BFA_FCS_ITNIM_SM_ONLINE:
-       case BFA_FCS_ITNIM_SM_INITIATOR:
-               break;
-
-       case BFA_FCS_ITNIM_SM_DELETE:
-               bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_offline);
-               bfa_fcs_itnim_free(itnim);
-               break;
-
-       default:
-               bfa_sm_fault(itnim->fcs, event);
-       }
-}
-
-
-
-/**
- *  itnim_private FCS ITNIM private interfaces
- */
-
-static void
-bfa_fcs_itnim_aen_post(struct bfa_fcs_itnim_s *itnim,
-                      enum bfa_itnim_aen_event event)
-{
-       struct bfa_fcs_rport_s *rport = itnim->rport;
-       union bfa_aen_data_u aen_data;
-       struct bfa_log_mod_s *logmod = rport->fcs->logm;
-       wwn_t           lpwwn = bfa_fcs_port_get_pwwn(rport->port);
-       wwn_t           rpwwn = rport->pwwn;
-       char            lpwwn_ptr[BFA_STRING_32];
-       char            rpwwn_ptr[BFA_STRING_32];
-
-       /*
-        * Don't post events for well known addresses
-        */
-       if (BFA_FCS_PID_IS_WKA(rport->pid))
-               return;
-
-       wwn2str(lpwwn_ptr, lpwwn);
-       wwn2str(rpwwn_ptr, rpwwn);
-
-       bfa_log(logmod, BFA_LOG_CREATE_ID(BFA_AEN_CAT_ITNIM, event),
-               rpwwn_ptr, lpwwn_ptr);
-
-       aen_data.itnim.vf_id = rport->port->fabric->vf_id;
-       aen_data.itnim.ppwwn =
-               bfa_fcs_port_get_pwwn(bfa_fcs_get_base_port(itnim->fcs));
-       aen_data.itnim.lpwwn = lpwwn;
-       aen_data.itnim.rpwwn = rpwwn;
-}
-
-static void
-bfa_fcs_itnim_send_prli(void *itnim_cbarg, struct bfa_fcxp_s *fcxp_alloced)
-{
-       struct bfa_fcs_itnim_s *itnim = itnim_cbarg;
-       struct bfa_fcs_rport_s *rport = itnim->rport;
-       struct bfa_fcs_port_s *port = rport->port;
-       struct fchs_s          fchs;
-       struct bfa_fcxp_s *fcxp;
-       int             len;
-
-       bfa_trc(itnim->fcs, itnim->rport->pwwn);
-
-       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
-       if (!fcxp) {
-               itnim->stats.fcxp_alloc_wait++;
-               bfa_fcxp_alloc_wait(port->fcs->bfa, &itnim->fcxp_wqe,
-                                   bfa_fcs_itnim_send_prli, itnim);
-               return;
-       }
-       itnim->fcxp = fcxp;
-
-       len = fc_prli_build(&fchs, bfa_fcxp_get_reqbuf(fcxp), itnim->rport->pid,
-                           bfa_fcs_port_get_fcid(port), 0);
-
-       bfa_fcxp_send(fcxp, rport->bfa_rport, port->fabric->vf_id, port->lp_tag,
-                     BFA_FALSE, FC_CLASS_3, len, &fchs,
-                     bfa_fcs_itnim_prli_response, (void *)itnim, FC_MAX_PDUSZ,
-                     FC_ELS_TOV);
-
-       itnim->stats.prli_sent++;
-       bfa_sm_send_event(itnim, BFA_FCS_ITNIM_SM_FRMSENT);
-}
-
-static void
-bfa_fcs_itnim_prli_response(void *fcsarg, struct bfa_fcxp_s *fcxp, void *cbarg,
-                           bfa_status_t req_status, u32 rsp_len,
-                           u32 resid_len, struct fchs_s *rsp_fchs)
-{
-       struct bfa_fcs_itnim_s *itnim = (struct bfa_fcs_itnim_s *)cbarg;
-       struct fc_els_cmd_s   *els_cmd;
-       struct fc_prli_s      *prli_resp;
-       struct fc_ls_rjt_s    *ls_rjt;
-       struct fc_prli_params_s *sparams;
-
-       bfa_trc(itnim->fcs, req_status);
-
-       /*
-        * Sanity Checks
-        */
-       if (req_status != BFA_STATUS_OK) {
-               itnim->stats.prli_rsp_err++;
-               bfa_sm_send_event(itnim, BFA_FCS_ITNIM_SM_RSP_ERROR);
-               return;
-       }
-
-       els_cmd = (struct fc_els_cmd_s *) BFA_FCXP_RSP_PLD(fcxp);
-
-       if (els_cmd->els_code == FC_ELS_ACC) {
-               prli_resp = (struct fc_prli_s *) els_cmd;
-
-               if (fc_prli_rsp_parse(prli_resp, rsp_len) != FC_PARSE_OK) {
-                       bfa_trc(itnim->fcs, rsp_len);
-                       /*
-                        * Check if this  r-port is also in Initiator mode.
-                        * If so, we need to set this ITN as a no-op.
-                        */
-                       if (prli_resp->parampage.servparams.initiator) {
-                               bfa_trc(itnim->fcs, prli_resp->parampage.type);
-                               itnim->rport->scsi_function =
-                                       BFA_RPORT_INITIATOR;
-                               itnim->stats.prli_rsp_acc++;
-                               bfa_sm_send_event(itnim,
-                                                 BFA_FCS_ITNIM_SM_RSP_OK);
-                               return;
-                       }
-
-                       itnim->stats.prli_rsp_parse_err++;
-                       return;
-               }
-               itnim->rport->scsi_function = BFA_RPORT_TARGET;
-
-               sparams = &prli_resp->parampage.servparams;
-               itnim->seq_rec = sparams->retry;
-               itnim->rec_support = sparams->rec_support;
-               itnim->task_retry_id = sparams->task_retry_id;
-               itnim->conf_comp = sparams->confirm;
-
-               itnim->stats.prli_rsp_acc++;
-               bfa_sm_send_event(itnim, BFA_FCS_ITNIM_SM_RSP_OK);
-       } else {
-               ls_rjt = (struct fc_ls_rjt_s *) BFA_FCXP_RSP_PLD(fcxp);
-
-               bfa_trc(itnim->fcs, ls_rjt->reason_code);
-               bfa_trc(itnim->fcs, ls_rjt->reason_code_expl);
-
-               itnim->stats.prli_rsp_rjt++;
-               bfa_sm_send_event(itnim, BFA_FCS_ITNIM_SM_RSP_ERROR);
-       }
-}
-
-static void
-bfa_fcs_itnim_timeout(void *arg)
-{
-       struct bfa_fcs_itnim_s *itnim = (struct bfa_fcs_itnim_s *)arg;
-
-       itnim->stats.timeout++;
-       bfa_sm_send_event(itnim, BFA_FCS_ITNIM_SM_TIMEOUT);
-}
-
-static void
-bfa_fcs_itnim_free(struct bfa_fcs_itnim_s *itnim)
-{
-       bfa_itnim_delete(itnim->bfa_itnim);
-       bfa_fcb_itnim_free(itnim->fcs->bfad, itnim->itnim_drv);
-}
-
-
-
-/**
- *  itnim_public FCS ITNIM public interfaces
- */
-
-/**
- *     Called by rport when a new rport is created.
- *
- * @param[in] rport    -  remote port.
- */
-struct bfa_fcs_itnim_s *
-bfa_fcs_itnim_create(struct bfa_fcs_rport_s *rport)
-{
-       struct bfa_fcs_port_s *port = rport->port;
-       struct bfa_fcs_itnim_s *itnim;
-       struct bfad_itnim_s *itnim_drv;
-       struct bfa_itnim_s *bfa_itnim;
-
-       /*
-        * call bfad to allocate the itnim
-        */
-       bfa_fcb_itnim_alloc(port->fcs->bfad, &itnim, &itnim_drv);
-       if (itnim == NULL) {
-               bfa_trc(port->fcs, rport->pwwn);
-               return NULL;
-       }
-
-       /*
-        * Initialize itnim
-        */
-       itnim->rport = rport;
-       itnim->fcs = rport->fcs;
-       itnim->itnim_drv = itnim_drv;
-
-       /*
-        * call BFA to create the itnim
-        */
-       bfa_itnim = bfa_itnim_create(port->fcs->bfa, rport->bfa_rport, itnim);
-
-       if (bfa_itnim == NULL) {
-               bfa_trc(port->fcs, rport->pwwn);
-               bfa_fcb_itnim_free(port->fcs->bfad, itnim_drv);
-               bfa_assert(0);
-               return NULL;
-       }
-
-       itnim->bfa_itnim = bfa_itnim;
-       itnim->seq_rec = BFA_FALSE;
-       itnim->rec_support = BFA_FALSE;
-       itnim->conf_comp = BFA_FALSE;
-       itnim->task_retry_id = BFA_FALSE;
-
-       /*
-        * Set State machine
-        */
-       bfa_sm_set_state(itnim, bfa_fcs_itnim_sm_offline);
-
-       return itnim;
-}
-
-/**
- *     Called by rport to delete  the instance of FCPIM.
- *
- * @param[in] rport    -  remote port.
- */
-void
-bfa_fcs_itnim_delete(struct bfa_fcs_itnim_s *itnim)
-{
-       bfa_trc(itnim->fcs, itnim->rport->pid);
-       bfa_sm_send_event(itnim, BFA_FCS_ITNIM_SM_DELETE);
-}
-
-/**
- * Notification from rport that PLOGI is complete to initiate FC-4 session.
- */
-void
-bfa_fcs_itnim_rport_online(struct bfa_fcs_itnim_s *itnim)
-{
-       itnim->stats.onlines++;
-
-       if (!BFA_FCS_PID_IS_WKA(itnim->rport->pid)) {
-               bfa_sm_send_event(itnim, BFA_FCS_ITNIM_SM_ONLINE);
-       } else {
-               /*
-                * For well known addresses, we set the itnim to initiator
-                * state
-                */
-               itnim->stats.initiator++;
-               bfa_sm_send_event(itnim, BFA_FCS_ITNIM_SM_INITIATOR);
-       }
-}
-
-/**
- * Called by rport to handle a remote device offline.
- */
-void
-bfa_fcs_itnim_rport_offline(struct bfa_fcs_itnim_s *itnim)
-{
-       itnim->stats.offlines++;
-       bfa_sm_send_event(itnim, BFA_FCS_ITNIM_SM_OFFLINE);
-}
-
-/**
- * Called by rport when remote port is known to be an initiator from
- * PRLI received.
- */
-void
-bfa_fcs_itnim_is_initiator(struct bfa_fcs_itnim_s *itnim)
-{
-       bfa_trc(itnim->fcs, itnim->rport->pid);
-       itnim->stats.initiator++;
-       bfa_sm_send_event(itnim, BFA_FCS_ITNIM_SM_INITIATOR);
-}
-
-/**
- * Called by rport to check if the itnim is online.
- */
-bfa_status_t
-bfa_fcs_itnim_get_online_state(struct bfa_fcs_itnim_s *itnim)
-{
-       bfa_trc(itnim->fcs, itnim->rport->pid);
-       switch (bfa_sm_to_state(itnim_sm_table, itnim->sm)) {
-       case BFA_ITNIM_ONLINE:
-       case BFA_ITNIM_INITIATIOR:
-               return BFA_STATUS_OK;
-
-       default:
-               return BFA_STATUS_NO_FCPIM_NEXUS;
-
-       }
-}
-
-/**
- * BFA completion callback for bfa_itnim_online().
- */
-void
-bfa_cb_itnim_online(void *cbarg)
-{
-       struct bfa_fcs_itnim_s *itnim = (struct bfa_fcs_itnim_s *)cbarg;
-
-       bfa_trc(itnim->fcs, itnim->rport->pwwn);
-       bfa_sm_send_event(itnim, BFA_FCS_ITNIM_SM_HCB_ONLINE);
-}
-
-/**
- * BFA completion callback for bfa_itnim_offline().
- */
-void
-bfa_cb_itnim_offline(void *cb_arg)
-{
-       struct bfa_fcs_itnim_s *itnim = (struct bfa_fcs_itnim_s *)cb_arg;
-
-       bfa_trc(itnim->fcs, itnim->rport->pwwn);
-       bfa_sm_send_event(itnim, BFA_FCS_ITNIM_SM_HCB_OFFLINE);
-}
-
-/**
- * Mark the beginning of PATH TOV handling. IO completion callbacks
- * are still pending.
- */
-void
-bfa_cb_itnim_tov_begin(void *cb_arg)
-{
-       struct bfa_fcs_itnim_s *itnim = (struct bfa_fcs_itnim_s *)cb_arg;
-
-       bfa_trc(itnim->fcs, itnim->rport->pwwn);
-}
-
-/**
- * Mark the end of PATH TOV handling. All pending IOs are already cleaned up.
- */
-void
-bfa_cb_itnim_tov(void *cb_arg)
-{
-       struct bfa_fcs_itnim_s *itnim = (struct bfa_fcs_itnim_s *)cb_arg;
-
-       bfa_trc(itnim->fcs, itnim->rport->pwwn);
-       bfa_fcb_itnim_tov(itnim->itnim_drv);
-}
-
-/**
- *             BFA notification to FCS/driver for second level error recovery.
- *
- * Atleast one I/O request has timedout and target is unresponsive to
- * repeated abort requests. Second level error recovery should be initiated
- * by starting implicit logout and recovery procedures.
- */
-void
-bfa_cb_itnim_sler(void *cb_arg)
-{
-       struct bfa_fcs_itnim_s *itnim = (struct bfa_fcs_itnim_s *)cb_arg;
-
-       itnim->stats.sler++;
-       bfa_trc(itnim->fcs, itnim->rport->pwwn);
-       bfa_fcs_rport_logo_imp(itnim->rport);
-}
-
-struct bfa_fcs_itnim_s *
-bfa_fcs_itnim_lookup(struct bfa_fcs_port_s *port, wwn_t rpwwn)
-{
-       struct bfa_fcs_rport_s *rport;
-       rport = bfa_fcs_rport_lookup(port, rpwwn);
-
-       if (!rport)
-               return NULL;
-
-       bfa_assert(rport->itnim != NULL);
-       return rport->itnim;
-}
-
-bfa_status_t
-bfa_fcs_itnim_attr_get(struct bfa_fcs_port_s *port, wwn_t rpwwn,
-                      struct bfa_itnim_attr_s *attr)
-{
-       struct bfa_fcs_itnim_s *itnim = NULL;
-
-       itnim = bfa_fcs_itnim_lookup(port, rpwwn);
-
-       if (itnim == NULL)
-               return BFA_STATUS_NO_FCPIM_NEXUS;
-
-       attr->state = bfa_sm_to_state(itnim_sm_table, itnim->sm);
-       attr->retry = itnim->seq_rec;
-       attr->rec_support = itnim->rec_support;
-       attr->conf_comp = itnim->conf_comp;
-       attr->task_retry_id = itnim->task_retry_id;
-       bfa_os_memset(&attr->io_latency, 0, sizeof(struct bfa_itnim_latency_s));
-
-       return BFA_STATUS_OK;
-}
-
-bfa_status_t
-bfa_fcs_itnim_stats_get(struct bfa_fcs_port_s *port, wwn_t rpwwn,
-                       struct bfa_itnim_stats_s *stats)
-{
-       struct bfa_fcs_itnim_s *itnim = NULL;
-
-       bfa_assert(port != NULL);
-
-       itnim = bfa_fcs_itnim_lookup(port, rpwwn);
-
-       if (itnim == NULL)
-               return BFA_STATUS_NO_FCPIM_NEXUS;
-
-       bfa_os_memcpy(stats, &itnim->stats, sizeof(struct bfa_itnim_stats_s));
-
-       return BFA_STATUS_OK;
-}
-
-bfa_status_t
-bfa_fcs_itnim_stats_clear(struct bfa_fcs_port_s *port, wwn_t rpwwn)
-{
-       struct bfa_fcs_itnim_s *itnim = NULL;
-
-       bfa_assert(port != NULL);
-
-       itnim = bfa_fcs_itnim_lookup(port, rpwwn);
-
-       if (itnim == NULL)
-               return BFA_STATUS_NO_FCPIM_NEXUS;
-
-       bfa_os_memset(&itnim->stats, 0, sizeof(struct bfa_itnim_stats_s));
-       return BFA_STATUS_OK;
-}
-
-void
-bfa_fcs_fcpim_uf_recv(struct bfa_fcs_itnim_s *itnim, struct fchs_s *fchs,
-                     u16 len)
-{
-       struct fc_els_cmd_s   *els_cmd;
-
-       bfa_trc(itnim->fcs, fchs->type);
-
-       if (fchs->type != FC_TYPE_ELS)
-               return;
-
-       els_cmd = (struct fc_els_cmd_s *) (fchs + 1);
-
-       bfa_trc(itnim->fcs, els_cmd->els_code);
-
-       switch (els_cmd->els_code) {
-       case FC_ELS_PRLO:
-               bfa_fcs_rport_prlo(itnim->rport, fchs->ox_id);
-               break;
-
-       default:
-               bfa_assert(0);
-       }
-}
-
-void
-bfa_fcs_itnim_pause(struct bfa_fcs_itnim_s *itnim)
-{
-}
-
-void
-bfa_fcs_itnim_resume(struct bfa_fcs_itnim_s *itnim)
-{
-}
diff --git a/drivers/scsi/bfa/fcptm.c b/drivers/scsi/bfa/fcptm.c
deleted file mode 100644 (file)
index 8c8b08c..0000000
+++ /dev/null
@@ -1,68 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- * This file contains dummy FCPTM routines to aid in Initiator Mode only
- * compilation of OS driver.
- *
- */
-
-#include "bfa_os_inc.h"
-#include "fcs_rport.h"
-#include "fcs_fcptm.h"
-#include "fcs/bfa_fcs_rport.h"
-
-struct bfa_fcs_tin_s *
-bfa_fcs_tin_create(struct bfa_fcs_rport_s *rport)
-{
-       return NULL;
-}
-
-void
-bfa_fcs_tin_delete(struct bfa_fcs_tin_s *tin)
-{
-}
-
-void
-bfa_fcs_tin_rport_offline(struct bfa_fcs_tin_s *tin)
-{
-}
-
-void
-bfa_fcs_tin_rport_online(struct bfa_fcs_tin_s *tin)
-{
-}
-
-void
-bfa_fcs_tin_rx_prli(struct bfa_fcs_tin_s *tin, struct fchs_s *fchs, u16 len)
-{
-}
-
-void
-bfa_fcs_fcptm_uf_recv(struct bfa_fcs_tin_s *tin, struct fchs_s *fchs, u16 len)
-{
-}
-
-void
-bfa_fcs_tin_pause(struct bfa_fcs_tin_s *tin)
-{
-}
-
-void
-bfa_fcs_tin_resume(struct bfa_fcs_tin_s *tin)
-{
-}
diff --git a/drivers/scsi/bfa/fcs.h b/drivers/scsi/bfa/fcs.h
deleted file mode 100644 (file)
index 8d08230..0000000
+++ /dev/null
@@ -1,30 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  fcs.h FCS module functions
- */
-
-
-#ifndef __FCS_H__
-#define __FCS_H__
-
-#define __fcs_min_cfg(__fcs)       ((__fcs)->min_cfg)
-
-void bfa_fcs_modexit_comp(struct bfa_fcs_s *fcs);
-
-#endif /* __FCS_H__ */
diff --git a/drivers/scsi/bfa/fcs_auth.h b/drivers/scsi/bfa/fcs_auth.h
deleted file mode 100644 (file)
index 65d155f..0000000
+++ /dev/null
@@ -1,37 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  fcs_uf.h FCS unsolicited frame receive
- */
-
-
-#ifndef __FCS_AUTH_H__
-#define __FCS_AUTH_H__
-
-#include <fcs/bfa_fcs.h>
-#include <fcs/bfa_fcs_vport.h>
-#include <fcs/bfa_fcs_lport.h>
-
-/*
- * fcs friend functions: only between fcs modules
- */
-void bfa_fcs_auth_uf_recv(struct bfa_fcs_fabric_s *fabric, int len);
-void bfa_fcs_auth_start(struct bfa_fcs_fabric_s *fabric);
-void bfa_fcs_auth_stop(struct bfa_fcs_fabric_s *fabric);
-
-#endif /* __FCS_UF_H__ */
diff --git a/drivers/scsi/bfa/fcs_fabric.h b/drivers/scsi/bfa/fcs_fabric.h
deleted file mode 100644 (file)
index 432ab8a..0000000
+++ /dev/null
@@ -1,68 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  fcs_lport.h FCS logical port interfaces
- */
-
-#ifndef __FCS_FABRIC_H__
-#define __FCS_FABRIC_H__
-
-#include <fcs/bfa_fcs.h>
-#include <fcs/bfa_fcs_vport.h>
-#include <fcs/bfa_fcs_lport.h>
-
-#define BFA_FCS_BRCD_SWITCH_OUI  0x051e
-
-/*
-* fcs friend functions: only between fcs modules
- */
-void           bfa_fcs_fabric_attach(struct bfa_fcs_s *fcs);
-void            bfa_fcs_fabric_modinit(struct bfa_fcs_s *fcs);
-void            bfa_fcs_fabric_modexit(struct bfa_fcs_s *fcs);
-void            bfa_fcs_fabric_modsusp(struct bfa_fcs_s *fcs);
-void            bfa_fcs_fabric_link_up(struct bfa_fcs_fabric_s *fabric);
-void            bfa_fcs_fabric_link_down(struct bfa_fcs_fabric_s *fabric);
-void            bfa_fcs_fabric_addvport(struct bfa_fcs_fabric_s *fabric,
-                                       struct bfa_fcs_vport_s *vport);
-void            bfa_fcs_fabric_delvport(struct bfa_fcs_fabric_s *fabric,
-                                       struct bfa_fcs_vport_s *vport);
-int             bfa_fcs_fabric_is_online(struct bfa_fcs_fabric_s *fabric);
-struct bfa_fcs_vport_s *bfa_fcs_fabric_vport_lookup(
-                       struct bfa_fcs_fabric_s *fabric, wwn_t pwwn);
-void            bfa_fcs_fabric_modstart(struct bfa_fcs_s *fcs);
-void            bfa_fcs_fabric_uf_recv(struct bfa_fcs_fabric_s *fabric,
-                       struct fchs_s *fchs, u16 len);
-u16        bfa_fcs_fabric_vport_count(struct bfa_fcs_fabric_s *fabric);
-bfa_boolean_t   bfa_fcs_fabric_is_loopback(struct bfa_fcs_fabric_s *fabric);
-bfa_boolean_t  bfa_fcs_fabric_is_auth_failed(struct bfa_fcs_fabric_s *fabric);
-enum bfa_pport_type bfa_fcs_fabric_port_type(struct bfa_fcs_fabric_s *fabric);
-void           bfa_fcs_fabric_psymb_init(struct bfa_fcs_fabric_s *fabric);
-void bfa_fcs_fabric_port_delete_comp(struct bfa_fcs_fabric_s *fabric);
-
-bfa_status_t bfa_fcs_fabric_addvf(struct bfa_fcs_fabric_s *vf,
-                       struct bfa_fcs_s *fcs, struct bfa_port_cfg_s *port_cfg,
-                       struct bfad_vf_s *vf_drv);
-void bfa_fcs_auth_finished(struct bfa_fcs_fabric_s *fabric,
-                       enum auth_status status);
-
-void bfa_fcs_fabric_set_fabric_name(struct bfa_fcs_fabric_s *fabric,
-                       wwn_t fabric_name);
-u16 bfa_fcs_fabric_get_switch_oui(struct bfa_fcs_fabric_s *fabric);
-void bfa_fcs_get_sym_name(const struct bfa_fcs_s *fcs, char *node_symname);
-
-#endif /* __FCS_FABRIC_H__ */
diff --git a/drivers/scsi/bfa/fcs_fcpim.h b/drivers/scsi/bfa/fcs_fcpim.h
deleted file mode 100644 (file)
index 11e6e7b..0000000
+++ /dev/null
@@ -1,39 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-#ifndef __FCS_FCPIM_H__
-#define __FCS_FCPIM_H__
-
-#include <defs/bfa_defs_port.h>
-#include <fcs/bfa_fcs_lport.h>
-#include <fcs/bfa_fcs_rport.h>
-
-/*
- * Following routines are from FCPIM and will be called by rport.
- */
-struct bfa_fcs_itnim_s *bfa_fcs_itnim_create(struct bfa_fcs_rport_s *rport);
-void bfa_fcs_itnim_delete(struct bfa_fcs_itnim_s *itnim);
-void bfa_fcs_itnim_rport_offline(struct bfa_fcs_itnim_s *itnim);
-void bfa_fcs_itnim_rport_online(struct bfa_fcs_itnim_s *itnim);
-bfa_status_t bfa_fcs_itnim_get_online_state(struct bfa_fcs_itnim_s *itnim);
-
-void bfa_fcs_itnim_is_initiator(struct bfa_fcs_itnim_s *itnim);
-void bfa_fcs_itnim_pause(struct bfa_fcs_itnim_s *itnim);
-void bfa_fcs_itnim_resume(struct bfa_fcs_itnim_s *itnim);
-
-void bfa_fcs_fcpim_uf_recv(struct bfa_fcs_itnim_s *itnim, struct fchs_s *fchs,
-                       u16 len);
-#endif /* __FCS_FCPIM_H__ */
diff --git a/drivers/scsi/bfa/fcs_fcptm.h b/drivers/scsi/bfa/fcs_fcptm.h
deleted file mode 100644 (file)
index ffff082..0000000
+++ /dev/null
@@ -1,45 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __FCS_FCPTM_H__
-#define __FCS_FCPTM_H__
-
-#include <defs/bfa_defs_port.h>
-#include <fcs/bfa_fcs_lport.h>
-#include <fcs/bfa_fcs_rport.h>
-
-/*
- * Following routines are from FCPTM and will be called by rport.
- */
-struct bfa_fcs_tin_s *bfa_fcs_tin_create(struct bfa_fcs_rport_s *rport);
-void bfa_fcs_tin_rport_offline(struct bfa_fcs_tin_s *tin);
-void bfa_fcs_tin_rport_online(struct bfa_fcs_tin_s *tin);
-void bfa_fcs_tin_delete(struct bfa_fcs_tin_s *tin);
-void bfa_fcs_tin_rx_prli(struct bfa_fcs_tin_s *tin, struct fchs_s *fchs,
-                       u16 len);
-void bfa_fcs_tin_pause(struct bfa_fcs_tin_s *tin);
-void bfa_fcs_tin_resume(struct bfa_fcs_tin_s *tin);
-
-/*
- * Modudle init/cleanup routines.
- */
-void bfa_fcs_fcptm_modinit(struct bfa_fcs_s *fcs);
-void bfa_fcs_fcptm_modexit(struct bfa_fcs_s *fcs);
-void bfa_fcs_fcptm_uf_recv(struct bfa_fcs_tin_s *tin, struct fchs_s *fchs,
-                       u16 len);
-
-#endif /* __FCS_FCPTM_H__ */
diff --git a/drivers/scsi/bfa/fcs_fcxp.h b/drivers/scsi/bfa/fcs_fcxp.h
deleted file mode 100644 (file)
index 8277fe9..0000000
+++ /dev/null
@@ -1,29 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  fcs_fcxp.h FCXP helper macros for FCS
- */
-
-
-#ifndef __FCS_FCXP_H__
-#define __FCS_FCXP_H__
-
-#define bfa_fcs_fcxp_alloc(__fcs)      \
-       bfa_fcxp_alloc(NULL, (__fcs)->bfa, 0, 0, NULL, NULL, NULL, NULL)
-
-#endif /* __FCS_FCXP_H__ */
diff --git a/drivers/scsi/bfa/fcs_lport.h b/drivers/scsi/bfa/fcs_lport.h
deleted file mode 100644 (file)
index a6508c8..0000000
+++ /dev/null
@@ -1,118 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  fcs_lport.h FCS logical port interfaces
- */
-
-#ifndef __FCS_LPORT_H__
-#define __FCS_LPORT_H__
-
-#define __VPORT_H__
-#include <defs/bfa_defs_port.h>
-#include <bfa_svc.h>
-#include <fcs/bfa_fcs_lport.h>
-#include <fcs/bfa_fcs_rport.h>
-#include <fcs/bfa_fcs_vport.h>
-#include <fcs_fabric.h>
-#include <fcs_ms.h>
-#include <cs/bfa_q.h>
-#include <fcbuild.h>
-
-/*
- * PID used in P2P/N2N ( In Big Endian)
- */
-#define N2N_LOCAL_PID      0x010000
-#define N2N_REMOTE_PID         0x020000
-
-/*
- * Misc Timeouts
- */
-/*
- * To be used when spawning a timer before retrying a failed command. Milli
- * Secs.
- */
-#define        BFA_FCS_RETRY_TIMEOUT 2000
-
-/*
- * Check for Port/Vport Mode/Role
- */
-#define        BFA_FCS_VPORT_IS_INITIATOR_MODE(port) \
-               (port->port_cfg.roles & BFA_PORT_ROLE_FCP_IM)
-
-#define        BFA_FCS_VPORT_IS_TARGET_MODE(port) \
-               (port->port_cfg.roles & BFA_PORT_ROLE_FCP_TM)
-
-#define        BFA_FCS_VPORT_IS_IPFC_MODE(port) \
-               (port->port_cfg.roles & BFA_PORT_ROLE_FCP_IPFC)
-
-/*
- * Is this a Well Known Address
- */
-#define BFA_FCS_PID_IS_WKA(pid)  ((bfa_os_ntoh3b(pid) > 0xFFF000) ?  1 : 0)
-
-/*
- * Pointer to elements within Port
- */
-#define BFA_FCS_GET_HAL_FROM_PORT(port)  (port->fcs->bfa)
-#define BFA_FCS_GET_NS_FROM_PORT(port)  (&port->port_topo.pfab.ns)
-#define BFA_FCS_GET_SCN_FROM_PORT(port)  (&port->port_topo.pfab.scn)
-#define BFA_FCS_GET_MS_FROM_PORT(port)  (&port->port_topo.pfab.ms)
-#define BFA_FCS_GET_FDMI_FROM_PORT(port)  (&port->port_topo.pfab.ms.fdmi)
-
-/*
- * handler for unsolicied frames
- */
-void bfa_fcs_port_uf_recv(struct bfa_fcs_port_s *lport, struct fchs_s *fchs,
-                       u16 len);
-
-/*
- * Following routines will be called by Fabric to indicate port
- * online/offline to vport.
- */
-void bfa_fcs_lport_attach(struct bfa_fcs_port_s *lport, struct bfa_fcs_s *fcs,
-                       uint16_t vf_id, struct bfa_fcs_vport_s *vport);
-void bfa_fcs_lport_init(struct bfa_fcs_port_s *lport,
-                       struct bfa_port_cfg_s *port_cfg);
-void bfa_fcs_port_online(struct bfa_fcs_port_s *port);
-void bfa_fcs_port_offline(struct bfa_fcs_port_s *port);
-void bfa_fcs_port_delete(struct bfa_fcs_port_s *port);
-bfa_boolean_t   bfa_fcs_port_is_online(struct bfa_fcs_port_s *port);
-
-/*
- * Lookup rport based on PID
- */
-struct bfa_fcs_rport_s *bfa_fcs_port_get_rport_by_pid(
-                       struct bfa_fcs_port_s *port, u32 pid);
-
-/*
- * Lookup rport based on PWWN
- */
-struct bfa_fcs_rport_s *bfa_fcs_port_get_rport_by_pwwn(
-                       struct bfa_fcs_port_s *port, wwn_t pwwn);
-struct bfa_fcs_rport_s *bfa_fcs_port_get_rport_by_nwwn(
-                       struct bfa_fcs_port_s *port, wwn_t nwwn);
-void bfa_fcs_port_add_rport(struct bfa_fcs_port_s *port,
-                       struct bfa_fcs_rport_s *rport);
-void bfa_fcs_port_del_rport(struct bfa_fcs_port_s *port,
-                       struct bfa_fcs_rport_s *rport);
-
-void bfa_fcs_port_modinit(struct bfa_fcs_s *fcs);
-void bfa_fcs_port_modexit(struct bfa_fcs_s *fcs);
-void bfa_fcs_port_lip(struct bfa_fcs_port_s *port);
-
-#endif /* __FCS_LPORT_H__ */
diff --git a/drivers/scsi/bfa/fcs_ms.h b/drivers/scsi/bfa/fcs_ms.h
deleted file mode 100644 (file)
index b6a8c12..0000000
+++ /dev/null
@@ -1,35 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  fcs_ms.h FCS ms interfaces
- */
-#ifndef __FCS_MS_H__
-#define __FCS_MS_H__
-
-/* MS FCS routines */
-void bfa_fcs_port_ms_init(struct bfa_fcs_port_s *port);
-void bfa_fcs_port_ms_offline(struct bfa_fcs_port_s *port);
-void bfa_fcs_port_ms_online(struct bfa_fcs_port_s *port);
-void bfa_fcs_port_ms_fabric_rscn(struct bfa_fcs_port_s *port);
-
-/* FDMI FCS routines */
-void bfa_fcs_port_fdmi_init(struct bfa_fcs_port_ms_s *ms);
-void bfa_fcs_port_fdmi_offline(struct bfa_fcs_port_ms_s *ms);
-void bfa_fcs_port_fdmi_online(struct bfa_fcs_port_ms_s *ms);
-
-#endif
diff --git a/drivers/scsi/bfa/fcs_port.h b/drivers/scsi/bfa/fcs_port.h
deleted file mode 100644 (file)
index 408c06a..0000000
+++ /dev/null
@@ -1,31 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  fcs_pport.h FCS physical port interfaces
- */
-
-
-#ifndef __FCS_PPORT_H__
-#define __FCS_PPORT_H__
-
-/*
- * fcs friend functions: only between fcs modules
- */
-void bfa_fcs_pport_attach(struct bfa_fcs_s *fcs);
-
-#endif /* __FCS_PPORT_H__ */
diff --git a/drivers/scsi/bfa/fcs_rport.h b/drivers/scsi/bfa/fcs_rport.h
deleted file mode 100644 (file)
index e634fb7..0000000
+++ /dev/null
@@ -1,61 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  fcs_rport.h FCS rport interfaces and defines
- */
-
-#ifndef __FCS_RPORT_H__
-#define __FCS_RPORT_H__
-
-#include <fcs/bfa_fcs_rport.h>
-
-#define BFA_FCS_RPORT_MAX_RETRIES               (5)
-
-void bfa_fcs_rport_uf_recv(struct bfa_fcs_rport_s *rport, struct fchs_s *fchs,
-                       u16 len);
-void bfa_fcs_rport_scn(struct bfa_fcs_rport_s *rport);
-
-struct bfa_fcs_rport_s *bfa_fcs_rport_create(struct bfa_fcs_port_s *port,
-                       u32 pid);
-void bfa_fcs_rport_delete(struct bfa_fcs_rport_s *rport);
-void bfa_fcs_rport_online(struct bfa_fcs_rport_s *rport);
-void bfa_fcs_rport_offline(struct bfa_fcs_rport_s *rport);
-void bfa_fcs_rport_start(struct bfa_fcs_port_s *port, struct fchs_s *rx_fchs,
-                       struct fc_logi_s *plogi_rsp);
-void bfa_fcs_rport_plogi_create(struct bfa_fcs_port_s *port,
-                       struct fchs_s *rx_fchs,
-                       struct fc_logi_s *plogi);
-void bfa_fcs_rport_plogi(struct bfa_fcs_rport_s *rport, struct fchs_s *fchs,
-                       struct fc_logi_s *plogi);
-void bfa_fcs_rport_logo_imp(struct bfa_fcs_rport_s *rport);
-void bfa_fcs_rport_prlo(struct bfa_fcs_rport_s *rport, uint16_t ox_id);
-void bfa_fcs_rport_itnim_ack(struct bfa_fcs_rport_s *rport);
-void bfa_fcs_rport_itntm_ack(struct bfa_fcs_rport_s *rport);
-void bfa_fcs_rport_tin_ack(struct bfa_fcs_rport_s *rport);
-void bfa_fcs_rport_fcptm_offline_done(struct bfa_fcs_rport_s *rport);
-int  bfa_fcs_rport_get_state(struct bfa_fcs_rport_s *rport);
-struct bfa_fcs_rport_s *bfa_fcs_rport_create_by_wwn(struct bfa_fcs_port_s *port,
-                       wwn_t wwn);
-
-
-/* Rport Features */
-void  bfa_fcs_rpf_init(struct bfa_fcs_rport_s *rport);
-void  bfa_fcs_rpf_rport_online(struct bfa_fcs_rport_s *rport);
-void  bfa_fcs_rpf_rport_offline(struct bfa_fcs_rport_s *rport);
-
-#endif /* __FCS_RPORT_H__ */
diff --git a/drivers/scsi/bfa/fcs_trcmod.h b/drivers/scsi/bfa/fcs_trcmod.h
deleted file mode 100644 (file)
index 41b5ae8..0000000
+++ /dev/null
@@ -1,56 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  fcs_trcmod.h BFA FCS trace modules
- */
-
-#ifndef __FCS_TRCMOD_H__
-#define __FCS_TRCMOD_H__
-
-#include <cs/bfa_trc.h>
-
-/*
- * !!! Only append to the enums defined here to avoid any versioning
- * !!! needed between trace utility and driver version
- */
-enum {
-       BFA_TRC_FCS_FABRIC              = 1,
-       BFA_TRC_FCS_VFAPI               = 2,
-       BFA_TRC_FCS_PORT                = 3,
-       BFA_TRC_FCS_VPORT               = 4,
-       BFA_TRC_FCS_VP_API              = 5,
-       BFA_TRC_FCS_VPS                 = 6,
-       BFA_TRC_FCS_RPORT               = 7,
-       BFA_TRC_FCS_FCPIM               = 8,
-       BFA_TRC_FCS_FCPTM               = 9,
-       BFA_TRC_FCS_NS                  = 10,
-       BFA_TRC_FCS_SCN                 = 11,
-       BFA_TRC_FCS_LOOP                = 12,
-       BFA_TRC_FCS_UF                  = 13,
-       BFA_TRC_FCS_PPORT               = 14,
-       BFA_TRC_FCS_FCPIP               = 15,
-       BFA_TRC_FCS_PORT_API    = 16,
-       BFA_TRC_FCS_RPORT_API   = 17,
-       BFA_TRC_FCS_AUTH                = 18,
-       BFA_TRC_FCS_N2N                 = 19,
-       BFA_TRC_FCS_MS                  = 20,
-       BFA_TRC_FCS_FDMI                = 21,
-       BFA_TRC_FCS_RPORT_FTRS  = 22,
-};
-
-#endif /* __FCS_TRCMOD_H__ */
diff --git a/drivers/scsi/bfa/fcs_uf.h b/drivers/scsi/bfa/fcs_uf.h
deleted file mode 100644 (file)
index f591072..0000000
+++ /dev/null
@@ -1,31 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  fcs_uf.h FCS unsolicited frame receive
- */
-
-
-#ifndef __FCS_UF_H__
-#define __FCS_UF_H__
-
-/*
- * fcs friend functions: only between fcs modules
- */
-void bfa_fcs_uf_attach(struct bfa_fcs_s *fcs);
-
-#endif /* __FCS_UF_H__ */
diff --git a/drivers/scsi/bfa/fcs_vport.h b/drivers/scsi/bfa/fcs_vport.h
deleted file mode 100644 (file)
index bb647a4..0000000
+++ /dev/null
@@ -1,32 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __FCS_VPORT_H__
-#define __FCS_VPORT_H__
-
-#include <fcs/bfa_fcs_lport.h>
-#include <fcs/bfa_fcs_vport.h>
-#include <defs/bfa_defs_pci.h>
-
-void bfa_fcs_vport_cleanup(struct bfa_fcs_vport_s *vport);
-void bfa_fcs_vport_online(struct bfa_fcs_vport_s *vport);
-void bfa_fcs_vport_offline(struct bfa_fcs_vport_s *vport);
-void bfa_fcs_vport_delete_comp(struct bfa_fcs_vport_s *vport);
-void bfa_fcs_vport_fcs_delete(struct bfa_fcs_vport_s *vport);
-
-#endif /* __FCS_VPORT_H__ */
-
diff --git a/drivers/scsi/bfa/fdmi.c b/drivers/scsi/bfa/fdmi.c
deleted file mode 100644 (file)
index 2b50eab..0000000
+++ /dev/null
@@ -1,1230 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  port_api.c BFA FCS port
- */
-
-
-#include <bfa.h>
-#include <bfa_svc.h>
-#include "fcs_lport.h"
-#include "fcs_rport.h"
-#include "lport_priv.h"
-#include "fcs_trcmod.h"
-#include "fcs_fcxp.h"
-#include <fcs/bfa_fcs_fdmi.h>
-
-BFA_TRC_FILE(FCS, FDMI);
-
-#define BFA_FCS_FDMI_CMD_MAX_RETRIES 2
-
-/*
- * forward declarations
- */
-static void     bfa_fcs_port_fdmi_send_rhba(void *fdmi_cbarg,
-                                           struct bfa_fcxp_s *fcxp_alloced);
-static void     bfa_fcs_port_fdmi_send_rprt(void *fdmi_cbarg,
-                                           struct bfa_fcxp_s *fcxp_alloced);
-static void     bfa_fcs_port_fdmi_send_rpa(void *fdmi_cbarg,
-                                          struct bfa_fcxp_s *fcxp_alloced);
-static void     bfa_fcs_port_fdmi_rhba_response(void *fcsarg,
-                                               struct bfa_fcxp_s *fcxp,
-                                               void *cbarg,
-                                               bfa_status_t req_status,
-                                               u32 rsp_len,
-                                               u32 resid_len,
-                                               struct fchs_s *rsp_fchs);
-static void     bfa_fcs_port_fdmi_rprt_response(void *fcsarg,
-                                               struct bfa_fcxp_s *fcxp,
-                                               void *cbarg,
-                                               bfa_status_t req_status,
-                                               u32 rsp_len,
-                                               u32 resid_len,
-                                               struct fchs_s *rsp_fchs);
-static void     bfa_fcs_port_fdmi_rpa_response(void *fcsarg,
-                                              struct bfa_fcxp_s *fcxp,
-                                              void *cbarg,
-                                              bfa_status_t req_status,
-                                              u32 rsp_len,
-                                              u32 resid_len,
-                                              struct fchs_s *rsp_fchs);
-static void     bfa_fcs_port_fdmi_timeout(void *arg);
-static u16 bfa_fcs_port_fdmi_build_rhba_pyld(
-                       struct bfa_fcs_port_fdmi_s *fdmi, u8 *pyld);
-static u16 bfa_fcs_port_fdmi_build_rprt_pyld(
-                       struct bfa_fcs_port_fdmi_s *fdmi, u8 *pyld);
-static u16 bfa_fcs_port_fdmi_build_rpa_pyld(
-                       struct bfa_fcs_port_fdmi_s *fdmi, u8 *pyld);
-static u16 bfa_fcs_port_fdmi_build_portattr_block(
-                       struct bfa_fcs_port_fdmi_s *fdmi, u8 *pyld);
-static void bfa_fcs_fdmi_get_hbaattr(struct bfa_fcs_port_fdmi_s *fdmi,
-                       struct bfa_fcs_fdmi_hba_attr_s *hba_attr);
-static void bfa_fcs_fdmi_get_portattr(struct bfa_fcs_port_fdmi_s *fdmi,
-                       struct bfa_fcs_fdmi_port_attr_s *port_attr);
-/**
- *  fcs_fdmi_sm FCS FDMI state machine
- */
-
-/**
- *  FDMI State Machine events
- */
-enum port_fdmi_event {
-       FDMISM_EVENT_PORT_ONLINE = 1,
-       FDMISM_EVENT_PORT_OFFLINE = 2,
-       FDMISM_EVENT_RSP_OK = 4,
-       FDMISM_EVENT_RSP_ERROR = 5,
-       FDMISM_EVENT_TIMEOUT = 6,
-       FDMISM_EVENT_RHBA_SENT = 7,
-       FDMISM_EVENT_RPRT_SENT = 8,
-       FDMISM_EVENT_RPA_SENT = 9,
-};
-
-static void bfa_fcs_port_fdmi_sm_offline(struct bfa_fcs_port_fdmi_s *fdmi,
-                       enum port_fdmi_event event);
-static void bfa_fcs_port_fdmi_sm_sending_rhba(struct bfa_fcs_port_fdmi_s *fdmi,
-                       enum port_fdmi_event event);
-static void bfa_fcs_port_fdmi_sm_rhba(struct bfa_fcs_port_fdmi_s *fdmi,
-                       enum port_fdmi_event event);
-static void bfa_fcs_port_fdmi_sm_rhba_retry(struct bfa_fcs_port_fdmi_s *fdmi,
-                       enum port_fdmi_event event);
-static void bfa_fcs_port_fdmi_sm_sending_rprt(struct bfa_fcs_port_fdmi_s *fdmi,
-                       enum port_fdmi_event event);
-static void bfa_fcs_port_fdmi_sm_rprt(struct bfa_fcs_port_fdmi_s *fdmi,
-                       enum port_fdmi_event event);
-static void bfa_fcs_port_fdmi_sm_rprt_retry(struct bfa_fcs_port_fdmi_s *fdmi,
-                       enum port_fdmi_event event);
-static void bfa_fcs_port_fdmi_sm_sending_rpa(struct bfa_fcs_port_fdmi_s *fdmi,
-                       enum port_fdmi_event event);
-static void     bfa_fcs_port_fdmi_sm_rpa(struct bfa_fcs_port_fdmi_s *fdmi,
-                       enum port_fdmi_event event);
-static void     bfa_fcs_port_fdmi_sm_rpa_retry(struct bfa_fcs_port_fdmi_s *fdmi,
-                       enum port_fdmi_event event);
-static void     bfa_fcs_port_fdmi_sm_online(struct bfa_fcs_port_fdmi_s *fdmi,
-                       enum port_fdmi_event event);
-static void    bfa_fcs_port_fdmi_sm_disabled(struct bfa_fcs_port_fdmi_s *fdmi,
-                       enum port_fdmi_event event);
-
-/**
- *             Start in offline state - awaiting MS to send start.
- */
-static void
-bfa_fcs_port_fdmi_sm_offline(struct bfa_fcs_port_fdmi_s *fdmi,
-                            enum port_fdmi_event event)
-{
-       struct bfa_fcs_port_s *port = fdmi->ms->port;
-
-       bfa_trc(port->fcs, port->port_cfg.pwwn);
-       bfa_trc(port->fcs, event);
-
-       fdmi->retry_cnt = 0;
-
-       switch (event) {
-       case FDMISM_EVENT_PORT_ONLINE:
-               if (port->vport) {
-                       /*
-                        * For Vports, register a new port.
-                        */
-                       bfa_sm_set_state(fdmi,
-                                        bfa_fcs_port_fdmi_sm_sending_rprt);
-                       bfa_fcs_port_fdmi_send_rprt(fdmi, NULL);
-               } else {
-                       /*
-                        * For a base port, we should first register the HBA
-                        * atribute. The HBA attribute also contains the base
-                        *  port registration.
-                        */
-                       bfa_sm_set_state(fdmi,
-                                        bfa_fcs_port_fdmi_sm_sending_rhba);
-                       bfa_fcs_port_fdmi_send_rhba(fdmi, NULL);
-               }
-               break;
-
-       case FDMISM_EVENT_PORT_OFFLINE:
-               break;
-
-       default:
-               bfa_sm_fault(port->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_port_fdmi_sm_sending_rhba(struct bfa_fcs_port_fdmi_s *fdmi,
-                                 enum port_fdmi_event event)
-{
-       struct bfa_fcs_port_s *port = fdmi->ms->port;
-
-       bfa_trc(port->fcs, port->port_cfg.pwwn);
-       bfa_trc(port->fcs, event);
-
-       switch (event) {
-       case FDMISM_EVENT_RHBA_SENT:
-               bfa_sm_set_state(fdmi, bfa_fcs_port_fdmi_sm_rhba);
-               break;
-
-       case FDMISM_EVENT_PORT_OFFLINE:
-               bfa_sm_set_state(fdmi, bfa_fcs_port_fdmi_sm_offline);
-               bfa_fcxp_walloc_cancel(BFA_FCS_GET_HAL_FROM_PORT(port),
-                                      &fdmi->fcxp_wqe);
-               break;
-
-       default:
-               bfa_sm_fault(port->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_port_fdmi_sm_rhba(struct bfa_fcs_port_fdmi_s *fdmi,
-                         enum port_fdmi_event event)
-{
-       struct bfa_fcs_port_s *port = fdmi->ms->port;
-
-       bfa_trc(port->fcs, port->port_cfg.pwwn);
-       bfa_trc(port->fcs, event);
-
-       switch (event) {
-       case FDMISM_EVENT_RSP_ERROR:
-               /*
-                * if max retries have not been reached, start timer for a
-                * delayed retry
-                */
-               if (fdmi->retry_cnt++ < BFA_FCS_FDMI_CMD_MAX_RETRIES) {
-                       bfa_sm_set_state(fdmi, bfa_fcs_port_fdmi_sm_rhba_retry);
-                       bfa_timer_start(BFA_FCS_GET_HAL_FROM_PORT(port),
-                                       &fdmi->timer, bfa_fcs_port_fdmi_timeout,
-                                       fdmi, BFA_FCS_RETRY_TIMEOUT);
-               } else {
-                       /*
-                        * set state to offline
-                        */
-                       bfa_sm_set_state(fdmi, bfa_fcs_port_fdmi_sm_offline);
-               }
-               break;
-
-       case FDMISM_EVENT_RSP_OK:
-               /*
-                * Initiate Register Port Attributes
-                */
-               bfa_sm_set_state(fdmi, bfa_fcs_port_fdmi_sm_sending_rpa);
-               fdmi->retry_cnt = 0;
-               bfa_fcs_port_fdmi_send_rpa(fdmi, NULL);
-               break;
-
-       case FDMISM_EVENT_PORT_OFFLINE:
-               bfa_fcxp_discard(fdmi->fcxp);
-               bfa_sm_set_state(fdmi, bfa_fcs_port_fdmi_sm_offline);
-               break;
-
-       default:
-               bfa_sm_fault(port->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_port_fdmi_sm_rhba_retry(struct bfa_fcs_port_fdmi_s *fdmi,
-                               enum port_fdmi_event event)
-{
-       struct bfa_fcs_port_s *port = fdmi->ms->port;
-
-       bfa_trc(port->fcs, port->port_cfg.pwwn);
-       bfa_trc(port->fcs, event);
-
-       switch (event) {
-       case FDMISM_EVENT_TIMEOUT:
-               /*
-                * Retry Timer Expired. Re-send
-                */
-               bfa_sm_set_state(fdmi, bfa_fcs_port_fdmi_sm_sending_rhba);
-               bfa_fcs_port_fdmi_send_rhba(fdmi, NULL);
-               break;
-
-       case FDMISM_EVENT_PORT_OFFLINE:
-               bfa_sm_set_state(fdmi, bfa_fcs_port_fdmi_sm_offline);
-               bfa_timer_stop(&fdmi->timer);
-               break;
-
-       default:
-               bfa_sm_fault(port->fcs, event);
-       }
-}
-
-/*
-* RPRT : Register Port
- */
-static void
-bfa_fcs_port_fdmi_sm_sending_rprt(struct bfa_fcs_port_fdmi_s *fdmi,
-                                 enum port_fdmi_event event)
-{
-       struct bfa_fcs_port_s *port = fdmi->ms->port;
-
-       bfa_trc(port->fcs, port->port_cfg.pwwn);
-       bfa_trc(port->fcs, event);
-
-       switch (event) {
-       case FDMISM_EVENT_RPRT_SENT:
-               bfa_sm_set_state(fdmi, bfa_fcs_port_fdmi_sm_rprt);
-               break;
-
-       case FDMISM_EVENT_PORT_OFFLINE:
-               bfa_sm_set_state(fdmi, bfa_fcs_port_fdmi_sm_offline);
-               bfa_fcxp_walloc_cancel(BFA_FCS_GET_HAL_FROM_PORT(port),
-                                      &fdmi->fcxp_wqe);
-               break;
-
-       default:
-               bfa_sm_fault(port->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_port_fdmi_sm_rprt(struct bfa_fcs_port_fdmi_s *fdmi,
-                         enum port_fdmi_event event)
-{
-       struct bfa_fcs_port_s *port = fdmi->ms->port;
-
-       bfa_trc(port->fcs, port->port_cfg.pwwn);
-       bfa_trc(port->fcs, event);
-
-       switch (event) {
-       case FDMISM_EVENT_RSP_ERROR:
-               /*
-                * if max retries have not been reached, start timer for a
-                * delayed retry
-                */
-               if (fdmi->retry_cnt++ < BFA_FCS_FDMI_CMD_MAX_RETRIES) {
-                       bfa_sm_set_state(fdmi, bfa_fcs_port_fdmi_sm_rprt_retry);
-                       bfa_timer_start(BFA_FCS_GET_HAL_FROM_PORT(port),
-                                       &fdmi->timer, bfa_fcs_port_fdmi_timeout,
-                                       fdmi, BFA_FCS_RETRY_TIMEOUT);
-
-               } else {
-                       /*
-                        * set state to offline
-                        */
-                       bfa_sm_set_state(fdmi, bfa_fcs_port_fdmi_sm_offline);
-                       fdmi->retry_cnt = 0;
-               }
-               break;
-
-       case FDMISM_EVENT_RSP_OK:
-               fdmi->retry_cnt = 0;
-               bfa_sm_set_state(fdmi, bfa_fcs_port_fdmi_sm_online);
-               break;
-
-       case FDMISM_EVENT_PORT_OFFLINE:
-               bfa_fcxp_discard(fdmi->fcxp);
-               bfa_sm_set_state(fdmi, bfa_fcs_port_fdmi_sm_offline);
-               break;
-
-       default:
-               bfa_sm_fault(port->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_port_fdmi_sm_rprt_retry(struct bfa_fcs_port_fdmi_s *fdmi,
-                               enum port_fdmi_event event)
-{
-       struct bfa_fcs_port_s *port = fdmi->ms->port;
-
-       bfa_trc(port->fcs, port->port_cfg.pwwn);
-       bfa_trc(port->fcs, event);
-
-       switch (event) {
-       case FDMISM_EVENT_TIMEOUT:
-               /*
-                * Retry Timer Expired. Re-send
-                */
-               bfa_sm_set_state(fdmi, bfa_fcs_port_fdmi_sm_sending_rprt);
-               bfa_fcs_port_fdmi_send_rprt(fdmi, NULL);
-               break;
-
-       case FDMISM_EVENT_PORT_OFFLINE:
-               bfa_sm_set_state(fdmi, bfa_fcs_port_fdmi_sm_offline);
-               bfa_timer_stop(&fdmi->timer);
-               break;
-
-       default:
-               bfa_sm_fault(port->fcs, event);
-       }
-}
-
-/*
- * Register Port Attributes
- */
-static void
-bfa_fcs_port_fdmi_sm_sending_rpa(struct bfa_fcs_port_fdmi_s *fdmi,
-                                enum port_fdmi_event event)
-{
-       struct bfa_fcs_port_s *port = fdmi->ms->port;
-
-       bfa_trc(port->fcs, port->port_cfg.pwwn);
-       bfa_trc(port->fcs, event);
-
-       switch (event) {
-       case FDMISM_EVENT_RPA_SENT:
-               bfa_sm_set_state(fdmi, bfa_fcs_port_fdmi_sm_rpa);
-               break;
-
-       case FDMISM_EVENT_PORT_OFFLINE:
-               bfa_sm_set_state(fdmi, bfa_fcs_port_fdmi_sm_offline);
-               bfa_fcxp_walloc_cancel(BFA_FCS_GET_HAL_FROM_PORT(port),
-                                      &fdmi->fcxp_wqe);
-               break;
-
-       default:
-               bfa_sm_fault(port->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_port_fdmi_sm_rpa(struct bfa_fcs_port_fdmi_s *fdmi,
-                        enum port_fdmi_event event)
-{
-       struct bfa_fcs_port_s *port = fdmi->ms->port;
-
-       bfa_trc(port->fcs, port->port_cfg.pwwn);
-       bfa_trc(port->fcs, event);
-
-       switch (event) {
-       case FDMISM_EVENT_RSP_ERROR:
-               /*
-                * if max retries have not been reached, start timer for a
-                * delayed retry
-                */
-               if (fdmi->retry_cnt++ < BFA_FCS_FDMI_CMD_MAX_RETRIES) {
-                       bfa_sm_set_state(fdmi, bfa_fcs_port_fdmi_sm_rpa_retry);
-                       bfa_timer_start(BFA_FCS_GET_HAL_FROM_PORT(port),
-                                       &fdmi->timer, bfa_fcs_port_fdmi_timeout,
-                                       fdmi, BFA_FCS_RETRY_TIMEOUT);
-               } else {
-                       /*
-                        * set state to offline
-                        */
-                       bfa_sm_set_state(fdmi, bfa_fcs_port_fdmi_sm_offline);
-                       fdmi->retry_cnt = 0;
-               }
-               break;
-
-       case FDMISM_EVENT_RSP_OK:
-               bfa_sm_set_state(fdmi, bfa_fcs_port_fdmi_sm_online);
-               fdmi->retry_cnt = 0;
-               break;
-
-       case FDMISM_EVENT_PORT_OFFLINE:
-               bfa_fcxp_discard(fdmi->fcxp);
-               bfa_sm_set_state(fdmi, bfa_fcs_port_fdmi_sm_offline);
-               break;
-
-       default:
-               bfa_sm_fault(port->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_port_fdmi_sm_rpa_retry(struct bfa_fcs_port_fdmi_s *fdmi,
-                              enum port_fdmi_event event)
-{
-       struct bfa_fcs_port_s *port = fdmi->ms->port;
-
-       bfa_trc(port->fcs, port->port_cfg.pwwn);
-       bfa_trc(port->fcs, event);
-
-       switch (event) {
-       case FDMISM_EVENT_TIMEOUT:
-               /*
-                * Retry Timer Expired. Re-send
-                */
-               bfa_sm_set_state(fdmi, bfa_fcs_port_fdmi_sm_sending_rpa);
-               bfa_fcs_port_fdmi_send_rpa(fdmi, NULL);
-               break;
-
-       case FDMISM_EVENT_PORT_OFFLINE:
-               bfa_sm_set_state(fdmi, bfa_fcs_port_fdmi_sm_offline);
-               bfa_timer_stop(&fdmi->timer);
-               break;
-
-       default:
-               bfa_sm_fault(port->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_port_fdmi_sm_online(struct bfa_fcs_port_fdmi_s *fdmi,
-                           enum port_fdmi_event event)
-{
-       struct bfa_fcs_port_s *port = fdmi->ms->port;
-
-       bfa_trc(port->fcs, port->port_cfg.pwwn);
-       bfa_trc(port->fcs, event);
-
-       switch (event) {
-       case FDMISM_EVENT_PORT_OFFLINE:
-               bfa_sm_set_state(fdmi, bfa_fcs_port_fdmi_sm_offline);
-               break;
-
-       default:
-               bfa_sm_fault(port->fcs, event);
-       }
-}
-
-/**
- *  FDMI is disabled state.
- */
-static void
-bfa_fcs_port_fdmi_sm_disabled(struct bfa_fcs_port_fdmi_s *fdmi,
-                               enum port_fdmi_event event)
-{
-       struct bfa_fcs_port_s *port = fdmi->ms->port;
-
-       bfa_trc(port->fcs, port->port_cfg.pwwn);
-       bfa_trc(port->fcs, event);
-
-       /* No op State. It can only be enabled at Driver Init. */
-}
-
-/**
-*   RHBA : Register HBA Attributes.
- */
-static void
-bfa_fcs_port_fdmi_send_rhba(void *fdmi_cbarg, struct bfa_fcxp_s *fcxp_alloced)
-{
-       struct bfa_fcs_port_fdmi_s *fdmi = fdmi_cbarg;
-       struct bfa_fcs_port_s *port = fdmi->ms->port;
-       struct fchs_s          fchs;
-       int             len, attr_len;
-       struct bfa_fcxp_s *fcxp;
-       u8        *pyld;
-
-       bfa_trc(port->fcs, port->port_cfg.pwwn);
-
-       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
-       if (!fcxp) {
-               bfa_fcxp_alloc_wait(port->fcs->bfa, &fdmi->fcxp_wqe,
-                                   bfa_fcs_port_fdmi_send_rhba, fdmi);
-               return;
-       }
-       fdmi->fcxp = fcxp;
-
-       pyld = bfa_fcxp_get_reqbuf(fcxp);
-       bfa_os_memset(pyld, 0, FC_MAX_PDUSZ);
-
-       len = fc_fdmi_reqhdr_build(&fchs, pyld, bfa_fcs_port_get_fcid(port),
-                                  FDMI_RHBA);
-
-       attr_len = bfa_fcs_port_fdmi_build_rhba_pyld(fdmi,
-                       (u8 *) ((struct ct_hdr_s *) pyld + 1));
-
-       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
-                     FC_CLASS_3, (len + attr_len), &fchs,
-                     bfa_fcs_port_fdmi_rhba_response, (void *)fdmi,
-                     FC_MAX_PDUSZ, FC_FCCT_TOV);
-
-       bfa_sm_send_event(fdmi, FDMISM_EVENT_RHBA_SENT);
-}
-
-static          u16
-bfa_fcs_port_fdmi_build_rhba_pyld(struct bfa_fcs_port_fdmi_s *fdmi,
-                                 u8 *pyld)
-{
-       struct bfa_fcs_port_s *port = fdmi->ms->port;
-       struct bfa_fcs_fdmi_hba_attr_s hba_attr;        /* @todo */
-       struct bfa_fcs_fdmi_hba_attr_s *fcs_hba_attr = &hba_attr; /* @todo */
-       struct fdmi_rhba_s    *rhba = (struct fdmi_rhba_s *) pyld;
-       struct fdmi_attr_s    *attr;
-       u8        *curr_ptr;
-       u16        len, count;
-
-       /*
-        * get hba attributes
-        */
-       bfa_fcs_fdmi_get_hbaattr(fdmi, fcs_hba_attr);
-
-       rhba->hba_id = bfa_fcs_port_get_pwwn(port);
-       rhba->port_list.num_ports = bfa_os_htonl(1);
-       rhba->port_list.port_entry = bfa_fcs_port_get_pwwn(port);
-
-       len = sizeof(rhba->hba_id) + sizeof(rhba->port_list);
-
-       count = 0;
-       len += sizeof(rhba->hba_attr_blk.attr_count);
-
-       /*
-        * fill out the invididual entries of the HBA attrib Block
-        */
-       curr_ptr = (u8 *) &rhba->hba_attr_blk.hba_attr;
-
-       /*
-        * Node Name
-        */
-       attr = (struct fdmi_attr_s *) curr_ptr;
-       attr->type = bfa_os_htons(FDMI_HBA_ATTRIB_NODENAME);
-       attr->len = sizeof(wwn_t);
-       memcpy(attr->value, &bfa_fcs_port_get_nwwn(port), attr->len);
-       curr_ptr += sizeof(attr->type) + sizeof(attr->len) + attr->len;
-       len += attr->len;
-       count++;
-       attr->len =
-               bfa_os_htons(attr->len + sizeof(attr->type) +
-                            sizeof(attr->len));
-
-       /*
-        * Manufacturer
-        */
-       attr = (struct fdmi_attr_s *) curr_ptr;
-       attr->type = bfa_os_htons(FDMI_HBA_ATTRIB_MANUFACTURER);
-       attr->len = (u16) strlen(fcs_hba_attr->manufacturer);
-       memcpy(attr->value, fcs_hba_attr->manufacturer, attr->len);
-       /* variable fields need to be 4 byte aligned */
-       attr->len = fc_roundup(attr->len, sizeof(u32));
-       curr_ptr += sizeof(attr->type) + sizeof(attr->len) + attr->len;
-       len += attr->len;
-       count++;
-       attr->len =
-               bfa_os_htons(attr->len + sizeof(attr->type) +
-                            sizeof(attr->len));
-
-       /*
-        * Serial Number
-        */
-       attr = (struct fdmi_attr_s *) curr_ptr;
-       attr->type = bfa_os_htons(FDMI_HBA_ATTRIB_SERIALNUM);
-       attr->len = (u16) strlen(fcs_hba_attr->serial_num);
-       memcpy(attr->value, fcs_hba_attr->serial_num, attr->len);
-       /* variable fields need to be 4 byte aligned */
-       attr->len = fc_roundup(attr->len, sizeof(u32));
-       curr_ptr += sizeof(attr->type) + sizeof(attr->len) + attr->len;
-       len += attr->len;
-       count++;
-       attr->len =
-               bfa_os_htons(attr->len + sizeof(attr->type) +
-                            sizeof(attr->len));
-
-       /*
-        * Model
-        */
-       attr = (struct fdmi_attr_s *) curr_ptr;
-       attr->type = bfa_os_htons(FDMI_HBA_ATTRIB_MODEL);
-       attr->len = (u16) strlen(fcs_hba_attr->model);
-       memcpy(attr->value, fcs_hba_attr->model, attr->len);
-       /* variable fields need to be 4 byte aligned */
-       attr->len = fc_roundup(attr->len, sizeof(u32));
-       curr_ptr += sizeof(attr->type) + sizeof(attr->len) + attr->len;
-       len += attr->len;
-       count++;
-       attr->len =
-               bfa_os_htons(attr->len + sizeof(attr->type) +
-                            sizeof(attr->len));
-
-       /*
-        * Model Desc
-        */
-       attr = (struct fdmi_attr_s *) curr_ptr;
-       attr->type = bfa_os_htons(FDMI_HBA_ATTRIB_MODEL_DESC);
-       attr->len = (u16) strlen(fcs_hba_attr->model_desc);
-       memcpy(attr->value, fcs_hba_attr->model_desc, attr->len);
-       /* variable fields need to be 4 byte aligned */
-       attr->len = fc_roundup(attr->len, sizeof(u32));
-       curr_ptr += sizeof(attr->type) + sizeof(attr->len) + attr->len;
-       len += attr->len;
-       count++;
-       attr->len =
-               bfa_os_htons(attr->len + sizeof(attr->type) +
-                            sizeof(attr->len));
-
-       /*
-        * H/W Version
-        */
-       if (fcs_hba_attr->hw_version[0] != '\0') {
-               attr = (struct fdmi_attr_s *) curr_ptr;
-               attr->type = bfa_os_htons(FDMI_HBA_ATTRIB_HW_VERSION);
-               attr->len = (u16) strlen(fcs_hba_attr->hw_version);
-               memcpy(attr->value, fcs_hba_attr->hw_version, attr->len);
-               /* variable fields need to be 4 byte aligned */
-               attr->len = fc_roundup(attr->len, sizeof(u32));
-               curr_ptr += sizeof(attr->type) + sizeof(attr->len) + attr->len;
-               len += attr->len;
-               count++;
-               attr->len =
-                       bfa_os_htons(attr->len + sizeof(attr->type) +
-                                    sizeof(attr->len));
-       }
-
-       /*
-        * Driver Version
-        */
-       attr = (struct fdmi_attr_s *) curr_ptr;
-       attr->type = bfa_os_htons(FDMI_HBA_ATTRIB_DRIVER_VERSION);
-       attr->len = (u16) strlen(fcs_hba_attr->driver_version);
-       memcpy(attr->value, fcs_hba_attr->driver_version, attr->len);
-       /* variable fields need to be 4 byte aligned */
-       attr->len = fc_roundup(attr->len, sizeof(u32));
-       curr_ptr += sizeof(attr->type) + sizeof(attr->len) + attr->len;
-       len += attr->len;;
-       count++;
-       attr->len =
-               bfa_os_htons(attr->len + sizeof(attr->type) +
-                            sizeof(attr->len));
-
-       /*
-        * Option Rom Version
-        */
-       if (fcs_hba_attr->option_rom_ver[0] != '\0') {
-               attr = (struct fdmi_attr_s *) curr_ptr;
-               attr->type = bfa_os_htons(FDMI_HBA_ATTRIB_ROM_VERSION);
-               attr->len = (u16) strlen(fcs_hba_attr->option_rom_ver);
-               memcpy(attr->value, fcs_hba_attr->option_rom_ver, attr->len);
-               /* variable fields need to be 4 byte aligned */
-               attr->len = fc_roundup(attr->len, sizeof(u32));
-               curr_ptr += sizeof(attr->type) + sizeof(attr->len) + attr->len;
-               len += attr->len;
-               count++;
-               attr->len =
-                       bfa_os_htons(attr->len + sizeof(attr->type) +
-                                    sizeof(attr->len));
-       }
-
-       /*
-        * f/w Version = driver version
-        */
-       attr = (struct fdmi_attr_s *) curr_ptr;
-       attr->type = bfa_os_htons(FDMI_HBA_ATTRIB_FW_VERSION);
-       attr->len = (u16) strlen(fcs_hba_attr->driver_version);
-       memcpy(attr->value, fcs_hba_attr->driver_version, attr->len);
-       /* variable fields need to be 4 byte aligned */
-       attr->len = fc_roundup(attr->len, sizeof(u32));
-       curr_ptr += sizeof(attr->type) + sizeof(attr->len) + attr->len;
-       len += attr->len;
-       count++;
-       attr->len =
-               bfa_os_htons(attr->len + sizeof(attr->type) +
-                            sizeof(attr->len));
-
-       /*
-        * OS Name
-        */
-       if (fcs_hba_attr->os_name[0] != '\0') {
-               attr = (struct fdmi_attr_s *) curr_ptr;
-               attr->type = bfa_os_htons(FDMI_HBA_ATTRIB_OS_NAME);
-               attr->len = (u16) strlen(fcs_hba_attr->os_name);
-               memcpy(attr->value, fcs_hba_attr->os_name, attr->len);
-               /* variable fields need to be 4 byte aligned */
-               attr->len = fc_roundup(attr->len, sizeof(u32));
-               curr_ptr += sizeof(attr->type) + sizeof(attr->len) + attr->len;
-               len += attr->len;
-               count++;
-               attr->len =
-                       bfa_os_htons(attr->len + sizeof(attr->type) +
-                                    sizeof(attr->len));
-       }
-
-       /*
-        * MAX_CT_PAYLOAD
-        */
-       attr = (struct fdmi_attr_s *) curr_ptr;
-       attr->type = bfa_os_htons(FDMI_HBA_ATTRIB_MAX_CT);
-       attr->len = sizeof(fcs_hba_attr->max_ct_pyld);
-       memcpy(attr->value, &fcs_hba_attr->max_ct_pyld, attr->len);
-       len += attr->len;
-       count++;
-       attr->len =
-               bfa_os_htons(attr->len + sizeof(attr->type) +
-                            sizeof(attr->len));
-
-       /*
-        * Update size of payload
-        */
-       len += ((sizeof(attr->type) + sizeof(attr->len)) * count);
-
-       rhba->hba_attr_blk.attr_count = bfa_os_htonl(count);
-       return len;
-}
-
-static void
-bfa_fcs_port_fdmi_rhba_response(void *fcsarg, struct bfa_fcxp_s *fcxp,
-                               void *cbarg, bfa_status_t req_status,
-                               u32 rsp_len, u32 resid_len,
-                               struct fchs_s *rsp_fchs)
-{
-       struct bfa_fcs_port_fdmi_s *fdmi = (struct bfa_fcs_port_fdmi_s *)cbarg;
-       struct bfa_fcs_port_s *port = fdmi->ms->port;
-       struct ct_hdr_s       *cthdr = NULL;
-
-       bfa_trc(port->fcs, port->port_cfg.pwwn);
-
-       /*
-        * Sanity Checks
-        */
-       if (req_status != BFA_STATUS_OK) {
-               bfa_trc(port->fcs, req_status);
-               bfa_sm_send_event(fdmi, FDMISM_EVENT_RSP_ERROR);
-               return;
-       }
-
-       cthdr = (struct ct_hdr_s *) BFA_FCXP_RSP_PLD(fcxp);
-       cthdr->cmd_rsp_code = bfa_os_ntohs(cthdr->cmd_rsp_code);
-
-       if (cthdr->cmd_rsp_code == CT_RSP_ACCEPT) {
-               bfa_sm_send_event(fdmi, FDMISM_EVENT_RSP_OK);
-               return;
-       }
-
-       bfa_trc(port->fcs, cthdr->reason_code);
-       bfa_trc(port->fcs, cthdr->exp_code);
-       bfa_sm_send_event(fdmi, FDMISM_EVENT_RSP_ERROR);
-}
-
-/**
-*   RPRT : Register Port
- */
-static void
-bfa_fcs_port_fdmi_send_rprt(void *fdmi_cbarg, struct bfa_fcxp_s *fcxp_alloced)
-{
-       struct bfa_fcs_port_fdmi_s *fdmi = fdmi_cbarg;
-       struct bfa_fcs_port_s *port = fdmi->ms->port;
-       struct fchs_s          fchs;
-       u16        len, attr_len;
-       struct bfa_fcxp_s *fcxp;
-       u8        *pyld;
-
-       bfa_trc(port->fcs, port->port_cfg.pwwn);
-
-       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
-       if (!fcxp) {
-               bfa_fcxp_alloc_wait(port->fcs->bfa, &fdmi->fcxp_wqe,
-                                   bfa_fcs_port_fdmi_send_rprt, fdmi);
-               return;
-       }
-       fdmi->fcxp = fcxp;
-
-       pyld = bfa_fcxp_get_reqbuf(fcxp);
-       bfa_os_memset(pyld, 0, FC_MAX_PDUSZ);
-
-       len = fc_fdmi_reqhdr_build(&fchs, pyld, bfa_fcs_port_get_fcid(port),
-                                  FDMI_RPRT);
-
-       attr_len = bfa_fcs_port_fdmi_build_rprt_pyld(fdmi,
-                       (u8 *) ((struct ct_hdr_s *) pyld + 1));
-
-       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
-                     FC_CLASS_3, len + attr_len, &fchs,
-                     bfa_fcs_port_fdmi_rprt_response, (void *)fdmi,
-                     FC_MAX_PDUSZ, FC_FCCT_TOV);
-
-       bfa_sm_send_event(fdmi, FDMISM_EVENT_RPRT_SENT);
-}
-
-/**
- * This routine builds Port Attribute Block that used in RPA, RPRT commands.
- */
-static          u16
-bfa_fcs_port_fdmi_build_portattr_block(struct bfa_fcs_port_fdmi_s *fdmi,
-                                      u8 *pyld)
-{
-       struct bfa_fcs_fdmi_port_attr_s fcs_port_attr;
-       struct fdmi_port_attr_s *port_attrib = (struct fdmi_port_attr_s *) pyld;
-       struct fdmi_attr_s    *attr;
-       u8        *curr_ptr;
-       u16        len;
-       u8         count = 0;
-
-       /*
-        * get port attributes
-        */
-       bfa_fcs_fdmi_get_portattr(fdmi, &fcs_port_attr);
-
-       len = sizeof(port_attrib->attr_count);
-
-       /*
-        * fill out the invididual entries
-        */
-       curr_ptr = (u8 *) &port_attrib->port_attr;
-
-       /*
-        * FC4 Types
-        */
-       attr = (struct fdmi_attr_s *) curr_ptr;
-       attr->type = bfa_os_htons(FDMI_PORT_ATTRIB_FC4_TYPES);
-       attr->len = sizeof(fcs_port_attr.supp_fc4_types);
-       memcpy(attr->value, fcs_port_attr.supp_fc4_types, attr->len);
-       curr_ptr += sizeof(attr->type) + sizeof(attr->len) + attr->len;
-       len += attr->len;
-       ++count;
-       attr->len =
-               bfa_os_htons(attr->len + sizeof(attr->type) +
-                            sizeof(attr->len));
-
-       /*
-        * Supported Speed
-        */
-       attr = (struct fdmi_attr_s *) curr_ptr;
-       attr->type = bfa_os_htons(FDMI_PORT_ATTRIB_SUPP_SPEED);
-       attr->len = sizeof(fcs_port_attr.supp_speed);
-       memcpy(attr->value, &fcs_port_attr.supp_speed, attr->len);
-       curr_ptr += sizeof(attr->type) + sizeof(attr->len) + attr->len;
-       len += attr->len;
-       ++count;
-       attr->len =
-               bfa_os_htons(attr->len + sizeof(attr->type) +
-                            sizeof(attr->len));
-
-       /*
-        * current Port Speed
-        */
-       attr = (struct fdmi_attr_s *) curr_ptr;
-       attr->type = bfa_os_htons(FDMI_PORT_ATTRIB_PORT_SPEED);
-       attr->len = sizeof(fcs_port_attr.curr_speed);
-       memcpy(attr->value, &fcs_port_attr.curr_speed, attr->len);
-       curr_ptr += sizeof(attr->type) + sizeof(attr->len) + attr->len;
-       len += attr->len;
-       ++count;
-       attr->len =
-               bfa_os_htons(attr->len + sizeof(attr->type) +
-                            sizeof(attr->len));
-
-       /*
-        * max frame size
-        */
-       attr = (struct fdmi_attr_s *) curr_ptr;
-       attr->type = bfa_os_htons(FDMI_PORT_ATTRIB_FRAME_SIZE);
-       attr->len = sizeof(fcs_port_attr.max_frm_size);
-       memcpy(attr->value, &fcs_port_attr.max_frm_size, attr->len);
-       curr_ptr += sizeof(attr->type) + sizeof(attr->len) + attr->len;
-       len += attr->len;
-       ++count;
-       attr->len =
-               bfa_os_htons(attr->len + sizeof(attr->type) +
-                            sizeof(attr->len));
-
-       /*
-        * OS Device Name
-        */
-       if (fcs_port_attr.os_device_name[0] != '\0') {
-               attr = (struct fdmi_attr_s *) curr_ptr;
-               attr->type = bfa_os_htons(FDMI_PORT_ATTRIB_DEV_NAME);
-               attr->len = (u16) strlen(fcs_port_attr.os_device_name);
-               memcpy(attr->value, fcs_port_attr.os_device_name, attr->len);
-               /* variable fields need to be 4 byte aligned */
-               attr->len = fc_roundup(attr->len, sizeof(u32));
-               curr_ptr += sizeof(attr->type) + sizeof(attr->len) + attr->len;
-               len += attr->len;
-               ++count;
-               attr->len =
-                       bfa_os_htons(attr->len + sizeof(attr->type) +
-                                    sizeof(attr->len));
-
-       }
-       /*
-        * Host Name
-        */
-       if (fcs_port_attr.host_name[0] != '\0') {
-               attr = (struct fdmi_attr_s *) curr_ptr;
-               attr->type = bfa_os_htons(FDMI_PORT_ATTRIB_HOST_NAME);
-               attr->len = (u16) strlen(fcs_port_attr.host_name);
-               memcpy(attr->value, fcs_port_attr.host_name, attr->len);
-               /* variable fields need to be 4 byte aligned */
-               attr->len = fc_roundup(attr->len, sizeof(u32));
-               curr_ptr += sizeof(attr->type) + sizeof(attr->len) + attr->len;
-               len += attr->len;
-               ++count;
-               attr->len =
-                       bfa_os_htons(attr->len + sizeof(attr->type) +
-                                    sizeof(attr->len));
-
-       }
-
-       /*
-        * Update size of payload
-        */
-       port_attrib->attr_count = bfa_os_htonl(count);
-       len += ((sizeof(attr->type) + sizeof(attr->len)) * count);
-       return len;
-}
-
-static          u16
-bfa_fcs_port_fdmi_build_rprt_pyld(struct bfa_fcs_port_fdmi_s *fdmi,
-                                 u8 *pyld)
-{
-       struct bfa_fcs_port_s *port = fdmi->ms->port;
-       struct fdmi_rprt_s    *rprt = (struct fdmi_rprt_s *) pyld;
-       u16        len;
-
-       rprt->hba_id = bfa_fcs_port_get_pwwn(bfa_fcs_get_base_port(port->fcs));
-       rprt->port_name = bfa_fcs_port_get_pwwn(port);
-
-       len = bfa_fcs_port_fdmi_build_portattr_block(fdmi,
-                       (u8 *) &rprt->port_attr_blk);
-
-       len += sizeof(rprt->hba_id) + sizeof(rprt->port_name);
-
-       return len;
-}
-
-static void
-bfa_fcs_port_fdmi_rprt_response(void *fcsarg, struct bfa_fcxp_s *fcxp,
-                               void *cbarg, bfa_status_t req_status,
-                               u32 rsp_len, u32 resid_len,
-                               struct fchs_s *rsp_fchs)
-{
-       struct bfa_fcs_port_fdmi_s *fdmi = (struct bfa_fcs_port_fdmi_s *)cbarg;
-       struct bfa_fcs_port_s *port = fdmi->ms->port;
-       struct ct_hdr_s       *cthdr = NULL;
-
-       bfa_trc(port->fcs, port->port_cfg.pwwn);
-
-       /*
-        * Sanity Checks
-        */
-       if (req_status != BFA_STATUS_OK) {
-               bfa_trc(port->fcs, req_status);
-               bfa_sm_send_event(fdmi, FDMISM_EVENT_RSP_ERROR);
-               return;
-       }
-
-       cthdr = (struct ct_hdr_s *) BFA_FCXP_RSP_PLD(fcxp);
-       cthdr->cmd_rsp_code = bfa_os_ntohs(cthdr->cmd_rsp_code);
-
-       if (cthdr->cmd_rsp_code == CT_RSP_ACCEPT) {
-               bfa_sm_send_event(fdmi, FDMISM_EVENT_RSP_OK);
-               return;
-       }
-
-       bfa_trc(port->fcs, cthdr->reason_code);
-       bfa_trc(port->fcs, cthdr->exp_code);
-       bfa_sm_send_event(fdmi, FDMISM_EVENT_RSP_ERROR);
-}
-
-/**
-*   RPA : Register Port Attributes.
- */
-static void
-bfa_fcs_port_fdmi_send_rpa(void *fdmi_cbarg, struct bfa_fcxp_s *fcxp_alloced)
-{
-       struct bfa_fcs_port_fdmi_s *fdmi = fdmi_cbarg;
-       struct bfa_fcs_port_s *port = fdmi->ms->port;
-       struct fchs_s          fchs;
-       u16        len, attr_len;
-       struct bfa_fcxp_s *fcxp;
-       u8        *pyld;
-
-       bfa_trc(port->fcs, port->port_cfg.pwwn);
-
-       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
-       if (!fcxp) {
-               bfa_fcxp_alloc_wait(port->fcs->bfa, &fdmi->fcxp_wqe,
-                                   bfa_fcs_port_fdmi_send_rpa, fdmi);
-               return;
-       }
-       fdmi->fcxp = fcxp;
-
-       pyld = bfa_fcxp_get_reqbuf(fcxp);
-       bfa_os_memset(pyld, 0, FC_MAX_PDUSZ);
-
-       len = fc_fdmi_reqhdr_build(&fchs, pyld, bfa_fcs_port_get_fcid(port),
-                                  FDMI_RPA);
-
-       attr_len = bfa_fcs_port_fdmi_build_rpa_pyld(fdmi,
-                       (u8 *) ((struct ct_hdr_s *) pyld + 1));
-
-       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
-                     FC_CLASS_3, len + attr_len, &fchs,
-                     bfa_fcs_port_fdmi_rpa_response, (void *)fdmi,
-                     FC_MAX_PDUSZ, FC_FCCT_TOV);
-
-       bfa_sm_send_event(fdmi, FDMISM_EVENT_RPA_SENT);
-}
-
-static          u16
-bfa_fcs_port_fdmi_build_rpa_pyld(struct bfa_fcs_port_fdmi_s *fdmi,
-                                u8 *pyld)
-{
-       struct bfa_fcs_port_s *port = fdmi->ms->port;
-       struct fdmi_rpa_s     *rpa = (struct fdmi_rpa_s *) pyld;
-       u16        len;
-
-       rpa->port_name = bfa_fcs_port_get_pwwn(port);
-
-       len = bfa_fcs_port_fdmi_build_portattr_block(fdmi,
-                       (u8 *) &rpa->port_attr_blk);
-
-       len += sizeof(rpa->port_name);
-
-       return len;
-}
-
-static void
-bfa_fcs_port_fdmi_rpa_response(void *fcsarg, struct bfa_fcxp_s *fcxp,
-                              void *cbarg, bfa_status_t req_status,
-                              u32 rsp_len, u32 resid_len,
-                              struct fchs_s *rsp_fchs)
-{
-       struct bfa_fcs_port_fdmi_s *fdmi = (struct bfa_fcs_port_fdmi_s *)cbarg;
-       struct bfa_fcs_port_s *port = fdmi->ms->port;
-       struct ct_hdr_s       *cthdr = NULL;
-
-       bfa_trc(port->fcs, port->port_cfg.pwwn);
-
-       /*
-        * Sanity Checks
-        */
-       if (req_status != BFA_STATUS_OK) {
-               bfa_trc(port->fcs, req_status);
-               bfa_sm_send_event(fdmi, FDMISM_EVENT_RSP_ERROR);
-               return;
-       }
-
-       cthdr = (struct ct_hdr_s *) BFA_FCXP_RSP_PLD(fcxp);
-       cthdr->cmd_rsp_code = bfa_os_ntohs(cthdr->cmd_rsp_code);
-
-       if (cthdr->cmd_rsp_code == CT_RSP_ACCEPT) {
-               bfa_sm_send_event(fdmi, FDMISM_EVENT_RSP_OK);
-               return;
-       }
-
-       bfa_trc(port->fcs, cthdr->reason_code);
-       bfa_trc(port->fcs, cthdr->exp_code);
-       bfa_sm_send_event(fdmi, FDMISM_EVENT_RSP_ERROR);
-}
-
-static void
-bfa_fcs_port_fdmi_timeout(void *arg)
-{
-       struct bfa_fcs_port_fdmi_s *fdmi = (struct bfa_fcs_port_fdmi_s *)arg;
-
-       bfa_sm_send_event(fdmi, FDMISM_EVENT_TIMEOUT);
-}
-
-static void
-bfa_fcs_fdmi_get_hbaattr(struct bfa_fcs_port_fdmi_s *fdmi,
-                        struct bfa_fcs_fdmi_hba_attr_s *hba_attr)
-{
-       struct bfa_fcs_port_s *port = fdmi->ms->port;
-       struct bfa_fcs_driver_info_s *driver_info = &port->fcs->driver_info;
-
-       bfa_os_memset(hba_attr, 0, sizeof(struct bfa_fcs_fdmi_hba_attr_s));
-
-       bfa_ioc_get_adapter_manufacturer(&port->fcs->bfa->ioc,
-               hba_attr->manufacturer);
-       bfa_ioc_get_adapter_serial_num(&port->fcs->bfa->ioc,
-                                               hba_attr->serial_num);
-       bfa_ioc_get_adapter_model(&port->fcs->bfa->ioc, hba_attr->model);
-       bfa_ioc_get_adapter_model(&port->fcs->bfa->ioc, hba_attr->model_desc);
-       bfa_ioc_get_pci_chip_rev(&port->fcs->bfa->ioc, hba_attr->hw_version);
-       bfa_ioc_get_adapter_optrom_ver(&port->fcs->bfa->ioc,
-               hba_attr->option_rom_ver);
-       bfa_ioc_get_adapter_fw_ver(&port->fcs->bfa->ioc, hba_attr->fw_version);
-
-       strncpy(hba_attr->driver_version, (char *)driver_info->version,
-               sizeof(hba_attr->driver_version));
-
-       strncpy(hba_attr->os_name, driver_info->host_os_name,
-               sizeof(hba_attr->os_name));
-
-       /*
-        * If there is a patch level, append it to the os name along with a
-        * separator
-        */
-       if (driver_info->host_os_patch[0] != '\0') {
-               strncat(hba_attr->os_name, BFA_FCS_PORT_SYMBNAME_SEPARATOR,
-                       sizeof(BFA_FCS_PORT_SYMBNAME_SEPARATOR));
-               strncat(hba_attr->os_name, driver_info->host_os_patch,
-                       sizeof(driver_info->host_os_patch));
-       }
-
-       hba_attr->max_ct_pyld = bfa_os_htonl(FC_MAX_PDUSZ);
-
-}
-
-static void
-bfa_fcs_fdmi_get_portattr(struct bfa_fcs_port_fdmi_s *fdmi,
-                         struct bfa_fcs_fdmi_port_attr_s *port_attr)
-{
-       struct bfa_fcs_port_s *port = fdmi->ms->port;
-       struct bfa_fcs_driver_info_s *driver_info = &port->fcs->driver_info;
-       struct bfa_pport_attr_s pport_attr;
-
-       bfa_os_memset(port_attr, 0, sizeof(struct bfa_fcs_fdmi_port_attr_s));
-
-       /*
-        * get pport attributes from hal
-        */
-       bfa_fcport_get_attr(port->fcs->bfa, &pport_attr);
-
-       /*
-        * get FC4 type Bitmask
-        */
-       fc_get_fc4type_bitmask(FC_TYPE_FCP, port_attr->supp_fc4_types);
-
-       /*
-        * Supported Speeds
-        */
-       port_attr->supp_speed = bfa_os_htonl(BFA_FCS_FDMI_SUPORTED_SPEEDS);
-
-       /*
-        * Current Speed
-        */
-       port_attr->curr_speed = bfa_os_htonl(pport_attr.speed);
-
-       /*
-        * Max PDU Size.
-        */
-       port_attr->max_frm_size = bfa_os_htonl(FC_MAX_PDUSZ);
-
-       /*
-        * OS device Name
-        */
-       strncpy(port_attr->os_device_name, (char *)driver_info->os_device_name,
-               sizeof(port_attr->os_device_name));
-
-       /*
-        * Host name
-        */
-       strncpy(port_attr->host_name, (char *)driver_info->host_machine_name,
-               sizeof(port_attr->host_name));
-
-}
-
-
-void
-bfa_fcs_port_fdmi_init(struct bfa_fcs_port_ms_s *ms)
-{
-       struct bfa_fcs_port_fdmi_s *fdmi = &ms->fdmi;
-
-       fdmi->ms = ms;
-       if (ms->port->fcs->fdmi_enabled)
-               bfa_sm_set_state(fdmi, bfa_fcs_port_fdmi_sm_offline);
-       else
-               bfa_sm_set_state(fdmi, bfa_fcs_port_fdmi_sm_disabled);
-}
-
-void
-bfa_fcs_port_fdmi_offline(struct bfa_fcs_port_ms_s *ms)
-{
-       struct bfa_fcs_port_fdmi_s *fdmi = &ms->fdmi;
-
-       fdmi->ms = ms;
-       bfa_sm_send_event(fdmi, FDMISM_EVENT_PORT_OFFLINE);
-}
-
-void
-bfa_fcs_port_fdmi_online(struct bfa_fcs_port_ms_s *ms)
-{
-       struct bfa_fcs_port_fdmi_s *fdmi = &ms->fdmi;
-
-       fdmi->ms = ms;
-       bfa_sm_send_event(fdmi, FDMISM_EVENT_PORT_ONLINE);
-}
diff --git a/drivers/scsi/bfa/include/aen/bfa_aen.h b/drivers/scsi/bfa/include/aen/bfa_aen.h
deleted file mode 100644 (file)
index 6abbab0..0000000
+++ /dev/null
@@ -1,96 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-#ifndef __BFA_AEN_H__
-#define __BFA_AEN_H__
-
-#include "defs/bfa_defs_aen.h"
-#include "defs/bfa_defs_status.h"
-#include "cs/bfa_debug.h"
-
-#define BFA_AEN_MAX_ENTRY      512
-
-extern int bfa_aen_max_cfg_entry;
-struct bfa_aen_s {
-       void            *bfad;
-       int             max_entry;
-       int             write_index;
-       int             read_index;
-       int             bfad_num;
-       int             seq_num;
-       void            (*aen_cb_notify)(void *bfad);
-       void            (*gettimeofday)(struct bfa_timeval_s *tv);
-       struct bfa_trc_mod_s *trcmod;
-       int             app_ri[BFA_AEN_MAX_APP]; /* For multiclient support */
-       struct bfa_aen_entry_s list[BFA_AEN_MAX_ENTRY]; /* Must be the last */
-};
-
-
-/**
- * Public APIs
- */
-static inline void
-bfa_aen_set_max_cfg_entry(int max_entry)
-{
-       bfa_aen_max_cfg_entry = max_entry;
-}
-
-static inline int
-bfa_aen_get_max_cfg_entry(void)
-{
-       return bfa_aen_max_cfg_entry;
-}
-
-static inline int
-bfa_aen_get_meminfo(void)
-{
-       return sizeof(struct bfa_aen_entry_s) * bfa_aen_get_max_cfg_entry();
-}
-
-static inline int
-bfa_aen_get_wi(struct bfa_aen_s *aen)
-{
-       return aen->write_index;
-}
-
-static inline int
-bfa_aen_get_ri(struct bfa_aen_s *aen)
-{
-       return aen->read_index;
-}
-
-static inline int
-bfa_aen_fetch_count(struct bfa_aen_s *aen, enum bfa_aen_app  app_id)
-{
-       bfa_assert((app_id < BFA_AEN_MAX_APP) && (app_id >= bfa_aen_app_bcu));
-       return ((aen->write_index + aen->max_entry) - aen->app_ri[app_id])
-               % aen->max_entry;
-}
-
-int bfa_aen_init(struct bfa_aen_s *aen, struct bfa_trc_mod_s *trcmod,
-               void *bfad, int bfad_num, void (*aen_cb_notify)(void *),
-               void (*gettimeofday)(struct bfa_timeval_s *));
-
-void bfa_aen_post(struct bfa_aen_s *aen, enum bfa_aen_category aen_category,
-                    int aen_type, union bfa_aen_data_u *aen_data);
-
-bfa_status_t bfa_aen_fetch(struct bfa_aen_s *aen,
-                       struct bfa_aen_entry_s *aen_entry,
-                       int entry_req, enum bfa_aen_app app_id, int *entry_ret);
-
-int bfa_aen_get_inst(struct bfa_aen_s *aen);
-
-#endif /* __BFA_AEN_H__ */
diff --git a/drivers/scsi/bfa/include/aen/bfa_aen_adapter.h b/drivers/scsi/bfa/include/aen/bfa_aen_adapter.h
deleted file mode 100644 (file)
index 260d3ea..0000000
+++ /dev/null
@@ -1,31 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/* messages define for BFA_AEN_CAT_ADAPTER Module */
-#ifndef        __bfa_aen_adapter_h__
-#define        __bfa_aen_adapter_h__
-
-#include  <cs/bfa_log.h>
-#include  <defs/bfa_defs_aen.h>
-
-#define BFA_AEN_ADAPTER_ADD \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_ADAPTER, BFA_ADAPTER_AEN_ADD)
-#define BFA_AEN_ADAPTER_REMOVE \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_ADAPTER, BFA_ADAPTER_AEN_REMOVE)
-
-#endif
-
diff --git a/drivers/scsi/bfa/include/aen/bfa_aen_audit.h b/drivers/scsi/bfa/include/aen/bfa_aen_audit.h
deleted file mode 100644 (file)
index 12cd7aa..0000000
+++ /dev/null
@@ -1,31 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/* messages define for BFA_AEN_CAT_AUDIT Module */
-#ifndef        __bfa_aen_audit_h__
-#define        __bfa_aen_audit_h__
-
-#include  <cs/bfa_log.h>
-#include  <defs/bfa_defs_aen.h>
-
-#define BFA_AEN_AUDIT_AUTH_ENABLE \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_AUDIT, BFA_AUDIT_AEN_AUTH_ENABLE)
-#define BFA_AEN_AUDIT_AUTH_DISABLE \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_AUDIT, BFA_AUDIT_AEN_AUTH_DISABLE)
-
-#endif
-
diff --git a/drivers/scsi/bfa/include/aen/bfa_aen_ethport.h b/drivers/scsi/bfa/include/aen/bfa_aen_ethport.h
deleted file mode 100644 (file)
index 507d0b5..0000000
+++ /dev/null
@@ -1,35 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/* messages define for BFA_AEN_CAT_ETHPORT Module */
-#ifndef        __bfa_aen_ethport_h__
-#define        __bfa_aen_ethport_h__
-
-#include  <cs/bfa_log.h>
-#include  <defs/bfa_defs_aen.h>
-
-#define BFA_AEN_ETHPORT_LINKUP \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_ETHPORT, BFA_ETHPORT_AEN_LINKUP)
-#define BFA_AEN_ETHPORT_LINKDOWN \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_ETHPORT, BFA_ETHPORT_AEN_LINKDOWN)
-#define BFA_AEN_ETHPORT_ENABLE \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_ETHPORT, BFA_ETHPORT_AEN_ENABLE)
-#define BFA_AEN_ETHPORT_DISABLE \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_ETHPORT, BFA_ETHPORT_AEN_DISABLE)
-
-#endif
-
diff --git a/drivers/scsi/bfa/include/aen/bfa_aen_ioc.h b/drivers/scsi/bfa/include/aen/bfa_aen_ioc.h
deleted file mode 100644 (file)
index 4daf96f..0000000
+++ /dev/null
@@ -1,45 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/* messages define for BFA_AEN_CAT_IOC Module */
-#ifndef        __bfa_aen_ioc_h__
-#define        __bfa_aen_ioc_h__
-
-#include  <cs/bfa_log.h>
-#include  <defs/bfa_defs_aen.h>
-
-#define BFA_AEN_IOC_HBGOOD \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_IOC, BFA_IOC_AEN_HBGOOD)
-#define BFA_AEN_IOC_HBFAIL \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_IOC, BFA_IOC_AEN_HBFAIL)
-#define BFA_AEN_IOC_ENABLE \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_IOC, BFA_IOC_AEN_ENABLE)
-#define BFA_AEN_IOC_DISABLE \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_IOC, BFA_IOC_AEN_DISABLE)
-#define BFA_AEN_IOC_FWMISMATCH \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_IOC, BFA_IOC_AEN_FWMISMATCH)
-#define BFA_AEN_IOC_FWCFG_ERROR \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_IOC, BFA_IOC_AEN_FWCFG_ERROR)
-#define BFA_AEN_IOC_INVALID_VENDOR      \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_IOC, BFA_IOC_AEN_INVALID_VENDOR)
-#define BFA_AEN_IOC_INVALID_NWWN        \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_IOC, BFA_IOC_AEN_INVALID_NWWN)
-#define BFA_AEN_IOC_INVALID_PWWN        \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_IOC, BFA_IOC_AEN_INVALID_PWWN)
-
-#endif
-
diff --git a/drivers/scsi/bfa/include/aen/bfa_aen_itnim.h b/drivers/scsi/bfa/include/aen/bfa_aen_itnim.h
deleted file mode 100644 (file)
index a7d8ddc..0000000
+++ /dev/null
@@ -1,33 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/* messages define for BFA_AEN_CAT_ITNIM Module */
-#ifndef        __bfa_aen_itnim_h__
-#define        __bfa_aen_itnim_h__
-
-#include  <cs/bfa_log.h>
-#include  <defs/bfa_defs_aen.h>
-
-#define BFA_AEN_ITNIM_ONLINE \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_ITNIM, BFA_ITNIM_AEN_ONLINE)
-#define BFA_AEN_ITNIM_OFFLINE \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_ITNIM, BFA_ITNIM_AEN_OFFLINE)
-#define BFA_AEN_ITNIM_DISCONNECT \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_ITNIM, BFA_ITNIM_AEN_DISCONNECT)
-
-#endif
-
diff --git a/drivers/scsi/bfa/include/aen/bfa_aen_lport.h b/drivers/scsi/bfa/include/aen/bfa_aen_lport.h
deleted file mode 100644 (file)
index 5a8ebb6..0000000
+++ /dev/null
@@ -1,51 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/* messages define for BFA_AEN_CAT_LPORT Module */
-#ifndef        __bfa_aen_lport_h__
-#define        __bfa_aen_lport_h__
-
-#include  <cs/bfa_log.h>
-#include  <defs/bfa_defs_aen.h>
-
-#define BFA_AEN_LPORT_NEW \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_LPORT, BFA_LPORT_AEN_NEW)
-#define BFA_AEN_LPORT_DELETE \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_LPORT, BFA_LPORT_AEN_DELETE)
-#define BFA_AEN_LPORT_ONLINE \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_LPORT, BFA_LPORT_AEN_ONLINE)
-#define BFA_AEN_LPORT_OFFLINE \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_LPORT, BFA_LPORT_AEN_OFFLINE)
-#define BFA_AEN_LPORT_DISCONNECT \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_LPORT, BFA_LPORT_AEN_DISCONNECT)
-#define BFA_AEN_LPORT_NEW_PROP \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_LPORT, BFA_LPORT_AEN_NEW_PROP)
-#define BFA_AEN_LPORT_DELETE_PROP \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_LPORT, BFA_LPORT_AEN_DELETE_PROP)
-#define BFA_AEN_LPORT_NEW_STANDARD \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_LPORT, BFA_LPORT_AEN_NEW_STANDARD)
-#define BFA_AEN_LPORT_DELETE_STANDARD \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_LPORT, BFA_LPORT_AEN_DELETE_STANDARD)
-#define BFA_AEN_LPORT_NPIV_DUP_WWN \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_LPORT, BFA_LPORT_AEN_NPIV_DUP_WWN)
-#define BFA_AEN_LPORT_NPIV_FABRIC_MAX \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_LPORT, BFA_LPORT_AEN_NPIV_FABRIC_MAX)
-#define BFA_AEN_LPORT_NPIV_UNKNOWN \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_LPORT, BFA_LPORT_AEN_NPIV_UNKNOWN)
-
-#endif
-
diff --git a/drivers/scsi/bfa/include/aen/bfa_aen_port.h b/drivers/scsi/bfa/include/aen/bfa_aen_port.h
deleted file mode 100644 (file)
index 9add905..0000000
+++ /dev/null
@@ -1,57 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/* messages define for BFA_AEN_CAT_PORT Module */
-#ifndef        __bfa_aen_port_h__
-#define        __bfa_aen_port_h__
-
-#include  <cs/bfa_log.h>
-#include  <defs/bfa_defs_aen.h>
-
-#define BFA_AEN_PORT_ONLINE \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_PORT, BFA_PORT_AEN_ONLINE)
-#define BFA_AEN_PORT_OFFLINE \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_PORT, BFA_PORT_AEN_OFFLINE)
-#define BFA_AEN_PORT_RLIR \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_PORT, BFA_PORT_AEN_RLIR)
-#define BFA_AEN_PORT_SFP_INSERT \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_PORT, BFA_PORT_AEN_SFP_INSERT)
-#define BFA_AEN_PORT_SFP_REMOVE \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_PORT, BFA_PORT_AEN_SFP_REMOVE)
-#define BFA_AEN_PORT_SFP_POM \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_PORT, BFA_PORT_AEN_SFP_POM)
-#define BFA_AEN_PORT_ENABLE \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_PORT, BFA_PORT_AEN_ENABLE)
-#define BFA_AEN_PORT_DISABLE \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_PORT, BFA_PORT_AEN_DISABLE)
-#define BFA_AEN_PORT_AUTH_ON \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_PORT, BFA_PORT_AEN_AUTH_ON)
-#define BFA_AEN_PORT_AUTH_OFF \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_PORT, BFA_PORT_AEN_AUTH_OFF)
-#define BFA_AEN_PORT_DISCONNECT \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_PORT, BFA_PORT_AEN_DISCONNECT)
-#define BFA_AEN_PORT_QOS_NEG \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_PORT, BFA_PORT_AEN_QOS_NEG)
-#define BFA_AEN_PORT_FABRIC_NAME_CHANGE \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_PORT, BFA_PORT_AEN_FABRIC_NAME_CHANGE)
-#define BFA_AEN_PORT_SFP_ACCESS_ERROR \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_PORT, BFA_PORT_AEN_SFP_ACCESS_ERROR)
-#define BFA_AEN_PORT_SFP_UNSUPPORT \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_PORT, BFA_PORT_AEN_SFP_UNSUPPORT)
-
-#endif
-
diff --git a/drivers/scsi/bfa/include/aen/bfa_aen_rport.h b/drivers/scsi/bfa/include/aen/bfa_aen_rport.h
deleted file mode 100644 (file)
index 7e4be1f..0000000
+++ /dev/null
@@ -1,37 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/* messages define for BFA_AEN_CAT_RPORT Module */
-#ifndef        __bfa_aen_rport_h__
-#define        __bfa_aen_rport_h__
-
-#include  <cs/bfa_log.h>
-#include  <defs/bfa_defs_aen.h>
-
-#define BFA_AEN_RPORT_ONLINE \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_RPORT, BFA_RPORT_AEN_ONLINE)
-#define BFA_AEN_RPORT_OFFLINE \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_RPORT, BFA_RPORT_AEN_OFFLINE)
-#define BFA_AEN_RPORT_DISCONNECT \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_RPORT, BFA_RPORT_AEN_DISCONNECT)
-#define BFA_AEN_RPORT_QOS_PRIO \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_RPORT, BFA_RPORT_AEN_QOS_PRIO)
-#define BFA_AEN_RPORT_QOS_FLOWID \
-       BFA_LOG_CREATE_ID(BFA_AEN_CAT_RPORT, BFA_RPORT_AEN_QOS_FLOWID)
-
-#endif
-
diff --git a/drivers/scsi/bfa/include/bfa.h b/drivers/scsi/bfa/include/bfa.h
deleted file mode 100644 (file)
index d52b32f..0000000
+++ /dev/null
@@ -1,203 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-#ifndef __BFA_H__
-#define __BFA_H__
-
-#include <bfa_os_inc.h>
-#include <cs/bfa_debug.h>
-#include <cs/bfa_q.h>
-#include <cs/bfa_trc.h>
-#include <cs/bfa_log.h>
-#include <cs/bfa_plog.h>
-#include <defs/bfa_defs_status.h>
-#include <defs/bfa_defs_ioc.h>
-#include <defs/bfa_defs_iocfc.h>
-#include <aen/bfa_aen.h>
-#include <bfi/bfi.h>
-
-struct bfa_s;
-#include <bfa_intr_priv.h>
-
-struct bfa_pcidev_s;
-
-/**
- * PCI devices supported by the current BFA
- */
-struct bfa_pciid_s {
-       u16        device_id;
-       u16        vendor_id;
-};
-
-extern char     bfa_version[];
-
-/**
- * BFA Power Mgmt Commands
- */
-enum bfa_pm_cmd {
-       BFA_PM_CTL_D0 = 0,
-       BFA_PM_CTL_D1 = 1,
-       BFA_PM_CTL_D2 = 2,
-       BFA_PM_CTL_D3 = 3,
-};
-
-/**
- * BFA memory resources
- */
-enum bfa_mem_type {
-       BFA_MEM_TYPE_KVA = 1,   /*! Kernel Virtual Memory *(non-dma-able) */
-       BFA_MEM_TYPE_DMA = 2,   /*! DMA-able memory */
-       BFA_MEM_TYPE_MAX = BFA_MEM_TYPE_DMA,
-};
-
-struct bfa_mem_elem_s {
-       enum bfa_mem_type mem_type;     /*  see enum bfa_mem_type       */
-       u32        mem_len;     /*  Total Length in Bytes       */
-       u8              *kva;           /*  kernel virtual address      */
-       u64        dma;         /*  dma address if DMA memory   */
-       u8              *kva_curp;      /*  kva allocation cursor       */
-       u64        dma_curp;    /*  dma allocation cursor       */
-};
-
-struct bfa_meminfo_s {
-       struct bfa_mem_elem_s meminfo[BFA_MEM_TYPE_MAX];
-};
-#define bfa_meminfo_kva(_m)    \
-       ((_m)->meminfo[BFA_MEM_TYPE_KVA - 1].kva_curp)
-#define bfa_meminfo_dma_virt(_m)       \
-       ((_m)->meminfo[BFA_MEM_TYPE_DMA - 1].kva_curp)
-#define bfa_meminfo_dma_phys(_m)       \
-       ((_m)->meminfo[BFA_MEM_TYPE_DMA - 1].dma_curp)
-
-/**
- * Generic Scatter Gather Element used by driver
- */
-struct bfa_sge_s {
-       u32        sg_len;
-       void           *sg_addr;
-};
-
-#define bfa_sge_to_be(__sge) do {                                          \
-       ((u32 *)(__sge))[0] = bfa_os_htonl(((u32 *)(__sge))[0]);      \
-       ((u32 *)(__sge))[1] = bfa_os_htonl(((u32 *)(__sge))[1]);      \
-       ((u32 *)(__sge))[2] = bfa_os_htonl(((u32 *)(__sge))[2]);      \
-} while (0)
-
-
-/*
- * bfa stats interfaces
- */
-#define bfa_stats(_mod, _stats)        ((_mod)->stats._stats++)
-
-#define bfa_ioc_get_stats(__bfa, __ioc_stats)  \
-       bfa_ioc_fetch_stats(&(__bfa)->ioc, __ioc_stats)
-#define bfa_ioc_clear_stats(__bfa)     \
-       bfa_ioc_clr_stats(&(__bfa)->ioc)
-#define bfa_get_nports(__bfa)   \
-       bfa_ioc_get_nports(&(__bfa)->ioc)
-#define bfa_get_adapter_manufacturer(__bfa, __manufacturer) \
-       bfa_ioc_get_adapter_manufacturer(&(__bfa)->ioc, __manufacturer)
-#define bfa_get_adapter_model(__bfa, __model)   \
-       bfa_ioc_get_adapter_model(&(__bfa)->ioc, __model)
-#define bfa_get_adapter_serial_num(__bfa, __serial_num) \
-       bfa_ioc_get_adapter_serial_num(&(__bfa)->ioc, __serial_num)
-#define bfa_get_adapter_fw_ver(__bfa, __fw_ver) \
-       bfa_ioc_get_adapter_fw_ver(&(__bfa)->ioc, __fw_ver)
-#define bfa_get_adapter_optrom_ver(__bfa, __optrom_ver) \
-       bfa_ioc_get_adapter_optrom_ver(&(__bfa)->ioc, __optrom_ver)
-#define bfa_get_pci_chip_rev(__bfa, __chip_rev) \
-       bfa_ioc_get_pci_chip_rev(&(__bfa)->ioc, __chip_rev)
-#define bfa_get_ioc_state(__bfa)    \
-       bfa_ioc_get_state(&(__bfa)->ioc)
-#define bfa_get_type(__bfa) \
-       bfa_ioc_get_type(&(__bfa)->ioc)
-#define bfa_get_mac(__bfa)  \
-       bfa_ioc_get_mac(&(__bfa)->ioc)
-#define bfa_get_mfg_mac(__bfa)  \
-       bfa_ioc_get_mfg_mac(&(__bfa)->ioc)
-#define bfa_get_fw_clock_res(__bfa)    \
-       ((__bfa)->iocfc.cfgrsp->fwcfg.fw_tick_res)
-
-/*
- * bfa API functions
- */
-void bfa_get_pciids(struct bfa_pciid_s **pciids, int *npciids);
-void bfa_cfg_get_default(struct bfa_iocfc_cfg_s *cfg);
-void bfa_cfg_get_min(struct bfa_iocfc_cfg_s *cfg);
-void bfa_cfg_get_meminfo(struct bfa_iocfc_cfg_s *cfg,
-                       struct bfa_meminfo_s *meminfo);
-void bfa_attach(struct bfa_s *bfa, void *bfad, struct bfa_iocfc_cfg_s *cfg,
-                       struct bfa_meminfo_s *meminfo,
-                       struct bfa_pcidev_s *pcidev);
-void bfa_init_trc(struct bfa_s *bfa, struct bfa_trc_mod_s *trcmod);
-void bfa_init_log(struct bfa_s *bfa, struct bfa_log_mod_s *logmod);
-void bfa_init_aen(struct bfa_s *bfa, struct bfa_aen_s *aen);
-void bfa_init_plog(struct bfa_s *bfa, struct bfa_plog_s *plog);
-void bfa_detach(struct bfa_s *bfa);
-void bfa_init(struct bfa_s *bfa);
-void bfa_start(struct bfa_s *bfa);
-void bfa_stop(struct bfa_s *bfa);
-void bfa_attach_fcs(struct bfa_s *bfa);
-void bfa_cb_init(void *bfad, bfa_status_t status);
-void bfa_cb_stop(void *bfad, bfa_status_t status);
-void bfa_cb_updateq(void *bfad, bfa_status_t status);
-
-bfa_boolean_t bfa_intx(struct bfa_s *bfa);
-void bfa_isr_enable(struct bfa_s *bfa);
-void bfa_isr_disable(struct bfa_s *bfa);
-void bfa_msix_getvecs(struct bfa_s *bfa, u32 *msix_vecs_bmap,
-                       u32 *num_vecs, u32 *max_vec_bit);
-#define bfa_msix(__bfa, __vec) ((__bfa)->msix.handler[__vec](__bfa, __vec))
-
-void bfa_comp_deq(struct bfa_s *bfa, struct list_head *comp_q);
-void bfa_comp_process(struct bfa_s *bfa, struct list_head *comp_q);
-void bfa_comp_free(struct bfa_s *bfa, struct list_head *comp_q);
-
-typedef void (*bfa_cb_ioc_t) (void *cbarg, enum bfa_status status);
-void bfa_iocfc_get_attr(struct bfa_s *bfa, struct bfa_iocfc_attr_s *attr);
-bfa_status_t bfa_iocfc_get_stats(struct bfa_s *bfa,
-                       struct bfa_iocfc_stats_s *stats,
-                       bfa_cb_ioc_t cbfn, void *cbarg);
-bfa_status_t bfa_iocfc_clear_stats(struct bfa_s *bfa,
-                       bfa_cb_ioc_t cbfn, void *cbarg);
-void bfa_get_attr(struct bfa_s *bfa, struct bfa_ioc_attr_s *ioc_attr);
-
-void bfa_adapter_get_attr(struct bfa_s *bfa,
-                       struct bfa_adapter_attr_s *ad_attr);
-u64 bfa_adapter_get_id(struct bfa_s *bfa);
-
-bfa_status_t bfa_iocfc_israttr_set(struct bfa_s *bfa,
-                       struct bfa_iocfc_intr_attr_s *attr);
-
-void bfa_iocfc_enable(struct bfa_s *bfa);
-void bfa_iocfc_disable(struct bfa_s *bfa);
-void bfa_ioc_auto_recover(bfa_boolean_t auto_recover);
-void bfa_chip_reset(struct bfa_s *bfa);
-void bfa_cb_ioc_disable(void *bfad);
-void bfa_timer_tick(struct bfa_s *bfa);
-#define bfa_timer_start(_bfa, _timer, _timercb, _arg, _timeout)        \
-       bfa_timer_begin(&(_bfa)->timer_mod, _timer, _timercb, _arg, _timeout)
-
-/*
- * BFA debug API functions
- */
-bfa_status_t bfa_debug_fwtrc(struct bfa_s *bfa, void *trcdata, int *trclen);
-bfa_status_t bfa_debug_fwsave(struct bfa_s *bfa, void *trcdata, int *trclen);
-void bfa_debug_fwsave_clear(struct bfa_s *bfa);
-
-#include "bfa_priv.h"
-
-#endif /* __BFA_H__ */
diff --git a/drivers/scsi/bfa/include/bfa_fcpim.h b/drivers/scsi/bfa/include/bfa_fcpim.h
deleted file mode 100644 (file)
index 4bc9453..0000000
+++ /dev/null
@@ -1,177 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_FCPIM_H__
-#define __BFA_FCPIM_H__
-
-#include <bfa.h>
-#include <bfa_svc.h>
-#include <bfi/bfi_fcpim.h>
-#include <defs/bfa_defs_fcpim.h>
-
-/*
- * forward declarations
- */
-struct bfa_itnim_s;
-struct bfa_ioim_s;
-struct bfa_tskim_s;
-struct bfad_ioim_s;
-struct bfad_tskim_s;
-
-/*
- * bfa fcpim module API functions
- */
-void           bfa_fcpim_path_tov_set(struct bfa_s *bfa, u16 path_tov);
-u16    bfa_fcpim_path_tov_get(struct bfa_s *bfa);
-void           bfa_fcpim_qdepth_set(struct bfa_s *bfa, u16 q_depth);
-u16    bfa_fcpim_qdepth_get(struct bfa_s *bfa);
-bfa_status_t bfa_fcpim_get_modstats(struct bfa_s *bfa,
-                       struct bfa_fcpim_stats_s *modstats);
-bfa_status_t bfa_fcpim_clr_modstats(struct bfa_s *bfa);
-void bfa_fcpim_set_ioredirect(struct bfa_s *bfa, bfa_boolean_t state);
-void bfa_fcpim_update_ioredirect(struct bfa_s *bfa);
-void bfa_cb_ioredirect_state_change(void *hcb_bfad, bfa_boolean_t ioredirect);
-
-#define bfa_fcpim_ioredirect_enabled(__bfa)                             \
-       (((struct bfa_fcpim_mod_s *)(BFA_FCPIM_MOD(__bfa)))->ioredirect)
-
-#define bfa_fcpim_get_next_reqq(__bfa, __qid)                           \
-{                                                                       \
-       struct bfa_fcpim_mod_s *__fcpim = BFA_FCPIM_MOD(__bfa);         \
-       __fcpim->reqq++;                                                \
-       __fcpim->reqq &= (BFI_IOC_MAX_CQS - 1);                          \
-       *(__qid) = __fcpim->reqq;                                       \
-}
-
-#define bfa_iocfc_map_msg_to_qid(__msg, __qid)                          \
-       *(__qid) = (u8)((__msg) & (BFI_IOC_MAX_CQS - 1));
-
-
-/*
- * bfa itnim API functions
- */
-struct bfa_itnim_s *bfa_itnim_create(struct bfa_s *bfa,
-                                       struct bfa_rport_s *rport, void *itnim);
-void           bfa_itnim_delete(struct bfa_itnim_s *itnim);
-void           bfa_itnim_online(struct bfa_itnim_s *itnim,
-                                bfa_boolean_t seq_rec);
-void           bfa_itnim_offline(struct bfa_itnim_s *itnim);
-void           bfa_itnim_get_stats(struct bfa_itnim_s *itnim,
-                       struct bfa_itnim_hal_stats_s *stats);
-void           bfa_itnim_clear_stats(struct bfa_itnim_s *itnim);
-
-#define bfa_itnim_get_reqq(__ioim) (((struct bfa_ioim_s *)__ioim)->itnim->reqq)
-
-/**
- *             BFA completion callback for bfa_itnim_online().
- *
- * @param[in]          itnim           FCS or driver itnim instance
- *
- * return None
- */
-void            bfa_cb_itnim_online(void *itnim);
-
-/**
- *             BFA completion callback for bfa_itnim_offline().
- *
- * @param[in]          itnim           FCS or driver itnim instance
- *
- * return None
- */
-void            bfa_cb_itnim_offline(void *itnim);
-void            bfa_cb_itnim_tov_begin(void *itnim);
-void            bfa_cb_itnim_tov(void *itnim);
-
-/**
- *             BFA notification to FCS/driver for second level error recovery.
- *
- * Atleast one I/O request has timedout and target is unresponsive to
- * repeated abort requests. Second level error recovery should be initiated
- * by starting implicit logout and recovery procedures.
- *
- * @param[in]          itnim           FCS or driver itnim instance
- *
- * return None
- */
-void            bfa_cb_itnim_sler(void *itnim);
-
-/*
- * bfa ioim API functions
- */
-struct bfa_ioim_s      *bfa_ioim_alloc(struct bfa_s *bfa,
-                                       struct bfad_ioim_s *dio,
-                                       struct bfa_itnim_s *itnim,
-                                       u16 nsgles);
-
-void           bfa_ioim_free(struct bfa_ioim_s *ioim);
-void           bfa_ioim_start(struct bfa_ioim_s *ioim);
-void           bfa_ioim_abort(struct bfa_ioim_s *ioim);
-void           bfa_ioim_delayed_comp(struct bfa_ioim_s *ioim,
-                                     bfa_boolean_t iotov);
-
-
-/**
- *             I/O completion notification.
- *
- * @param[in]          dio                     driver IO structure
- * @param[in]          io_status               IO completion status
- * @param[in]          scsi_status             SCSI status returned by target
- * @param[in]          sns_len                 SCSI sense length, 0 if none
- * @param[in]          sns_info                SCSI sense data, if any
- * @param[in]          residue                 Residual length
- *
- * @return None
- */
-void            bfa_cb_ioim_done(void *bfad, struct bfad_ioim_s *dio,
-                                 enum bfi_ioim_status io_status,
-                                 u8 scsi_status, int sns_len,
-                                 u8 *sns_info, s32 residue);
-
-/**
- *             I/O good completion notification.
- *
- * @param[in]          dio                     driver IO structure
- *
- * @return None
- */
-void            bfa_cb_ioim_good_comp(void *bfad, struct bfad_ioim_s *dio);
-
-/**
- *             I/O abort completion notification
- *
- * @param[in]          dio                     driver IO that was aborted
- *
- * @return None
- */
-void            bfa_cb_ioim_abort(void *bfad, struct bfad_ioim_s *dio);
-void           bfa_cb_ioim_resfree(void *hcb_bfad);
-
-void                   bfa_cb_ioim_resfree(void *hcb_bfad);
-
-/*
- * bfa tskim API functions
- */
-struct bfa_tskim_s     *bfa_tskim_alloc(struct bfa_s *bfa,
-                                       struct bfad_tskim_s *dtsk);
-void           bfa_tskim_free(struct bfa_tskim_s *tskim);
-void           bfa_tskim_start(struct bfa_tskim_s *tskim,
-                               struct bfa_itnim_s *itnim, lun_t lun,
-                               enum fcp_tm_cmnd tm, u8 t_secs);
-void           bfa_cb_tskim_done(void *bfad, struct bfad_tskim_s *dtsk,
-                                 enum bfi_tskim_status tsk_status);
-
-#endif /* __BFA_FCPIM_H__ */
diff --git a/drivers/scsi/bfa/include/bfa_fcptm.h b/drivers/scsi/bfa/include/bfa_fcptm.h
deleted file mode 100644 (file)
index 5f5ffe0..0000000
+++ /dev/null
@@ -1,47 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_FCPTM_H__
-#define __BFA_FCPTM_H__
-
-#include <bfa.h>
-#include <bfa_svc.h>
-#include <bfi/bfi_fcptm.h>
-
-/*
- * forward declarations
- */
-struct bfa_tin_s;
-struct bfa_iotm_s;
-struct bfa_tsktm_s;
-
-/*
- * bfa fcptm module API functions
- */
-void bfa_fcptm_path_tov_set(struct bfa_s *bfa, u16 path_tov);
-u16 bfa_fcptm_path_tov_get(struct bfa_s *bfa);
-void bfa_fcptm_qdepth_set(struct bfa_s *bfa, u16 q_depth);
-u16 bfa_fcptm_qdepth_get(struct bfa_s *bfa);
-
-/*
- * bfa tin API functions
- */
-void bfa_tin_get_stats(struct bfa_tin_s *tin, struct bfa_tin_stats_s *stats);
-void bfa_tin_clear_stats(struct bfa_tin_s *tin);
-
-#endif /* __BFA_FCPTM_H__ */
-
diff --git a/drivers/scsi/bfa/include/bfa_svc.h b/drivers/scsi/bfa/include/bfa_svc.h
deleted file mode 100644 (file)
index 7840943..0000000
+++ /dev/null
@@ -1,338 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-#ifndef __BFA_SVC_H__
-#define __BFA_SVC_H__
-
-/*
- * forward declarations
- */
-struct bfa_fcxp_s;
-
-#include <defs/bfa_defs_status.h>
-#include <defs/bfa_defs_pport.h>
-#include <defs/bfa_defs_rport.h>
-#include <defs/bfa_defs_qos.h>
-#include <defs/bfa_defs_fcport.h>
-#include <cs/bfa_sm.h>
-#include <bfa.h>
-
-/**
- *             BFA rport information.
- */
-struct bfa_rport_info_s {
-       u16        max_frmsz;   /*  max rcv pdu size               */
-       u32        pid:24,              /*  remote port ID                 */
-                       lp_tag:8;       /*  tag                     */
-       u32        local_pid:24,        /*  local port ID                   */
-                       cisc:8;         /*  CIRO supported                  */
-       u8         fc_class;    /*  supported FC classes. enum fc_cos */
-       u8         vf_en;               /*  virtual fabric enable          */
-       u16        vf_id;               /*  virtual fabric ID              */
-       enum bfa_pport_speed speed;     /*  Rport's current speed           */
-};
-
-/**
- * BFA rport data structure
- */
-struct bfa_rport_s {
-       struct list_head        qe;       /*  queue element */
-       bfa_sm_t              sm;         /*  state machine */
-       struct bfa_s          *bfa;       /*  backpointer to BFA */
-       void                  *rport_drv; /*  fcs/driver rport object */
-       u16              fw_handle; /*  firmware rport handle */
-       u16              rport_tag; /*  BFA rport tag */
-       struct bfa_rport_info_s rport_info; /*  rport info from fcs/driver */
-       struct bfa_reqq_wait_s reqq_wait; /*  to wait for room in reqq */
-       struct bfa_cb_qe_s    hcb_qe;    /*  BFA callback qelem */
-       struct bfa_rport_hal_stats_s stats; /*  BFA rport statistics  */
-       struct bfa_rport_qos_attr_s  qos_attr;
-       union a {
-               bfa_status_t    status;  /*  f/w status */
-               void            *fw_msg; /*  QoS scn event */
-       } event_arg;
-};
-#define BFA_RPORT_FC_COS(_rport)       ((_rport)->rport_info.fc_class)
-
-/**
- * Send completion callback.
- */
-typedef void (*bfa_cb_fcxp_send_t) (void *bfad_fcxp, struct bfa_fcxp_s *fcxp,
-                       void *cbarg, enum bfa_status req_status,
-                       u32 rsp_len, u32 resid_len,
-                       struct fchs_s *rsp_fchs);
-
-/**
- * BFA fcxp allocation (asynchronous)
- */
-typedef void (*bfa_fcxp_alloc_cbfn_t) (void *cbarg, struct bfa_fcxp_s *fcxp);
-
-struct bfa_fcxp_wqe_s {
-       struct list_head         qe;
-       bfa_fcxp_alloc_cbfn_t  alloc_cbfn;
-       void           *alloc_cbarg;
-};
-
-typedef u64 (*bfa_fcxp_get_sgaddr_t) (void *bfad_fcxp, int sgeid);
-typedef u32 (*bfa_fcxp_get_sglen_t) (void *bfad_fcxp, int sgeid);
-
-#define BFA_UF_BUFSZ   (2 * 1024 + 256)
-
-/**
- * @todo private
- */
-struct bfa_uf_buf_s {
-       u8         d[BFA_UF_BUFSZ];
-};
-
-
-struct bfa_uf_s {
-       struct list_head        qe;             /*  queue element         */
-       struct bfa_s    *bfa;           /*  bfa instance          */
-       u16        uf_tag;              /*  identifying tag fw msgs     */
-       u16        vf_id;
-       u16        src_rport_handle;
-       u16        rsvd;
-       u8              *data_ptr;
-       u16        data_len;    /*  actual receive length         */
-       u16        pb_len;              /*  posted buffer length          */
-       void            *buf_kva;       /*  buffer virtual address        */
-       u64        buf_pa;              /*  buffer physical address       */
-       struct bfa_cb_qe_s    hcb_qe;   /*  comp: BFA comp qelem          */
-       struct bfa_sge_s        sges[BFI_SGE_INLINE_MAX];
-};
-
-typedef void (*bfa_cb_pport_t) (void *cbarg, enum bfa_status status);
-
-/**
- * bfa lport login/logout service interface
- */
-struct bfa_lps_s {
-       struct list_head        qe;             /*  queue element */
-       struct bfa_s    *bfa;           /*  parent bfa instance */
-       bfa_sm_t        sm;             /*  finite state machine        */
-       u8              lp_tag;         /*  lport tag                   */
-       u8              reqq;           /*  lport request queue */
-       u8              alpa;           /*  ALPA for loop topologies    */
-       u32     lp_pid;         /*  lport port ID               */
-       bfa_boolean_t   fdisc;          /*  send FDISC instead of FLOGI  */
-       bfa_boolean_t   auth_en;        /*  enable authentication       */
-       bfa_boolean_t   auth_req;       /*  authentication required     */
-       bfa_boolean_t   npiv_en;        /*  NPIV is allowed by peer     */
-       bfa_boolean_t   fport;          /*  attached peer is F_PORT     */
-       bfa_boolean_t   brcd_switch;/*  attached peer is brcd switch    */
-       bfa_status_t    status;         /*  login status                */
-       u16     pdusz;          /*  max receive PDU size        */
-       u16     pr_bbcred;      /*  BB_CREDIT from peer         */
-       u8              lsrjt_rsn;      /*  LSRJT reason                */
-       u8              lsrjt_expl;     /*  LSRJT explanation           */
-       wwn_t           pwwn;           /*  port wwn of lport           */
-       wwn_t           nwwn;           /*  node wwn of lport           */
-       wwn_t           pr_pwwn;        /*  port wwn of lport peer      */
-       wwn_t           pr_nwwn;        /*  node wwn of lport peer      */
-       mac_t           lp_mac;         /*  fpma/spma MAC for lport     */
-       mac_t           fcf_mac;        /*  FCF MAC of lport            */
-       struct bfa_reqq_wait_s  wqe;    /*  request wait queue element  */
-       void            *uarg;          /*  user callback arg           */
-       struct bfa_cb_qe_s hcb_qe;      /*  comp: callback qelem        */
-       struct bfi_lps_login_rsp_s *loginrsp;
-       bfa_eproto_status_t     ext_status;
-};
-
-#define BFA_FCPORT(_bfa)        (&((_bfa)->modules.port))
-
-/*
- * bfa pport API functions
- */
-bfa_status_t bfa_fcport_enable(struct bfa_s *bfa);
-bfa_status_t bfa_fcport_disable(struct bfa_s *bfa);
-bfa_status_t bfa_fcport_cfg_speed(struct bfa_s *bfa,
-                       enum bfa_pport_speed speed);
-enum bfa_pport_speed bfa_fcport_get_speed(struct bfa_s *bfa);
-bfa_status_t bfa_fcport_cfg_topology(struct bfa_s *bfa,
-                       enum bfa_pport_topology topo);
-enum bfa_pport_topology bfa_fcport_get_topology(struct bfa_s *bfa);
-bfa_status_t bfa_fcport_cfg_hardalpa(struct bfa_s *bfa, u8 alpa);
-bfa_boolean_t bfa_fcport_get_hardalpa(struct bfa_s *bfa, u8 *alpa);
-u8 bfa_fcport_get_myalpa(struct bfa_s *bfa);
-bfa_status_t bfa_fcport_clr_hardalpa(struct bfa_s *bfa);
-bfa_status_t bfa_fcport_cfg_maxfrsize(struct bfa_s *bfa, u16 maxsize);
-u16 bfa_fcport_get_maxfrsize(struct bfa_s *bfa);
-u32 bfa_fcport_mypid(struct bfa_s *bfa);
-u8 bfa_fcport_get_rx_bbcredit(struct bfa_s *bfa);
-bfa_status_t bfa_fcport_trunk_enable(struct bfa_s *bfa, u8 bitmap);
-bfa_status_t bfa_fcport_trunk_disable(struct bfa_s *bfa);
-bfa_boolean_t bfa_fcport_trunk_query(struct bfa_s *bfa, u32 *bitmap);
-void bfa_fcport_get_attr(struct bfa_s *bfa, struct bfa_pport_attr_s *attr);
-wwn_t bfa_fcport_get_wwn(struct bfa_s *bfa, bfa_boolean_t node);
-void bfa_fcport_event_register(struct bfa_s *bfa,
-                       void (*event_cbfn) (void *cbarg,
-                       bfa_pport_event_t event), void *event_cbarg);
-bfa_boolean_t bfa_fcport_is_disabled(struct bfa_s *bfa);
-void bfa_fcport_cfg_qos(struct bfa_s *bfa, bfa_boolean_t on_off);
-void bfa_fcport_cfg_ratelim(struct bfa_s *bfa, bfa_boolean_t on_off);
-bfa_status_t bfa_fcport_cfg_ratelim_speed(struct bfa_s *bfa,
-                       enum bfa_pport_speed speed);
-enum bfa_pport_speed bfa_fcport_get_ratelim_speed(struct bfa_s *bfa);
-
-void bfa_fcport_set_tx_bbcredit(struct bfa_s *bfa, u16 tx_bbcredit);
-void bfa_fcport_busy(struct bfa_s *bfa, bfa_boolean_t status);
-void bfa_fcport_beacon(struct bfa_s *bfa, bfa_boolean_t beacon,
-                       bfa_boolean_t link_e2e_beacon);
-void bfa_cb_pport_event(void *cbarg, bfa_pport_event_t event);
-void bfa_fcport_qos_get_attr(struct bfa_s *bfa,
-                       struct bfa_qos_attr_s *qos_attr);
-void bfa_fcport_qos_get_vc_attr(struct bfa_s *bfa,
-                       struct bfa_qos_vc_attr_s *qos_vc_attr);
-bfa_status_t bfa_fcport_get_qos_stats(struct bfa_s *bfa,
-                       union bfa_fcport_stats_u *stats,
-                       bfa_cb_pport_t cbfn, void *cbarg);
-bfa_status_t bfa_fcport_clear_qos_stats(struct bfa_s *bfa, bfa_cb_pport_t cbfn,
-                       void *cbarg);
-bfa_status_t bfa_fcport_get_fcoe_stats(struct bfa_s *bfa,
-                       union bfa_fcport_stats_u *stats,
-                       bfa_cb_pport_t cbfn, void *cbarg);
-bfa_status_t bfa_fcport_clear_fcoe_stats(struct bfa_s *bfa, bfa_cb_pport_t cbfn,
-                       void *cbarg);
-
-bfa_boolean_t     bfa_fcport_is_ratelim(struct bfa_s *bfa);
-bfa_boolean_t  bfa_fcport_is_linkup(struct bfa_s *bfa);
-bfa_status_t bfa_fcport_get_stats(struct bfa_s *bfa,
-               union bfa_fcport_stats_u *stats,
-               bfa_cb_pport_t cbfn, void *cbarg);
-bfa_status_t bfa_fcport_clear_stats(struct bfa_s *bfa, bfa_cb_pport_t cbfn,
-               void *cbarg);
-bfa_boolean_t bfa_fcport_is_qos_enabled(struct bfa_s *bfa);
-
-/*
- * bfa rport API functions
- */
-struct bfa_rport_s *bfa_rport_create(struct bfa_s *bfa, void *rport_drv);
-void bfa_rport_delete(struct bfa_rport_s *rport);
-void bfa_rport_online(struct bfa_rport_s *rport,
-                       struct bfa_rport_info_s *rport_info);
-void bfa_rport_offline(struct bfa_rport_s *rport);
-void bfa_rport_speed(struct bfa_rport_s *rport, enum bfa_pport_speed speed);
-void bfa_rport_get_stats(struct bfa_rport_s *rport,
-                       struct bfa_rport_hal_stats_s *stats);
-void bfa_rport_clear_stats(struct bfa_rport_s *rport);
-void bfa_cb_rport_online(void *rport);
-void bfa_cb_rport_offline(void *rport);
-void bfa_cb_rport_qos_scn_flowid(void *rport,
-                       struct bfa_rport_qos_attr_s old_qos_attr,
-                       struct bfa_rport_qos_attr_s new_qos_attr);
-void bfa_cb_rport_qos_scn_prio(void *rport,
-                       struct bfa_rport_qos_attr_s old_qos_attr,
-                       struct bfa_rport_qos_attr_s new_qos_attr);
-void bfa_rport_get_qos_attr(struct bfa_rport_s *rport,
-                       struct bfa_rport_qos_attr_s *qos_attr);
-
-/*
- * bfa fcxp API functions
- */
-struct bfa_fcxp_s *bfa_fcxp_alloc(void *bfad_fcxp, struct bfa_s *bfa,
-                       int nreq_sgles, int nrsp_sgles,
-                       bfa_fcxp_get_sgaddr_t get_req_sga,
-                       bfa_fcxp_get_sglen_t get_req_sglen,
-                       bfa_fcxp_get_sgaddr_t get_rsp_sga,
-                       bfa_fcxp_get_sglen_t get_rsp_sglen);
-void bfa_fcxp_alloc_wait(struct bfa_s *bfa, struct bfa_fcxp_wqe_s *wqe,
-                       bfa_fcxp_alloc_cbfn_t alloc_cbfn, void *cbarg);
-void bfa_fcxp_walloc_cancel(struct bfa_s *bfa,
-                       struct bfa_fcxp_wqe_s *wqe);
-void bfa_fcxp_discard(struct bfa_fcxp_s *fcxp);
-
-void *bfa_fcxp_get_reqbuf(struct bfa_fcxp_s *fcxp);
-void *bfa_fcxp_get_rspbuf(struct bfa_fcxp_s *fcxp);
-
-void bfa_fcxp_free(struct bfa_fcxp_s *fcxp);
-
-void bfa_fcxp_send(struct bfa_fcxp_s *fcxp,
-                       struct bfa_rport_s *rport, u16 vf_id, u8 lp_tag,
-                       bfa_boolean_t cts, enum fc_cos cos,
-                       u32 reqlen, struct fchs_s *fchs,
-                       bfa_cb_fcxp_send_t cbfn,
-                       void *cbarg,
-                       u32 rsp_maxlen, u8 rsp_timeout);
-bfa_status_t bfa_fcxp_abort(struct bfa_fcxp_s *fcxp);
-u32        bfa_fcxp_get_reqbufsz(struct bfa_fcxp_s *fcxp);
-u32    bfa_fcxp_get_maxrsp(struct bfa_s *bfa);
-
-static inline void *
-bfa_uf_get_frmbuf(struct bfa_uf_s *uf)
-{
-       return uf->data_ptr;
-}
-
-static inline   u16
-bfa_uf_get_frmlen(struct bfa_uf_s *uf)
-{
-       return uf->data_len;
-}
-
-/**
- *      Callback prototype for unsolicited frame receive handler.
- *
- * @param[in]           cbarg           callback arg for receive handler
- * @param[in]           uf              unsolicited frame descriptor
- *
- * @return None
- */
-typedef void (*bfa_cb_uf_recv_t) (void *cbarg, struct bfa_uf_s *uf);
-
-/*
- * bfa uf API functions
- */
-void bfa_uf_recv_register(struct bfa_s *bfa, bfa_cb_uf_recv_t ufrecv,
-                       void *cbarg);
-void bfa_uf_free(struct bfa_uf_s *uf);
-
-/**
- * bfa lport service api
- */
-
-u32    bfa_lps_get_max_vport(struct bfa_s *bfa);
-struct bfa_lps_s *bfa_lps_alloc(struct bfa_s *bfa);
-void bfa_lps_delete(struct bfa_lps_s *lps);
-void bfa_lps_discard(struct bfa_lps_s *lps);
-void bfa_lps_flogi(struct bfa_lps_s *lps, void *uarg, u8 alpa, u16 pdusz,
-                  wwn_t pwwn, wwn_t nwwn, bfa_boolean_t auth_en);
-void bfa_lps_fdisc(struct bfa_lps_s *lps, void *uarg, u16 pdusz, wwn_t pwwn,
-                  wwn_t nwwn);
-void bfa_lps_flogo(struct bfa_lps_s *lps);
-void bfa_lps_fdisclogo(struct bfa_lps_s *lps);
-u8 bfa_lps_get_tag(struct bfa_lps_s *lps);
-bfa_boolean_t bfa_lps_is_npiv_en(struct bfa_lps_s *lps);
-bfa_boolean_t bfa_lps_is_fport(struct bfa_lps_s *lps);
-bfa_boolean_t bfa_lps_is_brcd_fabric(struct bfa_lps_s *lps);
-bfa_boolean_t bfa_lps_is_authreq(struct bfa_lps_s *lps);
-bfa_eproto_status_t bfa_lps_get_extstatus(struct bfa_lps_s *lps);
-u32 bfa_lps_get_pid(struct bfa_lps_s *lps);
-u8 bfa_lps_get_tag_from_pid(struct bfa_s *bfa, u32 pid);
-u16 bfa_lps_get_peer_bbcredit(struct bfa_lps_s *lps);
-wwn_t bfa_lps_get_peer_pwwn(struct bfa_lps_s *lps);
-wwn_t bfa_lps_get_peer_nwwn(struct bfa_lps_s *lps);
-u8 bfa_lps_get_lsrjt_rsn(struct bfa_lps_s *lps);
-u8 bfa_lps_get_lsrjt_expl(struct bfa_lps_s *lps);
-mac_t bfa_lps_get_lp_mac(struct bfa_lps_s *lps);
-void bfa_cb_lps_flogi_comp(void *bfad, void *uarg, bfa_status_t status);
-void bfa_cb_lps_flogo_comp(void *bfad, void *uarg);
-void bfa_cb_lps_fdisc_comp(void *bfad, void *uarg, bfa_status_t status);
-void bfa_cb_lps_fdisclogo_comp(void *bfad, void *uarg);
-void bfa_cb_lps_cvl_event(void *bfad, void *uarg);
-
-#endif /* __BFA_SVC_H__ */
-
diff --git a/drivers/scsi/bfa/include/bfa_timer.h b/drivers/scsi/bfa/include/bfa_timer.h
deleted file mode 100644 (file)
index f710874..0000000
+++ /dev/null
@@ -1,53 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-#ifndef __BFA_TIMER_H__
-#define __BFA_TIMER_H__
-
-#include <bfa_os_inc.h>
-#include <cs/bfa_q.h>
-
-struct bfa_s;
-
-typedef void (*bfa_timer_cbfn_t)(void *);
-
-/**
- * BFA timer data structure
- */
-struct bfa_timer_s {
-       struct list_head        qe;
-       bfa_timer_cbfn_t timercb;
-       void            *arg;
-       int             timeout;        /**< in millisecs. */
-};
-
-/**
- * Timer module structure
- */
-struct bfa_timer_mod_s {
-       struct list_head timer_q;
-};
-
-#define BFA_TIMER_FREQ 200 /**< specified in millisecs */
-
-void bfa_timer_beat(struct bfa_timer_mod_s *mod);
-void bfa_timer_init(struct bfa_timer_mod_s *mod);
-void bfa_timer_begin(struct bfa_timer_mod_s *mod, struct bfa_timer_s *timer,
-                       bfa_timer_cbfn_t timercb, void *arg,
-                       unsigned int timeout);
-void bfa_timer_stop(struct bfa_timer_s *timer);
-
-#endif /* __BFA_TIMER_H__ */
diff --git a/drivers/scsi/bfa/include/bfi/bfi.h b/drivers/scsi/bfa/include/bfi/bfi.h
deleted file mode 100644 (file)
index a550e80..0000000
+++ /dev/null
@@ -1,174 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFI_H__
-#define __BFI_H__
-
-#include <bfa_os_inc.h>
-#include <defs/bfa_defs_status.h>
-
-#pragma pack(1)
-
-/**
- * Msg header common to all msgs
- */
-struct bfi_mhdr_s {
-       u8         msg_class;   /*  @ref bfi_mclass_t       */
-       u8         msg_id;              /*  msg opcode with in the class   */
-       union {
-               struct {
-                       u8         rsvd;
-                       u8         lpu_id;      /*  msg destination         */
-               } h2i;
-               u16        i2htok;      /*  token in msgs to host           */
-       } mtag;
-};
-
-#define bfi_h2i_set(_mh, _mc, _op, _lpuid) do {                \
-       (_mh).msg_class                 = (_mc);      \
-       (_mh).msg_id                    = (_op);      \
-       (_mh).mtag.h2i.lpu_id   = (_lpuid);      \
-} while (0)
-
-#define bfi_i2h_set(_mh, _mc, _op, _i2htok) do {               \
-       (_mh).msg_class                 = (_mc);      \
-       (_mh).msg_id                    = (_op);      \
-       (_mh).mtag.i2htok               = (_i2htok);      \
-} while (0)
-
-/*
- * Message opcodes: 0-127 to firmware, 128-255 to host
- */
-#define BFI_I2H_OPCODE_BASE    128
-#define BFA_I2HM(_x)                   ((_x) + BFI_I2H_OPCODE_BASE)
-
-/**
- ****************************************************************************
- *
- * Scatter Gather Element and Page definition
- *
- ****************************************************************************
- */
-
-#define BFI_SGE_INLINE 1
-#define BFI_SGE_INLINE_MAX     (BFI_SGE_INLINE + 1)
-
-/**
- * SG Flags
- */
-enum {
-       BFI_SGE_DATA    = 0,    /*  data address, not last           */
-       BFI_SGE_DATA_CPL        = 1,    /*  data addr, last in current page */
-       BFI_SGE_DATA_LAST       = 3,    /*  data address, last               */
-       BFI_SGE_LINK    = 2,    /*  link address                     */
-       BFI_SGE_PGDLEN  = 2,    /*  cumulative data length for page */
-};
-
-/**
- * DMA addresses
- */
-union bfi_addr_u {
-       struct {
-               u32        addr_lo;
-               u32        addr_hi;
-       } a32;
-};
-
-/**
- * Scatter Gather Element
- */
-struct bfi_sge_s {
-#ifdef __BIGENDIAN
-       u32        flags:2,
-                       rsvd:2,
-                       sg_len:28;
-#else
-       u32        sg_len:28,
-                       rsvd:2,
-                       flags:2;
-#endif
-       union bfi_addr_u sga;
-};
-
-/**
- * Scatter Gather Page
- */
-#define BFI_SGPG_DATA_SGES             7
-#define BFI_SGPG_SGES_MAX              (BFI_SGPG_DATA_SGES + 1)
-#define BFI_SGPG_RSVD_WD_LEN   8
-struct bfi_sgpg_s {
-       struct bfi_sge_s sges[BFI_SGPG_SGES_MAX];
-       u32     rsvd[BFI_SGPG_RSVD_WD_LEN];
-};
-
-/*
- * Large Message structure - 128 Bytes size Msgs
- */
-#define BFI_LMSG_SZ            128
-#define BFI_LMSG_PL_WSZ        \
-                       ((BFI_LMSG_SZ - sizeof(struct bfi_mhdr_s)) / 4)
-
-struct bfi_msg_s {
-       struct bfi_mhdr_s mhdr;
-       u32     pl[BFI_LMSG_PL_WSZ];
-};
-
-/**
- * Mailbox message structure
- */
-#define BFI_MBMSG_SZ           7
-struct bfi_mbmsg_s {
-       struct bfi_mhdr_s       mh;
-       u32             pl[BFI_MBMSG_SZ];
-};
-
-/**
- * Message Classes
- */
-enum bfi_mclass {
-       BFI_MC_IOC              = 1,    /*  IO Controller (IOC)     */
-       BFI_MC_DIAG             = 2,    /*  Diagnostic Msgs                 */
-       BFI_MC_FLASH            = 3,    /*  Flash message class     */
-       BFI_MC_CEE              = 4,    /*  CEE                     */
-       BFI_MC_FCPORT           = 5,    /*  FC port                         */
-       BFI_MC_IOCFC            = 6,    /*  FC - IO Controller (IOC)        */
-       BFI_MC_LL               = 7,    /*  Link Layer                      */
-       BFI_MC_UF               = 8,    /*  Unsolicited frame receive       */
-       BFI_MC_FCXP             = 9,    /*  FC Transport                    */
-       BFI_MC_LPS              = 10,   /*  lport fc login services         */
-       BFI_MC_RPORT            = 11,   /*  Remote port             */
-       BFI_MC_ITNIM            = 12,   /*  I-T nexus (Initiator mode)      */
-       BFI_MC_IOIM_READ        = 13,   /*  read IO (Initiator mode)        */
-       BFI_MC_IOIM_WRITE       = 14,   /*  write IO (Initiator mode)       */
-       BFI_MC_IOIM_IO          = 15,   /*  IO (Initiator mode)     */
-       BFI_MC_IOIM             = 16,   /*  IO (Initiator mode)     */
-       BFI_MC_IOIM_IOCOM       = 17,   /*  good IO completion              */
-       BFI_MC_TSKIM            = 18,   /*  Initiator Task management       */
-       BFI_MC_SBOOT            = 19,   /*  SAN boot services               */
-       BFI_MC_IPFC             = 20,   /*  IP over FC Msgs                 */
-       BFI_MC_PORT             = 21,   /*  Physical port                   */
-       BFI_MC_MAX              = 32
-};
-
-#define BFI_IOC_MAX_CQS                4
-#define BFI_IOC_MAX_CQS_ASIC   8
-#define BFI_IOC_MSGLEN_MAX     32      /* 32 bytes */
-
-#pragma pack()
-
-#endif /* __BFI_H__ */
-
diff --git a/drivers/scsi/bfa/include/bfi/bfi_boot.h b/drivers/scsi/bfa/include/bfi/bfi_boot.h
deleted file mode 100644 (file)
index 5955afe..0000000
+++ /dev/null
@@ -1,34 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-/*
- * bfi_boot.h
- */
-
-#ifndef __BFI_BOOT_H__
-#define __BFI_BOOT_H__
-
-#define BFI_BOOT_TYPE_OFF              8
-#define BFI_BOOT_PARAM_OFF             12
-
-#define BFI_BOOT_TYPE_NORMAL           0       /* param is device id */
-#define        BFI_BOOT_TYPE_FLASH             1
-#define        BFI_BOOT_TYPE_MEMTEST           2
-
-#define BFI_BOOT_MEMTEST_RES_ADDR   0x900
-#define BFI_BOOT_MEMTEST_RES_SIG    0xA0A1A2A3
-
-#endif
diff --git a/drivers/scsi/bfa/include/bfi/bfi_cbreg.h b/drivers/scsi/bfa/include/bfi/bfi_cbreg.h
deleted file mode 100644 (file)
index a51ee61..0000000
+++ /dev/null
@@ -1,319 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/*
- * bfi_cbreg.h crossbow host block register definitions
- *
- * !!! Do not edit. Auto generated. !!!
- */
-
-#ifndef __BFI_CBREG_H__
-#define __BFI_CBREG_H__
-
-
-#define HOSTFN0_INT_STATUS               0x00014000
-#define __HOSTFN0_INT_STATUS_LVL_MK      0x00f00000
-#define __HOSTFN0_INT_STATUS_LVL_SH      20
-#define __HOSTFN0_INT_STATUS_LVL(_v)     ((_v) << __HOSTFN0_INT_STATUS_LVL_SH)
-#define __HOSTFN0_INT_STATUS_P           0x000fffff
-#define HOSTFN0_INT_MSK                  0x00014004
-#define HOST_PAGE_NUM_FN0                0x00014008
-#define __HOST_PAGE_NUM_FN               0x000001ff
-#define HOSTFN1_INT_STATUS               0x00014100
-#define __HOSTFN1_INT_STAT_LVL_MK        0x00f00000
-#define __HOSTFN1_INT_STAT_LVL_SH        20
-#define __HOSTFN1_INT_STAT_LVL(_v)       ((_v) << __HOSTFN1_INT_STAT_LVL_SH)
-#define __HOSTFN1_INT_STAT_P             0x000fffff
-#define HOSTFN1_INT_MSK                  0x00014104
-#define HOST_PAGE_NUM_FN1                0x00014108
-#define APP_PLL_400_CTL_REG              0x00014204
-#define __P_400_PLL_LOCK                 0x80000000
-#define __APP_PLL_400_SRAM_USE_100MHZ    0x00100000
-#define __APP_PLL_400_RESET_TIMER_MK     0x000e0000
-#define __APP_PLL_400_RESET_TIMER_SH     17
-#define __APP_PLL_400_RESET_TIMER(_v)    ((_v) << __APP_PLL_400_RESET_TIMER_SH)
-#define __APP_PLL_400_LOGIC_SOFT_RESET   0x00010000
-#define __APP_PLL_400_CNTLMT0_1_MK       0x0000c000
-#define __APP_PLL_400_CNTLMT0_1_SH       14
-#define __APP_PLL_400_CNTLMT0_1(_v)      ((_v) << __APP_PLL_400_CNTLMT0_1_SH)
-#define __APP_PLL_400_JITLMT0_1_MK       0x00003000
-#define __APP_PLL_400_JITLMT0_1_SH       12
-#define __APP_PLL_400_JITLMT0_1(_v)      ((_v) << __APP_PLL_400_JITLMT0_1_SH)
-#define __APP_PLL_400_HREF               0x00000800
-#define __APP_PLL_400_HDIV               0x00000400
-#define __APP_PLL_400_P0_1_MK            0x00000300
-#define __APP_PLL_400_P0_1_SH            8
-#define __APP_PLL_400_P0_1(_v)           ((_v) << __APP_PLL_400_P0_1_SH)
-#define __APP_PLL_400_Z0_2_MK            0x000000e0
-#define __APP_PLL_400_Z0_2_SH            5
-#define __APP_PLL_400_Z0_2(_v)           ((_v) << __APP_PLL_400_Z0_2_SH)
-#define __APP_PLL_400_RSEL200500         0x00000010
-#define __APP_PLL_400_ENARST             0x00000008
-#define __APP_PLL_400_BYPASS             0x00000004
-#define __APP_PLL_400_LRESETN            0x00000002
-#define __APP_PLL_400_ENABLE             0x00000001
-#define APP_PLL_212_CTL_REG              0x00014208
-#define __P_212_PLL_LOCK                 0x80000000
-#define __APP_PLL_212_RESET_TIMER_MK     0x000e0000
-#define __APP_PLL_212_RESET_TIMER_SH     17
-#define __APP_PLL_212_RESET_TIMER(_v)    ((_v) << __APP_PLL_212_RESET_TIMER_SH)
-#define __APP_PLL_212_LOGIC_SOFT_RESET   0x00010000
-#define __APP_PLL_212_CNTLMT0_1_MK       0x0000c000
-#define __APP_PLL_212_CNTLMT0_1_SH       14
-#define __APP_PLL_212_CNTLMT0_1(_v)      ((_v) << __APP_PLL_212_CNTLMT0_1_SH)
-#define __APP_PLL_212_JITLMT0_1_MK       0x00003000
-#define __APP_PLL_212_JITLMT0_1_SH       12
-#define __APP_PLL_212_JITLMT0_1(_v)      ((_v) << __APP_PLL_212_JITLMT0_1_SH)
-#define __APP_PLL_212_HREF               0x00000800
-#define __APP_PLL_212_HDIV               0x00000400
-#define __APP_PLL_212_P0_1_MK            0x00000300
-#define __APP_PLL_212_P0_1_SH            8
-#define __APP_PLL_212_P0_1(_v)           ((_v) << __APP_PLL_212_P0_1_SH)
-#define __APP_PLL_212_Z0_2_MK            0x000000e0
-#define __APP_PLL_212_Z0_2_SH            5
-#define __APP_PLL_212_Z0_2(_v)           ((_v) << __APP_PLL_212_Z0_2_SH)
-#define __APP_PLL_212_RSEL200500         0x00000010
-#define __APP_PLL_212_ENARST             0x00000008
-#define __APP_PLL_212_BYPASS             0x00000004
-#define __APP_PLL_212_LRESETN            0x00000002
-#define __APP_PLL_212_ENABLE             0x00000001
-#define HOST_SEM0_REG                    0x00014230
-#define __HOST_SEMAPHORE                 0x00000001
-#define HOST_SEM1_REG                    0x00014234
-#define HOST_SEM2_REG                    0x00014238
-#define HOST_SEM3_REG                    0x0001423c
-#define HOST_SEM0_INFO_REG               0x00014240
-#define HOST_SEM1_INFO_REG               0x00014244
-#define HOST_SEM2_INFO_REG               0x00014248
-#define HOST_SEM3_INFO_REG               0x0001424c
-#define HOSTFN0_LPU0_CMD_STAT            0x00019000
-#define __HOSTFN0_LPU0_MBOX_INFO_MK      0xfffffffe
-#define __HOSTFN0_LPU0_MBOX_INFO_SH      1
-#define __HOSTFN0_LPU0_MBOX_INFO(_v)     ((_v) << __HOSTFN0_LPU0_MBOX_INFO_SH)
-#define __HOSTFN0_LPU0_MBOX_CMD_STATUS   0x00000001
-#define LPU0_HOSTFN0_CMD_STAT            0x00019008
-#define __LPU0_HOSTFN0_MBOX_INFO_MK      0xfffffffe
-#define __LPU0_HOSTFN0_MBOX_INFO_SH      1
-#define __LPU0_HOSTFN0_MBOX_INFO(_v)     ((_v) << __LPU0_HOSTFN0_MBOX_INFO_SH)
-#define __LPU0_HOSTFN0_MBOX_CMD_STATUS   0x00000001
-#define HOSTFN1_LPU1_CMD_STAT            0x00019014
-#define __HOSTFN1_LPU1_MBOX_INFO_MK      0xfffffffe
-#define __HOSTFN1_LPU1_MBOX_INFO_SH      1
-#define __HOSTFN1_LPU1_MBOX_INFO(_v)     ((_v) << __HOSTFN1_LPU1_MBOX_INFO_SH)
-#define __HOSTFN1_LPU1_MBOX_CMD_STATUS   0x00000001
-#define LPU1_HOSTFN1_CMD_STAT            0x0001901c
-#define __LPU1_HOSTFN1_MBOX_INFO_MK      0xfffffffe
-#define __LPU1_HOSTFN1_MBOX_INFO_SH      1
-#define __LPU1_HOSTFN1_MBOX_INFO(_v)     ((_v) << __LPU1_HOSTFN1_MBOX_INFO_SH)
-#define __LPU1_HOSTFN1_MBOX_CMD_STATUS   0x00000001
-#define CPE_Q0_DEPTH                     0x00010014
-#define CPE_Q0_PI                        0x0001001c
-#define CPE_Q0_CI                        0x00010020
-#define CPE_Q1_DEPTH                     0x00010034
-#define CPE_Q1_PI                        0x0001003c
-#define CPE_Q1_CI                        0x00010040
-#define CPE_Q2_DEPTH                     0x00010054
-#define CPE_Q2_PI                        0x0001005c
-#define CPE_Q2_CI                        0x00010060
-#define CPE_Q3_DEPTH                     0x00010074
-#define CPE_Q3_PI                        0x0001007c
-#define CPE_Q3_CI                        0x00010080
-#define CPE_Q4_DEPTH                     0x00010094
-#define CPE_Q4_PI                        0x0001009c
-#define CPE_Q4_CI                        0x000100a0
-#define CPE_Q5_DEPTH                     0x000100b4
-#define CPE_Q5_PI                        0x000100bc
-#define CPE_Q5_CI                        0x000100c0
-#define CPE_Q6_DEPTH                     0x000100d4
-#define CPE_Q6_PI                        0x000100dc
-#define CPE_Q6_CI                        0x000100e0
-#define CPE_Q7_DEPTH                     0x000100f4
-#define CPE_Q7_PI                        0x000100fc
-#define CPE_Q7_CI                        0x00010100
-#define RME_Q0_DEPTH                     0x00011014
-#define RME_Q0_PI                        0x0001101c
-#define RME_Q0_CI                        0x00011020
-#define RME_Q1_DEPTH                     0x00011034
-#define RME_Q1_PI                        0x0001103c
-#define RME_Q1_CI                        0x00011040
-#define RME_Q2_DEPTH                     0x00011054
-#define RME_Q2_PI                        0x0001105c
-#define RME_Q2_CI                        0x00011060
-#define RME_Q3_DEPTH                     0x00011074
-#define RME_Q3_PI                        0x0001107c
-#define RME_Q3_CI                        0x00011080
-#define RME_Q4_DEPTH                     0x00011094
-#define RME_Q4_PI                        0x0001109c
-#define RME_Q4_CI                        0x000110a0
-#define RME_Q5_DEPTH                     0x000110b4
-#define RME_Q5_PI                        0x000110bc
-#define RME_Q5_CI                        0x000110c0
-#define RME_Q6_DEPTH                     0x000110d4
-#define RME_Q6_PI                        0x000110dc
-#define RME_Q6_CI                        0x000110e0
-#define RME_Q7_DEPTH                     0x000110f4
-#define RME_Q7_PI                        0x000110fc
-#define RME_Q7_CI                        0x00011100
-#define PSS_CTL_REG                      0x00018800
-#define __PSS_I2C_CLK_DIV_MK             0x00030000
-#define __PSS_I2C_CLK_DIV_SH             16
-#define __PSS_I2C_CLK_DIV(_v)            ((_v) << __PSS_I2C_CLK_DIV_SH)
-#define __PSS_LMEM_INIT_DONE             0x00001000
-#define __PSS_LMEM_RESET                 0x00000200
-#define __PSS_LMEM_INIT_EN               0x00000100
-#define __PSS_LPU1_RESET                 0x00000002
-#define __PSS_LPU0_RESET                 0x00000001
-#define PSS_ERR_STATUS_REG              0x00018810
-#define __PSS_LMEM1_CORR_ERR            0x00000800
-#define __PSS_LMEM0_CORR_ERR             0x00000400
-#define __PSS_LMEM1_UNCORR_ERR           0x00000200
-#define __PSS_LMEM0_UNCORR_ERR           0x00000100
-#define __PSS_BAL_PERR                   0x00000080
-#define __PSS_DIP_IF_ERR                 0x00000040
-#define __PSS_IOH_IF_ERR                 0x00000020
-#define __PSS_TDS_IF_ERR                 0x00000010
-#define __PSS_RDS_IF_ERR                 0x00000008
-#define __PSS_SGM_IF_ERR                 0x00000004
-#define __PSS_LPU1_RAM_ERR               0x00000002
-#define __PSS_LPU0_RAM_ERR               0x00000001
-#define ERR_SET_REG                     0x00018818
-#define __PSS_ERR_STATUS_SET            0x00000fff
-
-/*
- * These definitions are either in error/missing in spec. Its auto-generated
- * from hard coded values in regparse.pl.
- */
-#define __EMPHPOST_AT_4G_MK_FIX          0x0000001c
-#define __EMPHPOST_AT_4G_SH_FIX          0x00000002
-#define __EMPHPRE_AT_4G_FIX              0x00000003
-#define __SFP_TXRATE_EN_FIX              0x00000100
-#define __SFP_RXRATE_EN_FIX              0x00000080
-
-
-/*
- * These register definitions are auto-generated from hard coded values
- * in regparse.pl.
- */
-#define HOSTFN0_LPU_MBOX0_0              0x00019200
-#define HOSTFN1_LPU_MBOX0_8              0x00019260
-#define LPU_HOSTFN0_MBOX0_0              0x00019280
-#define LPU_HOSTFN1_MBOX0_8              0x000192e0
-
-
-/*
- * These register mapping definitions are auto-generated from mapping tables
- * in regparse.pl.
- */
-#define BFA_IOC0_HBEAT_REG               HOST_SEM0_INFO_REG
-#define BFA_IOC0_STATE_REG               HOST_SEM1_INFO_REG
-#define BFA_IOC1_HBEAT_REG               HOST_SEM2_INFO_REG
-#define BFA_IOC1_STATE_REG               HOST_SEM3_INFO_REG
-#define BFA_FW_USE_COUNT                 HOST_SEM4_INFO_REG
-
-#define CPE_Q_DEPTH(__n) \
-       (CPE_Q0_DEPTH + (__n) * (CPE_Q1_DEPTH - CPE_Q0_DEPTH))
-#define CPE_Q_PI(__n) \
-       (CPE_Q0_PI + (__n) * (CPE_Q1_PI - CPE_Q0_PI))
-#define CPE_Q_CI(__n) \
-       (CPE_Q0_CI + (__n) * (CPE_Q1_CI - CPE_Q0_CI))
-#define RME_Q_DEPTH(__n) \
-       (RME_Q0_DEPTH + (__n) * (RME_Q1_DEPTH - RME_Q0_DEPTH))
-#define RME_Q_PI(__n) \
-       (RME_Q0_PI + (__n) * (RME_Q1_PI - RME_Q0_PI))
-#define RME_Q_CI(__n) \
-       (RME_Q0_CI + (__n) * (RME_Q1_CI - RME_Q0_CI))
-
-#define CPE_Q_NUM(__fn, __q)  (((__fn) << 2) + (__q))
-#define RME_Q_NUM(__fn, __q)  (((__fn) << 2) + (__q))
-#define CPE_Q_MASK(__q)  ((__q) & 0x3)
-#define RME_Q_MASK(__q)  ((__q) & 0x3)
-
-
-/*
- * PCI MSI-X vector defines
- */
-enum {
-    BFA_MSIX_CPE_Q0 = 0,
-    BFA_MSIX_CPE_Q1 = 1,
-    BFA_MSIX_CPE_Q2 = 2,
-    BFA_MSIX_CPE_Q3 = 3,
-    BFA_MSIX_CPE_Q4 = 4,
-    BFA_MSIX_CPE_Q5 = 5,
-    BFA_MSIX_CPE_Q6 = 6,
-    BFA_MSIX_CPE_Q7 = 7,
-    BFA_MSIX_RME_Q0 = 8,
-    BFA_MSIX_RME_Q1 = 9,
-    BFA_MSIX_RME_Q2 = 10,
-    BFA_MSIX_RME_Q3 = 11,
-    BFA_MSIX_RME_Q4 = 12,
-    BFA_MSIX_RME_Q5 = 13,
-    BFA_MSIX_RME_Q6 = 14,
-    BFA_MSIX_RME_Q7 = 15,
-    BFA_MSIX_ERR_EMC = 16,
-    BFA_MSIX_ERR_LPU0 = 17,
-    BFA_MSIX_ERR_LPU1 = 18,
-    BFA_MSIX_ERR_PSS = 19,
-    BFA_MSIX_MBOX_LPU0 = 20,
-    BFA_MSIX_MBOX_LPU1 = 21,
-    BFA_MSIX_CB_MAX = 22,
-};
-
-/*
- * And corresponding host interrupt status bit field defines
- */
-#define __HFN_INT_CPE_Q0                   0x00000001U
-#define __HFN_INT_CPE_Q1                   0x00000002U
-#define __HFN_INT_CPE_Q2                   0x00000004U
-#define __HFN_INT_CPE_Q3                   0x00000008U
-#define __HFN_INT_CPE_Q4                   0x00000010U
-#define __HFN_INT_CPE_Q5                   0x00000020U
-#define __HFN_INT_CPE_Q6                   0x00000040U
-#define __HFN_INT_CPE_Q7                   0x00000080U
-#define __HFN_INT_RME_Q0                   0x00000100U
-#define __HFN_INT_RME_Q1                   0x00000200U
-#define __HFN_INT_RME_Q2                   0x00000400U
-#define __HFN_INT_RME_Q3                   0x00000800U
-#define __HFN_INT_RME_Q4                   0x00001000U
-#define __HFN_INT_RME_Q5                   0x00002000U
-#define __HFN_INT_RME_Q6                   0x00004000U
-#define __HFN_INT_RME_Q7                   0x00008000U
-#define __HFN_INT_ERR_EMC                  0x00010000U
-#define __HFN_INT_ERR_LPU0                 0x00020000U
-#define __HFN_INT_ERR_LPU1                 0x00040000U
-#define __HFN_INT_ERR_PSS                  0x00080000U
-#define __HFN_INT_MBOX_LPU0                0x00100000U
-#define __HFN_INT_MBOX_LPU1                0x00200000U
-#define __HFN_INT_MBOX1_LPU0               0x00400000U
-#define __HFN_INT_MBOX1_LPU1               0x00800000U
-#define __HFN_INT_CPE_MASK                 0x000000ffU
-#define __HFN_INT_RME_MASK                 0x0000ff00U
-
-
-/*
- * crossbow memory map.
- */
-#define PSS_SMEM_PAGE_START    0x8000
-#define PSS_SMEM_PGNUM(_pg0, _ma)      ((_pg0) + ((_ma) >> 15))
-#define PSS_SMEM_PGOFF(_ma)    ((_ma) & 0x7fff)
-
-/*
- * End of crossbow memory map
- */
-
-
-#endif /* __BFI_CBREG_H__ */
-
diff --git a/drivers/scsi/bfa/include/bfi/bfi_cee.h b/drivers/scsi/bfa/include/bfi/bfi_cee.h
deleted file mode 100644 (file)
index 0970596..0000000
+++ /dev/null
@@ -1,119 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-/**
- *  Copyright (c) 2006-2009 Brocade Communications Systems, Inc.
- *  All rights reserved.
- *
- *  bfi_dcbx.h BFI Interface (Mailbox commands and related structures)
- * between host driver and DCBX/LLDP firmware module.
- *
-**/
-
-#ifndef __BFI_CEE_H__
-#define __BFI_CEE_H__
-
-#include <bfi/bfi.h>
-
-#pragma pack(1)
-
-
-enum bfi_cee_h2i_msgs_e {
-       BFI_CEE_H2I_GET_CFG_REQ = 1,
-       BFI_CEE_H2I_RESET_STATS = 2,
-       BFI_CEE_H2I_GET_STATS_REQ = 3,
-};
-
-
-enum bfi_cee_i2h_msgs_e {
-       BFI_CEE_I2H_GET_CFG_RSP = BFA_I2HM(1),
-       BFI_CEE_I2H_RESET_STATS_RSP = BFA_I2HM(2),
-       BFI_CEE_I2H_GET_STATS_RSP = BFA_I2HM(3),
-};
-
-
-/* Data structures */
-
-/*
- * BFI_CEE_H2I_RESET_STATS
- */
-struct bfi_lldp_reset_stats_s {
-       struct bfi_mhdr_s  mh;
-};
-
-/*
- * BFI_CEE_H2I_RESET_STATS
- */
-struct bfi_cee_reset_stats_s {
-       struct bfi_mhdr_s  mh;
-};
-
-/*
- * BFI_CEE_H2I_GET_CFG_REQ
- */
-struct bfi_cee_get_req_s {
-       struct bfi_mhdr_s  mh;
-       union bfi_addr_u   dma_addr;
-};
-
-
-/*
- * BFI_CEE_I2H_GET_CFG_RSP
- */
-struct bfi_cee_get_rsp_s {
-       struct bfi_mhdr_s  mh;
-       u8            cmd_status;
-       u8            rsvd[3];
-};
-
-/*
- * BFI_CEE_H2I_GET_STATS_REQ
- */
-struct bfi_cee_stats_req_s {
-       struct bfi_mhdr_s  mh;
-       union bfi_addr_u   dma_addr;
-};
-
-
-/*
- * BFI_CEE_I2H_GET_STATS_RSP
- */
-struct bfi_cee_stats_rsp_s {
-       struct bfi_mhdr_s  mh;
-       u8                 cmd_status;
-       u8                 rsvd[3];
-};
-
-
-
-union bfi_cee_h2i_msg_u {
-       struct bfi_mhdr_s           mh;
-       struct bfi_cee_get_req_s   get_req;
-       struct bfi_cee_stats_req_s stats_req;
-};
-
-
-union bfi_cee_i2h_msg_u {
-       struct bfi_mhdr_s         mh;
-       struct bfi_cee_get_rsp_s  get_rsp;
-       struct bfi_cee_stats_rsp_s stats_rsp;
-};
-
-#pragma pack()
-
-
-#endif /* __BFI_CEE_H__ */
-
diff --git a/drivers/scsi/bfa/include/bfi/bfi_ctreg.h b/drivers/scsi/bfa/include/bfi/bfi_ctreg.h
deleted file mode 100644 (file)
index c0ef5a9..0000000
+++ /dev/null
@@ -1,640 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/*
- * bfi_ctreg.h catapult host block register definitions
- *
- * !!! Do not edit. Auto generated. !!!
- */
-
-#ifndef __BFI_CTREG_H__
-#define __BFI_CTREG_H__
-
-
-#define HOSTFN0_LPU_MBOX0_0              0x00019200
-#define HOSTFN1_LPU_MBOX0_8              0x00019260
-#define LPU_HOSTFN0_MBOX0_0              0x00019280
-#define LPU_HOSTFN1_MBOX0_8              0x000192e0
-#define HOSTFN2_LPU_MBOX0_0              0x00019400
-#define HOSTFN3_LPU_MBOX0_8              0x00019460
-#define LPU_HOSTFN2_MBOX0_0              0x00019480
-#define LPU_HOSTFN3_MBOX0_8              0x000194e0
-#define HOSTFN0_INT_STATUS               0x00014000
-#define __HOSTFN0_HALT_OCCURRED          0x01000000
-#define __HOSTFN0_INT_STATUS_LVL_MK      0x00f00000
-#define __HOSTFN0_INT_STATUS_LVL_SH      20
-#define __HOSTFN0_INT_STATUS_LVL(_v)     ((_v) << __HOSTFN0_INT_STATUS_LVL_SH)
-#define __HOSTFN0_INT_STATUS_P_MK        0x000f0000
-#define __HOSTFN0_INT_STATUS_P_SH        16
-#define __HOSTFN0_INT_STATUS_P(_v)       ((_v) << __HOSTFN0_INT_STATUS_P_SH)
-#define __HOSTFN0_INT_STATUS_F           0x0000ffff
-#define HOSTFN0_INT_MSK                  0x00014004
-#define HOST_PAGE_NUM_FN0                0x00014008
-#define __HOST_PAGE_NUM_FN               0x000001ff
-#define HOST_MSIX_ERR_INDEX_FN0          0x0001400c
-#define __MSIX_ERR_INDEX_FN              0x000001ff
-#define HOSTFN1_INT_STATUS               0x00014100
-#define __HOSTFN1_HALT_OCCURRED          0x01000000
-#define __HOSTFN1_INT_STATUS_LVL_MK      0x00f00000
-#define __HOSTFN1_INT_STATUS_LVL_SH      20
-#define __HOSTFN1_INT_STATUS_LVL(_v)     ((_v) << __HOSTFN1_INT_STATUS_LVL_SH)
-#define __HOSTFN1_INT_STATUS_P_MK        0x000f0000
-#define __HOSTFN1_INT_STATUS_P_SH        16
-#define __HOSTFN1_INT_STATUS_P(_v)       ((_v) << __HOSTFN1_INT_STATUS_P_SH)
-#define __HOSTFN1_INT_STATUS_F           0x0000ffff
-#define HOSTFN1_INT_MSK                  0x00014104
-#define HOST_PAGE_NUM_FN1                0x00014108
-#define HOST_MSIX_ERR_INDEX_FN1          0x0001410c
-#define APP_PLL_425_CTL_REG              0x00014204
-#define __P_425_PLL_LOCK                 0x80000000
-#define __APP_PLL_425_SRAM_USE_100MHZ    0x00100000
-#define __APP_PLL_425_RESET_TIMER_MK     0x000e0000
-#define __APP_PLL_425_RESET_TIMER_SH     17
-#define __APP_PLL_425_RESET_TIMER(_v)    ((_v) << __APP_PLL_425_RESET_TIMER_SH)
-#define __APP_PLL_425_LOGIC_SOFT_RESET   0x00010000
-#define __APP_PLL_425_CNTLMT0_1_MK       0x0000c000
-#define __APP_PLL_425_CNTLMT0_1_SH       14
-#define __APP_PLL_425_CNTLMT0_1(_v)      ((_v) << __APP_PLL_425_CNTLMT0_1_SH)
-#define __APP_PLL_425_JITLMT0_1_MK       0x00003000
-#define __APP_PLL_425_JITLMT0_1_SH       12
-#define __APP_PLL_425_JITLMT0_1(_v)      ((_v) << __APP_PLL_425_JITLMT0_1_SH)
-#define __APP_PLL_425_HREF               0x00000800
-#define __APP_PLL_425_HDIV               0x00000400
-#define __APP_PLL_425_P0_1_MK            0x00000300
-#define __APP_PLL_425_P0_1_SH            8
-#define __APP_PLL_425_P0_1(_v)           ((_v) << __APP_PLL_425_P0_1_SH)
-#define __APP_PLL_425_Z0_2_MK            0x000000e0
-#define __APP_PLL_425_Z0_2_SH            5
-#define __APP_PLL_425_Z0_2(_v)           ((_v) << __APP_PLL_425_Z0_2_SH)
-#define __APP_PLL_425_RSEL200500         0x00000010
-#define __APP_PLL_425_ENARST             0x00000008
-#define __APP_PLL_425_BYPASS             0x00000004
-#define __APP_PLL_425_LRESETN            0x00000002
-#define __APP_PLL_425_ENABLE             0x00000001
-#define APP_PLL_312_CTL_REG              0x00014208
-#define __P_312_PLL_LOCK                 0x80000000
-#define __ENABLE_MAC_AHB_1               0x00800000
-#define __ENABLE_MAC_AHB_0               0x00400000
-#define __ENABLE_MAC_1                   0x00200000
-#define __ENABLE_MAC_0                   0x00100000
-#define __APP_PLL_312_RESET_TIMER_MK     0x000e0000
-#define __APP_PLL_312_RESET_TIMER_SH     17
-#define __APP_PLL_312_RESET_TIMER(_v)    ((_v) << __APP_PLL_312_RESET_TIMER_SH)
-#define __APP_PLL_312_LOGIC_SOFT_RESET   0x00010000
-#define __APP_PLL_312_CNTLMT0_1_MK       0x0000c000
-#define __APP_PLL_312_CNTLMT0_1_SH       14
-#define __APP_PLL_312_CNTLMT0_1(_v)      ((_v) << __APP_PLL_312_CNTLMT0_1_SH)
-#define __APP_PLL_312_JITLMT0_1_MK       0x00003000
-#define __APP_PLL_312_JITLMT0_1_SH       12
-#define __APP_PLL_312_JITLMT0_1(_v)      ((_v) << __APP_PLL_312_JITLMT0_1_SH)
-#define __APP_PLL_312_HREF               0x00000800
-#define __APP_PLL_312_HDIV               0x00000400
-#define __APP_PLL_312_P0_1_MK            0x00000300
-#define __APP_PLL_312_P0_1_SH            8
-#define __APP_PLL_312_P0_1(_v)           ((_v) << __APP_PLL_312_P0_1_SH)
-#define __APP_PLL_312_Z0_2_MK            0x000000e0
-#define __APP_PLL_312_Z0_2_SH            5
-#define __APP_PLL_312_Z0_2(_v)           ((_v) << __APP_PLL_312_Z0_2_SH)
-#define __APP_PLL_312_RSEL200500         0x00000010
-#define __APP_PLL_312_ENARST             0x00000008
-#define __APP_PLL_312_BYPASS             0x00000004
-#define __APP_PLL_312_LRESETN            0x00000002
-#define __APP_PLL_312_ENABLE             0x00000001
-#define MBIST_CTL_REG                    0x00014220
-#define __EDRAM_BISTR_START              0x00000004
-#define __MBIST_RESET                    0x00000002
-#define __MBIST_START                    0x00000001
-#define MBIST_STAT_REG                   0x00014224
-#define __EDRAM_BISTR_STATUS             0x00000008
-#define __EDRAM_BISTR_DONE               0x00000004
-#define __MEM_BIT_STATUS                 0x00000002
-#define __MBIST_DONE                     0x00000001
-#define HOST_SEM0_REG                    0x00014230
-#define __HOST_SEMAPHORE                 0x00000001
-#define HOST_SEM1_REG                    0x00014234
-#define HOST_SEM2_REG                    0x00014238
-#define HOST_SEM3_REG                    0x0001423c
-#define HOST_SEM0_INFO_REG               0x00014240
-#define HOST_SEM1_INFO_REG               0x00014244
-#define HOST_SEM2_INFO_REG               0x00014248
-#define HOST_SEM3_INFO_REG               0x0001424c
-#define ETH_MAC_SER_REG                  0x00014288
-#define __APP_EMS_CKBUFAMPIN             0x00000020
-#define __APP_EMS_REFCLKSEL              0x00000010
-#define __APP_EMS_CMLCKSEL               0x00000008
-#define __APP_EMS_REFCKBUFEN2            0x00000004
-#define __APP_EMS_REFCKBUFEN1            0x00000002
-#define __APP_EMS_CHANNEL_SEL            0x00000001
-#define HOSTFN2_INT_STATUS               0x00014300
-#define __HOSTFN2_HALT_OCCURRED          0x01000000
-#define __HOSTFN2_INT_STATUS_LVL_MK      0x00f00000
-#define __HOSTFN2_INT_STATUS_LVL_SH      20
-#define __HOSTFN2_INT_STATUS_LVL(_v)     ((_v) << __HOSTFN2_INT_STATUS_LVL_SH)
-#define __HOSTFN2_INT_STATUS_P_MK        0x000f0000
-#define __HOSTFN2_INT_STATUS_P_SH        16
-#define __HOSTFN2_INT_STATUS_P(_v)       ((_v) << __HOSTFN2_INT_STATUS_P_SH)
-#define __HOSTFN2_INT_STATUS_F           0x0000ffff
-#define HOSTFN2_INT_MSK                  0x00014304
-#define HOST_PAGE_NUM_FN2                0x00014308
-#define HOST_MSIX_ERR_INDEX_FN2          0x0001430c
-#define HOSTFN3_INT_STATUS               0x00014400
-#define __HALT_OCCURRED                  0x01000000
-#define __HOSTFN3_INT_STATUS_LVL_MK      0x00f00000
-#define __HOSTFN3_INT_STATUS_LVL_SH      20
-#define __HOSTFN3_INT_STATUS_LVL(_v)     ((_v) << __HOSTFN3_INT_STATUS_LVL_SH)
-#define __HOSTFN3_INT_STATUS_P_MK        0x000f0000
-#define __HOSTFN3_INT_STATUS_P_SH        16
-#define __HOSTFN3_INT_STATUS_P(_v)       ((_v) << __HOSTFN3_INT_STATUS_P_SH)
-#define __HOSTFN3_INT_STATUS_F           0x0000ffff
-#define HOSTFN3_INT_MSK                  0x00014404
-#define HOST_PAGE_NUM_FN3                0x00014408
-#define HOST_MSIX_ERR_INDEX_FN3          0x0001440c
-#define FNC_ID_REG                       0x00014600
-#define __FUNCTION_NUMBER                0x00000007
-#define FNC_PERS_REG                     0x00014604
-#define __F3_FUNCTION_ACTIVE             0x80000000
-#define __F3_FUNCTION_MODE               0x40000000
-#define __F3_PORT_MAP_MK                 0x30000000
-#define __F3_PORT_MAP_SH                 28
-#define __F3_PORT_MAP(_v)                ((_v) << __F3_PORT_MAP_SH)
-#define __F3_VM_MODE                     0x08000000
-#define __F3_INTX_STATUS_MK              0x07000000
-#define __F3_INTX_STATUS_SH              24
-#define __F3_INTX_STATUS(_v)             ((_v) << __F3_INTX_STATUS_SH)
-#define __F2_FUNCTION_ACTIVE             0x00800000
-#define __F2_FUNCTION_MODE               0x00400000
-#define __F2_PORT_MAP_MK                 0x00300000
-#define __F2_PORT_MAP_SH                 20
-#define __F2_PORT_MAP(_v)                ((_v) << __F2_PORT_MAP_SH)
-#define __F2_VM_MODE                     0x00080000
-#define __F2_INTX_STATUS_MK              0x00070000
-#define __F2_INTX_STATUS_SH              16
-#define __F2_INTX_STATUS(_v)             ((_v) << __F2_INTX_STATUS_SH)
-#define __F1_FUNCTION_ACTIVE             0x00008000
-#define __F1_FUNCTION_MODE               0x00004000
-#define __F1_PORT_MAP_MK                 0x00003000
-#define __F1_PORT_MAP_SH                 12
-#define __F1_PORT_MAP(_v)                ((_v) << __F1_PORT_MAP_SH)
-#define __F1_VM_MODE                     0x00000800
-#define __F1_INTX_STATUS_MK              0x00000700
-#define __F1_INTX_STATUS_SH              8
-#define __F1_INTX_STATUS(_v)             ((_v) << __F1_INTX_STATUS_SH)
-#define __F0_FUNCTION_ACTIVE             0x00000080
-#define __F0_FUNCTION_MODE               0x00000040
-#define __F0_PORT_MAP_MK                 0x00000030
-#define __F0_PORT_MAP_SH                 4
-#define __F0_PORT_MAP(_v)                ((_v) << __F0_PORT_MAP_SH)
-#define __F0_VM_MODE                     0x00000008
-#define __F0_INTX_STATUS                 0x00000007
-enum {
-    __F0_INTX_STATUS_MSIX            = 0x0,
-    __F0_INTX_STATUS_INTA            = 0x1,
-    __F0_INTX_STATUS_INTB            = 0x2,
-    __F0_INTX_STATUS_INTC            = 0x3,
-    __F0_INTX_STATUS_INTD            = 0x4,
-};
-#define OP_MODE                          0x0001460c
-#define __APP_ETH_CLK_LOWSPEED           0x00000004
-#define __GLOBAL_CORECLK_HALFSPEED       0x00000002
-#define __GLOBAL_FCOE_MODE               0x00000001
-#define HOST_SEM4_REG                    0x00014610
-#define HOST_SEM5_REG                    0x00014614
-#define HOST_SEM6_REG                    0x00014618
-#define HOST_SEM7_REG                    0x0001461c
-#define HOST_SEM4_INFO_REG               0x00014620
-#define HOST_SEM5_INFO_REG               0x00014624
-#define HOST_SEM6_INFO_REG               0x00014628
-#define HOST_SEM7_INFO_REG               0x0001462c
-#define HOSTFN0_LPU0_MBOX0_CMD_STAT      0x00019000
-#define __HOSTFN0_LPU0_MBOX0_INFO_MK     0xfffffffe
-#define __HOSTFN0_LPU0_MBOX0_INFO_SH     1
-#define __HOSTFN0_LPU0_MBOX0_INFO(_v)    ((_v) << __HOSTFN0_LPU0_MBOX0_INFO_SH)
-#define __HOSTFN0_LPU0_MBOX0_CMD_STATUS  0x00000001
-#define HOSTFN0_LPU1_MBOX0_CMD_STAT      0x00019004
-#define __HOSTFN0_LPU1_MBOX0_INFO_MK     0xfffffffe
-#define __HOSTFN0_LPU1_MBOX0_INFO_SH     1
-#define __HOSTFN0_LPU1_MBOX0_INFO(_v)    ((_v) << __HOSTFN0_LPU1_MBOX0_INFO_SH)
-#define __HOSTFN0_LPU1_MBOX0_CMD_STATUS  0x00000001
-#define LPU0_HOSTFN0_MBOX0_CMD_STAT      0x00019008
-#define __LPU0_HOSTFN0_MBOX0_INFO_MK     0xfffffffe
-#define __LPU0_HOSTFN0_MBOX0_INFO_SH     1
-#define __LPU0_HOSTFN0_MBOX0_INFO(_v)    ((_v) << __LPU0_HOSTFN0_MBOX0_INFO_SH)
-#define __LPU0_HOSTFN0_MBOX0_CMD_STATUS  0x00000001
-#define LPU1_HOSTFN0_MBOX0_CMD_STAT      0x0001900c
-#define __LPU1_HOSTFN0_MBOX0_INFO_MK     0xfffffffe
-#define __LPU1_HOSTFN0_MBOX0_INFO_SH     1
-#define __LPU1_HOSTFN0_MBOX0_INFO(_v)    ((_v) << __LPU1_HOSTFN0_MBOX0_INFO_SH)
-#define __LPU1_HOSTFN0_MBOX0_CMD_STATUS  0x00000001
-#define HOSTFN1_LPU0_MBOX0_CMD_STAT      0x00019010
-#define __HOSTFN1_LPU0_MBOX0_INFO_MK     0xfffffffe
-#define __HOSTFN1_LPU0_MBOX0_INFO_SH     1
-#define __HOSTFN1_LPU0_MBOX0_INFO(_v)    ((_v) << __HOSTFN1_LPU0_MBOX0_INFO_SH)
-#define __HOSTFN1_LPU0_MBOX0_CMD_STATUS  0x00000001
-#define HOSTFN1_LPU1_MBOX0_CMD_STAT      0x00019014
-#define __HOSTFN1_LPU1_MBOX0_INFO_MK     0xfffffffe
-#define __HOSTFN1_LPU1_MBOX0_INFO_SH     1
-#define __HOSTFN1_LPU1_MBOX0_INFO(_v)    ((_v) << __HOSTFN1_LPU1_MBOX0_INFO_SH)
-#define __HOSTFN1_LPU1_MBOX0_CMD_STATUS  0x00000001
-#define LPU0_HOSTFN1_MBOX0_CMD_STAT      0x00019018
-#define __LPU0_HOSTFN1_MBOX0_INFO_MK     0xfffffffe
-#define __LPU0_HOSTFN1_MBOX0_INFO_SH     1
-#define __LPU0_HOSTFN1_MBOX0_INFO(_v)    ((_v) << __LPU0_HOSTFN1_MBOX0_INFO_SH)
-#define __LPU0_HOSTFN1_MBOX0_CMD_STATUS  0x00000001
-#define LPU1_HOSTFN1_MBOX0_CMD_STAT      0x0001901c
-#define __LPU1_HOSTFN1_MBOX0_INFO_MK     0xfffffffe
-#define __LPU1_HOSTFN1_MBOX0_INFO_SH     1
-#define __LPU1_HOSTFN1_MBOX0_INFO(_v)    ((_v) << __LPU1_HOSTFN1_MBOX0_INFO_SH)
-#define __LPU1_HOSTFN1_MBOX0_CMD_STATUS  0x00000001
-#define HOSTFN2_LPU0_MBOX0_CMD_STAT      0x00019150
-#define __HOSTFN2_LPU0_MBOX0_INFO_MK     0xfffffffe
-#define __HOSTFN2_LPU0_MBOX0_INFO_SH     1
-#define __HOSTFN2_LPU0_MBOX0_INFO(_v)    ((_v) << __HOSTFN2_LPU0_MBOX0_INFO_SH)
-#define __HOSTFN2_LPU0_MBOX0_CMD_STATUS  0x00000001
-#define HOSTFN2_LPU1_MBOX0_CMD_STAT      0x00019154
-#define __HOSTFN2_LPU1_MBOX0_INFO_MK     0xfffffffe
-#define __HOSTFN2_LPU1_MBOX0_INFO_SH     1
-#define __HOSTFN2_LPU1_MBOX0_INFO(_v)    ((_v) << __HOSTFN2_LPU1_MBOX0_INFO_SH)
-#define __HOSTFN2_LPU1_MBOX0BOX0_CMD_STATUS 0x00000001
-#define LPU0_HOSTFN2_MBOX0_CMD_STAT      0x00019158
-#define __LPU0_HOSTFN2_MBOX0_INFO_MK     0xfffffffe
-#define __LPU0_HOSTFN2_MBOX0_INFO_SH     1
-#define __LPU0_HOSTFN2_MBOX0_INFO(_v)    ((_v) << __LPU0_HOSTFN2_MBOX0_INFO_SH)
-#define __LPU0_HOSTFN2_MBOX0_CMD_STATUS  0x00000001
-#define LPU1_HOSTFN2_MBOX0_CMD_STAT      0x0001915c
-#define __LPU1_HOSTFN2_MBOX0_INFO_MK     0xfffffffe
-#define __LPU1_HOSTFN2_MBOX0_INFO_SH     1
-#define __LPU1_HOSTFN2_MBOX0_INFO(_v)    ((_v) << __LPU1_HOSTFN2_MBOX0_INFO_SH)
-#define __LPU1_HOSTFN2_MBOX0_CMD_STATUS  0x00000001
-#define HOSTFN3_LPU0_MBOX0_CMD_STAT      0x00019160
-#define __HOSTFN3_LPU0_MBOX0_INFO_MK     0xfffffffe
-#define __HOSTFN3_LPU0_MBOX0_INFO_SH     1
-#define __HOSTFN3_LPU0_MBOX0_INFO(_v)    ((_v) << __HOSTFN3_LPU0_MBOX0_INFO_SH)
-#define __HOSTFN3_LPU0_MBOX0_CMD_STATUS  0x00000001
-#define HOSTFN3_LPU1_MBOX0_CMD_STAT      0x00019164
-#define __HOSTFN3_LPU1_MBOX0_INFO_MK     0xfffffffe
-#define __HOSTFN3_LPU1_MBOX0_INFO_SH     1
-#define __HOSTFN3_LPU1_MBOX0_INFO(_v)    ((_v) << __HOSTFN3_LPU1_MBOX0_INFO_SH)
-#define __HOSTFN3_LPU1_MBOX0_CMD_STATUS  0x00000001
-#define LPU0_HOSTFN3_MBOX0_CMD_STAT      0x00019168
-#define __LPU0_HOSTFN3_MBOX0_INFO_MK     0xfffffffe
-#define __LPU0_HOSTFN3_MBOX0_INFO_SH     1
-#define __LPU0_HOSTFN3_MBOX0_INFO(_v)    ((_v) << __LPU0_HOSTFN3_MBOX0_INFO_SH)
-#define __LPU0_HOSTFN3_MBOX0_CMD_STATUS  0x00000001
-#define LPU1_HOSTFN3_MBOX0_CMD_STAT      0x0001916c
-#define __LPU1_HOSTFN3_MBOX0_INFO_MK     0xfffffffe
-#define __LPU1_HOSTFN3_MBOX0_INFO_SH     1
-#define __LPU1_HOSTFN3_MBOX0_INFO(_v)    ((_v) << __LPU1_HOSTFN3_MBOX0_INFO_SH)
-#define __LPU1_HOSTFN3_MBOX0_CMD_STATUS  0x00000001
-#define FW_INIT_HALT_P0                  0x000191ac
-#define __FW_INIT_HALT_P                 0x00000001
-#define FW_INIT_HALT_P1                  0x000191bc
-#define CPE_PI_PTR_Q0                    0x00038000
-#define __CPE_PI_UNUSED_MK               0xffff0000
-#define __CPE_PI_UNUSED_SH               16
-#define __CPE_PI_UNUSED(_v)              ((_v) << __CPE_PI_UNUSED_SH)
-#define __CPE_PI_PTR                     0x0000ffff
-#define CPE_PI_PTR_Q1                    0x00038040
-#define CPE_CI_PTR_Q0                    0x00038004
-#define __CPE_CI_UNUSED_MK               0xffff0000
-#define __CPE_CI_UNUSED_SH               16
-#define __CPE_CI_UNUSED(_v)              ((_v) << __CPE_CI_UNUSED_SH)
-#define __CPE_CI_PTR                     0x0000ffff
-#define CPE_CI_PTR_Q1                    0x00038044
-#define CPE_DEPTH_Q0                     0x00038008
-#define __CPE_DEPTH_UNUSED_MK            0xf8000000
-#define __CPE_DEPTH_UNUSED_SH            27
-#define __CPE_DEPTH_UNUSED(_v)           ((_v) << __CPE_DEPTH_UNUSED_SH)
-#define __CPE_MSIX_VEC_INDEX_MK          0x07ff0000
-#define __CPE_MSIX_VEC_INDEX_SH          16
-#define __CPE_MSIX_VEC_INDEX(_v)         ((_v) << __CPE_MSIX_VEC_INDEX_SH)
-#define __CPE_DEPTH                      0x0000ffff
-#define CPE_DEPTH_Q1                     0x00038048
-#define CPE_QCTRL_Q0                     0x0003800c
-#define __CPE_CTRL_UNUSED30_MK           0xfc000000
-#define __CPE_CTRL_UNUSED30_SH           26
-#define __CPE_CTRL_UNUSED30(_v)          ((_v) << __CPE_CTRL_UNUSED30_SH)
-#define __CPE_FUNC_INT_CTRL_MK           0x03000000
-#define __CPE_FUNC_INT_CTRL_SH           24
-#define __CPE_FUNC_INT_CTRL(_v)          ((_v) << __CPE_FUNC_INT_CTRL_SH)
-enum {
-    __CPE_FUNC_INT_CTRL_DISABLE      = 0x0,
-    __CPE_FUNC_INT_CTRL_F2NF         = 0x1,
-    __CPE_FUNC_INT_CTRL_3QUART       = 0x2,
-    __CPE_FUNC_INT_CTRL_HALF         = 0x3,
-};
-#define __CPE_CTRL_UNUSED20_MK           0x00f00000
-#define __CPE_CTRL_UNUSED20_SH           20
-#define __CPE_CTRL_UNUSED20(_v)          ((_v) << __CPE_CTRL_UNUSED20_SH)
-#define __CPE_SCI_TH_MK                  0x000f0000
-#define __CPE_SCI_TH_SH                  16
-#define __CPE_SCI_TH(_v)                 ((_v) << __CPE_SCI_TH_SH)
-#define __CPE_CTRL_UNUSED10_MK           0x0000c000
-#define __CPE_CTRL_UNUSED10_SH           14
-#define __CPE_CTRL_UNUSED10(_v)          ((_v) << __CPE_CTRL_UNUSED10_SH)
-#define __CPE_ACK_PENDING                0x00002000
-#define __CPE_CTRL_UNUSED40_MK           0x00001c00
-#define __CPE_CTRL_UNUSED40_SH           10
-#define __CPE_CTRL_UNUSED40(_v)          ((_v) << __CPE_CTRL_UNUSED40_SH)
-#define __CPE_PCIEID_MK                  0x00000300
-#define __CPE_PCIEID_SH                  8
-#define __CPE_PCIEID(_v)                 ((_v) << __CPE_PCIEID_SH)
-#define __CPE_CTRL_UNUSED00_MK           0x000000fe
-#define __CPE_CTRL_UNUSED00_SH           1
-#define __CPE_CTRL_UNUSED00(_v)          ((_v) << __CPE_CTRL_UNUSED00_SH)
-#define __CPE_ESIZE                      0x00000001
-#define CPE_QCTRL_Q1                     0x0003804c
-#define __CPE_CTRL_UNUSED31_MK           0xfc000000
-#define __CPE_CTRL_UNUSED31_SH           26
-#define __CPE_CTRL_UNUSED31(_v)          ((_v) << __CPE_CTRL_UNUSED31_SH)
-#define __CPE_CTRL_UNUSED21_MK           0x00f00000
-#define __CPE_CTRL_UNUSED21_SH           20
-#define __CPE_CTRL_UNUSED21(_v)          ((_v) << __CPE_CTRL_UNUSED21_SH)
-#define __CPE_CTRL_UNUSED11_MK           0x0000c000
-#define __CPE_CTRL_UNUSED11_SH           14
-#define __CPE_CTRL_UNUSED11(_v)          ((_v) << __CPE_CTRL_UNUSED11_SH)
-#define __CPE_CTRL_UNUSED41_MK           0x00001c00
-#define __CPE_CTRL_UNUSED41_SH           10
-#define __CPE_CTRL_UNUSED41(_v)          ((_v) << __CPE_CTRL_UNUSED41_SH)
-#define __CPE_CTRL_UNUSED01_MK           0x000000fe
-#define __CPE_CTRL_UNUSED01_SH           1
-#define __CPE_CTRL_UNUSED01(_v)          ((_v) << __CPE_CTRL_UNUSED01_SH)
-#define RME_PI_PTR_Q0                    0x00038020
-#define __LATENCY_TIME_STAMP_MK          0xffff0000
-#define __LATENCY_TIME_STAMP_SH          16
-#define __LATENCY_TIME_STAMP(_v)         ((_v) << __LATENCY_TIME_STAMP_SH)
-#define __RME_PI_PTR                     0x0000ffff
-#define RME_PI_PTR_Q1                    0x00038060
-#define RME_CI_PTR_Q0                    0x00038024
-#define __DELAY_TIME_STAMP_MK            0xffff0000
-#define __DELAY_TIME_STAMP_SH            16
-#define __DELAY_TIME_STAMP(_v)           ((_v) << __DELAY_TIME_STAMP_SH)
-#define __RME_CI_PTR                     0x0000ffff
-#define RME_CI_PTR_Q1                    0x00038064
-#define RME_DEPTH_Q0                     0x00038028
-#define __RME_DEPTH_UNUSED_MK            0xf8000000
-#define __RME_DEPTH_UNUSED_SH            27
-#define __RME_DEPTH_UNUSED(_v)           ((_v) << __RME_DEPTH_UNUSED_SH)
-#define __RME_MSIX_VEC_INDEX_MK          0x07ff0000
-#define __RME_MSIX_VEC_INDEX_SH          16
-#define __RME_MSIX_VEC_INDEX(_v)         ((_v) << __RME_MSIX_VEC_INDEX_SH)
-#define __RME_DEPTH                      0x0000ffff
-#define RME_DEPTH_Q1                     0x00038068
-#define RME_QCTRL_Q0                     0x0003802c
-#define __RME_INT_LATENCY_TIMER_MK       0xff000000
-#define __RME_INT_LATENCY_TIMER_SH       24
-#define __RME_INT_LATENCY_TIMER(_v)      ((_v) << __RME_INT_LATENCY_TIMER_SH)
-#define __RME_INT_DELAY_TIMER_MK         0x00ff0000
-#define __RME_INT_DELAY_TIMER_SH         16
-#define __RME_INT_DELAY_TIMER(_v)        ((_v) << __RME_INT_DELAY_TIMER_SH)
-#define __RME_INT_DELAY_DISABLE          0x00008000
-#define __RME_DLY_DELAY_DISABLE          0x00004000
-#define __RME_ACK_PENDING                0x00002000
-#define __RME_FULL_INTERRUPT_DISABLE     0x00001000
-#define __RME_CTRL_UNUSED10_MK           0x00000c00
-#define __RME_CTRL_UNUSED10_SH           10
-#define __RME_CTRL_UNUSED10(_v)          ((_v) << __RME_CTRL_UNUSED10_SH)
-#define __RME_PCIEID_MK                  0x00000300
-#define __RME_PCIEID_SH                  8
-#define __RME_PCIEID(_v)                 ((_v) << __RME_PCIEID_SH)
-#define __RME_CTRL_UNUSED00_MK           0x000000fe
-#define __RME_CTRL_UNUSED00_SH           1
-#define __RME_CTRL_UNUSED00(_v)          ((_v) << __RME_CTRL_UNUSED00_SH)
-#define __RME_ESIZE                      0x00000001
-#define RME_QCTRL_Q1                     0x0003806c
-#define __RME_CTRL_UNUSED11_MK           0x00000c00
-#define __RME_CTRL_UNUSED11_SH           10
-#define __RME_CTRL_UNUSED11(_v)          ((_v) << __RME_CTRL_UNUSED11_SH)
-#define __RME_CTRL_UNUSED01_MK           0x000000fe
-#define __RME_CTRL_UNUSED01_SH           1
-#define __RME_CTRL_UNUSED01(_v)          ((_v) << __RME_CTRL_UNUSED01_SH)
-#define PSS_CTL_REG                      0x00018800
-#define __PSS_I2C_CLK_DIV_MK             0x007f0000
-#define __PSS_I2C_CLK_DIV_SH             16
-#define __PSS_I2C_CLK_DIV(_v)            ((_v) << __PSS_I2C_CLK_DIV_SH)
-#define __PSS_LMEM_INIT_DONE             0x00001000
-#define __PSS_LMEM_RESET                 0x00000200
-#define __PSS_LMEM_INIT_EN               0x00000100
-#define __PSS_LPU1_RESET                 0x00000002
-#define __PSS_LPU0_RESET                 0x00000001
-#define PSS_ERR_STATUS_REG               0x00018810
-#define __PSS_LPU1_TCM_READ_ERR          0x00200000
-#define __PSS_LPU0_TCM_READ_ERR          0x00100000
-#define __PSS_LMEM5_CORR_ERR             0x00080000
-#define __PSS_LMEM4_CORR_ERR             0x00040000
-#define __PSS_LMEM3_CORR_ERR             0x00020000
-#define __PSS_LMEM2_CORR_ERR             0x00010000
-#define __PSS_LMEM1_CORR_ERR             0x00008000
-#define __PSS_LMEM0_CORR_ERR             0x00004000
-#define __PSS_LMEM5_UNCORR_ERR           0x00002000
-#define __PSS_LMEM4_UNCORR_ERR           0x00001000
-#define __PSS_LMEM3_UNCORR_ERR           0x00000800
-#define __PSS_LMEM2_UNCORR_ERR           0x00000400
-#define __PSS_LMEM1_UNCORR_ERR           0x00000200
-#define __PSS_LMEM0_UNCORR_ERR           0x00000100
-#define __PSS_BAL_PERR                   0x00000080
-#define __PSS_DIP_IF_ERR                 0x00000040
-#define __PSS_IOH_IF_ERR                 0x00000020
-#define __PSS_TDS_IF_ERR                 0x00000010
-#define __PSS_RDS_IF_ERR                 0x00000008
-#define __PSS_SGM_IF_ERR                 0x00000004
-#define __PSS_LPU1_RAM_ERR               0x00000002
-#define __PSS_LPU0_RAM_ERR               0x00000001
-#define ERR_SET_REG                     0x00018818
-#define __PSS_ERR_STATUS_SET            0x003fffff
-#define PMM_1T_RESET_REG_P0              0x0002381c
-#define __PMM_1T_RESET_P                 0x00000001
-#define PMM_1T_RESET_REG_P1              0x00023c1c
-#define HQM_QSET0_RXQ_DRBL_P0            0x00038000
-#define __RXQ0_ADD_VECTORS_P             0x80000000
-#define __RXQ0_STOP_P                    0x40000000
-#define __RXQ0_PRD_PTR_P                 0x0000ffff
-#define HQM_QSET1_RXQ_DRBL_P0            0x00038080
-#define __RXQ1_ADD_VECTORS_P             0x80000000
-#define __RXQ1_STOP_P                    0x40000000
-#define __RXQ1_PRD_PTR_P                 0x0000ffff
-#define HQM_QSET0_RXQ_DRBL_P1            0x0003c000
-#define HQM_QSET1_RXQ_DRBL_P1            0x0003c080
-#define HQM_QSET0_TXQ_DRBL_P0            0x00038020
-#define __TXQ0_ADD_VECTORS_P             0x80000000
-#define __TXQ0_STOP_P                    0x40000000
-#define __TXQ0_PRD_PTR_P                 0x0000ffff
-#define HQM_QSET1_TXQ_DRBL_P0            0x000380a0
-#define __TXQ1_ADD_VECTORS_P             0x80000000
-#define __TXQ1_STOP_P                    0x40000000
-#define __TXQ1_PRD_PTR_P                 0x0000ffff
-#define HQM_QSET0_TXQ_DRBL_P1            0x0003c020
-#define HQM_QSET1_TXQ_DRBL_P1            0x0003c0a0
-#define HQM_QSET0_IB_DRBL_1_P0           0x00038040
-#define __IB1_0_ACK_P                    0x80000000
-#define __IB1_0_DISABLE_P                0x40000000
-#define __IB1_0_NUM_OF_ACKED_EVENTS_P    0x0000ffff
-#define HQM_QSET1_IB_DRBL_1_P0           0x000380c0
-#define __IB1_1_ACK_P                    0x80000000
-#define __IB1_1_DISABLE_P                0x40000000
-#define __IB1_1_NUM_OF_ACKED_EVENTS_P    0x0000ffff
-#define HQM_QSET0_IB_DRBL_1_P1           0x0003c040
-#define HQM_QSET1_IB_DRBL_1_P1           0x0003c0c0
-#define HQM_QSET0_IB_DRBL_2_P0           0x00038060
-#define __IB2_0_ACK_P                    0x80000000
-#define __IB2_0_DISABLE_P                0x40000000
-#define __IB2_0_NUM_OF_ACKED_EVENTS_P    0x0000ffff
-#define HQM_QSET1_IB_DRBL_2_P0           0x000380e0
-#define __IB2_1_ACK_P                    0x80000000
-#define __IB2_1_DISABLE_P                0x40000000
-#define __IB2_1_NUM_OF_ACKED_EVENTS_P    0x0000ffff
-#define HQM_QSET0_IB_DRBL_2_P1           0x0003c060
-#define HQM_QSET1_IB_DRBL_2_P1           0x0003c0e0
-
-
-/*
- * These definitions are either in error/missing in spec. Its auto-generated
- * from hard coded values in regparse.pl.
- */
-#define __EMPHPOST_AT_4G_MK_FIX          0x0000001c
-#define __EMPHPOST_AT_4G_SH_FIX          0x00000002
-#define __EMPHPRE_AT_4G_FIX              0x00000003
-#define __SFP_TXRATE_EN_FIX              0x00000100
-#define __SFP_RXRATE_EN_FIX              0x00000080
-
-
-/*
- * These register definitions are auto-generated from hard coded values
- * in regparse.pl.
- */
-
-
-/*
- * These register mapping definitions are auto-generated from mapping tables
- * in regparse.pl.
- */
-#define BFA_IOC0_HBEAT_REG               HOST_SEM0_INFO_REG
-#define BFA_IOC0_STATE_REG               HOST_SEM1_INFO_REG
-#define BFA_IOC1_HBEAT_REG               HOST_SEM2_INFO_REG
-#define BFA_IOC1_STATE_REG               HOST_SEM3_INFO_REG
-#define BFA_FW_USE_COUNT                 HOST_SEM4_INFO_REG
-
-#define CPE_DEPTH_Q(__n) \
-       (CPE_DEPTH_Q0 + (__n) * (CPE_DEPTH_Q1 - CPE_DEPTH_Q0))
-#define CPE_QCTRL_Q(__n) \
-       (CPE_QCTRL_Q0 + (__n) * (CPE_QCTRL_Q1 - CPE_QCTRL_Q0))
-#define CPE_PI_PTR_Q(__n) \
-       (CPE_PI_PTR_Q0 + (__n) * (CPE_PI_PTR_Q1 - CPE_PI_PTR_Q0))
-#define CPE_CI_PTR_Q(__n) \
-       (CPE_CI_PTR_Q0 + (__n) * (CPE_CI_PTR_Q1 - CPE_CI_PTR_Q0))
-#define RME_DEPTH_Q(__n) \
-       (RME_DEPTH_Q0 + (__n) * (RME_DEPTH_Q1 - RME_DEPTH_Q0))
-#define RME_QCTRL_Q(__n) \
-       (RME_QCTRL_Q0 + (__n) * (RME_QCTRL_Q1 - RME_QCTRL_Q0))
-#define RME_PI_PTR_Q(__n) \
-       (RME_PI_PTR_Q0 + (__n) * (RME_PI_PTR_Q1 - RME_PI_PTR_Q0))
-#define RME_CI_PTR_Q(__n) \
-       (RME_CI_PTR_Q0 + (__n) * (RME_CI_PTR_Q1 - RME_CI_PTR_Q0))
-#define HQM_QSET_RXQ_DRBL_P0(__n) \
-       (HQM_QSET0_RXQ_DRBL_P0 + (__n) * (HQM_QSET1_RXQ_DRBL_P0 - \
-       HQM_QSET0_RXQ_DRBL_P0))
-#define HQM_QSET_TXQ_DRBL_P0(__n) \
-       (HQM_QSET0_TXQ_DRBL_P0 + (__n) * (HQM_QSET1_TXQ_DRBL_P0 - \
-       HQM_QSET0_TXQ_DRBL_P0))
-#define HQM_QSET_IB_DRBL_1_P0(__n) \
-       (HQM_QSET0_IB_DRBL_1_P0 + (__n) * (HQM_QSET1_IB_DRBL_1_P0 - \
-       HQM_QSET0_IB_DRBL_1_P0))
-#define HQM_QSET_IB_DRBL_2_P0(__n) \
-       (HQM_QSET0_IB_DRBL_2_P0 + (__n) * (HQM_QSET1_IB_DRBL_2_P0 - \
-       HQM_QSET0_IB_DRBL_2_P0))
-#define HQM_QSET_RXQ_DRBL_P1(__n) \
-       (HQM_QSET0_RXQ_DRBL_P1 + (__n) * (HQM_QSET1_RXQ_DRBL_P1 - \
-       HQM_QSET0_RXQ_DRBL_P1))
-#define HQM_QSET_TXQ_DRBL_P1(__n) \
-       (HQM_QSET0_TXQ_DRBL_P1 + (__n) * (HQM_QSET1_TXQ_DRBL_P1 - \
-       HQM_QSET0_TXQ_DRBL_P1))
-#define HQM_QSET_IB_DRBL_1_P1(__n) \
-       (HQM_QSET0_IB_DRBL_1_P1 + (__n) * (HQM_QSET1_IB_DRBL_1_P1 - \
-       HQM_QSET0_IB_DRBL_1_P1))
-#define HQM_QSET_IB_DRBL_2_P1(__n) \
-       (HQM_QSET0_IB_DRBL_2_P1 + (__n) * (HQM_QSET1_IB_DRBL_2_P1 - \
-       HQM_QSET0_IB_DRBL_2_P1))
-
-#define CPE_Q_NUM(__fn, __q)  (((__fn) << 2) + (__q))
-#define RME_Q_NUM(__fn, __q)  (((__fn) << 2) + (__q))
-#define CPE_Q_MASK(__q)  ((__q) & 0x3)
-#define RME_Q_MASK(__q)  ((__q) & 0x3)
-
-
-/*
- * PCI MSI-X vector defines
- */
-enum {
-    BFA_MSIX_CPE_Q0 = 0,
-    BFA_MSIX_CPE_Q1 = 1,
-    BFA_MSIX_CPE_Q2 = 2,
-    BFA_MSIX_CPE_Q3 = 3,
-    BFA_MSIX_RME_Q0 = 4,
-    BFA_MSIX_RME_Q1 = 5,
-    BFA_MSIX_RME_Q2 = 6,
-    BFA_MSIX_RME_Q3 = 7,
-    BFA_MSIX_LPU_ERR = 8,
-    BFA_MSIX_CT_MAX = 9,
-};
-
-/*
- * And corresponding host interrupt status bit field defines
- */
-#define __HFN_INT_CPE_Q0                   0x00000001U
-#define __HFN_INT_CPE_Q1                   0x00000002U
-#define __HFN_INT_CPE_Q2                   0x00000004U
-#define __HFN_INT_CPE_Q3                   0x00000008U
-#define __HFN_INT_CPE_Q4                   0x00000010U
-#define __HFN_INT_CPE_Q5                   0x00000020U
-#define __HFN_INT_CPE_Q6                   0x00000040U
-#define __HFN_INT_CPE_Q7                   0x00000080U
-#define __HFN_INT_RME_Q0                   0x00000100U
-#define __HFN_INT_RME_Q1                   0x00000200U
-#define __HFN_INT_RME_Q2                   0x00000400U
-#define __HFN_INT_RME_Q3                   0x00000800U
-#define __HFN_INT_RME_Q4                   0x00001000U
-#define __HFN_INT_RME_Q5                   0x00002000U
-#define __HFN_INT_RME_Q6                   0x00004000U
-#define __HFN_INT_RME_Q7                   0x00008000U
-#define __HFN_INT_ERR_EMC                  0x00010000U
-#define __HFN_INT_ERR_LPU0                 0x00020000U
-#define __HFN_INT_ERR_LPU1                 0x00040000U
-#define __HFN_INT_ERR_PSS                  0x00080000U
-#define __HFN_INT_MBOX_LPU0                0x00100000U
-#define __HFN_INT_MBOX_LPU1                0x00200000U
-#define __HFN_INT_MBOX1_LPU0               0x00400000U
-#define __HFN_INT_MBOX1_LPU1               0x00800000U
-#define __HFN_INT_LL_HALT                 0x01000000U
-#define __HFN_INT_CPE_MASK                 0x000000ffU
-#define __HFN_INT_RME_MASK                 0x0000ff00U
-
-
-/*
- * catapult memory map.
- */
-#define LL_PGN_HQM0                      0x0096
-#define LL_PGN_HQM1                      0x0097
-#define PSS_SMEM_PAGE_START    0x8000
-#define PSS_SMEM_PGNUM(_pg0, _ma)      ((_pg0) + ((_ma) >> 15))
-#define PSS_SMEM_PGOFF(_ma)    ((_ma) & 0x7fff)
-
-/*
- * End of catapult memory map
- */
-
-
-#endif /* __BFI_CTREG_H__ */
-
diff --git a/drivers/scsi/bfa/include/bfi/bfi_fabric.h b/drivers/scsi/bfa/include/bfi/bfi_fabric.h
deleted file mode 100644 (file)
index c0669ed..0000000
+++ /dev/null
@@ -1,92 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFI_FABRIC_H__
-#define __BFI_FABRIC_H__
-
-#include <bfi/bfi.h>
-
-#pragma pack(1)
-
-enum bfi_fabric_h2i_msgs {
-       BFI_FABRIC_H2I_CREATE_REQ       = 1,
-       BFI_FABRIC_H2I_DELETE_REQ       = 2,
-       BFI_FABRIC_H2I_SETAUTH          = 3,
-};
-
-enum bfi_fabric_i2h_msgs {
-       BFI_FABRIC_I2H_CREATE_RSP       = BFA_I2HM(1),
-       BFI_FABRIC_I2H_DELETE_RSP       = BFA_I2HM(2),
-       BFI_FABRIC_I2H_SETAUTH_RSP      = BFA_I2HM(3),
-       BFI_FABRIC_I2H_ONLINE           = BFA_I2HM(4),
-       BFI_FABRIC_I2H_OFFLINE          = BFA_I2HM(5),
-};
-
-struct bfi_fabric_create_req_s {
-       bfi_mhdr_t      mh;             /*  common msg header           */
-       u8         vf_en;               /*  virtual fabric enable       */
-       u8         rsvd;
-       u16        vf_id;               /*  virtual fabric ID           */
-       wwn_t           pwwn;           /*  port name                   */
-       wwn_t           nwwn;           /*  node name                   */
-};
-
-struct bfi_fabric_create_rsp_s {
-       bfi_mhdr_t      mh;             /*  common msg header           */
-       u16        bfa_handle;  /*  host fabric handle          */
-       u8         status;              /*  fabric create status        */
-       u8         rsvd;
-};
-
-struct bfi_fabric_delete_req_s {
-       bfi_mhdr_t      mh;             /*  common msg header           */
-       u16        fw_handle;   /*  firmware fabric handle      */
-       u16        rsvd;
-};
-
-struct bfi_fabric_delete_rsp_s {
-       bfi_mhdr_t      mh;             /*  common msg header           */
-       u16        bfa_handle;  /*  host fabric handle          */
-       u8         status;              /*  fabric deletion status      */
-       u8         rsvd;
-};
-
-#define BFI_FABRIC_AUTHSECRET_LEN      64
-struct bfi_fabric_setauth_req_s {
-       bfi_mhdr_t      mh;             /*  common msg header           */
-       u16        fw_handle;   /*  f/w handle of fabric        */
-       u8              algorithm;
-       u8              group;
-       u8              secret[BFI_FABRIC_AUTHSECRET_LEN];
-};
-
-union bfi_fabric_h2i_msg_u {
-       bfi_msg_t               *msg;
-       struct bfi_fabric_create_req_s  *create_req;
-       struct bfi_fabric_delete_req_s  *delete_req;
-};
-
-union bfi_fabric_i2h_msg_u {
-       bfi_msg_t               *msg;
-       struct bfi_fabric_create_rsp_s  *create_rsp;
-       struct bfi_fabric_delete_rsp_s  *delete_rsp;
-};
-
-#pragma pack()
-
-#endif /* __BFI_FABRIC_H__ */
-
diff --git a/drivers/scsi/bfa/include/bfi/bfi_fcpim.h b/drivers/scsi/bfa/include/bfi/bfi_fcpim.h
deleted file mode 100644 (file)
index 52c059f..0000000
+++ /dev/null
@@ -1,301 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFI_FCPIM_H__
-#define __BFI_FCPIM_H__
-
-#include "bfi.h"
-#include <protocol/fcp.h>
-
-#pragma pack(1)
-
-/*
- * Initiator mode I-T nexus interface defines.
- */
-
-enum bfi_itnim_h2i {
-       BFI_ITNIM_H2I_CREATE_REQ = 1,   /*  i-t nexus creation */
-       BFI_ITNIM_H2I_DELETE_REQ = 2,   /*  i-t nexus deletion */
-};
-
-enum bfi_itnim_i2h {
-       BFI_ITNIM_I2H_CREATE_RSP = BFA_I2HM(1),
-       BFI_ITNIM_I2H_DELETE_RSP = BFA_I2HM(2),
-       BFI_ITNIM_I2H_SLER_EVENT = BFA_I2HM(3),
-};
-
-struct bfi_itnim_create_req_s {
-       struct bfi_mhdr_s  mh;          /*  common msg header            */
-       u16        fw_handle;   /*  f/w handle for itnim         */
-       u8         class;               /*  FC class for IO              */
-       u8         seq_rec;     /*  sequence recovery support    */
-       u8         msg_no;              /*  seq id of the msg            */
-};
-
-struct bfi_itnim_create_rsp_s {
-       struct bfi_mhdr_s  mh;          /*  common msg header            */
-       u16        bfa_handle;  /*  bfa handle for itnim         */
-       u8         status;              /*  fcp request status           */
-       u8         seq_id;              /*  seq id of the msg            */
-};
-
-struct bfi_itnim_delete_req_s {
-       struct bfi_mhdr_s  mh;          /*  common msg header            */
-       u16        fw_handle;   /*  f/w itnim handle             */
-       u8         seq_id;              /*  seq id of the msg            */
-       u8         rsvd;
-};
-
-struct bfi_itnim_delete_rsp_s {
-       struct bfi_mhdr_s  mh;          /*  common msg header            */
-       u16        bfa_handle;  /*  bfa handle for itnim         */
-       u8         status;              /*  fcp request status           */
-       u8         seq_id;              /*  seq id of the msg            */
-};
-
-struct bfi_itnim_sler_event_s {
-       struct bfi_mhdr_s  mh;          /*  common msg header            */
-       u16        bfa_handle;  /*  bfa handle for itnim         */
-       u16        rsvd;
-};
-
-union bfi_itnim_h2i_msg_u {
-       struct bfi_itnim_create_req_s *create_req;
-       struct bfi_itnim_delete_req_s *delete_req;
-       struct bfi_msg_s      *msg;
-};
-
-union bfi_itnim_i2h_msg_u {
-       struct bfi_itnim_create_rsp_s *create_rsp;
-       struct bfi_itnim_delete_rsp_s *delete_rsp;
-       struct bfi_itnim_sler_event_s *sler_event;
-       struct bfi_msg_s      *msg;
-};
-
-/*
- * Initiator mode IO interface defines.
- */
-
-enum bfi_ioim_h2i {
-       BFI_IOIM_H2I_IOABORT_REQ = 1,   /*  IO abort request     */
-       BFI_IOIM_H2I_IOCLEANUP_REQ = 2, /*  IO cleanup request   */
-};
-
-enum bfi_ioim_i2h {
-       BFI_IOIM_I2H_IO_RSP = BFA_I2HM(1),      /*  non-fp IO response   */
-       BFI_IOIM_I2H_IOABORT_RSP = BFA_I2HM(2),/*  ABORT rsp     */
-};
-
-/**
- * IO command DIF info
- */
-struct bfi_ioim_dif_s {
-       u32     dif_info[4];
-};
-
-/**
- * FCP IO messages overview
- *
- * @note
- * - Max CDB length supported is 64 bytes.
- * - SCSI Linked commands and SCSI bi-directional Commands not
- *      supported.
- *
- */
-struct bfi_ioim_req_s {
-       struct bfi_mhdr_s  mh;          /*  Common msg header            */
-       u16        io_tag;              /*  I/O tag                      */
-       u16        rport_hdl;   /*  itnim/rport firmware handle */
-       struct fcp_cmnd_s cmnd;         /*  IO request info              */
-
-       /**
-        * SG elements array within the IO request must be double word
-        * aligned. This aligment is required to optimize SGM setup for the IO.
-        */
-       struct bfi_sge_s   sges[BFI_SGE_INLINE_MAX];
-       u8         io_timeout;
-       u8         dif_en;
-       u8         rsvd_a[2];
-       struct bfi_ioim_dif_s  dif;
-};
-
-/**
- *     This table shows various IO status codes from firmware and their
- *     meaning. Host driver can use these status codes to further process
- *     IO completions.
- *
- *     BFI_IOIM_STS_OK         : IO completed with error free SCSI &
- *                                        transport status.
- *                                        - io-tag can be reused.
- *
- *     BFA_IOIM_STS_SCSI_ERR           : IO completed with scsi error.
- *                                       - io-tag can be reused.
- *
- *     BFI_IOIM_STS_HOST_ABORTED       : IO was aborted successfully due to
- *                                        host request.
- *                                        - io-tag cannot be reused yet.
- *
- *     BFI_IOIM_STS_ABORTED            : IO was aborted successfully
- *                                        internally by f/w.
- *                                        - io-tag cannot be reused yet.
- *
- *     BFI_IOIM_STS_TIMEDOUT   : IO timedout and ABTS/RRQ is happening
- *                                        in the firmware and
- *                                        - io-tag cannot be reused yet.
- *
- *     BFI_IOIM_STS_SQER_NEEDED        : Firmware could not recover the IO
- *                                       with sequence level error
- *                                       logic and hence host needs to retry
- *                                       this IO with a different IO tag
- *                                       - io-tag cannot be used yet.
- *
- *     BFI_IOIM_STS_NEXUS_ABORT        : Second Level Error Recovery from host
- *                                       is required because 2 consecutive ABTS
- *                                       timedout and host needs logout and
- *                                       re-login with the target
- *                                       - io-tag cannot be used yet.
- *
- *     BFI_IOIM_STS_UNDERRUN   : IO completed with SCSI status good,
- *                                       but the data tranferred is less than
- *                                       the fcp data length in the command.
- *                                       ex. SCSI INQUIRY where transferred
- *                                       data length and residue count in FCP
- *                                       response accounts for total fcp-dl
- *                                       - io-tag can be reused.
- *
- *     BFI_IOIM_STS_OVERRUN    : IO completed with SCSI status good,
- *                                       but the data transerred is more than
- *                                       fcp data length in the command. ex.
- *                                       TAPE IOs where blocks can of unequal
- *                                       lengths.
- *                                       - io-tag can be reused.
- *
- *     BFI_IOIM_STS_RES_FREE   : Firmware has completed using io-tag
- *                                       during abort process
- *                                       - io-tag can be reused.
- *
- *     BFI_IOIM_STS_PROTO_ERR  : Firmware detected a protocol error.
- *                                       ex target sent more data than
- *                                       requested, or there was data frame
- *                                       loss and other reasons
- *                                       - io-tag cannot be used yet.
- *
- *     BFI_IOIM_STS_DIF_ERR    : Firwmare detected DIF error. ex: DIF
- *                                       CRC err or Ref Tag err or App tag err.
- *                                       - io-tag can be reused.
- *
- *     BFA_IOIM_STS_TSK_MGT_ABORT      : IO was aborted because of Task
- *                                       Management command from the host
- *                                       - io-tag can be reused.
- *
- *     BFI_IOIM_STS_UTAG               : Firmware does not know about this
- *                                       io_tag.
- *                                       - io-tag can be reused.
- */
-enum bfi_ioim_status {
-       BFI_IOIM_STS_OK = 0,
-       BFI_IOIM_STS_HOST_ABORTED = 1,
-       BFI_IOIM_STS_ABORTED = 2,
-       BFI_IOIM_STS_TIMEDOUT = 3,
-       BFI_IOIM_STS_RES_FREE = 4,
-       BFI_IOIM_STS_SQER_NEEDED = 5,
-       BFI_IOIM_STS_PROTO_ERR = 6,
-       BFI_IOIM_STS_UTAG = 7,
-       BFI_IOIM_STS_PATHTOV = 8,
-};
-
-#define BFI_IOIM_SNSLEN        (256)
-/**
- * I/O response message
- */
-struct bfi_ioim_rsp_s {
-       struct bfi_mhdr_s  mh;          /*  common msg header            */
-       u16        io_tag;              /*  completed IO tag             */
-       u16        bfa_rport_hndl;      /*  releated rport handle        */
-       u8         io_status;   /*  IO completion status         */
-       u8         reuse_io_tag;        /*  IO tag can be reused        */
-       u16     abort_tag;      /*  host abort request tag      */
-       u8              scsi_status;    /*  scsi status from target      */
-       u8              sns_len;        /*  scsi sense length            */
-       u8              resid_flags;    /*  IO residue flags             */
-       u8              rsvd_a;
-       u32     residue;        /*  IO residual length in bytes */
-       u32     rsvd_b[3];
-};
-
-struct bfi_ioim_abort_req_s {
-       struct bfi_mhdr_s  mh;          /*  Common msg header  */
-       u16        io_tag;         /*  I/O tag            */
-       u16        abort_tag;      /*  unique request tag */
-};
-
-/*
- * Initiator mode task management command interface defines.
- */
-
-enum bfi_tskim_h2i {
-       BFI_TSKIM_H2I_TM_REQ    = 1, /*  task-mgmt command         */
-       BFI_TSKIM_H2I_ABORT_REQ = 2, /*  task-mgmt command         */
-};
-
-enum bfi_tskim_i2h {
-       BFI_TSKIM_I2H_TM_RSP = BFA_I2HM(1),
-};
-
-struct bfi_tskim_req_s {
-       struct bfi_mhdr_s  mh;             /*  Common msg header          */
-       u16        tsk_tag;        /*  task management tag        */
-       u16        itn_fhdl;       /*  itn firmware handle        */
-       lun_t           lun;            /*  LU number                  */
-       u8         tm_flags;       /*  see fcp_tm_cmnd_t          */
-       u8         t_secs;         /*  Timeout value in seconds   */
-       u8         rsvd[2];
-};
-
-struct bfi_tskim_abortreq_s {
-       struct bfi_mhdr_s  mh;             /*  Common msg header          */
-       u16        tsk_tag;        /*  task management tag        */
-       u16        rsvd;
-};
-
-enum bfi_tskim_status {
-       /*
-        * Following are FCP-4 spec defined status codes,
-        * **DO NOT CHANGE THEM **
-        */
-       BFI_TSKIM_STS_OK       = 0,
-       BFI_TSKIM_STS_NOT_SUPP = 4,
-       BFI_TSKIM_STS_FAILED   = 5,
-
-       /**
-        * Defined by BFA
-        */
-       BFI_TSKIM_STS_TIMEOUT  = 10,    /*  TM request timedout     */
-       BFI_TSKIM_STS_ABORTED  = 11,    /*  Aborted on host request */
-};
-
-struct bfi_tskim_rsp_s {
-       struct bfi_mhdr_s  mh;          /*  Common msg header            */
-       u16        tsk_tag;     /*  task mgmt cmnd tag           */
-       u8         tsk_status;  /*  @ref bfi_tskim_status */
-       u8         rsvd;
-};
-
-#pragma pack()
-
-#endif /* __BFI_FCPIM_H__ */
-
diff --git a/drivers/scsi/bfa/include/bfi/bfi_fcxp.h b/drivers/scsi/bfa/include/bfi/bfi_fcxp.h
deleted file mode 100644 (file)
index e0e995a..0000000
+++ /dev/null
@@ -1,71 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFI_FCXP_H__
-#define __BFI_FCXP_H__
-
-#include "bfi.h"
-
-#pragma pack(1)
-
-enum bfi_fcxp_h2i {
-       BFI_FCXP_H2I_SEND_REQ = 1,
-};
-
-enum bfi_fcxp_i2h {
-       BFI_FCXP_I2H_SEND_RSP = BFA_I2HM(1),
-};
-
-#define BFA_FCXP_MAX_SGES      2
-
-/**
- * FCXP send request structure
- */
-struct bfi_fcxp_send_req_s {
-       struct bfi_mhdr_s  mh;          /*  Common msg header               */
-       u16        fcxp_tag;    /*  driver request tag              */
-       u16        max_frmsz;   /*  max send frame size     */
-       u16        vf_id;               /*  vsan tag if applicable          */
-       u16        rport_fw_hndl;       /*  FW Handle for the remote port  */
-       u8         class;               /*  FC class used for req/rsp       */
-       u8         rsp_timeout; /*  timeout in secs, 0-no response */
-       u8         cts;         /*  continue sequence               */
-       u8         lp_tag;              /*  lport tag                       */
-       struct fchs_s   fchs;           /*  request FC header structure    */
-       u32        req_len;     /*  request payload length          */
-       u32        rsp_maxlen;  /*  max response length expected   */
-       struct bfi_sge_s   req_sge[BFA_FCXP_MAX_SGES];  /*  request buf    */
-       struct bfi_sge_s   rsp_sge[BFA_FCXP_MAX_SGES];  /*  response buf   */
-};
-
-/**
- * FCXP send response structure
- */
-struct bfi_fcxp_send_rsp_s {
-       struct bfi_mhdr_s  mh;          /*  Common msg header               */
-       u16        fcxp_tag;    /*  send request tag                */
-       u8         req_status;  /*  request status                  */
-       u8         rsvd;
-       u32        rsp_len;     /*  actual response length          */
-       u32        residue_len; /*  residual response length        */
-       struct fchs_s   fchs;           /*  response FC header structure   */
-};
-
-#pragma pack()
-
-#endif /* __BFI_FCXP_H__ */
-
diff --git a/drivers/scsi/bfa/include/bfi/bfi_ioc.h b/drivers/scsi/bfa/include/bfi/bfi_ioc.h
deleted file mode 100644 (file)
index 450ded6..0000000
+++ /dev/null
@@ -1,208 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFI_IOC_H__
-#define __BFI_IOC_H__
-
-#include "bfi.h"
-#include <defs/bfa_defs_ioc.h>
-
-#pragma pack(1)
-
-enum bfi_ioc_h2i_msgs {
-       BFI_IOC_H2I_ENABLE_REQ          = 1,
-       BFI_IOC_H2I_DISABLE_REQ         = 2,
-       BFI_IOC_H2I_GETATTR_REQ         = 3,
-       BFI_IOC_H2I_DBG_SYNC            = 4,
-       BFI_IOC_H2I_DBG_DUMP            = 5,
-};
-
-enum bfi_ioc_i2h_msgs {
-       BFI_IOC_I2H_ENABLE_REPLY        = BFA_I2HM(1),
-       BFI_IOC_I2H_DISABLE_REPLY       = BFA_I2HM(2),
-       BFI_IOC_I2H_GETATTR_REPLY       = BFA_I2HM(3),
-       BFI_IOC_I2H_READY_EVENT         = BFA_I2HM(4),
-       BFI_IOC_I2H_HBEAT               = BFA_I2HM(5),
-};
-
-/**
- * BFI_IOC_H2I_GETATTR_REQ message
- */
-struct bfi_ioc_getattr_req_s {
-       struct bfi_mhdr_s       mh;
-       union bfi_addr_u        attr_addr;
-};
-
-struct bfi_ioc_attr_s {
-       wwn_t           mfg_pwwn;       /* Mfg port wwn */
-       wwn_t           mfg_nwwn;       /* Mfg node wwn */
-       mac_t           mfg_mac;        /* Mfg mac      */
-       u16             rsvd_a;
-       wwn_t           pwwn;
-       wwn_t           nwwn;
-       mac_t           mac;            /* PBC or Mfg mac */
-       u16             rsvd_b;
-       char            brcd_serialnum[STRSZ(BFA_MFG_SERIALNUM_SIZE)];
-       u8         pcie_gen;
-       u8         pcie_lanes_orig;
-       u8         pcie_lanes;
-       u8         rx_bbcredit; /*  receive buffer credits */
-       u32        adapter_prop;        /*  adapter properties     */
-       u16        maxfrsize;   /*  max receive frame size */
-       char       asic_rev;
-       u8         rsvd_c;
-       char       fw_version[BFA_VERSION_LEN];
-       char       optrom_version[BFA_VERSION_LEN];
-       struct bfa_mfg_vpd_s    vpd;
-       u32        card_type;   /* card type */
-};
-
-/**
- * BFI_IOC_I2H_GETATTR_REPLY message
- */
-struct bfi_ioc_getattr_reply_s {
-       struct bfi_mhdr_s  mh;          /*  Common msg header          */
-       u8              status; /*  cfg reply status           */
-       u8              rsvd[3];
-};
-
-/**
- * Firmware memory page offsets
- */
-#define BFI_IOC_SMEM_PG0_CB    (0x40)
-#define BFI_IOC_SMEM_PG0_CT    (0x180)
-
-/**
- * Firmware trace offset
- */
-#define BFI_IOC_TRC_OFF                (0x4b00)
-#define BFI_IOC_TRC_ENTS       256
-
-#define BFI_IOC_FW_SIGNATURE   (0xbfadbfad)
-#define BFI_IOC_MD5SUM_SZ      4
-struct bfi_ioc_image_hdr_s {
-       u32        signature;   /*  constant signature */
-       u32        rsvd_a;
-       u32        exec;                /*  exec vector        */
-       u32        param;               /*  parameters         */
-       u32        rsvd_b[4];
-       u32        md5sum[BFI_IOC_MD5SUM_SZ];
-};
-
-/**
- *  BFI_IOC_I2H_READY_EVENT message
- */
-struct bfi_ioc_rdy_event_s {
-       struct bfi_mhdr_s  mh;                  /*  common msg header */
-       u8         init_status; /*  init event status */
-       u8         rsvd[3];
-};
-
-struct bfi_ioc_hbeat_s {
-       struct bfi_mhdr_s  mh;          /*  common msg header           */
-       u32        hb_count;    /*  current heart beat count    */
-};
-
-/**
- * IOC hardware/firmware state
- */
-enum bfi_ioc_state {
-       BFI_IOC_UNINIT   = 0,           /*  not initialized                 */
-       BFI_IOC_INITING          = 1,   /*  h/w is being initialized        */
-       BFI_IOC_HWINIT   = 2,           /*  h/w is initialized              */
-       BFI_IOC_CFG      = 3,           /*  IOC configuration in progress   */
-       BFI_IOC_OP               = 4,   /*  IOC is operational              */
-       BFI_IOC_DISABLING        = 5,   /*  IOC is being disabled           */
-       BFI_IOC_DISABLED         = 6,   /*  IOC is disabled                 */
-       BFI_IOC_CFG_DISABLED = 7,       /*  IOC is being disabled;transient */
-       BFI_IOC_FAIL       = 8,         /*  IOC heart-beat failure          */
-       BFI_IOC_MEMTEST      = 9,       /*  IOC is doing memtest            */
-};
-
-#define BFI_IOC_ENDIAN_SIG  0x12345678
-
-enum {
-       BFI_ADAPTER_TYPE_FC   = 0x01,           /*  FC adapters           */
-       BFI_ADAPTER_TYPE_MK   = 0x0f0000,       /*  adapter type mask     */
-       BFI_ADAPTER_TYPE_SH   = 16,             /*  adapter type shift    */
-       BFI_ADAPTER_NPORTS_MK = 0xff00,         /*  number of ports mask  */
-       BFI_ADAPTER_NPORTS_SH = 8,              /*  number of ports shift */
-       BFI_ADAPTER_SPEED_MK  = 0xff,           /*  adapter speed mask    */
-       BFI_ADAPTER_SPEED_SH  = 0,              /*  adapter speed shift   */
-       BFI_ADAPTER_PROTO     = 0x100000,       /*  prototype adapaters   */
-       BFI_ADAPTER_TTV       = 0x200000,       /*  TTV debug capable     */
-       BFI_ADAPTER_UNSUPP    = 0x400000,       /*  unknown adapter type  */
-};
-
-#define BFI_ADAPTER_GETP(__prop, __adap_prop)                          \
-    (((__adap_prop) & BFI_ADAPTER_ ## __prop ## _MK) >>         \
-     BFI_ADAPTER_ ## __prop ## _SH)
-#define BFI_ADAPTER_SETP(__prop, __val)                        \
-    ((__val) << BFI_ADAPTER_ ## __prop ## _SH)
-#define BFI_ADAPTER_IS_PROTO(__adap_type)                      \
-    ((__adap_type) & BFI_ADAPTER_PROTO)
-#define BFI_ADAPTER_IS_TTV(__adap_type)                        \
-    ((__adap_type) & BFI_ADAPTER_TTV)
-#define BFI_ADAPTER_IS_UNSUPP(__adap_type)                     \
-    ((__adap_type) & BFI_ADAPTER_UNSUPP)
-#define BFI_ADAPTER_IS_SPECIAL(__adap_type)                     \
-    ((__adap_type) & (BFI_ADAPTER_TTV | BFI_ADAPTER_PROTO |     \
-                       BFI_ADAPTER_UNSUPP))
-
-/**
- * BFI_IOC_H2I_ENABLE_REQ & BFI_IOC_H2I_DISABLE_REQ messages
- */
-struct bfi_ioc_ctrl_req_s {
-       struct bfi_mhdr_s       mh;
-       u8                      ioc_class;
-       u8              rsvd[3];
-};
-
-/**
- * BFI_IOC_I2H_ENABLE_REPLY & BFI_IOC_I2H_DISABLE_REPLY messages
- */
-struct bfi_ioc_ctrl_reply_s {
-       struct bfi_mhdr_s  mh;          /*  Common msg header     */
-       u8         status;              /*  enable/disable status */
-       u8         rsvd[3];
-};
-
-#define BFI_IOC_MSGSZ   8
-/**
- * H2I Messages
- */
-union bfi_ioc_h2i_msg_u {
-       struct bfi_mhdr_s       mh;
-       struct bfi_ioc_ctrl_req_s enable_req;
-       struct bfi_ioc_ctrl_req_s disable_req;
-       struct bfi_ioc_getattr_req_s getattr_req;
-       u32                     mboxmsg[BFI_IOC_MSGSZ];
-};
-
-/**
- * I2H Messages
- */
-union bfi_ioc_i2h_msg_u {
-       struct bfi_mhdr_s       mh;
-       struct bfi_ioc_rdy_event_s      rdy_event;
-       u32                     mboxmsg[BFI_IOC_MSGSZ];
-};
-
-#pragma pack()
-
-#endif /* __BFI_IOC_H__ */
-
diff --git a/drivers/scsi/bfa/include/bfi/bfi_iocfc.h b/drivers/scsi/bfa/include/bfi/bfi_iocfc.h
deleted file mode 100644 (file)
index ccdfcc5..0000000
+++ /dev/null
@@ -1,179 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFI_IOCFC_H__
-#define __BFI_IOCFC_H__
-
-#include "bfi.h"
-#include <bfi/bfi_pbc.h>
-#include <defs/bfa_defs_ioc.h>
-#include <defs/bfa_defs_iocfc.h>
-#include <defs/bfa_defs_boot.h>
-
-#pragma pack(1)
-
-enum bfi_iocfc_h2i_msgs {
-       BFI_IOCFC_H2I_CFG_REQ           = 1,
-       BFI_IOCFC_H2I_GET_STATS_REQ     = 2,
-       BFI_IOCFC_H2I_CLEAR_STATS_REQ   = 3,
-       BFI_IOCFC_H2I_SET_INTR_REQ      = 4,
-       BFI_IOCFC_H2I_UPDATEQ_REQ = 5,
-};
-
-enum bfi_iocfc_i2h_msgs {
-       BFI_IOCFC_I2H_CFG_REPLY         = BFA_I2HM(1),
-       BFI_IOCFC_I2H_GET_STATS_RSP     = BFA_I2HM(2),
-       BFI_IOCFC_I2H_CLEAR_STATS_RSP   = BFA_I2HM(3),
-       BFI_IOCFC_I2H_UPDATEQ_RSP = BFA_I2HM(5),
-};
-
-struct bfi_iocfc_cfg_s {
-       u8         num_cqs;     /*  Number of CQs to be used     */
-       u8         sense_buf_len;       /*  SCSI sense length            */
-       u8         trunk_enabled;       /*  port trunking enabled        */
-       u8         trunk_ports; /*  trunk ports bit map          */
-       u32        endian_sig;  /*  endian signature of host     */
-
-       /**
-        * Request and response circular queue base addresses, size and
-        * shadow index pointers.
-        */
-       union bfi_addr_u  req_cq_ba[BFI_IOC_MAX_CQS];
-       union bfi_addr_u  req_shadow_ci[BFI_IOC_MAX_CQS];
-       u16    req_cq_elems[BFI_IOC_MAX_CQS];
-       union bfi_addr_u  rsp_cq_ba[BFI_IOC_MAX_CQS];
-       union bfi_addr_u  rsp_shadow_pi[BFI_IOC_MAX_CQS];
-       u16    rsp_cq_elems[BFI_IOC_MAX_CQS];
-
-       union bfi_addr_u  stats_addr;   /*  DMA-able address for stats    */
-       union bfi_addr_u  cfgrsp_addr;  /*  config response dma address  */
-       union bfi_addr_u  ioim_snsbase;  /*  IO sense buffer base address */
-       struct bfa_iocfc_intr_attr_s intr_attr; /*  IOC interrupt attributes */
-};
-
-/**
- * Boot target wwn information for this port. This contains either the stored
- * or discovered boot target port wwns for the port.
- */
-struct bfi_iocfc_bootwwns {
-       wwn_t           wwn[BFA_BOOT_BOOTLUN_MAX];
-       u8              nwwns;
-       u8              rsvd[7];
-};
-
-struct bfi_iocfc_cfgrsp_s {
-       struct bfa_iocfc_fwcfg_s        fwcfg;
-       struct bfa_iocfc_intr_attr_s    intr_attr;
-       struct bfi_iocfc_bootwwns       bootwwns;
-       struct bfi_pbc_s                pbc_cfg;
-};
-
-/**
- * BFI_IOCFC_H2I_CFG_REQ message
- */
-struct bfi_iocfc_cfg_req_s {
-       struct bfi_mhdr_s      mh;
-       union bfi_addr_u      ioc_cfg_dma_addr;
-};
-
-/**
- * BFI_IOCFC_I2H_CFG_REPLY message
- */
-struct bfi_iocfc_cfg_reply_s {
-       struct bfi_mhdr_s  mh;          /*  Common msg header          */
-       u8         cfg_success; /*  cfg reply status           */
-       u8         lpu_bm;              /*  LPUs assigned for this IOC */
-       u8         rsvd[2];
-};
-
-/**
- *  BFI_IOCFC_H2I_GET_STATS_REQ & BFI_IOCFC_H2I_CLEAR_STATS_REQ messages
- */
-struct bfi_iocfc_stats_req_s {
-       struct bfi_mhdr_s mh;           /*  msg header            */
-       u32        msgtag;              /*  msgtag for reply      */
-};
-
-/**
- * BFI_IOCFC_I2H_GET_STATS_RSP & BFI_IOCFC_I2H_CLEAR_STATS_RSP messages
- */
-struct bfi_iocfc_stats_rsp_s {
-       struct bfi_mhdr_s mh;           /*  common msg header     */
-       u8         status;              /*  reply status          */
-       u8         rsvd[3];
-       u32        msgtag;              /*  msgtag for reply      */
-};
-
-/**
- * BFI_IOCFC_H2I_SET_INTR_REQ message
- */
-struct bfi_iocfc_set_intr_req_s {
-       struct bfi_mhdr_s mh;           /*  common msg header     */
-       u8              coalesce;       /*  enable intr coalescing*/
-       u8         rsvd[3];
-       u16     delay;          /*  delay timer 0..1125us  */
-       u16     latency;        /*  latency timer 0..225us */
-};
-
-/**
- * BFI_IOCFC_H2I_UPDATEQ_REQ message
- */
-struct bfi_iocfc_updateq_req_s {
-       struct bfi_mhdr_s mh;           /*  common msg header     */
-       u32 reqq_ba;                    /*  reqq base addr        */
-       u32 rspq_ba;                    /*  rspq base addr        */
-       u32 reqq_sci;                   /*  reqq shadow ci        */
-       u32 rspq_spi;                   /*  rspq shadow pi        */
-};
-
-/**
- * BFI_IOCFC_I2H_UPDATEQ_RSP message
- */
-struct bfi_iocfc_updateq_rsp_s {
-       struct bfi_mhdr_s mh;           /*  common msg header     */
-       u8         status;              /*  updateq  status       */
-       u8         rsvd[3];
-};
-
-/**
- * H2I Messages
- */
-union bfi_iocfc_h2i_msg_u {
-       struct bfi_mhdr_s               mh;
-       struct bfi_iocfc_cfg_req_s      cfg_req;
-       struct bfi_iocfc_stats_req_s stats_get;
-       struct bfi_iocfc_stats_req_s stats_clr;
-       struct bfi_iocfc_updateq_req_s updateq_req;
-       u32                             mboxmsg[BFI_IOC_MSGSZ];
-};
-
-/**
- * I2H Messages
- */
-union bfi_iocfc_i2h_msg_u {
-       struct bfi_mhdr_s               mh;
-       struct bfi_iocfc_cfg_reply_s            cfg_reply;
-       struct bfi_iocfc_stats_rsp_s stats_get_rsp;
-       struct bfi_iocfc_stats_rsp_s stats_clr_rsp;
-       struct bfi_iocfc_updateq_rsp_s updateq_rsp;
-       u32                             mboxmsg[BFI_IOC_MSGSZ];
-};
-
-#pragma pack()
-
-#endif /* __BFI_IOCFC_H__ */
-
diff --git a/drivers/scsi/bfa/include/bfi/bfi_lport.h b/drivers/scsi/bfa/include/bfi/bfi_lport.h
deleted file mode 100644 (file)
index 2901061..0000000
+++ /dev/null
@@ -1,89 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFI_LPORT_H__
-#define __BFI_LPORT_H__
-
-#include <bfi/bfi.h>
-
-#pragma pack(1)
-
-enum bfi_lport_h2i_msgs {
-       BFI_LPORT_H2I_CREATE_REQ = 1,
-       BFI_LPORT_H2I_DELETE_REQ = 2,
-};
-
-enum bfi_lport_i2h_msgs {
-       BFI_LPORT_I2H_CREATE_RSP = BFA_I2HM(1),
-       BFI_LPORT_I2H_DELETE_RSP = BFA_I2HM(2),
-       BFI_LPORT_I2H_ONLINE      = BFA_I2HM(3),
-       BFI_LPORT_I2H_OFFLINE     = BFA_I2HM(4),
-};
-
-#define BFI_LPORT_MAX_SYNNAME  64
-
-enum bfi_lport_role_e {
-       BFI_LPORT_ROLE_FCPIM    = 1,
-       BFI_LPORT_ROLE_FCPTM    = 2,
-       BFI_LPORT_ROLE_IPFC     = 4,
-};
-
-struct bfi_lport_create_req_s {
-       bfi_mhdr_t      mh;             /*  common msg header           */
-       u16     fabric_fwhdl;   /*  parent fabric instance      */
-       u8              roles;          /*  lport FC-4 roles            */
-       u8              rsvd;
-       wwn_t           pwwn;           /*  port name                   */
-       wwn_t           nwwn;           /*  node name                   */
-       u8              symname[BFI_LPORT_MAX_SYNNAME];
-};
-
-struct bfi_lport_create_rsp_s {
-       bfi_mhdr_t      mh;             /*  common msg header           */
-       u8         status;              /*  lport creation status       */
-       u8         rsvd[3];
-};
-
-struct bfi_lport_delete_req_s {
-       bfi_mhdr_t      mh;             /*  common msg header           */
-       u16        fw_handle;   /*  firmware lport handle       */
-       u16        rsvd;
-};
-
-struct bfi_lport_delete_rsp_s {
-       bfi_mhdr_t      mh;             /*  common msg header           */
-       u16        bfa_handle;  /*  host lport handle           */
-       u8         status;              /*  lport deletion status       */
-       u8         rsvd;
-};
-
-union bfi_lport_h2i_msg_u {
-       bfi_msg_t               *msg;
-       struct bfi_lport_create_req_s   *create_req;
-       struct bfi_lport_delete_req_s   *delete_req;
-};
-
-union bfi_lport_i2h_msg_u {
-       bfi_msg_t               *msg;
-       struct bfi_lport_create_rsp_s   *create_rsp;
-       struct bfi_lport_delete_rsp_s   *delete_rsp;
-};
-
-#pragma pack()
-
-#endif /* __BFI_LPORT_H__ */
-
diff --git a/drivers/scsi/bfa/include/bfi/bfi_lps.h b/drivers/scsi/bfa/include/bfi/bfi_lps.h
deleted file mode 100644 (file)
index 7ed31bb..0000000
+++ /dev/null
@@ -1,104 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFI_LPS_H__
-#define __BFI_LPS_H__
-
-#include <bfi/bfi.h>
-
-#pragma pack(1)
-
-enum bfi_lps_h2i_msgs {
-       BFI_LPS_H2I_LOGIN_REQ   = 1,
-       BFI_LPS_H2I_LOGOUT_REQ  = 2,
-};
-
-enum bfi_lps_i2h_msgs {
-       BFI_LPS_H2I_LOGIN_RSP   = BFA_I2HM(1),
-       BFI_LPS_H2I_LOGOUT_RSP  = BFA_I2HM(2),
-       BFI_LPS_H2I_CVL_EVENT   = BFA_I2HM(3),
-};
-
-struct bfi_lps_login_req_s {
-       struct bfi_mhdr_s  mh;          /*  common msg header           */
-       u8              lp_tag;
-       u8              alpa;
-       u16     pdu_size;
-       wwn_t           pwwn;
-       wwn_t           nwwn;
-       u8              fdisc;
-       u8              auth_en;
-       u8              rsvd[2];
-};
-
-struct bfi_lps_login_rsp_s {
-       struct bfi_mhdr_s  mh;          /*  common msg header           */
-       u8              lp_tag;
-       u8              status;
-       u8              lsrjt_rsn;
-       u8              lsrjt_expl;
-       wwn_t           port_name;
-       wwn_t           node_name;
-       u16     bb_credit;
-       u8              f_port;
-       u8              npiv_en;
-       u32     lp_pid:24;
-       u32     auth_req:8;
-       mac_t           lp_mac;
-       mac_t           fcf_mac;
-       u8              ext_status;
-       u8      brcd_switch;/*  attached peer is brcd switch    */
-};
-
-struct bfi_lps_logout_req_s {
-       struct bfi_mhdr_s  mh;          /*  common msg header           */
-       u8              lp_tag;
-       u8              rsvd[3];
-       wwn_t           port_name;
-};
-
-struct bfi_lps_logout_rsp_s {
-       struct bfi_mhdr_s  mh;          /*  common msg header           */
-       u8              lp_tag;
-       u8              status;
-       u8              rsvd[2];
-};
-
-struct bfi_lps_cvl_event_s {
-       struct bfi_mhdr_s  mh;      /* common msg header      */
-       u8              lp_tag;
-       u8              rsvd[3];
-};
-
-union bfi_lps_h2i_msg_u {
-       struct bfi_mhdr_s               *msg;
-       struct bfi_lps_login_req_s      *login_req;
-       struct bfi_lps_logout_req_s     *logout_req;
-};
-
-union bfi_lps_i2h_msg_u {
-       struct bfi_msg_s                *msg;
-       struct bfi_lps_login_rsp_s      *login_rsp;
-       struct bfi_lps_logout_rsp_s     *logout_rsp;
-       struct bfi_lps_cvl_event_s      *cvl_event;
-};
-
-#pragma pack()
-
-#endif /* __BFI_LPS_H__ */
-
-
diff --git a/drivers/scsi/bfa/include/bfi/bfi_pbc.h b/drivers/scsi/bfa/include/bfi/bfi_pbc.h
deleted file mode 100644 (file)
index 88a4154..0000000
+++ /dev/null
@@ -1,62 +0,0 @@
-/*
- * Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFI_PBC_H__
-#define __BFI_PBC_H__
-
-#pragma pack(1)
-
-#define BFI_PBC_MAX_BLUNS      8
-#define BFI_PBC_MAX_VPORTS     16
-
-#define BFI_PBC_PORT_DISABLED   2
-/**
- * PBC boot lun configuration
- */
-struct bfi_pbc_blun_s {
-       wwn_t           tgt_pwwn;
-       lun_t           tgt_lun;
-};
-
-/**
- * PBC virtual port configuration
- */
-struct bfi_pbc_vport_s {
-       wwn_t           vp_pwwn;
-       wwn_t           vp_nwwn;
-};
-
-/**
- * BFI pre-boot configuration information
- */
-struct bfi_pbc_s {
-       u8              port_enabled;
-       u8              boot_enabled;
-       u8              nbluns;
-       u8              nvports;
-       u8              port_speed;
-       u8              rsvd_a;
-       u16             hss;
-       wwn_t           pbc_pwwn;
-       wwn_t           pbc_nwwn;
-       struct bfi_pbc_blun_s blun[BFI_PBC_MAX_BLUNS];
-       struct bfi_pbc_vport_s vport[BFI_PBC_MAX_VPORTS];
-};
-
-#pragma pack()
-
-#endif /* __BFI_PBC_H__ */
diff --git a/drivers/scsi/bfa/include/bfi/bfi_port.h b/drivers/scsi/bfa/include/bfi/bfi_port.h
deleted file mode 100644 (file)
index 3ec3bea..0000000
+++ /dev/null
@@ -1,115 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-#ifndef __BFI_PORT_H__
-#define __BFI_PORT_H__
-
-#include <bfi/bfi.h>
-#include <defs/bfa_defs_pport.h>
-
-#pragma pack(1)
-
-enum bfi_port_h2i {
-       BFI_PORT_H2I_ENABLE_REQ         = (1),
-       BFI_PORT_H2I_DISABLE_REQ        = (2),
-       BFI_PORT_H2I_GET_STATS_REQ      = (3),
-       BFI_PORT_H2I_CLEAR_STATS_REQ    = (4),
-};
-
-enum bfi_port_i2h {
-       BFI_PORT_I2H_ENABLE_RSP         = BFA_I2HM(1),
-       BFI_PORT_I2H_DISABLE_RSP        = BFA_I2HM(2),
-       BFI_PORT_I2H_GET_STATS_RSP      = BFA_I2HM(3),
-       BFI_PORT_I2H_CLEAR_STATS_RSP    = BFA_I2HM(4),
-};
-
-/**
- * Generic REQ type
- */
-struct bfi_port_generic_req_s {
-       struct bfi_mhdr_s  mh;          /*  msg header                      */
-       u32        msgtag;              /*  msgtag for reply                */
-       u32     rsvd;
-};
-
-/**
- * Generic RSP type
- */
-struct bfi_port_generic_rsp_s {
-       struct bfi_mhdr_s  mh;          /*  common msg header               */
-       u8         status;              /*  port enable status              */
-       u8         rsvd[3];
-       u32        msgtag;              /*  msgtag for reply                */
-};
-
-/**
- * @todo
- * BFI_PORT_H2I_ENABLE_REQ
- */
-
-/**
- * @todo
- * BFI_PORT_I2H_ENABLE_RSP
- */
-
-/**
- * BFI_PORT_H2I_DISABLE_REQ
- */
-
-/**
- * BFI_PORT_I2H_DISABLE_RSP
- */
-
-/**
- * BFI_PORT_H2I_GET_STATS_REQ
- */
-struct bfi_port_get_stats_req_s {
-       struct bfi_mhdr_s  mh;          /*  common msg header               */
-       union bfi_addr_u   dma_addr;
-};
-
-/**
- * BFI_PORT_I2H_GET_STATS_RSP
- */
-
-/**
- * BFI_PORT_H2I_CLEAR_STATS_REQ
- */
-
-/**
- * BFI_PORT_I2H_CLEAR_STATS_RSP
- */
-
-union bfi_port_h2i_msg_u {
-       struct bfi_mhdr_s               mh;
-       struct bfi_port_generic_req_s   enable_req;
-       struct bfi_port_generic_req_s   disable_req;
-       struct bfi_port_get_stats_req_s getstats_req;
-       struct bfi_port_generic_req_s   clearstats_req;
-};
-
-union bfi_port_i2h_msg_u {
-       struct bfi_mhdr_s               mh;
-       struct bfi_port_generic_rsp_s   enable_rsp;
-       struct bfi_port_generic_rsp_s   disable_rsp;
-       struct bfi_port_generic_rsp_s   getstats_rsp;
-       struct bfi_port_generic_rsp_s   clearstats_rsp;
-};
-
-#pragma pack()
-
-#endif /* __BFI_PORT_H__ */
-
diff --git a/drivers/scsi/bfa/include/bfi/bfi_pport.h b/drivers/scsi/bfa/include/bfi/bfi_pport.h
deleted file mode 100644 (file)
index 50dcf45..0000000
+++ /dev/null
@@ -1,118 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-#ifndef __BFI_PPORT_H__
-#define __BFI_PPORT_H__
-
-#include <bfi/bfi.h>
-#include <defs/bfa_defs_pport.h>
-
-#pragma pack(1)
-
-enum bfi_fcport_h2i {
-       BFI_FCPORT_H2I_ENABLE_REQ               = (1),
-       BFI_FCPORT_H2I_DISABLE_REQ              = (2),
-       BFI_FCPORT_H2I_SET_SVC_PARAMS_REQ       = (3),
-       BFI_FCPORT_H2I_STATS_GET_REQ            = (4),
-       BFI_FCPORT_H2I_STATS_CLEAR_REQ          = (5),
-};
-
-enum bfi_fcport_i2h {
-       BFI_FCPORT_I2H_ENABLE_RSP               = BFA_I2HM(1),
-       BFI_FCPORT_I2H_DISABLE_RSP              = BFA_I2HM(2),
-       BFI_FCPORT_I2H_SET_SVC_PARAMS_RSP       = BFA_I2HM(3),
-       BFI_FCPORT_I2H_STATS_GET_RSP            = BFA_I2HM(4),
-       BFI_FCPORT_I2H_STATS_CLEAR_RSP          = BFA_I2HM(5),
-       BFI_FCPORT_I2H_EVENT                    = BFA_I2HM(6),
-};
-
-/**
- * Generic REQ type
- */
-struct bfi_fcport_req_s {
-       struct bfi_mhdr_s  mh;          /*  msg header                      */
-       u32        msgtag;      /*  msgtag for reply                */
-};
-
-/**
- * Generic RSP type
- */
-struct bfi_fcport_rsp_s {
-       struct bfi_mhdr_s  mh;          /*  common msg header               */
-       u8                 status;      /*  port enable status              */
-       u8                 rsvd[3];
-       u32        msgtag;      /*  msgtag for reply                */
-};
-
-/**
- * BFI_FCPORT_H2I_ENABLE_REQ
- */
-struct bfi_fcport_enable_req_s {
-       struct bfi_mhdr_s  mh;          /*  msg header                      */
-       u32        rsvd1;
-       wwn_t              nwwn;        /*  node wwn of physical port       */
-       wwn_t              pwwn;        /*  port wwn of physical port       */
-       struct bfa_pport_cfg_s port_cfg; /*  port configuration     */
-       union bfi_addr_u   stats_dma_addr; /*  DMA address for stats        */
-       u32        msgtag;      /*  msgtag for reply                */
-       u32        rsvd2;
-};
-
-/**
- * BFI_FCPORT_H2I_SET_SVC_PARAMS_REQ
- */
-struct bfi_fcport_set_svc_params_req_s {
-       struct bfi_mhdr_s  mh;          /*  msg header */
-       u16        tx_bbcredit; /*  Tx credits */
-       u16        rsvd;
-};
-
-/**
- * BFI_FCPORT_I2H_EVENT
- */
-struct bfi_fcport_event_s {
-       struct bfi_mhdr_s       mh;     /*  common msg header */
-       struct bfa_pport_link_s link_state;
-};
-
-/**
- * fcport H2I message
- */
-union bfi_fcport_h2i_msg_u {
-       struct bfi_mhdr_s                       *mhdr;
-       struct bfi_fcport_enable_req_s          *penable;
-       struct bfi_fcport_req_s                 *pdisable;
-       struct bfi_fcport_set_svc_params_req_s  *psetsvcparams;
-       struct bfi_fcport_req_s                 *pstatsget;
-       struct bfi_fcport_req_s                 *pstatsclear;
-};
-
-/**
- * fcport I2H message
- */
-union bfi_fcport_i2h_msg_u {
-       struct bfi_msg_s                        *msg;
-       struct bfi_fcport_rsp_s                 *penable_rsp;
-       struct bfi_fcport_rsp_s                 *pdisable_rsp;
-       struct bfi_fcport_rsp_s                 *psetsvcparams_rsp;
-       struct bfi_fcport_rsp_s                 *pstatsget_rsp;
-       struct bfi_fcport_rsp_s                 *pstatsclear_rsp;
-       struct bfi_fcport_event_s               *event;
-};
-
-#pragma pack()
-
-#endif /* __BFI_PPORT_H__ */
diff --git a/drivers/scsi/bfa/include/bfi/bfi_rport.h b/drivers/scsi/bfa/include/bfi/bfi_rport.h
deleted file mode 100644 (file)
index e1cd83b..0000000
+++ /dev/null
@@ -1,104 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFI_RPORT_H__
-#define __BFI_RPORT_H__
-
-#include <bfi/bfi.h>
-
-#pragma pack(1)
-
-enum bfi_rport_h2i_msgs {
-       BFI_RPORT_H2I_CREATE_REQ = 1,
-       BFI_RPORT_H2I_DELETE_REQ = 2,
-       BFI_RPORT_H2I_SET_SPEED_REQ  = 3,
-};
-
-enum bfi_rport_i2h_msgs {
-       BFI_RPORT_I2H_CREATE_RSP = BFA_I2HM(1),
-       BFI_RPORT_I2H_DELETE_RSP = BFA_I2HM(2),
-       BFI_RPORT_I2H_QOS_SCN    = BFA_I2HM(3),
-};
-
-struct bfi_rport_create_req_s {
-       struct bfi_mhdr_s  mh;          /*  common msg header           */
-       u16        bfa_handle;  /*  host rport handle           */
-       u16        max_frmsz;   /*  max rcv pdu size            */
-       u32        pid:24,              /*  remote port ID              */
-                       lp_tag:8;       /*  local port tag              */
-       u32        local_pid:24,        /*  local port ID               */
-                       cisc:8;
-       u8         fc_class;    /*  supported FC classes        */
-       u8         vf_en;               /*  virtual fabric enable       */
-       u16        vf_id;               /*  virtual fabric ID           */
-};
-
-struct bfi_rport_create_rsp_s {
-       struct bfi_mhdr_s  mh;          /*  common msg header           */
-       u8         status;              /*  rport creation status       */
-       u8         rsvd[3];
-       u16        bfa_handle;  /*  host rport handle           */
-       u16        fw_handle;   /*  firmware rport handle       */
-       struct bfa_rport_qos_attr_s qos_attr;  /* QoS Attributes */
-};
-
-struct bfa_rport_speed_req_s {
-       struct bfi_mhdr_s  mh;          /*  common msg header           */
-       u16        fw_handle;   /*  firmware rport handle       */
-       u8              speed;          /*! rport's speed via RPSC  */
-       u8              rsvd;
-};
-
-struct bfi_rport_delete_req_s {
-       struct bfi_mhdr_s  mh;          /*  common msg header           */
-       u16        fw_handle;   /*  firmware rport handle       */
-       u16        rsvd;
-};
-
-struct bfi_rport_delete_rsp_s {
-       struct bfi_mhdr_s  mh;          /*  common msg header           */
-       u16        bfa_handle;  /*  host rport handle           */
-       u8         status;              /*  rport deletion status       */
-       u8         rsvd;
-};
-
-struct bfi_rport_qos_scn_s {
-       struct bfi_mhdr_s  mh;          /*  common msg header           */
-       u16        bfa_handle;  /*  host rport handle           */
-       u16        rsvd;
-       struct bfa_rport_qos_attr_s old_qos_attr;  /* Old QoS Attributes */
-       struct bfa_rport_qos_attr_s new_qos_attr;  /* New QoS Attributes */
-};
-
-union bfi_rport_h2i_msg_u {
-       struct bfi_msg_s                *msg;
-       struct bfi_rport_create_req_s   *create_req;
-       struct bfi_rport_delete_req_s   *delete_req;
-       struct bfi_rport_speed_req_s    *speed_req;
-};
-
-union bfi_rport_i2h_msg_u {
-       struct bfi_msg_s                *msg;
-       struct bfi_rport_create_rsp_s   *create_rsp;
-       struct bfi_rport_delete_rsp_s   *delete_rsp;
-       struct bfi_rport_qos_scn_s      *qos_scn_evt;
-};
-
-#pragma pack()
-
-#endif /* __BFI_RPORT_H__ */
-
diff --git a/drivers/scsi/bfa/include/bfi/bfi_uf.h b/drivers/scsi/bfa/include/bfi/bfi_uf.h
deleted file mode 100644 (file)
index f328a9e..0000000
+++ /dev/null
@@ -1,52 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFI_UF_H__
-#define __BFI_UF_H__
-
-#include "bfi.h"
-
-#pragma pack(1)
-
-enum bfi_uf_h2i {
-       BFI_UF_H2I_BUF_POST = 1,
-};
-
-enum bfi_uf_i2h {
-       BFI_UF_I2H_FRM_RCVD = BFA_I2HM(1),
-};
-
-#define BFA_UF_MAX_SGES        2
-
-struct bfi_uf_buf_post_s {
-       struct bfi_mhdr_s  mh;          /*  Common msg header           */
-       u16        buf_tag;     /*  buffer tag                  */
-       u16        buf_len;     /*  total buffer length */
-       struct bfi_sge_s   sge[BFA_UF_MAX_SGES]; /*  buffer DMA SGEs    */
-};
-
-struct bfi_uf_frm_rcvd_s {
-       struct bfi_mhdr_s  mh;          /*  Common msg header           */
-       u16        buf_tag;     /*  buffer tag                  */
-       u16        rsvd;
-       u16        frm_len;     /*  received frame length       */
-       u16        xfr_len;     /*  tranferred length           */
-};
-
-#pragma pack()
-
-#endif /* __BFI_UF_H__ */
diff --git a/drivers/scsi/bfa/include/cna/bfa_cna_trcmod.h b/drivers/scsi/bfa/include/cna/bfa_cna_trcmod.h
deleted file mode 100644 (file)
index a75a1f3..0000000
+++ /dev/null
@@ -1,40 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  bfa_cna_trcmod.h CNA trace modules
- */
-
-#ifndef __BFA_CNA_TRCMOD_H__
-#define __BFA_CNA_TRCMOD_H__
-
-#include <cs/bfa_trc.h>
-
-/*
- * !!! Only append to the enums defined here to avoid any versioning
- * !!! needed between trace utility and driver version
- */
-enum {
-       BFA_TRC_CNA_CEE         = 1,
-       BFA_TRC_CNA_PORT        = 2,
-       BFA_TRC_CNA_IOC     = 3,
-       BFA_TRC_CNA_DIAG    = 4,
-       BFA_TRC_CNA_IOC_CB  = 5,
-       BFA_TRC_CNA_IOC_CT  = 6,
-};
-
-#endif /* __BFA_CNA_TRCMOD_H__ */
diff --git a/drivers/scsi/bfa/include/cna/cee/bfa_cee.h b/drivers/scsi/bfa/include/cna/cee/bfa_cee.h
deleted file mode 100644 (file)
index 77f297f..0000000
+++ /dev/null
@@ -1,77 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_CEE_H__
-#define __BFA_CEE_H__
-
-#include <defs/bfa_defs_cee.h>
-#include <bfa_ioc.h>
-#include <cs/bfa_trc.h>
-#include <cs/bfa_log.h>
-
-typedef void (*bfa_cee_get_attr_cbfn_t) (void *dev, bfa_status_t status);
-typedef void (*bfa_cee_get_stats_cbfn_t) (void *dev, bfa_status_t status);
-typedef void (*bfa_cee_reset_stats_cbfn_t) (void *dev, bfa_status_t status);
-typedef void (*bfa_cee_hbfail_cbfn_t) (void *dev, bfa_status_t status);
-
-struct bfa_cee_cbfn_s {
-       bfa_cee_get_attr_cbfn_t    get_attr_cbfn;
-       void *get_attr_cbarg;
-       bfa_cee_get_stats_cbfn_t   get_stats_cbfn;
-       void *get_stats_cbarg;
-       bfa_cee_reset_stats_cbfn_t reset_stats_cbfn;
-       void *reset_stats_cbarg;
-};
-
-struct bfa_cee_s {
-       void *dev;
-       bfa_boolean_t get_attr_pending;
-       bfa_boolean_t get_stats_pending;
-       bfa_boolean_t reset_stats_pending;
-       bfa_status_t get_attr_status;
-       bfa_status_t get_stats_status;
-       bfa_status_t reset_stats_status;
-       struct bfa_cee_cbfn_s cbfn;
-       struct bfa_ioc_hbfail_notify_s hbfail;
-       struct bfa_trc_mod_s *trcmod;
-       struct bfa_log_mod_s *logmod;
-       struct bfa_cee_attr_s *attr;
-       struct bfa_cee_stats_s *stats;
-       struct bfa_dma_s attr_dma;
-       struct bfa_dma_s stats_dma;
-       struct bfa_ioc_s *ioc;
-       struct bfa_mbox_cmd_s get_cfg_mb;
-       struct bfa_mbox_cmd_s get_stats_mb;
-       struct bfa_mbox_cmd_s reset_stats_mb;
-};
-
-u32 bfa_cee_meminfo(void);
-void bfa_cee_mem_claim(struct bfa_cee_s *cee, u8 *dma_kva,
-                        u64 dma_pa);
-void bfa_cee_attach(struct bfa_cee_s *cee, struct bfa_ioc_s *ioc, void *dev,
-                       struct bfa_trc_mod_s *trcmod,
-                       struct bfa_log_mod_s *logmod);
-void bfa_cee_detach(struct bfa_cee_s *cee);
-bfa_status_t bfa_cee_get_attr(struct bfa_cee_s *cee,
-                        struct bfa_cee_attr_s *attr,
-                       bfa_cee_get_attr_cbfn_t cbfn, void *cbarg);
-bfa_status_t bfa_cee_get_stats(struct bfa_cee_s *cee,
-                       struct bfa_cee_stats_s *stats,
-                       bfa_cee_get_stats_cbfn_t cbfn, void *cbarg);
-bfa_status_t bfa_cee_reset_stats(struct bfa_cee_s *cee,
-                       bfa_cee_reset_stats_cbfn_t cbfn, void *cbarg);
-#endif /* __BFA_CEE_H__ */
diff --git a/drivers/scsi/bfa/include/cna/port/bfa_port.h b/drivers/scsi/bfa/include/cna/port/bfa_port.h
deleted file mode 100644 (file)
index d7babaf..0000000
+++ /dev/null
@@ -1,70 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_PORT_H__
-#define __BFA_PORT_H__
-
-#include <defs/bfa_defs_port.h>
-#include <bfa_ioc.h>
-#include <cs/bfa_trc.h>
-#include <cs/bfa_log.h>
-
-typedef void    (*bfa_port_stats_cbfn_t) (void *dev, bfa_status_t status);
-typedef void    (*bfa_port_endis_cbfn_t) (void *dev, bfa_status_t status);
-
-struct bfa_port_s {
-       void           *dev;
-       struct bfa_ioc_s *ioc;
-       struct bfa_trc_mod_s *trcmod;
-       struct bfa_log_mod_s *logmod;
-       u32        msgtag;
-       bfa_boolean_t   stats_busy;
-       struct bfa_mbox_cmd_s stats_mb;
-       bfa_port_stats_cbfn_t stats_cbfn;
-       void           *stats_cbarg;
-       bfa_status_t    stats_status;
-       u32             stats_reset_time;
-       union bfa_pport_stats_u *stats;
-       struct bfa_dma_s stats_dma;
-       bfa_boolean_t   endis_pending;
-       struct bfa_mbox_cmd_s endis_mb;
-       bfa_port_endis_cbfn_t endis_cbfn;
-       void           *endis_cbarg;
-       bfa_status_t    endis_status;
-       struct bfa_ioc_hbfail_notify_s hbfail;
-};
-
-void            bfa_port_attach(struct bfa_port_s *port, struct bfa_ioc_s *ioc,
-                               void *dev, struct bfa_trc_mod_s *trcmod,
-                               struct bfa_log_mod_s *logmod);
-void            bfa_port_detach(struct bfa_port_s *port);
-void            bfa_port_hbfail(void *arg);
-
-bfa_status_t    bfa_port_get_stats(struct bfa_port_s *port,
-                                  union bfa_pport_stats_u *stats,
-                                  bfa_port_stats_cbfn_t cbfn, void *cbarg);
-bfa_status_t    bfa_port_clear_stats(struct bfa_port_s *port,
-                                    bfa_port_stats_cbfn_t cbfn, void *cbarg);
-bfa_status_t    bfa_port_enable(struct bfa_port_s *port,
-                               bfa_port_endis_cbfn_t cbfn, void *cbarg);
-bfa_status_t    bfa_port_disable(struct bfa_port_s *port,
-                                bfa_port_endis_cbfn_t cbfn, void *cbarg);
-u32        bfa_port_meminfo(void);
-void            bfa_port_mem_claim(struct bfa_port_s *port, u8 *dma_kva,
-                                  u64 dma_pa);
-
-#endif /* __BFA_PORT_H__ */
diff --git a/drivers/scsi/bfa/include/cna/pstats/ethport_defs.h b/drivers/scsi/bfa/include/cna/pstats/ethport_defs.h
deleted file mode 100644 (file)
index 1563ee5..0000000
+++ /dev/null
@@ -1,36 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved.
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __ETHPORT_DEFS_H__
-#define __ETHPORT_DEFS_H__
-
-struct bnad_drv_stats {
-       u64 netif_queue_stop;
-       u64 netif_queue_wakeup;
-       u64 tso4;
-       u64 tso6;
-       u64 tso_err;
-       u64 tcpcsum_offload;
-       u64 udpcsum_offload;
-       u64 csum_help;
-       u64 csum_help_err;
-
-       u64 hw_stats_updates;
-       u64 netif_rx_schedule;
-       u64 netif_rx_complete;
-       u64 netif_rx_dropped;
-};
-#endif
diff --git a/drivers/scsi/bfa/include/cna/pstats/phyport_defs.h b/drivers/scsi/bfa/include/cna/pstats/phyport_defs.h
deleted file mode 100644 (file)
index eb75480..0000000
+++ /dev/null
@@ -1,218 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved.
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __PHYPORT_DEFS_H__
-#define __PHYPORT_DEFS_H__
-
-#define BNA_TXF_ID_MAX         64
-#define BNA_RXF_ID_MAX         64
-
-/*
- * Statistics
- */
-
-/*
- * TxF Frame Statistics
- */
-struct bna_stats_txf {
-       u64        ucast_octets;
-       u64        ucast;
-       u64        ucast_vlan;
-
-       u64        mcast_octets;
-       u64        mcast;
-       u64        mcast_vlan;
-
-       u64        bcast_octets;
-       u64        bcast;
-       u64        bcast_vlan;
-
-       u64        errors;
-       u64        filter_vlan; /* frames filtered due to VLAN */
-       u64        filter_mac_sa;       /* frames filtered due to SA check */
-};
-
-/*
- * RxF Frame Statistics
- */
-struct bna_stats_rxf {
-       u64        ucast_octets;
-       u64        ucast;
-       u64        ucast_vlan;
-
-       u64        mcast_octets;
-       u64        mcast;
-       u64        mcast_vlan;
-
-       u64        bcast_octets;
-       u64        bcast;
-       u64        bcast_vlan;
-       u64        frame_drops;
-};
-
-/*
- * FC Tx Frame Statistics
- */
-struct bna_stats_fc_tx {
-       u64        txf_ucast_octets;
-       u64        txf_ucast;
-       u64        txf_ucast_vlan;
-
-       u64        txf_mcast_octets;
-       u64        txf_mcast;
-       u64        txf_mcast_vlan;
-
-       u64        txf_bcast_octets;
-       u64        txf_bcast;
-       u64        txf_bcast_vlan;
-
-       u64        txf_parity_errors;
-       u64        txf_timeout;
-       u64        txf_fid_parity_errors;
-};
-
-/*
- * FC Rx Frame Statistics
- */
-struct bna_stats_fc_rx {
-       u64        rxf_ucast_octets;
-       u64        rxf_ucast;
-       u64        rxf_ucast_vlan;
-
-       u64        rxf_mcast_octets;
-       u64        rxf_mcast;
-       u64        rxf_mcast_vlan;
-
-       u64        rxf_bcast_octets;
-       u64        rxf_bcast;
-       u64        rxf_bcast_vlan;
-};
-
-/*
- * RAD Frame Statistics
- */
-struct cna_stats_rad {
-       u64        rx_frames;
-       u64        rx_octets;
-       u64        rx_vlan_frames;
-
-       u64        rx_ucast;
-       u64        rx_ucast_octets;
-       u64        rx_ucast_vlan;
-
-       u64        rx_mcast;
-       u64        rx_mcast_octets;
-       u64        rx_mcast_vlan;
-
-       u64        rx_bcast;
-       u64        rx_bcast_octets;
-       u64        rx_bcast_vlan;
-
-       u64        rx_drops;
-};
-
-/*
- * BPC Tx Registers
- */
-struct cna_stats_bpc_tx {
-       u64        tx_pause[8];
-       u64        tx_zero_pause[8];    /*  Pause cancellation */
-       u64        tx_first_pause[8];   /*  Pause initiation rather
-                                                *than retention */
-};
-
-/*
- * BPC Rx Registers
- */
-struct cna_stats_bpc_rx {
-       u64        rx_pause[8];
-       u64        rx_zero_pause[8];    /*  Pause cancellation */
-       u64        rx_first_pause[8];   /*  Pause initiation rather
-                                                *than retention */
-};
-
-/*
- * MAC Rx Statistics
- */
-struct cna_stats_mac_rx {
-       u64        frame_64;    /* both rx and tx counter */
-       u64        frame_65_127;        /* both rx and tx counter */
-       u64        frame_128_255;       /* both rx and tx counter */
-       u64        frame_256_511;       /* both rx and tx counter */
-       u64        frame_512_1023;      /* both rx and tx counter */
-       u64        frame_1024_1518;     /* both rx and tx counter */
-       u64        frame_1518_1522;     /* both rx and tx counter */
-       u64        rx_bytes;
-       u64        rx_packets;
-       u64        rx_fcs_error;
-       u64        rx_multicast;
-       u64        rx_broadcast;
-       u64        rx_control_frames;
-       u64        rx_pause;
-       u64        rx_unknown_opcode;
-       u64        rx_alignment_error;
-       u64        rx_frame_length_error;
-       u64        rx_code_error;
-       u64        rx_carrier_sense_error;
-       u64        rx_undersize;
-       u64        rx_oversize;
-       u64        rx_fragments;
-       u64        rx_jabber;
-       u64        rx_drop;
-};
-
-/*
- * MAC Tx Statistics
- */
-struct cna_stats_mac_tx {
-       u64        tx_bytes;
-       u64        tx_packets;
-       u64        tx_multicast;
-       u64        tx_broadcast;
-       u64        tx_pause;
-       u64        tx_deferral;
-       u64        tx_excessive_deferral;
-       u64        tx_single_collision;
-       u64        tx_muliple_collision;
-       u64        tx_late_collision;
-       u64        tx_excessive_collision;
-       u64        tx_total_collision;
-       u64        tx_pause_honored;
-       u64        tx_drop;
-       u64        tx_jabber;
-       u64        tx_fcs_error;
-       u64        tx_control_frame;
-       u64        tx_oversize;
-       u64        tx_undersize;
-       u64        tx_fragments;
-};
-
-/*
- * Complete statistics
- */
-struct bna_stats {
-       struct cna_stats_mac_rx mac_rx_stats;
-       struct cna_stats_bpc_rx bpc_rx_stats;
-       struct cna_stats_rad rad_stats;
-       struct bna_stats_fc_rx fc_rx_stats;
-       struct cna_stats_mac_tx mac_tx_stats;
-       struct cna_stats_bpc_tx bpc_tx_stats;
-       struct bna_stats_fc_tx fc_tx_stats;
-       struct bna_stats_rxf rxf_stats[BNA_TXF_ID_MAX];
-       struct bna_stats_txf txf_stats[BNA_RXF_ID_MAX];
-};
-
-#endif
diff --git a/drivers/scsi/bfa/include/cs/bfa_checksum.h b/drivers/scsi/bfa/include/cs/bfa_checksum.h
deleted file mode 100644 (file)
index 650f8d0..0000000
+++ /dev/null
@@ -1,60 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  bfa_checksum.h BFA checksum utilities
- */
-
-#ifndef __BFA_CHECKSUM_H__
-#define __BFA_CHECKSUM_H__
-
-static inline u32
-bfa_checksum_u32(u32 *buf, int sz)
-{
-       int             i, m = sz >> 2;
-       u32     sum = 0;
-
-       for (i = 0; i < m; i++)
-               sum ^= buf[i];
-
-       return sum;
-}
-
-static inline u16
-bfa_checksum_u16(u16 *buf, int sz)
-{
-       int             i, m = sz >> 1;
-       u16        sum = 0;
-
-       for (i = 0; i < m; i++)
-               sum ^= buf[i];
-
-       return sum;
-}
-
-static inline u8
-bfa_checksum_u8(u8 *buf, int sz)
-{
-       int             i;
-       u8         sum = 0;
-
-       for (i = 0; i < sz; i++)
-               sum ^= buf[i];
-
-       return sum;
-}
-#endif
diff --git a/drivers/scsi/bfa/include/cs/bfa_debug.h b/drivers/scsi/bfa/include/cs/bfa_debug.h
deleted file mode 100644 (file)
index 75a911e..0000000
+++ /dev/null
@@ -1,45 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  bfa_debug.h BFA debug interfaces
- */
-
-#ifndef __BFA_DEBUG_H__
-#define __BFA_DEBUG_H__
-
-#define bfa_assert(__cond)     do {                                    \
-       if (!(__cond))                                                  \
-               bfa_panic(__LINE__, __FILE__, #__cond);      \
-} while (0)
-
-#define bfa_sm_fault(__mod, __event)   do {                            \
-       bfa_trc(__mod, (((uint32_t)0xDEAD << 16) | __event));           \
-       bfa_sm_panic((__mod)->logm, __LINE__, __FILE__, __event);       \
-} while (0)
-
-#ifndef BFA_PERF_BUILD
-#define bfa_assert_fp(__cond)  bfa_assert(__cond)
-#else
-#define bfa_assert_fp(__cond)
-#endif
-
-struct bfa_log_mod_s;
-void bfa_panic(int line, char *file, char *panicstr);
-void bfa_sm_panic(struct bfa_log_mod_s *logm, int line, char *file, int event);
-
-#endif /* __BFA_DEBUG_H__ */
diff --git a/drivers/scsi/bfa/include/cs/bfa_log.h b/drivers/scsi/bfa/include/cs/bfa_log.h
deleted file mode 100644 (file)
index bc334e0..0000000
+++ /dev/null
@@ -1,184 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  bfa_log.h BFA log library data structure and function definition
- */
-
-#ifndef __BFA_LOG_H__
-#define __BFA_LOG_H__
-
-#include <bfa_os_inc.h>
-#include <defs/bfa_defs_status.h>
-#include <defs/bfa_defs_aen.h>
-
-/*
- * BFA log module definition
- *
- * To create a new module id:
- * Add a #define at the end of the list below. Select a value for your
- * definition so that it is one (1) greater than the previous
- * definition. Modify the definition of BFA_LOG_MODULE_ID_MAX to become
- * your new definition.
- * Should have no gaps in between the values because this is used in arrays.
- * IMPORTANT: AEN_IDs must be at the begining, otherwise update bfa_defs_aen.h
- */
-
-enum bfa_log_module_id {
-       BFA_LOG_UNUSED_ID       = 0,
-
-       /* AEN defs begin */
-       BFA_LOG_AEN_MIN         = BFA_LOG_UNUSED_ID,
-
-       BFA_LOG_AEN_ID_ADAPTER  = BFA_LOG_AEN_MIN + BFA_AEN_CAT_ADAPTER,/* 1 */
-       BFA_LOG_AEN_ID_PORT     = BFA_LOG_AEN_MIN + BFA_AEN_CAT_PORT,   /* 2 */
-       BFA_LOG_AEN_ID_LPORT    = BFA_LOG_AEN_MIN + BFA_AEN_CAT_LPORT,  /* 3 */
-       BFA_LOG_AEN_ID_RPORT    = BFA_LOG_AEN_MIN + BFA_AEN_CAT_RPORT,  /* 4 */
-       BFA_LOG_AEN_ID_ITNIM    = BFA_LOG_AEN_MIN + BFA_AEN_CAT_ITNIM,  /* 5 */
-       BFA_LOG_AEN_ID_TIN      = BFA_LOG_AEN_MIN + BFA_AEN_CAT_TIN,    /* 6 */
-       BFA_LOG_AEN_ID_IPFC     = BFA_LOG_AEN_MIN + BFA_AEN_CAT_IPFC,   /* 7 */
-       BFA_LOG_AEN_ID_AUDIT    = BFA_LOG_AEN_MIN + BFA_AEN_CAT_AUDIT,  /* 8 */
-       BFA_LOG_AEN_ID_IOC      = BFA_LOG_AEN_MIN + BFA_AEN_CAT_IOC,    /* 9 */
-       BFA_LOG_AEN_ID_ETHPORT  = BFA_LOG_AEN_MIN + BFA_AEN_CAT_ETHPORT,/* 10 */
-
-       BFA_LOG_AEN_MAX         = BFA_LOG_AEN_ID_ETHPORT,
-       /* AEN defs end */
-
-       BFA_LOG_MODULE_ID_MIN   = BFA_LOG_AEN_MAX,
-
-       BFA_LOG_FW_ID           = BFA_LOG_MODULE_ID_MIN + 1,
-       BFA_LOG_HAL_ID          = BFA_LOG_MODULE_ID_MIN + 2,
-       BFA_LOG_FCS_ID          = BFA_LOG_MODULE_ID_MIN + 3,
-       BFA_LOG_WDRV_ID         = BFA_LOG_MODULE_ID_MIN + 4,
-       BFA_LOG_LINUX_ID        = BFA_LOG_MODULE_ID_MIN + 5,
-       BFA_LOG_SOLARIS_ID      = BFA_LOG_MODULE_ID_MIN + 6,
-
-       BFA_LOG_MODULE_ID_MAX   = BFA_LOG_SOLARIS_ID,
-
-       /* Not part of any arrays */
-       BFA_LOG_MODULE_ID_ALL   = BFA_LOG_MODULE_ID_MAX + 1,
-       BFA_LOG_AEN_ALL         = BFA_LOG_MODULE_ID_MAX + 2,
-       BFA_LOG_DRV_ALL         = BFA_LOG_MODULE_ID_MAX + 3,
-};
-
-/*
- * BFA log catalog name
- */
-#define BFA_LOG_CAT_NAME       "BFA"
-
-/*
- * bfa log severity values
- */
-enum bfa_log_severity {
-       BFA_LOG_INVALID = 0,
-       BFA_LOG_CRITICAL = 1,
-       BFA_LOG_ERROR = 2,
-       BFA_LOG_WARNING = 3,
-       BFA_LOG_INFO = 4,
-       BFA_LOG_NONE = 5,
-       BFA_LOG_LEVEL_MAX = BFA_LOG_NONE
-};
-
-#define BFA_LOG_MODID_OFFSET           16
-
-
-struct bfa_log_msgdef_s {
-       u32     msg_id;         /*  message id */
-       int             attributes;     /*  attributes */
-       int             severity;       /*  severity level */
-       char            *msg_value;
-                                       /*  msg string */
-       char            *message;
-                                       /*  msg format string */
-       int             arg_type;       /*  argument type */
-       int             arg_num;        /*  number of argument */
-};
-
-/*
- * supported argument type
- */
-enum bfa_log_arg_type {
-       BFA_LOG_S = 0,          /*  string */
-       BFA_LOG_D,              /*  decimal */
-       BFA_LOG_I,              /*  integer */
-       BFA_LOG_O,              /*  oct number */
-       BFA_LOG_U,              /*  unsigned integer */
-       BFA_LOG_X,              /*  hex number */
-       BFA_LOG_F,              /*  floating */
-       BFA_LOG_C,              /*  character */
-       BFA_LOG_L,              /*  double */
-       BFA_LOG_P               /*  pointer */
-};
-
-#define BFA_LOG_ARG_TYPE       2
-#define BFA_LOG_ARG0           (0 * BFA_LOG_ARG_TYPE)
-#define BFA_LOG_ARG1           (1 * BFA_LOG_ARG_TYPE)
-#define BFA_LOG_ARG2           (2 * BFA_LOG_ARG_TYPE)
-#define BFA_LOG_ARG3           (3 * BFA_LOG_ARG_TYPE)
-
-#define BFA_LOG_GET_MOD_ID(msgid) ((msgid >> BFA_LOG_MODID_OFFSET) & 0xff)
-#define BFA_LOG_GET_MSG_IDX(msgid) (msgid & 0xffff)
-#define BFA_LOG_GET_MSG_ID(msgdef) ((msgdef)->msg_id)
-#define BFA_LOG_GET_MSG_FMT_STRING(msgdef) ((msgdef)->message)
-#define BFA_LOG_GET_SEVERITY(msgdef) ((msgdef)->severity)
-
-/*
- * Event attributes
- */
-#define BFA_LOG_ATTR_NONE      0
-#define BFA_LOG_ATTR_AUDIT     1
-#define BFA_LOG_ATTR_LOG       2
-#define BFA_LOG_ATTR_FFDC      4
-
-#define BFA_LOG_CREATE_ID(msw, lsw) \
-       (((u32)msw << BFA_LOG_MODID_OFFSET) | lsw)
-
-struct bfa_log_mod_s;
-
-/**
- * callback function
- */
-typedef void (*bfa_log_cb_t)(struct bfa_log_mod_s *log_mod, u32 msg_id,
-                       const char *format, ...);
-
-
-struct bfa_log_mod_s {
-       char            instance_info[BFA_STRING_32];   /*  instance info */
-       int             log_level[BFA_LOG_MODULE_ID_MAX + 1];
-                                               /*  log level for modules */
-       bfa_log_cb_t    cbfn;                   /*  callback function */
-};
-
-extern int bfa_log_init(struct bfa_log_mod_s *log_mod,
-                       char *instance_name, bfa_log_cb_t cbfn);
-extern int bfa_log(struct bfa_log_mod_s *log_mod, u32 msg_id, ...);
-extern bfa_status_t bfa_log_set_level(struct bfa_log_mod_s *log_mod,
-                       int mod_id, enum bfa_log_severity log_level);
-extern bfa_status_t bfa_log_set_level_all(struct bfa_log_mod_s *log_mod,
-                       enum bfa_log_severity log_level);
-extern bfa_status_t bfa_log_set_level_aen(struct bfa_log_mod_s *log_mod,
-                       enum bfa_log_severity log_level);
-extern enum bfa_log_severity bfa_log_get_level(struct bfa_log_mod_s *log_mod,
-                       int mod_id);
-extern enum bfa_log_severity bfa_log_get_msg_level(
-                       struct bfa_log_mod_s *log_mod, u32 msg_id);
-/*
- * array of messages generated from xml files
- */
-extern struct bfa_log_msgdef_s bfa_log_msg_array[];
-
-#endif
diff --git a/drivers/scsi/bfa/include/cs/bfa_perf.h b/drivers/scsi/bfa/include/cs/bfa_perf.h
deleted file mode 100644 (file)
index 45aa5f9..0000000
+++ /dev/null
@@ -1,34 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-#ifndef __BFAD_PERF_H__
-#define __BFAD_PERF_H__
-
-#ifdef BFAD_PERF_BUILD
-
-#undef bfa_trc
-#undef bfa_trc32
-#undef bfa_assert
-#undef BFA_TRC_FILE
-
-#define bfa_trc(_trcp, _data)
-#define bfa_trc32(_trcp, _data)
-#define bfa_assert(__cond)
-#define BFA_TRC_FILE(__mod, __submod)
-
-#endif
-
-#endif /* __BFAD_PERF_H__ */
diff --git a/drivers/scsi/bfa/include/cs/bfa_plog.h b/drivers/scsi/bfa/include/cs/bfa_plog.h
deleted file mode 100644 (file)
index f5bef63..0000000
+++ /dev/null
@@ -1,167 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-#ifndef __BFA_PORTLOG_H__
-#define __BFA_PORTLOG_H__
-
-#include "protocol/fc.h"
-#include <defs/bfa_defs_types.h>
-
-#define BFA_PL_NLOG_ENTS 256
-#define BFA_PL_LOG_REC_INCR(_x) ((_x)++, (_x) %= BFA_PL_NLOG_ENTS)
-
-#define BFA_PL_STRING_LOG_SZ   32   /* number of chars in string log */
-#define BFA_PL_INT_LOG_SZ      8    /* number of integers in the integer log */
-
-enum bfa_plog_log_type {
-       BFA_PL_LOG_TYPE_INVALID = 0,
-       BFA_PL_LOG_TYPE_INT     = 1,
-       BFA_PL_LOG_TYPE_STRING  = 2,
-};
-
-/*
- * the (fixed size) record format for each entry in the portlog
- */
-struct bfa_plog_rec_s {
-       u32        tv;  /* Filled by the portlog driver when the *
-                                * entry is added to the circular log.   */
-       u8         port;        /* Source port that logged this entry. CM
-                                * entities will use 0xFF */
-       u8         mid; /* Integer value to be used by all entities *
-                                * while logging. The module id to string   *
-                                * conversion will be done by BFAL. See
-                                * enum bfa_plog_mid */
-       u8         eid; /* indicates Rx, Tx, IOCTL, etc. See
-                                * enum bfa_plog_eid */
-       u8         log_type; /* indicates string log or integer log.
-                                  * see bfa_plog_log_type_t */
-       u8         log_num_ints;
-       /*
-        * interpreted only if log_type is INT_LOG. indicates number of
-        * integers in the int_log[] (0-PL_INT_LOG_SZ).
-        */
-       u8         rsvd;
-       u16        misc;        /* can be used to indicate fc frame length,
-                                *etc.. */
-       union {
-               char            string_log[BFA_PL_STRING_LOG_SZ];
-               u32        int_log[BFA_PL_INT_LOG_SZ];
-       } log_entry;
-
-};
-
-/*
- * the following #defines will be used by the logging entities to indicate
- * their module id. BFAL will convert the integer value to string format
- *
-* process to be used while changing the following #defines:
- *  - Always add new entries at the end
- *  - define corresponding string in BFAL
- *  - Do not remove any entry or rearrange the order.
- */
-enum bfa_plog_mid {
-       BFA_PL_MID_INVALID      = 0,
-       BFA_PL_MID_DEBUG        = 1,
-       BFA_PL_MID_DRVR         = 2,
-       BFA_PL_MID_HAL          = 3,
-       BFA_PL_MID_HAL_FCXP     = 4,
-       BFA_PL_MID_HAL_UF       = 5,
-       BFA_PL_MID_FCS          = 6,
-       BFA_PL_MID_LPS          = 7,
-       BFA_PL_MID_MAX          = 8
-};
-
-#define BFA_PL_MID_STRLEN    8
-struct bfa_plog_mid_strings_s {
-       char            m_str[BFA_PL_MID_STRLEN];
-};
-
-/*
- * the following #defines will be used by the logging entities to indicate
- * their event type. BFAL will convert the integer value to string format
- *
-* process to be used while changing the following #defines:
- *  - Always add new entries at the end
- *  - define corresponding string in BFAL
- *  - Do not remove any entry or rearrange the order.
- */
-enum bfa_plog_eid {
-       BFA_PL_EID_INVALID              = 0,
-       BFA_PL_EID_IOC_DISABLE          = 1,
-       BFA_PL_EID_IOC_ENABLE           = 2,
-       BFA_PL_EID_PORT_DISABLE         = 3,
-       BFA_PL_EID_PORT_ENABLE          = 4,
-       BFA_PL_EID_PORT_ST_CHANGE       = 5,
-       BFA_PL_EID_TX                   = 6,
-       BFA_PL_EID_TX_ACK1              = 7,
-       BFA_PL_EID_TX_RJT               = 8,
-       BFA_PL_EID_TX_BSY               = 9,
-       BFA_PL_EID_RX                   = 10,
-       BFA_PL_EID_RX_ACK1              = 11,
-       BFA_PL_EID_RX_RJT               = 12,
-       BFA_PL_EID_RX_BSY               = 13,
-       BFA_PL_EID_CT_IN                = 14,
-       BFA_PL_EID_CT_OUT               = 15,
-       BFA_PL_EID_DRIVER_START         = 16,
-       BFA_PL_EID_RSCN                 = 17,
-       BFA_PL_EID_DEBUG                = 18,
-       BFA_PL_EID_MISC                 = 19,
-       BFA_PL_EID_FIP_FCF_DISC         = 20,
-       BFA_PL_EID_FIP_FCF_CVL          = 21,
-       BFA_PL_EID_LOGIN                = 22,
-       BFA_PL_EID_LOGO                 = 23,
-       BFA_PL_EID_MAX                  = 24
-};
-
-#define BFA_PL_ENAME_STRLEN            8
-struct bfa_plog_eid_strings_s {
-       char            e_str[BFA_PL_ENAME_STRLEN];
-};
-
-#define BFA_PL_SIG_LEN 8
-#define BFA_PL_SIG_STR  "12pl123"
-
-/*
- * per port circular log buffer
- */
-struct bfa_plog_s {
-       char            plog_sig[BFA_PL_SIG_LEN];       /* Start signature */
-       u8         plog_enabled;
-       u8         rsvd[7];
-       u32        ticks;
-       u16        head;
-       u16        tail;
-       struct bfa_plog_rec_s  plog_recs[BFA_PL_NLOG_ENTS];
-};
-
-void bfa_plog_init(struct bfa_plog_s *plog);
-void bfa_plog_str(struct bfa_plog_s *plog, enum bfa_plog_mid mid,
-                       enum bfa_plog_eid event, u16 misc, char *log_str);
-void bfa_plog_intarr(struct bfa_plog_s *plog, enum bfa_plog_mid mid,
-                       enum bfa_plog_eid event, u16 misc,
-                       u32 *intarr, u32 num_ints);
-void bfa_plog_fchdr(struct bfa_plog_s *plog, enum bfa_plog_mid mid,
-                       enum bfa_plog_eid event, u16 misc,
-                       struct fchs_s *fchdr);
-void bfa_plog_fchdr_and_pl(struct bfa_plog_s *plog, enum bfa_plog_mid mid,
-                       enum bfa_plog_eid event, u16 misc,
-                       struct fchs_s *fchdr, u32 pld_w0);
-void bfa_plog_clear(struct bfa_plog_s *plog);
-void bfa_plog_enable(struct bfa_plog_s *plog);
-void bfa_plog_disable(struct bfa_plog_s *plog);
-bfa_boolean_t  bfa_plog_get_setting(struct bfa_plog_s *plog);
-
-#endif /* __BFA_PORTLOG_H__ */
diff --git a/drivers/scsi/bfa/include/cs/bfa_q.h b/drivers/scsi/bfa/include/cs/bfa_q.h
deleted file mode 100644 (file)
index ea895fa..0000000
+++ /dev/null
@@ -1,81 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  bfa_q.h Circular queue definitions.
- */
-
-#ifndef __BFA_Q_H__
-#define __BFA_Q_H__
-
-#define bfa_q_first(_q) ((void *)(((struct list_head *) (_q))->next))
-#define bfa_q_next(_qe)        (((struct list_head *) (_qe))->next)
-#define bfa_q_prev(_qe) (((struct list_head *) (_qe))->prev)
-
-/*
- * bfa_q_qe_init - to initialize a queue element
- */
-#define bfa_q_qe_init(_qe) {                                           \
-       bfa_q_next(_qe) = (struct list_head *) NULL;                    \
-       bfa_q_prev(_qe) = (struct list_head *) NULL;                    \
-}
-
-/*
- * bfa_q_deq - dequeue an element from head of the queue
- */
-#define bfa_q_deq(_q, _qe) {                                           \
-       if (!list_empty(_q)) {                                  \
-               (*((struct list_head **) (_qe))) = bfa_q_next(_q);      \
-               bfa_q_prev(bfa_q_next(*((struct list_head **) _qe))) =  \
-                                               (struct list_head *) (_q); \
-               bfa_q_next(_q) = bfa_q_next(*((struct list_head **) _qe)); \
-               BFA_Q_DBG_INIT(*((struct list_head **) _qe));           \
-       } else {                                                        \
-               *((struct list_head **) (_qe)) = (struct list_head *) NULL; \
-       }                                                               \
-}
-
-/*
- * bfa_q_deq_tail - dequeue an element from tail of the queue
- */
-#define bfa_q_deq_tail(_q, _qe) {                                          \
-       if (!list_empty(_q)) {                                              \
-               *((struct list_head **) (_qe)) = bfa_q_prev(_q);            \
-               bfa_q_next(bfa_q_prev(*((struct list_head **) _qe))) =      \
-                                               (struct list_head *) (_q);  \
-               bfa_q_prev(_q) = bfa_q_prev(*(struct list_head **) _qe);    \
-               BFA_Q_DBG_INIT(*((struct list_head **) _qe));               \
-       } else {                                                            \
-               *((struct list_head **) (_qe)) = (struct list_head *) NULL; \
-       }                                                                   \
-}
-
-/*
- * #ifdef BFA_DEBUG (Using bfa_assert to check for debug_build is not
- * consistent across modules)
- */
-#ifndef BFA_PERF_BUILD
-#define BFA_Q_DBG_INIT(_qe)    bfa_q_qe_init(_qe)
-#else
-#define BFA_Q_DBG_INIT(_qe)
-#endif
-
-#define bfa_q_is_on_q(_q, _qe)         \
-       bfa_q_is_on_q_func(_q, (struct list_head *)(_qe))
-extern int bfa_q_is_on_q_func(struct list_head *q, struct list_head *qe);
-
-#endif
diff --git a/drivers/scsi/bfa/include/cs/bfa_sm.h b/drivers/scsi/bfa/include/cs/bfa_sm.h
deleted file mode 100644 (file)
index 11fba90..0000000
+++ /dev/null
@@ -1,77 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  bfasm.h State machine defines
- */
-
-#ifndef __BFA_SM_H__
-#define __BFA_SM_H__
-
-typedef void (*bfa_sm_t)(void *sm, int event);
-/**
- * oc - object class eg. bfa_ioc
- * st - state, eg. reset
- * otype - object type, eg. struct bfa_ioc_s
- * etype - object type, eg. enum ioc_event
- */
-#define bfa_sm_state_decl(oc, st, otype, etype)         \
-       static void oc ## _sm_ ## st(otype * fsm, etype event)
-
-#define bfa_sm_set_state(_sm, _state)  ((_sm)->sm = (bfa_sm_t)(_state))
-#define bfa_sm_send_event(_sm, _event) ((_sm)->sm((_sm), (_event)))
-#define bfa_sm_get_state(_sm)          ((_sm)->sm)
-#define bfa_sm_cmp_state(_sm, _state)  ((_sm)->sm == (bfa_sm_t)(_state))
-
-/**
- * For converting from state machine function to state encoding.
- */
-struct bfa_sm_table_s {
-       bfa_sm_t        sm;     /*  state machine function      */
-       int             state;  /*  state machine encoding      */
-       char            *name;  /*  state name for display      */
-};
-#define BFA_SM(_sm)    ((bfa_sm_t)(_sm))
-
-int bfa_sm_to_state(struct bfa_sm_table_s *smt, bfa_sm_t sm);
-
-/**
- * State machine with entry actions.
- */
-typedef void (*bfa_fsm_t)(void *fsm, int event);
-
-/**
- * oc - object class eg. bfa_ioc
- * st - state, eg. reset
- * otype - object type, eg. struct bfa_ioc_s
- * etype - object type, eg. enum ioc_event
- */
-#define bfa_fsm_state_decl(oc, st, otype, etype)               \
-       static void oc ## _sm_ ## st(otype * fsm, etype event);      \
-       static void oc ## _sm_ ## st ## _entry(otype * fsm)
-
-#define bfa_fsm_set_state(_fsm, _state) do {   \
-       (_fsm)->fsm = (bfa_fsm_t)(_state);      \
-       _state ## _entry(_fsm);      \
-} while (0)
-
-#define bfa_fsm_send_event(_fsm, _event)       \
-       ((_fsm)->fsm((_fsm), (_event)))
-#define bfa_fsm_cmp_state(_fsm, _state)                \
-       ((_fsm)->fsm == (bfa_fsm_t)(_state))
-
-#endif
diff --git a/drivers/scsi/bfa/include/cs/bfa_trc.h b/drivers/scsi/bfa/include/cs/bfa_trc.h
deleted file mode 100644 (file)
index 310771c..0000000
+++ /dev/null
@@ -1,176 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-#ifndef __BFA_TRC_H__
-#define __BFA_TRC_H__
-
-#include <bfa_os_inc.h>
-
-#ifndef BFA_TRC_MAX
-#define BFA_TRC_MAX    (4 * 1024)
-#endif
-
-#ifndef BFA_TRC_TS
-#define BFA_TRC_TS(_trcm)      ((_trcm)->ticks++)
-#endif
-
-struct bfa_trc_s {
-#ifdef __BIGENDIAN
-       u16     fileno;
-       u16     line;
-#else
-       u16     line;
-       u16     fileno;
-#endif
-       u32     timestamp;
-       union {
-               struct {
-                       u32     rsvd;
-                       u32     u32;
-               } u32;
-               u64     u64;
-       } data;
-};
-
-
-struct bfa_trc_mod_s {
-       u32     head;
-       u32     tail;
-       u32     ntrc;
-       u32     stopped;
-       u32     ticks;
-       u32     rsvd[3];
-       struct bfa_trc_s trc[BFA_TRC_MAX];
-};
-
-
-enum {
-       BFA_TRC_FW   = 1,       /*  firmware modules */
-       BFA_TRC_HAL  = 2,       /*  BFA modules */
-       BFA_TRC_FCS  = 3,       /*  BFA FCS modules */
-       BFA_TRC_LDRV = 4,       /*  Linux driver modules */
-       BFA_TRC_SDRV = 5,       /*  Solaris driver modules */
-       BFA_TRC_VDRV = 6,       /*  vmware driver modules */
-       BFA_TRC_WDRV = 7,       /*  windows driver modules */
-       BFA_TRC_AEN  = 8,       /*  AEN module */
-       BFA_TRC_BIOS = 9,       /*  bios driver modules */
-       BFA_TRC_EFI  = 10,      /*  EFI driver modules */
-       BNA_TRC_WDRV = 11,      /*  BNA windows driver modules */
-       BNA_TRC_VDRV = 12,      /*  BNA vmware driver modules */
-       BNA_TRC_SDRV = 13,      /*  BNA Solaris driver modules */
-       BNA_TRC_LDRV = 14,      /*  BNA Linux driver modules */
-       BNA_TRC_HAL  = 15,      /*  BNA modules */
-       BFA_TRC_CNA  = 16,      /*  Common modules */
-       BNA_TRC_IMDRV = 17      /*  BNA windows intermediate driver modules */
-};
-#define BFA_TRC_MOD_SH 10
-#define BFA_TRC_MOD(__mod)     ((BFA_TRC_ ## __mod) << BFA_TRC_MOD_SH)
-
-/**
- * Define a new tracing file (module). Module should match one defined above.
- */
-#define BFA_TRC_FILE(__mod, __submod)                                  \
-       static int __trc_fileno = ((BFA_TRC_ ## __mod ## _ ## __submod) | \
-                                                BFA_TRC_MOD(__mod))
-
-
-#define bfa_trc32(_trcp, _data)        \
-       __bfa_trc((_trcp)->trcmod, __trc_fileno, __LINE__, (u32)_data)
-
-
-#ifndef BFA_BOOT_BUILD
-#define bfa_trc(_trcp, _data)  \
-       __bfa_trc((_trcp)->trcmod, __trc_fileno, __LINE__, (u64)_data)
-#else
-void bfa_boot_trc(struct bfa_trc_mod_s *trcmod, u16 fileno,
-                       u16 line, u32 data);
-#define bfa_trc(_trcp, _data)  \
-       bfa_boot_trc((_trcp)->trcmod, __trc_fileno, __LINE__, (u32)_data)
-#endif
-
-
-static inline void
-bfa_trc_init(struct bfa_trc_mod_s *trcm)
-{
-       trcm->head = trcm->tail = trcm->stopped = 0;
-       trcm->ntrc = BFA_TRC_MAX;
-}
-
-
-static inline void
-bfa_trc_stop(struct bfa_trc_mod_s *trcm)
-{
-       trcm->stopped = 1;
-}
-
-#ifdef FWTRC
-extern void dc_flush(void *data);
-#else
-#define dc_flush(data)
-#endif
-
-
-static inline void
-__bfa_trc(struct bfa_trc_mod_s *trcm, int fileno, int line, u64 data)
-{
-       int             tail = trcm->tail;
-       struct bfa_trc_s        *trc = &trcm->trc[tail];
-
-       if (trcm->stopped)
-               return;
-
-       trc->fileno = (u16) fileno;
-       trc->line = (u16) line;
-       trc->data.u64 = data;
-       trc->timestamp = BFA_TRC_TS(trcm);
-       dc_flush(trc);
-
-       trcm->tail = (trcm->tail + 1) & (BFA_TRC_MAX - 1);
-       if (trcm->tail == trcm->head)
-               trcm->head = (trcm->head + 1) & (BFA_TRC_MAX - 1);
-       dc_flush(trcm);
-}
-
-
-static inline void
-__bfa_trc32(struct bfa_trc_mod_s *trcm, int fileno, int line, u32 data)
-{
-       int             tail = trcm->tail;
-       struct bfa_trc_s *trc = &trcm->trc[tail];
-
-       if (trcm->stopped)
-               return;
-
-       trc->fileno = (u16) fileno;
-       trc->line = (u16) line;
-       trc->data.u32.u32 = data;
-       trc->timestamp = BFA_TRC_TS(trcm);
-       dc_flush(trc);
-
-       trcm->tail = (trcm->tail + 1) & (BFA_TRC_MAX - 1);
-       if (trcm->tail == trcm->head)
-               trcm->head = (trcm->head + 1) & (BFA_TRC_MAX - 1);
-       dc_flush(trcm);
-}
-
-#ifndef BFA_PERF_BUILD
-#define bfa_trc_fp(_trcp, _data)       bfa_trc(_trcp, _data)
-#else
-#define bfa_trc_fp(_trcp, _data)
-#endif
-
-#endif /* __BFA_TRC_H__ */
-
diff --git a/drivers/scsi/bfa/include/cs/bfa_wc.h b/drivers/scsi/bfa/include/cs/bfa_wc.h
deleted file mode 100644 (file)
index 0460bd4..0000000
+++ /dev/null
@@ -1,68 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  bfa_wc.h Generic wait counter.
- */
-
-#ifndef __BFA_WC_H__
-#define __BFA_WC_H__
-
-typedef void (*bfa_wc_resume_t) (void *cbarg);
-
-struct bfa_wc_s {
-       bfa_wc_resume_t wc_resume;
-       void            *wc_cbarg;
-       int             wc_count;
-};
-
-static inline void
-bfa_wc_up(struct bfa_wc_s *wc)
-{
-       wc->wc_count++;
-}
-
-static inline void
-bfa_wc_down(struct bfa_wc_s *wc)
-{
-       wc->wc_count--;
-       if (wc->wc_count == 0)
-               wc->wc_resume(wc->wc_cbarg);
-}
-
-/**
- * Initialize a waiting counter.
- */
-static inline void
-bfa_wc_init(struct bfa_wc_s *wc, bfa_wc_resume_t wc_resume, void *wc_cbarg)
-{
-       wc->wc_resume = wc_resume;
-       wc->wc_cbarg = wc_cbarg;
-       wc->wc_count = 0;
-       bfa_wc_up(wc);
-}
-
-/**
- * Wait for counter to reach zero
- */
-static inline void
-bfa_wc_wait(struct bfa_wc_s *wc)
-{
-       bfa_wc_down(wc);
-}
-
-#endif
diff --git a/drivers/scsi/bfa/include/defs/bfa_defs_adapter.h b/drivers/scsi/bfa/include/defs/bfa_defs_adapter.h
deleted file mode 100644 (file)
index aea0360..0000000
+++ /dev/null
@@ -1,83 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-#ifndef __BFA_DEFS_ADAPTER_H__
-#define __BFA_DEFS_ADAPTER_H__
-
-#include <protocol/types.h>
-#include <defs/bfa_defs_version.h>
-#include <defs/bfa_defs_mfg.h>
-
-/**
- * BFA adapter level attributes.
- */
-enum {
-       BFA_ADAPTER_SERIAL_NUM_LEN = STRSZ(BFA_MFG_SERIALNUM_SIZE),
-                                       /*
-                                        *!< adapter serial num length
-                                        */
-       BFA_ADAPTER_MODEL_NAME_LEN  = 16,  /*  model name length */
-       BFA_ADAPTER_MODEL_DESCR_LEN = 128, /*  model description length */
-       BFA_ADAPTER_MFG_NAME_LEN    = 8,   /*  manufacturer name length */
-       BFA_ADAPTER_SYM_NAME_LEN    = 64,  /*  adapter symbolic name length */
-       BFA_ADAPTER_OS_TYPE_LEN     = 64,  /*  adapter os type length */
-};
-
-struct bfa_adapter_attr_s {
-       char            manufacturer[BFA_ADAPTER_MFG_NAME_LEN];
-       char            serial_num[BFA_ADAPTER_SERIAL_NUM_LEN];
-       u32             card_type;
-       char            model[BFA_ADAPTER_MODEL_NAME_LEN];
-       char            model_descr[BFA_ADAPTER_MODEL_DESCR_LEN];
-       wwn_t           pwwn;
-       char            node_symname[FC_SYMNAME_MAX];
-       char            hw_ver[BFA_VERSION_LEN];
-       char            fw_ver[BFA_VERSION_LEN];
-       char            optrom_ver[BFA_VERSION_LEN];
-       char            os_type[BFA_ADAPTER_OS_TYPE_LEN];
-       struct bfa_mfg_vpd_s    vpd;
-       struct mac_s    mac;
-
-       u8              nports;
-       u8              max_speed;
-       u8              prototype;
-       char            asic_rev;
-
-       u8         pcie_gen;
-       u8         pcie_lanes_orig;
-       u8         pcie_lanes;
-       u8              cna_capable;
-       u8         is_mezz;
-};
-
-/**
- * BFA adapter level events
- * Arguments below are in BFAL context from Mgmt
- * BFA_PORT_AEN_ADD:        [in]: None     [out]: serial_num, pwwn, nports
- * BFA_PORT_AEN_REMOVE:     [in]: pwwn     [out]: serial_num, pwwn, nports
- */
-enum bfa_adapter_aen_event {
-       BFA_ADAPTER_AEN_ADD     = 1,    /*  New Adapter found event */
-       BFA_ADAPTER_AEN_REMOVE  = 2,    /*  Adapter removed event */
-};
-
-struct bfa_adapter_aen_data_s {
-       char            serial_num[BFA_ADAPTER_SERIAL_NUM_LEN];
-       u32        nports;      /*  Number of NPorts */
-       wwn_t           pwwn;   /*  WWN of one of its physical port */
-};
-
-#endif /* __BFA_DEFS_ADAPTER_H__ */
diff --git a/drivers/scsi/bfa/include/defs/bfa_defs_aen.h b/drivers/scsi/bfa/include/defs/bfa_defs_aen.h
deleted file mode 100644 (file)
index 3524469..0000000
+++ /dev/null
@@ -1,83 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_DEFS_AEN_H__
-#define __BFA_DEFS_AEN_H__
-
-#include <defs/bfa_defs_types.h>
-#include <defs/bfa_defs_ioc.h>
-#include <defs/bfa_defs_adapter.h>
-#include <defs/bfa_defs_port.h>
-#include <defs/bfa_defs_lport.h>
-#include <defs/bfa_defs_rport.h>
-#include <defs/bfa_defs_itnim.h>
-#include <defs/bfa_defs_tin.h>
-#include <defs/bfa_defs_ipfc.h>
-#include <defs/bfa_defs_audit.h>
-#include <defs/bfa_defs_ethport.h>
-
-#define BFA_AEN_MAX_APP         5
-
-enum bfa_aen_app {
-       bfa_aen_app_bcu = 0,    /* No thread for bcu */
-       bfa_aen_app_hcm = 1,
-       bfa_aen_app_cim = 2,
-       bfa_aen_app_snia = 3,
-       bfa_aen_app_test = 4,   /* To be removed after unit test */
-};
-
-enum bfa_aen_category {
-       BFA_AEN_CAT_ADAPTER     = 1,
-       BFA_AEN_CAT_PORT        = 2,
-       BFA_AEN_CAT_LPORT       = 3,
-       BFA_AEN_CAT_RPORT       = 4,
-       BFA_AEN_CAT_ITNIM       = 5,
-       BFA_AEN_CAT_TIN         = 6,
-       BFA_AEN_CAT_IPFC        = 7,
-       BFA_AEN_CAT_AUDIT       = 8,
-       BFA_AEN_CAT_IOC         = 9,
-       BFA_AEN_CAT_ETHPORT     = 10,
-       BFA_AEN_MAX_CAT         = 10
-};
-
-#pragma pack(1)
-union bfa_aen_data_u {
-       struct bfa_adapter_aen_data_s   adapter;
-       struct bfa_port_aen_data_s      port;
-       struct bfa_lport_aen_data_s     lport;
-       struct bfa_rport_aen_data_s     rport;
-       struct bfa_itnim_aen_data_s     itnim;
-       struct bfa_audit_aen_data_s     audit;
-       struct bfa_ioc_aen_data_s       ioc;
-       struct bfa_ethport_aen_data_s   ethport;
-};
-
-struct bfa_aen_entry_s {
-       enum bfa_aen_category   aen_category;
-       int                     aen_type;
-       union bfa_aen_data_u    aen_data;
-       struct bfa_timeval_s    aen_tv;
-       s32             seq_num;
-       s32             bfad_num;
-       s32             rsvd[1];
-};
-
-#pragma pack()
-
-#define bfa_aen_event_t int
-
-#endif /* __BFA_DEFS_AEN_H__ */
diff --git a/drivers/scsi/bfa/include/defs/bfa_defs_audit.h b/drivers/scsi/bfa/include/defs/bfa_defs_audit.h
deleted file mode 100644 (file)
index 8e3a962..0000000
+++ /dev/null
@@ -1,38 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_DEFS_AUDIT_H__
-#define __BFA_DEFS_AUDIT_H__
-
-#include <bfa_os_inc.h>
-
-/**
- * BFA audit events
- */
-enum bfa_audit_aen_event {
-       BFA_AUDIT_AEN_AUTH_ENABLE       = 1,
-       BFA_AUDIT_AEN_AUTH_DISABLE      = 2,
-};
-
-/**
- * audit event data
- */
-struct bfa_audit_aen_data_s {
-       wwn_t           pwwn;
-};
-
-#endif /* __BFA_DEFS_AUDIT_H__ */
diff --git a/drivers/scsi/bfa/include/defs/bfa_defs_auth.h b/drivers/scsi/bfa/include/defs/bfa_defs_auth.h
deleted file mode 100644 (file)
index f56ed87..0000000
+++ /dev/null
@@ -1,134 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-#ifndef __BFA_DEFS_AUTH_H__
-#define __BFA_DEFS_AUTH_H__
-
-#include <defs/bfa_defs_types.h>
-
-#define PUBLIC_KEY                     15409
-#define PRIVATE_KEY                    19009
-#define KEY_LEN                                32399
-#define BFA_AUTH_SECRET_STRING_LEN     256
-#define BFA_AUTH_FAIL_NO_PASSWORD      0xFE
-#define BFA_AUTH_FAIL_TIMEOUT          0xFF
-
-/**
- * Authentication status
- */
-enum bfa_auth_status {
-       BFA_AUTH_STATUS_NONE    = 0,    /*  no authentication */
-       BFA_AUTH_UNINIT         = 1,    /*  state - uninit */
-       BFA_AUTH_NEG_SEND       = 2,    /*  state - negotiate send */
-       BFA_AUTH_CHAL_WAIT      = 3,    /*  state - challenge wait */
-       BFA_AUTH_NEG_RETRY      = 4,    /*  state - negotiate retry */
-       BFA_AUTH_REPLY_SEND     = 5,    /*  state - reply send */
-       BFA_AUTH_STATUS_WAIT    = 6,    /*  state - status wait */
-       BFA_AUTH_SUCCESS        = 7,    /*  state - success */
-       BFA_AUTH_FAILED         = 8,    /*  state - failed */
-       BFA_AUTH_STATUS_UNKNOWN = 9,    /*  authentication status unknown */
-};
-
-enum bfa_auth_rej_code {
-       BFA_AUTH_RJT_CODE_AUTH_FAILURE   = 1, /* auth failure */
-       BFA_AUTH_RJT_CODE_LOGICAL_ERR    = 2, /* logical error */
-};
-
-/**
- * Authentication reject codes
- */
-enum bfa_auth_rej_code_exp {
-       BFA_AUTH_MECH_NOT_USABLE        = 1, /* auth. mechanism not usable */
-       BFA_AUTH_DH_GROUP_NOT_USABLE    = 2, /* DH Group not usable */
-       BFA_AUTH_HASH_FUNC_NOT_USABLE   = 3, /* hash Function not usable */
-       BFA_AUTH_AUTH_XACT_STARTED      = 4, /* auth xact started */
-       BFA_AUTH_AUTH_FAILED            = 5, /* auth failed */
-       BFA_AUTH_INCORRECT_PLD          = 6, /* incorrect payload */
-       BFA_AUTH_INCORRECT_PROTO_MSG    = 7, /* incorrect proto msg */
-       BFA_AUTH_RESTART_AUTH_PROTO     = 8, /* restart auth protocol */
-       BFA_AUTH_AUTH_CONCAT_NOT_SUPP   = 9, /* auth concat not supported */
-       BFA_AUTH_PROTO_VER_NOT_SUPP     = 10,/* proto version not supported */
-};
-
-struct auth_proto_stats_s {
-       u32        auth_rjts;
-       u32        auth_negs;
-       u32        auth_dones;
-
-       u32        dhchap_challenges;
-       u32        dhchap_replies;
-       u32        dhchap_successes;
-};
-
-/**
- * Authentication related statistics
- */
-struct bfa_auth_stats_s {
-       u32           auth_failures;    /*  authentication failures */
-       u32           auth_successes;   /*  authentication successes*/
-       struct auth_proto_stats_s auth_rx_stats; /*  Rx protocol stats */
-       struct auth_proto_stats_s auth_tx_stats; /*  Tx protocol stats */
-};
-
-/**
- * Authentication hash function algorithms
- */
-enum bfa_auth_algo {
-       BFA_AUTH_ALGO_MD5       = 1,    /*  Message-Digest algorithm 5 */
-       BFA_AUTH_ALGO_SHA1      = 2,    /*  Secure Hash Algorithm 1 */
-       BFA_AUTH_ALGO_MS        = 3,    /*  MD5, then SHA-1 */
-       BFA_AUTH_ALGO_SM        = 4,    /*  SHA-1, then MD5 */
-};
-
-/**
- * DH Groups
- *
- * Current value could be combination of one or more of the following values
- */
-enum bfa_auth_group {
-       BFA_AUTH_GROUP_DHNULL   = 0,    /*  DH NULL (value == 0) */
-       BFA_AUTH_GROUP_DH768    = 1,    /*  DH group 768 (value == 1) */
-       BFA_AUTH_GROUP_DH1024   = 2,    /*  DH group 1024 (value == 2) */
-       BFA_AUTH_GROUP_DH1280   = 4,    /*  DH group 1280 (value == 3) */
-       BFA_AUTH_GROUP_DH1536   = 8,    /*  DH group 1536 (value == 4) */
-
-       BFA_AUTH_GROUP_ALL      = 256   /*  Use default DH group order
-                                        *    0, 1, 2, 3, 4 */
-};
-
-/**
- * Authentication secret sources
- */
-enum bfa_auth_secretsource {
-       BFA_AUTH_SECSRC_LOCAL   = 1,    /*  locally configured */
-       BFA_AUTH_SECSRC_RADIUS  = 2,    /*  use radius server */
-       BFA_AUTH_SECSRC_TACACS  = 3,    /*  TACACS server */
-};
-
-/**
- * Authentication attributes
- */
-struct bfa_auth_attr_s {
-       enum bfa_auth_status    status;
-       enum bfa_auth_algo      algo;
-       enum bfa_auth_group     dh_grp;
-       enum bfa_auth_rej_code  rjt_code;
-       enum bfa_auth_rej_code_exp rjt_code_exp;
-       u8                      secret_set;
-       u8                      resv[3];
-};
-
-#endif /* __BFA_DEFS_AUTH_H__ */
diff --git a/drivers/scsi/bfa/include/defs/bfa_defs_boot.h b/drivers/scsi/bfa/include/defs/bfa_defs_boot.h
deleted file mode 100644 (file)
index 0fca10b..0000000
+++ /dev/null
@@ -1,81 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_DEFS_BOOT_H__
-#define __BFA_DEFS_BOOT_H__
-
-#include <protocol/types.h>
-#include <defs/bfa_defs_types.h>
-#include <defs/bfa_defs_pport.h>
-
-enum {
-       BFA_BOOT_BOOTLUN_MAX = 4,       /*  maximum boot lun per IOC */
-       BFA_PREBOOT_BOOTLUN_MAX = 8,    /*  maximum preboot lun per IOC */
-
-};
-
-#define BOOT_CFG_REV1  1
-
-/**
- *      Boot options setting. Boot options setting determines from where
- *      to get the boot lun information
- */
-enum bfa_boot_bootopt {
-    BFA_BOOT_AUTO_DISCOVER = 0,    /*  Boot from blun provided by fabric */
-    BFA_BOOT_STORED_BLUN   = 1,    /*  Boot from bluns stored in flash   */
-    BFA_BOOT_FIRST_LUN     = 2,    /*  Boot from first discovered blun   */
-};
-
-/**
- * Boot lun information.
- */
-struct bfa_boot_bootlun_s {
-       wwn_t           pwwn;   /*  port wwn of target */
-       lun_t           lun;    /*  64-bit lun */
-};
-
-/**
- * BOOT boot configuraton
- */
-struct bfa_boot_cfg_s {
-       u8         version;
-       u8         rsvd1;
-       u16        chksum;
-
-       u8         enable;              /*  enable/disable SAN boot */
-       u8         speed;               /*  boot speed settings */
-       u8         topology;    /*  boot topology setting */
-       u8         bootopt;     /*  bfa_boot_bootopt_t */
-
-       u32        nbluns;              /*  number of boot luns */
-
-       u32        rsvd2;
-
-       struct bfa_boot_bootlun_s blun[BFA_BOOT_BOOTLUN_MAX];
-       struct bfa_boot_bootlun_s blun_disc[BFA_BOOT_BOOTLUN_MAX];
-};
-
-struct bfa_boot_pbc_s {
-       u8         enable;         /* enable/disable SAN boot */
-       u8         speed;          /* boot speed settings */
-       u8         topology;       /* boot topology setting */
-       u8         rsvd1;
-       u32        nbluns;         /* number of boot luns */
-       struct bfa_boot_bootlun_s pblun[BFA_PREBOOT_BOOTLUN_MAX];
-};
-
-#endif /* __BFA_DEFS_BOOT_H__ */
diff --git a/drivers/scsi/bfa/include/defs/bfa_defs_cee.h b/drivers/scsi/bfa/include/defs/bfa_defs_cee.h
deleted file mode 100644 (file)
index 6eaf519..0000000
+++ /dev/null
@@ -1,157 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- *  bfa_defs_cee.h Interface declarations between host based
- *     BFAL and DCBX/LLDP module in Firmware
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-#ifndef __BFA_DEFS_CEE_H__
-#define __BFA_DEFS_CEE_H__
-
-#include <defs/bfa_defs_types.h>
-#include <defs/bfa_defs_pport.h>
-#include <protocol/types.h>
-
-#pragma pack(1)
-
-#define BFA_CEE_LLDP_MAX_STRING_LEN (128)
-
-#define BFA_CEE_LLDP_SYS_CAP_OTHER       0x0001
-#define BFA_CEE_LLDP_SYS_CAP_REPEATER    0x0002
-#define BFA_CEE_LLDP_SYS_CAP_MAC_BRIDGE  0x0004
-#define BFA_CEE_LLDP_SYS_CAP_WLAN_AP     0x0008
-#define BFA_CEE_LLDP_SYS_CAP_ROUTER      0x0010
-#define BFA_CEE_LLDP_SYS_CAP_TELEPHONE          0x0020
-#define BFA_CEE_LLDP_SYS_CAP_DOCSIS_CD   0x0040
-#define BFA_CEE_LLDP_SYS_CAP_STATION     0x0080
-#define BFA_CEE_LLDP_SYS_CAP_CVLAN          0x0100
-#define BFA_CEE_LLDP_SYS_CAP_SVLAN          0x0200
-#define BFA_CEE_LLDP_SYS_CAP_TPMR               0x0400
-
-
-/* LLDP string type */
-struct bfa_cee_lldp_str_s {
-       u8 sub_type;
-       u8 len;
-       u8 rsvd[2];
-       u8 value[BFA_CEE_LLDP_MAX_STRING_LEN];
-};
-
-
-/* LLDP parameters */
-struct bfa_cee_lldp_cfg_s {
-       struct bfa_cee_lldp_str_s chassis_id;
-       struct bfa_cee_lldp_str_s port_id;
-       struct bfa_cee_lldp_str_s port_desc;
-       struct bfa_cee_lldp_str_s sys_name;
-       struct bfa_cee_lldp_str_s sys_desc;
-       struct bfa_cee_lldp_str_s mgmt_addr;
-       u16    time_to_interval;
-       u16    enabled_system_cap;
-};
-
-enum bfa_cee_dcbx_version_e {
-       DCBX_PROTOCOL_PRECEE = 1,
-       DCBX_PROTOCOL_CEE    = 2,
-};
-
-enum bfa_cee_lls_e {
-       CEE_LLS_DOWN_NO_TLV = 0, /* LLS is down because the TLV not sent by
-                                 * the peer */
-       CEE_LLS_DOWN        = 1, /* LLS is down as advertised by the peer */
-       CEE_LLS_UP          = 2,
-};
-
-/* CEE/DCBX parameters */
-struct bfa_cee_dcbx_cfg_s {
-       u8 pgid[8];
-       u8 pg_percentage[8];
-       u8 pfc_enabled;          /* bitmap of priorties with PFC enabled */
-       u8 fcoe_user_priority;   /* bitmap of priorities used for FcoE
-                                      * traffic */
-       u8 dcbx_version;        /* operating version:CEE or preCEE */
-       u8 lls_fcoe;    /* FCoE Logical Link Status */
-       u8 lls_lan;     /* LAN Logical Link Status */
-       u8 rsvd[3];
-};
-
-/* CEE status */
-/* Making this to tri-state for the benefit of port list command */
-enum bfa_cee_status_e {
-       CEE_UP = 0,
-       CEE_PHY_UP = 1,
-       CEE_LOOPBACK = 2,
-       CEE_PHY_DOWN = 3,
-};
-
-/* CEE Query */
-struct bfa_cee_attr_s {
-       u8                   cee_status;
-       u8                   error_reason;
-       struct bfa_cee_lldp_cfg_s lldp_remote;
-       struct bfa_cee_dcbx_cfg_s dcbx_remote;
-       mac_t src_mac;
-       u8 link_speed;
-       u8 nw_priority;
-       u8 filler[2];
-};
-
-
-
-
-/* LLDP/DCBX/CEE Statistics */
-
-struct bfa_cee_lldp_stats_s {
-       u32 frames_transmitted;
-       u32 frames_aged_out;
-       u32 frames_discarded;
-       u32 frames_in_error;
-       u32 frames_rcvd;
-       u32 tlvs_discarded;
-       u32 tlvs_unrecognized;
-};
-
-struct bfa_cee_dcbx_stats_s {
-       u32 subtlvs_unrecognized;
-       u32 negotiation_failed;
-       u32 remote_cfg_changed;
-       u32 tlvs_received;
-       u32 tlvs_invalid;
-       u32 seqno;
-       u32 ackno;
-       u32 recvd_seqno;
-       u32 recvd_ackno;
-};
-
-struct bfa_cee_cfg_stats_s {
-       u32 cee_status_down;
-       u32 cee_status_up;
-       u32 cee_hw_cfg_changed;
-       u32 recvd_invalid_cfg;
-};
-
-
-struct bfa_cee_stats_s {
-       struct bfa_cee_lldp_stats_s lldp_stats;
-       struct bfa_cee_dcbx_stats_s dcbx_stats;
-       struct bfa_cee_cfg_stats_s  cfg_stats;
-};
-
-#pragma pack()
-
-
-#endif /* __BFA_DEFS_CEE_H__ */
-
-
diff --git a/drivers/scsi/bfa/include/defs/bfa_defs_driver.h b/drivers/scsi/bfa/include/defs/bfa_defs_driver.h
deleted file mode 100644 (file)
index 7d00d00..0000000
+++ /dev/null
@@ -1,41 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_DEFS_DRIVER_H__
-#define __BFA_DEFS_DRIVER_H__
-
-/**
- * Driver statistics
- */
-struct bfa_driver_stats_s {
-       u16    tm_io_abort;
-    u16    tm_io_abort_comp;
-    u16    tm_lun_reset;
-    u16    tm_lun_reset_comp;
-    u16    tm_target_reset;
-    u16    tm_bus_reset;
-    u16    ioc_restart;        /*  IOC restart count */
-    u16    rsvd;
-    u64    control_req;
-    u64    input_req;
-    u64    output_req;
-    u64    input_words;
-    u64    output_words;
-};
-
-
-#endif /* __BFA_DEFS_DRIVER_H__ */
diff --git a/drivers/scsi/bfa/include/defs/bfa_defs_ethport.h b/drivers/scsi/bfa/include/defs/bfa_defs_ethport.h
deleted file mode 100644 (file)
index b4fa092..0000000
+++ /dev/null
@@ -1,99 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_DEFS_ETHPORT_H__
-#define __BFA_DEFS_ETHPORT_H__
-
-#include <defs/bfa_defs_status.h>
-#include <defs/bfa_defs_port.h>
-#include <protocol/types.h>
-#include <cna/pstats/phyport_defs.h>
-#include <cna/pstats/ethport_defs.h>
-
-struct bna_tx_info_s {
-       u32    miniport_state;
-       u32    adapter_state;
-       u64    tx_count;
-       u64    tx_wi;
-       u64    tx_sg;
-       u64    tx_tcp_chksum;
-       u64    tx_udp_chksum;
-       u64    tx_ip_chksum;
-       u64    tx_lsov1;
-       u64    tx_lsov2;
-       u64    tx_max_sg_len ;
-};
-
-struct bna_rx_queue_info_s {
-       u16    q_id ;
-       u16    buf_size ;
-       u16    buf_count ;
-       u16    rsvd ;
-       u64    rx_count ;
-       u64    rx_dropped ;
-       u64    rx_unsupported ;
-       u64    rx_internal_err ;
-       u64    rss_count ;
-       u64    vlan_count ;
-       u64    rx_tcp_chksum ;
-       u64    rx_udp_chksum ;
-       u64    rx_ip_chksum ;
-       u64    rx_hds ;
-};
-
-struct bna_rx_q_set_s {
-       u16    q_set_type;
-       u32    miniport_state;
-       u32    adapter_state;
-       struct bna_rx_queue_info_s    rx_queue[2];
-};
-
-struct bna_port_stats_s {
-       struct bna_tx_info_s   tx_stats;
-       u16        qset_count ;
-       struct bna_rx_q_set_s  rx_qset[8];
-};
-
-struct bfa_ethport_stats_s {
-       struct bna_stats_txf    txf_stats[1];
-       struct bna_stats_rxf    rxf_stats[1];
-       struct bnad_drv_stats drv_stats;
-};
-
-/**
- * Ethernet port events
- * Arguments below are in BFAL context from Mgmt
- * BFA_PORT_AEN_ETH_LINKUP:    [in]: mac [out]: mac
- * BFA_PORT_AEN_ETH_LINKDOWN:  [in]: mac [out]: mac
- * BFA_PORT_AEN_ETH_ENABLE:  [in]: mac [out]: mac
- * BFA_PORT_AEN_ETH_DISABLE:  [in]: mac [out]: mac
- *
- */
-enum bfa_ethport_aen_event {
-       BFA_ETHPORT_AEN_LINKUP = 1, /*  Base Port Ethernet link up event */
-       BFA_ETHPORT_AEN_LINKDOWN = 2, /*  Base Port Ethernet link down event */
-       BFA_ETHPORT_AEN_ENABLE = 3, /*  Base Port Ethernet link enable event */
-       BFA_ETHPORT_AEN_DISABLE = 4, /*  Base Port Ethernet link disable
-                                     * event */
-};
-
-struct bfa_ethport_aen_data_s {
-       mac_t mac;      /*  MAC address of the physical port */
-};
-
-
-#endif /* __BFA_DEFS_ETHPORT_H__ */
diff --git a/drivers/scsi/bfa/include/defs/bfa_defs_fcpim.h b/drivers/scsi/bfa/include/defs/bfa_defs_fcpim.h
deleted file mode 100644 (file)
index c08f4f5..0000000
+++ /dev/null
@@ -1,45 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-#ifndef __BFA_DEFS_FCPIM_H__
-#define __BFA_DEFS_FCPIM_H__
-
-struct bfa_fcpim_stats_s {
-       u32        total_ios;   /*  Total IO count */
-       u32        qresumes;    /*  IO waiting for CQ space */
-       u32        no_iotags;   /*  NO IO contexts */
-       u32        io_aborts;   /*  IO abort requests */
-       u32        no_tskims;   /*  NO task management contexts */
-       u32        iocomp_ok;   /*  IO completions with OK status */
-       u32        iocomp_underrun;     /*  IO underrun (good) */
-       u32        iocomp_overrun;      /*  IO overrun (good) */
-       u32        iocomp_aborted;      /*  Aborted IO requests */
-       u32        iocomp_timedout;     /*  IO timeouts */
-       u32        iocom_nexus_abort;   /*  IO selection timeouts */
-       u32        iocom_proto_err;     /*  IO protocol errors */
-       u32        iocom_dif_err;       /*  IO SBC-3 protection errors */
-       u32        iocom_tm_abort;      /*  IO aborted by TM requests */
-       u32        iocom_sqer_needed;   /*  IO retry for SQ error
-                                                *recovery */
-       u32        iocom_res_free;      /*  Delayed freeing of IO resources */
-       u32        iocomp_scsierr;      /*  IO with non-good SCSI status */
-       u32        iocom_hostabrts;     /*  Host IO abort requests */
-       u32        iocom_utags; /*  IO comp with unknown tags */
-       u32        io_cleanups; /*  IO implicitly aborted */
-       u32        io_tmaborts; /*  IO aborted due to TM commands */
-       u32        rsvd;
-};
-#endif /*__BFA_DEFS_FCPIM_H__*/
diff --git a/drivers/scsi/bfa/include/defs/bfa_defs_fcport.h b/drivers/scsi/bfa/include/defs/bfa_defs_fcport.h
deleted file mode 100644 (file)
index af86a63..0000000
+++ /dev/null
@@ -1,88 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- *  bfa_defs_fcport.h
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-#ifndef __BFA_DEFS_FCPORT_H__
-#define __BFA_DEFS_FCPORT_H__
-
-#include <defs/bfa_defs_types.h>
-#include <protocol/types.h>
-
-#pragma pack(1)
-
-/**
- * FCoE statistics
- */
-struct bfa_fcoe_stats_s {
-       u64     secs_reset;     /*  Seconds since stats reset        */
-       u64     cee_linkups;    /*  CEE link up              */
-       u64     cee_linkdns;    /*  CEE link down                    */
-       u64     fip_linkups;    /*  FIP link up              */
-       u64     fip_linkdns;    /*  FIP link down                    */
-       u64     fip_fails;      /*  FIP failures                     */
-       u64     mac_invalids;   /*  Invalid mac assignments          */
-       u64     vlan_req;       /*  Vlan requests                    */
-       u64     vlan_notify;    /*  Vlan notifications               */
-       u64     vlan_err;       /*  Vlan notification errors         */
-       u64     vlan_timeouts;  /*  Vlan request timeouts            */
-       u64     vlan_invalids;  /*  Vlan invalids                    */
-       u64     disc_req;       /*  Discovery requests               */
-       u64     disc_rsp;       /*  Discovery responses      */
-       u64     disc_err;       /*  Discovery error frames           */
-       u64     disc_unsol;     /*  Discovery unsolicited            */
-       u64     disc_timeouts;  /*  Discovery timeouts               */
-       u64     disc_fcf_unavail; /*  Discovery FCF not avail        */
-       u64     linksvc_unsupp; /*  FIP link service req unsupp.    */
-       u64     linksvc_err;    /*  FIP link service req errors     */
-       u64     logo_req;       /*  FIP logos received                       */
-       u64     clrvlink_req;   /*  Clear virtual link requests     */
-       u64     op_unsupp;      /*  FIP operation unsupp.            */
-       u64     untagged;       /*  FIP untagged frames      */
-       u64     txf_ucast;      /*  Tx FCoE unicast frames           */
-       u64     txf_ucast_vlan; /*  Tx FCoE unicast vlan frames     */
-       u64     txf_ucast_octets; /*  Tx FCoE unicast octets         */
-       u64     txf_mcast;      /*  Tx FCoE mutlicast frames         */
-       u64     txf_mcast_vlan; /*  Tx FCoE mutlicast vlan frames   */
-       u64     txf_mcast_octets; /*  Tx FCoE multicast octets       */
-       u64     txf_bcast;      /*  Tx FCoE broadcast frames         */
-       u64     txf_bcast_vlan; /*  Tx FCoE broadcast vlan frames   */
-       u64     txf_bcast_octets; /*  Tx FCoE broadcast octets       */
-       u64     txf_timeout;    /*  Tx timeouts              */
-       u64     txf_parity_errors; /*  Transmit parity err           */
-       u64     txf_fid_parity_errors; /*  Transmit FID parity err  */
-       u64     rxf_ucast_octets; /* Rx FCoE unicast octets        */
-       u64     rxf_ucast;      /* Rx FCoE unicast frames          */
-       u64     rxf_ucast_vlan; /* Rx FCoE unicast vlan frames     */
-       u64     rxf_mcast_octets; /* Rx FCoE multicast octets      */
-       u64     rxf_mcast;      /* Rx FCoE multicast frames        */
-       u64     rxf_mcast_vlan; /* Rx FCoE multicast vlan frames   */
-       u64     rxf_bcast_octets; /* Rx FCoE broadcast octets      */
-       u64     rxf_bcast;      /* Rx FCoE broadcast frames        */
-       u64     rxf_bcast_vlan; /* Rx FCoE broadcast vlan frames   */
-};
-
-/**
- * QoS or FCoE stats (fcport stats excluding physical FC port stats)
- */
-union bfa_fcport_stats_u {
-       struct bfa_qos_stats_s  fcqos;
-       struct bfa_fcoe_stats_s fcoe;
-};
-
-#pragma pack()
-
-#endif  /* __BFA_DEFS_FCPORT_H__ */
diff --git a/drivers/scsi/bfa/include/defs/bfa_defs_ioc.h b/drivers/scsi/bfa/include/defs/bfa_defs_ioc.h
deleted file mode 100644 (file)
index add0a05..0000000
+++ /dev/null
@@ -1,158 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_DEFS_IOC_H__
-#define __BFA_DEFS_IOC_H__
-
-#include <protocol/types.h>
-#include <defs/bfa_defs_types.h>
-#include <defs/bfa_defs_version.h>
-#include <defs/bfa_defs_adapter.h>
-#include <defs/bfa_defs_pm.h>
-
-enum {
-       BFA_IOC_DRIVER_LEN      = 16,
-       BFA_IOC_CHIP_REV_LEN    = 8,
-};
-
-/**
- * Driver and firmware versions.
- */
-struct bfa_ioc_driver_attr_s {
-       char            driver[BFA_IOC_DRIVER_LEN];     /*  driver name */
-       char            driver_ver[BFA_VERSION_LEN];    /*  driver version */
-       char            fw_ver[BFA_VERSION_LEN];        /*  firmware version*/
-       char            bios_ver[BFA_VERSION_LEN];      /*  bios version */
-       char            efi_ver[BFA_VERSION_LEN];       /*  EFI version */
-       char            ob_ver[BFA_VERSION_LEN];        /*  openboot version*/
-};
-
-/**
- * IOC PCI device attributes
- */
-struct bfa_ioc_pci_attr_s {
-       u16        vendor_id;   /*  PCI vendor ID */
-       u16        device_id;   /*  PCI device ID */
-       u16        ssid;                /*  subsystem ID */
-       u16        ssvid;               /*  subsystem vendor ID */
-       u32        pcifn;               /*  PCI device function */
-       u32        rsvd;                /* padding */
-       u8         chip_rev[BFA_IOC_CHIP_REV_LEN];       /*  chip revision */
-};
-
-/**
- * IOC states
- */
-enum bfa_ioc_state {
-       BFA_IOC_RESET       = 1,  /*  IOC is in reset state */
-       BFA_IOC_SEMWAIT     = 2,  /*  Waiting for IOC hardware semaphore */
-       BFA_IOC_HWINIT      = 3,  /*  IOC hardware is being initialized */
-       BFA_IOC_GETATTR     = 4,  /*  IOC is being configured */
-       BFA_IOC_OPERATIONAL = 5,  /*  IOC is operational */
-       BFA_IOC_INITFAIL    = 6,  /*  IOC hardware failure */
-       BFA_IOC_HBFAIL      = 7,  /*  IOC heart-beat failure */
-       BFA_IOC_DISABLING   = 8,  /*  IOC is being disabled */
-       BFA_IOC_DISABLED    = 9,  /*  IOC is disabled */
-       BFA_IOC_FWMISMATCH  = 10, /*  IOC firmware different from drivers */
-};
-
-/**
- * IOC firmware stats
- */
-struct bfa_fw_ioc_stats_s {
-       u32        hb_count;
-       u32        cfg_reqs;
-       u32        enable_reqs;
-       u32        disable_reqs;
-       u32        stats_reqs;
-       u32        clrstats_reqs;
-       u32        unknown_reqs;
-       u32        ic_reqs;             /*  interrupt coalesce reqs */
-};
-
-/**
- * IOC driver stats
- */
-struct bfa_ioc_drv_stats_s {
-       u32     ioc_isrs;
-       u32     ioc_enables;
-       u32     ioc_disables;
-       u32     ioc_hbfails;
-       u32     ioc_boots;
-       u32     stats_tmos;
-       u32        hb_count;
-       u32        disable_reqs;
-       u32        enable_reqs;
-       u32        disable_replies;
-       u32        enable_replies;
-};
-
-/**
- * IOC statistics
- */
-struct bfa_ioc_stats_s {
-       struct bfa_ioc_drv_stats_s      drv_stats; /*  driver IOC stats */
-       struct bfa_fw_ioc_stats_s       fw_stats;  /*  firmware IOC stats */
-};
-
-
-enum bfa_ioc_type_e {
-       BFA_IOC_TYPE_FC   = 1,
-       BFA_IOC_TYPE_FCoE = 2,
-       BFA_IOC_TYPE_LL   = 3,
-};
-
-/**
- * IOC attributes returned in queries
- */
-struct bfa_ioc_attr_s {
-       enum bfa_ioc_type_e             ioc_type;
-       enum bfa_ioc_state              state;          /*  IOC state      */
-       struct bfa_adapter_attr_s       adapter_attr;   /*  HBA attributes */
-       struct bfa_ioc_driver_attr_s    driver_attr;    /*  driver attr    */
-       struct bfa_ioc_pci_attr_s       pci_attr;
-       u8                              port_id;        /*  port number    */
-       u8                              rsvd[7];        /*  64bit align    */
-};
-
-/**
- * BFA IOC level events
- */
-enum bfa_ioc_aen_event {
-       BFA_IOC_AEN_HBGOOD      = 1,    /*  Heart Beat restore event    */
-       BFA_IOC_AEN_HBFAIL      = 2,    /*  Heart Beat failure event    */
-       BFA_IOC_AEN_ENABLE      = 3,    /*  IOC enabled event           */
-       BFA_IOC_AEN_DISABLE     = 4,    /*  IOC disabled event          */
-       BFA_IOC_AEN_FWMISMATCH  = 5,    /*  IOC firmware mismatch       */
-       BFA_IOC_AEN_FWCFG_ERROR = 6,    /*  IOC firmware config error   */
-       BFA_IOC_AEN_INVALID_VENDOR = 7,
-       BFA_IOC_AEN_INVALID_NWWN = 8,   /*  Zero NWWN                   */
-       BFA_IOC_AEN_INVALID_PWWN = 9    /*  Zero PWWN                   */
-
-};
-
-/**
- * BFA IOC level event data, now just a place holder
- */
-struct bfa_ioc_aen_data_s {
-       wwn_t   pwwn;
-       s16 ioc_type;
-       mac_t   mac;
-};
-
-#endif /* __BFA_DEFS_IOC_H__ */
-
diff --git a/drivers/scsi/bfa/include/defs/bfa_defs_iocfc.h b/drivers/scsi/bfa/include/defs/bfa_defs_iocfc.h
deleted file mode 100644 (file)
index 31e728a..0000000
+++ /dev/null
@@ -1,322 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_DEFS_IOCFC_H__
-#define __BFA_DEFS_IOCFC_H__
-
-#include <protocol/types.h>
-#include <defs/bfa_defs_types.h>
-#include <defs/bfa_defs_version.h>
-#include <defs/bfa_defs_adapter.h>
-#include <defs/bfa_defs_pm.h>
-
-#define BFA_IOCFC_INTR_DELAY   1125
-#define BFA_IOCFC_INTR_LATENCY 225
-#define BFA_IOCFCOE_INTR_DELAY  25
-#define BFA_IOCFCOE_INTR_LATENCY 5
-
-/**
- * Interrupt coalescing configuration.
- */
-struct bfa_iocfc_intr_attr_s {
-       bfa_boolean_t   coalesce;       /*  enable/disable coalescing */
-       u16     latency;        /*  latency in microseconds   */
-       u16     delay;          /*  delay in microseconds     */
-};
-
-/**
- * IOC firmware configuraton
- */
-struct bfa_iocfc_fwcfg_s {
-       u16        num_fabrics; /*  number of fabrics           */
-       u16        num_lports;  /*  number of local lports      */
-       u16        num_rports;  /*  number of remote ports      */
-       u16        num_ioim_reqs;       /*  number of IO reqs           */
-       u16        num_tskim_reqs;      /*  task management requests    */
-       u16        num_iotm_reqs;       /*  number of TM IO reqs        */
-       u16        num_tsktm_reqs;      /*  TM task management requests*/
-       u16        num_fcxp_reqs;       /*  unassisted FC exchanges     */
-       u16        num_uf_bufs; /*  unsolicited recv buffers    */
-       u8         num_cqs;
-       u8         fw_tick_res;    /*!< FW clock resolution in ms */
-       u8         rsvd[4];
-
-};
-
-struct bfa_iocfc_drvcfg_s {
-       u16        num_reqq_elems;      /*  number of req queue elements */
-       u16        num_rspq_elems;      /*  number of rsp queue elements */
-       u16        num_sgpgs;   /*  number of total SG pages      */
-       u16        num_sboot_tgts;      /*  number of SAN boot targets    */
-       u16        num_sboot_luns;      /*  number of SAN boot luns       */
-       u16         ioc_recover;        /*  IOC recovery mode             */
-       u16         min_cfg;    /*  minimum configuration         */
-       u16        path_tov;    /*  device path timeout   */
-       bfa_boolean_t   delay_comp; /*  delay completion of
-                                                       failed inflight IOs */
-       u32             rsvd;
-};
-/**
- * IOC configuration
- */
-struct bfa_iocfc_cfg_s {
-       struct bfa_iocfc_fwcfg_s        fwcfg;  /*  firmware side config */
-       struct bfa_iocfc_drvcfg_s       drvcfg; /*  driver side config    */
-};
-
-/**
- * IOC firmware IO stats
- */
-struct bfa_fw_io_stats_s {
-       u32     host_abort;             /*  IO aborted by host driver*/
-       u32     host_cleanup;           /*  IO clean up by host driver */
-
-       u32     fw_io_timeout;          /*  IOs timedout */
-       u32     fw_frm_parse;           /*  frame parsed by f/w */
-       u32     fw_frm_data;            /*  fcp_data frame parsed by f/w */
-       u32     fw_frm_rsp;             /*  fcp_rsp frame parsed by f/w */
-       u32     fw_frm_xfer_rdy;        /*  xfer_rdy frame parsed by f/w */
-       u32     fw_frm_bls_acc;         /*  BLS ACC  frame parsed by f/w */
-       u32     fw_frm_tgt_abort;       /*  target ABTS parsed by f/w */
-       u32     fw_frm_unknown;         /*  unknown parsed by f/w */
-       u32     fw_data_dma;            /*  f/w DMA'ed the data frame */
-       u32     fw_frm_drop;            /*  f/w drop the frame */
-
-       u32     rec_timeout;            /*  FW rec timed out */
-       u32     error_rec;                      /*  FW sending rec on
-                                                       * an error condition*/
-       u32     wait_for_si;            /*  FW wait for SI */
-       u32     rec_rsp_inval;          /*  REC rsp invalid */
-       u32     seqr_io_abort;          /*  target does not know cmd so abort */
-       u32     seqr_io_retry;          /*  SEQR failed so retry IO */
-
-       u32     itn_cisc_upd_rsp;       /*  ITN cisc updated on fcp_rsp */
-       u32     itn_cisc_upd_data;      /*  ITN cisc updated on fcp_data */
-       u32     itn_cisc_upd_xfer_rdy;  /*  ITN cisc updated on fcp_data */
-
-       u32     fcp_data_lost;          /*  fcp data lost */
-
-       u32     ro_set_in_xfer_rdy;     /*  Target set RO in Xfer_rdy frame */
-       u32     xfer_rdy_ooo_err;       /*  Out of order Xfer_rdy received */
-       u32     xfer_rdy_unknown_err;   /*  unknown error in xfer_rdy frame */
-
-       u32     io_abort_timeout;       /*  ABTS timedout  */
-       u32     sler_initiated;         /*  SLER initiated */
-
-       u32     unexp_fcp_rsp;          /*  fcp response in wrong state */
-
-       u32     fcp_rsp_under_run;      /*  fcp rsp IO underrun */
-       u32        fcp_rsp_under_run_wr;   /*  fcp rsp IO underrun for write */
-       u32     fcp_rsp_under_run_err;  /*  fcp rsp IO underrun error */
-       u32        fcp_rsp_resid_inval;    /*  invalid residue */
-       u32     fcp_rsp_over_run;       /*  fcp rsp IO overrun */
-       u32     fcp_rsp_over_run_err;   /*  fcp rsp IO overrun error */
-       u32     fcp_rsp_proto_err;      /*  protocol error in fcp rsp */
-       u32     fcp_rsp_sense_err;      /*  error in sense info in fcp rsp */
-       u32     fcp_conf_req;           /*  FCP conf requested */
-
-       u32     tgt_aborted_io;         /*  target initiated abort */
-
-       u32     ioh_edtov_timeout_event;/*  IOH edtov timer popped */
-       u32     ioh_fcp_rsp_excp_event; /*  IOH FCP_RSP exception */
-       u32     ioh_fcp_conf_event;     /*  IOH FCP_CONF */
-       u32     ioh_mult_frm_rsp_event; /*  IOH multi_frame FCP_RSP */
-       u32     ioh_hit_class2_event;   /*  IOH hit class2 */
-       u32     ioh_miss_other_event;   /*  IOH miss other */
-       u32     ioh_seq_cnt_err_event;  /*  IOH seq cnt error */
-       u32     ioh_len_err_event;              /*  IOH len error - fcp_dl !=
-                                                       * bytes xfered */
-       u32     ioh_seq_len_err_event;  /*  IOH seq len error */
-       u32     ioh_data_oor_event;     /*  Data out of range */
-       u32     ioh_ro_ooo_event;       /*  Relative offset out of range */
-       u32     ioh_cpu_owned_event;    /*  IOH hit -iost owned by f/w */
-       u32     ioh_unexp_frame_event;  /*  unexpected frame recieved
-                                                *   count */
-       u32     ioh_err_int;            /*  IOH error int during data-phase
-                                                *   for scsi write
-                                                */
-};
-
-/**
- * IOC port firmware stats
- */
-
-struct bfa_fw_port_fpg_stats_s {
-    u32    intr_evt;
-    u32    intr;
-    u32    intr_excess;
-    u32    intr_cause0;
-    u32    intr_other;
-    u32    intr_other_ign;
-    u32    sig_lost;
-    u32    sig_regained;
-    u32    sync_lost;
-    u32    sync_to;
-    u32    sync_regained;
-    u32    div2_overflow;
-    u32    div2_underflow;
-    u32    efifo_overflow;
-    u32    efifo_underflow;
-    u32    idle_rx;
-    u32    lrr_rx;
-    u32    lr_rx;
-    u32    ols_rx;
-    u32    nos_rx;
-    u32    lip_rx;
-    u32    arbf0_rx;
-    u32    arb_rx;
-    u32    mrk_rx;
-    u32    const_mrk_rx;
-    u32    prim_unknown;
-};
-
-
-struct bfa_fw_port_lksm_stats_s {
-    u32    hwsm_success;       /*  hwsm state machine success          */
-    u32    hwsm_fails;         /*  hwsm fails                          */
-    u32    hwsm_wdtov;         /*  hwsm timed out                      */
-    u32    swsm_success;       /*  swsm success                        */
-    u32    swsm_fails;         /*  swsm fails                          */
-    u32    swsm_wdtov;         /*  swsm timed out                      */
-    u32    busybufs;           /*  link init failed due to busybuf     */
-    u32    buf_waits;          /*  bufwait state entries               */
-    u32    link_fails;         /*  link failures                       */
-    u32    psp_errors;         /*  primitive sequence protocol errors  */
-    u32    lr_unexp;           /*  No. of times LR rx-ed unexpectedly  */
-    u32    lrr_unexp;          /*  No. of times LRR rx-ed unexpectedly */
-    u32    lr_tx;              /*  No. of times LR tx started          */
-    u32    lrr_tx;             /*  No. of times LRR tx started         */
-    u32    ols_tx;             /*  No. of times OLS tx started         */
-    u32    nos_tx;             /*  No. of times NOS tx started         */
-    u32    hwsm_lrr_rx;        /*  No. of times LRR rx-ed by HWSM      */
-    u32    hwsm_lr_rx;         /* No. of times LR rx-ed by HWSM        */
-};
-
-
-struct bfa_fw_port_snsm_stats_s {
-    u32    hwsm_success;       /*  Successful hwsm terminations        */
-    u32    hwsm_fails;         /*  hwsm fail count                     */
-    u32    hwsm_wdtov;         /*  hwsm timed out                      */
-    u32    swsm_success;       /*  swsm success                        */
-    u32    swsm_wdtov;         /*  swsm timed out                      */
-    u32    error_resets;       /*  error resets initiated by upsm      */
-    u32    sync_lost;          /*  Sync loss count                     */
-    u32    sig_lost;           /*  Signal loss count                   */
-};
-
-
-struct bfa_fw_port_physm_stats_s {
-    u32    module_inserts;     /*  Module insert count                 */
-    u32    module_xtracts;     /*  Module extracts count               */
-    u32    module_invalids;    /*  Invalid module inserted count       */
-    u32    module_read_ign;    /*  Module validation status ignored    */
-    u32    laser_faults;       /*  Laser fault count                   */
-    u32    rsvd;
-};
-
-
-struct bfa_fw_fip_stats_s {
-    u32    vlan_req;           /*  vlan discovery requests             */
-    u32    vlan_notify;        /*  vlan notifications                  */
-    u32    vlan_err;           /*  vlan response error                 */
-    u32    vlan_timeouts;      /*  vlan disvoery timeouts              */
-    u32    vlan_invalids;      /*  invalid vlan in discovery advert.   */
-    u32    disc_req;           /*  Discovery solicit requests          */
-    u32    disc_rsp;           /*  Discovery solicit response          */
-    u32    disc_err;           /*  Discovery advt. parse errors        */
-    u32    disc_unsol;         /*  Discovery unsolicited               */
-    u32    disc_timeouts;      /*  Discovery timeouts                  */
-    u32    disc_fcf_unavail;   /*  Discovery FCF Not Avail.            */
-    u32    linksvc_unsupp;     /*  Unsupported link service req        */
-    u32    linksvc_err;        /*  Parse error in link service req     */
-    u32    logo_req;           /*  FIP logos received                 */
-    u32    clrvlink_req;       /*  Clear virtual link req              */
-    u32    op_unsupp;          /*  Unsupported FIP operation           */
-    u32    untagged;           /*  Untagged frames (ignored)           */
-    u32           invalid_version;    /*!< Invalid FIP version           */
-};
-
-
-struct bfa_fw_lps_stats_s {
-    u32    mac_invalids;       /*  Invalid mac assigned                */
-    u32    rsvd;
-};
-
-
-struct bfa_fw_fcoe_stats_s {
-    u32    cee_linkups;        /*  CEE link up count                   */
-    u32    cee_linkdns;        /*  CEE link down count                 */
-    u32    fip_linkups;        /*  FIP link up count                   */
-    u32    fip_linkdns;        /*  FIP link up count                   */
-    u32    fip_fails;          /*  FIP fail count                      */
-    u32    mac_invalids;       /*  Invalid mac assigned                */
-};
-
-/**
- * IOC firmware FCoE port stats
- */
-struct bfa_fw_fcoe_port_stats_s {
-    struct bfa_fw_fcoe_stats_s  fcoe_stats;
-    struct bfa_fw_fip_stats_s   fip_stats;
-};
-
-/**
- * IOC firmware FC port stats
- */
-struct bfa_fw_fc_port_stats_s {
-       struct bfa_fw_port_fpg_stats_s          fpg_stats;
-       struct bfa_fw_port_physm_stats_s        physm_stats;
-       struct bfa_fw_port_snsm_stats_s         snsm_stats;
-       struct bfa_fw_port_lksm_stats_s         lksm_stats;
-};
-
-/**
- * IOC firmware FC port stats
- */
-union bfa_fw_port_stats_s {
-       struct bfa_fw_fc_port_stats_s   fc_stats;
-       struct bfa_fw_fcoe_port_stats_s fcoe_stats;
-};
-
-/**
- * IOC firmware stats
- */
-struct bfa_fw_stats_s {
-       struct bfa_fw_ioc_stats_s       ioc_stats;
-       struct bfa_fw_io_stats_s        io_stats;
-       union  bfa_fw_port_stats_s      port_stats;
-};
-
-/**
- * IOC statistics
- */
-struct bfa_iocfc_stats_s {
-       struct bfa_fw_stats_s   fw_stats;       /*  firmware IOC stats      */
-};
-
-/**
- * IOC attributes returned in queries
- */
-struct bfa_iocfc_attr_s {
-       struct bfa_iocfc_cfg_s          config;         /*  IOCFC config   */
-       struct bfa_iocfc_intr_attr_s    intr_attr;      /*  interrupt attr */
-};
-
-#define BFA_IOCFC_PATHTOV_MAX  60
-#define BFA_IOCFC_QDEPTH_MAX   2000
-
-#endif /* __BFA_DEFS_IOC_H__ */
diff --git a/drivers/scsi/bfa/include/defs/bfa_defs_ipfc.h b/drivers/scsi/bfa/include/defs/bfa_defs_ipfc.h
deleted file mode 100644 (file)
index 7cb63ea..0000000
+++ /dev/null
@@ -1,70 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-#ifndef __BFA_DEFS_IPFC_H__
-#define __BFA_DEFS_IPFC_H__
-
-#include <bfa_os_inc.h>
-#include <protocol/types.h>
-#include <defs/bfa_defs_types.h>
-
-/**
- * FCS ip remote port states
- */
-enum bfa_iprp_state {
-       BFA_IPRP_UNINIT  = 0,   /*  PORT is not yet initialized */
-       BFA_IPRP_ONLINE  = 1,   /*  process login is complete */
-       BFA_IPRP_OFFLINE = 2,   /*  iprp is offline */
-};
-
-/**
- * FCS remote port statistics
- */
-struct bfa_iprp_stats_s {
-       u32        offlines;
-       u32        onlines;
-       u32        rscns;
-       u32        plogis;
-       u32        logos;
-       u32        plogi_timeouts;
-       u32        plogi_rejects;
-};
-
-/**
- * FCS iprp attribute returned in queries
- */
-struct bfa_iprp_attr_s {
-       enum bfa_iprp_state state;
-};
-
-struct bfa_ipfc_stats_s {
-       u32 arp_sent;
-       u32 arp_recv;
-       u32 arp_reply_sent;
-       u32 arp_reply_recv;
-       u32 farp_sent;
-       u32 farp_recv;
-       u32 farp_reply_sent;
-       u32 farp_reply_recv;
-       u32 farp_reject_sent;
-       u32 farp_reject_recv;
-};
-
-struct bfa_ipfc_attr_s {
-       bfa_boolean_t enabled;
-};
-
-#endif /* __BFA_DEFS_IPFC_H__ */
diff --git a/drivers/scsi/bfa/include/defs/bfa_defs_itnim.h b/drivers/scsi/bfa/include/defs/bfa_defs_itnim.h
deleted file mode 100644 (file)
index d77788b..0000000
+++ /dev/null
@@ -1,136 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-#ifndef __BFA_DEFS_ITNIM_H__
-#define __BFA_DEFS_ITNIM_H__
-
-#include <bfa_os_inc.h>
-#include <protocol/types.h>
-
-/**
- * FCS itnim states
- */
-enum bfa_itnim_state {
-       BFA_ITNIM_OFFLINE       = 0,    /*  offline */
-       BFA_ITNIM_PRLI_SEND     = 1,    /*  prli send */
-       BFA_ITNIM_PRLI_SENT     = 2,    /*  prli sent */
-       BFA_ITNIM_PRLI_RETRY    = 3,    /*  prli retry */
-       BFA_ITNIM_HCB_ONLINE    = 4,    /*  online callback */
-       BFA_ITNIM_ONLINE        = 5,    /*  online */
-       BFA_ITNIM_HCB_OFFLINE   = 6,    /*  offline callback */
-       BFA_ITNIM_INITIATIOR    = 7,    /*  initiator */
-};
-
-struct bfa_itnim_latency_s {
-       u32     min;
-       u32     max;
-       u32     count;
-       u32     clock_res;
-       u32     avg;
-       u32     rsvd;
-};
-
-struct bfa_itnim_hal_stats_s {
-       u32     onlines;        /*  ITN nexus onlines (PRLI done) */
-       u32     offlines;       /*  ITN Nexus offlines  */
-       u32     creates;        /*  ITN create requests         */
-       u32     deletes;        /*  ITN delete requests         */
-       u32     create_comps;   /*  ITN create completions      */
-       u32     delete_comps;   /*  ITN delete completions      */
-       u32     sler_events;    /*  SLER (sequence level error
-                                        * recovery) events */
-       u32     ioc_disabled;   /*  Num IOC disables            */
-       u32     cleanup_comps;  /*  ITN cleanup completions */
-       u32     tm_cmnds;       /*  task management(TM) cmnds sent */
-       u32     tm_fw_rsps;     /*  TM cmds firmware responses */
-       u32     tm_success;     /*  TM successes */
-       u32     tm_failures;    /*  TM failures */
-       u32     tm_io_comps;    /*  TM IO completions */
-       u32     tm_qresumes;    /*  TM queue resumes (after waiting
-                                        * for resources)
-                                        */
-       u32     tm_iocdowns;    /*  TM cmnds affected by IOC down */
-       u32     tm_cleanups;    /*  TM cleanups */
-       u32     tm_cleanup_comps;
-                                       /*  TM cleanup completions */
-       u32     ios;            /*  IO requests */
-       u32     io_comps;       /*  IO completions */
-       u64     input_reqs;     /*  INPUT requests */
-       u64     output_reqs;    /*  OUTPUT requests */
-};
-
-/**
- * FCS remote port statistics
- */
-struct bfa_itnim_stats_s {
-       u32        onlines;     /*  num rport online */
-       u32        offlines;    /*  num rport offline */
-       u32        prli_sent;   /*  num prli sent out */
-       u32        fcxp_alloc_wait;/*  num fcxp alloc waits */
-       u32        prli_rsp_err;        /*  num prli rsp errors */
-       u32        prli_rsp_acc;        /*  num prli rsp accepts */
-       u32        initiator;   /*  rport is an initiator */
-       u32        prli_rsp_parse_err;  /*  prli rsp parsing errors */
-       u32        prli_rsp_rjt;        /*  num prli rsp rejects */
-       u32        timeout;     /*  num timeouts detected */
-       u32        sler;                /*  num sler notification from BFA */
-       u32     rsvd;
-       struct bfa_itnim_hal_stats_s    hal_stats;
-};
-
-/**
- * FCS itnim attributes returned in queries
- */
-struct bfa_itnim_attr_s {
-       enum bfa_itnim_state state; /*  FCS itnim state        */
-       u8 retry;               /*  data retransmision support */
-       u8      task_retry_id;  /*  task retry ident support   */
-       u8 rec_support;    /*  REC supported              */
-       u8 conf_comp;      /*  confirmed completion supp  */
-       struct bfa_itnim_latency_s  io_latency; /* IO latency  */
-};
-
-/**
- * BFA ITNIM events.
- * Arguments below are in BFAL context from Mgmt
- * BFA_ITNIM_AEN_NEW:       [in]: None  [out]: vf_id, lpwwn
- * BFA_ITNIM_AEN_DELETE:    [in]: vf_id, lpwwn, rpwwn (0 = all fcp4 targets),
- *                               [out]: vf_id, ppwwn, lpwwn, rpwwn
- * BFA_ITNIM_AEN_ONLINE:    [in]: vf_id, lpwwn, rpwwn (0 = all fcp4 targets),
- *                               [out]: vf_id, ppwwn, lpwwn, rpwwn
- * BFA_ITNIM_AEN_OFFLINE:   [in]: vf_id, lpwwn, rpwwn (0 = all fcp4 targets),
- *                               [out]: vf_id, ppwwn, lpwwn, rpwwn
- * BFA_ITNIM_AEN_DISCONNECT:[in]: vf_id, lpwwn, rpwwn (0 = all fcp4 targets),
- *                               [out]: vf_id, ppwwn, lpwwn, rpwwn
- */
-enum bfa_itnim_aen_event {
-       BFA_ITNIM_AEN_ONLINE    = 1,    /*  Target online */
-       BFA_ITNIM_AEN_OFFLINE   = 2,    /*  Target offline */
-       BFA_ITNIM_AEN_DISCONNECT = 3,   /*  Target disconnected */
-};
-
-/**
- * BFA ITNIM event data structure.
- */
-struct bfa_itnim_aen_data_s {
-       u16        vf_id;       /*  vf_id of the IT nexus */
-       u16        rsvd[3];
-       wwn_t           ppwwn;  /*  WWN of its physical port */
-       wwn_t           lpwwn;  /*  WWN of logical port */
-       wwn_t           rpwwn;  /*  WWN of remote(target) port */
-};
-
-#endif /* __BFA_DEFS_ITNIM_H__ */
diff --git a/drivers/scsi/bfa/include/defs/bfa_defs_led.h b/drivers/scsi/bfa/include/defs/bfa_defs_led.h
deleted file mode 100644 (file)
index 6203927..0000000
+++ /dev/null
@@ -1,35 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_DEFS_LED_H__
-#define __BFA_DEFS_LED_H__
-
-#define        BFA_LED_MAX_NUM         3
-
-enum bfa_led_op {
-       BFA_LED_OFF   = 0,
-       BFA_LED_ON    = 1,
-       BFA_LED_FLICK = 2,
-       BFA_LED_BLINK = 3,
-};
-
-enum bfa_led_color {
-       BFA_LED_GREEN = 0,
-       BFA_LED_AMBER = 1,
-};
-
-#endif /* __BFA_DEFS_LED_H__ */
diff --git a/drivers/scsi/bfa/include/defs/bfa_defs_lport.h b/drivers/scsi/bfa/include/defs/bfa_defs_lport.h
deleted file mode 100644 (file)
index 0952a13..0000000
+++ /dev/null
@@ -1,68 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_DEFS_LPORT_H__
-#define __BFA_DEFS_LPORT_H__
-
-#include <defs/bfa_defs_types.h>
-#include <defs/bfa_defs_port.h>
-
-/**
- * BFA AEN logical port events.
- * Arguments below are in BFAL context from Mgmt
- * BFA_LPORT_AEN_NEW:       [in]: None         [out]: vf_id, ppwwn, lpwwn, roles
- * BFA_LPORT_AEN_DELETE:    [in]: lpwwn        [out]: vf_id, ppwwn. lpwwn, roles
- * BFA_LPORT_AEN_ONLINE:    [in]: lpwwn        [out]: vf_id, ppwwn. lpwwn, roles
- * BFA_LPORT_AEN_OFFLINE:   [in]: lpwwn        [out]: vf_id, ppwwn. lpwwn, roles
- * BFA_LPORT_AEN_DISCONNECT:[in]: lpwwn        [out]: vf_id, ppwwn. lpwwn, roles
- * BFA_LPORT_AEN_NEW_PROP:  [in]: None         [out]: vf_id, ppwwn. lpwwn, roles
- * BFA_LPORT_AEN_DELETE_PROP:     [in]: lpwwn  [out]: vf_id, ppwwn. lpwwn, roles
- * BFA_LPORT_AEN_NEW_STANDARD:    [in]: None   [out]: vf_id, ppwwn. lpwwn, roles
- * BFA_LPORT_AEN_DELETE_STANDARD: [in]: lpwwn  [out]: vf_id, ppwwn. lpwwn, roles
- * BFA_LPORT_AEN_NPIV_DUP_WWN:    [in]: lpwwn  [out]: vf_id, ppwwn. lpwwn, roles
- * BFA_LPORT_AEN_NPIV_FABRIC_MAX: [in]: lpwwn  [out]: vf_id, ppwwn. lpwwn, roles
- * BFA_LPORT_AEN_NPIV_UNKNOWN:    [in]: lpwwn  [out]: vf_id, ppwwn. lpwwn, roles
- */
-enum bfa_lport_aen_event {
-       BFA_LPORT_AEN_NEW       = 1,    /*  LPort created event */
-       BFA_LPORT_AEN_DELETE    = 2,    /*  LPort deleted event */
-       BFA_LPORT_AEN_ONLINE    = 3,    /*  LPort online event */
-       BFA_LPORT_AEN_OFFLINE   = 4,    /*  LPort offline event */
-       BFA_LPORT_AEN_DISCONNECT = 5,   /*  LPort disconnect event */
-       BFA_LPORT_AEN_NEW_PROP  = 6,    /*  VPort created event */
-       BFA_LPORT_AEN_DELETE_PROP = 7,  /*  VPort deleted event */
-       BFA_LPORT_AEN_NEW_STANDARD = 8, /*  VPort created event */
-       BFA_LPORT_AEN_DELETE_STANDARD = 9,  /*  VPort deleted event */
-       BFA_LPORT_AEN_NPIV_DUP_WWN = 10,    /*  VPort configured with
-                                            *   duplicate WWN event
-                                                */
-       BFA_LPORT_AEN_NPIV_FABRIC_MAX = 11, /*  Max NPIV in fabric/fport */
-       BFA_LPORT_AEN_NPIV_UNKNOWN = 12, /*  Unknown NPIV Error code event */
-};
-
-/**
- * BFA AEN event data structure
- */
-struct bfa_lport_aen_data_s {
-       u16        vf_id;       /*  vf_id of this logical port */
-       s16         roles;  /*  Logical port mode,IM/TM/IP etc */
-       u32        rsvd;
-       wwn_t           ppwwn;  /*  WWN of its physical port */
-       wwn_t           lpwwn;  /*  WWN of this logical port */
-};
-
-#endif /* __BFA_DEFS_LPORT_H__ */
diff --git a/drivers/scsi/bfa/include/defs/bfa_defs_mfg.h b/drivers/scsi/bfa/include/defs/bfa_defs_mfg.h
deleted file mode 100644 (file)
index d22fb79..0000000
+++ /dev/null
@@ -1,144 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-#ifndef __BFA_DEFS_MFG_H__
-#define __BFA_DEFS_MFG_H__
-
-#include <bfa_os_inc.h>
-
-/**
- * Manufacturing block version
- */
-#define BFA_MFG_VERSION                                2
-
-/**
- * Manufacturing block encrypted version
- */
-#define BFA_MFG_ENC_VER                                2
-
-/**
- * Manufacturing block version 1 length
- */
-#define BFA_MFG_VER1_LEN                       128
-
-/**
- * Manufacturing block header length
- */
-#define BFA_MFG_HDR_LEN                                4
-
-/**
- * Checksum size
- */
-#define BFA_MFG_CHKSUM_SIZE                    16
-
-/**
- * Manufacturing block format
- */
-#define BFA_MFG_SERIALNUM_SIZE                 11
-#define BFA_MFG_PARTNUM_SIZE                   14
-#define BFA_MFG_SUPPLIER_ID_SIZE               10
-#define BFA_MFG_SUPPLIER_PARTNUM_SIZE          20
-#define BFA_MFG_SUPPLIER_SERIALNUM_SIZE                20
-#define BFA_MFG_SUPPLIER_REVISION_SIZE         4
-#define STRSZ(_n)      (((_n) + 4) & ~3)
-
-/**
- * Manufacturing card type
- */
-enum {
-       BFA_MFG_TYPE_CB_MAX  = 825,      /*  Crossbow card type max     */
-       BFA_MFG_TYPE_FC8P2   = 825,      /*  8G 2port FC card           */
-       BFA_MFG_TYPE_FC8P1   = 815,      /*  8G 1port FC card           */
-       BFA_MFG_TYPE_FC4P2   = 425,      /*  4G 2port FC card           */
-       BFA_MFG_TYPE_FC4P1   = 415,      /*  4G 1port FC card           */
-       BFA_MFG_TYPE_CNA10P2 = 1020,     /*  10G 2port CNA card */
-       BFA_MFG_TYPE_CNA10P1 = 1010,     /*  10G 1port CNA card */
-       BFA_MFG_TYPE_JAYHAWK = 804,      /*  Jayhawk mezz card */
-       BFA_MFG_TYPE_WANCHESE = 1007,    /*  Wanchese mezz card */
-       BFA_MFG_TYPE_INVALID = 0,        /*  Invalid card type */
-};
-
-#pragma pack(1)
-
-/**
- * Card type to port number conversion
- */
-#define bfa_mfg_type2port_num(card_type) (((card_type) / 10) % 10)
-
-/**
- * Check if Mezz card
- */
-#define bfa_mfg_is_mezz(type) (( \
-       (type) == BFA_MFG_TYPE_JAYHAWK || \
-       (type) == BFA_MFG_TYPE_WANCHESE))
-
-/**
- * Check if card type valid
- */
-#define bfa_mfg_is_card_type_valid(type) (( \
-       (type) == BFA_MFG_TYPE_FC8P2 || \
-       (type) == BFA_MFG_TYPE_FC8P1 || \
-       (type) == BFA_MFG_TYPE_FC4P2 || \
-       (type) == BFA_MFG_TYPE_FC4P1 || \
-       (type) == BFA_MFG_TYPE_CNA10P2 || \
-       (type) == BFA_MFG_TYPE_CNA10P1 || \
-       bfa_mfg_is_mezz(type)))
-
-/**
- * All numerical fields are in big-endian format.
- */
-struct bfa_mfg_block_s {
-};
-
-/**
- * VPD data length
- */
-#define BFA_MFG_VPD_LEN                512
-
-#define BFA_MFG_VPD_PCI_HDR_OFF                137
-#define BFA_MFG_VPD_PCI_VER_MASK       0x07    /*  version mask 3 bits */
-#define BFA_MFG_VPD_PCI_VDR_MASK       0xf8    /*  vendor mask 5 bits */
-
-/**
- * VPD vendor tag
- */
-enum {
-       BFA_MFG_VPD_UNKNOWN     = 0,     /*  vendor unknown             */
-       BFA_MFG_VPD_IBM         = 1,     /*  vendor IBM                 */
-       BFA_MFG_VPD_HP          = 2,     /*  vendor HP                  */
-       BFA_MFG_VPD_DELL        = 3,     /*  vendor DELL                */
-       BFA_MFG_VPD_PCI_IBM     = 0x08,  /*  PCI VPD IBM                */
-       BFA_MFG_VPD_PCI_HP      = 0x10,  /*  PCI VPD HP                 */
-       BFA_MFG_VPD_PCI_DELL    = 0x20,  /*  PCI VPD DELL               */
-       BFA_MFG_VPD_PCI_BRCD    = 0xf8,  /*  PCI VPD Brocade            */
-};
-
-/**
- * All numerical fields are in big-endian format.
- */
-struct bfa_mfg_vpd_s {
-       u8              version;        /*  vpd data version */
-       u8              vpd_sig[3];     /*  characters 'V', 'P', 'D' */
-       u8              chksum;         /*  u8 checksum */
-       u8              vendor;         /*  vendor */
-       u8      len;            /*  vpd data length excluding header */
-       u8      rsv;
-       u8              data[BFA_MFG_VPD_LEN];  /*  vpd data */
-};
-
-#pragma pack()
-
-#endif /* __BFA_DEFS_MFG_H__ */
diff --git a/drivers/scsi/bfa/include/defs/bfa_defs_pci.h b/drivers/scsi/bfa/include/defs/bfa_defs_pci.h
deleted file mode 100644 (file)
index ea7d89b..0000000
+++ /dev/null
@@ -1,48 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_DEFS_PCI_H__
-#define __BFA_DEFS_PCI_H__
-
-/**
- * PCI device and vendor ID information
- */
-enum {
-       BFA_PCI_VENDOR_ID_BROCADE       = 0x1657,
-       BFA_PCI_DEVICE_ID_FC_8G2P       = 0x13,
-       BFA_PCI_DEVICE_ID_FC_8G1P       = 0x17,
-       BFA_PCI_DEVICE_ID_CT            = 0x14,
-       BFA_PCI_DEVICE_ID_CT_FC         = 0x21,
-};
-
-#define bfa_asic_id_ct(devid)                   \
-       ((devid) == BFA_PCI_DEVICE_ID_CT ||     \
-        (devid) == BFA_PCI_DEVICE_ID_CT_FC)
-
-/**
- * PCI sub-system device and vendor ID information
- */
-enum {
-       BFA_PCI_FCOE_SSDEVICE_ID        = 0x14,
-};
-
-/**
- * Maximum number of device address ranges mapped through different BAR(s)
- */
-#define BFA_PCI_ACCESS_RANGES 1
-
-#endif /* __BFA_DEFS_PCI_H__ */
diff --git a/drivers/scsi/bfa/include/defs/bfa_defs_pm.h b/drivers/scsi/bfa/include/defs/bfa_defs_pm.h
deleted file mode 100644 (file)
index e8d6d95..0000000
+++ /dev/null
@@ -1,33 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_DEFS_PM_H__
-#define __BFA_DEFS_PM_H__
-
-#include <bfa_os_inc.h>
-
-/**
- * BFA power management device states
- */
-enum bfa_pm_ds {
-       BFA_PM_DS_D0 = 0,       /*  full power mode */
-       BFA_PM_DS_D1 = 1,       /*  power save state 1 */
-       BFA_PM_DS_D2 = 2,       /*  power save state 2 */
-       BFA_PM_DS_D3 = 3,       /*  power off state */
-};
-
-#endif /* __BFA_DEFS_PM_H__ */
diff --git a/drivers/scsi/bfa/include/defs/bfa_defs_pom.h b/drivers/scsi/bfa/include/defs/bfa_defs_pom.h
deleted file mode 100644 (file)
index d9fa278..0000000
+++ /dev/null
@@ -1,56 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-#ifndef __BFA_DEFS_POM_H__
-#define __BFA_DEFS_POM_H__
-
-#include <bfa_os_inc.h>
-#include <defs/bfa_defs_types.h>
-
-/**
- * POM health status levels for each attributes.
- */
-enum bfa_pom_entry_health {
-       BFA_POM_HEALTH_NOINFO  = 1,     /*  no information */
-       BFA_POM_HEALTH_NORMAL  = 2,     /*  health is normal */
-       BFA_POM_HEALTH_WARNING = 3,     /*  warning level */
-       BFA_POM_HEALTH_ALARM   = 4,     /*  alarming level */
-};
-
-/**
- * Reading of temperature/voltage/current/power
- */
-struct bfa_pom_entry_s {
-       enum bfa_pom_entry_health health;       /*  POM entry health */
-       u32        curr_value;  /*  current value */
-       u32        thr_warn_high;       /*  threshold warning high */
-       u32        thr_warn_low;        /*  threshold warning low */
-       u32        thr_alarm_low;       /*  threshold alaram low */
-       u32        thr_alarm_high;      /*  threshold alarm high */
-};
-
-/**
- * POM attributes
- */
-struct bfa_pom_attr_s {
-       struct bfa_pom_entry_s temperature;     /*  centigrade */
-       struct bfa_pom_entry_s voltage; /*  volts */
-       struct bfa_pom_entry_s curr;    /*  milli amps */
-       struct bfa_pom_entry_s txpower; /*  micro watts */
-       struct bfa_pom_entry_s rxpower; /*  micro watts */
-};
-
-#endif /* __BFA_DEFS_POM_H__ */
diff --git a/drivers/scsi/bfa/include/defs/bfa_defs_port.h b/drivers/scsi/bfa/include/defs/bfa_defs_port.h
deleted file mode 100644 (file)
index ebdf0d1..0000000
+++ /dev/null
@@ -1,248 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_DEFS_PORT_H__
-#define __BFA_DEFS_PORT_H__
-
-#include <bfa_os_inc.h>
-#include <protocol/types.h>
-#include <defs/bfa_defs_pport.h>
-#include <defs/bfa_defs_ioc.h>
-
-#define BFA_FCS_FABRIC_IPADDR_SZ  16
-
-/**
- * symbolic names for base port/virtual port
- */
-#define BFA_SYMNAME_MAXLEN     128     /* vmware/windows uses 128 bytes */
-struct bfa_port_symname_s {
-       char            symname[BFA_SYMNAME_MAXLEN];
-};
-
-/**
-* Roles of FCS port:
- *     - FCP IM and FCP TM roles cannot be enabled together for a FCS port
- *     - Create multiple ports if both IM and TM functions required.
- *     - Atleast one role must be specified.
- */
-enum bfa_port_role {
-       BFA_PORT_ROLE_FCP_IM    = 0x01, /*  FCP initiator role */
-       BFA_PORT_ROLE_FCP_TM    = 0x02, /*  FCP target role */
-       BFA_PORT_ROLE_FCP_IPFC  = 0x04, /*  IP over FC role */
-       BFA_PORT_ROLE_FCP_MAX   = BFA_PORT_ROLE_FCP_IPFC | BFA_PORT_ROLE_FCP_IM
-};
-
-/**
- * FCS port configuration.
- */
-struct bfa_port_cfg_s {
-       wwn_t               pwwn;       /*  port wwn */
-       wwn_t               nwwn;       /*  node wwn */
-       struct bfa_port_symname_s  sym_name;   /*  vm port symbolic name */
-       bfa_boolean_t       preboot_vp;  /* vport created from PBC */
-       enum bfa_port_role     roles;      /*  FCS port roles */
-       u8             tag[16]; /*  opaque tag from application */
-};
-
-/**
- * FCS port states
- */
-enum bfa_port_state {
-       BFA_PORT_UNINIT  = 0,   /*  PORT is not yet initialized */
-       BFA_PORT_FDISC   = 1,   /*  FDISC is in progress */
-       BFA_PORT_ONLINE  = 2,   /*  login to fabric is complete */
-       BFA_PORT_OFFLINE = 3,   /*  No login to fabric */
-};
-
-/**
- * FCS port type. Required for VmWare.
- */
-enum bfa_port_type {
-       BFA_PORT_TYPE_PHYSICAL = 0,
-       BFA_PORT_TYPE_VIRTUAL,
-};
-
-/**
- * FCS port offline reason. Required for VmWare.
- */
-enum bfa_port_offline_reason {
-       BFA_PORT_OFFLINE_UNKNOWN = 0,
-       BFA_PORT_OFFLINE_LINKDOWN,
-       BFA_PORT_OFFLINE_FAB_UNSUPPORTED,       /*  NPIV not supported by the
-                                                *    fabric */
-       BFA_PORT_OFFLINE_FAB_NORESOURCES,
-       BFA_PORT_OFFLINE_FAB_LOGOUT,
-};
-
-/**
- * FCS lport info. Required for VmWare.
- */
-struct bfa_port_info_s {
-       u8         port_type;   /* bfa_port_type_t : physical or
-                                        * virtual */
-       u8         port_state;  /* one of bfa_port_state values */
-       u8         offline_reason;      /* one of bfa_port_offline_reason_t
-                                        * values */
-       wwn_t           port_wwn;
-       wwn_t           node_wwn;
-
-       /*
-        * following 4 feilds are valid for Physical Ports only
-        */
-       u32        max_vports_supp;     /* Max supported vports */
-       u32        num_vports_inuse;    /* Num of in use vports */
-       u32        max_rports_supp;     /* Max supported rports */
-       u32        num_rports_inuse;    /* Num of doscovered rports */
-
-};
-
-/**
- * FCS port statistics
- */
-struct bfa_port_stats_s {
-       u32        ns_plogi_sent;
-       u32        ns_plogi_rsp_err;
-       u32        ns_plogi_acc_err;
-       u32        ns_plogi_accepts;
-       u32        ns_rejects;  /* NS command rejects */
-       u32        ns_plogi_unknown_rsp;
-       u32        ns_plogi_alloc_wait;
-
-       u32        ns_retries;  /* NS command retries */
-       u32        ns_timeouts; /* NS command timeouts */
-
-       u32        ns_rspnid_sent;
-       u32        ns_rspnid_accepts;
-       u32        ns_rspnid_rsp_err;
-       u32        ns_rspnid_rejects;
-       u32        ns_rspnid_alloc_wait;
-
-       u32        ns_rftid_sent;
-       u32        ns_rftid_accepts;
-       u32        ns_rftid_rsp_err;
-       u32        ns_rftid_rejects;
-       u32        ns_rftid_alloc_wait;
-
-       u32     ns_rffid_sent;
-       u32     ns_rffid_accepts;
-       u32     ns_rffid_rsp_err;
-       u32     ns_rffid_rejects;
-       u32     ns_rffid_alloc_wait;
-
-       u32        ns_gidft_sent;
-       u32        ns_gidft_accepts;
-       u32        ns_gidft_rsp_err;
-       u32        ns_gidft_rejects;
-       u32        ns_gidft_unknown_rsp;
-       u32        ns_gidft_alloc_wait;
-
-       /*
-        * Mgmt Server stats
-        */
-       u32        ms_retries;  /* MS command retries */
-       u32        ms_timeouts; /* MS command timeouts */
-       u32        ms_plogi_sent;
-       u32        ms_plogi_rsp_err;
-       u32        ms_plogi_acc_err;
-       u32        ms_plogi_accepts;
-       u32        ms_rejects;  /* MS command rejects */
-       u32        ms_plogi_unknown_rsp;
-       u32        ms_plogi_alloc_wait;
-
-       u32        num_rscn;    /* Num of RSCN received */
-       u32        num_portid_rscn;/* Num portid format RSCN
-                                                               * received */
-
-       u32     uf_recvs;       /* unsolicited recv frames      */
-       u32     uf_recv_drops;  /* dropped received frames      */
-
-       u32     rsvd;           /* padding for 64 bit alignment */
-};
-
-/**
- * BFA port attribute returned in queries
- */
-struct bfa_port_attr_s {
-       enum bfa_port_state state;              /*  port state */
-       u32         pid;                /*  port ID */
-       struct bfa_port_cfg_s   port_cfg;       /*  port configuration */
-       enum bfa_pport_type port_type;  /*  current topology */
-       u32         loopback;   /*  cable is externally looped back */
-       wwn_t           fabric_name; /*  attached switch's nwwn */
-       u8              fabric_ip_addr[BFA_FCS_FABRIC_IPADDR_SZ]; /*  attached
-                                                       * fabric's ip addr */
-       struct mac_s    fpma_mac;       /*  Lport's FPMA Mac address */
-       u16     authfail;               /*  auth failed state */
-};
-
-/**
- * BFA physical port Level events
- * Arguments below are in BFAL context from Mgmt
- * BFA_PORT_AEN_ONLINE:     [in]: pwwn [out]: pwwn
- * BFA_PORT_AEN_OFFLINE:    [in]: pwwn [out]: pwwn
- * BFA_PORT_AEN_RLIR:       [in]: None [out]: pwwn, rlir_data, rlir_len
- * BFA_PORT_AEN_SFP_INSERT: [in]: pwwn [out]: port_id, pwwn
- * BFA_PORT_AEN_SFP_REMOVE: [in]: pwwn [out]: port_id, pwwn
- * BFA_PORT_AEN_SFP_POM:    [in]: pwwn [out]: level, port_id, pwwn
- * BFA_PORT_AEN_ENABLE:     [in]: pwwn [out]: pwwn
- * BFA_PORT_AEN_DISABLE:    [in]: pwwn [out]: pwwn
- * BFA_PORT_AEN_AUTH_ON:    [in]: pwwn [out]: pwwn
- * BFA_PORT_AEN_AUTH_OFF:   [in]: pwwn [out]: pwwn
- * BFA_PORT_AEN_DISCONNECT: [in]: pwwn [out]: pwwn
- * BFA_PORT_AEN_QOS_NEG:    [in]: pwwn [out]: pwwn
- * BFA_PORT_AEN_FABRIC_NAME_CHANGE: [in]: pwwn, [out]: pwwn, fwwn
- *
- */
-enum bfa_port_aen_event {
-       BFA_PORT_AEN_ONLINE     = 1,    /*  Physical Port online event */
-       BFA_PORT_AEN_OFFLINE    = 2,    /*  Physical Port offline event */
-       BFA_PORT_AEN_RLIR       = 3,    /*  RLIR event, not supported */
-       BFA_PORT_AEN_SFP_INSERT = 4,    /*  SFP inserted event */
-       BFA_PORT_AEN_SFP_REMOVE = 5,    /*  SFP removed event */
-       BFA_PORT_AEN_SFP_POM    = 6,    /*  SFP POM event */
-       BFA_PORT_AEN_ENABLE     = 7,    /*  Physical Port enable event */
-       BFA_PORT_AEN_DISABLE    = 8,    /*  Physical Port disable event */
-       BFA_PORT_AEN_AUTH_ON    = 9,    /*  Physical Port auth success event */
-       BFA_PORT_AEN_AUTH_OFF   = 10,   /*  Physical Port auth fail event */
-       BFA_PORT_AEN_DISCONNECT = 11,   /*  Physical Port disconnect event */
-       BFA_PORT_AEN_QOS_NEG    = 12,   /*  Base Port QOS negotiation event */
-       BFA_PORT_AEN_FABRIC_NAME_CHANGE = 13, /*  Fabric Name/WWN change
-                                              * event */
-       BFA_PORT_AEN_SFP_ACCESS_ERROR = 14, /*  SFP read error event */
-       BFA_PORT_AEN_SFP_UNSUPPORT = 15, /*  Unsupported SFP event */
-};
-
-enum bfa_port_aen_sfp_pom {
-       BFA_PORT_AEN_SFP_POM_GREEN = 1, /*  Normal */
-       BFA_PORT_AEN_SFP_POM_AMBER = 2, /*  Warning */
-       BFA_PORT_AEN_SFP_POM_RED   = 3, /*  Critical */
-       BFA_PORT_AEN_SFP_POM_MAX   = BFA_PORT_AEN_SFP_POM_RED
-};
-
-struct bfa_port_aen_data_s {
-       wwn_t           pwwn;         /*  WWN of the physical port */
-       wwn_t           fwwn;         /*  WWN of the fabric port */
-       s32         phy_port_num; /*! For SFP related events */
-       s16         ioc_type;
-       s16         level;        /*  Only transitions will
-                                       * be informed */
-       struct mac_s    mac;          /*  MAC address of the ethernet port,
-                                       * applicable to CNA port only */
-       s16         rsvd;
-};
-
-#endif /* __BFA_DEFS_PORT_H__ */
diff --git a/drivers/scsi/bfa/include/defs/bfa_defs_pport.h b/drivers/scsi/bfa/include/defs/bfa_defs_pport.h
deleted file mode 100644 (file)
index 2de6758..0000000
+++ /dev/null
@@ -1,393 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_DEFS_PPORT_H__
-#define __BFA_DEFS_PPORT_H__
-
-#include <bfa_os_inc.h>
-#include <protocol/fc.h>
-#include <defs/bfa_defs_types.h>
-#include <defs/bfa_defs_qos.h>
-#include <cna/pstats/phyport_defs.h>
-
-/* Modify char* port_stt[] in bfal_port.c if a new state was added */
-enum bfa_pport_states {
-       BFA_PPORT_ST_UNINIT             = 1,
-       BFA_PPORT_ST_ENABLING_QWAIT     = 2,
-       BFA_PPORT_ST_ENABLING           = 3,
-       BFA_PPORT_ST_LINKDOWN           = 4,
-       BFA_PPORT_ST_LINKUP             = 5,
-       BFA_PPORT_ST_DISABLING_QWAIT    = 6,
-       BFA_PPORT_ST_DISABLING          = 7,
-       BFA_PPORT_ST_DISABLED           = 8,
-       BFA_PPORT_ST_STOPPED            = 9,
-       BFA_PPORT_ST_IOCDOWN            = 10,
-       BFA_PPORT_ST_IOCDIS             = 11,
-       BFA_PPORT_ST_FWMISMATCH         = 12,
-       BFA_PPORT_ST_PREBOOT_DISABLED   = 13,
-       BFA_PPORT_ST_MAX_STATE,
-};
-
-/**
- *     Port speed settings. Each specific speed is a bit field. Use multiple
- *      bits to specify speeds to be selected for auto-negotiation.
- */
-enum bfa_pport_speed {
-       BFA_PPORT_SPEED_UNKNOWN = 0,
-       BFA_PPORT_SPEED_1GBPS   = 1,
-       BFA_PPORT_SPEED_2GBPS   = 2,
-       BFA_PPORT_SPEED_4GBPS   = 4,
-       BFA_PPORT_SPEED_8GBPS   = 8,
-       BFA_PPORT_SPEED_10GBPS  = 10,
-       BFA_PPORT_SPEED_AUTO =
-               (BFA_PPORT_SPEED_1GBPS | BFA_PPORT_SPEED_2GBPS |
-                BFA_PPORT_SPEED_4GBPS | BFA_PPORT_SPEED_8GBPS),
-};
-
-/**
- *             Port operational type (in sync with SNIA port type).
- */
-enum bfa_pport_type {
-       BFA_PPORT_TYPE_UNKNOWN = 1,     /*  port type is unknown */
-       BFA_PPORT_TYPE_TRUNKED = 2,     /*  Trunked mode */
-       BFA_PPORT_TYPE_NPORT   = 5,     /*  P2P with switched fabric */
-       BFA_PPORT_TYPE_NLPORT  = 6,     /*  public loop */
-       BFA_PPORT_TYPE_LPORT   = 20,    /*  private loop */
-       BFA_PPORT_TYPE_P2P     = 21,    /*  P2P with no switched fabric */
-       BFA_PPORT_TYPE_VPORT   = 22,    /*  NPIV - virtual port */
-};
-
-/**
- *             Port topology setting. A port's topology and fabric login status
- *             determine its operational type.
- */
-enum bfa_pport_topology {
-       BFA_PPORT_TOPOLOGY_NONE = 0,    /*  No valid topology */
-       BFA_PPORT_TOPOLOGY_P2P  = 1,    /*  P2P only */
-       BFA_PPORT_TOPOLOGY_LOOP = 2,    /*  LOOP topology */
-       BFA_PPORT_TOPOLOGY_AUTO = 3,    /*  auto topology selection */
-};
-
-/**
- *             Physical port loopback types.
- */
-enum bfa_pport_opmode {
-       BFA_PPORT_OPMODE_NORMAL   = 0x00, /*  normal non-loopback mode */
-       BFA_PPORT_OPMODE_LB_INT   = 0x01, /*  internal loop back */
-       BFA_PPORT_OPMODE_LB_SLW   = 0x02, /*  serial link wrapback (serdes) */
-       BFA_PPORT_OPMODE_LB_EXT   = 0x04, /*  external loop back (serdes) */
-       BFA_PPORT_OPMODE_LB_CBL   = 0x08, /*  cabled loop back */
-       BFA_PPORT_OPMODE_LB_NLINT = 0x20, /*  NL_Port internal loopback */
-};
-
-#define BFA_PPORT_OPMODE_LB_HARD(_mode)                        \
-       ((_mode == BFA_PPORT_OPMODE_LB_INT) ||          \
-     (_mode == BFA_PPORT_OPMODE_LB_SLW) ||             \
-     (_mode == BFA_PPORT_OPMODE_LB_EXT))
-
-/**
-               Port State (in sync with SNIA port state).
- */
-enum bfa_pport_snia_state {
-       BFA_PPORT_STATE_UNKNOWN  = 1,   /*  port is not initialized */
-       BFA_PPORT_STATE_ONLINE   = 2,   /*  port is ONLINE */
-       BFA_PPORT_STATE_DISABLED = 3,   /*  port is disabled by user */
-       BFA_PPORT_STATE_BYPASSED = 4,   /*  port is bypassed (in LOOP) */
-       BFA_PPORT_STATE_DIAG     = 5,   /*  port diagnostics is active */
-       BFA_PPORT_STATE_LINKDOWN = 6,   /*  link is down */
-       BFA_PPORT_STATE_LOOPBACK = 8,   /*  port is looped back */
-};
-
-/**
- *             Port link state
- */
-enum bfa_pport_linkstate {
-       BFA_PPORT_LINKUP         = 1,   /*  Physical port/Trunk link up */
-       BFA_PPORT_LINKDOWN       = 2,   /*  Physical port/Trunk link down */
-       BFA_PPORT_TRUNK_LINKDOWN = 3,   /*  Trunk link down (new tmaster) */
-};
-
-/**
- *             Port link state event
- */
-#define bfa_pport_event_t enum bfa_pport_linkstate
-
-/**
- *             Port link state reason code
- */
-enum bfa_pport_linkstate_rsn {
-       BFA_PPORT_LINKSTATE_RSN_NONE            = 0,
-       BFA_PPORT_LINKSTATE_RSN_DISABLED        = 1,
-       BFA_PPORT_LINKSTATE_RSN_RX_NOS          = 2,
-       BFA_PPORT_LINKSTATE_RSN_RX_OLS          = 3,
-       BFA_PPORT_LINKSTATE_RSN_RX_LIP          = 4,
-       BFA_PPORT_LINKSTATE_RSN_RX_LIPF7        = 5,
-       BFA_PPORT_LINKSTATE_RSN_SFP_REMOVED     = 6,
-       BFA_PPORT_LINKSTATE_RSN_PORT_FAULT      = 7,
-       BFA_PPORT_LINKSTATE_RSN_RX_LOS          = 8,
-       BFA_PPORT_LINKSTATE_RSN_LOCAL_FAULT     = 9,
-       BFA_PPORT_LINKSTATE_RSN_REMOTE_FAULT    = 10,
-       BFA_PPORT_LINKSTATE_RSN_TIMEOUT         = 11,
-
-
-
-       /* CEE related reason codes/errors */
-       CEE_LLDP_INFO_AGED_OUT       = 20,
-       CEE_LLDP_SHUTDOWN_TLV_RCVD   = 21,
-       CEE_PEER_NOT_ADVERTISE_DCBX  = 22,
-       CEE_PEER_NOT_ADVERTISE_PG    = 23,
-       CEE_PEER_NOT_ADVERTISE_PFC   = 24,
-       CEE_PEER_NOT_ADVERTISE_FCOE  = 25,
-       CEE_PG_NOT_COMPATIBLE        = 26,
-       CEE_PFC_NOT_COMPATIBLE       = 27,
-       CEE_FCOE_NOT_COMPATIBLE      = 28,
-       CEE_BAD_PG_RCVD              = 29,
-       CEE_BAD_BW_RCVD              = 30,
-       CEE_BAD_PFC_RCVD             = 31,
-       CEE_BAD_FCOE_PRI_RCVD        = 32,
-       CEE_FCOE_PRI_PFC_OFF         = 33,
-       CEE_DUP_CONTROL_TLV_RCVD     = 34,
-       CEE_DUP_FEAT_TLV_RCVD        = 35,
-       CEE_APPLY_NEW_CFG            = 36,      /* reason, not an error */
-       CEE_PROTOCOL_INIT            = 37,  /* reason, not an error */
-       CEE_PHY_LINK_DOWN            = 38,
-       CEE_LLS_FCOE_ABSENT          = 39,
-       CEE_LLS_FCOE_DOWN            = 40
-};
-
-/**
- *      Default Target Rate Limiting Speed.
- */
-#define BFA_PPORT_DEF_TRL_SPEED  BFA_PPORT_SPEED_1GBPS
-
-/**
- *      Physical port configuration
- */
-struct bfa_pport_cfg_s {
-       u8         topology;    /*  bfa_pport_topology          */
-       u8         speed;               /*  enum bfa_pport_speed        */
-       u8         trunked;     /*  trunked or not              */
-       u8         qos_enabled; /*  qos enabled or not          */
-       u8         trunk_ports; /*  bitmap of trunked ports     */
-       u8         cfg_hardalpa;        /*  is hard alpa configured     */
-       u16        maxfrsize;   /*  maximum frame size          */
-       u8         hardalpa;    /*  configured hard alpa        */
-       u8         rx_bbcredit; /*  receive buffer credits      */
-       u8         tx_bbcredit; /*  transmit buffer credits     */
-       u8         ratelimit;   /*  ratelimit enabled or not    */
-       u8         trl_def_speed;       /*  ratelimit default speed     */
-       u8              rsvd[3];
-       u16     path_tov;       /*  device path timeout */
-       u16     q_depth;        /*  SCSI Queue depth            */
-};
-
-/**
- *             Port attribute values.
- */
-struct bfa_pport_attr_s {
-       /*
-        * Static fields
-        */
-       wwn_t           nwwn;           /*  node wwn */
-       wwn_t           pwwn;           /*  port wwn */
-       wwn_t           factorynwwn;    /*  factory node wwn */
-       wwn_t           factorypwwn;    /*  factory port wwn */
-       enum fc_cos     cos_supported;  /*  supported class of services */
-       u32        rsvd;
-       struct fc_symname_s    port_symname;    /*  port symbolic name */
-       enum bfa_pport_speed speed_supported; /*  supported speeds */
-       bfa_boolean_t   pbind_enabled;  /*  Will be set if Persistent binding
-                                        *   enabled. Relevant only in Windows
-                                        */
-
-       /*
-        * Configured values
-        */
-       struct bfa_pport_cfg_s pport_cfg;       /*  pport cfg */
-
-       /*
-        * Dynamic field - info from BFA
-        */
-       enum bfa_pport_states   port_state;     /*  current port state */
-       enum bfa_pport_speed    speed;          /*  current speed */
-       enum bfa_pport_topology         topology;       /*  current topology */
-       bfa_boolean_t           beacon;         /*  current beacon status */
-       bfa_boolean_t           link_e2e_beacon;/*  set if link beacon on */
-       bfa_boolean_t           plog_enabled;   /*  set if portlog is enabled*/
-
-       /*
-        * Dynamic field - info from FCS
-        */
-       u32             pid;            /*  port ID */
-       enum bfa_pport_type     port_type;      /*  current topology */
-       u32             loopback;       /*  external loopback */
-       u32             authfail;       /* auth fail state */
-       u32             rsvd2;          /*  padding for 64 bit */
-};
-
-/**
- *             FC Port statistics.
- */
-struct bfa_pport_fc_stats_s {
-       u64    secs_reset; /* Seconds since stats is reset     */
-       u64    tx_frames;  /* Tx frames                */
-       u64    tx_words;   /* Tx words                 */
-       u64    tx_lip;     /* Tx LIP               */
-       u64    tx_nos;     /* Tx NOS               */
-       u64    tx_ols;     /* Tx OLS               */
-       u64    tx_lr;      /* Tx LR                */
-       u64    tx_lrr;     /* Tx LRR               */
-       u64    rx_frames;  /* Rx frames                */
-       u64    rx_words;   /* Rx words                 */
-       u64    lip_count;  /* Rx LIP                   */
-       u64    nos_count;  /* Rx NOS               */
-       u64    ols_count;  /* Rx OLS               */
-       u64    lr_count;   /* Rx LR                */
-       u64    lrr_count;  /* Rx LRR               */
-       u64    invalid_crcs;   /* Rx CRC err frames            */
-       u64    invalid_crc_gd_eof; /* Rx CRC err good EOF frames   */
-       u64    undersized_frm; /* Rx undersized frames         */
-       u64    oversized_frm;  /* Rx oversized frames          */
-       u64    bad_eof_frm;    /* Rx frames with bad EOF       */
-       u64    error_frames;   /* Errored frames           */
-       u64    dropped_frames; /* Dropped frames           */
-       u64    link_failures;  /* Link Failure (LF) count          */
-       u64    loss_of_syncs;  /* Loss of sync count           */
-       u64    loss_of_signals;/* Loss of signal count         */
-       u64    primseq_errs;   /* Primitive sequence protocol err. */
-       u64    bad_os_count;   /* Invalid ordered sets         */
-       u64    err_enc_out;    /* Encoding err nonframe_8b10b      */
-       u64    err_enc;    /* Encoding err frame_8b10b         */
-};
-
-/**
- *             Eth Port statistics.
- */
-struct bfa_pport_eth_stats_s {
-       u64    secs_reset;   /* Seconds since stats is reset   */
-       u64    frame_64;     /* Frames 64 bytes            */
-       u64    frame_65_127;     /* Frames 65-127 bytes        */
-       u64    frame_128_255;    /* Frames 128-255 bytes       */
-       u64    frame_256_511;    /* Frames 256-511 bytes       */
-       u64    frame_512_1023;   /* Frames 512-1023 bytes          */
-       u64    frame_1024_1518;  /* Frames 1024-1518 bytes         */
-       u64    frame_1519_1522;  /* Frames 1519-1522 bytes         */
-       u64    tx_bytes;     /* Tx bytes               */
-       u64    tx_packets;   /* Tx packets             */
-       u64    tx_mcast_packets; /* Tx multicast packets       */
-       u64    tx_bcast_packets; /* Tx broadcast packets       */
-       u64    tx_control_frame; /* Tx control frame           */
-       u64    tx_drop;      /* Tx drops               */
-       u64    tx_jabber;    /* Tx jabber              */
-       u64    tx_fcs_error;     /* Tx FCS error           */
-       u64    tx_fragments;     /* Tx fragments           */
-       u64    rx_bytes;     /* Rx bytes               */
-       u64    rx_packets;   /* Rx packets             */
-       u64    rx_mcast_packets; /* Rx multicast packets       */
-       u64    rx_bcast_packets; /* Rx broadcast packets       */
-       u64    rx_control_frames; /* Rx control frames         */
-       u64    rx_unknown_opcode; /* Rx unknown opcode         */
-       u64    rx_drop;      /* Rx drops               */
-       u64    rx_jabber;    /* Rx jabber              */
-       u64    rx_fcs_error;     /* Rx FCS errors              */
-       u64    rx_alignment_error; /* Rx alignment errors          */
-       u64    rx_frame_length_error; /* Rx frame len errors       */
-       u64    rx_code_error;    /* Rx code errors             */
-       u64    rx_fragments;     /* Rx fragments           */
-       u64    rx_pause;     /* Rx pause               */
-       u64    rx_zero_pause;    /* Rx zero pause              */
-       u64    tx_pause;     /* Tx pause               */
-       u64    tx_zero_pause;    /* Tx zero pause              */
-       u64    rx_fcoe_pause;    /* Rx FCoE pause              */
-       u64    rx_fcoe_zero_pause; /* Rx FCoE zero pause       */
-       u64    tx_fcoe_pause;    /* Tx FCoE pause              */
-       u64    tx_fcoe_zero_pause; /* Tx FCoE zero pause       */
-};
-
-/**
- *             Port statistics.
- */
-union bfa_pport_stats_u {
-       struct bfa_pport_fc_stats_s     fc;
-       struct bfa_pport_eth_stats_s    eth;
-};
-
-/**
- *              Port FCP mappings.
- */
-struct bfa_pport_fcpmap_s {
-       char            osdevname[256];
-       u32     bus;
-       u32        target;
-       u32        oslun;
-       u32        fcid;
-       wwn_t           nwwn;
-       wwn_t           pwwn;
-       u64        fcplun;
-       char            luid[256];
-};
-
-/**
- *              Port RNI        */
-struct bfa_pport_rnid_s {
-       wwn_t             wwn;
-       u32          unittype;
-       u32          portid;
-       u32          attached_nodes_num;
-       u16          ip_version;
-       u16          udp_port;
-       u8           ipaddr[16];
-       u16          rsvd;
-       u16          topologydiscoveryflags;
-};
-
-struct bfa_fcport_fcf_s {
-       wwn_t           name;           /* FCF name                 */
-       wwn_t           fabric_name;    /* Fabric Name              */
-       u8              fipenabled;     /* FIP enabled or not       */
-       u8              fipfailed;      /* FIP failed or not        */
-       u8              resv[2];
-       u8              pri;            /* FCF priority             */
-       u8              version;        /* FIP version used         */
-       u8              available;      /* Available  for  login    */
-       u8              fka_disabled;   /* FKA is disabled          */
-       u8              maxsz_verified; /* FCoE max size verified   */
-       u8              fc_map[3];      /* FC map                   */
-       u16             vlan;           /* FCoE vlan tag/priority   */
-       u32             fka_adv_per;    /* FIP  ka advert. period   */
-       struct mac_s    mac;            /* FCF mac                  */
-};
-
-/**
- *             Link state information
- */
-struct bfa_pport_link_s {
-       u8         linkstate;   /*  Link state bfa_pport_linkstate */
-       u8         linkstate_rsn;       /*  bfa_pport_linkstate_rsn_t */
-       u8         topology;    /*  P2P/LOOP bfa_pport_topology */
-       u8         speed;               /*  Link speed (1/2/4/8 G) */
-       u32        linkstate_opt;       /*  Linkstate optional data (debug) */
-       u8         trunked;     /*  Trunked or not (1 or 0) */
-       u8         resvd[3];
-       struct bfa_qos_attr_s  qos_attr;   /* QoS Attributes */
-       union {
-               struct bfa_qos_vc_attr_s qos_vc_attr;  /* VC info from ELP */
-               struct bfa_fcport_fcf_s fcf;    /* FCF information (for FCoE) */
-       } vc_fcf;
-};
-
-#endif /* __BFA_DEFS_PPORT_H__ */
diff --git a/drivers/scsi/bfa/include/defs/bfa_defs_qos.h b/drivers/scsi/bfa/include/defs/bfa_defs_qos.h
deleted file mode 100644 (file)
index aadbacd..0000000
+++ /dev/null
@@ -1,99 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_DEFS_QOS_H__
-#define __BFA_DEFS_QOS_H__
-
-/**
- * QoS states
- */
-enum bfa_qos_state {
-       BFA_QOS_ONLINE = 1,             /*  QoS is online */
-       BFA_QOS_OFFLINE = 2,            /*  QoS is offline */
-};
-
-
-/**
- * QoS  Priority levels.
- */
-enum bfa_qos_priority {
-       BFA_QOS_UNKNOWN = 0,
-       BFA_QOS_HIGH  = 1,      /*  QoS Priority Level High */
-       BFA_QOS_MED  =  2,      /*  QoS Priority Level Medium */
-       BFA_QOS_LOW  =  3,      /*  QoS Priority Level Low */
-};
-
-
-/**
- * QoS  bandwidth allocation for each priority level
- */
-enum bfa_qos_bw_alloc {
-       BFA_QOS_BW_HIGH  = 60,  /*  bandwidth allocation for High */
-       BFA_QOS_BW_MED  =  30,  /*  bandwidth allocation for Medium */
-       BFA_QOS_BW_LOW  =  10,  /*  bandwidth allocation for Low */
-};
-
-/**
- * QoS attribute returned in QoS Query
- */
-struct bfa_qos_attr_s {
-       enum bfa_qos_state state;               /*  QoS current state */
-       u32  total_bb_cr;               /*  Total BB Credits */
-};
-
-/**
- * These fields should be displayed only from the CLI.
- * There will be a separate BFAL API (get_qos_vc_attr ?)
- * to retrieve this.
- *
- */
-#define  BFA_QOS_MAX_VC  16
-
-struct bfa_qos_vc_info_s {
-       u8 vc_credit;
-       u8 borrow_credit;
-       u8 priority;
-       u8 resvd;
-};
-
-struct bfa_qos_vc_attr_s {
-       u16  total_vc_count;                    /*  Total VC Count */
-       u16  shared_credit;
-       u32  elp_opmode_flags;
-       struct bfa_qos_vc_info_s vc_info[BFA_QOS_MAX_VC];  /*   as many as
-                                                           * total_vc_count */
-};
-
-/**
- * QoS statistics
- */
-struct bfa_qos_stats_s {
-       u32     flogi_sent;             /*  QoS Flogi sent */
-       u32     flogi_acc_recvd;        /*  QoS Flogi Acc received */
-       u32     flogi_rjt_recvd; /*  QoS Flogi rejects received */
-       u32     flogi_retries;          /*  QoS Flogi retries */
-
-       u32     elp_recvd;              /*  QoS ELP received */
-       u32     elp_accepted;       /*  QoS ELP Accepted */
-       u32     elp_rejected;       /*  QoS ELP rejected */
-       u32     elp_dropped;        /*  QoS ELP dropped  */
-
-       u32     qos_rscn_recvd;     /*  QoS RSCN received */
-       u32     rsvd;           /* padding for 64 bit alignment */
-};
-
-#endif /* __BFA_DEFS_QOS_H__ */
diff --git a/drivers/scsi/bfa/include/defs/bfa_defs_rport.h b/drivers/scsi/bfa/include/defs/bfa_defs_rport.h
deleted file mode 100644 (file)
index e0af59d..0000000
+++ /dev/null
@@ -1,199 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_DEFS_RPORT_H__
-#define __BFA_DEFS_RPORT_H__
-
-#include <bfa_os_inc.h>
-#include <protocol/types.h>
-#include <defs/bfa_defs_pport.h>
-#include <defs/bfa_defs_port.h>
-#include <defs/bfa_defs_qos.h>
-
-/**
- * FCS remote port states
- */
-enum bfa_rport_state {
-       BFA_RPORT_UNINIT        = 0,    /*  PORT is not yet initialized */
-       BFA_RPORT_OFFLINE       = 1,    /*  rport is offline */
-       BFA_RPORT_PLOGI         = 2,    /*  PLOGI to rport is in progress */
-       BFA_RPORT_ONLINE        = 3,    /*  login to rport is complete */
-       BFA_RPORT_PLOGI_RETRY   = 4,    /*  retrying login to rport */
-       BFA_RPORT_NSQUERY       = 5,    /*  nameserver query */
-       BFA_RPORT_ADISC         = 6,    /*  ADISC authentication */
-       BFA_RPORT_LOGO          = 7,    /*  logging out with rport */
-       BFA_RPORT_LOGORCV       = 8,    /*  handling LOGO from rport */
-       BFA_RPORT_NSDISC        = 9,    /*  re-discover rport */
-};
-
-/**
- *  Rport Scsi Function : Initiator/Target.
- */
-enum bfa_rport_function {
-       BFA_RPORT_INITIATOR     = 0x01, /*  SCSI Initiator      */
-       BFA_RPORT_TARGET        = 0x02, /*  SCSI Target */
-};
-
-/**
- * port/node symbolic names for rport
- */
-#define BFA_RPORT_SYMNAME_MAXLEN       255
-struct bfa_rport_symname_s {
-       char            symname[BFA_RPORT_SYMNAME_MAXLEN];
-};
-
-struct bfa_rport_hal_stats_s {
-       u32        sm_un_cr;        /*  uninit: create events      */
-       u32        sm_un_unexp;     /*  uninit: exception events   */
-       u32        sm_cr_on;        /*  created: online events     */
-       u32        sm_cr_del;       /*  created: delete events     */
-       u32        sm_cr_hwf;       /*  created: IOC down          */
-       u32        sm_cr_unexp;     /*  created: exception events  */
-       u32        sm_fwc_rsp;      /*  fw create: f/w responses   */
-       u32        sm_fwc_del;      /*  fw create: delete events   */
-       u32        sm_fwc_off;      /*  fw create: offline events  */
-       u32        sm_fwc_hwf;      /*  fw create: IOC down        */
-       u32        sm_fwc_unexp;            /*  fw create: exception events*/
-       u32        sm_on_off;       /*  online: offline events     */
-       u32        sm_on_del;       /*  online: delete events      */
-       u32        sm_on_hwf;       /*  online: IOC down events    */
-       u32        sm_on_unexp;     /*  online: exception events   */
-       u32        sm_fwd_rsp;      /*  fw delete: fw responses    */
-       u32        sm_fwd_del;      /*  fw delete: delete events   */
-       u32        sm_fwd_hwf;      /*  fw delete: IOC down events */
-       u32        sm_fwd_unexp;            /*  fw delete: exception events*/
-       u32        sm_off_del;      /*  offline: delete events     */
-       u32        sm_off_on;       /*  offline: online events     */
-       u32        sm_off_hwf;      /*  offline: IOC down events   */
-       u32        sm_off_unexp;            /*  offline: exception events  */
-       u32        sm_del_fwrsp;            /*  delete: fw responses       */
-       u32        sm_del_hwf;      /*  delete: IOC down events    */
-       u32        sm_del_unexp;            /*  delete: exception events   */
-       u32        sm_delp_fwrsp;           /*  delete pend: fw responses  */
-       u32        sm_delp_hwf;     /*  delete pend: IOC downs     */
-       u32        sm_delp_unexp;           /*  delete pend: exceptions    */
-       u32        sm_offp_fwrsp;           /*  off-pending: fw responses  */
-       u32        sm_offp_del;     /*  off-pending: deletes       */
-       u32        sm_offp_hwf;     /*  off-pending: IOC downs     */
-       u32        sm_offp_unexp;           /*  off-pending: exceptions    */
-       u32        sm_iocd_off;     /*  IOC down: offline events   */
-       u32        sm_iocd_del;     /*  IOC down: delete events    */
-       u32        sm_iocd_on;      /*  IOC down: online events    */
-       u32        sm_iocd_unexp;           /*  IOC down: exceptions       */
-       u32        rsvd;
-};
-
-/**
- * FCS remote port statistics
- */
-struct bfa_rport_stats_s {
-       u32        offlines;           /*  remote port offline count  */
-       u32        onlines;            /*  remote port online count   */
-       u32        rscns;              /*  RSCN affecting rport       */
-       u32        plogis;                  /*  plogis sent                */
-       u32        plogi_accs;      /*  plogi accepts              */
-       u32        plogi_timeouts;          /*  plogi timeouts             */
-       u32        plogi_rejects;           /*  rcvd plogi rejects         */
-       u32        plogi_failed;            /*  local failure              */
-       u32        plogi_rcvd;      /*  plogis rcvd                */
-       u32        prli_rcvd;          /*  inbound PRLIs              */
-       u32        adisc_rcvd;         /*  ADISCs received            */
-       u32        adisc_rejects;      /*  recvd  ADISC rejects       */
-       u32        adisc_sent;         /*  ADISC requests sent        */
-       u32        adisc_accs;         /*  ADISC accepted by rport    */
-       u32        adisc_failed;       /*  ADISC failed (no response) */
-       u32        adisc_rejected;     /*  ADISC rejected by us    */
-       u32        logos;              /*  logos sent                 */
-       u32        logo_accs;          /*  LOGO accepts from rport    */
-       u32        logo_failed;        /*  LOGO failures              */
-       u32        logo_rejected;      /*  LOGO rejects from rport    */
-       u32        logo_rcvd;          /*  LOGO from remote port      */
-
-       u32        rpsc_rcvd;         /*  RPSC received            */
-       u32        rpsc_rejects;      /*  recvd  RPSC rejects       */
-       u32        rpsc_sent;         /*  RPSC requests sent        */
-       u32        rpsc_accs;         /*  RPSC accepted by rport    */
-       u32        rpsc_failed;       /*  RPSC failed (no response) */
-       u32        rpsc_rejected;     /*  RPSC rejected by us    */
-
-       u32        rsvd;
-       struct bfa_rport_hal_stats_s    hal_stats;  /*  BFA rport stats    */
-};
-
-/**
- *  Rport's QoS attributes
- */
-struct bfa_rport_qos_attr_s {
-       enum bfa_qos_priority qos_priority;  /*  rport's QoS priority   */
-       u32            qos_flow_id;       /*  QoS flow Id        */
-};
-
-/**
- * FCS remote port attributes returned in queries
- */
-struct bfa_rport_attr_s {
-       wwn_t                   nwwn;   /*  node wwn */
-       wwn_t                   pwwn;   /*  port wwn */
-       enum fc_cos cos_supported;      /*  supported class of services */
-       u32             pid;    /*  port ID */
-       u32             df_sz;  /*  Max payload size */
-       enum bfa_rport_state    state;  /*  Rport State machine state */
-       enum fc_cos             fc_cos; /*  FC classes of services */
-       bfa_boolean_t           cisc;   /*  CISC capable device */
-       struct bfa_rport_symname_s symname; /*  Symbolic Name */
-       enum bfa_rport_function scsi_function; /*  Initiator/Target */
-       struct bfa_rport_qos_attr_s qos_attr; /*  qos attributes  */
-       enum bfa_pport_speed curr_speed;   /*  operating speed got from
-                                           * RPSC ELS. UNKNOWN, if RPSC
-                                           * is not supported */
-       bfa_boolean_t   trl_enforced;   /*  TRL enforced ? TRUE/FALSE */
-       enum bfa_pport_speed    assigned_speed; /* Speed assigned by the user.
-                                                * will be used if RPSC is not
-                                                * supported by the rport */
-};
-
-#define bfa_rport_aen_qos_data_t struct bfa_rport_qos_attr_s
-
-/**
- * BFA remote port events
- * Arguments below are in BFAL context from Mgmt
- * BFA_RPORT_AEN_ONLINE:    [in]: lpwwn        [out]: vf_id, lpwwn, rpwwn
- * BFA_RPORT_AEN_OFFLINE:   [in]: lpwwn [out]: vf_id, lpwwn, rpwwn
- * BFA_RPORT_AEN_DISCONNECT:[in]: lpwwn [out]: vf_id, lpwwn, rpwwn
- * BFA_RPORT_AEN_QOS_PRIO:  [in]: lpwwn [out]: vf_id, lpwwn, rpwwn, prio
- * BFA_RPORT_AEN_QOS_FLOWID:[in]: lpwwn [out]: vf_id, lpwwn, rpwwn, flow_id
- */
-enum bfa_rport_aen_event {
-       BFA_RPORT_AEN_ONLINE      = 1,  /*  RPort online event */
-       BFA_RPORT_AEN_OFFLINE     = 2,  /*  RPort offline event */
-       BFA_RPORT_AEN_DISCONNECT  = 3,  /*  RPort disconnect event */
-       BFA_RPORT_AEN_QOS_PRIO    = 4,  /*  QOS priority change event */
-       BFA_RPORT_AEN_QOS_FLOWID  = 5,  /*  QOS flow Id change event */
-};
-
-struct bfa_rport_aen_data_s {
-       u16        vf_id;       /*  vf_id of this logical port */
-       u16        rsvd[3];
-       wwn_t           ppwwn;  /*  WWN of its physical port */
-       wwn_t           lpwwn;  /*  WWN of this logical port */
-       wwn_t           rpwwn;  /*  WWN of this remote port */
-       union {
-               bfa_rport_aen_qos_data_t qos;
-       } priv;
-};
-
-#endif /* __BFA_DEFS_RPORT_H__ */
diff --git a/drivers/scsi/bfa/include/defs/bfa_defs_status.h b/drivers/scsi/bfa/include/defs/bfa_defs_status.h
deleted file mode 100644 (file)
index 6eb4e62..0000000
+++ /dev/null
@@ -1,282 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-#ifndef __BFA_DEFS_STATUS_H__
-#define __BFA_DEFS_STATUS_H__
-
-/**
- * API status return values
- *
- * NOTE: The error msgs are auto generated from the comments. Only singe line
- * comments are supported
- */
-enum bfa_status {
-       BFA_STATUS_OK           = 0,    /*  Success */
-       BFA_STATUS_FAILED       = 1,    /*  Operation failed */
-       BFA_STATUS_EINVAL       = 2,    /*  Invalid params Check input
-                                        * parameters */
-       BFA_STATUS_ENOMEM       = 3,    /*  Out of resources */
-       BFA_STATUS_ENOSYS       = 4,    /*  Function not implemented */
-       BFA_STATUS_ETIMER       = 5,    /*  Timer expired - Retry, if
-                                        * persists, contact support */
-       BFA_STATUS_EPROTOCOL    = 6,    /*  Protocol error */
-       BFA_STATUS_ENOFCPORTS   = 7,    /*  No FC ports resources */
-       BFA_STATUS_NOFLASH      = 8,    /*  Flash not present */
-       BFA_STATUS_BADFLASH     = 9,    /*  Flash is corrupted or bad */
-       BFA_STATUS_SFP_UNSUPP   = 10,   /*  Unsupported SFP - Replace SFP */
-       BFA_STATUS_UNKNOWN_VFID = 11,   /*  VF_ID not found */
-       BFA_STATUS_DATACORRUPTED = 12,  /*  Diag returned data corrupted
-                                        * contact support */
-       BFA_STATUS_DEVBUSY      = 13,   /*  Device busy - Retry operation */
-       BFA_STATUS_ABORTED      = 14,   /*  Operation aborted */
-       BFA_STATUS_NODEV        = 15,   /*  Dev is not present */
-       BFA_STATUS_HDMA_FAILED  = 16,   /*  Host dma failed contact support */
-       BFA_STATUS_FLASH_BAD_LEN = 17,  /*  Flash bad length */
-       BFA_STATUS_UNKNOWN_LWWN = 18,   /*  LPORT PWWN not found */
-       BFA_STATUS_UNKNOWN_RWWN = 19,   /*  RPORT PWWN not found */
-       BFA_STATUS_FCPT_LS_RJT  = 20,   /*  Got LS_RJT for FC Pass
-                                        * through Req */
-       BFA_STATUS_VPORT_EXISTS = 21,   /*  VPORT already exists */
-       BFA_STATUS_VPORT_MAX    = 22,   /*  Reached max VPORT supported
-                                        * limit */
-       BFA_STATUS_UNSUPP_SPEED = 23,   /*  Invalid Speed Check speed
-                                        * setting */
-       BFA_STATUS_INVLD_DFSZ   = 24,   /*  Invalid Max data field size */
-       BFA_STATUS_CNFG_FAILED  = 25,   /*  Setting can not be persisted */
-       BFA_STATUS_CMD_NOTSUPP  = 26,   /*  Command/API not supported */
-       BFA_STATUS_NO_ADAPTER   = 27,   /*  No Brocade Adapter Found */
-       BFA_STATUS_LINKDOWN     = 28,   /*  Link is down - Check or replace
-                                        * SFP/cable */
-       BFA_STATUS_FABRIC_RJT   = 29,   /*  Reject from attached fabric */
-       BFA_STATUS_UNKNOWN_VWWN = 30,   /*  VPORT PWWN not found */
-       BFA_STATUS_NSLOGIN_FAILED = 31, /*  Nameserver login failed */
-       BFA_STATUS_NO_RPORTS    = 32,   /*  No remote ports found */
-       BFA_STATUS_NSQUERY_FAILED = 33, /*  Nameserver query failed */
-       BFA_STATUS_PORT_OFFLINE = 34,   /*  Port is not online */
-       BFA_STATUS_RPORT_OFFLINE = 35,  /*  RPORT is not online */
-       BFA_STATUS_TGTOPEN_FAILED = 36, /*  Remote SCSI target open failed */
-       BFA_STATUS_BAD_LUNS     = 37,   /*  No valid LUNs found */
-       BFA_STATUS_IO_FAILURE   = 38,   /*  SCSI target IO failure */
-       BFA_STATUS_NO_FABRIC    = 39,   /*  No switched fabric present */
-       BFA_STATUS_EBADF        = 40,   /*  Bad file descriptor */
-       BFA_STATUS_EINTR        = 41,   /*  A signal was caught during ioctl */
-       BFA_STATUS_EIO          = 42,   /*  I/O error */
-       BFA_STATUS_ENOTTY       = 43,   /*  Inappropriate I/O control
-                                        * operation */
-       BFA_STATUS_ENXIO        = 44,   /*  No such device or address */
-       BFA_STATUS_EFOPEN       = 45,   /*  Failed to open file */
-       BFA_STATUS_VPORT_WWN_BP = 46,   /*  WWN is same as base port's WWN */
-       BFA_STATUS_PORT_NOT_DISABLED = 47, /*  Port not disabled disable port
-                                           * first */
-       BFA_STATUS_BADFRMHDR    = 48,   /*  Bad frame header */
-       BFA_STATUS_BADFRMSZ     = 49,   /*  Bad frame size check and replace
-                                        * SFP/cable */
-       BFA_STATUS_MISSINGFRM   = 50,   /* Missing frame check and replace
-                                        * SFP/cable or for Mezz card check and
-                                        * replace pass through module */
-       BFA_STATUS_LINKTIMEOUT  = 51,   /*  Link timeout check and replace
-                                        * SFP/cable */
-       BFA_STATUS_NO_FCPIM_NEXUS = 52, /*  No FCP Nexus exists with the
-                                        * rport */
-       BFA_STATUS_CHECKSUM_FAIL = 53,  /*  checksum failure */
-       BFA_STATUS_GZME_FAILED  = 54,   /*  Get zone member query failed */
-       BFA_STATUS_SCSISTART_REQD = 55, /*  SCSI disk require START command */
-       BFA_STATUS_IOC_FAILURE  = 56,   /*  IOC failure - Retry, if persists
-                                        * contact support */
-       BFA_STATUS_INVALID_WWN  = 57,   /*  Invalid WWN */
-       BFA_STATUS_MISMATCH     = 58,   /*  Version mismatch */
-       BFA_STATUS_IOC_ENABLED  = 59,   /*  IOC is already enabled */
-       BFA_STATUS_ADAPTER_ENABLED = 60, /*  Adapter is not disabled disable
-                                         * adapter first */
-       BFA_STATUS_IOC_NON_OP   = 61,   /*  IOC is not operational. Enable IOC
-                                        * and if it still fails,
-                                        * contact support */
-       BFA_STATUS_ADDR_MAP_FAILURE = 62, /*  PCI base address not mapped
-                                          * in OS */
-       BFA_STATUS_SAME_NAME    = 63,   /*  Name exists! use a different
-                                        * name */
-       BFA_STATUS_PENDING      = 64,   /*  API completes asynchronously */
-       BFA_STATUS_8G_SPD       = 65,   /*  Speed setting not valid for
-                                        * 8G HBA */
-       BFA_STATUS_4G_SPD       = 66,   /*  Speed setting not valid for
-                                        * 4G HBA */
-       BFA_STATUS_AD_IS_ENABLE = 67,   /*  Adapter is already enabled */
-       BFA_STATUS_EINVAL_TOV   = 68,   /*  Invalid path failover TOV */
-       BFA_STATUS_EINVAL_QDEPTH = 69,  /*  Invalid queue depth value */
-       BFA_STATUS_VERSION_FAIL = 70,   /*  Application/Driver version
-                                        * mismatch */
-       BFA_STATUS_DIAG_BUSY    = 71,   /*  diag busy */
-       BFA_STATUS_BEACON_ON    = 72,   /*  Port Beacon already on */
-       BFA_STATUS_BEACON_OFF   = 73,   /*  Port Beacon already off */
-       BFA_STATUS_LBEACON_ON   = 74,   /*  Link End-to-End Beacon already
-                                        * on */
-       BFA_STATUS_LBEACON_OFF  = 75,   /*  Link End-to-End Beacon already
-                                        * off */
-       BFA_STATUS_PORT_NOT_INITED = 76, /*  Port not initialized */
-       BFA_STATUS_RPSC_ENABLED = 77, /*  Target has a valid speed */
-       BFA_STATUS_ENOFSAVE = 78,       /*  No saved firmware trace */
-       BFA_STATUS_BAD_FILE = 79,       /*  Not a valid Brocade Boot Code
-                                        * file */
-       BFA_STATUS_RLIM_EN = 80,        /*  Target rate limiting is already
-                                        * enabled */
-       BFA_STATUS_RLIM_DIS = 81,  /*  Target rate limiting is already
-                                   * disabled */
-       BFA_STATUS_IOC_DISABLED = 82,   /*  IOC is already disabled */
-       BFA_STATUS_ADAPTER_DISABLED = 83,   /*  Adapter is already disabled */
-       BFA_STATUS_BIOS_DISABLED = 84,   /*  Bios is already disabled */
-       BFA_STATUS_AUTH_ENABLED = 85,   /*  Authentication is already
-                                        * enabled */
-       BFA_STATUS_AUTH_DISABLED = 86,   /*  Authentication is already
-                                        * disabled */
-       BFA_STATUS_ERROR_TRL_ENABLED = 87,   /*  Target rate limiting is
-                                             * enabled */
-       BFA_STATUS_ERROR_QOS_ENABLED = 88,   /*  QoS is enabled */
-       BFA_STATUS_NO_SFP_DEV = 89, /*  No SFP device check or replace SFP */
-       BFA_STATUS_MEMTEST_FAILED = 90, /*  Memory test failed contact
-                                        * support */
-       BFA_STATUS_INVALID_DEVID = 91,  /*  Invalid device id provided */
-       BFA_STATUS_QOS_ENABLED = 92, /*  QOS is already enabled */
-       BFA_STATUS_QOS_DISABLED = 93, /*  QOS is already disabled */
-       BFA_STATUS_INCORRECT_DRV_CONFIG = 94, /*  Check configuration
-                                              * key/value pair */
-       BFA_STATUS_REG_FAIL = 95, /*  Can't read windows registry */
-       BFA_STATUS_IM_INV_CODE = 96, /*  Invalid IOCTL code */
-       BFA_STATUS_IM_INV_VLAN = 97, /*  Invalid VLAN ID */
-       BFA_STATUS_IM_INV_ADAPT_NAME = 98, /*  Invalid adapter name */
-       BFA_STATUS_IM_LOW_RESOURCES = 99, /*  Memory allocation failure in
-                                          * driver */
-       BFA_STATUS_IM_VLANID_IS_PVID = 100, /*  Given VLAN id same as PVID */
-       BFA_STATUS_IM_VLANID_EXISTS = 101, /*  Given VLAN id already exists */
-       BFA_STATUS_IM_FW_UPDATE_FAIL = 102, /*  Updating firmware with new
-                                            * VLAN ID failed */
-       BFA_STATUS_PORTLOG_ENABLED = 103, /*  Port Log is already enabled */
-       BFA_STATUS_PORTLOG_DISABLED = 104, /*  Port Log is already disabled */
-       BFA_STATUS_FILE_NOT_FOUND = 105, /*  Specified file could not be
-                                         * found */
-       BFA_STATUS_QOS_FC_ONLY = 106, /*  QOS can be enabled for FC mode
-                                      * only */
-       BFA_STATUS_RLIM_FC_ONLY = 107, /*  RATELIM can be enabled for FC mode
-                                       * only */
-       BFA_STATUS_CT_SPD = 108, /*  Invalid speed selection for Catapult. */
-       BFA_STATUS_LEDTEST_OP = 109, /*  LED test is operating */
-       BFA_STATUS_CEE_NOT_DN = 110, /*  eth port is not at down state, please
-                                     * bring down first */
-       BFA_STATUS_10G_SPD = 111, /*  Speed setting not valid for 10G CNA */
-       BFA_STATUS_IM_INV_TEAM_NAME = 112, /*  Invalid team name */
-       BFA_STATUS_IM_DUP_TEAM_NAME = 113, /*  Given team name already
-                                           * exists */
-       BFA_STATUS_IM_ADAPT_ALREADY_IN_TEAM = 114, /*  Given adapter is part
-                                                   * of another team */
-       BFA_STATUS_IM_ADAPT_HAS_VLANS = 115, /*  Adapter has VLANs configured.
-                                             * Delete all VLANs to become
-                                             * part of the team */
-       BFA_STATUS_IM_PVID_MISMATCH = 116, /*  Mismatching PVIDs configured
-                                           * for adapters */
-       BFA_STATUS_IM_LINK_SPEED_MISMATCH = 117, /*  Mismatching link speeds
-                                                 * configured for adapters */
-       BFA_STATUS_IM_MTU_MISMATCH = 118, /*  Mismatching MTUs configured for
-                                          * adapters */
-       BFA_STATUS_IM_RSS_MISMATCH = 119, /*  Mismatching RSS parameters
-                                          * configured for adapters */
-       BFA_STATUS_IM_HDS_MISMATCH = 120, /*  Mismatching HDS parameters
-                                          * configured for adapters */
-       BFA_STATUS_IM_OFFLOAD_MISMATCH = 121, /*  Mismatching offload
-                                              * parameters configured for
-                                              * adapters */
-       BFA_STATUS_IM_PORT_PARAMS = 122, /*  Error setting port parameters */
-       BFA_STATUS_IM_PORT_NOT_IN_TEAM = 123, /*  Port is not part of team */
-       BFA_STATUS_IM_CANNOT_REM_PRI = 124, /*  Primary adapter cannot be
-                                            * removed. Change primary before
-                                            * removing */
-       BFA_STATUS_IM_MAX_PORTS_REACHED = 125, /*  Exceeding maximum ports
-                                               * per team */
-       BFA_STATUS_IM_LAST_PORT_DELETE = 126, /*  Last port in team being
-                                              * deleted */
-       BFA_STATUS_IM_NO_DRIVER = 127, /*  IM driver is not installed */
-       BFA_STATUS_IM_MAX_VLANS_REACHED = 128, /*  Exceeding maximum VLANs
-                                               * per port */
-       BFA_STATUS_TOMCAT_SPD_NOT_ALLOWED = 129, /* Bios speed config not
-                                                 * allowed for CNA */
-       BFA_STATUS_NO_MINPORT_DRIVER = 130, /*  Miniport driver is not
-                                            * loaded */
-       BFA_STATUS_CARD_TYPE_MISMATCH = 131, /*  Card type mismatch */
-       BFA_STATUS_BAD_ASICBLK = 132, /*  Bad ASIC block */
-       BFA_STATUS_NO_DRIVER = 133, /*  Brocade adapter/driver not installed
-                                    *  or loaded */
-       BFA_STATUS_INVALID_MAC = 134, /*  Invalid MAC address */
-       BFA_STATUS_IM_NO_VLAN = 135, /*  No VLANs configured on the adapter */
-       BFA_STATUS_IM_ETH_LB_FAILED = 136, /*  Ethernet loopback test failed */
-       BFA_STATUS_IM_PVID_REMOVE = 137, /* Cannot remove port VLAN (PVID) */
-       BFA_STATUS_IM_PVID_EDIT = 138, /* Cannot edit port VLAN (PVID) */
-       BFA_STATUS_CNA_NO_BOOT = 139, /*  Boot upload not allowed for CNA */
-       BFA_STATUS_IM_PVID_NON_ZERO = 140, /*  Port VLAN ID (PVID) is Set to
-                                           * Non-Zero Value */
-       BFA_STATUS_IM_INETCFG_LOCK_FAILED = 141, /*  Acquiring Network
-                                                 * Subsystem Lock Failed.Please
-                                                 * try after some time */
-       BFA_STATUS_IM_GET_INETCFG_FAILED = 142, /*  Acquiring Network Subsystem
-                                                * handle Failed. Please try
-                                                * after some time */
-       BFA_STATUS_IM_NOT_BOUND = 143, /*  IM driver is not active */
-       BFA_STATUS_INSUFFICIENT_PERMS = 144, /*  User doesn't have sufficient
-                                             * permissions to execute the BCU
-                                             * application */
-       BFA_STATUS_IM_INV_VLAN_NAME = 145, /* Invalid/Reserved VLAN name
-                                           * string. The name is not allowed
-                                           * for the normal VLAN */
-       BFA_STATUS_CMD_NOTSUPP_CNA = 146, /*  Command not supported for CNA */
-       BFA_STATUS_IM_PASSTHRU_EDIT = 147, /* Can not edit passthrough VLAN
-                                           * id */
-       BFA_STATUS_IM_BIND_FAILED = 148, /* IM Driver bind operation
-                                         * failed */
-       BFA_STATUS_IM_UNBIND_FAILED = 149, /* IM Driver unbind operation
-                                           * failed */
-       BFA_STATUS_IM_PORT_IN_TEAM = 150, /*  Port is already part of the
-                                          * team */
-       BFA_STATUS_IM_VLAN_NOT_FOUND = 151, /*  VLAN ID doesn't exists */
-       BFA_STATUS_IM_TEAM_NOT_FOUND = 152, /*  Teaming configuration doesn't
-                                            * exists */
-       BFA_STATUS_IM_TEAM_CFG_NOT_ALLOWED = 153, /*  Given settings are not
-                                               * allowed for the current
-                                               * Teaming mode */
-       BFA_STATUS_PBC = 154, /* Operation not allowed for pre-boot
-                              * configuration */
-       BFA_STATUS_DEVID_MISSING = 155, /* Boot image is not for the adapter(s)
-                                        * installed */
-       BFA_STATUS_BAD_FWCFG = 156, /* Bad firmware configuration */
-       BFA_STATUS_CREATE_FILE = 157, /* Failed to create temporary file */
-       BFA_STATUS_INVALID_VENDOR = 158, /* Invalid switch vendor */
-       BFA_STATUS_SFP_NOT_READY = 159, /* SFP info is not ready. Retry */
-       BFA_STATUS_NO_TOPOLOGY_FOR_CNA = 160, /* Topology command not
-                                              * applicable to CNA */
-       BFA_STATUS_BOOT_CODE_UPDATED = 161, /* reboot -- -r is needed after
-                                            * boot code updated */
-       BFA_STATUS_BOOT_VERSION = 162, /* Boot code version not compatible with
-                                       * the driver installed */
-       BFA_STATUS_CARDTYPE_MISSING = 163, /* Boot image is not for the
-                                           * adapter(s) installed */
-       BFA_STATUS_INVALID_CARDTYPE = 164, /* Invalid card type provided */
-       BFA_STATUS_MAX_VAL              /* Unknown error code */
-};
-#define bfa_status_t enum bfa_status
-
-enum bfa_eproto_status {
-       BFA_EPROTO_BAD_ACCEPT = 0,
-       BFA_EPROTO_UNKNOWN_RSP = 1
-};
-#define bfa_eproto_status_t enum bfa_eproto_status
-
-#endif /* __BFA_DEFS_STATUS_H__ */
diff --git a/drivers/scsi/bfa/include/defs/bfa_defs_tin.h b/drivers/scsi/bfa/include/defs/bfa_defs_tin.h
deleted file mode 100644 (file)
index e05a2db..0000000
+++ /dev/null
@@ -1,118 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_DEFS_TIN_H__
-#define __BFA_DEFS_TIN_H__
-
-#include <protocol/types.h>
-#include <protocol/fc.h>
-
-/**
- * FCS tin states
- */
-enum bfa_tin_state_e {
-       BFA_TIN_SM_OFFLINE = 0,         /*  tin is offline */
-       BFA_TIN_SM_WOS_LOGIN = 1,       /*  Waiting PRLI ACC/RJT from ULP */
-       BFA_TIN_SM_WFW_ONLINE = 2,      /*  Waiting ACK to PRLI ACC from FW */
-       BFA_TIN_SM_ONLINE = 3,          /*  tin login is complete */
-       BFA_TIN_SM_WIO_RELOGIN = 4,     /*  tin relogin is in progress */
-       BFA_TIN_SM_WIO_LOGOUT = 5,      /*  Processing of PRLO req from
-                                        *   Initiator is in progress
-                                        */
-       BFA_TIN_SM_WOS_LOGOUT = 6,      /*  Processing of PRLO req from
-                                        *   Initiator is in progress
-                                        */
-       BFA_TIN_SM_WIO_CLEAN = 7,       /*  Waiting for IO cleanup before tin
-                                        *   is offline. This can be triggered
-                                        *   by RPORT LOGO (rcvd/sent) or by
-                                        *   PRLO (rcvd/sent)
-                                        */
-};
-
-struct bfa_prli_req_s {
-       struct fchs_s fchs;
-       struct fc_prli_s prli_payload;
-};
-
-struct bfa_prlo_req_s {
-       struct fchs_s fchs;
-       struct fc_prlo_s prlo_payload;
-};
-
-void bfa_tin_send_login_rsp(void *bfa_tin, u32 login_rsp,
-                               struct fc_ls_rjt_s rjt_payload);
-void bfa_tin_send_logout_rsp(void *bfa_tin, u32 logout_rsp,
-                               struct fc_ls_rjt_s rjt_payload);
-/**
- * FCS target port statistics
- */
-struct bfa_tin_stats_s {
-       u32 onlines;    /*  ITN nexus onlines (PRLI done) */
-       u32 offlines;   /*  ITN Nexus offlines  */
-       u32 prli_req_parse_err; /*  prli req parsing errors */
-       u32 prli_rsp_rjt;       /*  num prli rsp rejects sent */
-       u32 prli_rsp_acc;       /*  num prli rsp accepts sent */
-       u32 cleanup_comps;      /*  ITN cleanup completions */
-};
-
-/**
- * FCS tin attributes returned in queries
- */
-struct bfa_tin_attr_s {
-       enum bfa_tin_state_e state;
-       u8      seq_retry;    /*  Sequence retry supported      */
-       u8      rsvd[3];
-};
-
-/**
- * BFA TIN async event data structure for BFAL
- */
-enum bfa_tin_aen_event {
-       BFA_TIN_AEN_ONLINE      = 1,    /*  Target online */
-       BFA_TIN_AEN_OFFLINE     = 2,    /*  Target offline */
-       BFA_TIN_AEN_DISCONNECT  = 3,    /*  Target disconnected */
-};
-
-/**
- * BFA TIN event data structure.
- */
-struct bfa_tin_aen_data_s {
-       u16 vf_id;      /*  vf_id of the IT nexus */
-       u16 rsvd[3];
-       wwn_t lpwwn;    /*  WWN of logical port */
-       wwn_t rpwwn;    /*  WWN of remote(target) port */
-};
-
-/**
- * Below APIs are needed from BFA driver
- * Move these to BFA driver public header file?
- */
-/*  TIN rcvd new PRLI & gets bfad_tin_t ptr from driver this callback */
-void *bfad_tin_rcvd_login_req(void *bfad_tm_port, void *bfa_tin,
-                               wwn_t rp_wwn, u32 rp_fcid,
-                               struct bfa_prli_req_s prli_req);
-/*  TIN rcvd new PRLO */
-void bfad_tin_rcvd_logout_req(void *bfad_tin, wwn_t rp_wwn, u32 rp_fcid,
-                               struct bfa_prlo_req_s prlo_req);
-/*  TIN is online and ready for IO */
-void bfad_tin_online(void *bfad_tin);
-/*  TIN is offline and BFA driver can shutdown its upper stack */
-void bfad_tin_offline(void *bfad_tin);
-/*  TIN does not need this BFA driver tin tag anymore, so can be freed */
-void bfad_tin_res_free(void *bfad_tin);
-
-#endif /* __BFA_DEFS_TIN_H__ */
diff --git a/drivers/scsi/bfa/include/defs/bfa_defs_tsensor.h b/drivers/scsi/bfa/include/defs/bfa_defs_tsensor.h
deleted file mode 100644 (file)
index ade763d..0000000
+++ /dev/null
@@ -1,43 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_DEFS_TSENSOR_H__
-#define __BFA_DEFS_TSENSOR_H__
-
-#include <bfa_os_inc.h>
-#include <defs/bfa_defs_types.h>
-
-/**
- * Temperature sensor status values
- */
-enum bfa_tsensor_status {
-       BFA_TSENSOR_STATUS_UNKNOWN   = 1,   /*  unknown status */
-       BFA_TSENSOR_STATUS_FAULTY    = 2,   /*  sensor is faulty */
-       BFA_TSENSOR_STATUS_BELOW_MIN = 3,   /*  temperature below mininum */
-       BFA_TSENSOR_STATUS_NOMINAL   = 4,   /*  normal temperature */
-       BFA_TSENSOR_STATUS_ABOVE_MAX = 5,   /*  temperature above maximum */
-};
-
-/**
- * Temperature sensor attribute
- */
-struct bfa_tsensor_attr_s {
-       enum bfa_tsensor_status status; /*  temperature sensor status */
-       u32             value;  /*  current temperature in celsius */
-};
-
-#endif /* __BFA_DEFS_TSENSOR_H__ */
diff --git a/drivers/scsi/bfa/include/defs/bfa_defs_types.h b/drivers/scsi/bfa/include/defs/bfa_defs_types.h
deleted file mode 100644 (file)
index 4348332..0000000
+++ /dev/null
@@ -1,30 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-#ifndef __BFA_DEFS_TYPES_H__
-#define __BFA_DEFS_TYPES_H__
-
-#include <bfa_os_inc.h>
-
-enum bfa_boolean {
-       BFA_FALSE = 0,
-       BFA_TRUE  = 1
-};
-#define bfa_boolean_t enum bfa_boolean
-
-#define BFA_STRING_32  32
-
-#endif /* __BFA_DEFS_TYPES_H__ */
diff --git a/drivers/scsi/bfa/include/defs/bfa_defs_version.h b/drivers/scsi/bfa/include/defs/bfa_defs_version.h
deleted file mode 100644 (file)
index f8902a2..0000000
+++ /dev/null
@@ -1,22 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-#ifndef __BFA_DEFS_VERSION_H__
-#define __BFA_DEFS_VERSION_H__
-
-#define BFA_VERSION_LEN                64
-
-#endif
diff --git a/drivers/scsi/bfa/include/defs/bfa_defs_vf.h b/drivers/scsi/bfa/include/defs/bfa_defs_vf.h
deleted file mode 100644 (file)
index 3235be5..0000000
+++ /dev/null
@@ -1,74 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_DEFS_VF_H__
-#define __BFA_DEFS_VF_H__
-
-#include <bfa_os_inc.h>
-#include <defs/bfa_defs_port.h>
-#include <protocol/types.h>
-
-/**
- * VF states
- */
-enum bfa_vf_state {
-       BFA_VF_UNINIT    = 0,   /*  fabric is not yet initialized */
-       BFA_VF_LINK_DOWN = 1,   /*  link is down */
-       BFA_VF_FLOGI     = 2,   /*  flogi is in progress */
-       BFA_VF_AUTH      = 3,   /*  authentication in progress */
-       BFA_VF_NOFABRIC  = 4,   /*  fabric is not present */
-       BFA_VF_ONLINE    = 5,   /*  login to fabric is complete */
-       BFA_VF_EVFP      = 6,   /*  EVFP is in progress */
-       BFA_VF_ISOLATED  = 7,   /*  port isolated due to vf_id mismatch */
-};
-
-/**
- * VF statistics
- */
-struct bfa_vf_stats_s {
-       u32        flogi_sent;  /*  Num FLOGIs sent             */
-       u32        flogi_rsp_err;       /*  FLOGI response errors       */
-       u32        flogi_acc_err;       /*  FLOGI accept errors         */
-       u32        flogi_accepts;       /*  FLOGI accepts received      */
-       u32        flogi_rejects;       /*  FLOGI rejects received      */
-       u32        flogi_unknown_rsp; /*  Unknown responses for FLOGI */
-       u32        flogi_alloc_wait; /*  Allocation waits prior to
-                                          * sending FLOGI
-                                          */
-       u32        flogi_rcvd;  /*  FLOGIs received */
-       u32        flogi_rejected;      /*  Incoming FLOGIs rejected */
-       u32        fabric_onlines;      /*  Internal fabric online
-                                        * notification sent to other
-                                        * modules
-                                        */
-       u32        fabric_offlines; /*  Internal fabric offline
-                                         * notification sent to other
-                                         * modules
-                                         */
-       u32        resvd;
-};
-
-/**
- * VF attributes returned in queries
- */
-struct bfa_vf_attr_s {
-       enum bfa_vf_state  state;               /*  VF state */
-       u32        rsvd;
-       wwn_t           fabric_name;    /*  fabric name */
-};
-
-#endif /* __BFA_DEFS_VF_H__ */
diff --git a/drivers/scsi/bfa/include/defs/bfa_defs_vport.h b/drivers/scsi/bfa/include/defs/bfa_defs_vport.h
deleted file mode 100644 (file)
index 9f021f4..0000000
+++ /dev/null
@@ -1,91 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_DEFS_VPORT_H__
-#define __BFA_DEFS_VPORT_H__
-
-#include <bfa_os_inc.h>
-#include <defs/bfa_defs_port.h>
-#include <protocol/types.h>
-
-/**
- * VPORT states
- */
-enum bfa_vport_state {
-       BFA_FCS_VPORT_UNINIT            = 0,
-       BFA_FCS_VPORT_CREATED           = 1,
-       BFA_FCS_VPORT_OFFLINE           = 1,
-       BFA_FCS_VPORT_FDISC_SEND        = 2,
-       BFA_FCS_VPORT_FDISC             = 3,
-       BFA_FCS_VPORT_FDISC_RETRY       = 4,
-       BFA_FCS_VPORT_ONLINE            = 5,
-       BFA_FCS_VPORT_DELETING          = 6,
-       BFA_FCS_VPORT_CLEANUP           = 6,
-       BFA_FCS_VPORT_LOGO_SEND         = 7,
-       BFA_FCS_VPORT_LOGO                      = 8,
-       BFA_FCS_VPORT_ERROR                     = 9,
-       BFA_FCS_VPORT_MAX_STATE,
-};
-
-/**
- * vport statistics
- */
-struct bfa_vport_stats_s {
-       struct bfa_port_stats_s port_stats;     /*  base class (port) stats */
-       /*
-        * TODO - remove
-        */
-
-       u32        fdisc_sent;  /*  num fdisc sent */
-       u32        fdisc_accepts;       /*  fdisc accepts */
-       u32        fdisc_retries;       /*  fdisc retries */
-       u32        fdisc_timeouts;      /*  fdisc timeouts */
-       u32        fdisc_rsp_err;       /*  fdisc response error */
-       u32        fdisc_acc_bad;       /*  bad fdisc accepts */
-       u32        fdisc_rejects;       /*  fdisc rejects */
-       u32        fdisc_unknown_rsp;
-       /*
-        *!< fdisc rsp unknown error
-        */
-       u32        fdisc_alloc_wait;/*  fdisc req (fcxp)alloc wait */
-
-       u32        logo_alloc_wait;/*  logo req (fcxp) alloc wait */
-       u32        logo_sent;   /*  logo sent */
-       u32        logo_accepts;        /*  logo accepts */
-       u32        logo_rejects;        /*  logo rejects */
-       u32        logo_rsp_err;        /*  logo rsp errors */
-       u32        logo_unknown_rsp;
-                       /*  logo rsp unknown errors */
-
-       u32        fab_no_npiv; /*  fabric does not support npiv */
-
-       u32        fab_offline; /*  offline events from fab SM */
-       u32        fab_online;  /*  online events from fab SM */
-       u32        fab_cleanup; /*  cleanup request from fab SM */
-       u32        rsvd;
-};
-
-/**
- * BFA vport attribute returned in queries
- */
-struct bfa_vport_attr_s {
-       struct bfa_port_attr_s   port_attr; /*  base class (port) attributes */
-       enum bfa_vport_state vport_state; /*  vport state */
-       u32          rsvd;
-};
-
-#endif /* __BFA_DEFS_VPORT_H__ */
diff --git a/drivers/scsi/bfa/include/fcb/bfa_fcb.h b/drivers/scsi/bfa/include/fcb/bfa_fcb.h
deleted file mode 100644 (file)
index 2963b0b..0000000
+++ /dev/null
@@ -1,33 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  bfa_fcb.h BFA FCS callback interfaces
- */
-
-#ifndef __BFA_FCB_H__
-#define __BFA_FCB_H__
-
-/**
- *  fcb Main fcs callbacks
- */
-
-void bfa_fcb_exit(struct bfad_s *bfad);
-
-
-
-#endif /* __BFA_FCB_H__ */
diff --git a/drivers/scsi/bfa/include/fcb/bfa_fcb_fcpim.h b/drivers/scsi/bfa/include/fcb/bfa_fcb_fcpim.h
deleted file mode 100644 (file)
index 52585d3..0000000
+++ /dev/null
@@ -1,75 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
-* : bfad_fcpim.h - BFA FCS initiator mode remote port callbacks
- */
-
-#ifndef __BFAD_FCB_FCPIM_H__
-#define __BFAD_FCB_FCPIM_H__
-
-struct bfad_itnim_s;
-
-/*
- * RPIM callbacks
- */
-
-/**
- *     Memory allocation for remote port instance. Called before PRLI is
- *     initiated to the remote target port.
- *
- * @param[in] bfad             - driver instance
- * @param[out] itnim           - FCS remote port (IM) instance
- * @param[out] itnim_drv       - driver remote port (IM) instance
- *
- * @return None
- */
-void bfa_fcb_itnim_alloc(struct bfad_s *bfad, struct bfa_fcs_itnim_s **itnim,
-                                   struct bfad_itnim_s **itnim_drv);
-
-/**
- *             Free remote port (IM) instance.
- *
- * @param[in] bfad     - driver instance
- * @param[in] itnim_drv        - driver remote port instance
- *
- * @return None
- */
-void            bfa_fcb_itnim_free(struct bfad_s *bfad,
-                                  struct bfad_itnim_s *itnim_drv);
-
-/**
- *     Notification of when login with a remote target device is complete.
- *
- * @param[in] itnim_drv        - driver remote port instance
- *
- * @return None
- */
-void            bfa_fcb_itnim_online(struct bfad_itnim_s *itnim_drv);
-
-/**
- *     Notification when login with the remote device is severed.
- *
- * @param[in] itnim_drv        - driver remote port instance
- *
- * @return None
- */
-void            bfa_fcb_itnim_offline(struct bfad_itnim_s *itnim_drv);
-
-void            bfa_fcb_itnim_tov(struct bfad_itnim_s *itnim_drv);
-
-#endif /* __BFAD_FCB_FCPIM_H__ */
diff --git a/drivers/scsi/bfa/include/fcb/bfa_fcb_port.h b/drivers/scsi/bfa/include/fcb/bfa_fcb_port.h
deleted file mode 100644 (file)
index 5fd7f98..0000000
+++ /dev/null
@@ -1,113 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  bfa_fcb_port.h BFA FCS virtual port driver interfaces
- */
-
-#ifndef __BFA_FCB_PORT_H__
-#define __BFA_FCB_PORT_H__
-
-#include <fcb/bfa_fcb_vport.h>
-/**
- *  fcs_port_fcb FCS port driver interfaces
- */
-
-/*
- * Forward declarations
- */
-struct bfad_port_s;
-
-/*
- * Callback functions from BFA FCS to driver
- */
-
-/**
- *     Call from FCS to driver module when a port is instantiated. The port
- *     can be a base port or a virtual port with in the base fabric or
- *     a virtual fabric.
- *
- *  On this callback, driver is supposed to create scsi_host, scsi_tgt or
- *  network interfaces bases on ports personality/roles.
- *
- *      base port of base fabric:      vf_drv == NULL && vp_drv == NULL
- *      vport of base fabric:          vf_drv == NULL && vp_drv != NULL
- *      base port of VF:               vf_drv != NULL && vp_drv == NULL
- *      vport of VF:                   vf_drv != NULL && vp_drv != NULL
- *
- * @param[in] bfad   - driver instance
- * @param[in] port   - FCS port instance
- * @param[in] roles  - port roles: IM, TM, IP
- * @param[in] vf_drv - VF driver instance, NULL if base fabric (no VF)
- * @param[in] vp_drv - vport driver instance, NULL if base port
- *
- * @return None
- */
-struct bfad_port_s *bfa_fcb_port_new(struct bfad_s *bfad,
-                       struct bfa_fcs_port_s *port,
-                       enum bfa_port_role roles, struct bfad_vf_s *vf_drv,
-                       struct bfad_vport_s *vp_drv);
-
-/**
- *     Call from FCS to driver module when a port is deleted. The port
- *     can be a base port or a virtual port with in the base fabric or
- *     a virtual fabric.
- *
- * @param[in] bfad   - driver instance
- * @param[in] roles  - port roles: IM, TM, IP
- * @param[in] vf_drv - VF driver instance, NULL if base fabric (no VF)
- * @param[in] vp_drv - vport driver instance, NULL if base port
- *
- * @return None
- */
-void bfa_fcb_port_delete(struct bfad_s *bfad, enum bfa_port_role roles,
-                       struct bfad_vf_s *vf_drv, struct bfad_vport_s *vp_drv);
-
-/**
- *     Notification when port transitions to ONLINE state.
- *
- * Online notification is a logical link up for the local port. This
- * notification is sent after a successfull FLOGI, or a successful
- * link initialization in proviate-loop or N2N topologies.
- *
- * @param[in] bfad   - driver instance
- * @param[in] roles  - port roles: IM, TM, IP
- * @param[in] vf_drv - VF driver instance, NULL if base fabric (no VF)
- * @param[in] vp_drv - vport driver instance, NULL if base port
- *
- * @return None
- */
-void bfa_fcb_port_online(struct bfad_s *bfad, enum bfa_port_role roles,
-                       struct bfad_vf_s *vf_drv, struct bfad_vport_s *vp_drv);
-
-/**
- *     Notification when port transitions to OFFLINE state.
- *
- * Offline notification is a logical link down for the local port.
- *
- * @param[in] bfad   - driver instance
- * @param[in] roles  - port roles: IM, TM, IP
- * @param[in] vf_drv - VF driver instance, NULL if base fabric (no VF)
- * @param[in] vp_drv - vport driver instance, NULL if base port
- *
- * @return None
- */
-void bfa_fcb_port_offline(struct bfad_s *bfad, enum bfa_port_role roles,
-                       struct bfad_vf_s *vf_drv, struct bfad_vport_s *vp_drv);
-
-
-#endif /* __BFA_FCB_PORT_H__ */
diff --git a/drivers/scsi/bfa/include/fcb/bfa_fcb_rport.h b/drivers/scsi/bfa/include/fcb/bfa_fcb_rport.h
deleted file mode 100644 (file)
index e0261bb..0000000
+++ /dev/null
@@ -1,80 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  bfa_fcb_rport.h BFA FCS rport driver interfaces
- */
-
-#ifndef __BFA_FCB_RPORT_H__
-#define __BFA_FCB_RPORT_H__
-
-/**
- *  fcs_rport_fcb Remote port driver interfaces
- */
-
-
-struct bfad_rport_s;
-
-/*
- * Callback functions from BFA FCS to driver
- */
-
-/**
- *     Completion callback for bfa_fcs_rport_add().
- *
- * @param[in] rport_drv - driver instance of rport
- *
- * @return None
- */
-void bfa_fcb_rport_add(struct bfad_rport_s *rport_drv);
-
-/**
- *     Completion callback for bfa_fcs_rport_remove().
- *
- * @param[in] rport_drv - driver instance of rport
- *
- * @return None
- */
-void bfa_fcb_rport_remove(struct bfad_rport_s *rport_drv);
-
-/**
- *             Call to allocate a rport instance.
- *
- * @param[in] bfad - driver instance
- * @param[out] rport - BFA FCS instance of rport
- * @param[out] rport_drv - driver instance of rport
- *
- * @retval BFA_STATUS_OK - successfully allocated
- * @retval BFA_STATUS_ENOMEM - cannot allocate
- */
-bfa_status_t bfa_fcb_rport_alloc(struct bfad_s *bfad,
-                       struct bfa_fcs_rport_s **rport,
-                       struct bfad_rport_s **rport_drv);
-
-/**
- *     Call to free rport memory resources.
- *
- * @param[in] bfad - driver instance
- * @param[in] rport_drv - driver instance of rport
- *
- * @return None
- */
-void bfa_fcb_rport_free(struct bfad_s *bfad, struct bfad_rport_s **rport_drv);
-
-
-
-#endif /* __BFA_FCB_RPORT_H__ */
diff --git a/drivers/scsi/bfa/include/fcb/bfa_fcb_vf.h b/drivers/scsi/bfa/include/fcb/bfa_fcb_vf.h
deleted file mode 100644 (file)
index cfd3fac..0000000
+++ /dev/null
@@ -1,47 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  bfa_fcb_vf.h BFA FCS virtual fabric driver interfaces
- */
-
-#ifndef __BFA_FCB_VF_H__
-#define __BFA_FCB_VF_H__
-
-/**
- *  fcs_vf_fcb Virtual fabric driver intrefaces
- */
-
-
-struct bfad_vf_s;
-
-/*
- * Callback functions from BFA FCS to driver
- */
-
-/**
- *     Completion callback for bfa_fcs_vf_stop().
- *
- * @param[in] vf_drv - driver instance of vf
- *
- * @return None
- */
-void            bfa_fcb_vf_stop(struct bfad_vf_s *vf_drv);
-
-
-
-#endif /* __BFA_FCB_VF_H__ */
diff --git a/drivers/scsi/bfa/include/fcb/bfa_fcb_vport.h b/drivers/scsi/bfa/include/fcb/bfa_fcb_vport.h
deleted file mode 100644 (file)
index cfd6ba7..0000000
+++ /dev/null
@@ -1,48 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  bfa_fcb_vport.h BFA FCS virtual port driver interfaces
- */
-
-#ifndef __BFA_FCB_VPORT_H__
-#define __BFA_FCB_VPORT_H__
-
-/**
- *  fcs_vport_fcb Virtual port driver interfaces
- */
-
-
-struct bfad_vport_s;
-
-/*
- * Callback functions from BFA FCS to driver
- */
-
-/**
- *     Completion callback for bfa_fcs_vport_delete().
- *
- * @param[in] vport_drv - driver instance of vport
- *
- * @return None
- */
-void bfa_fcb_vport_delete(struct bfad_vport_s *vport_drv);
-void bfa_fcb_pbc_vport_create(struct bfad_s *bfad, struct bfi_pbc_vport_s);
-
-
-
-#endif /* __BFA_FCB_VPORT_H__ */
diff --git a/drivers/scsi/bfa/include/fcs/bfa_fcs.h b/drivers/scsi/bfa/include/fcs/bfa_fcs.h
deleted file mode 100644 (file)
index 54e5b81..0000000
+++ /dev/null
@@ -1,76 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_FCS_H__
-#define __BFA_FCS_H__
-
-#include <cs/bfa_debug.h>
-#include <defs/bfa_defs_status.h>
-#include <defs/bfa_defs_version.h>
-#include <bfa.h>
-#include <fcs/bfa_fcs_fabric.h>
-
-#define BFA_FCS_OS_STR_LEN             64
-
-struct bfa_fcs_stats_s {
-       struct {
-               u32        untagged; /*  untagged receive frames */
-               u32        tagged;      /*  tagged receive frames */
-               u32        vfid_unknown;        /*  VF id is unknown */
-       } uf;
-};
-
-struct bfa_fcs_driver_info_s {
-       u8  version[BFA_VERSION_LEN];           /*  Driver Version */
-       u8  host_machine_name[BFA_FCS_OS_STR_LEN];
-       u8  host_os_name[BFA_FCS_OS_STR_LEN]; /*  OS name and version */
-       u8  host_os_patch[BFA_FCS_OS_STR_LEN];/*  patch or service pack */
-       u8  os_device_name[BFA_FCS_OS_STR_LEN]; /*  Driver Device Name */
-};
-
-struct bfa_fcs_s {
-       struct bfa_s      *bfa; /*  corresponding BFA bfa instance */
-       struct bfad_s         *bfad; /*  corresponding BDA driver instance */
-       struct bfa_log_mod_s  *logm;    /*  driver logging module instance */
-       struct bfa_trc_mod_s  *trcmod;  /*  tracing module */
-       struct bfa_aen_s      *aen;     /*  aen component */
-       bfa_boolean_t   vf_enabled;     /*  VF mode is enabled */
-       bfa_boolean_t   fdmi_enabled;   /*!< FDMI is enabled */
-       bfa_boolean_t min_cfg;          /* min cfg enabled/disabled */
-       u16        port_vfid;   /*  port default VF ID */
-       struct bfa_fcs_driver_info_s driver_info;
-       struct bfa_fcs_fabric_s fabric; /*  base fabric state machine */
-       struct bfa_fcs_stats_s  stats;  /*  FCS statistics */
-       struct bfa_wc_s         wc;     /*  waiting counter */
-};
-
-/*
- * bfa fcs API functions
- */
-void bfa_fcs_attach(struct bfa_fcs_s *fcs, struct bfa_s *bfa,
-                       struct bfad_s *bfad, bfa_boolean_t min_cfg);
-void bfa_fcs_init(struct bfa_fcs_s *fcs);
-void bfa_fcs_driver_info_init(struct bfa_fcs_s *fcs,
-                       struct bfa_fcs_driver_info_s *driver_info);
-void bfa_fcs_set_fdmi_param(struct bfa_fcs_s *fcs, bfa_boolean_t fdmi_enable);
-void bfa_fcs_exit(struct bfa_fcs_s *fcs);
-void bfa_fcs_trc_init(struct bfa_fcs_s *fcs, struct bfa_trc_mod_s *trcmod);
-void bfa_fcs_log_init(struct bfa_fcs_s *fcs, struct bfa_log_mod_s *logmod);
-void bfa_fcs_aen_init(struct bfa_fcs_s *fcs, struct bfa_aen_s *aen);
-void           bfa_fcs_start(struct bfa_fcs_s *fcs);
-
-#endif /* __BFA_FCS_H__ */
diff --git a/drivers/scsi/bfa/include/fcs/bfa_fcs_auth.h b/drivers/scsi/bfa/include/fcs/bfa_fcs_auth.h
deleted file mode 100644 (file)
index 28c4c9f..0000000
+++ /dev/null
@@ -1,82 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_FCS_AUTH_H__
-#define __BFA_FCS_AUTH_H__
-
-struct bfa_fcs_s;
-
-#include <defs/bfa_defs_status.h>
-#include <defs/bfa_defs_auth.h>
-#include <defs/bfa_defs_vf.h>
-#include <cs/bfa_q.h>
-#include <cs/bfa_sm.h>
-#include <defs/bfa_defs_pport.h>
-#include <fcs/bfa_fcs_lport.h>
-#include <protocol/fc_sp.h>
-
-struct bfa_fcs_fabric_s;
-
-
-
-struct bfa_fcs_auth_s {
-       bfa_sm_t        sm;     /*  state machine */
-       bfa_boolean_t   policy; /*  authentication enabled/disabled */
-       enum bfa_auth_status status;    /*  authentication status */
-       enum auth_rjt_codes  rjt_code;  /*  auth reject status */
-       enum auth_rjt_code_exps  rjt_code_exp;  /*  auth reject reason */
-       enum bfa_auth_algo algo;        /*  Authentication algorithm */
-       struct bfa_auth_stats_s stats;  /*  Statistics */
-       enum auth_dh_gid   group;       /*  DH(diffie-hellman) Group */
-       enum bfa_auth_secretsource source;      /*  Secret source */
-       char            secret[BFA_AUTH_SECRET_STRING_LEN];
-                               /*  secret string */
-       u8         secret_len;
-                               /*  secret string length */
-       u8         nretries;
-                               /*  number of retries */
-       struct bfa_fcs_fabric_s *fabric;/*  pointer to fabric */
-       u8         sentcode;    /*  pointer to response data */
-       u8        *response;    /*  pointer to response data */
-       struct bfa_timer_s delay_timer;         /*  delay timer */
-       struct bfa_fcxp_s *fcxp;                /*  pointer to fcxp */
-       struct bfa_fcxp_wqe_s fcxp_wqe;
-};
-
-/**
- * bfa fcs authentication public functions
- */
-bfa_status_t    bfa_fcs_auth_get_attr(struct bfa_fcs_s *port,
-                                     struct bfa_auth_attr_s *attr);
-bfa_status_t    bfa_fcs_auth_set_policy(struct bfa_fcs_s *port,
-                                       bfa_boolean_t policy);
-enum bfa_auth_status bfa_fcs_auth_get_status(struct bfa_fcs_s *port);
-bfa_status_t    bfa_fcs_auth_set_algo(struct bfa_fcs_s *port,
-                                     enum bfa_auth_algo algo);
-bfa_status_t    bfa_fcs_auth_get_stats(struct bfa_fcs_s *port,
-                                      struct bfa_auth_stats_s *stats);
-bfa_status_t    bfa_fcs_auth_set_dh_group(struct bfa_fcs_s *port, int group);
-bfa_status_t    bfa_fcs_auth_set_secretstring(struct bfa_fcs_s *port,
-                                             char *secret);
-bfa_status_t    bfa_fcs_auth_set_secretstring_encrypt(struct bfa_fcs_s *port,
-                                             u32 secret[], u32 len);
-bfa_status_t    bfa_fcs_auth_set_secretsource(struct bfa_fcs_s *port,
-                                             enum bfa_auth_secretsource src);
-bfa_status_t    bfa_fcs_auth_reset_stats(struct bfa_fcs_s *port);
-bfa_status_t    bfa_fcs_auth_reinit(struct bfa_fcs_s *port);
-
-#endif /* __BFA_FCS_AUTH_H__ */
diff --git a/drivers/scsi/bfa/include/fcs/bfa_fcs_fabric.h b/drivers/scsi/bfa/include/fcs/bfa_fcs_fabric.h
deleted file mode 100644 (file)
index 08b79d5..0000000
+++ /dev/null
@@ -1,112 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_FCS_FABRIC_H__
-#define __BFA_FCS_FABRIC_H__
-
-struct bfa_fcs_s;
-
-#include <defs/bfa_defs_status.h>
-#include <defs/bfa_defs_vf.h>
-#include <cs/bfa_q.h>
-#include <cs/bfa_sm.h>
-#include <defs/bfa_defs_pport.h>
-#include <fcs/bfa_fcs_lport.h>
-#include <protocol/fc_sp.h>
-#include <fcs/bfa_fcs_auth.h>
-
-/*
- * forward declaration
- */
-struct bfad_vf_s;
-
-enum bfa_fcs_fabric_type {
-       BFA_FCS_FABRIC_UNKNOWN = 0,
-       BFA_FCS_FABRIC_SWITCHED = 1,
-       BFA_FCS_FABRIC_PLOOP = 2,
-       BFA_FCS_FABRIC_N2N = 3,
-};
-
-
-struct bfa_fcs_fabric_s {
-       struct list_head   qe;          /*  queue element */
-       bfa_sm_t         sm;            /*  state machine */
-       struct bfa_fcs_s *fcs;          /*  FCS instance */
-       struct bfa_fcs_port_s  bport;   /*  base logical port */
-       enum bfa_fcs_fabric_type fab_type; /*  fabric type */
-       enum bfa_pport_type oper_type;  /*  current link topology */
-       u8         is_vf;               /*  is virtual fabric? */
-       u8         is_npiv;     /*  is NPIV supported ? */
-       u8         is_auth;     /*  is Security/Auth supported ? */
-       u16        bb_credit;   /*  BB credit from fabric */
-       u16        vf_id;               /*  virtual fabric ID */
-       u16        num_vports;  /*  num vports */
-       u16        rsvd;
-       struct list_head         vport_q;       /*  queue of virtual ports */
-       struct list_head         vf_q;  /*  queue of virtual fabrics */
-       struct bfad_vf_s      *vf_drv;  /*  driver vf structure */
-       struct bfa_timer_s link_timer;  /*  Link Failure timer. Vport */
-       wwn_t           fabric_name;    /*  attached fabric name */
-       bfa_boolean_t   auth_reqd;      /*  authentication required     */
-       struct bfa_timer_s delay_timer; /*  delay timer         */
-       union {
-               u16        swp_vfid;/*  switch port VF id               */
-       } event_arg;
-       struct bfa_fcs_auth_s  auth;    /*  authentication config       */
-       struct bfa_wc_s        wc;      /*  wait counter for delete     */
-       struct bfa_vf_stats_s  stats;   /*  fabric/vf stats             */
-       struct bfa_lps_s        *lps;   /*  lport login services        */
-       u8      fabric_ip_addr[BFA_FCS_FABRIC_IPADDR_SZ];  /*  attached
-                                                           * fabric's ip addr
-                                                           */
-};
-
-#define bfa_fcs_fabric_npiv_capable(__f)    ((__f)->is_npiv)
-#define bfa_fcs_fabric_is_switched(__f)                        \
-       ((__f)->fab_type == BFA_FCS_FABRIC_SWITCHED)
-
-/**
- *   The design calls for a single implementation of base fabric and vf.
- */
-#define bfa_fcs_vf_t struct bfa_fcs_fabric_s
-
-struct bfa_vf_event_s {
-       u32        undefined;
-};
-
-/**
- * bfa fcs vf public functions
- */
-bfa_status_t bfa_fcs_vf_mode_enable(struct bfa_fcs_s *fcs, u16 vf_id);
-bfa_status_t bfa_fcs_vf_mode_disable(struct bfa_fcs_s *fcs);
-bfa_status_t bfa_fcs_vf_create(bfa_fcs_vf_t *vf, struct bfa_fcs_s *fcs,
-                              u16 vf_id, struct bfa_port_cfg_s *port_cfg,
-                              struct bfad_vf_s *vf_drv);
-bfa_status_t bfa_fcs_vf_delete(bfa_fcs_vf_t *vf);
-void bfa_fcs_vf_start(bfa_fcs_vf_t *vf);
-bfa_status_t bfa_fcs_vf_stop(bfa_fcs_vf_t *vf);
-void bfa_fcs_vf_list(struct bfa_fcs_s *fcs, u16 *vf_ids, int *nvfs);
-void bfa_fcs_vf_list_all(struct bfa_fcs_s *fcs, u16 *vf_ids, int *nvfs);
-void bfa_fcs_vf_get_attr(bfa_fcs_vf_t *vf, struct bfa_vf_attr_s *vf_attr);
-void bfa_fcs_vf_get_stats(bfa_fcs_vf_t *vf,
-                         struct bfa_vf_stats_s *vf_stats);
-void bfa_fcs_vf_clear_stats(bfa_fcs_vf_t *vf);
-void bfa_fcs_vf_get_ports(bfa_fcs_vf_t *vf, wwn_t vpwwn[], int *nports);
-bfa_fcs_vf_t *bfa_fcs_vf_lookup(struct bfa_fcs_s *fcs, u16 vf_id);
-struct bfad_vf_s *bfa_fcs_vf_get_drv_vf(bfa_fcs_vf_t *vf);
-
-#endif /* __BFA_FCS_FABRIC_H__ */
diff --git a/drivers/scsi/bfa/include/fcs/bfa_fcs_fcpim.h b/drivers/scsi/bfa/include/fcs/bfa_fcs_fcpim.h
deleted file mode 100644 (file)
index 9a35ecf..0000000
+++ /dev/null
@@ -1,132 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  bfa_fcs_fcpim.h BFA FCS FCP Initiator Mode interfaces/defines.
- */
-
-#ifndef __BFA_FCS_FCPIM_H__
-#define __BFA_FCS_FCPIM_H__
-
-#include <defs/bfa_defs_status.h>
-#include <defs/bfa_defs_itnim.h>
-#include <fcs/bfa_fcs.h>
-#include <fcs/bfa_fcs_rport.h>
-#include <fcs/bfa_fcs_lport.h>
-#include <bfa_fcpim.h>
-
-/*
- * forward declarations
- */
-struct bfad_itnim_s;
-
-struct bfa_fcs_itnim_s {
-       bfa_sm_t                sm;             /*  state machine */
-       struct bfa_fcs_rport_s  *rport;         /*  parent remote rport  */
-       struct bfad_itnim_s     *itnim_drv;     /*  driver peer instance */
-       struct bfa_fcs_s        *fcs;           /*  fcs instance         */
-       struct bfa_timer_s      timer;          /*  timer functions      */
-       struct bfa_itnim_s      *bfa_itnim;     /*  BFA itnim struct     */
-       u32                     prli_retries;   /*  max prli retry attempts */
-       bfa_boolean_t           seq_rec;        /*  seq recovery support */
-       bfa_boolean_t           rec_support;    /*  REC supported        */
-       bfa_boolean_t           conf_comp;      /*  FCP_CONF     support */
-       bfa_boolean_t           task_retry_id;  /*  task retry id supp   */
-       struct bfa_fcxp_wqe_s   fcxp_wqe;       /*  wait qelem for fcxp  */
-       struct bfa_fcxp_s *fcxp;                /*  FCXP in use          */
-       struct bfa_itnim_stats_s        stats;  /*  itn statistics       */
-};
-
-
-static inline struct bfad_port_s *
-bfa_fcs_itnim_get_drvport(struct bfa_fcs_itnim_s *itnim)
-{
-       return itnim->rport->port->bfad_port;
-}
-
-
-static inline struct bfa_fcs_port_s *
-bfa_fcs_itnim_get_port(struct bfa_fcs_itnim_s *itnim)
-{
-       return itnim->rport->port;
-}
-
-
-static inline wwn_t
-bfa_fcs_itnim_get_nwwn(struct bfa_fcs_itnim_s *itnim)
-{
-       return itnim->rport->nwwn;
-}
-
-
-static inline wwn_t
-bfa_fcs_itnim_get_pwwn(struct bfa_fcs_itnim_s *itnim)
-{
-       return itnim->rport->pwwn;
-}
-
-
-static inline u32
-bfa_fcs_itnim_get_fcid(struct bfa_fcs_itnim_s *itnim)
-{
-       return itnim->rport->pid;
-}
-
-
-static inline   u32
-bfa_fcs_itnim_get_maxfrsize(struct bfa_fcs_itnim_s *itnim)
-{
-       return itnim->rport->maxfrsize;
-}
-
-
-static inline   enum fc_cos
-bfa_fcs_itnim_get_cos(struct bfa_fcs_itnim_s *itnim)
-{
-       return itnim->rport->fc_cos;
-}
-
-
-static inline struct bfad_itnim_s *
-bfa_fcs_itnim_get_drvitn(struct bfa_fcs_itnim_s *itnim)
-{
-       return itnim->itnim_drv;
-}
-
-
-static inline struct bfa_itnim_s *
-bfa_fcs_itnim_get_halitn(struct bfa_fcs_itnim_s *itnim)
-{
-       return itnim->bfa_itnim;
-}
-
-/**
- * bfa fcs FCP Initiator mode API functions
- */
-void bfa_fcs_itnim_get_attr(struct bfa_fcs_itnim_s *itnim,
-                       struct bfa_itnim_attr_s *attr);
-void bfa_fcs_itnim_get_stats(struct bfa_fcs_itnim_s *itnim,
-                       struct bfa_itnim_stats_s *stats);
-struct bfa_fcs_itnim_s *bfa_fcs_itnim_lookup(struct bfa_fcs_port_s *port,
-                       wwn_t rpwwn);
-bfa_status_t bfa_fcs_itnim_attr_get(struct bfa_fcs_port_s *port, wwn_t rpwwn,
-                       struct bfa_itnim_attr_s *attr);
-bfa_status_t bfa_fcs_itnim_stats_get(struct bfa_fcs_port_s *port, wwn_t rpwwn,
-                       struct bfa_itnim_stats_s *stats);
-bfa_status_t bfa_fcs_itnim_stats_clear(struct bfa_fcs_port_s *port,
-                       wwn_t rpwwn);
-#endif /* __BFA_FCS_FCPIM_H__ */
diff --git a/drivers/scsi/bfa/include/fcs/bfa_fcs_fdmi.h b/drivers/scsi/bfa/include/fcs/bfa_fcs_fdmi.h
deleted file mode 100644 (file)
index 4441fff..0000000
+++ /dev/null
@@ -1,63 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  bfa_fcs_fdmi.h BFA fcs fdmi module public interface
- */
-
-#ifndef __BFA_FCS_FDMI_H__
-#define __BFA_FCS_FDMI_H__
-#include <bfa_os_inc.h>
-#include <protocol/fdmi.h>
-
-#define        BFA_FCS_FDMI_SUPORTED_SPEEDS  (FDMI_TRANS_SPEED_1G  | \
-                                       FDMI_TRANS_SPEED_2G | \
-                                       FDMI_TRANS_SPEED_4G | \
-                                       FDMI_TRANS_SPEED_8G)
-
-/*
-* HBA Attribute Block : BFA internal representation. Note : Some variable
-* sizes have been trimmed to suit BFA For Ex : Model will be "Brocade". Based
- * on this the size has been reduced to 16 bytes from the standard's 64 bytes.
- */
-struct bfa_fcs_fdmi_hba_attr_s {
-       wwn_t           node_name;
-       u8         manufacturer[64];
-       u8         serial_num[64];
-       u8         model[16];
-       u8         model_desc[256];
-       u8         hw_version[8];
-       u8         driver_version[8];
-       u8         option_rom_ver[BFA_VERSION_LEN];
-       u8         fw_version[8];
-       u8         os_name[256];
-       u32        max_ct_pyld;
-};
-
-/*
- * Port Attribute Block
- */
-struct bfa_fcs_fdmi_port_attr_s {
-       u8         supp_fc4_types[32];  /* supported FC4 types */
-       u32        supp_speed;  /* supported speed */
-       u32        curr_speed;  /* current Speed */
-       u32        max_frm_size;        /* max frame size */
-       u8         os_device_name[256]; /* OS device Name */
-       u8         host_name[256];      /* host name */
-};
-
-#endif /* __BFA_FCS_FDMI_H__ */
diff --git a/drivers/scsi/bfa/include/fcs/bfa_fcs_lport.h b/drivers/scsi/bfa/include/fcs/bfa_fcs_lport.h
deleted file mode 100644 (file)
index ceaefd3..0000000
+++ /dev/null
@@ -1,219 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  bfa_fcs_port.h BFA fcs port module public interface
- */
-
-#ifndef __BFA_FCS_PORT_H__
-#define __BFA_FCS_PORT_H__
-
-#include <defs/bfa_defs_status.h>
-#include <defs/bfa_defs_port.h>
-#include <defs/bfa_defs_pport.h>
-#include <defs/bfa_defs_rport.h>
-#include <cs/bfa_q.h>
-#include <bfa_svc.h>
-#include <cs/bfa_wc.h>
-
-struct bfa_fcs_s;
-struct bfa_fcs_fabric_s;
-
-/*
- * Maximum Rports supported per port (physical/logical).
- */
-#define BFA_FCS_MAX_RPORTS_SUPP  256   /* @todo : tentative value */
-
-
-struct bfa_fcs_port_ns_s {
-       bfa_sm_t        sm;             /*  state machine */
-       struct bfa_timer_s timer;
-       struct bfa_fcs_port_s *port;    /*  parent port */
-       struct bfa_fcxp_s *fcxp;
-       struct bfa_fcxp_wqe_s fcxp_wqe;
-};
-
-
-struct bfa_fcs_port_scn_s {
-       bfa_sm_t        sm;             /*  state machine */
-       struct bfa_timer_s timer;
-       struct bfa_fcs_port_s *port;    /*  parent port */
-       struct bfa_fcxp_s *fcxp;
-       struct bfa_fcxp_wqe_s fcxp_wqe;
-};
-
-
-struct bfa_fcs_port_fdmi_s {
-       bfa_sm_t        sm;             /*  state machine */
-       struct bfa_timer_s timer;
-       struct bfa_fcs_port_ms_s *ms;   /*  parent ms */
-       struct bfa_fcxp_s *fcxp;
-       struct bfa_fcxp_wqe_s fcxp_wqe;
-       u8         retry_cnt;   /*  retry count */
-       u8                 rsvd[3];
-};
-
-
-struct bfa_fcs_port_ms_s {
-       bfa_sm_t        sm;             /*  state machine */
-       struct bfa_timer_s timer;
-       struct bfa_fcs_port_s *port;    /*  parent port */
-       struct bfa_fcxp_s *fcxp;
-       struct bfa_fcxp_wqe_s fcxp_wqe;
-       struct bfa_fcs_port_fdmi_s fdmi;        /*  FDMI component of MS */
-       u8         retry_cnt;   /*  retry count */
-       u8                 rsvd[3];
-};
-
-
-struct bfa_fcs_port_fab_s {
-       struct bfa_fcs_port_ns_s ns;    /*  NS component of port */
-       struct bfa_fcs_port_scn_s scn;  /*  scn component of port */
-       struct bfa_fcs_port_ms_s ms;    /*  MS component of port */
-};
-
-
-
-#define        MAX_ALPA_COUNT          127
-
-struct bfa_fcs_port_loop_s {
-       u8         num_alpa;    /*  Num of ALPA entries in the map */
-       u8         alpa_pos_map[MAX_ALPA_COUNT];        /*  ALPA Positional
-                                                        *Map */
-       struct bfa_fcs_port_s *port;    /*  parent port */
-};
-
-
-
-struct bfa_fcs_port_n2n_s {
-       u32        rsvd;
-       u16        reply_oxid;  /*  ox_id from the req flogi to be
-                                        *used in flogi acc */
-       wwn_t           rem_port_wwn;   /*  Attached port's wwn */
-};
-
-
-union bfa_fcs_port_topo_u {
-       struct bfa_fcs_port_fab_s pfab;
-       struct bfa_fcs_port_loop_s ploop;
-       struct bfa_fcs_port_n2n_s pn2n;
-};
-
-
-struct bfa_fcs_port_s {
-       struct list_head         qe;    /*  used by port/vport */
-       bfa_sm_t               sm;      /*  state machine */
-       struct bfa_fcs_fabric_s *fabric;/*  parent fabric */
-       struct bfa_port_cfg_s  port_cfg;/*  port configuration */
-       struct bfa_timer_s link_timer;  /*  timer for link offline */
-       u32 pid:24;     /*  FC address */
-       u8  lp_tag;     /*  lport tag */
-       u16 num_rports; /*  Num of r-ports */
-       struct list_head rport_q;       /*  queue of discovered r-ports */
-       struct bfa_fcs_s *fcs;  /*  FCS instance */
-       union bfa_fcs_port_topo_u port_topo;    /*  fabric/loop/n2n details */
-       struct bfad_port_s *bfad_port;  /*  driver peer instance */
-       struct bfa_fcs_vport_s *vport;  /*  NULL for base ports */
-       struct bfa_fcxp_s *fcxp;
-       struct bfa_fcxp_wqe_s fcxp_wqe;
-       struct bfa_port_stats_s stats;
-       struct bfa_wc_s        wc;      /*  waiting counter for events */
-};
-
-#define bfa_fcs_lport_t struct bfa_fcs_port_s
-
-/**
- * Symbolic Name related defines
- *  Total bytes 255.
- *  Physical Port's symbolic name 128 bytes.
- *  For Vports, Vport's symbolic name is appended to the Physical port's
- *  Symbolic Name.
- *
- *  Physical Port's symbolic name Format : (Total 128 bytes)
- *  Adapter Model number/name : 12 bytes
- *  Driver Version     : 10 bytes
- *  Host Machine Name  : 30 bytes
- *     Host OS Info       : 48 bytes
- *     Host OS PATCH Info : 16 bytes
- *  ( remaining 12 bytes reserved to be used for separator)
- */
-#define BFA_FCS_PORT_SYMBNAME_SEPARATOR                " | "
-
-#define BFA_FCS_PORT_SYMBNAME_MODEL_SZ                 12
-#define BFA_FCS_PORT_SYMBNAME_VERSION_SZ               10
-#define BFA_FCS_PORT_SYMBNAME_MACHINENAME_SZ   30
-#define BFA_FCS_PORT_SYMBNAME_OSINFO_SZ                        48
-#define BFA_FCS_PORT_SYMBNAME_OSPATCH_SZ               16
-
-/**
- * Get FC port ID for a logical port.
- */
-#define bfa_fcs_port_get_fcid(_lport)  ((_lport)->pid)
-#define bfa_fcs_port_get_pwwn(_lport)  ((_lport)->port_cfg.pwwn)
-#define bfa_fcs_port_get_nwwn(_lport)  ((_lport)->port_cfg.nwwn)
-#define bfa_fcs_port_get_psym_name(_lport)     ((_lport)->port_cfg.sym_name)
-#define bfa_fcs_port_is_initiator(_lport)      \
-                       ((_lport)->port_cfg.roles & BFA_PORT_ROLE_FCP_IM)
-#define bfa_fcs_port_is_target(_lport) \
-                       ((_lport)->port_cfg.roles & BFA_PORT_ROLE_FCP_TM)
-#define bfa_fcs_port_get_nrports(_lport)       \
-                       ((_lport) ? (_lport)->num_rports : 0)
-
-static inline struct bfad_port_s *
-bfa_fcs_port_get_drvport(struct bfa_fcs_port_s *port)
-{
-       return port->bfad_port;
-}
-
-
-#define bfa_fcs_port_get_opertype(_lport)      ((_lport)->fabric->oper_type)
-
-
-#define bfa_fcs_port_get_fabric_name(_lport)   ((_lport)->fabric->fabric_name)
-
-
-#define bfa_fcs_port_get_fabric_ipaddr(_lport) \
-               ((_lport)->fabric->fabric_ip_addr)
-
-/**
- * bfa fcs port public functions
- */
-void bfa_fcs_cfg_base_port(struct bfa_fcs_s *fcs,
-                       struct bfa_port_cfg_s *port_cfg);
-struct bfa_fcs_port_s *bfa_fcs_get_base_port(struct bfa_fcs_s *fcs);
-void bfa_fcs_port_get_rports(struct bfa_fcs_port_s *port,
-                       wwn_t rport_wwns[], int *nrports);
-
-wwn_t bfa_fcs_port_get_rport(struct bfa_fcs_port_s *port, wwn_t wwn,
-                       int index, int nrports, bfa_boolean_t bwwn);
-
-struct bfa_fcs_port_s *bfa_fcs_lookup_port(struct bfa_fcs_s *fcs,
-                       u16 vf_id, wwn_t lpwwn);
-
-void bfa_fcs_port_get_info(struct bfa_fcs_port_s *port,
-                       struct bfa_port_info_s *port_info);
-void bfa_fcs_port_get_attr(struct bfa_fcs_port_s *port,
-                       struct bfa_port_attr_s *port_attr);
-void bfa_fcs_port_get_stats(struct bfa_fcs_port_s *fcs_port,
-                       struct bfa_port_stats_s *port_stats);
-void bfa_fcs_port_clear_stats(struct bfa_fcs_port_s *fcs_port);
-enum bfa_pport_speed bfa_fcs_port_get_rport_max_speed(
-                       struct bfa_fcs_port_s *port);
-void bfa_fcs_port_enable_ipfc_roles(struct bfa_fcs_port_s *fcs_port);
-void bfa_fcs_port_disable_ipfc_roles(struct bfa_fcs_port_s *fcs_port);
-
-#endif /* __BFA_FCS_PORT_H__ */
diff --git a/drivers/scsi/bfa/include/fcs/bfa_fcs_rport.h b/drivers/scsi/bfa/include/fcs/bfa_fcs_rport.h
deleted file mode 100644 (file)
index 3027fc6..0000000
+++ /dev/null
@@ -1,105 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __BFA_FCS_RPORT_H__
-#define __BFA_FCS_RPORT_H__
-
-#include <defs/bfa_defs_status.h>
-#include <cs/bfa_q.h>
-#include <fcs/bfa_fcs.h>
-#include <defs/bfa_defs_rport.h>
-
-#define BFA_FCS_RPORT_DEF_DEL_TIMEOUT  90      /* in secs */
-/*
- * forward declarations
- */
-struct bfad_rport_s;
-
-struct bfa_fcs_itnim_s;
-struct bfa_fcs_tin_s;
-struct bfa_fcs_iprp_s;
-
-/* Rport Features (RPF) */
-struct bfa_fcs_rpf_s {
-       bfa_sm_t               sm;      /*  state machine */
-       struct bfa_fcs_rport_s *rport;  /*  parent rport */
-       struct bfa_timer_s      timer;  /*  general purpose timer */
-       struct bfa_fcxp_s       *fcxp;  /*  FCXP needed for discarding */
-       struct bfa_fcxp_wqe_s   fcxp_wqe;       /*  fcxp wait queue element */
-       int                     rpsc_retries;   /*  max RPSC retry attempts */
-       enum bfa_pport_speed    rpsc_speed;     /* Current Speed from RPSC.
-                                                * O if RPSC fails */
-       enum bfa_pport_speed    assigned_speed; /* Speed assigned by the user.
-                                                * will be used if RPSC is not
-                                                * supported by the rport */
-};
-
-struct bfa_fcs_rport_s {
-       struct list_head         qe;    /*  used by port/vport */
-       struct bfa_fcs_port_s *port;    /*  parent FCS port */
-       struct bfa_fcs_s      *fcs;     /*  fcs instance */
-       struct bfad_rport_s   *rp_drv;  /*  driver peer instance */
-       u32        pid; /*  port ID of rport */
-       u16        maxfrsize;   /*  maximum frame size */
-       u16        reply_oxid;  /*  OX_ID of inbound requests */
-       enum fc_cos        fc_cos;      /*  FC classes of service supp */
-       bfa_boolean_t   cisc;   /*  CISC capable device */
-       bfa_boolean_t   prlo;   /*  processing prlo or LOGO */
-       wwn_t           pwwn;   /*  port wwn of rport */
-       wwn_t           nwwn;   /*  node wwn of rport */
-       struct bfa_rport_symname_s psym_name; /*  port symbolic name  */
-       bfa_sm_t        sm;             /*  state machine */
-       struct bfa_timer_s timer;       /*  general purpose timer */
-       struct bfa_fcs_itnim_s *itnim;  /*  ITN initiator mode role */
-       struct bfa_fcs_tin_s *tin;      /*  ITN initiator mode role */
-       struct bfa_fcs_iprp_s *iprp;    /*  IP/FC role */
-       struct bfa_rport_s *bfa_rport;  /*  BFA Rport */
-       struct bfa_fcxp_s *fcxp;        /*  FCXP needed for discarding */
-       int             plogi_retries;  /*  max plogi retry attempts */
-       int             ns_retries;     /*  max NS query retry attempts */
-       struct bfa_fcxp_wqe_s   fcxp_wqe; /*  fcxp wait queue element */
-       struct bfa_rport_stats_s stats; /*  rport stats */
-       enum bfa_rport_function scsi_function;  /*  Initiator/Target */
-       struct bfa_fcs_rpf_s rpf;       /* Rport features module */
-};
-
-static inline struct bfa_rport_s *
-bfa_fcs_rport_get_halrport(struct bfa_fcs_rport_s *rport)
-{
-       return rport->bfa_rport;
-}
-
-/**
- * bfa fcs rport API functions
- */
-bfa_status_t bfa_fcs_rport_add(struct bfa_fcs_port_s *port, wwn_t *pwwn,
-                       struct bfa_fcs_rport_s *rport,
-                       struct bfad_rport_s *rport_drv);
-bfa_status_t bfa_fcs_rport_remove(struct bfa_fcs_rport_s *rport);
-void bfa_fcs_rport_get_attr(struct bfa_fcs_rport_s *rport,
-                       struct bfa_rport_attr_s *attr);
-void bfa_fcs_rport_get_stats(struct bfa_fcs_rport_s *rport,
-                       struct bfa_rport_stats_s *stats);
-void bfa_fcs_rport_clear_stats(struct bfa_fcs_rport_s *rport);
-struct bfa_fcs_rport_s *bfa_fcs_rport_lookup(struct bfa_fcs_port_s *port,
-                       wwn_t rpwwn);
-struct bfa_fcs_rport_s *bfa_fcs_rport_lookup_by_nwwn(
-                       struct bfa_fcs_port_s *port, wwn_t rnwwn);
-void bfa_fcs_rport_set_del_timeout(u8 rport_tmo);
-void bfa_fcs_rport_set_speed(struct bfa_fcs_rport_s *rport,
-                       enum bfa_pport_speed speed);
-#endif /* __BFA_FCS_RPORT_H__ */
diff --git a/drivers/scsi/bfa/include/fcs/bfa_fcs_vport.h b/drivers/scsi/bfa/include/fcs/bfa_fcs_vport.h
deleted file mode 100644 (file)
index 0af2624..0000000
+++ /dev/null
@@ -1,67 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  bfa_fcs_vport.h BFA fcs vport module public interface
- */
-
-#ifndef __BFA_FCS_VPORT_H__
-#define __BFA_FCS_VPORT_H__
-
-#include <defs/bfa_defs_status.h>
-#include <defs/bfa_defs_port.h>
-#include <defs/bfa_defs_vport.h>
-#include <fcs/bfa_fcs.h>
-#include <fcb/bfa_fcb_vport.h>
-
-struct bfa_fcs_vport_s {
-       struct list_head                qe;             /*  queue elem   */
-       bfa_sm_t                sm;             /*  state machine       */
-       bfa_fcs_lport_t         lport;          /*  logical port        */
-       struct bfa_timer_s      timer;          /*  general purpose timer */
-       struct bfad_vport_s     *vport_drv;     /*  Driver private      */
-       struct bfa_vport_stats_s vport_stats;   /*  vport statistics    */
-       struct bfa_lps_s        *lps;           /*  Lport login service */
-       int                     fdisc_retries;
-};
-
-#define bfa_fcs_vport_get_port(vport) \
-                       ((struct bfa_fcs_port_s  *)(&vport->port))
-
-/**
- * bfa fcs vport public functions
- */
-bfa_status_t bfa_fcs_vport_create(struct bfa_fcs_vport_s *vport,
-                       struct bfa_fcs_s *fcs, u16 vf_id,
-                       struct bfa_port_cfg_s *port_cfg,
-                       struct bfad_vport_s *vport_drv);
-bfa_status_t bfa_fcs_pbc_vport_create(struct bfa_fcs_vport_s *vport,
-                       struct bfa_fcs_s *fcs, uint16_t vf_id,
-                       struct bfa_port_cfg_s *port_cfg,
-                       struct bfad_vport_s *vport_drv);
-bfa_status_t bfa_fcs_vport_delete(struct bfa_fcs_vport_s *vport);
-bfa_status_t bfa_fcs_vport_start(struct bfa_fcs_vport_s *vport);
-bfa_status_t bfa_fcs_vport_stop(struct bfa_fcs_vport_s *vport);
-void bfa_fcs_vport_get_attr(struct bfa_fcs_vport_s *vport,
-                       struct bfa_vport_attr_s *vport_attr);
-void bfa_fcs_vport_get_stats(struct bfa_fcs_vport_s *vport,
-                       struct bfa_vport_stats_s *vport_stats);
-void bfa_fcs_vport_clr_stats(struct bfa_fcs_vport_s *vport);
-struct bfa_fcs_vport_s *bfa_fcs_vport_lookup(struct bfa_fcs_s *fcs,
-                       u16 vf_id, wwn_t vpwwn);
-
-#endif /* __BFA_FCS_VPORT_H__ */
diff --git a/drivers/scsi/bfa/include/log/bfa_log_fcs.h b/drivers/scsi/bfa/include/log/bfa_log_fcs.h
deleted file mode 100644 (file)
index b6f5df8..0000000
+++ /dev/null
@@ -1,28 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/*
- * messages define for FCS Module
- */
-#ifndef        __BFA_LOG_FCS_H__
-#define        __BFA_LOG_FCS_H__
-#include  <cs/bfa_log.h>
-#define BFA_LOG_FCS_FABRIC_NOSWITCH    \
-       (((u32) BFA_LOG_FCS_ID << BFA_LOG_MODID_OFFSET) | 1)
-#define BFA_LOG_FCS_FABRIC_ISOLATED    \
-       (((u32) BFA_LOG_FCS_ID << BFA_LOG_MODID_OFFSET) | 2)
-#endif
diff --git a/drivers/scsi/bfa/include/log/bfa_log_hal.h b/drivers/scsi/bfa/include/log/bfa_log_hal.h
deleted file mode 100644 (file)
index 5f8f5e3..0000000
+++ /dev/null
@@ -1,36 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/* messages define for HAL Module */
-#ifndef        __BFA_LOG_HAL_H__
-#define        __BFA_LOG_HAL_H__
-#include  <cs/bfa_log.h>
-#define BFA_LOG_HAL_ASSERT \
-       (((u32) BFA_LOG_HAL_ID << BFA_LOG_MODID_OFFSET) | 1)
-#define BFA_LOG_HAL_HEARTBEAT_FAILURE \
-       (((u32) BFA_LOG_HAL_ID << BFA_LOG_MODID_OFFSET) | 2)
-#define BFA_LOG_HAL_FCPIM_PARM_INVALID \
-       (((u32) BFA_LOG_HAL_ID << BFA_LOG_MODID_OFFSET) | 3)
-#define BFA_LOG_HAL_SM_ASSERT \
-       (((u32) BFA_LOG_HAL_ID << BFA_LOG_MODID_OFFSET) | 4)
-#define BFA_LOG_HAL_DRIVER_ERROR \
-       (((u32) BFA_LOG_HAL_ID << BFA_LOG_MODID_OFFSET) | 5)
-#define BFA_LOG_HAL_DRIVER_CONFIG_ERROR \
-       (((u32) BFA_LOG_HAL_ID << BFA_LOG_MODID_OFFSET) | 6)
-#define BFA_LOG_HAL_MBOX_ERROR \
-       (((u32) BFA_LOG_HAL_ID << BFA_LOG_MODID_OFFSET) | 7)
-#endif
diff --git a/drivers/scsi/bfa/include/log/bfa_log_linux.h b/drivers/scsi/bfa/include/log/bfa_log_linux.h
deleted file mode 100644 (file)
index 44bc897..0000000
+++ /dev/null
@@ -1,62 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/* messages define for LINUX Module */
-#ifndef        __BFA_LOG_LINUX_H__
-#define        __BFA_LOG_LINUX_H__
-#include  <cs/bfa_log.h>
-#define BFA_LOG_LINUX_DEVICE_CLAIMED \
-               (((u32) BFA_LOG_LINUX_ID << BFA_LOG_MODID_OFFSET) | 1)
-#define BFA_LOG_LINUX_HASH_INIT_FAILED \
-               (((u32) BFA_LOG_LINUX_ID << BFA_LOG_MODID_OFFSET) | 2)
-#define BFA_LOG_LINUX_SYSFS_FAILED \
-               (((u32) BFA_LOG_LINUX_ID << BFA_LOG_MODID_OFFSET) | 3)
-#define BFA_LOG_LINUX_MEM_ALLOC_FAILED \
-               (((u32) BFA_LOG_LINUX_ID << BFA_LOG_MODID_OFFSET) | 4)
-#define BFA_LOG_LINUX_DRIVER_REGISTRATION_FAILED \
-               (((u32) BFA_LOG_LINUX_ID << BFA_LOG_MODID_OFFSET) | 5)
-#define BFA_LOG_LINUX_ITNIM_FREE \
-               (((u32) BFA_LOG_LINUX_ID << BFA_LOG_MODID_OFFSET) | 6)
-#define BFA_LOG_LINUX_ITNIM_ONLINE \
-               (((u32) BFA_LOG_LINUX_ID << BFA_LOG_MODID_OFFSET) | 7)
-#define BFA_LOG_LINUX_ITNIM_OFFLINE \
-               (((u32) BFA_LOG_LINUX_ID << BFA_LOG_MODID_OFFSET) | 8)
-#define BFA_LOG_LINUX_SCSI_HOST_FREE \
-               (((u32) BFA_LOG_LINUX_ID << BFA_LOG_MODID_OFFSET) | 9)
-#define BFA_LOG_LINUX_SCSI_ABORT \
-               (((u32) BFA_LOG_LINUX_ID << BFA_LOG_MODID_OFFSET) | 10)
-#define BFA_LOG_LINUX_SCSI_ABORT_COMP \
-               (((u32) BFA_LOG_LINUX_ID << BFA_LOG_MODID_OFFSET) | 11)
-#define BFA_LOG_LINUX_DRIVER_CONFIG_ERROR \
-               (((u32) BFA_LOG_LINUX_ID << BFA_LOG_MODID_OFFSET) | 12)
-#define BFA_LOG_LINUX_BNA_STATE_MACHINE \
-               (((u32) BFA_LOG_LINUX_ID << BFA_LOG_MODID_OFFSET) | 13)
-#define BFA_LOG_LINUX_IOC_ERROR \
-       (((u32) BFA_LOG_LINUX_ID << BFA_LOG_MODID_OFFSET) | 14)
-#define BFA_LOG_LINUX_RESOURCE_ALLOC_ERROR \
-       (((u32) BFA_LOG_LINUX_ID << BFA_LOG_MODID_OFFSET) | 15)
-#define BFA_LOG_LINUX_RING_BUFFER_ERROR \
-       (((u32) BFA_LOG_LINUX_ID << BFA_LOG_MODID_OFFSET) | 16)
-#define BFA_LOG_LINUX_DRIVER_ERROR \
-       (((u32) BFA_LOG_LINUX_ID << BFA_LOG_MODID_OFFSET) | 17)
-#define BFA_LOG_LINUX_DRIVER_INFO \
-       (((u32) BFA_LOG_LINUX_ID << BFA_LOG_MODID_OFFSET) | 18)
-#define BFA_LOG_LINUX_DRIVER_DIAG \
-       (((u32) BFA_LOG_LINUX_ID << BFA_LOG_MODID_OFFSET) | 19)
-#define BFA_LOG_LINUX_DRIVER_AEN \
-       (((u32) BFA_LOG_LINUX_ID << BFA_LOG_MODID_OFFSET) | 20)
-#endif
diff --git a/drivers/scsi/bfa/include/log/bfa_log_wdrv.h b/drivers/scsi/bfa/include/log/bfa_log_wdrv.h
deleted file mode 100644 (file)
index 809a95f..0000000
+++ /dev/null
@@ -1,36 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/*
- * messages define for WDRV Module
- */
-#ifndef        __BFA_LOG_WDRV_H__
-#define        __BFA_LOG_WDRV_H__
-#include  <cs/bfa_log.h>
-#define BFA_LOG_WDRV_IOC_INIT_ERROR    \
-       (((u32) BFA_LOG_WDRV_ID << BFA_LOG_MODID_OFFSET) | 1)
-#define BFA_LOG_WDRV_IOC_INTERNAL_ERROR \
-       (((u32) BFA_LOG_WDRV_ID << BFA_LOG_MODID_OFFSET) | 2)
-#define BFA_LOG_WDRV_IOC_START_ERROR   \
-       (((u32) BFA_LOG_WDRV_ID << BFA_LOG_MODID_OFFSET) | 3)
-#define BFA_LOG_WDRV_IOC_STOP_ERROR    \
-       (((u32) BFA_LOG_WDRV_ID << BFA_LOG_MODID_OFFSET) | 4)
-#define BFA_LOG_WDRV_INSUFFICIENT_RESOURCES \
-       (((u32) BFA_LOG_WDRV_ID << BFA_LOG_MODID_OFFSET) | 5)
-#define BFA_LOG_WDRV_BASE_ADDRESS_MAP_ERROR \
-       (((u32) BFA_LOG_WDRV_ID << BFA_LOG_MODID_OFFSET) | 6)
-#endif
diff --git a/drivers/scsi/bfa/include/protocol/ct.h b/drivers/scsi/bfa/include/protocol/ct.h
deleted file mode 100644 (file)
index b82540a..0000000
+++ /dev/null
@@ -1,492 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __CT_H__
-#define __CT_H__
-
-#include <protocol/types.h>
-
-#pragma pack(1)
-
-struct ct_hdr_s{
-       u32     rev_id:8;       /* Revision of the CT */
-       u32     in_id:24;       /* Initiator Id */
-       u32     gs_type:8;      /* Generic service Type */
-       u32     gs_sub_type:8;  /* Generic service sub type */
-       u32     options:8;      /* options */
-       u32     rsvrd:8;        /* reserved */
-       u32     cmd_rsp_code:16;/* ct command/response code */
-       u32     max_res_size:16;/* maximum/residual size */
-       u32     frag_id:8;      /* fragment ID */
-       u32     reason_code:8;  /* reason code */
-       u32     exp_code:8;     /* explanation code */
-       u32     vendor_unq:8;   /* vendor unique */
-};
-
-/*
- * defines for the Revision
- */
-enum {
-       CT_GS3_REVISION = 0x01,
-};
-
-/*
- * defines for gs_type
- */
-enum {
-       CT_GSTYPE_KEYSERVICE    = 0xF7,
-       CT_GSTYPE_ALIASSERVICE  = 0xF8,
-       CT_GSTYPE_MGMTSERVICE   = 0xFA,
-       CT_GSTYPE_TIMESERVICE   = 0xFB,
-       CT_GSTYPE_DIRSERVICE    = 0xFC,
-};
-
-/*
- * defines for gs_sub_type for gs type directory service
- */
-enum {
-       CT_GSSUBTYPE_NAMESERVER = 0x02,
-};
-
-/*
- * defines for gs_sub_type for gs type management service
- */
-enum {
-       CT_GSSUBTYPE_CFGSERVER  = 0x01,
-       CT_GSSUBTYPE_UNZONED_NS = 0x02,
-       CT_GSSUBTYPE_ZONESERVER = 0x03,
-       CT_GSSUBTYPE_LOCKSERVER = 0x04,
-       CT_GSSUBTYPE_HBA_MGMTSERVER = 0x10,     /* for FDMI */
-};
-
-/*
- * defines for CT response code field
- */
-enum {
-       CT_RSP_REJECT = 0x8001,
-       CT_RSP_ACCEPT = 0x8002,
-};
-
-/*
- * definitions for CT reason code
- */
-enum {
-       CT_RSN_INV_CMD          = 0x01,
-       CT_RSN_INV_VER          = 0x02,
-       CT_RSN_LOGIC_ERR        = 0x03,
-       CT_RSN_INV_SIZE         = 0x04,
-       CT_RSN_LOGICAL_BUSY     = 0x05,
-       CT_RSN_PROTO_ERR        = 0x07,
-       CT_RSN_UNABLE_TO_PERF   = 0x09,
-       CT_RSN_NOT_SUPP                 = 0x0B,
-       CT_RSN_SERVER_NOT_AVBL  = 0x0D,
-       CT_RSN_SESSION_COULD_NOT_BE_ESTBD = 0x0E,
-       CT_RSN_VENDOR_SPECIFIC  = 0xFF,
-
-};
-
-/*
- * definitions for explanations code for Name server
- */
-enum {
-       CT_NS_EXP_NOADDITIONAL  = 0x00,
-       CT_NS_EXP_ID_NOT_REG    = 0x01,
-       CT_NS_EXP_PN_NOT_REG    = 0x02,
-       CT_NS_EXP_NN_NOT_REG    = 0x03,
-       CT_NS_EXP_CS_NOT_REG    = 0x04,
-       CT_NS_EXP_IPN_NOT_REG   = 0x05,
-       CT_NS_EXP_IPA_NOT_REG   = 0x06,
-       CT_NS_EXP_FT_NOT_REG    = 0x07,
-       CT_NS_EXP_SPN_NOT_REG   = 0x08,
-       CT_NS_EXP_SNN_NOT_REG   = 0x09,
-       CT_NS_EXP_PT_NOT_REG    = 0x0A,
-       CT_NS_EXP_IPP_NOT_REG   = 0x0B,
-       CT_NS_EXP_FPN_NOT_REG   = 0x0C,
-       CT_NS_EXP_HA_NOT_REG    = 0x0D,
-       CT_NS_EXP_FD_NOT_REG    = 0x0E,
-       CT_NS_EXP_FF_NOT_REG    = 0x0F,
-       CT_NS_EXP_ACCESSDENIED  = 0x10,
-       CT_NS_EXP_UNACCEPTABLE_ID = 0x11,
-       CT_NS_EXP_DATABASEEMPTY                 = 0x12,
-       CT_NS_EXP_NOT_REG_IN_SCOPE              = 0x13,
-       CT_NS_EXP_DOM_ID_NOT_PRESENT    = 0x14,
-       CT_NS_EXP_PORT_NUM_NOT_PRESENT  = 0x15,
-       CT_NS_EXP_NO_DEVICE_ATTACHED    = 0x16
-};
-
-/*
- * definitions for the explanation code for all servers
- */
-enum {
-       CT_EXP_AUTH_EXCEPTION                   = 0xF1,
-       CT_EXP_DB_FULL                                  = 0xF2,
-       CT_EXP_DB_EMPTY                                 = 0xF3,
-       CT_EXP_PROCESSING_REQ                   = 0xF4,
-       CT_EXP_UNABLE_TO_VERIFY_CONN    = 0xF5,
-       CT_EXP_DEVICES_NOT_IN_CMN_ZONE  = 0xF6
-};
-
-/*
- * Command codes for Name server
- */
-enum {
-       GS_GID_PN       = 0x0121,       /* Get Id on port name */
-       GS_GPN_ID       = 0x0112,       /* Get port name on ID */
-       GS_GNN_ID       = 0x0113,       /* Get node name on ID */
-       GS_GID_FT       = 0x0171,       /* Get Id on FC4 type */
-       GS_GSPN_ID      = 0x0118,       /* Get symbolic PN on ID */
-       GS_RFT_ID       = 0x0217,       /* Register fc4type on ID */
-       GS_RSPN_ID      = 0x0218,       /* Register symbolic PN on ID */
-       GS_RPN_ID       = 0x0212,       /* Register port name */
-       GS_RNN_ID       = 0x0213,       /* Register node name */
-       GS_RCS_ID       = 0x0214,       /* Register class of service */
-       GS_RPT_ID       = 0x021A,       /* Register port type */
-       GS_GA_NXT       = 0x0100,       /* Get all next */
-       GS_RFF_ID       = 0x021F,       /* Register FC4 Feature         */
-};
-
-struct fcgs_id_req_s{
-       u32     rsvd:8;
-       u32     dap:24; /* port identifier */
-};
-#define fcgs_gpnid_req_t struct fcgs_id_req_s
-#define fcgs_gnnid_req_t struct fcgs_id_req_s
-#define fcgs_gspnid_req_t struct fcgs_id_req_s
-
-struct fcgs_gidpn_req_s{
-       wwn_t   port_name;      /* port wwn */
-};
-
-struct fcgs_gidpn_resp_s{
-       u32     rsvd:8;
-       u32     dap:24; /* port identifier */
-};
-
-/**
- * RFT_ID
- */
-struct fcgs_rftid_req_s {
-       u32     rsvd:8;
-       u32     dap:24;         /* port identifier */
-       u32     fc4_type[8];    /* fc4 types */
-};
-
-/**
- * RFF_ID : Register FC4 features.
- */
-
-#define FC_GS_FCP_FC4_FEATURE_INITIATOR  0x02
-#define FC_GS_FCP_FC4_FEATURE_TARGET    0x01
-
-struct fcgs_rffid_req_s{
-    u32    rsvd:8;
-    u32    dap:24;             /* port identifier      */
-    u32    rsvd1:16;
-    u32    fc4ftr_bits:8;      /* fc4 feature bits     */
-    u32    fc4_type:8; /* corresponding FC4 Type */
-};
-
-/**
- * GID_FT Request
- */
-struct fcgs_gidft_req_s{
-       u8      reserved;
-       u8      domain_id;      /* domain, 0 - all fabric */
-       u8      area_id;        /* area, 0 - whole domain */
-       u8      fc4_type;       /* FC_TYPE_FCP for SCSI devices */
-};                             /* GID_FT Request */
-
-/**
- * GID_FT Response
- */
-struct fcgs_gidft_resp_s {
-       u8              last:1; /* last port identifier flag */
-       u8              reserved:7;
-       u32     pid:24; /* port identifier */
-};                             /* GID_FT Response */
-
-/**
- * RSPN_ID
- */
-struct fcgs_rspnid_req_s{
-       u32     rsvd:8;
-       u32     dap:24;         /* port identifier */
-       u8              spn_len;        /* symbolic port name length */
-       u8              spn[256];       /* symbolic port name */
-};
-
-/**
- * RPN_ID
- */
-struct fcgs_rpnid_req_s{
-       u32     rsvd:8;
-       u32     port_id:24;
-       wwn_t           port_name;
-};
-
-/**
- * RNN_ID
- */
-struct fcgs_rnnid_req_s{
-       u32     rsvd:8;
-       u32     port_id:24;
-       wwn_t           node_name;
-};
-
-/**
- * RCS_ID
- */
-struct fcgs_rcsid_req_s{
-       u32     rsvd:8;
-       u32     port_id:24;
-       u32     cos;
-};
-
-/**
- * RPT_ID
- */
-struct fcgs_rptid_req_s{
-       u32     rsvd:8;
-       u32     port_id:24;
-       u32     port_type:8;
-       u32     rsvd1:24;
-};
-
-/**
- * GA_NXT Request
- */
-struct fcgs_ganxt_req_s{
-       u32     rsvd:8;
-       u32     port_id:24;
-};
-
-/**
- * GA_NXT Response
- */
-struct fcgs_ganxt_rsp_s{
-       u32     port_type:8;    /* Port Type */
-       u32     port_id:24;     /* Port Identifier */
-       wwn_t           port_name;      /* Port Name */
-       u8              spn_len;        /* Length of Symbolic Port Name */
-       char            spn[255];       /* Symbolic Port Name */
-       wwn_t           node_name;      /* Node Name */
-       u8              snn_len;        /* Length of Symbolic Node Name */
-       char            snn[255];       /* Symbolic Node Name */
-       u8              ipa[8];         /* Initial Process Associator */
-       u8              ip[16];         /* IP Address */
-       u32     cos;            /* Class of Service */
-       u32     fc4types[8];    /* FC-4 TYPEs */
-       wwn_t           fabric_port_name;
-                                       /* Fabric Port Name */
-       u32     rsvd:8;         /* Reserved */
-       u32     hard_addr:24;   /* Hard Address */
-};
-
-/*
- * Fabric Config Server
- */
-
-/*
- * Command codes for Fabric Configuration Server
- */
-enum {
-       GS_FC_GFN_CMD   = 0x0114,       /* GS FC Get Fabric Name  */
-       GS_FC_GMAL_CMD  = 0x0116,       /* GS FC GMAL  */
-       GS_FC_TRACE_CMD = 0x0400,       /* GS FC Trace Route */
-       GS_FC_PING_CMD  = 0x0401,       /* GS FC Ping */
-};
-
-/*
- * Source or Destination Port Tags.
- */
-enum {
-       GS_FTRACE_TAG_NPORT_ID          = 1,
-       GS_FTRACE_TAG_NPORT_NAME        = 2,
-};
-
-/*
-* Port Value : Could be a Port id or wwn
- */
-union fcgs_port_val_u{
-       u32     nport_id;
-       wwn_t           nport_wwn;
-};
-
-#define GS_FTRACE_MAX_HOP_COUNT        20
-#define GS_FTRACE_REVISION     1
-
-/*
- * Ftrace Related Structures.
- */
-
-/*
- * STR (Switch Trace) Reject Reason Codes. From FC-SW.
- */
-enum {
-       GS_FTRACE_STR_CMD_COMPLETED_SUCC        = 0,
-       GS_FTRACE_STR_CMD_NOT_SUPP_IN_NEXT_SWITCH,
-       GS_FTRACE_STR_NO_RESP_FROM_NEXT_SWITCH,
-       GS_FTRACE_STR_MAX_HOP_CNT_REACHED,
-       GS_FTRACE_STR_SRC_PORT_NOT_FOUND,
-       GS_FTRACE_STR_DST_PORT_NOT_FOUND,
-       GS_FTRACE_STR_DEVICES_NOT_IN_COMMON_ZONE,
-       GS_FTRACE_STR_NO_ROUTE_BW_PORTS,
-       GS_FTRACE_STR_NO_ADDL_EXPLN,
-       GS_FTRACE_STR_FABRIC_BUSY,
-       GS_FTRACE_STR_FABRIC_BUILD_IN_PROGRESS,
-       GS_FTRACE_STR_VENDOR_SPECIFIC_ERR_START = 0xf0,
-       GS_FTRACE_STR_VENDOR_SPECIFIC_ERR_END = 0xff,
-};
-
-/*
- * Ftrace Request
- */
-struct fcgs_ftrace_req_s{
-       u32     revision;
-       u16     src_port_tag;   /* Source Port tag */
-       u16     src_port_len;   /* Source Port len */
-       union fcgs_port_val_u src_port_val;     /* Source Port value */
-       u16     dst_port_tag;   /* Destination Port tag */
-       u16     dst_port_len;   /* Destination Port len */
-       union fcgs_port_val_u dst_port_val;     /* Destination Port value */
-       u32     token;
-       u8              vendor_id[8];   /* T10 Vendor Identifier */
-       u8              vendor_info[8]; /* Vendor specific Info */
-       u32     max_hop_cnt;    /* Max Hop Count */
-};
-
-/*
- * Path info structure
- */
-struct fcgs_ftrace_path_info_s{
-       wwn_t           switch_name;            /* Switch WWN */
-       u32     domain_id;
-       wwn_t           ingress_port_name;      /* Ingress ports wwn */
-       u32     ingress_phys_port_num;  /* Ingress ports physical port
-                                                * number
-                                                */
-       wwn_t           egress_port_name;       /* Ingress ports wwn */
-       u32     egress_phys_port_num;   /* Ingress ports physical port
-                                                * number
-                                                */
-};
-
-/*
- * Ftrace Acc Response
- */
-struct fcgs_ftrace_resp_s{
-       u32     revision;
-       u32     token;
-       u8              vendor_id[8];           /* T10 Vendor Identifier */
-       u8              vendor_info[8];         /* Vendor specific Info */
-       u32     str_rej_reason_code;    /* STR Reject Reason Code */
-       u32     num_path_info_entries;  /* No. of path info entries */
-       /*
-        * path info entry/entries.
-        */
-       struct fcgs_ftrace_path_info_s path_info[1];
-
-};
-
-/*
-* Fabric Config Server : FCPing
- */
-
-/*
- * FC Ping Request
- */
-struct fcgs_fcping_req_s{
-       u32     revision;
-       u16     port_tag;
-       u16     port_len;       /* Port len */
-       union fcgs_port_val_u port_val; /* Port value */
-       u32     token;
-};
-
-/*
- * FC Ping Response
- */
-struct fcgs_fcping_resp_s{
-       u32     token;
-};
-
-/*
- * Command codes for zone server query.
- */
-enum {
-       ZS_GZME = 0x0124,       /* Get zone member extended */
-};
-
-/*
- * ZS GZME request
- */
-#define ZS_GZME_ZNAMELEN       32
-struct zs_gzme_req_s{
-       u8      znamelen;
-       u8      rsvd[3];
-       u8      zname[ZS_GZME_ZNAMELEN];
-};
-
-enum zs_mbr_type{
-       ZS_MBR_TYPE_PWWN        = 1,
-       ZS_MBR_TYPE_DOMPORT     = 2,
-       ZS_MBR_TYPE_PORTID      = 3,
-       ZS_MBR_TYPE_NWWN        = 4,
-};
-
-struct zs_mbr_wwn_s{
-       u8      mbr_type;
-       u8      rsvd[3];
-       wwn_t   wwn;
-};
-
-struct zs_query_resp_s{
-       u32     nmbrs;  /*  number of zone members */
-       struct zs_mbr_wwn_s     mbr[1];
-};
-
-/*
- * GMAL Command ( Get ( interconnect Element) Management Address List)
- * To retrieve the IP Address of a Switch.
- */
-
-#define CT_GMAL_RESP_PREFIX_TELNET      "telnet://"
-#define CT_GMAL_RESP_PREFIX_HTTP        "http://"
-
-/*  GMAL/GFN request */
-struct fcgs_req_s {
-       wwn_t    wwn;   /* PWWN/NWWN */
-};
-
-#define fcgs_gmal_req_t struct fcgs_req_s
-#define fcgs_gfn_req_t struct fcgs_req_s
-
-/* Accept Response to GMAL */
-struct fcgs_gmal_resp_s {
-       u32             ms_len;   /* Num of entries */
-       u8      ms_ma[256];
-};
-
-struct fc_gmal_entry_s {
-       u8  len;
-       u8  prefix[7]; /* like "http://" */
-       u8  ip_addr[248];
-};
-
-#pragma pack()
-
-#endif
diff --git a/drivers/scsi/bfa/include/protocol/fc.h b/drivers/scsi/bfa/include/protocol/fc.h
deleted file mode 100644 (file)
index 436dd7c..0000000
+++ /dev/null
@@ -1,1111 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __FC_H__
-#define __FC_H__
-
-#include <protocol/types.h>
-
-#pragma pack(1)
-
-/*
- * Fibre Channel Header Structure (FCHS) definition
- */
-struct fchs_s {
-#ifdef __BIGENDIAN
-       u32        routing:4;   /* routing bits */
-       u32        cat_info:4;  /* category info */
-#else
-       u32        cat_info:4;  /* category info */
-       u32        routing:4;   /* routing bits */
-#endif
-       u32        d_id:24;     /* destination identifier */
-
-       u32        cs_ctl:8;    /* class specific control */
-       u32        s_id:24;     /* source identifier */
-
-       u32        type:8;              /* data structure type */
-       u32        f_ctl:24;    /* initial frame control */
-
-       u8         seq_id;              /* sequence identifier */
-       u8         df_ctl;              /* data field control */
-       u16        seq_cnt;     /* sequence count */
-
-       u16        ox_id;               /* originator exchange ID */
-       u16        rx_id;               /* responder exchange ID */
-
-       u32        ro;          /* relative offset */
-};
-
-#define FC_SOF_LEN      4
-#define FC_EOF_LEN      4
-#define FC_CRC_LEN      4
-
-/*
- * Fibre Channel BB_E Header Structure
- */
-struct fcbbehs_s {
-       u16     ver_rsvd;
-       u32     rsvd[2];
-       u32     rsvd__sof;
-};
-
-#define FC_SEQ_ID_MAX          256
-
-/*
- * routing bit definitions
- */
-enum {
-       FC_RTG_FC4_DEV_DATA     = 0x0,  /* FC-4 Device Data */
-       FC_RTG_EXT_LINK         = 0x2,  /* Extended Link Data */
-       FC_RTG_FC4_LINK_DATA    = 0x3,  /* FC-4 Link Data */
-       FC_RTG_VIDEO_DATA       = 0x4,  /* Video Data */
-       FC_RTG_EXT_HDR          = 0x5,  /* VFT, IFR or Encapsuled */
-       FC_RTG_BASIC_LINK       = 0x8,  /* Basic Link data */
-       FC_RTG_LINK_CTRL        = 0xC,  /* Link Control */
-};
-
-/*
- * information category for extended link data and FC-4 Link Data
- */
-enum {
-       FC_CAT_LD_REQUEST       = 0x2,  /* Request */
-       FC_CAT_LD_REPLY         = 0x3,  /* Reply */
-       FC_CAT_LD_DIAG          = 0xF,  /* for DIAG use only */
-};
-
-/*
- * information category for extended headers (VFT, IFR or encapsulation)
- */
-enum {
-       FC_CAT_VFT_HDR = 0x0,   /* Virtual fabric tagging header */
-       FC_CAT_IFR_HDR = 0x1,   /* Inter-Fabric routing header */
-       FC_CAT_ENC_HDR = 0x2,   /* Encapsulation header */
-};
-
-/*
- * information category for FC-4 device data
- */
-enum {
-       FC_CAT_UNCATEG_INFO     = 0x0,  /* Uncategorized information */
-       FC_CAT_SOLICIT_DATA     = 0x1,  /* Solicited Data */
-       FC_CAT_UNSOLICIT_CTRL   = 0x2,  /* Unsolicited Control */
-       FC_CAT_SOLICIT_CTRL     = 0x3,  /* Solicited Control */
-       FC_CAT_UNSOLICIT_DATA   = 0x4,  /* Unsolicited Data */
-       FC_CAT_DATA_DESC        = 0x5,  /* Data Descriptor */
-       FC_CAT_UNSOLICIT_CMD    = 0x6,  /* Unsolicited Command */
-       FC_CAT_CMD_STATUS       = 0x7,  /* Command Status */
-};
-
-/*
- * information category for Link Control
- */
-enum {
-       FC_CAT_ACK_1            = 0x00,
-       FC_CAT_ACK_0_N          = 0x01,
-       FC_CAT_P_RJT            = 0x02,
-       FC_CAT_F_RJT            = 0x03,
-       FC_CAT_P_BSY            = 0x04,
-       FC_CAT_F_BSY_DATA       = 0x05,
-       FC_CAT_F_BSY_LINK_CTL   = 0x06,
-       FC_CAT_F_LCR            = 0x07,
-       FC_CAT_NTY              = 0x08,
-       FC_CAT_END              = 0x09,
-};
-
-/*
- * Type Field Definitions. FC-PH Section 18.5 pg. 165
- */
-enum {
-       FC_TYPE_BLS             = 0x0,  /* Basic Link Service */
-       FC_TYPE_ELS             = 0x1,  /* Extended Link Service */
-       FC_TYPE_IP              = 0x5,  /* IP */
-       FC_TYPE_FCP             = 0x8,  /* SCSI-FCP */
-       FC_TYPE_GPP             = 0x9,  /* SCSI_GPP */
-       FC_TYPE_SERVICES        = 0x20, /* Fibre Channel Services */
-       FC_TYPE_FC_FSS          = 0x22, /* Fabric Switch Services */
-       FC_TYPE_FC_AL           = 0x23, /* FC-AL */
-       FC_TYPE_FC_SNMP         = 0x24, /* FC-SNMP */
-       FC_TYPE_MAX             = 256,  /* 256 FC-4 types */
-};
-
-struct fc_fc4types_s{
-       u8         bits[FC_TYPE_MAX / 8];
-};
-
-/*
- * Frame Control Definitions. FC-PH Table-45. pg. 168
- */
-enum {
-       FCTL_EC_ORIG = 0x000000,        /* exchange originator */
-       FCTL_EC_RESP = 0x800000,        /* exchange responder */
-       FCTL_SEQ_INI = 0x000000,        /* sequence initiator */
-       FCTL_SEQ_REC = 0x400000,        /* sequence recipient */
-       FCTL_FS_EXCH = 0x200000,        /* first sequence of xchg */
-       FCTL_LS_EXCH = 0x100000,        /* last sequence of xchg */
-       FCTL_END_SEQ = 0x080000,        /* last frame of sequence */
-       FCTL_SI_XFER = 0x010000,        /* seq initiative transfer */
-       FCTL_RO_PRESENT = 0x000008,     /* relative offset present */
-       FCTL_FILLBYTE_MASK = 0x000003   /* , fill byte mask */
-};
-
-/*
- * Fabric Well Known Addresses
- */
-enum {
-       FC_MIN_WELL_KNOWN_ADDR          = 0xFFFFF0,
-       FC_DOMAIN_CONTROLLER_MASK       = 0xFFFC00,
-       FC_ALIAS_SERVER                 = 0xFFFFF8,
-       FC_MGMT_SERVER                  = 0xFFFFFA,
-       FC_TIME_SERVER                  = 0xFFFFFB,
-       FC_NAME_SERVER                  = 0xFFFFFC,
-       FC_FABRIC_CONTROLLER            = 0xFFFFFD,
-       FC_FABRIC_PORT                  = 0xFFFFFE,
-       FC_BROADCAST_SERVER             = 0xFFFFFF
-};
-
-/*
- * domain/area/port defines
- */
-#define FC_DOMAIN_MASK  0xFF0000
-#define FC_DOMAIN_SHIFT 16
-#define FC_AREA_MASK    0x00FF00
-#define FC_AREA_SHIFT   8
-#define FC_PORT_MASK    0x0000FF
-#define FC_PORT_SHIFT   0
-
-#define FC_GET_DOMAIN(p)       (((p) & FC_DOMAIN_MASK) >> FC_DOMAIN_SHIFT)
-#define FC_GET_AREA(p)         (((p) & FC_AREA_MASK) >> FC_AREA_SHIFT)
-#define FC_GET_PORT(p)         (((p) & FC_PORT_MASK) >> FC_PORT_SHIFT)
-
-#define FC_DOMAIN_CTRLR(p)     (FC_DOMAIN_CONTROLLER_MASK | (FC_GET_DOMAIN(p)))
-
-enum {
-       FC_RXID_ANY = 0xFFFFU,
-};
-
-/*
- * generic ELS command
- */
-struct fc_els_cmd_s{
-       u32        els_code:8;  /* ELS Command Code */
-       u32        reserved:24;
-};
-
-/*
- * ELS Command Codes. FC-PH Table-75. pg. 223
- */
-enum {
-       FC_ELS_LS_RJT = 0x1,    /* Link Service Reject. */
-       FC_ELS_ACC = 0x02,      /* Accept */
-       FC_ELS_PLOGI = 0x03,    /* N_Port Login. */
-       FC_ELS_FLOGI = 0x04,    /* F_Port Login. */
-       FC_ELS_LOGO = 0x05,     /* Logout. */
-       FC_ELS_ABTX = 0x06,     /* Abort Exchange */
-       FC_ELS_RES = 0x08,      /* Read Exchange status */
-       FC_ELS_RSS = 0x09,      /* Read sequence status block */
-       FC_ELS_RSI = 0x0A,      /* Request Sequence Initiative */
-       FC_ELS_ESTC = 0x0C,     /* Estimate Credit. */
-       FC_ELS_RTV = 0x0E,      /* Read Timeout Value. */
-       FC_ELS_RLS = 0x0F,      /* Read Link Status. */
-       FC_ELS_ECHO = 0x10,     /* Echo */
-       FC_ELS_TEST = 0x11,     /* Test */
-       FC_ELS_RRQ = 0x12,      /* Reinstate Recovery Qualifier. */
-       FC_ELS_REC = 0x13,      /* Add this for TAPE support in FCR */
-       FC_ELS_PRLI = 0x20,     /* Process Login */
-       FC_ELS_PRLO = 0x21,     /* Process Logout. */
-       FC_ELS_SCN = 0x22,      /* State Change Notification. */
-       FC_ELS_TPRLO = 0x24,    /* Third Party Process Logout. */
-       FC_ELS_PDISC = 0x50,    /* Discover N_Port Parameters. */
-       FC_ELS_FDISC = 0x51,    /* Discover F_Port Parameters. */
-       FC_ELS_ADISC = 0x52,    /* Discover Address. */
-       FC_ELS_FAN = 0x60,      /* Fabric Address Notification */
-       FC_ELS_RSCN = 0x61,     /* Reg State Change Notification */
-       FC_ELS_SCR = 0x62,      /* State Change Registration. */
-       FC_ELS_RTIN = 0x77,     /* Mangement server request */
-       FC_ELS_RNID = 0x78,     /* Mangement server request */
-       FC_ELS_RLIR = 0x79,     /* Registered Link Incident Record */
-
-       FC_ELS_RPSC = 0x7D,     /* Report Port Speed Capabilities */
-       FC_ELS_QSA = 0x7E,      /* Query Security Attributes. Ref FC-SP */
-       FC_ELS_E2E_LBEACON = 0x81,
-                               /* End-to-End Link Beacon */
-       FC_ELS_AUTH = 0x90,     /* Authentication. Ref FC-SP */
-       FC_ELS_RFCN = 0x97,     /* Request Fabric Change Notification. Ref
-                                *FC-SP */
-
-};
-
-/*
- *  Version numbers for FC-PH standards,
- *  used in login to indicate what port
- *  supports. See FC-PH-X table 158.
- */
-enum {
-       FC_PH_VER_4_3 = 0x09,
-       FC_PH_VER_PH_3 = 0x20,
-};
-
-/*
- * PDU size defines
- */
-enum {
-       FC_MIN_PDUSZ = 512,
-       FC_MAX_PDUSZ = 2112,
-};
-
-/*
- * N_Port PLOGI Common Service Parameters.
- * FC-PH-x. Figure-76. pg. 308.
- */
-struct fc_plogi_csp_s{
-       u8         verhi;       /* FC-PH high version */
-       u8         verlo;       /* FC-PH low version */
-       u16        bbcred;      /* BB_Credit */
-
-#ifdef __BIGENDIAN
-       u8         ciro:1,              /* continuously increasing RO */
-                       rro:1,          /* random relative offset */
-                       npiv_supp:1,    /* NPIV supported */
-                       port_type:1,    /* N_Port/F_port */
-                       altbbcred:1,    /* alternate BB_Credit */
-                       resolution:1,   /* ms/ns ED_TOV resolution */
-                       vvl_info:1,     /* VVL Info included */
-                       reserved1:1;
-
-       u8         hg_supp:1,
-                       query_dbc:1,
-                       security:1,
-                       sync_cap:1,
-                       r_t_tov:1,
-                       dh_dup_supp:1,
-                       cisc:1,         /* continuously increasing seq count */
-                       payload:1;
-#else
-       u8         reserved2:2,
-                       resolution:1,   /* ms/ns ED_TOV resolution */
-                       altbbcred:1,    /* alternate BB_Credit */
-                       port_type:1,    /* N_Port/F_port */
-                       npiv_supp:1,    /* NPIV supported */
-                       rro:1,          /* random relative offset */
-                       ciro:1;         /* continuously increasing RO */
-
-       u8         payload:1,
-                       cisc:1,         /* continuously increasing seq count */
-                       dh_dup_supp:1,
-                       r_t_tov:1,
-                       sync_cap:1,
-                       security:1,
-                       query_dbc:1,
-                       hg_supp:1;
-#endif
-
-       u16        rxsz;                /* recieve data_field size */
-
-       u16        conseq;
-       u16        ro_bitmap;
-
-       u32        e_d_tov;
-};
-
-/*
- * N_Port PLOGI Class Specific Parameters.
- * FC-PH-x. Figure 78. pg. 318.
- */
-struct fc_plogi_clp_s{
-#ifdef __BIGENDIAN
-       u32        class_valid:1;
-       u32        intermix:1;  /* class intermix supported if set =1.
-                                        * valid only for class1. Reserved for
-                                        * class2 & class3
-                                        */
-       u32        reserved1:2;
-       u32        sequential:1;
-       u32        reserved2:3;
-#else
-       u32        reserved2:3;
-       u32        sequential:1;
-       u32        reserved1:2;
-       u32        intermix:1;  /* class intermix supported if set =1.
-                                        * valid only for class1. Reserved for
-                                        * class2 & class3
-                                        */
-       u32        class_valid:1;
-#endif
-
-       u32        reserved3:24;
-
-       u32        reserved4:16;
-       u32        rxsz:16;     /* Receive data_field size */
-
-       u32        reserved5:8;
-       u32        conseq:8;
-       u32        e2e_credit:16;       /* end to end credit */
-
-       u32        reserved7:8;
-       u32        ospx:8;
-       u32        reserved8:16;
-};
-
-#define FLOGI_VVL_BRCD    0x42524344 /* ASCII value for each character in
-                                     * string "BRCD" */
-
-/*
- * PLOGI els command and reply payload
- */
-struct fc_logi_s{
-       struct fc_els_cmd_s els_cmd;    /* ELS command code */
-       struct fc_plogi_csp_s  csp;             /* common service params */
-       wwn_t           port_name;
-       wwn_t           node_name;
-       struct fc_plogi_clp_s  class1;          /* class 1 service parameters */
-       struct fc_plogi_clp_s  class2;          /* class 2 service parameters */
-       struct fc_plogi_clp_s  class3;          /* class 3 service parameters */
-       struct fc_plogi_clp_s  class4;          /* class 4 service parameters */
-       u8         vvl[16];     /* vendor version level */
-};
-
-/*
- * LOGO els command payload
- */
-struct fc_logo_s{
-       struct fc_els_cmd_s    els_cmd; /* ELS command code */
-       u32        res1:8;
-       u32        nport_id:24; /* N_Port identifier of source */
-       wwn_t           orig_port_name; /* Port name of the LOGO originator */
-};
-
-/*
- * ADISC els command payload
- */
-struct fc_adisc_s {
-       struct fc_els_cmd_s    els_cmd; /* ELS command code */
-       u32        res1:8;
-       u32        orig_HA:24;  /* originator hard address */
-       wwn_t           orig_port_name; /* originator port name */
-       wwn_t           orig_node_name; /* originator node name */
-       u32        res2:8;
-       u32        nport_id:24; /* originator NPortID */
-};
-
-/*
- * Exchange status block
- */
-struct fc_exch_status_blk_s{
-       u32        oxid:16;
-       u32        rxid:16;
-       u32        res1:8;
-       u32        orig_np:24;  /* originator NPortID */
-       u32        res2:8;
-       u32        resp_np:24;  /* responder NPortID */
-       u32        es_bits;
-       u32        res3;
-       /*
-        * un modified section of the fields
-        */
-};
-
-/*
- * RES els command payload
- */
-struct fc_res_s {
-       struct fc_els_cmd_s    els_cmd; /* ELS command code */
-       u32        res1:8;
-       u32        nport_id:24; /* N_Port identifier of source */
-       u32        oxid:16;
-       u32        rxid:16;
-       u8         assoc_hdr[32];
-};
-
-/*
- * RES els accept payload
- */
-struct fc_res_acc_s{
-       struct fc_els_cmd_s els_cmd;    /* ELS command code */
-       struct fc_exch_status_blk_s fc_exch_blk; /* Exchange status block */
-};
-
-/*
- * REC els command payload
- */
-struct fc_rec_s {
-       struct fc_els_cmd_s    els_cmd; /* ELS command code */
-       u32        res1:8;
-       u32        nport_id:24; /* N_Port identifier of source */
-       u32        oxid:16;
-       u32        rxid:16;
-};
-
-#define FC_REC_ESB_OWN_RSP     0x80000000      /* responder owns */
-#define FC_REC_ESB_SI          0x40000000      /* SI is owned  */
-#define FC_REC_ESB_COMP                0x20000000      /* exchange is complete */
-#define FC_REC_ESB_ENDCOND_ABN 0x10000000      /* abnormal ending      */
-#define FC_REC_ESB_RQACT       0x04000000      /* recovery qual active */
-#define FC_REC_ESB_ERRP_MSK    0x03000000
-#define FC_REC_ESB_OXID_INV    0x00800000      /* invalid OXID         */
-#define FC_REC_ESB_RXID_INV    0x00400000      /* invalid RXID         */
-#define FC_REC_ESB_PRIO_INUSE  0x00200000
-
-/*
- * REC els accept payload
- */
-struct fc_rec_acc_s {
-       struct fc_els_cmd_s    els_cmd; /* ELS command code */
-       u32        oxid:16;
-       u32        rxid:16;
-       u32        res1:8;
-       u32        orig_id:24;  /* N_Port id of exchange originator */
-       u32        res2:8;
-       u32        resp_id:24;  /* N_Port id of exchange responder */
-       u32        count;               /* data transfer count */
-       u32        e_stat;              /* exchange status */
-};
-
-/*
- * RSI els payload
- */
-struct fc_rsi_s {
-       struct fc_els_cmd_s    els_cmd;
-       u32        res1:8;
-       u32        orig_sid:24;
-       u32        oxid:16;
-       u32        rxid:16;
-};
-
-/*
- * structure for PRLI paramater pages, both request & response
- * see FC-PH-X table 113 & 115 for explanation also FCP table 8
- */
-struct fc_prli_params_s{
-       u32        reserved:16;
-#ifdef __BIGENDIAN
-       u32        reserved1:5;
-       u32        rec_support:1;
-       u32        task_retry_id:1;
-       u32        retry:1;
-
-       u32        confirm:1;
-       u32        doverlay:1;
-       u32        initiator:1;
-       u32        target:1;
-       u32        cdmix:1;
-       u32        drmix:1;
-       u32        rxrdisab:1;
-       u32        wxrdisab:1;
-#else
-       u32        retry:1;
-       u32        task_retry_id:1;
-       u32        rec_support:1;
-       u32        reserved1:5;
-
-       u32        wxrdisab:1;
-       u32        rxrdisab:1;
-       u32        drmix:1;
-       u32        cdmix:1;
-       u32        target:1;
-       u32        initiator:1;
-       u32        doverlay:1;
-       u32        confirm:1;
-#endif
-};
-
-/*
- * valid values for rspcode in PRLI ACC payload
- */
-enum {
-       FC_PRLI_ACC_XQTD = 0x1,         /* request executed */
-       FC_PRLI_ACC_PREDEF_IMG = 0x5,   /* predefined image - no prli needed */
-};
-
-struct fc_prli_params_page_s{
-       u32        type:8;
-       u32        codext:8;
-#ifdef __BIGENDIAN
-       u32        origprocasv:1;
-       u32        rsppav:1;
-       u32        imagepair:1;
-       u32        reserved1:1;
-       u32        rspcode:4;
-#else
-       u32        rspcode:4;
-       u32        reserved1:1;
-       u32        imagepair:1;
-       u32        rsppav:1;
-       u32        origprocasv:1;
-#endif
-       u32        reserved2:8;
-
-       u32        origprocas;
-       u32        rspprocas;
-       struct fc_prli_params_s  servparams;
-};
-
-/*
- * PRLI request and accept payload, FC-PH-X tables 112 & 114
- */
-struct fc_prli_s{
-       u32        command:8;
-       u32        pglen:8;
-       u32        pagebytes:16;
-       struct fc_prli_params_page_s parampage;
-};
-
-/*
- * PRLO logout params page
- */
-struct fc_prlo_params_page_s{
-       u32        type:8;
-       u32        type_ext:8;
-#ifdef __BIGENDIAN
-       u32        opa_valid:1; /* originator process associator
-                                        * valid
-                                        */
-       u32        rpa_valid:1; /* responder process associator valid */
-       u32        res1:14;
-#else
-       u32        res1:14;
-       u32        rpa_valid:1; /* responder process associator valid */
-       u32        opa_valid:1; /* originator process associator
-                                        * valid
-                                        */
-#endif
-       u32        orig_process_assc;
-       u32        resp_process_assc;
-
-       u32        res2;
-};
-
-/*
- * PRLO els command payload
- */
-struct fc_prlo_s{
-       u32             command:8;
-       u32             page_len:8;
-       u32             payload_len:16;
-       struct fc_prlo_params_page_s    prlo_params[1];
-};
-
-/*
- * PRLO Logout response parameter page
- */
-struct fc_prlo_acc_params_page_s{
-       u32        type:8;
-       u32        type_ext:8;
-
-#ifdef __BIGENDIAN
-       u32        opa_valid:1; /* originator process associator
-                                        * valid
-                                        */
-       u32        rpa_valid:1; /* responder process associator valid */
-       u32        res1:14;
-#else
-       u32        res1:14;
-       u32        rpa_valid:1; /* responder process associator valid */
-       u32        opa_valid:1; /* originator process associator
-                                        * valid
-                                        */
-#endif
-       u32        orig_process_assc;
-       u32        resp_process_assc;
-
-       u32        fc4type_csp;
-};
-
-/*
- * PRLO els command ACC payload
- */
-struct fc_prlo_acc_s{
-       u32        command:8;
-       u32        page_len:8;
-       u32        payload_len:16;
-       struct fc_prlo_acc_params_page_s prlo_acc_params[1];
-};
-
-/*
- * SCR els command payload
- */
-enum {
-       FC_SCR_REG_FUNC_FABRIC_DETECTED = 0x01,
-       FC_SCR_REG_FUNC_N_PORT_DETECTED = 0x02,
-       FC_SCR_REG_FUNC_FULL = 0x03,
-       FC_SCR_REG_FUNC_CLEAR_REG = 0xFF,
-};
-
-/* SCR VU registrations */
-enum {
-       FC_VU_SCR_REG_FUNC_FABRIC_NAME_CHANGE = 0x01
-};
-
-struct fc_scr_s{
-       u32 command:8;
-       u32 res:24;
-       u32 vu_reg_func:8; /* Vendor Unique Registrations */
-       u32 res1:16;
-       u32 reg_func:8;
-};
-
-/*
- * Information category for Basic link data
- */
-enum {
-       FC_CAT_NOP      = 0x0,
-       FC_CAT_ABTS     = 0x1,
-       FC_CAT_RMC      = 0x2,
-       FC_CAT_BA_ACC   = 0x4,
-       FC_CAT_BA_RJT   = 0x5,
-       FC_CAT_PRMT     = 0x6,
-};
-
-/*
- * LS_RJT els reply payload
- */
-struct fc_ls_rjt_s {
-       struct fc_els_cmd_s    els_cmd;         /* ELS command code */
-       u32        res1:8;
-       u32        reason_code:8;               /* Reason code for reject */
-       u32        reason_code_expl:8;  /* Reason code explanation */
-       u32        vendor_unique:8;     /* Vendor specific */
-};
-
-/*
- * LS_RJT reason codes
- */
-enum {
-       FC_LS_RJT_RSN_INV_CMD_CODE      = 0x01,
-       FC_LS_RJT_RSN_LOGICAL_ERROR     = 0x03,
-       FC_LS_RJT_RSN_LOGICAL_BUSY      = 0x05,
-       FC_LS_RJT_RSN_PROTOCOL_ERROR    = 0x07,
-       FC_LS_RJT_RSN_UNABLE_TO_PERF_CMD = 0x09,
-       FC_LS_RJT_RSN_CMD_NOT_SUPP      = 0x0B,
-};
-
-/*
- * LS_RJT reason code explanation
- */
-enum {
-       FC_LS_RJT_EXP_NO_ADDL_INFO              = 0x00,
-       FC_LS_RJT_EXP_SPARMS_ERR_OPTIONS        = 0x01,
-       FC_LS_RJT_EXP_SPARMS_ERR_INI_CTL        = 0x03,
-       FC_LS_RJT_EXP_SPARMS_ERR_REC_CTL        = 0x05,
-       FC_LS_RJT_EXP_SPARMS_ERR_RXSZ           = 0x07,
-       FC_LS_RJT_EXP_SPARMS_ERR_CONSEQ         = 0x09,
-       FC_LS_RJT_EXP_SPARMS_ERR_CREDIT         = 0x0B,
-       FC_LS_RJT_EXP_INV_PORT_NAME             = 0x0D,
-       FC_LS_RJT_EXP_INV_NODE_FABRIC_NAME      = 0x0E,
-       FC_LS_RJT_EXP_INV_CSP                   = 0x0F,
-       FC_LS_RJT_EXP_INV_ASSOC_HDR             = 0x11,
-       FC_LS_RJT_EXP_ASSOC_HDR_REQD            = 0x13,
-       FC_LS_RJT_EXP_INV_ORIG_S_ID             = 0x15,
-       FC_LS_RJT_EXP_INV_OXID_RXID_COMB        = 0x17,
-       FC_LS_RJT_EXP_CMD_ALREADY_IN_PROG       = 0x19,
-       FC_LS_RJT_EXP_LOGIN_REQUIRED            = 0x1E,
-       FC_LS_RJT_EXP_INVALID_NPORT_ID          = 0x1F,
-       FC_LS_RJT_EXP_INSUFF_RES                = 0x29,
-       FC_LS_RJT_EXP_CMD_NOT_SUPP              = 0x2C,
-       FC_LS_RJT_EXP_INV_PAYLOAD_LEN           = 0x2D,
-};
-
-/*
- * RRQ els command payload
- */
-struct fc_rrq_s{
-       struct fc_els_cmd_s    els_cmd; /* ELS command code */
-       u32        res1:8;
-       u32        s_id:24;     /* exchange originator S_ID */
-
-       u32        ox_id:16;    /* originator exchange ID */
-       u32        rx_id:16;    /* responder exchange ID */
-
-       u32        res2[8];     /* optional association header */
-};
-
-/*
- * ABTS BA_ACC reply payload
- */
-struct fc_ba_acc_s{
-       u32        seq_id_valid:8;      /* set to 0x00 for Abort Exchange */
-       u32        seq_id:8;    /* invalid for Abort Exchange */
-       u32        res2:16;
-       u32        ox_id:16;    /* OX_ID from ABTS frame */
-       u32        rx_id:16;    /* RX_ID from ABTS frame */
-       u32        low_seq_cnt:16;      /* set to 0x0000 for Abort Exchange */
-       u32        high_seq_cnt:16;/* set to 0xFFFF for Abort Exchange */
-};
-
-/*
- * ABTS BA_RJT reject payload
- */
-struct fc_ba_rjt_s{
-       u32        res1:8;              /* Reserved */
-       u32        reason_code:8;       /* reason code for reject */
-       u32        reason_expl:8;       /* reason code explanation */
-       u32        vendor_unique:8;/* vendor unique reason code,set to 0 */
-};
-
-/*
- * TPRLO logout parameter page
- */
-struct fc_tprlo_params_page_s{
-       u32        type:8;
-       u32        type_ext:8;
-
-#ifdef __BIGENDIAN
-       u32        opa_valid:1;
-       u32        rpa_valid:1;
-       u32        tpo_nport_valid:1;
-       u32        global_process_logout:1;
-       u32        res1:12;
-#else
-       u32        res1:12;
-       u32        global_process_logout:1;
-       u32        tpo_nport_valid:1;
-       u32        rpa_valid:1;
-       u32        opa_valid:1;
-#endif
-
-       u32        orig_process_assc;
-       u32        resp_process_assc;
-
-       u32        res2:8;
-       u32        tpo_nport_id;
-};
-
-/*
- * TPRLO ELS command payload
- */
-struct fc_tprlo_s{
-       u32        command:8;
-       u32        page_len:8;
-       u32        payload_len:16;
-
-       struct fc_tprlo_params_page_s tprlo_params[1];
-};
-
-enum fc_tprlo_type{
-       FC_GLOBAL_LOGO = 1,
-       FC_TPR_LOGO
-};
-
-/*
- * TPRLO els command ACC payload
- */
-struct fc_tprlo_acc_s{
-       u32     command:8;
-       u32     page_len:8;
-       u32     payload_len:16;
-       struct fc_prlo_acc_params_page_s tprlo_acc_params[1];
-};
-
-/*
- * RSCN els command req payload
- */
-#define FC_RSCN_PGLEN  0x4
-
-enum fc_rscn_format{
-       FC_RSCN_FORMAT_PORTID   = 0x0,
-       FC_RSCN_FORMAT_AREA     = 0x1,
-       FC_RSCN_FORMAT_DOMAIN   = 0x2,
-       FC_RSCN_FORMAT_FABRIC   = 0x3,
-};
-
-struct fc_rscn_event_s{
-       u32        format:2;
-       u32        qualifier:4;
-       u32        resvd:2;
-       u32        portid:24;
-};
-
-struct fc_rscn_pl_s{
-       u8         command;
-       u8         pagelen;
-       u16        payldlen;
-       struct fc_rscn_event_s event[1];
-};
-
-/*
- * ECHO els command req payload
- */
-struct fc_echo_s {
-       struct fc_els_cmd_s    els_cmd;
-};
-
-/*
- * RNID els command
- */
-
-#define RNID_NODEID_DATA_FORMAT_COMMON                  0x00
-#define RNID_NODEID_DATA_FORMAT_FCP3                    0x08
-#define RNID_NODEID_DATA_FORMAT_DISCOVERY              0xDF
-
-#define RNID_ASSOCIATED_TYPE_UNKNOWN                    0x00000001
-#define RNID_ASSOCIATED_TYPE_OTHER                      0x00000002
-#define RNID_ASSOCIATED_TYPE_HUB                        0x00000003
-#define RNID_ASSOCIATED_TYPE_SWITCH                     0x00000004
-#define RNID_ASSOCIATED_TYPE_GATEWAY                    0x00000005
-#define RNID_ASSOCIATED_TYPE_STORAGE_DEVICE             0x00000009
-#define RNID_ASSOCIATED_TYPE_HOST                       0x0000000A
-#define RNID_ASSOCIATED_TYPE_STORAGE_SUBSYSTEM          0x0000000B
-#define RNID_ASSOCIATED_TYPE_STORAGE_ACCESS_DEVICE      0x0000000E
-#define RNID_ASSOCIATED_TYPE_NAS_SERVER                 0x00000011
-#define RNID_ASSOCIATED_TYPE_BRIDGE                     0x00000002
-#define RNID_ASSOCIATED_TYPE_VIRTUALIZATION_DEVICE      0x00000003
-#define RNID_ASSOCIATED_TYPE_MULTI_FUNCTION_DEVICE      0x000000FF
-
-/*
- * RNID els command payload
- */
-struct fc_rnid_cmd_s{
-       struct fc_els_cmd_s    els_cmd;
-       u32        node_id_data_format:8;
-       u32        reserved:24;
-};
-
-/*
- * RNID els response payload
- */
-
-struct fc_rnid_common_id_data_s{
-       wwn_t           port_name;
-       wwn_t           node_name;
-};
-
-struct fc_rnid_general_topology_data_s{
-       u32        vendor_unique[4];
-       u32        asso_type;
-       u32        phy_port_num;
-       u32        num_attached_nodes;
-       u32        node_mgmt:8;
-       u32        ip_version:8;
-       u32        udp_tcp_port_num:16;
-       u32        ip_address[4];
-       u32        reserved:16;
-       u32        vendor_specific:16;
-};
-
-struct fc_rnid_acc_s{
-       struct fc_els_cmd_s    els_cmd;
-       u32        node_id_data_format:8;
-       u32        common_id_data_length:8;
-       u32        reserved:8;
-       u32        specific_id_data_length:8;
-       struct fc_rnid_common_id_data_s common_id_data;
-       struct fc_rnid_general_topology_data_s gen_topology_data;
-};
-
-#define RNID_ASSOCIATED_TYPE_UNKNOWN                    0x00000001
-#define RNID_ASSOCIATED_TYPE_OTHER                      0x00000002
-#define RNID_ASSOCIATED_TYPE_HUB                        0x00000003
-#define RNID_ASSOCIATED_TYPE_SWITCH                     0x00000004
-#define RNID_ASSOCIATED_TYPE_GATEWAY                    0x00000005
-#define RNID_ASSOCIATED_TYPE_STORAGE_DEVICE             0x00000009
-#define RNID_ASSOCIATED_TYPE_HOST                       0x0000000A
-#define RNID_ASSOCIATED_TYPE_STORAGE_SUBSYSTEM          0x0000000B
-#define RNID_ASSOCIATED_TYPE_STORAGE_ACCESS_DEVICE      0x0000000E
-#define RNID_ASSOCIATED_TYPE_NAS_SERVER                 0x00000011
-#define RNID_ASSOCIATED_TYPE_BRIDGE                     0x00000002
-#define RNID_ASSOCIATED_TYPE_VIRTUALIZATION_DEVICE      0x00000003
-#define RNID_ASSOCIATED_TYPE_MULTI_FUNCTION_DEVICE      0x000000FF
-
-enum fc_rpsc_speed_cap{
-       RPSC_SPEED_CAP_1G = 0x8000,
-       RPSC_SPEED_CAP_2G = 0x4000,
-       RPSC_SPEED_CAP_4G = 0x2000,
-       RPSC_SPEED_CAP_10G = 0x1000,
-       RPSC_SPEED_CAP_8G = 0x0800,
-       RPSC_SPEED_CAP_16G = 0x0400,
-
-       RPSC_SPEED_CAP_UNKNOWN = 0x0001,
-};
-
-enum fc_rpsc_op_speed_s{
-       RPSC_OP_SPEED_1G = 0x8000,
-       RPSC_OP_SPEED_2G = 0x4000,
-       RPSC_OP_SPEED_4G = 0x2000,
-       RPSC_OP_SPEED_10G = 0x1000,
-       RPSC_OP_SPEED_8G = 0x0800,
-       RPSC_OP_SPEED_16G = 0x0400,
-
-       RPSC_OP_SPEED_NOT_EST = 0x0001, /*! speed not established */
-};
-
-struct fc_rpsc_speed_info_s{
-       u16        port_speed_cap;      /*! see fc_rpsc_speed_cap_t */
-       u16        port_op_speed;       /*! see fc_rpsc_op_speed_t */
-};
-
-enum link_e2e_beacon_subcmd{
-       LINK_E2E_BEACON_ON = 1,
-       LINK_E2E_BEACON_OFF = 2
-};
-
-enum beacon_type{
-       BEACON_TYPE_NORMAL      = 1,    /*! Normal Beaconing. Green */
-       BEACON_TYPE_WARN        = 2,    /*! Warning Beaconing. Yellow/Amber */
-       BEACON_TYPE_CRITICAL    = 3     /*! Critical Beaconing. Red */
-};
-
-struct link_e2e_beacon_param_s {
-       u8         beacon_type; /* Beacon Type. See beacon_type_t */
-       u8         beacon_frequency;
-                                       /* Beacon frequency. Number of blinks
-                                        * per 10 seconds
-                                        */
-       u16        beacon_duration;/* Beacon duration (in Seconds). The
-                                        * command operation should be
-                                        * terminated at the end of this
-                                        * timeout value.
-                                        *
-                                        * Ignored if diag_sub_cmd is
-                                        * LINK_E2E_BEACON_OFF.
-                                        *
-                                        * If 0, beaconing will continue till a
-                                        * BEACON OFF request is received
-                                        */
-};
-
-/*
- * Link E2E beacon request/good response format. For LS_RJTs use fc_ls_rjt_t
- */
-struct link_e2e_beacon_req_s{
-       u32        ls_code;     /*! FC_ELS_E2E_LBEACON in requests *
-                                        *or FC_ELS_ACC in good replies */
-       u32        ls_sub_cmd;  /*! See link_e2e_beacon_subcmd_t */
-       struct link_e2e_beacon_param_s beacon_parm;
-};
-
-/**
- * If RPSC request is sent to the Domain Controller, the request is for
- * all the ports within that domain (TODO - I don't think FOS implements
- * this...).
- */
-struct fc_rpsc_cmd_s{
-       struct fc_els_cmd_s    els_cmd;
-};
-
-/*
- * RPSC Acc
- */
-struct fc_rpsc_acc_s{
-       u32        command:8;
-       u32        rsvd:8;
-       u32        num_entries:16;
-
-       struct fc_rpsc_speed_info_s speed_info[1];
-};
-
-/**
- * If RPSC2 request is sent to the Domain Controller,
- */
-#define FC_BRCD_TOKEN    0x42524344
-
-struct fc_rpsc2_cmd_s{
-       struct fc_els_cmd_s    els_cmd;
-       u32             token;
-       u16             resvd;
-       u16             num_pids;       /* Number of pids in the request */
-       struct  {
-               u32     rsvd1:8;
-               u32     pid:24; /* port identifier */
-       } pid_list[1];
-};
-
-enum fc_rpsc2_port_type{
-       RPSC2_PORT_TYPE_UNKNOWN = 0,
-       RPSC2_PORT_TYPE_NPORT   = 1,
-       RPSC2_PORT_TYPE_NLPORT  = 2,
-       RPSC2_PORT_TYPE_NPIV_PORT  = 0x5f,
-       RPSC2_PORT_TYPE_NPORT_TRUNK  = 0x6f,
-};
-
-/*
- * RPSC2 portInfo entry structure
- */
-struct fc_rpsc2_port_info_s{
-    u32    pid;        /* PID */
-    u16    resvd1;
-    u16    index;      /* port number / index */
-    u8     resvd2;
-    u8         type;        /* port type N/NL/... */
-    u16    speed;      /* port Operating Speed */
-};
-
-/*
- * RPSC2 Accept payload
- */
-struct fc_rpsc2_acc_s{
-       u8        els_cmd;
-       u8        resvd;
-       u16       num_pids;  /* Number of pids in the request */
-       struct fc_rpsc2_port_info_s  port_info[1];    /* port information */
-};
-
-/**
- * bit fields so that multiple classes can be specified
- */
-enum fc_cos{
-       FC_CLASS_2      = 0x04,
-       FC_CLASS_3      = 0x08,
-       FC_CLASS_2_3    = 0x0C,
-};
-
-/*
- * symbolic name
- */
-struct fc_symname_s{
-       u8         symname[FC_SYMNAME_MAX];
-};
-
-struct fc_alpabm_s{
-       u8         alpa_bm[FC_ALPA_MAX / 8];
-};
-
-/*
- * protocol default timeout values
- */
-#define FC_ED_TOV              2
-#define FC_REC_TOV             (FC_ED_TOV + 1)
-#define FC_RA_TOV              10
-#define FC_ELS_TOV             (2 * FC_RA_TOV)
-#define FC_FCCT_TOV            (3 * FC_RA_TOV)
-
-/*
- * virtual fabric related defines
- */
-#define FC_VF_ID_NULL    0     /*  must not be used as VF_ID */
-#define FC_VF_ID_MIN     1
-#define FC_VF_ID_MAX     0xEFF
-#define FC_VF_ID_CTL     0xFEF /*  control VF_ID */
-
-/**
- * Virtual Fabric Tagging header format
- * @caution This is defined only in BIG ENDIAN format.
- */
-struct fc_vft_s{
-       u32        r_ctl:8;
-       u32        ver:2;
-       u32        type:4;
-       u32        res_a:2;
-       u32        priority:3;
-       u32        vf_id:12;
-       u32        res_b:1;
-       u32        hopct:8;
-       u32        res_c:24;
-};
-
-#pragma pack()
-
-#endif
diff --git a/drivers/scsi/bfa/include/protocol/fc_sp.h b/drivers/scsi/bfa/include/protocol/fc_sp.h
deleted file mode 100644 (file)
index 55bb0b3..0000000
+++ /dev/null
@@ -1,224 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __FC_SP_H__
-#define __FC_SP_H__
-
-#include <protocol/types.h>
-
-#pragma pack(1)
-
-enum auth_els_flags{
-       FC_AUTH_ELS_MORE_FRAGS_FLAG     = 0x80, /*! bit-7. More Fragments
-                                                * Follow
-                                                */
-       FC_AUTH_ELS_CONCAT_FLAG         = 0x40, /*! bit-6. Concatenation Flag */
-       FC_AUTH_ELS_SEQ_NUM_FLAG        = 0x01  /*! bit-0. Sequence Number */
-};
-
-enum auth_msg_codes{
-       FC_AUTH_MC_AUTH_RJT             = 0x0A, /*! Auth Reject */
-       FC_AUTH_MC_AUTH_NEG             = 0x0B, /*! Auth Negotiate */
-       FC_AUTH_MC_AUTH_DONE            = 0x0C, /*! Auth Done */
-
-       FC_AUTH_MC_DHCHAP_CHAL          = 0x10, /*! DHCHAP Challenge */
-       FC_AUTH_MC_DHCHAP_REPLY         = 0x11, /*! DHCHAP Reply */
-       FC_AUTH_MC_DHCHAP_SUCC          = 0x12, /*! DHCHAP Success */
-
-       FC_AUTH_MC_FCAP_REQ             = 0x13, /*! FCAP Request */
-       FC_AUTH_MC_FCAP_ACK             = 0x14, /*! FCAP Acknowledge */
-       FC_AUTH_MC_FCAP_CONF            = 0x15, /*! FCAP Confirm */
-
-       FC_AUTH_MC_FCPAP_INIT           = 0x16, /*! FCPAP Init */
-       FC_AUTH_MC_FCPAP_ACC            = 0x17, /*! FCPAP Accept */
-       FC_AUTH_MC_FCPAP_COMP           = 0x18, /*! FCPAP Complete */
-
-       FC_AUTH_MC_IKE_SA_INIT          = 0x22, /*! IKE SA INIT */
-       FC_AUTH_MC_IKE_SA_AUTH          = 0x23, /*! IKE SA Auth */
-       FC_AUTH_MC_IKE_CREATE_CHILD_SA  = 0x24, /*! IKE Create Child SA */
-       FC_AUTH_MC_IKE_INFO             = 0x25, /*! IKE informational */
-};
-
-enum auth_proto_version{
-       FC_AUTH_PROTO_VER_1     = 1,    /*! Protocol Version 1 */
-};
-
-enum {
-       FC_AUTH_ELS_COMMAND_CODE = 0x90,/*! Authentication ELS Command code  */
-       FC_AUTH_PROTO_PARAM_LEN_SZ = 4, /*! Size of Proto Parameter Len Field */
-       FC_AUTH_PROTO_PARAM_VAL_SZ = 4, /*! Size of Proto Parameter Val Field */
-       FC_MAX_AUTH_SECRET_LEN     = 256,
-                                       /*! Maximum secret string length */
-       FC_AUTH_NUM_USABLE_PROTO_LEN_SZ = 4,
-                                       /*! Size of usable protocols field */
-       FC_AUTH_RESP_VALUE_LEN_SZ       = 4,
-                                       /*! Size of response value length */
-       FC_MAX_CHAP_KEY_LEN     = 256,  /*! Maximum md5 digest length */
-       FC_MAX_AUTH_RETRIES     = 3,    /*! Maximum number of retries */
-       FC_MD5_DIGEST_LEN       = 16,   /*! MD5 digest length */
-       FC_SHA1_DIGEST_LEN      = 20,   /*! SHA1 digest length */
-       FC_MAX_DHG_SUPPORTED    = 1,    /*! Maximum DH Groups supported */
-       FC_MAX_ALG_SUPPORTED    = 1,    /*! Maximum algorithms supported */
-       FC_MAX_PROTO_SUPPORTED  = 1,    /*! Maximum protocols supported */
-       FC_START_TXN_ID         = 2,    /*! Starting transaction ID */
-};
-
-enum auth_proto_id{
-       FC_AUTH_PROTO_DHCHAP            = 0x00000001,
-       FC_AUTH_PROTO_FCAP              = 0x00000002,
-       FC_AUTH_PROTO_FCPAP             = 0x00000003,
-       FC_AUTH_PROTO_IKEv2             = 0x00000004,
-       FC_AUTH_PROTO_IKEv2_AUTH        = 0x00000005,
-};
-
-struct auth_name_s{
-       u16     name_tag;       /*! Name Tag = 1 for Authentication */
-       u16     name_len;       /*! Name Length = 8 for Authentication
-                                        */
-       wwn_t           name;           /*! Name. TODO - is this PWWN */
-};
-
-
-enum auth_hash_func{
-       FC_AUTH_HASH_FUNC_MD5           = 0x00000005,
-       FC_AUTH_HASH_FUNC_SHA_1         = 0x00000006,
-};
-
-enum auth_dh_gid{
-       FC_AUTH_DH_GID_0_DHG_NULL       = 0x00000000,
-       FC_AUTH_DH_GID_1_DHG_1024       = 0x00000001,
-       FC_AUTH_DH_GID_2_DHG_1280       = 0x00000002,
-       FC_AUTH_DH_GID_3_DHG_1536       = 0x00000003,
-       FC_AUTH_DH_GID_4_DHG_2048       = 0x00000004,
-       FC_AUTH_DH_GID_6_DHG_3072       = 0x00000006,
-       FC_AUTH_DH_GID_7_DHG_4096       = 0x00000007,
-       FC_AUTH_DH_GID_8_DHG_6144       = 0x00000008,
-       FC_AUTH_DH_GID_9_DHG_8192       = 0x00000009,
-};
-
-struct auth_els_msg_s {
-       u8              auth_els_code;  /*  Authentication ELS Code (0x90) */
-       u8      auth_els_flag;  /*  Authentication ELS Flags */
-       u8      auth_msg_code;  /*  Authentication Message Code */
-       u8      proto_version;  /*  Protocol Version */
-       u32     msg_len;        /*  Message Length */
-       u32     trans_id;       /*  Transaction Identifier (T_ID) */
-
-       /* Msg payload follows... */
-};
-
-
-enum auth_neg_param_tags {
-       FC_AUTH_NEG_DHCHAP_HASHLIST     = 0x0001,
-       FC_AUTH_NEG_DHCHAP_DHG_ID_LIST  = 0x0002,
-};
-
-
-struct dhchap_param_format_s {
-       u16     tag;            /*! Parameter Tag. See
-                                        * auth_neg_param_tags_t
-                                        */
-       u16     word_cnt;
-
-       /* followed by variable length parameter value... */
-};
-
-struct auth_proto_params_s {
-       u32     proto_param_len;
-       u32     proto_id;
-
-       /*
-        * Followed by variable length Protocol specific parameters. DH-CHAP
-        * uses dhchap_param_format_t
-        */
-};
-
-struct auth_neg_msg_s {
-       struct auth_name_s      auth_ini_name;
-       u32             usable_auth_protos;
-       struct auth_proto_params_s proto_params[1]; /*! (1..usable_auth_proto)
-                                                    * protocol params
-                                                    */
-};
-
-struct auth_dh_val_s {
-       u32 dh_val_len;
-       u32 dh_val[1];
-};
-
-struct auth_dhchap_chal_msg_s {
-       struct auth_els_msg_s   hdr;
-       struct auth_name_s auth_responder_name; /* TODO VRK - is auth_name_t
-                                                * type OK?
-                                                */
-       u32     hash_id;
-       u32     dh_grp_id;
-       u32     chal_val_len;
-       char            chal_val[1];
-
-       /* ...followed by variable Challenge length/value and DH length/value */
-};
-
-
-enum auth_rjt_codes {
-       FC_AUTH_RJT_CODE_AUTH_FAILURE   = 0x01,
-       FC_AUTH_RJT_CODE_LOGICAL_ERR    = 0x02,
-};
-
-enum auth_rjt_code_exps {
-       FC_AUTH_CEXP_AUTH_MECH_NOT_USABLE       = 0x01,
-       FC_AUTH_CEXP_DH_GROUP_NOT_USABLE        = 0x02,
-       FC_AUTH_CEXP_HASH_FUNC_NOT_USABLE       = 0x03,
-       FC_AUTH_CEXP_AUTH_XACT_STARTED          = 0x04,
-       FC_AUTH_CEXP_AUTH_FAILED                = 0x05,
-       FC_AUTH_CEXP_INCORRECT_PLD              = 0x06,
-       FC_AUTH_CEXP_INCORRECT_PROTO_MSG        = 0x07,
-       FC_AUTH_CEXP_RESTART_AUTH_PROTO         = 0x08,
-       FC_AUTH_CEXP_AUTH_CONCAT_NOT_SUPP       = 0x09,
-       FC_AUTH_CEXP_PROTO_VER_NOT_SUPP         = 0x0A,
-};
-
-enum auth_status {
-       FC_AUTH_STATE_INPROGRESS = 0,   /*! authentication in progress  */
-       FC_AUTH_STATE_FAILED    = 1,    /*! authentication failed */
-       FC_AUTH_STATE_SUCCESS   = 2     /*! authentication successful   */
-};
-
-struct auth_rjt_msg_s {
-       struct auth_els_msg_s   hdr;
-       u8              reason_code;
-       u8              reason_code_exp;
-       u8              rsvd[2];
-};
-
-
-struct auth_dhchap_neg_msg_s {
-       struct auth_els_msg_s hdr;
-       struct auth_neg_msg_s nego;
-};
-
-struct auth_dhchap_reply_msg_s {
-       struct auth_els_msg_s   hdr;
-
-       /*
-        * followed by response value length & Value + DH Value Length & Value
-        */
-};
-
-#pragma pack()
-
-#endif /* __FC_SP_H__ */
diff --git a/drivers/scsi/bfa/include/protocol/fcp.h b/drivers/scsi/bfa/include/protocol/fcp.h
deleted file mode 100644 (file)
index 74ea63c..0000000
+++ /dev/null
@@ -1,184 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __FCPPROTO_H__
-#define __FCPPROTO_H__
-
-#include <linux/bitops.h>
-#include <protocol/scsi.h>
-
-#pragma pack(1)
-
-enum {
-       FCP_RJT         = 0x01000000,   /* SRR reject */
-       FCP_SRR_ACCEPT  = 0x02000000,   /* SRR accept */
-       FCP_SRR         = 0x14000000,   /* Sequence Retransmission Request */
-};
-
-/*
- * SRR FC-4 LS payload
- */
-struct fc_srr_s{
-       u32     ls_cmd;
-       u32        ox_id:16;    /* ox-id */
-       u32        rx_id:16;    /* rx-id */
-       u32        ro;          /* relative offset */
-       u32        r_ctl:8;             /* R_CTL for I.U. */
-       u32        res:24;
-};
-
-
-/*
- * FCP_CMND definitions
- */
-#define FCP_CMND_CDB_LEN    16
-#define FCP_CMND_LUN_LEN    8
-
-struct fcp_cmnd_s{
-       lun_t           lun;            /* 64-bit LU number */
-       u8         crn;         /* command reference number */
-#ifdef __BIGENDIAN
-       u8         resvd:1,
-                       priority:4,     /* FCP-3: SAM-3 priority */
-                       taskattr:3;     /* scsi task attribute */
-#else
-       u8         taskattr:3,  /* scsi task attribute */
-                       priority:4,     /* FCP-3: SAM-3 priority */
-                       resvd:1;
-#endif
-       u8         tm_flags;    /* task management flags */
-#ifdef __BIGENDIAN
-       u8         addl_cdb_len:6,      /* additional CDB length words */
-                       iodir:2;        /* read/write FCP_DATA IUs */
-#else
-       u8         iodir:2,     /* read/write FCP_DATA IUs */
-                       addl_cdb_len:6; /* additional CDB length */
-#endif
-       struct scsi_cdb_s      cdb;
-
-       /*
-        * !!! additional cdb bytes follows here!!!
-        */
-       u32        fcp_dl;      /* bytes to be transferred */
-};
-
-#define fcp_cmnd_cdb_len(_cmnd) ((_cmnd)->addl_cdb_len * 4 + FCP_CMND_CDB_LEN)
-#define fcp_cmnd_fcpdl(_cmnd)  ((&(_cmnd)->fcp_dl)[(_cmnd)->addl_cdb_len])
-
-/*
- * fcp_cmnd_t.iodir field values
- */
-enum fcp_iodir{
-       FCP_IODIR_NONE  = 0,
-       FCP_IODIR_WRITE = 1,
-       FCP_IODIR_READ  = 2,
-       FCP_IODIR_RW    = 3,
-};
-
-/*
- * Task attribute field
- */
-enum {
-       FCP_TASK_ATTR_SIMPLE    = 0,
-       FCP_TASK_ATTR_HOQ       = 1,
-       FCP_TASK_ATTR_ORDERED   = 2,
-       FCP_TASK_ATTR_ACA       = 4,
-       FCP_TASK_ATTR_UNTAGGED  = 5,    /* obsolete in FCP-3 */
-};
-
-/*
- * Task management flags field - only one bit shall be set
- */
-enum fcp_tm_cmnd{
-       FCP_TM_ABORT_TASK_SET   = BIT(1),
-       FCP_TM_CLEAR_TASK_SET   = BIT(2),
-       FCP_TM_LUN_RESET        = BIT(4),
-       FCP_TM_TARGET_RESET     = BIT(5),       /* obsolete in FCP-3 */
-       FCP_TM_CLEAR_ACA        = BIT(6),
-};
-
-/*
- * FCP_XFER_RDY IU defines
- */
-struct fcp_xfer_rdy_s{
-       u32        data_ro;
-       u32        burst_len;
-       u32        reserved;
-};
-
-/*
- * FCP_RSP residue flags
- */
-enum fcp_residue{
-       FCP_NO_RESIDUE = 0,     /* no residue */
-       FCP_RESID_OVER = 1,     /* more data left that was not sent */
-       FCP_RESID_UNDER = 2,    /* less data than requested */
-};
-
-enum {
-       FCP_RSPINFO_GOOD = 0,
-       FCP_RSPINFO_DATALEN_MISMATCH = 1,
-       FCP_RSPINFO_CMND_INVALID = 2,
-       FCP_RSPINFO_ROLEN_MISMATCH = 3,
-       FCP_RSPINFO_TM_NOT_SUPP = 4,
-       FCP_RSPINFO_TM_FAILED = 5,
-};
-
-struct fcp_rspinfo_s{
-       u32        res0:24;
-       u32        rsp_code:8;  /* response code (as above) */
-       u32        res1;
-};
-
-struct fcp_resp_s{
-       u32        reserved[2]; /* 2 words reserved */
-       u16        reserved2;
-#ifdef __BIGENDIAN
-       u8         reserved3:3;
-       u8         fcp_conf_req:1;      /* FCP_CONF is requested */
-       u8         resid_flags:2;       /* underflow/overflow */
-       u8         sns_len_valid:1;/* sense len is valid */
-       u8         rsp_len_valid:1;/* response len is valid */
-#else
-       u8         rsp_len_valid:1;/* response len is valid */
-       u8         sns_len_valid:1;/* sense len is valid */
-       u8         resid_flags:2;       /* underflow/overflow */
-       u8         fcp_conf_req:1;      /* FCP_CONF is requested */
-       u8         reserved3:3;
-#endif
-       u8         scsi_status; /* one byte SCSI status */
-       u32        residue;     /* residual data bytes */
-       u32        sns_len;     /* length od sense info */
-       u32        rsp_len;     /* length of response info */
-};
-
-#define fcp_snslen(__fcprsp)   ((__fcprsp)->sns_len_valid ?            \
-                                       (__fcprsp)->sns_len : 0)
-#define fcp_rsplen(__fcprsp)   ((__fcprsp)->rsp_len_valid ?            \
-                                       (__fcprsp)->rsp_len : 0)
-#define fcp_rspinfo(__fcprsp)  ((struct fcp_rspinfo_s *)((__fcprsp) + 1))
-#define fcp_snsinfo(__fcprsp)  (((u8 *)fcp_rspinfo(__fcprsp)) +        \
-                                               fcp_rsplen(__fcprsp))
-
-struct fcp_cmnd_fr_s{
-       struct fchs_s          fchs;
-       struct fcp_cmnd_s      fcp;
-};
-
-#pragma pack()
-
-#endif
diff --git a/drivers/scsi/bfa/include/protocol/fdmi.h b/drivers/scsi/bfa/include/protocol/fdmi.h
deleted file mode 100644 (file)
index 6c05c26..0000000
+++ /dev/null
@@ -1,163 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __FDMI_H__
-#define __FDMI_H__
-
-#include <protocol/types.h>
-#include <protocol/fc.h>
-#include <protocol/ct.h>
-
-#pragma pack(1)
-
-/*
- * FDMI Command Codes
- */
-#define        FDMI_GRHL               0x0100
-#define        FDMI_GHAT               0x0101
-#define        FDMI_GRPL               0x0102
-#define        FDMI_GPAT               0x0110
-#define        FDMI_RHBA               0x0200
-#define        FDMI_RHAT               0x0201
-#define        FDMI_RPRT               0x0210
-#define        FDMI_RPA                0x0211
-#define        FDMI_DHBA               0x0300
-#define        FDMI_DPRT               0x0310
-
-/*
- * FDMI reason codes
- */
-#define        FDMI_NO_ADDITIONAL_EXP          0x00
-#define        FDMI_HBA_ALREADY_REG            0x10
-#define        FDMI_HBA_ATTRIB_NOT_REG         0x11
-#define        FDMI_HBA_ATTRIB_MULTIPLE        0x12
-#define        FDMI_HBA_ATTRIB_LENGTH_INVALID  0x13
-#define        FDMI_HBA_ATTRIB_NOT_PRESENT     0x14
-#define        FDMI_PORT_ORIG_NOT_IN_LIST      0x15
-#define        FDMI_PORT_HBA_NOT_IN_LIST       0x16
-#define        FDMI_PORT_ATTRIB_NOT_REG        0x20
-#define        FDMI_PORT_NOT_REG               0x21
-#define        FDMI_PORT_ATTRIB_MULTIPLE       0x22
-#define        FDMI_PORT_ATTRIB_LENGTH_INVALID 0x23
-#define        FDMI_PORT_ALREADY_REGISTEREED   0x24
-
-/*
- * FDMI Transmission Speed Mask values
- */
-#define        FDMI_TRANS_SPEED_1G             0x00000001
-#define        FDMI_TRANS_SPEED_2G             0x00000002
-#define        FDMI_TRANS_SPEED_10G            0x00000004
-#define        FDMI_TRANS_SPEED_4G             0x00000008
-#define        FDMI_TRANS_SPEED_8G             0x00000010
-#define        FDMI_TRANS_SPEED_16G            0x00000020
-#define        FDMI_TRANS_SPEED_UNKNOWN        0x00008000
-
-/*
- * FDMI HBA attribute types
- */
-enum fdmi_hba_attribute_type {
-       FDMI_HBA_ATTRIB_NODENAME = 1,   /* 0x0001 */
-       FDMI_HBA_ATTRIB_MANUFACTURER,   /* 0x0002 */
-       FDMI_HBA_ATTRIB_SERIALNUM,      /* 0x0003 */
-       FDMI_HBA_ATTRIB_MODEL,          /* 0x0004 */
-       FDMI_HBA_ATTRIB_MODEL_DESC,     /* 0x0005 */
-       FDMI_HBA_ATTRIB_HW_VERSION,     /* 0x0006 */
-       FDMI_HBA_ATTRIB_DRIVER_VERSION, /* 0x0007 */
-       FDMI_HBA_ATTRIB_ROM_VERSION,    /* 0x0008 */
-       FDMI_HBA_ATTRIB_FW_VERSION,     /* 0x0009 */
-       FDMI_HBA_ATTRIB_OS_NAME,        /* 0x000A */
-       FDMI_HBA_ATTRIB_MAX_CT,         /* 0x000B */
-
-       FDMI_HBA_ATTRIB_MAX_TYPE
-};
-
-/*
- * FDMI Port attribute types
- */
-enum fdmi_port_attribute_type {
-       FDMI_PORT_ATTRIB_FC4_TYPES = 1, /* 0x0001 */
-       FDMI_PORT_ATTRIB_SUPP_SPEED,    /* 0x0002 */
-       FDMI_PORT_ATTRIB_PORT_SPEED,    /* 0x0003 */
-       FDMI_PORT_ATTRIB_FRAME_SIZE,    /* 0x0004 */
-       FDMI_PORT_ATTRIB_DEV_NAME,      /* 0x0005 */
-       FDMI_PORT_ATTRIB_HOST_NAME,     /* 0x0006 */
-
-       FDMI_PORT_ATTR_MAX_TYPE
-};
-
-/*
- * FDMI attribute
- */
-struct fdmi_attr_s {
-       u16        type;
-       u16        len;
-       u8         value[1];
-};
-
-/*
- * HBA Attribute Block
- */
-struct fdmi_hba_attr_s {
-       u32        attr_count;  /* # of attributes */
-       struct fdmi_attr_s     hba_attr;        /* n attributes */
-};
-
-/*
- * Registered Port List
- */
-struct fdmi_port_list_s {
-       u32        num_ports;   /* number Of Port Entries */
-       wwn_t           port_entry;     /* one or more */
-};
-
-/*
- * Port Attribute Block
- */
-struct fdmi_port_attr_s {
-       u32        attr_count;  /* # of attributes */
-       struct fdmi_attr_s     port_attr;       /* n attributes */
-};
-
-/*
- * FDMI Register HBA Attributes
- */
-struct fdmi_rhba_s {
-       wwn_t           hba_id;         /* HBA Identifier */
-       struct fdmi_port_list_s port_list;      /* Registered Port List */
-       struct fdmi_hba_attr_s hba_attr_blk;    /* HBA attribute block */
-};
-
-/*
- * FDMI Register Port
- */
-struct fdmi_rprt_s {
-       wwn_t           hba_id;         /* HBA Identifier */
-       wwn_t           port_name;      /* Port wwn */
-       struct fdmi_port_attr_s port_attr_blk;  /* Port Attr Block */
-};
-
-/*
- * FDMI Register Port Attributes
- */
-struct fdmi_rpa_s {
-       wwn_t           port_name;      /* port wwn */
-       struct fdmi_port_attr_s port_attr_blk;  /* Port Attr Block */
-};
-
-#pragma pack()
-
-#endif
diff --git a/drivers/scsi/bfa/include/protocol/scsi.h b/drivers/scsi/bfa/include/protocol/scsi.h
deleted file mode 100644 (file)
index b220e6b..0000000
+++ /dev/null
@@ -1,1648 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __SCSI_H__
-#define __SCSI_H__
-
-#include <protocol/types.h>
-
-#pragma pack(1)
-
-/*
- * generic SCSI cdb definition
- */
-#define SCSI_MAX_CDBLEN     16
-struct scsi_cdb_s{
-       u8         scsi_cdb[SCSI_MAX_CDBLEN];
-};
-
-/*
- * scsi lun serial number definition
- */
-#define SCSI_LUN_SN_LEN     32
-struct scsi_lun_sn_s{
-       u8         lun_sn[SCSI_LUN_SN_LEN];
-};
-
-/*
- * SCSI Direct Access Commands
- */
-enum {
-       SCSI_OP_TEST_UNIT_READY         = 0x00,
-       SCSI_OP_REQUEST_SENSE           = 0x03,
-       SCSI_OP_FORMAT_UNIT             = 0x04,
-       SCSI_OP_READ6                   = 0x08,
-       SCSI_OP_WRITE6                  = 0x0A,
-       SCSI_OP_WRITE_FILEMARKS         = 0x10,
-       SCSI_OP_INQUIRY                 = 0x12,
-       SCSI_OP_MODE_SELECT6            = 0x15,
-       SCSI_OP_RESERVE6                = 0x16,
-       SCSI_OP_RELEASE6                = 0x17,
-       SCSI_OP_MODE_SENSE6             = 0x1A,
-       SCSI_OP_START_STOP_UNIT         = 0x1B,
-       SCSI_OP_SEND_DIAGNOSTIC         = 0x1D,
-       SCSI_OP_READ_CAPACITY           = 0x25,
-       SCSI_OP_READ10                  = 0x28,
-       SCSI_OP_WRITE10                 = 0x2A,
-       SCSI_OP_VERIFY10                = 0x2F,
-       SCSI_OP_READ_DEFECT_DATA        = 0x37,
-       SCSI_OP_LOG_SELECT              = 0x4C,
-       SCSI_OP_LOG_SENSE               = 0x4D,
-       SCSI_OP_MODE_SELECT10           = 0x55,
-       SCSI_OP_RESERVE10               = 0x56,
-       SCSI_OP_RELEASE10               = 0x57,
-       SCSI_OP_MODE_SENSE10            = 0x5A,
-       SCSI_OP_PER_RESERVE_IN          = 0x5E,
-       SCSI_OP_PER_RESERVE_OUR         = 0x5E,
-       SCSI_OP_READ16                  = 0x88,
-       SCSI_OP_WRITE16                 = 0x8A,
-       SCSI_OP_VERIFY16                = 0x8F,
-       SCSI_OP_READ_CAPACITY16         = 0x9E,
-       SCSI_OP_REPORT_LUNS             = 0xA0,
-       SCSI_OP_READ12                  = 0xA8,
-       SCSI_OP_WRITE12                 = 0xAA,
-       SCSI_OP_UNDEF                   = 0xFF,
-};
-
-/*
- * SCSI START_STOP_UNIT command
- */
-struct scsi_start_stop_unit_s{
-       u8         opcode;
-#ifdef __BIGENDIAN
-       u8         lun:3;
-       u8         reserved1:4;
-       u8         immed:1;
-#else
-       u8         immed:1;
-       u8         reserved1:4;
-       u8         lun:3;
-#endif
-       u8         reserved2;
-       u8         reserved3;
-#ifdef __BIGENDIAN
-       u8         power_conditions:4;
-       u8         reserved4:2;
-       u8         loEj:1;
-       u8         start:1;
-#else
-       u8         start:1;
-       u8         loEj:1;
-       u8         reserved4:2;
-       u8         power_conditions:4;
-#endif
-       u8         control;
-};
-
-/*
- * SCSI SEND_DIAGNOSTIC command
- */
-struct scsi_send_diagnostic_s{
-       u8         opcode;
-#ifdef __BIGENDIAN
-       u8         self_test_code:3;
-       u8         pf:1;
-       u8         reserved1:1;
-       u8         self_test:1;
-       u8         dev_offl:1;
-       u8         unit_offl:1;
-#else
-       u8         unit_offl:1;
-       u8         dev_offl:1;
-       u8         self_test:1;
-       u8         reserved1:1;
-       u8         pf:1;
-       u8         self_test_code:3;
-#endif
-       u8         reserved2;
-
-       u8         param_list_length[2];        /* MSB first */
-       u8         control;
-
-};
-
-/*
- * SCSI READ10/WRITE10 commands
- */
-struct scsi_rw10_s{
-       u8         opcode;
-#ifdef __BIGENDIAN
-       u8         lun:3;
-       u8         dpo:1;       /* Disable Page Out */
-       u8         fua:1;       /* Force Unit Access */
-       u8         reserved1:2;
-       u8         rel_adr:1;   /* relative address */
-#else
-       u8         rel_adr:1;
-       u8         reserved1:2;
-       u8         fua:1;
-       u8         dpo:1;
-       u8         lun:3;
-#endif
-       u8         lba0;        /* logical block address - MSB */
-       u8         lba1;
-       u8         lba2;
-       u8         lba3;        /* LSB */
-       u8         reserved3;
-       u8         xfer_length0;        /* transfer length in blocks - MSB */
-       u8         xfer_length1;        /* LSB */
-       u8         control;
-};
-
-#define SCSI_CDB10_GET_LBA(cdb)                     \
-    (((cdb)->lba0 << 24) | ((cdb)->lba1 << 16) |    \
-     ((cdb)->lba2 << 8) | (cdb)->lba3)
-
-#define SCSI_CDB10_SET_LBA(cdb, lba) {      \
-    (cdb)->lba0 = lba >> 24;            \
-    (cdb)->lba1 = (lba >> 16) & 0xFF;   \
-    (cdb)->lba2 = (lba >> 8) & 0xFF;    \
-    (cdb)->lba3 = lba & 0xFF;           \
-}
-
-#define SCSI_CDB10_GET_TL(cdb)  \
-    ((cdb)->xfer_length0 << 8 | (cdb)->xfer_length1)
-#define SCSI_CDB10_SET_TL(cdb, tl) {      \
-    (cdb)->xfer_length0 = tl >> 8;       \
-    (cdb)->xfer_length1 = tl & 0xFF;     \
-}
-
-/*
- * SCSI READ6/WRITE6 commands
- */
-struct scsi_rw6_s{
-       u8         opcode;
-#ifdef __BIGENDIAN
-       u8         lun:3;
-       u8         lba0:5;              /* MSb */
-#else
-       u8         lba0:5;              /* MSb */
-       u8         lun:3;
-#endif
-       u8         lba1;
-       u8         lba2;                /* LSB */
-       u8         xfer_length;
-       u8         control;
-};
-
-#define SCSI_TAPE_CDB6_GET_TL(cdb)              \
-    (((cdb)->tl0 << 16) | ((cdb)->tl1 << 8) | (cdb)->tl2)
-
-#define SCSI_TAPE_CDB6_SET_TL(cdb, tl) {      \
-    (cdb)->tl0 = tl >> 16;            \
-    (cdb)->tl1 = (tl >> 8) & 0xFF;    \
-    (cdb)->tl2 = tl & 0xFF;           \
-}
-
-/*
- * SCSI sequential (TAPE) wrtie command
- */
-struct scsi_tape_wr_s{
-       u8         opcode;
-#ifdef __BIGENDIAN
-       u8         rsvd:7;
-       u8         fixed:1;     /* MSb */
-#else
-       u8         fixed:1;     /* MSb */
-       u8         rsvd:7;
-#endif
-       u8         tl0;         /* Msb */
-       u8         tl1;
-       u8         tl2;         /* Lsb */
-
-       u8         control;
-};
-
-#define SCSI_CDB6_GET_LBA(cdb)              \
-    (((cdb)->lba0 << 16) | ((cdb)->lba1 << 8) | (cdb)->lba2)
-
-#define SCSI_CDB6_SET_LBA(cdb, lba) {      \
-    (cdb)->lba0 = lba >> 16;            \
-    (cdb)->lba1 = (lba >> 8) & 0xFF;    \
-    (cdb)->lba2 = lba & 0xFF;           \
-}
-
-#define SCSI_CDB6_GET_TL(cdb) ((cdb)->xfer_length)
-#define SCSI_CDB6_SET_TL(cdb, tl) {      \
-    (cdb)->xfer_length = tl;         \
-}
-
-/*
- * SCSI sense data format
- */
-struct scsi_sense_s{
-#ifdef __BIGENDIAN
-       u8         valid:1;
-       u8         rsp_code:7;
-#else
-       u8         rsp_code:7;
-       u8         valid:1;
-#endif
-       u8         seg_num;
-#ifdef __BIGENDIAN
-       u8         file_mark:1;
-       u8         eom:1;               /* end of media */
-       u8         ili:1;               /* incorrect length indicator */
-       u8         reserved:1;
-       u8         sense_key:4;
-#else
-       u8         sense_key:4;
-       u8         reserved:1;
-       u8         ili:1;               /* incorrect length indicator */
-       u8         eom:1;               /* end of media */
-       u8         file_mark:1;
-#endif
-       u8         information[4];      /* device-type or command specific info
-                                        */
-       u8         add_sense_length;
-                                       /* additional sense length */
-       u8         command_info[4];/* command specific information
-                                                */
-       u8         asc;         /* additional sense code */
-       u8         ascq;                /* additional sense code qualifier */
-       u8         fru_code;    /* field replaceable unit code */
-#ifdef __BIGENDIAN
-       u8         sksv:1;              /* sense key specific valid */
-       u8         c_d:1;               /* command/data bit */
-       u8         res1:2;
-       u8         bpv:1;               /* bit pointer valid */
-       u8         bpointer:3;  /* bit pointer */
-#else
-       u8         bpointer:3;  /* bit pointer */
-       u8         bpv:1;               /* bit pointer valid */
-       u8         res1:2;
-       u8         c_d:1;               /* command/data bit */
-       u8         sksv:1;              /* sense key specific valid */
-#endif
-       u8         fpointer[2]; /* field pointer */
-};
-
-#define SCSI_SENSE_CUR_ERR          0x70
-#define SCSI_SENSE_DEF_ERR          0x71
-
-/*
- * SCSI sense key values
- */
-#define SCSI_SK_NO_SENSE        0x0
-#define SCSI_SK_REC_ERR         0x1    /* recovered error */
-#define SCSI_SK_NOT_READY       0x2
-#define SCSI_SK_MED_ERR         0x3    /* medium error */
-#define SCSI_SK_HW_ERR          0x4    /* hardware error */
-#define SCSI_SK_ILLEGAL_REQ     0x5
-#define SCSI_SK_UNIT_ATT        0x6    /* unit attention */
-#define SCSI_SK_DATA_PROTECT    0x7
-#define SCSI_SK_BLANK_CHECK     0x8
-#define SCSI_SK_VENDOR_SPEC     0x9
-#define SCSI_SK_COPY_ABORTED    0xA
-#define SCSI_SK_ABORTED_CMND    0xB
-#define SCSI_SK_VOL_OVERFLOW    0xD
-#define SCSI_SK_MISCOMPARE      0xE
-
-/*
- * SCSI additional sense codes
- */
-#define SCSI_ASC_NO_ADD_SENSE           0x00
-#define SCSI_ASC_LUN_NOT_READY          0x04
-#define SCSI_ASC_LUN_COMMUNICATION      0x08
-#define SCSI_ASC_WRITE_ERROR            0x0C
-#define SCSI_ASC_INVALID_CMND_CODE      0x20
-#define SCSI_ASC_BAD_LBA                0x21
-#define SCSI_ASC_INVALID_FIELD_IN_CDB   0x24
-#define SCSI_ASC_LUN_NOT_SUPPORTED      0x25
-#define SCSI_ASC_LUN_WRITE_PROTECT      0x27
-#define SCSI_ASC_POWERON_BDR            0x29   /* power on reset, bus reset,
-                                                * bus device reset
-                                                */
-#define SCSI_ASC_PARAMS_CHANGED         0x2A
-#define SCSI_ASC_CMND_CLEARED_BY_A_I    0x2F
-#define SCSI_ASC_SAVING_PARAM_NOTSUPP   0x39
-#define SCSI_ASC_TOCC                   0x3F   /* target operating condtions
-                                                * changed
-                                                */
-#define SCSI_ASC_PARITY_ERROR           0x47
-#define SCSI_ASC_CMND_PHASE_ERROR       0x4A
-#define SCSI_ASC_DATA_PHASE_ERROR       0x4B
-#define SCSI_ASC_VENDOR_SPEC            0x7F
-
-/*
- * SCSI additional sense code qualifiers
- */
-#define SCSI_ASCQ_CAUSE_NOT_REPORT      0x00
-#define SCSI_ASCQ_BECOMING_READY        0x01
-#define SCSI_ASCQ_INIT_CMD_REQ          0x02
-#define SCSI_ASCQ_FORMAT_IN_PROGRESS    0x04
-#define SCSI_ASCQ_OPERATION_IN_PROGRESS 0x07
-#define SCSI_ASCQ_SELF_TEST_IN_PROGRESS 0x09
-#define SCSI_ASCQ_WR_UNEXP_UNSOL_DATA   0x0C
-#define SCSI_ASCQ_WR_NOTENG_UNSOL_DATA  0x0D
-
-#define SCSI_ASCQ_LBA_OUT_OF_RANGE      0x00
-#define SCSI_ASCQ_INVALID_ELEMENT_ADDR  0x01
-
-#define SCSI_ASCQ_LUN_WRITE_PROTECTED       0x00
-#define SCSI_ASCQ_LUN_HW_WRITE_PROTECTED    0x01
-#define SCSI_ASCQ_LUN_SW_WRITE_PROTECTED    0x02
-
-#define SCSI_ASCQ_POR   0x01   /* power on reset */
-#define SCSI_ASCQ_SBR   0x02   /* scsi bus reset */
-#define SCSI_ASCQ_BDR   0x03   /* bus device reset */
-#define SCSI_ASCQ_DIR   0x04   /* device internal reset */
-
-#define SCSI_ASCQ_MODE_PARAMS_CHANGED       0x01
-#define SCSI_ASCQ_LOG_PARAMS_CHANGED        0x02
-#define SCSI_ASCQ_RESERVATIONS_PREEMPTED    0x03
-#define SCSI_ASCQ_RESERVATIONS_RELEASED     0x04
-#define SCSI_ASCQ_REGISTRATIONS_PREEMPTED   0x05
-
-#define SCSI_ASCQ_MICROCODE_CHANGED 0x01
-#define SCSI_ASCQ_CHANGED_OPER_COND 0x02
-#define SCSI_ASCQ_INQ_CHANGED       0x03       /* inquiry data changed */
-#define SCSI_ASCQ_DI_CHANGED        0x05       /* device id changed */
-#define SCSI_ASCQ_RL_DATA_CHANGED   0x0E       /* report luns data changed */
-
-#define SCSI_ASCQ_DP_CRC_ERR            0x01   /* data phase crc error */
-#define SCSI_ASCQ_DP_SCSI_PARITY_ERR    0x02   /* data phase scsi parity error
-                                                */
-#define SCSI_ASCQ_IU_CRC_ERR            0x03   /* information unit crc error */
-#define SCSI_ASCQ_PROTO_SERV_CRC_ERR    0x05
-
-#define SCSI_ASCQ_LUN_TIME_OUT          0x01
-
-/* ------------------------------------------------------------
- * SCSI INQUIRY
- * ------------------------------------------------------------*/
-
-struct scsi_inquiry_s{
-       u8         opcode;
-#ifdef __BIGENDIAN
-       u8         lun:3;
-       u8         reserved1:3;
-       u8         cmd_dt:1;
-       u8         evpd:1;
-#else
-       u8         evpd:1;
-       u8         cmd_dt:1;
-       u8         reserved1:3;
-       u8         lun:3;
-#endif
-       u8         page_code;
-       u8         reserved2;
-       u8         alloc_length;
-       u8         control;
-};
-
-struct scsi_inquiry_vendor_s{
-       u8         vendor_id[8];
-};
-
-struct scsi_inquiry_prodid_s{
-       u8         product_id[16];
-};
-
-struct scsi_inquiry_prodrev_s{
-       u8         product_rev[4];
-};
-
-struct scsi_inquiry_data_s{
-#ifdef __BIGENDIAN
-       u8         peripheral_qual:3;   /* peripheral qualifier */
-       u8         device_type:5;               /* peripheral device type */
-
-       u8         rmb:1;                       /* removable medium bit */
-       u8         device_type_mod:7;   /* device type modifier */
-
-       u8         version;
-
-       u8         aenc:1;              /* async event notification capability
-                                        */
-       u8         trm_iop:1;   /* terminate I/O process */
-       u8         norm_aca:1;  /* normal ACA supported */
-       u8         hi_support:1;        /* SCSI-3: supports REPORT LUNS */
-       u8         rsp_data_format:4;
-
-       u8         additional_len;
-       u8         sccs:1;
-       u8         reserved1:7;
-
-       u8         reserved2:1;
-       u8         enc_serv:1;  /* enclosure service component */
-       u8         reserved3:1;
-       u8         multi_port:1;        /* multi-port device */
-       u8         m_chngr:1;   /* device in medium transport element */
-       u8         ack_req_q:1; /* SIP specific bit */
-       u8         addr32:1;    /* SIP specific bit */
-       u8         addr16:1;    /* SIP specific bit */
-
-       u8         rel_adr:1;   /* relative address */
-       u8         w_bus32:1;
-       u8         w_bus16:1;
-       u8         synchronous:1;
-       u8         linked_commands:1;
-       u8         trans_dis:1;
-       u8         cmd_queue:1; /* command queueing supported */
-       u8         soft_reset:1;        /* soft reset alternative (VS) */
-#else
-       u8         device_type:5;       /* peripheral device type */
-       u8         peripheral_qual:3;
-                                       /* peripheral qualifier */
-
-       u8         device_type_mod:7;
-                                       /* device type modifier */
-       u8         rmb:1;               /* removable medium bit */
-
-       u8         version;
-
-       u8         rsp_data_format:4;
-       u8         hi_support:1;        /* SCSI-3: supports REPORT LUNS */
-       u8         norm_aca:1;  /* normal ACA supported */
-       u8         terminate_iop:1;/* terminate I/O process */
-       u8         aenc:1;              /* async event notification capability
-                                        */
-
-       u8         additional_len;
-       u8         reserved1:7;
-       u8         sccs:1;
-
-       u8         addr16:1;    /* SIP specific bit */
-       u8         addr32:1;    /* SIP specific bit */
-       u8         ack_req_q:1; /* SIP specific bit */
-       u8         m_chngr:1;   /* device in medium transport element */
-       u8         multi_port:1;        /* multi-port device */
-       u8         reserved3:1; /* TBD - Vendor Specific */
-       u8         enc_serv:1;  /* enclosure service component */
-       u8         reserved2:1;
-
-       u8         soft_seset:1;        /* soft reset alternative (VS) */
-       u8         cmd_queue:1; /* command queueing supported */
-       u8         trans_dis:1;
-       u8         linked_commands:1;
-       u8         synchronous:1;
-       u8         w_bus16:1;
-       u8         w_bus32:1;
-       u8         rel_adr:1;   /* relative address */
-#endif
-       struct scsi_inquiry_vendor_s vendor_id;
-       struct scsi_inquiry_prodid_s product_id;
-       struct scsi_inquiry_prodrev_s product_rev;
-       u8         vendor_specific[20];
-       u8         reserved4[40];
-};
-
-/*
- * inquiry.peripheral_qual field values
- */
-#define SCSI_DEVQUAL_DEFAULT        0
-#define SCSI_DEVQUAL_NOT_CONNECTED  1
-#define SCSI_DEVQUAL_NOT_SUPPORTED  3
-
-/*
- * inquiry.device_type field values
- */
-#define SCSI_DEVICE_DIRECT_ACCESS       0x00
-#define SCSI_DEVICE_SEQ_ACCESS          0x01
-#define SCSI_DEVICE_ARRAY_CONTROLLER    0x0C
-#define SCSI_DEVICE_UNKNOWN             0x1F
-
-/*
- * inquiry.version
- */
-#define SCSI_VERSION_ANSI_X3131     2  /* ANSI X3.131 SCSI-2 */
-#define SCSI_VERSION_SPC            3  /* SPC (SCSI-3), ANSI X3.301:1997 */
-#define SCSI_VERSION_SPC_2          4  /* SPC-2 */
-
-/*
- * response data format
- */
-#define SCSI_RSP_DATA_FORMAT        2  /* SCSI-2 & SPC */
-
-/*
- * SCSI inquiry page codes
- */
-#define SCSI_INQ_PAGE_VPD_PAGES     0x00       /* supported vpd pages */
-#define SCSI_INQ_PAGE_USN_PAGE      0x80       /* unit serial number page */
-#define SCSI_INQ_PAGE_DEV_IDENT     0x83       /* device indentification page
-                                                */
-#define SCSI_INQ_PAGES_MAX          3
-
-/*
- * supported vital product data pages
- */
-struct scsi_inq_page_vpd_pages_s{
-#ifdef __BIGENDIAN
-       u8         peripheral_qual:3;
-       u8         device_type:5;
-#else
-       u8         device_type:5;
-       u8         peripheral_qual:3;
-#endif
-       u8         page_code;
-       u8         reserved;
-       u8         page_length;
-       u8         pages[SCSI_INQ_PAGES_MAX];
-};
-
-/*
- * Unit serial number page
- */
-#define SCSI_INQ_USN_LEN 32
-
-struct scsi_inq_usn_s{
-       char            usn[SCSI_INQ_USN_LEN];
-};
-
-struct scsi_inq_page_usn_s{
-#ifdef __BIGENDIAN
-       u8         peripheral_qual:3;
-       u8         device_type:5;
-#else
-       u8         device_type:5;
-       u8         peripheral_qual:3;
-#endif
-       u8         page_code;
-       u8         reserved1;
-       u8         page_length;
-       struct scsi_inq_usn_s  usn;
-};
-
-enum {
-       SCSI_INQ_DIP_CODE_BINARY = 1,   /* identifier has binary value */
-       SCSI_INQ_DIP_CODE_ASCII = 2,    /* identifier has ascii value */
-};
-
-enum {
-       SCSI_INQ_DIP_ASSOC_LUN = 0,     /* id is associated with device */
-       SCSI_INQ_DIP_ASSOC_PORT = 1,    /* id is associated with port that
-                                        * received the request
-                                        */
-};
-
-enum {
-       SCSI_INQ_ID_TYPE_VENDOR = 1,
-       SCSI_INQ_ID_TYPE_IEEE = 2,
-       SCSI_INQ_ID_TYPE_FC_FS = 3,
-       SCSI_INQ_ID_TYPE_OTHER = 4,
-};
-
-struct scsi_inq_dip_desc_s{
-#ifdef __BIGENDIAN
-       u8         res0:4;
-       u8         code_set:4;
-       u8         res1:2;
-       u8         association:2;
-       u8         id_type:4;
-#else
-       u8         code_set:4;
-       u8         res0:4;
-       u8         id_type:4;
-       u8         association:2;
-       u8         res1:2;
-#endif
-       u8         res2;
-       u8         id_len;
-       struct scsi_lun_sn_s   id;
-};
-
-/*
- * Device indentification page
- */
-struct scsi_inq_page_dev_ident_s{
-#ifdef __BIGENDIAN
-       u8         peripheral_qual:3;
-       u8         device_type:5;
-#else
-       u8         device_type:5;
-       u8         peripheral_qual:3;
-#endif
-       u8         page_code;
-       u8         reserved1;
-       u8         page_length;
-       struct scsi_inq_dip_desc_s desc;
-};
-
-/* ------------------------------------------------------------
- * READ CAPACITY
- * ------------------------------------------------------------
- */
-
-struct scsi_read_capacity_s{
-       u8         opcode;
-#ifdef __BIGENDIAN
-       u8         lun:3;
-       u8         reserved1:4;
-       u8         rel_adr:1;
-#else
-       u8         rel_adr:1;
-       u8         reserved1:4;
-       u8         lun:3;
-#endif
-       u8         lba0;        /* MSB */
-       u8         lba1;
-       u8         lba2;
-       u8         lba3;        /* LSB */
-       u8         reserved2;
-       u8         reserved3;
-#ifdef __BIGENDIAN
-       u8         reserved4:7;
-       u8         pmi:1;       /* partial medium indicator */
-#else
-       u8         pmi:1;       /* partial medium indicator */
-       u8         reserved4:7;
-#endif
-       u8         control;
-};
-
-struct scsi_read_capacity_data_s{
-       u32        max_lba;     /* maximum LBA available */
-       u32        block_length;        /* in bytes */
-};
-
-struct scsi_read_capacity16_data_s{
-       u64        lba; /* maximum LBA available */
-       u32        block_length;        /* in bytes */
-#ifdef __BIGENDIAN
-       u8         reserved1:4,
-                       p_type:3,
-                       prot_en:1;
-       u8              reserved2:4,
-                       lb_pbe:4;       /* logical blocks per physical block
-                                        * exponent */
-       u16     reserved3:2,
-                       lba_align:14;   /* lowest aligned logical block
-                                        * address */
-#else
-       u16     lba_align:14,   /* lowest aligned logical block
-                                        * address */
-                       reserved3:2;
-       u8              lb_pbe:4,       /* logical blocks per physical block
-                                        * exponent */
-                       reserved2:4;
-       u8              prot_en:1,
-                       p_type:3,
-                       reserved1:4;
-#endif
-       u64     reserved4;
-       u64     reserved5;
-};
-
-/* ------------------------------------------------------------
- * REPORT LUNS command
- * ------------------------------------------------------------
- */
-
-struct scsi_report_luns_s{
-       u8         opcode;              /* A0h - REPORT LUNS opCode */
-       u8         reserved1[5];
-       u8         alloc_length[4];/* allocation length MSB first */
-       u8         reserved2;
-       u8         control;
-};
-
-#define SCSI_REPORT_LUN_ALLOC_LENGTH(rl)                               \
-    ((rl->alloc_length[0] << 24) | (rl->alloc_length[1] << 16) |       \
-     (rl->alloc_length[2] << 8) | (rl->alloc_length[3]))
-
-#define SCSI_REPORT_LUNS_SET_ALLOCLEN(rl, alloc_len) {      \
-    (rl)->alloc_length[0] = (alloc_len) >> 24;                         \
-    (rl)->alloc_length[1] = ((alloc_len) >> 16) & 0xFF;                \
-    (rl)->alloc_length[2] = ((alloc_len) >> 8) & 0xFF;                 \
-    (rl)->alloc_length[3] = (alloc_len) & 0xFF;                        \
-}
-
-struct scsi_report_luns_data_s{
-       u32        lun_list_length;     /* length of LUN list length */
-       u32        reserved;
-       lun_t           lun[1];                 /* first LUN in lun list */
-};
-
-/* -------------------------------------------------------------
- * SCSI mode  parameters
- * -----------------------------------------------------------
- */
-enum {
-       SCSI_DA_MEDIUM_DEF = 0, /* direct access default medium type */
-       SCSI_DA_MEDIUM_SS = 1,  /* direct access single sided */
-       SCSI_DA_MEDIUM_DS = 2,  /* direct access double sided */
-};
-
-/*
- * SCSI Mode Select(6) cdb
- */
-struct scsi_mode_select6_s{
-       u8         opcode;
-#ifdef __BIGENDIAN
-       u8         reserved1:3;
-       u8         pf:1;                /* page format */
-       u8         reserved2:3;
-       u8         sp:1;                /* save pages if set to 1 */
-#else
-       u8         sp:1;        /* save pages if set to 1 */
-       u8         reserved2:3;
-       u8         pf:1;        /* page format */
-       u8         reserved1:3;
-#endif
-       u8         reserved3[2];
-       u8         alloc_len;
-       u8         control;
-};
-
-/*
- * SCSI Mode Select(10) cdb
- */
-struct scsi_mode_select10_s{
-       u8         opcode;
-#ifdef __BIGENDIAN
-       u8         reserved1:3;
-       u8         pf:1;        /* page format */
-       u8         reserved2:3;
-       u8         sp:1;        /* save pages if set to 1 */
-#else
-       u8         sp:1;        /* save pages if set to 1 */
-       u8         reserved2:3;
-       u8         pf:1;        /* page format */
-       u8         reserved1:3;
-#endif
-       u8         reserved3[5];
-       u8         alloc_len_msb;
-       u8         alloc_len_lsb;
-       u8         control;
-};
-
-/*
- * SCSI Mode Sense(6) cdb
- */
-struct scsi_mode_sense6_s{
-       u8         opcode;
-#ifdef __BIGENDIAN
-       u8         reserved1:4;
-       u8         dbd:1;       /* disable block discriptors if set to 1 */
-       u8         reserved2:3;
-
-       u8         pc:2;        /* page control */
-       u8         page_code:6;
-#else
-       u8         reserved2:3;
-       u8         dbd:1;       /* disable block descriptors if set to 1 */
-       u8         reserved1:4;
-
-       u8         page_code:6;
-       u8         pc:2;        /* page control */
-#endif
-       u8         reserved3;
-       u8         alloc_len;
-       u8         control;
-};
-
-/*
- * SCSI Mode Sense(10) cdb
- */
-struct scsi_mode_sense10_s{
-       u8         opcode;
-#ifdef __BIGENDIAN
-       u8         reserved1:3;
-       u8         LLBAA:1;     /* long LBA accepted if set to 1 */
-       u8         dbd:1;               /* disable block descriptors if set
-                                        * to 1
-                                        */
-       u8         reserved2:3;
-
-       u8         pc:2;                /* page control */
-       u8         page_code:6;
-#else
-       u8         reserved2:3;
-       u8         dbd:1;               /* disable block descriptors if set to
-                                        * 1
-                                        */
-       u8         LLBAA:1;     /* long LBA accepted if set to 1 */
-       u8         reserved1:3;
-
-       u8         page_code:6;
-       u8         pc:2;                /* page control */
-#endif
-       u8         reserved3[4];
-       u8         alloc_len_msb;
-       u8         alloc_len_lsb;
-       u8         control;
-};
-
-#define SCSI_CDB10_GET_AL(cdb)                                         \
-    ((cdb)->alloc_len_msb << 8 | (cdb)->alloc_len_lsb)
-
-#define SCSI_CDB10_SET_AL(cdb, al) {      \
-    (cdb)->alloc_len_msb = al >> 8;                                    \
-    (cdb)->alloc_len_lsb = al & 0xFF;                                  \
-}
-
-#define SCSI_CDB6_GET_AL(cdb) ((cdb)->alloc_len)
-
-#define SCSI_CDB6_SET_AL(cdb, al) {      \
-    (cdb)->alloc_len = al;                                             \
-}
-
-/*
- * page control field values
- */
-#define SCSI_PC_CURRENT_VALUES       0x0
-#define SCSI_PC_CHANGEABLE_VALUES    0x1
-#define SCSI_PC_DEFAULT_VALUES       0x2
-#define SCSI_PC_SAVED_VALUES         0x3
-
-/*
- * SCSI mode page codes
- */
-#define SCSI_MP_VENDOR_SPEC     0x00
-#define SCSI_MP_DISC_RECN       0x02   /* disconnect-reconnect page */
-#define SCSI_MP_FORMAT_DEVICE   0x03
-#define SCSI_MP_RDG             0x04   /* rigid disk geometry page */
-#define SCSI_MP_FDP             0x05   /* flexible disk page */
-#define SCSI_MP_CACHING         0x08   /* caching page */
-#define SCSI_MP_CONTROL         0x0A   /* control mode page */
-#define SCSI_MP_MED_TYPES_SUP   0x0B   /* medium types supported page */
-#define SCSI_MP_INFO_EXCP_CNTL  0x1C   /* informational exception control */
-#define SCSI_MP_ALL             0x3F   /* return all pages - mode sense only */
-
-/*
- * mode parameter header
- */
-struct scsi_mode_param_header6_s{
-       u8         mode_datalen;
-       u8         medium_type;
-
-       /*
-        * device specific parameters expanded for direct access devices
-        */
-#ifdef __BIGENDIAN
-       u32        wp:1;                /* write protected */
-       u32        reserved1:2;
-       u32        dpofua:1;    /* disable page out + force unit access
-                                        */
-       u32        reserved2:4;
-#else
-       u32        reserved2:4;
-       u32        dpofua:1;    /* disable page out + force unit access
-                                        */
-       u32        reserved1:2;
-       u32        wp:1;                /* write protected */
-#endif
-
-       u8         block_desclen;
-};
-
-struct scsi_mode_param_header10_s{
-       u32        mode_datalen:16;
-       u32        medium_type:8;
-
-       /*
-        * device specific parameters expanded for direct access devices
-        */
-#ifdef __BIGENDIAN
-       u32        wp:1;                /* write protected */
-       u32        reserved1:2;
-       u32        dpofua:1;    /* disable page out + force unit access
-                                        */
-       u32        reserved2:4;
-#else
-       u32        reserved2:4;
-       u32        dpofua:1;    /* disable page out + force unit access
-                                        */
-       u32        reserved1:2;
-       u32        wp:1;                /* write protected */
-#endif
-
-#ifdef __BIGENDIAN
-       u32        reserved3:7;
-       u32        longlba:1;
-#else
-       u32        longlba:1;
-       u32        reserved3:7;
-#endif
-       u32        reserved4:8;
-       u32        block_desclen:16;
-};
-
-/*
- * mode parameter block descriptor
- */
-struct scsi_mode_param_desc_s{
-       u32        nblks;
-       u32        density_code:8;
-       u32        block_length:24;
-};
-
-/*
- * Disconnect-reconnect mode page format
- */
-struct scsi_mp_disc_recn_s{
-#ifdef __BIGENDIAN
-       u8         ps:1;
-       u8         reserved1:1;
-       u8         page_code:6;
-#else
-       u8         page_code:6;
-       u8         reserved1:1;
-       u8         ps:1;
-#endif
-       u8         page_len;
-       u8         buf_full_ratio;
-       u8         buf_empty_ratio;
-
-       u8         bil_msb;     /* bus inactivity limit -MSB */
-       u8         bil_lsb;     /* bus inactivity limit -LSB */
-
-       u8         dtl_msb;     /* disconnect time limit - MSB */
-       u8         dtl_lsb;     /* disconnect time limit - LSB */
-
-       u8         ctl_msb;     /* connect time limit - MSB */
-       u8         ctl_lsb;     /* connect time limit - LSB */
-
-       u8         max_burst_len_msb;
-       u8         max_burst_len_lsb;
-#ifdef __BIGENDIAN
-       u8         emdp:1;      /* enable modify data pointers */
-       u8         fa:3;        /* fair arbitration */
-       u8         dimm:1;      /* disconnect immediate */
-       u8         dtdc:3;      /* data transfer disconnect control */
-#else
-       u8         dtdc:3;      /* data transfer disconnect control */
-       u8         dimm:1;      /* disconnect immediate */
-       u8         fa:3;        /* fair arbitration */
-       u8         emdp:1;      /* enable modify data pointers */
-#endif
-
-       u8         reserved3;
-
-       u8         first_burst_len_msb;
-       u8         first_burst_len_lsb;
-};
-
-/*
- * SCSI format device mode page
- */
-struct scsi_mp_format_device_s{
-#ifdef __BIGENDIAN
-       u32        ps:1;
-       u32        reserved1:1;
-       u32        page_code:6;
-#else
-       u32        page_code:6;
-       u32        reserved1:1;
-       u32        ps:1;
-#endif
-       u32        page_len:8;
-       u32        tracks_per_zone:16;
-
-       u32        a_sec_per_zone:16;
-       u32        a_tracks_per_zone:16;
-
-       u32        a_tracks_per_lun:16; /* alternate tracks/lun-MSB */
-       u32        sec_per_track:16;    /* sectors/track-MSB */
-
-       u32        bytes_per_sector:16;
-       u32        interleave:16;
-
-       u32        tsf:16;                      /* track skew factor-MSB */
-       u32        csf:16;                      /* cylinder skew factor-MSB */
-
-#ifdef __BIGENDIAN
-       u32        ssec:1;      /* soft sector formatting */
-       u32        hsec:1;      /* hard sector formatting */
-       u32        rmb:1;       /* removable media */
-       u32        surf:1;      /* surface */
-       u32        reserved2:4;
-#else
-       u32        reserved2:4;
-       u32        surf:1;      /* surface */
-       u32        rmb:1;       /* removable media */
-       u32        hsec:1;      /* hard sector formatting */
-       u32        ssec:1;      /* soft sector formatting */
-#endif
-       u32        reserved3:24;
-};
-
-/*
- * SCSI rigid disk device geometry page
- */
-struct scsi_mp_rigid_device_geometry_s{
-#ifdef __BIGENDIAN
-       u32        ps:1;
-       u32        reserved1:1;
-       u32        page_code:6;
-#else
-       u32        page_code:6;
-       u32        reserved1:1;
-       u32        ps:1;
-#endif
-       u32        page_len:8;
-       u32        num_cylinders0:8;
-       u32        num_cylinders1:8;
-
-       u32        num_cylinders2:8;
-       u32        num_heads:8;
-       u32        scwp0:8;
-       u32        scwp1:8;
-
-       u32        scwp2:8;
-       u32        scrwc0:8;
-       u32        scrwc1:8;
-       u32        scrwc2:8;
-
-       u32        dsr:16;
-       u32        lscyl0:8;
-       u32        lscyl1:8;
-
-       u32        lscyl2:8;
-#ifdef __BIGENDIAN
-       u32        reserved2:6;
-       u32        rpl:2;       /* rotational position locking */
-#else
-       u32        rpl:2;       /* rotational position locking */
-       u32        reserved2:6;
-#endif
-       u32        rot_off:8;
-       u32        reserved3:8;
-
-       u32        med_rot_rate:16;
-       u32        reserved4:16;
-};
-
-/*
- * SCSI caching mode page
- */
-struct scsi_mp_caching_s{
-#ifdef __BIGENDIAN
-       u8         ps:1;
-       u8         res1:1;
-       u8         page_code:6;
-#else
-       u8         page_code:6;
-       u8         res1:1;
-       u8         ps:1;
-#endif
-       u8         page_len;
-#ifdef __BIGENDIAN
-       u8         ic:1;        /* initiator control */
-       u8         abpf:1;      /* abort pre-fetch */
-       u8         cap:1;       /* caching analysis permitted */
-       u8         disc:1;      /* discontinuity */
-       u8         size:1;      /* size enable */
-       u8         wce:1;       /* write cache enable */
-       u8         mf:1;        /* multiplication factor */
-       u8         rcd:1;       /* read cache disable */
-
-       u8         drrp:4;      /* demand read retention priority */
-       u8         wrp:4;       /* write retention priority */
-#else
-       u8         rcd:1;       /* read cache disable */
-       u8         mf:1;        /* multiplication factor */
-       u8         wce:1;       /* write cache enable */
-       u8         size:1;      /* size enable */
-       u8         disc:1;      /* discontinuity */
-       u8         cap:1;       /* caching analysis permitted */
-       u8         abpf:1;      /* abort pre-fetch */
-       u8         ic:1;        /* initiator control */
-
-       u8         wrp:4;       /* write retention priority */
-       u8         drrp:4;      /* demand read retention priority */
-#endif
-       u8         dptl[2];/* disable pre-fetch transfer length */
-       u8         min_prefetch[2];
-       u8         max_prefetch[2];
-       u8         max_prefetch_limit[2];
-#ifdef __BIGENDIAN
-       u8         fsw:1;       /* force sequential write */
-       u8         lbcss:1;/* logical block cache segment size */
-       u8         dra:1;       /* disable read ahead */
-       u8         vs:2;        /* vendor specific */
-       u8         res2:3;
-#else
-       u8         res2:3;
-       u8         vs:2;        /* vendor specific */
-       u8         dra:1;       /* disable read ahead */
-       u8         lbcss:1;/* logical block cache segment size */
-       u8         fsw:1;       /* force sequential write */
-#endif
-       u8         num_cache_segs;
-
-       u8         cache_seg_size[2];
-       u8         res3;
-       u8         non_cache_seg_size[3];
-};
-
-/*
- * SCSI control mode page
- */
-struct scsi_mp_control_page_s{
-#ifdef __BIGENDIAN
-u8         ps:1;
-u8         reserved1:1;
-u8         page_code:6;
-#else
-u8         page_code:6;
-u8         reserved1:1;
-u8         ps:1;
-#endif
-       u8         page_len;
-#ifdef __BIGENDIAN
-       u8         tst:3;               /* task set type */
-       u8         reserved3:3;
-       u8         gltsd:1;     /* global logging target save disable */
-       u8         rlec:1;              /* report log exception condition */
-
-       u8         qalgo_mod:4; /* queue alogorithm modifier */
-       u8         reserved4:1;
-       u8         qerr:2;              /* queue error management */
-       u8         dque:1;              /* disable queuing */
-
-       u8         reserved5:1;
-       u8         rac:1;               /* report a check */
-       u8         reserved6:2;
-       u8         swp:1;               /* software write protect */
-       u8         raerp:1;     /* ready AER permission */
-       u8         uaaerp:1;    /* unit attenstion AER permission */
-       u8         eaerp:1;     /* error AER permission */
-
-       u8         reserved7:5;
-       u8         autoload_mod:3;
-#else
-       u8         rlec:1;              /* report log exception condition */
-       u8         gltsd:1;     /* global logging target save disable */
-       u8         reserved3:3;
-       u8         tst:3;               /* task set type */
-
-       u8         dque:1;              /* disable queuing */
-       u8         qerr:2;              /* queue error management */
-       u8         reserved4:1;
-       u8         qalgo_mod:4; /* queue alogorithm modifier */
-
-       u8         eaerp:1;     /* error AER permission */
-       u8         uaaerp:1;    /* unit attenstion AER permission */
-       u8         raerp:1;     /* ready AER permission */
-       u8         swp:1;               /* software write protect */
-       u8         reserved6:2;
-       u8         rac:1;               /* report a check */
-       u8         reserved5:1;
-
-       u8         autoload_mod:3;
-       u8         reserved7:5;
-#endif
-       u8         rahp_msb;    /* ready AER holdoff period - MSB */
-       u8         rahp_lsb;    /* ready AER holdoff period - LSB */
-
-       u8         busy_timeout_period_msb;
-       u8         busy_timeout_period_lsb;
-
-       u8         ext_selftest_compl_time_msb;
-       u8         ext_selftest_compl_time_lsb;
-};
-
-/*
- * SCSI medium types supported mode page
- */
-struct scsi_mp_medium_types_sup_s{
-#ifdef __BIGENDIAN
-       u8         ps:1;
-       u8         reserved1:1;
-       u8         page_code:6;
-#else
-       u8         page_code:6;
-       u8         reserved1:1;
-       u8         ps:1;
-#endif
-       u8         page_len;
-
-       u8         reserved3[2];
-       u8         med_type1_sup;       /* medium type one supported */
-       u8         med_type2_sup;       /* medium type two supported */
-       u8         med_type3_sup;       /* medium type three supported */
-       u8         med_type4_sup;       /* medium type four supported */
-};
-
-/*
- * SCSI informational exception control mode page
- */
-struct scsi_mp_info_excpt_cntl_s{
-#ifdef __BIGENDIAN
-       u8         ps:1;
-       u8         reserved1:1;
-       u8         page_code:6;
-#else
-       u8         page_code:6;
-       u8         reserved1:1;
-       u8         ps:1;
-#endif
-       u8         page_len;
-#ifdef __BIGENDIAN
-       u8         perf:1;              /* performance */
-       u8         reserved3:1;
-       u8         ebf:1;               /* enable background fucntion */
-       u8         ewasc:1;     /* enable warning */
-       u8         dexcpt:1;    /* disable exception control */
-       u8         test:1;              /* enable test device failure
-                                        * notification
-                                        */
-       u8         reserved4:1;
-       u8         log_error:1;
-
-       u8         reserved5:4;
-       u8         mrie:4;              /* method of reporting info
-                                        * exceptions
-                                        */
-#else
-       u8         log_error:1;
-       u8         reserved4:1;
-       u8         test:1;              /* enable test device failure
-                                        * notification
-                                        */
-       u8         dexcpt:1;    /* disable exception control */
-       u8         ewasc:1;     /* enable warning */
-       u8         ebf:1;               /* enable background fucntion */
-       u8         reserved3:1;
-       u8         perf:1;              /* performance */
-
-       u8         mrie:4;              /* method of reporting info
-                                        * exceptions
-                                        */
-       u8         reserved5:4;
-#endif
-       u8         interval_timer_msb;
-       u8         interval_timer_lsb;
-
-       u8         report_count_msb;
-       u8         report_count_lsb;
-};
-
-/*
- * Methods of reporting informational exceptions
- */
-#define SCSI_MP_IEC_NO_REPORT       0x0        /* no reporting of exceptions */
-#define SCSI_MP_IEC_AER             0x1        /* async event reporting */
-#define SCSI_MP_IEC_UNIT_ATTN       0x2        /* generate unit attenstion */
-#define SCSI_MO_IEC_COND_REC_ERR    0x3        /* conditionally generate recovered
-                                        * error
-                                        */
-#define SCSI_MP_IEC_UNCOND_REC_ERR  0x4        /* unconditionally generate recovered
-                                        * error
-                                        */
-#define SCSI_MP_IEC_NO_SENSE        0x5        /* generate no sense */
-#define SCSI_MP_IEC_ON_REQUEST      0x6        /* only report exceptions on request */
-
-/*
- * SCSI flexible disk page
- */
-struct scsi_mp_flexible_disk_s{
-#ifdef __BIGENDIAN
-       u8         ps:1;
-       u8         reserved1:1;
-       u8         page_code:6;
-#else
-       u8         page_code:6;
-       u8         reserved1:1;
-       u8         ps:1;
-#endif
-       u8         page_len;
-
-       u8         transfer_rate_msb;
-       u8         transfer_rate_lsb;
-
-       u8         num_heads;
-       u8         num_sectors;
-
-       u8         bytes_per_sector_msb;
-       u8         bytes_per_sector_lsb;
-
-       u8         num_cylinders_msb;
-       u8         num_cylinders_lsb;
-
-       u8         sc_wpc_msb;  /* starting cylinder-write
-                                        * precompensation msb
-                                        */
-       u8         sc_wpc_lsb;  /* starting cylinder-write
-                                        * precompensation lsb
-                                        */
-       u8         sc_rwc_msb;  /* starting cylinder-reduced write
-                                        * current msb
-                                        */
-       u8         sc_rwc_lsb;  /* starting cylinder-reduced write
-                                        * current lsb
-                                        */
-
-       u8         dev_step_rate_msb;
-       u8         dev_step_rate_lsb;
-
-       u8         dev_step_pulse_width;
-
-       u8         head_sd_msb; /* head settle delay msb */
-       u8         head_sd_lsb; /* head settle delay lsb */
-
-       u8         motor_on_delay;
-       u8         motor_off_delay;
-#ifdef __BIGENDIAN
-       u8         trdy:1;              /* true ready bit */
-       u8         ssn:1;               /* start sector number bit */
-       u8         mo:1;                /* motor on bit */
-       u8         reserved3:5;
-
-       u8         reserved4:4;
-       u8         spc:4;               /* step pulse per cylinder */
-#else
-       u8         reserved3:5;
-       u8         mo:1;                /* motor on bit */
-       u8         ssn:1;               /* start sector number bit */
-       u8         trdy:1;              /* true ready bit */
-
-       u8         spc:4;               /* step pulse per cylinder */
-       u8         reserved4:4;
-#endif
-       u8         write_comp;
-       u8         head_load_delay;
-       u8         head_unload_delay;
-#ifdef __BIGENDIAN
-       u8         pin34:4;     /* pin34 usage */
-       u8         pin2:4;              /* pin2 usage */
-
-       u8         pin4:4;              /* pin4 usage */
-       u8         pin1:4;              /* pin1 usage */
-#else
-       u8         pin2:4;              /* pin2 usage */
-       u8         pin34:4;     /* pin34 usage */
-
-       u8         pin1:4;              /* pin1 usage */
-       u8         pin4:4;              /* pin4 usage */
-#endif
-       u8         med_rot_rate_msb;
-       u8         med_rot_rate_lsb;
-
-       u8         reserved5[2];
-};
-
-struct scsi_mode_page_format_data6_s{
-       struct scsi_mode_param_header6_s mph;   /* mode page header */
-       struct scsi_mode_param_desc_s desc;     /* block descriptor */
-       struct scsi_mp_format_device_s format;  /* format device data */
-};
-
-struct scsi_mode_page_format_data10_s{
-       struct scsi_mode_param_header10_s mph;  /* mode page header */
-       struct scsi_mode_param_desc_s desc;     /* block descriptor */
-       struct scsi_mp_format_device_s format;  /* format device data */
-};
-
-struct scsi_mode_page_rdg_data6_s{
-       struct scsi_mode_param_header6_s mph;   /* mode page header */
-       struct scsi_mode_param_desc_s desc;     /* block descriptor */
-       struct scsi_mp_rigid_device_geometry_s rdg;
-                                       /* rigid geometry data */
-};
-
-struct scsi_mode_page_rdg_data10_s{
-       struct scsi_mode_param_header10_s mph;  /* mode page header */
-       struct scsi_mode_param_desc_s desc;     /* block descriptor */
-       struct scsi_mp_rigid_device_geometry_s rdg;
-                                       /* rigid geometry data */
-};
-
-struct scsi_mode_page_cache6_s{
-       struct scsi_mode_param_header6_s mph;   /* mode page header */
-       struct scsi_mode_param_desc_s desc;     /* block descriptor */
-       struct scsi_mp_caching_s cache; /* cache page data */
-};
-
-struct scsi_mode_page_cache10_s{
-       struct scsi_mode_param_header10_s mph;  /* mode page header */
-       struct scsi_mode_param_desc_s desc;     /* block descriptor */
-       struct scsi_mp_caching_s cache; /* cache page data */
-};
-
-/* --------------------------------------------------------------
- * Format Unit command
- * ------------------------------------------------------------
- */
-
-/*
- * Format Unit CDB
- */
-struct scsi_format_unit_s{
-       u8         opcode;
-#ifdef __BIGENDIAN
-       u8         res1:3;
-       u8         fmtdata:1;   /* if set, data out phase has format
-                                        * data
-                                        */
-       u8         cmplst:1;    /* if set, defect list is complete */
-       u8         def_list:3;  /* format of defect descriptor is
-                                        * fmtdata =1
-                                        */
-#else
-       u8         def_list:3;  /* format of defect descriptor is
-                                        * fmtdata = 1
-                                        */
-       u8         cmplst:1;    /* if set, defect list is complete */
-       u8         fmtdata:1;   /* if set, data out phase has format
-                                        * data
-                                        */
-       u8         res1:3;
-#endif
-       u8         interleave_msb;
-       u8         interleave_lsb;
-       u8         vendor_spec;
-       u8         control;
-};
-
-/*
- * h
- */
-struct scsi_reserve6_s{
-       u8         opcode;
-#ifdef __BIGENDIAN
-       u8         reserved:3;
-       u8         obsolete:4;
-       u8         extent:1;
-#else
-       u8         extent:1;
-       u8         obsolete:4;
-       u8         reserved:3;
-#endif
-       u8         reservation_id;
-       u16        param_list_len;
-       u8         control;
-};
-
-/*
- * h
- */
-struct scsi_release6_s{
-       u8         opcode;
-#ifdef __BIGENDIAN
-       u8         reserved1:3;
-       u8         obsolete:4;
-       u8         extent:1;
-#else
-       u8         extent:1;
-       u8         obsolete:4;
-       u8         reserved1:3;
-#endif
-       u8         reservation_id;
-       u16        reserved2;
-       u8         control;
-};
-
-/*
- * h
- */
-struct scsi_reserve10_s{
-       u8         opcode;
-#ifdef __BIGENDIAN
-       u8         reserved1:3;
-       u8         third_party:1;
-       u8         reserved2:2;
-       u8         long_id:1;
-       u8         extent:1;
-#else
-       u8         extent:1;
-       u8         long_id:1;
-       u8         reserved2:2;
-       u8         third_party:1;
-       u8         reserved1:3;
-#endif
-       u8         reservation_id;
-       u8         third_pty_dev_id;
-       u8         reserved3;
-       u8         reserved4;
-       u8         reserved5;
-       u16        param_list_len;
-       u8         control;
-};
-
-struct scsi_release10_s{
-       u8         opcode;
-#ifdef __BIGENDIAN
-       u8         reserved1:3;
-       u8         third_party:1;
-       u8         reserved2:2;
-       u8         long_id:1;
-       u8         extent:1;
-#else
-       u8         extent:1;
-       u8         long_id:1;
-       u8         reserved2:2;
-       u8         third_party:1;
-       u8         reserved1:3;
-#endif
-       u8         reservation_id;
-       u8         third_pty_dev_id;
-       u8         reserved3;
-       u8         reserved4;
-       u8         reserved5;
-       u16        param_list_len;
-       u8         control;
-};
-
-struct scsi_verify10_s{
-       u8         opcode;
-#ifdef __BIGENDIAN
-       u8         lun:3;
-       u8         dpo:1;
-       u8         reserved:2;
-       u8         bytchk:1;
-       u8         reladdr:1;
-#else
-       u8         reladdr:1;
-       u8         bytchk:1;
-       u8         reserved:2;
-       u8         dpo:1;
-       u8         lun:3;
-#endif
-       u8         lba0;
-       u8         lba1;
-       u8         lba2;
-       u8         lba3;
-       u8         reserved1;
-       u8         verification_len0;
-       u8         verification_len1;
-       u8         control_byte;
-};
-
-struct scsi_request_sense_s{
-       u8         opcode;
-#ifdef __BIGENDIAN
-       u8         lun:3;
-       u8         reserved:5;
-#else
-       u8         reserved:5;
-       u8         lun:3;
-#endif
-       u8         reserved0;
-       u8         reserved1;
-       u8         alloc_len;
-       u8         control_byte;
-};
-
-/* ------------------------------------------------------------
- * SCSI status byte values
- * ------------------------------------------------------------
- */
-#define SCSI_STATUS_GOOD                   0x00
-#define SCSI_STATUS_CHECK_CONDITION        0x02
-#define SCSI_STATUS_CONDITION_MET          0x04
-#define SCSI_STATUS_BUSY                   0x08
-#define SCSI_STATUS_INTERMEDIATE           0x10
-#define SCSI_STATUS_ICM                    0x14        /* intermediate condition met */
-#define SCSI_STATUS_RESERVATION_CONFLICT   0x18
-#define SCSI_STATUS_COMMAND_TERMINATED     0x22
-#define SCSI_STATUS_QUEUE_FULL             0x28
-#define SCSI_STATUS_ACA_ACTIVE             0x30
-
-#define SCSI_MAX_ALLOC_LEN             0xFF    /* maximum allocarion length
-                                                * in CDBs
-                                                */
-
-#define SCSI_OP_WRITE_VERIFY10      0x2E
-#define SCSI_OP_WRITE_VERIFY12      0xAE
-#define SCSI_OP_UNDEF               0xFF
-
-/*
- * SCSI WRITE-VERIFY(10) command
- */
-struct scsi_write_verify10_s{
-       u8         opcode;
-#ifdef __BIGENDIAN
-       u8         reserved1:3;
-       u8         dpo:1;               /* Disable Page Out */
-       u8         reserved2:1;
-       u8         ebp:1;               /* erse by-pass */
-       u8         bytchk:1;    /* byte check */
-       u8         rel_adr:1;   /* relative address */
-#else
-       u8         rel_adr:1;   /* relative address */
-       u8         bytchk:1;    /* byte check */
-       u8         ebp:1;               /* erse by-pass */
-       u8         reserved2:1;
-       u8         dpo:1;               /* Disable Page Out */
-       u8         reserved1:3;
-#endif
-       u8         lba0;                /* logical block address - MSB */
-       u8         lba1;
-       u8         lba2;
-       u8         lba3;                /* LSB */
-       u8         reserved3;
-       u8         xfer_length0;        /* transfer length in blocks - MSB */
-       u8         xfer_length1;        /* LSB */
-       u8         control;
-};
-
-#pragma pack()
-
-#endif /* __SCSI_H__ */
diff --git a/drivers/scsi/bfa/include/protocol/types.h b/drivers/scsi/bfa/include/protocol/types.h
deleted file mode 100644 (file)
index 2875a6c..0000000
+++ /dev/null
@@ -1,42 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  types.h Protocol defined base types
- */
-
-#ifndef __TYPES_H__
-#define __TYPES_H__
-
-#include <bfa_os_inc.h>
-
-#define wwn_t u64
-#define lun_t u64
-
-#define WWN_NULL       (0)
-#define FC_SYMNAME_MAX 256     /*  max name server symbolic name size */
-#define FC_ALPA_MAX    128
-
-#pragma pack(1)
-
-#define MAC_ADDRLEN    (6)
-struct mac_s { u8 mac[MAC_ADDRLEN]; };
-#define mac_t struct mac_s
-
-#pragma pack()
-
-#endif
diff --git a/drivers/scsi/bfa/loop.c b/drivers/scsi/bfa/loop.c
deleted file mode 100644 (file)
index f6342ef..0000000
+++ /dev/null
@@ -1,213 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  port_loop.c vport private loop implementation.
- */
-#include <bfa.h>
-#include <bfa_svc.h>
-#include "fcs_lport.h"
-#include "fcs_rport.h"
-#include "fcs_trcmod.h"
-#include "lport_priv.h"
-
-BFA_TRC_FILE(FCS, LOOP);
-
-/**
- *   ALPA to LIXA bitmap mapping
- *
- *   ALPA 0x00 (Word 0, Bit 30) is invalid for N_Ports. Also Word 0 Bit 31
- * is for L_bit (login required) and is filled as ALPA 0x00 here.
- */
-static const u8   port_loop_alpa_map[] = {
-       0xEF, 0xE8, 0xE4, 0xE2, 0xE1, 0xE0, 0xDC, 0xDA, /* Word 3 Bits 0..7 */
-       0xD9, 0xD6, 0xD5, 0xD4, 0xD3, 0xD2, 0xD1, 0xCE, /* Word 3 Bits 8..15 */
-       0xCD, 0xCC, 0xCB, 0xCA, 0xC9, 0xC7, 0xC6, 0xC5, /* Word 3 Bits 16..23 */
-       0xC3, 0xBC, 0xBA, 0xB9, 0xB6, 0xB5, 0xB4, 0xB3, /* Word 3 Bits 24..31 */
-
-       0xB2, 0xB1, 0xAE, 0xAD, 0xAC, 0xAB, 0xAA, 0xA9, /* Word 2 Bits 0..7 */
-       0xA7, 0xA6, 0xA5, 0xA3, 0x9F, 0x9E, 0x9D, 0x9B, /* Word 2 Bits 8..15 */
-       0x98, 0x97, 0x90, 0x8F, 0x88, 0x84, 0x82, 0x81, /* Word 2 Bits 16..23 */
-       0x80, 0x7C, 0x7A, 0x79, 0x76, 0x75, 0x74, 0x73, /* Word 2 Bits 24..31 */
-
-       0x72, 0x71, 0x6E, 0x6D, 0x6C, 0x6B, 0x6A, 0x69, /* Word 1 Bits 0..7 */
-       0x67, 0x66, 0x65, 0x63, 0x5C, 0x5A, 0x59, 0x56, /* Word 1 Bits 8..15 */
-       0x55, 0x54, 0x53, 0x52, 0x51, 0x4E, 0x4D, 0x4C, /* Word 1 Bits 16..23 */
-       0x4B, 0x4A, 0x49, 0x47, 0x46, 0x45, 0x43, 0x3C, /* Word 1 Bits 24..31 */
-
-       0x3A, 0x39, 0x36, 0x35, 0x34, 0x33, 0x32, 0x31, /* Word 0 Bits 0..7 */
-       0x2E, 0x2D, 0x2C, 0x2B, 0x2A, 0x29, 0x27, 0x26, /* Word 0 Bits 8..15 */
-       0x25, 0x23, 0x1F, 0x1E, 0x1D, 0x1B, 0x18, 0x17, /* Word 0 Bits 16..23 */
-       0x10, 0x0F, 0x08, 0x04, 0x02, 0x01, 0x00, 0x00, /* Word 0 Bits 24..31 */
-};
-
-/*
- * Local Functions
- */
-static bfa_status_t bfa_fcs_port_loop_send_plogi(struct bfa_fcs_port_s *port,
-                                       u8 alpa);
-
-static void bfa_fcs_port_loop_plogi_response(void *fcsarg,
-                                       struct bfa_fcxp_s *fcxp,
-                                       void *cbarg,
-                                       bfa_status_t req_status,
-                                       u32 rsp_len,
-                                       u32 resid_len,
-                                       struct fchs_s *rsp_fchs);
-/**
- *   Called by port to initializar in provate LOOP topology.
- */
-void
-bfa_fcs_port_loop_init(struct bfa_fcs_port_s *port)
-{
-}
-
-/**
- *   Called by port to notify transition to online state.
- */
-void
-bfa_fcs_port_loop_online(struct bfa_fcs_port_s *port)
-{
-
-       u8         num_alpa = port->port_topo.ploop.num_alpa;
-       u8        *alpa_pos_map = port->port_topo.ploop.alpa_pos_map;
-       struct bfa_fcs_rport_s *r_port;
-       int             ii = 0;
-
-       /*
-        * If the port role is Initiator Mode, create Rports.
-        */
-       if (port->port_cfg.roles == BFA_PORT_ROLE_FCP_IM) {
-               /*
-                * Check if the ALPA positional bitmap is available.
-                * if not, we send PLOGI to all possible ALPAs.
-                */
-               if (num_alpa > 0) {
-                       for (ii = 0; ii < num_alpa; ii++) {
-                               /*
-                                * ignore ALPA of bfa port
-                                */
-                               if (alpa_pos_map[ii] != port->pid) {
-                                       r_port = bfa_fcs_rport_create(port,
-                                               alpa_pos_map[ii]);
-                               }
-                       }
-               } else {
-                       for (ii = 0; ii < MAX_ALPA_COUNT; ii++) {
-                               /*
-                                * ignore ALPA of bfa port
-                                */
-                               if ((port_loop_alpa_map[ii] > 0)
-                                   && (port_loop_alpa_map[ii] != port->pid))
-                                       bfa_fcs_port_loop_send_plogi(port,
-                                               port_loop_alpa_map[ii]);
-                               /**TBD */
-                       }
-               }
-       } else {
-               /*
-                * TBD Target Mode ??
-                */
-       }
-
-}
-
-/**
- *   Called by port to notify transition to offline state.
- */
-void
-bfa_fcs_port_loop_offline(struct bfa_fcs_port_s *port)
-{
-
-}
-
-/**
- *   Called by port to notify a LIP on the loop.
- */
-void
-bfa_fcs_port_loop_lip(struct bfa_fcs_port_s *port)
-{
-}
-
-/**
- * Local Functions.
- */
-static bfa_status_t
-bfa_fcs_port_loop_send_plogi(struct bfa_fcs_port_s *port, u8 alpa)
-{
-       struct fchs_s          fchs;
-       struct bfa_fcxp_s *fcxp = NULL;
-       int             len;
-
-       bfa_trc(port->fcs, alpa);
-
-       fcxp = bfa_fcxp_alloc(NULL, port->fcs->bfa, 0, 0, NULL, NULL, NULL,
-                                 NULL);
-       bfa_assert(fcxp);
-
-       len = fc_plogi_build(&fchs, bfa_fcxp_get_reqbuf(fcxp), alpa,
-                            bfa_fcs_port_get_fcid(port), 0,
-                            port->port_cfg.pwwn, port->port_cfg.nwwn,
-                                bfa_fcport_get_maxfrsize(port->fcs->bfa));
-
-       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
-                         FC_CLASS_3, len, &fchs,
-                         bfa_fcs_port_loop_plogi_response, (void *)port,
-                         FC_MAX_PDUSZ, FC_RA_TOV);
-
-       return BFA_STATUS_OK;
-}
-
-/**
- *   Called by fcxp to notify the Plogi response
- */
-static void
-bfa_fcs_port_loop_plogi_response(void *fcsarg, struct bfa_fcxp_s *fcxp,
-                                void *cbarg, bfa_status_t req_status,
-                                u32 rsp_len, u32 resid_len,
-                                struct fchs_s *rsp_fchs)
-{
-       struct bfa_fcs_port_s *port = (struct bfa_fcs_port_s *) cbarg;
-       struct fc_logi_s     *plogi_resp;
-       struct fc_els_cmd_s   *els_cmd;
-
-       bfa_trc(port->fcs, req_status);
-
-       /*
-        * Sanity Checks
-        */
-       if (req_status != BFA_STATUS_OK) {
-               bfa_trc(port->fcs, req_status);
-               /*
-                * @todo
-                * This could mean that the device with this APLA does not
-                * exist on the loop.
-                */
-
-               return;
-       }
-
-       els_cmd = (struct fc_els_cmd_s *) BFA_FCXP_RSP_PLD(fcxp);
-       plogi_resp = (struct fc_logi_s *) els_cmd;
-
-       if (els_cmd->els_code == FC_ELS_ACC) {
-               bfa_fcs_rport_start(port, rsp_fchs, plogi_resp);
-       } else {
-               bfa_trc(port->fcs, plogi_resp->els_cmd.els_code);
-               bfa_assert(0);
-       }
-}
diff --git a/drivers/scsi/bfa/lport_api.c b/drivers/scsi/bfa/lport_api.c
deleted file mode 100644 (file)
index 72b3f50..0000000
+++ /dev/null
@@ -1,303 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  port_api.c BFA FCS port
- */
-
-#include <fcs/bfa_fcs.h>
-#include <fcs/bfa_fcs_lport.h>
-#include <fcs/bfa_fcs_rport.h>
-#include "fcs_rport.h"
-#include "fcs_fabric.h"
-#include "fcs_trcmod.h"
-#include "fcs_vport.h"
-
-BFA_TRC_FILE(FCS, PORT_API);
-
-
-
-/**
- *  fcs_port_api BFA FCS port API
- */
-
-void
-bfa_fcs_cfg_base_port(struct bfa_fcs_s *fcs, struct bfa_port_cfg_s *port_cfg)
-{
-}
-
-struct bfa_fcs_port_s *
-bfa_fcs_get_base_port(struct bfa_fcs_s *fcs)
-{
-       return &fcs->fabric.bport;
-}
-
-wwn_t
-bfa_fcs_port_get_rport(struct bfa_fcs_port_s *port, wwn_t wwn, int index,
-                      int nrports, bfa_boolean_t bwwn)
-{
-       struct list_head *qh, *qe;
-       struct bfa_fcs_rport_s *rport = NULL;
-       int             i;
-       struct bfa_fcs_s *fcs;
-
-       if (port == NULL || nrports == 0)
-               return (wwn_t) 0;
-
-       fcs = port->fcs;
-       bfa_trc(fcs, (u32) nrports);
-
-       i = 0;
-       qh = &port->rport_q;
-       qe = bfa_q_first(qh);
-
-       while ((qe != qh) && (i < nrports)) {
-               rport = (struct bfa_fcs_rport_s *)qe;
-               if (bfa_os_ntoh3b(rport->pid) > 0xFFF000) {
-                       qe = bfa_q_next(qe);
-                       bfa_trc(fcs, (u32) rport->pwwn);
-                       bfa_trc(fcs, rport->pid);
-                       bfa_trc(fcs, i);
-                       continue;
-               }
-
-               if (bwwn) {
-                       if (!memcmp(&wwn, &rport->pwwn, 8))
-                               break;
-               } else {
-                       if (i == index)
-                               break;
-               }
-
-               i++;
-               qe = bfa_q_next(qe);
-       }
-
-       bfa_trc(fcs, i);
-       if (rport)
-               return rport->pwwn;
-       else
-               return (wwn_t) 0;
-}
-
-void
-bfa_fcs_port_get_rports(struct bfa_fcs_port_s *port, wwn_t rport_wwns[],
-                       int *nrports)
-{
-       struct list_head *qh, *qe;
-       struct bfa_fcs_rport_s *rport = NULL;
-       int             i;
-       struct bfa_fcs_s *fcs;
-
-       if (port == NULL || rport_wwns == NULL || *nrports == 0)
-               return;
-
-       fcs = port->fcs;
-       bfa_trc(fcs, (u32) *nrports);
-
-       i = 0;
-       qh = &port->rport_q;
-       qe = bfa_q_first(qh);
-
-       while ((qe != qh) && (i < *nrports)) {
-               rport = (struct bfa_fcs_rport_s *)qe;
-               if (bfa_os_ntoh3b(rport->pid) > 0xFFF000) {
-                       qe = bfa_q_next(qe);
-                       bfa_trc(fcs, (u32) rport->pwwn);
-                       bfa_trc(fcs, rport->pid);
-                       bfa_trc(fcs, i);
-                       continue;
-               }
-
-               rport_wwns[i] = rport->pwwn;
-
-               i++;
-               qe = bfa_q_next(qe);
-       }
-
-       bfa_trc(fcs, i);
-       *nrports = i;
-       return;
-}
-
-/*
- * Iterate's through all the rport's in the given port to
- * determine the maximum operating speed.
- *
- * To be used in TRL Functionality only
- */
-enum bfa_pport_speed
-bfa_fcs_port_get_rport_max_speed(struct bfa_fcs_port_s *port)
-{
-       struct list_head *qh, *qe;
-       struct bfa_fcs_rport_s *rport = NULL;
-       struct bfa_fcs_s *fcs;
-       enum bfa_pport_speed max_speed = 0;
-       struct bfa_pport_attr_s pport_attr;
-       enum bfa_pport_speed pport_speed, rport_speed;
-       bfa_boolean_t     trl_enabled = bfa_fcport_is_ratelim(port->fcs->bfa);
-
-       if (port == NULL)
-               return 0;
-
-       fcs = port->fcs;
-
-       /*
-        * Get Physical port's current speed
-        */
-       bfa_fcport_get_attr(port->fcs->bfa, &pport_attr);
-       pport_speed = pport_attr.speed;
-       bfa_trc(fcs, pport_speed);
-
-       qh = &port->rport_q;
-       qe = bfa_q_first(qh);
-
-       while (qe != qh) {
-               rport = (struct bfa_fcs_rport_s *) qe;
-               if ((bfa_os_ntoh3b(rport->pid) > 0xFFF000) ||
-                       (bfa_fcs_rport_get_state(rport) ==
-                                               BFA_RPORT_OFFLINE)) {
-                       qe = bfa_q_next(qe);
-                       continue;
-               }
-
-               rport_speed = rport->rpf.rpsc_speed;
-               if ((trl_enabled) &&  (rport_speed ==
-                                               BFA_PPORT_SPEED_UNKNOWN)) {
-                       /* Use default ratelim speed setting */
-                       rport_speed =
-                               bfa_fcport_get_ratelim_speed(port->fcs->bfa);
-               }
-
-               if ((rport_speed  == BFA_PPORT_SPEED_8GBPS) ||
-                       (rport_speed > pport_speed)) {
-                       max_speed = rport_speed;
-                       break;
-               } else if (rport_speed > max_speed) {
-                       max_speed = rport_speed;
-               }
-
-               qe = bfa_q_next(qe);
-       }
-
-       bfa_trc(fcs, max_speed);
-       return max_speed;
-}
-
-struct bfa_fcs_port_s *
-bfa_fcs_lookup_port(struct bfa_fcs_s *fcs, u16 vf_id, wwn_t lpwwn)
-{
-       struct bfa_fcs_vport_s *vport;
-       bfa_fcs_vf_t   *vf;
-
-       bfa_assert(fcs != NULL);
-
-       vf = bfa_fcs_vf_lookup(fcs, vf_id);
-       if (vf == NULL) {
-               bfa_trc(fcs, vf_id);
-               return NULL;
-       }
-
-       if (!lpwwn || (vf->bport.port_cfg.pwwn == lpwwn))
-               return &vf->bport;
-
-       vport = bfa_fcs_fabric_vport_lookup(vf, lpwwn);
-       if (vport)
-               return &vport->lport;
-
-       return NULL;
-}
-
-/*
- *  API corresponding to VmWare's NPIV_VPORT_GETINFO.
- */
-void
-bfa_fcs_port_get_info(struct bfa_fcs_port_s *port,
-                     struct bfa_port_info_s *port_info)
-{
-
-       bfa_trc(port->fcs, port->fabric->fabric_name);
-
-       if (port->vport == NULL) {
-               /*
-                * This is a Physical port
-                */
-               port_info->port_type = BFA_PORT_TYPE_PHYSICAL;
-
-               /*
-                * @todo : need to fix the state & reason
-                */
-               port_info->port_state = 0;
-               port_info->offline_reason = 0;
-
-               port_info->port_wwn = bfa_fcs_port_get_pwwn(port);
-               port_info->node_wwn = bfa_fcs_port_get_nwwn(port);
-
-               port_info->max_vports_supp =
-                       bfa_lps_get_max_vport(port->fcs->bfa);
-               port_info->num_vports_inuse =
-                       bfa_fcs_fabric_vport_count(port->fabric);
-               port_info->max_rports_supp = BFA_FCS_MAX_RPORTS_SUPP;
-               port_info->num_rports_inuse = port->num_rports;
-       } else {
-               /*
-                * This is a virtual port
-                */
-               port_info->port_type = BFA_PORT_TYPE_VIRTUAL;
-
-               /*
-                * @todo : need to fix the state & reason
-                */
-               port_info->port_state = 0;
-               port_info->offline_reason = 0;
-
-               port_info->port_wwn = bfa_fcs_port_get_pwwn(port);
-               port_info->node_wwn = bfa_fcs_port_get_nwwn(port);
-       }
-}
-
-void
-bfa_fcs_port_get_stats(struct bfa_fcs_port_s *fcs_port,
-                      struct bfa_port_stats_s *port_stats)
-{
-       bfa_os_memcpy(port_stats, &fcs_port->stats,
-                     sizeof(struct bfa_port_stats_s));
-       return;
-}
-
-void
-bfa_fcs_port_clear_stats(struct bfa_fcs_port_s *fcs_port)
-{
-       bfa_os_memset(&fcs_port->stats, 0, sizeof(struct bfa_port_stats_s));
-       return;
-}
-
-void
-bfa_fcs_port_enable_ipfc_roles(struct bfa_fcs_port_s *fcs_port)
-{
-       fcs_port->port_cfg.roles |= BFA_PORT_ROLE_FCP_IPFC;
-       return;
-}
-
-void
-bfa_fcs_port_disable_ipfc_roles(struct bfa_fcs_port_s *fcs_port)
-{
-       fcs_port->port_cfg.roles &= ~BFA_PORT_ROLE_FCP_IPFC;
-       return;
-}
-
-
diff --git a/drivers/scsi/bfa/lport_priv.h b/drivers/scsi/bfa/lport_priv.h
deleted file mode 100644 (file)
index dbae370..0000000
+++ /dev/null
@@ -1,82 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#ifndef __VP_PRIV_H__
-#define __VP_PRIV_H__
-
-#include <fcs/bfa_fcs_lport.h>
-#include <fcs/bfa_fcs_vport.h>
-
-/*
- * Functions exported by vps
- */
-void            bfa_fcs_vport_init(struct bfa_fcs_vport_s *vport);
-
-/*
- * Functions exported by vps
- */
-void            bfa_fcs_vps_online(struct bfa_fcs_port_s *port);
-void            bfa_fcs_vps_offline(struct bfa_fcs_port_s *port);
-void            bfa_fcs_vps_lip(struct bfa_fcs_port_s *port);
-
-/*
- * Functions exported by port_fab
- */
-void            bfa_fcs_port_fab_init(struct bfa_fcs_port_s *vport);
-void            bfa_fcs_port_fab_online(struct bfa_fcs_port_s *vport);
-void            bfa_fcs_port_fab_offline(struct bfa_fcs_port_s *vport);
-void            bfa_fcs_port_fab_rx_frame(struct bfa_fcs_port_s *port,
-                                         u8 *rx_frame, u32 len);
-
-/*
- * Functions exported by VP-NS.
- */
-void            bfa_fcs_port_ns_init(struct bfa_fcs_port_s *vport);
-void            bfa_fcs_port_ns_offline(struct bfa_fcs_port_s *vport);
-void            bfa_fcs_port_ns_online(struct bfa_fcs_port_s *vport);
-void            bfa_fcs_port_ns_query(struct bfa_fcs_port_s *port);
-
-/*
- * Functions exported by VP-SCN
- */
-void            bfa_fcs_port_scn_init(struct bfa_fcs_port_s *vport);
-void            bfa_fcs_port_scn_offline(struct bfa_fcs_port_s *vport);
-void            bfa_fcs_port_scn_online(struct bfa_fcs_port_s *vport);
-void            bfa_fcs_port_scn_process_rscn(struct bfa_fcs_port_s *port,
-                                             struct fchs_s *rx_frame, u32 len);
-
-/*
- * Functions exported by VP-N2N
- */
-
-void            bfa_fcs_port_n2n_init(struct bfa_fcs_port_s *port);
-void            bfa_fcs_port_n2n_online(struct bfa_fcs_port_s *port);
-void            bfa_fcs_port_n2n_offline(struct bfa_fcs_port_s *port);
-void            bfa_fcs_port_n2n_rx_frame(struct bfa_fcs_port_s *port,
-                                         u8 *rx_frame, u32 len);
-
-/*
- * Functions exported by VP-LOOP
- */
-void            bfa_fcs_port_loop_init(struct bfa_fcs_port_s *port);
-void            bfa_fcs_port_loop_online(struct bfa_fcs_port_s *port);
-void            bfa_fcs_port_loop_offline(struct bfa_fcs_port_s *port);
-void            bfa_fcs_port_loop_lip(struct bfa_fcs_port_s *port);
-void            bfa_fcs_port_loop_rx_frame(struct bfa_fcs_port_s *port,
-                                          u8 *rx_frame, u32 len);
-
-#endif /* __VP_PRIV_H__ */
diff --git a/drivers/scsi/bfa/ms.c b/drivers/scsi/bfa/ms.c
deleted file mode 100644 (file)
index 1d579ef..0000000
+++ /dev/null
@@ -1,759 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-
-#include <bfa.h>
-#include <bfa_svc.h>
-#include "fcs_lport.h"
-#include "fcs_rport.h"
-#include "fcs_trcmod.h"
-#include "fcs_fcxp.h"
-#include "lport_priv.h"
-
-BFA_TRC_FILE(FCS, MS);
-
-#define BFA_FCS_MS_CMD_MAX_RETRIES  2
-/*
- * forward declarations
- */
-static void     bfa_fcs_port_ms_send_plogi(void *ms_cbarg,
-                                          struct bfa_fcxp_s *fcxp_alloced);
-static void     bfa_fcs_port_ms_timeout(void *arg);
-static void     bfa_fcs_port_ms_plogi_response(void *fcsarg,
-                                              struct bfa_fcxp_s *fcxp,
-                                              void *cbarg,
-                                              bfa_status_t req_status,
-                                              u32 rsp_len,
-                                              u32 resid_len,
-                                              struct fchs_s *rsp_fchs);
-
-static void     bfa_fcs_port_ms_send_gmal(void *ms_cbarg,
-                                         struct bfa_fcxp_s *fcxp_alloced);
-static void     bfa_fcs_port_ms_gmal_response(void *fcsarg,
-                                             struct bfa_fcxp_s *fcxp,
-                                             void *cbarg,
-                                             bfa_status_t req_status,
-                                             u32 rsp_len,
-                                             u32 resid_len,
-                                             struct fchs_s *rsp_fchs);
-static void     bfa_fcs_port_ms_send_gfn(void *ms_cbarg,
-                                        struct bfa_fcxp_s *fcxp_alloced);
-static void     bfa_fcs_port_ms_gfn_response(void *fcsarg,
-                                            struct bfa_fcxp_s *fcxp,
-                                            void *cbarg,
-                                            bfa_status_t req_status,
-                                            u32 rsp_len,
-                                            u32 resid_len,
-                                            struct fchs_s *rsp_fchs);
-/**
- *  fcs_ms_sm FCS MS state machine
- */
-
-/**
- *  MS State Machine events
- */
-enum port_ms_event {
-       MSSM_EVENT_PORT_ONLINE = 1,
-       MSSM_EVENT_PORT_OFFLINE = 2,
-       MSSM_EVENT_RSP_OK = 3,
-       MSSM_EVENT_RSP_ERROR = 4,
-       MSSM_EVENT_TIMEOUT = 5,
-       MSSM_EVENT_FCXP_SENT = 6,
-       MSSM_EVENT_PORT_FABRIC_RSCN = 7
-};
-
-static void     bfa_fcs_port_ms_sm_offline(struct bfa_fcs_port_ms_s *ms,
-                                          enum port_ms_event event);
-static void     bfa_fcs_port_ms_sm_plogi_sending(struct bfa_fcs_port_ms_s *ms,
-                                                enum port_ms_event event);
-static void     bfa_fcs_port_ms_sm_plogi(struct bfa_fcs_port_ms_s *ms,
-                                        enum port_ms_event event);
-static void     bfa_fcs_port_ms_sm_plogi_retry(struct bfa_fcs_port_ms_s *ms,
-                                              enum port_ms_event event);
-static void     bfa_fcs_port_ms_sm_gmal_sending(struct bfa_fcs_port_ms_s *ms,
-                                               enum port_ms_event event);
-static void     bfa_fcs_port_ms_sm_gmal(struct bfa_fcs_port_ms_s *ms,
-                                       enum port_ms_event event);
-static void     bfa_fcs_port_ms_sm_gmal_retry(struct bfa_fcs_port_ms_s *ms,
-                                             enum port_ms_event event);
-static void     bfa_fcs_port_ms_sm_gfn_sending(struct bfa_fcs_port_ms_s *ms,
-                                              enum port_ms_event event);
-static void     bfa_fcs_port_ms_sm_gfn(struct bfa_fcs_port_ms_s *ms,
-                                      enum port_ms_event event);
-static void     bfa_fcs_port_ms_sm_gfn_retry(struct bfa_fcs_port_ms_s *ms,
-                                            enum port_ms_event event);
-static void     bfa_fcs_port_ms_sm_online(struct bfa_fcs_port_ms_s *ms,
-                                         enum port_ms_event event);
-/**
- *             Start in offline state - awaiting NS to send start.
- */
-static void
-bfa_fcs_port_ms_sm_offline(struct bfa_fcs_port_ms_s *ms,
-                          enum port_ms_event event)
-{
-       bfa_trc(ms->port->fcs, ms->port->port_cfg.pwwn);
-       bfa_trc(ms->port->fcs, event);
-
-       switch (event) {
-       case MSSM_EVENT_PORT_ONLINE:
-               bfa_sm_set_state(ms, bfa_fcs_port_ms_sm_plogi_sending);
-               bfa_fcs_port_ms_send_plogi(ms, NULL);
-               break;
-
-       case MSSM_EVENT_PORT_OFFLINE:
-               break;
-
-       default:
-               bfa_sm_fault(ms->port->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_port_ms_sm_plogi_sending(struct bfa_fcs_port_ms_s *ms,
-                                enum port_ms_event event)
-{
-       bfa_trc(ms->port->fcs, ms->port->port_cfg.pwwn);
-       bfa_trc(ms->port->fcs, event);
-
-       switch (event) {
-       case MSSM_EVENT_FCXP_SENT:
-               bfa_sm_set_state(ms, bfa_fcs_port_ms_sm_plogi);
-               break;
-
-       case MSSM_EVENT_PORT_OFFLINE:
-               bfa_sm_set_state(ms, bfa_fcs_port_ms_sm_offline);
-               bfa_fcxp_walloc_cancel(BFA_FCS_GET_HAL_FROM_PORT(ms->port),
-                                      &ms->fcxp_wqe);
-               break;
-
-       default:
-               bfa_sm_fault(ms->port->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_port_ms_sm_plogi(struct bfa_fcs_port_ms_s *ms, enum port_ms_event event)
-{
-       bfa_trc(ms->port->fcs, ms->port->port_cfg.pwwn);
-       bfa_trc(ms->port->fcs, event);
-
-       switch (event) {
-       case MSSM_EVENT_RSP_ERROR:
-               /*
-                * Start timer for a delayed retry
-                */
-               bfa_sm_set_state(ms, bfa_fcs_port_ms_sm_plogi_retry);
-               ms->port->stats.ms_retries++;
-               bfa_timer_start(BFA_FCS_GET_HAL_FROM_PORT(ms->port), &ms->timer,
-                               bfa_fcs_port_ms_timeout, ms,
-                               BFA_FCS_RETRY_TIMEOUT);
-               break;
-
-       case MSSM_EVENT_RSP_OK:
-               /*
-                * since plogi is done, now invoke MS related sub-modules
-                */
-               bfa_fcs_port_fdmi_online(ms);
-
-               /**
-                * if this is a Vport, go to online state.
-                */
-               if (ms->port->vport) {
-                       bfa_sm_set_state(ms, bfa_fcs_port_ms_sm_online);
-                       break;
-               }
-
-               /*
-                * For a base port we need to get the
-                * switch's IP address.
-                */
-               bfa_sm_set_state(ms, bfa_fcs_port_ms_sm_gmal_sending);
-               bfa_fcs_port_ms_send_gmal(ms, NULL);
-               break;
-
-       case MSSM_EVENT_PORT_OFFLINE:
-               bfa_sm_set_state(ms, bfa_fcs_port_ms_sm_offline);
-               bfa_fcxp_discard(ms->fcxp);
-               break;
-
-       default:
-               bfa_sm_fault(ms->port->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_port_ms_sm_plogi_retry(struct bfa_fcs_port_ms_s *ms,
-                              enum port_ms_event event)
-{
-       bfa_trc(ms->port->fcs, ms->port->port_cfg.pwwn);
-       bfa_trc(ms->port->fcs, event);
-
-       switch (event) {
-       case MSSM_EVENT_TIMEOUT:
-               /*
-                * Retry Timer Expired. Re-send
-                */
-               bfa_sm_set_state(ms, bfa_fcs_port_ms_sm_plogi_sending);
-               bfa_fcs_port_ms_send_plogi(ms, NULL);
-               break;
-
-       case MSSM_EVENT_PORT_OFFLINE:
-               bfa_sm_set_state(ms, bfa_fcs_port_ms_sm_offline);
-               bfa_timer_stop(&ms->timer);
-               break;
-
-       default:
-               bfa_sm_fault(ms->port->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_port_ms_sm_online(struct bfa_fcs_port_ms_s *ms,
-                         enum port_ms_event event)
-{
-       bfa_trc(ms->port->fcs, ms->port->port_cfg.pwwn);
-       bfa_trc(ms->port->fcs, event);
-
-       switch (event) {
-       case MSSM_EVENT_PORT_OFFLINE:
-               bfa_sm_set_state(ms, bfa_fcs_port_ms_sm_offline);
-               break;
-
-       case MSSM_EVENT_PORT_FABRIC_RSCN:
-               bfa_sm_set_state(ms, bfa_fcs_port_ms_sm_gfn_sending);
-               ms->retry_cnt = 0;
-               bfa_fcs_port_ms_send_gfn(ms, NULL);
-               break;
-
-       default:
-               bfa_sm_fault(ms->port->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_port_ms_sm_gmal_sending(struct bfa_fcs_port_ms_s *ms,
-                               enum port_ms_event event)
-{
-       bfa_trc(ms->port->fcs, ms->port->port_cfg.pwwn);
-       bfa_trc(ms->port->fcs, event);
-
-       switch (event) {
-       case MSSM_EVENT_FCXP_SENT:
-               bfa_sm_set_state(ms, bfa_fcs_port_ms_sm_gmal);
-               break;
-
-       case MSSM_EVENT_PORT_OFFLINE:
-               bfa_sm_set_state(ms, bfa_fcs_port_ms_sm_offline);
-               bfa_fcxp_walloc_cancel(BFA_FCS_GET_HAL_FROM_PORT(ms->port),
-                                      &ms->fcxp_wqe);
-               break;
-
-       default:
-               bfa_sm_fault(ms->port->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_port_ms_sm_gmal(struct bfa_fcs_port_ms_s *ms, enum port_ms_event event)
-{
-       bfa_trc(ms->port->fcs, ms->port->port_cfg.pwwn);
-       bfa_trc(ms->port->fcs, event);
-
-       switch (event) {
-       case MSSM_EVENT_RSP_ERROR:
-               /*
-                * Start timer for a delayed retry
-                */
-               if (ms->retry_cnt++ < BFA_FCS_MS_CMD_MAX_RETRIES) {
-                       bfa_sm_set_state(ms, bfa_fcs_port_ms_sm_gmal_retry);
-                       ms->port->stats.ms_retries++;
-                       bfa_timer_start(BFA_FCS_GET_HAL_FROM_PORT(ms->port),
-                                       &ms->timer, bfa_fcs_port_ms_timeout, ms,
-                                       BFA_FCS_RETRY_TIMEOUT);
-               } else {
-                       bfa_sm_set_state(ms, bfa_fcs_port_ms_sm_gfn_sending);
-                       bfa_fcs_port_ms_send_gfn(ms, NULL);
-                       ms->retry_cnt = 0;
-               }
-               break;
-
-       case MSSM_EVENT_RSP_OK:
-               bfa_sm_set_state(ms, bfa_fcs_port_ms_sm_gfn_sending);
-               bfa_fcs_port_ms_send_gfn(ms, NULL);
-               break;
-
-       case MSSM_EVENT_PORT_OFFLINE:
-               bfa_sm_set_state(ms, bfa_fcs_port_ms_sm_offline);
-               bfa_fcxp_discard(ms->fcxp);
-               break;
-
-       default:
-               bfa_sm_fault(ms->port->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_port_ms_sm_gmal_retry(struct bfa_fcs_port_ms_s *ms,
-                             enum port_ms_event event)
-{
-       bfa_trc(ms->port->fcs, ms->port->port_cfg.pwwn);
-       bfa_trc(ms->port->fcs, event);
-
-       switch (event) {
-       case MSSM_EVENT_TIMEOUT:
-               /*
-                * Retry Timer Expired. Re-send
-                */
-               bfa_sm_set_state(ms, bfa_fcs_port_ms_sm_gmal_sending);
-               bfa_fcs_port_ms_send_gmal(ms, NULL);
-               break;
-
-       case MSSM_EVENT_PORT_OFFLINE:
-               bfa_sm_set_state(ms, bfa_fcs_port_ms_sm_offline);
-               bfa_timer_stop(&ms->timer);
-               break;
-
-       default:
-               bfa_sm_fault(ms->port->fcs, event);
-       }
-}
-
-/**
- *  ms_pvt MS local functions
- */
-
-static void
-bfa_fcs_port_ms_send_gmal(void *ms_cbarg, struct bfa_fcxp_s *fcxp_alloced)
-{
-       struct bfa_fcs_port_ms_s *ms = ms_cbarg;
-       struct bfa_fcs_port_s *port = ms->port;
-       struct fchs_s          fchs;
-       int             len;
-       struct bfa_fcxp_s *fcxp;
-
-       bfa_trc(port->fcs, port->pid);
-
-       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
-       if (!fcxp) {
-               bfa_fcxp_alloc_wait(port->fcs->bfa, &ms->fcxp_wqe,
-                                   bfa_fcs_port_ms_send_gmal, ms);
-               return;
-       }
-       ms->fcxp = fcxp;
-
-       len = fc_gmal_req_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
-                               bfa_fcs_port_get_fcid(port),
-                               bfa_lps_get_peer_nwwn(port->fabric->lps));
-
-       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
-                     FC_CLASS_3, len, &fchs, bfa_fcs_port_ms_gmal_response,
-                     (void *)ms, FC_MAX_PDUSZ, FC_FCCT_TOV);
-
-       bfa_sm_send_event(ms, MSSM_EVENT_FCXP_SENT);
-}
-
-static void
-bfa_fcs_port_ms_gmal_response(void *fcsarg, struct bfa_fcxp_s *fcxp,
-                             void *cbarg, bfa_status_t req_status,
-                             u32 rsp_len, u32 resid_len,
-                             struct fchs_s *rsp_fchs)
-{
-       struct bfa_fcs_port_ms_s *ms = (struct bfa_fcs_port_ms_s *)cbarg;
-       struct bfa_fcs_port_s *port = ms->port;
-       struct ct_hdr_s       *cthdr = NULL;
-       struct fcgs_gmal_resp_s *gmal_resp;
-       struct fc_gmal_entry_s *gmal_entry;
-       u32        num_entries;
-       u8        *rsp_str;
-
-       bfa_trc(port->fcs, req_status);
-       bfa_trc(port->fcs, port->port_cfg.pwwn);
-
-       /*
-        * Sanity Checks
-        */
-       if (req_status != BFA_STATUS_OK) {
-               bfa_trc(port->fcs, req_status);
-               bfa_sm_send_event(ms, MSSM_EVENT_RSP_ERROR);
-               return;
-       }
-
-       cthdr = (struct ct_hdr_s *) BFA_FCXP_RSP_PLD(fcxp);
-       cthdr->cmd_rsp_code = bfa_os_ntohs(cthdr->cmd_rsp_code);
-
-       if (cthdr->cmd_rsp_code == CT_RSP_ACCEPT) {
-               gmal_resp = (struct fcgs_gmal_resp_s *)(cthdr + 1);
-               num_entries = bfa_os_ntohl(gmal_resp->ms_len);
-               if (num_entries == 0) {
-                       bfa_sm_send_event(ms, MSSM_EVENT_RSP_ERROR);
-                       return;
-               }
-               /*
-                * The response could contain multiple Entries.
-                * Entries for SNMP interface, etc.
-                * We look for the entry with a telnet prefix.
-                * First "http://" entry refers to IP addr
-                */
-
-               gmal_entry = (struct fc_gmal_entry_s *)gmal_resp->ms_ma;
-               while (num_entries > 0) {
-                       if (strncmp
-                           (gmal_entry->prefix, CT_GMAL_RESP_PREFIX_HTTP,
-                            sizeof(gmal_entry->prefix)) == 0) {
-
-                               /*
-                                * if the IP address is terminating with a '/',
-                                * remove it. *Byte 0 consists of the length
-                                * of the string.
-                                */
-                               rsp_str = &(gmal_entry->prefix[0]);
-                               if (rsp_str[gmal_entry->len - 1] == '/')
-                                       rsp_str[gmal_entry->len - 1] = 0;
-                               /*
-                                * copy IP Address to fabric
-                                */
-                               strncpy(bfa_fcs_port_get_fabric_ipaddr(port),
-                                       gmal_entry->ip_addr,
-                                       BFA_FCS_FABRIC_IPADDR_SZ);
-                               break;
-                       } else {
-                               --num_entries;
-                               ++gmal_entry;
-                       }
-               }
-
-               bfa_sm_send_event(ms, MSSM_EVENT_RSP_OK);
-               return;
-       }
-
-       bfa_trc(port->fcs, cthdr->reason_code);
-       bfa_trc(port->fcs, cthdr->exp_code);
-       bfa_sm_send_event(ms, MSSM_EVENT_RSP_ERROR);
-}
-
-static void
-bfa_fcs_port_ms_sm_gfn_sending(struct bfa_fcs_port_ms_s *ms,
-                              enum port_ms_event event)
-{
-       bfa_trc(ms->port->fcs, ms->port->port_cfg.pwwn);
-       bfa_trc(ms->port->fcs, event);
-
-       switch (event) {
-       case MSSM_EVENT_FCXP_SENT:
-               bfa_sm_set_state(ms, bfa_fcs_port_ms_sm_gfn);
-               break;
-
-       case MSSM_EVENT_PORT_OFFLINE:
-               bfa_sm_set_state(ms, bfa_fcs_port_ms_sm_offline);
-               bfa_fcxp_walloc_cancel(BFA_FCS_GET_HAL_FROM_PORT(ms->port),
-                                      &ms->fcxp_wqe);
-               break;
-
-       default:
-               bfa_sm_fault(ms->port->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_port_ms_sm_gfn(struct bfa_fcs_port_ms_s *ms, enum port_ms_event event)
-{
-       bfa_trc(ms->port->fcs, ms->port->port_cfg.pwwn);
-       bfa_trc(ms->port->fcs, event);
-
-       switch (event) {
-       case MSSM_EVENT_RSP_ERROR:
-               /*
-                * Start timer for a delayed retry
-                */
-               if (ms->retry_cnt++ < BFA_FCS_MS_CMD_MAX_RETRIES) {
-                       bfa_sm_set_state(ms, bfa_fcs_port_ms_sm_gfn_retry);
-                       ms->port->stats.ms_retries++;
-                       bfa_timer_start(BFA_FCS_GET_HAL_FROM_PORT(ms->port),
-                                       &ms->timer, bfa_fcs_port_ms_timeout, ms,
-                                       BFA_FCS_RETRY_TIMEOUT);
-               } else {
-                       bfa_sm_set_state(ms, bfa_fcs_port_ms_sm_online);
-                       ms->retry_cnt = 0;
-               }
-               break;
-
-       case MSSM_EVENT_RSP_OK:
-               bfa_sm_set_state(ms, bfa_fcs_port_ms_sm_online);
-               break;
-
-       case MSSM_EVENT_PORT_OFFLINE:
-               bfa_sm_set_state(ms, bfa_fcs_port_ms_sm_offline);
-               bfa_fcxp_discard(ms->fcxp);
-               break;
-
-       default:
-               bfa_sm_fault(ms->port->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_port_ms_sm_gfn_retry(struct bfa_fcs_port_ms_s *ms,
-                            enum port_ms_event event)
-{
-       bfa_trc(ms->port->fcs, ms->port->port_cfg.pwwn);
-       bfa_trc(ms->port->fcs, event);
-
-       switch (event) {
-       case MSSM_EVENT_TIMEOUT:
-               /*
-                * Retry Timer Expired. Re-send
-                */
-               bfa_sm_set_state(ms, bfa_fcs_port_ms_sm_gfn_sending);
-               bfa_fcs_port_ms_send_gfn(ms, NULL);
-               break;
-
-       case MSSM_EVENT_PORT_OFFLINE:
-               bfa_sm_set_state(ms, bfa_fcs_port_ms_sm_offline);
-               bfa_timer_stop(&ms->timer);
-               break;
-
-       default:
-               bfa_sm_fault(ms->port->fcs, event);
-       }
-}
-
-/**
- *  ms_pvt MS local functions
- */
-
-static void
-bfa_fcs_port_ms_send_gfn(void *ms_cbarg, struct bfa_fcxp_s *fcxp_alloced)
-{
-       struct bfa_fcs_port_ms_s *ms = ms_cbarg;
-       struct bfa_fcs_port_s *port = ms->port;
-       struct fchs_s          fchs;
-       int             len;
-       struct bfa_fcxp_s *fcxp;
-
-       bfa_trc(port->fcs, port->pid);
-
-       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
-       if (!fcxp) {
-               bfa_fcxp_alloc_wait(port->fcs->bfa, &ms->fcxp_wqe,
-                                   bfa_fcs_port_ms_send_gfn, ms);
-               return;
-       }
-       ms->fcxp = fcxp;
-
-       len = fc_gfn_req_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
-                              bfa_fcs_port_get_fcid(port),
-                              bfa_lps_get_peer_nwwn(port->fabric->lps));
-
-       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
-                     FC_CLASS_3, len, &fchs, bfa_fcs_port_ms_gfn_response,
-                     (void *)ms, FC_MAX_PDUSZ, FC_FCCT_TOV);
-
-       bfa_sm_send_event(ms, MSSM_EVENT_FCXP_SENT);
-}
-
-static void
-bfa_fcs_port_ms_gfn_response(void *fcsarg, struct bfa_fcxp_s *fcxp, void *cbarg,
-                            bfa_status_t req_status, u32 rsp_len,
-                              u32 resid_len, struct fchs_s *rsp_fchs)
-{
-       struct bfa_fcs_port_ms_s *ms = (struct bfa_fcs_port_ms_s *)cbarg;
-       struct bfa_fcs_port_s *port = ms->port;
-       struct ct_hdr_s       *cthdr = NULL;
-       wwn_t          *gfn_resp;
-
-       bfa_trc(port->fcs, req_status);
-       bfa_trc(port->fcs, port->port_cfg.pwwn);
-
-       /*
-        * Sanity Checks
-        */
-       if (req_status != BFA_STATUS_OK) {
-               bfa_trc(port->fcs, req_status);
-               bfa_sm_send_event(ms, MSSM_EVENT_RSP_ERROR);
-               return;
-       }
-
-       cthdr = (struct ct_hdr_s *) BFA_FCXP_RSP_PLD(fcxp);
-       cthdr->cmd_rsp_code = bfa_os_ntohs(cthdr->cmd_rsp_code);
-
-       if (cthdr->cmd_rsp_code == CT_RSP_ACCEPT) {
-               gfn_resp = (wwn_t *) (cthdr + 1);
-               /*
-                * check if it has actually changed
-                */
-               if ((memcmp
-                    ((void *)&bfa_fcs_port_get_fabric_name(port), gfn_resp,
-                     sizeof(wwn_t)) != 0))
-                       bfa_fcs_fabric_set_fabric_name(port->fabric, *gfn_resp);
-               bfa_sm_send_event(ms, MSSM_EVENT_RSP_OK);
-               return;
-       }
-
-       bfa_trc(port->fcs, cthdr->reason_code);
-       bfa_trc(port->fcs, cthdr->exp_code);
-       bfa_sm_send_event(ms, MSSM_EVENT_RSP_ERROR);
-}
-
-/**
- *  ms_pvt MS local functions
- */
-
-static void
-bfa_fcs_port_ms_send_plogi(void *ms_cbarg, struct bfa_fcxp_s *fcxp_alloced)
-{
-       struct bfa_fcs_port_ms_s *ms = ms_cbarg;
-       struct bfa_fcs_port_s *port = ms->port;
-       struct fchs_s          fchs;
-       int             len;
-       struct bfa_fcxp_s *fcxp;
-
-       bfa_trc(port->fcs, port->pid);
-
-       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
-       if (!fcxp) {
-               port->stats.ms_plogi_alloc_wait++;
-               bfa_fcxp_alloc_wait(port->fcs->bfa, &ms->fcxp_wqe,
-                                   bfa_fcs_port_ms_send_plogi, ms);
-               return;
-       }
-       ms->fcxp = fcxp;
-
-       len = fc_plogi_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
-                            bfa_os_hton3b(FC_MGMT_SERVER),
-                            bfa_fcs_port_get_fcid(port), 0,
-                            port->port_cfg.pwwn, port->port_cfg.nwwn,
-                            bfa_fcport_get_maxfrsize(port->fcs->bfa));
-
-       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
-                     FC_CLASS_3, len, &fchs, bfa_fcs_port_ms_plogi_response,
-                     (void *)ms, FC_MAX_PDUSZ, FC_ELS_TOV);
-
-       port->stats.ms_plogi_sent++;
-       bfa_sm_send_event(ms, MSSM_EVENT_FCXP_SENT);
-}
-
-static void
-bfa_fcs_port_ms_plogi_response(void *fcsarg, struct bfa_fcxp_s *fcxp,
-                              void *cbarg, bfa_status_t req_status,
-                              u32 rsp_len, u32 resid_len,
-                              struct fchs_s *rsp_fchs)
-{
-       struct bfa_fcs_port_ms_s *ms = (struct bfa_fcs_port_ms_s *)cbarg;
-
-       struct bfa_fcs_port_s *port = ms->port;
-       struct fc_els_cmd_s   *els_cmd;
-       struct fc_ls_rjt_s    *ls_rjt;
-
-       bfa_trc(port->fcs, req_status);
-       bfa_trc(port->fcs, port->port_cfg.pwwn);
-
-       /*
-        * Sanity Checks
-        */
-       if (req_status != BFA_STATUS_OK) {
-               port->stats.ms_plogi_rsp_err++;
-               bfa_trc(port->fcs, req_status);
-               bfa_sm_send_event(ms, MSSM_EVENT_RSP_ERROR);
-               return;
-       }
-
-       els_cmd = (struct fc_els_cmd_s *) BFA_FCXP_RSP_PLD(fcxp);
-
-       switch (els_cmd->els_code) {
-
-       case FC_ELS_ACC:
-               if (rsp_len < sizeof(struct fc_logi_s)) {
-                       bfa_trc(port->fcs, rsp_len);
-                       port->stats.ms_plogi_acc_err++;
-                       bfa_sm_send_event(ms, MSSM_EVENT_RSP_ERROR);
-                       break;
-               }
-               port->stats.ms_plogi_accepts++;
-               bfa_sm_send_event(ms, MSSM_EVENT_RSP_OK);
-               break;
-
-       case FC_ELS_LS_RJT:
-               ls_rjt = (struct fc_ls_rjt_s *) BFA_FCXP_RSP_PLD(fcxp);
-
-               bfa_trc(port->fcs, ls_rjt->reason_code);
-               bfa_trc(port->fcs, ls_rjt->reason_code_expl);
-
-               port->stats.ms_rejects++;
-               bfa_sm_send_event(ms, MSSM_EVENT_RSP_ERROR);
-               break;
-
-       default:
-               port->stats.ms_plogi_unknown_rsp++;
-               bfa_trc(port->fcs, els_cmd->els_code);
-               bfa_sm_send_event(ms, MSSM_EVENT_RSP_ERROR);
-       }
-}
-
-static void
-bfa_fcs_port_ms_timeout(void *arg)
-{
-       struct bfa_fcs_port_ms_s *ms = (struct bfa_fcs_port_ms_s *)arg;
-
-       ms->port->stats.ms_timeouts++;
-       bfa_sm_send_event(ms, MSSM_EVENT_TIMEOUT);
-}
-
-
-void
-bfa_fcs_port_ms_init(struct bfa_fcs_port_s *port)
-{
-       struct bfa_fcs_port_ms_s *ms = BFA_FCS_GET_MS_FROM_PORT(port);
-
-       ms->port = port;
-       bfa_sm_set_state(ms, bfa_fcs_port_ms_sm_offline);
-
-       /*
-        * Invoke init routines of sub modules.
-        */
-       bfa_fcs_port_fdmi_init(ms);
-}
-
-void
-bfa_fcs_port_ms_offline(struct bfa_fcs_port_s *port)
-{
-       struct bfa_fcs_port_ms_s *ms = BFA_FCS_GET_MS_FROM_PORT(port);
-
-       ms->port = port;
-       bfa_sm_send_event(ms, MSSM_EVENT_PORT_OFFLINE);
-       bfa_fcs_port_fdmi_offline(ms);
-}
-
-void
-bfa_fcs_port_ms_online(struct bfa_fcs_port_s *port)
-{
-       struct bfa_fcs_port_ms_s *ms = BFA_FCS_GET_MS_FROM_PORT(port);
-
-       ms->port = port;
-       bfa_sm_send_event(ms, MSSM_EVENT_PORT_ONLINE);
-}
-
-void
-bfa_fcs_port_ms_fabric_rscn(struct bfa_fcs_port_s *port)
-{
-       struct bfa_fcs_port_ms_s *ms = BFA_FCS_GET_MS_FROM_PORT(port);
-
-       /*
-        * @todo.  Handle this only when in Online state
-        */
-       if (bfa_sm_cmp_state(ms, bfa_fcs_port_ms_sm_online))
-               bfa_sm_send_event(ms, MSSM_EVENT_PORT_FABRIC_RSCN);
-}
diff --git a/drivers/scsi/bfa/n2n.c b/drivers/scsi/bfa/n2n.c
deleted file mode 100644 (file)
index 7354568..0000000
+++ /dev/null
@@ -1,105 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  n2n.c n2n implementation.
- */
-#include <bfa.h>
-#include <bfa_svc.h>
-#include "fcs_lport.h"
-#include "fcs_rport.h"
-#include "fcs_trcmod.h"
-#include "lport_priv.h"
-
-BFA_TRC_FILE(FCS, N2N);
-
-/**
- *   Called by fcs/port to initialize N2N topology.
- */
-void
-bfa_fcs_port_n2n_init(struct bfa_fcs_port_s *port)
-{
-}
-
-/**
- *   Called by fcs/port to notify transition to online state.
- */
-void
-bfa_fcs_port_n2n_online(struct bfa_fcs_port_s *port)
-{
-       struct bfa_fcs_port_n2n_s *n2n_port = &port->port_topo.pn2n;
-       struct bfa_port_cfg_s *pcfg = &port->port_cfg;
-       struct bfa_fcs_rport_s *rport;
-
-       bfa_trc(port->fcs, pcfg->pwwn);
-
-       /*
-        * If our PWWN is > than that of the r-port, we have to initiate PLOGI
-        * and assign an Address. if not, we need to wait for its PLOGI.
-        *
-        * If our PWWN is < than that of the remote port, it will send a PLOGI
-        * with the PIDs assigned. The rport state machine take care of this
-        * incoming PLOGI.
-        */
-       if (memcmp
-           ((void *)&pcfg->pwwn, (void *)&n2n_port->rem_port_wwn,
-            sizeof(wwn_t)) > 0) {
-               port->pid = N2N_LOCAL_PID;
-               /**
-                * First, check if we know the device by pwwn.
-                */
-               rport = bfa_fcs_port_get_rport_by_pwwn(port,
-                                                      n2n_port->rem_port_wwn);
-               if (rport) {
-                       bfa_trc(port->fcs, rport->pid);
-                       bfa_trc(port->fcs, rport->pwwn);
-                       rport->pid = N2N_REMOTE_PID;
-                       bfa_fcs_rport_online(rport);
-                       return;
-               }
-
-               /*
-                * In n2n there can be only one rport. Delete the old one whose
-                * pid should be zero, because it is offline.
-                */
-               if (port->num_rports > 0) {
-                       rport = bfa_fcs_port_get_rport_by_pid(port, 0);
-                       bfa_assert(rport != NULL);
-                       if (rport) {
-                               bfa_trc(port->fcs, rport->pwwn);
-                               bfa_fcs_rport_delete(rport);
-                       }
-               }
-               bfa_fcs_rport_create(port, N2N_REMOTE_PID);
-       }
-}
-
-/**
- *   Called by fcs/port to notify transition to offline state.
- */
-void
-bfa_fcs_port_n2n_offline(struct bfa_fcs_port_s *port)
-{
-       struct bfa_fcs_port_n2n_s *n2n_port = &port->port_topo.pn2n;
-
-       bfa_trc(port->fcs, port->pid);
-       port->pid = 0;
-       n2n_port->rem_port_wwn = 0;
-       n2n_port->reply_oxid = 0;
-}
-
-
diff --git a/drivers/scsi/bfa/ns.c b/drivers/scsi/bfa/ns.c
deleted file mode 100644 (file)
index ae0edcc..0000000
+++ /dev/null
@@ -1,1242 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- * @page ns_sm_info VPORT NS State Machine
- *
- * @section ns_sm_interactions VPORT NS State Machine Interactions
- *
- * @section ns_sm VPORT NS State Machine
- *     img ns_sm.jpg
- */
-#include <bfa.h>
-#include <bfa_svc.h>
-#include <bfa_iocfc.h>
-#include "fcs_lport.h"
-#include "fcs_rport.h"
-#include "fcs_trcmod.h"
-#include "fcs_fcxp.h"
-#include "fcs.h"
-#include "lport_priv.h"
-
-BFA_TRC_FILE(FCS, NS);
-
-/*
- * forward declarations
- */
-static void     bfa_fcs_port_ns_send_plogi(void *ns_cbarg,
-                                          struct bfa_fcxp_s *fcxp_alloced);
-static void     bfa_fcs_port_ns_send_rspn_id(void *ns_cbarg,
-                                            struct bfa_fcxp_s *fcxp_alloced);
-static void     bfa_fcs_port_ns_send_rft_id(void *ns_cbarg,
-                                           struct bfa_fcxp_s *fcxp_alloced);
-static void     bfa_fcs_port_ns_send_rff_id(void *ns_cbarg,
-                                           struct bfa_fcxp_s *fcxp_alloced);
-static void     bfa_fcs_port_ns_send_gid_ft(void *ns_cbarg,
-                                           struct bfa_fcxp_s *fcxp_alloced);
-static void     bfa_fcs_port_ns_timeout(void *arg);
-static void     bfa_fcs_port_ns_plogi_response(void *fcsarg,
-                                              struct bfa_fcxp_s *fcxp,
-                                              void *cbarg,
-                                              bfa_status_t req_status,
-                                              u32 rsp_len,
-                                              u32 resid_len,
-                                              struct fchs_s *rsp_fchs);
-static void     bfa_fcs_port_ns_rspn_id_response(void *fcsarg,
-                                                struct bfa_fcxp_s *fcxp,
-                                                void *cbarg,
-                                                bfa_status_t req_status,
-                                                u32 rsp_len,
-                                                u32 resid_len,
-                                                struct fchs_s *rsp_fchs);
-static void     bfa_fcs_port_ns_rft_id_response(void *fcsarg,
-                                               struct bfa_fcxp_s *fcxp,
-                                               void *cbarg,
-                                               bfa_status_t req_status,
-                                               u32 rsp_len,
-                                               u32 resid_len,
-                                               struct fchs_s *rsp_fchs);
-static void     bfa_fcs_port_ns_rff_id_response(void *fcsarg,
-                                               struct bfa_fcxp_s *fcxp,
-                                               void *cbarg,
-                                               bfa_status_t req_status,
-                                               u32 rsp_len,
-                                               u32 resid_len,
-                                               struct fchs_s *rsp_fchs);
-static void     bfa_fcs_port_ns_gid_ft_response(void *fcsarg,
-                                               struct bfa_fcxp_s *fcxp,
-                                               void *cbarg,
-                                               bfa_status_t req_status,
-                                               u32 rsp_len,
-                                               u32 resid_len,
-                                               struct fchs_s *rsp_fchs);
-static void     bfa_fcs_port_ns_process_gidft_pids(struct bfa_fcs_port_s *port,
-                                                  u32 *pid_buf,
-                                                  u32 n_pids);
-
-static void     bfa_fcs_port_ns_boot_target_disc(struct bfa_fcs_port_s *port);
-/**
- *  fcs_ns_sm FCS nameserver interface state machine
- */
-
-/**
- * VPort NS State Machine events
- */
-enum vport_ns_event {
-       NSSM_EVENT_PORT_ONLINE = 1,
-       NSSM_EVENT_PORT_OFFLINE = 2,
-       NSSM_EVENT_PLOGI_SENT = 3,
-       NSSM_EVENT_RSP_OK = 4,
-       NSSM_EVENT_RSP_ERROR = 5,
-       NSSM_EVENT_TIMEOUT = 6,
-       NSSM_EVENT_NS_QUERY = 7,
-       NSSM_EVENT_RSPNID_SENT = 8,
-       NSSM_EVENT_RFTID_SENT = 9,
-       NSSM_EVENT_RFFID_SENT = 10,
-       NSSM_EVENT_GIDFT_SENT = 11,
-};
-
-static void     bfa_fcs_port_ns_sm_offline(struct bfa_fcs_port_ns_s *ns,
-                                          enum vport_ns_event event);
-static void     bfa_fcs_port_ns_sm_plogi_sending(struct bfa_fcs_port_ns_s *ns,
-                                                enum vport_ns_event event);
-static void     bfa_fcs_port_ns_sm_plogi(struct bfa_fcs_port_ns_s *ns,
-                                        enum vport_ns_event event);
-static void     bfa_fcs_port_ns_sm_plogi_retry(struct bfa_fcs_port_ns_s *ns,
-                                              enum vport_ns_event event);
-static void     bfa_fcs_port_ns_sm_sending_rspn_id(struct bfa_fcs_port_ns_s *ns,
-                                                  enum vport_ns_event event);
-static void     bfa_fcs_port_ns_sm_rspn_id(struct bfa_fcs_port_ns_s *ns,
-                                          enum vport_ns_event event);
-static void     bfa_fcs_port_ns_sm_rspn_id_retry(struct bfa_fcs_port_ns_s *ns,
-                                                enum vport_ns_event event);
-static void     bfa_fcs_port_ns_sm_sending_rft_id(struct bfa_fcs_port_ns_s *ns,
-                                                 enum vport_ns_event event);
-static void     bfa_fcs_port_ns_sm_rft_id_retry(struct bfa_fcs_port_ns_s *ns,
-                                               enum vport_ns_event event);
-static void     bfa_fcs_port_ns_sm_rft_id(struct bfa_fcs_port_ns_s *ns,
-                                         enum vport_ns_event event);
-static void     bfa_fcs_port_ns_sm_sending_rff_id(struct bfa_fcs_port_ns_s *ns,
-                                                 enum vport_ns_event event);
-static void     bfa_fcs_port_ns_sm_rff_id_retry(struct bfa_fcs_port_ns_s *ns,
-                                               enum vport_ns_event event);
-static void     bfa_fcs_port_ns_sm_rff_id(struct bfa_fcs_port_ns_s *ns,
-                                         enum vport_ns_event event);
-static void     bfa_fcs_port_ns_sm_sending_gid_ft(struct bfa_fcs_port_ns_s *ns,
-                                                 enum vport_ns_event event);
-static void     bfa_fcs_port_ns_sm_gid_ft(struct bfa_fcs_port_ns_s *ns,
-                                         enum vport_ns_event event);
-static void     bfa_fcs_port_ns_sm_gid_ft_retry(struct bfa_fcs_port_ns_s *ns,
-                                               enum vport_ns_event event);
-static void     bfa_fcs_port_ns_sm_online(struct bfa_fcs_port_ns_s *ns,
-                                         enum vport_ns_event event);
-/**
- *             Start in offline state - awaiting linkup
- */
-static void
-bfa_fcs_port_ns_sm_offline(struct bfa_fcs_port_ns_s *ns,
-                          enum vport_ns_event event)
-{
-       bfa_trc(ns->port->fcs, ns->port->port_cfg.pwwn);
-       bfa_trc(ns->port->fcs, event);
-
-       switch (event) {
-       case NSSM_EVENT_PORT_ONLINE:
-               bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_plogi_sending);
-               bfa_fcs_port_ns_send_plogi(ns, NULL);
-               break;
-
-       case NSSM_EVENT_PORT_OFFLINE:
-               break;
-
-       default:
-               bfa_sm_fault(ns->port->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_port_ns_sm_plogi_sending(struct bfa_fcs_port_ns_s *ns,
-                                enum vport_ns_event event)
-{
-       bfa_trc(ns->port->fcs, ns->port->port_cfg.pwwn);
-       bfa_trc(ns->port->fcs, event);
-
-       switch (event) {
-       case NSSM_EVENT_PLOGI_SENT:
-               bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_plogi);
-               break;
-
-       case NSSM_EVENT_PORT_OFFLINE:
-               bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_offline);
-               bfa_fcxp_walloc_cancel(BFA_FCS_GET_HAL_FROM_PORT(ns->port),
-                                      &ns->fcxp_wqe);
-               break;
-
-       default:
-               bfa_sm_fault(ns->port->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_port_ns_sm_plogi(struct bfa_fcs_port_ns_s *ns,
-                        enum vport_ns_event event)
-{
-       bfa_trc(ns->port->fcs, ns->port->port_cfg.pwwn);
-       bfa_trc(ns->port->fcs, event);
-
-       switch (event) {
-       case NSSM_EVENT_RSP_ERROR:
-               /*
-                * Start timer for a delayed retry
-                */
-               bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_plogi_retry);
-               ns->port->stats.ns_retries++;
-               bfa_timer_start(BFA_FCS_GET_HAL_FROM_PORT(ns->port), &ns->timer,
-                               bfa_fcs_port_ns_timeout, ns,
-                               BFA_FCS_RETRY_TIMEOUT);
-               break;
-
-       case NSSM_EVENT_RSP_OK:
-               bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_sending_rspn_id);
-               bfa_fcs_port_ns_send_rspn_id(ns, NULL);
-               break;
-
-       case NSSM_EVENT_PORT_OFFLINE:
-               bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_offline);
-               bfa_fcxp_discard(ns->fcxp);
-               break;
-
-       default:
-               bfa_sm_fault(ns->port->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_port_ns_sm_plogi_retry(struct bfa_fcs_port_ns_s *ns,
-                              enum vport_ns_event event)
-{
-       bfa_trc(ns->port->fcs, ns->port->port_cfg.pwwn);
-       bfa_trc(ns->port->fcs, event);
-
-       switch (event) {
-       case NSSM_EVENT_TIMEOUT:
-               /*
-                * Retry Timer Expired. Re-send
-                */
-               bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_plogi_sending);
-               bfa_fcs_port_ns_send_plogi(ns, NULL);
-               break;
-
-       case NSSM_EVENT_PORT_OFFLINE:
-               bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_offline);
-               bfa_timer_stop(&ns->timer);
-               break;
-
-       default:
-               bfa_sm_fault(ns->port->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_port_ns_sm_sending_rspn_id(struct bfa_fcs_port_ns_s *ns,
-                                  enum vport_ns_event event)
-{
-       bfa_trc(ns->port->fcs, ns->port->port_cfg.pwwn);
-       bfa_trc(ns->port->fcs, event);
-
-       switch (event) {
-       case NSSM_EVENT_RSPNID_SENT:
-               bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_rspn_id);
-               break;
-
-       case NSSM_EVENT_PORT_OFFLINE:
-               bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_offline);
-               bfa_fcxp_walloc_cancel(BFA_FCS_GET_HAL_FROM_PORT(ns->port),
-                                      &ns->fcxp_wqe);
-               break;
-
-       default:
-               bfa_sm_fault(ns->port->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_port_ns_sm_rspn_id(struct bfa_fcs_port_ns_s *ns,
-                          enum vport_ns_event event)
-{
-       bfa_trc(ns->port->fcs, ns->port->port_cfg.pwwn);
-       bfa_trc(ns->port->fcs, event);
-
-       switch (event) {
-       case NSSM_EVENT_RSP_ERROR:
-               /*
-                * Start timer for a delayed retry
-                */
-               bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_rspn_id_retry);
-               ns->port->stats.ns_retries++;
-               bfa_timer_start(BFA_FCS_GET_HAL_FROM_PORT(ns->port), &ns->timer,
-                               bfa_fcs_port_ns_timeout, ns,
-                               BFA_FCS_RETRY_TIMEOUT);
-               break;
-
-       case NSSM_EVENT_RSP_OK:
-               bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_sending_rft_id);
-               bfa_fcs_port_ns_send_rft_id(ns, NULL);
-               break;
-
-       case NSSM_EVENT_PORT_OFFLINE:
-               bfa_fcxp_discard(ns->fcxp);
-               bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_offline);
-               break;
-
-       default:
-               bfa_sm_fault(ns->port->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_port_ns_sm_rspn_id_retry(struct bfa_fcs_port_ns_s *ns,
-                                enum vport_ns_event event)
-{
-       bfa_trc(ns->port->fcs, ns->port->port_cfg.pwwn);
-       bfa_trc(ns->port->fcs, event);
-
-       switch (event) {
-       case NSSM_EVENT_TIMEOUT:
-               /*
-                * Retry Timer Expired. Re-send
-                */
-               bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_sending_rspn_id);
-               bfa_fcs_port_ns_send_rspn_id(ns, NULL);
-               break;
-
-       case NSSM_EVENT_PORT_OFFLINE:
-               bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_offline);
-               bfa_timer_stop(&ns->timer);
-               break;
-
-       default:
-               bfa_sm_fault(ns->port->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_port_ns_sm_sending_rft_id(struct bfa_fcs_port_ns_s *ns,
-                                 enum vport_ns_event event)
-{
-       bfa_trc(ns->port->fcs, ns->port->port_cfg.pwwn);
-       bfa_trc(ns->port->fcs, event);
-
-       switch (event) {
-       case NSSM_EVENT_RFTID_SENT:
-               bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_rft_id);
-               break;
-
-       case NSSM_EVENT_PORT_OFFLINE:
-               bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_offline);
-               bfa_fcxp_walloc_cancel(BFA_FCS_GET_HAL_FROM_PORT(ns->port),
-                                      &ns->fcxp_wqe);
-               break;
-
-       default:
-               bfa_sm_fault(ns->port->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_port_ns_sm_rft_id(struct bfa_fcs_port_ns_s *ns,
-                         enum vport_ns_event event)
-{
-       bfa_trc(ns->port->fcs, ns->port->port_cfg.pwwn);
-       bfa_trc(ns->port->fcs, event);
-
-       switch (event) {
-       case NSSM_EVENT_RSP_OK:
-               /*
-                * Now move to register FC4 Features
-                */
-               bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_sending_rff_id);
-               bfa_fcs_port_ns_send_rff_id(ns, NULL);
-               break;
-
-       case NSSM_EVENT_RSP_ERROR:
-               /*
-                * Start timer for a delayed retry
-                */
-               bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_rft_id_retry);
-               ns->port->stats.ns_retries++;
-               bfa_timer_start(BFA_FCS_GET_HAL_FROM_PORT(ns->port), &ns->timer,
-                               bfa_fcs_port_ns_timeout, ns,
-                               BFA_FCS_RETRY_TIMEOUT);
-               break;
-
-       case NSSM_EVENT_PORT_OFFLINE:
-               bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_offline);
-               bfa_fcxp_discard(ns->fcxp);
-               break;
-
-       default:
-               bfa_sm_fault(ns->port->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_port_ns_sm_rft_id_retry(struct bfa_fcs_port_ns_s *ns,
-                               enum vport_ns_event event)
-{
-       bfa_trc(ns->port->fcs, ns->port->port_cfg.pwwn);
-       bfa_trc(ns->port->fcs, event);
-
-       switch (event) {
-       case NSSM_EVENT_TIMEOUT:
-               bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_sending_rft_id);
-               bfa_fcs_port_ns_send_rft_id(ns, NULL);
-               break;
-
-       case NSSM_EVENT_PORT_OFFLINE:
-               bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_offline);
-               bfa_timer_stop(&ns->timer);
-               break;
-
-       default:
-               bfa_sm_fault(ns->port->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_port_ns_sm_sending_rff_id(struct bfa_fcs_port_ns_s *ns,
-                                 enum vport_ns_event event)
-{
-       bfa_trc(ns->port->fcs, ns->port->port_cfg.pwwn);
-       bfa_trc(ns->port->fcs, event);
-
-       switch (event) {
-       case NSSM_EVENT_RFFID_SENT:
-               bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_rff_id);
-               break;
-
-       case NSSM_EVENT_PORT_OFFLINE:
-               bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_offline);
-               bfa_fcxp_walloc_cancel(BFA_FCS_GET_HAL_FROM_PORT(ns->port),
-                                      &ns->fcxp_wqe);
-               break;
-
-       default:
-               bfa_sm_fault(ns->port->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_port_ns_sm_rff_id(struct bfa_fcs_port_ns_s *ns,
-                         enum vport_ns_event event)
-{
-       bfa_trc(ns->port->fcs, ns->port->port_cfg.pwwn);
-       bfa_trc(ns->port->fcs, event);
-
-       switch (event) {
-       case NSSM_EVENT_RSP_OK:
-
-               /*
-                * If min cfg mode is enabled, we donot initiate rport
-                * discovery with the fabric. Instead, we will retrieve the
-                * boot targets from HAL/FW.
-                */
-               if (__fcs_min_cfg(ns->port->fcs)) {
-                       bfa_fcs_port_ns_boot_target_disc(ns->port);
-                       bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_online);
-                       return;
-               }
-
-               /*
-                * If the port role is Initiator Mode issue NS query.
-                * If it is Target Mode, skip this and go to online.
-                */
-               if (BFA_FCS_VPORT_IS_INITIATOR_MODE(ns->port)) {
-                       bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_sending_gid_ft);
-                       bfa_fcs_port_ns_send_gid_ft(ns, NULL);
-               } else if (BFA_FCS_VPORT_IS_TARGET_MODE(ns->port)) {
-                       bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_online);
-               }
-               /*
-                * kick off mgmt srvr state machine
-                */
-               bfa_fcs_port_ms_online(ns->port);
-               break;
-
-       case NSSM_EVENT_RSP_ERROR:
-               /*
-                * Start timer for a delayed retry
-                */
-               bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_rff_id_retry);
-               ns->port->stats.ns_retries++;
-               bfa_timer_start(BFA_FCS_GET_HAL_FROM_PORT(ns->port), &ns->timer,
-                               bfa_fcs_port_ns_timeout, ns,
-                               BFA_FCS_RETRY_TIMEOUT);
-               break;
-
-       case NSSM_EVENT_PORT_OFFLINE:
-               bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_offline);
-               bfa_fcxp_discard(ns->fcxp);
-               break;
-
-       default:
-               bfa_sm_fault(ns->port->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_port_ns_sm_rff_id_retry(struct bfa_fcs_port_ns_s *ns,
-                               enum vport_ns_event event)
-{
-       bfa_trc(ns->port->fcs, ns->port->port_cfg.pwwn);
-       bfa_trc(ns->port->fcs, event);
-
-       switch (event) {
-       case NSSM_EVENT_TIMEOUT:
-               bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_sending_rff_id);
-               bfa_fcs_port_ns_send_rff_id(ns, NULL);
-               break;
-
-       case NSSM_EVENT_PORT_OFFLINE:
-               bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_offline);
-               bfa_timer_stop(&ns->timer);
-               break;
-
-       default:
-               bfa_sm_fault(ns->port->fcs, event);
-       }
-}
-static void
-bfa_fcs_port_ns_sm_sending_gid_ft(struct bfa_fcs_port_ns_s *ns,
-                                 enum vport_ns_event event)
-{
-       bfa_trc(ns->port->fcs, ns->port->port_cfg.pwwn);
-       bfa_trc(ns->port->fcs, event);
-
-       switch (event) {
-       case NSSM_EVENT_GIDFT_SENT:
-               bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_gid_ft);
-               break;
-
-       case NSSM_EVENT_PORT_OFFLINE:
-               bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_offline);
-               bfa_fcxp_walloc_cancel(BFA_FCS_GET_HAL_FROM_PORT(ns->port),
-                                      &ns->fcxp_wqe);
-               break;
-
-       default:
-               bfa_sm_fault(ns->port->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_port_ns_sm_gid_ft(struct bfa_fcs_port_ns_s *ns,
-                         enum vport_ns_event event)
-{
-       bfa_trc(ns->port->fcs, ns->port->port_cfg.pwwn);
-       bfa_trc(ns->port->fcs, event);
-
-       switch (event) {
-       case NSSM_EVENT_RSP_OK:
-               bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_online);
-               break;
-
-       case NSSM_EVENT_RSP_ERROR:
-               /*
-                * TBD: for certain reject codes, we don't need to retry
-                */
-               /*
-                * Start timer for a delayed retry
-                */
-               bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_gid_ft_retry);
-               ns->port->stats.ns_retries++;
-               bfa_timer_start(BFA_FCS_GET_HAL_FROM_PORT(ns->port), &ns->timer,
-                               bfa_fcs_port_ns_timeout, ns,
-                               BFA_FCS_RETRY_TIMEOUT);
-               break;
-
-       case NSSM_EVENT_PORT_OFFLINE:
-               bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_offline);
-               bfa_fcxp_discard(ns->fcxp);
-               break;
-
-       default:
-               bfa_sm_fault(ns->port->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_port_ns_sm_gid_ft_retry(struct bfa_fcs_port_ns_s *ns,
-                               enum vport_ns_event event)
-{
-       bfa_trc(ns->port->fcs, ns->port->port_cfg.pwwn);
-       bfa_trc(ns->port->fcs, event);
-
-       switch (event) {
-       case NSSM_EVENT_TIMEOUT:
-               bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_sending_gid_ft);
-               bfa_fcs_port_ns_send_gid_ft(ns, NULL);
-               break;
-
-       case NSSM_EVENT_PORT_OFFLINE:
-               bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_offline);
-               bfa_timer_stop(&ns->timer);
-               break;
-
-       default:
-               bfa_sm_fault(ns->port->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_port_ns_sm_online(struct bfa_fcs_port_ns_s *ns,
-                         enum vport_ns_event event)
-{
-       bfa_trc(ns->port->fcs, ns->port->port_cfg.pwwn);
-       bfa_trc(ns->port->fcs, event);
-
-       switch (event) {
-       case NSSM_EVENT_PORT_OFFLINE:
-               bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_offline);
-               break;
-
-       case NSSM_EVENT_NS_QUERY:
-               /*
-                * If the port role is Initiator Mode issue NS query.
-                * If it is Target Mode, skip this and go to online.
-                */
-               if (BFA_FCS_VPORT_IS_INITIATOR_MODE(ns->port)) {
-                       bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_sending_gid_ft);
-                       bfa_fcs_port_ns_send_gid_ft(ns, NULL);
-               };
-               break;
-
-       default:
-               bfa_sm_fault(ns->port->fcs, event);
-       }
-}
-
-
-
-/**
- *  ns_pvt Nameserver local functions
- */
-
-static void
-bfa_fcs_port_ns_send_plogi(void *ns_cbarg, struct bfa_fcxp_s *fcxp_alloced)
-{
-       struct bfa_fcs_port_ns_s *ns = ns_cbarg;
-       struct bfa_fcs_port_s *port = ns->port;
-       struct fchs_s          fchs;
-       int             len;
-       struct bfa_fcxp_s *fcxp;
-
-       bfa_trc(port->fcs, port->pid);
-
-       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
-       if (!fcxp) {
-               port->stats.ns_plogi_alloc_wait++;
-               bfa_fcxp_alloc_wait(port->fcs->bfa, &ns->fcxp_wqe,
-                                   bfa_fcs_port_ns_send_plogi, ns);
-               return;
-       }
-       ns->fcxp = fcxp;
-
-       len = fc_plogi_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
-                            bfa_os_hton3b(FC_NAME_SERVER),
-                            bfa_fcs_port_get_fcid(port), 0,
-                            port->port_cfg.pwwn, port->port_cfg.nwwn,
-                            bfa_fcport_get_maxfrsize(port->fcs->bfa));
-
-       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
-                     FC_CLASS_3, len, &fchs, bfa_fcs_port_ns_plogi_response,
-                     (void *)ns, FC_MAX_PDUSZ, FC_ELS_TOV);
-       port->stats.ns_plogi_sent++;
-
-       bfa_sm_send_event(ns, NSSM_EVENT_PLOGI_SENT);
-}
-
-static void
-bfa_fcs_port_ns_plogi_response(void *fcsarg, struct bfa_fcxp_s *fcxp,
-                              void *cbarg, bfa_status_t req_status,
-                              u32 rsp_len, u32 resid_len,
-                              struct fchs_s *rsp_fchs)
-{
-       struct bfa_fcs_port_ns_s *ns = (struct bfa_fcs_port_ns_s *)cbarg;
-       struct bfa_fcs_port_s *port = ns->port;
-       /* struct fc_logi_s *plogi_resp; */
-       struct fc_els_cmd_s   *els_cmd;
-       struct fc_ls_rjt_s    *ls_rjt;
-
-       bfa_trc(port->fcs, req_status);
-       bfa_trc(port->fcs, port->port_cfg.pwwn);
-
-       /*
-        * Sanity Checks
-        */
-       if (req_status != BFA_STATUS_OK) {
-               bfa_trc(port->fcs, req_status);
-               port->stats.ns_plogi_rsp_err++;
-               bfa_sm_send_event(ns, NSSM_EVENT_RSP_ERROR);
-               return;
-       }
-
-       els_cmd = (struct fc_els_cmd_s *) BFA_FCXP_RSP_PLD(fcxp);
-
-       switch (els_cmd->els_code) {
-
-       case FC_ELS_ACC:
-               if (rsp_len < sizeof(struct fc_logi_s)) {
-                       bfa_trc(port->fcs, rsp_len);
-                       port->stats.ns_plogi_acc_err++;
-                       bfa_sm_send_event(ns, NSSM_EVENT_RSP_ERROR);
-                       break;
-               }
-               port->stats.ns_plogi_accepts++;
-               bfa_sm_send_event(ns, NSSM_EVENT_RSP_OK);
-               break;
-
-       case FC_ELS_LS_RJT:
-               ls_rjt = (struct fc_ls_rjt_s *) BFA_FCXP_RSP_PLD(fcxp);
-
-               bfa_trc(port->fcs, ls_rjt->reason_code);
-               bfa_trc(port->fcs, ls_rjt->reason_code_expl);
-
-               port->stats.ns_rejects++;
-
-               bfa_sm_send_event(ns, NSSM_EVENT_RSP_ERROR);
-               break;
-
-       default:
-               port->stats.ns_plogi_unknown_rsp++;
-               bfa_trc(port->fcs, els_cmd->els_code);
-               bfa_sm_send_event(ns, NSSM_EVENT_RSP_ERROR);
-       }
-}
-
-/**
- * Register the symbolic port name.
- */
-static void
-bfa_fcs_port_ns_send_rspn_id(void *ns_cbarg, struct bfa_fcxp_s *fcxp_alloced)
-{
-       struct bfa_fcs_port_ns_s *ns = ns_cbarg;
-       struct bfa_fcs_port_s *port = ns->port;
-       struct fchs_s          fchs;
-       int             len;
-       struct bfa_fcxp_s *fcxp;
-       u8         symbl[256];
-       u8        *psymbl = &symbl[0];
-
-       bfa_os_memset(symbl, 0, sizeof(symbl));
-
-       bfa_trc(port->fcs, port->port_cfg.pwwn);
-
-       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
-       if (!fcxp) {
-               port->stats.ns_rspnid_alloc_wait++;
-               bfa_fcxp_alloc_wait(port->fcs->bfa, &ns->fcxp_wqe,
-                                   bfa_fcs_port_ns_send_rspn_id, ns);
-               return;
-       }
-       ns->fcxp = fcxp;
-
-       /*
-        * for V-Port, form a Port Symbolic Name
-        */
-       if (port->vport) {
-               /**For Vports,
-                *  we append the vport's port symbolic name to that of the base port.
-                */
-
-               strncpy((char *)psymbl,
-                       (char *)
-                       &(bfa_fcs_port_get_psym_name
-                         (bfa_fcs_get_base_port(port->fcs))),
-                       strlen((char *)
-                              &bfa_fcs_port_get_psym_name(bfa_fcs_get_base_port
-                                                          (port->fcs))));
-
-               /*
-                * Ensure we have a null terminating string.
-                */
-               ((char *)
-                psymbl)[strlen((char *)
-                               &bfa_fcs_port_get_psym_name
-                               (bfa_fcs_get_base_port(port->fcs)))] = 0;
-
-               strncat((char *)psymbl,
-                       (char *)&(bfa_fcs_port_get_psym_name(port)),
-                       strlen((char *)&bfa_fcs_port_get_psym_name(port)));
-       } else {
-               psymbl = (u8 *) &(bfa_fcs_port_get_psym_name(port));
-       }
-
-       len = fc_rspnid_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
-                             bfa_fcs_port_get_fcid(port), 0, psymbl);
-
-       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
-                     FC_CLASS_3, len, &fchs, bfa_fcs_port_ns_rspn_id_response,
-                     (void *)ns, FC_MAX_PDUSZ, FC_FCCT_TOV);
-
-       port->stats.ns_rspnid_sent++;
-
-       bfa_sm_send_event(ns, NSSM_EVENT_RSPNID_SENT);
-}
-
-static void
-bfa_fcs_port_ns_rspn_id_response(void *fcsarg, struct bfa_fcxp_s *fcxp,
-                                void *cbarg, bfa_status_t req_status,
-                                u32 rsp_len, u32 resid_len,
-                                struct fchs_s *rsp_fchs)
-{
-       struct bfa_fcs_port_ns_s *ns = (struct bfa_fcs_port_ns_s *)cbarg;
-       struct bfa_fcs_port_s *port = ns->port;
-       struct ct_hdr_s       *cthdr = NULL;
-
-       bfa_trc(port->fcs, port->port_cfg.pwwn);
-
-       /*
-        * Sanity Checks
-        */
-       if (req_status != BFA_STATUS_OK) {
-               bfa_trc(port->fcs, req_status);
-               port->stats.ns_rspnid_rsp_err++;
-               bfa_sm_send_event(ns, NSSM_EVENT_RSP_ERROR);
-               return;
-       }
-
-       cthdr = (struct ct_hdr_s *) BFA_FCXP_RSP_PLD(fcxp);
-       cthdr->cmd_rsp_code = bfa_os_ntohs(cthdr->cmd_rsp_code);
-
-       if (cthdr->cmd_rsp_code == CT_RSP_ACCEPT) {
-               port->stats.ns_rspnid_accepts++;
-               bfa_sm_send_event(ns, NSSM_EVENT_RSP_OK);
-               return;
-       }
-
-       port->stats.ns_rspnid_rejects++;
-       bfa_trc(port->fcs, cthdr->reason_code);
-       bfa_trc(port->fcs, cthdr->exp_code);
-       bfa_sm_send_event(ns, NSSM_EVENT_RSP_ERROR);
-}
-
-/**
- * Register FC4-Types
- * TBD, Need to retrieve this from the OS driver, in case IPFC is enabled ?
- */
-static void
-bfa_fcs_port_ns_send_rft_id(void *ns_cbarg, struct bfa_fcxp_s *fcxp_alloced)
-{
-       struct bfa_fcs_port_ns_s *ns = ns_cbarg;
-       struct bfa_fcs_port_s *port = ns->port;
-       struct fchs_s          fchs;
-       int             len;
-       struct bfa_fcxp_s *fcxp;
-
-       bfa_trc(port->fcs, port->port_cfg.pwwn);
-
-       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
-       if (!fcxp) {
-               port->stats.ns_rftid_alloc_wait++;
-               bfa_fcxp_alloc_wait(port->fcs->bfa, &ns->fcxp_wqe,
-                                   bfa_fcs_port_ns_send_rft_id, ns);
-               return;
-       }
-       ns->fcxp = fcxp;
-
-       len = fc_rftid_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
-                            bfa_fcs_port_get_fcid(port), 0,
-                            port->port_cfg.roles);
-
-       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
-                     FC_CLASS_3, len, &fchs, bfa_fcs_port_ns_rft_id_response,
-                     (void *)ns, FC_MAX_PDUSZ, FC_FCCT_TOV);
-
-       port->stats.ns_rftid_sent++;
-       bfa_sm_send_event(ns, NSSM_EVENT_RFTID_SENT);
-}
-
-static void
-bfa_fcs_port_ns_rft_id_response(void *fcsarg, struct bfa_fcxp_s *fcxp,
-                               void *cbarg, bfa_status_t req_status,
-                               u32 rsp_len, u32 resid_len,
-                               struct fchs_s *rsp_fchs)
-{
-       struct bfa_fcs_port_ns_s *ns = (struct bfa_fcs_port_ns_s *)cbarg;
-       struct bfa_fcs_port_s *port = ns->port;
-       struct ct_hdr_s       *cthdr = NULL;
-
-       bfa_trc(port->fcs, port->port_cfg.pwwn);
-
-       /*
-        * Sanity Checks
-        */
-       if (req_status != BFA_STATUS_OK) {
-               bfa_trc(port->fcs, req_status);
-               port->stats.ns_rftid_rsp_err++;
-               bfa_sm_send_event(ns, NSSM_EVENT_RSP_ERROR);
-               return;
-       }
-
-       cthdr = (struct ct_hdr_s *) BFA_FCXP_RSP_PLD(fcxp);
-       cthdr->cmd_rsp_code = bfa_os_ntohs(cthdr->cmd_rsp_code);
-
-       if (cthdr->cmd_rsp_code == CT_RSP_ACCEPT) {
-               port->stats.ns_rftid_accepts++;
-               bfa_sm_send_event(ns, NSSM_EVENT_RSP_OK);
-               return;
-       }
-
-       port->stats.ns_rftid_rejects++;
-       bfa_trc(port->fcs, cthdr->reason_code);
-       bfa_trc(port->fcs, cthdr->exp_code);
-       bfa_sm_send_event(ns, NSSM_EVENT_RSP_ERROR);
-}
-
-/**
-* Register FC4-Features : Should be done after RFT_ID
- */
-static void
-bfa_fcs_port_ns_send_rff_id(void *ns_cbarg, struct bfa_fcxp_s *fcxp_alloced)
-{
-       struct bfa_fcs_port_ns_s *ns = ns_cbarg;
-       struct bfa_fcs_port_s *port = ns->port;
-       struct fchs_s          fchs;
-       int             len;
-       struct bfa_fcxp_s *fcxp;
-       u8         fc4_ftrs = 0;
-
-       bfa_trc(port->fcs, port->port_cfg.pwwn);
-
-       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
-       if (!fcxp) {
-               port->stats.ns_rffid_alloc_wait++;
-               bfa_fcxp_alloc_wait(port->fcs->bfa, &ns->fcxp_wqe,
-                                   bfa_fcs_port_ns_send_rff_id, ns);
-               return;
-       }
-       ns->fcxp = fcxp;
-
-       if (BFA_FCS_VPORT_IS_INITIATOR_MODE(ns->port))
-               fc4_ftrs = FC_GS_FCP_FC4_FEATURE_INITIATOR;
-       else if (BFA_FCS_VPORT_IS_TARGET_MODE(ns->port))
-               fc4_ftrs = FC_GS_FCP_FC4_FEATURE_TARGET;
-
-       len = fc_rffid_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
-                            bfa_fcs_port_get_fcid(port), 0, FC_TYPE_FCP,
-                            fc4_ftrs);
-
-       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
-                     FC_CLASS_3, len, &fchs, bfa_fcs_port_ns_rff_id_response,
-                     (void *)ns, FC_MAX_PDUSZ, FC_FCCT_TOV);
-
-       port->stats.ns_rffid_sent++;
-       bfa_sm_send_event(ns, NSSM_EVENT_RFFID_SENT);
-}
-
-static void
-bfa_fcs_port_ns_rff_id_response(void *fcsarg, struct bfa_fcxp_s *fcxp,
-                               void *cbarg, bfa_status_t req_status,
-                               u32 rsp_len, u32 resid_len,
-                               struct fchs_s *rsp_fchs)
-{
-       struct bfa_fcs_port_ns_s *ns = (struct bfa_fcs_port_ns_s *)cbarg;
-       struct bfa_fcs_port_s *port = ns->port;
-       struct ct_hdr_s       *cthdr = NULL;
-
-       bfa_trc(port->fcs, port->port_cfg.pwwn);
-
-       /*
-        * Sanity Checks
-        */
-       if (req_status != BFA_STATUS_OK) {
-               bfa_trc(port->fcs, req_status);
-               port->stats.ns_rffid_rsp_err++;
-               bfa_sm_send_event(ns, NSSM_EVENT_RSP_ERROR);
-               return;
-       }
-
-       cthdr = (struct ct_hdr_s *) BFA_FCXP_RSP_PLD(fcxp);
-       cthdr->cmd_rsp_code = bfa_os_ntohs(cthdr->cmd_rsp_code);
-
-       if (cthdr->cmd_rsp_code == CT_RSP_ACCEPT) {
-               port->stats.ns_rffid_accepts++;
-               bfa_sm_send_event(ns, NSSM_EVENT_RSP_OK);
-               return;
-       }
-
-       port->stats.ns_rffid_rejects++;
-       bfa_trc(port->fcs, cthdr->reason_code);
-       bfa_trc(port->fcs, cthdr->exp_code);
-
-       if (cthdr->reason_code == CT_RSN_NOT_SUPP) {
-               /*
-                * if this command is not supported, we don't retry
-                */
-               bfa_sm_send_event(ns, NSSM_EVENT_RSP_OK);
-       } else {
-               bfa_sm_send_event(ns, NSSM_EVENT_RSP_ERROR);
-       }
-}
-
-/**
- * Query Fabric for FC4-Types Devices.
- *
-*  TBD : Need to use a local (FCS private) response buffer, since the response
- * can be larger than 2K.
- */
-static void
-bfa_fcs_port_ns_send_gid_ft(void *ns_cbarg, struct bfa_fcxp_s *fcxp_alloced)
-{
-       struct bfa_fcs_port_ns_s *ns = ns_cbarg;
-       struct bfa_fcs_port_s *port = ns->port;
-       struct fchs_s          fchs;
-       int             len;
-       struct bfa_fcxp_s *fcxp;
-
-       bfa_trc(port->fcs, port->pid);
-
-       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
-       if (!fcxp) {
-               port->stats.ns_gidft_alloc_wait++;
-               bfa_fcxp_alloc_wait(port->fcs->bfa, &ns->fcxp_wqe,
-                                   bfa_fcs_port_ns_send_gid_ft, ns);
-               return;
-       }
-       ns->fcxp = fcxp;
-
-       /*
-        * This query is only initiated for FCP initiator mode.
-        */
-       len = fc_gid_ft_build(&fchs, bfa_fcxp_get_reqbuf(fcxp), ns->port->pid,
-                             FC_TYPE_FCP);
-
-       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
-                     FC_CLASS_3, len, &fchs, bfa_fcs_port_ns_gid_ft_response,
-                     (void *)ns, bfa_fcxp_get_maxrsp(port->fcs->bfa),
-                     FC_FCCT_TOV);
-
-       port->stats.ns_gidft_sent++;
-
-       bfa_sm_send_event(ns, NSSM_EVENT_GIDFT_SENT);
-}
-
-static void
-bfa_fcs_port_ns_gid_ft_response(void *fcsarg, struct bfa_fcxp_s *fcxp,
-                               void *cbarg, bfa_status_t req_status,
-                               u32 rsp_len, u32 resid_len,
-                               struct fchs_s *rsp_fchs)
-{
-       struct bfa_fcs_port_ns_s *ns = (struct bfa_fcs_port_ns_s *)cbarg;
-       struct bfa_fcs_port_s *port = ns->port;
-       struct ct_hdr_s       *cthdr = NULL;
-       u32        n_pids;
-
-       bfa_trc(port->fcs, port->port_cfg.pwwn);
-
-       /*
-        * Sanity Checks
-        */
-       if (req_status != BFA_STATUS_OK) {
-               bfa_trc(port->fcs, req_status);
-               port->stats.ns_gidft_rsp_err++;
-               bfa_sm_send_event(ns, NSSM_EVENT_RSP_ERROR);
-               return;
-       }
-
-       if (resid_len != 0) {
-               /*
-                * TBD : we will need to allocate a larger buffer & retry the
-                * command
-                */
-               bfa_trc(port->fcs, rsp_len);
-               bfa_trc(port->fcs, resid_len);
-               return;
-       }
-
-       cthdr = (struct ct_hdr_s *) BFA_FCXP_RSP_PLD(fcxp);
-       cthdr->cmd_rsp_code = bfa_os_ntohs(cthdr->cmd_rsp_code);
-
-       switch (cthdr->cmd_rsp_code) {
-
-       case CT_RSP_ACCEPT:
-
-               port->stats.ns_gidft_accepts++;
-               n_pids = (fc_get_ctresp_pyld_len(rsp_len) / sizeof(u32));
-               bfa_trc(port->fcs, n_pids);
-               bfa_fcs_port_ns_process_gidft_pids(port,
-                                                  (u32 *) (cthdr + 1),
-                                                  n_pids);
-               bfa_sm_send_event(ns, NSSM_EVENT_RSP_OK);
-               break;
-
-       case CT_RSP_REJECT:
-
-               /*
-                * Check the reason code  & explanation.
-                * There may not have been any FC4 devices in the fabric
-                */
-               port->stats.ns_gidft_rejects++;
-               bfa_trc(port->fcs, cthdr->reason_code);
-               bfa_trc(port->fcs, cthdr->exp_code);
-
-               if ((cthdr->reason_code == CT_RSN_UNABLE_TO_PERF)
-                   && (cthdr->exp_code == CT_NS_EXP_FT_NOT_REG)) {
-
-                       bfa_sm_send_event(ns, NSSM_EVENT_RSP_OK);
-               } else {
-                       /*
-                        * for all other errors, retry
-                        */
-                       bfa_sm_send_event(ns, NSSM_EVENT_RSP_ERROR);
-               }
-               break;
-
-       default:
-               port->stats.ns_gidft_unknown_rsp++;
-               bfa_trc(port->fcs, cthdr->cmd_rsp_code);
-               bfa_sm_send_event(ns, NSSM_EVENT_RSP_ERROR);
-       }
-}
-
-/**
- *     This routine will be called by bfa_timer on timer timeouts.
- *
- *     param[in]       port    - pointer to bfa_fcs_port_t.
- *
- *     return
- *             void
- *
-*      Special Considerations:
- *
- *     note
- */
-static void
-bfa_fcs_port_ns_timeout(void *arg)
-{
-       struct bfa_fcs_port_ns_s *ns = (struct bfa_fcs_port_ns_s *)arg;
-
-       ns->port->stats.ns_timeouts++;
-       bfa_sm_send_event(ns, NSSM_EVENT_TIMEOUT);
-}
-
-/*
- * Process the PID list in GID_FT response
- */
-static void
-bfa_fcs_port_ns_process_gidft_pids(struct bfa_fcs_port_s *port,
-                                  u32 *pid_buf, u32 n_pids)
-{
-       struct fcgs_gidft_resp_s *gidft_entry;
-       struct bfa_fcs_rport_s *rport;
-       u32        ii;
-
-       for (ii = 0; ii < n_pids; ii++) {
-               gidft_entry = (struct fcgs_gidft_resp_s *) &pid_buf[ii];
-
-               if (gidft_entry->pid == port->pid)
-                       continue;
-
-               /*
-                * Check if this rport already exists
-                */
-               rport = bfa_fcs_port_get_rport_by_pid(port, gidft_entry->pid);
-               if (rport == NULL) {
-                       /*
-                        * this is a new device. create rport
-                        */
-                       rport = bfa_fcs_rport_create(port, gidft_entry->pid);
-               } else {
-                       /*
-                        * this rport already exists
-                        */
-                       bfa_fcs_rport_scn(rport);
-               }
-
-               bfa_trc(port->fcs, gidft_entry->pid);
-
-               /*
-                * if the last entry bit is set, bail out.
-                */
-               if (gidft_entry->last)
-                       return;
-       }
-}
-
-/**
- *  fcs_ns_public FCS nameserver public interfaces
- */
-
-/*
- * Functions called by port/fab.
- * These will send relevant Events to the ns state machine.
- */
-void
-bfa_fcs_port_ns_init(struct bfa_fcs_port_s *port)
-{
-       struct bfa_fcs_port_ns_s *ns = BFA_FCS_GET_NS_FROM_PORT(port);
-
-       ns->port = port;
-       bfa_sm_set_state(ns, bfa_fcs_port_ns_sm_offline);
-}
-
-void
-bfa_fcs_port_ns_offline(struct bfa_fcs_port_s *port)
-{
-       struct bfa_fcs_port_ns_s *ns = BFA_FCS_GET_NS_FROM_PORT(port);
-
-       ns->port = port;
-       bfa_sm_send_event(ns, NSSM_EVENT_PORT_OFFLINE);
-}
-
-void
-bfa_fcs_port_ns_online(struct bfa_fcs_port_s *port)
-{
-       struct bfa_fcs_port_ns_s *ns = BFA_FCS_GET_NS_FROM_PORT(port);
-
-       ns->port = port;
-       bfa_sm_send_event(ns, NSSM_EVENT_PORT_ONLINE);
-}
-
-void
-bfa_fcs_port_ns_query(struct bfa_fcs_port_s *port)
-{
-       struct bfa_fcs_port_ns_s *ns = BFA_FCS_GET_NS_FROM_PORT(port);
-
-       bfa_trc(port->fcs, port->pid);
-       bfa_sm_send_event(ns, NSSM_EVENT_NS_QUERY);
-}
-
-static void
-bfa_fcs_port_ns_boot_target_disc(struct bfa_fcs_port_s *port)
-{
-
-       struct bfa_fcs_rport_s *rport;
-       u8         nwwns;
-       wwn_t  wwns[BFA_PREBOOT_BOOTLUN_MAX];
-       int             ii;
-
-       bfa_iocfc_get_bootwwns(port->fcs->bfa, &nwwns, wwns);
-
-       for (ii = 0; ii < nwwns; ++ii) {
-               rport = bfa_fcs_rport_create_by_wwn(port, wwns[ii]);
-               bfa_assert(rport);
-       }
-}
-
-
diff --git a/drivers/scsi/bfa/plog.c b/drivers/scsi/bfa/plog.c
deleted file mode 100644 (file)
index fcb8864..0000000
+++ /dev/null
@@ -1,184 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#include <bfa_os_inc.h>
-#include <cs/bfa_plog.h>
-#include <cs/bfa_debug.h>
-
-static int
-plkd_validate_logrec(struct bfa_plog_rec_s *pl_rec)
-{
-       if ((pl_rec->log_type != BFA_PL_LOG_TYPE_INT)
-           && (pl_rec->log_type != BFA_PL_LOG_TYPE_STRING))
-               return 1;
-
-       if ((pl_rec->log_type != BFA_PL_LOG_TYPE_INT)
-           && (pl_rec->log_num_ints > BFA_PL_INT_LOG_SZ))
-               return 1;
-
-       return 0;
-}
-
-static void
-bfa_plog_add(struct bfa_plog_s *plog, struct bfa_plog_rec_s *pl_rec)
-{
-       u16        tail;
-       struct bfa_plog_rec_s *pl_recp;
-
-       if (plog->plog_enabled == 0)
-               return;
-
-       if (plkd_validate_logrec(pl_rec)) {
-               bfa_assert(0);
-               return;
-       }
-
-       tail = plog->tail;
-
-       pl_recp = &(plog->plog_recs[tail]);
-
-       bfa_os_memcpy(pl_recp, pl_rec, sizeof(struct bfa_plog_rec_s));
-
-       pl_recp->tv = BFA_TRC_TS(plog);
-       BFA_PL_LOG_REC_INCR(plog->tail);
-
-       if (plog->head == plog->tail)
-               BFA_PL_LOG_REC_INCR(plog->head);
-}
-
-void
-bfa_plog_init(struct bfa_plog_s *plog)
-{
-       bfa_os_memset((char *)plog, 0, sizeof(struct bfa_plog_s));
-
-       bfa_os_memcpy(plog->plog_sig, BFA_PL_SIG_STR, BFA_PL_SIG_LEN);
-       plog->head = plog->tail = 0;
-       plog->plog_enabled = 1;
-}
-
-void
-bfa_plog_str(struct bfa_plog_s *plog, enum bfa_plog_mid mid,
-               enum bfa_plog_eid event,
-               u16 misc, char *log_str)
-{
-       struct bfa_plog_rec_s  lp;
-
-       if (plog->plog_enabled) {
-               bfa_os_memset(&lp, 0, sizeof(struct bfa_plog_rec_s));
-               lp.mid = mid;
-               lp.eid = event;
-               lp.log_type = BFA_PL_LOG_TYPE_STRING;
-               lp.misc = misc;
-               strncpy(lp.log_entry.string_log, log_str,
-                       BFA_PL_STRING_LOG_SZ - 1);
-               lp.log_entry.string_log[BFA_PL_STRING_LOG_SZ - 1] = '\0';
-               bfa_plog_add(plog, &lp);
-       }
-}
-
-void
-bfa_plog_intarr(struct bfa_plog_s *plog, enum bfa_plog_mid mid,
-               enum bfa_plog_eid event,
-               u16 misc, u32 *intarr, u32 num_ints)
-{
-       struct bfa_plog_rec_s  lp;
-       u32        i;
-
-       if (num_ints > BFA_PL_INT_LOG_SZ)
-               num_ints = BFA_PL_INT_LOG_SZ;
-
-       if (plog->plog_enabled) {
-               bfa_os_memset(&lp, 0, sizeof(struct bfa_plog_rec_s));
-               lp.mid = mid;
-               lp.eid = event;
-               lp.log_type = BFA_PL_LOG_TYPE_INT;
-               lp.misc = misc;
-
-               for (i = 0; i < num_ints; i++)
-                       bfa_os_assign(lp.log_entry.int_log[i],
-                                       intarr[i]);
-
-               lp.log_num_ints = (u8) num_ints;
-
-               bfa_plog_add(plog, &lp);
-       }
-}
-
-void
-bfa_plog_fchdr(struct bfa_plog_s *plog, enum bfa_plog_mid mid,
-                       enum bfa_plog_eid event,
-                       u16 misc, struct fchs_s *fchdr)
-{
-       struct bfa_plog_rec_s  lp;
-       u32       *tmp_int = (u32 *) fchdr;
-       u32        ints[BFA_PL_INT_LOG_SZ];
-
-       if (plog->plog_enabled) {
-               bfa_os_memset(&lp, 0, sizeof(struct bfa_plog_rec_s));
-
-               ints[0] = tmp_int[0];
-               ints[1] = tmp_int[1];
-               ints[2] = tmp_int[4];
-
-               bfa_plog_intarr(plog, mid, event, misc, ints, 3);
-       }
-}
-
-void
-bfa_plog_fchdr_and_pl(struct bfa_plog_s *plog, enum bfa_plog_mid mid,
-                     enum bfa_plog_eid event, u16 misc, struct fchs_s *fchdr,
-                     u32 pld_w0)
-{
-       struct bfa_plog_rec_s  lp;
-       u32       *tmp_int = (u32 *) fchdr;
-       u32        ints[BFA_PL_INT_LOG_SZ];
-
-       if (plog->plog_enabled) {
-               bfa_os_memset(&lp, 0, sizeof(struct bfa_plog_rec_s));
-
-               ints[0] = tmp_int[0];
-               ints[1] = tmp_int[1];
-               ints[2] = tmp_int[4];
-               ints[3] = pld_w0;
-
-               bfa_plog_intarr(plog, mid, event, misc, ints, 4);
-       }
-}
-
-void
-bfa_plog_clear(struct bfa_plog_s *plog)
-{
-       plog->head = plog->tail = 0;
-}
-
-void
-bfa_plog_enable(struct bfa_plog_s *plog)
-{
-       plog->plog_enabled = 1;
-}
-
-void
-bfa_plog_disable(struct bfa_plog_s *plog)
-{
-       plog->plog_enabled = 0;
-}
-
-bfa_boolean_t
-bfa_plog_get_setting(struct bfa_plog_s *plog)
-{
-       return (bfa_boolean_t)plog->plog_enabled;
-}
diff --git a/drivers/scsi/bfa/rport.c b/drivers/scsi/bfa/rport.c
deleted file mode 100644 (file)
index 9b4c2c9..0000000
+++ /dev/null
@@ -1,2676 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  rport.c Remote port implementation.
- */
-
-#include <linux/slab.h>
-#include <bfa.h>
-#include <bfa_svc.h>
-#include "fcbuild.h"
-#include "fcs_vport.h"
-#include "fcs_lport.h"
-#include "fcs_rport.h"
-#include "fcs_fcpim.h"
-#include "fcs_fcptm.h"
-#include "fcs_trcmod.h"
-#include "fcs_fcxp.h"
-#include "fcs.h"
-#include <fcb/bfa_fcb_rport.h>
-#include <aen/bfa_aen_rport.h>
-
-BFA_TRC_FILE(FCS, RPORT);
-
-/* In millisecs */
-static u32 bfa_fcs_rport_del_timeout =
-                       BFA_FCS_RPORT_DEF_DEL_TIMEOUT * 1000;
-
-/*
- * forward declarations
- */
-static struct bfa_fcs_rport_s *bfa_fcs_rport_alloc(struct bfa_fcs_port_s *port,
-                                                  wwn_t pwwn, u32 rpid);
-static void     bfa_fcs_rport_free(struct bfa_fcs_rport_s *rport);
-static void     bfa_fcs_rport_hal_online(struct bfa_fcs_rport_s *rport);
-static void     bfa_fcs_rport_online_action(struct bfa_fcs_rport_s *rport);
-static void     bfa_fcs_rport_offline_action(struct bfa_fcs_rport_s *rport);
-static void     bfa_fcs_rport_update(struct bfa_fcs_rport_s *rport,
-                                    struct fc_logi_s *plogi);
-static void     bfa_fcs_rport_fc4_pause(struct bfa_fcs_rport_s *rport);
-static void     bfa_fcs_rport_fc4_resume(struct bfa_fcs_rport_s *rport);
-static void     bfa_fcs_rport_timeout(void *arg);
-static void     bfa_fcs_rport_send_plogi(void *rport_cbarg,
-                                        struct bfa_fcxp_s *fcxp_alloced);
-static void     bfa_fcs_rport_send_plogiacc(void *rport_cbarg,
-                                           struct bfa_fcxp_s *fcxp_alloced);
-static void     bfa_fcs_rport_plogi_response(void *fcsarg,
-                                            struct bfa_fcxp_s *fcxp,
-                                            void *cbarg,
-                                            bfa_status_t req_status,
-                                            u32 rsp_len,
-                                            u32 resid_len,
-                                            struct fchs_s *rsp_fchs);
-static void     bfa_fcs_rport_send_adisc(void *rport_cbarg,
-                                        struct bfa_fcxp_s *fcxp_alloced);
-static void     bfa_fcs_rport_adisc_response(void *fcsarg,
-                                            struct bfa_fcxp_s *fcxp,
-                                            void *cbarg,
-                                            bfa_status_t req_status,
-                                            u32 rsp_len,
-                                            u32 resid_len,
-                                            struct fchs_s *rsp_fchs);
-static void     bfa_fcs_rport_send_gidpn(void *rport_cbarg,
-                                        struct bfa_fcxp_s *fcxp_alloced);
-static void     bfa_fcs_rport_gidpn_response(void *fcsarg,
-                                            struct bfa_fcxp_s *fcxp,
-                                            void *cbarg,
-                                            bfa_status_t req_status,
-                                            u32 rsp_len,
-                                            u32 resid_len,
-                                            struct fchs_s *rsp_fchs);
-static void     bfa_fcs_rport_send_logo(void *rport_cbarg,
-                                       struct bfa_fcxp_s *fcxp_alloced);
-static void     bfa_fcs_rport_send_logo_acc(void *rport_cbarg);
-static void     bfa_fcs_rport_process_prli(struct bfa_fcs_rport_s *rport,
-                       struct fchs_s *rx_fchs, u16 len);
-static void     bfa_fcs_rport_send_ls_rjt(struct bfa_fcs_rport_s *rport,
-                       struct fchs_s *rx_fchs, u8 reason_code,
-                       u8 reason_code_expl);
-static void     bfa_fcs_rport_process_adisc(struct bfa_fcs_rport_s *rport,
-                       struct fchs_s *rx_fchs, u16 len);
-static void    bfa_fcs_rport_send_prlo_acc(struct bfa_fcs_rport_s *rport);
-/**
- *  fcs_rport_sm FCS rport state machine events
- */
-
-enum rport_event {
-       RPSM_EVENT_PLOGI_SEND = 1,      /*  new rport; start with PLOGI */
-       RPSM_EVENT_PLOGI_RCVD = 2,      /*  Inbound PLOGI from remote port */
-       RPSM_EVENT_PLOGI_COMP = 3,      /*  PLOGI completed to rport */
-       RPSM_EVENT_LOGO_RCVD = 4,       /*  LOGO from remote device */
-       RPSM_EVENT_LOGO_IMP = 5,        /*  implicit logo for SLER */
-       RPSM_EVENT_FCXP_SENT = 6,       /*  Frame from has been sent */
-       RPSM_EVENT_DELETE = 7,  /*  RPORT delete request */
-       RPSM_EVENT_SCN = 8,     /*  state change notification */
-       RPSM_EVENT_ACCEPTED = 9,/*  Good response from remote device */
-       RPSM_EVENT_FAILED = 10, /*  Request to rport failed.  */
-       RPSM_EVENT_TIMEOUT = 11,        /*  Rport SM timeout event */
-       RPSM_EVENT_HCB_ONLINE = 12,     /*  BFA rport online callback */
-       RPSM_EVENT_HCB_OFFLINE = 13,    /*  BFA rport offline callback */
-       RPSM_EVENT_FC4_OFFLINE = 14,    /*  FC-4 offline complete */
-       RPSM_EVENT_ADDRESS_CHANGE = 15, /*  Rport's PID has changed */
-       RPSM_EVENT_ADDRESS_DISC = 16,   /*  Need to Discover rport's PID */
-       RPSM_EVENT_PRLO_RCVD = 17,      /*  PRLO from remote device      */
-};
-
-static void     bfa_fcs_rport_sm_uninit(struct bfa_fcs_rport_s *rport,
-                                       enum rport_event event);
-static void     bfa_fcs_rport_sm_plogi_sending(struct bfa_fcs_rport_s *rport,
-                                              enum rport_event event);
-static void     bfa_fcs_rport_sm_plogiacc_sending(struct bfa_fcs_rport_s *rport,
-                                                 enum rport_event event);
-static void     bfa_fcs_rport_sm_plogi_retry(struct bfa_fcs_rport_s *rport,
-                                            enum rport_event event);
-static void     bfa_fcs_rport_sm_plogi(struct bfa_fcs_rport_s *rport,
-                                      enum rport_event event);
-static void     bfa_fcs_rport_sm_hal_online(struct bfa_fcs_rport_s *rport,
-                                           enum rport_event event);
-static void     bfa_fcs_rport_sm_online(struct bfa_fcs_rport_s *rport,
-                                       enum rport_event event);
-static void     bfa_fcs_rport_sm_nsquery_sending(struct bfa_fcs_rport_s *rport,
-                                                enum rport_event event);
-static void     bfa_fcs_rport_sm_nsquery(struct bfa_fcs_rport_s *rport,
-                                        enum rport_event event);
-static void     bfa_fcs_rport_sm_adisc_sending(struct bfa_fcs_rport_s *rport,
-                                              enum rport_event event);
-static void     bfa_fcs_rport_sm_adisc(struct bfa_fcs_rport_s *rport,
-                                      enum rport_event event);
-static void     bfa_fcs_rport_sm_fc4_logorcv(struct bfa_fcs_rport_s *rport,
-                                            enum rport_event event);
-static void     bfa_fcs_rport_sm_fc4_logosend(struct bfa_fcs_rport_s *rport,
-                                             enum rport_event event);
-static void     bfa_fcs_rport_sm_fc4_offline(struct bfa_fcs_rport_s *rport,
-                                            enum rport_event event);
-static void     bfa_fcs_rport_sm_hcb_offline(struct bfa_fcs_rport_s *rport,
-                                            enum rport_event event);
-static void     bfa_fcs_rport_sm_hcb_logorcv(struct bfa_fcs_rport_s *rport,
-                                            enum rport_event event);
-static void     bfa_fcs_rport_sm_hcb_logosend(struct bfa_fcs_rport_s *rport,
-                                             enum rport_event event);
-static void     bfa_fcs_rport_sm_logo_sending(struct bfa_fcs_rport_s *rport,
-                                             enum rport_event event);
-static void     bfa_fcs_rport_sm_offline(struct bfa_fcs_rport_s *rport,
-                                        enum rport_event event);
-static void     bfa_fcs_rport_sm_nsdisc_sending(struct bfa_fcs_rport_s *rport,
-                                               enum rport_event event);
-static void     bfa_fcs_rport_sm_nsdisc_retry(struct bfa_fcs_rport_s *rport,
-                                             enum rport_event event);
-static void     bfa_fcs_rport_sm_nsdisc_sent(struct bfa_fcs_rport_s *rport,
-                                            enum rport_event event);
-static void     bfa_fcs_rport_sm_nsdisc_sent(struct bfa_fcs_rport_s *rport,
-                                            enum rport_event event);
-
-static struct bfa_sm_table_s rport_sm_table[] = {
-       {BFA_SM(bfa_fcs_rport_sm_uninit), BFA_RPORT_UNINIT},
-       {BFA_SM(bfa_fcs_rport_sm_plogi_sending), BFA_RPORT_PLOGI},
-       {BFA_SM(bfa_fcs_rport_sm_plogiacc_sending), BFA_RPORT_ONLINE},
-       {BFA_SM(bfa_fcs_rport_sm_plogi_retry), BFA_RPORT_PLOGI_RETRY},
-       {BFA_SM(bfa_fcs_rport_sm_plogi), BFA_RPORT_PLOGI},
-       {BFA_SM(bfa_fcs_rport_sm_hal_online), BFA_RPORT_ONLINE},
-       {BFA_SM(bfa_fcs_rport_sm_online), BFA_RPORT_ONLINE},
-       {BFA_SM(bfa_fcs_rport_sm_nsquery_sending), BFA_RPORT_NSQUERY},
-       {BFA_SM(bfa_fcs_rport_sm_nsquery), BFA_RPORT_NSQUERY},
-       {BFA_SM(bfa_fcs_rport_sm_adisc_sending), BFA_RPORT_ADISC},
-       {BFA_SM(bfa_fcs_rport_sm_adisc), BFA_RPORT_ADISC},
-       {BFA_SM(bfa_fcs_rport_sm_fc4_logorcv), BFA_RPORT_LOGORCV},
-       {BFA_SM(bfa_fcs_rport_sm_fc4_logosend), BFA_RPORT_LOGO},
-       {BFA_SM(bfa_fcs_rport_sm_fc4_offline), BFA_RPORT_OFFLINE},
-       {BFA_SM(bfa_fcs_rport_sm_hcb_offline), BFA_RPORT_OFFLINE},
-       {BFA_SM(bfa_fcs_rport_sm_hcb_logorcv), BFA_RPORT_LOGORCV},
-       {BFA_SM(bfa_fcs_rport_sm_hcb_logosend), BFA_RPORT_LOGO},
-       {BFA_SM(bfa_fcs_rport_sm_logo_sending), BFA_RPORT_LOGO},
-       {BFA_SM(bfa_fcs_rport_sm_offline), BFA_RPORT_OFFLINE},
-       {BFA_SM(bfa_fcs_rport_sm_nsdisc_sending), BFA_RPORT_NSDISC},
-       {BFA_SM(bfa_fcs_rport_sm_nsdisc_retry), BFA_RPORT_NSDISC},
-       {BFA_SM(bfa_fcs_rport_sm_nsdisc_sent), BFA_RPORT_NSDISC},
-};
-
-/**
- *             Beginning state.
- */
-static void
-bfa_fcs_rport_sm_uninit(struct bfa_fcs_rport_s *rport, enum rport_event event)
-{
-       bfa_trc(rport->fcs, rport->pwwn);
-       bfa_trc(rport->fcs, rport->pid);
-       bfa_trc(rport->fcs, event);
-
-       switch (event) {
-       case RPSM_EVENT_PLOGI_SEND:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_plogi_sending);
-               rport->plogi_retries = 0;
-               bfa_fcs_rport_send_plogi(rport, NULL);
-               break;
-
-       case RPSM_EVENT_PLOGI_RCVD:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_plogiacc_sending);
-               bfa_fcs_rport_send_plogiacc(rport, NULL);
-               break;
-
-       case RPSM_EVENT_PLOGI_COMP:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_hal_online);
-               bfa_fcs_rport_hal_online(rport);
-               break;
-
-       case RPSM_EVENT_ADDRESS_CHANGE:
-       case RPSM_EVENT_ADDRESS_DISC:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_nsdisc_sending);
-               rport->ns_retries = 0;
-               bfa_fcs_rport_send_gidpn(rport, NULL);
-               break;
-
-       default:
-               bfa_sm_fault(rport->fcs, event);
-       }
-}
-
-/**
- *             PLOGI is being sent.
- */
-static void
-bfa_fcs_rport_sm_plogi_sending(struct bfa_fcs_rport_s *rport,
-                              enum rport_event event)
-{
-       bfa_trc(rport->fcs, rport->pwwn);
-       bfa_trc(rport->fcs, rport->pid);
-       bfa_trc(rport->fcs, event);
-
-       switch (event) {
-       case RPSM_EVENT_FCXP_SENT:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_plogi);
-               break;
-
-       case RPSM_EVENT_DELETE:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_uninit);
-               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
-               bfa_fcs_rport_free(rport);
-               break;
-
-       case RPSM_EVENT_PLOGI_RCVD:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_plogiacc_sending);
-               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
-               bfa_fcs_rport_send_plogiacc(rport, NULL);
-               break;
-
-       case RPSM_EVENT_ADDRESS_CHANGE:
-               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_nsdisc_sending);
-               rport->ns_retries = 0;
-               bfa_fcs_rport_send_gidpn(rport, NULL);
-               break;
-
-       case RPSM_EVENT_LOGO_IMP:
-               rport->pid = 0;
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_offline);
-               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
-               bfa_timer_start(rport->fcs->bfa, &rport->timer,
-                               bfa_fcs_rport_timeout, rport,
-                               bfa_fcs_rport_del_timeout);
-               break;
-
-       case RPSM_EVENT_SCN:
-               break;
-
-       default:
-               bfa_sm_fault(rport->fcs, event);
-       }
-}
-
-/**
- *             PLOGI is being sent.
- */
-static void
-bfa_fcs_rport_sm_plogiacc_sending(struct bfa_fcs_rport_s *rport,
-                                 enum rport_event event)
-{
-       bfa_trc(rport->fcs, rport->pwwn);
-       bfa_trc(rport->fcs, rport->pid);
-       bfa_trc(rport->fcs, event);
-
-       switch (event) {
-       case RPSM_EVENT_FCXP_SENT:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_hal_online);
-               bfa_fcs_rport_hal_online(rport);
-               break;
-
-       case RPSM_EVENT_DELETE:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_uninit);
-               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
-               bfa_fcs_rport_free(rport);
-               break;
-
-       case RPSM_EVENT_SCN:
-               /**
-                * Ignore, SCN is possibly online notification.
-                */
-               break;
-
-       case RPSM_EVENT_ADDRESS_CHANGE:
-               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_nsdisc_sending);
-               rport->ns_retries = 0;
-               bfa_fcs_rport_send_gidpn(rport, NULL);
-               break;
-
-       case RPSM_EVENT_LOGO_IMP:
-               rport->pid = 0;
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_offline);
-               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
-               bfa_timer_start(rport->fcs->bfa, &rport->timer,
-                               bfa_fcs_rport_timeout, rport,
-                               bfa_fcs_rport_del_timeout);
-               break;
-
-       case RPSM_EVENT_HCB_OFFLINE:
-               /**
-                * Ignore BFA callback, on a PLOGI receive we call bfa offline.
-                */
-               break;
-
-       default:
-               bfa_sm_fault(rport->fcs, event);
-       }
-}
-
-/**
- *             PLOGI is sent.
- */
-static void
-bfa_fcs_rport_sm_plogi_retry(struct bfa_fcs_rport_s *rport,
-                       enum rport_event event)
-{
-       bfa_trc(rport->fcs, rport->pwwn);
-       bfa_trc(rport->fcs, rport->pid);
-       bfa_trc(rport->fcs, event);
-
-       switch (event) {
-       case RPSM_EVENT_SCN:
-               bfa_timer_stop(&rport->timer);
-               /*
-                * !! fall through !!
-                */
-
-       case RPSM_EVENT_TIMEOUT:
-               if (rport->plogi_retries < BFA_FCS_RPORT_MAX_RETRIES) {
-                       rport->plogi_retries++;
-                       bfa_sm_set_state(rport, bfa_fcs_rport_sm_plogi_sending);
-                       bfa_fcs_rport_send_plogi(rport, NULL);
-               } else {
-                       rport->pid = 0;
-                       bfa_sm_set_state(rport, bfa_fcs_rport_sm_offline);
-                       bfa_timer_start(rport->fcs->bfa, &rport->timer,
-                                       bfa_fcs_rport_timeout, rport,
-                                       bfa_fcs_rport_del_timeout);
-               }
-               break;
-
-       case RPSM_EVENT_DELETE:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_uninit);
-               bfa_timer_stop(&rport->timer);
-               bfa_fcs_rport_free(rport);
-               break;
-
-       case RPSM_EVENT_PRLO_RCVD:
-       case RPSM_EVENT_LOGO_RCVD:
-               break;
-
-       case RPSM_EVENT_PLOGI_RCVD:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_plogiacc_sending);
-               bfa_timer_stop(&rport->timer);
-               bfa_fcs_rport_send_plogiacc(rport, NULL);
-               break;
-
-       case RPSM_EVENT_ADDRESS_CHANGE:
-               bfa_timer_stop(&rport->timer);
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_nsdisc_sending);
-               rport->ns_retries = 0;
-               bfa_fcs_rport_send_gidpn(rport, NULL);
-               break;
-
-       case RPSM_EVENT_LOGO_IMP:
-               rport->pid = 0;
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_offline);
-               bfa_timer_stop(&rport->timer);
-               bfa_timer_start(rport->fcs->bfa, &rport->timer,
-                               bfa_fcs_rport_timeout, rport,
-                               bfa_fcs_rport_del_timeout);
-               break;
-
-       case RPSM_EVENT_PLOGI_COMP:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_hal_online);
-               bfa_timer_stop(&rport->timer);
-               bfa_fcs_rport_hal_online(rport);
-               break;
-
-       default:
-               bfa_sm_fault(rport->fcs, event);
-       }
-}
-
-/**
- *             PLOGI is sent.
- */
-static void
-bfa_fcs_rport_sm_plogi(struct bfa_fcs_rport_s *rport, enum rport_event event)
-{
-       bfa_trc(rport->fcs, rport->pwwn);
-       bfa_trc(rport->fcs, rport->pid);
-       bfa_trc(rport->fcs, event);
-
-       switch (event) {
-       case RPSM_EVENT_ACCEPTED:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_hal_online);
-               rport->plogi_retries = 0;
-               bfa_fcs_rport_hal_online(rport);
-               break;
-
-       case RPSM_EVENT_LOGO_RCVD:
-               bfa_fcs_rport_send_logo_acc(rport);
-               /*
-                * !! fall through !!
-                */
-       case RPSM_EVENT_PRLO_RCVD:
-               if (rport->prlo == BFA_TRUE)
-                       bfa_fcs_rport_send_prlo_acc(rport);
-
-               bfa_fcxp_discard(rport->fcxp);
-               /*
-                * !! fall through !!
-                */
-       case RPSM_EVENT_FAILED:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_plogi_retry);
-               bfa_timer_start(rport->fcs->bfa, &rport->timer,
-                               bfa_fcs_rport_timeout, rport,
-                               BFA_FCS_RETRY_TIMEOUT);
-               break;
-
-       case RPSM_EVENT_LOGO_IMP:
-               rport->pid = 0;
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_offline);
-               bfa_fcxp_discard(rport->fcxp);
-               bfa_timer_start(rport->fcs->bfa, &rport->timer,
-                               bfa_fcs_rport_timeout, rport,
-                               bfa_fcs_rport_del_timeout);
-               break;
-
-       case RPSM_EVENT_ADDRESS_CHANGE:
-               bfa_fcxp_discard(rport->fcxp);
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_nsdisc_sending);
-               rport->ns_retries = 0;
-               bfa_fcs_rport_send_gidpn(rport, NULL);
-               break;
-
-       case RPSM_EVENT_PLOGI_RCVD:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_plogiacc_sending);
-               bfa_fcxp_discard(rport->fcxp);
-               bfa_fcs_rport_send_plogiacc(rport, NULL);
-               break;
-
-       case RPSM_EVENT_SCN:
-               /**
-                * Ignore SCN - wait for PLOGI response.
-                */
-               break;
-
-       case RPSM_EVENT_DELETE:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_uninit);
-               bfa_fcxp_discard(rport->fcxp);
-               bfa_fcs_rport_free(rport);
-               break;
-
-       case RPSM_EVENT_PLOGI_COMP:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_hal_online);
-               bfa_fcxp_discard(rport->fcxp);
-               bfa_fcs_rport_hal_online(rport);
-               break;
-
-       default:
-               bfa_sm_fault(rport->fcs, event);
-       }
-}
-
-/**
- *             PLOGI is complete. Awaiting BFA rport online callback. FC-4s
- *             are offline.
- */
-static void
-bfa_fcs_rport_sm_hal_online(struct bfa_fcs_rport_s *rport,
-                       enum rport_event event)
-{
-       bfa_trc(rport->fcs, rport->pwwn);
-       bfa_trc(rport->fcs, rport->pid);
-       bfa_trc(rport->fcs, event);
-
-       switch (event) {
-       case RPSM_EVENT_HCB_ONLINE:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_online);
-               bfa_fcs_rport_online_action(rport);
-               break;
-
-       case RPSM_EVENT_PRLO_RCVD:
-               break;
-
-       case RPSM_EVENT_LOGO_RCVD:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_hcb_logorcv);
-               bfa_rport_offline(rport->bfa_rport);
-               break;
-
-       case RPSM_EVENT_LOGO_IMP:
-       case RPSM_EVENT_ADDRESS_CHANGE:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_hcb_offline);
-               bfa_rport_offline(rport->bfa_rport);
-               break;
-
-       case RPSM_EVENT_PLOGI_RCVD:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_plogiacc_sending);
-               bfa_rport_offline(rport->bfa_rport);
-               bfa_fcs_rport_send_plogiacc(rport, NULL);
-               break;
-
-       case RPSM_EVENT_DELETE:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_hcb_logosend);
-               bfa_rport_offline(rport->bfa_rport);
-               break;
-
-       case RPSM_EVENT_SCN:
-               /**
-                * @todo
-                * Ignore SCN - PLOGI just completed, FC-4 login should detect
-                * device failures.
-                */
-               break;
-
-       default:
-               bfa_sm_fault(rport->fcs, event);
-       }
-}
-
-/**
- *             Rport is ONLINE. FC-4s active.
- */
-static void
-bfa_fcs_rport_sm_online(struct bfa_fcs_rport_s *rport, enum rport_event event)
-{
-       bfa_trc(rport->fcs, rport->pwwn);
-       bfa_trc(rport->fcs, rport->pid);
-       bfa_trc(rport->fcs, event);
-
-       switch (event) {
-       case RPSM_EVENT_SCN:
-               /**
-                * Pause FC-4 activity till rport is authenticated.
-                * In switched fabrics, check presence of device in nameserver
-                * first.
-                */
-               bfa_fcs_rport_fc4_pause(rport);
-
-               if (bfa_fcs_fabric_is_switched(rport->port->fabric)) {
-                       bfa_sm_set_state(rport,
-                                        bfa_fcs_rport_sm_nsquery_sending);
-                       rport->ns_retries = 0;
-                       bfa_fcs_rport_send_gidpn(rport, NULL);
-               } else {
-                       bfa_sm_set_state(rport, bfa_fcs_rport_sm_adisc_sending);
-                       bfa_fcs_rport_send_adisc(rport, NULL);
-               }
-               break;
-
-       case RPSM_EVENT_PLOGI_RCVD:
-       case RPSM_EVENT_LOGO_IMP:
-       case RPSM_EVENT_ADDRESS_CHANGE:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_offline);
-               bfa_fcs_rport_offline_action(rport);
-               break;
-
-       case RPSM_EVENT_DELETE:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_logosend);
-               bfa_fcs_rport_offline_action(rport);
-               break;
-
-       case RPSM_EVENT_LOGO_RCVD:
-       case RPSM_EVENT_PRLO_RCVD:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_logorcv);
-               bfa_fcs_rport_offline_action(rport);
-               break;
-
-       case RPSM_EVENT_PLOGI_COMP:
-               break;
-
-       default:
-               bfa_sm_fault(rport->fcs, event);
-       }
-}
-
-/**
- *             An SCN event is received in ONLINE state. NS query is being sent
- *             prior to ADISC authentication with rport. FC-4s are paused.
- */
-static void
-bfa_fcs_rport_sm_nsquery_sending(struct bfa_fcs_rport_s *rport,
-                                enum rport_event event)
-{
-       bfa_trc(rport->fcs, rport->pwwn);
-       bfa_trc(rport->fcs, rport->pid);
-       bfa_trc(rport->fcs, event);
-
-       switch (event) {
-       case RPSM_EVENT_FCXP_SENT:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_nsquery);
-               break;
-
-       case RPSM_EVENT_DELETE:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_logosend);
-               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
-               bfa_fcs_rport_offline_action(rport);
-               break;
-
-       case RPSM_EVENT_SCN:
-               /**
-                * ignore SCN, wait for response to query itself
-                */
-               break;
-
-       case RPSM_EVENT_LOGO_RCVD:
-       case RPSM_EVENT_PRLO_RCVD:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_logorcv);
-               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
-               bfa_fcs_rport_offline_action(rport);
-               break;
-
-       case RPSM_EVENT_LOGO_IMP:
-               rport->pid = 0;
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_offline);
-               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
-               bfa_timer_start(rport->fcs->bfa, &rport->timer,
-                               bfa_fcs_rport_timeout, rport,
-                               bfa_fcs_rport_del_timeout);
-               break;
-
-       case RPSM_EVENT_PLOGI_RCVD:
-       case RPSM_EVENT_ADDRESS_CHANGE:
-       case RPSM_EVENT_PLOGI_COMP:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_offline);
-               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
-               bfa_fcs_rport_offline_action(rport);
-               break;
-
-       default:
-               bfa_sm_fault(rport->fcs, event);
-       }
-}
-
-/**
- *     An SCN event is received in ONLINE state. NS query is sent to rport.
- *     FC-4s are paused.
- */
-static void
-bfa_fcs_rport_sm_nsquery(struct bfa_fcs_rport_s *rport, enum rport_event event)
-{
-       bfa_trc(rport->fcs, rport->pwwn);
-       bfa_trc(rport->fcs, rport->pid);
-       bfa_trc(rport->fcs, event);
-
-       switch (event) {
-       case RPSM_EVENT_ACCEPTED:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_adisc_sending);
-               bfa_fcs_rport_send_adisc(rport, NULL);
-               break;
-
-       case RPSM_EVENT_FAILED:
-               rport->ns_retries++;
-               if (rport->ns_retries < BFA_FCS_RPORT_MAX_RETRIES) {
-                       bfa_sm_set_state(rport,
-                                        bfa_fcs_rport_sm_nsquery_sending);
-                       bfa_fcs_rport_send_gidpn(rport, NULL);
-               } else {
-                       bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_offline);
-                       bfa_fcs_rport_offline_action(rport);
-               }
-               break;
-
-       case RPSM_EVENT_DELETE:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_logosend);
-               bfa_fcxp_discard(rport->fcxp);
-               bfa_fcs_rport_offline_action(rport);
-               break;
-
-       case RPSM_EVENT_SCN:
-               break;
-
-       case RPSM_EVENT_LOGO_RCVD:
-       case RPSM_EVENT_PRLO_RCVD:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_logorcv);
-               bfa_fcxp_discard(rport->fcxp);
-               bfa_fcs_rport_offline_action(rport);
-               break;
-
-       case RPSM_EVENT_PLOGI_COMP:
-       case RPSM_EVENT_ADDRESS_CHANGE:
-       case RPSM_EVENT_PLOGI_RCVD:
-       case RPSM_EVENT_LOGO_IMP:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_offline);
-               bfa_fcxp_discard(rport->fcxp);
-               bfa_fcs_rport_offline_action(rport);
-               break;
-
-       default:
-               bfa_sm_fault(rport->fcs, event);
-       }
-}
-
-/**
- *     An SCN event is received in ONLINE state. ADISC is being sent for
- *     authenticating with rport. FC-4s are paused.
- */
-static void
-bfa_fcs_rport_sm_adisc_sending(struct bfa_fcs_rport_s *rport,
-                              enum rport_event event)
-{
-       bfa_trc(rport->fcs, rport->pwwn);
-       bfa_trc(rport->fcs, rport->pid);
-       bfa_trc(rport->fcs, event);
-
-       switch (event) {
-       case RPSM_EVENT_FCXP_SENT:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_adisc);
-               break;
-
-       case RPSM_EVENT_DELETE:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_logosend);
-               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
-               bfa_fcs_rport_offline_action(rport);
-               break;
-
-       case RPSM_EVENT_LOGO_IMP:
-       case RPSM_EVENT_ADDRESS_CHANGE:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_offline);
-               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
-               bfa_fcs_rport_offline_action(rport);
-               break;
-
-       case RPSM_EVENT_LOGO_RCVD:
-       case RPSM_EVENT_PRLO_RCVD:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_logorcv);
-               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
-               bfa_fcs_rport_offline_action(rport);
-               break;
-
-       case RPSM_EVENT_SCN:
-               break;
-
-       case RPSM_EVENT_PLOGI_RCVD:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_offline);
-               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
-               bfa_fcs_rport_offline_action(rport);
-               break;
-
-       default:
-               bfa_sm_fault(rport->fcs, event);
-       }
-}
-
-/**
- *             An SCN event is received in ONLINE state. ADISC is to rport.
- *             FC-4s are paused.
- */
-static void
-bfa_fcs_rport_sm_adisc(struct bfa_fcs_rport_s *rport, enum rport_event event)
-{
-       bfa_trc(rport->fcs, rport->pwwn);
-       bfa_trc(rport->fcs, rport->pid);
-       bfa_trc(rport->fcs, event);
-
-       switch (event) {
-       case RPSM_EVENT_ACCEPTED:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_online);
-               bfa_fcs_rport_fc4_resume(rport);
-               break;
-
-       case RPSM_EVENT_PLOGI_RCVD:
-               /**
-                * Too complex to cleanup FC-4 & rport and then acc to PLOGI.
-                * At least go offline when a PLOGI is received.
-                */
-               bfa_fcxp_discard(rport->fcxp);
-               /*
-                * !!! fall through !!!
-                */
-
-       case RPSM_EVENT_FAILED:
-       case RPSM_EVENT_ADDRESS_CHANGE:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_offline);
-               bfa_fcs_rport_offline_action(rport);
-               break;
-
-       case RPSM_EVENT_DELETE:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_logosend);
-               bfa_fcxp_discard(rport->fcxp);
-               bfa_fcs_rport_offline_action(rport);
-               break;
-
-       case RPSM_EVENT_SCN:
-               /**
-                * already processing RSCN
-                */
-               break;
-
-       case RPSM_EVENT_LOGO_IMP:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_offline);
-               bfa_fcxp_discard(rport->fcxp);
-               bfa_fcs_rport_offline_action(rport);
-               break;
-
-       case RPSM_EVENT_LOGO_RCVD:
-       case RPSM_EVENT_PRLO_RCVD:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_logorcv);
-               bfa_fcxp_discard(rport->fcxp);
-               bfa_fcs_rport_offline_action(rport);
-               break;
-
-       default:
-               bfa_sm_fault(rport->fcs, event);
-       }
-}
-
-/**
- *             Rport has sent LOGO. Awaiting FC-4 offline completion callback.
- */
-static void
-bfa_fcs_rport_sm_fc4_logorcv(struct bfa_fcs_rport_s *rport,
-                       enum rport_event event)
-{
-       bfa_trc(rport->fcs, rport->pwwn);
-       bfa_trc(rport->fcs, rport->pid);
-       bfa_trc(rport->fcs, event);
-
-       switch (event) {
-       case RPSM_EVENT_FC4_OFFLINE:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_hcb_logorcv);
-               bfa_rport_offline(rport->bfa_rport);
-               break;
-
-       case RPSM_EVENT_DELETE:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_logosend);
-               break;
-
-       case RPSM_EVENT_LOGO_RCVD:
-       case RPSM_EVENT_PRLO_RCVD:
-       case RPSM_EVENT_ADDRESS_CHANGE:
-               break;
-
-       default:
-               bfa_sm_fault(rport->fcs, event);
-       }
-}
-
-/**
- *             LOGO needs to be sent to rport. Awaiting FC-4 offline completion
- *             callback.
- */
-static void
-bfa_fcs_rport_sm_fc4_logosend(struct bfa_fcs_rport_s *rport,
-                             enum rport_event event)
-{
-       bfa_trc(rport->fcs, rport->pwwn);
-       bfa_trc(rport->fcs, rport->pid);
-       bfa_trc(rport->fcs, event);
-
-       switch (event) {
-       case RPSM_EVENT_FC4_OFFLINE:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_hcb_logosend);
-               bfa_rport_offline(rport->bfa_rport);
-               break;
-
-       default:
-               bfa_sm_fault(rport->fcs, event);
-       }
-}
-
-/**
- *     Rport is going offline. Awaiting FC-4 offline completion callback.
- */
-static void
-bfa_fcs_rport_sm_fc4_offline(struct bfa_fcs_rport_s *rport,
-                       enum rport_event event)
-{
-       bfa_trc(rport->fcs, rport->pwwn);
-       bfa_trc(rport->fcs, rport->pid);
-       bfa_trc(rport->fcs, event);
-
-       switch (event) {
-       case RPSM_EVENT_FC4_OFFLINE:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_hcb_offline);
-               bfa_rport_offline(rport->bfa_rport);
-               break;
-
-       case RPSM_EVENT_SCN:
-       case RPSM_EVENT_LOGO_IMP:
-       case RPSM_EVENT_LOGO_RCVD:
-       case RPSM_EVENT_PRLO_RCVD:
-       case RPSM_EVENT_ADDRESS_CHANGE:
-               /**
-                * rport is already going offline.
-                * SCN - ignore and wait till transitioning to offline state
-                */
-               break;
-
-       case RPSM_EVENT_DELETE:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_fc4_logosend);
-               break;
-
-       default:
-               bfa_sm_fault(rport->fcs, event);
-       }
-}
-
-/**
- *             Rport is offline. FC-4s are offline. Awaiting BFA rport offline
- *             callback.
- */
-static void
-bfa_fcs_rport_sm_hcb_offline(struct bfa_fcs_rport_s *rport,
-                       enum rport_event event)
-{
-       bfa_trc(rport->fcs, rport->pwwn);
-       bfa_trc(rport->fcs, rport->pid);
-       bfa_trc(rport->fcs, event);
-
-       switch (event) {
-       case RPSM_EVENT_HCB_OFFLINE:
-       case RPSM_EVENT_ADDRESS_CHANGE:
-               if (bfa_fcs_port_is_online(rport->port)) {
-                       if (bfa_fcs_fabric_is_switched(rport->port->fabric)) {
-                               bfa_sm_set_state(rport,
-                                       bfa_fcs_rport_sm_nsdisc_sending);
-                               rport->ns_retries = 0;
-                               bfa_fcs_rport_send_gidpn(rport, NULL);
-                       } else {
-                               bfa_sm_set_state(rport,
-                                       bfa_fcs_rport_sm_plogi_sending);
-                               rport->plogi_retries = 0;
-                               bfa_fcs_rport_send_plogi(rport, NULL);
-                       }
-               } else {
-                       rport->pid = 0;
-                       bfa_sm_set_state(rport, bfa_fcs_rport_sm_offline);
-                       bfa_timer_start(rport->fcs->bfa, &rport->timer,
-                                       bfa_fcs_rport_timeout, rport,
-                                       bfa_fcs_rport_del_timeout);
-               }
-               break;
-
-       case RPSM_EVENT_DELETE:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_uninit);
-               bfa_fcs_rport_free(rport);
-               break;
-
-       case RPSM_EVENT_SCN:
-       case RPSM_EVENT_LOGO_RCVD:
-       case RPSM_EVENT_PRLO_RCVD:
-               /**
-                * Ignore, already offline.
-                */
-               break;
-
-       default:
-               bfa_sm_fault(rport->fcs, event);
-       }
-}
-
-/**
- *             Rport is offline. FC-4s are offline. Awaiting BFA rport offline
- *             callback to send LOGO accept.
- */
-static void
-bfa_fcs_rport_sm_hcb_logorcv(struct bfa_fcs_rport_s *rport,
-                       enum rport_event event)
-{
-       bfa_trc(rport->fcs, rport->pwwn);
-       bfa_trc(rport->fcs, rport->pid);
-       bfa_trc(rport->fcs, event);
-
-       switch (event) {
-       case RPSM_EVENT_HCB_OFFLINE:
-       case RPSM_EVENT_ADDRESS_CHANGE:
-               if (rport->pid && (rport->prlo == BFA_TRUE))
-                       bfa_fcs_rport_send_prlo_acc(rport);
-               if (rport->pid && (rport->prlo == BFA_FALSE))
-                       bfa_fcs_rport_send_logo_acc(rport);
-
-               /*
-                * If the lport is online and if the rport is not a well known
-                * address port, we try to re-discover the r-port.
-                */
-               if (bfa_fcs_port_is_online(rport->port)
-                   && (!BFA_FCS_PID_IS_WKA(rport->pid))) {
-                       bfa_sm_set_state(rport,
-                                        bfa_fcs_rport_sm_nsdisc_sending);
-                       rport->ns_retries = 0;
-                       bfa_fcs_rport_send_gidpn(rport, NULL);
-               } else {
-                       /*
-                        * if it is not a well known address, reset the pid to
-                        *
-                        */
-                       if (!BFA_FCS_PID_IS_WKA(rport->pid))
-                               rport->pid = 0;
-                       bfa_sm_set_state(rport, bfa_fcs_rport_sm_offline);
-                       bfa_timer_start(rport->fcs->bfa, &rport->timer,
-                                       bfa_fcs_rport_timeout, rport,
-                                       bfa_fcs_rport_del_timeout);
-               }
-               break;
-
-       case RPSM_EVENT_DELETE:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_hcb_logosend);
-               break;
-
-       case RPSM_EVENT_LOGO_IMP:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_hcb_offline);
-               break;
-
-       case RPSM_EVENT_LOGO_RCVD:
-       case RPSM_EVENT_PRLO_RCVD:
-               /**
-                * Ignore - already processing a LOGO.
-                */
-               break;
-
-       default:
-               bfa_sm_fault(rport->fcs, event);
-       }
-}
-
-/**
- * Rport is being deleted. FC-4s are offline. Awaiting BFA rport offline
- * callback to send LOGO.
- */
-static void
-bfa_fcs_rport_sm_hcb_logosend(struct bfa_fcs_rport_s *rport,
-                             enum rport_event event)
-{
-       bfa_trc(rport->fcs, rport->pwwn);
-       bfa_trc(rport->fcs, rport->pid);
-       bfa_trc(rport->fcs, event);
-
-       switch (event) {
-       case RPSM_EVENT_HCB_OFFLINE:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_logo_sending);
-               bfa_fcs_rport_send_logo(rport, NULL);
-               break;
-
-       case RPSM_EVENT_LOGO_RCVD:
-       case RPSM_EVENT_PRLO_RCVD:
-       case RPSM_EVENT_ADDRESS_CHANGE:
-               break;
-
-       default:
-               bfa_sm_fault(rport->fcs, event);
-       }
-}
-
-/**
- *             Rport is being deleted. FC-4s are offline. LOGO is being sent.
- */
-static void
-bfa_fcs_rport_sm_logo_sending(struct bfa_fcs_rport_s *rport,
-                             enum rport_event event)
-{
-       bfa_trc(rport->fcs, rport->pwwn);
-       bfa_trc(rport->fcs, rport->pid);
-       bfa_trc(rport->fcs, event);
-
-       switch (event) {
-       case RPSM_EVENT_FCXP_SENT:
-               /*
-                * Once LOGO is sent, we donot wait for the response
-                */
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_uninit);
-               bfa_fcs_rport_free(rport);
-               break;
-
-       case RPSM_EVENT_SCN:
-       case RPSM_EVENT_ADDRESS_CHANGE:
-               break;
-
-       case RPSM_EVENT_LOGO_RCVD:
-       case RPSM_EVENT_PRLO_RCVD:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_uninit);
-               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
-               bfa_fcs_rport_free(rport);
-               break;
-
-       default:
-               bfa_sm_fault(rport->fcs, event);
-       }
-}
-
-/**
- *             Rport is offline. FC-4s are offline. BFA rport is offline.
- *             Timer active to delete stale rport.
- */
-static void
-bfa_fcs_rport_sm_offline(struct bfa_fcs_rport_s *rport, enum rport_event event)
-{
-       bfa_trc(rport->fcs, rport->pwwn);
-       bfa_trc(rport->fcs, rport->pid);
-       bfa_trc(rport->fcs, event);
-
-       switch (event) {
-       case RPSM_EVENT_TIMEOUT:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_uninit);
-               bfa_fcs_rport_free(rport);
-               break;
-
-       case RPSM_EVENT_SCN:
-       case RPSM_EVENT_ADDRESS_CHANGE:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_nsdisc_sending);
-               bfa_timer_stop(&rport->timer);
-               rport->ns_retries = 0;
-               bfa_fcs_rport_send_gidpn(rport, NULL);
-               break;
-
-       case RPSM_EVENT_DELETE:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_uninit);
-               bfa_timer_stop(&rport->timer);
-               bfa_fcs_rport_free(rport);
-               break;
-
-       case RPSM_EVENT_PLOGI_RCVD:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_plogiacc_sending);
-               bfa_timer_stop(&rport->timer);
-               bfa_fcs_rport_send_plogiacc(rport, NULL);
-               break;
-
-       case RPSM_EVENT_LOGO_RCVD:
-       case RPSM_EVENT_PRLO_RCVD:
-       case RPSM_EVENT_LOGO_IMP:
-               break;
-
-       case RPSM_EVENT_PLOGI_COMP:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_hal_online);
-               bfa_timer_stop(&rport->timer);
-               bfa_fcs_rport_hal_online(rport);
-               break;
-
-       case RPSM_EVENT_PLOGI_SEND:
-               bfa_timer_stop(&rport->timer);
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_plogi_sending);
-               rport->plogi_retries = 0;
-               bfa_fcs_rport_send_plogi(rport, NULL);
-               break;
-
-       default:
-               bfa_sm_fault(rport->fcs, event);
-       }
-}
-
-/**
- *     Rport address has changed. Nameserver discovery request is being sent.
- */
-static void
-bfa_fcs_rport_sm_nsdisc_sending(struct bfa_fcs_rport_s *rport,
-                               enum rport_event event)
-{
-       bfa_trc(rport->fcs, rport->pwwn);
-       bfa_trc(rport->fcs, rport->pid);
-       bfa_trc(rport->fcs, event);
-
-       switch (event) {
-       case RPSM_EVENT_FCXP_SENT:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_nsdisc_sent);
-               break;
-
-       case RPSM_EVENT_DELETE:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_uninit);
-               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
-               bfa_fcs_rport_free(rport);
-               break;
-
-       case RPSM_EVENT_PLOGI_RCVD:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_plogiacc_sending);
-               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
-               bfa_fcs_rport_send_plogiacc(rport, NULL);
-               break;
-
-       case RPSM_EVENT_SCN:
-       case RPSM_EVENT_LOGO_RCVD:
-       case RPSM_EVENT_PRLO_RCVD:
-       case RPSM_EVENT_PLOGI_SEND:
-               break;
-
-       case RPSM_EVENT_ADDRESS_CHANGE:
-               rport->ns_retries = 0;  /* reset the retry count */
-               break;
-
-       case RPSM_EVENT_LOGO_IMP:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_offline);
-               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
-               bfa_timer_start(rport->fcs->bfa, &rport->timer,
-                               bfa_fcs_rport_timeout, rport,
-                               bfa_fcs_rport_del_timeout);
-               break;
-
-       case RPSM_EVENT_PLOGI_COMP:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_hal_online);
-               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rport->fcxp_wqe);
-               bfa_fcs_rport_hal_online(rport);
-               break;
-
-       default:
-               bfa_sm_fault(rport->fcs, event);
-       }
-}
-
-/**
- *             Nameserver discovery failed. Waiting for timeout to retry.
- */
-static void
-bfa_fcs_rport_sm_nsdisc_retry(struct bfa_fcs_rport_s *rport,
-                             enum rport_event event)
-{
-       bfa_trc(rport->fcs, rport->pwwn);
-       bfa_trc(rport->fcs, rport->pid);
-       bfa_trc(rport->fcs, event);
-
-       switch (event) {
-       case RPSM_EVENT_TIMEOUT:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_nsdisc_sending);
-               bfa_fcs_rport_send_gidpn(rport, NULL);
-               break;
-
-       case RPSM_EVENT_SCN:
-       case RPSM_EVENT_ADDRESS_CHANGE:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_nsdisc_sending);
-               bfa_timer_stop(&rport->timer);
-               rport->ns_retries = 0;
-               bfa_fcs_rport_send_gidpn(rport, NULL);
-               break;
-
-       case RPSM_EVENT_DELETE:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_uninit);
-               bfa_timer_stop(&rport->timer);
-               bfa_fcs_rport_free(rport);
-               break;
-
-       case RPSM_EVENT_PLOGI_RCVD:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_plogiacc_sending);
-               bfa_timer_stop(&rport->timer);
-               bfa_fcs_rport_send_plogiacc(rport, NULL);
-               break;
-
-       case RPSM_EVENT_LOGO_IMP:
-               rport->pid = 0;
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_offline);
-               bfa_timer_stop(&rport->timer);
-               bfa_timer_start(rport->fcs->bfa, &rport->timer,
-                               bfa_fcs_rport_timeout, rport,
-                               bfa_fcs_rport_del_timeout);
-               break;
-
-       case RPSM_EVENT_LOGO_RCVD:
-               bfa_fcs_rport_send_logo_acc(rport);
-               break;
-
-       case RPSM_EVENT_PRLO_RCVD:
-               bfa_fcs_rport_send_prlo_acc(rport);
-               break;
-
-       case RPSM_EVENT_PLOGI_COMP:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_hal_online);
-               bfa_timer_stop(&rport->timer);
-               bfa_fcs_rport_hal_online(rport);
-               break;
-
-       default:
-               bfa_sm_fault(rport->fcs, event);
-       }
-}
-
-/**
- * Rport address has changed. Nameserver discovery request is sent.
- */
-static void
-bfa_fcs_rport_sm_nsdisc_sent(struct bfa_fcs_rport_s *rport,
-                       enum rport_event event)
-{
-       bfa_trc(rport->fcs, rport->pwwn);
-       bfa_trc(rport->fcs, rport->pid);
-       bfa_trc(rport->fcs, event);
-
-       switch (event) {
-       case RPSM_EVENT_ACCEPTED:
-       case RPSM_EVENT_ADDRESS_CHANGE:
-               if (rport->pid) {
-                       bfa_sm_set_state(rport, bfa_fcs_rport_sm_plogi_sending);
-                       bfa_fcs_rport_send_plogi(rport, NULL);
-               } else {
-                       bfa_sm_set_state(rport,
-                                        bfa_fcs_rport_sm_nsdisc_sending);
-                       rport->ns_retries = 0;
-                       bfa_fcs_rport_send_gidpn(rport, NULL);
-               }
-               break;
-
-       case RPSM_EVENT_FAILED:
-               rport->ns_retries++;
-               if (rport->ns_retries < BFA_FCS_RPORT_MAX_RETRIES) {
-                       bfa_sm_set_state(rport,
-                                        bfa_fcs_rport_sm_nsdisc_sending);
-                       bfa_fcs_rport_send_gidpn(rport, NULL);
-               } else {
-                       rport->pid = 0;
-                       bfa_sm_set_state(rport, bfa_fcs_rport_sm_offline);
-                       bfa_timer_start(rport->fcs->bfa, &rport->timer,
-                                       bfa_fcs_rport_timeout, rport,
-                                       bfa_fcs_rport_del_timeout);
-               };
-               break;
-
-       case RPSM_EVENT_DELETE:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_uninit);
-               bfa_fcxp_discard(rport->fcxp);
-               bfa_fcs_rport_free(rport);
-               break;
-
-       case RPSM_EVENT_PLOGI_RCVD:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_plogiacc_sending);
-               bfa_fcxp_discard(rport->fcxp);
-               bfa_fcs_rport_send_plogiacc(rport, NULL);
-               break;
-
-       case RPSM_EVENT_LOGO_IMP:
-               rport->pid = 0;
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_offline);
-               bfa_fcxp_discard(rport->fcxp);
-               bfa_timer_start(rport->fcs->bfa, &rport->timer,
-                               bfa_fcs_rport_timeout, rport,
-                               bfa_fcs_rport_del_timeout);
-               break;
-
-       case RPSM_EVENT_PRLO_RCVD:
-               bfa_fcs_rport_send_prlo_acc(rport);
-               break;
-
-       case RPSM_EVENT_SCN:
-               /**
-                * ignore, wait for NS query response
-                */
-               break;
-
-       case RPSM_EVENT_LOGO_RCVD:
-               /**
-                * Not logged-in yet. Accept LOGO.
-                */
-               bfa_fcs_rport_send_logo_acc(rport);
-               break;
-
-       case RPSM_EVENT_PLOGI_COMP:
-               bfa_sm_set_state(rport, bfa_fcs_rport_sm_hal_online);
-               bfa_fcxp_discard(rport->fcxp);
-               bfa_fcs_rport_hal_online(rport);
-               break;
-
-       default:
-               bfa_sm_fault(rport->fcs, event);
-       }
-}
-
-
-
-/**
- *  fcs_rport_private FCS RPORT provate functions
- */
-
-static void
-bfa_fcs_rport_send_plogi(void *rport_cbarg, struct bfa_fcxp_s *fcxp_alloced)
-{
-       struct bfa_fcs_rport_s *rport = rport_cbarg;
-       struct bfa_fcs_port_s *port = rport->port;
-       struct fchs_s          fchs;
-       int             len;
-       struct bfa_fcxp_s *fcxp;
-
-       bfa_trc(rport->fcs, rport->pwwn);
-
-       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
-       if (!fcxp) {
-               bfa_fcxp_alloc_wait(port->fcs->bfa, &rport->fcxp_wqe,
-                                   bfa_fcs_rport_send_plogi, rport);
-               return;
-       }
-       rport->fcxp = fcxp;
-
-       len = fc_plogi_build(&fchs, bfa_fcxp_get_reqbuf(fcxp), rport->pid,
-                            bfa_fcs_port_get_fcid(port), 0,
-                            port->port_cfg.pwwn, port->port_cfg.nwwn,
-                            bfa_fcport_get_maxfrsize(port->fcs->bfa));
-
-       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
-                     FC_CLASS_3, len, &fchs, bfa_fcs_rport_plogi_response,
-                     (void *)rport, FC_MAX_PDUSZ, FC_ELS_TOV);
-
-       rport->stats.plogis++;
-       bfa_sm_send_event(rport, RPSM_EVENT_FCXP_SENT);
-}
-
-static void
-bfa_fcs_rport_plogi_response(void *fcsarg, struct bfa_fcxp_s *fcxp, void *cbarg,
-                            bfa_status_t req_status, u32 rsp_len,
-                            u32 resid_len, struct fchs_s *rsp_fchs)
-{
-       struct bfa_fcs_rport_s *rport = (struct bfa_fcs_rport_s *)cbarg;
-       struct fc_logi_s        *plogi_rsp;
-       struct fc_ls_rjt_s      *ls_rjt;
-       struct bfa_fcs_rport_s *twin;
-       struct list_head *qe;
-
-       bfa_trc(rport->fcs, rport->pwwn);
-
-       /*
-        * Sanity Checks
-        */
-       if (req_status != BFA_STATUS_OK) {
-               bfa_trc(rport->fcs, req_status);
-               rport->stats.plogi_failed++;
-               bfa_sm_send_event(rport, RPSM_EVENT_FAILED);
-               return;
-       }
-
-       plogi_rsp = (struct fc_logi_s *) BFA_FCXP_RSP_PLD(fcxp);
-
-       /**
-        * Check for failure first.
-        */
-       if (plogi_rsp->els_cmd.els_code != FC_ELS_ACC) {
-               ls_rjt = (struct fc_ls_rjt_s *) BFA_FCXP_RSP_PLD(fcxp);
-
-               bfa_trc(rport->fcs, ls_rjt->reason_code);
-               bfa_trc(rport->fcs, ls_rjt->reason_code_expl);
-
-               rport->stats.plogi_rejects++;
-               bfa_sm_send_event(rport, RPSM_EVENT_FAILED);
-               return;
-       }
-
-       /**
-        * PLOGI is complete. Make sure this device is not one of the known
-        * device with a new FC port address.
-        */
-       list_for_each(qe, &rport->port->rport_q) {
-               twin = (struct bfa_fcs_rport_s *)qe;
-               if (twin == rport)
-                       continue;
-               if (!rport->pwwn && (plogi_rsp->port_name == twin->pwwn)) {
-                       bfa_trc(rport->fcs, twin->pid);
-                       bfa_trc(rport->fcs, rport->pid);
-
-                       /*
-                        * Update plogi stats in twin
-                        */
-                       twin->stats.plogis += rport->stats.plogis;
-                       twin->stats.plogi_rejects += rport->stats.plogi_rejects;
-                       twin->stats.plogi_timeouts +=
-                               rport->stats.plogi_timeouts;
-                       twin->stats.plogi_failed += rport->stats.plogi_failed;
-                       twin->stats.plogi_rcvd += rport->stats.plogi_rcvd;
-                       twin->stats.plogi_accs++;
-
-                       bfa_fcs_rport_delete(rport);
-
-                       bfa_fcs_rport_update(twin, plogi_rsp);
-                       twin->pid = rsp_fchs->s_id;
-                       bfa_sm_send_event(twin, RPSM_EVENT_PLOGI_COMP);
-                       return;
-               }
-       }
-
-       /**
-        * Normal login path -- no evil twins.
-        */
-       rport->stats.plogi_accs++;
-       bfa_fcs_rport_update(rport, plogi_rsp);
-       bfa_sm_send_event(rport, RPSM_EVENT_ACCEPTED);
-}
-
-static void
-bfa_fcs_rport_send_plogiacc(void *rport_cbarg, struct bfa_fcxp_s *fcxp_alloced)
-{
-       struct bfa_fcs_rport_s *rport = rport_cbarg;
-       struct bfa_fcs_port_s *port = rport->port;
-       struct fchs_s          fchs;
-       int             len;
-       struct bfa_fcxp_s *fcxp;
-
-       bfa_trc(rport->fcs, rport->pwwn);
-       bfa_trc(rport->fcs, rport->reply_oxid);
-
-       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
-       if (!fcxp) {
-               bfa_fcxp_alloc_wait(port->fcs->bfa, &rport->fcxp_wqe,
-                                   bfa_fcs_rport_send_plogiacc, rport);
-               return;
-       }
-       rport->fcxp = fcxp;
-
-       len = fc_plogi_acc_build(&fchs, bfa_fcxp_get_reqbuf(fcxp), rport->pid,
-                                bfa_fcs_port_get_fcid(port), rport->reply_oxid,
-                                port->port_cfg.pwwn, port->port_cfg.nwwn,
-                                bfa_fcport_get_maxfrsize(port->fcs->bfa));
-
-       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
-                     FC_CLASS_3, len, &fchs, NULL, NULL, FC_MAX_PDUSZ, 0);
-
-       bfa_sm_send_event(rport, RPSM_EVENT_FCXP_SENT);
-}
-
-static void
-bfa_fcs_rport_send_adisc(void *rport_cbarg, struct bfa_fcxp_s *fcxp_alloced)
-{
-       struct bfa_fcs_rport_s *rport = rport_cbarg;
-       struct bfa_fcs_port_s *port = rport->port;
-       struct fchs_s          fchs;
-       int             len;
-       struct bfa_fcxp_s *fcxp;
-
-       bfa_trc(rport->fcs, rport->pwwn);
-
-       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
-       if (!fcxp) {
-               bfa_fcxp_alloc_wait(port->fcs->bfa, &rport->fcxp_wqe,
-                                   bfa_fcs_rport_send_adisc, rport);
-               return;
-       }
-       rport->fcxp = fcxp;
-
-       len = fc_adisc_build(&fchs, bfa_fcxp_get_reqbuf(fcxp), rport->pid,
-                            bfa_fcs_port_get_fcid(port), 0,
-                            port->port_cfg.pwwn, port->port_cfg.nwwn);
-
-       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
-                     FC_CLASS_3, len, &fchs, bfa_fcs_rport_adisc_response,
-                     rport, FC_MAX_PDUSZ, FC_ELS_TOV);
-
-       rport->stats.adisc_sent++;
-       bfa_sm_send_event(rport, RPSM_EVENT_FCXP_SENT);
-}
-
-static void
-bfa_fcs_rport_adisc_response(void *fcsarg, struct bfa_fcxp_s *fcxp, void *cbarg,
-                            bfa_status_t req_status, u32 rsp_len,
-                            u32 resid_len, struct fchs_s *rsp_fchs)
-{
-       struct bfa_fcs_rport_s *rport = (struct bfa_fcs_rport_s *)cbarg;
-       void           *pld = bfa_fcxp_get_rspbuf(fcxp);
-       struct fc_ls_rjt_s    *ls_rjt;
-
-       if (req_status != BFA_STATUS_OK) {
-               bfa_trc(rport->fcs, req_status);
-               rport->stats.adisc_failed++;
-               bfa_sm_send_event(rport, RPSM_EVENT_FAILED);
-               return;
-       }
-
-       if (fc_adisc_rsp_parse((struct fc_adisc_s *)pld, rsp_len, rport->pwwn,
-               rport->nwwn)  == FC_PARSE_OK) {
-               rport->stats.adisc_accs++;
-               bfa_sm_send_event(rport, RPSM_EVENT_ACCEPTED);
-               return;
-       }
-
-       rport->stats.adisc_rejects++;
-       ls_rjt = pld;
-       bfa_trc(rport->fcs, ls_rjt->els_cmd.els_code);
-       bfa_trc(rport->fcs, ls_rjt->reason_code);
-       bfa_trc(rport->fcs, ls_rjt->reason_code_expl);
-       bfa_sm_send_event(rport, RPSM_EVENT_FAILED);
-}
-
-static void
-bfa_fcs_rport_send_gidpn(void *rport_cbarg, struct bfa_fcxp_s *fcxp_alloced)
-{
-       struct bfa_fcs_rport_s *rport = rport_cbarg;
-       struct bfa_fcs_port_s *port = rport->port;
-       struct fchs_s          fchs;
-       struct bfa_fcxp_s *fcxp;
-       int             len;
-
-       bfa_trc(rport->fcs, rport->pid);
-
-       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
-       if (!fcxp) {
-               bfa_fcxp_alloc_wait(port->fcs->bfa, &rport->fcxp_wqe,
-                                   bfa_fcs_rport_send_gidpn, rport);
-               return;
-       }
-       rport->fcxp = fcxp;
-
-       len = fc_gidpn_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
-                            bfa_fcs_port_get_fcid(port), 0, rport->pwwn);
-
-       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
-                     FC_CLASS_3, len, &fchs, bfa_fcs_rport_gidpn_response,
-                     (void *)rport, FC_MAX_PDUSZ, FC_FCCT_TOV);
-
-       bfa_sm_send_event(rport, RPSM_EVENT_FCXP_SENT);
-}
-
-static void
-bfa_fcs_rport_gidpn_response(void *fcsarg, struct bfa_fcxp_s *fcxp, void *cbarg,
-                            bfa_status_t req_status, u32 rsp_len,
-                            u32 resid_len, struct fchs_s *rsp_fchs)
-{
-       struct bfa_fcs_rport_s *rport = (struct bfa_fcs_rport_s *)cbarg;
-       struct bfa_fcs_rport_s *twin;
-       struct list_head *qe;
-       struct ct_hdr_s         *cthdr;
-       struct fcgs_gidpn_resp_s        *gidpn_rsp;
-
-       bfa_trc(rport->fcs, rport->pwwn);
-
-       cthdr = (struct ct_hdr_s *) BFA_FCXP_RSP_PLD(fcxp);
-       cthdr->cmd_rsp_code = bfa_os_ntohs(cthdr->cmd_rsp_code);
-
-       if (cthdr->cmd_rsp_code == CT_RSP_ACCEPT) {
-               /*
-                * Check if the pid is the same as before.
-                */
-               gidpn_rsp = (struct fcgs_gidpn_resp_s *) (cthdr + 1);
-
-               if (gidpn_rsp->dap == rport->pid) {
-                       /*
-                        * Device is online
-                        */
-                       bfa_sm_send_event(rport, RPSM_EVENT_ACCEPTED);
-               } else {
-                       /*
-                        * Device's PID has changed. We need to cleanup and
-                        * re-login. If there is another device with the the
-                        * newly discovered pid, send an scn notice so that its
-                        * new pid can be discovered.
-                        */
-                       list_for_each(qe, &rport->port->rport_q) {
-                               twin = (struct bfa_fcs_rport_s *)qe;
-                               if (twin == rport)
-                                       continue;
-                               if (gidpn_rsp->dap == twin->pid) {
-                                       bfa_trc(rport->fcs, twin->pid);
-                                       bfa_trc(rport->fcs, rport->pid);
-
-                                       twin->pid = 0;
-                                       bfa_sm_send_event(twin,
-                                               RPSM_EVENT_ADDRESS_CHANGE);
-                               }
-                       }
-                       rport->pid = gidpn_rsp->dap;
-                       bfa_sm_send_event(rport, RPSM_EVENT_ADDRESS_CHANGE);
-               }
-               return;
-       }
-
-       /*
-        * Reject Response
-        */
-       switch (cthdr->reason_code) {
-       case CT_RSN_LOGICAL_BUSY:
-               /*
-                * Need to retry
-                */
-               bfa_sm_send_event(rport, RPSM_EVENT_TIMEOUT);
-               break;
-
-       case CT_RSN_UNABLE_TO_PERF:
-               /*
-                * device doesn't exist : Start timer to cleanup this later.
-                */
-               bfa_sm_send_event(rport, RPSM_EVENT_FAILED);
-               break;
-
-       default:
-               bfa_sm_send_event(rport, RPSM_EVENT_FAILED);
-               break;
-       }
-}
-
-/**
- *    Called to send a logout to the rport.
- */
-static void
-bfa_fcs_rport_send_logo(void *rport_cbarg, struct bfa_fcxp_s *fcxp_alloced)
-{
-       struct bfa_fcs_rport_s *rport = rport_cbarg;
-       struct bfa_fcs_port_s *port;
-       struct fchs_s          fchs;
-       struct bfa_fcxp_s *fcxp;
-       u16        len;
-
-       bfa_trc(rport->fcs, rport->pid);
-
-       port = rport->port;
-
-       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
-       if (!fcxp) {
-               bfa_fcxp_alloc_wait(port->fcs->bfa, &rport->fcxp_wqe,
-                                   bfa_fcs_rport_send_logo, rport);
-               return;
-       }
-       rport->fcxp = fcxp;
-
-       len = fc_logo_build(&fchs, bfa_fcxp_get_reqbuf(fcxp), rport->pid,
-                           bfa_fcs_port_get_fcid(port), 0,
-                           bfa_fcs_port_get_pwwn(port));
-
-       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
-                     FC_CLASS_3, len, &fchs, NULL, rport, FC_MAX_PDUSZ,
-                     FC_ELS_TOV);
-
-       rport->stats.logos++;
-       bfa_fcxp_discard(rport->fcxp);
-       bfa_sm_send_event(rport, RPSM_EVENT_FCXP_SENT);
-}
-
-/**
- *    Send ACC for a LOGO received.
- */
-static void
-bfa_fcs_rport_send_logo_acc(void *rport_cbarg)
-{
-       struct bfa_fcs_rport_s *rport = rport_cbarg;
-       struct bfa_fcs_port_s *port;
-       struct fchs_s          fchs;
-       struct bfa_fcxp_s *fcxp;
-       u16        len;
-
-       bfa_trc(rport->fcs, rport->pid);
-
-       port = rport->port;
-
-       fcxp = bfa_fcs_fcxp_alloc(port->fcs);
-       if (!fcxp)
-               return;
-
-       rport->stats.logo_rcvd++;
-       len = fc_logo_acc_build(&fchs, bfa_fcxp_get_reqbuf(fcxp), rport->pid,
-                               bfa_fcs_port_get_fcid(port), rport->reply_oxid);
-
-       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
-                     FC_CLASS_3, len, &fchs, NULL, NULL, FC_MAX_PDUSZ, 0);
-}
-
-/**
- *     This routine will be called by bfa_timer on timer timeouts.
- *
- *     param[in]       rport                   - pointer to bfa_fcs_port_ns_t.
- *     param[out]      rport_status    - pointer to return vport status in
- *
- *     return
- *             void
- *
-*      Special Considerations:
- *
- *     note
- */
-static void
-bfa_fcs_rport_timeout(void *arg)
-{
-       struct bfa_fcs_rport_s *rport = (struct bfa_fcs_rport_s *)arg;
-
-       rport->stats.plogi_timeouts++;
-       bfa_sm_send_event(rport, RPSM_EVENT_TIMEOUT);
-}
-
-static void
-bfa_fcs_rport_process_prli(struct bfa_fcs_rport_s *rport,
-                       struct fchs_s *rx_fchs, u16 len)
-{
-       struct bfa_fcxp_s *fcxp;
-       struct fchs_s          fchs;
-       struct bfa_fcs_port_s *port = rport->port;
-       struct fc_prli_s      *prli;
-
-       bfa_trc(port->fcs, rx_fchs->s_id);
-       bfa_trc(port->fcs, rx_fchs->d_id);
-
-       rport->stats.prli_rcvd++;
-
-       if (BFA_FCS_VPORT_IS_TARGET_MODE(port)) {
-               /*
-                * Target Mode : Let the fcptm handle it
-                */
-               bfa_fcs_tin_rx_prli(rport->tin, rx_fchs, len);
-               return;
-       }
-
-       /*
-        * We are either in Initiator or ipfc Mode
-        */
-       prli = (struct fc_prli_s *) (rx_fchs + 1);
-
-       if (prli->parampage.servparams.initiator) {
-               bfa_trc(rport->fcs, prli->parampage.type);
-               rport->scsi_function = BFA_RPORT_INITIATOR;
-               bfa_fcs_itnim_is_initiator(rport->itnim);
-       } else {
-               /*
-                * @todo: PRLI from a target ?
-                */
-               bfa_trc(port->fcs, rx_fchs->s_id);
-               rport->scsi_function = BFA_RPORT_TARGET;
-       }
-
-       fcxp = bfa_fcs_fcxp_alloc(port->fcs);
-       if (!fcxp)
-               return;
-
-       len = fc_prli_acc_build(&fchs, bfa_fcxp_get_reqbuf(fcxp), rx_fchs->s_id,
-                               bfa_fcs_port_get_fcid(port), rx_fchs->ox_id,
-                               port->port_cfg.roles);
-
-       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
-                     FC_CLASS_3, len, &fchs, NULL, NULL, FC_MAX_PDUSZ, 0);
-}
-
-static void
-bfa_fcs_rport_process_rpsc(struct bfa_fcs_rport_s *rport,
-                       struct fchs_s *rx_fchs, u16 len)
-{
-       struct bfa_fcxp_s *fcxp;
-       struct fchs_s          fchs;
-       struct bfa_fcs_port_s *port = rport->port;
-       struct fc_rpsc_speed_info_s speeds;
-       struct bfa_pport_attr_s pport_attr;
-
-       bfa_trc(port->fcs, rx_fchs->s_id);
-       bfa_trc(port->fcs, rx_fchs->d_id);
-
-       rport->stats.rpsc_rcvd++;
-       speeds.port_speed_cap =
-               RPSC_SPEED_CAP_1G | RPSC_SPEED_CAP_2G | RPSC_SPEED_CAP_4G |
-               RPSC_SPEED_CAP_8G;
-
-       /*
-        * get curent speed from pport attributes from BFA
-        */
-       bfa_fcport_get_attr(port->fcs->bfa, &pport_attr);
-
-       speeds.port_op_speed = fc_bfa_speed_to_rpsc_operspeed(pport_attr.speed);
-
-       fcxp = bfa_fcs_fcxp_alloc(port->fcs);
-       if (!fcxp)
-               return;
-
-       len = fc_rpsc_acc_build(&fchs, bfa_fcxp_get_reqbuf(fcxp), rx_fchs->s_id,
-                               bfa_fcs_port_get_fcid(port), rx_fchs->ox_id,
-                               &speeds);
-
-       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
-                     FC_CLASS_3, len, &fchs, NULL, NULL, FC_MAX_PDUSZ, 0);
-}
-
-static void
-bfa_fcs_rport_process_adisc(struct bfa_fcs_rport_s *rport,
-                       struct fchs_s *rx_fchs, u16 len)
-{
-       struct bfa_fcxp_s *fcxp;
-       struct fchs_s          fchs;
-       struct bfa_fcs_port_s *port = rport->port;
-       struct fc_adisc_s      *adisc;
-
-       bfa_trc(port->fcs, rx_fchs->s_id);
-       bfa_trc(port->fcs, rx_fchs->d_id);
-
-       rport->stats.adisc_rcvd++;
-
-       if (BFA_FCS_VPORT_IS_TARGET_MODE(port)) {
-               /*
-                * @todo : Target Mode handling
-                */
-               bfa_trc(port->fcs, rx_fchs->d_id);
-               bfa_assert(0);
-               return;
-       }
-
-       adisc = (struct fc_adisc_s *) (rx_fchs + 1);
-
-       /*
-        * Accept if the itnim for this rport is online. Else reject the ADISC
-        */
-       if (bfa_fcs_itnim_get_online_state(rport->itnim) == BFA_STATUS_OK) {
-
-               fcxp = bfa_fcs_fcxp_alloc(port->fcs);
-               if (!fcxp)
-                       return;
-
-               len = fc_adisc_acc_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
-                                        rx_fchs->s_id,
-                                        bfa_fcs_port_get_fcid(port),
-                                        rx_fchs->ox_id, port->port_cfg.pwwn,
-                                        port->port_cfg.nwwn);
-
-               bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag,
-                             BFA_FALSE, FC_CLASS_3, len, &fchs, NULL, NULL,
-                             FC_MAX_PDUSZ, 0);
-       } else {
-               rport->stats.adisc_rejected++;
-               bfa_fcs_rport_send_ls_rjt(rport, rx_fchs,
-                                         FC_LS_RJT_RSN_UNABLE_TO_PERF_CMD,
-                                         FC_LS_RJT_EXP_LOGIN_REQUIRED);
-       }
-
-}
-
-static void
-bfa_fcs_rport_hal_online(struct bfa_fcs_rport_s *rport)
-{
-       struct bfa_fcs_port_s *port = rport->port;
-       struct bfa_rport_info_s rport_info;
-
-       rport_info.pid = rport->pid;
-       rport_info.local_pid = port->pid;
-       rport_info.lp_tag = port->lp_tag;
-       rport_info.vf_id = port->fabric->vf_id;
-       rport_info.vf_en = port->fabric->is_vf;
-       rport_info.fc_class = rport->fc_cos;
-       rport_info.cisc = rport->cisc;
-       rport_info.max_frmsz = rport->maxfrsize;
-       bfa_rport_online(rport->bfa_rport, &rport_info);
-}
-
-static void
-bfa_fcs_rport_fc4_pause(struct bfa_fcs_rport_s *rport)
-{
-       if (bfa_fcs_port_is_initiator(rport->port))
-               bfa_fcs_itnim_pause(rport->itnim);
-
-       if (bfa_fcs_port_is_target(rport->port))
-               bfa_fcs_tin_pause(rport->tin);
-}
-
-static void
-bfa_fcs_rport_fc4_resume(struct bfa_fcs_rport_s *rport)
-{
-       if (bfa_fcs_port_is_initiator(rport->port))
-               bfa_fcs_itnim_resume(rport->itnim);
-
-       if (bfa_fcs_port_is_target(rport->port))
-               bfa_fcs_tin_resume(rport->tin);
-}
-
-static struct bfa_fcs_rport_s *
-bfa_fcs_rport_alloc(struct bfa_fcs_port_s *port, wwn_t pwwn, u32 rpid)
-{
-       struct bfa_fcs_s *fcs = port->fcs;
-       struct bfa_fcs_rport_s *rport;
-       struct bfad_rport_s *rport_drv;
-
-       /**
-        * allocate rport
-        */
-       if (bfa_fcb_rport_alloc(fcs->bfad, &rport, &rport_drv)
-           != BFA_STATUS_OK) {
-               bfa_trc(fcs, rpid);
-               return NULL;
-       }
-
-       /*
-        * Initialize r-port
-        */
-       rport->port = port;
-       rport->fcs = fcs;
-       rport->rp_drv = rport_drv;
-       rport->pid = rpid;
-       rport->pwwn = pwwn;
-
-       /**
-        * allocate BFA rport
-        */
-       rport->bfa_rport = bfa_rport_create(port->fcs->bfa, rport);
-       if (!rport->bfa_rport) {
-               bfa_trc(fcs, rpid);
-               kfree(rport_drv);
-               return NULL;
-       }
-
-       /**
-        * allocate FC-4s
-        */
-       bfa_assert(bfa_fcs_port_is_initiator(port) ^
-                  bfa_fcs_port_is_target(port));
-
-       if (bfa_fcs_port_is_initiator(port)) {
-               rport->itnim = bfa_fcs_itnim_create(rport);
-               if (!rport->itnim) {
-                       bfa_trc(fcs, rpid);
-                       bfa_rport_delete(rport->bfa_rport);
-                       kfree(rport_drv);
-                       return NULL;
-               }
-       }
-
-       if (bfa_fcs_port_is_target(port)) {
-               rport->tin = bfa_fcs_tin_create(rport);
-               if (!rport->tin) {
-                       bfa_trc(fcs, rpid);
-                       bfa_rport_delete(rport->bfa_rport);
-                       kfree(rport_drv);
-                       return NULL;
-               }
-       }
-
-       bfa_fcs_port_add_rport(port, rport);
-
-       bfa_sm_set_state(rport, bfa_fcs_rport_sm_uninit);
-
-       /*
-        * Initialize the Rport Features(RPF) Sub Module
-        */
-       if (!BFA_FCS_PID_IS_WKA(rport->pid))
-               bfa_fcs_rpf_init(rport);
-
-       return rport;
-}
-
-
-static void
-bfa_fcs_rport_free(struct bfa_fcs_rport_s *rport)
-{
-       struct bfa_fcs_port_s *port = rport->port;
-
-       /**
-        * - delete FC-4s
-        * - delete BFA rport
-        * - remove from queue of rports
-        */
-       if (bfa_fcs_port_is_initiator(port))
-               bfa_fcs_itnim_delete(rport->itnim);
-
-       if (bfa_fcs_port_is_target(port))
-               bfa_fcs_tin_delete(rport->tin);
-
-       bfa_rport_delete(rport->bfa_rport);
-       bfa_fcs_port_del_rport(port, rport);
-       kfree(rport->rp_drv);
-}
-
-static void
-bfa_fcs_rport_aen_post(struct bfa_fcs_rport_s *rport,
-                      enum bfa_rport_aen_event event,
-                      struct bfa_rport_aen_data_s *data)
-{
-       union bfa_aen_data_u aen_data;
-       struct bfa_log_mod_s *logmod = rport->fcs->logm;
-       wwn_t           lpwwn = bfa_fcs_port_get_pwwn(rport->port);
-       wwn_t           rpwwn = rport->pwwn;
-       char            lpwwn_ptr[BFA_STRING_32];
-       char            rpwwn_ptr[BFA_STRING_32];
-       char           *prio_str[] = { "unknown", "high", "medium", "low" };
-
-       wwn2str(lpwwn_ptr, lpwwn);
-       wwn2str(rpwwn_ptr, rpwwn);
-
-       switch (event) {
-       case BFA_RPORT_AEN_ONLINE:
-       case BFA_RPORT_AEN_OFFLINE:
-       case BFA_RPORT_AEN_DISCONNECT:
-               bfa_log(logmod, BFA_LOG_CREATE_ID(BFA_AEN_CAT_RPORT, event),
-                       rpwwn_ptr, lpwwn_ptr);
-               break;
-       case BFA_RPORT_AEN_QOS_PRIO:
-               aen_data.rport.priv.qos = data->priv.qos;
-               bfa_log(logmod, BFA_AEN_RPORT_QOS_PRIO,
-                       prio_str[aen_data.rport.priv.qos.qos_priority],
-                       rpwwn_ptr, lpwwn_ptr);
-               break;
-       case BFA_RPORT_AEN_QOS_FLOWID:
-               aen_data.rport.priv.qos = data->priv.qos;
-               bfa_log(logmod, BFA_AEN_RPORT_QOS_FLOWID,
-                       aen_data.rport.priv.qos.qos_flow_id, rpwwn_ptr,
-                       lpwwn_ptr);
-               break;
-       default:
-               break;
-       }
-
-       aen_data.rport.vf_id = rport->port->fabric->vf_id;
-       aen_data.rport.ppwwn =
-               bfa_fcs_port_get_pwwn(bfa_fcs_get_base_port(rport->fcs));
-       aen_data.rport.lpwwn = lpwwn;
-       aen_data.rport.rpwwn = rpwwn;
-}
-
-static void
-bfa_fcs_rport_online_action(struct bfa_fcs_rport_s *rport)
-{
-       struct bfa_fcs_port_s *port = rport->port;
-
-       rport->stats.onlines++;
-
-       if (bfa_fcs_port_is_initiator(port)) {
-               bfa_fcs_itnim_rport_online(rport->itnim);
-               if (!BFA_FCS_PID_IS_WKA(rport->pid))
-                       bfa_fcs_rpf_rport_online(rport);
-       };
-
-       if (bfa_fcs_port_is_target(port))
-               bfa_fcs_tin_rport_online(rport->tin);
-
-       /*
-        * Don't post events for well known addresses
-        */
-       if (!BFA_FCS_PID_IS_WKA(rport->pid))
-               bfa_fcs_rport_aen_post(rport, BFA_RPORT_AEN_ONLINE, NULL);
-}
-
-static void
-bfa_fcs_rport_offline_action(struct bfa_fcs_rport_s *rport)
-{
-       struct bfa_fcs_port_s *port = rport->port;
-
-       rport->stats.offlines++;
-
-       /*
-        * Don't post events for well known addresses
-        */
-       if (!BFA_FCS_PID_IS_WKA(rport->pid)) {
-               if (bfa_fcs_port_is_online(rport->port) == BFA_TRUE) {
-                       bfa_fcs_rport_aen_post(rport, BFA_RPORT_AEN_DISCONNECT,
-                                              NULL);
-               } else {
-                       bfa_fcs_rport_aen_post(rport, BFA_RPORT_AEN_OFFLINE,
-                                              NULL);
-               }
-       }
-
-       if (bfa_fcs_port_is_initiator(port)) {
-               bfa_fcs_itnim_rport_offline(rport->itnim);
-               if (!BFA_FCS_PID_IS_WKA(rport->pid))
-                       bfa_fcs_rpf_rport_offline(rport);
-       }
-
-       if (bfa_fcs_port_is_target(port))
-               bfa_fcs_tin_rport_offline(rport->tin);
-}
-
-/**
- * Update rport parameters from PLOGI or PLOGI accept.
- */
-static void
-bfa_fcs_rport_update(struct bfa_fcs_rport_s *rport, struct fc_logi_s *plogi)
-{
-       struct bfa_fcs_port_s *port = rport->port;
-
-       /**
-        * - port name
-        * - node name
-        */
-       rport->pwwn = plogi->port_name;
-       rport->nwwn = plogi->node_name;
-
-       /**
-        * - class of service
-        */
-       rport->fc_cos = 0;
-       if (plogi->class3.class_valid)
-               rport->fc_cos = FC_CLASS_3;
-
-       if (plogi->class2.class_valid)
-               rport->fc_cos |= FC_CLASS_2;
-
-       /**
-        * - CISC
-        * - MAX receive frame size
-        */
-       rport->cisc = plogi->csp.cisc;
-       rport->maxfrsize = bfa_os_ntohs(plogi->class3.rxsz);
-
-       bfa_trc(port->fcs, bfa_os_ntohs(plogi->csp.bbcred));
-       bfa_trc(port->fcs, port->fabric->bb_credit);
-       /**
-        * Direct Attach P2P mode :
-        * This is to handle a bug (233476) in IBM targets in Direct Attach
-        * Mode. Basically, in FLOGI Accept the target would have erroneously
-        * set the BB Credit to the value used in the FLOGI sent by the HBA.
-        * It uses the correct value (its own BB credit) in PLOGI.
-        */
-       if ((!bfa_fcs_fabric_is_switched(port->fabric))
-           && (bfa_os_ntohs(plogi->csp.bbcred) < port->fabric->bb_credit)) {
-
-               bfa_trc(port->fcs, bfa_os_ntohs(plogi->csp.bbcred));
-               bfa_trc(port->fcs, port->fabric->bb_credit);
-
-               port->fabric->bb_credit = bfa_os_ntohs(plogi->csp.bbcred);
-               bfa_fcport_set_tx_bbcredit(port->fcs->bfa,
-                                         port->fabric->bb_credit);
-       }
-
-}
-
-/**
- *   Called to handle LOGO received from an existing remote port.
- */
-static void
-bfa_fcs_rport_process_logo(struct bfa_fcs_rport_s *rport, struct fchs_s *fchs)
-{
-       rport->reply_oxid = fchs->ox_id;
-       bfa_trc(rport->fcs, rport->reply_oxid);
-
-       rport->prlo = BFA_FALSE;
-       rport->stats.logo_rcvd++;
-       bfa_sm_send_event(rport, RPSM_EVENT_LOGO_RCVD);
-}
-
-
-
-/**
- *  fcs_rport_public FCS rport public interfaces
- */
-
-/**
- *     Called by bport/vport to create a remote port instance for a discovered
- *     remote device.
- *
- * @param[in] port     - base port or vport
- * @param[in] rpid     - remote port ID
- *
- * @return None
- */
-struct bfa_fcs_rport_s *
-bfa_fcs_rport_create(struct bfa_fcs_port_s *port, u32 rpid)
-{
-       struct bfa_fcs_rport_s *rport;
-
-       bfa_trc(port->fcs, rpid);
-       rport = bfa_fcs_rport_alloc(port, WWN_NULL, rpid);
-       if (!rport)
-               return NULL;
-
-       bfa_sm_send_event(rport, RPSM_EVENT_PLOGI_SEND);
-       return rport;
-}
-
-/**
- * Called to create a rport for which only the wwn is known.
- *
- * @param[in] port     - base port
- * @param[in] rpwwn    - remote port wwn
- *
- * @return None
- */
-struct bfa_fcs_rport_s *
-bfa_fcs_rport_create_by_wwn(struct bfa_fcs_port_s *port, wwn_t rpwwn)
-{
-       struct bfa_fcs_rport_s *rport;
-
-       bfa_trc(port->fcs, rpwwn);
-       rport = bfa_fcs_rport_alloc(port, rpwwn, 0);
-       if (!rport)
-               return NULL;
-
-       bfa_sm_send_event(rport, RPSM_EVENT_ADDRESS_DISC);
-       return rport;
-}
-
-/**
- * Called by bport in private loop topology to indicate that a
- * rport has been discovered and plogi has been completed.
- *
- * @param[in] port     - base port or vport
- * @param[in] rpid     - remote port ID
- */
-void
-bfa_fcs_rport_start(struct bfa_fcs_port_s *port, struct fchs_s *fchs,
-                       struct fc_logi_s *plogi)
-{
-       struct bfa_fcs_rport_s *rport;
-
-       rport = bfa_fcs_rport_alloc(port, WWN_NULL, fchs->s_id);
-       if (!rport)
-               return;
-
-       bfa_fcs_rport_update(rport, plogi);
-
-       bfa_sm_send_event(rport, RPSM_EVENT_PLOGI_COMP);
-}
-
-/**
- *   Called by bport/vport to handle PLOGI received from a new remote port.
- *   If an existing rport does a plogi, it will be handled separately.
- */
-void
-bfa_fcs_rport_plogi_create(struct bfa_fcs_port_s *port, struct fchs_s *fchs,
-                          struct fc_logi_s *plogi)
-{
-       struct bfa_fcs_rport_s *rport;
-
-       rport = bfa_fcs_rport_alloc(port, plogi->port_name, fchs->s_id);
-       if (!rport)
-               return;
-
-       bfa_fcs_rport_update(rport, plogi);
-
-       rport->reply_oxid = fchs->ox_id;
-       bfa_trc(rport->fcs, rport->reply_oxid);
-
-       rport->stats.plogi_rcvd++;
-       bfa_sm_send_event(rport, RPSM_EVENT_PLOGI_RCVD);
-}
-
-static int
-wwn_compare(wwn_t wwn1, wwn_t wwn2)
-{
-       u8        *b1 = (u8 *) &wwn1;
-       u8        *b2 = (u8 *) &wwn2;
-       int             i;
-
-       for (i = 0; i < sizeof(wwn_t); i++) {
-               if (b1[i] < b2[i])
-                       return -1;
-               if (b1[i] > b2[i])
-                       return 1;
-       }
-       return 0;
-}
-
-/**
- *   Called by bport/vport to handle PLOGI received from an existing
- *      remote port.
- */
-void
-bfa_fcs_rport_plogi(struct bfa_fcs_rport_s *rport, struct fchs_s *rx_fchs,
-                   struct fc_logi_s *plogi)
-{
-       /**
-        * @todo Handle P2P and initiator-initiator.
-        */
-
-       bfa_fcs_rport_update(rport, plogi);
-
-       rport->reply_oxid = rx_fchs->ox_id;
-       bfa_trc(rport->fcs, rport->reply_oxid);
-
-       /**
-        * In Switched fabric topology,
-        * PLOGI to each other. If our pwwn is smaller, ignore it,
-        * if it is not a well known address.
-        * If the link topology is N2N,
-        * this Plogi should be accepted.
-        */
-       if ((wwn_compare(rport->port->port_cfg.pwwn, rport->pwwn) == -1)
-           && (bfa_fcs_fabric_is_switched(rport->port->fabric))
-           && (!BFA_FCS_PID_IS_WKA(rport->pid))) {
-               bfa_trc(rport->fcs, rport->pid);
-               return;
-       }
-
-       rport->stats.plogi_rcvd++;
-       bfa_sm_send_event(rport, RPSM_EVENT_PLOGI_RCVD);
-}
-
-/**
- * Called by bport/vport to delete a remote port instance.
- *
-* Rport delete is called under the following conditions:
- *             - vport is deleted
- *             - vf is deleted
- *             - explicit request from OS to delete rport (vmware)
- */
-void
-bfa_fcs_rport_delete(struct bfa_fcs_rport_s *rport)
-{
-       bfa_sm_send_event(rport, RPSM_EVENT_DELETE);
-}
-
-/**
- * Called by bport/vport to  when a target goes offline.
- *
- */
-void
-bfa_fcs_rport_offline(struct bfa_fcs_rport_s *rport)
-{
-       bfa_sm_send_event(rport, RPSM_EVENT_LOGO_IMP);
-}
-
-/**
- * Called by bport in n2n when a target (attached port) becomes online.
- *
- */
-void
-bfa_fcs_rport_online(struct bfa_fcs_rport_s *rport)
-{
-       bfa_sm_send_event(rport, RPSM_EVENT_PLOGI_SEND);
-}
-
-/**
- *   Called by bport/vport to notify SCN for the remote port
- */
-void
-bfa_fcs_rport_scn(struct bfa_fcs_rport_s *rport)
-{
-
-       rport->stats.rscns++;
-       bfa_sm_send_event(rport, RPSM_EVENT_SCN);
-}
-
-/**
- *   Called by  fcpim to notify that the ITN cleanup is done.
- */
-void
-bfa_fcs_rport_itnim_ack(struct bfa_fcs_rport_s *rport)
-{
-       bfa_sm_send_event(rport, RPSM_EVENT_FC4_OFFLINE);
-}
-
-/**
- *   Called by fcptm to notify that the ITN cleanup is done.
- */
-void
-bfa_fcs_rport_tin_ack(struct bfa_fcs_rport_s *rport)
-{
-       bfa_sm_send_event(rport, RPSM_EVENT_FC4_OFFLINE);
-}
-
-/**
- *     This routine BFA callback for bfa_rport_online() call.
- *
- *     param[in]       cb_arg  -  rport struct.
- *
- *     return
- *             void
- *
-*      Special Considerations:
- *
- *     note
- */
-void
-bfa_cb_rport_online(void *cbarg)
-{
-
-       struct bfa_fcs_rport_s *rport = (struct bfa_fcs_rport_s *)cbarg;
-
-       bfa_trc(rport->fcs, rport->pwwn);
-       bfa_sm_send_event(rport, RPSM_EVENT_HCB_ONLINE);
-}
-
-/**
- *     This routine BFA callback for bfa_rport_offline() call.
- *
- *     param[in]       rport   -
- *
- *     return
- *             void
- *
- *     Special Considerations:
- *
- *     note
- */
-void
-bfa_cb_rport_offline(void *cbarg)
-{
-       struct bfa_fcs_rport_s *rport = (struct bfa_fcs_rport_s *)cbarg;
-
-       bfa_trc(rport->fcs, rport->pwwn);
-       bfa_sm_send_event(rport, RPSM_EVENT_HCB_OFFLINE);
-}
-
-/**
- * This routine is a static BFA callback when there is a QoS flow_id
- * change notification
- *
- * @param[in]  rport   -
- *
- * @return     void
- *
- * Special Considerations:
- *
- * @note
- */
-void
-bfa_cb_rport_qos_scn_flowid(void *cbarg,
-                           struct bfa_rport_qos_attr_s old_qos_attr,
-                           struct bfa_rport_qos_attr_s new_qos_attr)
-{
-       struct bfa_fcs_rport_s *rport = (struct bfa_fcs_rport_s *)cbarg;
-       struct bfa_rport_aen_data_s aen_data;
-
-       bfa_trc(rport->fcs, rport->pwwn);
-       aen_data.priv.qos = new_qos_attr;
-       bfa_fcs_rport_aen_post(rport, BFA_RPORT_AEN_QOS_FLOWID, &aen_data);
-}
-
-/**
- * This routine is a static BFA callback when there is a QoS priority
- * change notification
- *
- * @param[in]  rport   -
- *
- * @return     void
- *
- * Special Considerations:
- *
- * @note
- */
-void
-bfa_cb_rport_qos_scn_prio(void *cbarg, struct bfa_rport_qos_attr_s old_qos_attr,
-                         struct bfa_rport_qos_attr_s new_qos_attr)
-{
-       struct bfa_fcs_rport_s *rport = (struct bfa_fcs_rport_s *)cbarg;
-       struct bfa_rport_aen_data_s aen_data;
-
-       bfa_trc(rport->fcs, rport->pwwn);
-       aen_data.priv.qos = new_qos_attr;
-       bfa_fcs_rport_aen_post(rport, BFA_RPORT_AEN_QOS_PRIO, &aen_data);
-}
-
-/**
- *             Called to process any unsolicted frames from this remote port
- */
-void
-bfa_fcs_rport_logo_imp(struct bfa_fcs_rport_s *rport)
-{
-       bfa_sm_send_event(rport, RPSM_EVENT_LOGO_IMP);
-}
-
-/**
- *             Called to process any unsolicted frames from this remote port
- */
-void
-bfa_fcs_rport_uf_recv(struct bfa_fcs_rport_s *rport, struct fchs_s *fchs,
-                       u16 len)
-{
-       struct bfa_fcs_port_s *port = rport->port;
-       struct fc_els_cmd_s   *els_cmd;
-
-       bfa_trc(rport->fcs, fchs->s_id);
-       bfa_trc(rport->fcs, fchs->d_id);
-       bfa_trc(rport->fcs, fchs->type);
-
-       if (fchs->type != FC_TYPE_ELS)
-               return;
-
-       els_cmd = (struct fc_els_cmd_s *) (fchs + 1);
-
-       bfa_trc(rport->fcs, els_cmd->els_code);
-
-       switch (els_cmd->els_code) {
-       case FC_ELS_LOGO:
-               bfa_fcs_rport_process_logo(rport, fchs);
-               break;
-
-       case FC_ELS_ADISC:
-               bfa_fcs_rport_process_adisc(rport, fchs, len);
-               break;
-
-       case FC_ELS_PRLO:
-               if (bfa_fcs_port_is_initiator(port))
-                       bfa_fcs_fcpim_uf_recv(rport->itnim, fchs, len);
-
-               if (bfa_fcs_port_is_target(port))
-                       bfa_fcs_fcptm_uf_recv(rport->tin, fchs, len);
-               break;
-
-       case FC_ELS_PRLI:
-               bfa_fcs_rport_process_prli(rport, fchs, len);
-               break;
-
-       case FC_ELS_RPSC:
-               bfa_fcs_rport_process_rpsc(rport, fchs, len);
-               break;
-
-       default:
-               bfa_fcs_rport_send_ls_rjt(rport, fchs,
-                                         FC_LS_RJT_RSN_CMD_NOT_SUPP,
-                                         FC_LS_RJT_EXP_NO_ADDL_INFO);
-               break;
-       }
-}
-
-/* Send best case acc to prlo */
-static void
-bfa_fcs_rport_send_prlo_acc(struct bfa_fcs_rport_s *rport)
-{
-       struct bfa_fcs_port_s *port = rport->port;
-       struct fchs_s fchs;
-       struct bfa_fcxp_s *fcxp;
-       int len;
-
-       bfa_trc(rport->fcs, rport->pid);
-
-       fcxp = bfa_fcs_fcxp_alloc(port->fcs);
-       if (!fcxp)
-               return;
-
-       len = fc_prlo_acc_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
-                       rport->pid, bfa_fcs_port_get_fcid(port),
-                       rport->reply_oxid, 0);
-
-       bfa_fcxp_send(fcxp, rport->bfa_rport, port->fabric->vf_id,
-                       port->lp_tag, BFA_FALSE, FC_CLASS_3, len, &fchs,
-                       NULL, NULL, FC_MAX_PDUSZ, 0);
-}
-
-/*
- * Send a LS reject
- */
-static void
-bfa_fcs_rport_send_ls_rjt(struct bfa_fcs_rport_s *rport, struct fchs_s *rx_fchs,
-                         u8 reason_code, u8 reason_code_expl)
-{
-       struct bfa_fcs_port_s *port = rport->port;
-       struct fchs_s          fchs;
-       struct bfa_fcxp_s *fcxp;
-       int             len;
-
-       bfa_trc(rport->fcs, rx_fchs->s_id);
-
-       fcxp = bfa_fcs_fcxp_alloc(rport->fcs);
-       if (!fcxp)
-               return;
-
-       len = fc_ls_rjt_build(&fchs, bfa_fcxp_get_reqbuf(fcxp), rx_fchs->s_id,
-                             bfa_fcs_port_get_fcid(port), rx_fchs->ox_id,
-                             reason_code, reason_code_expl);
-
-       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
-                     FC_CLASS_3, len, &fchs, NULL, NULL, FC_MAX_PDUSZ, 0);
-}
-
-/**
- * Return state of rport.
- */
-int
-bfa_fcs_rport_get_state(struct bfa_fcs_rport_s *rport)
-{
-       return bfa_sm_to_state(rport_sm_table, rport->sm);
-}
-
-/**
- *              Called by the Driver to set rport delete/ageout timeout
- *
- *     param[in]               rport timeout value in seconds.
- *
- *     return None
- */
-void
-bfa_fcs_rport_set_del_timeout(u8 rport_tmo)
-{
-       /*
-        * convert to Millisecs
-        */
-       if (rport_tmo > 0)
-               bfa_fcs_rport_del_timeout = rport_tmo * 1000;
-}
-
-void
-bfa_fcs_rport_prlo(struct bfa_fcs_rport_s *rport, uint16_t ox_id)
-{
-       bfa_trc(rport->fcs, rport->pid);
-
-       rport->prlo = BFA_TRUE;
-       rport->reply_oxid = ox_id;
-       bfa_sm_send_event(rport, RPSM_EVENT_PRLO_RCVD);
-}
diff --git a/drivers/scsi/bfa/rport_api.c b/drivers/scsi/bfa/rport_api.c
deleted file mode 100644 (file)
index 15e0c47..0000000
+++ /dev/null
@@ -1,185 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-#include <bfa.h>
-#include <bfa_svc.h>
-#include "fcs_vport.h"
-#include "fcs_lport.h"
-#include "fcs_rport.h"
-#include "fcs_trcmod.h"
-
-BFA_TRC_FILE(FCS, RPORT_API);
-
-/**
- *  rport_api.c Remote port implementation.
- */
-
-/**
- *  fcs_rport_api FCS rport API.
- */
-
-/**
- *     Direct API to add a target by port wwn. This interface is used, for
- *     example, by bios when target pwwn is known from boot lun configuration.
- */
-bfa_status_t
-bfa_fcs_rport_add(struct bfa_fcs_port_s *port, wwn_t *pwwn,
-                       struct bfa_fcs_rport_s *rport,
-                       struct bfad_rport_s *rport_drv)
-{
-       bfa_trc(port->fcs, *pwwn);
-
-       return BFA_STATUS_OK;
-}
-
-/**
- *     Direct API to remove a target and its associated resources. This
- *     interface is used, for example, by vmware driver to remove target
- *     ports from the target list for a VM.
- */
-bfa_status_t
-bfa_fcs_rport_remove(struct bfa_fcs_rport_s *rport_in)
-{
-
-       struct bfa_fcs_rport_s *rport;
-
-       bfa_trc(rport_in->fcs, rport_in->pwwn);
-
-       rport = bfa_fcs_port_get_rport_by_pwwn(rport_in->port, rport_in->pwwn);
-       if (rport == NULL) {
-               /*
-                * TBD Error handling
-                */
-               bfa_trc(rport_in->fcs, rport_in->pid);
-               return BFA_STATUS_UNKNOWN_RWWN;
-       }
-
-       /*
-        * TBD if this remote port is online, send a logo
-        */
-       return BFA_STATUS_OK;
-
-}
-
-/**
- *     Remote device status for display/debug.
- */
-void
-bfa_fcs_rport_get_attr(struct bfa_fcs_rport_s *rport,
-                       struct bfa_rport_attr_s *rport_attr)
-{
-       struct bfa_rport_qos_attr_s qos_attr;
-       struct bfa_fcs_port_s *port = rport->port;
-       enum bfa_pport_speed rport_speed = rport->rpf.rpsc_speed;
-
-       bfa_os_memset(rport_attr, 0, sizeof(struct bfa_rport_attr_s));
-
-       rport_attr->pid = rport->pid;
-       rport_attr->pwwn = rport->pwwn;
-       rport_attr->nwwn = rport->nwwn;
-       rport_attr->cos_supported = rport->fc_cos;
-       rport_attr->df_sz = rport->maxfrsize;
-       rport_attr->state = bfa_fcs_rport_get_state(rport);
-       rport_attr->fc_cos = rport->fc_cos;
-       rport_attr->cisc = rport->cisc;
-       rport_attr->scsi_function = rport->scsi_function;
-       rport_attr->curr_speed  = rport->rpf.rpsc_speed;
-       rport_attr->assigned_speed  = rport->rpf.assigned_speed;
-
-       bfa_rport_get_qos_attr(rport->bfa_rport, &qos_attr);
-       rport_attr->qos_attr = qos_attr;
-
-       rport_attr->trl_enforced = BFA_FALSE;
-
-       if (bfa_fcport_is_ratelim(port->fcs->bfa)) {
-               if (rport_speed == BFA_PPORT_SPEED_UNKNOWN) {
-                       /* Use default ratelim speed setting */
-                       rport_speed =
-                               bfa_fcport_get_ratelim_speed(rport->fcs->bfa);
-               }
-               if (rport_speed < bfa_fcs_port_get_rport_max_speed(port))
-                       rport_attr->trl_enforced = BFA_TRUE;
-       }
-
-       /*
-        * TODO
-        * rport->symname
-        */
-}
-
-/**
- *     Per remote device statistics.
- */
-void
-bfa_fcs_rport_get_stats(struct bfa_fcs_rport_s *rport,
-                       struct bfa_rport_stats_s *stats)
-{
-       *stats = rport->stats;
-}
-
-void
-bfa_fcs_rport_clear_stats(struct bfa_fcs_rport_s *rport)
-{
-       bfa_os_memset((char *)&rport->stats, 0,
-                       sizeof(struct bfa_rport_stats_s));
-}
-
-struct bfa_fcs_rport_s *
-bfa_fcs_rport_lookup(struct bfa_fcs_port_s *port, wwn_t rpwwn)
-{
-       struct bfa_fcs_rport_s *rport;
-
-       rport = bfa_fcs_port_get_rport_by_pwwn(port, rpwwn);
-       if (rport == NULL) {
-               /*
-                * TBD Error handling
-                */
-       }
-
-       return rport;
-}
-
-struct bfa_fcs_rport_s *
-bfa_fcs_rport_lookup_by_nwwn(struct bfa_fcs_port_s *port, wwn_t rnwwn)
-{
-       struct bfa_fcs_rport_s *rport;
-
-       rport = bfa_fcs_port_get_rport_by_nwwn(port, rnwwn);
-       if (rport == NULL) {
-               /*
-                * TBD Error handling
-                */
-       }
-
-       return rport;
-}
-
-/*
- * This API is to set the Rport's speed. Should be used when RPSC is not
- * supported by the rport.
- */
-void
-bfa_fcs_rport_set_speed(struct bfa_fcs_rport_s *rport,
-                       enum bfa_pport_speed speed)
-{
-       rport->rpf.assigned_speed  = speed;
-
-       /* Set this speed in f/w only if the RPSC speed is not available */
-       if (rport->rpf.rpsc_speed == BFA_PPORT_SPEED_UNKNOWN)
-               bfa_rport_speed(rport->bfa_rport, speed);
-}
-
-
diff --git a/drivers/scsi/bfa/rport_ftrs.c b/drivers/scsi/bfa/rport_ftrs.c
deleted file mode 100644 (file)
index f2a9361..0000000
+++ /dev/null
@@ -1,379 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  rport_ftrs.c Remote port features (RPF) implementation.
- */
-
-#include <bfa.h>
-#include <bfa_svc.h>
-#include "fcbuild.h"
-#include "fcs_rport.h"
-#include "fcs_lport.h"
-#include "fcs_trcmod.h"
-#include "fcs_fcxp.h"
-#include "fcs.h"
-
-BFA_TRC_FILE(FCS, RPORT_FTRS);
-
-#define BFA_FCS_RPF_RETRIES    (3)
-#define BFA_FCS_RPF_RETRY_TIMEOUT  (1000) /* 1 sec (In millisecs) */
-
-static void     bfa_fcs_rpf_send_rpsc2(void *rport_cbarg,
-                       struct bfa_fcxp_s *fcxp_alloced);
-static void     bfa_fcs_rpf_rpsc2_response(void *fcsarg,
-                       struct bfa_fcxp_s *fcxp, void *cbarg,
-                       bfa_status_t req_status, u32 rsp_len,
-                       u32 resid_len,
-                       struct fchs_s *rsp_fchs);
-static void     bfa_fcs_rpf_timeout(void *arg);
-
-/**
- *  fcs_rport_ftrs_sm FCS rport state machine events
- */
-
-enum rpf_event {
-       RPFSM_EVENT_RPORT_OFFLINE  = 1,     /*  Rport offline            */
-       RPFSM_EVENT_RPORT_ONLINE   = 2,     /*  Rport online            */
-       RPFSM_EVENT_FCXP_SENT      = 3,    /*  Frame from has been sent */
-       RPFSM_EVENT_TIMEOUT        = 4,    /*  Rport SM timeout event   */
-       RPFSM_EVENT_RPSC_COMP      = 5,
-       RPFSM_EVENT_RPSC_FAIL      = 6,
-       RPFSM_EVENT_RPSC_ERROR     = 7,
-};
-
-static void    bfa_fcs_rpf_sm_uninit(struct bfa_fcs_rpf_s *rpf,
-                                       enum rpf_event event);
-static void     bfa_fcs_rpf_sm_rpsc_sending(struct bfa_fcs_rpf_s *rpf,
-                                              enum rpf_event event);
-static void     bfa_fcs_rpf_sm_rpsc(struct bfa_fcs_rpf_s *rpf,
-                                              enum rpf_event event);
-static void    bfa_fcs_rpf_sm_rpsc_retry(struct bfa_fcs_rpf_s *rpf,
-                                                       enum rpf_event event);
-static void     bfa_fcs_rpf_sm_offline(struct bfa_fcs_rpf_s *rpf,
-                                                       enum rpf_event event);
-static void     bfa_fcs_rpf_sm_online(struct bfa_fcs_rpf_s *rpf,
-                                                       enum rpf_event event);
-
-static void
-bfa_fcs_rpf_sm_uninit(struct bfa_fcs_rpf_s *rpf, enum rpf_event event)
-{
-       struct bfa_fcs_rport_s *rport = rpf->rport;
-       struct bfa_fcs_fabric_s *fabric = &rport->fcs->fabric;
-
-       bfa_trc(rport->fcs, rport->pwwn);
-       bfa_trc(rport->fcs, rport->pid);
-       bfa_trc(rport->fcs, event);
-
-       switch (event) {
-       case RPFSM_EVENT_RPORT_ONLINE:
-               /* Send RPSC2 to a Brocade fabric only. */
-               if ((!BFA_FCS_PID_IS_WKA(rport->pid)) &&
-                       ((bfa_lps_is_brcd_fabric(rport->port->fabric->lps)) ||
-                       (bfa_fcs_fabric_get_switch_oui(fabric) ==
-                                               BFA_FCS_BRCD_SWITCH_OUI))) {
-                       bfa_sm_set_state(rpf, bfa_fcs_rpf_sm_rpsc_sending);
-                       rpf->rpsc_retries = 0;
-                       bfa_fcs_rpf_send_rpsc2(rpf, NULL);
-               }
-               break;
-
-       case RPFSM_EVENT_RPORT_OFFLINE:
-               break;
-
-       default:
-               bfa_sm_fault(rport->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_rpf_sm_rpsc_sending(struct bfa_fcs_rpf_s *rpf, enum rpf_event event)
-{
-       struct bfa_fcs_rport_s *rport = rpf->rport;
-
-       bfa_trc(rport->fcs, event);
-
-       switch (event) {
-       case RPFSM_EVENT_FCXP_SENT:
-               bfa_sm_set_state(rpf, bfa_fcs_rpf_sm_rpsc);
-               break;
-
-       case RPFSM_EVENT_RPORT_OFFLINE:
-               bfa_sm_set_state(rpf, bfa_fcs_rpf_sm_offline);
-               bfa_fcxp_walloc_cancel(rport->fcs->bfa, &rpf->fcxp_wqe);
-               rpf->rpsc_retries = 0;
-               break;
-
-       default:
-               bfa_sm_fault(rport->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_rpf_sm_rpsc(struct bfa_fcs_rpf_s *rpf, enum rpf_event event)
-{
-       struct bfa_fcs_rport_s *rport = rpf->rport;
-
-       bfa_trc(rport->fcs, rport->pid);
-       bfa_trc(rport->fcs, event);
-
-       switch (event) {
-       case RPFSM_EVENT_RPSC_COMP:
-               bfa_sm_set_state(rpf, bfa_fcs_rpf_sm_online);
-               /* Update speed info in f/w via BFA */
-               if (rpf->rpsc_speed != BFA_PPORT_SPEED_UNKNOWN)
-                       bfa_rport_speed(rport->bfa_rport, rpf->rpsc_speed);
-               else if (rpf->assigned_speed != BFA_PPORT_SPEED_UNKNOWN)
-                       bfa_rport_speed(rport->bfa_rport, rpf->assigned_speed);
-               break;
-
-       case RPFSM_EVENT_RPSC_FAIL:
-               /* RPSC not supported by rport */
-               bfa_sm_set_state(rpf, bfa_fcs_rpf_sm_online);
-               break;
-
-       case RPFSM_EVENT_RPSC_ERROR:
-               /* need to retry...delayed a bit. */
-               if (rpf->rpsc_retries++ < BFA_FCS_RPF_RETRIES) {
-                       bfa_timer_start(rport->fcs->bfa, &rpf->timer,
-                                   bfa_fcs_rpf_timeout, rpf,
-                                   BFA_FCS_RPF_RETRY_TIMEOUT);
-                       bfa_sm_set_state(rpf, bfa_fcs_rpf_sm_rpsc_retry);
-               } else {
-                       bfa_sm_set_state(rpf, bfa_fcs_rpf_sm_online);
-               }
-               break;
-
-       case RPFSM_EVENT_RPORT_OFFLINE:
-               bfa_sm_set_state(rpf, bfa_fcs_rpf_sm_offline);
-               bfa_fcxp_discard(rpf->fcxp);
-               rpf->rpsc_retries = 0;
-               break;
-
-       default:
-               bfa_sm_fault(rport->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_rpf_sm_rpsc_retry(struct bfa_fcs_rpf_s *rpf, enum rpf_event event)
-{
-       struct bfa_fcs_rport_s *rport = rpf->rport;
-
-       bfa_trc(rport->fcs, rport->pid);
-       bfa_trc(rport->fcs, event);
-
-       switch (event) {
-       case RPFSM_EVENT_TIMEOUT:
-               /* re-send the RPSC */
-               bfa_sm_set_state(rpf, bfa_fcs_rpf_sm_rpsc_sending);
-               bfa_fcs_rpf_send_rpsc2(rpf, NULL);
-               break;
-
-       case RPFSM_EVENT_RPORT_OFFLINE:
-               bfa_timer_stop(&rpf->timer);
-               bfa_sm_set_state(rpf, bfa_fcs_rpf_sm_offline);
-               rpf->rpsc_retries = 0;
-               break;
-
-       default:
-               bfa_sm_fault(rport->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_rpf_sm_online(struct bfa_fcs_rpf_s *rpf, enum rpf_event event)
-{
-       struct bfa_fcs_rport_s *rport = rpf->rport;
-
-       bfa_trc(rport->fcs, rport->pwwn);
-       bfa_trc(rport->fcs, rport->pid);
-       bfa_trc(rport->fcs, event);
-
-       switch (event) {
-       case RPFSM_EVENT_RPORT_OFFLINE:
-               bfa_sm_set_state(rpf, bfa_fcs_rpf_sm_offline);
-               rpf->rpsc_retries = 0;
-               break;
-
-       default:
-               bfa_sm_fault(rport->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_rpf_sm_offline(struct bfa_fcs_rpf_s *rpf, enum rpf_event event)
-{
-       struct bfa_fcs_rport_s *rport = rpf->rport;
-
-       bfa_trc(rport->fcs, rport->pwwn);
-       bfa_trc(rport->fcs, rport->pid);
-       bfa_trc(rport->fcs, event);
-
-       switch (event) {
-       case RPFSM_EVENT_RPORT_ONLINE:
-               bfa_sm_set_state(rpf, bfa_fcs_rpf_sm_rpsc_sending);
-               bfa_fcs_rpf_send_rpsc2(rpf, NULL);
-               break;
-
-       case RPFSM_EVENT_RPORT_OFFLINE:
-               break;
-
-       default:
-               bfa_sm_fault(rport->fcs, event);
-       }
-}
-/**
- * Called when Rport is created.
- */
-void  bfa_fcs_rpf_init(struct bfa_fcs_rport_s *rport)
-{
-       struct bfa_fcs_rpf_s *rpf = &rport->rpf;
-
-       bfa_trc(rport->fcs, rport->pid);
-       rpf->rport = rport;
-
-       bfa_sm_set_state(rpf, bfa_fcs_rpf_sm_uninit);
-}
-
-/**
- * Called when Rport becomes online
- */
-void  bfa_fcs_rpf_rport_online(struct bfa_fcs_rport_s *rport)
-{
-       bfa_trc(rport->fcs, rport->pid);
-
-       if (__fcs_min_cfg(rport->port->fcs))
-               return;
-
-       if (bfa_fcs_fabric_is_switched(rport->port->fabric))
-               bfa_sm_send_event(&rport->rpf, RPFSM_EVENT_RPORT_ONLINE);
-}
-
-/**
- * Called when Rport becomes offline
- */
-void  bfa_fcs_rpf_rport_offline(struct bfa_fcs_rport_s *rport)
-{
-       bfa_trc(rport->fcs, rport->pid);
-
-       if (__fcs_min_cfg(rport->port->fcs))
-               return;
-
-       rport->rpf.rpsc_speed = 0;
-       bfa_sm_send_event(&rport->rpf, RPFSM_EVENT_RPORT_OFFLINE);
-}
-
-static void
-bfa_fcs_rpf_timeout(void *arg)
-{
-       struct bfa_fcs_rpf_s *rpf = (struct bfa_fcs_rpf_s *) arg;
-       struct bfa_fcs_rport_s *rport = rpf->rport;
-
-       bfa_trc(rport->fcs, rport->pid);
-       bfa_sm_send_event(rpf, RPFSM_EVENT_TIMEOUT);
-}
-
-static void
-bfa_fcs_rpf_send_rpsc2(void *rpf_cbarg, struct bfa_fcxp_s *fcxp_alloced)
-{
-       struct bfa_fcs_rpf_s *rpf       = (struct bfa_fcs_rpf_s *)rpf_cbarg;
-       struct bfa_fcs_rport_s *rport = rpf->rport;
-       struct bfa_fcs_port_s *port = rport->port;
-       struct fchs_s          fchs;
-       int             len;
-       struct bfa_fcxp_s *fcxp;
-
-       bfa_trc(rport->fcs, rport->pwwn);
-
-       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
-       if (!fcxp) {
-               bfa_fcxp_alloc_wait(port->fcs->bfa, &rpf->fcxp_wqe,
-                                       bfa_fcs_rpf_send_rpsc2, rpf);
-               return;
-       }
-       rpf->fcxp = fcxp;
-
-       len = fc_rpsc2_build(&fchs, bfa_fcxp_get_reqbuf(fcxp), rport->pid,
-                           bfa_fcs_port_get_fcid(port), &rport->pid, 1);
-
-       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
-                         FC_CLASS_3, len, &fchs, bfa_fcs_rpf_rpsc2_response,
-                         rpf, FC_MAX_PDUSZ, FC_ELS_TOV);
-       rport->stats.rpsc_sent++;
-       bfa_sm_send_event(rpf, RPFSM_EVENT_FCXP_SENT);
-
-}
-
-static void
-bfa_fcs_rpf_rpsc2_response(void *fcsarg, struct bfa_fcxp_s *fcxp, void *cbarg,
-                           bfa_status_t req_status, u32 rsp_len,
-                           u32 resid_len, struct fchs_s *rsp_fchs)
-{
-       struct bfa_fcs_rpf_s *rpf = (struct bfa_fcs_rpf_s *) cbarg;
-       struct bfa_fcs_rport_s *rport = rpf->rport;
-       struct fc_ls_rjt_s    *ls_rjt;
-       struct fc_rpsc2_acc_s  *rpsc2_acc;
-       u16        num_ents;
-
-       bfa_trc(rport->fcs, req_status);
-
-       if (req_status != BFA_STATUS_OK) {
-               bfa_trc(rport->fcs, req_status);
-               if (req_status == BFA_STATUS_ETIMER)
-                       rport->stats.rpsc_failed++;
-               bfa_sm_send_event(rpf, RPFSM_EVENT_RPSC_ERROR);
-               return;
-       }
-
-       rpsc2_acc = (struct fc_rpsc2_acc_s *) BFA_FCXP_RSP_PLD(fcxp);
-       if (rpsc2_acc->els_cmd == FC_ELS_ACC) {
-               rport->stats.rpsc_accs++;
-               num_ents = bfa_os_ntohs(rpsc2_acc->num_pids);
-               bfa_trc(rport->fcs, num_ents);
-               if (num_ents > 0) {
-                       bfa_assert(rpsc2_acc->port_info[0].pid != rport->pid);
-                       bfa_trc(rport->fcs,
-                               bfa_os_ntohs(rpsc2_acc->port_info[0].pid));
-                       bfa_trc(rport->fcs,
-                               bfa_os_ntohs(rpsc2_acc->port_info[0].speed));
-                       bfa_trc(rport->fcs,
-                               bfa_os_ntohs(rpsc2_acc->port_info[0].index));
-                       bfa_trc(rport->fcs,
-                               rpsc2_acc->port_info[0].type);
-
-                       if (rpsc2_acc->port_info[0].speed == 0) {
-                               bfa_sm_send_event(rpf, RPFSM_EVENT_RPSC_ERROR);
-                               return;
-                       }
-
-                       rpf->rpsc_speed = fc_rpsc_operspeed_to_bfa_speed(
-                               bfa_os_ntohs(rpsc2_acc->port_info[0].speed));
-
-                       bfa_sm_send_event(rpf, RPFSM_EVENT_RPSC_COMP);
-               }
-       } else {
-               ls_rjt = (struct fc_ls_rjt_s *) BFA_FCXP_RSP_PLD(fcxp);
-               bfa_trc(rport->fcs, ls_rjt->reason_code);
-               bfa_trc(rport->fcs, ls_rjt->reason_code_expl);
-               rport->stats.rpsc_rejects++;
-               if (ls_rjt->reason_code == FC_LS_RJT_RSN_CMD_NOT_SUPP)
-                       bfa_sm_send_event(rpf, RPFSM_EVENT_RPSC_FAIL);
-               else
-                       bfa_sm_send_event(rpf, RPFSM_EVENT_RPSC_ERROR);
-       }
-}
diff --git a/drivers/scsi/bfa/scn.c b/drivers/scsi/bfa/scn.c
deleted file mode 100644 (file)
index 8a60129..0000000
+++ /dev/null
@@ -1,482 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-#include <bfa.h>
-#include <bfa_svc.h>
-#include "fcs_lport.h"
-#include "fcs_rport.h"
-#include "fcs_ms.h"
-#include "fcs_trcmod.h"
-#include "fcs_fcxp.h"
-#include "fcs.h"
-#include "lport_priv.h"
-
-BFA_TRC_FILE(FCS, SCN);
-
-#define FC_QOS_RSCN_EVENT              0x0c
-#define FC_FABRIC_NAME_RSCN_EVENT      0x0d
-
-/*
- * forward declarations
- */
-static void     bfa_fcs_port_scn_send_scr(void *scn_cbarg,
-                                         struct bfa_fcxp_s *fcxp_alloced);
-static void     bfa_fcs_port_scn_scr_response(void *fcsarg,
-                                             struct bfa_fcxp_s *fcxp,
-                                             void *cbarg,
-                                             bfa_status_t req_status,
-                                             u32 rsp_len,
-                                             u32 resid_len,
-                                             struct fchs_s *rsp_fchs);
-static void     bfa_fcs_port_scn_send_ls_acc(struct bfa_fcs_port_s *port,
-                                            struct fchs_s *rx_fchs);
-static void     bfa_fcs_port_scn_timeout(void *arg);
-
-/**
- *  fcs_scm_sm FCS SCN state machine
- */
-
-/**
- * VPort SCN State Machine events
- */
-enum port_scn_event {
-       SCNSM_EVENT_PORT_ONLINE = 1,
-       SCNSM_EVENT_PORT_OFFLINE = 2,
-       SCNSM_EVENT_RSP_OK = 3,
-       SCNSM_EVENT_RSP_ERROR = 4,
-       SCNSM_EVENT_TIMEOUT = 5,
-       SCNSM_EVENT_SCR_SENT = 6,
-};
-
-static void     bfa_fcs_port_scn_sm_offline(struct bfa_fcs_port_scn_s *scn,
-                                           enum port_scn_event event);
-static void     bfa_fcs_port_scn_sm_sending_scr(struct bfa_fcs_port_scn_s *scn,
-                                               enum port_scn_event event);
-static void     bfa_fcs_port_scn_sm_scr(struct bfa_fcs_port_scn_s *scn,
-                                       enum port_scn_event event);
-static void     bfa_fcs_port_scn_sm_scr_retry(struct bfa_fcs_port_scn_s *scn,
-                                             enum port_scn_event event);
-static void     bfa_fcs_port_scn_sm_online(struct bfa_fcs_port_scn_s *scn,
-                                          enum port_scn_event event);
-
-/**
- *             Starting state - awaiting link up.
- */
-static void
-bfa_fcs_port_scn_sm_offline(struct bfa_fcs_port_scn_s *scn,
-                           enum port_scn_event event)
-{
-       switch (event) {
-       case SCNSM_EVENT_PORT_ONLINE:
-               bfa_sm_set_state(scn, bfa_fcs_port_scn_sm_sending_scr);
-               bfa_fcs_port_scn_send_scr(scn, NULL);
-               break;
-
-       case SCNSM_EVENT_PORT_OFFLINE:
-               break;
-
-       default:
-               bfa_sm_fault(scn->port->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_port_scn_sm_sending_scr(struct bfa_fcs_port_scn_s *scn,
-                               enum port_scn_event event)
-{
-       switch (event) {
-       case SCNSM_EVENT_SCR_SENT:
-               bfa_sm_set_state(scn, bfa_fcs_port_scn_sm_scr);
-               break;
-
-       case SCNSM_EVENT_PORT_OFFLINE:
-               bfa_sm_set_state(scn, bfa_fcs_port_scn_sm_offline);
-               bfa_fcxp_walloc_cancel(scn->port->fcs->bfa, &scn->fcxp_wqe);
-               break;
-
-       default:
-               bfa_sm_fault(scn->port->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_port_scn_sm_scr(struct bfa_fcs_port_scn_s *scn,
-                       enum port_scn_event event)
-{
-       struct bfa_fcs_port_s *port = scn->port;
-
-       switch (event) {
-       case SCNSM_EVENT_RSP_OK:
-               bfa_sm_set_state(scn, bfa_fcs_port_scn_sm_online);
-               break;
-
-       case SCNSM_EVENT_RSP_ERROR:
-               bfa_sm_set_state(scn, bfa_fcs_port_scn_sm_scr_retry);
-               bfa_timer_start(port->fcs->bfa, &scn->timer,
-                               bfa_fcs_port_scn_timeout, scn,
-                               BFA_FCS_RETRY_TIMEOUT);
-               break;
-
-       case SCNSM_EVENT_PORT_OFFLINE:
-               bfa_sm_set_state(scn, bfa_fcs_port_scn_sm_offline);
-               bfa_fcxp_discard(scn->fcxp);
-               break;
-
-       default:
-               bfa_sm_fault(scn->port->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_port_scn_sm_scr_retry(struct bfa_fcs_port_scn_s *scn,
-                             enum port_scn_event event)
-{
-       switch (event) {
-       case SCNSM_EVENT_TIMEOUT:
-               bfa_sm_set_state(scn, bfa_fcs_port_scn_sm_sending_scr);
-               bfa_fcs_port_scn_send_scr(scn, NULL);
-               break;
-
-       case SCNSM_EVENT_PORT_OFFLINE:
-               bfa_sm_set_state(scn, bfa_fcs_port_scn_sm_offline);
-               bfa_timer_stop(&scn->timer);
-               break;
-
-       default:
-               bfa_sm_fault(scn->port->fcs, event);
-       }
-}
-
-static void
-bfa_fcs_port_scn_sm_online(struct bfa_fcs_port_scn_s *scn,
-                          enum port_scn_event event)
-{
-       switch (event) {
-       case SCNSM_EVENT_PORT_OFFLINE:
-               bfa_sm_set_state(scn, bfa_fcs_port_scn_sm_offline);
-               break;
-
-       default:
-               bfa_sm_fault(scn->port->fcs, event);
-       }
-}
-
-
-
-/**
- *  fcs_scn_private FCS SCN private functions
- */
-
-/**
- * This routine will be called to send a SCR command.
- */
-static void
-bfa_fcs_port_scn_send_scr(void *scn_cbarg, struct bfa_fcxp_s *fcxp_alloced)
-{
-       struct bfa_fcs_port_scn_s *scn = scn_cbarg;
-       struct bfa_fcs_port_s *port = scn->port;
-       struct fchs_s          fchs;
-       int             len;
-       struct bfa_fcxp_s *fcxp;
-
-       bfa_trc(port->fcs, port->pid);
-       bfa_trc(port->fcs, port->port_cfg.pwwn);
-
-       fcxp = fcxp_alloced ? fcxp_alloced : bfa_fcs_fcxp_alloc(port->fcs);
-       if (!fcxp) {
-               bfa_fcxp_alloc_wait(port->fcs->bfa, &scn->fcxp_wqe,
-                                   bfa_fcs_port_scn_send_scr, scn);
-               return;
-       }
-       scn->fcxp = fcxp;
-
-       /*
-        * Handle VU registrations for Base port only
-        */
-       if ((!port->vport) && bfa_ioc_get_fcmode(&port->fcs->bfa->ioc)) {
-               len = fc_scr_build(&fchs, bfa_fcxp_get_reqbuf(fcxp),
-                                  bfa_lps_is_brcd_fabric(port->fabric->lps),
-                                  port->pid, 0);
-       } else {
-               len = fc_scr_build(&fchs, bfa_fcxp_get_reqbuf(fcxp), BFA_FALSE,
-                                  port->pid, 0);
-       }
-
-       bfa_fcxp_send(fcxp, NULL, port->fabric->vf_id, port->lp_tag, BFA_FALSE,
-                     FC_CLASS_3, len, &fchs, bfa_fcs_port_scn_scr_response,
-                     (void *)scn, FC_MAX_PDUSZ, FC_ELS_TOV);
-
-       bfa_sm_send_event(scn, SCNSM_EVENT_SCR_SENT);
-}
-
-static void
-bfa_fcs_port_scn_scr_response(void *fcsarg, struct bfa_fcxp_s *fcxp,
-                             void *cbarg, bfa_status_t req_status,
-                             u32 rsp_len, u32 resid_len,
-                             struct fchs_s *rsp_fchs)
-{
-       struct bfa_fcs_port_scn_s *scn = (struct bfa_fcs_port_scn_s *)cbarg;
-       struct bfa_fcs_port_s *port = scn->port;
-       struct fc_els_cmd_s   *els_cmd;
-       struct fc_ls_rjt_s    *ls_rjt;
-
-       bfa_trc(port->fcs, port->port_cfg.pwwn);
-
-       /*
-        * Sanity Checks
-        */
-       if (req_status != BFA_STATUS_OK) {
-               bfa_trc(port->fcs, req_status);
-               bfa_sm_send_event(scn, SCNSM_EVENT_RSP_ERROR);
-               return;
-       }
-
-       els_cmd = (struct fc_els_cmd_s *) BFA_FCXP_RSP_PLD(fcxp);
-
-       switch (els_cmd->els_code) {
-
-       case FC_ELS_ACC:
-               bfa_sm_send_event(scn, SCNSM_EVENT_RSP_OK);
-               break;
-
-       case FC_ELS_LS_RJT:
-
-               ls_rjt = (struct fc_ls_rjt_s *) BFA_FCXP_RSP_PLD(fcxp);
-
-               bfa_trc(port->fcs, ls_rjt->reason_code);
-               bfa_trc(port->fcs, ls_rjt->reason_code_expl);
-
-               bfa_sm_send_event(scn, SCNSM_EVENT_RSP_ERROR);
-               break;
-
-       default:
-               bfa_sm_send_event(scn, SCNSM_EVENT_RSP_ERROR);
-       }
-}
-
-/*
- * Send a LS Accept
- */
-static void
-bfa_fcs_port_scn_send_ls_acc(struct bfa_fcs_port_s *port,
-                       struct fchs_s *rx_fchs)
-{
-       struct fchs_s          fchs;
-       struct bfa_fcxp_s *fcxp;
-       struct bfa_rport_s *bfa_rport = NULL;
-       int             len;
-
-       bfa_trc(port->fcs, rx_fchs->s_id);
-
-       fcxp = bfa_fcs_fcxp_alloc(port->fcs);
-       if (!fcxp)
-               return;
-
-       len = fc_ls_acc_build(&fchs, bfa_fcxp_get_reqbuf(fcxp), rx_fchs->s_id,
-                             bfa_fcs_port_get_fcid(port), rx_fchs->ox_id);
-
-       bfa_fcxp_send(fcxp, bfa_rport, port->fabric->vf_id, port->lp_tag,
-                     BFA_FALSE, FC_CLASS_3, len, &fchs, NULL, NULL,
-                     FC_MAX_PDUSZ, 0);
-}
-
-/**
- *     This routine will be called by bfa_timer on timer timeouts.
- *
- *     param[in]       vport                   - pointer to bfa_fcs_port_t.
- *     param[out]      vport_status    - pointer to return vport status in
- *
- *     return
- *             void
- *
-*      Special Considerations:
- *
- *     note
- */
-static void
-bfa_fcs_port_scn_timeout(void *arg)
-{
-       struct bfa_fcs_port_scn_s *scn = (struct bfa_fcs_port_scn_s *)arg;
-
-       bfa_sm_send_event(scn, SCNSM_EVENT_TIMEOUT);
-}
-
-
-
-/**
- *  fcs_scn_public FCS state change notification public interfaces
- */
-
-/*
- * Functions called by port/fab
- */
-void
-bfa_fcs_port_scn_init(struct bfa_fcs_port_s *port)
-{
-       struct bfa_fcs_port_scn_s *scn = BFA_FCS_GET_SCN_FROM_PORT(port);
-
-       scn->port = port;
-       bfa_sm_set_state(scn, bfa_fcs_port_scn_sm_offline);
-}
-
-void
-bfa_fcs_port_scn_offline(struct bfa_fcs_port_s *port)
-{
-       struct bfa_fcs_port_scn_s *scn = BFA_FCS_GET_SCN_FROM_PORT(port);
-
-       scn->port = port;
-       bfa_sm_send_event(scn, SCNSM_EVENT_PORT_OFFLINE);
-}
-
-void
-bfa_fcs_port_scn_online(struct bfa_fcs_port_s *port)
-{
-       struct bfa_fcs_port_scn_s *scn = BFA_FCS_GET_SCN_FROM_PORT(port);
-
-       scn->port = port;
-       bfa_sm_send_event(scn, SCNSM_EVENT_PORT_ONLINE);
-}
-
-static void
-bfa_fcs_port_scn_portid_rscn(struct bfa_fcs_port_s *port, u32 rpid)
-{
-       struct bfa_fcs_rport_s *rport;
-
-       bfa_trc(port->fcs, rpid);
-
-       /**
-        * If this is an unknown device, then it just came online.
-        * Otherwise let rport handle the RSCN event.
-        */
-       rport = bfa_fcs_port_get_rport_by_pid(port, rpid);
-       if (rport == NULL) {
-               /*
-                * If min cfg mode is enabled, we donot need to
-                * discover any new rports.
-                */
-               if (!__fcs_min_cfg(port->fcs))
-                       rport = bfa_fcs_rport_create(port, rpid);
-       } else {
-               bfa_fcs_rport_scn(rport);
-       }
-}
-
-/**
- * rscn format based PID comparison
- */
-#define __fc_pid_match(__c0, __c1, __fmt)              \
-       (((__fmt) == FC_RSCN_FORMAT_FABRIC) ||          \
-        (((__fmt) == FC_RSCN_FORMAT_DOMAIN) &&         \
-         ((__c0)[0] == (__c1)[0])) ||                  \
-        (((__fmt) == FC_RSCN_FORMAT_AREA) &&           \
-         ((__c0)[0] == (__c1)[0]) &&                   \
-         ((__c0)[1] == (__c1)[1])))
-
-static void
-bfa_fcs_port_scn_multiport_rscn(struct bfa_fcs_port_s *port,
-                       enum fc_rscn_format format, u32 rscn_pid)
-{
-       struct bfa_fcs_rport_s *rport;
-       struct list_head *qe, *qe_next;
-       u8        *c0, *c1;
-
-       bfa_trc(port->fcs, format);
-       bfa_trc(port->fcs, rscn_pid);
-
-       c0 = (u8 *) &rscn_pid;
-
-       list_for_each_safe(qe, qe_next, &port->rport_q) {
-               rport = (struct bfa_fcs_rport_s *)qe;
-               c1 = (u8 *) &rport->pid;
-               if (__fc_pid_match(c0, c1, format))
-                       bfa_fcs_rport_scn(rport);
-       }
-}
-
-void
-bfa_fcs_port_scn_process_rscn(struct bfa_fcs_port_s *port, struct fchs_s *fchs,
-                             u32 len)
-{
-       struct fc_rscn_pl_s   *rscn = (struct fc_rscn_pl_s *) (fchs + 1);
-       int             num_entries;
-       u32        rscn_pid;
-       bfa_boolean_t   nsquery = BFA_FALSE;
-       int             i = 0;
-
-       num_entries =
-               (bfa_os_ntohs(rscn->payldlen) -
-                sizeof(u32)) / sizeof(rscn->event[0]);
-
-       bfa_trc(port->fcs, num_entries);
-
-       port->stats.num_rscn++;
-
-       bfa_fcs_port_scn_send_ls_acc(port, fchs);
-
-       for (i = 0; i < num_entries; i++) {
-               rscn_pid = rscn->event[i].portid;
-
-               bfa_trc(port->fcs, rscn->event[i].format);
-               bfa_trc(port->fcs, rscn_pid);
-
-               switch (rscn->event[i].format) {
-               case FC_RSCN_FORMAT_PORTID:
-                       if (rscn->event[i].qualifier == FC_QOS_RSCN_EVENT) {
-                               /*
-                                * Ignore this event. f/w would have processed
-                                * it
-                                */
-                               bfa_trc(port->fcs, rscn_pid);
-                       } else {
-                               port->stats.num_portid_rscn++;
-                               bfa_fcs_port_scn_portid_rscn(port, rscn_pid);
-                       }
-                       break;
-
-               case FC_RSCN_FORMAT_FABRIC:
-                       if (rscn->event[i].qualifier ==
-                           FC_FABRIC_NAME_RSCN_EVENT) {
-                               bfa_fcs_port_ms_fabric_rscn(port);
-                               break;
-                       }
-                       /*
-                        * !!!!!!!!! Fall Through !!!!!!!!!!!!!
-                        */
-
-               case FC_RSCN_FORMAT_AREA:
-               case FC_RSCN_FORMAT_DOMAIN:
-                       nsquery = BFA_TRUE;
-                       bfa_fcs_port_scn_multiport_rscn(port,
-                                                       rscn->event[i].format,
-                                                       rscn_pid);
-                       break;
-
-               default:
-                       bfa_assert(0);
-                       nsquery = BFA_TRUE;
-               }
-       }
-
-       /**
-        * If any of area, domain or fabric RSCN is received, do a fresh discovery
-        * to find new devices.
-        */
-       if (nsquery)
-               bfa_fcs_port_ns_query(port);
-}
-
-
diff --git a/drivers/scsi/bfa/vfapi.c b/drivers/scsi/bfa/vfapi.c
deleted file mode 100644 (file)
index 391a479..0000000
+++ /dev/null
@@ -1,292 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  vfapi.c Fabric module implementation.
- */
-
-#include "fcs_fabric.h"
-#include "fcs_trcmod.h"
-
-BFA_TRC_FILE(FCS, VFAPI);
-
-/**
- *  fcs_vf_api virtual fabrics API
- */
-
-/**
- *             Enable VF mode.
- *
- * @param[in]          fcs             fcs module instance
- * @param[in]          vf_id           default vf_id of port, FC_VF_ID_NULL
- *                                     to use standard default vf_id of 1.
- *
- * @retval     BFA_STATUS_OK           vf mode is enabled
- * @retval     BFA_STATUS_BUSY         Port is active. Port must be disabled
- *                                     before VF mode can be enabled.
- */
-bfa_status_t
-bfa_fcs_vf_mode_enable(struct bfa_fcs_s *fcs, u16 vf_id)
-{
-       return BFA_STATUS_OK;
-}
-
-/**
- *             Disable VF mode.
- *
- * @param[in]          fcs             fcs module instance
- *
- * @retval     BFA_STATUS_OK           vf mode is disabled
- * @retval     BFA_STATUS_BUSY         VFs are present and being used. All
- *                                     VFs must be deleted before disabling
- *                                     VF mode.
- */
-bfa_status_t
-bfa_fcs_vf_mode_disable(struct bfa_fcs_s *fcs)
-{
-       return BFA_STATUS_OK;
-}
-
-/**
- *             Create a new VF instance.
- *
- *  A new VF is created using the given VF configuration. A VF is identified
- *  by VF id. No duplicate VF creation is allowed with the same VF id. Once
- *  a VF is created, VF is automatically started after link initialization
- *  and EVFP exchange is completed.
- *
- *     param[in] vf            -       FCS vf data structure. Memory is
- *                                     allocated by caller (driver)
- *     param[in] fcs           -       FCS module
- *     param[in] vf_cfg        -       VF configuration
- *     param[in] vf_drv        -       Opaque handle back to the driver's
- *                                     virtual vf structure
- *
- *     retval BFA_STATUS_OK VF creation is successful
- *     retval BFA_STATUS_FAILED VF creation failed
- *     retval BFA_STATUS_EEXIST A VF exists with the given vf_id
- */
-bfa_status_t
-bfa_fcs_vf_create(bfa_fcs_vf_t *vf, struct bfa_fcs_s *fcs, u16 vf_id,
-                 struct bfa_port_cfg_s *port_cfg, struct bfad_vf_s *vf_drv)
-{
-       bfa_trc(fcs, vf_id);
-       return BFA_STATUS_OK;
-}
-
-/**
- *     Use this function to delete a BFA VF object. VF object should
- *             be stopped before this function call.
- *
- *     param[in] vf - pointer to bfa_vf_t.
- *
- *     retval BFA_STATUS_OK    On vf deletion success
- *     retval BFA_STATUS_BUSY VF is not in a stopped state
- *     retval BFA_STATUS_INPROGRESS VF deletion in in progress
- */
-bfa_status_t
-bfa_fcs_vf_delete(bfa_fcs_vf_t *vf)
-{
-       bfa_trc(vf->fcs, vf->vf_id);
-       return BFA_STATUS_OK;
-}
-
-/**
- *     Start participation in VF. This triggers login to the virtual fabric.
- *
- *     param[in] vf - pointer to bfa_vf_t.
- *
- *     return None
- */
-void
-bfa_fcs_vf_start(bfa_fcs_vf_t *vf)
-{
-       bfa_trc(vf->fcs, vf->vf_id);
-}
-
-/**
- *     Logout with the virtual fabric.
- *
- *     param[in] vf - pointer to bfa_vf_t.
- *
- *     retval BFA_STATUS_OK    On success.
- *     retval BFA_STATUS_INPROGRESS VF is being stopped.
- */
-bfa_status_t
-bfa_fcs_vf_stop(bfa_fcs_vf_t *vf)
-{
-       bfa_trc(vf->fcs, vf->vf_id);
-       return BFA_STATUS_OK;
-}
-
-/**
- *     Returns attributes of the given VF.
- *
- *     param[in]       vf                      pointer to bfa_vf_t.
- *     param[out] vf_attr      vf attributes returned
- *
- *     return None
- */
-void
-bfa_fcs_vf_get_attr(bfa_fcs_vf_t *vf, struct bfa_vf_attr_s *vf_attr)
-{
-       bfa_trc(vf->fcs, vf->vf_id);
-}
-
-/**
- *             Return statistics associated with the given vf.
- *
- *     param[in]       vf                      pointer to bfa_vf_t.
- *     param[out] vf_stats     vf statistics returned
- *
- *  @return None
- */
-void
-bfa_fcs_vf_get_stats(bfa_fcs_vf_t *vf, struct bfa_vf_stats_s *vf_stats)
-{
-       bfa_os_memcpy(vf_stats, &vf->stats, sizeof(struct bfa_vf_stats_s));
-       return;
-}
-
-void
-/**
- *             clear statistics associated with the given vf.
- *
- *     param[in]       vf                      pointer to bfa_vf_t.
- *
- *  @return None
- */
-bfa_fcs_vf_clear_stats(bfa_fcs_vf_t *vf)
-{
-       bfa_os_memset(&vf->stats, 0, sizeof(struct bfa_vf_stats_s));
-       return;
-}
-
-/**
- *     Returns FCS vf structure for a given vf_id.
- *
- *     param[in]       vf_id           - VF_ID
- *
- *     return
- *             If lookup succeeds, retuns fcs vf object, otherwise returns NULL
- */
-bfa_fcs_vf_t   *
-bfa_fcs_vf_lookup(struct bfa_fcs_s *fcs, u16 vf_id)
-{
-       bfa_trc(fcs, vf_id);
-       if (vf_id == FC_VF_ID_NULL)
-               return &fcs->fabric;
-
-       /**
-        * @todo vf support
-        */
-
-       return NULL;
-}
-
-/**
- *     Returns driver VF structure for a given FCS vf.
- *
- *     param[in]       vf              - pointer to bfa_vf_t
- *
- *     return Driver VF structure
- */
-struct bfad_vf_s      *
-bfa_fcs_vf_get_drv_vf(bfa_fcs_vf_t *vf)
-{
-       bfa_assert(vf);
-       bfa_trc(vf->fcs, vf->vf_id);
-       return vf->vf_drv;
-}
-
-/**
- *     Return the list of VFs configured.
- *
- *     param[in]       fcs     fcs module instance
- *     param[out]      vf_ids  returned list of vf_ids
- *     param[in,out]   nvfs    in:size of vf_ids array,
- *                             out:total elements present,
- *                             actual elements returned is limited by the size
- *
- *     return Driver VF structure
- */
-void
-bfa_fcs_vf_list(struct bfa_fcs_s *fcs, u16 *vf_ids, int *nvfs)
-{
-       bfa_trc(fcs, *nvfs);
-}
-
-/**
- *     Return the list of all VFs visible from fabric.
- *
- *     param[in]       fcs     fcs module instance
- *     param[out]      vf_ids  returned list of vf_ids
- *     param[in,out]   nvfs    in:size of vf_ids array,
- *                             out:total elements present,
- *                             actual elements returned is limited by the size
- *
- *     return Driver VF structure
- */
-void
-bfa_fcs_vf_list_all(struct bfa_fcs_s *fcs, u16 *vf_ids, int *nvfs)
-{
-       bfa_trc(fcs, *nvfs);
-}
-
-/**
- *             Return the list of local logical ports present in the given VF.
- *
- *     param[in]       vf      vf for which logical ports are returned
- *     param[out]      lpwwn   returned logical port wwn list
- *     param[in,out]   nlports in:size of lpwwn list;
- *                             out:total elements present,
- *                             actual elements returned is limited by the size
- *
- */
-void
-bfa_fcs_vf_get_ports(bfa_fcs_vf_t *vf, wwn_t lpwwn[], int *nlports)
-{
-       struct list_head        *qe;
-       struct bfa_fcs_vport_s *vport;
-       int             i;
-       struct bfa_fcs_s      *fcs;
-
-       if (vf == NULL || lpwwn == NULL || *nlports == 0)
-               return;
-
-       fcs = vf->fcs;
-
-       bfa_trc(fcs, vf->vf_id);
-       bfa_trc(fcs, (u32) *nlports);
-
-       i = 0;
-       lpwwn[i++] = vf->bport.port_cfg.pwwn;
-
-       list_for_each(qe, &vf->vport_q) {
-               if (i >= *nlports)
-                       break;
-
-               vport = (struct bfa_fcs_vport_s *) qe;
-               lpwwn[i++] = vport->lport.port_cfg.pwwn;
-       }
-
-       bfa_trc(fcs, i);
-       *nlports = i;
-       return;
-}
-
-
diff --git a/drivers/scsi/bfa/vport.c b/drivers/scsi/bfa/vport.c
deleted file mode 100644 (file)
index b378ec7..0000000
+++ /dev/null
@@ -1,903 +0,0 @@
-/*
- * Copyright (c) 2005-2009 Brocade Communications Systems, Inc.
- * All rights reserved
- * www.brocade.com
- *
- * Linux driver for Brocade Fibre Channel Host Bus Adapter.
- *
- * This program is free software; you can redistribute it and/or modify it
- * under the terms of the GNU General Public License (GPL) Version 2 as
- * published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
- * General Public License for more details.
- */
-
-/**
- *  bfa_fcs_vport.c FCS virtual port state machine
- */
-
-#include <bfa.h>
-#include <bfa_svc.h>
-#include <fcbuild.h>
-#include "fcs_fabric.h"
-#include "fcs_lport.h"
-#include "fcs_vport.h"
-#include "fcs_trcmod.h"
-#include "fcs.h"
-#include <aen/bfa_aen_lport.h>
-
-BFA_TRC_FILE(FCS, VPORT);
-
-#define __vport_fcs(__vp)       ((__vp)->lport.fcs)
-#define __vport_pwwn(__vp)      ((__vp)->lport.port_cfg.pwwn)
-#define __vport_nwwn(__vp)      ((__vp)->lport.port_cfg.nwwn)
-#define __vport_bfa(__vp)       ((__vp)->lport.fcs->bfa)
-#define __vport_fcid(__vp)      ((__vp)->lport.pid)
-#define __vport_fabric(__vp)    ((__vp)->lport.fabric)
-#define __vport_vfid(__vp)      ((__vp)->lport.fabric->vf_id)
-
-#define BFA_FCS_VPORT_MAX_RETRIES  5
-/*
- * Forward declarations
- */
-static void     bfa_fcs_vport_do_fdisc(struct bfa_fcs_vport_s *vport);
-static void     bfa_fcs_vport_timeout(void *vport_arg);
-static void     bfa_fcs_vport_do_logo(struct bfa_fcs_vport_s *vport);
-static void     bfa_fcs_vport_free(struct bfa_fcs_vport_s *vport);
-
-/**
- *  fcs_vport_sm FCS virtual port state machine
- */
-
-/**
- * VPort State Machine events
- */
-enum bfa_fcs_vport_event {
-       BFA_FCS_VPORT_SM_CREATE = 1,    /*  vport create event */
-       BFA_FCS_VPORT_SM_DELETE = 2,    /*  vport delete event */
-       BFA_FCS_VPORT_SM_START = 3,     /*  vport start request */
-       BFA_FCS_VPORT_SM_STOP = 4,      /*  stop: unsupported */
-       BFA_FCS_VPORT_SM_ONLINE = 5,    /*  fabric online */
-       BFA_FCS_VPORT_SM_OFFLINE = 6,   /*  fabric offline event */
-       BFA_FCS_VPORT_SM_FRMSENT = 7,   /*  fdisc/logo sent events */
-       BFA_FCS_VPORT_SM_RSP_OK = 8,    /*  good response */
-       BFA_FCS_VPORT_SM_RSP_ERROR = 9, /*  error/bad response */
-       BFA_FCS_VPORT_SM_TIMEOUT = 10,  /*  delay timer event */
-       BFA_FCS_VPORT_SM_DELCOMP = 11,  /*  lport delete completion */
-       BFA_FCS_VPORT_SM_RSP_DUP_WWN = 12,      /*  Dup wnn error */
-       BFA_FCS_VPORT_SM_RSP_FAILED = 13,       /*  non-retryable failure */
-};
-
-static void     bfa_fcs_vport_sm_uninit(struct bfa_fcs_vport_s *vport,
-                                       enum bfa_fcs_vport_event event);
-static void     bfa_fcs_vport_sm_created(struct bfa_fcs_vport_s *vport,
-                                        enum bfa_fcs_vport_event event);
-static void     bfa_fcs_vport_sm_offline(struct bfa_fcs_vport_s *vport,
-                                        enum bfa_fcs_vport_event event);
-static void     bfa_fcs_vport_sm_fdisc(struct bfa_fcs_vport_s *vport,
-                                      enum bfa_fcs_vport_event event);
-static void     bfa_fcs_vport_sm_fdisc_retry(struct bfa_fcs_vport_s *vport,
-                                            enum bfa_fcs_vport_event event);
-static void     bfa_fcs_vport_sm_online(struct bfa_fcs_vport_s *vport,
-                                       enum bfa_fcs_vport_event event);
-static void     bfa_fcs_vport_sm_deleting(struct bfa_fcs_vport_s *vport,
-                                         enum bfa_fcs_vport_event event);
-static void     bfa_fcs_vport_sm_cleanup(struct bfa_fcs_vport_s *vport,
-                                        enum bfa_fcs_vport_event event);
-static void     bfa_fcs_vport_sm_logo(struct bfa_fcs_vport_s *vport,
-                                     enum bfa_fcs_vport_event event);
-static void     bfa_fcs_vport_sm_error(struct bfa_fcs_vport_s *vport,
-                                      enum bfa_fcs_vport_event event);
-
-static struct bfa_sm_table_s vport_sm_table[] = {
-       {BFA_SM(bfa_fcs_vport_sm_uninit), BFA_FCS_VPORT_UNINIT},
-       {BFA_SM(bfa_fcs_vport_sm_created), BFA_FCS_VPORT_CREATED},
-       {BFA_SM(bfa_fcs_vport_sm_offline), BFA_FCS_VPORT_OFFLINE},
-       {BFA_SM(bfa_fcs_vport_sm_fdisc), BFA_FCS_VPORT_FDISC},
-       {BFA_SM(bfa_fcs_vport_sm_fdisc_retry), BFA_FCS_VPORT_FDISC_RETRY},
-       {BFA_SM(bfa_fcs_vport_sm_online), BFA_FCS_VPORT_ONLINE},
-       {BFA_SM(bfa_fcs_vport_sm_deleting), BFA_FCS_VPORT_DELETING},
-       {BFA_SM(bfa_fcs_vport_sm_cleanup), BFA_FCS_VPORT_CLEANUP},
-       {BFA_SM(bfa_fcs_vport_sm_logo), BFA_FCS_VPORT_LOGO},
-       {BFA_SM(bfa_fcs_vport_sm_error), BFA_FCS_VPORT_ERROR}
-};
-
-/**
- * Beginning state.
- */
-static void
-bfa_fcs_vport_sm_uninit(struct bfa_fcs_vport_s *vport,
-                       enum bfa_fcs_vport_event event)
-{
-       bfa_trc(__vport_fcs(vport), __vport_pwwn(vport));
-       bfa_trc(__vport_fcs(vport), event);
-
-       switch (event) {
-       case BFA_FCS_VPORT_SM_CREATE:
-               bfa_sm_set_state(vport, bfa_fcs_vport_sm_created);
-               bfa_fcs_fabric_addvport(__vport_fabric(vport), vport);
-               break;
-
-       default:
-               bfa_sm_fault(__vport_fcs(vport), event);
-       }
-}
-
-/**
- * Created state - a start event is required to start up the state machine.
- */
-static void
-bfa_fcs_vport_sm_created(struct bfa_fcs_vport_s *vport,
-                        enum bfa_fcs_vport_event event)
-{
-       bfa_trc(__vport_fcs(vport), __vport_pwwn(vport));
-       bfa_trc(__vport_fcs(vport), event);
-
-       switch (event) {
-       case BFA_FCS_VPORT_SM_START:
-               if (bfa_fcs_fabric_is_online(__vport_fabric(vport))
-                   && bfa_fcs_fabric_npiv_capable(__vport_fabric(vport))) {
-                       bfa_sm_set_state(vport, bfa_fcs_vport_sm_fdisc);
-                       bfa_fcs_vport_do_fdisc(vport);
-               } else {
-                       /**
-                        * Fabric is offline or not NPIV capable, stay in
-                        * offline state.
-                        */
-                       vport->vport_stats.fab_no_npiv++;
-                       bfa_sm_set_state(vport, bfa_fcs_vport_sm_offline);
-               }
-               break;
-
-       case BFA_FCS_VPORT_SM_DELETE:
-               bfa_sm_set_state(vport, bfa_fcs_vport_sm_cleanup);
-               bfa_fcs_port_delete(&vport->lport);
-               break;
-
-       case BFA_FCS_VPORT_SM_ONLINE:
-       case BFA_FCS_VPORT_SM_OFFLINE:
-               /**
-                * Ignore ONLINE/OFFLINE events from fabric till vport is started.
-                */
-               break;
-
-       default:
-               bfa_sm_fault(__vport_fcs(vport), event);
-       }
-}
-
-/**
- * Offline state - awaiting ONLINE event from fabric SM.
- */
-static void
-bfa_fcs_vport_sm_offline(struct bfa_fcs_vport_s *vport,
-                        enum bfa_fcs_vport_event event)
-{
-       bfa_trc(__vport_fcs(vport), __vport_pwwn(vport));
-       bfa_trc(__vport_fcs(vport), event);
-
-       switch (event) {
-       case BFA_FCS_VPORT_SM_DELETE:
-               bfa_sm_set_state(vport, bfa_fcs_vport_sm_cleanup);
-               bfa_fcs_port_delete(&vport->lport);
-               break;
-
-       case BFA_FCS_VPORT_SM_ONLINE:
-               bfa_sm_set_state(vport, bfa_fcs_vport_sm_fdisc);
-               vport->fdisc_retries = 0;
-               bfa_fcs_vport_do_fdisc(vport);
-               break;
-
-       case BFA_FCS_VPORT_SM_OFFLINE:
-               /*
-                * This can happen if the vport couldn't be initialzied due
-                * the fact that the npiv was not enabled on the switch. In
-                * that case we will put the vport in offline state. However,
-                * the link can go down and cause the this event to be sent when
-                * we are already offline. Ignore it.
-                */
-               break;
-
-       default:
-               bfa_sm_fault(__vport_fcs(vport), event);
-       }
-}
-
-/**
- * FDISC is sent and awaiting reply from fabric.
- */
-static void
-bfa_fcs_vport_sm_fdisc(struct bfa_fcs_vport_s *vport,
-                      enum bfa_fcs_vport_event event)
-{
-       bfa_trc(__vport_fcs(vport), __vport_pwwn(vport));
-       bfa_trc(__vport_fcs(vport), event);
-
-       switch (event) {
-       case BFA_FCS_VPORT_SM_DELETE:
-               bfa_sm_set_state(vport, bfa_fcs_vport_sm_cleanup);
-               bfa_lps_discard(vport->lps);
-               bfa_fcs_port_delete(&vport->lport);
-               break;
-
-       case BFA_FCS_VPORT_SM_OFFLINE:
-               bfa_sm_set_state(vport, bfa_fcs_vport_sm_offline);
-               bfa_lps_discard(vport->lps);
-               break;
-
-       case BFA_FCS_VPORT_SM_RSP_OK:
-               bfa_sm_set_state(vport, bfa_fcs_vport_sm_online);
-               bfa_fcs_port_online(&vport->lport);
-               break;
-
-       case BFA_FCS_VPORT_SM_RSP_ERROR:
-               bfa_sm_set_state(vport, bfa_fcs_vport_sm_fdisc_retry);
-               bfa_timer_start(__vport_bfa(vport), &vport->timer,
-                               bfa_fcs_vport_timeout, vport,
-                               BFA_FCS_RETRY_TIMEOUT);
-               break;
-
-       case BFA_FCS_VPORT_SM_RSP_FAILED:
-               bfa_sm_set_state(vport, bfa_fcs_vport_sm_offline);
-               break;
-
-       case BFA_FCS_VPORT_SM_RSP_DUP_WWN:
-               bfa_sm_set_state(vport, bfa_fcs_vport_sm_error);
-               break;
-
-       default:
-               bfa_sm_fault(__vport_fcs(vport), event);
-       }
-}
-
-/**
- * FDISC attempt failed - a timer is active to retry FDISC.
- */
-static void
-bfa_fcs_vport_sm_fdisc_retry(struct bfa_fcs_vport_s *vport,
-                            enum bfa_fcs_vport_event event)
-{
-       bfa_trc(__vport_fcs(vport), __vport_pwwn(vport));
-       bfa_trc(__vport_fcs(vport), event);
-
-       switch (event) {
-       case BFA_FCS_VPORT_SM_DELETE:
-               bfa_sm_set_state(vport, bfa_fcs_vport_sm_cleanup);
-               bfa_timer_stop(&vport->timer);
-               bfa_fcs_port_delete(&vport->lport);
-               break;
-
-       case BFA_FCS_VPORT_SM_OFFLINE:
-               bfa_sm_set_state(vport, bfa_fcs_vport_sm_offline);
-               bfa_timer_stop(&vport->timer);
-               break;
-
-       case BFA_FCS_VPORT_SM_TIMEOUT:
-               bfa_sm_set_state(vport, bfa_fcs_vport_sm_fdisc);
-               vport->vport_stats.fdisc_retries++;
-               vport->fdisc_retries++;
-               bfa_fcs_vport_do_fdisc(vport);
-               break;
-
-       default:
-               bfa_sm_fault(__vport_fcs(vport), event);
-       }
-}
-
-/**
- * Vport is online (FDISC is complete).
- */
-static void
-bfa_fcs_vport_sm_online(struct bfa_fcs_vport_s *vport,
-                       enum bfa_fcs_vport_event event)
-{
-       bfa_trc(__vport_fcs(vport), __vport_pwwn(vport));
-       bfa_trc(__vport_fcs(vport), event);
-
-       switch (event) {
-       case BFA_FCS_VPORT_SM_DELETE:
-               bfa_sm_set_state(vport, bfa_fcs_vport_sm_deleting);
-               bfa_fcs_port_delete(&vport->lport);
-               break;
-
-       case BFA_FCS_VPORT_SM_OFFLINE:
-               bfa_sm_set_state(vport, bfa_fcs_vport_sm_offline);
-               bfa_lps_discard(vport->lps);
-               bfa_fcs_port_offline(&vport->lport);
-               break;
-
-       default:
-               bfa_sm_fault(__vport_fcs(vport), event);
-       }
-}
-
-/**
- * Vport is being deleted - awaiting lport delete completion to send
- * LOGO to fabric.
- */
-static void
-bfa_fcs_vport_sm_deleting(struct bfa_fcs_vport_s *vport,
-                         enum bfa_fcs_vport_event event)
-{
-       bfa_trc(__vport_fcs(vport), __vport_pwwn(vport));
-       bfa_trc(__vport_fcs(vport), event);
-
-       switch (event) {
-       case BFA_FCS_VPORT_SM_DELETE:
-               break;
-
-       case BFA_FCS_VPORT_SM_DELCOMP:
-               bfa_sm_set_state(vport, bfa_fcs_vport_sm_logo);
-               bfa_fcs_vport_do_logo(vport);
-               break;
-
-       case BFA_FCS_VPORT_SM_OFFLINE:
-               bfa_sm_set_state(vport, bfa_fcs_vport_sm_cleanup);
-               break;
-
-       default:
-               bfa_sm_fault(__vport_fcs(vport), event);
-       }
-}
-
-/**
- * Error State.
- * This state will be set when the Vport Creation fails due to errors like
- * Dup WWN. In this state only operation allowed is a Vport Delete.
- */
-static void
-bfa_fcs_vport_sm_error(struct bfa_fcs_vport_s *vport,
-                      enum bfa_fcs_vport_event event)
-{
-       bfa_trc(__vport_fcs(vport), __vport_pwwn(vport));
-       bfa_trc(__vport_fcs(vport), event);
-
-       switch (event) {
-       case BFA_FCS_VPORT_SM_DELETE:
-               bfa_sm_set_state(vport, bfa_fcs_vport_sm_cleanup);
-               bfa_fcs_port_delete(&vport->lport);
-
-               break;
-
-       default:
-               bfa_trc(__vport_fcs(vport), event);
-       }
-}
-
-/**
- * Lport cleanup is in progress since vport is being deleted. Fabric is
- * offline, so no LOGO is needed to complete vport deletion.
- */
-static void
-bfa_fcs_vport_sm_cleanup(struct bfa_fcs_vport_s *vport,
-                        enum bfa_fcs_vport_event event)
-{
-       bfa_trc(__vport_fcs(vport), __vport_pwwn(vport));
-       bfa_trc(__vport_fcs(vport), event);
-
-       switch (event) {
-       case BFA_FCS_VPORT_SM_DELCOMP:
-               bfa_sm_set_state(vport, bfa_fcs_vport_sm_uninit);
-               bfa_fcs_vport_free(vport);
-               break;
-
-       case BFA_FCS_VPORT_SM_DELETE:
-               break;
-
-       default:
-               bfa_sm_fault(__vport_fcs(vport), event);
-       }
-}
-
-/**
- * LOGO is sent to fabric. Vport delete is in progress. Lport delete cleanup
- * is done.
- */
-static void
-bfa_fcs_vport_sm_logo(struct bfa_fcs_vport_s *vport,
-                     enum bfa_fcs_vport_event event)
-{
-       bfa_trc(__vport_fcs(vport), __vport_pwwn(vport));
-       bfa_trc(__vport_fcs(vport), event);
-
-       switch (event) {
-       case BFA_FCS_VPORT_SM_OFFLINE:
-               bfa_lps_discard(vport->lps);
-               /*
-                * !!! fall through !!!
-                */
-
-       case BFA_FCS_VPORT_SM_RSP_OK:
-       case BFA_FCS_VPORT_SM_RSP_ERROR:
-               bfa_sm_set_state(vport, bfa_fcs_vport_sm_uninit);
-               bfa_fcs_vport_free(vport);
-               break;
-
-       case BFA_FCS_VPORT_SM_DELETE:
-               break;
-
-       default:
-               bfa_sm_fault(__vport_fcs(vport), event);
-       }
-}
-
-
-
-/**
- *  fcs_vport_private FCS virtual port private functions
- */
-
-/**
- * Send AEN notification
- */
-static void
-bfa_fcs_vport_aen_post(bfa_fcs_lport_t *port, enum bfa_lport_aen_event event)
-{
-       union bfa_aen_data_u aen_data;
-       struct bfa_log_mod_s *logmod = port->fcs->logm;
-       enum bfa_port_role role = port->port_cfg.roles;
-       wwn_t           lpwwn = bfa_fcs_port_get_pwwn(port);
-       char            lpwwn_ptr[BFA_STRING_32];
-       char           *role_str[BFA_PORT_ROLE_FCP_MAX / 2 + 1] =
-               { "Initiator", "Target", "IPFC" };
-
-       wwn2str(lpwwn_ptr, lpwwn);
-
-       bfa_assert(role <= BFA_PORT_ROLE_FCP_MAX);
-
-       bfa_log(logmod, BFA_LOG_CREATE_ID(BFA_AEN_CAT_LPORT, event), lpwwn_ptr,
-                       role_str[role/2]);
-
-       aen_data.lport.vf_id = port->fabric->vf_id;
-       aen_data.lport.roles = role;
-       aen_data.lport.ppwwn =
-               bfa_fcs_port_get_pwwn(bfa_fcs_get_base_port(port->fcs));
-       aen_data.lport.lpwwn = lpwwn;
-}
-
-/**
- * This routine will be called to send a FDISC command.
- */
-static void
-bfa_fcs_vport_do_fdisc(struct bfa_fcs_vport_s *vport)
-{
-       bfa_lps_fdisc(vport->lps, vport,
-                     bfa_fcport_get_maxfrsize(__vport_bfa(vport)),
-                     __vport_pwwn(vport), __vport_nwwn(vport));
-       vport->vport_stats.fdisc_sent++;
-}
-
-static void
-bfa_fcs_vport_fdisc_rejected(struct bfa_fcs_vport_s *vport)
-{
-       u8         lsrjt_rsn = bfa_lps_get_lsrjt_rsn(vport->lps);
-       u8         lsrjt_expl = bfa_lps_get_lsrjt_expl(vport->lps);
-
-       bfa_trc(__vport_fcs(vport), lsrjt_rsn);
-       bfa_trc(__vport_fcs(vport), lsrjt_expl);
-
-       /*
-        * For certain reason codes, we don't want to retry.
-        */
-       switch (bfa_lps_get_lsrjt_expl(vport->lps)) {
-       case FC_LS_RJT_EXP_INV_PORT_NAME:       /* by brocade */
-       case FC_LS_RJT_EXP_INVALID_NPORT_ID:    /* by Cisco */
-               if (vport->fdisc_retries < BFA_FCS_VPORT_MAX_RETRIES)
-                       bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_RSP_ERROR);
-               else {
-                       bfa_fcs_vport_aen_post(&vport->lport,
-                                              BFA_LPORT_AEN_NPIV_DUP_WWN);
-                       bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_RSP_DUP_WWN);
-               }
-               break;
-
-       case FC_LS_RJT_EXP_INSUFF_RES:
-               /*
-                * This means max logins per port/switch setting on the
-                * switch was exceeded.
-                */
-               if (vport->fdisc_retries < BFA_FCS_VPORT_MAX_RETRIES)
-                       bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_RSP_ERROR);
-               else {
-                       bfa_fcs_vport_aen_post(&vport->lport,
-                                              BFA_LPORT_AEN_NPIV_FABRIC_MAX);
-                       bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_RSP_FAILED);
-               }
-               break;
-
-       default:
-               if (vport->fdisc_retries == 0)  /* Print only once */
-                       bfa_fcs_vport_aen_post(&vport->lport,
-                                              BFA_LPORT_AEN_NPIV_UNKNOWN);
-               bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_RSP_ERROR);
-       }
-}
-
-/**
- *     Called to send a logout to the fabric. Used when a V-Port is
- *     deleted/stopped.
- */
-static void
-bfa_fcs_vport_do_logo(struct bfa_fcs_vport_s *vport)
-{
-       bfa_trc(__vport_fcs(vport), __vport_pwwn(vport));
-
-       vport->vport_stats.logo_sent++;
-       bfa_lps_fdisclogo(vport->lps);
-}
-
-/**
- *     This routine will be called by bfa_timer on timer timeouts.
- *
- *     param[in]       vport           - pointer to bfa_fcs_vport_t.
- *     param[out]      vport_status    - pointer to return vport status in
- *
- *     return
- *             void
- *
-*      Special Considerations:
- *
- *     note
- */
-static void
-bfa_fcs_vport_timeout(void *vport_arg)
-{
-       struct bfa_fcs_vport_s *vport = (struct bfa_fcs_vport_s *)vport_arg;
-
-       vport->vport_stats.fdisc_timeouts++;
-       bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_TIMEOUT);
-}
-
-static void
-bfa_fcs_vport_free(struct bfa_fcs_vport_s *vport)
-{
-       bfa_fcs_fabric_delvport(__vport_fabric(vport), vport);
-       bfa_fcb_vport_delete(vport->vport_drv);
-       bfa_lps_delete(vport->lps);
-}
-
-
-
-/**
- *  fcs_vport_public FCS virtual port public interfaces
- */
-
-/**
- * Online notification from fabric SM.
- */
-void
-bfa_fcs_vport_online(struct bfa_fcs_vport_s *vport)
-{
-       vport->vport_stats.fab_online++;
-       bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_ONLINE);
-}
-
-/**
- * Offline notification from fabric SM.
- */
-void
-bfa_fcs_vport_offline(struct bfa_fcs_vport_s *vport)
-{
-       vport->vport_stats.fab_offline++;
-       bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_OFFLINE);
-}
-
-/**
- * Cleanup notification from fabric SM on link timer expiry.
- */
-void
-bfa_fcs_vport_cleanup(struct bfa_fcs_vport_s *vport)
-{
-       vport->vport_stats.fab_cleanup++;
-}
-
-/**
- * delete notification from fabric SM. To be invoked from within FCS.
- */
-void
-bfa_fcs_vport_fcs_delete(struct bfa_fcs_vport_s *vport)
-{
-       bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_DELETE);
-}
-
-/**
- * Delete completion callback from associated lport
- */
-void
-bfa_fcs_vport_delete_comp(struct bfa_fcs_vport_s *vport)
-{
-       bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_DELCOMP);
-}
-
-/**
- *  fcs_vport_api Virtual port API
- */
-
-/**
- *     Use this function to instantiate a new FCS vport object. This
- *     function will not trigger any HW initialization process (which will be
- *     done in vport_start() call)
- *
- *     param[in] vport -       pointer to bfa_fcs_vport_t. This space
- *                                     needs to be allocated by the driver.
- *     param[in] fcs           -       FCS instance
- *     param[in] vport_cfg     -       vport configuration
- *     param[in] vf_id         -       VF_ID if vport is created within a VF.
- *                                     FC_VF_ID_NULL to specify base fabric.
- *     param[in] vport_drv     -       Opaque handle back to the driver's vport
- *                                     structure
- *
- *     retval BFA_STATUS_OK - on success.
- *     retval BFA_STATUS_FAILED - on failure.
- */
-bfa_status_t
-bfa_fcs_vport_create(struct bfa_fcs_vport_s *vport, struct bfa_fcs_s *fcs,
-                    u16 vf_id, struct bfa_port_cfg_s *vport_cfg,
-                    struct bfad_vport_s *vport_drv)
-{
-       if (vport_cfg->pwwn == 0)
-               return BFA_STATUS_INVALID_WWN;
-
-       if (bfa_fcs_port_get_pwwn(&fcs->fabric.bport) == vport_cfg->pwwn)
-               return BFA_STATUS_VPORT_WWN_BP;
-
-       if (bfa_fcs_vport_lookup(fcs, vf_id, vport_cfg->pwwn) != NULL)
-               return BFA_STATUS_VPORT_EXISTS;
-
-       if (bfa_fcs_fabric_vport_count(&fcs->fabric) ==
-               bfa_lps_get_max_vport(fcs->bfa))
-               return BFA_STATUS_VPORT_MAX;
-
-       vport->lps = bfa_lps_alloc(fcs->bfa);
-       if (!vport->lps)
-               return BFA_STATUS_VPORT_MAX;
-
-       vport->vport_drv = vport_drv;
-       vport_cfg->preboot_vp = BFA_FALSE;
-       bfa_sm_set_state(vport, bfa_fcs_vport_sm_uninit);
-
-       bfa_fcs_lport_attach(&vport->lport, fcs, vf_id, vport);
-       bfa_fcs_lport_init(&vport->lport, vport_cfg);
-
-       bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_CREATE);
-
-       return BFA_STATUS_OK;
-}
-
-/**
- *      Use this function to instantiate a new FCS PBC vport object. This
- *      function will not trigger any HW initialization process (which will be
- *      done in vport_start() call)
- *
- *      param[in] vport        -       pointer to bfa_fcs_vport_t. This space
- *                                      needs to be allocated by the driver.
- *      param[in] fcs          -       FCS instance
- *      param[in] vport_cfg    -       vport configuration
- *      param[in] vf_id        -       VF_ID if vport is created within a VF.
- *                                      FC_VF_ID_NULL to specify base fabric.
- *      param[in] vport_drv    -       Opaque handle back to the driver's vport
- *                                      structure
- *
- *      retval BFA_STATUS_OK - on success.
- *      retval BFA_STATUS_FAILED - on failure.
- */
-bfa_status_t
-bfa_fcs_pbc_vport_create(struct bfa_fcs_vport_s *vport, struct bfa_fcs_s *fcs,
-                       uint16_t vf_id, struct bfa_port_cfg_s *vport_cfg,
-                       struct bfad_vport_s *vport_drv)
-{
-       bfa_status_t rc;
-
-       rc = bfa_fcs_vport_create(vport, fcs, vf_id, vport_cfg, vport_drv);
-       vport->lport.port_cfg.preboot_vp = BFA_TRUE;
-
-       return rc;
-}
-
-/**
- *     Use this function initialize the vport.
- *
- *  @param[in] vport - pointer to bfa_fcs_vport_t.
- *
- *  @returns None
- */
-bfa_status_t
-bfa_fcs_vport_start(struct bfa_fcs_vport_s *vport)
-{
-       bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_START);
-
-       return BFA_STATUS_OK;
-}
-
-/**
- *     Use this function quiese the vport object. This function will return
- *     immediately, when the vport is actually stopped, the
- *     bfa_drv_vport_stop_cb() will be called.
- *
- *     param[in] vport - pointer to bfa_fcs_vport_t.
- *
- *     return None
- */
-bfa_status_t
-bfa_fcs_vport_stop(struct bfa_fcs_vport_s *vport)
-{
-       bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_STOP);
-
-       return BFA_STATUS_OK;
-}
-
-/**
- *     Use this function to delete a vport object. Fabric object should
- *             be stopped before this function call.
- *
- *     Donot invoke this from within FCS
- *
- *     param[in] vport - pointer to bfa_fcs_vport_t.
- *
- *     return     None
- */
-bfa_status_t
-bfa_fcs_vport_delete(struct bfa_fcs_vport_s *vport)
-{
-       if (vport->lport.port_cfg.preboot_vp)
-               return BFA_STATUS_PBC;
-
-       bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_DELETE);
-
-       return BFA_STATUS_OK;
-}
-
-/**
- *     Use this function to get vport's current status info.
- *
- *     param[in]       vport           pointer to bfa_fcs_vport_t.
- *     param[out]      attr            pointer to return vport attributes
- *
- *     return None
- */
-void
-bfa_fcs_vport_get_attr(struct bfa_fcs_vport_s *vport,
-                      struct bfa_vport_attr_s *attr)
-{
-       if (vport == NULL || attr == NULL)
-               return;
-
-       bfa_os_memset(attr, 0, sizeof(struct bfa_vport_attr_s));
-
-       bfa_fcs_port_get_attr(&vport->lport, &attr->port_attr);
-       attr->vport_state = bfa_sm_to_state(vport_sm_table, vport->sm);
-}
-
-/**
- *     Use this function to get vport's statistics.
- *
- *     param[in]       vport           pointer to bfa_fcs_vport_t.
- *     param[out]      stats           pointer to return vport statistics in
- *
- *     return None
- */
-void
-bfa_fcs_vport_get_stats(struct bfa_fcs_vport_s *vport,
-                       struct bfa_vport_stats_s *stats)
-{
-       *stats = vport->vport_stats;
-}
-
-/**
- *     Use this function to clear vport's statistics.
- *
- *     param[in]       vport           pointer to bfa_fcs_vport_t.
- *
- *     return None
- */
-void
-bfa_fcs_vport_clr_stats(struct bfa_fcs_vport_s *vport)
-{
-       bfa_os_memset(&vport->vport_stats, 0, sizeof(struct bfa_vport_stats_s));
-}
-
-/**
- *      Lookup a virtual port. Excludes base port from lookup.
- */
-struct bfa_fcs_vport_s *
-bfa_fcs_vport_lookup(struct bfa_fcs_s *fcs, u16 vf_id, wwn_t vpwwn)
-{
-       struct bfa_fcs_vport_s *vport;
-       struct bfa_fcs_fabric_s *fabric;
-
-       bfa_trc(fcs, vf_id);
-       bfa_trc(fcs, vpwwn);
-
-       fabric = bfa_fcs_vf_lookup(fcs, vf_id);
-       if (!fabric) {
-               bfa_trc(fcs, vf_id);
-               return NULL;
-       }
-
-       vport = bfa_fcs_fabric_vport_lookup(fabric, vpwwn);
-       return vport;
-}
-
-/**
- * FDISC Response
- */
-void
-bfa_cb_lps_fdisc_comp(void *bfad, void *uarg, bfa_status_t status)
-{
-       struct bfa_fcs_vport_s *vport = uarg;
-
-       bfa_trc(__vport_fcs(vport), __vport_pwwn(vport));
-       bfa_trc(__vport_fcs(vport), status);
-
-       switch (status) {
-       case BFA_STATUS_OK:
-               /*
-                * Initialize the V-Port fields
-                */
-               __vport_fcid(vport) = bfa_lps_get_pid(vport->lps);
-               vport->vport_stats.fdisc_accepts++;
-               bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_RSP_OK);
-               break;
-
-       case BFA_STATUS_INVALID_MAC:
-               /*
-                * Only for CNA
-                */
-               vport->vport_stats.fdisc_acc_bad++;
-               bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_RSP_ERROR);
-
-               break;
-
-       case BFA_STATUS_EPROTOCOL:
-               switch (bfa_lps_get_extstatus(vport->lps)) {
-               case BFA_EPROTO_BAD_ACCEPT:
-                       vport->vport_stats.fdisc_acc_bad++;
-                       break;
-
-               case BFA_EPROTO_UNKNOWN_RSP:
-                       vport->vport_stats.fdisc_unknown_rsp++;
-                       break;
-
-               default:
-                       break;
-               }
-
-               bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_RSP_ERROR);
-               break;
-
-       case BFA_STATUS_FABRIC_RJT:
-               vport->vport_stats.fdisc_rejects++;
-               bfa_fcs_vport_fdisc_rejected(vport);
-               break;
-
-       default:
-               vport->vport_stats.fdisc_rsp_err++;
-               bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_RSP_ERROR);
-       }
-}
-
-/**
- * LOGO response
- */
-void
-bfa_cb_lps_fdisclogo_comp(void *bfad, void *uarg)
-{
-       struct bfa_fcs_vport_s *vport = uarg;
-       bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_RSP_OK);
-}
-
-/**
- * Received clear virtual link
- */
-void
-bfa_cb_lps_cvl_event(void *bfad, void *uarg)
-{
-       struct bfa_fcs_vport_s *vport = uarg;
-
-       /* Send an Offline followed by an ONLINE */
-       bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_OFFLINE);
-       bfa_sm_send_event(vport, BFA_FCS_VPORT_SM_ONLINE);
-}