《電子技術(shù)應用》
您所在的位置:首頁 > 可編程邏輯 > 設計應用 > 基于Xilinx FPGA的片上系統(tǒng)無線保密通信終端
基于Xilinx FPGA的片上系統(tǒng)無線保密通信終端
摘要: 本設計使用硬件描述語言VHDL在FPGA數(shù)字邏輯層面上實現(xiàn)AES加解密,為了系統(tǒng)的擴展性和構(gòu)建良好的人機交互,設計通過PS/2鍵盤輸入加密密鑰,并將其顯示在LCD上。在軟核MicroBlaze上,通過SPI總線讀寫FIFO和RAM控制射頻芯片CC2420,使系統(tǒng)具有信道選擇、地址識別、自動CRC校驗功能,使系統(tǒng)更加安全、通信誤碼率更低。
Abstract:
Key words :

  0 引言

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

  1 系統(tǒng)設計思想

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

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

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

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

  為了確保數(shù)據(jù)不出錯和不丟失,本設計采用了CRC校驗、超時重傳、返回ACK和NOACK等措施來確保數(shù)據(jù)的不出錯和丟失,

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

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

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

  3.1.1 AES簡介

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

  3.1.2 AES加解密模塊設計

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

 ?、?字節(jié)代換模塊

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

  ②密鑰擴展模塊

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

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

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


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

 

  3.3 軟核控制模塊
 
  3.3.1 軟核MicroBlaze簡介
 
  MicroBlaze 是一款由xilinx公司開發(fā)的嵌入式處理器軟核,其采用RISC(Reduced Instruction Set Computer)優(yōu)化架構(gòu)。它符合IBM CoreConnect標準,能夠與PPC405系統(tǒng)無縫連接[3]。MicroBlaze是一個非常簡化卻具有較高性能的軟核,在Spartan3E系列FPGA中它只占400個Slice,相當于10萬門FPGA容量的1/3。其為哈佛結(jié)構(gòu),32位地址總線,獨立的指令和數(shù)據(jù)緩存,并且有獨立的數(shù)據(jù)和指令總線連接到IBM的PLB總線,使得它能很容易和其它外設IP核一起完成整體功能。支持SPI、I2C、PCI、CAN總線,支持重置、硬件異常、中斷、用戶異常、暫停等機制,可配置UART、GPIO等接口。
 
  3.3.2 microblaze的控制流程
 
                                               圖3 microblaze的控制流程
 
  3.3.3 microblaze的控制流程主程序
 
  main () {
 
  Initial()//初始化系統(tǒng);
 
  CmdSend()//上位機命令輸入;
 
  DataRev()//數(shù)據(jù)接收;
 
  AESEny()//數(shù)據(jù)加密;
 
  DataPackage()數(shù)據(jù)打包;
 
  CC2420Sen()加密數(shù)據(jù)發(fā)送;
 
  Return success; }
 
  結(jié)語
 
  本系統(tǒng)將軟件加解密(在50M的頻率下使用軟件來進行加解密)與硬件加解密時間做了對比:如表3所示。
                                           表3 軟件和硬件加密對比
                                        表4 AES加密占用FPGA資源統(tǒng)計表
 
  該方案充分有效的利用了Spartan 3E的資源,尤其為可編程邏輯和RAM的利用。其中AES加解密中的乘法運算均由LUT查找表來實現(xiàn),用空間換取時間,獲得了很高的算法速度。在AES算法測試時我們發(fā)現(xiàn)80%的AES加解密時間都用于密鑰擴展算法中,如果能再進一步把算法優(yōu)化,比如做成流水線的算法模式的話,加解密時間又能減少近20%,即由現(xiàn)在的6.74us減少到略大于5.39us,效率又可以增加很多。
 
  參考文獻:
 
  [1]AES算法FPGA實現(xiàn)分析,唐金藝,[M] 海軍計算技術(shù)研究所
 
  [2]唐明,張煥國,劉樹渡等 AES的高性能硬件設計與研究 [M] 武漢大學計算機學院
 
  [3]趙峰 馬迪民 孫偉等 FPGA上的嵌入式設計[M] 2008.4
 
  [4]佟玉偉 陸浪如 FPGA先進加密算法 (AES) 的并行實現(xiàn) [M] 交通與計算機 2002.6
