1.软件版本

MATLAB2013b,quartusii12.1

2.本算法理论知识

        标准的TEA算法使用64位的明文分组和128位的密钥,它使用Feistel分组加密框架,至少 32 轮的加密循环次数。该算法使用了一个神秘常数δ作为倍数,它来源于黄金比率,以保证每一轮加密都不相同。但δ的精确值并不重要,通常情况下,TEA 算法把它定义为

0x 9e3779b9(16进制数)。TEA算法每一次可以操作64bit(8byte),采用128bit(16byte)作为key,算法采用迭代的形式。 

        这里TEA算法的基本结构框图如下图所示:

【TEA算法】基于FPGA的TEA算法的实现_d3

1 Two Feistel rounds(one cycle)of TEA

        TEA加密算法的主要步骤如下所示:

for (i=0; i < 32; i++)

{                           

    sum += delta;

    v0 += ((v1<<4) + k0) ^ (v1 + sum) ^ ((v1>>5) + k1);

    v1 += ((v0<<4) + k2) ^ (v0 + sum) ^ ((v0>>5) + k3);

}

v[0]=v0; v[1]=v1;

       TEA解密算法的主要步骤如下所示:

for(i=0; i<32; i++)

{                              

   v1 -= ((v0<<4) + k2) ^ (v0 + sum) ^ ((v0>>5) + k3);

   v0 -= ((v1<<4) + k0) ^ (v1 + sum) ^ ((v1>>5) + k1);

   sum -= delta;                

}

v[0]=v0; v[1]=v1;

        在上面的加密和解密过程中:

         X+sum表示X和sum相加;

         A^B表示A和B做异或处理;

         A<<K,表示将数值A按二进制左移4位;

         A>>K,表示将数值A按二进制右移4位;

这里,分别设计到加法计算单元,异或计算单元和移位计算单元。

3.部分核心代码

    ·TEA加密算法的VHDL实现        

        加密部分,其VHDL代码如下所示:

if(Round_Times < 64) then

    sum        :=sum+delta;

    z_total    :=((z(27 downto 0)&"0000")+k(0))XOR(sum + z)XOR(("00000"&z(31 downto 5))+k(1));

    y             :=y+z_total;

    y_total    :=((y(27 downto 0)&"0000")+k(2))XOR(sum + y)XOR(("00000"&y(31 downto 5))+k(3));

    z             :=z+y_total;

   output_Enc <=y&z;      

end if;

    ·TEA解密算法的VHDL实现        

        解密部分,其VHDL代码如下所示:

if(Round_Times=64)then

    sum:= (delta(26 downto 0)) & "00000";

end if;

    y_total    :=((y(27 downto 0)&"0000")+k(2))XOR(sum + y)XOR(("00000"&y(31 downto 5))+k(3));

    z              :=  z-y_total;

    z_total    :=((z(27 downto 0)&"0000")+k(0))XOR(sum + z)XOR(("00000"&z(31 downto 5))+k(1));

     y             :=  y-z_total;

     sum        :=  sum-delta;

     output_Dec <=  y&z;

end if

4.操作步骤与仿真结论

·Single Round模式的仿真

8bits

【TEA算法】基于FPGA的TEA算法的实现_加密算法_02

     由于没有8bit的文件,我们这里输入数据为AC,密钥信息为:1,2,3,4。从QUARTUSII的仿真结果可知,系统是正确的。这里,当加密次数为1的时候,加密后的数据为0A,和MATLAB中的仿真一致。

16bits

【TEA算法】基于FPGA的TEA算法的实现_数据_03

         MATLAB中的mat文件test_data_16_1_18.mat可知,输入数据为A1D3,密钥信息为:A8,C3,95,CC。从QUARTUSII的仿真结果可知,系统是正确的。这里,当加密次数为1的时候,加密后的数据为3E22,和MATLAB中的仿真一致。

·16 Round模式的仿真

8bits

【TEA算法】基于FPGA的TEA算法的实现_d3_04

     由于没有8bit的文件,我们这里输入数据为AC,密钥信息为:1,2,3,4。从QUARTUSII的仿真结果可知,系统是正确的。这里,当加密次数为16的时候,加密后的数据为5B,和MATLAB中的仿真一致。

16bits

【TEA算法】基于FPGA的TEA算法的实现_fpga开发_05

         MATLAB中的mat文件test_data_16_1_18.mat可知,输入数据为A1D3,密钥信息为:A8,C3,95,CC。从QUARTUSII的仿真结果可知,系统是正确的。这里,当加密次数为1的时候,加密后的数据为E52F,和MATLAB中的仿真一致。

·标准TEA算法,64bits32 rounds

         这个部分的QUARTUSII的仿真结果如下图所示:

【TEA算法】基于FPGA的TEA算法的实现_fpga开发_06

         MATLAB中的mat文件test_data_64_1_18.mat可知,输入数据为B561CF9BFC637BC0,密钥信息为:F7845289,E7CD35ED, BE05AD82, E0DD2879。从QUARTUSII的仿真结果可知,系统是正确的。

5.参考文献

[01]Andem, Vikram Reddy(2003).A Cryptanalysis of the Tiny Encryption Algorithm, Masters thesis.Tuscaloosa:The University of Alabama.

​http://home.uchicago.edu/~andem/Vikram_Andem.pdf.​

[02]Hernández, Julio César; Isasi, Pedro; Ribagorda,Arturo(2002)."An application of genetic algorithms to the cryptoanalysis of one round TEA". Proceedings of the 2002 Symposium on Artificial Intelligence and its Application.

​http://www.actapress.com/PDFViewer.aspx?paperId=26972.​

[03]Hernández, Julio César;Sierra,JoséMaría;Isasi,Pedro;Ribargorda.Arturo(2003)."Finding efficient distinguishers for cryptographic mappings, with an application to the block cipher TEA". Proceedings of the 2003 Congress on Evolutionary Computation 3:2189.doi:10.1109 /CEC.

​http://ieeexplore.ieee.org/xpl/freeabs_all.jsp?arnumber=1299943.A28-31​