[alsa-devel] [PATCHv2] TWL4030: hands-free start-up sequence.

stanley.miao stanley.miao at windriver.com
Thu Dec 11 16:32:48 CET 2008


Changes from last version:

1, clear the bits explicitly.

Stanley.

On Thu, 2008-12-11 at 23:28 +0800, Stanley.Miao wrote:
> A special start-up sequence is required to reduce the pop-noise of Class D
> amplifier when enable hands-free on TWL4030.
> 
> Signed-off-by: Stanley.Miao <stanley.miao at windriver.com>
> ---
>  sound/soc/codecs/twl4030.c |   34 ++++++++++++++++++++++++++++++----
>  sound/soc/codecs/twl4030.h |    6 ++++++
>  2 files changed, 36 insertions(+), 4 deletions(-)
> 
> diff --git a/sound/soc/codecs/twl4030.c b/sound/soc/codecs/twl4030.c
> index 1377302..5184888 100644
> --- a/sound/soc/codecs/twl4030.c
> +++ b/sound/soc/codecs/twl4030.c
> @@ -322,6 +322,30 @@ static int outmixer_event(struct snd_soc_dapm_widget *w,
>  	return ret;
>  }
>  
> +static int handsfree_event(struct snd_soc_dapm_widget *w,
> +		struct snd_kcontrol *kcontrol, int event)
> +{
> +	struct soc_enum *e = (struct soc_enum *)w->kcontrols->private_value;
> +	unsigned char hs_ctl;
> +
> +	hs_ctl = twl4030_read_reg_cache(w->codec, e->reg);
> +
> +	if (hs_ctl & TWL4030_HF_CTL_REF_EN) {
> +		hs_ctl |= TWL4030_HF_CTL_RAMP_EN;
> +		twl4030_write(w->codec, e->reg, hs_ctl);
> +		hs_ctl |= TWL4030_HF_CTL_LOOP_EN;
> +		twl4030_write(w->codec, e->reg, hs_ctl);
> +		hs_ctl |= TWL4030_HF_CTL_HB_EN;
> +		twl4030_write(w->codec, e->reg, hs_ctl);
> +	} else {
> +		hs_ctl &= ~(TWL4030_HF_CTL_RAMP_EN | TWL4030_HF_CTL_LOOP_EN
> +				| TWL4030_HF_CTL_HB_EN);
> +		twl4030_write(w->codec, e->reg, hs_ctl);
> +	}
> +
> +	return 0;
> +}
> +
>  /*
>   * Some of the gain controls in TWL (mostly those which are associated with
>   * the outputs) are implemented in an interesting way:
> @@ -806,10 +830,12 @@ static const struct snd_soc_dapm_widget twl4030_dapm_widgets[] = {
>  	SND_SOC_DAPM_MUX("CarkitR Mux", SND_SOC_NOPM, 0, 0,
>  		&twl4030_dapm_carkitr_control),
>  	/* HandsfreeL/R */
> -	SND_SOC_DAPM_MUX("HandsfreeL Mux", TWL4030_REG_HFL_CTL, 5, 0,
> -		&twl4030_dapm_handsfreel_control),
> -	SND_SOC_DAPM_MUX("HandsfreeR Mux", TWL4030_REG_HFR_CTL, 5, 0,
> -		&twl4030_dapm_handsfreer_control),
> +	SND_SOC_DAPM_MUX_E("HandsfreeL Mux", TWL4030_REG_HFL_CTL, 5, 0,
> +		&twl4030_dapm_handsfreel_control, handsfree_event,
> +		SND_SOC_DAPM_POST_PMU|SND_SOC_DAPM_POST_PMD),
> +	SND_SOC_DAPM_MUX_E("HandsfreeR Mux", TWL4030_REG_HFR_CTL, 5, 0,
> +		&twl4030_dapm_handsfreer_control, handsfree_event,
> +		SND_SOC_DAPM_POST_PMU|SND_SOC_DAPM_POST_PMD),
>  
>  	SND_SOC_DAPM_ADC("ADCL", "Left Capture", SND_SOC_NOPM, 0, 0),
>  	SND_SOC_DAPM_ADC("ADCR", "Right Capture", SND_SOC_NOPM, 0, 0),
> diff --git a/sound/soc/codecs/twl4030.h b/sound/soc/codecs/twl4030.h
> index a2065d4..54615c7 100644
> --- a/sound/soc/codecs/twl4030.h
> +++ b/sound/soc/codecs/twl4030.h
> @@ -191,6 +191,12 @@
>  #define TWL4030_RAMP_DELAY_2581MS	0x1C
>  #define TWL4030_RAMP_EN			0x02
>  
> +/* HFL_CTL (0x29, 0x2A) Fields */
> +#define TWL4030_HF_CTL_HB_EN		0x04
> +#define TWL4030_HF_CTL_LOOP_EN		0x08
> +#define TWL4030_HF_CTL_RAMP_EN		0x10
> +#define TWL4030_HF_CTL_REF_EN		0x20
> +
>  /* APLL_CTL (0x3A) Fields */
>  
>  #define TWL4030_APLL_EN			0x10


More information about the Alsa-devel mailing list