]> git.karo-electronics.de Git - mv-sheeva.git/blobdiff - drivers/media/video/sh_mobile_ceu_camera.c
[media] V4L: sh-mobile-ceu-camera: fix mixed CSI2 & parallel camera case
[mv-sheeva.git] / drivers / media / video / sh_mobile_ceu_camera.c
index 59101c0be869ceb870563ab15c7e1dc1f9a4c24d..5c8ddd821df604405b43061dc8c12b4e9ca311ff 100644 (file)
@@ -717,10 +717,13 @@ static void capture_restore(struct sh_mobile_ceu_dev *pcdev, u32 capsr)
 static struct v4l2_subdev *find_bus_subdev(struct sh_mobile_ceu_dev *pcdev,
                                           struct soc_camera_device *icd)
 {
-       if (!pcdev->csi2_pdev)
-               return soc_camera_to_subdev(icd);
+       if (pcdev->csi2_pdev) {
+               struct v4l2_subdev *csi2_sd = find_csi2(pcdev);
+               if (csi2_sd && csi2_sd->grp_id == (u32)icd)
+                       return csi2_sd;
+       }
 
-       return find_csi2(pcdev);
+       return soc_camera_to_subdev(icd);
 }
 
 #define CEU_BUS_FLAGS (V4L2_MBUS_MASTER |      \