All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] hda: add bounds checking for the codec command fields
@ 2009-07-17  8:24 Wu Fengguang
  2009-07-17  8:27 ` Wu Fengguang
  0 siblings, 1 reply; 8+ messages in thread
From: Wu Fengguang @ 2009-07-17  8:24 UTC (permalink / raw)
  To: alsa-devel; +Cc: Takashi Iwai, Chaohong Guo

A recent bug involves passing auto detected >0x7f NID to codec command,
creating an invalid codec addr field, and finally lead to cmd timeout
and fall back into single command mode. Jaroslav fixed that bug in
alc880_parse_auto_config().

It would be safer to further check the bounds of all cmd fields.

Cc: Jaroslav Kysela <perex@perex.cz>
Signed-off-by: Wu Fengguang <fengguang.wu@intel.com>
---
diff --git a/sound/pci/hda/hda_codec.c b/sound/pci/hda/hda_codec.c
index 462e2ce..7d09650 100644
--- a/sound/pci/hda/hda_codec.c
+++ b/sound/pci/hda/hda_codec.c
@@ -150,6 +150,16 @@ make_codec_cmd(struct hda_codec *codec, hda_nid_t nid, int direct,
 {
 	u32 val;
 
+	if ((direct & ~1) || (nid & ~0x7f) ||
+	    (verb & ~0xfff) || (parm & ~0xff)) {
+		printk(KERN_ERR "hda-codec: out of range cmd %x:%x:%x:%x:%x\n",
+		       codec->addr, direct, nid, verb, parm);
+		direct &= 1;
+		nid  &= 0x7f;
+		verb &= 0xfff;
+		parm &= 0xff;
+	}
+
 	val = (u32)(codec->addr & 0x0f) << 28;
 	val |= (u32)direct << 27;
 	val |= (u32)nid << 20;

^ permalink raw reply related	[flat|nested] 8+ messages in thread

* Re: [PATCH] hda: add bounds checking for the codec command fields
  2009-07-17  8:24 [PATCH] hda: add bounds checking for the codec command fields Wu Fengguang
@ 2009-07-17  8:27 ` Wu Fengguang
  2009-07-17  8:49   ` [PATCH] hda: add bounds checking for the codec command fields v2 Wu Fengguang
  0 siblings, 1 reply; 8+ messages in thread
From: Wu Fengguang @ 2009-07-17  8:27 UTC (permalink / raw)
  To: alsa-devel; +Cc: Takashi Iwai, Chaohong Guo

On Fri, Jul 17, 2009 at 04:24:10PM +0800, Wu Fengguang wrote:
> A recent bug involves passing auto detected >0x7f NID to codec command,
> creating an invalid codec addr field, and finally lead to cmd timeout
> and fall back into single command mode. Jaroslav fixed that bug in
> alc880_parse_auto_config().
> 
> It would be safer to further check the bounds of all cmd fields.
> 
> Cc: Jaroslav Kysela <perex@perex.cz>
> Signed-off-by: Wu Fengguang <fengguang.wu@intel.com>
> ---
> diff --git a/sound/pci/hda/hda_codec.c b/sound/pci/hda/hda_codec.c
> index 462e2ce..7d09650 100644
> --- a/sound/pci/hda/hda_codec.c
> +++ b/sound/pci/hda/hda_codec.c
> @@ -150,6 +150,16 @@ make_codec_cmd(struct hda_codec *codec, hda_nid_t nid, int direct,
>  {
>  	u32 val;
>  
> +	if ((direct & ~1) || (nid & ~0x7f) ||
> +	    (verb & ~0xfff) || (parm & ~0xff)) {
> +		printk(KERN_ERR "hda-codec: out of range cmd %x:%x:%x:%x:%x\n",
> +		       codec->addr, direct, nid, verb, parm);

Maybe we shall simply return here?

> +		direct &= 1;
> +		nid  &= 0x7f;
> +		verb &= 0xfff;
> +		parm &= 0xff;
> +	}
> +
>  	val = (u32)(codec->addr & 0x0f) << 28;
>  	val |= (u32)direct << 27;
>  	val |= (u32)nid << 20;

^ permalink raw reply	[flat|nested] 8+ messages in thread

* [PATCH] hda: add bounds checking for the codec command fields v2
  2009-07-17  8:27 ` Wu Fengguang
