summaryrefslogtreecommitdiffstats
path: root/zebra/rt_netlink.h
diff options
context:
space:
mode:
authorChirag Shah <chirag@cumulusnetworks.com>2018-12-11 06:33:16 +0100
committerChirag Shah <chirag@cumulusnetworks.com>2018-12-31 23:40:31 +0100
commit67fb9374dcdebc4b6e135118fe53a9054aa93382 (patch)
treee6aea55ca52473017968f742e5cca724bf052ae8 /zebra/rt_netlink.h
parentzebra: netlink_request consolidataion (diff)
downloadfrr-67fb9374dcdebc4b6e135118fe53a9054aa93382.tar.xz
frr-67fb9374dcdebc4b6e135118fe53a9054aa93382.zip
zebra: evpn remote delete fetch local entry
An EVPN type-2 entry is in freeze state during remote update, remote VTEP can send typ-2 withdraw update, upon receiving an entry delete (withdraw), first check kernel has in local reachable state. Upon unfreeze use the local entry to advertise to peers. Fetch is for both MAC and IP, delete can come for only MAC or MAC-IP combined route. The specific entry fetch only required request flag to be set, dump flag is not required. Testing Done: Simulate two VTEPs to do M1, IP1 mobility sequence, freeze MAC during remote MAC update, subsequently send withdraw type-2 route from origintating VTEP. This results in read apis to invoke for local reachable entry. Zebra updates its cache and upon unfreeze originates type-2. Signed-off-by: Chirag Shah <chirag@cumulusnetworks.com>
Diffstat (limited to 'zebra/rt_netlink.h')
-rw-r--r--zebra/rt_netlink.h5
1 files changed, 5 insertions, 0 deletions
diff --git a/zebra/rt_netlink.h b/zebra/rt_netlink.h
index cefd1996a..b778583e2 100644
--- a/zebra/rt_netlink.h
+++ b/zebra/rt_netlink.h
@@ -71,6 +71,11 @@ extern int netlink_macfdb_read_for_bridge(struct zebra_ns *zns,
extern int netlink_neigh_read(struct zebra_ns *zns);
extern int netlink_neigh_read_for_vlan(struct zebra_ns *zns,
struct interface *vlan_if);
+extern int netlink_macfdb_read_specific_mac(struct zebra_ns *zns,
+ struct interface *br_if,
+ struct ethaddr *mac, uint16_t vid);
+extern int netlink_neigh_read_specific_ip(struct ipaddr *ip,
+ struct interface *vlan_if);
#endif /* HAVE_NETLINK */