Overview ======== Some simple tools for working with IPv6 addresses. ipv6-arpa - Given an IPv6 address, display it in ip6.arpa format. e.g $ ./ipv6-arpa 2001:db8:1:2::f00f Address : 2001:0db8:0001:0002:0000:0000:0000:f00f ip6.arpa :- f.0.0.f.0.0.0.0.0.0.0.0.0.0.0.0.2.0.0.0.1.0.0.0.8.b.d.0.1.0.0.2.ip6.arpa. ipv6-isin - Given an IPv6 network/prefix and an IPv6 address, determine if the address falls within the given network. e.g $ ./ipv6-isin 2001:db8:1:2::/64 2001:db8:1:2::cafe Yes $ ./ipv6-isin 2001:db8:1:2::/64 2001:db8:1:20::cafe No ipv6-range - Given a network address and prefix, calculate the range of available IPs. e.g $ ./ipv6-range 2001:db8:1:2::/64 Network : 2001:db8:1:2::/64 Start : 2001:0db8:0001:0002:0000:0000:0000:0000 End : 2001:0db8:0001:0002:ffff:ffff:ffff:ffff A /64 provides 18,446,744,073,709,551,616 addresses gen-ula - Generates an IPv6 ULA prefix based on the algorithm in RFC 4193. e.g $ ./gen-ula fd0c:d0e3:46f0::/48 /64 subnet range: fd0c:d0e3:46f0:0000::/64 - fd0c:d0e3:46f0:ffff::/64 The gen-ula tool requires libuuid and mhash. mac-to-eui64 - Generates a modified EUI-64 identifier for the given MAC address. $ ./mac-to-eui64 00:21:2f:b5:6e:10 Modified EUI-64 :- 02:21:2f:ff:fe:b5:6e:10 (SLAAC Host) ::0221:2fff:feb5:6e10 The mac address can also be read from stdin e.g $ ./ipv6-extract-mac fe80::6231:97ff:fe1a:de8b | ./mac-to-eui64 Modified EUI-64 :- 62:31:97:ff:fe:1a:de:8b (SLAAC Host) ::6231:97ff:fe1a:de8b mac-type - Test the U/L (Universal/Local) and IG (Individual/Group) bits of a MAC address. $ ./mac-type 00:21:2f:b5:6e:10 U/L (LG) bit is NOT set. Address is universally administered. IG bit is NOT set. Unicast address. $ ./mac-type df:ad:be:ef:ca:fe U/L (LG) bit is set. Address is locally administered. IG bit is set. Broadcast address. The mac address can also be read from stdin e.g $ ./ipv6-extract-mac fe80::6231:97ff:fe1a:de8b | ./mac-type U/L (LG) bit is NOT set. Address is universally administered. IG bit is NOT set. Unicast address. ipv6-extract-mac - Given an IPv6 address such as one generated through SLAAC. This will attempt to extract the MAC address from it. ./ipv6-extract-mac 2001:db8::200:5eff:fe00:5300 00:00:5e:00:53:00 prefix-to-mask - Given an IPv6 prefix length, display the compressed and uncompressed network mask representations. $ ./prefix-to-mask 10 comp ffc0:: uncomp ffc0:0000:0000:0000:0000:0000:0000:0000 mask-to-prefix - Given an IPv6 network mask display the prefix length. $ ./mask-to-prefix ffc0:: prefixlen : 10 ipv6-fmt - Given an IPv6 address format it in compressed, expanded and URI literal forms. $ ./ipv6-fmt 2001:0db8:0000::dead:0000:beef Compressed : 2001:db8::dead:0:beef Expanded : 2001:0db8:0000:0000:0000:dead:0000:beef URI Literal : [2001:db8::dead:0:beef] ipv6-gen-slaac - Given an IPv6 network & MAC address, generate the corresponding SLAAC address. $ ./ipv6-gen-slaac 2001:db8:a:b:: 00:24:1d:ba:80:00 SLAAC : 2001:db8:a:b:224:1dff:feba:8000 These tools are licensed under the GNU General Public License Version 2 or the GNU Lesser General Public License Version 2.1