[alsa-devel] [PATCH v7 3/3] ASoC: da7210: Add support for line input and mic

Girdwood, Liam lrg at ti.com
Thu Oct 20 19:01:55 CEST 2011


On 20 October 2011 15:42, Ashish Chavan <ashish.chavan at kpitcummins.com> wrote:
> DA7210 has three line inputs (AUX1 Left, AUX1 Right and AUX2) and
> a stereo MIC. This patch adds gain controls for MIC, AUX1, AUX2 as
> well as INPGA. It also adds a control to set  MIC BIAS voltage.
>
> Signed-off-by: Ashish Chavan <ashish.chavan at kpitcummins.com>
> Signed-off-by: David Dajun Chen <dchen at diasemi.com>
> ---
> Changes since v2:
> - Removed static enable of mic and aux, as now DAPM will take care of
> that
>
> Changes since v1:
> - Removed explicit setting of default gains
> - Removed control to set mic bias voltage
> ---
>  sound/soc/codecs/da7210.c |   32 ++++++++++++++++++++++++++++++++
>  1 files changed, 32 insertions(+), 0 deletions(-)
>
> diff --git a/sound/soc/codecs/da7210.c b/sound/soc/codecs/da7210.c
> index eaec60a..2f38b39 100644
> --- a/sound/soc/codecs/da7210.c
> +++ b/sound/soc/codecs/da7210.c
> @@ -181,9 +181,14 @@
>
>  /* AUX1_L bit fields */
>  #define DA7210_AUX1_L_VOL              (0x3F << 0)
> +#define DA7210_AUX1_L_EN               (1 << 7)
>
>  /* AUX1_R bit fields */
>  #define DA7210_AUX1_R_VOL              (0x3F << 0)
> +#define DA7210_AUX1_R_EN               (1 << 7)
> +
> +/* AUX2 bit fields */
> +#define DA7210_AUX2_EN                 (1 << 3)
>
>  /* Minimum INPGA and AUX1 volume to enable noise suppression */
>  #define DA7210_INPGA_MIN_VOL_NS                0x0A  /* 10.5dB */
> @@ -234,9 +239,19 @@ static const unsigned int mono_vol_tlv[] = {
>        0x3, 0x7, TLV_DB_SCALE_ITEM(-1800, 600, 0)
>  };
>
> +static const unsigned int aux1_vol_tlv[] = {
> +       TLV_DB_RANGE_HEAD(2),
> +       0x0, 0x10, TLV_DB_SCALE_ITEM(TLV_DB_GAIN_MUTE, 0, 1),
> +       /* -48dB to 21dB */
> +       0x11, 0x3f, TLV_DB_SCALE_ITEM(-4800, 150, 0)
> +};
> +
>  static const DECLARE_TLV_DB_SCALE(eq_gain_tlv, -1050, 150, 0);
>  static const DECLARE_TLV_DB_SCALE(adc_eq_master_gain_tlv, -1800, 600, 1);
>  static const DECLARE_TLV_DB_SCALE(dac_gain_tlv, -7725, 75, 0);
> +static const DECLARE_TLV_DB_SCALE(mic_vol_tlv, -600, 600, 0);
> +static const DECLARE_TLV_DB_SCALE(aux2_vol_tlv, -600, 600, 0);
> +static const DECLARE_TLV_DB_SCALE(inpga_gain_tlv, -450, 150, 0);
>
>  /* ADC and DAC high pass filter f0 value */
>  static const char const *da7210_hpf_cutoff_txt[] = {
> @@ -344,6 +359,17 @@ static const struct snd_kcontrol_new da7210_snd_controls[] = {
>        SOC_SINGLE_TLV("Mono Playback Volume", DA7210_OUT2, 0, 0x7, 0,
>                       mono_vol_tlv),
>
> +       SOC_DOUBLE_R_TLV("Mic Capture Volume",
> +                        DA7210_MIC_L, DA7210_MIC_R,
> +                        0, 0x5, 0, mic_vol_tlv),
> +       SOC_DOUBLE_R_TLV("Aux1 Capture Volume",
> +                        DA7210_AUX1_L, DA7210_AUX1_R,
> +                        0, 0x3f, 0, aux1_vol_tlv),
> +       SOC_SINGLE_TLV("Aux2 Capture Volume", DA7210_AUX2, 0, 0x3, 0,
> +                      aux2_vol_tlv),
> +       SOC_DOUBLE_TLV("In PGA Capture Volume", DA7210_IN_GAIN, 0, 4, 0xF, 0,
> +                      inpga_gain_tlv),
> +
>        /* DAC Equalizer  controls */
>        SOC_SINGLE("DAC EQ Switch", DA7210_DAC_EQ5, 7, 1, 0),
>        SOC_SINGLE_TLV("DAC EQ1 Volume", DA7210_DAC_EQ1_2, 0, 0xf, 1,
> @@ -928,6 +954,12 @@ static int da7210_probe(struct snd_soc_codec *codec)
>        snd_soc_write(codec, DA7210_OUT2, DA7210_OUT2_EN |
>                     DA7210_OUT2_OUTMIX_L | DA7210_OUT2_OUTMIX_R);
>
> +       /* Enable Aux1 */
> +       snd_soc_write(codec, DA7210_AUX1_L, DA7210_AUX1_L_EN);
> +       snd_soc_write(codec, DA7210_AUX1_R, DA7210_AUX1_R_EN);
> +       /* Enable Aux2 */
> +       snd_soc_write(codec, DA7210_AUX2, DA7210_AUX2_EN);
> +

Your comment states this is now done by DAPM ?

Thanks

Liam


>        /* Diable PLL and bypass it */
>        snd_soc_write(codec, DA7210_PLL, DA7210_PLL_FS_48000);
>
> --
> 1.7.1
>
>
>


More information about the Alsa-devel mailing list