通过FPGA实现AES加密算法

总体结构设计

总体设计方案

整体模块按功能可分为加密部分和解密部分,通过输入端口mode进行选择。实际功能模块有,加密解密共用的密钥异或模块Xorkey,S盒替换模块Dsbox、Inv_sbox,行变换模块Row_trans,列混合模块Col_trans以及密钥扩展模块Key8bit。由于解密部分与加密的执行顺序不同以及解密部分密钥扩展的特殊性,针对解密部分还有时序调整 Time_adjust、Inv_comb模块,密钥存储模块Keysave,以及一片用于存储输入数据的FIFO。整体由Control模块控制。

对于加密,Xorkey模块将输入的数据进行异或,Dsbox由rom实现,行变换Row_trans模块输出地址至ram,Col_trans从ram中读取数据并进行相应的运算,密钥扩展与以上模块并行处理,一轮耗时22个时钟,从数据输入到输出完毕共用231个时钟,速率为27.7Mbps,资源消耗476LE。

对于解密,先算完十轮密钥扩展,并存至ram中,再进行类似加密的轮变换,只是密钥异或模块的密钥需从ram中取得。十轮密钥扩展完毕并存储花费227个时钟,十轮异或运算花费226个时钟,速率为14.1Mbps,资源消耗在600左右。(写解密的时候直接在加密模块上进行的逻辑修改,没有单独的数据,从后期结果推算的大致结果)。整体消耗805LES,RTL schematic图如下:

总体设计框图

总体设计框图如下:

其中part of decryption是指与解密与加密不同的部分,包括对扩展密钥的存储、用于输入数据的FIFO以及部分时序调整。控制模块Control用于加密和解密的切换。
下面分别从加密和解密两个部分进行子模块和结构的描述。

加密各部分结构设计

加密部分整体概述

加密部分算法流程图如下:
针对该加密算法,设计的模块及功能如下:
Xorkey:与扩展密钥进行异或运算
Dsbox:S盒变换
Row_trans:行变换
Col_trans:列变换
Key8bit:密钥扩展模块
下面一一进行阐述。

密钥异或模块Xorkey设计

密钥异或模块将输入的8bit明文和密钥进行异或,由输入使能enain控制,enaout为输出使能,消耗9个LE。

S盒变换模块Dsbox设计

Dsbox使用了双口rom,一方面用于变换Xorkey的输出数据,一方面用于密钥扩展时最后一列的S盒变换。

行变换模块Row_trans的设计

DSbox模块出输出数据通往ram,同时Row_trans模块接受到使能信号后,按照一定的规律向ram输入写入的数据地址,消耗20个LE。

Row_trans结构框图如下所示:

如上所示,使能信号为高时,计数器counter从0记到15,计算地址部分根据mode的不同输出相应的地址。Wren是ram的写使能信号,col_st是加密部分中通往列变换模块的使能信号。Addrout是通往ram的写地址,由于采用了乒乓操作,位宽为5。

列变换模块Col_trans的设计

加密和解密的列变换算法不同,在轮变换中的顺序也不同,解密稍复杂一些。在加密功能中,col_trans接收到col_st为高后,从ram中按顺序读出数据,采用并行计算的方法,读入一个数据进行4次计算,读入4个数据后可开始输出结果。由于列变换中使用的第4个数据是行变换之前的最后一个数据,因此在行变换开始后的12个时钟,列变换模块才能开始从ram中读取数据,又经过4个时钟后才能输出,故该模块需要16个时钟。加密加上解密的列变换一共消耗321个LE。


解密部分结构设计

加密部分总体概述

加密部分算法如下:

解密部分与加密部分大体一致,故而Xorkey、key8bit、用于行变换的dpram,用于key8bit的sbox是通用的,row_trans和col_trans进行了部分改变。同时,考虑到解密部分的密钥异或模块使用的密钥与密钥扩展运算顺序相反,即第一次密钥异或模块使用的密钥是密钥扩展第十轮的结果,第二次则为第九轮结果……故采取先算出十轮密钥扩展结果并进行存储,轮变换时再进行读取并运算的方法。
解密部分用于密钥扩展有Simreq, Time_adjust与Keysave模块,存储输入数据使用了一片FIFO,逆Sbox运算使用Inv_sbox模块,同时增加了用于调整运算顺序的Inv_comb模块。
解密部分的所有模块如下:
Inv_storekey:用于存输入数据的FIFO
Simkeyreq:模拟keyreq变化
Key8bit:密钥扩展模块(与加密共用)
Sbox用于密钥扩展部分(共用)
Time_adjust:密钥读写地址控制
Keysave:用于存扩展秘钥的ram
Xorkey:密钥异或模块(共用)
Inv_sbox:逆S盒变换
Row_trans:行变换(部分共用)
Dpram:用于行变换的ram(共用)
Col_tran:列变换(部分共用)
Inv_comb:解密运算顺序调整
下面重点阐述解密与加密不同的模块。

解密部分密钥扩展结构

