本程序主要用来计算DMA数据读写过程中所花费的总得时间周期,依据公式T=tStart+ceil(L/4)*2+ceil(L/256)*tTransform*2

因为tTransform是一个常量(通常默认为11),因此只需根据debug文件分析出tStart即可。

一开始我以为tStart是一个变量,是buffer2-2(读)的开始时刻与准备时刻最后一个buffer2-17(写)的差值,因此写了

以下程序:

 #*************************************************************************

     # File Name: performance_testing.py
# Author: jiangjing
# Mail: jjdl@mail.ustc.edu.cn
# Created Time: Sat 15 Jul 2017 09:34:04 PM PDT
#************************************************************************\
import math
import sys def GetFirstBuffer2_2(path):
fDebug=open(path).read()
index2_2=fDebug.index("[buffer2-2]")
index_space=fDebug.index(" ",index2_2+17)
return [index2_2,fDebug[index2_2+17:index_space]] def GetLastBuffer2_17(path,index2_2):
fDebug=open(path).read()
index2_17=fDebug.rindex("[buffer2-17]",0,index2_2)
index_space=fDebug.index(" ",index2_17+18)
return [index2_17,fDebug[index2_17+18:index_space]] def GetTotalTime(L,path,tTransform=11): #the 'path' is the paht of debug file
buffer2_2=GetFirstBuffer2_2(path)
buffer2_17=GetLastBuffer2_17(path,buffer2_2[0])
return int(buffer2_2[1])-int(buffer2_17[1])+math.ceil(L/4)+math.ceil(L/256)*tTransform*2 #the code just for debug,you can comment the following code
if __name__=='__main__':
if(len(sys.argv)>1):
print(GetTotalTime(int(sys.argv[1]),sys.argv[2]))

但师兄说其实tStart也是一个常量,所以又将程序简化了以下:

 #*************************************************************************
# File Name: PerformanceTesting.py
# Author: jiangjing
# Mail: jjdl@mail.ustc.edu.cn
# Created Time: Sun 16 Jul 2017 06:12:22 AM PDT
#************************************************************************
import math tStart=2448
def GetTime(L,tTransform=11):
return tStart+math.ceil(L/4)+math.ceil(L/256)*tTransform*2 def GetTotalTime(lList):
totalTime=0
for l in lList:
L=l[4]
totalTime+=GetTime(L)
return totalTime

下面的这个test.py为测试样例:

 #*************************************************************************
# File Name: test.py
# Author: jiangjing
# Mail: jjdl@mail.ustc.edu.cn
# Created Time: Sun 16 Jul 2017 06:18:24 AM PDT
#************************************************************************
import PerformanceTesting as PT lList=[[0,0,0,0,65555],[0,0,0,0,672323]]
print(PT.GetTotalTime(lList))

考虑到测试的便捷性,师兄建议我采用c语言进行编写。

 一下为C语言版本代码:

 #include"stdio.h"
#include"math.h"
#include"conv2_route_plan.c"
#include"route_plan.h"
#define uint32_t unsigned long uint32_t tStart=;
uint32_t GetTime(uint32_t L){
return tStart+ceil(L/)*+ceil(L/)**;
} uint32_t GetTotalTime(route_plan_t lList){
uint32_t totalTime=;
uint32_t i;
for(i=;i<lList.num_item;i++)
{
totalTime+=GetTime(lList.route_item_array[i].len);
}
return totalTime;
} int main()
{
printf("%d\n",GetTotalTime(conv2_route_plan));
return ;
}

  其中“route_plan.h“是从师兄的项目中拷下来的,里面定义了输出数据的格式。

 #ifndef _ROUTE_PLAN_H_
#define _ROUTE_PLAN_H_ #include <stdint.h> typedef struct {
uint32_t src_buffer_id;
uint32_t src_buffer_offset;
uint32_t dest_buffer_id;
uint32_t dest_buffer_offset;
size_t len;
} route_item_t; typedef struct {
uint32_t num_item;
route_item_t* route_item_array;
} route_plan_t;
#endif // #ifndef _ROUTE_PLAN_H_

  其中“conv2_route_plan.c”文件是main.py文件运行输出的结果之一,里面包含了计算计算clock必要的数据。通过改变dsp的数目,本文件中的数据也会发生变化。

以下是dsp=32时的数据情况:

#include "route_plan.h"

