《電子技術(shù)應(yīng)用》
您所在的位置:首頁 > 嵌入式技術(shù) > 業(yè)界動(dòng)態(tài) > 基于CH375的嵌入式USB文件加解密系統(tǒng)的設(shè)計(jì)

基于CH375的嵌入式USB文件加解密系統(tǒng)的設(shè)計(jì)

2008-07-08
作者:王 殊, 程 卓

??? 摘? 要: 介紹了采用CH375與單片機(jī)實(shí)現(xiàn)的基于USB HOST技術(shù)的嵌入式文件加密解密系統(tǒng),該系統(tǒng)采用基于隨機(jī)算子的輕量級(jí)加密算法對USB移動(dòng)存儲(chǔ)設(shè)備" title="存儲(chǔ)設(shè)備">存儲(chǔ)設(shè)備中的文件進(jìn)行加密解密。
??? 關(guān)鍵詞: USB HOST? 加解密" title="加解密">加解密" title="文件加解密" title="文件加解密">文件加解密">文件加解密? 隨機(jī)算子? 嵌入式系統(tǒng)

?

??? 隨著信息與通信技術(shù)的飛速發(fā)展,信息安全與通信加解密在個(gè)人隱私特別在軍事情報(bào)和國家機(jī)密等方面顯得尤為突出。數(shù)據(jù)加密技術(shù)" title="加密技術(shù)">加密技術(shù)無疑是保護(hù)信息安全最有效的一種方法。傳統(tǒng)的文件加密方式是基于PC平臺(tái)的,不能滿足移動(dòng)場合的應(yīng)用需求。基于PC機(jī)的加密技術(shù)使明文到密文必須經(jīng)過PC機(jī)環(huán)節(jié),在不能保證PC機(jī)軟硬件絕對可靠的情況下,可能失密。基于嵌入式設(shè)計(jì)的本系統(tǒng)可以便攜使用,并在完成加密或解密過程后可將芯片程序擦除或?qū)⑿酒茐模苊饧咏饷苡布h(huán)節(jié)的失密。本設(shè)計(jì)提高了系統(tǒng)的安全性,提供了便攜使用的可能,有一定的理論意義和較高的使用價(jià)值。
1 USB HOST控制器CH375
??? CH375 是一款USB總線的通用接口芯片,支持USB HOST主機(jī)方式和USB DEVICE/SLAVE設(shè)備方式。CH375具有8位數(shù)據(jù)總線和讀、寫、片選控制線以及中斷輸出,可以方便地掛接到單片機(jī)/DSP/MCU/MPU等控制器的系統(tǒng)總線上。
??? CH375的USB 主機(jī)方式支持常用的USB 全速設(shè)備,外部單片機(jī)可以通過CH375 按照相應(yīng)的USB 協(xié)議與USB 設(shè)備通信。CH375 還內(nèi)置了處理海量存儲(chǔ)設(shè)備的專用通信協(xié)議的固件,外部單片機(jī)可以直接以扇區(qū)為基本單位讀寫常用的USB 存儲(chǔ)設(shè)備(包括USB 硬盤/USB 閃存盤/U盤)[1]。CH375的接口框圖如圖1所示。

?

?

2 系統(tǒng)結(jié)構(gòu)
??? 嵌入式文件加解密系統(tǒng)主要分為四個(gè)部分:運(yùn)算處理模塊、按鍵與狀態(tài)顯示模塊、USB通信模塊、電源模塊。系統(tǒng)結(jié)構(gòu)框圖如圖2所示。

?


??? 運(yùn)算處理模塊由P89V51RD2單片機(jī)與32KB的RAM 62256及其外圍電路組成,負(fù)責(zé)加解密計(jì)算與整個(gè)系統(tǒng)的控制。按鍵產(chǎn)生加解密操作的控制信號(hào),LED顯示當(dāng)前系統(tǒng)狀態(tài)。USB通信模塊對USB存儲(chǔ)設(shè)備進(jìn)行數(shù)據(jù)傳輸與文件操作。電源模塊為本系統(tǒng)供電并且為USB總線提供5V電源電壓。

