diff options
author | Al Viro <viro@zeniv.linux.org.uk> | 2013-03-03 12:49:06 -0500 |
---|---|---|
committer | Al Viro <viro@zeniv.linux.org.uk> | 2013-03-03 22:59:36 -0500 |
commit | 8d2d5c4a251924e4f70657e96a2a3f87647544f0 (patch) | |
tree | ada470f9738d49bfc2d55cb01f8c62188ce8ae12 /kernel/sys.c | |
parent | 35280bd4a3fa841897e2638437607fdec6c34f31 (diff) |
switch getrusage() to COMPAT_SYSCALL_DEFINE
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Diffstat (limited to 'kernel/sys.c')
-rw-r--r-- | kernel/sys.c | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/kernel/sys.c b/kernel/sys.c index 81f56445fba9..fd2b5259ad7a 100644 --- a/kernel/sys.c +++ b/kernel/sys.c | |||
@@ -1784,6 +1784,20 @@ SYSCALL_DEFINE2(getrusage, int, who, struct rusage __user *, ru) | |||
1784 | return getrusage(current, who, ru); | 1784 | return getrusage(current, who, ru); |
1785 | } | 1785 | } |
1786 | 1786 | ||
1787 | #ifdef CONFIG_COMPAT | ||
1788 | COMPAT_SYSCALL_DEFINE2(getrusage, int, who, struct compat_rusage __user *, ru) | ||
1789 | { | ||
1790 | struct rusage r; | ||
1791 | |||
1792 | if (who != RUSAGE_SELF && who != RUSAGE_CHILDREN && | ||
1793 | who != RUSAGE_THREAD) | ||
1794 | return -EINVAL; | ||
1795 | |||
1796 | k_getrusage(current, who, &r); | ||
1797 | return put_compat_rusage(&r, ru); | ||
1798 | } | ||
1799 | #endif | ||
1800 | |||
1787 | SYSCALL_DEFINE1(umask, int, mask) | 1801 | SYSCALL_DEFINE1(umask, int, mask) |
1788 | { | 1802 | { |
1789 | mask = xchg(¤t->fs->umask, mask & S_IRWXUGO); | 1803 | mask = xchg(¤t->fs->umask, mask & S_IRWXUGO); |