diff options
Diffstat (limited to 'target/linux/bcm27xx/patches-5.10/950-0729-media-i2c-ov7251-Add-fwnode-properties-controls.patch')
-rw-r--r-- | target/linux/bcm27xx/patches-5.10/950-0729-media-i2c-ov7251-Add-fwnode-properties-controls.patch | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/target/linux/bcm27xx/patches-5.10/950-0729-media-i2c-ov7251-Add-fwnode-properties-controls.patch b/target/linux/bcm27xx/patches-5.10/950-0729-media-i2c-ov7251-Add-fwnode-properties-controls.patch new file mode 100644 index 0000000000..eb64d31d49 --- /dev/null +++ b/target/linux/bcm27xx/patches-5.10/950-0729-media-i2c-ov7251-Add-fwnode-properties-controls.patch @@ -0,0 +1,48 @@ +From f58356e67346323ffd3061aea7ca16c0f0f6a72e Mon Sep 17 00:00:00 2001 +From: Dave Stevenson <dave.stevenson@raspberrypi.com> +Date: Tue, 3 Aug 2021 11:33:33 +0100 +Subject: [PATCH] media: i2c: ov7251: Add fwnode properties controls + +Add call to v4l2_ctrl_new_fwnode_properties to read and +create the fwnode based controls. + +Signed-off-by: Dave Stevenson <dave.stevenson@raspberrypi.com> +--- + drivers/media/i2c/ov7251.c | 12 +++++++++++- + 1 file changed, 11 insertions(+), 1 deletion(-) + +--- a/drivers/media/i2c/ov7251.c ++++ b/drivers/media/i2c/ov7251.c +@@ -1253,6 +1253,7 @@ static const struct v4l2_subdev_ops ov72 + + static int ov7251_probe(struct i2c_client *client) + { ++ struct v4l2_fwnode_device_properties props; + struct device *dev = &client->dev; + struct fwnode_handle *endpoint; + struct ov7251 *ov7251; +@@ -1338,7 +1339,7 @@ static int ov7251_probe(struct i2c_clien + + mutex_init(&ov7251->lock); + +- v4l2_ctrl_handler_init(&ov7251->ctrls, 7); ++ v4l2_ctrl_handler_init(&ov7251->ctrls, 9); + ov7251->ctrls.lock = &ov7251->lock; + + v4l2_ctrl_new_std(&ov7251->ctrls, &ov7251_ctrl_ops, +@@ -1374,6 +1375,15 @@ static int ov7251_probe(struct i2c_clien + goto free_ctrl; + } + ++ ret = v4l2_fwnode_device_parse(&client->dev, &props); ++ if (ret) ++ goto free_ctrl; ++ ++ ret = v4l2_ctrl_new_fwnode_properties(&ov7251->ctrls, &ov7251_ctrl_ops, ++ &props); ++ if (ret) ++ goto free_ctrl; ++ + v4l2_i2c_subdev_init(&ov7251->sd, client, &ov7251_subdev_ops); + ov7251->sd.flags |= V4L2_SUBDEV_FL_HAS_DEVNODE; + ov7251->pad.flags = MEDIA_PAD_FL_SOURCE; |