<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > EDA/PCB > 設(shè)計應(yīng)用 > 基于FPGA平臺的抗DPA攻擊電路級防護技術(shù)研究

          基于FPGA平臺的抗DPA攻擊電路級防護技術(shù)研究

          作者: 時間:2010-07-09 來源:網(wǎng)絡(luò) 收藏

          1.3 預(yù)充電技術(shù)的實現(xiàn)
          普通邏輯門不能提供持續(xù)轉(zhuǎn)換活動,邏輯門的輸入不變將導致門的數(shù)據(jù)獨立。解決這個問題要通過增加預(yù)充電來提供變換。當時鐘為高時,連接預(yù)充電輸入一個預(yù)充電相位,連接點變化到邏輯O;當時鐘為低時,輸入計算相位,實際計算完成。在上采用預(yù)充電邏輯的目的是要求在預(yù)充電相位期間slice的輸出必須是邏輯O,有兩種方式來完成。在一個Xilinx的slice中,每個LUT后跟著專門的多路選擇器和內(nèi)存單元,可配置為寄存器或鎖存器。這里考慮使用多路復用器和內(nèi)存單元來實現(xiàn)預(yù)充電,每種方法各有優(yōu)點和缺點:
          (1)使用時鐘控制的多路復用器來實現(xiàn)預(yù)充電功能。將每個片子中單獨的內(nèi)存單元作為寄存器,但是除了寄存器的普通時鐘還要分配一個反向時鐘。這種方法的缺點是復制一個時鐘信號并生成直接和互補信號將明顯增加功耗和電路面積,布線也將復雜化。
          (2)使用內(nèi)存單元作為帶有反向使能輸入的異步清零鎖存器來實現(xiàn)預(yù)充電功能。只需要一個單獨信號給寄存器和預(yù)充電鎖存器,預(yù)充電功能由連接反向使能輸入和鎖存器的清零輸入實現(xiàn),使用這種方法的缺點是專門設(shè)計的寄存器存儲器需要一個單獨的slice。

          2 DES加密模塊的實現(xiàn)
          要在上實現(xiàn)安全防護結(jié)構(gòu)來確保關(guān)鍵部件的功耗恒定。這里選擇從雙軌和預(yù)充電技術(shù)在上實現(xiàn)旁路安全防護邏輯。當前的技術(shù)水平需要在FPGA上進行精確控制布局和布線。下面從S盒硬件宏的實現(xiàn)和DES加密核的實現(xiàn)來介紹基于FPGA的DES加密模塊實現(xiàn)。
          2.1 S盒硬件宏的實現(xiàn)
          S盒的設(shè)計是DES算法關(guān)鍵部分,S盒設(shè)計的優(yōu)劣將影響整個算法性能。在采用FPGA實現(xiàn)時,應(yīng)從資源和速度的角度出發(fā),有效利用FPGA可配置屬性,充分考慮器件內(nèi)部結(jié)構(gòu),盡可能使兩者都達到最優(yōu)。在設(shè)計中,由于綜合工具的介入,所輸出的網(wǎng)表很難被設(shè)計者所理解,同時要找到一種更好的方法來控制組合電路,因此要建立硬件宏模塊,簡稱硬宏。這與傳統(tǒng)的設(shè)計流程不同之處是要充分利用:FPG Editor的功能,目的是從FPGA底層結(jié)構(gòu)的配置上實現(xiàn)雙軌和預(yù)充電技術(shù)。
          通過Xilinx提供的FPGA Editor工具,首先讀入布局布線后輸出的NCD文件,并將其轉(zhuǎn)化為新的NVD文件,再送往BitGen軟件,進行布局布線的優(yōu)化,最終在FPGA內(nèi)部來建立目標電路,把它存為一個宏文件便于在上層進行調(diào)用。要注意兩個問題:建立硬宏需要進入到slice內(nèi)部,準確控制Slice內(nèi)部的器件選擇和器件之間的連線,防止設(shè)計出錯;宏的功能驗證要建立仿真模型,直接編寫一個行為仿真模型后在上層設(shè)計中調(diào)用這個仿真模型,要確保仿真模型和宏之間的一致性。
          2.2 DES加密核的實現(xiàn)
          DES算法的基本流程如下:首先,輸入明文通過初始置換,將其分成左、右各為32位的兩個部分,然后進行16輪完全相同的運算。經(jīng)過16輪運算后,左、右半部分合并在一起經(jīng)過一個末置換(初始置換的逆置換),于是整個算法結(jié)束。在每一輪運算中,密鑰位移位,然后再從密鑰的56位中選取48位。通過一個擴展置換,將數(shù)據(jù)的右半部分擴展為48位,并通過一個異或操作與一個48位密鑰結(jié)合,通過8個S盒將這48位替代成新的32位數(shù)據(jù),再通過一級置換操作,這四步操作即為函數(shù)f。
          S盒是DES中的非線性模塊,直接決定DES算法的安全性。在函數(shù)f的實現(xiàn)中,采用上面的思路,使用例化調(diào)用了S盒。DES加密核的VHDL設(shè)計思路如下:首先調(diào)用庫函數(shù)構(gòu)造ROM,然后使用VHDL語句進行行為描述。這種方法要結(jié)合器件的內(nèi)部結(jié)構(gòu),對于小容量的ROM采用數(shù)組描述,大容量的ROM應(yīng)采用元件的方式來實現(xiàn)。在VHDL設(shè)計中,庫函數(shù)、子程序的調(diào)用以及元件的調(diào)用和使用間接變量,都是影響速度的主要因素。由此得到DES Core的接口定義如下:


          DIY機械鍵盤相關(guān)社區(qū):機械鍵盤DIY




          關(guān)鍵詞: FPGA DPA 攻擊 電路

          評論


          相關(guān)推薦

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

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();