comparison gsm-fw/g23m-aci/aci/cmh_simr.c @ 775:eedbf248bac0

gsm-fw/g23m-aci subtree: initial import from LoCosto source
author Michael Spacefalcon <msokolov@ivan.Harhan.ORG>
date Sun, 12 Oct 2014 01:45:14 +0000
parents
children 28f24c230edd
comparison
equal deleted inserted replaced
774:40a721fd9854 775:eedbf248bac0
1 /*
2 +-----------------------------------------------------------------------------
3 | Project : GSM-PS (6147)
4 | Modul : CMH_SIMR
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 which are responsible
18 | for the responses of the protocol stack adapter for
19 | the subscriber identity module.
20 +-----------------------------------------------------------------------------
21 */
22
23 #ifndef CMH_SIMR_C
24 #define CMH_SIMR_C
25 #endif
26
27 #include "aci_all.h"
28 /*==== INCLUDES ===================================================*/
29 #include "aci_mem.h"
30
31 #include "aci_cmh.h"
32 #include "ati_cmd.h"
33 #include "aci_cmd.h"
34 #include "pcm.h"
35
36 #ifdef FAX_AND_DATA
37 #include "aci_fd.h"
38 #endif /* of #ifdef FAX_AND_DATA */
39
40 #ifndef _SIMULATION_
41 #include "ffs/ffs.h"
42 #include "ffs_coat.h"
43 #endif
44
45 #ifdef DTI
46 #include "dti.h" /* functionality of the dti library */
47 #include "dti_conn_mng.h"
48 #include "dti_cntrl_mng.h"
49 #endif /* DTI */
50
51 #include "phb.h"
52 #include "ksd.h"
53 #include "aci.h"
54 #include "psa.h"
55 #include "psa_sim.h"
56 #include "psa_cc.h"
57 #include "psa_sat.h"
58 #include "psa_mm.h"
59 #include "cmh.h"
60 #include "cmh_sim.h"
61 #include "cmh_mm.h"
62 #include "cmh_phb.h"
63
64 #include "aci_ext_pers.h"
65 #include "aci_slock.h"
66 #include "psa_sms.h"
67
68 #ifdef SIM_PERS
69 #include "general.h" // included for compilation error UNIT8 in sec_drv.h
70 #include "sec_drv.h"
71 #endif
72
73 #ifdef GPRS
74 #include "gaci.h"
75 #include "gaci_cmh.h"
76 #include "psa_gmm.h"
77 #include "cmh_gmm.h"
78 #endif
79
80 #include "p_mmcm.h"
81 #include "m_cc.h"
82
83 #include "aoc.h"
84
85 #ifdef DTI
86 #include "wap_aci.h"
87 #include "psa_tcpip.h"
88 #include "psa_l2r.h"
89 #endif
90
91 #ifdef SIM_PERS
92 EXTERN T_ACI_SIM_CONFIG aci_slock_sim_config; /* SIM configuration, initialised by a T_SIM_MMI_INSERT_IND */
93 EXTERN T_SEC_DRV_CONFIGURATION *cfg_data ;
94 #endif
95
96 /*==== CONSTANTS ==================================================*/
97
98
99 /*==== TYPES ======================================================*/
100
101
102 /*==== EXPORT =====================================================*/
103
104
105 /*==== VARIABLES ==================================================*/
106
107 /*==== FUNCTIONS ==================================================*/
108 LOCAL void cmhSIM_ProcessEvents ( T_ACI_AT_CMD at_cmd_id );
109 LOCAL void cmhSIM_Compare_CNUMMsisdnIdx ( void );
110 LOCAL void cmhSIM_SndError( T_ACI_CMD_SRC ownBuf,
111 T_ACI_AT_CMD cmdBuf,
112 T_ACI_CME_ERR cme_err );
113
114 /*
115 +-------------------------------------------------------------------+
116 | PROJECT : GSM-PS (6147) MODULE : CMH_SIMR |
117 | ROUTINE : cmhSIM_SIMSync |
118 +-------------------------------------------------------------------+
119
120 PURPOSE : SIM data synchronized
121
122 */
123
124 GLOBAL void cmhSIM_SIMSync ( void )
125 {
126 TRACE_FUNCTION ("cmhSIM_SIMSync()");
127
128 /* process event */
129 switch( simEntStat.curCmd )
130 {
131 case( AT_CMD_CFUN ):
132 if (mmEntStat.curCmd NEQ AT_CMD_CFUN) /* Has MM already deregistered? */
133 {
134 R_AT( RAT_OK, simEntStat.entOwn )
135 ( AT_CMD_CFUN );
136
137 /* log result */
138 cmh_logRslt ( simEntStat.entOwn, RAT_OK, AT_CMD_CFUN,
139 -1, BS_SPEED_NotPresent,CME_ERR_NotPresent );
140 }
141 /*lint -fallthrough*/
142 case( AT_CMD_COPS ):
143 case( AT_CMD_P_COPS ):
144
145 simEntStat.curCmd = AT_CMD_NONE;
146 break;
147 }
148 }
149
150 /*
151 +-------------------------------------------------------------------+
152 | PROJECT : GSM-PS (6147) MODULE : CMH_SIMR |
153 | ROUTINE : clck_fdn_accepted() |
154 +-------------------------------------------------------------------+
155
156 PURPOSE : PIN2 status allows CLCK changing the status concerning FDN.
157
158 */
159
160 LOCAL void clck_fdn_accepted ( void )
161 {
162 switch( simShrdPrm.setPrm[simEntStat.entOwn].actProc )
163 {
164 case( SIM_FDN_ENABLE ):
165 if( simShrdPrm.crdFun EQ SIM_ADN_ENABLED )
166 {
167 simShrdPrm.crdFun = SIM_FDN_ENABLED;
168 }
169 if( simShrdPrm.crdFun EQ SIM_ADN_BDN_ENABLED )
170 {
171 simShrdPrm.crdFun = SIM_FDN_BDN_ENABLED;
172 }
173
174 pb_switch_adn_fdn( FDN_ENABLE, simShrdPrm.classFDN ); /* inform PHB */
175 break;
176
177 case( SIM_FDN_DISABLE ):
178 if( simShrdPrm.crdFun EQ SIM_FDN_ENABLED )
179 {
180 simShrdPrm.crdFun = SIM_ADN_ENABLED;
181 }
182 if( simShrdPrm.crdFun EQ SIM_FDN_BDN_ENABLED )
183 {
184 simShrdPrm.crdFun = SIM_ADN_BDN_ENABLED;
185 }
186 pb_switch_adn_fdn( FDN_DISABLE, simShrdPrm.classFDN ); /* inform PHB */
187 break;
188 }
189 }
190
191 /*
192 +-------------------------------------------------------------------+
193 | PROJECT : GSM-PS (6147) MODULE : CMH_SIMR |
194 | ROUTINE : cmhsim_simactivated_clck |
195 +-------------------------------------------------------------------+
196 PURPOSE : SIM activated after AT+CLCK
197 */
198
199 LOCAL void cmhsim_simactivated_clck( void )
200 {
201 T_ACI_CME_ERR err = CME_ERR_Unknown;
202
203 TRACE_FUNCTION ("cmhsim_simactivated_clck()");
204
205 simEntStat.curCmd = AT_CMD_NONE;
206
207 switch( simShrdPrm.rslt )
208 {
209 case( SIM_NO_ERROR ):
210 clck_fdn_accepted();
211
212 R_AT( RAT_OK, simEntStat.entOwn )
213 ( AT_CMD_CLCK );
214 cmh_logRslt ( simEntStat.entOwn, RAT_OK, AT_CMD_CLCK, -1,
215 BS_SPEED_NotPresent,CME_ERR_NotPresent );
216 return;
217
218 case( SIM_CAUSE_PIN2_EXPECT ):
219 TRACE_EVENT_P1("simShrdPrm.pn2Stat: %d", simShrdPrm.pn2Stat);
220
221 if ( simShrdPrm.pn2Stat EQ PS_PIN2 )
222 {
223 if ( ( simShrdPrm.setPrm[simEntStat.entOwn].curPIN[0] NEQ 0x00 ) AND
224 ( simShrdPrm.setPrm[simEntStat.entOwn].curPIN[0] NEQ NOT_PRESENT_CHAR ) )
225 {
226 /* if PIN2 is required and a pin is given, then check pin with PIN2 */
227 simEntStat.curCmd = AT_CMD_CLCK; /* further processing */
228
229 simShrdPrm.setPrm[simEntStat.entOwn].PINType = PHASE_2_PIN_2;
230 psaSIM_VerifyPIN(); /* verify PIN */
231 return;
232 }
233 else
234 {
235 /* if PIN2 is required and no pin is given, then send cme_err with PIN2
236 required message code */
237 if ( simShrdPrm.PINStat EQ PS_RDY )
238 {
239 simShrdPrm.PINStat = PS_PIN2;
240 }
241 err = CME_ERR_SimPin2Req;
242 }
243 }
244 else
245 {
246 err = CME_ERR_WrongPasswd;
247 }
248 break;
249
250 /*case( SIM_CAUSE_PIN1_EXPECT ):
251 case( SIM_CAUSE_PUK1_EXPECT ):*/
252
253 /* Should be CME_ERR_SimPuk2Req, and it is done
254 in the default case
255 case( SIM_CAUSE_PIN2_BLOCKED):
256 case( SIM_CAUSE_PUK2_EXPECT ):
257 err = CME_ERR_WrongPasswd;
258 break;*/
259
260 default:
261 err = cmhSIM_GetCmeFromSim( simShrdPrm.rslt );
262 break;
263 }
264
265 R_AT( RAT_CME, simEntStat.entOwn )
266 ( AT_CMD_CLCK, err );
267 cmh_logRslt ( simEntStat.entOwn, RAT_CME, AT_CMD_CLCK,
268 -1, BS_SPEED_NotPresent, err );
269
270 }
271
272 /*
273 +-------------------------------------------------------------------+
274 | PROJECT : GSM-PS (6147) MODULE : CMH_SIMR |
275 | ROUTINE : cmhsim_simactivated_start |
276 +-------------------------------------------------------------------+
277 PURPOSE : SIM activated after AT+CFUN, +CPIN, +CIMI and %NRG
278 */
279 LOCAL void simactivated_cpinresult( T_ACI_CPIN_RSLT cpin_result )
280 {
281 R_AT( RAT_CPIN, simEntStat.entOwn )
282 ( cpin_result );
283 R_AT( RAT_OK, simEntStat.entOwn )
284 ( AT_CMD_CPIN );
285 cmh_logRslt ( simEntStat.entOwn, RAT_OK, AT_CMD_CPIN,
286 -1, BS_SPEED_NotPresent,CME_ERR_NotPresent );
287 }
288
289 LOCAL void simactivated_errorresult( T_ACI_CME_ERR error_result, T_ACI_AT_CMD cmdBuf )
290 {
291 R_AT( RAT_CME, simEntStat.entOwn )
292 ( cmdBuf, error_result );
293
294 if( cmdBuf NEQ AT_CMD_CIMI )
295 {
296 cmh_logRslt ( simEntStat.entOwn, RAT_CME, cmdBuf,
297 -1, BS_SPEED_NotPresent, error_result );
298 }
299 }
300
301 LOCAL void cmhsim_simactivated_start( void )
302 {
303 T_ACI_AT_CMD cmdBuf = simEntStat.curCmd; /* buffers current command */
304
305 TRACE_FUNCTION ("cmhsim_simactivated_start()");
306
307 simEntStat.curCmd = AT_CMD_NONE;
308
309 switch( simShrdPrm.SIMStat )
310 {
311 case( SS_INV ):
312 simactivated_errorresult( CME_ERR_SimWrong, cmdBuf );
313 return;
314
315 case( SS_URCHB ):
316 simactivated_errorresult( CME_ERR_SimNotIns, cmdBuf );
317 return;
318
319 case( NO_VLD_SS ):
320 simactivated_errorresult( CME_ERR_NotPresent, cmdBuf );
321 return;
322
323 case( SS_OK ):
324 switch( simShrdPrm.PINStat )
325 {
326 case( PS_PIN1 ):
327 if( cmdBuf EQ AT_CMD_CPIN )
328 {
329 simactivated_cpinresult( CPIN_RSLT_SimPinReq );
330 }
331 else
332 {
333 simactivated_errorresult( CME_ERR_SimPinReq, cmdBuf );
334 }
335 break;
336
337 case( PS_PIN2 ):
338 if( cmdBuf EQ AT_CMD_CPIN )
339 {
340 simactivated_cpinresult( CPIN_RSLT_SimPin2Req );
341 }
342 else
343 {
344 simactivated_errorresult( CME_ERR_SimPin2Req, cmdBuf );
345 }
346 break;
347
348 case( PS_RDY ):
349 /* wait for SIM insert indication to complete command */
350 simEntStat.curCmd = cmdBuf;
351 break;
352 }
353 break;
354
355 case( SS_BLKD ):
356
357 switch( simShrdPrm.PINStat )
358 {
359 case( PS_PUK1 ):
360 if( cmdBuf EQ AT_CMD_CPIN )
361 {
362 simactivated_cpinresult( CPIN_RSLT_SimPukReq );
363 }
364 else
365 {
366 simactivated_errorresult( CME_ERR_SimPukReq, cmdBuf );
367 }
368 break;
369
370 case( PS_PUK2 ):
371 if( cmdBuf EQ AT_CMD_CPIN )
372 {
373 simactivated_cpinresult( CPIN_RSLT_SimPuk2Req );
374 }
375 else
376 {
377 simactivated_errorresult( CME_ERR_SimPuk2Req, cmdBuf );
378 }
379 break;
380 }
381 break;
382
383 }
384 }
385
386 /*
387 +-------------------------------------------------------------------+
388 | PROJECT : GSM-PS (6147) MODULE : CMH_SIMR |
389 | ROUTINE : cmhSIM_SIMActivated |
390 +-------------------------------------------------------------------+
391
392 PURPOSE : SIM activated
393
394 */
395
396 GLOBAL void cmhSIM_SIMActivated ( void )
397 {
398 T_ACI_CMD_SRC idx;
399
400 TRACE_FUNCTION ("cmhSIM_SIMActivated()");
401
402 /* check for command context */
403 switch( simEntStat.curCmd )
404 {
405 case( AT_CMD_CFUN ):
406 case( AT_CMD_CPIN ):
407 case( AT_CMD_CIMI ):
408 case( AT_CMD_NRG ):
409 case( AT_CMD_SIMRST):
410 /* process event for +CFUN, +CPIN, +CIMI and for %NRG command */
411 cmhsim_simactivated_start( );
412 break;
413
414 case( AT_CMD_CLCK ):
415 /* process event for +CLCK command */
416 cmhsim_simactivated_clck( );
417 break;
418
419 case( AT_CMD_NONE ):
420 /* process event spontaneous insertion */
421 if (simShrdPrm.rslt EQ SIM_NO_ERROR)
422 {
423 ; /* do nothing right now since the %SIMINS: -1 must be
424 syncronized with SIM_MMI_INSERT_IND which will come later! */
425 }
426 else
427 {
428 for( idx = CMD_SRC_LCL; idx < CMD_SRC_MAX; idx++ )
429 {
430 R_AT( RAT_SIMINS, idx )(cmhSIM_GetCmeFromSim (simShrdPrm.rslt));
431 }
432 }
433 break;
434 }
435 }
436
437 /*
438 +-------------------------------------------------------------------+
439 | PROJECT : GSM-PS (6147) MODULE : CMH_SIMR |
440 | ROUTINE : cmhSIM_SIMInserted |
441 +-------------------------------------------------------------------+
442
443 PURPOSE : SIM inserted
444
445 */
446
447 GLOBAL void cmhSIM_SIMInserted ( void )
448 {
449 USHORT cmdBuf; /* buffers current command */
450 CHAR imsiBuf[MAX_IMSI_LEN+1]; /* buffer IMSI representation +1 for '\0'*/
451 T_ACI_CME_ERR err_code = CME_ERR_NotPresent; /* code holding the correct error code calculated */
452 #ifdef SIM_PERS
453 T_ACI_CPIN_RSLT code = CPIN_RSLT_NotPresent;
454 #endif
455 BOOL return_rat_ok = 1; /* return ok? */
456
457 TRACE_FUNCTION ("cmhSIM_SIMInserted()");
458
459 /* Check if the SIM is functional and the IMSI value is valid*/
460 if ( simShrdPrm.crdFun EQ SIM_NO_OPERATION OR
461 simShrdPrm.imsi.c_field EQ 0 )
462 {
463 simShrdPrm.SIMStat = SS_INV;
464 err_code = CME_ERR_SimWrong;
465 }
466 cmdBuf = simEntStat.curCmd;
467 switch( cmdBuf )
468 {
469 case( AT_CMD_CFUN ):
470 case( AT_CMD_CPIN ):
471 case( AT_CMD_PVRF ):
472 case( AT_CMD_SIMRST):
473 case( KSD_CMD_UBLK):
474 /*
475 *----------------------------------------------------------------
476 * process event for +CFUN, +CPIN, %PVRF commands and for the
477 SIM reset condition
478 *----------------------------------------------------------------
479 */
480
481 simEntStat.curCmd = AT_CMD_NONE;
482 #ifdef SIM_PERS
483 if((aci_slock_sim_config.sim_type EQ SIM_TYPEAPPROVAL) AND AciSLockShrd.blocked)
484 {
485 simShrdPrm.SIMStat = SS_INV;
486 err_code = CME_ERR_SimWrong;
487 }
488 if(cfg_data EQ NULL)
489 {
490 simShrdPrm.SIMStat = SS_INV;
491 ACI_ERR_DESC( ACI_ERR_CLASS_Ext, EXT_ERR_NoMEPD );
492 err_code = CME_ERR_Unknown;
493 aci_slock_send_RAT(cmdBuf,err_code);
494 simShrdPrm.PINQuery = 0;
495 AciSLockShrd.cpin_query = SEND_CPIN_REQ_CODE_NONE;
496 return;
497 }
498 #endif
499
500 if( err_code EQ CME_ERR_SimWrong )
501 {
502 R_AT( RAT_CME, simEntStat.entOwn ) ((T_ACI_AT_CMD) cmdBuf, err_code );
503 cmh_logRslt ( simEntStat.entOwn, RAT_CME, (T_ACI_AT_CMD)cmdBuf, -1, BS_SPEED_NotPresent, err_code );
504 simShrdPrm.PINQuery = 0;
505 #ifdef SIM_PERS
506 AciSLockShrd.cpin_query = SEND_CPIN_REQ_CODE_NONE;
507 #endif
508 return;
509 }
510
511 #ifdef SIM_PERS
512 /* check for personalisation locking. If SIM was detected as not correct, do signal AT_CPIN */
513
514 if ( AciSLockShrd.blocked)
515 {
516 return_rat_ok = 0;
517 if(AciSLockShrd.cpin_query EQ SEND_CPIN_REQ_CODE_NONE)
518 {
519 /* @GBR: Alternativly CME_ERR_SimWrong might be returned, but this way is telling the MMI mor specific, what went wrong. */
520
521 aci_set_cme_error_code_and_logRslt( cmdBuf );
522 }
523 else
524 {
525 if(AciSLockShrd.cpin_query EQ SEND_CPIN_REQ_CODE_RAT )
526 {
527 aci_set_cpin_code(AciSLockShrd.current_lock,&code);
528 R_AT( RAT_CPIN, simEntStat.entOwn )
529 ( code );
530 }
531 AciSLockShrd.cpin_query = SEND_CPIN_REQ_CODE_NONE;
532 }
533 }
534
535 #endif
536 if ( (cmdBuf EQ AT_CMD_CPIN) AND (simShrdPrm.PINQuery EQ 1) ) /* Case when PIN is disabled and CFUN=0 */
537 {
538 R_AT( RAT_CPIN, simEntStat.entOwn )
539 ( CPIN_RSLT_SimReady );
540 simShrdPrm.PINQuery = 0;
541 }
542
543 #if defined (GPRS) AND defined (DTI)
544 gprs_sim_inserted();
545 #endif /* GPRS */
546
547 if (return_rat_ok EQ 1) /* @gbr: only send ok, if everhing went okay. The +CFUN might not be ready here, so don't send something! */
548 {
549
550 R_AT( RAT_OK, simEntStat.entOwn ) ((T_ACI_AT_CMD) cmdBuf );
551 cmh_logRslt ( simEntStat.entOwn, RAT_OK,(T_ACI_AT_CMD) cmdBuf, -1, BS_SPEED_NotPresent, CME_ERR_NotPresent );
552 #ifdef SIM_PERS
553 AciSLockShrd.cpin_query = SEND_CPIN_REQ_CODE_NONE;
554 #endif
555 }
556 break;
557
558 case( AT_CMD_CIMI ):
559 /*
560 *----------------------------------------------------------------
561 * process event for +CIMI command
562 *----------------------------------------------------------------
563 */
564
565
566 if( err_code EQ CME_ERR_SimWrong )
567 {
568 R_AT( RAT_CME, simEntStat.entOwn ) ( AT_CMD_CIMI, err_code );
569 cmh_logRslt ( simEntStat.entOwn, RAT_CME, AT_CMD_CIMI, -1, BS_SPEED_NotPresent, err_code );
570 return;
571 }
572
573 R_AT( RAT_CIMI, simEntStat.entOwn )
574 ( psaSIM_cnvrtIMSI2ASCII( imsiBuf ));
575
576 simEntStat.curCmd = AT_CMD_NONE;
577
578 R_AT( RAT_OK, simEntStat.entOwn )
579 ( AT_CMD_CIMI );
580 break;
581
582 case( AT_CMD_NRG ):
583 /*
584 *----------------------------------------------------------------
585 * process event for %NRG
586 *----------------------------------------------------------------
587 */
588 if( err_code EQ CME_ERR_SimWrong )
589 {
590 simEntStat.curCmd = AT_CMD_NONE;
591 mmEntStat.curCmd = AT_CMD_NONE;
592 R_AT( RAT_CME, simEntStat.entOwn ) ( (T_ACI_AT_CMD)cmdBuf, err_code );
593 cmh_logRslt ( simEntStat.entOwn, RAT_CME, (T_ACI_AT_CMD)cmdBuf, -1, BS_SPEED_NotPresent, err_code );
594 return;
595 }
596
597 switch( cmhPrm[simShrdPrm.owner].mmCmdPrm.NRGregMode )
598 {
599 case( NRG_RGMD_Auto ):
600
601 mmShrdPrm.regMode = MODE_AUTO;
602
603 simEntStat.curCmd = AT_CMD_NONE;
604 mmEntStat.curCmd = AT_CMD_NRG;
605 mmShrdPrm.owner = simShrdPrm.owner;
606 mmEntStat.entOwn = (T_ACI_CMD_SRC)simShrdPrm.owner;
607
608 #if defined (GPRS) AND defined (DTI)
609 (void)psaG_MM_CMD_REG (); /* register to network */
610 #else
611 (void)psaMM_Registrate (); /* register to network */
612 #endif
613
614 cmhMM_Ntfy_NtwRegistrationStatus(CREG_STAT_Search);
615 break;
616
617 case( NRG_RGMD_Manual ):
618
619 mmShrdPrm.regMode = MODE_MAN;
620
621 simEntStat.curCmd = AT_CMD_NONE;
622 mmEntStat.curCmd = AT_CMD_NRG;
623 mmShrdPrm.owner = simShrdPrm.owner;
624 mmEntStat.entOwn = (T_ACI_CMD_SRC) simShrdPrm.owner;
625
626 #if defined (GPRS) && defined (DTI)
627 psaG_MM_CMD_NET_SEL ( ); /* register to network */
628 #else
629 psaMM_NetSel (); /* register to network */
630 #endif
631
632 cmhMM_Ntfy_NtwRegistrationStatus(CREG_STAT_Search);
633 break;
634 }
635 break;
636
637 case( AT_CMD_NONE ):
638 {
639 T_ACI_CMD_SRC idx;
640 //TISH, patch for ASTec31853
641 //start
642 /*modified for Roaming issue*/
643 TRACE_EVENT("reset mm reg stat");
644 mmShrdPrm.regStat = NO_VLD_RS;
645 //end
646 /* process event spontaneous insertion */
647 for( idx = CMD_SRC_LCL; idx < CMD_SRC_MAX; idx++ )
648 {
649 R_AT( RAT_SIMINS, idx )( err_code );
650 }
651 }
652 break;
653
654 }
655 }
656
657 /*
658 +-------------------------------------------------------------------+
659 | PROJECT : GSM-PS (6147) MODULE : CMH_SIMR |
660 | ROUTINE : cmhSIM_SIMRemoved |
661 +-------------------------------------------------------------------+
662
663 PURPOSE : SIM removed
664
665 */
666
667 GLOBAL void cmhSIM_SIMRemoved ( void )
668 {
669 T_ACI_AT_CMD cmdBuf; /* buffers command */
670 T_ACI_CMD_SRC idx;
671 T_ACI_CME_ERR cme_error; /* CME error code */
672 T_ACI_SIMREM_TYPE srt; /* type of SIM remove */
673
674 TRACE_FUNCTION ("cmhSIM_SIMRemoved()");
675
676 if (simEntStat.curCmd NEQ AT_CMD_NONE)
677 {
678 cmdBuf = simEntStat.curCmd;
679 simEntStat.curCmd = AT_CMD_NONE;
680
681 if (simShrdPrm.rslt EQ SIM_NO_ERROR)
682 cme_error = CME_ERR_SimBusy;
683 else
684 cme_error = cmhSIM_GetCmeFromSim (simShrdPrm.rslt);
685
686 R_AT( RAT_CME, simEntStat.entOwn )
687 ( cmdBuf, cme_error );
688 cmh_logRslt ( simEntStat.entOwn, RAT_CME, cmdBuf,
689 -1, BS_SPEED_NotPresent, cme_error );
690 }
691 EfPLMNselStat = EF_STAT_UNKNWN;
692 /*
693 *----------------------------------------------------------------
694 * send unsolicited result
695 *----------------------------------------------------------------
696 */
697 TRACE_EVENT_P1("Result of SIM remove indication: %x", simShrdPrm.rslt);
698 switch (simShrdPrm.rslt)
699 {
700 case SIM_NO_ERROR:
701 /* In this case the AT command state is set to SIM RESET */
702 /* NO, don't do this!
703 This line would prevent a %SIMIND: 11 and instead leads to
704 "+CME ERROR: SIM PIN required" without any command context which is wrong */
705 /* simEntStat.curCmd = AT_CMD_SIMRST; */
706 srt = SIMREM_RESET;
707 break;
708 case SIM_CAUSE_DRV_TEMPFAIL:
709 srt = SIMREM_RETRY;
710 break;
711 default:
712 srt = SIMREM_FAILURE;
713 break;
714 }
715
716 for( idx = CMD_SRC_LCL; idx < CMD_SRC_MAX; idx++ )
717 {
718 R_AT( RAT_SIMREM, idx )(srt);
719 }
720 }
721
722 /*
723 +-------------------------------------------------------------------+
724 | PROJECT : GSM-PS (6147) MODULE : CMH_SIMR |
725 | ROUTINE : cmhSIM_PINVerified |
726 +-------------------------------------------------------------------+
727
728 PURPOSE : SIM verified
729
730 */
731 LOCAL void pin_verified_clck (USHORT sim_result)
732 {
733 TRACE_FUNCTION ("pin_verified_clck()");
734
735 switch(sim_result)
736 {
737 case( SIM_NO_ERROR ):
738 /* now do it ! */
739
740 /* Check if we want to do FDN Lock or ALS Lock */
741 switch (simShrdPrm.setPrm[simShrdPrm.owner].actProc)
742 {
743 case SIM_FDN_ENABLE:
744 case SIM_FDN_DISABLE:
745 /* FDN Lock */
746 if( psaSIM_ActivateSIM() < 0 ) /* activate SIM card */
747 {
748 simEntStat.curCmd = AT_CMD_NONE;
749
750 R_AT( RAT_CME, simEntStat.entOwn )
751 ( AT_CMD_CLCK, CME_ERR_Unknown );
752 cmh_logRslt ( simEntStat.entOwn, RAT_CME, AT_CMD_CLCK,
753 -1, BS_SPEED_NotPresent, CME_ERR_Unknown );
754 }
755 break;
756
757 case SIM_ALS_LOCK:
758 case SIM_ALS_UNLOCK:
759 /* ALS Lock to PIN2 */
760 if (simShrdPrm.setPrm[simShrdPrm.owner].actProc EQ SIM_ALS_LOCK)
761 {
762 ALSlock = cmhPrm[simShrdPrm.owner].ccCmdPrm.ALSmode;
763 /* pull all sources to the current ALSmode, otherwise a lock won't make sense */
764 {
765 int i;
766 for (i=0; i<OWN_SRC_MAX; i++)
767 cmhPrm[i].ccCmdPrm.ALSmode = ALSlock;
768 /* and lock them all */
769 }
770 #ifndef _SIMULATION_
771 /* write Lock to FFS */
772 /* Implements Measure#32: Row 1071 */
773 FFS_fwrite(gsm_com_alslock_path, &ALSlock, sizeof(ALSlock));
774 #endif
775 }
776 else
777 /* unlock ALS */
778 {
779 ALSlock = ALS_MOD_NOTPRESENT;
780 #ifndef _SIMULATION_
781 /* remove lock from FFS */
782 /* Implements Measure#32: Row 1071 */
783 FFS_remove(gsm_com_alslock_path);
784 #endif
785 }
786
787 simEntStat.curCmd = AT_CMD_NONE;
788
789 R_AT( RAT_OK, simEntStat.entOwn )
790 ( AT_CMD_CLCK );
791 cmh_logRslt ( simEntStat.entOwn, RAT_OK, AT_CMD_CLCK, -1, BS_SPEED_NotPresent,CME_ERR_NotPresent);
792 break;
793
794 }
795 break; /* SIM_NO_ERROR */
796
797 case( SIM_CAUSE_PIN1_EXPECT ):
798 case( SIM_CAUSE_PIN2_EXPECT ):
799 case( SIM_CAUSE_PIN1_BLOCKED ):
800 case( SIM_CAUSE_PUK1_EXPECT ):
801 case( SIM_CAUSE_PIN2_BLOCKED ):
802 case( SIM_CAUSE_PUK2_EXPECT ):
803 simEntStat.curCmd = AT_CMD_NONE;
804
805 R_AT( RAT_CME, simEntStat.entOwn )
806 ( AT_CMD_CLCK, cmhSIM_GetCmeFromSim ( sim_result ) /*CME_ERR_WrongPasswd*/ );
807 cmh_logRslt ( simEntStat.entOwn, RAT_CME, AT_CMD_CLCK,
808 -1,BS_SPEED_NotPresent, CME_ERR_WrongPasswd );
809 break;
810
811 default:
812 simEntStat.curCmd = AT_CMD_NONE;
813 R_AT( RAT_CME, simEntStat.entOwn )
814 ( AT_CMD_CLCK, CME_ERR_SimFail );
815 cmh_logRslt ( simEntStat.entOwn, RAT_CME, AT_CMD_CLCK,
816 -1, BS_SPEED_NotPresent, CME_ERR_SimFail );
817 break;
818 }
819 }
820
821 GLOBAL void cmhSIM_PINVerified ( void )
822 {
823 T_ACI_AT_CMD cmdBuf; /* buffers command */
824 T_PHB_CMD_PRM * pPHBCmdPrm; /* points to PHB command parameters */
825
826 TRACE_FUNCTION ("cmhSIM_PINVerified()");
827
828 pPHBCmdPrm = &cmhPrm[simShrdPrm.owner].phbCmdPrm;
829
830 /*
831 *-------------------------------------------------------------------
832 * check for command context
833 *-------------------------------------------------------------------
834 */
835 switch( simEntStat.curCmd )
836 {
837 case( AT_CMD_CLCK ):
838 /* process event for +CLCK command */
839 pin_verified_clck( simShrdPrm.rslt );
840 return;
841
842 case( AT_CMD_CPIN ):
843 case( AT_CMD_PVRF ):
844 /*
845 *----------------------------------------------------------------
846 * process event for +CPIN and %PVRF command
847 *----------------------------------------------------------------
848 */
849 switch( simShrdPrm.rslt )
850 {
851 case( SIM_NO_ERROR ):
852
853 /* if verified PIN was PIN 2 or PIN 1 was already entered */
854 if( simShrdPrm.setPrm[simEntStat.entOwn].PINType EQ
855 PHASE_2_PIN_2 OR
856 simShrdPrm.crdPhs NEQ 0xFF )
857 {
858 cmdBuf = simEntStat.curCmd;
859 simEntStat.curCmd = AT_CMD_NONE;
860
861 R_AT( RAT_OK, simEntStat.entOwn )
862 ( cmdBuf );
863 cmh_logRslt ( simEntStat.entOwn, RAT_OK, cmdBuf, -1, BS_SPEED_NotPresent,CME_ERR_NotPresent);
864 }
865 /* otherwise wait for SIM insert indication to complete command */
866 break;
867
868 case( SIM_CAUSE_PIN1_EXPECT ):
869 case( SIM_CAUSE_PIN2_EXPECT ):
870 case( SIM_CAUSE_PUK1_EXPECT ):
871 case( SIM_CAUSE_PUK2_EXPECT ):
872 cmdBuf = simEntStat.curCmd;
873 simEntStat.curCmd = AT_CMD_NONE;
874
875 R_AT( RAT_CME, simEntStat.entOwn )
876 ( cmdBuf, CME_ERR_WrongPasswd );
877 cmh_logRslt ( simEntStat.entOwn, RAT_CME, cmdBuf,
878 -1, BS_SPEED_NotPresent, CME_ERR_WrongPasswd );
879 break;
880 case( SIM_CAUSE_PIN1_BLOCKED):
881 cmdBuf = simEntStat.curCmd;
882 simEntStat.curCmd = AT_CMD_NONE;
883
884 R_AT( RAT_CME, simEntStat.entOwn )
885 ( cmdBuf, CME_ERR_SimPukReq );
886 cmh_logRslt ( simEntStat.entOwn, RAT_CME, cmdBuf,
887 -1, BS_SPEED_NotPresent, CME_ERR_SimPukReq );
888 break;
889 case( SIM_CAUSE_PIN2_BLOCKED):
890 cmdBuf = simEntStat.curCmd;
891 simEntStat.curCmd = AT_CMD_NONE;
892
893 R_AT( RAT_CME, simEntStat.entOwn )
894 ( cmdBuf, CME_ERR_SimPuk2Req );
895 cmh_logRslt ( simEntStat.entOwn, RAT_CME, cmdBuf,
896 -1,BS_SPEED_NotPresent, CME_ERR_SimPuk2Req );
897 break;
898 default:
899 cmdBuf = simEntStat.curCmd;
900 simEntStat.curCmd = AT_CMD_NONE;
901 R_AT( RAT_CME, simEntStat.entOwn )
902 ( cmdBuf, CME_ERR_SimFail );
903 break;
904 }
905 break;
906
907 /* Implements Measure 106 */
908 case( AT_CMD_CAMM ):
909 case( AT_CMD_CPUC ):
910 case( AT_CMD_CACM ):
911 cmhSIM_ProcessEvents( simEntStat.curCmd );
912 break;
913 /*----------------------------------------------------------*
914 * The below code is for CPBW SIM verification response *
915 *----------------------------------------------------------*/
916
917 case( AT_CMD_CPBS ):
918 /*
919 *----------------------------------------------------------------
920 * process event for +CPBW command
921 *----------------------------------------------------------------
922 */
923 switch( simShrdPrm.rslt )
924 {
925 case( SIM_NO_ERROR ):
926
927 /*-----------------------------------------------*
928 * if verified PIN was PIN 2 was already entered *
929 *-----------------------------------------------*/
930
931 cmdBuf = simEntStat.curCmd;
932 simEntStat.curCmd = AT_CMD_NONE;
933
934 pPHBCmdPrm->cmhStor = (T_ACI_PB_STOR)pPHBCmdPrm->temp_cmhStor;
935 pPHBCmdPrm->phbStor = pPHBCmdPrm->temp_phbStor;
936
937 R_AT( RAT_OK, simEntStat.entOwn )
938 ( cmdBuf );
939
940 cmh_logRslt ( simEntStat.entOwn, RAT_OK, cmdBuf, -1, BS_SPEED_NotPresent,CME_ERR_NotPresent );
941
942 /*---------------------------------------------------------------*
943 * otherwise wait for SIM insert indication to complete command *
944 *---------------------------------------------------------------*/
945
946 break;
947
948 case( SIM_CAUSE_PUK2_EXPECT ):
949 case( SIM_CAUSE_PIN2_BLOCKED):
950 case( SIM_CAUSE_PIN2_EXPECT ):
951
952 cmdBuf = simEntStat.curCmd;
953 simEntStat.curCmd = AT_CMD_NONE;
954
955 R_AT( RAT_CME, simEntStat.entOwn )
956 ( cmdBuf, CME_ERR_WrongPasswd );
957 cmh_logRslt ( simEntStat.entOwn, RAT_CME, cmdBuf,
958 -1, BS_SPEED_NotPresent, CME_ERR_WrongPasswd );
959 break;
960
961 default:
962 cmdBuf = simEntStat.curCmd;
963 simEntStat.curCmd = AT_CMD_NONE;
964 R_AT( RAT_CME, simEntStat.entOwn )
965 ( cmdBuf, CME_ERR_SimFail );
966 break;
967 }
968 break;
969
970 default:
971
972 simEntStat.curCmd = AT_CMD_NONE;
973 R_AT( RAT_CME, simEntStat.entOwn )
974 ( AT_CMD_CPIN, CME_ERR_Unknown );
975 cmh_logRslt ( simEntStat.entOwn, RAT_CME, AT_CMD_CPIN,
976 -1,BS_SPEED_NotPresent, CME_ERR_Unknown );
977 break;
978 }
979 }
980
981 /*
982 +-------------------------------------------------------------------+
983 | PROJECT : GSM-PS (6147) MODULE : CMH_SIMR |
984 | ROUTINE : cmhSIM_PINChanged |
985 +-------------------------------------------------------------------+
986
987 PURPOSE : SIM changed
988
989 */
990
991 GLOBAL void cmhSIM_PINChanged ( void )
992 {
993 T_ACI_CME_ERR err;
994 USHORT cmdBuf = simEntStat.curCmd;
995
996 TRACE_FUNCTION ("cmhSIM_PINChanged()");
997
998 /*
999 *-------------------------------------------------------------------
1000 * check for command context
1001 *-------------------------------------------------------------------
1002 */
1003 switch( cmdBuf )
1004 {
1005 case( AT_CMD_CPWD ):
1006 /*lint -e{408} */
1007 case( KSD_CMD_PWD ): /* KSD_CMD_* extends AT_CMD_* */
1008 /*
1009 *----------------------------------------------------------------
1010 * process event for +CPWD and KSD PWD command
1011 *----------------------------------------------------------------
1012 */
1013 switch( simShrdPrm.rslt )
1014 {
1015 case( SIM_NO_ERROR ):
1016
1017 simEntStat.curCmd = AT_CMD_NONE;
1018
1019 R_AT( RAT_OK, simEntStat.entOwn )
1020 ((T_ACI_AT_CMD) cmdBuf );
1021 cmh_logRslt ( simEntStat.entOwn, RAT_OK, (T_ACI_AT_CMD)cmdBuf, -1, BS_SPEED_NotPresent, CME_ERR_NotPresent );
1022 return;
1023
1024 /* why not use a meaningful CME error code?
1025 case( SIM_CAUSE_PUK1_EXPECT ):
1026 case( SIM_CAUSE_PUK2_EXPECT ): */
1027 case( SIM_CAUSE_PIN1_EXPECT ):
1028 case( SIM_CAUSE_PIN2_EXPECT ):
1029 err = CME_ERR_WrongPasswd;
1030 break;
1031
1032 default:
1033 err = cmhSIM_GetCmeFromSim ( simShrdPrm.rslt );
1034 break;
1035 }
1036
1037 simEntStat.curCmd = AT_CMD_NONE;
1038
1039 R_AT( RAT_CME, simEntStat.entOwn )
1040 ( (T_ACI_AT_CMD)cmdBuf, err );
1041 cmh_logRslt ( simEntStat.entOwn, RAT_CME, (T_ACI_AT_CMD)cmdBuf,
1042 -1, BS_SPEED_NotPresent, err );
1043 break;
1044 }
1045 }
1046
1047 /*
1048 +-------------------------------------------------------------------+
1049 | PROJECT : GSM-PS (6147) MODULE : CMH_SIMR |
1050 | ROUTINE : cmhSIM_CardUnblocked |
1051 +-------------------------------------------------------------------+
1052
1053 PURPOSE : Card unblocked
1054
1055 */
1056
1057 GLOBAL void cmhSIM_CardUnblocked ( void )
1058 {
1059 USHORT cmdBuf =simEntStat.curCmd ;
1060 T_ACI_CME_ERR err;
1061
1062 TRACE_FUNCTION ("cmhSIM_CardUnblocked()");
1063
1064 /*
1065 *-------------------------------------------------------------------
1066 * check for command context
1067 *-------------------------------------------------------------------
1068 */
1069 switch( cmdBuf )
1070 {
1071 case( AT_CMD_CPIN ):
1072 case( AT_CMD_PVRF ):
1073 /*lint -e{408} */
1074 case( KSD_CMD_UBLK ):
1075 /*
1076 *----------------------------------------------------------------
1077 * process event for +CPIN, %PVRF and KSD UBLK command
1078 *----------------------------------------------------------------
1079 */
1080 switch( simShrdPrm.rslt )
1081 {
1082 case( SIM_NO_ERROR ):
1083
1084 if(simShrdPrm.crdPhs NEQ 0xFF)/* If SIM insert indication is already received*/
1085 {
1086 simEntStat.curCmd = AT_CMD_NONE;
1087
1088 R_AT( RAT_OK, simEntStat.entOwn )
1089 ( (T_ACI_AT_CMD)cmdBuf );
1090 cmh_logRslt ( simEntStat.entOwn, RAT_OK,(T_ACI_AT_CMD) cmdBuf, -1, BS_SPEED_NotPresent, CME_ERR_NotPresent );
1091 }/* else wait till SIM insert indication is received*/
1092 return;
1093
1094 /* why not use a meaningful CME error code?
1095 case( SIM_CAUSE_PUK1_EXPECT ):
1096 case( SIM_CAUSE_PUK2_EXPECT ): */
1097 case( SIM_CAUSE_PIN1_EXPECT ):
1098 case( SIM_CAUSE_PIN2_EXPECT ):
1099 err = CME_ERR_WrongPasswd;
1100 break;
1101
1102 default:
1103 err = cmhSIM_GetCmeFromSim ( simShrdPrm.rslt );
1104 break;
1105 }
1106
1107 simEntStat.curCmd = AT_CMD_NONE;
1108
1109 R_AT( RAT_CME, simEntStat.entOwn )
1110 ( (T_ACI_AT_CMD)cmdBuf, err );
1111 cmh_logRslt ( simEntStat.entOwn, RAT_CME,(T_ACI_AT_CMD) cmdBuf,
1112 -1, BS_SPEED_NotPresent, err );
1113 break;
1114 }
1115 }
1116
1117 /*
1118 +-------------------------------------------------------------------+
1119 | PROJECT : GSM-PS (6147) MODULE : CMH_SIMR |
1120 | ROUTINE : cmhSIM_SIMResponseData |
1121 +-------------------------------------------------------------------+
1122
1123 PURPOSE : SIM response data
1124
1125 */
1126
1127 GLOBAL void cmhSIM_SIMResponseData( T_SIM_TRNS_RSP_PRM* rsp )
1128 {
1129 T_ACI_AT_CMD cmdBuf; /* buffers command */
1130 T_ACI_CMD_SRC ownBuf; /* buffers current owner */
1131 UBYTE *rspData;
1132
1133 TRACE_FUNCTION ("cmhSIM_SIMResponseData()");
1134
1135 cmdBuf = simEntStat.curCmd;
1136 simEntStat.curCmd = AT_CMD_NONE;
1137
1138 ownBuf = simEntStat.entOwn;
1139 simShrdPrm.owner = (T_OWN)CMD_SRC_NONE;
1140 simEntStat.entOwn = CMD_SRC_NONE;
1141
1142 /*
1143 *-------------------------------------------------------------------
1144 * check for command context
1145 *-------------------------------------------------------------------
1146 */
1147 switch( cmdBuf )
1148 {
1149 case( AT_CMD_CRSM ):
1150 if (simShrdPrm.rslt NEQ SIM_NO_ERROR AND
1151 GET_CAUSE_DEFBY(simShrdPrm.rslt) EQ DEFBY_CONDAT )
1152 {
1153 /*
1154 *----------------------------------------------------------------
1155 * error event for +CRSM
1156 *----------------------------------------------------------------
1157 */
1158 R_AT( RAT_CME, ownBuf )
1159 (
1160 cmdBuf,
1161 cmhSIM_GetCmeFromSim ( simShrdPrm.rslt )
1162 );
1163 }
1164 else
1165 {
1166 /*
1167 *----------------------------------------------------------------
1168 * process event for +CRSM
1169 *----------------------------------------------------------------
1170 */
1171 R_AT( RAT_CRSM, ownBuf )
1172 ( rsp->sw1, rsp->sw2, rsp->rspLen, ((rsp->rspLen)?rsp->rsp:NULL));
1173
1174 R_AT( RAT_OK, ownBuf )
1175 ( cmdBuf );
1176 }
1177 break;
1178
1179 case( AT_CMD_CSIM ):
1180 /*
1181 *----------------------------------------------------------------
1182 * error event for +CSIM
1183 *----------------------------------------------------------------
1184 */
1185 if (simShrdPrm.rslt NEQ SIM_NO_ERROR)
1186 {
1187 R_AT( RAT_CME, ownBuf )
1188 (
1189 cmdBuf,
1190 cmhSIM_GetCmeFromSim ( simShrdPrm.rslt )
1191 );
1192
1193 return;
1194 }
1195 /*
1196 *----------------------------------------------------------------
1197 * process event for +CSIM
1198 *----------------------------------------------------------------
1199 */
1200 ACI_MALLOC(rspData, MAX_SIM_CMD+2); /* alloc 2 byte more for sw1 and sw2 */
1201 memcpy (rspData, rsp->rsp, rsp->rspLen);
1202 rspData[rsp->rspLen++] = rsp->sw1;
1203 rspData[rsp->rspLen++] = rsp->sw2;
1204
1205 R_AT( RAT_CSIM, ownBuf )
1206 ( rsp->rspLen, rspData);
1207
1208 ACI_MFREE(rspData);
1209
1210 R_AT( RAT_OK, ownBuf )
1211 ( cmdBuf );
1212 break;
1213
1214 default:
1215 TRACE_EVENT("wrong command context (+CRSM or +CSIM expected)");
1216 break;
1217 }
1218 }
1219
1220 /*
1221 +--------------------------------------------------------------------+
1222 | PROJECT : GSM-PS (6147) MODULE : CMH_SIMR |
1223 | ROUTINE : cmhSIM_CnfMsisdn |
1224 +--------------------------------------------------------------------+
1225
1226 PURPOSE : This function handles the confirmation of reading
1227 EF MSISDN from SIM.
1228 */
1229 GLOBAL void cmhSIM_CnfMsisdn ( SHORT table_id )
1230 {
1231 T_SIM_CMD_PRM* pSIMCmdPrm; /* points to SIM command parameters */
1232 T_ACI_AT_CMD cmdBuf; /* buffers current command */
1233 T_ACI_CMD_SRC ownBuf; /* buffers current owner */
1234
1235 UBYTE* ptr; /* pointer to decoded data */
1236 UBYTE alphaLen; /* max. length of alpha identifier */
1237 UBYTE* pExchData; /* points to exchange data buffer */
1238 UBYTE dataLen; /* holds length of data */
1239
1240 TRACE_FUNCTION ("cmhSIM_CnfMsisdn()");
1241
1242 pSIMCmdPrm = &cmhPrm[simEntStat.entOwn].simCmdPrm;
1243 cmdBuf = simEntStat.curCmd;
1244 ownBuf = simEntStat.entOwn;
1245 pExchData = simShrdPrm.atb[table_id].exchData;
1246 dataLen = simShrdPrm.atb[table_id].dataLen;
1247
1248
1249 switch ( simShrdPrm.atb[table_id].errCode )
1250 {
1251 case ( SIM_NO_ERROR ):
1252 {
1253 /*
1254 *-------------------------------------------------------------
1255 * check basic consistency of read data
1256 *-------------------------------------------------------------
1257 */
1258 if ( pExchData EQ NULL OR
1259 dataLen < ACI_MIN_SIZE_EF_MSISDN )
1260 {
1261 /* Implements Measure 7, 17, 24, 35 */
1262 cmhSIM_SndError( ownBuf, cmdBuf, CME_ERR_Unknown );
1263 }
1264 else
1265 {
1266 ptr = pExchData;
1267 alphaLen = dataLen - ACI_MIN_SIZE_EF_MSISDN;
1268
1269 /*
1270 *-----------------------------------------------------------
1271 * process parameter <lenEfMsisdn>
1272 *-----------------------------------------------------------
1273 */
1274 CNUMLenEfMsisdn = dataLen;
1275
1276 /*
1277 *-----------------------------------------------------------
1278 * process parameter <cnumMaxRec>
1279 *-----------------------------------------------------------
1280 */
1281 if ( pSIMCmdPrm -> CNUMActRec EQ 1 )
1282 CNUMMaxRec = simShrdPrm.atb[table_id].recMax;
1283
1284 /*
1285 *-----------------------------------------------------------
1286 * process parameter <alpha>
1287 *-----------------------------------------------------------
1288 */
1289 cmhPHB_getTagNt ( ptr,
1290 alphaLen,
1291 CNUMMsisdn[CNUMMsisdnIdx].alpha,
1292 MAX_ALPHA_LEN );
1293
1294 ptr += alphaLen;
1295
1296 /*
1297 *-----------------------------------------------------------
1298 * process parameter <number>
1299 *-----------------------------------------------------------
1300 */
1301 cmhPHB_getAdrStr ( CNUMMsisdn[CNUMMsisdnIdx].number,
1302 MAX_PHB_NUM_LEN - 1,
1303 ptr + 2,
1304 *ptr );
1305
1306 /*
1307 *-----------------------------------------------------------
1308 * validate entry of MSISDN list
1309 *-----------------------------------------------------------
1310 */
1311 /* VO patch 14.03.01
1312 * move validate entry to after decoding alpha and number
1313 * and set the vldFlag only when the alpha or the number exists. */
1314 if ( strlen(CNUMMsisdn[CNUMMsisdnIdx].number) OR
1315 strlen(CNUMMsisdn[CNUMMsisdnIdx].alpha) )
1316 {
1317 CNUMMsisdn[CNUMMsisdnIdx].vldFlag = TRUE;
1318 pSIMCmdPrm -> CNUMOutput++;
1319 }
1320
1321 /*
1322 *-----------------------------------------------------------
1323 * process parameter <type>
1324 *-----------------------------------------------------------
1325 */
1326 cmhPHB_toaDmrg ( *( ptr + 1 ),
1327 &CNUMMsisdn[CNUMMsisdnIdx].type );
1328
1329 ptr += 12;
1330
1331 /*
1332 *-----------------------------------------------------------
1333 * invalidate parameter <speed>, <service>, <itc>
1334 *-----------------------------------------------------------
1335 */
1336 CNUMMsisdn[CNUMMsisdnIdx].speed = BS_SPEED_NotPresent;
1337 CNUMMsisdn[CNUMMsisdnIdx].service = CNUM_SERV_NotPresent;
1338 CNUMMsisdn[CNUMMsisdnIdx].itc = CNUM_ITC_NotPresent;
1339
1340 if ( *ptr NEQ 0xFF )
1341 {
1342 /*
1343 *---------------------------------------------------------
1344 * bearer capability EF present
1345 *---------------------------------------------------------
1346 */
1347 if ( cmhSIM_ReqCcp ( ownBuf, *ptr++ ) NEQ AT_EXCT )
1348 {
1349 /* Implements Measure 7, 17, 24, 35 */
1350 cmhSIM_SndError( ownBuf, cmdBuf, CME_ERR_Unknown );
1351 }
1352 }
1353 else
1354 {
1355 /* Implements Measure 200 */
1356
1357 if ( CNUMMsisdn[CNUMMsisdnIdx].vldFlag EQ FALSE )
1358 {
1359 CNUMMsisdnIdx--;
1360 }
1361
1362 cmhSIM_Compare_CNUMMsisdnIdx();
1363 }
1364 }
1365
1366 break;
1367 }
1368
1369 default:
1370 {
1371 /* Implements Measure 7, 17, 24, 35 */
1372 cmhSIM_SndError( ownBuf, cmdBuf,
1373 cmhSIM_GetCmeFromSim (simShrdPrm.atb[table_id].errCode) );
1374 break;
1375 }
1376
1377 }
1378
1379 simShrdPrm.atb[table_id].ntryUsdFlg = FALSE;
1380 }
1381
1382 /*
1383 +--------------------------------------------------------------------+
1384 | PROJECT : GSM-F&D (8411) MODULE : CMH_SIMR |
1385 | STATE : code ROUTINE : cmhSIM_CnfCcp |
1386 +--------------------------------------------------------------------+
1387
1388 PURPOSE : This function handles the confirmation of reading
1389 EF CCP from SIM.
1390 */
1391 GLOBAL void cmhSIM_CnfCcp ( SHORT table_id )
1392 {
1393 T_ACI_AT_CMD cmdBuf; /* buffers current command */
1394 T_ACI_CMD_SRC ownBuf; /* buffers current owner */
1395
1396 T_U_CALL_CONF* callCnf; /* call confirm message */
1397 T_M_CC_bearer_cap* bearCap; /* bearer capability */
1398 UBYTE* pExchData; /* points to exchange data buffer */
1399 UBYTE dataLen; /* holds length of data */
1400
1401 TRACE_FUNCTION ("cmhSIM_CnfCcp()");
1402
1403 cmdBuf = simEntStat.curCmd;
1404 ownBuf = simEntStat.entOwn;
1405 dataLen = simShrdPrm.atb[table_id].dataLen;
1406 pExchData = simShrdPrm.atb[table_id].exchData;
1407
1408 switch ( simShrdPrm.atb[table_id].errCode )
1409 {
1410 case ( SIM_NO_ERROR ):
1411 {
1412 /*
1413 *-------------------------------------------------------------
1414 * check basic consistency of read data
1415 *-------------------------------------------------------------
1416 */
1417 if ( pExchData EQ NULL OR
1418 dataLen NEQ ACI_SIZE_EF_CCP )
1419 {
1420 /* Implements Measure 7, 17, 24, 35 */
1421 cmhSIM_SndError( ownBuf, cmdBuf, CME_ERR_Unknown );
1422 }
1423 else
1424 {
1425 /*
1426 *-----------------------------------------------------------
1427 * extracting the relevant data from bearer capability IE
1428 *-----------------------------------------------------------
1429 */
1430 UBYTE bearCapLen = pExchData[0];
1431
1432 if (bearCapLen <= 13 ) /* do not decode empty or invalid entries,
1433 see 11.11/10.5.4.1 max 14 bytes */
1434 {
1435 /*lint -e415 -e416 -e669 (Waring: creation of out of bound ptr or data overrun)*/
1436 PALLOC_MSG ( msg, MMCM_DATA_REQ, U_CALL_CONF);
1437
1438 msg -> sdu.l_buf = bearCapLen * 0x08;
1439 msg -> sdu.o_buf = 0x08;
1440 msg -> sdu.buf[0] = 0x83;
1441 msg -> sdu.buf[1] = U_CALL_CONF;
1442
1443 memcpy ( &msg -> sdu.buf[2],
1444 pExchData,
1445 bearCapLen+1);
1446 /*lint +e415 +e416 +e669 (Waring: creation of out of bound ptr or data overrun)*/
1447 /*
1448 *-----------------------------------------------------------
1449 * use of CCD for decoding of bearer capability
1450 *-----------------------------------------------------------
1451 */
1452 CCD_START;
1453
1454 memset (_decodedMsg, 0, sizeof (_decodedMsg));
1455
1456 if ( ccd_decodeMsg ( CCDENT_CC,
1457 UPLINK,
1458 (T_MSGBUF *) &msg->sdu,
1459 (UBYTE *) _decodedMsg,
1460 NOT_PRESENT_8BIT) EQ ccdOK
1461 AND
1462
1463 _decodedMsg[0] EQ U_CALL_CONF )
1464 {
1465 callCnf = ( T_U_CALL_CONF * )&_decodedMsg[0];
1466
1467 if ( callCnf -> v_bearer_cap )
1468 {
1469 bearCap = &callCnf -> bearer_cap;
1470
1471 /*
1472 *-------------------------------------------------------
1473 * process parameter <speed> of MSISDN
1474 *-------------------------------------------------------
1475 */
1476 if ( bearCap -> v_user_rate )
1477 {
1478 CNUMMsisdn[CNUMMsisdnIdx].speed =
1479 cmhSIM_GetUserRate ( bearCap -> user_rate );
1480 }
1481
1482 /*
1483 *-------------------------------------------------------
1484 * process parameter <itc> and <service> of MSISDN
1485 *-------------------------------------------------------
1486 */
1487 if ( bearCap -> v_trans_cap )
1488 {
1489 CNUMMsisdn[CNUMMsisdnIdx].itc =
1490 cmhSIM_GetItc ( bearCap -> trans_cap );
1491 }
1492
1493 if ( bearCap -> v_user_inf_l2_prot AND
1494 bearCap -> user_inf_l2_prot EQ M_CC_L2_X25 AND
1495 bearCap -> v_sync_async AND
1496 bearCap -> sync_async EQ M_CC_SYNCHRONOUS )
1497 {
1498 CNUMMsisdn[CNUMMsisdnIdx].service =
1499 CNUM_SERV_PacketSynch;
1500 }
1501 else if
1502 ( bearCap -> v_sig_access_prot
1503 AND
1504 ( bearCap -> sig_access_prot EQ M_CC_SIAP_X28_INDIV_NUI OR
1505 bearCap -> sig_access_prot EQ M_CC_SIAP_X28_UNIV_NUI OR
1506 bearCap -> sig_access_prot EQ M_CC_SIAP_X28_NON_DEDIC
1507 )
1508
1509 AND
1510 bearCap -> v_sync_async
1511 AND
1512 bearCap -> sync_async EQ M_CC_ASYNCHRONOUS
1513 )
1514 {
1515 CNUMMsisdn[CNUMMsisdnIdx].service =
1516 CNUM_SERV_PadAsynch;
1517 }
1518 else if ( bearCap -> v_sync_async )
1519 {
1520 CNUMMsisdn[CNUMMsisdnIdx].service =
1521 cmhSIM_GetSrvFromSync ( bearCap -> sync_async );
1522
1523 }
1524 else if ( bearCap -> v_trans_cap )
1525 {
1526 CNUMMsisdn[CNUMMsisdnIdx].service =
1527 cmhSIM_GetSrvFromItc ( bearCap -> trans_cap );
1528 }
1529 }
1530 }
1531 CCD_END;
1532
1533 PFREE ( msg );
1534 }
1535
1536 /*
1537 *-----------------------------------------------------------
1538 * tmpActRec is used to prevent conflicts with global
1539 * variable pSIMCmdPrm -> CNUMActRec
1540 *-----------------------------------------------------------
1541 */
1542 /* Implements Measure 200 */
1543 cmhSIM_Compare_CNUMMsisdnIdx();
1544 }
1545
1546 break;
1547 }
1548
1549 default:
1550 {
1551 /* Implements Measure 7, 17, 24, 35 */
1552 cmhSIM_SndError( ownBuf, cmdBuf,
1553 cmhSIM_GetCmeFromSim(simShrdPrm.atb[table_id].errCode));
1554 break;
1555 }
1556
1557 }
1558
1559 simShrdPrm.atb[table_id].ntryUsdFlg = FALSE;
1560 }
1561
1562 /*
1563 +--------------------------------------------------------------------+
1564 | PROJECT : GSM-F&D (8411) MODULE : CMH_SIMR |
1565 | STATE : code ROUTINE : cmhSIM_RdCnfPlmnSel|
1566 +--------------------------------------------------------------------+
1567
1568 PURPOSE : This function handles the confirmation of reading
1569 EF PLMN SEL from SIM.
1570 */
1571 GLOBAL void cmhSIM_RdCnfPlmnSel ( SHORT table_id )
1572 {
1573 T_SIM_CMD_PRM * pSIMCmdPrm; /* points to SIM command parameters */
1574 T_ACI_AT_CMD cmdBuf; /* buffers current command */
1575 T_ACI_CMD_SRC ownBuf; /* buffers current owner */
1576 T_ACI_CPOL_LST CPOLPlmnSelLst; /* PLMN SEL list */
1577 T_ACI_RETURN ret;
1578 SHORT lastIdx; /* holds last index */
1579 SHORT usdNtry; /* holds number of used entries */
1580
1581 TRACE_FUNCTION ("cmhSIM_RdCnfPlmnSel()");
1582
1583 pSIMCmdPrm = &cmhPrm[simEntStat.entOwn].simCmdPrm;
1584 cmdBuf = simEntStat.curCmd;
1585 ownBuf = simEntStat.entOwn;
1586
1587
1588 switch ( simShrdPrm.atb[table_id].errCode )
1589 {
1590 case ( SIM_NO_ERROR ):
1591 {
1592 /*
1593 *-------------------------------------------------------------
1594 * check basic consistency of read data
1595 *-------------------------------------------------------------
1596 */
1597 if ( simShrdPrm.atb[table_id].exchData EQ NULL OR
1598 simShrdPrm.atb[table_id].dataLen < ACI_MIN_SIZE_EF_PLMN_SEL)
1599 {
1600 pSIMCmdPrm->CPOLact = CPOL_ACT_None;
1601 /* Implements Measure 7, 17, 24, 35 */
1602 cmhSIM_SndError( ownBuf, cmdBuf, CME_ERR_Unknown );
1603 break;
1604 }
1605
1606 EfPLMNselStat = EF_STAT_READ;
1607 CPOLSimEfDataLen = simShrdPrm.atb[table_id].dataLen;
1608
1609 if( pSIMCmdPrm->CPOLmode EQ CPOL_MOD_CompactList )
1610 {
1611 cmhSIM_CmpctPlmnSel( simShrdPrm.atb[table_id].dataLen,
1612 simShrdPrm.atb[table_id].exchData );
1613 }
1614
1615 /*
1616 *-----------------------------------------------------------
1617 * what is to do ?
1618 *-----------------------------------------------------------
1619 */
1620 switch( pSIMCmdPrm->CPOLact )
1621 {
1622 /*
1623 *-----------------------------------------------------------
1624 * read out PLMN SEL list
1625 *-----------------------------------------------------------
1626 */
1627 case( CPOL_ACT_Read ):
1628
1629 /* fill in buffer */
1630 lastIdx = cmhSIM_FillPlmnSelList(pSIMCmdPrm->CPOLidx,
1631 pSIMCmdPrm->CPOLfrmt,
1632 &CPOLPlmnSelLst[0],
1633 simShrdPrm.atb[table_id].dataLen,
1634 (UBYTE *)simShrdPrm.atb[table_id].exchData);
1635 /* notify about PLMN SEL list */
1636 simEntStat.curCmd = AT_CMD_NONE;
1637 simShrdPrm.owner = (T_OWN)CMD_SRC_NONE;
1638 simEntStat.entOwn = CMD_SRC_NONE;
1639
1640 R_AT( RAT_CPOL, ownBuf ) ( ACI_NumParmNotPresent,
1641 lastIdx,
1642 &CPOLPlmnSelLst[0],
1643 ACI_NumParmNotPresent );
1644
1645 R_AT( RAT_OK, ownBuf )( AT_CMD_CPOL );
1646 break;
1647
1648 /*
1649 *-----------------------------------------------------------
1650 * write PLMN SEL list
1651 *-----------------------------------------------------------
1652 */
1653 case( CPOL_ACT_Write ):
1654
1655 if( pSIMCmdPrm->CPOLidx EQ NOT_PRESENT_8BIT )
1656
1657 ret = cmhSIM_FndEmptyPlmnSel( simEntStat.entOwn,
1658 pSIMCmdPrm->CPOLplmn );
1659 else
1660
1661 ret = cmhSIM_UpdPlmnSel( simEntStat.entOwn,
1662 pSIMCmdPrm->CPOLidx,
1663 pSIMCmdPrm->CPOLplmn,
1664 pSIMCmdPrm->CPOLmode);
1665 if( ret EQ AT_FAIL )
1666 {
1667 pSIMCmdPrm->CPOLact = CPOL_ACT_None;
1668 /* Implements Measure 7, 17, 24, 35 */
1669
1670 /* T_ACI_CME_ERR is used for TypeCast as the
1671 * ACI_ERR_DESC_NR() will retrun ULONG and the function expects
1672 * T_ACI_CME_ERR and there will no major harm as well.
1673 */
1674 cmhSIM_SndError( simEntStat.entOwn, AT_CMD_CPOL,
1675 (T_ACI_CME_ERR) ACI_ERR_DESC_NR( aciErrDesc ));
1676 }
1677 break;
1678
1679 /*
1680 *-----------------------------------------------------------
1681 * delete PLMN SEL entry
1682 *-----------------------------------------------------------
1683 */
1684 case( CPOL_ACT_Delete ):
1685
1686 if( pSIMCmdPrm->CPOLidx2 EQ NOT_PRESENT_8BIT )
1687
1688 ret = cmhSIM_DelPlmnSel( simEntStat.entOwn,
1689 pSIMCmdPrm->CPOLidx,
1690 pSIMCmdPrm->CPOLmode );
1691 else
1692
1693 ret = cmhSIM_ChgPlmnSel( simEntStat.entOwn,
1694 pSIMCmdPrm->CPOLidx,
1695 pSIMCmdPrm->CPOLidx2 );
1696
1697 if( ret EQ AT_FAIL )
1698 {
1699 pSIMCmdPrm->CPOLact = CPOL_ACT_None;
1700 /* Implements Measure 7, 17, 24, 35 */
1701
1702 /* T_ACI_CME_ERR is used for TypeCast as the ACI_ERR_DESC_NR()
1703 * will retrun ULONG and the function expects T_ACI_CME_ERR
1704 * and there will no major harm as well
1705 */
1706 cmhSIM_SndError( simEntStat.entOwn, AT_CMD_CPOL,
1707 (T_ACI_CME_ERR) ACI_ERR_DESC_NR( aciErrDesc ));
1708 }
1709 break;
1710
1711 /*
1712 *-----------------------------------------------------------
1713 * test PLMN SEL entry number
1714 *-----------------------------------------------------------
1715 */
1716 case( CPOL_ACT_Test ):
1717
1718 /* notify about PLMN SEL entry number */
1719 simEntStat.curCmd = AT_CMD_NONE;
1720 simShrdPrm.owner = (T_OWN)CMD_SRC_NONE;
1721 simEntStat.entOwn = CMD_SRC_NONE;
1722
1723 lastIdx = CPOLSimEfDataLen / ACI_LEN_PLMN_SEL_NTRY;
1724 usdNtry = cmhSIM_UsdPlmnSelNtry( CPOLSimEfDataLen,
1725 (UBYTE *)simShrdPrm.atb[table_id].exchData );
1726
1727 R_AT( RAT_CPOL, ownBuf ) ( ACI_NumParmNotPresent,
1728 lastIdx,
1729 NULL,
1730 usdNtry );
1731
1732 R_AT( RAT_OK, ownBuf )( AT_CMD_CPOL );
1733 break;
1734 }
1735 break;
1736 }
1737
1738 case ( SIM_CAUSE_UNKN_FILE_ID ):
1739 EfPLMNselStat = EF_STAT_NOT_AVAIL;
1740 /*lint -fallthrough*/
1741 /*lint -fallthrough*/
1742 default:
1743 {
1744 pSIMCmdPrm->CPOLact = CPOL_ACT_None;
1745 /* Implements Measure 7, 17, 24, 35 */
1746 cmhSIM_SndError( ownBuf, cmdBuf,
1747 cmhSIM_GetCmeFromSim(simShrdPrm.atb[table_id].errCode));
1748 break;
1749 }
1750
1751 }
1752
1753 simShrdPrm.atb[table_id].ntryUsdFlg = FALSE;
1754
1755 }
1756
1757 /*
1758 +--------------------------------------------------------------------+
1759 | PROJECT : GSM-F&D (8411) MODULE : CMH_SIMR |
1760 | STATE : code ROUTINE : cmhSIM_WrCnfPlmnSel|
1761 +--------------------------------------------------------------------+
1762
1763 PURPOSE : This function handles the confirmation of writing
1764 EF PLMN SEL to SIM.
1765 */
1766 GLOBAL void cmhSIM_WrCnfPlmnSel ( SHORT table_id )
1767 {
1768 T_SIM_CMD_PRM * pSIMCmdPrm; /* points to SIM command parameters */
1769 UBYTE ownBuf;
1770
1771 TRACE_FUNCTION ("cmhSIM_WrCnfPlmnSel()");
1772
1773 pSIMCmdPrm = &cmhPrm[simEntStat.entOwn].simCmdPrm;
1774 ownBuf = simEntStat.entOwn;
1775
1776 switch ( simShrdPrm.atb[table_id].errCode )
1777 {
1778 /* successful PLMN SEL list update */
1779 case ( SIM_NO_ERROR ):
1780 {
1781 pSIMCmdPrm->CPOLact = CPOL_ACT_None;
1782 simEntStat.curCmd = AT_CMD_NONE;
1783 simShrdPrm.owner = (T_OWN)CMD_SRC_NONE;
1784 simEntStat.entOwn = CMD_SRC_NONE;
1785
1786 R_AT( RAT_OK, (T_ACI_CMD_SRC)ownBuf )( AT_CMD_CPOL );
1787 break;
1788 }
1789 case SIM_CAUSE_ACCESS_PROHIBIT:
1790 {
1791 pSIMCmdPrm->CPOLact = CPOL_ACT_None;
1792 /* Implements Measure 7, 17, 24, 35 */
1793 cmhSIM_SndError((T_ACI_CMD_SRC)ownBuf, AT_CMD_CPOL, CME_ERR_OpNotAllow );
1794 break;
1795 }
1796
1797 /* unsuccessful PLMN SEL list update */
1798 default:
1799 {
1800 pSIMCmdPrm->CPOLact = CPOL_ACT_None;
1801 /* Implements Measure 7, 17, 24, 35 */
1802 cmhSIM_SndError((T_ACI_CMD_SRC)ownBuf, AT_CMD_CPOL,
1803 cmhSIM_GetCmeFromSim(simShrdPrm.atb[table_id].errCode));
1804 break;
1805 }
1806 }
1807
1808 simShrdPrm.atb[table_id].ntryUsdFlg = FALSE;
1809 }
1810
1811 /*
1812 +--------------------------------------------------------------------+
1813 | PROJECT : GSM-F&D (8411) MODULE : CMH_SIMR |
1814 | STATE : code ROUTINE : cmhSIM_RdCnfLangELP|
1815 +--------------------------------------------------------------------+
1816
1817 PURPOSE : This function handles the confirmation of reading
1818 from the SIM (EF ELP).
1819 */
1820 GLOBAL void cmhSIM_RdCnfLangELP ( SHORT table_id )
1821 {
1822 T_SIM_CMD_PRM *pSIMCmdPrm; /* points to SIM command parameters */
1823 T_PHB_CMD_PRM *pPHBCmdPrm; /* points to PHB command parameter */
1824
1825 T_ACI_AT_CMD cmdBuf; /* buffers current command */
1826 T_ACI_CMD_SRC ownBuf; /* buffers current owner */
1827 CHAR Clang_buffer[3]={0};/* Current language */
1828 T_ACI_LAN_SUP clng;
1829 EF_CLNG lng;
1830 BOOL Suplng = FALSE;
1831 T_ACI_LAN_SUP LngPCMsupLst[MAX_LAN];
1832 SHORT lastIdx;
1833 T_ACI_RETURN ret ;
1834
1835 TRACE_FUNCTION ("cmhSIM_RdCnfLangELP()");
1836
1837 pSIMCmdPrm = &cmhPrm[simEntStat.entOwn].simCmdPrm;
1838 cmdBuf = simEntStat.curCmd;
1839 ownBuf = simEntStat.entOwn;
1840 pPHBCmdPrm = &cmhPrm[ownBuf].phbCmdPrm;
1841 simShrdPrm.atb[table_id].ntryUsdFlg = FALSE;
1842 simEntStat.curCmd = AT_CMD_NONE;
1843
1844 clng.str = Clang_buffer;
1845
1846 switch ( simShrdPrm.atb[table_id].errCode )
1847 {
1848 case ( SIM_NO_ERROR ):
1849 /*
1850 *-------------------------------------------------------------
1851 * check basic consistency of read data
1852 *-------------------------------------------------------------
1853 */
1854 if ( simShrdPrm.atb[table_id].exchData EQ NULL OR
1855 simShrdPrm.atb[table_id].dataLen < ACI_MIN_SIZE_EF_LAN)
1856
1857 {
1858 pSIMCmdPrm->CLANact = CLAN_ACT_None;
1859 simShrdPrm.owner = (T_OWN)CMD_SRC_NONE;
1860 simEntStat.entOwn = CMD_SRC_NONE;
1861
1862 R_AT( RAT_CME, ownBuf ) ( cmdBuf, CME_ERR_Unknown );
1863 return;
1864 }
1865
1866 memcpy(clng.str, (UBYTE *)simShrdPrm.atb[table_id].exchData, CLAN_CODE_LEN);
1867 ret=getSupLangFromPCM(&LngPCMsupLst[0], &lastIdx);
1868 if (ret EQ AT_FAIL)
1869 {
1870 return;
1871 }
1872 Suplng=checkSuppLang(&LngPCMsupLst[0],lastIdx, &clng);
1873 simShrdPrm.owner = (T_OWN)CMD_SRC_NONE;
1874 simEntStat.entOwn = CMD_SRC_NONE;
1875
1876 /*
1877 *---------------------------------------------------------------------
1878 * check if the language,which was read from EF ELP is supported in PCM
1879 *---------------------------------------------------------------------
1880 */
1881 if(Suplng)
1882 {
1883 switch( pSIMCmdPrm->CLANact )
1884 {
1885 case( CLAN_ACT_Read ):
1886 R_AT( RAT_CLAN, ownBuf ) (&clng);
1887 R_AT( RAT_OK, ownBuf )( AT_CMD_CLAN );
1888 break;
1889 case( CLAN_ACT_Write ):
1890 memcpy(lng.data,clng.str ,CLAN_CODE_LEN);
1891 /* Implements Measure#32 Row 1072 */
1892 pcm_WriteFile (( UBYTE* )ef_clng_id,SIZE_EF_CLNG,( UBYTE*) &lng);
1893
1894 if (pPHBCmdPrm->CLAEmode EQ CLAE_MOD_Enable)
1895 R_AT( RAT_CLAE, ownBuf ) (&clng);
1896
1897 R_AT( RAT_OK, ownBuf )( AT_CMD_CLAN );
1898 break;
1899 }
1900 }
1901 else
1902 /*
1903 *-------------------------------------------------------------
1904 * read the EF LP if the language is not supported in PCM
1905 *-------------------------------------------------------------
1906 */
1907 /* Implements Measure 150 and 159 */
1908 cmhSIM_ReqLanguage_LP_or_ELP ( ownBuf, SIM_LP );
1909 break;
1910
1911 /*
1912 *-------------------------------------------------------------
1913 * read the EF LP if the EF ELP not available
1914 *-------------------------------------------------------------
1915 */
1916 case ( SIM_CAUSE_UNKN_FILE_ID ):
1917 /* Implements Measure 150 and 159 */
1918 cmhSIM_ReqLanguage_LP_or_ELP ( ownBuf, SIM_LP );
1919 break;
1920
1921 default:
1922 pSIMCmdPrm->CLANact = CLAN_ACT_None;
1923 simShrdPrm.owner = (T_OWN)CMD_SRC_NONE;
1924 simEntStat.entOwn = CMD_SRC_NONE;
1925
1926 R_AT( RAT_CME, ownBuf) ( AT_CMD_CLAN, CME_ERR_Unknown );
1927 break;
1928
1929 }
1930
1931 }
1932
1933
1934 /*
1935 +------------------------------------------------------------------------+
1936 | PROJECT : GSM-F&D (8411) MODULE : CMH_SIMR |
1937 | STATE : code ROUTINE : cmhSIM_RdCnfLangPrfELP |
1938 +------------------------------------------------------------------------+
1939
1940 PURPOSE : This function handles the confirmation of reading
1941 from the SIM (EF ELP) for SAT feature LS.
1942 */
1943 GLOBAL void cmhSIM_RdCnfLangPrfELP ( SHORT table_id )
1944 {
1945
1946 T_ACI_SAT_TERM_RESP resp_data;
1947 CHAR Clang_buffer[3]={0};/* Current language */
1948 T_ACI_LAN_SUP clng;
1949 BOOL Suplng = FALSE;
1950 T_ACI_LAN_SUP LngPCMsupLst[MAX_LAN];
1951 SHORT lastIdx;
1952 T_ACI_RETURN ret ;
1953
1954
1955 TRACE_FUNCTION ("cmhSIM_RdCnfLangPrfELP()");
1956
1957 psaSAT_InitTrmResp( &resp_data );
1958
1959 simShrdPrm.atb[table_id].ntryUsdFlg = FALSE;
1960
1961 clng.str = Clang_buffer;
1962
1963 switch ( simShrdPrm.atb[table_id].errCode )
1964 {
1965 case ( SIM_NO_ERROR ):
1966 /*
1967 *-------------------------------------------------------------
1968 * check basic consistency of read data
1969 *-------------------------------------------------------------
1970 */
1971 if ( simShrdPrm.atb[table_id].exchData EQ NULL OR
1972 simShrdPrm.atb[table_id].dataLen < ACI_MIN_SIZE_EF_LAN)
1973
1974 {
1975 psaSAT_SendTrmResp( RSLT_ME_UNAB_PROC, &resp_data );
1976 return;
1977 }
1978
1979 memcpy(clng.str, (UBYTE *)simShrdPrm.atb[table_id].exchData, CLAN_CODE_LEN);
1980 ret=getSupLangFromPCM(&LngPCMsupLst[0], &lastIdx);
1981 if (ret EQ AT_FAIL)
1982 {
1983 psaSAT_SendTrmResp( RSLT_ME_UNAB_PROC, &resp_data );
1984 return;
1985 }
1986
1987 Suplng=checkSuppLang(&LngPCMsupLst[0],lastIdx, &clng);
1988
1989
1990 /*
1991 *---------------------------------------------------------------------
1992 * check if the language,which was read from EF ELP is supported in PCM
1993 *---------------------------------------------------------------------
1994 */
1995 if(Suplng)
1996 {
1997 /* Send Terminal resp*/
1998 memcpy(&resp_data.lang, (UBYTE *)simShrdPrm.atb[table_id].exchData, CLAN_CODE_LEN);
1999 psaSAT_SendTrmResp( RSLT_PERF_SUCCESS, &resp_data );
2000
2001 }
2002 else
2003 {
2004 /*
2005 *-------------------------------------------------------------
2006 * read the EF LP if the language is not supported in PCM
2007 *-------------------------------------------------------------
2008 */
2009 /* Implements Measure 119 */
2010 if ( cmhSIM_ReqLanguagePrf_LP_or_ELP( SIM_LP, ACI_MAX_LAN_LP_NTRY,
2011 CLANSimEfDataLP,
2012 cmhSIM_RdCnfLangPrfLP ) EQ FALSE )
2013 {
2014 psaSAT_SendTrmResp( RSLT_ME_UNAB_PROC, &resp_data );
2015 }
2016 }
2017 break;
2018
2019 /*
2020 *-------------------------------------------------------------
2021 * read the EF LP if the EF ELP not available
2022 *-------------------------------------------------------------
2023 */
2024 case ( SIM_CAUSE_UNKN_FILE_ID ):
2025 /* Implements Measure 119 */
2026 if (cmhSIM_ReqLanguagePrf_LP_or_ELP ( SIM_LP, ACI_MAX_LAN_LP_NTRY,
2027 CLANSimEfDataLP,
2028 cmhSIM_RdCnfLangPrfLP ) EQ FALSE )
2029 {
2030 psaSAT_SendTrmResp( RSLT_ME_UNAB_PROC, &resp_data );
2031 }
2032 break;
2033
2034 default:
2035 psaSAT_SendTrmResp( RSLT_ME_UNAB_PROC, &resp_data );
2036 break;
2037
2038 }
2039 }
2040
2041
2042 /*
2043 +--------------------------------------------------------------------+
2044 | PROJECT : GSM-F&D (8411) MODULE : CMH_SIMR |
2045 | STATE : code ROUTINE : cmhSIM_RdCnfLangLP |
2046 +--------------------------------------------------------------------+
2047
2048 PURPOSE : This function handles the confirmation of reading
2049 EF LP from SIM.
2050 */
2051 GLOBAL void cmhSIM_RdCnfLangLP ( SHORT table_id )
2052 {
2053 T_SIM_CMD_PRM * pSIMCmdPrm; /* points to SIM command parameters */
2054 T_PHB_CMD_PRM * pPHBCmdPrm; /* points to PHB command parameter */
2055 T_ACI_AT_CMD cmdBuf; /* buffers current command */
2056 T_ACI_CMD_SRC ownBuf; /* buffers current owner */
2057 T_ACI_LAN_SUP clng;
2058 EF_CLNG lng;
2059 BOOL Suplng= FALSE;
2060 SHORT lastIdx;
2061 T_ACI_LAN_SUP LngPCMsupLst[MAX_LAN];
2062
2063
2064 TRACE_FUNCTION ("cmhSIM_RdCnfLangLP()");
2065
2066 pSIMCmdPrm = &cmhPrm[simEntStat.entOwn].simCmdPrm;
2067 cmdBuf = simEntStat.curCmd;
2068 ownBuf = simEntStat.entOwn;
2069 pPHBCmdPrm = &cmhPrm[ownBuf].phbCmdPrm;
2070 simShrdPrm.atb[table_id].ntryUsdFlg = FALSE;
2071 simEntStat.curCmd = AT_CMD_NONE;
2072
2073 clng.lng=(T_ACI_CLAN_LNG)simShrdPrm.atb[table_id].exchData[0];
2074
2075 getSupLangFromPCM(&LngPCMsupLst[0], &lastIdx);
2076 Suplng=checkSuppLangInLP(&LngPCMsupLst[0],lastIdx, &clng);
2077
2078 if ( simShrdPrm.atb[table_id].errCode EQ SIM_NO_ERROR AND
2079 Suplng )
2080 {
2081 simShrdPrm.owner = (T_OWN)CMD_SRC_NONE;
2082 simEntStat.entOwn = CMD_SRC_NONE;
2083 /*
2084 *-------------------------------------------------------------
2085 * check basic consistency of read data
2086 *-------------------------------------------------------------
2087 */
2088 if ( simShrdPrm.atb[table_id].exchData EQ NULL OR
2089 simShrdPrm.atb[table_id].dataLen < ACI_LEN_LAN_LP_NTRY)
2090
2091 {
2092 simShrdPrm.owner = (T_OWN)CMD_SRC_NONE;
2093 simEntStat.entOwn = CMD_SRC_NONE;
2094 pSIMCmdPrm->CLANact = CLAN_ACT_None;
2095 R_AT( RAT_CME, ownBuf ) ( cmdBuf, CME_ERR_Unknown );
2096 return;
2097 }
2098
2099 #ifdef SIM_TOOLKIT
2100 if (simShrdPrm.fuRef >= 0)
2101 {
2102 psaSAT_FUConfirm (simShrdPrm.fuRef, SIM_FU_SUCCESS);
2103 }
2104 #endif
2105
2106 /*
2107 *-----------------------------------------------------
2108 * read the supported laguage or write it PCM
2109 *-----------------------------------------------------
2110 */
2111 switch( pSIMCmdPrm->CLANact )
2112 {
2113 case( CLAN_ACT_Read ):
2114 R_AT( RAT_CLAN, ownBuf ) (&clng);
2115 R_AT( RAT_OK, ownBuf )( AT_CMD_CLAN );
2116 break;
2117 case( CLAN_ACT_Write ):
2118 memcpy(lng.data,(UBYTE *) clng.str,CLAN_CODE_LEN);
2119 /* Implements Measure#32 Row 1072 */
2120 pcm_WriteFile (( UBYTE* )ef_clng_id,SIZE_EF_CLNG,( UBYTE*) &lng);
2121 if (pPHBCmdPrm->CLAEmode EQ CLAE_MOD_Enable)
2122 { R_AT( RAT_CLAE, ownBuf ) (&clng);}
2123
2124 R_AT( RAT_OK, ownBuf )( AT_CMD_CLAN );
2125 break;
2126
2127 }
2128 }
2129 else
2130 {
2131
2132 #ifdef SIM_TOOLKIT
2133 if (simShrdPrm.fuRef >= 0)
2134 {
2135 psaSAT_FUConfirm (simShrdPrm.fuRef, SIM_FU_ERROR);
2136 }
2137 #endif
2138 /*
2139 *---------------------------------------------------------------
2140 * Preferred language is not supported in MS
2141 *---------------------------------------------------------------
2142 */
2143 if ( simShrdPrm.atb[table_id].errCode EQ SIM_CAUSE_UNKN_FILE_ID OR
2144 !Suplng )
2145 {
2146 TRACE_FUNCTION ("preferred language not supported");
2147
2148 switch( pSIMCmdPrm->CLANact )
2149 {
2150 case( CLAN_ACT_Read ):
2151 R_AT( RAT_CLAN, ownBuf ) (&LngPCMsupLst[0]);
2152 R_AT( RAT_OK, ownBuf )( AT_CMD_CLAN );
2153 break;
2154 case( CLAN_ACT_Write ): /* Preferred Language not supported,so not change CLAN */
2155 R_AT( RAT_OK, ownBuf )( AT_CMD_CLAN );
2156 break;
2157 }
2158 }
2159 else
2160 {
2161 pSIMCmdPrm->CLANact = CLAN_ACT_None;
2162 simShrdPrm.owner = (T_OWN)CMD_SRC_NONE;
2163 simEntStat.entOwn = CMD_SRC_NONE;
2164 R_AT( RAT_CME, ownBuf) ( AT_CMD_CLAN, CME_ERR_Unknown );
2165 }
2166 }
2167 }
2168
2169
2170 /*
2171 +-----------------------------------------------------------------------+
2172 | PROJECT : GSM-F&D (8411) MODULE : CMH_SIMR |
2173 | STATE : code ROUTINE : cmhSIM_RdCnfLangPrfLP |
2174 +-----------------------------------------------------------------------+
2175
2176 PURPOSE : This function handles the confirmation of reading
2177 EF LP from SIM for SAT feature LS.
2178 */
2179 GLOBAL void cmhSIM_RdCnfLangPrfLP ( SHORT table_id )
2180 {
2181
2182 T_ACI_SAT_TERM_RESP resp_data;
2183 T_ACI_LAN_SUP clng;
2184 BOOL Suplng= FALSE;
2185 SHORT lastIdx;
2186 T_ACI_LAN_SUP lngPCMsupLst[MAX_LAN];
2187 T_ACI_RETURN ret;
2188
2189 TRACE_FUNCTION ("cmhSIM_RdCnfLangPrfLP()");
2190
2191 psaSAT_InitTrmResp( &resp_data );
2192
2193 simShrdPrm.atb[table_id].ntryUsdFlg = FALSE;
2194
2195 clng.lng=(T_ACI_CLAN_LNG)simShrdPrm.atb[table_id].exchData[0];
2196 ret = getSupLangFromPCM(&lngPCMsupLst[0], &lastIdx);
2197 if(ret EQ AT_FAIL)
2198 {
2199 psaSAT_SendTrmResp( RSLT_ME_UNAB_PROC, &resp_data );
2200 return;
2201 }
2202
2203 Suplng=checkSuppLangInLP(&lngPCMsupLst[0],lastIdx, &clng);
2204
2205 if ( simShrdPrm.atb[table_id].errCode EQ SIM_NO_ERROR AND
2206 Suplng )
2207 {
2208 /*
2209 *-------------------------------------------------------------
2210 * check basic consistency of read data
2211 *-------------------------------------------------------------
2212 */
2213 if ( simShrdPrm.atb[table_id].exchData EQ NULL OR
2214 simShrdPrm.atb[table_id].dataLen < ACI_LEN_LAN_LP_NTRY)
2215
2216 {
2217 psaSAT_SendTrmResp( RSLT_ME_UNAB_PROC, &resp_data );
2218 return;
2219 }
2220
2221 #ifdef SIM_TOOLKIT
2222 if (simShrdPrm.fuRef >= 0)
2223 {
2224 psaSAT_FUConfirm (simShrdPrm.fuRef, SIM_FU_SUCCESS);
2225 }
2226 #endif
2227
2228 /*
2229 *-----------------------------------------------------
2230 * Send the Terminal Response
2231 *-----------------------------------------------------
2232 */
2233 memcpy(&resp_data.lang, clng.str, CLAN_CODE_LEN);
2234 psaSAT_SendTrmResp( RSLT_PERF_SUCCESS, &resp_data );
2235 }
2236 else
2237 {
2238
2239 #ifdef SIM_TOOLKIT
2240 if (simShrdPrm.fuRef >= 0)
2241 {
2242 psaSAT_FUConfirm (simShrdPrm.fuRef, SIM_FU_ERROR);
2243 }
2244 #endif
2245 /*
2246 *---------------------------------------------------------------
2247 * read default language from ME
2248 *---------------------------------------------------------------
2249 */
2250
2251 if ( simShrdPrm.atb[table_id].errCode EQ SIM_CAUSE_UNKN_FILE_ID OR
2252 !Suplng )
2253 {
2254 TRACE_FUNCTION ("default language is selected");
2255 memcpy(&resp_data.lang, &lngPCMsupLst[0].str, CLAN_CODE_LEN);
2256 psaSAT_SendTrmResp( RSLT_PERF_SUCCESS, &resp_data );
2257
2258 }
2259 else
2260 {
2261 psaSAT_SendTrmResp( RSLT_ME_UNAB_PROC, &resp_data );
2262 }
2263
2264 }
2265
2266 }
2267
2268
2269 /*
2270 +--------------------------------------------------------------------------+
2271 | PROJECT : GSM-F&D (8411) MODULE : CMH_SIMR |
2272 | STATE : code ROUTINE : SIM_ENT_CSDconnect_dti_cb |
2273 +--------------------------------------------------------------------------+
2274
2275 PURPOSE : Callback for connection between SIM and TRA/L2R for CSD.
2276
2277 */
2278 #ifdef FF_SAT_E
2279 #ifdef DTI
2280 GLOBAL BOOL SIM_ENT_CSDconnect_dti_cb(UBYTE dti_id, T_DTI_CONN_STATE result_type)
2281 {
2282 TRACE_FUNCTION("SIM_ENT_CSDconnect_dti_cb");
2283
2284 switch( result_type)
2285 {
2286 case DTI_CONN_STATE_DISCONNECTING:
2287 break;
2288 case DTI_CONN_STATE_DISCONNECTED:
2289 /* wap_state is set to IPA_Deactivated in psaTCPIP_config_dispatch() */
2290 if (wap_state EQ UDPA_Deactivation)
2291 {
2292 wap_state = IPA_Deactivation;
2293 psaUDPIP_config_dispatch();
2294 }
2295 dti_cntrl_erase_entry(dti_id);
2296 dti_cntrl_clear_conn_parms(dti_id);
2297 if (simShrdPrm.sat_class_e_dti_id EQ dti_id)
2298 {
2299 simShrdPrm.sat_class_e_dti_id = DTI_DTI_ID_NOTPRESENT;
2300 TRACE_EVENT("sat_class_e_dti_id reset");
2301 }
2302 break;
2303 case DTI_CONN_STATE_CONNECTING:
2304 break;
2305 case DTI_CONN_STATE_CONNECTED:
2306 /* the SIM-SNDCP connection has been established, now send SIM_BIP_CONFIG
2307 * request to SIM */
2308 psaSIM_Bip_Config_Req();
2309
2310 break;
2311 case DTI_CONN_STATE_ERROR:
2312 /* connection not possible: disconnect UDP, L2R or TRA */
2313 TRACE_EVENT("SIM_ENT_CSDconnect_dti_cb connection not possible: disconnect UDP,L2R or TRA");
2314 dti_cntrl_close_dpath_from_dti_id( dti_id );
2315 break;
2316 case DTI_CONN_STATE_UNKNOWN:
2317 default:
2318 TRACE_EVENT("SIM_ENT_CSDconnect_dti_cb call with not awaited value");
2319 break;
2320 }
2321 return TRUE;
2322 }
2323 #endif /* DTI */
2324
2325 #if defined (GPRS) AND defined (DTI)
2326 /*
2327 +---------------------------------------------------------------------------+
2328 | PROJECT : GSM-F&D (8411) MODULE : CMH_SIMR |
2329 | STATE : code ROUTINE : SIM_SNDCP_connect_dti_cb |
2330 +---------------------------------------------------------------------------+
2331
2332 PURPOSE : Callback for connection between SIM and SNDCP.
2333
2334 */
2335 GLOBAL BOOL SIM_SNDCP_connect_dti_cb(UBYTE dti_id, T_DTI_CONN_STATE result_type)
2336 {
2337 TRACE_FUNCTION("SIM_SNDCP_connect_dti_cb");
2338
2339 switch( result_type)
2340 {
2341 case DTI_CONN_STATE_DISCONNECTING:
2342 break;
2343 case DTI_CONN_STATE_DISCONNECTED:
2344 dti_cntrl_erase_entry(dti_id);
2345 if (simShrdPrm.sat_class_e_dti_id EQ dti_id)
2346 {
2347 simShrdPrm.sat_class_e_dti_id = DTI_DTI_ID_NOTPRESENT;
2348 TRACE_EVENT("sat_class_e_dti_id reset");
2349 }
2350 break;
2351 case DTI_CONN_STATE_CONNECTING:
2352 break;
2353 case DTI_CONN_STATE_CONNECTED:
2354 /* the SIM-SNDCP connection has been established, now send SIM_BIP_CONFIG
2355 * request to SIM */
2356 psaSIM_Bip_Config_Req();
2357 break;
2358 case DTI_CONN_STATE_ERROR:
2359 /* connection not possible: disconnect SNDCP */
2360 dti_cntrl_close_dpath_from_dti_id( dti_id );
2361 break;
2362 case DTI_CONN_STATE_UNKNOWN:
2363 default:
2364 TRACE_EVENT("SIM_SNDCP_connect_dti_cb call with not awaited value");
2365 break;
2366 }
2367 return TRUE;
2368 }
2369
2370
2371 /*
2372 +--------------------------------------------------------------------------+
2373 | PROJECT : GSM-F&D (8411) MODULE : CMH_SIMR |
2374 | STATE : code ROUTINE : SIM_ENT_GPRSconnect_dti_cb|
2375 +--------------------------------------------------------------------------+
2376
2377 PURPOSE : Callback for connection between SIM and UDP/SNDCP for GPRS.
2378
2379 */
2380
2381 GLOBAL BOOL SIM_ENT_GPRSconnect_dti_cb(UBYTE dti_id, T_DTI_CONN_STATE result_type)
2382 {
2383 TRACE_FUNCTION("SIM_ENT_GPRSconnect_dti_cb");
2384
2385 switch( result_type)
2386 {
2387 case DTI_CONN_STATE_DISCONNECTING:
2388 break;
2389 case DTI_CONN_STATE_DISCONNECTED:
2390 dti_cntrl_erase_entry(dti_id);
2391 if (simShrdPrm.sat_class_e_dti_id EQ dti_id)
2392 {
2393 simShrdPrm.sat_class_e_dti_id = DTI_DTI_ID_NOTPRESENT;
2394 TRACE_EVENT("sat_class_e_dti_id reset");
2395 }
2396 break;
2397 case DTI_CONN_STATE_CONNECTING:
2398 case DTI_CONN_STATE_CONNECTED:
2399 break;
2400 case DTI_CONN_STATE_ERROR:
2401 /* connection not possible: disconnect UDP or SNDCP */
2402 TRACE_EVENT("SIM_ENT_GPRSconnect_dti_cb connection not possible: disconnect UDP or SNDCP");
2403 dti_cntrl_close_dpath_from_dti_id( dti_id );
2404 break;
2405 case DTI_CONN_STATE_UNKNOWN:
2406 default:
2407 TRACE_EVENT("SIM_ENT_GPRSconnect_dti_cb call with not awaited value");
2408 break;
2409 }
2410 return TRUE;
2411 }
2412
2413 #endif /* GPRS */
2414
2415 #endif /* FF_SAT_E */
2416
2417 #ifdef FF_DUAL_SIM
2418
2419 /*
2420 +-------------------------------------------------------------------+
2421 | PROJECT : GSM-PS (6147) MODULE : CMH_SIMR |
2422 | ROUTINE : cmhSIM_SIMSelected |
2423 +-------------------------------------------------------------------+
2424
2425 PURPOSE : Informs the upper layer the result of the SIM Selection process.
2426
2427 */
2428 GLOBAL void cmhSIM_SIMSelected ( void )
2429 {
2430 T_ACI_AT_CMD cmdBuf;
2431 T_ACI_CME_ERR err;
2432
2433 TRACE_FUNCTION("cmhSIM_SIMSelected()");
2434
2435 switch(simEntStat.curCmd)
2436 {
2437 case(AT_CMD_SIM):
2438
2439 switch( simShrdPrm.rslt )
2440 {
2441 case( SIM_NO_ERROR ):
2442
2443 simEntStat.curCmd = AT_CMD_NONE;
2444
2445 R_AT( RAT_OK, simEntStat.entOwn )
2446 ( AT_CMD_SIM );
2447 cmh_logRslt ( simEntStat.entOwn, RAT_OK, AT_CMD_SIM,
2448 -1, BS_SPEED_NotPresent,CME_ERR_NotPresent);
2449 return;
2450
2451 default:
2452 err = cmhSIM_GetCmeFromSim ( simShrdPrm.rslt );
2453 break;
2454 }
2455
2456 cmdBuf = simEntStat.curCmd;
2457 simEntStat.curCmd = AT_CMD_NONE;
2458
2459 R_AT( RAT_CME, simEntStat.entOwn )
2460 ( cmdBuf, err );
2461 cmh_logRslt ( simEntStat.entOwn, RAT_CME, cmdBuf,
2462 -1, BS_SPEED_NotPresent, err );
2463 break;
2464 }
2465 }
2466 #endif /*FF_DUAL_SIM*/
2467
2468 #ifdef FF_CPHS_REL4
2469 /*
2470 +--------------------------------------------------------------------+
2471 | PROJECT : GSM-PS (6147) MODULE : CMH_SIMR |
2472 | ROUTINE : cmhSIM_RdCnfCfis |
2473 +--------------------------------------------------------------------+
2474
2475 PURPOSE : This function handles the confirmation of reading
2476 EF CFIS from SIM.
2477 */
2478 GLOBAL void cmhSIM_RdCnfCfis ( SHORT table_id )
2479 {
2480 T_ACI_AT_CMD cmdBuf; /* buffers current command */
2481 T_ACI_CMD_SRC ownBuf; /* buffers current owner */
2482 T_ACI_CFIS_CFU cfisData; /* CFIS data */
2483
2484 UBYTE *pExchData; /* points to exchange data buffer */
2485 UBYTE dataLen; /* holds length of data */
2486 UBYTE CFISmaxRcd; /* holds no. of records in EF-CFIS */
2487
2488 TRACE_FUNCTION ("cmhSIM_RdCnfCfis()");
2489
2490 cmdBuf = simEntStat.curCmd;
2491 ownBuf = simEntStat.entOwn;
2492 pExchData = simShrdPrm.atb[table_id].exchData;
2493 dataLen = simShrdPrm.atb[table_id].dataLen;
2494
2495 switch ( simShrdPrm.atb[table_id].errCode )
2496 {
2497 case ( SIM_NO_ERROR ):
2498 {
2499 /*
2500 *-------------------------------------------------------------
2501 * check basic consistency of read data
2502 *-------------------------------------------------------------
2503 */
2504 if ( pExchData EQ NULL OR
2505 dataLen < ACI_SIZE_EF_CFIS OR *pExchData EQ 0xFF)
2506 {
2507 simEntStat.curCmd = AT_CMD_NONE;
2508 simEntStat.entOwn = simShrdPrm.owner = OWN_NONE;
2509
2510 R_AT( RAT_CME, ownBuf ) ( cmdBuf, CME_ERR_Unknown );
2511 }
2512 else
2513 {
2514 /*
2515 *-----------------------------------------------------------
2516 * process parameter <msp>
2517 *-----------------------------------------------------------
2518 */
2519 cfisData.mspId = *pExchData;
2520
2521 /*
2522 *-----------------------------------------------------------
2523 * process parameter <cfustat>
2524 *-----------------------------------------------------------
2525 */
2526 cfisData.cfuStat = *(pExchData+1);
2527
2528 /*
2529 *-----------------------------------------------------------
2530 * process parameter <type>
2531 *-----------------------------------------------------------
2532 */
2533 cmhPHB_toaDmrg ( *( pExchData + 3 ),
2534 &cfisData.type );
2535
2536 /*
2537 *-----------------------------------------------------------
2538 * process parameter <number>
2539 *-----------------------------------------------------------
2540 */
2541 cmhPHB_getAdrStr ( cfisData.number ,
2542 MAX_PHB_NUM_LEN - 1,
2543 pExchData + 4,
2544 *(pExchData+2) );
2545
2546 CFISmaxRcd = simShrdPrm.atb[table_id].recMax;
2547
2548 R_AT( RAT_P_CFIS, ownBuf ) ( &cfisData );
2549
2550 if( CFISIndex )
2551 {
2552 if( CFISIndex NEQ CFISmaxRcd )
2553 {
2554 CFISIndex++;
2555 if ( cmhSIM_ReadRecordEF (ownBuf, AT_CMD_P_CFIS, SIM_CFIS,
2556 CFISIndex, NOT_PRESENT_8BIT, NULL, cmhSIM_RdCnfCfis) NEQ AT_EXCT )
2557 {
2558 simEntStat.curCmd = AT_CMD_NONE;
2559 simEntStat.entOwn = simShrdPrm.owner = OWN_NONE;
2560
2561 R_AT( RAT_CME, ownBuf ) ( cmdBuf, CME_ERR_Unknown );
2562 }
2563 }
2564 else
2565 {
2566 CFISIndex=0;
2567 }
2568 }
2569 if( CFISIndex EQ 0 )
2570 {
2571 simEntStat.curCmd = AT_CMD_NONE;
2572 simEntStat.entOwn = simShrdPrm.owner = OWN_NONE;
2573 R_AT( RAT_OK, ownBuf ) ( cmdBuf );
2574 }
2575 }
2576 break;
2577 }
2578 default:
2579 {
2580 simEntStat.curCmd = AT_CMD_NONE;
2581 simEntStat.entOwn = simShrdPrm.owner = OWN_NONE;
2582
2583 R_AT( RAT_CME, ownBuf )
2584 (
2585 cmdBuf,
2586 cmhSIM_GetCmeFromSim ( simShrdPrm.atb[table_id].errCode )
2587 );
2588 break;
2589 }
2590 }
2591 simShrdPrm.atb[table_id].ntryUsdFlg = FALSE;
2592 }
2593
2594 /*
2595 +--------------------------------------------------------------------+
2596 | PROJECT : GSM-PS (6147) MODULE : CMH_SIMR |
2597 | ROUTINE : cmhSIM_WrCnfCfis |
2598 +--------------------------------------------------------------------+
2599
2600 PURPOSE : This function handles the confirmation of writing data
2601 into EF-CFIS in SIM.
2602 */
2603 GLOBAL void cmhSIM_WrCnfCfis ( SHORT table_id )
2604 {
2605
2606 T_ACI_AT_CMD cmdBuf; /* buffers current command */
2607 T_ACI_CMD_SRC ownBuf; /* buffers current owner */
2608
2609 TRACE_FUNCTION ("cmhSIM_WrCnfCfis ()");
2610
2611 cmdBuf = simEntStat.curCmd;
2612 ownBuf = simEntStat.entOwn;
2613 simEntStat.curCmd = AT_CMD_NONE;
2614 simEntStat.entOwn = simShrdPrm.owner = OWN_NONE;
2615
2616 if ( simShrdPrm.atb[table_id].errCode EQ SIM_NO_ERROR)
2617 {
2618 R_AT( RAT_OK, ownBuf ) ( cmdBuf );
2619 }
2620 else
2621 {
2622 R_AT( RAT_CME, ownBuf ) /* unsuccessful SIM write */
2623 (
2624 cmdBuf,
2625 cmhSIM_GetCmeFromSim ( simShrdPrm.atb[table_id].errCode )
2626 );
2627 }
2628 simShrdPrm.atb[table_id].ntryUsdFlg = FALSE;
2629 }
2630 /*
2631 +--------------------------------------------------------------------+
2632 | PROJECT : GSM-PS (6147) MODULE : CMH_SIMR |
2633 | ROUTINE : cmhSIM_RdCnfMbi |
2634 +--------------------------------------------------------------------+
2635
2636 PURPOSE : This function handles the confirmation of reading
2637 EF-MBI from SIM.
2638 */
2639 GLOBAL void cmhSIM_RdCnfMbi ( SHORT table_id )
2640 {
2641 T_ACI_AT_CMD cmdBuf; /* buffers current command */
2642 T_ACI_CMD_SRC ownBuf; /* buffers current owner */
2643 T_ACI_MBI mbiData; /* MBT data */
2644
2645 UBYTE *pExchData; /* points to exchange data buffer */
2646 UBYTE dataLen; /* holds length of data */
2647 UBYTE MBImaxRcd; /* holds no. of records in EF-MBI */
2648
2649
2650 TRACE_FUNCTION ("cmhSIM_RdCnfMbi()");
2651
2652 cmdBuf = simEntStat.curCmd;
2653 ownBuf = simEntStat.entOwn;
2654 simEntStat.curCmd = AT_CMD_NONE;
2655 simEntStat.entOwn = simShrdPrm.owner = OWN_NONE;
2656 pExchData = simShrdPrm.atb[table_id].exchData;
2657 dataLen = simShrdPrm.atb[table_id].dataLen;
2658 MBImaxRcd = simShrdPrm.atb[table_id].recMax;
2659
2660 switch ( simShrdPrm.atb[table_id].errCode )
2661 {
2662 case ( SIM_NO_ERROR ):
2663 {
2664 /*
2665 *-------------------------------------------------------------
2666 * check basic consistency of read data
2667 *-------------------------------------------------------------
2668 */
2669 if ( pExchData EQ NULL OR
2670 dataLen < ACI_SIZE_EF_MBI )
2671 {
2672 R_AT( RAT_CME, ownBuf ) ( cmdBuf, CME_ERR_Unknown );
2673 }
2674 else
2675 {
2676 mbiData.mbdn_id_voice = *pExchData;
2677 mbiData.mbdn_id_fax = *( pExchData + 1 );
2678 mbiData.mbdn_id_email = *( pExchData + 2 );
2679 mbiData.mbdn_id_other = *( pExchData + 3 );
2680
2681 R_AT( RAT_P_MBI, ownBuf ) ( &mbiData );
2682
2683 if( MBI_Index )
2684 {
2685 if( MBI_Index NEQ MBImaxRcd )
2686 {
2687 MBI_Index++;
2688 if ( cmhSIM_ReadRecordEF (ownBuf, AT_CMD_P_MBI, SIM_MBI,
2689 MBI_Index, NOT_PRESENT_8BIT, NULL, cmhSIM_RdCnfMbi) NEQ AT_EXCT )
2690 {
2691 R_AT( RAT_CME, ownBuf ) ( cmdBuf, CME_ERR_Unknown );
2692 }
2693 }
2694 else
2695 {
2696 MBI_Index = 0;
2697 }
2698 }
2699 if( MBI_Index EQ 0 )
2700 {
2701 R_AT( RAT_OK, ownBuf ) ( cmdBuf );
2702 }
2703 }
2704 break;
2705 }
2706 default:
2707 {
2708 R_AT( RAT_CME, ownBuf )
2709 (
2710 cmdBuf,
2711 cmhSIM_GetCmeFromSim ( simShrdPrm.atb[table_id].errCode )
2712 );
2713 break;
2714 }
2715 }
2716 simShrdPrm.atb[table_id].ntryUsdFlg = FALSE;
2717 }
2718 /*
2719 +--------------------------------------------------------------------+
2720 | PROJECT : GSM-PS (6147) MODULE : CMH_SIMR |
2721 | ROUTINE : cmhSIM_RdCnfMbdn |
2722 +--------------------------------------------------------------------+
2723
2724 PURPOSE : This function handles the confirmation of reading
2725 EF-MBDN from SIM.
2726 */
2727 GLOBAL void cmhSIM_RdCnfMbdn ( SHORT table_id )
2728 {
2729 T_ACI_AT_CMD cmdBuf; /* buffers current command */
2730 T_ACI_CMD_SRC ownBuf; /* buffers current owner */
2731 T_ACI_MBDN mbdnData; /* MBDN data */
2732
2733 UBYTE *pExchData; /* points to exchange data buffer */
2734 UBYTE dataLen; /* holds length of data */
2735 UBYTE alphaLen; /* max. length of alpha identifier */
2736
2737 TRACE_FUNCTION ("cmhSIM_RdCnfMbdn()");
2738
2739 cmdBuf = simEntStat.curCmd;
2740 ownBuf = simEntStat.entOwn;
2741 pExchData = simShrdPrm.atb[table_id].exchData;
2742 dataLen = simShrdPrm.atb[table_id].dataLen;
2743 simEntStat.curCmd = AT_CMD_NONE;
2744 simEntStat.entOwn = simShrdPrm.owner = OWN_NONE;
2745
2746 switch ( simShrdPrm.atb[table_id].errCode )
2747 {
2748 case ( SIM_NO_ERROR ):
2749 {
2750 /*
2751 *-------------------------------------------------------------
2752 * check basic consistency of read data
2753 *-------------------------------------------------------------
2754 */
2755 if ( pExchData EQ NULL OR
2756 dataLen < ACI_SIZE_EF_MBDN )
2757 {
2758 R_AT( RAT_CME, ownBuf ) ( cmdBuf, CME_ERR_Unknown );
2759 }
2760 else
2761 {
2762 alphaLen = dataLen - ACI_MIN_SIZE_EF_MSISDN;
2763 /*
2764 *-----------------------------------------------------------
2765 * process parameter <alpha>
2766 *-----------------------------------------------------------
2767 */
2768 cmhPHB_getTagNt ( pExchData,
2769 alphaLen,
2770 mbdnData.alpha,
2771 MAX_ALPHA_LEN );
2772
2773 pExchData += alphaLen;
2774 /*
2775 *-----------------------------------------------------------
2776 * process parameter <type>
2777 *-----------------------------------------------------------
2778 */
2779 cmhPHB_toaDmrg ( *( pExchData + 1 ),
2780 &mbdnData.type );
2781
2782 /*
2783 *-----------------------------------------------------------
2784 * process parameter <number>
2785 *-----------------------------------------------------------
2786 */
2787 cmhPHB_getAdrStr ( mbdnData.number ,
2788 MAX_MB_NUM_LEN - 1,
2789 pExchData + 2,
2790 *pExchData );
2791
2792 R_AT( RAT_P_MBDN, ownBuf ) ( &mbdnData );
2793 R_AT( RAT_OK, ownBuf ) ( cmdBuf );
2794 }
2795 break;
2796 }
2797 default:
2798 {
2799 R_AT( RAT_CME, ownBuf )
2800 (
2801 cmdBuf,
2802 cmhSIM_GetCmeFromSim ( simShrdPrm.atb[table_id].errCode )
2803 );
2804 break;
2805 }
2806 }
2807 simShrdPrm.atb[table_id].ntryUsdFlg = FALSE;
2808 }
2809
2810 /*
2811 +--------------------------------------------------------------------+
2812 | PROJECT : GSM-PS (6147) MODULE : CMH_SIMR |
2813 | ROUTINE : cmhSIM_WrCnfMbdn |
2814 +--------------------------------------------------------------------+
2815
2816 PURPOSE : This function handles the confirmation of writing data
2817 into EF-MBDN in SIM.
2818 */
2819 GLOBAL void cmhSIM_WrCnfMbdn ( SHORT table_id )
2820 {
2821
2822 T_ACI_AT_CMD cmdBuf; /* buffers current command */
2823 T_ACI_CMD_SRC ownBuf; /* buffers current owner */
2824
2825 TRACE_FUNCTION ("cmhSIM_WrCnfMbdn ()");
2826
2827 cmdBuf = simEntStat.curCmd;
2828 ownBuf = simEntStat.entOwn;
2829 simEntStat.curCmd = AT_CMD_NONE;
2830 simEntStat.entOwn = simShrdPrm.owner = OWN_NONE;
2831
2832 if ( simShrdPrm.atb[table_id].errCode EQ SIM_NO_ERROR)
2833 {
2834 R_AT( RAT_OK, ownBuf ) ( cmdBuf );
2835 }
2836 else
2837 {
2838 R_AT( RAT_CME, ownBuf ) /* unsuccessful SIM write */
2839 (
2840 cmdBuf,
2841 cmhSIM_GetCmeFromSim ( simShrdPrm.atb[table_id].errCode )
2842 );
2843 }
2844 simShrdPrm.atb[table_id].ntryUsdFlg = FALSE;
2845 }
2846
2847 /*
2848 +--------------------------------------------------------------------+
2849 | PROJECT : GSM-PS (6147) MODULE : CMH_SIMR |
2850 | ROUTINE : cmhSIM_RdCnfMwis |
2851 +--------------------------------------------------------------------+
2852
2853 PURPOSE : This function handles the confirmation of reading
2854 EF MWIS from SIM.
2855 */
2856 GLOBAL void cmhSIM_RdCnfMwis ( SHORT table_id )
2857 {
2858 T_ACI_AT_CMD cmdBuf; /* buffers current command */
2859 T_ACI_CMD_SRC ownBuf; /* buffers current owner */
2860 T_ACI_MWIS_MWI mwisData; /* MWIS data */
2861
2862 UBYTE *pExchData; /* points to exchange data buffer */
2863 UBYTE dataLen; /* holds length of data */
2864 UBYTE MWISmaxRcd; /* holds no. of records in EF-MWIS */
2865
2866 TRACE_FUNCTION ("cmhSIM_RdCnfMwis()");
2867
2868 cmdBuf = simEntStat.curCmd;
2869 ownBuf = simEntStat.entOwn;
2870 pExchData = simShrdPrm.atb[table_id].exchData;
2871 dataLen = simShrdPrm.atb[table_id].dataLen;
2872
2873 switch ( simShrdPrm.atb[table_id].errCode )
2874 {
2875 case ( SIM_NO_ERROR ):
2876 {
2877 /*
2878 *-------------------------------------------------------------
2879 * check basic consistency of read data
2880 *-------------------------------------------------------------
2881 */
2882 if ( pExchData EQ NULL OR
2883 dataLen < ACI_SIZE_EF_MWIS OR *pExchData EQ 0x00)
2884 {
2885 simEntStat.curCmd = AT_CMD_NONE;
2886 simEntStat.entOwn = simShrdPrm.owner = OWN_NONE;
2887
2888 R_AT( RAT_CME, ownBuf ) ( cmdBuf, CME_ERR_Unknown );
2889 }
2890 else
2891 {
2892 /*
2893 *-----------------------------------------------------------
2894 * process parameter <mwisStat>
2895 *-----------------------------------------------------------
2896 */
2897 mwisData.mwiStat = *pExchData;
2898
2899 /*
2900 *-----------------------------------------------------------
2901 * process parameter <mwis_count_voice>
2902 *-----------------------------------------------------------
2903 */
2904 mwisData.mwis_count_voice = *(pExchData+1);
2905
2906 /*
2907 *-----------------------------------------------------------
2908 * process parameter <mwis_count_fax>
2909 *-----------------------------------------------------------
2910 */
2911 mwisData.mwis_count_fax = *(pExchData+2);
2912
2913 /*
2914 *-----------------------------------------------------------
2915 * process parameter <mwis_count_email>
2916 *-----------------------------------------------------------
2917 */
2918 mwisData.mwis_count_email = *(pExchData+3);
2919
2920 /*
2921 *-----------------------------------------------------------
2922 * process parameter <mwis_count_other>
2923 *-----------------------------------------------------------
2924 */
2925 mwisData.mwis_count_other = *(pExchData+4);
2926
2927 MWISmaxRcd = simShrdPrm.atb[table_id].recMax;
2928
2929 R_AT( RAT_P_MWIS, ownBuf ) ( &mwisData );
2930
2931 if( MWISIndex )
2932 {
2933 if( MWISIndex NEQ MWISmaxRcd )
2934 {
2935 MWISIndex++;
2936 if ( cmhSIM_ReadRecordEF (ownBuf, AT_CMD_P_MWIS, SIM_MWIS,
2937 MWISIndex, NOT_PRESENT_8BIT, NULL, cmhSIM_RdCnfMwis) NEQ AT_EXCT )
2938 {
2939 simEntStat.curCmd = AT_CMD_NONE;
2940 simEntStat.entOwn = simShrdPrm.owner = OWN_NONE;
2941
2942 R_AT( RAT_CME, ownBuf ) ( cmdBuf, CME_ERR_Unknown );
2943 }
2944 }
2945 else
2946 {
2947 MWISIndex=0;
2948 }
2949 }
2950 if( MWISIndex EQ 0 )
2951 {
2952 simEntStat.curCmd = AT_CMD_NONE;
2953 simEntStat.entOwn = simShrdPrm.owner = OWN_NONE;
2954 R_AT( RAT_OK, ownBuf ) ( cmdBuf );
2955 }
2956 }
2957 break;
2958 }
2959 default:
2960 {
2961 simEntStat.curCmd = AT_CMD_NONE;
2962 simEntStat.entOwn = simShrdPrm.owner = OWN_NONE;
2963
2964 R_AT( RAT_CME, ownBuf )
2965 (
2966 cmdBuf,
2967 cmhSIM_GetCmeFromSim ( simShrdPrm.atb[table_id].errCode )
2968 );
2969 break;
2970 }
2971 }
2972 simShrdPrm.atb[table_id].ntryUsdFlg = FALSE;
2973 }
2974
2975 /*
2976 +--------------------------------------------------------------------+
2977 | PROJECT : GSM-PS (6147) MODULE : CMH_SIMR |
2978 | ROUTINE : cmhSIM_WrCnfMwis |
2979 +--------------------------------------------------------------------+
2980
2981 PURPOSE : This function handles the confirmation of writing data
2982 into EF-MWIS in SIM.
2983 */
2984 GLOBAL void cmhSIM_WrCnfMwis ( SHORT table_id )
2985 {
2986
2987 T_ACI_AT_CMD cmdBuf; /* buffers current command */
2988 T_ACI_CMD_SRC ownBuf; /* buffers current owner */
2989 U8 i = 0;
2990 T_ACI_MWIS_MWI mwisData; /* MWIS data */
2991
2992 TRACE_FUNCTION ("cmhSIM_WrCnfMwis ()");
2993
2994 cmdBuf = simEntStat.curCmd;
2995 ownBuf = simEntStat.entOwn;
2996 simEntStat.curCmd = AT_CMD_NONE;
2997 simEntStat.entOwn = simShrdPrm.owner = OWN_NONE;
2998
2999 if ( simShrdPrm.atb[table_id].errCode EQ SIM_NO_ERROR)
3000 {
3001 if( cmdBuf NEQ AT_CMD_P_MWIS )
3002 {
3003 memcpy(&mwisData,&smsShrdPrm.MWISdata,sizeof(T_ACI_MWIS_MWI));
3004 for(i; i < CMD_SRC_MAX; i++)
3005 {
3006 R_AT( RAT_P_MWI, i)(1,&mwisData);
3007 }
3008 }
3009 else
3010 {
3011 R_AT( RAT_OK, ownBuf ) ( cmdBuf );
3012 }
3013 }
3014 else
3015 {
3016 R_AT( RAT_CME, ownBuf ) /* unsuccessful SIM write */
3017 (
3018 cmdBuf,
3019 cmhSIM_GetCmeFromSim ( simShrdPrm.atb[table_id].errCode )
3020 );
3021 }
3022 simShrdPrm.atb[table_id].ntryUsdFlg = FALSE;
3023 }
3024 #endif /* FF_CPHS_REL4 */
3025
3026 /* Implements Measure 97 */
3027 /*
3028 +------------------------------------------------------------------------------
3029 | Function : cmhSIM_CardUnblocked_PINChanged
3030 +------------------------------------------------------------------------------
3031 | Purpose : This function can check whether the Card is Unblocked
3032 | or PIN is Changed.
3033 | When this function will be called for checking whether
3034 | the PIN is changed then the argument PINChanged will be
3035 | TRUE otherwise it will be FALSE
3036 |
3037 | Parameters : PINChanged - TRUE or FALSE
3038 |
3039 | Return : void
3040 +------------------------------------------------------------------------------
3041 */
3042
3043 GLOBAL void cmhSIM_CardUnblocked_PINChanged ( BOOL PINChanged )
3044 {
3045 UBYTE cmdBuf;
3046 T_ACI_CME_ERR err;
3047
3048 TRACE_FUNCTION ( "cmhSIM_CardUnblocked_PINChanged()" );
3049
3050 /*
3051 *-------------------------------------------------------------------
3052 * check for command context
3053 *-------------------------------------------------------------------
3054 */
3055
3056 switch( simEntStat.curCmd )
3057 {
3058 case( AT_CMD_CPIN ):
3059 case( AT_CMD_PVRF ):
3060 /*lint -e{408}*/
3061 case( KSD_CMD_UBLK ):
3062 case( AT_CMD_CPWD ):
3063 /*lint -e{408}*/
3064 case( KSD_CMD_PWD ):
3065 /*
3066 *----------------------------------------------------------------
3067 * process event for +CPIN, %PVRF and KSD UBLK command
3068 * also
3069 * process event for +CPWD and KSD PWD command
3070 *----------------------------------------------------------------
3071 */
3072 switch( simShrdPrm.rslt )
3073 {
3074 case( SIM_NO_ERROR ):
3075 if( (PINChanged EQ TRUE) OR (simShrdPrm.crdPhs NEQ 0xFF) )
3076 {
3077 cmdBuf = simEntStat.curCmd;
3078 simEntStat.curCmd = AT_CMD_NONE;
3079
3080 R_AT( RAT_OK, simEntStat.entOwn )
3081 ( cmdBuf );
3082 cmh_logRslt ( simEntStat.entOwn, RAT_OK, (T_ACI_AT_CMD)cmdBuf, -1, BS_SPEED_NotPresent, CME_ERR_NotPresent );
3083 }
3084 return;
3085
3086 case( SIM_CAUSE_PIN1_EXPECT ):
3087 case( SIM_CAUSE_PIN2_EXPECT ):
3088 err = CME_ERR_WrongPasswd;
3089 break;
3090
3091 default:
3092 err = cmhSIM_GetCmeFromSim ( simShrdPrm.rslt );
3093 break;
3094 }
3095
3096 cmdBuf = simEntStat.curCmd;
3097 simEntStat.curCmd = AT_CMD_NONE;
3098
3099 R_AT( RAT_CME, simEntStat.entOwn )
3100 ( cmdBuf, err );
3101
3102 cmh_logRslt ( simEntStat.entOwn, RAT_CME, (T_ACI_AT_CMD)cmdBuf,
3103 -1, BS_SPEED_NotPresent, err );
3104 break;
3105 }
3106 }
3107
3108 /* Implements Measure 106 */
3109 /*
3110 +------------------------------------------------------------------------------
3111 | Function : cmhSIM_ProcessEvents
3112 |------------------------------------------------------------------------------
3113 | Purpose : Process Events for +CAMM, +CPUC, +CACM commands.
3114 |
3115 | Parameters : at_cmd_id - AT command identifier
3116 |
3117 | Return : void
3118 +------------------------------------------------------------------------------
3119 */
3120
3121 LOCAL void cmhSIM_ProcessEvents ( T_ACI_AT_CMD at_cmd_id )
3122 {
3123 TRACE_FUNCTION ( "cmhSIM_ProcessEvents()" );
3124
3125 simEntStat.curCmd = AT_CMD_NONE;
3126
3127 if( simShrdPrm.rslt EQ SIM_NO_ERROR )
3128 {
3129 /*
3130 * Try it again
3131 */
3132 switch ( at_cmd_id )
3133 {
3134 case ( AT_CMD_CAMM ):
3135 aoc_update_sim_datafield ( SECOND_UPDATE, ACT_WR_DAT,
3136 SIM_ACMMAX, aoc_update_acmmax_cb );
3137 break;
3138
3139 case ( AT_CMD_CPUC ):
3140 aoc_update_puct (SECOND_UPDATE, 0L);
3141 break;
3142
3143 case ( AT_CMD_CACM ):
3144 aoc_update_sim_datafield ( SECOND_UPDATE, ACT_WR_REC,
3145 SIM_ACM, aoc_update_acm_cb );
3146 break;
3147 }
3148 }
3149 else
3150 {
3151 R_AT( RAT_CME, simEntStat.entOwn )
3152 ( at_cmd_id, CME_ERR_WrongPasswd );
3153 }
3154 }
3155
3156 /* Implements Measure 183 */
3157 /*
3158 +------------------------------------------------------------------------------
3159 | Function : cmhSIM_PINEnabledDisabled
3160 |------------------------------------------------------------------------------
3161 | Purpose : SIM Enabled or Disabled
3162 |
3163 | Parameters : void
3164 |
3165 | Return : void
3166 +------------------------------------------------------------------------------
3167 */
3168
3169 GLOBAL void cmhSIM_PINEnabledDisabled ( void )
3170 {
3171 T_ACI_CME_ERR err;
3172
3173 TRACE_FUNCTION ( "cmhSIM_PINEnabledDisabled()" );
3174
3175 /*
3176 *-------------------------------------------------------------------
3177 * check for command context
3178 *-------------------------------------------------------------------
3179 */
3180 if( simEntStat.curCmd EQ AT_CMD_CLCK )
3181 {
3182 /*
3183 *----------------------------------------------------------------
3184 * process event for +CLCK command
3185 *----------------------------------------------------------------
3186 */
3187 switch( simShrdPrm.rslt )
3188 {
3189 case( SIM_NO_ERROR ):
3190
3191 simEntStat.curCmd = AT_CMD_NONE;
3192
3193 R_AT( RAT_OK, simEntStat.entOwn )
3194 ( AT_CMD_CLCK );
3195 cmh_logRslt ( simEntStat.entOwn, RAT_OK, AT_CMD_CLCK, -1, BS_SPEED_NotPresent, CME_ERR_NotPresent );
3196 return;
3197
3198 case( SIM_CAUSE_PIN1_EXPECT ):
3199 case( SIM_CAUSE_PIN1_BLOCKED ):
3200 err = CME_ERR_WrongPasswd;
3201 break;
3202
3203 default:
3204 err = cmhSIM_GetCmeFromSim ( simShrdPrm.rslt );
3205 break;
3206 }
3207
3208 simEntStat.curCmd = AT_CMD_NONE;
3209
3210 R_AT( RAT_CME, simEntStat.entOwn )
3211 ( AT_CMD_CLCK, err );
3212 cmh_logRslt ( simEntStat.entOwn, RAT_CME, AT_CMD_CLCK,
3213 -1, BS_SPEED_NotPresent, err );
3214 }
3215 }
3216
3217 /* Implements Measure 200 */
3218 /*
3219 +------------------------------------------------------------------------------
3220 | Function : cmhSIM_Compare_CNUMMsisdnIdx
3221 |------------------------------------------------------------------------------
3222 | Purpose : Comapres CNUMMsisdnIdx
3223 |
3224 | Parameters : void
3225 |
3226 | Return : void
3227 +------------------------------------------------------------------------------
3228 */
3229
3230 LOCAL void cmhSIM_Compare_CNUMMsisdnIdx ( void )
3231 {
3232 T_SIM_CMD_PRM* pSIMCmdPrm;
3233 T_ACI_AT_CMD cmdBuf;
3234 T_ACI_CMD_SRC ownBuf;
3235
3236 TRACE_FUNCTION ( "cmhSIM_Compare_CNUMMsisdnIdx()" );
3237
3238 pSIMCmdPrm = &cmhPrm[simEntStat.entOwn].simCmdPrm;
3239 cmdBuf = simEntStat.curCmd;
3240 ownBuf = simEntStat.entOwn;
3241
3242 if ( (CNUMMsisdnIdx EQ MAX_MSISDN - 1) OR
3243 ((pSIMCmdPrm -> CNUMActRec) EQ CNUMMaxRec) )
3244 {
3245 simEntStat.curCmd = AT_CMD_NONE;
3246 simShrdPrm.owner = (T_OWN)CMD_SRC_NONE;
3247 simEntStat.entOwn = CMD_SRC_NONE;
3248
3249 R_AT( RAT_CNUM, ownBuf ) ( &CNUMMsisdn[0], CNUMMaxRec );
3250
3251 if ( (pSIMCmdPrm -> CNUMActRec) EQ CNUMMaxRec )
3252 {
3253 if (pSIMCmdPrm -> CNUMOutput)
3254 {
3255 R_AT( RAT_OK, ownBuf ) ( cmdBuf );
3256 }
3257 else
3258 {
3259 R_AT( RAT_CME, ownBuf ) ( cmdBuf, CME_ERR_NotFound );
3260 }
3261 }
3262 }
3263 else
3264 {
3265 CNUMMsisdnIdx++;
3266 pSIMCmdPrm -> CNUMActRec++;
3267
3268 if ( cmhSIM_ReqMsisdn ( ownBuf, pSIMCmdPrm -> CNUMActRec ) NEQ AT_EXCT )
3269 {
3270 cmhSIM_SndError( ownBuf, cmdBuf, CME_ERR_Unknown );
3271 }
3272 }
3273
3274 }
3275
3276 /* Implements Measure 7, 17, 24, 35 */
3277 /*
3278 +------------------------------------------------------------------------------
3279 | Function : cmhSIM_SndError
3280 |------------------------------------------------------------------------------
3281 | Purpose : Reports Error
3282 |
3283 | Parameters : ownBuf - AT Command Source Identifier
3284 | cmdBuf - AT Command Identifier
3285 | cme_err - +CME ERROR parameter
3286 |
3287 | Return : void
3288 +------------------------------------------------------------------------------
3289 */
3290 LOCAL void cmhSIM_SndError( T_ACI_CMD_SRC ownBuf, T_ACI_AT_CMD cmdBuf,
3291 T_ACI_CME_ERR cme_err )
3292 {
3293 TRACE_FUNCTION ( "cmhSIM_SndError()" );
3294
3295 simEntStat.curCmd = AT_CMD_NONE;
3296 simShrdPrm.owner = (T_OWN)CMD_SRC_NONE;
3297 simEntStat.entOwn = CMD_SRC_NONE;
3298
3299 R_AT( RAT_CME, ownBuf ) ( cmdBuf, cme_err );
3300
3301 }
3302
3303 /*==== EOF ========================================================*/
3304