[alsa-devel] Alsa 1.0.13 (and others) does not work on ALC880

Takashi Iwai tiwai at suse.de
Wed Jun 6 14:54:40 CEST 2007


At Wed, 6 Jun 2007 01:07:15 -0500 (CDT),
acallan.alsa at ugnet.org wrote:
> 
> cat /proc/asound/card0/codec#1 works just fine, and sound still works
> fine even after that.  Looking at the function print_codec_info()
> (hda_proc.c), there is already the check:
> if (! codec->afg)
>         return;
> after the vendor, subsystem, and revision are retrieved but before the
> pcm, amp caps, and node information are retrieved.

Oh silly me.

I guess the following patch works alone.  Could you test it?


Takashi

diff -r 8bc69e73a655 pci/hda/hda_codec.c
--- a/pci/hda/hda_codec.c	Wed Jun 06 14:48:52 2007 +0200
+++ b/pci/hda/hda_codec.c	Wed Jun 06 14:52:15 2007 +0200
@@ -562,7 +562,7 @@ int __devinit snd_hda_codec_new(struct h
 		return -ENODEV;
 	}
 
-	if (read_widget_caps(codec, codec->afg ? codec->afg : codec->mfg) < 0) {
+	if (codec->afg && read_widget_caps(codec, codec->afg) < 0) {
 		snd_printk(KERN_ERR "hda_codec: cannot malloc\n");
 		snd_hda_codec_free(codec);
 		return -ENOMEM;
diff -r 8bc69e73a655 pci/hda/hda_local.h
--- a/pci/hda/hda_local.h	Wed Jun 06 14:48:52 2007 +0200
+++ b/pci/hda/hda_local.h	Wed Jun 06 14:53:03 2007 +0200
@@ -274,7 +274,7 @@ static inline u32 get_wcaps(struct hda_c
 	if (nid < codec->start_nid ||
 	    nid >= codec->start_nid + codec->num_nodes)
 		return snd_hda_param_read(codec, nid, AC_PAR_AUDIO_WIDGET_CAP);
-	return codec->wcaps[nid - codec->start_nid];
+	return codec->wcaps ? codec->wcaps[nid - codec->start_nid] : 0;
 }
 
 int snd_hda_override_amp_caps(struct hda_codec *codec, hda_nid_t nid, int dir,


More information about the Alsa-devel mailing list