Adam Ierymenko 147945d20f Lets try always supplying the AES keys to Packet dearmor() and see if that prevents the coma problem. 4 years ago
..
AES.cpp 9d66d876f4 Likely fix for some alignment issues on ARM. 4 years ago
AES.hpp 70f37962cf Backport AES fixes for compiler, arch, and splitting into separate files. 4 years ago
AES_aesni.cpp dd65680150 Windows build fixes, version bump in AIP. 4 years ago
AES_armcrypto.cpp a624dfd776 Fixing regression in AES for ARM targets 4 years ago
Address.hpp 06730c7d1d BSL date bump 5 years ago
AtomicCounter.hpp 06730c7d1d BSL date bump 5 years ago
Bond.cpp ecfac0601a Add new bond control commands to CLI 4 years ago
Bond.hpp ecfac0601a Add new bond control commands to CLI 4 years ago
BondController.cpp ecfac0601a Add new bond control commands to CLI 4 years ago
BondController.hpp ecfac0601a Add new bond control commands to CLI 4 years ago
Buffer.hpp 06730c7d1d BSL date bump 5 years ago
C25519.cpp 2ac49d99dd AES integrated on send side. 5 years ago
C25519.hpp 06730c7d1d BSL date bump 5 years ago
Capability.cpp 06730c7d1d BSL date bump 5 years ago
Capability.hpp 06730c7d1d BSL date bump 5 years ago
CertificateOfMembership.cpp 06730c7d1d BSL date bump 5 years ago
CertificateOfMembership.hpp 06730c7d1d BSL date bump 5 years ago
CertificateOfOwnership.cpp 06730c7d1d BSL date bump 5 years ago
CertificateOfOwnership.hpp 06730c7d1d BSL date bump 5 years ago
Constants.hpp 9d66d876f4 Likely fix for some alignment issues on ARM. 4 years ago
Credential.hpp 06730c7d1d BSL date bump 5 years ago
DNS.hpp 06730c7d1d BSL date bump 5 years ago
Dictionary.hpp 06730c7d1d BSL date bump 5 years ago
Flow.hpp 06730c7d1d BSL date bump 5 years ago
Hashtable.hpp 06730c7d1d BSL date bump 5 years ago
Identity.cpp 2ac49d99dd AES integrated on send side. 5 years ago
Identity.hpp 7219ca0c0f AES works! Only with this or newer nodes. Uses salsa with older ones as usual. 4 years ago
IncomingPacket.cpp 147945d20f Lets try always supplying the AES keys to Packet dearmor() and see if that prevents the coma problem. 4 years ago
IncomingPacket.hpp 06730c7d1d BSL date bump 5 years ago
InetAddress.cpp de308f05e0 missing break in InetAddress::ipScope() 4 years ago
InetAddress.hpp 90f18f7ee7 Fix for ZTO-33 (Jira), only assign routes if there is a viable source IP. 4 years ago
MAC.hpp 06730c7d1d BSL date bump 5 years ago
Membership.cpp 06730c7d1d BSL date bump 5 years ago
Membership.hpp 06730c7d1d BSL date bump 5 years ago
MulticastGroup.hpp 06730c7d1d BSL date bump 5 years ago
Multicaster.cpp 44af828aa4 Tweak multicast settings to prevent failures due to TX queue overflow. 4 years ago
Multicaster.hpp 9480ff1f37 Fix some timestamp signedness mismatches. 4 years ago
Mutex.hpp 06730c7d1d BSL date bump 5 years ago
Network.cpp dc806dd718 Try pipelining tap reads on Linux for a little more speed. 4 years ago
Network.hpp 06730c7d1d BSL date bump 5 years ago
NetworkConfig.cpp 06730c7d1d BSL date bump 5 years ago
NetworkConfig.hpp 06730c7d1d BSL date bump 5 years ago
NetworkController.hpp 06730c7d1d BSL date bump 5 years ago
Node.cpp 06730c7d1d BSL date bump 5 years ago
Node.hpp 06730c7d1d BSL date bump 5 years ago
OutboundMulticast.cpp 06730c7d1d BSL date bump 5 years ago
OutboundMulticast.hpp 06730c7d1d BSL date bump 5 years ago
Packet.cpp 31d8758ad9 Apple "fat binaries" are back! 4 years ago
Packet.hpp e6b5f8aabd AES work... but disabled in this commit. 4 years ago
Path.cpp 06730c7d1d BSL date bump 5 years ago
Path.hpp ecfac0601a Add new bond control commands to CLI 4 years ago
Peer.cpp ac808d51d6 Crash fix 4 years ago
Peer.hpp 147945d20f Lets try always supplying the AES keys to Packet dearmor() and see if that prevents the coma problem. 4 years ago
Poly1305.cpp d530356055 RingBuffer<> is now templated with size, buffer is now static. 6 years ago
Poly1305.hpp 06730c7d1d BSL date bump 5 years ago
README.md 8a2ff0b31e Actual documentation. 8 years ago
Revocation.cpp 06730c7d1d BSL date bump 5 years ago
Revocation.hpp 06730c7d1d BSL date bump 5 years ago
RingBuffer.hpp 06730c7d1d BSL date bump 5 years ago
RuntimeEnvironment.hpp 06730c7d1d BSL date bump 5 years ago
SHA512.cpp 1ad555a071 More selective push of AES modifications and refactoring stuff. 4 years ago
SHA512.hpp 2ac49d99dd AES integrated on send side. 5 years ago
Salsa20.cpp 9681fedbb4 Spellcheck sweep across codebase 7 years ago
Salsa20.hpp 41c187ba12 Another very small crypto optimization. 8 years ago
SelfAwareness.cpp 06730c7d1d BSL date bump 5 years ago
SelfAwareness.hpp 06730c7d1d BSL date bump 5 years ago
SharedPtr.hpp 06730c7d1d BSL date bump 5 years ago
Switch.cpp 26a0cbcd73 Revert "Push credentials in multicast." 4 years ago
Switch.hpp 06730c7d1d BSL date bump 5 years ago
Tag.cpp 06730c7d1d BSL date bump 5 years ago
Tag.hpp 06730c7d1d BSL date bump 5 years ago
Topology.cpp d64c5a92c6 Merge pull request #1233 from dosuperuser/improvement/optimizations 4 years ago
Topology.hpp 06730c7d1d BSL date bump 5 years ago
Trace.cpp 06730c7d1d BSL date bump 5 years ago
Trace.hpp 06730c7d1d BSL date bump 5 years ago
Utils.cpp 31d8758ad9 Apple "fat binaries" are back! 4 years ago
Utils.hpp 90f18f7ee7 Fix for ZTO-33 (Jira), only assign routes if there is a viable source IP. 4 years ago
World.hpp 06730c7d1d BSL date bump 5 years ago

README.md

ZeroTier Network Hypervisor Core

This directory contains the real ZeroTier: a completely OS-independent global virtual Ethernet switch engine. This is where the magic happens.

Give it wire packets and it gives you Ethernet packets, and vice versa. The core contains absolutely no actual I/O, port configuration, or other OS-specific code (except Utils::getSecureRandom()). It provides a simple C API via /include/ZeroTierOne.h. It's designed to be small and maximally portable for future use on small embedded and special purpose systems.

Code in here follows these guidelines:

  • Keep it minimal, especially in terms of code footprint and memory use.
  • There should be no OS-dependent code here unless absolutely necessary (e.g. getSecureRandom).
  • If it's not part of the core virtual Ethernet switch it does not belong here.
  • No C++11 or C++14 since older and embedded compilers don't support it yet and this should be maximally portable.
  • Minimize the use of complex C++ features since at some point we might end up "minus-minus'ing" this code if doing so proves necessary to port to tiny embedded systems.