《電子技術(shù)應(yīng)用》
您所在的位置:首頁 > 其他 > 業(yè)界動(dòng)態(tài) > SmartLock并口單片機(jī)軟件狗加密技術(shù)

SmartLock并口單片機(jī)軟件狗加密技術(shù)

2009-01-12
作者:李長洲 魏蛟龍 周曼麗

  摘? 要: 介紹一套單片機(jī)軟件狗加密系統(tǒng)——SmartLock。它安裝在微機(jī)并行口上,通過并口與加密軟件進(jìn)行通信,主要使用代碼移植的方法實(shí)現(xiàn)軟件加密。該系統(tǒng)具有加密可靠、使用方便、兼容性好等特點(diǎn)。

  關(guān)鍵詞: 軟件加密? 并行口? 單片機(jī)? 代碼移植

?

  由于加密給軟件開發(fā)者和用戶帶來了許多不便和麻煩,因此,全球軟件業(yè)的趨勢是開發(fā)不加密軟件,依靠版權(quán)法來保護(hù)軟件開發(fā)者的權(quán)益。但對于一些大型的工程應(yīng)用軟件系統(tǒng)如:AutoCAD、Xilinx FPGA開發(fā)系統(tǒng)等,由于銷量小、成本高,不得已仍然需要使用軟件加密技術(shù)。另外,對于某些敏感行業(yè)的應(yīng)用軟件也必須實(shí)行軟件加密,對程序代碼進(jìn)行保護(hù)。

  早期的軟件加密方法有:軟盤或硬盤加密、加密卡等,由于加密性能、兼容性能或使用不方便等方面的原因而被淘汰。目前廣為流行的是軟件狗硬件電路加密法,其中又以使用單片機(jī)的加密技術(shù)最為可靠。其硬件通常都帶有智能抗分析技術(shù),不可復(fù)制,且加密方式靈活、工作可靠、運(yùn)行速度快、使用方便,不失為軟件加密的一種優(yōu)選方法。

  SmartLock軟件狗加密系統(tǒng)的硬件部分外形類似火柴盒,兩頭分別帶有一個(gè)IEEE-1284并行口的公頭和母頭,串接在并行口和打印機(jī)之間。軟件狗使用的是Atmel公司的89C2051單片機(jī),芯片從微機(jī)并行口取電,通過并口與加密軟件進(jìn)行通信,系統(tǒng)主要使用代碼移植技術(shù)實(shí)現(xiàn)軟件加密。

1 Smart Lock系統(tǒng)的硬件設(shè)計(jì)

  通過研究微機(jī)打印口接口電路、IEEE-1284并口通信標(biāo)準(zhǔn)和89C2051型單片機(jī)特性,設(shè)計(jì)出SmartLock加密系統(tǒng)的硬件電路如圖1所示。有89C2051單片機(jī)、3個(gè)鍺二極管、1個(gè)12MHz晶振、2個(gè)30pF瓷片電容和1個(gè)電阻共8個(gè)元件。系統(tǒng)從并行口中共引出了11根端口線,其中有8根數(shù)據(jù)線D0~D7、1根狀態(tài)線(低電平有效 ,當(dāng)打印機(jī)接收完一字節(jié)數(shù)據(jù)允許微機(jī)發(fā)送下一字節(jié)數(shù)據(jù)時(shí),發(fā)給微機(jī)信號)、1根控制線(低電平有效,打印機(jī)自動(dòng)換行信號)和地線GND。

?

?

  微機(jī)的標(biāo)準(zhǔn)并口并不提供+5V電源,所以只有從驅(qū)動(dòng)能力較強(qiáng)的數(shù)據(jù)口“借電”。依據(jù)IBM PC AT/XT設(shè)計(jì)標(biāo)準(zhǔn),并行口數(shù)據(jù)位的高電平(4.5V)輸出電流為2.5mA(舊式的TTL型)或15mA(CMOS型),而89C2051單片機(jī)的典型工作電流為5.5mA/3V,工作頻率為12MHz。所以使用D4~D6三根數(shù)據(jù)線經(jīng)鍺二極管并在一起作為單片機(jī)電源(采用鍺管的原因是因?yàn)樗膲航递^小,只有0.4V)。同時(shí)為減少軟件狗硬件的功耗,電路設(shè)計(jì)得極其簡潔,除了單片機(jī),沒有其它有源器件。

  單片機(jī)復(fù)位使用的是上電自動(dòng)復(fù)位電路。因此微機(jī)對并行口供電幾百毫秒之后,單片機(jī)才進(jìn)入正常工作狀態(tài)。

