[alsa-devel] [PATCH 3/5] HDA: add support for analog loopback to STAC9204/9205/922x/927x

Takashi Iwai tiwai at suse.de
Tue Aug 28 12:50:15 CEST 2007


At Tue, 28 Aug 2007 05:08:02 +0300,
Maxim Levitsky wrote:
> 
> From 204b216691b2d74e100bc321654ddadd2ff710af Mon Sep 17 00:00:00 2001
> From: Maxim Levitsky <maximlevitsky at gmail.com>
> Date: Tue, 28 Aug 2007 01:06:00 +0300
> Subject: [PATCH] HDA: add support for analog loopback to STAC9204/9205/922x/927x
> 
> ---
>  sound/pci/hda/patch_sigmatel.c |   59 ++++++++++++++++++++++++++++++++++++++++
>  1 files changed, 59 insertions(+), 0 deletions(-)
> 
> diff --git a/sound/pci/hda/patch_sigmatel.c b/sound/pci/hda/patch_sigmatel.c
> index 12b318e..a1f55d1 100644
> --- a/sound/pci/hda/patch_sigmatel.c
> +++ b/sound/pci/hda/patch_sigmatel.c
> @@ -128,6 +128,7 @@ struct sigmatel_spec {
>  	/* i/o switches */
>  	unsigned int io_switch[2];
>  	unsigned int clfe_swap;
> +	unsigned int aloopback;
>  
>  	struct hda_pcm pcm_rec[2];	/* PCM information */
>  
> @@ -277,6 +278,50 @@ static int stac92xx_mux_enum_put(struct snd_kcontrol *kcontrol, struct snd_ctl_e
>  				     spec->mux_nids[adc_idx], &spec->cur_mux[adc_idx]);
>  }
>  
> +static int stac92xx_aloopback_info(struct snd_kcontrol *kcontrol,
> +	struct snd_ctl_elem_info *uinfo)
> +{
> +	uinfo->type = SNDRV_CTL_ELEM_TYPE_BOOLEAN;
> +	uinfo->count = 1;
> +	uinfo->value.integer.min = 0;
> +	uinfo->value.integer.max = 1;
> +	return 0;
> +}

Use snd_ctl_boolean_mono_info().

> +static int stac92xx_aloopback_get(struct snd_kcontrol *kcontrol,
> +	struct snd_ctl_elem_value *ucontrol)
> +{
> +	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
> +	struct sigmatel_spec *spec = codec->spec;
> +
> +	ucontrol->value.integer.value[0] = spec->aloopback;
> +	return 0;
> +}
> +
> +static int stac92xx_aloopback_put(struct snd_kcontrol *kcontrol,
> +		struct snd_ctl_elem_value *ucontrol)
> +{
> +	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
> +	struct sigmatel_spec *spec = codec->spec;
> +	unsigned int dac_mode;
> +
> +	spec->aloopback = ucontrol->value.integer.value[0];
> +
> +	dac_mode = snd_hda_codec_read(codec, codec->afg, 0,
> +		kcontrol->private_value & 0xFFFF, 0x0);
> +
> +	if (spec->aloopback)
> +		dac_mode |= 0x40;
> +	else
> +		dac_mode &= ~0x40;
> +
> +	snd_hda_codec_write(codec, codec->afg, 0,
> +		kcontrol->private_value >> 16, dac_mode);
> +
> +	return 1;
> +}

Check the value change, and use snd_hda_codec_write_cache().



Takashi


More information about the Alsa-devel mailing list