當前位置:首頁 > 單片機 > 單片機
[導讀]眾所周知, 有一些公司或個人專門做單片機的解密服務,另外,單片機的指令不論怎樣加密最終它還要在明文的方式下才能運行, 而且解密者可以使用單片機開發(fā)系統(tǒng)單步調試ROM中的程序。 當解密者了解了指令的運行過程之后

眾所周知, 有一些公司或個人專門做單片機的解密服務,另外,單片機的指令不論怎樣加密最終它還要在明文的方式下才能運行, 而且解密者可以使用單片機開發(fā)系統(tǒng)單步調試ROM中的程序。 當解密者了解了指令的運行過程之后, 也就獲得了加密的程序, 如某些智能計價器的運算方法等,通過修改程序并仿制新的ROM芯片, 就可以達到解密的目的。因此,對單片機的加密還要在程序的運行上進行加密處理, 也就是程序的動態(tài)加密措施。

1 程序的動態(tài)解碼

動態(tài)解碼是對加密程序的指令或數(shù)據(jù)代碼進行動態(tài)恢復。在程序運行時, 有一段指令是專門對某一區(qū)域的指令或數(shù)據(jù)代碼解密, 而且當解密后的代碼使用完畢, 還要將其重新加密, 使存儲器中不存在完整的程序代碼。 這種方法對防程序的靜態(tài)分析很有效, 因為從加密程序的清單上很難看出程序的真實面目。然而,在程序的反跟蹤方面, 動態(tài)解碼又有其獨到之處, 在阻止帶斷點調試跟蹤方面, 由于程序在執(zhí)行之前是以密文方式出現(xiàn)的, 解密者很難確定斷點設置的位置, 稍有不慎就會因解密失敗造成系統(tǒng)的破壞(電擦除EPROM中的數(shù)據(jù))。下面是程序動態(tài)解碼的具體例子:

……
SUB1: ADD A,#94H ;虛設的程序段
XRL 54H,#13H
……
MOV R0,#20H
MOV R1,#5
MOV R2,#55H
MOV DPTR,#SUB1
MOV A,#00H
LOOP1: PUSH A
MOVC A,@A+DPTR
XRL A,R2 ;異或運算
MOV @R0,A ;存入實際數(shù)據(jù)
POP A
INC A
INC R0
DJNZ R1,LOOP1
……

該程序是將RAM地址為20H開始的數(shù)據(jù)組(設有5個)進行動態(tài)變換, 因為初始的數(shù)據(jù)組是密碼形式的, 它需要在程序運行中改變,在程序的其他段中要使用改變后的數(shù)據(jù)。這里是用SUB1程序段中的指令代碼(代碼為:24H,94H,63H,54H,13H)與55H進行動態(tài)解碼,數(shù)據(jù)55H是加密數(shù)據(jù),它"異或"指令代碼后得到正確的數(shù)據(jù)存入20H開始的單元中(結果為:71H,C1H,36H,01H,46H)。為了說明動態(tài)數(shù)據(jù)解碼過程, 這個例子比較簡單, 實際在轉入該程序段時, 可以由某些運算生成數(shù)據(jù)單元地址, 以增強程序的抗分析能力。

2 程序段防修改

在加密程序中, 所設置的障礙不會只有一處。為了使加密措施完善, 在一些關鍵地方程序的前后呼應是反破譯的有效方法。 解密者為了一些目的, 必然要修改某段程序指令;而程序段防修改就是針對這種解密方法所采用的技術手段。為了達到加密程序的完整性, 可以在程序的關鍵處取指令或數(shù)據(jù)代碼參加某種運算, 其結果作為判斷程序是否被變動的依據(jù)。 下面是程序防修改的程序段:

……
SUB2: ADD A,#35H
SUBB A,#05H
……
MOV DPTR,#SUB2
MOV R0,#30H
MOV A,#1
MOV R1,#3
MOV @R0,#24H ;SUB2段第一個指令代碼為24H
LOOP2: PUSH A
MOVC A,@A+DPTR
XRL 30H,A ;異或運算
POP A
INC A
DJNZ R1,LOOP2
MOV A,30H
……
CJNE A,#80H,ERR ;結果與80H比較
……
ERR: MOV A,#0 ;錯誤出口
……

在SUB2程序段, 是通過指令計算某些數(shù)據(jù)的,如收費的算法等。解密者總要修改部分指令, 達到某種目的。然而, 反解密的工作是在后面的LOOP2程序段中,是用到了SUB2程序段中的指令字節(jié)(這里是用了4個字節(jié))進行運算(這里是用"異或"運算),它的結果將直接影響下面程序的正確執(zhí)行(正確的運算結果為80H)。如果改變該SUB2程序段,則在LOOP2程序段中將程序引入歧途, 會不知不覺地走入迷途。如果在硬件設計上有電擦除EEPROM,可以進一步將程序中的數(shù)據(jù)修改(或刪除),使跟蹤者造成設備的"損壞",無法重新分析程序。

上面介紹的單片機加密方法,是阻止解密者非法獲得ROM中的程序或者使ROM中的程序無法在復制的單片機系統(tǒng)中運行。在實際應用中,判斷程序正常運行與被跟蹤運行是有很多方法的。例如,可以根據(jù)時鐘計時斷定某個程序段運行的時間, 以便作出不同的反應, 因為單步與連續(xù)運行在時間上是有很大差別的。另外, 對單片機的加密不能僅限于上述的一種方法,而且反跟蹤的方法也不能單一, 要幾種方法配合使用才能達到好的效果。如軟件加密與硬件加密相結合,動態(tài)解碼可與程序防修改相結合等,充分利用新技術、新方法(如可編程邏輯器件等)使單片機的加密保護更有效。
 

本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內容真實性等。需要轉載請聯(lián)系該專欄作者,如若文章內容侵犯您的權益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或將催生出更大的獨角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉型技術解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術公司SODA.Auto推出其旗艦產品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關鍵字: 汽車 人工智能 智能驅動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務中斷的風險,如企業(yè)系統(tǒng)復雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務連續(xù)性,提升韌性,成...

關鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網易近期正在縮減他們對日本游戲市場的投資。

關鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產業(yè)博覽會開幕式在貴陽舉行,華為董事、質量流程IT總裁陶景文發(fā)表了演講。

關鍵字: 華為 12nm EDA 半導體

8月28日消息,在2024中國國際大數(shù)據(jù)產業(yè)博覽會上,華為常務董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權最終是由生態(tài)的繁榮決定的。

關鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應對環(huán)境變化,經營業(yè)績穩(wěn)中有升 落實提質增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務引領增長 以科技創(chuàng)新為引領,提升企業(yè)核心競爭力 堅持高質量發(fā)展策略,塑強核心競爭優(yōu)勢...

關鍵字: 通信 BSP 電信運營商 數(shù)字經濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術學會聯(lián)合牽頭組建的NVI技術創(chuàng)新聯(lián)盟在BIRTV2024超高清全產業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術創(chuàng)新聯(lián)...

關鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關鍵字: BSP 信息技術
關閉
關閉