+segment_manager_properties_t *application_get_segment_manager_properties (u32
+ app_index);
+
+segment_manager_properties_t
+ * application_segment_manager_properties (application_t * app);
+
+/*
+ * Local session
+ */
+
+local_session_t *application_local_session_alloc (app_worker_t * app);
+void application_local_session_free (app_worker_t * app,
+ local_session_t * ls);
+local_session_t *application_get_local_session (app_worker_t * app,
+ u32 session_index);
+local_session_t *application_get_local_session_from_handle (session_handle_t
+ handle);
+local_session_t
+ * application_get_local_listen_session_from_handle (session_handle_t lh);
+int application_start_local_listen (application_t * server,
+ session_endpoint_cfg_t * sep,
+ session_handle_t * handle);
+int application_stop_local_listen (u32 app_index, u32 app_or_wrk,
+ session_handle_t lh);
+int application_local_session_connect (app_worker_t * client,
+ app_worker_t * server,
+ local_session_t * ls, u32 opaque);
+int application_local_session_connect_notify (local_session_t * ls);
+int application_local_session_disconnect (u32 app_or_wrk,
+ local_session_t * ls);
+int application_local_session_disconnect_w_index (u32 app_or_wrk,
+ u32 ls_index);
+void app_worker_local_sessions_free (app_worker_t * app);
+
+always_inline u32
+local_session_id (local_session_t * ls)
+{
+ ASSERT (ls->session_index < (2 << 16));
+ u32 app_or_wrk_index;
+
+ if (ls->session_state == SESSION_STATE_LISTENING)
+ {
+ ASSERT (ls->app_index < (2 << 16));
+ app_or_wrk_index = ls->app_index;
+ }
+ else
+ {
+ ASSERT (ls->app_wrk_index < (2 << 16));
+ app_or_wrk_index = ls->app_wrk_index;
+ }
+
+ return ((u32) app_or_wrk_index << 16 | (u32) ls->session_index);
+}
+
+always_inline void
+local_session_parse_id (u32 ls_id, u32 * app_or_wrk, u32 * session_index)
+{
+ *app_or_wrk = ls_id >> 16;
+ *session_index = ls_id & 0xFF;
+}
+
+always_inline void
+local_session_parse_handle (session_handle_t handle, u32 * app_or_wrk_index,
+ u32 * session_index)
+{
+ u32 bottom;
+ ASSERT ((handle >> 32) == SESSION_LOCAL_HANDLE_PREFIX);
+ bottom = (handle & 0xFFFFFFFF);
+ local_session_parse_id (bottom, app_or_wrk_index, session_index);
+}
+
+always_inline session_handle_t
+application_local_session_handle (local_session_t * ls)
+{
+ return ((u64) SESSION_LOCAL_HANDLE_PREFIX << 32)
+ | (u64) local_session_id (ls);
+}
+
+always_inline local_session_t *
+application_get_local_listen_session (application_t * app, u32 session_index)
+{
+ return pool_elt_at_index (app->local_listen_sessions, session_index);
+}
+
+always_inline local_session_t *
+application_get_local_listener_w_handle (session_handle_t handle)
+{
+ u32 server_index, session_index;
+ application_t *app;
+ local_session_parse_handle (handle, &server_index, &session_index);
+ app = application_get (server_index);
+ return application_get_local_listen_session (app, session_index);
+}
+
+always_inline u8
+application_local_session_listener_has_transport (local_session_t * ls)
+{
+ transport_proto_t tp;
+ tp = session_type_transport_proto (ls->listener_session_type);
+ return (tp != TRANSPORT_PROTO_NONE);
+}
+
+void mq_send_local_session_disconnected_cb (u32 app_or_wrk,
+ local_session_t * ls);
+
+uword unformat_application_proto (unformat_input_t * input, va_list * args);
+