1999-02-19 00:21:36 +00:00
/*
* Copyright ( c ) 1993 Ulrich Pegelow < pegelow @ moorea . uni - muenster . de >
* Copyright ( c ) 1993 Branko Lankester < branko @ hacktic . nl >
* Copyright ( c ) 1993 , 1994 , 1995 , 1996 Rick Sladkey < jrs @ world . std . com >
1999-12-23 14:20:14 +00:00
* Copyright ( c ) 1996 - 1999 Wichert Akkerman < wichert @ cistron . nl >
1999-02-19 00:21:36 +00:00
* All rights reserved .
*
* Redistribution and use in source and binary forms , with or without
* modification , are permitted provided that the following conditions
* are met :
* 1. Redistributions of source code must retain the above copyright
* notice , this list of conditions and the following disclaimer .
* 2. Redistributions in binary form must reproduce the above copyright
* notice , this list of conditions and the following disclaimer in the
* documentation and / or other materials provided with the distribution .
* 3. The name of the author may not be used to endorse or promote products
* derived from this software without specific prior written permission .
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ` ` AS IS ' ' AND ANY EXPRESS OR
* IMPLIED WARRANTIES , INCLUDING , BUT NOT LIMITED TO , THE IMPLIED WARRANTIES
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED .
* IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT , INDIRECT ,
* INCIDENTAL , SPECIAL , EXEMPLARY , OR CONSEQUENTIAL DAMAGES ( INCLUDING , BUT
* NOT LIMITED TO , PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES ; LOSS OF USE ,
* DATA , OR PROFITS ; OR BUSINESS INTERRUPTION ) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY , WHETHER IN CONTRACT , STRICT LIABILITY , OR TORT
* ( INCLUDING NEGLIGENCE OR OTHERWISE ) ARISING IN ANY WAY OUT OF THE USE OF
* THIS SOFTWARE , EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE .
*
* $ Id $
*/
# include "defs.h"
2000-09-01 21:03:06 +00:00
# if defined(LINUX) || defined(SUNOS4) || defined(FREEBSD)
1999-02-19 00:21:36 +00:00
2004-04-16 21:48:40 +00:00
# ifdef HAVE_MQUEUE_H
# include <mqueue.h>
# endif
# include <fcntl.h>
1999-02-19 00:21:36 +00:00
# include <sys/ipc.h>
# include <sys/sem.h>
# include <sys/msg.h>
# include <sys/shm.h>
# ifndef MSG_STAT
# define MSG_STAT 11
# endif
# ifndef MSG_INFO
# define MSG_INFO 12
# endif
# ifndef SHM_STAT
# define SHM_STAT 13
# endif
# ifndef SHM_INFO
# define SHM_INFO 14
# endif
# ifndef SEM_STAT
# define SEM_STAT 18
# endif
# ifndef SEM_INFO
# define SEM_INFO 19
# endif
2003-01-14 09:46:17 +00:00
# if defined LINUX && !defined IPC_64
# define IPC_64 0x100
# endif
2004-04-16 21:48:40 +00:00
extern void printsigevent ( struct tcb * tcp , long arg ) ;
2004-09-04 03:39:20 +00:00
static const struct xlat msgctl_flags [ ] = {
1999-02-19 00:21:36 +00:00
{ IPC_RMID , " IPC_RMID " } ,
{ IPC_SET , " IPC_SET " } ,
{ IPC_STAT , " IPC_STAT " } ,
# ifdef LINUX
{ IPC_INFO , " IPC_INFO " } ,
{ MSG_STAT , " MSG_STAT " } ,
{ MSG_INFO , " MSG_INFO " } ,
# endif /* LINUX */
{ 0 , NULL } ,
} ;
2004-09-04 03:39:20 +00:00
static const struct xlat semctl_flags [ ] = {
1999-02-19 00:21:36 +00:00
{ IPC_RMID , " IPC_RMID " } ,
{ IPC_SET , " IPC_SET " } ,
{ IPC_STAT , " IPC_STAT " } ,
# ifdef LINUX
{ IPC_INFO , " IPC_INFO " } ,
{ SEM_STAT , " SEM_STAT " } ,
{ SEM_INFO , " SEM_INFO " } ,
# endif /* LINUX */
{ GETPID , " GETPID " } ,
{ GETVAL , " GETVAL " } ,
{ GETALL , " GETALL " } ,
{ GETNCNT , " GETNCNT " } ,
{ GETZCNT , " GETZCNT " } ,
{ SETVAL , " SETVAL " } ,
{ SETALL , " SETALL " } ,
{ 0 , NULL } ,
} ;
2004-09-04 03:39:20 +00:00
static const struct xlat shmctl_flags [ ] = {
1999-02-19 00:21:36 +00:00
{ IPC_RMID , " IPC_RMID " } ,
{ IPC_SET , " IPC_SET " } ,
{ IPC_STAT , " IPC_STAT " } ,
# ifdef LINUX
{ IPC_INFO , " IPC_INFO " } ,
{ SHM_STAT , " SHM_STAT " } ,
{ SHM_INFO , " SHM_INFO " } ,
# endif /* LINUX */
2003-01-14 09:46:17 +00:00
# ifdef SHM_LOCK
1999-02-19 00:21:36 +00:00
{ SHM_LOCK , " SHM_LOCK " } ,
2000-09-01 21:03:06 +00:00
# endif
2003-01-14 09:46:17 +00:00
# ifdef SHM_UNLOCK
1999-02-19 00:21:36 +00:00
{ SHM_UNLOCK , " SHM_UNLOCK " } ,
2003-01-14 09:46:17 +00:00
# endif
1999-02-19 00:21:36 +00:00
{ 0 , NULL } ,
} ;
2004-09-04 03:39:20 +00:00
static const struct xlat resource_flags [ ] = {
1999-02-19 00:21:36 +00:00
{ IPC_CREAT , " IPC_CREAT " } ,
{ IPC_EXCL , " IPC_EXCL " } ,
{ IPC_NOWAIT , " IPC_NOWAIT " } ,
2005-05-09 07:40:33 +00:00
{ 0 , NULL } ,
} ;
static const struct xlat shm_resource_flags [ ] = {
{ IPC_CREAT , " IPC_CREAT " } ,
{ IPC_EXCL , " IPC_EXCL " } ,
2003-07-17 09:03:04 +00:00
# ifdef SHM_HUGETLB
{ SHM_HUGETLB , " SHM_HUGETLB " } ,
# endif
1999-02-19 00:21:36 +00:00
{ 0 , NULL } ,
} ;
2004-09-04 03:39:20 +00:00
static const struct xlat shm_flags [ ] = {
1999-02-19 00:21:36 +00:00
# ifdef LINUX
{ SHM_REMAP , " SHM_REMAP " } ,
# endif /* LINUX */
{ SHM_RDONLY , " SHM_RDONLY " } ,
{ SHM_RND , " SHM_RND " } ,
{ 0 , NULL } ,
} ;
2004-09-04 03:39:20 +00:00
static const struct xlat msg_flags [ ] = {
1999-02-19 00:21:36 +00:00
{ MSG_NOERROR , " MSG_NOERROR " } ,
# ifdef LINUX
{ MSG_EXCEPT , " MSG_EXCEPT " } ,
# endif /* LINUX */
{ IPC_NOWAIT , " IPC_NOWAIT " } ,
{ 0 , NULL } ,
} ;
2009-10-07 22:25:10 +02:00
static const struct xlat semop_flags [ ] = {
{ SEM_UNDO , " SEM_UNDO " } ,
{ IPC_NOWAIT , " IPC_NOWAIT " } ,
{ 0 , NULL } ,
} ;
2011-05-30 14:00:14 +02:00
int sys_msgget ( struct tcb * tcp )
1999-02-19 00:21:36 +00:00
{
if ( entering ( tcp ) ) {
if ( tcp - > u_arg [ 0 ] )
2006-08-22 07:36:55 +00:00
tprintf ( " %#lx " , tcp - > u_arg [ 0 ] ) ;
1999-02-19 00:21:36 +00:00
else
2011-09-01 10:00:28 +02:00
tprints ( " IPC_PRIVATE " ) ;
tprints ( " , " ) ;
2005-05-31 Dmitry V. Levin <ldv@altlinux.org>
* util.c (printxval): Change third argument from "char *" to
"const char *".
(printflags): Add third argument, "const char *", with similar
meaning to the third argument of printxval().
* defs.h (printxval): Change third argument from "char *" to
"const char *".
(printflags): Add third argument.
* bjm.c (sys_query_module) [LINUX]: Pass third argument to
printflags().
* desc.c (sys_fcntl): Likewise.
(sys_flock) [LOCK_SH]: Likewise.
(print_epoll_event) [HAVE_SYS_EPOLL_H]: Likewise.
* file.c (sys_open): Likewise.
(solaris_open) [LINUXSPARC]: Likewise.
(sys_access): Likewise.
(sys_chflags, sys_fchflags) [FREEBSD]: Likewise.
(realprintstat) [HAVE_LONG_LONG_OFF_T &&
HAVE_STRUCT_STAT_ST_FLAGS]: Likewise.
(printstat64) [HAVE_STAT64 &&
HAVE_STRUCT_STAT_ST_FLAGS]: Likewise.
(sys_setxattr, sys_fsetxattr): Likewise.
* ipc.c (sys_msgget, sys_msgsnd, sys_msgrcv, sys_semget,
sys_shmget, sys_shmat) [LINUX || SUNOS4 || FREEBSD]: Likewise.
(sys_mq_open) [LINUX]: Likewise.
(printmqattr) [HAVE_MQUEUE_H]: Likewise.
* mem.c (print_mmap) [!HAVE_LONG_LONG_OFF_T]: Likewise.
(sys_mmap64) [_LFS64_LARGEFILE || HAVE_LONG_LONG_OFF_T]: Likewise.
(sys_mprotect): Likewise.
(sys_mremap, sys_madvise, sys_mlockall) [LINUX]: Likewise.
(sys_msync) [MS_ASYNC]: Likewise.
(sys_mctl) [MC_SYNC]: Likewise.
(sys_remap_file_pages, sys_mbind, sys_get_mempolicy) [LINUX]:
Likewise.
* net.c (printmsghdr) [HAVE_STRUCT_MSGHDR_MSG_CONTROL]: Likewise.
(sys_send, sys_sendto): Likewise.
(sys_sendmsg) [HAVE_SENDMSG]: Likewise.
(sys_recv, sys_recvfrom): Likewise.
(sys_recvmsg) [HAVE_SENDMSG]: Likewise.
(printicmpfilter) [ICMP_FILTER]: Likewise.
* proc.c (proc_ioctl) [SVR4 && !HAVE_MP_PROCFS || FREEBSD]: Likewise.
* process.c (sys_clone) [LINUX]: Likewise.
(printwaitn): Likewise.
(sys_waitid) [SVR4 || LINUX]: Likewise.
* signal.c (sys_sigvec) [SUNOS4 || FREEBSD]: Likewise.
(sys_sigaction): Likewise.
(printcontext) [SVR4]: Likewise.
(print_stack_t) [LINUX) || FREEBSD]: Likewise.
(sys_rt_sigaction) [LINUX]: Likewise.
* sock.c (sock_ioctl) [LINUX]: Likewise.
* stream.c (sys_putmsg, sys_getmsg): Likewise.
(sys_putpmsg) [SYS_putpmsg]: Likewise.
(sys_getpmsg) [SYS_getpmsg]: Likewise.
(sys_poll): Likewise.
(print_transport_message) [TI_BIND]: Likewise.
(stream_ioctl): Likewise.
* system.c (sys_mount, sys_reboot): Likewise.
(sys_cacheflush) [LINUX && M68K]: Likewise.
(sys_capget, sys_capset) [SYS_capget]: Likewise.
* term.c (term_ioctl) [TIOCMGET]: Likewise.
* time.c (sys_clock_nanosleep, sys_timer_settime) [LINUX]:
Likewise.
Fixes RH#159310.
2005-06-01 19:02:36 +00:00
if ( printflags ( resource_flags , tcp - > u_arg [ 1 ] & ~ 0777 , NULL ) ! = 0 )
2011-09-01 10:00:28 +02:00
tprints ( " | " ) ;
2003-07-17 09:03:04 +00:00
tprintf ( " %#lo " , tcp - > u_arg [ 1 ] & 0777 ) ;
1999-02-19 00:21:36 +00:00
}
return 0 ;
}
2003-01-14 09:46:17 +00:00
# ifdef IPC_64
# define PRINTCTL(flagset, arg, dflt) \
2011-09-01 10:00:28 +02:00
if ( ( arg ) & IPC_64 ) tprints ( " IPC_64| " ) ; \
2003-01-14 09:46:17 +00:00
printxval ( ( flagset ) , ( arg ) & ~ IPC_64 , dflt )
# else
# define PRINTCTL printxval
# endif
2005-12-02 03:57:07 +00:00
static int
2011-05-30 14:00:14 +02:00
indirect_ipccall ( struct tcb * tcp )
2005-12-02 03:57:07 +00:00
{
# ifdef LINUX
# ifdef X86_64
return current_personality > 0 ;
# endif
2005-12-02 04:18:55 +00:00
# if defined IA64
return tcp - > scno < 1024 ; /* ia32 emulation syscalls are low */
2005-12-02 03:57:07 +00:00
# endif
2005-12-02 04:34:09 +00:00
# if !defined MIPS && !defined HPPA
return 1 ;
# endif
# endif /* LINUX */
2005-12-02 03:57:07 +00:00
return 0 ;
}
2011-05-30 14:00:14 +02:00
int sys_msgctl ( struct tcb * tcp )
1999-02-19 00:21:36 +00:00
{
if ( entering ( tcp ) ) {
2003-01-14 09:46:17 +00:00
tprintf ( " %lu, " , tcp - > u_arg [ 0 ] ) ;
PRINTCTL ( msgctl_flags , tcp - > u_arg [ 1 ] , " MSG_??? " ) ;
2005-12-02 03:57:07 +00:00
tprintf ( " , %#lx " , tcp - > u_arg [ indirect_ipccall ( tcp ) ? 3 : 2 ] ) ;
1999-02-19 00:21:36 +00:00
}
return 0 ;
}
2009-10-08 23:33:15 +00:00
static void
2010-03-31 22:22:01 +00:00
tprint_msgsnd ( struct tcb * tcp , long addr , unsigned long count ,
unsigned long flags )
1999-02-19 00:21:36 +00:00
{
long mtype ;
2009-10-08 23:33:15 +00:00
if ( umove ( tcp , addr , & mtype ) < 0 ) {
tprintf ( " %#lx " , addr ) ;
} else {
tprintf ( " {%lu, " , mtype ) ;
printstr ( tcp , addr + sizeof ( mtype ) , count ) ;
2011-09-01 10:00:28 +02:00
tprints ( " } " ) ;
2009-10-08 23:33:15 +00:00
}
tprintf ( " , %lu, " , count ) ;
2010-03-31 22:22:01 +00:00
printflags ( msg_flags , flags , " MSG_??? " ) ;
2009-10-08 23:33:15 +00:00
}
int sys_msgsnd ( struct tcb * tcp )
{
1999-02-19 00:21:36 +00:00
if ( entering ( tcp ) ) {
2009-11-03 14:38:44 +00:00
tprintf ( " %d, " , ( int ) tcp - > u_arg [ 0 ] ) ;
2005-12-02 03:57:07 +00:00
if ( indirect_ipccall ( tcp ) ) {
2010-03-31 22:22:01 +00:00
tprint_msgsnd ( tcp , tcp - > u_arg [ 3 ] , tcp - > u_arg [ 1 ] ,
tcp - > u_arg [ 2 ] ) ;
2005-12-02 03:57:07 +00:00
} else {
2010-03-31 22:22:01 +00:00
tprint_msgsnd ( tcp , tcp - > u_arg [ 1 ] , tcp - > u_arg [ 2 ] ,
tcp - > u_arg [ 3 ] ) ;
2005-12-02 03:57:07 +00:00
}
1999-02-19 00:21:36 +00:00
}
return 0 ;
}
2009-11-03 14:38:44 +00:00
static void
tprint_msgrcv ( struct tcb * tcp , long addr , unsigned long count , long msgtyp )
1999-02-19 00:21:36 +00:00
{
long mtype ;
2009-11-03 14:38:44 +00:00
if ( syserror ( tcp ) | | umove ( tcp , addr , & mtype ) < 0 ) {
tprintf ( " %#lx " , addr ) ;
} else {
tprintf ( " {%lu, " , mtype ) ;
printstr ( tcp , addr + sizeof ( mtype ) , count ) ;
2011-09-01 10:00:28 +02:00
tprints ( " } " ) ;
2009-11-03 14:38:44 +00:00
}
tprintf ( " , %lu, %ld, " , count , msgtyp ) ;
}
int sys_msgrcv ( struct tcb * tcp )
{
2005-12-02 03:44:12 +00:00
if ( entering ( tcp ) ) {
2009-11-03 14:38:44 +00:00
tprintf ( " %d, " , ( int ) tcp - > u_arg [ 0 ] ) ;
2005-12-02 03:44:12 +00:00
} else {
2005-12-02 03:57:07 +00:00
if ( indirect_ipccall ( tcp ) ) {
struct ipc_wrapper {
struct msgbuf * msgp ;
long msgtyp ;
} tmp ;
2009-11-03 14:38:44 +00:00
if ( umove ( tcp , tcp - > u_arg [ 3 ] , & tmp ) < 0 ) {
tprintf ( " %#lx, %lu, " ,
tcp - > u_arg [ 3 ] , tcp - > u_arg [ 1 ] ) ;
} else {
tprint_msgrcv ( tcp , ( long ) tmp . msgp ,
tcp - > u_arg [ 1 ] , tmp . msgtyp ) ;
}
2005-12-02 03:57:07 +00:00
printflags ( msg_flags , tcp - > u_arg [ 2 ] , " MSG_??? " ) ;
} else {
2009-11-03 14:38:44 +00:00
tprint_msgrcv ( tcp , tcp - > u_arg [ 1 ] ,
tcp - > u_arg [ 2 ] , tcp - > u_arg [ 3 ] ) ;
2005-12-02 03:57:07 +00:00
printflags ( msg_flags , tcp - > u_arg [ 4 ] , " MSG_??? " ) ;
}
1999-02-19 00:21:36 +00:00
}
return 0 ;
}
2009-10-07 22:14:00 +00:00
static void
tprint_sembuf ( struct tcb * tcp , long addr , unsigned long count )
1999-02-19 00:21:36 +00:00
{
2009-10-07 22:14:00 +00:00
unsigned long i , max_count ;
if ( abbrev ( tcp ) )
max_count = ( max_strlen < count ) ? max_strlen : count ;
else
max_count = count ;
if ( ! max_count ) {
tprintf ( " %#lx, %lu " , addr , count ) ;
return ;
}
2011-06-07 12:13:24 +02:00
for ( i = 0 ; i < max_count ; + + i ) {
2009-10-07 22:14:00 +00:00
struct sembuf sb ;
if ( i )
2011-09-01 10:00:28 +02:00
tprints ( " , " ) ;
2009-10-07 22:14:00 +00:00
if ( umove ( tcp , addr + i * sizeof ( struct sembuf ) , & sb ) < 0 ) {
if ( i ) {
2011-09-01 10:00:28 +02:00
tprints ( " {???} " ) ;
2009-10-07 22:14:00 +00:00
break ;
} else {
tprintf ( " %#lx, %lu " , addr , count ) ;
return ;
}
} else {
if ( ! i )
2011-09-01 10:00:28 +02:00
tprints ( " { " ) ;
2009-10-07 22:14:00 +00:00
tprintf ( " {%u, %d, " , sb . sem_num , sb . sem_op ) ;
printflags ( semop_flags , sb . sem_flg , " SEM_??? " ) ;
2011-09-01 10:00:28 +02:00
tprints ( " } " ) ;
2009-10-07 22:14:00 +00:00
}
}
if ( i < max_count | | max_count < count )
2011-09-01 10:00:28 +02:00
tprints ( " , ... " ) ;
2009-10-07 22:25:10 +02:00
2009-10-07 22:14:00 +00:00
tprintf ( " }, %lu " , count ) ;
}
int sys_semop ( struct tcb * tcp )
{
1999-02-19 00:21:36 +00:00
if ( entering ( tcp ) ) {
2009-10-07 22:14:00 +00:00
tprintf ( " %lu, " , tcp - > u_arg [ 0 ] ) ;
2005-12-02 03:57:07 +00:00
if ( indirect_ipccall ( tcp ) ) {
2009-10-07 22:14:00 +00:00
tprint_sembuf ( tcp , tcp - > u_arg [ 3 ] , tcp - > u_arg [ 1 ] ) ;
2005-12-02 03:57:07 +00:00
} else {
2009-10-07 22:14:00 +00:00
tprint_sembuf ( tcp , tcp - > u_arg [ 1 ] , tcp - > u_arg [ 2 ] ) ;
2005-12-02 03:57:07 +00:00
}
1999-02-19 00:21:36 +00:00
}
return 0 ;
}
2003-04-08 01:46:48 +00:00
# ifdef LINUX
2009-10-07 22:14:00 +00:00
int sys_semtimedop ( struct tcb * tcp )
2003-04-08 01:46:48 +00:00
{
if ( entering ( tcp ) ) {
2009-10-07 22:14:00 +00:00
tprintf ( " %lu, " , tcp - > u_arg [ 0 ] ) ;
2006-04-25 07:22:01 +00:00
if ( indirect_ipccall ( tcp ) ) {
2009-10-07 22:14:00 +00:00
tprint_sembuf ( tcp , tcp - > u_arg [ 3 ] , tcp - > u_arg [ 1 ] ) ;
2011-09-01 10:00:28 +02:00
tprints ( " , " ) ;
2011-11-30 13:16:29 +01:00
# if defined(S390)
printtv ( tcp , tcp - > u_arg [ 2 ] ) ;
# else
2005-12-02 03:57:07 +00:00
printtv ( tcp , tcp - > u_arg [ 5 ] ) ;
2011-11-30 13:16:29 +01:00
# endif
2005-12-02 03:57:07 +00:00
} else {
2009-10-07 22:14:00 +00:00
tprint_sembuf ( tcp , tcp - > u_arg [ 1 ] , tcp - > u_arg [ 2 ] ) ;
2011-09-01 10:00:28 +02:00
tprints ( " , " ) ;
2005-12-02 03:57:07 +00:00
printtv ( tcp , tcp - > u_arg [ 3 ] ) ;
}
2003-04-08 01:46:48 +00:00
}
return 0 ;
}
# endif
2011-05-30 14:00:14 +02:00
int sys_semget ( struct tcb * tcp )
1999-02-19 00:21:36 +00:00
{
if ( entering ( tcp ) ) {
if ( tcp - > u_arg [ 0 ] )
2006-08-22 07:36:55 +00:00
tprintf ( " %#lx " , tcp - > u_arg [ 0 ] ) ;
1999-02-19 00:21:36 +00:00
else
2011-09-01 10:00:28 +02:00
tprints ( " IPC_PRIVATE " ) ;
1999-02-19 00:21:36 +00:00
tprintf ( " , %lu " , tcp - > u_arg [ 1 ] ) ;
2011-09-01 10:00:28 +02:00
tprints ( " , " ) ;
2005-05-31 Dmitry V. Levin <ldv@altlinux.org>
* util.c (printxval): Change third argument from "char *" to
"const char *".
(printflags): Add third argument, "const char *", with similar
meaning to the third argument of printxval().
* defs.h (printxval): Change third argument from "char *" to
"const char *".
(printflags): Add third argument.
* bjm.c (sys_query_module) [LINUX]: Pass third argument to
printflags().
* desc.c (sys_fcntl): Likewise.
(sys_flock) [LOCK_SH]: Likewise.
(print_epoll_event) [HAVE_SYS_EPOLL_H]: Likewise.
* file.c (sys_open): Likewise.
(solaris_open) [LINUXSPARC]: Likewise.
(sys_access): Likewise.
(sys_chflags, sys_fchflags) [FREEBSD]: Likewise.
(realprintstat) [HAVE_LONG_LONG_OFF_T &&
HAVE_STRUCT_STAT_ST_FLAGS]: Likewise.
(printstat64) [HAVE_STAT64 &&
HAVE_STRUCT_STAT_ST_FLAGS]: Likewise.
(sys_setxattr, sys_fsetxattr): Likewise.
* ipc.c (sys_msgget, sys_msgsnd, sys_msgrcv, sys_semget,
sys_shmget, sys_shmat) [LINUX || SUNOS4 || FREEBSD]: Likewise.
(sys_mq_open) [LINUX]: Likewise.
(printmqattr) [HAVE_MQUEUE_H]: Likewise.
* mem.c (print_mmap) [!HAVE_LONG_LONG_OFF_T]: Likewise.
(sys_mmap64) [_LFS64_LARGEFILE || HAVE_LONG_LONG_OFF_T]: Likewise.
(sys_mprotect): Likewise.
(sys_mremap, sys_madvise, sys_mlockall) [LINUX]: Likewise.
(sys_msync) [MS_ASYNC]: Likewise.
(sys_mctl) [MC_SYNC]: Likewise.
(sys_remap_file_pages, sys_mbind, sys_get_mempolicy) [LINUX]:
Likewise.
* net.c (printmsghdr) [HAVE_STRUCT_MSGHDR_MSG_CONTROL]: Likewise.
(sys_send, sys_sendto): Likewise.
(sys_sendmsg) [HAVE_SENDMSG]: Likewise.
(sys_recv, sys_recvfrom): Likewise.
(sys_recvmsg) [HAVE_SENDMSG]: Likewise.
(printicmpfilter) [ICMP_FILTER]: Likewise.
* proc.c (proc_ioctl) [SVR4 && !HAVE_MP_PROCFS || FREEBSD]: Likewise.
* process.c (sys_clone) [LINUX]: Likewise.
(printwaitn): Likewise.
(sys_waitid) [SVR4 || LINUX]: Likewise.
* signal.c (sys_sigvec) [SUNOS4 || FREEBSD]: Likewise.
(sys_sigaction): Likewise.
(printcontext) [SVR4]: Likewise.
(print_stack_t) [LINUX) || FREEBSD]: Likewise.
(sys_rt_sigaction) [LINUX]: Likewise.
* sock.c (sock_ioctl) [LINUX]: Likewise.
* stream.c (sys_putmsg, sys_getmsg): Likewise.
(sys_putpmsg) [SYS_putpmsg]: Likewise.
(sys_getpmsg) [SYS_getpmsg]: Likewise.
(sys_poll): Likewise.
(print_transport_message) [TI_BIND]: Likewise.
(stream_ioctl): Likewise.
* system.c (sys_mount, sys_reboot): Likewise.
(sys_cacheflush) [LINUX && M68K]: Likewise.
(sys_capget, sys_capset) [SYS_capget]: Likewise.
* term.c (term_ioctl) [TIOCMGET]: Likewise.
* time.c (sys_clock_nanosleep, sys_timer_settime) [LINUX]:
Likewise.
Fixes RH#159310.
2005-06-01 19:02:36 +00:00
if ( printflags ( resource_flags , tcp - > u_arg [ 2 ] & ~ 0777 , NULL ) ! = 0 )
2011-09-01 10:00:28 +02:00
tprints ( " | " ) ;
2003-07-17 09:03:04 +00:00
tprintf ( " %#lo " , tcp - > u_arg [ 2 ] & 0777 ) ;
1999-02-19 00:21:36 +00:00
}
return 0 ;
}
2011-05-30 14:00:14 +02:00
int sys_semctl ( struct tcb * tcp )
1999-02-19 00:21:36 +00:00
{
if ( entering ( tcp ) ) {
tprintf ( " %lu " , tcp - > u_arg [ 0 ] ) ;
tprintf ( " , %lu, " , tcp - > u_arg [ 1 ] ) ;
2003-01-14 09:46:17 +00:00
PRINTCTL ( semctl_flags , tcp - > u_arg [ 2 ] , " SEM_??? " ) ;
1999-02-19 00:21:36 +00:00
tprintf ( " , %#lx " , tcp - > u_arg [ 3 ] ) ;
}
return 0 ;
}
2011-05-30 14:00:14 +02:00
int sys_shmget ( struct tcb * tcp )
1999-02-19 00:21:36 +00:00
{
if ( entering ( tcp ) ) {
if ( tcp - > u_arg [ 0 ] )
2006-08-22 07:36:55 +00:00
tprintf ( " %#lx " , tcp - > u_arg [ 0 ] ) ;
1999-02-19 00:21:36 +00:00
else
2011-09-01 10:00:28 +02:00
tprints ( " IPC_PRIVATE " ) ;
1999-02-19 00:21:36 +00:00
tprintf ( " , %lu " , tcp - > u_arg [ 1 ] ) ;
2011-09-01 10:00:28 +02:00
tprints ( " , " ) ;
2005-05-31 Dmitry V. Levin <ldv@altlinux.org>
* util.c (printxval): Change third argument from "char *" to
"const char *".
(printflags): Add third argument, "const char *", with similar
meaning to the third argument of printxval().
* defs.h (printxval): Change third argument from "char *" to
"const char *".
(printflags): Add third argument.
* bjm.c (sys_query_module) [LINUX]: Pass third argument to
printflags().
* desc.c (sys_fcntl): Likewise.
(sys_flock) [LOCK_SH]: Likewise.
(print_epoll_event) [HAVE_SYS_EPOLL_H]: Likewise.
* file.c (sys_open): Likewise.
(solaris_open) [LINUXSPARC]: Likewise.
(sys_access): Likewise.
(sys_chflags, sys_fchflags) [FREEBSD]: Likewise.
(realprintstat) [HAVE_LONG_LONG_OFF_T &&
HAVE_STRUCT_STAT_ST_FLAGS]: Likewise.
(printstat64) [HAVE_STAT64 &&
HAVE_STRUCT_STAT_ST_FLAGS]: Likewise.
(sys_setxattr, sys_fsetxattr): Likewise.
* ipc.c (sys_msgget, sys_msgsnd, sys_msgrcv, sys_semget,
sys_shmget, sys_shmat) [LINUX || SUNOS4 || FREEBSD]: Likewise.
(sys_mq_open) [LINUX]: Likewise.
(printmqattr) [HAVE_MQUEUE_H]: Likewise.
* mem.c (print_mmap) [!HAVE_LONG_LONG_OFF_T]: Likewise.
(sys_mmap64) [_LFS64_LARGEFILE || HAVE_LONG_LONG_OFF_T]: Likewise.
(sys_mprotect): Likewise.
(sys_mremap, sys_madvise, sys_mlockall) [LINUX]: Likewise.
(sys_msync) [MS_ASYNC]: Likewise.
(sys_mctl) [MC_SYNC]: Likewise.
(sys_remap_file_pages, sys_mbind, sys_get_mempolicy) [LINUX]:
Likewise.
* net.c (printmsghdr) [HAVE_STRUCT_MSGHDR_MSG_CONTROL]: Likewise.
(sys_send, sys_sendto): Likewise.
(sys_sendmsg) [HAVE_SENDMSG]: Likewise.
(sys_recv, sys_recvfrom): Likewise.
(sys_recvmsg) [HAVE_SENDMSG]: Likewise.
(printicmpfilter) [ICMP_FILTER]: Likewise.
* proc.c (proc_ioctl) [SVR4 && !HAVE_MP_PROCFS || FREEBSD]: Likewise.
* process.c (sys_clone) [LINUX]: Likewise.
(printwaitn): Likewise.
(sys_waitid) [SVR4 || LINUX]: Likewise.
* signal.c (sys_sigvec) [SUNOS4 || FREEBSD]: Likewise.
(sys_sigaction): Likewise.
(printcontext) [SVR4]: Likewise.
(print_stack_t) [LINUX) || FREEBSD]: Likewise.
(sys_rt_sigaction) [LINUX]: Likewise.
* sock.c (sock_ioctl) [LINUX]: Likewise.
* stream.c (sys_putmsg, sys_getmsg): Likewise.
(sys_putpmsg) [SYS_putpmsg]: Likewise.
(sys_getpmsg) [SYS_getpmsg]: Likewise.
(sys_poll): Likewise.
(print_transport_message) [TI_BIND]: Likewise.
(stream_ioctl): Likewise.
* system.c (sys_mount, sys_reboot): Likewise.
(sys_cacheflush) [LINUX && M68K]: Likewise.
(sys_capget, sys_capset) [SYS_capget]: Likewise.
* term.c (term_ioctl) [TIOCMGET]: Likewise.
* time.c (sys_clock_nanosleep, sys_timer_settime) [LINUX]:
Likewise.
Fixes RH#159310.
2005-06-01 19:02:36 +00:00
if ( printflags ( shm_resource_flags , tcp - > u_arg [ 2 ] & ~ 0777 , NULL ) ! = 0 )
2011-09-01 10:00:28 +02:00
tprints ( " | " ) ;
2003-07-17 09:03:04 +00:00
tprintf ( " %#lo " , tcp - > u_arg [ 2 ] & 0777 ) ;
1999-02-19 00:21:36 +00:00
}
return 0 ;
}
2011-05-30 14:00:14 +02:00
int sys_shmctl ( struct tcb * tcp )
1999-02-19 00:21:36 +00:00
{
if ( entering ( tcp ) ) {
tprintf ( " %lu, " , tcp - > u_arg [ 0 ] ) ;
2003-01-14 09:46:17 +00:00
PRINTCTL ( shmctl_flags , tcp - > u_arg [ 1 ] , " SHM_??? " ) ;
2005-12-02 03:57:07 +00:00
if ( indirect_ipccall ( tcp ) ) {
tprintf ( " , %#lx " , tcp - > u_arg [ 3 ] ) ;
} else {
tprintf ( " , %#lx " , tcp - > u_arg [ 2 ] ) ;
}
1999-02-19 00:21:36 +00:00
}
return 0 ;
}
2011-05-30 14:00:14 +02:00
int sys_shmat ( struct tcb * tcp )
1999-02-19 00:21:36 +00:00
{
# ifdef LINUX
unsigned long raddr ;
# endif /* LINUX */
if ( exiting ( tcp ) ) {
tprintf ( " %lu " , tcp - > u_arg [ 0 ] ) ;
2005-12-02 03:57:07 +00:00
if ( indirect_ipccall ( tcp ) ) {
tprintf ( " , %#lx " , tcp - > u_arg [ 3 ] ) ;
2011-09-01 10:00:28 +02:00
tprints ( " , " ) ;
2005-12-02 03:57:07 +00:00
printflags ( shm_flags , tcp - > u_arg [ 1 ] , " SHM_??? " ) ;
} else {
tprintf ( " , %#lx " , tcp - > u_arg [ 1 ] ) ;
2011-09-01 10:00:28 +02:00
tprints ( " , " ) ;
2005-12-02 03:57:07 +00:00
printflags ( shm_flags , tcp - > u_arg [ 2 ] , " SHM_??? " ) ;
}
1999-02-19 00:21:36 +00:00
if ( syserror ( tcp ) )
return 0 ;
2009-10-05 23:31:54 +00:00
/* HPPA does not use an IPC multiplexer on Linux. */
# if defined(LINUX) && !defined(HPPA)
1999-02-19 00:21:36 +00:00
if ( umove ( tcp , tcp - > u_arg [ 2 ] , & raddr ) < 0 )
return RVAL_NONE ;
tcp - > u_rval = raddr ;
# endif /* LINUX */
return RVAL_HEX ;
}
return 0 ;
}
2011-05-30 14:00:14 +02:00
int sys_shmdt ( struct tcb * tcp )
1999-02-19 00:21:36 +00:00
{
2005-12-02 03:57:07 +00:00
if ( entering ( tcp ) ) {
if ( indirect_ipccall ( tcp ) ) {
tprintf ( " %#lx " , tcp - > u_arg [ 3 ] ) ;
} else {
tprintf ( " %#lx " , tcp - > u_arg [ 0 ] ) ;
}
}
1999-02-19 00:21:36 +00:00
return 0 ;
}
2000-09-01 21:03:06 +00:00
# endif /* defined(LINUX) || defined(SUNOS4) || defined(FREEBSD) */
2004-04-16 21:48:40 +00:00
# ifdef LINUX
2007-01-11 23:19:55 +00:00
int
sys_mq_open ( struct tcb * tcp )
2004-04-16 21:48:40 +00:00
{
if ( entering ( tcp ) ) {
printpath ( tcp , tcp - > u_arg [ 0 ] ) ;
2011-09-01 10:00:28 +02:00
tprints ( " , " ) ;
2004-04-16 21:48:40 +00:00
/* flags */
2009-03-10 20:41:58 +00:00
tprint_open_modes ( tcp - > u_arg [ 1 ] ) ;
2004-04-16 21:48:40 +00:00
if ( tcp - > u_arg [ 1 ] & O_CREAT ) {
# ifndef HAVE_MQUEUE_H
tprintf ( " , %lx " , tcp - > u_arg [ 2 ] ) ;
# else
struct mq_attr attr ;
/* mode */
tprintf ( " , %#lo, " , tcp - > u_arg [ 2 ] ) ;
if ( umove ( tcp , tcp - > u_arg [ 3 ] , & attr ) < 0 )
2011-09-01 10:00:28 +02:00
tprints ( " { ??? } " ) ;
2004-04-16 21:48:40 +00:00
else
tprintf ( " {mq_maxmsg=%ld, mq_msgsize=%ld} " ,
attr . mq_maxmsg , attr . mq_msgsize ) ;
# endif
}
}
return 0 ;
}
2007-01-11 23:19:55 +00:00
int
sys_mq_timedsend ( struct tcb * tcp )
2004-04-16 21:48:40 +00:00
{
if ( entering ( tcp ) ) {
tprintf ( " %ld, " , tcp - > u_arg [ 0 ] ) ;
printstr ( tcp , tcp - > u_arg [ 1 ] , tcp - > u_arg [ 2 ] ) ;
tprintf ( " , %lu, %ld, " , tcp - > u_arg [ 2 ] , tcp - > u_arg [ 3 ] ) ;
printtv ( tcp , tcp - > u_arg [ 4 ] ) ;
}
return 0 ;
}
2007-01-11 23:19:55 +00:00
int
sys_mq_timedreceive ( struct tcb * tcp )
2004-04-16 21:48:40 +00:00
{
if ( entering ( tcp ) )
tprintf ( " %ld, " , tcp - > u_arg [ 0 ] ) ;
else {
printstr ( tcp , tcp - > u_arg [ 1 ] , tcp - > u_arg [ 2 ] ) ;
tprintf ( " , %lu, %ld, " , tcp - > u_arg [ 2 ] , tcp - > u_arg [ 3 ] ) ;
printtv ( tcp , tcp - > u_arg [ 4 ] ) ;
}
return 0 ;
}
2007-01-11 23:19:55 +00:00
int
sys_mq_notify ( struct tcb * tcp )
2004-04-16 21:48:40 +00:00
{
if ( entering ( tcp ) ) {
tprintf ( " %ld, " , tcp - > u_arg [ 0 ] ) ;
printsigevent ( tcp , tcp - > u_arg [ 1 ] ) ;
}
return 0 ;
}
2007-01-11 23:19:55 +00:00
static void
printmqattr ( struct tcb * tcp , long addr )
2004-04-16 21:48:40 +00:00
{
if ( addr = = 0 )
2011-09-01 10:00:28 +02:00
tprints ( " NULL " ) ;
2004-04-16 21:48:40 +00:00
else {
# ifndef HAVE_MQUEUE_H
tprintf ( " %#lx " , addr ) ;
# else
struct mq_attr attr ;
if ( umove ( tcp , addr , & attr ) < 0 ) {
2011-09-01 10:00:28 +02:00
tprints ( " {...} " ) ;
2004-04-16 21:48:40 +00:00
return ;
}
2011-09-01 10:00:28 +02:00
tprints ( " {mq_flags= " ) ;
2009-03-10 20:41:58 +00:00
tprint_open_modes ( attr . mq_flags ) ;
2004-04-16 21:48:40 +00:00
tprintf ( " , mq_maxmsg=%ld, mq_msgsize=%ld, mq_curmsg=%ld} " ,
attr . mq_maxmsg , attr . mq_msgsize , attr . mq_curmsgs ) ;
# endif
}
}
2007-01-11 23:19:55 +00:00
int
sys_mq_getsetattr ( struct tcb * tcp )
2004-04-16 21:48:40 +00:00
{
if ( entering ( tcp ) ) {
tprintf ( " %ld, " , tcp - > u_arg [ 0 ] ) ;
printmqattr ( tcp , tcp - > u_arg [ 1 ] ) ;
2011-09-01 10:00:28 +02:00
tprints ( " , " ) ;
2004-04-16 21:48:40 +00:00
} else
printmqattr ( tcp , tcp - > u_arg [ 2 ] ) ;
return 0 ;
}
# endif