diff options
-rw-r--r-- | drivers/gpu/drm/i915/intel_display.c | 119 |
1 files changed, 36 insertions, 83 deletions
diff --git a/drivers/gpu/drm/i915/intel_display.c b/drivers/gpu/drm/i915/intel_display.c index b41c87ac561f..832210bac9b4 100644 --- a/drivers/gpu/drm/i915/intel_display.c +++ b/drivers/gpu/drm/i915/intel_display.c | |||
@@ -4924,7 +4924,7 @@ static int ironlake_crtc_mode_set(struct drm_crtc *crtc, | |||
4924 | int refclk, num_connectors = 0; | 4924 | int refclk, num_connectors = 0; |
4925 | intel_clock_t clock, reduced_clock; | 4925 | intel_clock_t clock, reduced_clock; |
4926 | u32 dpll, fp = 0, fp2 = 0, dspcntr, pipeconf; | 4926 | u32 dpll, fp = 0, fp2 = 0, dspcntr, pipeconf; |
4927 | bool ok, has_reduced_clock = false, is_sdvo = false, is_dvo = false; | 4927 | bool ok, has_reduced_clock = false, is_sdvo = false; |
4928 | bool is_crt = false, is_lvds = false, is_tv = false, is_dp = false; | 4928 | bool is_crt = false, is_lvds = false, is_tv = false, is_dp = false; |
4929 | struct intel_encoder *has_edp_encoder = NULL; | 4929 | struct intel_encoder *has_edp_encoder = NULL; |
4930 | struct drm_mode_config *mode_config = &dev->mode_config; | 4930 | struct drm_mode_config *mode_config = &dev->mode_config; |
@@ -4950,9 +4950,6 @@ static int ironlake_crtc_mode_set(struct drm_crtc *crtc, | |||
4950 | if (encoder->needs_tv_clock) | 4950 | if (encoder->needs_tv_clock) |
4951 | is_tv = true; | 4951 | is_tv = true; |
4952 | break; | 4952 | break; |
4953 | case INTEL_OUTPUT_DVO: | ||
4954 | is_dvo = true; | ||
4955 | break; | ||
4956 | case INTEL_OUTPUT_TVOUT: | 4953 | case INTEL_OUTPUT_TVOUT: |
4957 | is_tv = true; | 4954 | is_tv = true; |
4958 | break; | 4955 | break; |
@@ -4974,13 +4971,11 @@ static int ironlake_crtc_mode_set(struct drm_crtc *crtc, | |||
4974 | refclk = dev_priv->lvds_ssc_freq * 1000; | 4971 | refclk = dev_priv->lvds_ssc_freq * 1000; |
4975 | DRM_DEBUG_KMS("using SSC reference clock of %d MHz\n", | 4972 | DRM_DEBUG_KMS("using SSC reference clock of %d MHz\n", |
4976 | refclk / 1000); | 4973 | refclk / 1000); |
4977 | } else if (!IS_GEN2(dev)) { | 4974 | } else { |
4978 | refclk = 96000; | 4975 | refclk = 96000; |
4979 | if (!has_edp_encoder || | 4976 | if (!has_edp_encoder || |
4980 | intel_encoder_is_pch_edp(&has_edp_encoder->base)) | 4977 | intel_encoder_is_pch_edp(&has_edp_encoder->base)) |
4981 | refclk = 120000; /* 120Mhz refclk */ | 4978 | refclk = 120000; /* 120Mhz refclk */ |
4982 | } else { | ||
4983 | refclk = 48000; | ||
4984 | } | 4979 | } |
4985 | 4980 | ||
4986 | /* | 4981 | /* |
@@ -5169,17 +5164,10 @@ static int ironlake_crtc_mode_set(struct drm_crtc *crtc, | |||
5169 | udelay(200); | 5164 | udelay(200); |
5170 | } | 5165 | } |
5171 | 5166 | ||
5172 | if (IS_PINEVIEW(dev)) { | 5167 | fp = clock.n << 16 | clock.m1 << 8 | clock.m2; |
5173 | fp = (1 << clock.n) << 16 | clock.m1 << 8 | clock.m2; | 5168 | if (has_reduced_clock) |
5174 | if (has_reduced_clock) | 5169 | fp2 = reduced_clock.n << 16 | reduced_clock.m1 << 8 | |
5175 | fp2 = (1 << reduced_clock.n) << 16 | | 5170 | reduced_clock.m2; |
5176 | reduced_clock.m1 << 8 | reduced_clock.m2; | ||
5177 | } else { | ||
5178 | fp = clock.n << 16 | clock.m1 << 8 | clock.m2; | ||
5179 | if (has_reduced_clock) | ||
5180 | fp2 = reduced_clock.n << 16 | reduced_clock.m1 << 8 | | ||
5181 | reduced_clock.m2; | ||
5182 | } | ||
5183 | 5171 | ||
5184 | /* Enable autotuning of the PLL clock (if permissible) */ | 5172 | /* Enable autotuning of the PLL clock (if permissible) */ |
5185 | factor = 21; | 5173 | factor = 21; |
@@ -5196,59 +5184,38 @@ static int ironlake_crtc_mode_set(struct drm_crtc *crtc, | |||
5196 | 5184 | ||
5197 | dpll = 0; | 5185 | dpll = 0; |
5198 | 5186 | ||
5199 | if (!IS_GEN2(dev)) { | 5187 | if (is_lvds) |
5200 | if (is_lvds) | 5188 | dpll |= DPLLB_MODE_LVDS; |
5201 | dpll |= DPLLB_MODE_LVDS; | 5189 | else |
5202 | else | 5190 | dpll |= DPLLB_MODE_DAC_SERIAL; |
5203 | dpll |= DPLLB_MODE_DAC_SERIAL; | 5191 | if (is_sdvo) { |
5204 | if (is_sdvo) { | 5192 | int pixel_multiplier = intel_mode_get_pixel_multiplier(adjusted_mode); |
5205 | int pixel_multiplier = intel_mode_get_pixel_multiplier(adjusted_mode); | 5193 | if (pixel_multiplier > 1) { |
5206 | if (pixel_multiplier > 1) { | 5194 | dpll |= (pixel_multiplier - 1) << PLL_REF_SDVO_HDMI_MULTIPLIER_SHIFT; |
5207 | if (IS_I945G(dev) || IS_I945GM(dev) || IS_G33(dev)) | ||
5208 | dpll |= (pixel_multiplier - 1) << SDVO_MULTIPLIER_SHIFT_HIRES; | ||
5209 | else | ||
5210 | dpll |= (pixel_multiplier - 1) << PLL_REF_SDVO_HDMI_MULTIPLIER_SHIFT; | ||
5211 | } | ||
5212 | dpll |= DPLL_DVO_HIGH_SPEED; | ||
5213 | } | 5195 | } |
5214 | if (is_dp || intel_encoder_is_pch_edp(&has_edp_encoder->base)) | 5196 | dpll |= DPLL_DVO_HIGH_SPEED; |
5215 | dpll |= DPLL_DVO_HIGH_SPEED; | 5197 | } |
5198 | if (is_dp || intel_encoder_is_pch_edp(&has_edp_encoder->base)) | ||
5199 | dpll |= DPLL_DVO_HIGH_SPEED; | ||
5216 | 5200 | ||
5217 | /* compute bitmask from p1 value */ | 5201 | /* compute bitmask from p1 value */ |
5218 | if (IS_PINEVIEW(dev)) | 5202 | dpll |= (1 << (clock.p1 - 1)) << DPLL_FPA01_P1_POST_DIV_SHIFT; |
5219 | dpll |= (1 << (clock.p1 - 1)) << DPLL_FPA01_P1_POST_DIV_SHIFT_PINEVIEW; | 5203 | /* also FPA1 */ |
5220 | else { | 5204 | dpll |= (1 << (clock.p1 - 1)) << DPLL_FPA1_P1_POST_DIV_SHIFT; |
5221 | dpll |= (1 << (clock.p1 - 1)) << DPLL_FPA01_P1_POST_DIV_SHIFT; | 5205 | |
5222 | /* also FPA1 */ | 5206 | switch (clock.p2) { |
5223 | dpll |= (1 << (clock.p1 - 1)) << DPLL_FPA1_P1_POST_DIV_SHIFT; | 5207 | case 5: |
5224 | if (IS_G4X(dev) && has_reduced_clock) | 5208 | dpll |= DPLL_DAC_SERIAL_P2_CLOCK_DIV_5; |
5225 | dpll |= (1 << (reduced_clock.p1 - 1)) << DPLL_FPA1_P1_POST_DIV_SHIFT; | 5209 | break; |
5226 | } | 5210 | case 7: |
5227 | switch (clock.p2) { | 5211 | dpll |= DPLLB_LVDS_P2_CLOCK_DIV_7; |
5228 | case 5: | 5212 | break; |
5229 | dpll |= DPLL_DAC_SERIAL_P2_CLOCK_DIV_5; | 5213 | case 10: |
5230 | break; | 5214 | dpll |= DPLL_DAC_SERIAL_P2_CLOCK_DIV_10; |
5231 | case 7: | 5215 | break; |
5232 | dpll |= DPLLB_LVDS_P2_CLOCK_DIV_7; | 5216 | case 14: |
5233 | break; | 5217 | dpll |= DPLLB_LVDS_P2_CLOCK_DIV_14; |
5234 | case 10: | 5218 | break; |
5235 | dpll |= DPLL_DAC_SERIAL_P2_CLOCK_DIV_10; | ||
5236 | break; | ||
5237 | case 14: | ||
5238 | dpll |= DPLLB_LVDS_P2_CLOCK_DIV_14; | ||
5239 | break; | ||
5240 | } | ||
5241 | } else { | ||
5242 | if (is_lvds) { | ||
5243 | dpll |= (1 << (clock.p1 - 1)) << DPLL_FPA01_P1_POST_DIV_SHIFT; | ||
5244 | } else { | ||
5245 | if (clock.p1 == 2) | ||
5246 | dpll |= PLL_P1_DIVIDE_BY_TWO; | ||
5247 | else | ||
5248 | dpll |= (clock.p1 - 2) << DPLL_FPA01_P1_POST_DIV_SHIFT; | ||
5249 | if (clock.p2 == 4) | ||
5250 | dpll |= PLL_P2_DIVIDE_BY_4; | ||
5251 | } | ||
5252 | } | 5219 | } |
5253 | 5220 | ||
5254 | if (is_sdvo && is_tv) | 5221 | if (is_sdvo && is_tv) |
@@ -5268,20 +5235,6 @@ static int ironlake_crtc_mode_set(struct drm_crtc *crtc, | |||
5268 | /* Set up the display plane register */ | 5235 | /* Set up the display plane register */ |
5269 | dspcntr = DISPPLANE_GAMMA_ENABLE; | 5236 | dspcntr = DISPPLANE_GAMMA_ENABLE; |
5270 | 5237 | ||
5271 | if (pipe == 0 && INTEL_INFO(dev)->gen < 4) { | ||
5272 | /* Enable pixel doubling when the dot clock is > 90% of the (display) | ||
5273 | * core speed. | ||
5274 | * | ||
5275 | * XXX: No double-wide on 915GM pipe B. Is that the only reason for the | ||
5276 | * pipe == 0 check? | ||
5277 | */ | ||
5278 | if (mode->clock > | ||
5279 | dev_priv->display.get_display_clock_speed(dev) * 9 / 10) | ||
5280 | pipeconf |= PIPECONF_DOUBLE_WIDE; | ||
5281 | else | ||
5282 | pipeconf &= ~PIPECONF_DOUBLE_WIDE; | ||
5283 | } | ||
5284 | |||
5285 | DRM_DEBUG_KMS("Mode for pipe %c:\n", pipe == 0 ? 'A' : 'B'); | 5238 | DRM_DEBUG_KMS("Mode for pipe %c:\n", pipe == 0 ? 'A' : 'B'); |
5286 | drm_mode_debug_printmodeline(mode); | 5239 | drm_mode_debug_printmodeline(mode); |
5287 | 5240 | ||