<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>

新聞中心

EEPW首頁(yè) > 嵌入式系統 > 設計應用 > 對單片機及其程序的運行上加密解析方案

對單片機及其程序的運行上加密解析方案

作者: 時(shí)間:2012-06-01 來(lái)源:網(wǎng)絡(luò ) 收藏

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

本文引用地址:http://dyxdggzs.com/article/171383.htm

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

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

POP A

INC A

INC R0

DJNZ R1,LOOP1

……

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

2 程序段防修改

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


上一頁(yè) 1 2 下一頁(yè)

評論


相關(guān)推薦

技術(shù)專(zhuān)區

關(guān)閉
国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>