[alsa-devel] [PATCH] hda: add bounds checking for the codec command fields v2

Takashi Iwai tiwai at suse.de
Fri Jul 17 11:28:52 CEST 2009


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 at perex.cz>
> > > Signed-off-by: Wu Fengguang <fengguang.wu at 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 at perex.cz>
> Signed-off-by: Wu Fengguang <fengguang.wu at 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:
> 


More information about the Alsa-devel mailing list