]> git.proxmox.com Git - mirror_iproute2.git/blob - bridge/bridge.c
06b7a548a3c1f0cacb4b87bb45115903ccee66b3
[mirror_iproute2.git] / bridge / bridge.c
1 /*
2 * Get/set/delete bridge with netlink
3 *
4 * Authors: Stephen Hemminger <shemminger@vyatta.com>
5 */
6
7 #include <stdio.h>
8 #include <stdlib.h>
9 #include <unistd.h>
10 #include <sys/socket.h>
11 #include <string.h>
12
13 #include "SNAPSHOT.h"
14 #include "utils.h"
15 #include "br_common.h"
16
17 struct rtnl_handle rth = { .fd = -1 };
18 int preferred_family = AF_UNSPEC;
19 int resolve_hosts;
20 int show_stats;
21 int show_details;
22 int timestamp;
23
24 static void usage(void) __attribute__((noreturn));
25
26 static void usage(void)
27 {
28 fprintf(stderr,
29 "Usage: bridge [ OPTIONS ] OBJECT { COMMAND | help }\n"
30 "where OBJECT := { fdb | mdb | vlan | monitor }\n"
31 " OPTIONS := { -V[ersion] | -s[tatistics] | -d[etails]\n" );
32 exit(-1);
33 }
34
35 static int do_help(int argc, char **argv)
36 {
37 usage();
38 }
39
40
41 static const struct cmd {
42 const char *cmd;
43 int (*func)(int argc, char **argv);
44 } cmds[] = {
45 { "fdb", do_fdb },
46 { "mdb", do_mdb },
47 { "vlan", do_vlan },
48 { "monitor", do_monitor },
49 { "help", do_help },
50 { 0 }
51 };
52
53 static int do_cmd(const char *argv0, int argc, char **argv)
54 {
55 const struct cmd *c;
56
57 for (c = cmds; c->cmd; ++c) {
58 if (matches(argv0, c->cmd) == 0)
59 return c->func(argc-1, argv+1);
60 }
61
62 fprintf(stderr, "Object \"%s\" is unknown, try \"bridge help\".\n", argv0);
63 return -1;
64 }
65
66 int
67 main(int argc, char **argv)
68 {
69 while (argc > 1) {
70 char *opt = argv[1];
71 if (strcmp(opt,"--") == 0) {
72 argc--; argv++;
73 break;
74 }
75 if (opt[0] != '-')
76 break;
77 if (opt[1] == '-')
78 opt++;
79
80 if (matches(opt, "-help") == 0) {
81 usage();
82 } else if (matches(opt, "-Version") == 0) {
83 printf("bridge utility, 0.0\n");
84 exit(0);
85 } else if (matches(opt, "-stats") == 0 ||
86 matches(opt, "-statistics") == 0) {
87 ++show_stats;
88 } else if (matches(opt, "-details") == 0) {
89 ++show_details;
90 } else if (matches(opt, "-timestamp") == 0) {
91 ++timestamp;
92 } else if (matches(opt, "-family") == 0) {
93 argc--;
94 argv++;
95 if (argc <= 1)
96 usage();
97 if (strcmp(argv[1], "inet") == 0)
98 preferred_family = AF_INET;
99 else if (strcmp(argv[1], "inet6") == 0)
100 preferred_family = AF_INET6;
101 else if (strcmp(argv[1], "help") == 0)
102 usage();
103 else
104 invarg("invalid protocol family", argv[1]);
105 } else if (strcmp(opt, "-4") == 0) {
106 preferred_family = AF_INET;
107 } else if (strcmp(opt, "-6") == 0) {
108 preferred_family = AF_INET6;
109 } else {
110 fprintf(stderr, "Option \"%s\" is unknown, try \"bridge help\".\n", opt);
111 exit(-1);
112 }
113 argc--; argv++;
114 }
115
116 if (rtnl_open(&rth, 0) < 0)
117 exit(1);
118
119 if (argc > 1)
120 return do_cmd(argv[1], argc-1, argv+1);
121
122 rtnl_close(&rth);
123 usage();
124 }