X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=vswitchd%2Fovs-vswitchd.c;h=fd2144abb0da2e20d4ecf7decb7e55f990ffb21a;hb=3adb8bf04838d8fa5a382f501437b62af99ed874;hp=4352f5f743af394d3324af99c6a619e2b44c9fd9;hpb=5792c5c64a194304b554e2c6b9a9a4c0216c08a4;p=openvswitch diff --git a/vswitchd/ovs-vswitchd.c b/vswitchd/ovs-vswitchd.c index 4352f5f7..fd2144ab 100644 --- a/vswitchd/ovs-vswitchd.c +++ b/vswitchd/ovs-vswitchd.c @@ -32,9 +32,9 @@ #include "fault.h" #include "leak-checker.h" #include "mgmt.h" +#include "netdev.h" #include "ovs-vswitchd.h" #include "poll-loop.h" -#include "port.h" #include "proc-net-compat.h" #include "process.h" #include "signals.h" @@ -50,7 +50,7 @@ static void parse_options(int argc, char *argv[]); static void usage(void) NO_RETURN; -static void reload(struct unixctl_conn *, const char *args); +static unixctl_cb_func reload; static bool need_reconfigure; static struct unixctl_conn **conns; @@ -79,12 +79,14 @@ main(int argc, char *argv[]) if (retval) { ovs_fatal(retval, "could not listen for control connections"); } - unixctl_command_register("vswitchd/reload", reload); + unixctl_command_register("vswitchd/reload", reload, NULL); - cfg_read(); + retval = cfg_read(); + if (retval) { + ovs_fatal(retval, "could not read config file"); + } mgmt_init(); bridge_init(); - port_init(); mgmt_reconfigure(); need_reconfigure = false; @@ -102,6 +104,7 @@ main(int argc, char *argv[]) } unixctl_server_run(unixctl); dp_run(); + netdev_run(); if (need_reconfigure) { poll_immediate_wake(); @@ -111,6 +114,7 @@ main(int argc, char *argv[]) bridge_wait(); unixctl_server_wait(unixctl); dp_wait(); + netdev_wait(); poll_block(); } @@ -118,7 +122,7 @@ main(int argc, char *argv[]) } static void -reload(struct unixctl_conn *conn, const char *args UNUSED) +reload(struct unixctl_conn *conn, const char *args UNUSED, void *aux UNUSED) { need_reconfigure = true; conns = xrealloc(conns, sizeof *conns * (n_conns + 1)); @@ -133,7 +137,6 @@ reconfigure(void) cfg_read(); bridge_reconfigure(); mgmt_reconfigure(); - port_reconfigure(); for (i = 0; i < n_conns; i++) { unixctl_command_reply(conns[i], 202, NULL); @@ -222,6 +225,7 @@ parse_options(int argc, char *argv[]) "use --help for usage"); } + cfg_init(); config_file = argv[0]; error = cfg_set_file(config_file); if (error) {