X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=ofproto%2Fofproto-dpif.h;h=88593ce3df56526e4b2502409430bf83022e019e;hb=7aaeab4df24b7e9460705b1dad1010eef0354c50;hp=6c9afcd105a82ca76ff088bc1bcc0a74278e1609;hpb=ade6ad9cceeaac187ed7632824de413f25539241;p=sliver-openvswitch.git diff --git a/ofproto/ofproto-dpif.h b/ofproto/ofproto-dpif.h index 6c9afcd10..88593ce3d 100644 --- a/ofproto/ofproto-dpif.h +++ b/ofproto/ofproto-dpif.h @@ -19,12 +19,14 @@ #include "hmapx.h" #include "ofproto/ofproto-provider.h" +#include "ovs-thread.h" #include "timer.h" #include "util.h" union user_action_cookie; struct ofproto_dpif; struct ofport_dpif; +struct dpif_backer; struct rule_dpif { struct rule up; @@ -42,8 +44,9 @@ struct rule_dpif { * packet_count or byte_count member or that can be obtained from the * datapath by, e.g., dpif_flow_get() for any subfacet. */ - uint64_t packet_count; /* Number of packets received. */ - uint64_t byte_count; /* Number of bytes received. */ + struct ovs_mutex stats_mutex; + uint64_t packet_count OVS_GUARDED; /* Number of packets received. */ + uint64_t byte_count OVS_GUARDED; /* Number of bytes received. */ }; static inline struct rule_dpif *rule_dpif_cast(const struct rule *rule) @@ -61,21 +64,16 @@ struct rule_dpif *rule_dpif_miss_rule(struct ofproto_dpif *ofproto, void rule_credit_stats(struct rule_dpif *, const struct dpif_flow_stats *); -size_t put_userspace_action(const struct ofproto_dpif *, - struct ofpbuf *odp_actions, const struct flow *, - const union user_action_cookie *, - const size_t cookie_size); - bool ofproto_has_vlan_splinters(const struct ofproto_dpif *); ofp_port_t vsp_realdev_to_vlandev(const struct ofproto_dpif *, ofp_port_t realdev_ofp_port, ovs_be16 vlan_tci); - -int ofproto_dpif_queue_to_priority(const struct ofproto_dpif *, - uint32_t queue_id, uint32_t *priority); +bool vsp_adjust_flow(const struct ofproto_dpif *, struct flow *); void ofproto_dpif_send_packet_in(struct ofproto_dpif *, struct ofputil_packet_in *pin); void ofproto_dpif_flow_mod(struct ofproto_dpif *, struct ofputil_flow_mod *); +struct ofport_dpif *odp_port_to_ofport(const struct dpif_backer *, odp_port_t); + #endif /* ofproto-dpif.h */