MTKtask简单总结(速成版)

整理文档很辛苦,赏杯茶钱您下走!

免费阅读已结束,点击下载阅读编辑剩下 ...

阅读已结束,您可以下载文档离线阅读编辑

资源描述

MTKtask小结1MTK的基本执行单元是task,从操作系统的角度来理解,task有些像线程而不是进程,进程之间的地址空间是相互隔离的,说白点就是进程之间的全局变量是不相互干扰的。而线程之间则是用同一个地址空间,MTK的task之间的地址空间也是共同的,也就是说在MTK编程里,定义了一个全局变量,那么在任何一个task里面都能引用,(这里只是举个例子,在实际编程过程中最好不要用全局变量,实在没有办法避开,那么全局变量也要分模块化,进行封装)。所以说,MTK的task更像线程,MTK用的是实时操作系统nucleus,是非抢占式操作系统,也就是当高优先级的task在运行时,低优先级的task是得不到运行时间的,除非等高优先级的task因为种种原因挂起。MTK还有一个跟task想关的概念叫module,它跟task之间的关系是:一个task可以对应多个module。task主要表示是一个执行单元,module主要是用于传递消息,在MTK中,消息传递是module为单位src_mod–des_mod,而不是以task为单位。MTKtask小结2虽然MTK手机,是featurephone(功能机),不像symbian6那样可以同时运行多个应用。但是MTK还是由许多task组成。平时MTK的后台播放MP3就是由一个task完成的。具体以后分析。现在来看看MTK最主要的task,MMItask,MTK的应用程序都是在该task里面运行,它有一整套开发MTK应用的framework。先来看创建MMItask的函数kal_boolmmi_create(comptask_handler_struct**handle){/*----------------------------------------------------------------*//*LocalVariables*//*----------------------------------------------------------------*/staticcomptask_handler_structmmi_handler_info={MMI_task,/*taskentryfunction*/MMI_Init,/*taskinitializationfunction*/NULL,NULL,/*taskresethandler*/NULL,/*taskterminationhandler*/};/*----------------------------------------------------------------*//*CodeBody*//*----------------------------------------------------------------*/*handle=&mmi_handler_info;returnKAL_TRUE;}这个函数的结构,是MTK创建task的基本结构,系统初始化时,会调用该函数。看里面的结构体typedefstruct{kal_task_func_ptrcomp_entry_func;//task的入口函数task_init_func_ptrcomp_init_func;//task的初始化函数task_cfg_func_ptrcomp_cfg_func;//task的配置函数task_reset_func_ptrcomp_reset_func;//task的重置函数task_end_func_ptrcomp_end_func;//task的终止函数}comptask_handler_struct;task的入口函数是必须的,这个函数告诉系统,初始化完相应的task控制块后,就要进入该函数来运行。task初始化函数,是在进入task入口函数之前被调用,用来初始化可能需要的资源,可选。task终止函数是,当task结束是要调用,用来释放资源,可选。其他两个函数我也不清楚干什么,希望知道的共享下先看MMItask的初始化函数.MMI_BOOLMMI_Init(task_indx_typetask_indx){//创建一个mutex(互斥体)mmi_mutex_trace=kal_create_mutex(mmi_trace);//这个是初始化2step按键,2step按键是指有一些按键具有半按下状态//比如照相功能,按下一半进行聚焦,再按下一半拍照mmi_frm_get_2step_keys();//初始化timer。L4InitTimer();//初始化UI相关信息,里面有许多画点,图等函数setup_UI_wrappers();returnMMI_TRUE;}初始化函数比较简单。下面来看MMI的入口函数,这个函数是整个MMI运行的核心。//为了简单,删除了大部分宏控制程序voidMMI_task(oslEntryType*entry_param){MYQUEUEMessage;oslMsgqidqid;U32my_index;U32count=0;U32queue_node_number=0;//获得task的外部消息队列id,通过这个id,获得别的task往MMItask发送的消息//MMItask有两个消息,外部消息队列和内部消息队列//外部消息队列的消息不直接处理,只是简单的存放到内部消息队列,//这样使内部消息队列的优先级稍微高一点qid=task_info_g[entry_param-task_indx].task_ext_qid;mmi_ext_qid=qid;//初始化event处理函数,这个几个event必须在获得消息前就进行注册//不然可能使得这个event丢弃。具体event事件,下次介绍InitEventHandlersBeforePowerOn();//进入task的while循环//task的while(1)循环使得这个task不会结束,只有挂起或者运行while(1){{//判断是否有key事件需要处理if(g_keypad_flag==MMI_TRUE){mmi_frm_key_handle(NULL);}//获得外部消息队列里,消息的个数msg_get_ext_queue_info(mmi_ext_qid,&queue_node_number);//如果没有任何消息需要处理(内部消息和外部消息都没有,同时也没有按键需要处理)//OslNumOfCircularQMsgs获得内部消息队列消息的个数if((queue_node_number==0)&&(OslNumOfCircularQMsgs()==0)&&(g_keypad_flag==MMI_FALSE)){U8flag=0;ilm_structilm_ptr;//去外部消息队列里获得消息,这是一个阻塞函数,也就是说,如果外部消息队列里,//没有任何消息,那么这个task将被阻塞,或者说挂起,也就是不在运行,//直到有消息到达,才会被唤醒,看过操作系统原理的,应该不难理解这个意思和这个本质OslReceiveMsgExtQ(qid,&Message);//如果有消息,获得task的indexOslGetMyTaskIndex(&my_index);//设置该task的获得mod为MMImod.OslStackSetActiveModuleID(my_index,MOD_MMI);//保存该消息,用于放入到内部队列ilm_ptr.src_mod_id=Message.src_mod_id;ilm_ptr.dest_mod_id=Message.dest_mod_id;ilm_ptr.msg_id=Message.msg_id;ilm_ptr.sap_id=Message.sap_id;ilm_ptr.local_para_ptr=Message.local_para_ptr;ilm_ptr.peer_buff_ptr=Message.peer_buff_ptr;//放入内部队列//这个内部队列是个简单的循环队列flag=OslWriteCircularQ(&ilm_ptr);//对timer消息进行特殊处理if(Message.src_mod_id!=MOD_TIMER){hold_local_para(ilm_ptr.local_para_ptr);hold_peer_buff(ilm_ptr.peer_buff_ptr);OslFreeInterTaskMsg(&Message);}}else{//把外部消息放入到内部消息mmi_frm_fetch_msg_from_extQ_to_circularQ();}//处理内部消息count=OslNumOfCircularQMsgs();while(count0){OslGetMyTaskIndex(&my_index);OslStackSetActiveModuleID(my_index,MOD_MMI);if(OslReadCircularQ(&Message)){CheckAndPrintMsgId((U16)(Message.msg_id));//是否是wap的消息//这里就体现了一个task可以对应多个modif(Message.dest_mod_id==MOD_WAP){}else{switch(Message.msg_id){//timer消息具体看MTKtimer小结2caseMSG_ID_TIMER_EXPIRY:{kal_uint16msg_len;//处理stacktimer消息EvshedMMITimerHandler(get_local_para_ptr(Message.oslDataPtr,&msg_len));}break;//开机消息//具体分析见后文caseMSG_ID_MMI_EQ_POWER_ON_IND:{mmi_eq_power_on_ind_struct*p=(mmi_eq_power_on_ind_struct*)Message.oslDataPtr;/*Toinitializedata/time*/SetDateTime((void*)&(p-rtc_time));gdi_init();g_pwr_context.PowerOnMMIStatus=MMI_POWER_ON_INDICATION;switch(p-poweron_mode){casePOWER_ON_KEYPAD:OslMemoryStart(MMI_TRUE);g_charbat_context.PowerOnCharger=0;g_pwr_context.PowerOnMode=POWER_ON_KEYPAD;DTGetRTCTime(&StartUpTime);memset(&LastDuration,0,sizeof(LastDuration));mmi_bootup_entry_disk_check();break;casePOWER_ON_PRECHARGE:casePOWER_ON_CHARGER_IN:g_pwr_context.PowerOnMode=p-poweron_mode;InitializeChargingScr();if(!g_charbat_context.isChargerConnected){QuitSystemOperation();}break;casePOWER_ON_ALARM:g_pwr_context.PowerOnMode=POWER_ON_ALARM;gdi_layer_clear(GDI_COLOR_BLACK);AlmInitRTCPwron();break;casePOWER_ON_EXCEPTION:g_pwr_context.PowerOnMode=POWER_ON_EXCEPTION;gdi_layer_clear(GDI_COLOR_BLACK);OslMemoryS

1 / 12
下载文档,编辑使用

©2015-2020 m.777doc.com 三七文档.

备案号:鲁ICP备2024069028号-1 客服联系 QQ:2149211541

×
保存成功