Mstar 平台(648)唤醒之串口唤醒
串口唤醒功能主要是从supernova 待机进入PM后,串口接收PC端口发送过来的特定字串,然后将主板唤醒的功能。与IR,KEYPAD,WOL,CEC,MHL 等等基本流程一致,触发源不一样而已。
待机前设置待机参数
pstPMCfg->stPMWakeCfg.bPmWakeEnableIR = TRUE;
pstPMCfg->stPMWakeCfg.bPmWakeEnableSAR = TRUE;
pstPMCfg->stPMWakeCfg.bPmWakeEnableGPIO0 = FALSE;
pstPMCfg->stPMWakeCfg.bPmWakeEnableGPIO1 = FALSE;
pstPMCfg->stPMWakeCfg.bPmWakeEnableUART1 = TRUE;
bPmWakeEnableUART1 设置为FALSE,开启该口的唤醒功能,然后EnterSleepMode里面设置到PM里面
vendor\mstar\supernova\projects\msrv\control\src\MSrv_Control_common.cpp mapi_interface::Get_mapi_system()->PowerDown(&stPMCfg,bTrigger);
PM 开启相关参数
开启PM_WK_UART_EN
vendor\mstar\pm\zenonia\Project\Mstar\Source\Configurations\cusProj_config.h //-----Uart Wakeup---
#ifndef PM_WK_UART_EN
#define PM_WK_UART_EN 1
#endif
开启串口,设置串口波特率
vendor\mstar\pm\zenonia\Project\Mstar\Source\Configurations\cusProj_config.h
vendor\mstar\pm\zenonia\Project\Source\cus_config.h #define UART1_BAUDRATE 19200//38400//9600//38400
#define ENABLE_UART0 ENABLE
开启UART0 口,并设置串口波特率为19200(平台目前不支持115200)
设置UART口的寄存器CLK
vendor\mstar\pm\zenonia\Project\Source\customer.c
void Cus_Sys_ChangeUartForPllClk(U32 u32Mcu_Clk)
{
// Change MCU clock --> Change UART baud rate
#if ENABLE_UART0
ADCON |= 0x80;
S0RELL = (UART_CLKREL(u32Mcu_Clk, UART0_BAUDRATE) & 0xff);
S0RELH = ((UART_CLKREL(u32Mcu_Clk, UART0_BAUDRATE) >> ) & 0x3);
S0CON = 0x50;
PCON |= 0x80;
//S0BUF = (char)"*";
TI0=;
#endif #if ENABLE_UART1
S1RELL = (UART1_CLKREL(u32Mcu_Clk, UART1_BAUDRATE) & 0xff);
S1RELH = ((UART1_CLKREL(u32Mcu_Clk, UART1_BAUDRATE) >> ) & 0x3);
S1CON = 0x90; // mode 1, 8-bit UART, enable receive
S1CON |= BIT1;
#endif #if PM_WK_UART_EN
S1RELL = (UART_CLKREL(u32Mcu_Clk, UART1_BAUDRATE) & 0xff);
S1RELH = ((UART_CLKREL(u32Mcu_Clk, UART1_BAUDRATE) >> ) & 0x3);
S1CON = 0xd0;
PCON |= 0x80;
S1CON |= BIT1;
#endif
}
Cus_Sys_ChangeUartForPllClk 里面设置串口clk,配置好S1CON,PCON 否则后面无法获取到唤醒的字串。
设置唤醒字串
vendor\mstar\pm\zenonia\Project\Mstar\Source\CusProj_Inf.h
#if PM_WK_UART_EN
#define UART_WAKEUP_COMMAND "mstar"
#define UART_RECEIVED_TIMEOUT 0xFFFF
#endif
UART_WAKEUP_COMMAND 设置唤醒字串。
循环监听
BOOLEAN CusProj_InfUart1Polling(void)
{
U8 u8UartWakeupCmd[] = { };
U32 u32UartRxCount = ;
U32 u32UartRxTimeout = ; if(strlen(UART_WAKEUP_COMMAND) == )
return TRUE; while((u32UartRxTimeout < UART_RECEIVED_TIMEOUT) && (u32UartRxCount < strlen(UART_WAKEUP_COMMAND)))
{
//WriteByte(0x0EEC, ReadByte(0x0EEC)&(~BIT1));//swtich gpio_pm[5] to 51's uart_rx1 and gpio_pm[1] to 51's uart_tx1
//WriteByte(0x0EEC, ReadByte(0x0EEC)|(BIT0));//swtich gpio_pm[5] to 51's uart_rx1 and gpio_pm[1] to 51's uart_tx1
if (S1CON & BIT0) // UART1 have received a ascii data
{
//printf("S1BUF = 0x%x\n", S1BUF);
u8UartWakeupCmd[u32UartRxCount++] = S1BUF; if(u32UartRxCount == strlen(UART_WAKEUP_COMMAND))
{
if (strcmp(u8UartWakeupCmd, UART_WAKEUP_COMMAND) == )
{
u32UartRxCount = ;
return TRUE;
}
else
{
S1CON &= ~BIT0; // clear received flag
return FALSE;
}
} S1CON &= ~BIT0; // clear received flag
}
u32UartRxTimeout++;
} if (u32UartRxTimeout >= u32UartRxTimeout)
{
u32UartRxCount = ;
memset(u8UartWakeupCmd, , );
u32UartRxTimeout = ;
} return FALSE;
} void CusProj_InfUart1Isr(void)
{
if( Read2Byte(0x0F0A) & BIT8 ) //gpio_pm_5_fiq_final_status
{
if(CusProj_InfUart1Polling() == TRUE)
{
WriteByte(0x0E6B, (ReadByte(0x0E6B)&(~BIT1)));// disable swtich gpio_pm[5] to HK51's uart_rx1 and gpio_pm[1] to HK51's uart_tx1 MDrv_PM_PowerUp(PM_WKUP_UART); WriteByte(0x0F0A, (ReadByte(0x0F0A))|(BIT6)); //clear PAD_GPIO_PM5
WriteByte(0x0F0A, (ReadByte(0x0F0A))&(~BIT6)); WriteByte(0x0F0A, ReadByte(0x0F0A)&(~BIT7)); //gpio_pm_5_fiq_pol
WriteByte(0x0F0A, ReadByte(0x0F0A)|(BIT4)); //mask gpio_pm_5_fiq_mask
WriteByte(0x0F0A, ReadByte(0x0F0A)& ~(BIT0));// gpio_pm[5] is output enable
while();
}
else
{
WriteByte(0x0F0A, (ReadByte(0x0F0A))|(BIT6)); //clear PAD_GPIO_PM5
WriteByte(0x0F0A, (ReadByte(0x0F0A))&(~BIT6));
}
}
}
CusProj_InfUart1Polling 中通过S1BUF不停读取字串,与唤醒字串匹配后,就开是唤醒
唤醒
MDrv_PM_PowerUp(PM_WKUP_UART); INTERFACE void MDrv_PM_PowerUp(PM_WkupSrc eWkupSrc); PM 唤醒源如下:
typedef enum
{
PM_WKUP_NONE = , ///No wakeup event happens
PM_WKUP_IR = , ///Wakeup event IR
PM_WKUP_DVI = , ///Wakeup event DVI
PM_WKUP_DVI2 = , ///Wakeup event DVI2
PM_WKUP_CEC = , ///Wakeup event CEC
PM_WKUP_SAR = , ///Wakeup event SAR
PM_WKUP_ESYNC = , ///Wakeup event ESYNC
PM_WKUP_SYNC = , ///Wakeup event SYNC
PM_WKUP_RTC = , ///Wakeup event RTC
PM_WKUP_RTC2 = , ///Wakeup event RTC2
PM_WKUP_AVLINK = ,///Wakeup event AVLINK
PM_WKUP_UART = , ///Wakeup event UART
PM_WKUP_GPIO = , ///Wakeup event GPIO
PM_WKUP_MHL = , ///Wakeup event MHL
PM_WKUP_WOL = ///Wakeup event WOL
//13~15: reserved
} PM_WkupSrc;
通过PM_WKUP_UART 事件唤醒。
Mstar 平台(648)唤醒之串口唤醒的更多相关文章
- mstar 平台I2C 配置
		芯片的pin 脚可以用作不同的功能,总结一句就是外设进行状态和数据交换. 最常用的是作为GPIO,设置为输出模式时,通过高低电平来控制一些外围设置:// 如LED,屏的电源,背光的开关,功放的静音等等 ... 
