STM32单片机-加密烧录Hex

本内容介绍单片机加密Hex烧录,包括专用烧录器加密烧录、J-Link加密烧录以及通过mcuisp或FlyMcu加密烧录。紫色文字是超链接,点击自动跳转至相关博文。持续更新,原创不易!

目录:
一、专用烧录器加密烧录Hex
1、使用ST官方的下载器
2、其他公司烧录器
二、J-Link加密烧录Hex
1、简述
2、与J-Link相关的设置
3、烧写文件载入与连接目标
三、通过mcuisp或FlyMcu加密烧录Hex
-----------------------------------------------------------------------------------------------------------------
一、专用烧录器加密烧录Hex
1、使用ST官方的下载器

STM32单片机-加密烧录Hex_第1张图片

-----------------------------------------------------------
2、其他公司烧录器

STM32单片机-加密烧录Hex_第2张图片

 

STM32单片机-加密烧录Hex_第3张图片

-----------------------------------------------------------------------------------------------------------------
二、J-Link加密烧录Hex
1、简述
本处以烧写STM32F103VET6说明,软件:Flasher_Windows_V722a(百度网盘搜索文件名或移步https://download.csdn.net/download/liht_1634/85077430),实际测试J-Flash V4.90版亦可行。
-----------------------------------------------------------
2、与J-Link相关的设置

STM32单片机-加密烧录Hex_第4张图片

 

STM32单片机-加密烧录Hex_第5张图片

若硬件无异常,但一直无法连接上单片机,可降低此处的两个SWD speed的值。

STM32单片机-加密烧录Hex_第6张图片

 

STM32单片机-加密烧录Hex_第7张图片

加密芯片后通过Keil的SWD将不能下载程序。
-----------------------------------------------------------
3、烧写文件载入与连接目标

STM32单片机-加密烧录Hex_第8张图片

STM32单片机-加密烧录Hex_第9张图片

STM32单片机-加密烧录Hex_第10张图片

STM32单片机-加密烧录Hex_第11张图片

J-Flash 7.22a版本成功下载

STM32单片机-加密烧录Hex_第12张图片

J-Flash 4.90版本成功下载
-----------------------------------------------------------------------------------------------------------------
三、通过mcuisp或FlyMcu加密烧录Hex

STM32单片机-加密烧录Hex_第13张图片

 

STM32单片机-加密烧录Hex_第14张图片

 

STM32单片机-加密烧录Hex_第15张图片

mcuisp或FlyMcu调用开放的API加密程序。
STM32F系列的MCU提供了号称全球唯一ID的96位序列号。从官方文档RM0008文档里我们看到其主要应用于以下几个方面:
1)用来作为序列号(终端应用或出厂标识记录);
2)用来作为密码,在编写闪存时,将此唯一标识与软件加解密算法结合使用,提高代码在闪存存储器内的安全性;
3)用来激活带安全机制的自举过程;
一个简单的读取例程:
static Int32U CpuID[3];
void GetCpuID(void)
{
          CpuID[0]=*(Int32U*)(0x1ffff7e8);
          CpuID[1]=*(Int32U*)(0x1ffff7ec);
          CpuID[2]=*(Int32U*)(0x1ffff7f0);
}
利用STM32F唯一96bit序列号实现反拷贝加密的源代码:
//---------------------------------------------------------------------------
#include "windows.h"
#pragma argsused
BOOL WINAPI DllMain(HINSTANCE hinstDLL, DWORD fwdreason, LPVOID lpvReserved)
{
          return 1;
}
//---------------------------------------------------------------------------
//本示例代码用BCB5编写,很容易移植到VC++等编译环境
//导出函数mcuisp_AntiCopy,mcuisp.exe将调用mcuisp_AntiCopy函数来实现反拷贝功能
extern "C" __declspec(dllexport) int __stdcall mcuisp_AntiCopy(
          unsigned char *buf,         //FLASH内容存储缓冲
          DWORD buflen,               //FLASH代码长度(字节)
          DWORD startaddress,         //FLASH的地址偏移,STM32F一般为0x08000000
          unsigned char const *inbuf, //前12字节为96bit的芯片序列号
          DWORD inputbuflen           //序列号信息的长度
          );
//--
int __stdcall mcuisp_AntiCopy(
          unsigned char *buf,         //FLASH内容存储缓冲
          DWORD buflen,               //FLASH代码长度(字节)
          DWORD startaddress,         //FLASH的地址偏移,STM32F一般为0x08000000
          unsigned char const *inbuf, //前12字节为96bit的芯片序列号
          DWORD inputbuflen           //序列号信息的长度
          )
{
  //mcuisp_AntiCopy根据FLASH内容和芯片序列号,经过运算后,修改FLASH内容
  //本例中,简单的把序列号拷贝到0x08010000的位置
  //可以在STM32的代码中比对0x08010000和0x1ffff7e8的内容,相符才正常运行
  //实际应用中,可以采取比较复杂的算法
  memcpy(buf+0x10000,inbuf,12);
  return 0;
};
上述DLL与mcuisp配合,即可实现STM32F AntiCopy功能。由于算法由用户自己把握,自由发挥,可最大限度保护用户的代码。
-----------------------------------------------------------------------------------------------------------------

你可能感兴趣的:(单片机,PLC,PLD,单片机,stm32,加密烧录Hex)