Commit 122a0c73 authored by Juliusz Chroboczek's avatar Juliusz Chroboczek

Add link-local addresses to interface dump.

parent 06acd47c
...@@ -26,6 +26,7 @@ THE SOFTWARE. ...@@ -26,6 +26,7 @@ THE SOFTWARE.
#include <unistd.h> #include <unistd.h>
#include <errno.h> #include <errno.h>
#include <sys/time.h> #include <sys/time.h>
#include <arpa/inet.h>
#include "babeld.h" #include "babeld.h"
#include "interface.h" #include "interface.h"
...@@ -90,13 +91,26 @@ static void ...@@ -90,13 +91,26 @@ static void
local_notify_interface_1(struct local_socket *s, local_notify_interface_1(struct local_socket *s,
struct interface *ifp, int kind) struct interface *ifp, int kind)
{ {
char buf[512]; char buf[512], v4[INET_ADDRSTRLEN];
int rc; int rc;
int up;
up = if_up(ifp);
if(up && ifp->ipv4)
inet_ntop(AF_INET, ifp->ipv4, v4, INET_ADDRSTRLEN);
else
v4[0] = '\0';
if(up)
rc = snprintf(buf, 512,
"%s interface %s up true%s%s%s%s\n",
local_kind(kind), ifp->name,
ifp->ll ? " ipv6 " : "",
ifp->ll ? format_address(*ifp->ll) : "",
v4[0] ? " ipv4 " : "", v4);
else
rc = snprintf(buf, 512, "%s interface %s up false\n",
local_kind(kind), ifp->name);
rc = snprintf(buf, 512,
"%s interface %s up %s\n",
local_kind(kind), ifp->name,
if_up(ifp) ? "true" : "false");
if(rc < 0 || rc >= 512) if(rc < 0 || rc >= 512)
goto fail; goto fail;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment