SylixOS调试方法详解——性能分析

1. SylixOS调试方法介绍

SylixOS实现了一个功能强大的调试stub(桩),可在设备或模拟器上在线调试应用程序,RealEvo-IDE也提供配套的调试插件。目前RealEvo-IDE既支持自动推送调试、也支持传统的手动启动gdbserver的调试方式。在官方公布的使用手册中没有详细写出在平常开发中很是实用的几种调试方式,本文主要介绍性能分析的调试方法。app

在平常开发过程当中常常会遇到程序不够快的状况,可是不知道到底慢在哪里,每每是随意寻找函数优化,并无没有真正定位到程序哪里慢,存在很大的偶然性。性能分析工具就是用动态采样的方式定位真正慢的位置,定位以后再在这个点上进行优化,最终程序运行时间对比是很是明显的。函数

2. SylixOS性能分析调试步骤详解

2.1.1   性能分析演示demo

SylixOS的性能分析主要是经过加载性能分析模块(sperfs.ko)来查看各个函数消耗的CPU时间,可以准确找到须要优化的点。下面经过创建一个“perfoms_check_app”来作性能分析调试的演示,代码如程序清单 2‑1所示。工具

程序清单 2‑1  static_check_app代码性能

//sperfstart sperfs优化

#include <stdio.h>spa

 

#define   USE_SLEEP插件

 

void module_sleep(int iSecond)线程

{调试

#ifdef USE_SLEEPorm

   sleep(1);

#else

   bspDelayUs(iSecond*1000*1000);

#endif

}

 

void calc_value(void)

{

   static int i;

 

   i++;

}

void do_something(void)

{

   /*

    *  do something

    */

   calc_value();

   module_sleep(1);

}

 

int main (int argc, char **argv)

{

   while (1){

//     do_something();

   }

    return  (0);

}

 

2.1.2   加载性能分析模块(sperfs.ko)

(sperfs.ko模块为SylixOS性能分析检查提供一种调试工具)

点击IDE界面右上角“Device”;选择目标机器IP地址,这里使用的是虚拟机的IP地址:192.168.7.32,右击IP号打开“Launch FTP”进行传输;而后在本地文件夹中找到sperfs.ko模块,传输路径选择在“/lib/modules”目录下;最后双击sperfs.ko便可完成模块加载的准备工做,具体步骤如图 2‑1所示。

图 2‑1  加载sperfs.ko模块方法一

除上述方法外还能够经过“cp”指令将性能分析模块的拷贝在“/lib/modules”目录下,如图 2‑2所示。

图 2‑2  加载sperfs.ko模块方法二

完成后在“cd /lib/modules”目录下用“ls”查看是否完成拷贝,结果如图 2‑2所示。

图 2‑3  查看是否完成加载

而后经过“chmod”改变文件的权限,再用“modulereg”命令注册性能分析模块,如图 2‑3所示。

图 2‑4 注册内核模块

最后经过“sperfstart”命令开启性能分析的功能,再用“sperfs”命令查看性能分析结果,如图 2‑4所示。

图 2‑5  开启性能分析模块

除此以外咱们经过Talnet再打开一个调试窗口,运行演示程序“perfoms_check_app”,性能分析结果如图 2‑5所示,除空闲线程t_idleo和sperfs.ko外消耗CPU时间最多的函数是程序是performs_check中的main函数,在这里只须要优化该函数就能够减小程序运行时间。

                                                                         图 2‑6  性能分析结果                                                

对该函数进行优化,优化结果如程序清单 2‑2所示。

程序清单 2‑2  main函数优化结果

int main (int argc, char **argv)

{

   while (1){

    do_something();

   }

    return  (0);

}

 

 

再次进行性能分析,结果如图 2‑6所示,main函数消耗的CPU时间已经大大减小。

图 2‑7  优化后性能分析结果

3. 总结

在SylixOS中可使用多种调试方式进行相关调试,根据实际状况对程序进行调试,本节主要介绍性能分析检查工具。下一篇文档将经过一个完整的工程文件来描述多种调试方式。

4. 参考资料

《SylixOS应用程序开发手册》

《RealEvo-IDE使用手册》

相关文章
相关标签/搜索