version 1.173.2.2, 2009/04/28 07:37:23 |
version 1.183.2.2, 2012/10/30 17:22:47 |
Line 118 __KERNEL_RCSID(0, "$NetBSD$"); |
|
Line 118 __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 128 __KERNEL_RCSID(0, "$NetBSD$"); |
|
#endif |
#endif |
#endif /* FAST_IPSEC */ |
#endif /* FAST_IPSEC */ |
|
|
#ifdef IPSEC |
|
#include <netinet6/ipsec.h> |
|
#include <netinet6/ipsec_private.h> |
|
#include <netinet6/esp.h> |
|
#include <netkey/key.h> |
|
#endif /* IPSEC */ |
|
|
|
#ifdef COMPAT_50 |
#ifdef COMPAT_50 |
#include <compat/sys/socket.h> |
#include <compat/sys/socket.h> |
#endif |
#endif |
Line 232 EVCNT_ATTACH_STATIC(udp6_swcsum); |
|
Line 223 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 626 udp4_sendup(struct mbuf *m, int off /* o |
|
return; |
return; |
} |
} |
|
|
#if defined(IPSEC) || defined(FAST_IPSEC) |
#if 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 676 udp6_sendup(struct mbuf *m, int off /* o |
|
return; |
return; |
in6p = sotoin6pcb(so); |
in6p = sotoin6pcb(so); |
|
|
#if defined(IPSEC) || defined(FAST_IPSEC) |
#if 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 795 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 836 udp4_realinput(struct sockaddr_in *src, |
|
Line 832 udp4_realinput(struct sockaddr_in *src, |
|
} |
} |
#endif |
#endif |
|
|
|
/* |
|
* Check the minimum TTL for socket. |
|
*/ |
|
if (mtod(m, struct ip *)->ip_ttl < inp->inp_ip_minttl) |
|
goto bad; |
|
|
udp4_sendup(m, off, (struct sockaddr *)src, inp->inp_socket); |
udp4_sendup(m, off, (struct sockaddr *)src, inp->inp_socket); |
rcvcnt++; |
rcvcnt++; |
} |
} |
Line 948 udp6_realinput(int af, struct sockaddr_i |
|
Line 950 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 1076 udp_ctloutput(int op, struct socket *so, |
|
Line 1078 udp_ctloutput(int op, struct socket *so, |
|
break; |
break; |
} |
} |
break; |
break; |
|
|
default: |
default: |
error = ENOPROTOOPT; |
error = ENOPROTOOPT; |
break; |
break; |
Line 1289 udp_usrreq(struct socket *so, int req, s |
|
Line 1291 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 1361 sysctl_net_inet_udp_stats(SYSCTLFN_ARGS) |
|
Line 1364 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) |
{ |
{ |
|
|
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 1570 udp4_espinudp(struct mbuf **mp, int off, |
|
Line 1573 udp4_espinudp(struct mbuf **mp, int off, |
|
esp4_input(n, iphdrlen); |
esp4_input(n, iphdrlen); |
#endif |
#endif |
|
|
/* We handled it, it shoudln't be handled by UDP */ |
/* We handled it, it shouldn't be handled by UDP */ |
return 1; |
return 1; |
} |
} |
#endif |
#endif |