diff options
author | Matus Fabian <matfabia@cisco.com> | 2018-01-31 01:13:23 -0800 |
---|---|---|
committer | Matus Fabian <matfabia@cisco.com> | 2018-01-31 01:13:23 -0800 |
commit | 9dba7816f6c3b5e4c879f839bb4bc61dcdbde757 (patch) | |
tree | 681ae6bedfbebdb5fcafcd8389866452cfb98dd8 /src/plugins/nat/nat_api.c | |
parent | 8ad6a2dfed0a7248be9d005dd04c76da142f2238 (diff) |
NAT44: nat44_static_mapping_details protocol=0 if addr_only=0 (VPP-1158)
Change-Id: I1e3cfc751e7657464fc850dc56ddf763df45f62e
Signed-off-by: Matus Fabian <matfabia@cisco.com>
Diffstat (limited to 'src/plugins/nat/nat_api.c')
-rw-r--r-- | src/plugins/nat/nat_api.c | 18 |
1 files changed, 12 insertions, 6 deletions
diff --git a/src/plugins/nat/nat_api.c b/src/plugins/nat/nat_api.c index 3cb7399558f..2fefb8b7c1b 100644 --- a/src/plugins/nat/nat_api.c +++ b/src/plugins/nat/nat_api.c @@ -764,14 +764,17 @@ send_nat44_static_mapping_details (snat_static_mapping_t * m, rmp->addr_only = m->addr_only; clib_memcpy (rmp->local_ip_address, &(m->local_addr), 4); clib_memcpy (rmp->external_ip_address, &(m->external_addr), 4); - rmp->local_port = htons (m->local_port); - rmp->external_port = htons (m->external_port); rmp->external_sw_if_index = ~0; rmp->vrf_id = htonl (m->vrf_id); - rmp->protocol = snat_proto_to_ip_proto (m->proto); rmp->context = context; rmp->twice_nat = m->twice_nat; rmp->out2in_only = m->out2in_only; + if (m->addr_only == 0) + { + rmp->protocol = snat_proto_to_ip_proto (m->proto); + rmp->external_port = htons (m->external_port); + rmp->local_port = htons (m->local_port); + } if (m->tag) strncpy ((char *) rmp->tag, (char *) m->tag, vec_len (m->tag)); @@ -792,13 +795,16 @@ send_nat44_static_map_resolve_details (snat_static_map_resolve_t * m, ntohs (VL_API_NAT44_STATIC_MAPPING_DETAILS + sm->msg_id_base); rmp->addr_only = m->addr_only; clib_memcpy (rmp->local_ip_address, &(m->l_addr), 4); - rmp->local_port = htons (m->l_port); - rmp->external_port = htons (m->e_port); rmp->external_sw_if_index = htonl (m->sw_if_index); rmp->vrf_id = htonl (m->vrf_id); - rmp->protocol = snat_proto_to_ip_proto (m->proto); rmp->context = context; rmp->twice_nat = m->twice_nat; + if (m->addr_only == 0) + { + rmp->protocol = snat_proto_to_ip_proto (m->proto); + rmp->external_port = htons (m->e_port); + rmp->local_port = htons (m->l_port); + } if (m->tag) strncpy ((char *) rmp->tag, (char *) m->tag, vec_len (m->tag)); |