灵动微mm32f003通过flash读写保护设置,实现对程序的加密保护

项目终于完工,准备批量生产。考虑到知识产权的保护,需要对MM32F003程序进行加密保护。如果不做任何处理,就把产品投入市场,万一竞争对手直接抄袭硬件,拷贝程序,那自己辛辛苦苦的劳动成功就只能拱手让人了。
好在MM32F003这颗M0芯片,比起老古董51单片机要强大了许多,自带flash的写、读保护功能。在用户手册flash的章节,可以看到相关的介绍。如果需要在自己的程序里面实现flash区域的读写保护功能,请直接与原厂索要相关资料。反正实现起来比较复杂,我试了两天,放弃了。
另外一个比较简单的方法就是直接使用灵动微官方的MM32-LINK工具,直接配置相应的寄存器,就可以实现flash的读写保护。
具体操作步骤可以查看官方文档《qs_MM32-LINK_V1.1》,我这边只简要说明一下流程和注意事项。

1 配置OPTByte为写保护

运行mm32-link program程序,菜单project->OPTByte...,打开OPTByte configure,如下图:


OPTByte configure

勾选Address前面的复选框即开启写保护。

2 配置Block Protect为读保护

菜单project->Block Protect...,打开Block Protect configure,如下图:


Block Protect configure

勾选Block0前面的复选框即开启读保护。

3 写入配置

点击program按钮,见下图:

MM32-LINK Program

点击后弹出新的窗口,见下图:


Program

点击program按钮会完成烧写动作。注意右侧的OPTByteProtect复选框,只有选中时才能写入flash读写保护的配置。

4 注意事项

我就是在这里翻车的,试了好久,有时可以成功配置标志位,有时又不能成功。后来请原厂的Z工帮忙远程操作,才发现原来有一个细节我没有注意到。在主界面的下侧有几个状态指示灯,当芯片的指示灯为红色时,是无法烧写程序的,说明mm32-link与芯片没有建立连接,需要将目标板重新断电再上电,才能正常烧写。


状态栏

5 验证读写保护

芯片写入读写保护的配置后,使用keil就无法烧写程序了,只有通过mm32-link program工具恢复标志位,才能烧写。
读写保护之后,如果你想通过jflash工具读取目标板的程序,只能读出全FF的文件。通过mm32-link program读出的程序虽然看似有意义,但是某些数据是错误的,重新写入目标板会导致程序工作异常。

6 清除读写保护

使用mm32-link program工具,去掉OPTByte和Block Protect的复选框,重新烧写标志位即可。

你可能感兴趣的:(灵动微mm32f003通过flash读写保护设置,实现对程序的加密保护)