5.加读保护:Target---Secure chip,点击是,就是加上了读保护!
验证方法,可以使用一个没有加读保护的芯片,重复步骤中的3,连接上之后,read back一下,看看是否能读出?
然后再使用一个加了读保护的芯片,重复步骤中的3,连接之后,read back一下,看看是不是真的不能读出了,如果成功加了读保护,它会一直停在那里,数据一直读不出来,最后弹出一个错误警告!
到此,读保护已经加载进去了!
可是有的时候,你突然发现你的代码需要更新,如果你不解除读保护功能的话,你将很难再次将程序写入,解除方法也就是步骤中的5项中的反操作:Target---Unsecure chip
解除成功后,你就可以再次写入你更新后的代码了。并没有网友所说的要更改BOOT0和BOOT1的设置,等等。。。 (BOOT0和BOOT1用来改变程序从哪个区运行,本人遇到过把JTAG的RST引脚Remap成GPIO时,禁用JTAG后需要改变BOOT0和BOOT1来进入ISP模式来探险Flash,这里是加入写保护,而非禁用JTAG,故可以不改变BOOT0和BOOT1的设置。不知理解的是否正确)
这个加载代码读保护功能的步骤可能对有些人来说还是比较麻烦的,毕竟产品多的时候,写入之后还要按一下写保护命令,对于产线操作员来说,可能一时疏忽忘记其中一个,就会造成代码的外泄,是不是应该还有更简单的办法一键写入呢,答案是肯定的!
可惜此方法不是我发现的,是我们的项目经理
具体做法,就是要在生成HEX文件之前,要多几个步骤
1.首先,加载: C:\Keil\ARM\Boards\Keil\MCBSTM32\Blinky文件夹中的一个STM32F10xOPT.s文件
2.修改下面两个值为1
3.生成HEX文件之前务必进行一下此配置
这样的话,就简单的一个HEX文件就会使你的产品流入市场之后,即便是被抄板成功,也不会是代码流出了
当然,必须保证自己公司的员工不会外泄。。。
个人之见,如果大家有更好的方法,请指教一下!谢谢 |