MTK平台定时器消息处理机制

移动开发
MTK平台定时器消息处理机制是本文要介绍的内容,主要是来了解并学习MTK中定时器的处理机制,具体内容的实现来看本文详解。

MTK平台定时器消息处理机制是本文要介绍的内容,主要是来了解并学习MTK定时器的处理机制,不多说,具体内容的实现来看本文详解。

发送定时器消息

(1).步骤

StartTimer->L4StartTimer

(2).两种类型的定时器

MTK中有两种类型的定时器

a、NO_ALIGNMENT

非队列式的,即要求立即执行的定时器,时间到了就自动被reset.

b、ALIGNMENT

队列式的,即可以通过队列操作,有一定的延时容忍的定时器.y

其基本执行流程:执行定时器-->超时?-->保存timerid,eventid--timerstop||noevent?---->END;

  1. |YN|  
  2.  
  3. ||  
  4.  
  5. ---------------------------------------------------------- 

c.除了触摸屏和手写,其他情况下的定时器一般都是队列式的.

(3).L4StartTimer的作用

判断将要发送的定时器ID,根据是否是队列类型传递给不同的队列结构(event_sheduler1/event_sheduler2);

(4).TimerExpiry

这是作为参数传递给L4StartTimer的回调函数,由于MTK做了一定的封装,因此其内部具体回调触发过程

无法得知,但根据猜测,应该是在定时时间一到,以中断的方式发出消息(MSG_ID_TIMER_EXPIRY),并将其写到MMI的循环队列.

该函数可能是在L4CallBackTimer中调用的,L4CallBackTimer的作用如下:

a.重置当前定时器信息结构(mmi_frm_timer_type);

b.执行定时器到点后的执行函数(TimerExpiry);

c.讲Timer消息写到MMI循环队列中.

与StartTimer对应的StopTimer

(1).具体实现通过调用L4StopTimer操作.

(2).作用:找出指定要停止的定时器ID在队列中的位置,然后使用evshed_cancel_event将指定定时器节点从队列中删除.

定时器消息的处理

(1).步骤

...->创建MMITask->设置MMITask入口函数->调用EvshedMMITimerHandler

(2).evshed_timer_handler()->处理具体的定时器事件

简单分析MTK定时器消息事件,由于只是简单的分析,谬误定然甚多,忘包涵包涵并不吝指正.

MTK定时器消息处理机

一、基本概念及Neclus内核定时器初始化

