blob: c752e50413b24f80be4934764a05378f990dac12 [file] [log] [blame]
Dave Wallace543852a2017-08-03 02:11:34 -04001/*
2 * Copyright (c) 2017 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#ifndef included_vppcom_h
17#define included_vppcom_h
18
19#include <netdb.h>
20#include <errno.h>
Dave Wallace048b1d62018-01-03 22:24:41 -050021#include <sys/poll.h>
Dave Wallacef7f809c2017-10-03 01:48:42 -040022#include <sys/epoll.h>
Dave Wallace543852a2017-08-03 02:11:34 -040023
Keith Burns (alagalah)5a2946c2018-02-02 08:21:56 -080024/* *INDENT-OFF* */
25#ifdef __cplusplus
26extern "C"
27{
28#endif
29/* *INDENT-ON* */
30
Dave Wallace543852a2017-08-03 02:11:34 -040031/*
32 * VPPCOM Public API Definitions, Enums, and Data Structures
33 */
Dave Wallace774169b2017-11-01 20:07:40 -040034#define INVALID_SESSION_ID (~0)
Dave Wallace774169b2017-11-01 20:07:40 -040035#define VPPCOM_CONF_DEFAULT "/etc/vpp/vcl.conf"
36#define VPPCOM_ENV_CONF "VCL_CONFIG"
Dave Wallace498b3a52017-11-09 13:00:34 -050037#define VPPCOM_ENV_DEBUG "VCL_DEBUG"
Dave Wallaceb5a86ee2018-02-16 18:26:11 -050038#define VPPCOM_ENV_API_PREFIX "VCL_API_PREFIX"
Dave Wallace774169b2017-11-01 20:07:40 -040039#define VPPCOM_ENV_APP_PROXY_TRANSPORT_TCP "VCL_APP_PROXY_TRANSPORT_TCP"
40#define VPPCOM_ENV_APP_PROXY_TRANSPORT_UDP "VCL_APP_PROXY_TRANSPORT_UDP"
41#define VPPCOM_ENV_APP_NAMESPACE_ID "VCL_APP_NAMESPACE_ID"
42#define VPPCOM_ENV_APP_NAMESPACE_SECRET "VCL_APP_NAMESPACE_SECRET"
43#define VPPCOM_ENV_APP_SCOPE_LOCAL "VCL_APP_SCOPE_LOCAL"
44#define VPPCOM_ENV_APP_SCOPE_GLOBAL "VCL_APP_SCOPE_GLOBAL"
Dave Wallace543852a2017-08-03 02:11:34 -040045
46typedef enum
47{
48 VPPCOM_PROTO_TCP = 0,
49 VPPCOM_PROTO_UDP,
50} vppcom_proto_t;
51
Dave Wallace048b1d62018-01-03 22:24:41 -050052static inline char *
53vppcom_proto_str (vppcom_proto_t proto)
54{
55 char *proto_str;
56
57 switch (proto)
58 {
59 case VPPCOM_PROTO_TCP:
60 proto_str = "VPPCOM_PROTO_TCP";
61 break;
62 case VPPCOM_PROTO_UDP:
63 proto_str = "VPPCOM_PROTO_UDP";
64 break;
65 default:
66 proto_str = "UNKNOWN";
67 break;
68 }
69 return proto_str;
70}
71
Dave Wallace543852a2017-08-03 02:11:34 -040072typedef enum
73{
74 VPPCOM_IS_IP6 = 0,
75 VPPCOM_IS_IP4,
76} vppcom_is_ip4_t;
77
78typedef struct vppcom_endpt_t_
79{
Dave Wallace543852a2017-08-03 02:11:34 -040080 uint8_t is_cut_thru;
81 uint8_t is_ip4;
82 uint8_t *ip;
83 uint16_t port;
84} vppcom_endpt_t;
85
86typedef enum
87{
88 VPPCOM_OK = 0,
89 VPPCOM_EAGAIN = -EAGAIN,
Dave Wallace048b1d62018-01-03 22:24:41 -050090 VPPCOM_EFAULT = -EFAULT,
Dave Wallace60caa062017-11-10 17:07:13 -050091 VPPCOM_ENOMEM = -ENOMEM,
Dave Wallace543852a2017-08-03 02:11:34 -040092 VPPCOM_EINVAL = -EINVAL,
93 VPPCOM_EBADFD = -EBADFD,
94 VPPCOM_EAFNOSUPPORT = -EAFNOSUPPORT,
Dave Wallaceee45d412017-11-24 21:44:06 -050095 VPPCOM_ECONNABORTED = -ECONNABORTED,
Dave Wallace543852a2017-08-03 02:11:34 -040096 VPPCOM_ECONNRESET = -ECONNRESET,
Dave Wallace4878cbe2017-11-21 03:45:09 -050097 VPPCOM_ENOTCONN = -ENOTCONN,
Dave Wallace543852a2017-08-03 02:11:34 -040098 VPPCOM_ECONNREFUSED = -ECONNREFUSED,
99 VPPCOM_ETIMEDOUT = -ETIMEDOUT,
100} vppcom_error_t;
101
Dave Wallace35830af2017-10-09 01:43:42 -0400102typedef enum
103{
104 VPPCOM_ATTR_GET_NREAD,
Dave Wallace227867f2017-11-13 21:21:53 -0500105 VPPCOM_ATTR_GET_NWRITE,
Dave Wallace35830af2017-10-09 01:43:42 -0400106 VPPCOM_ATTR_GET_FLAGS,
107 VPPCOM_ATTR_SET_FLAGS,
108 VPPCOM_ATTR_GET_LCL_ADDR,
109 VPPCOM_ATTR_GET_PEER_ADDR,
Dave Wallace048b1d62018-01-03 22:24:41 -0500110 VPPCOM_ATTR_GET_LIBC_EPFD,
111 VPPCOM_ATTR_SET_LIBC_EPFD,
112 VPPCOM_ATTR_GET_PROTOCOL,
113 VPPCOM_ATTR_GET_LISTEN,
114 VPPCOM_ATTR_GET_ERROR,
115 VPPCOM_ATTR_GET_TX_FIFO_LEN,
116 VPPCOM_ATTR_SET_TX_FIFO_LEN,
117 VPPCOM_ATTR_GET_RX_FIFO_LEN,
118 VPPCOM_ATTR_SET_RX_FIFO_LEN,
119 VPPCOM_ATTR_GET_REUSEADDR,
Stevenb5a11602017-10-11 09:59:30 -0700120 VPPCOM_ATTR_SET_REUSEADDR,
Dave Wallace048b1d62018-01-03 22:24:41 -0500121 VPPCOM_ATTR_GET_REUSEPORT,
122 VPPCOM_ATTR_SET_REUSEPORT,
123 VPPCOM_ATTR_GET_BROADCAST,
Stevenb5a11602017-10-11 09:59:30 -0700124 VPPCOM_ATTR_SET_BROADCAST,
Dave Wallace048b1d62018-01-03 22:24:41 -0500125 VPPCOM_ATTR_GET_V6ONLY,
Stevenb5a11602017-10-11 09:59:30 -0700126 VPPCOM_ATTR_SET_V6ONLY,
Dave Wallace048b1d62018-01-03 22:24:41 -0500127 VPPCOM_ATTR_GET_KEEPALIVE,
Stevenbccd3392017-10-12 20:42:21 -0700128 VPPCOM_ATTR_SET_KEEPALIVE,
Dave Wallace048b1d62018-01-03 22:24:41 -0500129 VPPCOM_ATTR_GET_TCP_NODELAY,
130 VPPCOM_ATTR_SET_TCP_NODELAY,
131 VPPCOM_ATTR_GET_TCP_KEEPIDLE,
Stevenbccd3392017-10-12 20:42:21 -0700132 VPPCOM_ATTR_SET_TCP_KEEPIDLE,
Dave Wallace048b1d62018-01-03 22:24:41 -0500133 VPPCOM_ATTR_GET_TCP_KEEPINTVL,
Stevenbccd3392017-10-12 20:42:21 -0700134 VPPCOM_ATTR_SET_TCP_KEEPINTVL,
Dave Wallace048b1d62018-01-03 22:24:41 -0500135 VPPCOM_ATTR_GET_TCP_USER_MSS,
136 VPPCOM_ATTR_SET_TCP_USER_MSS,
Dave Wallace35830af2017-10-09 01:43:42 -0400137} vppcom_attr_op_t;
138
Dave Wallace048b1d62018-01-03 22:24:41 -0500139typedef struct _vcl_poll
140{
141 uint32_t fds_ndx;
142 uint32_t sid;
143 short events;
144 short *revents;
145} vcl_poll_t;
146
Keith Burns (alagalah)410bcca2018-03-23 13:42:49 -0700147typedef struct vppcom_ioevent_
148{
149 uint32_t session_index;
150 size_t bytes;
151} vppcom_ioevent_t;
152
153
Dave Wallace543852a2017-08-03 02:11:34 -0400154/*
155 * VPPCOM Public API Functions
156 */
157static inline const char *
158vppcom_retval_str (int retval)
159{
160 char *st;
161
162 switch (retval)
163 {
164 case VPPCOM_OK:
165 st = "VPPCOM_OK";
166 break;
167
168 case VPPCOM_EAGAIN:
169 st = "VPPCOM_EAGAIN";
170 break;
171
Dave Wallace048b1d62018-01-03 22:24:41 -0500172 case VPPCOM_EFAULT:
173 st = "VPPCOM_EFAULT";
174 break;
175
Dave Wallacee376f932017-11-19 11:20:02 -0500176 case VPPCOM_ENOMEM:
177 st = "VPPCOM_ENOMEM";
178 break;
179
Dave Wallace543852a2017-08-03 02:11:34 -0400180 case VPPCOM_EINVAL:
181 st = "VPPCOM_EINVAL";
182 break;
183
184 case VPPCOM_EBADFD:
185 st = "VPPCOM_EBADFD";
186 break;
187
188 case VPPCOM_EAFNOSUPPORT:
189 st = "VPPCOM_EAFNOSUPPORT";
190 break;
191
Dave Wallaceee45d412017-11-24 21:44:06 -0500192 case VPPCOM_ECONNABORTED:
193 st = "VPPCOM_ECONNABORTED";
194 break;
195
Dave Wallace543852a2017-08-03 02:11:34 -0400196 case VPPCOM_ECONNRESET:
197 st = "VPPCOM_ECONNRESET";
198 break;
199
Dave Wallace4878cbe2017-11-21 03:45:09 -0500200 case VPPCOM_ENOTCONN:
201 st = "VPPCOM_ENOTCONN";
202 break;
203
Dave Wallace543852a2017-08-03 02:11:34 -0400204 case VPPCOM_ECONNREFUSED:
205 st = "VPPCOM_ECONNREFUSED";
206 break;
207
208 case VPPCOM_ETIMEDOUT:
209 st = "VPPCOM_ETIMEDOUT";
210 break;
211
212 default:
213 st = "UNKNOWN_STATE";
214 break;
215 }
216
217 return st;
218}
219
Keith Burns (alagalah)0d2b0d52018-03-06 15:55:22 -0800220/**
221 * User registered callback for when connection arrives on listener created
222 * with vppcom_session_register_listener()
223 * @param uint32_t - newly accepted session_index
224 * @param vppcom_endpt_t* - ip/port information of remote
225 * @param void* - user passed arg to pass back
226 */
227typedef void (*vppcom_session_listener_cb) (uint32_t, vppcom_endpt_t *,
228 void *);
229
230/**
Keith Burns (alagalah)410bcca2018-03-23 13:42:49 -0700231 * User registered callback for IO events (rx/tx)
232 * @param vppcom_ioevent_t* -
233 * @param void* - user passed arg to pass back
234 */
235typedef void (*vppcom_session_ioevent_cb) (vppcom_ioevent_t *, void *);
236
237/**
238 * @brief vppcom_session_register_listener accepts a bound session_index, and
239 * listens for connections.
240 *
241 * On successful connection, calls registered callback (cb) with new
242 * session_index.
243 *
244 * On error, calls registered error callback (errcb).
245 *
246 * @param session_index - bound session_index to create listener on
247 * @param cb - on new accepted session callback
248 * @param errcb - on failure callback
249 * @param flags - placeholder for future use. Must be ZERO
250 * @param q_len - max listener connection backlog
251 * @param ptr - user data
252 * @return
253 */
254extern int vppcom_session_register_ioevent_cb (uint32_t session_index,
255 vppcom_session_ioevent_cb cb,
256 uint8_t rx, void *ptr);
257
258/**
Keith Burns (alagalah)0d2b0d52018-03-06 15:55:22 -0800259 * User registered ERROR callback for any errors associated with
260 * handling vppcom_session_register_listener() and connections
261 * @param void* - user passed arg to pass back
262 */
263typedef void (*vppcom_session_listener_errcb) (void *);
264
265/**
266 * @brief vppcom_session_register_listener accepts a bound session_index, and
267 * listens for connections.
268 *
269 * On successful connection, calls registered callback (cb) with new
270 * session_index.
271 *
272 * On error, calls registered error callback (errcb).
273 *
274 * @param session_index - bound session_index to create listener on
275 * @param cb - on new accepted session callback
276 * @param errcb - on failure callback
277 * @param flags - placeholder for future use. Must be ZERO
278 * @param q_len - max listener connection backlog
279 * @param ptr - user data
280 * @return
281 */
282extern int vppcom_session_register_listener (uint32_t session_index,
283 vppcom_session_listener_cb cb,
284 vppcom_session_listener_errcb
285 errcb, uint8_t flags, int q_len,
286 void *ptr);
287
Dave Wallace543852a2017-08-03 02:11:34 -0400288/* TBD: make these constructor/destructor function */
289extern int vppcom_app_create (char *app_name);
290extern void vppcom_app_destroy (void);
291
Dave Wallacec04cbf12018-02-07 18:14:02 -0500292extern int vppcom_session_create (uint8_t proto, uint8_t is_nonblocking);
Dave Wallace543852a2017-08-03 02:11:34 -0400293extern int vppcom_session_close (uint32_t session_index);
294
295extern int vppcom_session_bind (uint32_t session_index, vppcom_endpt_t * ep);
296extern int vppcom_session_listen (uint32_t session_index, uint32_t q_len);
Keith Burns (alagalah)0d2b0d52018-03-06 15:55:22 -0800297
Dave Wallace543852a2017-08-03 02:11:34 -0400298extern int vppcom_session_accept (uint32_t session_index,
Dave Wallace048b1d62018-01-03 22:24:41 -0500299 vppcom_endpt_t * client_ep, uint32_t flags);
Dave Wallace543852a2017-08-03 02:11:34 -0400300
301extern int vppcom_session_connect (uint32_t session_index,
302 vppcom_endpt_t * server_ep);
Dave Wallace048b1d62018-01-03 22:24:41 -0500303extern int vppcom_session_read (uint32_t session_index, void *buf, size_t n);
304extern int vppcom_session_write (uint32_t session_index, void *buf, size_t n);
Dave Wallace543852a2017-08-03 02:11:34 -0400305
306extern int vppcom_select (unsigned long n_bits,
307 unsigned long *read_map,
308 unsigned long *write_map,
309 unsigned long *except_map, double wait_for_time);
310
Dave Wallacef7f809c2017-10-03 01:48:42 -0400311extern int vppcom_epoll_create (void);
312extern int vppcom_epoll_ctl (uint32_t vep_idx, int op,
313 uint32_t session_index,
314 struct epoll_event *event);
315extern int vppcom_epoll_wait (uint32_t vep_idx, struct epoll_event *events,
316 int maxevents, double wait_for_time);
Dave Wallace35830af2017-10-09 01:43:42 -0400317extern int vppcom_session_attr (uint32_t session_index, uint32_t op,
318 void *buffer, uint32_t * buflen);
Stevenac1f96d2017-10-24 16:03:58 -0700319extern int vppcom_session_recvfrom (uint32_t session_index, void *buffer,
320 uint32_t buflen, int flags,
321 vppcom_endpt_t * ep);
322extern int vppcom_session_sendto (uint32_t session_index, void *buffer,
323 uint32_t buflen, int flags,
324 vppcom_endpt_t * ep);
Dave Wallace048b1d62018-01-03 22:24:41 -0500325extern int vppcom_poll (vcl_poll_t * vp, uint32_t n_sids,
326 double wait_for_time);
Dave Wallacef7f809c2017-10-03 01:48:42 -0400327
Keith Burns (alagalah)5a2946c2018-02-02 08:21:56 -0800328/* *INDENT-OFF* */
329#ifdef __cplusplus
330}
331#endif
332/* *INDENT-ON* */
333
Dave Wallace543852a2017-08-03 02:11:34 -0400334#endif /* included_vppcom_h */
335
336/*
337 * fd.io coding-style-patch-verification: ON
338 *
339 * Local Variables:
340 * eval: (c-set-style "gnu")
341 * End:
342 */