[PATCH] drm/amd/display: add basic atomic check for cursor plane

Kazlauskas, Nicholas nicholas.kazlauskas at amd.com
Mon Mar 30 12:59:53 UTC 2020


On 2020-03-30 5:23 a.m., Simon Ser wrote:
> This patch adds a basic cursor check when an atomic test-only commit is
> performed. The position and size of the cursor plane is checked.
> 
> This should fix user-space relying on atomic checks to assign buffers to
> planes.
> 
> Signed-off-by: Simon Ser <contact at emersion.fr>
> Reported-by: Roman Gilg <subdiff at gmail.com>
> References: https://github.com/emersion/libliftoff/issues/46
> Cc: Alex Deucher <alexander.deucher at amd.com>
> Cc: Harry Wentland <hwentlan at amd.com>
> ---
>   .../gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c | 26 +++++++++++++++++--
>   1 file changed, 24 insertions(+), 2 deletions(-)
> 
> diff --git a/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c b/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c
> index f6b0b9a121fd..e1b084318ad6 100644
> --- a/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c
> +++ b/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c
> @@ -7843,6 +7843,7 @@ static int dm_update_plane_state(struct dc *dc,
>   	struct drm_crtc_state *old_crtc_state, *new_crtc_state;
>   	struct dm_crtc_state *dm_new_crtc_state, *dm_old_crtc_state;
>   	struct dm_plane_state *dm_new_plane_state, *dm_old_plane_state;
> +	struct amdgpu_crtc *new_acrtc;
>   	bool needs_reset;
>   	int ret = 0;
> 
> @@ -7852,9 +7853,30 @@ static int dm_update_plane_state(struct dc *dc,
>   	dm_new_plane_state = to_dm_plane_state(new_plane_state);
>   	dm_old_plane_state = to_dm_plane_state(old_plane_state);
> 
> -	/*TODO Implement atomic check for cursor plane */
> -	if (plane->type == DRM_PLANE_TYPE_CURSOR)
> +	/*TODO Implement better atomic check for cursor plane */
> +	if (plane->type == DRM_PLANE_TYPE_CURSOR) {
> +		if (!enable || !new_plane_crtc ||
> +			drm_atomic_plane_disabling(plane->state, new_plane_state))
> +			return 0;
> +
> +		new_acrtc = to_amdgpu_crtc(new_plane_crtc);
> +
> +		if ((new_plane_state->crtc_w > new_acrtc->max_cursor_width) ||
> +			(new_plane_state->crtc_h > new_acrtc->max_cursor_height)) {
> +			DRM_DEBUG_ATOMIC("Bad cursor size %d x %d\n",
> +							 new_plane_state->crtc_w, new_plane_state->crtc_h);
> +			return -EINVAL;
> +		}
> +
> +		if (new_plane_state->crtc_x <= -new_acrtc->max_cursor_width ||
> +			new_plane_state->crtc_y <= -new_acrtc->max_cursor_height) {
> +			DRM_DEBUG_ATOMIC("Bad cursor position %d, %d\n",
> +							 new_plane_state->crtc_x, new_plane_state->crtc_y);
> +			return -EINVAL;

We've been doing these checks for position before but I don't think we 
really need them. DC should be disabling the cursor when we ask for a 
position completely off the screen.

I think that's better than rejecting the commit entirely at least.

Nicholas Kazlauskas

> +		}
> +
>   		return 0;
> +	}
> 
>   	needs_reset = should_reset_plane(state, plane, old_plane_state,
>   					 new_plane_state);
> --
> 2.26.0
> 
> 
> _______________________________________________
> amd-gfx mailing list
> amd-gfx at lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/amd-gfx
> 



More information about the amd-gfx mailing list