www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

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

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


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

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

POP A

INC A

INC R0

DJNZ R1,LOOP1

……

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

2 程序段防修改

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

……

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

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


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

8位單片機在嵌入式設計領域已經成為半個多世紀以來的主流選擇。盡管嵌入式系統市場日益復雜,8位單片機依然不斷發(fā)展,積極應對新的挑戰(zhàn)和系統需求。如今,Microchip推出的8位PIC?和AVR?單片機系列,配備了先進的獨立...

關鍵字: 單片機 嵌入式 CPU

在嵌入式系統開發(fā)中,程序燒錄是連接軟件設計與硬件實現的關鍵環(huán)節(jié)。當前主流的單片機燒錄技術已形成ICP(在電路編程)、ISP(在系統編程)、IAP(在應用編程)三大技術體系,分別對應開發(fā)調試、量產燒錄、遠程升級等不同場景。...

關鍵字: 單片機 ISP ICP IAP 嵌入式系統開發(fā)

在嵌入式系統開發(fā)中,看門狗(Watchdog Timer, WDT)是保障系統可靠性的核心組件,其初始化時機的選擇直接影響系統抗干擾能力和穩(wěn)定性。本文從硬件架構、軟件流程、安全規(guī)范三個維度,系統分析看門狗初始化的最佳實踐...

關鍵字: 單片機 看門狗 嵌入式系統

本文中,小編將對單片機予以介紹,如果你想對它的詳細情況有所認識,或者想要增進對它的了解程度,不妨請看以下內容哦。

關鍵字: 單片機 開發(fā)板 Keil

在這篇文章中,小編將對PLC的相關內容和情況加以介紹以幫助大家增進對它的了解程度,和小編一起來閱讀以下內容吧。

關鍵字: PLC 模塊化 程序

隨著單片機系統越來越廣泛地應用于消費類電子、醫(yī)療、工業(yè)自動化、智能化儀器儀表、航空航天等各領域,單片機系統面臨著電磁干擾(EMI)日益嚴重的威脅。電磁兼容性(EMC)包含系統的發(fā)射和敏感度兩方面的問題。

關鍵字: 單片機 電磁兼容

以下內容中,小編將對單片機的相關內容進行著重介紹和闡述,希望本文能幫您增進對單片機的了解,和小編一起來看看吧。

關鍵字: 單片機 復位電路

在這篇文章中,小編將為大家?guī)韱纹瑱C的相關報道。如果你對本文即將要講解的內容存在一定興趣,不妨繼續(xù)往下閱讀哦。

關鍵字: 單片機 異常復位

今天,小編將在這篇文章中為大家?guī)韱纹瑱C的有關報道,通過閱讀這篇文章,大家可以對它具備清晰的認識,主要內容如下。

關鍵字: 單片機 仿真器

單片機將是下述內容的主要介紹對象,通過這篇文章,小編希望大家可以對它的相關情況以及信息有所認識和了解,詳細內容如下。

關鍵字: 單片機 中斷 boot
關閉