]>
Commit | Line | Data |
---|---|---|
1 | /* | |
2 | * Copyright (c) 2018 Apple Inc. All rights reserved. | |
3 | * | |
4 | * @APPLE_OSREFERENCE_LICENSE_HEADER_START@ | |
5 | * | |
6 | * This file contains Original Code and/or Modifications of Original Code | |
7 | * as defined in and that are subject to the Apple Public Source License | |
8 | * Version 2.0 (the 'License'). You may not use this file except in | |
9 | * compliance with the License. The rights granted to you under the License | |
10 | * may not be used to create, or enable the creation or redistribution of, | |
11 | * unlawful or unlicensed copies of an Apple operating system, or to | |
12 | * circumvent, violate, or enable the circumvention or violation of, any | |
13 | * terms of an Apple operating system software license agreement. | |
14 | * | |
15 | * Please obtain a copy of the License at | |
16 | * http://www.opensource.apple.com/apsl/ and read it before using this file. | |
17 | * | |
18 | * The Original Code and all software distributed under the License are | |
19 | * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER | |
20 | * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, | |
21 | * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, | |
22 | * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. | |
23 | * Please see the License for the specific language governing rights and | |
24 | * limitations under the License. | |
25 | * | |
26 | * @APPLE_OSREFERENCE_LICENSE_HEADER_END@ | |
27 | */ | |
28 | ||
29 | #include <errno.h> | |
30 | #include <mach/host_special_ports.h> | |
31 | #include <mach/task_special_ports.h> | |
32 | #include <mach/thread_special_ports.h> | |
33 | #include <mach/port_descriptions.h> | |
34 | #include <stdlib.h> | |
35 | #include <strings.h> | |
36 | ||
37 | const char * | |
38 | mach_host_special_port_description(int port) | |
39 | { | |
40 | int port_index = (int)port; | |
41 | ||
42 | if (port_index < 0 || port_index > HOST_MAX_SPECIAL_PORT) { | |
43 | return NULL; | |
44 | } | |
45 | ||
46 | static const char *hsp_descs[] = { | |
47 | [HOST_PORT] = "host (restricted)", | |
48 | [HOST_PRIV_PORT] = "host private (restricted)", | |
49 | [HOST_IO_MASTER_PORT] = "I/O master (restricted)", | |
50 | ||
51 | [HOST_DYNAMIC_PAGER_PORT] = "dynamic pager", | |
52 | [HOST_AUDIT_CONTROL_PORT] = "audit control", | |
53 | [HOST_USER_NOTIFICATION_PORT] = "user notification", | |
54 | [HOST_AUTOMOUNTD_PORT] = "automounter", | |
55 | [HOST_LOCKD_PORT] = "lockd", | |
56 | [HOST_KTRACE_BACKGROUND_PORT] = "ktrace background notification", | |
57 | [HOST_SEATBELT_PORT] = "seatbelt", | |
58 | [HOST_KEXTD_PORT] = "kextd", | |
59 | [HOST_LAUNCHCTL_PORT] = "launchctl", | |
60 | [HOST_UNFREED_PORT] = "fairplay", | |
61 | [HOST_AMFID_PORT] = "amfi", | |
62 | [HOST_GSSD_PORT] = "gssd", | |
63 | [HOST_TELEMETRY_PORT] = "telemetry", | |
64 | [HOST_ATM_NOTIFICATION_PORT] = "atm notification", | |
65 | [HOST_COALITION_PORT] = "coalition notification", | |
66 | [HOST_SYSDIAGNOSE_PORT] = "sysdiagnose notification", | |
67 | [HOST_XPC_EXCEPTION_PORT] = "XPC exception", | |
68 | [HOST_CONTAINERD_PORT] = "container manager", | |
69 | [HOST_NODE_PORT] = "node", | |
70 | [HOST_RESOURCE_NOTIFY_PORT] = "resource notify", | |
71 | [HOST_CLOSURED_PORT] = "closured", | |
72 | [HOST_SYSPOLICYD_PORT] = "syspolicyd", | |
73 | [HOST_FILECOORDINATIOND_PORT] = "filecoordinationd", | |
74 | [HOST_FAIRPLAYD_PORT] = "fairplayd", | |
75 | [HOST_IOCOMPRESSIONSTATS_PORT] = "I/O compression stats", | |
76 | }; | |
77 | _Static_assert(HOST_IOCOMPRESSIONSTATS_PORT == HOST_MAX_SPECIAL_PORT, | |
78 | "all host special ports must have descriptions"); | |
79 | ||
80 | return hsp_descs[port_index]; | |
81 | } | |
82 | ||
83 | const char * | |
84 | mach_task_special_port_description(int port) | |
85 | { | |
86 | int port_index = (int)port; | |
87 | ||
88 | if (port_index < 0 || port_index > TASK_MAX_SPECIAL_PORT) { | |
89 | return NULL; | |
90 | } | |
91 | ||
92 | static const char *tsp_descs[] = { | |
93 | [TASK_KERNEL_PORT] = "kernel", | |
94 | [TASK_HOST_PORT] = "host", | |
95 | [TASK_NAME_PORT] = "name", | |
96 | [TASK_BOOTSTRAP_PORT] = "bootstrap", | |
97 | [TASK_INSPECT_PORT] = "inspect", | |
98 | [TASK_READ_PORT] = "read", | |
99 | [TASK_SEATBELT_PORT] = "seatbelt", | |
100 | [TASK_ACCESS_PORT] = "access", | |
101 | [TASK_DEBUG_CONTROL_PORT] = "debug control", | |
102 | [TASK_RESOURCE_NOTIFY_PORT] = "resource notify", | |
103 | }; | |
104 | _Static_assert(TASK_RESOURCE_NOTIFY_PORT == TASK_MAX_SPECIAL_PORT, | |
105 | "all task special ports must have descriptions"); | |
106 | ||
107 | return tsp_descs[port_index]; | |
108 | } | |
109 | ||
110 | const char * | |
111 | mach_thread_special_port_description(int port) | |
112 | { | |
113 | int port_index = (int)port; | |
114 | ||
115 | if (port_index < 0 || port_index > THREAD_MAX_SPECIAL_PORT) { | |
116 | return NULL; | |
117 | } | |
118 | ||
119 | static const char *tsp_descs[] = { | |
120 | [THREAD_KERNEL_PORT] = "kernel", | |
121 | [THREAD_INSPECT_PORT] = "inspect", | |
122 | [THREAD_READ_PORT] = "read", | |
123 | }; | |
124 | _Static_assert(THREAD_READ_PORT == THREAD_MAX_SPECIAL_PORT, | |
125 | "all thread special ports must have descriptions"); | |
126 | ||
127 | return tsp_descs[port_index]; | |
128 | } | |
129 | ||
130 | static int | |
131 | port_for_id_internal(const char *id, const char **ids, int nids) | |
132 | { | |
133 | if (!id) { | |
134 | errno = EINVAL; | |
135 | return -1; | |
136 | } | |
137 | ||
138 | for (int i = 0; i < nids; i++) { | |
139 | if (ids[i] && strcmp(ids[i], id) == 0) { | |
140 | return i; | |
141 | } | |
142 | } | |
143 | ||
144 | errno = ENOENT; | |
145 | return -1; | |
146 | } | |
147 | ||
148 | int | |
149 | mach_host_special_port_for_id(const char *id) | |
150 | { | |
151 | static const char *hsp_ids[] = { | |
152 | #define SP_ENTRY(id) [id] = #id | |
153 | SP_ENTRY(HOST_PORT), | |
154 | SP_ENTRY(HOST_PRIV_PORT), | |
155 | SP_ENTRY(HOST_IO_MASTER_PORT), | |
156 | SP_ENTRY(HOST_DYNAMIC_PAGER_PORT), | |
157 | SP_ENTRY(HOST_AUDIT_CONTROL_PORT), | |
158 | SP_ENTRY(HOST_USER_NOTIFICATION_PORT), | |
159 | SP_ENTRY(HOST_AUTOMOUNTD_PORT), | |
160 | SP_ENTRY(HOST_LOCKD_PORT), | |
161 | SP_ENTRY(HOST_KTRACE_BACKGROUND_PORT), | |
162 | SP_ENTRY(HOST_SEATBELT_PORT), | |
163 | SP_ENTRY(HOST_KEXTD_PORT), | |
164 | SP_ENTRY(HOST_LAUNCHCTL_PORT), | |
165 | SP_ENTRY(HOST_UNFREED_PORT), | |
166 | SP_ENTRY(HOST_AMFID_PORT), | |
167 | SP_ENTRY(HOST_GSSD_PORT), | |
168 | SP_ENTRY(HOST_TELEMETRY_PORT), | |
169 | SP_ENTRY(HOST_ATM_NOTIFICATION_PORT), | |
170 | SP_ENTRY(HOST_COALITION_PORT), | |
171 | SP_ENTRY(HOST_SYSDIAGNOSE_PORT), | |
172 | SP_ENTRY(HOST_XPC_EXCEPTION_PORT), | |
173 | SP_ENTRY(HOST_CONTAINERD_PORT), | |
174 | SP_ENTRY(HOST_NODE_PORT), | |
175 | SP_ENTRY(HOST_RESOURCE_NOTIFY_PORT), | |
176 | SP_ENTRY(HOST_CLOSURED_PORT), | |
177 | SP_ENTRY(HOST_SYSPOLICYD_PORT), | |
178 | SP_ENTRY(HOST_FILECOORDINATIOND_PORT), | |
179 | }; | |
180 | ||
181 | return port_for_id_internal(id, hsp_ids, | |
182 | sizeof(hsp_ids) / sizeof(hsp_ids[0])); | |
183 | } | |
184 | ||
185 | int | |
186 | mach_task_special_port_for_id(const char *id) | |
187 | { | |
188 | static const char *tsp_ids[] = { | |
189 | SP_ENTRY(TASK_KERNEL_PORT), | |
190 | SP_ENTRY(TASK_HOST_PORT), | |
191 | SP_ENTRY(TASK_NAME_PORT), | |
192 | SP_ENTRY(TASK_BOOTSTRAP_PORT), | |
193 | SP_ENTRY(TASK_INSPECT_PORT), | |
194 | SP_ENTRY(TASK_READ_PORT), | |
195 | SP_ENTRY(TASK_SEATBELT_PORT), | |
196 | SP_ENTRY(TASK_ACCESS_PORT), | |
197 | SP_ENTRY(TASK_DEBUG_CONTROL_PORT), | |
198 | SP_ENTRY(TASK_RESOURCE_NOTIFY_PORT), | |
199 | }; | |
200 | ||
201 | return port_for_id_internal(id, tsp_ids, | |
202 | sizeof(tsp_ids) / sizeof(tsp_ids[0])); | |
203 | } | |
204 | ||
205 | int | |
206 | mach_thread_special_port_for_id(const char *id) | |
207 | { | |
208 | static const char *tsp_ids[] = { | |
209 | SP_ENTRY(THREAD_KERNEL_PORT), | |
210 | SP_ENTRY(THREAD_INSPECT_PORT), | |
211 | SP_ENTRY(THREAD_READ_PORT), | |
212 | #undef SP_ENTRY | |
213 | }; | |
214 | ||
215 | return port_for_id_internal(id, tsp_ids, | |
216 | sizeof(tsp_ids) / sizeof(tsp_ids[0])); | |
217 | } |