2009-10-12 16:47:59 +02:00
|
|
|
From d9c50cda4f12fc4c64b8b494a298659b8ad341ed Mon Sep 17 00:00:00 2001
|
2009-08-11 17:37:13 +02:00
|
|
|
From: Ulrich Hecht <uli@suse.de>
|
|
|
|
Date: Thu, 23 Jul 2009 17:41:57 +0200
|
|
|
|
Subject: [PATCH 29/33] linux-user: define a couple of syscalls for non-uid16 targets
|
|
|
|
|
|
|
|
Quite a number of syscalls are only defined on systems with USE_UID16
|
|
|
|
defined; this patch defines them on other systems as well.
|
|
|
|
|
|
|
|
Fixes a large number of uid/gid-related testcases on the s390x target
|
|
|
|
(and most likely on other targets as well)
|
|
|
|
|
|
|
|
Signed-off-by: Ulrich Hecht <uli@suse.de>
|
|
|
|
---
|
|
|
|
linux-user/syscall.c | 125 ++++++++++++++++++++++++++++++++++++++++++--------
|
|
|
|
1 files changed, 105 insertions(+), 20 deletions(-)
|
|
|
|
|
|
|
|
diff --git a/linux-user/syscall.c b/linux-user/syscall.c
|
|
|
|
index 49dfb40..b1ef3c9 100644
|
|
|
|
--- a/linux-user/syscall.c
|
|
|
|
+++ b/linux-user/syscall.c
|
|
|
|
@@ -309,7 +309,7 @@ static int sys_fchmodat(int dirfd, const char *pathname, mode_t mode)
|
|
|
|
return (fchmodat(dirfd, pathname, mode, 0));
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
-#if defined(TARGET_NR_fchownat) && defined(USE_UID16)
|
|
|
|
+#if defined(TARGET_NR_fchownat)
|
|
|
|
static int sys_fchownat(int dirfd, const char *pathname, uid_t owner,
|
|
|
|
gid_t group, int flags)
|
|
|
|
{
|
|
|
|
@@ -418,7 +418,7 @@ _syscall3(int,sys_faccessat,int,dirfd,const char *,pathname,int,mode)
|
|
|
|
#if defined(TARGET_NR_fchmodat) && defined(__NR_fchmodat)
|
|
|
|
_syscall3(int,sys_fchmodat,int,dirfd,const char *,pathname, mode_t,mode)
|
|
|
|
#endif
|
|
|
|
-#if defined(TARGET_NR_fchownat) && defined(__NR_fchownat) && defined(USE_UID16)
|
|
|
|
+#if defined(TARGET_NR_fchownat) && defined(__NR_fchownat)
|
|
|
|
_syscall5(int,sys_fchownat,int,dirfd,const char *,pathname,
|
|
|
|
uid_t,owner,gid_t,group,int,flags)
|
|
|
|
#endif
|
|
|
|
@@ -6382,18 +6382,35 @@ abi_long do_syscall(void *cpu_env, int num, abi_long arg1,
|
|
|
|
case TARGET_NR_setfsgid:
|
|
|
|
ret = get_errno(setfsgid(arg1));
|
|
|
|
break;
|
|
|
|
+#else /* USE_UID16 */
|
|
|
|
+#if defined(TARGET_NR_fchownat) && defined(__NR_fchownat)
|
|
|
|
+ case TARGET_NR_fchownat:
|
|
|
|
+ if (!(p = lock_user_string(arg2)))
|
|
|
|
+ goto efault;
|
|
|
|
+ ret = get_errno(sys_fchownat(arg1, p, arg3, arg4, arg5));
|
|
|
|
+ unlock_user(p, arg2, 0);
|
|
|
|
+ break;
|
|
|
|
+#endif
|
|
|
|
#endif /* USE_UID16 */
|
|
|
|
|
|
|
|
-#ifdef TARGET_NR_lchown32
|
|
|
|
+#if defined(TARGET_NR_lchown32) || !defined(USE_UID16)
|
|
|
|
+#if defined(TARGET_NR_lchown32)
|
|
|
|
case TARGET_NR_lchown32:
|
|
|
|
+#else
|
|
|
|
+ case TARGET_NR_lchown:
|
|
|
|
+#endif
|
|
|
|
if (!(p = lock_user_string(arg1)))
|
|
|
|
goto efault;
|
|
|
|
ret = get_errno(lchown(p, arg2, arg3));
|
|
|
|
unlock_user(p, arg1, 0);
|
|
|
|
break;
|
|
|
|
#endif
|
|
|
|
-#ifdef TARGET_NR_getuid32
|
|
|
|
+#if defined(TARGET_NR_getuid32) || (defined(TARGET_NR_getuid) && !defined(USE_UID16))
|
|
|
|
+#if defined(TARGET_NR_getuid32)
|
|
|
|
case TARGET_NR_getuid32:
|
|
|
|
+#else
|
|
|
|
+ case TARGET_NR_getuid:
|
|
|
|
+#endif
|
|
|
|
ret = get_errno(getuid());
|
|
|
|
break;
|
|
|
|
#endif
|
|
|
|
@@ -6421,33 +6438,57 @@ abi_long do_syscall(void *cpu_env, int num, abi_long arg1,
|
|
|
|
break;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
-#ifdef TARGET_NR_getgid32
|
|
|
|
+#if defined(TARGET_NR_getgid32) || (defined(TARGET_NR_getgid) && !defined(USE_UID16))
|
|
|
|
+#if defined(TARGET_NR_getgid32)
|
|
|
|
case TARGET_NR_getgid32:
|
|
|
|
+#else
|
|
|
|
+ case TARGET_NR_getgid:
|
|
|
|
+#endif
|
|
|
|
ret = get_errno(getgid());
|
|
|
|
break;
|
|
|
|
#endif
|
|
|
|
-#ifdef TARGET_NR_geteuid32
|
|
|
|
+#if defined(TARGET_NR_geteuid32) || (defined(TARGET_NR_geteuid) && !defined(USE_UID16))
|
|
|
|
+#if defined(TARGET_NR_geteuid32)
|
|
|
|
case TARGET_NR_geteuid32:
|
|
|
|
+#else
|
|
|
|
+ case TARGET_NR_geteuid:
|
|
|
|
+#endif
|
|
|
|
ret = get_errno(geteuid());
|
|
|
|
break;
|
|
|
|
#endif
|
|
|
|
-#ifdef TARGET_NR_getegid32
|
|
|
|
+#if defined(TARGET_NR_getegid32) || (defined(TARGET_NR_getegid) && !defined(USE_UID16))
|
|
|
|
+#if defined(TARGET_NR_getegid32)
|
|
|
|
case TARGET_NR_getegid32:
|
|
|
|
+#else
|
|
|
|
+ case TARGET_NR_getegid:
|
|
|
|
+#endif
|
|
|
|
ret = get_errno(getegid());
|
|
|
|
break;
|
|
|
|
#endif
|
|
|
|
-#ifdef TARGET_NR_setreuid32
|
|
|
|
+#if defined(TARGET_NR_setreuid32) || !defined(USE_UID16)
|
|
|
|
+#if defined(TARGET_NR_setreuid32)
|
|
|
|
case TARGET_NR_setreuid32:
|
|
|
|
+#else
|
|
|
|
+ case TARGET_NR_setreuid:
|
|
|
|
+#endif
|
|
|
|
ret = get_errno(setreuid(arg1, arg2));
|
|
|
|
break;
|
|
|
|
#endif
|
|
|
|
-#ifdef TARGET_NR_setregid32
|
|
|
|
+#if defined(TARGET_NR_setregid32) || !defined(USE_UID16)
|
|
|
|
+#if defined(TARGET_NR_setregid32)
|
|
|
|
case TARGET_NR_setregid32:
|
|
|
|
+#else
|
|
|
|
+ case TARGET_NR_setregid:
|
|
|
|
+#endif
|
|
|
|
ret = get_errno(setregid(arg1, arg2));
|
|
|
|
break;
|
|
|
|
#endif
|
|
|
|
-#ifdef TARGET_NR_getgroups32
|
|
|
|
+#if defined(TARGET_NR_getgroups32) || !defined(USE_UID16)
|
|
|
|
+#if defined(TARGET_NR_getgroups32)
|
|
|
|
case TARGET_NR_getgroups32:
|
|
|
|
+#else
|
|
|
|
+ case TARGET_NR_getgroups:
|
|
|
|
+#endif
|
|
|
|
{
|
|
|
|
int gidsetsize = arg1;
|
|
|
|
uint32_t *target_grouplist;
|
|
|
|
@@ -6471,8 +6512,12 @@ abi_long do_syscall(void *cpu_env, int num, abi_long arg1,
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
#endif
|
|
|
|
-#ifdef TARGET_NR_setgroups32
|
|
|
|
+#if defined(TARGET_NR_setgroups32) || !defined(USE_UID16)
|
|
|
|
+#if defined(TARGET_NR_setgroups32)
|
|
|
|
case TARGET_NR_setgroups32:
|
|
|
|
+#else
|
|
|
|
+ case TARGET_NR_setgroups:
|
|
|
|
+#endif
|
|
|
|
{
|
|
|
|
int gidsetsize = arg1;
|
|
|
|
uint32_t *target_grouplist;
|
|
|
|
@@ -6492,18 +6537,30 @@ abi_long do_syscall(void *cpu_env, int num, abi_long arg1,
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
#endif
|
|
|
|
-#ifdef TARGET_NR_fchown32
|
|
|
|
+#if defined(TARGET_NR_fchown32) || !defined(USE_UID16)
|
|
|
|
+#if defined(TARGET_NR_fchown32)
|
|
|
|
case TARGET_NR_fchown32:
|
|
|
|
+#else
|
|
|
|
+ case TARGET_NR_fchown:
|
|
|
|
+#endif
|
|
|
|
ret = get_errno(fchown(arg1, arg2, arg3));
|
|
|
|
break;
|
|
|
|
#endif
|
|
|
|
-#ifdef TARGET_NR_setresuid32
|
|
|
|
+#if defined(TARGET_NR_setresuid32) || !defined(USE_UID16)
|
|
|
|
+#if defined(TARGET_NR_setresuid32)
|
|
|
|
case TARGET_NR_setresuid32:
|
|
|
|
+#else
|
|
|
|
+ case TARGET_NR_setresuid:
|
|
|
|
+#endif
|
|
|
|
ret = get_errno(setresuid(arg1, arg2, arg3));
|
|
|
|
break;
|
|
|
|
#endif
|
|
|
|
-#ifdef TARGET_NR_getresuid32
|
|
|
|
+#if defined(TARGET_NR_getresuid32) || !defined(USE_UID16)
|
|
|
|
+#if defined(TARGET_NR_getresuid32)
|
|
|
|
case TARGET_NR_getresuid32:
|
|
|
|
+#else
|
|
|
|
+ case TARGET_NR_getresuid:
|
|
|
|
+#endif
|
|
|
|
{
|
|
|
|
uid_t ruid, euid, suid;
|
|
|
|
ret = get_errno(getresuid(&ruid, &euid, &suid));
|
|
|
|
@@ -6516,13 +6573,21 @@ abi_long do_syscall(void *cpu_env, int num, abi_long arg1,
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
#endif
|
|
|
|
-#ifdef TARGET_NR_setresgid32
|
|
|
|
+#if defined(TARGET_NR_setresgid32) || !defined(USE_UID16)
|
|
|
|
+#if defined(TARGET_NR_setresgid32)
|
|
|
|
case TARGET_NR_setresgid32:
|
|
|
|
+#else
|
|
|
|
+ case TARGET_NR_setresgid:
|
|
|
|
+#endif
|
|
|
|
ret = get_errno(setresgid(arg1, arg2, arg3));
|
|
|
|
break;
|
|
|
|
#endif
|
|
|
|
+#if defined(TARGET_NR_getresgid32) || !defined(USE_UID16)
|
|
|
|
#ifdef TARGET_NR_getresgid32
|
|
|
|
case TARGET_NR_getresgid32:
|
|
|
|
+#else
|
|
|
|
+ case TARGET_NR_getresgid:
|
|
|
|
+#endif
|
|
|
|
{
|
|
|
|
gid_t rgid, egid, sgid;
|
|
|
|
ret = get_errno(getresgid(&rgid, &egid, &sgid));
|
|
|
|
@@ -6535,31 +6600,51 @@ abi_long do_syscall(void *cpu_env, int num, abi_long arg1,
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
#endif
|
|
|
|
-#ifdef TARGET_NR_chown32
|
|
|
|
+#if defined(TARGET_NR_chown32) || !defined(USE_UID16)
|
|
|
|
+#if defined(TARGET_NR_chown32)
|
|
|
|
case TARGET_NR_chown32:
|
|
|
|
+#else
|
|
|
|
+ case TARGET_NR_chown:
|
|
|
|
+#endif
|
|
|
|
if (!(p = lock_user_string(arg1)))
|
|
|
|
goto efault;
|
|
|
|
ret = get_errno(chown(p, arg2, arg3));
|
|
|
|
unlock_user(p, arg1, 0);
|
|
|
|
break;
|
|
|
|
#endif
|
|
|
|
-#ifdef TARGET_NR_setuid32
|
|
|
|
+#if defined(TARGET_NR_setuid32) || !defined(USE_UID16)
|
|
|
|
+#if defined(TARGET_NR_setuid32)
|
|
|
|
case TARGET_NR_setuid32:
|
|
|
|
+#else
|
|
|
|
+ case TARGET_NR_setuid:
|
|
|
|
+#endif
|
|
|
|
ret = get_errno(setuid(arg1));
|
|
|
|
break;
|
|
|
|
#endif
|
|
|
|
-#ifdef TARGET_NR_setgid32
|
|
|
|
+#if defined(TARGET_NR_setgid32) || !defined(USE_UID16)
|
|
|
|
+#if defined(TARGET_NR_setgid32)
|
|
|
|
case TARGET_NR_setgid32:
|
|
|
|
+#else
|
|
|
|
+ case TARGET_NR_setgid:
|
|
|
|
+#endif
|
|
|
|
ret = get_errno(setgid(arg1));
|
|
|
|
break;
|
|
|
|
#endif
|
|
|
|
-#ifdef TARGET_NR_setfsuid32
|
|
|
|
+#if defined(TARGET_NR_setfsuid32) || !defined(USE_UID16)
|
|
|
|
+#if defined(TARGET_NR_setfsuid32)
|
|
|
|
case TARGET_NR_setfsuid32:
|
|
|
|
+#else
|
|
|
|
+ case TARGET_NR_setfsuid:
|
|
|
|
+#endif
|
|
|
|
ret = get_errno(setfsuid(arg1));
|
|
|
|
break;
|
|
|
|
#endif
|
|
|
|
-#ifdef TARGET_NR_setfsgid32
|
|
|
|
+#if defined(TARGET_NR_setfsgid32) || !defined(USE_UID16)
|
|
|
|
+#if defined(TARGET_NR_setfsgid32)
|
|
|
|
case TARGET_NR_setfsgid32:
|
|
|
|
+#else
|
|
|
|
+ case TARGET_NR_setfsgid:
|
|
|
|
+#endif
|
|
|
|
ret = get_errno(setfsgid(arg1));
|
|
|
|
break;
|
|
|
|
#endif
|
|
|
|
--
|
|
|
|
1.6.2.1
|
|
|
|
|