1. 确保芯片已经正确地烧录了程序。可以使用 STM8CubeProgrammer、STVD或其他 SWIM/SWD 接口的调试工具,查看是否已将程序成功烧录到芯片中。如果程序未能正确下载,则需要检查编译和链接的过程是否正确,并尝试重新下载。
2. 检查程序是否与硬件相兼容。有时候程序适用于某些型号或版本的 STM8S 芯片,而与另一种型号的芯片不兼容,需要检查是否选择了正确的芯片型号。
3. 检查程序代码是否正确。有时候程序未能正确运行是因为存在代码逻辑缺陷或者程序本身存在错误。应该在下载程序前认真检查代码,以确保代码逻辑正确并且符合设计要求。
4. 检查硬件电路是否正确连接。如果芯片的电源和时钟信号等外部引脚连接错误,则可能导致程序无法正常运行。需要检查硬件电路连接是否正确,并排除硬件故障导致程序未能运行的可能性。
综上所述,需要对硬件和软件两方面进行全面的排查,并进行逐一验证,才能找到程序未能运行的原因,并最终解决问题。
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),下次读到这个标志位,就不运行这个程序
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)