[alsa-devel] [PATCH] [PATCH v2] ALSA: hda: Retry codec read on first time failure
Takashi Iwai
tiwai at suse.de
Fri Aug 30 07:38:49 CEST 2019
On Fri, 30 Aug 2019 07:23:18 +0200,
vani.ganji at intel.com wrote:
>
> From: Vani Ganji <vani.ganji at intel.com>
>
> Sometimes HDMI audio fails while fast switching
> between HDMI and Speaker due to codec Get Power state verb read failure.
>
> Verb is codec driver to access codec HW. Since issue scenario involves
> fast switching between HDMI and speaker, there might be chance to fail
> read from HW and same happened in the error scenario.
>
> Based on Display/Graphics architect suggestion, added a retry mechanism
> for failure on first attempt.
>
> Changes from v1:
> -Corrected missing braces.
>
> Signed-off-by: Vani Ganji <vani.ganji at intel.com>
Do you still need this even with the very latest upstream code?
As mentioned, the recent change to use the sync-write should reduce
such errors.
If it's about the SOF/SST, you can try to set the hdac_bus.sync_write
flag in the corresponding drivers, too.
thanks,
Takashi
> ---
> sound/hda/hdac_device.c | 15 +++++++++++----
> 1 file changed, 11 insertions(+), 4 deletions(-)
>
> diff --git a/sound/hda/hdac_device.c b/sound/hda/hdac_device.c
> index b26cc93e7e10..3874d54aa686 100644
> --- a/sound/hda/hdac_device.c
> +++ b/sound/hda/hdac_device.c
> @@ -984,10 +984,17 @@ static unsigned int codec_read(struct hdac_device *hdac, hda_nid_t nid,
> {
> unsigned int cmd = snd_hdac_make_cmd(hdac, nid, verb, parm);
> unsigned int res;
> -
> - if (snd_hdac_exec_verb(hdac, cmd, flags, &res))
> - return -1;
> -
> + unsigned int count;
> +
> + /* Retry verb once more if it fails first time */
> + /* recommended to retry since it is HW related */
> + for (count = 0; count <= 1; count++) {
> + if (snd_hdac_exec_verb(hdac, cmd, flags, &res)) {
> + if (count == 1)
> + return -1;
> + } else
> + break;
> + }
> return res;
> }
>
> --
> 2.17.1
>
> _______________________________________________
> Alsa-devel mailing list
> Alsa-devel at alsa-project.org
> https://mailman.alsa-project.org/mailman/listinfo/alsa-devel
>
More information about the Alsa-devel
mailing list