RDA UMF进程 UMF_IR.C 遥控处理

2023-10-31 19:50
文章标签 处理 进程 ir 遥控 rda umf

本文主要是介绍RDA UMF进程 UMF_IR.C 遥控处理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

SIS架构图:

  

   SW Structure

  

  APP Event Flow :消息分发流程

  

 

 

UMF进程:

int umf_main(int argc, char* argv[])
{umf_Init();/* AFW initialize public module */AL_FW_Init(FW_MAIN_INIT, MAINAPP_FW_Callback, MAINAPP_FW_GetContext);SW_init();MainApp_InitCfg_t stMainAppInit ={.pfInitFlow = MAINAPP_InitFlow,                //软件初始化,及回调通过“MAINAPP_Initialize()”注册到“g_pfInitFlow”。并在“MAINAPP_MainRoutine”完成执行.pGUIObjectTable = MAIN_APP_GUI_Obj_List,   //已创建UI窗口链表,主要用于窗口的创建、销毁和消息的流动.pfOnTimerUpdate = MAINAPP_OnTimerUpdate,  .pfOnEvent = MAINAPP_OnEvent          //UI事件处理,在MAINAPP_MainRoutine->_MAINAPP_ExternalEventHandler中调用};MAINAPP_Initialize(&stMainAppInit);        //创建主线程"MAINAPP_MainRoutine",主要负责消息调度、服务注册、消息投递和消息处理while (1){sleep(100);}}

主线程“main_app.c”->MAINAPP_MainRoutine:

  主要负责消息调度和消息驱动,最后都会转到服务例程处理"_SYSAPP_MainRoutine":

void MAINAPP_MainRoutine(void *pParam)
{unsigned int dMessage;unsigned int dMessageType;App_MessageBody_t MsgReceived;if (g_pfInitFlow != NULL){g_pfInitFlow((void *)(&gdTotalAppSize));    //执行"MAINAPP_InitFlow"
    }while (!bMPBreakCondition){bMainAppRunning = 1;GL_Status_t MsgReport;//取消息MsgReport = GL_QueueReceive(MainAppQueueHandle, (void *)(&MsgReceived), APP_MESSAGE_BODY_SIZE, GL_INFINITE_WAIT);//消息转换"APP_CustomerFuncStart",主要是IR KEYPAD等UI_EVENT等消息在处理前做必要的转换MAINAPP_MessageDisposeStart(&MsgReceived.dMessage, &MsgReceived.dParam);dMessageType = ((MsgReceived.dMessage) & APPLICATION_MESSAGE_TYPE_MASK);dMessage = ((MsgReceived.dMessage) & APPLICATION_MESSAGE_MASK);//OS消息处理switch (dMessageType){case APPLICATION_INTERNAL_MESSAGE_TYPE:_MAINAPP_InternalEventHandler(dMessage, MsgReceived.dParam);break;case APPLICATION_EXTERNAL_MESSAGE_TYPE:case APPLICATION_EXTERNAL_MESSAGE_TYPE|APPLICATION_EXTERNAL_UI_MESSAGE_TYPE:_MAINAPP_ExternalEventHandler(dMessage, MsgReceived.dParam);break;default:break;}MAINAPP_MessageDisposeEnd(&MsgReceived.dMessage, &MsgReceived.dParam);}GL_TaskYield();                //线程让步return ;
}

SW及消息队列初始化:

int MAINAPP_InitFlow(void *param)
{_MAINAPP_SW_Init();/* initialize message filter. */_MAINAPP_InitSysApp((UINT32 *)param); /* initialize PQ relative function */PQ_Init();/*create App Infra update timer.*/SYSAPP_TIMER_CreateTimer();return SP_SUCCESS;
}

IR回调:

static int _MAINAPP_InitSysApp(UINT32* dTotalApp)
{SYSAPP_IF_Initialize(TOTAL_SYS_APP_SIZE, apstSysAppInst); //将服务apstSysAppInst注册到gpAppInstTable。*dTotalApp = TOTAL_SYS_APP_SIZE;APP_RegionMgr_Init();APP_GuiMgr_Set_Menu() ;APP_GuiMgr_SwitchShareMenu(TOTAL_SYS_APP_SIZE);

    UINT8 i;
    for (i = 0; i < TOTAL_SYS_APP_SIZE; i++)
    {  
      SYSAPP_IF_InitializeSysApp(i, MainAppQueueHandle);       //1 by 1 创建服务线程"_SYSAPP_MainRoutine",DTV服务有SYS_APP_DVB/SYS_APP_ATV/SYS_APP_FILE_PLAYER
    }

/* initialize IR */ir_SetMappingTable(stIR_map, dIR_map_size);ir_LoadEventCode(0);KP_LoadCustomerConfig();ir_init(_MAINAPP_Ir_Callback);                                        //接收线程“ir_Receive”接收到IR后,通过此回调将消息投递到“消息队列”
    joystick_init(_MAINAPP_Joystick_Callback);MAINAPP_RegisterFunc(APP_CustomerFuncStart, APP_CustomerFuncEnd);    //IR处理,回调注册到"g_pfMessageDisposeStart",通过主例程MAINAPP_MainRoutine->GL_QueueReceive取消息后调用MAINAPP_MessageDisposeStartreturn 0;
}

创建IR/KEYPAD接收线程及“IR_CallBack”回调指针的注册:

int ir_init(IR_CallBack_t pIR_CallBackFunc)
{IR_IOC_IOData irbuf;pthread_t irthread;irdev = open("/dev/sisir", O_RDWR);if(KP_init() == E_FAIL){return E_FAIL;}size_t stacksize = 16*1024;pthread_attr_t attr;pthread_attr_init(&attr);pthread_attr_setstacksize(&attr, stacksize);if(pthread_create(&irthread, &attr, ir_Receive, NULL) != 0)        //IR接收线程ir_Receive,接收IR并调用"IR_CallBack"投递消息到消息队列
    {UMFDBG(0,"IR pthread_create fail \n");}pthread_attr_destroy(&attr);IR_CallBack = pIR_CallBackFunc;                                    //注册回调指针,即在ir_Receive线程中,调用“IR_CallBack”即调用“_MAINAPP_Ir_Callback”将IR投递到消息队列return S_OK;
}

 服务例程“_SYSAPP_MainRoutine”:

static void _SYSAPP_MainRoutine(void *pParam)
{SysAppInstDef *pstCurrentSysApp = (SysAppInstDef *) pParam;SystemAppInfra_t *pstTempInfra = (SystemAppInfra_t *) pstCurrentSysApp->stSystemAppInfrastructure;pstCurrentSysApp->fpOnCreate(&(pstTempInfra->pPrivateData));UINT32 dMessage;UINT32 dMessageType;App_MessageBody_t Message;while (!pstTempInfra->dBreakCondition){//取消息GL_QueueReceive(pstTempInfra->stMsgQueueHandle, (void *)(&Message), APP_MESSAGE_BODY_SIZE, GL_INFINITE_WAIT);//消息转换"APP_CustomerFuncStart",主要是IR KEYPAD等UI_EVENT等消息在消息处理前做必要的转换MAINAPP_MessageDisposeStart(&Message.dMessage, &Message.dParam);dMessageType = ((Message.dMessage) & APPLICATION_MESSAGE_TYPE_MASK);dMessage = ((Message.dMessage) & APPLICATION_MESSAGE_MASK);sysappfl2("[SysApp] System app Received MSG, types is:%d.\n", Message.dMessage);//OS消息处理switch (dMessageType){case APPLICATION_INTERNAL_MESSAGE_TYPE:_SYSAPP_InternalEventHandler(pstCurrentSysApp, pstTempInfra, dMessage, Message.dParam);break;case APPLICATION_EXTERNAL_MESSAGE_KEY_RELEASE_TYPE:case APPLICATION_EXTERNAL_MESSAGE_KEY_RELEASE_TYPE|APPLICATION_EXTERNAL_UI_MESSAGE_TYPE:_SYSAPP_ExternalEventHandler(pstCurrentSysApp, pstTempInfra, dMessage, Message.dParam);break;case APPLICATION_EXTERNAL_MESSAGE_TYPE:case APPLICATION_EXTERNAL_MESSAGE_TYPE|APPLICATION_EXTERNAL_UI_MESSAGE_TYPE:_SYSAPP_ExternalEventHandler(pstCurrentSysApp, pstTempInfra, dMessage, Message.dParam);break;default:break;}MAINAPP_MessageDisposeEnd(&Message.dMessage, &Message.dParam);}GL_TaskYield();return;
}

 

服务例程事件处理:

static void _SYSAPP_ExternalEventHandler(SysAppInstDef *pstSysApp,SystemAppInfra_t *pstInfra, UINT32 dMessage, UINT32 dParam)
{switch(dMessage){case APPLICATION_EXTERNAL_TIMER_MESSAGE:pstSysApp->fpOnTimerUpdate(pstInfra->pPrivateData);_SYSAPP_GOBJ_GUIObjectTimerUpdate(pstSysApp->dSystemApplicationIndex);break;default://当前菜单先处理,如果没有聚焦UI,则转到相应的服务处理,如:atv_app.c->_ATVApp_OnEvent处理if(_SYSAPP_GOBJ_GUIObjectMessageHandler(pstSysApp->dSystemApplicationIndex, dMessage, dParam)  //主要负责GUI_OBJECT_POST_EVENT及GUI_OBJECT_EVENT_BYPASS的事件处理== SYSTEM_APP_NO_FOCUSED_GUIOBJ){pstSysApp->fpOnEvent(pstInfra->pPrivateData, dMessage, dParam);}break;}return;
}

 

转载于:https://www.cnblogs.com/jiangzhaowei/p/7419805.html

这篇关于RDA UMF进程 UMF_IR.C 遥控处理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/317711

相关文章

Python实现批量CSV转Excel的高性能处理方案

《Python实现批量CSV转Excel的高性能处理方案》在日常办公中,我们经常需要将CSV格式的数据转换为Excel文件,本文将介绍一个基于Python的高性能解决方案,感兴趣的小伙伴可以跟随小编一... 目录一、场景需求二、技术方案三、核心代码四、批量处理方案五、性能优化六、使用示例完整代码七、小结一、

Python中 try / except / else / finally 异常处理方法详解

《Python中try/except/else/finally异常处理方法详解》:本文主要介绍Python中try/except/else/finally异常处理方法的相关资料,涵... 目录1. 基本结构2. 各部分的作用tryexceptelsefinally3. 执行流程总结4. 常见用法(1)多个e

PHP应用中处理限流和API节流的最佳实践

《PHP应用中处理限流和API节流的最佳实践》限流和API节流对于确保Web应用程序的可靠性、安全性和可扩展性至关重要,本文将详细介绍PHP应用中处理限流和API节流的最佳实践,下面就来和小编一起学习... 目录限流的重要性在 php 中实施限流的最佳实践使用集中式存储进行状态管理(如 Redis)采用滑动

MyBatis-plus处理存储json数据过程

《MyBatis-plus处理存储json数据过程》文章介绍MyBatis-Plus3.4.21处理对象与集合的差异:对象可用内置Handler配合autoResultMap,集合需自定义处理器继承F... 目录1、如果是对象2、如果需要转换的是List集合总结对象和集合分两种情况处理,目前我用的MP的版本

Python自动化处理PDF文档的操作完整指南

《Python自动化处理PDF文档的操作完整指南》在办公自动化中,PDF文档处理是一项常见需求,本文将介绍如何使用Python实现PDF文档的自动化处理,感兴趣的小伙伴可以跟随小编一起学习一下... 目录使用pymupdf读写PDF文件基本概念安装pymupdf提取文本内容提取图像添加水印使用pdfplum

C# LiteDB处理时间序列数据的高性能解决方案

《C#LiteDB处理时间序列数据的高性能解决方案》LiteDB作为.NET生态下的轻量级嵌入式NoSQL数据库,一直是时间序列处理的优选方案,本文将为大家大家简单介绍一下LiteDB处理时间序列数... 目录为什么选择LiteDB处理时间序列数据第一章:LiteDB时间序列数据模型设计1.1 核心设计原则

基于Redis自动过期的流处理暂停机制

《基于Redis自动过期的流处理暂停机制》基于Redis自动过期的流处理暂停机制是一种高效、可靠且易于实现的解决方案,防止延时过大的数据影响实时处理自动恢复处理,以避免积压的数据影响实时性,下面就来详... 目录核心思路代码实现1. 初始化Redis连接和键前缀2. 接收数据时检查暂停状态3. 检测到延时过

Java利用@SneakyThrows注解提升异常处理效率详解

《Java利用@SneakyThrows注解提升异常处理效率详解》这篇文章将深度剖析@SneakyThrows的原理,用法,适用场景以及隐藏的陷阱,看看它如何让Java异常处理效率飙升50%,感兴趣的... 目录前言一、检查型异常的“诅咒”:为什么Java开发者讨厌它1.1 检查型异常的痛点1.2 为什么说

Linux系统管理与进程任务管理方式

《Linux系统管理与进程任务管理方式》本文系统讲解Linux管理核心技能,涵盖引导流程、服务控制(Systemd与GRUB2)、进程管理(前台/后台运行、工具使用)、计划任务(at/cron)及常用... 目录引言一、linux系统引导过程与服务控制1.1 系统引导的五个关键阶段1.2 GRUB2的进化优

Python利用PySpark和Kafka实现流处理引擎构建指南

《Python利用PySpark和Kafka实现流处理引擎构建指南》本文将深入解剖基于Python的实时处理黄金组合:Kafka(分布式消息队列)与PySpark(分布式计算引擎)的化学反应,并构建一... 目录引言:数据洪流时代的生存法则第一章 Kafka:数据世界的中央神经系统消息引擎核心设计哲学高吞吐