AES加解密效率测试(纯软件AES128/256)--以嵌入式Cortex-M0与M3 平台为例



AES256/128 纯软件加解密时间效率测试–以Cortex-M0与M3 MCU为例

  • 一、测试环境与方法
  • 二、测试代码介绍(以AES256为例)
  • 三、测试结果与抓包截图

AES软件源码库(C语言),包含全部CBC/CTR等模式,见链接:
http://download.csdn.net/download/howiexue/9978483

SHA、HMAC软件源码库(C语言)见链接:
http://download.csdn.net/download/howiexue/9978474

常见加密/签名/哈希算法性能比较 (多平台 AES/DES, DH, ECDSA, RSA等)
https://blog.csdn.net/howiexue/article/details/79283008

另一篇基于STM32L0x平台 **《SHA/HMAC/AES-CBC/CTR算法执行效率以及RAM消耗测试》**请见链接: http://blog.csdn.net/howiexue/article/details/78700694


一、测试环境与方法:

1、测试环境:MCU 为STM32F030(Cortex-M0)、STM32F103(Cortex-M3),主频分别统一设置为24M、48M

2、加解密算法:AESCBC-256以及128

3、测试方法:输入不同数据量,通过GPIO翻转法获取软件执行AES加解密所耗的时间


二、测试代码介绍(以AES256为例)

测试代码很简单,就是将一个GPIO拉高,在AES加解密时拉低,并用逻辑分析仪进行抓包或者示波器查看低电平的间隔。

这里以AESCBC256代码为例:(所有数据仅供测试所用)

准备AES 参数(key、iv、testdata等)

const unsigned char AES_key[32]		 = {0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f,0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f};

const unsigned char AES_iv[16]		 = {0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00};

unsigned char testdata[]= {
0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 以下省略, 想测多少就输入多少数据 。。。}

执行AES加解密 ,同时反转IO电平

void AesTest(void)
{
  int testdata_Len;
  testdata_Len=sizeof(testdata);
  Aes enc;
	for(int i=0; i<100;i++)
	{
	/******** 加密过程 ************/
	HAL_GPIO_WritePin(LED1_GPIO_Port,LED1_Pin,GPIO_PIN_SET);
    AesSetKey(&enc, AES_key, sizeof(AES_key), AES_iv, AES_ENCRYPTION);//初始化AES加密参数,IO电平为高   
    HAL_Delay(1);//delay 1 ms为加密,2ms为解密
    HAL_GPIO_WritePin(LED1_GPIO_Port,LED1_Pin,GPIO_PIN_RESET);    
    AesCbcEncrypt(&enc, (byte *)testdata, (byte *)testdata,   testdata_Len);//执行加密函数,此时电平为低
	HAL_GPIO_WritePin(LED1_GPIO_Port,LED1_Pin,GPIO_PIN_SET);
    HAL_Delay(2);
	 /******** 解密过程 ************/ 
     AesSetKey(&enc, AES_key, sizeof(AES_key), AES_iv, AES_DECRYPTION);//初始化AES解密参数,IO电平为高
    HAL_GPIO_WritePin(LED1_GPIO_Port,LED1_Pin,GPIO_PIN_RESET);    
    AesCbcDecrypt(&enc, (byte *)testdata, (byte *)testdata,   testdata_Len);执行解密函数,此时电平为低
    HAL_GPIO_WritePin(LED1_GPIO_Port,LED1_Pin,GPIO_PIN_SET);
	}


三、测试结果与抓包截图

1、主频统一设置为24M

这里写图片描述

附部分I2C抓包截图:

1024byte时M3工作在24M主频:

这里写图片描述

1024byte时M0工作在24M主频:

这里写图片描述

2、主频设置为48M

基于STM32F030C8(Cortex-M0)芯片,工作在48M主频:
这里写图片描述

附部分I2C抓包截图:

1024 – AES256 :

这里写图片描述

128 – AES256:

这里写图片描述

16 - AES256:

AES256

由此可见,AES(Advanced Encryption Standard) 加密算法相比于RSA等对称加密算法是非常快的。。


四、参考:官方数据AES硬件与软件加密效率

4.1 飞思卡尔单片机(M4)
这里写图片描述

这里写图片描述

4.2 STM32单片机(M3)

这里写图片描述


在这里插入图片描述

博主热门文章推荐:

一篇读懂系列:

LoRa Mesh系列:

网络安全系列:

嵌入式开发系列:

AI / 机器学习系列:


HLS(HTTP Live Streaming)是苹果公司提出的一种流媒体传输协议,而M3U8则是HLS流媒体的播放列表文件格式。在HLS中,媒体数据被分段传输,并通过M3U8文件来描述这些媒体段的详细信息。M3U8文件中包含了媒体段的URL地址,可以从服务器获取这些媒体段进行播放。 Sample-AES(Sample-based AES encryption)是HLS中对媒体段进行加密的一种方式。它使用AES(Advanced Encryption Standard)算法对每个媒体段进行加密,然后在M3U8文件中使用URI方式引用加密的密钥。这样,只有具有正确密钥的用户才能解密和播放这些加密的媒体段。 要实现HLS/M3U8的Sample-AES解密软件开发,需要考虑以下几个步骤: 1. 解析M3U8文件:通过解析M3U8文件,获取媒体段的URL地址和加密键信息。可以使用Python等编程语言来实现M3U8文件的解析。 2. 下载媒体段:根据M3U8文件中的URL地址,从服务器上下载加密的媒体段。可以使用HTTP请求库(如requests库)来发送HTTP请求并下载媒体段。 3. 获取密钥:从M3U8文件中的加密键信息中获取加密用的密钥。密钥通常以URI的形式给出,可以根据URI的规则找到对应的密钥。 4. 解密媒体段:使用AES算法和获取的密钥对下载的媒体段进行解密。可以使用AES加密库来实现解密算法。 5. 播放媒体:将解密后的媒体段进行播放。可以使用FFmpeg等多媒体处理库来实现播放功能。 总之,实现HLS/M3U8的Sample-AES解密软件开发,涉及到M3U8文件的解析、媒体段的下载、密钥的获取、媒体的解密和播放等步骤。通过合理选择编程语言和相关库,可以实现这一功能。
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

HowieXue

求打赏~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值