aboutsummaryrefslogtreecommitdiffstats
path: root/src/plugins/nat/nat_api.c
diff options
context:
space:
mode:
authorFilip Varga <fivarga@cisco.com>2020-09-30 22:24:47 +0200
committerOle Tr�an <otroan@employees.org>2020-10-23 12:09:07 +0000
commit5f4f2081c47a5d86c9c96b7de23a2b0147c737d8 (patch)
treefd80c764cc3deb527f54d289c12a03d85c563373 /src/plugins/nat/nat_api.c
parent498889ae5d36eca5e2c017400b70f71bc5cdaf4a (diff)
nat: nat44 enable/disable dynamic config
This patch changes initialization and configuration of NAT plugin. Instead of allocating data structures at vpp plugin initialization phase allocation and configuration happens after calling enable API or CLI call. This reduces base VPP memory footprint and also enables dynamic reconfiguration of the NAT plugin. Type: improvement Change-Id: I42c069ee19a0311d043ac1f3f230d87bc8d2680f Signed-off-by: Filip Varga <fivarga@cisco.com>
Diffstat (limited to 'src/plugins/nat/nat_api.c')
-rw-r--r--src/plugins/nat/nat_api.c84
1 files changed, 84 insertions, 0 deletions
diff --git a/src/plugins/nat/nat_api.c b/src/plugins/nat/nat_api.c
index 11d4ded48a9..39f1af70f9d 100644
--- a/src/plugins/nat/nat_api.c
+++ b/src/plugins/nat/nat_api.c
@@ -334,6 +334,89 @@ vl_api_nat_set_log_level_t_print (vl_api_nat_set_log_level_t *
}
static void
+ vl_api_nat44_plugin_enable_disable_t_handler
+ (vl_api_nat44_plugin_enable_disable_t * mp)
+{
+ snat_main_t *sm = &snat_main;
+ nat44_config_t c = { 0 };
+ vl_api_nat44_plugin_enable_disable_reply_t *rmp;
+ int rv = 0;
+
+ if (mp->enable)
+ {
+ c.endpoint_dependent = mp->flags & NAT44_API_IS_ENDPOINT_DEPENDENT;
+ c.static_mapping_only = mp->flags & NAT44_API_IS_STATIC_MAPPING_ONLY;
+ c.connection_tracking = mp->flags & NAT44_API_IS_CONNECTION_TRACKING;
+ c.out2in_dpo = mp->flags & NAT44_API_IS_OUT2IN_DPO;
+
+ c.inside_vrf = ntohl (mp->inside_vrf);
+ c.outside_vrf = ntohl (mp->outside_vrf);
+
+ c.users = ntohl (mp->users);
+ c.user_memory = ntohl (mp->user_memory);
+
+ c.sessions = ntohl (mp->sessions);
+ c.session_memory = ntohl (mp->session_memory);
+
+ c.user_sessions = ntohl (mp->user_sessions);
+
+ rv = nat44_plugin_enable (c);
+ }
+ else
+ rv = nat44_plugin_disable ();
+
+ REPLY_MACRO (VL_API_NAT44_PLUGIN_ENABLE_DISABLE_REPLY);
+}
+
+static void *vl_api_nat44_plugin_enable_disable_t_print
+ (vl_api_nat44_plugin_enable_disable_t * mp, void *handle)
+{
+ u8 *s;
+ u32 val;
+
+ s = format (0, "SCRIPT: nat44_plugin_enable_disable ");
+ if (mp->enable)
+ {
+ s = format (s, "enable ");
+ if (mp->flags & NAT44_API_IS_ENDPOINT_DEPENDENT)
+ s = format (s, "endpoint-dependent ");
+ else
+ s = format (s, "endpoint-indepenednet ");
+ if (mp->flags & NAT44_API_IS_STATIC_MAPPING_ONLY)
+ s = format (s, "static_mapping_only ");
+ if (mp->flags & NAT44_API_IS_CONNECTION_TRACKING)
+ s = format (s, "connection_tracking ");
+ if (mp->flags & NAT44_API_IS_OUT2IN_DPO)
+ s = format (s, "out2in_dpo ");
+ val = ntohl (mp->inside_vrf);
+ if (val)
+ s = format (s, "inside_vrf %u ", val);
+ val = ntohl (mp->outside_vrf);
+ if (val)
+ s = format (s, "outside_vrf %u ", val);
+ val = ntohl (mp->users);
+ if (val)
+ s = format (s, "users %u ", val);
+ val = ntohl (mp->user_memory);
+ if (val)
+ s = format (s, "user_memory %u ", val);
+ val = ntohl (mp->sessions);
+ if (val)
+ s = format (s, "sessions %u ", val);
+ val = ntohl (mp->session_memory);
+ if (val)
+ s = format (s, "session_memory %u ", val);
+ val = ntohl (mp->user_sessions);
+ if (val)
+ s = format (s, "user_sessions %u ", val);
+ }
+ else
+ s = format (s, "disable ");
+
+ FINISH;
+}
+
+static void
vl_api_nat_ipfix_enable_disable_t_handler (vl_api_nat_ipfix_enable_disable_t *
mp)
{
@@ -2228,6 +2311,7 @@ _(NAT_SHOW_CONFIG, nat_show_config) \
_(NAT_SHOW_CONFIG_2, nat_show_config_2) \
_(NAT_SET_WORKERS, nat_set_workers) \
_(NAT_WORKER_DUMP, nat_worker_dump) \
+_(NAT44_PLUGIN_ENABLE_DISABLE, nat44_plugin_enable_disable) \
_(NAT44_DEL_USER, nat44_del_user) \
_(NAT44_SET_SESSION_LIMIT, nat44_set_session_limit) \
_(NAT_SET_LOG_LEVEL, nat_set_log_level) \