2 并口通信協(xié)議

  軟件狗使用數(shù)據(jù)口的D0~D3及D7作為微機(jī)向單片機(jī)傳送數(shù)據(jù)的前向數(shù)據(jù)通道(一次送半字節(jié)數(shù)據(jù),用D7位標(biāo)志高/低半字節(jié));并口控制/狀態(tài)信號中的平時(shí)不常用,所以這里用來作為微機(jī)向單片機(jī)傳送數(shù)據(jù)時(shí)的握手信號。信號為高電平,則表示微機(jī)已準(zhǔn)備好待傳送數(shù)據(jù),此協(xié)議中稱為DR(data ready)信號;信號為低電平,表示單片機(jī)已準(zhǔn)備好接收數(shù)據(jù),此協(xié)議中稱為PR(peripheral ready)信號。

  軟件狗從微機(jī)接收數(shù)據(jù)的時(shí)序如圖2所示。具體步驟是:

  (1)微機(jī)中的加密程序?qū)R()控制線設(shè)置為0,然后在并口的D4~D6數(shù)據(jù)線上給一個(gè)負(fù)脈沖后再置恒1,使軟件狗復(fù)位啟動(dòng);

  (2)加密程序延時(shí)300ms后,設(shè)置D7為0,表示傳送的是數(shù)據(jù)的低半字節(jié);

  (3)加密程序?qū)⑿枰獋魉偷臄?shù)據(jù)放到并口的D0~D3;

  (4)加密程序在DR控制線上給出一個(gè)正脈沖,通知軟件狗數(shù)據(jù)已準(zhǔn)備好;

  (5)軟件狗收到DR信號后從D0~D3線上讀取數(shù)據(jù),同時(shí),從D7位可以了解這半字節(jié)數(shù)據(jù)是低位還是高位。讀完數(shù)據(jù)后在PR()狀態(tài)線上給出負(fù)脈沖,通知微機(jī)數(shù)據(jù)已讀完,可以進(jìn)行下一次傳送;

  (6)加密程序收到PR信號后,即進(jìn)行下一輪的數(shù)據(jù)傳送,直到最后所有數(shù)據(jù)傳送完畢或一定時(shí)間后仍沒有收到PR信號,則出錯(cuò)退出。

?

?

  SmartLock系統(tǒng)使用了狀態(tài)線作為單片機(jī)向微機(jī)發(fā)送“串行”數(shù)據(jù)時(shí)的數(shù)據(jù)線。同時(shí),通過使用獨(dú)特的脈寬調(diào)制數(shù)據(jù)傳送方式,實(shí)現(xiàn)了單端口線的數(shù)據(jù)傳輸。這是由于:

  (1)微機(jī)并行口的用途是由微機(jī)向外設(shè)進(jìn)行單向的數(shù)據(jù)傳輸,同時(shí)沒有多余的備用端口線;

  (2)并口中只有狀態(tài)線才能向微機(jī)傳送信息,其中狀態(tài)線一般不用。

  軟件狗向微機(jī)發(fā)送數(shù)據(jù)的時(shí)序比較特殊,如圖3所示。具體步驟是:

  (1)微機(jī)中的加密程序?qū)⒖刂茙l(fā)送完畢后開始等待軟件狗的返回?cái)?shù)據(jù)。

  (2)軟件狗計(jì)算出返回?cái)?shù)據(jù)后,首先發(fā)送一個(gè)固定長度的標(biāo)準(zhǔn)負(fù)脈沖,然后再依據(jù)數(shù)據(jù)值發(fā)送一個(gè)數(shù)據(jù)脈沖,兩個(gè)脈沖代表一個(gè)數(shù)據(jù)值;直到所有數(shù)據(jù)發(fā)送完畢為止。

  (3)加密程序通過計(jì)算數(shù)據(jù)脈沖與標(biāo)準(zhǔn)脈沖的寬度比得到數(shù)據(jù)值。

  以上說明的是微機(jī)與軟件狗之間數(shù)據(jù)通信的底層協(xié)議。雙方通信時(shí)數(shù)據(jù)幀的具體格式則可以由用戶根據(jù)需要自行定義。

?

?

3 加密軟件系統(tǒng)

  軟件部分目前只采用內(nèi)含式加密法。分為以下五個(gè)模塊:底層I/O操作模塊、用戶接口模塊、反跟蹤模塊、異常處理模塊和全自動(dòng)操作模塊。它們之間的結(jié)構(gòu)層次關(guān)系見圖4。

?

?

3.1 底層I/O模塊

  底層I/O模塊是最底層的功能函數(shù),也是整個(gè)加密軟件系統(tǒng)的核心。主要用于與軟件狗進(jìn)行數(shù)據(jù)通信,向軟件狗發(fā)送數(shù)據(jù),接收軟件狗的返回值(包括對返回值的數(shù)字化轉(zhuǎn)換和求精)及向上層模塊報(bào)告通信過程中出現(xiàn)的錯(cuò)誤。實(shí)際上是前面密鑰模塊在微機(jī)內(nèi)運(yùn)行的接口部分。另外,各種反跟蹤技術(shù)主要也融入到此模塊中。

