MTK死机bug

死机bug 一、一个编译开关引发的血案:(此问题耗时本菜鸟1周排查出来)

 

问题主要涉及到以下文件:(橙色为新增加部分)

 

1FLYFOT_FEATURES.h

 

#define _FT_SMS_DOUBLE_LINE_INBOX_    

 

2MMI_features.h

 #include "FLYFOT_FEATURES.h" 

3mmi_msg_context.h

 typedef struct

{

   

    unsigned short msgtype;

    unsigned char storageType;

 

    unsigned char startseg;

    unsigned char totalseg;

 

    unsigned char timestamp[7];

    unsigned char number[21];

#ifdef _FT_SMS_DOUBLE_LINE_INBOX_

 

         unsigned char sms_content[MMI_SMS_MINI_STORED_CONTENT_SIZE];

#endif

    unsigned short ref;

    unsigned short startindex;

#ifdef __UNIFIED_MESSAGE_BACKGROUND_SEND_SUPPORT__

    unsigned char send_status;

#endif

 

#if defined(__UNIFIED_MSG_SUPPORT__) && !defined(__UNIFIED_MESSAGE_LOW_MEMORY_SUPPORT__)

    unsigned short content[MMI_SMS_MAX_MMI_STORED_CONTENT_SIZE];

#endif

#ifdef __MSG_SMS_EMAIL_SUPPORT__

         unsigned char  pid;

#endif

#ifdef __EMS_NON_STD_7BIT_CHAR__

         unsigned char dcs;

#endif

} mmi_frm_sms_msgbox_struct;

 

4mmi_msg_context.c:(没有#include "MMI_features.h"

mmi_frm_sms_msgbox_struct mmi_frm_sms_msg_box[MMI_SMS_MAX_MSG_NUM];   

 

 

5SMSUtil.c:(有#include "MMI_features.h"

mmi_ucs2ncpy((S8*) mmi_frm_sms_msg_box[addindex].sms_content, (S8*) data->sms_content,MMI_SMS_MINI_STORED_CONTENT_SIZE/2 - 1);

 

/* 由于此文件有#include "MMI_features.h",所以_FT_SMS_DOUBLE_LINE_INBOX_开关在mmi_frm_sms_msgbox_struct里有效,所以. sms_content部分

 

可以编译通过,但是由于之前没有内存分配,运行时则会越界。。

就MTK 6225平台而言,大部分的xxx .c文件,通常都有包含#include "MMI_features.h",也就是说,在修改.h时候,并不会遇到编译开关打开了却“无效”或“部分文件有效、部分文件无效”的问题。

而在  .../MTK_08A40/custom/common文件夹下,一些.c文件,可能由于客户化关系,并没有包含#include "MMI_features.h", 那么当需要修改或扩展此文件夹下的.h中的结构体时(并且使用了编译开关),

应该检查其对应的变量声明处(对应的.c文件)有无包含#include "MMI_features.h",此文件夹比较特殊,请大家引起注意。

死机bug 二、MMI TASK 栈内存爆掉

void F1(void)
{
 
 U8 tmp_buf[512];
 U8 i ;
  
 for(i=0;i<512;i++)
 {
  tmp_buf[i] = 0;
 }
}
此函数的执行会导致手机重启。
 

如果将512修改为256,则没有问题了。

此问题的原因是栈内存爆掉了,想必是程序在调用该函数之前,已经调用了一些函数,并且已经使用了许多的栈内存。

MTK平台 MMI TASK的stack size 通常定义为2k。

死机bug 三、MMI Quece爆掉

短信按姓名排序

void mmi_frm_sms_create_sms_list(void)
{
        for (i = 0; i < g_frm_sms_cntx.mmi_frm_sms_msg_box_size; i++)
        {
               sort_by_name_done(i);
        }
}

由于按姓名排序需要拼音比较、号码匹配等较为复杂的操作,所用算法又是效率极低的冒泡排序法。所以比较耗时,排序1条时间近0.1秒。
故,完成3000条短信排序,需要几分钟的时间,这样执行时,MMI TASK一直被占用,导致MMI QUEUE爆掉。


这个问题的最终解决方法是,将冒泡排序算法改为堆排序。时间大大缩短,仅为3秒,问题得解。

 

死机bug 四、 History栈爆掉

 


static S16 increment(void)
{
    ++currHistoryIndex;
    MMI_ASSERT(currHistoryIndex < MAX_HISTORY);  //history 栈超过30!!
    return currHistoryIndex;
}
分析:
重复进行信箱排序,途径的界面为:
1,inbox list界面。
2,inbox option界面。
3,排序选择界面。
4,Processing处理界面。
5,inbox msg 阅读界面。
这是一个循环,所以中间的任意界面的history都在不停的压栈,弹栈。
原来代码里没有对SCR_ID_MSG_INBOX_OPTION,SCR_ID_MSG_INBOX_MSG,SCR_ID_MSG_SMS_SORT_INBOX_SETTING界面进行弹栈操作,致使每进行一次循坏操作,栈内id就会累加,导致栈最终爆掉。

解决方法,使得每次entryscreen 某一个Scr_ID的时候,都DeleteScreenIfPresent(Scr_ID);
达到进入屏幕A之前,必先清除屏幕A,保持history 栈里始终至多有一个屏幕A,问题得解。

 

 

死机bug 五、常规死机问题

 

1,数组长度越界。
2,数据类型越界。
3,0作为"/"或"%"。

4,文件句柄超出,内存泄露等。


你可能感兴趣的:(算法,struct,list,processing,sms,MTK)