|
@@ -45,10 +45,6 @@ struct nl_adr_req {
|
|
LinuxNetLink::LinuxNetLink()
|
|
LinuxNetLink::LinuxNetLink()
|
|
: _t()
|
|
: _t()
|
|
, _running(false)
|
|
, _running(false)
|
|
- , _routes_ipv4()
|
|
|
|
- , _rv4_m()
|
|
|
|
- , _routes_ipv6()
|
|
|
|
- , _rv6_m()
|
|
|
|
, _seq(0)
|
|
, _seq(0)
|
|
, _interfaces()
|
|
, _interfaces()
|
|
, _if_m()
|
|
, _if_m()
|
|
@@ -147,9 +143,9 @@ int LinuxNetLink::_doRecv(int fd)
|
|
}
|
|
}
|
|
|
|
|
|
if (nlp->nlmsg_type == NLMSG_OVERRUN) {
|
|
if (nlp->nlmsg_type == NLMSG_OVERRUN) {
|
|
-//#ifdef ZT_NETLINK_TRACE
|
|
|
|
|
|
+#ifdef ZT_NETLINK_TRACE
|
|
fprintf(stderr, "NLMSG_OVERRUN: Data lost\n");
|
|
fprintf(stderr, "NLMSG_OVERRUN: Data lost\n");
|
|
-//#endif
|
|
|
|
|
|
+#endif
|
|
p = buf;
|
|
p = buf;
|
|
nll = 0;
|
|
nll = 0;
|
|
break;
|
|
break;
|
|
@@ -175,11 +171,10 @@ int LinuxNetLink::_doRecv(int fd)
|
|
void LinuxNetLink::threadMain() throw()
|
|
void LinuxNetLink::threadMain() throw()
|
|
{
|
|
{
|
|
int rtn = 0;
|
|
int rtn = 0;
|
|
-
|
|
|
|
while(_running) {
|
|
while(_running) {
|
|
rtn = _doRecv(_fd);
|
|
rtn = _doRecv(_fd);
|
|
if (rtn <= 0) {
|
|
if (rtn <= 0) {
|
|
- Thread::sleep(100);
|
|
|
|
|
|
+ Thread::sleep(250);
|
|
continue;
|
|
continue;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
@@ -217,6 +212,7 @@ void LinuxNetLink::_processMessage(struct nlmsghdr *nlp, int nll)
|
|
|
|
|
|
void LinuxNetLink::_ipAddressAdded(struct nlmsghdr *nlp)
|
|
void LinuxNetLink::_ipAddressAdded(struct nlmsghdr *nlp)
|
|
{
|
|
{
|
|
|
|
+#ifdef ZT_NETLINK_TRACE
|
|
struct ifaddrmsg *ifap = (struct ifaddrmsg *)NLMSG_DATA(nlp);
|
|
struct ifaddrmsg *ifap = (struct ifaddrmsg *)NLMSG_DATA(nlp);
|
|
struct rtattr *rtap = (struct rtattr *)IFA_RTA(ifap);
|
|
struct rtattr *rtap = (struct rtattr *)IFA_RTA(ifap);
|
|
int ifal = IFA_PAYLOAD(nlp);
|
|
int ifal = IFA_PAYLOAD(nlp);
|
|
@@ -244,13 +240,13 @@ void LinuxNetLink::_ipAddressAdded(struct nlmsghdr *nlp)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
-#ifdef ZT_NETLINK_TRACE
|
|
|
|
fprintf(stderr,"Added IP Address %s local: %s label: %s broadcast: %s\n", addr, local, label, bcast);
|
|
fprintf(stderr,"Added IP Address %s local: %s label: %s broadcast: %s\n", addr, local, label, bcast);
|
|
#endif
|
|
#endif
|
|
}
|
|
}
|
|
|
|
|
|
void LinuxNetLink::_ipAddressDeleted(struct nlmsghdr *nlp)
|
|
void LinuxNetLink::_ipAddressDeleted(struct nlmsghdr *nlp)
|
|
{
|
|
{
|
|
|
|
+#ifdef ZT_NETLINK_TRACE
|
|
struct ifaddrmsg *ifap = (struct ifaddrmsg *)NLMSG_DATA(nlp);
|
|
struct ifaddrmsg *ifap = (struct ifaddrmsg *)NLMSG_DATA(nlp);
|
|
struct rtattr *rtap = (struct rtattr *)IFA_RTA(ifap);
|
|
struct rtattr *rtap = (struct rtattr *)IFA_RTA(ifap);
|
|
int ifal = IFA_PAYLOAD(nlp);
|
|
int ifal = IFA_PAYLOAD(nlp);
|
|
@@ -278,13 +274,13 @@ void LinuxNetLink::_ipAddressDeleted(struct nlmsghdr *nlp)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
-#ifdef ZT_NETLINK_TRACE
|
|
|
|
fprintf(stderr, "Removed IP Address %s local: %s label: %s broadcast: %s\n", addr, local, label, bcast);
|
|
fprintf(stderr, "Removed IP Address %s local: %s label: %s broadcast: %s\n", addr, local, label, bcast);
|
|
#endif
|
|
#endif
|
|
}
|
|
}
|
|
|
|
|
|
void LinuxNetLink::_routeAdded(struct nlmsghdr *nlp)
|
|
void LinuxNetLink::_routeAdded(struct nlmsghdr *nlp)
|
|
{
|
|
{
|
|
|
|
+#ifdef ZT_NETLINK_TRACE
|
|
char dsts[40] = {0};
|
|
char dsts[40] = {0};
|
|
char gws[40] = {0};
|
|
char gws[40] = {0};
|
|
char srcs[40] = {0};
|
|
char srcs[40] = {0};
|
|
@@ -315,13 +311,13 @@ void LinuxNetLink::_routeAdded(struct nlmsghdr *nlp)
|
|
}
|
|
}
|
|
sprintf(ms, "%d", rtp->rtm_dst_len);
|
|
sprintf(ms, "%d", rtp->rtm_dst_len);
|
|
|
|
|
|
-#ifdef ZT_NETLINK_TRACE
|
|
|
|
fprintf(stderr, "Route Added: dst %s/%s gw %s src %s if %s\n", dsts, ms, gws, srcs, ifs);
|
|
fprintf(stderr, "Route Added: dst %s/%s gw %s src %s if %s\n", dsts, ms, gws, srcs, ifs);
|
|
#endif
|
|
#endif
|
|
}
|
|
}
|
|
|
|
|
|
void LinuxNetLink::_routeDeleted(struct nlmsghdr *nlp)
|
|
void LinuxNetLink::_routeDeleted(struct nlmsghdr *nlp)
|
|
{
|
|
{
|
|
|
|
+#ifdef ZT_NETLINK_TRACE
|
|
char dsts[40] = {0};
|
|
char dsts[40] = {0};
|
|
char gws[40] = {0};
|
|
char gws[40] = {0};
|
|
char srcs[40] = {0};
|
|
char srcs[40] = {0};
|
|
@@ -352,7 +348,6 @@ void LinuxNetLink::_routeDeleted(struct nlmsghdr *nlp)
|
|
}
|
|
}
|
|
sprintf(ms, "%d", rtp->rtm_dst_len);
|
|
sprintf(ms, "%d", rtp->rtm_dst_len);
|
|
|
|
|
|
-#ifdef ZT_NETLINK_TRACE
|
|
|
|
fprintf(stderr, "Route Deleted: dst %s/%s gw %s src %s if %s\n", dsts, ms, gws, srcs, ifs);
|
|
fprintf(stderr, "Route Deleted: dst %s/%s gw %s src %s if %s\n", dsts, ms, gws, srcs, ifs);
|
|
#endif
|
|
#endif
|
|
}
|
|
}
|
|
@@ -1045,16 +1040,6 @@ void LinuxNetLink::removeAddress(const InetAddress &addr, const char *iface)
|
|
close(fd);
|
|
close(fd);
|
|
}
|
|
}
|
|
|
|
|
|
-RouteList LinuxNetLink::getIPV4Routes() const
|
|
|
|
-{
|
|
|
|
- return _routes_ipv4;
|
|
|
|
-}
|
|
|
|
-
|
|
|
|
-RouteList LinuxNetLink::getIPV6Routes() const
|
|
|
|
-{
|
|
|
|
- return _routes_ipv6;
|
|
|
|
-}
|
|
|
|
-
|
|
|
|
int LinuxNetLink::_indexForInterface(const char *iface)
|
|
int LinuxNetLink::_indexForInterface(const char *iface)
|
|
{
|
|
{
|
|
Mutex::Lock l(_if_m);
|
|
Mutex::Lock l(_if_m);
|