📄 mfw_cb.c
字号:
/*
+------------------------------------------------------------------+
| PROJECT : GSM-MFW (8417) MODULE : MFW_CB |
| STATE : code ROUTINE : rAT_PercentRLOG |
+------------------------------------------------------------------+
PURPOSE :
*/
void rAT_PercentRLOG(T_ACI_RLOG *rslt)
{
T_MFW_CM_CALL_STAT stat;
UBYTE ton;
UBYTE mode;
TRACE_FUNCTION("rAT_PercentRLOG()");
TRACE_EVENT_P1("rslt->dest %d",rslt->dest);
TRACE_EVENT_P1("rslt->atRslt %d",rslt->atRslt);
if (rslt->dest > CMD_SRC_LCL)
{
switch (rslt->atRslt)
{
case RLOG_RSLT_OK:
TRACE_EVENT_P1("rslt->rsltPrm.rOK.cmdId %d", rslt->rsltPrm.rOK.cmdId);
if (rslt->rsltPrm.rOK.cmdId EQ AT_CMD_A
OR rslt->rsltPrm.rOK.cmdId EQ AT_CMD_D)
cm_rmt_ok_connect();
if (rslt->rsltPrm.rOK.cmdId EQ AT_CMD_H
OR rslt->rsltPrm.rOK.cmdId EQ AT_CMD_CHUP)
//NM Berlin / UK integration 21.09.01
cm_ok_disconnect(CMD_SRC_ATI_1, rslt->rsltPrm.rOK.cId);
if (rslt->rsltPrm.rOK.cmdId EQ AT_CMD_ABRT)
{
if (cm_search_callStat(rslt->rsltPrm.rOK.cId, &stat, &ton, &mode) == CM_OK)
{
if (stat == CALL_DEACTIVE)
//NM Berlin / UK integration 21.09.01
cm_ok_disconnect(CMD_SRC_ATI_1, rslt->rsltPrm.rOK.cId);
}
}
if (rslt->rsltPrm.rOK.cmdId EQ AT_CMD_CHLD)
//NM Berlin / UK integration 21.09.01
cm_result_cmd(CMD_SRC_ATI_1, Present);
#ifdef GPRS /* JVJ 10-10-02 */
/* SH - GPRS*/
switch(rslt->rsltPrm.rOK.cmdId)
{
case AT_CMD_CGDCONT:
case AT_CMD_CGQREQ:
case AT_CMD_CGQMIN:
case AT_CMD_CGATT:
case AT_CMD_CGACT:
case AT_CMD_CGDATA:
case AT_CMD_CGPADDR:
case AT_CMD_CGAUTO:
case AT_CMD_CGANS:
case AT_CMD_CGCLASS:
case AT_CMD_CGEREP:
case AT_CMD_CGREG:
case AT_CMD_CGSMS:
case AT_CMD_SNCNT:
case AT_CMD_P_CGREG:
gprs_ok(rslt->rsltPrm.rOK.cId);
break;
}
/* end SH */
break;
#endif
case RLOG_RSLT_NoCarrier:
#ifdef GPRS /* JVJ 10-10-02 */
/* SH - don't send to CM for GPRS call*/
if (rslt->rsltPrm.rNO_CARRIER.cmdId == AT_CMD_CGDATA)
{
gprs_err_connect(rslt->rsltPrm.rNO_CARRIER.cId);
}
else
#endif
cm_rmt_error_connect(rslt->rsltPrm.rNO_CARRIER.cId);
break;
case RLOG_RSLT_Busy:
/* SH - don't send to CM for GPRS call*/
#ifdef GPRS /* JVJ 10-10-02 */
if (rslt->rsltPrm.rBUSY.cmdId == AT_CMD_CGDATA)
gprs_err_connect(rslt->rsltPrm.rBUSY.cId);
else
#endif
cm_rmt_error_connect(rslt->rsltPrm.rBUSY.cId);
break;
case RLOG_RSLT_NoAnswer:
/* SH - don't send to CM for GPRS call*/
#ifdef GPRS /* JVJ 10-10-02 */
if (rslt->rsltPrm.rNO_ANSWER.cmdId == AT_CMD_CGDATA)
gprs_err_connect(rslt->rsltPrm.rNO_ANSWER.cId);
else
#endif
cm_rmt_error_connect(rslt->rsltPrm.rNO_ANSWER.cId);
break;
case RLOG_RSLT_Connect:
//NM
//merged latest version of MFW from Berlin
//only related with NO_ASCIIZ
//code 1: was replaced by code 2
//keep it still comment out the code 1
//by reason of problem swap the codes
//code 1:
//cm_data_connect(rslt->rsltPrm.rCONNECT.cId);
/* notify MMI of connect by external MMI */
//code 2:
/* SH - don't send to CM for GPRS call*/
#ifdef GPRS /* JVJ 10-10-02 */
if (rslt->rsltPrm.rCONNECT.cmdId == AT_CMD_CGDATA)
gprs_connect(rslt->rsltPrm.rCONNECT.cId);
else
/* SH end */
#endif
cm_rmt_ok_connect(); /* VO ???: to be changed (needs E_CM_CONNECT) */
break;
#ifdef GPRS /* JVJ 10-10-02 */
case RLOG_RSLT_CME:
/* SH - GPRS*/
switch(rslt->rsltPrm.rOK.cmdId)
{
case AT_CMD_CGDCONT:
case AT_CMD_CGQREQ:
case AT_CMD_CGQMIN:
case AT_CMD_CGATT:
case AT_CMD_CGACT:
case AT_CMD_CGDATA:
case AT_CMD_CGPADDR:
case AT_CMD_CGAUTO:
case AT_CMD_CGANS:
case AT_CMD_CGCLASS:
case AT_CMD_CGEREP:
case AT_CMD_CGREG:
case AT_CMD_CGSMS:
case AT_CMD_SNCNT:
case AT_CMD_P_CGREG:
gprs_error(rslt->rsltPrm.rCME.cmdId,rslt->rsltPrm.rCME.err);
break;
}
/* end SH */
break;
#endif
}
}
}
/*
+------------------------------------------------------------------+
| PROJECT : GSM-MFW (8417) MODULE : MFW_CB |
| STATE : code ROUTINE : rAT_PercentCLOG |
+------------------------------------------------------------------+
PURPOSE :
*/
void rAT_PercentCLOG(T_ACI_CLOG *cmd)
{
TRACE_FUNCTION("rAT_PercentCLOG()");
if (cmd->retCode NEQ AT_CMPL AND cmd->retCode NEQ AT_EXCT)
return;
switch (cmd->cmdType)
{
case CLOG_TYPE_Set:
switch (cmd->atCmd)
{
case AT_CMD_D:
if (cmd->cmdPrm.sD.simCallCtrl NEQ D_SIMCC_ACTIVE_CHECK)
cm_AT_D(cmd);
break;
#ifdef SIM_TOOLKIT
case AT_CMD_A:
if (mfwSatMoAccepted)
{ /* ES!! accepted SAT Call */
mfwSatMoAccepted = 0;
cm_AT_D(cmd);
}
break;
#endif
case KSD_CMD_CB:
case KSD_CMD_CF:
case KSD_CMD_CW:
case KSD_CMD_CL:
case KSD_CMD_PWD:
case KSD_CMD_UBLK:
case KSD_CMD_USSD:
case AT_CMD_CUSD:
ss_command_info(cmd);
break;
case AT_CMD_CHLD:
cm_AT_CHLD(cmd);
break;
default:
break;
}
break;
case CLOG_TYPE_Query:
break;
case CLOG_TYPE_Test:
break;
}
}
/*
+--------------------------------------------------------------------+
| PROJECT: GSM-MFW (8417) MODULE: MFW_CB |
| STATE : code ROUTINE: rAT_PercentDRV |
+--------------------------------------------------------------------+
PURPOSE : Driver indication from layer 1
*/
GLOBAL void rAT_PercentDRV( T_ACI_DRV_DEV device,
T_ACI_DRV_FCT function,
UBYTE val1,
UBYTE val2)
{
TRACE_FUNCTION ("rAT_PercentDRV()");
//ES!! check device & function !!
drvKeyUpDown(val2,val1); //ES!! val2 korrekt ?
}
/*
+--------------------------------------------------------------------+
| PROJECT: GSM-MFW (8417) MODULE: MFW_CB |
| STATE : code ROUTINE: rAT_PercentCNAP |
+--------------------------------------------------------------------+
PURPOSE : handles rAT_PercentCNAP call back
*/
EXTERN void rAT_PercentCNAP ( T_callingName *NameId, T_ACI_CNAP_STATUS status )
{
TRACE_FUNCTION("rAT_PercentCNAP()");
}
/*
+--------------------------------------------------------------------+
| PROJECT : MODULE : MFW_ACI_DUMMY |
| STATE : code ROUTINE : rAT_PlusCLAN |
+--------------------------------------------------------------------+
PURPOSE : handles AT_PlusCLAN call back
*/
EXTERN void rAT_PlusCLAN (T_ACI_LAN_SUP *CLang )
{
TRACE_FUNCTION("rAT_PlusCLAN()");
sim_read_lp_cnf(SIM_NO_ERROR,CLang);
}
/*
+--------------------------------------------------------------------+
| PROJECT : MODULE : MFW_ACI_DUMMY |
| STATE : code ROUTINE : rAT_PlusCLAE |
+--------------------------------------------------------------------+
PURPOSE : handles AT_PlusCLAE call back
*/
EXTERN void rAT_PlusCLAE (T_ACI_LAN_SUP *CLang )
{
TRACE_FUNCTION("rAT_PlusCLAE()");
}
/*
+--------------------------------------------------------------------+
| PROJECT : ACI/MMI MODULE : ACI_RET |
| STATE : code ROUTINE : rAT_PercentCSQ |
+--------------------------------------------------------------------+
PURPOSE : handles rAT_PercentCSQ call back
Shen,Chao
*/
EXTERN void rAT_PercentCSQ(UBYTE rssi, UBYTE ber, UBYTE actlevel)
{
TRACE_FUNCTION("rAT_PercentCSQ()");
}
#ifdef FF_CPHS
/*
+--------------------------------------------------------------------+
| PROJECT : MODULE : MFW_ACI_DUMMY |
| STATE : code ROUTINE : rAT_PercentCPVWI |
+--------------------------------------------------------------------+
PURPOSE : handles AT_PercentCPVWI call back
*/
GLOBAL void rAT_PercentCPVWI ( UBYTE flag_set,
USHORT line)
{ }
/*
+--------------------------------------------------------------------+
| PROJECT : MODULE : MFW_ACI_DUMMY |
| STATE : code ROUTINE : rAT_PercentCPNUMS |
+--------------------------------------------------------------------+
PURPOSE : handles AT_PercentCPNUMS call back
*/
GLOBAL void rAT_PercentCPNUMS(UBYTE element_index,
UBYTE index_level,
CHAR *alpha_tag,
CHAR *number,
BOOL premium_flag,
BOOL network_flag)
{
}
/*
+--------------------------------------------------------------------+
| PROJECT : MODULE : MFW_ACI_DUMMY |
| STATE : code ROUTINE : rAT_PercentCPCFU |
+--------------------------------------------------------------------+
PURPOSE : handles AT_PercentCPCFU call back
*/
GLOBAL void rAT_PercentCPCFU(UBYTE flag_set,
T_CPHS_LINES line)
{}
/*
+--------------------------------------------------------------------+
| PROJECT : MODULE : MFW_ACI_DUMMY |
| STATE : code ROUTINE : rAT_PercentCPROAM |
+--------------------------------------------------------------------+
PURPOSE : handles AT_PercentCPROAM call back
*/
GLOBAL void rAT_PercentCPROAM(UBYTE roam_status)
{}
#endif /* FF_CPHS */
/* EOF */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -