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

2024-11-29 08:49:41
推荐回答(2个)
回答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),下次读到这个标志位,就不运行这个程序



回答2:

STM8S主流系列
意法半导体的STM8S系列主流8位微控制器适于工业、消费类和计算机市场的多种应用,特别是要实现大批量的情况。基于STM8专有内核,STM8S系列采用ST的130纳米工艺技术和先进内核架构,主频达到24 MHz,处理能力高达20MIPS。嵌入式EEPROM、RC振荡器和全套标准外设为设计者提供了稳定且可靠的解决方案。
相关工具链,从经济型探索套件到更复杂的评估套件和第三方工具,为利用STM8S微控制器进行开发提供了极大方便。
STM8S系列包括四个产品线,具有不同特性,但是保持了全面兼容性和可升级性,从而减少了未来产品设计变更。
STM8S003/005/007超值型是入门级产品,具有基本功能。
STM8S103/105基本型提供了更多特性和封装选项。
STM8S20增强型配有全套外设,满足中、高端应用的性能要求。
STM8S专用型提供了更多模拟特性和专用固件解决方案。