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:
Steven Siloti 2016-08-25 16:26:48 -07:00 committed by Arvid Norberg
parent 599967c4b5
commit 3a665a1040
3 changed files with 12 additions and 11 deletions

View File

@ -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

View File

@ -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;
} }

View File

@ -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()));