diff options
-rw-r--r-- | drivers/gpu/drm/i915/intel_display.c | 26 | ||||
-rw-r--r-- | drivers/gpu/drm/i915/intel_drv.h | 6 | ||||
-rw-r--r-- | drivers/gpu/drm/i915/intel_panel.c | 56 | ||||
-rw-r--r-- | drivers/gpu/drm/i915/intel_pm.c | 33 | ||||
-rw-r--r-- | drivers/gpu/drm/i915/intel_sprite.c | 4 |
5 files changed, 67 insertions, 58 deletions
diff --git a/drivers/gpu/drm/i915/intel_display.c b/drivers/gpu/drm/i915/intel_display.c index 234a77d0ee4e..b8d7ad6cab91 100644 --- a/drivers/gpu/drm/i915/intel_display.c +++ b/drivers/gpu/drm/i915/intel_display.c | |||
@@ -4696,7 +4696,6 @@ static void intel_set_pipe_timings(struct intel_crtc *intel_crtc) | |||
4696 | enum transcoder cpu_transcoder = intel_crtc->config.cpu_transcoder; | 4696 | enum transcoder cpu_transcoder = intel_crtc->config.cpu_transcoder; |
4697 | struct drm_display_mode *adjusted_mode = | 4697 | struct drm_display_mode *adjusted_mode = |
4698 | &intel_crtc->config.adjusted_mode; | 4698 | &intel_crtc->config.adjusted_mode; |
4699 | struct drm_display_mode *mode = &intel_crtc->config.requested_mode; | ||
4700 | uint32_t vsyncshift, crtc_vtotal, crtc_vblank_end; | 4699 | uint32_t vsyncshift, crtc_vtotal, crtc_vblank_end; |
4701 | 4700 | ||
4702 | /* We need to be careful not to changed the adjusted mode, for otherwise | 4701 | /* We need to be careful not to changed the adjusted mode, for otherwise |
@@ -4749,7 +4748,8 @@ static void intel_set_pipe_timings(struct intel_crtc *intel_crtc) | |||
4749 | * always be the user's requested size. | 4748 | * always be the user's requested size. |
4750 | */ | 4749 | */ |
4751 | I915_WRITE(PIPESRC(pipe), | 4750 | I915_WRITE(PIPESRC(pipe), |
4752 | ((mode->hdisplay - 1) << 16) | (mode->vdisplay - 1)); | 4751 | ((intel_crtc->config.pipe_src_w - 1) << 16) | |
4752 | (intel_crtc->config.pipe_src_h - 1)); | ||
4753 | } | 4753 | } |
4754 | 4754 | ||
4755 | static void intel_get_pipe_timings(struct intel_crtc *crtc, | 4755 | static void intel_get_pipe_timings(struct intel_crtc *crtc, |
@@ -4787,8 +4787,11 @@ static void intel_get_pipe_timings(struct intel_crtc *crtc, | |||
4787 | } | 4787 | } |
4788 | 4788 | ||
4789 | tmp = I915_READ(PIPESRC(crtc->pipe)); | 4789 | tmp = I915_READ(PIPESRC(crtc->pipe)); |
4790 | pipe_config->requested_mode.vdisplay = (tmp & 0xffff) + 1; | 4790 | pipe_config->pipe_src_h = (tmp & 0xffff) + 1; |
4791 | pipe_config->requested_mode.hdisplay = ((tmp >> 16) & 0xffff) + 1; | 4791 | pipe_config->pipe_src_w = ((tmp >> 16) & 0xffff) + 1; |
4792 | |||
4793 | pipe_config->requested_mode.vdisplay = pipe_config->pipe_src_h; | ||
4794 | pipe_config->requested_mode.hdisplay = pipe_config->pipe_src_w; | ||
4792 | } | 4795 | } |
4793 | 4796 | ||
4794 | static void intel_crtc_mode_from_pipe_config(struct intel_crtc *intel_crtc, | 4797 | static void intel_crtc_mode_from_pipe_config(struct intel_crtc *intel_crtc, |
@@ -4884,7 +4887,6 @@ static int i9xx_crtc_mode_set(struct drm_crtc *crtc, | |||
4884 | struct drm_device *dev = crtc->dev; | 4887 | struct drm_device *dev = crtc->dev; |
4885 | struct drm_i915_private *dev_priv = dev->dev_private; | 4888 | struct drm_i915_private *dev_priv = dev->dev_private; |
4886 | struct intel_crtc *intel_crtc = to_intel_crtc(crtc); | 4889 | struct intel_crtc *intel_crtc = to_intel_crtc(crtc); |
4887 | struct drm_display_mode *mode = &intel_crtc->config.requested_mode; | ||
4888 | int pipe = intel_crtc->pipe; | 4890 | int pipe = intel_crtc->pipe; |
4889 | int plane = intel_crtc->plane; | 4891 | int plane = intel_crtc->plane; |
4890 | int refclk, num_connectors = 0; | 4892 | int refclk, num_connectors = 0; |
@@ -4983,8 +4985,8 @@ static int i9xx_crtc_mode_set(struct drm_crtc *crtc, | |||
4983 | * which should always be the user's requested size. | 4985 | * which should always be the user's requested size. |
4984 | */ | 4986 | */ |
4985 | I915_WRITE(DSPSIZE(plane), | 4987 | I915_WRITE(DSPSIZE(plane), |
4986 | ((mode->vdisplay - 1) << 16) | | 4988 | ((intel_crtc->config.pipe_src_h - 1) << 16) | |
4987 | (mode->hdisplay - 1)); | 4989 | (intel_crtc->config.pipe_src_w - 1)); |
4988 | I915_WRITE(DSPPOS(plane), 0); | 4990 | I915_WRITE(DSPPOS(plane), 0); |
4989 | 4991 | ||
4990 | i9xx_set_pipeconf(intel_crtc); | 4992 | i9xx_set_pipeconf(intel_crtc); |
@@ -8349,6 +8351,8 @@ static void intel_dump_pipe_config(struct intel_crtc *crtc, | |||
8349 | DRM_DEBUG_KMS("adjusted mode:\n"); | 8351 | DRM_DEBUG_KMS("adjusted mode:\n"); |
8350 | drm_mode_debug_printmodeline(&pipe_config->adjusted_mode); | 8352 | drm_mode_debug_printmodeline(&pipe_config->adjusted_mode); |
8351 | DRM_DEBUG_KMS("port clock: %d\n", pipe_config->port_clock); | 8353 | DRM_DEBUG_KMS("port clock: %d\n", pipe_config->port_clock); |
8354 | DRM_DEBUG_KMS("pipe src size: %dx%d\n", | ||
8355 | pipe_config->pipe_src_w, pipe_config->pipe_src_h); | ||
8352 | DRM_DEBUG_KMS("gmch pfit: control: 0x%08x, ratios: 0x%08x, lvds border: 0x%08x\n", | 8356 | DRM_DEBUG_KMS("gmch pfit: control: 0x%08x, ratios: 0x%08x, lvds border: 0x%08x\n", |
8353 | pipe_config->gmch_pfit.control, | 8357 | pipe_config->gmch_pfit.control, |
8354 | pipe_config->gmch_pfit.pgm_ratios, | 8358 | pipe_config->gmch_pfit.pgm_ratios, |
@@ -8400,6 +8404,10 @@ intel_modeset_pipe_config(struct drm_crtc *crtc, | |||
8400 | 8404 | ||
8401 | drm_mode_copy(&pipe_config->adjusted_mode, mode); | 8405 | drm_mode_copy(&pipe_config->adjusted_mode, mode); |
8402 | drm_mode_copy(&pipe_config->requested_mode, mode); | 8406 | drm_mode_copy(&pipe_config->requested_mode, mode); |
8407 | |||
8408 | pipe_config->pipe_src_w = mode->hdisplay; | ||
8409 | pipe_config->pipe_src_h = mode->vdisplay; | ||
8410 | |||
8403 | pipe_config->cpu_transcoder = | 8411 | pipe_config->cpu_transcoder = |
8404 | (enum transcoder) to_intel_crtc(crtc)->pipe; | 8412 | (enum transcoder) to_intel_crtc(crtc)->pipe; |
8405 | pipe_config->shared_dpll = DPLL_ID_PRIVATE; | 8413 | pipe_config->shared_dpll = DPLL_ID_PRIVATE; |
@@ -8756,8 +8764,8 @@ intel_pipe_config_compare(struct drm_device *dev, | |||
8756 | DRM_MODE_FLAG_NVSYNC); | 8764 | DRM_MODE_FLAG_NVSYNC); |
8757 | } | 8765 | } |
8758 | 8766 | ||
8759 | PIPE_CONF_CHECK_I(requested_mode.hdisplay); | 8767 | PIPE_CONF_CHECK_I(pipe_src_w); |
8760 | PIPE_CONF_CHECK_I(requested_mode.vdisplay); | 8768 | PIPE_CONF_CHECK_I(pipe_src_h); |
8761 | 8769 | ||
8762 | PIPE_CONF_CHECK_I(gmch_pfit.control); | 8770 | PIPE_CONF_CHECK_I(gmch_pfit.control); |
8763 | /* pfit ratios are autocomputed by the hw on gen4+ */ | 8771 | /* pfit ratios are autocomputed by the hw on gen4+ */ |
diff --git a/drivers/gpu/drm/i915/intel_drv.h b/drivers/gpu/drm/i915/intel_drv.h index 8306940f0ae7..3046e78f31eb 100644 --- a/drivers/gpu/drm/i915/intel_drv.h +++ b/drivers/gpu/drm/i915/intel_drv.h | |||
@@ -215,6 +215,12 @@ struct intel_crtc_config { | |||
215 | /* Actual pipe timings ie. what we program into the pipe timing | 215 | /* Actual pipe timings ie. what we program into the pipe timing |
216 | * registers. adjusted_mode.clock is the pipe pixel clock. */ | 216 | * registers. adjusted_mode.clock is the pipe pixel clock. */ |
217 | struct drm_display_mode adjusted_mode; | 217 | struct drm_display_mode adjusted_mode; |
218 | |||
219 | /* Pipe source size (ie. panel fitter input size) | ||
220 | * All planes will be positioned inside this space, | ||
221 | * and get clipped at the edges. */ | ||
222 | int pipe_src_w, pipe_src_h; | ||
223 | |||
218 | /* Whether to set up the PCH/FDI. Note that we never allow sharing | 224 | /* Whether to set up the PCH/FDI. Note that we never allow sharing |
219 | * between pch encoders and cpu encoders. */ | 225 | * between pch encoders and cpu encoders. */ |
220 | bool has_pch_encoder; | 226 | bool has_pch_encoder; |
diff --git a/drivers/gpu/drm/i915/intel_panel.c b/drivers/gpu/drm/i915/intel_panel.c index 42114ecbae0e..c9dba46f52af 100644 --- a/drivers/gpu/drm/i915/intel_panel.c +++ b/drivers/gpu/drm/i915/intel_panel.c | |||
@@ -50,23 +50,22 @@ intel_pch_panel_fitting(struct intel_crtc *intel_crtc, | |||
50 | struct intel_crtc_config *pipe_config, | 50 | struct intel_crtc_config *pipe_config, |
51 | int fitting_mode) | 51 | int fitting_mode) |
52 | { | 52 | { |
53 | struct drm_display_mode *mode, *adjusted_mode; | 53 | struct drm_display_mode *adjusted_mode; |
54 | int x, y, width, height; | 54 | int x, y, width, height; |
55 | 55 | ||
56 | mode = &pipe_config->requested_mode; | ||
57 | adjusted_mode = &pipe_config->adjusted_mode; | 56 | adjusted_mode = &pipe_config->adjusted_mode; |
58 | 57 | ||
59 | x = y = width = height = 0; | 58 | x = y = width = height = 0; |
60 | 59 | ||
61 | /* Native modes don't need fitting */ | 60 | /* Native modes don't need fitting */ |
62 | if (adjusted_mode->hdisplay == mode->hdisplay && | 61 | if (adjusted_mode->hdisplay == pipe_config->pipe_src_w && |
63 | adjusted_mode->vdisplay == mode->vdisplay) | 62 | adjusted_mode->vdisplay == pipe_config->pipe_src_h) |
64 | goto done; | 63 | goto done; |
65 | 64 | ||
66 | switch (fitting_mode) { | 65 | switch (fitting_mode) { |
67 | case DRM_MODE_SCALE_CENTER: | 66 | case DRM_MODE_SCALE_CENTER: |
68 | width = mode->hdisplay; | 67 | width = pipe_config->pipe_src_w; |
69 | height = mode->vdisplay; | 68 | height = pipe_config->pipe_src_h; |
70 | x = (adjusted_mode->hdisplay - width + 1)/2; | 69 | x = (adjusted_mode->hdisplay - width + 1)/2; |
71 | y = (adjusted_mode->vdisplay - height + 1)/2; | 70 | y = (adjusted_mode->vdisplay - height + 1)/2; |
72 | break; | 71 | break; |
@@ -74,17 +73,17 @@ intel_pch_panel_fitting(struct intel_crtc *intel_crtc, | |||
74 | case DRM_MODE_SCALE_ASPECT: | 73 | case DRM_MODE_SCALE_ASPECT: |
75 | /* Scale but preserve the aspect ratio */ | 74 | /* Scale but preserve the aspect ratio */ |
76 | { | 75 | { |
77 | u32 scaled_width = adjusted_mode->hdisplay * mode->vdisplay; | 76 | u32 scaled_width = adjusted_mode->hdisplay * pipe_config->pipe_src_h; |
78 | u32 scaled_height = mode->hdisplay * adjusted_mode->vdisplay; | 77 | u32 scaled_height = pipe_config->pipe_src_w * adjusted_mode->vdisplay; |
79 | if (scaled_width > scaled_height) { /* pillar */ | 78 | if (scaled_width > scaled_height) { /* pillar */ |
80 | width = scaled_height / mode->vdisplay; | 79 | width = scaled_height / pipe_config->pipe_src_h; |
81 | if (width & 1) | 80 | if (width & 1) |
82 | width++; | 81 | width++; |
83 | x = (adjusted_mode->hdisplay - width + 1) / 2; | 82 | x = (adjusted_mode->hdisplay - width + 1) / 2; |
84 | y = 0; | 83 | y = 0; |
85 | height = adjusted_mode->vdisplay; | 84 | height = adjusted_mode->vdisplay; |
86 | } else if (scaled_width < scaled_height) { /* letter */ | 85 | } else if (scaled_width < scaled_height) { /* letter */ |
87 | height = scaled_width / mode->hdisplay; | 86 | height = scaled_width / pipe_config->pipe_src_w; |
88 | if (height & 1) | 87 | if (height & 1) |
89 | height++; | 88 | height++; |
90 | y = (adjusted_mode->vdisplay - height + 1) / 2; | 89 | y = (adjusted_mode->vdisplay - height + 1) / 2; |
@@ -176,14 +175,13 @@ void intel_gmch_panel_fitting(struct intel_crtc *intel_crtc, | |||
176 | { | 175 | { |
177 | struct drm_device *dev = intel_crtc->base.dev; | 176 | struct drm_device *dev = intel_crtc->base.dev; |
178 | u32 pfit_control = 0, pfit_pgm_ratios = 0, border = 0; | 177 | u32 pfit_control = 0, pfit_pgm_ratios = 0, border = 0; |
179 | struct drm_display_mode *mode, *adjusted_mode; | 178 | struct drm_display_mode *adjusted_mode; |
180 | 179 | ||
181 | mode = &pipe_config->requested_mode; | ||
182 | adjusted_mode = &pipe_config->adjusted_mode; | 180 | adjusted_mode = &pipe_config->adjusted_mode; |
183 | 181 | ||
184 | /* Native modes don't need fitting */ | 182 | /* Native modes don't need fitting */ |
185 | if (adjusted_mode->hdisplay == mode->hdisplay && | 183 | if (adjusted_mode->hdisplay == pipe_config->pipe_src_w && |
186 | adjusted_mode->vdisplay == mode->vdisplay) | 184 | adjusted_mode->vdisplay == pipe_config->pipe_src_h) |
187 | goto out; | 185 | goto out; |
188 | 186 | ||
189 | switch (fitting_mode) { | 187 | switch (fitting_mode) { |
@@ -192,16 +190,16 @@ void intel_gmch_panel_fitting(struct intel_crtc *intel_crtc, | |||
192 | * For centered modes, we have to calculate border widths & | 190 | * For centered modes, we have to calculate border widths & |
193 | * heights and modify the values programmed into the CRTC. | 191 | * heights and modify the values programmed into the CRTC. |
194 | */ | 192 | */ |
195 | centre_horizontally(adjusted_mode, mode->hdisplay); | 193 | centre_horizontally(adjusted_mode, pipe_config->pipe_src_w); |
196 | centre_vertically(adjusted_mode, mode->vdisplay); | 194 | centre_vertically(adjusted_mode, pipe_config->pipe_src_h); |
197 | border = LVDS_BORDER_ENABLE; | 195 | border = LVDS_BORDER_ENABLE; |
198 | break; | 196 | break; |
199 | case DRM_MODE_SCALE_ASPECT: | 197 | case DRM_MODE_SCALE_ASPECT: |
200 | /* Scale but preserve the aspect ratio */ | 198 | /* Scale but preserve the aspect ratio */ |
201 | if (INTEL_INFO(dev)->gen >= 4) { | 199 | if (INTEL_INFO(dev)->gen >= 4) { |
202 | u32 scaled_width = adjusted_mode->hdisplay * | 200 | u32 scaled_width = adjusted_mode->hdisplay * |
203 | mode->vdisplay; | 201 | pipe_config->pipe_src_h; |
204 | u32 scaled_height = mode->hdisplay * | 202 | u32 scaled_height = pipe_config->pipe_src_w * |
205 | adjusted_mode->vdisplay; | 203 | adjusted_mode->vdisplay; |
206 | 204 | ||
207 | /* 965+ is easy, it does everything in hw */ | 205 | /* 965+ is easy, it does everything in hw */ |
@@ -211,12 +209,12 @@ void intel_gmch_panel_fitting(struct intel_crtc *intel_crtc, | |||
211 | else if (scaled_width < scaled_height) | 209 | else if (scaled_width < scaled_height) |
212 | pfit_control |= PFIT_ENABLE | | 210 | pfit_control |= PFIT_ENABLE | |
213 | PFIT_SCALING_LETTER; | 211 | PFIT_SCALING_LETTER; |
214 | else if (adjusted_mode->hdisplay != mode->hdisplay) | 212 | else if (adjusted_mode->hdisplay != pipe_config->pipe_src_w) |
215 | pfit_control |= PFIT_ENABLE | PFIT_SCALING_AUTO; | 213 | pfit_control |= PFIT_ENABLE | PFIT_SCALING_AUTO; |
216 | } else { | 214 | } else { |
217 | u32 scaled_width = adjusted_mode->hdisplay * | 215 | u32 scaled_width = adjusted_mode->hdisplay * |
218 | mode->vdisplay; | 216 | pipe_config->pipe_src_h; |
219 | u32 scaled_height = mode->hdisplay * | 217 | u32 scaled_height = pipe_config->pipe_src_w * |
220 | adjusted_mode->vdisplay; | 218 | adjusted_mode->vdisplay; |
221 | /* | 219 | /* |
222 | * For earlier chips we have to calculate the scaling | 220 | * For earlier chips we have to calculate the scaling |
@@ -226,11 +224,11 @@ void intel_gmch_panel_fitting(struct intel_crtc *intel_crtc, | |||
226 | if (scaled_width > scaled_height) { /* pillar */ | 224 | if (scaled_width > scaled_height) { /* pillar */ |
227 | centre_horizontally(adjusted_mode, | 225 | centre_horizontally(adjusted_mode, |
228 | scaled_height / | 226 | scaled_height / |
229 | mode->vdisplay); | 227 | pipe_config->pipe_src_h); |
230 | 228 | ||
231 | border = LVDS_BORDER_ENABLE; | 229 | border = LVDS_BORDER_ENABLE; |
232 | if (mode->vdisplay != adjusted_mode->vdisplay) { | 230 | if (pipe_config->pipe_src_h != adjusted_mode->vdisplay) { |
233 | u32 bits = panel_fitter_scaling(mode->vdisplay, adjusted_mode->vdisplay); | 231 | u32 bits = panel_fitter_scaling(pipe_config->pipe_src_h, adjusted_mode->vdisplay); |
234 | pfit_pgm_ratios |= (bits << PFIT_HORIZ_SCALE_SHIFT | | 232 | pfit_pgm_ratios |= (bits << PFIT_HORIZ_SCALE_SHIFT | |
235 | bits << PFIT_VERT_SCALE_SHIFT); | 233 | bits << PFIT_VERT_SCALE_SHIFT); |
236 | pfit_control |= (PFIT_ENABLE | | 234 | pfit_control |= (PFIT_ENABLE | |
@@ -240,11 +238,11 @@ void intel_gmch_panel_fitting(struct intel_crtc *intel_crtc, | |||
240 | } else if (scaled_width < scaled_height) { /* letter */ | 238 | } else if (scaled_width < scaled_height) { /* letter */ |
241 | centre_vertically(adjusted_mode, | 239 | centre_vertically(adjusted_mode, |
242 | scaled_width / | 240 | scaled_width / |
243 | mode->hdisplay); | 241 | pipe_config->pipe_src_w); |
244 | 242 | ||
245 | border = LVDS_BORDER_ENABLE; | 243 | border = LVDS_BORDER_ENABLE; |
246 | if (mode->hdisplay != adjusted_mode->hdisplay) { | 244 | if (pipe_config->pipe_src_w != adjusted_mode->hdisplay) { |
247 | u32 bits = panel_fitter_scaling(mode->hdisplay, adjusted_mode->hdisplay); | 245 | u32 bits = panel_fitter_scaling(pipe_config->pipe_src_w, adjusted_mode->hdisplay); |
248 | pfit_pgm_ratios |= (bits << PFIT_HORIZ_SCALE_SHIFT | | 246 | pfit_pgm_ratios |= (bits << PFIT_HORIZ_SCALE_SHIFT | |
249 | bits << PFIT_VERT_SCALE_SHIFT); | 247 | bits << PFIT_VERT_SCALE_SHIFT); |
250 | pfit_control |= (PFIT_ENABLE | | 248 | pfit_control |= (PFIT_ENABLE | |
@@ -265,8 +263,8 @@ void intel_gmch_panel_fitting(struct intel_crtc *intel_crtc, | |||
265 | * Full scaling, even if it changes the aspect ratio. | 263 | * Full scaling, even if it changes the aspect ratio. |
266 | * Fortunately this is all done for us in hw. | 264 | * Fortunately this is all done for us in hw. |
267 | */ | 265 | */ |
268 | if (mode->vdisplay != adjusted_mode->vdisplay || | 266 | if (pipe_config->pipe_src_h != adjusted_mode->vdisplay || |
269 | mode->hdisplay != adjusted_mode->hdisplay) { | 267 | pipe_config->pipe_src_w != adjusted_mode->hdisplay) { |
270 | pfit_control |= PFIT_ENABLE; | 268 | pfit_control |= PFIT_ENABLE; |
271 | if (INTEL_INFO(dev)->gen >= 4) | 269 | if (INTEL_INFO(dev)->gen >= 4) |
272 | pfit_control |= PFIT_SCALING_AUTO; | 270 | pfit_control |= PFIT_SCALING_AUTO; |
diff --git a/drivers/gpu/drm/i915/intel_pm.c b/drivers/gpu/drm/i915/intel_pm.c index 9cf3aa525414..fe19ba3360a7 100644 --- a/drivers/gpu/drm/i915/intel_pm.c +++ b/drivers/gpu/drm/i915/intel_pm.c | |||
@@ -450,9 +450,8 @@ void intel_update_fbc(struct drm_device *dev) | |||
450 | struct drm_framebuffer *fb; | 450 | struct drm_framebuffer *fb; |
451 | struct intel_framebuffer *intel_fb; | 451 | struct intel_framebuffer *intel_fb; |
452 | struct drm_i915_gem_object *obj; | 452 | struct drm_i915_gem_object *obj; |
453 | const struct drm_display_mode *mode; | ||
454 | const struct drm_display_mode *adjusted_mode; | 453 | const struct drm_display_mode *adjusted_mode; |
455 | unsigned int max_hdisplay, max_vdisplay; | 454 | unsigned int max_width, max_height; |
456 | 455 | ||
457 | if (!I915_HAS_FBC(dev)) { | 456 | if (!I915_HAS_FBC(dev)) { |
458 | set_no_fbc_reason(dev_priv, FBC_UNSUPPORTED); | 457 | set_no_fbc_reason(dev_priv, FBC_UNSUPPORTED); |
@@ -496,7 +495,6 @@ void intel_update_fbc(struct drm_device *dev) | |||
496 | fb = crtc->fb; | 495 | fb = crtc->fb; |
497 | intel_fb = to_intel_framebuffer(fb); | 496 | intel_fb = to_intel_framebuffer(fb); |
498 | obj = intel_fb->obj; | 497 | obj = intel_fb->obj; |
499 | mode = &intel_crtc->config.requested_mode; | ||
500 | adjusted_mode = &intel_crtc->config.adjusted_mode; | 498 | adjusted_mode = &intel_crtc->config.adjusted_mode; |
501 | 499 | ||
502 | if (i915_enable_fbc < 0 && | 500 | if (i915_enable_fbc < 0 && |
@@ -519,14 +517,14 @@ void intel_update_fbc(struct drm_device *dev) | |||
519 | } | 517 | } |
520 | 518 | ||
521 | if (IS_G4X(dev) || INTEL_INFO(dev)->gen >= 5) { | 519 | if (IS_G4X(dev) || INTEL_INFO(dev)->gen >= 5) { |
522 | max_hdisplay = 4096; | 520 | max_width = 4096; |
523 | max_vdisplay = 2048; | 521 | max_height = 2048; |
524 | } else { | 522 | } else { |
525 | max_hdisplay = 2048; | 523 | max_width = 2048; |
526 | max_vdisplay = 1536; | 524 | max_height = 1536; |
527 | } | 525 | } |
528 | if ((mode->hdisplay > max_hdisplay) || | 526 | if (intel_crtc->config.pipe_src_w > max_width || |
529 | (mode->vdisplay > max_vdisplay)) { | 527 | intel_crtc->config.pipe_src_h > max_height) { |
530 | if (set_no_fbc_reason(dev_priv, FBC_MODE_TOO_LARGE)) | 528 | if (set_no_fbc_reason(dev_priv, FBC_MODE_TOO_LARGE)) |
531 | DRM_DEBUG_KMS("mode too large for compression, disabling\n"); | 529 | DRM_DEBUG_KMS("mode too large for compression, disabling\n"); |
532 | goto out_disable; | 530 | goto out_disable; |
@@ -1178,7 +1176,7 @@ static bool g4x_compute_wm0(struct drm_device *dev, | |||
1178 | adjusted_mode = &to_intel_crtc(crtc)->config.adjusted_mode; | 1176 | adjusted_mode = &to_intel_crtc(crtc)->config.adjusted_mode; |
1179 | clock = adjusted_mode->clock; | 1177 | clock = adjusted_mode->clock; |
1180 | htotal = adjusted_mode->htotal; | 1178 | htotal = adjusted_mode->htotal; |
1181 | hdisplay = to_intel_crtc(crtc)->config.requested_mode.hdisplay; | 1179 | hdisplay = to_intel_crtc(crtc)->config.pipe_src_w; |
1182 | pixel_size = crtc->fb->bits_per_pixel / 8; | 1180 | pixel_size = crtc->fb->bits_per_pixel / 8; |
1183 | 1181 | ||
1184 | /* Use the small buffer method to calculate plane watermark */ | 1182 | /* Use the small buffer method to calculate plane watermark */ |
@@ -1265,7 +1263,7 @@ static bool g4x_compute_srwm(struct drm_device *dev, | |||
1265 | adjusted_mode = &to_intel_crtc(crtc)->config.adjusted_mode; | 1263 | adjusted_mode = &to_intel_crtc(crtc)->config.adjusted_mode; |
1266 | clock = adjusted_mode->clock; | 1264 | clock = adjusted_mode->clock; |
1267 | htotal = adjusted_mode->htotal; | 1265 | htotal = adjusted_mode->htotal; |
1268 | hdisplay = to_intel_crtc(crtc)->config.requested_mode.hdisplay; | 1266 | hdisplay = to_intel_crtc(crtc)->config.pipe_src_w; |
1269 | pixel_size = crtc->fb->bits_per_pixel / 8; | 1267 | pixel_size = crtc->fb->bits_per_pixel / 8; |
1270 | 1268 | ||
1271 | line_time_us = (htotal * 1000) / clock; | 1269 | line_time_us = (htotal * 1000) / clock; |
@@ -1496,7 +1494,7 @@ static void i965_update_wm(struct drm_crtc *unused_crtc) | |||
1496 | &to_intel_crtc(crtc)->config.adjusted_mode; | 1494 | &to_intel_crtc(crtc)->config.adjusted_mode; |
1497 | int clock = adjusted_mode->clock; | 1495 | int clock = adjusted_mode->clock; |
1498 | int htotal = adjusted_mode->htotal; | 1496 | int htotal = adjusted_mode->htotal; |
1499 | int hdisplay = to_intel_crtc(crtc)->config.requested_mode.hdisplay; | 1497 | int hdisplay = to_intel_crtc(crtc)->config.pipe_src_w; |
1500 | int pixel_size = crtc->fb->bits_per_pixel / 8; | 1498 | int pixel_size = crtc->fb->bits_per_pixel / 8; |
1501 | unsigned long line_time_us; | 1499 | unsigned long line_time_us; |
1502 | int entries; | 1500 | int entries; |
@@ -1618,7 +1616,7 @@ static void i9xx_update_wm(struct drm_crtc *unused_crtc) | |||
1618 | &to_intel_crtc(enabled)->config.adjusted_mode; | 1616 | &to_intel_crtc(enabled)->config.adjusted_mode; |
1619 | int clock = adjusted_mode->clock; | 1617 | int clock = adjusted_mode->clock; |
1620 | int htotal = adjusted_mode->htotal; | 1618 | int htotal = adjusted_mode->htotal; |
1621 | int hdisplay = to_intel_crtc(crtc)->config.requested_mode.hdisplay; | 1619 | int hdisplay = to_intel_crtc(crtc)->config.pipe_src_w; |
1622 | int pixel_size = enabled->fb->bits_per_pixel / 8; | 1620 | int pixel_size = enabled->fb->bits_per_pixel / 8; |
1623 | unsigned long line_time_us; | 1621 | unsigned long line_time_us; |
1624 | int entries; | 1622 | int entries; |
@@ -1768,7 +1766,7 @@ static bool ironlake_compute_srwm(struct drm_device *dev, int level, int plane, | |||
1768 | adjusted_mode = &to_intel_crtc(crtc)->config.adjusted_mode; | 1766 | adjusted_mode = &to_intel_crtc(crtc)->config.adjusted_mode; |
1769 | clock = adjusted_mode->clock; | 1767 | clock = adjusted_mode->clock; |
1770 | htotal = adjusted_mode->htotal; | 1768 | htotal = adjusted_mode->htotal; |
1771 | hdisplay = to_intel_crtc(crtc)->config.requested_mode.hdisplay; | 1769 | hdisplay = to_intel_crtc(crtc)->config.pipe_src_w; |
1772 | pixel_size = crtc->fb->bits_per_pixel / 8; | 1770 | pixel_size = crtc->fb->bits_per_pixel / 8; |
1773 | 1771 | ||
1774 | line_time_us = (htotal * 1000) / clock; | 1772 | line_time_us = (htotal * 1000) / clock; |
@@ -2123,8 +2121,8 @@ static uint32_t ilk_pipe_pixel_rate(struct drm_device *dev, | |||
2123 | if (pfit_size) { | 2121 | if (pfit_size) { |
2124 | uint64_t pipe_w, pipe_h, pfit_w, pfit_h; | 2122 | uint64_t pipe_w, pipe_h, pfit_w, pfit_h; |
2125 | 2123 | ||
2126 | pipe_w = intel_crtc->config.requested_mode.hdisplay; | 2124 | pipe_w = intel_crtc->config.pipe_src_w; |
2127 | pipe_h = intel_crtc->config.requested_mode.vdisplay; | 2125 | pipe_h = intel_crtc->config.pipe_src_h; |
2128 | pfit_w = (pfit_size >> 16) & 0xFFFF; | 2126 | pfit_w = (pfit_size >> 16) & 0xFFFF; |
2129 | pfit_h = pfit_size & 0xFFFF; | 2127 | pfit_h = pfit_size & 0xFFFF; |
2130 | if (pipe_w < pfit_w) | 2128 | if (pipe_w < pfit_w) |
@@ -2650,8 +2648,7 @@ static void hsw_compute_wm_parameters(struct drm_device *dev, | |||
2650 | p->pixel_rate = ilk_pipe_pixel_rate(dev, crtc); | 2648 | p->pixel_rate = ilk_pipe_pixel_rate(dev, crtc); |
2651 | p->pri.bytes_per_pixel = crtc->fb->bits_per_pixel / 8; | 2649 | p->pri.bytes_per_pixel = crtc->fb->bits_per_pixel / 8; |
2652 | p->cur.bytes_per_pixel = 4; | 2650 | p->cur.bytes_per_pixel = 4; |
2653 | p->pri.horiz_pixels = | 2651 | p->pri.horiz_pixels = intel_crtc->config.pipe_src_w; |
2654 | intel_crtc->config.requested_mode.hdisplay; | ||
2655 | p->cur.horiz_pixels = 64; | 2652 | p->cur.horiz_pixels = 64; |
2656 | /* TODO: for now, assume primary and cursor planes are always enabled. */ | 2653 | /* TODO: for now, assume primary and cursor planes are always enabled. */ |
2657 | p->pri.enabled = true; | 2654 | p->pri.enabled = true; |
diff --git a/drivers/gpu/drm/i915/intel_sprite.c b/drivers/gpu/drm/i915/intel_sprite.c index ae0e686e6e55..231b289e8e57 100644 --- a/drivers/gpu/drm/i915/intel_sprite.c +++ b/drivers/gpu/drm/i915/intel_sprite.c | |||
@@ -652,8 +652,8 @@ intel_update_plane(struct drm_plane *plane, struct drm_crtc *crtc, | |||
652 | .y2 = crtc_y + crtc_h, | 652 | .y2 = crtc_y + crtc_h, |
653 | }; | 653 | }; |
654 | const struct drm_rect clip = { | 654 | const struct drm_rect clip = { |
655 | .x2 = intel_crtc->config.requested_mode.hdisplay, | 655 | .x2 = intel_crtc->config.pipe_src_w, |
656 | .y2 = intel_crtc->config.requested_mode.vdisplay, | 656 | .y2 = intel_crtc->config.pipe_src_h, |
657 | }; | 657 | }; |
658 | 658 | ||
659 | intel_fb = to_intel_framebuffer(fb); | 659 | intel_fb = to_intel_framebuffer(fb); |