[PATCH v3 11/20] drm: omapdrm: Check DSS manager state in the enable/disable helpers

Laurent Pinchart laurent.pinchart at ideasonboard.com
Tue Dec 13 23:56:38 UTC 2016


Hi Tomi,

On Tuesday 13 Dec 2016 10:15:35 Tomi Valkeinen wrote:
> On 13/12/16 01:07, Laurent Pinchart wrote:
> > On Tuesday 20 Sep 2016 16:57:59 Tomi Valkeinen wrote:
> >> On 19/09/16 15:27, Laurent Pinchart wrote:
> >>> The omapdrm DSS manager enable/disable operations check the DSS manager
> >>> state to avoid double enabling/disabling. Move that code to the DSS
> >>> manager to decrease the dependency of the DRM layer to the DSS layer.
> >>> 
> >>> Signed-off-by: Laurent Pinchart <laurent.pinchart at ideasonboard.com>
> >>> ---
> >>>  drivers/gpu/drm/omapdrm/dss/dispc.c  | 1 -
> >>>  drivers/gpu/drm/omapdrm/dss/output.c | 6 ++++++
> >>>  drivers/gpu/drm/omapdrm/omap_crtc.c  | 3 ---
> >>>  3 files changed, 6 insertions(+), 4 deletions(-)
> >>> 
> >>> diff --git a/drivers/gpu/drm/omapdrm/dss/dispc.c
> >>> b/drivers/gpu/drm/omapdrm/dss/dispc.c index 535240fba671..ab150bf21dd8
> >>> 100644
> >>> --- a/drivers/gpu/drm/omapdrm/dss/dispc.c
> >>> +++ b/drivers/gpu/drm/omapdrm/dss/dispc.c
> >>> @@ -2911,7 +2911,6 @@ bool dispc_mgr_is_enabled(enum omap_channel
> >>> channel)
> >>>  {
> >>>  	return !!mgr_fld_read(channel, DISPC_MGR_FLD_ENABLE);
> >>>  }
> >>> -EXPORT_SYMBOL(dispc_mgr_is_enabled);
> >>> 
> >>>  void dispc_wb_enable(bool enable)
> >>>  {
> >>> diff --git a/drivers/gpu/drm/omapdrm/dss/output.c
> >>> b/drivers/gpu/drm/omapdrm/dss/output.c index 24f859488201..f0be621895fa
> >>> 100644
> >>> --- a/drivers/gpu/drm/omapdrm/dss/output.c
> >>> +++ b/drivers/gpu/drm/omapdrm/dss/output.c
> >>> @@ -217,12 +217,18 @@ EXPORT_SYMBOL(dss_mgr_set_lcd_config);
> >>>  int dss_mgr_enable(enum omap_channel channel)
> >>>  {
> >>> +	if (dispc_mgr_is_enabled(channel))
> >>> +		return 0;
> >>> +
> >>>  	return dss_mgr_ops->enable(channel);
> >>>  }
> 
> Looking at this again, I think this is not correct. The functions in
> output.c are just trampolines basically. They just pass the calls to
> omapdrm. Let's not add any logic there.

I can't wait to clean all this up and get rid of them :-)

> Also, the above could even cause a crash, as the HW is not necessarily
> enabled before the ->enable() is called.
> 
> >>>  EXPORT_SYMBOL(dss_mgr_enable);
> >>>  
> >>>  void dss_mgr_disable(enum omap_channel channel)
> >>>  {
> >>> +	if (!dispc_mgr_is_enabled(channel))
> >>> +		return;
> >>> +
> >>>  	dss_mgr_ops->disable(channel);
> >>>  }
> >>>  EXPORT_SYMBOL(dss_mgr_disable);
> >>> diff --git a/drivers/gpu/drm/omapdrm/omap_crtc.c
> >>> b/drivers/gpu/drm/omapdrm/omap_crtc.c index 4b7e16786e1e..a0c26592fc69
> >>> 100644
> >>> --- a/drivers/gpu/drm/omapdrm/omap_crtc.c
> >>> +++ b/drivers/gpu/drm/omapdrm/omap_crtc.c
> >>> @@ -141,9 +141,6 @@ static void omap_crtc_set_enabled(struct drm_crtc
> >>> *crtc, bool enable)
> >>>  		return;
> >>>  	}
> >>> 
> >>> -	if (dispc_mgr_is_enabled(channel) == enable)
> >>> -		return;
> >>> -
> >>>  	if (omap_crtc->channel == OMAP_DSS_CHANNEL_DIGIT) {
> >>>  		/*
> >>>  		 * Digit output produces some sync lost interrupts during the
> >> 
> >> With this change omap_crtc_set_enabled() will do extra work if the
> >> output is already enabled/disabled, and, if I'm not mistaken, will do
> >> omap_irq_wait() there which might lead to issues.
> > 
> > That's correct, but the DRM core nowadays should really guarantee that
> > CRTCs won't be enabled or disabled multiple times.
> 
> Ok. So we could probably add a dev_warn() there, as getting that state
> wrong might cause issues that are difficult to debug. It would be best
> to check the HW state, but if you want to remove the call to dispc, I
> guess just checking omap_crtc->enabled is good enough.

I'll do that. I don't like reading back the hardware state when it's supposed 
to match the software state. If there's a mismatch then there's a bug, and if 
they always match, it's pointless.

> The comment for omap_crtc_set_enabled talks about suspend/resume.
> Perhaps at some point it was called from suspend/resume, even for crtcs
> that were already disabled, which would explain the need for the check.

-- 
Regards,

Laurent Pinchart



More information about the dri-devel mailing list