Encyclopedia  |   World Factbook  |   World Flags  |   Reference Tables  |   List of Lists     
   Academic Disciplines  |   Historical Timeline  |   Themed Timelines  |   Biographies  |   How-Tos     
Sponsor by The Tattoo Collection
Main Page | See live article | Alphabetical index


6to4 (sometimes written 6 to 4) is a system that allows IPv6 packets to be transmitted over an IPv4 network. 6to4 is useful when two hosts wish to exchange IPv6 traffic but some portion of the network between those hosts only supports IPv4.

6to4 does not facilitate interoperation between IPv4-only hosts and IPv6-only hosts.

Table of contents
1 How 6to4 works
2 References

How 6to4 works

6to4 performs three functions:

  1. Assigns a block of IPv6 address space to any host or network that has a global IPv4 address.
  2. Encapsulates IPv6 packets inside IPv4 packets for transmission over an IPv4 network.
  3. Routes traffic between 6to4 and "native" IPv6 networks.

Address Block Allocation

For any 32-bit global IPv4 address that is assigned to a host or network, a 48-bit 6to4 IPv6 prefix can be constructed for use by that host or network by prepending 2002 (hex) to the IPv4 address. Thus if were a global IPv4 address (it isn't), the corresponding 6to4 prefix would be 2002:0A14:1E28::/48. (IPv4 addresses use decimal notation while IPv6 addresses use hexadecimal notation). Since the IPv6 address is 128 bits long and 6to4 provides a 48-bit prefix, 6to4 allows up to 280 IPv6 hosts on a network to communicate with other IPv6 hosts, even if the only external connectivity is using IPv4 and there is only a single IPv4 address.

Any IPv6 address that begins with the 2002::/16 prefix is known of as a 6to4 address, as opposed to a native IPv6 address which do not use that prefix.

Encapsulation and Transmission

6to4 embeds an IPv6 packet in the payload portion of an IPv4 packet with protocol type 41. To send an IPv6 packet over an IPv4 network to a 6to4 destination address, an IPv4 header with protocol type 41 is prepended to the IPv6 packet. The IPv4 destination address for the prepended packet header is derived from the IPv6 destination address of the inner packet, by extracting the 32 bits immediately following the IPv6 destination address's 2002:: prefix. The IPv4 source address in the prepended packet header is the IPv4 address of the host or router which is sending the packet over IPv4. The resulting IPv4 packet is then routed to its IPv4 destination address just like any other IPv4 packet.

Routing Between 6to4 and Native IPv6

To allow hosts and networks using 6to4 addresses to exchange traffic with hosts using "native" IPv6 addresses, "relay routers" have been established. A relay router connects to an IPv4 network and an IPv6 network. 6to4 packets arriving on an IPv4 interface will have their IPv6 payloads routed to the IPv6 network, while packets arriving on the IPv6 interface with a destination address prefix of 2002::/16 will be encapsulated and forwarded over the IPv4 network.

Some relay routers are for private use only, and will only forward traffic between the networks that they are configured to serve. Other relay routers are for public use, and will forward traffic between the public IPv4 Internet and the public IPv6 Internet. Public relay routers may advertise connectivity to the prefix on the public IPv4 Internet and to 2002:c058:6301::/48 on the public IPv6 Internet. This allows native IPv6 networks to send traffic to networks using 6to4 with no additional configuration. Hosts or local networks using 6to4 can send to native IPv6 networks by locally configuring a route for the 2002:://16 prefix.

6to4 may be used by an individual host, or by a local IPv6 network. When used by an individual host, that host must have IPv4 connectivity and a global IPv4 address, and the host is responsible for encapsulation of outgoing IPv6 packets and decapsulation of incoming 6to4 packets. When 6to4 is used by a local network, the entire local network needs only a single IPv4 address. Within that network, hosts learn their IPv6 addresses and routing using ordinary router discovery protocols, just as on a native IPv6 network.


B. Carpenter, K. Moore. "Connection of IPv6 Domains via IPv4 Clouds". RFC 3056, February 2001.

R. Gilligan, E. Nordmark, "Transition Mechanisms for IPv6 Hosts and Routers". RFC 2893, August 2000.

C. Huitema, "An Anycast Prefix for 6to4 Relay Routers". RFC 3068, June 2001.