Greg Kroah-Hartman | 6f52b16 | 2017-11-01 15:08:43 +0100 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */ |
Arnd Bergmann | 2864d32 | 2009-05-13 22:56:26 +0000 | [diff] [blame] | 2 | #ifndef __ASM_GENERIC_IPCBUF_H |
| 3 | #define __ASM_GENERIC_IPCBUF_H |
| 4 | |
Masahiro Yamada | 5b00967 | 2019-12-04 16:52:57 -0800 | [diff] [blame] | 5 | #include <linux/posix_types.h> |
| 6 | |
Arnd Bergmann | 2864d32 | 2009-05-13 22:56:26 +0000 | [diff] [blame] | 7 | /* |
| 8 | * The generic ipc64_perm structure: |
| 9 | * Note extra padding because this structure is passed back and forth |
| 10 | * between kernel and user space. |
| 11 | * |
| 12 | * ipc64_perm was originally meant to be architecture specific, but |
| 13 | * everyone just ended up making identical copies without specific |
| 14 | * optimizations, so we may just as well all use the same one. |
| 15 | * |
| 16 | * Pad space is left for: |
| 17 | * - 32-bit mode_t on architectures that only had 16 bit |
| 18 | * - 32-bit seq |
| 19 | * - 2 miscellaneous 32-bit values |
| 20 | */ |
| 21 | |
| 22 | struct ipc64_perm { |
| 23 | __kernel_key_t key; |
| 24 | __kernel_uid32_t uid; |
| 25 | __kernel_gid32_t gid; |
| 26 | __kernel_uid32_t cuid; |
| 27 | __kernel_gid32_t cgid; |
| 28 | __kernel_mode_t mode; |
| 29 | /* pad if mode_t is u16: */ |
| 30 | unsigned char __pad1[4 - sizeof(__kernel_mode_t)]; |
| 31 | unsigned short seq; |
| 32 | unsigned short __pad2; |
H.J. Lu | 071ed24 | 2013-12-27 14:14:19 -0800 | [diff] [blame] | 33 | __kernel_ulong_t __unused1; |
| 34 | __kernel_ulong_t __unused2; |
Arnd Bergmann | 2864d32 | 2009-05-13 22:56:26 +0000 | [diff] [blame] | 35 | }; |
| 36 | |
| 37 | #endif /* __ASM_GENERIC_IPCBUF_H */ |