X-Git-Url: http://git.cascardo.eti.br/?a=blobdiff_plain;f=lib%2Fmatch.h;h=0a6ac29ceeca79896217b932d67669af902bb7a7;hb=bef3f465bcd5f81823c7fb8750e3f639486b3587;hp=c664a6efc586ad6956ee2a92afdcf7f12ccc6fdc;hpb=8fd4792403254f868398a89fb5625830ee5a08eb;p=cascardo%2Fovs.git diff --git a/lib/match.h b/lib/match.h index c664a6efc..0a6ac29ce 100644 --- a/lib/match.h +++ b/lib/match.h @@ -1,5 +1,5 @@ /* - * Copyright (c) 2009, 2010, 2011, 2012, 2013, 2014, 2015 Nicira, Inc. + * Copyright (c) 2009, 2010, 2011, 2012, 2013, 2014, 2015, 2016 Nicira, Inc. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -70,6 +70,12 @@ void match_set_tun_src(struct match *match, ovs_be32 src); void match_set_tun_src_masked(struct match *match, ovs_be32 src, ovs_be32 mask); void match_set_tun_dst(struct match *match, ovs_be32 dst); void match_set_tun_dst_masked(struct match *match, ovs_be32 dst, ovs_be32 mask); +void match_set_tun_ipv6_src(struct match *, const struct in6_addr *); +void match_set_tun_ipv6_src_masked(struct match *, const struct in6_addr *, + const struct in6_addr *); +void match_set_tun_ipv6_dst(struct match *, const struct in6_addr *); +void match_set_tun_ipv6_dst_masked(struct match *, const struct in6_addr *, + const struct in6_addr *); void match_set_tun_ttl(struct match *match, uint8_t ttl); void match_set_tun_ttl_masked(struct match *match, uint8_t ttl, uint8_t mask); void match_set_tun_tos(struct match *match, uint8_t tos); @@ -83,14 +89,21 @@ void match_set_tun_gbp_flags(struct match *match, uint8_t flags); void match_set_in_port(struct match *, ofp_port_t ofp_port); void match_set_pkt_mark(struct match *, uint32_t pkt_mark); void match_set_pkt_mark_masked(struct match *, uint32_t pkt_mark, uint32_t mask); +void match_set_ct_state(struct match *, uint32_t ct_state); +void match_set_ct_state_masked(struct match *, uint32_t ct_state, uint32_t mask); +void match_set_ct_zone(struct match *, uint16_t ct_zone); +void match_set_ct_mark(struct match *, uint32_t ct_mark); +void match_set_ct_mark_masked(struct match *, uint32_t ct_mark, uint32_t mask); +void match_set_ct_label(struct match *, ovs_u128 ct_label); +void match_set_ct_label_masked(struct match *, ovs_u128 ct_label, ovs_u128 mask); void match_set_skb_priority(struct match *, uint32_t skb_priority); void match_set_dl_type(struct match *, ovs_be16); -void match_set_dl_src(struct match *, const uint8_t[ETH_ADDR_LEN]); -void match_set_dl_src_masked(struct match *, const uint8_t dl_src[ETH_ADDR_LEN], - const uint8_t mask[ETH_ADDR_LEN]); -void match_set_dl_dst(struct match *, const uint8_t[ETH_ADDR_LEN]); -void match_set_dl_dst_masked(struct match *, const uint8_t dl_dst[ETH_ADDR_LEN], - const uint8_t mask[ETH_ADDR_LEN]); +void match_set_dl_src(struct match *, const struct eth_addr ); +void match_set_dl_src_masked(struct match *, const struct eth_addr dl_src, + const struct eth_addr mask); +void match_set_dl_dst(struct match *, const struct eth_addr); +void match_set_dl_dst_masked(struct match *, const struct eth_addr dl_dst, + const struct eth_addr mask); void match_set_dl_tci(struct match *, ovs_be16 tci); void match_set_dl_tci_masked(struct match *, ovs_be16 tci, ovs_be16 mask); void match_set_any_vid(struct match *); @@ -107,6 +120,8 @@ void match_set_any_mpls_tc(struct match *, int idx); void match_set_mpls_tc(struct match *, int idx, uint8_t); void match_set_any_mpls_bos(struct match *, int idx); void match_set_mpls_bos(struct match *, int idx, uint8_t); +void match_set_any_mpls_ttl(struct match *, int idx); +void match_set_mpls_ttl(struct match *, int idx, uint8_t); void match_set_tp_src(struct match *, ovs_be16); void match_set_mpls_lse(struct match *, int idx, ovs_be32 lse); void match_set_tp_src_masked(struct match *, ovs_be16 port, ovs_be16 mask); @@ -126,14 +141,14 @@ void match_set_nw_frag(struct match *, uint8_t nw_frag); void match_set_nw_frag_masked(struct match *, uint8_t nw_frag, uint8_t mask); void match_set_icmp_type(struct match *, uint8_t); void match_set_icmp_code(struct match *, uint8_t); -void match_set_arp_sha(struct match *, const uint8_t[ETH_ADDR_LEN]); +void match_set_arp_sha(struct match *, const struct eth_addr); void match_set_arp_sha_masked(struct match *, - const uint8_t arp_sha[ETH_ADDR_LEN], - const uint8_t mask[ETH_ADDR_LEN]); -void match_set_arp_tha(struct match *, const uint8_t[ETH_ADDR_LEN]); + const struct eth_addr arp_sha, + const struct eth_addr mask); +void match_set_arp_tha(struct match *, const struct eth_addr); void match_set_arp_tha_masked(struct match *, - const uint8_t arp_tha[ETH_ADDR_LEN], - const uint8_t mask[ETH_ADDR_LEN]); + const struct eth_addr arp_tha, + const struct eth_addr mask); void match_set_ipv6_src(struct match *, const struct in6_addr *); void match_set_ipv6_src_masked(struct match *, const struct in6_addr *, const struct in6_addr *); @@ -159,6 +174,9 @@ void match_print(const struct match *); /* Compressed match. */ /* A sparse representation of a "struct match". + * + * 'flows' is used for allocating both 'flow' and 'mask' with one + * miniflow_alloc() call. * * There are two invariants: * @@ -170,8 +188,13 @@ void match_print(const struct match *); * 'values', which makes minimatch_matches_flow() faster. */ struct minimatch { - struct miniflow *flow; - struct minimask *mask; + union { + struct { + struct miniflow *flow; + struct minimask *mask; + }; + struct miniflow *flows[2]; + }; }; void minimatch_init(struct minimatch *, const struct match *);