3.2 用戶接口模塊

  用戶接口模塊有多個(gè),分別與軟件狗的各個(gè)功能一一對應(yīng),用于對通信中數(shù)據(jù)格式的轉(zhuǎn)換及對通信過程的管理。它們將上層軟件傳來的指令翻譯為軟件狗能識別的格式后再傳給底層模塊,然后將底層模塊的返回值整理后上傳。

  用戶接口函數(shù)可由待加密軟件直接調(diào)用。它們自行檢測并處理軟件被跟蹤調(diào)試時(shí)的情況,同時(shí)顯式或是隱式地向用戶軟件提供軟件狗是否合法的信息,用戶軟件可依據(jù)該信息來自行定義對軟件系統(tǒng)處于非法運(yùn)行狀態(tài)時(shí)的處理措施(本軟件系統(tǒng)提供了與各種反擊方法對應(yīng)的函數(shù))。這種使用模式十分有利于加密模塊與軟件系統(tǒng)的融合,能大大提高軟件系統(tǒng)的抗解密性能。

3.3 全自動(dòng)操作模塊

  若用戶要求軟件加密系統(tǒng)自動(dòng)完成對軟件狗的檢測及對檢測結(jié)果的處理,則可使用該函數(shù)。它自行使用隨機(jī)命令調(diào)用用戶接口模塊以檢測軟件狗的合法性,然后自動(dòng)對檢測結(jié)果進(jìn)行判斷并處理。當(dāng)然,集成度高必然導(dǎo)致抗解密性能下降。

3.4 反跟蹤模塊

  各類反跟蹤措施(函數(shù)或程序段)用于檢測軟件系統(tǒng)目前是否處于被跟蹤的狀態(tài),或人為地制造一些障礙,阻止解密者對本加密軟件的分析。它們?nèi)诤嫌诘讓覫/O模塊、用戶接口函數(shù)及自動(dòng)操作模塊中,隱蔽地檢測軟件系統(tǒng)是否運(yùn)行于調(diào)試環(huán)境下并自動(dòng)作出相應(yīng)處理。

3.5 異常情況處理模塊

  當(dāng)加密軟件檢測到軟件系統(tǒng)運(yùn)行在調(diào)試環(huán)境下或軟件狗非法時(shí),就調(diào)用這一模塊正?;蚍钦5刂兄钩绦虻倪\(yùn)行。一般情況下由于程序已處于被調(diào)試的狀態(tài),中止程序運(yùn)行的標(biāo)準(zhǔn)方法通常會被解密者覺察出來而達(dá)不到目的。因此,只有那些違反常規(guī)的操作代碼才能有效地中止程序的運(yùn)行。

4 加密軟件的使用方法

  用戶軟件只需以函數(shù)調(diào)用的方式調(diào)用SmartLock加密系統(tǒng)中的用戶接口模塊,完成對軟件的加密。這樣便在用戶軟件和加密軟件之間建立了數(shù)據(jù)聯(lián)系,隱式地檢查合法軟件狗的存在。加密軟件將自動(dòng)對調(diào)試軟件檢測和處理,用戶不需管理。

  另一個(gè)更為可靠的使用方式是用戶定制加密軟件。SmartLock系統(tǒng)將用戶待加密軟件中的某些算法完全移植到單片機(jī)軟件狗中去,再提供相應(yīng)的用戶接口模塊。這一方式下用戶軟件將受到最大限度的保護(hù)。

