diff options
author | Jiri Benc <jbenc@redhat.com> | 2016-11-10 16:28:18 +0100 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2016-11-13 00:51:02 -0500 |
commit | 329f45bc4f191c663dc156c510816411a4310578 (patch) | |
tree | 8e505cd157e30c5cbfe4789822ed4f571806d276 /net/openvswitch/flow.c | |
parent | 738314a084aae5f76ff760279034b39d52c42e8b (diff) | |
download | linux-stable-329f45bc4f191c663dc156c510816411a4310578.tar.gz linux-stable-329f45bc4f191c663dc156c510816411a4310578.tar.bz2 linux-stable-329f45bc4f191c663dc156c510816411a4310578.zip |
openvswitch: add mac_proto field to the flow key
Use a hole in the structure. We support only Ethernet so far and will add
a support for L2-less packets shortly. We could use a bool to indicate
whether the Ethernet header is present or not but the approach with the
mac_proto field is more generic and occupies the same number of bytes in the
struct, while allowing later extensibility. It also makes the code in the
next patches more self explaining.
It would be nice to use ARPHRD_ constants but those are u16 which would be
waste. Thus define our own constants.
Another upside of this is that we can overload this new field to also denote
whether the flow key is valid. This has the advantage that on
refragmentation, we don't have to reparse the packet but can rely on the
stored eth.type. This is especially important for the next patches in this
series - instead of adding another branch for L2-less packets before calling
ovs_fragment, we can just remove all those branches completely.
Signed-off-by: Jiri Benc <jbenc@redhat.com>
Acked-by: Pravin B Shelar <pshelar@ovn.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/openvswitch/flow.c')
-rw-r--r-- | net/openvswitch/flow.c | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/net/openvswitch/flow.c b/net/openvswitch/flow.c index 22087062bd10..96c8c4716603 100644 --- a/net/openvswitch/flow.c +++ b/net/openvswitch/flow.c @@ -751,6 +751,7 @@ int ovs_flow_key_extract(const struct ip_tunnel_info *tun_info, key->phy.skb_mark = skb->mark; ovs_ct_fill_key(skb, key); key->ovs_flow_hash = 0; + key->mac_proto = MAC_PROTO_ETHERNET; key->recirc_id = 0; return key_extract(skb, key); |