On Mon, Nov 02, 2020 at 02:38:32PM +0100, Maxime Ripard wrote:
> dispnv50 references the crtc->state pointer in order to get the current
> CRTC state in its atomic_check hook, which would be the old CRTC state in
> the global atomic state.
> 
> Use the drm_atomic_get_old_crtc_state helper to get that state to make it
> more obvious.
> 
> Suggested-by: Ville Syrjälä <ville.syrj...@linux.intel.com>
> Signed-off-by: Maxime Ripard <max...@cerno.tech>

Looks correct
Reviewed-by: Ville Syrjälä <ville.syrj...@linux.intel.com>

> ---
>  drivers/gpu/drm/nouveau/dispnv50/head.c | 4 +++-
>  1 file changed, 3 insertions(+), 1 deletion(-)
> 
> diff --git a/drivers/gpu/drm/nouveau/dispnv50/head.c 
> b/drivers/gpu/drm/nouveau/dispnv50/head.c
> index 0542ca22b33a..537c1ef2e464 100644
> --- a/drivers/gpu/drm/nouveau/dispnv50/head.c
> +++ b/drivers/gpu/drm/nouveau/dispnv50/head.c
> @@ -313,11 +313,13 @@ nv50_head_atomic_check_mode(struct nv50_head *head, 
> struct nv50_head_atom *asyh)
>  static int
>  nv50_head_atomic_check(struct drm_crtc *crtc, struct drm_atomic_state *state)
>  {
> +     struct drm_crtc_state *old_crtc_state = 
> drm_atomic_get_old_crtc_state(state,
> +                                                                           
> crtc);
>       struct drm_crtc_state *crtc_state = drm_atomic_get_new_crtc_state(state,
>                                                                         crtc);
>       struct nouveau_drm *drm = nouveau_drm(crtc->dev);
>       struct nv50_head *head = nv50_head(crtc);
> -     struct nv50_head_atom *armh = nv50_head_atom(crtc->state);
> +     struct nv50_head_atom *armh = nv50_head_atom(old_crtc_state);
>       struct nv50_head_atom *asyh = nv50_head_atom(crtc_state);
>       struct nouveau_conn_atom *asyc = NULL;
>       struct drm_connector_state *conns;
> -- 
> 2.28.0

-- 
Ville Syrjälä
Intel
_______________________________________________
dri-devel mailing list
dri-devel@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/dri-devel

Reply via email to