Commit 34ca70ef authored by Arnd Bergmann's avatar Arnd Bergmann Committed by David S. Miller

sparc32: fix struct ipc64_perm type definition

As discussed in the strace issue tracker, it appears that the sparc32
sysvipc support has been broken for the past 11 years. It was however
working in compat mode, which is how it must have escaped most of the
regular testing.

The problem is that a cleanup patch inadvertently changed the uid/gid
fields in struct ipc64_perm from 32-bit types to 16-bit types in uapi
headers.

Both glibc and uclibc-ng still use the original types, so they should
work fine with compat mode, but not natively.  Change the definitions
to use __kernel_uid32_t and __kernel_gid32_t again.

Fixes: 83c86984 ("sparc: unify ipcbuf.h")
Link: https://github.com/strace/strace/issues/116
Cc: <stable@vger.kernel.org> # v2.6.29
Cc: Sam Ravnborg <sam@ravnborg.org>
Cc: "Dmitry V . Levin" <ldv@altlinux.org>
Cc: Rich Felker <dalias@libc.org>
Cc: libc-alpha@sourceware.org
Signed-off-by: default avatarArnd Bergmann <arnd@arndb.de>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent e2b9fc2d
...@@ -15,19 +15,19 @@ ...@@ -15,19 +15,19 @@
struct ipc64_perm struct ipc64_perm
{ {
__kernel_key_t key; __kernel_key_t key;
__kernel_uid_t uid; __kernel_uid32_t uid;
__kernel_gid_t gid; __kernel_gid32_t gid;
__kernel_uid_t cuid; __kernel_uid32_t cuid;
__kernel_gid_t cgid; __kernel_gid32_t cgid;
#ifndef __arch64__ #ifndef __arch64__
unsigned short __pad0; unsigned short __pad0;
#endif #endif
__kernel_mode_t mode; __kernel_mode_t mode;
unsigned short __pad1; unsigned short __pad1;
unsigned short seq; unsigned short seq;
unsigned long long __unused1; unsigned long long __unused1;
unsigned long long __unused2; unsigned long long __unused2;
}; };
#endif /* __SPARC_IPCBUF_H */ #endif /* __SPARC_IPCBUF_H */
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment