X-Git-Url: https://gerrit.fd.io/r/gitweb?a=blobdiff_plain;f=src%2Fvnet%2Fipsec%2Fipsec_format.c;h=9204b1c090d12679b5585cd848e208a834e66b76;hb=06abf235269558fe75d72019a437337b24d7199e;hp=c8c0170efe77e28cc42aa2de7c58f3cd242585e5;hpb=7cd35f5d688d9e3bddf66602655274dae944b086;p=vpp.git diff --git a/src/vnet/ipsec/ipsec_format.c b/src/vnet/ipsec/ipsec_format.c index c8c0170efe7..9204b1c090d 100644 --- a/src/vnet/ipsec/ipsec_format.c +++ b/src/vnet/ipsec/ipsec_format.c @@ -153,8 +153,8 @@ format_ipsec_replay_window (u8 * s, va_list * args) return s; } -u8 * -format_ipsec_policy (u8 * s, va_list * args) +static u8 * +format_ipsec_policy_with_suffix (u8 *s, va_list *args, u8 *suffix) { u32 pi = va_arg (*args, u32); ip46_type_t ip_type = IP46_TYPE_IP4; @@ -168,7 +168,7 @@ format_ipsec_policy (u8 * s, va_list * args) pi, p->priority, format_ipsec_policy_action, p->policy, format_ipsec_policy_type, p->type); - if (p->protocol) + if (p->protocol != IPSEC_POLICY_PROTOCOL_ANY) { s = format (s, "%U", format_ip_protocol, p->protocol); } @@ -180,6 +180,9 @@ format_ipsec_policy (u8 * s, va_list * args) { s = format (s, " sa %u", p->sa_id); } + if (suffix) + s = format (s, " %s", suffix); + if (p->is_ipv6) { ip_type = IP46_TYPE_IP6; @@ -200,6 +203,18 @@ format_ipsec_policy (u8 * s, va_list * args) return (s); } +u8 * +format_ipsec_policy (u8 *s, va_list *args) +{ + return format_ipsec_policy_with_suffix (s, args, 0); +} + +u8 * +format_ipsec_policy_fp (u8 *s, va_list *args) +{ + return format_ipsec_policy_with_suffix (s, args, (u8 *) ""); +} + u8 * format_ipsec_spd (u8 * s, va_list * args) { @@ -218,12 +233,16 @@ format_ipsec_spd (u8 * s, va_list * args) s = format (s, "spd %u", spd->id); -#define _(v, n) \ - s = format (s, "\n %s:", n); \ - vec_foreach(i, spd->policies[IPSEC_SPD_POLICY_##v]) \ - { \ - s = format (s, "\n %U", format_ipsec_policy, *i); \ - } +#define _(v, n) \ + s = format (s, "\n %s:", n); \ + vec_foreach (i, spd->policies[IPSEC_SPD_POLICY_##v]) \ + { \ + s = format (s, "\n %U", format_ipsec_policy, *i); \ + } \ + vec_foreach (i, spd->fp_spd.fp_policies[IPSEC_SPD_POLICY_##v]) \ + { \ + s = format (s, "\n %U", format_ipsec_policy_fp, *i); \ + } foreach_ipsec_spd_policy_type; #undef _