《嵌入式 – GD32开发实战指南》第19章 程序加密
開發(fā)環(huán)境:
MDK:Keil 5.30
開發(fā)板:GD32F207I-EVAL
MCU:GD32F207IK
19.1程序加密工作原理
GD32通過讀取芯片唯一ID號(hào)來實(shí)現(xiàn)程序的保護(hù),防止被抄襲。96位的產(chǎn)品唯一身份標(biāo)識(shí)所提供的參考號(hào)碼對(duì)任意一個(gè)GD32微控制器,在任何情況下都是唯一的。用戶在何種情況下,都不能修改這個(gè)身份標(biāo)識(shí)。按照用戶不同的用法,可以以字節(jié)(8位)為單位讀取,也可以以半字(16位)或者全字(32位)讀取。在這里要提醒讀者,要注意大端小端模式。
19.2程序加密具體代碼實(shí)現(xiàn)
其實(shí)讀取ID很簡單,如果存儲(chǔ)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]); }如果存儲(chǔ)ID的變量為32位。則需要讀取3次。
u32 Sys_ID[3]; Sys_ID[2] = *(__IO u32*)(0X1FFFF7E8); // 低字節(jié) Sys_ID[1] = *(__IO u32 *)(0X1FFFF7EC); // Sys_ID[0] = *(__IO u32 *)(0X1FFFF7F0); // 高字節(jié)STM32單片機(jī)的存儲(chǔ)方式為小端模式。
【注】大小端
地址從小到大,先放低字節(jié),再放高字節(jié):小端模式
地址從小到大,先放高字節(jié),再放低字節(jié):大端模式
主函數(shù)代碼如下:
/*brief main functionparam[in] noneparam[out] noneretval none */ int main(void) {uint8_t Sys_ID[12],i;//systick initsysTick_init();//usart init 115200 8-N-1com_init(COM1);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 36if(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);} }19.3實(shí)驗(yàn)現(xiàn)象
將程序編譯完成后下載到板子中,可以看到打印出來的唯一ID,該程序是通過現(xiàn)讀取ID在通過ID判斷,才會(huì)打印出ID后面的“通過”字樣。
當(dāng)然啦,每個(gè)芯片的ID是不一樣。
歡迎訪問我的網(wǎng)站
BruceOu的嗶哩嗶哩
BruceOu的主頁
BruceOu的博客
BruceOu的CSDN博客
BruceOu的簡書
BruceOu的知乎
資源獲取方式
1.關(guān)注公眾號(hào)[嵌入式實(shí)驗(yàn)樓]
2.在公眾號(hào)回復(fù)關(guān)鍵詞[GD32開發(fā)實(shí)戰(zhàn)指南]獲取資料提取碼
總結(jié)
以上是生活随笔為你收集整理的《嵌入式 – GD32开发实战指南》第19章 程序加密的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 中标麒麟 NeoKylin-SDK 里都
- 下一篇: 一文详尽混淆矩阵、准确率、精确率、召回率