diff mbox series

[RFC,v1,16/19] media: renesas: vsp1: Pass subdev state to entity operations

Message ID 20231122043009.2741-17-laurent.pinchart+renesas@ideasonboard.com (mailing list archive)
State New
Delegated to: Kieran Bingham
Headers show
Series media: renesas: vsp1: Conversion to subdev active state | expand

Commit Message

Laurent Pinchart Nov. 22, 2023, 4:30 a.m. UTC
From: Laurent Pinchart <laurent.pinchart@ideasonboard.com>

To prepare for the removal of the vsp1_entity.state field, pass the
state to all entity operations that needs to access it, instead of
accessing the state from the entity inside the operation handlers. This
lowers the number of accesses to the field.

Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
---
 .../media/platform/renesas/vsp1/vsp1_brx.c    |  4 ++--
 .../media/platform/renesas/vsp1/vsp1_clu.c    |  3 ++-
 .../media/platform/renesas/vsp1/vsp1_drm.c    |  3 ++-
 .../media/platform/renesas/vsp1/vsp1_entity.c |  3 ++-
 .../media/platform/renesas/vsp1/vsp1_entity.h |  4 ++++
 .../media/platform/renesas/vsp1/vsp1_hgo.c    |  5 +++--
 .../media/platform/renesas/vsp1/vsp1_hgt.c    |  5 +++--
 .../media/platform/renesas/vsp1/vsp1_hsit.c   |  1 +
 .../media/platform/renesas/vsp1/vsp1_lif.c    |  4 ++--
 .../media/platform/renesas/vsp1/vsp1_lut.c    |  1 +
 .../media/platform/renesas/vsp1/vsp1_pipe.c   |  4 ++--
 .../media/platform/renesas/vsp1/vsp1_rpf.c    | 10 ++++-----
 .../media/platform/renesas/vsp1/vsp1_sru.c    | 22 ++++++++-----------
 .../media/platform/renesas/vsp1/vsp1_uds.c    | 20 ++++++++---------
 .../media/platform/renesas/vsp1/vsp1_uif.c    |  3 ++-
 .../media/platform/renesas/vsp1/vsp1_video.c  |  6 +++--
 .../media/platform/renesas/vsp1/vsp1_wpf.c    |  9 ++++----
 17 files changed, 58 insertions(+), 49 deletions(-)

Comments

Jacopo Mondi June 18, 2024, 4:52 p.m. UTC | #1
Hi Laurent

On Wed, Nov 22, 2023 at 06:30:06AM GMT, Laurent Pinchart wrote:
> From: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
>
> To prepare for the removal of the vsp1_entity.state field, pass the
> state to all entity operations that needs to access it, instead of
> accessing the state from the entity inside the operation handlers. This
> lowers the number of accesses to the field.
>
> Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>

I recall you sent a series to s/sd_state/state in some i2c subdev ?
Not a big deal
Reviewed-by: Jacopo Mondi <jacopo.mondi@ideasonboard.com>

