X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=lib%2Fofp-util.h;h=05d6acecf48ae28531aad26a28be0c7a4727cb14;hb=8321fb9c570bd25bb8925e7b5116ab90662113b5;hp=62548e52cb96f5893b3ed5404b32d0e90b5f7b22;hpb=3052b0c5e566564fc1768af33292c0acf2ed61a0;p=openvswitch diff --git a/lib/ofp-util.h b/lib/ofp-util.h index 62548e52..05d6acec 100644 --- a/lib/ofp-util.h +++ b/lib/ofp-util.h @@ -22,19 +22,23 @@ #include #include #include "flow.h" +#include "openvswitch/types.h" struct ofpbuf; struct ofp_action_header; +/* Alignment of ofp_actions. */ +#define OFP_ACTION_ALIGN 8 + /* OpenFlow protocol utility functions. */ void *make_openflow(size_t openflow_len, uint8_t type, struct ofpbuf **); void *make_nxmsg(size_t openflow_len, uint32_t subtype, struct ofpbuf **); void *make_openflow_xid(size_t openflow_len, uint8_t type, - uint32_t xid, struct ofpbuf **); -void *make_nxmsg_xid(size_t openflow_len, uint32_t subtype, uint32_t xid, + ovs_be32 xid, struct ofpbuf **); +void *make_nxmsg_xid(size_t openflow_len, uint32_t subtype, ovs_be32 xid, struct ofpbuf **); void *put_openflow(size_t openflow_len, uint8_t type, struct ofpbuf *); -void *put_openflow_xid(size_t openflow_len, uint8_t type, uint32_t xid, +void *put_openflow_xid(size_t openflow_len, uint8_t type, ovs_be32 xid, struct ofpbuf *); void update_openflow_length(struct ofpbuf *); struct ofpbuf *make_flow_mod(uint16_t command, const struct flow *, @@ -62,8 +66,6 @@ int check_ofp_message(const struct ofp_header *, uint8_t type, size_t size); int check_ofp_message_array(const struct ofp_header *, uint8_t type, size_t size, size_t array_elt_size, size_t *n_array_elts); -int check_ofp_packet_out(const struct ofp_header *, struct ofpbuf *data, - int *n_actions, int max_ports); struct flow_stats_iterator { const uint8_t *pos, *end; @@ -80,7 +82,7 @@ const union ofp_action *actions_first(struct actions_iterator *, size_t n_actions); const union ofp_action *actions_next(struct actions_iterator *); int validate_actions(const union ofp_action *, size_t n_actions, - int max_ports); + const struct flow *, int max_ports); bool action_outputs_to_port(const union ofp_action *, uint16_t port); void normalize_match(struct ofp_match *);