From: Timo Teräs Date: Sat, 23 May 2015 08:08:38 +0000 (+0300) Subject: lib: make sockunion2str safer to use X-Git-Tag: frr-2.0-rc1~732 X-Git-Url: https://git.puffer.fish/?a=commitdiff_plain;h=67e2b6f013abb23b42f9e2f85e5a3a44916b617c;p=mirror%2Ffrr.git lib: make sockunion2str safer to use It's mostly used for logging, and the return value is never checked, so try to make it valid. Signed-off-by: Timo Teräs Signed-off-by: David Lamparter (cherry picked from commit 53009d387a633997b16d32224b50451b5c81b61a) --- diff --git a/lib/sockunion.c b/lib/sockunion.c index fdff61f542..4fd5f1444c 100644 --- a/lib/sockunion.c +++ b/lib/sockunion.c @@ -166,13 +166,20 @@ str2sockunion (const char *str, union sockunion *su) const char * sockunion2str (union sockunion *su, char *buf, size_t len) { - if (su->sa.sa_family == AF_INET) - return inet_ntop (AF_INET, &su->sin.sin_addr, buf, len); + switch (sockunion_family(su)) + { + case AF_UNSPEC: + snprintf (buf, len, "(unspec)"); + return buf; + case AF_INET: + return inet_ntop (AF_INET, &su->sin.sin_addr, buf, len); #ifdef HAVE_IPV6 - else if (su->sa.sa_family == AF_INET6) - return inet_ntop (AF_INET6, &su->sin6.sin6_addr, buf, len); + case AF_INET6: + return inet_ntop (AF_INET6, &su->sin6.sin6_addr, buf, len); #endif /* HAVE_IPV6 */ - return NULL; + } + snprintf (buf, len, "(af %d)", sockunion_family(su)); + return buf; } union sockunion *