GD32开发实战指南(基础篇) 第19章 程序加密

描述

开发环境:

MDK:Keil 5.30

开发板:GD32F207I-EVAL

MCU:GD32F207IK

1 程序加密工作原理

GD32通过读取芯片唯一ID号来实现程序的保护,防止被抄袭。96位的产品唯一身份标识所提供的参考号码对任意一个GD32微控制器,在任何情况下都是唯一的。用户在何种情况下,都不能修改这个身份标识。按照用户不同的用法,可以以字节(8位)为单位读取,也可以以半字(16位)或者全字(32位)读取。在这里要提醒读者, 要注意大端小端模式

2 程序加密具体代码实现

其实读取ID很简单,如果存储ID的变量为8位。则需要读取12次,如下所示。

uint8_t 	Sys_ID[12],i;
for(i=0;i<12;i++)
{
    Sys_ID[i]=*( uint8_t*)(0x1FFFF7E8+i);
    printf(" %0.2X",Sys_ID[i]);
}

如果存储ID的变量为32位。则需要读取3次。

u32 Sys_ID[3];
Sys_ID[2] = *(__IO u32*)(0X1FFFF7E8); // 低字节
Sys_ID[1] = *(__IO u32 *)(0X1FFFF7EC); //
Sys_ID[0] = *(__IO u32 *)(0X1FFFF7F0); // 高字节

STM32单片机的存储方式为小端模式。

【注】大小端

地址从小到大,先放低字节,再放高字节:小端模式

地址从小到大,先放高字节,再放低字节:大端模式

主函数代码如下:

/*
    brief      main function
    param[in]  none
    param[out] none
    retval     none
*/
int main(void)
{
    uint8_t	Sys_ID[12],i;

    //systick init
    sysTick_init();

    //usart init 115200 8-N-1
    com_init(COM1, 115200, 0, 1);
    for(i=0;i<12;i++)
    {
        Sys_ID[i]=*(uint8_t*)(0x1FFFF7E8+i);
        printf(" %0.2X",Sys_ID[i]);
    }
    //ID 48 1D 35 54 33 34 34 08 33 31 35 36
    if(Sys_ID[0]==0x48 && Sys_ID[1]==0x1D && Sys_ID[2]==0x35 &&
     Sys_ID[3]==0x54 && Sys_ID[4]==0x33 && Sys_ID[5]==0x34 &&
     Sys_ID[6]==0x34 && Sys_ID[7]==0x08 && Sys_ID[8]==0x33 &&
     Sys_ID[9]==0x31 && Sys_ID[10]==0x35 && Sys_ID[11]==0x36)
    {
        printf("\\r\\nPass\\r\\n");
    }
    else
    {
        printf("\\r\\nFail\\r\\n");
    }
    while(1)
    {
        delay_ms(1000);
    }
}

3 实验现象

将程序编译完成后下载到板子中,可以看到打印出来的唯一ID,该程序是通过现读取ID在通过ID判断,才会打印出ID后面的“通过”字样。

GD32

当然啦,每个芯片的ID是不一样。

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分