[alsa-devel] [PATCHv4 3/7] ASoC: TWL6030: Manual power-up/down sequences
Olaya, Margarita
magi.olaya at ti.com
Thu Feb 25 00:42:20 CET 2010
> -----Original Message-----
> From: Liam Girdwood [mailto:lrg at slimlogic.co.uk]
> Sent: Wednesday, February 24, 2010 4:41 AM
> To: Olaya, Margarita
> Cc: alsa-devel at alsa-project.org; linux-omap at vger.kernel.org; broonie at opensource.wolfsonmicro.com
> Subject: Re: [PATCHv4 3/7] ASoC: TWL6030: Manual power-up/down sequences
>
> On Tue, 2010-02-23 at 18:10 -0600, Olaya, Margarita wrote:
> > From: Misael Lopez Cruz <x0052729 at ti.com>
> >
> > TWL6030 codec device can be powered-up/down through a specific register
> > writes sequence. These sequences can be used when no gpio line is
> > provided for AUDPWRON.
> >
> > When the codec is powered-up in this way, automatic power-down sequence
> > (triggered by thermal shutdown) is not possible.
> >
> > Signed-off-by: Misael Lopez Cruz <x0052729 at ti.com>
> > Signed-off-by: Jorge Eduardo Candelaria <jorge.candelaria at ti.com>
> > Signed-off-by: Margarita Olaya Cabrera <magi.olaya at ti.com>
> > ---
> > sound/soc/codecs/twl6030.c | 112 ++++++++++++++++++++++++++++++++++++++-----
> > sound/soc/codecs/twl6030.h | 16 ++++++
> > 2 files changed, 115 insertions(+), 13 deletions(-)
> >
> > diff --git a/sound/soc/codecs/twl6030.c b/sound/soc/codecs/twl6030.c
> > index 8b52aa1..ec838b1 100644
> > --- a/sound/soc/codecs/twl6030.c
> > +++ b/sound/soc/codecs/twl6030.c
> > @@ -244,6 +244,88 @@ static void twl6030_init_vdd_regs(struct snd_soc_codec *codec)
> > }
> > }
> >
> > +/* twl6030 codec manual power-up sequence */
> > +static void twl6030_power_up(struct snd_soc_codec *codec)
> > +{
> > + u8 ncpctl, ldoctl, lppllctl, accctl;
> > +
> > + ncpctl = twl6030_read_reg_cache(codec, TWL6030_REG_NCPCTL);
> > + ldoctl = twl6030_read_reg_cache(codec, TWL6030_REG_LDOCTL);
> > + lppllctl = twl6030_read_reg_cache(codec, TWL6030_REG_LPPLLCTL);
> > + accctl = twl6030_read_reg_cache(codec, TWL6030_REG_ACCCTL);
> > +
> > + /* enable reference system */
> > + ldoctl |= TWL6030_REFENA;
> > + twl6030_write(codec, TWL6030_REG_LDOCTL, ldoctl);
> > + mdelay(10);
> > + /* enable internal oscillator */
> > + ldoctl |= TWL6030_OSCENA;
> > + twl6030_write(codec, TWL6030_REG_LDOCTL, ldoctl);
> > + udelay(10);
> > + /* enable high-side ldo */
> > + ldoctl |= TWL6030_HSLDOENA;
> > + twl6030_write(codec, TWL6030_REG_LDOCTL, ldoctl);
> > + udelay(244);
> > + /* enable negative charge pump */
> > + ncpctl |= TWL6030_NCPENA | TWL6030_NCPOPEN;
> > + twl6030_write(codec, TWL6030_REG_NCPCTL, ncpctl);
> > + udelay(488);
> > + /* enable low-side ldo */
> > + ldoctl |= TWL6030_LSLDOENA;
> > + twl6030_write(codec, TWL6030_REG_LDOCTL, ldoctl);
> > + udelay(244);
> > + /* enable low-power pll */
> > + lppllctl |= TWL6030_LPLLENA;
> > + twl6030_write(codec, TWL6030_REG_LPPLLCTL, lppllctl);
> > + /* reset state machine */
> > + accctl |= TWL6030_RESETSPLIT;
> > + twl6030_write(codec, TWL6030_REG_ACCCTL, accctl);
> > + mdelay(5);
> > + accctl &= ~TWL6030_RESETSPLIT;
> > + twl6030_write(codec, TWL6030_REG_ACCCTL, accctl);
> > + /* disable internal oscillator */
> > + ldoctl &= ~TWL6030_OSCENA;
> > + twl6030_write(codec, TWL6030_REG_LDOCTL, ldoctl);
> > +}
> > +
> > +/* twl6030 codec manual power-down sequence */
> > +static void twl6030_power_down(struct snd_soc_codec *codec)
> > +{
> > + u8 ncpctl, ldoctl, lppllctl, accctl;
> > +
> > + ncpctl = twl6030_read_reg_cache(codec, TWL6030_REG_NCPCTL);
> > + ldoctl = twl6030_read_reg_cache(codec, TWL6030_REG_LDOCTL);
> > + lppllctl = twl6030_read_reg_cache(codec, TWL6030_REG_LPPLLCTL);
> > + accctl = twl6030_read_reg_cache(codec, TWL6030_REG_ACCCTL);
> > +
> > + /* enable internal oscillator */
> > + ldoctl |= TWL6030_OSCENA;
> > + twl6030_write(codec, TWL6030_REG_LDOCTL, ldoctl);
> > + udelay(10);
> > + /* disable low-power pll */
> > + lppllctl &= ~TWL6030_LPLLENA;
> > + twl6030_write(codec, TWL6030_REG_LPPLLCTL, lppllctl);
> > + /* disable low-side ldo */
> > + ldoctl &= ~TWL6030_LSLDOENA;
> > + twl6030_write(codec, TWL6030_REG_LDOCTL, ldoctl);
> > + udelay(244);
> > + /* disable negative charge pump */
> > + ncpctl &= ~(TWL6030_NCPENA | TWL6030_NCPOPEN);
> > + twl6030_write(codec, TWL6030_REG_NCPCTL, ncpctl);
> > + udelay(488);
> > + /* disable high-side ldo */
> > + ldoctl &= ~TWL6030_HSLDOENA;
> > + twl6030_write(codec, TWL6030_REG_LDOCTL, ldoctl);
> > + udelay(244);
> > + /* disable internal oscillator */
> > + ldoctl &= ~TWL6030_OSCENA;
> > + twl6030_write(codec, TWL6030_REG_LDOCTL, ldoctl);
> > + /* disable reference system */
> > + ldoctl &= ~TWL6030_REFENA;
> > + twl6030_write(codec, TWL6030_REG_LDOCTL, ldoctl);
> > + mdelay(10);
> > +}
> > +
> > /*
>
>
> Some large mdelays here again.
>
> Liam
Ok, I'll verify and change them.
- Margarita
>
> --
> Freelance Developer, SlimLogic Ltd
> ASoC and Voltage Regulator Maintainer.
> http://www.slimlogic.co.uk
More information about the Alsa-devel
mailing list