route_item_t conv2_route_item_array[] = {
{, 0.0, , 57856.0, 404992.0},
{, 0.0, , 462848.0, 57856.0},
{, 347136.0, , 0.0, 57856.0},
{, 0.0, , 57856.0, 404992.0},
{, 0.0, , 462848.0, 57856.0},
{, 347136.0, , 0.0, 57856.0},
{, 0.0, , 57856.0, 404992.0},
{, 0.0, , 462848.0, 57856.0},
{, 347136.0, , 0.0, 57856.0},
{, 0.0, , 57856.0, 404992.0},
{, 0.0, , 462848.0, 57856.0},
{, 347136.0, , 0.0, 57856.0},
{, 0.0, , 57856.0, 404992.0},
{, 0.0, , 462848.0, 57856.0},
{, 347136.0, , 0.0, 57856.0},
{, 0.0, , 57856.0, 404992.0},
{, 0.0, , 462848.0, 57856.0},
{, 347136.0, , 0.0, 57856.0},
{, 0.0, , 57856.0, 404992.0},
{, 0.0, , 462848.0, 57856.0},
{, 347136.0, , 0.0, 57856.0},
{, 0.0, , 57856.0, 404992.0},
{, 0.0, , 462848.0, 57856.0},
{, 347136.0, , 0.0, 57856.0},
{, 0.0, , 57856.0, 404992.0},
{, 0.0, , 462848.0, 57856.0},
{, 347136.0, , 0.0, 57856.0},
{, 0.0, , 57856.0, 404992.0},
{, 0.0, , 462848.0, 57856.0},
{, 347136.0, , 0.0, 57856.0},
{, 0.0, , 57856.0, 404992.0},
{, 0.0, , 462848.0, 57856.0},
{, 347136.0, , 0.0, 57856.0},
{, 0.0, , 57856.0, 404992.0},
{, 0.0, , 462848.0, 57856.0},
{, 347136.0, , 0.0, 57856.0},
{, 0.0, , 57856.0, 404992.0},
{, 0.0, , 462848.0, 57856.0},
{, 347136.0, , 0.0, 57856.0},
{, 0.0, , 57856.0, 404992.0},
{, 0.0, , 462848.0, 57856.0},
{, 347136.0, , 0.0, 57856.0},
{, 0.0, , 57856.0, 404992.0},
{, 0.0, , 462848.0, 57856.0},
{, 347136.0, , 0.0, 57856.0},
{, 0.0, , 57856.0, 404992.0},
{, 0.0, , 462848.0, 57856.0},
{, 347136.0, , 0.0, 57856.0},
{, 0.0, , 57856.0, 404992.0},
{, 0.0, , 462848.0, 57856.0},
{, 347136.0, , 0.0, 57856.0},
{, 0.0, , 57856.0, 404992.0},
{, 0.0, , 462848.0, 57856.0},
{, 347136.0, , 0.0, 57856.0},
{, 0.0, , 57856.0, 404992.0},
{, 0.0, , 462848.0, 57856.0},
{, 347136.0, , 0.0, 57856.0},
{, 0.0, , 57856.0, 404992.0},
{, 0.0, , 462848.0, 57856.0},
{, 347136.0, , 0.0, 57856.0},
{, 0.0, , 57856.0, 404992.0},
{, 0.0, , 462848.0, 57856.0},
{, 347136.0, , 0.0, 57856.0},
{, 0.0, , 57856.0, 404992.0},
{, 0.0, , 462848.0, 57856.0},
{, 347136.0, , 0.0, 57856.0},
{, 0.0, , 57856.0, 404992.0},
{, 0.0, , 462848.0, 57856.0},
{, 347136.0, , 0.0, 57856.0},
{, 0.0, , 57856.0, 404992.0},
{, 0.0, , 462848.0, 57856.0},
{, 347136.0, , 0.0, 57856.0},
{, 0.0, , 57856.0, 404992.0},
{, 0.0, , 462848.0, 57856.0},
{, 347136.0, , 0.0, 57856.0},
{, 0.0, , 57856.0, 404992.0},
{, 0.0, , 462848.0, 57856.0},
{, 347136.0, , 0.0, 57856.0},
{, 0.0, , 57856.0, 404992.0},
{, 0.0, , 462848.0, 57856.0},
{, 347136.0, , 0.0, 57856.0},
{, 0.0, , 57856.0, 404992.0},
{, 0.0, , 462848.0, 57856.0},
{, 347136.0, , 0.0, 57856.0},
{, 0.0, , 57856.0, 404992.0},
{, 0.0, , 462848.0, 57856.0},
{, 347136.0, , 0.0, 57856.0},
{, 0.0, , 57856.0, 404992.0},
{, 0.0, , 462848.0, 57856.0},
{, 347136.0, , 0.0, 57856.0},
{, 0.0, , 57856.0, 404992.0},
{, 0.0, , 462848.0, 57856.0},
{, 347136.0, , 0.0, 57856.0},
{, 0.0, , 57856.0, 404992.0},
};
route_plan_t conv2_route_plan = {
.num_item = ,
.route_item_array = conv2_route_item_array
};

  

最后的测试结果如下表:

