kernel-janitors.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [patch] ALSA: echoaudio: read past end of array
@ 2015-03-23  9:41 Dan Carpenter
  2015-03-23 13:00 ` Takashi Iwai
  0 siblings, 1 reply; 2+ messages in thread
From: Dan Carpenter @ 2015-03-23  9:41 UTC (permalink / raw)
  To: Jaroslav Kysela
  Cc: Takashi Iwai, alsa-devel, kernel-janitors, Sudip Mukherjee,
	Sachin Kamat

We need to cap "ucontrol->id.index / num_busses_in(chip)" so the we
don't read beyond the end of the array.

I also adding a check on "in" and changing the type in
snd_echo_mixer_put() from short to unsigned int. Those changes are done
for symmetry and are cosmetic.

Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>

diff --git a/sound/pci/echoaudio/echoaudio.c b/sound/pci/echoaudio/echoaudio.c
index a962de0..862db9a 100644
--- a/sound/pci/echoaudio/echoaudio.c
+++ b/sound/pci/echoaudio/echoaudio.c
@@ -1283,12 +1283,14 @@ static int snd_echo_mixer_info(struct snd_kcontrol *kcontrol,
 static int snd_echo_mixer_get(struct snd_kcontrol *kcontrol,
 			      struct snd_ctl_elem_value *ucontrol)
 {
-	struct echoaudio *chip;
+	struct echoaudio *chip = snd_kcontrol_chip(kcontrol);
+	unsigned int out = ucontrol->id.index / num_busses_in(chip);
+	unsigned int in = ucontrol->id.index % num_busses_in(chip);
 
-	chip = snd_kcontrol_chip(kcontrol);
-	ucontrol->value.integer.value[0] -		chip->monitor_gain[ucontrol->id.index / num_busses_in(chip)]
-			[ucontrol->id.index % num_busses_in(chip)];
+	if (out >= ECHO_MAXAUDIOOUTPUTS || in >= ECHO_MAXAUDIOINPUTS)
+		return -EINVAL;
+
+	ucontrol->value.integer.value[0] = chip->monitor_gain[out][in];
 	return 0;
 }
 
@@ -1297,12 +1299,14 @@ static int snd_echo_mixer_put(struct snd_kcontrol *kcontrol,
 {
 	struct echoaudio *chip;
 	int changed,  gain;
-	short out, in;
+	unsigned int out, in;
 
 	changed = 0;
 	chip = snd_kcontrol_chip(kcontrol);
 	out = ucontrol->id.index / num_busses_in(chip);
 	in = ucontrol->id.index % num_busses_in(chip);
+	if (out >= ECHO_MAXAUDIOOUTPUTS || in >= ECHO_MAXAUDIOINPUTS)
+		return -EINVAL;
 	gain = ucontrol->value.integer.value[0];
 	if (gain < ECHOGAIN_MINOUT || gain > ECHOGAIN_MAXOUT)
 		return -EINVAL;

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

* Re: [patch] ALSA: echoaudio: read past end of array
  2015-03-23  9:41 [patch] ALSA: echoaudio: read past end of array Dan Carpenter
@ 2015-03-23 13:00 ` Takashi Iwai
  0 siblings, 0 replies; 2+ messages in thread
From: Takashi Iwai @ 2015-03-23 13:00 UTC (permalink / raw)
  To: Dan Carpenter
  Cc: Jaroslav Kysela, Sudip Mukherjee, Sachin Kamat, alsa-devel,
	kernel-janitors

At Mon, 23 Mar 2015 12:41:31 +0300,
Dan Carpenter wrote:
> 
> We need to cap "ucontrol->id.index / num_busses_in(chip)" so the we
> don't read beyond the end of the array.
> 
> I also adding a check on "in" and changing the type in
> snd_echo_mixer_put() from short to unsigned int. Those changes are done
> for symmetry and are cosmetic.
> 
> Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>

Applied, thanks.


Takashi

> 
> diff --git a/sound/pci/echoaudio/echoaudio.c b/sound/pci/echoaudio/echoaudio.c
> index a962de0..862db9a 100644
> --- a/sound/pci/echoaudio/echoaudio.c
> +++ b/sound/pci/echoaudio/echoaudio.c
> @@ -1283,12 +1283,14 @@ static int snd_echo_mixer_info(struct snd_kcontrol *kcontrol,
>  static int snd_echo_mixer_get(struct snd_kcontrol *kcontrol,
>  			      struct snd_ctl_elem_value *ucontrol)
>  {
> -	struct echoaudio *chip;
> +	struct echoaudio *chip = snd_kcontrol_chip(kcontrol);
> +	unsigned int out = ucontrol->id.index / num_busses_in(chip);
> +	unsigned int in = ucontrol->id.index % num_busses_in(chip);
>  
> -	chip = snd_kcontrol_chip(kcontrol);
> -	ucontrol->value.integer.value[0] > -		chip->monitor_gain[ucontrol->id.index / num_busses_in(chip)]
> -			[ucontrol->id.index % num_busses_in(chip)];
> +	if (out >= ECHO_MAXAUDIOOUTPUTS || in >= ECHO_MAXAUDIOINPUTS)
> +		return -EINVAL;
> +
> +	ucontrol->value.integer.value[0] = chip->monitor_gain[out][in];
>  	return 0;
>  }
>  
> @@ -1297,12 +1299,14 @@ static int snd_echo_mixer_put(struct snd_kcontrol *kcontrol,
>  {
>  	struct echoaudio *chip;
>  	int changed,  gain;
> -	short out, in;
> +	unsigned int out, in;
>  
>  	changed = 0;
>  	chip = snd_kcontrol_chip(kcontrol);
>  	out = ucontrol->id.index / num_busses_in(chip);
>  	in = ucontrol->id.index % num_busses_in(chip);
> +	if (out >= ECHO_MAXAUDIOOUTPUTS || in >= ECHO_MAXAUDIOINPUTS)
> +		return -EINVAL;
>  	gain = ucontrol->value.integer.value[0];
>  	if (gain < ECHOGAIN_MINOUT || gain > ECHOGAIN_MAXOUT)
>  		return -EINVAL;
> 

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

end of thread, other threads:[~2015-03-23 13:00 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2015-03-23  9:41 [patch] ALSA: echoaudio: read past end of array Dan Carpenter
2015-03-23 13:00 ` Takashi Iwai

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).