From owner-freebsd-doc Tue Apr 9 9:52:50 2002 Delivered-To: freebsd-doc@freebsd.org Received: from core.radioactivedata.org (146-115-127-91.c3-0.smr-ubr1.sbo-smr.ma.cable.rcn.com [146.115.127.91]) by hub.freebsd.org (Postfix) with ESMTP id A0C4037B400 for ; Tue, 9 Apr 2002 09:52:29 -0700 (PDT) Received: from radioactivedata.org (localhost [127.0.0.1]) by core.radioactivedata.org (8.12.2/8.9.3) with ESMTP id g39GqQfD001007; Tue, 9 Apr 2002 12:52:26 -0400 (EDT) (envelope-from mbertsch@radioactivedata.org) Message-ID: <3CB31C4A.5040102@radioactivedata.org> Date: Tue, 09 Apr 2002 12:52:26 -0400 From: Mike DeGraw-Bertsch User-Agent: Mozilla/5.0 (X11; U; FreeBSD i386; en-US; rv:0.9.9) Gecko/20020317 X-Accept-Language: en-us, en MIME-Version: 1.0 To: Nick Sayer Cc: freebsd-doc@freebsd.org Subject: Re: suggestion: handbook 17.14: Basic IPv6 setup using 6to4 References: <3CB0FB94.3060308@quack.kfu.com> Content-Type: text/plain; charset=ISO-8859-15; format=flowed Content-Transfer-Encoding: 7bit Sender: owner-freebsd-doc@FreeBSD.ORG Precedence: bulk List-ID: List-Archive: (Web Archive) List-Help: (List Instructions) List-Subscribe: List-Unsubscribe: X-Loop: FreeBSD.org Hi Nick, I hadn't realized that this was possible w/o finding someone to agree to route IPv6 for you. Neat. I wrote an article for the O'Reilly Network, at http://www.oreillynet.com/pub/a/bsd/2002/02/22/ipv6.html, on how to setup an IPv6 connection using Freenet6. It's useful for folks who, like me, have a dynamic IP address. Perhaps we can join our texts into '17.14: Basic IPv6 Setup'? Let me know what you think. -Mike Nick Sayer wrote: > I nominate this block of text: > > > Anyone with a single static IPv4 address can set up a machine to act as > an IPv6 router using 6to4. With such a setup, it is possible for up to > 65,536 networks of 2^64 machines to be given globally reachable IPv6 > addresses reached through such a gateway. All one needs to do is add a > few short lines to rc.conf. > > [insert a short primer on IPv6 here] > > 6to4 is a special transition mechanism to make it easier for isolated > LANs running IPv6 to be able to reach each other. All users of 6to4 can > communicate with each other without doing anything special other than > setting up a 6to4 router at each location. 6to4 works by making special > "magic" IPv6 prefixes. These prefixes consist of a 16 bit constant, > which is 2002::/16 followed by the 32 bit IPv4 address of the 6to4 > router for that node. By including that in the prefix, it is immediately > clear how to route the replies back to their origin - you simply > encapsulate the replies in IPv4 packets addressed to the IPv4 address in > the prefix. For example, if a network had a 6to4 router at 10.0.0.1 (it > wouldn't, since that address is not routable on IPv4, but bear with me), > then its coresponding 6to4 prefix would be 2002:a00:1::/48. If it had a > host at 2002:a00:1::1, then traffic addressed to that machine would be > encapsulated in packets addressed to 10.0.0.1, which would get them to > the 6to4 router. Q.E.D. > > The one wrinkle is that 6to4 does not describe how 6to4 equipped hosts > can reach non-6to4 IPv6 destinations. Fortunately, RFC 3068 addresses > this. To make a long story short, 6to4 nodes need only set their default > route to the special address 2002:c058:6301:: and the traffic will get > to any globally routable IPv6 address regardless of whether or not it is > in 6to4 space. > > On the machine designated as the 6to4 router, you will need to set up > stf0, which will be the interface used to send out the IPv6-in-IPv4 > encapsulated packets. You'll need to add the following to your kernel > configuration file, if it's not already there: > > options INET6 > pseudo-device stf 1 > > Having done that, you can add the following lines to your rc.conf file: > > ipv6_enable="YES" > ipv6_network_interfaces="auto" > ipv6_gateway_enable="YES" > ipv6_prefix_nn0="2002:xxxx:xxxx:0" # see below > stf_interface_ipv4addr="xxx.xxx.xxx.xxx" # Put your IPv4 address here > ipv6_defaultrouter="2002:c058:6301::" > > The ipv6_prefix line should have "nn0" changed to the name of your > Ethernet card (additional lines can be added if you are serving multiple > networks). The xxxx:xxxx should be changed to the hexidecimal > representation of the same IPv4 address that is in the > stf_interface_ipv4addr line. > > Having done that (and rebooted), you should find that you can reach IPv6 > hosts from the 6to4 router. > > If you have hosts connected to the LAN which you'd like to use IPv6 as > well, your next step is to configure them. This is easier. Put this in > rc.conf: > > ipv6_enable="YES" > > That's all (well, they will also need "options INET6" in their kernel > config). They will use IPv6 router discovery to find the 6to4 router and > get all the information they need. > > > To Unsubscribe: send mail to majordomo@FreeBSD.org > with "unsubscribe freebsd-doc" in the body of the message To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-doc" in the body of the message