diff options
author | Nathan Skrzypczak <nathan.skrzypczak@gmail.com> | 2019-11-07 17:55:01 +0100 |
---|---|---|
committer | Florin Coras <florin.coras@gmail.com> | 2019-11-12 17:50:13 +0000 |
commit | 31bd035621bdc57deb757613b534bd6c2b032814 (patch) | |
tree | 279767f3a036cd7b83bf12e91efe3d9eb8f63c3e | |
parent | 55a9dacbb81e17d81b61449cbc11ac1f9249b801 (diff) |
session: session enable in multiworker
Having session enable in config file wasn't
working for multiple workers
Type: fix
Change-Id: Ib29ba540a6e1d714e7e470f4c7518e3d266fe7ca
Signed-off-by: Nathan Skrzypczak <nathan.skrzypczak@gmail.com>
-rw-r--r-- | src/vnet/session/session.c | 17 | ||||
-rw-r--r-- | src/vnet/session/session.h | 2 |
2 files changed, 18 insertions, 1 deletions
diff --git a/src/vnet/session/session.c b/src/vnet/session/session.c index 5cd840bd834..163f4d2a6a6 100644 --- a/src/vnet/session/session.c +++ b/src/vnet/session/session.c @@ -1609,10 +1609,25 @@ session_manager_main_init (vlib_main_t * vm) smm->evt_qs_segment_size = 1 << 20; #endif smm->is_enabled = 0; + smm->session_enable_asap = 0; + return 0; +} + +static clib_error_t * +session_main_init (vlib_main_t * vm) +{ + session_main_t *smm = &session_main; + if (smm->session_enable_asap) + { + vlib_worker_thread_barrier_sync (vm); + vnet_session_enable_disable (vm, 1 /* is_en */ ); + vlib_worker_thread_barrier_release (vm); + } return 0; } VLIB_INIT_FUNCTION (session_manager_main_init); +VLIB_MAIN_LOOP_ENTER_FUNCTION (session_main_init); static clib_error_t * session_config_fn (vlib_main_t * vm, unformat_input_t * input) @@ -1694,7 +1709,7 @@ session_config_fn (vlib_main_t * vm, unformat_input_t * input) &smm->evt_qs_segment_size)) ; else if (unformat (input, "enable")) - vnet_session_enable_disable (vm, 1 /* is_en */ ); + smm->session_enable_asap = 1; else return clib_error_return (0, "unknown input `%U'", format_unformat_error, input); diff --git a/src/vnet/session/session.h b/src/vnet/session/session.h index 830a34b72e8..e239818caf9 100644 --- a/src/vnet/session/session.h +++ b/src/vnet/session/session.h @@ -166,6 +166,8 @@ typedef struct session_main_ /** Session manager is enabled */ u8 is_enabled; + /** Enable session manager at startup */ + u8 session_enable_asap; /** vpp fifo event queue configured length */ u32 configured_event_queue_length; |