> -----Original Message-----
> From: Hogander, Jouni <[email protected]>
> Sent: Thursday, June 13, 2024 3:02 PM
> To: [email protected]
> Cc: Manna, Animesh <[email protected]>; Kahola, Mika
> <[email protected]>; Hogander, Jouni <[email protected]>
> Subject: [PATCH v8 02/20] drm/i915/display: Wa 16021440873 is writing
> wrong register
> 
> Wa 16021440873 is writing wrong register. Instead of PIPE_SRCSZ_ERLY_TPT
> write CURPOS_ERLY_TPT.
> 
> v2: use right offset as well
> 
> Fixes: 29cdef8539c3 ("drm/i915/display: Implement Wa_16021440873")
> Signed-off-by: Jouni Högander <[email protected]>
> ---
>  drivers/gpu/drm/i915/display/intel_cursor.c |  4 ++--
>  drivers/gpu/drm/i915/display/intel_psr.c    | 12 +++---------
>  2 files changed, 5 insertions(+), 11 deletions(-)
> 
> diff --git a/drivers/gpu/drm/i915/display/intel_cursor.c
> b/drivers/gpu/drm/i915/display/intel_cursor.c
> index cea0cfed569d..6ea76687dd14 100644
> --- a/drivers/gpu/drm/i915/display/intel_cursor.c
> +++ b/drivers/gpu/drm/i915/display/intel_cursor.c
> @@ -524,8 +524,8 @@ static void wa_16021440873(struct intel_plane
> *plane,
> 
>       intel_de_write_fw(dev_priv, SEL_FETCH_CUR_CTL(pipe), ctl);
> 
> -     intel_de_write(dev_priv, PIPE_SRCSZ_ERLY_TPT(pipe),
> -                    PIPESRC_HEIGHT(et_y_position));
> +     intel_de_write(dev_priv, CURPOS_ERLY_TPT(dev_priv, pipe),
> +                    CURSOR_POS_Y(et_y_position));
>  }
> 
>  static void i9xx_cursor_update_sel_fetch_arm(struct intel_plane *plane, diff
> --git a/drivers/gpu/drm/i915/display/intel_psr.c
> b/drivers/gpu/drm/i915/display/intel_psr.c
> index 66ab8abd0a04..44144dcfb1a3 100644
> --- a/drivers/gpu/drm/i915/display/intel_psr.c
> +++ b/drivers/gpu/drm/i915/display/intel_psr.c
> @@ -2164,19 +2164,14 @@ static void psr2_man_trk_ctl_calc(struct
> intel_crtc_state *crtc_state,
>       crtc_state->psr2_man_track_ctl = val;
>  }
> 
> -static u32
> -psr2_pipe_srcsz_early_tpt_calc(struct intel_crtc_state *crtc_state,
> -                            bool full_update, bool cursor_in_su_area)
> +static u32 psr2_pipe_srcsz_early_tpt_calc(struct intel_crtc_state 
> *crtc_state,
> +                                       bool full_update)
>  {
>       int width, height;
> 
>       if (!crtc_state->enable_psr2_su_region_et || full_update)
>               return 0;
> 
> -     if (!cursor_in_su_area)
> -             return PIPESRC_WIDTH(0) |
> -                     PIPESRC_HEIGHT(drm_rect_height(&crtc_state-
> >pipe_src));
> -

Should the PIPESRC_WIDTH() related changes go with patch1?
Not sure why it is added with this patch which correct the register offset 
value.

Regards,
Animesh 

>       width = drm_rect_width(&crtc_state->psr2_su_area);
>       height = drm_rect_height(&crtc_state->psr2_su_area);
> 
> @@ -2485,8 +2480,7 @@ int intel_psr2_sel_fetch_update(struct
> intel_atomic_state *state,
>  skip_sel_fetch_set_loop:
>       psr2_man_trk_ctl_calc(crtc_state, full_update);
>       crtc_state->pipe_srcsz_early_tpt =
> -             psr2_pipe_srcsz_early_tpt_calc(crtc_state, full_update,
> -                                            cursor_in_su_area);
> +             psr2_pipe_srcsz_early_tpt_calc(crtc_state, full_update);
>       return 0;
>  }
> 
> --
> 2.34.1

Reply via email to