美文网首页
灵动微mm32f003程序加密保护

灵动微mm32f003程序加密保护

作者: 黄开通 | 来源:发表于2020-11-02 16:35 被阅读0次

    项目终于完工,准备批量生产。考虑到知识产权的保护,需要对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程序加密保护

          本文链接:https://www.haomeiwen.com/subject/maumvktx.html