- 
                Notifications
    You must be signed in to change notification settings 
- Fork 13.9k
          Fix Ipv6Addr::is_unicast_global to check for unicast global scope
          #85696
        
          New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Conversation
| (rust-highfive has picked a reviewer for you, use r? to override) | 
| What does that mean for unique local addresses now? Those clearly are not global and RFC 4291 doesn't even acknowledge their existence even though RFC 4193 predates it by a year. Edit: Nevermind, I see  | 
| Yes that is where the difference between "global scope" and "globally reachable" comes into play. RFC 4193 has the following: 
 
 So unique local addresses are indeed not globally reachable (which is implemented in  | 
| Perhaps it would be less confusing to rename  I have already included in the documentation of   | 
is_unicast_global to check for unicast global scopeIpv6Addr::is_unicast_global to check for unicast global scope
      …r=joshtriplett Remove `Ipv6Addr::is_unicast_link_local_strict` Removes the unstable method `Ipv6Addr::is_unicast_link_local_strict` and keeps the behaviour of `Ipv6Addr::is_unicast_link_local`, see also rust-lang#85604 where I have tried to summarize related discussion so far. My intent is for `is_unicast_link_local`, `is_unicast_site_local` and `is_unicast_global` to have the semantics of checking if an address has Link-Local, Site-Local or Global scope, see also rust-lang#85696 which changes the behaviour of `is_unicast_global` and renames these methods to `has_unicast_XXX_scope` to reflect this. For checking Link-Local scope we currently have two methods: `is_unicast_link_local` and `is_unicast_link_local_strict`. This is because of what appears to be conflicting definitions in [IETF RFC 4291](https://datatracker.ietf.org/doc/html/rfc4291). From [IETF RFC 4291 section 2.4](https://datatracker.ietf.org/doc/html/rfc4291#section-2.4): "Link-Local unicast" (`FE80::/10`) ```text Address type Binary prefix IPv6 notation Section ------------ ------------- ------------- ------- Unspecified 00...0 (128 bits) ::/128 2.5.2 Loopback 00...1 (128 bits) ::1/128 2.5.3 Multicast 11111111 FF00::/8 2.7 Link-Local unicast 1111111010 FE80::/10 2.5.6 Global Unicast (everything else) ``` From [IETF RFC 4291 section 2.5.6](https://datatracker.ietf.org/doc/html/rfc4291#section-2.5.6): "Link-Local IPv6 Unicast Addresses" (`FE80::/64`) ```text | 10 bits | 54 bits | 64 bits | +----------+-------------------------+----------------------------+ |1111111010| 0 | interface ID | +----------+-------------------------+----------------------------+ ``` With `is_unicast_link_local` checking `FE80::/10` and `is_unicast_link_local_strict` checking `FE80::/64`. There is also [IETF RFC 5156 section 2.4](https://datatracker.ietf.org/doc/html/rfc5156#section-2.4) which defines "Link-Scoped Unicast" as `FE80::/10`. It has been pointed out that implementations in other languages and the linux kernel all use `FE80::/10` (rust-lang#76098 (comment), rust-lang#76098 (comment)). Given all of this I believe the correct interpretation to be the following: All addresses in `FE80::/10` are defined as having Link-Local scope, however currently only the block `FE80::/64` has been allocated for "Link-Local IPv6 Unicast Addresses". This might change in the future however; more addresses in `FE80::/10` could be allocated and those will have Link-Local scope. I therefore believe the current behaviour of `is_unicast_link_local` to be correct (if interpreting it to have the semantics of `has_unicast_link_local_scope`) and `is_unicast_link_local_strict` to be unnecessary, confusing and even a potential source of future bugs: Currently there is no real difference in checking `FE80::/10` or `FE80::/64`, since any address in practice will be `FE80::/64`. However if an application uses `is_unicast_link_local_strict` to implement link-local (so non-global) behaviour, it will be incorrect in the future if addresses outside of `FE80::/64` are allocated. r? `@joshtriplett` as reviewer of all the related PRs
| ☔ The latest upstream changes (presumably #85819) made this pull request unmergeable. Please resolve the merge conflicts. | 
| ☔ The latest upstream changes (presumably #86160) made this pull request unmergeable. Please resolve the merge conflicts. | 
| ☔ The latest upstream changes (presumably #85820) made this pull request unmergeable. Please resolve the merge conflicts. | 
…_unicast_global_scope` are together
| I rebased and reordered the methods so now  | 
      
        
              This comment has been minimized.
        
        
      
    
  This comment has been minimized.
| None => self.is_unicast_global(), | ||
| None => { | ||
| self.has_unicast_global_scope() | ||
| && !(self.is_unique_local() || self.is_documentation()) | ||
| } | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This implementation of is_global is changed completely in #86634
| Block on #86634 | 
| ☔ The latest upstream changes (presumably #89512) made this pull request unmergeable. Please resolve the merge conflicts. | 
| @CDirkx I'm trying to figure out where the "ip" feature left off and I think its on this rebase need. Am I correct? | 
See #85604 for previous discussion.
The current behaviour of
Ipv6Addr::is_unicast_globalis/// Returns [`true`] if the address is a globally routable unicast address.This is inconsistent with methods like
is_unicast_link_localandis_unicast_site_local, which check if an address has unicast link-local scope or site-local scope respectively. Similarly one would expectis_unicast_globalto check if an address has unicast global scope (which is not the same thing as being globally routable, for that we already haveIpv6Addr::is_globalwhich is reworked in #86634).This PR changes the behaviour to
Basing itself on the following table from RFC 4291:
The documentation is also updated to reflect that future RFCs may change the behaviour of this method: "Future specifications may redefine one or more sub-ranges of the Global Unicast space for other purposes".
The behaviour of
is_globalis kept the same, it used to delegate tois_unicast_globalbut now performs the checks for global reachability itself.To avoid further confusion between
is_unicast_globalandis_global, and the concepts of "global scope" and "globally reachable", the folowing methods have been renamed:is_unicast_global->has_unicast_global_scopeis_unicast_link_local->has_unicast_link_local_scopeis_unicast_link_local_strict->has_unicast_link_local_scope_strictIpv6Addr::is_unicast_link_local_strict#85819)is_unicast_site_local->has_unicast_site_local_scopeIpv6Addr::is_unicast_site_local#85820)