]> git.ipfire.org Git - thirdparty/iproute2.git/commitdiff
ip: Properly display AF_BRIDGE address information for neighbor events
authorDonald Sharp <sharpd@cumulusnetworks.com>
Fri, 23 Feb 2018 19:10:09 +0000 (14:10 -0500)
committerStephen Hemminger <stephen@networkplumber.org>
Fri, 23 Feb 2018 19:27:09 +0000 (11:27 -0800)
The vxlan driver when a neighbor add/delete event occurs sends
NDA_DST filled with a union:

union vxlan_addr {
struct sockaddr_in sin;
struct sockaddr_in6 sin6;
struct sockaddr sa;
};

This eventually calls rt_addr_n2a_r which had no handler for the
AF_BRIDGE family and "???" was being printed.

Add code to properly display this data when requested.

Signed-off-by: Donald Sharp <sharpd@cumulusnetworks.com>
Signed-off-by: Stephen Hemminger <stephen@networkplumber.org>
lib/utils.c

index 8e15625e0c1ec1af66afb1da391aad9e0c46ce66..379739d61246dc0d544257a282f164d8bcc17a1d 100644 (file)
@@ -983,6 +983,25 @@ const char *rt_addr_n2a_r(int af, int len,
        }
        case AF_PACKET:
                return ll_addr_n2a(addr, len, ARPHRD_VOID, buf, buflen);
+       case AF_BRIDGE:
+       {
+               const union {
+                       struct sockaddr sa;
+                       struct sockaddr_in sin;
+                       struct sockaddr_in6 sin6;
+               } *sa = addr;
+
+               switch (sa->sa.sa_family) {
+               case AF_INET:
+                       return inet_ntop(AF_INET, &sa->sin.sin_addr,
+                                        buf, buflen);
+               case AF_INET6:
+                       return inet_ntop(AF_INET6, &sa->sin6.sin6_addr,
+                                        buf, buflen);
+               }
+
+               /* fallthrough */
+       }
        default:
                return "???";
        }