Commit c7535333 authored by Juliusz Chroboczek's avatar Juliusz Chroboczek

Add a function to determine an interface's link-local addresses.

parent ff148e90
...@@ -29,6 +29,35 @@ THE SOFTWARE. ...@@ -29,6 +29,35 @@ THE SOFTWARE.
#include "kernel_netlink.c" #include "kernel_netlink.c"
#endif #endif
/* Return an interface's link-local addresses */
int
kernel_ll_addresses(char *ifname, int ifindex,
unsigned char (*addresses)[16], int maxaddr)
{
struct kernel_route routes[64];
int rc, i, j;
rc = kernel_addresses(ifname, ifindex, routes, 64);
if(rc < 0)
return -1;
j = 0;
for(i = 0; i < rc; i++) {
unsigned char *prefix;
if(j >= maxaddr)
break;
if(routes[i].ifindex != ifindex)
continue;
prefix = routes[i].prefix;
if(prefix[0] == 0xFE && prefix[1] == 0x80 &&
memcmp(prefix + 2, zeroes, 6) == 0) {
memcpy(addresses[j], prefix, 16);
j++;
}
}
return j;
}
/* Like gettimeofday, but should return monotonic time. If POSIX clocks /* Like gettimeofday, but should return monotonic time. If POSIX clocks
are not available, falls back to gettimeofday. */ are not available, falls back to gettimeofday. */
int int
......
...@@ -59,4 +59,6 @@ int kernel_routes(struct kernel_route *routes, int maxroutes); ...@@ -59,4 +59,6 @@ int kernel_routes(struct kernel_route *routes, int maxroutes);
int kernel_callback(int (*fn)(int, void*), void *closure); int kernel_callback(int (*fn)(int, void*), void *closure);
int kernel_addresses(char *ifname, int ifindex, int kernel_addresses(char *ifname, int ifindex,
struct kernel_route *routes, int maxroutes); struct kernel_route *routes, int maxroutes);
int kernel_ll_addresses(char *ifname, int ifindex,
unsigned char (*addresses)[16], int maxaddr);
int gettime(struct timeval *tv); int gettime(struct timeval *tv);
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