- Android:Mstar平台 HDMI OUT 静音流程
		一.framework层 1. APP调用 AudioManager 的 adjustStreamVolume() 接口实现在: frameworks\base\services\core\java\ ... 
- MSTAR 平台
		MApp_Menu.c ZUI_exefunc.h //菜单属性 MApp_ZUI_APItables.h #define GETWNDINFO(hwnd) (&g_GUI_WindowLis ... 
- android 休眠唤醒机制分析(三) — suspend
		本文转自:http://blog.csdn.net/g_salamander/article/details/7988340 前面我们分析了休眠的第一个阶段即浅度休眠,现在我们继续看休眠的第二个阶段 ... 
- 【原创】STM32低功耗模式及中断唤醒(基于BMI160及RTC)的研究
		预研目标 六轴静止时,终端进入低功耗模式:六轴震动时,终端正常工作模式,从而极大减少非工作时的电流消耗. 解决方案 机器静止时,依据六轴算法,CPU进入休眠(停止)模式:机器工作时,触发六轴中断唤醒C ... 
- 【工业串口和网络软件通讯平台(SuperIO)教程】八.SuperIO通讯机制与设备驱动对接的说明
		SuperIO相关资料下载:http://pan.baidu.com/s/1pJ7lZWf 1.1 通讯机制说明 通讯的总体机制采用呼叫应答方式,就是上位机软件主动发送请求数据命令,下位机终端接 ... 
