linux_msg.h 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. /* $OpenBSD: linux_msg.h,v 1.3 2011/04/05 22:54:31 pirofti Exp $ */
  2. /* $NetBSD: linux_msg.h,v 1.2 1995/08/15 21:14:34 fvdl Exp $ */
  3. /*
  4. * Copyright (c) 1995 Frank van der Linden
  5. * All rights reserved.
  6. *
  7. * Redistribution and use in source and binary forms, with or without
  8. * modification, are permitted provided that the following conditions
  9. * are met:
  10. * 1. Redistributions of source code must retain the above copyright
  11. * notice, this list of conditions and the following disclaimer.
  12. * 2. Redistributions in binary form must reproduce the above copyright
  13. * notice, this list of conditions and the following disclaimer in the
  14. * documentation and/or other materials provided with the distribution.
  15. * 3. All advertising materials mentioning features or use of this software
  16. * must display the following acknowledgement:
  17. * This product includes software developed for the NetBSD Project
  18. * by Frank van der Linden
  19. * 4. The name of the author may not be used to endorse or promote products
  20. * derived from this software without specific prior written permission
  21. *
  22. * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
  23. * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
  24. * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
  25. * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
  26. * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
  27. * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  28. * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  29. * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  30. * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
  31. * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  32. */
  33. #ifndef _LINUX_MSG_H_
  34. #define _LINUX_MSG_H_
  35. /*
  36. * msq_id_ds structure. Mostly the same fields, except for some internal
  37. * ones.
  38. */
  39. struct linux_msqid_ds {
  40. struct linux_ipc_perm l_msg_perm;
  41. void *l_msg_first;
  42. void *l_msg_last;
  43. linux_time_t l_msg_stime;
  44. linux_time_t l_msg_rtime;
  45. linux_time_t l_msg_ctime;
  46. void *l_wwait; /* Linux internal */
  47. void *l_rwait; /* Linux internal */
  48. ushort l_msg_cbytes;
  49. ushort l_msg_qnum;
  50. ushort l_msg_qbytes;
  51. ushort l_msg_lspid;
  52. ushort l_msg_lrpid;
  53. };
  54. #define LINUX_MSG_NOERROR 0x1000
  55. #define LINUX_MSG_EXCEPT 0x2000
  56. /*
  57. * The notorious anonymous message structure.
  58. */
  59. struct linux_mymsg {
  60. long l_mtype;
  61. char l_mtext[1];
  62. };
  63. /*
  64. * This kludge is used for the 6th argument to the msgrcv system
  65. * call, to get around the maximum of 5 arguments to a syscall in Linux.
  66. */
  67. struct linux_msgrcv_msgarg {
  68. struct linux_mymsg *msg;
  69. int type;
  70. };
  71. /*
  72. * For msgctl calls.
  73. */
  74. struct linux_msginfo {
  75. int l_msgpool;
  76. int l_msgmap;
  77. int l_msgmax;
  78. int l_msgmnb;
  79. int l_msgmni;
  80. int l_msgssz;
  81. int l_msgtql;
  82. ushort l_msgseg;
  83. };
  84. #define LINUX_MSG_STAT 11
  85. #define LINUX_MSG_INFO 12
  86. #endif /* _LINUX_MSG_H_ */