如何解决Flash被保护后的程序下载问题
-
目前没有专门针对每款芯片做示例,操作的方式是原理都是一样的,可以直接参考这个示例做。
-
houjun_xiao 请问,打开这个工程报如下错误怎么解决

-
Erase_CUSNVR.zip你试一试,这个是基于SDK 1.4.0的
-
houjun_xiao 好的,可以打开了,但HA01的 EFM_Type 没有 NVR_ADDR ,
代码里的 EFM->NVR_ADDR = 0x10000400U; 要怎么替换

-
直接对目的地址赋值即可,例如*((uint32_t *))0x10000400)=0;
需要注意HA0的FLASH存在WE控制位,在赋值前先将CTRL寄存器中的WE位置1

-
按照示例在RAM中调用接口对CUS_NVR擦除成功后,还是没办法对芯片擦写,JLink提示擦除失败。


有什么其他需要注意的地方吗? -
擦除NVR中的protect配置数据后,需要Reset MCU才能生效。
-
houjun_xiao 有个问题就是,软件上电之后会执行写保护的动作,就算之后在RAM中擦除了NVR,复位之后是不是也会被重新写保护?
-
擦除NVR后,Protect的配置数据就被清除了,所以Reset之后不会再有写保护,升级完程序后,如果想恢复写保护,就需要重写NVR。
-
houjun_xiao Project是指CUS_NVR的配置,还是用户代码的配置?
-
EFM写保护功能可以通过两种方式配置:1.通过CUS_NVR中合法的值在MCU初始化阶段即完成写保护写保护寄存器设置,2.若CUS_NVR中无合法的值,则可通过代码设置EFM写保护寄存器,从而配置写保护功能。需要注意,这个寄存器在代码中只能由1改写为0,不能由0改写为1, 该寄存器中某位的值为0时,该为位对应的区域被写保护。

-
houjun_xiao 对使用的方法没有疑问,有疑问的点是如何解除写保护,比如我在初始化时候 EFM->ADDR_PROT[0] = 0;
EFM->ADDR_PROT[1] = 0; EFM->ADDR_PROT[2] = 0;即写保护了全部Flash地址,这个时候没办法重新用JLink烧写软件了,使用示例的代码生成的Hex用JLink下载到RAM,然后在RAM去擦除CUS_NVR,这个时候擦除的只是NVR的数据吧,那么复位之后,初始化的时候是不是还是会重新写保护? -
如果你时代码设置的写保护,擦除CUS_NVR是没有用的。这种情况你如果想通过JLink下载程序,只能Attach到MCU,然后Reset,然后在执行EFM->ADDR_PROT[0] = 0;
EFM->ADDR_PROT[1] = 0; EFM->ADDR_PROT[2] = 0前打断点,此时可以下载。 -
houjun_xiao 好的,了解了多谢
快速上手云途开发生态
发帖前请查看
帮助改进和优化YT CONFIG TOOL,有机会抽取YTM32B1ME0 EVB哦...