资源描述:
《可重构keccak算法设计及fpga实现》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、可重构Keccak算法设计及FPGA实现摘要:在分析研究keccak算法的基础上,针对现有keccak算法的硬件实现方案版本单一,应用不灵活的问题,设计了一种高性能可重构的keccak算法硬件实现方案。实验结果表明:该方案在xilinx公司的现场可编程门阵列(fpga)virtex5平台上的时钟频率可达214mhz,占用1607slices;该方案具有吞吐量高(9131mbps),应用灵活性好,可支持4种不同参数版本的优点。关键词:keccak算法;海绵结构;哈希算法;可重构;现场可编程门阵列re
2、configurablekeccakalgorithmanditsimplementationonfpgaplatformwuwufei1,wangyi1,2,3*,lirenfa1,2,3(1.embeddedsystemsandnetworkinglaboratory,hunanuniversity,changshahunan410082,china;2.hunanprovincegraduateinnovationbase,hunanuniversity,changshahu
3、nan410082,china;3.hunanprovincekeylaboratoryofnetworkandinformationsecurity,hunanuniversity,changshahunan410082,china)abstract:basedontheanalysisofkeccakalgorithm,concerningthesituationthattheexistinghardwareimplementationsofkeccakalgorithmlackofflexibil
4、ityandcouldonlysupportoneversion,thispaperproposedanewreconfigurablekeccakhardwareimplementation,whichcouldsupportfourversionsalgorithms.theproposeddesignachieved214mhzclockfrequencyusing1607sliceswhenbeingportedtoxilinxvirtex5fpgaplatform.theexperimenta
5、lresultsshowthattheproposeddesignhastheadvantagesofhighthroughput(9131mbps),goodflexibilityandsupportingfourversions.keywords:keccakalgorithm;spongestructure;hashalgorithm;reconfigurability;fieldprogrammablegatearray(fpga)0引言安全散列算法(securehashalgorithm,s
6、ha)[1]是由美国国家标准与技术研究院(nationalinstituteofstandardsandtechnology,nist)于1993年发布的一种数据加密算法。其主要思想是将可变长度的消息映射成固定长度的消息摘要,广泛应用于密码保护、消息鉴别、数据完整性验证以及数字签名等信息安全领域。nist先后发布了sha0、sha1和sha2共3个版本标准,随着计算机技术的飞速发展和破解技术的增强这3个版本逐个被成功攻击[2-4],因此nist采用公开竞赛的方式来制定新的安全散列算法即sha
7、3标准算法。经过两轮竞赛其中有5个算法成功进入到第三轮,分别是blake、grstl、jh、skein和keccak[5]1-7。目前国内对keccak研究较少,基于可重构技术的密码算法硬件实现的研究内容多集中于多个密码算法的整合实现[6]和一类密码算法的统一框架设计实现[7]等方面。国外已经有学者在硬件平台上实现keccak算法,如:爱尔兰国立考克大学的baldwin等[8]14在xilinxfpga上单个实现了keccak224、keccak256、keccak384与ke
8、ccak512,其最大的吞吐量为8518mbps(keccak384);日本情报通信研究机构的matsuo等[9]14同样在xilinxfpga上实现了keccak256,其吞吐量为8397mbps;strmbergson等[10]2实现了keccak256,在stratixⅲ平台上的吞吐量为10000mbps,同时在该平台上实现了面积最优的kecca