Buildroot lmbench使用方法

/**********************************************************************
 *                 Buildroot lmbench使用方法
 * 说明:
 *     想在i.mx6上用Buildroot编译出lmbench,结果发现全是单独的命令,不知道
 * 怎么使用,脚本需要用到perl,所以编译需要选好perl。
 *
 *                                2018-6-21 深圳 宝安西乡 曾剑锋
 *********************************************************************/

一、参考文档:
    1. Performances
        http://www.armadeus.org/wiki/index.php?title=Performances
    2. Linux系统性能测试工具Lmbench
        https://wiki.deepin.io/mediawiki/index.php?title=Linux%E7%B3%BB%E7%BB%9F%E6%80%A7%E8%83%BD%E6%B5%8B%E8%AF%95%E5%B7%A5%E5%85%B7Lmbench
    3. 性能测试工具Lmbench使用说明
        https://wenku.baidu.com/view/aa29812727d3240c8447ef9a.html

二、解决办法:
    1. 将Buildroot编译出来的文件夹打包,目前我自己的是:/output/build/lmbench-3.0-a9
    2. 拷贝到主板上解压;
    3. cd /jump/to/lmbench/dir/
    4. cd scripts
    5. OS=arm ./config-run  (生成的配置放在后面)
        MULTIPLE COPIES [default 1] 2
        Job placement selection: 2
        MB [default ] 8
        SUBSET (ALL|HARWARE|OS|DEVELOPMENT) [default all] HARDWARE
        then default value (except for result mailing, choose no) except
        Processor mhz [default 189 MHz, 5.2910 nanosec clock] 192
        FSDIR [default /var/tmp] /mnt/host/
        Mail results [default yes] no
    6. OS=arm ./results
        Using config in CONFIG.buildroot
        Sat Jan  1 00:05:54 UTC 2000
        Latency measurements
        Sat Jan  1 00:06:50 UTC 2000
        Calculating file system latency
        Sat Jan  1 00:06:52 UTC 2000
        Local networking
        Sat Jan  1 00:09:36 UTC 2000
        Bandwidth measurements
        Sat Jan  1 00:17:04 UTC 2000
        Calculating context switch overhead
        Sat Jan  1 00:18:01 UTC 2000
        McCalpin's STREAM benchmark
        Sat Jan  1 00:18:38 UTC 2000
        Calculating memory load latency

        Sat Jan  1 00:27:37 UTC 2000
    7. ./getsummary ../results/arm/*,
                         L M B E N C H  3 . 0   S U M M A R Y
                         ------------------------------------
                         (Alpha software, do not distribute)

        Basic system parameters
        ------------------------------------------------------------------------------
        Host                 OS Description              Mhz  tlb  cache  mem   scal
                                                             pages line   par   load
                                                                   bytes
        --------- ------------- ----------------------- ---- ----- ----- ------ ----
        buildroot Linux 4.1.15+                     arm  996          64           2

        Processor, Processes - times in microseconds - smaller is better
        ------------------------------------------------------------------------------
        Host                 OS  Mhz null null      open slct sig  sig  fork exec sh
                                     call  I/O stat clos TCP  inst hndl proc proc proc
        --------- ------------- ---- ---- ---- ---- ---- ---- ---- ---- ---- ---- ----
        buildroot Linux 4.1.15+  996 0.23 0.56 5.70 12.1 19.7 0.66 4.03 1303 3049 7073

        Basic integer operations - times in nanoseconds - smaller is better
        -------------------------------------------------------------------
        Host                 OS  intgr intgr  intgr  intgr  intgr
                                  bit   add    mul    div    mod
        --------- ------------- ------ ------ ------ ------ ------

        Basic uint64 operations - times in nanoseconds - smaller is better
        ------------------------------------------------------------------
        Host                 OS int64  int64  int64  int64  int64
                                 bit    add    mul    div    mod
        --------- ------------- ------ ------ ------ ------ ------

        Basic float operations - times in nanoseconds - smaller is better
        -----------------------------------------------------------------
        Host                 OS  float  float  float  float
                                 add    mul    div    bogo
        --------- ------------- ------ ------ ------ ------

        Basic double operations - times in nanoseconds - smaller is better
        ------------------------------------------------------------------
        Host                 OS  double double double double
                                 add    mul    div    bogo
        --------- ------------- ------  ------ ------ ------

        Context switching - times in microseconds - smaller is better
        -------------------------------------------------------------------------
        Host                 OS  2p/0K 2p/16K 2p/64K 8p/16K 8p/64K 16p/16K 16p/64K
                                 ctxsw  ctxsw  ctxsw ctxsw  ctxsw   ctxsw   ctxsw
        --------- ------------- ------ ------ ------ ------ ------ ------- -------
        buildroot Linux 4.1.15+ 3.6900   10.8   21.9   26.8   46.8    33.3    49.3

        *Local* Communication latencies in microseconds - smaller is better
        ---------------------------------------------------------------------
        Host                 OS 2p/0K  Pipe AF     UDP  RPC/   TCP  RPC/ TCP
                                ctxsw       UNIX         UDP         TCP conn
        --------- ------------- ----- ----- ---- ----- ----- ----- ----- ----
        buildroot Linux 4.1.15+ 3.690  17.2 26.5  76.4        86.0

        *Remote* Communication latencies in microseconds - smaller is better
        ---------------------------------------------------------------------
        Host                 OS   UDP  RPC/  TCP   RPC/ TCP
                                       UDP         TCP  conn
        --------- ------------- ----- ----- ----- ----- ----
        buildroot Linux 4.1.15+

        File & VM system latencies in microseconds - smaller is better
        -------------------------------------------------------------------------------
        Host                 OS   0K File      10K File     Mmap    Prot   Page   100fd
                                Create Delete Create Delete Latency Fault  Fault  selct
        --------- ------------- ------ ------ ------ ------ ------- ----- ------- -----
        buildroot Linux 4.1.15+                              1998.0 0.207 1.42140 6.259

        *Local* Communication bandwidths in MB/s - bigger is better
        -----------------------------------------------------------------------------
        Host                OS  Pipe AF    TCP  File   Mmap  Bcopy  Bcopy  Mem   Mem
                                     UNIX      reread reread (libc) (hand) read write
        --------- ------------- ---- ---- ---- ------ ------ ------ ------ ---- -----
        buildroot Linux 4.1.15+ 453. 411. 238.  552.7 1214.5  591.4  537.1 1204 596.0

        Memory latencies in nanoseconds - smaller is better
            (WARNING - may not be correct, check graphs)
        ------------------------------------------------------------------------------
        Host                 OS   Mhz   L1 $   L2 $    Main mem    Rand mem    Guesses
        --------- -------------   ---   ----   ----    --------    --------    -------
        buildroot Linux 4.1.15+   996 4.0220   33.7        61.1       316.6

三、生成的配置
    DISKS=""
    DISK_DESC=""
    OUTPUT=/dev/tty
    ENOUGH=5000
    FASTMEM="NO"
    FILE=/var/tmp/XXX
    FSDIR=/var/tmp
    INFO=INFO.buildroot
    LINE_SIZE=64
    LOOP_O=0.00001841
    MAIL=no
    TOTAL_MEM=1001
    MB=8
    MHZ="995 MHz, 1.0050 nanosec clock"
    MOTHERBOARD=""
    NETWORKS=""
    OS="arm"
    PROCESSORS="2"
    REMOTE=""
    SLOWFS="NO"
    SYNC_MAX="2"
    LMBENCH_SCHED="BALANCED"
    TIMING_O=0
    RSH=
    RCP=
    VERSION=3.0-a9
    BENCHMARK_HARDWARE=YES
    BENCHMARK_OS=YES
    BENCHMARK_SYSCALL=
    BENCHMARK_SELECT=
    BENCHMARK_SIG=
    BENCHMARK_PROC=
    BENCHMARK_CTX=
    BENCHMARK_PAGEFAULT=
    BENCHMARK_FILE=
    BENCHMARK_MMAP=
    BENCHMARK_PIPE=
    BENCHMARK_UNIX=
    BENCHMARK_UDP=
    BENCHMARK_TCP=
    BENCHMARK_CONNECT=
    BENCHMARK_RPC=
    BENCHMARK_HTTP=
    BENCHMARK_BCOPY=
    BENCHMARK_MEM=
    BENCHMARK_OPS=

四、getsummary显示数据疑问:
    1. 可能前面会发现整形、浮点等运算为什么无效?也就是没有数据。
    2. 分析getsummary源代码:
        [...省略]
                if (/SYNC_MAX/) {              -------+
                        @_ = split;                   |
                        $_[1] =~ s/\]//;              |
                        push(@load, $_[1]);   --------+----------------------+
                }                                                            |
        [...省略]                                                             |
        for ($i = 0; $i <= $#uname; $i++) {                                  |
                if (&resultsq($i, $i, ( 'int64_bit', 'int64_add',            |
                                        'int64_mul', 'int64_div',            |
                                        'int64_mod' )) <= 0) {               |
                        next;                                                |
                }                                                            |
                if ($load[$i] > 1) {       <---------------------------------+
                        next; 
                }
                printf "%-9.9s %13.13s ", $host[$i], &getos($uname[$i]);
                printf " %5.5s %6.6s %6.6s %6.6s %6.6s\n",
                        &scale_num($int64_bit[$i], 6, $load[$i]),
                        &scale_num($int64_add[$i], 6, $load[$i]),
                        &scale_num($int64_mul[$i], 6, $load[$i]),
                        &scale_num($int64_div[$i], 6, $load[$i]),
                        &scale_num($int64_mod[$i], 6, $load[$i]);
        }
        [...省略]
    3. 可知SYNC_MAX不能设置大于1的值,否者不会显示相应的部分。
    

 

posted on 2018-06-22 15:58  zengjf  阅读(1323)  评论(0编辑  收藏  举报

导航