s390/cmm: fix information leak in cmm_timeout_handler()
commit b8e51a6a9d
upstream.
The problem is that we were putting the NUL terminator too far:
buf[sizeof(buf) - 1] = '\0';
If the user input isn't NUL terminated and they haven't initialized the
whole buffer then it leads to an info leak. The NUL terminator should
be:
buf[len - 1] = '\0';
Signed-off-by: Yihui Zeng <yzeng56@asu.edu>
Cc: stable@vger.kernel.org
Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
[heiko.carstens@de.ibm.com: keep semantics of how *lenp and *ppos are handled]
Signed-off-by: Heiko Carstens <heiko.carstens@de.ibm.com>
Signed-off-by: Vasily Gorbik <gor@linux.ibm.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
2b56c89ae8
commit
119e9aef45
@ -307,16 +307,16 @@ static int cmm_timeout_handler(struct ctl_table *ctl, int write,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (write) {
|
if (write) {
|
||||||
len = *lenp;
|
len = min(*lenp, sizeof(buf));
|
||||||
if (copy_from_user(buf, buffer,
|
if (copy_from_user(buf, buffer, len))
|
||||||
len > sizeof(buf) ? sizeof(buf) : len))
|
|
||||||
return -EFAULT;
|
return -EFAULT;
|
||||||
buf[sizeof(buf) - 1] = '\0';
|
buf[len - 1] = '\0';
|
||||||
cmm_skip_blanks(buf, &p);
|
cmm_skip_blanks(buf, &p);
|
||||||
nr = simple_strtoul(p, &p, 0);
|
nr = simple_strtoul(p, &p, 0);
|
||||||
cmm_skip_blanks(p, &p);
|
cmm_skip_blanks(p, &p);
|
||||||
seconds = simple_strtoul(p, &p, 0);
|
seconds = simple_strtoul(p, &p, 0);
|
||||||
cmm_set_timeout(nr, seconds);
|
cmm_set_timeout(nr, seconds);
|
||||||
|
*ppos += *lenp;
|
||||||
} else {
|
} else {
|
||||||
len = sprintf(buf, "%ld %ld\n",
|
len = sprintf(buf, "%ld %ld\n",
|
||||||
cmm_timeout_pages, cmm_timeout_seconds);
|
cmm_timeout_pages, cmm_timeout_seconds);
|
||||||
@ -324,9 +324,9 @@ static int cmm_timeout_handler(struct ctl_table *ctl, int write,
|
|||||||
len = *lenp;
|
len = *lenp;
|
||||||
if (copy_to_user(buffer, buf, len))
|
if (copy_to_user(buffer, buf, len))
|
||||||
return -EFAULT;
|
return -EFAULT;
|
||||||
|
*lenp = len;
|
||||||
|
*ppos += len;
|
||||||
}
|
}
|
||||||
*lenp = len;
|
|
||||||
*ppos += len;
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user