Re: [PATCH] hda empty modelname comparison

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



At Wed, 07 Mar 2007 12:04:30 -0800,
Tobin Davis wrote:
> 
> On Tue, 2007-03-06 at 15:59 +0100, Joachim Deguara wrote:
> 
>     This patch prevents a comparison between a possibly empty modelname
>     string in the hda code.
>     
>     -Joachim
> 
> Unfortunately, the way the original patch was written, the only options are
> generic or segfault.  Your patch just removes the segfault, sending all cards
> to the generic parser.
> 
> I've tested a slightly different approach, based on your empty test, just
> reverse logic.  Test it to confirm that it works.  It works on my system with
> a Conexant reference board and a Sigmatel STAC9227 (both on the same system).
> 
> Signed off by Tobin Davis <tdavis@xxxxxxxxxxxx>                               
That's my bad.  I haven't tested much, and unfortunately, 1.0.14rc3
was released while I've been in vacation soon after the wrong patch.

The fix patch below is already on my local tree, but it couldn't be
pushed because the ALSA HG tree is currently down (I guess Jaroslav is
working on his server).  If needed, we'll release the fixed version.
So stay tuned.


Takashi

# HG changeset patch
# User tiwai
# Date 1173279359 -3600
# Node ID 9b8fef0370f213c42fc93098c7b8cc2c8188b177
# Parent  e4f79cb873e55818b4aca604d17e350b5a480a27
Fix NULL dereference with null modelname

Fix the NULL dereference of modelname option.  The check is moved to
find_codec_preset() now, too.

diff -r e4f79cb873e5 -r 9b8fef0370f2 pci/hda/hda_codec.c
--- a/pci/hda/hda_codec.c	Tue Mar 06 11:29:05 2007 +0100
+++ b/pci/hda/hda_codec.c	Wed Mar 07 15:55:59 2007 +0100
@@ -403,6 +403,9 @@ static const struct hda_codec_preset *fi
 {
 	const struct hda_codec_preset **tbl, *preset;
 
+	if (codec->bus->modelname && !strcmp(codec->bus->modelname, "generic"))
+		return NULL; /* use the generic parser */
+
 	for (tbl = hda_preset_tables; *tbl; tbl++) {
 		for (preset = *tbl; preset->id; preset++) {
 			u32 mask = preset->mask;
@@ -573,8 +576,7 @@ int snd_hda_codec_new(struct hda_bus *bu
 							 0);
 	}
 
-	if (strcmp(codec->bus->modelname, "generic"))
-		codec->preset = find_codec_preset(codec);
+	codec->preset = find_codec_preset(codec);
 	if (! *bus->card->mixername)
 		snd_hda_get_codec_name(codec, bus->card->mixername,
 				       sizeof(bus->card->mixername));

-------------------------------------------------------------------------
Take Surveys. Earn Cash. Influence the Future of IT
Join SourceForge.net's Techsay panel and you'll get the chance to share your
opinions on IT & business topics through brief surveys-and earn cash
http://www.techsay.com/default.php?page=join.php&p=sourceforge&CID=DEVDEV
_______________________________________________
Alsa-devel mailing list
Alsa-devel@xxxxxxxxxxxxxxxxxxxxx
https://lists.sourceforge.net/lists/listinfo/alsa-devel

[Index of Archives]     [ALSA User]     [Linux Audio Users]     [Kernel Archive]     [Asterisk PBX]     [Photo Sharing]     [Linux Sound]     [Video 4 Linux]     [Gimp]     [Yosemite News]

  Powered by Linux