drm/i915: Stop pretending to mask/unmask LPE audio interrupts
vlv_display_irq_postinstall() enables the LPE audio interrupts regardless of whether the LPE audio irq chip has masked/unmasked them. Also the irqchip masking/unmasking doesn't consider the state of the display power well or the device, and hence just leads to dmesg spew when it tries to access the hardware while it's powered down. If the current way works, then we don't need to do anything in the mask/unmask hooks. If it doesn't work, well, then we'd need to properly track whether the irqchip has masked/unmasked the interrupts when we enable display interrupts. And the mask/unmask hooks would need to check whether display interrupts are even enabled before frobbing with he registers. So let's just assume the current way works and neuter the mask/unmask hooks. Also clean up vlv_display_irq_postinstall() a bit and stop it from trying to unmask/enable the LPE C interrupt on VLV since it doesn't exist. Cc: Takashi Iwai <tiwai@suse.de> Cc: Pierre-Louis Bossart <pierre-louis.bossart@linux.intel.com> Signed-off-by: Ville Syrjälä <ville.syrjala@linux.intel.com> Link: http://patchwork.freedesktop.org/patch/msgid/20170427160231.13337-4-ville.syrjala@linux.intel.com Reviewed-by: Takashi Iwai <tiwai@suse.de>
This commit is contained in:
parent
8d5c30308d
commit
ebf5f92147
|
@ -2953,7 +2953,6 @@ static void vlv_display_irq_postinstall(struct drm_i915_private *dev_priv)
|
||||||
u32 pipestat_mask;
|
u32 pipestat_mask;
|
||||||
u32 enable_mask;
|
u32 enable_mask;
|
||||||
enum pipe pipe;
|
enum pipe pipe;
|
||||||
u32 val;
|
|
||||||
|
|
||||||
pipestat_mask = PLANE_FLIP_DONE_INT_STATUS_VLV |
|
pipestat_mask = PLANE_FLIP_DONE_INT_STATUS_VLV |
|
||||||
PIPE_CRC_DONE_INTERRUPT_STATUS;
|
PIPE_CRC_DONE_INTERRUPT_STATUS;
|
||||||
|
@ -2964,18 +2963,16 @@ static void vlv_display_irq_postinstall(struct drm_i915_private *dev_priv)
|
||||||
|
|
||||||
enable_mask = I915_DISPLAY_PORT_INTERRUPT |
|
enable_mask = I915_DISPLAY_PORT_INTERRUPT |
|
||||||
I915_DISPLAY_PIPE_A_EVENT_INTERRUPT |
|
I915_DISPLAY_PIPE_A_EVENT_INTERRUPT |
|
||||||
I915_DISPLAY_PIPE_B_EVENT_INTERRUPT;
|
I915_DISPLAY_PIPE_B_EVENT_INTERRUPT |
|
||||||
|
I915_LPE_PIPE_A_INTERRUPT |
|
||||||
|
I915_LPE_PIPE_B_INTERRUPT;
|
||||||
|
|
||||||
if (IS_CHERRYVIEW(dev_priv))
|
if (IS_CHERRYVIEW(dev_priv))
|
||||||
enable_mask |= I915_DISPLAY_PIPE_C_EVENT_INTERRUPT;
|
enable_mask |= I915_DISPLAY_PIPE_C_EVENT_INTERRUPT |
|
||||||
|
I915_LPE_PIPE_C_INTERRUPT;
|
||||||
|
|
||||||
WARN_ON(dev_priv->irq_mask != ~0);
|
WARN_ON(dev_priv->irq_mask != ~0);
|
||||||
|
|
||||||
val = (I915_LPE_PIPE_A_INTERRUPT |
|
|
||||||
I915_LPE_PIPE_B_INTERRUPT |
|
|
||||||
I915_LPE_PIPE_C_INTERRUPT);
|
|
||||||
|
|
||||||
enable_mask |= val;
|
|
||||||
|
|
||||||
dev_priv->irq_mask = ~enable_mask;
|
dev_priv->irq_mask = ~enable_mask;
|
||||||
|
|
||||||
GEN5_IRQ_INIT(VLV_, dev_priv->irq_mask, enable_mask);
|
GEN5_IRQ_INIT(VLV_, dev_priv->irq_mask, enable_mask);
|
||||||
|
|
|
@ -149,44 +149,10 @@ static void lpe_audio_platdev_destroy(struct drm_i915_private *dev_priv)
|
||||||
|
|
||||||
static void lpe_audio_irq_unmask(struct irq_data *d)
|
static void lpe_audio_irq_unmask(struct irq_data *d)
|
||||||
{
|
{
|
||||||
struct drm_i915_private *dev_priv = d->chip_data;
|
|
||||||
unsigned long irqflags;
|
|
||||||
u32 val = (I915_LPE_PIPE_A_INTERRUPT |
|
|
||||||
I915_LPE_PIPE_B_INTERRUPT);
|
|
||||||
|
|
||||||
if (IS_CHERRYVIEW(dev_priv))
|
|
||||||
val |= I915_LPE_PIPE_C_INTERRUPT;
|
|
||||||
|
|
||||||
spin_lock_irqsave(&dev_priv->irq_lock, irqflags);
|
|
||||||
|
|
||||||
dev_priv->irq_mask &= ~val;
|
|
||||||
I915_WRITE(VLV_IIR, val);
|
|
||||||
I915_WRITE(VLV_IIR, val);
|
|
||||||
I915_WRITE(VLV_IMR, dev_priv->irq_mask);
|
|
||||||
POSTING_READ(VLV_IMR);
|
|
||||||
|
|
||||||
spin_unlock_irqrestore(&dev_priv->irq_lock, irqflags);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void lpe_audio_irq_mask(struct irq_data *d)
|
static void lpe_audio_irq_mask(struct irq_data *d)
|
||||||
{
|
{
|
||||||
struct drm_i915_private *dev_priv = d->chip_data;
|
|
||||||
unsigned long irqflags;
|
|
||||||
u32 val = (I915_LPE_PIPE_A_INTERRUPT |
|
|
||||||
I915_LPE_PIPE_B_INTERRUPT);
|
|
||||||
|
|
||||||
if (IS_CHERRYVIEW(dev_priv))
|
|
||||||
val |= I915_LPE_PIPE_C_INTERRUPT;
|
|
||||||
|
|
||||||
spin_lock_irqsave(&dev_priv->irq_lock, irqflags);
|
|
||||||
|
|
||||||
dev_priv->irq_mask |= val;
|
|
||||||
I915_WRITE(VLV_IMR, dev_priv->irq_mask);
|
|
||||||
I915_WRITE(VLV_IIR, val);
|
|
||||||
I915_WRITE(VLV_IIR, val);
|
|
||||||
POSTING_READ(VLV_IIR);
|
|
||||||
|
|
||||||
spin_unlock_irqrestore(&dev_priv->irq_lock, irqflags);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct irq_chip lpe_audio_irqchip = {
|
static struct irq_chip lpe_audio_irqchip = {
|
||||||
|
@ -330,8 +296,6 @@ void intel_lpe_audio_teardown(struct drm_i915_private *dev_priv)
|
||||||
|
|
||||||
desc = irq_to_desc(dev_priv->lpe_audio.irq);
|
desc = irq_to_desc(dev_priv->lpe_audio.irq);
|
||||||
|
|
||||||
lpe_audio_irq_mask(&desc->irq_data);
|
|
||||||
|
|
||||||
lpe_audio_platdev_destroy(dev_priv);
|
lpe_audio_platdev_destroy(dev_priv);
|
||||||
|
|
||||||
irq_free_desc(dev_priv->lpe_audio.irq);
|
irq_free_desc(dev_priv->lpe_audio.irq);
|
||||||
|
|
Loading…
Reference in New Issue