summaryrefslogtreecommitdiff
path: root/node/InetAddress.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'node/InetAddress.cpp')
-rw-r--r--node/InetAddress.cpp23
1 files changed, 21 insertions, 2 deletions
diff --git a/node/InetAddress.cpp b/node/InetAddress.cpp
index 30b1ff2e..3f6b9be6 100644
--- a/node/InetAddress.cpp
+++ b/node/InetAddress.cpp
@@ -395,7 +395,6 @@ bool InetAddress::operator<(const InetAddress &a) const
}
InetAddress InetAddress::makeIpv6LinkLocal(const MAC &mac)
- throw()
{
struct sockaddr_in6 sin6;
sin6.sin6_family = AF_INET6;
@@ -420,7 +419,6 @@ InetAddress InetAddress::makeIpv6LinkLocal(const MAC &mac)
}
InetAddress InetAddress::makeIpv6rfc4193(uint64_t nwid,uint64_t zeroTierAddress)
- throw()
{
InetAddress r;
struct sockaddr_in6 *const sin6 = reinterpret_cast<struct sockaddr_in6 *>(&r);
@@ -445,4 +443,25 @@ InetAddress InetAddress::makeIpv6rfc4193(uint64_t nwid,uint64_t zeroTierAddress)
return r;
}
+InetAddress InetAddress::makeIpv66plane(uint64_t nwid,uint64_t zeroTierAddress)
+{
+ nwid ^= (nwid >> 32);
+ InetAddress r;
+ struct sockaddr_in6 *const sin6 = reinterpret_cast<struct sockaddr_in6 *>(&r);
+ sin6->sin6_family = AF_INET6;
+ sin6->sin6_addr.s6_addr[0] = 0xfc;
+ sin6->sin6_addr.s6_addr[1] = (uint8_t)(nwid >> 24);
+ sin6->sin6_addr.s6_addr[2] = (uint8_t)(nwid >> 16);
+ sin6->sin6_addr.s6_addr[3] = (uint8_t)(nwid >> 8);
+ sin6->sin6_addr.s6_addr[4] = (uint8_t)nwid;
+ sin6->sin6_addr.s6_addr[5] = (uint8_t)(zeroTierAddress >> 32);
+ sin6->sin6_addr.s6_addr[6] = (uint8_t)(zeroTierAddress >> 24);
+ sin6->sin6_addr.s6_addr[7] = (uint8_t)(zeroTierAddress >> 16);
+ sin6->sin6_addr.s6_addr[8] = (uint8_t)(zeroTierAddress >> 8);
+ sin6->sin6_addr.s6_addr[9] = (uint8_t)zeroTierAddress;
+ sin6->sin6_addr.s6_addr[15] = 0x01;
+ sin6->sin6_port = Utils::hton((uint16_t)40);
+ return r;
+}
+
} // namespace ZeroTier