X-Git-Url: https://gerrit.fd.io/r/gitweb?a=blobdiff_plain;f=src%2Fvcl%2Fvcl_bapi.c;h=ea8f2ce5651c3d6b7b1b700ba1ded4badf4d97a6;hb=178cf493d009995b28fdf220f04c98860ff79a9b;hp=d9e8e7e046cb044abc2199bb4cca038de79f4711;hpb=6011699556bc48eac884920d818a2a50339b9f01;p=vpp.git diff --git a/src/vcl/vcl_bapi.c b/src/vcl/vcl_bapi.c index d9e8e7e046c..ea8f2ce5651 100644 --- a/src/vcl/vcl_bapi.c +++ b/src/vcl/vcl_bapi.c @@ -87,6 +87,7 @@ static void vl_api_application_attach_reply_t_handler (vl_api_application_attach_reply_t * mp) { + vcl_worker_t *wrk = vcl_worker_get (0); u32 n_fds = 0; int *fds = 0; @@ -97,7 +98,7 @@ vl_api_application_attach_reply_t_handler (vl_api_application_attach_reply_t * return; } - vcm->app_event_queue = uword_to_pointer (mp->app_event_queue_address, + wrk->app_event_queue = uword_to_pointer (mp->app_event_queue_address, svm_msg_q_t *); if (mp->n_fds) { @@ -116,10 +117,8 @@ vl_api_application_attach_reply_t_handler (vl_api_application_attach_reply_t * if (mp->fd_flags & SESSION_FD_F_MQ_EVENTFD) { - svm_msg_q_set_consumer_eventfd (vcm->app_event_queue, fds[n_fds]); - if (vcm->mqs_epfd < 0) - clib_unix_warning ("epoll_create() returned"); - vcl_mq_epoll_add_evfd (vcm->app_event_queue); + svm_msg_q_set_consumer_eventfd (wrk->app_event_queue, fds[n_fds]); + vcl_mq_epoll_add_evfd (wrk, wrk->app_event_queue); n_fds++; } @@ -135,6 +134,71 @@ vl_api_application_attach_reply_t_handler (vl_api_application_attach_reply_t * vcm->app_state = STATE_APP_ATTACHED; } +static void +vl_api_app_worker_add_del_reply_t_handler (vl_api_app_worker_add_del_reply_t * + mp) +{ + int n_fds = 0, *fds = 0; + vcl_worker_t *wrk; + u32 wrk_index; + + if (mp->retval) + { + clib_warning ("VCL<%d>: add/del worker failed: %U", getpid (), + format_api_error, ntohl (mp->retval)); + goto failed; + } + wrk_index = clib_net_to_host_u32 (mp->wrk_index); + if (mp->context != wrk_index) + { + clib_warning ("VCL<%d>: wrk numbering doesn't match ours: %u, vpp: %u", + getpid (), mp->context, wrk_index); + goto failed; + } + if (!mp->is_add) + return; + + wrk = vcl_worker_get (wrk_index); + wrk->app_event_queue = uword_to_pointer (mp->app_event_queue_address, + svm_msg_q_t *); + + if (mp->n_fds) + { + vec_validate (fds, mp->n_fds); + vl_socket_client_recv_fd_msg (fds, mp->n_fds, 5); + + if (mp->fd_flags & SESSION_FD_F_VPP_MQ_SEGMENT) + if (ssvm_segment_attach ("vpp-worker-seg", SSVM_SEGMENT_MEMFD, + fds[n_fds++])) + goto failed; + + if (mp->fd_flags & SESSION_FD_F_MEMFD_SEGMENT) + if (ssvm_segment_attach ((char *) mp->segment_name, + SSVM_SEGMENT_MEMFD, fds[n_fds++])) + goto failed; + + if (mp->fd_flags & SESSION_FD_F_MQ_EVENTFD) + { + svm_msg_q_set_consumer_eventfd (wrk->app_event_queue, fds[n_fds]); + vcl_mq_epoll_add_evfd (wrk, wrk->app_event_queue); + n_fds++; + } + + vec_free (fds); + } + else + { + if (ssvm_segment_attach ((char *) mp->segment_name, SSVM_SEGMENT_SHM, + -1)) + goto failed; + } + vcm->app_state = STATE_APP_READY; + return; + +failed: + vcm->app_state = STATE_APP_FAILED; +} + static void vl_api_application_detach_reply_t_handler (vl_api_application_detach_reply_t * mp) @@ -191,6 +255,7 @@ static void { vcl_cut_through_registration_t *ctr; u32 mqc_index = ~0; + vcl_worker_t *wrk; int *fds = 0; if (mp->n_fds) @@ -200,22 +265,23 @@ static void vl_socket_client_recv_fd_msg (fds, mp->n_fds, 5); } - ctr = vcl_ct_registration_lock_and_alloc (); + wrk = vcl_worker_get (mp->wrk_index); + ctr = vcl_ct_registration_lock_and_alloc (wrk); ctr->mq = uword_to_pointer (mp->evt_q_address, svm_msg_q_t *); ctr->peer_mq = uword_to_pointer (mp->peer_evt_q_address, svm_msg_q_t *); - VDBG (0, "Adding ct registration %u", vcl_ct_registration_index (ctr)); + VDBG (0, "Adding ct registration %u", vcl_ct_registration_index (wrk, ctr)); if (mp->n_fds && (mp->fd_flags & SESSION_FD_F_MQ_EVENTFD)) { svm_msg_q_set_consumer_eventfd (ctr->mq, fds[0]); svm_msg_q_set_producer_eventfd (ctr->peer_mq, fds[1]); - mqc_index = vcl_mq_epoll_add_evfd (ctr->mq); + mqc_index = vcl_mq_epoll_add_evfd (wrk, ctr->mq); ctr->epoll_evt_conn_index = mqc_index; vec_free (fds); } - vcl_ct_registration_lookup_add (mp->evt_q_address, - vcl_ct_registration_index (ctr)); - vcl_ct_registration_unlock (); + vcl_ct_registration_lookup_add (wrk, mp->evt_q_address, + vcl_ct_registration_index (wrk, ctr)); + vcl_ct_registration_unlock (wrk); } static void @@ -238,15 +304,37 @@ vl_api_unbind_sock_reply_t_handler (vl_api_unbind_sock_reply_t * mp) VDBG (1, "VCL<%d>: sid %u: unbind succeeded!", getpid (), mp->context); } +static void +vl_api_disconnect_session_reply_t_handler (vl_api_disconnect_session_reply_t * + mp) +{ + if (mp->retval) + clib_warning ("VCL<%d>: ERROR: sid %u: disconnect failed: %U", + getpid (), mp->context, format_api_error, + ntohl (mp->retval)); +} + +static void +vl_api_connect_session_reply_t_handler (vl_api_connect_sock_reply_t * mp) +{ + if (mp->retval) + clib_warning ("VCL<%d>: ERROR: sid %u: connect failed: %U", + getpid (), mp->context, format_api_error, + ntohl (mp->retval)); +} + #define foreach_sock_msg \ _(SESSION_ENABLE_DISABLE_REPLY, session_enable_disable_reply) \ _(BIND_SOCK_REPLY, bind_sock_reply) \ _(UNBIND_SOCK_REPLY, unbind_sock_reply) \ +_(CONNECT_SESSION_REPLY, connect_session_reply) \ +_(DISCONNECT_SESSION_REPLY, disconnect_session_reply) \ _(APPLICATION_ATTACH_REPLY, application_attach_reply) \ _(APPLICATION_DETACH_REPLY, application_detach_reply) \ _(MAP_ANOTHER_SEGMENT, map_another_segment) \ _(UNMAP_SEGMENT, unmap_segment) \ _(APP_CUT_THROUGH_REGISTRATION_ADD, app_cut_through_registration_add) \ +_(APP_WORKER_ADD_DEL_REPLY, app_worker_add_del_reply) \ void vppcom_api_hookup (void) @@ -313,7 +401,7 @@ vppcom_app_send_attach (void) if (nsid_len) { bmp->namespace_id_len = nsid_len; - clib_memcpy (bmp->namespace_id, vcm->cfg.namespace_id, nsid_len); + clib_memcpy_fast (bmp->namespace_id, vcm->cfg.namespace_id, nsid_len); bmp->options[APP_OPTIONS_NAMESPACE_SECRET] = vcm->cfg.namespace_secret; } vl_msg_api_send_shmem (vcm->vl_input_queue, (u8 *) & bmp); @@ -333,33 +421,50 @@ vppcom_app_send_detach (void) } void -vppcom_send_connect_sock (vcl_session_t * session, u32 session_index) +vcl_send_app_worker_add_del (u8 is_add) +{ + vcl_worker_t *wrk = vcl_worker_get_current (); + vl_api_app_worker_add_del_t *mp; + u32 wrk_index = wrk->wrk_index; + + mp = vl_msg_api_alloc (sizeof (*mp)); + memset (mp, 0, sizeof (*mp)); + + mp->_vl_msg_id = ntohs (VL_API_APP_WORKER_ADD_DEL); + mp->client_index = vcm->my_client_index; + mp->app_api_index = clib_host_to_net_u32 (vcm->my_client_index); + mp->context = wrk_index; + mp->is_add = is_add; + if (!is_add) + mp->wrk_index = clib_host_to_net_u32 (wrk_index); + + vl_msg_api_send_shmem (vcm->vl_input_queue, (u8 *) & mp); +} + +void +vppcom_send_connect_sock (vcl_session_t * session) { vl_api_connect_sock_t *cmp; - /* Assumes caller as acquired the spinlock: vcm->sessions_lockp */ cmp = vl_msg_api_alloc (sizeof (*cmp)); memset (cmp, 0, sizeof (*cmp)); cmp->_vl_msg_id = ntohs (VL_API_CONNECT_SOCK); cmp->client_index = vcm->my_client_index; - cmp->context = session_index; - + cmp->context = session->session_index; + cmp->wrk_index = vcl_get_worker_index (); cmp->is_ip4 = session->transport.is_ip4; - clib_memcpy (cmp->ip, &session->transport.rmt_ip, sizeof (cmp->ip)); + clib_memcpy_fast (cmp->ip, &session->transport.rmt_ip, sizeof (cmp->ip)); cmp->port = session->transport.rmt_port; cmp->proto = session->session_type; - clib_memcpy (cmp->options, session->options, sizeof (cmp->options)); + clib_memcpy_fast (cmp->options, session->options, sizeof (cmp->options)); vl_msg_api_send_shmem (vcm->vl_input_queue, (u8 *) & cmp); } void -vppcom_send_disconnect_session (u64 vpp_handle, u32 session_index) +vppcom_send_disconnect_session (u64 vpp_handle) { vl_api_disconnect_session_t *dmp; - VDBG (1, "VCL<%d>: vpp handle 0x%llx, sid %u: sending disconnect msg", - getpid (), vpp_handle, session_index); - dmp = vl_msg_api_alloc (sizeof (*dmp)); memset (dmp, 0, sizeof (*dmp)); dmp->_vl_msg_id = ntohs (VL_API_DISCONNECT_SESSION); @@ -372,7 +477,7 @@ vppcom_send_disconnect_session (u64 vpp_handle, u32 session_index) * of bind and listen locally via vppcom_session_bind() and * vppcom_session_listen() */ void -vppcom_send_bind_sock (vcl_session_t * session, u32 session_index) +vppcom_send_bind_sock (vcl_session_t * session) { vl_api_bind_sock_t *bmp; @@ -382,12 +487,13 @@ vppcom_send_bind_sock (vcl_session_t * session, u32 session_index) bmp->_vl_msg_id = ntohs (VL_API_BIND_SOCK); bmp->client_index = vcm->my_client_index; - bmp->context = session_index; + bmp->context = session->session_index; + bmp->wrk_index = vcl_get_worker_index (); bmp->is_ip4 = session->transport.is_ip4; - clib_memcpy (bmp->ip, &session->transport.lcl_ip, sizeof (bmp->ip)); + clib_memcpy_fast (bmp->ip, &session->transport.lcl_ip, sizeof (bmp->ip)); bmp->port = session->transport.lcl_port; bmp->proto = session->session_type; - clib_memcpy (bmp->options, session->options, sizeof (bmp->options)); + clib_memcpy_fast (bmp->options, session->options, sizeof (bmp->options)); vl_msg_api_send_shmem (vcm->vl_input_queue, (u8 *) & bmp); } @@ -401,6 +507,7 @@ vppcom_send_unbind_sock (u64 vpp_handle) ump->_vl_msg_id = ntohs (VL_API_UNBIND_SOCK); ump->client_index = vcm->my_client_index; + ump->wrk_index = vcl_get_worker_index (); ump->handle = vpp_handle; vl_msg_api_send_shmem (vcm->vl_input_queue, (u8 *) & ump); }