FreeCalypso > hg > fc-tourmaline
diff src/g23m-aci/aci/cmh_mmr.c @ 1:fa8dc04885d8
src/g23m-*: import from Magnetite
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Fri, 16 Oct 2020 06:25:50 +0000 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/g23m-aci/aci/cmh_mmr.c Fri Oct 16 06:25:50 2020 +0000 @@ -0,0 +1,804 @@ +/* ++----------------------------------------------------------------------------- +| Project : GSM-PS (6147) +| Modul : CMH_MMR ++----------------------------------------------------------------------------- +| Copyright 2002 Texas Instruments Berlin, AG +| All rights reserved. +| +| This file is confidential and a trade secret of Texas +| Instruments Berlin, AG +| The receipt of or possession of this file does not convey +| any rights to reproduce or disclose its contents or to +| manufacture, use, or sell anything it may describe, in +| whole, or in part, without the specific written consent of +| Texas Instruments Berlin, AG. ++----------------------------------------------------------------------------- +| Purpose : This module defines the functions which are responsible +| for the responses of the protocol stack adapter for +| mobility management. ++----------------------------------------------------------------------------- +*/ + +#ifndef CMH_MMR_C +#define CMH_MMR_C +#endif + +#include "aci_all.h" + +/*==== INCLUDES ===================================================*/ + +#include "aci_cmh.h" +#include "ati_cmd.h" +#include "aci_cmd.h" +#include "aci_mem.h" + +#ifdef FAX_AND_DATA +#include "aci_fd.h" +#endif /* of #ifdef FAX_AND_DATA */ + +#include "aci.h" +#include "psa.h" +#include "psa_mm.h" +#include "psa_sim.h" +#include "cmh.h" +#include "cmh_mm.h" + +#ifdef DTI + #include "dti.h" /* functionality of the dti library */ + #include "dti_conn_mng.h" + #include "dti_cntrl_mng.h" +#endif + +#include "cmh_sim.h" + +#ifdef GPRS + #include "gaci.h" + #include "gaci_cmh.h" + #include "psa_gmm.h" + #include "cmh_gmm.h" +#endif + +/*==== CONSTANTS ==================================================*/ + + +/*==== TYPES ======================================================*/ + + +/*==== EXPORT =====================================================*/ + + +/*==== VARIABLES ==================================================*/ + +/*==== FUNCTIONS ==================================================*/ +LOCAL void cmhMM_Registration_AutoMode( T_ACI_AT_CMD at_cmd_id ); +/* ++-------------------------------------------------------------------+ +| PROJECT : GSM-PS (6147) MODULE : CMH_MMR | +| ROUTINE : cmhMM_Registered | ++-------------------------------------------------------------------+ + + PURPOSE : ME is registered to the network + +*/ + +GLOBAL SHORT cmhMM_Registered ( void ) +{ + SHORT mncCur, mccCur; /* holds mnc and mcc of current PLMN */ + UBYTE cmdBuf; /* buffers current command */ + + TRACE_FUNCTION ("cmhMM_Registered()"); + +/* + *------------------------------------------------------------------- + * check for command context + *------------------------------------------------------------------- + */ + switch( mmEntStat.curCmd ) + { + case( AT_CMD_NONE ): + case( AT_CMD_COPS ): + case (AT_CMD_P_COPS): + case( AT_CMD_NRG ): + + /* check for home PLMN or roaming */ + if( mmShrdPrm.usedPLMN.v_plmn EQ VLD_PLMN ) + { + cmhMM_CnvrtPLMN2INT( mmShrdPrm.usedPLMN.mcc, + mmShrdPrm.usedPLMN.mnc, + &mccCur, &mncCur ); + + /* Store the new PLMN and the IMSI in the FFS */ + if (!cmhMM_OperatorStoreInFFS(mmShrdPrm.usedPLMN.mcc, + mmShrdPrm.usedPLMN.mnc, + simShrdPrm.imsi.field)) + TRACE_EVENT("Could not write PLMN and IMSI in FFS"); + + + if( cmhSIM_plmn_is_hplmn (mccCur, mncCur)) + { + cmhMM_Ntfy_NtwRegistrationStatus(CREG_STAT_Reg); + } + else + { + cmhMM_Ntfy_NtwRegistrationStatus(CREG_STAT_Roam); + } + } + + if( mmEntStat.curCmd NEQ AT_CMD_NONE ) + { +#if defined (GPRS) AND defined (DTI) + psaG_MM_CMD_SET_REGMD ( mmShrdPrm.regMode ); /* restore former registration mode*/ +#else + /* restore former registration mode */ + psaMM_SetRegMode ( mmShrdPrm.regMode ); +#endif + + cmdBuf = mmEntStat.curCmd; + mmEntStat.curCmd = AT_CMD_NONE; + + /* From the flight mode if the user registers directly + change the variable to full functionality. */ + if (CFUNfun NEQ CFUN_FUN_Full) + { + CFUNfun = CFUN_FUN_Full; + } + + R_AT( RAT_OK, mmEntStat.entOwn ) + ( cmdBuf ); + + /* log result */ + cmh_logRslt ( mmEntStat.entOwn, RAT_OK, (T_ACI_AT_CMD)cmdBuf, + -1, BS_SPEED_NotPresent ,CME_ERR_NotPresent ); + } + break; + } + + return 0; +} + +/* ++-------------------------------------------------------------------+ +| PROJECT : GSM-PS (6147) MODULE : CMH_MMR | +| ROUTINE : cmhMM_Deregistered | ++-------------------------------------------------------------------+ + + PURPOSE : ME is deregistered from network + +*/ + +GLOBAL SHORT cmhMM_Deregistered ( void ) +{ + T_ACI_RETURN ret; + + TRACE_FUNCTION ("cmhMM_Deregistered()"); + +/* + *------------------------------------------------------------------- + * check for command context + *------------------------------------------------------------------- + */ + switch( mmEntStat.curCmd ) + { + case( AT_CMD_NONE ): + /* + *---------------------------------------------------------------- + * process event if no command was invoked + *---------------------------------------------------------------- + */ + switch( mmShrdPrm.deregCs ) + { + case( NREG_LIMITED_SERVICE ): + case( NREG_NO_SERVICE ): + + if (mmShrdPrm.regModeAutoBack) + { + /* + * Fallback to automatic mode is allowed, fallback. + * If MM is not in full service and the registration mode + * is switched from manual to automatic, + * MM starts a network search immediately. + */ + mmShrdPrm.regModeBeforeAbort = mmShrdPrm.regMode; + mmShrdPrm.regMode = MODE_AUTO; + mmShrdPrm.regModeAutoBack = FALSE; +#if defined (GPRS) AND defined (DTI) + psaG_MM_CMD_SET_REGMD ( MODE_AUTO ); +#else + psaMM_SetRegMode (MODE_AUTO); +#endif + } + + cmhMM_Ntfy_NtwRegistrationStatus(cmhMM_GetNregCREGStat()); + break; + } + break; + + case( AT_CMD_CFUN ): + /* + *---------------------------------------------------------------- + * process event for +CFUN command + *---------------------------------------------------------------- + */ + mmEntStat.curCmd = AT_CMD_NONE; + + cmhMM_Ntfy_NtwRegistrationStatus(CREG_STAT_NoSearch); + + if (simEntStat.curCmd NEQ AT_CMD_CFUN) /* Has SIM already finished flushing of LDN entries? */ + { + R_AT( RAT_OK, mmEntStat.entOwn ) + ( AT_CMD_CFUN ); + + /* log result */ + cmh_logRslt ( mmEntStat.entOwn, RAT_OK, AT_CMD_CFUN, -1, + BS_SPEED_NotPresent,CME_ERR_NotPresent ); + } + + break; + + case( AT_CMD_BAND ): + /* + *---------------------------------------------------------------- + * process event for %BAND command + *---------------------------------------------------------------- + */ + cmhMM_Ntfy_NtwRegistrationStatus(CREG_STAT_NoSearch); + + /* switch back to full functionnality */ + ret = sAT_PlusCFUN( mmEntStat.entOwn, + CFUN_FUN_Full, + CFUN_RST_NotPresent ); + + + /* SPR#919 - SH - fix advised by CLB */ + mmEntStat.curCmd = AT_CMD_NONE; + simEntStat.curCmd = AT_CMD_NONE; + /* end SH */ + + if( ret EQ AT_CMPL ) + { + R_AT( RAT_OK, mmEntStat.entOwn ) + (AT_CMD_BAND); + } + else + { + TRACE_EVENT_P1 + ("Fatal Error in sAT_PlusCFUN switching on !!!, ret_type: %d", ret); + R_AT( RAT_CME, mmEntStat.entOwn ) + ( AT_CMD_BAND, CME_ERR_Unknown ); + + } + /*SPR#919 - SH - fix advised by CLB + mmEntStat.curCmd = AT_CMD_NONE; + simEntStat.curCmd = AT_CMD_NONE; + */ + break; + + case( AT_CMD_COPS ): + case( AT_CMD_P_COPS): + /* + *---------------------------------------------------------------- + * process event for +COPS command + *---------------------------------------------------------------- + */ + switch( mmShrdPrm.COPSmode ) + { + case( COPS_MOD_Auto ): + case( COPS_MOD_Man ): + + cmhMM_Ntfy_NtwRegistrationStatus(CREG_STAT_Denied); + + /* If the current running command is AT+COPS=?, we should not do the below + actions. pnn_read_cnt will be valid when AT+COPS=? is running. */ + if (mmShrdPrm.pnn_read_cnt EQ 0) + { + mmEntStat.curCmd = AT_CMD_NONE; +#if defined (GPRS) AND defined (DTI) + psaG_MM_CMD_SET_REGMD ( mmShrdPrm.regMode ); /* restore former registration mode*/ +#else + /* restore former registration mode */ + psaMM_SetRegMode ( mmShrdPrm.regMode); +#endif + + R_AT( RAT_CME, mmEntStat.entOwn ) + ( mmEntStat.curCmd, cmhMM_GetNregCMEStat() ); + + /* log result */ + cmh_logRslt ( mmEntStat.entOwn, RAT_CME, AT_CMD_COPS, -1, BS_SPEED_NotPresent , + cmhMM_GetNregCMEStat() ); + } + break; + case( COPS_MOD_Dereg ): + + cmhMM_Ntfy_NtwRegistrationStatus(CREG_STAT_NoSearch); + + R_AT( RAT_OK, mmEntStat.entOwn ) + ( mmEntStat.curCmd ); + + /* log result */ + cmh_logRslt ( mmEntStat.entOwn, RAT_OK, mmEntStat.curCmd, -1, + BS_SPEED_NotPresent,CME_ERR_NotPresent ); + + mmEntStat.curCmd = AT_CMD_NONE; + break; + + case( COPS_MOD_SetOnly ): + + cmhMM_Ntfy_NtwRegistrationStatus(cmhMM_GetNregCREGStat()); + break; + + case( COPS_MOD_Both ): + + /* Implements Measure 87 */ + cmhMM_Registration_AutoMode( mmEntStat.curCmd ); + break; + } + break; + + case( AT_CMD_NRG ): + /* + *---------------------------------------------------------------- + * process event for %NRG command + *---------------------------------------------------------------- + */ + switch( cmhPrm[mmEntStat.entOwn].mmCmdPrm.NRGsrvMode ) + { + case( NRG_SVMD_Full ): + + switch( cmhPrm[mmEntStat.entOwn].mmCmdPrm.NRGregMode ) + { + case( NRG_RGMD_Auto ): + case( NRG_RGMD_Manual ): + + mmEntStat.curCmd = AT_CMD_NONE; + + cmhMM_Ntfy_NtwRegistrationStatus(CREG_STAT_Denied); + +#if defined (GPRS) AND defined (DTI) + psaG_MM_CMD_SET_REGMD ( mmShrdPrm.regMode ); /* restore former registration mode*/ +#else + /* restore former registration mode */ + psaMM_SetRegMode ( mmShrdPrm.regMode ); +#endif + + R_AT( RAT_CME, mmEntStat.entOwn ) + ( AT_CMD_NRG, cmhMM_GetNregCMEStat()); + + /* log result */ + cmh_logRslt ( mmEntStat.entOwn, RAT_CME, AT_CMD_NRG, -1, + BS_SPEED_NotPresent ,cmhMM_GetNregCMEStat() ); + break; + + case( NRG_RGMD_Both ): + + /* Implements Measure 87 */ + cmhMM_Registration_AutoMode( AT_CMD_NRG ); + + break; + } + break; + + case( NRG_SVMD_Limited ): + + /* pending registration request */ + if( regReqPnd EQ TRUE ) + { + mmShrdPrm.regMode = MODE_AUTO; + +#if defined (GPRS) AND defined (DTI) + (void)psaG_MM_CMD_REG (); /* register to network */ +#else + (void)psaMM_Registrate (); /* register to network */ +#endif + + regReqPnd = FALSE; + break; + } + + if( mmShrdPrm.regStat EQ RS_LMTD_SRV ) + { + mmEntStat.curCmd = AT_CMD_NONE; + + cmhMM_Ntfy_NtwRegistrationStatus(cmhMM_GetNregCREGStat()); + + R_AT( RAT_OK, mmEntStat.entOwn ) + ( AT_CMD_NRG ); + + /* log result */ + cmh_logRslt ( mmEntStat.entOwn, RAT_OK, AT_CMD_NRG, -1, + BS_SPEED_NotPresent, CME_ERR_NotPresent ); + } + else + { + mmEntStat.curCmd = AT_CMD_NONE; + + cmhMM_Ntfy_NtwRegistrationStatus(CREG_STAT_Denied); + +#if defined (GPRS) AND defined (DTI) + psaG_MM_CMD_SET_REGMD ( mmShrdPrm.regMode ); /* restore former registration mode*/ +#else + /* restore former registration mode */ + psaMM_SetRegMode ( mmShrdPrm.regMode ); +#endif + + R_AT( RAT_CME, mmEntStat.entOwn ) + ( AT_CMD_NRG, cmhMM_GetNregCMEStat() ); + + /* log result */ + cmh_logRslt ( mmEntStat.entOwn, RAT_CME, AT_CMD_NRG, -1, + BS_SPEED_NotPresent ,cmhMM_GetNregCMEStat() ); + } + break; + + case( NRG_SVMD_NoSrv ): + + mmEntStat.curCmd = AT_CMD_NONE; + + cmhMM_Ntfy_NtwRegistrationStatus(CREG_STAT_NoSearch); + + R_AT( RAT_OK, mmEntStat.entOwn ) + ( AT_CMD_NRG ); + + /* log result */ + cmh_logRslt ( mmEntStat.entOwn, RAT_OK, AT_CMD_NRG, -1, + BS_SPEED_NotPresent,CME_ERR_NotPresent ); + break; + + case( NRG_SVMD_SetRegModeOnly ): + + cmhMM_Ntfy_NtwRegistrationStatus(cmhMM_GetNregCREGStat()); + break; + + } + break; + } + + return 0; +} + +/* ++-------------------------------------------------------------------+ +| PROJECT : GSM-PS (6147) MODULE : CMH_MMR | +| ROUTINE : cmhMM_NetworkLst | ++-------------------------------------------------------------------+ + + PURPOSE : List of networks available + +*/ + +GLOBAL SHORT cmhMM_NetworkLst ( void ) +{ + /* + * We need a structure which has to fit into one not too big partition. + * sizeof (T_OP_NAME) = 36 (35 characters plus one alignment byte) + * with MAX_LONG_OPER_LEN = 26 and MAX_SHRT_OPER_LEN = 9 + * => sizeof (T_OP_NAME) * MAX_OPER = 432 + * => This fits into one of the 432er partitions of which we have some. + */ + typedef struct + { + char longNamBuf[MAX_LONG_OPER_LEN]; /* buffer long name */ + char shrtNamBuf[MAX_SHRT_OPER_LEN]; /* buffer short name*/ + } T_OP_NAME; + + T_OP_NAME * op_name = NULL; /* Holds operator names */ + T_OPER_ENTRY plmnDesc; /* PLMN description */ + T_ACI_COPS_OPDESC * operLst = NULL; /* operator list T_ACI_COPS_LST */ + SHORT lstIdx; /* holds list idx */ + SHORT mcc, mnc; /* holds converted mnc and mcc */ + BOOL found; /* Result of cmhMM_FindXXX() */ + T_ACI_AT_CMD bufCmd; + + TRACE_FUNCTION ("cmhMM_NetworkLst()"); + +/* + *------------------------------------------------------------------- + * check for command context + *------------------------------------------------------------------- + */ + switch( mmEntStat.curCmd ) + { + case( AT_CMD_COPS ): + case (AT_CMD_P_COPS): + + ACI_MALLOC (op_name, sizeof (T_OP_NAME) * MAX_OPER); + ACI_MALLOC (operLst, sizeof (T_ACI_COPS_OPDESC) * MAX_OPER); + + /* + *--------------------------------------------------------------- + * for every entry of the PLMN list + *--------------------------------------------------------------- + */ + for( lstIdx = 0; lstIdx < MAX_OPER AND lstIdx < MAX_PLMN_ID; lstIdx++ ) + { + /* + *------------------------------------------------------------- + * if last entry of PLMN list, close oper list and return + *------------------------------------------------------------- + */ + if( mmShrdPrm.PLMNLst[lstIdx].v_plmn EQ INVLD_PLMN ) + { + operLst[lstIdx].status = COPS_STAT_NotPresent; + operLst[lstIdx].longOper = NULL; + operLst[lstIdx].shortOper = NULL; + operLst[lstIdx].numOper[0]= '\0'; + break; + } + + /* + *------------------------------------------------------------- + * find PLMN description + *------------------------------------------------------------- + */ + cmhMM_CnvrtPLMN2INT( mmShrdPrm.PLMNLst[lstIdx].mcc, + mmShrdPrm.PLMNLst[lstIdx].mnc, + &mcc, &mnc ); + + found = cmhMM_FindPLMN (&plmnDesc, mcc, mnc, mmShrdPrm.LACLst[lstIdx], TRUE); + + if (!found) /* no description found */ + { + operLst[lstIdx].longOper = ""; + operLst[lstIdx].shortOper = ""; + } + else + { + /* Copy strings into dynamic buffer so that they don't get lost */ + memcpy (op_name[lstIdx].longNamBuf, plmnDesc.longName, MAX_LONG_OPER_LEN); + memcpy (op_name[lstIdx].shrtNamBuf, plmnDesc.shrtName, MAX_SHRT_OPER_LEN); + + /* EONS PLMN name conding scheme and source flag */ + operLst[lstIdx].pnn = plmnDesc.pnn; + operLst[lstIdx].longOper = op_name[lstIdx].longNamBuf; + operLst[lstIdx].long_len = plmnDesc.long_len; + operLst[lstIdx].long_ext_dcs = plmnDesc.long_ext_dcs; + operLst[lstIdx].shortOper = op_name[lstIdx].shrtNamBuf; + operLst[lstIdx].shrt_len = plmnDesc.shrt_len; + operLst[lstIdx].shrt_ext_dcs = plmnDesc.shrt_ext_dcs; + } + + /* + *------------------------------------------------------------- + * build numeric representation + *------------------------------------------------------------- + */ + /* Implements Measure#32: Row 987 & 986 */ + cmhMM_mcc_mnc_print(&(operLst[lstIdx].numOper[0]), mcc, mnc); + + /* + *------------------------------------------------------------- + * set PLMN status + *------------------------------------------------------------- + */ + if (mmShrdPrm.PLMNLst[lstIdx].v_plmn EQ mmShrdPrm.usedPLMN.v_plmn AND + memcmp (mmShrdPrm.PLMNLst[lstIdx].mcc, + mmShrdPrm.usedPLMN.mcc, + SIZE_MCC) EQ 0 AND + memcmp (mmShrdPrm.PLMNLst[lstIdx].mnc, + mmShrdPrm.usedPLMN.mnc, SIZE_MNC) EQ 0) + { + operLst[lstIdx].status = COPS_STAT_Current; + } + else + { + switch( mmShrdPrm.FRBLst[lstIdx] ) + { + case( FORB_PLMN_NOT_INCLUDED ): + operLst[lstIdx].status = COPS_STAT_Available; + break; + case( 1 /*FORB_PLMN_INCLUDED*/ ): + operLst[lstIdx].status = COPS_STAT_Forbidden; + break; + default: + operLst[lstIdx].status = COPS_STAT_Unknown; + break; + } + } + } + +#if defined (GPRS) AND defined (DTI) + psaG_MM_CMD_SET_REGMD ( mmShrdPrm.regMode ); /* restore former registration mode*/ +#else + /* restore former registration mode */ + psaMM_SetRegMode ( mmShrdPrm.regMode ); +#endif + bufCmd = mmEntStat.curCmd; + mmEntStat.curCmd = AT_CMD_NONE; + if(bufCmd EQ AT_CMD_COPS) + { + R_AT( RAT_COPS, mmEntStat.entOwn ) + ( --lstIdx, &operLst[0]); + } + else + { + R_AT( RAT_P_COPS, mmEntStat.entOwn ) + ( --lstIdx, &operLst[0]); + } + R_AT( RAT_OK, mmEntStat.entOwn ) + ( mmEntStat.curCmd ); + + /* log result */ + cmh_logRslt ( mmEntStat.entOwn, RAT_OK, mmEntStat.curCmd , -1, + BS_SPEED_NotPresent,CME_ERR_NotPresent ); + + ACI_MFREE (op_name); + ACI_MFREE (operLst); + + break; + } + + return 0; +} + +/* ++-------------------------------------------------------------------+ +| PROJECT : GSM-PS (6147) MODULE : CMH_MMR | +| ROUTINE : cmhMM_SelNetwork | ++-------------------------------------------------------------------+ + + PURPOSE : Select a network, cause for failure from MM is passed as parameter + to report appropriate error. +*/ + +GLOBAL SHORT cmhMM_SelNetwork ( USHORT cause ) +{ + TRACE_FUNCTION ("cmhMM_SelNetwork()"); + + switch( mmEntStat.curCmd ) + { + case( AT_CMD_COPS ): + +#if defined (GPRS) AND defined (DTI) + psaG_MM_CMD_SET_REGMD ( mmShrdPrm.regMode ); /* restore former registration mode*/ +#else + /* restore former registration mode */ + psaMM_SetRegMode ( mmShrdPrm.regMode ); +#endif + + switch(cause) + { + case MMCS_SIM_REMOVED: + /* If the SIM is not inserted or if the SIM requires a PIN, more meaningful error + * codes are returned*/ + if ( (cmhSIM_GetSIMError(mmEntStat.entOwn, mmEntStat.curCmd)) NEQ AT_CMPL) + { + R_AT( RAT_CME, mmEntStat.entOwn ) ( mmEntStat.curCmd , CME_ERR_NotPresent); + } + break; + + case MMCS_PLMN_NOT_IDLE_MODE: + R_AT( RAT_CME, mmEntStat.entOwn ) ( mmEntStat.curCmd , CME_ERR_AbortedByNetwork ); + break; + + default: + R_AT( RAT_CME, mmEntStat.entOwn ) ( mmEntStat.curCmd , CME_ERR_NotPresent); + break; + } + + /* log result */ + cmh_logRslt ( mmEntStat.entOwn, RAT_CME, mmEntStat.curCmd , -1, + BS_SPEED_NotPresent, CME_ERR_NotPresent ); + + mmEntStat.curCmd = AT_CMD_NONE; + + break; + } + + return 0; +} + + +/* ++-------------------------------------------------------------------+ +| PROJECT : GSM-PS (6147) MODULE : CMH_MMR | +| ROUTINE : cmhMM_CipheringInd | ++-------------------------------------------------------------------+ + + PURPOSE : ciphering indication received + +*/ + +GLOBAL SHORT cmhMM_CipheringInd ( UBYTE ciph ) +{ + SHORT idx; /* holds index counter */ + + TRACE_FUNCTION ("cmhMM_CipheringInd()"); + + if (simShrdPrm.ciSIMEnabled NEQ TRUE) + { + return 1; + } + + for (idx = 0; idx < CMD_SRC_MAX; idx++) + { + /* + *----------------------------------------------------------------- + * new message indication + *----------------------------------------------------------------- + */ +#ifndef GPRS + #define CIPH_NA 2 +#endif + R_AT(RAT_P_CPRI,(T_ACI_CMD_SRC)idx) ( ciph, CIPH_NA ); + } + return 0; +} + +/* Implements Measure 87 */ +/* ++------------------------------------------------------------------------------ +| Function : cmhMM_Registration_AutoMode ++------------------------------------------------------------------------------ +| Purpose : This Function will try to register into network in +| automatic mode. +| +| Parameters : void +| +| Return : void ++------------------------------------------------------------------------------ +*/ + +LOCAL void cmhMM_Registration_AutoMode( T_ACI_AT_CMD at_cmd_id ) +{ + TRACE_FUNCTION ("cmhMM_Registration_AutoMode()"); + + if ( mmShrdPrm.regModeAutoBack ) + { + /* + * Tried register to network in manual mode. Attempt failed. + * Now trying to register into network in automatic mode. + */ + + mmShrdPrm.regModeBeforeAbort = mmShrdPrm.regMode; + mmShrdPrm.regMode = MODE_AUTO; + mmShrdPrm.regModeAutoBack = FALSE; + +#if defined (GPRS) AND defined (DTI) + if( psaG_MM_CMD_REG ( ) EQ 0 ) +#else + if( psaMM_Registrate () EQ 0 ) +#endif + { + return; + } + + } + else + { + + cmhMM_Ntfy_NtwRegistrationStatus(CREG_STAT_Denied); + + /* If fallback to automatic mode is allowed, fall back */ + if ( at_cmd_id EQ AT_CMD_NRG ) + { + if (mmShrdPrm.regModeAutoBack) + { + mmShrdPrm.regModeBeforeAbort = mmShrdPrm.regMode; + mmShrdPrm.regModeAutoBack = FALSE; + mmShrdPrm.regMode = MODE_AUTO; + } + } + +#if defined (GPRS) AND defined (DTI) + /* restore former registration mode*/ + psaG_MM_CMD_SET_REGMD ( mmShrdPrm.regMode ); +#else + /* restore former registration mode or set new one */ + psaMM_SetRegMode ( mmShrdPrm.regMode ); +#endif + } + + mmEntStat.curCmd = AT_CMD_NONE; + + R_AT( RAT_CME, mmEntStat.entOwn ) + ( at_cmd_id, cmhMM_GetNregCMEStat()); + + /* log result */ + cmh_logRslt ( mmEntStat.entOwn, RAT_CME, mmEntStat.curCmd, -1, + BS_SPEED_NotPresent,cmhMM_GetNregCMEStat() ); + +} + + +/*==== EOF ========================================================*/ +