summaryrefslogtreecommitdiff
path: root/node/Multicaster.cpp
diff options
context:
space:
mode:
authorAdam Ierymenko <adam.ierymenko@gmail.com>2014-10-09 17:58:31 -0700
committerAdam Ierymenko <adam.ierymenko@gmail.com>2014-10-09 17:58:31 -0700
commit4941c8a1f393c50259ae2cc0f1e8b79068d44af3 (patch)
tree81860de8661732dd62bcc33169bf6db1b663c94d /node/Multicaster.cpp
parentd5e0f7e3e453482bf6e7d6d8cb76a68ecc26b287 (diff)
downloadinfinitytier-4941c8a1f393c50259ae2cc0f1e8b79068d44af3.tar.gz
infinitytier-4941c8a1f393c50259ae2cc0f1e8b79068d44af3.zip
New multicast bug fixes, TRACE improvements, and temporarily disable legacy multicast for debugging purposes.
Diffstat (limited to 'node/Multicaster.cpp')
-rw-r--r--node/Multicaster.cpp29
1 files changed, 19 insertions, 10 deletions
diff --git a/node/Multicaster.cpp b/node/Multicaster.cpp
index 191a1db3..c94ac34b 100644
--- a/node/Multicaster.cpp
+++ b/node/Multicaster.cpp
@@ -28,6 +28,7 @@
#include <algorithm>
#include "Constants.hpp"
+#include "RuntimeEnvironment.hpp"
#include "SharedPtr.hpp"
#include "Multicaster.hpp"
#include "Topology.hpp"
@@ -37,7 +38,7 @@
#include "CMWC4096.hpp"
#include "C25519.hpp"
#include "CertificateOfMembership.hpp"
-#include "RuntimeEnvironment.hpp"
+#include "Logger.hpp"
namespace ZeroTier {
@@ -62,23 +63,23 @@ unsigned int Multicaster::gather(const Address &queryingPeer,uint64_t nwid,const
if ((gs == _groups.end())||(gs->second.members.empty())) {
appendTo.append((uint32_t)0);
appendTo.append((uint16_t)0);
+ //TRACE("..MC Multicaster::gather() attached 0 of 0 peers for %.16llx/%s (1)",nwid,mg.toString().c_str());
return 0;
}
if (limit > gs->second.members.size())
limit = (unsigned int)gs->second.members.size();
- if (limit > ((ZT_PROTO_MAX_PACKET_LENGTH / 5) + 1))
- limit = (ZT_PROTO_MAX_PACKET_LENGTH / 5) + 1;
+ if (limit > ((ZT_PROTO_MAX_PACKET_LENGTH / ZT_ADDRESS_LENGTH) + 1))
+ limit = (ZT_PROTO_MAX_PACKET_LENGTH / ZT_ADDRESS_LENGTH) + 1;
unsigned int totalAt = appendTo.size();
appendTo.addSize(4); // sizeof(uint32_t)
unsigned int nAt = appendTo.size();
appendTo.addSize(2); // sizeof(uint16_t)
+ // Members are returned in random order so that repeated gather queries
+ // will return different subsets of a large multicast group.
while ((n < limit)&&((appendTo.size() + ZT_ADDRESS_LENGTH) <= ZT_PROTO_MAX_PACKET_LENGTH)) {
- // Pick a member at random -- if we've already picked it,
- // keep circling the buffer until we find one we haven't.
- // This won't loop forever since limit <= members.size().
rptr = (unsigned int)RR->prng->next32();
restart_member_scan:
a = gs->second.members[rptr % (unsigned int)gs->second.members.size()].address.toInt();
@@ -105,8 +106,12 @@ restart_member_scan:
}
}
+ n -= skipped;
+
appendTo.setAt(totalAt,(uint32_t)(gs->second.members.size() - skipped));
- appendTo.setAt(nAt,(uint16_t)(n - skipped));
+ appendTo.setAt(nAt,(uint16_t)n);
+
+ //TRACE("..MC Multicaster::gather() attached %u of %u peers for %.16llx/%s (2)",n,(unsigned int)(gs->second.members.size() - skipped),nwid,mg.toString().c_str());
return n;
}
@@ -151,8 +156,8 @@ void Multicaster::send(
OutboundMulticast out;
out.init(
+ RR,
now,
- RR->identity.address(),
nwid,
com,
limit,
@@ -196,6 +201,8 @@ void Multicaster::send(
gs.lastExplicitGather = now;
SharedPtr<Peer> sn(RR->topology->getBestSupernode());
if (sn) {
+ TRACE(">>MC GATHER up to %u in %.16llx/%s",gatherLimit,nwid,mg.toString().c_str());
+
Packet outp(sn->address(),RR->identity.address(),Packet::VERB_MULTICAST_GATHER);
outp.append(nwid);
outp.append((uint8_t)0);
@@ -216,8 +223,8 @@ void Multicaster::send(
OutboundMulticast &out = gs.txQueue.back();
out.init(
+ RR,
now,
- RR->identity.address(),
nwid,
com,
limit,
@@ -351,7 +358,7 @@ void Multicaster::clean(uint64_t now)
}
}
-void Multicaster::_add(uint64_t now,uint64_t nwid,MulticastGroupStatus &gs,const Address &learnedFrom,const Address &member)
+void Multicaster::_add(uint64_t now,uint64_t nwid,const MulticastGroup &mg,MulticastGroupStatus &gs,const Address &learnedFrom,const Address &member)
{
// assumes _groups_m is locked
@@ -376,6 +383,8 @@ void Multicaster::_add(uint64_t now,uint64_t nwid,MulticastGroupStatus &gs,const
// this somewhere else but we'll try this for now.
gs.members.push_back(MulticastGroupMember(member,learnedFrom,now));
+ TRACE("..MC %s joined multicast group %.16llx/%s via %s",member.toString().c_str(),nwid,mg.toString().c_str(),((learnedFrom) ? learnedFrom.toString().c_str() : "(direct)"));
+
// Try to send to any outgoing multicasts that are waiting for more recipients
for(std::list<OutboundMulticast>::iterator tx(gs.txQueue.begin());tx!=gs.txQueue.end();) {
{ // TODO / LEGACY: don't send new multicast frame to old peers (if we know their version)