mirror of
https://git.proxmox.com/git/mirror_frr
synced 2025-08-08 07:37:29 +00:00
zebra: proper refcounting for rmac/nh entries
Signed-off-by: Mitesh Kanjariya <mitesh@cumulusnetworks.comy>
This commit is contained in:
parent
a89b49cc4e
commit
6134fd82a0
@ -396,10 +396,10 @@ void connected_down(struct interface *ifp, struct connected *ifc)
|
|||||||
* head.
|
* head.
|
||||||
*/
|
*/
|
||||||
rib_delete(afi, SAFI_UNICAST, ifp->vrf_id, ZEBRA_ROUTE_CONNECT, 0, 0,
|
rib_delete(afi, SAFI_UNICAST, ifp->vrf_id, ZEBRA_ROUTE_CONNECT, 0, 0,
|
||||||
&p, NULL, &nh, 0, 0, false);
|
&p, NULL, &nh, 0, 0, false, NULL);
|
||||||
|
|
||||||
rib_delete(afi, SAFI_MULTICAST, ifp->vrf_id, ZEBRA_ROUTE_CONNECT, 0,
|
rib_delete(afi, SAFI_MULTICAST, ifp->vrf_id, ZEBRA_ROUTE_CONNECT, 0,
|
||||||
0, &p, NULL, &nh, 0, 0, false);
|
0, &p, NULL, &nh, 0, 0, false, NULL);
|
||||||
|
|
||||||
if (IS_ZEBRA_DEBUG_RIB_DETAILED) {
|
if (IS_ZEBRA_DEBUG_RIB_DETAILED) {
|
||||||
char buf[PREFIX_STRLEN];
|
char buf[PREFIX_STRLEN];
|
||||||
|
@ -1039,7 +1039,7 @@ void rtm_read(struct rt_msghdr *rtm)
|
|||||||
if (rtm->rtm_type == RTM_CHANGE)
|
if (rtm->rtm_type == RTM_CHANGE)
|
||||||
rib_delete(AFI_IP, SAFI_UNICAST, VRF_DEFAULT,
|
rib_delete(AFI_IP, SAFI_UNICAST, VRF_DEFAULT,
|
||||||
ZEBRA_ROUTE_KERNEL, 0, zebra_flags, &p, NULL,
|
ZEBRA_ROUTE_KERNEL, 0, zebra_flags, &p, NULL,
|
||||||
NULL, 0, 0, true);
|
NULL, 0, 0, true, NULL);
|
||||||
|
|
||||||
if (!nh.type) {
|
if (!nh.type) {
|
||||||
nh.type = NEXTHOP_TYPE_IPV4;
|
nh.type = NEXTHOP_TYPE_IPV4;
|
||||||
@ -1054,7 +1054,7 @@ void rtm_read(struct rt_msghdr *rtm)
|
|||||||
else
|
else
|
||||||
rib_delete(AFI_IP, SAFI_UNICAST, VRF_DEFAULT,
|
rib_delete(AFI_IP, SAFI_UNICAST, VRF_DEFAULT,
|
||||||
ZEBRA_ROUTE_KERNEL, 0, zebra_flags, &p, NULL,
|
ZEBRA_ROUTE_KERNEL, 0, zebra_flags, &p, NULL,
|
||||||
&nh, 0, 0, true);
|
&nh, 0, 0, true, NULL);
|
||||||
}
|
}
|
||||||
if (dest.sa.sa_family == AF_INET6) {
|
if (dest.sa.sa_family == AF_INET6) {
|
||||||
/* One day we might have a debug section here like one in the
|
/* One day we might have a debug section here like one in the
|
||||||
@ -1085,7 +1085,7 @@ void rtm_read(struct rt_msghdr *rtm)
|
|||||||
if (rtm->rtm_type == RTM_CHANGE)
|
if (rtm->rtm_type == RTM_CHANGE)
|
||||||
rib_delete(AFI_IP6, SAFI_UNICAST, VRF_DEFAULT,
|
rib_delete(AFI_IP6, SAFI_UNICAST, VRF_DEFAULT,
|
||||||
ZEBRA_ROUTE_KERNEL, 0, zebra_flags, &p, NULL,
|
ZEBRA_ROUTE_KERNEL, 0, zebra_flags, &p, NULL,
|
||||||
NULL, 0, 0, true);
|
NULL, 0, 0, true, NULL);
|
||||||
|
|
||||||
if (!nh.type) {
|
if (!nh.type) {
|
||||||
nh.type = ifindex ? NEXTHOP_TYPE_IPV6_IFINDEX
|
nh.type = ifindex ? NEXTHOP_TYPE_IPV6_IFINDEX
|
||||||
@ -1102,7 +1102,7 @@ void rtm_read(struct rt_msghdr *rtm)
|
|||||||
else
|
else
|
||||||
rib_delete(AFI_IP6, SAFI_UNICAST, VRF_DEFAULT,
|
rib_delete(AFI_IP6, SAFI_UNICAST, VRF_DEFAULT,
|
||||||
ZEBRA_ROUTE_KERNEL, 0, zebra_flags, &p, NULL,
|
ZEBRA_ROUTE_KERNEL, 0, zebra_flags, &p, NULL,
|
||||||
&nh, 0, 0, true);
|
&nh, 0, 0, true, NULL);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -570,7 +570,7 @@ int zebra_del_import_table_entry(struct route_node *rn, struct route_entry *re)
|
|||||||
|
|
||||||
rib_delete(afi, SAFI_UNICAST, re->vrf_id, ZEBRA_ROUTE_TABLE,
|
rib_delete(afi, SAFI_UNICAST, re->vrf_id, ZEBRA_ROUTE_TABLE,
|
||||||
re->table, re->flags, &p, NULL, re->nexthop,
|
re->table, re->flags, &p, NULL, re->nexthop,
|
||||||
zebrad.rtm_table_default, re->metric, false);
|
zebrad.rtm_table_default, re->metric, false, NULL);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -304,7 +304,8 @@ extern int rib_add_multipath(afi_t afi, safi_t safi, struct prefix *,
|
|||||||
extern void rib_delete(afi_t afi, safi_t safi, vrf_id_t vrf_id, int type,
|
extern void rib_delete(afi_t afi, safi_t safi, vrf_id_t vrf_id, int type,
|
||||||
u_short instance, int flags, struct prefix *p,
|
u_short instance, int flags, struct prefix *p,
|
||||||
struct prefix_ipv6 *src_p, const struct nexthop *nh,
|
struct prefix_ipv6 *src_p, const struct nexthop *nh,
|
||||||
u_int32_t table_id, u_int32_t metric, bool fromkernel);
|
u_int32_t table_id, u_int32_t metric, bool fromkernel,
|
||||||
|
struct ethaddr *rmac);
|
||||||
|
|
||||||
extern struct route_entry *rib_match(afi_t afi, safi_t safi, vrf_id_t,
|
extern struct route_entry *rib_match(afi_t afi, safi_t safi, vrf_id_t,
|
||||||
union g_addr *,
|
union g_addr *,
|
||||||
|
@ -535,13 +535,13 @@ static int netlink_route_change_read_unicast(struct sockaddr_nl *snl,
|
|||||||
memcpy(&nh.gate, gate, sz);
|
memcpy(&nh.gate, gate, sz);
|
||||||
rib_delete(afi, SAFI_UNICAST, vrf_id,
|
rib_delete(afi, SAFI_UNICAST, vrf_id,
|
||||||
proto, 0, flags, &p, NULL, &nh,
|
proto, 0, flags, &p, NULL, &nh,
|
||||||
table, metric, true);
|
table, metric, true, NULL);
|
||||||
} else {
|
} else {
|
||||||
/* XXX: need to compare the entire list of nexthops
|
/* XXX: need to compare the entire list of nexthops
|
||||||
* here for NLM_F_APPEND stupidity */
|
* here for NLM_F_APPEND stupidity */
|
||||||
rib_delete(afi, SAFI_UNICAST, vrf_id,
|
rib_delete(afi, SAFI_UNICAST, vrf_id,
|
||||||
proto, 0, flags, &p, NULL, NULL,
|
proto, 0, flags, &p, NULL, NULL,
|
||||||
table, metric, true);
|
table, metric, true, NULL);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -50,6 +50,7 @@
|
|||||||
#include "zebra/zebra_rnh.h"
|
#include "zebra/zebra_rnh.h"
|
||||||
#include "zebra/interface.h"
|
#include "zebra/interface.h"
|
||||||
#include "zebra/connected.h"
|
#include "zebra/connected.h"
|
||||||
|
#include "zebra/zebra_vxlan.h"
|
||||||
|
|
||||||
DEFINE_HOOK(rib_update, (struct route_node * rn, const char *reason),
|
DEFINE_HOOK(rib_update, (struct route_node * rn, const char *reason),
|
||||||
(rn, reason))
|
(rn, reason))
|
||||||
@ -2319,7 +2320,8 @@ int rib_add_multipath(afi_t afi, safi_t safi, struct prefix *p,
|
|||||||
void rib_delete(afi_t afi, safi_t safi, vrf_id_t vrf_id, int type,
|
void rib_delete(afi_t afi, safi_t safi, vrf_id_t vrf_id, int type,
|
||||||
u_short instance, int flags, struct prefix *p,
|
u_short instance, int flags, struct prefix *p,
|
||||||
struct prefix_ipv6 *src_p, const struct nexthop *nh,
|
struct prefix_ipv6 *src_p, const struct nexthop *nh,
|
||||||
u_int32_t table_id, u_int32_t metric, bool fromkernel)
|
u_int32_t table_id, u_int32_t metric, bool fromkernel,
|
||||||
|
struct ethaddr *rmac)
|
||||||
{
|
{
|
||||||
struct route_table *table;
|
struct route_table *table;
|
||||||
struct route_node *rn;
|
struct route_node *rn;
|
||||||
@ -2472,6 +2474,22 @@ void rib_delete(afi_t afi, safi_t safi, vrf_id_t vrf_id, int type,
|
|||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (CHECK_FLAG(flags, ZEBRA_FLAG_EVPN_TYPE2_ROUTE)) {
|
||||||
|
struct nexthop *tmp_nh;
|
||||||
|
|
||||||
|
for (ALL_NEXTHOPS(re->nexthop, tmp_nh)) {
|
||||||
|
struct ipaddr vtep_ip;
|
||||||
|
|
||||||
|
memset(&vtep_ip, 0, sizeof(struct ipaddr));
|
||||||
|
vtep_ip.ipa_type = IPADDR_V4;
|
||||||
|
memcpy(&(vtep_ip.ipaddr_v4),
|
||||||
|
&(tmp_nh->gate.ipv4),
|
||||||
|
sizeof(struct in_addr));
|
||||||
|
zebra_vxlan_evpn_vrf_route_del(re->vrf_id, rmac,
|
||||||
|
&vtep_ip, p);
|
||||||
|
}
|
||||||
|
}
|
||||||
rib_delnode(rn, same);
|
rib_delnode(rn, same);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -48,6 +48,7 @@
|
|||||||
#include "zebra/zebra_l2.h"
|
#include "zebra/zebra_l2.h"
|
||||||
#include "lib/json.h"
|
#include "lib/json.h"
|
||||||
|
|
||||||
|
DEFINE_MTYPE_STATIC(ZEBRA, HOST_PREFIX, "host prefix");
|
||||||
DEFINE_MTYPE_STATIC(ZEBRA, ZVNI, "VNI hash");
|
DEFINE_MTYPE_STATIC(ZEBRA, ZVNI, "VNI hash");
|
||||||
DEFINE_MTYPE_STATIC(ZEBRA, ZL3VNI, "L3 VNI hash");
|
DEFINE_MTYPE_STATIC(ZEBRA, ZL3VNI, "L3 VNI hash");
|
||||||
DEFINE_MTYPE_STATIC(ZEBRA, ZVNI_VTEP, "VNI remote VTEP");
|
DEFINE_MTYPE_STATIC(ZEBRA, ZVNI_VTEP, "VNI remote VTEP");
|
||||||
@ -666,14 +667,14 @@ static void zl3vni_print_nh_hash(struct hash_backet *backet,
|
|||||||
vty_out(vty, "%-15s %-17s %6d\n",
|
vty_out(vty, "%-15s %-17s %6d\n",
|
||||||
ipaddr2str(&(n->ip), buf2, sizeof(buf2)),
|
ipaddr2str(&(n->ip), buf2, sizeof(buf2)),
|
||||||
prefix_mac2str(&n->emac, buf1, sizeof(buf1)),
|
prefix_mac2str(&n->emac, buf1, sizeof(buf1)),
|
||||||
n->nh_refcnt);
|
listcount(n->host_list));
|
||||||
} else {
|
} else {
|
||||||
json_object_string_add(json_nh, "vtep-ip",
|
json_object_string_add(json_nh, "vtep-ip",
|
||||||
inet_ntoa(n->r_vtep_ip));
|
inet_ntoa(n->r_vtep_ip));
|
||||||
json_object_string_add(json_nh, "rmac",
|
json_object_string_add(json_nh, "rmac",
|
||||||
prefix_mac2str(&n->emac, buf1,
|
prefix_mac2str(&n->emac, buf1,
|
||||||
sizeof(buf1)));
|
sizeof(buf1)));
|
||||||
json_object_int_add(json_nh, "refCnt", n->nh_refcnt);
|
json_object_int_add(json_nh, "refCnt", listcount(n->host_list));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -806,14 +807,15 @@ static void zl3vni_print_rmac_hash(struct hash_backet *backet,
|
|||||||
vty_out(vty, "%-17s %-21s %-6d\n",
|
vty_out(vty, "%-17s %-21s %-6d\n",
|
||||||
prefix_mac2str(&zrmac->macaddr, buf, sizeof(buf)),
|
prefix_mac2str(&zrmac->macaddr, buf, sizeof(buf)),
|
||||||
inet_ntoa(zrmac->fwd_info.r_vtep_ip),
|
inet_ntoa(zrmac->fwd_info.r_vtep_ip),
|
||||||
zrmac->rmac_refcnt);
|
listcount(zrmac->host_list));
|
||||||
} else {
|
} else {
|
||||||
json_object_string_add(json_rmac, "rmac",
|
json_object_string_add(json_rmac, "rmac",
|
||||||
prefix_mac2str(&zrmac->macaddr, buf,
|
prefix_mac2str(&zrmac->macaddr, buf,
|
||||||
sizeof(buf)));
|
sizeof(buf)));
|
||||||
json_object_string_add(json_rmac, "vtep-ip",
|
json_object_string_add(json_rmac, "vtep-ip",
|
||||||
inet_ntoa(zrmac->fwd_info.r_vtep_ip));
|
inet_ntoa(zrmac->fwd_info.r_vtep_ip));
|
||||||
json_object_int_add(json_rmac, "refcnt", zrmac->rmac_refcnt);
|
json_object_int_add(json_rmac, "refcnt",
|
||||||
|
listcount(zrmac->host_list));
|
||||||
json_object_array_add(json, json_rmac);
|
json_object_array_add(json, json_rmac);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -2756,6 +2758,47 @@ static void zvni_cleanup_all(struct hash_backet *backet, void *zvrf)
|
|||||||
zvni_del(zvni);
|
zvni_del(zvni);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int is_host_present_in_host_list(struct list *list,
|
||||||
|
struct prefix *host)
|
||||||
|
{
|
||||||
|
struct listnode *node = NULL;
|
||||||
|
struct prefix *p = NULL;
|
||||||
|
|
||||||
|
for (ALL_LIST_ELEMENTS_RO(list, node, p)) {
|
||||||
|
if (prefix_same(p, host))
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void host_list_add_host(struct list *list,
|
||||||
|
struct prefix *host)
|
||||||
|
{
|
||||||
|
struct prefix *p = NULL;
|
||||||
|
|
||||||
|
p = XCALLOC(MTYPE_HOST_PREFIX, sizeof(struct prefix));
|
||||||
|
memcpy(p, host, sizeof(struct prefix));
|
||||||
|
|
||||||
|
listnode_add_sort(list, p);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void host_list_delete_host(struct list *list,
|
||||||
|
struct prefix *host)
|
||||||
|
{
|
||||||
|
struct listnode *node = NULL, *nnode = NULL, *node_to_del = NULL;
|
||||||
|
struct prefix *p = NULL;
|
||||||
|
|
||||||
|
for (ALL_LIST_ELEMENTS(list, node, nnode, p)) {
|
||||||
|
if (prefix_same(p, host)) {
|
||||||
|
XFREE(MTYPE_HOST_PREFIX, p);
|
||||||
|
node_to_del = node;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (node_to_del)
|
||||||
|
list_delete_node(list, node_to_del);
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Look up MAC hash entry.
|
* Look up MAC hash entry.
|
||||||
*/
|
*/
|
||||||
@ -2800,8 +2843,8 @@ static zebra_mac_t *zl3vni_rmac_add(zebra_l3vni_t *zl3vni,
|
|||||||
zrmac = hash_get(zl3vni->rmac_table, &tmp_rmac, zl3vni_rmac_alloc);
|
zrmac = hash_get(zl3vni->rmac_table, &tmp_rmac, zl3vni_rmac_alloc);
|
||||||
assert(zrmac);
|
assert(zrmac);
|
||||||
|
|
||||||
zrmac->neigh_list = list_new();
|
zrmac->host_list = list_new();
|
||||||
zrmac->neigh_list->cmp = (int (*)(void *, void *))neigh_cmp;
|
zrmac->host_list->cmp = (int (*)(void *, void *))prefix_cmp;
|
||||||
|
|
||||||
SET_FLAG(zrmac->flags, ZEBRA_MAC_REMOTE);
|
SET_FLAG(zrmac->flags, ZEBRA_MAC_REMOTE);
|
||||||
SET_FLAG(zrmac->flags, ZEBRA_MAC_REMOTE_RMAC);
|
SET_FLAG(zrmac->flags, ZEBRA_MAC_REMOTE_RMAC);
|
||||||
@ -2882,9 +2925,10 @@ static int zl3vni_rmac_uninstall(zebra_l3vni_t *zl3vni,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* handle rmac add */
|
/* handle rmac add */
|
||||||
static int zebra_vxlan_l3vni_remote_rmac_add(zebra_l3vni_t *zl3vni,
|
static int zl3vni_remote_rmac_add(zebra_l3vni_t *zl3vni,
|
||||||
struct ethaddr *rmac,
|
struct ethaddr *rmac,
|
||||||
struct ipaddr *vtep_ip)
|
struct ipaddr *vtep_ip,
|
||||||
|
struct prefix *host_prefix)
|
||||||
{
|
{
|
||||||
char buf[ETHER_ADDR_STRLEN];
|
char buf[ETHER_ADDR_STRLEN];
|
||||||
char buf1[INET6_ADDRSTRLEN];
|
char buf1[INET6_ADDRSTRLEN];
|
||||||
@ -2909,14 +2953,17 @@ static int zebra_vxlan_l3vni_remote_rmac_add(zebra_l3vni_t *zl3vni,
|
|||||||
/* install rmac in kernel */
|
/* install rmac in kernel */
|
||||||
zl3vni_rmac_install(zl3vni, zrmac);
|
zl3vni_rmac_install(zl3vni, zrmac);
|
||||||
}
|
}
|
||||||
zrmac->rmac_refcnt++;
|
|
||||||
|
if (!is_host_present_in_host_list(zrmac->host_list, host_prefix))
|
||||||
|
host_list_add_host(zrmac->host_list, host_prefix);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* handle rmac delete */
|
/* handle rmac delete */
|
||||||
static int zebra_vxlan_l3vni_remote_rmac_del(zebra_l3vni_t *zl3vni,
|
static int zl3vni_remote_rmac_del(zebra_l3vni_t *zl3vni,
|
||||||
struct ethaddr *rmac)
|
struct ethaddr *rmac,
|
||||||
|
struct prefix *host_prefix)
|
||||||
{
|
{
|
||||||
zebra_mac_t *zrmac = NULL;
|
zebra_mac_t *zrmac = NULL;
|
||||||
|
|
||||||
@ -2924,8 +2971,8 @@ static int zebra_vxlan_l3vni_remote_rmac_del(zebra_l3vni_t *zl3vni,
|
|||||||
if (!zrmac)
|
if (!zrmac)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
zrmac->rmac_refcnt--;
|
host_list_delete_host(zrmac->host_list, host_prefix);
|
||||||
if (!zrmac->rmac_refcnt) {
|
if (list_isempty(zrmac->host_list)) {
|
||||||
|
|
||||||
/* uninstall from kernel */
|
/* uninstall from kernel */
|
||||||
zl3vni_rmac_uninstall(zl3vni, zrmac);
|
zl3vni_rmac_uninstall(zl3vni, zrmac);
|
||||||
@ -2982,6 +3029,9 @@ static zebra_neigh_t *zl3vni_nh_add(zebra_l3vni_t *zl3vni,
|
|||||||
n = hash_get(zl3vni->nh_table, &tmp_n, zl3vni_nh_alloc);
|
n = hash_get(zl3vni->nh_table, &tmp_n, zl3vni_nh_alloc);
|
||||||
assert(n);
|
assert(n);
|
||||||
|
|
||||||
|
n->host_list = list_new();
|
||||||
|
n->host_list->cmp = (int (*)(void *, void *))prefix_cmp;
|
||||||
|
|
||||||
memcpy(&n->emac, mac, ETH_ALEN);
|
memcpy(&n->emac, mac, ETH_ALEN);
|
||||||
SET_FLAG(n->flags, ZEBRA_NEIGH_REMOTE);
|
SET_FLAG(n->flags, ZEBRA_NEIGH_REMOTE);
|
||||||
SET_FLAG(n->flags, ZEBRA_NEIGH_REMOTE_NH);
|
SET_FLAG(n->flags, ZEBRA_NEIGH_REMOTE_NH);
|
||||||
@ -3037,9 +3087,10 @@ static int zl3vni_nh_uninstall(zebra_l3vni_t *zl3vni,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* add remote vtep as a neigh entry */
|
/* add remote vtep as a neigh entry */
|
||||||
static int zebra_vxlan_l3vni_remote_nh_add(zebra_l3vni_t *zl3vni,
|
static int zl3vni_remote_nh_add(zebra_l3vni_t *zl3vni,
|
||||||
struct ipaddr *vtep_ip,
|
struct ipaddr *vtep_ip,
|
||||||
struct ethaddr *rmac)
|
struct ethaddr *rmac,
|
||||||
|
struct prefix *host_prefix)
|
||||||
{
|
{
|
||||||
char buf[ETHER_ADDR_STRLEN];
|
char buf[ETHER_ADDR_STRLEN];
|
||||||
char buf1[INET6_ADDRSTRLEN];
|
char buf1[INET6_ADDRSTRLEN];
|
||||||
@ -3063,13 +3114,17 @@ static int zebra_vxlan_l3vni_remote_nh_add(zebra_l3vni_t *zl3vni,
|
|||||||
/* install the nh neigh in kernel */
|
/* install the nh neigh in kernel */
|
||||||
zl3vni_nh_install(zl3vni, nh);
|
zl3vni_nh_install(zl3vni, nh);
|
||||||
}
|
}
|
||||||
nh->nh_refcnt++;
|
|
||||||
|
if (!is_host_present_in_host_list(nh->host_list, host_prefix))
|
||||||
|
host_list_add_host(nh->host_list, host_prefix);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* handle nh neigh delete */
|
/* handle nh neigh delete */
|
||||||
static int zebra_vxlan_l3vni_remote_nh_del(zebra_l3vni_t *zl3vni,
|
static int zl3vni_remote_nh_del(zebra_l3vni_t *zl3vni,
|
||||||
struct ipaddr *vtep_ip)
|
struct ipaddr *vtep_ip,
|
||||||
|
struct prefix *host_prefix)
|
||||||
{
|
{
|
||||||
zebra_neigh_t *nh = NULL;
|
zebra_neigh_t *nh = NULL;
|
||||||
|
|
||||||
@ -3077,8 +3132,8 @@ static int zebra_vxlan_l3vni_remote_nh_del(zebra_l3vni_t *zl3vni,
|
|||||||
if (!nh)
|
if (!nh)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
nh->nh_refcnt--;
|
host_list_delete_host(nh->host_list, host_prefix);
|
||||||
if (!nh->nh_refcnt) {
|
if (list_isempty(nh->host_list)) {
|
||||||
|
|
||||||
/* uninstall from kernel */
|
/* uninstall from kernel */
|
||||||
zl3vni_nh_uninstall(zl3vni, nh);
|
zl3vni_nh_uninstall(zl3vni, nh);
|
||||||
@ -3533,7 +3588,8 @@ static int zebra_vxlan_handle_vni_transition(struct zebra_vrf *zvrf,
|
|||||||
/* handle evpn route in vrf table */
|
/* handle evpn route in vrf table */
|
||||||
void zebra_vxlan_evpn_vrf_route_add(vrf_id_t vrf_id,
|
void zebra_vxlan_evpn_vrf_route_add(vrf_id_t vrf_id,
|
||||||
struct ethaddr *rmac,
|
struct ethaddr *rmac,
|
||||||
struct ipaddr *ip)
|
struct ipaddr *vtep_ip,
|
||||||
|
struct prefix *host_prefix)
|
||||||
{
|
{
|
||||||
zebra_l3vni_t *zl3vni = NULL;
|
zebra_l3vni_t *zl3vni = NULL;
|
||||||
|
|
||||||
@ -3542,16 +3598,17 @@ void zebra_vxlan_evpn_vrf_route_add(vrf_id_t vrf_id,
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
/* add the next hop neighbor */
|
/* add the next hop neighbor */
|
||||||
zebra_vxlan_l3vni_remote_nh_add(zl3vni, ip, rmac);
|
zl3vni_remote_nh_add(zl3vni, vtep_ip, rmac, host_prefix);
|
||||||
|
|
||||||
/* add the rmac */
|
/* add the rmac */
|
||||||
zebra_vxlan_l3vni_remote_rmac_add(zl3vni, rmac, ip);
|
zl3vni_remote_rmac_add(zl3vni, rmac, vtep_ip, host_prefix);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* handle evpn vrf route delete */
|
/* handle evpn vrf route delete */
|
||||||
void zebra_vxlan_evpn_vrf_route_del(vrf_id_t vrf_id,
|
void zebra_vxlan_evpn_vrf_route_del(vrf_id_t vrf_id,
|
||||||
struct ethaddr *rmac,
|
struct ethaddr *rmac,
|
||||||
struct ipaddr *ip)
|
struct ipaddr *vtep_ip,
|
||||||
|
struct prefix *host_prefix)
|
||||||
{
|
{
|
||||||
zebra_l3vni_t *zl3vni = NULL;
|
zebra_l3vni_t *zl3vni = NULL;
|
||||||
|
|
||||||
@ -3560,10 +3617,10 @@ void zebra_vxlan_evpn_vrf_route_del(vrf_id_t vrf_id,
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
/* delete the next hop entry */
|
/* delete the next hop entry */
|
||||||
zebra_vxlan_l3vni_remote_nh_del(zl3vni, ip);
|
zl3vni_remote_nh_del(zl3vni, vtep_ip, host_prefix);
|
||||||
|
|
||||||
/* delete the rmac entry */
|
/* delete the rmac entry */
|
||||||
zebra_vxlan_l3vni_remote_rmac_del(zl3vni, rmac);
|
zl3vni_remote_rmac_del(zl3vni, rmac, host_prefix);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -147,9 +147,11 @@ extern void zebra_vxlan_ns_init(struct zebra_ns *zns);
|
|||||||
extern void zebra_vxlan_ns_disable(struct zebra_ns *zns);
|
extern void zebra_vxlan_ns_disable(struct zebra_ns *zns);
|
||||||
extern void zebra_vxlan_evpn_vrf_route_add(vrf_id_t vrf_id,
|
extern void zebra_vxlan_evpn_vrf_route_add(vrf_id_t vrf_id,
|
||||||
struct ethaddr *rmac,
|
struct ethaddr *rmac,
|
||||||
struct ipaddr *ip);
|
struct ipaddr *ip,
|
||||||
|
struct prefix *host_prefix);
|
||||||
extern void zebra_vxlan_evpn_vrf_route_del(vrf_id_t vrf_id,
|
extern void zebra_vxlan_evpn_vrf_route_del(vrf_id_t vrf_id,
|
||||||
struct ethaddr *rmac,
|
struct ethaddr *rmac,
|
||||||
struct ipaddr *ip);
|
struct ipaddr *vtep_ip,
|
||||||
|
struct prefix *host_prefix);
|
||||||
|
|
||||||
#endif /* _ZEBRA_VXLAN_H */
|
#endif /* _ZEBRA_VXLAN_H */
|
||||||
|
@ -242,8 +242,8 @@ struct zebra_mac_t_ {
|
|||||||
/* List of neigh associated with this mac */
|
/* List of neigh associated with this mac */
|
||||||
struct list *neigh_list;
|
struct list *neigh_list;
|
||||||
|
|
||||||
/* Refcnt of number of mac-ips */
|
/* list of hosts pointing to this remote RMAC */
|
||||||
u_int32_t rmac_refcnt;
|
struct list *host_list;
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -315,8 +315,8 @@ struct zebra_neigh_t_ {
|
|||||||
/* Remote VTEP IP - applicable only for remote neighbors. */
|
/* Remote VTEP IP - applicable only for remote neighbors. */
|
||||||
struct in_addr r_vtep_ip;
|
struct in_addr r_vtep_ip;
|
||||||
|
|
||||||
/* refcnt of remote mac-ip referring to a NH neigh */
|
/* list of hosts pointing to this remote NH entry */
|
||||||
u_int32_t nh_refcnt;
|
struct list *host_list;
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -1192,7 +1192,8 @@ static int zread_route_add(struct zserv *client, u_short length,
|
|||||||
zebra_vxlan_evpn_vrf_route_add(
|
zebra_vxlan_evpn_vrf_route_add(
|
||||||
vrf_id,
|
vrf_id,
|
||||||
&api.rmac,
|
&api.rmac,
|
||||||
&vtep_ip);
|
&vtep_ip,
|
||||||
|
&api.prefix);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -1297,7 +1298,7 @@ static int zread_route_del(struct zserv *client, u_short length,
|
|||||||
|
|
||||||
rib_delete(afi, api.safi, zvrf_id(zvrf), api.type, api.instance,
|
rib_delete(afi, api.safi, zvrf_id(zvrf), api.type, api.instance,
|
||||||
api.flags, &api.prefix, src_p, NULL, zvrf->table_id,
|
api.flags, &api.prefix, src_p, NULL, zvrf->table_id,
|
||||||
api.metric, false);
|
api.metric, false, &api.rmac);
|
||||||
|
|
||||||
/* Stats */
|
/* Stats */
|
||||||
switch (api.prefix.family) {
|
switch (api.prefix.family) {
|
||||||
@ -1498,7 +1499,7 @@ static int zread_ipv4_delete(struct zserv *client, u_short length,
|
|||||||
table_id = zvrf->table_id;
|
table_id = zvrf->table_id;
|
||||||
|
|
||||||
rib_delete(AFI_IP, api.safi, zvrf_id(zvrf), api.type, api.instance,
|
rib_delete(AFI_IP, api.safi, zvrf_id(zvrf), api.type, api.instance,
|
||||||
api.flags, &p, NULL, NULL, table_id, 0, false);
|
api.flags, &p, NULL, NULL, table_id, 0, false, NULL);
|
||||||
client->v4_route_del_cnt++;
|
client->v4_route_del_cnt++;
|
||||||
|
|
||||||
stream_failure:
|
stream_failure:
|
||||||
@ -1916,7 +1917,8 @@ static int zread_ipv6_delete(struct zserv *client, u_short length,
|
|||||||
src_pp = NULL;
|
src_pp = NULL;
|
||||||
|
|
||||||
rib_delete(AFI_IP6, api.safi, zvrf_id(zvrf), api.type, api.instance,
|
rib_delete(AFI_IP6, api.safi, zvrf_id(zvrf), api.type, api.instance,
|
||||||
api.flags, &p, src_pp, NULL, client->rtm_table, 0, false);
|
api.flags, &p, src_pp, NULL, client->rtm_table, 0, false,
|
||||||
|
NULL);
|
||||||
|
|
||||||
client->v6_route_del_cnt++;
|
client->v6_route_del_cnt++;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user