media: v4l: async: Fix duplicated list deletion
authorSebastian Reichel <sre@kernel.org>
Mon, 13 Nov 2023 22:57:23 +0000 (23:57 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 25 Jan 2024 23:35:33 +0000 (15:35 -0800)
[ Upstream commit 3de6ee94aae701fa949cd3b5df6b6a440ddfb8f2 ]

The list deletion call dropped here is already called from the
helper function in the line before. Having a second list_del()
call results in either a warning (with CONFIG_DEBUG_LIST=y):

list_del corruption, c46c8198->next is LIST_POISON1 (00000100)

If CONFIG_DEBUG_LIST is disabled the operation results in a
kernel error due to NULL pointer dereference.

Fixes: 28a1295795d8 ("media: v4l: async: Allow multiple connections between entities")
Signed-off-by: Sebastian Reichel <sre@kernel.org>
Signed-off-by: Sakari Ailus <sakari.ailus@linux.intel.com>
Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/media/v4l2-core/v4l2-async.c

index 091e8cf4114ba2bb6903bbff6712adf1b140701d..8cfd593d293d10d754b21ef828da1dd9bcacc30a 100644 (file)
@@ -880,7 +880,6 @@ void v4l2_async_unregister_subdev(struct v4l2_subdev *sd)
                                  &asc->notifier->waiting_list);
 
                        v4l2_async_unbind_subdev_one(asc->notifier, asc);
-                       list_del(&asc->asc_subdev_entry);
                }
        }