我这有两款摄像头,分别是 KS2A418-2.0、USB HD Camera,这两款摄像头都支持UVC。
这两款摄像头接电脑都可以正常打开,但是接到RK3399开发板,USB HD Camera可以正常打开, KS2A418-2.0则提示 Camera error cannot connect the camera。
查看两款摄像头分辨率,分别如下:
通过查询资料,可能是系统相机默认打开分辨率问题,遂下载了一款360相机安装到开发板中进行测试,打开下载的360相机,可正常调用。
若出现该情况,即系统相机无法调用摄像头问题,按以下进行检查:
1、确认摄像头支持UVC驱动。可通过串口日志查看是否有摄像头接入。
2、确认 /dev目录下有video设备,如下图所示:图中video0设备即为摄像头驱动。
3、下载相机APP调用摄像头测试。
查资料说的是系统相机只能打开640*480分辨率摄像头,其他的不支持。在哪修改系统相机默认分辨率,暂时还不太清楚。
参考资料:https://blog.csdn.net/sslinp/article/details/84825530
移植的MIPI摄像头OV5648也出现了同样的问题,刚开始是可以出图像的,用了一段时间,改进了一版电路板,后来又出了同样的问题,使用360相机可以打开,但是使用系统自带的相机就无法打开。
通过示波器排除了reset,powerdown,Mclk,I2C等问题,通过logcat -s CameraHal 查看调试信息,出现 “camsys_marvin has been opened”的错误信息,在驱动中找到相关文件,kernel/drivers/media/video/rk_camsys/camsys_drv.c下找到camsys_open()函数,临时屏蔽该条异常判断,升级kernel再次测试,系统相机可以调用OV5648,多次测试都可以出图像,说明系统相机调用摄像头时,一直提示被占用,实际没有占用,相机没有做处理,而360相机可能是做了一些处理。目前暂时还没有找到相关处理办法。
diff --git a/kernel/drivers/media/video/rk_camsys/camsys_drv.c b/kernel/drivers/media/video/rk_camsys/camsys_drv.c
index ba47c65..d1f02cf 100644
--- a/kernel/drivers/media/video/rk_camsys/camsys_drv.c
+++ b/kernel/drivers/media/video/rk_camsys/camsys_drv.c
@@ -810,12 +810,19 @@ static int camsys_open(struct inode *inode, struct file *file)
}
}
spin_unlock(&camsys_devs.lock);
- if (atomic_read(&camsys_dev->refcount) >= 1) {
- camsys_err("%s has been opened!",
- dev_name(camsys_dev->miscdev.this_device));
- err = -EBUSY;
- goto end;
+ // dlc del for test 20200114
+ //if (atomic_read(&camsys_dev->refcount) >= 1) {
+ // printk("-----error %d-----\n", atomic_read(&camsys_dev->refcount) );
+ // camsys_err("%s has been opened!",
+ // dev_name(camsys_dev->miscdev.this_device));
+ // err = -EBUSY;
+ // goto end;
+ //}
+ //else
+ {
+ printk("-----success %d-----\n",atomic_read(&camsys_dev->refcount) );
}
+
INIT_LIST_HEAD(&camsys_dev->extdevs.active);