01问题的描述
某客户使用 stm32g071 芯片从 standby 模式下唤醒,想要 sram 的数据在退出 standby模式后得以保持。根据手册的描述,配置了相应的比特位,但是发现数据仍然保持不了。
02问题的复现
根据客户的描述,以及 stm32g071 的最新版参考手册 rm0444 发现,在 standby 模式下,可以通过设置 pwr_cr3 的 rrs 比特位去控制 sram 的保持能力,相应的 api 接口函数为hal_pwrex_enablesramretention()、hal_pwrex_disablesramretention() ;
基于例程
......stm32cuberepositorystm32cube_fw_g0_v1.6.1projectsnucleog071rbexamplespwrpwr_standbyewarm
以及相应的 nucleo-g071 开发板,修改部分代码,根据 led4 的闪烁频率去判断从 standby 模式退出后,sarm 里面的数据是否能够保持住。
03问题的排查
基于上述的配置,简单的测试了一下,发现即使 hal_pwrex_enablesramretention() 使能了,但是测试代码中的 sram_magic_word 的值没有保持住,显示的是 led4 的闪烁频率为1s。
究竟是什么原因导致了数据没有保持住呢,再次查看参考手册,确定了只要使能 pwr_cr3的 rrs 比特位即能保持住,对比了 pwr_cr3 的 rrs 比特位的说明,在 standby 模式下,sram 的数据可以保持,但是当退出 standby 模式呢?
由于测试的是从 standby 模式退出,standby 模式退出后会进行 reset,该复位导致了 sram的数据被覆盖或丢失?通过查阅资料,发现是编译器的配置导致的。以 iar 为例,查看其默认的脚本文件 icf;
也就是说,在程序执行的时候,会将 readwrite 的数据进行自动的初始化,而具有.noint 性质的块则不初始化,所以这儿还需要将 sram 里面要保持的数据放置在.noinit 的 section 中。
04问题的解决
知道原因之后,相应的措施也就明朗了,修改 icf 文件如下:
并将想要保持的 sram 中的数据前面加关键字__no_init :
再次下载程序,发现 led4 的闪烁频率跟随 rrs 比特位值的不同而不同,符合预期。另外在实现的过程中,需要说明两点的是:
1、修改 icf 后,可以通过 map 文件查看,应如下文所示,如果发现“p2”mismatch 之类的提示,检查下该 section 中的变量,如上面提到的 sram_magic_word,可能被编译器优化了,在map 中也搜索不到该名称,则可以在实际的代码中使用该变量进行一些运算或判断,然后重新编译即可解决。
2、当调试器连着 iar 调试界面运行的时候,无论 rrs 的值设置为 0 或 1,g071 从standby 模式下退出后,sram 中的内容均可以保持,如果需要验证 rrs 的值的影响,则建议断开调试器,让程序 free-running ,可以通过比如 led 的闪烁频率去判断结果。
小米电动螺丝刀评测 小巧精致轻便实用
Magic UI四子围城,2022折叠屏灵魂觉醒
IDT推出支持5Gbps高速控制器的CrystalFree CMOS振荡器
飞行汽车正式接受预订,895万起售,2020年正式交付!
5大行业痛点直击:如何选购适配的时间服务器?
STM32G071从standby模式退出后的SRAM数据保留
出售Agilent86105C光/电模块
Arm® Cortex®-M0+MCU如何优化通用处理、传感和控制
腾讯发布首款带屏智能音箱
小鹏汽车与大疆孵化的Livox览沃科技达成合作
华米科技是黄汪的第四次创业,他的“黄金赛道”有多长?
单面晶圆减薄和处理研究报告
科大讯飞的AI同传造假行为遭曝光!
如何使用直接阻抗法测量晶振负载谐振频率
物通博联嵌入式数据采集网关采集传感器的数据上传到云端
Qorvo推出两款新的高性能X频段前端模块
建筑能耗分析系统
HT-LH361烟气湿度仪CEMS专用
成为爬虫工程师需要哪些技能
360周鸿祎:马斯克的脑机接口实验相当于打开潘多拉魔盒