camera调试:RK3588 apk打开不出图如何排查?

这篇具有很好参考价值的文章主要介绍了camera调试:RK3588 apk打开不出图如何排查?。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

这篇文章主要介绍一下,驱动已经实现,i2c已经通信正常且驱动成功注册,但是apk打开不出图应该如何排查。

很多同学调试camera的时候,经常会遇到,驱动按照原厂给的序列配置了,但是打开apk不出图或者apk直接闪退,下面介绍一下这类问题主要的排查方向。

(1)确认sensor驱动是否正常注册

查看log,类似如下,sensor check ID正常之后就会注册成V4L2子设备,log会打印连接到对应的DPHY上面。

[    2.441640][    T1] gc8034 4-0037: driver version: 00.01.09
[    2.441689][    T1] gc8034 4-0037: Failed to get power-gpios, maybe no use
[    2.441794][    T1] gc8034 4-0037: supply dovdd not found, using dummy regulator
[    2.441902][    T1] gc8034 4-0037: supply dvdd not found, using dummy regulator
[    2.441946][    T1] gc8034 4-0037: supply avdd not found, using dummy regulator
[    2.441985][    T1] gc8034 4-0037: lane_num(2)  pixel_rate(320400000)
[    2.441998][    T1] gc8034 4-0037: could not get default pinstate
[    2.442006][    T1] gc8034 4-0037: could not get sleep pinstate
[    2.448076][    T1] gc8034 4-0037: detected gc8044 sensor
[    2.448156][    T1] rockchip-csi2-dphy csi2-dphy1: dphy1 matches m00_b_gc8034 4-0037:bus type 5
[    2.448806][    T1] rkcif-mipi-lvds: Async subdev notifier completed
[    2.449111][  T144] rkisp-vir0: Async subdev notifier completed

sensor注册失败,大多数原因都是check ID失败,也就是i2c不通,可以看上一篇文章进行排查:

(1条消息) camera调试:i2c不通如何排查?_人生苦短,我想躺平的博客-CSDN博客

(2)查看拓扑是否正常

查看pipeline的命令如下:

media-ctl -p -d /dev/mediaX   X = 0..1..2..3...

在rk3588的平台上,正常会有两个链路,分别如下:

sensor -> csi_dphy -> mipi_csi2 -> rkcif_mipi_lvds
rkcif_mipi_lvds_stdif -> rkisp_vir

可使用上述命令查看pipeline链路是否完整。

(3)确认驱动是否可以抓图

使用V4L2工具抓图确认驱动是否正常,RAWsensor可以从RKCIF的节点抓RAW数据:

设置非紧凑

echo 0 > /sys/devices/platform/rkcif_mipi_lvds/compact_test

抓raw图

v4l2-ctl -d /dev/video0 --set-fmt-video=width=1920,height=1080,pixelformat='BG10' --stream-mmap=3 --stream-skip=20 --stream-to=/data/1080p60.raw --stream-count=5 --stream-poll

抓数据流,不保存图,仅刷出帧率:

v4l2-ctl --verbose -d /dev/video0 --set-fmt-video=width=1920,height=1080,pixelformat='NV12' --stream-mmap=4 --set-selection=target=crop,flags=0,top=0,left=0,width=1920,height=1080

如果可以抓到数据流,或者可以抓到图像的话,可以从isp 节点的mainpath抓一张NV12的图像,使用看图软件确认图像是否正常,可以确认驱动是否正常出图

抓不到图,下面分几种情况:

①命令敲完直接报错(no such devices/invalid param)

命令敲完直接停止报错,检查命令是否正确。

可能还会出现no such devices之类的报错,大概率是由于链路没有enabled的导致的,正常开机之后pipeline是enabled的,如果打开了apk,pipeline有可能会被清空,建议直接重启之后不打开apk,直接抓数据。命令配置pipeline参考:

V4L2常用调试命令_人生苦短,我想躺平的博客-CSDN博客_v4l2调试

②抓数据没有,串口也没有报错,抓图select timeout

这种情况可能性一般有以下:

  • 接口错误,RK3588有多个MIPI接口,dts配置的接口和实际硬件的连接对不上
  • 硬件错误,硬件的连接性错了
  • sensor没输出
  • 其他主控的问题

