X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=utilities%2Fovs-controller.c;h=c38c8123669f91f7284596c41b24e221e9ef5e48;hb=c18ea70d06e980dc768166881c5aeac0b3491561;hp=1be84f78706ffd688d16180b9cf7e556f1793466;hpb=d98e60075528c3065ad453f7add4b30f22edcde3;p=openvswitch diff --git a/utilities/ovs-controller.c b/utilities/ovs-controller.c index 1be84f78..c38c8123 100644 --- a/utilities/ovs-controller.c +++ b/utilities/ovs-controller.c @@ -77,9 +77,9 @@ static uint32_t default_queue = UINT32_MAX; /* -Q, --port-queue: map from port name to port number (cast to void *). */ static struct shash port_queues = SHASH_INITIALIZER(&port_queues); -/* --with-flows: File with flows to send to switch, or null to not load - * any default flows. */ -static struct ovs_queue default_flows = OVS_QUEUE_INITIALIZER; +/* --with-flows: Flows to send to switch, or an empty list not to send any + * default flows. */ +static struct list default_flows = LIST_INITIALIZER(&default_flows); /* --unixctl: Name of unixctl socket, or null to use the default. */ static char *unixctl_path = NULL; @@ -229,7 +229,7 @@ new_switch(struct switch_ *sw, struct vconn *vconn) : learn_macs ? LSW_LEARN : LSW_FLOOD); cfg.max_idle = set_up_flows ? max_idle : -1; - cfg.default_flows = default_flows.head; + cfg.default_flows = &default_flows; cfg.default_queue = default_queue; cfg.port_queues = &port_queues; sw->lswitch = lswitch_create(sw->rconn, &cfg); @@ -260,7 +260,7 @@ do_switching(struct switch_ *sw) static void read_flow_file(const char *name) { - struct ofpbuf *b; + enum nx_flow_format flow_format; FILE *stream; stream = fopen(optarg, "r"); @@ -268,8 +268,9 @@ read_flow_file(const char *name) ovs_fatal(errno, "%s: open", name); } - while ((b = parse_ofp_add_flow_file(stream)) != NULL) { - queue_push_tail(&default_flows, b); + flow_format = NXFF_OPENFLOW10; + while (parse_ofp_add_flow_file(&default_flows, &flow_format, stream)) { + continue; } fclose(stream);