Qualcomm Snapdragon Profiler使用教程(3)

2023-10-19 18:59

本文主要是介绍Qualcomm Snapdragon Profiler使用教程(3),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Qualcomm Snapdragon Profiler使用教程(3)

    • 1. 跟踪捕获
    • 2. 额外的要求
    • 3. 启动应用
    • 4. 跟踪捕获的基础操作
    • 5. 评估DSP性能
    • 6. 捕捉OpenCL的应用程序
    • 7. 捕获Vulkan应用程序
    • 8. 分析
    • 9. 测量时间
    • 10. 注释

1. 跟踪捕获

跟踪捕获模式,如图5-2。捕获snapdragon驱动的设备上可用的跟踪事件和数据。一旦捕获,调用跟踪可以用于以下方面:

  • 收集和显示重要的性能统计数据
  • 查看内核中每个CPU核上的线程调度情况
  • 查看CPU、DSP和GPU活动在同一时间轴上的相关性
    在这里插入图片描述
    Figure 5-2 Trace Capture mode

2. 额外的要求

OpenGL ES、Vulkan和OpenCL应用程序必须包含android.permission。并且需要在应用程序的AndroidManifest.xml中启用API跟踪和GPU指标。

3. 启动应用

Trace Capture面板中的Launch Application按钮可用于启动安装在目标设备上的任何应用程序。使用这个按钮的具体作用取决于正在启动的应用程序的类型。

  • 如果想要获取Vulkan跟踪指标,那么启动Vulkan应用时必须使用该按钮。
  • OpenGL ES应用程序使用该按钮将允许Snapdragon Profiler加载其OpenGL API拦截器(interceptor可对方法进行拦截)库的最新版本,这将启用最佳的分析功能。当OpenGL ES应用程序在没有使用按钮的情况下在设备上启动时,设备上预安装的API拦截器库将被使用。
  • 所有其他应用程序的行为都是相同的,无论他们是从设备或按钮启动。使用Launch Application按钮启动应用程序使用Java调试协议(Java Debug Wire
    Protocol)。因此,在使用此功能时,建议禁用其他使用JDWP的调试和分析工具。

4. 跟踪捕获的基础操作

  1. 检查Android设备是否连接到安装了Snapdragon Profiler的计算机,并启动Profiler(见3.2节)。

  2. 选择“文件–>连接”,或者在开始页面单击“连接到一个设备”,连接到一个设备并开始一个会话(参见3.3节)。

  3. 在“开始”页面中,单击“新建跟踪捕获”,或者选择“捕获–>新建跟踪”。

  4. 创建了一个新的Capture选项卡。当选择此选项卡时,将显示一个类似于Realtime的视图,附带Start Capture和Stop Capture按钮。
    在这里插入图片描述

  5. 在Data Sources面板中,选择要查看的指标。从进程列表中选择一个进程,以查看特定于该进程的指标(如果存在的话)。

  6. 单击start capture,开始捕获。
    在这里插入图片描述

  7. 单击“Stop Capture”,几秒钟后停止捕获。Snapdragon Profiler处理并在图形窗格中显示跟踪数据。

注意:Snapdragon Profiler不允许跟踪捕获超过10秒。

在这里插入图片描述在这里插入图片描述

5. 评估DSP性能

为了收集DSP数据,必须使用配备骁龙820处理器的设备,如三星Galaxy S7。

  1. 检查Android设备是否连接到安装了Snapdragon Profiler的计算机,并启动Profiler(见3.2节)。

  2. 选择文件–>连接,或者在开始页面单击“连接到一个设备”,连接到一个设备并开始一个会话(参见3.3节)。

  3. 在开始页面中,单击New Trace Capture,或者选择Capture --> New Trace来查看应用程序或设备的跟踪级别对应的性能数据。

  4. 在Metrics窗口中,如果需要的话可以展开系统类别,将会显示两个子类别:Trace和DSP。Trace采集的数据来自Android系统Trace和DSP采集的数据来自于DSP设备。

  5. 选择捕获指标:

a. 展开“DSP”子类别,查看可选指标。滚动到DSP %利用率,并选中复选框来启用这个指标。

b. 展开Trace子类别,并启用CPU Frequency和HW模块指标。收集DSP和跟踪指标将展示Profiler在不同处理器子系统之间关联时间轴信息的能力。

注意:要查看DSP %利用率的变化,需要在捕获期间打开一个产生音频的应用程序。
  1. 单击左上角的Start Capture开始捕获。

  2. 捕获几秒钟后,打开音频。

  3. 让音频播放几秒钟,然后单击Stop Capture。捕获可以继续,但是它会在10秒后自动停止捕获。

  4. 捕获数据显示在主分析器窗口中。

