22 #undef __included_bihash_template_h__ 62 }) v4_connection_key_t;
87 u16 lcl_port,
u16 rmt_port,
u8 proto)
90 kv->
key[1] = (
u64) proto << 32 | (
u64) rmt_port << 16 | (
u64) lcl_port;
99 kv->
key[1] = (
u64) proto << 32 | (
u64) lcl_port;
107 kv->
key[1] = (
u64) proto << 32;
114 make_v4_ss_kv (kv, &tc->lcl_ip.ip4, &tc->rmt_ip.ip4, tc->lcl_port,
115 tc->rmt_port, tc->proto);
120 u16 lcl_port,
u16 rmt_port,
u8 proto)
126 kv->
key[4] = (
u64) proto << 32 | (
u64) rmt_port << 16 | (
u64) lcl_port;
139 kv->
key[4] = (
u64) proto << 32 | (
u64) lcl_port;
151 kv->
key[4] = (
u64) proto << 32;
159 make_v6_ss_kv (kv, &tc->lcl_ip.ip6, &tc->rmt_ip.ip6, tc->lcl_port,
160 tc->rmt_port, tc->proto);
168 if (
vec_len (fib_index_to_table_index[fib_proto]) <= fib_index)
172 vec_validate (fib_index_to_table_index[fib_proto], fib_index);
173 fib_index_to_table_index[fib_proto][fib_index] = table_index;
174 st->active_fib_proto = fib_proto;
180 table_index = fib_index_to_table_index[fib_proto][fib_index];
197 if (
vec_len (fib_index_to_table_index[fib_proto]) <= tc->fib_index)
206 if (
vec_len (fib_index_to_table_index[fib_proto]) <= fib_index)
214 if (
vec_len (fib_index_to_table_index[fib_proto]) <= fib_index)
216 return fib_index_to_table_index[fib_proto][fib_index];
244 return clib_bihash_add_del_16_8 (&st->v4_session_hash, &kv4,
251 return clib_bihash_add_del_48_8 (&st->v6_session_hash, &kv6,
270 sep->transport_proto);
272 return clib_bihash_add_del_16_8 (&st->v4_session_hash, &kv4, 1);
277 sep->transport_proto);
279 return clib_bihash_add_del_48_8 (&st->v6_session_hash, &kv6, 1);
297 sep->transport_proto);
298 return clib_bihash_add_del_16_8 (&st->v4_session_hash, &kv4, 0);
303 sep->transport_proto);
304 return clib_bihash_add_del_48_8 (&st->v6_session_hash, &kv6, 0);
329 return clib_bihash_add_del_16_8 (&st->v4_session_hash, &kv4,
335 return clib_bihash_add_del_48_8 (&st->v6_session_hash, &kv6,
345 ts = tp_vfts[tp].get_connection (s->connection_index, s->thread_index);
361 switch (action_index)
404 u32 action_index, app_index;
420 u32 action_index, app_index;
456 sep->transport_proto);
457 rv = clib_bihash_search_inline_16_8 (&st->v4_session_hash, &kv4);
462 memset (&lcl4, 0,
sizeof (lcl4));
463 srt = &st->session_rules[sep->transport_proto];
476 sep->transport_proto);
477 rv = clib_bihash_search_inline_48_8 (&st->v6_session_hash, &kv6);
483 memset (&lcl6, 0,
sizeof (lcl6));
484 srt = &st->session_rules[sep->transport_proto];
531 memset (&lcl4, 0,
sizeof (lcl4));
532 srt = &st->session_rules[sep->transport_proto];
542 sep->transport_proto);
543 rv = clib_bihash_search_inline_16_8 (&st->v4_session_hash, &kv4);
554 rv = clib_bihash_search_inline_16_8 (&st->v4_session_hash, &kv4);
567 rv = clib_bihash_search_inline_16_8 (&st->v4_session_hash, &kv4);
576 memset (&lcl6, 0,
sizeof (lcl6));
577 srt = &st->session_rules[sep->transport_proto];
584 sep->transport_proto);
585 rv = clib_bihash_search_inline_48_8 (&st->v6_session_hash, &kv6);
595 kv6.
key[0] = kv6.
key[1] = 0;
596 rv = clib_bihash_search_inline_48_8 (&st->v6_session_hash, &kv6);
602 kv6.
key[0] = kv6.
key[1] = 0;
608 kv6.
key[4] = kv6.
key[5] = 0;
609 rv = clib_bihash_search_inline_48_8 (&st->v6_session_hash, &kv6);
618 u16 lcl_port,
u8 proto,
u8 use_wildcard)
627 rv = clib_bihash_search_inline_16_8 (&st->v4_session_hash, &kv4);
637 rv = clib_bihash_search_inline_16_8 (&st->v4_session_hash, &kv4);
650 rv = clib_bihash_search_inline_16_8 (&st->v4_session_hash, &kv4);
670 u16 lcl_port,
u8 proto,
u8 ip_wildcard)
676 rv = clib_bihash_search_inline_48_8 (&st->v6_session_hash, &kv6);
683 kv6.
key[0] = kv6.
key[1] = 0;
684 rv = clib_bihash_search_inline_48_8 (&st->v6_session_hash, &kv6);
690 kv6.
key[0] = kv6.
key[1] = 0;
694 rv = clib_bihash_search_inline_48_8 (&st->v6_session_hash, &kv6);
723 sep->transport_proto, 0);
726 sep->transport_proto, 0);
744 return clib_bihash_add_del_16_8 (&st->v4_half_open_hash, &kv4,
751 return clib_bihash_add_del_48_8 (&st->v6_half_open_hash, &kv6,
769 return clib_bihash_add_del_16_8 (&st->v4_half_open_hash, &kv4,
775 return clib_bihash_add_del_48_8 (&st->v6_half_open_hash, &kv6,
794 make_v4_ss_kv (&kv4, &tc->lcl_ip.ip4, &tc->rmt_ip.ip4, tc->lcl_port,
795 tc->rmt_port, tc->proto);
796 rv = clib_bihash_search_inline_16_8 (&st->v4_half_open_hash, &kv4);
802 make_v6_ss_kv (&kv6, &tc->lcl_ip.ip6, &tc->rmt_ip.ip6, tc->lcl_port,
803 tc->rmt_port, tc->proto);
804 rv = clib_bihash_search_inline_48_8 (&st->v6_half_open_hash, &kv6);
819 return tp_vfts[sst].get_half_open (handle & 0xFFFFFFFF);
853 u16 rmt_port,
u8 proto,
u32 thread_index,
870 rv = clib_bihash_search_inline_16_8 (&st->v4_session_hash, &kv4);
875 return tp_vfts[proto].get_connection (s->connection_index,
882 rv = clib_bihash_search_inline_16_8 (&st->v4_half_open_hash, &kv4);
884 return tp_vfts[proto].get_half_open (kv4.
value & 0xFFFFFFFF);
890 rmt, lcl_port, rmt_port);
897 return tp_vfts[proto].get_listener (s->connection_index);
906 return tp_vfts[proto].get_listener (s->connection_index);
946 rv = clib_bihash_search_inline_16_8 (&st->v4_session_hash, &kv4);
950 return tp_vfts[proto].get_connection (s->connection_index,
957 rv = clib_bihash_search_inline_16_8 (&st->v4_half_open_hash, &kv4);
959 return tp_vfts[proto].get_half_open (kv4.
value & 0xFFFFFFFF);
965 rmt, lcl_port, rmt_port);
972 return tp_vfts[proto].get_listener (s->connection_index);
981 return tp_vfts[proto].get_listener (s->connection_index);
1001 u16 lcl_port,
u16 rmt_port,
u8 proto)
1017 rv = clib_bihash_search_inline_16_8 (&st->v4_session_hash, &kv4);
1025 rmt, lcl_port, rmt_port);
1071 u16 rmt_port,
u8 proto,
u32 thread_index,
1085 rv = clib_bihash_search_inline_48_8 (&st->v6_session_hash, &kv6);
1090 return tp_vfts[proto].get_connection (s->connection_index,
1095 rv = clib_bihash_search_inline_48_8 (&st->v6_half_open_hash, &kv6);
1097 return tp_vfts[proto].get_half_open (kv6.
value & 0xFFFFFFFF);
1101 rmt, lcl_port, rmt_port);
1108 return tp_vfts[proto].get_listener (s->connection_index);
1115 return tp_vfts[proto].get_listener (s->connection_index);
1152 rv = clib_bihash_search_inline_48_8 (&st->v6_session_hash, &kv6);
1156 return tp_vfts[proto].get_connection (s->connection_index,
1161 rv = clib_bihash_search_inline_48_8 (&st->v6_half_open_hash, &kv6);
1163 return tp_vfts[proto].get_half_open (kv6.
value & 0xFFFFFFFF);
1167 rmt, lcl_port, rmt_port);
1174 return tp_vfts[proto].get_listener (s->connection_index);
1181 return tp_vfts[proto].get_listener (s->connection_index);
1201 u16 lcl_port,
u16 rmt_port,
u8 proto)
1214 rv = clib_bihash_search_inline_48_8 (&st->v6_session_hash, &kv6);
1220 rmt, lcl_port, rmt_port);
1248 if (args->scope > 3)
1254 "invalid transport proto");
1257 fib_proto = args->table_args.rmt.fp_proto;
1260 srt = &st->session_rules[args->transport_proto];
1269 memset (&args->table_args.lcl, 0, sizeof (args->table_args.lcl));
1270 args->table_args.lcl.fp_proto = args->table_args.rmt.fp_proto;
1271 args->table_args.lcl_port = 0;
1273 srt = &st->session_rules[args->transport_proto];
1289 for (fp = 0; fp <
ARRAY_LEN (fib_index_to_table_index); fp++)
1302 u32 is_local = va_arg (*args,
u32);
1303 u8 *app_name, *str = 0;
1305 v4_connection_key_t *key = (v4_connection_key_t *) kvp->
key;
1314 &key->dst, clib_net_to_host_u16 (key->dst_port));
1315 s =
format (s,
"%-40v%-30v", str, app_name);
1322 clib_net_to_host_u16 (key->src_port));
1323 s =
format (s,
"%-30v%-30v", str, app_name);
1329 typedef struct _ip4_session_table_show_ctx_t
1346 u8 type,
u8 is_local)
1350 .is_local = is_local,
1372 u32 proto = ~0, lcl_port, rmt_port, action = 0, lcl_plen = 0, rmt_plen = 0;
1373 u32 appns_index, scope = 0;
1374 ip46_address_t lcl_ip, rmt_ip;
1375 u8 is_ip4 = 1, conn_set = 0;
1376 u8 fib_proto, is_add = 1, *ns_id = 0;
1381 memset (&lcl_ip, 0,
sizeof (lcl_ip));
1382 memset (&rmt_ip, 0,
sizeof (rmt_ip));
1389 else if (
unformat (input,
"appns %_%v%_", &ns_id))
1391 else if (
unformat (input,
"scope global"))
1393 else if (
unformat (input,
"scope local"))
1395 else if (
unformat (input,
"scope all"))
1400 &lcl_ip.ip4, &lcl_plen, &lcl_port,
1408 &lcl_ip.ip6, &lcl_plen, &lcl_port,
1415 else if (
unformat (input,
"action %d", &action))
1417 else if (
unformat (input,
"tag %_%v%_", &tag))
1429 if (is_add && !conn_set && action == ~0)
1434 if (!is_add && !tag && !conn_set)
1462 .table_args.lcl.fp_addr = lcl_ip,
1463 .table_args.lcl.fp_len = lcl_plen,
1464 .table_args.lcl.fp_proto = fib_proto,
1465 .table_args.rmt.fp_addr = rmt_ip,
1466 .table_args.rmt.fp_len = rmt_plen,
1467 .table_args.rmt.fp_proto = fib_proto,
1468 .table_args.lcl_port = lcl_port,
1469 .table_args.rmt_port = rmt_port,
1470 .table_args.action_index = action,
1471 .table_args.is_add = is_add,
1472 .table_args.tag = tag,
1473 .appns_index = appns_index,
1484 .path =
"session rule",
1485 .short_help =
"session rule [add|del] appns <ns_id> proto <proto> " 1486 "<lcl-ip/plen> <lcl-port> <rmt-ip/plen> <rmt-port> action <action>",
1499 srt = &st->session_rules[transport_proto];
1511 srt = &st->session_rules[transport_proto];
1519 u32 transport_proto = ~0, lcl_port, rmt_port, lcl_plen, rmt_plen;
1520 u32 fib_index, scope = 0;
1521 ip46_address_t lcl_ip, rmt_ip;
1522 u8 is_ip4 = 1, show_one = 0;
1526 u8 *ns_id = 0, fib_proto;
1528 memset (&lcl_ip, 0,
sizeof (lcl_ip));
1529 memset (&rmt_ip, 0,
sizeof (rmt_ip));
1534 else if (
unformat (input,
"appns %_%v%_", &ns_id))
1536 else if (
unformat (input,
"scope global"))
1538 else if (
unformat (input,
"scope local"))
1541 &lcl_ip.ip4, &lcl_plen, &lcl_port,
1549 &lcl_ip.ip6, &lcl_plen, &lcl_port,
1561 if (transport_proto == ~0)
1581 if (scope == 1 || scope == 0)
1584 fib_index = is_ip4 ? app_ns->ip4_fib_index : app_ns->ip6_fib_index;
1594 srt = &st->session_rules[transport_proto];
1602 srt = &st->session_rules[transport_proto];
1613 .path =
"show session rules",
1614 .short_help =
"show session rules [<proto> appns <id> <lcl-ip/plen> " 1615 "<lcl-port> <rmt-ip/plen> <rmt-port> scope <scope>]",
#define vec_validate(V, I)
Make sure vector is long enough for given index (no header, unspecified alignment) ...
#define SESSION_DROP_HANDLE
stream_session_t * session_lookup_listener6(u32 fib_index, ip6_address_t *lcl, u16 lcl_port, u8 proto)
int session_lookup_del_connection(transport_connection_t *tc)
Delete transport connection from session table.
static session_table_t * session_table_get_or_alloc_for_connection(transport_connection_t *tc)
session_table_t * session_table_alloc(void)
void session_lookup_show_table_entries(vlib_main_t *vm, session_table_t *table, u8 type, u8 is_local)
#define SESSION_RULES_TABLE_ACTION_DROP
u8 * format_transport_proto_short(u8 *s, va_list *args)
clib_bihash_kv_48_8_t session_kv6_t
void session_rules_table_cli_dump(vlib_main_t *vm, session_rules_table_t *srt, u8 fib_proto)
#define SESSION_TABLE_INVALID_INDEX
u64 session_lookup_endpoint_listener(u32 table_index, session_endpoint_t *sep, u8 use_rules)
Lookup listener for session endpoint in table.
static clib_error_t * session_rule_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
static session_table_t * session_table_get_for_fib_index(u32 fib_proto, u32 fib_index)
struct _session_rules_table_t session_rules_table_t
struct _transport_connection transport_connection_t
clib_error_t * session_rules_table_add_del(session_rules_table_t *srt, session_rule_table_add_del_args_t *args)
Add/delete session rule.
static u8 session_lookup_action_index_is_valid(u32 action_index)
u32 app_namespace_index(app_namespace_t *app_ns)
stream_session_t * session_lookup_rules_table_session4(session_table_t *st, u8 proto, ip4_address_t *lcl, u16 lcl_port, ip4_address_t *rmt, u16 rmt_port)
UNUSED.
stream_session_t * session_lookup_listener4(u32 fib_index, ip4_address_t *lcl, u16 lcl_port, u8 proto)
void session_lookup_set_tables_appns(app_namespace_t *app_ns)
Mark (global) tables as pertaining to app ns.
static clib_error_t * show_session_rules_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
u32 session_lookup_get_index_for_fib(u32 fib_proto, u32 fib_index)
struct _transport_proto_vft transport_proto_vft_t
int session_lookup_del_session(stream_session_t *s)
u32 session_rules_table_lookup4(session_rules_table_t *srt, ip4_address_t *lcl_ip, ip4_address_t *rmt_ip, u16 lcl_port, u16 rmt_port)
static void make_v6_listener_kv(session_kv6_t *kv, ip6_address_t *lcl, u16 lcl_port, u8 proto)
static stream_session_t * session_get_from_handle(session_handle_t handle)
u64 session_lookup_half_open_handle(transport_connection_t *tc)
static void make_v6_ss_kv_from_tc(session_kv6_t *kv, transport_connection_t *tc)
stream_session_t * session_lookup_listener(u32 table_index, session_endpoint_t *sep)
Lookup listener, exact or proxy (inaddr_any:0) match.
static stream_session_t * session_lookup_listener6_i(session_table_t *st, ip6_address_t *lcl, u16 lcl_port, u8 proto, u8 ip_wildcard)
transport_connection_t * session_lookup_connection6(u32 fib_index, ip6_address_t *lcl, ip6_address_t *rmt, u16 lcl_port, u16 rmt_port, u8 proto)
Lookup connection with ip6 and transport layer information.
#define SESSION_INVALID_INDEX
clib_error_t * vnet_session_rule_add_del(session_rule_add_del_args_t *args)
transport_proto_vft_t * tp_vfts
Generate typed init functions for multiple hash table styles...
static void make_v6_ss_kv(session_kv6_t *kv, ip6_address_t *lcl, ip6_address_t *rmt, u16 lcl_port, u16 rmt_port, u8 proto)
static stream_session_t * listen_session_get(u32 index)
#define clib_error_return(e, args...)
static int ip4_session_table_show(clib_bihash_kv_16_8_t *kvp, void *arg)
static void make_v6_proxy_kv(session_kv6_t *kv, ip6_address_t *lcl, u8 proto)
struct _stream_session_t stream_session_t
int session_lookup_del_half_open(transport_connection_t *tc)
transport_connection_t * session_lookup_connection4(u32 fib_index, ip4_address_t *lcl, ip4_address_t *rmt, u16 lcl_port, u16 rmt_port, u8 proto)
Lookup connection with ip4 and transport layer information.
static transport_proto_t session_get_transport_proto(stream_session_t *s)
void session_table_init(session_table_t *slt, u8 fib_proto)
Initialize session table hash tables.
u32 app_namespace_get_fib_index(app_namespace_t *app_ns, u8 fib_proto)
struct _session_endpoint session_endpoint_t
struct _session_rule_add_del_args session_rule_add_del_args_t
void session_lookup_dump_rules_table(u32 fib_index, u8 fib_proto, u8 transport_proto)
static app_namespace_t * app_namespace_get_default(void)
stream_session_t * session_lookup_safe6(u32 fib_index, ip6_address_t *lcl, ip6_address_t *rmt, u16 lcl_port, u16 rmt_port, u8 proto)
Lookup session with ip6 and transport layer information.
stream_session_t * application_first_listener(application_t *app, u8 fib_proto, u8 transport_proto)
app_namespace_t * app_namespace_get(u32 index)
u8 * application_name_from_index(u32 app_index)
Returns app name.
static stream_session_t * session_get(u32 si, u32 thread_index)
u32 session_rules_table_lookup6(session_rules_table_t *srt, ip6_address_t *lcl_ip, ip6_address_t *rmt_ip, u16 lcl_port, u16 rmt_port)
u64 session_lookup_local_endpoint(u32 table_index, session_endpoint_t *sep)
Look up endpoint in local session table.
static session_table_t * session_table_get_for_connection(transport_connection_t *tc)
static stream_session_t * session_lookup_listener4_i(session_table_t *st, ip4_address_t *lcl, u16 lcl_port, u8 proto, u8 use_wildcard)
static session_type_t session_type_from_proto_and_ip(transport_proto_t proto, u8 is_ip4)
static u32 * fib_index_to_table_index[2]
Network namespace index (i.e., fib index) to session lookup table.
#define SESSION_RULES_TABLE_INVALID_INDEX
session_table_t * app_namespace_get_local_table(app_namespace_t *app_ns)
#define vec_free(V)
Free vector's memory (no header).
int session_lookup_del_session_endpoint(u32 table_index, session_endpoint_t *sep)
static stream_session_t * session_get_from_handle_safe(u64 handle)
Get session from handle and 'lock' pool resize if not in same thread.
#define clib_warning(format, args...)
stream_session_t * session_lookup_safe4(u32 fib_index, ip4_address_t *lcl, ip4_address_t *rmt, u16 lcl_port, u16 rmt_port, u8 proto)
Lookup session with ip4 and transport layer information.
#define SESSION_INVALID_HANDLE
u8 ip4_is_local_host(ip4_address_t *ip4_address)
static u8 transport_connection_fib_proto(transport_connection_t *tc)
u8 ip6_is_local_host(ip6_address_t *ip6_address)
struct _application application_t
int session_lookup_add_session_endpoint(u32 table_index, session_endpoint_t *sep, u64 value)
struct _app_namespace app_namespace_t
#define VLIB_CLI_COMMAND(x,...)
transport_connection_t * session_lookup_connection_wt4(u32 fib_index, ip4_address_t *lcl, ip4_address_t *rmt, u16 lcl_port, u16 rmt_port, u8 proto, u32 thread_index, u8 *is_filtered)
Lookup connection with ip4 and transport layer information.
session_table_t * session_table_get(u32 table_index)
static void make_v4_proxy_kv(session_kv4_t *kv, ip4_address_t *lcl, u8 proto)
struct _ip4_session_table_show_ctx_t ip4_session_table_show_ctx_t
static stream_session_t * session_lookup_action_to_session(u32 action_index, u8 fib_proto, u8 transport_proto)
uword unformat_transport_proto(unformat_input_t *input, va_list *args)
static stream_session_t * session_lookup_app_listen_session(u32 app_index, u8 fib_proto, u8 transport_proto)
static u64 session_lookup_action_to_handle(u32 action_index)
void ip4_session_table_walk(clib_bihash_16_8_t *hash, ip4_session_table_walk_fn_t fn, void *arg)
#define clib_error_report(e)
#define SESSION_RULES_TABLE_ACTION_ALLOW
typedef CLIB_PACKED(struct{union{struct{ip4_address_t src;ip4_address_t dst;u16 src_port;u16 dst_port;u32 proto;};u64 as_u64[2];};})
transport_connection_t * session_lookup_connection_wt6(u32 fib_index, ip6_address_t *lcl, ip6_address_t *rmt, u16 lcl_port, u16 rmt_port, u8 proto, u32 thread_index, u8 *is_filtered)
Lookup connection with ip6 and transport layer information.
static void make_v4_listener_kv(session_kv4_t *kv, ip4_address_t *lcl, u16 lcl_port, u8 proto)
static vlib_main_t * vlib_get_main(void)
#define HALF_OPEN_LOOKUP_INVALID_VALUE
void session_rules_table_show_rule(vlib_main_t *vm, session_rules_table_t *srt, ip46_address_t *lcl_ip, u16 lcl_port, ip46_address_t *rmt_ip, u16 rmt_port, u8 is_ip4)
u8 * format_ip4_session_lookup_kvp(u8 *s, va_list *args)
#define SESSION_RULE_TAG_MAX_LEN
enum _transport_proto transport_proto_t
void session_lookup_init(void)
#define vec_len(v)
Number of elements in vector (rvalue-only, NULL tolerant)
void session_lookup_dump_local_rules_table(u32 table_index, u8 fib_proto, u8 transport_proto)
struct _session_lookup_table session_table_t
static session_table_t * session_table_get_or_alloc(u8 fib_proto, u8 fib_index)
int session_lookup_add_connection(transport_connection_t *tc, u64 value)
Add transport connection to a session table.
u32 session_table_index(session_table_t *slt)
#define clib_error_return_code(e, code, flags, args...)
static void make_v4_ss_kv(session_kv4_t *kv, ip4_address_t *lcl, ip4_address_t *rmt, u16 lcl_port, u16 rmt_port, u8 proto)
app_namespace_t * app_namespace_get_from_id(const u8 *ns_id)
int session_lookup_add_half_open(transport_connection_t *tc, u64 value)
void vlib_cli_output(vlib_main_t *vm, char *fmt,...)
stream_session_t * session_lookup_rules_table_session6(session_table_t *st, u8 proto, ip6_address_t *lcl, u16 lcl_port, ip6_address_t *rmt, u16 rmt_port)
UNUSED.
u8 * format_transport_proto(u8 *s, va_list *args)
static void make_v4_ss_kv_from_tc(session_kv4_t *kv, transport_connection_t *tc)
application_t * application_get_if_valid(u32 index)
transport_connection_t * session_lookup_half_open_connection(u64 handle, u8 proto, u8 is_ip4)
clib_bihash_kv_16_8_t session_kv4_t