Loading...
  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
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
;	derived from: FreeBSD @(#)syscalls.master	8.2 (Berkeley) 1/13/94
;
; System call name/number master file.
; This is file processed by .../xnu/bsd/kern/makesyscalls.sh and creates:
;	.../xnu/bsd/kern/init_sysent.c 
;	.../xnu/bsd/kern/syscalls.c 
;	.../xnu/bsd/sys/syscall.h 
;	.../xnu/bsd/sys/sysproto.h 

; Columns -> | Number Files | { Name and Args } | { Comments }
;	Number:  	system call number, must be in order
;	Files:		with files to generate - "ALL" or any combo of:
;					"T" for syscall table (in init_sysent.c)
;					"N" for syscall names (in syscalls.c)
;					"H" for syscall headers (in syscall.h)
;					"P" for syscall prototypes (in sysproto.h)
;	Name and Args:	function prototype, optionally followed by
;			NO_SYSCALL_STUB (which mean no system call stub will
;			be generated in libSystem) and ending with a semicolon.
;			(Note: functions prefixed by double-underbar are
;			automatically given the NO_SYSCALL_STUB attribute.)
;	Comments:  	additional comments about the sys call copied to output files

; #ifdef's, #include's, #if's etc. are copied to all output files.
; N.B.: makesyscalls.sh and createsyscalls.pl must be updated to account
; for any new argument types.

#include <sys/appleapiopts.h>
#include <sys/param.h>
#include <sys/systm.h>
#include <sys/types.h>
#include <sys/sysent.h>
#include <sys/sysproto.h>

0	ALL	{ int nosys(void); }   { indirect syscall }
1	ALL	{ void exit(int rval); } 
2	ALL	{ int fork(void); } 
3	ALL	{ user_ssize_t read(int fd, user_addr_t cbuf, user_size_t nbyte); } 
4	ALL	{ user_ssize_t write(int fd, user_addr_t cbuf, user_size_t nbyte); } 
5	ALL	{ int open(user_addr_t path, int flags, int mode); } 
6	ALL	{ int close(int fd); } 
7	ALL	{ int wait4(int pid, user_addr_t status, int options, user_addr_t rusage); } 
8	ALL	{ int nosys(void); }   { old creat }
9	ALL	{ int link(user_addr_t path, user_addr_t link); } 
10	ALL	{ int unlink(user_addr_t path); } 
11	ALL	{ int nosys(void); }   { old execv }
12	ALL	{ int chdir(user_addr_t path); } 
13	ALL	{ int fchdir(int fd); } 
14	ALL	{ int mknod(user_addr_t path, int mode, int dev); } 
15	ALL	{ int chmod(user_addr_t path, int mode); } 
16	ALL	{ int chown(user_addr_t path, int uid, int gid); } 
17	UALL	{ int obreak(char *nsize) NO_SYSCALL_STUB; }   { old break }

#if COMPAT_GETFSSTAT
18	ALL	{ int ogetfsstat(user_addr_t buf, int bufsize, int flags); } 
#else
18	ALL	{ int getfsstat(user_addr_t buf, int bufsize, int flags); } 
#endif

19	ALL	{ int nosys(void); }   { old lseek }
20	ALL	{ int getpid(void); } 
21	ALL	{ int nosys(void); }   { old mount }
22	ALL	{ int nosys(void); }   { old umount }
23	ALL	{ int setuid(uid_t uid); } 
24	ALL	{ int getuid(void); } 
25	ALL	{ int geteuid(void); } 
26	ALL	{ int ptrace(int req, pid_t pid, caddr_t addr, int data); } 
#if SOCKETS
27	ALL	{ int recvmsg(int s, struct msghdr *msg, int flags); } 
28	ALL	{ int sendmsg(int s, caddr_t msg, int flags); } 
29	ALL	{ int recvfrom(int s, void *buf, size_t len, int flags, struct sockaddr *from, int *fromlenaddr); } 
30	ALL	{ int accept(int s, caddr_t name, socklen_t	*anamelen); } 
31	ALL	{ int getpeername(int fdes, caddr_t asa, socklen_t *alen); } 
32	ALL	{ int getsockname(int fdes, caddr_t asa, socklen_t *alen); } 
#else
27	ALL	{ int nosys(void); }
28	ALL	{ int nosys(void); }
29	ALL	{ int nosys(void); }
30	ALL	{ int nosys(void); }
31	ALL	{ int nosys(void); }
32	ALL	{ int nosys(void); }
#endif /* SOCKETS */
33	ALL	{ int access(user_addr_t path, int flags); } 
34	ALL	{ int chflags(char *path, int flags); } 
35	ALL	{ int fchflags(int fd, int flags); } 
36	ALL	{ int sync(void); } 
37	ALL	{ int kill(int pid, int signum, int posix); } 
38	ALL	{ int nosys(void); }   { old stat  }
39	ALL	{ int getppid(void); } 
40	ALL	{ int nosys(void); }   { old lstat }
41	ALL	{ int dup(u_int fd); } 
42	ALL	{ int pipe(void); } 
43	ALL	{ int getegid(void); } 
44	ALL	{ int profil(short *bufbase, size_t bufsize, u_long pcoffset, u_int pcscale); } 
45	ALL	{ int nosys(void); } { old ktrace }
46	ALL	{ int sigaction(int signum, struct __sigaction *nsa, struct sigaction *osa); } 
47	ALL	{ int getgid(void); } 
48	ALL	{ int sigprocmask(int how, user_addr_t mask, user_addr_t omask); } 
49	ALL	{ int getlogin(char *namebuf, u_int namelen); } 
50	ALL	{ int setlogin(char *namebuf); } 
51	ALL	{ int acct(char *path); } 
52	ALL	{ int sigpending(struct sigvec *osv); } 
53	ALL	{ int sigaltstack(struct sigaltstack *nss, struct sigaltstack *oss); } 
54	ALL	{ int ioctl(int fd, u_long com, caddr_t data); } 
55	ALL	{ int reboot(int opt, char *command); } 
56	ALL	{ int revoke(char *path); } 
57	ALL	{ int symlink(char *path, char *link); } 
58	ALL	{ int readlink(char *path, char *buf, int count); } 
59	ALL	{ int execve(char *fname, char **argp, char **envp); } 
60	ALL	{ int umask(int newmask); } 
61	ALL	{ int chroot(user_addr_t path); } 
62	ALL	{ int nosys(void); }   { old fstat }
63	ALL	{ int nosys(void); }   { used internally, reserved }
64	ALL	{ int nosys(void); }   { old getpagesize }
65	ALL	{ int msync(caddr_t addr, size_t len, int flags); } 
66	ALL	{ int vfork(void); } 
67	ALL	{ int nosys(void); }   { old vread }
68	ALL	{ int nosys(void); }   { old vwrite }
69	ALL	{ int sbrk(int incr) NO_SYSCALL_STUB; } 
70	ALL	{ int sstk(int incr) NO_SYSCALL_STUB; } 
71	ALL	{ int nosys(void); }   { old mmap }
72	ALL	{ int ovadvise(void) NO_SYSCALL_STUB; }   { old vadvise }
73	ALL	{ int munmap(caddr_t addr, size_t len); } 
74	ALL	{ int mprotect(caddr_t addr, size_t len, int prot); } 
75	ALL	{ int madvise(caddr_t addr, size_t len, int behav); } 
76	ALL	{ int nosys(void); }   { old vhangup }
77	ALL	{ int nosys(void); }   { old vlimit }
78	ALL	{ int mincore(user_addr_t addr, user_size_t len, user_addr_t vec); } 
79	ALL	{ int getgroups(u_int gidsetsize, gid_t *gidset); } 
80	ALL	{ int setgroups(u_int gidsetsize, gid_t *gidset); } 
81	ALL	{ int getpgrp(void); } 
82	ALL	{ int setpgid(int pid, int pgid); } 
83	ALL	{ int setitimer(u_int which, struct itimerval *itv, struct itimerval *oitv); } 
84	ALL	{ int nosys(void); }   { old wait }
85	ALL	{ int swapon(void); } 
86	ALL	{ int getitimer(u_int which, struct itimerval *itv); } 
87	ALL	{ int nosys(void); }   { old gethostname }
88	ALL	{ int nosys(void); }   { old sethostname }
89	ALL	{ int getdtablesize(void); } 
90	ALL	{ int dup2(u_int from, u_int to); } 
91	ALL	{ int nosys(void); }   { old getdopt }
92	ALL	{ int fcntl(int fd, int cmd, long arg); } 
93	ALL	{ int select(int nd, u_int32_t *in, u_int32_t *ou, u_int32_t *ex, struct timeval *tv); } 
94	ALL	{ int nosys(void); }   { old setdopt }
95	ALL	{ int fsync(int fd); } 
96	ALL	{ int setpriority(int which, id_t who, int prio); } 
#if SOCKETS
97	ALL	{ int socket(int domain, int type, int protocol); } 
98	ALL	{ int connect(int s, caddr_t name, socklen_t namelen); } 
#else
97	ALL	{ int nosys(void); }
98	ALL	{ int nosys(void); }
#endif /* SOCKETS */
99	ALL	{ int nosys(void); }   { old accept }
100	ALL	{ int getpriority(int which, id_t who); } 
101	ALL	{ int nosys(void); }   { old send }
102	ALL	{ int nosys(void); }   { old recv }
103	ALL	{ int nosys(void); }   { old sigreturn }
#if SOCKETS
104	ALL	{ int bind(int s, caddr_t name, socklen_t namelen); } 
105	ALL	{ int setsockopt(int s, int level, int name, caddr_t val, socklen_t valsize); } 
106	ALL	{ int listen(int s, int backlog); } 
#else
104	ALL	{ int nosys(void); }
105	ALL	{ int nosys(void); }
106	ALL	{ int nosys(void); }
#endif /* SOCKETS */
107	ALL	{ int nosys(void); }   { old vtimes }
108	ALL	{ int nosys(void); }   { old sigvec }
109	ALL	{ int nosys(void); }   { old sigblock }
110	ALL	{ int nosys(void); }   { old sigsetmask }
111	ALL	{ int sigsuspend(sigset_t mask); } 
112	ALL	{ int nosys(void); }   { old sigstack }
#if SOCKETS
113	ALL	{ int nosys(void); }   { old recvmsg }
114	ALL	{ int nosys(void); }   { old sendmsg }	
#else
113	ALL	{ int nosys(void); }
114	ALL	{ int nosys(void); }
#endif /* SOCKETS */
115	ALL	{ int nosys(void); }   { old vtrace }
116	ALL	{ int gettimeofday(struct timeval *tp, struct timezone *tzp); } 
117	ALL	{ int getrusage(int who, struct rusage *rusage); } 
#if SOCKETS
118	ALL	{ int getsockopt(int s, int level, int name, caddr_t val, socklen_t *avalsize); } 
#else
118	ALL	{ int nosys(void); }
#endif /* SOCKETS */
119	ALL	{ int nosys(void); }   { old resuba }
120	ALL	{ user_ssize_t readv(int fd, struct iovec *iovp, u_int iovcnt); } 
121	ALL	{ user_ssize_t writev(int fd, struct iovec *iovp, u_int iovcnt); } 
122	ALL	{ int settimeofday(struct timeval *tv, struct timezone *tzp); } 
123	ALL	{ int fchown(int fd, int uid, int gid); } 
124	ALL	{ int fchmod(int fd, int mode); } 
125	ALL	{ int nosys(void); }   { old recvfrom }
126	ALL	{ int setreuid(uid_t ruid, uid_t euid); }
127	ALL	{ int setregid(gid_t rgid, gid_t egid); }
128	ALL	{ int rename(char *from, char *to); } 
129	ALL	{ int nosys(void); }   { old truncate }
130	ALL	{ int nosys(void); }   { old ftruncate }
131	ALL	{ int flock(int fd, int how); } 
132	ALL	{ int mkfifo(user_addr_t path, int mode); } 
#if SOCKETS
133	ALL	{ int sendto(int s, caddr_t buf, size_t len, int flags, caddr_t to, socklen_t tolen); } 
134	ALL	{ int shutdown(int s, int how); } 
135	ALL	{ int socketpair(int domain, int type, int protocol, int *rsv); } 
#else
133	ALL	{ int nosys(void); }
134	ALL	{ int nosys(void); }
135	ALL	{ int nosys(void); }
#endif /* SOCKETS */
136	ALL	{ int mkdir(user_addr_t path, int mode); } 
137	ALL	{ int rmdir(char *path); } 
138	ALL	{ int utimes(char *path, struct timeval *tptr); } 
139	ALL	{ int futimes(int fd, struct timeval *tptr); } 
140	ALL	{ int adjtime(struct timeval *delta, struct timeval *olddelta); } 
141	ALL	{ int nosys(void); }   { old getpeername }
142	ALL	{ int gethostuuid(unsigned char *uuid_buf, const struct timespec *timeoutp); }
143	ALL	{ int nosys(void); }   { old sethostid 	}
144	ALL	{ int nosys(void); }   { old getrlimit }
145	ALL	{ int nosys(void); }   { old setrlimit }
146	ALL	{ int nosys(void); }   { old killpg }
147	ALL	{ int setsid(void); } 
148	ALL	{ int nosys(void); }   { old setquota }
149	ALL	{ int nosys(void); }   { old qquota }
150	ALL	{ int nosys(void); }   { old getsockname }
151	ALL	{ int getpgid(pid_t pid); } 
152	ALL	{ int setprivexec(int flag); } 
153	ALL	{ user_ssize_t pread(int fd, user_addr_t buf, user_size_t nbyte, off_t offset); } 
154	ALL	{ user_ssize_t pwrite(int fd, user_addr_t buf, user_size_t nbyte, off_t offset); } 

#if NFSSERVER
155	ALL	{ int nfssvc(int flag, caddr_t argp); } 
#else
155	ALL	{ int nosys(void); } 
#endif

156	ALL	{ int nosys(void); }   { old getdirentries }
157	ALL	{ int statfs(char *path, struct statfs *buf); } 
158	ALL	{ int fstatfs(int fd, struct statfs *buf); } 
159	ALL	{ int unmount(user_addr_t path, int flags); } 
160	ALL	{ int nosys(void); }   { old async_daemon }

#if NFSSERVER
161	ALL	{ int getfh(char *fname, fhandle_t *fhp); } 
#else
161	ALL	{ int nosys(void); } 
#endif

162	ALL	{ int nosys(void); }   { old getdomainname }
163	ALL	{ int nosys(void); }   { old setdomainname }
164	ALL	{ int nosys(void); } 
165	ALL	{ int quotactl(const char *path, int cmd, int uid, caddr_t arg); } 
166	ALL	{ int nosys(void); }   { old exportfs }
167	ALL	{ int mount(char *type, char *path, int flags, caddr_t data); } 
168	ALL	{ int nosys(void); }   { old ustat }
169	ALL	{ int csops(pid_t pid, uint32_t ops, user_addr_t useraddr, user_size_t usersize); } 
170	HN	{ int table(void); }   { old table }
171	ALL	{ int nosys(void); }   { old wait3 }
172	ALL	{ int nosys(void); }   { old rpause	}	
173	ALL	{ int waitid(idtype_t idtype, id_t id, siginfo_t *infop, int options); } 
174	ALL	{ int nosys(void); }   { old getdents }
175	ALL	{ int nosys(void); }   { old gc_control }
176	ALL	{ int add_profil(short *bufbase, size_t bufsize, u_long pcoffset, u_int pcscale); } 
177	ALL	{ int nosys(void); } 
178	ALL	{ int nosys(void); } 
179	ALL	{ int nosys(void); } 
180	ALL 	{ int kdebug_trace(int code, int arg1, int arg2, int arg3, int arg4, int arg5) NO_SYSCALL_STUB; } 
181	ALL	{ int setgid(gid_t gid); } 
182	ALL	{ int setegid(gid_t egid); } 
183	ALL	{ int seteuid(uid_t euid); } 
184	ALL	{ int sigreturn(struct ucontext *uctx, int infostyle); } 
185	UALL 	{ int chud(int code, int arg1, int arg2, int arg3, int arg4, int arg5) NO_SYSCALL_STUB; } 
186	ALL	{ int nosys(void); } 
187	ALL	{ int nosys(void); } 
188	ALL	{ int stat(user_addr_t path, user_addr_t ub); } 
189	ALL	{ int fstat(int fd, user_addr_t ub); } 
190	ALL	{ int lstat(user_addr_t path, user_addr_t ub); } 
191	ALL	{ int pathconf(char *path, int name); } 
192	ALL	{ int fpathconf(int fd, int name); } 
193	ALL	{ int nosys(void); } 
194	ALL	{ int getrlimit(u_int which, struct rlimit *rlp); } 
195	ALL	{ int setrlimit(u_int which, struct rlimit *rlp); } 
196	ALL	{ int getdirentries(int fd, char *buf, u_int count, long *basep); } 
197	ALL	{ user_addr_t mmap(caddr_t addr, size_t len, int prot, int flags, int fd, off_t pos); } 
198	ALL	{ int nosys(void); } 	{ __syscall }
199	ALL	{ off_t lseek(int fd, off_t offset, int whence); } 
200	ALL	{ int truncate(char *path, off_t length); } 
201	ALL	{ int ftruncate(int fd, off_t length); } 
202	ALL 	{ int __sysctl(int *name, u_int namelen, void *old, size_t *oldlenp, void *new, size_t newlen); } 
203	ALL	{ int mlock(caddr_t addr, size_t len); } 
204	ALL	{ int munlock(caddr_t addr, size_t len); } 
205	ALL	{ int undelete(user_addr_t path); } 

#if NETAT
206	ALL	{ int ATsocket(int proto); } 
207	UALL	{ int ATgetmsg(int fd, void *ctlptr, void *datptr, int *flags); } 
208	UALL	{ int ATputmsg(int fd, void *ctlptr, void *datptr, int flags); } 
209	UALL	{ int ATPsndreq(int fd, unsigned char *buf, int len, int nowait); } 
210	UALL	{ int ATPsndrsp(int fd, unsigned char *respbuff, int resplen, int datalen); } 
211	UALL	{ int ATPgetreq(int fd, unsigned char *buf, int buflen); } 
212	UALL	{ int ATPgetrsp(int fd, unsigned char *bdsp); } 
213	ALL	{ int nosys(void); } 	{ Reserved for AppleTalk }
#else
206	ALL	{ int nosys(void); }
207	ALL	{ int nosys(void); }
208	ALL	{ int nosys(void); }
209	ALL	{ int nosys(void); }
210	ALL	{ int nosys(void); }
211	ALL	{ int nosys(void); }
212	ALL	{ int nosys(void); }
213	ALL	{ int nosys(void); } 	{ Reserved for AppleTalk }
#endif /* NETAT */

214	ALL	{ int kqueue_from_portset_np(int portset); } 
215	ALL	{ int kqueue_portset_np(int fd); } 

; System Calls 216 - 230 are reserved for calls to support HFS/HFS Plus
; file system semantics. Currently, we only use 215-227.  The rest is 
; for future expansion in anticipation of new MacOS APIs for HFS Plus.
; These calls are not conditionalized because while they are specific
; to HFS semantics, they are not specific to the HFS filesystem.
; We expect all filesystems to recognize the call and report that it is
; not supported or to actually implement it.
216	UHN	{ int mkcomplex(const char *path, mode_t mode, u_long type); } 	{ soon to be obsolete }
217	UHN	{ int statv(const char *path, struct vstat *vsb); } 	{ soon to be obsolete }
218	UHN	{ int lstatv(const char *path, struct vstat *vsb); } 	{ soon to be obsolete }
219	UHN	{ int fstatv(int fd, struct vstat *vsb); } 	{ soon to be obsolete }
220	ALL	{ int getattrlist(const char *path, struct attrlist *alist, void *attributeBuffer, size_t bufferSize, u_long options); } 
221	ALL	{ int setattrlist(const char *path, struct attrlist *alist, void *attributeBuffer, size_t bufferSize, u_long options); } 
222	ALL	{ int getdirentriesattr(int fd, struct attrlist *alist, void *buffer, size_t buffersize, u_long *count, u_long *basep, u_long *newstate, u_long options); } 
223	ALL	{ int exchangedata(const char *path1, const char *path2, u_long options); } 
224	ALL	{ int nosys(void); } { was checkuseraccess }
225	ALL	{ int searchfs(const char *path, struct fssearchblock *searchblock, u_long *nummatches, u_long scriptcode, u_long options, struct searchstate *state); } 
226	ALL	{ int delete(user_addr_t path) NO_SYSCALL_STUB; }       { private delete (Carbon semantics) }
227	ALL	{ int copyfile(char *from, char *to, int mode, int flags) NO_SYSCALL_STUB; } 
228	ALL	{ int nosys(void); } 
229	ALL	{ int nosys(void); } 
230	ALL	{ int poll(struct pollfd *fds, u_int nfds, int timeout); } 
231	ALL	{ int watchevent(struct eventreq *u_req, int u_eventmask); } 
232	ALL	{ int waitevent(struct eventreq *u_req, struct timeval *tv); } 
233	ALL	{ int modwatch(struct eventreq *u_req, int u_eventmask); } 
234	ALL	{ user_ssize_t getxattr(user_addr_t path, user_addr_t attrname, user_addr_t value, size_t size, uint32_t position, int options); } 
235	ALL	{ user_ssize_t fgetxattr(int fd, user_addr_t attrname, user_addr_t value, size_t size, uint32_t position, int options); } 
236	ALL	{ int setxattr(user_addr_t path, user_addr_t attrname, user_addr_t value, size_t size, uint32_t position, int options); } 
237	ALL	{ int fsetxattr(int fd, user_addr_t attrname, user_addr_t value, size_t size, uint32_t position, int options); } 
238	ALL	{ int removexattr(user_addr_t path, user_addr_t attrname, int options); } 
239	ALL	{ int fremovexattr(int fd, user_addr_t attrname, int options); } 
240	ALL	{ user_ssize_t listxattr(user_addr_t path, user_addr_t namebuf, size_t bufsize, int options); } 
241	ALL	{ user_ssize_t flistxattr(int fd, user_addr_t namebuf, size_t bufsize, int options); } 
242	ALL	{ int fsctl(const char *path, u_long cmd, caddr_t data, u_long options); } 
243	ALL	{ int initgroups(u_int gidsetsize, gid_t *gidset, int gmuid); } 
244	ALL	{ int posix_spawn(pid_t *pid, const char *path, const struct _posix_spawn_args_desc *adesc, char **argv, char **envp); } 
245	ALL	{ int nosys(void); } 
246	ALL	{ int nosys(void); } 

#if NFSCLIENT
247	ALL	{ int nfsclnt(int flag, caddr_t argp); } 
#else
247	ALL	{ int nosys(void); } 
#endif
#if NFSSERVER
248	ALL	{ int fhopen(const struct fhandle *u_fhp, int flags); } 
#else
248	ALL	{ int nosys(void); } 
#endif

249	ALL	{ int nosys(void); } 
250	ALL	{ int minherit(void *addr, size_t len, int inherit); } 
#if SYSV_SEM
251	ALL	{ int semsys(u_int which, int a2, int a3, int a4, int a5); } 
#else
251	ALL	{ int nosys(void); } 
#endif
#if SYSV_MSG
252	ALL	{ int msgsys(u_int which, int a2, int a3, int a4, int a5); }
#else
252	ALL	{ int nosys(void); } 
#endif
#if SYSV_SHM
253	ALL	{ int shmsys(u_int which, int a2, int a3, int a4); } 
#else
253	ALL	{ int nosys(void); } 
#endif
#if SYSV_SEM
254	ALL	{ int semctl(int semid, int semnum, int cmd, semun_t arg); } 
255	ALL	{ int semget(key_t key, int	nsems, int semflg); } 
256	ALL	{ int semop(int semid, struct sembuf *sops, int nsops); } 
257	ALL	{ int nosys(void); } 
#else
254	ALL	{ int nosys(void); } 
255	ALL	{ int nosys(void); } 
256	ALL	{ int nosys(void); } 
257	ALL	{ int nosys(void); } 
#endif
#if SYSV_MSG
258	ALL	{ int msgctl(int msqid, int cmd, struct	msqid_ds *buf); } 
259	ALL	{ int msgget(key_t key, int msgflg); } 
260	ALL	{ int msgsnd(int msqid, void *msgp, size_t msgsz, int msgflg); } 
261	ALL	{ user_ssize_t msgrcv(int msqid, void *msgp, size_t msgsz, long msgtyp, int msgflg); } 
#else
258	ALL	{ int nosys(void); } 
259	ALL	{ int nosys(void); } 
260	ALL	{ int nosys(void); } 
261	ALL	{ int nosys(void); } 
#endif
#if SYSV_SHM
262	ALL	{ user_addr_t shmat(int shmid, void *shmaddr, int shmflg); } 
263	ALL	{ int shmctl(int shmid, int cmd, struct shmid_ds *buf); } 
264	ALL	{ int shmdt(void *shmaddr); } 
265	ALL	{ int shmget(key_t key, size_t size, int shmflg); } 
#else
262	ALL	{ int nosys(void); } 
263	ALL	{ int nosys(void); } 
264	ALL	{ int nosys(void); } 
265	ALL	{ int nosys(void); } 
#endif
266	ALL	{ int shm_open(const char *name, int oflag, int mode); } 
267	ALL	{ int shm_unlink(const char *name); } 
268	ALL	{ user_addr_t sem_open(const char *name, int oflag, int mode, int value); } 
269	ALL	{ int sem_close(sem_t *sem); } 
270	ALL	{ int sem_unlink(const char *name); } 
271	ALL	{ int sem_wait(sem_t *sem); } 
272	ALL	{ int sem_trywait(sem_t *sem); } 
273	ALL	{ int sem_post(sem_t *sem); } 
274	ALL	{ int sem_getvalue(sem_t *sem, int *sval); } 
275	ALL	{ int sem_init(sem_t *sem, int phsared, u_int value); } 
276	ALL	{ int sem_destroy(sem_t *sem); } 
277	ALL	{ int open_extended(user_addr_t path, int flags, uid_t uid, gid_t gid, int mode, user_addr_t xsecurity) NO_SYSCALL_STUB; } 
278	ALL	{ int umask_extended(int newmask, user_addr_t xsecurity) NO_SYSCALL_STUB; } 
279	ALL	{ int stat_extended(user_addr_t path, user_addr_t ub, user_addr_t xsecurity, user_addr_t xsecurity_size) NO_SYSCALL_STUB; } 
280	ALL	{ int lstat_extended(user_addr_t path, user_addr_t ub, user_addr_t xsecurity, user_addr_t xsecurity_size) NO_SYSCALL_STUB; } 
281	ALL	{ int fstat_extended(int fd, user_addr_t ub, user_addr_t xsecurity, user_addr_t xsecurity_size) NO_SYSCALL_STUB; } 
282	ALL	{ int chmod_extended(user_addr_t path, uid_t uid, gid_t gid, int mode, user_addr_t xsecurity) NO_SYSCALL_STUB; } 
283	ALL	{ int fchmod_extended(int fd, uid_t uid, gid_t gid, int mode, user_addr_t xsecurity) NO_SYSCALL_STUB; } 
284	ALL	{ int access_extended(user_addr_t entries, size_t size, user_addr_t results, uid_t uid) NO_SYSCALL_STUB; } 
285	ALL	{ int settid(uid_t uid, gid_t gid) NO_SYSCALL_STUB; } 
286	ALL	{ int gettid(uid_t *uidp, gid_t *gidp) NO_SYSCALL_STUB; } 
287	ALL	{ int setsgroups(int setlen, user_addr_t guidset) NO_SYSCALL_STUB; } 
288	ALL	{ int getsgroups(user_addr_t setlen, user_addr_t guidset) NO_SYSCALL_STUB; } 
289	ALL	{ int setwgroups(int setlen, user_addr_t guidset) NO_SYSCALL_STUB; } 
290	ALL	{ int getwgroups(user_addr_t setlen, user_addr_t guidset) NO_SYSCALL_STUB; }
291	ALL	{ int mkfifo_extended(user_addr_t path, uid_t uid, gid_t gid, int mode, user_addr_t xsecurity) NO_SYSCALL_STUB; } 
292	ALL	{ int mkdir_extended(user_addr_t path, uid_t uid, gid_t gid, int mode, user_addr_t xsecurity) NO_SYSCALL_STUB; } 
293	ALL	{ int identitysvc(int opcode, user_addr_t message) NO_SYSCALL_STUB; } 
294	ALL	{ int shared_region_check_np(uint64_t *start_address) NO_SYSCALL_STUB; }
295	ALL	{ int shared_region_map_np(int fd, uint32_t count, const struct shared_file_mapping_np *mappings) NO_SYSCALL_STUB; }
296	ALL	{ int nosys(void); } { old load_shared_file }
297	ALL	{ int nosys(void); } { old reset_shared_file }
298	ALL	{ int nosys(void); } { old new_system_shared_regions }
299	ALL	{ int enosys(void); } { old shared_region_map_file_np }
300	ALL	{ int enosys(void); } { old shared_region_make_private_np }
301	ALL	{ int __pthread_mutex_destroy(int mutexid); } 
302	ALL	{ int __pthread_mutex_init(user_addr_t  mutex, user_addr_t attr); } 
303	ALL	{ int __pthread_mutex_lock(int mutexid); } 
304	ALL	{ int __pthread_mutex_trylock(int mutexid); } 
305	ALL	{ int __pthread_mutex_unlock(int mutexid); } 
306	ALL	{ int __pthread_cond_init(user_addr_t cond, user_addr_t attr); } 
307	ALL	{ int __pthread_cond_destroy(int condid); } 
308	ALL	{ int __pthread_cond_broadcast(int condid); } 
309	ALL	{ int __pthread_cond_signal(int condid); } 
310	ALL	{ int getsid(pid_t pid); } 
311	ALL	{ int settid_with_pid(pid_t pid, int assume) NO_SYSCALL_STUB; } 
312	ALL	{ int __pthread_cond_timedwait(int condid, int mutexid, user_addr_t abstime); } 
313	ALL	{ int aio_fsync(int op, user_addr_t aiocbp); } 
314 	ALL	{ user_ssize_t aio_return(user_addr_t aiocbp); } 
315	ALL	{ int aio_suspend(user_addr_t aiocblist, int nent, user_addr_t timeoutp); } 
316	ALL	{ int aio_cancel(int fd, user_addr_t aiocbp); } 
317	ALL	{ int aio_error(user_addr_t aiocbp); } 
318	ALL	{ int aio_read(user_addr_t aiocbp); } 
319	ALL	{ int aio_write(user_addr_t aiocbp); } 
320	ALL	{ int lio_listio(int mode, user_addr_t aiocblist, int nent, user_addr_t sigp); } 
321	ALL	{ int __pthread_cond_wait(int condid, int mutexid); } 
322	ALL	{ int iopolicysys(int cmd, void *arg) NO_SYSCALL_STUB; } 
323	ALL	{ int nosys(void); } 
324	ALL	{ int mlockall(int how); } 
325	ALL	{ int munlockall(int how); } 
326	ALL	{ int nosys(void); } 
327	ALL	{ int issetugid(void); } 
328	ALL	{ int __pthread_kill(int thread_port, int sig); } 
329	ALL	{ int __pthread_sigmask(int how, user_addr_t set, user_addr_t oset); } 
330	ALL	{ int __sigwait(user_addr_t set, user_addr_t sig); } 
331	ALL	{ int __disable_threadsignal(int value); } 
332	ALL	{ int __pthread_markcancel(int thread_port); } 
333	ALL	{ int __pthread_canceled(int  action); } 
334	ALL	{ int __semwait_signal(int cond_sem, int mutex_sem, int timeout, int relative, time_t tv_sec, int32_t tv_nsec); } 
335	ALL	{ int nosys(void); }   { old utrace }
336	ALL	{ int proc_info(int32_t callnum,int32_t pid,uint32_t flavor, uint64_t arg,user_addr_t buffer,int32_t buffersize) NO_SYSCALL_STUB; } 
#if SENDFILE
337	ALL	{ int sendfile(int fd, int s, off_t offset, off_t *nbytes, struct sf_hdtr *hdtr, int flags); } 
#else /* !SENDFILE */
337	ALL	{ int nosys(void); }
#endif /* SENDFILE */
338	ALL	{ int stat64(user_addr_t path, user_addr_t ub); } 
339	ALL	{ int fstat64(int fd, user_addr_t ub); } 
340	ALL	{ int lstat64(user_addr_t path, user_addr_t ub); } 
341	ALL	{ int stat64_extended(user_addr_t path, user_addr_t ub, user_addr_t xsecurity, user_addr_t xsecurity_size) NO_SYSCALL_STUB; } 
342	ALL	{ int lstat64_extended(user_addr_t path, user_addr_t ub, user_addr_t xsecurity, user_addr_t xsecurity_size) NO_SYSCALL_STUB; } 
343	ALL	{ int fstat64_extended(int fd, user_addr_t ub, user_addr_t xsecurity, user_addr_t xsecurity_size) NO_SYSCALL_STUB; } 
344	ALL	{ user_ssize_t getdirentries64(int fd, void *buf, user_size_t bufsize, off_t *position) NO_SYSCALL_STUB; } 
345	ALL	{ int statfs64(char *path, struct statfs64 *buf); } 
346	ALL	{ int fstatfs64(int fd, struct statfs64 *buf); } 
347	ALL	{ int getfsstat64(user_addr_t buf, int bufsize, int flags); } 
348	ALL	{ int __pthread_chdir(user_addr_t path); } 
349	ALL	{ int __pthread_fchdir(int fd); } 

#if AUDIT
350	ALL	{ int audit(void *record, int length); } 
351	ALL	{ int auditon(int cmd, void *data, int length); } 
352	ALL	{ int nosys(void); } 
353	ALL	{ int getauid(au_id_t *auid); } 
354	ALL	{ int setauid(au_id_t *auid); } 
355	ALL	{ int getaudit(struct auditinfo *auditinfo); } 
356	ALL	{ int setaudit(struct auditinfo *auditinfo); } 
357	ALL	{ int getaudit_addr(struct auditinfo_addr *auditinfo_addr, int length); } 
358	ALL	{ int setaudit_addr(struct auditinfo_addr *auditinfo_addr, int length); } 
359	ALL	{ int auditctl(char *path); } 
#else
350	ALL	{ int nosys(void); } 
351	ALL	{ int nosys(void); } 
352	ALL	{ int nosys(void); } 
353	ALL	{ int nosys(void); } 
354	ALL	{ int nosys(void); } 
355	ALL	{ int nosys(void); } 
356	ALL	{ int nosys(void); } 
357	ALL	{ int nosys(void); } 
358	ALL	{ int nosys(void); } 
359	ALL	{ int nosys(void); } 
#endif

360	ALL	{ user_addr_t bsdthread_create(user_addr_t func, user_addr_t func_arg, user_addr_t stack, user_addr_t pthread, uint32_t flags) NO_SYSCALL_STUB; } 
361	ALL	{ int bsdthread_terminate(user_addr_t stackaddr, size_t freesize, uint32_t port, uint32_t sem) NO_SYSCALL_STUB; } 
362	ALL	{ int kqueue(void); } 
363	ALL	{ int kevent(int fd, const struct kevent *changelist, int nchanges, struct kevent *eventlist, int nevents, const struct timespec *timeout); } 
364	ALL	{ int lchown(user_addr_t path, uid_t owner, gid_t group); }
365	ALL	{ int stack_snapshot(pid_t pid, user_addr_t tracebuf, uint32_t tracebuf_size, uint32_t options) NO_SYSCALL_STUB; }
366	ALL	{ int bsdthread_register(user_addr_t threadstart, user_addr_t wqthread, int pthsize) NO_SYSCALL_STUB; } 
367	ALL	{ int workq_open(void) NO_SYSCALL_STUB; }
368	ALL	{ int workq_ops(int options, user_addr_t item, int prio) NO_SYSCALL_STUB; }
369	ALL	{ int nosys(void); } 
370	ALL	{ int nosys(void); } 
371	ALL	{ int nosys(void); } 
372	ALL	{ int nosys(void); } 
373	ALL	{ int nosys(void); } 
374	ALL	{ int nosys(void); } 
375	ALL	{ int nosys(void); } 
376	ALL	{ int nosys(void); } 
377	ALL	{ int nosys(void); } 
378	ALL	{ int nosys(void); } 
379	ALL	{ int nosys(void); } 
380	ALL	{ int __mac_execve(char *fname, char **argp, char **envp, struct mac *mac_p); } 
381	ALL	{ int __mac_syscall(char *policy, int call, user_addr_t arg); } 
382	ALL	{ int __mac_get_file(char *path_p, struct mac *mac_p); } 
383	ALL	{ int __mac_set_file(char *path_p, struct mac *mac_p); } 
384	ALL	{ int __mac_get_link(char *path_p, struct mac *mac_p); } 
385	ALL	{ int __mac_set_link(char *path_p, struct mac *mac_p); } 
386	ALL	{ int __mac_get_proc(struct mac *mac_p); } 
387	ALL	{ int __mac_set_proc(struct mac *mac_p); } 
388	ALL	{ int __mac_get_fd(int fd, struct mac *mac_p); } 
389	ALL	{ int __mac_set_fd(int fd, struct mac *mac_p); } 
390	ALL	{ int __mac_get_pid(pid_t pid, struct mac *mac_p); } 
391	ALL	{ int __mac_get_lcid(pid_t lcid, struct mac *mac_p); }
392	ALL	{ int __mac_get_lctx(struct mac *mac_p); }
393	ALL	{ int __mac_set_lctx(struct mac *mac_p); }
394	ALL	{ int setlcid(pid_t pid, pid_t lcid) NO_SYSCALL_STUB; }
395	ALL	{ int getlcid(pid_t pid) NO_SYSCALL_STUB; }
396	ALL	{ user_ssize_t read_nocancel(int fd, user_addr_t cbuf, user_size_t nbyte) NO_SYSCALL_STUB; } 
397	ALL	{ user_ssize_t write_nocancel(int fd, user_addr_t cbuf, user_size_t nbyte) NO_SYSCALL_STUB; } 
398	ALL	{ int open_nocancel(user_addr_t path, int flags, int mode) NO_SYSCALL_STUB; } 
399	ALL	{ int close_nocancel(int fd) NO_SYSCALL_STUB; } 
400	ALL	{ int wait4_nocancel(int pid, user_addr_t status, int options, user_addr_t rusage) NO_SYSCALL_STUB; } 
#if SOCKETS
401	ALL	{ int recvmsg_nocancel(int s, struct msghdr *msg, int flags) NO_SYSCALL_STUB; } 
402	ALL	{ int sendmsg_nocancel(int s, caddr_t msg, int flags) NO_SYSCALL_STUB; } 
403	ALL	{ int recvfrom_nocancel(int s, void *buf, size_t len, int flags, struct sockaddr *from, int *fromlenaddr) NO_SYSCALL_STUB; } 
404	ALL	{ int accept_nocancel(int s, caddr_t name, socklen_t	*anamelen) NO_SYSCALL_STUB; } 
#else
401	ALL	{ int nosys(void); }
402	ALL	{ int nosys(void); }
403	ALL	{ int nosys(void); }
404	ALL	{ int nosys(void); }
#endif /* SOCKETS */
405	ALL	{ int msync_nocancel(caddr_t addr, size_t len, int flags) NO_SYSCALL_STUB; } 
406	ALL	{ int fcntl_nocancel(int fd, int cmd, long arg) NO_SYSCALL_STUB; } 
407	ALL	{ int select_nocancel(int nd, u_int32_t *in, u_int32_t *ou, u_int32_t *ex, struct timeval *tv) NO_SYSCALL_STUB; } 
408	ALL	{ int fsync_nocancel(int fd) NO_SYSCALL_STUB; } 
#if SOCKETS
409	ALL	{ int connect_nocancel(int s, caddr_t name, socklen_t namelen) NO_SYSCALL_STUB; } 
#else
409	ALL	{ int nosys(void); }
#endif /* SOCKETS */
410	ALL	{ int sigsuspend_nocancel(sigset_t mask) NO_SYSCALL_STUB; } 
411	ALL	{ user_ssize_t readv_nocancel(int fd, struct iovec *iovp, u_int iovcnt) NO_SYSCALL_STUB; } 
412	ALL	{ user_ssize_t writev_nocancel(int fd, struct iovec *iovp, u_int iovcnt) NO_SYSCALL_STUB; } 
#if SOCKETS
413	ALL	{ int sendto_nocancel(int s, caddr_t buf, size_t len, int flags, caddr_t to, socklen_t tolen) NO_SYSCALL_STUB; } 
#else
413	ALL	{ int nosys(void); }
#endif /* SOCKETS */
414	ALL	{ user_ssize_t pread_nocancel(int fd, user_addr_t buf, user_size_t nbyte, off_t offset) NO_SYSCALL_STUB; } 
415	ALL	{ user_ssize_t pwrite_nocancel(int fd, user_addr_t buf, user_size_t nbyte, off_t offset) NO_SYSCALL_STUB; } 
416	ALL	{ int waitid_nocancel(idtype_t idtype, id_t id, siginfo_t *infop, int options) NO_SYSCALL_STUB; } 
417	ALL	{ int poll_nocancel(struct pollfd *fds, u_int nfds, int timeout) NO_SYSCALL_STUB; } 
#if SYSV_MSG
418	ALL	{ int msgsnd_nocancel(int msqid, void *msgp, size_t msgsz, int msgflg) NO_SYSCALL_STUB; } 
419	ALL	{ user_ssize_t msgrcv_nocancel(int msqid, void *msgp, size_t msgsz, long msgtyp, int msgflg) NO_SYSCALL_STUB; } 
#else
418	ALL	{ int nosys(void); } 
419	ALL	{ int nosys(void); } 
#endif
420	ALL	{ int sem_wait_nocancel(sem_t *sem) NO_SYSCALL_STUB; } 
421	ALL	{ int aio_suspend_nocancel(user_addr_t aiocblist, int nent, user_addr_t timeoutp) NO_SYSCALL_STUB; } 
422	ALL	{ int __sigwait_nocancel(user_addr_t set, user_addr_t sig) NO_SYSCALL_STUB; } 
423	ALL	{ int __semwait_signal_nocancel(int cond_sem, int mutex_sem, int timeout, int relative, time_t tv_sec, int32_t tv_nsec) NO_SYSCALL_STUB; } 
424	ALL	{ int __mac_mount(char *type, char *path, int flags, caddr_t data, struct mac *mac_p); } 
425	ALL	{ int __mac_get_mount(char *path, struct mac *mac_p); } 
426	ALL	{ int __mac_getfsstat(user_addr_t buf, int bufsize, user_addr_t mac, int macsize, int flags); }