打印

利用STM32F唯一96bit序列号实现反拷贝加密的源代码公开

[复制链接]
5283|1
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
mcuisp|  楼主 | 2009-9-27 22:36 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
本帖最后由 mcuisp 于 2009-9-27 22:39 编辑

//---------------------------------------------------------------------------
#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功能。
由于算法由用户自己把握,自由发挥,可最大限度保护用户的代码。
沙发
bhsdlmj| | 2009-9-28 08:16 | 只看该作者
:victory:

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

个人签名:www.mcuisp.com 免费STM32 ISP软件 EP968手持烧录器,现场升级/生产线量产STM32,STM8S/L,FreeScale,LPC2000,LPC9xx,C8051F,AVR,PIC......

340

主题

4985

帖子

22

粉丝