FD.io VPP
v20.01-48-g3e0dafb74
Vector Packet Processing
nsim.h
Go to the documentation of this file.
1
2
/*
3
* nsim.h - skeleton vpp engine plug-in header file
4
*
5
* Copyright (c) <current-year> <your-organization>
6
* Licensed under the Apache License, Version 2.0 (the "License");
7
* you may not use this file except in compliance with the License.
8
* You may obtain a copy of the License at:
9
*
10
* http://www.apache.org/licenses/LICENSE-2.0
11
*
12
* Unless required by applicable law or agreed to in writing, software
13
* distributed under the License is distributed on an "AS IS" BASIS,
14
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
* See the License for the specific language governing permissions and
16
* limitations under the License.
17
*/
18
#ifndef __included_nsim_h__
19
#define __included_nsim_h__
20
21
#include <
vnet/vnet.h
>
22
#include <
vnet/ip/ip.h
>
23
#include <
vnet/ethernet/ethernet.h
>
24
25
#include <
vppinfra/hash.h
>
26
#include <
vppinfra/error.h
>
27
28
typedef
struct
29
{
30
f64
tx_time
;
31
u32
rx_sw_if_index
;
32
u32
tx_sw_if_index
;
33
u32
output_next_index
;
34
u32
buffer_index
;
35
u32
pad
;
/* pad to 32-bytes */
36
}
nsim_wheel_entry_t
;
37
38
typedef
struct
39
{
40
u32
wheel_size
;
41
u32
cursize
;
42
u32
head
;
43
u32
tail
;
44
nsim_wheel_entry_t
*
entries
;
45
CLIB_CACHE_LINE_ALIGN_MARK
(
pad
);
46
}
nsim_wheel_t
;
47
48
typedef
struct
49
{
50
/* API message ID base */
51
u16
msg_id_base
;
52
53
/* Two interfaces, cross-connected with delay */
54
u32
sw_if_index0,
sw_if_index1
;
55
u32
output_next_index0,
output_next_index1
;
56
57
/* N interfaces, using the output feature */
58
u32
*
output_next_index_by_sw_if_index
;
59
60
/* Random seed for loss-rate simulation */
61
u32
seed
;
62
63
/* Per-thread scheduler wheels */
64
nsim_wheel_t
**
wheel_by_thread
;
65
66
/* Config parameters */
67
f64
delay
;
68
f64
bandwidth
;
69
f64
packet_size
;
70
f64
drop_fraction
;
71
u32
poll_main_thread
;
72
73
u64
mmap_size
;
74
75
/* Wheels are configured */
76
int
is_configured
;
77
78
/* convenience */
79
vlib_main_t
*
vlib_main
;
80
vnet_main_t
*
vnet_main
;
81
}
nsim_main_t
;
82
83
extern
nsim_main_t
nsim_main
;
84
85
extern
vlib_node_registration_t
nsim_node
;
86
extern
vlib_node_registration_t
nsim_input_node
;
87
88
#endif
/* __included_nsim_h__ */
89
90
/*
91
* fd.io coding-style-patch-verification: ON
92
*
93
* Local Variables:
94
* eval: (c-set-style "gnu")
95
* End:
96
*/
nsim_main_t::output_next_index_by_sw_if_index
u32 * output_next_index_by_sw_if_index
Definition:
nsim.h:58
nsim_main_t::packet_size
f64 packet_size
Definition:
nsim.h:69
pad
u8 pad[3]
log2 (size of the packing page block)
Definition:
bihash_doc.h:61
CLIB_CACHE_LINE_ALIGN_MARK
#define CLIB_CACHE_LINE_ALIGN_MARK(mark)
Definition:
cache.h:60
nsim_main_t::msg_id_base
u16 msg_id_base
Definition:
nsim.h:51
u64
unsigned long u64
Definition:
types.h:89
nsim_wheel_entry_t
Definition:
nsim.h:28
nsim_wheel_entry_t::pad
u32 pad
Definition:
nsim.h:35
ip.h
hash.h
f64
double f64
Definition:
types.h:142
nsim_wheel_t::cursize
u32 cursize
Definition:
nsim.h:41
nsim_wheel_entry_t::tx_sw_if_index
u32 tx_sw_if_index
Definition:
nsim.h:32
nsim_main_t::vnet_main
vnet_main_t * vnet_main
Definition:
nsim.h:80
nsim_main_t::is_configured
int is_configured
Definition:
nsim.h:76
nsim_wheel_t
Definition:
nsim.h:38
u32
unsigned int u32
Definition:
types.h:88
nsim_node
vlib_node_registration_t nsim_node
(constructor) VLIB_REGISTER_NODE (nsim_node)
Definition:
node.c:51
ethernet.h
nsim_main_t::mmap_size
u64 mmap_size
Definition:
nsim.h:73
u16
unsigned short u16
Definition:
types.h:57
nsim_wheel_t::tail
u32 tail
Definition:
nsim.h:43
vnet.h
nsim_main_t::sw_if_index1
u32 sw_if_index1
Definition:
nsim.h:54
nsim_input_node
vlib_node_registration_t nsim_input_node
(constructor) VLIB_REGISTER_NODE (nsim_input_node)
Definition:
nsim_input.c:168
nsim_wheel_t::entries
nsim_wheel_entry_t * entries
Definition:
nsim.h:44
nsim_wheel_t::head
u32 head
Definition:
nsim.h:42
nsim_main_t::vlib_main
vlib_main_t * vlib_main
Definition:
nsim.h:79
vnet_main_t
Definition:
vnet.h:51
nsim_main_t
Definition:
nsim.h:48
nsim_main_t::wheel_by_thread
nsim_wheel_t ** wheel_by_thread
Definition:
nsim.h:64
nsim_main_t::poll_main_thread
u32 poll_main_thread
Definition:
nsim.h:71
vlib_node_registration_t
struct _vlib_node_registration vlib_node_registration_t
nsim_main_t::seed
u32 seed
Definition:
nsim.h:61
nsim_main_t::bandwidth
f64 bandwidth
Definition:
nsim.h:68
nsim_wheel_entry_t::tx_time
f64 tx_time
Definition:
nsim.h:30
nsim_wheel_entry_t::buffer_index
u32 buffer_index
Definition:
nsim.h:34
vlib_main_t
Definition:
main.h:83
nsim_main
nsim_main_t nsim_main
Definition:
nsim.c:39
error.h
nsim_main_t::delay
f64 delay
Definition:
nsim.h:67
nsim_wheel_entry_t::output_next_index
u32 output_next_index
Definition:
nsim.h:33
nsim_main_t::drop_fraction
f64 drop_fraction
Definition:
nsim.h:70
nsim_wheel_t::wheel_size
u32 wheel_size
Definition:
nsim.h:40
nsim_main_t::output_next_index1
u32 output_next_index1
Definition:
nsim.h:55
nsim_wheel_entry_t::rx_sw_if_index
u32 rx_sw_if_index
Definition:
nsim.h:31
src
plugins
nsim
nsim.h
Generated on Wed Sep 9 2020 00:04:03 for FD.io VPP by
1.8.13