blob: 0df18f4284d958dca6e2332edbb2b2dd59d51686 [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>
Dave Barach5c20a012017-06-13 08:48:31 -040022#include <vppinfra/timing_wheel.h>
Florin Corase127a7e2016-02-18 22:20:01 +010023
Filip Tehlara5abdeb2016-07-18 17:35:40 +020024#define NUMBER_OF_RETRIES 1
Florin Corasa2157cf2016-08-16 21:09:14 +020025#define PENDING_MREQ_EXPIRATION_TIME 3.0 /* seconds */
Florin Corasf4691cd2016-08-15 19:16:32 +020026#define PENDING_MREQ_QUEUE_LEN 5
Filip Tehlara5abdeb2016-07-18 17:35:40 +020027
Filip Tehlar397fd7d2016-10-26 14:31:24 +020028#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 */
Filip Tehlar7048ff12017-07-27 08:09:14 +020033#define QUICK_MAP_REGISTER_MSG_COUNT 5
Filip Tehlar397fd7d2016-10-26 14:31:24 +020034#define QUICK_MAP_REGISTER_INTERVAL 3.0
35
36/* normal map-register period */
37#define MAP_REGISTER_INTERVAL 60.0
38
Filip Tehlar7048ff12017-07-27 08:09:14 +020039/* how many tries until next map-server election */
40#define MAX_EXPIRED_MAP_REGISTERS_DEFAULT 3
41
42#define PENDING_MREG_EXPIRATION_TIME 3.0 /* seconds */
43
Florin Corascdc74272017-06-21 16:27:01 -070044/* 24 hours */
45#define MAP_REGISTER_DEFAULT_TTL 86400
Filip Tehlar397fd7d2016-10-26 14:31:24 +020046
Florin Corase127a7e2016-02-18 22:20:01 +010047typedef struct
48{
49 gid_address_t src;
50 gid_address_t dst;
Filip Tehlara5abdeb2016-07-18 17:35:40 +020051 u32 retries_num;
52 f64 time_to_expire;
53 u8 is_smr_invoked;
Florin Corasa2157cf2016-08-16 21:09:14 +020054 u64 *nonces;
Filip Tehlara5abdeb2016-07-18 17:35:40 +020055 u8 to_be_removed;
Florin Corase127a7e2016-02-18 22:20:01 +010056} pending_map_request_t;
57
58typedef struct
59{
Filip Tehlar7048ff12017-07-27 08:09:14 +020060 f64 time_to_expire;
61} pending_map_register_t;
62
63typedef struct
64{
Filip Tehlar2fdaece2016-09-28 14:27:59 +020065 gid_address_t leid;
66 gid_address_t reid;
Filip Tehlar69a9b762016-09-23 10:00:52 +020067 u8 is_src_dst;
Florin Corasa2157cf2016-08-16 21:09:14 +020068 locator_pair_t *locator_pairs;
Florin Corase127a7e2016-02-18 22:20:01 +010069} fwd_entry_t;
70
Filip Tehlar69a9b762016-09-23 10:00:52 +020071typedef struct
72{
73 gid_address_t leid;
74 gid_address_t reid;
75} lisp_adjacency_t;
76
Florin Corase127a7e2016-02-18 22:20:01 +010077typedef enum
78{
79 IP4_MISS_PACKET,
80 IP6_MISS_PACKET
81} miss_packet_type_t;
82
Filip Tehlar397fd7d2016-10-26 14:31:24 +020083/* map-server/map-resolver structure */
Florin Corase127a7e2016-02-18 22:20:01 +010084typedef struct
85{
Filip Tehlara5abdeb2016-07-18 17:35:40 +020086 u8 is_down;
87 f64 last_update;
88 ip_address_t address;
Filip Tehlar397fd7d2016-10-26 14:31:24 +020089 char *key;
90} lisp_msmr_t;
Filip Tehlara5abdeb2016-07-18 17:35:40 +020091
92typedef struct
93{
Florin Corase127a7e2016-02-18 22:20:01 +010094 /* headers */
95 u8 data[100];
96 u32 length;
97 miss_packet_type_t type;
98} miss_packet_t;
99
Filip Tehlard5a65db2017-05-17 17:21:10 +0200100typedef struct
101{
102 u8 mac[6];
103 u32 ip4;
104} lisp_api_l2_arp_entry_t;
105
Filip Tehlar05879992017-09-05 15:46:09 +0200106typedef struct
107{
108 u8 mac[6];
109 u8 ip6[16];
110} lisp_api_ndp_entry_t;
111
Florin Corasdca88042016-09-14 16:01:38 +0200112typedef enum
113{
114 MR_MODE_DST_ONLY = 0,
115 MR_MODE_SRC_DST,
116 _MR_MODE_MAX
117} map_request_mode_t;
118
Florin Corasba888e42017-01-24 11:38:18 -0800119#define foreach_lisp_flag_bit \
Filip Tehlar4868ff62017-03-09 16:48:39 +0100120 _(USE_PETR, "Use Proxy-ETR") \
121 _(STATS_ENABLED, "Statistics enabled")
Florin Corasba888e42017-01-24 11:38:18 -0800122
123typedef enum lisp_flag_bits
124{
125#define _(sym, str) LISP_FLAG_BIT_##sym,
126 foreach_lisp_flag_bit
127#undef _
128} lisp_flag_bits_e;
129
130typedef enum lisp_flags
131{
132#define _(sym, str) LISP_FLAG_##sym = 1 << LISP_FLAG_BIT_##sym,
133 foreach_lisp_flag_bit
134#undef _
135} lisp_flags_e;
136
Florin Corase127a7e2016-02-18 22:20:01 +0100137typedef struct
138{
Filip Tehlard5a65db2017-05-17 17:21:10 +0200139 ip_address_t addr;
140 u32 bd;
141} lisp_l2_arp_key_t;
142
143typedef struct
144{
Florin Corasacd4c632017-06-15 14:33:48 -0700145 u64 nonce;
146 u8 is_rloc_probe;
147 mapping_t *mappings;
148 volatile u8 is_free;
149} map_records_arg_t;
150
151typedef struct
152{
Florin Corasba888e42017-01-24 11:38:18 -0800153 u32 flags;
154
Filip Tehlar46d4e362016-05-09 09:39:26 +0200155 /* LISP feature status */
156 u8 is_enabled;
157
Florin Corase127a7e2016-02-18 22:20:01 +0100158 /* eid table */
159 gid_dictionary_t mapping_index_by_gid;
160
161 /* pool of mappings */
Florin Corasa2157cf2016-08-16 21:09:14 +0200162 mapping_t *mapping_pool;
Florin Corase127a7e2016-02-18 22:20:01 +0100163
Filip Tehlar397fd7d2016-10-26 14:31:24 +0200164 /* hash map of secret keys by mapping index */
165 u8 *key_by_mapping_index;
166
Florin Corase127a7e2016-02-18 22:20:01 +0100167 /* pool of locators */
Florin Corasa2157cf2016-08-16 21:09:14 +0200168 locator_t *locator_pool;
Florin Corase127a7e2016-02-18 22:20:01 +0100169
170 /* pool of locator-sets */
Florin Corasa2157cf2016-08-16 21:09:14 +0200171 locator_set_t *locator_set_pool;
Florin Corase127a7e2016-02-18 22:20:01 +0100172
173 /* vector of locator-set vectors composed of and indexed by locator index */
Florin Corasa2157cf2016-08-16 21:09:14 +0200174 u32 **locator_to_locator_sets;
Florin Corase127a7e2016-02-18 22:20:01 +0100175
176 /* hash map of locators by name */
Florin Corasa2157cf2016-08-16 21:09:14 +0200177 uword *locator_set_index_by_name;
Florin Corase127a7e2016-02-18 22:20:01 +0100178
179 /* vector of eid index vectors supported and indexed by locator-set index */
Florin Corasa2157cf2016-08-16 21:09:14 +0200180 u32 **locator_set_to_eids;
Florin Corase127a7e2016-02-18 22:20:01 +0100181
182 /* vectors of indexes for local locator-sets and mappings */
Florin Corasa2157cf2016-08-16 21:09:14 +0200183 u32 *local_mappings_indexes;
184 u32 *local_locator_set_indexes;
Florin Corase127a7e2016-02-18 22:20:01 +0100185
186 /* hash map of forwarding entries by mapping index */
Florin Corasa2157cf2016-08-16 21:09:14 +0200187 u32 *fwd_entry_by_mapping_index;
Florin Corase127a7e2016-02-18 22:20:01 +0100188
Alberto Rodriguez-Natal8d66f9d2017-09-09 14:15:15 -0700189 /* pool of vectors of rmts per lcl mapping in adjacencies */
190 u32 **lcl_to_rmt_adjacencies;
191
192 /* hash of pool positions of vectors of rmts by lcl mapping index */
193 u32 *lcl_to_rmt_adjs_by_lcl_idx;
194
Florin Corase127a7e2016-02-18 22:20:01 +0100195 /* forwarding entries pool */
Florin Corasa2157cf2016-08-16 21:09:14 +0200196 fwd_entry_t *fwd_entry_pool;
Florin Corase127a7e2016-02-18 22:20:01 +0100197
198 /* hash map keyed by nonce of pending map-requests */
Florin Corasa2157cf2016-08-16 21:09:14 +0200199 uword *pending_map_requests_by_nonce;
Florin Corase127a7e2016-02-18 22:20:01 +0100200
201 /* pool of pending map requests */
Florin Corasa2157cf2016-08-16 21:09:14 +0200202 pending_map_request_t *pending_map_requests_pool;
Florin Corase127a7e2016-02-18 22:20:01 +0100203
Filip Tehlar7048ff12017-07-27 08:09:14 +0200204 /* pool of pending map registers */
205 pending_map_register_t *pending_map_registers_pool;
206
Filip Tehlar397fd7d2016-10-26 14:31:24 +0200207 /* hash map of sent map register messages */
208 uword *map_register_messages_by_nonce;
209
Filip Tehlara5abdeb2016-07-18 17:35:40 +0200210 /* vector of map-resolvers */
Filip Tehlar397fd7d2016-10-26 14:31:24 +0200211 lisp_msmr_t *map_resolvers;
212
213 /* vector of map-servers */
214 lisp_msmr_t *map_servers;
Filip Tehlara5abdeb2016-07-18 17:35:40 +0200215
216 /* map resolver address currently being used for sending requests.
217 * This has to be an actual address and not an index to map_resolvers vector
218 * since the vector may be modified during request resend/retry procedure
219 * and break things :-) */
220 ip_address_t active_map_resolver;
Filip Tehlar7048ff12017-07-27 08:09:14 +0200221 ip_address_t active_map_server;
Filip Tehlara5abdeb2016-07-18 17:35:40 +0200222
223 u8 do_map_resolver_election;
Filip Tehlar7048ff12017-07-27 08:09:14 +0200224 u8 do_map_server_election;
Florin Corase127a7e2016-02-18 22:20:01 +0100225
Andrej Kozemcakb6e4d392016-06-14 13:55:57 +0200226 /* map-request locator set index */
227 u32 mreq_itr_rlocs;
228
Florin Coras1a1adc72016-07-22 01:45:30 +0200229 /* vni to vrf hash tables */
Florin Corasa2157cf2016-08-16 21:09:14 +0200230 uword *table_id_by_vni;
231 uword *vni_by_table_id;
Filip Tehlar324112f2016-06-02 16:07:38 +0200232
Florin Coras1a1adc72016-07-22 01:45:30 +0200233 /* vni to bd-index hash tables */
Florin Corasa2157cf2016-08-16 21:09:14 +0200234 uword *bd_id_by_vni;
235 uword *vni_by_bd_id;
Florin Coras1a1adc72016-07-22 01:45:30 +0200236
237 /* track l2 and l3 interfaces that have been created for vni */
Florin Corasa2157cf2016-08-16 21:09:14 +0200238 uword *l2_dp_intf_by_vni;
Florin Coras577c3552016-04-21 00:45:40 +0200239
Florin Corasba888e42017-01-24 11:38:18 -0800240 /* Proxy ITR map index */
Filip Tehlar53f09e32016-05-19 14:25:44 +0200241 u32 pitr_map_index;
242
Florin Corasba888e42017-01-24 11:38:18 -0800243 /** Proxy ETR map index */
244 u32 petr_map_index;
245
Filip Tehlar53f09e32016-05-19 14:25:44 +0200246 /* LISP PITR mode */
247 u8 lisp_pitr;
248
Filip Tehlaref2a5bf2017-05-30 07:14:46 +0200249 /* mapping index for NSH */
250 u32 nsh_map_index;
251
Florin Corasdca88042016-09-14 16:01:38 +0200252 /* map request mode */
253 u8 map_request_mode;
254
Filip Tehlar397fd7d2016-10-26 14:31:24 +0200255 /* enable/disable map registering */
256 u8 map_registering;
257
258 /* enable/disable rloc-probing */
259 u8 rloc_probing;
260
Filip Tehlar9677a942016-11-28 10:23:31 +0100261 /* timing wheel for mappping timeouts */
262 timing_wheel_t wheel;
263
Florin Corasacd4c632017-06-15 14:33:48 -0700264 /** Per thread pool of records shared with thread0 */
265 map_records_arg_t **map_records_args_pool;
266
Filip Tehlar1e553a02017-08-02 12:45:07 +0200267 /* TTL used for all mappings when registering */
268 u32 map_register_ttl;
269
Filip Tehlar7048ff12017-07-27 08:09:14 +0200270 /* control variables for map server election */
271 u32 max_expired_map_registers;
272 u32 expired_map_registers;
273
Florin Corase127a7e2016-02-18 22:20:01 +0100274 /* commodity */
Florin Corasa2157cf2016-08-16 21:09:14 +0200275 ip4_main_t *im4;
276 ip6_main_t *im6;
277 vlib_main_t *vlib_main;
278 vnet_main_t *vnet_main;
Florin Corase127a7e2016-02-18 22:20:01 +0100279} lisp_cp_main_t;
280
281/* lisp-gpe control plane */
Florin Corasf3dc11a2017-01-24 03:13:43 -0800282extern lisp_cp_main_t lisp_control_main;
Florin Corase127a7e2016-02-18 22:20:01 +0100283
284extern vlib_node_registration_t lisp_cp_input_node;
Neale Ranns0bfe5d82016-08-25 15:29:12 +0100285extern vlib_node_registration_t lisp_cp_lookup_ip4_node;
286extern vlib_node_registration_t lisp_cp_lookup_ip6_node;
Florin Corase127a7e2016-02-18 22:20:01 +0100287
Florin Corasa2157cf2016-08-16 21:09:14 +0200288clib_error_t *lisp_cp_init ();
Florin Corase127a7e2016-02-18 22:20:01 +0100289
Florin Corasf727db92016-06-23 15:01:58 +0200290always_inline lisp_cp_main_t *
Florin Corasa2157cf2016-08-16 21:09:14 +0200291vnet_lisp_cp_get_main ()
292{
Florin Corasf727db92016-06-23 15:01:58 +0200293 return &lisp_control_main;
294}
295
Filip Tehlar4868ff62017-03-09 16:48:39 +0100296void
297get_src_and_dst_eids_from_buffer (lisp_cp_main_t * lcm, vlib_buffer_t * b,
298 gid_address_t * src, gid_address_t * dst,
299 u16 type);
300
Florin Corase127a7e2016-02-18 22:20:01 +0100301typedef struct
302{
303 u8 is_add;
304 union
305 {
Florin Corasa2157cf2016-08-16 21:09:14 +0200306 u8 *name;
Florin Corase127a7e2016-02-18 22:20:01 +0100307 u32 index;
308 };
Florin Corasa2157cf2016-08-16 21:09:14 +0200309 locator_t *locators;
Florin Corase127a7e2016-02-18 22:20:01 +0100310 u8 local;
311} vnet_lisp_add_del_locator_set_args_t;
312
313int
314vnet_lisp_add_del_locator_set (vnet_lisp_add_del_locator_set_args_t * a,
315 u32 * ls_index);
Andrej Kozemcakb92feb62016-03-31 13:51:42 +0200316int
Andrej Kozemcakb92feb62016-03-31 13:51:42 +0200317vnet_lisp_add_del_locator (vnet_lisp_add_del_locator_set_args_t * a,
Florin Corasa2157cf2016-08-16 21:09:14 +0200318 locator_set_t * ls, u32 * ls_index);
Andrej Kozemcakb92feb62016-03-31 13:51:42 +0200319
Florin Corase127a7e2016-02-18 22:20:01 +0100320typedef struct
321{
322 u8 is_add;
Florin Corasf727db92016-06-23 15:01:58 +0200323 gid_address_t eid;
Florin Corase127a7e2016-02-18 22:20:01 +0100324 u32 locator_set_index;
325
326 u32 ttl;
327 u8 action;
328 u8 authoritative;
329
330 u8 local;
Filip Tehlar3cd9e732016-08-23 10:52:44 +0200331 u8 is_static;
Filip Tehlar397fd7d2016-10-26 14:31:24 +0200332 u8 *key;
333 u8 key_id;
Florin Corase127a7e2016-02-18 22:20:01 +0100334} vnet_lisp_add_del_mapping_args_t;
335
336int
Florin Corasa2157cf2016-08-16 21:09:14 +0200337vnet_lisp_map_cache_add_del (vnet_lisp_add_del_mapping_args_t * a,
338 u32 * map_index);
Florin Coras577c3552016-04-21 00:45:40 +0200339int
340vnet_lisp_add_del_local_mapping (vnet_lisp_add_del_mapping_args_t * a,
Florin Corasa2157cf2016-08-16 21:09:14 +0200341 u32 * map_index_result);
Florin Corase127a7e2016-02-18 22:20:01 +0100342
Florin Corasf727db92016-06-23 15:01:58 +0200343int
Filip Tehlar809bc742017-08-14 19:15:36 +0200344vnet_lisp_add_mapping (vnet_lisp_add_del_mapping_args_t * a,
345 locator_t * rlocs, u32 * res_map_index,
346 u8 * is_changed);
347
348int vnet_lisp_del_mapping (gid_address_t * eid, u32 * res_map_index);
Florin Corasf727db92016-06-23 15:01:58 +0200349
350typedef struct
351{
Filip Tehlar2fdaece2016-09-28 14:27:59 +0200352 gid_address_t reid;
353 gid_address_t leid;
Florin Corasf727db92016-06-23 15:01:58 +0200354 u8 is_add;
355} vnet_lisp_add_del_adjacency_args_t;
356
Florin Corasa2157cf2016-08-16 21:09:14 +0200357int vnet_lisp_add_del_adjacency (vnet_lisp_add_del_adjacency_args_t * a);
Florin Corasf727db92016-06-23 15:01:58 +0200358
Florin Corase127a7e2016-02-18 22:20:01 +0100359typedef struct
360{
361 u8 is_add;
362 ip_address_t address;
363} vnet_lisp_add_del_map_resolver_args_t;
364
365int
366vnet_lisp_add_del_map_resolver (vnet_lisp_add_del_map_resolver_args_t * a);
Filip Tehlar397fd7d2016-10-26 14:31:24 +0200367int vnet_lisp_add_del_map_server (ip_address_t * addr, u8 is_add);
Florin Corase127a7e2016-02-18 22:20:01 +0100368
Florin Corasa2157cf2016-08-16 21:09:14 +0200369clib_error_t *vnet_lisp_enable_disable (u8 is_enabled);
370u8 vnet_lisp_enable_disable_status (void);
Filip Tehlar195bcee2016-05-13 17:37:35 +0200371
Florin Corasa2157cf2016-08-16 21:09:14 +0200372int vnet_lisp_pitr_set_locator_set (u8 * locator_set_name, u8 is_add);
Florin Corasba888e42017-01-24 11:38:18 -0800373int vnet_lisp_use_petr (ip_address_t * ip, u8 is_add);
Filip Tehlar53f09e32016-05-19 14:25:44 +0200374
Andrej Kozemcakb6e4d392016-06-14 13:55:57 +0200375typedef struct
376{
377 u8 is_add;
Florin Corasa2157cf2016-08-16 21:09:14 +0200378 u8 *locator_set_name;
Andrej Kozemcakb6e4d392016-06-14 13:55:57 +0200379} vnet_lisp_add_del_mreq_itr_rloc_args_t;
380
381int
382vnet_lisp_add_del_mreq_itr_rlocs (vnet_lisp_add_del_mreq_itr_rloc_args_t * a);
383
Florin Corasa2157cf2016-08-16 21:09:14 +0200384int vnet_lisp_clear_all_remote_adjacencies (void);
Filip Tehlar58f886a2016-05-30 15:57:40 +0200385
Florin Corasa2157cf2016-08-16 21:09:14 +0200386int vnet_lisp_eid_table_map (u32 vni, u32 vrf, u8 is_l2, u8 is_add);
Filip Tehlar397fd7d2016-10-26 14:31:24 +0200387int vnet_lisp_add_del_map_table_key (gid_address_t * eid, char *key,
388 u8 is_add);
Florin Corasdca88042016-09-14 16:01:38 +0200389int vnet_lisp_set_map_request_mode (u8 mode);
390u8 vnet_lisp_get_map_request_mode (void);
Filip Tehlar69a9b762016-09-23 10:00:52 +0200391lisp_adjacency_t *vnet_lisp_adjacencies_get_by_vni (u32 vni);
Filip Tehlar397fd7d2016-10-26 14:31:24 +0200392int vnet_lisp_rloc_probe_enable_disable (u8 is_enable);
393int vnet_lisp_map_register_enable_disable (u8 is_enable);
394u8 vnet_lisp_map_register_state_get (void);
395u8 vnet_lisp_rloc_probe_state_get (void);
Filip Tehlar64929642017-09-20 08:41:23 +0200396int vnet_lisp_add_del_l2_arp_ndp_entry (gid_address_t * key, u8 * mac,
397 u8 is_add);
Filip Tehlard5a65db2017-05-17 17:21:10 +0200398u32 *vnet_lisp_l2_arp_bds_get (void);
399lisp_api_l2_arp_entry_t *vnet_lisp_l2_arp_entries_get_by_bd (u32 bd);
Filip Tehlaref2a5bf2017-05-30 07:14:46 +0200400int vnet_lisp_nsh_set_locator_set (u8 * locator_set_name, u8 is_add);
Filip Tehlar1e553a02017-08-02 12:45:07 +0200401int vnet_lisp_map_register_set_ttl (u32 ttl);
402u32 vnet_lisp_map_register_get_ttl (void);
Filip Tehlar7048ff12017-07-27 08:09:14 +0200403int vnet_lisp_map_register_fallback_threshold_set (u32 value);
404u32 vnet_lisp_map_register_fallback_threshold_get (void);
Filip Tehlar05879992017-09-05 15:46:09 +0200405u32 *vnet_lisp_ndp_bds_get (void);
406lisp_api_ndp_entry_t *vnet_lisp_ndp_entries_get_by_bd (u32 bd);
Filip Tehlar324112f2016-06-02 16:07:38 +0200407
Filip Tehlar816f4372017-04-26 16:09:06 +0200408map_records_arg_t *parse_map_reply (vlib_buffer_t * b);
409
Florin Corasba888e42017-01-24 11:38:18 -0800410always_inline mapping_t *
411lisp_get_petr_mapping (lisp_cp_main_t * lcm)
412{
413 return pool_elt_at_index (lcm->mapping_pool, lcm->petr_map_index);
414}
415
Florin Corase127a7e2016-02-18 22:20:01 +0100416#endif /* VNET_CONTROL_H_ */
Florin Corasa2157cf2016-08-16 21:09:14 +0200417
418/*
419 * fd.io coding-style-patch-verification: ON
420 *
421 * Local Variables:
422 * eval: (c-set-style "gnu")
423 * End:
424 */