在Android设备上打开Perfetto调试日志开关
背景说明
在Android设备上调试 Perfetto 采集日志的模块时,发现 logcat 中打印的 Perfetto 日志只有 info 及以上等级。通过分析 Perfetto 源码发现,日志等级受特定宏控制。
日志级别控制宏
Perfetto打印日志相关的代码在 external/perfetto/include/perfetto/base/logging.h文件中,Perfetto 日志等级受以下宏控制:
PERFETTO_FORCE_DLOG_ONPERFETTO_VERBOSE_LOGS


要打印 info 以下级别的日志(如 verbose、debug 级别),需要修改这些宏并重新编译。
宏修改方法
在以下文件中找到这两个宏,将这两个宏的值都修改为1
external/perfetto/include/perfetto/base/build_configs/android_tree/perfetto_build_flags.h
如图:

重新编译生效
修改宏定义后,需要重新编译 Perfetto。在AOSP中编译perfetto的方式如下:
在Android 源码中编译Perfetto:
# 在 AOSP 源码根目录执行
mmma external/perfetto
# 或编译特定组件
m traced traced_probes perfetto
编译方法参考:
- Perfetto build instructions - Perfetto Tracing Docs
- 构建 Android | Android Open Source Project
重新编译并刷入设备后,在 logcat 中应该能看到更详细的 Perfetto 调试日志,包括 verbose 和 debug 级别的输出。
