29 #define UNSUPPORTED_IN_ED_MODE_STR \ 30 "This command is unsupported in endpoint dependent mode" 31 #define SUPPORTED_ONLY_IN_ED_MODE_STR \ 32 "This command is supported only in endpoint dependent mode" 49 if (
unformat (line_input,
"%U", unformat_bitmap_list, &bitmap))
71 case VNET_API_ERROR_INVALID_WORKER:
74 case VNET_API_ERROR_FEATURE_DISABLED:
76 "Supported only if 2 or more workes available.");
125 if (!
unformat (line_input,
"%d", &log_level))
131 if (log_level > SNAT_LOG_DEBUG)
168 if (
unformat (line_input,
"domain %d", &domain_id))
170 else if (
unformat (line_input,
"src-port %d", &src_port))
172 else if (
unformat (line_input,
"disable"))
208 else if (
unformat (input,
"verbose"))
261 u32 psid, psid_offset, psid_length, port_start, port_end;
269 if (
unformat (line_input,
"default"))
273 (line_input,
"map-e psid %d psid-offset %d psid-len %d", &psid,
274 &psid_offset, &psid_length))
279 (line_input,
"port-range %d - %d", &port_start, &port_end))
281 if (port_end <= port_start)
285 "The end-port must be greater than start-port");
317 case NAT_ADDR_AND_PORT_ALLOC_ALG_MAPE:
321 case NAT_ADDR_AND_PORT_ALLOC_ALG_RANGE:
347 if (
unformat (line_input,
"disable"))
349 else if (
unformat (line_input,
"%d", &mss))
385 u32 port, session_refresh_interval = 10;
399 (line_input,
"refresh-interval %u", &session_refresh_interval))
437 else if (
unformat (line_input,
"path-mtu %u", &path_mtu))
463 u32 path_mtu, session_refresh_interval, resync_ack_missed;
482 session_refresh_interval);
491 vlib_cli_output (vm,
" completed (%d ACK missed)\n", resync_ack_missed);
523 u32 start_host_order, end_host_order;
537 if (
unformat (line_input,
"%U - %U",
541 else if (
unformat (line_input,
"tenant-vrf %u", &vrf_id))
545 else if (
unformat (line_input,
"twice-nat"))
547 else if (
unformat (line_input,
"del"))
563 start_host_order = clib_host_to_net_u32 (start_addr.
as_u32);
564 end_host_order = clib_host_to_net_u32 (end_addr.
as_u32);
566 if (end_host_order < start_host_order)
572 count = (end_host_order - start_host_order) + 1;
581 for (i = 0; i <
count; i++)
590 case VNET_API_ERROR_VALUE_EXIST:
593 case VNET_API_ERROR_NO_SUCH_ENTRY:
596 case VNET_API_ERROR_UNSPECIFIED:
600 case VNET_API_ERROR_FEATURE_DISABLED:
603 "twice NAT available only for endpoint-dependent mode.");
623 u64 now,
u64 sess_timeout_time)
632 clib_dlist_remove_head (tsm->lru_pool, tsm->n##_lru_head_index); \ 633 if (~0 != oldest_index) \ 635 oldest_elt = pool_elt_at_index (tsm->lru_pool, oldest_index); \ 636 s = pool_elt_at_index (tsm->sessions, oldest_elt->value); \ 637 sess_timeout_time = \ 638 s->last_heard + (f64)nat44_session_get_timeout (sm, s); \ 639 vlib_cli_output (vm, d " LRU min session timeout %llu (now %llu)", \ 640 sess_timeout_time, now); \ 641 clib_dlist_addhead (tsm->lru_pool, tsm->n##_lru_head_index, \ 644 _(tcp_estab,
"established tcp");
645 _(tcp_trans,
"transitory tcp");
647 _(unk_proto,
"unknown protocol");
666 u64 sess_timeout_time;
668 u32 udp_sessions = 0;
669 u32 tcp_sessions = 0;
670 u32 icmp_sessions = 0;
674 u32 transitory_wait_closed = 0;
675 u32 transitory_closed = 0;
691 sess_timeout_time = s->last_heard +
692 (f64) nat44_session_get_timeout (sm, s);
693 if (now >= sess_timeout_time)
696 switch (s->nat_proto)
698 case NAT_PROTOCOL_ICMP:
701 case NAT_PROTOCOL_TCP:
705 if (s->tcp_closed_timestamp)
707 if (now >= s->tcp_closed_timestamp)
713 ++transitory_wait_closed;
721 case NAT_PROTOCOL_UDP:
738 sess_timeout_time = s->last_heard +
739 (f64) nat44_session_get_timeout (sm, s);
740 if (now >= sess_timeout_time)
743 switch (s->nat_proto)
745 case NAT_PROTOCOL_ICMP:
748 case NAT_PROTOCOL_TCP:
752 if (s->tcp_closed_timestamp)
754 if (now >= s->tcp_closed_timestamp)
760 ++transitory_wait_closed;
768 case NAT_PROTOCOL_UDP:
785 transitory_wait_closed);
810 #define _(N, i, n, s) \ 811 vlib_cli_output (vm, " %d busy %s ports", ap->busy_##n##_ports, s); 824 #define _(N, i, n, s) \ 825 vlib_cli_output (vm, " %d busy %s ports", ap->busy_##n##_ports, s); 841 u32 *inside_sw_if_indices = 0;
842 u32 *outside_sw_if_indices = 0;
843 u8 is_output_feature = 0;
857 vec_add1 (inside_sw_if_indices, sw_if_index);
860 vec_add1 (outside_sw_if_indices, sw_if_index);
861 else if (
unformat (line_input,
"output-feature"))
862 is_output_feature = 1;
863 else if (
unformat (line_input,
"del"))
873 if (
vec_len (inside_sw_if_indices))
875 for (i = 0; i <
vec_len (inside_sw_if_indices); i++)
877 sw_if_index = inside_sw_if_indices[
i];
878 if (is_output_feature)
881 (sw_if_index, 1, is_del))
884 is_del ?
"del" :
"add",
895 is_del ?
"del" :
"add",
904 if (
vec_len (outside_sw_if_indices))
906 for (i = 0; i <
vec_len (outside_sw_if_indices); i++)
908 sw_if_index = outside_sw_if_indices[
i];
909 if (is_output_feature)
912 (sw_if_index, 0, is_del))
915 is_del ?
"del" :
"add",
926 is_del ?
"del" :
"add",
955 vlib_cli_output (vm,
" %U %s", format_vnet_sw_if_index_name, vnm,
957 (nat_interface_is_inside(i) &&
958 nat_interface_is_outside(i)) ?
"in out" :
959 (nat_interface_is_inside(i) ?
"in" :
"out"));
964 vlib_cli_output (vm,
" %U output-feature %s",
965 format_vnet_sw_if_index_name, vnm,
967 (nat_interface_is_inside(i) &&
968 nat_interface_is_outside(i)) ?
"in out" :
969 (nat_interface_is_inside(i) ?
"in" :
"out"));
985 int is_add = 1, addr_only = 1, rv, exact = 0;
1011 else if (
unformat (line_input,
"external %U %u",
1015 else if (
unformat (line_input,
"external %U",
1025 else if (
unformat (line_input,
"twice-nat"))
1027 else if (
unformat (line_input,
"self-twice-nat"))
1029 else if (
unformat (line_input,
"out2in-only"))
1031 else if (
unformat (line_input,
"del"))
1041 if (twice_nat && addr_only)
1053 "address only mapping doesn't support protocol");
1057 else if (!proto_set)
1064 clib_host_to_net_u16 (e_port),
1065 vrf_id, addr_only, sw_if_index, proto, is_add,
1066 twice_nat, out2in_only, 0, 0, exact_addr,
1071 case VNET_API_ERROR_INVALID_VALUE:
1074 case VNET_API_ERROR_NO_SUCH_ENTRY:
1080 case VNET_API_ERROR_NO_SUCH_FIB:
1083 case VNET_API_ERROR_VALUE_EXIST:
1086 case VNET_API_ERROR_FEATURE_DISABLED:
1089 "twice-nat/out2in-only available only for endpoint-dependent mode.");
1127 else if (
unformat (line_input,
"external %U",
1135 else if (
unformat (line_input,
"del"))
1147 clib_host_to_net_u16 (port),
vrf_id, addr_only,
1148 sw_if_index, proto, is_add, 0, 0, 0, 1,
1153 case VNET_API_ERROR_INVALID_VALUE:
1156 case VNET_API_ERROR_NO_SUCH_ENTRY:
1162 case VNET_API_ERROR_NO_SUCH_FIB:
1165 case VNET_API_ERROR_VALUE_EXIST:
1201 if (
unformat (line_input,
"local %U:%u probability %u",
1205 local.addr = l_addr;
1206 local.port = (
u16) l_port;
1210 else if (
unformat (line_input,
"local %U:%u vrf %u probability %u",
1215 local.addr = l_addr;
1216 local.port = (
u16) l_port;
1227 else if (
unformat (line_input,
"twice-nat"))
1229 else if (
unformat (line_input,
"self-twice-nat"))
1231 else if (
unformat (line_input,
"out2in-only"))
1233 else if (
unformat (line_input,
"del"))
1235 else if (
unformat (line_input,
"affinity %u", &affinity))
1258 is_add, twice_nat, out2in_only, 0,
1263 case VNET_API_ERROR_INVALID_VALUE:
1266 case VNET_API_ERROR_NO_SUCH_ENTRY:
1272 case VNET_API_ERROR_VALUE_EXIST:
1275 case VNET_API_ERROR_FEATURE_DISABLED:
1309 if (
unformat (line_input,
"local %U:%u probability %u",
1312 else if (
unformat (line_input,
"local %U:%u vrf %u probability %u",
1322 else if (
unformat (line_input,
"del"))
1332 if (!l_port || !e_port)
1351 case VNET_API_ERROR_INVALID_VALUE:
1355 case VNET_API_ERROR_NO_SUCH_ENTRY:
1358 case VNET_API_ERROR_VALUE_EXIST:
1361 case VNET_API_ERROR_FEATURE_DISABLED:
1365 case VNET_API_ERROR_UNSPECIFIED:
1391 vlib_cli_output (vm,
" %U", format_snat_static_mapping, m);
1422 else if (
unformat (line_input,
"twice-nat"))
1424 else if (
unformat (line_input,
"del"))
1498 if (
unformat (line_input,
"detail"))
1529 vlib_cli_output (vm,
" %U", format_snat_user, tsm, u, detail);
1537 vlib_cli_output (vm,
" %U\n", format_snat_session, tsm, s);
1561 if (
unformat (line_input,
"%u", &session_limit))
1606 else if (
unformat (line_input,
"fib %u", &fib_index))
1646 int is_in = 0, is_ed = 0;
1663 else if (
unformat (line_input,
"in"))
1668 else if (
unformat (line_input,
"out"))
1678 &eh_addr, &eh_port))
1691 clib_host_to_net_u16 (eh_port),
1721 u8 forwarding_enable;
1722 u8 forwarding_enable_set = 0;
1731 if (!forwarding_enable_set &&
unformat (line_input,
"enable"))
1733 forwarding_enable = 1;
1734 forwarding_enable_set = 1;
1736 else if (!forwarding_enable_set &&
unformat (line_input,
"disable"))
1738 forwarding_enable = 0;
1739 forwarding_enable_set = 1;
1749 if (!forwarding_enable_set)
1785 else if (
unformat (line_input,
"tcp-established %u",
1793 "Invalid TCP established timeouts value");
1797 else if (
unformat (line_input,
"tcp-transitory %u",
1805 "Invalid TCP transitory timeouts value");
1817 else if (
unformat (line_input,
"reset"))
1871 if (
unformat (line_input,
"%u", &fib))
1893 per_vrf_sessions_t *per_vrf_sessions;
1902 per_vrf_sessions->rx_fib_index,
1903 per_vrf_sessions->tx_fib_index,
1904 per_vrf_sessions->ses_count,
1905 per_vrf_sessions->expired ?
"expired" :
"");
1916 .path =
"debug nat44 fib expire",
1917 .short_help =
"debug nat44 fib expire <fib-index>",
1924 .path =
"debug nat44 fib registration",
1925 .short_help =
"debug nat44 fib registration",
1937 .path =
"set nat workers",
1939 .short_help =
"set nat workers <workers-list>",
1953 .path =
"show nat workers",
1954 .short_help =
"show nat workers",
1968 .path =
"set nat timeout",
1971 "set nat timeout [udp <sec> | tcp-established <sec> " 1972 "tcp-transitory <sec> | icmp <sec> | reset]",
1987 .path =
"show nat timeouts",
1988 .short_help =
"show nat timeouts",
2000 .path =
"nat set logging level",
2002 .short_help =
"nat set logging level <level>",
2015 .path =
"nat ipfix logging",
2017 .short_help =
"nat ipfix logging [domain <domain-id>] [src-port <port>] [disable]",
2033 .path =
"nat addr-port-assignment-alg",
2034 .short_help =
"nat addr-port-assignment-alg <alg-name> [<alg-params>]",
2045 .path =
"show nat addr-port-assignment-alg",
2046 .short_help =
"show nat addr-port-assignment-alg",
2061 .path =
"nat mss-clamping",
2062 .short_help =
"nat mss-clamping <mss-value>|disable",
2073 .path =
"show nat mss-clamping",
2074 .short_help =
"show nat mss-clamping",
2085 .path =
"nat ha failover",
2086 .short_help =
"nat ha failover <ip4-address>:<port> [refresh-interval <sec>]",
2097 .path =
"nat ha listener",
2098 .short_help =
"nat ha listener <ip4-address>:<port> [path-mtu <path-mtu>]",
2109 .path =
"show nat ha",
2110 .short_help =
"show nat ha",
2121 .path =
"nat ha flush",
2122 .short_help =
"nat ha flush",
2133 .path =
"nat ha resync",
2134 .short_help =
"nat ha resync",
2145 .path =
"show nat44 hash tables",
2146 .short_help =
"show nat44 hash tables [detail|verbose]",
2162 .path =
"nat44 add address",
2163 .short_help =
"nat44 add address <ip4-range-start> [- <ip4-range-end>] " 2164 "[tenant-vrf <vrf-id>] [twice-nat] [del]",
2176 .path =
"show nat44 summary",
2177 .short_help =
"show nat44 summary",
2206 .path =
"show nat44 addresses",
2207 .short_help =
"show nat44 addresses",
2222 .path =
"set interface nat44",
2224 .short_help =
"set interface nat44 in <intfc> out <intfc> [output-feature] " 2239 .path =
"show nat44 interfaces",
2240 .short_help =
"show nat44 interfaces",
2264 .path =
"nat44 add static mapping",
2267 "nat44 add static mapping tcp|udp|icmp local <addr> [<port|icmp-echo-id>] " 2268 "external <addr> [<port|icmp-echo-id>] [vrf <table-id>] [twice-nat|self-twice-nat] " 2269 "[out2in-only] [exact <pool-addr>] [del]",
2286 .path =
"nat44 add identity mapping",
2288 .short_help =
"nat44 add identity mapping <ip4-addr>|external <interface> " 2289 "[<protocol> <port>] [vrf <table-id>] [del]",
2303 .path =
"nat44 add load-balancing static mapping",
2306 "nat44 add load-balancing static mapping protocol tcp|udp " 2307 "external <addr>:<port> local <addr>:<port> [vrf <table-id>] " 2308 "probability <n> [twice-nat|self-twice-nat] [out2in-only] " 2309 "[affinity <timeout-seconds>] [del]",
2322 .path =
"nat44 add load-balancing back-end",
2325 "nat44 add load-balancing back-end protocol tcp|udp " 2326 "external <addr>:<port> local <addr>:<port> [vrf <table-id>] " 2327 "probability <n> [del]",
2346 .path =
"show nat44 static mappings",
2347 .short_help =
"show nat44 static mappings",
2360 .path =
"nat44 add interface address",
2361 .short_help =
"nat44 add interface address <interface> [twice-nat] [del]",
2377 .path =
"show nat44 interface address",
2378 .short_help =
"show nat44 interface address",
2389 .path =
"show nat44 sessions",
2390 .short_help =
"show nat44 sessions [detail|metrics]",
2401 .path =
"set nat44 session limit",
2402 .short_help =
"set nat44 session limit <limit> [vrf <table-id>]",
2414 .path =
"nat44 del user",
2415 .short_help =
"nat44 del user <addr> [fib <index>]",
2427 .path =
"clear nat44 sessions",
2428 .short_help =
"clear nat44 sessions",
2442 .path =
"nat44 del session",
2443 .short_help =
"nat44 del session in|out <addr>:<port> tcp|udp|icmp [vrf <id>] [external-host <addr>:<port>]",
2460 .path =
"nat44 forwarding",
2461 .short_help =
"nat44 forwarding enable|disable",
static clib_error_t * add_address_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
#define UNSUPPORTED_IN_ED_MODE_STR
vl_api_address_t end_addr
uword translation_memory_size
u32 * max_translations_per_fib
#define nat_log_info(...)
#define vec_foreach_index(var, v)
Iterate over vector indices.
static clib_error_t * nat44_show_sessions_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
clib_bihash_16_8_t out2in_ed
int snat_del_address(snat_main_t *sm, ip4_address_t addr, u8 delete_sm, u8 twice_nat)
Delete external address from NAT44 pool.
int nat64_set_udp_timeout(u32 timeout)
Set UDP session timeout.
nat_affinity_main_t nat_affinity_main
int nat44_del_session(snat_main_t *sm, ip4_address_t *addr, u16 port, nat_protocol_t proto, u32 vrf_id, int is_in)
Delete NAT44 session.
vnet_main_t * vnet_get_main(void)
static void nat44_show_lru_summary(vlib_main_t *vm, snat_main_per_thread_data_t *tsm, u64 now, u64 sess_timeout_time)
#define SNAT_TCP_ESTABLISHED_TIMEOUT
static clib_error_t * nat44_set_session_limit_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
vl_api_address_t start_addr
clib_memset(h->entries, 0, sizeof(h->entries[0]) *entries)
static f64 vlib_time_now(vlib_main_t *vm)
per_vrf_sessions_t * per_vrf_sessions_vec
static clib_error_t * nat_ha_resync_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
#define vec_add1(V, E)
Add 1 element to end of vector (unspecified alignment).
int nat44_del_ed_session(snat_main_t *sm, ip4_address_t *addr, u16 port, ip4_address_t *eh_addr, u16 eh_port, u8 proto, u32 vrf_id, int is_in)
Delete NAT44 endpoint-dependent session.
unformat_function_t unformat_vnet_sw_interface
static clib_error_t * add_identity_mapping_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
void nat_ha_get_resync_status(u8 *in_resync, u32 *resync_ack_missed)
Get resync status.
static clib_error_t * nat44_show_summary_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
format_function_t format_vnet_sw_if_index_name
int snat_interface_add_del(u32 sw_if_index, u8 is_inside, int is_del)
Enable/disable NAT44 feature on the interface.
static clib_error_t * nat_show_ha_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
clib_bihash_8_8_t user_hash
static clib_error_t * nat44_debug_fib_expire_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
int nat_ha_resync(u32 client_index, u32 pid, nat_ha_resync_event_cb_t event_callback)
Resync HA (resend existing sessions to new failover)
#define pool_foreach(VAR, POOL, BODY)
Iterate through pool.
clib_bihash_16_8_t affinity_hash
int snat_add_address(snat_main_t *sm, ip4_address_t *addr, u32 vrf_id, u8 twice_nat)
Add external address to NAT44 pool.
int nat64_set_icmp_timeout(u32 timeout)
Set ICMP session timeout.
#define vec_elt_at_index(v, i)
Get vector value at index i checking that i is in bounds.
#define clib_error_return(e, args...)
int snat_ipfix_logging_enable_disable(int enable, u32 domain_id, u16 src_port)
Enable/disable NAT plugin IPFIX logging.
static clib_error_t * nat44_set_alloc_addr_and_port_alg_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
static clib_error_t * nat_set_mss_clamping_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
u32 * auto_add_sw_if_indices_twice_nat
vlib_worker_thread_t * vlib_worker_threads
static clib_error_t * nat44_show_hash_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
static_always_inline int nat44_user_del(ip4_address_t *addr, u32 fib_index)
nat_addr_and_port_alloc_alg_t addr_and_port_alloc_alg
static clib_error_t * nat44_show_addresses_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
static clib_error_t * snat_forwarding_set_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
snat_static_mapping_t * static_mappings
static clib_error_t * nat44_del_user_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
void nat_ha_get_listener(ip4_address_t *addr, u16 *port, u32 *path_mtu)
Get HA listener/local configuration.
void nat_ha_flush(u8 is_resync)
Flush the current HA data (for testing)
clib_bihash_8_8_t static_mapping_by_external
static clib_error_t * snat_feature_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
void nat_set_alloc_addr_and_port_default(void)
Set address and port assignment algorithm to default/standard.
snat_interface_t * output_feature_interfaces
static clib_error_t * snat_set_log_level_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
void expire_per_vrf_sessions(u32 fib_index)
vl_api_ip_port_and_mask_t src_port
static clib_error_t * add_lb_static_mapping_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
static clib_error_t * snat_ipfix_logging_enable_disable_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
u32 ft_table_id
Table ID (hash key) for this FIB.
static clib_error_t * nat_show_workers_commnad_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
static clib_error_t * nat44_show_interfaces_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
void nat44_add_del_address_dpo(ip4_address_t addr, u8 is_add)
Add/delete external address to FIB DPO (out2in DPO mode)
sll srl srl sll sra u16x4 i
#define vec_free(V)
Free vector's memory (no header).
format_function_t format_snat_static_map_to_resolve
int snat_interface_add_del_output_feature(u32 sw_if_index, u8 is_inside, int is_del)
Enable/disable NAT44 output feature on the interface (postrouting NAT)
format_function_t format_nat_addr_and_port_alloc_alg
static clib_error_t * set_timeout_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
int nat44_update_session_limit(u32 session_limit, u32 vrf_id)
Update NAT44 session limit flushing all data (session limit, vrf id)
u32 tcp_transitory_timeout
int nat_ha_set_listener(ip4_address_t *addr, u16 port, u32 path_mtu)
Set HA listener (local settings)
static clib_error_t * nat_ha_failover_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
#define VLIB_CLI_COMMAND(x,...)
u32 * auto_add_sw_if_indices
static clib_error_t * nat_show_mss_clamping_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
unformat_function_t unformat_nat_protocol
static clib_error_t * nat_ha_flush_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
static clib_error_t * nat_ha_listener_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
void vlib_cli_output(vlib_main_t *vm, char *fmt,...)
int nat_ha_set_failover(ip4_address_t *addr, u16 port, u32 session_refresh_interval)
Set HA failover (remote settings)
void nat_set_alloc_addr_and_port_range(u16 start_port, u16 end_port)
Set address and port assignment algorithm for port range.
static clib_error_t * add_static_mapping_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
#define clib_bitmap_free(v)
Free a bitmap.
#define SUPPORTED_ONLY_IN_ED_MODE_STR
snat_address_t * twice_nat_addresses
static clib_error_t * nat44_del_session_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
NAT64 global declarations.
int nat64_set_tcp_timeouts(u32 trans, u32 est)
Set TCP session timeouts.
static clib_error_t * nat_show_timeouts_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
void nat44_sessions_clear()
int nat44_lb_static_mapping_add_del_local(ip4_address_t e_addr, u16 e_port, ip4_address_t l_addr, u16 l_port, nat_protocol_t proto, u32 vrf_id, u8 probability, u8 is_add)
#define vec_len(v)
Number of elements in vector (rvalue-only, NULL tolerant)
static_always_inline u8 nat_proto_to_ip_proto(nat_protocol_t nat_proto)
static clib_error_t * snat_add_interface_address_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
snat_main_per_thread_data_t * per_thread_data
fib_table_t * fib_table_get(fib_node_index_t index, fib_protocol_t proto)
Get a pointer to a FIB table.
snat_address_t * addresses
static clib_error_t * nat44_show_alloc_addr_and_port_alg_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
int snat_add_interface_address(snat_main_t *sm, u32 sw_if_index, int is_del, u8 twice_nat)
Add/delete NAT44 pool address from specific interface.
static clib_error_t * nat44_show_interface_address_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
void nat_ha_get_failover(ip4_address_t *addr, u16 *port, u32 *session_refresh_interval)
Get HA failover/remote settings.
static clib_error_t * nat44_show_static_mappings_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
static clib_error_t * add_lb_backend_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
#define SNAT_ICMP_TIMEOUT
snat_static_map_resolve_t * to_resolve
static clib_error_t * nat44_debug_fib_registration_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
static clib_error_t * nat44_clear_sessions_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
static void increment_v4_address(ip4_address_t *a)
#define vec_foreach(var, vec)
Vector iterator.
int nat44_add_del_lb_static_mapping(ip4_address_t e_addr, u16 e_port, nat_protocol_t proto, nat44_lb_addr_port_t *locals, u8 is_add, twice_nat_type_t twice_nat, u8 out2in_only, u8 *tag, u32 affinity)
Add/delete static mapping with load-balancing (multiple backends)
int snat_set_workers(uword *bitmap)
Set NAT plugin workers.
int snat_add_static_mapping(ip4_address_t l_addr, ip4_address_t e_addr, u16 l_port, u16 e_port, u32 vrf_id, int addr_only, u32 sw_if_index, nat_protocol_t proto, int is_add, twice_nat_type_t twice_nat, u8 out2in_only, u8 *tag, u8 identity_nat, ip4_address_t pool_addr, int exact)
Add/delete NAT44 static mapping.
clib_bihash_16_8_t in2out_ed
void nat_set_alloc_addr_and_port_mape(u16 psid, u16 psid_offset, u16 psid_length)
Set address and port assignment algorithm for MAP-E CE.
NAT plugin client-IP based session affinity for load-balancing.
#define SNAT_TCP_TRANSITORY_TIMEOUT
snat_session_t * sessions
clib_bihash_8_8_t static_mapping_by_local
static clib_error_t * set_workers_command_fn(vlib_main_t *vm, unformat_input_t *input, vlib_cli_command_t *cmd)
vl_api_interface_index_t sw_if_index
snat_interface_t * interfaces
u32 tcp_established_timeout
static uword pool_elts(void *v)
Number of active elements in a pool.