STM32 进阶教程 14 - 程序加密之FLASH读写保护

前言

在嵌入式应用开发中,应用开发完成后往往需要对芯片中的程序进行加密处理,用以保护程序安全(不至被竞争对手从芯片把程序固件考走),本节将给大学介绍一个如何实现程序自动给芯片加密功能。学完本节内容,你也可以开发不容易初别人破解的程序了。

 

示例详解

基于硬件平台: STM32F10C8T6最小系统板, MCU 的型号是 STM32F103c8t6, 使用stm32cubemx 工具自动产生的配置工程,使用KEIL5编译代码。

 

STM32 进阶教程 14 - 程序加密之FLASH读写保护_第1张图片

 

本示例所用的最小系统板原理图:

STM32 进阶教程 14 - 程序加密之FLASH读写保护_第2张图片

 

    1. 关于CUBEMX工具及KEIL工具的操作将不再细讲,如果还有不熟悉的可以查看之前的教程文档。下面直接介绍工程配置:
      1. 系统时钟树

STM32 进阶教程 14 - 程序加密之FLASH读写保护_第3张图片

      1. 定时器配置

STM32 进阶教程 14 - 程序加密之FLASH读写保护_第4张图片

      1. 引脚配置

STM32 进阶教程 14 - 程序加密之FLASH读写保护_第5张图片

STM32 进阶教程 14 - 程序加密之FLASH读写保护_第6张图片

      1. 中断配置(保持默认)

STM32 进阶教程 14 - 程序加密之FLASH读写保护_第7张图片

 

 

    1. 工程代码

 

      1. 在main.c中加入如下代码

STM32 进阶教程 14 - 程序加密之FLASH读写保护_第8张图片

STM32 进阶教程 14 - 程序加密之FLASH读写保护_第9张图片

 

    1. 编译工程无错误后,下载程序,程序正常运行,LED灯正常闪烁(500ms交替亮灭),但是无法仿真了,说明flash读保护成功!!

STM32 进阶教程 14 - 程序加密之FLASH读写保护_第10张图片

用JFLASH配合JLINK工具来看看能否从芯片中读取固件,连接上MCU后按下图所示操作进行芯片固件读取(当然也可以用该工具对芯片进行加密):

STM32 进阶教程 14 - 程序加密之FLASH读写保护_第11张图片

提示读取失败,说明加密代码功能OK,起到保护芯片固件的作用。

STM32 进阶教程 14 - 程序加密之FLASH读写保护_第12张图片

接下来我们再回去看看不加密时的表现:

STM32 进阶教程 14 - 程序加密之FLASH读写保护_第13张图片

可以正常仿真:

STM32 进阶教程 14 - 程序加密之FLASH读写保护_第14张图片

也可以顺利从芯片中读取出固件:

STM32 进阶教程 14 - 程序加密之FLASH读写保护_第15张图片

STM32 进阶教程 14 - 程序加密之FLASH读写保护_第16张图片

OK,本期实验完成!下期见!同时如果大家有什么疑问或是有想了解的其它内容,也欢迎大家留言!!最后喜欢这个公众号的同学们记得加关注了,会有不定期技术干货推出!!

文中源码资料下载,在公众号里给十三发消息:

下载|STM32进阶教程 14

STM32 进阶教程 14 - 程序加密之FLASH读写保护_第17张图片

 

关注十三公众号

 

你可能感兴趣的:(STM32,MCU加密,固件加密)