diff options
author | Jesse Barnes <jbarnes@virtuousgeek.org> | 2009-08-17 16:31:43 -0400 |
---|---|---|
committer | Eric Anholt <eric@anholt.net> | 2009-09-04 16:05:38 -0400 |
commit | 652c393a3368af84359da37c45afc35a91144960 (patch) | |
tree | 35f76866301f0ee61819d6265068ca548d119c0e /drivers/gpu/drm/i915/intel_bios.c | |
parent | 043029655816ed4cfc2ed247020ef97e5d637392 (diff) |
drm/i915: add dynamic clock frequency control
There are several sources of unnecessary power consumption on Intel
graphics systems. The first is the LVDS clock. TFTs don't suffer from
persistence issues like CRTs, and so we can reduce the LVDS refresh rate
when the screen is idle. It will be automatically upclocked when
userspace triggers graphical activity. Beyond that, we can enable memory
self refresh. This allows the memory to go into a lower power state when
the graphics are idle. Finally, we can drop some clocks on the gpu
itself. All of these things can be reenabled between frames when GPU
activity is triggered, and so there should be no user visible graphical
changes.
Signed-off-by: Jesse Barnes <jesse.barnes@intel.com>
Signed-off-by: Matthew Garrett <mjg@redhat.com>
Signed-off-by: Eric Anholt <eric@anholt.net>
Diffstat (limited to 'drivers/gpu/drm/i915/intel_bios.c')
-rw-r--r-- | drivers/gpu/drm/i915/intel_bios.c | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/drivers/gpu/drm/i915/intel_bios.c b/drivers/gpu/drm/i915/intel_bios.c index f806fcc54e09..1e28c1652fd0 100644 --- a/drivers/gpu/drm/i915/intel_bios.c +++ b/drivers/gpu/drm/i915/intel_bios.c | |||
@@ -355,8 +355,14 @@ parse_driver_features(struct drm_i915_private *dev_priv, | |||
355 | } | 355 | } |
356 | 356 | ||
357 | driver = find_section(bdb, BDB_DRIVER_FEATURES); | 357 | driver = find_section(bdb, BDB_DRIVER_FEATURES); |
358 | if (driver && driver->lvds_config == BDB_DRIVER_FEATURE_EDP) | 358 | if (!driver) |
359 | return; | ||
360 | |||
361 | if (driver->lvds_config == BDB_DRIVER_FEATURE_EDP) | ||
359 | dev_priv->edp_support = 1; | 362 | dev_priv->edp_support = 1; |
363 | |||
364 | if (driver->dual_frequency) | ||
365 | dev_priv->render_reclock_avail = true; | ||
360 | } | 366 | } |
361 | 367 | ||
362 | /** | 368 | /** |