MTK-call history operate(1)

product: In CM, Where and How to write call log 

1.call history的保存。在各种通话状态中的保存过程

1.MO

(1)放弃outgoing call

ProcessPSHangupSucEvent()

       LogCallInfoForCallHistory(*handle);

       GetEndTimeAndNotifyCallAborted();

              CMGetExactTime(GetDateTimeAndNotifyCallAbortedCBack);

                                                 memcpy(&cm_p->state_info.CallStructureForCallLog.start_time, t, sizeof(MYTIME));  拷贝当前时间

                                             memcpy(&cm_p->state_info.CallStructureForCallLog.end_time, t, sizeof(MYTIME));

                                                 LogCall();

                                                        LogCallWithStartTime(&cm_p->state_info.CallStructureForCallLog);

                                                               if (CM_CALL_MO == log->orgination_flag) 判断电话类型:MO, MT

                                                           {

                                                              CHISTLogDialedCall(log);

                                                                             ReqWriteCallLog(call, PHB_LND);

                                                           }

                                                           else if (CM_CALL_MT == log->orgination_flag)

                                                          {

                                                              CHISTLogRecvdCall(log);

                                                                             ReqWriteCallLog(call, PHB_LNR);

                                                           }

                                                 EntryScrNotifyCallAborted();

 

       ReqWriteCallLog()这是最后写入函数

              设置返回消息PRT_MMI_PHB_SET_LAST_NUMBER_RSP的CBack函数:RspWriteDialedNum,RspWriteMissedNum,RspWriteRecvdNum。

              chis_p->process = CALL_LOG_PROC_WRITE;

 

              dataPtr = (SET_LAST_NUMBER_REQ*) OslConstructDataPtr(sizeof(SET_LAST_NUMBER_REQ));

          dataPtr->type = type;

          dataPtr->no_data = 0;

          dataPtr->index = 0xff;

              memset((U8*) & dataPtr->entry.tel, 0, sizeof(CALL_LOG_NUMBER_STRUCT));                   清空号码入口

              memset((U8*) & dataPtr->entry.alpha_id, 0, sizeof(CALL_LOG_NAME_STRUCT));               清空姓名入口

 

              //开始装载号码和姓名

              如果号码第一位是+,dataPtr->entry.tel.type = 145(0x91),否则dataPtr->entry.tel.type = 129(0x81).

              然后把号码转换成ASCII码,并拷贝到dataPtr->entry.tel.number中。

              姓名也要转换成ASCII码,并转换成大端格式。(小端:低位放低地址,大端:低位放高地址)

             

              ConvertMYTIME2RTC(&dataPtr->entry.time, &dailCall->start_time);     开始时间转换成RTC格式

          dataPtr->entry.call_duration = 0;       时间

          dataPtr->entry.count = 1;                  次数

 

              发送消息: PRT_MMI_PHB_SET_LAST_NUMBER_REQ

 

然后PS返回消息PRT_MMI_PHB_SET_LAST_NUMBER_RSP,进入CBACK函数:

RspWriteDialedNum()

       chis_p->nDialedCalls = (U8) rsp->no_list;      当前已拨电话数目

       chis_p->process = CALL_LOG_PROC_NONE;

 

 

(2)网络挂断MO call

ProcessEndCallIdAndGoBack()

       LogCallInfoForCallHistory()

       GetEndTimeAndLogUnconnectedMOCall()

              CMGetExactTime(GetDateTimeAndLogUnconnectedMOCallCBack);

                                                 memcpy(&cm_p->state_info.CallStructureForCallLog.start_time, t, sizeof(MYTIME));

                                             memcpy(&cm_p->state_info.CallStructureForCallLog.end_time, t, sizeof(MYTIME));

                                             LogCall();

       EntryScr1004NotifyEndCallDuration()

 

 

(3)MO call connect

OutgoingCallConnected()

       DTGetRTCTime(&t);   获取当前时间

       UpdateCallStartTimeAndLogCall(handle, &t);

              memcpy(&cm_p->state_info.AllCalls[index].start_time, t, sizeof(MYTIME));   //拷贝当前时间

              LogCallWithStartTime(&cm_p->state_info.AllCalls[index]);

 

MT CALL

(4)reject a MT

ProcessIncomingCallRejected

       LogCallInfoForCallHistory(GetIncomingCallHandle());

   PurgeIncomingCallStructure();

              SetCallState( )

                     GetEndTimeAndNotifyCallRejected()             reject a MT call

                            CMGetExactTime( GetDateTimeAndNotifyCallRejectedCBack );

                                                               memcpy(&cm_p->state_info.CallStructureForCallLog.start_time,t,sizeof(MYTIME));

                                                               memcpy(&cm_p->state_info.CallStructureForCallLog.end_time,t,sizeof(MYTIME));

                                                        CHISTLogRejectedCall(&cm_p->state_info.CallStructureForCallLog);

                                                                      ReqWriteCallLog( call, PHB_LNM );

                                                               EntryScr1004NotifyEndCallDuration( )

             

                     GetEndTimeAndNotifyCallMissed()            miss a MT call

                            memcpy(&cm_p->state_info.CallStructureForCallLog.start_time, &t, sizeof(MYTIME));

                        memcpy(&cm_p->state_info.CallStructureForCallLog.end_time, &t, sizeof(MYTIME));

                        CHISTLogMissedCall(&cm_p->state_info.CallStructureForCallLog);

                                   设置未接电话的status icon以及一些变量

                                   ReqWriteCallLog(call, PHB_LNM);

 

(5)接听MT