@ 2009-07-17  8:49   ` Wu Fengguang
  2009-07-17  9:28     ` Takashi Iwai
       [not found]     ` <BB1F052FCDB1EA468BD99786C8B1ED2C05871FFCB9@PDSMSX501.ccr.corp.intel.com>
  0 siblings, 2 replies; 8+ messages in thread
From: Wu Fengguang @ 2009-07-17  8:49 UTC (permalink / raw)
  To: alsa-devel; +Cc: Takashi Iwai, Chaohong Guo, John Villalovos

On Fri, Jul 17, 2009 at 04:27:03PM +0800, Wu Fengguang wrote:
> On Fri, Jul 17, 2009 at 04:24:10PM +0800, Wu Fengguang wrote:
> > A recent bug involves passing auto detected >0x7f NID to codec command,
> > creating an invalid codec addr field, and finally lead to cmd timeout
> > and fall back into single command mode. Jaroslav fixed that bug in
> > alc880_parse_auto_config().
> > 
> > It would be safer to further check the bounds of all cmd fields.
> > 
> > Cc: Jaroslav Kysela <perex@perex.cz>
> > Signed-off-by: Wu Fengguang <fengguang.wu@intel.com>
> > ---
> > diff --git a/sound/pci/hda/hda_codec.c b/sound/pci/hda/hda_codec.c
> > index 462e2ce..7d09650 100644
> > --- a/sound/pci/hda/hda_codec.c
> > +++ b/sound/pci/hda/hda_codec.c
> > @@ -150,6 +150,16 @@ make_codec_cmd(struct hda_codec *codec, hda_nid_t nid, int direct,
> >  {
> >  	u32 val;
> >  
> > +	if ((direct & ~1) || (nid & ~0x7f) ||
> > +	    (verb & ~0xfff) || (parm & ~0xff)) {
> > +		printk(KERN_ERR "hda-codec: out of range cmd %x:%x:%x:%x:%x\n",
> > +		       codec->addr, direct, nid, verb, parm);
> 
> Maybe we shall simply return here?

Here it is :)

---
hda: add bounds checking for the codec command fields

A recent bug involves passing auto detected >0x7f NID to codec command,
creating an invalid codec addr field, and finally lead to cmd timeout
and fall back into single command mode. Jaroslav fixed that bug in
alc880_parse_auto_config().

It would be safer to further check the bounds of all cmd fields.

Cc: Jaroslav Kysela <perex@perex.cz>
Signed-off-by: Wu Fengguang <fengguang.wu@intel.com>
---
 sound/pci/hda/hda_codec.c |   12 +++++++++++-
 1 file changed, 11 insertions(+), 1 deletion(-)

--- sound-2.6.orig/sound/pci/hda/hda_codec.c
+++ sound-2.6/sound/pci/hda/hda_codec.c
@@ -150,7 +150,14 @@ make_codec_cmd(struct hda_codec *codec, 
 {
 	u32 val;
 
-	val = (u32)(codec->addr & 0x0f) << 28;
+	if ((codec->addr & ~0xf) | (direct & ~1) | (nid & ~0x7f) |
+	    (verb & ~0xfff) | (parm & ~0xff)) {
+		printk(KERN_ERR "hda-codec: out of range cmd %x:%x:%x:%x:%x\n",
+		       codec->addr, direct, nid, verb, parm);
+		return ~0;
+	}
+
+	val = (u32)codec->addr << 28;
 	val |= (u32)direct << 27;
 	val |= (u32)nid << 20;
 	val |= verb << 8;
@@ -167,6 +174,9 @@ static int codec_exec_verb(struct hda_co
 	struct hda_bus *bus = codec->bus;
 	int err;
 
+	if (cmd == ~0)
+		return -1;
+
 	if (res)
 		*res = -1;
  again:

^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [PATCH] hda: add bounds checking for the codec command fields v2
  2009-07-17  8:49   ` [PATCH] hda: add bounds checking for the codec command fields v2 Wu Fengguang
@ 2009-07-17  9:28     ` Takashi Iwai
       [not found]     ` <BB1F052FCDB1EA468BD99786C8B1ED2C05871FFCB9@PDSMSX501.ccr.corp.intel.com>
  1 sibling, 0 replies; 8+ messages in thread
From: Takashi Iwai @ 2009-07-17  9:28 UTC (permalink / raw)
  To: Wu Fengguang; +Cc: Chaohong Guo, alsa-devel, John Villalovos

