[alsa-devel] [PATCH v2] hda: fix out-of-bound hdmi_eld.sad[] write

Takashi Iwai tiwai at suse.de
Wed Jul 29 14:45:04 CEST 2009


At Wed, 29 Jul 2009 19:31:14 +0800,
Wu Fengguang wrote:
> 
> On Wed, Jul 29, 2009 at 12:25:11PM +0200, Roel Kluin wrote:
> > e->sad[] is declared with size ELD_MAX_SAD (16), but the guard allows
> > the range 0-31
> 
> Good catch, thank you, Roel!
> 
> Minor fix: '>=' should be used in this line:
> 
> > +			if (n < 0 || n > ELD_MAX_SAD)
> 
> So I'd suggest this updated patch.

Applied the updated one now.  Thanks.


Takashi


> Thanks,
> Fengguang
> ---
> hda: fix out-of-bound hdmi_eld.sad[] write
> 
> From: Roel Kluin <roel.kluin at gmail.com>
> 
> e->sad[] is declared with size ELD_MAX_SAD=16, but the guard
> allows range 0-31.
> 
> Signed-off-by: Roel Kluin <roel.kluin at gmail.com>
> Signed-off-by: Wu Fengguang <fengguang.wu at intel.com>
> ---
>  sound/pci/hda/hda_eld.c |    4 ++--
>  1 file changed, 2 insertions(+), 2 deletions(-)
> 
> --- sound-2.6.orig/sound/pci/hda/hda_eld.c
> +++ sound-2.6/sound/pci/hda/hda_eld.c
> @@ -508,7 +508,7 @@ static void hdmi_write_eld_info(struct s
>  	char name[64];
>  	char *sname;
>  	long long val;
> -	int n;
> +	unsigned int n;
>  
>  	while (!snd_info_get_line(buffer, line, sizeof(line))) {
>  		if (sscanf(line, "%s %llx", name, &val) != 2)
> @@ -539,7 +539,7 @@ static void hdmi_write_eld_info(struct s
>  				sname++;
>  				n = 10 * n + name[4] - '0';
>  			}
> -			if (n < 0 || n > 31) /* double the CEA limit */
> +			if (n >= ELD_MAX_SAD)
>  				continue;
>  			if (!strcmp(sname, "_coding_type"))
>  				e->sad[n].format = val;
> 


More information about the Alsa-devel mailing list