Merge branch 'iproute2-master' into next
Signed-off-by: David Ahern <dsahern@gmail.com>
This commit is contained in:
commit
10fb5faec1
|
|
@ -8,8 +8,8 @@
|
||||||
|
|
||||||
void print_vlan_info(struct rtattr *tb, int ifindex);
|
void print_vlan_info(struct rtattr *tb, int ifindex);
|
||||||
int print_linkinfo(struct nlmsghdr *n, void *arg);
|
int print_linkinfo(struct nlmsghdr *n, void *arg);
|
||||||
|
int print_mdb_mon(struct nlmsghdr *n, void *arg);
|
||||||
int print_fdb(struct nlmsghdr *n, void *arg);
|
int print_fdb(struct nlmsghdr *n, void *arg);
|
||||||
int print_mdb(struct nlmsghdr *n, void *arg);
|
|
||||||
|
|
||||||
int do_fdb(int argc, char **argv);
|
int do_fdb(int argc, char **argv);
|
||||||
int do_mdb(int argc, char **argv);
|
int do_mdb(int argc, char **argv);
|
||||||
|
|
|
||||||
78
bridge/mdb.c
78
bridge/mdb.c
|
|
@ -132,9 +132,6 @@ static void print_mdb_entry(FILE *f, int ifindex, const struct br_mdb_entry *e,
|
||||||
|
|
||||||
open_json_object(NULL);
|
open_json_object(NULL);
|
||||||
|
|
||||||
if (n->nlmsg_type == RTM_DELMDB)
|
|
||||||
print_bool(PRINT_ANY, "deleted", "Deleted ", true);
|
|
||||||
|
|
||||||
print_int(PRINT_ANY, "index", "%u: ", ifindex);
|
print_int(PRINT_ANY, "index", "%u: ", ifindex);
|
||||||
print_color_string(PRINT_ANY, COLOR_IFNAME, "dev", "%s ", dev);
|
print_color_string(PRINT_ANY, COLOR_IFNAME, "dev", "%s ", dev);
|
||||||
print_string(PRINT_ANY, "port", " %s ",
|
print_string(PRINT_ANY, "port", " %s ",
|
||||||
|
|
@ -189,10 +186,8 @@ static void print_mdb_entries(FILE *fp, struct nlmsghdr *n,
|
||||||
int rem = RTA_PAYLOAD(mdb);
|
int rem = RTA_PAYLOAD(mdb);
|
||||||
struct rtattr *i;
|
struct rtattr *i;
|
||||||
|
|
||||||
open_json_array(PRINT_JSON, "mdb");
|
|
||||||
for (i = RTA_DATA(mdb); RTA_OK(i, rem); i = RTA_NEXT(i, rem))
|
for (i = RTA_DATA(mdb); RTA_OK(i, rem); i = RTA_NEXT(i, rem))
|
||||||
br_print_mdb_entry(fp, ifindex, i, n);
|
br_print_mdb_entry(fp, ifindex, i, n);
|
||||||
close_json_array(PRINT_JSON, NULL);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void print_router_entries(FILE *fp, struct nlmsghdr *n,
|
static void print_router_entries(FILE *fp, struct nlmsghdr *n,
|
||||||
|
|
@ -200,7 +195,6 @@ static void print_router_entries(FILE *fp, struct nlmsghdr *n,
|
||||||
{
|
{
|
||||||
const char *brifname = ll_index_to_name(ifindex);
|
const char *brifname = ll_index_to_name(ifindex);
|
||||||
|
|
||||||
open_json_array(PRINT_JSON, "router");
|
|
||||||
if (n->nlmsg_type == RTM_GETMDB) {
|
if (n->nlmsg_type == RTM_GETMDB) {
|
||||||
if (show_details)
|
if (show_details)
|
||||||
br_print_router_ports(fp, router, brifname);
|
br_print_router_ports(fp, router, brifname);
|
||||||
|
|
@ -222,15 +216,12 @@ static void print_router_entries(FILE *fp, struct nlmsghdr *n,
|
||||||
port_name, brifname);
|
port_name, brifname);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
close_json_array(PRINT_JSON, NULL);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int print_mdb(struct nlmsghdr *n, void *arg)
|
static int __parse_mdb_nlmsg(struct nlmsghdr *n, struct rtattr **tb)
|
||||||
{
|
{
|
||||||
FILE *fp = arg;
|
|
||||||
struct br_port_msg *r = NLMSG_DATA(n);
|
struct br_port_msg *r = NLMSG_DATA(n);
|
||||||
int len = n->nlmsg_len;
|
int len = n->nlmsg_len;
|
||||||
struct rtattr *tb[MDBA_MAX+1];
|
|
||||||
|
|
||||||
if (n->nlmsg_type != RTM_GETMDB &&
|
if (n->nlmsg_type != RTM_GETMDB &&
|
||||||
n->nlmsg_type != RTM_NEWMDB &&
|
n->nlmsg_type != RTM_NEWMDB &&
|
||||||
|
|
@ -253,6 +244,54 @@ int print_mdb(struct nlmsghdr *n, void *arg)
|
||||||
|
|
||||||
parse_rtattr(tb, MDBA_MAX, MDBA_RTA(r), n->nlmsg_len - NLMSG_LENGTH(sizeof(*r)));
|
parse_rtattr(tb, MDBA_MAX, MDBA_RTA(r), n->nlmsg_len - NLMSG_LENGTH(sizeof(*r)));
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int print_mdbs(struct nlmsghdr *n, void *arg)
|
||||||
|
{
|
||||||
|
struct br_port_msg *r = NLMSG_DATA(n);
|
||||||
|
struct rtattr *tb[MDBA_MAX+1];
|
||||||
|
FILE *fp = arg;
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
ret = __parse_mdb_nlmsg(n, tb);
|
||||||
|
if (ret != 1)
|
||||||
|
return ret;
|
||||||
|
|
||||||
|
if (tb[MDBA_MDB])
|
||||||
|
print_mdb_entries(fp, n, r->ifindex, tb[MDBA_MDB]);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int print_rtrs(struct nlmsghdr *n, void *arg)
|
||||||
|
{
|
||||||
|
struct br_port_msg *r = NLMSG_DATA(n);
|
||||||
|
struct rtattr *tb[MDBA_MAX+1];
|
||||||
|
FILE *fp = arg;
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
ret = __parse_mdb_nlmsg(n, tb);
|
||||||
|
if (ret != 1)
|
||||||
|
return ret;
|
||||||
|
|
||||||
|
if (tb[MDBA_ROUTER])
|
||||||
|
print_router_entries(fp, n, r->ifindex, tb[MDBA_ROUTER]);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int print_mdb_mon(struct nlmsghdr *n, void *arg)
|
||||||
|
{
|
||||||
|
struct br_port_msg *r = NLMSG_DATA(n);
|
||||||
|
struct rtattr *tb[MDBA_MAX+1];
|
||||||
|
FILE *fp = arg;
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
ret = __parse_mdb_nlmsg(n, tb);
|
||||||
|
if (ret != 1)
|
||||||
|
return ret;
|
||||||
|
|
||||||
if (n->nlmsg_type == RTM_DELMDB)
|
if (n->nlmsg_type == RTM_DELMDB)
|
||||||
print_bool(PRINT_ANY, "deleted", "Deleted ", true);
|
print_bool(PRINT_ANY, "deleted", "Deleted ", true);
|
||||||
|
|
||||||
|
|
@ -291,6 +330,7 @@ static int mdb_show(int argc, char **argv)
|
||||||
}
|
}
|
||||||
|
|
||||||
new_json_obj(json);
|
new_json_obj(json);
|
||||||
|
open_json_object(NULL);
|
||||||
|
|
||||||
/* get mdb entries */
|
/* get mdb entries */
|
||||||
if (rtnl_mdbdump_req(&rth, PF_BRIDGE) < 0) {
|
if (rtnl_mdbdump_req(&rth, PF_BRIDGE) < 0) {
|
||||||
|
|
@ -298,11 +338,27 @@ static int mdb_show(int argc, char **argv)
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (rtnl_dump_filter(&rth, print_mdb, stdout) < 0) {
|
open_json_array(PRINT_JSON, "mdb");
|
||||||
|
if (rtnl_dump_filter(&rth, print_mdbs, stdout) < 0) {
|
||||||
fprintf(stderr, "Dump terminated\n");
|
fprintf(stderr, "Dump terminated\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
close_json_array(PRINT_JSON, NULL);
|
||||||
|
|
||||||
|
/* get router ports */
|
||||||
|
if (rtnl_mdbdump_req(&rth, PF_BRIDGE) < 0) {
|
||||||
|
perror("Cannot send dump request");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
open_json_object("router");
|
||||||
|
if (rtnl_dump_filter(&rth, print_rtrs, stdout) < 0) {
|
||||||
|
fprintf(stderr, "Dump terminated\n");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
close_json_object();
|
||||||
|
|
||||||
|
close_json_object();
|
||||||
delete_json_obj();
|
delete_json_obj();
|
||||||
fflush(stdout);
|
fflush(stdout);
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -61,7 +61,7 @@ static int accept_msg(struct rtnl_ctrl_data *ctrl,
|
||||||
case RTM_DELMDB:
|
case RTM_DELMDB:
|
||||||
if (prefix_banner)
|
if (prefix_banner)
|
||||||
fprintf(fp, "[MDB]");
|
fprintf(fp, "[MDB]");
|
||||||
return print_mdb(n, arg);
|
return print_mdb_mon(n, arg);
|
||||||
|
|
||||||
case NLMSG_TSTAMP:
|
case NLMSG_TSTAMP:
|
||||||
print_nlmsg_timestamp(fp, n);
|
print_nlmsg_timestamp(fp, n);
|
||||||
|
|
|
||||||
|
|
@ -252,10 +252,10 @@ static int filter_vlan_check(__u16 vid, __u16 flags)
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void open_vlan_port(int ifi_index)
|
static void open_vlan_port(int ifi_index, const char *fmt)
|
||||||
{
|
{
|
||||||
open_json_object(NULL);
|
open_json_object(NULL);
|
||||||
print_string(PRINT_ANY, "ifname", "%s",
|
print_color_string(PRINT_ANY, COLOR_IFNAME, "ifname", fmt,
|
||||||
ll_index_to_name(ifi_index));
|
ll_index_to_name(ifi_index));
|
||||||
open_json_array(PRINT_JSON, "vlans");
|
open_json_array(PRINT_JSON, "vlans");
|
||||||
}
|
}
|
||||||
|
|
@ -286,7 +286,7 @@ static void print_vlan_tunnel_info(FILE *fp, struct rtattr *tb, int ifindex)
|
||||||
__u32 last_tunid_start = 0;
|
__u32 last_tunid_start = 0;
|
||||||
|
|
||||||
if (!filter_vlan)
|
if (!filter_vlan)
|
||||||
open_vlan_port(ifindex);
|
open_vlan_port(ifindex, "%s");
|
||||||
|
|
||||||
open_json_array(PRINT_JSON, "tunnel");
|
open_json_array(PRINT_JSON, "tunnel");
|
||||||
for (i = RTA_DATA(list); RTA_OK(i, rem); i = RTA_NEXT(i, rem)) {
|
for (i = RTA_DATA(list); RTA_OK(i, rem); i = RTA_NEXT(i, rem)) {
|
||||||
|
|
@ -331,7 +331,7 @@ static void print_vlan_tunnel_info(FILE *fp, struct rtattr *tb, int ifindex)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (filter_vlan)
|
if (filter_vlan)
|
||||||
open_vlan_port(ifindex);
|
open_vlan_port(ifindex, "%s");
|
||||||
|
|
||||||
open_json_object(NULL);
|
open_json_object(NULL);
|
||||||
print_range("vlan", last_vid_start, tunnel_vid);
|
print_range("vlan", last_vid_start, tunnel_vid);
|
||||||
|
|
@ -463,7 +463,7 @@ static void print_one_vlan_stats(const struct bridge_vlan_xstats *vstats)
|
||||||
print_lluint(PRINT_ANY, "tx_bytes",
|
print_lluint(PRINT_ANY, "tx_bytes",
|
||||||
" TX: %llu bytes",
|
" TX: %llu bytes",
|
||||||
vstats->tx_bytes);
|
vstats->tx_bytes);
|
||||||
print_lluint(PRINT_ANY, "tx_packets", " %llu packets",
|
print_lluint(PRINT_ANY, "tx_packets", " %llu packets\n",
|
||||||
vstats->tx_packets);
|
vstats->tx_packets);
|
||||||
close_json_object();
|
close_json_object();
|
||||||
}
|
}
|
||||||
|
|
@ -472,7 +472,7 @@ static void print_vlan_stats_attr(struct rtattr *attr, int ifindex)
|
||||||
{
|
{
|
||||||
struct rtattr *brtb[LINK_XSTATS_TYPE_MAX+1];
|
struct rtattr *brtb[LINK_XSTATS_TYPE_MAX+1];
|
||||||
struct rtattr *i, *list;
|
struct rtattr *i, *list;
|
||||||
const char *ifname;
|
bool found_vlan = false;
|
||||||
int rem;
|
int rem;
|
||||||
|
|
||||||
parse_rtattr(brtb, LINK_XSTATS_TYPE_MAX, RTA_DATA(attr),
|
parse_rtattr(brtb, LINK_XSTATS_TYPE_MAX, RTA_DATA(attr),
|
||||||
|
|
@ -483,12 +483,6 @@ static void print_vlan_stats_attr(struct rtattr *attr, int ifindex)
|
||||||
list = brtb[LINK_XSTATS_TYPE_BRIDGE];
|
list = brtb[LINK_XSTATS_TYPE_BRIDGE];
|
||||||
rem = RTA_PAYLOAD(list);
|
rem = RTA_PAYLOAD(list);
|
||||||
|
|
||||||
ifname = ll_index_to_name(ifindex);
|
|
||||||
open_vlan_port(ifindex);
|
|
||||||
|
|
||||||
print_color_string(PRINT_FP, COLOR_IFNAME,
|
|
||||||
NULL, "%-16s", ifname);
|
|
||||||
|
|
||||||
for (i = RTA_DATA(list); RTA_OK(i, rem); i = RTA_NEXT(i, rem)) {
|
for (i = RTA_DATA(list); RTA_OK(i, rem); i = RTA_NEXT(i, rem)) {
|
||||||
const struct bridge_vlan_xstats *vstats = RTA_DATA(i);
|
const struct bridge_vlan_xstats *vstats = RTA_DATA(i);
|
||||||
|
|
||||||
|
|
@ -503,8 +497,18 @@ static void print_vlan_stats_attr(struct rtattr *attr, int ifindex)
|
||||||
!(vstats->flags & BRIDGE_VLAN_INFO_BRENTRY))
|
!(vstats->flags & BRIDGE_VLAN_INFO_BRENTRY))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
/* found vlan stats, first time print the interface name */
|
||||||
|
if (!found_vlan) {
|
||||||
|
open_vlan_port(ifindex, "%-16s");
|
||||||
|
found_vlan = true;
|
||||||
|
} else {
|
||||||
|
print_string(PRINT_FP, NULL, "%-16s", "");
|
||||||
|
}
|
||||||
print_one_vlan_stats(vstats);
|
print_one_vlan_stats(vstats);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* vlan_port is opened only if there are any vlan stats */
|
||||||
|
if (found_vlan)
|
||||||
close_vlan_port();
|
close_vlan_port();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -632,7 +636,7 @@ void print_vlan_info(struct rtattr *tb, int ifindex)
|
||||||
int rem = RTA_PAYLOAD(list);
|
int rem = RTA_PAYLOAD(list);
|
||||||
__u16 last_vid_start = 0;
|
__u16 last_vid_start = 0;
|
||||||
|
|
||||||
open_vlan_port(ifindex);
|
open_vlan_port(ifindex, "%s");
|
||||||
|
|
||||||
for (i = RTA_DATA(list); RTA_OK(i, rem); i = RTA_NEXT(i, rem)) {
|
for (i = RTA_DATA(list); RTA_OK(i, rem); i = RTA_NEXT(i, rem)) {
|
||||||
struct bridge_vlan_info *vinfo;
|
struct bridge_vlan_info *vinfo;
|
||||||
|
|
|
||||||
|
|
@ -274,8 +274,6 @@ int print_rule(struct nlmsghdr *n, void *arg)
|
||||||
"src", "%s", src);
|
"src", "%s", src);
|
||||||
if (frh->src_len != host_len)
|
if (frh->src_len != host_len)
|
||||||
print_uint(PRINT_ANY, "srclen", "/%u", frh->src_len);
|
print_uint(PRINT_ANY, "srclen", "/%u", frh->src_len);
|
||||||
else
|
|
||||||
print_string(PRINT_FP, NULL, " ", NULL);
|
|
||||||
} else if (frh->src_len) {
|
} else if (frh->src_len) {
|
||||||
print_string(PRINT_ANY, "src", "from %s", "0");
|
print_string(PRINT_ANY, "src", "from %s", "0");
|
||||||
print_uint(PRINT_ANY, "srclen", "/%u", frh->src_len);
|
print_uint(PRINT_ANY, "srclen", "/%u", frh->src_len);
|
||||||
|
|
@ -291,8 +289,6 @@ int print_rule(struct nlmsghdr *n, void *arg)
|
||||||
"dst", "%s", dst);
|
"dst", "%s", dst);
|
||||||
if (frh->dst_len != host_len)
|
if (frh->dst_len != host_len)
|
||||||
print_uint(PRINT_ANY, "dstlen", "/%u", frh->dst_len);
|
print_uint(PRINT_ANY, "dstlen", "/%u", frh->dst_len);
|
||||||
else
|
|
||||||
print_string(PRINT_FP, NULL, " ", NULL);
|
|
||||||
} else if (frh->dst_len) {
|
} else if (frh->dst_len) {
|
||||||
print_string(PRINT_ANY, "dst", " to %s", "0");
|
print_string(PRINT_ANY, "dst", " to %s", "0");
|
||||||
print_uint(PRINT_ANY, "dstlen", "/%u", frh->dst_len);
|
print_uint(PRINT_ANY, "dstlen", "/%u", frh->dst_len);
|
||||||
|
|
@ -431,6 +427,8 @@ int print_rule(struct nlmsghdr *n, void *arg)
|
||||||
print_string(PRINT_ANY,
|
print_string(PRINT_ANY,
|
||||||
"flow_from", " realms %s/",
|
"flow_from", " realms %s/",
|
||||||
rtnl_rtrealm_n2a(from, b1, sizeof(b1)));
|
rtnl_rtrealm_n2a(from, b1, sizeof(b1)));
|
||||||
|
else
|
||||||
|
print_string(PRINT_FP, NULL, " realms ", NULL);
|
||||||
|
|
||||||
print_string(PRINT_ANY, "flow_to", "%s",
|
print_string(PRINT_ANY, "flow_to", "%s",
|
||||||
rtnl_rtrealm_n2a(to, b1, sizeof(b1)));
|
rtnl_rtrealm_n2a(to, b1, sizeof(b1)));
|
||||||
|
|
|
||||||
|
|
@ -8,8 +8,8 @@
|
||||||
|
|
||||||
%locations
|
%locations
|
||||||
%token-table
|
%token-table
|
||||||
%error-verbose
|
%define parse.error verbose
|
||||||
%name-prefix "ematch_"
|
%define api.prefix {ematch_}
|
||||||
|
|
||||||
%union {
|
%union {
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue