blob: f253b23f8194839852279b840d8275c07941b847 [file] [log] [blame]
Ed Warnickecb9cada2015-12-08 15:45:58 -07001/*
2 * Copyright (c) 2015 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 * interface_funcs.h: VNET interfaces/sub-interfaces exported functions
17 *
18 * Copyright (c) 2008 Eliot Dresselhaus
19 *
20 * Permission is hereby granted, free of charge, to any person obtaining
21 * a copy of this software and associated documentation files (the
22 * "Software"), to deal in the Software without restriction, including
23 * without limitation the rights to use, copy, modify, merge, publish,
24 * distribute, sublicense, and/or sell copies of the Software, and to
25 * permit persons to whom the Software is furnished to do so, subject to
26 * the following conditions:
27 *
28 * The above copyright notice and this permission notice shall be
29 * included in all copies or substantial portions of the Software.
30 *
31 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
32 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
33 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
34 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
35 * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
36 * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
37 * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
38 */
39
40#ifndef included_vnet_interface_funcs_h
41#define included_vnet_interface_funcs_h
42
43always_inline vnet_hw_interface_t *
44vnet_get_hw_interface (vnet_main_t * vnm, u32 hw_if_index)
Dave Barachba868bb2016-08-08 09:51:21 -040045{
46 return pool_elt_at_index (vnm->interface_main.hw_interfaces, hw_if_index);
47}
Ed Warnickecb9cada2015-12-08 15:45:58 -070048
Damjan Mariona35cc142018-03-16 01:25:27 +010049always_inline vnet_hw_interface_t *
Dave Barach3940de32019-07-23 16:28:36 -040050vnet_get_hw_interface_or_null (vnet_main_t * vnm, u32 hw_if_index)
Damjan Mariona35cc142018-03-16 01:25:27 +010051{
52 if (!pool_is_free_index (vnm->interface_main.hw_interfaces, hw_if_index))
53 return pool_elt_at_index (vnm->interface_main.hw_interfaces, hw_if_index);
54 return (NULL);
55}
56
Ed Warnickecb9cada2015-12-08 15:45:58 -070057always_inline vnet_sw_interface_t *
58vnet_get_sw_interface (vnet_main_t * vnm, u32 sw_if_index)
Dave Barachba868bb2016-08-08 09:51:21 -040059{
60 return pool_elt_at_index (vnm->interface_main.sw_interfaces, sw_if_index);
61}
Ed Warnickecb9cada2015-12-08 15:45:58 -070062
63always_inline vnet_sw_interface_t *
Dave Barach3940de32019-07-23 16:28:36 -040064vnet_get_sw_interface_or_null (vnet_main_t * vnm, u32 sw_if_index)
Neale Ranns75152282017-01-09 01:00:45 -080065{
66 if (!pool_is_free_index (vnm->interface_main.sw_interfaces, sw_if_index))
67 return pool_elt_at_index (vnm->interface_main.sw_interfaces, sw_if_index);
68 return (NULL);
69}
70
71always_inline vnet_sw_interface_t *
Ed Warnickecb9cada2015-12-08 15:45:58 -070072vnet_get_hw_sw_interface (vnet_main_t * vnm, u32 hw_if_index)
73{
Dave Barachba868bb2016-08-08 09:51:21 -040074 vnet_hw_interface_t *hw = vnet_get_hw_interface (vnm, hw_if_index);
75 vnet_sw_interface_t *sw = vnet_get_sw_interface (vnm, hw->sw_if_index);
Ed Warnickecb9cada2015-12-08 15:45:58 -070076 ASSERT (sw->type == VNET_SW_INTERFACE_TYPE_HARDWARE);
77 return sw;
78}
79
80always_inline vnet_sw_interface_t *
81vnet_get_sup_sw_interface (vnet_main_t * vnm, u32 sw_if_index)
82{
Dave Barachba868bb2016-08-08 09:51:21 -040083 vnet_sw_interface_t *sw = vnet_get_sw_interface (vnm, sw_if_index);
Pavel Kotucek15ac81c2017-06-20 14:00:26 +020084 if (sw->type == VNET_SW_INTERFACE_TYPE_SUB ||
Neale Ranns17ff3c12018-07-04 10:24:24 -070085 sw->type == VNET_SW_INTERFACE_TYPE_PIPE ||
Pavel Kotucek15ac81c2017-06-20 14:00:26 +020086 sw->type == VNET_SW_INTERFACE_TYPE_P2P)
Ed Warnickecb9cada2015-12-08 15:45:58 -070087 sw = vnet_get_sw_interface (vnm, sw->sup_sw_if_index);
88 return sw;
89}
90
91always_inline vnet_hw_interface_t *
92vnet_get_sup_hw_interface (vnet_main_t * vnm, u32 sw_if_index)
93{
Dave Barachba868bb2016-08-08 09:51:21 -040094 vnet_sw_interface_t *sw = vnet_get_sup_sw_interface (vnm, sw_if_index);
Neale Ranns17ff3c12018-07-04 10:24:24 -070095 ASSERT ((sw->type == VNET_SW_INTERFACE_TYPE_HARDWARE) ||
96 (sw->type == VNET_SW_INTERFACE_TYPE_PIPE));
Ed Warnickecb9cada2015-12-08 15:45:58 -070097 return vnet_get_hw_interface (vnm, sw->hw_if_index);
98}
99
Dave Barach3940de32019-07-23 16:28:36 -0400100always_inline vnet_hw_interface_t *
101vnet_get_sup_hw_interface_api_visible_or_null (vnet_main_t * vnm,
102 u32 sw_if_index)
103{
104 vnet_sw_interface_t *si;
105 if (PREDICT_FALSE (pool_is_free_index (vnm->interface_main.sw_interfaces,
106 sw_if_index)))
107 return NULL;
108 si = vnet_get_sup_sw_interface (vnm, sw_if_index);
109 if (PREDICT_FALSE (si->flags & VNET_SW_INTERFACE_FLAG_HIDDEN))
110 return NULL;
111 ASSERT ((si->type == VNET_SW_INTERFACE_TYPE_HARDWARE) ||
112 (si->type == VNET_SW_INTERFACE_TYPE_PIPE));
113 return vnet_get_hw_interface (vnm, si->hw_if_index);
114}
115
Ed Warnickecb9cada2015-12-08 15:45:58 -0700116always_inline vnet_hw_interface_class_t *
117vnet_get_hw_interface_class (vnet_main_t * vnm, u32 hw_class_index)
Dave Barachba868bb2016-08-08 09:51:21 -0400118{
119 return vec_elt_at_index (vnm->interface_main.hw_interface_classes,
120 hw_class_index);
121}
Ed Warnickecb9cada2015-12-08 15:45:58 -0700122
123always_inline vnet_device_class_t *
124vnet_get_device_class (vnet_main_t * vnm, u32 dev_class_index)
Dave Barachba868bb2016-08-08 09:51:21 -0400125{
126 return vec_elt_at_index (vnm->interface_main.device_classes,
127 dev_class_index);
128}
Ed Warnickecb9cada2015-12-08 15:45:58 -0700129
Dave Barach7be864a2016-11-28 11:41:35 -0500130static inline u8 *
131vnet_get_sw_interface_tag (vnet_main_t * vnm, u32 sw_if_index)
132{
133 uword *p;
134 p = hash_get (vnm->interface_tag_by_sw_if_index, sw_if_index);
135 if (p)
136 return ((u8 *) p[0]);
137 return 0;
138}
139
140static inline void
141vnet_set_sw_interface_tag (vnet_main_t * vnm, u8 * tag, u32 sw_if_index)
142{
143 uword *p;
144 p = hash_get (vnm->interface_tag_by_sw_if_index, sw_if_index);
145 if (p)
146 {
147 u8 *oldtag = (u8 *) p[0];
148 hash_unset (vnm->interface_tag_by_sw_if_index, sw_if_index);
149 vec_free (oldtag);
150 }
151
152 hash_set (vnm->interface_tag_by_sw_if_index, sw_if_index, tag);
153}
154
155static inline void
156vnet_clear_sw_interface_tag (vnet_main_t * vnm, u32 sw_if_index)
157{
158 uword *p;
159 p = hash_get (vnm->interface_tag_by_sw_if_index, sw_if_index);
160 if (p)
161 {
162 u8 *oldtag = (u8 *) p[0];
163 hash_unset (vnm->interface_tag_by_sw_if_index, sw_if_index);
164 vec_free (oldtag);
165 }
166}
167
Neale Ranns8b37b872016-11-21 12:25:22 +0000168/**
Neale Ranns0053de62018-05-22 08:40:52 -0700169 * Walk return code
170 */
171typedef enum walk_rc_t_
172{
173 WALK_STOP,
174 WALK_CONTINUE,
175} walk_rc_t;
176
177/**
Neale Ranns8b37b872016-11-21 12:25:22 +0000178 * Call back walk type for walking SW indices on a HW interface
179 */
Neale Ranns0053de62018-05-22 08:40:52 -0700180typedef walk_rc_t (*vnet_hw_sw_interface_walk_t) (vnet_main_t * vnm,
181 u32 sw_if_index, void *ctx);
Neale Ranns8b37b872016-11-21 12:25:22 +0000182
183/**
184 * @brief
185 * Walk the SW interfaces on a HW interface - this is the super
186 * interface and any sub-interfaces.
187 */
188void vnet_hw_interface_walk_sw (vnet_main_t * vnm,
189 u32 hw_if_index,
190 vnet_hw_sw_interface_walk_t fn, void *ctx);
191
Neale Ranns0053de62018-05-22 08:40:52 -0700192/**
193 * Call back walk type for walking SW indices on a HW interface
194 */
195typedef walk_rc_t (*vnet_sw_interface_walk_t) (vnet_main_t * vnm,
196 vnet_sw_interface_t * si,
197 void *ctx);
198
199/**
200 * @brief
201 * Walk all the SW interfaces in the system.
202 */
203void vnet_sw_interface_walk (vnet_main_t * vnm,
204 vnet_sw_interface_walk_t fn, void *ctx);
205
Neale Ranns17ff3c12018-07-04 10:24:24 -0700206
207/**
208 * Call back walk type for walking all HW indices
209 */
210typedef walk_rc_t (*vnet_hw_interface_walk_t) (vnet_main_t * vnm,
211 u32 hw_if_index, void *ctx);
212
213/**
214 * @brief
215 * Walk all the HW interface
216 */
217void vnet_hw_interface_walk (vnet_main_t * vnm,
218 vnet_hw_interface_walk_t fn, void *ctx);
219
Ed Warnickecb9cada2015-12-08 15:45:58 -0700220/* Register a hardware interface instance. */
221u32 vnet_register_interface (vnet_main_t * vnm,
222 u32 dev_class_index,
223 u32 dev_instance,
Dave Barachba868bb2016-08-08 09:51:21 -0400224 u32 hw_class_index, u32 hw_instance);
Ed Warnickecb9cada2015-12-08 15:45:58 -0700225
John Loe5453d02018-01-23 19:21:34 -0500226/**
227 * Set interface output node - for interface registered without its output/tx
228 * nodes created because its VNET_DEVICE_CLASS did not specify any tx_function.
229 * This is typically the case for tunnel interfaces.
230 */
231void vnet_set_interface_output_node (vnet_main_t * vnm,
232 u32 hw_if_index, u32 node_index);
233
Neale Ranns6fdcc3d2021-10-08 07:30:47 +0000234void vnet_set_interface_l3_output_node (vlib_main_t *vm, u32 sw_if_index,
235 u8 *output_node);
236void vnet_reset_interface_l3_output_node (vlib_main_t *vm, u32 sw_if_index);
237
Ed Warnickecb9cada2015-12-08 15:45:58 -0700238/* Creates a software interface given template. */
Dave Barachba868bb2016-08-08 09:51:21 -0400239clib_error_t *vnet_create_sw_interface (vnet_main_t * vnm,
240 vnet_sw_interface_t * template,
241 u32 * sw_if_index);
Ed Warnickecb9cada2015-12-08 15:45:58 -0700242
243void vnet_delete_hw_interface (vnet_main_t * vnm, u32 hw_if_index);
244void vnet_delete_sw_interface (vnet_main_t * vnm, u32 sw_if_index);
Neale Ranns0bfe5d82016-08-25 15:29:12 +0100245int vnet_sw_interface_is_p2p (vnet_main_t * vnm, u32 sw_if_index);
Neale Ranns5f8f6172019-04-18 10:23:56 +0000246int vnet_sw_interface_is_nbma (vnet_main_t * vnm, u32 sw_if_index);
Ed Warnickecb9cada2015-12-08 15:45:58 -0700247
Neale Ranns1855b8e2018-07-11 10:31:26 -0700248always_inline vnet_sw_interface_flags_t
Ed Warnickecb9cada2015-12-08 15:45:58 -0700249vnet_sw_interface_get_flags (vnet_main_t * vnm, u32 sw_if_index)
250{
Dave Barachba868bb2016-08-08 09:51:21 -0400251 vnet_sw_interface_t *sw = vnet_get_sw_interface (vnm, sw_if_index);
Ed Warnickecb9cada2015-12-08 15:45:58 -0700252 return sw->flags;
253}
254
255always_inline uword
Damjan Mariona35cc142018-03-16 01:25:27 +0100256vnet_sw_interface_is_valid (vnet_main_t * vnm, u32 sw_if_index)
257{
258 return !pool_is_free_index (vnm->interface_main.sw_interfaces, sw_if_index);
259}
260
261always_inline uword
262vnet_hw_interface_is_valid (vnet_main_t * vnm, u32 hw_if_index)
263{
264 return !pool_is_free_index (vnm->interface_main.hw_interfaces, hw_if_index);
265}
266
267
268always_inline uword
Ed Warnickecb9cada2015-12-08 15:45:58 -0700269vnet_sw_interface_is_admin_up (vnet_main_t * vnm, u32 sw_if_index)
Dave Barachba868bb2016-08-08 09:51:21 -0400270{
271 return (vnet_sw_interface_get_flags (vnm, sw_if_index) &
272 VNET_SW_INTERFACE_FLAG_ADMIN_UP) != 0;
273}
Ed Warnickecb9cada2015-12-08 15:45:58 -0700274
275always_inline uword
Eyal Bari3212c572017-03-06 11:47:50 +0200276vnet_swif_is_api_visible (vnet_sw_interface_t * si)
277{
278 return !(si->flags & VNET_SW_INTERFACE_FLAG_HIDDEN);
279}
280
281always_inline uword
282vnet_sw_interface_is_api_visible (vnet_main_t * vnm, u32 sw_if_index)
283{
284 vnet_sw_interface_t *si = vnet_get_sw_interface (vnm, sw_if_index);
285 return vnet_swif_is_api_visible (si);
286}
287
288always_inline uword
289vnet_sw_interface_is_api_valid (vnet_main_t * vnm, u32 sw_if_index)
290{
291 return !pool_is_free_index (vnm->interface_main.sw_interfaces, sw_if_index)
292 && vnet_sw_interface_is_api_visible (vnm, sw_if_index);
293}
294
Neale Ranns93cc3ee2018-10-10 07:22:51 -0700295always_inline const u8 *
296vnet_sw_interface_get_hw_address (vnet_main_t * vnm, u32 sw_if_index)
297{
298 vnet_hw_interface_t *hw = vnet_get_sup_hw_interface (vnm, sw_if_index);
299 return hw->hw_address;
300}
301
Eyal Bari3212c572017-03-06 11:47:50 +0200302always_inline uword
Ed Warnickecb9cada2015-12-08 15:45:58 -0700303vnet_hw_interface_get_flags (vnet_main_t * vnm, u32 hw_if_index)
304{
Dave Barachba868bb2016-08-08 09:51:21 -0400305 vnet_hw_interface_t *hw = vnet_get_hw_interface (vnm, hw_if_index);
Ed Warnickecb9cada2015-12-08 15:45:58 -0700306 return hw->flags;
307}
308
Ole Troand7231612018-06-07 10:17:57 +0200309always_inline u32
310vnet_hw_interface_get_mtu (vnet_main_t * vnm, u32 hw_if_index)
Damjan Marionfe7d4a22018-04-13 19:43:39 +0200311{
312 vnet_hw_interface_t *hw = vnet_get_hw_interface (vnm, hw_if_index);
Ole Troand7231612018-06-07 10:17:57 +0200313 return hw->max_packet_bytes;
Damjan Marionfe7d4a22018-04-13 19:43:39 +0200314}
315
Ole Troand7231612018-06-07 10:17:57 +0200316always_inline u32
317vnet_sw_interface_get_mtu (vnet_main_t * vnm, u32 sw_if_index, vnet_mtu_t af)
Neale Rannsb80c5362016-10-08 13:03:40 +0100318{
Ole Troand7231612018-06-07 10:17:57 +0200319 vnet_sw_interface_t *sw = vnet_get_sw_interface (vnm, sw_if_index);
320 u32 mtu;
321 mtu = sw->mtu[af] > 0 ? sw->mtu[af] : sw->mtu[VNET_MTU_L3];
322 if (mtu == 0)
323 return 9000; /* $$$ Deal with interface-types not setting MTU */
324 return mtu;
Neale Rannsb80c5362016-10-08 13:03:40 +0100325}
326
327always_inline uword
Ed Warnickecb9cada2015-12-08 15:45:58 -0700328vnet_hw_interface_is_link_up (vnet_main_t * vnm, u32 hw_if_index)
Dave Barachba868bb2016-08-08 09:51:21 -0400329{
Neale Ranns3e2e1902019-03-14 09:21:02 -0700330 return ((vnet_hw_interface_get_flags (vnm, hw_if_index) &
331 VNET_HW_INTERFACE_FLAG_LINK_UP) != 0);
332}
333
334always_inline uword
335vnet_sw_interface_is_link_up (vnet_main_t * vnm, u32 sw_if_index)
336{
337 vnet_sw_interface_t *sw = vnet_get_sup_sw_interface (vnm, sw_if_index);
338
339 return (vnet_hw_interface_is_link_up (vnm, sw->hw_if_index));
340}
341
342always_inline uword
343vnet_sw_interface_is_up (vnet_main_t * vnm, u32 sw_if_index)
344{
345 return (vnet_sw_interface_is_admin_up (vnm, sw_if_index) &&
346 vnet_sw_interface_is_link_up (vnm, sw_if_index));
Dave Barachba868bb2016-08-08 09:51:21 -0400347}
Ed Warnickecb9cada2015-12-08 15:45:58 -0700348
Neale Ranns44db1ca2020-12-24 09:16:09 +0000349always_inline uword
350vnet_sw_interface_is_sub (vnet_main_t *vnm, u32 sw_if_index)
351{
352 vnet_sw_interface_t *sw = vnet_get_sw_interface (vnm, sw_if_index);
353
354 return (sw->sw_if_index != sw->sup_sw_if_index);
355}
356
Pim van Pelt76b19ce2021-08-10 23:44:44 +0200357clib_error_t *vnet_sw_interface_supports_addressing (vnet_main_t *vnm,
358 u32 sw_if_index);
359
Ed Warnickecb9cada2015-12-08 15:45:58 -0700360always_inline vlib_frame_t *
361vnet_get_frame_to_sw_interface (vnet_main_t * vnm, u32 sw_if_index)
362{
Dave Barachba868bb2016-08-08 09:51:21 -0400363 vnet_hw_interface_t *hw = vnet_get_sup_hw_interface (vnm, sw_if_index);
Stevenac0932d2018-02-27 14:43:40 -0800364 return vlib_get_frame_to_node (vlib_get_main (), hw->output_node_index);
Ed Warnickecb9cada2015-12-08 15:45:58 -0700365}
366
367always_inline void
Dave Barachba868bb2016-08-08 09:51:21 -0400368vnet_put_frame_to_sw_interface (vnet_main_t * vnm, u32 sw_if_index,
369 vlib_frame_t * f)
Ed Warnickecb9cada2015-12-08 15:45:58 -0700370{
Dave Barachba868bb2016-08-08 09:51:21 -0400371 vnet_hw_interface_t *hw = vnet_get_sup_hw_interface (vnm, sw_if_index);
Stevenac0932d2018-02-27 14:43:40 -0800372 return vlib_put_frame_to_node (vlib_get_main (), hw->output_node_index, f);
Ed Warnickecb9cada2015-12-08 15:45:58 -0700373}
374
Damjan Marion5100aa92018-11-08 15:30:16 +0100375always_inline void
376vnet_hw_interface_set_link_speed (vnet_main_t * vnm, u32 hw_if_index,
377 u32 link_speed)
378{
379 vnet_hw_interface_t *hw = vnet_get_hw_interface (vnm, hw_if_index);
380 hw->link_speed = link_speed;
381}
382
Ed Warnickecb9cada2015-12-08 15:45:58 -0700383/* Change interface flags (e.g. up, down, enable, disable). */
Dave Barachba868bb2016-08-08 09:51:21 -0400384clib_error_t *vnet_hw_interface_set_flags (vnet_main_t * vnm, u32 hw_if_index,
Neale Ranns6e43e062018-10-26 05:17:03 -0700385 vnet_hw_interface_flags_t flags);
Ed Warnickecb9cada2015-12-08 15:45:58 -0700386
387/* Change interface flags (e.g. up, down, enable, disable). */
Dave Barachba868bb2016-08-08 09:51:21 -0400388clib_error_t *vnet_sw_interface_set_flags (vnet_main_t * vnm, u32 sw_if_index,
Neale Ranns6e43e062018-10-26 05:17:03 -0700389 vnet_sw_interface_flags_t flags);
Ed Warnickecb9cada2015-12-08 15:45:58 -0700390
Neale Rannsc87b66c2019-02-07 07:26:12 -0800391void vnet_sw_interface_admin_up (vnet_main_t * vnm, u32 sw_if_index);
392void vnet_sw_interface_admin_down (vnet_main_t * vnm, u32 sw_if_index);
393
Ed Warnickecb9cada2015-12-08 15:45:58 -0700394/* Change interface class. */
Dave Barachba868bb2016-08-08 09:51:21 -0400395clib_error_t *vnet_hw_interface_set_class (vnet_main_t * vnm, u32 hw_if_index,
396 u32 new_hw_class_index);
Ed Warnickecb9cada2015-12-08 15:45:58 -0700397
398/* Redirect rx pkts to node */
399int vnet_hw_interface_rx_redirect_to_node (vnet_main_t * vnm, u32 hw_if_index,
Dave Barachba868bb2016-08-08 09:51:21 -0400400 u32 node_index);
Ed Warnickecb9cada2015-12-08 15:45:58 -0700401
Dave Barachba868bb2016-08-08 09:51:21 -0400402void vnet_hw_interface_init_for_class (vnet_main_t * vnm, u32 hw_if_index,
403 u32 hw_class_index, u32 hw_instance);
Ed Warnickecb9cada2015-12-08 15:45:58 -0700404
Sean Hope608d1ed2016-03-09 00:35:21 -0500405/* Rename interface */
Dave Barachba868bb2016-08-08 09:51:21 -0400406clib_error_t *vnet_rename_interface (vnet_main_t * vnm, u32 hw_if_index,
407 char *new_name);
Sean Hope608d1ed2016-03-09 00:35:21 -0500408
Matthew Smithe0792fd2019-07-12 11:48:24 -0500409/* Add/delete secondary interface mac address*/
410clib_error_t *vnet_hw_interface_add_del_mac_address (vnet_main_t * vnm,
411 u32 hw_if_index,
412 const u8 * mac_address,
413 u8 is_add);
414
Pavel Kotucekc631f2d2016-09-26 10:40:02 +0200415/* Change interface mac address*/
416clib_error_t *vnet_hw_interface_change_mac_address (vnet_main_t * vnm,
417 u32 hw_if_index,
Neale Ranns8f8994a2018-10-30 03:47:20 -0700418 const u8 * mac_address);
Pavel Kotucekc631f2d2016-09-26 10:40:02 +0200419
Stevenad8015b2017-10-29 22:10:46 -0700420/* Change rx-mode */
421clib_error_t *set_hw_interface_change_rx_mode (vnet_main_t * vnm,
422 u32 hw_if_index,
423 u8 queue_id_valid,
424 u32 queue_id,
Damjan Marioneabd4242020-10-07 20:59:07 +0200425 vnet_hw_if_rx_mode mode);
Stevenad8015b2017-10-29 22:10:46 -0700426
Mohsin Kazmi54f7c512018-08-23 18:28:11 +0200427/* Set rx-placement on the interface */
428clib_error_t *set_hw_interface_rx_placement (u32 hw_if_index, u32 queue_id,
429 u32 thread_index, u8 is_main);
430
Damjan Marionfe7d4a22018-04-13 19:43:39 +0200431/* Set the MTU on the HW interface */
432void vnet_hw_interface_set_mtu (vnet_main_t * vnm, u32 hw_if_index, u32 mtu);
Neale Rannsffd78d12018-02-09 06:05:16 -0800433
Ole Troand7231612018-06-07 10:17:57 +0200434/* Set the MTU on the SW interface */
435void vnet_sw_interface_set_mtu (vnet_main_t * vnm, u32 sw_if_index, u32 mtu);
436void vnet_sw_interface_set_protocol_mtu (vnet_main_t * vnm, u32 sw_if_index,
437 u32 mtu[]);
438
Neale Ranns2ae2bc52018-03-16 03:22:39 -0700439/* update the unnumbered state of an interface */
Stanislav Zaikin328b5da2021-07-15 16:27:29 +0200440int vnet_sw_interface_update_unnumbered (u32 sw_if_index, u32 ip_sw_if_index,
441 u8 enable);
Neale Ranns2ae2bc52018-03-16 03:22:39 -0700442
Neale Ranns871dc422018-03-29 01:28:09 -0700443int vnet_sw_interface_stats_collect_enable_disable (u32 sw_if_index,
444 u8 enable);
Neale Ranns1855b8e2018-07-11 10:31:26 -0700445void vnet_sw_interface_ip_directed_broadcast (vnet_main_t * vnm,
446 u32 sw_if_index, u8 enable);
Neale Ranns871dc422018-03-29 01:28:09 -0700447
Chenmin Sunc4665092020-07-06 08:20:39 +0800448/* set interface rss queues */
449clib_error_t *vnet_hw_interface_set_rss_queues (vnet_main_t * vnm,
450 vnet_hw_interface_t * hi,
451 clib_bitmap_t * bitmap);
452
Damjan Marion1bd6cbb2021-04-15 13:12:51 +0200453void vnet_hw_if_update_runtime_data (vnet_main_t *vnm, u32 hw_if_index);
454
Ed Warnickecb9cada2015-12-08 15:45:58 -0700455/* Formats sw/hw interface. */
456format_function_t format_vnet_hw_interface;
Damjan Marioneabd4242020-10-07 20:59:07 +0200457format_function_t format_vnet_hw_if_rx_mode;
Damjan Mariona35cc142018-03-16 01:25:27 +0100458format_function_t format_vnet_hw_if_index_name;
Ed Warnickecb9cada2015-12-08 15:45:58 -0700459format_function_t format_vnet_sw_interface;
460format_function_t format_vnet_sw_interface_name;
Sean Hope679ea792016-02-22 15:12:01 -0500461format_function_t format_vnet_sw_interface_name_override;
Ed Warnickecb9cada2015-12-08 15:45:58 -0700462format_function_t format_vnet_sw_if_index_name;
463format_function_t format_vnet_sw_interface_flags;
464
465/* Parses sw/hw interface name -> index. */
466unformat_function_t unformat_vnet_sw_interface;
467unformat_function_t unformat_vnet_hw_interface;
Dave Barach08eb2bb2020-04-15 09:34:43 -0400468unformat_function_t unformat_vnet_buffer_flags;
Mohsin Kazmi68095382021-02-10 11:26:24 +0100469unformat_function_t unformat_vnet_buffer_offload_flags;
Ed Warnickecb9cada2015-12-08 15:45:58 -0700470
471/* Parses interface flags (up, down, enable, disable, etc.) */
472unformat_function_t unformat_vnet_hw_interface_flags;
473unformat_function_t unformat_vnet_sw_interface_flags;
474
Jon Loeliger9485d992019-11-08 15:05:23 -0600475/* VLAN tag-rewrite */
476format_function_t format_vtr;
477
Ed Warnickecb9cada2015-12-08 15:45:58 -0700478/* Node runtime for interface output function. */
Dave Barachba868bb2016-08-08 09:51:21 -0400479typedef struct
480{
Ed Warnickecb9cada2015-12-08 15:45:58 -0700481 u32 hw_if_index;
482 u32 sw_if_index;
483 u32 dev_instance;
484 u32 is_deleted;
485} vnet_interface_output_runtime_t;
486
Damjan Marion10ae7662017-06-30 19:53:03 +0200487/* Interface output function. */
Dave Barachba868bb2016-08-08 09:51:21 -0400488word vnet_sw_interface_compare (vnet_main_t * vnm, uword sw_if_index0,
489 uword sw_if_index1);
490word vnet_hw_interface_compare (vnet_main_t * vnm, uword hw_if_index0,
491 uword hw_if_index1);
Ed Warnickecb9cada2015-12-08 15:45:58 -0700492
Dave Barachba868bb2016-08-08 09:51:21 -0400493typedef enum
494{
Damjan Marion9c6ae5f2016-11-15 23:20:01 +0100495 VNET_INTERFACE_OUTPUT_NEXT_DROP,
Ed Warnickecb9cada2015-12-08 15:45:58 -0700496 VNET_INTERFACE_OUTPUT_NEXT_TX,
497} vnet_interface_output_next_t;
498
Dave Barachba868bb2016-08-08 09:51:21 -0400499typedef enum
500{
Ed Warnickecb9cada2015-12-08 15:45:58 -0700501 VNET_INTERFACE_TX_NEXT_DROP,
502 VNET_INTERFACE_TX_N_NEXT,
503} vnet_interface_tx_next_t;
504
John Lo405e41b2016-04-23 15:14:12 -0400505#define VNET_SIMULATED_ETHERNET_TX_NEXT_ETHERNET_INPUT VNET_INTERFACE_TX_N_NEXT
Dave Barach635ec3b2018-07-13 20:12:45 -0400506#define VNET_SIMULATED_ETHERNET_TX_NEXT_L2_INPUT (VNET_SIMULATED_ETHERNET_TX_NEXT_ETHERNET_INPUT + 1)
John Lo405e41b2016-04-23 15:14:12 -0400507
Dave Barachba868bb2016-08-08 09:51:21 -0400508typedef enum
509{
Ed Warnickecb9cada2015-12-08 15:45:58 -0700510 VNET_INTERFACE_OUTPUT_ERROR_INTERFACE_DOWN,
511 VNET_INTERFACE_OUTPUT_ERROR_INTERFACE_DELETED,
512} vnet_interface_output_error_t;
513
514/* Format for interface output traces. */
Dave Barachba868bb2016-08-08 09:51:21 -0400515u8 *format_vnet_interface_output_trace (u8 * s, va_list * va);
Ed Warnickecb9cada2015-12-08 15:45:58 -0700516
Dave Barachba868bb2016-08-08 09:51:21 -0400517serialize_function_t serialize_vnet_interface_state,
518 unserialize_vnet_interface_state;
Ed Warnickecb9cada2015-12-08 15:45:58 -0700519
Damjan Marion25ab6c52021-03-05 14:41:25 +0100520/**
521 * @brief Add buffer (vlib_buffer_t) to the trace
522 *
523 * @param *pm - pcap_main_t
524 * @param *vm - vlib_main_t
525 * @param buffer_index - u32
526 * @param n_bytes_in_trace - u32
527 *
528 */
529static inline void
530pcap_add_buffer (pcap_main_t *pm, struct vlib_main_t *vm, u32 buffer_index,
531 u32 n_bytes_in_trace)
532{
533 vlib_buffer_t *b = vlib_get_buffer (vm, buffer_index);
534 u32 n = vlib_buffer_length_in_chain (vm, b);
535 i32 n_left = clib_min (n_bytes_in_trace, n);
536 f64 time_now = vlib_time_now (vm);
537 void *d;
538
539 if (PREDICT_TRUE (pm->n_packets_captured < pm->n_packets_to_capture))
540 {
541 clib_spinlock_lock_if_init (&pm->lock);
542 d = pcap_add_packet (pm, time_now, n_left, n);
543 while (1)
544 {
545 u32 copy_length = clib_min ((u32) n_left, b->current_length);
546 clib_memcpy_fast (d, b->data + b->current_data, copy_length);
547 n_left -= b->current_length;
548 if (n_left <= 0)
549 break;
550 d += b->current_length;
551 ASSERT (b->flags & VLIB_BUFFER_NEXT_PRESENT);
552 b = vlib_get_buffer (vm, b->next_buffer);
553 }
554 clib_spinlock_unlock_if_init (&pm->lock);
555 }
556}
Ed Warnickecb9cada2015-12-08 15:45:58 -0700557#endif /* included_vnet_interface_funcs_h */
Dave Barachba868bb2016-08-08 09:51:21 -0400558
559/*
560 * fd.io coding-style-patch-verification: ON
561 *
562 * Local Variables:
563 * eval: (c-set-style "gnu")
564 * End:
565 */