X-Git-Url: https://gerrit.fd.io/r/gitweb?p=vpp.git;a=blobdiff_plain;f=src%2Fvnet%2Fsession%2Fsession.h;h=d5f040edc594fa84a8fad637ab7432b2b78eed23;hp=a98986124d77faac087a545b936c30fe14eb8cc6;hb=fa76a76;hpb=5a7ca7bde104b12f8dc4a751fd911819d4bd6c8e diff --git a/src/vnet/session/session.h b/src/vnet/session/session.h index a98986124d7..d5f040edc59 100644 --- a/src/vnet/session/session.h +++ b/src/vnet/session/session.h @@ -223,9 +223,14 @@ typedef struct session_manager_worker_ /** Vector of postponed disconnects */ session_event_t *pending_disconnects; + /** Vector of postponed events */ + session_event_t *postponed_event_vector; + /** Peekers rw lock */ clib_rwlock_t peekers_rw_locks; + u32 last_tx_packets; + } session_manager_worker_t; struct _session_manager_main @@ -436,6 +441,14 @@ session_type_from_proto_and_ip (transport_proto_t proto, u8 is_ip4) return (proto << 1 | is_ip4); } +always_inline u64 +session_segment_handle (stream_session_t * s) +{ + svm_fifo_t *f = s->server_rx_fifo; + return segment_manager_make_segment_handle (f->segment_manager, + f->segment_index); +} + always_inline u8 session_has_transport (stream_session_t * s) { @@ -519,6 +532,13 @@ transport_tx_fifo_size (transport_connection_t * tc) return s->server_tx_fifo->nitems; } +always_inline u8 +transport_rx_fifo_has_ooo_data (transport_connection_t * tc) +{ + stream_session_t *s = session_get (tc->c_index, tc->thread_index); + return svm_fifo_has_ooo_data (s->server_rx_fifo); +} + always_inline f64 transport_dispatch_period (u32 thread_index) { @@ -551,7 +571,7 @@ session_clone_safe (u32 session_index, u32 thread_index) session_pool_add_peeker (thread_index); new_s = session_alloc (current_thread_index); old_s = session_manager_main.wrk[thread_index].sessions + session_index; - clib_memcpy (new_s, old_s, sizeof (*new_s)); + clib_memcpy_fast (new_s, old_s, sizeof (*new_s)); session_pool_remove_peeker (thread_index); new_s->thread_index = current_thread_index; new_s->session_index = session_get_index (new_s);