新聞中心

        EEPW首頁(yè) > 模擬技術(shù) > 設(shè)計(jì)應(yīng)用 > 對(duì)單片機(jī)程序的動(dòng)態(tài)加密措施

        對(duì)單片機(jī)程序的動(dòng)態(tài)加密措施

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

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

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

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

          ……

          SUB1: ADD A,#94H ;虛設(shè)的程序段

          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 ;異或運(yùn)算

          MOV @R0,A ;存入實(shí)際數(shù)據(jù)

          POP A

          INC A

          INC R0

          DJNZ R1,LOOP1


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

        關(guān)鍵詞: 單片機(jī) 動(dòng)態(tài)加密

        評(píng)論


        相關(guān)推薦

        技術(shù)專區(qū)

        關(guān)閉
        主站蜘蛛池模板: 浏阳市| 灵山县| 大关县| 平乡县| 长乐市| 伊宁县| 中卫市| 靖宇县| 淳化县| 丰宁| 开化县| 博湖县| 合肥市| 元谋县| 城口县| 纳雍县| 东方市| 水富县| 广元市| 建瓯市| 肇州县| 许昌县| 涿鹿县| 平罗县| 昆明市| 黄梅县| 上高县| 吴旗县| 凤山县| 锡林浩特市| 边坝县| 上杭县| 渭南市| 东台市| 房产| 赤壁市| 大邑县| 巴林左旗| 五指山市| 德江县| 姚安县|