【玩转STM32】:串口唤醒低功耗的三种方式/低功耗下打印数据

在使用STM32做低功耗项目时,大概率会遇到一个问题:低功耗模式下想打印数据怎么办?

今天,学长给大家另辟蹊径,介绍一种使用串口唤醒低功耗的案例、方法。可设置三种唤醒方式:检测到起始位唤醒、检测到 RXNE 标志唤醒(即接收到数据)、检测到匹配地址时唤醒。

应用在低功耗项目上可实现在低功耗模式下也能打印调试数据,可谓低功耗调试神器。

1 串口唤醒低功耗介绍

1.1 唤醒源

关于低功耗,学长在这里就不单独做介绍了,改天单独开篇做低功耗相关的介绍,只需要知道低功耗模式总共有三种,按功耗由高到低分别为睡眠、停止、待机模式。

先抛出结论,USART和LPUART都可将STM32 MCU从低功耗模式唤醒,不同系列的MCU USART和LPUART 可唤醒的低功耗模式有差别,如下图所示:

大家先明白STM32有不同的USART/LPUART唤醒源可用于将MCU从低功耗模式唤醒:

  • 1、通过USART/LPUART_CR3寄存器的WUS位字段选择的特定事件。

    • 00:在地址匹配时唤醒(按照USART/LPUART_CR2寄存器的ADD[7:0]和ADDM7的定义)
    • 01:保留
    • 10:检测到Start位时唤醒
    • 11:在每次接收到数据时唤醒(即USART/LPUART_ISR寄存器中RXNE置位)

当唤醒事件得到验证时,通过硬件将USART/LPUART_ISR寄存器中的WUF标志置位,无论MCU处于低功耗模式还是运行模式。如果USART/LPUART_CR3寄存器中的相应中断使能位( WUFIE)置位,它将生成唤醒中断。

  • 2、RXNE中断

在进入低功耗模式前,必须通过USART/LPUART_CR1寄存器中的RXNEIE位置位来使能RXNE中断。

1.2 唤醒方式

根据上门说到的低功耗模式唤醒源可知,串口有三种唤醒方式可以将STM32从低功耗模式唤醒:

  • 检测到起始位唤醒。
  • 检测到 RXNE 标志唤醒,即接收到数据。
  • 检测到匹配地址时唤醒。

匹配地址支持 7bit 和 4bit 匹配两种方式,比如我们采用 7bit 匹配, 设置地址是 0x19,那么用户唤醒的时候要将最高 bit 设置为 1, 即发送地址 0x99( 0b1001 1001)才可以唤醒。

如果STM32 MCU处于低功耗模式且用作USART/LPUART内核时钟的HSI时钟关闭,当在USART/LPUART接收线路上检测到下降沿时,USART/LPUART接口请求重新开启HSI时钟。然后,将使用HSI时钟进行帧接收。

如果唤醒事件得到验证,将从低功耗模式唤醒MCU并进行正常的数据接收。

唤醒成功时的时序效果如下:

如果唤醒事件未得到验证, HSI时钟将重新关闭, MCU不唤醒并维持低功耗模式,内核时钟请求被释放。

唤醒失败时的时序效果:

注: tWUUSART或tWULPUART是唤醒时间参数

1.3 USART 与 LPUART 比较

LPUART 比 USART 特性更少,但可用更低功耗工作,并可更有效地使用 LSE 时钟。两种外设的主要特性总结如下:

本文只讲述通过USART唤醒低功耗模式,LPUART唤醒低功耗模式的方法类似,但在低功耗模式下功能更为强大,本文暂不展开,后面开篇做详细介绍

2 USART唤醒低功耗流程

2.1 时钟设置

串口初始化的流程与正常串口的一致,唯一差别是串口唤醒低功耗时需要将串口的时钟设置为LSE 或者 HSI 时钟,其他的初始化流程不变。

