news 2026/4/16 13:38:26

在CH585M代码中如何精细化配置PMU(电源管理单元)和RAM保留

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
在CH585M代码中如何精细化配置PMU(电源管理单元)和RAM保留
在CH585M代码中如何精细化配置PMU(电源管理单元)和RAM保留大小,以适配不同业务场景(如是否需要保留数据)并最大化降低功耗,下面结合硬件特性和可落地的代码,从「原理→核心函数→分场景实现→验证」全流程讲解:

一、先理解CH585M的PMU+RAM保留硬件特性

CH585M的低功耗核心是「PMU下电模式」和「RAM保留分级」的组合,两者直接决定休眠功耗:

PMU模式RAM保留选项休眠功耗(典型值)数据保留特性适用场景
Retention(保留)32K RAM(默认)1.1μA保留全部RAM数据,唤醒后直接使用需要保留大量中间数据
Retention(保留)16K RAM≈0.95μA保留16K RAM数据中等数据保留需求
Retention(保留)8K RAM≈0.8μA仅保留8K RAM数据仅需保留少量配置/计数数据
Deep(深度下电)无RAM保留≈0.5μA所有RAM数据丢失,唤醒后重初始化无需保留数据,追求极致功耗

二、实现精细化配置的核心函数

CH585M的SDK提供了2个核心函数,是精细化配置的基础,先理解参数含义:

1. RAM保留配置函数

voidPMU_RAMRetentionConfig(PMU_RAM_RETENTION_T size);
  • 入参PMU_RAM_RETENTION_T size:可选值如下(SDK枚举定义):
    • PMU_RAM_RETENTION_32K:保留全部32K RAM(默认)
    • PMU_RAM_RETENTION_16K:保留16K RAM
    • PMU_RAM_RETENTION_8K:仅保留8K RAM

2. PMU下电模式配置函数

voidPMU_PowerDownModeCfg(PMU_PWR_DOWN_MODE_T mode,uint32_twakeup_src);
  • 入参1PMU_PWR_DOWN_MODE_T mode
    • PMU_PWR_DOWN_MODE_RETENTION:保留模式(配合RAM保留)
    • PMU_PWR_DOWN_MODE_DEEP:深度下电模式(无RAM保留)
  • 入参2wakeup_src:唤醒源(可组合):
    • PMU_PWR_DOWN_WAKEUP_RTC:RTC周期性唤醒(常用)
    • PMU_PWR_DOWN_WAKEUP_GPIO:GPIO外部中断唤醒
    • 0:仅依赖指定唤醒源(无额外唤醒)

三、分场景实现精细化PMU+RAM保留(可直接复用)

场景1:需保留少量数据(如唤醒计数)→8K RAM + Retention模式

这是最常用的平衡方案,功耗低且保留关键数据,完整代码片段:

#include"CH58x_common.h"// 定义需要保留的全局变量(放入保留RAM区)__attribute__((section(".ram_retention")))uint32_twakeup_count=0;// 唤醒计数,保留在8K RAM中/********************************************************************* * @fn PMU_RAM_Config_MinData * @brief 精细化配置:8K RAM保留 + Retention模式 + RTC唤醒 * @return none ********************************************************************/voidPMU_RAM_Config_MinData(void){// 前置步骤:禁用所有冗余时钟(必做,否则时钟泄漏拉高功耗)RCC_PeriphClockCmd(RCC_PERIPH_ALL,DISABLE);RCC_PeriphClockCmd(RCC_PERIPH_RTC,ENABLE);// 仅保留RTC时钟// 步骤1:配置8K RAM保留(核心精细化点)PMU_RAMRetentionConfig(PMU_RAM_RETENTION_8K);// 步骤2:配置PMU Retention模式,仅RTC唤醒PMU_PowerDownModeCfg(PMU_PWR_DOWN_MODE_RETENTION,PMU_PWR_DOWN_WAKEUP_RTC);// 唤醒计数+1(验证数据是否保留)wakeup_count++;}// 主函数中调用intmain(void){System_Init();while(1){// 业务逻辑:完成后进入精细化低功耗PMU_RAM_Config_MinData();}}

场景2:无需保留任何数据→无RAM保留 + Deep模式

追求极致功耗,唤醒后重新初始化所有外设,代码片段:

