2638|1

1万

帖子

25

TA的资源

裸片初长成(高级)

楼主
 

【TI首届低功耗设计大赛】FR5969 的AES模块使用 [复制链接]

FR5969 有个AES模块,使用起来很方便,简单地说,将数据写入再读出,就完成加密(解密)工作!


1、AES模块的组成:


上图中未画出控制寄存器。

由上图可见,事先设置好密钥,然后将数据从AESADIN输入,如果是OFB或CFB模式,可从AESAXDIN输入,使输入数据和原来的数据相异或。这样,解密时不仅需要密钥,而且还需要前后数据,使加密更加可靠。
最后从AESADOUT读出数据。
FR5969的AES模块是128位的,要处理的数应该是128的整数倍。

2、
过程就这么简单,下图是单个128位的加密过程:




在TI的库中,AES256.c文件,对数据的加密解密均使用8位操作,实际上,使用16位操作很方便,完全可以自己编制一加密(解密)函数使用。

解密过程与加密过程相同。

3、对于大块数据的加解密过程,可以使用DMA与AES模块结合使用最为方便。
  FR5969为AES模块提供了11、12、13这三个触发源。可以在加(解)密时使用,

例如在ECB时,使用11(AES trigger 0)、12(AES trigger 1)两个触发源:
          AES trigger 0会在加密准备就绪时触发,再次触发时是在数据全部从AESADOUT读出后。
         AES trigger 1,在装载首块数据时触发或上次AES trigger 0处理后,再次触发时是在128位数据写入AESADIN后。

由上可见,AES模块和DMA的配合是很好的。在CBC、OFB、CFB模式时,也都有基本相同的触了方法。


所以,AES配合DMA时(ECB模式)可以这样编程:


ECB_Encryption(key, plaintext, ciphertext, num_blocks)
{
       // Configure AES for block cipher:
        AESCMEN= 1;
        AESCMx= ECB;
        AESOPx= 00;
       // Write key into AESAKEY;
      for ( int i = 1; i < 8; i++)
      {
          AESAKEY = Key;
       }


       // Setup DMA:
       DMA0CTL = xxx;
      DMACTL0 = 11;                        // AES trigger 0触发DMA0
    DMA0SAL = AESADOUT;//
    DMA0DAL = (unsigned int) ciphertext;
    DMA0SZ  = ( num_blocks*8 words);


     DMACTL1 = 12;                        // AES trigger 1触发DMA1,
     …………
       // Start encryption:
     // 当AESBLKCNT=块长度时加密结束, DMA0IFG=1
}




最新回复

从来没有用过这个东西,感谢楼主分享,改天我也去试试  详情 回复 发表于 2014-12-27 09:54
 
点赞 关注

回复
举报

2057

帖子

0

TA的资源

五彩晶圆(初级)

沙发
 
从来没有用过这个东西,感谢楼主分享,改天我也去试试
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/6 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表