aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm
diff options
context:
space:
mode:
authorChris Wilson <chris@chris-wilson.co.uk>2012-12-07 05:43:24 -0500
committerDaniel Vetter <daniel.vetter@ffwll.ch>2012-12-17 06:38:45 -0500
commit52bd02d8e3fd83201a1a81bdb4ec6fc0b54d24a0 (patch)
treed43b37193ef1ec58395304a4c585423a6bba1c3f /drivers/gpu/drm
parentaf6c4575afada1a9c411e42439b5d40908865b11 (diff)
drm/i915: Clear self-refresh watermarks when disabled
If we elect to disable self-refresh as they require too many FIFO entries, clear the values prior to writing them into the registers. If they are too large they may occupy more bits than available and so corrupt neighbouring WM values. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk> Reviewed-by: Jesse Barnes <jbarnes@virtuousgeek.org> Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Diffstat (limited to 'drivers/gpu/drm')
-rw-r--r--drivers/gpu/drm/i915/intel_pm.c14
1 files changed, 8 insertions, 6 deletions
diff --git a/drivers/gpu/drm/i915/intel_pm.c b/drivers/gpu/drm/i915/intel_pm.c
index cdd70e654af5..bfc46529f6df 100644
--- a/drivers/gpu/drm/i915/intel_pm.c
+++ b/drivers/gpu/drm/i915/intel_pm.c
@@ -1303,7 +1303,6 @@ static void valleyview_update_wm(struct drm_device *dev)
1303 &planeb_wm, &cursorb_wm)) 1303 &planeb_wm, &cursorb_wm))
1304 enabled |= 2; 1304 enabled |= 2;
1305 1305
1306 plane_sr = cursor_sr = 0;
1307 if (single_plane_enabled(enabled) && 1306 if (single_plane_enabled(enabled) &&
1308 g4x_compute_srwm(dev, ffs(enabled) - 1, 1307 g4x_compute_srwm(dev, ffs(enabled) - 1,
1309 sr_latency_ns, 1308 sr_latency_ns,
@@ -1314,11 +1313,13 @@ static void valleyview_update_wm(struct drm_device *dev)
1314 2*sr_latency_ns, 1313 2*sr_latency_ns,
1315 &valleyview_wm_info, 1314 &valleyview_wm_info,
1316 &valleyview_cursor_wm_info, 1315 &valleyview_cursor_wm_info,
1317 &ignore_plane_sr, &cursor_sr)) 1316 &ignore_plane_sr, &cursor_sr)) {
1318 I915_WRITE(FW_BLC_SELF_VLV, FW_CSPWRDWNEN); 1317 I915_WRITE(FW_BLC_SELF_VLV, FW_CSPWRDWNEN);
1319 else 1318 } else {
1320 I915_WRITE(FW_BLC_SELF_VLV, 1319 I915_WRITE(FW_BLC_SELF_VLV,
1321 I915_READ(FW_BLC_SELF_VLV) & ~FW_CSPWRDWNEN); 1320 I915_READ(FW_BLC_SELF_VLV) & ~FW_CSPWRDWNEN);
1321 plane_sr = cursor_sr = 0;
1322 }
1322 1323
1323 DRM_DEBUG_KMS("Setting FIFO watermarks - A: plane=%d, cursor=%d, B: plane=%d, cursor=%d, SR: plane=%d, cursor=%d\n", 1324 DRM_DEBUG_KMS("Setting FIFO watermarks - A: plane=%d, cursor=%d, B: plane=%d, cursor=%d, SR: plane=%d, cursor=%d\n",
1324 planea_wm, cursora_wm, 1325 planea_wm, cursora_wm,
@@ -1358,17 +1359,18 @@ static void g4x_update_wm(struct drm_device *dev)
1358 &planeb_wm, &cursorb_wm)) 1359 &planeb_wm, &cursorb_wm))
1359 enabled |= 2; 1360 enabled |= 2;
1360 1361
1361 plane_sr = cursor_sr = 0;
1362 if (single_plane_enabled(enabled) && 1362 if (single_plane_enabled(enabled) &&
1363 g4x_compute_srwm(dev, ffs(enabled) - 1, 1363 g4x_compute_srwm(dev, ffs(enabled) - 1,
1364 sr_latency_ns, 1364 sr_latency_ns,
1365 &g4x_wm_info, 1365 &g4x_wm_info,
1366 &g4x_cursor_wm_info, 1366 &g4x_cursor_wm_info,
1367 &plane_sr, &cursor_sr)) 1367 &plane_sr, &cursor_sr)) {
1368 I915_WRITE(FW_BLC_SELF, FW_BLC_SELF_EN); 1368 I915_WRITE(FW_BLC_SELF, FW_BLC_SELF_EN);
1369 else 1369 } else {
1370 I915_WRITE(FW_BLC_SELF, 1370 I915_WRITE(FW_BLC_SELF,
1371 I915_READ(FW_BLC_SELF) & ~FW_BLC_SELF_EN); 1371 I915_READ(FW_BLC_SELF) & ~FW_BLC_SELF_EN);
1372 plane_sr = cursor_sr = 0;
1373 }
1372 1374
1373 DRM_DEBUG_KMS("Setting FIFO watermarks - A: plane=%d, cursor=%d, B: plane=%d, cursor=%d, SR: plane=%d, cursor=%d\n", 1375 DRM_DEBUG_KMS("Setting FIFO watermarks - A: plane=%d, cursor=%d, B: plane=%d, cursor=%d, SR: plane=%d, cursor=%d\n",
1374 planea_wm, cursora_wm, 1376 planea_wm, cursora_wm,