mirror of
https://github.com/zerotier/ZeroTierOne.git
synced 2025-01-18 10:46:33 +00:00
Save space in expecting-reply-to tracking.
This commit is contained in:
parent
2b10a982e9
commit
127bcb02ff
@ -219,25 +219,34 @@ public:
|
|||||||
/**
|
/**
|
||||||
* Register that we are expecting a reply to a packet ID
|
* Register that we are expecting a reply to a packet ID
|
||||||
*
|
*
|
||||||
|
* This only uses the most significant bits of the packet ID, both to save space
|
||||||
|
* and to avoid using the higher bits that can be modified during armor() to
|
||||||
|
* mask against the packet send counter used for QoS detection.
|
||||||
|
*
|
||||||
* @param packetId Packet ID to expect reply to
|
* @param packetId Packet ID to expect reply to
|
||||||
*/
|
*/
|
||||||
inline void expectReplyTo(const uint64_t packetId)
|
inline void expectReplyTo(const uint64_t packetId)
|
||||||
{
|
{
|
||||||
const unsigned long bucket = (unsigned long)(packetId & ZT_EXPECTING_REPLIES_BUCKET_MASK1);
|
const unsigned long bucket = (unsigned long)(packetId & ZT_EXPECTING_REPLIES_BUCKET_MASK1);
|
||||||
_expectingRepliesTo[bucket][_expectingRepliesToBucketPtr[bucket]++ & ZT_EXPECTING_REPLIES_BUCKET_MASK2] = packetId;
|
_expectingRepliesTo[bucket][_expectingRepliesToBucketPtr[bucket]++ & ZT_EXPECTING_REPLIES_BUCKET_MASK2] = (uint32_t)(packetId >> 32);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Check whether a given packet ID is something we are expecting a reply to
|
* Check whether a given packet ID is something we are expecting a reply to
|
||||||
*
|
*
|
||||||
|
* This only uses the most significant bits of the packet ID, both to save space
|
||||||
|
* and to avoid using the higher bits that can be modified during armor() to
|
||||||
|
* mask against the packet send counter used for QoS detection.
|
||||||
|
*
|
||||||
* @param packetId Packet ID to check
|
* @param packetId Packet ID to check
|
||||||
* @return True if we're expecting a reply
|
* @return True if we're expecting a reply
|
||||||
*/
|
*/
|
||||||
inline bool expectingReplyTo(const uint64_t packetId) const
|
inline bool expectingReplyTo(const uint64_t packetId) const
|
||||||
{
|
{
|
||||||
const unsigned long bucket = (unsigned long)(packetId & ZT_EXPECTING_REPLIES_BUCKET_MASK1);
|
const unsigned long bucket = (unsigned long)(packetId & ZT_EXPECTING_REPLIES_BUCKET_MASK1);
|
||||||
|
const uint32_t pid = (uint32_t)(packetId >> 32);
|
||||||
for(unsigned long i=0;i<=ZT_EXPECTING_REPLIES_BUCKET_MASK2;++i) {
|
for(unsigned long i=0;i<=ZT_EXPECTING_REPLIES_BUCKET_MASK2;++i) {
|
||||||
if (_expectingRepliesTo[bucket][i] == packetId)
|
if (_expectingRepliesTo[bucket][i] == pid)
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
@ -281,9 +290,9 @@ private:
|
|||||||
|
|
||||||
// For tracking packet IDs to filter out OK/ERROR replies to packets we did not send
|
// For tracking packet IDs to filter out OK/ERROR replies to packets we did not send
|
||||||
uint8_t _expectingRepliesToBucketPtr[ZT_EXPECTING_REPLIES_BUCKET_MASK1 + 1];
|
uint8_t _expectingRepliesToBucketPtr[ZT_EXPECTING_REPLIES_BUCKET_MASK1 + 1];
|
||||||
uint64_t _expectingRepliesTo[ZT_EXPECTING_REPLIES_BUCKET_MASK1 + 1][ZT_EXPECTING_REPLIES_BUCKET_MASK2 + 1];
|
uint32_t _expectingRepliesTo[ZT_EXPECTING_REPLIES_BUCKET_MASK1 + 1][ZT_EXPECTING_REPLIES_BUCKET_MASK2 + 1];
|
||||||
|
|
||||||
// Time of last identity verification indexed by InetAddress.rateGateHash()
|
// Time of last identity verification indexed by InetAddress.rateGateHash() -- used in IncomingPacket::_doHELLO() via rateGateIdentityVerification()
|
||||||
uint64_t _lastIdentityVerification[16384];
|
uint64_t _lastIdentityVerification[16384];
|
||||||
|
|
||||||
std::vector< std::pair< uint64_t, SharedPtr<Network> > > _networks;
|
std::vector< std::pair< uint64_t, SharedPtr<Network> > > _networks;
|
||||||
|
Loading…
Reference in New Issue
Block a user