diff options
author | Takashi Iwai <tiwai@suse.de> | 2017-01-12 17:13:21 +0100 |
---|---|---|
committer | Takashi Iwai <tiwai@suse.de> | 2017-01-15 09:09:04 +0100 |
commit | 41438f1314b0f6f4d94edc56bb5bc77138445bb3 (patch) | |
tree | 51798b8b53730b4d8d7de9d5384ba4fd6cd6b896 /sound/pci/hda/hda_controller.h | |
parent | ALSA: oxfw: enclose identifiers referred by single function for scs1x feature (diff) | |
download | linux-41438f1314b0f6f4d94edc56bb5bc77138445bb3.tar.xz linux-41438f1314b0f6f4d94edc56bb5bc77138445bb3.zip |
ALSA: hda - Make single_cmd option to stop the fallback mechanism
HD-audio driver has a mechanism to fall back to the single cmd mode as
a last resort if the CORB/RIRB communication goes wrong even after
switching to the polling mode. The switching has worked in the past
well, but Enrico Mioso reported that his system crashes when this
happens.
Although the actual cause of the crash isn't still fully analyzed yet,
it'd be in anyway good to provide an option to turn off the fallback
mode. Now this patch extends the behavior of the existing single_cmd
option for that. Namely,
- The option is changed from bool to bint.
- As default, it is the mode allowing the fallback to single cmd.
- Once when either true/false value is given to the option, the driver
explicitly turns on/off the single cmd mode, but without the
fallback.
That is, if you want to disable the fallback, just pass single_cmd=0
option. Passing single_cmd=1 will keep working like before.
Signed-off-by: Takashi Iwai <tiwai@suse.de>
Diffstat (limited to 'sound/pci/hda/hda_controller.h')
-rw-r--r-- | sound/pci/hda/hda_controller.h | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/sound/pci/hda/hda_controller.h b/sound/pci/hda/hda_controller.h index a50e0532622a..35a9ab2cac46 100644 --- a/sound/pci/hda/hda_controller.h +++ b/sound/pci/hda/hda_controller.h @@ -150,6 +150,7 @@ struct azx { int bdl_pos_adj; int poll_count; unsigned int running:1; + unsigned int fallback_to_single_cmd:1; unsigned int single_cmd:1; unsigned int polling_mode:1; unsigned int msi:1; |