Diff Detail
- Repository
- rG FreeBSD src repository
- Lint
Lint Passed - Unit
No Test Coverage - Build Status
Buildable 57748 Build 54636: arc lint + arc unit
Event Timeline
I tested the IPv6-only machine and found no errors affecting it. Here are some methods I employed to ensure IPv6 cleanliness:
- I added an IPv6 multicast link-local address to simulate broadcast in IPv4.
- Utilized sockaddr_storage to represent the multicast address, making it compatible with both IPv4 and IPv6.
- Replaced the use of getservbyname with getaddrinfo for address resolution.
- Employed getnameinfo to retrieve the port and host string instead of relying on getservbyname.
However, there are instances where I still used switch case statements:
- I resorted to switch case statements for setsockopt as IPv4 and IPv6 have different options, and I couldn't find a function to handle this divergence effectively.
- Similarly, I employed switch case statements for setting multicast addresses.
While I understand that using switch case statements is generally not recommended, in the mentioned instances, it seemed like the most suitable solution. If there's an alternative approach you know of, I'm open to suggestions.
Questions:
- I use for loop iterating over the return list from getaddrinfo: I currently only create a socket and bind it to the first address encountered in the list if it succeeds. Is this approach advisable, or should I prioritize binding IPv6 addresses first?
- INET and INET6 problems, should I use them and what should I do if both are not defined.
- Should I write the test (ATF test) for the new code here? Actually, should I write the test for every utilities I revise in all GSoC projects?
What do you do if neither INET nor INET6 are defined? In a lot of cases, it looks like you fail. Likewise for when you don't have the right address family compiled in.
Ah, that's unexpected. However, is there a chance that INET and INET6 might not be defined? This scenario suggests that users aren't seeking to disable all network functions (WITHOUT_INET and WITHOUT_INET6 defined), which essentially implies they can't use the rwhod command.
Alternatively, should I set INET as the default if INET and INET6 are undefined? Or print some info when both are not defined? I've examined some clean IPv6 examples (like syslog and ifmcstat), and it appears they don't implement any special procedures. If there's a better approach to revising this, please advise.
- Use MCAST_JOIN_GROUP to replace IP_ADD_MEMBERSHIP and IPV6_JOIN_GROUP.
- Warn if multiple addresses are return. getaddrinfo() may return multiple address and I give a warn message and tell it only on address will be used to create socket.