X-Git-Url: https://gerrit.fd.io/r/gitweb?a=blobdiff_plain;f=src%2Fvnet%2Fsession%2Fapplication_local.c;h=d2edd54512aef049533fb675a722f13cb0d2180d;hb=317b8e08367c769b90463613231b9fcfad486098;hp=d1df657229d41713daf895ace011cae586136cf8;hpb=9f1a5432b3e6fa57bfe0788ca0ebb84075253bf7;p=vpp.git diff --git a/src/vnet/session/application_local.c b/src/vnet/session/application_local.c index d1df657229d..d2edd54512a 100644 --- a/src/vnet/session/application_local.c +++ b/src/vnet/session/application_local.c @@ -23,6 +23,9 @@ ct_enable_disable_main_pre_input_node (u8 is_add) { u32 n_conns; + if (!vlib_num_workers ()) + return; + n_conns = pool_elts (connections); if (n_conns > 2) return; @@ -472,6 +475,19 @@ ct_custom_tx (void *session) return ct_session_tx (s); } +static int +ct_app_rx_evt (transport_connection_t * tc) +{ + ct_connection_t *ct = (ct_connection_t *) tc, *peer_ct; + session_t *ps; + + peer_ct = ct_connection_get (ct->peer_index); + if (!peer_ct) + return -1; + ps = session_get (peer_ct->c_s_index, peer_ct->c_thread_index); + return session_dequeue_notify (ps); +} + static u8 * format_ct_listener (u8 * s, va_list * args) { @@ -532,6 +548,7 @@ const static transport_proto_vft_t cut_thru_proto = { .close = ct_session_close, .get_connection = ct_session_get, .custom_tx = ct_custom_tx, + .app_rx_evt = ct_app_rx_evt, .tx_type = TRANSPORT_TX_INTERNAL, .service_type = TRANSPORT_SERVICE_APP, .format_listener = format_ct_listener,