- Java多线程系列--“基础篇”05之 线程等待与唤醒
		概要 本章,会对线程等待/唤醒方法进行介绍.涉及到的内容包括:1. wait(), notify(), notifyAll()等方法介绍2. wait()和notify()3. wait(long t ... 
- java多线程系类:基础篇:05线程的等待与唤醒
		概要 本章,会对线程等待/唤醒方法进行介绍.涉及到的内容包括:1. wait(), notify(), notifyAll()等方法介绍2. wait()和notify()3. wait(long t ... 
- java 多线程—— 线程等待与唤醒
		java 多线程 目录: Java 多线程——基础知识 Java 多线程 —— synchronized关键字 java 多线程——一个定时调度的例子 java 多线程——quartz 定时调度的例子 ... 
随机推荐
- java.lang.UnsatisfiedLinkError: dlopen failed: library "/system/lib/libjni_i
			出错log:java.lang.UnsatisfiedLinkError: dlopen failed: library "/system/lib/libskytvjni.so" ... 
- 使用composer命令加载vendor中的第三方类库
			1.首先下载需要的第三方类库,放在TP框架下的vendor文件夹下 2.给第三方类库SDK写上命名空间,命名空间为该类库的文件夹对应的名字 3.在composer.json文件中添加需要加载的第三方类 ... 
- 生产环境OOM\死锁问题排查修复
			OOM: 1.快速恢复业务:如果是集群中的一台机器故障,先隔离故障服务器:如果是多台,则根据Nginx转发策略,对该功能转发到单独的集群,与其他流量隔离,确保其他业务不受影响 2.收集内存溢出Dump ... 
- idea导入mybatis源码
			1.最近在学mybatis,想下载源码导入idea结果网上一查没有一篇完整的,结果让我进了个大坑,算了,废话少说 2.两种办法,一个是git客户端克隆,另外一个是下载code压缩包.先说通过git客户 ... 
- eclipse 小提示
			1.模糊提示插件 Code Recommenders alt+/ 模糊提示插件 Code Recommenders 
- Httpd服务入门知识-Httpd服务常见配置案例之设定默认字符集
			Httpd服务入门知识-Httpd服务常见配置案例之设定默认字符集 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.查看生产环境中使用的字符集案例 1>.查看腾讯设置的默认 ... 
- Httpd服务入门知识-Httpd服务常见配置案例之DSO( Dynamic Shared Object)加载动态模块配置
			Httpd服务入门知识-Httpd服务常见配置案例之DSO( Dynamic Shared Object)加载动态模块配置 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.加载动 ... 
- TKey SSO 单点登录系统介绍
			Introduction TKey = Token Key 以 OAuth 2.0 标准为接口设计原则的单点登录系统(SSO) 初衷: 做国内各种登录场景的配件,以完善的学习资料为主核心竞争力 纯粹的 ... 
- 性能测试基础---LR场景设置
			·场景设置. 性能测试场景依托于性能测试脚本,但是又独立于脚本. 所谓场景(scenario),就是用来模拟多用户运行性能测试脚本的情形,是来源于我们对于业务场景的分析的. 性能测试对于业务场景的分析 ... 
- Spring Cloud Config 知识点
			Spring Cloud Config项目是一个解决分布式系统的配置管理方案.它包含了Client和Server两个部分,server提供配置文件的存储.以接口的形式将配置文件的内容提供出去,clie ... 
