Commit 50fe0de0 authored by Ezequiel Garcia's avatar Ezequiel Garcia Committed by Mauro Carvalho Chehab

media: marvell-ccic: Use v4l2_async_notifier_add_*_subdev

The use of v4l2_async_notifier_add_subdev will be discouraged.
Drivers are instead encouraged to use a helper such as
v4l2_async_notifier_add_fwnode_remote_subdev.

This fixes a misuse of the API, as v4l2_async_notifier_add_subdev
should get a kmalloc'ed struct v4l2_async_subdev,
removing some boilerplate code while at it.

Use the appropriate helper: v4l2_async_notifier_add_i2c_subdev
or v4l2_async_notifier_add_fwnode_remote_subdev, which handles
the needed setup, instead of open-coding it.
Signed-off-by: default avatarEzequiel Garcia <ezequiel@collabora.com>
Reviewed-by: default avatarJacopo Mondi <jacopo+renesas@jmondi.org>
Reviewed-by: default avatarHelen Koike <helen.koike@collabora.com>
Signed-off-by: default avatarSakari Ailus <sakari.ailus@linux.intel.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab+huawei@kernel.org>
parent 88367b15
...@@ -489,6 +489,7 @@ static int cafe_pci_probe(struct pci_dev *pdev, ...@@ -489,6 +489,7 @@ static int cafe_pci_probe(struct pci_dev *pdev,
int ret; int ret;
struct cafe_camera *cam; struct cafe_camera *cam;
struct mcam_camera *mcam; struct mcam_camera *mcam;
struct v4l2_async_subdev *asd;
/* /*
* Start putting together one of our big camera structures. * Start putting together one of our big camera structures.
...@@ -546,9 +547,16 @@ static int cafe_pci_probe(struct pci_dev *pdev, ...@@ -546,9 +547,16 @@ static int cafe_pci_probe(struct pci_dev *pdev,
if (ret) if (ret)
goto out_pdown; goto out_pdown;
mcam->asd.match_type = V4L2_ASYNC_MATCH_I2C; v4l2_async_notifier_init(&mcam->notifier);
mcam->asd.match.i2c.adapter_id = i2c_adapter_id(cam->i2c_adapter);
mcam->asd.match.i2c.address = ov7670_info.addr; asd = v4l2_async_notifier_add_i2c_subdev(&mcam->notifier,
i2c_adapter_id(cam->i2c_adapter),
ov7670_info.addr,
sizeof(*asd));
if (IS_ERR(asd)) {
ret = PTR_ERR(asd);
goto out_smbus_shutdown;
}
ret = mccic_register(mcam); ret = mccic_register(mcam);
if (ret) if (ret)
......
...@@ -1866,16 +1866,6 @@ int mccic_register(struct mcam_camera *cam) ...@@ -1866,16 +1866,6 @@ int mccic_register(struct mcam_camera *cam)
cam->pix_format = mcam_def_pix_format; cam->pix_format = mcam_def_pix_format;
cam->mbus_code = mcam_def_mbus_code; cam->mbus_code = mcam_def_mbus_code;
/*
* Register sensor notifier.
*/
v4l2_async_notifier_init(&cam->notifier);
ret = v4l2_async_notifier_add_subdev(&cam->notifier, &cam->asd);
if (ret) {
cam_warn(cam, "failed to add subdev to a notifier");
goto out;
}
cam->notifier.ops = &mccic_notify_ops; cam->notifier.ops = &mccic_notify_ops;
ret = v4l2_async_notifier_register(&cam->v4l2_dev, &cam->notifier); ret = v4l2_async_notifier_register(&cam->v4l2_dev, &cam->notifier);
if (ret < 0) { if (ret < 0) {
......
...@@ -151,7 +151,6 @@ struct mcam_camera { ...@@ -151,7 +151,6 @@ struct mcam_camera {
*/ */
struct video_device vdev; struct video_device vdev;
struct v4l2_async_notifier notifier; struct v4l2_async_notifier notifier;
struct v4l2_async_subdev asd;
struct v4l2_subdev *sensor; struct v4l2_subdev *sensor;
/* Videobuf2 stuff */ /* Videobuf2 stuff */
......
...@@ -180,6 +180,7 @@ static int mmpcam_probe(struct platform_device *pdev) ...@@ -180,6 +180,7 @@ static int mmpcam_probe(struct platform_device *pdev)
struct resource *res; struct resource *res;
struct fwnode_handle *ep; struct fwnode_handle *ep;
struct mmp_camera_platform_data *pdata; struct mmp_camera_platform_data *pdata;
struct v4l2_async_subdev *asd;
int ret; int ret;
cam = devm_kzalloc(&pdev->dev, sizeof(*cam), GFP_KERNEL); cam = devm_kzalloc(&pdev->dev, sizeof(*cam), GFP_KERNEL);
...@@ -238,10 +239,15 @@ static int mmpcam_probe(struct platform_device *pdev) ...@@ -238,10 +239,15 @@ static int mmpcam_probe(struct platform_device *pdev)
if (!ep) if (!ep)
return -ENODEV; return -ENODEV;
mcam->asd.match_type = V4L2_ASYNC_MATCH_FWNODE; v4l2_async_notifier_init(&mcam->notifier);
mcam->asd.match.fwnode = fwnode_graph_get_remote_port_parent(ep);
asd = v4l2_async_notifier_add_fwnode_remote_subdev(&mcam->notifier,
ep, sizeof(*asd));
fwnode_handle_put(ep); fwnode_handle_put(ep);
if (IS_ERR(asd)) {
ret = PTR_ERR(asd);
goto out;
}
/* /*
* Register the device with the core. * Register the device with the core.
...@@ -278,7 +284,6 @@ static int mmpcam_probe(struct platform_device *pdev) ...@@ -278,7 +284,6 @@ static int mmpcam_probe(struct platform_device *pdev)
pm_runtime_enable(&pdev->dev); pm_runtime_enable(&pdev->dev);
return 0; return 0;
out: out:
fwnode_handle_put(mcam->asd.match.fwnode);
mccic_shutdown(mcam); mccic_shutdown(mcam);
return ret; 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