X-Git-Url: https://gerrit.fd.io/r/gitweb?a=blobdiff_plain;f=src%2Fvnet%2Fsession%2Fsession_table.c;h=47d19092e2b3d98caf2401258ffbff308e5dddf4;hb=993683150202254c6ba8dd43e087a7229edd5d4c;hp=04c0c816ab0c3088dbaaf65f5a36f65da8f2a420;hpb=cea194d8f973a2f2b5ef72d212533057174cc70a;p=vpp.git diff --git a/src/vnet/session/session_table.c b/src/vnet/session/session_table.c index 04c0c816ab0..47d19092e2b 100644 --- a/src/vnet/session/session_table.c +++ b/src/vnet/session/session_table.c @@ -21,6 +21,12 @@ */ static session_table_t *lookup_tables; +session_table_t * +_get_session_tables (void) +{ + return lookup_tables; +} + session_table_t * session_table_alloc (void) { @@ -39,9 +45,9 @@ session_table_index (session_table_t * slt) session_table_t * session_table_get (u32 table_index) { - if (vec_len (lookup_tables) <= table_index) + if (pool_is_free_index (lookup_tables, table_index)) return 0; - return vec_elt_at_index (lookup_tables, table_index); + return pool_elt_at_index (lookup_tables, table_index); } #define foreach_hash_table_parameter \ @@ -61,8 +67,11 @@ session_table_get (u32 table_index) * otherwise it uses defaults above. */ void -session_table_init (session_table_t * slt) +session_table_init (session_table_t * slt, u8 fib_proto) { + u8 all = fib_proto > FIB_PROTOCOL_IP6 ? 1 : 0; + int i; + #define _(af,table,parm,value) \ u32 configured_##af##_##table##_table_##parm = value; foreach_hash_table_parameter; @@ -75,18 +84,27 @@ session_table_init (session_table_t * slt) foreach_hash_table_parameter; #undef _ - clib_bihash_init_16_8 (&slt->v4_session_hash, "v4 session table", - configured_v4_session_table_buckets, - configured_v4_session_table_memory); - clib_bihash_init_48_8 (&slt->v6_session_hash, "v6 session table", - configured_v6_session_table_buckets, - configured_v6_session_table_memory); - clib_bihash_init_16_8 (&slt->v4_half_open_hash, "v4 half-open table", - configured_v4_halfopen_table_buckets, - configured_v4_halfopen_table_memory); - clib_bihash_init_48_8 (&slt->v6_half_open_hash, "v6 half-open table", - configured_v6_halfopen_table_buckets, - configured_v6_halfopen_table_memory); + if (fib_proto == FIB_PROTOCOL_IP4 || all) + { + clib_bihash_init_16_8 (&slt->v4_session_hash, "v4 session table", + configured_v4_session_table_buckets, + configured_v4_session_table_memory); + clib_bihash_init_16_8 (&slt->v4_half_open_hash, "v4 half-open table", + configured_v4_halfopen_table_buckets, + configured_v4_halfopen_table_memory); + } + if (fib_proto == FIB_PROTOCOL_IP6 || all) + { + clib_bihash_init_48_8 (&slt->v6_session_hash, "v6 session table", + configured_v6_session_table_buckets, + configured_v6_session_table_memory); + clib_bihash_init_48_8 (&slt->v6_half_open_hash, "v6 half-open table", + configured_v6_halfopen_table_buckets, + configured_v6_halfopen_table_memory); + } + + for (i = 0; i < TRANSPORT_N_PROTO; i++) + session_rules_table_init (&slt->session_rules[i]); } typedef struct _ip4_session_table_walk_ctx_t