mirror of
https://github.com/openvswitch/ovs
synced 2025-09-05 00:35:33 +00:00
Introduce ofpacts, an abstraction of OpenFlow actions.
OpenFlow actions have always been somewhat awkward to handle. Moreover, over time we've started creating actions that require more complicated parsing. When we maintain those actions internally in their wire format, we end up parsing them multiple times, whenever we have to look at the set of actions. When we add support for OpenFlow 1.1 or later protocols, the situation will get worse, because these newer protocols support many of the same actions but with different representations. It becomes unrealistic to handle each protocol in its wire format. This commit adopts a new strategy, by converting OpenFlow actions into an internal form from the wire format when they are read, and converting them back to the wire format when flows are dumped. I believe that this will be more maintainable over time. Thanks to Simon Horman and Pravin Shelar for reviews. Signed-off-by: Ben Pfaff <blp@nicira.com>
This commit is contained in:
@@ -23,6 +23,7 @@
|
||||
#include "flow.h"
|
||||
#include "mac-learning.h"
|
||||
#include "odp-util.h"
|
||||
#include "ofp-actions.h"
|
||||
#include "ofp-util.h"
|
||||
#include "ofpbuf.h"
|
||||
#include "ofproto.h"
|
||||
@@ -214,18 +215,19 @@ fail_open_flushed(struct fail_open *fo)
|
||||
int disconn_secs = connmgr_failure_duration(fo->connmgr);
|
||||
bool open = disconn_secs >= trigger_duration(fo);
|
||||
if (open) {
|
||||
union ofp_action action;
|
||||
struct ofpbuf ofpacts;
|
||||
struct cls_rule rule;
|
||||
|
||||
/* Set up a flow that matches every packet and directs them to
|
||||
* OFPP_NORMAL. */
|
||||
memset(&action, 0, sizeof action);
|
||||
action.type = htons(OFPAT10_OUTPUT);
|
||||
action.output.len = htons(sizeof action);
|
||||
action.output.port = htons(OFPP_NORMAL);
|
||||
ofpbuf_init(&ofpacts, OFPACT_OUTPUT_SIZE);
|
||||
ofpact_put_OUTPUT(&ofpacts)->port = OFPP_NORMAL;
|
||||
ofpact_pad(&ofpacts);
|
||||
|
||||
cls_rule_init_catchall(&rule, FAIL_OPEN_PRIORITY);
|
||||
ofproto_add_flow(fo->ofproto, &rule, &action, 1);
|
||||
ofproto_add_flow(fo->ofproto, &rule, ofpacts.data, ofpacts.size);
|
||||
|
||||
ofpbuf_uninit(&ofpacts);
|
||||
}
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user