From: Sakari Ailus Date: Thu, 11 May 2023 12:08:42 +0000 (+0200) Subject: media: v4l: async: Try more connections X-Git-Tag: v6.6.7~2014^2~194 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=765f60568f2904b2de3011a8de2fadba4e4de44f;p=platform%2Fkernel%2Flinux-starfive.git media: v4l: async: Try more connections When an async sub-device is registered, it used to be that the first one of its connections were matched when found. Continue looking for matches until a notifier no longer has any. Signed-off-by: Sakari Ailus Tested-by: Philipp Zabel # imx6qp Tested-by: Niklas Söderlund # rcar + adv746x Tested-by: Aishwarya Kothari # Apalis i.MX6Q with TC358743 Tested-by: Lad Prabhakar # Renesas RZ/G2L SMARC Signed-off-by: Mauro Carvalho Chehab --- diff --git a/drivers/media/v4l2-core/v4l2-async.c b/drivers/media/v4l2-core/v4l2-async.c index 44f72aa..6b3c02d 100644 --- a/drivers/media/v4l2-core/v4l2-async.c +++ b/drivers/media/v4l2-core/v4l2-async.c @@ -789,6 +789,7 @@ int v4l2_async_register_subdev(struct v4l2_subdev *sd) if (!v4l2_dev) continue; +again: asc = v4l2_async_find_match(notifier, sd); if (!asc) continue; @@ -801,13 +802,12 @@ int v4l2_async_register_subdev(struct v4l2_subdev *sd) if (ret) goto err_unbind; - goto out_unlock; + goto again; } /* None matched, wait for hot-plugging */ list_add(&sd->async_list, &subdev_list); -out_unlock: mutex_unlock(&list_lock); return 0;