不同场景systrace tag

本文详细介绍了如何使用Perfconv和Systrace工具在Android系统中抓取CPU调度、频率调整、内存使用和GPU频率等关键性能指标。通过开启特定的trace事件,可以深入分析应用启动、界面切换、游戏场景、响应时间和安装过程中的性能瓶颈,以及解决流畅性问题。同时,关注了硬件资源如GPU、内存和电源管理等方面,为系统优化提供依据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

CPU sched

使用Perfconv抓取

请参考perfconv抓取fpsgo以及schedule相关tag

使用systrace抓取

kernel-5.10 

频率和摆核信息都抓取:

sched_migrate_task sugov_ext_util sched_task_uclamp sched_select_task_rq sched_queue_task sched_frequency_limits sched_find_energy_efficient_cpu sched_big_task_rotation sched_force_migrate sched_waking irq

只抓摆核的

sched_select_task_rq sched_force_migrate sched_migrate_task sched_queue_task

只抓调频的

sugov_ext_util sched_frequency_limits freq_qos_user_setting sched_queue_task

比如在您的脚本里这样设置:

        adb shell "echo 1 > /sys/kernel/tracing/events/sched/sched_blocked_reason/enable"
        adb shell "echo 1 > /sys/kernel/tracing/events/sched/sched_migrate_task/enable"
        adb shell "echo 1 > /sys/kernel/tracing/events/scheduler/sched_task_uclamp/enable"
        adb shell "echo 1 > /sys/kernel/tracing/events/scheduler/sugov_ext_util/enable"

        adb shell "echo 1 > /sys/kernel/tracing/events/sched/sched_waking/enable"
        adb shell "echo 1 > /sys/kernel/tracing/events/scheduler/sched_select_task_rq/enable"
        adb shell "echo 1 > /sys/kernel/tracing/events/scheduler/sched_find_energy_efficient_cpu/enable"
        adb shell "echo 1 > /sys/kernel/tracing/events/scheduler/sched_big_task_rotation/enable"
        adb shell "echo 1 > /sys/kernel/tracing/events/scheduler/sched_force_migrate/enable"

kernel-4.14 

sched 需要打开的 event:

sched_switch sched_wakeup sched_find_best_target sched_select_task_rq schedutil_uclamp_util sched_boost_cpu sched_boost_task cpu_frequency_limits cpu_frequency sched_hmp_migrate sched_util

IRQ 需要打开的 event:

/sys/kernel/tracing/events/scheduler/irq

irq_handler_entry
irq_handler_exit

work queue 需要打开的 event:

/sys/kernel/tracing/events/workqueue/
workqueue_execute_start
workqueue_execute_end
workqueue_queue_work
workqueue_activate_work

fpsgo

使用Perfconv抓取

请参考perfconv抓取fpsgo以及schedule相关tag

使用systrace抓取

请打开:

        adb shell "echo 63 > /sys/kernel/fpsgo/common/systrace_mask"        // this for fpsgo

        adb shell “echo 1 > /sys/kernel/fpsgo/xgf/xgf_trace_enable
        adb shell “echo 1 > /sys/kernel/fpsgo/xgf/xgf_log_trace_enable

CPU频率

如果发现CPU频率缺失,检查如下trace event有没有打开

/sys/kernel/tracing/events/power/cpu_frequency_limits/
cpu_frequency_limits
cpu_frequency
cpu_idle

DDR频率

需要打开的 systrace event:

adb shell "echo 1 > /sys/devices/system/cpu/perf/enable"

kernel-V4.1*版本:  adb shell "echo 1 > /sys/kernel/tracing/events/mtk_events/perf_index_s/enable"

kernel-V5.10版本:  adb shell "echo 1 > /sys/kernel/tracing/events/perf_tracker/perf_index_s/enable"

GPU频率

需要打开的 systrace event:

        adb shell "echo 1 > /sys/module/ged/parameters/ged_log_perf_trace_enable"   // these for GPU
        adb shell "echo 1 > /sys/devices/system/cpu/perf/enable"
        adb shell "echo 1 > /sys/module/ged/parameters/ged_log_trace_enable"

        adb shell "echo 1 > /sys/kernel/tracing/events/mtk_events/perf_index_gpu/enable"
        adb shell "echo 1 > /sys/kernel/tracing/events/perf_tracker/perf_index_gpu/enable"

生成systrace log:

       mtkPowerMsgHdl-762 ( 700) [005] ...1 37118.430645: tracing_mark_write: C|5566|gpu_freq|431|0|0
       mtkPowerMsgHdl-762 ( 700) [005] ...1 37118.430645: tracing_mark_write: C|5566|gpu_freq_max|886|0|0

Memory用量

需要打开的 systrace event:

adb shell "echo 1 > /sys/devices/system/cpu/perf/enable"

kernel-V4.1*版本:  adb shell "echo 1 > /sys/kernel/tracing/events/mtk_events/perf_index_l/enable"

kernel-V5.10版本:  adb shell "echo 1 > /sys/kernel/tracing/events/perf_tracker/perf_index_l/enable"

生成systrace log:

<idle>-0 (-----) [002] d.h1 2173.342581: perf_index_l: free_mem=853360 avail_mem=5227104 iostats=0|0|0|0|0|0|0|0|0|7992616|0 stall=3|0|0|0|0|0|0|0

常用场景systrace tag推荐

CPU的信息,最好都带上

sched、freq、idle

app launch/switch(打开app,进入某个界面)

gfx、view、input、res、am、wm

或者参考perfconv抓取fpsgo以及schedule相关tag

测试列表、桌面滑动等流畅性问题场景

gfx、view、input

例如:gfx input view webview wm am sm audio video hal res dalvik bionic power pm ss pdx sched freq idle load  binder_driver binder_lock

或者参考perfconv抓取fpsgo以及schedule相关tag

响应时间

gfx、view、input

或者参考perfconv抓取fpsgo以及schedule相关tag

安装时间

gfx input view webview wm am sm audio video hal res dalvik bionic power pm ss pdx sched freq idle load memreclaim binder_driver binder_lock

Game场景

gfx input sched view webview wm am smvideo hal app res dalvik bionic power pm ss pdx sched freq idle load memreclaim binder_driver binder_lock

或者参考perfconv抓取fpsgo以及schedule相关tag

GC、IO卡顿

gfx、view、input、dalvik、disk

HWUI绘图相关

gfx、view、input、hwui

power (亮灭屏、电量相关的问题)

gfx、view、input、res、am、wm、power

