1999-02-19 00:21:36 +00:00
/*
* Copyright ( c ) 1991 , 1992 Paul Kranenburg < pk @ cs . few . eur . nl >
* Copyright ( c ) 1993 Branko Lankester < branko @ hacktic . nl >
* Copyright ( c ) 1993 , 1994 , 1995 , 1996 Rick Sladkey < jrs @ world . std . com >
2000-07-05 16:05:39 +00:00
* Copyright ( c ) 1996 - 2000 Wichert Akkerman < wichert @ cistron . nl >
2017-05-22 19:14:52 +02:00
* Copyright ( c ) 1999 - 2017 The strace developers .
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 .
*/
# include "defs.h"
2017-07-08 14:57:44 +00:00
# include "print_fields.h"
1999-02-19 00:21:36 +00:00
# include <sys/stat.h>
# include <sys/socket.h>
2014-11-21 20:46:16 +00:00
# include <sys/uio.h>
1999-02-19 00:21:36 +00:00
# include <sys/un.h>
# include <netinet/in.h>
2001-02-16 19:59:55 +00:00
# ifdef HAVE_NETINET_TCP_H
2012-03-16 12:02:22 +01:00
# include <netinet / tcp.h>
2000-09-01 21:03:06 +00:00
# endif
2001-02-16 19:59:55 +00:00
# ifdef HAVE_NETINET_UDP_H
2012-03-16 12:02:22 +01:00
# include <netinet / udp.h>
2001-02-16 19:59:55 +00:00
# endif
2011-01-14 11:08:12 +01:00
# ifdef HAVE_NETINET_SCTP_H
2012-03-16 12:02:22 +01:00
# include <netinet / sctp.h>
2011-01-14 11:08:12 +01:00
# endif
1999-02-19 00:21:36 +00:00
# include <arpa/inet.h>
2001-02-16 20:29:03 +00:00
# include <net/if.h>
1999-02-19 00:21:36 +00:00
# include <asm/types.h>
2016-06-19 22:02:45 +00:00
# ifdef HAVE_NETIPX_IPX_H
2012-03-16 12:02:22 +01:00
# include <netipx / ipx.h>
1999-02-19 00:21:36 +00:00
# else
2012-03-16 12:02:22 +01:00
# include <linux / ipx.h>
1999-02-19 00:21:36 +00:00
# endif
decode extend getsockopt/setsockopt options
Currently the code assumes the set of valid options between getsockopt
and setsockopt are exactly the same and thus maintains one list. The
kernel unfortunately does not do this -- it allows for different opts
between the get and set functions. See the {g,s}et_opt{min,max} fields
in the various netfilter subcores.
To support this, extend the printxval function to take multiple sets of
xlats as varargs. Then we add the new get/set lists, and pass them down
in the net code when decoding things.
A simple example is iptables; before:
getsockopt(4, SOL_IP, 0x40 /* IP_??? */, ...) = 0
getsockopt(4, SOL_IP, 0x41 /* IP_??? */, ...) = 0
after:
getsockopt(4, SOL_IP, IPT_SO_GET_INFO, ...) = 0
getsockopt(4, SOL_IP, IPT_SO_GET_ENTRIES, ...) = 0
If these were setsockopt calls, then 0x40 & 0x41 would be
IPT_SO_SET_REPLACE & IPT_SO_SET_ADD_COUNTERS.
* configure.ac: Check for netfilter headers.
* defs.h (printxvals): New prototype.
(printxval): Change to a define.
* net.c: Include netfilter headers and new sockopts headers.
(print_sockopt_fd_level_name): Add a is_getsockopt argument. Change SOL_IP
and SOL_IPV6 decoding to use printxvals, and use is_getsockopt to pass more
xlats down.
(getsockopt): Call print_sockopt_fd_level_name with is_getsockopt as true.
(setsockopt): Call print_sockopt_fd_level_name with is_getsockopt as false.
* util.c (printxval): Rename to ...
(printxvals): ... this. Rewrite to be varargs based.
* xlat/getsockipoptions.in: New xlat list.
* xlat/getsockipv6options.in, xlat/setsockipoptions.in,
xlat/setsockipv6options.in: Likewise.
2015-08-19 13:29:27 -04:00
# if defined(HAVE_LINUX_IP_VS_H)
# include <linux / ip_vs.h>
# endif
2017-06-25 00:40:29 +00:00
# include "netlink.h"
decode extend getsockopt/setsockopt options
Currently the code assumes the set of valid options between getsockopt
and setsockopt are exactly the same and thus maintains one list. The
kernel unfortunately does not do this -- it allows for different opts
between the get and set functions. See the {g,s}et_opt{min,max} fields
in the various netfilter subcores.
To support this, extend the printxval function to take multiple sets of
xlats as varargs. Then we add the new get/set lists, and pass them down
in the net code when decoding things.
A simple example is iptables; before:
getsockopt(4, SOL_IP, 0x40 /* IP_??? */, ...) = 0
getsockopt(4, SOL_IP, 0x41 /* IP_??? */, ...) = 0
after:
getsockopt(4, SOL_IP, IPT_SO_GET_INFO, ...) = 0
getsockopt(4, SOL_IP, IPT_SO_GET_ENTRIES, ...) = 0
If these were setsockopt calls, then 0x40 & 0x41 would be
IPT_SO_SET_REPLACE & IPT_SO_SET_ADD_COUNTERS.
* configure.ac: Check for netfilter headers.
* defs.h (printxvals): New prototype.
(printxval): Change to a define.
* net.c: Include netfilter headers and new sockopts headers.
(print_sockopt_fd_level_name): Add a is_getsockopt argument. Change SOL_IP
and SOL_IPV6 decoding to use printxvals, and use is_getsockopt to pass more
xlats down.
(getsockopt): Call print_sockopt_fd_level_name with is_getsockopt as true.
(setsockopt): Call print_sockopt_fd_level_name with is_getsockopt as false.
* util.c (printxval): Rename to ...
(printxvals): ... this. Rewrite to be varargs based.
* xlat/getsockipoptions.in: New xlat list.
* xlat/getsockipv6options.in, xlat/setsockipoptions.in,
xlat/setsockipv6options.in: Likewise.
2015-08-19 13:29:27 -04:00
# if defined(HAVE_LINUX_NETFILTER_ARP_ARP_TABLES_H)
# include <linux / netfilter_arp / arp_tables.h>
# endif
# if defined(HAVE_LINUX_NETFILTER_BRIDGE_EBTABLES_H)
# include <linux / netfilter_bridge / ebtables.h>
# endif
# if defined(HAVE_LINUX_NETFILTER_IPV4_IP_TABLES_H)
# include <linux / netfilter_ipv4 / ip_tables.h>
# endif
# if defined(HAVE_LINUX_NETFILTER_IPV6_IP6_TABLES_H)
# include <linux / netfilter_ipv6 / ip6_tables.h>
# endif
2016-06-15 21:35:48 +00:00
# include <linux/if_packet.h>
2016-06-15 21:27:41 +00:00
# include <linux/icmp.h>
1999-02-19 00:21:36 +00:00
2014-04-25 23:30:54 +00:00
# include "xlat/socktypes.h"
# include "xlat/sock_type_flags.h"
2008-11-10 17:21:23 +00:00
# ifndef SOCK_TYPE_MASK
# define SOCK_TYPE_MASK 0xf
# endif
2015-01-29 04:42:37 +00:00
2014-04-25 23:30:54 +00:00
# include "xlat/socketlayers.h"
2015-01-29 04:42:37 +00:00
2014-04-25 23:30:54 +00:00
# include "xlat/inet_protocols.h"
2014-03-11 23:37:37 +09:00
2016-06-25 13:47:54 +00:00
# ifdef HAVE_BLUETOOTH_BLUETOOTH_H
# include <bluetooth / bluetooth.h>
2014-10-03 11:40:28 +02:00
# include "xlat / bt_protocols.h"
# endif
2016-07-06 15:49:22 +00:00
static void
2016-12-26 10:26:03 +00:00
decode_sockbuf ( struct tcb * const tcp , const int fd , const kernel_ulong_t addr ,
const kernel_ulong_t addrlen )
2016-07-06 15:49:22 +00:00
{
switch ( verbose ( tcp ) ? getfdproto ( tcp , fd ) : SOCK_PROTO_UNKNOWN ) {
case SOCK_PROTO_NETLINK :
2016-07-11 12:54:59 +00:00
decode_netlink ( tcp , fd , addr , addrlen ) ;
2016-07-06 15:49:22 +00:00
break ;
default :
2016-12-20 16:43:26 +00:00
printstrn ( tcp , addr , addrlen ) ;
2016-07-06 15:49:22 +00:00
}
}
2008-11-10 17:21:23 +00:00
/*
* low bits of the socket type define real socket type ,
* other bits are socket type flags .
*/
static void
2016-05-14 21:46:05 +00:00
tprint_sock_type ( unsigned int flags )
2008-11-10 17:21:23 +00:00
{
const char * str = xlookup ( socktypes , flags & SOCK_TYPE_MASK ) ;
2011-06-22 14:32:43 +02:00
if ( str ) {
2011-09-01 09:55:05 +02:00
tprints ( str ) ;
2008-11-10 17:21:23 +00:00
flags & = ~ SOCK_TYPE_MASK ;
if ( ! flags )
return ;
2011-09-01 10:00:28 +02:00
tprints ( " | " ) ;
2008-11-10 17:21:23 +00:00
}
printflags ( sock_type_flags , flags , " SOCK_??? " ) ;
}
2015-04-07 01:36:50 +00:00
SYS_FUNC ( socket )
1999-02-19 00:21:36 +00:00
{
2016-04-04 01:35:28 +00:00
printxval ( addrfams , tcp - > u_arg [ 0 ] , " AF_??? " ) ;
2015-07-19 22:52:47 +00:00
tprints ( " , " ) ;
tprint_sock_type ( tcp - > u_arg [ 1 ] ) ;
tprints ( " , " ) ;
switch ( tcp - > u_arg [ 0 ] ) {
2016-04-04 01:35:28 +00:00
case AF_INET :
case AF_INET6 :
2015-07-19 22:52:47 +00:00
printxval ( inet_protocols , tcp - > u_arg [ 2 ] , " IPPROTO_??? " ) ;
break ;
2016-06-19 22:02:45 +00:00
2016-04-04 01:35:28 +00:00
case AF_NETLINK :
2015-07-19 22:52:47 +00:00
printxval ( netlink_protocols , tcp - > u_arg [ 2 ] , " NETLINK_??? " ) ;
break ;
2016-06-19 22:02:45 +00:00
2016-06-21 16:43:30 +00:00
# ifdef HAVE_BLUETOOTH_BLUETOOTH_H
2016-04-04 01:35:28 +00:00
case AF_BLUETOOTH :
2015-07-19 22:52:47 +00:00
printxval ( bt_protocols , tcp - > u_arg [ 2 ] , " BTPROTO_??? " ) ;
break ;
2014-03-11 23:37:37 +09:00
# endif
2016-06-19 22:02:45 +00:00
2015-07-19 22:52:47 +00:00
default :
2016-12-26 10:16:35 +00:00
tprintf ( " % " PRI_klu , tcp - > u_arg [ 2 ] ) ;
2015-07-19 22:52:47 +00:00
break ;
1999-02-19 00:21:36 +00:00
}
2015-07-19 22:52:47 +00:00
2015-08-02 01:41:26 +00:00
return RVAL_DECODED | RVAL_FD ;
1999-02-19 00:21:36 +00:00
}
2016-07-09 21:52:43 +00:00
static bool
2016-12-23 10:47:36 +00:00
fetch_socklen ( struct tcb * const tcp , int * const plen ,
2016-12-26 10:26:03 +00:00
const kernel_ulong_t sockaddr , const kernel_ulong_t socklen )
2016-07-09 21:52:43 +00:00
{
return verbose ( tcp ) & & sockaddr & & socklen
& & umove ( tcp , socklen , plen ) = = 0 ;
}
2009-08-14 12:34:05 +02:00
static int
2016-07-09 21:52:34 +00:00
decode_sockname ( struct tcb * tcp )
1999-02-19 00:21:36 +00:00
{
2016-07-09 21:52:43 +00:00
int ulen , rlen ;
1999-02-19 00:21:36 +00:00
if ( entering ( tcp ) ) {
Add decoding of sockets descriptor 'paths' for network calls
* net.c (sys_bind, sys_listen, do_accept, sys_send, sys_sendto,
sys_sendmsg, sys_sendmmsg, sys_recv, sys_recvfrom, sys_recvmsg,
sys_recvmmsg, sys_shutdown, sys_getsockopt, sys_setsockopt): Decode
socket descriptor arguments using printfd.
* pathtrace.c (pathtrace_match): Also check TRACE_NETWORK syscalls
that take socket descriptor arguments.
* tests/net-fd.test: New test for socket descriptor arguments decoding.
* tests/Makefile.am (TESTS): Add net-fd.test.
(net-fd.log): New dependency on net.log.
Signed-off-by: Philippe Ombredanne <pombredanne@nexb.com>
Signed-off-by: Dmitry V. Levin <ldv@altlinux.org>
2014-02-01 09:57:45 -08:00
printfd ( tcp , tcp - > u_arg [ 0 ] ) ;
tprints ( " , " ) ;
2016-07-09 21:52:43 +00:00
if ( fetch_socklen ( tcp , & ulen , tcp - > u_arg [ 1 ] , tcp - > u_arg [ 2 ] ) ) {
2016-07-15 16:08:19 +00:00
set_tcb_priv_ulong ( tcp , ulen ) ;
2016-07-09 21:52:43 +00:00
return 0 ;
} else {
printaddr ( tcp - > u_arg [ 1 ] ) ;
tprints ( " , " ) ;
printaddr ( tcp - > u_arg [ 2 ] ) ;
return RVAL_DECODED ;
}
2009-08-14 12:34:05 +02:00
}
net.c: use printaddr and umove_or_printaddr
* net.c (printsock): Use printaddr and umove_or_printaddr.
(printcmsghdr, printmsghdr, printmmsghdr, decode_mmsg, do_sockname,
sys_recv, sys_recvfrom, sys_recvmsg, do_pipe, print_linger, print_ucred,
print_tpacket_stats, print_icmp_filter, print_getsockopt,
print_group_req, print_tpacket_req, print_packet_mreq,
print_setsockopt): Use printaddr.
(print_mreq, print_mreq6): Use umove_or_printaddr.
2015-07-19 22:36:46 +00:00
2016-07-15 16:08:19 +00:00
ulen = get_tcb_priv_ulong ( tcp ) ;
2016-07-09 21:52:43 +00:00
if ( syserror ( tcp ) | | umove ( tcp , tcp - > u_arg [ 2 ] , & rlen ) < 0 ) {
net.c: use printaddr and umove_or_printaddr
* net.c (printsock): Use printaddr and umove_or_printaddr.
(printcmsghdr, printmsghdr, printmmsghdr, decode_mmsg, do_sockname,
sys_recv, sys_recvfrom, sys_recvmsg, do_pipe, print_linger, print_ucred,
print_tpacket_stats, print_icmp_filter, print_getsockopt,
print_group_req, print_tpacket_req, print_packet_mreq,
print_setsockopt): Use printaddr.
(print_mreq, print_mreq6): Use umove_or_printaddr.
2015-07-19 22:36:46 +00:00
printaddr ( tcp - > u_arg [ 1 ] ) ;
2016-07-09 21:52:43 +00:00
tprintf ( " , [%d] " , ulen ) ;
net.c: use printaddr and umove_or_printaddr
* net.c (printsock): Use printaddr and umove_or_printaddr.
(printcmsghdr, printmsghdr, printmmsghdr, decode_mmsg, do_sockname,
sys_recv, sys_recvfrom, sys_recvmsg, do_pipe, print_linger, print_ucred,
print_tpacket_stats, print_icmp_filter, print_getsockopt,
print_group_req, print_tpacket_req, print_packet_mreq,
print_setsockopt): Use printaddr.
(print_mreq, print_mreq6): Use umove_or_printaddr.
2015-07-19 22:36:46 +00:00
} else {
2016-07-09 21:52:43 +00:00
decode_sockaddr ( tcp , tcp - > u_arg [ 1 ] , ulen > rlen ? rlen : ulen ) ;
2016-07-09 21:52:58 +00:00
if ( ulen ! = rlen )
2016-07-09 21:52:51 +00:00
tprintf ( " , [%d->%d] " , ulen , rlen ) ;
else
tprintf ( " , [%d] " , rlen ) ;
1999-02-19 00:21:36 +00:00
}
net.c: use printaddr and umove_or_printaddr
* net.c (printsock): Use printaddr and umove_or_printaddr.
(printcmsghdr, printmsghdr, printmmsghdr, decode_mmsg, do_sockname,
sys_recv, sys_recvfrom, sys_recvmsg, do_pipe, print_linger, print_ucred,
print_tpacket_stats, print_icmp_filter, print_getsockopt,
print_group_req, print_tpacket_req, print_packet_mreq,
print_setsockopt): Use printaddr.
(print_mreq, print_mreq6): Use umove_or_printaddr.
2015-07-19 22:36:46 +00:00
2016-07-09 21:52:34 +00:00
return RVAL_DECODED ;
1999-02-19 00:21:36 +00:00
}
2015-04-07 01:36:50 +00:00
SYS_FUNC ( accept )
2009-08-14 12:34:05 +02:00
{
2016-07-09 21:52:34 +00:00
return decode_sockname ( tcp ) | RVAL_FD ;
2009-08-14 12:34:05 +02:00
}
2015-04-07 01:36:50 +00:00
SYS_FUNC ( accept4 )
2009-08-14 12:34:05 +02:00
{
2016-07-09 21:52:34 +00:00
int rc = decode_sockname ( tcp ) ;
if ( rc & RVAL_DECODED ) {
tprints ( " , " ) ;
printflags ( sock_type_flags , tcp - > u_arg [ 3 ] , " SOCK_??? " ) ;
}
return rc | RVAL_FD ;
2009-08-14 12:34:05 +02:00
}
2015-04-07 01:36:50 +00:00
SYS_FUNC ( send )
1999-02-19 00:21:36 +00:00
{
2015-07-19 22:52:47 +00:00
printfd ( tcp , tcp - > u_arg [ 0 ] ) ;
tprints ( " , " ) ;
2016-07-06 15:49:22 +00:00
decode_sockbuf ( tcp , tcp - > u_arg [ 0 ] , tcp - > u_arg [ 1 ] , tcp - > u_arg [ 2 ] ) ;
2016-12-26 10:16:35 +00:00
tprintf ( " , % " PRI_klu " , " , tcp - > u_arg [ 2 ] ) ;
2015-07-19 22:52:47 +00:00
/* flags */
printflags ( msg_flags , tcp - > u_arg [ 3 ] , " MSG_??? " ) ;
return RVAL_DECODED ;
1999-02-19 00:21:36 +00:00
}
2015-04-07 01:36:50 +00:00
SYS_FUNC ( sendto )
1999-02-19 00:21:36 +00:00
{
2015-07-19 22:52:47 +00:00
printfd ( tcp , tcp - > u_arg [ 0 ] ) ;
tprints ( " , " ) ;
2016-07-06 15:49:22 +00:00
decode_sockbuf ( tcp , tcp - > u_arg [ 0 ] , tcp - > u_arg [ 1 ] , tcp - > u_arg [ 2 ] ) ;
2016-12-26 10:16:35 +00:00
tprintf ( " , % " PRI_klu " , " , tcp - > u_arg [ 2 ] ) ;
2015-07-19 22:52:47 +00:00
/* flags */
printflags ( msg_flags , tcp - > u_arg [ 3 ] , " MSG_??? " ) ;
/* to address */
2016-07-12 09:17:30 +00:00
const int addrlen = tcp - > u_arg [ 5 ] ;
2015-07-19 22:52:47 +00:00
tprints ( " , " ) ;
2016-07-12 09:17:30 +00:00
decode_sockaddr ( tcp , tcp - > u_arg [ 4 ] , addrlen ) ;
2015-07-19 22:52:47 +00:00
/* to length */
2016-07-12 09:17:30 +00:00
tprintf ( " , %d " , addrlen ) ;
2015-07-19 22:52:47 +00:00
return RVAL_DECODED ;
1999-02-19 00:21:36 +00:00
}
2015-04-07 01:36:50 +00:00
SYS_FUNC ( recv )
1999-02-19 00:21:36 +00:00
{
if ( entering ( tcp ) ) {
Add decoding of sockets descriptor 'paths' for network calls
* net.c (sys_bind, sys_listen, do_accept, sys_send, sys_sendto,
sys_sendmsg, sys_sendmmsg, sys_recv, sys_recvfrom, sys_recvmsg,
sys_recvmmsg, sys_shutdown, sys_getsockopt, sys_setsockopt): Decode
socket descriptor arguments using printfd.
* pathtrace.c (pathtrace_match): Also check TRACE_NETWORK syscalls
that take socket descriptor arguments.
* tests/net-fd.test: New test for socket descriptor arguments decoding.
* tests/Makefile.am (TESTS): Add net-fd.test.
(net-fd.log): New dependency on net.log.
Signed-off-by: Philippe Ombredanne <pombredanne@nexb.com>
Signed-off-by: Dmitry V. Levin <ldv@altlinux.org>
2014-02-01 09:57:45 -08:00
printfd ( tcp , tcp - > u_arg [ 0 ] ) ;
tprints ( " , " ) ;
1999-02-19 00:21:36 +00:00
} else {
2016-07-06 15:49:22 +00:00
if ( syserror ( tcp ) ) {
net.c: use printaddr and umove_or_printaddr
* net.c (printsock): Use printaddr and umove_or_printaddr.
(printcmsghdr, printmsghdr, printmmsghdr, decode_mmsg, do_sockname,
sys_recv, sys_recvfrom, sys_recvmsg, do_pipe, print_linger, print_ucred,
print_tpacket_stats, print_icmp_filter, print_getsockopt,
print_group_req, print_tpacket_req, print_packet_mreq,
print_setsockopt): Use printaddr.
(print_mreq, print_mreq6): Use umove_or_printaddr.
2015-07-19 22:36:46 +00:00
printaddr ( tcp - > u_arg [ 1 ] ) ;
2016-07-06 15:49:22 +00:00
} else {
decode_sockbuf ( tcp , tcp - > u_arg [ 0 ] , tcp - > u_arg [ 1 ] ,
tcp - > u_rval ) ;
}
1999-02-19 00:21:36 +00:00
2016-12-26 10:16:35 +00:00
tprintf ( " , % " PRI_klu " , " , tcp - > u_arg [ 2 ] ) ;
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
printflags ( msg_flags , tcp - > u_arg [ 3 ] , " MSG_??? " ) ;
1999-02-19 00:21:36 +00:00
}
return 0 ;
}
2015-04-07 01:36:50 +00:00
SYS_FUNC ( recvfrom )
1999-02-19 00:21:36 +00:00
{
2016-07-12 07:46:19 +00:00
int ulen , rlen ;
1999-02-19 00:21:36 +00:00
if ( entering ( tcp ) ) {
Add decoding of sockets descriptor 'paths' for network calls
* net.c (sys_bind, sys_listen, do_accept, sys_send, sys_sendto,
sys_sendmsg, sys_sendmmsg, sys_recv, sys_recvfrom, sys_recvmsg,
sys_recvmmsg, sys_shutdown, sys_getsockopt, sys_setsockopt): Decode
socket descriptor arguments using printfd.
* pathtrace.c (pathtrace_match): Also check TRACE_NETWORK syscalls
that take socket descriptor arguments.
* tests/net-fd.test: New test for socket descriptor arguments decoding.
* tests/Makefile.am (TESTS): Add net-fd.test.
(net-fd.log): New dependency on net.log.
Signed-off-by: Philippe Ombredanne <pombredanne@nexb.com>
Signed-off-by: Dmitry V. Levin <ldv@altlinux.org>
2014-02-01 09:57:45 -08:00
printfd ( tcp , tcp - > u_arg [ 0 ] ) ;
tprints ( " , " ) ;
2016-07-12 07:46:19 +00:00
if ( fetch_socklen ( tcp , & ulen , tcp - > u_arg [ 4 ] , tcp - > u_arg [ 5 ] ) ) {
2016-07-15 16:08:19 +00:00
set_tcb_priv_ulong ( tcp , ulen ) ;
2016-07-12 07:46:19 +00:00
}
1999-02-19 00:21:36 +00:00
} else {
net.c: recvfrom fixes
This change fixes these three problems (before/after is shown):
On interrupted syscall, flags are not decoded:
-recvfrom(3, 0x7fff0a41e306, 10, 2, 0, 0) = ? ERESTARTSYS
+recvfrom(3, 0x7fff0a41e306, 10, MSG_PEEK, 0, 0) = ? ERESTARTSYS
If peer address is unavalable (example: anon sockets from socketpair()),
kernel returns socklen of 0, but we ignore that and show bogus sockaddr data:
-recvfrom(3, "123456789\0", 10, MSG_PEEK, {sa_family=0x7777 /* AF_??? */, sa_data="wwwwwwwwwwwwww"}, [0]) = 10
+recvfrom(3, "123456789\0", 10, MSG_PEEK, 0x7ffde6edf760, [0]) = 10
SYS_FUNC(recvfrom) passes address of fromlen, not fromlen, to printsock():
- printsock(tcp, tcp->u_arg[4], tcp->u_arg[5]);
+ printsock(tcp, tcp->u_arg[4], fromlen);
Signed-off-by: Denys Vlasenko <dvlasenk@redhat.com>
2015-07-30 13:29:20 +02:00
/* buf */
1999-02-19 00:21:36 +00:00
if ( syserror ( tcp ) ) {
2015-07-30 13:53:42 +00:00
printaddr ( tcp - > u_arg [ 1 ] ) ;
net.c: recvfrom fixes
This change fixes these three problems (before/after is shown):
On interrupted syscall, flags are not decoded:
-recvfrom(3, 0x7fff0a41e306, 10, 2, 0, 0) = ? ERESTARTSYS
+recvfrom(3, 0x7fff0a41e306, 10, MSG_PEEK, 0, 0) = ? ERESTARTSYS
If peer address is unavalable (example: anon sockets from socketpair()),
kernel returns socklen of 0, but we ignore that and show bogus sockaddr data:
-recvfrom(3, "123456789\0", 10, MSG_PEEK, {sa_family=0x7777 /* AF_??? */, sa_data="wwwwwwwwwwwwww"}, [0]) = 10
+recvfrom(3, "123456789\0", 10, MSG_PEEK, 0x7ffde6edf760, [0]) = 10
SYS_FUNC(recvfrom) passes address of fromlen, not fromlen, to printsock():
- printsock(tcp, tcp->u_arg[4], tcp->u_arg[5]);
+ printsock(tcp, tcp->u_arg[4], fromlen);
Signed-off-by: Denys Vlasenko <dvlasenk@redhat.com>
2015-07-30 13:29:20 +02:00
} else {
2016-07-06 15:49:22 +00:00
decode_sockbuf ( tcp , tcp - > u_arg [ 0 ] , tcp - > u_arg [ 1 ] ,
tcp - > u_rval ) ;
1999-02-19 00:21:36 +00:00
}
2016-07-12 07:46:19 +00:00
/* size */
2016-12-26 10:16:35 +00:00
tprintf ( " , % " PRI_klu " , " , tcp - > u_arg [ 2 ] ) ;
1999-02-19 00:21:36 +00:00
/* flags */
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
printflags ( msg_flags , tcp - > u_arg [ 3 ] , " MSG_??? " ) ;
net.c: use printaddr and umove_or_printaddr
* net.c (printsock): Use printaddr and umove_or_printaddr.
(printcmsghdr, printmsghdr, printmmsghdr, decode_mmsg, do_sockname,
sys_recv, sys_recvfrom, sys_recvmsg, do_pipe, print_linger, print_ucred,
print_tpacket_stats, print_icmp_filter, print_getsockopt,
print_group_req, print_tpacket_req, print_packet_mreq,
print_setsockopt): Use printaddr.
(print_mreq, print_mreq6): Use umove_or_printaddr.
2015-07-19 22:36:46 +00:00
tprints ( " , " ) ;
2016-07-12 07:46:19 +00:00
2016-07-15 16:08:19 +00:00
ulen = get_tcb_priv_ulong ( tcp ) ;
2016-07-12 07:46:19 +00:00
if ( ! fetch_socklen ( tcp , & rlen , tcp - > u_arg [ 4 ] , tcp - > u_arg [ 5 ] ) ) {
/* from address */
net.c: use printaddr and umove_or_printaddr
* net.c (printsock): Use printaddr and umove_or_printaddr.
(printcmsghdr, printmsghdr, printmmsghdr, decode_mmsg, do_sockname,
sys_recv, sys_recvfrom, sys_recvmsg, do_pipe, print_linger, print_ucred,
print_tpacket_stats, print_icmp_filter, print_getsockopt,
print_group_req, print_tpacket_req, print_packet_mreq,
print_setsockopt): Use printaddr.
(print_mreq, print_mreq6): Use umove_or_printaddr.
2015-07-19 22:36:46 +00:00
printaddr ( tcp - > u_arg [ 4 ] ) ;
tprints ( " , " ) ;
2016-07-12 07:46:19 +00:00
/* from length */
net.c: use printaddr and umove_or_printaddr
* net.c (printsock): Use printaddr and umove_or_printaddr.
(printcmsghdr, printmsghdr, printmmsghdr, decode_mmsg, do_sockname,
sys_recv, sys_recvfrom, sys_recvmsg, do_pipe, print_linger, print_ucred,
print_tpacket_stats, print_icmp_filter, print_getsockopt,
print_group_req, print_tpacket_req, print_packet_mreq,
print_setsockopt): Use printaddr.
(print_mreq, print_mreq6): Use umove_or_printaddr.
2015-07-19 22:36:46 +00:00
printaddr ( tcp - > u_arg [ 5 ] ) ;
1999-02-19 00:21:36 +00:00
return 0 ;
}
2016-07-12 07:46:19 +00:00
if ( syserror ( tcp ) ) {
/* from address */
printaddr ( tcp - > u_arg [ 4 ] ) ;
/* from length */
tprintf ( " , [%d] " , ulen ) ;
return 0 ;
}
net.c: recvfrom fixes
This change fixes these three problems (before/after is shown):
On interrupted syscall, flags are not decoded:
-recvfrom(3, 0x7fff0a41e306, 10, 2, 0, 0) = ? ERESTARTSYS
+recvfrom(3, 0x7fff0a41e306, 10, MSG_PEEK, 0, 0) = ? ERESTARTSYS
If peer address is unavalable (example: anon sockets from socketpair()),
kernel returns socklen of 0, but we ignore that and show bogus sockaddr data:
-recvfrom(3, "123456789\0", 10, MSG_PEEK, {sa_family=0x7777 /* AF_??? */, sa_data="wwwwwwwwwwwwww"}, [0]) = 10
+recvfrom(3, "123456789\0", 10, MSG_PEEK, 0x7ffde6edf760, [0]) = 10
SYS_FUNC(recvfrom) passes address of fromlen, not fromlen, to printsock():
- printsock(tcp, tcp->u_arg[4], tcp->u_arg[5]);
+ printsock(tcp, tcp->u_arg[4], fromlen);
Signed-off-by: Denys Vlasenko <dvlasenk@redhat.com>
2015-07-30 13:29:20 +02:00
/* from address */
2016-07-12 07:46:19 +00:00
decode_sockaddr ( tcp , tcp - > u_arg [ 4 ] , ulen > rlen ? rlen : ulen ) ;
1999-02-19 00:21:36 +00:00
/* from length */
2016-07-12 07:46:19 +00:00
if ( ulen ! = rlen )
tprintf ( " , [%d->%d] " , ulen , rlen ) ;
else
tprintf ( " , [%d] " , rlen ) ;
1999-02-19 00:21:36 +00:00
}
return 0 ;
}
2015-04-07 01:36:50 +00:00
SYS_FUNC ( getsockname )
1999-02-19 00:21:36 +00:00
{
2016-07-09 21:52:34 +00:00
return decode_sockname ( tcp ) ;
1999-02-19 00:21:36 +00:00
}
2015-08-02 01:54:48 +00:00
static void
printpair_fd ( struct tcb * tcp , const int i0 , const int i1 )
{
tprints ( " [ " ) ;
printfd ( tcp , i0 ) ;
tprints ( " , " ) ;
printfd ( tcp , i1 ) ;
tprints ( " ] " ) ;
}
static void
2016-12-26 10:26:03 +00:00
decode_pair_fd ( struct tcb * const tcp , const kernel_ulong_t addr )
2015-08-02 01:54:48 +00:00
{
int pair [ 2 ] ;
if ( umove_or_printaddr ( tcp , addr , & pair ) )
return ;
printpair_fd ( tcp , pair [ 0 ] , pair [ 1 ] ) ;
}
2008-10-23 Dmitry V. Levin <ldv@altlinux.org>
Implement parsers for new linux syscalls.
* desc.c (do_dup2, [LINUX] sys_dup3): New functions.
(sys_dup2): Use do_dup2.
[LINUX] (sys_epoll_create1): New function.
[LINUX] (do_eventfd, sys_eventfd2): New functions.
[LINUX] (sys_eventfd): Use do_eventfd.
* net.c (do_pipe, [LINUX] sys_pipe2): New functions.
(sys_pipe): Use do_pipe.
* signal.c [LINUX] (do_signalfd, sys_signalfd4): New functions.
[LINUX] (sys_signalfd): Use do_signalfd.
* linux/syscall.h: Declare new sys_* functions.
* linux/syscallent.h: Hook up signalfd4, eventfd2, epoll_create1,
dup3, pipe2, inotify_init1.
* linux/x86_64/syscallent.h: Hook up paccept, signalfd4, eventfd2,
epoll_create1, dup3, pipe2, inotify_init1.
2008-11-10 22:53:02 +00:00
static int
do_pipe ( struct tcb * tcp , int flags_arg )
{
1999-02-19 00:21:36 +00:00
if ( exiting ( tcp ) ) {
2016-02-12 16:37:31 +00:00
decode_pair_fd ( tcp , tcp - > u_arg [ 0 ] ) ;
2008-10-23 Dmitry V. Levin <ldv@altlinux.org>
Implement parsers for new linux syscalls.
* desc.c (do_dup2, [LINUX] sys_dup3): New functions.
(sys_dup2): Use do_dup2.
[LINUX] (sys_epoll_create1): New function.
[LINUX] (do_eventfd, sys_eventfd2): New functions.
[LINUX] (sys_eventfd): Use do_eventfd.
* net.c (do_pipe, [LINUX] sys_pipe2): New functions.
(sys_pipe): Use do_pipe.
* signal.c [LINUX] (do_signalfd, sys_signalfd4): New functions.
[LINUX] (sys_signalfd): Use do_signalfd.
* linux/syscall.h: Declare new sys_* functions.
* linux/syscallent.h: Hook up signalfd4, eventfd2, epoll_create1,
dup3, pipe2, inotify_init1.
* linux/x86_64/syscallent.h: Hook up paccept, signalfd4, eventfd2,
epoll_create1, dup3, pipe2, inotify_init1.
2008-11-10 22:53:02 +00:00
if ( flags_arg > = 0 ) {
2011-09-01 10:00:28 +02:00
tprints ( " , " ) ;
2008-10-23 Dmitry V. Levin <ldv@altlinux.org>
Implement parsers for new linux syscalls.
* desc.c (do_dup2, [LINUX] sys_dup3): New functions.
(sys_dup2): Use do_dup2.
[LINUX] (sys_epoll_create1): New function.
[LINUX] (do_eventfd, sys_eventfd2): New functions.
[LINUX] (sys_eventfd): Use do_eventfd.
* net.c (do_pipe, [LINUX] sys_pipe2): New functions.
(sys_pipe): Use do_pipe.
* signal.c [LINUX] (do_signalfd, sys_signalfd4): New functions.
[LINUX] (sys_signalfd): Use do_signalfd.
* linux/syscall.h: Declare new sys_* functions.
* linux/syscallent.h: Hook up signalfd4, eventfd2, epoll_create1,
dup3, pipe2, inotify_init1.
* linux/x86_64/syscallent.h: Hook up paccept, signalfd4, eventfd2,
epoll_create1, dup3, pipe2, inotify_init1.
2008-11-10 22:53:02 +00:00
printflags ( open_mode_flags , tcp - > u_arg [ flags_arg ] , " O_??? " ) ;
}
}
1999-02-19 00:21:36 +00:00
return 0 ;
}
2015-04-07 01:36:50 +00:00
SYS_FUNC ( pipe )
2008-10-23 Dmitry V. Levin <ldv@altlinux.org>
Implement parsers for new linux syscalls.
* desc.c (do_dup2, [LINUX] sys_dup3): New functions.
(sys_dup2): Use do_dup2.
[LINUX] (sys_epoll_create1): New function.
[LINUX] (do_eventfd, sys_eventfd2): New functions.
[LINUX] (sys_eventfd): Use do_eventfd.
* net.c (do_pipe, [LINUX] sys_pipe2): New functions.
(sys_pipe): Use do_pipe.
* signal.c [LINUX] (do_signalfd, sys_signalfd4): New functions.
[LINUX] (sys_signalfd): Use do_signalfd.
* linux/syscall.h: Declare new sys_* functions.
* linux/syscallent.h: Hook up signalfd4, eventfd2, epoll_create1,
dup3, pipe2, inotify_init1.
* linux/x86_64/syscallent.h: Hook up paccept, signalfd4, eventfd2,
epoll_create1, dup3, pipe2, inotify_init1.
2008-11-10 22:53:02 +00:00
{
2016-02-12 16:37:31 +00:00
# ifdef HAVE_GETRVAL2
if ( exiting ( tcp ) & & ! syserror ( tcp ) )
printpair_fd ( tcp , tcp - > u_rval , getrval2 ( tcp ) ) ;
return 0 ;
# else
2008-10-23 Dmitry V. Levin <ldv@altlinux.org>
Implement parsers for new linux syscalls.
* desc.c (do_dup2, [LINUX] sys_dup3): New functions.
(sys_dup2): Use do_dup2.
[LINUX] (sys_epoll_create1): New function.
[LINUX] (do_eventfd, sys_eventfd2): New functions.
[LINUX] (sys_eventfd): Use do_eventfd.
* net.c (do_pipe, [LINUX] sys_pipe2): New functions.
(sys_pipe): Use do_pipe.
* signal.c [LINUX] (do_signalfd, sys_signalfd4): New functions.
[LINUX] (sys_signalfd): Use do_signalfd.
* linux/syscall.h: Declare new sys_* functions.
* linux/syscallent.h: Hook up signalfd4, eventfd2, epoll_create1,
dup3, pipe2, inotify_init1.
* linux/x86_64/syscallent.h: Hook up paccept, signalfd4, eventfd2,
epoll_create1, dup3, pipe2, inotify_init1.
2008-11-10 22:53:02 +00:00
return do_pipe ( tcp , - 1 ) ;
2016-02-12 16:37:31 +00:00
# endif
2008-10-23 Dmitry V. Levin <ldv@altlinux.org>
Implement parsers for new linux syscalls.
* desc.c (do_dup2, [LINUX] sys_dup3): New functions.
(sys_dup2): Use do_dup2.
[LINUX] (sys_epoll_create1): New function.
[LINUX] (do_eventfd, sys_eventfd2): New functions.
[LINUX] (sys_eventfd): Use do_eventfd.
* net.c (do_pipe, [LINUX] sys_pipe2): New functions.
(sys_pipe): Use do_pipe.
* signal.c [LINUX] (do_signalfd, sys_signalfd4): New functions.
[LINUX] (sys_signalfd): Use do_signalfd.
* linux/syscall.h: Declare new sys_* functions.
* linux/syscallent.h: Hook up signalfd4, eventfd2, epoll_create1,
dup3, pipe2, inotify_init1.
* linux/x86_64/syscallent.h: Hook up paccept, signalfd4, eventfd2,
epoll_create1, dup3, pipe2, inotify_init1.
2008-11-10 22:53:02 +00:00
}
2015-04-07 01:36:50 +00:00
SYS_FUNC ( pipe2 )
2008-10-23 Dmitry V. Levin <ldv@altlinux.org>
Implement parsers for new linux syscalls.
* desc.c (do_dup2, [LINUX] sys_dup3): New functions.
(sys_dup2): Use do_dup2.
[LINUX] (sys_epoll_create1): New function.
[LINUX] (do_eventfd, sys_eventfd2): New functions.
[LINUX] (sys_eventfd): Use do_eventfd.
* net.c (do_pipe, [LINUX] sys_pipe2): New functions.
(sys_pipe): Use do_pipe.
* signal.c [LINUX] (do_signalfd, sys_signalfd4): New functions.
[LINUX] (sys_signalfd): Use do_signalfd.
* linux/syscall.h: Declare new sys_* functions.
* linux/syscallent.h: Hook up signalfd4, eventfd2, epoll_create1,
dup3, pipe2, inotify_init1.
* linux/x86_64/syscallent.h: Hook up paccept, signalfd4, eventfd2,
epoll_create1, dup3, pipe2, inotify_init1.
2008-11-10 22:53:02 +00:00
{
return do_pipe ( tcp , 1 ) ;
}
2015-04-07 01:36:50 +00:00
SYS_FUNC ( socketpair )
1999-02-19 00:21:36 +00:00
{
if ( entering ( tcp ) ) {
2016-04-04 01:35:28 +00:00
printxval ( addrfams , tcp - > u_arg [ 0 ] , " AF_??? " ) ;
2011-09-01 10:00:28 +02:00
tprints ( " , " ) ;
2014-09-10 17:48:28 +00:00
tprint_sock_type ( tcp - > u_arg [ 1 ] ) ;
2016-12-26 10:16:35 +00:00
tprintf ( " , % " PRI_klu , tcp - > u_arg [ 2 ] ) ;
1999-02-19 00:21:36 +00:00
} else {
2015-07-06 22:33:39 +00:00
tprints ( " , " ) ;
2015-08-02 01:54:48 +00:00
decode_pair_fd ( tcp , tcp - > u_arg [ 3 ] ) ;
1999-02-19 00:21:36 +00:00
}
return 0 ;
}
2015-01-29 04:42:37 +00:00
# include "xlat/sockoptions.h"
# include "xlat/sockipoptions.h"
decode extend getsockopt/setsockopt options
Currently the code assumes the set of valid options between getsockopt
and setsockopt are exactly the same and thus maintains one list. The
kernel unfortunately does not do this -- it allows for different opts
between the get and set functions. See the {g,s}et_opt{min,max} fields
in the various netfilter subcores.
To support this, extend the printxval function to take multiple sets of
xlats as varargs. Then we add the new get/set lists, and pass them down
in the net code when decoding things.
A simple example is iptables; before:
getsockopt(4, SOL_IP, 0x40 /* IP_??? */, ...) = 0
getsockopt(4, SOL_IP, 0x41 /* IP_??? */, ...) = 0
after:
getsockopt(4, SOL_IP, IPT_SO_GET_INFO, ...) = 0
getsockopt(4, SOL_IP, IPT_SO_GET_ENTRIES, ...) = 0
If these were setsockopt calls, then 0x40 & 0x41 would be
IPT_SO_SET_REPLACE & IPT_SO_SET_ADD_COUNTERS.
* configure.ac: Check for netfilter headers.
* defs.h (printxvals): New prototype.
(printxval): Change to a define.
* net.c: Include netfilter headers and new sockopts headers.
(print_sockopt_fd_level_name): Add a is_getsockopt argument. Change SOL_IP
and SOL_IPV6 decoding to use printxvals, and use is_getsockopt to pass more
xlats down.
(getsockopt): Call print_sockopt_fd_level_name with is_getsockopt as true.
(setsockopt): Call print_sockopt_fd_level_name with is_getsockopt as false.
* util.c (printxval): Rename to ...
(printxvals): ... this. Rewrite to be varargs based.
* xlat/getsockipoptions.in: New xlat list.
* xlat/getsockipv6options.in, xlat/setsockipoptions.in,
xlat/setsockipv6options.in: Likewise.
2015-08-19 13:29:27 -04:00
# include "xlat/getsockipoptions.h"
# include "xlat/setsockipoptions.h"
2015-01-29 04:42:37 +00:00
# include "xlat/sockipv6options.h"
decode extend getsockopt/setsockopt options
Currently the code assumes the set of valid options between getsockopt
and setsockopt are exactly the same and thus maintains one list. The
kernel unfortunately does not do this -- it allows for different opts
between the get and set functions. See the {g,s}et_opt{min,max} fields
in the various netfilter subcores.
To support this, extend the printxval function to take multiple sets of
xlats as varargs. Then we add the new get/set lists, and pass them down
in the net code when decoding things.
A simple example is iptables; before:
getsockopt(4, SOL_IP, 0x40 /* IP_??? */, ...) = 0
getsockopt(4, SOL_IP, 0x41 /* IP_??? */, ...) = 0
after:
getsockopt(4, SOL_IP, IPT_SO_GET_INFO, ...) = 0
getsockopt(4, SOL_IP, IPT_SO_GET_ENTRIES, ...) = 0
If these were setsockopt calls, then 0x40 & 0x41 would be
IPT_SO_SET_REPLACE & IPT_SO_SET_ADD_COUNTERS.
* configure.ac: Check for netfilter headers.
* defs.h (printxvals): New prototype.
(printxval): Change to a define.
* net.c: Include netfilter headers and new sockopts headers.
(print_sockopt_fd_level_name): Add a is_getsockopt argument. Change SOL_IP
and SOL_IPV6 decoding to use printxvals, and use is_getsockopt to pass more
xlats down.
(getsockopt): Call print_sockopt_fd_level_name with is_getsockopt as true.
(setsockopt): Call print_sockopt_fd_level_name with is_getsockopt as false.
* util.c (printxval): Rename to ...
(printxvals): ... this. Rewrite to be varargs based.
* xlat/getsockipoptions.in: New xlat list.
* xlat/getsockipv6options.in, xlat/setsockipoptions.in,
xlat/setsockipv6options.in: Likewise.
2015-08-19 13:29:27 -04:00
# include "xlat/getsockipv6options.h"
# include "xlat/setsockipv6options.h"
2015-01-29 04:42:37 +00:00
# include "xlat/sockipxoptions.h"
2017-11-15 16:36:21 +00:00
# include "xlat/socknetlinkoptions.h"
2015-01-29 04:42:37 +00:00
# include "xlat/sockpacketoptions.h"
2017-11-15 16:36:21 +00:00
# include "xlat/sockrawoptions.h"
2015-01-29 04:42:37 +00:00
# include "xlat/socksctpoptions.h"
# include "xlat/socktcpoptions.h"
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
static void
2016-04-01 01:03:20 +00:00
print_sockopt_fd_level_name ( struct tcb * tcp , int fd , unsigned int level ,
unsigned int name , bool is_getsockopt )
1999-02-19 00:21:36 +00:00
{
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
printfd ( tcp , fd ) ;
tprints ( " , " ) ;
printxval ( socketlayers , level , " SOL_?? " ) ;
tprints ( " , " ) ;
switch ( level ) {
case SOL_SOCKET :
printxval ( sockoptions , name , " SO_??? " ) ;
break ;
case SOL_IP :
decode extend getsockopt/setsockopt options
Currently the code assumes the set of valid options between getsockopt
and setsockopt are exactly the same and thus maintains one list. The
kernel unfortunately does not do this -- it allows for different opts
between the get and set functions. See the {g,s}et_opt{min,max} fields
in the various netfilter subcores.
To support this, extend the printxval function to take multiple sets of
xlats as varargs. Then we add the new get/set lists, and pass them down
in the net code when decoding things.
A simple example is iptables; before:
getsockopt(4, SOL_IP, 0x40 /* IP_??? */, ...) = 0
getsockopt(4, SOL_IP, 0x41 /* IP_??? */, ...) = 0
after:
getsockopt(4, SOL_IP, IPT_SO_GET_INFO, ...) = 0
getsockopt(4, SOL_IP, IPT_SO_GET_ENTRIES, ...) = 0
If these were setsockopt calls, then 0x40 & 0x41 would be
IPT_SO_SET_REPLACE & IPT_SO_SET_ADD_COUNTERS.
* configure.ac: Check for netfilter headers.
* defs.h (printxvals): New prototype.
(printxval): Change to a define.
* net.c: Include netfilter headers and new sockopts headers.
(print_sockopt_fd_level_name): Add a is_getsockopt argument. Change SOL_IP
and SOL_IPV6 decoding to use printxvals, and use is_getsockopt to pass more
xlats down.
(getsockopt): Call print_sockopt_fd_level_name with is_getsockopt as true.
(setsockopt): Call print_sockopt_fd_level_name with is_getsockopt as false.
* util.c (printxval): Rename to ...
(printxvals): ... this. Rewrite to be varargs based.
* xlat/getsockipoptions.in: New xlat list.
* xlat/getsockipv6options.in, xlat/setsockipoptions.in,
xlat/setsockipv6options.in: Likewise.
2015-08-19 13:29:27 -04:00
printxvals ( name , " IP_??? " , sockipoptions ,
is_getsockopt ? getsockipoptions : setsockipoptions , NULL ) ;
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
break ;
case SOL_IPV6 :
decode extend getsockopt/setsockopt options
Currently the code assumes the set of valid options between getsockopt
and setsockopt are exactly the same and thus maintains one list. The
kernel unfortunately does not do this -- it allows for different opts
between the get and set functions. See the {g,s}et_opt{min,max} fields
in the various netfilter subcores.
To support this, extend the printxval function to take multiple sets of
xlats as varargs. Then we add the new get/set lists, and pass them down
in the net code when decoding things.
A simple example is iptables; before:
getsockopt(4, SOL_IP, 0x40 /* IP_??? */, ...) = 0
getsockopt(4, SOL_IP, 0x41 /* IP_??? */, ...) = 0
after:
getsockopt(4, SOL_IP, IPT_SO_GET_INFO, ...) = 0
getsockopt(4, SOL_IP, IPT_SO_GET_ENTRIES, ...) = 0
If these were setsockopt calls, then 0x40 & 0x41 would be
IPT_SO_SET_REPLACE & IPT_SO_SET_ADD_COUNTERS.
* configure.ac: Check for netfilter headers.
* defs.h (printxvals): New prototype.
(printxval): Change to a define.
* net.c: Include netfilter headers and new sockopts headers.
(print_sockopt_fd_level_name): Add a is_getsockopt argument. Change SOL_IP
and SOL_IPV6 decoding to use printxvals, and use is_getsockopt to pass more
xlats down.
(getsockopt): Call print_sockopt_fd_level_name with is_getsockopt as true.
(setsockopt): Call print_sockopt_fd_level_name with is_getsockopt as false.
* util.c (printxval): Rename to ...
(printxvals): ... this. Rewrite to be varargs based.
* xlat/getsockipoptions.in: New xlat list.
* xlat/getsockipv6options.in, xlat/setsockipoptions.in,
xlat/setsockipv6options.in: Likewise.
2015-08-19 13:29:27 -04:00
printxvals ( name , " IPV6_??? " , sockipv6options ,
is_getsockopt ? getsockipv6options : setsockipv6options , NULL ) ;
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
break ;
case SOL_IPX :
printxval ( sockipxoptions , name , " IPX_??? " ) ;
break ;
case SOL_PACKET :
printxval ( sockpacketoptions , name , " PACKET_??? " ) ;
break ;
case SOL_TCP :
printxval ( socktcpoptions , name , " TCP_??? " ) ;
break ;
case SOL_SCTP :
printxval ( socksctpoptions , name , " SCTP_??? " ) ;
break ;
case SOL_RAW :
printxval ( sockrawoptions , name , " RAW_??? " ) ;
break ;
2017-11-15 16:36:21 +00:00
case SOL_NETLINK :
printxval ( socknetlinkoptions , name , " NETLINK_??? " ) ;
break ;
1999-02-19 00:21:36 +00:00
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
/* Other SOL_* protocol levels still need work. */
default :
tprintf ( " %u " , name ) ;
}
tprints ( " , " ) ;
}
2002-05-22 15:46:49 +00:00
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
static void
2017-07-08 14:57:44 +00:00
print_set_linger ( struct tcb * const tcp , const kernel_ulong_t addr ,
2017-07-09 18:43:34 +00:00
const int len )
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
{
struct linger linger ;
2017-07-09 18:43:34 +00:00
if ( len < ( int ) sizeof ( linger ) ) {
net.c: use printaddr and umove_or_printaddr
* net.c (printsock): Use printaddr and umove_or_printaddr.
(printcmsghdr, printmsghdr, printmmsghdr, decode_mmsg, do_sockname,
sys_recv, sys_recvfrom, sys_recvmsg, do_pipe, print_linger, print_ucred,
print_tpacket_stats, print_icmp_filter, print_getsockopt,
print_group_req, print_tpacket_req, print_packet_mreq,
print_setsockopt): Use printaddr.
(print_mreq, print_mreq6): Use umove_or_printaddr.
2015-07-19 22:36:46 +00:00
printaddr ( addr ) ;
2017-07-09 18:43:34 +00:00
} else if ( ! umove_or_printaddr ( tcp , addr , & linger ) ) {
PRINT_FIELD_D ( " { " , linger , l_onoff ) ;
PRINT_FIELD_D ( " , " , linger , l_linger ) ;
tprints ( " } " ) ;
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
}
}
2017-07-08 14:57:44 +00:00
static void
print_get_linger ( struct tcb * const tcp , const kernel_ulong_t addr ,
unsigned int len )
{
struct linger linger ;
if ( len < sizeof ( linger ) ) {
if ( len ! = sizeof ( linger . l_onoff ) ) {
printstr_ex ( tcp , addr , len , QUOTE_FORCE_HEX ) ;
return ;
}
} else {
len = sizeof ( linger ) ;
}
if ( umoven ( tcp , addr , len , & linger ) < 0 ) {
printaddr ( addr ) ;
return ;
}
PRINT_FIELD_D ( " { " , linger , l_onoff ) ;
if ( len = = sizeof ( linger ) )
PRINT_FIELD_D ( " , " , linger , l_linger ) ;
tprints ( " } " ) ;
}
2010-12-03 16:54:53 +00:00
# ifdef SO_PEERCRED
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
static void
2017-07-08 19:27:26 +00:00
print_ucred ( struct tcb * const tcp , const kernel_ulong_t addr , unsigned int len )
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
{
struct ucred uc ;
2017-07-08 19:27:26 +00:00
if ( len < sizeof ( uc ) ) {
if ( len ! = sizeof ( uc . pid )
& & len ! = offsetofend ( struct ucred , uid ) ) {
printstr_ex ( tcp , addr , len , QUOTE_FORCE_HEX ) ;
return ;
}
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
} else {
2017-07-08 19:27:26 +00:00
len = sizeof ( uc ) ;
}
if ( umoven ( tcp , addr , len , & uc ) < 0 ) {
printaddr ( addr ) ;
return ;
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
}
2017-07-08 19:27:26 +00:00
PRINT_FIELD_D ( " { " , uc , pid ) ;
if ( len > sizeof ( uc . pid ) )
PRINT_FIELD_UID ( " , " , uc , uid ) ;
if ( len = = sizeof ( uc ) )
PRINT_FIELD_UID ( " , " , uc , gid ) ;
tprints ( " } " ) ;
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
}
# endif /* SO_PEERCRED */
2009-11-13 12:51:04 +00:00
# ifdef PACKET_STATISTICS
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
static void
2016-12-26 10:26:03 +00:00
print_tpacket_stats ( struct tcb * const tcp , const kernel_ulong_t addr ,
net: change address argument type from long to kernel_ureg_t
* net.c (decode_sockbuf, decode_pair_fd, print_linger, print_ucred,
print_tpacket_stats, print_icmp_filter, print_getsockopt, print_mreq,
print_mreq6, print_group_req, print_tpacket_req, print_packet_mreq,
print_setsockopt): Change address argument type from long
to kernel_ureg_t.
2016-12-23 10:50:10 +00:00
const int len )
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
{
struct tpacket_stats stats ;
2002-05-22 15:46:49 +00:00
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
if ( len ! = sizeof ( stats ) | |
umove ( tcp , addr , & stats ) < 0 ) {
net.c: use printaddr and umove_or_printaddr
* net.c (printsock): Use printaddr and umove_or_printaddr.
(printcmsghdr, printmsghdr, printmmsghdr, decode_mmsg, do_sockname,
sys_recv, sys_recvfrom, sys_recvmsg, do_pipe, print_linger, print_ucred,
print_tpacket_stats, print_icmp_filter, print_getsockopt,
print_group_req, print_tpacket_req, print_packet_mreq,
print_setsockopt): Use printaddr.
(print_mreq, print_mreq6): Use umove_or_printaddr.
2015-07-19 22:36:46 +00:00
printaddr ( addr ) ;
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
} else {
2017-07-09 13:54:01 +00:00
PRINT_FIELD_U ( " { " , stats , tp_packets ) ;
PRINT_FIELD_U ( " { " , stats , tp_drops ) ;
tprints ( " } " ) ;
1999-02-19 00:21:36 +00:00
}
}
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
# endif /* PACKET_STATISTICS */
1999-02-19 00:21:36 +00:00
2016-06-15 21:29:07 +00:00
# include "xlat/icmpfilterflags.h"
2015-01-29 04:42:37 +00:00
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
static void
2016-12-26 10:26:03 +00:00
print_icmp_filter ( struct tcb * const tcp , const kernel_ulong_t addr , int len )
2000-07-05 16:05:39 +00:00
{
2016-05-06 00:06:15 +00:00
struct icmp_filter filter = { } ;
2000-07-05 16:05:39 +00:00
2016-05-06 00:06:15 +00:00
if ( len > ( int ) sizeof ( filter ) )
len = sizeof ( filter ) ;
else if ( len < = 0 ) {
net.c: use printaddr and umove_or_printaddr
* net.c (printsock): Use printaddr and umove_or_printaddr.
(printcmsghdr, printmsghdr, printmmsghdr, decode_mmsg, do_sockname,
sys_recv, sys_recvfrom, sys_recvmsg, do_pipe, print_linger, print_ucred,
print_tpacket_stats, print_icmp_filter, print_getsockopt,
print_group_req, print_tpacket_req, print_packet_mreq,
print_setsockopt): Use printaddr.
(print_mreq, print_mreq6): Use umove_or_printaddr.
2015-07-19 22:36:46 +00:00
printaddr ( addr ) ;
2000-07-05 16:05:39 +00:00
return ;
}
2016-05-06 00:06:15 +00:00
if ( umoven_or_printaddr ( tcp , addr , len , & filter ) )
return ;
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
printflags ( icmpfilterflags , ~ filter . data , " ICMP_??? " ) ;
2011-09-01 10:00:28 +02:00
tprints ( " ) " ) ;
2000-07-05 16:05:39 +00:00
}
2017-11-16 02:27:40 +00:00
static bool
print_uint32 ( struct tcb * tcp , void * elem_buf , size_t elem_size , void * data )
{
tprintf ( " %u " , * ( uint32_t * ) elem_buf ) ;
return true ;
}
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
static void
net: change address argument type from long to kernel_ureg_t
* net.c (decode_sockbuf, decode_pair_fd, print_linger, print_ucred,
print_tpacket_stats, print_icmp_filter, print_getsockopt, print_mreq,
print_mreq6, print_group_req, print_tpacket_req, print_packet_mreq,
print_setsockopt): Change address argument type from long
to kernel_ureg_t.
2016-12-23 10:50:10 +00:00
print_getsockopt ( struct tcb * const tcp , const unsigned int level ,
2016-12-26 10:26:03 +00:00
const unsigned int name , const kernel_ulong_t addr ,
2017-11-16 02:27:40 +00:00
const int ulen , const int rlen )
1999-02-19 00:21:36 +00:00
{
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
if ( addr & & verbose ( tcp ) )
2002-05-23 11:48:58 +00:00
switch ( level ) {
2012-03-17 04:42:07 +01:00
case SOL_SOCKET :
2002-05-23 11:48:58 +00:00
switch ( name ) {
2012-03-17 04:42:07 +01:00
case SO_LINGER :
2017-11-16 02:27:40 +00:00
print_get_linger ( tcp , addr , rlen ) ;
2017-07-08 14:57:44 +00:00
return ;
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
# ifdef SO_PEERCRED
case SO_PEERCRED :
2017-11-16 02:27:40 +00:00
print_ucred ( tcp , addr , rlen ) ;
2017-07-08 14:57:44 +00:00
return ;
2002-05-23 11:48:58 +00:00
# endif
2017-07-08 14:57:44 +00:00
# ifdef SO_ATTACH_FILTER
case SO_ATTACH_FILTER :
2017-11-16 02:27:40 +00:00
if ( rlen & & ( unsigned short ) rlen = = ( unsigned int ) rlen )
print_sock_fprog ( tcp , addr , rlen ) ;
2017-07-08 14:57:44 +00:00
else
printaddr ( addr ) ;
return ;
# endif /* SO_ATTACH_FILTER */
2002-05-23 11:48:58 +00:00
}
break ;
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
case SOL_PACKET :
switch ( name ) {
2015-01-29 04:42:37 +00:00
# ifdef PACKET_STATISTICS
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
case PACKET_STATISTICS :
2017-11-16 02:27:40 +00:00
print_tpacket_stats ( tcp , addr , rlen ) ;
2017-07-08 14:57:44 +00:00
return ;
2015-01-29 04:42:37 +00:00
# endif
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
}
2002-05-23 11:48:58 +00:00
break ;
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
case SOL_RAW :
switch ( name ) {
case ICMP_FILTER :
2017-11-16 02:27:40 +00:00
print_icmp_filter ( tcp , addr , rlen ) ;
2017-07-08 14:57:44 +00:00
return ;
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
}
2004-08-31 07:01:26 +00:00
break ;
2017-11-16 00:12:46 +00:00
case SOL_NETLINK :
2017-11-16 02:27:40 +00:00
if ( ulen < 0 | | rlen < 0 ) {
/*
* As the kernel neither accepts nor returns a negative
* length , in case of successful getsockopt syscall
* invocation these negative values must have come
* from userspace .
*/
printaddr ( addr ) ;
return ;
}
switch ( name ) {
case NETLINK_LIST_MEMBERSHIPS : {
uint32_t buf ;
print_array ( tcp , addr , MIN ( ulen , rlen ) / sizeof ( buf ) ,
& buf , sizeof ( buf ) ,
umoven_or_printaddr , print_uint32 , 0 ) ;
break ;
}
default :
2017-11-16 00:12:46 +00:00
printnum_int ( tcp , addr , " %d " ) ;
2017-11-16 02:27:40 +00:00
break ;
}
2017-11-16 00:12:46 +00:00
return ;
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
}
/* default arg printing */
if ( verbose ( tcp ) ) {
2017-11-16 02:27:40 +00:00
if ( rlen = = sizeof ( int ) ) {
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
printnum_int ( tcp , addr , " %d " ) ;
} else {
2017-11-16 02:27:40 +00:00
printstrn ( tcp , addr , rlen ) ;
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
}
} else {
net.c: use printaddr and umove_or_printaddr
* net.c (printsock): Use printaddr and umove_or_printaddr.
(printcmsghdr, printmsghdr, printmmsghdr, decode_mmsg, do_sockname,
sys_recv, sys_recvfrom, sys_recvmsg, do_pipe, print_linger, print_ucred,
print_tpacket_stats, print_icmp_filter, print_getsockopt,
print_group_req, print_tpacket_req, print_packet_mreq,
print_setsockopt): Use printaddr.
(print_mreq, print_mreq6): Use umove_or_printaddr.
2015-07-19 22:36:46 +00:00
printaddr ( addr ) ;
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
}
}
2015-04-07 01:36:50 +00:00
SYS_FUNC ( getsockopt )
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
{
2017-07-08 14:57:44 +00:00
int ulen , rlen ;
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
if ( entering ( tcp ) ) {
print_sockopt_fd_level_name ( tcp , tcp - > u_arg [ 0 ] ,
decode extend getsockopt/setsockopt options
Currently the code assumes the set of valid options between getsockopt
and setsockopt are exactly the same and thus maintains one list. The
kernel unfortunately does not do this -- it allows for different opts
between the get and set functions. See the {g,s}et_opt{min,max} fields
in the various netfilter subcores.
To support this, extend the printxval function to take multiple sets of
xlats as varargs. Then we add the new get/set lists, and pass them down
in the net code when decoding things.
A simple example is iptables; before:
getsockopt(4, SOL_IP, 0x40 /* IP_??? */, ...) = 0
getsockopt(4, SOL_IP, 0x41 /* IP_??? */, ...) = 0
after:
getsockopt(4, SOL_IP, IPT_SO_GET_INFO, ...) = 0
getsockopt(4, SOL_IP, IPT_SO_GET_ENTRIES, ...) = 0
If these were setsockopt calls, then 0x40 & 0x41 would be
IPT_SO_SET_REPLACE & IPT_SO_SET_ADD_COUNTERS.
* configure.ac: Check for netfilter headers.
* defs.h (printxvals): New prototype.
(printxval): Change to a define.
* net.c: Include netfilter headers and new sockopts headers.
(print_sockopt_fd_level_name): Add a is_getsockopt argument. Change SOL_IP
and SOL_IPV6 decoding to use printxvals, and use is_getsockopt to pass more
xlats down.
(getsockopt): Call print_sockopt_fd_level_name with is_getsockopt as true.
(setsockopt): Call print_sockopt_fd_level_name with is_getsockopt as false.
* util.c (printxval): Rename to ...
(printxvals): ... this. Rewrite to be varargs based.
* xlat/getsockipoptions.in: New xlat list.
* xlat/getsockipv6options.in, xlat/setsockipoptions.in,
xlat/setsockipv6options.in: Likewise.
2015-08-19 13:29:27 -04:00
tcp - > u_arg [ 1 ] , tcp - > u_arg [ 2 ] , true ) ;
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
2017-07-08 14:57:44 +00:00
if ( verbose ( tcp ) & & tcp - > u_arg [ 4 ]
& & umove ( tcp , tcp - > u_arg [ 4 ] , & ulen ) = = 0 ) {
set_tcb_priv_ulong ( tcp , ulen ) ;
return 0 ;
} else {
2016-06-11 01:28:21 +00:00
printaddr ( tcp - > u_arg [ 3 ] ) ;
tprints ( " , " ) ;
printaddr ( tcp - > u_arg [ 4 ] ) ;
2017-07-08 14:57:44 +00:00
return RVAL_DECODED ;
}
} else {
ulen = get_tcb_priv_ulong ( tcp ) ;
if ( syserror ( tcp ) | | umove ( tcp , tcp - > u_arg [ 4 ] , & rlen ) < 0 ) {
printaddr ( tcp - > u_arg [ 3 ] ) ;
tprintf ( " , [%d] " , ulen ) ;
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
} else {
print_getsockopt ( tcp , tcp - > u_arg [ 1 ] , tcp - > u_arg [ 2 ] ,
2017-11-16 02:27:40 +00:00
tcp - > u_arg [ 3 ] , ulen , rlen ) ;
2017-07-08 14:57:44 +00:00
if ( ulen ! = rlen )
tprintf ( " , [%d->%d] " , ulen , rlen ) ;
else
tprintf ( " , [%d] " , rlen ) ;
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
}
}
return 0 ;
}
2015-06-08 14:19:46 +00:00
# ifdef IP_ADD_MEMBERSHIP
static void
2016-12-26 10:26:03 +00:00
print_mreq ( struct tcb * const tcp , const kernel_ulong_t addr ,
2017-07-09 18:43:34 +00:00
const int len )
2015-06-08 14:19:46 +00:00
{
struct ip_mreq mreq ;
2017-07-09 18:43:34 +00:00
if ( len < ( int ) sizeof ( mreq ) ) {
printaddr ( addr ) ;
} else if ( ! umove_or_printaddr ( tcp , addr , & mreq ) ) {
PRINT_FIELD_INET4_ADDR ( " { " , mreq , imr_multiaddr ) ;
PRINT_FIELD_INET4_ADDR ( " , " , mreq , imr_interface ) ;
tprints ( " } " ) ;
2015-06-08 14:19:46 +00:00
}
}
# endif /* IP_ADD_MEMBERSHIP */
# ifdef IPV6_ADD_MEMBERSHIP
static void
2016-12-26 10:26:03 +00:00
print_mreq6 ( struct tcb * const tcp , const kernel_ulong_t addr ,
2017-07-09 18:43:34 +00:00
const int len )
2015-06-08 14:19:46 +00:00
{
struct ipv6_mreq mreq ;
2017-07-09 18:43:34 +00:00
if ( len < ( int ) sizeof ( mreq ) ) {
printaddr ( addr ) ;
} else if ( ! umove_or_printaddr ( tcp , addr , & mreq ) ) {
PRINT_FIELD_INET_ADDR ( " { " , mreq , ipv6mr_multiaddr , AF_INET6 ) ;
PRINT_FIELD_IFINDEX ( " , " , mreq , ipv6mr_interface ) ;
tprints ( " } " ) ;
2017-06-15 21:02:14 +00:00
}
2015-06-08 14:19:46 +00:00
}
# endif /* IPV6_ADD_MEMBERSHIP */
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
# ifdef PACKET_RX_RING
static void
2016-12-26 10:26:03 +00:00
print_tpacket_req ( struct tcb * const tcp , const kernel_ulong_t addr , const int len )
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
{
struct tpacket_req req ;
if ( len ! = sizeof ( req ) | |
umove ( tcp , addr , & req ) < 0 ) {
net.c: use printaddr and umove_or_printaddr
* net.c (printsock): Use printaddr and umove_or_printaddr.
(printcmsghdr, printmsghdr, printmmsghdr, decode_mmsg, do_sockname,
sys_recv, sys_recvfrom, sys_recvmsg, do_pipe, print_linger, print_ucred,
print_tpacket_stats, print_icmp_filter, print_getsockopt,
print_group_req, print_tpacket_req, print_packet_mreq,
print_setsockopt): Use printaddr.
(print_mreq, print_mreq6): Use umove_or_printaddr.
2015-07-19 22:36:46 +00:00
printaddr ( addr ) ;
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
} else {
2017-07-09 13:54:01 +00:00
PRINT_FIELD_U ( " { " , req , tp_block_size ) ;
PRINT_FIELD_U ( " , " , req , tp_block_nr ) ;
PRINT_FIELD_U ( " , " , req , tp_frame_size ) ;
PRINT_FIELD_U ( " , " , req , tp_frame_nr ) ;
tprints ( " } " ) ;
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
}
}
# endif /* PACKET_RX_RING */
2015-01-29 03:26:53 +00:00
# ifdef PACKET_ADD_MEMBERSHIP
# include "xlat / packet_mreq_type.h"
static void
2016-12-26 10:26:03 +00:00
print_packet_mreq ( struct tcb * const tcp , const kernel_ulong_t addr , const int len )
2015-01-29 03:26:53 +00:00
{
struct packet_mreq mreq ;
if ( len ! = sizeof ( mreq ) | |
umove ( tcp , addr , & mreq ) < 0 ) {
net.c: use printaddr and umove_or_printaddr
* net.c (printsock): Use printaddr and umove_or_printaddr.
(printcmsghdr, printmsghdr, printmmsghdr, decode_mmsg, do_sockname,
sys_recv, sys_recvfrom, sys_recvmsg, do_pipe, print_linger, print_ucred,
print_tpacket_stats, print_icmp_filter, print_getsockopt,
print_group_req, print_tpacket_req, print_packet_mreq,
print_setsockopt): Use printaddr.
(print_mreq, print_mreq6): Use umove_or_printaddr.
2015-07-19 22:36:46 +00:00
printaddr ( addr ) ;
2015-01-29 03:26:53 +00:00
} else {
unsigned int i ;
2017-07-09 13:54:01 +00:00
PRINT_FIELD_IFINDEX ( " { " , mreq , mr_ifindex ) ;
PRINT_FIELD_XVAL ( " , " , mreq , mr_type , packet_mreq_type ,
" PACKET_MR_??? " ) ;
PRINT_FIELD_U ( " , " , mreq , mr_alen ) ;
tprints ( " , mr_address= " ) ;
2015-01-29 03:26:53 +00:00
if ( mreq . mr_alen > ARRAY_SIZE ( mreq . mr_address ) )
mreq . mr_alen = ARRAY_SIZE ( mreq . mr_address ) ;
for ( i = 0 ; i < mreq . mr_alen ; + + i )
tprintf ( " %02x " , mreq . mr_address [ i ] ) ;
tprints ( " } " ) ;
}
}
# endif /* PACKET_ADD_MEMBERSHIP */
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
static void
net: change address argument type from long to kernel_ureg_t
* net.c (decode_sockbuf, decode_pair_fd, print_linger, print_ucred,
print_tpacket_stats, print_icmp_filter, print_getsockopt, print_mreq,
print_mreq6, print_group_req, print_tpacket_req, print_packet_mreq,
print_setsockopt): Change address argument type from long
to kernel_ureg_t.
2016-12-23 10:50:10 +00:00
print_setsockopt ( struct tcb * const tcp , const unsigned int level ,
2016-12-26 10:26:03 +00:00
const unsigned int name , const kernel_ulong_t addr ,
net: change address argument type from long to kernel_ureg_t
* net.c (decode_sockbuf, decode_pair_fd, print_linger, print_ucred,
print_tpacket_stats, print_icmp_filter, print_getsockopt, print_mreq,
print_mreq6, print_group_req, print_tpacket_req, print_packet_mreq,
print_setsockopt): Change address argument type from long
to kernel_ureg_t.
2016-12-23 10:50:10 +00:00
const int len )
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
{
if ( addr & & verbose ( tcp ) )
switch ( level ) {
case SOL_SOCKET :
switch ( name ) {
case SO_LINGER :
2017-07-08 14:57:44 +00:00
print_set_linger ( tcp , addr , len ) ;
2017-07-08 14:57:44 +00:00
return ;
2017-07-08 14:57:44 +00:00
# ifdef SO_ATTACH_FILTER
case SO_ATTACH_FILTER :
# ifdef SO_ATTACH_REUSEPORT_CBPF
case SO_ATTACH_REUSEPORT_CBPF :
# endif
if ( ( unsigned int ) len = = get_sock_fprog_size ( ) )
decode_sock_fprog ( tcp , addr ) ;
else
printaddr ( addr ) ;
return ;
# endif /* SO_ATTACH_FILTER */
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
}
2002-05-23 11:48:58 +00:00
break ;
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
2015-01-30 01:55:20 +00:00
case SOL_IP :
switch ( name ) {
2015-06-08 14:19:46 +00:00
# ifdef IP_ADD_MEMBERSHIP
case IP_ADD_MEMBERSHIP :
case IP_DROP_MEMBERSHIP :
print_mreq ( tcp , addr , len ) ;
2017-07-08 14:57:44 +00:00
return ;
2015-06-08 14:19:46 +00:00
# endif /* IP_ADD_MEMBERSHIP */
2015-01-30 01:55:20 +00:00
# ifdef MCAST_JOIN_GROUP
case MCAST_JOIN_GROUP :
case MCAST_LEAVE_GROUP :
print_group_req ( tcp , addr , len ) ;
2017-07-08 14:57:44 +00:00
return ;
2015-01-30 01:55:20 +00:00
# endif /* MCAST_JOIN_GROUP */
}
2015-02-08 01:19:06 +00:00
break ;
2015-06-08 14:19:46 +00:00
case SOL_IPV6 :
switch ( name ) {
# ifdef IPV6_ADD_MEMBERSHIP
case IPV6_ADD_MEMBERSHIP :
case IPV6_DROP_MEMBERSHIP :
# ifdef IPV6_JOIN_ANYCAST
case IPV6_JOIN_ANYCAST :
# endif
# ifdef IPV6_LEAVE_ANYCAST
case IPV6_LEAVE_ANYCAST :
# endif
print_mreq6 ( tcp , addr , len ) ;
2017-07-08 14:57:44 +00:00
return ;
2015-06-08 14:19:46 +00:00
# endif /* IPV6_ADD_MEMBERSHIP */
2017-07-09 18:43:34 +00:00
# ifdef MCAST_JOIN_GROUP
case MCAST_JOIN_GROUP :
case MCAST_LEAVE_GROUP :
print_group_req ( tcp , addr , len ) ;
return ;
# endif /* MCAST_JOIN_GROUP */
2015-06-08 14:19:46 +00:00
}
break ;
2015-01-30 01:55:20 +00:00
2012-03-17 04:42:07 +01:00
case SOL_PACKET :
2009-11-13 12:51:04 +00:00
switch ( name ) {
2015-01-29 04:42:37 +00:00
# ifdef PACKET_RX_RING
2012-03-17 04:42:07 +01:00
case PACKET_RX_RING :
2015-01-29 04:42:37 +00:00
# ifdef PACKET_TX_RING
2012-03-17 04:42:07 +01:00
case PACKET_TX_RING :
2015-01-29 04:42:37 +00:00
# endif
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
print_tpacket_req ( tcp , addr , len ) ;
2017-07-08 14:57:44 +00:00
return ;
2015-01-29 04:42:37 +00:00
# endif /* PACKET_RX_RING */
# ifdef PACKET_ADD_MEMBERSHIP
2015-01-29 03:26:53 +00:00
case PACKET_ADD_MEMBERSHIP :
case PACKET_DROP_MEMBERSHIP :
print_packet_mreq ( tcp , addr , len ) ;
2017-07-08 14:57:44 +00:00
return ;
2015-01-29 04:42:37 +00:00
# endif /* PACKET_ADD_MEMBERSHIP */
2009-11-13 12:51:04 +00:00
}
2002-05-23 11:48:58 +00:00
break ;
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
2012-03-17 04:42:07 +01:00
case SOL_RAW :
2002-05-23 11:48:58 +00:00
switch ( name ) {
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
case ICMP_FILTER :
print_icmp_filter ( tcp , addr , len ) ;
2017-07-08 14:57:44 +00:00
return ;
2002-05-23 11:48:58 +00:00
}
break ;
2017-11-16 00:12:46 +00:00
case SOL_NETLINK :
if ( len < ( int ) sizeof ( int ) )
printaddr ( addr ) ;
else
printnum_int ( tcp , addr , " %d " ) ;
return ;
2002-05-23 11:48:58 +00:00
}
2002-05-22 15:46:49 +00:00
2002-05-23 11:48:58 +00:00
/* default arg printing */
2002-05-22 15:46:49 +00:00
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
if ( verbose ( tcp ) ) {
if ( len = = sizeof ( int ) ) {
printnum_int ( tcp , addr , " %d " ) ;
} else {
2016-12-20 16:43:26 +00:00
printstrn ( tcp , addr , len ) ;
getsockopt, setsockopt: do not decode structures in non-verbose mode
Move the code that is common between getsockopt and setsockopt parsers
to a separate function.
Move printers specific to getsockopt and setsockopt to separate
functions, choose appropriate parsers depending on verbose mode.
Move parsers of specific socket options to separate functions.
* net.c (printicmpfilter): Rename to print_icmp_filter.
(printsockopt): Remove.
(print_sockopt_fd_level_name, print_linger, print_ucred,
print_tpacket_stats, print_getsockopt, print_tpacket_req,
print_packet_mreq, print_setsockopt): New functions.
(sys_getsockopt, sys_setsockopt): Use them.
2015-01-29 03:11:41 +00:00
}
} else {
net.c: use printaddr and umove_or_printaddr
* net.c (printsock): Use printaddr and umove_or_printaddr.
(printcmsghdr, printmsghdr, printmmsghdr, decode_mmsg, do_sockname,
sys_recv, sys_recvfrom, sys_recvmsg, do_pipe, print_linger, print_ucred,
print_tpacket_stats, print_icmp_filter, print_getsockopt,
print_group_req, print_tpacket_req, print_packet_mreq,
print_setsockopt): Use printaddr.
(print_mreq, print_mreq6): Use umove_or_printaddr.
2015-07-19 22:36:46 +00:00
printaddr ( addr ) ;
2002-05-23 11:48:58 +00:00
}
}
2015-04-07 01:36:50 +00:00
SYS_FUNC ( setsockopt )
2002-05-23 11:48:58 +00:00
{
2015-07-19 22:52:47 +00:00
print_sockopt_fd_level_name ( tcp , tcp - > u_arg [ 0 ] ,
decode extend getsockopt/setsockopt options
Currently the code assumes the set of valid options between getsockopt
and setsockopt are exactly the same and thus maintains one list. The
kernel unfortunately does not do this -- it allows for different opts
between the get and set functions. See the {g,s}et_opt{min,max} fields
in the various netfilter subcores.
To support this, extend the printxval function to take multiple sets of
xlats as varargs. Then we add the new get/set lists, and pass them down
in the net code when decoding things.
A simple example is iptables; before:
getsockopt(4, SOL_IP, 0x40 /* IP_??? */, ...) = 0
getsockopt(4, SOL_IP, 0x41 /* IP_??? */, ...) = 0
after:
getsockopt(4, SOL_IP, IPT_SO_GET_INFO, ...) = 0
getsockopt(4, SOL_IP, IPT_SO_GET_ENTRIES, ...) = 0
If these were setsockopt calls, then 0x40 & 0x41 would be
IPT_SO_SET_REPLACE & IPT_SO_SET_ADD_COUNTERS.
* configure.ac: Check for netfilter headers.
* defs.h (printxvals): New prototype.
(printxval): Change to a define.
* net.c: Include netfilter headers and new sockopts headers.
(print_sockopt_fd_level_name): Add a is_getsockopt argument. Change SOL_IP
and SOL_IPV6 decoding to use printxvals, and use is_getsockopt to pass more
xlats down.
(getsockopt): Call print_sockopt_fd_level_name with is_getsockopt as true.
(setsockopt): Call print_sockopt_fd_level_name with is_getsockopt as false.
* util.c (printxval): Rename to ...
(printxvals): ... this. Rewrite to be varargs based.
* xlat/getsockipoptions.in: New xlat list.
* xlat/getsockipv6options.in, xlat/setsockipoptions.in,
xlat/setsockipv6options.in: Likewise.
2015-08-19 13:29:27 -04:00
tcp - > u_arg [ 1 ] , tcp - > u_arg [ 2 ] , false ) ;
2015-07-19 22:52:47 +00:00
print_setsockopt ( tcp , tcp - > u_arg [ 1 ] , tcp - > u_arg [ 2 ] ,
tcp - > u_arg [ 3 ] , tcp - > u_arg [ 4 ] ) ;
2017-07-08 14:57:44 +00:00
tprintf ( " , %d " , ( int ) tcp - > u_arg [ 4 ] ) ;
2015-07-19 22:52:47 +00:00
return RVAL_DECODED ;
1999-02-19 00:21:36 +00:00
}