FreeCalypso > hg > fc-tourmaline
diff src/g23m-aci/aci/ati_err.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/ati_err.c Fri Oct 16 06:25:50 2020 +0000 @@ -0,0 +1,928 @@ +/* ++----------------------------------------------------------------------------- +| Project : GSM-F&D (8411) +| Modul : ATI ++----------------------------------------------------------------------------- +| 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 : AT Command Interpreter: Error handling. ++----------------------------------------------------------------------------- +*/ + +/*********************************/ +/* General Error Handling in ACI */ +/*********************************/ + +#ifndef ATI_ERR_C +#define ATI_ERR_C + +#undef DUMMY_ATI_STRINGS + +#include "aci_all.h" + +#include "aci_cmh.h" +#include "ati_cmd.h" +#include "aci_io.h" +#include "aci_cmd.h" +#include "l4_tim.h" + +#include "aci.h" +#include "aci_mem.h" + +#include "aci_lst.h" +#include "ati_int.h" + +#ifdef FF_ATI_BAT + +#include "typedefs.h" +#include "gdd.h" +#include "bat.h" + +#include "ati_bat.h" + +#endif /*FF_ATI_BAT*/ + +LOCAL CHAR *AT_Fail_Error(void); + +EXTERN T_ACI_ERR_DESC aciErrDesc; + +LOCAL CHAR ErrBuff[MAX_CMD_LEN]; + +typedef struct +{ + CHAR *msg; + CHAR *nmb; + AtErrCode code; +} AtErrTable; + +LOCAL const AtErrTable tabAtError[]= +{ + "OK", "0", atOk, + "CONNECT", "1", atConnect, + "RING", "2", atRing, + "NO CARRIER", "3", atNoCarrier, + "NO DIALTONE", "6", atNoDialtone, + "BUSY", "7", atBusy, + "NO ANSWER", "8", atNoAnswer, + "CONNECT 9600","15", atConnect1, + /* this has to be the last entry */ + "ERROR", "4", atError +}; + +GLOBAL CHAR *disable_or_numeric(const CHAR* key,LONG e) /* e is actually enum...*/ +{ + UBYTE srcId = srcId_cb; + + if(ati_user_output_cfg[srcId].CMEE_stat EQ CMEE_MOD_Disable) + { + cmdAtError(atError); + } + else if(ati_user_output_cfg[srcId].CMEE_stat EQ CMEE_MOD_Numeric) + { + sprintf(cmdErrStr,"%s ERROR: %d",key,e); + } + return cmdErrStr; +} + + +/* ++--------------------------------------------------------------------+ +| PROJECT : GSM-F&D (8411) MODULE : ACI_CMD | +| STATE : code ROUTINE : cmdExtError | ++--------------------------------------------------------------------+ + + PURPOSE : handle extended errors + +*/ + +LOCAL const struct T_ATI_EXT_ERR /* error code - error message mapping */ +{ + const CHAR* msg; /* error message */ + const T_ACI_EXT_ERR code; /* error code */ + const ULONG displ_code; /* error code to be display */ +} + +err[] = +{ +"parameter not allowed", EXT_ERR_Parameter, EXT_ERR_Parameter, +"data corrupted", EXT_ERR_DataCorrupt, EXT_ERR_DataCorrupt, +"internal error", EXT_ERR_Internal, EXT_ERR_Internal, +"call table full", EXT_ERR_CallTabFull, EXT_ERR_CallTabFull, +"service table full", EXT_ERR_SrvTabFull, EXT_ERR_SrvTabFull, +"call not found", EXT_ERR_CallNotFound, EXT_ERR_CallNotFound, +"no data-call supported", EXT_ERR_NoDataCallSup, EXT_ERR_NoDataCallSup, +"one call on hold", EXT_ERR_OneCallOnHold, EXT_ERR_OneCallOnHold, +"hold call not supported for this type", EXT_ERR_CallTypeNoHold, EXT_ERR_CallTypeNoHold, +"number not allowed by FDN", EXT_ERR_FdnCheck, EXT_ERR_FdnCheck, +"number not allowed by BDN", EXT_ERR_BdnCheck, EXT_ERR_BdnCheck, +"parallel USSD not supported", EXT_ERR_ParallelUSSD, EXT_ERR_ParallelUSSD, +"fax minimum speed condition", EXT_ERR_FaxMinSpeedCond, EXT_ERR_FaxMinSpeedCond, +"conflict with command details", EXT_ERR_CmdDetailsSAT, EXT_ERR_CmdDetailsSAT, +"IMEI illegal", EXT_ERR_IMEICheck, EXT_ERR_IMEICheck, +"not allowed by ALS-Lock", EXT_ERR_AlsLock, EXT_ERR_AlsLock, +#ifdef REL99 +"Last failed message not present", EXT_ERR_FailedMsgNotPresent,EXT_ERR_FailedMsgNotPresent, +#endif +#if defined FF_EOTD +"Command not supported", EXT_ERR_LCS_CmdNotSup, 0, +"Command not recognised/out of range", EXT_ERR_LCS_CmdNotRec, 1, +"LCS Client ID not recognised/out of range", EXT_ERR_LCS_CLPSClientNotRec, 2, +"Interval attribute out of range", EXT_ERR_LCS_IntervalNotSup, 3, +"Repeat attribute not supported/ out of range", EXT_ERR_LCS_RepeatNotSup, 4, +"Send request type not recognised / out of range", EXT_ERR_LCS_SendReqTyNotRec, 2, +"User confirmation request type not recognised / out of range", EXT_ERR_LCS_UsConfReqTyNotRec, 3, +"LCS Client ID not recognised/out of range", EXT_ERR_LCS_CLSRClientIdNotRec, 4, +"Circuit switched call number out of range", EXT_ERR_LCS_CSCallNumNotSup, 5, +#endif /* FF_EOTD */ + +#ifdef SIM_PERS +"BlockedNetwork lock - PIN required", EXT_ERR_BlockedNetworkPersPinReq, EXT_ERR_BlockedNetworkPersPinReq, +"BlockedNetwork lock - PUK required", EXT_ERR_BlockedNetworkPersPukReq, EXT_ERR_BlockedNetworkPersPukReq, +"Busy Error", EXT_ERR_Busy, EXT_ERR_Busy, /* Penalty timer is running */ +"MEPD not present", EXT_ERR_NoMEPD, EXT_ERR_NoMEPD, /* Penalty timer is running */ +#endif + +"error unknown", EXT_ERR_Unknown, EXT_ERR_Unknown, +/* this has to be the last entry */ +"other error", EXT_ERR_NotPresent, 0xFFFFFFFF +}; + +GLOBAL CHAR *cmdExtError (T_ACI_EXT_ERR e) +{ + SHORT idx=0; + T_ACI_ERR_DESC aed; + UBYTE srcId = srcId_cb; + + if ( e EQ EXT_ERR_NotPresent ) + { + if (((aed = qAT_ErrDesc()) >> 16) EQ ACI_ERR_CLASS_Ext) + { + e = (T_ACI_EXT_ERR)(aed & 0xFFFF); + } + else + { + e = EXT_ERR_Unknown; + } + } + *ErrBuff = '\0'; + cmdErrStr = ErrBuff; + + if (ati_user_output_cfg[srcId].CMEE_stat EQ CMEE_MOD_Verbose OR + ati_user_output_cfg[srcId].CMEE_stat EQ CMEE_MOD_Numeric) + { + /* search the array for the index of the notified failure */ + while ( err[idx].code NEQ EXT_ERR_NotPresent AND + err[idx].code NEQ e ) + { + idx++; + } + } + else /* Catch some Extended Error Codes and map them to more suitable codes */ + { + switch (e) + { + case EXT_ERR_CallTabFull: + case EXT_ERR_FdnCheck: + case EXT_ERR_BdnCheck: + return(cmdAtError(atNoCarrier)); + } + } + if (ati_user_output_cfg[srcId].CMEE_stat EQ CMEE_MOD_Verbose) + { + strcat(cmdErrStr,"+EXT ERROR: "); + strcat( cmdErrStr, err[idx].msg ); + } + return(disable_or_numeric("+EXT", err[idx].displ_code)); +} + +/* ++--------------------------------------------------------------------+ +| PROJECT : GSM-F&D (8411) MODULE : ACI_CMD | +| STATE : code ROUTINE : cmdCmeError | ++--------------------------------------------------------------------+ + + PURPOSE : handle Mobile Equipment Errors + +*/ +#ifdef GPRS +#define GPRS_ERR(a,b) a,b, +#else +#define GPRS_ERR(a,b) +#endif /* GPRS */ + +LOCAL const struct T_ATI_CME_ERR /* error code - error message mapping */ +{ + const CHAR* msg; /* error message */ + const T_ACI_CME_ERR code; /* error code */ +} + error[] = +{ +"phone failure", CME_ERR_PhoneFail, +"no connection to phone", CME_ERR_NoConnect, +"phone-adaptor link reserved", CME_ERR_LinkRes, +"operation not allowed", CME_ERR_OpNotAllow, +"operation not supported", CME_ERR_OpNotSupp, +"PH-SIM PIN required", CME_ERR_PhSimPinReq, +"SIM not inserted", CME_ERR_SimNotIns, +"SIM PIN required", CME_ERR_SimPinReq, +"SIM PUK required", CME_ERR_SimPukReq, +"SIM failure", CME_ERR_SimFail, +"SIM busy", CME_ERR_SimBusy, +"SIM wrong", CME_ERR_SimWrong, +"incorrect password", CME_ERR_WrongPasswd, +"SIM PIN2 required", CME_ERR_SimPin2Req, +"SIM PUK2 required", CME_ERR_SimPuk2Req, +"memory full", CME_ERR_MemFull, +"invalid index", CME_ERR_InvIdx, +"not found", CME_ERR_NotFound, +"memory failure", CME_ERR_MemFail, +"text string too long", CME_ERR_TxtToLong, +"invalid characters in text string", CME_ERR_InvalidTxtChar, +"dial string too long", CME_ERR_DialToLong, +"invalid characters in dial string", CME_ERR_InvDialChar, +"no network service", CME_ERR_NoServ, +"network timeout", CME_ERR_Timeout, +"network not allowed - emergency calls only", CME_ERR_LimServ, +"Network lock - PIN required", CME_ERR_NetworkPersPinReq, /* PIN to change network personalisation required */ +"Network lock - PUK required", CME_ERR_NetworkPersPukReq, /* network personalisation PUK is required */ +"Subnetwork lock - PIN required", CME_ERR_NetworkSubsetPersPinReq, /* keycode to change nw subset personalisation required */ +"Subnetwork lock - PUK required", CME_ERR_NetworkSubsetPersPukReq, /* network subset personalisation PUK is required */ +"Provider lock - PIN required", CME_ERR_ProviderPersPinReq, /* keycode to change service provider personal. required */ +"Provider lock - PUK required", CME_ERR_ProviderPersPukReq, /* service provider personalisation PUK is required */ +"Corporate lock - PIN required", CME_ERR_CorporatePersPinReq, /* keycode to change corporate personalisation required */ +"Corporate lock - PUK required", CME_ERR_CorporatePersPukReq, /* corporate personalisation PUK is required */ +"unknown", CME_ERR_Unknown, /* ATTENTION! If you insert new entries before CME_ERR_Unknown, remember to increase NBR_CME_NORM_ERR */ +GPRS_ERR("illegal MS", CME_ERR_GPRSBadMs) +GPRS_ERR("illegal ME", CME_ERR_GPRSBadMe) +GPRS_ERR("GPRS service not allowed", CME_ERR_GPRSNoService) +GPRS_ERR("PLMN not allowed", CME_ERR_GPRSBadPlmn) +GPRS_ERR("Location not allowed", CME_ERR_GPRSBadLoc) +GPRS_ERR("Roaming not allowed in Location Area", CME_ERR_GPRSNoRoam) +GPRS_ERR("GPRS service option not supported", CME_ERR_GPRSSerOptNsup) +GPRS_ERR("requested service option not subscribed",CME_ERR_GPRSSerOptNsub) +GPRS_ERR("service option temporarily out of order",CME_ERR_GPRSSerOptOOO) +GPRS_ERR("unspecified GPRS error", CME_ERR_GPRSUnspec) +GPRS_ERR("PDP authorisation error", CME_ERR_GPRSPdpAuth) +GPRS_ERR("invalid module class", CME_ERR_GPRSBadModClass) +"failed to abort", CME_ERR_FailedToAbort, +"ACM reset needed", CME_ERR_AcmResetNeeded, +"sim extension memory full", CME_ERR_SimNoExtAvail, +"sim reset needed", CME_ERR_SimResetNeeded, +"Aborted by Network", CME_ERR_AbortedByNetwork, +/* this has to be the last entry */ +"other error", CME_ERR_NotPresent +}; + +GLOBAL CHAR *cmdCmeError (T_ACI_CME_ERR e) +{ + SHORT idx=0; + T_ACI_ERR_DESC aed; + UBYTE srcId = srcId_cb; + + *ErrBuff = '\0'; /* initialization */ + cmdErrStr = ErrBuff; + + if ( e EQ CME_ERR_NotPresent ) + { + if (((aed = qAT_ErrDesc()) >> 16) EQ ACI_ERR_CLASS_Cme) + { + e = (T_ACI_CME_ERR)(aed & 0xFFFF); + } + else + { + e = CME_ERR_Unknown; + } + } + else if( e EQ CME_ERR_Unknown ) + { + return(AT_Fail_Error()); + } + + if (ati_user_output_cfg[srcId].CMEE_stat EQ CMEE_MOD_Verbose) + { + strcat(cmdErrStr,"+CME ERROR: "); + + /* search for the description of the notified error */ + while ( error[idx].code NEQ CME_ERR_NotPresent AND + error[idx].code NEQ e ) + { + idx++; + } + strcat( cmdErrStr, error[idx].msg ); + } + return(disable_or_numeric("+CME",e)); +} + + +/* ++--------------------------------------------------------------------+ +| PROJECT : GSM-F&D (8411) MODULE : ACI_CMD | +| STATE : code ROUTINE : cmdCmsError | ++--------------------------------------------------------------------+ + + PURPOSE : handle Short Message Errors + +*/ + +LOCAL const struct T_ATI_CMS_ERR /* error code - error message mapping */ +{ + const CHAR* msg; /* error message */ + const T_ACI_CMS_ERR code; /* error code */ +} + cms_err[] = +{ + "unassigned (unallocated) number", CMS_ERR_UnAllocNum, + "operator determined barring", CMS_ERR_OpDetermBarr, + "call barred", CMS_ERR_CallBarr, + "short message transfer rejected", CMS_ERR_TransReject, + "destination out of service", CMS_ERR_DestOutOfServ, + "unidentified subscriber", CMS_ERR_UnidentSubsc, + "facility rejected", CMS_ERR_FacReject, + "unknown subscriber", CMS_ERR_UnKnownSubsc, + "network out of order", CMS_ERR_NetOutOfOrder, + "temporary failure", CMS_ERR_TempFail, + "congestion", CMS_ERR_Congestion, + "resources unavailable, unspecified", CMS_ERR_ResUnAvail, + "requested facility not subscribed", CMS_ERR_FacNotSubscr, + "requested facility not implemented", CMS_ERR_FacNotImpl, + "invalid short message transfer ref. value", CMS_ERR_TransRefInval, + "semantically incorrect message", CMS_ERR_InValSM, + "invalid mandatory information", CMS_ERR_InValManInfo, + "message type non-existent or not implemented", CMS_ERR_MsgTypNotExist, + "message not compatible with SM protocol state", CMS_ERR_MsgNotCompatible, + "information element non-existent or not impl.", CMS_ERR_InfoElemNotImpl, + "protocol error, unspecified", CMS_ERR_ProtErr, + "interworking, unspecified", CMS_ERR_InterWrkUnSpec, + "telematic interworking not supported", CMS_ERR_TlmtkNotSup, + "short message type 0 not supported", CMS_ERR_SM0NotSup, + "cannot replace short message", CMS_ERR_CantReplceSM, + "unspecified TP-PID error", CMS_ERR_UnSpecPIDErr, + "data coding scheme (alphabet) not supported", CMS_ERR_DcsNotSup, + "message class not supported", CMS_ERR_MsgClassNotSup, + "unspecified TP-DCS error", CMS_ERR_UnSpecTpDcs, + "command cannot be actioned", CMS_ERR_CmdNotAct, + "command unsupported", CMS_ERR_CmdUnSup, + "unspecified TP-Command error", CMS_ERR_UnSpecTpCmd, + "TPDU not supported", CMS_ERR_TpduUnSup, + "SC busy", CMS_ERR_ScBsy, + "no SC subscription", CMS_ERR_NoScSubsc, + "SC system failure", CMS_ERR_ScSysFail, + "invalid SME address", CMS_ERR_InValSme, + "destination SME barred", CMS_ERR_DestSmeBarr, + "SM rejected-duplicate SM", CMS_ERR_SmRejctDuplSm, + "TP-VPF not supported", CMS_ERR_SmTPVPFNotSup, + "TP-VP not supported", CMS_ERR_SmTPVPNotSup, + "SIM SMS storage full", CMS_ERR_SimSmsStorFull, + "no SMS storage capability in SIM", CMS_ERR_NoStorInSim, + "error in MS", CMS_ERR_ErrInMs, + "memory capacity exceeded", CMS_ERR_MemCabExcee, + "unspecified error cause", CMS_ERR_UnSpecErr, + "ME failure", CMS_ERR_MeFail, + "SMS service of ME reserved", CMS_ERR_ServRes, + "operation not allowed", CMS_ERR_OpNotAllowed, + "operation not supported", CMS_ERR_OpNotSup, + "invalid PDU mode parameter", CMS_ERR_InValPduMod, + "invalid text mode parameter", CMS_ERR_InValTxtMod, + "SIM not inserted", CMS_ERR_SimNotIns, + "SIM PIN required", CMS_ERR_SimPinReq, + "PH-SIM PIN required", CMS_ERR_PhSimPinReq, + "SIM failure", CMS_ERR_SimFail, + "SIM busy", CMS_ERR_SimBsy, + "SIM wrong", CMS_ERR_SimWrong, + "SIM PUK required", CMS_ERR_SimPukReq, + "SIM PIN2 required", CMS_ERR_SimPin2Req, + "SIM PUK2 required", CMS_ERR_SimPuk2Req, + "memory failure", CMS_ERR_MemFail, + "invalid memory index", CMS_ERR_InValMemIdx, + "memory full", CMS_ERR_MemFull, + "SMSC address unknown", CMS_ERR_SmscAdrUnKnown, + "no network service", CMS_ERR_NoNetServ, + "network timeout", CMS_ERR_NetTimeOut, + "no +CNMA acknowledegment expected", CMS_ERR_NoCnmaAckExpect, + "unknown error", CMS_ERR_UnknownErr, + "failed to abort", CMS_ERR_FailedToAbort, + /* this must be the last entry */ + "other error", CMS_ERR_NotPresent +}; + +#define NBR_CMS_ERR 69 +#define MAX_CMS_LTH 60 + +GLOBAL char* cmdCmsError ( T_ACI_CMS_ERR e ) +{ + int i = 0; + T_ACI_ERR_DESC aed; + UBYTE srcId = srcId_cb; + + if ( e EQ CMS_ERR_NotPresent ) + { + if (((aed = qAT_ErrDesc()) >> 16) EQ ACI_ERR_CLASS_Cms) + { + e = (T_ACI_CMS_ERR)(aed & 0xFFFF); + } + else /* no SMS error code */ + { + e = CMS_ERR_UnknownErr; + } + } + + { + *ErrBuff = '\0'; /* build message */ + cmdErrStr = ErrBuff; + + if ( ati_user_output_cfg[srcId].CMEE_stat EQ CMEE_MOD_Verbose ) + { + strcat( cmdErrStr, "+CMS ERROR: " ); + + while ( cms_err[i].code NEQ CMS_ERR_NotPresent AND + cms_err[i].code NEQ e ) + { + i++; + } + strcat( cmdErrStr, cms_err[i].msg ); + } + else if ( ati_user_output_cfg[srcId].CMEE_stat EQ CMEE_MOD_Disable ) + { + strcat ( cmdErrStr, "ERROR" ); + } + else if ( ati_user_output_cfg[srcId].CMEE_stat EQ CMEE_MOD_Numeric ) + { + sprintf ( cmdErrStr, "+CMS ERROR: %d", e ); + } + } + return cmdErrStr; +} + + +/* ++--------------------------------------------------------------------+ +| PROJECT : GSM-F&D (8411) MODULE : ACI_CMD | +| STATE : code ROUTINE : atPlusCEER | ++--------------------------------------------------------------------+ + + PURPOSE : Extented error report +*/ + +typedef struct + { + char * desc; + T_ACI_CEER rpt; + } CEER_TABLE; + +/* Defined by standards CEER cause description table */ +const CEER_TABLE StdCEERDesc[]= +{ + {"unassigned number", CEER_Unassign }, + {"no route to destination", CEER_NoRoute }, + {"channel unacceptable", CEER_ChanUnaccept }, + {"operator determined barring", CEER_Barred }, + {"normal call clearing", CEER_CallClear }, + {"user busy", CEER_UserBusy }, + {"no user responding", CEER_NoResponse }, + {"user alerting, no answer", CEER_AlertNoAnswer }, + {"call rejected", CEER_CallReject }, + {"number changed", CEER_NumChanged }, + {"non selected user clearing", CEER_UserClear }, + {"destination out of order", CEER_DestOutOfOrder }, + {"invalid number format", CEER_NumFormat }, + {"facility rejected", CEER_FacilityReject }, + {"response to status enquiry", CEER_StatusEnquiry }, + {"normal, unspecified", CEER_Unspecified }, + {"no channel available", CEER_NoChanAvail }, + {"network out of order", CEER_NetworkOutOfOrder }, + {"temporary failure", CEER_TempFailure }, + {"switching equipment congestion", CEER_SwitchCongest }, + {"access information discarded", CEER_InfoDiscard }, + {"requested channel unavailable", CEER_ReqChanUnavail }, + {"recources unavailable", CEER_ResourceUnavail }, + {"quality of service unavailable", CEER_QOS_Unavail }, + {"requested facility unsubscribed", CEER_FAC_Unsubscr }, + {"incoming calls barred within CUG", CEER_BarredInCUG }, + {"bearer capability not authorized", CEER_BearerCapNotAuth }, + {"bearer capability not available", CEER_BearerCapUnavail }, + {"service not available", CEER_ServUnavail }, + {"bearer service not implemented", CEER_BearerNotImpl }, + {"ACM reached ACM maximum", CEER_ACM_Max }, + {"facility not implemented", CEER_FAC_NotImpl }, + {"only restricted bearer cap. avail.", CEER_RestrictBearerCap }, + {"service not implemented", CEER_ServNotImpl }, + {"invalid TI", CEER_InvalidTI }, + {"no member of CUG", CEER_UserNotInCUG }, + {"incompatible destination", CEER_IncompatDest }, + {"invalid transit network selection", CEER_InvalidTransNet }, + {"incorrect message", CEER_IncorrMsg }, + {"invalid mandatory information", CEER_InvalidMandInfo }, + {"message type not implemented", CEER_MsgTypeNotImpl }, + {"message type incompatible", CEER_MsgTypeIncomp }, + {"info element not implemented", CEER_InfoElemNotImpl }, + {"conditional info element error", CEER_CondInfoElem }, + {"message incompatible", CEER_MsgIncomp }, + {"recovery on time expiry", CEER_Timer }, + {"protocol error", CEER_Protocol }, + {"interworking error", CEER_Interworking }, + {"bearer service not available", CEER_ReqBearerServNotAvail }, + {"no TI available", CEER_NoTransIdAvail }, + {"timer 303 expiry", CEER_Timer303 }, + {"establishment failure", CEER_EstabFail }, + {"no error", CEER_NoError }, + {"operation failed", CEER_Failed }, + {"timeout", CEER_Timeout }, + {"bearer service not compatible", CEER_BearerServNotCompat }, +#ifdef GPRS + {"unsuccessful GPRS attach", CEER_FailedGPRSAttach }, + {"unsuccessful PDP context activation",CEER_FailedGPRSContextAct }, + {"GPRS detach", CEER_GPRSDetach }, + {"GPRS PDP context deactivation", CEER_GPRSDeactivation }, +#endif /* GPRS */ + /* these have to be the last entries */ + {"no error", CEER_NotPresent }, + /* last entry for at+ceer */ + { NULL, CEER_NotPresent} +}; + +/* Proprietary ACI CEER cause description table */ +const CEER_TABLE pACI_CEERDesc[]= +{ + {"ACM reached ACM maximum", (T_ACI_CEER)P_CEER_ACMMaxReachedOrExceeded }, + {"number not in FDN list", (T_ACI_CEER) P_CEER_InvalidFDN }, + /* these have to be the last entries */ + {"no error", CEER_NotPresent }, + /* last entry for at+ceer */ + { NULL, CEER_NotPresent} +}; + +/* Proprietary MM CEER cause description table */ +const CEER_TABLE pMM_CEERDesc[]= +{ + {"IMSI not present in HLR", (T_ACI_CEER)P_MM_CEER_IMSINotInHLR}, + {"no service", (T_ACI_CEER)P_MM_CEER_NoService }, + /* these have to be the last entries */ + {"no error", CEER_NotPresent }, + /* last entry for at+ceer */ + { NULL, CEER_NotPresent} +}; + +/* Proprietary SS CEER cause description table */ +const CEER_TABLE pSS_CEERDesc[]= +{ + {"Unknown Subscriber", (T_ACI_CEER)P_SS_CEER_UnknownSubscriber }, + {"Illegal Subscriber", (T_ACI_CEER)P_SS_CEER_IllegalSubscriber }, + {"Bearer service not provisioned", (T_ACI_CEER)P_SS_CEER_BearerSvcNotProv }, + {"Teleservice not provisioned", (T_ACI_CEER)P_SS_CEER_TeleSvcNotProv }, + {"Illegal Equipment", (T_ACI_CEER)P_SS_CEER_IllegalEquipment }, + {"Call barred", (T_ACI_CEER)P_SS_CEER_CallBarred }, + {"Illegal supplementary service operation", (T_ACI_CEER)P_SS_CEER_IllegalSSOperation }, + {"SS error status", (T_ACI_CEER)P_SS_CEER_SSerrStatus }, + {"SS not available", (T_ACI_CEER)P_SS_CEER_SSNotAvail }, + {"SS subscript violation", (T_ACI_CEER)P_SS_CEER_SSSubsViolation }, + {"SS incompatible", (T_ACI_CEER)P_SS_CEER_SSIncomp }, + {"Facility not supported", (T_ACI_CEER)P_SS_CEER_FacNotSupported }, + {"Absent subscriber", (T_ACI_CEER)P_SS_CEER_AbsentSubs }, + {"System failure", (T_ACI_CEER)P_SS_CEER_SystenFail }, + {"Data Missing", (T_ACI_CEER)P_SS_CEER_DataMissing }, + {"Unexpected Data Value", (T_ACI_CEER)P_SS_CEER_UnexpectData }, + {"Password registration failure", (T_ACI_CEER)P_SS_CEER_PwdRegFail }, + {"Negative password check", (T_ACI_CEER)P_SS_CEER_NegPwdCheck}, + {"Number of password attempts violation", (T_ACI_CEER)P_SS_CEER_NumPwdViolation }, + {"Unknown alphabet", (T_ACI_CEER)P_SS_CEER_UnknownAlpha }, + {"Unstructured supplementary service data busy", (T_ACI_CEER)P_SS_CEER_UssdBusy }, + {"Number of multiparty participants exceeded", (T_ACI_CEER)P_SS_CEER_MaxNumMptyExceed }, + {"Resource not available", (T_ACI_CEER)P_SS_CEER_ResourceNotAvail }, + + /* these have to be the last entries */ + {"no error", CEER_NotPresent }, + /* last entry for at+ceer */ + { NULL, CEER_NotPresent} +}; +#define MAX_CEER_DESC_LTH (50) +#define MAX_CEER_VAL_LTH (11) + +GLOBAL void getCeerDesc(USHORT cause, char *desc) +{ + SHORT idx; + int val; + + TRACE_FUNCTION("getCeerDesc()"); + + memset(desc,0,MAX_CEER_DESC_LTH); + + if ( GET_CAUSE_DEFBY(cause) EQ DEFBY_STD ) + { + TRACE_EVENT_P1("Cause: %d, defined by standard", cause); + val = GET_CAUSE_VALUE(cause); + + if ( val EQ NOT_PRESENT_8BIT ) + { + val = CEER_NotPresent; + } + TRACE_EVENT("Get desc from Standard CEER desc table"); + for( idx = 0; StdCEERDesc[idx].desc NEQ NULL; idx++ ) + { + if ( StdCEERDesc[idx].rpt EQ val ) + { + memcpy(desc, StdCEERDesc[idx].desc, strlen(StdCEERDesc[idx].desc) ); + return; + } + } + } + + if ( GET_CAUSE_DEFBY(cause) EQ DEFBY_CONDAT ) + { + if ( GET_CAUSE_ORIGIN_ENTITY(cause) EQ MNCC_ACI_ORIGINATING_ENTITY ) + { + TRACE_EVENT_P1("Cause: %d, is ACI proprietary", cause); + val = GET_CAUSE_VALUE(cause); + + if ( val EQ NOT_PRESENT_8BIT ) + { + val = P_CEER_NotPresent; + } + TRACE_EVENT("Get desc from proprietary ACI CEER desc table"); + for( idx = 0; pACI_CEERDesc[idx].desc NEQ NULL; idx++ ) + { + if ( pACI_CEERDesc[idx].rpt EQ val ) + { + memcpy(desc, pACI_CEERDesc[idx].desc, strlen(pACI_CEERDesc[idx].desc) ); + return; + } + } + } + else if ( GET_CAUSE_ORIGIN_ENTITY(cause) EQ MM_ORIGINATING_ENTITY ) + { + TRACE_EVENT_P1("Cause: %d, is MM proprietary", cause); + val = GET_CAUSE_VALUE(cause); + + if ( val EQ NOT_PRESENT_8BIT ) + { + val = P_MM_CEER_NotPresent; + } + TRACE_EVENT("Get desc from proprietary MM CEER desc table"); + for( idx = 0; pMM_CEERDesc[idx].desc NEQ NULL; idx++ ) + { + if ( pMM_CEERDesc[idx].rpt EQ val ) + { + memcpy(desc, pMM_CEERDesc[idx].desc, strlen(pMM_CEERDesc[idx].desc) ); + return; + } + } + } + else if ( GET_CAUSE_ORIGIN_ENTITY(cause) EQ SS_ORIGINATING_ENTITY ) + { + TRACE_EVENT_P1("Cause: %d, is SS proprietary", cause); + val = GET_CAUSE_VALUE(cause); + + if ( val EQ NOT_PRESENT_8BIT ) + { + val = P_SS_CEER_NotPresent; + } + TRACE_EVENT("Get desc from proprietary SS CEER desc table"); + for( idx = 0; pSS_CEERDesc[idx].desc NEQ NULL; idx++ ) + { + if ( pSS_CEERDesc[idx].rpt EQ val ) + { + memcpy(desc, pSS_CEERDesc[idx].desc, strlen(pSS_CEERDesc[idx].desc) ); + return; + } + } + } + } +} + + +GLOBAL T_ATI_RSLT atPlusCEER(char *cl, UBYTE srcId) +{ + TRACE_FUNCTION("atPlusCEER()"); + +#ifdef FF_ATI_BAT + { + T_BAT_cmd_send cmd; + T_BAT_no_parameter dummy; + + cmd.ctrl_params=BAT_CMD_SET_PLUS_CEER; + dummy.bat_dummy = 0xFF; + cmd.params.ptr_set_plus_ceer = &dummy; + bat_send(ati_bat_get_client(srcId), &cmd); + return(ATI_EXCT); + } +#else /* no FF_ATI_BAT */ + { + char desc[MAX_CEER_DESC_LTH]; + T_ACI_RETURN ret; + USHORT cause; + + ret=qAT_PlusCEER( (T_ACI_CMD_SRC)srcId, &cause ); + if (ret EQ AT_CMPL) + { + /* check if description text is available*/ + getCeerDesc(cause, desc); + + if ( desc[0] EQ 0 ) + { + /* no description text is available */ + sprintf( g_sa, "+CEER: %d,%d,%d,%d", + GET_CAUSE_DEFBY(cause), GET_CAUSE_ORIGSIDE(cause), + GET_CAUSE_ORIGIN_ENTITY(cause), GET_CAUSE_VALUE(cause)); + } + else + { + /* description text is available */ + sprintf( g_sa, "+CEER: %d,%d,%d,%d,%s", + GET_CAUSE_DEFBY(cause), GET_CAUSE_ORIGSIDE(cause), + GET_CAUSE_ORIGIN_ENTITY(cause), GET_CAUSE_VALUE(cause), + desc ); + } + io_sendMessage(srcId, g_sa, ATI_NORMAL_OUTPUT); + return ATI_CMPL; + } + else + { + cmdAtError(atError); + return ATI_FAIL; + } + } +#endif /* no FF_ATI_BAT */ +} + +/* ++--------------------------------------------------------------------+ +| PROJECT : GSM-F&D (8411) MODULE : ACI_CMD | +| STATE : code ROUTINE : atPercentCSSD | ++--------------------------------------------------------------------+ + + PURPOSE : Supplementary Service Diagnostic +*/ + +GLOBAL T_ATI_RSLT atPercentCSSD(char *cl, UBYTE srcId) +{ + T_ACI_RETURN ret; + UBYTE ss_diag; + CHAR *me = "%CSSD: "; + + TRACE_FUNCTION("atPercentCSSD()"); + + ret = qAT_PercentCSSD( (T_ACI_CMD_SRC)srcId, &ss_diag); + + if (ret EQ AT_CMPL) + { + sprintf( g_sa, "%s%d", me, ss_diag ); + io_sendMessage(srcId, g_sa, ATI_NORMAL_OUTPUT); + return ATI_CMPL; + } + else + { + cmdAtError(atError); + return ATI_FAIL; + } + +} + +/* ++--------------------------------------------------------------------+ +| PROJECT : GSM-F&D (8411) MODULE : ACI_CMD | +| STATE : code ROUTINE : cmdCeerError | ++--------------------------------------------------------------------+ + + PURPOSE : handle CEER Errors + +*/ + +GLOBAL CHAR *cmdCeerError(USHORT cause) +{ + T_ACI_ERR_DESC aed; + char desc[MAX_CEER_DESC_LTH]; + UBYTE srcId = srcId_cb; + + *ErrBuff = '\0'; /* build message */ + cmdErrStr = ErrBuff; + + if ( GET_CAUSE_VALUE(cause) EQ NOT_PRESENT_8BIT ) + { + if (((aed = qAT_ErrDesc()) >> 16) EQ ACI_ERR_CLASS_Ceer) + cause = (T_ACI_CEER)(aed & 0xFFFF); + else + cause = CAUSE_MAKE(DEFBY_STD, ORIGSIDE_MS, MNCC_ACI_ORIGINATING_ENTITY, + CEER_NoError); + } + if (ati_user_output_cfg[srcId].CMEE_stat EQ CMEE_MOD_Verbose) + { + sprintf(cmdErrStr, "+CEER ERROR: %d,%d,%d,%d,", + GET_CAUSE_DEFBY(cause), GET_CAUSE_ORIGSIDE(cause), + GET_CAUSE_ORIGIN_ENTITY(cause), GET_CAUSE_VALUE(cause)); + + getCeerDesc(cause, desc); + + if ( desc[0] NEQ 0 ) + { + strcat( cmdErrStr, desc); + } + + } + return(disable_or_numeric("+CEER",cause)); +} + +/* ++--------------------------------------------------------------------+ +| PROJECT : GSM-F&D (8411) MODULE : ACI_CMD | +| STATE : code ROUTINE : cmdAtError | ++--------------------------------------------------------------------+ + + PURPOSE : handle standard AT Errors + +*/ + +GLOBAL CHAR *cmdAtError (AtErrCode e) +{ + SHORT idx=0; + + *ErrBuff = '\0'; + cmdErrStr = ErrBuff; + + /* search for the description of the notified error */ + while ( tabAtError[idx].code NEQ atError AND + tabAtError[idx].code NEQ e ) + { + idx++; + } + sprintf(cmdErrStr,(at.s1415.atV) ? tabAtError[idx].msg : tabAtError[idx].nmb); + return cmdErrStr; +} + +/* ++--------------------------------------------------------------------+ +| PROJECT : GSM-F&D (8411) MODULE : ACI_CMD | +| STATE : code ROUTINE : AT_FailError | ++--------------------------------------------------------------------+ + + PURPOSE : General handling of errors (either CME CMS CEER or EXT errors) + when function returns AT_FAIL + +*/ +#define ACI_GET_ERR_CLASS() ((aciErrDesc & 0xFFFF0000) >> 16) +#define ACI_GET_ERR_VALUE() (aciErrDesc & 0x0000FFFF) +#define ACI_RESET_ERR_DESC() (aciErrDesc = 0xFFFFFFFF) +#define ACI_VALID_ERR_DESC() (aciErrDesc NEQ 0xFFFFFFFF) + +LOCAL CHAR *AT_Fail_Error(void) +{ + T_ACI_ERR_CLASS err_class; + + if ( ACI_VALID_ERR_DESC() ) + { + err_class = (T_ACI_ERR_CLASS)ACI_GET_ERR_CLASS(); + switch(err_class) + { + case(ACI_ERR_CLASS_NotPresent): + break; + case(ACI_ERR_CLASS_Cme): + { + T_ACI_CME_ERR l_err; + + l_err = (T_ACI_CME_ERR)ACI_GET_ERR_VALUE(); + ACI_RESET_ERR_DESC(); /* needs to be reinitialized */ + return(cmdCmeError (l_err)); + } + case(ACI_ERR_CLASS_Cms): + { + T_ACI_CMS_ERR l_err; + + l_err = (T_ACI_CMS_ERR)ACI_GET_ERR_VALUE(); + ACI_RESET_ERR_DESC(); /* needs to be reinitialized */ + return(cmdCmsError (l_err)); + } + case(ACI_ERR_CLASS_Ceer): + { + T_ACI_CEER l_err; + + l_err = (T_ACI_CEER)ACI_GET_ERR_VALUE(); + ACI_RESET_ERR_DESC(); /* needs to be reinitialized */ + /* return(cmdCeerError((USHORT)err)); */ + return(cmdCeerError(l_err)); + } + case(ACI_ERR_CLASS_Ext): + { + T_ACI_EXT_ERR l_err; + + l_err = (T_ACI_EXT_ERR)ACI_GET_ERR_VALUE(); + ACI_RESET_ERR_DESC(); /* needs to be reinitialized */ + return(cmdExtError (l_err)); + } + default: + break; + } + } + *ErrBuff = '\0'; + cmdErrStr = ErrBuff; + + return (cmdCmeError(CME_ERR_NotPresent)); +} + +#endif /* ATI_ERR_C */