{
struct drm_i915_private *dev_priv = to_i915(display->drm);
- lockdep_assert_held(&dev_priv->irq_lock);
+ spin_lock_irq(&dev_priv->irq_lock);
if (display->irq.vlv_display_irqs_enabled)
- return;
+ goto out;
display->irq.vlv_display_irqs_enabled = true;
_vlv_display_irq_reset(display);
vlv_display_irq_postinstall(display);
}
+
+out:
+ spin_unlock_irq(&dev_priv->irq_lock);
}
void valleyview_disable_display_irqs(struct intel_display *display)
{
struct drm_i915_private *dev_priv = to_i915(display->drm);
- lockdep_assert_held(&dev_priv->irq_lock);
+ spin_lock_irq(&dev_priv->irq_lock);
if (!display->irq.vlv_display_irqs_enabled)
- return;
+ goto out;
display->irq.vlv_display_irqs_enabled = false;
if (intel_irqs_enabled(dev_priv))
_vlv_display_irq_reset(display);
+out:
+ spin_unlock_irq(&dev_priv->irq_lock);
}
void ilk_de_irq_postinstall(struct intel_display *display)
static void vlv_display_power_well_init(struct intel_display *display)
{
- struct drm_i915_private *dev_priv = to_i915(display->drm);
struct intel_encoder *encoder;
enum pipe pipe;
vlv_init_display_clock_gating(display);
- spin_lock_irq(&dev_priv->irq_lock);
valleyview_enable_display_irqs(display);
- spin_unlock_irq(&dev_priv->irq_lock);
/*
* During driver initialization/resume we can avoid restoring the
{
struct drm_i915_private *dev_priv = to_i915(display->drm);
- spin_lock_irq(&dev_priv->irq_lock);
valleyview_disable_display_irqs(display);
- spin_unlock_irq(&dev_priv->irq_lock);
/* make sure we're done processing display irqs */
intel_synchronize_irq(dev_priv);