/*
- * Copyright (c) 2000 Apple Computer, Inc. All rights reserved.
+ * Copyright (c) 2000-2012 Apple Inc. All rights reserved.
+ *
+ * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
*
- * @APPLE_LICENSE_HEADER_START@
- *
- * Copyright (c) 1999-2003 Apple Computer, Inc. All Rights Reserved.
- *
* 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. Please obtain a copy of the License at
- * http://www.opensource.apple.com/apsl/ and read it before using this
- * file.
- *
+ * 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.
+ *
+ * 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,
* 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) 1998, 1999 Apple Computer, Inc. All Rights Reserved */
/* Copyright (c) 1995 NeXT Computer, Inc. All Rights Reserved */
#ifndef _SYS_DOMAIN_H_
#define _SYS_DOMAIN_H_
+#ifdef PRIVATE
#include <sys/appleapiopts.h>
-
+#include <sys/cdefs.h>
+#ifdef KERNEL_PRIVATE
+#include <kern/locks.h>
/*
* Structure per communications domain.
*/
/*
* Forward structure declarations for function prototypes [sic].
*/
-#ifdef __APPLE_API_UNSTABLE
struct mbuf;
-struct domain {
+#pragma pack(4)
+
+#ifdef XNU_KERNEL_PRIVATE
+/*
+ * Legacy domain.
+ *
+ * NOTE: Do not modify this structure, as there are modules outside of xnu
+ * which rely on the size and layout for binary compatibility. This structure
+ * is simply used by the exported net_{add,del}_domain_old, pffinddomain_old
+ * routines. Internally, domains are stored in the private variant of domain
+ * defined down below.
+ */
+struct domain_old {
+#else
+struct domain {
+#endif /* !XNU_KERNEL_PRIVATE */
int dom_family; /* AF_xxx */
- char *dom_name;
- void (*dom_init) /* initialize domain data structures */
- __P((void));
+ const char *dom_name;
+ void (*dom_init)(void); /* initialize domain data structures */
int (*dom_externalize) /* externalize access rights */
- __P((struct mbuf *));
+ (struct mbuf *);
void (*dom_dispose) /* dispose of internalized rights */
- __P((struct mbuf *));
+ (struct mbuf *);
+#ifdef XNU_KERNEL_PRIVATE
+ struct protosw_old *dom_protosw; /* Chain of protosw's for AF */
+ struct domain_old *dom_next;
+#else
struct protosw *dom_protosw; /* Chain of protosw's for AF */
struct domain *dom_next;
+#endif /* !XNU_KERNEL_PRIVATE */
int (*dom_rtattach) /* initialize routing table */
- __P((void **, int));
+ (void **, int);
int dom_rtoffset; /* an arg to rtattach, in bits */
int dom_maxrtkey; /* for routing layer */
- int dom_protohdrlen; /* Let the protocol tell us */
+ int dom_protohdrlen; /* len of protocol header */
int dom_refs; /* # socreates outstanding */
- u_long reserved[4];
+ lck_mtx_t *dom_mtx; /* domain global mutex */
+ uint32_t dom_flags;
+ uint32_t reserved[2];
};
-#ifdef KERNEL
-extern struct domain *domains;
-extern struct domain localdomain;
-extern void net_add_domain(struct domain *dp);
-extern int net_del_domain(struct domain *);
+#pragma pack()
-#define DOMAIN_SET(domain_set)
+#ifdef XNU_KERNEL_PRIVATE
+/*
+ * Internal, private and extendable representation of domain.
+ */
+struct domain {
+ int dom_family; /* AF_xxx */
+ uint32_t dom_flags; /* domain flags (see below ) */
+ uint32_t dom_refs; /* # socreates outstanding */
+ lck_mtx_t *dom_mtx; /* domain global mutex */
+ decl_lck_mtx_data(, dom_mtx_s);
+ TAILQ_ENTRY(domain) dom_entry; /* next domain in list */
+ TAILQ_HEAD(, protosw) dom_protosw; /* protosw chain */
+ void (*dom_init) /* initialize domain data structures */
+ (struct domain *);
+ int (*dom_externalize) /* externalize access rights */
+ (struct mbuf *);
+ void (*dom_dispose) /* dispose of internalized rights */
+ (struct mbuf *);
+ int (*dom_rtattach) /* initialize routing table */
+ (void **, int);
+ int dom_rtoffset; /* an arg to rtattach, in bits */
+ int dom_maxrtkey; /* for routing layer */
+ int dom_protohdrlen; /* len of protocol header */
+ const char *dom_name;
+ struct domain_old *dom_old; /* domain pointer per net_add_domain */
+};
+
+extern TAILQ_HEAD(domains_head, domain) domains;
+extern struct domain *localdomain;
+#endif /* XNU_KERNEL_PRIVATE */
/*
-#define DOMAIN_SET(name) \
- DATA_SET(domain_set, name ## domain)
-*/
+ * Values for dom_flags
+ */
+#define DOM_REENTRANT 0x1
+#ifdef BSD_KERNEL_PRIVATE
+#define DOM_INITIALIZED 0x2 /* domain has been initialized */
+#define DOM_ATTACHED 0x4 /* domain is in the global list */
+#define DOM_OLD 0x10000000 /* domain added via net_add_domain */
+
+/* pseudo-public domain flags */
+#define DOMF_USERFLAGS (DOM_REENTRANT)
+#endif /* BSD_KERNEL_PRIVATE */
-#endif
-#endif /* __APPLE_API_UNSTABLE */
+__BEGIN_DECLS
+#ifdef XNU_KERNEL_PRIVATE
+extern void net_add_domain_old(struct domain_old *dp);
+extern int net_del_domain_old(struct domain_old *);
+extern void net_drain_domains(void);
+extern void domain_proto_mtx_lock_assert_held(void);
+extern void domain_proto_mtx_lock_assert_notheld(void);
+struct domain_guard;
+typedef const struct domain_guard *domain_guard_t;
+extern domain_guard_t domain_guard_deploy(void);
+extern void domain_guard_release(domain_guard_t);
+struct domain_unguard;
+typedef const struct domain_unguard *domain_unguard_t;
+extern domain_unguard_t domain_unguard_deploy(void);
+extern void domain_unguard_release(domain_unguard_t);
+extern struct domain_old *pffinddomain_old(int);
+#else
+extern void net_add_domain(struct domain *dp);
+extern int net_del_domain(struct domain *);
+#endif /* XNU_KERNEL_PRIVATE */
+extern struct domain *pffinddomain(int);
+__END_DECLS
+#endif /* KERNEL_PRIVATE */
+#endif /* PRIVATE */
#endif /* _SYS_DOMAIN_H_ */