[Intel-gfx] [PATCH 59/71] drm/i915/chv: Fix CHV PLL state tracking
Mika Kuoppala
mika.kuoppala at linux.intel.com
Fri Apr 25 14:01:16 CEST 2014
ville.syrjala at linux.intel.com writes:
> From: Ville Syrjälä <ville.syrjala at linux.intel.com>
>
> Setup the pipe config dpll state correctly for CHV. Also add
> a assert_pipe_disabled() to chv_disable_pll(), and program the
> DPLL_MD registers in chv_enable_pll().
>
> Signed-off-by: Ville Syrjälä <ville.syrjala at linux.intel.com>
Reviewed-by: Mika Kuoppala <mika.kuoppala at intel.com>
> ---
> drivers/gpu/drm/i915/intel_display.c | 41 +++++++++++++++++++++++-------------
> 1 file changed, 26 insertions(+), 15 deletions(-)
>
> diff --git a/drivers/gpu/drm/i915/intel_display.c b/drivers/gpu/drm/i915/intel_display.c
> index bf64e9d..d531c9d 100644
> --- a/drivers/gpu/drm/i915/intel_display.c
> +++ b/drivers/gpu/drm/i915/intel_display.c
> @@ -1559,7 +1559,6 @@ static void chv_enable_pll(struct intel_crtc *crtc)
> struct drm_i915_private *dev_priv = dev->dev_private;
> int pipe = crtc->pipe;
> enum dpio_channel port = vlv_pipe_to_channel(pipe);
> - int dpll = DPLL(crtc->pipe);
> u32 tmp;
>
> assert_pipe_disabled(dev_priv, crtc->pipe);
> @@ -1579,20 +1578,21 @@ static void chv_enable_pll(struct intel_crtc *crtc)
> udelay(1);
>
> /* Enable PLL */
> - tmp = I915_READ(dpll);
> - tmp |= DPLL_VCO_ENABLE;
> - I915_WRITE(dpll, tmp);
> + I915_WRITE(DPLL(pipe), crtc->config.dpll_hw_state.dpll);
>
> /* Check PLL is locked */
> - if (wait_for(((I915_READ(dpll) & DPLL_LOCK_VLV) == DPLL_LOCK_VLV), 1))
> + if (wait_for(((I915_READ(DPLL(pipe)) & DPLL_LOCK_VLV) == DPLL_LOCK_VLV), 1))
> DRM_ERROR("PLL %d failed to lock\n", pipe);
>
> + /* not sure when this should be written */
> + I915_WRITE(DPLL_MD(pipe), crtc->config.dpll_hw_state.dpll_md);
> + POSTING_READ(DPLL_MD(pipe));
> +
> /* Deassert soft data lane reset*/
> tmp = vlv_dpio_read(dev_priv, pipe, VLV_PCS_DW0(port));
> tmp |= (DPIO_PCS_TX_LANE2_RESET | DPIO_PCS_TX_LANE1_RESET);
> vlv_dpio_write(dev_priv, pipe, VLV_PCS_DW0(port), tmp);
>
> -
> mutex_unlock(&dev_priv->dpio_lock);
> }
>
> @@ -1684,14 +1684,17 @@ static void vlv_disable_pll(struct drm_i915_private *dev_priv, enum pipe pipe)
>
> static void chv_disable_pll(struct drm_i915_private *dev_priv, enum pipe pipe)
> {
> - int dpll = DPLL(pipe);
> u32 val;
>
> - /* Set PLL en = 0 */
> - val = I915_READ(dpll);
> - val &= ~DPLL_VCO_ENABLE;
> - I915_WRITE(dpll, val);
> + /* Make sure the pipe isn't still relying on us */
> + assert_pipe_disabled(dev_priv, pipe);
>
> + /* Set PLL en = 0 */
> + val = DPLL_SSC_REF_CLOCK_CHV;
> + if (pipe != PIPE_A)
> + val |= DPLL_INTEGRATED_CRI_CLK_VLV;
> + I915_WRITE(DPLL(pipe), val);
> + POSTING_READ(DPLL(pipe));
> }
>
> void vlv_wait_port_ready(struct drm_i915_private *dev_priv,
> @@ -5448,7 +5451,14 @@ static void chv_update_pll(struct intel_crtc *crtc)
> u32 bestn, bestm1, bestm2, bestp1, bestp2, bestm2_frac;
> int refclk;
>
> - mutex_lock(&dev_priv->dpio_lock);
> + crtc->config.dpll_hw_state.dpll = DPLL_SSC_REF_CLOCK_CHV |
> + DPLL_REFA_CLK_ENABLE_VLV | DPLL_VGA_MODE_DIS |
> + DPLL_VCO_ENABLE;
> + if (pipe != PIPE_A)
> + crtc->config.dpll_hw_state.dpll |= DPLL_INTEGRATED_CRI_CLK_VLV;
> +
> + crtc->config.dpll_hw_state.dpll_md =
> + (crtc->config.pixel_multiplier - 1) << DPLL_MD_UDI_MULTIPLIER_SHIFT;
>
> bestn = crtc->config.dpll.n;
> bestm2_frac = crtc->config.dpll.m2 & 0x3fffff;
> @@ -5460,9 +5470,10 @@ static void chv_update_pll(struct intel_crtc *crtc)
> /*
> * Enable Refclk and SSC
> */
> - val = I915_READ(dpll_reg);
> - val |= (DPLL_SSC_REF_CLOCK_CHV | DPLL_REFA_CLK_ENABLE_VLV);
> - I915_WRITE(dpll_reg, val);
> + I915_WRITE(dpll_reg,
> + crtc->config.dpll_hw_state.dpll & ~DPLL_VCO_ENABLE);
> +
> + mutex_lock(&dev_priv->dpio_lock);
>
> /* Propagate soft reset to data lane reset */
> val = vlv_dpio_read(dev_priv, pipe, VLV_PCS_DW0(port));
> --
> 1.8.3.2
>
> _______________________________________________
> Intel-gfx mailing list
> Intel-gfx at lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/intel-gfx
More information about the Intel-gfx
mailing list