Blame view
kernel/uid16.c
5.28 KB
1da177e4c
|
1 2 3 4 5 6 |
/* * Wrapper functions for 16bit uid back compatibility. All nicely tied * together in the faint hope we can take the out in five years time. */ #include <linux/mm.h> |
1da177e4c
|
7 |
#include <linux/mman.h> |
1da177e4c
|
8 9 10 |
#include <linux/notifier.h> #include <linux/reboot.h> #include <linux/prctl.h> |
c59ede7b7
|
11 |
#include <linux/capability.h> |
1da177e4c
|
12 13 14 15 16 17 |
#include <linux/init.h> #include <linux/highuid.h> #include <linux/security.h> #include <linux/syscalls.h> #include <asm/uaccess.h> |
ca013e945
|
18 |
SYSCALL_DEFINE3(chown16, const char __user *, filename, old_uid_t, user, old_gid_t, group) |
1da177e4c
|
19 |
{ |
5a7b46b36
|
20 21 |
long ret = sys_chown(filename, low2highuid(user), low2highgid(group)); /* avoid REGPARM breakage on x86: */ |
54a015104
|
22 |
asmlinkage_protect(3, ret, filename, user, group); |
5a7b46b36
|
23 |
return ret; |
1da177e4c
|
24 |
} |
ca013e945
|
25 |
SYSCALL_DEFINE3(lchown16, const char __user *, filename, old_uid_t, user, old_gid_t, group) |
1da177e4c
|
26 |
{ |
5a7b46b36
|
27 28 |
long ret = sys_lchown(filename, low2highuid(user), low2highgid(group)); /* avoid REGPARM breakage on x86: */ |
54a015104
|
29 |
asmlinkage_protect(3, ret, filename, user, group); |
5a7b46b36
|
30 |
return ret; |
1da177e4c
|
31 |
} |
ca013e945
|
32 |
SYSCALL_DEFINE3(fchown16, unsigned int, fd, old_uid_t, user, old_gid_t, group) |
1da177e4c
|
33 |
{ |
5a7b46b36
|
34 35 |
long ret = sys_fchown(fd, low2highuid(user), low2highgid(group)); /* avoid REGPARM breakage on x86: */ |
54a015104
|
36 |
asmlinkage_protect(3, ret, fd, user, group); |
5a7b46b36
|
37 |
return ret; |
1da177e4c
|
38 |
} |
a6b42e83f
|
39 |
SYSCALL_DEFINE2(setregid16, old_gid_t, rgid, old_gid_t, egid) |
1da177e4c
|
40 |
{ |
5a7b46b36
|
41 42 |
long ret = sys_setregid(low2highgid(rgid), low2highgid(egid)); /* avoid REGPARM breakage on x86: */ |
54a015104
|
43 |
asmlinkage_protect(2, ret, rgid, egid); |
5a7b46b36
|
44 |
return ret; |
1da177e4c
|
45 |
} |
a6b42e83f
|
46 |
SYSCALL_DEFINE1(setgid16, old_gid_t, gid) |
1da177e4c
|
47 |
{ |
5a7b46b36
|
48 49 |
long ret = sys_setgid(low2highgid(gid)); /* avoid REGPARM breakage on x86: */ |
54a015104
|
50 |
asmlinkage_protect(1, ret, gid); |
5a7b46b36
|
51 |
return ret; |
1da177e4c
|
52 |
} |
a6b42e83f
|
53 |
SYSCALL_DEFINE2(setreuid16, old_uid_t, ruid, old_uid_t, euid) |
1da177e4c
|
54 |
{ |
5a7b46b36
|
55 56 |
long ret = sys_setreuid(low2highuid(ruid), low2highuid(euid)); /* avoid REGPARM breakage on x86: */ |
54a015104
|
57 |
asmlinkage_protect(2, ret, ruid, euid); |
5a7b46b36
|
58 |
return ret; |
1da177e4c
|
59 |
} |
a6b42e83f
|
60 |
SYSCALL_DEFINE1(setuid16, old_uid_t, uid) |
1da177e4c
|
61 |
{ |
5a7b46b36
|
62 63 |
long ret = sys_setuid(low2highuid(uid)); /* avoid REGPARM breakage on x86: */ |
54a015104
|
64 |
asmlinkage_protect(1, ret, uid); |
5a7b46b36
|
65 |
return ret; |
1da177e4c
|
66 |
} |
a6b42e83f
|
67 |
SYSCALL_DEFINE3(setresuid16, old_uid_t, ruid, old_uid_t, euid, old_uid_t, suid) |
1da177e4c
|
68 |
{ |
5a7b46b36
|
69 70 71 |
long ret = sys_setresuid(low2highuid(ruid), low2highuid(euid), low2highuid(suid)); /* avoid REGPARM breakage on x86: */ |
54a015104
|
72 |
asmlinkage_protect(3, ret, ruid, euid, suid); |
5a7b46b36
|
73 |
return ret; |
1da177e4c
|
74 |
} |
a6b42e83f
|
75 |
SYSCALL_DEFINE3(getresuid16, old_uid_t __user *, ruid, old_uid_t __user *, euid, old_uid_t __user *, suid) |
1da177e4c
|
76 |
{ |
86a264abe
|
77 |
const struct cred *cred = current_cred(); |
1da177e4c
|
78 |
int retval; |
86a264abe
|
79 80 81 |
if (!(retval = put_user(high2lowuid(cred->uid), ruid)) && !(retval = put_user(high2lowuid(cred->euid), euid))) retval = put_user(high2lowuid(cred->suid), suid); |
1da177e4c
|
82 83 84 |
return retval; } |
a6b42e83f
|
85 |
SYSCALL_DEFINE3(setresgid16, old_gid_t, rgid, old_gid_t, egid, old_gid_t, sgid) |
1da177e4c
|
86 |
{ |
5a7b46b36
|
87 88 89 |
long ret = sys_setresgid(low2highgid(rgid), low2highgid(egid), low2highgid(sgid)); /* avoid REGPARM breakage on x86: */ |
54a015104
|
90 |
asmlinkage_protect(3, ret, rgid, egid, sgid); |
5a7b46b36
|
91 |
return ret; |
1da177e4c
|
92 |
} |
a6b42e83f
|
93 94 |
SYSCALL_DEFINE3(getresgid16, old_gid_t __user *, rgid, old_gid_t __user *, egid, old_gid_t __user *, sgid) |
1da177e4c
|
95 |
{ |
86a264abe
|
96 |
const struct cred *cred = current_cred(); |
1da177e4c
|
97 |
int retval; |
86a264abe
|
98 99 100 |
if (!(retval = put_user(high2lowgid(cred->gid), rgid)) && !(retval = put_user(high2lowgid(cred->egid), egid))) retval = put_user(high2lowgid(cred->sgid), sgid); |
1da177e4c
|
101 102 103 |
return retval; } |
a6b42e83f
|
104 |
SYSCALL_DEFINE1(setfsuid16, old_uid_t, uid) |
1da177e4c
|
105 |
{ |
5a7b46b36
|
106 107 |
long ret = sys_setfsuid(low2highuid(uid)); /* avoid REGPARM breakage on x86: */ |
54a015104
|
108 |
asmlinkage_protect(1, ret, uid); |
5a7b46b36
|
109 |
return ret; |
1da177e4c
|
110 |
} |
a6b42e83f
|
111 |
SYSCALL_DEFINE1(setfsgid16, old_gid_t, gid) |
1da177e4c
|
112 |
{ |
5a7b46b36
|
113 114 |
long ret = sys_setfsgid(low2highgid(gid)); /* avoid REGPARM breakage on x86: */ |
54a015104
|
115 |
asmlinkage_protect(1, ret, gid); |
5a7b46b36
|
116 |
return ret; |
1da177e4c
|
117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 |
} static int groups16_to_user(old_gid_t __user *grouplist, struct group_info *group_info) { int i; old_gid_t group; for (i = 0; i < group_info->ngroups; i++) { group = high2lowgid(GROUP_AT(group_info, i)); if (put_user(group, grouplist+i)) return -EFAULT; } return 0; } static int groups16_from_user(struct group_info *group_info, old_gid_t __user *grouplist) { int i; old_gid_t group; for (i = 0; i < group_info->ngroups; i++) { if (get_user(group, grouplist+i)) return -EFAULT; GROUP_AT(group_info, i) = low2highgid(group); } return 0; } |
003d7ab47
|
148 |
SYSCALL_DEFINE2(getgroups16, int, gidsetsize, old_gid_t __user *, grouplist) |
1da177e4c
|
149 |
{ |
86a264abe
|
150 151 |
const struct cred *cred = current_cred(); int i; |
1da177e4c
|
152 153 154 |
if (gidsetsize < 0) return -EINVAL; |
86a264abe
|
155 |
i = cred->group_info->ngroups; |
1da177e4c
|
156 157 158 159 160 |
if (gidsetsize) { if (i > gidsetsize) { i = -EINVAL; goto out; } |
86a264abe
|
161 |
if (groups16_to_user(grouplist, cred->group_info)) { |
1da177e4c
|
162 163 164 165 166 |
i = -EFAULT; goto out; } } out: |
1da177e4c
|
167 168 |
return i; } |
003d7ab47
|
169 |
SYSCALL_DEFINE2(setgroups16, int, gidsetsize, old_gid_t __user *, grouplist) |
1da177e4c
|
170 171 172 |
{ struct group_info *group_info; int retval; |
b0e77598f
|
173 |
if (!nsown_capable(CAP_SETGID)) |
1da177e4c
|
174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 |
return -EPERM; if ((unsigned)gidsetsize > NGROUPS_MAX) return -EINVAL; group_info = groups_alloc(gidsetsize); if (!group_info) return -ENOMEM; retval = groups16_from_user(group_info, grouplist); if (retval) { put_group_info(group_info); return retval; } retval = set_current_groups(group_info); put_group_info(group_info); return retval; } |
003d7ab47
|
192 |
SYSCALL_DEFINE0(getuid16) |
1da177e4c
|
193 |
{ |
86a264abe
|
194 |
return high2lowuid(current_uid()); |
1da177e4c
|
195 |
} |
003d7ab47
|
196 |
SYSCALL_DEFINE0(geteuid16) |
1da177e4c
|
197 |
{ |
86a264abe
|
198 |
return high2lowuid(current_euid()); |
1da177e4c
|
199 |
} |
003d7ab47
|
200 |
SYSCALL_DEFINE0(getgid16) |
1da177e4c
|
201 |
{ |
86a264abe
|
202 |
return high2lowgid(current_gid()); |
1da177e4c
|
203 |
} |
003d7ab47
|
204 |
SYSCALL_DEFINE0(getegid16) |
1da177e4c
|
205 |
{ |
86a264abe
|
206 |
return high2lowgid(current_egid()); |
1da177e4c
|
207 |
} |