]> www.infradead.org Git - users/dwmw2/linux.git/commitdiff
media: v4l: async: Fix notifier list entry init
authorAlexander Stein <alexander.stein@ew.tq-group.com>
Thu, 7 Mar 2024 14:24:51 +0000 (15:24 +0100)
committerHans Verkuil <hverkuil-cisco@xs4all.nl>
Wed, 10 Apr 2024 13:15:30 +0000 (15:15 +0200)
struct v4l2_async_notifier has several list_head members, but only
waiting_list and done_list are initialized. notifier_entry was kept
'zeroed' leading to an uninitialized list_head.
This results in a NULL-pointer dereference if csi2_async_register() fails,
e.g. node for remote endpoint is disabled, and returns -ENOTCONN.
The following calls to v4l2_async_nf_unregister() results in a NULL
pointer dereference.
Add the missing list head initializer.

Fixes: b8ec754ae4c5 ("media: v4l: async: Set v4l2_device and subdev in async notifier init")
Cc: <stable@vger.kernel.org> # for 6.6 and later
Signed-off-by: Alexander Stein <alexander.stein@ew.tq-group.com>
Signed-off-by: Sakari Ailus <sakari.ailus@linux.intel.com>
Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl>
drivers/media/v4l2-core/v4l2-async.c

index 3ec323bd528b161e156284f35f43e006196fff71..6a7dcf43d71257cf3f9ac72b8856cd8131df44d1 100644 (file)
@@ -563,6 +563,7 @@ void v4l2_async_nf_init(struct v4l2_async_notifier *notifier,
 {
        INIT_LIST_HEAD(&notifier->waiting_list);
        INIT_LIST_HEAD(&notifier->done_list);
+       INIT_LIST_HEAD(&notifier->notifier_entry);
        notifier->v4l2_dev = v4l2_dev;
 }
 EXPORT_SYMBOL(v4l2_async_nf_init);
@@ -572,6 +573,7 @@ void v4l2_async_subdev_nf_init(struct v4l2_async_notifier *notifier,
 {
        INIT_LIST_HEAD(&notifier->waiting_list);
        INIT_LIST_HEAD(&notifier->done_list);
+       INIT_LIST_HEAD(&notifier->notifier_entry);
        notifier->sd = sd;
 }
 EXPORT_SYMBOL_GPL(v4l2_async_subdev_nf_init);