]>
git.proxmox.com Git - mirror_iproute2.git/blob - bridge/bridge.c
2 * Get/set/delete bridge with netlink
4 * Authors: Stephen Hemminger <shemminger@vyatta.com>
10 #include <sys/socket.h>
15 #include "br_common.h"
17 struct rtnl_handle rth
= { .fd
= -1 };
18 int preferred_family
= AF_UNSPEC
;
24 static void usage(void) __attribute__((noreturn
));
26 static void usage(void)
29 "Usage: bridge [ OPTIONS ] OBJECT { COMMAND | help }\n"
30 "where OBJECT := { fdb | monitor }\n"
31 " OPTIONS := { -V[ersion] | -s[tatistics] | -d[etails]\n" );
35 static int do_help(int argc
, char **argv
)
41 static const struct cmd
{
43 int (*func
)(int argc
, char **argv
);
46 { "monitor", do_monitor
},
51 static int do_cmd(const char *argv0
, int argc
, char **argv
)
55 for (c
= cmds
; c
->cmd
; ++c
) {
56 if (matches(argv0
, c
->cmd
) == 0)
57 return c
->func(argc
-1, argv
+1);
60 fprintf(stderr
, "Object \"%s\" is unknown, try \"bridge help\".\n", argv0
);
65 main(int argc
, char **argv
)
69 if (strcmp(opt
,"--") == 0) {
78 if (matches(opt
, "-help") == 0) {
80 } else if (matches(opt
, "-Version") == 0) {
81 printf("bridge utility, 0.0\n");
83 } else if (matches(opt
, "-stats") == 0 ||
84 matches(opt
, "-statistics") == 0) {
86 } else if (matches(opt
, "-details") == 0) {
88 } else if (matches(opt
, "-timestamp") == 0) {
90 } else if (matches(opt
, "-family") == 0) {
95 if (strcmp(argv
[1], "inet") == 0)
96 preferred_family
= AF_INET
;
97 else if (strcmp(argv
[1], "inet6") == 0)
98 preferred_family
= AF_INET6
;
99 else if (strcmp(argv
[1], "help") == 0)
102 invarg("invalid protocol family", argv
[1]);
103 } else if (strcmp(opt
, "-4") == 0) {
104 preferred_family
= AF_INET
;
105 } else if (strcmp(opt
, "-6") == 0) {
106 preferred_family
= AF_INET6
;
108 fprintf(stderr
, "Option \"%s\" is unknown, try \"bridge help\".\n", opt
);
114 if (rtnl_open(&rth
, 0) < 0)
118 return do_cmd(argv
[1], argc
-1, argv
+1);