上述的问题,比较常见的是dts配置错误和sensor没有信号输出,可以直接测量MIPI信号来确认,后面的文章会介绍主控端如何通过寄存器排查信号的问题。

③出现MIPI 相关报错

出现MIPI相关的报错,比较常见的是出现crc的报错刷屏:

[ 2266.859853][    C0] mipi2-csi2 ERR1:0x1000000 (crc,vc: 0) 
[ 2266.859862][    C0] mipi2-csi2 ERR1:0x1000000 (crc,vc: 0) 
[ 2266.859869][    C0] mipi2-csi2 ERR2:0x100 (ecc,vc: 0) 
[ 2266.859920][    C0] mipi2-csi2 ERR1:0x1000000 (crc,vc: 0) 
[ 2266.859930][    C0] mipi2-csi2 ERR1:0x10000000 (ecc2)
[ 2266.859962][    C0] mipi2-csi2 ERR1:0x1000000 (crc,vc: 0) 
[ 2266.859970][    C0] mipi2-csi2 ERR2:0x100 (ecc,vc: 0) 
[ 2266.860026][    C0] mipi2-csi2 ERR1:0x1000000 (crc,vc: 0) 
[ 2266.860033][    C0] mipi2-csi2 ERR1:0x10000000 (ecc2)
[ 2266.860093][    C0] mipi2-csi2 ERR1:0x1000000 (crc,vc: 0) 
[ 2266.860101][    C0] mipi2-csi2 ERR1:0x1000000 (crc,vc: 0) 
[ 2266.860108][    C0] mipi2-csi2 ERR2:0x100 (ecc,vc: 0) 
[ 2266.860160][    C0] mipi2-csi2 ERR1:0x1000000 (crc,vc: 0) 
[ 2266.860167][    C0] mipi2-csi2 ERR1:0x1000000 (crc,vc: 0)

出现上述mipi相关的报错,crc/ecc等报错,本质上都是与phy层的mipi信号相关,可能原因如下:

  • 驱动配置的MIPI时钟与sensor输出的MIPI时钟对应不上
  • MIPI时序错误,例如SOT的时序不符合MIPI的SPEC
  • MIPI信号质量不佳导致的报错

示波器测量可以确认sensor输出的MIPI时钟大小,驱动需要与其对应,MIPI信号质量的问题,可以通过将驱动的xvclk降低到12M/6M,如果降低后没出现MIPI的报错,那么需要排查硬件的走线等等。MIPI时序的问题,建议测量MIPI信号,看是否符合spec,后面再写文章来介绍这部分。

④vicap控制器的其他报错

包括PICK_SIZE_ERROR报错、iommu的报错等,需要确认一下sensor输出的图像格式是否正确,驱动配置的是否正确,抓图的大小与图像格式是否正确等等。

(4)确认camera服务是否成功注册设备

使用如下命令确认camera设备是否注册上:

dumpsys media.camera

如果发现设备没有注册上,重点排查camera3_profiles.xml文件配置是否正确,重点是moduleID 和name字段的检查。

(5)确认IQ效果文件的有效性

JSON文件在设备上的/vendor/etc/camera/rkisp2/,命名规则如下:

sensor_module-name_module-lens-name.json

确认文件命令是否正确,已经效果文件是否有效,需要跟dts的配置对应。

这个问题也可以先使用SOC运行看是否正常,SOC模式不会跑3A算法,也就不会用到IQ文件。

(6)cameraHAL报错

cameraHAL的相关报错导致,可以搜索logcat的关键词进行排查定位问题:

E RkCamera

(7)camera_engine_rkaiq相关报错

AIQ的相关报错,建议给原厂排查。文章来源地址https://www.toymoban.com/news/detail-482956.html

