2 * Copyright (c) 1993 Ulrich Pegelow <pegelow@moorea.uni-muenster.de>
3 * Copyright (c) 1993 Branko Lankester <branko@hacktic.nl>
4 * Copyright (c) 1993, 1994, 1995, 1996 Rick Sladkey <jrs@world.std.com>
5 * Copyright (c) 1996-1999 Wichert Akkerman <wichert@cistron.nl>
8 * Redistribution and use in source and binary forms, with or without
9 * modification, are permitted provided that the following conditions
11 * 1. Redistributions of source code must retain the above copyright
12 * notice, this list of conditions and the following disclaimer.
13 * 2. Redistributions in binary form must reproduce the above copyright
14 * notice, this list of conditions and the following disclaimer in the
15 * documentation and/or other materials provided with the distribution.
16 * 3. The name of the author may not be used to endorse or promote products
17 * derived from this software without specific prior written permission.
19 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
20 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
21 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
22 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
23 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
24 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
25 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
26 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
28 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
35 #if defined(LINUX) || defined(SUNOS4) || defined(FREEBSD)
66 #if defined LINUX && !defined IPC_64
70 extern const struct xlat openmodes[];
71 extern void printsigevent(struct tcb *tcp, long arg);
73 static const struct xlat msgctl_flags[] = {
74 { IPC_RMID, "IPC_RMID" },
75 { IPC_SET, "IPC_SET" },
76 { IPC_STAT, "IPC_STAT" },
78 { IPC_INFO, "IPC_INFO" },
79 { MSG_STAT, "MSG_STAT" },
80 { MSG_INFO, "MSG_INFO" },
85 static const struct xlat semctl_flags[] = {
86 { IPC_RMID, "IPC_RMID" },
87 { IPC_SET, "IPC_SET" },
88 { IPC_STAT, "IPC_STAT" },
90 { IPC_INFO, "IPC_INFO" },
91 { SEM_STAT, "SEM_STAT" },
92 { SEM_INFO, "SEM_INFO" },
97 { GETNCNT, "GETNCNT" },
98 { GETZCNT, "GETZCNT" },
100 { SETALL, "SETALL" },
104 static const struct xlat shmctl_flags[] = {
105 { IPC_RMID, "IPC_RMID" },
106 { IPC_SET, "IPC_SET" },
107 { IPC_STAT, "IPC_STAT" },
109 { IPC_INFO, "IPC_INFO" },
110 { SHM_STAT, "SHM_STAT" },
111 { SHM_INFO, "SHM_INFO" },
114 { SHM_LOCK, "SHM_LOCK" },
117 { SHM_UNLOCK, "SHM_UNLOCK" },
122 static const struct xlat resource_flags[] = {
123 { IPC_CREAT, "IPC_CREAT" },
124 { IPC_EXCL, "IPC_EXCL" },
125 { IPC_NOWAIT, "IPC_NOWAIT" },
129 static const struct xlat shm_resource_flags[] = {
130 { IPC_CREAT, "IPC_CREAT" },
131 { IPC_EXCL, "IPC_EXCL" },
133 { SHM_HUGETLB, "SHM_HUGETLB" },
138 static const struct xlat shm_flags[] = {
140 { SHM_REMAP, "SHM_REMAP" },
142 { SHM_RDONLY, "SHM_RDONLY" },
143 { SHM_RND, "SHM_RND" },
147 static const struct xlat msg_flags[] = {
148 { MSG_NOERROR, "MSG_NOERROR" },
150 { MSG_EXCEPT, "MSG_EXCEPT" },
152 { IPC_NOWAIT, "IPC_NOWAIT" },
161 tprintf("%lu", tcp->u_arg[0]);
163 tprintf("IPC_PRIVATE");
165 if (printflags(resource_flags, tcp->u_arg[1] & ~0777, NULL) != 0)
167 tprintf("%#lo", tcp->u_arg[1] & 0777);
173 # define PRINTCTL(flagset, arg, dflt) \
174 if ((arg) & IPC_64) tprintf("IPC_64|"); \
175 printxval((flagset), (arg) &~ IPC_64, dflt)
177 # define PRINTCTL printxval
181 indirect_ipccall(tcp)
186 return current_personality > 0;
197 tprintf("%lu, ", tcp->u_arg[0]);
198 PRINTCTL(msgctl_flags, tcp->u_arg[1], "MSG_???");
199 tprintf(", %#lx", tcp->u_arg[indirect_ipccall(tcp) ? 3 : 2]);
210 tprintf("%lu", tcp->u_arg[0]);
211 if (indirect_ipccall(tcp)) {
212 umove(tcp, tcp->u_arg[3], &mtype);
213 tprintf(", {%lu, ", mtype);
214 printstr(tcp, tcp->u_arg[3] + sizeof(long),
216 tprintf("}, %lu", tcp->u_arg[1]);
218 printflags(msg_flags, tcp->u_arg[2], "MSG_???");
220 umove(tcp, tcp->u_arg[1], &mtype);
221 tprintf(", {%lu, ", mtype);
222 printstr(tcp, tcp->u_arg[1] + sizeof(long),
224 tprintf("}, %lu", tcp->u_arg[2]);
226 printflags(msg_flags, tcp->u_arg[3], "MSG_???");
238 tprintf("%lu, ", tcp->u_arg[0]);
240 tprintf("%lu", tcp->u_arg[0]);
241 if (indirect_ipccall(tcp)) {
246 umove(tcp, tcp->u_arg[3], &tmp);
247 umove(tcp, (long) tmp.msgp, &mtype);
248 tprintf(", {%lu, ", mtype);
249 printstr(tcp, (long) (tmp.msgp) + sizeof(long),
251 tprintf("}, %lu", tcp->u_arg[1]);
252 tprintf(", %ld", tmp.msgtyp);
254 printflags(msg_flags, tcp->u_arg[2], "MSG_???");
256 umove(tcp, tcp->u_arg[1], &mtype);
257 tprintf("{%lu, ", mtype);
258 printstr(tcp, tcp->u_arg[1] + sizeof(long),
260 tprintf("}, %lu", tcp->u_arg[2]);
261 tprintf(", %ld", tcp->u_arg[3]);
263 printflags(msg_flags, tcp->u_arg[4], "MSG_???");
273 tprintf("%lu", tcp->u_arg[0]);
274 if (indirect_ipccall(tcp)) {
275 tprintf(", %#lx", tcp->u_arg[3]);
276 tprintf(", %lu", tcp->u_arg[1]);
278 tprintf(", %#lx", tcp->u_arg[1]);
279 tprintf(", %lu", tcp->u_arg[2]);
286 int sys_semtimedop(tcp)
290 tprintf("%lu", tcp->u_arg[0]);
291 if (!indirect_ipccall(tcp)) {
292 tprintf(", %#lx", tcp->u_arg[3]);
293 tprintf(", %lu, ", tcp->u_arg[1]);
294 printtv(tcp, tcp->u_arg[5]);
296 tprintf(", %#lx", tcp->u_arg[1]);
297 tprintf(", %lu, ", tcp->u_arg[2]);
298 printtv(tcp, tcp->u_arg[3]);
310 tprintf("%lu", tcp->u_arg[0]);
312 tprintf("IPC_PRIVATE");
313 tprintf(", %lu", tcp->u_arg[1]);
315 if (printflags(resource_flags, tcp->u_arg[2] & ~0777, NULL) != 0)
317 tprintf("%#lo", tcp->u_arg[2] & 0777);
326 tprintf("%lu", tcp->u_arg[0]);
327 tprintf(", %lu, ", tcp->u_arg[1]);
328 PRINTCTL(semctl_flags, tcp->u_arg[2], "SEM_???");
329 tprintf(", %#lx", tcp->u_arg[3]);
339 tprintf("%lu", tcp->u_arg[0]);
341 tprintf("IPC_PRIVATE");
342 tprintf(", %lu", tcp->u_arg[1]);
344 if (printflags(shm_resource_flags, tcp->u_arg[2] & ~0777, NULL) != 0)
346 tprintf("%#lo", tcp->u_arg[2] & 0777);
355 tprintf("%lu, ", tcp->u_arg[0]);
356 PRINTCTL(shmctl_flags, tcp->u_arg[1], "SHM_???");
357 if (indirect_ipccall(tcp)) {
358 tprintf(", %#lx", tcp->u_arg[3]);
360 tprintf(", %#lx", tcp->u_arg[2]);
374 tprintf("%lu", tcp->u_arg[0]);
375 if (indirect_ipccall(tcp)) {
376 tprintf(", %#lx", tcp->u_arg[3]);
378 printflags(shm_flags, tcp->u_arg[1], "SHM_???");
380 tprintf(", %#lx", tcp->u_arg[1]);
382 printflags(shm_flags, tcp->u_arg[2], "SHM_???");
387 if (umove(tcp, tcp->u_arg[2], &raddr) < 0)
400 if (indirect_ipccall(tcp)) {
401 tprintf("%#lx", tcp->u_arg[3]);
403 tprintf("%#lx", tcp->u_arg[0]);
409 #endif /* defined(LINUX) || defined(SUNOS4) || defined(FREEBSD) */
416 printpath(tcp, tcp->u_arg[0]);
419 printflags(openmodes, tcp->u_arg[1] + 1, "O_???");
420 if (tcp->u_arg[1] & O_CREAT) {
421 # ifndef HAVE_MQUEUE_H
422 tprintf(", %lx", tcp->u_arg[2]);
426 tprintf(", %#lo, ", tcp->u_arg[2]);
427 if (umove(tcp, tcp->u_arg[3], &attr) < 0)
430 tprintf("{mq_maxmsg=%ld, mq_msgsize=%ld}",
431 attr.mq_maxmsg, attr.mq_msgsize);
438 int sys_mq_timedsend(tcp)
442 tprintf("%ld, ", tcp->u_arg[0]);
443 printstr(tcp, tcp->u_arg[1], tcp->u_arg[2]);
444 tprintf(", %lu, %ld, ", tcp->u_arg[2], tcp->u_arg[3]);
445 printtv(tcp, tcp->u_arg[4]);
450 int sys_mq_timedreceive(tcp)
454 tprintf("%ld, ", tcp->u_arg[0]);
456 printstr(tcp, tcp->u_arg[1], tcp->u_arg[2]);
457 tprintf(", %lu, %ld, ", tcp->u_arg[2], tcp->u_arg[3]);
458 printtv(tcp, tcp->u_arg[4]);
463 int sys_mq_notify(tcp)
467 tprintf("%ld, ", tcp->u_arg[0]);
468 printsigevent(tcp, tcp->u_arg[1]);
473 static void printmqattr(tcp, addr)
480 # ifndef HAVE_MQUEUE_H
481 tprintf("%#lx", addr);
484 if (umove(tcp, addr, &attr) < 0) {
488 tprintf("{mq_flags=");
489 printflags(openmodes, attr.mq_flags + 1, "O_???");
490 tprintf(", mq_maxmsg=%ld, mq_msgsize=%ld, mq_curmsg=%ld}",
491 attr.mq_maxmsg, attr.mq_msgsize, attr.mq_curmsgs);
496 int sys_mq_getsetattr(tcp)
500 tprintf("%ld, ", tcp->u_arg[0]);
501 printmqattr(tcp, tcp->u_arg[1]);
504 printmqattr(tcp, tcp->u_arg[2]);