[alsa-devel] Wrong channel order with multichannel HDMI on MCP7A

Takashi Iwai tiwai at suse.de
Mon Jul 26 11:34:36 CEST 2010


At Mon, 26 Jul 2010 11:14:17 +0200,
私 wrote:
> 
> At Sun, 25 Jul 2010 19:51:39 +0300,
> Anssi Hannula wrote:
> > 
> > Hi all!
> > 
> > I have a motherboard with NVIDIA MCP7A HDMI audio.
> > However, multichannel audio is not mapped properly into the HDMI order.
> > 
> > On 5.1, I get RL in FC, RR in LFE, FC in RL, LFE in RR.
> > 
> > Interestingly, this is not consistent with the ALSA channel order (FL FR RL RR 
> > FC LFE) being passed directly to HDMI (FL FR LFE FC RL RR). Instead it looks 
> > like there has been a waveformatex (FL FR FC LFE RL RR; windows?) => HDMI 
> > conversion instead of ALSA => HDMI.
> > 
> > Same happens for 7.1.
> > 
> > Is it possible to set the hardware to do an ALSA => HDMI conversion instead?
> > If not, we should manually compensate for this somewhere, right?
> 
> Does the patch below change anything?

Ah crap, it should be irrelevant.
Wei, don't MCP 7x chips support the channel mapping as MCP 89?


thanks,

Takashi


> > Somewhat relatedly, trying to output 4 channels results in silence only. 
> 
> Although 5.1/7.1 work?
> 
> > Trying to output 3 or 5 channels triggers a timeout with I/O error, with the 
> > following in the kernel log: "ALSA pcm_lib.c:1757: playback write error (DMA 
> > or IRQ trouble?)"
> 
> HD-audio doesn't support the odd number of channels in general, so
> they should be played as 4 or 6 channels.  But, it looks like
> something wrong in the setup...
> 
> 
> thanks,
> 
> Takashi
> 
> ---
> diff --git a/sound/pci/hda/patch_nvhdmi.c b/sound/pci/hda/patch_nvhdmi.c
> index 3c10c0b..7355c60 100644
> --- a/sound/pci/hda/patch_nvhdmi.c
> +++ b/sound/pci/hda/patch_nvhdmi.c
> @@ -511,6 +511,8 @@ static int patch_nvhdmi_8ch_7x(struct hda_codec *codec)
>  
>  	codec->patch_ops = nvhdmi_patch_ops_8ch_7x;
>  
> +	init_channel_allocations();
> +
>  	return 0;
>  }
>  


More information about the Alsa-devel mailing list