On Mon, 14 Mar 2016 06:05:06 +0100, Subhransu S. Prusty wrote: > > 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@xxxxxxxxx> > Signed-off-by: Subhransu S. Prusty <subhransu.s.prusty@xxxxxxxxx> > Tested-by: Andreas Reis <andreas.reis@xxxxxxxxx> > Signed-off-by: Vinod Koul <vinod.koul@xxxxxxxxx> Applied, thanks. Takashi > --- > sound/pci/hda/patch_hdmi.c | 8 ++++++-- > 1 file changed, 6 insertions(+), 2 deletions(-) > > diff --git a/sound/pci/hda/patch_hdmi.c b/sound/pci/hda/patch_hdmi.c > index f59e87b..a386a65 100644 > --- a/sound/pci/hda/patch_hdmi.c > +++ b/sound/pci/hda/patch_hdmi.c > @@ -2827,8 +2827,12 @@ static int nvhdmi_chmap_cea_alloc_validate_get_type(struct hdac_chmap *chmap, > if (cap->ca_index == 0x00 && channels == 2) > return SNDRV_CTL_TLVT_CHMAP_FIXED; > > - return chmap->ops.chmap_cea_alloc_validate_get_type( > - chmap, cap, channels); > + /* If the speaker allocation matches the channel count, it is OK. */ > + 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, > -- > 1.9.1 > _______________________________________________ Alsa-devel mailing list Alsa-devel@xxxxxxxxxxxxxxxx http://mailman.alsa-project.org/mailman/listinfo/alsa-devel