RK3288 USB UVC camera 摄像头 VIDIOC_DQBUF Failed!!! err[I/O error]

RK3288     Android5.1   多个品牌USB摄像头

同一块主板和代码,大部分品牌的USB摄像头可以正常使用,只有某一款USB摄像头不能使用。

插上摄像头,底层可以识别到摄像头。

<6>[ 47.479515] usb 3-1.4: new high-speed USB device number 5 using usb20_host
<6>[ 47.696548] usb 3-1.4: New USB device found, idVendor=058f, idProduct=2657
<6>[ 47.696719] usb 3-1.4: New USB device strings: Mfr=1, Product=2, SerialNumber=0
<6>[ 47.696825] usb 3-1.4: Product: PC Camera
<6>[ 47.696908] usb 3-1.4: Manufacturer: Alcor Micro, Corp.
<6>[ 47.708510] uvcvideo: Found UVC 1.00 device PC Camera (058f:2657)
<6>[ 47.718236] input: PC Camera as /devices/ff540000.usb/usb3/3-1/3-1.4/3-1.4:1.0/input/input5

但是每次打开摄像头app都显示“无法连接到相机”,上层 log 如下。

D/CameraHal(  177): setParameters(583): setParameters(583): Set preview size 800x600
... ...
D/CameraHal(  177): startPreview(177): startPreview177:preview_w = 800,preview_h = 600,drv_w = 800,drv_h = 600
D/CameraHal(  177): cameraSetSize(476): cameraSetSize(476):IN, w = 800,h = 600
... ...
E/CameraHal(  177): getFrame(614): getFrame(614): VIDIOC_DQBUF Failed!!! err[I/O error]
E/CameraHal(  177): getFrame(620): getFrame(620): camera driver or device may be error, so notify CAMERA_MSG_ERROR

最后官方的回复如下:

USB摄像头800x600分辨率输出有问题,强制使用1280x960,同时保留1280x720为录像使用,由软件剪切到1280x720

diff --git a/CameraHal/CameraUSBAdapter.cpp b/CameraHal/CameraUSBAdapter.cpp
index b88dd17..adb446b 100644
--- a/CameraHal/CameraUSBAdapter.cpp
+++ b/CameraHal/CameraUSBAdapter.cpp
@@ -134,8 +134,8 @@ void CameraUSBAdapter::initDefaultParameters(int camFd)

     params.set(KEY_PREVIEW_W_FORCE,"0");
     params.set(KEY_PREVIEW_H_FORCE,"0");
-    params.set(CameraParameters::KEY_SUPPORTED_PREVIEW_SIZES, parameterString.string());
-    params.setPreviewSize(640,480);
+    params.set(CameraParameters::KEY_SUPPORTED_PREVIEW_SIZES, "1280x960,1280x720");
+    params.setPreviewSize(1280, 960);
     /*picture size setting*/      
     params.set(CameraParameters::KEY_SUPPORTED_PICTURE_SIZES, parameterString.string());        
     params.setPictureSize(mCamDriverFrmWidthMax,  mCamDriverFrmHeightMax);   

按照官方的 patch 修改后,摄像头可以正常使用。

如果出现可以预览,不能拍照的问题,还需要更改拍照的分辨率

diff --git a/CameraHal/CameraUSBAdapter.cpp b/CameraHal/CameraUSBAdapter.cpp
index b88dd17..adb446b 100644
--- a/CameraHal/CameraUSBAdapter.cpp
+++ b/CameraHal/CameraUSBAdapter.cpp
@@ -134,8 +134,8 @@ void CameraUSBAdapter::initDefaultParameters(int camFd)

     params.set(KEY_PREVIEW_W_FORCE,"0");
     params.set(KEY_PREVIEW_H_FORCE,"0");
     params.set(CameraParameters::KEY_SUPPORTED_PREVIEW_SIZES, "1280x960,1280x720");
     params.setPreviewSize(1280, 960);
     /*picture size setting*/      
-    params.set(CameraParameters::KEY_SUPPORTED_PICTURE_SIZES, parameterString.string());        
-    params.setPictureSize(mCamDriverFrmWidthMax,  mCamDriverFrmHeightMax);
+    params.set(CameraParameters::KEY_SUPPORTED_PICTURE_SIZES, "1280x960,1280x720");        
+    params.setPictureSize(1280, 960);
原文地址:https://www.cnblogs.com/lialong1st/p/9075930.html