mirror of
https://github.com/openvswitch/ovs
synced 2025-10-27 15:18:06 +00:00
openflow: Table maintenance commands for Geneve options.
In order to work with Geneve options, we need to maintain a mapping table between an option (defined by <class, type, length>) and an NXM field that can be operated on for the purposes of matches, actions, etc. This mapping must be explicitly specified by the user. Conceptually, this table could be communicated using either OpenFlow or OVSDB. Using OVSDB requires less code and definition of extensions than OpenFlow but introduces the possibility that mapping table updates and flow modifications are desynchronized from each other. This is dangerous because the mapping table signifcantly impacts the way that flows using Geneve options are installed and processed by OVS. Therefore, the mapping table is maintained using OpenFlow commands instead, which opens the possibility of using synchronization between table changes and flow modifications through barriers, bundles, etc. There are two primary groups of OpenFlow messages that are introduced as Nicira extensions: modification commands (add, delete, clear mappings) and table status request/reply to dump the current table along with switch information. Note that mappings should not be changed while they are in active use by a flow. The result of doing so is undefined. This only adds the OpenFlow infrastructure but doesn't actually do anything with the information yet after the messages have been decoded. Signed-off-by: Jesse Gross <jesse@nicira.com> Acked-by: Ben Pfaff <blp@nicira.com>
This commit is contained in:
@@ -751,7 +751,10 @@ static inline bool dl_type_is_ip_any(ovs_be16 dl_type)
|
||||
}
|
||||
|
||||
/* Tunnel header */
|
||||
#define GENEVE_MAX_OPT_SIZE 124
|
||||
|
||||
#define GENEVE_CRIT_OPT_TYPE (1 << 7)
|
||||
|
||||
struct geneve_opt {
|
||||
ovs_be16 opt_class;
|
||||
uint8_t type;
|
||||
|
||||
Reference in New Issue
Block a user