2009-09-24 08:46:15 +08:00
|
|
|
/*
|
2010-09-16 02:50:55 +08:00
|
|
|
* Copyright (c) 2005-2010 Brocade Communications Systems, Inc.
|
2009-09-24 08:46:15 +08:00
|
|
|
* 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.
|
|
|
|
*/
|
2010-09-16 02:50:55 +08:00
|
|
|
|
|
|
|
#include "bfa_modules.h"
|
2009-09-24 08:46:15 +08:00
|
|
|
|
2010-10-19 08:17:23 +08:00
|
|
|
/*
|
2009-09-24 08:46:15 +08:00
|
|
|
* BFA module list terminated by NULL
|
|
|
|
*/
|
|
|
|
struct bfa_module_s *hal_mods[] = {
|
|
|
|
&hal_mod_sgpg,
|
2010-03-06 11:37:37 +08:00
|
|
|
&hal_mod_fcport,
|
2009-09-24 08:46:15 +08:00
|
|
|
&hal_mod_fcxp,
|
|
|
|
&hal_mod_lps,
|
|
|
|
&hal_mod_uf,
|
|
|
|
&hal_mod_rport,
|
|
|
|
&hal_mod_fcpim,
|
|
|
|
NULL
|
|
|
|
};
|
|
|
|
|
2010-10-19 08:17:23 +08:00
|
|
|
/*
|
2009-09-24 08:46:15 +08:00
|
|
|
* 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 */
|
2010-03-06 11:37:37 +08:00
|
|
|
bfa_fcport_isr, /* BFI_MC_FCPORT */
|
2009-09-24 08:46:15 +08:00
|
|
|
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, /* --------- */
|
|
|
|
};
|
|
|
|
|
2010-09-16 02:50:55 +08:00
|
|
|
|
2010-10-19 08:17:23 +08:00
|
|
|
/*
|
2009-09-24 08:46:15 +08:00
|
|
|
* Message handlers for mailbox command classes
|
|
|
|
*/
|
|
|
|
bfa_ioc_mbox_mcfunc_t bfa_mbox_isrs[BFI_MC_MAX] = {
|
|
|
|
NULL,
|
2010-09-16 02:50:55 +08:00
|
|
|
NULL, /* BFI_MC_IOC */
|
|
|
|
NULL, /* BFI_MC_DIAG */
|
2009-09-24 08:46:15 +08:00
|
|
|
NULL, /* BFI_MC_FLASH */
|
2010-09-16 02:50:55 +08:00
|
|
|
NULL, /* BFI_MC_CEE */
|
|
|
|
NULL, /* BFI_MC_PORT */
|
2009-09-24 08:46:15 +08:00
|
|
|
bfa_iocfc_isr, /* BFI_MC_IOCFC */
|
|
|
|
NULL,
|
|
|
|
};
|
|
|
|
|
2010-09-16 02:50:55 +08:00
|
|
|
|
|
|
|
|
|
|
|
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;
|
|
|
|
}
|