summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorSteven Barth <steven@midlink.org>2015-03-11 10:06:54 +0100
committerSteven Barth <steven@midlink.org>2015-03-11 10:07:21 +0100
commita3bffff7f3e6411c8737454381ac21dcf62a6dcd (patch)
treed237a9175fb6bb9ca83432b0eed9dacc38ae2019 /src
parent8d9b60fb496000988f3633951f2e30380fc2de50 (diff)
downloadodhcp6c-a3bffff7f3e6411c8737454381ac21dcf62a6dcd.tar.gz
Get rid of getifaddrs for interface ID detection
Signed-off-by: Steven Barth <steven@midlink.org>
Diffstat (limited to 'src')
-rw-r--r--src/ra.c35
1 files changed, 9 insertions, 26 deletions
diff --git a/src/ra.c b/src/ra.c
index b21bc56..54cf086 100644
--- a/src/ra.c
+++ b/src/ra.c
@@ -13,7 +13,6 @@
*/
#include <fcntl.h>
-#include <ifaddrs.h>
#include <stdio.h>
#include <signal.h>
#include <string.h>
@@ -252,37 +251,21 @@ bool ra_process(void)
{
bool found = false;
bool changed = false;
- bool has_lladdr = !IN6_IS_ADDR_UNSPECIFIED(&lladdr);
uint8_t buf[1500], cmsg_buf[128];
struct nd_router_advert *adv = (struct nd_router_advert*)buf;
struct odhcp6c_entry entry = {IN6ADDR_ANY_INIT, 0, 0, IN6ADDR_ANY_INIT, 0, 0, 0, 0, 0, 0};
const struct in6_addr any = IN6ADDR_ANY_INIT;
- if (!has_lladdr) {
- // Autodetect interface-id if not specified
- struct ifaddrs *ifaddr, *ifa;
+ if (IN6_IS_ADDR_UNSPECIFIED(&lladdr)) {
+ struct sockaddr_in6 addr = {AF_INET6, 0, 0, ALL_IPV6_ROUTERS, if_index};
+ socklen_t alen = sizeof(addr);
+ int sock = socket(AF_INET6, SOCK_RAW, IPPROTO_ICMPV6);
- if (getifaddrs(&ifaddr) == 0) {
- for (ifa = ifaddr; ifa != NULL; ifa = ifa->ifa_next) {
- struct sockaddr_in6 *addr;
+ if (!connect(sock, (struct sockaddr*)&addr, sizeof(addr)) &&
+ !getsockname(sock, (struct sockaddr*)&addr, &alen))
+ lladdr = addr.sin6_addr;
- if (ifa->ifa_addr == NULL || ifa->ifa_addr->sa_family != AF_INET6)
- continue;
-
- addr = (struct sockaddr_in6*)ifa->ifa_addr;
-
- if (!IN6_IS_ADDR_LINKLOCAL(&addr->sin6_addr))
- continue;
-
- if (!strcmp(ifa->ifa_name, if_name)) {
- lladdr = addr->sin6_addr;
- has_lladdr = true;
- break;
- }
- }
-
- freeifaddrs(ifaddr);
- }
+ close(sock);
}
while (true) {
@@ -295,7 +278,7 @@ bool ra_process(void)
if (len <= 0)
break;
- if (!has_lladdr)
+ if (IN6_IS_ADDR_UNSPECIFIED(&lladdr))
continue;
int hlim = 0;