media: v4l: async: Move async subdev notifier operations to a separate structure
The async subdev notifier .bound(), .unbind() and .complete() operations are function pointers stored directly in the v4l2_async_subdev structure. As the structure isn't immutable, this creates a potential security risk as the function pointers are mutable. To fix this, move the function pointers to a new v4l2_async_subdev_operations structure that can be made const in drivers. Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> Acked-by: Hans Verkuil <hans.verkuil@cisco.com> Acked-by: Niklas Söderlund <niklas.soderlund+renesas@ragnatech.se> Reviewed-by: Sebastian Reichel <sebastian.reichel@collabora.co.uk> Signed-off-by: Mauro Carvalho Chehab <mchehab@s-opensource.com>
This commit is contained in:

committed by
Mauro Carvalho Chehab

parent
bce9e317ce
commit
b6ee3f0dcf
@@ -2171,6 +2171,10 @@ static int isp_subdev_notifier_complete(struct v4l2_async_notifier *async)
|
||||
return media_device_register(&isp->media_dev);
|
||||
}
|
||||
|
||||
static const struct v4l2_async_notifier_operations isp_subdev_notifier_ops = {
|
||||
.complete = isp_subdev_notifier_complete,
|
||||
};
|
||||
|
||||
/*
|
||||
* isp_probe - Probe ISP platform device
|
||||
* @pdev: Pointer to ISP platform device
|
||||
@@ -2341,7 +2345,7 @@ static int isp_probe(struct platform_device *pdev)
|
||||
if (ret < 0)
|
||||
goto error_register_entities;
|
||||
|
||||
isp->notifier.complete = isp_subdev_notifier_complete;
|
||||
isp->notifier.ops = &isp_subdev_notifier_ops;
|
||||
|
||||
ret = v4l2_async_notifier_register(&isp->v4l2_dev, &isp->notifier);
|
||||
if (ret)
|
||||
|
Reference in New Issue
Block a user