SylixOS调试方法详解——性能分析
admin
2023-03-16 05:21:10
0

1. SylixOS调试方法介绍

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

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

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

2.1.1   性能分析演示demo

SylixOS的性能分析主要是通过加载性能分析模块(sperfs.ko)来查看各个函数消耗的CPU时间,能够准确找到需要优化的点。下面通过建立一个“perfoms_check_app”来做性能分析调试的演示,代码如程序清单 21所示。

程序清单 21  static_check_app代码

//sperfstart sperfs

#include


#define   USE_SLEEP


void module_sleep(int iSecond)

{

#ifdef USE_SLEEP

   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即可完成模块加载的准备工作,具体步骤如图 21所示。

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

图 21  加载sperfs.ko模块方法一

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

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

图 22  加载sperfs.ko模块方法二

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

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

图 23  查看是否完成加载

然后通过“chmod”改变文件的权限,再用“modulereg”命令注册性能分析模块,如图 23所示。

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

图 24 注册内核模块

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

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

图 25  开启性能分析模块

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

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

                                                                         图 26  性能分析结果                                                

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

程序清单 22  main函数优化结果

int main (int argc, char **argv)

{

   while (1){

    do_something();

   }

    return  (0);

}



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


图 27  优化后性能分析结果

3. 总结

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

4. 参考资料

《SylixOS应用程序开发手册》

《RealEvo-IDE使用手册》


相关内容

热门资讯

柯建铭自爆常跟赖清德报告“大罢... 海峡导报综合报道 民进党今年“7·26”“8·23”两次“大罢免”遭遇滑铁卢,作为发起人的台民意机构...
终于明白“白金岛放炮罚.究竟有... 终于明白“白金岛放炮罚.究竟有挂吗?”太坑了原来有挂您好,白金岛放炮罚这个游戏其实有挂的,确实是有挂...
获得黄金王冠后,特朗普回赠李在... 据韩联社12月24日报道,韩国总统室秘书室长姜勋植周三在社交媒体上发布了美国总统特朗普赠送给李在明的...
玩家分享攻略“微乐龙江麻将.辅... 玩家分享攻略“微乐龙江麻将.辅助器?”必胜开挂神器您好,微乐龙江麻将这个游戏其实有挂的,确实是有挂的...
【第一财经】“闲来麻将.到底有... 有 亲,根据资深记者爆料闲来麻将是可以开挂的,确实有挂(咨询软件无需打开...
最新引进“花城牌舍.辅助开挂神... 有 亲,根据资深记者爆料花城牌舍是可以开挂的,确实有挂(咨询软件无需打开...
玩家最新攻略“沧海麻将.真的有... 您好:沧海麻将这款游戏可以开挂,确实是有挂的,需要了解加客服微信【4282891】很多玩家在这款游戏...
量子计算迎爆发期 全球产业规模... 中信建投证券在12月24日发布的研报中指出,量子计算作为量子科技的核心,有望成为引领下一代科技革命的...
今日重大消息“天天九州麻将.开... 您好:天天九州麻将这款游戏可以开挂,确实是有挂的,需要了解加客服微信【4282891】很多玩家在这款...
广东餐饮安全监管技能提升大赛在... 中新网广州12月24日电 (记者 孙秋霞)“粤监新程·AI赋能”餐饮安全监管技能提升大赛近日在广州落...