zoukankan      html  css  js  c++  java
  • 利用STM32F唯一96bit序列号实现反拷贝加密的源代码公开(转)

    源:利用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功能。
    由于算法由用户自己把握,自由发挥,可最大限度保护用户的代码

  • 相关阅读:
    select 1 from ... sql语句中的1代表什么意思?
    装饰者模式
    Dao层抽取BaseDao公共方法
    DBUtils工具类
    java Page分页显示
    QTP
    Gym 100513F Ilya Muromets(前缀和)
    AcWing1165 单词环(01分数规划)
    AcWing904 虫洞(spfa判负环)
    AcWing1148 秘密的奶牛运输(次小生成树)
  • 原文地址:https://www.cnblogs.com/LittleTiger/p/4597438.html
Copyright © 2011-2022 走看看