[PATCH v4 10/22] drm: omapdrm: Let the DRM core skip plane commit on inactive CRTCs

Tomi Valkeinen tomi.valkeinen at ti.com
Wed Dec 14 10:43:54 UTC 2016


On 14/12/16 02:27, Laurent Pinchart wrote:
> The DRM core supports skipping plane update for inactive CRTCs for
> hardware that don't need it or can't cope with it. That's our case, and
> the driver already skips flushing planes on inactice CRTCs.
> 
> We can't remove the check from the driver, as active CRTCs are disabled
> at the hardware level when an atomic flush is performed if a mode set is
> pending. There's however no need to forward the plane commit calls to
> the driver, so use the DRM core infrastructure to skip them with a
> detailed comment to explain why the check must still be kept in the
> driver.
> 
> Signed-off-by: Laurent Pinchart <laurent.pinchart at ideasonboard.com>
> ---
> Changes since v3:
> 
> - Reworded commit message
> ---
>  drivers/gpu/drm/omapdrm/omap_crtc.c | 8 +++++++-
>  drivers/gpu/drm/omapdrm/omap_drv.c  | 3 ++-
>  2 files changed, 9 insertions(+), 2 deletions(-)
> 
> diff --git a/drivers/gpu/drm/omapdrm/omap_crtc.c b/drivers/gpu/drm/omapdrm/omap_crtc.c
> index 42c3b44f9689..2832dbffd873 100644
> --- a/drivers/gpu/drm/omapdrm/omap_crtc.c
> +++ b/drivers/gpu/drm/omapdrm/omap_crtc.c
> @@ -414,7 +414,13 @@ static void omap_crtc_atomic_flush(struct drm_crtc *crtc,
>  		dispc_mgr_set_gamma(omap_crtc->channel, lut, length);
>  	}
>  
> -	/* Only flush the CRTC if it is currently enabled. */
> +	/*
> +	 * Only flush the CRTC if it is currently enabled. CRTCs that require a
> +	 * mode set are disabled prior plane updates and enabled afterwards.
> +	 * They are thus not active (regardless of what their CRTC core state
> +	 * reports) and the DRM core could thus call this function even though
> +	 * the CRTC is currently disabled. Do nothing in that case.
> +	 */
>  	if (!omap_crtc->enabled)
>  		return;
>  
> diff --git a/drivers/gpu/drm/omapdrm/omap_drv.c b/drivers/gpu/drm/omapdrm/omap_drv.c
> index 6faba13c8e41..0a2d461d62cf 100644
> --- a/drivers/gpu/drm/omapdrm/omap_drv.c
> +++ b/drivers/gpu/drm/omapdrm/omap_drv.c
> @@ -96,7 +96,8 @@ static void omap_atomic_complete(struct omap_atomic_state_commit *commit)
>  	dispc_runtime_get();
>  
>  	drm_atomic_helper_commit_modeset_disables(dev, old_state);
> -	drm_atomic_helper_commit_planes(dev, old_state, 0);
> +	drm_atomic_helper_commit_planes(dev, old_state,
> +					DRM_PLANE_COMMIT_ACTIVE_ONLY);
>  	drm_atomic_helper_commit_modeset_enables(dev, old_state);

Just to make sure. "ACTIVE" in this context means a crtc that's already
enabled, or will be enabled at the
drm_atomic_helper_commit_modeset_enables() call?

If so:

Reviewed-by: Tomi Valkeinen <tomi.valkeinen at ti.com>

 Tomi

-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 819 bytes
Desc: OpenPGP digital signature
URL: <https://lists.freedesktop.org/archives/dri-devel/attachments/20161214/c97285b6/attachment.sig>


More information about the dri-devel mailing list