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

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

3天内不再提示

揭秘ARM架构对Linux调测特性的支持

Linux阅码场 来源:Linux阅码场 作者:Linux阅码场 2022-08-22 14:51 次阅读

一、浅谈手机性能的可观测性

1.概述

手机上的性能指标是综合的变化,由上图可以看的出来手机更关注人跟机器的交互这,云系统则是比较关注机器跟机器的交互。

手机系统比较特别的地方在于资源都是比较受限,例如: 电量,性能…因此针对用户体验是需要特别庖丁解牛来建立指标。

指标(METRIC) -业界有特定的体验度量模型,目标是发现产品和服务中的问题及理解使用者的行为和偏好。

性能体验度量是多层次,多个维度的,只用一项指标去表征的所有性能特征是远远不够的。

c5bf8638-21c9-11ed-ba43-dac502259ad0.png

以上是几个个常用指标,这些指标常常是互相搭配的例如Andrid近年常用的GSM+HEART。度量模型围绕用户使用的旅程,识别关键体验路径(KEP),为不同接触点分解出不同的性能指标。

2.性能追踪

c5d29066-21c9-11ed-ba43-dac502259ad0.png

实际上如何构建手机可观测性,我们都会采取分层次拆解,由上图可以看的出来藉助于Android/Linux系统的生态系已经有不少工具可以用于追踪系统的信息

性能追踪在手机装置面临的挑战:

1、低开销:不会降低用户的体验,因为手机资源是受限的所以如何有性的采集会是很大的考验。

2、不可接触:开发人员无法实时获取使用者的故障第一现场信息,用户很多操作行为都是不容易在现,因此识别关键体验路径会是开发的过程之一。

3、偶发性:低概率,不易复现(Heisen berg Bug),对于第三方应用跟系统交互或是用户行为常常有偶发性不易在现的问题需要准确的追踪机制辅助找到原因。

4、不可预见:用已知模式分析未知问题。

讲师介绍了一些Android上常见的工具

žSystrace : 用于将设备活动保存到跟踪档的Android 工具。

žcpu_profile : 在android平台实现周期性采集调用栈。

žsimpleperf : simpleperf是Anroid平台的一套性能分析工具,功能大致与linux perf相似。

žnanotrace : 通过在虚拟机(包括解析器和编译程序)中插桩,获取从APK到framework层的执行路径的调用链和函数执行时长。

žobjtrace : 动态跟踪函数参数值。

žblktrace : blktrace 结合btt可以统计一个IO是在调度队列停留的时间长,还是在硬件上消耗的时间长。

žHitrace : 对于跨设备/进程/线程的业务流程处理,通过相同的traceid在整个业务流程中传递,将调用层次、各种输出信息关联和展现。

3.可观测性之Logging

c5dd7d64-21c9-11ed-ba43-dac502259ad0.png

上图由上而下的拆解展示日志的重要性,首先我们需要了解用户行为,关注用户体验并记录对应的错误日志,当时系统状态与硬件状态用于改善用户体验。

手机系统的日志系统时常需要整合第三方应用,因为第三方应用不开源,管理日志上常常没有足够权限,还有手机储存大小受限因此最终的日志系统方案都是朝可以汇整日志并更精准建立模型为目标。

总结以上几点用户体验是感性的,不单单只是数字因此讲者认科技应该是有温度的。

Q&A

Q : 是否有AI优化思路?

A: 目前还在努力,有尝试用AI分析用户体验不过效果不明显。目前比较多还是在做基础体验度量。

Q : 跑分跟用户体验怎么看?

A: 跑分不能直接当用户体验侦率,累积布局偏移可參考。

Q: nanotrace可否第三方插庄?

A: yes

Q : 是否能找到唤醒源?

A:可打开irq,ipi中断事件可以看到换醒源。

二、揭秘ARM架构对Linux调测特性的支持

讲师简介:张健, 现就职于北京大简技术有限公司, 14年ARM架构和操作系统一线研发经验. 在北京, 柏林, 拉斯维加斯, 多地发表技术演讲。

首先,本次分享从调试视角、性能影响两个角度出发,对调试特性进行了宏观的分类。

1.调试类型

调试包含两个维度的特性:调试视角维度与性能影响维度。

1.调试视角维度

从调试视角维度出发,调试分为external debug与self-hosted debug,前者包括openocd、kgdb、ftrace、perf等内核调试基础设施,后者则是通过JTAG、FTOI等体系结构相关调试接口连接芯片,同时用调试软件控制硬件调试器进行调试。

