/* * 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.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 "bfad_drv.h" #include <fcb/bfa_fcb.h> /** * FCS sub-modules */ struct bfa_fcs_mod_s { 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_MODULE(bfa_fcs_pport), BFA_FCS_MODULE(bfa_fcs_uf), BFA_FCS_MODULE(bfa_fcs_fabric), BFA_FCS_MODULE(bfa_fcs_vport), BFA_FCS_MODULE(bfa_fcs_rport), BFA_FCS_MODULE(bfa_fcs_fcpim), }; /** * fcs_api BFA FCS API */ static void bfa_fcs_exit_comp(void *fcs_cbarg) { struct bfa_fcs_s *fcs = fcs_cbarg; struct bfad_s *bfad = fcs->bfad; complete(&bfad->comp); } /** * fcs_api BFA FCS API */ /** * FCS instance initialization. * * param[in] fcs FCS instance * param[in] bfa BFA instance * param[in] bfad BFA driver instance * * return None */ void bfa_fcs_init(struct bfa_fcs_s *fcs, struct bfa_s *bfa, struct bfad_s *bfad, bfa_boolean_t min_cfg) { int i; struct bfa_fcs_mod_s *mod; fcs->bfa = bfa; fcs->bfad = bfad; fcs->min_cfg = min_cfg; bfa_attach_fcs(bfa); fcbuild_init(); for (i = 0; i < sizeof(fcs_modules) / sizeof(fcs_modules[0]); i++) { mod = &fcs_modules[i]; mod->modinit(fcs); } } /** * Start FCS operations. */ void bfa_fcs_start(struct bfa_fcs_s *fcs) { bfa_fcs_fabric_modstart(fcs); } /** * FCS driver details initialization. * * param[in] fcs FCS instance * param[in] driver_info Driver Details * * return None */ void bfa_fcs_driver_info_init(struct bfa_fcs_s *fcs, struct bfa_fcs_driver_info_s *driver_info) { fcs->driver_info = *driver_info; bfa_fcs_fabric_psymb_init(&fcs->fabric); } /** * FCS instance cleanup and exit. * * param[in] fcs FCS instance * return None */ void bfa_fcs_exit(struct bfa_fcs_s *fcs) { struct bfa_fcs_mod_s *mod; int nmods, i; bfa_wc_init(&fcs->wc, bfa_fcs_exit_comp, fcs); nmods = sizeof(fcs_modules) / sizeof(fcs_modules[0]); for (i = 0; i < nmods; i++) { bfa_wc_up(&fcs->wc); mod = &fcs_modules[i]; mod->modexit(fcs); } bfa_wc_wait(&fcs->wc); } void 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) { fcs->logm = logmod; } void bfa_fcs_aen_init(struct bfa_fcs_s *fcs, struct bfa_aen_s *aen) { fcs->aen = aen; } void bfa_fcs_modexit_comp(struct bfa_fcs_s *fcs) { bfa_wc_down(&fcs->wc); }