version 1.65, 2003/08/07 16:33:26 |
version 1.72, 2004/02/11 10:54:29 |
|
|
ip6intrq.ifq_maxlen = ip6qmaxlen; |
ip6intrq.ifq_maxlen = ip6qmaxlen; |
nd6_init(); |
nd6_init(); |
frag6_init(); |
frag6_init(); |
ip6_flow_seq = arc4random(); |
|
|
|
ip6_init2((void *)0); |
ip6_init2((void *)0); |
|
|
|
|
if (ip6_forward_rt.ro_rt != NULL && |
if (ip6_forward_rt.ro_rt != NULL && |
(ip6_forward_rt.ro_rt->rt_flags & RTF_UP) != 0 && |
(ip6_forward_rt.ro_rt->rt_flags & RTF_UP) != 0 && |
IN6_ARE_ADDR_EQUAL(&ip6->ip6_dst, |
IN6_ARE_ADDR_EQUAL(&ip6->ip6_dst, |
&((struct sockaddr_in6 *)(&ip6_forward_rt.ro_dst))->sin6_addr)) |
&((struct sockaddr_in6 *)(&ip6_forward_rt.ro_dst))->sin6_addr)) |
ip6stat.ip6s_forward_cachehit++; |
ip6stat.ip6s_forward_cachehit++; |
else { |
else { |
struct sockaddr_in6 *dst6; |
struct sockaddr_in6 *dst6; |
|
|
*/ |
*/ |
#if defined(NFAITH) && 0 < NFAITH |
#if defined(NFAITH) && 0 < NFAITH |
if (ip6_keepfaith) { |
if (ip6_keepfaith) { |
if (ip6_forward_rt.ro_rt && ip6_forward_rt.ro_rt->rt_ifp |
if (ip6_forward_rt.ro_rt && ip6_forward_rt.ro_rt->rt_ifp && |
&& ip6_forward_rt.ro_rt->rt_ifp->if_type == IFT_FAITH) { |
ip6_forward_rt.ro_rt->rt_ifp->if_type == IFT_FAITH) { |
/* XXX do we need more sanity checks? */ |
/* XXX do we need more sanity checks? */ |
ours = 1; |
ours = 1; |
deliverifp = ip6_forward_rt.ro_rt->rt_ifp; /* faith */ |
deliverifp = ip6_forward_rt.ro_rt->rt_ifp; /* faith */ |
Line 771 ip6_hopopts_input(plenp, rtalertp, mp, o |
|
Line 770 ip6_hopopts_input(plenp, rtalertp, mp, o |
|
struct mbuf *m = *mp; |
struct mbuf *m = *mp; |
int off = *offp, hbhlen; |
int off = *offp, hbhlen; |
struct ip6_hbh *hbh; |
struct ip6_hbh *hbh; |
u_int8_t *opt; |
|
|
|
/* validation of the length of the header */ |
/* validation of the length of the header */ |
IP6_EXTHDR_GET(hbh, struct ip6_hbh *, m, |
IP6_EXTHDR_GET(hbh, struct ip6_hbh *, m, |
Line 790 ip6_hopopts_input(plenp, rtalertp, mp, o |
|
Line 788 ip6_hopopts_input(plenp, rtalertp, mp, o |
|
KASSERT(IP6_HDR_ALIGNED_P(hbh)); |
KASSERT(IP6_HDR_ALIGNED_P(hbh)); |
off += hbhlen; |
off += hbhlen; |
hbhlen -= sizeof(struct ip6_hbh); |
hbhlen -= sizeof(struct ip6_hbh); |
opt = (u_int8_t *)hbh + sizeof(struct ip6_hbh); |
|
|
|
if (ip6_process_hopopts(m, (u_int8_t *)hbh + sizeof(struct ip6_hbh), |
if (ip6_process_hopopts(m, (u_int8_t *)hbh + sizeof(struct ip6_hbh), |
hbhlen, rtalertp, plenp) < 0) |
hbhlen, rtalertp, plenp) < 0) |
Line 1352 ip6_nexthdr(m, off, proto, nxtp) |
|
Line 1349 ip6_nexthdr(m, off, proto, nxtp) |
|
if (m->m_pkthdr.len < off + sizeof(fh)) |
if (m->m_pkthdr.len < off + sizeof(fh)) |
return -1; |
return -1; |
m_copydata(m, off, sizeof(fh), (caddr_t)&fh); |
m_copydata(m, off, sizeof(fh), (caddr_t)&fh); |
if ((ntohs(fh.ip6f_offlg) & IP6F_OFF_MASK) != 0) |
if ((fh.ip6f_offlg & IP6F_OFF_MASK) != 0) |
return -1; |
return -1; |
if (nxtp) |
if (nxtp) |
*nxtp = fh.ip6f_nxt; |
*nxtp = fh.ip6f_nxt; |
Line 1438 u_char inet6ctlerrmap[PRC_NCMDS] = { |
|
Line 1435 u_char inet6ctlerrmap[PRC_NCMDS] = { |
|
ENOPROTOOPT |
ENOPROTOOPT |
}; |
}; |
|
|
int |
SYSCTL_SETUP(sysctl_net_inet6_ip6_setup, "sysctl net.inet6.ip6 subtree setup") |
ip6_sysctl(name, namelen, oldp, oldlenp, newp, newlen) |
|
int *name; |
|
u_int namelen; |
|
void *oldp; |
|
size_t *oldlenp; |
|
void *newp; |
|
size_t newlen; |
|
{ |
{ |
int old, error; |
|
|
|
/* All sysctl names at this level are terminal. */ |
sysctl_createv(SYSCTL_PERMANENT, |
if (namelen != 1) |
CTLTYPE_NODE, "net", NULL, |
return ENOTDIR; |
NULL, 0, NULL, 0, |
|
CTL_NET, CTL_EOL); |
switch (name[0]) { |
sysctl_createv(SYSCTL_PERMANENT, |
|
CTLTYPE_NODE, "inet6", NULL, |
case IPV6CTL_FORWARDING: |
NULL, 0, NULL, 0, |
return sysctl_int(oldp, oldlenp, newp, newlen, |
CTL_NET, PF_INET6, CTL_EOL); |
&ip6_forwarding); |
sysctl_createv(SYSCTL_PERMANENT, |
case IPV6CTL_SENDREDIRECTS: |
CTLTYPE_NODE, "ip6", NULL, |
return sysctl_int(oldp, oldlenp, newp, newlen, |
NULL, 0, NULL, 0, |
&ip6_sendredirects); |
CTL_NET, PF_INET6, IPPROTO_IPV6, CTL_EOL); |
case IPV6CTL_DEFHLIM: |
|
return sysctl_int(oldp, oldlenp, newp, newlen, &ip6_defhlim); |
sysctl_createv(SYSCTL_PERMANENT|SYSCTL_READWRITE, |
case IPV6CTL_MAXFRAGPACKETS: |
CTLTYPE_INT, "forwarding", NULL, |
return sysctl_int(oldp, oldlenp, newp, newlen, |
NULL, 0, &ip6_forwarding, 0, |
&ip6_maxfragpackets); |
CTL_NET, PF_INET6, IPPROTO_IPV6, |
case IPV6CTL_ACCEPT_RTADV: |
IPV6CTL_FORWARDING, CTL_EOL); |
return sysctl_int(oldp, oldlenp, newp, newlen, |
sysctl_createv(SYSCTL_PERMANENT|SYSCTL_READWRITE, |
&ip6_accept_rtadv); |
CTLTYPE_INT, "redirect", NULL, |
case IPV6CTL_KEEPFAITH: |
NULL, 0, &ip6_sendredirects, 0, |
return sysctl_int(oldp, oldlenp, newp, newlen, &ip6_keepfaith); |
CTL_NET, PF_INET6, IPPROTO_IPV6, |
case IPV6CTL_LOG_INTERVAL: |
IPV6CTL_SENDREDIRECTS, CTL_EOL); |
return sysctl_int(oldp, oldlenp, newp, newlen, |
sysctl_createv(SYSCTL_PERMANENT|SYSCTL_READWRITE, |
&ip6_log_interval); |
CTLTYPE_INT, "hlim", NULL, |
case IPV6CTL_HDRNESTLIMIT: |
NULL, 0, &ip6_defhlim, 0, |
return sysctl_int(oldp, oldlenp, newp, newlen, |
CTL_NET, PF_INET6, IPPROTO_IPV6, |
&ip6_hdrnestlimit); |
IPV6CTL_DEFHLIM, CTL_EOL); |
case IPV6CTL_DAD_COUNT: |
#ifdef notyet |
return sysctl_int(oldp, oldlenp, newp, newlen, &ip6_dad_count); |
sysctl_createv(SYSCTL_PERMANENT|SYSCTL_READWRITE, |
case IPV6CTL_AUTO_FLOWLABEL: |
CTLTYPE_INT, "mtu", NULL, |
return sysctl_int(oldp, oldlenp, newp, newlen, |
NULL, 0, &, 0, |
&ip6_auto_flowlabel); |
CTL_NET, PF_INET6, IPPROTO_IPV6, |
case IPV6CTL_DEFMCASTHLIM: |
IPV6CTL_DEFMTU, CTL_EOL); |
return sysctl_int(oldp, oldlenp, newp, newlen, |
|
&ip6_defmcasthlim); |
|
#if NGIF > 0 |
|
case IPV6CTL_GIF_HLIM: |
|
return sysctl_int(oldp, oldlenp, newp, newlen, |
|
&ip6_gif_hlim); |
|
#endif |
#endif |
case IPV6CTL_KAME_VERSION: |
#ifdef __no_idea__ |
return sysctl_rdstring(oldp, oldlenp, newp, __KAME_VERSION); |
sysctl_createv(SYSCTL_PERMANENT|SYSCTL_READWRITE, |
case IPV6CTL_USE_DEPRECATED: |
CTLTYPE_INT, "forwsrcrt", NULL, |
return sysctl_int(oldp, oldlenp, newp, newlen, |
NULL, 0, &?, 0, |
&ip6_use_deprecated); |
CTL_NET, PF_INET6, IPPROTO_IPV6, |
case IPV6CTL_RR_PRUNE: |
IPV6CTL_FORWSRCRT, CTL_EOL); |
return sysctl_int(oldp, oldlenp, newp, newlen, &ip6_rr_prune); |
sysctl_createv(SYSCTL_PERMANENT|SYSCTL_READWRITE, |
case IPV6CTL_V6ONLY: |
CTLTYPE_STRUCT, "stats", NULL, |
#ifdef INET6_BINDV6ONLY |
NULL, 0, &?, sizeof(?), |
return sysctl_rdint(oldp, oldlenp, newp, ip6_v6only); |
CTL_NET, PF_INET6, IPPROTO_IPV6, |
#else |
IPV6CTL_STATS, CTL_EOL); |
return sysctl_int(oldp, oldlenp, newp, newlen, &ip6_v6only); |
sysctl_createv(SYSCTL_PERMANENT|SYSCTL_READWRITE, |
|
CTLTYPE_STRUCT, "mrtstats", NULL, |
|
NULL, 0, &?, sizeof(?), |
|
CTL_NET, PF_INET6, IPPROTO_IPV6, |
|
IPV6CTL_MRTSTATS, CTL_EOL); |
|
sysctl_createv(SYSCTL_PERMANENT|SYSCTL_READWRITE, |
|
CTLTYPE_?, "mrtproto", NULL, |
|
NULL, 0, &?, sizeof(?), |
|
CTL_NET, PF_INET6, IPPROTO_IPV6, |
|
IPV6CTL_MRTPROTO, CTL_EOL); |
#endif |
#endif |
case IPV6CTL_ANONPORTMIN: |
sysctl_createv(SYSCTL_PERMANENT|SYSCTL_READWRITE, |
old = ip6_anonportmin; |
CTLTYPE_INT, "maxfragpackets", NULL, |
error = sysctl_int(oldp, oldlenp, newp, newlen, |
NULL, 0, &ip6_maxfragpackets, 0, |
&ip6_anonportmin); |
CTL_NET, PF_INET6, IPPROTO_IPV6, |
if (ip6_anonportmin >= ip6_anonportmax || ip6_anonportmin < 0 || |
IPV6CTL_MAXFRAGPACKETS, CTL_EOL); |
ip6_anonportmin > 65535 |
#ifdef __no_idea__ |
#ifndef IPNOPRIVPORTS |
sysctl_createv(SYSCTL_PERMANENT|SYSCTL_READWRITE, |
|| ip6_anonportmin < IPV6PORT_RESERVED |
CTLTYPE_INT, "sourcecheck", NULL, |
|
NULL, 0, &?, 0, |
|
CTL_NET, PF_INET6, IPPROTO_IPV6, |
|
IPV6CTL_SOURCECHECK, CTL_EOL); |
|
sysctl_createv(SYSCTL_PERMANENT|SYSCTL_READWRITE, |
|
CTLTYPE_INT, "sourcecheck_logint", NULL, |
|
NULL, 0, &?, 0, |
|
CTL_NET, PF_INET6, IPPROTO_IPV6, |
|
IPV6CTL_SOURCECHECK_LOGINT, CTL_EOL); |
#endif |
#endif |
) { |
sysctl_createv(SYSCTL_PERMANENT|SYSCTL_READWRITE, |
ip6_anonportmin = old; |
CTLTYPE_INT, "accept_rtadv", NULL, |
return (EINVAL); |
NULL, 0, &ip6_accept_rtadv, 0, |
} |
CTL_NET, PF_INET6, IPPROTO_IPV6, |
return (error); |
IPV6CTL_ACCEPT_RTADV, CTL_EOL); |
case IPV6CTL_ANONPORTMAX: |
sysctl_createv(SYSCTL_PERMANENT|SYSCTL_READWRITE, |
old = ip6_anonportmax; |
CTLTYPE_INT, "keepfaith", NULL, |
error = sysctl_int(oldp, oldlenp, newp, newlen, |
NULL, 0, &ip6_keepfaith, 0, |
&ip6_anonportmax); |
CTL_NET, PF_INET6, IPPROTO_IPV6, |
if (ip6_anonportmin >= ip6_anonportmax || ip6_anonportmax < 0 || |
IPV6CTL_KEEPFAITH, CTL_EOL); |
ip6_anonportmax > 65535 |
sysctl_createv(SYSCTL_PERMANENT|SYSCTL_READWRITE, |
#ifndef IPNOPRIVPORTS |
CTLTYPE_INT, "log_interval", NULL, |
|| ip6_anonportmax < IPV6PORT_RESERVED |
NULL, 0, &ip6_log_interval, 0, |
|
CTL_NET, PF_INET6, IPPROTO_IPV6, |
|
IPV6CTL_LOG_INTERVAL, CTL_EOL); |
|
sysctl_createv(SYSCTL_PERMANENT|SYSCTL_READWRITE, |
|
CTLTYPE_INT, "hdrnestlimit", NULL, |
|
NULL, 0, &ip6_hdrnestlimit, 0, |
|
CTL_NET, PF_INET6, IPPROTO_IPV6, |
|
IPV6CTL_HDRNESTLIMIT, CTL_EOL); |
|
sysctl_createv(SYSCTL_PERMANENT|SYSCTL_READWRITE, |
|
CTLTYPE_INT, "dad_count", NULL, |
|
NULL, 0, &ip6_dad_count, 0, |
|
CTL_NET, PF_INET6, IPPROTO_IPV6, |
|
IPV6CTL_DAD_COUNT, CTL_EOL); |
|
sysctl_createv(SYSCTL_PERMANENT|SYSCTL_READWRITE, |
|
CTLTYPE_INT, "auto_flowlabel", NULL, |
|
NULL, 0, &ip6_auto_flowlabel, 0, |
|
CTL_NET, PF_INET6, IPPROTO_IPV6, |
|
IPV6CTL_AUTO_FLOWLABEL, CTL_EOL); |
|
sysctl_createv(SYSCTL_PERMANENT|SYSCTL_READWRITE, |
|
CTLTYPE_INT, "defmcasthlim", NULL, |
|
NULL, 0, &ip6_defmcasthlim, 0, |
|
CTL_NET, PF_INET6, IPPROTO_IPV6, |
|
IPV6CTL_DEFMCASTHLIM, CTL_EOL); |
|
#if NGIF > 0 |
|
sysctl_createv(SYSCTL_PERMANENT|SYSCTL_READWRITE, |
|
CTLTYPE_INT, "gifhlim", NULL, |
|
NULL, 0, &ip6_gif_hlim, 0, |
|
CTL_NET, PF_INET6, IPPROTO_IPV6, |
|
IPV6CTL_GIF_HLIM, CTL_EOL); |
|
#endif /* NGIF */ |
|
sysctl_createv(SYSCTL_PERMANENT, |
|
CTLTYPE_STRING, "kame_version", NULL, |
|
NULL, 0, __KAME_VERSION, 0, |
|
CTL_NET, PF_INET6, IPPROTO_IPV6, |
|
IPV6CTL_KAME_VERSION, CTL_EOL); |
|
sysctl_createv(SYSCTL_PERMANENT|SYSCTL_READWRITE, |
|
CTLTYPE_INT, "use_deprecated", NULL, |
|
NULL, 0, &ip6_use_deprecated, 0, |
|
CTL_NET, PF_INET6, IPPROTO_IPV6, |
|
IPV6CTL_USE_DEPRECATED, CTL_EOL); |
|
sysctl_createv(SYSCTL_PERMANENT|SYSCTL_READWRITE, |
|
CTLTYPE_INT, "rr_prune", NULL, |
|
NULL, 0, &ip6_rr_prune, 0, |
|
CTL_NET, PF_INET6, IPPROTO_IPV6, |
|
IPV6CTL_RR_PRUNE, CTL_EOL); |
|
sysctl_createv(SYSCTL_PERMANENT |
|
#ifndef INET6_BINDV6ONLY |
|
|SYSCTL_READWRITE, |
#endif |
#endif |
) { |
CTLTYPE_INT, "v6only", NULL, |
ip6_anonportmax = old; |
NULL, 0, &ip6_v6only, 0, |
return (EINVAL); |
CTL_NET, PF_INET6, IPPROTO_IPV6, |
} |
IPV6CTL_V6ONLY, CTL_EOL); |
return (error); |
sysctl_createv(SYSCTL_PERMANENT|SYSCTL_READWRITE, |
|
CTLTYPE_INT, "anonportmin", NULL, |
|
sysctl_net_inet_ip_ports, 0, &ip6_anonportmin, 0, |
|
CTL_NET, PF_INET6, IPPROTO_IPV6, |
|
IPV6CTL_ANONPORTMIN, CTL_EOL); |
|
sysctl_createv(SYSCTL_PERMANENT|SYSCTL_READWRITE, |
|
CTLTYPE_INT, "anonportmax", NULL, |
|
sysctl_net_inet_ip_ports, 0, &ip6_anonportmax, 0, |
|
CTL_NET, PF_INET6, IPPROTO_IPV6, |
|
IPV6CTL_ANONPORTMAX, CTL_EOL); |
#ifndef IPNOPRIVPORTS |
#ifndef IPNOPRIVPORTS |
case IPV6CTL_LOWPORTMIN: |
sysctl_createv(SYSCTL_PERMANENT|SYSCTL_READWRITE, |
old = ip6_lowportmin; |
CTLTYPE_INT, "lowportmin", NULL, |
error = sysctl_int(oldp, oldlenp, newp, newlen, |
sysctl_net_inet_ip_ports, 0, &ip6_lowportmin, 0, |
&ip6_lowportmin); |
CTL_NET, PF_INET6, IPPROTO_IPV6, |
if (ip6_lowportmin >= ip6_lowportmax || |
IPV6CTL_LOWPORTMIN, CTL_EOL); |
ip6_lowportmin > IPV6PORT_RESERVEDMAX || |
sysctl_createv(SYSCTL_PERMANENT|SYSCTL_READWRITE, |
ip6_lowportmin < IPV6PORT_RESERVEDMIN) { |
CTLTYPE_INT, "lowportmax", NULL, |
ip6_lowportmin = old; |
sysctl_net_inet_ip_ports, 0, &ip6_lowportmax, 0, |
return (EINVAL); |
CTL_NET, PF_INET6, IPPROTO_IPV6, |
} |
IPV6CTL_LOWPORTMAX, CTL_EOL); |
return (error); |
#endif /* IPNOPRIVPORTS */ |
case IPV6CTL_LOWPORTMAX: |
sysctl_createv(SYSCTL_PERMANENT|SYSCTL_READWRITE, |
old = ip6_lowportmax; |
CTLTYPE_INT, "maxfrags", NULL, |
error = sysctl_int(oldp, oldlenp, newp, newlen, |
NULL, 0, &ip6_maxfrags, 0, |
&ip6_lowportmax); |
CTL_NET, PF_INET6, IPPROTO_IPV6, |
if (ip6_lowportmin >= ip6_lowportmax || |
IPV6CTL_MAXFRAGS, CTL_EOL); |
ip6_lowportmax > IPV6PORT_RESERVEDMAX || |
|
ip6_lowportmax < IPV6PORT_RESERVEDMIN) { |
|
ip6_lowportmax = old; |
|
return (EINVAL); |
|
} |
|
return (error); |
|
#endif |
|
case IPV6CTL_MAXFRAGS: |
|
return sysctl_int(oldp, oldlenp, newp, newlen, &ip6_maxfrags); |
|
default: |
|
return EOPNOTSUPP; |
|
} |
|
/* NOTREACHED */ |
|
} |
} |