xref: /xnu-11417.140.69/bsd/net/network_agent.h (revision 43a90889846e00bfb5cf1d255cdc0a701a1e05a4)
1*43a90889SApple OSS Distributions /*
2*43a90889SApple OSS Distributions  * Copyright (c) 2014-2017, 2023 Apple Inc. All rights reserved.
3*43a90889SApple OSS Distributions  *
4*43a90889SApple OSS Distributions  * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
5*43a90889SApple OSS Distributions  *
6*43a90889SApple OSS Distributions  * This file contains Original Code and/or Modifications of Original Code
7*43a90889SApple OSS Distributions  * as defined in and that are subject to the Apple Public Source License
8*43a90889SApple OSS Distributions  * Version 2.0 (the 'License'). You may not use this file except in
9*43a90889SApple OSS Distributions  * compliance with the License. The rights granted to you under the License
10*43a90889SApple OSS Distributions  * may not be used to create, or enable the creation or redistribution of,
11*43a90889SApple OSS Distributions  * unlawful or unlicensed copies of an Apple operating system, or to
12*43a90889SApple OSS Distributions  * circumvent, violate, or enable the circumvention or violation of, any
13*43a90889SApple OSS Distributions  * terms of an Apple operating system software license agreement.
14*43a90889SApple OSS Distributions  *
15*43a90889SApple OSS Distributions  * Please obtain a copy of the License at
16*43a90889SApple OSS Distributions  * http://www.opensource.apple.com/apsl/ and read it before using this file.
17*43a90889SApple OSS Distributions  *
18*43a90889SApple OSS Distributions  * The Original Code and all software distributed under the License are
19*43a90889SApple OSS Distributions  * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
20*43a90889SApple OSS Distributions  * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
21*43a90889SApple OSS Distributions  * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
22*43a90889SApple OSS Distributions  * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
23*43a90889SApple OSS Distributions  * Please see the License for the specific language governing rights and
24*43a90889SApple OSS Distributions  * limitations under the License.
25*43a90889SApple OSS Distributions  *
26*43a90889SApple OSS Distributions  * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
27*43a90889SApple OSS Distributions  */
28*43a90889SApple OSS Distributions 
29*43a90889SApple OSS Distributions #ifndef _NETAGENT_H_
30*43a90889SApple OSS Distributions #define _NETAGENT_H_
31*43a90889SApple OSS Distributions #include <net/net_kev.h>
32*43a90889SApple OSS Distributions 
33*43a90889SApple OSS Distributions #ifdef PRIVATE
34*43a90889SApple OSS Distributions 
35*43a90889SApple OSS Distributions #include <netinet/in.h>
36*43a90889SApple OSS Distributions #include <sys/socket.h>
37*43a90889SApple OSS Distributions #include <uuid/uuid.h>
38*43a90889SApple OSS Distributions 
39*43a90889SApple OSS Distributions #ifdef BSD_KERNEL_PRIVATE
40*43a90889SApple OSS Distributions #include <stdbool.h>
41*43a90889SApple OSS Distributions 
42*43a90889SApple OSS Distributions errno_t netagent_init(void);
43*43a90889SApple OSS Distributions #endif
44*43a90889SApple OSS Distributions /*
45*43a90889SApple OSS Distributions  * Name registered by the Network Agent kernel control
46*43a90889SApple OSS Distributions  */
47*43a90889SApple OSS Distributions #define NETAGENT_CONTROL_NAME "com.apple.net.netagent"
48*43a90889SApple OSS Distributions 
49*43a90889SApple OSS Distributions struct netagent_message_header {
50*43a90889SApple OSS Distributions 	u_int8_t                message_type;
51*43a90889SApple OSS Distributions 	u_int8_t                message_flags;
52*43a90889SApple OSS Distributions 	u_int32_t               message_id;
53*43a90889SApple OSS Distributions 	u_int32_t               message_error;
54*43a90889SApple OSS Distributions 	u_int32_t               message_payload_length;
55*43a90889SApple OSS Distributions };
56*43a90889SApple OSS Distributions 
57*43a90889SApple OSS Distributions struct netagent_session_message_header {
58*43a90889SApple OSS Distributions 	u_int8_t                message_type;
59*43a90889SApple OSS Distributions 	u_int8_t                message_flags;
60*43a90889SApple OSS Distributions 	u_int32_t               message_id;
61*43a90889SApple OSS Distributions 	u_int32_t               message_error;
62*43a90889SApple OSS Distributions 	uuid_t                  message_agent_id;
63*43a90889SApple OSS Distributions 	u_int32_t               message_payload_length;
64*43a90889SApple OSS Distributions };
65*43a90889SApple OSS Distributions 
66*43a90889SApple OSS Distributions struct netagent_trigger_message {
67*43a90889SApple OSS Distributions 	u_int32_t               trigger_flags;
68*43a90889SApple OSS Distributions 	pid_t                   trigger_pid;
69*43a90889SApple OSS Distributions 	uuid_t                  trigger_proc_uuid;
70*43a90889SApple OSS Distributions };
71*43a90889SApple OSS Distributions 
72*43a90889SApple OSS Distributions struct netagent_client_message {
73*43a90889SApple OSS Distributions 	uuid_t                  client_id;
74*43a90889SApple OSS Distributions };
75*43a90889SApple OSS Distributions 
76*43a90889SApple OSS Distributions struct netagent_client_error_message {
77*43a90889SApple OSS Distributions 	uuid_t                  client_id;
78*43a90889SApple OSS Distributions 	int32_t                 error_code;
79*43a90889SApple OSS Distributions };
80*43a90889SApple OSS Distributions 
81*43a90889SApple OSS Distributions struct netagent_client_group_message {
82*43a90889SApple OSS Distributions 	uuid_t                  client_id;
83*43a90889SApple OSS Distributions 	u_int8_t                group_members[0];
84*43a90889SApple OSS Distributions };
85*43a90889SApple OSS Distributions 
86*43a90889SApple OSS Distributions struct netagent_assign_nexus_message {
87*43a90889SApple OSS Distributions 	uuid_t                  assign_client_id;
88*43a90889SApple OSS Distributions 	u_int8_t                assign_necp_results[0];
89*43a90889SApple OSS Distributions };
90*43a90889SApple OSS Distributions 
91*43a90889SApple OSS Distributions struct netagent_session_assign_nexus_message {
92*43a90889SApple OSS Distributions 	uuid_t                  agent_id;
93*43a90889SApple OSS Distributions 	uuid_t                  assign_client_id;
94*43a90889SApple OSS Distributions 	u_int8_t                assign_necp_results[0];
95*43a90889SApple OSS Distributions };
96*43a90889SApple OSS Distributions 
97*43a90889SApple OSS Distributions #define NETAGENT_MESSAGE_TYPE_REGISTER                  1       // Pass netagent to set, no return value
98*43a90889SApple OSS Distributions #define NETAGENT_MESSAGE_TYPE_UNREGISTER                2       // No value, no return value
99*43a90889SApple OSS Distributions #define NETAGENT_MESSAGE_TYPE_UPDATE                    3       // Pass netagent to update, no return value
100*43a90889SApple OSS Distributions #define NETAGENT_MESSAGE_TYPE_GET                               4       // No value, return netagent
101*43a90889SApple OSS Distributions #define NETAGENT_MESSAGE_TYPE_TRIGGER                   5       // Kernel initiated, no reply expected
102*43a90889SApple OSS Distributions #define NETAGENT_MESSAGE_TYPE_ASSERT                    6       // Deprecated
103*43a90889SApple OSS Distributions #define NETAGENT_MESSAGE_TYPE_UNASSERT                  7       // Deprecated
104*43a90889SApple OSS Distributions #define NETAGENT_MESSAGE_TYPE_TRIGGER_ASSERT    8       // Kernel initiated, no reply expected
105*43a90889SApple OSS Distributions #define NETAGENT_MESSAGE_TYPE_TRIGGER_UNASSERT  9       // Kernel initiated, no reply expected
106*43a90889SApple OSS Distributions #define NETAGENT_MESSAGE_TYPE_REQUEST_NEXUS             10      // Kernel initiated, struct netagent_client_message
107*43a90889SApple OSS Distributions #define NETAGENT_MESSAGE_TYPE_ASSIGN_NEXUS              11      // Pass struct netagent_assign_nexus_message
108*43a90889SApple OSS Distributions #define NETAGENT_MESSAGE_TYPE_CLOSE_NEXUS               12      // Kernel initiated, struct netagent_client_message
109*43a90889SApple OSS Distributions #define NETAGENT_MESSAGE_TYPE_CLIENT_TRIGGER    13      // Kernel initiated, struct netagent_client_message
110*43a90889SApple OSS Distributions #define NETAGENT_MESSAGE_TYPE_CLIENT_ASSERT             14      // Kernel initiated, struct netagent_client_message
111*43a90889SApple OSS Distributions #define NETAGENT_MESSAGE_TYPE_CLIENT_UNASSERT   15      // Kernel initiated, struct netagent_client_message
112*43a90889SApple OSS Distributions 
113*43a90889SApple OSS Distributions #define NETAGENT_OPTION_TYPE_REGISTER                   NETAGENT_MESSAGE_TYPE_REGISTER          // Pass netagent to set, no return value
114*43a90889SApple OSS Distributions #define NETAGENT_OPTION_TYPE_UNREGISTER                 NETAGENT_MESSAGE_TYPE_UNREGISTER        // Pass agent uuid in session mode, no return value
115*43a90889SApple OSS Distributions #define NETAGENT_OPTION_TYPE_UPDATE                             NETAGENT_MESSAGE_TYPE_UPDATE            // Pass netagent to update, no return value
116*43a90889SApple OSS Distributions #define NETAGENT_OPTION_TYPE_ASSIGN_NEXUS               NETAGENT_MESSAGE_TYPE_ASSIGN_NEXUS      // Pass struct netagent_assign_nexus_message
117*43a90889SApple OSS Distributions #define NETAGENT_OPTION_TYPE_USE_COUNT                  16                                                                      // Pass use count to set, get current use count
118*43a90889SApple OSS Distributions #define NETAGENT_MESSAGE_TYPE_ABORT_NEXUS               17      // Kernel private
119*43a90889SApple OSS Distributions #define NETAGENT_MESSAGE_TYPE_ADD_GROUP_MEMBERS         18      // Kernel initiated, struct netagent_client_group_message
120*43a90889SApple OSS Distributions #define NETAGENT_MESSAGE_TYPE_REMOVE_GROUP_MEMBERS      19      // Kernel initiated, struct netagent_client_group_message
121*43a90889SApple OSS Distributions #define NETAGENT_MESSAGE_TYPE_ASSIGN_GROUP_MEMBERS      20      // Pass struct netagent_assign_nexus_message
122*43a90889SApple OSS Distributions #define NETAGENT_OPTION_TYPE_ADD_TOKEN                 21      // Set new token bytes
123*43a90889SApple OSS Distributions #define NETAGENT_OPTION_TYPE_FLUSH_TOKENS              22      // Flush all tokens
124*43a90889SApple OSS Distributions #define NETAGENT_OPTION_TYPE_TOKEN_COUNT               23      // Get remaining token count (uint32_t)
125*43a90889SApple OSS Distributions #define NETAGENT_OPTION_TYPE_TOKEN_LOW_WATER           24      // Set/get token low water mark (uint32_t)
126*43a90889SApple OSS Distributions #define NETAGENT_MESSAGE_TYPE_TOKENS_NEEDED            25      // Kernel intiated, no content
127*43a90889SApple OSS Distributions #define NETAGENT_MESSAGE_TYPE_CLIENT_ERROR             26      // Kernel intiated, struct netagent_client_error_message
128*43a90889SApple OSS Distributions #define NETAGENT_OPTION_TYPE_RESET_CLIENT_ERROR        27      // Call to reset client error and counts
129*43a90889SApple OSS Distributions #define NETAGENT_OPTION_TYPE_ENABLE_SESSION_MODE       28      // Enables registering multiple agents on a single fd "session". Must be set before registering an agent.
130*43a90889SApple OSS Distributions #define NETAGENT_OPTION_TYPE_UNREGISTER_ALL            29      // Applicable for session mode, unregisters all associated agents.
131*43a90889SApple OSS Distributions 
132*43a90889SApple OSS Distributions #define NETAGENT_MESSAGE_FLAGS_RESPONSE                 0x01    // Used for acks, errors, and query responses
133*43a90889SApple OSS Distributions 
134*43a90889SApple OSS Distributions #define NETAGENT_MESSAGE_ERROR_NONE                     0
135*43a90889SApple OSS Distributions #define NETAGENT_MESSAGE_ERROR_INTERNAL                 1
136*43a90889SApple OSS Distributions #define NETAGENT_MESSAGE_ERROR_UNKNOWN_TYPE             2
137*43a90889SApple OSS Distributions #define NETAGENT_MESSAGE_ERROR_INVALID_DATA             3
138*43a90889SApple OSS Distributions #define NETAGENT_MESSAGE_ERROR_NOT_REGISTERED           4
139*43a90889SApple OSS Distributions #define NETAGENT_MESSAGE_ERROR_ALREADY_REGISTERED       5
140*43a90889SApple OSS Distributions #define NETAGENT_MESSAGE_ERROR_CANNOT_UPDATE            6
141*43a90889SApple OSS Distributions #define NETAGENT_MESSAGE_ERROR_CANNOT_ASSIGN            7
142*43a90889SApple OSS Distributions 
143*43a90889SApple OSS Distributions #define NETAGENT_DOMAINSIZE             32
144*43a90889SApple OSS Distributions #define NETAGENT_TYPESIZE               32
145*43a90889SApple OSS Distributions #define NETAGENT_DESCSIZE               128
146*43a90889SApple OSS Distributions 
147*43a90889SApple OSS Distributions #define NETAGENT_MAX_DATA_SIZE                  4096
148*43a90889SApple OSS Distributions 
149*43a90889SApple OSS Distributions #define NETAGENT_MAX_TOKEN_COUNT                256
150*43a90889SApple OSS Distributions 
151*43a90889SApple OSS Distributions 
152*43a90889SApple OSS Distributions #define NETAGENT_FLAG_REGISTERED                0x0001 // Agent is registered
153*43a90889SApple OSS Distributions #define NETAGENT_FLAG_ACTIVE                    0x0002 // Agent is active
154*43a90889SApple OSS Distributions #define NETAGENT_FLAG_KERNEL_ACTIVATED          0x0004 // Agent can be activated by kernel activity
155*43a90889SApple OSS Distributions #define NETAGENT_FLAG_USER_ACTIVATED            0x0008 // Agent can be activated by system call (netagent_trigger)
156*43a90889SApple OSS Distributions #define NETAGENT_FLAG_VOLUNTARY                 0x0010 // Use of agent is optional
157*43a90889SApple OSS Distributions #define NETAGENT_FLAG_SPECIFIC_USE_ONLY         0x0020 // Agent should only be used and activated when specifically required
158*43a90889SApple OSS Distributions #define NETAGENT_FLAG_NETWORK_PROVIDER          0x0040 // Agent provides network access
159*43a90889SApple OSS Distributions #define NETAGENT_FLAG_NEXUS_PROVIDER            0x0080 // Agent provides a skywalk nexus
160*43a90889SApple OSS Distributions #define NETAGENT_FLAG_SUPPORTS_BROWSE           0x0100 // Assertions will cause agent to fill in browse endpoints
161*43a90889SApple OSS Distributions #define NETAGENT_FLAG_REQUIRES_ASSERT           0x0200 // Assertions are expected to be taken against this agent
162*43a90889SApple OSS Distributions #define NETAGENT_FLAG_NEXUS_LISTENER            0x0400 // Nexus supports listeners
163*43a90889SApple OSS Distributions #define NETAGENT_FLAG_UPDATE_IMMEDIATELY        0x0800 // Updates the clients without waiting for a leeway
164*43a90889SApple OSS Distributions #define NETAGENT_FLAG_CUSTOM_ETHER_NEXUS        0x2000 // Agent provides a custom ethertype nexus
165*43a90889SApple OSS Distributions #define NETAGENT_FLAG_CUSTOM_IP_NEXUS           0x4000 // Agent provides a custom IP nexus
166*43a90889SApple OSS Distributions #define NETAGENT_FLAG_INTERPOSE_NEXUS           0x8000 // Agent provides an interpose nexus
167*43a90889SApple OSS Distributions #define NETAGENT_FLAG_SUPPORTS_RESOLVE          0x10000 // Assertions will cause agent to fill in resolved endpoints
168*43a90889SApple OSS Distributions #define NETAGENT_FLAG_SUPPORTS_GROUPS           0x20000 // Group actions can be performed
169*43a90889SApple OSS Distributions 
170*43a90889SApple OSS Distributions #define NETAGENT_NEXUS_MAX_REQUEST_TYPES                        16
171*43a90889SApple OSS Distributions #define NETAGENT_NEXUS_MAX_RESOLUTION_TYPE_PAIRS        15
172*43a90889SApple OSS Distributions 
173*43a90889SApple OSS Distributions #define NETAGENT_NEXUS_FRAME_TYPE_UNKNOWN               0
174*43a90889SApple OSS Distributions #define NETAGENT_NEXUS_FRAME_TYPE_LINK                  1
175*43a90889SApple OSS Distributions #define NETAGENT_NEXUS_FRAME_TYPE_INTERNET              2
176*43a90889SApple OSS Distributions #define NETAGENT_NEXUS_FRAME_TYPE_TRANSPORT             3
177*43a90889SApple OSS Distributions #define NETAGENT_NEXUS_FRAME_TYPE_APPLICATION   4
178*43a90889SApple OSS Distributions 
179*43a90889SApple OSS Distributions #define NETAGENT_NEXUS_ENDPOINT_TYPE_ADDRESS    1
180*43a90889SApple OSS Distributions #define NETAGENT_NEXUS_ENDPOINT_TYPE_HOST               2
181*43a90889SApple OSS Distributions #define NETAGENT_NEXUS_ENDPOINT_TYPE_BONJOUR    3
182*43a90889SApple OSS Distributions #define NETAGENT_NEXUS_ENDPOINT_TYPE_SRV        5
183*43a90889SApple OSS Distributions 
184*43a90889SApple OSS Distributions #define NETAGENT_NEXUS_FLAG_SUPPORTS_USER_PACKET_POOL   0x1
185*43a90889SApple OSS Distributions #define NETAGENT_NEXUS_FLAG_ASSERT_UNSUPPORTED                  0x2 // No calls to assert the agent are required
186*43a90889SApple OSS Distributions #define NETAGENT_NEXUS_FLAG_SHOULD_USE_EVENT_RING       0x4 // indicates that nexus agent should use event rings
187*43a90889SApple OSS Distributions 
188*43a90889SApple OSS Distributions struct netagent_nexus {
189*43a90889SApple OSS Distributions 	u_int32_t       frame_type;
190*43a90889SApple OSS Distributions 	u_int32_t       endpoint_assignment_type;
191*43a90889SApple OSS Distributions 	u_int32_t       endpoint_request_types[NETAGENT_NEXUS_MAX_REQUEST_TYPES];
192*43a90889SApple OSS Distributions 	u_int32_t       endpoint_resolution_type_pairs[NETAGENT_NEXUS_MAX_RESOLUTION_TYPE_PAIRS * 2];
193*43a90889SApple OSS Distributions 	u_int32_t       nexus_max_buf_size;
194*43a90889SApple OSS Distributions 	u_int32_t       reserved;
195*43a90889SApple OSS Distributions 	u_int32_t       nexus_flags;
196*43a90889SApple OSS Distributions };
197*43a90889SApple OSS Distributions 
198*43a90889SApple OSS Distributions #define NETAGENT_NEXUS_HAS_MAX_BUF_SIZE    1 // struct netagent_nexus includes nexus_max_buf_size
199*43a90889SApple OSS Distributions 
200*43a90889SApple OSS Distributions #define NETAGENT_TRIGGER_FLAG_USER              0x0001  // Userspace triggered agent
201*43a90889SApple OSS Distributions #define NETAGENT_TRIGGER_FLAG_KERNEL            0x0002  // Kernel triggered agent
202*43a90889SApple OSS Distributions 
203*43a90889SApple OSS Distributions struct kev_netagent_data {
204*43a90889SApple OSS Distributions 	uuid_t          netagent_uuid;
205*43a90889SApple OSS Distributions };
206*43a90889SApple OSS Distributions 
207*43a90889SApple OSS Distributions // To be used with kernel control socket
208*43a90889SApple OSS Distributions struct netagent {
209*43a90889SApple OSS Distributions 	uuid_t          netagent_uuid;
210*43a90889SApple OSS Distributions 	char            netagent_domain[NETAGENT_DOMAINSIZE];
211*43a90889SApple OSS Distributions 	char            netagent_type[NETAGENT_TYPESIZE];
212*43a90889SApple OSS Distributions 	char            netagent_desc[NETAGENT_DESCSIZE];
213*43a90889SApple OSS Distributions 	u_int32_t       netagent_flags;
214*43a90889SApple OSS Distributions 	u_int32_t       netagent_data_size;
215*43a90889SApple OSS Distributions 	u_int8_t        netagent_data[0];
216*43a90889SApple OSS Distributions };
217*43a90889SApple OSS Distributions 
218*43a90889SApple OSS Distributions // To be used with SIOCGAGENTDATA
219*43a90889SApple OSS Distributions struct netagent_req {
220*43a90889SApple OSS Distributions 	uuid_t          netagent_uuid;
221*43a90889SApple OSS Distributions 	char            netagent_domain[NETAGENT_DOMAINSIZE];
222*43a90889SApple OSS Distributions 	char            netagent_type[NETAGENT_TYPESIZE];
223*43a90889SApple OSS Distributions 	char            netagent_desc[NETAGENT_DESCSIZE];
224*43a90889SApple OSS Distributions 	u_int32_t       netagent_flags;
225*43a90889SApple OSS Distributions 	u_int32_t       netagent_data_size;
226*43a90889SApple OSS Distributions 	u_int8_t        *netagent_data;
227*43a90889SApple OSS Distributions };
228*43a90889SApple OSS Distributions 
229*43a90889SApple OSS Distributions // To be used with SIOCGAGENTLIST
230*43a90889SApple OSS Distributions struct netagentlist_req {
231*43a90889SApple OSS Distributions 	u_int32_t       data_size;
232*43a90889SApple OSS Distributions 	u_int8_t        *data;
233*43a90889SApple OSS Distributions };
234*43a90889SApple OSS Distributions #ifdef BSD_KERNEL_PRIVATE
235*43a90889SApple OSS Distributions int netagent_ioctl(u_long cmd, caddr_t __sized_by(IOCPARM_LEN(cmd)) data);
236*43a90889SApple OSS Distributions 
237*43a90889SApple OSS Distributions struct netagent_req32 {
238*43a90889SApple OSS Distributions 	uuid_t          netagent_uuid;
239*43a90889SApple OSS Distributions 	char            netagent_domain[NETAGENT_DOMAINSIZE];
240*43a90889SApple OSS Distributions 	char            netagent_type[NETAGENT_TYPESIZE];
241*43a90889SApple OSS Distributions 	char            netagent_desc[NETAGENT_DESCSIZE];
242*43a90889SApple OSS Distributions 	u_int32_t       netagent_flags;
243*43a90889SApple OSS Distributions 	u_int32_t       netagent_data_size;
244*43a90889SApple OSS Distributions 	user32_addr_t   netagent_data;
245*43a90889SApple OSS Distributions };
246*43a90889SApple OSS Distributions struct netagent_req64 {
247*43a90889SApple OSS Distributions 	uuid_t          netagent_uuid;
248*43a90889SApple OSS Distributions 	char            netagent_domain[NETAGENT_DOMAINSIZE];
249*43a90889SApple OSS Distributions 	char            netagent_type[NETAGENT_TYPESIZE];
250*43a90889SApple OSS Distributions 	char            netagent_desc[NETAGENT_DESCSIZE];
251*43a90889SApple OSS Distributions 	u_int32_t       netagent_flags;
252*43a90889SApple OSS Distributions 	u_int32_t       netagent_data_size;
253*43a90889SApple OSS Distributions 	user64_addr_t   netagent_data __attribute__((aligned(8)));
254*43a90889SApple OSS Distributions };
255*43a90889SApple OSS Distributions struct netagentlist_req32 {
256*43a90889SApple OSS Distributions 	u_int32_t       data_size;
257*43a90889SApple OSS Distributions 	user32_addr_t   data;
258*43a90889SApple OSS Distributions };
259*43a90889SApple OSS Distributions struct netagentlist_req64 {
260*43a90889SApple OSS Distributions 	u_int32_t       data_size;
261*43a90889SApple OSS Distributions 	user64_addr_t   data __attribute__((aligned(8)));
262*43a90889SApple OSS Distributions };
263*43a90889SApple OSS Distributions 
264*43a90889SApple OSS Distributions struct necp_client_agent_parameters;
265*43a90889SApple OSS Distributions 
266*43a90889SApple OSS Distributions // Kernel accessors
267*43a90889SApple OSS Distributions extern void netagent_post_updated_interfaces(uuid_t uuid); // To be called from interface ioctls
268*43a90889SApple OSS Distributions 
269*43a90889SApple OSS Distributions extern u_int32_t netagent_get_flags(uuid_t uuid);
270*43a90889SApple OSS Distributions 
271*43a90889SApple OSS Distributions extern errno_t netagent_set_flags(uuid_t uuid, u_int32_t flags);
272*43a90889SApple OSS Distributions 
273*43a90889SApple OSS Distributions extern u_int32_t netagent_get_generation(uuid_t uuid);
274*43a90889SApple OSS Distributions 
275*43a90889SApple OSS Distributions extern bool netagent_get_agent_domain_and_type(uuid_t uuid, char *domain __sized_by(NETAGENT_DOMAINSIZE), char *type __sized_by(NETAGENT_TYPESIZE));
276*43a90889SApple OSS Distributions 
277*43a90889SApple OSS Distributions extern int netagent_kernel_trigger(uuid_t uuid);
278*43a90889SApple OSS Distributions 
279*43a90889SApple OSS Distributions extern int netagent_client_message(uuid_t agent_uuid, uuid_t necp_client_uuid, pid_t pid, void *handle, u_int8_t message_type);
280*43a90889SApple OSS Distributions 
281*43a90889SApple OSS Distributions extern int netagent_client_message_with_params(uuid_t agent_uuid,
282*43a90889SApple OSS Distributions     uuid_t necp_client_uuid,
283*43a90889SApple OSS Distributions     pid_t pid,
284*43a90889SApple OSS Distributions     void *handle,
285*43a90889SApple OSS Distributions     u_int8_t message_type,
286*43a90889SApple OSS Distributions     struct necp_client_agent_parameters *parameters,
287*43a90889SApple OSS Distributions     void * __sized_by(*assigned_results_length) * assigned_results,
288*43a90889SApple OSS Distributions     size_t *assigned_results_length);
289*43a90889SApple OSS Distributions 
290*43a90889SApple OSS Distributions extern int netagent_copyout(uuid_t uuid, user_addr_t user_addr, u_int32_t user_size);
291*43a90889SApple OSS Distributions 
292*43a90889SApple OSS Distributions extern int netagent_acquire_token(uuid_t uuid, user_addr_t user_addr, u_int32_t user_size, int *retval);
293*43a90889SApple OSS Distributions 
294*43a90889SApple OSS Distributions 
295*43a90889SApple OSS Distributions // Kernel agent management
296*43a90889SApple OSS Distributions 
297*43a90889SApple OSS Distributions typedef void * netagent_session_t;
298*43a90889SApple OSS Distributions 
299*43a90889SApple OSS Distributions struct netagent_nexus_agent {
300*43a90889SApple OSS Distributions 	struct netagent                         agent;
301*43a90889SApple OSS Distributions 	struct netagent_nexus           nexus_data;
302*43a90889SApple OSS Distributions };
303*43a90889SApple OSS Distributions 
304*43a90889SApple OSS Distributions #define NETAGENT_EVENT_TRIGGER                                  NETAGENT_MESSAGE_TYPE_CLIENT_TRIGGER
305*43a90889SApple OSS Distributions #define NETAGENT_EVENT_ASSERT                                   NETAGENT_MESSAGE_TYPE_CLIENT_ASSERT
306*43a90889SApple OSS Distributions #define NETAGENT_EVENT_UNASSERT                                 NETAGENT_MESSAGE_TYPE_CLIENT_UNASSERT
307*43a90889SApple OSS Distributions #define NETAGENT_EVENT_NEXUS_FLOW_INSERT                        NETAGENT_MESSAGE_TYPE_REQUEST_NEXUS
308*43a90889SApple OSS Distributions #define NETAGENT_EVENT_NEXUS_FLOW_REMOVE                        NETAGENT_MESSAGE_TYPE_CLOSE_NEXUS
309*43a90889SApple OSS Distributions #define NETAGENT_EVENT_NEXUS_FLOW_ABORT                         NETAGENT_MESSAGE_TYPE_ABORT_NEXUS
310*43a90889SApple OSS Distributions 
311*43a90889SApple OSS Distributions typedef errno_t (*netagent_event_f)(u_int8_t event, uuid_t necp_client_uuid, pid_t pid, void *necp_handle, void *context, struct necp_client_agent_parameters *parameters, void * __sized_by (*assigned_results_length) *assigned_results, size_t *assigned_results_length);
312*43a90889SApple OSS Distributions 
313*43a90889SApple OSS Distributions extern netagent_session_t netagent_create(netagent_event_f event_handler, void *handle);
314*43a90889SApple OSS Distributions 
315*43a90889SApple OSS Distributions extern void netagent_destroy(netagent_session_t session);
316*43a90889SApple OSS Distributions 
317*43a90889SApple OSS Distributions extern errno_t netagent_register(netagent_session_t session, struct netagent *agent);
318*43a90889SApple OSS Distributions 
319*43a90889SApple OSS Distributions extern errno_t netagent_update(netagent_session_t session, struct netagent *agent);
320*43a90889SApple OSS Distributions 
321*43a90889SApple OSS Distributions extern errno_t netagent_unregister(netagent_session_t session);
322*43a90889SApple OSS Distributions 
323*43a90889SApple OSS Distributions extern errno_t netagent_assign_nexus(netagent_session_t _session,
324*43a90889SApple OSS Distributions     uuid_t necp_client_uuid,
325*43a90889SApple OSS Distributions     void *assign_message __sized_by(assigned_results_length),
326*43a90889SApple OSS Distributions     size_t assigned_results_length);                                                                      // Length of assigned_results_length
327*43a90889SApple OSS Distributions 
328*43a90889SApple OSS Distributions extern errno_t netagent_update_flow_protoctl_event(netagent_session_t _session,
329*43a90889SApple OSS Distributions     uuid_t client_id,
330*43a90889SApple OSS Distributions     uint32_t protoctl_event_code,
331*43a90889SApple OSS Distributions     uint32_t protoctl_event_val,
332*43a90889SApple OSS Distributions     uint32_t protoctl_event_tcp_seq_number);
333*43a90889SApple OSS Distributions 
334*43a90889SApple OSS Distributions extern int netagent_use(uuid_t agent_uuid, uint64_t *out_use_count);
335*43a90889SApple OSS Distributions 
336*43a90889SApple OSS Distributions #endif /* BSD_KERNEL_PRIVATE */
337*43a90889SApple OSS Distributions 
338*43a90889SApple OSS Distributions #ifndef KERNEL
339*43a90889SApple OSS Distributions extern int netagent_trigger(uuid_t agent_uuid, size_t agent_uuidlen);
340*43a90889SApple OSS Distributions #endif /* !KERNEL */
341*43a90889SApple OSS Distributions 
342*43a90889SApple OSS Distributions #endif /* PRIVATE */
343*43a90889SApple OSS Distributions 
344*43a90889SApple OSS Distributions #endif /* _NETAGENT_H_ */
345