Commit d925c59a authored by Daniel Vetter's avatar Daniel Vetter

drm/i915: conditionally disable pch resources in ilk_crtc_disable

Simlar to how disable already works on haswell. This is possible
since we now carefully track the pch state in the pipe config.
Reviewed-by: default avatarVille Syrjälä <ville.syrjala@linux.intel.com>
Signed-off-by: default avatarDaniel Vetter <daniel.vetter@ffwll.ch>
parent cdbd2316
...@@ -3436,7 +3436,9 @@ static void ironlake_crtc_disable(struct drm_crtc *crtc) ...@@ -3436,7 +3436,9 @@ static void ironlake_crtc_disable(struct drm_crtc *crtc)
intel_disable_planes(crtc); intel_disable_planes(crtc);
intel_disable_plane(dev_priv, plane, pipe); intel_disable_plane(dev_priv, plane, pipe);
intel_set_pch_fifo_underrun_reporting(dev, pipe, false); if (intel_crtc->config.has_pch_encoder)
intel_set_pch_fifo_underrun_reporting(dev, pipe, false);
intel_disable_pipe(dev_priv, pipe); intel_disable_pipe(dev_priv, pipe);
ironlake_pfit_disable(intel_crtc); ironlake_pfit_disable(intel_crtc);
...@@ -3445,42 +3447,45 @@ static void ironlake_crtc_disable(struct drm_crtc *crtc) ...@@ -3445,42 +3447,45 @@ static void ironlake_crtc_disable(struct drm_crtc *crtc)
if (encoder->post_disable) if (encoder->post_disable)
encoder->post_disable(encoder); encoder->post_disable(encoder);
ironlake_fdi_disable(crtc); if (intel_crtc->config.has_pch_encoder) {
ironlake_fdi_disable(crtc);
ironlake_disable_pch_transcoder(dev_priv, pipe); ironlake_disable_pch_transcoder(dev_priv, pipe);
intel_set_pch_fifo_underrun_reporting(dev, pipe, true); intel_set_pch_fifo_underrun_reporting(dev, pipe, true);
if (HAS_PCH_CPT(dev)) { if (HAS_PCH_CPT(dev)) {
/* disable TRANS_DP_CTL */ /* disable TRANS_DP_CTL */
reg = TRANS_DP_CTL(pipe); reg = TRANS_DP_CTL(pipe);
temp = I915_READ(reg); temp = I915_READ(reg);
temp &= ~(TRANS_DP_OUTPUT_ENABLE | TRANS_DP_PORT_SEL_MASK); temp &= ~(TRANS_DP_OUTPUT_ENABLE |
temp |= TRANS_DP_PORT_SEL_NONE; TRANS_DP_PORT_SEL_MASK);
I915_WRITE(reg, temp); temp |= TRANS_DP_PORT_SEL_NONE;
I915_WRITE(reg, temp);
/* disable DPLL_SEL */
temp = I915_READ(PCH_DPLL_SEL); /* disable DPLL_SEL */
switch (pipe) { temp = I915_READ(PCH_DPLL_SEL);
case 0: switch (pipe) {
temp &= ~(TRANSA_DPLL_ENABLE | TRANSA_DPLLB_SEL); case 0:
break; temp &= ~(TRANSA_DPLL_ENABLE | TRANSA_DPLLB_SEL);
case 1: break;
temp &= ~(TRANSB_DPLL_ENABLE | TRANSB_DPLLB_SEL); case 1:
break; temp &= ~(TRANSB_DPLL_ENABLE | TRANSB_DPLLB_SEL);
case 2: break;
/* C shares PLL A or B */ case 2:
temp &= ~(TRANSC_DPLL_ENABLE | TRANSC_DPLLB_SEL); /* C shares PLL A or B */
break; temp &= ~(TRANSC_DPLL_ENABLE | TRANSC_DPLLB_SEL);
default: break;
BUG(); /* wtf */ default:
BUG(); /* wtf */
}
I915_WRITE(PCH_DPLL_SEL, temp);
} }
I915_WRITE(PCH_DPLL_SEL, temp);
}
/* disable PCH DPLL */ /* disable PCH DPLL */
intel_disable_pch_pll(intel_crtc); intel_disable_pch_pll(intel_crtc);
ironlake_fdi_pll_disable(intel_crtc); ironlake_fdi_pll_disable(intel_crtc);
}
intel_crtc->active = false; intel_crtc->active = false;
intel_update_watermarks(dev); intel_update_watermarks(dev);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment