mirror of
https://github.com/adulau/aha.git
synced 2024-12-31 21:26:18 +00:00
ASoC: tlv320aic3x: Enable PLL when not bypassed
PLL was not being enabled when it was not bypassed. This patch enables the PLL when it is used. Additionally, it disables the PLL when it is bypassed. Without this patch, the audio on TI DM646x EVM and DM355 EVM does not work properly. The bit clocks and the frame sync signals from the codec are not correct and hence the playback/record are faster than usual for most sample rates. The reason for this was that the PLL was not enabled when it was not bypassed. Tested on DM6467 EVM, playback tested on DM355 EVM. Signed-off-by: Chaithrika U S <chaithrika@ti.com> Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
This commit is contained in:
parent
b7d4de7ff0
commit
06c71282a9
1 changed files with 10 additions and 1 deletions
|
@ -767,6 +767,7 @@ static int aic3x_hw_params(struct snd_pcm_substream *substream,
|
||||||
int codec_clk = 0, bypass_pll = 0, fsref, last_clk = 0;
|
int codec_clk = 0, bypass_pll = 0, fsref, last_clk = 0;
|
||||||
u8 data, r, p, pll_q, pll_p = 1, pll_r = 1, pll_j = 1;
|
u8 data, r, p, pll_q, pll_p = 1, pll_r = 1, pll_j = 1;
|
||||||
u16 pll_d = 1;
|
u16 pll_d = 1;
|
||||||
|
u8 reg;
|
||||||
|
|
||||||
/* select data word length */
|
/* select data word length */
|
||||||
data =
|
data =
|
||||||
|
@ -801,8 +802,16 @@ static int aic3x_hw_params(struct snd_pcm_substream *substream,
|
||||||
pll_q &= 0xf;
|
pll_q &= 0xf;
|
||||||
aic3x_write(codec, AIC3X_PLL_PROGA_REG, pll_q << PLLQ_SHIFT);
|
aic3x_write(codec, AIC3X_PLL_PROGA_REG, pll_q << PLLQ_SHIFT);
|
||||||
aic3x_write(codec, AIC3X_GPIOB_REG, CODEC_CLKIN_CLKDIV);
|
aic3x_write(codec, AIC3X_GPIOB_REG, CODEC_CLKIN_CLKDIV);
|
||||||
} else
|
/* disable PLL if it is bypassed */
|
||||||
|
reg = aic3x_read_reg_cache(codec, AIC3X_PLL_PROGA_REG);
|
||||||
|
aic3x_write(codec, AIC3X_PLL_PROGA_REG, reg & ~PLL_ENABLE);
|
||||||
|
|
||||||
|
} else {
|
||||||
aic3x_write(codec, AIC3X_GPIOB_REG, CODEC_CLKIN_PLLDIV);
|
aic3x_write(codec, AIC3X_GPIOB_REG, CODEC_CLKIN_PLLDIV);
|
||||||
|
/* enable PLL when it is used */
|
||||||
|
reg = aic3x_read_reg_cache(codec, AIC3X_PLL_PROGA_REG);
|
||||||
|
aic3x_write(codec, AIC3X_PLL_PROGA_REG, reg | PLL_ENABLE);
|
||||||
|
}
|
||||||
|
|
||||||
/* Route Left DAC to left channel input and
|
/* Route Left DAC to left channel input and
|
||||||
* right DAC to right channel input */
|
* right DAC to right channel input */
|
||||||
|
|
Loading…
Reference in a new issue