所有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的读保护:

/* 设置Flash读保护 */ 
            if (FLASH_GetReadOutProtectionStatus()!=SET) 
            { 
                 /* 会擦除Flash */
                 FLASH_Unlock(); //写保护时可以不用这句话,可用可不用
                 FLASH_ReadOutProtection(ENABLE); 
             }清除flash的读保护:
           /* 清除Flash读保护 */ 
             if (FLASH_GetReadOutProtectionStatus()==SET) 
             { 
                 /* 会擦除Flash */
                 FLASH_Unlock();
                 FLASH_ReadOutProtection(DISABLE); 
                 flash_unlock_timeout=1500;
             }

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

STM32用ID加密程序

下面简单介绍下使用方法。

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

存储stm32芯片的ID号的数组

for(i=0;i<12;i++)
                {
                   sys_id[i]=*(u8*)(0x1FFFF7E8+i);  //读取STM32芯片的唯一ID
               }

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

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

       实际怎么使用还是要看当时情况,也可能用不上这两种方法。