blob: 565dcd5be99c03e3e2a124210adbf852fc83731c [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
Ed Warnickecb9cada2015-12-08 15:45:58 -0700353always_inline vlib_frame_t *
354vnet_get_frame_to_sw_interface (vnet_main_t * vnm, u32 sw_if_index)
355{
Dave Barachba868bb2016-08-08 09:51:21 -0400356 vnet_hw_interface_t *hw = vnet_get_sup_hw_interface (vnm, sw_if_index);
Stevenac0932d2018-02-27 14:43:40 -0800357 return vlib_get_frame_to_node (vlib_get_main (), hw->output_node_index);
Ed Warnickecb9cada2015-12-08 15:45:58 -0700358}
359
360always_inline void
Dave Barachba868bb2016-08-08 09:51:21 -0400361vnet_put_frame_to_sw_interface (vnet_main_t * vnm, u32 sw_if_index,
362 vlib_frame_t * f)
Ed Warnickecb9cada2015-12-08 15:45:58 -0700363{
Dave Barachba868bb2016-08-08 09:51:21 -0400364 vnet_hw_interface_t *hw = vnet_get_sup_hw_interface (vnm, sw_if_index);
Stevenac0932d2018-02-27 14:43:40 -0800365 return vlib_put_frame_to_node (vlib_get_main (), hw->output_node_index, f);
Ed Warnickecb9cada2015-12-08 15:45:58 -0700366}
367
Damjan Marion5100aa92018-11-08 15:30:16 +0100368always_inline void
369vnet_hw_interface_set_link_speed (vnet_main_t * vnm, u32 hw_if_index,
370 u32 link_speed)
371{
372 vnet_hw_interface_t *hw = vnet_get_hw_interface (vnm, hw_if_index);
373 hw->link_speed = link_speed;
374}
375
Ed Warnickecb9cada2015-12-08 15:45:58 -0700376/* Change interface flags (e.g. up, down, enable, disable). */
Dave Barachba868bb2016-08-08 09:51:21 -0400377clib_error_t *vnet_hw_interface_set_flags (vnet_main_t * vnm, u32 hw_if_index,
Neale Ranns6e43e062018-10-26 05:17:03 -0700378 vnet_hw_interface_flags_t flags);
Ed Warnickecb9cada2015-12-08 15:45:58 -0700379
380/* Change interface flags (e.g. up, down, enable, disable). */
Dave Barachba868bb2016-08-08 09:51:21 -0400381clib_error_t *vnet_sw_interface_set_flags (vnet_main_t * vnm, u32 sw_if_index,
Neale Ranns6e43e062018-10-26 05:17:03 -0700382 vnet_sw_interface_flags_t flags);
Ed Warnickecb9cada2015-12-08 15:45:58 -0700383
Neale Rannsc87b66c2019-02-07 07:26:12 -0800384void vnet_sw_interface_admin_up (vnet_main_t * vnm, u32 sw_if_index);
385void vnet_sw_interface_admin_down (vnet_main_t * vnm, u32 sw_if_index);
386
Ed Warnickecb9cada2015-12-08 15:45:58 -0700387/* Change interface class. */
Dave Barachba868bb2016-08-08 09:51:21 -0400388clib_error_t *vnet_hw_interface_set_class (vnet_main_t * vnm, u32 hw_if_index,
389 u32 new_hw_class_index);
Ed Warnickecb9cada2015-12-08 15:45:58 -0700390
391/* Redirect rx pkts to node */
392int vnet_hw_interface_rx_redirect_to_node (vnet_main_t * vnm, u32 hw_if_index,
Dave Barachba868bb2016-08-08 09:51:21 -0400393 u32 node_index);
Ed Warnickecb9cada2015-12-08 15:45:58 -0700394
Dave Barachba868bb2016-08-08 09:51:21 -0400395void vnet_hw_interface_init_for_class (vnet_main_t * vnm, u32 hw_if_index,
396 u32 hw_class_index, u32 hw_instance);
Ed Warnickecb9cada2015-12-08 15:45:58 -0700397
Sean Hope608d1ed2016-03-09 00:35:21 -0500398/* Rename interface */
Dave Barachba868bb2016-08-08 09:51:21 -0400399clib_error_t *vnet_rename_interface (vnet_main_t * vnm, u32 hw_if_index,
400 char *new_name);
Sean Hope608d1ed2016-03-09 00:35:21 -0500401
Matthew Smithe0792fd2019-07-12 11:48:24 -0500402/* Add/delete secondary interface mac address*/
403clib_error_t *vnet_hw_interface_add_del_mac_address (vnet_main_t * vnm,
404 u32 hw_if_index,
405 const u8 * mac_address,
406 u8 is_add);
407
Pavel Kotucekc631f2d2016-09-26 10:40:02 +0200408/* Change interface mac address*/
409clib_error_t *vnet_hw_interface_change_mac_address (vnet_main_t * vnm,
410 u32 hw_if_index,
Neale Ranns8f8994a2018-10-30 03:47:20 -0700411 const u8 * mac_address);
Pavel Kotucekc631f2d2016-09-26 10:40:02 +0200412
Stevenad8015b2017-10-29 22:10:46 -0700413/* Change rx-mode */
414clib_error_t *set_hw_interface_change_rx_mode (vnet_main_t * vnm,
415 u32 hw_if_index,
416 u8 queue_id_valid,
417 u32 queue_id,
Damjan Marioneabd4242020-10-07 20:59:07 +0200418 vnet_hw_if_rx_mode mode);
Stevenad8015b2017-10-29 22:10:46 -0700419
Mohsin Kazmi54f7c512018-08-23 18:28:11 +0200420/* Set rx-placement on the interface */
421clib_error_t *set_hw_interface_rx_placement (u32 hw_if_index, u32 queue_id,
422 u32 thread_index, u8 is_main);
423
Damjan Marionfe7d4a22018-04-13 19:43:39 +0200424/* Set the MTU on the HW interface */
425void vnet_hw_interface_set_mtu (vnet_main_t * vnm, u32 hw_if_index, u32 mtu);
Neale Rannsffd78d12018-02-09 06:05:16 -0800426
Ole Troand7231612018-06-07 10:17:57 +0200427/* Set the MTU on the SW interface */
428void vnet_sw_interface_set_mtu (vnet_main_t * vnm, u32 sw_if_index, u32 mtu);
429void vnet_sw_interface_set_protocol_mtu (vnet_main_t * vnm, u32 sw_if_index,
430 u32 mtu[]);
431
Neale Ranns2ae2bc52018-03-16 03:22:39 -0700432/* update the unnumbered state of an interface */
433void vnet_sw_interface_update_unnumbered (u32 sw_if_index,
434 u32 ip_sw_if_index, u8 enable);
435
Neale Ranns871dc422018-03-29 01:28:09 -0700436int vnet_sw_interface_stats_collect_enable_disable (u32 sw_if_index,
437 u8 enable);
Neale Ranns1855b8e2018-07-11 10:31:26 -0700438void vnet_sw_interface_ip_directed_broadcast (vnet_main_t * vnm,
439 u32 sw_if_index, u8 enable);
Neale Ranns871dc422018-03-29 01:28:09 -0700440
Chenmin Sunc4665092020-07-06 08:20:39 +0800441/* set interface rss queues */
442clib_error_t *vnet_hw_interface_set_rss_queues (vnet_main_t * vnm,
443 vnet_hw_interface_t * hi,
444 clib_bitmap_t * bitmap);
445
Ed Warnickecb9cada2015-12-08 15:45:58 -0700446/* Formats sw/hw interface. */
447format_function_t format_vnet_hw_interface;
Damjan Marioneabd4242020-10-07 20:59:07 +0200448format_function_t format_vnet_hw_if_rx_mode;
Damjan Mariona35cc142018-03-16 01:25:27 +0100449format_function_t format_vnet_hw_if_index_name;
Ed Warnickecb9cada2015-12-08 15:45:58 -0700450format_function_t format_vnet_sw_interface;
451format_function_t format_vnet_sw_interface_name;
Sean Hope679ea792016-02-22 15:12:01 -0500452format_function_t format_vnet_sw_interface_name_override;
Ed Warnickecb9cada2015-12-08 15:45:58 -0700453format_function_t format_vnet_sw_if_index_name;
454format_function_t format_vnet_sw_interface_flags;
455
456/* Parses sw/hw interface name -> index. */
457unformat_function_t unformat_vnet_sw_interface;
458unformat_function_t unformat_vnet_hw_interface;
Dave Barach08eb2bb2020-04-15 09:34:43 -0400459unformat_function_t unformat_vnet_buffer_flags;
Mohsin Kazmi68095382021-02-10 11:26:24 +0100460unformat_function_t unformat_vnet_buffer_offload_flags;
Ed Warnickecb9cada2015-12-08 15:45:58 -0700461
462/* Parses interface flags (up, down, enable, disable, etc.) */
463unformat_function_t unformat_vnet_hw_interface_flags;
464unformat_function_t unformat_vnet_sw_interface_flags;
465
Jon Loeliger9485d992019-11-08 15:05:23 -0600466/* VLAN tag-rewrite */
467format_function_t format_vtr;
468
Ed Warnickecb9cada2015-12-08 15:45:58 -0700469/* Node runtime for interface output function. */
Dave Barachba868bb2016-08-08 09:51:21 -0400470typedef struct
471{
Ed Warnickecb9cada2015-12-08 15:45:58 -0700472 u32 hw_if_index;
473 u32 sw_if_index;
474 u32 dev_instance;
475 u32 is_deleted;
476} vnet_interface_output_runtime_t;
477
Damjan Marion10ae7662017-06-30 19:53:03 +0200478/* Interface output function. */
Dave Barachba868bb2016-08-08 09:51:21 -0400479word vnet_sw_interface_compare (vnet_main_t * vnm, uword sw_if_index0,
480 uword sw_if_index1);
481word vnet_hw_interface_compare (vnet_main_t * vnm, uword hw_if_index0,
482 uword hw_if_index1);
Ed Warnickecb9cada2015-12-08 15:45:58 -0700483
Dave Barachba868bb2016-08-08 09:51:21 -0400484typedef enum
485{
Damjan Marion9c6ae5f2016-11-15 23:20:01 +0100486 VNET_INTERFACE_OUTPUT_NEXT_DROP,
Ed Warnickecb9cada2015-12-08 15:45:58 -0700487 VNET_INTERFACE_OUTPUT_NEXT_TX,
488} vnet_interface_output_next_t;
489
Dave Barachba868bb2016-08-08 09:51:21 -0400490typedef enum
491{
Ed Warnickecb9cada2015-12-08 15:45:58 -0700492 VNET_INTERFACE_TX_NEXT_DROP,
493 VNET_INTERFACE_TX_N_NEXT,
494} vnet_interface_tx_next_t;
495
John Lo405e41b2016-04-23 15:14:12 -0400496#define VNET_SIMULATED_ETHERNET_TX_NEXT_ETHERNET_INPUT VNET_INTERFACE_TX_N_NEXT
Dave Barach635ec3b2018-07-13 20:12:45 -0400497#define VNET_SIMULATED_ETHERNET_TX_NEXT_L2_INPUT (VNET_SIMULATED_ETHERNET_TX_NEXT_ETHERNET_INPUT + 1)
John Lo405e41b2016-04-23 15:14:12 -0400498
Dave Barachba868bb2016-08-08 09:51:21 -0400499typedef enum
500{
Ed Warnickecb9cada2015-12-08 15:45:58 -0700501 VNET_INTERFACE_OUTPUT_ERROR_INTERFACE_DOWN,
502 VNET_INTERFACE_OUTPUT_ERROR_INTERFACE_DELETED,
Andrew Yourtchenko6a7cff72018-10-12 16:09:22 +0200503 VNET_INTERFACE_OUTPUT_ERROR_NO_BUFFERS_FOR_GSO,
504 VNET_INTERFACE_OUTPUT_ERROR_UNHANDLED_GSO_TYPE,
Ed Warnickecb9cada2015-12-08 15:45:58 -0700505} vnet_interface_output_error_t;
506
507/* Format for interface output traces. */
Dave Barachba868bb2016-08-08 09:51:21 -0400508u8 *format_vnet_interface_output_trace (u8 * s, va_list * va);
Ed Warnickecb9cada2015-12-08 15:45:58 -0700509
Dave Barachba868bb2016-08-08 09:51:21 -0400510serialize_function_t serialize_vnet_interface_state,
511 unserialize_vnet_interface_state;
Ed Warnickecb9cada2015-12-08 15:45:58 -0700512
Damjan Marion25ab6c52021-03-05 14:41:25 +0100513/**
514 * @brief Add buffer (vlib_buffer_t) to the trace
515 *
516 * @param *pm - pcap_main_t
517 * @param *vm - vlib_main_t
518 * @param buffer_index - u32
519 * @param n_bytes_in_trace - u32
520 *
521 */
522static inline void
523pcap_add_buffer (pcap_main_t *pm, struct vlib_main_t *vm, u32 buffer_index,
524 u32 n_bytes_in_trace)
525{
526 vlib_buffer_t *b = vlib_get_buffer (vm, buffer_index);
527 u32 n = vlib_buffer_length_in_chain (vm, b);
528 i32 n_left = clib_min (n_bytes_in_trace, n);
529 f64 time_now = vlib_time_now (vm);
530 void *d;
531
532 if (PREDICT_TRUE (pm->n_packets_captured < pm->n_packets_to_capture))
533 {
534 clib_spinlock_lock_if_init (&pm->lock);
535 d = pcap_add_packet (pm, time_now, n_left, n);
536 while (1)
537 {
538 u32 copy_length = clib_min ((u32) n_left, b->current_length);
539 clib_memcpy_fast (d, b->data + b->current_data, copy_length);
540 n_left -= b->current_length;
541 if (n_left <= 0)
542 break;
543 d += b->current_length;
544 ASSERT (b->flags & VLIB_BUFFER_NEXT_PRESENT);
545 b = vlib_get_buffer (vm, b->next_buffer);
546 }
547 clib_spinlock_unlock_if_init (&pm->lock);
548 }
549}
Ed Warnickecb9cada2015-12-08 15:45:58 -0700550#endif /* included_vnet_interface_funcs_h */
Dave Barachba868bb2016-08-08 09:51:21 -0400551
552/*
553 * fd.io coding-style-patch-verification: ON
554 *
555 * Local Variables:
556 * eval: (c-set-style "gnu")
557 * End:
558 */