diff options
author | Jesse Barnes <jbarnes@virtuousgeek.org> | 2011-01-05 15:01:26 -0500 |
---|---|---|
committer | Chris Wilson <chris@chris-wilson.co.uk> | 2011-01-11 15:43:59 -0500 |
commit | d5bb081b027b520f9e59b4fb8faea83a136ec15e (patch) | |
tree | 5ff85d01f3763d0e4be1ae7934ef673db2b9c604 | |
parent | 1daed3fb8324d517a1f9da43f1a1d3619d1b0ddc (diff) |
drm/i915: cleanup rc6 code
Cleanup several aspects of the rc6 code:
- misnamed intel_disable_clock_gating function (was only about rc6)
- remove commented call to intel_disable_clock_gating
- rc6 enabling code belongs in its own function (allows us to move the
actual clock gating enable call back into restore_state)
- allocate power & render contexts up front, only free on unload
(avoids ugly lazy init at rc6 enable time)
Signed-off-by: Jesse Barnes <jbarnes@virtuousgeek.org>
[ickle: checkpatch cleanup]
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
-rw-r--r-- | drivers/gpu/drm/i915/i915_drv.c | 6 | ||||
-rw-r--r-- | drivers/gpu/drm/i915/i915_drv.h | 1 | ||||
-rw-r--r-- | drivers/gpu/drm/i915/i915_suspend.c | 7 | ||||
-rw-r--r-- | drivers/gpu/drm/i915/intel_display.c | 107 |
4 files changed, 75 insertions, 46 deletions
diff --git a/drivers/gpu/drm/i915/i915_drv.c b/drivers/gpu/drm/i915/i915_drv.c index 02fce7fbcd8a..0de75a23f8e7 100644 --- a/drivers/gpu/drm/i915/i915_drv.c +++ b/drivers/gpu/drm/i915/i915_drv.c | |||
@@ -355,10 +355,10 @@ static int i915_drm_thaw(struct drm_device *dev) | |||
355 | 355 | ||
356 | /* Resume the modeset for every activated CRTC */ | 356 | /* Resume the modeset for every activated CRTC */ |
357 | drm_helper_resume_force_mode(dev); | 357 | drm_helper_resume_force_mode(dev); |
358 | } | ||
359 | 358 | ||
360 | /* Clock gating state */ | 359 | if (dev_priv->renderctx && dev_priv->pwrctx) |
361 | intel_enable_clock_gating(dev); | 360 | ironlake_enable_rc6(dev); |
361 | } | ||
362 | 362 | ||
363 | intel_opregion_init(dev); | 363 | intel_opregion_init(dev); |
364 | 364 | ||
diff --git a/drivers/gpu/drm/i915/i915_drv.h b/drivers/gpu/drm/i915/i915_drv.h index 1f77d8c6c6a2..455260067ff7 100644 --- a/drivers/gpu/drm/i915/i915_drv.h +++ b/drivers/gpu/drm/i915/i915_drv.h | |||
@@ -1260,6 +1260,7 @@ extern void intel_disable_fbc(struct drm_device *dev); | |||
1260 | extern void intel_enable_fbc(struct drm_crtc *crtc, unsigned long interval); | 1260 | extern void intel_enable_fbc(struct drm_crtc *crtc, unsigned long interval); |
1261 | extern bool intel_fbc_enabled(struct drm_device *dev); | 1261 | extern bool intel_fbc_enabled(struct drm_device *dev); |
1262 | extern bool ironlake_set_drps(struct drm_device *dev, u8 val); | 1262 | extern bool ironlake_set_drps(struct drm_device *dev, u8 val); |
1263 | extern void ironlake_enable_rc6(struct drm_device *dev); | ||
1263 | extern void gen6_set_rps(struct drm_device *dev, u8 val); | 1264 | extern void gen6_set_rps(struct drm_device *dev, u8 val); |
1264 | extern void intel_detect_pch (struct drm_device *dev); | 1265 | extern void intel_detect_pch (struct drm_device *dev); |
1265 | extern int intel_trans_dp_port_sel (struct drm_crtc *crtc); | 1266 | extern int intel_trans_dp_port_sel (struct drm_crtc *crtc); |
diff --git a/drivers/gpu/drm/i915/i915_suspend.c b/drivers/gpu/drm/i915/i915_suspend.c index 147cd9666700..0521ecf26017 100644 --- a/drivers/gpu/drm/i915/i915_suspend.c +++ b/drivers/gpu/drm/i915/i915_suspend.c | |||
@@ -822,10 +822,6 @@ int i915_save_state(struct drm_device *dev) | |||
822 | if (IS_GEN6(dev)) | 822 | if (IS_GEN6(dev)) |
823 | gen6_disable_rps(dev); | 823 | gen6_disable_rps(dev); |
824 | 824 | ||
825 | /* XXX disabling the clock gating breaks suspend on gm45 | ||
826 | intel_disable_clock_gating(dev); | ||
827 | */ | ||
828 | |||
829 | /* Cache mode state */ | 825 | /* Cache mode state */ |
830 | dev_priv->saveCACHE_MODE_0 = I915_READ(CACHE_MODE_0); | 826 | dev_priv->saveCACHE_MODE_0 = I915_READ(CACHE_MODE_0); |
831 | 827 | ||
@@ -868,6 +864,9 @@ int i915_restore_state(struct drm_device *dev) | |||
868 | I915_WRITE (IMR, dev_priv->saveIMR); | 864 | I915_WRITE (IMR, dev_priv->saveIMR); |
869 | } | 865 | } |
870 | 866 | ||
867 | /* Clock gating state */ | ||
868 | intel_enable_clock_gating(dev); | ||
869 | |||
871 | if (IS_IRONLAKE_M(dev)) { | 870 | if (IS_IRONLAKE_M(dev)) { |
872 | ironlake_enable_drps(dev); | 871 | ironlake_enable_drps(dev); |
873 | intel_init_emon(dev); | 872 | intel_init_emon(dev); |
diff --git a/drivers/gpu/drm/i915/intel_display.c b/drivers/gpu/drm/i915/intel_display.c index f3c0525d5328..1190efa390bd 100644 --- a/drivers/gpu/drm/i915/intel_display.c +++ b/drivers/gpu/drm/i915/intel_display.c | |||
@@ -6415,44 +6415,6 @@ void intel_enable_clock_gating(struct drm_device *dev) | |||
6415 | } else if (IS_I830(dev)) { | 6415 | } else if (IS_I830(dev)) { |
6416 | I915_WRITE(DSPCLK_GATE_D, OVRUNIT_CLOCK_GATE_DISABLE); | 6416 | I915_WRITE(DSPCLK_GATE_D, OVRUNIT_CLOCK_GATE_DISABLE); |
6417 | } | 6417 | } |
6418 | |||
6419 | /* | ||
6420 | * GPU can automatically power down the render unit if given a page | ||
6421 | * to save state. | ||
6422 | */ | ||
6423 | if (IS_IRONLAKE_M(dev)) { | ||
6424 | if (dev_priv->renderctx == NULL) | ||
6425 | dev_priv->renderctx = intel_alloc_context_page(dev); | ||
6426 | if (dev_priv->renderctx) { | ||
6427 | struct drm_i915_gem_object *obj = dev_priv->renderctx; | ||
6428 | if (BEGIN_LP_RING(6) != 0) { | ||
6429 | i915_gem_object_unpin(obj); | ||
6430 | drm_gem_object_unreference(&obj->base); | ||
6431 | dev_priv->renderctx = NULL; | ||
6432 | return; | ||
6433 | } | ||
6434 | OUT_RING(MI_SUSPEND_FLUSH | MI_SUSPEND_FLUSH_EN); | ||
6435 | OUT_RING(MI_SET_CONTEXT); | ||
6436 | OUT_RING(obj->gtt_offset | | ||
6437 | MI_MM_SPACE_GTT | | ||
6438 | MI_SAVE_EXT_STATE_EN | | ||
6439 | MI_RESTORE_EXT_STATE_EN | | ||
6440 | MI_RESTORE_INHIBIT); | ||
6441 | OUT_RING(MI_SUSPEND_FLUSH); | ||
6442 | OUT_RING(MI_NOOP); | ||
6443 | OUT_RING(MI_FLUSH); | ||
6444 | ADVANCE_LP_RING(); | ||
6445 | } else | ||
6446 | DRM_DEBUG_KMS("Failed to allocate render context." | ||
6447 | "Disable RC6\n"); | ||
6448 | |||
6449 | if (dev_priv->pwrctx == NULL) | ||
6450 | dev_priv->pwrctx = intel_alloc_context_page(dev); | ||
6451 | if (dev_priv->pwrctx) { | ||
6452 | struct drm_i915_gem_object *obj = dev_priv->pwrctx; | ||
6453 | I915_WRITE(PWRCTXA, obj->gtt_offset | PWRCTX_EN); | ||
6454 | } | ||
6455 | } | ||
6456 | } | 6418 | } |
6457 | 6419 | ||
6458 | void intel_disable_clock_gating(struct drm_device *dev) | 6420 | void intel_disable_clock_gating(struct drm_device *dev) |
@@ -6482,6 +6444,57 @@ void intel_disable_clock_gating(struct drm_device *dev) | |||
6482 | } | 6444 | } |
6483 | } | 6445 | } |
6484 | 6446 | ||
6447 | static void ironlake_disable_rc6(struct drm_device *dev) | ||
6448 | { | ||
6449 | struct drm_i915_private *dev_priv = dev->dev_private; | ||
6450 | |||
6451 | /* Wake the GPU, prevent RC6, then restore RSTDBYCTL */ | ||
6452 | I915_WRITE(RSTDBYCTL, I915_READ(RSTDBYCTL) | RCX_SW_EXIT); | ||
6453 | wait_for(((I915_READ(RSTDBYCTL) & RSX_STATUS_MASK) == RSX_STATUS_ON), | ||
6454 | 10); | ||
6455 | POSTING_READ(CCID); | ||
6456 | I915_WRITE(PWRCTXA, 0); | ||
6457 | POSTING_READ(PWRCTXA); | ||
6458 | I915_WRITE(RSTDBYCTL, I915_READ(RSTDBYCTL) & ~RCX_SW_EXIT); | ||
6459 | POSTING_READ(RSTDBYCTL); | ||
6460 | i915_gem_object_unpin(dev_priv->renderctx); | ||
6461 | drm_gem_object_unreference(&dev_priv->renderctx->base); | ||
6462 | dev_priv->renderctx = NULL; | ||
6463 | i915_gem_object_unpin(dev_priv->pwrctx); | ||
6464 | drm_gem_object_unreference(&dev_priv->pwrctx->base); | ||
6465 | dev_priv->pwrctx = NULL; | ||
6466 | } | ||
6467 | |||
6468 | void ironlake_enable_rc6(struct drm_device *dev) | ||
6469 | { | ||
6470 | struct drm_i915_private *dev_priv = dev->dev_private; | ||
6471 | int ret; | ||
6472 | |||
6473 | /* | ||
6474 | * GPU can automatically power down the render unit if given a page | ||
6475 | * to save state. | ||
6476 | */ | ||
6477 | ret = BEGIN_LP_RING(6); | ||
6478 | if (ret) { | ||
6479 | ironlake_disable_rc6(dev); | ||
6480 | return; | ||
6481 | } | ||
6482 | OUT_RING(MI_SUSPEND_FLUSH | MI_SUSPEND_FLUSH_EN); | ||
6483 | OUT_RING(MI_SET_CONTEXT); | ||
6484 | OUT_RING(dev_priv->renderctx->gtt_offset | | ||
6485 | MI_MM_SPACE_GTT | | ||
6486 | MI_SAVE_EXT_STATE_EN | | ||
6487 | MI_RESTORE_EXT_STATE_EN | | ||
6488 | MI_RESTORE_INHIBIT); | ||
6489 | OUT_RING(MI_SUSPEND_FLUSH); | ||
6490 | OUT_RING(MI_NOOP); | ||
6491 | OUT_RING(MI_FLUSH); | ||
6492 | ADVANCE_LP_RING(); | ||
6493 | |||
6494 | I915_WRITE(PWRCTXA, dev_priv->pwrctx->gtt_offset | PWRCTX_EN); | ||
6495 | I915_WRITE(RSTDBYCTL, I915_READ(RSTDBYCTL) & ~RCX_SW_EXIT); | ||
6496 | } | ||
6497 | |||
6485 | /* Set up chip specific display functions */ | 6498 | /* Set up chip specific display functions */ |
6486 | static void intel_init_display(struct drm_device *dev) | 6499 | static void intel_init_display(struct drm_device *dev) |
6487 | { | 6500 | { |
@@ -6724,6 +6737,21 @@ void intel_modeset_init(struct drm_device *dev) | |||
6724 | if (IS_GEN6(dev)) | 6737 | if (IS_GEN6(dev)) |
6725 | gen6_enable_rps(dev_priv); | 6738 | gen6_enable_rps(dev_priv); |
6726 | 6739 | ||
6740 | if (IS_IRONLAKE_M(dev)) { | ||
6741 | dev_priv->renderctx = intel_alloc_context_page(dev); | ||
6742 | if (!dev_priv->renderctx) | ||
6743 | goto skip_rc6; | ||
6744 | dev_priv->pwrctx = intel_alloc_context_page(dev); | ||
6745 | if (!dev_priv->pwrctx) { | ||
6746 | i915_gem_object_unpin(dev_priv->renderctx); | ||
6747 | drm_gem_object_unreference(&dev_priv->renderctx->base); | ||
6748 | dev_priv->renderctx = NULL; | ||
6749 | goto skip_rc6; | ||
6750 | } | ||
6751 | ironlake_enable_rc6(dev); | ||
6752 | } | ||
6753 | |||
6754 | skip_rc6: | ||
6727 | INIT_WORK(&dev_priv->idle_work, intel_idle_update); | 6755 | INIT_WORK(&dev_priv->idle_work, intel_idle_update); |
6728 | setup_timer(&dev_priv->idle_timer, intel_gpu_idle_timer, | 6756 | setup_timer(&dev_priv->idle_timer, intel_gpu_idle_timer, |
6729 | (unsigned long)dev); | 6757 | (unsigned long)dev); |
@@ -6760,7 +6788,8 @@ void intel_modeset_cleanup(struct drm_device *dev) | |||
6760 | if (IS_GEN6(dev)) | 6788 | if (IS_GEN6(dev)) |
6761 | gen6_disable_rps(dev); | 6789 | gen6_disable_rps(dev); |
6762 | 6790 | ||
6763 | intel_disable_clock_gating(dev); | 6791 | if (IS_IRONLAKE_M(dev)) |
6792 | ironlake_disable_rc6(dev); | ||
6764 | 6793 | ||
6765 | mutex_unlock(&dev->struct_mutex); | 6794 | mutex_unlock(&dev->struct_mutex); |
6766 | 6795 | ||