3 基于CH375的USB HOST在本系統(tǒng)的硬件設(shè)計(jì)實(shí)現(xiàn)
3.1 CH375與P89V51RD2單片機(jī)的接口部分
??? CH375與P89V51RD2單片機(jī)的接口如圖3所示。CH375 的TXD引腳通過1kΩ左右的下拉電阻接地或者直接接地,使CH375 工作于并口方式。CH375的CS#連接到單片機(jī)的A15 引腳,端口地址范圍為0000H~7FFFH,為了避免沖突,外部RAM地址在8000H 以上。

?


??? 電容C3用于CH375 內(nèi)部電源節(jié)點(diǎn)退耦,C3是容量為0.01μF 的獨(dú)石或高頻瓷片電容。電容C4和C5用于外部電源退耦,C4是容量為0.1μF的獨(dú)石或高頻瓷片電容。晶體X1、電容C1和C2組成CH375的時(shí)鐘振蕩電路。USB-HOST主機(jī)方式要求時(shí)鐘頻率比較準(zhǔn)確,X1的頻率為12MHz±0.4‰,C1和C2是容量約為15pF的獨(dú)石或高頻瓷片電容。
??? 如果電源上電過程較慢并且電源斷電后放電時(shí)間較長,將導(dǎo)致CH375不能可靠復(fù)位。所以在RSTI引腳與VCC 之間跨接一個(gè)容量為0.47μF 的電容C11,并且可以減少干擾。
??? 在設(shè)計(jì)印刷線路板PCB 時(shí),需要注意:退耦電容C3 和C4盡量靠近CH375 的相連引腳;使UD+和UD-信號(hào)線貼近平行布線,盡量在兩側(cè)提供地線或者覆銅,減少來自外界的信號(hào)干擾;盡量縮短XI和XO引腳相關(guān)信號(hào)線的長度,減少高頻時(shí)鐘對外界的干擾,并應(yīng)該在相關(guān)元器件周邊環(huán)繞地線或者覆銅。
3.2 P89V51RD2單片機(jī)擴(kuò)展部分
??? P89V51RD2單片機(jī)擴(kuò)展部分電路圖如圖4所示。MCS-51 單片機(jī)用U2鎖存A7~A0 地址。U3用于簡單的地址譯碼,產(chǎn)生所需的片選信號(hào),使本系統(tǒng)CH375 芯片的片選地址范圍為B000H~BFFFH,本系統(tǒng)中CH375 需要占用兩個(gè)地址:地址BXX1H用于寫命令,地址BXX0H 用于讀寫數(shù)據(jù)。

?

?

3.3 供電電路部分
??? 供電部分電路如圖5所示,用于對USB總線供電。設(shè)計(jì)時(shí)除了要考慮自身功耗,更重要的是要保證對總線提供直流5V/500mA的供電。本設(shè)計(jì)所用的芯片都工作在直流5V下,所以選用常見的直流電壓轉(zhuǎn)換芯片μA7805。該系統(tǒng)工作時(shí),只須外接能夠輸出直流電壓為7V~20V的電源適配器即可(可外掛鋰電池組或駁接車載12V電源便攜使用)。

?

?

4 系統(tǒng)軟件設(shè)計(jì)
4.1系統(tǒng)工作流程圖
??? CH375對文件的讀寫模式分為扇區(qū)模式和字節(jié)模式。本系統(tǒng)選用速度較快的扇區(qū)模式,每次讀取4個(gè)扇區(qū)數(shù)據(jù),循環(huán)讀寫至文件結(jié)束。工作流程如圖6所示。

?


