YTM32的片内flash应用答疑 - 释疑efm_sts[accerr]寄存器位
文章目录
- YTM32的片内flash应用答疑 - 释疑efm_sts[accerr]寄存器位
- 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]
寄存器位的描述如下:
实际上,在具体的应用场景中,当在执行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
- 这个sector存储的是芯片生产制造相关的数据,其中第8个NVR sector地址段是
-
执行块擦除(
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]
寄存器置位,软件可以试着再重新执行一次或者多次操作(或者稍微等一下再操作),可以大幅减少这种小概率事件。