From: Adhemerval Zanella <adhemerval.zanella@linaro.org>
To: libc-alpha@sourceware.org
Subject: Re: [PATCH v2 1/2] ipc: Refactor sysvipc internal definitions
Date: Wed, 28 Aug 2019 11:06:20 -0300 [thread overview]
Message-ID: <6160c098-4204-6246-96b1-a44bbb5d4da7@linaro.org> (raw)
In-Reply-To: <f903e57e-9cd7-f633-d0f4-15977006d36b@linaro.org>
Ping (x2).
On 09/08/2019 09:18, Adhemerval Zanella wrote:
> Ping.
>
> On 20/05/2019 14:53, Adhemerval Zanella wrote:
>> Changes from previous version:
>>
>> - Added __ASSUME_SYSVIPC_DEFAULT_IPC_64 instead of redefine __IPC_64
>> on kernel-features.h. The new assume macro is used to setup the
>> __IPC_64 value on ipc-priv.h.
>>
>> - Annexed the 'ipc: Refactor sysvipc compat type' to make it possible
>> share the generic ipc_priv.h definions for all architectures.
>>
>> --
>>
>> This patch refactor the internal sysvipc in two main points:
>>
>> 1. Add a new __ASSUME_SYSVIPC_DEFAULT_IPC_64 to infer the __IPC_64
>> value in wire-up or ipc syscall. The defaut value assumed for
>> __IPC_64 is also changed from 0x100 to 0x0, aligning with Linux
>> generic UAPI. The idea is to simplify the Linux 5.1 wire-up for
>> sysvipc syscalls for some 32-bit ABIs (which expectes __IPC_64
>> being 0x0) and simplify new ports (which would not require add
>> a ipc_priv.h to override the __IPC_64 value).
>>
>> 2. It removes some duplicated definition from sysvipc compat code
>> at ipc_priv.h. The idea is also to make it simpler to enable
>> the new wireup sysvipc on Linux v5.1.
>>
>> There is no semantic change expected on any port. Checked with a build
>> against all affected ABIs.
>>
>> * sysdeps/unix/sysv/linux/ipc_priv.h (__OLD_IPC_ID_TYPE,
>> __OLD_IPC_MODE_TYPE, __OLD_IPC_SEQ_TYPE): Define.
>> (__old_ipc_perm): Use the new defines.
>> * sysdeps/unix/sysv/linux/alpha/ipc_priv.h (__OLD_IPC_ID_TYPE,
>> __OLD_IPC_MODE_TYPE, __OLD_IPC_SEQ_TYPE): Define.
>> (__old_ipc_perm): Use the new defines.
>> * sysdeps/unix/sysv/linux/mips/mips64/ipc_priv.h (__OLD_IPC_ID_TYPE,
>> __OLD_IPC_MODE_TYPE, __OLD_IPC_SEQ_TYPE): Define.
>> (__old_ipc_perm): Use the new defines.
>> * sysdeps/unix/sysv/linux/powerpc/ipc_priv.h (__OLD_IPC_ID_TYPE,
>> __OLD_IPC_MODE_TYPE, __OLD_IPC_SEQ_TYPE): Define.
>> (__old_ipc_perm): Use the new defines.
>> * sysdeps/unix/sysv/linux/kernel-features.h
>> (__ASSUME_SYSVIPC_DEFAULT_IPC_64): Define.
>> * sysdeps/unix/sysv/linux/alpha/kernel-features.h
>> (__ASSUME_SYSVIPC_DEFAULT_IPC_64): Undefine.
>> * sysdeps/unix/sysv/linux/arm/kernel-features.h
>> (__ASSUME_SYSVIPC_DEFAULT_IPC_64): Likewise.
>> * sysdeps/unix/sysv/linux/i386/kernel-features.h
>> (__ASSUME_SYSVIPC_DEFAULT_IPC_64): Likewise.
>> * sysdeps/unix/sysv/linux/m68k/kernel-features.h
>> (__ASSUME_SYSVIPC_DEFAULT_IPC_64): Likewise.
>> * sysdeps/unix/sysv/linux/mips/kernel-features.h
>> (__ASSUME_SYSVIPC_DEFAULT_IPC_64): Likewise.
>> * sysdeps/unix/sysv/linux/microblaze/kernel-features.h
>> (__ASSUME_SYSVIPC_DEFAULT_IPC_64): Likewise.
>> * sysdeps/unix/sysv/linux/powerpc/kernel-features.h
>> (__ASSUME_SYSVIPC_DEFAULT_IPC_64): Likewise.
>> * sysdeps/unix/sysv/linux/s390/kernel-features.h
>> (__ASSUME_SYSVIPC_DEFAULT_IPC_64): Likewise.
>> * sysdeps/unix/sysv/linux/sh/kernel-features.h
>> (__ASSUME_SYSVIPC_DEFAULT_IPC_64): Likewise.
>> * sysdeps/unix/sysv/linux/sparc/kernel-features.h
>> [!__arch64__] (__ASSUME_SYSVIPC_DEFAULT_IPC_64): Likewise.
>> * sysdeps/unix/sysv/linux/nios2/kernel-features.h: New file.
>> * sysdeps/unix/sysv/linux/hppa/ipc_priv.h: Remove file.
>> * sysdeps/unix/sysv/linux/ia64/ipc_priv.h: Likewise.
>> * sysdeps/unix/sysv/linux/nios2/ipc_priv.h: Likewise.
>> * sysdeps/unix/sysv/linux/csky/ipc_priv.h: Likewise.
>> * sysdeps/unix/sysv/linux/riscv/ipc_priv.h: Likewise.
>> * sysdeps/unix/sysv/linux/sparc/sparc64/ipc_priv.h: Likewise.
>> * sysdeps/unix/sysv/linux/x86_64/ipc_priv.h: Likewise.
>> ---
>> sysdeps/unix/sysv/linux/alpha/ipc_priv.h | 18 +++--------
>> .../unix/sysv/linux/alpha/kernel-features.h | 3 ++
>> sysdeps/unix/sysv/linux/arm/kernel-features.h | 2 ++
>> sysdeps/unix/sysv/linux/hppa/ipc_priv.h | 21 ------------
>> .../unix/sysv/linux/i386/kernel-features.h | 1 +
>> sysdeps/unix/sysv/linux/ia64/ipc_priv.h | 21 ------------
>> sysdeps/unix/sysv/linux/ipc_priv.h | 31 +++++++++++++-----
>> sysdeps/unix/sysv/linux/kernel-features.h | 3 ++
>> .../unix/sysv/linux/m68k/kernel-features.h | 1 +
>> .../sysv/linux/microblaze/kernel-features.h | 2 ++
>> .../unix/sysv/linux/mips/kernel-features.h | 2 ++
>> .../unix/sysv/linux/mips/mips64/ipc_priv.h | 18 +++--------
>> sysdeps/unix/sysv/linux/nios2/ipc_priv.h | 21 ------------
>> .../ipc_priv.h => nios2/kernel-features.h} | 11 ++++---
>> sysdeps/unix/sysv/linux/powerpc/ipc_priv.h | 25 +++------------
>> .../unix/sysv/linux/powerpc/kernel-features.h | 1 +
>> sysdeps/unix/sysv/linux/riscv/ipc_priv.h | 21 ------------
>> .../unix/sysv/linux/s390/kernel-features.h | 1 +
>> sysdeps/unix/sysv/linux/sh/kernel-features.h | 1 +
>> .../unix/sysv/linux/sparc/kernel-features.h | 3 ++
>> .../unix/sysv/linux/sparc/sparc64/ipc_priv.h | 20 ++++--------
>> sysdeps/unix/sysv/linux/x86_64/ipc_priv.h | 32 -------------------
>> 22 files changed, 67 insertions(+), 192 deletions(-)
>> delete mode 100644 sysdeps/unix/sysv/linux/hppa/ipc_priv.h
>> delete mode 100644 sysdeps/unix/sysv/linux/ia64/ipc_priv.h
>> delete mode 100644 sysdeps/unix/sysv/linux/nios2/ipc_priv.h
>> rename sysdeps/unix/sysv/linux/{csky/ipc_priv.h => nios2/kernel-features.h} (69%)
>> delete mode 100644 sysdeps/unix/sysv/linux/riscv/ipc_priv.h
>> delete mode 100644 sysdeps/unix/sysv/linux/x86_64/ipc_priv.h
>>
>> diff --git a/sysdeps/unix/sysv/linux/alpha/ipc_priv.h b/sysdeps/unix/sysv/linux/alpha/ipc_priv.h
>> index fc5e713f42..fa79bddcf3 100644
>> --- a/sysdeps/unix/sysv/linux/alpha/ipc_priv.h
>> +++ b/sysdeps/unix/sysv/linux/alpha/ipc_priv.h
>> @@ -16,17 +16,7 @@
>> License along with the GNU C Library; if not, see
>> <http://www.gnu.org/licenses/>. */
>>
>> -#include <sys/ipc.h> /* For __key_t */
>> -
>> -#define __IPC_64 0x100
>> -
>> -struct __old_ipc_perm
>> -{
>> - __key_t __key; /* Key. */
>> - unsigned int uid; /* Owner's user ID. */
>> - unsigned int gid; /* Owner's group ID. */
>> - unsigned int cuid; /* Creator's user ID. */
>> - unsigned int cgid; /* Creator's group ID. */
>> - unsigned int mode; /* Read/write permission. */
>> - unsigned short int __seq; /* Sequence number. */
>> -};
>> +#define __OLD_IPC_ID_TYPE unsigned int
>> +#define __OLD_IPC_MODE_TYPE unsigned int
>> +#define __OLD_IPC_SEQ_TYPE unsigned short int
>> +#include <sysdeps/unix/sysv/linux/ipc_priv.h>
>> diff --git a/sysdeps/unix/sysv/linux/alpha/kernel-features.h b/sysdeps/unix/sysv/linux/alpha/kernel-features.h
>> index 4a5d029c1d..f3aab5bcee 100644
>> --- a/sysdeps/unix/sysv/linux/alpha/kernel-features.h
>> +++ b/sysdeps/unix/sysv/linux/alpha/kernel-features.h
>> @@ -53,4 +53,7 @@
>> # undef __ASSUME_STATX
>> #endif
>>
>> +/* Alpha support old sysvipc even being a 64-bit architecture. */
>> +#undef __ASSUME_SYSVIPC_DEFAULT_IPC_64
>> +
>> #endif /* _KERNEL_FEATURES_H */
>> diff --git a/sysdeps/unix/sysv/linux/arm/kernel-features.h b/sysdeps/unix/sysv/linux/arm/kernel-features.h
>> index 2d2d355844..75ac97a82f 100644
>> --- a/sysdeps/unix/sysv/linux/arm/kernel-features.h
>> +++ b/sysdeps/unix/sysv/linux/arm/kernel-features.h
>> @@ -50,3 +50,5 @@
>>
>> #undef __ASSUME_CLONE_DEFAULT
>> #define __ASSUME_CLONE_BACKWARDS 1
>> +
>> +#undef __ASSUME_SYSVIPC_DEFAULT_IPC_64
>> diff --git a/sysdeps/unix/sysv/linux/hppa/ipc_priv.h b/sysdeps/unix/sysv/linux/hppa/ipc_priv.h
>> deleted file mode 100644
>> index 5e170a9a2b..0000000000
>> --- a/sysdeps/unix/sysv/linux/hppa/ipc_priv.h
>> +++ /dev/null
>> @@ -1,21 +0,0 @@
>> -/* Old SysV permission definition for Linux. Hppa version.
>> - Copyright (C) 2017-2019 Free Software Foundation, Inc.
>> - This file is part of the GNU C Library.
>> -
>> - The GNU C Library is free software; you can redistribute it and/or
>> - modify it under the terms of the GNU Lesser General Public
>> - License as published by the Free Software Foundation; either
>> - version 2.1 of the License, or (at your option) any later version.
>> -
>> - The GNU C Library is distributed in the hope that it will be useful,
>> - but WITHOUT ANY WARRANTY; without even the implied warranty of
>> - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
>> - Lesser General Public License for more details.
>> -
>> - You should have received a copy of the GNU Lesser General Public
>> - License along with the GNU C Library; if not, see
>> - <http://www.gnu.org/licenses/>. */
>> -
>> -#include <sys/ipc.h> /* For __key_t */
>> -
>> -#define __IPC_64 0x0
>> diff --git a/sysdeps/unix/sysv/linux/i386/kernel-features.h b/sysdeps/unix/sysv/linux/i386/kernel-features.h
>> index 3ac725b5a2..411eb2fca4 100644
>> --- a/sysdeps/unix/sysv/linux/i386/kernel-features.h
>> +++ b/sysdeps/unix/sysv/linux/i386/kernel-features.h
>> @@ -45,6 +45,7 @@
>>
>> /* i686 only supports ipc syscall. */
>> #undef __ASSUME_DIRECT_SYSVIPC_SYSCALLS
>> +#undef __ASSUME_SYSVIPC_DEFAULT_IPC_64
>>
>> #undef __ASSUME_CLONE_DEFAULT
>> #define __ASSUME_CLONE_BACKWARDS 1
>> diff --git a/sysdeps/unix/sysv/linux/ia64/ipc_priv.h b/sysdeps/unix/sysv/linux/ia64/ipc_priv.h
>> deleted file mode 100644
>> index 6b2438cd03..0000000000
>> --- a/sysdeps/unix/sysv/linux/ia64/ipc_priv.h
>> +++ /dev/null
>> @@ -1,21 +0,0 @@
>> -/* Old SysV permission definition for Linux. IA64 version.
>> - Copyright (C) 2017-2019 Free Software Foundation, Inc.
>> - This file is part of the GNU C Library.
>> -
>> - The GNU C Library is free software; you can redistribute it and/or
>> - modify it under the terms of the GNU Lesser General Public
>> - License as published by the Free Software Foundation; either
>> - version 2.1 of the License, or (at your option) any later version.
>> -
>> - The GNU C Library is distributed in the hope that it will be useful,
>> - but WITHOUT ANY WARRANTY; without even the implied warranty of
>> - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
>> - Lesser General Public License for more details.
>> -
>> - You should have received a copy of the GNU Lesser General Public
>> - License along with the GNU C Library; if not, see
>> - <http://www.gnu.org/licenses/>. */
>> -
>> -#include <sys/ipc.h> /* For __key_t */
>> -
>> -#define __IPC_64 0x0
>> diff --git a/sysdeps/unix/sysv/linux/ipc_priv.h b/sysdeps/unix/sysv/linux/ipc_priv.h
>> index 1d1bd19541..d387b44c8f 100644
>> --- a/sysdeps/unix/sysv/linux/ipc_priv.h
>> +++ b/sysdeps/unix/sysv/linux/ipc_priv.h
>> @@ -17,18 +17,33 @@
>> <http://www.gnu.org/licenses/>. */
>>
>> #include <sys/ipc.h> /* For __key_t */
>> -
>> -#define __IPC_64 0x100
>> +#include <kernel-features.h>
>> +
>> +#ifdef __ASSUME_SYSVIPC_DEFAULT_IPC_64
>> +# define __IPC_64 0x0
>> +#else
>> +# define __IPC_64 0x100
>> +#endif
>> +
>> +#ifndef __OLD_IPC_ID_TYPE
>> +# define __OLD_IPC_ID_TYPE unsigned short int
>> +#endif
>> +#ifndef __OLD_IPC_MODE_TYPE
>> +# define __OLD_IPC_MODE_TYPE unsigned short int
>> +#endif
>> +#ifndef __OLD_IPC_SEQ_TYPE
>> +# define __OLD_IPC_SEQ_TYPE unsigned short int
>> +#endif
>>
>> struct __old_ipc_perm
>> {
>> __key_t __key; /* Key. */
>> - unsigned short int uid; /* Owner's user ID. */
>> - unsigned short int gid; /* Owner's group ID. */
>> - unsigned short int cuid; /* Creator's user ID. */
>> - unsigned short int cgid; /* Creator's group ID. */
>> - unsigned short int mode; /* Read/write permission. */
>> - unsigned short int __seq; /* Sequence number. */
>> + __OLD_IPC_ID_TYPE uid; /* Owner's user ID. */
>> + __OLD_IPC_ID_TYPE gid; /* Owner's group ID. */
>> + __OLD_IPC_ID_TYPE cuid; /* Creator's user ID. */
>> + __OLD_IPC_ID_TYPE cgid; /* Creator's group ID. */
>> + __OLD_IPC_MODE_TYPE mode; /* Read/write permission. */
>> + __OLD_IPC_SEQ_TYPE __seq; /* Sequence number. */
>> };
>>
>> #define SEMCTL_ARG_ADDRESS(__arg) &__arg.array
>> diff --git a/sysdeps/unix/sysv/linux/kernel-features.h b/sysdeps/unix/sysv/linux/kernel-features.h
>> index bc5c959f58..fa99a11c2d 100644
>> --- a/sysdeps/unix/sysv/linux/kernel-features.h
>> +++ b/sysdeps/unix/sysv/linux/kernel-features.h
>> @@ -80,6 +80,9 @@
>> /* Support for SysV IPC through wired syscalls. All supported architectures
>> either support ipc syscall and/or all the ipc correspondent syscalls. */
>> #define __ASSUME_DIRECT_SYSVIPC_SYSCALLS 1
>> +/* The generic default __IPC_64 value is 0x0, however some architectures
>> + require a different value of 0x100. */
>> +#define __ASSUME_SYSVIPC_DEFAULT_IPC_64 1
>>
>> /* Support for p{read,write}v2 was added in 4.6. However Linux default
>> implementation does not assume the __ASSUME_* and instead use a fallback
>> diff --git a/sysdeps/unix/sysv/linux/m68k/kernel-features.h b/sysdeps/unix/sysv/linux/m68k/kernel-features.h
>> index 1976724362..46418977c8 100644
>> --- a/sysdeps/unix/sysv/linux/m68k/kernel-features.h
>> +++ b/sysdeps/unix/sysv/linux/m68k/kernel-features.h
>> @@ -52,3 +52,4 @@
>>
>> /* m68k only supports ipc syscall. */
>> #undef __ASSUME_DIRECT_SYSVIPC_SYSCALLS
>> +#undef __ASSUME_SYSVIPC_DEFAULT_IPC_64
>> diff --git a/sysdeps/unix/sysv/linux/microblaze/kernel-features.h b/sysdeps/unix/sysv/linux/microblaze/kernel-features.h
>> index 8df19400af..bed0c4a4e5 100644
>> --- a/sysdeps/unix/sysv/linux/microblaze/kernel-features.h
>> +++ b/sysdeps/unix/sysv/linux/microblaze/kernel-features.h
>> @@ -72,3 +72,5 @@
>>
>> #undef __ASSUME_CLONE_DEFAULT
>> #define __ASSUME_CLONE_BACKWARDS3
>> +
>> +#undef __ASSUME_SYSVIPC_DEFAULT_IPC_64
>> diff --git a/sysdeps/unix/sysv/linux/mips/kernel-features.h b/sysdeps/unix/sysv/linux/mips/kernel-features.h
>> index c341c3fa10..b9fa89c81d 100644
>> --- a/sysdeps/unix/sysv/linux/mips/kernel-features.h
>> +++ b/sysdeps/unix/sysv/linux/mips/kernel-features.h
>> @@ -50,3 +50,5 @@
>>
>> #undef __ASSUME_CLONE_DEFAULT
>> #define __ASSUME_CLONE_BACKWARDS 1
>> +
>> +#undef __ASSUME_SYSVIPC_DEFAULT_IPC_64
>> diff --git a/sysdeps/unix/sysv/linux/mips/mips64/ipc_priv.h b/sysdeps/unix/sysv/linux/mips/mips64/ipc_priv.h
>> index bb31656069..682ec35662 100644
>> --- a/sysdeps/unix/sysv/linux/mips/mips64/ipc_priv.h
>> +++ b/sysdeps/unix/sysv/linux/mips/mips64/ipc_priv.h
>> @@ -16,17 +16,7 @@
>> License along with the GNU C Library; if not, see
>> <http://www.gnu.org/licenses/>. */
>>
>> -#include <sys/ipc.h>
>> -
>> -#define __IPC_64 0x100
>> -
>> -struct __old_ipc_perm
>> -{
>> - __key_t __key; /* Key. */
>> - int uid; /* Owner's user ID. */
>> - int gid; /* Owner's group ID. */
>> - int cuid; /* Creator's user ID. */
>> - int cgid; /* Creator's group ID. */
>> - int mode; /* Read/write permission. */
>> - unsigned short int __seq; /* Sequence number. */
>> -};
>> +#define __OLD_IPC_ID_TYPE int
>> +#define __OLD_IPC_MODE_TYPE int
>> +#define __OLD_IPC_SEQ_TYPE unsigned short int
>> +#include <sysdeps/unix/sysv/linux/ipc_priv.h>
>> diff --git a/sysdeps/unix/sysv/linux/nios2/ipc_priv.h b/sysdeps/unix/sysv/linux/nios2/ipc_priv.h
>> deleted file mode 100644
>> index d6e6be797a..0000000000
>> --- a/sysdeps/unix/sysv/linux/nios2/ipc_priv.h
>> +++ /dev/null
>> @@ -1,21 +0,0 @@
>> -/* Old SysV permission definition for Linux. Nios II version.
>> - Copyright (C) 2017-2019 Free Software Foundation, Inc.
>> - This file is part of the GNU C Library.
>> -
>> - The GNU C Library is free software; you can redistribute it and/or
>> - modify it under the terms of the GNU Lesser General Public
>> - License as published by the Free Software Foundation; either
>> - version 2.1 of the License, or (at your option) any later version.
>> -
>> - The GNU C Library is distributed in the hope that it will be useful,
>> - but WITHOUT ANY WARRANTY; without even the implied warranty of
>> - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
>> - Lesser General Public License for more details.
>> -
>> - You should have received a copy of the GNU Lesser General Public
>> - License along with the GNU C Library; if not, see
>> - <http://www.gnu.org/licenses/>. */
>> -
>> -#include <sys/ipc.h> /* For __key_t */
>> -
>> -#define __IPC_64 0x0
>> diff --git a/sysdeps/unix/sysv/linux/csky/ipc_priv.h b/sysdeps/unix/sysv/linux/nios2/kernel-features.h
>> similarity index 69%
>> rename from sysdeps/unix/sysv/linux/csky/ipc_priv.h
>> rename to sysdeps/unix/sysv/linux/nios2/kernel-features.h
>> index e1beadb2a0..7f4023831e 100644
>> --- a/sysdeps/unix/sysv/linux/csky/ipc_priv.h
>> +++ b/sysdeps/unix/sysv/linux/nios2/kernel-features.h
>> @@ -1,5 +1,6 @@
>> -/* Old SysV permission definition for Linux. C-SKY version.
>> - Copyright (C) 2017-2019 Free Software Foundation, Inc.
>> +/* Set flags signalling availability of kernel features based on given
>> + kernel version number. NIOS2 version.
>> + Copyright (C) 2019 Free Software Foundation, Inc.
>> This file is part of the GNU C Library.
>>
>> The GNU C Library is free software; you can redistribute it and/or
>> @@ -13,9 +14,9 @@
>> Lesser General Public License for more details.
>>
>> You should have received a copy of the GNU Lesser General Public
>> - License along with the GNU C Library; if not, see
>> + License along with the GNU C Library. If not, see
>> <http://www.gnu.org/licenses/>. */
>>
>> -#include <sys/ipc.h> /* For __key_t */
>> +#include_next <kernel-features.h>
>>
>> -#define __IPC_64 0x0
>> +#undef __ASSUME_SYSVIPC_DEFAULT_IPC_64
>> diff --git a/sysdeps/unix/sysv/linux/powerpc/ipc_priv.h b/sysdeps/unix/sysv/linux/powerpc/ipc_priv.h
>> index 3450933f56..f641ed9a32 100644
>> --- a/sysdeps/unix/sysv/linux/powerpc/ipc_priv.h
>> +++ b/sysdeps/unix/sysv/linux/powerpc/ipc_priv.h
>> @@ -16,24 +16,7 @@
>> License along with the GNU C Library; if not, see
>> <http://www.gnu.org/licenses/>. */
>>
>> -#include <sys/ipc.h> /* For __key_t */
>> -
>> -#define __IPC_64 0x100
>> -
>> -struct __old_ipc_perm
>> -{
>> - __key_t __key; /* Key. */
>> - unsigned int uid; /* Owner's user ID. */
>> - unsigned int gid; /* Owner's group ID. */
>> - unsigned int cuid; /* Creator's user ID. */
>> - unsigned int cgid; /* Creator's group ID. */
>> - unsigned int mode; /* Read/write permission. */
>> - unsigned short int __seq; /* Sequence number. */
>> -};
>> -
>> -#define SEMCTL_ARG_ADDRESS(__arg) &__arg.array
>> -
>> -#define MSGRCV_ARGS(__msgp, __msgtyp) \
>> - ((long int []){ (long int) __msgp, __msgtyp })
>> -
>> -#include <ipc_ops.h>
>> +#define __OLD_IPC_ID_TYPE unsigned int
>> +#define __OLD_IPC_MODE_TYPE unsigned int
>> +#define __OLD_IPC_SEQ_TYPE unsigned short int
>> +#include <sysdeps/unix/sysv/linux/ipc_priv.h>
>> diff --git a/sysdeps/unix/sysv/linux/powerpc/kernel-features.h b/sysdeps/unix/sysv/linux/powerpc/kernel-features.h
>> index 413a185db3..e787182396 100644
>> --- a/sysdeps/unix/sysv/linux/powerpc/kernel-features.h
>> +++ b/sysdeps/unix/sysv/linux/powerpc/kernel-features.h
>> @@ -46,6 +46,7 @@
>>
>> /* powerpc only supports ipc syscall. */
>> #undef __ASSUME_DIRECT_SYSVIPC_SYSCALLS
>> +#undef __ASSUME_SYSVIPC_DEFAULT_IPC_64
>>
>> #undef __ASSUME_CLONE_DEFAULT
>> #define __ASSUME_CLONE_BACKWARDS 1
>> diff --git a/sysdeps/unix/sysv/linux/riscv/ipc_priv.h b/sysdeps/unix/sysv/linux/riscv/ipc_priv.h
>> deleted file mode 100644
>> index ea957a56be..0000000000
>> --- a/sysdeps/unix/sysv/linux/riscv/ipc_priv.h
>> +++ /dev/null
>> @@ -1,21 +0,0 @@
>> -/* Old SysV permission definition for Linux. RISC-V version.
>> - Copyright (C) 2018-2019 Free Software Foundation, Inc.
>> - This file is part of the GNU C Library.
>> -
>> - The GNU C Library is free software; you can redistribute it and/or
>> - modify it under the terms of the GNU Lesser General Public
>> - License as published by the Free Software Foundation; either
>> - version 2.1 of the License, or (at your option) any later version.
>> -
>> - The GNU C Library is distributed in the hope that it will be useful,
>> - but WITHOUT ANY WARRANTY; without even the implied warranty of
>> - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
>> - Lesser General Public License for more details.
>> -
>> - You should have received a copy of the GNU Lesser General Public
>> - License along with the GNU C Library; if not, see
>> - <http://www.gnu.org/licenses/>. */
>> -
>> -#include <sys/ipc.h> /* For __key_t */
>> -
>> -#define __IPC_64 0x0
>> diff --git a/sysdeps/unix/sysv/linux/s390/kernel-features.h b/sysdeps/unix/sysv/linux/s390/kernel-features.h
>> index 8fdf38c454..57077ea4cc 100644
>> --- a/sysdeps/unix/sysv/linux/s390/kernel-features.h
>> +++ b/sysdeps/unix/sysv/linux/s390/kernel-features.h
>> @@ -47,6 +47,7 @@
>>
>> /* s390 only supports ipc syscall. */
>> #undef __ASSUME_DIRECT_SYSVIPC_SYSCALLS
>> +#undef __ASSUME_SYSVIPC_DEFAULT_IPC_64
>>
>> #undef __ASSUME_CLONE_DEFAULT
>> #define __ASSUME_CLONE_BACKWARDS2
>> diff --git a/sysdeps/unix/sysv/linux/sh/kernel-features.h b/sysdeps/unix/sysv/linux/sh/kernel-features.h
>> index b11a5cb544..cf68256abe 100644
>> --- a/sysdeps/unix/sysv/linux/sh/kernel-features.h
>> +++ b/sysdeps/unix/sysv/linux/sh/kernel-features.h
>> @@ -43,6 +43,7 @@
>>
>> /* sh only supports ipc syscall. */
>> #undef __ASSUME_DIRECT_SYSVIPC_SYSCALLS
>> +#undef __ASSUME_SYSVIPC_DEFAULT_IPC_64
>>
>> /* Support for several syscalls was added in 4.8. */
>> #if __LINUX_KERNEL_VERSION < 0x040800
>> diff --git a/sysdeps/unix/sysv/linux/sparc/kernel-features.h b/sysdeps/unix/sysv/linux/sparc/kernel-features.h
>> index f441bd811d..82c8236c23 100644
>> --- a/sysdeps/unix/sysv/linux/sparc/kernel-features.h
>> +++ b/sysdeps/unix/sysv/linux/sparc/kernel-features.h
>> @@ -60,6 +60,9 @@
>>
>> /* sparc only supports ipc syscall. */
>> #undef __ASSUME_DIRECT_SYSVIPC_SYSCALLS
>> +#ifndef __arch64__
>> +# undef __ASSUME_SYSVIPC_DEFAULT_IPC_64
>> +#endif
>>
>> /* Support for the renameat2 syscall was added in 3.16. */
>> #if __LINUX_KERNEL_VERSION < 0x031000
>> diff --git a/sysdeps/unix/sysv/linux/sparc/sparc64/ipc_priv.h b/sysdeps/unix/sysv/linux/sparc/sparc64/ipc_priv.h
>> index 8936aed022..3d813fe9e6 100644
>> --- a/sysdeps/unix/sysv/linux/sparc/sparc64/ipc_priv.h
>> +++ b/sysdeps/unix/sysv/linux/sparc/sparc64/ipc_priv.h
>> @@ -16,26 +16,18 @@
>> License along with the GNU C Library; if not, see
>> <http://www.gnu.org/licenses/>. */
>>
>> -#include <sys/ipc.h> /* For __key_t */
>> -
>> -#define __IPC_64 0x0
>> -
>> -struct __old_ipc_perm
>> -{
>> - __key_t __key; /* Key. */
>> - unsigned int uid; /* Owner's user ID. */
>> - unsigned int gid; /* Owner's group ID. */
>> - unsigned int cuid; /* Creator's user ID. */
>> - unsigned int cgid; /* Creator's group ID. */
>> - unsigned int mode; /* Read/write permission. */
>> - unsigned short int __seq; /* Sequence number. */
>> -};
>> +#define __OLD_IPC_ID_TYPE unsigned int
>> +#define __OLD_IPC_MODE_TYPE unsigned int
>> +#define __OLD_IPC_SEQ_TYPE unsigned short int
>> +#include <sysdeps/unix/sysv/linux/ipc_priv.h>
>>
>> /* SPARC semctl multiplex syscall expects the union pointed address, not
>> the union address itself. */
>> +#undef SEMCTL_ARG_ADDRESS
>> #define SEMCTL_ARG_ADDRESS(__arg) __arg.array
>>
>> /* Also for msgrcv it does not use the kludge on final 2 arguments. */
>> +#undef MSGRCV_ARGS
>> #define MSGRCV_ARGS(__msgp, __msgtyp) __msgp, __msgtyp
>>
>> #include <ipc_ops.h>
>> diff --git a/sysdeps/unix/sysv/linux/x86_64/ipc_priv.h b/sysdeps/unix/sysv/linux/x86_64/ipc_priv.h
>> deleted file mode 100644
>> index 1ac288aa65..0000000000
>> --- a/sysdeps/unix/sysv/linux/x86_64/ipc_priv.h
>> +++ /dev/null
>> @@ -1,32 +0,0 @@
>> -/* Old SysV permission definition for Linux. x86_64 version.
>> - Copyright (C) 2016-2019 Free Software Foundation, Inc.
>> - This file is part of the GNU C Library.
>> -
>> - The GNU C Library is free software; you can redistribute it and/or
>> - modify it under the terms of the GNU Lesser General Public
>> - License as published by the Free Software Foundation; either
>> - version 2.1 of the License, or (at your option) any later version.
>> -
>> - The GNU C Library is distributed in the hope that it will be useful,
>> - but WITHOUT ANY WARRANTY; without even the implied warranty of
>> - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
>> - Lesser General Public License for more details.
>> -
>> - You should have received a copy of the GNU Lesser General Public
>> - License along with the GNU C Library; if not, see
>> - <http://www.gnu.org/licenses/>. */
>> -
>> -#include <sys/ipc.h> /* For __key_t */
>> -
>> -#define __IPC_64 0x0
>> -
>> -struct __old_ipc_perm
>> -{
>> - __key_t __key; /* Key. */
>> - unsigned short uid; /* Owner's user ID. */
>> - unsigned short gid; /* Owner's group ID. */
>> - unsigned short cuid; /* Creator's user ID. */
>> - unsigned short cgid; /* Creator's group ID. */
>> - unsigned short mode; /* Read/write permission. */
>> - unsigned short int __seq; /* Sequence number. */
>> -};
>>
prev parent reply other threads:[~2019-08-28 14:07 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2019-05-20 17:53 [PATCH v2 1/2] ipc: Refactor sysvipc internal definitions Adhemerval Zanella
2019-05-20 17:53 ` [PATCH v2 2/2] Update sysvipc kernel-features.h files for Linux 5.1 Adhemerval Zanella
2019-05-20 19:10 ` Joseph Myers
2019-05-20 19:20 ` Adhemerval Zanella
2019-08-28 14:07 ` Adhemerval Zanella
2019-08-09 12:18 ` [PATCH v2 1/2] ipc: Refactor sysvipc internal definitions Adhemerval Zanella
2019-08-28 14:06 ` Adhemerval Zanella [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
List information: https://www.gnu.org/software/libc/involved.html
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=6160c098-4204-6246-96b1-a44bbb5d4da7@linaro.org \
--to=adhemerval.zanella@linaro.org \
--cc=libc-alpha@sourceware.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).