Commit 91dce767 authored by Kai Vehmanen's avatar Kai Vehmanen Committed by Mark Brown

ASoC: SOF: Intel: drop HDA codec upon probe failure

In case a HDA codec probe fails, do not raise error immediately,
but instead remove the codec from bus->codec_mask and continue
probe for other codecs.

This allows for more robust behaviour in cases where one codec
in the system is faulty. SOF driver load can still proceed with
the codecs that can be probed successfully. Probe may still
fail if suitable machine driver is not found, but in many
cases the generic HDA machine driver can operate with a subset
of codecs.
Reviewed-by: default avatarRanjani Sridharan <ranjani.sridharan@linux.intel.com>
Signed-off-by: default avatarKai Vehmanen <kai.vehmanen@linux.intel.com>
Signed-off-by: default avatarPierre-Louis Bossart <pierre-louis.bossart@linux.intel.com>
Link: https://lore.kernel.org/r/20191218002616.7652-6-pierre-louis.bossart@linux.intel.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
parent 35dc19ad
...@@ -140,8 +140,8 @@ static int hda_codec_probe(struct snd_sof_dev *sdev, int address, ...@@ -140,8 +140,8 @@ static int hda_codec_probe(struct snd_sof_dev *sdev, int address,
} }
/* Codec initialization */ /* Codec initialization */
int hda_codec_probe_bus(struct snd_sof_dev *sdev, void hda_codec_probe_bus(struct snd_sof_dev *sdev,
bool hda_codec_use_common_hdmi) bool hda_codec_use_common_hdmi)
{ {
struct hdac_bus *bus = sof_to_bus(sdev); struct hdac_bus *bus = sof_to_bus(sdev);
int i, ret; int i, ret;
...@@ -154,13 +154,11 @@ int hda_codec_probe_bus(struct snd_sof_dev *sdev, ...@@ -154,13 +154,11 @@ int hda_codec_probe_bus(struct snd_sof_dev *sdev,
ret = hda_codec_probe(sdev, i, hda_codec_use_common_hdmi); ret = hda_codec_probe(sdev, i, hda_codec_use_common_hdmi);
if (ret < 0) { if (ret < 0) {
dev_err(bus->dev, "error: codec #%d probe error, ret: %d\n", dev_warn(bus->dev, "codec #%d probe error, ret: %d\n",
i, ret); i, ret);
return ret; bus->codec_mask &= ~BIT(i);
} }
} }
return 0;
} }
EXPORT_SYMBOL(hda_codec_probe_bus); EXPORT_SYMBOL(hda_codec_probe_bus);
......
...@@ -575,8 +575,8 @@ void sof_hda_bus_init(struct hdac_bus *bus, struct device *dev); ...@@ -575,8 +575,8 @@ void sof_hda_bus_init(struct hdac_bus *bus, struct device *dev);
/* /*
* HDA Codec operations. * HDA Codec operations.
*/ */
int hda_codec_probe_bus(struct snd_sof_dev *sdev, void hda_codec_probe_bus(struct snd_sof_dev *sdev,
bool hda_codec_use_common_hdmi); bool hda_codec_use_common_hdmi);
void hda_codec_jack_wake_enable(struct snd_sof_dev *sdev); void hda_codec_jack_wake_enable(struct snd_sof_dev *sdev);
void hda_codec_jack_check(struct snd_sof_dev *sdev); void hda_codec_jack_check(struct snd_sof_dev *sdev);
......
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