[PATCH v3 1/5] netlink: introduce family specific decoder of NETLINK_ROUTE

Dmitry V. Levin ldv at altlinux.org
Wed Aug 9 11:45:08 UTC 2017


On Wed, Aug 09, 2017 at 10:07:38AM +0800, JingPiao Chen wrote:
> * netlink_route.c: New file.
> * Makefile.am (strace_SOURCES): Add it.
> * defs.h (decode_netlink_route): New prototype.
> * netlink.c (netlink_decoders): Add NETLINK_ROUTE.
> 
> Co-authored-by: Fabien Siron <fabien.siron at epita.fr>
> ---
>  Makefile.am     |  1 +
>  defs.h          |  1 +
>  netlink.c       |  1 +
>  netlink_route.c | 62 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++
>  4 files changed, 65 insertions(+)
>  create mode 100644 netlink_route.c
> 
> diff --git a/Makefile.am b/Makefile.am
> index 5b2b93a..23ce121 100644
> --- a/Makefile.am
> +++ b/Makefile.am
> @@ -193,6 +193,7 @@ strace_SOURCES =	\
>  	netlink_inet_diag.c \
>  	netlink_netlink_diag.c \
>  	netlink_packet_diag.c \
> +	netlink_route.c	\
>  	netlink_selinux.c \
>  	netlink_smc_diag.c \
>  	netlink_sock_diag.c \
> diff --git a/defs.h b/defs.h
> index 081fd4a..44a6296 100644
> --- a/defs.h
> +++ b/defs.h
> @@ -697,6 +697,7 @@ decode_netlink_ ## name(struct tcb *, const struct nlmsghdr *,		\
>  /* End of DECL_NETLINK definition. */
>  
>  DECL_NETLINK(crypto);
> +DECL_NETLINK(route);
>  DECL_NETLINK(selinux);
>  DECL_NETLINK(sock_diag);
>  
> diff --git a/netlink.c b/netlink.c
> index 2f34673..2a0353f 100644
> --- a/netlink.c
> +++ b/netlink.c
> @@ -372,6 +372,7 @@ static const netlink_decoder_t netlink_decoders[] = {
>  #ifdef HAVE_LINUX_CRYPTOUSER_H
>  	[NETLINK_CRYPTO] = decode_netlink_crypto,
>  #endif
> +	[NETLINK_ROUTE] = decode_netlink_route,
>  	[NETLINK_SELINUX] = decode_netlink_selinux,
>  	[NETLINK_SOCK_DIAG] = decode_netlink_sock_diag
>  };
> diff --git a/netlink_route.c b/netlink_route.c
> new file mode 100644
> index 0000000..2e7faa4
> --- /dev/null
> +++ b/netlink_route.c
> @@ -0,0 +1,62 @@
> +/*
> + * Copyright (c) 2016 Fabien Siron <fabien.siron at epita.fr>
> + * Copyright (c) 2017 JingPiao Chen <chenjingpiao at gmail.com>
> + * Copyright (c) 2016-2017 The strace developers.
> + * 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"
> +#include "netlink.h"
> +
> +static void
> +decode_family(struct tcb *const tcp, const uint8_t family,
> +	      const kernel_ulong_t addr, const unsigned int len)
> +{
> +	tprints("{family=");
> +	printxval(addrfams, family, "AF_???");
> +	if (len > sizeof(family)) {
> +		tprints(", ");
> +		printstr_ex(tcp, addr + sizeof(family),
> +			    len - sizeof(family), QUOTE_FORCE_HEX);
> +	}
> +	tprints("}");
> +}
> +
> +bool
> +decode_netlink_route(struct tcb *const tcp,
> +		     const struct nlmsghdr *const nlmsghdr,
> +		     const kernel_ulong_t addr,
> +		     const unsigned int len)
> +{
> +	uint8_t family;
> +
> +	if (nlmsghdr->nlmsg_type == NLMSG_DONE)
> +		return false;

Thanks, I've merged the series.

Please note that "nlmsghdr->nlmsg_type == NLMSG_DONE" branch of this
statement is not covered by tests yet.


-- 
ldv
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 801 bytes
Desc: not available
URL: <http://lists.strace.io/pipermail/strace-devel/attachments/20170809/0ff2d22e/attachment.bin>


More information about the Strace-devel mailing list