aboutsummaryrefslogtreecommitdiffstats
path: root/sound/core/compress_offload.c
diff options
context:
space:
mode:
authorDan Carpenter <dan.carpenter@oracle.com>2013-04-21 07:07:29 -0400
committerTakashi Iwai <tiwai@suse.de>2013-04-22 04:34:46 -0400
commit1c62e9f2b5a97c53aaae490f844949d32cca6dc6 (patch)
tree8a69eaf2daf2872b21b3617fe9072ead3422fa09 /sound/core/compress_offload.c
parentf0283b58d01d36910fcd195d1fc365a3356b2be0 (diff)
ALSA: compress: info leak in snd_compr_get_caps()
If the ->get_caps() function doesn't clear the buffer then there would stack information leaked to userspace. For example, soc_compr_get_caps() can return success without clearing the buffer. Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com> Signed-off-by: Takashi Iwai <tiwai@suse.de>
Diffstat (limited to 'sound/core/compress_offload.c')
-rw-r--r--sound/core/compress_offload.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/sound/core/compress_offload.c b/sound/core/compress_offload.c
index 7941ace78283..664c69398b41 100644
--- a/sound/core/compress_offload.c
+++ b/sound/core/compress_offload.c
@@ -409,6 +409,7 @@ snd_compr_get_caps(struct snd_compr_stream *stream, unsigned long arg)
409 if (!stream->ops->get_caps) 409 if (!stream->ops->get_caps)
410 return -ENXIO; 410 return -ENXIO;
411 411
412 memset(&caps, 0, sizeof(caps));
412 retval = stream->ops->get_caps(stream, &caps); 413 retval = stream->ops->get_caps(stream, &caps);
413 if (retval) 414 if (retval)
414 goto out; 415 goto out;