forked from sdnfv/openNetVM
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathonvm_nflib.h
300 lines (269 loc) · 9.09 KB
/
onvm_nflib.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
/*********************************************************************
* openNetVM
* https://sdnfv.github.io
*
* BSD LICENSE
*
* Copyright(c)
* 2015-2019 George Washington University
* 2015-2019 University of California Riverside
* 2016-2019 Hewlett Packard Enterprise Development LP
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in
* the documentation and/or other materials provided with the
* distribution.
* * The name of the author may not be used to endorse or promote
* products derived from this software without specific prior
* written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
********************************************************************/
/******************************************************************************
onvm_nflib.h
Header file for the API
******************************************************************************/
#ifndef _ONVM_NFLIB_H_
#define _ONVM_NFLIB_H_
#include <rte_mbuf.h>
#include "onvm_common.h"
#include "onvm_pkt_common.h"
#include "onvm_threading.h"
/************************************API**************************************/
/**
* Initialize the starting OpenNetVM NF context.
*
* @return
* Pointer to the created NF context
*/
struct onvm_nf_local_ctx *
onvm_nflib_init_nf_local_ctx(void);
/**
* Initialize an empty NF functional table
*
* @return
* Pointer to the created function table struct
*/
struct onvm_nf_function_table *
onvm_nflib_init_nf_function_table(void);
/**
* Initialize the default OpenNetVM signal handling.
*
* @param nf_local_ctx
* Pointer to a context struct of this NF.
* @param signal_handler
* Function pointer to an optional NF specific signal handler function,
* that will be called after the default onvm signal handler.
* @return
* Error code or 0 if succesfull
*/
int
onvm_nflib_start_signal_handler(struct onvm_nf_local_ctx *nf_local_ctx, handle_signal_func signal_hanlder);
/**
* Initialize the OpenNetVM container Library.
* This will setup the DPDK EAL as a secondary process, and notify the host
* that there is a new NF.
*
* @argc
* The argc argument that was given to the main() function.
* @argv
* The argv argument that was given to the main() function
* @param tag
* A uniquely identifiable string for this NF.
* For example, can be the application name (e.g. "bridge_nf")
* @param nf_local_ctx
* Pointer to a context struct of this NF.
* @param nf_function_table
* Pointer to a function table struct for this NF
* @return
* On success, the number of parsed arguments, which is greater or equal to
* zero. After the call to onvm_nf_init(), all arguments argv[x] with x < ret
* may be modified and should not be accessed by the application.,
* On error, a negative value.
*/
int
onvm_nflib_init(int argc, char *argv[], const char *nf_tag, struct onvm_nf_local_ctx *nf_local_ctx,
struct onvm_nf_function_table *nf_function_table);
/**
* Runs the OpenNetVM container library.
*
* @param nf_local_ctx
* Pointer to a context struct of this NF.
* @return
* 0 on success, or a negative value on error.
*/
int
onvm_nflib_run(struct onvm_nf_local_ctx *nf_local_ctx);
/**
* Return a packet that was created by the NF or has previously had the
* ONVM_NF_ACTION_BUFFER action called on it.
*
* @param nf
* Pointer to a struct containing information about this NF.
* @param pkt
* a pointer to a packet that should now have a action other than buffer.
* @return
* 0 on success, or a negative value on error.
*/
int
onvm_nflib_return_pkt(struct onvm_nf *nf, struct rte_mbuf *pkt);
/**
* Return a group of packets that were created by the NF or have previously had the
* ONVM_NF_ACTION_BUFFER action called on it.
*
* @param pkts
* a pointer to a buffer of packets that should now have an action other than buffer.
* @param count
* the number of packets contained within the buffer.
* @return
* 0 on success, or a negative value on error (-1 if bad arguments, -ENOBUFS if enqueue fails).
*/
int
onvm_nflib_return_pkt_bulk(struct onvm_nf *nf, struct rte_mbuf **pkts, uint16_t count);
/**
* Inform the manager that the NF is ready to receive packets.
* This only needs to be called when the NF is using advanced rings
* Otherwise, onvm_nflib_run will call this
*
* @param nf
* Pointer to a struct containing information about this NF.
* @return
* 0 on success, or a negative value on failure
*/
int
onvm_nflib_nf_ready(struct onvm_nf *nf);
/*
* Start the NF by signaling manager that its ready to recieve packets
*
* Input: Pointer to context struct of this NF
*/
int
onvm_nflib_start_nf(struct onvm_nf_local_ctx *nf_local_ctx, struct onvm_nf_init_cfg *nf_init_cfg);
/**
* Process an message. Does stuff.
*
* @param msg
* a pointer to a message to be processed
* @param nf_local_ctx
* Pointer to a context struct of this NF.
* @return
* 0 on success, or a negative value on error
*/
int
onvm_nflib_handle_msg(struct onvm_nf_msg *msg, struct onvm_nf_local_ctx *nf_local_ctx);
int
onvm_nflib_send_msg_to_nf(uint16_t dest_nf, void *msg_data);
/**
* Stop this NF and clean up its memory
* Sends shutdown message to manager.
*
* @param nf_local_ctx
* Pointer to a context struct of this NF.
*/
void
onvm_nflib_stop(struct onvm_nf_local_ctx *nf_local_ctx);
/**
* Function that initialize the NF init config data structure.
*
* Input : the tag to name the NF
* Output : the data structure initialized
*
*/
struct onvm_nf_init_cfg *
onvm_nflib_init_nf_init_cfg(const char *tag);
/*
* Function that initialize the NF init config data structure.
* the arguments are copied from the parent information
*
* Input : pointer to the parent NF
* Output : the data structure initialized
*
*/
struct onvm_nf_init_cfg *
onvm_nflib_inherit_parent_init_cfg(struct onvm_nf *parent);
/**
* Allocates an empty scaling config to be filled in by the NF.
* Defines the instance_id to NF_NO_ID..
*
* @param nf
* An onvm_nf struct describing this NF.
* @return
* Pointer to onvm_nf_scale_info structure for running onvm_nflib_scale
*/
struct onvm_nf_scale_info *
onvm_nflib_get_empty_scaling_config(struct onvm_nf *nf);
/**
* Fill the onvm_nflib_scale_info with the infromation of the parent, inherits
* service id, pkt functions(setup, pkt_handler, callback, advanced rings).
*
* @param nf
* An onvm_nf struct describing this NF.
* @param data
* Void data pointer for the scale_info.
* @return
* Pointer to onvm_nf_scale_info structure which can be used to run onvm_nflib_scale
*/
struct onvm_nf_scale_info *
onvm_nflib_inherit_parent_config(struct onvm_nf *nf, void *data);
/*
* Scales the NF. Determines the core to scale to, and starts a new thread for the NF.
*
* @param scale_info
* A scale info struct describing the child NF to be launched
* @return
* Error code or 0 if successful.
*/
int
onvm_nflib_scale(struct onvm_nf_scale_info *scale_info);
/**
* Request LPM memory region. Returns the success or failure of this initialization.
*
* @param lpm_request
* An LPM request struct to initialize the LPM region
* @return
* Request response status
*/
int
onvm_nflib_request_lpm(struct lpm_request *req);
/*
* Initializes a flow_tables hashmap. Returns the status code, representing the success or failure of the initialization
*
* @param rte_hash_parameters
* A hash_params struct containing the properly initialized properties of the hashmap
* @return
* Status of the intitialization
*/
int
onvm_nflib_request_ft(struct rte_hash_parameters *ipv4_hash_params);
struct onvm_service_chain *
onvm_nflib_get_default_chain(void);
/**
* Retrieves custom onvm flags
*/
struct onvm_configuration *
onvm_nflib_get_onvm_config(void);
/**
* Prints a summary of NF activity
* @param NF instance id
*/
void
onvm_nflib_stats_summary_output(uint16_t id);
#endif // _ONVM_NFLIB_H_