stm32fl151进入停止模式,配置引脚PB5和PC13唤醒以及RTC定时唤醒,用HAL库函数写代码
时间: 2024-02-19 11:03:03 浏览: 86
好的,下面是使用HAL库函数在STM32F1系列的MCU上实现进入停止模式并配置引脚PB5和PC13唤醒以及RTC定时唤醒的代码:
```c
#include "stm32f1xx_hal.h"
/* RTC全局变量 */
RTC_HandleTypeDef hrtc;
int main(void)
{
/* 初始化 HAL 库 */
HAL_Init();
/* 配置系统时钟 */
SystemClock_Config();
/* 配置引脚 PB5 和 PC13 为唤醒引脚 */
__HAL_RCC_GPIOB_CLK_ENABLE();
__HAL_RCC_GPIOC_CLK_ENABLE();
GPIO_InitTypeDef GPIO_InitStruct = {0};
GPIO_InitStruct.Pin = GPIO_PIN_5;
GPIO_InitStruct.Mode = GPIO_MODE_IT_RISING;
GPIO_InitStruct.Pull = GPIO_NOPULL;
HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
GPIO_InitStruct.Pin = GPIO_PIN_13;
HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
/* 配置 RTC */
/* RTC 时钟源使用 LSE */
__HAL_RCC_RTC_ENABLE();
hrtc.Instance = RTC;
hrtc.Init.AsynchPrediv = 0x7F;
hrtc.Init.SynchPrediv = 0xFF;
hrtc.Init.HourFormat = RTC_HOURFORMAT_24;
hrtc.Init.OutPut = RTC_OUTPUT_DISABLE;
HAL_RTC_Init(&hrtc);
/* 配置 RTC 定时唤醒 */
RTC_TimeTypeDef sTime = {0};
RTC_DateTypeDef sDate = {0};
RTC_AlarmTypeDef sAlarm = {0};
HAL_RTC_GetTime(&hrtc, &sTime, RTC_FORMAT_BIN);
HAL_RTC_GetDate(&hrtc, &sDate, RTC_FORMAT_BIN);
sAlarm.AlarmTime.Hours = sTime.Hours;
sAlarm.AlarmTime.Minutes = sTime.Minutes;
sAlarm.AlarmTime.Seconds = sTime.Seconds + 10;
sAlarm.Alarm = RTC_ALARM_A;
sAlarm.AlarmDateWeekDaySel = RTC_ALARMDATEWEEKDAYSEL_DATE;
sAlarm.AlarmMask = RTC_ALARMMASK_NONE;
sAlarm.AlarmSubSecondMask = RTC_ALARMSUBSECONDMASK_NONE;
HAL_RTC_SetAlarm_IT(&hrtc, &sAlarm, RTC_FORMAT_BIN);
/* 配置进入停止模式的参数 */
/* 停止模式下,所有中断被禁止,唤醒后重新开启中断 */
/* 停止模式下,所有时钟被禁止,唤醒后重新开启时钟 */
/* 停止模式下,所有外设被禁止,唤醒后重新初始化外设 */
/* 注意,进入停止模式后,代码不会继续执行,必须通过唤醒事件重新启动 */
static RCC_ClkInitTypeDef RCC_ClkInitStruct;
static RCC_OscInitTypeDef RCC_OscInitStruct;
RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSI;
RCC_OscInitStruct.HSIState = RCC_HSI_ON;
RCC_OscInitStruct.LSEState = RCC_LSE_ON;
RCC_OscInitStruct.HSEState = RCC_HSE_OFF;
RCC_OscInitStruct.PLL.PLLState = RCC_PLL_NONE;
HAL_RCC_OscConfig(&RCC_OscInitStruct);
RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK | RCC_CLOCKTYPE_SYSCLK
| RCC_CLOCKTYPE_PCLK1 | RCC_CLOCKTYPE_PCLK2;
RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_HSI;
RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV1;
RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1;
HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_0);
/* 进入停止模式 */
HAL_PWREx_EnableWakeUpPin(PWR_WAKEUP_PIN1 | PWR_WAKEUP_PIN2);
HAL_PWR_EnableWakeUpPin(PWR_WAKEUP_PIN1);
HAL_RTCEx_DeactivateWakeUpTimer(&hrtc);
HAL_RTCEx_SetWakeUpTimer_IT(&hrtc, 10, RTC_WAKEUPCLOCK_CK_SPRE_16BITS);
HAL_PWR_EnterSTOPMode(PWR_LOWPOWERREGULATOR_ON, PWR_STOPENTRY_WFI);
/* 在这里执行唤醒后的代码 */
while (1)
{
/* 循环执行 */
}
}
/* RTC 定时唤醒中断处理函数 */
void HAL_RTC_AlarmAEventCallback(RTC_HandleTypeDef *hrtc)
{
/* 在这里执行 RTC 定时唤醒后的代码 */
}
```
需要注意的是,在进入停止模式后,代码不会继续执行,必须通过唤醒事件重新启动。因此,如果需要在唤醒后进行一些操作,需要在 `while (1)` 中编写相应的代码。另外,需要在 `HAL_RTC_AlarmAEventCallback` 中编写 RTC 定时唤醒后的代码。
阅读全文