/*
- * Copyright (c) 2000 Apple Computer, Inc. All rights reserved.
+ * Copyright (c) 2008-2016 Apple Inc. All rights reserved.
*
- * @APPLE_LICENSE_HEADER_START@
+ * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
*
- * The contents of this file constitute Original Code as defined in and
- * are subject to the Apple Public Source License Version 1.1 (the
- * "License"). You may not use this file except in compliance with the
- * License. Please obtain a copy of the License at
- * http://www.apple.com/publicsource and read it before using this file.
+ * This file contains Original Code and/or Modifications of Original Code
+ * as defined in and that are subject to the Apple Public Source License
+ * Version 2.0 (the 'License'). You may not use this file except in
+ * compliance with the License. The rights granted to you under the License
+ * may not be used to create, or enable the creation or redistribution of,
+ * unlawful or unlicensed copies of an Apple operating system, or to
+ * circumvent, violate, or enable the circumvention or violation of, any
+ * terms of an Apple operating system software license agreement.
*
- * This Original Code and all software distributed under the License are
- * distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER
+ * Please obtain a copy of the License at
+ * http://www.opensource.apple.com/apsl/ and read it before using this file.
+ *
+ * The Original Code and all software distributed under the License are
+ * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
* EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
* INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT. Please see the
- * License for the specific language governing rights and limitations
- * under the License.
+ * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
+ * Please see the License for the specific language governing rights and
+ * limitations under the License.
*
- * @APPLE_LICENSE_HEADER_END@
+ * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
*/
/*
* Copyright (c) 1982, 1986, 1989, 1993
#ifndef _NETINET_UDP_VAR_H_
#define _NETINET_UDP_VAR_H_
+#include <sys/appleapiopts.h>
#include <sys/sysctl.h>
/*
* UDP kernel structures and variables.
*/
struct udpiphdr {
- struct ipovly ui_i; /* overlaid ip structure */
+ struct ipovly ui_i; /* overlaid ip structure */
struct udphdr ui_u; /* udp header */
};
#define ui_x1 ui_i.ih_x1
#define ui_next ui_i.ih_next
#define ui_prev ui_i.ih_prev
-struct udpcb {
- /* XXX - these should be by reference so we can do options quickly */
- struct ip udb_ip;
- struct udphdr udb_uh;
- struct sockaddr_in udb_conn;
- struct in_hostcache *udb_hc;
- struct mbuf *udb_queue;
-};
-#define inptoudpcb(inp) ((struct udpdb *)(inp)->inp_ppcb)
-
struct udpstat {
- /* input statistics: */
- u_long udps_ipackets; /* total input packets */
- u_long udps_hdrops; /* packet shorter than header */
- u_long udps_badsum; /* checksum error */
- u_long udps_badlen; /* data length larger than packet */
- u_long udps_noport; /* no socket on port */
- u_long udps_noportbcast; /* of above, arrived as broadcast */
- u_long udps_fullsock; /* not delivered, input socket full */
- u_long udpps_pcbcachemiss; /* input packets missing pcb cache */
- u_long udpps_pcbhashmiss; /* input packets not for hashed pcb */
- /* output statistics: */
- u_long udps_opackets; /* total output packets */
- u_long udps_fastout; /* output packets on fast path */
+ /* input statistics: */
+ u_int32_t udps_ipackets; /* total input packets */
+ u_int32_t udps_hdrops; /* packet shorter than header */
+ u_int32_t udps_badsum; /* checksum error */
+ u_int32_t udps_badlen; /* data length larger than packet */
+ u_int32_t udps_noport; /* no socket on port */
+ u_int32_t udps_noportbcast; /* of above, arrived as broadcast */
+ u_int32_t udps_fullsock; /* not delivered, input socket full */
+ u_int32_t udpps_pcbcachemiss; /* input packets missing pcb cache */
+ u_int32_t udpps_pcbhashmiss; /* input packets not for hashed pcb */
+ /* output statistics: */
+ u_int32_t udps_opackets; /* total output packets */
+ u_int32_t udps_fastout; /* output packets on fast path */
+ u_int32_t udps_nosum; /* no checksum */
+ u_int32_t udps_noportmcast; /* of no socket on port, multicast */
+ u_int32_t udps_filtermcast; /* blocked by multicast filter */
+ /* checksum statistics: */
+ u_int32_t udps_rcv_swcsum; /* udp swcksum (inbound), packets */
+ u_int32_t udps_rcv_swcsum_bytes; /* udp swcksum (inbound), bytes */
+ u_int32_t udps_rcv6_swcsum; /* udp6 swcksum (inbound), packets */
+ u_int32_t udps_rcv6_swcsum_bytes; /* udp6 swcksum (inbound), bytes */
+ u_int32_t udps_snd_swcsum; /* udp swcksum (outbound), packets */
+ u_int32_t udps_snd_swcsum_bytes; /* udp swcksum (outbound), bytes */
+ u_int32_t udps_snd6_swcsum; /* udp6 swcksum (outbound), packets */
+ u_int32_t udps_snd6_swcsum_bytes; /* udp6 swcksum (outbound), bytes */
};
/*
#define UDPCTL_PCBLIST 5 /* list of PCBs for UDP sockets */
#define UDPCTL_MAXID 6
-#define UDPCTL_NAMES { \
- { 0, 0 }, \
- { "checksum", CTLTYPE_INT }, \
- { "stats", CTLTYPE_STRUCT }, \
- { "maxdgram", CTLTYPE_INT }, \
- { "recvspace", CTLTYPE_INT }, \
- { "pcblist", CTLTYPE_STRUCT }, \
+#ifdef BSD_KERNEL_PRIVATE
+#include <kern/locks.h>
+#include <sys/bitstring.h>
+
+#define UDPCTL_NAMES { \
+ { 0, 0 }, \
+ { "checksum", CTLTYPE_INT }, \
+ { "stats", CTLTYPE_STRUCT }, \
+ { "maxdgram", CTLTYPE_INT }, \
+ { "recvspace", CTLTYPE_INT }, \
+ { "pcblist", CTLTYPE_STRUCT }, \
}
-#ifdef KERNEL
+#ifdef INET6
+#define udp6stat udpstat
+#define udp6s_opackets udps_opackets
+#endif /* INET6 */
+
SYSCTL_DECL(_net_inet_udp);
-extern struct pr_usrreqs udp_usrreqs;
-extern struct inpcbhead udb;
-extern struct inpcbinfo udbinfo;
-extern u_long udp_sendspace;
-extern u_long udp_recvspace;
+struct udpstat_local {
+ u_int64_t port_unreach;
+ u_int64_t faithprefix; /* deprecated */
+ u_int64_t port0;
+ u_int64_t badlength;
+ u_int64_t badchksum;
+ u_int64_t badmcast;
+ u_int64_t cleanup;
+ u_int64_t badipsec;
+};
+
+extern struct pr_usrreqs udp_usrreqs;
+extern struct inpcbhead udb;
+extern struct inpcbinfo udbinfo;
+extern u_int32_t udp_sendspace;
+extern u_int32_t udp_recvspace;
extern struct udpstat udpstat;
-extern int log_in_vain;
+extern int udp_log_in_vain;
-void udp_ctlinput __P((int, struct sockaddr *, void *));
-void udp_init __P((void));
-void udp_input __P((struct mbuf *, int));
+__BEGIN_DECLS
+extern void udp_ctlinput(int, struct sockaddr *, void *);
+extern int udp_ctloutput(struct socket *, struct sockopt *);
+extern void udp_init(struct protosw *, struct domain *);
+extern void udp_input(struct mbuf *, int);
+extern int udp_connectx_common(struct socket *, int, struct sockaddr *,
+ struct sockaddr *, struct proc *, uint32_t, sae_associd_t,
+ sae_connid_t *, uint32_t, void *, uint32_t, struct uio*, user_ssize_t *);
+extern void udp_notify(struct inpcb *inp, int errno);
+extern int udp_shutdown(struct socket *so);
+extern int udp_lock(struct socket *, int, void *);
+extern int udp_unlock(struct socket *, int, void *);
+extern lck_mtx_t *udp_getlock(struct socket *, int);
+extern void udp_get_ports_used(u_int32_t, int, u_int32_t, bitstr_t *);
+extern uint32_t udp_count_opportunistic(unsigned int, u_int32_t);
+extern uint32_t udp_find_anypcb_byaddr(struct ifaddr *);
-void udp_notify __P((struct inpcb *inp, int errno));
-int udp_shutdown __P((struct socket *so));
-#endif
+extern void udp_fill_keepalive_offload_frames(struct ifnet *,
+ struct ifnet_keepalive_offload_frame *, u_int32_t, size_t, u_int32_t *);
-#endif
+__END_DECLS
+#endif /* BSD_KERNEL_PRIVATE */
+#endif /* _NETINET_UDP_VAR_H_ */