blob: 052410e27d6f5178280af1fb8258be0283c4c2b6 [file] [log] [blame]
Ed Warnickecb9cada2015-12-08 15:45:58 -07001/*
Florin Corase127a7e2016-02-18 22:20:01 +01002 * Copyright (c) 2016 Cisco and/or its affiliates.
Ed Warnickecb9cada2015-12-08 15:45:58 -07003 * 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 */
Florin Corasff0bf132016-09-05 19:30:35 +020015/**
16 * @file
17 * @brief Common utility functions for IPv4, IPv6 and L2 LISP-GPE tunnels.
18 *
19 */
Florin Corase127a7e2016-02-18 22:20:01 +010020
Ed Warnickecb9cada2015-12-08 15:45:58 -070021#include <vnet/lisp-gpe/lisp_gpe.h>
Neale Ranns5e575b12016-10-03 09:40:25 +010022#include <vnet/lisp-gpe/lisp_gpe_fwd_entry.h>
Neale Ranns0bfe5d82016-08-25 15:29:12 +010023#include <vnet/lisp-gpe/lisp_gpe_adjacency.h>
Neale Ranns5e575b12016-10-03 09:40:25 +010024#include <vnet/lisp-gpe/lisp_gpe_tenant.h>
Ed Warnickecb9cada2015-12-08 15:45:58 -070025
Florin Corasff0bf132016-09-05 19:30:35 +020026/** LISP-GPE global state */
Ed Warnickecb9cada2015-12-08 15:45:58 -070027lisp_gpe_main_t lisp_gpe_main;
28
Florin Coras1a1adc72016-07-22 01:45:30 +020029
Florin Corasff0bf132016-09-05 19:30:35 +020030/** CLI command to add/del forwarding entry. */
Ed Warnickecb9cada2015-12-08 15:45:58 -070031static clib_error_t *
Florin Corase127a7e2016-02-18 22:20:01 +010032lisp_gpe_add_del_fwd_entry_command_fn (vlib_main_t * vm,
Florin Coras220beac2016-08-16 23:04:00 +020033 unformat_input_t * input,
34 vlib_cli_command_t * cmd)
Ed Warnickecb9cada2015-12-08 15:45:58 -070035{
Florin Coras220beac2016-08-16 23:04:00 +020036 unformat_input_t _line_input, *line_input = &_line_input;
Ed Warnickecb9cada2015-12-08 15:45:58 -070037 u8 is_add = 1;
Florin Corasbb5c22f2016-08-02 02:31:03 +020038 ip_address_t lloc, rloc;
Florin Coras220beac2016-08-16 23:04:00 +020039 clib_error_t *error = 0;
40 gid_address_t _reid, *reid = &_reid, _leid, *leid = &_leid;
Filip Tehlarc3af7bf2017-01-13 14:13:09 +010041 u8 reid_set = 0, leid_set = 0, is_negative = 0, dp_table_set = 0,
42 vni_set = 0;
43 u32 vni = 0, dp_table = 0, action = ~0, w;
Florin Coras220beac2016-08-16 23:04:00 +020044 locator_pair_t pair, *pairs = 0;
Andrej Kozemcak8ebb2a12016-06-07 12:25:20 +020045 int rv;
Florin Corase127a7e2016-02-18 22:20:01 +010046
Filip Tehlarc3af7bf2017-01-13 14:13:09 +010047 memset (leid, 0, sizeof (*leid));
48 memset (reid, 0, sizeof (*reid));
49
Ed Warnickecb9cada2015-12-08 15:45:58 -070050 /* Get a line of input. */
Florin Coras220beac2016-08-16 23:04:00 +020051 if (!unformat_user (input, unformat_line_input, line_input))
Ed Warnickecb9cada2015-12-08 15:45:58 -070052 return 0;
53
Florin Corase127a7e2016-02-18 22:20:01 +010054 while (unformat_check_input (line_input) != UNFORMAT_END_OF_INPUT)
55 {
56 if (unformat (line_input, "del"))
Florin Coras220beac2016-08-16 23:04:00 +020057 is_add = 0;
Florin Corase127a7e2016-02-18 22:20:01 +010058 else if (unformat (line_input, "add"))
Florin Coras220beac2016-08-16 23:04:00 +020059 is_add = 1;
60 else if (unformat (line_input, "leid %U", unformat_gid_address, leid))
61 {
62 leid_set = 1;
63 }
64 else if (unformat (line_input, "reid %U", unformat_gid_address, reid))
65 {
66 reid_set = 1;
67 }
Florin Coras03c4f992016-07-19 15:27:58 +020068 else if (unformat (line_input, "vni %u", &vni))
Florin Coras220beac2016-08-16 23:04:00 +020069 {
70 gid_address_vni (leid) = vni;
71 gid_address_vni (reid) = vni;
72 vni_set = 1;
73 }
Filip Tehlarc3af7bf2017-01-13 14:13:09 +010074 else if (unformat (line_input, "vrf %u", &dp_table))
Florin Coras220beac2016-08-16 23:04:00 +020075 {
Filip Tehlarc3af7bf2017-01-13 14:13:09 +010076 dp_table_set = 1;
Florin Coras220beac2016-08-16 23:04:00 +020077 }
Filip Tehlarc3af7bf2017-01-13 14:13:09 +010078 else if (unformat (line_input, "bd %u", &dp_table))
Neale Ranns5e575b12016-10-03 09:40:25 +010079 {
Filip Tehlarc3af7bf2017-01-13 14:13:09 +010080 dp_table_set = 1;
Neale Ranns5e575b12016-10-03 09:40:25 +010081 }
Florin Coras03c4f992016-07-19 15:27:58 +020082 else if (unformat (line_input, "negative action %U",
Florin Coras220beac2016-08-16 23:04:00 +020083 unformat_negative_mapping_action, &action))
84 {
85 is_negative = 1;
86 }
Filip Tehlarc3af7bf2017-01-13 14:13:09 +010087 else if (unformat (line_input, "loc-pair %U %U w %d",
Florin Coras220beac2016-08-16 23:04:00 +020088 unformat_ip_address, &lloc,
Filip Tehlarc3af7bf2017-01-13 14:13:09 +010089 unformat_ip_address, &rloc, &w))
Florin Coras220beac2016-08-16 23:04:00 +020090 {
91 pair.lcl_loc = lloc;
92 pair.rmt_loc = rloc;
Florin Coras220beac2016-08-16 23:04:00 +020093 pair.weight = w;
Florin Coras42e480d2017-01-16 00:57:02 -080094 pair.priority = 0;
Florin Coras220beac2016-08-16 23:04:00 +020095 vec_add1 (pairs, pair);
96 }
Florin Corase127a7e2016-02-18 22:20:01 +010097 else
Florin Coras220beac2016-08-16 23:04:00 +020098 {
99 error = unformat_parse_error (line_input);
Filip Tehlarc3af7bf2017-01-13 14:13:09 +0100100 vlib_cli_output (vm, "parse error: '%U'",
101 format_unformat_error, line_input);
Florin Coras220beac2016-08-16 23:04:00 +0200102 goto done;
103 }
Florin Corase127a7e2016-02-18 22:20:01 +0100104 }
Ed Warnickecb9cada2015-12-08 15:45:58 -0700105
Florin Coras03c4f992016-07-19 15:27:58 +0200106 if (!reid_set)
Florin Corase127a7e2016-02-18 22:20:01 +0100107 {
Filip Tehlarc3af7bf2017-01-13 14:13:09 +0100108 vlib_cli_output (vm, "remote eid must be set!");
Florin Corase127a7e2016-02-18 22:20:01 +0100109 goto done;
110 }
111
Florin Corasb69111e2017-02-13 23:55:27 -0800112 if (gid_address_type (reid) != GID_ADDR_NSH && (!vni_set || !dp_table_set))
113 {
114 vlib_cli_output (vm, "vni and vrf/bd must be set!");
115 goto done;
116 }
117
Florin Coras03c4f992016-07-19 15:27:58 +0200118 if (is_negative)
Florin Corase127a7e2016-02-18 22:20:01 +0100119 {
Florin Coras03c4f992016-07-19 15:27:58 +0200120 if (~0 == action)
Florin Coras220beac2016-08-16 23:04:00 +0200121 {
Filip Tehlarc3af7bf2017-01-13 14:13:09 +0100122 vlib_cli_output (vm, "no action set for negative tunnel!");
Florin Coras220beac2016-08-16 23:04:00 +0200123 goto done;
124 }
Florin Coras03c4f992016-07-19 15:27:58 +0200125 }
126 else
127 {
Florin Corasbb5c22f2016-08-02 02:31:03 +0200128 if (vec_len (pairs) == 0)
Florin Coras220beac2016-08-16 23:04:00 +0200129 {
Filip Tehlarc3af7bf2017-01-13 14:13:09 +0100130 vlib_cli_output (vm, "expected ip4/ip6 locators");
Florin Coras220beac2016-08-16 23:04:00 +0200131 goto done;
132 }
Florin Corase127a7e2016-02-18 22:20:01 +0100133 }
134
Florin Coras03c4f992016-07-19 15:27:58 +0200135 if (!leid_set)
136 {
137 /* if leid not set, make sure it's the same AFI like reid */
Florin Coras220beac2016-08-16 23:04:00 +0200138 gid_address_type (leid) = gid_address_type (reid);
Florin Coras03c4f992016-07-19 15:27:58 +0200139 if (GID_ADDR_IP_PREFIX == gid_address_type (reid))
Florin Coras220beac2016-08-16 23:04:00 +0200140 gid_address_ip_version (leid) = gid_address_ip_version (reid);
Florin Coras03c4f992016-07-19 15:27:58 +0200141 }
142
143 /* add fwd entry */
Florin Coras220beac2016-08-16 23:04:00 +0200144 vnet_lisp_gpe_add_del_fwd_entry_args_t _a, *a = &_a;
145 memset (a, 0, sizeof (a[0]));
Florin Coras03c4f992016-07-19 15:27:58 +0200146
147 a->is_add = is_add;
Florin Coras82bf7cd2016-09-26 18:59:44 +0300148 a->is_negative = is_negative;
Florin Coras03c4f992016-07-19 15:27:58 +0200149 a->vni = vni;
Filip Tehlarc3af7bf2017-01-13 14:13:09 +0100150 a->table_id = dp_table;
Florin Coras220beac2016-08-16 23:04:00 +0200151 gid_address_copy (&a->lcl_eid, leid);
152 gid_address_copy (&a->rmt_eid, reid);
Florin Corasbb5c22f2016-08-02 02:31:03 +0200153 a->locator_pairs = pairs;
Florin Corasce1b4c72017-01-26 14:25:34 -0800154 a->action = action;
Florin Coras03c4f992016-07-19 15:27:58 +0200155
156 rv = vnet_lisp_gpe_add_del_fwd_entry (a, 0);
157 if (0 != rv)
158 {
Filip Tehlarc3af7bf2017-01-13 14:13:09 +0100159 vlib_cli_output (vm, "failed to %s gpe tunnel!",
160 is_add ? "add" : "delete");
Florin Coras03c4f992016-07-19 15:27:58 +0200161 }
162
Florin Coras220beac2016-08-16 23:04:00 +0200163done:
Filip Tehlarc3af7bf2017-01-13 14:13:09 +0100164 unformat_free (line_input);
Florin Coras220beac2016-08-16 23:04:00 +0200165 vec_free (pairs);
Florin Corase127a7e2016-02-18 22:20:01 +0100166 return error;
167}
168
Florin Coras220beac2016-08-16 23:04:00 +0200169/* *INDENT-OFF* */
Florin Corased09a052016-05-06 14:22:40 +0200170VLIB_CLI_COMMAND (lisp_gpe_add_del_fwd_entry_command, static) = {
Filip Tehlar82786c42017-02-20 15:20:37 +0100171 .path = "gpe entry",
172 .short_help = "gpe entry add/del vni <vni> vrf/bd <id> [leid <leid>]"
Filip Tehlarc3af7bf2017-01-13 14:13:09 +0100173 "reid <reid> [loc-pair <lloc> <rloc> w <weight>] "
Florin Corasff0bf132016-09-05 19:30:35 +0200174 "[negative action <action>]",
Florin Corase127a7e2016-02-18 22:20:01 +0100175 .function = lisp_gpe_add_del_fwd_entry_command_fn,
176};
Florin Coras220beac2016-08-16 23:04:00 +0200177/* *INDENT-ON* */
Florin Corase127a7e2016-02-18 22:20:01 +0100178
Florin Corasff0bf132016-09-05 19:30:35 +0200179/** Check if LISP-GPE is enabled. */
Andrej Kozemcaka9edd852016-05-02 12:14:33 +0200180u8
Florin Coras220beac2016-08-16 23:04:00 +0200181vnet_lisp_gpe_enable_disable_status (void)
Andrej Kozemcaka9edd852016-05-02 12:14:33 +0200182{
Florin Coras220beac2016-08-16 23:04:00 +0200183 lisp_gpe_main_t *lgm = &lisp_gpe_main;
Andrej Kozemcaka9edd852016-05-02 12:14:33 +0200184
185 return lgm->is_en;
186}
187
Florin Corasff0bf132016-09-05 19:30:35 +0200188/** Enable/disable LISP-GPE. */
Florin Coras577c3552016-04-21 00:45:40 +0200189clib_error_t *
190vnet_lisp_gpe_enable_disable (vnet_lisp_gpe_enable_disable_args_t * a)
Florin Corase127a7e2016-02-18 22:20:01 +0100191{
Florin Coras220beac2016-08-16 23:04:00 +0200192 lisp_gpe_main_t *lgm = &lisp_gpe_main;
Florin Corase127a7e2016-02-18 22:20:01 +0100193
Florin Coras577c3552016-04-21 00:45:40 +0200194 if (a->is_en)
Florin Corase127a7e2016-02-18 22:20:01 +0100195 {
Andrej Kozemcaka9edd852016-05-02 12:14:33 +0200196 lgm->is_en = 1;
Florin Corase127a7e2016-02-18 22:20:01 +0100197 }
198 else
199 {
Neale Ranns0bfe5d82016-08-25 15:29:12 +0100200 /* remove all entries */
Neale Ranns5e575b12016-10-03 09:40:25 +0100201 vnet_lisp_gpe_fwd_entry_flush ();
Florin Coras577c3552016-04-21 00:45:40 +0200202
Florin Coras1a1adc72016-07-22 01:45:30 +0200203 /* disable all l3 ifaces */
Neale Ranns5e575b12016-10-03 09:40:25 +0100204 lisp_gpe_tenant_flush ();
Florin Coras220beac2016-08-16 23:04:00 +0200205
Andrej Kozemcaka9edd852016-05-02 12:14:33 +0200206 lgm->is_en = 0;
Florin Corase127a7e2016-02-18 22:20:01 +0100207 }
Florin Coras577c3552016-04-21 00:45:40 +0200208
209 return 0;
Florin Corase127a7e2016-02-18 22:20:01 +0100210}
211
Filip Tehlar3e7b56932017-02-21 18:28:34 +0100212/** Set GPE encapsulation mode. */
213int
214vnet_gpe_set_encap_mode (gpe_encap_mode_t mode)
215{
216 lisp_gpe_main_t *lgm = &lisp_gpe_main;
217
218 if (mode >= GPE_ENCAP_COUNT)
219 return VNET_API_ERROR_INVALID_GPE_MODE;
220
221 if (pool_elts (lgm->lisp_fwd_entry_pool) != 0)
222 return VNET_API_ERROR_LISP_GPE_ENTRIES_PRESENT;
223
224 lgm->encap_mode = mode;
225 return 0;
226}
227
228/** CLI command to set GPE encap */
229static clib_error_t *
230gpe_set_encap_mode_command_fn (vlib_main_t * vm,
231 unformat_input_t * input,
232 vlib_cli_command_t * cmd)
233{
234 unformat_input_t _line_input, *line_input = &_line_input;
235 gpe_encap_mode_t mode = GPE_ENCAP_COUNT;
236 vnet_api_error_t rv;
237
238 /* Get a line of input. */
239 if (!unformat_user (input, unformat_line_input, line_input))
240 return 0;
241
242 while (unformat_check_input (line_input) != UNFORMAT_END_OF_INPUT)
243 {
244 if (unformat (line_input, "lisp"))
245 mode = GPE_ENCAP_LISP;
246 else if (unformat (line_input, "vxlan"))
247 mode = GPE_ENCAP_VXLAN;
248 else
249 {
250 return clib_error_return (0, "parse error: '%U'",
251 format_unformat_error, line_input);
252 }
253 }
254 rv = vnet_gpe_set_encap_mode (mode);
255 if (rv)
256 {
257 return clib_error_return (0,
258 "Error: invalid mode or GPE entries are present!");
259 }
260
261 return 0;
262}
263
264/* *INDENT-OFF* */
265VLIB_CLI_COMMAND (gpe_set_encap_mode_command, static) = {
266 .path = "gpe encap",
267 .short_help = "gpe encap [lisp|vxlan]",
268 .function = gpe_set_encap_mode_command_fn,
269};
270/* *INDENT-ON* */
271
272/** Format GPE encap mode. */
273u8 *
274format_vnet_gpe_encap_mode (u8 * s, va_list * args)
275{
276 lisp_gpe_main_t *lgm = &lisp_gpe_main;
277
278 switch (lgm->encap_mode)
279 {
280 case GPE_ENCAP_LISP:
281 return format (s, "lisp");
282 case GPE_ENCAP_VXLAN:
283 return format (s, "vxlan");
284 default:
285 return 0;
286 }
287 return 0;
288}
289
290/** CLI command to show GPE encap */
291static clib_error_t *
292gpe_show_encap_mode_command_fn (vlib_main_t * vm,
293 unformat_input_t * input,
294 vlib_cli_command_t * cmd)
295{
296 vlib_cli_output (vm, "encap mode: %U", format_vnet_gpe_encap_mode);
297 return 0;
298}
299
300/* *INDENT-OFF* */
301VLIB_CLI_COMMAND (gpe_show_encap_mode_command, static) = {
302 .path = "show gpe encap",
303 .short_help = "show GPE encapulation mode",
304 .function = gpe_show_encap_mode_command_fn,
305};
306/* *INDENT-ON* */
307
Florin Corasff0bf132016-09-05 19:30:35 +0200308/** CLI command to enable/disable LISP-GPE. */
Florin Corase127a7e2016-02-18 22:20:01 +0100309static clib_error_t *
Florin Coras220beac2016-08-16 23:04:00 +0200310lisp_gpe_enable_disable_command_fn (vlib_main_t * vm,
311 unformat_input_t * input,
312 vlib_cli_command_t * cmd)
Florin Corase127a7e2016-02-18 22:20:01 +0100313{
Florin Coras220beac2016-08-16 23:04:00 +0200314 unformat_input_t _line_input, *line_input = &_line_input;
Florin Coras577c3552016-04-21 00:45:40 +0200315 u8 is_en = 1;
Florin Coras220beac2016-08-16 23:04:00 +0200316 vnet_lisp_gpe_enable_disable_args_t _a, *a = &_a;
Billy McFalla9a20e72017-02-15 11:39:12 -0500317 clib_error_t *error = NULL;
Florin Corase127a7e2016-02-18 22:20:01 +0100318
319 /* Get a line of input. */
Florin Coras220beac2016-08-16 23:04:00 +0200320 if (!unformat_user (input, unformat_line_input, line_input))
Florin Corase127a7e2016-02-18 22:20:01 +0100321 return 0;
322
323 while (unformat_check_input (line_input) != UNFORMAT_END_OF_INPUT)
324 {
Florin Coras577c3552016-04-21 00:45:40 +0200325 if (unformat (line_input, "enable"))
Florin Coras220beac2016-08-16 23:04:00 +0200326 is_en = 1;
Florin Coras577c3552016-04-21 00:45:40 +0200327 else if (unformat (line_input, "disable"))
Florin Coras220beac2016-08-16 23:04:00 +0200328 is_en = 0;
Florin Corase127a7e2016-02-18 22:20:01 +0100329 else
Florin Coras220beac2016-08-16 23:04:00 +0200330 {
Billy McFalla9a20e72017-02-15 11:39:12 -0500331 error = clib_error_return (0, "parse error: '%U'",
332 format_unformat_error, line_input);
333 goto done;
Florin Coras220beac2016-08-16 23:04:00 +0200334 }
Florin Corase127a7e2016-02-18 22:20:01 +0100335 }
Florin Coras577c3552016-04-21 00:45:40 +0200336 a->is_en = is_en;
Billy McFalla9a20e72017-02-15 11:39:12 -0500337 error = vnet_lisp_gpe_enable_disable (a);
338
339done:
340 unformat_free (line_input);
341
342 return error;
Florin Corase127a7e2016-02-18 22:20:01 +0100343}
344
Florin Coras220beac2016-08-16 23:04:00 +0200345/* *INDENT-OFF* */
Florin Coras577c3552016-04-21 00:45:40 +0200346VLIB_CLI_COMMAND (enable_disable_lisp_gpe_command, static) = {
Filip Tehlar82786c42017-02-20 15:20:37 +0100347 .path = "gpe",
348 .short_help = "gpe [enable|disable]",
Florin Coras577c3552016-04-21 00:45:40 +0200349 .function = lisp_gpe_enable_disable_command_fn,
Florin Corase127a7e2016-02-18 22:20:01 +0100350};
Florin Coras220beac2016-08-16 23:04:00 +0200351/* *INDENT-ON* */
Florin Corase127a7e2016-02-18 22:20:01 +0100352
Florin Corasff0bf132016-09-05 19:30:35 +0200353/** CLI command to show LISP-GPE interfaces. */
Filip Tehlar53f09e32016-05-19 14:25:44 +0200354static clib_error_t *
355lisp_show_iface_command_fn (vlib_main_t * vm,
Florin Coras220beac2016-08-16 23:04:00 +0200356 unformat_input_t * input,
357 vlib_cli_command_t * cmd)
Filip Tehlar53f09e32016-05-19 14:25:44 +0200358{
Florin Coras220beac2016-08-16 23:04:00 +0200359 lisp_gpe_main_t *lgm = &lisp_gpe_main;
360 hash_pair_t *p;
Filip Tehlar53f09e32016-05-19 14:25:44 +0200361
362 vlib_cli_output (vm, "%=10s%=12s", "vrf", "hw_if_index");
Florin Coras220beac2016-08-16 23:04:00 +0200363
364 /* *INDENT-OFF* */
Florin Coras1a1adc72016-07-22 01:45:30 +0200365 hash_foreach_pair (p, lgm->l3_ifaces.hw_if_index_by_dp_table, ({
Filip Tehlar53f09e32016-05-19 14:25:44 +0200366 vlib_cli_output (vm, "%=10d%=10d", p->key, p->value[0]);
367 }));
Florin Coras220beac2016-08-16 23:04:00 +0200368 /* *INDENT-ON* */
Florin Coras1a1adc72016-07-22 01:45:30 +0200369
370 if (0 != lgm->l2_ifaces.hw_if_index_by_dp_table)
371 {
372 vlib_cli_output (vm, "%=10s%=12s", "bd_id", "hw_if_index");
Florin Coras220beac2016-08-16 23:04:00 +0200373 /* *INDENT-OFF* */
Florin Coras1a1adc72016-07-22 01:45:30 +0200374 hash_foreach_pair (p, lgm->l2_ifaces.hw_if_index_by_dp_table, ({
375 vlib_cli_output (vm, "%=10d%=10d", p->key, p->value[0]);
376 }));
Florin Coras220beac2016-08-16 23:04:00 +0200377 /* *INDENT-ON* */
Florin Coras1a1adc72016-07-22 01:45:30 +0200378 }
Filip Tehlar53f09e32016-05-19 14:25:44 +0200379 return 0;
380}
381
Florin Coras220beac2016-08-16 23:04:00 +0200382/* *INDENT-OFF* */
Filip Tehlar53f09e32016-05-19 14:25:44 +0200383VLIB_CLI_COMMAND (lisp_show_iface_command) = {
Filip Tehlar82786c42017-02-20 15:20:37 +0100384 .path = "show gpe interface",
385 .short_help = "show gpe interface",
Filip Tehlar53f09e32016-05-19 14:25:44 +0200386 .function = lisp_show_iface_command_fn,
387};
Florin Coras220beac2016-08-16 23:04:00 +0200388/* *INDENT-ON* */
Florin Coras1a1adc72016-07-22 01:45:30 +0200389
Florin Corasff0bf132016-09-05 19:30:35 +0200390/** Format LISP-GPE status. */
Florin Coras1a1adc72016-07-22 01:45:30 +0200391u8 *
392format_vnet_lisp_gpe_status (u8 * s, va_list * args)
393{
Florin Coras220beac2016-08-16 23:04:00 +0200394 lisp_gpe_main_t *lgm = &lisp_gpe_main;
Florin Coras1a1adc72016-07-22 01:45:30 +0200395 return format (s, "%s", lgm->is_en ? "enabled" : "disabled");
396}
397
Florin Corasff0bf132016-09-05 19:30:35 +0200398/** LISP-GPE init function. */
Florin Corase127a7e2016-02-18 22:20:01 +0100399clib_error_t *
Florin Coras220beac2016-08-16 23:04:00 +0200400lisp_gpe_init (vlib_main_t * vm)
Florin Corase127a7e2016-02-18 22:20:01 +0100401{
Florin Coras220beac2016-08-16 23:04:00 +0200402 lisp_gpe_main_t *lgm = &lisp_gpe_main;
403 clib_error_t *error = 0;
Florin Corase127a7e2016-02-18 22:20:01 +0100404
405 if ((error = vlib_call_init_function (vm, ip_main_init)))
406 return error;
407
408 if ((error = vlib_call_init_function (vm, ip4_lookup_init)))
409 return error;
410
Florin Coras220beac2016-08-16 23:04:00 +0200411 lgm->vnet_main = vnet_get_main ();
Florin Corase127a7e2016-02-18 22:20:01 +0100412 lgm->vlib_main = vm;
413 lgm->im4 = &ip4_main;
Florin Coras02655bd2016-04-26 00:17:24 +0200414 lgm->im6 = &ip6_main;
415 lgm->lm4 = &ip4_main.lookup_main;
416 lgm->lm6 = &ip6_main.lookup_main;
Filip Tehlar3e7b56932017-02-21 18:28:34 +0100417 lgm->encap_mode = GPE_ENCAP_LISP;
Florin Coras577c3552016-04-21 00:45:40 +0200418
Neale Ranns5e575b12016-10-03 09:40:25 +0100419 lgm->lisp_gpe_fwd_entries =
420 hash_create_mem (0, sizeof (lisp_gpe_fwd_entry_key_t), sizeof (uword));
Florin Coras1a1adc72016-07-22 01:45:30 +0200421
Florin Coras220beac2016-08-16 23:04:00 +0200422 udp_register_dst_port (vm, UDP_DST_PORT_lisp_gpe,
423 lisp_gpe_ip4_input_node.index, 1 /* is_ip4 */ );
Florin Coras02655bd2016-04-26 00:17:24 +0200424 udp_register_dst_port (vm, UDP_DST_PORT_lisp_gpe6,
Florin Coras220beac2016-08-16 23:04:00 +0200425 lisp_gpe_ip6_input_node.index, 0 /* is_ip4 */ );
Florin Coras263440e2017-02-22 23:38:08 -0800426
Filip Tehlar4868ff62017-03-09 16:48:39 +0100427 lgm->lisp_stats_index_by_key =
428 hash_create_mem (0, sizeof (lisp_stats_key_t), sizeof (uword));
Filip Tehlar21511912017-04-07 10:41:42 +0200429 memset (&lgm->counters, 0, sizeof (lgm->counters));
430 lgm->counters.name = "LISP counters";
431
Ed Warnickecb9cada2015-12-08 15:45:58 -0700432 return 0;
433}
434
Filip Tehlar3e7b56932017-02-21 18:28:34 +0100435gpe_encap_mode_t
436vnet_gpe_get_encap_mode (void)
437{
438 lisp_gpe_main_t *lgm = &lisp_gpe_main;
439 return lgm->encap_mode;
440}
441
Florin Coras220beac2016-08-16 23:04:00 +0200442VLIB_INIT_FUNCTION (lisp_gpe_init);
443
444/*
445 * fd.io coding-style-patch-verification: ON
446 *
447 * Local Variables:
448 * eval: (c-set-style "gnu")
449 * End:
450 */