diff options
author | Daniel Vetter <daniel.vetter@ffwll.ch> | 2013-07-06 06:52:05 -0400 |
---|---|---|
committer | Daniel Vetter <daniel.vetter@ffwll.ch> | 2013-07-08 16:04:37 -0400 |
commit | 4a33e48d0e121953342194b45d33dc752353d62b (patch) | |
tree | afa5f26b06ca0cba742431ca68a987c3af211374 /drivers/gpu/drm/i915/intel_display.c | |
parent | c6cfb325677ea6305fb19acf3a4d14ea267f923e (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.c | 11 |
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; |