提交 1a7f60b9 编写于 作者: T Takashi Iwai

Revert "ALSA: hda: Flush interrupts on disabling"

This reverts commit caa8422d.

It turned out that this commit caused a regression at shutdown /
reboot, as the synchronize_irq() calls seems blocking the whole
shutdown.  Also another part of the change about shuffling the call
order looks suspicious; the azx_stop_chip() call disables the CORB /
RIRB while the others may still need the CORB/RIRB update.

Since the original commit itself was a cargo-fix, let's revert the
whole patch.

Fixes: caa8422d ("ALSA: hda: Flush interrupts on disabling")
BugLink: https://bugzilla.kernel.org/show_bug.cgi?id=205333
BugLinK: https://bugs.freedesktop.org/show_bug.cgi?id=111174Signed-off-by: NTakashi Iwai <tiwai@suse.de>
Cc: Chris Wilson <chris@chris-wilson.co.uk>
Link: https://lore.kernel.org/r/20191028081056.22010-1-tiwai@suse.deSigned-off-by: NTakashi Iwai <tiwai@suse.de>
上级 f2bbdbcb
...@@ -447,8 +447,6 @@ static void azx_int_disable(struct hdac_bus *bus) ...@@ -447,8 +447,6 @@ static void azx_int_disable(struct hdac_bus *bus)
list_for_each_entry(azx_dev, &bus->stream_list, list) list_for_each_entry(azx_dev, &bus->stream_list, list)
snd_hdac_stream_updateb(azx_dev, SD_CTL, SD_INT_MASK, 0); snd_hdac_stream_updateb(azx_dev, SD_CTL, SD_INT_MASK, 0);
synchronize_irq(bus->irq);
/* disable SIE for all streams */ /* disable SIE for all streams */
snd_hdac_chip_writeb(bus, INTCTL, 0); snd_hdac_chip_writeb(bus, INTCTL, 0);
......
...@@ -1348,9 +1348,9 @@ static int azx_free(struct azx *chip) ...@@ -1348,9 +1348,9 @@ static int azx_free(struct azx *chip)
} }
if (bus->chip_init) { if (bus->chip_init) {
azx_stop_chip(chip);
azx_clear_irq_pending(chip); azx_clear_irq_pending(chip);
azx_stop_all_streams(chip); azx_stop_all_streams(chip);
azx_stop_chip(chip);
} }
if (bus->irq >= 0) if (bus->irq >= 0)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册