On 07/31/2017 04:29 PM, Russell King wrote:
> The video setup path aways sets the clock disable register to a specific
> value, which has the effect of disabling the CEC engine.  When we add the
> CEC driver, this becomes a problem.
> 
> Fix this by only setting/clearing the bits that the video path needs to.
> 
> Reviewed-by: Jose Abreu <joab...@synopsys.com>
> Signed-off-by: Russell King <rmk+ker...@armlinux.org.uk>

Acked-by: Hans Verkuil <hans.verk...@cisco.com>

Regards,

        Hans

> ---
>  drivers/gpu/drm/bridge/synopsys/dw-hdmi.c | 29 ++++++++++++++++++-----------
>  1 file changed, 18 insertions(+), 11 deletions(-)
> 
> diff --git a/drivers/gpu/drm/bridge/synopsys/dw-hdmi.c 
> b/drivers/gpu/drm/bridge/synopsys/dw-hdmi.c
> index 82e55ee8e4fa..b08cc0c95590 100644
> --- a/drivers/gpu/drm/bridge/synopsys/dw-hdmi.c
> +++ b/drivers/gpu/drm/bridge/synopsys/dw-hdmi.c
> @@ -166,6 +166,7 @@ struct dw_hdmi {
>       bool bridge_is_on;              /* indicates the bridge is on */
>       bool rxsense;                   /* rxsense state */
>       u8 phy_mask;                    /* desired phy int mask settings */
> +     u8 mc_clkdis;                   /* clock disable register */
>  
>       spinlock_t audio_lock;
>       struct mutex audio_mutex;
> @@ -551,8 +552,11 @@ EXPORT_SYMBOL_GPL(dw_hdmi_set_sample_rate);
>  
>  static void hdmi_enable_audio_clk(struct dw_hdmi *hdmi, bool enable)
>  {
> -     hdmi_modb(hdmi, enable ? 0 : HDMI_MC_CLKDIS_AUDCLK_DISABLE,
> -               HDMI_MC_CLKDIS_AUDCLK_DISABLE, HDMI_MC_CLKDIS);
> +     if (enable)
> +             hdmi->mc_clkdis &= ~HDMI_MC_CLKDIS_AUDCLK_DISABLE;
> +     else
> +             hdmi->mc_clkdis |= HDMI_MC_CLKDIS_AUDCLK_DISABLE;
> +     hdmi_writeb(hdmi, hdmi->mc_clkdis, HDMI_MC_CLKDIS);
>  }
>  
>  static void dw_hdmi_ahb_audio_enable(struct dw_hdmi *hdmi)
> @@ -1574,8 +1578,6 @@ static void hdmi_av_composer(struct dw_hdmi *hdmi,
>  /* HDMI Initialization Step B.4 */
>  static void dw_hdmi_enable_video_path(struct dw_hdmi *hdmi)
>  {
> -     u8 clkdis;
> -
>       /* control period minimum duration */
>       hdmi_writeb(hdmi, 12, HDMI_FC_CTRLDUR);
>       hdmi_writeb(hdmi, 32, HDMI_FC_EXCTRLDUR);
> @@ -1587,17 +1589,21 @@ static void dw_hdmi_enable_video_path(struct dw_hdmi 
> *hdmi)
>       hdmi_writeb(hdmi, 0x21, HDMI_FC_CH2PREAM);
>  
>       /* Enable pixel clock and tmds data path */
> -     clkdis = 0x7F;
> -     clkdis &= ~HDMI_MC_CLKDIS_PIXELCLK_DISABLE;
> -     hdmi_writeb(hdmi, clkdis, HDMI_MC_CLKDIS);
> +     hdmi->mc_clkdis |= HDMI_MC_CLKDIS_HDCPCLK_DISABLE |
> +                        HDMI_MC_CLKDIS_CSCCLK_DISABLE |
> +                        HDMI_MC_CLKDIS_AUDCLK_DISABLE |
> +                        HDMI_MC_CLKDIS_PREPCLK_DISABLE |
> +                        HDMI_MC_CLKDIS_TMDSCLK_DISABLE;
> +     hdmi->mc_clkdis &= ~HDMI_MC_CLKDIS_PIXELCLK_DISABLE;
> +     hdmi_writeb(hdmi, hdmi->mc_clkdis, HDMI_MC_CLKDIS);
>  
> -     clkdis &= ~HDMI_MC_CLKDIS_TMDSCLK_DISABLE;
> -     hdmi_writeb(hdmi, clkdis, HDMI_MC_CLKDIS);
> +     hdmi->mc_clkdis &= ~HDMI_MC_CLKDIS_TMDSCLK_DISABLE;
> +     hdmi_writeb(hdmi, hdmi->mc_clkdis, HDMI_MC_CLKDIS);
>  
>       /* Enable csc path */
>       if (is_color_space_conversion(hdmi)) {
> -             clkdis &= ~HDMI_MC_CLKDIS_CSCCLK_DISABLE;
> -             hdmi_writeb(hdmi, clkdis, HDMI_MC_CLKDIS);
> +             hdmi->mc_clkdis &= ~HDMI_MC_CLKDIS_CSCCLK_DISABLE;
> +             hdmi_writeb(hdmi, hdmi->mc_clkdis, HDMI_MC_CLKDIS);
>       }
>  
>       /* Enable color space conversion if needed */
> @@ -2272,6 +2278,7 @@ __dw_hdmi_probe(struct platform_device *pdev,
>       hdmi->disabled = true;
>       hdmi->rxsense = true;
>       hdmi->phy_mask = (u8)~(HDMI_PHY_HPD | HDMI_PHY_RX_SENSE);
> +     hdmi->mc_clkdis = 0x7f;
>  
>       mutex_init(&hdmi->mutex);
>       mutex_init(&hdmi->audio_mutex);
> 

_______________________________________________
dri-devel mailing list
dri-devel@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/dri-devel

Reply via email to