blob: 28312d4c85a67d67dd30d1e12b47c7c343c0e5af [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
Ed Warnickecb9cada2015-12-08 15:45:58 -0700234/* Creates a software interface given template. */
Dave Barachba868bb2016-08-08 09:51:21 -0400235clib_error_t *vnet_create_sw_interface (vnet_main_t * vnm,
236 vnet_sw_interface_t * template,
237 u32 * sw_if_index);
Ed Warnickecb9cada2015-12-08 15:45:58 -0700238
239void vnet_delete_hw_interface (vnet_main_t * vnm, u32 hw_if_index);
240void vnet_delete_sw_interface (vnet_main_t * vnm, u32 sw_if_index);
Neale Ranns0bfe5d82016-08-25 15:29:12 +0100241int vnet_sw_interface_is_p2p (vnet_main_t * vnm, u32 sw_if_index);
Neale Ranns5f8f6172019-04-18 10:23:56 +0000242int vnet_sw_interface_is_nbma (vnet_main_t * vnm, u32 sw_if_index);
Ed Warnickecb9cada2015-12-08 15:45:58 -0700243
Neale Ranns1855b8e2018-07-11 10:31:26 -0700244always_inline vnet_sw_interface_flags_t
Ed Warnickecb9cada2015-12-08 15:45:58 -0700245vnet_sw_interface_get_flags (vnet_main_t * vnm, u32 sw_if_index)
246{
Dave Barachba868bb2016-08-08 09:51:21 -0400247 vnet_sw_interface_t *sw = vnet_get_sw_interface (vnm, sw_if_index);
Ed Warnickecb9cada2015-12-08 15:45:58 -0700248 return sw->flags;
249}
250
251always_inline uword
Damjan Mariona35cc142018-03-16 01:25:27 +0100252vnet_sw_interface_is_valid (vnet_main_t * vnm, u32 sw_if_index)
253{
254 return !pool_is_free_index (vnm->interface_main.sw_interfaces, sw_if_index);
255}
256
257always_inline uword
258vnet_hw_interface_is_valid (vnet_main_t * vnm, u32 hw_if_index)
259{
260 return !pool_is_free_index (vnm->interface_main.hw_interfaces, hw_if_index);
261}
262
263
264always_inline uword
Ed Warnickecb9cada2015-12-08 15:45:58 -0700265vnet_sw_interface_is_admin_up (vnet_main_t * vnm, u32 sw_if_index)
Dave Barachba868bb2016-08-08 09:51:21 -0400266{
267 return (vnet_sw_interface_get_flags (vnm, sw_if_index) &
268 VNET_SW_INTERFACE_FLAG_ADMIN_UP) != 0;
269}
Ed Warnickecb9cada2015-12-08 15:45:58 -0700270
271always_inline uword
Eyal Bari3212c572017-03-06 11:47:50 +0200272vnet_swif_is_api_visible (vnet_sw_interface_t * si)
273{
274 return !(si->flags & VNET_SW_INTERFACE_FLAG_HIDDEN);
275}
276
277always_inline uword
278vnet_sw_interface_is_api_visible (vnet_main_t * vnm, u32 sw_if_index)
279{
280 vnet_sw_interface_t *si = vnet_get_sw_interface (vnm, sw_if_index);
281 return vnet_swif_is_api_visible (si);
282}
283
284always_inline uword
285vnet_sw_interface_is_api_valid (vnet_main_t * vnm, u32 sw_if_index)
286{
287 return !pool_is_free_index (vnm->interface_main.sw_interfaces, sw_if_index)
288 && vnet_sw_interface_is_api_visible (vnm, sw_if_index);
289}
290
Neale Ranns93cc3ee2018-10-10 07:22:51 -0700291always_inline const u8 *
292vnet_sw_interface_get_hw_address (vnet_main_t * vnm, u32 sw_if_index)
293{
294 vnet_hw_interface_t *hw = vnet_get_sup_hw_interface (vnm, sw_if_index);
295 return hw->hw_address;
296}
297
Eyal Bari3212c572017-03-06 11:47:50 +0200298always_inline uword
Ed Warnickecb9cada2015-12-08 15:45:58 -0700299vnet_hw_interface_get_flags (vnet_main_t * vnm, u32 hw_if_index)
300{
Dave Barachba868bb2016-08-08 09:51:21 -0400301 vnet_hw_interface_t *hw = vnet_get_hw_interface (vnm, hw_if_index);
Ed Warnickecb9cada2015-12-08 15:45:58 -0700302 return hw->flags;
303}
304
Ole Troand7231612018-06-07 10:17:57 +0200305always_inline u32
306vnet_hw_interface_get_mtu (vnet_main_t * vnm, u32 hw_if_index)
Damjan Marionfe7d4a22018-04-13 19:43:39 +0200307{
308 vnet_hw_interface_t *hw = vnet_get_hw_interface (vnm, hw_if_index);
Ole Troand7231612018-06-07 10:17:57 +0200309 return hw->max_packet_bytes;
Damjan Marionfe7d4a22018-04-13 19:43:39 +0200310}
311
Ole Troand7231612018-06-07 10:17:57 +0200312always_inline u32
313vnet_sw_interface_get_mtu (vnet_main_t * vnm, u32 sw_if_index, vnet_mtu_t af)
Neale Rannsb80c5362016-10-08 13:03:40 +0100314{
Ole Troand7231612018-06-07 10:17:57 +0200315 vnet_sw_interface_t *sw = vnet_get_sw_interface (vnm, sw_if_index);
316 u32 mtu;
317 mtu = sw->mtu[af] > 0 ? sw->mtu[af] : sw->mtu[VNET_MTU_L3];
318 if (mtu == 0)
319 return 9000; /* $$$ Deal with interface-types not setting MTU */
320 return mtu;
Neale Rannsb80c5362016-10-08 13:03:40 +0100321}
322
323always_inline uword
Ed Warnickecb9cada2015-12-08 15:45:58 -0700324vnet_hw_interface_is_link_up (vnet_main_t * vnm, u32 hw_if_index)
Dave Barachba868bb2016-08-08 09:51:21 -0400325{
Neale Ranns3e2e1902019-03-14 09:21:02 -0700326 return ((vnet_hw_interface_get_flags (vnm, hw_if_index) &
327 VNET_HW_INTERFACE_FLAG_LINK_UP) != 0);
328}
329
330always_inline uword
331vnet_sw_interface_is_link_up (vnet_main_t * vnm, u32 sw_if_index)
332{
333 vnet_sw_interface_t *sw = vnet_get_sup_sw_interface (vnm, sw_if_index);
334
335 return (vnet_hw_interface_is_link_up (vnm, sw->hw_if_index));
336}
337
338always_inline uword
339vnet_sw_interface_is_up (vnet_main_t * vnm, u32 sw_if_index)
340{
341 return (vnet_sw_interface_is_admin_up (vnm, sw_if_index) &&
342 vnet_sw_interface_is_link_up (vnm, sw_if_index));
Dave Barachba868bb2016-08-08 09:51:21 -0400343}
Ed Warnickecb9cada2015-12-08 15:45:58 -0700344
Neale Ranns44db1ca2020-12-24 09:16:09 +0000345always_inline uword
346vnet_sw_interface_is_sub (vnet_main_t *vnm, u32 sw_if_index)
347{
348 vnet_sw_interface_t *sw = vnet_get_sw_interface (vnm, sw_if_index);
349
350 return (sw->sw_if_index != sw->sup_sw_if_index);
351}
352
Pim van Pelt76b19ce2021-08-10 23:44:44 +0200353clib_error_t *vnet_sw_interface_supports_addressing (vnet_main_t *vnm,
354 u32 sw_if_index);
355
Ed Warnickecb9cada2015-12-08 15:45:58 -0700356always_inline vlib_frame_t *
357vnet_get_frame_to_sw_interface (vnet_main_t * vnm, u32 sw_if_index)
358{
Dave Barachba868bb2016-08-08 09:51:21 -0400359 vnet_hw_interface_t *hw = vnet_get_sup_hw_interface (vnm, sw_if_index);
Stevenac0932d2018-02-27 14:43:40 -0800360 return vlib_get_frame_to_node (vlib_get_main (), hw->output_node_index);
Ed Warnickecb9cada2015-12-08 15:45:58 -0700361}
362
363always_inline void
Dave Barachba868bb2016-08-08 09:51:21 -0400364vnet_put_frame_to_sw_interface (vnet_main_t * vnm, u32 sw_if_index,
365 vlib_frame_t * f)
Ed Warnickecb9cada2015-12-08 15:45:58 -0700366{
Dave Barachba868bb2016-08-08 09:51:21 -0400367 vnet_hw_interface_t *hw = vnet_get_sup_hw_interface (vnm, sw_if_index);
Stevenac0932d2018-02-27 14:43:40 -0800368 return vlib_put_frame_to_node (vlib_get_main (), hw->output_node_index, f);
Ed Warnickecb9cada2015-12-08 15:45:58 -0700369}
370
Damjan Marion5100aa92018-11-08 15:30:16 +0100371always_inline void
372vnet_hw_interface_set_link_speed (vnet_main_t * vnm, u32 hw_if_index,
373 u32 link_speed)
374{
375 vnet_hw_interface_t *hw = vnet_get_hw_interface (vnm, hw_if_index);
376 hw->link_speed = link_speed;
377}
378
Ed Warnickecb9cada2015-12-08 15:45:58 -0700379/* Change interface flags (e.g. up, down, enable, disable). */
Dave Barachba868bb2016-08-08 09:51:21 -0400380clib_error_t *vnet_hw_interface_set_flags (vnet_main_t * vnm, u32 hw_if_index,
Neale Ranns6e43e062018-10-26 05:17:03 -0700381 vnet_hw_interface_flags_t flags);
Ed Warnickecb9cada2015-12-08 15:45:58 -0700382
383/* Change interface flags (e.g. up, down, enable, disable). */
Dave Barachba868bb2016-08-08 09:51:21 -0400384clib_error_t *vnet_sw_interface_set_flags (vnet_main_t * vnm, u32 sw_if_index,
Neale Ranns6e43e062018-10-26 05:17:03 -0700385 vnet_sw_interface_flags_t flags);
Ed Warnickecb9cada2015-12-08 15:45:58 -0700386
Neale Rannsc87b66c2019-02-07 07:26:12 -0800387void vnet_sw_interface_admin_up (vnet_main_t * vnm, u32 sw_if_index);
388void vnet_sw_interface_admin_down (vnet_main_t * vnm, u32 sw_if_index);
389
Ed Warnickecb9cada2015-12-08 15:45:58 -0700390/* Change interface class. */
Dave Barachba868bb2016-08-08 09:51:21 -0400391clib_error_t *vnet_hw_interface_set_class (vnet_main_t * vnm, u32 hw_if_index,
392 u32 new_hw_class_index);
Ed Warnickecb9cada2015-12-08 15:45:58 -0700393
394/* Redirect rx pkts to node */
395int vnet_hw_interface_rx_redirect_to_node (vnet_main_t * vnm, u32 hw_if_index,
Dave Barachba868bb2016-08-08 09:51:21 -0400396 u32 node_index);
Ed Warnickecb9cada2015-12-08 15:45:58 -0700397
Dave Barachba868bb2016-08-08 09:51:21 -0400398void vnet_hw_interface_init_for_class (vnet_main_t * vnm, u32 hw_if_index,
399 u32 hw_class_index, u32 hw_instance);
Ed Warnickecb9cada2015-12-08 15:45:58 -0700400
Sean Hope608d1ed2016-03-09 00:35:21 -0500401/* Rename interface */
Dave Barachba868bb2016-08-08 09:51:21 -0400402clib_error_t *vnet_rename_interface (vnet_main_t * vnm, u32 hw_if_index,
403 char *new_name);
Sean Hope608d1ed2016-03-09 00:35:21 -0500404
Matthew Smithe0792fd2019-07-12 11:48:24 -0500405/* Add/delete secondary interface mac address*/
406clib_error_t *vnet_hw_interface_add_del_mac_address (vnet_main_t * vnm,
407 u32 hw_if_index,
408 const u8 * mac_address,
409 u8 is_add);
410
Pavel Kotucekc631f2d2016-09-26 10:40:02 +0200411/* Change interface mac address*/
412clib_error_t *vnet_hw_interface_change_mac_address (vnet_main_t * vnm,
413 u32 hw_if_index,
Neale Ranns8f8994a2018-10-30 03:47:20 -0700414 const u8 * mac_address);
Pavel Kotucekc631f2d2016-09-26 10:40:02 +0200415
Stevenad8015b2017-10-29 22:10:46 -0700416/* Change rx-mode */
417clib_error_t *set_hw_interface_change_rx_mode (vnet_main_t * vnm,
418 u32 hw_if_index,
419 u8 queue_id_valid,
420 u32 queue_id,
Damjan Marioneabd4242020-10-07 20:59:07 +0200421 vnet_hw_if_rx_mode mode);
Stevenad8015b2017-10-29 22:10:46 -0700422
Mohsin Kazmi54f7c512018-08-23 18:28:11 +0200423/* Set rx-placement on the interface */
424clib_error_t *set_hw_interface_rx_placement (u32 hw_if_index, u32 queue_id,
425 u32 thread_index, u8 is_main);
426
Damjan Marionfe7d4a22018-04-13 19:43:39 +0200427/* Set the MTU on the HW interface */
428void vnet_hw_interface_set_mtu (vnet_main_t * vnm, u32 hw_if_index, u32 mtu);
Neale Rannsffd78d12018-02-09 06:05:16 -0800429
Ole Troand7231612018-06-07 10:17:57 +0200430/* Set the MTU on the SW interface */
431void vnet_sw_interface_set_mtu (vnet_main_t * vnm, u32 sw_if_index, u32 mtu);
432void vnet_sw_interface_set_protocol_mtu (vnet_main_t * vnm, u32 sw_if_index,
433 u32 mtu[]);
434
Neale Ranns2ae2bc52018-03-16 03:22:39 -0700435/* update the unnumbered state of an interface */
Stanislav Zaikin328b5da2021-07-15 16:27:29 +0200436int vnet_sw_interface_update_unnumbered (u32 sw_if_index, u32 ip_sw_if_index,
437 u8 enable);
Neale Ranns2ae2bc52018-03-16 03:22:39 -0700438
Neale Ranns871dc422018-03-29 01:28:09 -0700439int vnet_sw_interface_stats_collect_enable_disable (u32 sw_if_index,
440 u8 enable);
Neale Ranns1855b8e2018-07-11 10:31:26 -0700441void vnet_sw_interface_ip_directed_broadcast (vnet_main_t * vnm,
442 u32 sw_if_index, u8 enable);
Neale Ranns871dc422018-03-29 01:28:09 -0700443
Chenmin Sunc4665092020-07-06 08:20:39 +0800444/* set interface rss queues */
445clib_error_t *vnet_hw_interface_set_rss_queues (vnet_main_t * vnm,
446 vnet_hw_interface_t * hi,
447 clib_bitmap_t * bitmap);
448
Damjan Marion1bd6cbb2021-04-15 13:12:51 +0200449void vnet_hw_if_update_runtime_data (vnet_main_t *vnm, u32 hw_if_index);
450
Ed Warnickecb9cada2015-12-08 15:45:58 -0700451/* Formats sw/hw interface. */
452format_function_t format_vnet_hw_interface;
Damjan Marioneabd4242020-10-07 20:59:07 +0200453format_function_t format_vnet_hw_if_rx_mode;
Damjan Mariona35cc142018-03-16 01:25:27 +0100454format_function_t format_vnet_hw_if_index_name;
Ed Warnickecb9cada2015-12-08 15:45:58 -0700455format_function_t format_vnet_sw_interface;
456format_function_t format_vnet_sw_interface_name;
Sean Hope679ea792016-02-22 15:12:01 -0500457format_function_t format_vnet_sw_interface_name_override;
Ed Warnickecb9cada2015-12-08 15:45:58 -0700458format_function_t format_vnet_sw_if_index_name;
459format_function_t format_vnet_sw_interface_flags;
460
461/* Parses sw/hw interface name -> index. */
462unformat_function_t unformat_vnet_sw_interface;
463unformat_function_t unformat_vnet_hw_interface;
Dave Barach08eb2bb2020-04-15 09:34:43 -0400464unformat_function_t unformat_vnet_buffer_flags;
Mohsin Kazmi68095382021-02-10 11:26:24 +0100465unformat_function_t unformat_vnet_buffer_offload_flags;
Ed Warnickecb9cada2015-12-08 15:45:58 -0700466
467/* Parses interface flags (up, down, enable, disable, etc.) */
468unformat_function_t unformat_vnet_hw_interface_flags;
469unformat_function_t unformat_vnet_sw_interface_flags;
470
Jon Loeliger9485d992019-11-08 15:05:23 -0600471/* VLAN tag-rewrite */
472format_function_t format_vtr;
473
Ed Warnickecb9cada2015-12-08 15:45:58 -0700474/* Node runtime for interface output function. */
Dave Barachba868bb2016-08-08 09:51:21 -0400475typedef struct
476{
Ed Warnickecb9cada2015-12-08 15:45:58 -0700477 u32 hw_if_index;
478 u32 sw_if_index;
479 u32 dev_instance;
480 u32 is_deleted;
481} vnet_interface_output_runtime_t;
482
Damjan Marion10ae7662017-06-30 19:53:03 +0200483/* Interface output function. */
Dave Barachba868bb2016-08-08 09:51:21 -0400484word vnet_sw_interface_compare (vnet_main_t * vnm, uword sw_if_index0,
485 uword sw_if_index1);
486word vnet_hw_interface_compare (vnet_main_t * vnm, uword hw_if_index0,
487 uword hw_if_index1);
Ed Warnickecb9cada2015-12-08 15:45:58 -0700488
Dave Barachba868bb2016-08-08 09:51:21 -0400489typedef enum
490{
Damjan Marion9c6ae5f2016-11-15 23:20:01 +0100491 VNET_INTERFACE_OUTPUT_NEXT_DROP,
Ed Warnickecb9cada2015-12-08 15:45:58 -0700492 VNET_INTERFACE_OUTPUT_NEXT_TX,
493} vnet_interface_output_next_t;
494
Dave Barachba868bb2016-08-08 09:51:21 -0400495typedef enum
496{
Ed Warnickecb9cada2015-12-08 15:45:58 -0700497 VNET_INTERFACE_TX_NEXT_DROP,
498 VNET_INTERFACE_TX_N_NEXT,
499} vnet_interface_tx_next_t;
500
John Lo405e41b2016-04-23 15:14:12 -0400501#define VNET_SIMULATED_ETHERNET_TX_NEXT_ETHERNET_INPUT VNET_INTERFACE_TX_N_NEXT
Dave Barach635ec3b2018-07-13 20:12:45 -0400502#define VNET_SIMULATED_ETHERNET_TX_NEXT_L2_INPUT (VNET_SIMULATED_ETHERNET_TX_NEXT_ETHERNET_INPUT + 1)
John Lo405e41b2016-04-23 15:14:12 -0400503
Dave Barachba868bb2016-08-08 09:51:21 -0400504typedef enum
505{
Ed Warnickecb9cada2015-12-08 15:45:58 -0700506 VNET_INTERFACE_OUTPUT_ERROR_INTERFACE_DOWN,
507 VNET_INTERFACE_OUTPUT_ERROR_INTERFACE_DELETED,
508} vnet_interface_output_error_t;
509
510/* Format for interface output traces. */
Dave Barachba868bb2016-08-08 09:51:21 -0400511u8 *format_vnet_interface_output_trace (u8 * s, va_list * va);
Ed Warnickecb9cada2015-12-08 15:45:58 -0700512
Dave Barachba868bb2016-08-08 09:51:21 -0400513serialize_function_t serialize_vnet_interface_state,
514 unserialize_vnet_interface_state;
Ed Warnickecb9cada2015-12-08 15:45:58 -0700515
Damjan Marion25ab6c52021-03-05 14:41:25 +0100516/**
517 * @brief Add buffer (vlib_buffer_t) to the trace
518 *
519 * @param *pm - pcap_main_t
520 * @param *vm - vlib_main_t
521 * @param buffer_index - u32
522 * @param n_bytes_in_trace - u32
523 *
524 */
525static inline void
526pcap_add_buffer (pcap_main_t *pm, struct vlib_main_t *vm, u32 buffer_index,
527 u32 n_bytes_in_trace)
528{
529 vlib_buffer_t *b = vlib_get_buffer (vm, buffer_index);
530 u32 n = vlib_buffer_length_in_chain (vm, b);
531 i32 n_left = clib_min (n_bytes_in_trace, n);
532 f64 time_now = vlib_time_now (vm);
533 void *d;
534
535 if (PREDICT_TRUE (pm->n_packets_captured < pm->n_packets_to_capture))
536 {
537 clib_spinlock_lock_if_init (&pm->lock);
538 d = pcap_add_packet (pm, time_now, n_left, n);
539 while (1)
540 {
541 u32 copy_length = clib_min ((u32) n_left, b->current_length);
542 clib_memcpy_fast (d, b->data + b->current_data, copy_length);
543 n_left -= b->current_length;
544 if (n_left <= 0)
545 break;
546 d += b->current_length;
547 ASSERT (b->flags & VLIB_BUFFER_NEXT_PRESENT);
548 b = vlib_get_buffer (vm, b->next_buffer);
549 }
550 clib_spinlock_unlock_if_init (&pm->lock);
551 }
552}
Ed Warnickecb9cada2015-12-08 15:45:58 -0700553#endif /* included_vnet_interface_funcs_h */
Dave Barachba868bb2016-08-08 09:51:21 -0400554
555/*
556 * fd.io coding-style-patch-verification: ON
557 *
558 * Local Variables:
559 * eval: (c-set-style "gnu")
560 * End:
561 */