如何实现STM8的程序加密?可以使用其RC校验码吗

如何实现STM8的程序加密?可以使用其RC校验码吗,第1张

stm8具有唯一id,可以利用这个id做程序加密

例如

#define ID_ENCRYPT_EOR_RESULT_ADDRESS (0x9ff0)

#define ID_ENCRYPT_ADD_RESULT_ADDRESS (0x9ff4)

void Stm8s103EncryptDemo(void)

{

      uint32 *u16IdAddress

uint16 u32EorRslt, u16AddRslt

   

      //千万别显式的读取ID,即要把0x4865运算成隐式的,例如此碧拆前例中0x4865 = (0x1194 * 4) + 0x215

      //这样,别人就算破解出了你的程序,也查找不到0x4865,这样就不能轻易的软解密,这样处理后如果要软解密,

      //一定要反汇编出来进行复杂逆向分析,难度极大,代价极高,很难搞定软加密了,达到保护产品的目的。

      gU16IdAdressVar = 0x1194

      gU16IdAdressVar <<= 2

      u16IdAddress = (uint16*)(gU16IdAdressVar + 0x215)//0x4865

 

      //读取单片机的ID,并进行运算,具体算法可以自己定,这里只用到简单的异或及和运算

      u16EorRslt = (*u16IdAddress) ^ (*(u16IdAddress + 1)) ^ (*(u16IdAddress + 2))

      u16AddRslt = (*u16IdAddress) + (*(u16IdAddress + 1)) + (*(u16IdAddress + 2))

      //进行对比,如果运算结果与FLASH保存的结果不一样,说明非法,运行错误代码

      if(u16EorRslt != *((uint16*)ID_ENCRYPT_EOR_RESULT_ADDRESS))

      {

              while(1)//异或算法结果不正确,进行错误分支

      }

      if(u16AddRslt != *((uint32*)ID_ENCRYPT_ADD_RESULT_ADDRESS))

      {

              while(1)//和算法结果不正确,进御穗行错误分支

     悔清 }

}

1,如果板子上有外部存储器,可以先编写一个程序,利用算法把id计算得到一些值存入外部存储器,然后再烧写真正的程序,真正的程序去校验外部存储器的数据是否合法即可

2,利用板子上按键组合,或是上电按住某些键,程序在这个时候利用算法把id计算得到一些值存入程序区(stm8为EE区),程序运行时去验证程序区数据是否正确

3,轩微编程器有软件加密的功能,编程器会读芯片id,根据算法直接改写缓冲区,达到软件加密的作用

4,读出的id通过一定算法,例如异或加上一个数,得到的数据存入flash(只运行一次,运行后标志位也存入flash),下次读到这个标志位,就不运行这个程序

IAR for STM8 v2.20.2破解版

http://www.ddooo.com/softdown/94457.htm

1、下载IAR for STM8安装文件,点击安装包即可进入准备安装(解压)纤晌冲过程,如下图所示:

2、选择第二项:“Install IAR Embedded

Workbench”选项

3、进入安装向导界面,点击“next”按钮

4、同意IAR for

STM8的软件安装条款

5、选择安装路径,默认安装目录为:C:\Program Files

(x86)\IAR Systems\Embedded Workbench 7.3

6、勾选需要安装调试的驱动(默认安装即可),点击“Next”

7、选择安装程序文件夹(默认),点击“Next”

8、提示(安装路径、驱动等)是否准备好安装,确认没有问题,点击“Install”开始安装

9、安装过程中,会提示安装驱动,点击“是”

10、等待驱动安装完毕,点击“Finish”,软件安装完成,点击“Exit”,退出安装向导界面,如下图所示:

11、打开上面安装好的IAR for

STM8软件(没有创建桌面快捷方式,可以从开始菜单打开软件)。 点击Help ->License

Manager进入许可管理,如下图所示:

12、打开许可管理会d出如下“许可向导”,点击“取消”毁歼。

13、使用离线激活方式:License ->

Offline Activation进入离线激活界面

14、打开注册机:选择IAR类型,生产许可码,复制许可码,如下图所示:

15、将上面获取的注册码复制并粘贴到“离线激活界面”界面中,点击“下谨告一步”

16、选择“NO”不锁定,点击“下一步”

17、保存激活信息“ActivationInfo.txt”在安装目录下,点击“下一步”

默认安装路径为:C:\Program

Files (x86)\IAR Systems\Embedded Workbench 7.3

18、请求激活信息文件,点击“下一步”,进入浏览“注册码”界面(备用)

19、下面,暂时切换到前面打开的注册机,在注册机上打开ActivationInfo.txt

20、生成“ActivationResponse.txt”文件,同样保存在软件安装目录下

21、回到软件注册界面,打开上一步生成的“ActivationResponse.txt”的文件,点击“下一步”

22、点击“Done”,注册完成

23、查看注册状态(出现以下信息说明注册成功)


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/12556350.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-26
下一篇 2023-05-26

发表评论

登录后才能评论

评论列表(0条)

保存