继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

高通 Camx debug log控制

小驰行动派
关注TA
已关注
手记 7
粉丝 3
获赞 5

某天,在某网站上看到一句话,“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等级的日志是默认输出的。

http://img2.sycdn.imooc.com/62013e69000108fe10310317.jpg

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

例如:

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

http://img3.sycdn.imooc.com/62013e690001db3310380279.jpg

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


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

http://img2.sycdn.imooc.com/62013e6a00019e4a10230653.jpg

下面来举个具体的例子:

我需要打开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日志

http://img2.sycdn.imooc.com/62013e6a0001b1f909440773.jpg

例子:

我们需要打开 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 没加对,自省."


http://img1.sycdn.imooc.com/62013e6b000189b006400042.jpg


深圳上班,

生活简简单单,

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

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



 

打开App,阅读手记
1人推荐
发表评论
随时随地看视频慕课网APP