Home | History | Annotate | Download | only in freebsd
      1 # Copyright 2017 syzkaller project authors. All rights reserved.
      2 # Use of this source code is governed by Apache 2 LICENSE that can be found in the LICENSE file.
      3 
      4 include <sys/types.h>
      5 include <sys/socket.h>
      6 include <sys/sockio.h>
      7 include <netinet/in.h>
      8 
      9 # IP sockets
     10 
     11 resource sock_in[sock]
     12 resource ifindex[int32]
     13 
     14 sock_in_pair {
     15 	f0	sock_in
     16 	f1	sock_in
     17 }
     18 
     19 sockaddr_in {
     20 	family	const[AF_INET, int16]
     21 	port	sock_port
     22 	addr	ipv4_addr
     23 	pad	array[const[0, int8], 8]
     24 }
     25 
     26 sockaddr_storage_in {
     27 	addr	sockaddr_in
     28 	pad	array[const[0, int64], 15]
     29 }
     30 
     31 socket$inet(domain const[AF_INET], type flags[socket_type], proto int8) sock_in
     32 socketpair$inet(domain const[AF_INET], type flags[socket_type], proto int8, fds ptr[out, sock_in_pair])
     33 accept$inet(fd sock_in, peer ptr[out, sockaddr_in, opt], peerlen ptr[inout, len[peer, int32]]) sock_in
     34 accept4$inet(fd sock_in, peer ptr[out, sockaddr_in, opt], peerlen ptr[inout, len[peer, int32]], flags flags[accept_flags]) sock_in
     35 bind$inet(fd sock_in, addr ptr[in, sockaddr_in], addrlen len[addr])
     36 connect$inet(fd sock_in, addr ptr[in, sockaddr_in], addrlen len[addr])
     37 sendto$inet(fd sock_in, buf buffer[in], len len[buf], f flags[send_flags], addr ptr[in, sockaddr_in, opt], addrlen len[addr])
     38 recvfrom$inet(fd sock_in, buf buffer[out], len len[buf], f flags[recv_flags], addr ptr[in, sockaddr_in, opt], addrlen len[addr])
     39 getsockname$inet(fd sock_in, addr ptr[out, sockaddr_in], addrlen ptr[inout, len[addr, int32]])
     40 getpeername$inet(fd sock_in, peer ptr[out, sockaddr_in], peerlen ptr[inout, len[peer, int32]])
     41 
     42 # Generic IP options
     43 
     44 inet_option_types_int = IP_TOS, IP_TTL, IP_HDRINCL, IP_RECVOPTS, IP_RETOPTS, IP_RECVTTL, IP_RECVTOS, IP_RECVORIGDSTADDR, IP_MINTTL
     45 
     46 inet_option_types_buf = IP_OPTIONS, IP_IPSEC_POLICY, IP_MULTICAST_IF, IP_ADD_MEMBERSHIP, IP_DROP_MEMBERSHIP, IP_UNBLOCK_SOURCE, IP_BLOCK_SOURCE, IP_ADD_SOURCE_MEMBERSHIP, IP_DROP_SOURCE_MEMBERSHIP, IP_MSFILTER, MCAST_JOIN_GROUP, MCAST_BLOCK_SOURCE, MCAST_UNBLOCK_SOURCE, MCAST_LEAVE_GROUP, MCAST_JOIN_SOURCE_GROUP, MCAST_LEAVE_SOURCE_GROUP
     47 
     48 getsockopt$inet_int(fd sock_in, level const[IPPROTO_IP], optname flags[inet_option_types_int], optval ptr[out, int32], optlen ptr[inout, len[optval, int32]])
     49 setsockopt$inet_int(fd sock_in, level const[IPPROTO_IP], optname flags[inet_option_types_int], optval ptr[in, int32], optlen len[optval])
     50 getsockopt$inet_buf(fd sock_in, level const[IPPROTO_IP], optname flags[inet_option_types_buf], optval buffer[out], optlen ptr[inout, len[optval, int32]])
     51 setsockopt$inet_buf(fd sock_in, level const[IPPROTO_IP], optname flags[inet_option_types_buf], optval buffer[in], optlen len[optval])
     52 
     53 # Specific IP options
     54 
     55 sockopt_opt_ip_opts = IP_OPTIONS
     56 
     57 getsockopt$inet_opts(fd sock_in, level const[IPPROTO_IP], optname flags[sockopt_opt_ip_opts], optval buffer[out], optlen ptr[inout, len[optval, int32]])
     58 setsockopt$inet_opts(fd sock_in, level const[IPPROTO_IP], optname flags[sockopt_opt_ip_opts], optval buffer[in], optlen len[optval])
     59 
     60 sockopt_opt_ip_mreq = IP_ADD_MEMBERSHIP, IP_DROP_MEMBERSHIP, IP_MULTICAST_IF
     61 
     62 getsockopt$inet_mreq(fd sock_in, level const[IPPROTO_IP], optname flags[sockopt_opt_ip_mreq], optval ptr[out, ip_mreq], optlen ptr[inout, len[optval, int32]])
     63 setsockopt$inet_mreq(fd sock_in, level const[IPPROTO_IP], optname flags[sockopt_opt_ip_mreq], optval ptr[in, ip_mreq], optlen len[optval])
     64 getsockopt$inet_mreqn(fd sock_in, level const[IPPROTO_IP], optname flags[sockopt_opt_ip_mreq], optval ptr[out, ip_mreqn], optlen ptr[inout, len[optval, int32]])
     65 setsockopt$inet_mreqn(fd sock_in, level const[IPPROTO_IP], optname flags[sockopt_opt_ip_mreq], optval ptr[in, ip_mreqn], optlen len[optval])
     66 
     67 sockopt_opt_ip_mreqsrc = IP_ADD_SOURCE_MEMBERSHIP, IP_BLOCK_SOURCE, IP_DROP_SOURCE_MEMBERSHIP, IP_UNBLOCK_SOURCE
     68 
     69 getsockopt$inet_mreqsrc(fd sock_in, level const[IPPROTO_IP], optname flags[sockopt_opt_ip_mreqsrc], optval ptr[out, ip_mreq_source], optlen ptr[inout, len[optval, int32]])
     70 setsockopt$inet_mreqsrc(fd sock_in, level const[IPPROTO_IP], optname flags[sockopt_opt_ip_mreqsrc], optval ptr[in, ip_mreq_source], optlen len[optval])
     71 
     72 setsockopt$inet_msfilter(fd sock_in, level const[IPPROTO_IP], optname const[IP_MSFILTER], optval ptr[in, ip_msfilter], optlen len[optval])
     73 
     74 setsockopt$inet_MCAST_JOIN_GROUP(fd sock_in, level const[IPPROTO_IP], optname const[MCAST_JOIN_GROUP], optval ptr[in, group_req_in], optlen len[optval])
     75 setsockopt$inet_MCAST_LEAVE_GROUP(fd sock_in, level const[IPPROTO_IP], optname const[MCAST_LEAVE_GROUP], optval ptr[in, group_req_in], optlen len[optval])
     76 
     77 sockopt_opt_ip_group_source_req = MCAST_JOIN_SOURCE_GROUP, MCAST_LEAVE_SOURCE_GROUP, MCAST_BLOCK_SOURCE, MCAST_UNBLOCK_SOURCE
     78 
     79 setsockopt$inet_group_source_req(fd sock_in, level const[IPPROTO_IP], optname flags[sockopt_opt_ip_group_source_req], optval ptr[in, group_source_req_in], optlen len[optval])
     80 
     81 ip_mreq {
     82 	imr_multiaddr	ipv4_addr
     83 	imr_interface	ipv4_addr
     84 }
     85 
     86 ip_mreqn {
     87 	imr_multiaddr	ipv4_addr
     88 	imr_address	ipv4_addr
     89 	imr_ifindex	ifindex
     90 }
     91 
     92 ip_mreq_source {
     93 	imr_multiaddr	ipv4_addr
     94 	imr_interface	ipv4_addr
     95 	imr_sourceaddr	ipv4_addr
     96 }
     97 
     98 ip_msfilter {
     99 	imsf_multiaddr	ipv4_addr
    100 	imsf_interface	ipv4_addr
    101 	imsf_fmode	flags[ip_msfilter_mode, int32]
    102 	imsf_numsrc	len[imsf_slist, int32]
    103 	imsf_slist	array[ipv4_addr]
    104 }
    105 
    106 ip_msfilter_mode = MCAST_INCLUDE, MCAST_EXCLUDE
    107 
    108 group_req_in {
    109 	gr_interface	int32
    110 	gr_group	sockaddr_storage_in
    111 }
    112 
    113 group_source_req_in {
    114 	gsr_interface	int32
    115 	gsr_group	sockaddr_storage_in
    116 	gsr_source	sockaddr_storage_in
    117 }
    118