4.2 單片機(jī)軟件
??? 單片機(jī)軟件編寫比較復(fù)雜,以下是CH375程序編寫時(shí)的要點(diǎn):
??? CH375芯片占用兩個(gè)地址位,單片機(jī)A0 引腳為選擇命令數(shù)據(jù)端口,并通過8 位并口對CH375 芯片進(jìn)行讀寫,所有操作命令都是由一個(gè)命令碼、若干個(gè)輸入數(shù)據(jù)和若干個(gè)輸出數(shù)據(jù)" title="輸出數(shù)據(jù)">輸出數(shù)據(jù)組成,部分命令不需要輸入數(shù)據(jù),部分命令沒有輸出數(shù)據(jù)[2]
??? 單片機(jī)對CH375的操作步驟如下:
??? (1)在A0=1時(shí)向命令端口寫入命令代碼;
??? (2)如果該命令具有輸入數(shù)據(jù),則在A0=0 時(shí)依次寫入輸入數(shù)據(jù),每次一個(gè)字節(jié);
??? (3)如果該命令具有輸出數(shù)據(jù),則在A0=0 時(shí)依次讀取輸出數(shù)據(jù),每次一個(gè)字節(jié);
??? (4)命令完成,可以暫停或者轉(zhuǎn)到(1)繼續(xù)執(zhí)行下一個(gè)命令。CH375 芯片專門用于處理USB 通信,在接收到數(shù)據(jù)后或者發(fā)送完數(shù)據(jù)后,CH375以中斷方式通知單片機(jī)進(jìn)行處理。CH375內(nèi)部中斷邏輯圖如圖7所示。

?


??? 單片機(jī)通過CH375芯片接收數(shù)據(jù)的處理步驟如下:
??? (1)當(dāng)CH375接收到USB主機(jī)發(fā)來的數(shù)據(jù)時(shí),首先鎖定當(dāng)前USB 緩沖區(qū),防止被后續(xù)數(shù)據(jù)覆蓋,然后將INT#引腳設(shè)置為低電平,向單片機(jī)請求中斷。
??? (2)單片機(jī)進(jìn)入中斷服務(wù)程序時(shí),首先執(zhí)行GET_STATUS 命令獲取中斷狀態(tài)。
??? (3)CH375在GET_STATUS 命令完成后,將INT#引腳恢復(fù)為高電平,取消中斷請求。

