]> www.infradead.org Git - users/jedix/linux-maple.git/commitdiff
ASoC: SOF: Set SOF_FW_BOOT_FAILED in case we have failure during boot
authorPeter Ujfalusi <peter.ujfalusi@linux.intel.com>
Thu, 23 Dec 2021 11:36:20 +0000 (13:36 +0200)
committerMark Brown <broonie@kernel.org>
Thu, 23 Dec 2021 13:38:20 +0000 (13:38 +0000)
Change the fw_state to SOF_FW_BOOT_FAILED if we encountered an error during
booting the firmware.

Signed-off-by: Peter Ujfalusi <peter.ujfalusi@linux.intel.com>
Reviewed-by: Pierre-Louis Bossart <pierre-louis.bossart@linux.intel.com>
Reviewed-by: Bard Liao <yung-chuan.liao@linux.intel.com>
Reviewed-by: Ranjani Sridharan <ranjani.sridharan@linux.intel.com>
Link: https://lore.kernel.org/r/20211223113628.18582-13-peter.ujfalusi@linux.intel.com
Signed-off-by: Mark Brown <broonie@kernel.org>
sound/soc/sof/core.c
sound/soc/sof/loader.c
sound/soc/sof/pm.c

index 00f8ffee2866b7fa37448728c7093398d5f8f3c9..aa7a721f34e4a67b887e09b3175ad6779b3a0721 100644 (file)
@@ -202,6 +202,7 @@ static int sof_probe_continue(struct snd_sof_dev *sdev)
        if (ret < 0) {
                dev_err(sdev->dev, "error: failed to load DSP firmware %d\n",
                        ret);
+               sof_set_fw_state(sdev, SOF_FW_BOOT_FAILED);
                goto fw_load_err;
        }
 
@@ -215,6 +216,7 @@ static int sof_probe_continue(struct snd_sof_dev *sdev)
        if (ret < 0) {
                dev_err(sdev->dev, "error: failed to boot DSP firmware %d\n",
                        ret);
+               sof_set_fw_state(sdev, SOF_FW_BOOT_FAILED);
                goto fw_run_err;
        }
 
index f81f2473279965b5831db27fbbbd7c595823cb40..697f03565a70daa8cadcc8f66841a23e5c298a0b 100644 (file)
@@ -838,7 +838,6 @@ int snd_sof_run_firmware(struct snd_sof_dev *sdev)
                snd_sof_dsp_dbg_dump(sdev, "Firmware boot failure due to timeout",
                                     SOF_DBG_DUMP_REGS | SOF_DBG_DUMP_MBOX |
                                     SOF_DBG_DUMP_TEXT | SOF_DBG_DUMP_PCI);
-               sof_set_fw_state(sdev, SOF_FW_BOOT_FAILED);
                return -EIO;
        }
 
index f22b5ee2347868b2d2bb2bffbba8c4b6fcc4cb51..022b19669735134db1549b4a2743f27b97460508 100644 (file)
@@ -130,6 +130,7 @@ static int sof_resume(struct device *dev, bool runtime_resume)
                dev_err(sdev->dev,
                        "error: failed to load DSP firmware after resume %d\n",
                        ret);
+               sof_set_fw_state(sdev, SOF_FW_BOOT_FAILED);
                return ret;
        }
 
@@ -144,6 +145,7 @@ static int sof_resume(struct device *dev, bool runtime_resume)
                dev_err(sdev->dev,
                        "error: failed to boot DSP firmware after resume %d\n",
                        ret);
+               sof_set_fw_state(sdev, SOF_FW_BOOT_FAILED);
                return ret;
        }