Various other fixes including removal of more mem*() issues and netlink fixes for AARCH64.

This commit is contained in:
Adam Ierymenko 2019-03-25 22:19:52 +00:00
parent d5ac8512e3
commit d81549a7b1
5 changed files with 74 additions and 59 deletions

View File

@ -79,6 +79,8 @@ public:
_maxCustodyChainLength(0), _maxCustodyChainLength(0),
_ruleCount(0) _ruleCount(0)
{ {
memset(_rules,0,sizeof(_rules));
memset(_custody,0,sizeof(_custody));
} }
/** /**

View File

@ -200,10 +200,11 @@ bool NetworkConfig::toDictionary(Dictionary<ZT_NETWORKCONFIG_DICT_CAPACITY> &d,b
bool NetworkConfig::fromDictionary(const Dictionary<ZT_NETWORKCONFIG_DICT_CAPACITY> &d) bool NetworkConfig::fromDictionary(const Dictionary<ZT_NETWORKCONFIG_DICT_CAPACITY> &d)
{ {
static const NetworkConfig NIL_NC;
Buffer<ZT_NETWORKCONFIG_DICT_CAPACITY> *tmp = new Buffer<ZT_NETWORKCONFIG_DICT_CAPACITY>(); Buffer<ZT_NETWORKCONFIG_DICT_CAPACITY> *tmp = new Buffer<ZT_NETWORKCONFIG_DICT_CAPACITY>();
try { try {
*this = NetworkConfig(); *this = NIL_NC;
// Fields that are always present, new or old // Fields that are always present, new or old
this->networkId = d.getUI(ZT_NETWORKCONFIG_DICT_KEY_NETWORK_ID,0); this->networkId = d.getUI(ZT_NETWORKCONFIG_DICT_KEY_NETWORK_ID,0);

View File

@ -89,6 +89,7 @@ public:
_issuedTo(issuedTo), _issuedTo(issuedTo),
_signedBy() _signedBy()
{ {
memset(_signature.data,0,sizeof(_signature.data));
} }
inline uint32_t id() const { return _id; } inline uint32_t id() const { return _id; }

View File

@ -29,7 +29,6 @@
#include <unistd.h> #include <unistd.h>
#include <linux/if_tun.h> #include <linux/if_tun.h>
namespace ZeroTier { namespace ZeroTier {
struct nl_route_req { struct nl_route_req {
@ -63,7 +62,6 @@ LinuxNetLink::LinuxNetLink()
, _fd(socket(AF_NETLINK, SOCK_RAW, NETLINK_ROUTE)) , _fd(socket(AF_NETLINK, SOCK_RAW, NETLINK_ROUTE))
, _la({0}) , _la({0})
{ {
// set socket timeout to 1 sec so we're not permablocking recv() calls // set socket timeout to 1 sec so we're not permablocking recv() calls
_setSocketTimeout(_fd, 1); _setSocketTimeout(_fd, 1);
@ -75,11 +73,8 @@ LinuxNetLink::LinuxNetLink()
::exit(1); ::exit(1);
} }
fprintf(stderr, "Requesting IPV4 Routes\n");
_requestIPv4Routes(); _requestIPv4Routes();
fprintf(stderr, "Requesting IPV6 Routes\n");
_requestIPv6Routes(); _requestIPv6Routes();
fprintf(stderr, "Requesting Interface List\n");
_requestInterfaceList(); _requestInterfaceList();
_running = true; _running = true;
@ -90,7 +85,6 @@ LinuxNetLink::~LinuxNetLink()
{ {
_running = false; _running = false;
Thread::join(_t); Thread::join(_t);
::close(_fd); ::close(_fd);
} }
@ -108,15 +102,20 @@ void LinuxNetLink::_setSocketTimeout(int fd, int seconds)
int LinuxNetLink::_doRecv(int fd) int LinuxNetLink::_doRecv(int fd)
{ {
char buf[8192]; char *const buf = (char *)valloc(8192);
if (!buf) {
fprintf(stderr,"malloc failed!\n");
::exit(1);
}
char *p = NULL; char *p = NULL;
struct nlmsghdr *nlp; struct nlmsghdr *nlp;
int nll = 0; int nll = 0;
int rtn = 0; int rtn = 0;
p = buf; p = buf;
while(true) { for(;;) {
rtn = recv(fd, p, sizeof(buf) - nll, 0); rtn = recv(fd, p, 8192 - nll, 0);
if (rtn > 0) { if (rtn > 0) {
nlp = (struct nlmsghdr *)p; nlp = (struct nlmsghdr *)p;
@ -124,9 +123,9 @@ int LinuxNetLink::_doRecv(int fd)
if(nlp->nlmsg_type == NLMSG_ERROR && (nlp->nlmsg_flags & NLM_F_ACK) != NLM_F_ACK) { if(nlp->nlmsg_type == NLMSG_ERROR && (nlp->nlmsg_flags & NLM_F_ACK) != NLM_F_ACK) {
struct nlmsgerr *err = (struct nlmsgerr*)NLMSG_DATA(nlp); struct nlmsgerr *err = (struct nlmsgerr*)NLMSG_DATA(nlp);
if (err->error != 0) { if (err->error != 0) {
#ifdef ZT_TRACE //#ifdef ZT_TRACE
fprintf(stderr, "rtnetlink error: %s\n", strerror(-(err->error))); fprintf(stderr, "rtnetlink error: %s\n", strerror(-(err->error)));
#endif //#endif
} }
p = buf; p = buf;
nll = 0; nll = 0;
@ -150,9 +149,9 @@ int LinuxNetLink::_doRecv(int fd)
} }
if (nlp->nlmsg_type == NLMSG_OVERRUN) { if (nlp->nlmsg_type == NLMSG_OVERRUN) {
#ifdef ZT_TRACE //#ifdef ZT_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;
@ -161,6 +160,7 @@ int LinuxNetLink::_doRecv(int fd)
nll += rtn; nll += rtn;
_processMessage(nlp, nll); _processMessage(nlp, nll);
p = buf; p = buf;
nll = 0; nll = 0;
break; break;
@ -168,6 +168,9 @@ int LinuxNetLink::_doRecv(int fd)
break; break;
} }
} }
free(buf);
return rtn; return rtn;
} }
@ -242,8 +245,9 @@ void LinuxNetLink::_ipAddressAdded(struct nlmsghdr *nlp)
break; break;
} }
} }
#ifdef ZT_TRACE #ifdef ZT_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
} }
@ -275,8 +279,9 @@ void LinuxNetLink::_ipAddressDeleted(struct nlmsghdr *nlp)
break; break;
} }
} }
#ifdef ZT_TRACE #ifdef ZT_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
} }
@ -288,7 +293,7 @@ void LinuxNetLink::_routeAdded(struct nlmsghdr *nlp)
char ifs[16] = {0}; char ifs[16] = {0};
char ms[24] = {0}; char ms[24] = {0};
struct rtmsg *rtp = (struct rtmsg *) NLMSG_DATA(nlp); struct rtmsg *rtp = (struct rtmsg *)NLMSG_DATA(nlp);
struct rtattr *rtap = (struct rtattr *)RTM_RTA(rtp); struct rtattr *rtap = (struct rtattr *)RTM_RTA(rtp);
int rtl = RTM_PAYLOAD(nlp); int rtl = RTM_PAYLOAD(nlp);
@ -311,8 +316,9 @@ void LinuxNetLink::_routeAdded(struct nlmsghdr *nlp)
} }
} }
sprintf(ms, "%d", rtp->rtm_dst_len); sprintf(ms, "%d", rtp->rtm_dst_len);
#ifdef ZT_TRACE #ifdef ZT_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
} }
@ -349,7 +355,7 @@ void LinuxNetLink::_routeDeleted(struct nlmsghdr *nlp)
sprintf(ms, "%d", rtp->rtm_dst_len); sprintf(ms, "%d", rtp->rtm_dst_len);
#ifdef ZT_TRACE #ifdef ZT_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
} }
@ -394,8 +400,9 @@ void LinuxNetLink::_linkAdded(struct nlmsghdr *nlp)
memcpy(entry.mac_bin, mac_bin, 6); memcpy(entry.mac_bin, mac_bin, 6);
entry.mtu = mtu; entry.mtu = mtu;
} }
#ifdef ZT_TRACE #ifdef ZT_TRACE
fprintf(stderr, "Link Added: %s mac: %s, mtu: %d\n", ifname, mac, mtu); //fprintf(stderr, "Link Added: %s mac: %s, mtu: %d\n", ifname, mac, mtu);
#endif #endif
} }
@ -428,9 +435,11 @@ void LinuxNetLink::_linkDeleted(struct nlmsghdr *nlp)
break; break;
} }
} }
#ifdef ZT_TRACE #ifdef ZT_TRACE
fprintf(stderr, "Link Deleted: %s mac: %s, mtu: %d\n", ifname, mac, mtu); //fprintf(stderr, "Link Deleted: %s mac: %s, mtu: %d\n", ifname, mac, mtu);
#endif #endif
{ {
Mutex::Lock l(_if_m); Mutex::Lock l(_if_m);
if(_interfaces.contains(ifip->ifi_index)) { if(_interfaces.contains(ifip->ifi_index)) {
@ -454,7 +463,8 @@ void LinuxNetLink::_requestIPv4Routes()
la.nl_pid = getpid(); la.nl_pid = getpid();
la.nl_groups = RTMGRP_IPV4_ROUTE; la.nl_groups = RTMGRP_IPV4_ROUTE;
if(bind(fd, (struct sockaddr*)&la, sizeof(la))) { if(bind(fd, (struct sockaddr*)&la, sizeof(la))) {
fprintf(stderr, "Error binding RTNETLINK: %s\n", strerror(errno)); fprintf(stderr, "Error binding RTNETLINK (_requiestIPv4Routes #1): %s\n", strerror(errno));
close(fd);
return; return;
} }
@ -506,7 +516,8 @@ void LinuxNetLink::_requestIPv6Routes()
la.nl_pid = getpid(); la.nl_pid = getpid();
la.nl_groups = RTMGRP_IPV6_ROUTE; la.nl_groups = RTMGRP_IPV6_ROUTE;
if(bind(fd, (struct sockaddr*)&la, sizeof(struct sockaddr_nl))) { if(bind(fd, (struct sockaddr*)&la, sizeof(struct sockaddr_nl))) {
fprintf(stderr, "Error binding RTNETLINK: %s\n", strerror(errno)); fprintf(stderr, "Error binding RTNETLINK (_requestIPv6Routes #1): %s\n", strerror(errno));
close(fd);
return; return;
} }
@ -558,7 +569,8 @@ void LinuxNetLink::_requestInterfaceList()
la.nl_pid = getpid(); la.nl_pid = getpid();
la.nl_groups = RTMGRP_LINK; la.nl_groups = RTMGRP_LINK;
if(bind(fd, (struct sockaddr*)&la, sizeof(struct sockaddr_nl))) { if(bind(fd, (struct sockaddr*)&la, sizeof(struct sockaddr_nl))) {
fprintf(stderr, "Error binding RTNETLINK: %s\n", strerror(errno)); fprintf(stderr, "Error binding RTNETLINK (_requestInterfaceList #1): %s\n", strerror(errno));
close(fd);
return; return;
} }
@ -595,6 +607,8 @@ void LinuxNetLink::_requestInterfaceList()
void LinuxNetLink::addRoute(const InetAddress &target, const InetAddress &via, const InetAddress &src, const char *ifaceName) void LinuxNetLink::addRoute(const InetAddress &target, const InetAddress &via, const InetAddress &src, const char *ifaceName)
{ {
if (!target) return;
int fd = socket(AF_NETLINK, SOCK_RAW, NETLINK_ROUTE); int fd = socket(AF_NETLINK, SOCK_RAW, NETLINK_ROUTE);
if (fd == -1) { if (fd == -1) {
fprintf(stderr, "Error opening RTNETLINK socket: %s\n", strerror(errno)); fprintf(stderr, "Error opening RTNETLINK socket: %s\n", strerror(errno));
@ -609,24 +623,18 @@ void LinuxNetLink::addRoute(const InetAddress &target, const InetAddress &via, c
la.nl_pid = getpid(); la.nl_pid = getpid();
if(bind(fd, (struct sockaddr*)&la, sizeof(struct sockaddr_nl))) { if(bind(fd, (struct sockaddr*)&la, sizeof(struct sockaddr_nl))) {
fprintf(stderr, "Error binding RTNETLINK: %s\n", strerror(errno)); fprintf(stderr, "Error binding RTNETLINK (addRoute #1): %s\n", strerror(errno));
close(fd);
return; return;
} }
#ifdef ZT_TRACE #ifdef ZT_TRACE
char tmp[64]; //char tmp[64];
char tmp2[64]; //char tmp2[64];
char tmp3[64]; //char tmp3[64];
fprintf(stderr, "Adding Route. target: %s via: %s src: %s iface: %s\n", target.toString(tmp), via.toString(tmp2), src.toString(tmp3), ifaceName); //fprintf(stderr, "Adding Route. target: %s via: %s src: %s iface: %s\n", target.toString(tmp), via.toString(tmp2), src.toString(tmp3), ifaceName);
#endif #endif
if(!target) {
#ifdef ZT_TRACE
fprintf(stderr, "Uhhhh adding an empty route?!?!?");
#endif
return;
}
int rtl = sizeof(struct rtmsg); int rtl = sizeof(struct rtmsg);
struct nl_route_req req; struct nl_route_req req;
bzero(&req, sizeof(req)); bzero(&req, sizeof(req));
@ -678,8 +686,6 @@ void LinuxNetLink::addRoute(const InetAddress &target, const InetAddress &via, c
} }
} }
req.nl.nlmsg_len = NLMSG_LENGTH(rtl); req.nl.nlmsg_len = NLMSG_LENGTH(rtl);
req.nl.nlmsg_flags = NLM_F_REQUEST | NLM_F_EXCL | NLM_F_CREATE | NLM_F_ACK; req.nl.nlmsg_flags = NLM_F_REQUEST | NLM_F_EXCL | NLM_F_CREATE | NLM_F_ACK;
req.nl.nlmsg_type = RTM_NEWROUTE; req.nl.nlmsg_type = RTM_NEWROUTE;
@ -717,6 +723,8 @@ void LinuxNetLink::addRoute(const InetAddress &target, const InetAddress &via, c
void LinuxNetLink::delRoute(const InetAddress &target, const InetAddress &via, const InetAddress &src, const char *ifaceName) void LinuxNetLink::delRoute(const InetAddress &target, const InetAddress &via, const InetAddress &src, const char *ifaceName)
{ {
if (!target) return;
int fd = socket(AF_NETLINK, SOCK_RAW, NETLINK_ROUTE); int fd = socket(AF_NETLINK, SOCK_RAW, NETLINK_ROUTE);
if (fd == -1) { if (fd == -1) {
fprintf(stderr, "Error opening RTNETLINK socket: %s\n", strerror(errno)); fprintf(stderr, "Error opening RTNETLINK socket: %s\n", strerror(errno));
@ -730,22 +738,17 @@ void LinuxNetLink::delRoute(const InetAddress &target, const InetAddress &via, c
la.nl_pid = getpid(); la.nl_pid = getpid();
if(bind(fd, (struct sockaddr*)&la, sizeof(struct sockaddr_nl))) { if(bind(fd, (struct sockaddr*)&la, sizeof(struct sockaddr_nl))) {
fprintf(stderr, "Error binding RTNETLINK: %s\n", strerror(errno)); fprintf(stderr, "Error binding RTNETLINK (delRoute #1): %s\n", strerror(errno));
close(fd);
return; return;
} }
#ifdef ZT_TRACE
char tmp[64];
char tmp2[64];
char tmp3[64];
fprintf(stderr, "Removing Route. target: %s via: %s src: %s iface: %s\n", target.toString(tmp), via.toString(tmp2), src.toString(tmp3), ifaceName);
#endif
if(!target) {
#ifdef ZT_TRACE #ifdef ZT_TRACE
fprintf(stderr, "Uhhhh deleting an empty route?!?!?"); //char tmp[64];
//char tmp2[64];
//char tmp3[64];
//fprintf(stderr, "Removing Route. target: %s via: %s src: %s iface: %s\n", target.toString(tmp), via.toString(tmp2), src.toString(tmp3), ifaceName);
#endif #endif
return;
}
int rtl = sizeof(struct rtmsg); int rtl = sizeof(struct rtmsg);
struct nl_route_req req; struct nl_route_req req;
@ -798,8 +801,6 @@ void LinuxNetLink::delRoute(const InetAddress &target, const InetAddress &via, c
} }
} }
req.nl.nlmsg_len = NLMSG_LENGTH(rtl); req.nl.nlmsg_len = NLMSG_LENGTH(rtl);
req.nl.nlmsg_flags = NLM_F_REQUEST; req.nl.nlmsg_flags = NLM_F_REQUEST;
req.nl.nlmsg_type = RTM_DELROUTE; req.nl.nlmsg_type = RTM_DELROUTE;
@ -846,6 +847,7 @@ void LinuxNetLink::addAddress(const InetAddress &addr, const char *iface)
_setSocketTimeout(fd); _setSocketTimeout(fd);
struct sockaddr_nl la; struct sockaddr_nl la;
memset(&la,0,sizeof(la));
la.nl_family = AF_NETLINK; la.nl_family = AF_NETLINK;
la.nl_pid = getpid(); la.nl_pid = getpid();
if (addr.isV4()) { if (addr.isV4()) {
@ -853,18 +855,23 @@ void LinuxNetLink::addAddress(const InetAddress &addr, const char *iface)
} else { } else {
la.nl_groups = RTMGRP_IPV6_IFADDR; la.nl_groups = RTMGRP_IPV6_IFADDR;
} }
if(bind(fd, (struct sockaddr*)&la, sizeof(struct sockaddr_nl))) { if(bind(fd, (struct sockaddr*)&la, sizeof(struct sockaddr_nl))) {
fprintf(stderr, "Error binding RTNETLINK: %s\n", strerror(errno)); fprintf(stderr, "Error binding RTNETLINK (addAddress #1): %s\n", strerror(errno));
close(fd);
return; return;
} }
#ifdef ZT_TRACE #ifdef ZT_TRACE
char tmp[128]; //char tmp[128];
fprintf(stderr, "Adding IP address %s to interface %s", addr.toString(tmp), iface); //fprintf(stderr, "Adding IP address %s to interface %s", addr.toString(tmp), iface);
#endif #endif
int interface_index = _indexForInterface(iface); int interface_index = _indexForInterface(iface);
if (interface_index == -1) { if (interface_index == -1) {
fprintf(stderr, "Unable to find index for interface %s\n", iface); fprintf(stderr, "Unable to find index for interface %s\n", iface);
close(fd);
return; return;
} }
@ -962,17 +969,21 @@ void LinuxNetLink::removeAddress(const InetAddress &addr, const char *iface)
la.nl_groups = RTMGRP_IPV6_IFADDR; la.nl_groups = RTMGRP_IPV6_IFADDR;
} }
if(bind(fd, (struct sockaddr*)&la, sizeof(struct sockaddr_nl))) { if(bind(fd, (struct sockaddr*)&la, sizeof(struct sockaddr_nl))) {
fprintf(stderr, "Error binding RTNETLINK: %s\n", strerror(errno)); fprintf(stderr, "Error binding RTNETLINK (removeAddress #1): %s\n", strerror(errno));
close(fd);
return; return;
} }
#ifdef ZT_TRACE #ifdef ZT_TRACE
char tmp[128]; //char tmp[128];
fprintf(stderr, "Removing IP address %s from interface %s", addr.toString(tmp), iface); //fprintf(stderr, "Removing IP address %s from interface %s", addr.toString(tmp), iface);
#endif #endif
int interface_index = _indexForInterface(iface); int interface_index = _indexForInterface(iface);
if (interface_index == -1) { if (interface_index == -1) {
fprintf(stderr, "Unable to find index for interface %s\n", iface); fprintf(stderr, "Unable to find index for interface %s\n", iface);
close(fd);
return; return;
} }

View File

@ -621,7 +621,7 @@ public:
_incomingPacketConcurrency = tmp; _incomingPacketConcurrency = tmp;
} }
} }
for(long t=0;t<_incomingPacketConcurrency;++t) { for(unsigned long t=0;t<_incomingPacketConcurrency;++t) {
_incomingPacketThreads.push_back(std::thread([this]() { _incomingPacketThreads.push_back(std::thread([this]() {
OneServiceIncomingPacket *pkt = nullptr; OneServiceIncomingPacket *pkt = nullptr;
for(;;) { for(;;) {