??? (4)由于通過上述GET_STATUS 命令獲取的中斷狀態(tài)是“下傳成功”,所以單片機(jī)執(zhí)行RD_USB_DATA 命令從CH375讀取接收到的數(shù)據(jù)。
??? (5)CH375在RD_USB_DATA 命令完成后釋放當(dāng)前緩沖區(qū),從而可以繼續(xù)USB通信。
??? (6)單片機(jī)退出中斷服務(wù)程序。
??? 單片機(jī)通過CH375芯片發(fā)送數(shù)據(jù)的處理步驟如下:
??? (1)單片機(jī)執(zhí)行WR_USB_DATA 命令向CH375寫入要發(fā)送的數(shù)據(jù)。
??? (2)CH375被動(dòng)地等待USB 主機(jī)在需要時(shí)取走數(shù)據(jù)。
??? (3)USB主機(jī)取走數(shù)據(jù)后,CH375首先鎖定當(dāng)前USB緩沖區(qū),防止重復(fù)發(fā)送數(shù)據(jù),然后將INT#引腳設(shè)置為低電平,向單片機(jī)請求中斷。
??? (4)單片機(jī)進(jìn)入中斷服務(wù)程序時(shí),首先執(zhí)行GET_STATUS 命令獲取中斷狀態(tài)。
??? (5)CH375在GET_STATUS 命令完成后,將INT#引腳恢復(fù)為高電平,取消中斷請求。
??? (6)由于通過上述GET_STATUS 命令獲取的中斷狀態(tài)是“上傳成功”,所以單片機(jī)執(zhí)行WR_USB_DATA 命令向CH375寫入另一組要發(fā)送的數(shù)據(jù)。如果沒有后續(xù)數(shù)據(jù)需要發(fā)送,單片機(jī)就不必執(zhí)行WR_USB_DATA 命令。
??? (7)單片機(jī)執(zhí)行UNLOCK_USB 命令。
??? (8)CH375在UNLOCK_USB 命令完成后釋放當(dāng)前緩沖區(qū),從而可以繼續(xù)USB 通信。
??? (9)單片機(jī)退出中斷服務(wù)程序。
??? (10)如果單片機(jī)已經(jīng)寫入了另一組要發(fā)送的數(shù)據(jù),則轉(zhuǎn)到(2),否則結(jié)束。
4.3 加密算法設(shè)計(jì)
??? 本系統(tǒng)采用一種基于隨機(jī)因子的輕量級(jí)加密算法。
??? 傳統(tǒng)的置換和替代加密技術(shù)比較脆弱,同一明文M在同一文件或所有文件中均為相同的密文C,因此很容易通過頻度統(tǒng)計(jì)的辦法破解。針對傳統(tǒng)的置換和替代加密技術(shù)的缺點(diǎn),本系統(tǒng)在對文件進(jìn)行加密時(shí)加入隨機(jī)因子,使得明文隨著位置的不同其對應(yīng)密文也有所不同,其基本過程如下:
??? (1)首先將明文M采取一定的方法“亂”排序:例如將每10個(gè)字節(jié)分為一組,先在每組內(nèi)倒序排列,再在組內(nèi)采取奇偶位置對調(diào),從而完成分組換位的目的。
????(2)其次對“亂”排序的二次明文M進(jìn)行加密處理:加密各明文到密文的轉(zhuǎn)換不是固定的,而是隨機(jī)的,稱為隨機(jī)加密因子。基本流程如下:
??? ①取出二次明文當(dāng)前需加密的字節(jié)SB。
??? ②計(jì)算SB的隨機(jī)加密因子Factor。
??? ③變換SB到DB,DB=SB XOR Factor[3]
??? 其中,SB為明文,DB為加密后的密文。隨機(jī)加密因子Factor由兩部分組成:密鑰Key和SB的位置偏移量p(mod 256)。設(shè)密鑰為:“Huazhong University of Seience and Technology EI DSP Laboratory Zoe”共69個(gè)字符。當(dāng)前需要加密的二次明文為字母A(SB的ASCII碼為65,其在文件中的偏移量p為第234個(gè)字節(jié)),則密鑰Key計(jì)算方法如下:234 mod 69=27,密鑰中第27個(gè)字母為i(ASCII碼為105),所以Key=105。隨機(jī)加密因子Factor=(105+234=339)mod 256=73。密文DB=SB XOR Factor=65 XOR 73=8。如果第236個(gè)字節(jié)也為字母A,可計(jì)算出所對應(yīng)的Factor=85,密文為17。可見同一明文在文件中的位置不同,相應(yīng)的密文也有所不同,這樣就難以通過頻度統(tǒng)計(jì)的辦法破解。
??? 本系統(tǒng)硬件可以與計(jì)算復(fù)雜度不高的任何加密算法配合使用。
5系統(tǒng)的實(shí)驗(yàn)結(jié)果與討論
5.1供電測試

