datapath: Add support for unique flow IDs.
authorJoe Stringer <joestringer@nicira.com>
Thu, 22 Jan 2015 00:42:52 +0000 (16:42 -0800)
committerJoe Stringer <joestringer@nicira.com>
Fri, 27 Feb 2015 18:58:37 +0000 (10:58 -0800)
commitbc619e29dfcb0d41607f5bc9002fe9fd046cb919
treeb6ac65bf8304f7c9ed94fa254e1d2d760256d4c6
parentc623ba497a10fc8526d529261453facf227d468e
datapath: Add support for unique flow IDs.

Previously, flows were manipulated by userspace specifying a full,
unmasked flow key. This adds significant burden onto flow
serialization/deserialization, particularly when dumping flows.

This patch adds an alternative way to refer to flows using a
variable-length "unique flow identifier" (UFID). At flow setup time,
userspace may specify a UFID for a flow, which is stored with the flow
and inserted into a separate table for lookup, in addition to the
standard flow table. Flows created using a UFID must be fetched or
deleted using the UFID.

All flow dump operations may now be made more terse with OVS_UFID_F_*
flags. For example, the OVS_UFID_F_OMIT_KEY flag allows responses to
omit the flow key from a datapath operation if the flow has a
corresponding UFID. This significantly reduces the time spent assembling
and transacting netlink messages. With all OVS_UFID_F_OMIT_* flags
enabled, the datapath only returns the UFID and statistics for each flow
during flow dump, increasing ovs-vswitchd revalidator performance by 40%
or more.

Signed-off-by: Joe Stringer <joestringer@nicira.com>
Acked-by: Pravin B Shelar <pshelar@nicira.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
datapath/datapath.c
datapath/flow.h
datapath/flow_netlink.c
datapath/flow_netlink.h
datapath/flow_table.c
datapath/flow_table.h
datapath/linux/compat/include/linux/openvswitch.h