未验证 提交 83b71361 编写于 作者: V Vijendar Mukunda 提交者: Mark Brown

ASoC: amd: vg: fix for pm resume callback sequence

The previous condition is used to cross check only the active
stream status for I2S HS instance playback and capture use cases.

Modified logic to invoke sequence for two i2s controller instances.

This also fixes warnings reported by kernel robot:
"warning: variable 'frmt_val' set but not used"
"warning: variable 'reg_val' set but not used"
Reported-by: Nkernel test robot <lkp@intel.com>
Signed-off-by: NVijendar Mukunda <Vijendar.Mukunda@amd.com>
Link: https://lore.kernel.org/r/20220225193054.24916-1-Vijendar.Mukunda@amd.comSigned-off-by: NMark Brown <broonie@kernel.org>
上级 6d260880
...@@ -423,51 +423,51 @@ static int acp5x_audio_remove(struct platform_device *pdev) ...@@ -423,51 +423,51 @@ static int acp5x_audio_remove(struct platform_device *pdev)
static int __maybe_unused acp5x_pcm_resume(struct device *dev) static int __maybe_unused acp5x_pcm_resume(struct device *dev)
{ {
struct i2s_dev_data *adata; struct i2s_dev_data *adata;
u32 val, reg_val, frmt_val; struct i2s_stream_instance *rtd;
u32 val;
reg_val = 0;
frmt_val = 0;
adata = dev_get_drvdata(dev); adata = dev_get_drvdata(dev);
if (adata->play_stream && adata->play_stream->runtime) { if (adata->play_stream && adata->play_stream->runtime) {
struct i2s_stream_instance *rtd = rtd = adata->play_stream->runtime->private_data;
adata->play_stream->runtime->private_data;
config_acp5x_dma(rtd, SNDRV_PCM_STREAM_PLAYBACK); config_acp5x_dma(rtd, SNDRV_PCM_STREAM_PLAYBACK);
switch (rtd->i2s_instance) { acp_writel((rtd->xfer_resolution << 3), rtd->acp5x_base + ACP_HSTDM_ITER);
case I2S_HS_INSTANCE: if (adata->tdm_mode == TDM_ENABLE) {
reg_val = ACP_HSTDM_ITER; acp_writel(adata->tdm_fmt, adata->acp5x_base + ACP_HSTDM_TXFRMT);
frmt_val = ACP_HSTDM_TXFRMT; val = acp_readl(adata->acp5x_base + ACP_HSTDM_ITER);
break; acp_writel(val | 0x2, adata->acp5x_base + ACP_HSTDM_ITER);
case I2S_SP_INSTANCE: }
default: }
reg_val = ACP_I2STDM_ITER; if (adata->i2ssp_play_stream && adata->i2ssp_play_stream->runtime) {
frmt_val = ACP_I2STDM_TXFRMT; rtd = adata->i2ssp_play_stream->runtime->private_data;
config_acp5x_dma(rtd, SNDRV_PCM_STREAM_PLAYBACK);
acp_writel((rtd->xfer_resolution << 3), rtd->acp5x_base + ACP_I2STDM_ITER);
if (adata->tdm_mode == TDM_ENABLE) {
acp_writel(adata->tdm_fmt, adata->acp5x_base + ACP_I2STDM_TXFRMT);
val = acp_readl(adata->acp5x_base + ACP_I2STDM_ITER);
acp_writel(val | 0x2, adata->acp5x_base + ACP_I2STDM_ITER);
} }
acp_writel((rtd->xfer_resolution << 3),
rtd->acp5x_base + reg_val);
} }
if (adata->capture_stream && adata->capture_stream->runtime) { if (adata->capture_stream && adata->capture_stream->runtime) {
struct i2s_stream_instance *rtd = rtd = adata->capture_stream->runtime->private_data;
adata->capture_stream->runtime->private_data;
config_acp5x_dma(rtd, SNDRV_PCM_STREAM_CAPTURE); config_acp5x_dma(rtd, SNDRV_PCM_STREAM_CAPTURE);
switch (rtd->i2s_instance) { acp_writel((rtd->xfer_resolution << 3), rtd->acp5x_base + ACP_HSTDM_IRER);
case I2S_HS_INSTANCE: if (adata->tdm_mode == TDM_ENABLE) {
reg_val = ACP_HSTDM_IRER; acp_writel(adata->tdm_fmt, adata->acp5x_base + ACP_HSTDM_RXFRMT);
frmt_val = ACP_HSTDM_RXFRMT; val = acp_readl(adata->acp5x_base + ACP_HSTDM_IRER);
break; acp_writel(val | 0x2, adata->acp5x_base + ACP_HSTDM_IRER);
case I2S_SP_INSTANCE:
default:
reg_val = ACP_I2STDM_IRER;
frmt_val = ACP_I2STDM_RXFRMT;
} }
acp_writel((rtd->xfer_resolution << 3),
rtd->acp5x_base + reg_val);
} }
if (adata->tdm_mode == TDM_ENABLE) { if (adata->i2ssp_capture_stream && adata->i2ssp_capture_stream->runtime) {
acp_writel(adata->tdm_fmt, adata->acp5x_base + frmt_val); rtd = adata->i2ssp_capture_stream->runtime->private_data;
val = acp_readl(adata->acp5x_base + reg_val); config_acp5x_dma(rtd, SNDRV_PCM_STREAM_CAPTURE);
acp_writel(val | 0x2, adata->acp5x_base + reg_val); acp_writel((rtd->xfer_resolution << 3), rtd->acp5x_base + ACP_I2STDM_IRER);
if (adata->tdm_mode == TDM_ENABLE) {
acp_writel(adata->tdm_fmt, adata->acp5x_base + ACP_I2STDM_RXFRMT);
val = acp_readl(adata->acp5x_base + ACP_I2STDM_IRER);
acp_writel(val | 0x2, adata->acp5x_base + ACP_I2STDM_IRER);
}
} }
acp_writel(1, adata->acp5x_base + ACP_EXTERNAL_INTR_ENB); acp_writel(1, adata->acp5x_base + ACP_EXTERNAL_INTR_ENB);
return 0; return 0;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册