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 定时调度的例子 ...
随机推荐
- 关于DataX
1. 关于DataX 1.1. 前言 为什么写这篇文章,因为初出茅庐的时候,曾经遇到的一个面试官就是DataX的作者之一,而当时我还偏偏因为业务需求做了个数据库的同步工具,我当时不知道他做过这么专业的 ...
- Sping注解开发
基本注解 @Configuration 作用: 标记在类上表示是一个配置类(相当于一个配置类) @Bean 作用: 在容器中放一个bean相当于xml文件里的bean标签 @Configuration ...
- getsockopt套接口选项
1. getsockopt int getsockopt(int sockfd, int level, int optname, void *optval, socklen_t *optlen); i ...
- C/ C++ 快速上手
C++ 快速上手 (一)https://www.cnblogs.com/cosmo89929/archive/2012/12/22/2828745.html C++ 快速上手 (二)https://w ...
- Python 集合(Set)、字典(Dictionary)
集合(Set) 集合是无序的,无序也就没有索引,不能进行索引相关的操作.无序,python解释器就不能通过索引(位置)区分集合中的相同元素,所以集合中不能有相同的元素. 集合用大括号{ }表示. 集 ...
- 基于TCP协议的大文件传输(粘包问题处理)
基于TCP的大文件上传服务端实现 # 服务端 # -*- coding: utf-8 -*- from socket import * import json, struct server = soc ...
- 启动keepalived报错(VI_1): received an invalid passwd!
一.署keepalived后测试主down掉后无法自动切换到备 查看message日志一直报此错误 [root@lb-nginx-master ~]# tailf /var/log/messages ...
- kuangbin专题专题四 Wormholes POJ - 3259
题目链接:https://vjudge.net/problem/POJ-3259 思路:求有无负环,起点随意选就可以,因为目的只是找出有没有负环,有了负环就可以让时间一直回退,那么一定能回到当初,这里 ...
- 最长上生子序列LIS
学习动态规划问题(DP问题)中,其中有一个知识点叫最长上升子序列(longest increasing subsequence),也可以叫最长非降序子序列,简称LIS.简单说一下自己的心得. 我们都 ...
- Tensorcore使用方法
用于深度学习的自动混合精度 深度神经网络训练传统上依赖IEEE单精度格式,但在混合精度的情况下,可以训练半精度,同时保持单精度网络的精度.这种同时使用单精度和半精度表示的技术称为混合精度技术. 混合 ...