DMA性能测试的更多相关文章

  1. 【STM32H7教程】第62章 STM32H7的MDMA,DMA2D和通用DMA性能比较

    完整教程下载地址:http://www.armbbs.cn/forum.php?mod=viewthread&tid=86980 第62章       STM32H7的MDMA,DMA2D和通 ...

  2. Arduino Due, Maple and Teensy3.0 的 W5200性能测试

    开源平台中以太网连接方案里W5100是众所周知的,W5200正在此领域越来越受欢迎.这个测试结果是在Arduino Due(Atmel CortexM3-84Mhz), Maple(ST Cortex ...

  3. 6款实用的硬盘、SSD固态硬盘、U盘、储存卡磁盘性能测试工具

    一.检测工具名称汇总 HDTune ATTO Disk Benchmark CrystalDiskMark AS SSD Benchmark Parkdale CrystalDiskInfo 二.各项 ...

  4. Ignite性能测试以及对redis的对比

    测试方法 为了对Ignite做一个基本了解,做了一个性能测试,测试方法也比较简单主要是针对client模式,因为这种方法和使用redis的方式特别像.测试方法很简单主要是下面几点: 不作参数优化,默认 ...

  5. 性能测试工具 wrk 安装与使用

    介绍 今天给大家介绍一款开源的性能测试工具 wrk,简单易用,没有Load Runner那么复杂,他和 apache benchmark(ab)同属于性能测试工具,但是比 ab 功能更加强大,并且可以 ...

  6. .NET Core性能测试组件BenchmarkDotNet 支持.NET Framework Mono

    .NET Core 超强性能测试组件BenchmarkDotNet 支持Full .NET Framework, .NET Core (RTM), Mono. BenchmarkDotNet支持 C# ...

  7. C#中实现并发的几种方法的性能测试

    C#中实现并发的几种方法的性能测试 0x00 起因 去年写的一个程序因为需要在局域网发送消息支持一些命令和简单数据的传输,所以写了一个C/S的通信模块.当时的做法很简单,服务端等待链接,有用户接入后开 ...

  8. STM32基于HAL库通过DMA读写SDIO

    通过STM32CUBEMX生成DMA读写sdio的工程,再读写过程中总会卡死在DMA中断等待读写完成的while中,最终发现while等待的标志在SDIO的中断里置位的,而SDIO中断优先级如果小于或 ...

  9. 「视频直播技术详解」系列之七:直播云 SDK 性能测试模型

    ​关于直播的技术文章不少,成体系的不多.我们将用七篇文章,更系统化地介绍当下大热的视频直播各环节的关键技术,帮助视频直播创业者们更全面.深入地了解视频直播技术,更好地技术选型. 本系列文章大纲如下: ...

随机推荐

  1. windowService中使用多线程

    windowService中使用多线程 代码 using System;using System.Collections.Generic;using System.Linq;using System. ...

  2. aop 例子(annotation方式实现)

    面向切面编程(也叫面向方面),可以通过预编译方式和运行期动态代理实现在不修改源代码的情况下给程序动态统一添加功能的一种技术.AOP实际是GoF设计模式的延续,设计模式孜孜不倦追求的是调用者和被调用者之 ...

  3. Python 连接Oracle数据库

    连接:python操作oracle数据库  python——连接Oracle数据库 python模块:cx_Oracle, DBUtil 大概步骤: 1. 下载模块 cx_Oracle (注意版本) ...

  4. [转]从onload和DOMContentLoaded谈起

    这篇文章是对这一两年内几篇dom ready文章的汇总(文章的最后会标注参考文章),因为浏览器进化的关系,可能他们现在的行为与本文所谈到的一些行为不相符.我也并没有一一去验证,所以本文仅供参考,在具体 ...

  5. Windows C/C++调试

    windows兼容dirent.h error c4996: 'fopen': This function or variable may be unsafe This file requires _ ...

  6. PCB上的导线 怎么开窗 去掉绿油 把铜皮裸露

    开窗是个专业术语,你可以简单的理解为"去掉绿油,把铜皮裸露". 导线开窗用途一: 例如这个板子中的蛇形天线,就是导线开窗后的效果. 导线开窗用途二: 把需要过大电流的导线开窗,就可 ...

  7. 在Windows环境中学习Linux

    如何在Windows环境下学习Linux?方法如下: 方法一: 下载Cygwin,Cygwin是一个在windows平台上运行的类UNIX模拟环境,网上有很多安装教程,这里不多说. 方法二: 下载一个 ...

  8. nodejs链接mysql

    使用mysql连接池:1.安装mysql支持npm install mysql 2.安装node.js的mysqlpool模块npm install -g node-mysql //-g表全局 3.直 ...

  9. win764位安装mysql-5.6

    1配置mysql的MYSQL_HOME和PATH 增加环境变量: MYSQL_HOME=D:\mysql-5.6.14-winx64 修改环境变脸: 在path后面增加%MYSQL_HOME%\bin ...

  10. mysql 1069 数据库无法启动解决办法

    mysql无缘无故的启动不了了. 在控制台里面用root连接,报错10061. 在服务管理里面启动,报错1069. 在网上找了一些解决方法,删除my.ini之类的,都无效.后来在百度经验里面找到了可行 ...