當(dāng)前位置:首頁(yè) > 電源 > 數(shù)字電源
[導(dǎo)讀]本設(shè)計(jì)使用硬件描述語(yǔ)言VHDL在FPGA數(shù)字邏輯層面上實(shí)現(xiàn)AES加解密,為了系統(tǒng)的擴(kuò)展性和構(gòu)建良好的人機(jī)交互,設(shè)計(jì)通過(guò)PS/2鍵盤(pán)輸入加密密鑰,并將其顯示在LCD上。在軟核MicroBlaze上,通過(guò)SPI總線讀寫(xiě)FIFO和RAM控制射頻芯片CC2420,使系統(tǒng)具有信道選擇、地址識(shí)別、自動(dòng)CRC校驗(yàn)功能,使系統(tǒng)更加安全、通信誤碼率更低。

0 引言

  利用軟件實(shí)施加密算法已經(jīng)成為實(shí)時(shí)安全通信系統(tǒng)的重要瓶頸。標(biāo)準(zhǔn)的商品化CPU和DSP無(wú)法跟上數(shù)據(jù)加密算法的計(jì)算速度要求。此外,CPU和DSP需要完成太多的其他任務(wù)。基于FPGA高度優(yōu)化的可編程的硬件安全性解決方案提供了并行處理能力,并且可以達(dá)到所要求的加密處理性能基準(zhǔn)[1].然而如果僅使用FPGA可編程VHDL來(lái)實(shí)現(xiàn)的話,系統(tǒng)就不夠靈活,升級(jí)困難,況且實(shí)現(xiàn)起來(lái)有很大的難度,本系統(tǒng)以AES加密算法為例,使用Xilinx SPARTAN 3E為開(kāi)發(fā)平臺(tái),以Xilinx的嵌入式軟核Microblaze為主控制器,調(diào)用FPGA的硬件VHDL編程實(shí)現(xiàn)的AES加解密和控制CC2420來(lái)實(shí)現(xiàn)高速有效的數(shù)據(jù)通信。

  1 系統(tǒng)設(shè)計(jì)思想

  本設(shè)計(jì)使用硬件描述語(yǔ)言VHDL在FPGA數(shù)字邏輯層面上實(shí)現(xiàn)AES加解密,為了系統(tǒng)的擴(kuò)展性和構(gòu)建良好的人機(jī)交互,設(shè)計(jì)通過(guò)PS/2鍵盤(pán)輸入加密密鑰,并將其顯示在LCD上。在軟核MicroBlaze上,通過(guò)SPI總線讀寫(xiě)FIFO和RAM控制射頻芯片CC2420,使系統(tǒng)具有信道選擇、地址識(shí)別、自動(dòng)CRC校驗(yàn)功能,使系統(tǒng)更加安全、通信誤碼率更低。

  1.1 數(shù)據(jù)幀結(jié)構(gòu)設(shè)計(jì)

  為了更好的提高本系統(tǒng)數(shù)據(jù)的傳輸率,在官方zigbee的數(shù)據(jù)幀格式基礎(chǔ)上做了修改。采用如表5-2所示的數(shù)據(jù)幀格式。數(shù)據(jù)幀發(fā)送時(shí),CC2420自動(dòng)在數(shù)據(jù)包的開(kāi)始處加上前導(dǎo)碼和幀起始分隔符在數(shù)據(jù)包末尾加CRC檢驗(yàn)。
 

  1.2 數(shù)據(jù)可靠傳輸

  為了確保數(shù)據(jù)不出錯(cuò)和不丟失,本設(shè)計(jì)采用了CRC校驗(yàn)、超時(shí)重傳、返回ACK和NOACK等措施來(lái)確保數(shù)據(jù)的不出錯(cuò)和丟失,

  2  系統(tǒng)模塊構(gòu)成

  加密端通過(guò)串口和網(wǎng)口從發(fā)送段接收數(shù)據(jù),當(dāng)接收夠16字節(jié)(128bit),或不足時(shí)能自動(dòng)補(bǔ)零成128bit后送給硬件AES加密模塊。在軟核Microblaze的控制下通過(guò)VHDL編程的AES加密后將數(shù)據(jù)進(jìn)行組幀打包,通過(guò)軟核對(duì)CC2420的寄存器的讀寫(xiě)將數(shù)據(jù)通過(guò)無(wú)線發(fā)送端CC2420發(fā)送出去,同時(shí)等待發(fā)送段確認(rèn)。接收端在接收到數(shù)據(jù)以后,從數(shù)據(jù)包中將數(shù)據(jù)提取,進(jìn)行快速AES解密,解密完成后進(jìn)行CRC校驗(yàn),如果校驗(yàn)正確則向源地址發(fā)送ACK確認(rèn)。將正確數(shù)據(jù)送出,如果校驗(yàn)失敗,則返回NOACK。為了確保安全,AES加解密算法需要的密鑰key由鍵盤(pán)輸入和修改,同時(shí)可以在LCD上顯示出來(lái)。必須保證兩端key相同才能保證正常通信。

                                                                                    圖1 系統(tǒng)總體控制數(shù)據(jù)流圖
  3 AES加解密模塊

  3.1.1 AES簡(jiǎn)介

  AES加解密算法(Rijndael算法)對(duì)待加密的明文先進(jìn)行分段然后加密,明文的長(zhǎng)度可以是l28位、192位或256位。同樣,用于加密的密鑰長(zhǎng)度也有l(wèi)28位、192位或256位。根據(jù)明文及密鑰長(zhǎng)度不同的組合,加密的輪次有10輪、12輪和l4輪。在圈函數(shù)的每一圈迭代中,包括4步變換,分別是字節(jié)代換運(yùn)算、行變換、列混合以及圈密鑰的加法變換。經(jīng)過(guò)驗(yàn)證,選用l28位的明文和密鑰是幾種組合中加解密速度最快的[2]。所以在本系統(tǒng)設(shè)計(jì)中使用的為128位明文和128位密文的組合。由于AES為對(duì)稱加解密,所以在此文中我們只討論AES的加密方法,解密就是與AES對(duì)稱的方式來(lái)進(jìn)行的。

  3.1.2 AES加解密模塊設(shè)計(jì)

  在本系統(tǒng)中,使用了FPGA的硬件描述語(yǔ)言(VHDL)來(lái)實(shí)現(xiàn)了AES的加解密算法,AES分別為輪密鑰加、字節(jié)代換、行移位、列混淆、密鑰擴(kuò)展,下面為5個(gè)用硬件描述語(yǔ)言實(shí)現(xiàn)的小模塊的分別介紹。由于列混淆模塊、行移位模塊、輪密鑰加與文獻(xiàn)[4]中算法相同在此不做討論。

  ① 字節(jié)代換模塊

  此模塊為AES中的每一個(gè)字節(jié)提供了一個(gè)非線性代換。任一非零字節(jié)被函數(shù)所代替。如果x是零字節(jié),y=b 就是SubBytes變化的結(jié)果。在本設(shè)計(jì)中,為了加快算法速度,將S盒預(yù)先寫(xiě)入RAM中,直接用地址來(lái)指示替代的字節(jié),利用空間來(lái)?yè)Q時(shí)間,達(dá)到了加快用算的目的。

 ?、诿荑€擴(kuò)展模塊

  本設(shè)計(jì)采用了Xilinx IP核Single Block RAM 位寬32,深度64,在程序的開(kāi)始,由用戶設(shè)置的初始密鑰系統(tǒng)按照密鑰擴(kuò)展算法生成的10輪擴(kuò)展密鑰,將生成的密鑰按照地址次序從低到高放入RAM中,在每一輪執(zhí)行addroundkey時(shí)取出對(duì)應(yīng)輪數(shù)的密鑰,與明文相加(異或)。

                                                                        圖2 AES解密模塊仿真波形
  
        3.2 無(wú)線通信模塊

  在本系統(tǒng)中采用TI 公司的CC2420來(lái)實(shí)現(xiàn)數(shù)據(jù)的無(wú)線通信CC2420工作于免授權(quán)的2.4GHz頻段,33個(gè)16位配置寄存器、15個(gè)命令選通寄存器、1個(gè)128字節(jié)的RX RAM、1個(gè)128字節(jié)的TX RAM、1個(gè)112字節(jié)的安全信息存儲(chǔ)器。TX和RX RAM的存取可通過(guò)地址或者用兩個(gè)8位的寄存器。主機(jī)可通過(guò)SPI總線設(shè)置其工作在Normal模式,通過(guò)SPI總線MOSI,MISO接口對(duì)TX FIFO和RX FIFO及狀態(tài)進(jìn)行寫(xiě)和讀的操作,將數(shù)據(jù)寫(xiě)入和讀出RAM來(lái)實(shí)現(xiàn)與CC2420的數(shù)據(jù)傳輸,通過(guò)觸發(fā)CC2420STXON,SRXON來(lái)實(shí)現(xiàn)數(shù)據(jù)的無(wú)線發(fā)送和接收。表二是本系統(tǒng)CC2420涉及的寄存器及其功能。


  表2 是本系統(tǒng)CC2420涉及的寄存器及其功能

 [!--empirenews.page--]

  3.3 軟核控制模塊
 
  3.3.1 軟核MicroBlaze簡(jiǎn)介
 
  MicroBlaze 是一款由xilinx公司開(kāi)發(fā)的嵌入式處理器軟核,其采用RISC(Reduced Instruction Set Computer)優(yōu)化架構(gòu)。它符合IBM CoreConnect標(biāo)準(zhǔn),能夠與PPC405系統(tǒng)無(wú)縫連接[3]。MicroBlaze是一個(gè)非常簡(jiǎn)化卻具有較高性能的軟核,在Spartan3E系列FPGA中它只占400個(gè)Slice,相當(dāng)于10萬(wàn)門(mén)FPGA容量的1/3。其為哈佛結(jié)構(gòu),32位地址總線,獨(dú)立的指令和數(shù)據(jù)緩存,并且有獨(dú)立的數(shù)據(jù)和指令總線連接到IBM的PLB總線,使得它能很容易和其它外設(shè)IP核一起完成整體功能。支持SPI、I2C、PCI、CAN總線,支持重置、硬件異常、中斷、用戶異常、暫停等機(jī)制,可配置UART、GPIO等接口。
 
  3.3.2 microblaze的控制流程
 
                                               圖3 microblaze的控制流程
 
  3.3.3 microblaze的控制流程主程序
 
  main () {
 
  Initial()//初始化系統(tǒng);
 
  CmdSend()//上位機(jī)命令輸入;
 
  DataRev()//數(shù)據(jù)接收;
 
  AESEny()//數(shù)據(jù)加密;
 
  DataPackage()數(shù)據(jù)打包;
 
  CC2420Sen()加密數(shù)據(jù)發(fā)送;
 
  Return success; }
 
  結(jié)語(yǔ)
 
  本系統(tǒng)將軟件加解密(在50M的頻率下使用軟件來(lái)進(jìn)行加解密)與硬件加解密時(shí)間做了對(duì)比:如表3所示。
                                           表3 軟件和硬件加密對(duì)比
                                        表4 AES加密占用FPGA資源統(tǒng)計(jì)表
 
  該方案充分有效的利用了Spartan 3E的資源,尤其為可編程邏輯和RAM的利用。其中AES加解密中的乘法運(yùn)算均由LUT查找表來(lái)實(shí)現(xiàn),用空間換取時(shí)間,獲得了很高的算法速度。在AES算法測(cè)試時(shí)我們發(fā)現(xiàn)80%的AES加解密時(shí)間都用于密鑰擴(kuò)展算法中,如果能再進(jìn)一步把算法優(yōu)化,比如做成流水線的算法模式的話,加解密時(shí)間又能減少近20%,即由現(xiàn)在的6.74us減少到略大于5.39us,效率又可以增加很多。
 
  參考文獻(xiàn):
 
  [1]AES算法FPGA實(shí)現(xiàn)分析,唐金藝,[M] 海軍計(jì)算技術(shù)研究所
 
  [2]唐明,張煥國(guó),劉樹(shù)渡等 AES的高性能硬件設(shè)計(jì)與研究 [M] 武漢大學(xué)計(jì)算機(jī)學(xué)院
 
  [3]趙峰 馬迪民 孫偉等 FPGA上的嵌入式設(shè)計(jì)[M] 2008.4
 
  [4]佟玉偉 陸浪如 FPGA先進(jìn)加密算法 (AES) 的并行實(shí)現(xiàn) [M] 交通與計(jì)算機(jī) 2002.6
本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專(zhuān)欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車(chē)的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車(chē)技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車(chē)工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車(chē)。 SODA V工具的開(kāi)發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車(chē) 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來(lái)越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來(lái)越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開(kāi)幕式在貴陽(yáng)舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語(yǔ)權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