我需要從用戶空間訪問IF_RA_MANAGED
和IF_RA_OTHERCONF
(in6_dev->if_flags
)。從用戶空間訪問IF_RA_MANAGED和IF_RA_OTHERCONF
有誰知道我該怎麼做?
感謝
我需要從用戶空間訪問IF_RA_MANAGED
和IF_RA_OTHERCONF
(in6_dev->if_flags
)。從用戶空間訪問IF_RA_MANAGED和IF_RA_OTHERCONF
有誰知道我該怎麼做?
感謝
我想你可以用PF_NETLINK
插座做到這一點。
的ip
效用,這是iproute2
部分具有似乎顯示該信息,例如監視模式:
[email protected]:/tmp/iproute-20100519/ip > ip -6 monitor
2: eth0 inet6 2001:XXXX:XXXX:0:XXXX:XXXX:XXXX:XXXX/64 scope global dynamic
valid_lft 86400sec preferred_lft 14400sec
prefix 2001:XXXX:XXXX::X/64 dev eth0 onlink autoconf valid 14400 preferred 131084
(對於偏執起見移除了一些詳細的地址)。我沒有任何在這個局域網上設置這些標誌的RA,但我99%確定他們也會出現在那裏。
與strace
周圍戳顯示了有趣的通話似乎是:
socket(PF_NETLINK, SOCK_RAW, 0) = 3
setsockopt(3, SOL_SOCKET, SO_SNDBUF, [32768], 4) = 0
setsockopt(3, SOL_SOCKET, SO_RCVBUF, [1048576], 4) = 0
bind(3, {sa_family=AF_NETLINK, pid=0, groups=fffffff7}, 12) = 0
getsockname(3, {sa_family=AF_NETLINK, pid=7151, groups=fffffff7}, [12]) = 0
time(NULL) = 1309595579
send(3, "...", 20, 0) = 20
recvmsg(3, {msg_name(12)={sa_family=AF_NETLINK, pid=0, groups=00000000}, msg_iov(1)=[{"...", 16384}], msg_controllen=0, msg_flags=0}, 0) = 864
爲iproute2
源有一個文件,ip/ipmonitor.c
,這似乎做的大部分工作:
int print_prefix(const struct sockaddr_nl *who, struct nlmsghdr *n, void *arg);
int accept_msg(const struct sockaddr_nl *who,
struct nlmsghdr *n, void *arg)
{
// Snipped some unrelated stuff
if (n->nlmsg_type == RTM_NEWPREFIX) {
if (prefix_banner)
fprintf(fp, "[PREFIX]");
print_prefix(who, n, arg);
return 0;
}
}
所以我認爲你應該能夠使用這個解決方案。
此問題已在其重複「Where m flag and o flag will be stored in Linux」中得到解答。具體來說,問題海報發現他的問題的解決方案,並在博客上發佈代碼http://kumaran127.blogspot.jp/2013/05/get-m-and-o-flag-of-most-recently.html。
'onlink'和'autoconf'是前綴標誌,但otherconf和manager不是前綴標誌。他們是inet6_dev.if_flags – drizzt