Commit 4d1284cd authored by Peter Ujfalusi's avatar Peter Ujfalusi Committed by Mark Brown

ASoC: SOF: Simplify sof_probe_complete handling for acpi/pci/of

Set the sof_data->sof_probe_complete callback unconditionally of
CONFIG_SND_SOC_SOF_PROBE_WORK_QUEUE.

The sof_probe_complete will be called when the sof_probe_continue()
function is successfully executed, called either directly from
snd_sof_device_probe() or from the scheduled work.

Since all error cases within the call chain of snd_sof_device_probe() have
error prints, there is no need to print again in the acpi/pci/of level.
Signed-off-by: default avatarPeter Ujfalusi <peter.ujfalusi@linux.intel.com>
Reviewed-by: default avatarPierre-Louis Bossart <pierre-louis.bossart@linux.intel.com>
Signed-off-by: default avatarRanjani Sridharan <ranjani.sridharan@linux.intel.com>
Link: https://lore.kernel.org/r/20210409220959.1543456-3-ranjani.sridharan@linux.intel.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
parent 3bcae98e
...@@ -61,7 +61,6 @@ int sof_acpi_probe(struct platform_device *pdev, const struct sof_dev_desc *desc ...@@ -61,7 +61,6 @@ int sof_acpi_probe(struct platform_device *pdev, const struct sof_dev_desc *desc
struct device *dev = &pdev->dev; struct device *dev = &pdev->dev;
struct snd_sof_pdata *sof_pdata; struct snd_sof_pdata *sof_pdata;
const struct snd_sof_dsp_ops *ops; const struct snd_sof_dsp_ops *ops;
int ret;
dev_dbg(dev, "ACPI DSP detected"); dev_dbg(dev, "ACPI DSP detected");
...@@ -93,22 +92,11 @@ int sof_acpi_probe(struct platform_device *pdev, const struct sof_dev_desc *desc ...@@ -93,22 +92,11 @@ int sof_acpi_probe(struct platform_device *pdev, const struct sof_dev_desc *desc
sof_pdata->tplg_filename_prefix = sof_pdata->tplg_filename_prefix =
sof_pdata->desc->default_tplg_path; sof_pdata->desc->default_tplg_path;
#if IS_ENABLED(CONFIG_SND_SOC_SOF_PROBE_WORK_QUEUE) /* set callback to be called on successful device probe to enable runtime_pm */
/* set callback to enable runtime_pm */
sof_pdata->sof_probe_complete = sof_acpi_probe_complete; sof_pdata->sof_probe_complete = sof_acpi_probe_complete;
#endif
/* call sof helper for DSP hardware probe */
ret = snd_sof_device_probe(dev, sof_pdata);
if (ret) {
dev_err(dev, "error: failed to probe DSP hardware!\n");
return ret;
}
#if !IS_ENABLED(CONFIG_SND_SOC_SOF_PROBE_WORK_QUEUE) /* call sof helper for DSP hardware probe */
sof_acpi_probe_complete(dev); return snd_sof_device_probe(dev, sof_pdata);
#endif
return ret;
} }
EXPORT_SYMBOL_NS(sof_acpi_probe, SND_SOC_SOF_ACPI_DEV); EXPORT_SYMBOL_NS(sof_acpi_probe, SND_SOC_SOF_ACPI_DEV);
......
...@@ -71,7 +71,6 @@ static int sof_of_probe(struct platform_device *pdev) ...@@ -71,7 +71,6 @@ static int sof_of_probe(struct platform_device *pdev)
const struct sof_dev_desc *desc; const struct sof_dev_desc *desc;
struct snd_sof_pdata *sof_pdata; struct snd_sof_pdata *sof_pdata;
const struct snd_sof_dsp_ops *ops; const struct snd_sof_dsp_ops *ops;
int ret;
dev_info(&pdev->dev, "DT DSP detected"); dev_info(&pdev->dev, "DT DSP detected");
...@@ -98,22 +97,11 @@ static int sof_of_probe(struct platform_device *pdev) ...@@ -98,22 +97,11 @@ static int sof_of_probe(struct platform_device *pdev)
sof_pdata->fw_filename_prefix = sof_pdata->desc->default_fw_path; sof_pdata->fw_filename_prefix = sof_pdata->desc->default_fw_path;
sof_pdata->tplg_filename_prefix = sof_pdata->desc->default_tplg_path; sof_pdata->tplg_filename_prefix = sof_pdata->desc->default_tplg_path;
#if IS_ENABLED(CONFIG_SND_SOC_SOF_PROBE_WORK_QUEUE) /* set callback to be called on successful device probe to enable runtime_pm */
/* set callback to enable runtime_pm */
sof_pdata->sof_probe_complete = sof_of_probe_complete; sof_pdata->sof_probe_complete = sof_of_probe_complete;
#endif
/* call sof helper for DSP hardware probe */
ret = snd_sof_device_probe(dev, sof_pdata);
if (ret) {
dev_err(dev, "error: failed to probe DSP hardware\n");
return ret;
}
#if !IS_ENABLED(CONFIG_SND_SOC_SOF_PROBE_WORK_QUEUE)
sof_of_probe_complete(dev);
#endif
return ret; /* call sof helper for DSP hardware probe */
return snd_sof_device_probe(dev, sof_pdata);
} }
static int sof_of_remove(struct platform_device *pdev) static int sof_of_remove(struct platform_device *pdev)
......
...@@ -184,25 +184,13 @@ int sof_pci_probe(struct pci_dev *pci, const struct pci_device_id *pci_id) ...@@ -184,25 +184,13 @@ int sof_pci_probe(struct pci_dev *pci, const struct pci_device_id *pci_id)
if (sof_override_tplg_name) if (sof_override_tplg_name)
sof_pdata->tplg_filename = sof_override_tplg_name; sof_pdata->tplg_filename = sof_override_tplg_name;
#if IS_ENABLED(CONFIG_SND_SOC_SOF_PROBE_WORK_QUEUE) /* set callback to be called on successful device probe to enable runtime_pm */
/* set callback to enable runtime_pm */
sof_pdata->sof_probe_complete = sof_pci_probe_complete; sof_pdata->sof_probe_complete = sof_pci_probe_complete;
#endif
/* call sof helper for DSP hardware probe */ /* call sof helper for DSP hardware probe */
ret = snd_sof_device_probe(dev, sof_pdata); ret = snd_sof_device_probe(dev, sof_pdata);
if (ret) { if (ret)
dev_err(dev, "error: failed to probe DSP hardware!\n"); pci_release_regions(pci);
goto release_regions;
}
#if !IS_ENABLED(CONFIG_SND_SOC_SOF_PROBE_WORK_QUEUE)
sof_pci_probe_complete(dev);
#endif
return ret;
release_regions:
pci_release_regions(pci);
return ret; return ret;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment