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

前言

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

 

示例详解

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

 

 

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

 

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

      1. 定时器配置

      1. 引脚配置

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

 

 

    1. 工程代码

 

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

 

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

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

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

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

可以正常仿真:

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

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

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

下载|STM32进阶教程 14

 

关注十三公众号

 

评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值