aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/i915/intel_display.c
diff options
context:
space:
mode:
authorDaniel Vetter <daniel.vetter@ffwll.ch>2013-07-06 06:52:05 -0400
committerDaniel Vetter <daniel.vetter@ffwll.ch>2013-07-08 16:04:37 -0400
commit4a33e48d0e121953342194b45d33dc752353d62b (patch)
treeafa5f26b06ca0cba742431ca68a987c3af211374 /drivers/gpu/drm/i915/intel_display.c
parentc6cfb325677ea6305fb19acf3a4d14ea267f923e (diff)
drm/i915: fix dvo DPLL regression
I've missed that intel_dvo_mode_set changes the dpll configuration. Hence when I've reworked the sequence to only enable the dpll in the crtc_enable callback in commit 66e3d5c09940d08d94b03e65b420fadaa7484318 Author: Daniel Vetter <daniel.vetter@ffwll.ch> Date: Sun Jun 16 21:24:16 2013 +0200 drm/i915: move i9xx dpll enabling into crtc enable function that special DVO bit was lost. Some BSpec reading confirms that it's only needed for DVO encoders. Section 1.5.4, "DPLL A Control Register" for bit 30: "2X Clock Enable. When driving In non-gang DVO modes such as a connected flat panel or TV, a 2X" version of the clock is needed. When not using the 2X output it should be disabled. This bit cannot be set when driving the integrated LVDS port on devices such as Montara-GM." Fix this regression up. Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=66516 Cc: Chris Wilson <chris@chris-wilson.co.uk> Reported-by: Chris Wilson <chris@chris-wilson.co.uk> Reviewed-by: Chris Wilson <chris@chris-wilson.co.uk> Partially-tested-by: Chris Wilson <chris@chris-wilson.co.uk> Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Diffstat (limited to 'drivers/gpu/drm/i915/intel_display.c')
-rw-r--r--drivers/gpu/drm/i915/intel_display.c11
1 files changed, 7 insertions, 4 deletions
diff --git a/drivers/gpu/drm/i915/intel_display.c b/drivers/gpu/drm/i915/intel_display.c
index a45bb92f35ad..41efd3519e35 100644
--- a/drivers/gpu/drm/i915/intel_display.c
+++ b/drivers/gpu/drm/i915/intel_display.c
@@ -4544,10 +4544,10 @@ static void i9xx_update_pll(struct intel_crtc *crtc,
4544 } 4544 }
4545 4545
4546 if (is_sdvo) 4546 if (is_sdvo)
4547 dpll |= DPLL_DVO_HIGH_SPEED; 4547 dpll |= DPLL_SDVO_HIGH_SPEED;
4548 4548
4549 if (intel_pipe_has_type(&crtc->base, INTEL_OUTPUT_DISPLAYPORT)) 4549 if (intel_pipe_has_type(&crtc->base, INTEL_OUTPUT_DISPLAYPORT))
4550 dpll |= DPLL_DVO_HIGH_SPEED; 4550 dpll |= DPLL_SDVO_HIGH_SPEED;
4551 4551
4552 /* compute bitmask from p1 value */ 4552 /* compute bitmask from p1 value */
4553 if (IS_PINEVIEW(dev)) 4553 if (IS_PINEVIEW(dev))
@@ -4619,6 +4619,9 @@ static void i8xx_update_pll(struct intel_crtc *crtc,
4619 dpll |= PLL_P2_DIVIDE_BY_4; 4619 dpll |= PLL_P2_DIVIDE_BY_4;
4620 } 4620 }
4621 4621
4622 if (intel_pipe_has_type(&crtc->base, INTEL_OUTPUT_DVO))
4623 dpll |= DPLL_DVO_2X_MODE;
4624
4622 if (intel_pipe_has_type(&crtc->base, INTEL_OUTPUT_LVDS) && 4625 if (intel_pipe_has_type(&crtc->base, INTEL_OUTPUT_LVDS) &&
4623 intel_panel_use_ssc(dev_priv) && num_connectors < 2) 4626 intel_panel_use_ssc(dev_priv) && num_connectors < 2)
4624 dpll |= PLLB_REF_INPUT_SPREADSPECTRUMIN; 4627 dpll |= PLLB_REF_INPUT_SPREADSPECTRUMIN;
@@ -5650,9 +5653,9 @@ static uint32_t ironlake_compute_dpll(struct intel_crtc *intel_crtc,
5650 << PLL_REF_SDVO_HDMI_MULTIPLIER_SHIFT; 5653 << PLL_REF_SDVO_HDMI_MULTIPLIER_SHIFT;
5651 5654
5652 if (is_sdvo) 5655 if (is_sdvo)
5653 dpll |= DPLL_DVO_HIGH_SPEED; 5656 dpll |= DPLL_SDVO_HIGH_SPEED;
5654 if (intel_crtc->config.has_dp_encoder) 5657 if (intel_crtc->config.has_dp_encoder)
5655 dpll |= DPLL_DVO_HIGH_SPEED; 5658 dpll |= DPLL_SDVO_HIGH_SPEED;
5656 5659
5657 /* compute bitmask from p1 value */ 5660 /* compute bitmask from p1 value */
5658 dpll |= (1 << (intel_crtc->config.dpll.p1 - 1)) << DPLL_FPA01_P1_POST_DIV_SHIFT; 5661 dpll |= (1 << (intel_crtc->config.dpll.p1 - 1)) << DPLL_FPA01_P1_POST_DIV_SHIFT;