mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-11-16 16:54:20 +08:00
ASoC: cirrus: i2s: Prepare clock before using it
Use clk_prepare_enable()/clk_disable_unprepare() in preparation for switch to Common Clock Framework, otherwise the following is visible: WARNING: CPU: 0 PID: 97 at drivers/clk/clk.c:1011 clk_core_enable+0x9c/0xbc Enabling unprepared mclk ... Hardware name: Cirrus Logic EDB9302 Evaluation Board ... clk_core_enable clk_core_enable_lock ep93xx_i2s_hw_params snd_soc_dai_hw_params soc_pcm_hw_params snd_pcm_hw_params snd_pcm_ioctl ... Signed-off-by: Alexander Sverdlin <alexander.sverdlin@gmail.com> Acked-by: Mark Brown <broonie@kernel.org> Link: https://lore.kernel.org/r/20211018103105.146380-2-alexander.sverdlin@gmail.com' Signed-off-by: Arnd Bergmann <arnd@arndb.de>
This commit is contained in:
parent
409d8a9c1d
commit
f4ff6b56bc
@ -111,9 +111,9 @@ static void ep93xx_i2s_enable(struct ep93xx_i2s_info *info, int stream)
|
||||
if ((ep93xx_i2s_read_reg(info, EP93XX_I2S_TX0EN) & 0x1) == 0 &&
|
||||
(ep93xx_i2s_read_reg(info, EP93XX_I2S_RX0EN) & 0x1) == 0) {
|
||||
/* Enable clocks */
|
||||
clk_enable(info->mclk);
|
||||
clk_enable(info->sclk);
|
||||
clk_enable(info->lrclk);
|
||||
clk_prepare_enable(info->mclk);
|
||||
clk_prepare_enable(info->sclk);
|
||||
clk_prepare_enable(info->lrclk);
|
||||
|
||||
/* Enable i2s */
|
||||
ep93xx_i2s_write_reg(info, EP93XX_I2S_GLCTRL, 1);
|
||||
@ -156,9 +156,9 @@ static void ep93xx_i2s_disable(struct ep93xx_i2s_info *info, int stream)
|
||||
ep93xx_i2s_write_reg(info, EP93XX_I2S_GLCTRL, 0);
|
||||
|
||||
/* Disable clocks */
|
||||
clk_disable(info->lrclk);
|
||||
clk_disable(info->sclk);
|
||||
clk_disable(info->mclk);
|
||||
clk_disable_unprepare(info->lrclk);
|
||||
clk_disable_unprepare(info->sclk);
|
||||
clk_disable_unprepare(info->mclk);
|
||||
}
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user