你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

STM32程序加密

[复制链接]
STMCU小助手 发布时间:2023-1-7 11:58
所有STM32的芯片都提供对Flash的保护,防止对Flash的非法访问 - 写保护和读保护。读保护即大家通常说的“加密”,是作用于整个Flash存储区域。一旦设置了Flash的读保护,内置的Flash存储区只能通过程序的正常执行才能读出,而不能通过这两种方式中的任何一种方式读出:通过调试器(JTAG或SWD)和从RAM中启动并执行的程序。我们这里程序加密的目的是防止板子中的程序被其他人读出使用,这里有两种方法可供使用:

       1.禁止读出Flash存储器内容;
       2.STM32用ID加密程序;

这里我们分别对这两种方法进行介绍。

一.禁止读出Flash存储器内容

       这种方法主要是防止程序被读出,正如文章开头所说,一旦设置了Flash的读保护,内置的Flash存储区只能通过程序的正常执行才能读出,而不能通过这两种方式中的任何一种方式读出:通过调试器(JTAG或SWD)和从RAM中启动并执行的程序。这是也无法对flash进行烧写程序了,所以使用时需要谨慎。下面简单介绍下使用方法。

       1.在程序中包含#include "stm32f10x_flash.h"头文件 并在这条语句前面加入 这一行话:#define _FLASH_PROG;   //flash读写保护时需要加入的


       2.实现flash的读保护:

  1.            /* 设置Flash读保护 */
  2.            if (FLASH_GetReadOutProtectionStatus()!=SET)
  3.            {
  4.                 /* 会擦除Flash */
  5.                 FLASH_Unlock(); //写保护时可以不用这句话,可用可不用
  6.                 FLASH_ReadOutProtection(ENABLE);
  7.             }
复制代码

       3.清除flash的读保护:
  1.            /* 清除Flash读保护 */
  2.             if (FLASH_GetReadOutProtectionStatus()==SET)
  3.             {
  4.                 /* 会擦除Flash */
  5.                 FLASH_Unlock();
  6.                 FLASH_ReadOutProtection(DISABLE);
  7.                 flash_unlock_timeout=1500;
  8.             }
复制代码

       主要就是以上三步,具体如何在程序中使用,看自己的需求。


二.STM32用ID加密程序

        每个STM32芯片都有一个全球唯一的ID,这个唯一码可以利用作软件加密,ID号是12个字节大小共96位,ID号的起始地址是0x0x1FFFF7E8。利用这个ID码程序在运行时比较ID码是否正确来判断是否往下执行程序。下面简单介绍下使用方法。

        1.读取目标板子的ID号,并修改程序将ID号保存在程序中:

  1.               U8 sys_id[12]={0};  //存储stm32芯片的ID号的数组


  2.                for(i=0;i<12;i++)
  3.                {
  4.                   sys_id=*(u8*)(0x1FFFF7E8+i);  //读取STM32芯片的唯一ID
  5.               }
复制代码

        2.将修改后的程序再下载到目标板子上这时就可以使用上面读出ID来对比当前板子上ID是否一致来确定程序是否执行。

       这个方法就算程序被其他人读取也无法在其他板子上运行,因为ID不一致。麻烦的地方是每块板子的程序的ID不一样造成程序维护麻烦。

       实际怎么使用还是要看当时情况,也可能用不上这两种方法。
————————————————
版权声明:阿木zhang

收藏 评论0 发布时间:2023-1-7 11:58

举报

0个回答

所属标签

相似分享

官网相关资源

关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32N6 AI生态系统
STM32MCU,MPU高性能GUI
ST ACEPACK电源模块
意法半导体生物传感器
STM32Cube扩展软件包
关注我们
st-img 微信公众号
st-img 手机版