[alsa-devel] [BUG] NULL pointer dereference in patch_sigmatel.c
Takashi Iwai
tiwai at suse.de
Thu Aug 6 16:13:19 CEST 2009
At Thu, 06 Aug 2009 16:41:27 +0300,
Ozan Çağlayan wrote:
>
> Takashi Iwai wrote On 17-07-2009 12:45:
> > At Fri, 17 Jul 2009 11:33:08 +0200,
> > I wrote:
> >
> >> At Thu, 16 Jul 2009 22:51:50 +0300,
> >> Ozan Çağlayan wrote:
> >>
> >>> Hi,
> >>>
> >>> One of our users is having a NULL ptr dereference upon loading the
> >>> snd_hda_intel module with 20090624's snapshot. There's only one commit
> >>> after that date in patch_sigmatel.c so I didn't tell him to try with the
> >>> latest snapshot but if you think that the bug may be related to another
> >>> part of the ALSA codebase, I can make him try the latest snapshot.
> >>>
> >> I suppose you are using unstable tree, right?
> >>
> >
> > Looking through the stack trace, it's not...
> >
>
> Okay I've founded the problem. Here's the relevant code portion that
> I've got from gdb:
>
> (gdb) list *cxt5051_init+0x90
> 0xdf4 is in cxt5051_init
> (/var/pisi/alsa-driver-1.0.20_20090805-41/work/alsa-driver/pci/hda/../../alsa-kernel/pci/hda/patch_conexant.c:384).
> 379 jack->type = type;
> 380
> 381 err = snd_jack_new(codec->bus->card, name, type,
> &jack->jack);
> 382 if (err < 0)
> 383 return err;
> 384 jack->jack->private_data = jack;
> 385 jack->jack->private_free = conexant_free_jack_priv;
> 386 return 0;
> 387 }
> 388
So, either jack or jack->jack is a wrong value, likely NULL. Could
you add a debug print to verify that?
> and then I've checked the mainline linus-2.6 and found out the following
> commit:
>
> commit 95c0909961bc5ff18c78b2ab0d093cddc0a8b0b5
> Author: Takashi Iwai <tiwai at suse.de>
> Date: Tue Apr 14 16:15:29 2009 +0200
>
> ALSA: hda - Avoid call of snd_jack_report at release
>
> Don't call snd_jack_report at release of sigmatel and conexnat codecs
> which results in Oops at unloading the module.
>
> The Oops is triggered by the power-up sequence during the free due to
> the pincfg restoration. Since the power-up sequence is involved with
> the unsol handling, the jack reporting may be issued during that.
> The Oops occurs with this jack reporting because the jack instances
> have been already released but the codec doesn't do the proper
> book-keeping.
>
> This patch adds the book-keeping of jack instances to avoid the access
> to bogus pointers.
>
> Reverting this fixed the problem on the machine which has the conexant
> cx codec. Seen that the commit patches also the sigmatel one, it
> explains the other oops in the beginning of this thread.
Yes.
Takashi
More information about the Alsa-devel
mailing list