STM32L0进入低功耗模式使用USART1
Entering Low Power Mode on STM32L0 to use USART1
我想使用尽可能少的功率以大约 300 波特率读取 USART1。 40 个字节。还有许多其他外围设备,但它们不需要 运行- 所有需要 运行ning 的是并行的 RTC。外设要冷冻,ram要一样
我的看法 低功耗 运行 模式是最佳模式(如果我在这里错了,请纠正我):
void HAL_PWREx_EnableLowPowerRunMode(void)
{
/* Enters the Low Power Run mode */
SET_BIT(PWR->CR, PWR_CR_LPSDSR);
SET_BIT(PWR->CR, PWR_CR_LPRUN);
}
现在时钟配置是
- 系统时钟源 = PLL (HSI)
- SYSCLK(Hz) = 32000000
- HCLK(Hz) = 32000000
- AHB 预分频器 = 1
- APB1 预分频器 = 1
- APB2 预分频器 = 1
- 恒指频率(Hz) = 16000000
- PLLMUL = 6
- PLLDIV = 3
- 闪存延迟 (WS) = 1
- 电源调节器电压 = SCALE 1
如何进入此模式并从中恢复?
// Init?
HAL_PWREx_EnableLowPowerRunMode();
HAL_PWREx_DisableLowPowerRunMode();
// Deinit?
我的初始化尝试,我在这里遗漏了什么?
void init_clock(){
RCC_OscInitTypeDef RCC_OscInitStruct;
RCC_ClkInitTypeDef RCC_ClkInitStruct;
RCC_PeriphCLKInitTypeDef PeriphClkInit;
/**Initializes the CPU, AHB and APB busses clocks
*/
RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
|RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2;
RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_MSI;
RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV1;
RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1;
if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_0) != HAL_OK)
{
Error_Handler();
}
/**Configure the main internal regulator output voltage
*/
__HAL_PWR_VOLTAGESCALING_CONFIG(PWR_REGULATOR_VOLTAGE_SCALE2);
/**Initializes the CPU, AHB and APB busses clocks
*/
RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSI|RCC_OSCILLATORTYPE_MSI;
RCC_OscInitStruct.HSIState = RCC_HSI_DIV4;
RCC_OscInitStruct.HSICalibrationValue = 16;
RCC_OscInitStruct.MSIState = RCC_MSI_ON;
RCC_OscInitStruct.MSICalibrationValue = 0;
RCC_OscInitStruct.MSIClockRange = RCC_MSIRANGE_0;
RCC_OscInitStruct.PLL.PLLState = RCC_PLL_NONE;
if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)
{
Error_Handler();
}
PeriphClkInit.PeriphClockSelection = RCC_PERIPHCLK_USART1;
PeriphClkInit.Usart1ClockSelection = RCC_USART1CLKSOURCE_SYSCLK;
if (HAL_RCCEx_PeriphCLKConfig(&PeriphClkInit) != HAL_OK)
{
Error_Handler();
}
}
- Deinit = 与时钟配置的初始初始化相同
USART1可以在停止模式下接收一个字节,也可以唤醒。
实现低功耗的步骤是对USART1 使用LSE 并从RXNE 的停止模式中唤醒。
UART_WakeUpTypeDef wakeup;
wakeup.WakeUpEvent=UART_WAKEUP_ON_READDATA_NONEMPTY;
HAL_UARTEx_StopModeWakeUpSourceConfig(&huart1,wakeup);
HAL_UARTEx_EnableStopMode(&huart1);
这比具有 DMA 和低功耗睡眠的 BAM 更简单,即使不更好也等于。
我想使用尽可能少的功率以大约 300 波特率读取 USART1。 40 个字节。还有许多其他外围设备,但它们不需要 运行- 所有需要 运行ning 的是并行的 RTC。外设要冷冻,ram要一样
我的看法 低功耗 运行 模式是最佳模式(如果我在这里错了,请纠正我):
void HAL_PWREx_EnableLowPowerRunMode(void)
{
/* Enters the Low Power Run mode */
SET_BIT(PWR->CR, PWR_CR_LPSDSR);
SET_BIT(PWR->CR, PWR_CR_LPRUN);
}
现在时钟配置是
- 系统时钟源 = PLL (HSI)
- SYSCLK(Hz) = 32000000
- HCLK(Hz) = 32000000
- AHB 预分频器 = 1
- APB1 预分频器 = 1
- APB2 预分频器 = 1
- 恒指频率(Hz) = 16000000
- PLLMUL = 6
- PLLDIV = 3
- 闪存延迟 (WS) = 1
- 电源调节器电压 = SCALE 1
如何进入此模式并从中恢复?
// Init?
HAL_PWREx_EnableLowPowerRunMode();
HAL_PWREx_DisableLowPowerRunMode();
// Deinit?
我的初始化尝试,我在这里遗漏了什么?
void init_clock(){
RCC_OscInitTypeDef RCC_OscInitStruct;
RCC_ClkInitTypeDef RCC_ClkInitStruct;
RCC_PeriphCLKInitTypeDef PeriphClkInit;
/**Initializes the CPU, AHB and APB busses clocks
*/
RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
|RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2;
RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_MSI;
RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV1;
RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1;
if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_0) != HAL_OK)
{
Error_Handler();
}
/**Configure the main internal regulator output voltage
*/
__HAL_PWR_VOLTAGESCALING_CONFIG(PWR_REGULATOR_VOLTAGE_SCALE2);
/**Initializes the CPU, AHB and APB busses clocks
*/
RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSI|RCC_OSCILLATORTYPE_MSI;
RCC_OscInitStruct.HSIState = RCC_HSI_DIV4;
RCC_OscInitStruct.HSICalibrationValue = 16;
RCC_OscInitStruct.MSIState = RCC_MSI_ON;
RCC_OscInitStruct.MSICalibrationValue = 0;
RCC_OscInitStruct.MSIClockRange = RCC_MSIRANGE_0;
RCC_OscInitStruct.PLL.PLLState = RCC_PLL_NONE;
if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)
{
Error_Handler();
}
PeriphClkInit.PeriphClockSelection = RCC_PERIPHCLK_USART1;
PeriphClkInit.Usart1ClockSelection = RCC_USART1CLKSOURCE_SYSCLK;
if (HAL_RCCEx_PeriphCLKConfig(&PeriphClkInit) != HAL_OK)
{
Error_Handler();
}
}
- Deinit = 与时钟配置的初始初始化相同
USART1可以在停止模式下接收一个字节,也可以唤醒。
实现低功耗的步骤是对USART1 使用LSE 并从RXNE 的停止模式中唤醒。
UART_WakeUpTypeDef wakeup;
wakeup.WakeUpEvent=UART_WAKEUP_ON_READDATA_NONEMPTY;
HAL_UARTEx_StopModeWakeUpSourceConfig(&huart1,wakeup);
HAL_UARTEx_EnableStopMode(&huart1);
这比具有 DMA 和低功耗睡眠的 BAM 更简单,即使不更好也等于。