??? 按照USB規(guī)范,USB總線接入U(xiǎn)SB設(shè)備時(shí),需要總線提供大約500mA電流。接入U(xiǎn)SB存儲(chǔ)設(shè)備時(shí)產(chǎn)生瞬時(shí)電壓降不可避免。如果壓降過大,會(huì)導(dǎo)致系統(tǒng)不能正常工作。在此,有必要對系統(tǒng)工作時(shí)的電壓進(jìn)行監(jiān)測。測試結(jié)果,接入U(xiǎn)SB設(shè)備瞬間,電壓高于4.6V,系統(tǒng)無異常。
5.2文件加密準(zhǔn)確性測試
??? 使用本系統(tǒng)分別對U盤中大小為1KB~1MB的10個(gè)文件進(jìn)行加密操作,將得到的密文用UltraEdite-32與正確密文進(jìn)行自動(dòng)比對。結(jié)果全部正確。可見其加密過程可靠性較好。
5.3 速度測試
??? 使用本系統(tǒng)分別對U盤中大小為1KB~10MB的10個(gè)文件進(jìn)行加密操作,分別記錄完成時(shí)間(從按鍵操作到LED顯示完成)。測得平均加密速度為35KB/s,與CH375公布的100KB/s~200KB/s的讀寫速度有差距。其原因是加密操作涉及讀明文與寫密文操作,數(shù)據(jù)傳輸量加倍;而且加密計(jì)算也需要占用單片機(jī)的工作時(shí)間。提高速度可使用高性能的MCU,也可對部分子程序改用匯編語言混合編程。
??? 本文詳細(xì)介紹了基于CH375和51單片機(jī)的嵌入式USB文件加解密系統(tǒng)的設(shè)計(jì)。該系統(tǒng)使文件加解密脫離了PC機(jī),便捷易用,并使用隨機(jī)加密因子使密文抗破解能力比傳統(tǒng)方法有很大提高。
參考文獻(xiàn)
[1] 馬偉.計(jì)算機(jī)USB系統(tǒng)原理及其主/從機(jī)設(shè)計(jì)[M].北京:北京航空航天大學(xué)出版社,2004.
[2]?USB總線通用接口芯片CH375 U盤文件級(jí)子程序庫說明.南京沁恒電子有限公司,2004.
[3] 石林祥,賀海暉,魏淑桃. 一種使用文件加密方法的實(shí)現(xiàn),計(jì)算機(jī)工程,2004,(12).