ProcessAcceptIncomingCall()

       EntryScr1002ActiveCall()

              DummyScr1002ActiveCall()

                     UpdateCallStartTimeAndLogCall()            与MO接通相同

                            memcpy(&cm_p->state_info.AllCalls[index].start_time, t, sizeof(MYTIME));

                            LogCallWithStartTime(&cm_p->state_info.AllCalls[index]);

 

 

(6)挂断ACTIVE、HOLD call

ProcessPSHangupSucEvent()

       LogCallInfoForCallHistory()

       GetEndTimeAndNotifyEndCallDuration()

              memcpy(&gTimeStructForEndedCallStartTime, &(cm_p->state_info.AllCalls[GetMMIStructIndexof(handle)].start_time), sizeof(MYTIME));       //开始时间

              memset(&temp, 0, sizeof(MYTIME));

              if (!(memcmp(&gTimeStructForEndedCallStartTime, &temp, sizeof(MYTIME)) == 0))         //开始时间不为0,即:要更新已经写入NVRAM的call log record

              {

                     DTGetRTCTime(&(cm_p->state_info.CallStructureForCallLog.end_time));     //获取电话结束时间

                     CHISTLogDialedCallDuration(&cm_p->state_info.CallStructureForCallLog); 或者

                            if (电话start time 与 end time不同)

                            {

                                   GetTimeDifference(&call->end_time, &call->start_time, &chis_p->last_call_time);                获取时间差,即最后通话时间

                           IncrementTime(chis_p->total_out_time, chis_p->last_call_time, &(chis_p->total_out_time)); 已拨电话总计增加

 

                           WriteRecord(NVRAM_EF_CALL_TIME_LID, 2, (void*)&chis_p->total_out_time, sizeof(MYTIME), &error);

                           WriteRecord(NVRAM_EF_CALL_TIME_LID, 1, (void*)&chis_p->last_call_time, sizeof(MYTIME), &error);

 

                           mmi_chist_log_call_duration(call, PHB_LND);       更新已经写入NVRAM中的record.

                                          首先根据类型:PHB_LND,PHB_LNR设置开始读取的record位置:

                                          if (type == PHB_LND)

                                      {

                                         start_lid = 1;

                                      }

                                      else if (type == PHB_LNR)

                                      {

                                                 //计算结果是5。

                                         start_lid = 1 + ((TOT_SIZE_OF_DIALED_LIST + TOT_SIZE_OF_ONE_LN_LIST -1)/TOT_SIZE_OF_ONE_LN_LIST) +

                                                  ((TOT_SIZE_OF_DIALED_LIST + TOT_SIZE_OF_ONE_LN_LIST -1)/TOT_SIZE_OF_ONE_LN_LIST);

                                     }

                                          注意:关于call log在NVRAM中的存储,文件ID是:NVRAM_EF_PHB_LN_ENTRY_LID。一共有6个record,每个record共924字节。

                                          是不是record1,2存储dialed call log,3,4存储misesed call log,5,6存储received call log?

                                          在下面的ReadRecord( )函数中,变量temp_call_log中最多只能读取10个log entry,那么另外10个call log也就是上面的record 6怎么读取的                                        (每种call log是20个)?

 

                                          temp_call_log = OslMalloc(NVRAM_EF_PHB_LN_ENTRY_SIZE);     分配空间,准备存储读取的call log

                                          ReadRecord(NVRAM_EF_PHB_LN_ENTRY_LID, start_lid, temp_call_log, NVRAM_EF_PHB_LN_ENTRY_SIZE, &error);       读取NVRAM

                                          for (i=0; i< temp_call_log->no_entry; i++)

                                          {

                                                 ConvertRTC2MYTIME(&start_time, &temp_call_log->array[i].time);      获取读取到的call log开始时间

                                                 if (CompareTime(start_time, call->start_time, NULL) == 0)                      与要保存的开始时间相同

                                                 {           

                                                        先把temp_call_log->array[i].addr_bcd[]中的BCD码转换成ASCII码,再转换成UCS2。

                                                        AnsiiToUnicodeString(ucs2_number, (S8*) tempNumber);

                                                        if (pfnUnicodeStrcmp((const S8*)ucs2_number, (const S8*)call->num) == 0)         与要保存的电话号码相同

                                                        {

                                                               更新temp_call_log->array[i].call_duration = call.end_time – call.start_time;

                                                               WriteRecord(NVRAM_EF_PHB_LN_ENTRY_LID, start_lid, temp_call_log, NVRAM_EF_PHB_LN_ENTRY_SIZE, &error);

                                           break;

                                                        }

                                                 }                                       

                                          }                                       

                            }

 

                     CHISTLogRecvdCallDuration(&cm_p->state_info.CallStructureForCallLog);

                            if (电话start time 与 end time不同)

                            {

                                   GetTimeDifference(&call->end_time, &call->start_time, &chis_p->last_call_time);                获取时间差,即最后通话时间

                           IncrementTime(chis_p->total_in_time, chis_p->last_call_time, &(chis_p->total_in_time));      已接电话总计增加

 

                           WriteRecord(NVRAM_EF_CALL_TIME_LID, 3, (void*)&chis_p->total_in_time, sizeof(MYTIME), &error);

                           WriteRecord(NVRAM_EF_CALL_TIME_LID, 1, (void*)&chis_p->last_call_time, sizeof(MYTIME), &error);

 

                           mmi_chist_log_call_duration(call, PHB_LNR);

                            }

              }

             

              CMGetExactTime(GetDateTimeAndNotifyEndCallDurationCBack);

                                                 EntryScr1004NotifyEndCallDuration();

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

IOT物联网小镇

赏点银子去植发

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值