28433b9ecc1b3648771ff60a51473bbda3d52b06
[cascardo/ovs.git] / lib / match.h
1 /*
2  * Copyright (c) 2009, 2010, 2011, 2012 Nicira, Inc.
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at:
7  *
8  *     http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16
17 #ifndef MATCH_H
18 #define MATCH_H 1
19
20 #include "flow.h"
21
22 struct ds;
23
24 /* A flow classification match.
25  *
26  * Use one of the match_*() functions to initialize a "struct match".
27  *
28  * The match_*() functions below maintain the following important invariant.
29  * If a bit or a field is wildcarded in 'wc', then the corresponding bit or
30  * field in 'flow' is set to all-0-bits.  (The match_zero_wildcarded_fields()
31  * function can be used to restore this invariant after adding wildcards.) */
32 struct match {
33     struct flow flow;
34     struct flow_wildcards wc;
35 };
36
37 void match_init(struct match *,
38                 const struct flow *, const struct flow_wildcards *);
39 void match_wc_init(struct match *match, const struct flow *flow);
40 void match_init_catchall(struct match *);
41 void match_init_exact(struct match *, const struct flow *);
42
43 void match_zero_wildcarded_fields(struct match *);
44
45 void match_set_reg(struct match *, unsigned int reg_idx, uint32_t value);
46 void match_set_reg_masked(struct match *, unsigned int reg_idx,
47                           uint32_t value, uint32_t mask);
48 void match_set_metadata(struct match *, ovs_be64 metadata);
49 void match_set_metadata_masked(struct match *,
50                                ovs_be64 metadata, ovs_be64 mask);
51 void match_set_tun_id(struct match *, ovs_be64 tun_id);
52 void match_set_tun_id_masked(struct match *, ovs_be64 tun_id, ovs_be64 mask);
53 void match_set_in_port(struct match *, uint16_t ofp_port);
54 void match_set_dl_type(struct match *, ovs_be16);
55 void match_set_dl_src(struct match *, const uint8_t[6]);
56 void match_set_dl_src_masked(struct match *, const uint8_t dl_src[6],
57                              const uint8_t mask[6]);
58 void match_set_dl_dst(struct match *, const uint8_t[6]);
59 void match_set_dl_dst_masked(struct match *, const uint8_t dl_dst[6],
60                              const uint8_t mask[6]);
61 void match_set_dl_tci(struct match *, ovs_be16 tci);
62 void match_set_dl_tci_masked(struct match *, ovs_be16 tci, ovs_be16 mask);
63 void match_set_any_vid(struct match *);
64 void match_set_dl_vlan(struct match *, ovs_be16);
65 void match_set_vlan_vid(struct match *, ovs_be16);
66 void match_set_vlan_vid_masked(struct match *, ovs_be16 vid, ovs_be16 mask);
67 void match_set_any_pcp(struct match *);
68 void match_set_dl_vlan_pcp(struct match *, uint8_t);
69 void match_set_tp_src(struct match *, ovs_be16);
70 void match_set_tp_src_masked(struct match *, ovs_be16 port, ovs_be16 mask);
71 void match_set_tp_dst(struct match *, ovs_be16);
72 void match_set_tp_dst_masked(struct match *, ovs_be16 port, ovs_be16 mask);
73 void match_set_nw_proto(struct match *, uint8_t);
74 void match_set_nw_src(struct match *, ovs_be32);
75 void match_set_nw_src_masked(struct match *, ovs_be32 ip, ovs_be32 mask);
76 void match_set_nw_dst(struct match *, ovs_be32);
77 void match_set_nw_dst_masked(struct match *, ovs_be32 ip, ovs_be32 mask);
78 void match_set_nw_dscp(struct match *, uint8_t);
79 void match_set_nw_ecn(struct match *, uint8_t);
80 void match_set_nw_ttl(struct match *, uint8_t);
81 void match_set_nw_frag(struct match *, uint8_t nw_frag);
82 void match_set_nw_frag_masked(struct match *, uint8_t nw_frag, uint8_t mask);
83 void match_set_icmp_type(struct match *, uint8_t);
84 void match_set_icmp_code(struct match *, uint8_t);
85 void match_set_arp_sha(struct match *, const uint8_t[6]);
86 void match_set_arp_sha_masked(struct match *,
87                               const uint8_t arp_sha[6],
88                               const uint8_t mask[6]);
89 void match_set_arp_tha(struct match *, const uint8_t[6]);
90 void match_set_arp_tha_masked(struct match *,
91                               const uint8_t arp_tha[6],
92                               const uint8_t mask[6]);
93 void match_set_ipv6_src(struct match *, const struct in6_addr *);
94 void match_set_ipv6_src_masked(struct match *, const struct in6_addr *,
95                                const struct in6_addr *);
96 void match_set_ipv6_dst(struct match *, const struct in6_addr *);
97 void match_set_ipv6_dst_masked(struct match *, const struct in6_addr *,
98                                const struct in6_addr *);
99 void match_set_ipv6_label(struct match *, ovs_be32);
100 void match_set_ipv6_label_masked(struct match *, ovs_be32, ovs_be32);
101 void match_set_nd_target(struct match *, const struct in6_addr *);
102 void match_set_nd_target_masked(struct match *, const struct in6_addr *,
103                                 const struct in6_addr *);
104
105 bool match_equal(const struct match *, const struct match *);
106 uint32_t match_hash(const struct match *, uint32_t basis);
107
108 void match_format(const struct match *, struct ds *, unsigned int priority);
109 char *match_to_string(const struct match *, unsigned int priority);
110 void match_print(const struct match *);
111 \f
112 /* Compressed match. */
113
114 /* A sparse representation of a "struct match".
115  *
116  * This has the same invariant as "struct match", that is, a 1-bit in the
117  * 'flow' must correspond to a 1-bit in 'mask'.
118  *
119  * The invariants for the underlying miniflow and minimask are also maintained,
120  * which means that 'flow' and 'mask' can have different 'map's.  In
121  * particular, if the match checks that a given 32-bit field has value 0, then
122  * 'map' will have a 1-bit in 'mask' but a 0-bit in 'flow' for that field. */
123 struct minimatch {
124     struct miniflow flow;
125     struct minimask mask;
126 };
127
128 void minimatch_init(struct minimatch *, const struct match *);
129 void minimatch_clone(struct minimatch *, const struct minimatch *);
130 void minimatch_destroy(struct minimatch *);
131
132 void minimatch_expand(const struct minimatch *, struct match *);
133
134 bool minimatch_equal(const struct minimatch *a, const struct minimatch *b);
135 uint32_t minimatch_hash(const struct minimatch *, uint32_t basis);
136
137 void minimatch_format(const struct minimatch *, struct ds *,
138                       unsigned int priority);
139 char *minimatch_to_string(const struct minimatch *, unsigned int priority);
140
141 #endif /* match.h */