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中数据清洗与处理的常用方法

《一文详解Python中数据清洗与处理的常用方法》在数据处理与分析过程中,缺失值、重复值、异常值等问题是常见的挑战,本文总结了多种数据清洗与处理方法,文中的示例代码简洁易懂,有需要的小伙伴可以参考下... 目录缺失值处理重复值处理异常值处理数据类型转换文本清洗数据分组统计数据分箱数据标准化在数据处理与分析过

mysql外键创建不成功/失效如何处理

《mysql外键创建不成功/失效如何处理》文章介绍了在MySQL5.5.40版本中,创建带有外键约束的`stu`和`grade`表时遇到的问题,发现`grade`表的`id`字段没有随着`studen... 当前mysql版本:SELECT VERSION();结果为:5.5.40。在复习mysql外键约

Go语言使用Buffer实现高性能处理字节和字符

《Go语言使用Buffer实现高性能处理字节和字符》在Go中,bytes.Buffer是一个非常高效的类型,用于处理字节数据的读写操作,本文将详细介绍一下如何使用Buffer实现高性能处理字节和... 目录1. bytes.Buffer 的基本用法1.1. 创建和初始化 Buffer1.2. 使用 Writ

Python视频处理库VidGear使用小结

《Python视频处理库VidGear使用小结》VidGear是一个高性能的Python视频处理库,本文主要介绍了Python视频处理库VidGear使用小结,文中通过示例代码介绍的非常详细,对大家的... 目录一、VidGear的安装二、VidGear的主要功能三、VidGear的使用示例四、VidGea

Python结合requests和Cheerio处理网页内容的操作步骤

《Python结合requests和Cheerio处理网页内容的操作步骤》Python因其简洁明了的语法和强大的库支持,成为了编写爬虫程序的首选语言之一,requests库是Python中用于发送HT... 目录一、前言二、环境搭建三、requests库的基本使用四、Cheerio库的基本使用五、结合req

使用Python处理CSV和Excel文件的操作方法

《使用Python处理CSV和Excel文件的操作方法》在数据分析、自动化和日常开发中,CSV和Excel文件是非常常见的数据存储格式,ython提供了强大的工具来读取、编辑和保存这两种文件,满足从基... 目录1. CSV 文件概述和处理方法1.1 CSV 文件格式的基本介绍1.2 使用 python 内

python多进程实现数据共享的示例代码

《python多进程实现数据共享的示例代码》本文介绍了Python中多进程实现数据共享的方法,包括使用multiprocessing模块和manager模块这两种方法,具有一定的参考价值,感兴趣的可以... 目录背景进程、进程创建进程间通信 进程间共享数据共享list实践背景 安卓ui自动化框架,使用的是

如何使用celery进行异步处理和定时任务(django)

《如何使用celery进行异步处理和定时任务(django)》文章介绍了Celery的基本概念、安装方法、如何使用Celery进行异步任务处理以及如何设置定时任务,通过Celery,可以在Web应用中... 目录一、celery的作用二、安装celery三、使用celery 异步执行任务四、使用celery

SpringBoot操作spark处理hdfs文件的操作方法

《SpringBoot操作spark处理hdfs文件的操作方法》本文介绍了如何使用SpringBoot操作Spark处理HDFS文件,包括导入依赖、配置Spark信息、编写Controller和Ser... 目录SpringBoot操作spark处理hdfs文件1、导入依赖2、配置spark信息3、cont

C#如何优雅地取消进程的执行之Cancellation详解

《C#如何优雅地取消进程的执行之Cancellation详解》本文介绍了.NET框架中的取消协作模型,包括CancellationToken的使用、取消请求的发送和接收、以及如何处理取消事件... 目录概述与取消线程相关的类型代码举例操作取消vs对象取消监听并响应取消请求轮询监听通过回调注册进行监听使用Wa