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),下次读到这个标志位,就不运行这个程序
额,首先,这个加密的原理要清楚。还有编译的原理要清楚。。。
第一,程序为什么会被读出来?因为编程器编程总要校验一下比较安全,保证编程可靠。所以,编程器一般都可以读程序。但是,这个被山寨哥们看上了就是大大的方便了。于是,加密位就被设计出来了。加密一下,编程器就读不出程序了。这个在编程时编程器设置项了可以选择。具体发生的事情是:编程器对器件的加密位编程。于是器件的“读”功能就被限制。只有全擦除可以连加密位一起还原。如此就达到了代码保护的作用。由于这个过程不涉及程序本身,属于对器件的“设置”。并不是靠程序执行来起作用的。所以靠编译器来加密?还是算了吧。。。
第二,编译是把由高级语言写成的源代码,翻译成“天书”的过程。这个涉及到的,仅仅是一个翻译的过程。就像说话,跟美国人说是要说“鸟语”的。但是意思是一个样的。要是这个再能加密,那么抱歉,美国人也不都是中情局的,到时候会看不懂“密电”的。
以上就是关于如何实现STM8的程序加密可以使用其RC校验码吗全部的内容,包括:如何实现STM8的程序加密可以使用其RC校验码吗、51单片机怎么加密 在源代码会不会有用来加密的代码、等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)