如何实现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),下次读到这个标志位,就不运行这个程序

简单的啊。思路:8个LED接在一个口,如P1口。再将另外两个LED接在另外某个口(如P2)的两个引脚。然后将两个按键分别接在空闲的口的两个引脚。

按下一个按键,使8个LED的输出状态变化,0xFE循环移位实现,LED低电平亮。另外的按键按下,两个LED状态翻转。

不是可以直接调用库文件吗?

TIM1_DeInit();

//设置死区时间10/16=06us

TIM1_BDTRConfig(TIM1_OSSISTATE_ENABLE,TIM1_LOCKLEVEL_OFF,10,TIM1_BREAK_DISABLE,

TIM1_BREAKPOLARITY_LOW,TIM1_AUTOMATICOUTPUT_DISABLE);

//设置PWM频率10K

TIM1_TimeBaseInit(0, TIM1_COUNTERMODE_UP, 10016, 0); //100us 10K

//PWM极性设置相同,则输出为互补,否则为同步信号。

TIM1_OC1Init(TIM1_OCMODE_PWM1, TIM1_OUTPUTSTATE_DISABLE, TIM1_OUTPUTNSTATE_DISABLE,

PulseWidth, TIM1_OCPOLARITY_HIGH, TIM1_OCNPOLARITY_HIGH,

TIM1_OCIDLESTATE_RESET, TIM1_OCNIDLESTATE_RESET);

TIM1_OC2Init(TIM1_OCMODE_PWM1, TIM1_OUTPUTSTATE_DISABLE, TIM1_OUTPUTNSTATE_DISABLE,

PulseWidth, TIM1_OCPOLARITY_HIGH, TIM1_OCNPOLARITY_HIGH,

TIM1_OCIDLESTATE_RESET, TIM1_OCNIDLESTATE_RESET);

TIM1_OC3Init(TIM1_OCMODE_PWM1, TIM1_OUTPUTSTATE_DISABLE, TIM1_OUTPUTNSTATE_DISABLE,

PulseWidth, TIM1_OCPOLARITY_HIGH, TIM1_OCNPOLARITY_HIGH,

TIM1_OCIDLESTATE_RESET, TIM1_OCNIDLESTATE_RESET);

TIM1_ITConfig(TIM1_IT_UPDATE, ENABLE);

TIM1_ARRPreloadConfig(ENABLE);

TIM1_Cmd(ENABLE);

TIM1_CtrlPWMOutputs(ENABLE);

^是按位异或的符号,PD_ODR ^ 0x08是PD_ODR的值与0x08进行异或,结果值送回PD_ODR,异或是异位为1,即1异或0为1,要具体知道该程序意思,还需知道前后程序的内容。

以上就是关于如何实现STM8的程序加密可以使用其RC校验码吗全部的内容,包括:如何实现STM8的程序加密可以使用其RC校验码吗、stm8s903k3t6c控制21个灯同时亮灭循环怎么写程序、stm8s005k6 单片机 tim2 ch2 无法输出PWM,请给一个基本的程序,感谢,弄了很久...等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

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

原文地址: http://outofmemory.cn/zz/9971904.html

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

发表评论

登录后才能评论

评论列表(0条)

保存