X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=ofproto%2Fofproto-dpif.h;h=0704297379db2220664845bc95de234269022f8c;hb=42943cdef10197befc9acc8c6fdb632a210c055f;hp=bfba344fb803dbf2ea194981267fedcf7df9e225;hpb=db7d4e469903adf1cbf05c9cd70b9eb77946c202;p=sliver-openvswitch.git diff --git a/ofproto/ofproto-dpif.h b/ofproto/ofproto-dpif.h index bfba344fb..070429737 100644 --- a/ofproto/ofproto-dpif.h +++ b/ofproto/ofproto-dpif.h @@ -100,7 +100,6 @@ struct ofproto_dpif { /* Support for debugging async flow mods. */ struct list completions; - bool has_bundle_action; /* True when the first bundle action appears. */ struct netdev_stats stats; /* To account packets generated and consumed in * userspace. */ @@ -127,15 +126,16 @@ struct ofport_dpif { struct hmap_node odp_port_node; /* In dpif_backer's "odp_to_ofport_map". */ struct ofport up; - uint32_t odp_port; + odp_port_t odp_port; struct ofbundle *bundle; /* Bundle that contains this port, if any. */ struct list bundle_node; /* In struct ofbundle's "ports" list. */ struct cfm *cfm; /* Connectivity Fault Management, if any. */ struct bfd *bfd; /* BFD, if any. */ tag_type tag; /* Tag associated with this port. */ bool may_enable; /* May be enabled in bonds. */ + bool is_tunnel; /* This port is a tunnel. */ long long int carrier_seq; /* Carrier status changes. */ - struct tnl_port *tnl_port; /* Tunnel handle, or null. */ + struct ofport_dpif *peer; /* Peer if patch port. */ /* Spanning tree. */ struct stp_port *stp_port; /* Spanning Tree Protocol, if any. */ @@ -150,7 +150,7 @@ struct ofport_dpif { * drivers in old versions of Linux that do not properly support VLANs when * VLAN devices are not used. When broken device drivers are no longer in * widespread use, we will delete these interfaces. */ - uint16_t realdev_ofp_port; + ofp_port_t realdev_ofp_port; int vlandev_vid; }; @@ -227,14 +227,13 @@ mirror_mask_ffs(mirror_mask_t mask) } struct ofport_dpif *get_ofp_port(const struct ofproto_dpif *, - uint16_t ofp_port); + ofp_port_t ofp_port); struct ofport_dpif *get_odp_port(const struct ofproto_dpif *, - uint32_t odp_port); + odp_port_t odp_port); -struct ofport_dpif *ofport_get_peer(const struct ofport_dpif *); - -uint32_t ofp_port_to_odp_port(const struct ofproto_dpif *, uint16_t ofp_port); +odp_port_t ofp_port_to_odp_port(const struct ofproto_dpif *, + ofp_port_t ofp_port); struct rule_dpif *rule_dpif_lookup_in_table(struct ofproto_dpif *, const struct flow *, @@ -257,18 +256,19 @@ size_t put_userspace_action(const struct ofproto_dpif *, const union user_action_cookie *, const size_t cookie_size); -bool stp_should_process_flow(const struct flow *); +bool stp_should_process_flow(const struct flow *, struct flow_wildcards *); void stp_process_packet(const struct ofport_dpif *, const struct ofpbuf *packet); -uint16_t vsp_realdev_to_vlandev(const struct ofproto_dpif *, - uint16_t realdev_ofp_port, - ovs_be16 vlan_tci); +ofp_port_t vsp_realdev_to_vlandev(const struct ofproto_dpif *, + ofp_port_t realdev_ofp_port, + ovs_be16 vlan_tci); bool ofproto_dpif_dscp_from_priority(const struct ofport_dpif *, uint32_t priority, uint8_t *dscp); int ofproto_dpif_queue_to_priority(const struct ofproto_dpif *, uint32_t queue_id, uint32_t *priority); - +tag_type calculate_flow_tag(struct ofproto_dpif *, const struct flow *, + uint8_t table_id, struct rule_dpif *); #endif /* ofproto-dpif.h */