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

相关文章

Python 安装和配置flask, flask_cors的图文教程

《Python安装和配置flask,flask_cors的图文教程》:本文主要介绍Python安装和配置flask,flask_cors的图文教程,本文通过图文并茂的形式给大家介绍的非常详细,... 目录一.python安装:二,配置环境变量,三:检查Python安装和环境变量,四:安装flask和flas

Spring Security基于数据库的ABAC属性权限模型实战开发教程

《SpringSecurity基于数据库的ABAC属性权限模型实战开发教程》:本文主要介绍SpringSecurity基于数据库的ABAC属性权限模型实战开发教程,本文给大家介绍的非常详细,对大... 目录1. 前言2. 权限决策依据RBACABAC综合对比3. 数据库表结构说明4. 实战开始5. MyBA

使用Python自建轻量级的HTTP调试工具

《使用Python自建轻量级的HTTP调试工具》这篇文章主要为大家详细介绍了如何使用Python自建一个轻量级的HTTP调试工具,文中的示例代码讲解详细,感兴趣的小伙伴可以参考一下... 目录一、为什么需要自建工具二、核心功能设计三、技术选型四、分步实现五、进阶优化技巧六、使用示例七、性能对比八、扩展方向建

使用Python实现一键隐藏屏幕并锁定输入

《使用Python实现一键隐藏屏幕并锁定输入》本文主要介绍了使用Python编写一个一键隐藏屏幕并锁定输入的黑科技程序,能够在指定热键触发后立即遮挡屏幕,并禁止一切键盘鼠标输入,这样就再也不用担心自己... 目录1. 概述2. 功能亮点3.代码实现4.使用方法5. 展示效果6. 代码优化与拓展7. 总结1.

使用Python开发一个简单的本地图片服务器

《使用Python开发一个简单的本地图片服务器》本文介绍了如何结合wxPython构建的图形用户界面GUI和Python内建的Web服务器功能,在本地网络中搭建一个私人的,即开即用的网页相册,文中的示... 目录项目目标核心技术栈代码深度解析完整代码工作流程主要功能与优势潜在改进与思考运行结果总结你是否曾经

Linux中的计划任务(crontab)使用方式

《Linux中的计划任务(crontab)使用方式》:本文主要介绍Linux中的计划任务(crontab)使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、前言1、linux的起源与发展2、什么是计划任务(crontab)二、crontab基础1、cro

kotlin中const 和val的区别及使用场景分析

《kotlin中const和val的区别及使用场景分析》在Kotlin中,const和val都是用来声明常量的,但它们的使用场景和功能有所不同,下面给大家介绍kotlin中const和val的区别,... 目录kotlin中const 和val的区别1. val:2. const:二 代码示例1 Java

Ubuntu中远程连接Mysql数据库的详细图文教程

《Ubuntu中远程连接Mysql数据库的详细图文教程》Ubuntu是一个以桌面应用为主的Linux发行版操作系统,这篇文章主要为大家详细介绍了Ubuntu中远程连接Mysql数据库的详细图文教程,有... 目录1、版本2、检查有没有mysql2.1 查询是否安装了Mysql包2.2 查看Mysql版本2.

C++变换迭代器使用方法小结

《C++变换迭代器使用方法小结》本文主要介绍了C++变换迭代器使用方法小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1、源码2、代码解析代码解析:transform_iterator1. transform_iterat

C++中std::distance使用方法示例

《C++中std::distance使用方法示例》std::distance是C++标准库中的一个函数,用于计算两个迭代器之间的距离,本文主要介绍了C++中std::distance使用方法示例,具... 目录语法使用方式解释示例输出:其他说明:总结std::distance&n编程bsp;是 C++ 标准