nx-match: Move all knowledge of OXM/NXM here.
[cascardo/ovs.git] / lib / nx-match.h
1 /*
2  * Copyright (c) 2010, 2011, 2012, 2013, 2014 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 NX_MATCH_H
18 #define NX_MATCH_H 1
19
20 #include <stdint.h>
21 #include <sys/types.h>
22 #include <netinet/in.h>
23 #include "compiler.h"
24 #include "flow.h"
25 #include "meta-flow.h"
26 #include "ofp-errors.h"
27 #include "openvswitch/types.h"
28
29 struct ds;
30 struct match;
31 struct ofpact_reg_move;
32 struct ofpact_reg_load;
33 struct ofpact_stack;
34 struct ofpbuf;
35 struct nx_action_reg_load;
36 struct nx_action_reg_move;
37
38
39 /* Nicira Extended Match (NXM) flexible flow match helper functions.
40  *
41  * See include/openflow/nicira-ext.h for NXM specification.
42  */
43
44 void mf_format_subfield(const struct mf_subfield *, struct ds *);
45 char *mf_parse_subfield__(struct mf_subfield *sf, const char **s)
46     WARN_UNUSED_RESULT;
47 char *mf_parse_subfield(struct mf_subfield *, const char *s)
48     WARN_UNUSED_RESULT;
49
50 enum ofperr nx_pull_match(struct ofpbuf *, unsigned int match_len,
51                           struct match *,
52                           ovs_be64 *cookie, ovs_be64 *cookie_mask);
53 enum ofperr nx_pull_match_loose(struct ofpbuf *, unsigned int match_len,
54                                 struct match *, ovs_be64 *cookie,
55                                 ovs_be64 *cookie_mask);
56 enum ofperr oxm_pull_match(struct ofpbuf *, struct match *);
57 enum ofperr oxm_pull_match_loose(struct ofpbuf *, struct match *);
58 int nx_put_match(struct ofpbuf *, const struct match *,
59                  ovs_be64 cookie, ovs_be64 cookie_mask);
60 int oxm_put_match(struct ofpbuf *, const struct match *, enum ofp_version);
61
62 /* Decoding and encoding OXM/NXM headers (just a field ID) or entries (a field
63  * ID followed by a value and possibly a mask). */
64 enum ofperr nx_pull_entry(struct ofpbuf *, const struct mf_field **,
65                           union mf_value *value, union mf_value *mask);
66 enum ofperr nx_pull_header(struct ofpbuf *, const struct mf_field **,
67                            bool *masked);
68 void nx_put_entry(struct ofpbuf *, enum mf_field_id, enum ofp_version,
69                   const union mf_value *value, const union mf_value *mask);
70 void nx_put_header(struct ofpbuf *, enum mf_field_id, enum ofp_version,
71                    bool masked);
72
73 /* NXM and OXM protocol headers values.
74  *
75  * These are often alternatives to nx_pull_entry/header() and
76  * nx_put_entry/header() for decoding and encoding OXM/NXM.  In those cases,
77  * the nx_*() functions should be preferred because they can support the 64-bit
78  * "experimenter" OXM format (even though it is not yet implemented). */
79 uint32_t mf_oxm_header(enum mf_field_id, enum ofp_version oxm_version);
80 const struct mf_field *mf_from_nxm_header(uint32_t nxm_header);
81
82 char *nx_match_to_string(const uint8_t *, unsigned int match_len);
83 char *oxm_match_to_string(const struct ofpbuf *, unsigned int match_len);
84 int nx_match_from_string(const char *, struct ofpbuf *);
85 int oxm_match_from_string(const char *, struct ofpbuf *);
86
87 void nx_format_field_name(enum mf_field_id, enum ofp_version, struct ds *);
88
89 char *nxm_parse_reg_move(struct ofpact_reg_move *, const char *)
90     WARN_UNUSED_RESULT;
91 char *nxm_parse_reg_load(struct ofpact_reg_load *, const char *)
92     WARN_UNUSED_RESULT;
93
94 void nxm_format_reg_move(const struct ofpact_reg_move *, struct ds *);
95 void nxm_format_reg_load(const struct ofpact_reg_load *, struct ds *);
96
97 enum ofperr nxm_reg_move_check(const struct ofpact_reg_move *,
98                                const struct flow *);
99 enum ofperr nxm_reg_load_check(const struct ofpact_reg_load *,
100                                const struct flow *);
101
102 void nxm_execute_reg_move(const struct ofpact_reg_move *, struct flow *,
103                           struct flow_wildcards *);
104 void nxm_execute_reg_load(const struct ofpact_reg_load *, struct flow *,
105                           struct flow_wildcards *);
106 void nxm_reg_load(const struct mf_subfield *, uint64_t src_data,
107                   struct flow *, struct flow_wildcards *);
108
109 char *nxm_parse_stack_action(struct ofpact_stack *, const char *)
110     WARN_UNUSED_RESULT;
111
112 void nxm_format_stack_push(const struct ofpact_stack *, struct ds *);
113 void nxm_format_stack_pop(const struct ofpact_stack *, struct ds *);
114
115 enum ofperr nxm_stack_push_check(const struct ofpact_stack *,
116                                  const  struct flow *);
117 enum ofperr nxm_stack_pop_check(const struct ofpact_stack *,
118                                const struct flow *);
119
120 void nxm_execute_stack_push(const struct ofpact_stack *,
121                             const struct flow *, struct flow_wildcards *,
122                             struct ofpbuf *);
123 void nxm_execute_stack_pop(const struct ofpact_stack *,
124                             struct flow *, struct flow_wildcards *,
125                             struct ofpbuf *);
126
127 ovs_be64 oxm_bitmap_from_mf_bitmap(const struct mf_bitmap *, enum ofp_version);
128 struct mf_bitmap oxm_bitmap_to_mf_bitmap(ovs_be64 oxm_bitmap,
129                                          enum ofp_version);
130 struct mf_bitmap oxm_writable_fields(void);
131 struct mf_bitmap oxm_matchable_fields(void);
132 struct mf_bitmap oxm_maskable_fields(void);
133
134 /* Dealing with the 'ofs_nbits' members in several Nicira extensions. */
135
136 static inline ovs_be16
137 nxm_encode_ofs_nbits(int ofs, int n_bits)
138 {
139     return htons((ofs << 6) | (n_bits - 1));
140 }
141
142 static inline int
143 nxm_decode_ofs(ovs_be16 ofs_nbits)
144 {
145     return ntohs(ofs_nbits) >> 6;
146 }
147
148 static inline int
149 nxm_decode_n_bits(ovs_be16 ofs_nbits)
150 {
151     return (ntohs(ofs_nbits) & 0x3f) + 1;
152 }
153 \f
154 /* This is my guess at the length of a "typical" nx_match, for use in
155  * predicting space requirements. */
156 #define NXM_TYPICAL_LEN 64
157
158 #endif /* nx-match.h */