-#define ODP_FLOW_GET _IOWR('O', 13, struct odp_flow)
-#define ODP_FLOW_PUT _IOWR('O', 14, struct odp_flow)
-#define ODP_FLOW_DUMP _IOWR('O', 15, struct odp_flow_dump)
-#define ODP_FLOW_FLUSH _IO('O', 16)
-#define ODP_FLOW_DEL _IOWR('O', 17, struct odp_flow)
+#define ODP_FLOW_NEW _IOWR('O', 13, struct odp_flow)
+#define ODP_FLOW_DEL _IOWR('O', 14, struct odp_flow)
+#define ODP_FLOW_GET _IOWR('O', 15, struct odp_flow)
+#define ODP_FLOW_SET _IOWR('O', 16, struct odp_flow)
+#define ODP_FLOW_DUMP _IOWR('O', 17, struct odp_flow)
+#define ODP_FLOW_FLUSH _IO('O', 19)
+
+#define ODP_EXECUTE _IOR('O', 18, struct odp_packet)
+
+/**
+ * struct odp_datapath - header with basic information about a datapath.
+ * @dp_idx: Datapath index (-1 to make a request not specific to a datapath).
+ * @len: Length of this structure plus the Netlink attributes following it.
+ * @total_len: Total space available for kernel reply to request.
+ *
+ * Followed by &struct nlattr attributes, whose types are drawn from
+ * %ODP_DP_ATTR_*, up to a length of @len bytes including the &struct
+ * odp_datapath header.
+ */
+struct odp_datapath {
+ int32_t dp_idx;
+ uint32_t len;
+ uint32_t total_len;
+};
+
+enum odp_datapath_type {
+ ODP_DP_ATTR_UNSPEC,
+ ODP_DP_ATTR_NAME, /* name of dp_ifidx netdev */
+ ODP_DP_ATTR_STATS, /* struct odp_stats */
+ ODP_DP_ATTR_IPV4_FRAGS, /* 32-bit enum odp_frag_handling */
+ ODP_DP_ATTR_SAMPLING, /* 32-bit fraction of packets to sample. */
+ __ODP_DP_ATTR_MAX
+};