ASoC: SOF: Intel: mtl: define and set power_down_dsp op
For MTL platform, dsp cores need to go power down first then dsp subsystem also need to set power down. Signed-off-by: Fred Oh <fred.oh@linux.intel.com> Reviewed-by: Rander Wang <rander.wang@intel.com> Reviewed-by: Bard Liao <yung-chuan.liao@linux.intel.com> Signed-off-by: Ranjani Sridharan <ranjani.sridharan@linux.intel.com> Link: https://lore.kernel.org/r/20220922213644.666315-4-ranjani.sridharan@linux.intel.com Signed-off-by: Mark Brown <broonie@kernel.org>
This commit is contained in:
parent
c714031f93
commit
2090cb9bf5
@ -406,6 +406,33 @@ static int mtl_dsp_core_power_down(struct snd_sof_dev *sdev, int core)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int mtl_power_down_dsp(struct snd_sof_dev *sdev)
|
||||||
|
{
|
||||||
|
u32 dsphfdsscs, cpa;
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
/* first power down core */
|
||||||
|
ret = mtl_dsp_core_power_down(sdev, SOF_DSP_PRIMARY_CORE);
|
||||||
|
if (ret) {
|
||||||
|
dev_err(sdev->dev, "mtl dsp power down error, %d\n", ret);
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Set the DSP subsystem power down */
|
||||||
|
snd_sof_dsp_update_bits(sdev, HDA_DSP_BAR, MTL_HFDSSCS,
|
||||||
|
MTL_HFDSSCS_SPA_MASK, 0);
|
||||||
|
|
||||||
|
/* Wait for unstable CPA read (1 then 0 then 1) just after setting SPA bit */
|
||||||
|
usleep_range(1000, 1010);
|
||||||
|
|
||||||
|
/* poll with timeout to check if operation successful */
|
||||||
|
cpa = MTL_HFDSSCS_CPA_MASK;
|
||||||
|
dsphfdsscs = snd_sof_dsp_read(sdev, HDA_DSP_BAR, MTL_HFDSSCS);
|
||||||
|
return snd_sof_dsp_read_poll_timeout(sdev, HDA_DSP_BAR, MTL_HFDSSCS, dsphfdsscs,
|
||||||
|
(dsphfdsscs & cpa) == 0, HDA_DSP_REG_POLL_INTERVAL_US,
|
||||||
|
HDA_DSP_RESET_TIMEOUT_US);
|
||||||
|
}
|
||||||
|
|
||||||
static int mtl_dsp_cl_init(struct snd_sof_dev *sdev, int stream_tag, bool imr_boot)
|
static int mtl_dsp_cl_init(struct snd_sof_dev *sdev, int stream_tag, bool imr_boot)
|
||||||
{
|
{
|
||||||
struct sof_intel_hda_dev *hda = sdev->pdata->hw_pdata;
|
struct sof_intel_hda_dev *hda = sdev->pdata->hw_pdata;
|
||||||
@ -792,6 +819,7 @@ const struct sof_intel_dsp_desc mtl_chip_info = {
|
|||||||
.check_sdw_irq = mtl_dsp_check_sdw_irq,
|
.check_sdw_irq = mtl_dsp_check_sdw_irq,
|
||||||
.check_ipc_irq = mtl_dsp_check_ipc_irq,
|
.check_ipc_irq = mtl_dsp_check_ipc_irq,
|
||||||
.cl_init = mtl_dsp_cl_init,
|
.cl_init = mtl_dsp_cl_init,
|
||||||
|
.power_down_dsp = mtl_power_down_dsp,
|
||||||
.hw_ip_version = SOF_INTEL_ACE_1_0,
|
.hw_ip_version = SOF_INTEL_ACE_1_0,
|
||||||
};
|
};
|
||||||
EXPORT_SYMBOL_NS(mtl_chip_info, SND_SOC_SOF_INTEL_HDA_COMMON);
|
EXPORT_SYMBOL_NS(mtl_chip_info, SND_SOC_SOF_INTEL_HDA_COMMON);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user