diff options
author | Eugeni Dodonov <eugeni.dodonov@intel.com> | 2012-07-02 10:51:04 -0400 |
---|---|---|
committer | Daniel Vetter <daniel.vetter@ffwll.ch> | 2012-07-03 16:15:21 -0400 |
commit | e7911c48a05bc0002616a51e99761dec36110b04 (patch) | |
tree | c7a371e758fecb36e76c323a41b17b21f24ef417 /drivers | |
parent | c4de7b0ffda2bb4843fd7f1052d0a2bb90bd08a5 (diff) |
drm/i915: support Haswell force waking
There is a different ACK register for force wake on Haswell, so account
for that.
Signed-off-by: Eugeni Dodonov <eugeni.dodonov@intel.com>
Reviewed-by: Ben Widawsky <ben@bwidawsk.net>
Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/gpu/drm/i915/i915_drv.c | 22 | ||||
-rw-r--r-- | drivers/gpu/drm/i915/i915_reg.h | 1 |
2 files changed, 19 insertions, 4 deletions
diff --git a/drivers/gpu/drm/i915/i915_drv.c b/drivers/gpu/drm/i915/i915_drv.c index a4ea4a9fc425..3ac414ff7f84 100644 --- a/drivers/gpu/drm/i915/i915_drv.c +++ b/drivers/gpu/drm/i915/i915_drv.c | |||
@@ -451,12 +451,19 @@ static void __gen6_gt_wait_for_thread_c0(struct drm_i915_private *dev_priv) | |||
451 | 451 | ||
452 | static void __gen6_gt_force_wake_get(struct drm_i915_private *dev_priv) | 452 | static void __gen6_gt_force_wake_get(struct drm_i915_private *dev_priv) |
453 | { | 453 | { |
454 | if (wait_for_atomic_us((I915_READ_NOTRACE(FORCEWAKE_ACK) & 1) == 0, 500)) | 454 | u32 forcewake_ack; |
455 | |||
456 | if (IS_HASWELL(dev_priv->dev)) | ||
457 | forcewake_ack = FORCEWAKE_ACK_HSW; | ||
458 | else | ||
459 | forcewake_ack = FORCEWAKE_ACK; | ||
460 | |||
461 | if (wait_for_atomic_us((I915_READ_NOTRACE(forcewake_ack) & 1) == 0, 500)) | ||
455 | DRM_ERROR("Force wake wait timed out\n"); | 462 | DRM_ERROR("Force wake wait timed out\n"); |
456 | 463 | ||
457 | I915_WRITE_NOTRACE(FORCEWAKE, 1); | 464 | I915_WRITE_NOTRACE(FORCEWAKE, 1); |
458 | 465 | ||
459 | if (wait_for_atomic_us((I915_READ_NOTRACE(FORCEWAKE_ACK) & 1), 500)) | 466 | if (wait_for_atomic_us((I915_READ_NOTRACE(forcewake_ack) & 1), 500)) |
460 | DRM_ERROR("Force wake wait timed out\n"); | 467 | DRM_ERROR("Force wake wait timed out\n"); |
461 | 468 | ||
462 | __gen6_gt_wait_for_thread_c0(dev_priv); | 469 | __gen6_gt_wait_for_thread_c0(dev_priv); |
@@ -464,12 +471,19 @@ static void __gen6_gt_force_wake_get(struct drm_i915_private *dev_priv) | |||
464 | 471 | ||
465 | static void __gen6_gt_force_wake_mt_get(struct drm_i915_private *dev_priv) | 472 | static void __gen6_gt_force_wake_mt_get(struct drm_i915_private *dev_priv) |
466 | { | 473 | { |
467 | if (wait_for_atomic_us((I915_READ_NOTRACE(FORCEWAKE_MT_ACK) & 1) == 0, 500)) | 474 | u32 forcewake_ack; |
475 | |||
476 | if (IS_HASWELL(dev_priv->dev)) | ||
477 | forcewake_ack = FORCEWAKE_ACK_HSW; | ||
478 | else | ||
479 | forcewake_ack = FORCEWAKE_MT_ACK; | ||
480 | |||
481 | if (wait_for_atomic_us((I915_READ_NOTRACE(forcewake_ack) & 1) == 0, 500)) | ||
468 | DRM_ERROR("Force wake wait timed out\n"); | 482 | DRM_ERROR("Force wake wait timed out\n"); |
469 | 483 | ||
470 | I915_WRITE_NOTRACE(FORCEWAKE_MT, _MASKED_BIT_ENABLE(1)); | 484 | I915_WRITE_NOTRACE(FORCEWAKE_MT, _MASKED_BIT_ENABLE(1)); |
471 | 485 | ||
472 | if (wait_for_atomic_us((I915_READ_NOTRACE(FORCEWAKE_MT_ACK) & 1), 500)) | 486 | if (wait_for_atomic_us((I915_READ_NOTRACE(forcewake_ack) & 1), 500)) |
473 | DRM_ERROR("Force wake wait timed out\n"); | 487 | DRM_ERROR("Force wake wait timed out\n"); |
474 | 488 | ||
475 | __gen6_gt_wait_for_thread_c0(dev_priv); | 489 | __gen6_gt_wait_for_thread_c0(dev_priv); |
diff --git a/drivers/gpu/drm/i915/i915_reg.h b/drivers/gpu/drm/i915/i915_reg.h index 8b400e96de10..40000841b39d 100644 --- a/drivers/gpu/drm/i915/i915_reg.h +++ b/drivers/gpu/drm/i915/i915_reg.h | |||
@@ -4071,6 +4071,7 @@ | |||
4071 | #define FORCEWAKE 0xA18C | 4071 | #define FORCEWAKE 0xA18C |
4072 | #define FORCEWAKE_VLV 0x1300b0 | 4072 | #define FORCEWAKE_VLV 0x1300b0 |
4073 | #define FORCEWAKE_ACK_VLV 0x1300b4 | 4073 | #define FORCEWAKE_ACK_VLV 0x1300b4 |
4074 | #define FORCEWAKE_ACK_HSW 0x130044 | ||
4074 | #define FORCEWAKE_ACK 0x130090 | 4075 | #define FORCEWAKE_ACK 0x130090 |
4075 | #define FORCEWAKE_MT 0xa188 /* multi-threaded */ | 4076 | #define FORCEWAKE_MT 0xa188 /* multi-threaded */ |
4076 | #define FORCEWAKE_MT_ACK 0x130040 | 4077 | #define FORCEWAKE_MT_ACK 0x130040 |