以设置HSI为串口时钟为例:

  /* 公众号:轻松学长 */
  /*# Enable the HSI clock  #*/
  RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSI;
  RCC_OscInitStruct.HSIState = RCC_HSI_ON;
  RCC_OscInitStruct.HSICalibrationValue = RCC_HSICALIBRATION_DEFAULT;
  RCC_OscInitStruct.PLL.PLLState = RCC_PLL_NONE;
  if (HAL_RCC_OscConfig(&RCC_OscInitStruct)!= HAL_OK)
  {
    /* Error */
    while(1); 
  }
  
  /*# Configure HSI as USART clock source #*/
  USARTx_RCC_CONFIG(RCC_USARTxCLKSOURCE_HSI);
  
  /* Select HSI as wakeup clock from stop mode */
  __HAL_RCC_WAKEUPSTOP_CLK_CONFIG(RCC_STOP_WAKEUPCLOCK_HSI);

2.2 进入低功耗模式前配置

选择合适的唤醒方式,在STM32进入低功耗前,进行相应配置,三种唤醒方式的配置案例代码如下:

  • 接收到数据唤醒
  /* 公众号:轻松学长 */
  /* make sure that no UART transfer is on-going */ 
  while(__HAL_UART_GET_FLAG(&UartHandle, USART_ISR_BUSY) == SET);
  /* make sure that UART is ready to receive
   * (test carried out again later in HAL_UARTEx_StopModeWakeUpSourceConfig) */
  while(__HAL_UART_GET_FLAG(&UartHandle, USART_ISR_REACK) == RESET);

  /* set the wake-up event:
   * specify wake-up on RXNE flag */
  WakeUpSelection.WakeUpEvent = UART_WAKEUP_ON_READDATA_NONEMPTY;
  if (HAL_UARTEx_StopModeWakeUpSourceConfig(&UartHandle, WakeUpSelection)!= HAL_OK)
  {
    Error_Handler(); 
  }
 
  /* Enable the UART Wake UP from STOP1 mode Interrupt */
  __HAL_UART_ENABLE_IT(&UartHandle, UART_IT_WUF);
  • 检测到起始位唤醒
  /* 公众号:轻松学长 */
  /* make sure that no UART transfer is on-going */ 
  while(__HAL_UART_GET_FLAG(&UartHandle, USART_ISR_BUSY) == SET);
  /* make sure that UART is ready to receive 
   * (test carried out again later in HAL_UARTEx_StopModeWakeUpSourceConfig) */
  while(__HAL_UART_GET_FLAG(&UartHandle, USART_ISR_REACK) == RESET);
  
  /* set the wake-up event:
   * specify wake-up on start-bit detection */
  WakeUpSelection.WakeUpEvent = UART_WAKEUP_ON_STARTBIT;
  if (HAL_UARTEx_StopModeWakeUpSourceConfig(&UartHandle, WakeUpSelection)!= HAL_OK)
  {
    Error_Handler();
  }

  /* Enable the UART Wake UP from STOP1 mode Interrupt */
  __HAL_UART_ENABLE_IT(&UartHandle, UART_IT_WUF);
  • 检测到匹配地址唤醒
/* 公众号:轻松学长 */
/* make sure that no UART transfer is on-going */ 
  while(__HAL_UART_GET_FLAG(&UartHandle, USART_ISR_BUSY) == SET);
  /* make sure that UART is ready to receive
   * (test carried out again later in HAL_UARTEx_StopModeWakeUpSourceConfig) */
  while(__HAL_UART_GET_FLAG(&UartHandle, USART_ISR_REACK) == RESET);
     
  /* set the wake-up event:  
   * specify address-to-match type. 
   * The address is 0x29, meaning the character triggering the 
   * address match is 0xA9 */
  WakeUpSelection.WakeUpEvent = UART_WAKEUP_ON_ADDRESS;
  WakeUpSelection.AddressLength = UART_ADDRESS_DETECT_7B;
  WakeUpSelection.Address = 0x29;  
  if (HAL_UARTEx_StopModeWakeUpSourceConfig(&UartHandle, WakeUpSelection)!= HAL_OK)
  {
    Error_Handler(); 
  }

  /* Enable the UART Wake UP from stop mode Interrupt */
  __HAL_UART_ENABLE_IT(&UartHandle, UART_IT_WUF);