At Fri, 17 Jul 2009 16:49:19 +0800,
Wu Fengguang wrote:
> 
> On Fri, Jul 17, 2009 at 04:27:03PM +0800, Wu Fengguang wrote:
> > On Fri, Jul 17, 2009 at 04:24:10PM +0800, Wu Fengguang wrote:
> > > A recent bug involves passing auto detected >0x7f NID to codec command,
> > > creating an invalid codec addr field, and finally lead to cmd timeout
> > > and fall back into single command mode. Jaroslav fixed that bug in
> > > alc880_parse_auto_config().
> > > 
> > > It would be safer to further check the bounds of all cmd fields.
> > > 
> > > Cc: Jaroslav Kysela <perex@perex.cz>
> > > Signed-off-by: Wu Fengguang <fengguang.wu@intel.com>
> > > ---
> > > diff --git a/sound/pci/hda/hda_codec.c b/sound/pci/hda/hda_codec.c
> > > index 462e2ce..7d09650 100644
> > > --- a/sound/pci/hda/hda_codec.c
> > > +++ b/sound/pci/hda/hda_codec.c
> > > @@ -150,6 +150,16 @@ make_codec_cmd(struct hda_codec *codec, hda_nid_t nid, int direct,
> > >  {
> > >  	u32 val;
> > >  
> > > +	if ((direct & ~1) || (nid & ~0x7f) ||
> > > +	    (verb & ~0xfff) || (parm & ~0xff)) {
> > > +		printk(KERN_ERR "hda-codec: out of range cmd %x:%x:%x:%x:%x\n",
> > > +		       codec->addr, direct, nid, verb, parm);
> > 
> > Maybe we shall simply return here?
> 
> Here it is :)
> 
> ---
> hda: add bounds checking for the codec command fields
> 
> A recent bug involves passing auto detected >0x7f NID to codec command,
> creating an invalid codec addr field, and finally lead to cmd timeout
> and fall back into single command mode. Jaroslav fixed that bug in
> alc880_parse_auto_config().
> 
> It would be safer to further check the bounds of all cmd fields.
> 
> Cc: Jaroslav Kysela <perex@perex.cz>
> Signed-off-by: Wu Fengguang <fengguang.wu@intel.com>

Looks good.  Applied now.

Thanks!

Takashi


> ---
>  sound/pci/hda/hda_codec.c |   12 +++++++++++-
>  1 file changed, 11 insertions(+), 1 deletion(-)
> 
> --- sound-2.6.orig/sound/pci/hda/hda_codec.c
> +++ sound-2.6/sound/pci/hda/hda_codec.c
> @@ -150,7 +150,14 @@ make_codec_cmd(struct hda_codec *codec, 
>  {
>  	u32 val;
>  
> -	val = (u32)(codec->addr & 0x0f) << 28;
> +	if ((codec->addr & ~0xf) | (direct & ~1) | (nid & ~0x7f) |
> +	    (verb & ~0xfff) | (parm & ~0xff)) {
> +		printk(KERN_ERR "hda-codec: out of range cmd %x:%x:%x:%x:%x\n",
> +		       codec->addr, direct, nid, verb, parm);
> +		return ~0;
> +	}
> +
> +	val = (u32)codec->addr << 28;
>  	val |= (u32)direct << 27;
>  	val |= (u32)nid << 20;
>  	val |= verb << 8;
> @@ -167,6 +174,9 @@ static int codec_exec_verb(struct hda_co
>  	struct hda_bus *bus = codec->bus;
>  	int err;
>  
> +	if (cmd == ~0)
> +		return -1;
> +
>  	if (res)
>  		*res = -1;
>   again:
> 

^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [PATCH] hda: add bounds checking for the codec command fields v2
       [not found]       ` <s5hljmn8u52.wl%tiwai@suse.de>
@ 2009-07-17 10:53         ` Takashi Iwai
  2009-07-17 11:10           ` Wu Fengguang
  2009-07-17 11:05         ` Wu Fengguang
  1 sibling, 1 reply; 8+ messages in thread
From: Takashi Iwai @ 2009-07-17 10:53 UTC (permalink / raw)
  To: Wu, Fengguang; +Cc: Guo, Chaohong, alsa-devel@alsa-project.org, John Villalovos

At Fri, 17 Jul 2009 12:46:01 +0200,
I wrote:
> 
> At Fri, 17 Jul 2009 18:41:05 +0800,
> Guo, Chaohong wrote:
> > 
> > Although it does address this issue, I am not comfortable with this fixing. 
> > It seems more like a workaround than fix.
> 
> No, it's rather for catching a bug.  This is definitely neither
> "workaround" nor "fix".

BTW, I fixed the patch again as below.


Takashi

---
>From 82e1b804b03defe46fb69ffd2c8b19e6649bcb0d Mon Sep 17 00:00:00 2001
From: Takashi Iwai <tiwai@suse.de>
Date: Fri, 17 Jul 2009 12:47:34 +0200
Subject: [PATCH] ALSA: hda - Fix the previous sanity check in make_codec_cmd()

The newly added sanity-check for a codec verb can be better written
with logical ORs.  Also, the parameter can be more than 8bit.

Signed-off-by: Takashi Iwai <tiwai@suse.de>
---
 sound/pci/hda/hda_codec.c |    4 ++--
 1 files changed, 2 insertions(+), 2 deletions(-)

diff --git a/sound/pci/hda/hda_codec.c b/sound/pci/hda/hda_codec.c
index d9d3262..35f0f22 100644
--- a/sound/pci/hda/hda_codec.c
+++ b/sound/pci/hda/hda_codec.c
@@ -150,8 +150,8 @@ make_codec_cmd(struct hda_codec *codec, hda_nid_t nid, int direct,
 {
 	u32 val;
 
-	if ((codec->addr & ~0xf) | (direct & ~1) | (nid & ~0x7f) |
-	    (verb & ~0xfff) | (parm & ~0xff)) {
+	if ((codec->addr & ~0xf) || (direct & ~1) || (nid & ~0x7f) ||
+	    (verb & ~0xfff) || (parm & ~0xffff)) {
 		printk(KERN_ERR "hda-codec: out of range cmd %x:%x:%x:%x:%x\n",
 		       codec->addr, direct, nid, verb, parm);
 		return ~0;
-- 
1.6.3.2

^ permalink raw reply related	[flat|nested] 8+ messages in thread

* Re: [PATCH] hda: add bounds checking for the codec command fields v2
       [not found]       ` <s5hljmn8u52.wl%tiwai@suse.de>
  2009-07-17 10:53         ` Takashi Iwai
@ 2009-07-17 11:05         ` Wu Fengguang
  2009-07-20  2:13           ` Guo, Chaohong
  1 sibling, 1 reply; 8+ messages in thread
From: Wu Fengguang @ 2009-07-17 11:05 UTC (permalink / raw)
  To: Takashi Iwai; +Cc: Guo, Chaohong, alsa-devel@alsa-project.org, John Villalovos

On Fri, Jul 17, 2009 at 06:46:01PM +0800, Takashi Iwai wrote:
> At Fri, 17 Jul 2009 18:41:05 +0800,
> Guo, Chaohong wrote:
> > 
> > Although it does address this issue, I am not comfortable with this fixing. 
> > It seems more like a workaround than fix.
> 
> No, it's rather for catching a bug.  This is definitely neither
> "workaround" nor "fix".

Yes, I wrote this mainly for catching unknown bugs.

> >  Moreover, if long format node
> > ID is used in the future,  the code will cause little trouble for maintaining.
> 
> Well, the current code doesn't support the long id (as the restriction
> of HD-audio controller side), so we'd need major changes in anyway.
> Thus this check is no big issue for maintenance, at least to me :)

Does the HDA spec define cmd format that accept long form NID?
If so, can you point me to the specific location please? Thanks.

> > what I want is to fix it during parsing connection list, and verify the node
> > id is valid there .  
> 
> Heh, this was already fixed :)

AFAIK, snd_hda_get_connections() won't return NIDs bigger than
0x7f(short) or 0x7ffff(long).

Thanks,
Fengguang

^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [PATCH] hda: add bounds checking for the codec command fields v2
  2009-07-17 10:53         ` Takashi Iwai
@ 2009-07-17 11:10           ` Wu Fengguang
  0 siblings, 0 replies; 8+ messages in thread
From: Wu Fengguang @ 2009-07-17 11:10 UTC (permalink / raw)
  To: Takashi Iwai; +Cc: Guo, Chaohong, alsa-devel@alsa-project.org, John Villalovos

On Fri, Jul 17, 2009 at 06:53:24PM +0800, Takashi Iwai wrote:
> At Fri, 17 Jul 2009 12:46:01 +0200,
> I wrote:
> > 
> > At Fri, 17 Jul 2009 18:41:05 +0800,
> > Guo, Chaohong wrote:
> > > 
> > > Although it does address this issue, I am not comfortable with this fixing. 
> > > It seems more like a workaround than fix.
> > 
> > No, it's rather for catching a bug.  This is definitely neither
> > "workaround" nor "fix".
> 
> BTW, I fixed the patch again as below.
> 
> 
> Takashi
> 
> ---
> >From 82e1b804b03defe46fb69ffd2c8b19e6649bcb0d Mon Sep 17 00:00:00 2001
> From: Takashi Iwai <tiwai@suse.de>
> Date: Fri, 17 Jul 2009 12:47:34 +0200
> Subject: [PATCH] ALSA: hda - Fix the previous sanity check in make_codec_cmd()
> 
> The newly added sanity-check for a codec verb can be better written
> with logical ORs.  Also, the parameter can be more than 8bit.

Ah OK, thanks for the fix!

Thanks,
Fengguang

^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [PATCH] hda: add bounds checking for the codec command fields v2
  2009-07-17 11:05         ` Wu Fengguang
@ 2009-07-20  2:13           ` Guo, Chaohong
  0 siblings, 0 replies; 8+ messages in thread
From: Guo, Chaohong @ 2009-07-20  2:13 UTC (permalink / raw)
  To: Wu, Fengguang, Takashi Iwai
  Cc: alsa-devel@alsa-project.org, John Villalovos, Jaroslav

 

>Cc: Guo, Chaohong; alsa-devel@alsa-project.org; Jaroslav 
>Kysela; John Villalovos
>Subject: Re: [PATCH] hda: add bounds checking for the codec 
>command fields v2
>
>On Fri, Jul 17, 2009 at 06:46:01PM +0800, Takashi Iwai wrote:
>> At Fri, 17 Jul 2009 18:41:05 +0800,
>> Guo, Chaohong wrote:
>> > 
>> > Although it does address this issue, I am not comfortable 
>with this fixing. 
>> > It seems more like a workaround than fix.
>> 
>> No, it's rather for catching a bug.  This is definitely neither
>> "workaround" nor "fix".
>
>Yes, I wrote this mainly for catching unknown bugs.

Oh, I misunderstood your intention.  So, we still need to  investigate
the bug which occurs on RH i386 version  :)



>
>> >  Moreover, if long format node
>> > ID is used in the future,  the code will cause little 
>trouble for maintaining.
>> 
>> Well, the current code doesn't support the long id (as the 
>restriction
>> of HD-audio controller side), so we'd need major changes in anyway.
>> Thus this check is no big issue for maintenance, at least to me :)
>
>Does the HDA spec define cmd format that accept long form NID?
>If so, can you point me to the specific location please? Thanks.

No.  AFAIK,  HDA doesn't specifiy long NID verb yet,  I said "In the
feature".   but who knows why hardware vendors want to use long
NID in the future,  seems 128 is enough.


-minskey


>
>> > what I want is to fix it during parsing connection list, 
>and verify the node
>> > id is valid there .  
>> 
>> Heh, this was already fixed :)
>
>AFAIK, snd_hda_get_connections() won't return NIDs bigger than
>0x7f(short) or 0x7ffff(long).
>
>Thanks,
>Fengguang
>

^ permalink raw reply	[flat|nested] 8+ messages in thread

end of thread, other threads:[~2009-07-20  2:15 UTC | newest]

Thread overview: 8+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2009-07-17  8:24 [PATCH] hda: add bounds checking for the codec command fields Wu Fengguang
2009-07-17  8:27 ` Wu Fengguang
2009-07-17  8:49   ` [PATCH] hda: add bounds checking for the codec command fields v2 Wu Fengguang
2009-07-17  9:28     ` Takashi Iwai
     [not found]     ` <BB1F052FCDB1EA468BD99786C8B1ED2C05871FFCB9@PDSMSX501.ccr.corp.intel.com>
     [not found]       ` <s5hljmn8u52.wl%tiwai@suse.de>
2009-07-17 10:53         ` Takashi Iwai
2009-07-17 11:10           ` Wu Fengguang
2009-07-17 11:05         ` Wu Fengguang
2009-07-20  2:13           ` Guo, Chaohong

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.