注意:在捕获几秒钟后,由于音频活动,DSP %利用率增加了。且在音频运行期间,跟踪数据中的活动也会增加。
  1. 使用书签功能可以方便地查看跨时间轴的相关性。

6. 捕捉OpenCL的应用程序

使用跟踪捕获来了解OpenCL应用程序是如何在由Snapdragon处理器驱动的设备上执行的。

注意:并不是所有的移动设备都支持OpenCL。使用像OpenCL Info这样的应用程序,看看你的设备是否支持OpenCL。根据所捕获的应用程序和首选行为,在运行应用程序之前可能需要额外的设置步骤。
  1. 检查Android设备是否连接到安装了Snapdragon Profiler的计算机,并启动Profiler(见3.2节)。

  2. 选择文件—>连接,或者在开始页面单击“连接到一个设备”,连接到一个设备开始一个会话(参见3.3节)。

  3. 如果要捕获的应用程序是命令行,并且首选从开始捕获,则必须在运行应用程序之前设置Enable Blocking选项。一旦设置好,应用程序将暂停执行,直到捕获开始。

注意:OpenCL预设布局可以方便地访问所有与OpenCL相关的视图。
  1. 在开始页面中,单击New Trace Capture,或者选择Capture --> New Trace来查看应用程序或设备的跟踪级别对应的性能数据。

  2. 从进程列表中选择应用程序。OpenCL跟踪指标将出现在指标树视图中。

  3. 启用OpenCL跟踪指标和捕获的其他OpenCL指标。

  4. 单击左上角的Start Capture开始捕获。

注意:如果被捕获的应用程序是命令行,则在给定的应用程序上继续执行。
  1. 单击“Stop Capture”,结束捕获。如果应用程序完成执行,捕获将自动停止。

  2. 然后传输和处理数据。进度指示器将显示在分析器窗口的右下角。

  3. 处理完成后,跟踪捕获数据显示在主分析器窗口中,根据主机上的线程、GPU上的上下文和设备进行组织。

  • 事件链接
    在等待或完成事件的调用之间显示相关链接。
  • 跟踪元素
    选择trace elements以在trace视图中查看元素的详细信息。
  • 可视化缓冲区
    如果启用了缓冲区和图像数据传输,则会显示另一条带有标记的轨道,其中绑定到给定缓冲区的数据可能已被修改。
  • 快照跟踪缓冲区
    单击一个标记来查看该数据,并在缓冲区或图像查看器上查看选定的缓冲区数据。
  • 查看器缓冲区
    可以自定义缓冲区查看器以适应所查看的数据。可以修改每页的行数和列数以对齐数据,也可以更改显示格式以匹配最常见的用例。
  • 跟踪视图
    使用API调用的跟踪数据返回值、参数和指标计算将出现在跟踪视图中。
  • 资源及监控视图
    Resources视图列出了捕获过程中收集的所有资源。单击某个资源,在检查器视图中显示该资源的详细信息。程序在Inspector视图中显示静态代码分析,在source视图中也显示包含内核的代码。

7. 捕获Vulkan应用程序

要为Vulkan应用程序捕获Vulkan跟踪指标,必须从Snapdragon Profiler的跟踪捕获面板启动应用程序。此外,Vulkan跟踪指标要求你的应用程序是可调试的(除了在根设备上)。在应用程序的AndroidManifest.xml中设置android:debuggable标志为true。

  1. 按照Trace Capture basics(跟踪捕获的基础操作)中的步骤1-4连接并打开一个新的Trace Capture选项卡,然后单击Data Sources面板中的Launch Application按钮:
    在这里插入图片描述

  2. 启动应用程序窗口,如图5-3所示。从已安装应用列表中选择一个应用程序,然后单击Launch。如果应用程序已经在运行,它将重新启动并启用Vulkan跟踪分析。
    在这里插入图片描述

    Figure 5-3 Launch Application window

  3. 从跟踪捕获基础的第5步开始,选择指标并开始捕获。

8. 分析

一些跟踪指标支持额外的分析。捕获跟踪之后,如果工具栏上的Analytics按钮已启用,则单击它。

在这里插入图片描述

“分析”窗口如图5-4所示。在左侧面板中选择一个统计信息来查看其他信息。

在这里插入图片描述

5-4 Analytics window

9. 测量时间