本站內(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。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
亚洲永久免费| 亚洲欧洲精品一区二区三区| 精品av久久707| 国产伦精品一区二区三区高清版| 欧美日韩国产bt| 欧美激情精品久久久六区热门| 玖玖综合伊人| 久久伊人精品天天| 久久久久免费视频| 久久精品一区二区三区不卡牛牛| 欧美一区二区三区男人的天堂| 亚洲欧美精品suv| 亚洲欧美激情一区二区| 亚洲摸下面视频| 亚洲欧美区自拍先锋| 亚洲欧美成人| 亚洲欧美自拍偷拍| 欧美一区二区三区四区视频| 性欧美18~19sex高清播放| 香蕉成人伊视频在线观看| 亚洲欧美美女| 久久精品国产亚洲精品| 久久久久天天天天| 老鸭窝91久久精品色噜噜导演| 久久综合网络一区二区| 免费看成人av| 欧美日本不卡视频| 国产精品高潮呻吟久久av无限| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ入口 | 亚洲精品在线三区| 一本色道久久综合狠狠躁篇的优点| 一区二区精品国产| 亚洲一区二区在线免费观看视频| 亚洲欧美一区二区三区久久| 欧美影院精品一区| 免费亚洲一区| 欧美日韩一二区| 国产精品视频xxx| 国内精品视频在线观看| 亚洲电影欧美电影有声小说| 亚洲精品一区二区三区av| 夜夜爽av福利精品导航| 亚洲女与黑人做爰| 亚洲国产精品一区| 亚洲精品一二三| 亚洲自拍电影| 久久婷婷国产麻豆91天堂| 蜜臀av在线播放一区二区三区| 欧美欧美天天天天操| 国产精品日韩久久久久| 黄色av一区| 亚洲精品一区二区三区不| 亚洲一区二区三区久久| 久久精品人人做人人爽| 亚洲巨乳在线| 欧美一区二区三区四区视频| 美脚丝袜一区二区三区在线观看| 欧美日韩亚洲网| 国产视频久久久久| 亚洲精品极品| 欧美一区二区三区视频在线观看| 亚洲精品视频一区二区三区| 午夜久久资源| 欧美成人官网二区| 国产精品视频成人| 亚洲激情成人在线| 性伦欧美刺激片在线观看| 日韩视频免费看| 久久久久国产精品人| 欧美日韩精品三区| 国产有码在线一区二区视频| 99国产成+人+综合+亚洲欧美| 欧美在线一二三四区| 在线亚洲电影| 麻豆freexxxx性91精品| 国产精品久久久久久久电影| 亚洲国产精品久久久久秋霞影院| 亚洲免费在线观看视频| 夜夜嗨av一区二区三区四季av | 国产日韩精品久久久| 亚洲区在线播放| 欧美一区二视频| 亚洲欧美日韩一区在线观看| 欧美激情一区二区| 国产在线精品自拍| 亚洲一区视频在线| 一区二区三区产品免费精品久久75 | 国产精品久久久久久久久免费樱桃 | 欧美人与性动交cc0o| 极品少妇一区二区| 亚洲一区视频在线观看视频| 一区二区三区精品久久久| 麻豆精品国产91久久久久久| 国产视频一区二区在线观看 | 欧美在线一二三四区| 亚洲欧美日韩成人| 欧美精品亚洲| 在线精品视频一区二区| 午夜精品影院| 亚洲欧美中文日韩v在线观看| 欧美日韩国产丝袜另类| 亚洲电影自拍| 亚洲国产精彩中文乱码av在线播放| 欧美一区高清| 国产精品日韩二区| 亚洲少妇自拍| 这里只有精品丝袜| 欧美日韩黄色大片| 亚洲精品一区在线观看| 亚洲精品免费在线播放| 美女日韩欧美| 激情成人av| 亚洲二区在线| 久久午夜国产精品| 国产主播一区二区三区| 午夜亚洲一区| 久久本道综合色狠狠五月| 国产精品一级二级三级| 亚洲一区二区在线视频| 欧美一级专区| 国产美女扒开尿口久久久| 亚洲欧美在线视频观看| 久久福利一区| 国精产品99永久一区一区| 欧美在线观看视频| 久久美女性网| 在线精品国产欧美| 亚洲毛片播放| 欧美日韩中文在线| 中文在线一区| 欧美一级夜夜爽| 国产专区欧美精品| 亚洲激情偷拍| 欧美精品一区二区视频| 日韩视频一区二区| 亚洲欧美日韩国产| 国产一区二区三区成人欧美日韩在线观看| 欧美一级成年大片在线观看| 久久久久综合网| 怡红院精品视频在线观看极品| 亚洲经典三级| 欧美日韩成人综合在线一区二区 | 亚洲日本aⅴ片在线观看香蕉| 欧美激情在线观看| 亚洲最新在线| 欧美一区二区三区日韩视频| 国内精品伊人久久久久av影院| 亚洲区欧美区| 欧美日韩亚洲一区二区| 亚洲一区久久久| 久久九九有精品国产23| 在线精品一区| 亚洲一区欧美| 国产色爱av资源综合区| 91久久久久久久久久久久久| 欧美日韩成人在线观看| 亚洲欧美视频在线观看| 噜噜爱69成人精品| 亚洲精品系列| 久久国产毛片| 亚洲啪啪91| 欧美一区二区视频在线| 在线观看一区| 亚洲欧美视频| 在线观看亚洲精品| 亚洲午夜精品17c| 国产主播一区| 在线视频亚洲欧美| 国产一区二区成人久久免费影院| 亚洲欧洲一区二区天堂久久 | 欧美一区二区三区四区视频 | 国产精品美女一区二区在线观看| 久久精品国产精品| 欧美日韩在线播放一区二区| 久久成人精品无人区| 欧美日韩久久精品| 亚洲成人资源| 国产精品二区二区三区| 亚洲欧洲三级| 国产视频在线观看一区二区三区 | 亚洲欧美在线网| 亚洲国产精品女人久久久| 午夜精品久久久久久| 亚洲国产清纯| 久久精品二区亚洲w码| 99www免费人成精品| 久久夜色精品亚洲噜噜国产mv| 日韩午夜中文字幕| 麻豆精品视频在线| 午夜精品免费在线| 国产精品vvv| 99re66热这里只有精品3直播| 国产婷婷97碰碰久久人人蜜臀| 99这里有精品| 在线播放日韩| 久久精品五月婷婷| 亚洲视频欧美视频| 欧美日本韩国| 亚洲区国产区| 国产综合精品一区|