此內(nèi)容為AET網(wǎng)站原創(chuàng),未經(jīng)授權(quán)禁止轉(zhuǎn)載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
久久久久天天天天| 欧美国产精品中文字幕| 久久精品一区二区三区中文字幕| 日韩亚洲一区在线播放| 亚洲国产精品精华液2区45| 国产人成一区二区三区影院| 国产精品久久久久999| 欧美日韩在线大尺度| 欧美激情亚洲激情| 欧美成人激情视频| 玖玖在线精品| 久久综合中文色婷婷| 久久久亚洲国产天美传媒修理工| 欧美一区二区日韩| 午夜免费在线观看精品视频| 亚洲欧美国产日韩天堂区| 亚洲一二三区精品| 亚洲午夜av电影| 亚洲校园激情| 亚洲一区日本| 午夜精品久久| 欧美一区1区三区3区公司| 午夜在线视频一区二区区别| 欧美一区二区三区播放老司机| 性欧美超级视频| 羞羞答答国产精品www一本| 亚洲欧美日韩国产成人精品影院 | 亚洲日本中文字幕| 亚洲日本aⅴ片在线观看香蕉| 亚洲国内自拍| 99国内精品久久久久久久软件| 一本色道久久综合一区| 亚洲综合视频网| 久久国产手机看片| 浪潮色综合久久天堂| 欧美搞黄网站| 国产精品va在线播放我和闺蜜| 国产精品另类一区| 国产曰批免费观看久久久| 一区二区三区在线免费观看 | 91久久国产综合久久| 日韩一级免费| 亚洲欧美日韩精品| 久久尤物视频| 欧美日韩在线观看视频| 国产欧美一区二区精品性色 | 精品成人一区二区三区| 91久久精品日日躁夜夜躁国产| 一本色道久久88亚洲综合88| 亚洲欧美在线一区二区| 亚洲激情午夜| 亚洲一区二区三区精品视频| 久久激情视频久久| 欧美噜噜久久久xxx| 国产欧美日韩91| 亚洲精品1234| 性欧美暴力猛交69hd| 日韩午夜在线播放| 欧美在线一二三四区| 欧美激情精品久久久久久| 国产精品成人aaaaa网站| 黄色成人片子| 亚洲天堂男人| 91久久精品美女高潮| 亚洲字幕在线观看| 欧美高清在线播放| 国产情侣一区| 亚洲美女少妇无套啪啪呻吟| 香蕉亚洲视频| 一区二区三区欧美在线观看| 久久免费精品视频| 国产精品成人一区二区| 在线观看欧美精品| 亚洲欧美国产一区二区三区| 99国产精品久久久久久久久久| 欧美一区二区三区电影在线观看| 欧美国产在线视频| 国产亚洲欧美一区二区三区| 99热精品在线| 最新亚洲电影| 久久久噜噜噜久久久| 国产精品久久久久久久久婷婷| 亚洲成色www8888| 午夜精品久久久久久| 亚洲图片在区色| 免费日韩成人| 国产一区二区视频在线观看| 亚洲特级片在线| 一区二区高清在线| 欧美大片国产精品| 红杏aⅴ成人免费视频| 小黄鸭视频精品导航| 亚洲综合激情| 欧美日韩国产首页在线观看| 影音先锋在线一区| 午夜精品久久久久久99热| 亚洲专区欧美专区| 欧美日韩视频不卡| 亚洲人成在线影院| 亚洲国产欧美一区| 久久久久一区二区三区| 国产精品视频精品| 亚洲网站视频福利| 中文欧美日韩| 欧美日韩精品一区二区| 亚洲电影免费| 亚洲国产精品专区久久| 久久深夜福利| 国产一区二区三区网站| 午夜日韩av| 欧美一区二区免费| 国产精品一区二区三区久久| 亚洲网站啪啪| 亚洲欧美综合v| 国产精品久久久亚洲一区 | 亚洲福利视频网站| 久久久久免费| 国模套图日韩精品一区二区| 欧美一区二区三区免费观看视频| 小辣椒精品导航| 国产精品久线观看视频| 国产精品99久久久久久白浆小说| 亚洲午夜激情网站| 国产精品sss| 亚洲自拍都市欧美小说| 性欧美在线看片a免费观看| 国产精品一区免费观看| 午夜精品视频在线观看一区二区| 欧美一区二区福利在线| 国产精品自拍网站| 欧美一进一出视频| 久久婷婷久久一区二区三区| 一区二区三区自拍| 91久久香蕉国产日韩欧美9色| 免费一级欧美片在线播放| 亚洲黄色成人网| 国产精品99久久久久久宅男| 欧美视频一区二区| 亚洲一区二区视频在线| 欧美一区观看| 韩日精品中文字幕| 亚洲激情视频| 欧美三日本三级少妇三99| 亚洲图片在线观看| 久久久久久9| 亚洲国产三级| 亚洲女同性videos| 国产亚洲精品aa| 亚洲国产日韩一区| 欧美日韩免费看| 亚洲欧美www| 免费成年人欧美视频| 亚洲精品偷拍| 亚洲欧美日韩精品在线| 狠色狠色综合久久| 中文av字幕一区| 国产日韩三区| 亚洲日韩中文字幕在线播放| 欧美日韩精品二区| 亚洲欧美日韩国产精品| 蜜臀91精品一区二区三区| 99国内精品久久久久久久软件| 午夜视频一区在线观看| 黄色精品一区二区| 一区二区三区欧美在线| 国产日韩精品一区观看| 亚洲精品在线观| 国产精品呻吟| 亚洲欧洲日产国产网站| 国产精品夫妻自拍| 亚洲第一视频网站| 欧美视频精品一区| 欧美在线高清视频| 欧美日本在线播放| 欧美亚洲综合在线| 欧美日韩高清在线播放| 欧美一区二区视频免费观看 | 欧美精品国产精品日韩精品| 亚洲永久在线观看| 欧美夫妇交换俱乐部在线观看| 亚洲午夜在线视频| 欧美成人国产一区二区| 亚洲欧美国产一区二区三区| 欧美激情综合五月色丁香小说| 亚洲自拍偷拍一区| 欧美国产日本在线| 欧美一区二区三区电影在线观看| 欧美日韩国产成人| 欧美在线免费观看亚洲| 欧美日韩影院| 亚洲日本成人女熟在线观看| 国产精品毛片a∨一区二区三区|国| 亚洲国产精品久久精品怡红院| 国产精品美女www爽爽爽| 亚洲日本va在线观看| 国产婷婷97碰碰久久人人蜜臀| 在线性视频日韩欧美| 在线观看一区视频| 欧美在线视频一区| 一区二区91|