開發環境:
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); // 高字節
【注】大小端
地址從小到大,先放低字節,再放高字節:小端模式
地址從小到大,先放高字節,再放低字節:大端模式
主函數代碼如下:
/*
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后面的“通過”字樣。
當然啦,每個芯片的ID是不一樣。
-
微控制器
+關注
關注
48文章
7903瀏覽量
153671 -
Cortex-M
+關注
關注
2文章
230瀏覽量
30214 -
STM32單片機
+關注
關注
59文章
549瀏覽量
59368 -
GD32
+關注
關注
7文章
418瀏覽量
25135
發布評論請先 登錄
評論