X-Git-Url: https://gerrit.fd.io/r/gitweb?a=blobdiff_plain;f=src%2Fvnet%2Fsession%2Fsession.h;h=a6118d127664959bd52902f7f74a1f203d18e6ff;hb=371ca50a74a9c4f1b74c4c1b65c6fdec610fcfc3;hp=108e5fe259a932fe2353dfea211b31df753b01e7;hpb=f8f516a8b0ccab2f5d9796f90419bf2661c750af;p=vpp.git diff --git a/src/vnet/session/session.h b/src/vnet/session/session.h index 108e5fe259a..a6118d12766 100644 --- a/src/vnet/session/session.h +++ b/src/vnet/session/session.h @@ -25,6 +25,7 @@ #define HALF_OPEN_LOOKUP_INVALID_VALUE ((u64)~0) #define INVALID_INDEX ((u32)~0) #define SESSION_PROXY_LISTENER_INDEX ((u32)~0 - 1) +#define SESSION_LOCAL_HANDLE_PREFIX 0x7FFFFFFF /* TODO decide how much since we have pre-data as well */ #define MAX_HDRS_LEN 100 /* Max number of bytes for headers */ @@ -113,6 +114,7 @@ typedef int extern session_fifo_rx_fn session_tx_fifo_peek_and_snd; extern session_fifo_rx_fn session_tx_fifo_dequeue_and_snd; +extern session_fifo_rx_fn session_tx_fifo_dequeue_internal; u8 session_node_lookup_fifo_event (svm_fifo_t * f, session_fifo_event_t * e); @@ -232,6 +234,8 @@ stream_session_is_valid (u32 si, u8 thread_index) } stream_session_t *session_alloc (u32 thread_index); +int session_alloc_fifos (segment_manager_t * sm, stream_session_t * s); +void session_free (stream_session_t * s); always_inline stream_session_t * session_get (u32 si, u32 thread_index) @@ -299,7 +303,7 @@ session_get_from_handle_if_valid (session_handle_t handle) always_inline u8 session_handle_is_local (session_handle_t handle) { - if ((handle >> 32) == SESSION_LOCAL_TABLE_PREFIX) + if ((handle >> 32) == SESSION_LOCAL_HANDLE_PREFIX) return 1; return 0; } @@ -310,6 +314,12 @@ session_type_transport_proto (session_type_t st) return (st >> 1); } +always_inline u8 +session_type_is_ip4 (session_type_t st) +{ + return (st & 1); +} + always_inline transport_proto_t session_get_transport_proto (stream_session_t * s) { @@ -446,7 +456,6 @@ transport_connection_t *session_get_transport (stream_session_t * s); u32 stream_session_tx_fifo_max_dequeue (transport_connection_t * tc); -stream_session_t *session_alloc (u32 thread_index); int session_enqueue_stream_connection (transport_connection_t * tc, vlib_buffer_t * b, u32 offset, @@ -524,6 +533,13 @@ listen_session_get_from_handle (session_handle_t handle) return s; } +always_inline void +listen_session_parse_handle (session_handle_t handle, u32 * type, u32 * index) +{ + *type = handle >> 32; + *index = handle & 0xFFFFFFFF; +} + always_inline stream_session_t * listen_session_new (session_type_t type) { @@ -566,18 +582,6 @@ session_manager_get_listener (u8 session_type, u32 index) index); } -/** - * Set peek or dequeue function for given session type - * - * Reliable transport protocols will probably want to use a peek function - */ -always_inline void -session_manager_set_transport_rx_fn (session_type_t type, u8 is_peek) -{ - session_manager_main.session_tx_fns[type] = (is_peek) ? - session_tx_fifo_peek_and_snd : session_tx_fifo_dequeue_and_snd; -} - always_inline u8 session_manager_is_enabled () {