Commit 4b6e07d8 authored by Varun Chandramohan's avatar Varun Chandramohan Committed by Stephen Hemminger

Enable Type Labels For "ip monitor all"

This patch adds prefix lables for "ip monitor all" command to simplfy
understanding of the output.
Signed-off-by: default avatarVarun Chandramohan <varunc@linux.vnet.ibm.com>
parent fb063322
...@@ -25,6 +25,7 @@ ...@@ -25,6 +25,7 @@
#include "ip_common.h" #include "ip_common.h"
static void usage(void) __attribute__((noreturn)); static void usage(void) __attribute__((noreturn));
int prefix_banner;
static void usage(void) static void usage(void)
{ {
...@@ -42,31 +43,45 @@ int accept_msg(const struct sockaddr_nl *who, ...@@ -42,31 +43,45 @@ int accept_msg(const struct sockaddr_nl *who,
print_timestamp(fp); print_timestamp(fp);
if (n->nlmsg_type == RTM_NEWROUTE || n->nlmsg_type == RTM_DELROUTE) { if (n->nlmsg_type == RTM_NEWROUTE || n->nlmsg_type == RTM_DELROUTE) {
if (prefix_banner)
fprintf(fp, "[ROUTE]");
print_route(who, n, arg); print_route(who, n, arg);
return 0; return 0;
} }
if (n->nlmsg_type == RTM_NEWLINK || n->nlmsg_type == RTM_DELLINK) { if (n->nlmsg_type == RTM_NEWLINK || n->nlmsg_type == RTM_DELLINK) {
ll_remember_index(who, n, NULL); ll_remember_index(who, n, NULL);
if (prefix_banner)
fprintf(fp, "[LINK]");
print_linkinfo(who, n, arg); print_linkinfo(who, n, arg);
return 0; return 0;
} }
if (n->nlmsg_type == RTM_NEWADDR || n->nlmsg_type == RTM_DELADDR) { if (n->nlmsg_type == RTM_NEWADDR || n->nlmsg_type == RTM_DELADDR) {
if (prefix_banner)
fprintf(fp, "[ADDR]");
print_addrinfo(who, n, arg); print_addrinfo(who, n, arg);
return 0; return 0;
} }
if (n->nlmsg_type == RTM_NEWADDRLABEL || n->nlmsg_type == RTM_DELADDRLABEL) { if (n->nlmsg_type == RTM_NEWADDRLABEL || n->nlmsg_type == RTM_DELADDRLABEL) {
if (prefix_banner)
fprintf(fp, "[ADDRLABEL]");
print_addrlabel(who, n, arg); print_addrlabel(who, n, arg);
return 0; return 0;
} }
if (n->nlmsg_type == RTM_NEWNEIGH || n->nlmsg_type == RTM_DELNEIGH) { if (n->nlmsg_type == RTM_NEWNEIGH || n->nlmsg_type == RTM_DELNEIGH) {
if (prefix_banner)
fprintf(fp, "[NEIGH]");
print_neigh(who, n, arg); print_neigh(who, n, arg);
return 0; return 0;
} }
if (n->nlmsg_type == RTM_NEWPREFIX) { if (n->nlmsg_type == RTM_NEWPREFIX) {
if (prefix_banner)
fprintf(fp, "[PREFIX]");
print_prefix(who, n, arg); print_prefix(who, n, arg);
return 0; return 0;
} }
if (n->nlmsg_type == RTM_NEWRULE || n->nlmsg_type == RTM_DELRULE) { if (n->nlmsg_type == RTM_NEWRULE || n->nlmsg_type == RTM_DELRULE) {
if (prefix_banner)
fprintf(fp, "[RULE]");
print_rule(who, n, arg); print_rule(who, n, arg);
return 0; return 0;
} }
...@@ -130,6 +145,7 @@ int do_ipmonitor(int argc, char **argv) ...@@ -130,6 +145,7 @@ int do_ipmonitor(int argc, char **argv)
groups = 0; groups = 0;
} else if (strcmp(*argv, "all") == 0) { } else if (strcmp(*argv, "all") == 0) {
groups = ~RTMGRP_TC; groups = ~RTMGRP_TC;
prefix_banner=1;
} else if (matches(*argv, "help") == 0) { } else if (matches(*argv, "help") == 0) {
usage(); usage();
} else { } else {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment