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

    文章

    10827

    浏览量

    211178
  • Linux
    +关注

    关注

    87

    文章

    11232

    浏览量

    208942
  • ARM架构
    +关注

    关注

    14

    文章

    177

    浏览量

    36291

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

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

收藏 人收藏

    评论

    相关推荐

    什么是ARM架构?什么是X86架构?两者的区别是什么?

    一、什么是ARM架构? (一)起源与发展 ARM 架构由英国剑桥的 Acorn 计算机公司开发。因市场无合适产品,Acorn 自行设计出第一款微处理器,命名为
    的头像 发表于 09-06 10:40 696次阅读

    ARMxy ARM工业边缘计算网关带Ubuntu OS支持二次开发

    OS的优势以及二次开发的重要性。 一、ARMxy网关的技术特性 ARMxy系列边缘计算网关是基于ARM架构设计的高性能计算设备,具备以下技术特性: 高性能处理器:采用先进的
    的头像 发表于 08-19 15:32 347次阅读
    ARMxy <b class='flag-5'>ARM</b>工业边缘计算网关带Ubuntu OS<b class='flag-5'>支持</b>二次开发

    LBEE5KL1DX-883如何获得Linux支持

    我们需要 Linux 支持文档和源代码,以便在基于 Arm Cortex A9 并使用 Linux 的系统模块上使用 LBEE5KL1DX-883 模块。 谁能帮助我们获取设备驱动程序
    发表于 07-23 08:25

    请问Lierda 5G EVK具体支持哪些linux系统?

    Lierda 5G EVK这款产品的开发驱动适用于Ubantu 18.04或者centos吗,ARM架构的主机,接这个驱动麻不麻烦
    发表于 06-04 07:50

    Linux 6.10集成RISC-V更新,支持Rust编程语言

    本次补丁升级中,Linux内核进一步扩展了对应于RISC-V架构的Rust编程语言支持。在此之前,Rust已可应用在x86_64、龙芯LoongArch以及ARM64等多种
    的头像 发表于 05-23 17:16 911次阅读

    fpga封装技术和arm架构的优缺点

    FPGA封装技术和ARM架构是两个不同的概念,分别属于硬件设计的不同领域。
    的头像 发表于 03-26 15:51 758次阅读

    英特尔与Arm联手助力初创企业开发Arm架构SoC

    据介绍,此次合作旨在联合推动使用Intel 18A制程工艺研发Arm架构SoC的初创企业发展。英特尔和Arm将携手提供IP和制造及相关金融支持,助力初创企业持续进行创新和增长。这些企业
    的头像 发表于 03-25 15:34 368次阅读

    Arm v9芯片新架构揭秘

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

    arm架构和x86架构区别 linux是x86还是arm

    ARM架构和x86架构是两种不同的计算机处理器架构,它们在体系结构、指令集、应用领域等方面有着明显的区别。Linux操作系统则具有广泛的适配
    的头像 发表于 01-30 13:46 1.7w次阅读

    arm开发板如何安装linux系统

    工具和软件: 一台运行Linux系统的电脑 一个支持ARM架构的开发板 一个USB转串口模块 一根Micro USB线缆 一个SD卡读卡器 一个空的SD卡 一个USB键盘和鼠标(可选)
    的头像 发表于 01-24 14:19 3081次阅读

    Linux内核中信号详解

      1 信号的角色 1.1 x86/64架构信号定义 1.2 ARM架构信号定义 1.3 RISC-V架构信号定义 1.4 信号的系统调用 1.5 信号工作原理 2 信号的响应行为 3
    的头像 发表于 01-13 09:40 1333次阅读
    <b class='flag-5'>Linux</b>内核中信号详解

    rk3399移植Linux内核

    Linux内核移植到RK3399上。 首先,我们需要了解RK3399的硬件架构特性。RK3399采用的是ARM架构,具有双核Cortex-
    的头像 发表于 01-08 09:56 1066次阅读

    Linux内核内存管理架构解析

    内存管理子系统可能是linux内核中最为复杂的一个子系统,其支持的功能需求众多,如页面映射、页面分配、页面回收、页面交换、冷热页面、紧急页面、页面碎片管理、页面缓存、页面统计等,而且对性能也有很高
    的头像 发表于 01-04 09:24 635次阅读
    <b class='flag-5'>Linux</b>内核内存管理<b class='flag-5'>架构</b>解析

    Debian宣布停止i386架构支持

    近日,在英国剑桥市举行的小规模DebConf活动中,Debian GNU/Linux的发布团队召开春季会议,探讨了未来发展方向,其中包括停止对i386架构支持
    的头像 发表于 12-19 10:16 824次阅读

    基于Debian的Sparky Linux 7.2的亮点

    Linux kernel 6.1 LTS 提供支持,Sparky Linux 7.2采用 LXQt 1.2.0 和 KDE Plasma 5.27.5,现在提供 ARMHF 和 ARM
    的头像 发表于 12-14 10:13 572次阅读
    基于Debian的Sparky <b class='flag-5'>Linux</b> 7.2的亮点