contiki/core/net/ip64
Simon Duquennoy db60906e99 Merge pull request #1121 from uknoblic/ip64
ip64: Streamlined configuration parameters
2015-09-24 11:24:18 +02:00
..
ip64-addrmap.c
ip64-addrmap.h
ip64-arp.c
ip64-arp.h
ip64-conf-example.h
ip64-dhcpc.c
ip64-dhcpc.h
ip64-dns64.c
ip64-dns64.h
ip64-driver.h
ip64-eth-interface.c
ip64-eth-interface.h
ip64-eth.c
ip64-eth.h
ip64-interface.h
ip64-ipv4-dhcp.c
ip64-ipv4-dhcp.h
ip64-null-driver.c
ip64-null-driver.h
ip64-slip-interface.c
ip64-slip-interface.h
ip64-special-ports.c
ip64-special-ports.h
ip64.c
ip64.h
README.md

The ip64 module lets an IPv6 Contiki network be connected to an IPv4 network without any additional configuration or outside software. The ip64 module runs on the RPL root node and translates outgoing IPv6 packets into IPv4 packets nd incoming IPv4 packets to IPv6 packets.

The ip64 module uses stateful NAT64 (RFC6164) to do the packet translation and DNS64 (RFC6147) to catch DNS requests for IPv6 addresses, turn them into requests for IPv4 addresses, and turn the replies into responses for IPv6 addresses. This allows devices on the inside IPv6 network to connect to named servers on the outside IPv4 network.

The ip64 module hooks into the IPv6 stack via a fallback interface. Any packet that can not be routed into the local RPL mesh will be sent over the fallback interface, where ip64 picks it up, translates it into an IPv4 packet, and sends it over its outgoing interface.

In addition to providing NAT64 and DNS64 services, the ip64 module also performs DHCPv4 to request IPv4 address for devices connected to a medium such as Ethernet. The ip64 module also performs ARP processing to communicate over the Ethernet.

The ip64 module uses a configuration file called ip64-conf.h that specifies what device to use for the IPv4 network. This file is intended to be placed in the platform directory. An example configuration file called ip64-conf-example.h is provided in this directory.