[alsa-devel] [PATCH] sound/pci/rme9652: prevent reading uninitialized stack memory

Takashi Iwai tiwai at suse.de
Sat Sep 25 17:52:35 CEST 2010


At Sat, 25 Sep 2010 11:07:27 -0400,
Dan Rosenberg wrote:
> 
> The SNDRV_HDSP_IOCTL_GET_CONFIG_INFO and
> SNDRV_HDSP_IOCTL_GET_CONFIG_INFO ioctls in hdspm.c and hdsp.c allow
> unprivileged users to read uninitialized kernel stack memory, because
> several fields of the hdsp{m}_config_info structs declared on the stack
> are not altered or zeroed before being copied back to the user.  This
> patch takes care of it.
> 
> Signed-off-by: Dan Rosenberg <dan.j.rosenberg at gmail.com>

Thanks, applied now with minor optimization (memset outside
spinlock).


Takashi


> diff -urp linux-2.6.35.5.orig/sound/pci/rme9652/hdsp.c linux-2.6.35.5/sound/pci/rme9652/hdsp.c
> --- linux-2.6.35.5.orig/sound/pci/rme9652/hdsp.c	2010-09-20 16:59:09.000000000 -0400
> +++ linux-2.6.35.5/sound/pci/rme9652/hdsp.c	2010-09-25 10:59:42.000000000 -0400
> @@ -4601,6 +4601,8 @@ static int snd_hdsp_hwdep_ioctl(struct s
>  		unsigned long flags;
>  		int i;
>  
> +		memset(&info, 0, sizeof(info));
> +
>  		err = hdsp_check_for_iobox(hdsp);
>  		if (err < 0)
>  			return err;
> diff -urp linux-2.6.35.5.orig/sound/pci/rme9652/hdspm.c linux-2.6.35.5/sound/pci/rme9652/hdspm.c
> --- linux-2.6.35.5.orig/sound/pci/rme9652/hdspm.c	2010-09-20 16:59:09.000000000 -0400
> +++ linux-2.6.35.5/sound/pci/rme9652/hdspm.c	2010-09-25 10:58:44.000000000 -0400
> @@ -4128,6 +4128,9 @@ static int snd_hdspm_hwdep_ioctl(struct 
>  	case SNDRV_HDSPM_IOCTL_GET_CONFIG_INFO:
>  
>  		spin_lock_irq(&hdspm->lock);
> +		
> +		memset(&info, 0, sizeof(info));
> +		
>  		info.pref_sync_ref = hdspm_pref_sync_ref(hdspm);
>  		info.wordclock_sync_check = hdspm_wc_sync_check(hdspm);
>  
> 
> 


More information about the Alsa-devel mailing list