Commit 2fe749f5 authored by Helge Deller's avatar Helge Deller

parisc: Use compat layer for msgctl, shmat, shmctl and semtimedop syscalls

Switch over the msgctl, shmat, shmctl and semtimedop syscalls to use the compat
layer. The problem was found with the debian procenv package, which called
	shmctl(0, SHM_INFO, &info);
in which the shmctl syscall then overwrote parts of the surrounding areas on
the stack on which the info variable was stored and thus lead to a segfault
later on.

Additionally fix the definition of struct shminfo64 to use unsigned longs like
the other architectures. This has no impact on userspace since we only have a
32bit userspace up to now.
Signed-off-by: default avatarHelge Deller <deller@gmx.de>
Cc: John David Anglin <dave.anglin@bell.net>
Cc: <stable@vger.kernel.org> # v3.10+
parent 8dd95c68
...@@ -36,23 +36,16 @@ struct shmid64_ds { ...@@ -36,23 +36,16 @@ struct shmid64_ds {
unsigned int __unused2; unsigned int __unused2;
}; };
#ifdef CONFIG_64BIT
/* The 'unsigned int' (formerly 'unsigned long') data types below will
* ensure that a 32-bit app calling shmctl(*,IPC_INFO,*) will work on
* a wide kernel, but if some of these values are meant to contain pointers
* they may need to be 'long long' instead. -PB XXX FIXME
*/
#endif
struct shminfo64 { struct shminfo64 {
unsigned int shmmax; unsigned long shmmax;
unsigned int shmmin; unsigned long shmmin;
unsigned int shmmni; unsigned long shmmni;
unsigned int shmseg; unsigned long shmseg;
unsigned int shmall; unsigned long shmall;
unsigned int __unused1; unsigned long __unused1;
unsigned int __unused2; unsigned long __unused2;
unsigned int __unused3; unsigned long __unused3;
unsigned int __unused4; unsigned long __unused4;
}; };
#endif /* _PARISC_SHMBUF_H */ #endif /* _PARISC_SHMBUF_H */
...@@ -286,11 +286,11 @@ ...@@ -286,11 +286,11 @@
ENTRY_COMP(msgsnd) ENTRY_COMP(msgsnd)
ENTRY_COMP(msgrcv) ENTRY_COMP(msgrcv)
ENTRY_SAME(msgget) /* 190 */ ENTRY_SAME(msgget) /* 190 */
ENTRY_SAME(msgctl) ENTRY_COMP(msgctl)
ENTRY_SAME(shmat) ENTRY_COMP(shmat)
ENTRY_SAME(shmdt) ENTRY_SAME(shmdt)
ENTRY_SAME(shmget) ENTRY_SAME(shmget)
ENTRY_SAME(shmctl) /* 195 */ ENTRY_COMP(shmctl) /* 195 */
ENTRY_SAME(ni_syscall) /* streams1 */ ENTRY_SAME(ni_syscall) /* streams1 */
ENTRY_SAME(ni_syscall) /* streams2 */ ENTRY_SAME(ni_syscall) /* streams2 */
ENTRY_SAME(lstat64) ENTRY_SAME(lstat64)
...@@ -323,7 +323,7 @@ ...@@ -323,7 +323,7 @@
ENTRY_SAME(epoll_ctl) /* 225 */ ENTRY_SAME(epoll_ctl) /* 225 */
ENTRY_SAME(epoll_wait) ENTRY_SAME(epoll_wait)
ENTRY_SAME(remap_file_pages) ENTRY_SAME(remap_file_pages)
ENTRY_SAME(semtimedop) ENTRY_COMP(semtimedop)
ENTRY_COMP(mq_open) ENTRY_COMP(mq_open)
ENTRY_SAME(mq_unlink) /* 230 */ ENTRY_SAME(mq_unlink) /* 230 */
ENTRY_COMP(mq_timedsend) ENTRY_COMP(mq_timedsend)
......
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