0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

鸿蒙智联设备调试调优面临的挑战

HarmonyOS开发者 来源:HarmonyOS开发者 作者:HarmonyOS开发者 2021-12-17 14:42 次阅读

作者:zhaowenguang,dinglu, 华为高级工程师

Huawei LiteOS是轻量级的开源物联网操作系统智能硬件使能平台,可广泛应用于智能家居、穿戴式、车联网、制造业等领域,使物联网终端开发更简单、互联更加容易、业务更加智能、体验更加顺畅、数据更加安全。

它具有入门简单、开发便捷,轻量级、低功耗、广联接,生态体系完善等优点。提供了若干高效硬件维测能力,通过集成到DevEco Device Tool中,形成了可供开发者使用的调试调优工具,助力开发者在鸿蒙智联设备调试调优过程中更加精准的分析、定位问题。

接下来,我们将重点介绍DevEco Device Tool中集成的一系列调试调优工具。

一、鸿蒙智联设备调试调优面临的挑战

开发者在鸿蒙智联设备调试调优过程中面临如下挑战:

系统镜像文件太大,分析和优化难度较大。

运行态内存紧缺,系统各任务栈大小无法设置。

性能瓶颈无法定位,不能针对性的进行优化。

仅仅靠添加打印和人工分析日志来定位问题效率低下。

内存问题最难定位,缺少检测工具。

如何应对这些挑战,让开发者能高效且准确的完成鸿蒙智联设备调试调优?

二、高效调试调优五大法宝

针对以上挑战,HUAWEI DevEco Device Tool版本中提供了鸿蒙智联设备调试调优五大法宝:镜像分析工具、栈估算分析工具、性能分析工具、可视化Trace工具、轻量级内存检测工具,下面我们将逐一介绍。注:镜像分析工具和栈估算分析工具已集成于HUAWEI DevEco Device Tool 3.0 Beta1版本中,目前只支持GCC编译的镜像,Clang暂不支持。性能分析工具、可视化Trace工具及轻量级内存检测工具将尽快上线,具体上线时间待官方通知。

1. 镜像分析工具

镜像分析工具,主要解决“资源受限情况下镜像的分析及优化”。通过对编译生成的map文件进行内存占用分析,获取镜像中各模块对ROMRAM的占用大小。

该工具支持查看内存区域总览、内存详细信息、文件大小及模块大小。同时支持一些统计功能,包括排序、过滤、导出表格等操作以及按文件或模块筛选查看的功能。镜像分析结果按照内存区域、详细信息、文件大小和模块大小4个界面进行展示。

Memory Regions:内存区域界面以表格的形式展示了每个区域的内存使用情况。如图1所示,Memory Regions包含了起始地址、结束地址、大小、可用内存以及内存占用。

54b1b602-5a8f-11ec-b2e9-dac502259ad0.png

图1 Memory Regions

Memory Details:内存详细信息里显示了Section和Symbol的信息。如图2所示,Memory Details通过树状表格展示层级关系、名称、VMA、LMA以及Size。

54e648ae-5a8f-11ec-b2e9-dac502259ad0.png

图2 Memory Details

File Size:文件大小里展示了.a文件和.o文件的层级关系以及不同section的内存占用。

Module Size:模块大小里展示了模块和组件的层级关系以及不同section的内存占用。

使用该工具可帮助开发者快速评估并优化镜像的ROM、RAM使用情况。

2. 栈估算分析工具

栈估算分析工具,主要解决“运行态内存紧缺情况下系统各任务栈的设置”。通过遍历反汇编文件,计算函数的局部栈开销并分析函数之间的调用关系,从而估算出任务的栈大小,为栈溢出分析、栈空间优化提供基础的数据参考。

该工具提供函数调用关系图、函数总的最大栈开销、内部开销,并提供展示函数所在具体位置。栈分析结果按照函数列表和调用关系进行展示。

Function List:函数列表界面显示每个函数的函数名称和函数内部栈开销,如图3所示。

55295914-5a8f-11ec-b2e9-dac502259ad0.png

图3 Function List

