 1da177e4c3
			
		
	
	
	1da177e4c3
	
	
	
		
			
			Initial git repository build. I'm not bothering with the full history, even though we have it. We can create a separate "historical" git archive of that later if we want to, and in the meantime it's about 3.2GB when imported into git - space that would just make the early git days unnecessarily complicated, when we don't have a lot of good infrastructure for it. Let it rip!
		
			
				
	
	
		
			125 lines
		
	
	
	
		
			3 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			125 lines
		
	
	
	
		
			3 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) ;
 | |
| }
 | |
| 
 |