ALSA: hda - Fixes double fault in nvhdmi_chmap_cea_alloc_validate_get_type
nvhdmi_chmap_cea_alloc_validate_get_type calls itself recursively
using chmap ops causing the double fault.
Fixed by adding the default validate_get_type handling inside nvdia
validate_get_type handler.
Link: https://bugzilla.kernel.org/show_bug.cgi?id=114311
Fixes: 67b90cb
("ALSA: hda - Create common chmap object")
Reported-by: Andreas Reis <andreas.reis@gmail.com>
Signed-off-by: Subhransu S. Prusty <subhransu.s.prusty@intel.com>
Tested-by: Andreas Reis <andreas.reis@gmail.com>
Signed-off-by: Vinod Koul <vinod.koul@intel.com>
Signed-off-by: Takashi Iwai <tiwai@suse.de>
This commit is contained in:
Родитель
4061db03dd
Коммит
028cb68ee3
|
@ -2836,8 +2836,12 @@ static int nvhdmi_chmap_cea_alloc_validate_get_type(struct hdac_chmap *chmap,
|
||||||
if (cap->ca_index == 0x00 && channels == 2)
|
if (cap->ca_index == 0x00 && channels == 2)
|
||||||
return SNDRV_CTL_TLVT_CHMAP_FIXED;
|
return SNDRV_CTL_TLVT_CHMAP_FIXED;
|
||||||
|
|
||||||
return chmap->ops.chmap_cea_alloc_validate_get_type(
|
/* If the speaker allocation matches the channel count, it is OK. */
|
||||||
chmap, cap, channels);
|
if (cap->channels != channels)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
/* all channels are remappable freely */
|
||||||
|
return SNDRV_CTL_TLVT_CHMAP_VAR;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int nvhdmi_chmap_validate(struct hdac_chmap *chmap,
|
static int nvhdmi_chmap_validate(struct hdac_chmap *chmap,
|
||||||
|
|
Загрузка…
Ссылка в новой задаче