由于key8bit消耗资源比较多,故解密部分需要充分利用key8bit模块。考虑到key8bit的使能输入是keyreq,持续16个周期的高电平,key8bit会算完一轮扩展密钥,故解密部分通过Simkeyreq模块模拟keyreq的变换控制key8bit进行十轮运算,Time_adjust模块用于输出相应的写地址至ram(keysave)中,同时也输出相应的写使能。Simkeyreq模块结构如下:

其中enain是用户的输入信号,cycle_cnt是来自key8bit的密钥扩展次数。Simkeyreq耗用17LE。 Time_adjust模块结构如下:

keyreq是来自Simkeyreq的信号,用于计算密钥扩展输出时的写地址与写使能信号wren,keyreqaddr是来自轮变换的取密钥信号,keyreqaddr为高时模块计算通往ram的读地址rd_addr。Inv_cyclecnt是轮变换的次数,用于计算rd_addr。Time_adjust耗用26个LE。 Keysave模块是一个准双口ram,用于存储扩展后的密钥。下图是Simkeyreq、keysave和Time_adjust模块连接示意图

密钥扩展花费226个时钟,写代码的时候这里没注意还能不能进行时间上的优化,之后会进一步考虑。

运算控制Inv_comb模块设计结构

由于解密部分与加密部分的运算顺序的不同,故设计一个Inv_comb模块进行密钥异或,行变换、列变换之间的调控以及轮变换进行次数的计算。

enain是行变换的输出使能,Rd_addr是通往行变换ram的读地址,enaout是通往Xorkey的输入使能,keyreqaddr是通往Time_adjust的扩展密钥读使能信号,Inv_cyclecnt是轮变换运算次数的输出。该模块消耗45个LE。写到这里发现该模块的rd_addr与列变化模块有重复之处,应该可以继续优化。

AES加密解密模块实现结果

按照本文所设计的结构,分别采用Altera公司的CycloneIV和Xilinx公司的Spartan6 xc6slx9FPGA进行综合,得到结果如下。

CycloneIV(LE) Spartan6(Slice)
加密 476(6%) 265(5%)
整体 805(13%) 463(8%)
加密速率为27.7Mbps,解密速率为14.1Mbps。考虑到秘钥扩展部分以及解密模块的部分逻辑重复应该还有一定的速率和资源的优化空间。

作者:Hu_Yang_BUAA
来源:CSDN
原文:https://blog.csdn.net/Hu_Yang_BUAA/article/details/52390389
版权声明:本文为博主原创文章,转载请附上博文链接!
作者:Hu_Yang_BUAA
来源:CSDN
原文:https://blog.csdn.net/hu_yang_buaa/article/details/52214852
版权声明:本文为博主原创文章,转载请附上博文链接!

题)

欢迎使用Markdown编辑器

你好! 这是你第一次使用 Markdown编辑器 所展示的欢迎页。如果你想学习如何使用Markdown编辑器, 可以仔细阅读这篇文章,了解一下Markdown的基本语法知识。

新的改变

我们对Markdown编辑器进行了一些功能拓展与语法支持,除了标准的Markdown编辑器功能,我们增加了如下几点新功能,帮助你用它写博客:

  1. 全新的界面设计 ,将会带来全新的写作体验;
  2. 在创作中心设置你喜爱的代码高亮样式,Markdown 将代码片显示选择的高亮样式 进行展示;
  3. 增加了 图片拖拽 功能,你可以将本地的图片直接拖拽到编辑区域直接展示;
  4. 全新的 KaTeX数学公式 语法;
  5. 增加了支持甘特图的mermaid语法1 功能;
  6. 增加了 多屏幕编辑 Markdown文章功能;
  7. 增加了 焦点写作模式、预览模式、简洁写作模式、左右区域同步滚轮设置 等功能,功能按钮位于编辑区域与预览区域中间;
  8. 增加了 检查列表 功能。

功能快捷键

撤销:Ctrl/Command + Z
重做:Ctrl/Command + Y
加粗:Ctrl/Command + B
斜体:Ctrl/Command + I
标题:Ctrl/Command + Shift + H
无序列表:Ctrl/Command + Shift + U
有序列表:Ctrl/Command + Shift + O
检查列表:Ctrl/Command + Shift + C
插入代码:Ctrl/Command + Shift + K
插入链接:Ctrl/Command + Shift + L
插入图片:Ctrl/Command + Shift + G

合理的创建标题,有助于目录的生成

直接输入1次#,并按下space后,将生成1级标题。
输入2次#,并按下space后,将生成2级标题。
以此类推,我们支持6级标题。有助于使用TOC语法后生成一个完美的目录。

如何改变文本的样式

强调文本 强调文本

加粗文本 加粗文本

标记文本

删除文本

引用文本

H2O is是液体。

210 运算结果是 1024.

插入链接与图片

链接: link.

图片: Alt

带尺寸的图片: Alt

居中的图片: Alt

居中并且带尺寸的图片: Alt

当然,我们为

  • 0
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值