Call Graph:调用关系界面显示每个函数的调用关系,包括函数名称、调用深度、函数最大栈开销。

使用该工具可帮助开发者减少爆栈风险,节省内存优化栈空间。

3. 性能分析工具

性能分析工具,主要解决“性能瓶颈的定位及优化”。基于事件采样统计的原理,实现热点函数、热点路径的分析,助力识别性能瓶颈。

该工具提供计数模式及采样模式两种工作模式,采集事件发生的次数及执行时间以及上下文如PC,回溯栈等,用于解析出热点函数与热点路径等信息。同时,该工具还支持3种类型的采样事件:

硬件PMU事件:如cycle,cache等。

软件打点采样:如中断、内存申请等。

高精度周期事件:即按固定周期采样,精度us级。支持热点函数及热点路径的查看。

5565ac0c-5a8f-11ec-b2e9-dac502259ad0.png

图4 性能分析工具界面

使用该工具可帮助开发者快速有效识别性能瓶颈,辅助系统性能优化。

4. 可视化Trace工具

可视化Trace工具,主要解决“程序运行不符合预期情况下的问题定位”。通过采用静态代码桩和缓冲区记录的方式,在桩被执行时,获取事件发生的上下文、系统任务等信息,并记录到缓冲区,帮助开发者了解何时何处发生的什么事件。

该工具以图形界面展示事件详情、CPU占比、内存趋势图、任务切换轨迹等信息。下面是Trace 可视化的4个界面:

事件信息视图:如图5所示。使用自然语言解释系统何时(时间戳)何处(在哪个CPU的那个任务中)发生的具体事件。

55b0d380-5a8f-11ec-b2e9-dac502259ad0.png

图5 时间信息视图

任务轨迹视图:如图6所示。以系统时间为纵坐标,展示任务切换的轨迹,如图,不同颜色表示不同的任务,不同色块的迁移对应一次任务切换,点击色块会显示导致任务切换的原因,色块的长度对应其运行的时长。

56005748-5a8f-11ec-b2e9-dac502259ad0.png

图6 任务轨迹视图

CPU负载视图:如图7所示。统计任意时间段内的任务执行cpu占比,不同颜色对应不同的任务。

563626fc-5a8f-11ec-b2e9-dac502259ad0.png

图7 CPU负载视图

内存监控视图:如图8所示。以系统时间为横坐标,展示随时间变化的系统内存使用情况。

56815046-5a8f-11ec-b2e9-dac502259ad0.png

图8 内存监控视图

使用该工具可帮助开发者清晰的了解系统运行的轨迹,更好的理解系统、辅助定位死机死锁问题。

5. 轻量级内存检测工具

轻量级内存检测工具,主要解决“一键定位内存问题”。该工具基于影子内存映射和标记的原理,可快速解决内存越界访问、释放后访问、多重释放等疑难杂症,并且在检测到错误后实时打印回溯栈。如图9所示,轻量级内存检测工具结合backtrace,快速一键式定位问题代码段。

56b66efc-5a8f-11ec-b2e9-dac502259ad0.png

图9 定位到出错的代码行号

使用该工具可帮助开发者根据回溯栈一键定位到出错的代码行号。

以上就是本期全部内容,相信五大法宝定能让你在鸿蒙智联设备开发的道路上披荆斩棘,赶快点击下方链接下载试用吧!

原文标题:鸿蒙智联设备开发,这五大法宝你应该拥有

文章出处:【微信公众号:HarmonyOS开发者】欢迎添加关注!文章转载请注明出处。

审核编辑:彭菁
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 物联网
    +关注

    关注

    2870

    文章

    41671

    浏览量

    358794
  • 智能硬件
    +关注

    关注

    203

    文章

    2307

    浏览量

    106565
  • 鸿蒙
    +关注

    关注

    55

    文章

    1651

    浏览量

    42136
  • 鸿蒙智联
    +关注

    关注

    0

    文章

    29

    浏览量

    381

原文标题:鸿蒙智联设备开发,这五大法宝你应该拥有

