Message ID | 20190701074630.51472-1-rander.wang@linux.intel.com (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
Series | ALSA: hda: Fix a headphone detection issue when using SOF | expand |
On Mon, 01 Jul 2019 09:46:30 +0200, Rander Wang wrote: > > To save power, the hda hdmi driver in ASoC invokes snd_hdac_ext_bus_link_put > to disable CORB/RIRB buffers DMA if there is no user of bus and invokes > snd_hdac_ext_bus_link_get to set up CORB/RIRB buffers when it is used. > Unsolicited responses is disabled in snd_hdac_bus_stop_cmd_io called by > snd_hdac_ext_bus_link_put , but it is not enabled in snd_hdac_bus_init_cmd_io > called by snd_hdac_ext_bus_link_get. So for put-get sequence, Unsolicited > responses is disabled and headphone can't be detected by hda codecs. > > Now unsolicited responses is only enabled in snd_hdac_bus_reset_link > which resets controller. The function is only called for setup of > controller. This patch enables Unsolicited responses after RIRB is > initialized in snd_hdac_bus_init_cmd_io which works together with > snd_hdac_bus_reset_link to set up controller. > > Tested legacy hda driver and SOF driver on intel whiskeylake. > > Reviewed-by: Takashi Iwai <tiwai@suse.de> > Signed-off-by: Rander Wang <rander.wang@linux.intel.com> Applied now. Thanks. Takashi
diff --git a/sound/hda/hdac_controller.c b/sound/hda/hdac_controller.c index d6a91429c058..c24fc8d266a9 100644 --- a/sound/hda/hdac_controller.c +++ b/sound/hda/hdac_controller.c @@ -78,6 +78,8 @@ void snd_hdac_bus_init_cmd_io(struct hdac_bus *bus) snd_hdac_chip_writew(bus, RINTCNT, 1); /* enable rirb dma and response irq */ snd_hdac_chip_writeb(bus, RIRBCTL, AZX_RBCTL_DMA_EN | AZX_RBCTL_IRQ_EN); + /* Accept unsolicited responses */ + snd_hdac_chip_updatel(bus, GCTL, AZX_GCTL_UNSOL, AZX_GCTL_UNSOL); spin_unlock_irq(&bus->reg_lock); } EXPORT_SYMBOL_GPL(snd_hdac_bus_init_cmd_io); @@ -416,9 +418,6 @@ int snd_hdac_bus_reset_link(struct hdac_bus *bus, bool full_reset) return -EBUSY; } - /* Accept unsolicited responses */ - snd_hdac_chip_updatel(bus, GCTL, AZX_GCTL_UNSOL, AZX_GCTL_UNSOL); - /* detect codecs */ if (!bus->codec_mask) { bus->codec_mask = snd_hdac_chip_readw(bus, STATESTS);