Hello, Can anyone try a patch for adding 6rd (RFC 5569) support to stf(4)? The patch for HEAD can be found at:
http://people.allbsd.org/~hrs/FreeBSD/stf_6rd_20100921-1.diff While it still includes a lot of extra code only for debugging purpose, it should work anyway. The operating principle and a configuration example are the following: 0. Supposed Network Structure (IPv6/IPv4 Internet) | | <-- static or dynamic routes between Internet and | IPv6 network in ISP for 6rd (2001:db8::/32). | ^ +-+---------+ | | PE router | | +-+-----+---+ | |.1 |::1 ISP | | | | --+---------------------- | | 2001:db8:c000:0201::/64 | | | | 192.0.2.0/24 <-- IPv4 network between the provider | --+----+---------------- and its customers. v | |.2 ^ +------+----+ | | CE router |(IPv6 default route is 2001:db8:c000:0201::1) | +------+----+ HOME |::1 | | | | 2001:db8:c000:0202::/64 <-- IPv6 LAN on customer side v --+----+--------------------------- | |::2 +--+---+ |HOST-A| (IPv6 default route is 2001:db8:c000:0202::1) +------+ [Provider side] A PE router is used for routing between Internet and ISP's IPv4/IPv6 network. The router works in the two ways: 1) It accepts a 6rd IPv4 packet which contains an IPv6 packet inside, decapsulates it, and delivers it as a normal IPv6 packet based on the routing table. 2) It accepts an IPv6 packet with the 6rd prefix, encapsulates it in an IPv4 packet, and then delivers it as a 6rd IPv4 packet to another 6rd router. A prefix for 6rd is 2001:db8::/32 in this example. Since IPv4 address of the PE router is 192.0.2.1, the calculated 6rd IPv6 prefix is 2001:db8:c000:0201::/64 (c000:0201 == 192.0.2.1 in HEX). The 6rd encap/decap will be done only for packets within this IPv6 prefix. [Customer side] A CE router is used for routing between LAN (customer side) and WAN (provider side). It has 192.0.2.2/24 on WAN and 2001:db8:c000:0202::/64 on LAN. No direct IPv6 reachability on WAN side. The behavior of the CE router is basically the same as the PE router. 1. 6rd functionality The CE router accepts an IPv6 packet with a address range 2001:db8:c000:0202::/64, and if the destination address is not within the LAN, it encapsulates the packet and delivers it as an IPv4 packet. The IPv4 packet's destination address is chosen in the following way: if the IPv6 dst addr is within 2001:db8::/32 it will be the calculated IPv4 address from the dst addr. If not, it picks up the next hop IPv6 address and try to calculate IPv4 address from it. If both fail, delivery of the IPv4 packet also fails (unreachable). For incoming 6rd IPv4 packets, CE router decapsulates and delivers them as normal IPv6 packets. Note that decapsulation happens only when IPv4 address part in the IPv6 dst addr in the incoming 6rd IPv4 packets matches the router's IPv4 address itself. In this way, CE router offers IPv6 reachability over the IPv4 network. For example, "ping6 2001:db8:c000:0201::1" from HOST-A works like this: a) IPv6 packet is delivered from HOST-A to CE router. The packet has the following address information: src: 2001:db8:c000:0202::2 (HOST-A) dst: 2001:db8:c000:0201::1 next hop: 2001:db8:c000:0202::1 (CE router) b) CE router accepts a packet from HOST-A but no on-link connection to 2001:db8:c000:0202::1. It encapsulates it into an IPv4 packet like this: outer IPv4 src: 192.0.2.2 outer IPv4 dst: 192.0.2.1 inner IPv6 src: 2001:db8:c000:0202::2 inner IPv6 dst: 2001:db8:c000:0201::1 The outer IPv4 address pair is chosen by CE router's IPv4 address and calculated from inner dst address. The IPv4 packet will be delivered based on the IPv4 routing table. c) PE router receives a 6rd IPv4 packet in b). It checks the inner src IPv6 addr matches 6rd prefix and dst IPv4 addr matches the PE router's, and then decapsulates it. The IPv6 packet will be delivered based on the IPv6 routing table. In this case, PE router has 2001:db8:c000:0201::1, so the IPv6 packet already reaches the final destination over IPv4 network. In the same way HOST-A can reach IPv6 Internet if PE router has sufficient routing information. 2. Configuration You might want to set ipv6_activate_all_interfaces=YES in rc.conf before trying the following command lines. And of course IPv6 prefixes here must be global ones in a real configuration. 2.1 HOST-A # ifconfig fxp0 inet6 2001:db8:c000:0202::2/64 # route add -inet6 default 2001:db8:c000:0202::1 2.2 CE router # ifconfig fxp0 inet6 2001:db8:c000:0202::1/64 # ifconfig fxp1 inet 192.0.2.2/24 # ifconfig stf0 create # ifconfig stf0 inet6 2001:db8:c000:0202::/32 # route add -inet6 default 2001:db8:c000:0201::1 # net.inet.ip.forwarding=1 # net.inet6.ip6.forwarding=1 Note that prefixlen of the stf interface must be the same as the 6rd relay prefix, not include the IPv4 part. This means it is from 0 to 32 in theory. 2.3 PE router # ifconfig fxp0 inet 192.0.2.1/24 # ifconfig fxp1 inet6 2001:db8:c000:0201::1/64 # ifconfig stf0 create # ifconfig stf0 inet6 2001:db8:c000:0201::/32 # net.inet.ip.forwarding=1 # net.inet6.ip6.forwarding=1 # (+ routes to Internet must be configured in some way) 2.4 Test HOST-A# ping6 2001:db8:c000:0201::1 (communication within 6rd domain) HOST-A# ping6 www.kame.net (communication beyond PE router) The patched version of stf(4) also supports the following: - multiple 6rd domains by adding multiple IPv6 addresses. - 6to4 (2002::/16) works as before. - stf(4) is clonable now and can be moved across vnets. While you can have multiple instances, only one of them in a vnet can be marked as UP. Any comments are welcome. -- Hiroki
pgpJgRLNuxp0z.pgp
Description: PGP signature