c5ee9414-21c9-11ed-ba43-dac502259ad0.png

其中,红色所示技术为硬件调试接口,蓝色所示技术为相关软件调试工具。软硬件调试工具共享CPU和内核所提供的调试能力。

2.性能影响维度

从性能影响维度出发,调试分为影响(多为停止)当前CPU状态的侵入式调试和不影响CPU运行的非侵入式调试。前者多会暂停当前CPU的执行流,同时通过相关机制(比如,AR cross trigger)告知其他核当前被调试的状态,从而影响系统状态。

这种调试类型虽然带来了强大的调试能力,但是在芯片和内核的设计开发时需要考虑CPU调试过程中与其他外围设备的关系,因为CPU的调试状态不会影响到其他硬件,一致性等问题是该方法的经典挑战;对于非侵入式的调试类型,它不会直接停止当前的CPU运行状态,更多对系统起到监控跟踪的作用。

c5ff74d2-21c9-11ed-ba43-dac502259ad0.png

接下来,分享从断点、Trace、PMU三类调试手段出发讲述ARM架构的系统调试特性。

2.侵入式调试手段之断点

断点调试是侵入式的,单纯依赖用户态基础设施或顶层应用无法达到启停系统的能力要求。因此,断点调试的设计需要硬件和操作系统的支持,即断点调试要有陷入高特权级别环境的能力。

用户通过配置编译选项获得指定平台下的gdb调试器,将被追踪程序当作参数传递gdb调试器,gdb调试器fork出被调试程序子进程,两者通过PTRACE_XXX请求建立连接。

对于软件断点,gdb将通过符号表等信息在开发者指定的位置填入调试指令(x86为INT3,ARM为BRK/BRKT);对于硬件断点,gdb会将指定位置的地址写入到调试寄存器中。

当程序运行至软件断点或硬件断点处,子进程会触发相应异常,待异常信号被gdb捕获后,通过比对记录的断点信息来判断是否是调试原因所触发的异常,如此来实现gdb调试进程的启停能力。

c60d1ea2-21c9-11ed-ba43-dac502259ad0.png

3.非侵入调试类型之Trace

ARM Coresight架构是遵循可观测性的架构设计,Cortex Processor后的ETM负责在处理器外部抓取指令序列,不影响CPU的运行状态。并且,Trace信息的传输未经系统总线,减少了对系统带宽的影响。Coresight架构中存在多个执行流抓取点,存在多个对应的ETM,多个ETM收集的信息会传入下游的Funnel,Funnel将根据数据所存在的信息将执行流信息进行分流处理。

c61a271e-21c9-11ed-ba43-dac502259ad0.png

关于具体的互联结构可以查看对应版本的设备树文件。(所在源码目录为/arch/arm64/boot/dts)

4.非侵入调试类型之Performance Monitor Unit(PMU)

CPU中存在PMU部件,该部件会监控CPU的相关性能信息,用户可以通过访问相应的寄存器获取相关信息。perf是一种可以访问PMU的用户态工具。

c62d3b4c-21c9-11ed-ba43-dac502259ad0.png

perf访问PMU的相关流程如下:

1.使用perf_pmu_register注册PMU事件。

2.perf_event_open系统调用打开对应事件的文件描述符,从中读取记录的值。

审核编辑 :李倩

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

    关注

    68

    文章

    10446

    浏览量

    206571
  • Linux
    +关注

    关注

    87

    文章

    10990

    浏览量

    206738
  • ARM架构
    +关注

    关注

    14

    文章

    167

    浏览量

    35992

原文标题:PODS峰会笔记: 浅谈手机性能的可观测性&揭秘ARM架构对Linux调测特性的支持(Day3)

