summaryrefslogtreecommitdiff
path: root/node
diff options
context:
space:
mode:
authorAdam Ierymenko <adam.ierymenko@gmail.com>2013-07-06 15:56:12 -0400
committerAdam Ierymenko <adam.ierymenko@gmail.com>2013-07-06 15:56:12 -0400
commit2eaac3891ec5f6da0ba9577bd032fd692392dd40 (patch)
treee20e47dc23bc290b96268084baa32e891fff7b76 /node
parent7f3dea018c8034208b40e2633b04d06f917c1957 (diff)
downloadinfinitytier-2eaac3891ec5f6da0ba9577bd032fd692392dd40.tar.gz
infinitytier-2eaac3891ec5f6da0ba9577bd032fd692392dd40.zip
Enable ff:ff:ff:ff:ff:ff w/no ADI a.k.a. broadcast. YOLO.
Diffstat (limited to 'node')
-rw-r--r--node/EthernetTap.cpp8
-rw-r--r--node/EthernetTap.hpp3
-rw-r--r--node/Switch.cpp8
3 files changed, 16 insertions, 3 deletions
diff --git a/node/EthernetTap.cpp b/node/EthernetTap.cpp
index 596cc5c2..68884464 100644
--- a/node/EthernetTap.cpp
+++ b/node/EthernetTap.cpp
@@ -31,6 +31,10 @@
#include "Logger.hpp"
#include "RuntimeEnvironment.hpp"
#include "Mutex.hpp"
+#include "MulticastGroup.hpp"
+
+// ff:ff:ff:ff:ff:ff with no ADI
+static const ZeroTier::MulticastGroup _blindWildcardMulticastGroup(ZeroTier::MAC(0xff),0);
/* ======================================================================== */
#if defined(__linux__) || defined(linux) || defined(__LINUX__) || defined(__linux)
@@ -337,6 +341,8 @@ bool EthernetTap::updateMulticastGroups(std::set<MulticastGroup> &groups)
bool changed = false;
+ newGroups.insert(_blindWildcardMulticastGroup); // always join this
+
for(std::set<MulticastGroup>::iterator mg(newGroups.begin());mg!=newGroups.end();++mg) {
if (!groups.count(*mg)) {
groups.insert(*mg);
@@ -658,6 +664,8 @@ bool EthernetTap::updateMulticastGroups(std::set<MulticastGroup> &groups)
bool changed = false;
+ newGroups.insert(_blindWildcardMulticastGroup); // always join this
+
for(std::set<MulticastGroup>::iterator mg(newGroups.begin());mg!=newGroups.end();++mg) {
if (!groups.count(*mg)) {
groups.insert(*mg);
diff --git a/node/EthernetTap.hpp b/node/EthernetTap.hpp
index bf1d0eef..5c666907 100644
--- a/node/EthernetTap.hpp
+++ b/node/EthernetTap.hpp
@@ -164,6 +164,9 @@ public:
* This populates a set or, if already populated, modifies it to contain
* only multicast groups in which this device is interested.
*
+ * This should always include the blind wildcard MulticastGroup (MAC of
+ * ff:ff:ff:ff:ff:ff and 0 ADI field).
+ *
* @param groups Set to modify in place
* @return True if set was changed since last call
*/
diff --git a/node/Switch.cpp b/node/Switch.cpp
index 87218b0d..ed646308 100644
--- a/node/Switch.cpp
+++ b/node/Switch.cpp
@@ -252,9 +252,11 @@ void Switch::onLocalEthernet(const SharedPtr<Network> &network,const MAC &from,c
if (to.isMulticast()) {
MulticastGroup mg(to,0);
- // Handle special cases: IPv4 ARP
- if ((etherType == ZT_ETHERTYPE_ARP)&&(data.size() == 28)&&(data[2] == 0x08)&&(data[3] == 0x00)&&(data[4] == 6)&&(data[5] == 4)&&(data[7] == 0x01))
- mg = MulticastGroup::deriveMulticastGroupForAddressResolution(InetAddress(data.field(24,4),4,0));
+ if (to.isBroadcast()) {
+ // Cram IPv4 IP into ADI field to make IPv4 ARP broadcast channel specific and scalable
+ if ((etherType == ZT_ETHERTYPE_ARP)&&(data.size() == 28)&&(data[2] == 0x08)&&(data[3] == 0x00)&&(data[4] == 6)&&(data[5] == 4)&&(data[7] == 0x01))
+ mg = MulticastGroup::deriveMulticastGroupForAddressResolution(InetAddress(data.field(24,4),4,0));
+ }
// Remember this message's CRC, but don't drop if we've already seen it
// since it's our own.