项目终于完工,准备批量生产。考虑到知识产权的保护,需要对MM32F003程序进行加密保护。如果不做任何处理,就把产品投入市场,万一竞争对手直接抄袭硬件,拷贝程序,那自己辛辛苦苦的劳动成功就只能拱手让人了。
好在MM32F003这颗M0芯片,比起老古董51单片机要强大了许多,自带flash的写、读保护功能。在用户手册flash的章节,可以看到相关的介绍。如果需要在自己的程序里面实现flash区域的读写保护功能,请直接与原厂索要相关资料。反正实现起来比较复杂,我试了两天,放弃了。
另外一个比较简单的方法就是直接使用灵动微官方的MM32-LINK工具,直接配置相应的寄存器,就可以实现flash的读写保护。
具体操作步骤可以查看官方文档《qs_MM32-LINK_V1.1》,我这边只简要说明一下流程和注意事项。
1 配置OPTByte为写保护
运行mm32-link program程序,菜单project->OPTByte...,打开OPTByte configure,如下图:
勾选Address
前面的复选框即开启写保护。
2 配置Block Protect为读保护
菜单project->Block Protect...,打开Block Protect configure,如下图:
勾选Block0
前面的复选框即开启读保护。
3 写入配置
点击program
按钮,见下图:
点击后弹出新的窗口,见下图:
点击program
按钮会完成烧写动作。注意右侧的OPTByte
和Protect
复选框,只有选中时才能写入flash读写保护的配置。
4 注意事项
我就是在这里翻车的,试了好久,有时可以成功配置标志位,有时又不能成功。后来请原厂的Z工帮忙远程操作,才发现原来有一个细节我没有注意到。在主界面的下侧有几个状态指示灯,当芯片的指示灯为红色时,是无法烧写程序的,说明mm32-link与芯片没有建立连接,需要将目标板重新断电再上电,才能正常烧写。
5 验证读写保护
芯片写入读写保护的配置后,使用keil就无法烧写程序了,只有通过mm32-link program工具恢复标志位,才能烧写。
读写保护之后,如果你想通过jflash工具读取目标板的程序,只能读出全FF的文件。通过mm32-link program读出的程序虽然看似有意义,但是某些数据是错误的,重新写入目标板会导致程序工作异常。
6 清除读写保护
使用mm32-link program工具,去掉OPTByte和Block Protect的复选框,重新烧写标志位即可。