[发明专利]兼容SM4和AES算法S盒的实现方法和电路模块有效
申请号: | 202110774994.2 | 申请日: | 2021-07-08 |
公开(公告)号: | CN113507357B | 公开(公告)日: | 2022-03-11 |
发明(设计)人: | 朱敏 | 申请(专利权)人: | 无锡沐创集成电路设计有限公司 |
主分类号: | H04L9/06 | 分类号: | H04L9/06 |
代理公司: | 苏州华博知识产权代理有限公司 32232 | 代理人: | 杨敏 |
地址: | 214000 江苏省无锡市*** | 国省代码: | 江苏;32 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 兼容 sm4 aes 算法 实现 方法 电路 模块 | ||
1.一种兼容SM4和AES算法S盒的实现方法,其特征在于,包括如下步骤:
设计获得用于SM4和AES算法共享的辅助S盒S辅助(x)=A1·x-1+a1;
将输入数据x分成两路:第一路输入数据x和第二路输入数据x,其中,
第一路输入数据x先进行线性变换TSM4(x)=A·x+a,并随后将经线性变换的数据TSM4(x)进行辅助S盒运算SSM4(x)=S辅助(x)TSM4(x),从而获得SM4的S盒SSM4(x)=A1(A·x+a)-1+a1,
第二路输入数据x直接进行辅助S盒运算SAES辅助(x)=A1·x-1+a1,随后将经辅助S盒运算的数据SAES辅助(x)进行线性变换TAES(x)=Bx+b,从而获得AES的S盒SAES(x)=B1x-1+b1,其中,B1=BA1,b1=Ba1,其中,
线性变换TSM4(x)的矩阵A和常数矩阵a定义为:
线性变换TAES(x)的矩阵B和常数矩阵b定义为:
2.根据权利要求1所述的方法,其特征在于,辅助S盒为256字节的查找表。
3.根据权利要求2所述的方法,其特征在于,辅助S盒定义为如下的查找表:
4.根据权利要求1所述的方法,其特征在于,根据需要来选择所述经线性变换的数据TSM4(x)或者第二路输入数据x来进行辅助S盒运算,并根据需要来选择S盒SSM4(x)=A1(A·x+a)-1+a1或者S盒SAES(x)=B1x-1+b1作为最终输出的S盒。
5.根据权利要求4所述的方法,其特征在于,
当需要获得SM4的S盒时,选择所述经线性变换的数据TSM4(x)进行辅助S盒运算SSM4(x)=S辅助(x)TSM4(x),并选择S盒SSM4(x)=A1(A·x+a)-1+a1作为最终输出的S盒;
当需要获得AES的S盒时,选择所述第二路输入数据x进行辅助S盒运算SAES辅助(x)=A1·x-1+a1,并选择S盒SAES(x)=B1x-1+b1作为最终输出的S盒。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于无锡沐创集成电路设计有限公司,未经无锡沐创集成电路设计有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202110774994.2/1.html,转载请声明来源钻瓜专利网。