2016-01-21 01:01:18 +03:00
|
|
|
/* $NetBSD: udp_var.h,v 1.41 2016/01/20 22:01:18 riastradh Exp $ */
|
1994-06-29 10:29:24 +04:00
|
|
|
|
1993-03-21 12:45:37 +03:00
|
|
|
/*
|
1994-05-13 10:02:48 +04:00
|
|
|
* Copyright (c) 1982, 1986, 1989, 1993
|
|
|
|
* The Regents of the University of California. All rights reserved.
|
1993-03-21 12:45:37 +03:00
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
* documentation and/or other materials provided with the distribution.
|
2003-08-07 20:26:28 +04:00
|
|
|
* 3. Neither the name of the University nor the names of its contributors
|
1993-03-21 12:45:37 +03:00
|
|
|
* may be used to endorse or promote products derived from this software
|
|
|
|
* without specific prior written permission.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
|
|
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
|
|
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
|
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
|
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
|
* SUCH DAMAGE.
|
|
|
|
*
|
1994-06-29 10:29:24 +04:00
|
|
|
* @(#)udp_var.h 8.1 (Berkeley) 6/10/93
|
1993-03-21 12:45:37 +03:00
|
|
|
*/
|
|
|
|
|
1998-02-10 04:26:19 +03:00
|
|
|
#ifndef _NETINET_UDP_VAR_H_
|
|
|
|
#define _NETINET_UDP_VAR_H_
|
|
|
|
|
1993-03-21 12:45:37 +03:00
|
|
|
/*
|
|
|
|
* UDP kernel structures and variables.
|
|
|
|
*/
|
|
|
|
struct udpiphdr {
|
|
|
|
struct ipovly ui_i; /* overlaid ip structure */
|
|
|
|
struct udphdr ui_u; /* udp header */
|
2007-12-25 21:33:32 +03:00
|
|
|
} __packed;
|
1993-03-21 12:45:37 +03:00
|
|
|
#define ui_x1 ui_i.ih_x1
|
|
|
|
#define ui_pr ui_i.ih_pr
|
|
|
|
#define ui_len ui_i.ih_len
|
|
|
|
#define ui_src ui_i.ih_src
|
|
|
|
#define ui_dst ui_i.ih_dst
|
|
|
|
#define ui_sport ui_u.uh_sport
|
|
|
|
#define ui_dport ui_u.uh_dport
|
|
|
|
#define ui_ulen ui_u.uh_ulen
|
|
|
|
#define ui_sum ui_u.uh_sum
|
|
|
|
|
2008-04-07 00:17:27 +04:00
|
|
|
/*
|
|
|
|
* UDP statistics.
|
|
|
|
* Each counter is an unsigned 64-bit value.
|
|
|
|
*/
|
|
|
|
#define UDP_STAT_IPACKETS 0 /* total input packets */
|
|
|
|
#define UDP_STAT_HDROPS 1 /* packet shorter than header */
|
|
|
|
#define UDP_STAT_BADSUM 2 /* checksum error */
|
|
|
|
#define UDP_STAT_BADLEN 3 /* data length larger than packet */
|
|
|
|
#define UDP_STAT_NOPORT 4 /* no socket on port */
|
|
|
|
#define UDP_STAT_NOPORTBCAST 5 /* of above, arrived as broadcast */
|
|
|
|
#define UDP_STAT_FULLSOCK 6 /* not delivered, input socket full */
|
|
|
|
#define UDP_STAT_PCBHASHMISS 7 /* input packets missing PCB hash */
|
|
|
|
#define UDP_STAT_OPACKETS 8 /* total output packets */
|
|
|
|
|
|
|
|
#define UDP_NSTATS 9
|
1993-03-21 12:45:37 +03:00
|
|
|
|
1994-05-13 10:02:48 +04:00
|
|
|
/*
|
|
|
|
* Names for UDP sysctl objects
|
|
|
|
*/
|
|
|
|
#define UDPCTL_CHECKSUM 1 /* checksum UDP packets */
|
1997-07-29 02:19:53 +04:00
|
|
|
#define UDPCTL_SENDSPACE 2 /* default send buffer */
|
|
|
|
#define UDPCTL_RECVSPACE 3 /* default recv buffer */
|
2004-12-15 07:25:19 +03:00
|
|
|
#define UDPCTL_LOOPBACKCKSUM 4 /* do UDP checksum on loopback */
|
2005-08-05 13:21:25 +04:00
|
|
|
#define UDPCTL_STATS 5 /* UDP statistics */
|
2011-09-24 21:18:17 +04:00
|
|
|
#define UDPCTL_MAXID 7
|
1994-05-13 10:02:48 +04:00
|
|
|
|
|
|
|
#define UDPCTL_NAMES { \
|
|
|
|
{ 0, 0 }, \
|
|
|
|
{ "checksum", CTLTYPE_INT }, \
|
1997-07-29 02:19:53 +04:00
|
|
|
{ "sendspace", CTLTYPE_INT }, \
|
|
|
|
{ "recvspace", CTLTYPE_INT }, \
|
2004-12-15 07:25:19 +03:00
|
|
|
{ "do_loopback_cksum", CTLTYPE_INT }, \
|
2005-08-05 13:21:25 +04:00
|
|
|
{ "stats", CTLTYPE_STRUCT }, \
|
1994-05-13 10:02:48 +04:00
|
|
|
}
|
1993-03-21 12:45:37 +03:00
|
|
|
|
1995-03-27 00:23:52 +04:00
|
|
|
#ifdef _KERNEL
|
2014-05-18 18:46:15 +04:00
|
|
|
|
2002-05-13 00:33:50 +04:00
|
|
|
extern struct inpcbtable udbtable;
|
2014-05-18 18:46:15 +04:00
|
|
|
extern const struct pr_usrreqs udp_usrreqs;
|
Changes to allow the IPv4 and IPv6 layers to align headers themseves,
as necessary:
* Implement a new mbuf utility routine, m_copyup(), is is like
m_pullup(), except that it always prepends and copies, rather
than only doing so if the desired length is larger than m->m_len.
m_copyup() also allows an offset into the destination mbuf, which
allows space for packet headers, in the forwarding case.
* Add *_HDR_ALIGNED_P() macros for IP, IPv6, ICMP, and IGMP. These
macros expand to 1 if __NO_STRICT_ALIGNMENT is defined, so that
architectures which do not have strict alignment constraints don't
pay for the test or visit the new align-if-needed path.
* Use the new macros to check if a header needs to be aligned, or to
assert that it already is, as appropriate.
Note: This code is still somewhat experimental. However, the new
code path won't be visited if individual device drivers continue
to guarantee that packets are delivered to layer 3 already properly
aligned (which are rules that are already in use).
2002-07-01 02:40:32 +04:00
|
|
|
|
KNF: de-__P, bzero -> memset, bcmp -> memcmp. Remove extraneous
parentheses in return statements.
Cosmetic: don't open-code TAILQ_FOREACH().
Cosmetic: change types of variables to avoid oodles of casts: in
in6_src.c, avoid casts by changing several route_in6 pointers
to struct route pointers. Remove unnecessary casts to caddr_t
elsewhere.
Pave the way for eliminating address family-specific route caches:
soon, struct route will not embed a sockaddr, but it will hold
a reference to an external sockaddr, instead. We will set the
destination sockaddr using rtcache_setdst(). (I created a stub
for it, but it isn't used anywhere, yet.) rtcache_free() will
free the sockaddr. I have extracted from rtcache_free() a helper
subroutine, rtcache_clear(). rtcache_clear() will "forget" a
cached route, but it will not forget the destination by releasing
the sockaddr. I use rtcache_clear() instead of rtcache_free()
in rtcache_update(), because rtcache_update() is not supposed
to forget the destination.
Constify:
1 Introduce const accessor for route->ro_dst, rtcache_getdst().
2 Constify the 'dst' argument to ifnet->if_output(). This
led me to constify a lot of code called by output routines.
3 Constify the sockaddr argument to protosw->pr_ctlinput. This
led me to constify a lot of code called by ctlinput routines.
4 Introduce const macros for converting from a generic sockaddr
to family-specific sockaddrs, e.g., sockaddr_in: satocsin6,
satocsin, et cetera.
2007-02-18 01:34:07 +03:00
|
|
|
void *udp_ctlinput(int, const struct sockaddr *, void *);
|
2008-08-06 19:01:23 +04:00
|
|
|
int udp_ctloutput(int, struct socket *, struct sockopt *);
|
2004-04-21 21:49:46 +04:00
|
|
|
void udp_init(void);
|
2014-01-02 22:29:01 +04:00
|
|
|
void udp_init_common(void);
|
2004-04-21 21:49:46 +04:00
|
|
|
void udp_input(struct mbuf *, ...);
|
2016-01-21 01:01:18 +03:00
|
|
|
int udp_output(struct mbuf *, struct inpcb *);
|
2004-04-21 21:49:46 +04:00
|
|
|
int udp_sysctl(int *, u_int, void *, size_t *, void *, size_t);
|
2004-12-21 08:51:31 +03:00
|
|
|
|
2008-04-12 09:58:22 +04:00
|
|
|
int udp_input_checksum(int af, struct mbuf *, const struct udphdr *, int,
|
2004-12-21 08:51:31 +03:00
|
|
|
int);
|
2008-04-12 09:58:22 +04:00
|
|
|
void udp_statinc(u_int);
|
|
|
|
#endif /* _KERNEL */
|
1998-02-10 04:26:19 +03:00
|
|
|
|
2005-12-11 02:31:41 +03:00
|
|
|
#endif /* !_NETINET_UDP_VAR_H_ */
|