- Introduction
- Concept
- Conclusion
Introduction
之前有客户在基于ytm32b1le05
微控制器做ota
方案,其中在擦写片内flash模块时,需要对操作的有效性进行判定,涉及到多efm_sts[accerr]
寄存器位的理解。这里对efm_sts[accerr]
寄存器的功能进行详细解释。
Concept
efm_sts[accerr]
寄存器位可用于告知用户efm模块目前的工作状态是否正常。通常在用户使用efm模块擦写片内flash后,用于验证擦写命令是否运行成功。若当由于操作不当导致擦写操作失败后,efm硬件将通过这个标志位反馈给用户。
在RM手册中,对efm_sts[accerr]
寄存器位的描述如下:
图x EFM_STS[ACCERR]寄存器
实际上,在具体的应用场景中,当在执行efm命令的过程中(通过执行efm_cmd命令擦写片内flash)置位efm_sts[accerr]
寄存器,可以排查如下要点:
- 执行EFM Command 没有遵循以下流程:
- step 1: AHB write target address
- step 2: write
EFM_CMD_UNLOCK
register with0xFD95_73F5
- step 3: write
EFM_CMD
register with correct command code
- EFM 在执行命令时(
efm_sts[idle]=0
),AHB 总线访问了 flash - EFM 在执行命令时(
efm_sts[idle]=0
),重复发命令 - 写到
EFM_CMD
寄存器的命令码不正确(只能是8‘h2
,8'h16
,8h18
) - 128KB flash 存储器分成
64
个2 KB
的区间,每个区间用EFM_PROT1[31:0]:EFM_PROT0[31:0]
的一个 bit 保护。
- 如果寄存器
EFM_PROT*[n]=1'b0
, 对应的 2 KB flash sector 就是只读的, 擦和写这个sector的区域,将会置位efm_sts[accerr]
寄存器 - 如果寄存器
EFM_PROT1[31:0]:EFM_PROT0[31:0] } != 64'hffffffff_ffffffff
,执行擦除块命令(BLOCK_ERASE
),将会置位efm_sts[accerr]
寄存器
- 擦除或写入第8个NVR sector的存储区
- 这个sector存储的是芯片生产制造相关的数据,其中第8个NVR sector地址段是
0x1000_0E00 ~ 0x1000_0FFF
- 执行块擦除(
BLOCK_ERASE
)的操作流程中,AHB write target address 这一步的目标地址不在有效区间0x0000_0000 ~ 0x0001_FFFF
- 擦除了
OTP_NVR
的区域0x1000_0800 ~ 0x1000_09FF
Conclusion
使用efm模块擦写片内flash的操作同常规访问寄存器控制电路不同,涉及存放程序本身的介质,需要对MCU芯片的特性有比较深入的了解才好把控。建议:
- 使用SDK提供的驱动,或者基于SDK的驱动进行精简。
- 把操作flash的程序放在ram里执行,特别是执行flash命令的关键部分的操作,避免操作flash的同时访问flash的情况。在c源码中使用预编译宏修饰相关函数的 定义 和 声明 的同时,还要注意在 linker file 中有所体现。
- 在软件层面做好验证参数有效性的操作,不要过于依赖硬件的机制。软件相对更容易定位和调试,而尽量让操作硬件的部分简明扼要。
- 若是因为操作时序导致的
efm_sts[accerr]
寄存器置位,软件可以试着再重新执行一次或者多次操作(或者稍微等一下再操作),可以大幅减少这种小概率事件。
作者:安德鲁苏
来源:安德鲁的设计笔记本
推荐阅读
欢迎大家点赞留言,更多Arm技术文章动态请关注极术社区嵌入式客栈专栏欢迎添加极术小姐姐微信(id:aijishu20)加入技术交流群,请备注研究方向。