[PATCH 6/6] drm/msm/mdp5: Don't use async plane update path if plane visibility changes
Gustavo Padovan
gustavo at padovan.org
Wed Nov 1 11:26:09 UTC 2017
Hi Archit,
2017-10-27 Archit Taneja <architt at codeaurora.org>:
> When a plane moves out of bounds (i.e, outside the crtc clip region), the
> plane state's "visible" parameter changes to false. When this happens, we
> (a) release the hwpipe resources away from it, and
> (b) unstage the corresponding hwpipe(s) from the Layer Mixers in the CRTC.
>
> (a) requires use to acquire the global atomic state and assign a new
> hwpipe. (b) requires us to re-configure the Layer Mixer, which is done in
> the CRTC. We don't want to do these things in the async plane update path,
> so return an error if the new state's "visible" isn't the same as the
> current state's "visible".
>
> Cc: Gustavo Padovan <gustavo.padovan at collabora.com>
> Signed-off-by: Archit Taneja <architt at codeaurora.org>
> ---
> drivers/gpu/drm/msm/mdp/mdp5/mdp5_plane.c | 25 +++++++++++++++++++++++++
> 1 file changed, 25 insertions(+)
>
> diff --git a/drivers/gpu/drm/msm/mdp/mdp5/mdp5_plane.c b/drivers/gpu/drm/msm/mdp/mdp5/mdp5_plane.c
> index f1cf367e853d..be50445f9901 100644
> --- a/drivers/gpu/drm/msm/mdp/mdp5/mdp5_plane.c
> +++ b/drivers/gpu/drm/msm/mdp/mdp5/mdp5_plane.c
> @@ -470,6 +470,9 @@ static int mdp5_plane_atomic_async_check(struct drm_plane *plane,
> {
> struct mdp5_plane_state *mdp5_state = to_mdp5_plane_state(state);
> struct drm_crtc_state *crtc_state;
> + struct drm_rect clip;
> + int min_scale, max_scale;
> + int ret;
>
> crtc_state = drm_atomic_get_existing_crtc_state(state->state,
> state->crtc);
> @@ -495,6 +498,28 @@ static int mdp5_plane_atomic_async_check(struct drm_plane *plane,
> plane->state->fb != state->fb)
> return -EINVAL;
>
> + clip.x1 = 0;
> + clip.y1 = 0;
> + clip.x2 = crtc_state->adjusted_mode.hdisplay;
> + clip.y2 = crtc_state->adjusted_mode.vdisplay;
> + min_scale = FRAC_16_16(1, 8);
> + max_scale = FRAC_16_16(8, 1);
> +
> + ret = drm_plane_helper_check_state(state, &clip, min_scale,
> + max_scale, true, true);
> + if (ret)
> + return ret;
> +
> + /*
> + * if the visibility of the plane changes (i.e, if the cursor is
> + * clipped out completely, we can't take the async path because
> + * we need to stage/unstage the plane from the Layer Mixer(s). We
> + * also assign/unassign the hwpipe(s) tied to the plane. We avoid
> + * taking the fast path for both these reasons.
> + */
> + if (state->visible != plane->state->visible)
> + return -EINVAL;
> +
> return 0;
> }
Reviewed-by: Gustavo Padovan <gustavo.padovan at collabora.com>
Gustavo
More information about the dri-devel
mailing list