drm/i915: enable ring freq scaling, RC6 and graphics turbo on Ivy Bridge v3
authorJesse Barnes <jbarnes@virtuousgeek.org>
Wed, 29 Jun 2011 20:34:36 +0000 (13:34 -0700)
committerKeith Packard <keithp@keithp.com>
Wed, 29 Jun 2011 20:47:29 +0000 (13:47 -0700)
They use the same register interfaces, so we can simply enable the
existing code on IVB.

v2:
  - resolve conflict with ring freq scaling, we can enable it too
v3:
  - resolve conflict again, this time on drm-intel-next

Signed-off-by: Jesse Barnes <jbarnes@virtuousgeek.org>
Signed-off-by: Keith Packard <keithp@keithp.com>
drivers/gpu/drm/i915/i915_debugfs.c
drivers/gpu/drm/i915/intel_display.c

index 8a5a032ec69611ce4f149584b6056b18a8d1cfe7..ed627307ab513596d056d89e5b1fa67c20e577be 100644 (file)
@@ -865,7 +865,7 @@ static int i915_cur_delayinfo(struct seq_file *m, void *unused)
                           MEMSTAT_VID_SHIFT);
                seq_printf(m, "Current P-state: %d\n",
                           (rgvstat & MEMSTAT_PSTATE_MASK) >> MEMSTAT_PSTATE_SHIFT);
-       } else if (IS_GEN6(dev)) {
+       } else if (IS_GEN6(dev) || IS_GEN7(dev)) {
                u32 gt_perf_status = I915_READ(GEN6_GT_PERF_STATUS);
                u32 rp_state_limits = I915_READ(GEN6_RP_STATE_LIMITS);
                u32 rp_state_cap = I915_READ(GEN6_RP_STATE_CAP);
@@ -1131,7 +1131,7 @@ static int i915_ring_freq_table(struct seq_file *m, void *unused)
        int ret;
        int gpu_freq, ia_freq;
 
-       if (!IS_GEN6(dev)) {
+       if (!(IS_GEN6(dev) || IS_GEN7(dev))) {
                seq_printf(m, "unsupported on this chipset\n");
                return 0;
        }
index 804ac4d6cb482fd5eb6367147912c72f143637af..823b8d99d9e658ba03a4b895d48471cb21e24039 100644 (file)
@@ -7970,7 +7970,7 @@ void intel_modeset_init(struct drm_device *dev)
                intel_init_emon(dev);
        }
 
-       if (IS_GEN6(dev)) {
+       if (IS_GEN6(dev) || IS_GEN7(dev)) {
                gen6_enable_rps(dev_priv);
                gen6_update_ring_freq(dev_priv);
        }
@@ -8014,7 +8014,7 @@ void intel_modeset_cleanup(struct drm_device *dev)
 
        if (IS_IRONLAKE_M(dev))
                ironlake_disable_drps(dev);
-       if (IS_GEN6(dev))
+       if (IS_GEN6(dev) || IS_GEN7(dev))
                gen6_disable_rps(dev);
 
        if (IS_IRONLAKE_M(dev))