> ---
>  .../media/platform/renesas/vsp1/vsp1_brx.c    |  4 ++--
>  .../media/platform/renesas/vsp1/vsp1_clu.c    |  3 ++-
>  .../media/platform/renesas/vsp1/vsp1_drm.c    |  3 ++-
>  .../media/platform/renesas/vsp1/vsp1_entity.c |  3 ++-
>  .../media/platform/renesas/vsp1/vsp1_entity.h |  4 ++++
>  .../media/platform/renesas/vsp1/vsp1_hgo.c    |  5 +++--
>  .../media/platform/renesas/vsp1/vsp1_hgt.c    |  5 +++--
>  .../media/platform/renesas/vsp1/vsp1_hsit.c   |  1 +
>  .../media/platform/renesas/vsp1/vsp1_lif.c    |  4 ++--
>  .../media/platform/renesas/vsp1/vsp1_lut.c    |  1 +
>  .../media/platform/renesas/vsp1/vsp1_pipe.c   |  4 ++--
>  .../media/platform/renesas/vsp1/vsp1_rpf.c    | 10 ++++-----
>  .../media/platform/renesas/vsp1/vsp1_sru.c    | 22 ++++++++-----------
>  .../media/platform/renesas/vsp1/vsp1_uds.c    | 20 ++++++++---------
>  .../media/platform/renesas/vsp1/vsp1_uif.c    |  3 ++-
>  .../media/platform/renesas/vsp1/vsp1_video.c  |  6 +++--
>  .../media/platform/renesas/vsp1/vsp1_wpf.c    |  9 ++++----
>  17 files changed, 58 insertions(+), 49 deletions(-)
>
> diff --git a/drivers/media/platform/renesas/vsp1/vsp1_brx.c b/drivers/media/platform/renesas/vsp1/vsp1_brx.c
> index 05940d0427bf..7639ea53dd47 100644
> --- a/drivers/media/platform/renesas/vsp1/vsp1_brx.c
> +++ b/drivers/media/platform/renesas/vsp1/vsp1_brx.c
> @@ -272,6 +272,7 @@ static const struct v4l2_subdev_ops brx_ops = {
>   */
>
>  static void brx_configure_stream(struct vsp1_entity *entity,
> +				 struct v4l2_subdev_state *sd_state,
>  				 struct vsp1_pipeline *pipe,
>  				 struct vsp1_dl_list *dl,
>  				 struct vsp1_dl_body *dlb)
> @@ -281,8 +282,7 @@ static void brx_configure_stream(struct vsp1_entity *entity,
>  	unsigned int flags;
>  	unsigned int i;
>
> -	format = v4l2_subdev_state_get_format(brx->entity.state,
> -					      brx->entity.source_pad);
> +	format = v4l2_subdev_state_get_format(sd_state, brx->entity.source_pad);
>
>  	/*
>  	 * The hardware is extremely flexible but we have no userspace API to
> diff --git a/drivers/media/platform/renesas/vsp1/vsp1_clu.c b/drivers/media/platform/renesas/vsp1/vsp1_clu.c
> index 1e57676a420c..56c77809d2ec 100644
> --- a/drivers/media/platform/renesas/vsp1/vsp1_clu.c
> +++ b/drivers/media/platform/renesas/vsp1/vsp1_clu.c
> @@ -170,6 +170,7 @@ static const struct v4l2_subdev_ops clu_ops = {
>   */
>
>  static void clu_configure_stream(struct vsp1_entity *entity,
> +				 struct v4l2_subdev_state *sd_state,
>  				 struct vsp1_pipeline *pipe,
>  				 struct vsp1_dl_list *dl,
>  				 struct vsp1_dl_body *dlb)
> @@ -181,7 +182,7 @@ static void clu_configure_stream(struct vsp1_entity *entity,
>  	 * The yuv_mode can't be changed during streaming. Cache it internally
>  	 * for future runtime configuration calls.
>  	 */
> -	format = v4l2_subdev_state_get_format(clu->entity.state, CLU_PAD_SINK);
> +	format = v4l2_subdev_state_get_format(sd_state, CLU_PAD_SINK);
>  	clu->yuv_mode = format->code == MEDIA_BUS_FMT_AYUV8_1X32;
>  }
>
> diff --git a/drivers/media/platform/renesas/vsp1/vsp1_drm.c b/drivers/media/platform/renesas/vsp1/vsp1_drm.c
> index 11313e26a298..b5d1f238f7be 100644
> --- a/drivers/media/platform/renesas/vsp1/vsp1_drm.c
> +++ b/drivers/media/platform/renesas/vsp1/vsp1_drm.c
> @@ -574,7 +574,8 @@ static void vsp1_du_pipeline_configure(struct vsp1_pipeline *pipe)
>  		}
>
>  		vsp1_entity_route_setup(entity, pipe, dlb);
> -		vsp1_entity_configure_stream(entity, pipe, dl, dlb);
> +		vsp1_entity_configure_stream(entity, entity->state, pipe,
> +					     dl, dlb);
>  		vsp1_entity_configure_frame(entity, pipe, dl, dlb);
>  		vsp1_entity_configure_partition(entity, pipe,
>  						&pipe->part_table[0], dl, dlb);
> diff --git a/drivers/media/platform/renesas/vsp1/vsp1_entity.c b/drivers/media/platform/renesas/vsp1/vsp1_entity.c
> index e9de75de8bde..d3533a75361a 100644
> --- a/drivers/media/platform/renesas/vsp1/vsp1_entity.c
> +++ b/drivers/media/platform/renesas/vsp1/vsp1_entity.c
> @@ -70,12 +70,13 @@ void vsp1_entity_route_setup(struct vsp1_entity *entity,
>  }
>
>  void vsp1_entity_configure_stream(struct vsp1_entity *entity,
> +				  struct v4l2_subdev_state *sd_state,
>  				  struct vsp1_pipeline *pipe,
>  				  struct vsp1_dl_list *dl,
>  				  struct vsp1_dl_body *dlb)
>  {
>  	if (entity->ops->configure_stream)
> -		entity->ops->configure_stream(entity, pipe, dl, dlb);
> +		entity->ops->configure_stream(entity, sd_state, pipe, dl, dlb);
>  }
>
>  void vsp1_entity_configure_frame(struct vsp1_entity *entity,
> diff --git a/drivers/media/platform/renesas/vsp1/vsp1_entity.h b/drivers/media/platform/renesas/vsp1/vsp1_entity.h
> index 42000d6e2530..1d9d050e79da 100644
> --- a/drivers/media/platform/renesas/vsp1/vsp1_entity.h
> +++ b/drivers/media/platform/renesas/vsp1/vsp1_entity.h
> @@ -79,6 +79,7 @@ struct vsp1_route {
>  struct vsp1_entity_operations {
>  	void (*destroy)(struct vsp1_entity *entity);
>  	void (*configure_stream)(struct vsp1_entity *entity,
> +				 struct v4l2_subdev_state *state,
>  				 struct vsp1_pipeline *pipe,
>  				 struct vsp1_dl_list *dl,
>  				 struct vsp1_dl_body *dlb);
> @@ -92,8 +93,10 @@ struct vsp1_entity_operations {
>  				    struct vsp1_dl_list *dl,
>  				    struct vsp1_dl_body *dlb);
>  	unsigned int (*max_width)(struct vsp1_entity *entity,
> +				  struct v4l2_subdev_state *state,
>  				  struct vsp1_pipeline *pipe);
>  	void (*partition)(struct vsp1_entity *entity,
> +			  struct v4l2_subdev_state *state,
>  			  struct vsp1_pipeline *pipe,
>  			  struct vsp1_partition *partition,
>  			  unsigned int index,
> @@ -151,6 +154,7 @@ void vsp1_entity_route_setup(struct vsp1_entity *entity,
>  			     struct vsp1_dl_body *dlb);
>
>  void vsp1_entity_configure_stream(struct vsp1_entity *entity,
> +				  struct v4l2_subdev_state *sd_state,
>  				  struct vsp1_pipeline *pipe,
>  				  struct vsp1_dl_list *dl,
>  				  struct vsp1_dl_body *dlb);
> diff --git a/drivers/media/platform/renesas/vsp1/vsp1_hgo.c b/drivers/media/platform/renesas/vsp1/vsp1_hgo.c
> index 4ee5f0e5e9c3..237dc4c7c5ed 100644
> --- a/drivers/media/platform/renesas/vsp1/vsp1_hgo.c
> +++ b/drivers/media/platform/renesas/vsp1/vsp1_hgo.c
> @@ -130,6 +130,7 @@ static const struct v4l2_ctrl_config hgo_num_bins_control = {
>   */
>
>  static void hgo_configure_stream(struct vsp1_entity *entity,
> +				 struct v4l2_subdev_state *sd_state,
>  				 struct vsp1_pipeline *pipe,
>  				 struct vsp1_dl_list *dl,
>  				 struct vsp1_dl_body *dlb)
> @@ -140,8 +141,8 @@ static void hgo_configure_stream(struct vsp1_entity *entity,
>  	unsigned int hratio;
>  	unsigned int vratio;
>
> -	crop = v4l2_subdev_state_get_crop(entity->state, HISTO_PAD_SINK);
> -	compose = v4l2_subdev_state_get_compose(entity->state, HISTO_PAD_SINK);
> +	crop = v4l2_subdev_state_get_crop(sd_state, HISTO_PAD_SINK);
> +	compose = v4l2_subdev_state_get_compose(sd_state, HISTO_PAD_SINK);
>
>  	vsp1_hgo_write(hgo, dlb, VI6_HGO_REGRST, VI6_HGO_REGRST_RCLEA);
>
> diff --git a/drivers/media/platform/renesas/vsp1/vsp1_hgt.c b/drivers/media/platform/renesas/vsp1/vsp1_hgt.c
> index b739d8045576..b73eac676ef0 100644
> --- a/drivers/media/platform/renesas/vsp1/vsp1_hgt.c
> +++ b/drivers/media/platform/renesas/vsp1/vsp1_hgt.c
> @@ -126,6 +126,7 @@ static const struct v4l2_ctrl_config hgt_hue_areas = {
>   */
>
>  static void hgt_configure_stream(struct vsp1_entity *entity,
> +				 struct v4l2_subdev_state *sd_state,
>  				 struct vsp1_pipeline *pipe,
>  				 struct vsp1_dl_list *dl,
>  				 struct vsp1_dl_body *dlb)
> @@ -139,8 +140,8 @@ static void hgt_configure_stream(struct vsp1_entity *entity,
>  	u8 upper;
>  	unsigned int i;
>
> -	crop = v4l2_subdev_state_get_crop(entity->state, HISTO_PAD_SINK);
> -	compose = v4l2_subdev_state_get_compose(entity->state, HISTO_PAD_SINK);
> +	crop = v4l2_subdev_state_get_crop(sd_state, HISTO_PAD_SINK);
> +	compose = v4l2_subdev_state_get_compose(sd_state, HISTO_PAD_SINK);
>
>  	vsp1_hgt_write(hgt, dlb, VI6_HGT_REGRST, VI6_HGT_REGRST_RCLEA);
>
> diff --git a/drivers/media/platform/renesas/vsp1/vsp1_hsit.c b/drivers/media/platform/renesas/vsp1/vsp1_hsit.c
> index 4a8cce808c93..932ac1c795bc 100644
> --- a/drivers/media/platform/renesas/vsp1/vsp1_hsit.c
> +++ b/drivers/media/platform/renesas/vsp1/vsp1_hsit.c
> @@ -127,6 +127,7 @@ static const struct v4l2_subdev_ops hsit_ops = {
>   */
>
>  static void hsit_configure_stream(struct vsp1_entity *entity,
> +				  struct v4l2_subdev_state *sd_state,
>  				  struct vsp1_pipeline *pipe,
>  				  struct vsp1_dl_list *dl,
>  				  struct vsp1_dl_body *dlb)
> diff --git a/drivers/media/platform/renesas/vsp1/vsp1_lif.c b/drivers/media/platform/renesas/vsp1/vsp1_lif.c
> index 29d4c1521e6a..308917338022 100644
> --- a/drivers/media/platform/renesas/vsp1/vsp1_lif.c
> +++ b/drivers/media/platform/renesas/vsp1/vsp1_lif.c
> @@ -83,6 +83,7 @@ static const struct v4l2_subdev_ops lif_ops = {
>   */
>
>  static void lif_configure_stream(struct vsp1_entity *entity,
> +				 struct v4l2_subdev_state *sd_state,
>  				 struct vsp1_pipeline *pipe,
>  				 struct vsp1_dl_list *dl,
>  				 struct vsp1_dl_body *dlb)
> @@ -93,8 +94,7 @@ static void lif_configure_stream(struct vsp1_entity *entity,
>  	unsigned int obth;
>  	unsigned int lbth;
>
> -	format = v4l2_subdev_state_get_format(lif->entity.state,
> -					      LIF_PAD_SOURCE);
> +	format = v4l2_subdev_state_get_format(sd_state, LIF_PAD_SOURCE);
>
>  	switch (entity->vsp1->version & VI6_IP_VERSION_MODEL_MASK) {
>  	case VI6_IP_VERSION_MODEL_VSPD_GEN2:
> diff --git a/drivers/media/platform/renesas/vsp1/vsp1_lut.c b/drivers/media/platform/renesas/vsp1/vsp1_lut.c
> index 451d24ab0b56..0382ddaa6911 100644
> --- a/drivers/media/platform/renesas/vsp1/vsp1_lut.c
> +++ b/drivers/media/platform/renesas/vsp1/vsp1_lut.c
> @@ -146,6 +146,7 @@ static const struct v4l2_subdev_ops lut_ops = {
>   */
>
>  static void lut_configure_stream(struct vsp1_entity *entity,
> +				 struct v4l2_subdev_state *sd_state,
>  				 struct vsp1_pipeline *pipe,
>  				 struct vsp1_dl_list *dl,
>  				 struct vsp1_dl_body *dlb)
> diff --git a/drivers/media/platform/renesas/vsp1/vsp1_pipe.c b/drivers/media/platform/renesas/vsp1/vsp1_pipe.c
> index edc5e9f3ba65..37f89fa5a6e2 100644
> --- a/drivers/media/platform/renesas/vsp1/vsp1_pipe.c
> +++ b/drivers/media/platform/renesas/vsp1/vsp1_pipe.c
> @@ -487,8 +487,8 @@ static void vsp1_pipeline_propagate_partition(struct vsp1_pipeline *pipe,
>
>  	list_for_each_entry_reverse(entity, &pipe->entities, list_pipe) {
>  		if (entity->ops->partition)
> -			entity->ops->partition(entity, pipe, partition, index,
> -					       window);
> +			entity->ops->partition(entity, entity->state, pipe,
> +					       partition, index, window);
>  	}
>  }
>
> diff --git a/drivers/media/platform/renesas/vsp1/vsp1_rpf.c b/drivers/media/platform/renesas/vsp1/vsp1_rpf.c
> index b4558670b46f..309f02b49088 100644
> --- a/drivers/media/platform/renesas/vsp1/vsp1_rpf.c
> +++ b/drivers/media/platform/renesas/vsp1/vsp1_rpf.c
> @@ -48,6 +48,7 @@ static inline void vsp1_rpf_write(struct vsp1_rwpf *rpf,
>   */
>
>  static void rpf_configure_stream(struct vsp1_entity *entity,
> +				 struct v4l2_subdev_state *sd_state,
>  				 struct vsp1_pipeline *pipe,
>  				 struct vsp1_dl_list *dl,
>  				 struct vsp1_dl_body *dlb)
> @@ -80,10 +81,8 @@ static void rpf_configure_stream(struct vsp1_entity *entity,
>  	vsp1_rpf_write(rpf, dlb, VI6_RPF_SRCM_PSTRIDE, pstride);
>
>  	/* Format */
> -	sink_format = v4l2_subdev_state_get_format(rpf->entity.state,
> -						   RWPF_PAD_SINK);
> -	source_format = v4l2_subdev_state_get_format(rpf->entity.state,
> -						     RWPF_PAD_SOURCE);
> +	sink_format = v4l2_subdev_state_get_format(sd_state, RWPF_PAD_SINK);
> +	source_format = v4l2_subdev_state_get_format(sd_state, RWPF_PAD_SOURCE);
>
>  	infmt = VI6_RPF_INFMT_CIPM
>  	      | (fmtinfo->hwfmt << VI6_RPF_INFMT_RDFMT_SHIFT);
> @@ -347,6 +346,7 @@ static void rpf_configure_partition(struct vsp1_entity *entity,
>  }
>
>  static void rpf_partition(struct vsp1_entity *entity,
> +			  struct v4l2_subdev_state *sd_state,
>  			  struct vsp1_pipeline *pipe,
>  			  struct vsp1_partition *partition,
>  			  unsigned int partition_idx,
> @@ -364,7 +364,7 @@ static void rpf_partition(struct vsp1_entity *entity,
>  	 * our crop to provide a 'sub-crop' matching the expected partition
>  	 * window.
>  	 */
> -	*rpf_rect = *v4l2_subdev_state_get_crop(entity->state, RWPF_PAD_SINK);
> +	*rpf_rect = *v4l2_subdev_state_get_crop(sd_state, RWPF_PAD_SINK);
>
>  	if (pipe->partitions > 1) {
>  		rpf_rect->width = window->width;
> diff --git a/drivers/media/platform/renesas/vsp1/vsp1_sru.c b/drivers/media/platform/renesas/vsp1/vsp1_sru.c
> index f35187daa643..4f32024b9ed4 100644
> --- a/drivers/media/platform/renesas/vsp1/vsp1_sru.c
> +++ b/drivers/media/platform/renesas/vsp1/vsp1_sru.c
> @@ -265,6 +265,7 @@ static const struct v4l2_subdev_ops sru_ops = {
>   */
>
>  static void sru_configure_stream(struct vsp1_entity *entity,
> +				 struct v4l2_subdev_state *sd_state,
>  				 struct vsp1_pipeline *pipe,
>  				 struct vsp1_dl_list *dl,
>  				 struct vsp1_dl_body *dlb)
> @@ -275,9 +276,8 @@ static void sru_configure_stream(struct vsp1_entity *entity,
>  	struct v4l2_mbus_framefmt *output;
>  	u32 ctrl0;
>
> -	input = v4l2_subdev_state_get_format(sru->entity.state, SRU_PAD_SINK);
> -	output = v4l2_subdev_state_get_format(sru->entity.state,
> -					      SRU_PAD_SOURCE);
> +	input = v4l2_subdev_state_get_format(sd_state, SRU_PAD_SINK);
> +	output = v4l2_subdev_state_get_format(sd_state, SRU_PAD_SOURCE);
>
>  	if (input->code == MEDIA_BUS_FMT_ARGB8888_1X32)
>  		ctrl0 = VI6_SRU_CTRL0_PARAM2 | VI6_SRU_CTRL0_PARAM3
> @@ -298,16 +298,14 @@ static void sru_configure_stream(struct vsp1_entity *entity,
>  }
>
>  static unsigned int sru_max_width(struct vsp1_entity *entity,
> +				  struct v4l2_subdev_state *sd_state,
>  				  struct vsp1_pipeline *pipe)
>  {
> -	struct vsp1_sru *sru = to_sru(&entity->subdev);
>  	struct v4l2_mbus_framefmt *input;
>  	struct v4l2_mbus_framefmt *output;
>
> -	input = v4l2_subdev_state_get_format(sru->entity.state,
> -					     SRU_PAD_SINK);
> -	output = v4l2_subdev_state_get_format(sru->entity.state,
> -					      SRU_PAD_SOURCE);
> +	input = v4l2_subdev_state_get_format(sd_state, SRU_PAD_SINK);
> +	output = v4l2_subdev_state_get_format(sd_state, SRU_PAD_SOURCE);
>
>  	/*
>  	 * The maximum input width of the SRU is 288 input pixels, but 32
> @@ -321,19 +319,17 @@ static unsigned int sru_max_width(struct vsp1_entity *entity,
>  }
>
>  static void sru_partition(struct vsp1_entity *entity,
> +			  struct v4l2_subdev_state *sd_state,
>  			  struct vsp1_pipeline *pipe,
>  			  struct vsp1_partition *partition,
>  			  unsigned int partition_idx,
>  			  struct v4l2_rect *window)
>  {
> -	struct vsp1_sru *sru = to_sru(&entity->subdev);
>  	struct v4l2_mbus_framefmt *input;
>  	struct v4l2_mbus_framefmt *output;
>
> -	input = v4l2_subdev_state_get_format(sru->entity.state,
> -					     SRU_PAD_SINK);
> -	output = v4l2_subdev_state_get_format(sru->entity.state,
> -					      SRU_PAD_SOURCE);
> +	input = v4l2_subdev_state_get_format(sd_state, SRU_PAD_SINK);
> +	output = v4l2_subdev_state_get_format(sd_state, SRU_PAD_SOURCE);
>
>  	/* Adapt if SRUx2 is enabled. */
>  	if (input->width != output->width) {
> diff --git a/drivers/media/platform/renesas/vsp1/vsp1_uds.c b/drivers/media/platform/renesas/vsp1/vsp1_uds.c
> index e5953d86c17c..d39a89a0f27d 100644
> --- a/drivers/media/platform/renesas/vsp1/vsp1_uds.c
> +++ b/drivers/media/platform/renesas/vsp1/vsp1_uds.c
> @@ -252,6 +252,7 @@ static const struct v4l2_subdev_ops uds_ops = {
>   */
>
>  static void uds_configure_stream(struct vsp1_entity *entity,
> +				 struct v4l2_subdev_state *sd_state,
>  				 struct vsp1_pipeline *pipe,
>  				 struct vsp1_dl_list *dl,
>  				 struct vsp1_dl_body *dlb)
> @@ -263,9 +264,8 @@ static void uds_configure_stream(struct vsp1_entity *entity,
>  	unsigned int vscale;
>  	bool multitap;
>
> -	input = v4l2_subdev_state_get_format(uds->entity.state, UDS_PAD_SINK);
> -	output = v4l2_subdev_state_get_format(uds->entity.state,
> -					      UDS_PAD_SOURCE);
> +	input = v4l2_subdev_state_get_format(sd_state, UDS_PAD_SINK);
> +	output = v4l2_subdev_state_get_format(sd_state, UDS_PAD_SOURCE);
>
>  	hscale = uds_compute_ratio(input->width, output->width);
>  	vscale = uds_compute_ratio(input->height, output->height);
> @@ -321,16 +321,15 @@ static void uds_configure_partition(struct vsp1_entity *entity,
>  }
>
>  static unsigned int uds_max_width(struct vsp1_entity *entity,
> +				  struct v4l2_subdev_state *sd_state,
>  				  struct vsp1_pipeline *pipe)
>  {
> -	struct vsp1_uds *uds = to_uds(&entity->subdev);
>  	const struct v4l2_mbus_framefmt *output;
>  	const struct v4l2_mbus_framefmt *input;
>  	unsigned int hscale;
>
> -	input = v4l2_subdev_state_get_format(uds->entity.state, UDS_PAD_SINK);
> -	output = v4l2_subdev_state_get_format(uds->entity.state,
> -					      UDS_PAD_SOURCE);
> +	input = v4l2_subdev_state_get_format(sd_state, UDS_PAD_SINK);
> +	output = v4l2_subdev_state_get_format(sd_state, UDS_PAD_SOURCE);
>  	hscale = output->width / input->width;
>
>  	/*
> @@ -356,18 +355,17 @@ static unsigned int uds_max_width(struct vsp1_entity *entity,
>   */
>
>  static void uds_partition(struct vsp1_entity *entity,
> +			  struct v4l2_subdev_state *sd_state,
>  			  struct vsp1_pipeline *pipe,
>  			  struct vsp1_partition *partition,
>  			  unsigned int partition_idx,
>  			  struct v4l2_rect *window)
>  {
> -	struct vsp1_uds *uds = to_uds(&entity->subdev);
>  	const struct v4l2_mbus_framefmt *output;
>  	const struct v4l2_mbus_framefmt *input;
>
> -	input = v4l2_subdev_state_get_format(uds->entity.state, UDS_PAD_SINK);
> -	output = v4l2_subdev_state_get_format(uds->entity.state,
> -					      UDS_PAD_SOURCE);
> +	input = v4l2_subdev_state_get_format(sd_state, UDS_PAD_SINK);
> +	output = v4l2_subdev_state_get_format(sd_state, UDS_PAD_SOURCE);
>
>  	partition->uds_sink.width = window->width * input->width
>  				  / output->width;
> diff --git a/drivers/media/platform/renesas/vsp1/vsp1_uif.c b/drivers/media/platform/renesas/vsp1/vsp1_uif.c
> index cecd2f7024f4..e69acb5f0fbb 100644
> --- a/drivers/media/platform/renesas/vsp1/vsp1_uif.c
> +++ b/drivers/media/platform/renesas/vsp1/vsp1_uif.c
> @@ -188,6 +188,7 @@ static const struct v4l2_subdev_ops uif_ops = {
>   */
>
>  static void uif_configure_stream(struct vsp1_entity *entity,
> +				 struct v4l2_subdev_state *sd_state,
>  				 struct vsp1_pipeline *pipe,
>  				 struct vsp1_dl_list *dl,
>  				 struct vsp1_dl_body *dlb)
> @@ -200,7 +201,7 @@ static void uif_configure_stream(struct vsp1_entity *entity,
>  	vsp1_uif_write(uif, dlb, VI6_UIF_DISCOM_DOCMPMR,
>  		       VI6_UIF_DISCOM_DOCMPMR_SEL(9));
>
> -	crop = v4l2_subdev_state_get_crop(entity->state, UIF_PAD_SINK);
> +	crop = v4l2_subdev_state_get_crop(sd_state, UIF_PAD_SINK);
>
>  	left = crop->left;
>  	width = crop->width;
> diff --git a/drivers/media/platform/renesas/vsp1/vsp1_video.c b/drivers/media/platform/renesas/vsp1/vsp1_video.c
> index 84394994ccee..6645cf1d533b 100644
> --- a/drivers/media/platform/renesas/vsp1/vsp1_video.c
> +++ b/drivers/media/platform/renesas/vsp1/vsp1_video.c
> @@ -693,7 +693,9 @@ static int vsp1_video_pipeline_setup_partitions(struct vsp1_pipeline *pipe)
>  			if (!entity->ops->max_width)
>  				continue;
>
> -			entity_max = entity->ops->max_width(entity, pipe);
> +			entity_max = entity->ops->max_width(entity,
> +							    entity->state,
> +							    pipe);
>  			if (entity_max)
>  				div_size = min(div_size, entity_max);
>  		}
> @@ -754,7 +756,7 @@ static int vsp1_video_setup_pipeline(struct vsp1_pipeline *pipe)
>
>  	list_for_each_entry(entity, &pipe->entities, list_pipe) {
>  		vsp1_entity_route_setup(entity, pipe, pipe->stream_config);
> -		vsp1_entity_configure_stream(entity, pipe, NULL,
> +		vsp1_entity_configure_stream(entity, entity->state, pipe, NULL,
>  					     pipe->stream_config);
>  	}
>
> diff --git a/drivers/media/platform/renesas/vsp1/vsp1_wpf.c b/drivers/media/platform/renesas/vsp1/vsp1_wpf.c
> index 5c363ff1d36c..e3d961c8d3e3 100644
> --- a/drivers/media/platform/renesas/vsp1/vsp1_wpf.c
> +++ b/drivers/media/platform/renesas/vsp1/vsp1_wpf.c
> @@ -229,6 +229,7 @@ static int wpf_configure_writeback_chain(struct vsp1_rwpf *wpf,
>  }
>
>  static void wpf_configure_stream(struct vsp1_entity *entity,
> +				 struct v4l2_subdev_state *sd_state,
>  				 struct vsp1_pipeline *pipe,
>  				 struct vsp1_dl_list *dl,
>  				 struct vsp1_dl_body *dlb)
> @@ -243,10 +244,8 @@ static void wpf_configure_stream(struct vsp1_entity *entity,
>  	u32 srcrpf = 0;
>  	int ret;
>
> -	sink_format = v4l2_subdev_state_get_format(wpf->entity.state,
> -						   RWPF_PAD_SINK);
> -	source_format = v4l2_subdev_state_get_format(wpf->entity.state,
> -						     RWPF_PAD_SOURCE);
> +	sink_format = v4l2_subdev_state_get_format(sd_state, RWPF_PAD_SINK);
> +	source_format = v4l2_subdev_state_get_format(sd_state, RWPF_PAD_SOURCE);
>
>  	/* Format */
>  	if (!pipe->lif || wpf->writeback) {
> @@ -496,6 +495,7 @@ static void wpf_configure_partition(struct vsp1_entity *entity,
>  }
>
>  static unsigned int wpf_max_width(struct vsp1_entity *entity,
> +				  struct v4l2_subdev_state *sd_state,
>  				  struct vsp1_pipeline *pipe)
>  {
>  	struct vsp1_rwpf *wpf = to_rwpf(&entity->subdev);
> @@ -504,6 +504,7 @@ static unsigned int wpf_max_width(struct vsp1_entity *entity,
>  }
>
>  static void wpf_partition(struct vsp1_entity *entity,
> +			  struct v4l2_subdev_state *sd_state,
>  			  struct vsp1_pipeline *pipe,
>  			  struct vsp1_partition *partition,
>  			  unsigned int partition_idx,
> --
> Regards,
>
> Laurent Pinchart
>
>
Laurent Pinchart June 18, 2024, 5:17 p.m. UTC | #2
Hi Jacopo,

On Tue, Jun 18, 2024 at 06:52:26PM +0200, Jacopo Mondi wrote:
> On Wed, Nov 22, 2023 at 06:30:06AM GMT, Laurent Pinchart wrote:
> > From: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
> >
> > To prepare for the removal of the vsp1_entity.state field, pass the
> > state to all entity operations that needs to access it, instead of
> > accessing the state from the entity inside the operation handlers. This
> > lowers the number of accesses to the field.
> >
> > Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
> 
> I recall you sent a series to s/sd_state/state in some i2c subdev ?

Patch 19/19 in this series renames everything to 'state'. I'll rename
state variables in this patch already and address the leftovers in
19/19, making it smaller.

> Not a big deal
> Reviewed-by: Jacopo Mondi <jacopo.mondi@ideasonboard.com>
> 
> > ---
> >  .../media/platform/renesas/vsp1/vsp1_brx.c    |  4 ++--
> >  .../media/platform/renesas/vsp1/vsp1_clu.c    |  3 ++-
> >  .../media/platform/renesas/vsp1/vsp1_drm.c    |  3 ++-
> >  .../media/platform/renesas/vsp1/vsp1_entity.c |  3 ++-
> >  .../media/platform/renesas/vsp1/vsp1_entity.h |  4 ++++
> >  .../media/platform/renesas/vsp1/vsp1_hgo.c    |  5 +++--
> >  .../media/platform/renesas/vsp1/vsp1_hgt.c    |  5 +++--
> >  .../media/platform/renesas/vsp1/vsp1_hsit.c   |  1 +
> >  .../media/platform/renesas/vsp1/vsp1_lif.c    |  4 ++--
> >  .../media/platform/renesas/vsp1/vsp1_lut.c    |  1 +
> >  .../media/platform/renesas/vsp1/vsp1_pipe.c   |  4 ++--
> >  .../media/platform/renesas/vsp1/vsp1_rpf.c    | 10 ++++-----
> >  .../media/platform/renesas/vsp1/vsp1_sru.c    | 22 ++++++++-----------
> >  .../media/platform/renesas/vsp1/vsp1_uds.c    | 20 ++++++++---------
> >  .../media/platform/renesas/vsp1/vsp1_uif.c    |  3 ++-
> >  .../media/platform/renesas/vsp1/vsp1_video.c  |  6 +++--
> >  .../media/platform/renesas/vsp1/vsp1_wpf.c    |  9 ++++----
> >  17 files changed, 58 insertions(+), 49 deletions(-)
> >
> > diff --git a/drivers/media/platform/renesas/vsp1/vsp1_brx.c b/drivers/media/platform/renesas/vsp1/vsp1_brx.c
> > index 05940d0427bf..7639ea53dd47 100644
> > --- a/drivers/media/platform/renesas/vsp1/vsp1_brx.c
> > +++ b/drivers/media/platform/renesas/vsp1/vsp1_brx.c
> > @@ -272,6 +272,7 @@ static const struct v4l2_subdev_ops brx_ops = {
> >   */
> >
> >  static void brx_configure_stream(struct vsp1_entity *entity,
> > +				 struct v4l2_subdev_state *sd_state,
> >  				 struct vsp1_pipeline *pipe,
> >  				 struct vsp1_dl_list *dl,
> >  				 struct vsp1_dl_body *dlb)
> > @@ -281,8 +282,7 @@ static void brx_configure_stream(struct vsp1_entity *entity,
> >  	unsigned int flags;
> >  	unsigned int i;
> >
> > -	format = v4l2_subdev_state_get_format(brx->entity.state,
> > -					      brx->entity.source_pad);
> > +	format = v4l2_subdev_state_get_format(sd_state, brx->entity.source_pad);
> >
> >  	/*
> >  	 * The hardware is extremely flexible but we have no userspace API to
> > diff --git a/drivers/media/platform/renesas/vsp1/vsp1_clu.c b/drivers/media/platform/renesas/vsp1/vsp1_clu.c
> > index 1e57676a420c..56c77809d2ec 100644
> > --- a/drivers/media/platform/renesas/vsp1/vsp1_clu.c
> > +++ b/drivers/media/platform/renesas/vsp1/vsp1_clu.c
> > @@ -170,6 +170,7 @@ static const struct v4l2_subdev_ops clu_ops = {
> >   */
> >
> >  static void clu_configure_stream(struct vsp1_entity *entity,
> > +				 struct v4l2_subdev_state *sd_state,
> >  				 struct vsp1_pipeline *pipe,
> >  				 struct vsp1_dl_list *dl,
> >  				 struct vsp1_dl_body *dlb)
> > @@ -181,7 +182,7 @@ static void clu_configure_stream(struct vsp1_entity *entity,
> >  	 * The yuv_mode can't be changed during streaming. Cache it internally
> >  	 * for future runtime configuration calls.
> >  	 */
> > -	format = v4l2_subdev_state_get_format(clu->entity.state, CLU_PAD_SINK);
> > +	format = v4l2_subdev_state_get_format(sd_state, CLU_PAD_SINK);
> >  	clu->yuv_mode = format->code == MEDIA_BUS_FMT_AYUV8_1X32;
> >  }
> >
> > diff --git a/drivers/media/platform/renesas/vsp1/vsp1_drm.c b/drivers/media/platform/renesas/vsp1/vsp1_drm.c
> > index 11313e26a298..b5d1f238f7be 100644
> > --- a/drivers/media/platform/renesas/vsp1/vsp1_drm.c
> > +++ b/drivers/media/platform/renesas/vsp1/vsp1_drm.c
> > @@ -574,7 +574,8 @@ static void vsp1_du_pipeline_configure(struct vsp1_pipeline *pipe)
> >  		}
> >
> >  		vsp1_entity_route_setup(entity, pipe, dlb);
> > -		vsp1_entity_configure_stream(entity, pipe, dl, dlb);
> > +		vsp1_entity_configure_stream(entity, entity->state, pipe,
> > +					     dl, dlb);
> >  		vsp1_entity_configure_frame(entity, pipe, dl, dlb);
> >  		vsp1_entity_configure_partition(entity, pipe,
> >  						&pipe->part_table[0], dl, dlb);
> > diff --git a/drivers/media/platform/renesas/vsp1/vsp1_entity.c b/drivers/media/platform/renesas/vsp1/vsp1_entity.c
> > index e9de75de8bde..d3533a75361a 100644
> > --- a/drivers/media/platform/renesas/vsp1/vsp1_entity.c
> > +++ b/drivers/media/platform/renesas/vsp1/vsp1_entity.c
> > @@ -70,12 +70,13 @@ void vsp1_entity_route_setup(struct vsp1_entity *entity,
> >  }
> >
> >  void vsp1_entity_configure_stream(struct vsp1_entity *entity,
> > +				  struct v4l2_subdev_state *sd_state,
> >  				  struct vsp1_pipeline *pipe,
> >  				  struct vsp1_dl_list *dl,
> >  				  struct vsp1_dl_body *dlb)
> >  {
> >  	if (entity->ops->configure_stream)
> > -		entity->ops->configure_stream(entity, pipe, dl, dlb);
> > +		entity->ops->configure_stream(entity, sd_state, pipe, dl, dlb);
> >  }
> >
> >  void vsp1_entity_configure_frame(struct vsp1_entity *entity,
> > diff --git a/drivers/media/platform/renesas/vsp1/vsp1_entity.h b/drivers/media/platform/renesas/vsp1/vsp1_entity.h
> > index 42000d6e2530..1d9d050e79da 100644
> > --- a/drivers/media/platform/renesas/vsp1/vsp1_entity.h
> > +++ b/drivers/media/platform/renesas/vsp1/vsp1_entity.h
> > @@ -79,6 +79,7 @@ struct vsp1_route {
> >  struct vsp1_entity_operations {
> >  	void (*destroy)(struct vsp1_entity *entity);
> >  	void (*configure_stream)(struct vsp1_entity *entity,
> > +				 struct v4l2_subdev_state *state,
> >  				 struct vsp1_pipeline *pipe,
> >  				 struct vsp1_dl_list *dl,
> >  				 struct vsp1_dl_body *dlb);
> > @@ -92,8 +93,10 @@ struct vsp1_entity_operations {
> >  				    struct vsp1_dl_list *dl,
> >  				    struct vsp1_dl_body *dlb);
> >  	unsigned int (*max_width)(struct vsp1_entity *entity,
> > +				  struct v4l2_subdev_state *state,
> >  				  struct vsp1_pipeline *pipe);
> >  	void (*partition)(struct vsp1_entity *entity,
> > +			  struct v4l2_subdev_state *state,
> >  			  struct vsp1_pipeline *pipe,
> >  			  struct vsp1_partition *partition,
> >  			  unsigned int index,
> > @@ -151,6 +154,7 @@ void vsp1_entity_route_setup(struct vsp1_entity *entity,
> >  			     struct vsp1_dl_body *dlb);
> >
> >  void vsp1_entity_configure_stream(struct vsp1_entity *entity,
> > +				  struct v4l2_subdev_state *sd_state,
> >  				  struct vsp1_pipeline *pipe,
> >  				  struct vsp1_dl_list *dl,
> >  				  struct vsp1_dl_body *dlb);
> > diff --git a/drivers/media/platform/renesas/vsp1/vsp1_hgo.c b/drivers/media/platform/renesas/vsp1/vsp1_hgo.c
> > index 4ee5f0e5e9c3..237dc4c7c5ed 100644
> > --- a/drivers/media/platform/renesas/vsp1/vsp1_hgo.c
> > +++ b/drivers/media/platform/renesas/vsp1/vsp1_hgo.c
> > @@ -130,6 +130,7 @@ static const struct v4l2_ctrl_config hgo_num_bins_control = {
> >   */
> >
> >  static void hgo_configure_stream(struct vsp1_entity *entity,
> > +				 struct v4l2_subdev_state *sd_state,
> >  				 struct vsp1_pipeline *pipe,
> >  				 struct vsp1_dl_list *dl,
> >  				 struct vsp1_dl_body *dlb)
> > @@ -140,8 +141,8 @@ static void hgo_configure_stream(struct vsp1_entity *entity,
> >  	unsigned int hratio;
> >  	unsigned int vratio;
> >
> > -	crop = v4l2_subdev_state_get_crop(entity->state, HISTO_PAD_SINK);
> > -	compose = v4l2_subdev_state_get_compose(entity->state, HISTO_PAD_SINK);
> > +	crop = v4l2_subdev_state_get_crop(sd_state, HISTO_PAD_SINK);
> > +	compose = v4l2_subdev_state_get_compose(sd_state, HISTO_PAD_SINK);
> >
> >  	vsp1_hgo_write(hgo, dlb, VI6_HGO_REGRST, VI6_HGO_REGRST_RCLEA);
> >
> > diff --git a/drivers/media/platform/renesas/vsp1/vsp1_hgt.c b/drivers/media/platform/renesas/vsp1/vsp1_hgt.c
> > index b739d8045576..b73eac676ef0 100644
> > --- a/drivers/media/platform/renesas/vsp1/vsp1_hgt.c
> > +++ b/drivers/media/platform/renesas/vsp1/vsp1_hgt.c
> > @@ -126,6 +126,7 @@ static const struct v4l2_ctrl_config hgt_hue_areas = {
> >   */
> >
> >  static void hgt_configure_stream(struct vsp1_entity *entity,
> > +				 struct v4l2_subdev_state *sd_state,
> >  				 struct vsp1_pipeline *pipe,
> >  				 struct vsp1_dl_list *dl,
> >  				 struct vsp1_dl_body *dlb)
> > @@ -139,8 +140,8 @@ static void hgt_configure_stream(struct vsp1_entity *entity,
> >  	u8 upper;
> >  	unsigned int i;
> >
> > -	crop = v4l2_subdev_state_get_crop(entity->state, HISTO_PAD_SINK);
> > -	compose = v4l2_subdev_state_get_compose(entity->state, HISTO_PAD_SINK);
> > +	crop = v4l2_subdev_state_get_crop(sd_state, HISTO_PAD_SINK);
> > +	compose = v4l2_subdev_state_get_compose(sd_state, HISTO_PAD_SINK);
> >
> >  	vsp1_hgt_write(hgt, dlb, VI6_HGT_REGRST, VI6_HGT_REGRST_RCLEA);
> >
> > diff --git a/drivers/media/platform/renesas/vsp1/vsp1_hsit.c b/drivers/media/platform/renesas/vsp1/vsp1_hsit.c
> > index 4a8cce808c93..932ac1c795bc 100644
> > --- a/drivers/media/platform/renesas/vsp1/vsp1_hsit.c
> > +++ b/drivers/media/platform/renesas/vsp1/vsp1_hsit.c
> > @@ -127,6 +127,7 @@ static const struct v4l2_subdev_ops hsit_ops = {
> >   */
> >
> >  static void hsit_configure_stream(struct vsp1_entity *entity,
> > +				  struct v4l2_subdev_state *sd_state,
> >  				  struct vsp1_pipeline *pipe,
> >  				  struct vsp1_dl_list *dl,
> >  				  struct vsp1_dl_body *dlb)
> > diff --git a/drivers/media/platform/renesas/vsp1/vsp1_lif.c b/drivers/media/platform/renesas/vsp1/vsp1_lif.c
> > index 29d4c1521e6a..308917338022 100644
> > --- a/drivers/media/platform/renesas/vsp1/vsp1_lif.c
> > +++ b/drivers/media/platform/renesas/vsp1/vsp1_lif.c
> > @@ -83,6 +83,7 @@ static const struct v4l2_subdev_ops lif_ops = {
> >   */
> >
> >  static void lif_configure_stream(struct vsp1_entity *entity,
> > +				 struct v4l2_subdev_state *sd_state,
> >  				 struct vsp1_pipeline *pipe,
> >  				 struct vsp1_dl_list *dl,
> >  				 struct vsp1_dl_body *dlb)
> > @@ -93,8 +94,7 @@ static void lif_configure_stream(struct vsp1_entity *entity,
> >  	unsigned int obth;
> >  	unsigned int lbth;
> >
> > -	format = v4l2_subdev_state_get_format(lif->entity.state,
> > -					      LIF_PAD_SOURCE);
> > +	format = v4l2_subdev_state_get_format(sd_state, LIF_PAD_SOURCE);
> >
> >  	switch (entity->vsp1->version & VI6_IP_VERSION_MODEL_MASK) {
> >  	case VI6_IP_VERSION_MODEL_VSPD_GEN2:
> > diff --git a/drivers/media/platform/renesas/vsp1/vsp1_lut.c b/drivers/media/platform/renesas/vsp1/vsp1_lut.c
> > index 451d24ab0b56..0382ddaa6911 100644
> > --- a/drivers/media/platform/renesas/vsp1/vsp1_lut.c
> > +++ b/drivers/media/platform/renesas/vsp1/vsp1_lut.c
> > @@ -146,6 +146,7 @@ static const struct v4l2_subdev_ops lut_ops = {
> >   */
> >
> >  static void lut_configure_stream(struct vsp1_entity *entity,
> > +				 struct v4l2_subdev_state *sd_state,
> >  				 struct vsp1_pipeline *pipe,
> >  				 struct vsp1_dl_list *dl,
> >  				 struct vsp1_dl_body *dlb)
> > diff --git a/drivers/media/platform/renesas/vsp1/vsp1_pipe.c b/drivers/media/platform/renesas/vsp1/vsp1_pipe.c
> > index edc5e9f3ba65..37f89fa5a6e2 100644
> > --- a/drivers/media/platform/renesas/vsp1/vsp1_pipe.c
> > +++ b/drivers/media/platform/renesas/vsp1/vsp1_pipe.c
> > @@ -487,8 +487,8 @@ static void vsp1_pipeline_propagate_partition(struct vsp1_pipeline *pipe,
> >
> >  	list_for_each_entry_reverse(entity, &pipe->entities, list_pipe) {
> >  		if (entity->ops->partition)
> > -			entity->ops->partition(entity, pipe, partition, index,
> > -					       window);
> > +			entity->ops->partition(entity, entity->state, pipe,
> > +					       partition, index, window);
> >  	}
> >  }
> >
> > diff --git a/drivers/media/platform/renesas/vsp1/vsp1_rpf.c b/drivers/media/platform/renesas/vsp1/vsp1_rpf.c
> > index b4558670b46f..309f02b49088 100644
> > --- a/drivers/media/platform/renesas/vsp1/vsp1_rpf.c
> > +++ b/drivers/media/platform/renesas/vsp1/vsp1_rpf.c
> > @@ -48,6 +48,7 @@ static inline void vsp1_rpf_write(struct vsp1_rwpf *rpf,
> >   */
> >
> >  static void rpf_configure_stream(struct vsp1_entity *entity,
> > +				 struct v4l2_subdev_state *sd_state,
> >  				 struct vsp1_pipeline *pipe,
> >  				 struct vsp1_dl_list *dl,
> >  				 struct vsp1_dl_body *dlb)
> > @@ -80,10 +81,8 @@ static void rpf_configure_stream(struct vsp1_entity *entity,
> >  	vsp1_rpf_write(rpf, dlb, VI6_RPF_SRCM_PSTRIDE, pstride);
> >
> >  	/* Format */
> > -	sink_format = v4l2_subdev_state_get_format(rpf->entity.state,
> > -						   RWPF_PAD_SINK);
> > -	source_format = v4l2_subdev_state_get_format(rpf->entity.state,
> > -						     RWPF_PAD_SOURCE);
> > +	sink_format = v4l2_subdev_state_get_format(sd_state, RWPF_PAD_SINK);
> > +	source_format = v4l2_subdev_state_get_format(sd_state, RWPF_PAD_SOURCE);
> >
> >  	infmt = VI6_RPF_INFMT_CIPM
> >  	      | (fmtinfo->hwfmt << VI6_RPF_INFMT_RDFMT_SHIFT);
> > @@ -347,6 +346,7 @@ static void rpf_configure_partition(struct vsp1_entity *entity,
> >  }
> >
> >  static void rpf_partition(struct vsp1_entity *entity,
> > +			  struct v4l2_subdev_state *sd_state,
> >  			  struct vsp1_pipeline *pipe,
> >  			  struct vsp1_partition *partition,
> >  			  unsigned int partition_idx,
> > @@ -364,7 +364,7 @@ static void rpf_partition(struct vsp1_entity *entity,
> >  	 * our crop to provide a 'sub-crop' matching the expected partition
> >  	 * window.
> >  	 */
> > -	*rpf_rect = *v4l2_subdev_state_get_crop(entity->state, RWPF_PAD_SINK);
> > +	*rpf_rect = *v4l2_subdev_state_get_crop(sd_state, RWPF_PAD_SINK);
> >
> >  	if (pipe->partitions > 1) {
> >  		rpf_rect->width = window->width;
> > diff --git a/drivers/media/platform/renesas/vsp1/vsp1_sru.c b/drivers/media/platform/renesas/vsp1/vsp1_sru.c
> > index f35187daa643..4f32024b9ed4 100644
> > --- a/drivers/media/platform/renesas/vsp1/vsp1_sru.c
> > +++ b/drivers/media/platform/renesas/vsp1/vsp1_sru.c
> > @@ -265,6 +265,7 @@ static const struct v4l2_subdev_ops sru_ops = {
> >   */
> >
> >  static void sru_configure_stream(struct vsp1_entity *entity,
> > +				 struct v4l2_subdev_state *sd_state,
> >  				 struct vsp1_pipeline *pipe,
> >  				 struct vsp1_dl_list *dl,
> >  				 struct vsp1_dl_body *dlb)
> > @@ -275,9 +276,8 @@ static void sru_configure_stream(struct vsp1_entity *entity,
> >  	struct v4l2_mbus_framefmt *output;
> >  	u32 ctrl0;
> >
> > -	input = v4l2_subdev_state_get_format(sru->entity.state, SRU_PAD_SINK);
> > -	output = v4l2_subdev_state_get_format(sru->entity.state,
> > -					      SRU_PAD_SOURCE);
> > +	input = v4l2_subdev_state_get_format(sd_state, SRU_PAD_SINK);
> > +	output = v4l2_subdev_state_get_format(sd_state, SRU_PAD_SOURCE);
> >
> >  	if (input->code == MEDIA_BUS_FMT_ARGB8888_1X32)
> >  		ctrl0 = VI6_SRU_CTRL0_PARAM2 | VI6_SRU_CTRL0_PARAM3
> > @@ -298,16 +298,14 @@ static void sru_configure_stream(struct vsp1_entity *entity,
> >  }
> >
> >  static unsigned int sru_max_width(struct vsp1_entity *entity,
> > +				  struct v4l2_subdev_state *sd_state,
> >  				  struct vsp1_pipeline *pipe)
> >  {
> > -	struct vsp1_sru *sru = to_sru(&entity->subdev);
> >  	struct v4l2_mbus_framefmt *input;
> >  	struct v4l2_mbus_framefmt *output;
> >
> > -	input = v4l2_subdev_state_get_format(sru->entity.state,
> > -					     SRU_PAD_SINK);
> > -	output = v4l2_subdev_state_get_format(sru->entity.state,
> > -					      SRU_PAD_SOURCE);
> > +	input = v4l2_subdev_state_get_format(sd_state, SRU_PAD_SINK);
> > +	output = v4l2_subdev_state_get_format(sd_state, SRU_PAD_SOURCE);
> >
> >  	/*
> >  	 * The maximum input width of the SRU is 288 input pixels, but 32
> > @@ -321,19 +319,17 @@ static unsigned int sru_max_width(struct vsp1_entity *entity,
> >  }
> >
> >  static void sru_partition(struct vsp1_entity *entity,
> > +			  struct v4l2_subdev_state *sd_state,
> >  			  struct vsp1_pipeline *pipe,
> >  			  struct vsp1_partition *partition,
> >  			  unsigned int partition_idx,
> >  			  struct v4l2_rect *window)
> >  {
> > -	struct vsp1_sru *sru = to_sru(&entity->subdev);
> >  	struct v4l2_mbus_framefmt *input;
> >  	struct v4l2_mbus_framefmt *output;
> >
> > -	input = v4l2_subdev_state_get_format(sru->entity.state,
> > -					     SRU_PAD_SINK);
> > -	output = v4l2_subdev_state_get_format(sru->entity.state,
> > -					      SRU_PAD_SOURCE);
> > +	input = v4l2_subdev_state_get_format(sd_state, SRU_PAD_SINK);
> > +	output = v4l2_subdev_state_get_format(sd_state, SRU_PAD_SOURCE);
> >
> >  	/* Adapt if SRUx2 is enabled. */
> >  	if (input->width != output->width) {
> > diff --git a/drivers/media/platform/renesas/vsp1/vsp1_uds.c b/drivers/media/platform/renesas/vsp1/vsp1_uds.c
> > index e5953d86c17c..d39a89a0f27d 100644
> > --- a/drivers/media/platform/renesas/vsp1/vsp1_uds.c
> > +++ b/drivers/media/platform/renesas/vsp1/vsp1_uds.c
> > @@ -252,6 +252,7 @@ static const struct v4l2_subdev_ops uds_ops = {
> >   */
> >
> >  static void uds_configure_stream(struct vsp1_entity *entity,
> > +				 struct v4l2_subdev_state *sd_state,
> >  				 struct vsp1_pipeline *pipe,
> >  				 struct vsp1_dl_list *dl,
> >  				 struct vsp1_dl_body *dlb)
> > @@ -263,9 +264,8 @@ static void uds_configure_stream(struct vsp1_entity *entity,
> >  	unsigned int vscale;
> >  	bool multitap;
> >
> > -	input = v4l2_subdev_state_get_format(uds->entity.state, UDS_PAD_SINK);
> > -	output = v4l2_subdev_state_get_format(uds->entity.state,
> > -					      UDS_PAD_SOURCE);
> > +	input = v4l2_subdev_state_get_format(sd_state, UDS_PAD_SINK);
> > +	output = v4l2_subdev_state_get_format(sd_state, UDS_PAD_SOURCE);
> >
> >  	hscale = uds_compute_ratio(input->width, output->width);
> >  	vscale = uds_compute_ratio(input->height, output->height);
> > @@ -321,16 +321,15 @@ static void uds_configure_partition(struct vsp1_entity *entity,
> >  }
> >
> >  static unsigned int uds_max_width(struct vsp1_entity *entity,
> > +				  struct v4l2_subdev_state *sd_state,
> >  				  struct vsp1_pipeline *pipe)
> >  {
> > -	struct vsp1_uds *uds = to_uds(&entity->subdev);
> >  	const struct v4l2_mbus_framefmt *output;
> >  	const struct v4l2_mbus_framefmt *input;
> >  	unsigned int hscale;
> >
> > -	input = v4l2_subdev_state_get_format(uds->entity.state, UDS_PAD_SINK);
> > -	output = v4l2_subdev_state_get_format(uds->entity.state,
> > -					      UDS_PAD_SOURCE);
> > +	input = v4l2_subdev_state_get_format(sd_state, UDS_PAD_SINK);
> > +	output = v4l2_subdev_state_get_format(sd_state, UDS_PAD_SOURCE);
> >  	hscale = output->width / input->width;
> >
> >  	/*
> > @@ -356,18 +355,17 @@ static unsigned int uds_max_width(struct vsp1_entity *entity,
> >   */
> >
> >  static void uds_partition(struct vsp1_entity *entity,
> > +			  struct v4l2_subdev_state *sd_state,
> >  			  struct vsp1_pipeline *pipe,
> >  			  struct vsp1_partition *partition,
> >  			  unsigned int partition_idx,
> >  			  struct v4l2_rect *window)
> >  {
> > -	struct vsp1_uds *uds = to_uds(&entity->subdev);
> >  	const struct v4l2_mbus_framefmt *output;
> >  	const struct v4l2_mbus_framefmt *input;
> >
> > -	input = v4l2_subdev_state_get_format(uds->entity.state, UDS_PAD_SINK);
> > -	output = v4l2_subdev_state_get_format(uds->entity.state,
> > -					      UDS_PAD_SOURCE);
> > +	input = v4l2_subdev_state_get_format(sd_state, UDS_PAD_SINK);
> > +	output = v4l2_subdev_state_get_format(sd_state, UDS_PAD_SOURCE);
> >
> >  	partition->uds_sink.width = window->width * input->width
> >  				  / output->width;
> > diff --git a/drivers/media/platform/renesas/vsp1/vsp1_uif.c b/drivers/media/platform/renesas/vsp1/vsp1_uif.c
> > index cecd2f7024f4..e69acb5f0fbb 100644
> > --- a/drivers/media/platform/renesas/vsp1/vsp1_uif.c
> > +++ b/drivers/media/platform/renesas/vsp1/vsp1_uif.c
> > @@ -188,6 +188,7 @@ static const struct v4l2_subdev_ops uif_ops = {
> >   */
> >
> >  static void uif_configure_stream(struct vsp1_entity *entity,
> > +				 struct v4l2_subdev_state *sd_state,
> >  				 struct vsp1_pipeline *pipe,
> >  				 struct vsp1_dl_list *dl,
> >  				 struct vsp1_dl_body *dlb)
> > @@ -200,7 +201,7 @@ static void uif_configure_stream(struct vsp1_entity *entity,
> >  	vsp1_uif_write(uif, dlb, VI6_UIF_DISCOM_DOCMPMR,
> >  		       VI6_UIF_DISCOM_DOCMPMR_SEL(9));
> >
> > -	crop = v4l2_subdev_state_get_crop(entity->state, UIF_PAD_SINK);
> > +	crop = v4l2_subdev_state_get_crop(sd_state, UIF_PAD_SINK);
> >
> >  	left = crop->left;
> >  	width = crop->width;
> > diff --git a/drivers/media/platform/renesas/vsp1/vsp1_video.c b/drivers/media/platform/renesas/vsp1/vsp1_video.c
> > index 84394994ccee..6645cf1d533b 100644
> > --- a/drivers/media/platform/renesas/vsp1/vsp1_video.c
> > +++ b/drivers/media/platform/renesas/vsp1/vsp1_video.c
> > @@ -693,7 +693,9 @@ static int vsp1_video_pipeline_setup_partitions(struct vsp1_pipeline *pipe)
> >  			if (!entity->ops->max_width)
> >  				continue;
> >
> > -			entity_max = entity->ops->max_width(entity, pipe);
> > +			entity_max = entity->ops->max_width(entity,
> > +							    entity->state,
> > +							    pipe);
> >  			if (entity_max)
> >  				div_size = min(div_size, entity_max);
> >  		}
> > @@ -754,7 +756,7 @@ static int vsp1_video_setup_pipeline(struct vsp1_pipeline *pipe)
> >
> >  	list_for_each_entry(entity, &pipe->entities, list_pipe) {
> >  		vsp1_entity_route_setup(entity, pipe, pipe->stream_config);
> > -		vsp1_entity_configure_stream(entity, pipe, NULL,
> > +		vsp1_entity_configure_stream(entity, entity->state, pipe, NULL,
> >  					     pipe->stream_config);
> >  	}
> >
> > diff --git a/drivers/media/platform/renesas/vsp1/vsp1_wpf.c b/drivers/media/platform/renesas/vsp1/vsp1_wpf.c
> > index 5c363ff1d36c..e3d961c8d3e3 100644
> > --- a/drivers/media/platform/renesas/vsp1/vsp1_wpf.c
> > +++ b/drivers/media/platform/renesas/vsp1/vsp1_wpf.c
> > @@ -229,6 +229,7 @@ static int wpf_configure_writeback_chain(struct vsp1_rwpf *wpf,
> >  }
> >
> >  static void wpf_configure_stream(struct vsp1_entity *entity,
> > +				 struct v4l2_subdev_state *sd_state,
> >  				 struct vsp1_pipeline *pipe,
> >  				 struct vsp1_dl_list *dl,
> >  				 struct vsp1_dl_body *dlb)
> > @@ -243,10 +244,8 @@ static void wpf_configure_stream(struct vsp1_entity *entity,
> >  	u32 srcrpf = 0;
> >  	int ret;
> >
> > -	sink_format = v4l2_subdev_state_get_format(wpf->entity.state,
> > -						   RWPF_PAD_SINK);
> > -	source_format = v4l2_subdev_state_get_format(wpf->entity.state,
> > -						     RWPF_PAD_SOURCE);
> > +	sink_format = v4l2_subdev_state_get_format(sd_state, RWPF_PAD_SINK);
> > +	source_format = v4l2_subdev_state_get_format(sd_state, RWPF_PAD_SOURCE);
> >
> >  	/* Format */
> >  	if (!pipe->lif || wpf->writeback) {
> > @@ -496,6 +495,7 @@ static void wpf_configure_partition(struct vsp1_entity *entity,
> >  }
> >
> >  static unsigned int wpf_max_width(struct vsp1_entity *entity,
> > +				  struct v4l2_subdev_state *sd_state,
> >  				  struct vsp1_pipeline *pipe)
> >  {
> >  	struct vsp1_rwpf *wpf = to_rwpf(&entity->subdev);
> > @@ -504,6 +504,7 @@ static unsigned int wpf_max_width(struct vsp1_entity *entity,
> >  }
> >
> >  static void wpf_partition(struct vsp1_entity *entity,
> > +			  struct v4l2_subdev_state *sd_state,
> >  			  struct vsp1_pipeline *pipe,
> >  			  struct vsp1_partition *partition,
> >  			  unsigned int partition_idx,
diff mbox series

Patch

diff --git a/drivers/media/platform/renesas/vsp1/vsp1_brx.c b/drivers/media/platform/renesas/vsp1/vsp1_brx.c
index 05940d0427bf..7639ea53dd47 100644
--- a/drivers/media/platform/renesas/vsp1/vsp1_brx.c
+++ b/drivers/media/platform/renesas/vsp1/vsp1_brx.c
@@ -272,6 +272,7 @@  static const struct v4l2_subdev_ops brx_ops = {
  */
 
 static void brx_configure_stream(struct vsp1_entity *entity,
+				 struct v4l2_subdev_state *sd_state,
 				 struct vsp1_pipeline *pipe,
 				 struct vsp1_dl_list *dl,
 				 struct vsp1_dl_body *dlb)
@@ -281,8 +282,7 @@  static void brx_configure_stream(struct vsp1_entity *entity,
 	unsigned int flags;
 	unsigned int i;
 
-	format = v4l2_subdev_state_get_format(brx->entity.state,
-					      brx->entity.source_pad);
+	format = v4l2_subdev_state_get_format(sd_state, brx->entity.source_pad);
 
 	/*
 	 * The hardware is extremely flexible but we have no userspace API to
diff --git a/drivers/media/platform/renesas/vsp1/vsp1_clu.c b/drivers/media/platform/renesas/vsp1/vsp1_clu.c
index 1e57676a420c..56c77809d2ec 100644
--- a/drivers/media/platform/renesas/vsp1/vsp1_clu.c
+++ b/drivers/media/platform/renesas/vsp1/vsp1_clu.c
@@ -170,6 +170,7 @@  static const struct v4l2_subdev_ops clu_ops = {
  */
 
 static void clu_configure_stream(struct vsp1_entity *entity,
+				 struct v4l2_subdev_state *sd_state,
 				 struct vsp1_pipeline *pipe,
 				 struct vsp1_dl_list *dl,
 				 struct vsp1_dl_body *dlb)
@@ -181,7 +182,7 @@  static void clu_configure_stream(struct vsp1_entity *entity,
 	 * The yuv_mode can't be changed during streaming. Cache it internally
 	 * for future runtime configuration calls.
 	 */
-	format = v4l2_subdev_state_get_format(clu->entity.state, CLU_PAD_SINK);
+	format = v4l2_subdev_state_get_format(sd_state, CLU_PAD_SINK);
 	clu->yuv_mode = format->code == MEDIA_BUS_FMT_AYUV8_1X32;
 }
 
diff --git a/drivers/media/platform/renesas/vsp1/vsp1_drm.c b/drivers/media/platform/renesas/vsp1/vsp1_drm.c
index 11313e26a298..b5d1f238f7be 100644
--- a/drivers/media/platform/renesas/vsp1/vsp1_drm.c
+++ b/drivers/media/platform/renesas/vsp1/vsp1_drm.c
@@ -574,7 +574,8 @@  static void vsp1_du_pipeline_configure(struct vsp1_pipeline *pipe)
 		}
 
 		vsp1_entity_route_setup(entity, pipe, dlb);
-		vsp1_entity_configure_stream(entity, pipe, dl, dlb);
+		vsp1_entity_configure_stream(entity, entity->state, pipe,
+					     dl, dlb);
 		vsp1_entity_configure_frame(entity, pipe, dl, dlb);
 		vsp1_entity_configure_partition(entity, pipe,
 						&pipe->part_table[0], dl, dlb);
diff --git a/drivers/media/platform/renesas/vsp1/vsp1_entity.c b/drivers/media/platform/renesas/vsp1/vsp1_entity.c
index e9de75de8bde..d3533a75361a 100644
--- a/drivers/media/platform/renesas/vsp1/vsp1_entity.c
+++ b/drivers/media/platform/renesas/vsp1/vsp1_entity.c
@@ -70,12 +70,13 @@  void vsp1_entity_route_setup(struct vsp1_entity *entity,
 }
 
 void vsp1_entity_configure_stream(struct vsp1_entity *entity,
+				  struct v4l2_subdev_state *sd_state,
 				  struct vsp1_pipeline *pipe,
 				  struct vsp1_dl_list *dl,
 				  struct vsp1_dl_body *dlb)
 {
 	if (entity->ops->configure_stream)
-		entity->ops->configure_stream(entity, pipe, dl, dlb);
+		entity->ops->configure_stream(entity, sd_state, pipe, dl, dlb);
 }
 
 void vsp1_entity_configure_frame(struct vsp1_entity *entity,
diff --git a/drivers/media/platform/renesas/vsp1/vsp1_entity.h b/drivers/media/platform/renesas/vsp1/vsp1_entity.h
index 42000d6e2530..1d9d050e79da 100644
--- a/drivers/media/platform/renesas/vsp1/vsp1_entity.h
+++ b/drivers/media/platform/renesas/vsp1/vsp1_entity.h
@@ -79,6 +79,7 @@  struct vsp1_route {
 struct vsp1_entity_operations {
 	void (*destroy)(struct vsp1_entity *entity);
 	void (*configure_stream)(struct vsp1_entity *entity,
+				 struct v4l2_subdev_state *state,
 				 struct vsp1_pipeline *pipe,
 				 struct vsp1_dl_list *dl,
 				 struct vsp1_dl_body *dlb);
@@ -92,8 +93,10 @@  struct vsp1_entity_operations {
 				    struct vsp1_dl_list *dl,
 				    struct vsp1_dl_body *dlb);
 	unsigned int (*max_width)(struct vsp1_entity *entity,
+				  struct v4l2_subdev_state *state,
 				  struct vsp1_pipeline *pipe);
 	void (*partition)(struct vsp1_entity *entity,
+			  struct v4l2_subdev_state *state,
 			  struct vsp1_pipeline *pipe,
 			  struct vsp1_partition *partition,
 			  unsigned int index,
@@ -151,6 +154,7 @@  void vsp1_entity_route_setup(struct vsp1_entity *entity,
 			     struct vsp1_dl_body *dlb);
 
 void vsp1_entity_configure_stream(struct vsp1_entity *entity,
+				  struct v4l2_subdev_state *sd_state,
 				  struct vsp1_pipeline *pipe,
 				  struct vsp1_dl_list *dl,
 				  struct vsp1_dl_body *dlb);
diff --git a/drivers/media/platform/renesas/vsp1/vsp1_hgo.c b/drivers/media/platform/renesas/vsp1/vsp1_hgo.c
index 4ee5f0e5e9c3..237dc4c7c5ed 100644
--- a/drivers/media/platform/renesas/vsp1/vsp1_hgo.c
+++ b/drivers/media/platform/renesas/vsp1/vsp1_hgo.c
@@ -130,6 +130,7 @@  static const struct v4l2_ctrl_config hgo_num_bins_control = {
  */
 
 static void hgo_configure_stream(struct vsp1_entity *entity,
+				 struct v4l2_subdev_state *sd_state,
 				 struct vsp1_pipeline *pipe,
 				 struct vsp1_dl_list *dl,
 				 struct vsp1_dl_body *dlb)
@@ -140,8 +141,8 @@  static void hgo_configure_stream(struct vsp1_entity *entity,
 	unsigned int hratio;
 	unsigned int vratio;
 
-	crop = v4l2_subdev_state_get_crop(entity->state, HISTO_PAD_SINK);
-	compose = v4l2_subdev_state_get_compose(entity->state, HISTO_PAD_SINK);
+	crop = v4l2_subdev_state_get_crop(sd_state, HISTO_PAD_SINK);
+	compose = v4l2_subdev_state_get_compose(sd_state, HISTO_PAD_SINK);
 
 	vsp1_hgo_write(hgo, dlb, VI6_HGO_REGRST, VI6_HGO_REGRST_RCLEA);
 
diff --git a/drivers/media/platform/renesas/vsp1/vsp1_hgt.c b/drivers/media/platform/renesas/vsp1/vsp1_hgt.c
index b739d8045576..b73eac676ef0 100644
--- a/drivers/media/platform/renesas/vsp1/vsp1_hgt.c
+++ b/drivers/media/platform/renesas/vsp1/vsp1_hgt.c
@@ -126,6 +126,7 @@  static const struct v4l2_ctrl_config hgt_hue_areas = {
  */
 
 static void hgt_configure_stream(struct vsp1_entity *entity,
+				 struct v4l2_subdev_state *sd_state,
 				 struct vsp1_pipeline *pipe,
 				 struct vsp1_dl_list *dl,
 				 struct vsp1_dl_body *dlb)
@@ -139,8 +140,8 @@  static void hgt_configure_stream(struct vsp1_entity *entity,
 	u8 upper;
 	unsigned int i;
 
-	crop = v4l2_subdev_state_get_crop(entity->state, HISTO_PAD_SINK);
-	compose = v4l2_subdev_state_get_compose(entity->state, HISTO_PAD_SINK);
+	crop = v4l2_subdev_state_get_crop(sd_state, HISTO_PAD_SINK);
+	compose = v4l2_subdev_state_get_compose(sd_state, HISTO_PAD_SINK);
 
 	vsp1_hgt_write(hgt, dlb, VI6_HGT_REGRST, VI6_HGT_REGRST_RCLEA);
 
diff --git a/drivers/media/platform/renesas/vsp1/vsp1_hsit.c b/drivers/media/platform/renesas/vsp1/vsp1_hsit.c
index 4a8cce808c93..932ac1c795bc 100644
--- a/drivers/media/platform/renesas/vsp1/vsp1_hsit.c
+++ b/drivers/media/platform/renesas/vsp1/vsp1_hsit.c
@@ -127,6 +127,7 @@  static const struct v4l2_subdev_ops hsit_ops = {
  */
 
 static void hsit_configure_stream(struct vsp1_entity *entity,
+				  struct v4l2_subdev_state *sd_state,
 				  struct vsp1_pipeline *pipe,
 				  struct vsp1_dl_list *dl,
 				  struct vsp1_dl_body *dlb)
diff --git a/drivers/media/platform/renesas/vsp1/vsp1_lif.c b/drivers/media/platform/renesas/vsp1/vsp1_lif.c
index 29d4c1521e6a..308917338022 100644
--- a/drivers/media/platform/renesas/vsp1/vsp1_lif.c
+++ b/drivers/media/platform/renesas/vsp1/vsp1_lif.c
@@ -83,6 +83,7 @@  static const struct v4l2_subdev_ops lif_ops = {
  */
 
 static void lif_configure_stream(struct vsp1_entity *entity,
+				 struct v4l2_subdev_state *sd_state,
 				 struct vsp1_pipeline *pipe,
 				 struct vsp1_dl_list *dl,
 				 struct vsp1_dl_body *dlb)
@@ -93,8 +94,7 @@  static void lif_configure_stream(struct vsp1_entity *entity,
 	unsigned int obth;
 	unsigned int lbth;
 
-	format = v4l2_subdev_state_get_format(lif->entity.state,
-					      LIF_PAD_SOURCE);
+	format = v4l2_subdev_state_get_format(sd_state, LIF_PAD_SOURCE);
 
 	switch (entity->vsp1->version & VI6_IP_VERSION_MODEL_MASK) {
 	case VI6_IP_VERSION_MODEL_VSPD_GEN2:
diff --git a/drivers/media/platform/renesas/vsp1/vsp1_lut.c b/drivers/media/platform/renesas/vsp1/vsp1_lut.c
index 451d24ab0b56..0382ddaa6911 100644
--- a/drivers/media/platform/renesas/vsp1/vsp1_lut.c
+++ b/drivers/media/platform/renesas/vsp1/vsp1_lut.c
@@ -146,6 +146,7 @@  static const struct v4l2_subdev_ops lut_ops = {
  */
 
 static void lut_configure_stream(struct vsp1_entity *entity,
+				 struct v4l2_subdev_state *sd_state,
 				 struct vsp1_pipeline *pipe,
 				 struct vsp1_dl_list *dl,
 				 struct vsp1_dl_body *dlb)
diff --git a/drivers/media/platform/renesas/vsp1/vsp1_pipe.c b/drivers/media/platform/renesas/vsp1/vsp1_pipe.c
index edc5e9f3ba65..37f89fa5a6e2 100644
--- a/drivers/media/platform/renesas/vsp1/vsp1_pipe.c
+++ b/drivers/media/platform/renesas/vsp1/vsp1_pipe.c
@@ -487,8 +487,8 @@  static void vsp1_pipeline_propagate_partition(struct vsp1_pipeline *pipe,
 
 	list_for_each_entry_reverse(entity, &pipe->entities, list_pipe) {
 		if (entity->ops->partition)
-			entity->ops->partition(entity, pipe, partition, index,
-					       window);
+			entity->ops->partition(entity, entity->state, pipe,
+					       partition, index, window);
 	}
 }
 
diff --git a/drivers/media/platform/renesas/vsp1/vsp1_rpf.c b/drivers/media/platform/renesas/vsp1/vsp1_rpf.c
index b4558670b46f..309f02b49088 100644
--- a/drivers/media/platform/renesas/vsp1/vsp1_rpf.c
+++ b/drivers/media/platform/renesas/vsp1/vsp1_rpf.c
@@ -48,6 +48,7 @@  static inline void vsp1_rpf_write(struct vsp1_rwpf *rpf,
  */
 
 static void rpf_configure_stream(struct vsp1_entity *entity,
+				 struct v4l2_subdev_state *sd_state,
 				 struct vsp1_pipeline *pipe,
 				 struct vsp1_dl_list *dl,
 				 struct vsp1_dl_body *dlb)
@@ -80,10 +81,8 @@  static void rpf_configure_stream(struct vsp1_entity *entity,
 	vsp1_rpf_write(rpf, dlb, VI6_RPF_SRCM_PSTRIDE, pstride);
 
 	/* Format */
-	sink_format = v4l2_subdev_state_get_format(rpf->entity.state,
-						   RWPF_PAD_SINK);
-	source_format = v4l2_subdev_state_get_format(rpf->entity.state,
-						     RWPF_PAD_SOURCE);
+	sink_format = v4l2_subdev_state_get_format(sd_state, RWPF_PAD_SINK);
+	source_format = v4l2_subdev_state_get_format(sd_state, RWPF_PAD_SOURCE);
 
 	infmt = VI6_RPF_INFMT_CIPM
 	      | (fmtinfo->hwfmt << VI6_RPF_INFMT_RDFMT_SHIFT);
@@ -347,6 +346,7 @@  static void rpf_configure_partition(struct vsp1_entity *entity,
 }
 
 static void rpf_partition(struct vsp1_entity *entity,
+			  struct v4l2_subdev_state *sd_state,
 			  struct vsp1_pipeline *pipe,
 			  struct vsp1_partition *partition,
 			  unsigned int partition_idx,
@@ -364,7 +364,7 @@  static void rpf_partition(struct vsp1_entity *entity,
 	 * our crop to provide a 'sub-crop' matching the expected partition
 	 * window.
 	 */
-	*rpf_rect = *v4l2_subdev_state_get_crop(entity->state, RWPF_PAD_SINK);
+	*rpf_rect = *v4l2_subdev_state_get_crop(sd_state, RWPF_PAD_SINK);
 
 	if (pipe->partitions > 1) {
 		rpf_rect->width = window->width;
diff --git a/drivers/media/platform/renesas/vsp1/vsp1_sru.c b/drivers/media/platform/renesas/vsp1/vsp1_sru.c
index f35187daa643..4f32024b9ed4 100644
--- a/drivers/media/platform/renesas/vsp1/vsp1_sru.c
+++ b/drivers/media/platform/renesas/vsp1/vsp1_sru.c
@@ -265,6 +265,7 @@  static const struct v4l2_subdev_ops sru_ops = {
  */
 
 static void sru_configure_stream(struct vsp1_entity *entity,
+				 struct v4l2_subdev_state *sd_state,
 				 struct vsp1_pipeline *pipe,
 				 struct vsp1_dl_list *dl,
 				 struct vsp1_dl_body *dlb)
@@ -275,9 +276,8 @@  static void sru_configure_stream(struct vsp1_entity *entity,
 	struct v4l2_mbus_framefmt *output;
 	u32 ctrl0;
 
-	input = v4l2_subdev_state_get_format(sru->entity.state, SRU_PAD_SINK);
-	output = v4l2_subdev_state_get_format(sru->entity.state,
-					      SRU_PAD_SOURCE);
+	input = v4l2_subdev_state_get_format(sd_state, SRU_PAD_SINK);
+	output = v4l2_subdev_state_get_format(sd_state, SRU_PAD_SOURCE);
 
 	if (input->code == MEDIA_BUS_FMT_ARGB8888_1X32)
 		ctrl0 = VI6_SRU_CTRL0_PARAM2 | VI6_SRU_CTRL0_PARAM3
@@ -298,16 +298,14 @@  static void sru_configure_stream(struct vsp1_entity *entity,
 }
 
 static unsigned int sru_max_width(struct vsp1_entity *entity,
+				  struct v4l2_subdev_state *sd_state,
 				  struct vsp1_pipeline *pipe)
 {
-	struct vsp1_sru *sru = to_sru(&entity->subdev);
 	struct v4l2_mbus_framefmt *input;
 	struct v4l2_mbus_framefmt *output;
 
-	input = v4l2_subdev_state_get_format(sru->entity.state,
-					     SRU_PAD_SINK);
-	output = v4l2_subdev_state_get_format(sru->entity.state,
-					      SRU_PAD_SOURCE);
+	input = v4l2_subdev_state_get_format(sd_state, SRU_PAD_SINK);
+	output = v4l2_subdev_state_get_format(sd_state, SRU_PAD_SOURCE);
 
 	/*
 	 * The maximum input width of the SRU is 288 input pixels, but 32
@@ -321,19 +319,17 @@  static unsigned int sru_max_width(struct vsp1_entity *entity,
 }
 
 static void sru_partition(struct vsp1_entity *entity,
+			  struct v4l2_subdev_state *sd_state,
 			  struct vsp1_pipeline *pipe,
 			  struct vsp1_partition *partition,
 			  unsigned int partition_idx,
 			  struct v4l2_rect *window)
 {
-	struct vsp1_sru *sru = to_sru(&entity->subdev);
 	struct v4l2_mbus_framefmt *input;
 	struct v4l2_mbus_framefmt *output;
 
-	input = v4l2_subdev_state_get_format(sru->entity.state,
-					     SRU_PAD_SINK);
-	output = v4l2_subdev_state_get_format(sru->entity.state,
-					      SRU_PAD_SOURCE);
+	input = v4l2_subdev_state_get_format(sd_state, SRU_PAD_SINK);
+	output = v4l2_subdev_state_get_format(sd_state, SRU_PAD_SOURCE);
 
 	/* Adapt if SRUx2 is enabled. */
 	if (input->width != output->width) {
diff --git a/drivers/media/platform/renesas/vsp1/vsp1_uds.c b/drivers/media/platform/renesas/vsp1/vsp1_uds.c
index e5953d86c17c..d39a89a0f27d 100644
--- a/drivers/media/platform/renesas/vsp1/vsp1_uds.c
+++ b/drivers/media/platform/renesas/vsp1/vsp1_uds.c
@@ -252,6 +252,7 @@  static const struct v4l2_subdev_ops uds_ops = {
  */
 
 static void uds_configure_stream(struct vsp1_entity *entity,
+				 struct v4l2_subdev_state *sd_state,
 				 struct vsp1_pipeline *pipe,
 				 struct vsp1_dl_list *dl,
 				 struct vsp1_dl_body *dlb)
@@ -263,9 +264,8 @@  static void uds_configure_stream(struct vsp1_entity *entity,
 	unsigned int vscale;
 	bool multitap;
 
-	input = v4l2_subdev_state_get_format(uds->entity.state, UDS_PAD_SINK);
-	output = v4l2_subdev_state_get_format(uds->entity.state,
-					      UDS_PAD_SOURCE);
+	input = v4l2_subdev_state_get_format(sd_state, UDS_PAD_SINK);
+	output = v4l2_subdev_state_get_format(sd_state, UDS_PAD_SOURCE);
 
 	hscale = uds_compute_ratio(input->width, output->width);
 	vscale = uds_compute_ratio(input->height, output->height);
@@ -321,16 +321,15 @@  static void uds_configure_partition(struct vsp1_entity *entity,
 }
 
 static unsigned int uds_max_width(struct vsp1_entity *entity,
+				  struct v4l2_subdev_state *sd_state,
 				  struct vsp1_pipeline *pipe)
 {
-	struct vsp1_uds *uds = to_uds(&entity->subdev);
 	const struct v4l2_mbus_framefmt *output;
 	const struct v4l2_mbus_framefmt *input;
 	unsigned int hscale;
 
-	input = v4l2_subdev_state_get_format(uds->entity.state, UDS_PAD_SINK);
-	output = v4l2_subdev_state_get_format(uds->entity.state,
-					      UDS_PAD_SOURCE);
+	input = v4l2_subdev_state_get_format(sd_state, UDS_PAD_SINK);
+	output = v4l2_subdev_state_get_format(sd_state, UDS_PAD_SOURCE);
 	hscale = output->width / input->width;
 
 	/*
@@ -356,18 +355,17 @@  static unsigned int uds_max_width(struct vsp1_entity *entity,
  */
 
 static void uds_partition(struct vsp1_entity *entity,
+			  struct v4l2_subdev_state *sd_state,
 			  struct vsp1_pipeline *pipe,
 			  struct vsp1_partition *partition,
 			  unsigned int partition_idx,
 			  struct v4l2_rect *window)
 {
-	struct vsp1_uds *uds = to_uds(&entity->subdev);
 	const struct v4l2_mbus_framefmt *output;
 	const struct v4l2_mbus_framefmt *input;
 
-	input = v4l2_subdev_state_get_format(uds->entity.state, UDS_PAD_SINK);
-	output = v4l2_subdev_state_get_format(uds->entity.state,
-					      UDS_PAD_SOURCE);
+	input = v4l2_subdev_state_get_format(sd_state, UDS_PAD_SINK);
+	output = v4l2_subdev_state_get_format(sd_state, UDS_PAD_SOURCE);
 
 	partition->uds_sink.width = window->width * input->width
 				  / output->width;
diff --git a/drivers/media/platform/renesas/vsp1/vsp1_uif.c b/drivers/media/platform/renesas/vsp1/vsp1_uif.c
index cecd2f7024f4..e69acb5f0fbb 100644
--- a/drivers/media/platform/renesas/vsp1/vsp1_uif.c
+++ b/drivers/media/platform/renesas/vsp1/vsp1_uif.c
@@ -188,6 +188,7 @@  static const struct v4l2_subdev_ops uif_ops = {
  */
 
 static void uif_configure_stream(struct vsp1_entity *entity,
+				 struct v4l2_subdev_state *sd_state,
 				 struct vsp1_pipeline *pipe,
 				 struct vsp1_dl_list *dl,
 				 struct vsp1_dl_body *dlb)
@@ -200,7 +201,7 @@  static void uif_configure_stream(struct vsp1_entity *entity,
 	vsp1_uif_write(uif, dlb, VI6_UIF_DISCOM_DOCMPMR,
 		       VI6_UIF_DISCOM_DOCMPMR_SEL(9));
 
-	crop = v4l2_subdev_state_get_crop(entity->state, UIF_PAD_SINK);
+	crop = v4l2_subdev_state_get_crop(sd_state, UIF_PAD_SINK);
 
 	left = crop->left;
 	width = crop->width;
diff --git a/drivers/media/platform/renesas/vsp1/vsp1_video.c b/drivers/media/platform/renesas/vsp1/vsp1_video.c
index 84394994ccee..6645cf1d533b 100644
--- a/drivers/media/platform/renesas/vsp1/vsp1_video.c
+++ b/drivers/media/platform/renesas/vsp1/vsp1_video.c
@@ -693,7 +693,9 @@  static int vsp1_video_pipeline_setup_partitions(struct vsp1_pipeline *pipe)
 			if (!entity->ops->max_width)
 				continue;
 
-			entity_max = entity->ops->max_width(entity, pipe);
+			entity_max = entity->ops->max_width(entity,
+							    entity->state,
+							    pipe);
 			if (entity_max)
 				div_size = min(div_size, entity_max);
 		}
@@ -754,7 +756,7 @@  static int vsp1_video_setup_pipeline(struct vsp1_pipeline *pipe)
 
 	list_for_each_entry(entity, &pipe->entities, list_pipe) {
 		vsp1_entity_route_setup(entity, pipe, pipe->stream_config);
-		vsp1_entity_configure_stream(entity, pipe, NULL,
+		vsp1_entity_configure_stream(entity, entity->state, pipe, NULL,
 					     pipe->stream_config);
 	}
 
diff --git a/drivers/media/platform/renesas/vsp1/vsp1_wpf.c b/drivers/media/platform/renesas/vsp1/vsp1_wpf.c
index 5c363ff1d36c..e3d961c8d3e3 100644
--- a/drivers/media/platform/renesas/vsp1/vsp1_wpf.c
+++ b/drivers/media/platform/renesas/vsp1/vsp1_wpf.c
@@ -229,6 +229,7 @@  static int wpf_configure_writeback_chain(struct vsp1_rwpf *wpf,
 }
 
 static void wpf_configure_stream(struct vsp1_entity *entity,
+				 struct v4l2_subdev_state *sd_state,
 				 struct vsp1_pipeline *pipe,
 				 struct vsp1_dl_list *dl,
 				 struct vsp1_dl_body *dlb)
@@ -243,10 +244,8 @@  static void wpf_configure_stream(struct vsp1_entity *entity,
 	u32 srcrpf = 0;
 	int ret;
 
-	sink_format = v4l2_subdev_state_get_format(wpf->entity.state,
-						   RWPF_PAD_SINK);
-	source_format = v4l2_subdev_state_get_format(wpf->entity.state,
-						     RWPF_PAD_SOURCE);
+	sink_format = v4l2_subdev_state_get_format(sd_state, RWPF_PAD_SINK);
+	source_format = v4l2_subdev_state_get_format(sd_state, RWPF_PAD_SOURCE);
 
 	/* Format */
 	if (!pipe->lif || wpf->writeback) {
@@ -496,6 +495,7 @@  static void wpf_configure_partition(struct vsp1_entity *entity,
 }
 
 static unsigned int wpf_max_width(struct vsp1_entity *entity,
+				  struct v4l2_subdev_state *sd_state,
 				  struct vsp1_pipeline *pipe)
 {
 	struct vsp1_rwpf *wpf = to_rwpf(&entity->subdev);
@@ -504,6 +504,7 @@  static unsigned int wpf_max_width(struct vsp1_entity *entity,
 }
 
 static void wpf_partition(struct vsp1_entity *entity,
+			  struct v4l2_subdev_state *sd_state,
 			  struct vsp1_pipeline *pipe,
 			  struct vsp1_partition *partition,
 			  unsigned int partition_idx,