Commit b0fe7778 authored by Kieran Bingham's avatar Kieran Bingham Committed by Mauro Carvalho Chehab

media: i2c: adv748x: Store the pixel rate ctrl on CSI objects

The current implementation has to search the list of controls for the
pixel rate control, each time it is set.  This can be optimised easily
by storing the ctrl pointer in the CSI/TX object, and referencing that
directly.

While at it, fix up a missing blank line also highlighted in review
comments.
Signed-off-by: default avatarKieran Bingham <kieran.bingham+renesas@ideasonboard.com>
Tested-by: default avatarNiklas Söderlund <niklas.soderlund+renesas@ragnatech.se>
Acked-by: default avatarSakari Ailus <sakari.ailus@linux.intel.com>
Signed-off-by: default avatarHans Verkuil <hans.verkuil@cisco.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@s-opensource.com>
parent 7df66d77
...@@ -267,6 +267,7 @@ static int adv748x_afe_g_input_status(struct v4l2_subdev *sd, u32 *status) ...@@ -267,6 +267,7 @@ static int adv748x_afe_g_input_status(struct v4l2_subdev *sd, u32 *status)
ret = adv748x_afe_status(afe, status, NULL); ret = adv748x_afe_status(afe, status, NULL);
mutex_unlock(&state->mutex); mutex_unlock(&state->mutex);
return ret; return ret;
} }
......
...@@ -223,13 +223,12 @@ static const struct v4l2_subdev_ops adv748x_csi2_ops = { ...@@ -223,13 +223,12 @@ static const struct v4l2_subdev_ops adv748x_csi2_ops = {
int adv748x_csi2_set_pixelrate(struct v4l2_subdev *sd, s64 rate) int adv748x_csi2_set_pixelrate(struct v4l2_subdev *sd, s64 rate)
{ {
struct v4l2_ctrl *ctrl; struct adv748x_csi2 *tx = adv748x_sd_to_csi2(sd);
ctrl = v4l2_ctrl_find(sd->ctrl_handler, V4L2_CID_PIXEL_RATE); if (!tx->pixel_rate)
if (!ctrl)
return -EINVAL; return -EINVAL;
return v4l2_ctrl_s_ctrl_int64(ctrl, rate); return v4l2_ctrl_s_ctrl_int64(tx->pixel_rate, rate);
} }
static int adv748x_csi2_s_ctrl(struct v4l2_ctrl *ctrl) static int adv748x_csi2_s_ctrl(struct v4l2_ctrl *ctrl)
...@@ -251,8 +250,10 @@ static int adv748x_csi2_init_controls(struct adv748x_csi2 *tx) ...@@ -251,8 +250,10 @@ static int adv748x_csi2_init_controls(struct adv748x_csi2 *tx)
v4l2_ctrl_handler_init(&tx->ctrl_hdl, 1); v4l2_ctrl_handler_init(&tx->ctrl_hdl, 1);
v4l2_ctrl_new_std(&tx->ctrl_hdl, &adv748x_csi2_ctrl_ops, tx->pixel_rate = v4l2_ctrl_new_std(&tx->ctrl_hdl,
V4L2_CID_PIXEL_RATE, 1, INT_MAX, 1, 1); &adv748x_csi2_ctrl_ops,
V4L2_CID_PIXEL_RATE, 1, INT_MAX,
1, 1);
tx->sd.ctrl_handler = &tx->ctrl_hdl; tx->sd.ctrl_handler = &tx->ctrl_hdl;
if (tx->ctrl_hdl.error) { if (tx->ctrl_hdl.error) {
......
...@@ -97,6 +97,7 @@ struct adv748x_csi2 { ...@@ -97,6 +97,7 @@ struct adv748x_csi2 {
struct media_pad pads[ADV748X_CSI2_NR_PADS]; struct media_pad pads[ADV748X_CSI2_NR_PADS];
struct v4l2_ctrl_handler ctrl_hdl; struct v4l2_ctrl_handler ctrl_hdl;
struct v4l2_ctrl *pixel_rate;
struct v4l2_subdev sd; struct v4l2_subdev sd;
}; };
......
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