session: segment handle in accept/connect notifications
[vpp.git] / src / vnet / session / session.h
index a989861..d5f040e 100644 (file)
@@ -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);