Android15跟踪函数调用关系

注:这里介绍Android15 Camera系统调试用到的跟踪函数调用关系的一些方法。

使用CallStack类dump调用栈

例如,跟踪Camera3OutputStream对象的创建。

1.dump调用栈

步骤1.Camera3OutputStream.h/.cpp中通过CallStack类打印调用信息.

复制代码
//frameworks/av/services/camera/libcameraservice/device3/Camera3OutputStream.h
//添加dumpCallStack()接口,封装CallStack调用
class Camera3OutputStream :
        public Camera3IOStreamBase,
        public Camera3OutputStreamInterface {
    ...
    static void dumpCallStack(const char* prefix);
};
//frameworks/av/services/camera/libcameraservice/device3/Camera3OutputStream.cpp
//添加dumpCallStack()接口实现
#include "utils/CallStack.h"
void Camera3OutputStream::dumpCallStack(const char* prefix)
{
    android::CallStack stack(prefix);
    stack.update();
    //stack.log("CAMERA_CALLSTACK");
}

步骤2.Camera3OutputStream需要的位置添加dumpCallStack()调用

复制代码
//frameworks/av/services/camera/libcameraservice/device3/Camera3OutputStream.cpp
Camera3OutputStream::Camera3OutputStream(int id,
        sp<Surface> consumer,
        uint32_t width, uint32_t height, int format,
        android_dataspace dataSpace, camera_stream_rotation_t rotation,
        nsecs_t timestampOffset, const std::string& physicalCameraId,
        const std::unordered_set<int32_t> &sensorPixelModeUsed, IPCTransport transport,
        int setId, bool isMultiResolution, int64_t dynamicRangeProfile,
        int64_t streamUseCase, bool deviceTimeBaseIsRealtime, int timestampBase,
        int mirrorMode, int32_t colorSpace, bool useReadoutTimestamp) :
        Camera3IOStreamBase(id, CAMERA_STREAM_OUTPUT, width, height,
                        /*maxSize*/0, format, dataSpace, rotation,
                        physicalCameraId, sensorPixelModesUsec, setId, isMultiResolution,
                        dynamicRangeProfile, streamUseCase, deviceTimeBaseRealtime,
                        timestampBase, colorSpace),
        mConsumer(consumer),
        mTransform(0),
        ... {
        
        dumpCallStack("Camera3OutputStream::Camera3OutputStream1");
        ...
}

步骤3.编译并更新cameraserver到设备

步骤4.重启系统

步骤5.操作相机

2.查看调用栈

通过logcat抓取日志,有如下调用关系

相关推荐
DogDaoDao5 小时前
Android 硬件编码器参数完全指南:MediaCodec 深度解析
android·音视频·视频编解码·h264·硬编码·视频直播·mediacodec
JohnnyDeng946 小时前
Android 自定义 View:Canvas 绘图与事件分发深度解析
android
Android小码家9 小时前
Framework之Launcher小窗开发
android·framework·虚拟屏·小窗
赏金术士9 小时前
第七章:状态管理实战与架构总结
android·ui·kotlin·compose
颂love10 小时前
MySQL的执行流程
android·数据库·mysql
云起SAAS15 小时前
抖音小游戏源码 - 消消乐 | 含激励广告+成就系统 | 开箱即用商业级消除游戏模板
android·游戏·广告联盟·看激励广告联盟流量主·抖音小游戏源码 - 消消乐
大貔貅喝啤酒16 小时前
基于Windows下载安装Android Studio 3.3.2版本教程(2026详细图文版)
android·java·windows·android studio
程序员码歌16 小时前
OpenSpec 到 Superpowers:AI 编码从说清到做对
android·前端·人工智能
2501_9151063216 小时前
深入解析无源码iOS加固原理与方案,保护应用安全
android·安全·ios·小程序·uni-app·cocoa·iphone
黄林晴20 小时前
重磅官宣:Android UI 开发正式进入 Compose-first 时代
android·google io