|
FD.io VPP
v21.06-3-gbb25fbf28
Vector Packet Processing
|
Go to the documentation of this file.
38 #define vl_print(handle, ...) vlib_cli_output (handle, __VA_ARGS__)
45 #define foreach_session_api_msg \
46 _(APP_ATTACH, app_attach) \
47 _(APPLICATION_DETACH, application_detach) \
48 _(SESSION_ENABLE_DISABLE, session_enable_disable) \
49 _(APP_NAMESPACE_ADD_DEL, app_namespace_add_del) \
50 _(SESSION_RULE_ADD_DEL, session_rule_add_del) \
51 _(SESSION_RULES_DUMP, session_rules_dump) \
52 _(APP_ADD_CERT_KEY_PAIR, app_add_cert_key_pair) \
53 _(APP_DEL_CERT_KEY_PAIR, app_del_cert_key_pair) \
54 _(APP_WORKER_ADD_DEL, app_worker_add_del) \
62 return TRANSPORT_PROTO_TCP;
64 return TRANSPORT_PROTO_UDP;
66 return TRANSPORT_PROTO_TLS;
68 return TRANSPORT_PROTO_QUIC;
70 return TRANSPORT_PROTO_NONE;
74 static vl_api_transport_proto_t
79 case TRANSPORT_PROTO_TCP:
81 case TRANSPORT_PROTO_UDP:
83 case TRANSPORT_PROTO_TLS:
85 case TRANSPORT_PROTO_QUIC:
97 return SESSION_E_BAPI_NO_FD;
102 return SESSION_E_BAPI_SEND_FD;
135 session_event_t *evt;
176 m.
rmt.port = ct->c_rmt_port;
177 m.
lcl.port = ct->c_lcl_port;
186 return SESSION_E_MQ_MSG_ALLOC;
204 session_event_t *evt;
211 evt->event_type = evt_type;
230 for (
i = 0;
i <
f->shr->n_subscribers;
i++)
275 session_event_t *evt;
295 m.
retval = SESSION_E_REFUSED;
316 m.
lcl.port = cct->c_lcl_port;
317 m.
lcl.is_ip4 = cct->c_is_ip4;
331 s->
rx_fifo->shr->client_session_index = api_context;
332 s->
tx_fifo->shr->client_session_index = api_context;
339 return SESSION_E_MQ_MSG_ALLOC;
360 session_event_t *evt;
401 return SESSION_E_MQ_MSG_ALLOC;
419 session_event_t *evt;
442 session_event_t *evt;
478 session_event_t *evt;
504 fd_flags |= SESSION_FD_F_MEMFD_SEGMENT;
539 session_event_t *evt;
571 session_event_t *evt;
610 vl_api_session_enable_disable_reply_t *rmp;
621 int rv = 0, *fds = 0, n_fds = 0, n_workers,
i;
625 u8 fd_flags = 0, ctrl_thread;
637 rv = VNET_API_ERROR_FEATURE_DISABLED;
643 rv = VNET_API_ERROR_APP_UNSUPPORTED_CFG;
649 "Out of options, fix api message definition");
671 fd_flags |= SESSION_FD_F_VPP_MQ_SEGMENT;
672 fds[n_fds] = rx_mqs_seg->
ssvm.
fd;
678 fd_flags |= SESSION_FD_F_MEMFD_SEGMENT;
679 fds[n_fds] =
a->segment->fd;
684 fd_flags |= SESSION_FD_F_MQ_EVENTFD;
691 fd_flags |= SESSION_FD_F_VPP_MQ_EVENTFD;
692 for (
i = 0;
i < n_workers + 1;
i++)
705 ctrl_thread = n_workers ? 1 : 0;
707 rmp->
app_index = clib_host_to_net_u32 (
a->app_index);
739 rv = VNET_API_ERROR_FEATURE_DISABLED;
750 rv = VNET_API_ERROR_INVALID_VALUE;
756 .wrk_map_index = clib_net_to_host_u32 (mp->
wrk_index),
773 fd_flags |= SESSION_FD_F_MEMFD_SEGMENT;
774 fds[n_fds] = args.segment->fd;
779 fd_flags |= SESSION_FD_F_MQ_EVENTFD;
788 rmp->
wrk_index = clib_host_to_net_u32 (args.wrk_map_index);
796 if (
vec_len (args.segment->name))
811 vl_api_application_detach_reply_t *rmp;
812 int rv = VNET_API_ERROR_INVALID_VALUE_2;
818 rv = VNET_API_ERROR_FEATURE_DISABLED;
843 rv = VNET_API_ERROR_FEATURE_DISABLED;
851 .secret = clib_net_to_host_u64 (mp->
secret),
852 .sw_if_index = clib_net_to_host_u32 (mp->
sw_if_index),
853 .ip4_fib_id = clib_net_to_host_u32 (mp->
ip4_fib_id),
854 .ip6_fib_id = clib_net_to_host_u32 (mp->
ip6_fib_id),
864 rv = VNET_API_ERROR_UNSPECIFIED;
873 rmp->
appns_index = clib_host_to_net_u32 (appns_index);
881 vl_api_session_rule_add_del_reply_t *rmp;
891 table_args->lcl_port = mp->
lcl_port;
892 table_args->rmt_port = mp->
rmt_port;
893 table_args->action_index = clib_net_to_host_u32 (mp->
action_index);
894 table_args->is_add = mp->
is_add;
895 mp->
tag[
sizeof (mp->
tag) - 1] = 0;
896 table_args->tag =
format (0,
"%s", mp->
tag);
897 args.appns_index = clib_net_to_host_u32 (mp->
appns_index);
898 args.scope = mp->
scope;
899 args.transport_proto =
901 TRANSPORT_PROTO_UDP ? 1 : 0;
916 session_mask_or_match_4_t *match =
917 (session_mask_or_match_4_t *) & rule->match;
918 session_mask_or_match_4_t *
mask =
919 (session_mask_or_match_4_t *) & rule->mask;
924 rmp->_vl_msg_id =
ntohs (VL_API_SESSION_RULES_DETAILS);
938 rmp->
action_index = clib_host_to_net_u32 (rule->action_index);
942 rmp->
appns_index = clib_host_to_net_u32 (appns_index);
958 session_mask_or_match_6_t *match =
959 (session_mask_or_match_6_t *) & rule->match;
960 session_mask_or_match_6_t *
mask =
961 (session_mask_or_match_6_t *) & rule->mask;
966 rmp->_vl_msg_id =
ntohs (VL_API_SESSION_RULES_DETAILS);
980 rmp->
action_index = clib_host_to_net_u32 (rule->action_index);
984 rmp->
appns_index = clib_host_to_net_u32 (appns_index);
999 mma_rule_16_t *rule16;
1000 mma_rule_40_t *rule40;
1001 mma_rules_table_16_t *srt16;
1002 mma_rules_table_40_t *srt40;
1009 srt16 = &srt->session_rules_tables_16;
1011 ri = mma_rules_table_rule_index_16 (srt16, rule16);
1022 srt40 = &srt->session_rules_tables_40;
1024 ri = mma_rules_table_rule_index_40 (srt40, rule40);
1049 st->active_fib_proto, tp,
1050 st->is_local, st->appns_index, reg,
1066 rv = VNET_API_ERROR_FEATURE_DISABLED;
1070 cert_len = clib_net_to_host_u16 (mp->
cert_len);
1071 if (cert_len > 10000)
1073 rv = VNET_API_ERROR_INVALID_VALUE;
1077 certkey_len = clib_net_to_host_u16 (mp->
certkey_len);
1078 if (certkey_len < cert_len)
1080 rv = VNET_API_ERROR_INVALID_VALUE;
1084 key_len = certkey_len - cert_len;
1087 rv = VNET_API_ERROR_INVALID_VALUE;
1094 a->cert_len = cert_len;
1102 rmp->
index = clib_host_to_net_u32 (
a->index);
1110 vl_api_app_del_cert_key_pair_reply_t *rmp;
1115 rv = VNET_API_ERROR_FEATURE_DISABLED;
1118 ckpair_index = clib_net_to_host_u32 (mp->
index);
1133 a->api_client_index = client_index;
1141 #define vl_msg_name_crc_list
1143 #undef vl_msg_name_crc_list
1148 #define _(id,n,crc) vl_msg_api_add_msg_name_crc (am, #n "_" #crc, id);
1149 foreach_vl_msg_name_crc_session;
1166 vl_msg_api_set_handlers(VL_API_##N, #n, \
1167 vl_api_##n##_t_handler, \
1169 vl_api_##n##_t_endian, \
1170 vl_api_##n##_t_print, \
1171 sizeof(vl_api_##n##_t), 1);
1217 session_event_t *evt;
1229 fd_flags |= SESSION_FD_F_MEMFD_SEGMENT;
1230 fds[n_fds] = sp->
fd;
1267 session_event_t *evt;
1302 int rv = 0, *fds = 0, n_fds = 0,
i, n_workers;
1305 u8 fd_flags = 0, ctrl_thread;
1321 a->use_sock_api = 1;
1337 fd_flags |= SESSION_FD_F_VPP_MQ_SEGMENT;
1338 fds[n_fds] = rx_mqs_seg->
ssvm.
fd;
1344 fd_flags |= SESSION_FD_F_MEMFD_SEGMENT;
1345 fds[n_fds] =
a->segment->fd;
1350 fd_flags |= SESSION_FD_F_MQ_EVENTFD;
1357 fd_flags |= SESSION_FD_F_VPP_MQ_EVENTFD;
1358 for (
i = 0;
i < n_workers + 1;
i++)
1373 ctrl_thread = n_workers ? 1 : 0;
1389 handle->aah_app_wrk_index = app_wrk->
wrk_index;
1401 u16 sock_index = api_handle & 0xffff;
1428 u32 sapi_handle = -1;
1435 rv = VNET_API_ERROR_INVALID_VALUE;
1444 .api_client_index = sapi_handle,
1463 fd_flags |= SESSION_FD_F_MEMFD_SEGMENT;
1464 fds[n_fds] = args.segment->fd;
1469 fd_flags |= SESSION_FD_F_MQ_EVENTFD;
1494 handle->aah_app_wrk_index = app_wrk->
wrk_index;
1505 u32 api_client_handle;
1517 .api_client_index = api_client_handle,
1562 handle->aah_app_wrk_index, msg.
type);
1576 clib_warning (
"called for app ns %u", handle->aah_app_ns_index);
1628 cf.file_descriptor = ccs->fd;
1631 cf.private_data = handle.as_u64;
1632 cf.description =
format (0,
"app sock conn fd: %d", ccs->fd);
1638 ccs->private_data = handle.as_u64;
1650 char *subdir =
"/app_ns_sockets/";
1653 struct stat file_stat;
1661 vec_add (dir, (
u8 *) subdir, strlen (subdir));
1671 app_ns->sock_name =
format (0,
"%v%v%c", dir, app_ns->ns_id, 0);
1677 cs->config = (
char *) app_ns->sock_name;
1689 if (stat ((
char *) app_ns->sock_name, &file_stat) == -1)
u32 ip4_mask_to_preflen(ip4_address_t *mask)
static void sapi_socket_detach(app_namespace_t *app_ns, clib_socket_t *cs)
#define CLIB_SOCKET_F_IS_SERVER
@ APP_SAPI_MSG_TYPE_ATTACH_REPLY
static vl_api_registration_t * vl_api_client_index_to_registration(u32 index)
static u32 vlib_num_workers()
u32 wrk_index
Worker index in global worker pool.
clib_file_main_t file_main
static u32 vl_api_registration_file_index(vl_api_registration_t *reg)
void vlib_worker_thread_barrier_release(vlib_main_t *vm)
enum session_error_ session_error_t
#define vec_add(V, E, N)
Add N elements to end of vector V (no header, unspecified alignment)
vl_api_transport_proto_t transport_proto
VL_MSG_API_REAPER_FUNCTION(application_reaper_cb)
svm_msg_q_t * application_rx_mq_get(application_t *app, u32 mq_index)
void ip_set(ip46_address_t *dst, void *src, u8 is_ip4)
@ SESSION_RULE_SCOPE_API_GLOBAL
static session_cb_vft_t session_mq_sapi_cb_vft
Application detach from session layer.
#define REPLY_MACRO2(t, body)
struct _vnet_app_namespace_add_del_args vnet_app_namespace_add_del_args_t
static void mq_notify_close_subscribers(u32 app_index, session_handle_t sh, svm_fifo_t *f, session_evt_type_t evt_type)
void svm_msg_q_add_and_unlock(svm_msg_q_t *mq, svm_msg_q_msg_t *msg)
Producer enqueue one message to queue with mutex held.
@ APP_SAPI_MSG_TYPE_ADD_DEL_WORKER
static void vl_api_send_msg(vl_api_registration_t *rp, u8 *elem)
#define APP_NAMESPACE_INVALID_INDEX
bool is_add[default=true]
void mq_send_unlisten_reply(app_worker_t *app_wrk, session_handle_t sh, u32 context, int rv)
static u8 svm_fifo_n_subscribers(svm_fifo_t *f)
Fifo number of subscribers getter.
struct _vnet_app_worker_add_del_args vnet_app_worker_add_del_args_t
@ SESSION_CTRL_EVT_CONNECTED
vl_api_interface_index_t sw_if_index[default=0xffffffff]
app_sapi_worker_add_del_reply_msg_t worker_add_del_reply
void session_get_endpoint(session_t *s, transport_endpoint_t *tep, u8 is_lcl)
@ SESSION_CTRL_EVT_DISCONNECTED
uword fifo_segment_msg_q_offset(fifo_segment_t *fs, u32 mq_index)
Message queue offset on segment.
static void mq_send_session_close_evt(app_worker_t *app_wrk, session_handle_t sh, session_evt_type_t evt_type)
static u64 listen_session_get_handle(session_t *s)
session_t * ct_session_get_peer(session_t *s)
void * svm_msg_q_msg_data(svm_msg_q_t *mq, svm_msg_q_msg_t *msg)
Get data for message in queue.
static int mq_send_add_segment_sapi_cb(u32 app_wrk_index, u64 segment_handle)
struct _app_namespace app_namespace_t
static clib_error_t * clib_socket_recvmsg(clib_socket_t *s, void *msg, int msglen, int fds[], int num_fds)
@ TRANSPORT_PROTO_API_QUIC
session_t * app_listener_get_local_session(app_listener_t *al)
Reply for app worker add/del.
u64 session_segment_handle(session_t *s)
segment_manager_props_t * application_segment_manager_properties(application_t *app)
uword vpp_event_queue_address
clib_file_function_t * read_function
#define SESSION_INVALID_INDEX
u32 app_index
App index in app pool.
#define APP_INVALID_INDEX
@ SVM_Q_NOWAIT
non-blocking call - works with both condvar and eventfd signaling
int vnet_application_detach(vnet_app_detach_args_t *a)
Detach application from vpp.
u16 fp_len
The mask length.
session_handle_t app_listen_session_handle(session_t *ls)
Get app listener handle for listening session.
u8 thread_index
Index of the thread that allocated the session.
vlib_main_t * vm
X-connect all packets from the HOST to the PHY.
static int mq_send_add_segment_cb(u32 app_wrk_index, u64 segment_handle)
static clib_error_t * session_api_hookup(vlib_main_t *vm)
u64 app_event_queue_address
static u32 session_thread_from_handle(session_handle_t handle)
static clib_socket_t * appns_sapi_get_socket(app_namespace_t *app_ns, u32 sock_index)
struct _vnet_app_detach_args_t vnet_app_detach_args_t
#define clib_error_report(e)
struct _transport_connection transport_connection_t
session_t * app_worker_first_listener(app_worker_t *app, u8 fib_proto, u8 transport_proto)
app_namespace_t * app_namespace_get(u32 index)
static_always_inline void * clib_memcpy_fast(void *restrict dst, const void *restrict src, size_t n)
static void vl_api_app_del_cert_key_pair_t_handler(vl_api_app_del_cert_key_pair_t *mp)
@ TRANSPORT_PROTO_API_NONE
void ip_prefix_encode(const fib_prefix_t *in, vl_api_prefix_t *out)
@ TRANSPORT_PROTO_API_TLS
static clib_error_t * sapi_sock_write_ready(clib_file_t *cf)
int(* session_accept_callback)(session_t *new_session)
Notify server of newly accepted session.
static void vl_api_session_enable_disable_t_handler(vl_api_session_enable_disable_t *mp)
static int mq_send_del_segment_cb(u32 app_wrk_index, u64 segment_handle)
struct _svm_fifo svm_fifo_t
fifo_segment_t * segment_manager_get_segment_w_handle(u64 segment_handle)
static u32 appns_sapi_socket_index(app_namespace_t *app_ns, clib_socket_t *cs)
u8 application_use_private_rx_mqs(void)
@ SESSION_CLEANUP_TRANSPORT
application_t * application_get(u32 app_index)
static void vl_api_session_rules_dump_t_handler(vl_api_session_rules_dump_t *mp)
u32 app_wrk_index
Index of the app worker that owns the session.
#define pool_foreach(VAR, POOL)
Iterate through pool.
svm_fifo_t * rx_fifo
Pointers to rx/tx buffers.
u32 session_index
global listening session index
#define vec_len(v)
Number of elements in vector (rvalue-only, NULL tolerant)
@ SESSION_CTRL_EVT_UNLISTEN_REPLY
static void sapi_add_del_worker_handler(app_namespace_t *app_ns, clib_socket_t *cs, app_sapi_worker_add_del_msg_t *mp)
struct _session_rules_table_t session_rules_table_t
Application attach to session layer.
static void mq_send_session_cleanup_cb(session_t *s, session_cleanup_ntf_t ntf)
transport_connection_t * session_get_transport(session_t *s)
#define foreach_session_api_msg
static int mq_try_lock_and_alloc_msg(svm_msg_q_t *app_mq, svm_msg_q_msg_t *msg)
static clib_error_t * clib_socket_close(clib_socket_t *sock)
int vnet_app_del_cert_key_pair(u32 index)
session_handle_t new_handle
#define vlib_worker_thread_barrier_sync(X)
An API client registration, only in vpp/vlib.
app_worker_t * app_worker_get_if_valid(u32 wrk_index)
@ SESSION_CTRL_EVT_CLEANUP
#define session_table_foreach(VAR, BODY)
static void mq_send_session_reset_cb(session_t *s)
void ip_prefix_decode(const vl_api_prefix_t *in, fib_prefix_t *out)
fifo_segment_t * application_get_rx_mqs_segment(application_t *app)
if(node->flags &VLIB_NODE_FLAG_TRACE) vnet_interface_output_trace(vm
static u8 session_type_is_ip4(session_type_t st)
static char * vlib_unix_get_runtime_dir(void)
static clib_error_t * clib_socket_sendmsg(clib_socket_t *s, void *msg, int msglen, int fds[], int num_fds)
static void vl_api_app_worker_add_del_t_handler(vl_api_app_worker_add_del_t *mp)
static clib_socket_t * appns_sapi_alloc_socket(app_namespace_t *app_ns)
static fib_protocol_t session_get_fib_proto(session_t *s)
static void sapi_socket_close_w_handle(u32 api_handle)
static clib_error_t * sapi_sock_accept_ready(clib_file_t *scf)
static api_main_t * vlibapi_get_main(void)
static void send_session_rule_details4(mma_rule_16_t *rule, u8 is_local, u8 transport_proto, u32 appns_index, u8 *tag, vl_api_registration_t *reg, u32 context)
sll srl srl sll sra u16x4 i
@ SESSION_RULE_SCOPE_API_LOCAL
static session_handle_t session_handle(session_t *s)
u32 ns_index
Namespace the application belongs to.
static void send_session_rules_table_details(session_rules_table_t *srt, u8 fib_proto, u8 tp, u8 is_local, u32 appns_index, vl_api_registration_t *reg, u32 context)
#define vec_validate(V, I)
Make sure vector is long enough for given index (no header, unspecified alignment)
clib_error_t * vlib_unix_recursive_mkdir(char *path)
application_t * application_get_if_valid(u32 app_index)
svm_msg_q_t * event_queue
Application listens for events on this svm queue.
int vnet_app_add_cert_key_pair(vnet_app_add_cert_key_pair_args_t *a)
#define STATIC_ASSERT(truth,...)
app_sapi_attach_reply_msg_t attach_reply
app_sapi_worker_add_del_msg_t worker_add_del
ip46_address_t fp_addr
The address type is not deriveable from the fp_addr member.
struct _vnet_app_add_cert_key_pair_args_ vnet_app_add_cert_key_pair_args_t
Delete certificate and key.
static clib_file_t * clib_file_get(clib_file_main_t *fm, u32 file_index)
int application_is_proxy(application_t *app)
session_handle_t listener_handle
Parent listener session index if the result of an accept.
app_listener_t * app_listener_get_w_handle(session_handle_t handle)
Get app listener for listener session handle.
#define VL_API_INVALID_FI
int vnet_application_attach(vnet_app_attach_args_t *a)
Attach application to vpp.
API main structure, used by both vpp and binary API clients.
static void mq_send_session_migrate_cb(session_t *s, session_handle_t new_sh)
static int mq_send_del_segment_sapi_cb(u32 app_wrk_index, u64 segment_handle)
u8 * session_rules_table_rule_tag(session_rules_table_t *srt, u32 ri, u8 is_ip4)
@ APP_SAPI_MSG_TYPE_SEND_FDS
ssvm_private_t ssvm
ssvm segment data
bool is_add[default=true]
#define vec_free(V)
Free vector's memory (no header).
static u32 appns_sapi_handle_sock_index(u32 sapi_sock_handle)
vl_api_session_rule_scope_t scope
@ APP_SAPI_MSG_TYPE_ADD_DEL_WORKER_REPLY
@ SESSION_CTRL_EVT_ACCEPTED
static void mq_send_session_disconnected_cb(session_t *s)
static clib_error_t * application_reaper_cb(u32 client_index)
static clib_error_t * vl_api_send_fd_msg(vl_api_registration_t *reg, int fds[], int n_fds)
static int session_send_fds(vl_api_registration_t *reg, int fds[], int n_fds)
int vl_api_vec_to_api_string(const u8 *vec, vl_api_string_t *str)
application_t * application_lookup(u32 api_client_index)
static u8 session_main_is_enabled()
static transport_proto_t api_session_transport_proto_decode(const vl_api_transport_proto_t *api_tp)
static session_cb_vft_t session_mq_cb_vft
description fragment has unexpected format
__clib_export clib_error_t * clib_socket_init(clib_socket_t *s)
u32 app_namespace_index_from_id(const u8 *ns_id)
static void clib_file_del(clib_file_main_t *um, clib_file_t *f)
static vl_api_transport_proto_t api_session_transport_proto_encode(const transport_proto_t tp)
bool is_add[default=true]
static u32 appns_sapi_socket_handle(app_namespace_t *app_ns, clib_socket_t *cs)
struct _session_rules_table_add_del_args session_rule_table_add_del_args_t
static void send_session_rule_details6(mma_rule_40_t *rule, u8 is_local, u8 transport_proto, u32 appns_index, u8 *tag, vl_api_registration_t *reg, u32 context)
#define TRANSPORT_N_PROTOS
ssvm_segment_type_t ssvm_type(const ssvm_private_t *ssvm)
static clib_error_t * sapi_sock_read_ready(clib_file_t *cf)
enum _transport_proto transport_proto_t
#define CLIB_SOCKET_F_ALLOW_GROUP_WRITE
static void vl_api_app_add_cert_key_pair_t_handler(vl_api_app_add_cert_key_pair_t *mp)
int mq_send_session_bound_cb(u32 app_wrk_index, u32 api_context, session_handle_t handle, int rv)
app_worker_t * app_worker_get(u32 wrk_index)
static void appns_sapi_free_socket(app_namespace_t *app_ns, clib_socket_t *cs)
enable/disable session layer
app_worker_t * application_get_worker(application_t *app, u32 wrk_map_index)
void vlib_rpc_call_main_thread(void *callback, u8 *args, u32 arg_size)
static uword clib_file_add(clib_file_main_t *um, clib_file_t *template)
u32 app_namespace_index(app_namespace_t *app_ns)
static int mq_send_session_accepted_cb(session_t *s)
#define SESSION_INVALID_HANDLE
add/del application namespace
u8 * vl_api_from_api_to_new_vec(void *mp, vl_api_string_t *astr)
@ TRANSPORT_SERVICE_CL
connectionless service
int vnet_app_worker_add_del(vnet_app_worker_add_del_args_t *a)
vl_api_transport_proto_t transport_proto
u32 ip6_mask_to_preflen(ip6_address_t *mask)
clib_memset(h->entries, 0, sizeof(h->entries[0]) *entries)
int svm_msg_q_lock_and_alloc_msg_w_ring(svm_msg_q_t *mq, u32 ring_index, u8 noblock, svm_msg_q_msg_t *msg)
Lock message queue and allocate message buffer on ring.
static transport_proto_t session_get_transport_proto(session_t *s)
@ TRANSPORT_PROTO_API_UDP
u32 wrk_map_index
Worker index in app's map pool.
static vlib_main_t * vlib_get_main(void)
static transport_service_type_t session_transport_service_type(session_t *s)
int mq_send_session_connected_cb(u32 app_wrk_index, u32 api_context, session_t *s, session_error_t err)
vl_api_session_rule_scope_t scope
static clib_error_t * sapi_sock_error(clib_file_t *cf)
#define CLIB_SOCKET_F_PASSCRED
static void vl_api_application_detach_t_handler(vl_api_application_detach_t *mp)
int vnet_session_rule_add_del(session_rule_add_del_args_t *args)
Application attach reply.
#define clib_warning(format, args...)
app_sapi_attach_msg_t attach
@ APP_SAPI_MSG_TYPE_ATTACH
static void session_api_attach_handler(app_namespace_t *app_ns, clib_socket_t *cs, app_sapi_attach_msg_t *mp)
static void setup_message_id_table(api_main_t *am)
#define clib_error_free(e)
static void sapi_send_fds(app_worker_t *app_wrk, int *fds, int n_fds)
@ SESSION_CTRL_EVT_MIGRATED
Reply for app namespace add/del.
uword fifo_segment_fifo_offset(svm_fifo_t *f)
struct _vnet_app_attach_args_t vnet_app_attach_args_t
u32 app_index
Index of owning app.
struct _socket_t clib_socket_t
static u8 session_has_transport(session_t *s)
int vnet_app_namespace_add_del(vnet_app_namespace_add_del_args_t *a)
@ TRANSPORT_PROTO_API_TCP
@ SESSION_MQ_CTRL_EVT_RING
vl_api_registration_t * vl_mem_api_client_index_to_registration(u32 handle)
u32 api_client_index
API index for the worker.
VLIB_API_INIT_FUNCTION(session_api_hookup)
uword vpp_event_queue_address
add/del application worker
session_t * app_listener_get_session(app_listener_t *al)
static void vl_api_session_rule_add_del_t_handler(vl_api_session_rule_add_del_t *mp)
volatile u8 session_state
State in session layer state machine.
u8 appns_sapi_enabled(void)
static void vl_api_app_namespace_add_del_t_handler(vl_api_app_namespace_add_del_t *mp)
Aggregate type for a prefix.
static session_t * listen_session_get_from_handle(session_handle_t handle)
u64 app_event_queue_address
struct _session_lookup_table session_table_t
#define CLIB_SOCKET_F_SEQPACKET
int appns_sapi_add_ns_socket(app_namespace_t *app_ns)
static void vl_api_app_attach_t_handler(vl_api_app_attach_t *mp)
clib_error_t * vnet_session_enable_disable(vlib_main_t *vm, u8 is_en)
static int svm_msg_q_get_eventfd(svm_msg_q_t *mq)
struct _session_rule_add_del_args session_rule_add_del_args_t
@ SESSION_CTRL_EVT_APP_ADD_SEGMENT
__clib_export clib_error_t * clib_socket_accept(clib_socket_t *server, clib_socket_t *client)
void * vl_msg_api_alloc(int nbytes)
bool is_enable[default=true]
@ SESSION_CTRL_EVT_APP_DEL_SEGMENT