mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-12-01 08:04:22 +08:00
media: rkisp1: capture: Fix and simplify (un)registration
The rkisp1_register_capture() and rkisp1_unregister_capture() functions don't destroy the mutex (in the error path for the former). Fix this and make rkisp1_unregister_capture() and rkisp1_capture_devs_unregister() safe to be called on an unregistered capture node to prepare for simplification of error handling at probe time. While at it, drop the double initialization of cap->rkisp1 in rkisp1_capture_devs_register() as the field is already initialized in rkisp1_capture_init(). Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> Reviewed-by: Ricardo Ribalda <ribalda@chromium.org> Signed-off-by: Mauro Carvalho Chehab <mchehab@kernel.org>
This commit is contained in:
parent
56c8534e2d
commit
55fcb913d5
@ -1326,8 +1326,12 @@ static const struct v4l2_file_operations rkisp1_fops = {
|
||||
|
||||
static void rkisp1_unregister_capture(struct rkisp1_capture *cap)
|
||||
{
|
||||
if (!video_is_registered(&cap->vnode.vdev))
|
||||
return;
|
||||
|
||||
media_entity_cleanup(&cap->vnode.vdev.entity);
|
||||
vb2_video_unregister_device(&cap->vnode.vdev);
|
||||
mutex_destroy(&cap->vnode.vlock);
|
||||
}
|
||||
|
||||
void rkisp1_capture_devs_unregister(struct rkisp1_device *rkisp1)
|
||||
@ -1381,14 +1385,14 @@ static int rkisp1_register_capture(struct rkisp1_capture *cap)
|
||||
if (ret) {
|
||||
dev_err(cap->rkisp1->dev,
|
||||
"vb2 queue init failed (err=%d)\n", ret);
|
||||
return ret;
|
||||
goto error;
|
||||
}
|
||||
|
||||
vdev->queue = q;
|
||||
|
||||
ret = media_entity_pads_init(&vdev->entity, 1, &node->pad);
|
||||
if (ret)
|
||||
return ret;
|
||||
goto error;
|
||||
|
||||
ret = video_register_device(vdev, VFL_TYPE_VIDEO, -1);
|
||||
if (ret) {
|
||||
@ -1404,6 +1408,7 @@ static int rkisp1_register_capture(struct rkisp1_capture *cap)
|
||||
|
||||
error:
|
||||
media_entity_cleanup(&vdev->entity);
|
||||
mutex_destroy(&node->vlock);
|
||||
return ret;
|
||||
}
|
||||
|
||||
@ -1439,26 +1444,21 @@ rkisp1_capture_init(struct rkisp1_device *rkisp1, enum rkisp1_stream_id id)
|
||||
|
||||
int rkisp1_capture_devs_register(struct rkisp1_device *rkisp1)
|
||||
{
|
||||
struct rkisp1_capture *cap;
|
||||
unsigned int i, j;
|
||||
unsigned int i;
|
||||
int ret;
|
||||
|
||||
for (i = 0; i < ARRAY_SIZE(rkisp1->capture_devs); i++) {
|
||||
struct rkisp1_capture *cap = &rkisp1->capture_devs[i];
|
||||
|
||||
rkisp1_capture_init(rkisp1, i);
|
||||
cap = &rkisp1->capture_devs[i];
|
||||
cap->rkisp1 = rkisp1;
|
||||
|
||||
ret = rkisp1_register_capture(cap);
|
||||
if (ret)
|
||||
goto err_unreg_capture_devs;
|
||||
if (ret) {
|
||||
rkisp1_capture_devs_unregister(rkisp1);
|
||||
return ret;
|
||||
}
|
||||
}
|
||||
|
||||
return 0;
|
||||
|
||||
err_unreg_capture_devs:
|
||||
for (j = 0; j < i; j++) {
|
||||
cap = &rkisp1->capture_devs[j];
|
||||
rkisp1_unregister_capture(cap);
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user