From: Kishore Aramalla Date: Thu, 11 Apr 2019 19:04:34 +0000 (-0700) Subject: zebra: L3VNI's are allowed to unconfigure from any VRF X-Git-Tag: 7.1_pulled~39^2 X-Git-Url: https://git.puffer.fish/?a=commitdiff_plain;h=7a6ca8a6aee50d2724e379f22ac9205e1fae06ab;p=mirror%2Ffrr.git zebra: L3VNI's are allowed to unconfigure from any VRF L3VNI configured in a specific VRF is allowed to unconfigure from any VRF, including default (global) VRF. This results L3VNI delete notification to BGP and subsequent type-5 route uninstall from the VRF the L3VNI belong to. This also resulted in the inconsistent running configuration. The deleted L3VNI still shows up in its original VRF. The VRF in which the "no vni " was executed doesn't display its own L3VNI. Added a VRF check in zebra to prevent this. Signed-off-by: Kishore Aramalla --- diff --git a/zebra/zebra_vxlan.c b/zebra/zebra_vxlan.c index 3a8426e772..9afa915d5b 100644 --- a/zebra/zebra_vxlan.c +++ b/zebra/zebra_vxlan.c @@ -8688,6 +8688,13 @@ int zebra_vxlan_process_vrf_vni_cmd(struct zebra_vrf *zvrf, vni_t vni, return -1; } + if (zvrf->l3vni != vni) { + snprintf(err, err_str_sz, + "VNI %d doesn't exist in VRF: %s", + vni, zvrf->vrf->name); + return -1; + } + if (filter && !CHECK_FLAG(zl3vni->filter, PREFIX_ROUTES_ONLY)) { snprintf(err, ERR_STR_SZ, "prefix-routes-only is not set for the vni");