FreeCalypso > hg > tcs211-c139
comparison g23m/condat/ms/src/aci/psa_gpppf.c @ 0:509db1a7b7b8
initial import: leo2moko-r1
author | Space Falcon <falcon@ivan.Harhan.ORG> |
---|---|
date | Mon, 01 Jun 2015 03:24:05 +0000 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
-1:000000000000 | 0:509db1a7b7b8 |
---|---|
1 /* | |
2 +----------------------------------------------------------------------------- | |
3 | Project : | |
4 | Modul : | |
5 +----------------------------------------------------------------------------- | |
6 | Copyright 2002 Texas Instruments Berlin, AG | |
7 | All rights reserved. | |
8 | | |
9 | This file is confidential and a trade secret of Texas | |
10 | Instruments Berlin, AG | |
11 | The receipt of or possession of this file does not convey | |
12 | any rights to reproduce or disclose its contents or to | |
13 | manufacture, use, or sell anything it may describe, in | |
14 | whole, or in part, without the specific written consent of | |
15 | Texas Instruments Berlin, AG. | |
16 +----------------------------------------------------------------------------- | |
17 | Purpose : This module defines the functions for the protocol | |
18 | stack adapter for GPRS Point-to-Point Protocol ( PPP ). | |
19 +----------------------------------------------------------------------------- | |
20 */ | |
21 | |
22 #if defined (GPRS) && defined (DTI) | |
23 | |
24 #ifndef PSA_GPPPF_C | |
25 #define PSA_GPPPF_C | |
26 #endif | |
27 | |
28 #include "aci_all.h" | |
29 | |
30 #undef TRACING | |
31 /*==== INCLUDES ===================================================*/ | |
32 #include "dti.h" /* functionality of the dti library */ | |
33 #include "aci_cmh.h" | |
34 #include "ati_cmd.h" | |
35 #include "aci_cmd.h" | |
36 #include "aci.h" | |
37 #include "psa.h" | |
38 | |
39 #include "dti_conn_mng.h" | |
40 #include "dti_cntrl_mng.h" | |
41 | |
42 #include "gaci.h" | |
43 #include "gaci_cmh.h" | |
44 #include "cmh.h" | |
45 #include "cmh_sm.h" | |
46 | |
47 #include "psa_gppp.h" | |
48 #include "aci_io.h" | |
49 | |
50 #include "psa_uart.h" | |
51 #include "sap_dti.h" | |
52 #ifdef FF_PSI | |
53 #include "psa_psi.h" | |
54 #include "cmh_psi.h" | |
55 #include "ati_src_psi.h" | |
56 #endif /*FF_PSI*/ | |
57 | |
58 /*==== CONSTANTS ==================================================*/ | |
59 /*#define ITM_WDT (14)*/ /* item width in chars */ | |
60 /*#define HDR_WDT (10)*/ /* header width in chars */ | |
61 | |
62 /*==== TYPES ======================================================*/ | |
63 | |
64 | |
65 /*==== EXPORT =====================================================*/ | |
66 | |
67 | |
68 /*==== VARIABLES ==================================================*/ | |
69 | |
70 /*==== FUNCTIONS ==================================================*/ | |
71 EXTERN void cmhGPPP_send_establish_request( UBYTE peer ); | |
72 | |
73 /* | |
74 +-------------------------------------------------------------------+ | |
75 | PROJECT : GPRS (8441) MODULE : PSA_PPPF | | |
76 | STATE : code ROUTINE : psaGPPP_Init | | |
77 +-------------------------------------------------------------------+ | |
78 | |
79 PURPOSE : initialize the protocol stack adapter for PPP. | |
80 | |
81 */ | |
82 | |
83 /* MACRO: initializer for set parameter */ | |
84 #ifdef INIT_SET_PARM | |
85 #undef INIT_SET_PARM | |
86 #endif | |
87 | |
88 #define INIT_SET_PARM( dest, def )\ | |
89 for( LpCnt = 0; LpCnt < OWN_MAX; LpCnt++ )\ | |
90 gpppShrdPrm.setPrm[LpCnt].dest = def | |
91 | |
92 GLOBAL void psaGPPP_Init ( UBYTE accm, UBYTE restart_timer, | |
93 UBYTE max_configure, UBYTE max_terminate, UBYTE max_failure ) | |
94 { | |
95 | |
96 /* | |
97 *------------------------------------------------------------------- | |
98 * set default parms | |
99 *------------------------------------------------------------------- | |
100 */ | |
101 gpppShrdPrm.owner = (UBYTE) OWN_NONE; | |
102 gpppShrdPrm.ppp_authentication_protocol = PPP_AP_AUTO; | |
103 | |
104 gpppShrdPrm.accm = accm; | |
105 gpppShrdPrm.restart_timer = restart_timer; | |
106 gpppShrdPrm.max_configure = max_configure; | |
107 gpppShrdPrm.max_terminate = max_terminate; | |
108 gpppShrdPrm.max_failure = max_failure; | |
109 | |
110 } | |
111 | |
112 GLOBAL void psaGPPPS_Dti_Req( T_DTI_CONN_LINK_ID link_id, UBYTE peer ) | |
113 { | |
114 | |
115 TRACE_FUNCTION("psaGPPPS_Dti_Req()"); | |
116 | |
117 switch ( peer ) | |
118 { | |
119 #ifdef BT_ADAPTER | |
120 case DTI_ENTITY_BLUETOOTH: | |
121 #endif /* BT_ADAPTER */ | |
122 case DTI_ENTITY_UART: | |
123 pdp_context[work_cids[0] - 1].link_id_uart = link_id; | |
124 dti_cntrl_set_conn_parms(link_id, DTI_ENTITY_UART, 0, 0); | |
125 dti_cntrl_set_conn_parms(link_id, DTI_ENTITY_PPPS, 0, 0); | |
126 if(DTI_TUPLE_NO_NOTPRESENT NEQ EXTRACT_TUPLE_NO(pdp_context[work_cids[0] - 1].link_id_new)) | |
127 { | |
128 io_setDCD (pdp_context[work_cids[0] - 1].owner, IO_DCD_ON); | |
129 cmhGPPP_send_establish_request(peer); | |
130 } | |
131 break; | |
132 #ifdef FF_PSI | |
133 case DTI_ENTITY_PSI: | |
134 pdp_context[work_cids[0] - 1].link_id_uart = link_id; | |
135 dti_cntrl_set_conn_parms(link_id, DTI_ENTITY_PSI, 0, 0); | |
136 dti_cntrl_set_conn_parms(link_id, DTI_ENTITY_PPPS, 0, 0); | |
137 if(DTI_TUPLE_NO_NOTPRESENT NEQ EXTRACT_TUPLE_NO(pdp_context[work_cids[0] - 1].link_id_new)) | |
138 { | |
139 io_setDCD (pdp_context[work_cids[0] - 1].owner, IO_DCD_ON); | |
140 cmhGPPP_send_establish_request(peer); | |
141 } | |
142 break; | |
143 #endif /*FF_PSI*/ | |
144 case DTI_ENTITY_AAA: | |
145 pdp_context[work_cids[0] - 1].link_id_uart = link_id; | |
146 dti_cntrl_set_conn_parms(link_id, DTI_ENTITY_AAA, 0, 0); | |
147 dti_cntrl_set_conn_parms(link_id, DTI_ENTITY_PPPS, 0, 0); | |
148 if(DTI_TUPLE_NO_NOTPRESENT NEQ EXTRACT_TUPLE_NO(pdp_context[work_cids[0] - 1].link_id_new)) | |
149 { | |
150 cmhGPPP_send_establish_request(peer); | |
151 } | |
152 break; | |
153 case DTI_ENTITY_SNDCP: | |
154 pdp_context[work_cids[0] - 1].link_id_new = link_id; | |
155 if(DTI_TUPLE_NO_NOTPRESENT NEQ EXTRACT_TUPLE_NO(pdp_context[work_cids[0] - 1].link_id_uart)) | |
156 { | |
157 T_DTI_ENTITY_ID other_peer = dti_cntrl_get_peer(DTI_ENTITY_PPPS, 0, 0); | |
158 if(DTI_ENTITY_UART EQ other_peer OR DTI_ENTITY_PSI EQ other_peer) | |
159 { | |
160 io_setDCD (pdp_context[work_cids[0] - 1].owner, IO_DCD_ON); | |
161 } | |
162 cmhGPPP_send_establish_request(other_peer); | |
163 } | |
164 break; | |
165 } | |
166 } | |
167 | |
168 /* | |
169 +-------------------------------------------------------------------------+ | |
170 | PROJECT : GSM-F&D (8411) MODULE : PSA_PPPF | | |
171 | STATE : code ROUTINE : PPP_UART_connect_dti_cb | | |
172 +-------------------------------------------------------------------------+ | |
173 | |
174 PURPOSE : Callback for DTI connection between PPP Server and UART. | |
175 | |
176 */ | |
177 GLOBAL BOOL PPP_UART_connect_dti_cb(UBYTE dti_id, T_DTI_CONN_STATE result_type) | |
178 { | |
179 TRACE_FUNCTION("PPP_UART_connect_dti_cb"); | |
180 | |
181 switch( result_type) | |
182 { | |
183 case DTI_CONN_STATE_DISCONNECTING: | |
184 break; | |
185 case DTI_CONN_STATE_DISCONNECTED: | |
186 dti_cntrl_clear_conn_parms(dti_id); | |
187 if (dti_cntrl_is_dti_id_to_reconnect(dti_id)) | |
188 { | |
189 T_DTI_ENTITY_ID entity_list[] = {DTI_ENTITY_ACI}; | |
190 T_DTI_CNTRL info; | |
191 | |
192 if (dti_cntrl_get_info_from_dti_id( dti_id, &info) EQ FALSE) | |
193 { | |
194 TRACE_EVENT_P1("cannot find info for dti_id=%d", dti_id); | |
195 return FALSE; | |
196 } | |
197 | |
198 if (info.dev_id EQ DTI_ENTITY_UART) | |
199 { | |
200 io_setDCD (info.src_id, IO_DCD_OFF); | |
201 | |
202 dti_cntrl_clear_dti_id_to_reconnect(dti_id); | |
203 dti_cntrl_est_dpath_indirect ( info.src_id, | |
204 entity_list, | |
205 1, | |
206 SPLIT, | |
207 atiUART_dti_cb, | |
208 DTI_CPBLTY_CMD, | |
209 DTI_CID_NOTPRESENT); | |
210 } | |
211 #ifdef FF_PSI | |
212 else if (info.dev_id EQ DTI_ENTITY_PSI) | |
213 { | |
214 io_setDCD (info.src_id, IO_DCD_OFF); | |
215 | |
216 dti_cntrl_clear_dti_id_to_reconnect(dti_id); | |
217 dti_cntrl_est_dpath_indirect ( info.src_id, | |
218 entity_list, | |
219 1, | |
220 SPLIT, | |
221 atiPSI_dti_cb, | |
222 DTI_CPBLTY_CMD, | |
223 DTI_CID_NOTPRESENT); | |
224 } | |
225 #endif /*FF_PSI*/ | |
226 else | |
227 return FALSE; | |
228 } | |
229 break; | |
230 | |
231 case DTI_CONN_STATE_CONNECTING: | |
232 break; | |
233 case DTI_CONN_STATE_CONNECTED: | |
234 break; | |
235 | |
236 case DTI_CONN_STATE_ERROR: | |
237 /* connection not possible: disconnect PPP */ | |
238 dti_cntrl_close_dpath_from_dti_id(dti_id); | |
239 break; | |
240 case DTI_CONN_STATE_UNKNOWN: | |
241 default: | |
242 TRACE_EVENT("PPP_UART_connect_dti_cb call with not awaited value"); | |
243 break; | |
244 } | |
245 return TRUE; | |
246 } | |
247 | |
248 /* | |
249 +--------------------------------------------------------------------------+ | |
250 | PROJECT : GSM-F&D (8411) MODULE : PSA_PPPF | | |
251 | STATE : code ROUTINE : PPP_SNDCP_connect_dti_cb | | |
252 +--------------------------------------------------------------------------+ | |
253 | |
254 PURPOSE : Callback for connection between PPP Server and SNDCP. | |
255 | |
256 */ | |
257 GLOBAL BOOL PPP_SNDCP_connect_dti_cb(UBYTE dti_id, T_DTI_CONN_STATE result_type) | |
258 { | |
259 TRACE_FUNCTION("PPP_SNDCP_connect_dti_cb"); | |
260 | |
261 switch( result_type) | |
262 { | |
263 case DTI_CONN_STATE_DISCONNECTING: | |
264 case DTI_CONN_STATE_DISCONNECTED: | |
265 case DTI_CONN_STATE_CONNECTING: | |
266 case DTI_CONN_STATE_CONNECTED: | |
267 break; | |
268 case DTI_CONN_STATE_ERROR: | |
269 /* connection not possible: disconnect SNDCP */ | |
270 dti_cntrl_close_dpath_from_dti_id( dti_id ); | |
271 break; | |
272 case DTI_CONN_STATE_UNKNOWN: | |
273 default: | |
274 TRACE_EVENT("PPP_SNDCP_connect_dti_cb call with not awaited value"); | |
275 break; | |
276 } | |
277 return TRUE; | |
278 } | |
279 | |
280 #if 0 | |
281 /* | |
282 +-------------------------------------------------------------------+ | |
283 | PROJECT : GSM-PS (6147) MODULE : PSA_PPPF | | |
284 | ROUTINE : psaGPPP_shrPrmDump | | |
285 +-------------------------------------------------------------------+ | |
286 | |
287 PURPOSE : this function dumps the shared parameter to the debug | |
288 output. | |
289 */ | |
290 | |
291 GLOBAL void psaGPPP_shrPrmDump ( void ) | |
292 { | |
293 #ifdef TRACING | |
294 | |
295 char lnBuf [80]; /* holds buffer for output line */ | |
296 char mccBuf[SIZE_MCC + 1]; /* MCC converted to printable C-string */ | |
297 char mncBuf[SIZE_MNC + 1]; /* MNC converted to printable C-string */ | |
298 SHORT chrNr; /* holds number of processed chars */ | |
299 SHORT cnt; /* holds a counter */ | |
300 | |
301 /* --- PLMN list ------------------------------------------------*/ | |
302 for( cnt = 0; cnt<MAX_PLMN_ID AND | |
303 mmShrdPrm.PLMNLst[cnt].v_plmn NEQ INVLD_PLMN; cnt++ ) | |
304 { | |
305 chrNr = sprintf( lnBuf, "%*.*s[%2d]", HDR_WDT, HDR_WDT, " PLMN list",cnt ); | |
306 utl_BCD2String (mccBuf, mmShrdPrm.PLMNLst[cnt].mcc, SIZE_MCC); | |
307 utl_BCD2String (mncBuf, mmShrdPrm.PLMNLst[cnt].mnc, SIZE_MNC); | |
308 chrNr += sprintf( lnBuf+chrNr, "%*s %*s", | |
309 ITM_WDT/2, ITM_WDT/2, mccBuf, mncBuf); | |
310 TRACE_EVENT( lnBuf ); | |
311 } | |
312 | |
313 /* --- used PLMN ------------------------------------------------*/ | |
314 chrNr = sprintf( lnBuf, "%*.*s", HDR_WDT, HDR_WDT, " used PLMN" ); | |
315 if( mmShrdPrm.usedPLMN.v_plmn EQ VLD_PLMN ) | |
316 { | |
317 utl_BCD2String (mccBuf, mmShrdPrm.usedPLMN.mcc, SIZE_MCC); | |
318 utl_BCD2String (mncBuf, mmShrdPrm.usedPLMN.mnc, SIZE_MNC); | |
319 chrNr += sprintf( lnBuf+chrNr, "%*s %*s", | |
320 ITM_WDT/2, ITM_WDT/2, mccBuf, mncBuf); | |
321 } | |
322 else | |
323 { | |
324 chrNr += sprintf( lnBuf+chrNr, "%*s", ITM_WDT, "none" ); | |
325 } | |
326 TRACE_EVENT( lnBuf ); | |
327 | |
328 /* --- registration mode ----------------------------------------*/ | |
329 chrNr = sprintf( lnBuf, "%*.*s", HDR_WDT, HDR_WDT, "rgstr mode" ); | |
330 chrNr += sprintf( lnBuf+chrNr, "%*hd", ITM_WDT, | |
331 mmShrdPrm.setPrm[0].regMode ); | |
332 TRACE_EVENT( lnBuf ); | |
333 | |
334 /* --- registration status --------------------------------------*/ | |
335 chrNr = sprintf( lnBuf, "%*.*s", HDR_WDT, HDR_WDT, "rgstr stat" ); | |
336 chrNr += sprintf( lnBuf+chrNr, "%*hd", ITM_WDT, | |
337 mmShrdPrm.regStat ); | |
338 TRACE_EVENT( lnBuf ); | |
339 | |
340 /* --- search result --------------------------------------------*/ | |
341 chrNr = sprintf( lnBuf, "%*.*s", HDR_WDT, HDR_WDT, " srch rslt" ); | |
342 chrNr += sprintf( lnBuf+chrNr, "%*hd", ITM_WDT, | |
343 mmShrdPrm.srchRslt ); | |
344 TRACE_EVENT( lnBuf ); | |
345 | |
346 /* --- de-registration cause ------------------------------------*/ | |
347 chrNr = sprintf( lnBuf, "%*.*s", HDR_WDT, HDR_WDT, "dereg caus" ); | |
348 chrNr += sprintf( lnBuf+chrNr, "%*X", ITM_WDT, | |
349 mmShrdPrm.deregCs ); | |
350 TRACE_EVENT( lnBuf ); | |
351 | |
352 #endif /* of #ifdef TRACING */ | |
353 } | |
354 #endif /* #if 0 */ | |
355 | |
356 #endif /* GPRS */ | |
357 /*==== EOF ========================================================*/ | |
358 |