mirror of
https://github.com/raspberrypi/linux.git
synced 2025-12-06 18:09:56 +00:00
ASoC: SOF: Intel: hda-dsp: Skip IMR boot on ACE platforms in case of S3 suspend
[ Upstream commit c61115b37f ]
SoCs with ACE architecture are tailored to use s2idle instead deep (S3)
suspend state and the IMR content is lost when the system is forced to
enter even to S3.
When waking up from S3 state the IMR boot will fail as the content is lost.
Set the skip_imr_boot flag to make sure that we don't try IMR in this case.
Signed-off-by: Peter Ujfalusi <peter.ujfalusi@linux.intel.com>
Reviewed-by: Pierre-Louis Bossart <pierre-louis.bossart@linux.intel.com>
Reviewed-by: Rander Wang <rander.wang@intel.com>
Reviewed-by: Liam Girdwood <liam.r.girdwood@intel.com>
Reviewed-by: Ranjani Sridharan <ranjani.sridharan@linux.intel.com>
Link: https://msgid.link/r/20240322112504.4192-1-peter.ujfalusi@linux.intel.com
Signed-off-by: Mark Brown <broonie@kernel.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
3ae6d64271
commit
056f7e8ffa
@@ -681,17 +681,27 @@ static int hda_suspend(struct snd_sof_dev *sdev, bool runtime_suspend)
|
|||||||
struct sof_intel_hda_dev *hda = sdev->pdata->hw_pdata;
|
struct sof_intel_hda_dev *hda = sdev->pdata->hw_pdata;
|
||||||
const struct sof_intel_dsp_desc *chip = hda->desc;
|
const struct sof_intel_dsp_desc *chip = hda->desc;
|
||||||
struct hdac_bus *bus = sof_to_bus(sdev);
|
struct hdac_bus *bus = sof_to_bus(sdev);
|
||||||
|
bool imr_lost = false;
|
||||||
int ret, j;
|
int ret, j;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* The memory used for IMR boot loses its content in deeper than S3 state
|
* The memory used for IMR boot loses its content in deeper than S3
|
||||||
* We must not try IMR boot on next power up (as it will fail).
|
* state on CAVS platforms.
|
||||||
*
|
* On ACE platforms due to the system architecture the IMR content is
|
||||||
|
* lost at S3 state already, they are tailored for s2idle use.
|
||||||
|
* We must not try IMR boot on next power up in these cases as it will
|
||||||
|
* fail.
|
||||||
|
*/
|
||||||
|
if (sdev->system_suspend_target > SOF_SUSPEND_S3 ||
|
||||||
|
(chip->hw_ip_version >= SOF_INTEL_ACE_1_0 &&
|
||||||
|
sdev->system_suspend_target == SOF_SUSPEND_S3))
|
||||||
|
imr_lost = true;
|
||||||
|
|
||||||
|
/*
|
||||||
* In case of firmware crash or boot failure set the skip_imr_boot to true
|
* In case of firmware crash or boot failure set the skip_imr_boot to true
|
||||||
* as well in order to try to re-load the firmware to do a 'cold' boot.
|
* as well in order to try to re-load the firmware to do a 'cold' boot.
|
||||||
*/
|
*/
|
||||||
if (sdev->system_suspend_target > SOF_SUSPEND_S3 ||
|
if (imr_lost || sdev->fw_state == SOF_FW_CRASHED ||
|
||||||
sdev->fw_state == SOF_FW_CRASHED ||
|
|
||||||
sdev->fw_state == SOF_FW_BOOT_FAILED)
|
sdev->fw_state == SOF_FW_BOOT_FAILED)
|
||||||
hda->skip_imr_boot = true;
|
hda->skip_imr_boot = true;
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user