Commit 9e584556 authored by Takashi Iwai's avatar Takashi Iwai Committed by Luis Henriques

ALSA: info: Limit the proc text input size

BugLink: http://bugs.launchpad.net/bugs/1642968

commit 027a9fe6 upstream.

The ALSA proc handler allows currently the write in the unlimited size
until kmalloc() fails.  But basically the write is supposed to be only
for small inputs, mostly for one line inputs, and we don't have to
handle too large sizes at all.  Since the kmalloc error results in the
kernel warning, it's better to limit the size beforehand.

This patch adds the limit of 16kB, which must be large enough for the
currently existing code.
Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: default avatarTim Gardner <tim.gardner@canonical.com>
parent 43d1eda3
...@@ -331,6 +331,9 @@ static ssize_t snd_info_text_entry_write(struct file *file, ...@@ -331,6 +331,9 @@ static ssize_t snd_info_text_entry_write(struct file *file,
if (!valid_pos(pos, count)) if (!valid_pos(pos, count))
return -EIO; return -EIO;
next = pos + count; next = pos + count;
/* don't handle too large text inputs */
if (next > 16 * 1024)
return -EIO;
mutex_lock(&entry->access); mutex_lock(&entry->access);
buf = data->wbuffer; buf = data->wbuffer;
if (!buf) { if (!buf) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment