1 /* $NetBSD: linux_msg.h,v 1.12 2008/12/09 11:09:11 njoly Exp $ */
4 * Copyright (c) 1995, 1998 The NetBSD Foundation, Inc.
7 * This code is derived from software contributed to The NetBSD Foundation
8 * by Frank van der Linden and Eric Haszlakiewicz.
10 * Redistribution and use in source and binary forms, with or without
11 * modification, are permitted provided that the following conditions
13 * 1. Redistributions of source code must retain the above copyright
14 * notice, this list of conditions and the following disclaimer.
15 * 2. Redistributions in binary form must reproduce the above copyright
16 * notice, this list of conditions and the following disclaimer in the
17 * documentation and/or other materials provided with the distribution.
19 * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
20 * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
21 * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
23 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29 * POSSIBILITY OF SUCH DAMAGE.
38 * msq_id_ds structure. Mostly the same fields, except for some internal
41 struct linux_msqid_ds
{
42 struct linux_ipc_perm l_msg_perm
;
45 linux_time_t l_msg_stime
;
46 linux_time_t l_msg_rtime
;
47 linux_time_t l_msg_ctime
;
48 void *l_wwait
; /* Linux internal */
49 void *l_rwait
; /* Linux internal */
57 struct linux_msqid64_ds
{
58 struct linux_ipc64_perm l_msg_perm
;
59 linux_time_t l_msg_stime
;
63 linux_time_t l_msg_rtime
;
67 linux_time_t l_msg_ctime
;
81 #define LINUX_MSG_NOERROR 0x1000
82 #define LINUX_MSG_EXCEPT 0x2000
85 * The notorious anonymous message structure.
93 * This kludge is used for the 6th argument to the msgrcv system
94 * call, to get around the maximum of 5 arguments to a syscall in Linux.
96 struct linux_msgrcv_msgarg
{
97 struct linux_mymsg
*msg
;
103 struct linux_msginfo
{
114 #define LINUX_MSG_STAT 11
115 #define LINUX_MSG_INFO 12
117 /* Pretend the sys_msgctl syscall is defined */
118 struct linux_sys_msgctl_args
{
119 syscallarg(int) msqid
;
121 syscallarg(struct linux_msqid_ds
*) buf
;
128 int linux_sys_msgctl(struct lwp
*, const struct linux_sys_msgctl_args
*, register_t
*);
129 void linux_to_bsd_msqid_ds(struct linux_msqid_ds
*, struct msqid_ds
*);
130 void linux_to_bsd_msqid64_ds(struct linux_msqid64_ds
*, struct msqid_ds
*);
131 void bsd_to_linux_msqid_ds(struct msqid_ds
*, struct linux_msqid_ds
*);
132 void bsd_to_linux_msqid64_ds(struct msqid_ds
*, struct linux_msqid64_ds
*);
134 #endif /* !_KERNEL */
135 #endif /* !SYSVMSG */
137 #endif /* !_LINUX_MSG_H */