]>
git.proxmox.com Git - mirror_iproute2.git/blob - ip/ipmonitor.c
2 * ipmonitor.c "ip monitor".
4 * This program is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU General Public License
6 * as published by the Free Software Foundation; either version
7 * 2 of the License, or (at your option) any later version.
9 * Authors: Alexey Kuznetsov, <kuznet@ms2.inr.ac.ru>
18 #include <sys/socket.h>
19 #include <netinet/in.h>
20 #include <arpa/inet.h>
25 #include "ip_common.h"
27 static void usage(void) __attribute__((noreturn
));
30 static void usage(void)
32 fprintf(stderr
, "Usage: ip monitor [ all | LISTofOBJECTS ] [ FILE ]"
33 "[ label ] [dev DEVICE]\n");
34 fprintf(stderr
, "LISTofOBJECTS := link | address | route | mroute | prefix |\n");
35 fprintf(stderr
, " neigh | netconf | rule | nsid\n");
36 fprintf(stderr
, "FILE := file FILENAME\n");
40 static int accept_msg(const struct sockaddr_nl
*who
,
41 struct rtnl_ctrl_data
*ctrl
,
42 struct nlmsghdr
*n
, void *arg
)
44 FILE *fp
= (FILE*)arg
;
46 if (n
->nlmsg_type
== RTM_NEWROUTE
|| n
->nlmsg_type
== RTM_DELROUTE
) {
47 struct rtmsg
*r
= NLMSG_DATA(n
);
48 int len
= n
->nlmsg_len
- NLMSG_LENGTH(sizeof(*r
));
51 fprintf(stderr
, "BUG: wrong nlmsg len %d\n", len
);
55 if (r
->rtm_flags
& RTM_F_CLONED
)
61 if (r
->rtm_family
== RTNL_FAMILY_IPMR
||
62 r
->rtm_family
== RTNL_FAMILY_IP6MR
) {
64 fprintf(fp
, "[MROUTE]");
65 print_mroute(who
, n
, arg
);
69 fprintf(fp
, "[ROUTE]");
70 print_route(who
, n
, arg
);
78 if (n
->nlmsg_type
== RTM_NEWLINK
|| n
->nlmsg_type
== RTM_DELLINK
) {
79 ll_remember_index(who
, n
, NULL
);
81 fprintf(fp
, "[LINK]");
82 print_linkinfo(who
, n
, arg
);
85 if (n
->nlmsg_type
== RTM_NEWADDR
|| n
->nlmsg_type
== RTM_DELADDR
) {
87 fprintf(fp
, "[ADDR]");
88 print_addrinfo(who
, n
, arg
);
91 if (n
->nlmsg_type
== RTM_NEWADDRLABEL
|| n
->nlmsg_type
== RTM_DELADDRLABEL
) {
93 fprintf(fp
, "[ADDRLABEL]");
94 print_addrlabel(who
, n
, arg
);
97 if (n
->nlmsg_type
== RTM_NEWNEIGH
|| n
->nlmsg_type
== RTM_DELNEIGH
||
98 n
->nlmsg_type
== RTM_GETNEIGH
) {
99 if (preferred_family
) {
100 struct ndmsg
*r
= NLMSG_DATA(n
);
102 if (r
->ndm_family
!= preferred_family
)
107 fprintf(fp
, "[NEIGH]");
108 print_neigh(who
, n
, arg
);
111 if (n
->nlmsg_type
== RTM_NEWPREFIX
) {
113 fprintf(fp
, "[PREFIX]");
114 print_prefix(who
, n
, arg
);
117 if (n
->nlmsg_type
== RTM_NEWRULE
|| n
->nlmsg_type
== RTM_DELRULE
) {
119 fprintf(fp
, "[RULE]");
120 print_rule(who
, n
, arg
);
123 if (n
->nlmsg_type
== RTM_NEWNETCONF
) {
125 fprintf(fp
, "[NETCONF]");
126 print_netconf(who
, ctrl
, n
, arg
);
129 if (n
->nlmsg_type
== NLMSG_TSTAMP
) {
130 print_nlmsg_timestamp(fp
, n
);
133 if (n
->nlmsg_type
== RTM_NEWNSID
|| n
->nlmsg_type
== RTM_DELNSID
) {
135 fprintf(fp
, "[NSID]");
136 print_nsid(who
, n
, arg
);
139 if (n
->nlmsg_type
!= NLMSG_ERROR
&& n
->nlmsg_type
!= NLMSG_NOOP
&&
140 n
->nlmsg_type
!= NLMSG_DONE
) {
141 fprintf(fp
, "Unknown message: type=0x%08x(%d) flags=0x%08x(%d)"
142 "len=0x%08x(%d)\n", n
->nlmsg_type
, n
->nlmsg_type
,
143 n
->nlmsg_flags
, n
->nlmsg_flags
, n
->nlmsg_len
,
149 int do_ipmonitor(int argc
, char **argv
)
164 groups
|= nl_mgrp(RTNLGRP_LINK
);
165 groups
|= nl_mgrp(RTNLGRP_IPV4_IFADDR
);
166 groups
|= nl_mgrp(RTNLGRP_IPV6_IFADDR
);
167 groups
|= nl_mgrp(RTNLGRP_IPV4_ROUTE
);
168 groups
|= nl_mgrp(RTNLGRP_IPV6_ROUTE
);
169 groups
|= nl_mgrp(RTNLGRP_MPLS_ROUTE
);
170 groups
|= nl_mgrp(RTNLGRP_IPV4_MROUTE
);
171 groups
|= nl_mgrp(RTNLGRP_IPV6_MROUTE
);
172 groups
|= nl_mgrp(RTNLGRP_IPV6_PREFIX
);
173 groups
|= nl_mgrp(RTNLGRP_NEIGH
);
174 groups
|= nl_mgrp(RTNLGRP_IPV4_NETCONF
);
175 groups
|= nl_mgrp(RTNLGRP_IPV6_NETCONF
);
176 groups
|= nl_mgrp(RTNLGRP_IPV4_RULE
);
177 groups
|= nl_mgrp(RTNLGRP_IPV6_RULE
);
178 groups
|= nl_mgrp(RTNLGRP_NSID
);
183 if (matches(*argv
, "file") == 0) {
186 } else if (matches(*argv
, "label") == 0) {
188 } else if (matches(*argv
, "link") == 0) {
191 } else if (matches(*argv
, "address") == 0) {
194 } else if (matches(*argv
, "route") == 0) {
197 } else if (matches(*argv
, "mroute") == 0) {
200 } else if (matches(*argv
, "prefix") == 0) {
203 } else if (matches(*argv
, "neigh") == 0) {
206 } else if (matches(*argv
, "netconf") == 0) {
209 } else if (matches(*argv
, "rule") == 0) {
212 } else if (matches(*argv
, "nsid") == 0) {
215 } else if (strcmp(*argv
, "all") == 0) {
217 } else if (matches(*argv
, "help") == 0) {
219 } else if (strcmp(*argv
, "dev") == 0) {
222 ifindex
= ll_name_to_index(*argv
);
224 invarg("Device does not exist\n", *argv
);
226 fprintf(stderr
, "Argument \"%s\" is unknown, try \"ip monitor help\".\n", *argv
);
232 ipaddr_reset_filter(1, ifindex
);
233 iproute_reset_filter(ifindex
);
234 ipmroute_reset_filter(ifindex
);
235 ipneigh_reset_filter(ifindex
);
236 ipnetconf_reset_filter(ifindex
);
239 groups
|= nl_mgrp(RTNLGRP_LINK
);
241 if (!preferred_family
|| preferred_family
== AF_INET
)
242 groups
|= nl_mgrp(RTNLGRP_IPV4_IFADDR
);
243 if (!preferred_family
|| preferred_family
== AF_INET6
)
244 groups
|= nl_mgrp(RTNLGRP_IPV6_IFADDR
);
247 if (!preferred_family
|| preferred_family
== AF_INET
)
248 groups
|= nl_mgrp(RTNLGRP_IPV4_ROUTE
);
249 if (!preferred_family
|| preferred_family
== AF_INET6
)
250 groups
|= nl_mgrp(RTNLGRP_IPV6_ROUTE
);
251 if (!preferred_family
|| preferred_family
== AF_MPLS
)
252 groups
|= nl_mgrp(RTNLGRP_MPLS_ROUTE
);
255 if (!preferred_family
|| preferred_family
== AF_INET
)
256 groups
|= nl_mgrp(RTNLGRP_IPV4_MROUTE
);
257 if (!preferred_family
|| preferred_family
== AF_INET6
)
258 groups
|= nl_mgrp(RTNLGRP_IPV6_MROUTE
);
261 if (!preferred_family
|| preferred_family
== AF_INET6
)
262 groups
|= nl_mgrp(RTNLGRP_IPV6_PREFIX
);
265 groups
|= nl_mgrp(RTNLGRP_NEIGH
);
268 if (!preferred_family
|| preferred_family
== AF_INET
)
269 groups
|= nl_mgrp(RTNLGRP_IPV4_NETCONF
);
270 if (!preferred_family
|| preferred_family
== AF_INET6
)
271 groups
|= nl_mgrp(RTNLGRP_IPV6_NETCONF
);
274 if (!preferred_family
|| preferred_family
== AF_INET
)
275 groups
|= nl_mgrp(RTNLGRP_IPV4_RULE
);
276 if (!preferred_family
|| preferred_family
== AF_INET6
)
277 groups
|= nl_mgrp(RTNLGRP_IPV6_RULE
);
280 groups
|= nl_mgrp(RTNLGRP_NSID
);
284 fp
= fopen(file
, "r");
286 perror("Cannot fopen");
289 return rtnl_from_file(fp
, accept_msg
, stdout
);
292 if (rtnl_open(&rth
, groups
) < 0)
297 if (rtnl_listen(&rth
, accept_msg
, stdout
) < 0)