forked from premiere/premiere-libtorrent
fix inconsistant prefix calulcation (#1030)
The special case for calculating the prefix in the last bucket was being applied to the condidate node but not the existing nodes in the bucket.
This commit is contained in:
parent
599967c4b5
commit
3a665a1040
|
@ -72,7 +72,7 @@ bool TORRENT_EXTRA_EXPORT verify_secret_id(node_id const& nid);
|
||||||
node_id TORRENT_EXTRA_EXPORT generate_id_impl(address const& ip_, boost::uint32_t r);
|
node_id TORRENT_EXTRA_EXPORT generate_id_impl(address const& ip_, boost::uint32_t r);
|
||||||
|
|
||||||
bool TORRENT_EXTRA_EXPORT verify_id(node_id const& nid, address const& source_ip);
|
bool TORRENT_EXTRA_EXPORT verify_id(node_id const& nid, address const& source_ip);
|
||||||
bool TORRENT_EXTRA_EXPORT matching_prefix(node_entry const& n, int mask, int prefix, int bucket_index);
|
bool TORRENT_EXTRA_EXPORT matching_prefix(node_entry const& n, int mask, int prefix, int offset);
|
||||||
node_id TORRENT_EXTRA_EXPORT generate_prefix_mask(int bits);
|
node_id TORRENT_EXTRA_EXPORT generate_prefix_mask(int bits);
|
||||||
|
|
||||||
} } // namespace libtorrent::dht
|
} } // namespace libtorrent::dht
|
||||||
|
|
|
@ -216,10 +216,10 @@ node_id generate_id(address const& ip)
|
||||||
return generate_id_impl(ip, random());
|
return generate_id_impl(ip, random());
|
||||||
}
|
}
|
||||||
|
|
||||||
bool matching_prefix(node_entry const& n, int mask, int prefix, int bucket_index)
|
bool matching_prefix(node_entry const& n, int mask, int prefix, int offset)
|
||||||
{
|
{
|
||||||
node_id id = n.id;
|
node_id id = n.id;
|
||||||
id <<= bucket_index + 1;
|
id <<= offset;
|
||||||
return (id[0] & mask) == prefix;
|
return (id[0] & mask) == prefix;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -809,18 +809,19 @@ ip_ok:
|
||||||
std::vector<bucket_t::iterator> nodes;
|
std::vector<bucket_t::iterator> nodes;
|
||||||
bool force_replace = false;
|
bool force_replace = false;
|
||||||
|
|
||||||
{
|
|
||||||
node_id id = e.id;
|
|
||||||
// the last bucket is special, since it hasn't been split yet, it
|
// the last bucket is special, since it hasn't been split yet, it
|
||||||
// includes that top bit as well
|
// includes that top bit as well
|
||||||
if (bucket_index + 1 == m_buckets.size())
|
int const prefix_offset =
|
||||||
id <<= bucket_index;
|
bucket_index + 1 == m_buckets.size() ? bucket_index : bucket_index + 1;
|
||||||
else
|
|
||||||
id <<= bucket_index + 1;
|
{
|
||||||
|
node_id id = e.id;
|
||||||
|
id <<= prefix_offset;
|
||||||
|
int const candidate_prefix = id[0] & mask;
|
||||||
|
|
||||||
for (j = b.begin(); j != b.end(); ++j)
|
for (j = b.begin(); j != b.end(); ++j)
|
||||||
{
|
{
|
||||||
if (!matching_prefix(*j, mask, id[0] & mask, bucket_index)) continue;
|
if (!matching_prefix(*j, mask, candidate_prefix, prefix_offset)) continue;
|
||||||
nodes.push_back(j);
|
nodes.push_back(j);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -850,7 +851,7 @@ ip_ok:
|
||||||
for (j = b.begin(); j != b.end(); ++j)
|
for (j = b.begin(); j != b.end(); ++j)
|
||||||
{
|
{
|
||||||
node_id id = j->id;
|
node_id id = j->id;
|
||||||
id <<= bucket_index + 1;
|
id <<= prefix_offset;
|
||||||
int this_prefix = (id[0] & mask) >> mask_shift;
|
int this_prefix = (id[0] & mask) >> mask_shift;
|
||||||
TORRENT_ASSERT(this_prefix >= 0);
|
TORRENT_ASSERT(this_prefix >= 0);
|
||||||
TORRENT_ASSERT(this_prefix < int(prefix.size()));
|
TORRENT_ASSERT(this_prefix < int(prefix.size()));
|
||||||
|
|
Loading…
Reference in New Issue