]>
git.proxmox.com Git - mirror_iproute2.git/blob - ip/ipmonitor.c
70f2a7adbae1f1c00ca1774919e3b250b44fe489
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 ] [ label ]\n");
33 fprintf(stderr
, "LISTofOBJECTS := link | address | route | mroute | prefix |\n");
34 fprintf(stderr
, " neigh | netconf\n");
35 fprintf(stderr
, "FILE := file FILENAME\n");
39 static int accept_msg(const struct sockaddr_nl
*who
,
40 struct nlmsghdr
*n
, void *arg
)
42 FILE *fp
= (FILE*)arg
;
47 if (n
->nlmsg_type
== RTM_NEWROUTE
|| n
->nlmsg_type
== RTM_DELROUTE
) {
48 struct rtmsg
*r
= NLMSG_DATA(n
);
49 int len
= n
->nlmsg_len
- NLMSG_LENGTH(sizeof(*r
));
52 fprintf(stderr
, "BUG: wrong nlmsg len %d\n", len
);
56 if (r
->rtm_family
== RTNL_FAMILY_IPMR
||
57 r
->rtm_family
== RTNL_FAMILY_IP6MR
) {
59 fprintf(fp
, "[MROUTE]");
60 print_mroute(who
, n
, arg
);
64 fprintf(fp
, "[ROUTE]");
65 print_route(who
, n
, arg
);
69 if (n
->nlmsg_type
== RTM_NEWLINK
|| n
->nlmsg_type
== RTM_DELLINK
) {
70 ll_remember_index(who
, n
, NULL
);
72 fprintf(fp
, "[LINK]");
73 print_linkinfo(who
, n
, arg
);
76 if (n
->nlmsg_type
== RTM_NEWADDR
|| n
->nlmsg_type
== RTM_DELADDR
) {
78 fprintf(fp
, "[ADDR]");
79 print_addrinfo(who
, n
, arg
);
82 if (n
->nlmsg_type
== RTM_NEWADDRLABEL
|| n
->nlmsg_type
== RTM_DELADDRLABEL
) {
84 fprintf(fp
, "[ADDRLABEL]");
85 print_addrlabel(who
, n
, arg
);
88 if (n
->nlmsg_type
== RTM_NEWNEIGH
|| n
->nlmsg_type
== RTM_DELNEIGH
||
89 n
->nlmsg_type
== RTM_GETNEIGH
) {
90 if (preferred_family
) {
91 struct ndmsg
*r
= NLMSG_DATA(n
);
93 if (r
->ndm_family
!= preferred_family
)
98 fprintf(fp
, "[NEIGH]");
99 print_neigh(who
, n
, arg
);
102 if (n
->nlmsg_type
== RTM_NEWPREFIX
) {
104 fprintf(fp
, "[PREFIX]");
105 print_prefix(who
, n
, arg
);
108 if (n
->nlmsg_type
== RTM_NEWRULE
|| n
->nlmsg_type
== RTM_DELRULE
) {
110 fprintf(fp
, "[RULE]");
111 print_rule(who
, n
, arg
);
114 if (n
->nlmsg_type
== RTM_NEWNETCONF
) {
116 fprintf(fp
, "[NETCONF]");
117 print_netconf(who
, n
, arg
);
120 if (n
->nlmsg_type
== 15) {
122 time_t secs
= ((__u32
*)NLMSG_DATA(n
))[0];
123 long usecs
= ((__u32
*)NLMSG_DATA(n
))[1];
124 tstr
= asctime(localtime(&secs
));
125 tstr
[strlen(tstr
)-1] = 0;
126 fprintf(fp
, "Timestamp: %s %lu us\n", tstr
, usecs
);
129 if (n
->nlmsg_type
== RTM_NEWQDISC
||
130 n
->nlmsg_type
== RTM_DELQDISC
||
131 n
->nlmsg_type
== RTM_NEWTCLASS
||
132 n
->nlmsg_type
== RTM_DELTCLASS
||
133 n
->nlmsg_type
== RTM_NEWTFILTER
||
134 n
->nlmsg_type
== RTM_DELTFILTER
)
136 if (n
->nlmsg_type
!= NLMSG_ERROR
&& n
->nlmsg_type
!= NLMSG_NOOP
&&
137 n
->nlmsg_type
!= NLMSG_DONE
) {
138 fprintf(fp
, "Unknown message: %08x %08x %08x\n",
139 n
->nlmsg_len
, n
->nlmsg_type
, n
->nlmsg_flags
);
144 int do_ipmonitor(int argc
, char **argv
)
147 unsigned groups
= ~RTMGRP_TC
;
157 ipaddr_reset_filter(1);
158 iproute_reset_filter();
159 ipmroute_reset_filter();
160 ipneigh_reset_filter();
163 if (matches(*argv
, "file") == 0) {
166 } else if (matches(*argv
, "label") == 0) {
168 } else if (matches(*argv
, "link") == 0) {
171 } else if (matches(*argv
, "address") == 0) {
174 } else if (matches(*argv
, "route") == 0) {
177 } else if (matches(*argv
, "mroute") == 0) {
180 } else if (matches(*argv
, "prefix") == 0) {
183 } else if (matches(*argv
, "neigh") == 0) {
186 } else if (matches(*argv
, "netconf") == 0) {
189 } else if (strcmp(*argv
, "all") == 0) {
192 } else if (matches(*argv
, "help") == 0) {
195 fprintf(stderr
, "Argument \"%s\" is unknown, try \"ip monitor help\".\n", *argv
);
202 groups
|= nl_mgrp(RTNLGRP_LINK
);
204 if (!preferred_family
|| preferred_family
== AF_INET
)
205 groups
|= nl_mgrp(RTNLGRP_IPV4_IFADDR
);
206 if (!preferred_family
|| preferred_family
== AF_INET6
)
207 groups
|= nl_mgrp(RTNLGRP_IPV6_IFADDR
);
210 if (!preferred_family
|| preferred_family
== AF_INET
)
211 groups
|= nl_mgrp(RTNLGRP_IPV4_ROUTE
);
212 if (!preferred_family
|| preferred_family
== AF_INET6
)
213 groups
|= nl_mgrp(RTNLGRP_IPV6_ROUTE
);
216 if (!preferred_family
|| preferred_family
== AF_INET
)
217 groups
|= nl_mgrp(RTNLGRP_IPV4_MROUTE
);
218 if (!preferred_family
|| preferred_family
== AF_INET6
)
219 groups
|= nl_mgrp(RTNLGRP_IPV6_MROUTE
);
222 if (!preferred_family
|| preferred_family
== AF_INET6
)
223 groups
|= nl_mgrp(RTNLGRP_IPV6_PREFIX
);
226 groups
|= nl_mgrp(RTNLGRP_NEIGH
);
229 if (!preferred_family
|| preferred_family
== AF_INET
)
230 groups
|= nl_mgrp(RTNLGRP_IPV4_NETCONF
);
231 if (!preferred_family
|| preferred_family
== AF_INET6
)
232 groups
|= nl_mgrp(RTNLGRP_IPV6_NETCONF
);
236 fp
= fopen(file
, "r");
238 perror("Cannot fopen");
241 return rtnl_from_file(fp
, accept_msg
, stdout
);
244 if (rtnl_open(&rth
, groups
) < 0)
248 if (rtnl_listen(&rth
, accept_msg
, stdout
) < 0)