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 定时调度的例子 ...
随机推荐
- 【总结】web工作代码分类整理(持续更新)
文件.blob 文件下载失败,将Blob对象转换为Json,处理异常错误? 使用FileReader,核心代码: var reader = new FileReader() reader.onload ...
- 13 ARM指令集与Thumb指令集
指令格式 ARM基本格式 <opcode>{<cond>}{S}{.W|.N}<Rd>,<Rn>{,<operand2>} opecode: ...
- Mac OS 查看端口和杀死进程
查看sudo lsof -i:port (端口号) sudo lsof -i:9501 COMMAND PID USER FD TYPE DEVICESIZE/OFF NODE NAME php 77 ...
- python中的exec()函数和eval()函数
exec()函数 exec函数用于执行存储在字符串中的python语句 >>> exec("x=1") >>> x 但有时候,直接这样执行可能会 ...
- JVM垃圾收集算法之标记算法
前言 总所周知,jvm的垃圾收集算法一般包括标记.清除.整理三个阶段,最近在看了有关于垃圾收集的标记算法,记录一下自己的理解. 垃圾收集中标记算法有两种:一种是引用计数法,一种是根搜索算法. 引用记数 ...
- JavaFX 井字棋游戏
利用JavaFX设计一个井字棋游戏,其中包括了能够与玩家对战的AI.AI的实现相比五子棋来说要简单得多,可以保证AI在后手情况下绝对不会输,具体实现如下: /* * To change this li ...
- C#和PHP加密结果一致的DES加密解密算法。php实现和c#一致的DES加密解密
DES加密算法 des对称加密,是一种比较传统的加密方式,其加密运算.解密运算使用的是同样的密钥,信息的发送者和信息的接收者在进行信息的传输与处理时,必须共同持有该密码(称为对称密码),是一种对称加密 ...
- Pytorch数据读取详解
原文:http://studyai.com/article/11efc2bf#%E9%87%87%E6%A0%B7%E5%99%A8%20Sampler%20&%20BatchSampler ...
- Jmeter 局域网的IP欺骗终极解决方案
ip欺骗是什么? ip欺骗就是模拟ip.什么意思呢,一个电脑就只有一个ip地址,当然如果有多块网卡的话,会有多个ip地址,一般服务器上有个网卡,咱们自己的电脑一般都只有一个ip地址,但是你做压测 ...
- python应用-输入三个数,输出其最大值
""" 输入三个数,输出其最大值 Author:罗万财 Date:2017-7-6 """ a=int(input('a=')) b=int ...