Annotation of sys/netinet6/in6_proto.c, Revision 1.1
1.1 ! nbrk 1: /* $OpenBSD: in6_proto.c,v 1.52 2007/05/03 15:47:47 claudio Exp $ */
! 2: /* $KAME: in6_proto.c,v 1.66 2000/10/10 15:35:47 itojun Exp $ */
! 3:
! 4: /*
! 5: * Copyright (C) 1995, 1996, 1997, and 1998 WIDE Project.
! 6: * All rights reserved.
! 7: *
! 8: * Redistribution and use in source and binary forms, with or without
! 9: * modification, are permitted provided that the following conditions
! 10: * are met:
! 11: * 1. Redistributions of source code must retain the above copyright
! 12: * notice, this list of conditions and the following disclaimer.
! 13: * 2. Redistributions in binary form must reproduce the above copyright
! 14: * notice, this list of conditions and the following disclaimer in the
! 15: * documentation and/or other materials provided with the distribution.
! 16: * 3. Neither the name of the project nor the names of its contributors
! 17: * may be used to endorse or promote products derived from this software
! 18: * without specific prior written permission.
! 19: *
! 20: * THIS SOFTWARE IS PROVIDED BY THE PROJECT AND CONTRIBUTORS ``AS IS'' AND
! 21: * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
! 22: * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
! 23: * ARE DISCLAIMED. IN NO EVENT SHALL THE PROJECT OR CONTRIBUTORS BE LIABLE
! 24: * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
! 25: * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
! 26: * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
! 27: * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
! 28: * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
! 29: * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
! 30: * SUCH DAMAGE.
! 31: */
! 32:
! 33: /*
! 34: * Copyright (c) 1982, 1986, 1993
! 35: * The Regents of the University of California. All rights reserved.
! 36: *
! 37: * Redistribution and use in source and binary forms, with or without
! 38: * modification, are permitted provided that the following conditions
! 39: * are met:
! 40: * 1. Redistributions of source code must retain the above copyright
! 41: * notice, this list of conditions and the following disclaimer.
! 42: * 2. Redistributions in binary form must reproduce the above copyright
! 43: * notice, this list of conditions and the following disclaimer in the
! 44: * documentation and/or other materials provided with the distribution.
! 45: * 3. Neither the name of the University nor the names of its contributors
! 46: * may be used to endorse or promote products derived from this software
! 47: * without specific prior written permission.
! 48: *
! 49: * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
! 50: * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
! 51: * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
! 52: * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
! 53: * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
! 54: * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
! 55: * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
! 56: * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
! 57: * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
! 58: * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
! 59: * SUCH DAMAGE.
! 60: *
! 61: * @(#)in_proto.c 8.1 (Berkeley) 6/10/93
! 62: */
! 63:
! 64: #include <sys/param.h>
! 65: #include <sys/socket.h>
! 66: #include <sys/protosw.h>
! 67: #include <sys/kernel.h>
! 68: #include <sys/domain.h>
! 69: #include <sys/mbuf.h>
! 70:
! 71: #include <net/if.h>
! 72: #include <net/radix.h>
! 73: #ifndef SMALL_KERNEL
! 74: #include <net/radix_mpath.h>
! 75: #endif
! 76: #include <net/route.h>
! 77:
! 78: #include <netinet/in.h>
! 79: #include <netinet/in_systm.h>
! 80: #include <netinet/in_var.h>
! 81: #include <netinet/ip.h>
! 82: #include <netinet/ip_var.h>
! 83: #include <netinet/in_pcb.h>
! 84: #include <netinet/ip6.h>
! 85: #include <netinet6/ip6_var.h>
! 86: #include <netinet/icmp6.h>
! 87:
! 88: #include <netinet/tcp.h>
! 89: #include <netinet/tcp_timer.h>
! 90: #include <netinet/tcp_var.h>
! 91: #include <netinet/udp.h>
! 92: #include <netinet/udp_var.h>
! 93: #include <netinet/ip_ipsp.h>
! 94: #include <netinet/ip_ah.h>
! 95: #include <netinet/ip_esp.h>
! 96: #include <netinet/ip_ipip.h>
! 97:
! 98: #ifdef MROUTING
! 99: #include <netinet6/pim6_var.h>
! 100: #endif
! 101:
! 102: #include <netinet6/nd6.h>
! 103:
! 104: #include <netinet6/ip6protosw.h>
! 105:
! 106: #include "gif.h"
! 107: #if NGIF > 0
! 108: #include <netinet6/in6_gif.h>
! 109: #endif
! 110:
! 111: #include "carp.h"
! 112: #if NCARP > 0
! 113: #include <netinet/ip_carp.h>
! 114: #endif
! 115:
! 116: /*
! 117: * TCP/IP protocol family: IP6, ICMP6, UDP, TCP.
! 118: */
! 119:
! 120: extern struct domain inet6domain;
! 121:
! 122: struct ip6protosw inet6sw[] = {
! 123: { 0, &inet6domain, IPPROTO_IPV6, 0,
! 124: 0, 0, 0, 0,
! 125: 0,
! 126: ip6_init, 0, frag6_slowtimo, frag6_drain,
! 127: ip6_sysctl,
! 128: },
! 129: { SOCK_DGRAM, &inet6domain, IPPROTO_UDP, PR_ATOMIC|PR_ADDR,
! 130: udp6_input, 0, udp6_ctlinput, ip6_ctloutput,
! 131: udp6_usrreq, 0,
! 132: 0, 0, 0,
! 133: udp_sysctl,
! 134: },
! 135: { SOCK_STREAM, &inet6domain, IPPROTO_TCP, PR_CONNREQUIRED|PR_WANTRCVD|PR_ABRTACPTDIS,
! 136: tcp6_input, 0, tcp6_ctlinput, tcp_ctloutput,
! 137: tcp6_usrreq,
! 138: #ifdef INET /* don't call initialization and timeout routines twice */
! 139: 0, 0, 0, tcp_drain,
! 140: #else
! 141: tcp_init, tcp_fasttimo, tcp_slowtimo, tcp_drain,
! 142: #endif
! 143: tcp_sysctl,
! 144: },
! 145: { SOCK_RAW, &inet6domain, IPPROTO_RAW, PR_ATOMIC|PR_ADDR,
! 146: rip6_input, rip6_output, rip6_ctlinput, rip6_ctloutput,
! 147: rip6_usrreq,
! 148: 0, 0, 0, 0,
! 149: },
! 150: { SOCK_RAW, &inet6domain, IPPROTO_ICMPV6, PR_ATOMIC|PR_ADDR,
! 151: icmp6_input, rip6_output, rip6_ctlinput, rip6_ctloutput,
! 152: rip6_usrreq,
! 153: icmp6_init, icmp6_fasttimo, 0, 0,
! 154: icmp6_sysctl,
! 155: },
! 156: { SOCK_RAW, &inet6domain, IPPROTO_DSTOPTS,PR_ATOMIC|PR_ADDR,
! 157: dest6_input, 0, 0, 0,
! 158: 0,
! 159: 0, 0, 0, 0,
! 160: },
! 161: { SOCK_RAW, &inet6domain, IPPROTO_ROUTING,PR_ATOMIC|PR_ADDR,
! 162: route6_input, 0, 0, 0,
! 163: 0,
! 164: 0, 0, 0, 0,
! 165: },
! 166: { SOCK_RAW, &inet6domain, IPPROTO_FRAGMENT,PR_ATOMIC|PR_ADDR,
! 167: frag6_input, 0, 0, 0,
! 168: 0,
! 169: 0, 0, 0, 0,
! 170: },
! 171: #ifdef IPSEC
! 172: { SOCK_RAW, &inet6domain, IPPROTO_AH, PR_ATOMIC|PR_ADDR,
! 173: ah6_input, 0, 0, 0,
! 174: 0,
! 175: 0, 0, 0, 0,
! 176: ah_sysctl,
! 177: },
! 178: { SOCK_RAW, &inet6domain, IPPROTO_ESP, PR_ATOMIC|PR_ADDR,
! 179: esp6_input, 0, 0, 0,
! 180: 0,
! 181: 0, 0, 0, 0,
! 182: esp_sysctl,
! 183: },
! 184: { SOCK_RAW, &inet6domain, IPPROTO_IPCOMP, PR_ATOMIC|PR_ADDR,
! 185: ipcomp6_input, 0, 0, 0,
! 186: 0,
! 187: 0, 0, 0, 0,
! 188: ipcomp_sysctl,
! 189: },
! 190: #endif /* IPSEC */
! 191: #if NGIF > 0
! 192: { SOCK_RAW, &inet6domain, IPPROTO_IPV6, PR_ATOMIC|PR_ADDR,
! 193: in6_gif_input, rip6_output, 0, rip6_ctloutput,
! 194: rip6_usrreq, /* XXX */
! 195: 0, 0, 0, 0,
! 196: },
! 197: #ifdef INET
! 198: { SOCK_RAW, &inet6domain, IPPROTO_IPV4, PR_ATOMIC|PR_ADDR,
! 199: in6_gif_input, rip6_output, 0, rip6_ctloutput,
! 200: rip6_usrreq, /* XXX */
! 201: 0, 0, 0, 0,
! 202: },
! 203: #endif /* INET */
! 204: #else /* NGIF */
! 205: { SOCK_RAW, &inet6domain, IPPROTO_IPV6, PR_ATOMIC|PR_ADDR,
! 206: ip4_input6, rip6_output, 0, rip6_ctloutput,
! 207: rip6_usrreq, /* XXX */
! 208: 0, 0, 0, 0, ipip_sysctl
! 209: },
! 210: #ifdef INET
! 211: { SOCK_RAW, &inet6domain, IPPROTO_IPV4, PR_ATOMIC|PR_ADDR,
! 212: ip4_input6, rip6_output, 0, rip6_ctloutput,
! 213: rip6_usrreq, /* XXX */
! 214: 0, 0, 0, 0,
! 215: },
! 216: #endif /* INET */
! 217: #endif /* GIF */
! 218: #ifdef MROUTING
! 219: { SOCK_RAW, &inet6domain, IPPROTO_PIM, PR_ATOMIC|PR_ADDR,
! 220: pim6_input, rip6_output, 0, rip6_ctloutput,
! 221: rip6_usrreq,
! 222: 0, 0, 0, 0,
! 223: },
! 224: #endif
! 225: #if NCARP > 0
! 226: { SOCK_RAW, &inet6domain, IPPROTO_CARP, PR_ATOMIC|PR_ADDR,
! 227: carp6_proto_input, rip6_output, 0, rip6_ctloutput,
! 228: rip6_usrreq,
! 229: 0, 0, 0, 0, carp_sysctl
! 230: },
! 231: #endif /* NCARP */
! 232: /* raw wildcard */
! 233: { SOCK_RAW, &inet6domain, 0, PR_ATOMIC|PR_ADDR,
! 234: rip6_input, rip6_output, 0, rip6_ctloutput,
! 235: rip6_usrreq, rip6_init,
! 236: 0, 0, 0,
! 237: },
! 238: };
! 239:
! 240: struct domain inet6domain =
! 241: { AF_INET6, "internet6", 0, 0, 0,
! 242: (struct protosw *)inet6sw,
! 243: (struct protosw *)&inet6sw[sizeof(inet6sw)/sizeof(inet6sw[0])], 0,
! 244: #ifndef SMALL_KERNEL
! 245: rn_mpath_inithead,
! 246: #else
! 247: rn_inithead,
! 248: #endif
! 249: offsetof(struct sockaddr_in6, sin6_addr) << 3,
! 250: sizeof(struct sockaddr_in6),
! 251: in6_domifattach, in6_domifdetach, };
! 252:
! 253: /*
! 254: * Internet configuration info
! 255: */
! 256: int ip6_forwarding = 0; /* no forwarding unless sysctl'd to enable */
! 257: int ip6_mforwarding = 0; /* no multicast forwarding unless ... */
! 258: int ip6_multipath = 0; /* no using multipath routes unless ... */
! 259: int ip6_sendredirects = 1;
! 260: int ip6_defhlim = IPV6_DEFHLIM;
! 261: int ip6_defmcasthlim = IPV6_DEFAULT_MULTICAST_HOPS;
! 262: int ip6_accept_rtadv = 0; /* enabling forwarding and rtadv concurrently is dangerous */
! 263: int ip6_maxfragpackets = 200;
! 264: int ip6_maxfrags = 200;
! 265: int ip6_log_interval = 5;
! 266: int ip6_hdrnestlimit = 10; /* appropriate? */
! 267: int ip6_dad_count = 1; /* DupAddrDetectionTransmits */
! 268: int ip6_auto_flowlabel = 1;
! 269: int ip6_use_deprecated = 1; /* allow deprecated addr (RFC2462 5.5.4) */
! 270: int ip6_rr_prune = 5; /* router renumbering prefix
! 271: * walk list every 5 sec. */
! 272: int ip6_mcast_pmtu = 0; /* enable pMTU discovery for multicast? */
! 273: const int ip6_v6only = 1;
! 274: u_int32_t ip6_id = 0UL;
! 275: int ip6_keepfaith = 0;
! 276: time_t ip6_log_time = (time_t)0L;
! 277:
! 278: /* icmp6 */
! 279: /*
! 280: * BSDI4 defines these variables in in_proto.c...
! 281: * XXX: what if we don't define INET? Should we define pmtu6_expire
! 282: * or so? (jinmei@kame.net 19990310)
! 283: */
! 284: int pmtu_expire = 60*10;
! 285:
! 286: /* raw IP6 parameters */
! 287: /*
! 288: * Nominal space allocated to a raw ip socket.
! 289: */
! 290: #define RIPV6SNDQ 8192
! 291: #define RIPV6RCVQ 8192
! 292:
! 293: u_long rip6_sendspace = RIPV6SNDQ;
! 294: u_long rip6_recvspace = RIPV6RCVQ;
! 295:
! 296: /* ICMPV6 parameters */
! 297: int icmp6_rediraccept = 1; /* accept and process redirects */
! 298: int icmp6_redirtimeout = 10 * 60; /* 10 minutes */
! 299: struct timeval icmp6errratelim = { 0, 0 }; /* no ratelimit */
! 300: int icmp6errppslim = 100; /* 100pps */
! 301: int icmp6_nodeinfo = 1; /* enable/disable NI response */
! 302:
! 303: /* UDP on IP6 parameters */
! 304: int udp6_sendspace = 9216; /* really max datagram size */
! 305: int udp6_recvspace = 40 * (1024 + sizeof(struct sockaddr_in6));
! 306: /* 40 1K datagrams */
CVSweb