大家可能都知道破解51單片機(jī)是很容易的,但為什么容易,又是如何來(lái)破解的,可能很多人就不大清楚了,我在這里結(jié)合網(wǎng)上一些前輩整理的資料,和自己的經(jīng)驗(yàn),對(duì)MCU破解技術(shù)做個(gè)簡(jiǎn)單分析。
大家不要把解密想的很復(fù)雜,他不像研發(fā)一款產(chǎn)品那樣,先確定客戶需求或者新產(chǎn)品主要功能,然后立項(xiàng)確定技術(shù)指標(biāo),分配軟硬件開(kāi)發(fā)任務(wù),基于硬件調(diào)試程序,然后驗(yàn)證功能,測(cè)試bug,還要做環(huán)境試驗(yàn)。行業(yè)里解密的方法有很多,每個(gè)人破解的思路也不一樣。但是大致分為幾種。
一軟件破解利用軟件破解目標(biāo)單片機(jī)的方法,利用這種方法,不會(huì)對(duì)目標(biāo)MCU元器件造成物理?yè)p傷。主要是對(duì)WINBONGD,SYNCMOS單片機(jī)和GAL門(mén)陣列,這種利用軟件解密設(shè)備,按照一定的步驟操作,執(zhí)行片內(nèi)的程序送到片外的指令,然后用解密的設(shè)備進(jìn)行截獲,這樣芯片內(nèi)部的程序就被解密完成了(GAL采用邏輯猜測(cè)),就可以得到加密單片機(jī)中的程序。
二硬件破解流程如下:
1、測(cè)試
使用高檔編程器等設(shè)備測(cè)試芯片是否正常,并把配置字保存。
2、開(kāi)蓋
采用手工或?qū)S瞄_(kāi)蓋設(shè)備進(jìn)行開(kāi)蓋處理,這里說(shuō)的開(kāi)蓋并不是說(shuō)單片機(jī)或者其他MCU真有一個(gè)蓋。簡(jiǎn)單解釋一下,MCU其實(shí)是一個(gè)大規(guī)模集成電路,它是由N個(gè)電路組合而成的,而晶圓就是搭載集成電路的載體。將晶圓進(jìn)行封裝后,就形成了我們?nèi)粘K玫?a target="_blank">IC芯片,封裝形式可以有多種,比如TSSOP28、QFN28等,大家可以自己去百度搜索,這里不再?gòu)?fù)述。
對(duì)不同芯片,提供對(duì)應(yīng)的圖紙,讓廠家做電路修改,目的是讓MCU的存儲(chǔ)區(qū)變得可讀。有些MCU默認(rèn)不允許讀出Flash或者E2PROM中的數(shù)據(jù),因?yàn)橛杏布娐纷霰Wo(hù),而一旦切斷加密連線,程序就暴露可讀了。如圖2所示
(切割掉加密熔絲,這樣就可以直接讀出芯片內(nèi)部程序)
4、讀程序
取回修改過(guò)的MCU,直接用編程器讀出程序,可以是HEX文件,或者BIN文件。
5、燒寫(xiě)樣片給客戶
按照讀出的程序和配置,燒寫(xiě)到目標(biāo)MCU中,這樣就完成了MCU的破解。 至此,硬件破解法成功完成。
三軟硬兼施采用軟件和硬件結(jié)合的方法,需要對(duì)芯片的內(nèi)部結(jié)構(gòu)非常的熟悉。
另外還有其他一些破解技術(shù),例如電子探測(cè)攻擊、過(guò)錯(cuò)產(chǎn)生技術(shù)等等,但是最終目的只有一個(gè),就是能夠模仿出目標(biāo)MCU的功能就可以了。
看到這里大家應(yīng)該明白一個(gè)道理,破解MCU并不能做到把MCU中的程序原封不動(dòng)的還原出來(lái)。目前的技術(shù)也做不到,至少國(guó)內(nèi)應(yīng)該做不到。針對(duì)以上情況,加密芯片應(yīng)運(yùn)而生,初期確實(shí)能很好的保護(hù)MCU的安全,但很快就被找到了漏洞。
我舉個(gè)實(shí)際破解的例子分析一下,大家就能夠明白了。
加密原理:
MCU和加密芯片各存儲(chǔ)一條認(rèn)證秘鑰,存儲(chǔ)同樣的加密算法;
MCU產(chǎn)生隨機(jī)數(shù)發(fā)給加密芯片,后者用秘鑰加密后將密文返回,此時(shí)MCU解密后,比對(duì)明文是否和生成的隨機(jī)數(shù)相等。如果相等,程序正常運(yùn)行;如果不相等,出錯(cuò)處理。
因?yàn)楸I版商沒(méi)有這條秘鑰,加密芯片與MCU交互的數(shù)據(jù)又是隨機(jī)變化的,無(wú)法找到規(guī)律,所以只能把加密芯片的程序破解了,再?gòu)?fù)制一片加密芯片才能讓MCU的程序跑起來(lái)。而加密芯片不同于通用MCU,它內(nèi)部有很多安全機(jī)制,破解難度非常大。
這種加密方案看似非常安全,但其實(shí)還是有漏洞的。
破解方法:
-
首先按照第二種破解方法,獲取到MCU的HEX文件。此處省略N步,不再?gòu)?fù)述。
-
使用軟件進(jìn)行HEX反編譯,反編譯軟件目前有很多。
-
在反編譯的程序中,找到對(duì)比點(diǎn),比如圖3所示,CJNE語(yǔ)句可能就是這個(gè)對(duì)比點(diǎn)。因此只要把箭頭2那行語(yǔ)句刪除,然后重新把匯編語(yǔ)言下載到MCU中,破解工作就完成了。此時(shí)即使沒(méi)有加密芯片,MCU也能正常運(yùn)行了。
其實(shí)原因很簡(jiǎn)單。MCU是要對(duì)加密芯片的返回值進(jìn)行判斷的,那么不讓他做判斷,這樣一來(lái)不管加密芯片返回值是什么,程序都能正常運(yùn)行。
因此這種加密方案很快就被破解了。當(dāng)然也不是這么絕對(duì),因?yàn)橛行㎝CU即使剖片也不能獲得里面的HEX或者BIN文件,所以這種破解方案也要看MCU的安全等級(jí)夠不夠高。但是足以說(shuō)明一個(gè)問(wèn)題,這種通過(guò)對(duì)比加密結(jié)果來(lái)實(shí)現(xiàn)加密的方案,安全等級(jí)還是不夠高,還是有破解漏洞的。
因?yàn)槠邢蓿酒谥蛔鼋饷芗夹g(shù)的簡(jiǎn)單介紹。所謂知己知彼,百戰(zhàn)百勝,唯有了解了破解技術(shù),才能更有效的做加密防護(hù)。
-
mcu
+關(guān)注
關(guān)注
146文章
17353瀏覽量
352788 -
51單片機(jī)
+關(guān)注
關(guān)注
274文章
5705瀏覽量
124389
原文標(biāo)題:三種破解MCU 技術(shù),就是這么簡(jiǎn)單!
文章出處:【微信號(hào):mcu168,微信公眾號(hào):硬件攻城獅】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
FPGA頻率測(cè)量的三種方法
![FPGA頻率測(cè)量的<b class='flag-5'>三種方法</b>](https://file1.elecfans.com/web3/M00/05/5E/wKgZO2d_KMWAdJQqAAAQGss4Fmo827.png)
51單片機(jī)中為什么很少出現(xiàn)printf的身影
![<b class='flag-5'>51</b><b class='flag-5'>單片機(jī)</b>中為什么很少出現(xiàn)printf的身影](https://file1.elecfans.com/web3/M00/00/D3/wKgZPGdOcWOAYumHAAAGbaPdCx0068.png)
基于51單片機(jī)的手動(dòng)數(shù)字時(shí)鐘
![基于<b class='flag-5'>51</b><b class='flag-5'>單片機(jī)</b>的手動(dòng)數(shù)字時(shí)鐘](https://file1.elecfans.com//web1/M00/F3/4F/wKgZoWcVAq2AGPEHAAVBtNVqXVM246.png)
基于51單片機(jī)的遙控開(kāi)關(guān)仿真(雙機(jī)通信)
![基于<b class='flag-5'>51</b><b class='flag-5'>單片機(jī)</b>的遙控開(kāi)關(guān)仿真(雙機(jī)通信)](https://file1.elecfans.com//web1/M00/F3/4E/wKgaoWcVA6-ARF9OAAX1mmwmbVY374.png)
如何實(shí)現(xiàn)51單片機(jī)與PC機(jī)的串行通信
51單片機(jī)驅(qū)動(dòng)
單片機(jī)的三種總線結(jié)構(gòu)
51單片機(jī)晶振的問(wèn)題總結(jié)
51單片機(jī)燒錄軟件怎么用
MCUXpresso IDE下在線聯(lián)合調(diào)試雙核MCU工程的三種方法
![MCUXpresso IDE下在線聯(lián)合調(diào)試雙核MCU工程的<b class='flag-5'>三種方法</b>](https://file1.elecfans.com/web2/M00/01/47/wKgZoma0cXeABzT3AAA1KoC8H4g757.png)
?51單片機(jī)串口通信詳細(xì)介紹-小白必看
![?<b class='flag-5'>51</b><b class='flag-5'>單片機(jī)</b>串口通信詳細(xì)介紹-小白必看](https://file1.elecfans.com/web2/M00/CA/86/wKgZomYfJtSAR25GAAA4_qAJ84Y871.png)
51單片機(jī)流水燈制作
![<b class='flag-5'>51</b><b class='flag-5'>單片機(jī)</b>流水燈制作](https://file1.elecfans.com/web2/M00/C1/E3/wKgaomXb8VyASKTsAACFYv8Crn0012.png)
評(píng)論