文章出处:【微信号:LinuxDev,微信公众号:Linux阅码场】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    Arm v9芯片新架构揭秘

    从中长期来看,随着单芯片 ARM 核数增加、基于 ARM 架构芯片数量的上升以及ARM 应用场景的增加,公司仍将保持增长。据公司公告数据显示,2023 财年,高端芯片采用
    发表于 02-27 14:14 878次阅读
    <b class='flag-5'>Arm</b> v9芯片新<b class='flag-5'>架构</b><b class='flag-5'>揭秘</b>

    Linux实时内核准备支持RISC-V

    目前,Linux RT补丁集允许为ARM64(AArch64)、ARM、PowerPC和x86/x86_64架构启用PREEMPT_RT。最近正在处理的一组补丁也将扩展对RISC-V的
    的头像 发表于 10-31 16:29 337次阅读

    基于ARM Linux和S3C2440的嵌入式Linux内核设计

    电子发烧友网站提供《基于ARM Linux和S3C2440的嵌入式Linux内核设计.pdf》资料免费下载
    发表于 10-12 10:37 2次下载
    基于<b class='flag-5'>ARM</b> <b class='flag-5'>Linux</b>和S3C2440的嵌入式<b class='flag-5'>Linux</b>内核设计

    基于ARMLinux系统移植

    电子发烧友网站提供《基于ARMLinux系统移植.pdf》资料免费下载
    发表于 10-11 10:57 0次下载
    基于<b class='flag-5'>ARM</b>的<b class='flag-5'>Linux</b>系统移植

    如何安装ARM编译器Linux

    。 注意:ARM编译器Linux版运行在64位ARM硬件上,它不是交叉编译器。 有关兼容性的详细信息,请参阅支持的平台。
    发表于 08-28 06:45

    从电源架构迁移到ARM的应用说明

    迁移到另一种体系结构的决策所涉及的问题。 本课程假定您熟悉电源架构,并解释了相应的和附加的ARM功能。 ARM架构得到了ARM互联社区中大量
    发表于 08-22 06:09

    Emulex HBA CLI ARM架构上的Linux发行说明 版本14.0.326.13-1

    电子发烧友网站提供《Emulex HBA CLI ARM架构上的Linux发行说明 版本14.0.326.13-1.pdf》资料免费下载
    发表于 08-15 11:08 1次下载
    Emulex HBA CLI <b class='flag-5'>ARM</b><b class='flag-5'>架构</b>上的<b class='flag-5'>Linux</b>发行说明 版本14.0.326.13-1

    Emulex HBA CLI ARM架构上的Linux发行说明

    电子发烧友网站提供《Emulex HBA CLI ARM架构上的Linux发行说明.pdf》资料免费下载
    发表于 08-10 16:28 0次下载
    Emulex HBA CLI <b class='flag-5'>ARM</b><b class='flag-5'>架构</b>上的<b class='flag-5'>Linux</b>发行说明

    ARM领域管理扩展(RME)系统架构介绍

    本章介绍Realm Management Extension(RME)系统架构。RME架构是在[1]中指定,并且被定义为Armv9体系结构的A轮廓的扩展。 RME体系结构定义了符合Arm要求的一组
    发表于 08-09 07:52

    Arm架构的扩展详解

    架构,根据发布时间使用最新的扩展。 本指南解释了Arm架构的扩展,并提供了如何阅读的指导并利用它们。 在本指南的最后,您可以检查您的知识。您将学习以下内容: •用于标识扩展的命名方案。 •哪些功能在不同的扩展中可用。 •如何确定
    发表于 08-02 06:08

    架构Arch Linux发行版正式发布

    近日,龙架构Arch Linux发行版官方网站宣布结束beta状态,正式支持架构。Arch Linux是一种轻量级、可定制、灵活的
    的头像 发表于 07-18 11:16 612次阅读

    两大架构RISC-V 和 ARM 的各种关系

    一、RISC-V 和 ARM 的相似之处 RISC-V 和 ARM 基本上都是 RISC(精简指令集计算机)。RISC-V 和 ARM 都使用加载-存储架构。意思是数据从内存中加载,在
    发表于 06-21 20:31

    X86架构Arm架构的区别

    X86架构ARM架构是主流的两种CPU架构,X86架构的CPU是PC服务器行业的老大,ARM
    的头像 发表于 06-16 12:50 7708次阅读
    X86<b class='flag-5'>架构</b>与<b class='flag-5'>Arm</b><b class='flag-5'>架构</b>的区别

    为什么x86和arm架构不同,但是都能装linux呢?

    为什么x86和arm架构不同,但是都能装linux呢?他们的编译时如何实现的?
    发表于 05-16 10:21

    设备仿真模拟软件 QEMU 8.0 发布:改进对 ARM / RISC-V 架构支持

    8.0 版本带来了对 ARM 和 RISC-V 架构的改进支持。对于 ARM,增加了对 FEAT_EVT、FEAT_FGT 和 AArch32 ARMv8-R 的仿真
    发表于 05-05 09:48