diff --git a/soc/swr-mstr-ctrl.c b/soc/swr-mstr-ctrl.c index c3ad05345e..3a33f82780 100644 --- a/soc/swr-mstr-ctrl.c +++ b/soc/swr-mstr-ctrl.c @@ -3101,9 +3101,18 @@ int swrm_wcd_notify(struct platform_device *pdev, u32 id, void *data) * next activity on soundwire will request clock from new clock * source. */ + if (!data) { + dev_err(swrm->dev, "%s: data is NULL for id:%d\n", + __func__, id); + ret = -EINVAL; + break; + } mutex_lock(&swrm->mlock); - if (swrm->state == SWR_MSTR_UP) - swrm_device_suspend(&pdev->dev); + if (swrm->clk_src != *(int *)data) { + if (swrm->state == SWR_MSTR_UP) + swrm_device_suspend(&pdev->dev); + swrm->clk_src = *(int *)data; + } mutex_unlock(&swrm->mlock); break; case SWR_CLK_FREQ: diff --git a/soc/swr-mstr-ctrl.h b/soc/swr-mstr-ctrl.h index c2955f88d8..2e7cac4fb6 100644 --- a/soc/swr-mstr-ctrl.h +++ b/soc/swr-mstr-ctrl.h @@ -187,6 +187,7 @@ struct swr_mstr_ctrl { u32 swr_irq_wakeup_capable; int hw_core_clk_en; int aud_core_clk_en; + int clk_src; #ifdef CONFIG_DEBUG_FS struct dentry *debugfs_swrm_dent; struct dentry *debugfs_peek;