Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit e7e52dfc authored by Marek Szyprowski's avatar Marek Szyprowski Committed by Mark Brown
Browse files

ASoC: samsung: i2s: Move saving and restoring regs to runtime pm operations



This patch moves saving and restoring I2S registers to runtime PM
operations, what prepares the driver to operate with audio power domain.
When support for audio power domain is enabled and the domain is being
turned off, the I2S module will loose its context (registers), so runtime
callbacks have to handle it. System sleep suspend/resume operation are
implemented on top of runtime PM operations with generic
pm_runtime_force_suspend/resume helpers.

Signed-off-by: default avatarMarek Szyprowski <m.szyprowski@samsung.com>
Signed-off-by: default avatarMark Brown <broonie@kernel.org>
parent dc938ddb
Loading
Loading
Loading
Loading
+12 −14
Original line number Original line Diff line number Diff line
@@ -983,24 +983,12 @@ i2s_delay(struct snd_pcm_substream *substream, struct snd_soc_dai *dai)
#ifdef CONFIG_PM
#ifdef CONFIG_PM
static int i2s_suspend(struct snd_soc_dai *dai)
static int i2s_suspend(struct snd_soc_dai *dai)
{
{
	struct i2s_dai *i2s = to_info(dai);
	return pm_runtime_force_suspend(dai->dev);

	i2s->suspend_i2smod = readl(i2s->addr + I2SMOD);
	i2s->suspend_i2scon = readl(i2s->addr + I2SCON);
	i2s->suspend_i2spsr = readl(i2s->addr + I2SPSR);

	return 0;
}
}


static int i2s_resume(struct snd_soc_dai *dai)
static int i2s_resume(struct snd_soc_dai *dai)
{
{
	struct i2s_dai *i2s = to_info(dai);
	return pm_runtime_force_resume(dai->dev);

	writel(i2s->suspend_i2scon, i2s->addr + I2SCON);
	writel(i2s->suspend_i2smod, i2s->addr + I2SMOD);
	writel(i2s->suspend_i2spsr, i2s->addr + I2SPSR);

	return 0;
}
}
#else
#else
#define i2s_suspend NULL
#define i2s_suspend NULL
@@ -1129,6 +1117,10 @@ static int i2s_runtime_suspend(struct device *dev)
{
{
	struct i2s_dai *i2s = dev_get_drvdata(dev);
	struct i2s_dai *i2s = dev_get_drvdata(dev);


	i2s->suspend_i2smod = readl(i2s->addr + I2SMOD);
	i2s->suspend_i2scon = readl(i2s->addr + I2SCON);
	i2s->suspend_i2spsr = readl(i2s->addr + I2SPSR);

	clk_disable_unprepare(i2s->clk);
	clk_disable_unprepare(i2s->clk);


	return 0;
	return 0;
@@ -1140,6 +1132,10 @@ static int i2s_runtime_resume(struct device *dev)


	clk_prepare_enable(i2s->clk);
	clk_prepare_enable(i2s->clk);


	writel(i2s->suspend_i2scon, i2s->addr + I2SCON);
	writel(i2s->suspend_i2smod, i2s->addr + I2SMOD);
	writel(i2s->suspend_i2spsr, i2s->addr + I2SPSR);

	return 0;
	return 0;
}
}
#endif /* CONFIG_PM */
#endif /* CONFIG_PM */
@@ -1510,6 +1506,8 @@ MODULE_DEVICE_TABLE(of, exynos_i2s_match);
static const struct dev_pm_ops samsung_i2s_pm = {
static const struct dev_pm_ops samsung_i2s_pm = {
	SET_RUNTIME_PM_OPS(i2s_runtime_suspend,
	SET_RUNTIME_PM_OPS(i2s_runtime_suspend,
				i2s_runtime_resume, NULL)
				i2s_runtime_resume, NULL)
	SET_SYSTEM_SLEEP_PM_OPS(pm_runtime_force_suspend,
				     pm_runtime_force_resume)
};
};


static struct platform_driver samsung_i2s_driver = {
static struct platform_driver samsung_i2s_driver = {