diff options
author | Rich Felker <dalias@aerifal.cx> | 2012-09-22 08:02:42 -0400 |
---|---|---|
committer | Rich Felker <dalias@aerifal.cx> | 2012-09-22 08:02:42 -0400 |
commit | fce46bf980a82bad9e6c083066cae4813649ebf5 (patch) | |
tree | 076e0e1317bda0fd4b29d43183b3c2465bb7d903 | |
parent | 0b3e2257fa9f4c4773f8aec1bdbccbc46a4d9477 (diff) | |
download | musl-fce46bf980a82bad9e6c083066cae4813649ebf5.tar.gz musl-fce46bf980a82bad9e6c083066cae4813649ebf5.tar.bz2 musl-fce46bf980a82bad9e6c083066cae4813649ebf5.tar.xz musl-fce46bf980a82bad9e6c083066cae4813649ebf5.zip |
fix broken semctl on systems that don't use IPC_64 flag
not tested on mips and arm; they may still be broken. x86_64 should be
ok now.
-rw-r--r-- | arch/arm/bits/ipc.h | 2 | ||||
-rw-r--r-- | arch/i386/bits/ipc.h | 2 | ||||
-rw-r--r-- | arch/mips/bits/ipc.h | 2 | ||||
-rw-r--r-- | src/ipc/semctl.c | 8 |
4 files changed, 12 insertions, 2 deletions
diff --git a/arch/arm/bits/ipc.h b/arch/arm/bits/ipc.h index 51ad4427..b748d3b7 100644 --- a/arch/arm/bits/ipc.h +++ b/arch/arm/bits/ipc.h @@ -10,3 +10,5 @@ struct ipc_perm long __pad1; long __pad2; }; + +#define IPC_64 0x100 diff --git a/arch/i386/bits/ipc.h b/arch/i386/bits/ipc.h index 51ad4427..b748d3b7 100644 --- a/arch/i386/bits/ipc.h +++ b/arch/i386/bits/ipc.h @@ -10,3 +10,5 @@ struct ipc_perm long __pad1; long __pad2; }; + +#define IPC_64 0x100 diff --git a/arch/mips/bits/ipc.h b/arch/mips/bits/ipc.h index 51ad4427..b748d3b7 100644 --- a/arch/mips/bits/ipc.h +++ b/arch/mips/bits/ipc.h @@ -10,3 +10,5 @@ struct ipc_perm long __pad1; long __pad2; }; + +#define IPC_64 0x100 diff --git a/src/ipc/semctl.c b/src/ipc/semctl.c index a210e20b..9de5b1d7 100644 --- a/src/ipc/semctl.c +++ b/src/ipc/semctl.c @@ -3,6 +3,10 @@ #include "syscall.h" #include "ipc.h" +#ifndef IPC_64 +#define IPC_64 0 +#endif + int semctl(int id, int num, int cmd, ...) { long arg; @@ -11,8 +15,8 @@ int semctl(int id, int num, int cmd, ...) arg = va_arg(ap, long); va_end(ap); #ifdef SYS_semctl - return syscall(SYS_semctl, id, num, cmd | 0x100, arg); + return syscall(SYS_semctl, id, num, cmd | IPC_64, arg); #else - return syscall(SYS_ipc, IPCOP_semctl, id, num, cmd | 0x100, &arg); + return syscall(SYS_ipc, IPCOP_semctl, id, num, cmd | IPC_64, &arg); #endif } |