blob: eae8a184f768c6c4f5215e1e1937aa4cb80aac78 [file] [log] [blame]
Florin Corase127a7e2016-02-18 22:20:01 +01001/*
2 * Copyright (c) 2016 Cisco and/or its affiliates.
3 * Licensed under the Apache License, Version 2.0 (the "License");
4 * you may not use this file except in compliance with the License.
5 * You may obtain a copy of the License at:
6 *
7 * http://www.apache.org/licenses/LICENSE-2.0
8 *
9 * Unless required by applicable law or agreed to in writing, software
10 * distributed under the License is distributed on an "AS IS" BASIS,
11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 * See the License for the specific language governing permissions and
13 * limitations under the License.
14 */
15
16#ifndef VNET_CONTROL_H_
17#define VNET_CONTROL_H_
18
19#include <vnet/vnet.h>
20#include <vnet/lisp-cp/gid_dictionary.h>
21#include <vnet/lisp-cp/lisp_types.h>
22
Filip Tehlara5abdeb2016-07-18 17:35:40 +020023#define NUMBER_OF_RETRIES 1
Florin Corasa2157cf2016-08-16 21:09:14 +020024#define PENDING_MREQ_EXPIRATION_TIME 3.0 /* seconds */
Florin Corasf4691cd2016-08-15 19:16:32 +020025#define PENDING_MREQ_QUEUE_LEN 5
Filip Tehlara5abdeb2016-07-18 17:35:40 +020026
Filip Tehlar397fd7d2016-10-26 14:31:24 +020027#define PENDING_MREG_EXPIRATION_TIME 3.0 /* seconds */
28#define RLOC_PROBING_INTERVAL 60.0
29
30/* when map-registration is enabled "quick registration" takes place first.
31 In this mode ETR sends map-register messages at an increased frequency
32 until specified message count is reached */
33#define QUICK_MAP_REGISTER_MSG_COUNT 3
34#define QUICK_MAP_REGISTER_INTERVAL 3.0
35
36/* normal map-register period */
37#define MAP_REGISTER_INTERVAL 60.0
38
Filip Tehlarfb9931f2016-12-09 13:52:38 +010039/* 15 minutes */
40#define MAP_REGISTER_DEFAULT_TTL 900
Filip Tehlar397fd7d2016-10-26 14:31:24 +020041
Florin Corase127a7e2016-02-18 22:20:01 +010042typedef struct
43{
44 gid_address_t src;
45 gid_address_t dst;
Filip Tehlara5abdeb2016-07-18 17:35:40 +020046 u32 retries_num;
47 f64 time_to_expire;
48 u8 is_smr_invoked;
Florin Corasa2157cf2016-08-16 21:09:14 +020049 u64 *nonces;
Filip Tehlara5abdeb2016-07-18 17:35:40 +020050 u8 to_be_removed;
Florin Corase127a7e2016-02-18 22:20:01 +010051} pending_map_request_t;
52
53typedef struct
54{
Filip Tehlar2fdaece2016-09-28 14:27:59 +020055 gid_address_t leid;
56 gid_address_t reid;
Filip Tehlar69a9b762016-09-23 10:00:52 +020057 u8 is_src_dst;
Florin Corasa2157cf2016-08-16 21:09:14 +020058 locator_pair_t *locator_pairs;
Florin Corase127a7e2016-02-18 22:20:01 +010059} fwd_entry_t;
60
Filip Tehlar69a9b762016-09-23 10:00:52 +020061typedef struct
62{
63 gid_address_t leid;
64 gid_address_t reid;
65} lisp_adjacency_t;
66
Florin Corase127a7e2016-02-18 22:20:01 +010067typedef enum
68{
69 IP4_MISS_PACKET,
70 IP6_MISS_PACKET
71} miss_packet_type_t;
72
Filip Tehlar397fd7d2016-10-26 14:31:24 +020073/* map-server/map-resolver structure */
Florin Corase127a7e2016-02-18 22:20:01 +010074typedef struct
75{
Filip Tehlara5abdeb2016-07-18 17:35:40 +020076 u8 is_down;
77 f64 last_update;
78 ip_address_t address;
Filip Tehlar397fd7d2016-10-26 14:31:24 +020079 char *key;
80} lisp_msmr_t;
Filip Tehlara5abdeb2016-07-18 17:35:40 +020081
82typedef struct
83{
Florin Corase127a7e2016-02-18 22:20:01 +010084 /* headers */
85 u8 data[100];
86 u32 length;
87 miss_packet_type_t type;
88} miss_packet_t;
89
Florin Corasdca88042016-09-14 16:01:38 +020090typedef enum
91{
92 MR_MODE_DST_ONLY = 0,
93 MR_MODE_SRC_DST,
94 _MR_MODE_MAX
95} map_request_mode_t;
96
Florin Corasba888e42017-01-24 11:38:18 -080097#define foreach_lisp_flag_bit \
Filip Tehlar4868ff62017-03-09 16:48:39 +010098 _(USE_PETR, "Use Proxy-ETR") \
99 _(STATS_ENABLED, "Statistics enabled")
Florin Corasba888e42017-01-24 11:38:18 -0800100
101typedef enum lisp_flag_bits
102{
103#define _(sym, str) LISP_FLAG_BIT_##sym,
104 foreach_lisp_flag_bit
105#undef _
106} lisp_flag_bits_e;
107
108typedef enum lisp_flags
109{
110#define _(sym, str) LISP_FLAG_##sym = 1 << LISP_FLAG_BIT_##sym,
111 foreach_lisp_flag_bit
112#undef _
113} lisp_flags_e;
114
Florin Corase127a7e2016-02-18 22:20:01 +0100115typedef struct
116{
Florin Corasba888e42017-01-24 11:38:18 -0800117 u32 flags;
118
Filip Tehlar46d4e362016-05-09 09:39:26 +0200119 /* LISP feature status */
120 u8 is_enabled;
121
Florin Corase127a7e2016-02-18 22:20:01 +0100122 /* eid table */
123 gid_dictionary_t mapping_index_by_gid;
124
125 /* pool of mappings */
Florin Corasa2157cf2016-08-16 21:09:14 +0200126 mapping_t *mapping_pool;
Florin Corase127a7e2016-02-18 22:20:01 +0100127
Filip Tehlar397fd7d2016-10-26 14:31:24 +0200128 /* hash map of secret keys by mapping index */
129 u8 *key_by_mapping_index;
130
Florin Corase127a7e2016-02-18 22:20:01 +0100131 /* pool of locators */
Florin Corasa2157cf2016-08-16 21:09:14 +0200132 locator_t *locator_pool;
Florin Corase127a7e2016-02-18 22:20:01 +0100133
134 /* pool of locator-sets */
Florin Corasa2157cf2016-08-16 21:09:14 +0200135 locator_set_t *locator_set_pool;
Florin Corase127a7e2016-02-18 22:20:01 +0100136
137 /* vector of locator-set vectors composed of and indexed by locator index */
Florin Corasa2157cf2016-08-16 21:09:14 +0200138 u32 **locator_to_locator_sets;
Florin Corase127a7e2016-02-18 22:20:01 +0100139
140 /* hash map of locators by name */
Florin Corasa2157cf2016-08-16 21:09:14 +0200141 uword *locator_set_index_by_name;
Florin Corase127a7e2016-02-18 22:20:01 +0100142
143 /* vector of eid index vectors supported and indexed by locator-set index */
Florin Corasa2157cf2016-08-16 21:09:14 +0200144 u32 **locator_set_to_eids;
Florin Corase127a7e2016-02-18 22:20:01 +0100145
146 /* vectors of indexes for local locator-sets and mappings */
Florin Corasa2157cf2016-08-16 21:09:14 +0200147 u32 *local_mappings_indexes;
148 u32 *local_locator_set_indexes;
Florin Corase127a7e2016-02-18 22:20:01 +0100149
150 /* hash map of forwarding entries by mapping index */
Florin Corasa2157cf2016-08-16 21:09:14 +0200151 u32 *fwd_entry_by_mapping_index;
Florin Corase127a7e2016-02-18 22:20:01 +0100152
153 /* forwarding entries pool */
Florin Corasa2157cf2016-08-16 21:09:14 +0200154 fwd_entry_t *fwd_entry_pool;
Florin Corase127a7e2016-02-18 22:20:01 +0100155
156 /* hash map keyed by nonce of pending map-requests */
Florin Corasa2157cf2016-08-16 21:09:14 +0200157 uword *pending_map_requests_by_nonce;
Florin Corase127a7e2016-02-18 22:20:01 +0100158
159 /* pool of pending map requests */
Florin Corasa2157cf2016-08-16 21:09:14 +0200160 pending_map_request_t *pending_map_requests_pool;
Florin Corase127a7e2016-02-18 22:20:01 +0100161
Filip Tehlar397fd7d2016-10-26 14:31:24 +0200162 /* hash map of sent map register messages */
163 uword *map_register_messages_by_nonce;
164
Filip Tehlara5abdeb2016-07-18 17:35:40 +0200165 /* vector of map-resolvers */
Filip Tehlar397fd7d2016-10-26 14:31:24 +0200166 lisp_msmr_t *map_resolvers;
167
168 /* vector of map-servers */
169 lisp_msmr_t *map_servers;
Filip Tehlara5abdeb2016-07-18 17:35:40 +0200170
171 /* map resolver address currently being used for sending requests.
172 * This has to be an actual address and not an index to map_resolvers vector
173 * since the vector may be modified during request resend/retry procedure
174 * and break things :-) */
175 ip_address_t active_map_resolver;
176
177 u8 do_map_resolver_election;
Florin Corase127a7e2016-02-18 22:20:01 +0100178
Andrej Kozemcakb6e4d392016-06-14 13:55:57 +0200179 /* map-request locator set index */
180 u32 mreq_itr_rlocs;
181
Florin Coras1a1adc72016-07-22 01:45:30 +0200182 /* vni to vrf hash tables */
Florin Corasa2157cf2016-08-16 21:09:14 +0200183 uword *table_id_by_vni;
184 uword *vni_by_table_id;
Filip Tehlar324112f2016-06-02 16:07:38 +0200185
Florin Coras1a1adc72016-07-22 01:45:30 +0200186 /* vni to bd-index hash tables */
Florin Corasa2157cf2016-08-16 21:09:14 +0200187 uword *bd_id_by_vni;
188 uword *vni_by_bd_id;
Florin Coras1a1adc72016-07-22 01:45:30 +0200189
190 /* track l2 and l3 interfaces that have been created for vni */
Florin Corasa2157cf2016-08-16 21:09:14 +0200191 uword *l2_dp_intf_by_vni;
Florin Coras577c3552016-04-21 00:45:40 +0200192
Florin Corasba888e42017-01-24 11:38:18 -0800193 /* Proxy ITR map index */
Filip Tehlar53f09e32016-05-19 14:25:44 +0200194 u32 pitr_map_index;
195
Florin Corasba888e42017-01-24 11:38:18 -0800196 /** Proxy ETR map index */
197 u32 petr_map_index;
198
Filip Tehlar53f09e32016-05-19 14:25:44 +0200199 /* LISP PITR mode */
200 u8 lisp_pitr;
201
Florin Corasdca88042016-09-14 16:01:38 +0200202 /* map request mode */
203 u8 map_request_mode;
204
Filip Tehlar397fd7d2016-10-26 14:31:24 +0200205 /* enable/disable map registering */
206 u8 map_registering;
207
208 /* enable/disable rloc-probing */
209 u8 rloc_probing;
210
Filip Tehlar9677a942016-11-28 10:23:31 +0100211 /* timing wheel for mappping timeouts */
212 timing_wheel_t wheel;
213
Florin Corase127a7e2016-02-18 22:20:01 +0100214 /* commodity */
Florin Corasa2157cf2016-08-16 21:09:14 +0200215 ip4_main_t *im4;
216 ip6_main_t *im6;
217 vlib_main_t *vlib_main;
218 vnet_main_t *vnet_main;
Florin Corase127a7e2016-02-18 22:20:01 +0100219} lisp_cp_main_t;
220
221/* lisp-gpe control plane */
Florin Corasf3dc11a2017-01-24 03:13:43 -0800222extern lisp_cp_main_t lisp_control_main;
Florin Corase127a7e2016-02-18 22:20:01 +0100223
224extern vlib_node_registration_t lisp_cp_input_node;
Neale Ranns0bfe5d82016-08-25 15:29:12 +0100225extern vlib_node_registration_t lisp_cp_lookup_ip4_node;
226extern vlib_node_registration_t lisp_cp_lookup_ip6_node;
Florin Corase127a7e2016-02-18 22:20:01 +0100227
Florin Corasa2157cf2016-08-16 21:09:14 +0200228clib_error_t *lisp_cp_init ();
Florin Corase127a7e2016-02-18 22:20:01 +0100229
Florin Corasf727db92016-06-23 15:01:58 +0200230always_inline lisp_cp_main_t *
Florin Corasa2157cf2016-08-16 21:09:14 +0200231vnet_lisp_cp_get_main ()
232{
Florin Corasf727db92016-06-23 15:01:58 +0200233 return &lisp_control_main;
234}
235
Filip Tehlar4868ff62017-03-09 16:48:39 +0100236void
237get_src_and_dst_eids_from_buffer (lisp_cp_main_t * lcm, vlib_buffer_t * b,
238 gid_address_t * src, gid_address_t * dst,
239 u16 type);
240
Florin Corase127a7e2016-02-18 22:20:01 +0100241typedef struct
242{
243 u8 is_add;
244 union
245 {
Florin Corasa2157cf2016-08-16 21:09:14 +0200246 u8 *name;
Florin Corase127a7e2016-02-18 22:20:01 +0100247 u32 index;
248 };
Florin Corasa2157cf2016-08-16 21:09:14 +0200249 locator_t *locators;
Florin Corase127a7e2016-02-18 22:20:01 +0100250 u8 local;
251} vnet_lisp_add_del_locator_set_args_t;
252
253int
254vnet_lisp_add_del_locator_set (vnet_lisp_add_del_locator_set_args_t * a,
255 u32 * ls_index);
Andrej Kozemcakb92feb62016-03-31 13:51:42 +0200256int
Andrej Kozemcakb92feb62016-03-31 13:51:42 +0200257vnet_lisp_add_del_locator (vnet_lisp_add_del_locator_set_args_t * a,
Florin Corasa2157cf2016-08-16 21:09:14 +0200258 locator_set_t * ls, u32 * ls_index);
Andrej Kozemcakb92feb62016-03-31 13:51:42 +0200259
Florin Corase127a7e2016-02-18 22:20:01 +0100260typedef struct
261{
262 u8 is_add;
Florin Corasf727db92016-06-23 15:01:58 +0200263 gid_address_t eid;
Florin Corase127a7e2016-02-18 22:20:01 +0100264 u32 locator_set_index;
265
266 u32 ttl;
267 u8 action;
268 u8 authoritative;
269
270 u8 local;
Filip Tehlar3cd9e732016-08-23 10:52:44 +0200271 u8 is_static;
Filip Tehlar397fd7d2016-10-26 14:31:24 +0200272 u8 *key;
273 u8 key_id;
Florin Corase127a7e2016-02-18 22:20:01 +0100274} vnet_lisp_add_del_mapping_args_t;
275
276int
Florin Corasa2157cf2016-08-16 21:09:14 +0200277vnet_lisp_map_cache_add_del (vnet_lisp_add_del_mapping_args_t * a,
278 u32 * map_index);
Florin Coras577c3552016-04-21 00:45:40 +0200279int
280vnet_lisp_add_del_local_mapping (vnet_lisp_add_del_mapping_args_t * a,
Florin Corasa2157cf2016-08-16 21:09:14 +0200281 u32 * map_index_result);
Florin Corase127a7e2016-02-18 22:20:01 +0100282
Florin Corasf727db92016-06-23 15:01:58 +0200283int
284vnet_lisp_add_del_mapping (gid_address_t * deid, locator_t * dlocs, u8 action,
Filip Tehlar3cd9e732016-08-23 10:52:44 +0200285 u8 authoritative, u32 ttl, u8 is_add, u8 is_static,
Florin Corasa2157cf2016-08-16 21:09:14 +0200286 u32 * res_map_index);
Florin Corasf727db92016-06-23 15:01:58 +0200287
288typedef struct
289{
Filip Tehlar2fdaece2016-09-28 14:27:59 +0200290 gid_address_t reid;
291 gid_address_t leid;
Florin Corasf727db92016-06-23 15:01:58 +0200292 u8 is_add;
293} vnet_lisp_add_del_adjacency_args_t;
294
Florin Corasa2157cf2016-08-16 21:09:14 +0200295int vnet_lisp_add_del_adjacency (vnet_lisp_add_del_adjacency_args_t * a);
Florin Corasf727db92016-06-23 15:01:58 +0200296
Florin Corase127a7e2016-02-18 22:20:01 +0100297typedef struct
298{
299 u8 is_add;
300 ip_address_t address;
301} vnet_lisp_add_del_map_resolver_args_t;
302
303int
304vnet_lisp_add_del_map_resolver (vnet_lisp_add_del_map_resolver_args_t * a);
Filip Tehlar397fd7d2016-10-26 14:31:24 +0200305int vnet_lisp_add_del_map_server (ip_address_t * addr, u8 is_add);
Florin Corase127a7e2016-02-18 22:20:01 +0100306
Florin Corasa2157cf2016-08-16 21:09:14 +0200307clib_error_t *vnet_lisp_enable_disable (u8 is_enabled);
308u8 vnet_lisp_enable_disable_status (void);
Filip Tehlar195bcee2016-05-13 17:37:35 +0200309
Florin Corasa2157cf2016-08-16 21:09:14 +0200310int vnet_lisp_pitr_set_locator_set (u8 * locator_set_name, u8 is_add);
Florin Corasba888e42017-01-24 11:38:18 -0800311int vnet_lisp_use_petr (ip_address_t * ip, u8 is_add);
Filip Tehlar53f09e32016-05-19 14:25:44 +0200312
Andrej Kozemcakb6e4d392016-06-14 13:55:57 +0200313typedef struct
314{
315 u8 is_add;
Florin Corasa2157cf2016-08-16 21:09:14 +0200316 u8 *locator_set_name;
Andrej Kozemcakb6e4d392016-06-14 13:55:57 +0200317} vnet_lisp_add_del_mreq_itr_rloc_args_t;
318
319int
320vnet_lisp_add_del_mreq_itr_rlocs (vnet_lisp_add_del_mreq_itr_rloc_args_t * a);
321
Florin Corasa2157cf2016-08-16 21:09:14 +0200322int vnet_lisp_clear_all_remote_adjacencies (void);
Filip Tehlar58f886a2016-05-30 15:57:40 +0200323
Florin Corasa2157cf2016-08-16 21:09:14 +0200324int vnet_lisp_eid_table_map (u32 vni, u32 vrf, u8 is_l2, u8 is_add);
Filip Tehlar397fd7d2016-10-26 14:31:24 +0200325int vnet_lisp_add_del_map_table_key (gid_address_t * eid, char *key,
326 u8 is_add);
Florin Corasdca88042016-09-14 16:01:38 +0200327int vnet_lisp_set_map_request_mode (u8 mode);
328u8 vnet_lisp_get_map_request_mode (void);
Filip Tehlar69a9b762016-09-23 10:00:52 +0200329lisp_adjacency_t *vnet_lisp_adjacencies_get_by_vni (u32 vni);
Filip Tehlar397fd7d2016-10-26 14:31:24 +0200330int vnet_lisp_rloc_probe_enable_disable (u8 is_enable);
331int vnet_lisp_map_register_enable_disable (u8 is_enable);
332u8 vnet_lisp_map_register_state_get (void);
333u8 vnet_lisp_rloc_probe_state_get (void);
Filip Tehlar324112f2016-06-02 16:07:38 +0200334
Florin Corasba888e42017-01-24 11:38:18 -0800335always_inline mapping_t *
336lisp_get_petr_mapping (lisp_cp_main_t * lcm)
337{
338 return pool_elt_at_index (lcm->mapping_pool, lcm->petr_map_index);
339}
340
Florin Corase127a7e2016-02-18 22:20:01 +0100341#endif /* VNET_CONTROL_H_ */
Florin Corasa2157cf2016-08-16 21:09:14 +0200342
343/*
344 * fd.io coding-style-patch-verification: ON
345 *
346 * Local Variables:
347 * eval: (c-set-style "gnu")
348 * End:
349 */