文章出处:【微信号:HarmonyOS_Dev,微信公众号:HarmonyOS开发者】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    装备厂商如何实现生产设备远程运维调试

    随着科技的发展和全球化的推进,装备厂商面临着越来越多的挑战和需求。其中,如何快速、高效地解决设备出现的问题成为了关键。为了应对这一挑战,装备厂商需要实现生产
    的头像 发表于 04-03 14:37 73次阅读

    Keli5+Proteus8.13失败了的原因?

    大佬,Keli5+Proteus8.13失败了,提示这个问题,系统是win11
    发表于 03-27 06:16

    DevEco Studio 4.1带来多种调试能力,助力鸿蒙原生应用开发高效调试

    目前,HarmonyOS NEXT星河预览版已经正式面向开发者开放申请,面向鸿蒙原生应用及元服务开发者提供的集成开发环境——DevEco Studio也迎来功能更细化的4.1版本。3年来
    的头像 发表于 02-04 15:35 290次阅读

    微波GaN HEMT 技术面临挑战

    报告内容包含: 微带WBG MMIC工艺 GaN HEMT 结构的生长 GaN HEMT 技术面临挑战
    发表于 12-14 11:06 209次阅读
    微波GaN HEMT 技术<b class='flag-5'>面临</b>的<b class='flag-5'>挑战</b>

    当芯片变身 3D系统,3D异构集成面临哪些挑战

    当芯片变身 3D 系统,3D 异构集成面临哪些挑战
    的头像 发表于 11-24 17:51 311次阅读
    当芯片变身 3D系统,3D异构集成<b class='flag-5'>面临</b>哪些<b class='flag-5'>挑战</b>

    便携式医疗监控系统面临的设计挑战

    电子发烧友网站提供《便携式医疗监控系统面临的设计挑战.doc》资料免费下载
    发表于 11-10 09:48 0次下载
    便携式医疗监控系统<b class='flag-5'>面临</b>的设计<b class='flag-5'>挑战</b>

    HarmonyOS NEXT工具Smart Perf Host高效使用指南

    了测试、、分析一站式服务,**接下来让我们一起来看Smart Perf如何解决开发性能问题。 在Smart Perf工具全家桶中,Smart Perf Host主要提供性能
    发表于 11-09 08:35

    华为鸿蒙系统

    HiLink将与Harmony OS统一为鸿蒙^ [35]^。 2021年6月2日晚,华为正式发布HarmonyOS 2及多款搭载HarmonyOS 2的新产品^ [39]^。7月29日,华为Sound X
    发表于 11-02 19:39

    请问protues如何与keil

    protues如何与keil
    发表于 10-25 07:22

    激光设备

    激光阻机
    jf_74981212
    发布于 :2023年09月12日 14:13:52

    激光设备

    激光阻机
    jf_74981212
    发布于 :2023年08月17日 17:21:45

    鸿蒙再出发,携手伙伴共赢空间智能化,创造无限可能

    品牌升级发布以来,HarmonyOS Connect生态快速成长。目前,鸿蒙生态设备数量已经成功突破3.6亿,超过2400家品牌伙伴入驻HarmonyOS Connect大家庭。 HarmonyOS
    发表于 08-09 17:14

    飞速发展的HBM仍面临着一些挑战

    飞速发展的HBM仍面临着一些挑战
    的头像 发表于 07-22 10:36 1282次阅读
    飞速发展的HBM仍<b class='flag-5'>面临</b>着一些<b class='flag-5'>挑战</b>

    专访深开鸿CEO王成录:做成鸿蒙生态 需要一家万亿市值的公司

    让所有设备都用同一个系统,讲同一种语言,这样的想法在华为内部曾经讨论了两年,最终鸿蒙方案在激辩中诞生。随着搭载鸿蒙设备的数量突破一个又一个天文数字,
    发表于 06-15 14:46

    提高复杂串行协议的调试效率

    调试复杂的串行协议是验证工程师面临的最大挑战。这是影响每个项目进度的最耗费时间和精力的活动之一。传统的调试方法使用松散连接的波形、日志文件、消息和文档的组合,这不足以进行高效的
    的头像 发表于 05-26 11:23 458次阅读
    提高复杂串行协议的<b class='flag-5'>调试</b>效率