| /****************************************************************************** |
| * |
| * (C)Copyright 1998,1999 SysKonnect, |
| * a business unit of Schneider & Koch & Co. Datensysteme GmbH. |
| * |
| * See the file "skfddi.c" for further information. |
| * |
| * This program is free software; you can redistribute it and/or modify |
| * it under the terms of the GNU General Public License as published by |
| * the Free Software Foundation; either version 2 of the License, or |
| * (at your option) any later version. |
| * |
| * The information in this file is provided "AS IS" without warranty. |
| * |
| ******************************************************************************/ |
| |
| /* |
| Init SMT |
| call all module level initialization routines |
| */ |
| |
| #include "h/types.h" |
| #include "h/fddi.h" |
| #include "h/smc.h" |
| |
| #ifndef lint |
| static const char ID_sccs[] = "@(#)smtinit.c 1.15 97/05/06 (C) SK " ; |
| #endif |
| |
| void init_fddi_driver(struct s_smc *smc, u_char *mac_addr); |
| |
| /* define global debug variable */ |
| #if defined(DEBUG) && !defined(DEBUG_BRD) |
| struct smt_debug debug; |
| #endif |
| |
| #ifndef MULT_OEM |
| #define OEMID(smc,i) oem_id[i] |
| extern u_char oem_id[] ; |
| #else /* MULT_OEM */ |
| #define OEMID(smc,i) smc->hw.oem_id->oi_mark[i] |
| extern struct s_oem_ids oem_ids[] ; |
| #endif /* MULT_OEM */ |
| |
| /* |
| * Set OEM specific values |
| * |
| * Can not be called in smt_reset_defaults, because it is not sure that |
| * the OEM ID is already defined. |
| */ |
| static void set_oem_spec_val(struct s_smc *smc) |
| { |
| struct fddi_mib *mib ; |
| |
| mib = &smc->mib ; |
| |
| /* |
| * set IBM specific values |
| */ |
| if (OEMID(smc,0) == 'I') { |
| mib->fddiSMTConnectionPolicy = POLICY_MM ; |
| } |
| } |
| |
| /* |
| * Init SMT |
| */ |
| int init_smt(struct s_smc *smc, u_char *mac_addr) |
| /* u_char *mac_addr; canonical address or NULL */ |
| { |
| int p ; |
| |
| #if defined(DEBUG) && !defined(DEBUG_BRD) |
| debug.d_smt = 0 ; |
| debug.d_smtf = 0 ; |
| debug.d_rmt = 0 ; |
| debug.d_ecm = 0 ; |
| debug.d_pcm = 0 ; |
| debug.d_cfm = 0 ; |
| |
| debug.d_plc = 0 ; |
| #ifdef ESS |
| debug.d_ess = 0 ; |
| #endif |
| #ifdef SBA |
| debug.d_sba = 0 ; |
| #endif |
| #endif /* DEBUG && !DEBUG_BRD */ |
| |
| /* First initialize the ports mib->pointers */ |
| for ( p = 0; p < NUMPHYS; p ++ ) { |
| smc->y[p].mib = & smc->mib.p[p] ; |
| } |
| |
| set_oem_spec_val(smc) ; |
| (void) smt_set_mac_opvalues(smc) ; |
| init_fddi_driver(smc,mac_addr) ; /* HW driver */ |
| smt_fixup_mib(smc) ; /* update values that depend on s.sas */ |
| |
| ev_init(smc) ; /* event queue */ |
| #ifndef SLIM_SMT |
| smt_init_evc(smc) ; /* evcs in MIB */ |
| #endif /* no SLIM_SMT */ |
| smt_timer_init(smc) ; /* timer package */ |
| smt_agent_init(smc) ; /* SMT frame manager */ |
| |
| pcm_init(smc) ; /* PCM state machine */ |
| ecm_init(smc) ; /* ECM state machine */ |
| cfm_init(smc) ; /* CFM state machine */ |
| rmt_init(smc) ; /* RMT state machine */ |
| |
| for (p = 0 ; p < NUMPHYS ; p++) { |
| pcm(smc,p,0) ; /* PCM A state machine */ |
| } |
| ecm(smc,0) ; /* ECM state machine */ |
| cfm(smc,0) ; /* CFM state machine */ |
| rmt(smc,0) ; /* RMT state machine */ |
| |
| smt_agent_task(smc) ; /* NIF FSM etc */ |
| |
| PNMI_INIT(smc) ; /* PNMI initialization */ |
| |
| return 0; |
| } |
| |