calipers,如图5-5所示,用于测量两个标记之间的时间。

  1. 双击时间轴(请参见绿框),在要测量的区域的开始和结束处设置标记。

  2. 左键单击其中一个标记,然后shift +左键单击另一个标记。
    在这里插入图片描述

    5-5 Measuring time with the calipers

设置,可以通过轨道左侧的一个小齿轮图标进行访问,它将总结在该组的每条轨道上花费的时间。只有屏幕上可见的元素才会被加满。
在这里插入图片描述

10. 注释

通过右键单击跟踪捕获中的任何块元素,可以将注释添加到该元素。为该组添加了一个注释跟踪。
在这里插入图片描述

这篇关于Qualcomm Snapdragon Profiler使用教程(3)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/241745

相关文章

Spring Boot整合Redis注解实现增删改查功能(Redis注解使用)

《SpringBoot整合Redis注解实现增删改查功能(Redis注解使用)》文章介绍了如何使用SpringBoot整合Redis注解实现增删改查功能,包括配置、实体类、Repository、Se... 目录配置Redis连接定义实体类创建Repository接口增删改查操作示例插入数据查询数据删除数据更

使用python生成固定格式序号的方法详解

《使用python生成固定格式序号的方法详解》这篇文章主要为大家详细介绍了如何使用python生成固定格式序号,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以参考一下... 目录生成结果验证完整生成代码扩展说明1. 保存到文本文件2. 转换为jsON格式3. 处理特殊序号格式(如带圈数字)4

Java使用Swing生成一个最大公约数计算器

《Java使用Swing生成一个最大公约数计算器》这篇文章主要为大家详细介绍了Java使用Swing生成一个最大公约数计算器的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一下... 目录第一步:利用欧几里得算法计算最大公约数欧几里得算法的证明情形 1:b=0情形 2:b>0完成相关代码第二步:加

Java中流式并行操作parallelStream的原理和使用方法

《Java中流式并行操作parallelStream的原理和使用方法》本文详细介绍了Java中的并行流(parallelStream)的原理、正确使用方法以及在实际业务中的应用案例,并指出在使用并行流... 目录Java中流式并行操作parallelStream0. 问题的产生1. 什么是parallelS

Linux join命令的使用及说明

《Linuxjoin命令的使用及说明》`join`命令用于在Linux中按字段将两个文件进行连接,类似于SQL的JOIN,它需要两个文件按用于匹配的字段排序,并且第一个文件的换行符必须是LF,`jo... 目录一. 基本语法二. 数据准备三. 指定文件的连接key四.-a输出指定文件的所有行五.-o指定输出

Linux jq命令的使用解读

《Linuxjq命令的使用解读》jq是一个强大的命令行工具,用于处理JSON数据,它可以用来查看、过滤、修改、格式化JSON数据,通过使用各种选项和过滤器,可以实现复杂的JSON处理任务... 目录一. 简介二. 选项2.1.2.2-c2.3-r2.4-R三. 字段提取3.1 普通字段3.2 数组字段四.

Linux kill正在执行的后台任务 kill进程组使用详解

《Linuxkill正在执行的后台任务kill进程组使用详解》文章介绍了两个脚本的功能和区别,以及执行这些脚本时遇到的进程管理问题,通过查看进程树、使用`kill`命令和`lsof`命令,分析了子... 目录零. 用到的命令一. 待执行的脚本二. 执行含子进程的脚本,并kill2.1 进程查看2.2 遇到的

详解SpringBoot+Ehcache使用示例

《详解SpringBoot+Ehcache使用示例》本文介绍了SpringBoot中配置Ehcache、自定义get/set方式,并实际使用缓存的过程,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录摘要概念内存与磁盘持久化存储:配置灵活性:编码示例引入依赖:配置ehcache.XML文件:配置

Java 虚拟线程的创建与使用深度解析

《Java虚拟线程的创建与使用深度解析》虚拟线程是Java19中以预览特性形式引入,Java21起正式发布的轻量级线程,本文给大家介绍Java虚拟线程的创建与使用,感兴趣的朋友一起看看吧... 目录一、虚拟线程简介1.1 什么是虚拟线程?1.2 为什么需要虚拟线程?二、虚拟线程与平台线程对比代码对比示例:三

k8s按需创建PV和使用PVC详解

《k8s按需创建PV和使用PVC详解》Kubernetes中,PV和PVC用于管理持久存储,StorageClass实现动态PV分配,PVC声明存储需求并绑定PV,通过kubectl验证状态,注意回收... 目录1.按需创建 PV(使用 StorageClass)创建 StorageClass2.创建 PV