From: Guennadi Liakhovetski Date: Sat, 25 Dec 2010 21:29:52 +0000 (-0300) Subject: [media] v4l: soc-camera: fix multiple simultaneous user case X-Git-Tag: firefly_0821_release~7613^2~3167^2 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=24d8c0293b04ad207648bb2a0dbfebff8b47d166;p=firefly-linux-kernel-4.4.55.git [media] v4l: soc-camera: fix multiple simultaneous user case A recent patch has introduced a regression, whereby a second open of an soc-camera video device breaks the running capture. This patch fixes this bug by guaranteeing, that video buffers get initialised only during the first open of the device node. Signed-off-by: Guennadi Liakhovetski Signed-off-by: Mauro Carvalho Chehab --- diff --git a/drivers/media/video/soc_camera.c b/drivers/media/video/soc_camera.c index 335120c2021b..052bd6dfa5a7 100644 --- a/drivers/media/video/soc_camera.c +++ b/drivers/media/video/soc_camera.c @@ -405,13 +405,13 @@ static int soc_camera_open(struct file *file) ret = soc_camera_set_fmt(icd, &f); if (ret < 0) goto esfmt; + + ici->ops->init_videobuf(&icd->vb_vidq, icd); } file->private_data = icd; dev_dbg(&icd->dev, "camera device open\n"); - ici->ops->init_videobuf(&icd->vb_vidq, icd); - mutex_unlock(&icd->video_lock); return 0;