/********************************************************************* * @fn PMU_RAM_Config_DeepSleep * @brief 精细化配置:无RAM保留 + Deep模式 + RTC唤醒 * @return none ********************************************************************/voidPMU_RAM_Config_DeepSleep(void){// 前置步骤:禁用所有时钟RCC_PeriphClockCmd(RCC_PERIPH_ALL,DISABLE);RCC_PeriphClockCmd(RCC_PERIPH_RTC,ENABLE);// 步骤1:Deep模式无需配置RAM保留(自动无保留)// 步骤2:配置PMU Deep模式,仅RTC唤醒PMU_PowerDownModeCfg(PMU_PWR_DOWN_MODE_DEEP,PMU_PWR_DOWN_WAKEUP_RTC);}// 主函数中调用(唤醒后需重新初始化外设)intmain(void){while(1){// 唤醒后重新初始化所有外设System_Init();SX1262_Init();W25Q16_Init();// 完成业务后进入深度下电PMU_RAM_Config_DeepSleep();}}

场景3:需保留较多数据→16K/32K RAM + Retention模式

仅在需要保留大量数据时使用(如缓存接收的LoRa数据),代码片段:

/********************************************************************* * @fn PMU_RAM_Config_MoreData * @brief 精细化配置:16K RAM保留 + Retention模式 + RTC+GPIO唤醒 * @return none ********************************************************************/voidPMU_RAM_Config_MoreData(void){// 前置步骤:禁用冗余时钟RCC_PeriphClockCmd(RCC_PERIPH_ALL,DISABLE);RCC_PeriphClockCmd(RCC_PERIPH_RTC,ENABLE);// 步骤1:配置16K RAM保留(按需换32K)PMU_RAMRetentionConfig(PMU_RAM_RETENTION_16K);// 换32K则用PMU_RAM_RETENTION_32K// 步骤2:配置PMU Retention模式,RTC+GPIO双唤醒PMU_PowerDownModeCfg(PMU_PWR_DOWN_MODE_RETENTION,PMU_PWR_DOWN_WAKEUP_RTC|PMU_PWR_DOWN_WAKEUP_GPIO);}

四、关键注意事项(确保配置生效)

  1. 全局变量放入保留RAM区
    若要保留数据,需给变量加__attribute__((section(".ram_retention")))属性,否则即使配置了RAM保留,变量也会丢失(SDK默认仅.ram_retention段保留)。
  2. 禁用冗余时钟是前提
    无论哪种配置,必须先禁用RCC_PERIPH_ALL(除RTC),否则外设时钟泄漏会让功耗比理论值高0.5~1μA。
  3. 唤醒源匹配场景
    • 仅周期性任务:选PMU_PWR_DOWN_WAKEUP_RTC
    • 需紧急响应:加PMU_PWR_DOWN_WAKEUP_GPIO,但会轻微增加漏电(≈0.1μA)。

五、验证配置是否生效

  1. 功耗验证
    • 8K RAM+Retention:CH585M休眠功耗≈0.8μA;
    • Deep模式:≈0.5μA;
    • 若功耗偏高,检查是否漏关时钟/GPIO未设为模拟输入。
  2. 数据保留验证
    打印wakeup_count变量,若每次唤醒后计数递增,说明RAM保留生效;若重置为0,说明配置错误(如变量未加保留属性)。

总结

实现CH585M精细化PMU+RAM保留的核心是:

  1. 按业务需求选最小RAM保留(8K优先,非必要不选16K/32K);
  2. 按需选PMU模式(需保留数据→Retention,无需→Deep);
  3. 配置前必禁冗余时钟(否则功耗优化失效)。

这套配置方式可直接集成到之前的低功耗工程代码中,替换原有简单的PMU配置,进一步压低休眠功耗。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 11:14:50

用Sambert-HifiGan解决客服语音难题:多情感TTS实战

用Sambert-HifiGan解决客服语音难题:多情感TTS实战 引言:当客服系统需要“有情绪”的声音 在智能客服、虚拟助手和自动化外呼等场景中,传统的单一语调语音合成(TTS)系统往往显得机械、冷漠,难以传递真实服务…

作者头像 李华
网站建设 2026/4/16 11:03:43

MelonLoader插件加载器完全指南:从入门到精通

MelonLoader插件加载器完全指南:从入门到精通 【免费下载链接】MelonLoader The Worlds First Universal Mod Loader for Unity Games compatible with both Il2Cpp and Mono 项目地址: https://gitcode.com/gh_mirrors/me/MelonLoader 想要为你的Unity游戏注…

作者头像 李华
网站建设 2026/4/16 12:44:15

招聘季手忙脚乱?这款VIP套餐让HR效率翻倍的秘密

校招旺季、业务扩张等场景下,企业批量招聘时HR常陷入困境:多岗位发布耗时、海量简历手动邀约低效、职位易沉底需反复刷新。招聘需求大的企业HR更是感慨,大多精力都耗费在招聘琐事上。批量招聘的核心痛点是“多岗位、多候选人、高曝光”需求与…

作者头像 李华
网站建设 2026/4/16 11:01:31

从GitHub星标到生产环境:热门开源项目的落地挑战

从GitHub星标到生产环境:热门开源项目的落地挑战 引言:当明星项目遇见真实场景 在AI生成内容(AIGC)领域,Image-to-Video图像转视频生成器自发布以来迅速成为GitHub上的高星项目。其基于I2VGen-XL模型的架构&#xff0c…

作者头像 李华
网站建设 2026/4/16 11:08:57

终极指南:构建不可逆向的安全扫描器代码混淆防护体系

终极指南:构建不可逆向的安全扫描器代码混淆防护体系 【免费下载链接】tsunami-security-scanner Tsunami is a general purpose network security scanner with an extensible plugin system for detecting high severity vulnerabilities with high confidence. …

作者头像 李华
网站建设 2026/4/16 10:13:51

Sambert-HifiGan在公共服务领域的应用:智能语音导览

Sambert-HifiGan在公共服务领域的应用:智能语音导览 引言:让城市服务“会说话”——智能语音导览的现实需求 随着智慧城市建设的不断推进,公共服务的智能化、人性化成为提升市民体验的关键方向。在博物馆、政务大厅、旅游景区、交通枢纽等公共…

作者头像 李华