X-Git-Url: https://gerrit.fd.io/r/gitweb?a=blobdiff_plain;f=src%2Fvnet%2Fipsec%2Fipsec_spd_policy.c;h=6424210b4e31b96173b420dd0ad2b294e97ad687;hb=e5d34919b;hp=d4a32e38568524dbb230fa304e01dc231cec777c;hpb=9f231d4f147c7e3fdf562680488ec5dfe7655b5e;p=vpp.git diff --git a/src/vnet/ipsec/ipsec_spd_policy.c b/src/vnet/ipsec/ipsec_spd_policy.c index d4a32e38568..6424210b4e3 100644 --- a/src/vnet/ipsec/ipsec_spd_policy.c +++ b/src/vnet/ipsec/ipsec_spd_policy.c @@ -142,17 +142,6 @@ ipsec_add_del_policy (vlib_main_t * vm, u32 spd_index; uword *p; - clib_warning ("policy-id %u priority %d type %U", policy->id, - policy->priority, format_ipsec_policy_type, policy->type); - - if (policy->policy == IPSEC_POLICY_ACTION_PROTECT) - { - p = hash_get (im->sa_index_by_sa_id, policy->sa_id); - if (!p) - return VNET_API_ERROR_SYSCALL_ERROR_1; - policy->sa_index = p[0]; - } - p = hash_get (im->spd_index_by_spd_id, policy->id); if (!p) @@ -167,6 +156,17 @@ ipsec_add_del_policy (vlib_main_t * vm, { u32 policy_index; + if (policy->policy == IPSEC_POLICY_ACTION_PROTECT) + { + index_t sa_index = ipsec_sa_find_and_lock (policy->sa_id); + + if (INDEX_INVALID == sa_index) + return VNET_API_ERROR_SYSCALL_ERROR_1; + policy->sa_index = sa_index; + } + else + policy->sa_index = INDEX_INVALID; + pool_get (im->policies, vp); clib_memcpy (vp, policy, sizeof (*vp)); policy_index = vp - im->policies; @@ -182,23 +182,20 @@ ipsec_add_del_policy (vlib_main_t * vm, } else { - ipsec_spd_policy_type_t ptype; u32 ii; - FOR_EACH_IPSEC_SPD_POLICY_TYPE (ptype) + vec_foreach_index (ii, (spd->policies[policy->type])) { - vec_foreach_index (ii, (spd->policies[ptype])) - { - vp = pool_elt_at_index (im->policies, spd->policies[ptype][ii]); - if (ipsec_policy_is_equal (vp, policy)) - { - vec_del1 (spd->policies[ptype], ii); - pool_put (im->policies, vp); - goto done; - } - } + vp = pool_elt_at_index (im->policies, + spd->policies[policy->type][ii]); + if (ipsec_policy_is_equal (vp, policy)) + { + vec_del1 (spd->policies[policy->type], ii); + ipsec_sa_unlock (vp->sa_index); + pool_put (im->policies, vp); + break; + } } - done:; } return 0;