expires:指定定时器到期的时间,这个时间被表示成自系统启动以来的时钟滴答计数(也即时钟节拍数)。当一个定时器的expires值小于或等于jiffies变量时,我们就说这个定时器已经超时或到期了。在初始化一个定时器后,通常把它的expires域设置成当前expires变量的当前值加上某个时间间隔值(以时钟滴答次数计。

  1. typedefstructtimertable  
  2. {/*storethetimer_id.MSB(MostSignificantBit)isalign_timer_mask*/  
  3. U16timer_id[SIMULTANEOUS_TIMER_NUM];  
  4. /*storetheevent_idthatreturnsfromevshed_set_event()*/  
  5. eventidevent_id[SIMULTANEOUS_TIMER_NUM];  
  6. /*storethetimer_expiry_func*/  
  7. oslTimerFuncPtrcallback_func[SIMULTANEOUS_TIMER_NUM];  
  8. /*pointtothenextTIMERTABLEdata*/  
  9. structtimertable*next;  
  10. }TIMERTABLE;  
  11. typedeflcd_dll_node*eventid;  
  12. structlcd_dll_node{  
  13. void*data;  
  14. lcd_dll_node*prev;  
  15. lcd_dll_node*next;  
  16. }; 

(1)timer_id:定时器id最多同时12个。

(2)双向链表元素event_id:用来将多个定时器调度动作连接成一条双向循环队列。

(3)函数指针callback_func:指向一个可执行函数。当定时器到期时,内核就执行function所指定的函数,产生expires消息。

  1. //L4initthetimer  
  2. /*****************************************************************************  
  3. *FUNCTION  
  4. *L4InitTimer  
  5. *DESCRIPTION  
  6. *Thisfunctionistoinitthetimerwhiletaskcreate.  
  7. *  
  8. *PARAMETERS  
  9. *aINvoid  
  10. *RETURNS  
  11. *VOID.  
  12. *GLOBALSAFFECTED  
  13. *external_global  
  14. *****************************************************************************/  
  15. voidL4InitTimer(void)  
  16. {  
  17. /*----------------------------------------------------------------*/  
  18. /*LocalVariables*/  
  19. /*----------------------------------------------------------------*/  
  20. TIMERTABLE*p;  
  21. TIMERTABLE*pp;  
  22. /*----------------------------------------------------------------*/  
  23. /*CodeBody*/  
  24. /*----------------------------------------------------------------*/  
  25. /*TrytofreeTIMERTABLElistexcludeg_timer_table*/  
  26. p=g_timer_table.next;  
  27. pp=NULL;  
  28. do  
  29. {  
  30. if(p!=NULL)  
  31. {  
  32. ppp=p->next;  
  33. OslMfree(p);  
  34. }  
  35. p=pp;  
  36. }while(p!=NULL);  
  37. /*resetg_timer_talbe*/  
  38. memset(&g_timer_table,0,sizeof(TIMERTABLE));  
  39. g_timer_table_size=SIMULTANEOUS_TIMER_NUM;  
  40. g_timer_table_used=0;  
  41. /*Initiatetheclocktimecallbackfunction.*/  
  42. get_clocktime_callback_func=NULL;  
  43. set_clocktime_callback_func=NULL;  
  44. /*Initatethenoalignmentstacktimer*/  
  45. stack_init_timer(&base_timer1,"MMI_Base_Timer1",MOD_MMI);  
  46. /*Createanoalignmenttimerschedule*/  
  47. event_scheduler1_ptr=new_evshed(&base_timer1,  
  48. L4StartBaseTimer,L4StopBaseTimer,  
  49. 0,kal_evshed_get_mem,kal_evshed_free_mem,0);  
  50. /*Initatethealignmentstacktimer*/  
  51. stack_init_timer(&base_timer2,"MMI_Base_Timer2",MOD_MMI);  
  52. /*Createanalignmenttimerschedule*/  
  53. event_scheduler2_ptr=new_evshed(&base_timer2,  
  54. L4StartBaseTimer,L4StopBaseTimer,  
  55. 0,kal_evshed_get_mem,kal_evshed_free_mem,255);  
  56. }  
  57. typedefstructstack_timer_struct_t{  
  58. module_typedest_mod_id;  
  59. kal_timeridkal_timer_id;  
  60. kal_uint16timer_indx;  
  61. stack_timer_status_typetimer_status;  
  62. kal_uint8invalid_time_out_count;  
  63. }stack_timer_struct;  
  64. /*************************************************************************  
  65. *ExportedFunctionPrototypes  
  66. *************************************************************************/  
  67. /*  
  68. *Important:  
  69. *Currentimplementationmax_delay_ticks_disibledevent="text-indent:24pt;line-height:150%"align="left"> 

小结:

MTK平台定时器消息处理机制的内容介绍完了,希望通过本文的学习能对你有所帮助!

责任编辑:zhaolei 来源: 互联网
相关推荐

2011-03-17 09:20:05

异常处理机制

2011-07-01 14:20:59

Qt 事件

2011-07-01 14:14:34

Qt 事件

2014-05-22 15:45:58

Android消息处理机制Looper

2014-05-22 15:15:53

Android消息处理机制Looper

2014-05-22 15:33:31

Android消息处理机制Looper

2014-05-22 15:18:25

Android消息处理机制Looper

2014-05-22 14:57:28

Android消息处理机制Looper

2014-05-22 15:48:50

Android消息处理机制Looper

2014-05-22 15:41:59

Android消息处理机制Looper

2014-05-22 15:07:44

Android消息处理机制Looper

2014-05-22 15:38:27

Android消息处理机制Looper

2014-05-22 15:04:00

Android消息处理机制Looper

2014-05-22 15:00:16

Android消息处理机制Looper

2011-07-21 15:20:41

java异常处理机制

2010-07-28 15:56:22

FlexTimer定时

2009-11-11 10:14:10

linux定时器操作系统

2021-07-03 17:53:52

Java异常处理机制

2023-12-25 09:30:41

Java垃圾回收

2009-08-05 18:09:17

C#异常处理机制
点赞
收藏

51CTO技术栈公众号