Commit 6e655bf2 authored by Takashi Iwai's avatar Takashi Iwai

ALSA: hda - Don't return a fatal error at PCM-creation errors

Don't return a fatal error to the driver but continue to probe when
any error occurs at creating PCM streams for each codec.
It's often non-fatal and keeping it would help debugging.
Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
parent f93d461b
...@@ -2833,8 +2833,16 @@ int snd_hda_codec_build_pcms(struct hda_codec *codec) ...@@ -2833,8 +2833,16 @@ int snd_hda_codec_build_pcms(struct hda_codec *codec)
if (!codec->patch_ops.build_pcms) if (!codec->patch_ops.build_pcms)
return 0; return 0;
err = codec->patch_ops.build_pcms(codec); err = codec->patch_ops.build_pcms(codec);
if (err < 0) if (err < 0) {
return err; printk(KERN_ERR "hda_codec: cannot build PCMs"
"for #%d (error %d)\n", codec->addr, err);
err = snd_hda_codec_reset(codec);
if (err < 0) {
printk(KERN_ERR
"hda_codec: cannot revert codec\n");
return err;
}
}
} }
for (pcm = 0; pcm < codec->num_pcms; pcm++) { for (pcm = 0; pcm < codec->num_pcms; pcm++) {
struct hda_pcm *cpcm = &codec->pcm_info[pcm]; struct hda_pcm *cpcm = &codec->pcm_info[pcm];
...@@ -2846,11 +2854,15 @@ int snd_hda_codec_build_pcms(struct hda_codec *codec) ...@@ -2846,11 +2854,15 @@ int snd_hda_codec_build_pcms(struct hda_codec *codec)
if (!cpcm->pcm) { if (!cpcm->pcm) {
dev = get_empty_pcm_device(codec->bus, cpcm->pcm_type); dev = get_empty_pcm_device(codec->bus, cpcm->pcm_type);
if (dev < 0) if (dev < 0)
return 0; continue; /* no fatal error */
cpcm->device = dev; cpcm->device = dev;
err = snd_hda_attach_pcm(codec, cpcm); err = snd_hda_attach_pcm(codec, cpcm);
if (err < 0) if (err < 0) {
return err; printk(KERN_ERR "hda_codec: cannot attach "
"PCM stream %d for codec #%d\n",
dev, codec->addr);
continue; /* no fatal error */
}
} }
} }
return 0; return 0;
......
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