#c #networking #ipv6 #netlink
#c #сеть #ipv6 #netlink
Вопрос:
Я пытаюсь установить IPv6-адрес интерфейса, используя libnl
. Просматривая документацию и другие ресурсы, это в основном то, что я пытаюсь сделать:
static int set_ipv6(const char *if_name, const char *ipv6) {
struct rtnl_link *link = NULL;
struct nl_sock *sk = NULL;
struct rtnl_addr *ipv6_addr = NULL;
struct nl_addr* lo_ipv6_addr = NULL;
struct nl_cache *link_cache = NULL;
int err = 0;
int ifindex = 0;
sk = nl_socket_alloc();
if ((err = nl_connect(sk, NETLINK_ROUTE)) < 0) {
nl_perror(err, "nl_connect");
return err;
}
ipv6_addr = rtnl_addr_alloc();
if ((err = nl_addr_parse(ipv6, AF_INET6, amp;lo_ipv6_addr)) < 0) {
nl_perror(err, "nl_addr_parse");
return err;
}
printf("This part segfaultsn");
if((err = rtnl_addr_set_local(ipv6_addr, lo_ipv6_addr)) < 0) {
nl_perror(err, "rtnl_addr_set_local");
return err;
}
if ((err = rtnl_link_alloc_cache(sk, AF_UNSPEC, amp;link_cache)) < 0) {
nl_perror(err, "rtnl_link_alloc_cache");
return err;
}
if((link = rtnl_link_get_by_name(link_cache, if_name)) == NULL) {
return -1;
}
if((ifindex = rtnl_link_get_ifindex(link)) == 0) {
fprintf(stderr,"index of %s not setn", if_name);
return -1;
}
rtnl_addr_set_ifindex(ipv6_addr, ifindex);
rtnl_addr_set_link(ipv6_addr, link);
if ((err = rtnl_addr_add(sk, ipv6_addr, 0)) < 0) {
nl_perror(err, "rtnl_addr_add");
return err;
}
nl_addr_put(lo_ipv6_addr);
rtnl_addr_put(ipv6_addr);
nl_cache_free(link_cache);
nl_socket_free(sk);
rtnl_link_put(link);
return 0;
}
Очевидно, что я вызываю этот код с помощью чего-то вроде:
set_ipv6("veth1", "fc00:dead:cafe:1::2");
Где veth1 является допустимым устройством veth.
Однако по какой-то странной причине этот код, похоже, segfault, как только rtnl_addr_set_local
вызывается, поскольку он пытается разыменовать недопустимый адрес в rdi
регистре при настройке стека.
Есть идеи, что может быть не так или это может быть ошибкой libnl
?
Спасибо!
Ответ №1:
Понял это, кажется, мне не хватало директивы include, точнее — заголовка addr.h .
#include <netlink/route/addr.h>