]> git.proxmox.com Git - mirror_frr.git/commitdiff
nhrpd: Clear shortcut routes properly for all protocols
authorGaurav Goyal <gaurav.goyal@4rf.com>
Sun, 1 Nov 2020 23:11:19 +0000 (12:11 +1300)
committerReuben Dowle <reuben.dowle@4rf.com>
Wed, 16 Dec 2020 21:17:07 +0000 (10:17 +1300)
Currently when nhrp shortcuts are purged they will not be recreated. This
patch fixes that by ensuring the shortcut routes get purged correctly.

This situation can be reproduced by first allowing a shortcut to be created
then clearing the shortcut:
clear ip nhrp cache
clear ip nhrp shortcuts

Signed-off-by: Reuben Dowle <reuben.dowle@4rf.com>
lib/sockunion.c [changed mode: 0644->0755]
lib/sockunion.h [changed mode: 0644->0755]
nhrpd/nhrp_route.c [changed mode: 0644->0755]

old mode 100644 (file)
new mode 100755 (executable)
index c999845..1dbf77e
@@ -708,3 +708,20 @@ static ssize_t printfrr_psu(char *buf, size_t bsz, const char *fmt,
        fb.pos[0] = '\0';
        return consumed;
 }
+
+int sockunion_is_null(const union sockunion *su)
+{
+       unsigned char null_s6_addr[16] = {0};
+
+       switch (sockunion_family(su)) {
+       case AF_UNSPEC:
+               return 1;
+       case AF_INET:
+               return (su->sin.sin_addr.s_addr == 0);
+       case AF_INET6:
+               return !memcmp(su->sin6.sin6_addr.s6_addr, null_s6_addr,
+                              sizeof(null_s6_addr));
+       default:
+               return 0;
+       }
+}
old mode 100644 (file)
new mode 100755 (executable)
index 72f12b7..5e80ba1
@@ -102,6 +102,7 @@ extern union sockunion *sockunion_getpeername(int);
 extern union sockunion *sockunion_dup(const union sockunion *);
 extern void sockunion_free(union sockunion *);
 extern void sockunion_init(union sockunion *);
+extern int sockunion_is_null(const union sockunion *su);
 
 #ifdef _FRR_ATTRIBUTE_PRINTFRR
 #pragma FRR printfrr_ext "%pSU"  (union sockunion *)
old mode 100644 (file)
new mode 100755 (executable)
index e7d35b9..ce2b1fe
@@ -56,7 +56,7 @@ static void nhrp_route_update_put(struct route_node *rn)
        struct route_info *ri = rn->info;
 
        if (!ri->ifp && !ri->nhrp_ifp
-           && sockunion_family(&ri->via) == AF_UNSPEC) {
+           && sockunion_is_null(&ri->via)) {
                XFREE(MTYPE_NHRP_ROUTE, rn->info);
                route_unlock_node(rn);
        }
@@ -70,8 +70,7 @@ static void nhrp_route_update_zebra(const struct prefix *p,
        struct route_node *rn;
        struct route_info *ri;
 
-       rn = nhrp_route_update_get(
-               p, (sockunion_family(nexthop) != AF_UNSPEC) || ifp);
+       rn = nhrp_route_update_get(p, !sockunion_is_null(nexthop) || ifp);
        if (rn) {
                ri = rn->info;
                ri->via = *nexthop;
@@ -225,7 +224,7 @@ int nhrp_route_read(ZAPI_CALLBACK_ARGS)
               sockunion2str(&nexthop_addr, buf, sizeof(buf)),
               ifp ? ifp->name : "(none)");
 
-       nhrp_route_update_zebra(&api.prefix, &nexthop_addr, ifp);
+       nhrp_route_update_zebra(&api.prefix, &nexthop_addr, added ? ifp : NULL);
        nhrp_shortcut_prefix_change(&api.prefix, !added);
 
        return 0;