隨著計算機(jī)技術(shù)、微電子技術(shù)的不斷融合,嵌入式系統(tǒng)應(yīng)用得到了迅猛發(fā)展。近年來嵌入式技術(shù)廣泛用于解決保密信息的傳輸、存儲和管理方面的問題。而這些都需要嵌入式系統(tǒng)集成有可靠的加密模塊?,F(xiàn)有一些應(yīng)用中的加密模塊還不盡如人意。本文針對此應(yīng)用需求設(shè)計一種適用于嵌入式系統(tǒng)的加密IP核。
1 AES算法
1.1 AES算法描述
密鑰密碼體制分為流密碼和分組密碼兩種。分組密碼是信息與網(wǎng)絡(luò)安全中實現(xiàn)數(shù)據(jù)加密、數(shù)字簽名、認(rèn)證及密鑰管理的核心體制,具有速度快、易于標(biāo)準(zhǔn)化和便于軟硬件實現(xiàn)等特點。AES采用分組密碼的加密方式,其分組長度分為128 bit、192 bit、256 bit三種,AES密碼在相同的輪函數(shù)作用下,迭代運算次數(shù)的不同可達(dá)到不同級別的安全強(qiáng)度。128 bit分組長度的情況下,循環(huán)輪數(shù)指定為11次,目前還沒有可行的算法可以對該模型進(jìn)行有效攻擊。每一輪處理均為作用在中間結(jié)果上的一批運算,該中間結(jié)果稱為狀態(tài),用4&TImes;4字節(jié)矩陣表示,其中,數(shù)據(jù)矩陣稱為State、密鑰矩陣稱為Key。AES加密涉及5種運算,分別是字節(jié)代換 (SubBytes)、行移變換(ShiftRows)、列混合變換(MixColumns)、密鑰加法(AddRoundKey)和密鑰擴(kuò)展 (ExpandedKey)。
字節(jié)代換是對State每個字節(jié)進(jìn)行獨立非線性變換,由字節(jié)在GF(28)域中求其乘法逆并外加一個仿射變換完成。具體實現(xiàn)中廣泛使用查表方式完成該步變換(實現(xiàn)該功能單元被稱為Sbox),以避免復(fù)雜的乘法運算。
行移變換是對State進(jìn)行按行移位操作,第0行不移位,第1行循環(huán)左移一位,第2行循環(huán)左移兩位,第3行循環(huán)左移三位。
密鑰加法是將輪密鑰Key和狀態(tài)State中對應(yīng)字節(jié)按位“異或”。
密鑰擴(kuò)展提供輪變換對應(yīng)密鑰加法用到的各輪密鑰。各輪運算中使用到的輪密鑰都不相同,密鑰擴(kuò)展運算通過控制迭代運算次數(shù)計算出對應(yīng)輪所需輪密鑰。
加密過程由11輪運算組成,其中首輪只進(jìn)行密鑰加法,接著進(jìn)行9次輪變換,輪變換由字節(jié)代換、行移變換、列混合變換及密鑰加法4個步驟構(gòu)成,再進(jìn)行末輪變換,在末輪中跳過列混合變換。末輪完成后輸出密文數(shù)據(jù)。AES加密過程如圖1所示。
1.2 常用AES優(yōu)化實現(xiàn)
AES算法的輪操作特點看似更適合于在通用CPU平臺下編程實現(xiàn),而實際上,此種實現(xiàn)方式在性能方面存在加密速度慢等先天局限性。AES加密處理單元一般處于數(shù)據(jù)主干道上,其處理數(shù)據(jù)能力直接影響整個應(yīng)用系統(tǒng)的外在性能表現(xiàn),因此,研究數(shù)據(jù)處理能力強(qiáng)的硬件加密實現(xiàn)方式具有重要的意義。如何實現(xiàn)高性價比的硬件AES加密一直是加密算法應(yīng)用領(lǐng)域研究的熱點問題。
常見的硬件優(yōu)化實現(xiàn)有如下幾種方式:(1)串行方式。將輪函數(shù)展平,每輪對應(yīng)一級組合邏輯,11輪迭代過程直接相連,前一級輸出作為次一級的輸入,每一個時鐘周期均可完成一個分組處理;(2)迭代方式。各輪迭代只用一個對應(yīng)輪函數(shù)功能的組合邏輯實體實現(xiàn),每11個時鐘周期完成一個分組處理;(3)流水線方式。用于提高系統(tǒng)工作時鐘周期的流水線技術(shù),一般僅在局部使用,或是與串行方式并用,可提高工作時鐘頻率,使其滿足極大帶寬的應(yīng)用要求;(4)輪內(nèi)實現(xiàn)流水線。在輪函數(shù)對應(yīng)實體中插入寄存器,將一輪運算分至多個邏輯段完成,每個時鐘周期仍能完成一個數(shù)據(jù)分組處理。
以上AES算法實現(xiàn)方式各有優(yōu)缺點,但總體來說缺乏靈活性。當(dāng)前應(yīng)用于嵌入式系統(tǒng)的AES加密模塊在靈活性、資源占用上還不是很理想。在對常用優(yōu)化方法進(jìn)行研究后,本文針對嵌入式系統(tǒng)設(shè)計一種AES加密IP核、實現(xiàn)低資源占用、高性能要求、32位數(shù)據(jù)位寬、且能方便進(jìn)行并行連接,實現(xiàn)數(shù)據(jù)位寬擴(kuò)展。
2 IP核設(shè)計
2.1 系統(tǒng)架構(gòu)設(shè)計
IP系統(tǒng)分為時序控制、密鑰處理、數(shù)據(jù)處理三個主要單元,系統(tǒng)的工作模式分為閑置模式、密鑰輸入模式、單輪加密模式及連續(xù)加密模式。復(fù)位后系統(tǒng)處于閑置模式,單輪加密模式可以直接切換為連續(xù)加密模式,而連續(xù)加密模式需進(jìn)入到閑置模式至少一個時鐘周期后才可切換到單輪加密工作模式。
密鑰處理單元在系統(tǒng)進(jìn)入密鑰輸入模式后的連續(xù)4個時鐘周期從數(shù)據(jù)輸入端口讀入總共128位密鑰數(shù)據(jù),在第5個時鐘周期到來時完成第一輪密鑰的計算,然后系統(tǒng)返回閑置模式。在加密模式中密鑰處理單元按算法需求實時計算各輪密鑰,并按32位為一組輸出,與數(shù)據(jù)通道中32位數(shù)據(jù)進(jìn)行“異或”運算。在系統(tǒng)模式由加密模式轉(zhuǎn)為閑置模式時,完成密鑰處理單元的歸位動作,使得單元狀態(tài)與密鑰輸入后的狀態(tài)相同,為下一次加密做準(zhǔn)備。
數(shù)據(jù)處理單元在加密模式下對明文數(shù)據(jù)進(jìn)行迭代運算。該單元檢測到當(dāng)前是最末輪數(shù)據(jù)處理時自動跳過列混合運算。在系統(tǒng)進(jìn)入加密模式后,數(shù)據(jù)處理單元從輸入端口分4次讀入128位明文數(shù)據(jù),經(jīng)過接下來的40個時鐘周期數(shù)據(jù)運算過程后,得到密文中的第一個32位數(shù)據(jù)段。
時序控制單元負(fù)責(zé)整個系統(tǒng)關(guān)鍵控制信號的生成,控制信號集中由一個單元負(fù)責(zé)產(chǎn)生,不僅利于軟件綜合出較高的時鐘頻率,而且輸出的時鐘相位也有較優(yōu)的一致性。
系統(tǒng)正常工作狀態(tài)為先進(jìn)行一次密鑰載入操作,然后觸發(fā)進(jìn)入加密模式進(jìn)行多次的數(shù)據(jù)加密。在需要時可以在閑置狀態(tài)下再次進(jìn)行密鑰模式對密鑰進(jìn)行更新。
在系統(tǒng)閑置狀態(tài)下,密鑰加載信號被檢測為有效時,系統(tǒng)進(jìn)入密鑰輸入模式,對密鑰數(shù)據(jù)進(jìn)行讀入、保存及生成第一輪密鑰待用,而忽略密鑰處理單元中是否先前已存在密鑰數(shù)據(jù)。數(shù)據(jù)加載引腳指示系統(tǒng)由閑置模式輸入單輪加密模式,因為128位數(shù)據(jù)要在4個時鐘周期完成讀入,加密后數(shù)據(jù)也需要4個時鐘周期時間才能完成輸出。因此,從明文數(shù)據(jù)輸入到密文數(shù)據(jù)輸出共需要等待40個時鐘周期。如果此時檢測到數(shù)據(jù)加載引腳信號有效則在輸出密文的同時進(jìn)行下一輪明文的讀入,系統(tǒng)進(jìn)入到連續(xù)加密模式,否則在接下來的4個時鐘周期將密文輸出后系統(tǒng)由單輪加密模式切換到閑置模式。連續(xù)加密模式適合用于進(jìn)行批量數(shù)據(jù)加密處理,系統(tǒng)每40 個時鐘周期會從輸入端口讀入128位明文數(shù)據(jù),同時在這40個時鐘周期中將提供密文數(shù)據(jù)。在進(jìn)行大量數(shù)據(jù)處理時,載入密鑰及載入第一組加密數(shù)據(jù)的幾個時鐘周期均可忽略,系統(tǒng)性能為每40個時鐘周期處理128位數(shù)據(jù)。在讀入明文時,若檢測到載入數(shù)據(jù)信號無效,則退出連續(xù)加密模式,系統(tǒng)回復(fù)到閑置狀態(tài)。
-
嵌入式
+關(guān)注
關(guān)注
5152文章
19675瀏覽量
317647 -
IP
+關(guān)注
關(guān)注
5文章
1805瀏覽量
152607 -
IP核
+關(guān)注
關(guān)注
4文章
338瀏覽量
50818
原文標(biāo)題:一種適用于嵌入式系統(tǒng)的加密IP核可以這樣來設(shè)計!
文章出處:【微信號:mcuworld,微信公眾號:嵌入式資訊精選】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
基于XILINX FPGA片上嵌入式系統(tǒng)的用戶IP開發(fā)
嵌入式系統(tǒng)介紹
一種適用于嵌入式系統(tǒng)的模塊動態(tài)加載技術(shù)
嵌入式系統(tǒng)的定義和組成是什么
基于GPRS網(wǎng)絡(luò)的嵌入式系統(tǒng)的研究
一種適用于嵌入式數(shù)據(jù)庫的新索引機(jī)制
嵌入式系統(tǒng)的構(gòu)建
嵌入式AES加密IP核設(shè)計
一種適用于嵌入式系統(tǒng)的加密IP核設(shè)計詳解

一種適用于Nagle算法的簡化嵌入式TCP協(xié)議淺析

AD7775:L2MOS全嵌入式伺服前端,適用于硬盤過時數(shù)據(jù)表

適用于嵌入式C的AWS IoT設(shè)備開發(fā)工具包
適用于MSP430 MCUs的IAR嵌入式工作臺IDE版本7+

評論