Skip to content

Commit

Permalink
Remove old check for 3-byte shifted IP addresses from pre-0.2.9 node …
Browse files Browse the repository at this point in the history
…messages

The change removes an old check for IPv6 addresses in range ::ff:ff00:0:0:0/72 that were created due to a bug in size field of addr messages for 0.2.8 nodes and before.

This check is no longer needed as they are no more pre 0.2.9 nodes on the network (as per bitnodes network snapshot).

Credits for discovering this go to sipa
  • Loading branch information
i-rme authored and Your Name committed Aug 28, 2020
1 parent 8d6224f commit 29a6824
Showing 1 changed file with 0 additions and 11 deletions.
11 changes: 0 additions & 11 deletions src/netaddress.cpp
Expand Up @@ -269,17 +269,6 @@ bool CNetAddr::IsLocal() const
*/
bool CNetAddr::IsValid() const
{
// Cleanup 3-byte shifted addresses caused by garbage in size field
// of addr messages from versions before 0.2.9 checksum.
// Two consecutive addr messages look like this:
// header20 vectorlen3 addr26 addr26 addr26 header20 vectorlen3 addr26 addr26 addr26...
// so if the first length field is garbled, it reads the second batch
// of addr misaligned by 3 bytes.
if (IsIPv6() && memcmp(m_addr.data(), IPV4_IN_IPV6_PREFIX.data() + 3,
sizeof(IPV4_IN_IPV6_PREFIX) - 3) == 0) {
return false;
}

// unspecified IPv6 address (::/128)
unsigned char ipNone6[16] = {};
if (IsIPv6() && memcmp(m_addr.data(), ipNone6, sizeof(ipNone6)) == 0) {
Expand Down

0 comments on commit 29a6824

Please sign in to comment.