前言
在嵌入式应用开发中,应用开发完成后往往需要对芯片中的程序进行加密处理,用以保护程序安全(不至被竞争对手从芯片把程序固件考走),本节将给大学介绍一个如何实现程序自动给芯片加密功能。学完本节内容,你也可以开发不容易初别人破解的程序了。
示例详解
基于硬件平台: STM32F10C8T6最小系统板, MCU 的型号是 STM32F103c8t6, 使用stm32cubemx 工具自动产生的配置工程,使用KEIL5编译代码。
本示例所用的最小系统板原理图:
-
-
关于CUBEMX工具及KEIL工具的操作将不再细讲,如果还有不熟悉的可以查看之前的教程文档。下面直接介绍工程配置:
- 系统时钟树
-
-
- 定时器配置
-
-
- 引脚配置
-
-
- 中断配置(保持默认)
-
- 工程代码
-
-
- 在main.c中加入如下代码
-
- 编译工程无错误后,下载程序,程序正常运行,LED灯正常闪烁(500ms交替亮灭),但是无法仿真了,说明flash读保护成功!!
用JFLASH配合JLINK工具来看看能否从芯片中读取固件,连接上MCU后按下图所示操作进行芯片固件读取(当然也可以用该工具对芯片进行加密):
提示读取失败,说明加密代码功能OK,起到保护芯片固件的作用。
接下来我们再回去看看不加密时的表现:
可以正常仿真:
也可以顺利从芯片中读取出固件:
OK,本期实验完成!下期见!同时如果大家有什么疑问或是有想了解的其它内容,也欢迎大家留言!!最后喜欢这个公众号的同学们记得加关注了,会有不定期技术干货推出!!
文中源码资料下载,在公众号里给十三发消息:
下载|STM32进阶教程 14
关注十三公众号