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

//---------------------------------------------------------------------------
#include
#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功能。
由于算法由用户自己把握,自由发挥,可最大限度保护用户的代码
  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值