unofficial mirror of libc-alpha@sourceware.org
 help / color / mirror / Atom feed
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.  */
>> -};
>>

      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).