Commit 2d66aef5 authored by Ville Syrjälä's avatar Ville Syrjälä Committed by Daniel Vetter

drm/i915: Refactor power well refcount inc/dec operations

We increase/decrease the power well refcount in several places now, and
all of those places need to do the same thing, so pull that code into
a few small helper functions.

v2: Rename the funcs to __intel_power_well_{get,put}
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 6765625e
...@@ -5345,6 +5345,19 @@ static void __intel_set_power_well(struct drm_device *dev, bool enable) ...@@ -5345,6 +5345,19 @@ static void __intel_set_power_well(struct drm_device *dev, bool enable)
} }
} }
static void __intel_power_well_get(struct i915_power_well *power_well)
{
if (!power_well->count++)
__intel_set_power_well(power_well->device, true);
}
static void __intel_power_well_put(struct i915_power_well *power_well)
{
WARN_ON(!power_well->count);
if (!--power_well->count)
__intel_set_power_well(power_well->device, false);
}
void intel_display_power_get(struct drm_device *dev, void intel_display_power_get(struct drm_device *dev,
enum intel_display_power_domain domain) enum intel_display_power_domain domain)
{ {
...@@ -5367,8 +5380,7 @@ void intel_display_power_get(struct drm_device *dev, ...@@ -5367,8 +5380,7 @@ void intel_display_power_get(struct drm_device *dev,
case POWER_DOMAIN_TRANSCODER_B: case POWER_DOMAIN_TRANSCODER_B:
case POWER_DOMAIN_TRANSCODER_C: case POWER_DOMAIN_TRANSCODER_C:
spin_lock_irq(&power_well->lock); spin_lock_irq(&power_well->lock);
if (!power_well->count++) __intel_power_well_get(power_well);
__intel_set_power_well(power_well->device, true);
spin_unlock_irq(&power_well->lock); spin_unlock_irq(&power_well->lock);
return; return;
default: default:
...@@ -5398,9 +5410,7 @@ void intel_display_power_put(struct drm_device *dev, ...@@ -5398,9 +5410,7 @@ void intel_display_power_put(struct drm_device *dev,
case POWER_DOMAIN_TRANSCODER_B: case POWER_DOMAIN_TRANSCODER_B:
case POWER_DOMAIN_TRANSCODER_C: case POWER_DOMAIN_TRANSCODER_C:
spin_lock_irq(&power_well->lock); spin_lock_irq(&power_well->lock);
WARN_ON(!power_well->count); __intel_power_well_put(power_well);
if (!--power_well->count)
__intel_set_power_well(power_well->device, false);
spin_unlock_irq(&power_well->lock); spin_unlock_irq(&power_well->lock);
return; return;
default: default:
...@@ -5417,8 +5427,7 @@ void i915_request_power_well(void) ...@@ -5417,8 +5427,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++) __intel_power_well_get(hsw_pwr);
__intel_set_power_well(hsw_pwr->device, true);
spin_unlock_irq(&hsw_pwr->lock); spin_unlock_irq(&hsw_pwr->lock);
} }
EXPORT_SYMBOL_GPL(i915_request_power_well); EXPORT_SYMBOL_GPL(i915_request_power_well);
...@@ -5430,9 +5439,7 @@ void i915_release_power_well(void) ...@@ -5430,9 +5439,7 @@ void i915_release_power_well(void)
return; return;
spin_lock_irq(&hsw_pwr->lock); spin_lock_irq(&hsw_pwr->lock);
WARN_ON(!hsw_pwr->count); __intel_power_well_put(hsw_pwr);
if (!--hsw_pwr->count)
__intel_set_power_well(hsw_pwr->device, false);
spin_unlock_irq(&hsw_pwr->lock); spin_unlock_irq(&hsw_pwr->lock);
} }
EXPORT_SYMBOL_GPL(i915_release_power_well); EXPORT_SYMBOL_GPL(i915_release_power_well);
...@@ -5479,14 +5486,10 @@ void intel_set_power_well(struct drm_device *dev, bool enable) ...@@ -5479,14 +5486,10 @@ void intel_set_power_well(struct drm_device *dev, bool enable)
power_well->i915_request = enable; power_well->i915_request = enable;
if (enable) { if (enable)
if (!power_well->count++) __intel_power_well_get(power_well);
__intel_set_power_well(dev, true); else
} else { __intel_power_well_put(power_well);
WARN_ON(!power_well->count);
if (!--power_well->count)
__intel_set_power_well(dev, false);
}
out: out:
spin_unlock_irq(&power_well->lock); spin_unlock_irq(&power_well->lock);
......
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