X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=lib%2Fodp-execute.h;h=91f0c51839c195585f13d36e724136b64b93e710;hb=HEAD;hp=5d9fa90bd9246104422fcf7dad216b2fb5f5aff9;hpb=4fc65926033eb4a020d1f63db540fe551eae9f82;p=sliver-openvswitch.git diff --git a/lib/odp-execute.h b/lib/odp-execute.h index 5d9fa90bd..91f0c5183 100644 --- a/lib/odp-execute.h +++ b/lib/odp-execute.h @@ -18,21 +18,25 @@ #ifndef EXECUTE_ACTIONS_H #define EXECUTE_ACTIONS_H 1 +#include #include #include #include "openvswitch/types.h" -struct flow; struct nlattr; struct ofpbuf; +struct pkt_metadata; -void -odp_execute_actions(void *dp, struct ofpbuf *packet, struct flow *key, +typedef void (*odp_execute_cb)(void *dp, struct ofpbuf *packet, + struct pkt_metadata *, + const struct nlattr *action, bool may_steal); + +/* Actions that need to be executed in the context of a datapath are handed + * to 'dp_execute_action', if non-NULL. Currently this is called only for + * actions OVS_ACTION_ATTR_OUTPUT and OVS_ACTION_ATTR_USERSPACE so + * 'dp_execute_action' needs to handle only these. */ +void odp_execute_actions(void *dp, struct ofpbuf *packet, bool steal, + struct pkt_metadata *, const struct nlattr *actions, size_t actions_len, - void (*output)(void *dp, struct ofpbuf *packet, - const struct flow *key, - odp_port_t out_port), - void (*userspace)(void *dp, struct ofpbuf *packet, - const struct flow *key, - const struct nlattr *action)); + odp_execute_cb dp_execute_action); #endif