Skip to content

Commit

Permalink
ipc: initialize structure memory to zero for compat functions
Browse files Browse the repository at this point in the history
This takes care of leaking uninitialized kernel stack memory to
userspace from non-zeroed fields in structs in compat ipc functions.

Signed-off-by: Dan Rosenberg <drosenberg@vsecurity.com>
Cc: Manfred Spraul <manfred@colorfullife.com>
Cc: Arnd Bergmann <arnd@arndb.de>
Cc: <stable@kernel.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
  • Loading branch information
Dan Rosenberg authored and torvalds committed Oct 28, 2010
1 parent b795218 commit 03145be
Show file tree
Hide file tree
Showing 2 changed files with 11 additions and 0 deletions.
6 changes: 6 additions & 0 deletions ipc/compat.c
Original file line number Diff line number Diff line change
Expand Up @@ -241,6 +241,8 @@ long compat_sys_semctl(int first, int second, int third, void __user *uptr)
struct semid64_ds __user *up64;
int version = compat_ipc_parse_version(&third);

memset(&s64, 0, sizeof(s64));

if (!uptr)
return -EINVAL;
if (get_user(pad, (u32 __user *) uptr))
Expand Down Expand Up @@ -421,6 +423,8 @@ long compat_sys_msgctl(int first, int second, void __user *uptr)
int version = compat_ipc_parse_version(&second);
void __user *p;

memset(&m64, 0, sizeof(m64));

switch (second & (~IPC_64)) {
case IPC_INFO:
case IPC_RMID:
Expand Down Expand Up @@ -594,6 +598,8 @@ long compat_sys_shmctl(int first, int second, void __user *uptr)
int err, err2;
int version = compat_ipc_parse_version(&second);

memset(&s64, 0, sizeof(s64));

switch (second & (~IPC_64)) {
case IPC_RMID:
case SHM_LOCK:
Expand Down
5 changes: 5 additions & 0 deletions ipc/compat_mq.c
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,9 @@ asmlinkage long compat_sys_mq_open(const char __user *u_name,
void __user *p = NULL;
if (u_attr && oflag & O_CREAT) {
struct mq_attr attr;

memset(&attr, 0, sizeof(attr));

p = compat_alloc_user_space(sizeof(attr));
if (get_compat_mq_attr(&attr, u_attr) ||
copy_to_user(p, &attr, sizeof(attr)))
Expand Down Expand Up @@ -127,6 +130,8 @@ asmlinkage long compat_sys_mq_getsetattr(mqd_t mqdes,
struct mq_attr __user *p = compat_alloc_user_space(2 * sizeof(*p));
long ret;

memset(&mqstat, 0, sizeof(mqstat));

if (u_mqstat) {
if (get_compat_mq_attr(&mqstat, u_mqstat) ||
copy_to_user(p, &mqstat, sizeof(mqstat)))
Expand Down

0 comments on commit 03145be

Please sign in to comment.