126 lines
3.0 KiB
C
126 lines
3.0 KiB
C
|
/******************************************************************************
|
||
|
*
|
||
|
* (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;
|
||
|
}
|
||
|
|