Commit 9cdb826c authored by Ville Syrjälä's avatar Ville Syrjälä Committed by Daniel Vetter

drm/i915: Change i915_request power well handling

Reorganize the internal i915_request power well handling to use the
reference count just like everyone else. This way all we need to do is
check the reference count and we know whether the power well needs to be
enabled of disabled.

v2: Split he intel_display_power_{get,put} change to another patch.
    Add intel_resume_power_well() to make sure we enable the power
    well on resume
Signed-off-by: default avatarVille Syrjälä <ville.syrjala@linux.intel.com>
Reviewed-by: default avatarPaulo Zanoni <paulo.r.zanoni@intel.com>
Signed-off-by: default avatarDaniel Vetter <daniel.vetter@ffwll.ch>
parent 81c12f6e
...@@ -764,6 +764,7 @@ extern bool intel_display_power_enabled(struct drm_device *dev, ...@@ -764,6 +764,7 @@ extern bool intel_display_power_enabled(struct drm_device *dev,
enum intel_display_power_domain domain); enum intel_display_power_domain domain);
extern void intel_init_power_well(struct drm_device *dev); extern void intel_init_power_well(struct drm_device *dev);
extern void intel_set_power_well(struct drm_device *dev, bool enable); extern void intel_set_power_well(struct drm_device *dev, bool enable);
extern void intel_resume_power_well(struct drm_device *dev);
extern void intel_enable_gt_powersave(struct drm_device *dev); extern void intel_enable_gt_powersave(struct drm_device *dev);
extern void intel_disable_gt_powersave(struct drm_device *dev); extern void intel_disable_gt_powersave(struct drm_device *dev);
extern void ironlake_teardown_rc6(struct drm_device *dev); extern void ironlake_teardown_rc6(struct drm_device *dev);
......
...@@ -5354,8 +5354,7 @@ void i915_request_power_well(void) ...@@ -5354,8 +5354,7 @@ void i915_request_power_well(void)
return; return;
spin_lock_irq(&hsw_pwr->lock); spin_lock_irq(&hsw_pwr->lock);
if (!hsw_pwr->count++ && if (!hsw_pwr->count++)
!hsw_pwr->i915_request)
__intel_set_power_well(hsw_pwr->device, true); __intel_set_power_well(hsw_pwr->device, true);
spin_unlock_irq(&hsw_pwr->lock); spin_unlock_irq(&hsw_pwr->lock);
} }
...@@ -5369,8 +5368,7 @@ void i915_release_power_well(void) ...@@ -5369,8 +5368,7 @@ void i915_release_power_well(void)
spin_lock_irq(&hsw_pwr->lock); spin_lock_irq(&hsw_pwr->lock);
WARN_ON(!hsw_pwr->count); WARN_ON(!hsw_pwr->count);
if (!--hsw_pwr->count && if (!--hsw_pwr->count)
!hsw_pwr->i915_request)
__intel_set_power_well(hsw_pwr->device, false); __intel_set_power_well(hsw_pwr->device, false);
spin_unlock_irq(&hsw_pwr->lock); spin_unlock_irq(&hsw_pwr->lock);
} }
...@@ -5406,15 +5404,41 @@ void intel_set_power_well(struct drm_device *dev, bool enable) ...@@ -5406,15 +5404,41 @@ void intel_set_power_well(struct drm_device *dev, bool enable)
return; return;
spin_lock_irq(&power_well->lock); spin_lock_irq(&power_well->lock);
/*
* This function will only ever contribute one
* to the power well reference count. i915_request
* is what tracks whether we have or have not
* added the one to the reference count.
*/
if (power_well->i915_request == enable)
goto out;
power_well->i915_request = enable; power_well->i915_request = enable;
/* only reject "disable" power well request */ if (enable) {
if (power_well->count && !enable) { if (!power_well->count++)
spin_unlock_irq(&power_well->lock); __intel_set_power_well(dev, true);
return; } else {
WARN_ON(!power_well->count);
if (!--power_well->count)
__intel_set_power_well(dev, false);
} }
__intel_set_power_well(dev, enable); out:
spin_unlock_irq(&power_well->lock);
}
void intel_resume_power_well(struct drm_device *dev)
{
struct drm_i915_private *dev_priv = dev->dev_private;
struct i915_power_well *power_well = &dev_priv->power_well;
if (!HAS_POWER_WELL(dev))
return;
spin_lock_irq(&power_well->lock);
__intel_set_power_well(dev, power_well->count > 0);
spin_unlock_irq(&power_well->lock); spin_unlock_irq(&power_well->lock);
} }
...@@ -5433,6 +5457,7 @@ void intel_init_power_well(struct drm_device *dev) ...@@ -5433,6 +5457,7 @@ void intel_init_power_well(struct drm_device *dev)
/* For now, we need the power well to be always enabled. */ /* For now, we need the power well to be always enabled. */
intel_set_power_well(dev, true); intel_set_power_well(dev, true);
intel_resume_power_well(dev);
/* We're taking over the BIOS, so clear any requests made by it since /* We're taking over the BIOS, so clear any requests made by it since
* the driver is in charge now. */ * the driver is in charge now. */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment