version 1.174.2.2, 2009/07/23 23:32:48 |
version 1.184, 2011/12/19 11:59:57 |
Line 96 __KERNEL_RCSID(0, "$NetBSD$"); |
|
Line 96 __KERNEL_RCSID(0, "$NetBSD$"); |
|
#include <netinet/udp.h> |
#include <netinet/udp.h> |
#include <netinet/udp_var.h> |
#include <netinet/udp_var.h> |
#include <netinet/udp_private.h> |
#include <netinet/udp_private.h> |
|
#include <netinet/rfc6056.h> |
|
|
#ifdef INET6 |
#ifdef INET6 |
#include <netinet/ip6.h> |
#include <netinet/ip6.h> |
Line 118 __KERNEL_RCSID(0, "$NetBSD$"); |
|
Line 119 __KERNEL_RCSID(0, "$NetBSD$"); |
|
#include <net/if_faith.h> |
#include <net/if_faith.h> |
#endif |
#endif |
|
|
#include <machine/stdarg.h> |
|
|
|
#ifdef FAST_IPSEC |
#ifdef FAST_IPSEC |
#include <netipsec/ipsec.h> |
#include <netipsec/ipsec.h> |
#include <netipsec/ipsec_var.h> |
#include <netipsec/ipsec_var.h> |
Line 130 __KERNEL_RCSID(0, "$NetBSD$"); |
|
Line 129 __KERNEL_RCSID(0, "$NetBSD$"); |
|
#endif |
#endif |
#endif /* FAST_IPSEC */ |
#endif /* FAST_IPSEC */ |
|
|
#ifdef IPSEC |
#ifdef KAME_IPSEC |
#include <netinet6/ipsec.h> |
#include <netinet6/ipsec.h> |
#include <netinet6/ipsec_private.h> |
#include <netinet6/ipsec_private.h> |
#include <netinet6/esp.h> |
#include <netinet6/esp.h> |
#include <netkey/key.h> |
#include <netkey/key.h> |
#endif /* IPSEC */ |
#endif /* KAME_IPSEC */ |
|
|
#ifdef COMPAT_50 |
#ifdef COMPAT_50 |
#include <compat/sys/socket.h> |
#include <compat/sys/socket.h> |
Line 232 EVCNT_ATTACH_STATIC(udp6_swcsum); |
|
Line 231 EVCNT_ATTACH_STATIC(udp6_swcsum); |
|
|
|
#endif /* UDP_CSUM_COUNTERS */ |
#endif /* UDP_CSUM_COUNTERS */ |
|
|
|
static void sysctl_net_inet_udp_setup(struct sysctllog **); |
|
|
void |
void |
udp_init(void) |
udp_init(void) |
{ |
{ |
|
|
|
sysctl_net_inet_udp_setup(NULL); |
|
|
in_pcbinit(&udbtable, udbhashsize, udbhashsize); |
in_pcbinit(&udbtable, udbhashsize, udbhashsize); |
|
|
MOWNER_ATTACH(&udp_tx_mowner); |
MOWNER_ATTACH(&udp_tx_mowner); |
Line 631 udp4_sendup(struct mbuf *m, int off /* o |
|
Line 634 udp4_sendup(struct mbuf *m, int off /* o |
|
return; |
return; |
} |
} |
|
|
#if defined(IPSEC) || defined(FAST_IPSEC) |
#if defined(KAME_IPSEC) || defined(FAST_IPSEC) |
/* check AH/ESP integrity. */ |
/* check AH/ESP integrity. */ |
if (so != NULL && ipsec4_in_reject_so(m, so)) { |
if (so != NULL && ipsec4_in_reject_so(m, so)) { |
IPSEC_STATINC(IPSEC_STAT_IN_POLVIO); |
IPSEC_STATINC(IPSEC_STAT_IN_POLVIO); |
Line 681 udp6_sendup(struct mbuf *m, int off /* o |
|
Line 684 udp6_sendup(struct mbuf *m, int off /* o |
|
return; |
return; |
in6p = sotoin6pcb(so); |
in6p = sotoin6pcb(so); |
|
|
#if defined(IPSEC) || defined(FAST_IPSEC) |
#if defined(KAME_IPSEC) || defined(FAST_IPSEC) |
/* check AH/ESP integrity. */ |
/* check AH/ESP integrity. */ |
if (so != NULL && ipsec6_in_reject_so(m, so)) { |
if (so != NULL && ipsec6_in_reject_so(m, so)) { |
IPSEC6_STATINC(IPSEC_STAT_IN_POLVIO); |
IPSEC6_STATINC(IPSEC_STAT_IN_POLVIO); |
Line 800 udp4_realinput(struct sockaddr_in *src, |
|
Line 803 udp4_realinput(struct sockaddr_in *src, |
|
/* |
/* |
* Locate pcb for datagram. |
* Locate pcb for datagram. |
*/ |
*/ |
inp = in_pcblookup_connect(&udbtable, *src4, *sport, *dst4, *dport); |
inp = in_pcblookup_connect(&udbtable, *src4, *sport, *dst4, |
|
*dport, 0); |
if (inp == 0) { |
if (inp == 0) { |
UDP_STATINC(UDP_STAT_PCBHASHMISS); |
UDP_STATINC(UDP_STAT_PCBHASHMISS); |
inp = in_pcblookup_bind(&udbtable, *dst4, *dport); |
inp = in_pcblookup_bind(&udbtable, *dst4, *dport); |
Line 954 udp6_realinput(int af, struct sockaddr_i |
|
Line 958 udp6_realinput(int af, struct sockaddr_i |
|
* Locate pcb for datagram. |
* Locate pcb for datagram. |
*/ |
*/ |
in6p = in6_pcblookup_connect(&udbtable, &src6, sport, dst6, |
in6p = in6_pcblookup_connect(&udbtable, &src6, sport, dst6, |
dport, 0); |
dport, 0, 0); |
if (in6p == 0) { |
if (in6p == 0) { |
UDP_STATINC(UDP_STAT_PCBHASHMISS); |
UDP_STATINC(UDP_STAT_PCBHASHMISS); |
in6p = in6_pcblookup_bind(&udbtable, dst6, dport, 0); |
in6p = in6_pcblookup_bind(&udbtable, dst6, dport, 0); |
Line 1082 udp_ctloutput(int op, struct socket *so, |
|
Line 1086 udp_ctloutput(int op, struct socket *so, |
|
break; |
break; |
} |
} |
break; |
break; |
|
|
|
case UDP_RFC6056ALGO: |
|
error = sockopt_getint(sopt, &optval); |
|
if (error) |
|
break; |
|
|
|
error = rfc6056_algo_index_select( |
|
(struct inpcb_hdr *)inp, optval); |
|
break; |
|
|
default: |
default: |
error = ENOPROTOOPT; |
error = ENOPROTOOPT; |
Line 1295 udp_usrreq(struct socket *so, int req, s |
|
Line 1308 udp_usrreq(struct socket *so, int req, s |
|
{ |
{ |
struct in_addr laddr; /* XXX */ |
struct in_addr laddr; /* XXX */ |
|
|
|
memset(&laddr, 0, sizeof laddr); |
if (nam) { |
if (nam) { |
laddr = inp->inp_laddr; /* XXX */ |
laddr = inp->inp_laddr; /* XXX */ |
if ((so->so_state & SS_ISCONNECTED) != 0) { |
if ((so->so_state & SS_ISCONNECTED) != 0) { |
Line 1367 sysctl_net_inet_udp_stats(SYSCTLFN_ARGS) |
|
Line 1381 sysctl_net_inet_udp_stats(SYSCTLFN_ARGS) |
|
/* |
/* |
* Sysctl for udp variables. |
* Sysctl for udp variables. |
*/ |
*/ |
SYSCTL_SETUP(sysctl_net_inet_udp_setup, "sysctl net.inet.udp subtree setup") |
static void |
|
sysctl_net_inet_udp_setup(struct sysctllog **clog) |
{ |
{ |
|
const struct sysctlnode *rfc6056_node; |
|
|
sysctl_createv(clog, 0, NULL, NULL, |
sysctl_createv(clog, 0, NULL, NULL, |
CTLFLAG_PERMANENT, |
CTLFLAG_PERMANENT, |
CTLTYPE_NODE, "net", NULL, |
CTLTYPE_NODE, "net", NULL, |
Line 1429 SYSCTL_SETUP(sysctl_net_inet_udp_setup, |
|
Line 1445 SYSCTL_SETUP(sysctl_net_inet_udp_setup, |
|
sysctl_net_inet_udp_stats, 0, NULL, 0, |
sysctl_net_inet_udp_stats, 0, NULL, 0, |
CTL_NET, PF_INET, IPPROTO_UDP, UDPCTL_STATS, |
CTL_NET, PF_INET, IPPROTO_UDP, UDPCTL_STATS, |
CTL_EOL); |
CTL_EOL); |
|
/* RFC6056 subtree */ |
|
sysctl_createv(clog, 0, NULL, &rfc6056_node, |
|
CTLFLAG_PERMANENT, |
|
CTLTYPE_NODE, "rfc6056", |
|
SYSCTL_DESCR("RFC 6056"), |
|
NULL, 0, NULL, 0, |
|
CTL_NET, PF_INET, IPPROTO_UDP, CTL_CREATE, CTL_EOL); |
|
sysctl_createv(clog, 0, &rfc6056_node, NULL, |
|
CTLFLAG_PERMANENT, |
|
CTLTYPE_STRING, "available", |
|
SYSCTL_DESCR("RFC 6056 available algorithms"), |
|
sysctl_rfc6056_available, 0, NULL, RFC6056_MAXLEN, |
|
CTL_CREATE, CTL_EOL); |
|
sysctl_createv(clog, 0, &rfc6056_node, NULL, |
|
CTLFLAG_PERMANENT|CTLFLAG_READWRITE, |
|
CTLTYPE_STRING, "selected", |
|
SYSCTL_DESCR("RFC 6056 selected algorithm"), |
|
sysctl_rfc6056_selected, 0, NULL, RFC6056_MAXLEN, |
|
CTL_CREATE, CTL_EOL); |
} |
} |
#endif |
#endif |
|
|