2.3 退出低功耗之后配置

退出低功耗之后,调用这个函数就可以啦。

/* 公众号:轻松学长 */
HAL_UARTEx_DisableStopMode(&UartHandle);

就这么简单三个步骤,就可实现串口唤醒低功耗模式,可谓知者不难,难者不知。

更多关于STM32串口唤醒低功耗资料及参考代码,可公众号后台回复 串口唤醒 获取资料及源码

我是轻松学长,仰望星空,脚踏实地,做一个有趣有料的技术人。

我的公众号:

我的视频号:

1设计要求 要求系统按如下方式进入和退出睡眠模式: 在系统启动2秒后,将RTC在3秒钟之后配置为产生一个报警事件,接着通过WFI指令使系统进入停机模式。 如果要唤醒系统到正常模式,可通过按Key按钮;否则,在3秒钟后,会产生RTC报警中断自动将系统唤醒。 一旦退出停机模式,系统时钟被配置成先前的状态(在停机模式下,外部高速振荡器HSE和PLL是不可用的)。 经过一段延时之后,系统将再次进入停机状态,并可按上述操作无限重复。 2 硬件电路设计 硬件电路采用与7.1小节应用实例一样硬件电路,可见图7-10。其中Key按钮用于通过PB9产生一个外部中断, LED1、LED2、LED3、LED4则用于显示处理器所处的模式和中断触发情况。 3 软件程序设计 根据任务要求,程序内容主要包括: (1) 配置GPIOB口,配置RTC,配置外部中断; (2) 配置PB口第9个引脚作为外部中断,下降延触发;配置RTC报警中断,上升沿触发; (3) 两个中断服务子程序的内容分别是:切换LED2和LED3灯的状态; 整个工程包含3个源文件:STM32F10x.s、stm32f10x_it.c和main.c,其中STM32F10x.s为启动代码,所有中断 服务子程序均在stm32f10x_it.c中,其它函数则在main.c中。下面分别介绍相关的函数,具体程序清单见参考程序。 函数SYSCLKConfig_STOP用于当处理器从停机模式唤醒之后,配置系统时钟、使能HSE和PLL,并以PLL作为系统时钟源。当处理器处理停机模式的时候,HSE、PLL是不可用的。 函数GPIO_Configuration用于配置GPIO的PC6、PC7、PC8、PC9和PB9。 函数EXTI_Configuration用于配置外部中断线9(PB9)和17(RTC报警)。 函数NVIC_Configuration配置NVIC及中断向量表,这里主要是配置外部中断线9和17。 函数EXTI9_5_IRQHandler处理按钮Key(PB9)所触发的中断,其主要作用是将LED2灯的状态翻转一次。 函数RTCAlarm_IRQHandler处理RTC报警所触发的中断,其主要作用事将LED3 灯的状态翻转一次,如果设置了唤醒标志则清除之。 运行过程: (1) 使用Keil uVision3 通过ULINK 2仿真器连接EduKit-M3实验平台,打开实验例程目录PWR_TEST子目录下的PWR.Uv2 例程,编译链接工程; (2) 选择软件调试模式,点击MDK 的Debug菜单,选择Start/Stop Debug Session项或Ctrl+F5键,在逻 辑分析仪中添加GPIOC_ODR.6、GPIOC_ODR.7、GPIOC_ODR.8、GPIOC_ODR.9,点击Run按钮即可在逻辑分析 仪中看到如图7-14,还可用Peripherals-General Port-GPIOB来模拟KEY按钮的动作; (3) 选择硬件调试模式,选择Start/Stop Debug Session项或Ctrl+F5键,下载程序并运行,观察LED灯 的变化情况。注意,当目标系统进入停机模式之后,将无法使用仿真器进行调试了; (4) 退出Debug模式,打开Flash菜单>Download,将程序下载到EduKit-M3实验平台的Flash中,按RESET键复位,观察 LED灯的情况,正常情况应为:系统处于运行模式时LED1亮、LED4灭;系统处于停机状态时LED1灭、LED4亮; 当按下KEY按钮时LED2灯状态发生反转;当发生RTC报警时LED3状态发生反转。
### 回答1: stm32l051低功耗串口是一款针对低功耗应用场景而设计的串口芯片。相比于传统的串口芯片,其在功耗控制、性能优化等方面有着显著的优势。 在功耗控制方面,stm32l051低功耗串口采用了独特的低功耗设计方案,能够在工作状态和待机状态之间快速切换,以实现更加高效的功耗控制。同时,其还集成了多种省电技术,例如低功耗时钟、低功耗微控制器模式等,使得设备在脱机状态下的能耗得到大幅降低。 在性能优化方面,stm32l051低功耗串口支持多种串行通信协议,例如UART、SPI、I2C、LIN等,同时支持数据包、多主机、帧同步等多种特性。其还支持数据缓存、DMA传输等高效的数据传输方式,在串行数据传输的过程中能够提高通信速率与通信质量,避免了串口传输时出现的一些问题。 总之,stm32l051低功耗串口是一款性能强劲,功耗低、稳定可靠的串口芯片,广泛应用于各种低功耗设备中。 ### 回答2: STM32L051是一款低功耗的微控制器,其特性包括丰富的外设和强大的处理能力,同时也是一款非常注重功耗管理的单片机。其中,低功耗串口是这款微控制器的一项特色。 低功耗串口是一种以最小化能耗为目的的串口传输方式。它通过将对串口唤醒信号最小化,降低串口传输过程中的能耗。在STM32L051中,低功耗串口的实现采用了多种技术,如自动处理、片上缓冲等,旨在将传输时的电流消耗最小化。 在一般的串口传输过程中,不断的串口空闲时段会导致功率的浪费。而低功耗串口则可以在传输结束后,很快进入睡眠模式,等到下一次传输开始时再次唤醒。这样就保证了整个传输过程中的最小功耗。 另外,STM32L051低功耗串口也支持多种传输模式。它可以通过自适应低功耗模式实现自动切换和自主处理。通过使用DMA传输数据,更进一步提高了传输的效率和稳定性,同时也能使股支持它的应用程序更加高效。 综上所述,STM32L051的低功耗串口是一种专门针对低功耗应用而开发的串口传输方式。其通过多种技术手段和特殊设计,能够实现最小化的功耗消耗,使得整个传输过程更加高效和稳定。 ### 回答3: STM32L051是一款高性能、低功耗的微控制器芯片,可广泛应用于智能家居、工业自动化、机器人等领域。该芯片的低功耗串口是其特有的一项功能,可以有效减少芯片的能耗,节省电力资源。 低功耗串口采用异步串行通信协议,能够实现数据的传输。在传输数据时,芯片可以进入低功耗模式,从而有效降低功耗。此外,该串口还支持自动唤醒功能,能够在特定条件下自动唤醒芯片,提高工作效率。 在使用STM32L051的低功耗串口时,需要根据实际应用场景进行配置。用户可以设置波特率、奇偶校验等参数,满足不同需求。同时,为了避免数据丢失或干扰,用户还需要采用合适的数据传输方式,如单线半双工模式或双线全双工模式等。 综上所述,STM32L051的低功耗串口功能是其具有竞争力的一项特性。通过合理配置和使用,该功能可以大大降低芯片的功耗,提高系统效率,为用户提供优质的使用体验。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值