X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=lib%2Fdpif.h;h=1496c227f3c63e8f842d6cad1dab43ba928cbce6;hb=eedc0097f475a15297375a2aba39313c0f98f330;hp=b1717937e99782da6866b5b0c5bf3116895eb04f;hpb=a4af00400a835eb87569ba40e21874c05e872c0f;p=sliver-openvswitch.git diff --git a/lib/dpif.h b/lib/dpif.h index b1717937e..1496c227f 100644 --- a/lib/dpif.h +++ b/lib/dpif.h @@ -18,10 +18,16 @@ #ifndef DPIF_H #define DPIF_H 1 -#include "openvswitch/datapath-protocol.h" #include #include #include +#include "openflow/openflow.h" +#include "openvswitch/datapath-protocol.h" +#include "util.h" + +#ifdef __cplusplus +extern "C" { +#endif struct dpif; struct ofpbuf; @@ -86,6 +92,14 @@ int dpif_execute(struct dpif *, uint16_t in_port, const union odp_action[], size_t n_actions, const struct ofpbuf *); +/* Minimum number of bytes of headroom for a packet returned by dpif_recv() + * member function. This headroom allows "struct odp_msg" to be replaced by + * "struct ofp_packet_in" without copying the buffer. */ +#define DPIF_RECV_MSG_PADDING (sizeof(struct ofp_packet_in) \ + - sizeof(struct odp_msg)) +BUILD_ASSERT_DECL(sizeof(struct ofp_packet_in) > sizeof(struct odp_msg)); +BUILD_ASSERT_DECL(DPIF_RECV_MSG_PADDING % 4 == 0); + int dpif_recv_get_mask(const struct dpif *, int *listen_mask); int dpif_recv_set_mask(struct dpif *, int listen_mask); int dpif_get_sflow_probability(const struct dpif *, uint32_t *probability); @@ -97,4 +111,11 @@ void dpif_recv_wait(struct dpif *); void dpif_get_netflow_ids(const struct dpif *, uint8_t *engine_type, uint8_t *engine_id); +int dpif_queue_to_priority(const struct dpif *, uint32_t queue_id, + uint32_t *priority); + +#ifdef __cplusplus +} +#endif + #endif /* dpif.h */