5 代碼移植技術(shù)

  傳統(tǒng)的軟件加密的指導(dǎo)思想是:在軟件系統(tǒng)中加入一種特殊的信息,這種信息既是加密后的軟件系統(tǒng)在正常運(yùn)行時(shí)必須引用的,又是用戶無法自行復(fù)制的。于是,加密后該軟件系統(tǒng)的運(yùn)行完全依賴于售給用戶的原信息載體。這一載體在加密技術(shù)中又被稱為密鑰。

  本加密系統(tǒng)使用的代碼移植技術(shù)是指將待加密軟件的某些算法、程序段、重要的運(yùn)算過程改造成單片機(jī)程序放在單片機(jī)中執(zhí)行。由于單片機(jī)的程序ROM是解密者不可讀的,這樣,這段代碼就被完全地保護(hù)起來了,解密者將無法接觸到這段代碼和數(shù)據(jù)。通過接口函數(shù),軟件狗可代替用戶軟件系統(tǒng)執(zhí)行一些簡單的運(yùn)算功能,以實(shí)現(xiàn)代碼移植。這一技術(shù)實(shí)際上是改造了傳統(tǒng)的加密指導(dǎo)思想,它把原軟件系統(tǒng)中的一部分信息取出來,封裝到解密者不可復(fù)制的軟件狗中。

  按傳統(tǒng)加密思想加密后的軟件系統(tǒng)中,軟件部分實(shí)際上仍然包含有原軟件系統(tǒng)正常運(yùn)行時(shí)所需要的所有信息(指令算法和數(shù)據(jù))。在經(jīng)過代碼移植技術(shù)加密的軟件系統(tǒng),系統(tǒng)的軟件部分已不完整,解密者即使歷盡千辛萬苦把軟件分析透徹了,軟件系統(tǒng)的正常運(yùn)行還是離不開軟件狗的支持。

  SmartLock軟件加密系統(tǒng)中使用的新穎技術(shù)主要有以下兩點(diǎn),它們有力地保證了軟件狗的抗分析、反跟蹤性能。

  (1)特殊的并口通信協(xié)議

  脈沖形式的握手信號,可有效對抗各種跟蹤調(diào)試工具及軟件。由圖2軟件狗的數(shù)據(jù)接收時(shí)序可知,本通信協(xié)議中,微機(jī)向單片機(jī)傳送數(shù)據(jù)時(shí)是使用窄脈沖信號作為握手信號,這樣微機(jī)的CPU必須不間斷地查詢軟件狗的PR信號。而解密者在調(diào)試跟蹤本軟件時(shí)必然會因調(diào)試狀態(tài)下軟件運(yùn)行時(shí)斷時(shí)續(xù)而收不到握手信號,使數(shù)據(jù)傳輸過程出錯(cuò)。軟件將無法正常工作。同時(shí),反跟蹤模塊也可由此輕易查知調(diào)試環(huán)境的存在而采取相應(yīng)的對策。

  通過脈寬調(diào)制信號從軟件狗向微機(jī)傳送數(shù)據(jù)是一種全新的微機(jī)打印口數(shù)據(jù)傳輸方法。由于它與通常的數(shù)字信號相差很大,所以這種形式的數(shù)據(jù)具有很強(qiáng)的反動(dòng)態(tài)跟蹤能力。這樣既解決了標(biāo)準(zhǔn)并行口反向傳輸信道窄的問題,又可有效對抗各種調(diào)試工具軟件及端口信號分析儀。除非解密者完全了解它的工作機(jī)理,否則根本無法知道軟件狗在干什么。

  (2)代碼移植技術(shù)

  該技術(shù)將待加密軟件與加密系統(tǒng)緊密配合,將需要保護(hù)的軟件完全封裝在黑盒中。

  實(shí)際使用時(shí),SmartLock軟件狗系統(tǒng)還可以進(jìn)行更靈活的設(shè)計(jì)以達(dá)到更強(qiáng)的加密效果。例如:將并行口的數(shù)據(jù)線與89C2051單片機(jī)的P1口全部對接,同時(shí)將8根數(shù)據(jù)線全部通過鍺二極管并接成單片機(jī)電源。通信過程中,將其中的5根作為數(shù)據(jù)傳輸線,3根作為電源傳輸線;而且每根數(shù)據(jù)端口線的作用可以進(jìn)行動(dòng)態(tài)再分配。這種方法可以讓端口分析儀幾乎失去作用,抗分析性極強(qiáng)。

  SmartLock軟件狗可以輕易設(shè)計(jì)成一系列軟件加密狗,在實(shí)際應(yīng)用中效果良好。

?

參考文獻(xiàn)

1 劉? 鳴.計(jì)算機(jī)磁盤加密技術(shù).天津:天津大學(xué)出版社,1996

2 張昆藏.IBM PC/XT微型計(jì)算機(jī)接口技術(shù).北京:清華大學(xué)出版社,1991

3 IEEE 1284-1994號PC機(jī)雙向并口外設(shè)接口的通信標(biāo)準(zhǔn),1994

4 Atmel89C2051技術(shù)手冊

本站內(nèi)容除特別聲明的原創(chuàng)文章之外,轉(zhuǎn)載內(nèi)容只為傳遞更多信息,并不代表本網(wǎng)站贊同其觀點(diǎn)。轉(zhuǎn)載的所有的文章、圖片、音/視頻文件等資料的版權(quán)歸版權(quán)所有權(quán)人所有。本站采用的非本站原創(chuàng)文章及圖片等內(nèi)容無法一一聯(lián)系確認(rèn)版權(quán)者。如涉及作品內(nèi)容、版權(quán)和其它問題,請及時(shí)通過電子郵件或電話通知我們,以便迅速采取適當(dāng)措施,避免給雙方造成不必要的經(jīng)濟(jì)損失。聯(lián)系電話:010-82306118;郵箱:aet@chinaaet.com。