From: Nikolay Aleksandrov Date: Wed, 15 Feb 2017 14:23:13 +0000 (+0100) Subject: iplink: bridge_slave: add support for displaying xstats X-Git-Tag: v4.11.0~52 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=217264a0793dfe867c8db359efee361b3dba7ce8;p=thirdparty%2Fiproute2.git iplink: bridge_slave: add support for displaying xstats This patch adds support to the bridge_slave link type for displaying xstats by reusing the previously added bridge xstats callbacks. Signed-off-by: Nikolay Aleksandrov --- diff --git a/ip/ip_common.h b/ip/ip_common.h index e046b57e9..abb2b8d5d 100644 --- a/ip/ip_common.h +++ b/ip/ip_common.h @@ -98,6 +98,9 @@ struct link_util { struct link_util *get_link_kind(const char *kind); void br_dump_bridge_id(const struct ifla_bridge_id *id, char *buf, size_t len); +int bridge_parse_xstats(struct link_util *lu, int argc, char **argv); +int bridge_print_xstats(const struct sockaddr_nl *who, + struct nlmsghdr *n, void *arg); __u32 ipvrf_get_table(const char *name); int name_is_vrf(const char *name); diff --git a/ip/iplink_bridge.c b/ip/iplink_bridge.c index 62ceee6b5..818b43c89 100644 --- a/ip/iplink_bridge.c +++ b/ip/iplink_bridge.c @@ -680,8 +680,8 @@ static void bridge_print_stats_attr(FILE *f, struct rtattr *attr, int ifindex) } } -static int bridge_print_xstats(const struct sockaddr_nl *who, - struct nlmsghdr *n, void *arg) +int bridge_print_xstats(const struct sockaddr_nl *who, + struct nlmsghdr *n, void *arg) { struct if_stats_msg *ifsm = NLMSG_DATA(n); struct rtattr *tb[IFLA_STATS_MAX+1]; @@ -708,7 +708,7 @@ static int bridge_print_xstats(const struct sockaddr_nl *who, return 0; } -static int bridge_parse_xstats(struct link_util *lu, int argc, char **argv) +int bridge_parse_xstats(struct link_util *lu, int argc, char **argv) { while (argc > 0) { if (strcmp(*argv, "igmp") == 0 || strcmp(*argv, "mcast") == 0) { diff --git a/ip/iplink_bridge_slave.c b/ip/iplink_bridge_slave.c index 6353fc533..3e883328a 100644 --- a/ip/iplink_bridge_slave.c +++ b/ip/iplink_bridge_slave.c @@ -312,4 +312,6 @@ struct link_util bridge_slave_link_util = { .print_opt = bridge_slave_print_opt, .parse_opt = bridge_slave_parse_opt, .print_help = bridge_slave_print_help, + .parse_ifla_xstats = bridge_parse_xstats, + .print_ifla_xstats = bridge_print_xstats, };