-
Notifications
You must be signed in to change notification settings - Fork 3
/
krw_daemonUser.h
419 lines (370 loc) · 9.12 KB
/
krw_daemonUser.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
#ifndef _kernrw_daemon_user_
#define _kernrw_daemon_user_
/* Module kernrw_daemon */
#include <string.h>
#include <mach/ndr.h>
#include <mach/boolean.h>
#include <mach/kern_return.h>
#include <mach/notify.h>
#include <mach/mach_types.h>
#include <mach/message.h>
#include <mach/mig_errors.h>
#include <mach/port.h>
/* BEGIN VOUCHER CODE */
#ifndef KERNEL
#if defined(__has_include)
#if __has_include(<mach/mig_voucher_support.h>)
#ifndef USING_VOUCHERS
#define USING_VOUCHERS
#endif
#ifndef __VOUCHER_FORWARD_TYPE_DECLS__
#define __VOUCHER_FORWARD_TYPE_DECLS__
#ifdef __cplusplus
extern "C" {
#endif
extern boolean_t voucher_mach_msg_set(mach_msg_header_t *msg) __attribute__((weak_import));
#ifdef __cplusplus
}
#endif
#endif // __VOUCHER_FORWARD_TYPE_DECLS__
#endif // __has_include(<mach/mach_voucher_types.h>)
#endif // __has_include
#endif // !KERNEL
/* END VOUCHER CODE */
/* BEGIN MIG_STRNCPY_ZEROFILL CODE */
#if defined(__has_include)
#if __has_include(<mach/mig_strncpy_zerofill_support.h>)
#ifndef USING_MIG_STRNCPY_ZEROFILL
#define USING_MIG_STRNCPY_ZEROFILL
#endif
#ifndef __MIG_STRNCPY_ZEROFILL_FORWARD_TYPE_DECLS__
#define __MIG_STRNCPY_ZEROFILL_FORWARD_TYPE_DECLS__
#ifdef __cplusplus
extern "C" {
#endif
extern int mig_strncpy_zerofill(char *dest, const char *src, int len) __attribute__((weak_import));
#ifdef __cplusplus
}
#endif
#endif /* __MIG_STRNCPY_ZEROFILL_FORWARD_TYPE_DECLS__ */
#endif /* __has_include(<mach/mig_strncpy_zerofill_support.h>) */
#endif /* __has_include */
/* END MIG_STRNCPY_ZEROFILL CODE */
#ifdef AUTOTEST
#ifndef FUNCTION_PTR_T
#define FUNCTION_PTR_T
typedef void (*function_ptr_t)(mach_port_t, char *, mach_msg_type_number_t);
typedef struct {
char *name;
function_ptr_t function;
} function_table_entry;
typedef function_table_entry *function_table_t;
#endif /* FUNCTION_PTR_T */
#endif /* AUTOTEST */
#ifndef kernrw_daemon_MSG_COUNT
#define kernrw_daemon_MSG_COUNT 7
#endif /* kernrw_daemon_MSG_COUNT */
#include <mach/std_types.h>
#include <mach/mig.h>
#include <mach/mig.h>
#include <mach/mach_types.h>
#ifdef __BeforeMigUserHeader
__BeforeMigUserHeader
#endif /* __BeforeMigUserHeader */
#include <sys/cdefs.h>
__BEGIN_DECLS
/* Routine read32 */
#ifdef mig_external
mig_external
#else
extern
#endif /* mig_external */
kern_return_t krw_read32
(
mach_port_t server_port,
uint64_t kaddr,
uint32_t *val
);
/* Routine read64 */
#ifdef mig_external
mig_external
#else
extern
#endif /* mig_external */
kern_return_t krw_read64
(
mach_port_t server_port,
uint64_t kaddr,
uint64_t *val
);
/* Routine write32 */
#ifdef mig_external
mig_external
#else
extern
#endif /* mig_external */
kern_return_t krw_write32
(
mach_port_t server_port,
uint64_t kaddr,
uint32_t val
);
/* Routine write64 */
#ifdef mig_external
mig_external
#else
extern
#endif /* mig_external */
kern_return_t krw_write64
(
mach_port_t server_port,
uint64_t kaddr,
uint64_t val
);
/* Routine kernelBase */
#ifdef mig_external
mig_external
#else
extern
#endif /* mig_external */
kern_return_t krw_kernelBase
(
mach_port_t server_port,
uint64_t *val
);
/* Routine kernelProc */
#ifdef mig_external
mig_external
#else
extern
#endif /* mig_external */
kern_return_t krw_kernelProc
(
mach_port_t server_port,
uint64_t *val
);
/* Routine allProc */
#ifdef mig_external
mig_external
#else
extern
#endif /* mig_external */
kern_return_t krw_allProc
(
mach_port_t server_port,
uint64_t *val
);
__END_DECLS
/********************** Caution **************************/
/* The following data types should be used to calculate */
/* maximum message sizes only. The actual message may be */
/* smaller, and the position of the arguments within the */
/* message layout may vary from what is presented here. */
/* For example, if any of the arguments are variable- */
/* sized, and less than the maximum is sent, the data */
/* will be packed tight in the actual message to reduce */
/* the presence of holes. */
/********************** Caution **************************/
/* typedefs for all requests */
#ifndef __Request__kernrw_daemon_subsystem__defined
#define __Request__kernrw_daemon_subsystem__defined
#ifdef __MigPackStructs
#pragma pack(push, 4)
#endif
typedef struct {
mach_msg_header_t Head;
NDR_record_t NDR;
uint64_t kaddr;
} __Request__read32_t __attribute__((unused));
#ifdef __MigPackStructs
#pragma pack(pop)
#endif
#ifdef __MigPackStructs
#pragma pack(push, 4)
#endif
typedef struct {
mach_msg_header_t Head;
NDR_record_t NDR;
uint64_t kaddr;
} __Request__read64_t __attribute__((unused));
#ifdef __MigPackStructs
#pragma pack(pop)
#endif
#ifdef __MigPackStructs
#pragma pack(push, 4)
#endif
typedef struct {
mach_msg_header_t Head;
NDR_record_t NDR;
uint64_t kaddr;
uint32_t val;
} __Request__write32_t __attribute__((unused));
#ifdef __MigPackStructs
#pragma pack(pop)
#endif
#ifdef __MigPackStructs
#pragma pack(push, 4)
#endif
typedef struct {
mach_msg_header_t Head;
NDR_record_t NDR;
uint64_t kaddr;
uint64_t val;
} __Request__write64_t __attribute__((unused));
#ifdef __MigPackStructs
#pragma pack(pop)
#endif
#ifdef __MigPackStructs
#pragma pack(push, 4)
#endif
typedef struct {
mach_msg_header_t Head;
} __Request__kernelBase_t __attribute__((unused));
#ifdef __MigPackStructs
#pragma pack(pop)
#endif
#ifdef __MigPackStructs
#pragma pack(push, 4)
#endif
typedef struct {
mach_msg_header_t Head;
} __Request__kernelProc_t __attribute__((unused));
#ifdef __MigPackStructs
#pragma pack(pop)
#endif
#ifdef __MigPackStructs
#pragma pack(push, 4)
#endif
typedef struct {
mach_msg_header_t Head;
} __Request__allProc_t __attribute__((unused));
#ifdef __MigPackStructs
#pragma pack(pop)
#endif
#endif /* !__Request__kernrw_daemon_subsystem__defined */
/* union of all requests */
#ifndef __RequestUnion__krw_kernrw_daemon_subsystem__defined
#define __RequestUnion__krw_kernrw_daemon_subsystem__defined
union __RequestUnion__krw_kernrw_daemon_subsystem {
__Request__read32_t Request_krw_read32;
__Request__read64_t Request_krw_read64;
__Request__write32_t Request_krw_write32;
__Request__write64_t Request_krw_write64;
__Request__kernelBase_t Request_krw_kernelBase;
__Request__kernelProc_t Request_krw_kernelProc;
__Request__allProc_t Request_krw_allProc;
};
#endif /* !__RequestUnion__krw_kernrw_daemon_subsystem__defined */
/* typedefs for all replies */
#ifndef __Reply__kernrw_daemon_subsystem__defined
#define __Reply__kernrw_daemon_subsystem__defined
#ifdef __MigPackStructs
#pragma pack(push, 4)
#endif
typedef struct {
mach_msg_header_t Head;
NDR_record_t NDR;
kern_return_t RetCode;
uint32_t val;
} __Reply__read32_t __attribute__((unused));
#ifdef __MigPackStructs
#pragma pack(pop)
#endif
#ifdef __MigPackStructs
#pragma pack(push, 4)
#endif
typedef struct {
mach_msg_header_t Head;
NDR_record_t NDR;
kern_return_t RetCode;
uint64_t val;
} __Reply__read64_t __attribute__((unused));
#ifdef __MigPackStructs
#pragma pack(pop)
#endif
#ifdef __MigPackStructs
#pragma pack(push, 4)
#endif
typedef struct {
mach_msg_header_t Head;
NDR_record_t NDR;
kern_return_t RetCode;
} __Reply__write32_t __attribute__((unused));
#ifdef __MigPackStructs
#pragma pack(pop)
#endif
#ifdef __MigPackStructs
#pragma pack(push, 4)
#endif
typedef struct {
mach_msg_header_t Head;
NDR_record_t NDR;
kern_return_t RetCode;
} __Reply__write64_t __attribute__((unused));
#ifdef __MigPackStructs
#pragma pack(pop)
#endif
#ifdef __MigPackStructs
#pragma pack(push, 4)
#endif
typedef struct {
mach_msg_header_t Head;
NDR_record_t NDR;
kern_return_t RetCode;
uint64_t val;
} __Reply__kernelBase_t __attribute__((unused));
#ifdef __MigPackStructs
#pragma pack(pop)
#endif
#ifdef __MigPackStructs
#pragma pack(push, 4)
#endif
typedef struct {
mach_msg_header_t Head;
NDR_record_t NDR;
kern_return_t RetCode;
uint64_t val;
} __Reply__kernelProc_t __attribute__((unused));
#ifdef __MigPackStructs
#pragma pack(pop)
#endif
#ifdef __MigPackStructs
#pragma pack(push, 4)
#endif
typedef struct {
mach_msg_header_t Head;
NDR_record_t NDR;
kern_return_t RetCode;
uint64_t val;
} __Reply__allProc_t __attribute__((unused));
#ifdef __MigPackStructs
#pragma pack(pop)
#endif
#endif /* !__Reply__kernrw_daemon_subsystem__defined */
/* union of all replies */
#ifndef __ReplyUnion__krw_kernrw_daemon_subsystem__defined
#define __ReplyUnion__krw_kernrw_daemon_subsystem__defined
union __ReplyUnion__krw_kernrw_daemon_subsystem {
__Reply__read32_t Reply_krw_read32;
__Reply__read64_t Reply_krw_read64;
__Reply__write32_t Reply_krw_write32;
__Reply__write64_t Reply_krw_write64;
__Reply__kernelBase_t Reply_krw_kernelBase;
__Reply__kernelProc_t Reply_krw_kernelProc;
__Reply__allProc_t Reply_krw_allProc;
};
#endif /* !__RequestUnion__krw_kernrw_daemon_subsystem__defined */
#ifndef subsystem_to_name_map_kernrw_daemon
#define subsystem_to_name_map_kernrw_daemon \
{ "read32", 600 },\
{ "read64", 601 },\
{ "write32", 602 },\
{ "write64", 603 },\
{ "kernelBase", 604 },\
{ "kernelProc", 605 },\
{ "allProc", 606 }
#endif
#ifdef __AfterMigUserHeader
__AfterMigUserHeader
#endif /* __AfterMigUserHeader */
#endif /* _kernrw_daemon_user_ */