aboutsummaryrefslogtreecommitdiffstats
path: root/sys
diff options
context:
space:
mode:
authorAndrey Konovalov <andreyknvl@google.com>2017-02-02 15:58:15 +0100
committerAndrey Konovalov <andreyknvl@google.com>2017-02-02 16:30:47 +0100
commit97ebf05eb984fbb4ab7b7156bef6fa4fafe6ecfe (patch)
tree144f58878f1a4ecba32ef268059fc6f88fa275d9 /sys
parent50f2f474ff43d934c84d67e5b0c5ba4ebc4c2bb8 (diff)
prog, sys: add ipv6 description and checksum
Diffstat (limited to 'sys')
-rw-r--r--sys/socket.txt24
-rw-r--r--sys/test.txt12
-rw-r--r--sys/vnet.txt125
-rw-r--r--sys/vnet_amd64.const30
-rw-r--r--sys/vnet_arm64.const30
-rw-r--r--sys/vnet_ppc64le.const30
6 files changed, 246 insertions, 5 deletions
diff --git a/sys/socket.txt b/sys/socket.txt
index 9e86c4de7..de9f44564 100644
--- a/sys/socket.txt
+++ b/sys/socket.txt
@@ -216,6 +216,30 @@ tcp_pair {
+
+# AF_INET6: TCP support
+
+resource sock_tcp6[sock]
+
+socket$tcp6(domain const[AF_INET6], type const[SOCK_STREAM], proto const[0]) sock_tcp6
+socketpair$tcp6(domain const[AF_INET6], type const[SOCK_STREAM], proto const[0], fds ptr[out, tcp6_pair])
+accept$tcp6(fd sock_tcp6, peer ptr[out, sockaddr_in6, opt], peerlen ptr[inout, len[peer, int32]]) sock_tcp6
+accept4$tcp6(fd sock_tcp6, peer ptr[out, sockaddr_in6, opt], peerlen ptr[inout, len[peer, int32]], flags flags[accept_flags]) sock_tcp6
+bind$tcp6(fd sock_tcp6, addr ptr[in, sockaddr_in6], addrlen len[addr])
+connect$tcp6(fd sock_tcp6, addr ptr[in, sockaddr_in6], addrlen len[addr])
+sendto$tcp6(fd sock_tcp6, buf buffer[in], len len[buf], f flags[send_flags], addr ptr[in, sockaddr_in6, opt], addrlen len[addr])
+recvfrom$tcp6(fd sock_tcp6, buf buffer[out], len len[buf], f flags[recv_flags], addr ptr[in, sockaddr_in6, opt], addrlen len[addr])
+getsockname$tcp6(fd sock_tcp6, addr ptr[out, sockaddr_in6], addrlen ptr[inout, len[addr, int32]])
+getpeername$tcp6(fd sock_tcp6, peer ptr[out, sockaddr_in6], peerlen ptr[inout, len[peer, int32]])
+
+tcp6_pair {
+ f0 sock_tcp6
+ f1 sock_tcp6
+}
+
+
+
+
# AF_UNIX support.
resource sock_unix[sock]
diff --git a/sys/test.txt b/sys/test.txt
index 932ddac01..5d1d3266d 100644
--- a/sys/test.txt
+++ b/sys/test.txt
@@ -395,6 +395,7 @@ syz_test$bf1(a0 ptr[in, syz_bf_struct1])
syz_test$csum_encode(a0 ptr[in, syz_csum_encode])
syz_test$csum_ipv4(a0 ptr[in, syz_csum_ipv4_header])
syz_test$csum_ipv4_tcp(a0 ptr[in, syz_csum_ipv4_tcp_packet])
+syz_test$csum_ipv6_tcp(a0 ptr[in, syz_csum_ipv6_tcp_packet])
syz_csum_encode {
f0 int16
@@ -408,7 +409,6 @@ syz_csum_encode {
syz_csum_ipv4_header {
csum csum[ipv4, int16]
data syz_csum_encode
- protocol int8
src_ip int32be
dst_ip int32be
} [packed]
@@ -426,3 +426,13 @@ syz_csum_ipv4_tcp_packet {
header syz_csum_ipv4_header
payload syz_csum_tcp_packet
} [packed]
+
+syz_csum_ipv6_header {
+ src_ip array[int8, 16]
+ dst_ip array[int8, 16]
+} [packed]
+
+syz_csum_ipv6_tcp_packet {
+ header syz_csum_ipv6_header
+ payload syz_csum_tcp_packet
+} [packed]
diff --git a/sys/vnet.txt b/sys/vnet.txt
index 5e9becc70..49582cae4 100644
--- a/sys/vnet.txt
+++ b/sys/vnet.txt
@@ -78,9 +78,10 @@ eth2_packet {
payload eth2_payload
} [packed]
-eth2_payload {
+eth2_payload [
ipv4 ipv4_packet
-} [packed]
+ ipv6 ipv6_packet
+] [varlen]
################################################################################
##################################### IPv4 #####################################
@@ -242,8 +243,8 @@ ipv4_header {
dscp int8:6
total_len len[ipv4_packet, int16be]
id int16be
- frag_off int16:13
- flags int16:3
+ frag_off int16be
+# TODO: frag_off is actually 13 bits, 3 bits are flags
ttl int8
protocol flags[ipv4_types, int8]
csum csum[ipv4, int16be]
@@ -258,6 +259,122 @@ ipv4_packet {
} [packed]
################################################################################
+##################################### IPv6 #####################################
+################################################################################
+
+# https://tools.ietf.org/html/rfc2460#section-3
+# https://en.wikipedia.org/wiki/IPv6_packet#Fixed_header
+
+include <uapi/linux/in6.h>
+include <uapi/linux/ipv6.h>
+include <net/ipv6.h>
+
+ipv6_types = IPPROTO_IP, IPPROTO_ICMP, IPPROTO_IGMP, IPPROTO_IPIP, IPPROTO_TCP, IPPROTO_EGP, IPPROTO_PUP, IPPROTO_UDP, IPPROTO_IDP, IPPROTO_TP, IPPROTO_DCCP, IPPROTO_IPV6, IPPROTO_RSVP, IPPROTO_GRE, IPPROTO_ESP, IPPROTO_AH, IPPROTO_MTP, IPPROTO_BEETPH, IPPROTO_ENCAP, IPPROTO_PIM, IPPROTO_COMP, IPPROTO_SCTP, IPPROTO_UDPLITE, IPPROTO_MPLS, IPPROTO_RAW, IPPROTO_HOPOPTS, IPPROTO_ROUTING, IPPROTO_FRAGMENT, IPPROTO_ICMPV6, IPPROTO_NONE, IPPROTO_DSTOPTS, IPPROTO_MH, NEXTHDR_HOP, NEXTHDR_TCP, NEXTHDR_UDP, NEXTHDR_IPV6, NEXTHDR_ROUTING, NEXTHDR_FRAGMENT, NEXTHDR_GRE, NEXTHDR_ESP, NEXTHDR_AUTH, NEXTHDR_ICMP, NEXTHDR_NONE, NEXTHDR_DEST, NEXTHDR_SCTP, NEXTHDR_MOBILITY
+
+# This corresponds to LOCAL_IPV6 ("fd00::%02hxaa" % pid) in executor/common.h
+ipv6_addr_local {
+ a0 const[0xfd, int8]
+ a1 array[const[0x00, int8], 13]
+ a2 proc[int8, 0, 1]
+ a3 const[0xaa, int8]
+} [packed]
+
+# This corresponds to REMOTE_IPV6 ("fd00::%02hxbb" % pid) in executor/common.h
+ipv6_addr_remote {
+ a0 const[0xfd, int8]
+ a1 array[const[0x00, int8], 13]
+ a2 proc[int8, 0, 1]
+ a3 const[0xbb, int8]
+} [packed]
+
+ipv6_addr_loopback {
+ a0 const[0, int64be]
+ a1 const[1, int64be]
+} [packed]
+
+ipv6_addr [
+ local ipv6_addr_local
+ remote ipv6_addr_remote
+ loopback ipv6_addr_loopback
+]
+
+# TODO: Describe more types of headers
+# NEXTHDR_HOP, NEXTHDR_TCP, NEXTHDR_UDP, NEXTHDR_IPV6, NEXTHDR_ROUTING, NEXTHDR_FRAGMENT, NEXTHDR_GRE, NEXTHDR_ESP, NEXTHDR_AUTH, NEXTHDR_ICMP, NEXTHDR_NONE, NEXTHDR_DEST, NEXTHDR_SCTP, NEXTHDR_MOBILITY
+# https://tools.ietf.org/html/rfc2402
+# https://tools.ietf.org/html/rfc2406
+
+# https://tools.ietf.org/html/rfc2460#section-4
+# The length field in each of the extension headers specifies the
+# length of the header in 8-octet units not including the first 8 octets.
+ipv6_ext_header [
+ hopopts ipv6_hopots_ext_header
+ routing ipv6_routing_ext_header
+ fragment ipv6_fragment_ext_header
+ dstopts ipv6_dstopts_ext_header
+] [varlen]
+
+ipv6_hopots_ext_header {
+ next_header flags[ipv6_types, int8]
+ length bytesize8[options, int8]
+ pad array[const[0, int8], 6]
+ options array[ipv6_tlv_option]
+} [packed, align_8]
+
+ipv6_routing_types = IPV6_SRCRT_STRICT, IPV6_SRCRT_TYPE_0, IPV6_SRCRT_TYPE_2
+
+ipv6_routing_ext_header {
+ next_header flags[ipv6_types, int8]
+ length bytesize8[data, int8]
+ routing_type flags[ipv6_routing_types, int8]
+ segments_left int8
+ reserved int32be
+ data array[ipv6_addr]
+} [packed, align_8]
+
+ipv6_fragment_ext_header {
+ next_header flags[ipv6_types, int8]
+ reserved1 int8
+ m_flag int16:1
+ reserved2 int16:2
+ fragment_offset int16be:13
+ identification int32
+} [packed]
+
+ipv6_dstopts_ext_header {
+ next_header flags[ipv6_types, int8]
+ length bytesize8[options, int8]
+ pad array[const[0, int8], 6]
+ options array[ipv6_tlv_option]
+} [packed]
+
+# TODO: describe particular tlv options
+ipv6_tlv_option_types = IPV6_TLV_PAD1, IPV6_TLV_PADN, IPV6_TLV_ROUTERALERT, IPV6_TLV_CALIPSO, IPV6_TLV_JUMBO, IPV6_TLV_HAO, 0xff, 0xfe
+
+ipv6_tlv_option {
+ type flags[ipv6_tlv_option_types, int8]
+ length len[data, int8]
+ data array[int8]
+} [packed]
+
+ipv6_packet {
+ priority int8:4
+ version const[6, int8:4]
+ flow_label array[int8, 3]
+# TODO: flow_label is actually 20 bits, 4 bits are part of priority
+ length len[payload, int16be]
+ next_header flags[ipv6_types, int8]
+ hop_limit int8
+ src_ip ipv6_addr
+ dst_ip ipv6_addr
+ payload ipv6_packet_payload
+} [packed]
+
+ipv6_packet_payload {
+ ext_headers array[ipv6_ext_header]
+ payload ip_payload
+} [packed]
+
+################################################################################
###################################### IP ######################################
################################################################################
diff --git a/sys/vnet_amd64.const b/sys/vnet_amd64.const
index 9d9a8855b..b59f7a4f3 100644
--- a/sys/vnet_amd64.const
+++ b/sys/vnet_amd64.const
@@ -80,27 +80,57 @@ IPPROTO_AH = 51
IPPROTO_BEETPH = 94
IPPROTO_COMP = 108
IPPROTO_DCCP = 33
+IPPROTO_DSTOPTS = 60
IPPROTO_EGP = 8
IPPROTO_ENCAP = 98
IPPROTO_ESP = 50
+IPPROTO_FRAGMENT = 44
IPPROTO_GRE = 47
+IPPROTO_HOPOPTS = 0
IPPROTO_ICMP = 1
+IPPROTO_ICMPV6 = 58
IPPROTO_IDP = 22
IPPROTO_IGMP = 2
IPPROTO_IP = 0
IPPROTO_IPIP = 4
IPPROTO_IPV6 = 41
+IPPROTO_MH = 135
IPPROTO_MPLS = 137
IPPROTO_MTP = 92
+IPPROTO_NONE = 59
IPPROTO_PIM = 103
IPPROTO_PUP = 12
IPPROTO_RAW = 255
+IPPROTO_ROUTING = 43
IPPROTO_RSVP = 46
IPPROTO_SCTP = 132
IPPROTO_TCP = 6
IPPROTO_TP = 29
IPPROTO_UDP = 17
IPPROTO_UDPLITE = 136
+IPV6_SRCRT_STRICT = 1
+IPV6_SRCRT_TYPE_0 = 0
+IPV6_SRCRT_TYPE_2 = 2
+IPV6_TLV_CALIPSO = 7
+IPV6_TLV_HAO = 201
+IPV6_TLV_JUMBO = 194
+IPV6_TLV_PAD1 = 0
+IPV6_TLV_PADN = 1
+IPV6_TLV_ROUTERALERT = 5
+NEXTHDR_AUTH = 51
+NEXTHDR_DEST = 60
+NEXTHDR_ESP = 50
+NEXTHDR_FRAGMENT = 44
+NEXTHDR_GRE = 47
+NEXTHDR_HOP = 0
+NEXTHDR_ICMP = 58
+NEXTHDR_IPV6 = 41
+NEXTHDR_MOBILITY = 135
+NEXTHDR_NONE = 59
+NEXTHDR_ROUTING = 43
+NEXTHDR_SCTP = 132
+NEXTHDR_TCP = 6
+NEXTHDR_UDP = 17
TCPHDR_ACK = 16
TCPHDR_CWR = 128
TCPHDR_ECE = 64
diff --git a/sys/vnet_arm64.const b/sys/vnet_arm64.const
index 9d9a8855b..b59f7a4f3 100644
--- a/sys/vnet_arm64.const
+++ b/sys/vnet_arm64.const
@@ -80,27 +80,57 @@ IPPROTO_AH = 51
IPPROTO_BEETPH = 94
IPPROTO_COMP = 108
IPPROTO_DCCP = 33
+IPPROTO_DSTOPTS = 60
IPPROTO_EGP = 8
IPPROTO_ENCAP = 98
IPPROTO_ESP = 50
+IPPROTO_FRAGMENT = 44
IPPROTO_GRE = 47
+IPPROTO_HOPOPTS = 0
IPPROTO_ICMP = 1
+IPPROTO_ICMPV6 = 58
IPPROTO_IDP = 22
IPPROTO_IGMP = 2
IPPROTO_IP = 0
IPPROTO_IPIP = 4
IPPROTO_IPV6 = 41
+IPPROTO_MH = 135
IPPROTO_MPLS = 137
IPPROTO_MTP = 92
+IPPROTO_NONE = 59
IPPROTO_PIM = 103
IPPROTO_PUP = 12
IPPROTO_RAW = 255
+IPPROTO_ROUTING = 43
IPPROTO_RSVP = 46
IPPROTO_SCTP = 132
IPPROTO_TCP = 6
IPPROTO_TP = 29
IPPROTO_UDP = 17
IPPROTO_UDPLITE = 136
+IPV6_SRCRT_STRICT = 1
+IPV6_SRCRT_TYPE_0 = 0
+IPV6_SRCRT_TYPE_2 = 2
+IPV6_TLV_CALIPSO = 7
+IPV6_TLV_HAO = 201
+IPV6_TLV_JUMBO = 194
+IPV6_TLV_PAD1 = 0
+IPV6_TLV_PADN = 1
+IPV6_TLV_ROUTERALERT = 5
+NEXTHDR_AUTH = 51
+NEXTHDR_DEST = 60
+NEXTHDR_ESP = 50
+NEXTHDR_FRAGMENT = 44
+NEXTHDR_GRE = 47
+NEXTHDR_HOP = 0
+NEXTHDR_ICMP = 58
+NEXTHDR_IPV6 = 41
+NEXTHDR_MOBILITY = 135
+NEXTHDR_NONE = 59
+NEXTHDR_ROUTING = 43
+NEXTHDR_SCTP = 132
+NEXTHDR_TCP = 6
+NEXTHDR_UDP = 17
TCPHDR_ACK = 16
TCPHDR_CWR = 128
TCPHDR_ECE = 64
diff --git a/sys/vnet_ppc64le.const b/sys/vnet_ppc64le.const
index 9d9a8855b..b59f7a4f3 100644
--- a/sys/vnet_ppc64le.const
+++ b/sys/vnet_ppc64le.const
@@ -80,27 +80,57 @@ IPPROTO_AH = 51
IPPROTO_BEETPH = 94
IPPROTO_COMP = 108
IPPROTO_DCCP = 33
+IPPROTO_DSTOPTS = 60
IPPROTO_EGP = 8
IPPROTO_ENCAP = 98
IPPROTO_ESP = 50
+IPPROTO_FRAGMENT = 44
IPPROTO_GRE = 47
+IPPROTO_HOPOPTS = 0
IPPROTO_ICMP = 1
+IPPROTO_ICMPV6 = 58
IPPROTO_IDP = 22
IPPROTO_IGMP = 2
IPPROTO_IP = 0
IPPROTO_IPIP = 4
IPPROTO_IPV6 = 41
+IPPROTO_MH = 135
IPPROTO_MPLS = 137
IPPROTO_MTP = 92
+IPPROTO_NONE = 59
IPPROTO_PIM = 103
IPPROTO_PUP = 12
IPPROTO_RAW = 255
+IPPROTO_ROUTING = 43
IPPROTO_RSVP = 46
IPPROTO_SCTP = 132
IPPROTO_TCP = 6
IPPROTO_TP = 29
IPPROTO_UDP = 17
IPPROTO_UDPLITE = 136
+IPV6_SRCRT_STRICT = 1
+IPV6_SRCRT_TYPE_0 = 0
+IPV6_SRCRT_TYPE_2 = 2
+IPV6_TLV_CALIPSO = 7
+IPV6_TLV_HAO = 201
+IPV6_TLV_JUMBO = 194
+IPV6_TLV_PAD1 = 0
+IPV6_TLV_PADN = 1
+IPV6_TLV_ROUTERALERT = 5
+NEXTHDR_AUTH = 51
+NEXTHDR_DEST = 60
+NEXTHDR_ESP = 50
+NEXTHDR_FRAGMENT = 44
+NEXTHDR_GRE = 47
+NEXTHDR_HOP = 0
+NEXTHDR_ICMP = 58
+NEXTHDR_IPV6 = 41
+NEXTHDR_MOBILITY = 135
+NEXTHDR_NONE = 59
+NEXTHDR_ROUTING = 43
+NEXTHDR_SCTP = 132
+NEXTHDR_TCP = 6
+NEXTHDR_UDP = 17
TCPHDR_ACK = 16
TCPHDR_CWR = 128
TCPHDR_ECE = 64