Commit 55fcb913 authored by Laurent Pinchart's avatar Laurent Pinchart Committed by Mauro Carvalho Chehab

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: default avatarLaurent Pinchart <laurent.pinchart@ideasonboard.com>
Reviewed-by: default avatarRicardo Ribalda <ribalda@chromium.org>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@kernel.org>
parent 56c8534e
...@@ -1326,8 +1326,12 @@ static const struct v4l2_file_operations rkisp1_fops = { ...@@ -1326,8 +1326,12 @@ static const struct v4l2_file_operations rkisp1_fops = {
static void rkisp1_unregister_capture(struct rkisp1_capture *cap) static void rkisp1_unregister_capture(struct rkisp1_capture *cap)
{ {
if (!video_is_registered(&cap->vnode.vdev))
return;
media_entity_cleanup(&cap->vnode.vdev.entity); media_entity_cleanup(&cap->vnode.vdev.entity);
vb2_video_unregister_device(&cap->vnode.vdev); vb2_video_unregister_device(&cap->vnode.vdev);
mutex_destroy(&cap->vnode.vlock);
} }
void rkisp1_capture_devs_unregister(struct rkisp1_device *rkisp1) void rkisp1_capture_devs_unregister(struct rkisp1_device *rkisp1)
...@@ -1381,14 +1385,14 @@ static int rkisp1_register_capture(struct rkisp1_capture *cap) ...@@ -1381,14 +1385,14 @@ static int rkisp1_register_capture(struct rkisp1_capture *cap)
if (ret) { if (ret) {
dev_err(cap->rkisp1->dev, dev_err(cap->rkisp1->dev,
"vb2 queue init failed (err=%d)\n", ret); "vb2 queue init failed (err=%d)\n", ret);
return ret; goto error;
} }
vdev->queue = q; vdev->queue = q;
ret = media_entity_pads_init(&vdev->entity, 1, &node->pad); ret = media_entity_pads_init(&vdev->entity, 1, &node->pad);
if (ret) if (ret)
return ret; goto error;
ret = video_register_device(vdev, VFL_TYPE_VIDEO, -1); ret = video_register_device(vdev, VFL_TYPE_VIDEO, -1);
if (ret) { if (ret) {
...@@ -1404,6 +1408,7 @@ static int rkisp1_register_capture(struct rkisp1_capture *cap) ...@@ -1404,6 +1408,7 @@ static int rkisp1_register_capture(struct rkisp1_capture *cap)
error: error:
media_entity_cleanup(&vdev->entity); media_entity_cleanup(&vdev->entity);
mutex_destroy(&node->vlock);
return ret; return ret;
} }
...@@ -1439,26 +1444,21 @@ rkisp1_capture_init(struct rkisp1_device *rkisp1, enum rkisp1_stream_id id) ...@@ -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) int rkisp1_capture_devs_register(struct rkisp1_device *rkisp1)
{ {
struct rkisp1_capture *cap; unsigned int i;
unsigned int i, j;
int ret; int ret;
for (i = 0; i < ARRAY_SIZE(rkisp1->capture_devs); i++) { for (i = 0; i < ARRAY_SIZE(rkisp1->capture_devs); i++) {
struct rkisp1_capture *cap = &rkisp1->capture_devs[i];
rkisp1_capture_init(rkisp1, i); rkisp1_capture_init(rkisp1, i);
cap = &rkisp1->capture_devs[i];
cap->rkisp1 = rkisp1;
ret = rkisp1_register_capture(cap); ret = rkisp1_register_capture(cap);
if (ret) if (ret) {
goto err_unreg_capture_devs; rkisp1_capture_devs_unregister(rkisp1);
return ret;
}
} }
return 0; return 0;
err_unreg_capture_devs:
for (j = 0; j < i; j++) {
cap = &rkisp1->capture_devs[j];
rkisp1_unregister_capture(cap);
}
return ret;
} }
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment