0d6ff71ae3
This patch adds the functions needed to handle IPv6 packets. ICMPv6 and NDP headers are implemented. Slirp is now able to send NDP Router or Neighbor Advertisement when it receives Router or Neighbor Solicitation. Using a 64bit-sized IPv6 prefix, the guest is now able to perform stateless autoconfiguration (SLAAC) and to compute its IPv6 address. This patch adds an ndp_table, mainly inspired by arp_table, to keep an NDP cache and manage network address resolution. Slirp regularly sends NDP Neighbor Advertisement, as recommended by the RFC, to make the guest refresh its route. This also adds ip6_cksum() to compute ICMPv6 checksums using IPv6 pseudo-header. Some #define ETH_* are moved upper in slirp.h to make them accessible to other slirp/*.h Signed-off-by: Guillaume Subiron <maethor@subiron.org> Signed-off-by: Samuel Thibault <samuel.thibault@ens-lyon.org> Reviewed-by: Thomas Huth <thuth@redhat.com>
41 lines
840 B
C
41 lines
840 B
C
/*
|
|
* Copyright (c) 2013
|
|
* Guillaume Subiron, Yann Bordenave, Serigne Modou Wagne.
|
|
*/
|
|
|
|
#include "qemu/osdep.h"
|
|
#include "qemu-common.h"
|
|
#include "slirp.h"
|
|
|
|
/* Number of packets queued before we start sending
|
|
* (to prevent allocing too many mbufs) */
|
|
#define IF6_THRESH 10
|
|
|
|
/*
|
|
* IPv6 output. The packet in mbuf chain m contains a IP header
|
|
*/
|
|
int ip6_output(struct socket *so, struct mbuf *m, int fast)
|
|
{
|
|
struct ip6 *ip = mtod(m, struct ip6 *);
|
|
|
|
DEBUG_CALL("ip6_output");
|
|
DEBUG_ARG("so = %lx", (long)so);
|
|
DEBUG_ARG("m = %lx", (long)m);
|
|
|
|
/* Fill IPv6 header */
|
|
ip->ip_v = IP6VERSION;
|
|
ip->ip_hl = IP6_HOP_LIMIT;
|
|
ip->ip_tc_hi = 0;
|
|
ip->ip_tc_lo = 0;
|
|
ip->ip_fl_hi = 0;
|
|
ip->ip_fl_lo = 0;
|
|
|
|
if (fast) {
|
|
if_encap(m->slirp, m);
|
|
} else {
|
|
if_output(so, m);
|
|
}
|
|
|
|
return 0;
|
|
}
|