1 // SPDX-License-Identifier: GPL-2.0-or-later
2 /******************************************************************************
3  *
4  *	(C)Copyright 1998,1999 SysKonnect,
5  *	a business unit of Schneider & Koch & Co. Datensysteme GmbH.
6  *
7  *	See the file "skfddi.c" for further information.
8  *
9  *	The information in this file is provided "AS IS" without warranty.
10  *
11  ******************************************************************************/
12 
13 /*
14 	Init SMT
15 	call all module level initialization routines
16 */
17 
18 #include "h/types.h"
19 #include "h/fddi.h"
20 #include "h/smc.h"
21 
22 #ifndef	lint
23 static const char ID_sccs[] = "@(#)smtinit.c	1.15 97/05/06 (C) SK " ;
24 #endif
25 
26 void init_fddi_driver(struct s_smc *smc, u_char *mac_addr);
27 
28 /* define global debug variable */
29 #if defined(DEBUG) && !defined(DEBUG_BRD)
30 struct smt_debug debug;
31 #endif
32 
33 #ifndef MULT_OEM
34 #define OEMID(smc,i)	oem_id[i]
35 	extern u_char	oem_id[] ;
36 #else	/* MULT_OEM */
37 #define OEMID(smc,i)	smc->hw.oem_id->oi_mark[i]
38 	extern struct s_oem_ids	oem_ids[] ;
39 #endif	/* MULT_OEM */
40 
41 /*
42  * Set OEM specific values
43  *
44  * Can not be called in smt_reset_defaults, because it is not sure that
45  * the OEM ID is already defined.
46  */
set_oem_spec_val(struct s_smc * smc)47 static void set_oem_spec_val(struct s_smc *smc)
48 {
49 	struct fddi_mib *mib ;
50 
51 	mib = &smc->mib ;
52 
53 	/*
54 	 * set IBM specific values
55 	 */
56 	if (OEMID(smc,0) == 'I') {
57 		mib->fddiSMTConnectionPolicy = POLICY_MM ;
58 	}
59 }
60 
61 /*
62  * Init SMT
63  */
init_smt(struct s_smc * smc,u_char * mac_addr)64 int init_smt(struct s_smc *smc, u_char *mac_addr)
65 /* u_char *mac_addr;	canonical address or NULL */
66 {
67 	int	p ;
68 
69 #if defined(DEBUG) && !defined(DEBUG_BRD)
70 	debug.d_smt = 0 ;
71 	debug.d_smtf = 0 ;
72 	debug.d_rmt = 0 ;
73 	debug.d_ecm = 0 ;
74 	debug.d_pcm = 0 ;
75 	debug.d_cfm = 0 ;
76 
77 	debug.d_plc = 0 ;
78 #ifdef	ESS
79 	debug.d_ess = 0 ;
80 #endif
81 #ifdef	SBA
82 	debug.d_sba = 0 ;
83 #endif
84 #endif	/* DEBUG && !DEBUG_BRD */
85 
86 	/* First initialize the ports mib->pointers */
87 	for ( p = 0; p < NUMPHYS; p ++ ) {
88 		smc->y[p].mib = & smc->mib.p[p] ;
89 	}
90 
91 	set_oem_spec_val(smc) ;
92 	(void) smt_set_mac_opvalues(smc) ;
93 	init_fddi_driver(smc,mac_addr) ;	/* HW driver */
94 	smt_fixup_mib(smc) ;		/* update values that depend on s.sas */
95 
96 	ev_init(smc) ;			/* event queue */
97 #ifndef	SLIM_SMT
98 	smt_init_evc(smc) ;		/* evcs in MIB */
99 #endif	/* no SLIM_SMT */
100 	smt_timer_init(smc) ;		/* timer package */
101 	smt_agent_init(smc) ;		/* SMT frame manager */
102 
103 	pcm_init(smc) ;			/* PCM state machine */
104 	ecm_init(smc) ;			/* ECM state machine */
105 	cfm_init(smc) ;			/* CFM state machine */
106 	rmt_init(smc) ;			/* RMT state machine */
107 
108 	for (p = 0 ; p < NUMPHYS ; p++) {
109 		pcm(smc,p,0) ;		/* PCM A state machine */
110 	}
111 	ecm(smc,0) ;			/* ECM state machine */
112 	cfm(smc,0) ;			/* CFM state machine */
113 	rmt(smc,0) ;			/* RMT state machine */
114 
115 	smt_agent_task(smc) ;		/* NIF FSM etc */
116 
117         PNMI_INIT(smc) ;                /* PNMI initialization */
118 
119 	return 0;
120 }
121 
122