ipc.h 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. /* Copyright (C) 2000 Free Software Foundation, Inc.
  2. This file is part of the GNU C Library.
  3. Contributed by David Mosberger-Tang <davidm@hpl.hp.com>
  4. The GNU C Library is free software; you can redistribute it and/or
  5. modify it under the terms of the GNU Lesser General Public
  6. License as published by the Free Software Foundation; either
  7. version 2.1 of the License, or (at your option) any later version.
  8. The GNU C Library is distributed in the hope that it will be useful,
  9. but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  11. Lesser General Public License for more details.
  12. You should have received a copy of the GNU Lesser General Public
  13. License along with the GNU C Library; if not, see
  14. <http://www.gnu.org/licenses/>. */
  15. #ifndef _SYS_IPC_H
  16. # error "Never use <bits/ipc.h> directly; include <sys/ipc.h> instead."
  17. #endif
  18. #include <sys/types.h>
  19. /* Mode bits for `msgget', `semget', and `shmget'. */
  20. #define IPC_CREAT 01000 /* Create key if key does not exist. */
  21. #define IPC_EXCL 02000 /* Fail if key exists. */
  22. #define IPC_NOWAIT 04000 /* Return error on wait. */
  23. /* Control commands for `msgctl', `semctl', and `shmctl'. */
  24. #define IPC_RMID 0 /* Remove identifier. */
  25. #define IPC_SET 1 /* Set `ipc_perm' options. */
  26. #define IPC_STAT 2 /* Get `ipc_perm' options. */
  27. #define IPC_INFO 3 /* See ipcs. */
  28. /* Special key values. */
  29. #define IPC_PRIVATE ((__key_t) 0) /* Private key. */
  30. /* Data structure used to pass permission information to IPC operations. */
  31. struct ipc_perm
  32. {
  33. __key_t __key; /* Key. */
  34. __uid_t uid; /* Owner's user ID. */
  35. __gid_t gid; /* Owner's group ID. */
  36. __uid_t cuid; /* Creator's user ID. */
  37. __gid_t cgid; /* Creator's group ID. */
  38. __mode_t mode; /* Read/write permission. */
  39. unsigned short int __seq; /* Sequence number. */
  40. unsigned short int __pad1;
  41. unsigned long int __unused1;
  42. unsigned long int __unused2;
  43. };