<think>好的,我现在需要回答用户关于“Android camera trace”的问题。首先,我需要明确用户的问题到底在问什么。可能用户想了解的是Android系统中的摄像头追踪技术,或者是调试摄像头问题时使用的跟踪工具,比如日志或trace文件。接下来,我需要确认这两个方向的内容,然后组织回答。 首先,Android摄像头追踪可能涉及几个方面:硬件层面的摄像头传感器追踪,软件层面的图像处理或算法追踪,或者是开发调试时的日志追踪。用户提到的“trace”可能更偏向于后者,即调试和分析摄像头问题时使用的工具或方法。 接下来,我应该回顾Android系统中与摄像头相关的框架。Android Camera Framework分为应用层、Java API、Native框架、HAL层,以及驱动层。当出现摄像头问题时,trace通常涉及从应用层到底层驱动的日志收集和分析。这时候可能需要启用不同层次的日志,比如CameraService的日志、HAL层的调试信息,或者使用systrace等工具进行性能分析。 然后,我需要考虑用户可能的实际需求。如果是开发者,他们可能想知道如何启用摄像头相关的日志,如何抓取trace,或者使用哪些工具来分析摄像头性能问题。如果是普通用户,可能的问题是如何排查摄像头无法使用的情况,但普通用户可能不会直接使用trace工具,所以更可能是开发者或技术支持人员需要这些信息。 接下来,我需要整理Android中常用的trace工具和方法。例如,使用adb logcat来查看日志,通过设置属性启用详细日志(如persist.camera.log.enable),使用systrace或Perfetto进行系统级性能跟踪,或者使用厂商提供的特定工具。此外,在Android的相机应用中可能存在隐藏的开发者选项,可以启用更详细的日志记录。 另外,Android的Camera2 API和后来的CameraX库可能提供了不同的调试方法。需要检查这些API的文档,看看是否有相关的追踪或日志功能。例如,在Camera2中,可以通过设置相机会话的参数来获取回调信息,帮助追踪摄像头状态。 还需要考虑到不同Android版本之间的差异。比如,在Android 10及以上,项目主线(Project Treble)可能改变了HAL层的结构,影响trace的方法。此外,某些厂商可能定制了自己的摄像头堆栈,trace的方法可能有所不同,需要参考特定厂商的文档。 然后,我应该组织这些信息,分步骤解释如何启用trace,收集日志,分析问题。可能需要包括具体的adb命令,如adb shell setprop log.tag.Camera VERBOSE,或者使用systrace的步骤。同时,提醒用户在抓取trace时复现问题,以确保日志中包含相关事件。 此外,可能存在的常见问题场景,比如摄像头启动失败、预览卡顿、拍照失败等,可以举例说明如何通过trace来定位问题。例如,如果摄像头无法打开,可以检查HAL层的日志是否有权限错误或硬件初始化失败的信息。 最后,需要验证信息的准确性,确保提到的工具和方法适用于当前主流的Android版本,并注意区分通用方法和厂商特定方法。同时,建议用户查阅官方文档或资源,如Android开发者网站或AOSP代码库,以获取最新信息。</think>Android Camera Trace 通常指用于调试、分析摄像头问题(如性能、异常行为)的追踪工具或日志系统。以下是逐步介绍: --- ### 一、Android 摄像头架构分层 1. **应用层**:调用 Camera API 的 App。 2. **Java Framework**:提供 `Camera`/`Camera2` API。 3. **Native Framework**:`CameraService`(核心服务)、`CameraProvider`(HAL 接口)。 4. **HAL 层**:厂商实现的硬件抽象层(如 `android.hardware.camera.provider@2.4`)。 5. **内核驱动**:Linux 内核的摄像头驱动(如 V4L2)。 --- ### 二、关键 Trace 工具与方法 #### 1. **Logcat 日志 - **启用摄像头详细日志**: ```bash adb shell setprop persist.camera.log.enable 1 adb shell setprop log.tag.Camera VERBOSE adb logcat -c && adb logcat -v threadtime > camera.log ``` - 过滤关键字:`CAMERA`、`CameraService`、`HAL`。 #### 2. **Camera HAL 调试 - 修改 HAL 层日志级别(需 root): ```bash adb shell setprop vendor.camera.hal.debug 5 # 部分厂商使用此属性 ``` #### 3. **Systrace/Perfetto - **抓取系统级 Trace**: 1. 启用 `systrace` 或 `Perfetto` 工具。 2. 添加 `camera` 和 `graphics` 类别。 3. 复现问题后分析关键线程(如 `CameraService`、`Binder` 调用)。 #### 4. **厂商专用工具 - 高通:使用 `QCXLog` 或 `QCAT` 分析摄像头流水线。 - 联发科:通过 `MTKLogger` 抓取底层日志。 --- ### 三、常见问题定位 #### 场景 1:摄像头启动失败 1. **检查 Logcat**: - 搜索 `CameraService::connect` 错误,确认权限或 HAL 返回码。 - 示例错误:`STATUS_ERROR_ENUMERATE`(设备未找到)。 2. **HAL 日志**: - 检查 `camx` 或 `mm-camera` 日志(厂商相关),确认传感器初始化是否超时。 #### 场景 2:预览卡顿 1. **Systrace 分析**: - 观察 `SurfaceView` 的帧提交间隔。 - 检查 `dequeueBuffer` 是否阻塞(可能 GPU 或 Buffer 不足)。 2. **CPU/GPU 负载**: - 使用 `top` 或 `dumpsys gfxinfo` 查看资源占用。 --- ### 四、高级调试 - **启用 Camera2 调试**: ```java CameraCharacteristics characteristics = manager.getCameraCharacteristics(cameraId); characteristics.get(CameraCharacteristics.INFO_SUPPORTED_HARDWARE_LEVEL); // 使用 `dumpsys media.camera` 查看设备状态 ``` - **AOSP 源码分析**: - 关键代码路径:`frameworks/av/services/camera/libcameraservice` --- ### 五、注意事项 1. **版本差异**:Android 10+ 强制要求 Treble 架构,HAL 实现可能不同。 2. **厂商定制**:部分日志属性或工具需参考厂商文档(如高通/MTK/华为)。 通过以上步骤,可系统性定位摄像头问题(从 API 调用到驱动层)。建议结合官方文档与具体设备信息进一步分析。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值