到了这里,关于camera调试:RK3588 apk打开不出图如何排查?的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • RK3588-ES8388音频调试笔记

    本文是基于RK3588平台,音频芯片ES8388调试总结。 外接声卡:ES8388 步骤 ① dts配置 步骤 ② 编译烧写,调试 系统声音配置: ES8388设备驱动配置 查看声卡命令: cat /proc/asound/cards 将wav文件拷贝到板子上: RK Android 播放音乐 ( RK Android SDK 标配 tiny-alsa 工具 ): RK Android 录音: RK Li

    2024年02月16日
    浏览(52)
  • RK3588 - ES8388音频调试笔记

    专栏总目录 本文是基于RK3588平台,音频芯片ES8388调试总结。 外接声卡:ES8388 步骤 ① dts配置 步骤 ② 编译烧写,调试 系统声音配置: ES8388设备驱动配置 查看声卡命令: cat /proc/asound/cards 将wav文件拷贝到板子上: RK Android 播放音乐 ( RK Android SDK 标配 tiny-alsa 工具 ): RK Android

    2024年02月15日
    浏览(77)
  • RK3588 Android 12 北斗模块调试

    北斗模块用的MTK RS1612M3 , http://www.sragps.com/web/down.html,可以查看相关资料,用串口和系统通讯 Android12中主要包括串口设备树修改,GPS2.0加载,gps.default.so编译和上层应用测试,以下主要记录测试中碰到的难点 板子上用的串口8,因此打开uart8的设备树配置 uart8 { status = “okay”;

    2024年02月15日
    浏览(42)
  • RK3588-MIPI屏幕调试笔记:RK3588-MIPI-DSI之LCD上电初始化时序

    mipi屏调试一般都要在RK平台的dts中配置屏幕上电初始化时序 :panel-init-sequence和下电初始化时序:panel-exit-sequence。本文讲解如何配置屏幕的这些初始化时序。 注意:这里的parameter并不是指数据字节个数 0x05 命令类型:(DCS Short Write, no parameters) 0x15 命令类型:(DCS Short Write, 1 p

    2024年02月12日
    浏览(86)
  • ArmSoM-W3(RK3588)之调试UART

    专栏总目录 本文主要讲解如何关于RK3588开发板UART的使用和调试方法,包括UART作为普通串口和控制台两种不同使用场景 Rockchip UART (Universal Asynchronous Receiver/Transmitter) 基于16550A串口标准,完整模块支持以下功能: 支持5、6、7、8 bits数据位。 支持1、1.5、2 bits停止位。 支持奇校

    2024年02月10日
    浏览(61)
  • RK3588开发笔记-USB3.0接口调试

    目录 前言 一、资源介绍 二、硬件连接 三、设备树配置

    2024年02月08日
    浏览(41)
  • rk平台调试音频(从驱动到apk)

     需要实现的功能: 输入:hdmiin、uvc、mic可以实时切换 输出:耳机和HDMI OUT同时输出声音 这里注意:mic是存在hedset情况,4节耳机,即可输出又可输出同时进行 开发情况: 一、先熟悉大致的Android的音频架构及流程: 1.apk想要录音,播音的接口:常用接口 AudioManager:音频管理器

    2024年02月15日
    浏览(69)
  • RK35XX系列(RK3568)Camera 热插拔功能 调试记录

    SOC:RK3568 system:Android12 kernel:kernel-4.19 芯片:NVP6158C xs9922 目前我的主板上NVP6158接入4路Camera走DVP通道,xs9922接入4路AHDCamera走mipi通道 RK kernel-4.19支持xs9922 nvp6158c驱动路径       drivers/media/i2c/xs9922/xs9922.c  drivers/media/i2c/nvp6158_drv/nvp6158_v4l2.c RK支持Camera热插拔复位机制,如果

    2024年02月13日
    浏览(49)
  • ArmSoM-W3之RK3588 - ES8388音频调试笔记

    专栏总目录 本文是基于RK3588平台,音频芯片ES8388调试总结。 外接声卡:ES8388 步骤 ① dts配置 步骤 ② 编译烧写,调试 系统声音配置: ES8388设备驱动配置 查看声卡命令: cat /proc/asound/cards 将wav文件拷贝到板子上: RK Android 播放音乐 ( RK Android SDK 标配 tiny-alsa 工具 ): RK Android

    2024年02月12日
    浏览(190)
  • RK3588 PWM调试记录---linux pwm子系统驱动框架

    RK3588一共有4组PWM,每组有4个通道,共可以产生4*4=16路PWM波形; PWM0 开始地址:0xfd8b0000 PWM1 开始地址:0xfebd0000 PWM2 开始地址:0xfebe0000 PWM3 开始地址:0xfebf0000 即每组PWM的地址空间是(0xfd8b0000-0xfebd0000=0x1000)64KB(0x1000/1024) RK3588的PWM支持捕获、连续和单次触发三种模式。 1.捕获模式

    2024年02月12日
    浏览(55)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包