1.下载
https://github.com/kdlucas/byte-unixbench/archive/v5.1.3.tar.gz
2.修改Makefile 交叉编译
#CC=gcc
CC = arm-linux-gnueabihf-gcc
3.make
4.修改Run
将main函数中的 preChecks();注释掉,因为其中有 system(“make all”);
5.将编译过的整个byte-unixbench-5.1.3拷贝到开发板上。
已经手动编译过了,此时Run是在小板子上。
http://bbs.eeworld.com.cn/thread-503566-1-1.html
测试介绍
================================
UnixBench源于1995 年,基线系统是“George”,一个工作站:SPARCstation 20‐61,128MB
RAM,Solaris2.3,此系统的指数值被设定为10,所以,如果一个系统的最后结果分数为520,意思是指此系统比基线系统运行快52 倍。
UnixBench也支持多CPU系统的测试,默认的行为是测试两次,第一次是一个进程的测试,第二次是N份测试,N等于CPU个数。这样的设计是为了以下目标:
测试系统的单任务性能
测试系统的多任务性能
测试系统并行处理的能力
UnixBench一个基于系统的基准测试工具,不单纯是CPU 内存 或者磁盘测试工具。测试结果不仅仅取决于硬件,也取决于系统、开发库、甚至是编译器。
Dhrystone测试
测试聚焦在字符串处理,没有浮点运算操作。这个测试用于测试链接器编译、代码优化、内存缓存、等待状态、整数数据类型等,硬件和软件设计都会非常大的影响测试结果。
Whetstone 测试
这项测试项目用于测试浮点运算效率和速度。这项测试项目包含若干个科学计算的典型性能模块,包含大量的C语言函数,sin cos sqrt exp和日志以及使用整数和浮点的数学操作。包含数组访问、条件分支和过程调用。
Execl Throughput测试
(execl 吞吐,这里的execl是类unix系统非常重要的函数,非办公软件的excel)
这项测试测试每秒execl函数调用次数。execl是 exec函数家族的一部分,使用新的图形处理代替当前的图形处理。有许多命令和前端的execve()函数命令非常相似。
File Copy测试
这项测试衡量文件数据从一个文件被传输到另外一个,使用大量的缓存。包括文件的读、写、复制测试,测试指标是一定时间内(默认是10秒)被重写、读、复制的字符数量。
Pipe Throughput(管道吞吐)测试
pipe是简单的进程之间的通讯。管道吞吐测试是测试在一秒钟一个进程写512比特到一个管道中并且读回来的次数。管道吞吐测试和实际编程有差距。
Pipe-based Context Switching (基于管道的上下文交互)测试
这项测试衡量两个进程通过管道交换和整数倍的增加吞吐的次数。基于管道的上下文切换和真实程序很类似。测试程序产生一个双向管道通讯的子线程。
Process Creation(进程创建)测试
这项测试衡量一个进程能产生子线程并且立即退出的次数。新进程真的创建进程阻塞和内存占用,所以测试程序直接使用内存带宽。这项测试用于典型的比较大量的操作系统进程创建操作。
Shell Scripts测试
shell脚本测试用于衡量在一分钟内,一个进程可以启动并停止shell脚本的次数,通常会测试1,2, 3, 4, 8 个shell脚本的共同拷贝,shell脚本是一套转化数据文件的脚本。
System Call Overhead (系统调用消耗)测试
这项测试衡量进入和离开系统内核的消耗,例如,系统调用的消耗。程序简单重复的执行getpid调用(返回调用的进程id)。消耗的指标是调用进入和离开内核的执行时间。
================================
测试方法
首先确保被测试系统干净,没有后台大量占用资源的程序在运行。比较简单的方法是烧写一个新系统,做简单必要配置后,重启,就是一个干净的测试平台。如果是对比测试,把能控制的因素都控制成相同。比如测试Raspberry
2和3的时候,就可以使用同一张存储卡,系统版本也要保持一致。
把测试软件传到被测系统中,可以通过FTP等方法传输。
解压缩tar.gz包:
tar -xvf unixbench-5.1.2.tar.gz
cd unixbench-5.1.2
复制代码
如果是针对服务器等非图形环境的测试,需要关掉图形测试。
编辑文件Makefile
vim Makefile
复制代码
注释掉GRAPHIC_TESTS = defined这一行,也就是在这一行开头加个“#”号。我这个版本是在第46行。
保存文件。
编译
make clean
make all
复制代码
如果没有错误,就可以运行测试了
./Run
复制代码
在Raspberry上测试一次的时间大约是半小时左右。测试完成后,结果会在屏幕上显示出来,也可以在results目录里找到保存测试结果和相关log。
文件USAGE里写了更详细的测试参数,部分参数如下图
如果是一般测试,使用没有参数的默认设置就可以了,在多核系统上,软件会测试单核性能和多核性能各1次。
为了严谨起见,这样的测试应该测试多次,然后分数取平均值。不过既然是非专业测试,通常测试几次后发现分数比较稳定后,取其中一次作代表就可以了。如果分数波动很大,那就需要找找原因了。
http://blog.sina.com.cn/s/blog_7695e9f40100yimf.html
unixbench5测试内容包含了system、2d、3d、misc测试项。system测试系统的一些基本功能;2d测试2D图形加速;3d测试3D加速;misc测试诸如字符,整型等测试。详情见下面。
system:
dhry2reg Dhrystone 2 using register variables
whetstone-double Double-Precision Whetstone
syscall System Call Overhead
pipe Pipe Throughput
context1 Pipe-based Context Switching
spawn Process Creation
execl Execl Throughput
fstime-w File Write 1024 bufsize 2000 maxblocks
fstime-r File Read 1024 bufsize 2000 maxblocks
fstime File Copy 1024 bufsize 2000 maxblocks
fsbuffer-w File Write 256 bufsize 500 maxblocks
fsbuffer-r File Read 256 bufsize 500 maxblocks
fsbuffer File Copy 256 bufsize 500 maxblocks
fsdisk-w File Write 4096 bufsize 8000 maxblocks
fsdisk-r File Read 4096 bufsize 8000 maxblocks
fsdisk File Copy 4096 bufsize 8000 maxblocks
shell1 Shell Scripts (1 concurrent) (runs “looper 60 multi.sh 1”)
shell8 Shell Scripts (8 concurrent) (runs “looper 60 multi.sh 8”)
shell16 Shell Scripts (8 concurrent) (runs “looper 60 multi.sh 16”)
2d:
2d-rects 2D graphics: rectangles
2d-lines 2D graphics: lines
2d-circle 2D graphics: circles
2d-ellipse 2D graphics: ellipses
2d-shapes 2D graphics: polygons
2d-aashapes 2D graphics: aa polygons
2d-polys 2D graphics: complex polygons
2d-text 2D graphics: text
2d-blit 2D graphics: images and blits
2d-window 2D graphics: windows
3d:
ubgears 3D graphics: gears
misc:
C C Compiler Throughput (“looper 60 $cCompiler cctest.c”)
arithoh Arithoh (huh?)
short Arithmetic Test (short) (this is arith.c configured for
“short” variables; ditto for the ones below)
int Arithmetic Test (int)
long Arithmetic Test (long)
float Arithmetic Test (float)
double Arithmetic Test (double)
dc Dc: sqrt(2) to 99 decimal places (runs
“looper 30 dc < dc.dat”, using your system’s copy of “dc”)
hanoi Recursion Test — Tower of Hanoi
grep Grep for a string in a large file, using your system’s
copy of “grep”
sysexec Exercise fork() and exec().
unixbench5包含system和graphic测试,如果你需要测试graphic,则需要修改Makefile,不要注释掉”GRAPHIC_TESTS = defined,同时需要系统提供x11perf命令gl_glibs库。
进入源包,执行
make
◆ 执行system测试方法:Run
◆ 执行graphic测试方法:Run graphics
◆ 执行system,graphics测试方法:Run gindex
Run用法
Run [ -q | -v ] [-i <n> ] [-c <n> [-c <n> …]] [test …]
选项说明:
-q |
不显示测试过程 |
-v |
显示测试过程 |
-i <count> |
执行次数,最低3次,默认10 |
-c <n> |
每次测试并行n个copies(并行任务) |
备注:-c选项可以用来执行多次,如:
Run -c 1 -c 4表示执行两次,第一次单个copies,第二次4个copies的测试任务。
对于多cpu系统的性能测试策略,需要统计单任务,多任务及其并行的性能增强。
以4个cpu的PC为例,需要测试两次,4个CPU就是要并行执行4个copies,
Run -q -c 1 -c 4
测试结果单个并行的任务的得分为171.3,4个并行任务的得分为395.7。对比测试时需要关注这个值。