手记

高通 Camx debug log控制

某天,在某网站上看到一句话,“log开的好,问题都能搞”。 

问题能不能都搞好不知道,不过log开的好,对分析问题的确有很大的帮助。

高通camx的日志主要分2大模块,UMD (user mode driver) 和KMD( kerner mode driver),也就是用户层和kernel层日志。 

下面就来看下这2大块日志debug的时候该如何设置?

一、UDM日志 

高通camx camera debug日志格式如下: 

 CamX: [<Verbosity Level>][<Group>] <File>:<Line Number> <Function Name> <Message>.

例子:CamX: [INFO][CORE] camxexamplefile:123 ExampleFunction()This is the message.

有2种方式可以设置日志打印开关: 

第一种是在:/vendor/etc/camera/camxoverridesettings.txt 文件中进行配置;

另一种是通过adb命令设置prop属性:adb shell setprop <setting> <value>

我们先看看下camx下都定义了哪些日志类型等级(如下图所示)。

Error等级的日志是默认输出的。

接下来再看下,设置各日志类型等级对应的相关属性。

例如:

我们需要打开Info级别的日志,那对应的就是设置logInfoMask属性值。

大家肯定还有疑问,camx里面有这么多模块,怎么去单独打开某个模块的日志呢?


好了,看下面表格,各个模块高通已经给我们定义好了,定义的代码在camx/src/utils/camxtypes.h里面。

下面来举个具体的例子:

我需要打开camx里面ISP的Info级别的日志,怎么设?

对应上面的表格,CamxLogGroupISP 对应的值是 1<< 3,1<<3也就是 0x8;

而且从上面我们知道 info级别的日志,对应的属性是logInfoMask。

那很简单了,设置如下:

adb shell setprop persist.vendor.camera.logInfoMask 0x8 

或:

adb root 
adb remount
adb shell "echo logInfoMask=0x8 >> /vendor/etc/camera/camxoverridesettings.txt"


然后kill下camera 服务相关的进程,我们设置的内容就生效了。


二、KMD日志

例子:

我们需要打开 KMD里面 CAM_SENSOR and CAM_ICP 的调试日志, 怎么设?

adb root 

adb remount 

adb shell “echo 0x120 > /sys/module/cam_debug_util/parameters/debug_mdl” 

adb shell cat /proc/kmsg > name_of_kmd_logs.txt


还是别人说的话,"在熟练掌握 UDM KDM 及 usecase 的 debug 流程之后,解起问题称心如意。如果不是这样,那一定是你的log 没加对,自省."



深圳上班,

生活简简单单,

14年开始从事Android Camera相关软件开发工作,

做过车载、手机、执法记录仪......



 

1人推荐
随时随地看视频
慕课网APP